mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-12 17:32:19 +00:00
Add method MachineInstr::substituteValue() which substitutes
one Value with another one in all operands and implicit references of the machine instruction. Also add method MachineOperand::getVRegValueOrNull(). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3307 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e2a78e3186
commit
a7710518da
@ -106,6 +106,10 @@ public:
|
||||
opType == MO_PCRelativeDisp);
|
||||
return value;
|
||||
}
|
||||
inline Value* getVRegValueOrNull() const {
|
||||
return (opType == MO_VirtualRegister || opType == MO_CCRegister ||
|
||||
opType == MO_PCRelativeDisp)? value : NULL;
|
||||
}
|
||||
inline int getMachineRegNum() const {
|
||||
assert(opType == MO_MachineRegister);
|
||||
return regNum;
|
||||
@ -356,6 +360,10 @@ public:
|
||||
bool isDef=false,
|
||||
bool isDefAndUse=false);
|
||||
|
||||
unsigned substituteValue (const Value* oldVal,
|
||||
Value* newVal,
|
||||
bool defsOnly = true);
|
||||
|
||||
void setOperandHi32 (unsigned i);
|
||||
void setOperandLo32 (unsigned i);
|
||||
void setOperandHi64 (unsigned i);
|
||||
@ -390,12 +398,13 @@ public:
|
||||
public:
|
||||
typedef ValOpIterator<MITy, VTy> _Self;
|
||||
|
||||
inline VTy operator*() const { return MI->getOperand(i).getVRegValue(); }
|
||||
|
||||
const MachineOperand &getMachineOperand() const {
|
||||
return MI->getOperand(i);
|
||||
inline VTy operator*() const {
|
||||
return MI->getOperand(i).getVRegValue();
|
||||
}
|
||||
|
||||
const MachineOperand &getMachineOperand() const { return MI->getOperand(i);}
|
||||
MachineOperand &getMachineOperand() { return MI->getOperand(i);}
|
||||
|
||||
inline VTy operator->() const { return operator*(); }
|
||||
|
||||
inline bool isDef() const { return MI->getOperand(i).opIsDef(); }
|
||||
|
Loading…
x
Reference in New Issue
Block a user