ARM JIT should observe -relocation-model command line option.
llvm-svn: 58433
diff --git a/llvm/lib/Target/ARM/ARMTargetMachine.cpp b/llvm/lib/Target/ARM/ARMTargetMachine.cpp
index a96e25f..4ffd779 100644
--- a/llvm/lib/Target/ARM/ARMTargetMachine.cpp
+++ b/llvm/lib/Target/ARM/ARMTargetMachine.cpp
@@ -85,7 +85,9 @@
InstrInfo(Subtarget),
FrameInfo(Subtarget),
JITInfo(*this),
- TLInfo(*this) {}
+ TLInfo(*this) {
+ DefRelocModel = getRelocationModel();
+}
unsigned ARMTargetMachine::getJITMatchQuality() {
#if defined(__arm__)
@@ -157,7 +159,8 @@
bool ARMTargetMachine::addCodeEmitter(PassManagerBase &PM, bool Fast,
bool DumpAsm, MachineCodeEmitter &MCE) {
// FIXME: Move this to TargetJITInfo!
- setRelocationModel(Reloc::Static);
+ if (DefRelocModel == Reloc::Default)
+ setRelocationModel(Reloc::Static);
// Machine code emitter pass for ARM.
PM.add(createARMCodeEmitterPass(*this, MCE));