summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorTim Northover <tnorthover@apple.com>2014-04-16 15:27:52 +0000
committerTim Northover <tnorthover@apple.com>2014-04-16 15:27:52 +0000
commit3e69958b6b09a6cddc02eec185e3ace68e0670be (patch)
tree6a3c3900b458d763bbb1c8d102b7c5c71182020f /llvm/lib
parent5e73df5cf0f344656604731c6ea055401c7752d3 (diff)
downloadbcm5719-llvm-3e69958b6b09a6cddc02eec185e3ace68e0670be.tar.gz
bcm5719-llvm-3e69958b6b09a6cddc02eec185e3ace68e0670be.zip
AArch64/ARM64: produce correct relocation for conditional branches.
llvm-svn: 206391
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/ARM64/MCTargetDesc/ARM64ELFObjectWriter.cpp6
1 files changed, 5 insertions, 1 deletions
diff --git a/llvm/lib/Target/ARM64/MCTargetDesc/ARM64ELFObjectWriter.cpp b/llvm/lib/Target/ARM64/MCTargetDesc/ARM64ELFObjectWriter.cpp
index 1a132a17ffc..7779b824e0c 100644
--- a/llvm/lib/Target/ARM64/MCTargetDesc/ARM64ELFObjectWriter.cpp
+++ b/llvm/lib/Target/ARM64/MCTargetDesc/ARM64ELFObjectWriter.cpp
@@ -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");
}
OpenPOWER on IntegriCloud