aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Target/ARM/ARMCodeEmitter.cpp
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-11-08 01:31:27 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-11-08 01:31:27 +0000
commite96a490d7a0e224961d37f60f85e8556a64ed2b1 (patch)
tree8e08427d0f274f2b95911caf6bf81ff2ad73ad42 /lib/Target/ARM/ARMCodeEmitter.cpp
parentfd827c41cec48d4b8a6159ad29f5069d613170a8 (diff)
downloadexternal_llvm-e96a490d7a0e224961d37f60f85e8556a64ed2b1.zip
external_llvm-e96a490d7a0e224961d37f60f85e8556a64ed2b1.tar.gz
external_llvm-e96a490d7a0e224961d37f60f85e8556a64ed2b1.tar.bz2
Handle ARM machine constantpool entry with non-lazy ptr.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@58882 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMCodeEmitter.cpp')
-rw-r--r--lib/Target/ARM/ARMCodeEmitter.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/lib/Target/ARM/ARMCodeEmitter.cpp b/lib/Target/ARM/ARMCodeEmitter.cpp
index 32cf226..49d2cb0 100644
--- a/lib/Target/ARM/ARMCodeEmitter.cpp
+++ b/lib/Target/ARM/ARMCodeEmitter.cpp
@@ -336,8 +336,13 @@ void ARMCodeEmitter::emitConstPoolInstruction(const MachineInstr &MI) {
GlobalValue *GV = ACPV->getGV();
if (GV) {
assert(!ACPV->isStub() && "Don't know how to deal this yet!");
- emitGlobalAddress(GV, ARM::reloc_arm_machine_cp_entry, false,
- (intptr_t)ACPV);
+ if (ACPV->isNonLazyPointer())
+ MCE.addRelocation(MachineRelocation::getGVNonLazyPtr(
+ MCE.getCurrentPCOffset(), ARM::reloc_arm_machine_cp_entry, GV,
+ (intptr_t)ACPV, false));
+ else
+ emitGlobalAddress(GV, ARM::reloc_arm_machine_cp_entry,
+ ACPV->isStub(), (intptr_t)ACPV);
} else {
assert(!ACPV->isNonLazyPointer() && "Don't know how to deal this yet!");
emitExternalSymbolAddress(ACPV->getSymbol(), ARM::reloc_arm_absolute);