diff --git a/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp b/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp index b400b87f30b..6a4bdeb133b 100644 --- a/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp +++ b/lib/Target/X86/MCTargetDesc/X86ELFObjectWriter.cpp @@ -108,6 +108,9 @@ unsigned X86ELFObjectWriter::GetRelocType(const MCValue &Target, case MCSymbolRefExpr::VK_None: Type = ELF::R_X86_64_64; break; + case MCSymbolRefExpr::VK_TPOFF: + Type = ELF::R_X86_64_TPOFF64; + break; case MCSymbolRefExpr::VK_DTPOFF: Type = ELF::R_X86_64_DTPOFF64; break; diff --git a/test/MC/ELF/relocation.s b/test/MC/ELF/relocation.s index d2c4f2e0781..ba50c8182fb 100644 --- a/test/MC/ELF/relocation.s +++ b/test/MC/ELF/relocation.s @@ -19,6 +19,7 @@ bar: leaq foo-bar(%r14),%r14 addq $bar,%rax # R_X86_64_32S .quad foo@DTPOFF + movabsq $baz@TPOFF, %rax // CHECK: Section { // CHECK: Name: .rela.text @@ -39,6 +40,7 @@ bar: // 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: 0x71 R_X86_64_TPOFF64 baz 0x0 // CHECK-NEXT: ] // CHECK-NEXT: }