Handle reloc_riprel_4byte_movq_load. Should make the bots happy.
authorRafael Espindola <rafael.espindola@gmail.com>
Mon, 27 Dec 2010 02:03:24 +0000 (02:03 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Mon, 27 Dec 2010 02:03:24 +0000 (02:03 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122579 91177308-0d34-0410-b5e6-96231b3b80d8

lib/MC/ELFObjectWriter.cpp
test/MC/ELF/relocation.s

index 88c7200734fb40dda165607fdb465306ba73bae7..c4e2e3f390b229d5dfccae431ba38ba62abc63ac 100644 (file)
@@ -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:
index a3ad5268b4076c4dec8afb5af69ffc25ab75e13d..ea27214b8a9ee822cb598ce0e7438dc4a413c206 100644 (file)
@@ -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)