summaryrefslogtreecommitdiff
path: root/lib/Target/ARM/ARMJITInfo.cpp
diff options
context:
space:
mode:
authorZonr Chang <zonr.xchg@gmail.com>2010-05-25 08:42:45 +0000
committerZonr Chang <zonr.xchg@gmail.com>2010-05-25 08:42:45 +0000
commitf86399be0c2cd095ebaa80dcc0180dab45ec263c (patch)
tree935f352a9a093c3f2e197c45ef3ea5f5a6e17153 /lib/Target/ARM/ARMJITInfo.cpp
parenta85df80ed7ff55595ab7982dd1c0543a8dc56efe (diff)
downloadllvm-f86399be0c2cd095ebaa80dcc0180dab45ec263c.tar.gz
llvm-f86399be0c2cd095ebaa80dcc0180dab45ec263c.tar.bz2
llvm-f86399be0c2cd095ebaa80dcc0180dab45ec263c.tar.xz
Add support to MOVimm32 using movt/movw for ARM JIT
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@104587 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMJITInfo.cpp')
-rw-r--r--lib/Target/ARM/ARMJITInfo.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/lib/Target/ARM/ARMJITInfo.cpp b/lib/Target/ARM/ARMJITInfo.cpp
index b31a4fa343..5f6d7eef4b 100644
--- a/lib/Target/ARM/ARMJITInfo.cpp
+++ b/lib/Target/ARM/ARMJITInfo.cpp
@@ -318,6 +318,18 @@ void ARMJITInfo::relocate(void *Function, MachineRelocation *MR,
*((intptr_t*)RelocPos) |= ResultPtr;
break;
}
+ case ARM::reloc_arm_movw: {
+ ResultPtr = ResultPtr & 0xFFFF;
+ *((intptr_t*)RelocPos) |= ResultPtr & 0xFFF;
+ *((intptr_t*)RelocPos) |= ((ResultPtr >> 12) & 0xF) << 16;
+ break;
+ }
+ case ARM::reloc_arm_movt: {
+ ResultPtr = (ResultPtr >> 16) & 0xFFFF;
+ *((intptr_t*)RelocPos) |= ResultPtr & 0xFFF;
+ *((intptr_t*)RelocPos) |= ((ResultPtr >> 12) & 0xF) << 16;
+ break;
+ }
}
}
}