summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/PowerPC
diff options
context:
space:
mode:
authorBill Schmidt <wschmidt@linux.vnet.ibm.com>2013-02-25 16:44:35 +0000
committerBill Schmidt <wschmidt@linux.vnet.ibm.com>2013-02-25 16:44:35 +0000
commitb4548299814ef9d90e2ae99bb628c82c944234ea (patch)
treeac57730f8521317bf1f06ed1485f36fbe68ee4d7 /llvm/lib/Target/PowerPC
parent62e681744c4dbbb73d8f8200ad2777c02af3e66d (diff)
downloadbcm5719-llvm-b4548299814ef9d90e2ae99bb628c82c944234ea.tar.gz
bcm5719-llvm-b4548299814ef9d90e2ae99bb628c82c944234ea.zip
Fix missing relocation for TLS addressing peephole optimization.
Report and fix due to Kai Nacke. Testcase update by me. llvm-svn: 176029
Diffstat (limited to 'llvm/lib/Target/PowerPC')
-rw-r--r--llvm/lib/Target/PowerPC/MCTargetDesc/PPCELFObjectWriter.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/llvm/lib/Target/PowerPC/MCTargetDesc/PPCELFObjectWriter.cpp b/llvm/lib/Target/PowerPC/MCTargetDesc/PPCELFObjectWriter.cpp
index ad41f3ad3a8..61868d446fe 100644
--- a/llvm/lib/Target/PowerPC/MCTargetDesc/PPCELFObjectWriter.cpp
+++ b/llvm/lib/Target/PowerPC/MCTargetDesc/PPCELFObjectWriter.cpp
@@ -153,6 +153,9 @@ unsigned PPCELFObjectWriter::getRelocTypeInner(const MCValue &Target,
case PPC::fixup_ppc_toc16:
switch (Modifier) {
default: llvm_unreachable("Unsupported Modifier");
+ case MCSymbolRefExpr::VK_PPC_TPREL16_LO:
+ Type = ELF::R_PPC64_TPREL16_LO;
+ break;
case MCSymbolRefExpr::VK_PPC_DTPREL16_LO:
Type = ELF::R_PPC64_DTPREL16_LO;
break;
OpenPOWER on IntegriCloud