2015-11-11 09:00:24 +08:00
|
|
|
// REQUIRES: x86
|
|
|
|
// RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t
|
2015-11-18 14:11:01 +08:00
|
|
|
// RUN: ld.lld -shared %t -o %tout
|
2015-11-11 09:00:24 +08:00
|
|
|
// RUN: llvm-readobj -sections -relocations %tout | FileCheck %s
|
|
|
|
// RUN: llvm-objdump -d %tout | FileCheck %s --check-prefix=DIS
|
|
|
|
|
|
|
|
leaq a@tlsld(%rip), %rdi
|
|
|
|
callq __tls_get_addr@PLT
|
|
|
|
leaq b@tlsld(%rip), %rdi
|
|
|
|
callq __tls_get_addr@PLT
|
2015-11-11 09:27:58 +08:00
|
|
|
leaq a@dtpoff(%rax), %rcx
|
|
|
|
leaq b@dtpoff(%rax), %rcx
|
2015-11-21 06:47:40 +08:00
|
|
|
.long b@dtpoff, 0
|
2015-11-13 08:28:34 +08:00
|
|
|
leaq c@tlsgd(%rip), %rdi
|
|
|
|
rex64
|
|
|
|
callq __tls_get_addr@PLT
|
|
|
|
leaq c@dtpoff(%rax), %rcx
|
2015-12-02 03:20:26 +08:00
|
|
|
// Initial Exec Model Code Sequence, II
|
|
|
|
movq c@gottpoff(%rip),%rax
|
|
|
|
movq %fs:(%rax),%rax
|
2015-11-11 09:00:24 +08:00
|
|
|
|
2015-11-21 06:47:40 +08:00
|
|
|
.global a
|
2015-11-11 09:27:58 +08:00
|
|
|
.hidden a
|
2015-11-21 06:47:40 +08:00
|
|
|
.section .tbss,"awT",@nobits
|
2015-11-11 09:00:24 +08:00
|
|
|
.align 4
|
|
|
|
a:
|
2015-11-21 06:47:40 +08:00
|
|
|
.long 0
|
2015-11-11 09:28:23 +08:00
|
|
|
|
2015-11-21 06:47:40 +08:00
|
|
|
.section .tbss,"awT",@nobits
|
2015-11-11 09:00:24 +08:00
|
|
|
.align 4
|
|
|
|
b:
|
2015-11-21 06:47:40 +08:00
|
|
|
.long 0
|
2015-11-13 08:28:34 +08:00
|
|
|
.global c
|
2015-11-21 06:47:40 +08:00
|
|
|
.section .tbss,"awT",@nobits
|
2015-11-13 08:28:34 +08:00
|
|
|
.align 4
|
|
|
|
c:
|
2015-11-21 06:47:40 +08:00
|
|
|
.long 0
|
2015-11-11 09:00:24 +08:00
|
|
|
|
2015-11-13 08:28:34 +08:00
|
|
|
// Get the address of the got, and check that it has 4 entries.
|
2015-11-11 09:00:24 +08:00
|
|
|
|
|
|
|
// CHECK: Sections [
|
|
|
|
// CHECK: Name: .got
|
|
|
|
// CHECK-NEXT: Type: SHT_PROGBITS
|
|
|
|
// CHECK-NEXT: Flags [
|
|
|
|
// CHECK-NEXT: SHF_ALLOC
|
|
|
|
// CHECK-NEXT: SHF_WRITE
|
|
|
|
// CHECK-NEXT: ]
|
|
|
|
// CHECK-NEXT: Address: 0x20D0
|
|
|
|
// CHECK-NEXT: Offset:
|
2015-12-02 03:20:26 +08:00
|
|
|
// CHECK-NEXT: Size: 40
|
2015-11-11 09:00:24 +08:00
|
|
|
|
|
|
|
// CHECK: Relocations [
|
|
|
|
// CHECK: Section ({{.+}}) .rela.dyn {
|
|
|
|
// CHECK-NEXT: 0x20D0 R_X86_64_DTPMOD64 - 0x0
|
2015-11-13 08:28:34 +08:00
|
|
|
// CHECK-NEXT: 0x20E0 R_X86_64_DTPMOD64 c 0x0
|
|
|
|
// CHECK-NEXT: 0x20E8 R_X86_64_DTPOFF64 c 0x0
|
2015-12-02 03:20:26 +08:00
|
|
|
// CHECK-NEXT: 0x20F0 R_X86_64_TPOFF64 c 0x0
|
2015-11-11 09:00:24 +08:00
|
|
|
// CHECK-NEXT: }
|
|
|
|
|
|
|
|
// 4297 = (0x20D0 + -4) - (0x1000 + 3) // PC relative offset to got entry.
|
2015-11-11 09:27:58 +08:00
|
|
|
// 4285 = (0x20D0 + -4) - (0x100c + 3) // PC relative offset to got entry.
|
2015-11-13 08:28:34 +08:00
|
|
|
// 4267 = (0x20E0 + -4) - (0x102e + 3) // PC relative offset to got entry.
|
2015-12-02 03:20:26 +08:00
|
|
|
// 4263 = (0x20F0 + -4) - (0x1042 + 3) // PC relative offset to got entry.
|
2015-11-11 09:00:24 +08:00
|
|
|
|
|
|
|
// DIS: Disassembly of section .text:
|
|
|
|
// DIS-NEXT: .text:
|
|
|
|
// DIS-NEXT: 1000: {{.+}} leaq 4297(%rip), %rdi
|
|
|
|
// DIS-NEXT: 1007: {{.+}} callq
|
|
|
|
// DIS-NEXT: 100c: {{.+}} leaq 4285(%rip), %rdi
|
2015-11-11 09:27:58 +08:00
|
|
|
// DIS-NEXT: 1013: {{.+}} callq
|
|
|
|
// DIS-NEXT: 1018: {{.+}} leaq (%rax), %rcx
|
|
|
|
// DIS-NEXT: 101f: {{.+}} leaq 4(%rax), %rcx
|
2015-11-11 09:28:11 +08:00
|
|
|
// DIS-NEXT: 1026: 04 00
|
|
|
|
// DIS-NEXT: 1028: 00 00
|
|
|
|
// DIS-NEXT: 102a: 00 00
|
|
|
|
// DIS-NEXT: 102c: 00 00
|
2015-11-13 08:28:34 +08:00
|
|
|
// DIS-NEXT: 102e: {{.+}} leaq 4267(%rip), %rdi
|
|
|
|
// DIS-NEXT: 1035: {{.+}} callq
|
|
|
|
// DIS-NEXT: 103b: {{.+}} leaq 8(%rax), %rcx
|
2015-12-02 03:20:26 +08:00
|
|
|
// DIS-NEXT: 1042: {{.+}} movq 4263(%rip), %rax
|
|
|
|
// DIS-NEXT: 1049: {{.+}} movq %fs:(%rax), %rax
|