ARM: Support relative references using the PREL31 symbol variant.
authorPeter Collingbourne <peter@pcc.me.uk>
Thu, 10 Mar 2016 19:30:18 +0000 (19:30 +0000)
committerPeter Collingbourne <peter@pcc.me.uk>
Thu, 10 Mar 2016 19:30:18 +0000 (19:30 +0000)
Differential Revision: http://reviews.llvm.org/D17937

llvm-svn: 263156

llvm/lib/Target/ARM/MCTargetDesc/ARMELFObjectWriter.cpp
llvm/test/MC/ARM/symbol-variants.s

index 388ce79..9001ad3 100644 (file)
@@ -98,6 +98,9 @@ unsigned ARMELFObjectWriter::GetRelocTypeInner(const MCValue &Target,
       case MCSymbolRefExpr::VK_ARM_GOT_PREL:
         Type = ELF::R_ARM_GOT_PREL;
         break;
+      case MCSymbolRefExpr::VK_ARM_PREL31:
+        Type = ELF::R_ARM_PREL31;
+        break;
       }
       break;
     case ARM::fixup_arm_blx:
index af1bc07..c541905 100644 (file)
@@ -84,8 +84,14 @@ bl f05(plt)
 @ CHECK: 60 R_ARM_TLS_GOTDESC f24
 @ CHECK: 64 R_ARM_TLS_GOTDESC f25
 
+@ prel31 (relative)
+.word f26(PREL31)-.
+.word f27(prel31)-.
+@CHECK: 68 R_ARM_PREL31 f26
+@CHECK: 6c R_ARM_PREL31 f27
+
 @ got_prel
-.word  f26(GOT_PREL) + (. - .Lsym)
-       ldr r3, =f27(GOT_PREL)
-@ CHECK: 68 R_ARM_GOT_PREL f26
-@ CHECK: 70 R_ARM_GOT_PREL f27
+.word  f28(GOT_PREL) + (. - .Lsym)
+       ldr r3, =f29(GOT_PREL)
+@ CHECK: 70 R_ARM_GOT_PREL f28
+@ CHECK: 78 R_ARM_GOT_PREL f29