summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/ARM/ARMJITInfo.cpp
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2007-08-07 01:37:15 +0000
committerEvan Cheng <evan.cheng@apple.com>2007-08-07 01:37:15 +0000
commitf7c6effc44d6843ed2ed6d1a08a88c050486d752 (patch)
tree45894dcd0614e46facf2b34779d2e83ed93f0418 /llvm/lib/Target/ARM/ARMJITInfo.cpp
parent57c6ac5fe59fdf049603a2c80d4129a6b5b49ec4 (diff)
downloadbcm5719-llvm-f7c6effc44d6843ed2ed6d1a08a88c050486d752.tar.gz
bcm5719-llvm-f7c6effc44d6843ed2ed6d1a08a88c050486d752.zip
Initial JIT support for ARM by Raul Fernandes Herbster.
llvm-svn: 40887
Diffstat (limited to 'llvm/lib/Target/ARM/ARMJITInfo.cpp')
-rw-r--r--llvm/lib/Target/ARM/ARMJITInfo.cpp20
1 files changed, 19 insertions, 1 deletions
diff --git a/llvm/lib/Target/ARM/ARMJITInfo.cpp b/llvm/lib/Target/ARM/ARMJITInfo.cpp
index 294a12bc786..9622a29272c 100644
--- a/llvm/lib/Target/ARM/ARMJITInfo.cpp
+++ b/llvm/lib/Target/ARM/ARMJITInfo.cpp
@@ -127,5 +127,23 @@ void *ARMJITInfo::emitFunctionStub(void *Fn, MachineCodeEmitter &MCE) {
/// referenced global symbols.
void ARMJITInfo::relocate(void *Function, MachineRelocation *MR,
unsigned NumRelocs, unsigned char* GOTBase) {
-
+ for (unsigned i = 0; i != NumRelocs; ++i, ++MR) {
+ void *RelocPos = (char*)Function + MR->getMachineCodeOffset();
+ intptr_t ResultPtr = (intptr_t)MR->getResultPointer();
+ switch ((ARM::RelocationType)MR->getRelocationType()) {
+ case ARM::reloc_arm_relative: {
+ // PC relative relocation
+ *((unsigned*)RelocPos) += (unsigned)ResultPtr;
+ break;
+ }
+ case ARM::reloc_arm_absolute:
+ break;
+ case ARM::reloc_arm_branch: {
+ // relocation to b and bl instructions
+ ResultPtr = (ResultPtr-(intptr_t)RelocPos) >> 2;
+ *((unsigned*)RelocPos) |= ResultPtr;
+ break;
+ }
+ }
+ }
}
OpenPOWER on IntegriCloud