Skip to content

Commit 8d56798

Browse files
committed
Updated tests
1 parent b9cfa55 commit 8d56798

File tree

3 files changed

+44
-13
lines changed

3 files changed

+44
-13
lines changed

lld/test/ELF/pack-dyn-relocs-tls-x86-64.s

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,7 @@
1313
foo:
1414
movq tlsvar@GOTTPOFF(%rip), %rcx
1515
movq tlsvar2@GOTTPOFF(%rip), %r31
16+
addq tlsvar3@GOTTPOFF(%rip), %rcx, %r16
1617

1718

1819
.section .tdata,"awT",@progbits
@@ -21,7 +22,11 @@ tlsvar:
2122
.word 42
2223
tlsvar2:
2324
.word 42
25+
tlsvar3:
26+
.word 42
27+
2428
// CHECK: Section ({{.+}}) .rela.dyn {
2529
// CHECK-NEXT: R_X86_64_TPOFF64 - 0x1234
2630
// CHECK-NEXT: R_X86_64_TPOFF64 - 0x1236
31+
// CHECK-NEXT: R_X86_64_TPOFF64 - 0x1238
2732
// CHECK-NEXT: }

lld/test/ELF/tls-opt.s

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -20,20 +20,25 @@
2020
// DISASM-NEXT: leaq -4(%r15), %r15
2121
// DISASM-NEXT: addq $-4, %rsp
2222
// DISASM-NEXT: addq $-4, %r12
23+
# EPGR
2324
// DISASM-NEXT: movq $-8, %r16
2425
// DISASM-NEXT: movq $-8, %r20
2526
// DISASM-NEXT: movq $-4, %r16
2627
// DISASM-NEXT: addq $-8, %r16
2728
// DISASM-NEXT: addq $-8, %r28
2829
// DISASM-NEXT: addq $-4, %r16
30+
# NDD
2931
// DISASM-NEXT: addq $-10, %r16, %r16
3032
// DISASM-NEXT: addq $-10, %r16, %r20
3133
// DISASM-NEXT: addq $-10, %r16, %rax
3234
// DISASM-NEXT: addq $-10, %rax, %r16
3335
// DISASM-NEXT: addq $-10, %r8, %r16
3436
// DISASM-NEXT: addq $-10, %rax, %r12
37+
# NDD + NF
3538
// DISASM-NEXT: {nf} addq $-10, %r8, %r16
3639
// DISASM-NEXT: {nf} addq $-10, %rax, %r12
40+
# NF
41+
// DISASM-NEXT: {nf} addq $-10, %r12
3742

3843
// LD to LE:
3944
// DISASM-NEXT: movq %fs:0, %rax
@@ -90,15 +95,18 @@ _start:
9095
addq tls0@GOTTPOFF(%rip), %r16
9196
addq tls0@GOTTPOFF(%rip), %r28
9297
addq tls1@GOTTPOFF(%rip), %r16
93-
# NDD
98+
# NDD
9499
addq tls0@GOTTPOFF(%rip), %r16, %r16
95100
addq tls0@GOTTPOFF(%rip), %r16, %r20
96101
addq tls0@GOTTPOFF(%rip), %r16, %rax
97102
addq tls0@GOTTPOFF(%rip), %rax, %r16
98103
addq %r8, tls0@GOTTPOFF(%rip), %r16
99104
addq tls0@GOTTPOFF(%rip), %rax, %r12
105+
# NDD + NF
100106
{nf} addq %r8, tls0@GOTTPOFF(%rip), %r16
101107
{nf} addq tls0@GOTTPOFF(%rip), %rax, %r12
108+
# NF
109+
{nf} addq tls0@GOTTPOFF(%rip), %r12
102110

103111
// LD to LE
104112
leaq tls0@tlsld(%rip), %rdi

lld/test/ELF/x86-64-tls-ie-local.s

Lines changed: 30 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -5,29 +5,47 @@
55
# RUN: llvm-readobj -r %t.so | FileCheck --check-prefix=REL %s
66
# RUN: llvm-objdump --no-print-imm-hex -d --no-show-raw-insn %t.so | FileCheck %s
77

8-
# SEC: .got PROGBITS 0000000000002348 000348 000010 00 WA 0 0 8
8+
# SEC: .got PROGBITS 0000000000002378 000378 000010 00 WA 0 0 8
99

1010
## Dynamic relocations for non-preemptable symbols in a shared object have section index 0.
1111
# REL: .rela.dyn {
12-
# REL-NEXT: 0x2348 R_X86_64_TPOFF64 - 0x0
13-
# REL-NEXT: 0x2350 R_X86_64_TPOFF64 - 0x4
12+
# REL-NEXT: 0x2378 R_X86_64_TPOFF64 - 0x0
13+
# REL-NEXT: 0x2380 R_X86_64_TPOFF64 - 0x4
1414
# REL-NEXT: }
1515

16-
## &.got[0] - 0x127f = 0x2348 - 0x127f = 4297
17-
## &.got[1] - 0x1286 = 0x2350 - 0x1286 = 4298
18-
## &.got[2] - 0x128e = 0x2348 - 0x128e = 4282
19-
## &.got[3] - 0x1296 = 0x2350 - 0x1296 = 4282
16+
## &.got[0] - 0x127f = 0x2378 - 0x127f = 4345
17+
## &.got[1] - 0x1286 = 0x2380 - 0x1286 = 4346
18+
## &.got[2] - 0x128e = 0x2378 - 0x128e = 4330
19+
## &.got[3] - 0x1296 = 0x2380 - 0x1296 = 4330
20+
## &.got[0] - 0x12a0 = 0x2376 - 0x12a0 = 4310
21+
## &.got[1] - 0x12aa = 0x237e - 0x12aa = 4308
22+
## &.got[0] - 0x12b4 = 0x2376 - 0x12b4 = 4290
23+
## &.got[1] - 0x12be = 0x237e - 0x12be = 4288
24+
## &.got[0] - 0x12c8 = 0x2376 - 0x12c8 = 4270
2025

21-
# CHECK: 1278: addq 4297(%rip), %rax
22-
# CHECK-NEXT: 127f: addq 4298(%rip), %rax
23-
# CHECK-NEXT: 1286: addq 4282(%rip), %r16
24-
# CHECK-NEXT: 128e: addq 4282(%rip), %r16
26+
# CHECK: 1278: addq 4345(%rip), %rax
27+
# CHECK-NEXT: 127f: addq 4346(%rip), %rax
28+
# CHECK-NEXT: 1286: addq 4330(%rip), %r16
29+
# CHECK-NEXT: 128e: addq 4330(%rip), %r16
30+
# CHECK-NEXT: 1296: addq %r8, 4310(%rip), %r16
31+
# CHECK-NEXT: 12a0: addq 4308(%rip), %rax, %r12
32+
# CHECK-NEXT: 12aa: {nf} addq %r8, 4290(%rip), %r16
33+
# CHECK-NEXT: 12b4: {nf} addq 4288(%rip), %rax, %r12
34+
# CHECK-NEXT: 12be: {nf} addq 4270(%rip), %r12
2535

2636
addq foo@GOTTPOFF(%rip), %rax
2737
addq bar@GOTTPOFF(%rip), %rax
38+
# EGPR
2839
addq foo@GOTTPOFF(%rip), %r16
2940
addq bar@GOTTPOFF(%rip), %r16
30-
41+
# NDD
42+
addq %r8, foo@GOTTPOFF(%rip), %r16
43+
addq bar@GOTTPOFF(%rip), %rax, %r12
44+
# NDD + NF
45+
{nf} addq %r8, foo@GOTTPOFF(%rip), %r16
46+
{nf} addq bar@GOTTPOFF(%rip), %rax, %r12
47+
# NF
48+
{nf} addq foo@GOTTPOFF(%rip), %r12
3149

3250
.section .tbss,"awT",@nobits
3351
foo:

0 commit comments

Comments
 (0)