summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-09-12 21:06:08 +0000
committerChris Lattner <sabre@nondot.org>2009-09-12 21:06:08 +0000
commita1378f3d895feb25a11559e09b45ff8237c5cd45 (patch)
treece25651f067cf7a60783074ab2844f4060d6fd2f /llvm/lib
parent6ccf7ed4be50f04888bb0ff09a9a606d646579b3 (diff)
downloadbcm5719-llvm-a1378f3d895feb25a11559e09b45ff8237c5cd45.tar.gz
bcm5719-llvm-a1378f3d895feb25a11559e09b45ff8237c5cd45.zip
factor MBB label lowering better
llvm-svn: 81630
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp10
-rw-r--r--llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.h2
2 files changed, 6 insertions, 6 deletions
diff --git a/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp b/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp
index 625be15390b..023882ce5da 100644
--- a/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp
+++ b/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp
@@ -45,13 +45,12 @@ MCSymbol *X86MCInstLower::GetPICBaseSymbol() const {
return Ctx.GetOrCreateSymbol(Name.str());
}
-MCOperand X86MCInstLower::LowerMBBOperand(const MachineOperand &MO) const {
+MCSymbol *X86MCInstLower::GetMBBSymbol(unsigned MBBID) const {
SmallString<60> Name;
raw_svector_ostream(Name) << AsmPrinter.MAI->getPrivateGlobalPrefix() << "BB"
- << AsmPrinter.getFunctionNumber() << '_' << MO.getMBB()->getNumber();
+ << AsmPrinter.getFunctionNumber() << '_' << MBBID;
- MCSymbol *Sym = Ctx.GetOrCreateSymbol(Name.str());
- return MCOperand::CreateExpr(MCSymbolRefExpr::Create(Sym, Ctx));
+ return Ctx.GetOrCreateSymbol(Name.str());
}
@@ -320,7 +319,8 @@ void X86MCInstLower::Lower(const MachineInstr *MI, MCInst &OutMI) const {
MCOp = MCOperand::CreateImm(MO.getImm());
break;
case MachineOperand::MO_MachineBasicBlock:
- MCOp = LowerMBBOperand(MO);
+ MCOp = MCOperand::CreateExpr(MCSymbolRefExpr::Create(
+ GetMBBSymbol(MO.getMBB()->getNumber()), Ctx));
break;
case MachineOperand::MO_GlobalAddress:
MCOp = LowerSymbolOperand(MO, GetGlobalAddressSymbol(MO));
diff --git a/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.h b/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.h
index 2f9691ed097..3329b90cda3 100644
--- a/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.h
+++ b/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.h
@@ -36,7 +36,7 @@ public:
MCSymbol *GetPICBaseSymbol() const;
- MCOperand LowerMBBOperand(const MachineOperand &MO) const;
+ MCSymbol *GetMBBSymbol(unsigned MBBID) const;
MCSymbol *GetGlobalAddressSymbol(const MachineOperand &MO) const;
MCSymbol *GetExternalSymbolSymbol(const MachineOperand &MO) const;
MCSymbol *GetJumpTableSymbol(const MachineOperand &MO) const;
OpenPOWER on IntegriCloud