AArch64/ARM64: produce correct relocation for conditional branches.
authorTim Northover <tnorthover@apple.com>
Wed, 16 Apr 2014 15:27:52 +0000 (15:27 +0000)
committerTim Northover <tnorthover@apple.com>
Wed, 16 Apr 2014 15:27:52 +0000 (15:27 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@206391 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/ARM64/MCTargetDesc/ARM64ELFObjectWriter.cpp
test/MC/AArch64/elf-reloc-condbr.s

index 1a132a17ffcd9f4fa3b5ba6106cca2f3dc3480c0..7779b824e0cb7bfc5aa840376d58bd150da3310d 100644 (file)
@@ -83,7 +83,11 @@ unsigned ARM64ELFObjectWriter::GetRelocType(const MCValue &Target,
     case ARM64::fixup_arm64_pcrel_call26:
       return ELF::R_AARCH64_CALL26;
     case ARM64::fixup_arm64_pcrel_imm19:
-      return ELF::R_AARCH64_TLSIE_LD_GOTTPREL_PREL19;
+      // A bit of an oddity here: shared by both "ldr x0, :gottprel:var" and
+      // "b.eq var".
+      if (SymLoc == ARM64MCExpr::VK_GOTTPREL)
+        return ELF::R_AARCH64_TLSIE_LD_GOTTPREL_PREL19;
+      return ELF::R_AARCH64_CONDBR19;
     default:
       llvm_unreachable("Unsupported pc-relative fixup kind");
     }
index b70dfa70fb8ebd32470a2402526db5c1ced748c6..9b70a20e1bc243c10fca98e0cf88a366fe28be0d 100644 (file)
@@ -1,4 +1,4 @@
-// RUN: llvm-mc -triple=aarch64-none-linux-gnu -filetype=obj %s -o - | \
+// RUN: llvm-mc -triple=arm64-none-linux-gnu -filetype=obj %s -o - | \
 // RUN:   llvm-readobj -r | FileCheck -check-prefix=OBJ %s
 
         b.eq somewhere