diff options
author | Zonr Chang <zonr.xchg@gmail.com> | 2010-05-25 08:42:45 +0000 |
---|---|---|
committer | Zonr Chang <zonr.xchg@gmail.com> | 2010-05-25 08:42:45 +0000 |
commit | 2da5aa1b603c0751a9178a7b41d5ed145825e66f (patch) | |
tree | d83bc3dfe1127051bb396b3337381b967ce21626 /llvm/lib/Target/ARM/ARMJITInfo.cpp | |
parent | 09737ee8858250cd1adb579fcce029632c6a3863 (diff) | |
download | bcm5719-llvm-2da5aa1b603c0751a9178a7b41d5ed145825e66f.tar.gz bcm5719-llvm-2da5aa1b603c0751a9178a7b41d5ed145825e66f.zip |
Add support to MOVimm32 using movt/movw for ARM JIT
llvm-svn: 104587
Diffstat (limited to 'llvm/lib/Target/ARM/ARMJITInfo.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/ARMJITInfo.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/llvm/lib/Target/ARM/ARMJITInfo.cpp b/llvm/lib/Target/ARM/ARMJITInfo.cpp index b31a4fa343b..5f6d7eef4b5 100644 --- a/llvm/lib/Target/ARM/ARMJITInfo.cpp +++ b/llvm/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; + } } } } |