diff --git a/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp b/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp index de80dd835e9..b400b87f30b 100644 --- a/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp +++ b/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp @@ -101,7 +101,18 @@ unsigned X86ELFObjectWriter::GetRelocType(const MCValue &Target, } else { switch ((unsigned)Fixup.getKind()) { default: llvm_unreachable("invalid fixup kind!"); - case FK_Data_8: Type = ELF::R_X86_64_64; break; + case FK_Data_8: + switch (Modifier) { + default: + llvm_unreachable("Unimplemented"); + case MCSymbolRefExpr::VK_None: + Type = ELF::R_X86_64_64; + break; + case MCSymbolRefExpr::VK_DTPOFF: + Type = ELF::R_X86_64_DTPOFF64; + break; + } + break; case X86::reloc_signed_4byte: switch (Modifier) { default: diff --git a/test/MC/ELF/relocation.s b/test/MC/ELF/relocation.s index 18d43dab763..d2c4f2e0781 100644 --- a/test/MC/ELF/relocation.s +++ b/test/MC/ELF/relocation.s @@ -18,7 +18,7 @@ bar: movq foo(%rip), %rdx leaq foo-bar(%r14),%r14 addq $bar,%rax # R_X86_64_32S - + .quad foo@DTPOFF // CHECK: Section { // CHECK: Name: .rela.text @@ -38,6 +38,7 @@ bar: // CHECK-NEXT: 0x55 R_X86_64_PC32 foo 0xFFFFFFFFFFFFFFFC // CHECK-NEXT: 0x5C R_X86_64_PC32 foo 0x5C // CHECK-NEXT: 0x63 R_X86_64_32S .text 0x0 +// CHECK-NEXT: 0x67 R_X86_64_DTPOFF64 foo 0x0 // CHECK-NEXT: ] // CHECK-NEXT: }