aboutsummaryrefslogtreecommitdiffstats
path: root/include/llvm/CodeGen/MachineInstrBuilder.h
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-06-25 01:16:22 +0000
committerChris Lattner <sabre@nondot.org>2009-06-25 01:16:22 +0000
commit9a96c425db72bc6e879e8445e3a3bf1f1e556b56 (patch)
treeb56b1c1203f1904810d6d9315cf3aba556e354c7 /include/llvm/CodeGen/MachineInstrBuilder.h
parent4b950ec0722cbb3915f9b7f108b9fece341b13ae (diff)
downloadexternal_llvm-9a96c425db72bc6e879e8445e3a3bf1f1e556b56.zip
external_llvm-9a96c425db72bc6e879e8445e3a3bf1f1e556b56.tar.gz
external_llvm-9a96c425db72bc6e879e8445e3a3bf1f1e556b56.tar.bz2
ad MachineInstrBuilder support for target flags on operands.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@74155 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/CodeGen/MachineInstrBuilder.h')
-rw-r--r--include/llvm/CodeGen/MachineInstrBuilder.h37
1 files changed, 23 insertions, 14 deletions
diff --git a/include/llvm/CodeGen/MachineInstrBuilder.h b/include/llvm/CodeGen/MachineInstrBuilder.h
index d3a0995..4adb846 100644
--- a/include/llvm/CodeGen/MachineInstrBuilder.h
+++ b/include/llvm/CodeGen/MachineInstrBuilder.h
@@ -74,8 +74,9 @@ public:
return *this;
}
- const MachineInstrBuilder &addMBB(MachineBasicBlock *MBB) const {
- MI->addOperand(MachineOperand::CreateMBB(MBB));
+ const MachineInstrBuilder &addMBB(MachineBasicBlock *MBB,
+ unsigned char TargetFlags = 0) const {
+ MI->addOperand(MachineOperand::CreateMBB(MBB, TargetFlags));
return *this;
}
@@ -85,25 +86,29 @@ public:
}
const MachineInstrBuilder &addConstantPoolIndex(unsigned Idx,
- int Offset = 0) const {
- MI->addOperand(MachineOperand::CreateCPI(Idx, Offset));
+ int Offset = 0,
+ unsigned char TargetFlags = 0) const {
+ MI->addOperand(MachineOperand::CreateCPI(Idx, Offset, TargetFlags));
return *this;
}
- const MachineInstrBuilder &addJumpTableIndex(unsigned Idx) const {
- MI->addOperand(MachineOperand::CreateJTI(Idx));
+ const MachineInstrBuilder &addJumpTableIndex(unsigned Idx,
+ unsigned char TargetFlags = 0) const {
+ MI->addOperand(MachineOperand::CreateJTI(Idx, TargetFlags));
return *this;
}
const MachineInstrBuilder &addGlobalAddress(GlobalValue *GV,
- int64_t Offset = 0) const {
- MI->addOperand(MachineOperand::CreateGA(GV, Offset));
+ int64_t Offset = 0,
+ unsigned char TargetFlags = 0) const {
+ MI->addOperand(MachineOperand::CreateGA(GV, Offset, TargetFlags));
return *this;
}
const MachineInstrBuilder &addExternalSymbol(const char *FnName,
- int64_t Offset = 0) const {
- MI->addOperand(MachineOperand::CreateES(FnName, Offset));
+ int64_t Offset = 0,
+ unsigned char TargetFlags = 0) const {
+ MI->addOperand(MachineOperand::CreateES(FnName, Offset, TargetFlags));
return *this;
}
@@ -126,13 +131,17 @@ public:
if (MO.isFI())
return addFrameIndex(MO.getIndex());
if (MO.isGlobal())
- return addGlobalAddress(MO.getGlobal(), MO.getOffset());
+ return addGlobalAddress(MO.getGlobal(), MO.getOffset(),
+ MO.getTargetFlags());
if (MO.isCPI())
- return addConstantPoolIndex(MO.getIndex(), MO.getOffset());
+ return addConstantPoolIndex(MO.getIndex(), MO.getOffset(),
+ MO.getTargetFlags());
if (MO.isSymbol())
- return addExternalSymbol(MO.getSymbolName());
+ return addExternalSymbol(MO.getSymbolName(), MO.getOffset(),
+ MO.getTargetFlags());
if (MO.isJTI())
- return addJumpTableIndex(MO.getIndex());
+ return addJumpTableIndex(MO.getIndex(),
+ MO.getTargetFlags());
assert(0 && "Unknown operand for MachineInstrBuilder::AddOperand!");
return *this;