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 | 8a6449c46e0a0e6a3b6db1298006b300b773a370 (patch) | |
tree | 1ab6eeae59d1a0f9ffb2c02ce43495a1ae18ed62 /llvm/lib/Target/ARM/ARMAsmBackend.cpp | |
parent | e97ae90da0f9a298a185229748d76bdf99a40da6 (diff) | |
download | bcm5719-llvm-8a6449c46e0a0e6a3b6db1298006b300b773a370.tar.gz bcm5719-llvm-8a6449c46e0a0e6a3b6db1298006b300b773a370.zip |
Add support for loading from a constant pool.
llvm-svn: 121226
Diffstat (limited to 'llvm/lib/Target/ARM/ARMAsmBackend.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/ARMAsmBackend.cpp | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/llvm/lib/Target/ARM/ARMAsmBackend.cpp b/llvm/lib/Target/ARM/ARMAsmBackend.cpp index 90b181e2cb7..f5ac33ab236 100644 --- a/llvm/lib/Target/ARM/ARMAsmBackend.cpp +++ b/llvm/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; |