1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-23 19:23:23 +01:00

Change interface to MachineInstr::substituteValue to specify more precisely

which args can be substituted: defsOnly, defsAndUses or usesOnly.

llvm-svn: 7154
This commit is contained in:
Vikram S. Adve 2003-07-10 19:45:07 +00:00
parent 0b23c58179
commit 6aa3abf7fa
2 changed files with 23 additions and 8 deletions

View File

@ -646,7 +646,8 @@ public:
unsigned substituteValue(const Value* oldVal, Value* newVal,
bool defsOnly = true);
bool defsOnly, bool notDefsAndUses,
bool& someArgsWereIgnored);
void setOperandHi32(unsigned i) { operands[i].markHi32(); }
void setOperandLo32(unsigned i) { operands[i].markLo32(); }

View File

@ -153,29 +153,43 @@ MachineInstr::SetRegForImplicitRef(unsigned i, int regNum)
// Subsitute all occurrences of Value* oldVal with newVal in all operands
// and all implicit refs. If defsOnly == true, substitute defs only.
// and all implicit refs.
// If defsOnly == true, substitute defs only.
unsigned
MachineInstr::substituteValue(const Value* oldVal, Value* newVal, bool defsOnly)
MachineInstr::substituteValue(const Value* oldVal, Value* newVal,
bool defsOnly, bool notDefsAndUses,
bool& someArgsWereIgnored)
{
assert((defsOnly || !notDefsAndUses) &&
"notDefsAndUses is irrelevant if defsOnly == false.");
unsigned numSubst = 0;
// Subsitute operands
for (MachineInstr::val_op_iterator O = begin(), E = end(); O != E; ++O)
if (*O == oldVal)
if (!defsOnly || !O.isUseOnly())
if (!defsOnly ||
notDefsAndUses && O.isDefOnly() ||
!notDefsAndUses && !O.isUseOnly())
{
O.getMachineOperand().value = newVal;
++numSubst;
}
else
someArgsWereIgnored = true;
// Subsitute implicit refs
for (unsigned i=0, N=getNumImplicitRefs(); i < N; ++i)
if (getImplicitRef(i) == oldVal)
if (!defsOnly || !getImplicitOp(i).opIsUse())
if (!defsOnly ||
notDefsAndUses && getImplicitOp(i).opIsDefOnly() ||
!notDefsAndUses && !getImplicitOp(i).opIsUse())
{
getImplicitOp(i).value = newVal;
++numSubst;
}
else
someArgsWereIgnored = true;
return numSubst;
}
@ -191,10 +205,10 @@ static inline std::ostream&
OutputValue(std::ostream &os, const Value* val)
{
os << "(val ";
os << (void*) val; // print address always
if (val && val->hasName())
return os << val->getName() << ")";
else
return os << (void*) val << ")"; // print address only
os << " " << val->getName() << ")"; // print name also, if available
return os;
}
static inline void OutputReg(std::ostream &os, unsigned RegNo,