[llvm-commits] CVS: llvm/lib/Target/PowerPC/PPC32CodeEmitter.cpp
Chris Lattner
lattner at cs.uiuc.edu
Sun Apr 17 17:46:26 PDT 2005
Changes in directory llvm/lib/Target/PowerPC:
PPC32CodeEmitter.cpp updated: 1.27 -> 1.28
---
Log message:
Handle ExternalSymbol operands in the PPC JIT
---
Diffs of the changes: (+13 -9)
PPC32CodeEmitter.cpp | 22 +++++++++++++---------
1 files changed, 13 insertions(+), 9 deletions(-)
Index: llvm/lib/Target/PowerPC/PPC32CodeEmitter.cpp
diff -u llvm/lib/Target/PowerPC/PPC32CodeEmitter.cpp:1.27 llvm/lib/Target/PowerPC/PPC32CodeEmitter.cpp:1.28
--- llvm/lib/Target/PowerPC/PPC32CodeEmitter.cpp:1.27 Thu Nov 25 01:09:01 2004
+++ llvm/lib/Target/PowerPC/PPC32CodeEmitter.cpp Sun Apr 17 19:46:10 2005
@@ -188,8 +188,10 @@
rv = enumRegToMachineReg(MO.getReg());
} else if (MO.isImmediate()) {
rv = MO.getImmedValue();
- } else if (MO.isGlobalAddress()) {
- GlobalValue *GV = MO.getGlobal();
+ } else if (MO.isGlobalAddress() || MO.isExternalSymbol()) {
+ bool isExternal = MO.isExternalSymbol() ||
+ MO.getGlobal()->hasWeakLinkage() ||
+ MO.getGlobal()->isExternal();
unsigned Reloc = 0;
int Offset = 0;
if (MI.getOpcode() == PPC::CALLpcrel)
@@ -199,29 +201,31 @@
Offset = -((intptr_t)MovePCtoLROffset+4);
if (MI.getOpcode() == PPC::LOADHiAddr) {
- if (GV->hasWeakLinkage() || GV->isExternal())
+ if (isExternal)
Reloc = PPC::reloc_absolute_ptr_high; // Pointer to stub
else
Reloc = PPC::reloc_absolute_high; // Pointer to symbol
} else if (MI.getOpcode() == PPC::LA) {
- assert(!(GV->hasWeakLinkage() || GV->isExternal())
- && "Something in the ISEL changed\n");
+ assert(!isExternal && "Something in the ISEL changed\n");
Reloc = PPC::reloc_absolute_low;
} else if (MI.getOpcode() == PPC::LWZ) {
Reloc = PPC::reloc_absolute_ptr_low;
- assert((GV->hasWeakLinkage() || GV->isExternal()) &&
- "Something in the ISEL changed\n");
+ assert(isExternal && "Something in the ISEL changed\n");
} else {
// These don't show up for global value references AFAIK, only for
// constant pool refs: PPC::LFS, PPC::LFD
assert(0 && "Unknown instruction for relocation!");
}
}
- MCE.addRelocation(MachineRelocation(MCE.getCurrentPCOffset(),
- Reloc, MO.getGlobal(), Offset));
+ if (MO.isGlobalAddress())
+ MCE.addRelocation(MachineRelocation(MCE.getCurrentPCOffset(),
+ Reloc, MO.getGlobal(), Offset));
+ else
+ MCE.addRelocation(MachineRelocation(MCE.getCurrentPCOffset(),
+ Reloc, MO.getSymbolName(), Offset));
} else if (MO.isMachineBasicBlock()) {
unsigned* CurrPC = (unsigned*)(intptr_t)MCE.getCurrentPCValue();
BBRefs.push_back(std::make_pair(MO.getMachineBasicBlock(), CurrPC));
More information about the llvm-commits
mailing list