summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/ARM/ARMAsmBackend.cpp
diff options
context:
space:
mode:
authorBill Wendling <isanbard@gmail.com>2010-12-08 01:57:09 +0000
committerBill Wendling <isanbard@gmail.com>2010-12-08 01:57:09 +0000
commit8a6449c46e0a0e6a3b6db1298006b300b773a370 (patch)
tree1ab6eeae59d1a0f9ffb2c02ce43495a1ae18ed62 /llvm/lib/Target/ARM/ARMAsmBackend.cpp
parente97ae90da0f9a298a185229748d76bdf99a40da6 (diff)
downloadbcm5719-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.cpp11
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;
OpenPOWER on IntegriCloud