diff options
author | Bill Wendling <isanbard@gmail.com> | 2010-12-08 01:57:09 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2010-12-08 01:57:09 +0000 |
commit | b8958b031ec5163261f490f131780c5dc3d823d6 (patch) | |
tree | 0ba2c5f719017b8d47891046bc3e111bef276b60 /lib/Target/ARM/ARMAsmBackend.cpp | |
parent | 43c249cf1e417083ec8cbdfb4866a42861a7f638 (diff) | |
download | external_llvm-b8958b031ec5163261f490f131780c5dc3d823d6.zip external_llvm-b8958b031ec5163261f490f131780c5dc3d823d6.tar.gz external_llvm-b8958b031ec5163261f490f131780c5dc3d823d6.tar.bz2 |
Add support for loading from a constant pool.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@121226 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMAsmBackend.cpp')
-rw-r--r-- | lib/Target/ARM/ARMAsmBackend.cpp | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/lib/Target/ARM/ARMAsmBackend.cpp b/lib/Target/ARM/ARMAsmBackend.cpp index 90b181e..f5ac33a 100644 --- a/lib/Target/ARM/ARMAsmBackend.cpp +++ b/lib/Target/ARM/ARMAsmBackend.cpp @@ -138,6 +138,9 @@ static unsigned adjustFixupValue(unsigned Kind, uint64_t Value) { Binary = ((Binary & 0x7ff) << 16) | (Binary >> 11); return Binary; } + case ARM::fixup_arm_thumb_cp: + // Offset by 4, and don't encode the low two bits. + return ((Value - 4) >> 2) & 0xff; case ARM::fixup_t2_pcrel_10: case ARM::fixup_arm_pcrel_10: { // Offset by 8 just as above. @@ -243,13 +246,17 @@ static unsigned getFixupKindNumBytes(unsigned Kind) { switch (Kind) { default: llvm_unreachable("Unknown fixup kind!"); - case FK_Data_4: - return 4; + + case ARM::fixup_arm_thumb_cp: + return 1; + case ARM::fixup_arm_ldst_pcrel_12: case ARM::fixup_arm_pcrel_10: case ARM::fixup_arm_adr_pcrel_12: case ARM::fixup_arm_branch: return 3; + + case FK_Data_4: case ARM::fixup_t2_pcrel_10: case ARM::fixup_arm_thumb_bl: return 4; |