summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2010-12-27 02:03:24 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2010-12-27 02:03:24 +0000
commit8fc59a682fa1cc097fcaa13dc9f3721fa8f34877 (patch)
tree8ef477a5be872671877ce321c4b74050e0f07044
parentb7577657cdf30199a091d3f71d63ff9ab25846f0 (diff)
downloadbcm5719-llvm-8fc59a682fa1cc097fcaa13dc9f3721fa8f34877.tar.gz
bcm5719-llvm-8fc59a682fa1cc097fcaa13dc9f3721fa8f34877.zip
Handle reloc_riprel_4byte_movq_load. Should make the bots happy.
llvm-svn: 122579
-rw-r--r--llvm/lib/MC/ELFObjectWriter.cpp1
-rw-r--r--llvm/test/MC/ELF/relocation.s7
2 files changed, 8 insertions, 0 deletions
diff --git a/llvm/lib/MC/ELFObjectWriter.cpp b/llvm/lib/MC/ELFObjectWriter.cpp
index 88c7200734f..c4e2e3f390b 100644
--- a/llvm/lib/MC/ELFObjectWriter.cpp
+++ b/llvm/lib/MC/ELFObjectWriter.cpp
@@ -1610,6 +1610,7 @@ unsigned X86ELFObjectWriter::GetRelocType(const MCValue &Target,
assert(Modifier == MCSymbolRefExpr::VK_None);
Type = ELF::R_X86_64_PC64;
break;
+ case X86::reloc_riprel_4byte_movq_load:
case FK_Data_4: // FIXME?
case X86::reloc_riprel_4byte:
case FK_PCRel_4:
diff --git a/llvm/test/MC/ELF/relocation.s b/llvm/test/MC/ELF/relocation.s
index a3ad5268b40..ea27214b8a9 100644
--- a/llvm/test/MC/ELF/relocation.s
+++ b/llvm/test/MC/ELF/relocation.s
@@ -15,6 +15,7 @@ bar:
leaq foo@TLSLD(%rip), %rdi # R_X86_64_TLSLD
leaq foo@DTPOFF(%rax), %rcx # R_X86_64_DTPOFF32
pushq $bar
+ movq foo(%rip), %rdx
// CHECK: # Section 0x00000001
@@ -98,3 +99,9 @@ bar:
// CHECK-NEXT: ('r_sym', 0x00000002)
// CHECK-NEXT: ('r_type', 0x0000000b)
// CHECK-NEXT: ('r_addend', 0x00000000)
+
+// CHECK: # Relocation 0x0000000c
+// CHECK-NEXT: (('r_offset', 0x00000055)
+// CHECK-NEXT: ('r_sym', 0x00000006)
+// CHECK-NEXT: ('r_type', 0x00000002)
+// CHECK-NEXT: ('r_addend', 0xfffffffc)
OpenPOWER on IntegriCloud