Automatic date update in version.in
[deliverable/binutils-gdb.git] / ld / testsuite / ld-x86-64 / tlsbin.dd
CommitLineData
bffbf940
JJ
1#source: tlsbinpic.s
2#source: tlsbin.s
3#as: --64
e41b3a13 4#ld: -shared -melf_x86_64 --no-ld-generated-unwind-info
bffbf940
JJ
5#objdump: -drj.text
6#target: x86_64-*-*
7
8# PT_TLS layout is:
9# Offset from Offset from Name
10# TCB base TCB end
11# 0x00 -0xa0 sg1..sg8
12# 0x20 -0x80 sl1..sl8
13# 0x40 -0x60 sh1..sh8
14# 0x60 -0x40 bg1..bg8
15# 0x80 -0x20 bl1..bl8
16
5a68afcf 17.*: +file format elf64-x86-64.*
bffbf940
JJ
18
19Disassembly of section .text:
20
5a68afcf
RM
21[0-9a-f]+ <fn2>:
22 +[0-9a-f]+: 55[ ]+push %rbp
23 +[0-9a-f]+: 48 89 e5[ ]+mov %rsp,%rbp
bffbf940 24# GD -> IE because variable is not defined in executable
5a68afcf
RM
25 +[0-9a-f]+: 64 48 8b 04 25 00 00[ ]+mov %fs:0x0,%rax
26 +[0-9a-f]+: 00 00 *
a24bb4f0 27 +[0-9a-f]+: 48 03 05 ([0-9a-f]{2} ){4}[ ]+add 0x[0-9a-f]+\(%rip\),%rax +# [0-9a-f]+ <.*>
bffbf940 28# -> R_X86_64_TPOFF64 sG1
5a68afcf
RM
29 +[0-9a-f]+: 90[ ]+nop *
30 +[0-9a-f]+: 90[ ]+nop *
31 +[0-9a-f]+: 90[ ]+nop *
32 +[0-9a-f]+: 90[ ]+nop *
bffbf940
JJ
33# GD -> IE because variable is not defined in executable where
34# the variable is referenced through IE too
5a68afcf
RM
35 +[0-9a-f]+: 64 48 8b 04 25 00 00[ ]+mov %fs:0x0,%rax
36 +[0-9a-f]+: 00 00 *
a24bb4f0 37 +[0-9a-f]+: 48 03 05 ([0-9a-f]{2} ){4}[ ]+add 0x[0-9a-f]+\(%rip\),%rax +# [0-9a-f]+ <.*>
bffbf940 38# -> R_X86_64_TPOFF64 sG2
5a68afcf
RM
39 +[0-9a-f]+: 90[ ]+nop *
40 +[0-9a-f]+: 90[ ]+nop *
41 +[0-9a-f]+: 90[ ]+nop *
42 +[0-9a-f]+: 90[ ]+nop *
bffbf940 43# GD -> LE with global variable defined in executable
5a68afcf
RM
44 +[0-9a-f]+: 64 48 8b 04 25 00 00[ ]+mov %fs:0x0,%rax
45 +[0-9a-f]+: 00 00 *
46 +[0-9a-f]+: 48 8d 80 60 ff ff ff[ ]+lea -0xa0\(%rax\),%rax
bffbf940 47# sg1
5a68afcf
RM
48 +[0-9a-f]+: 90[ ]+nop *
49 +[0-9a-f]+: 90[ ]+nop *
50 +[0-9a-f]+: 90[ ]+nop *
51 +[0-9a-f]+: 90[ ]+nop *
bffbf940 52# GD -> LE with local variable defined in executable
5a68afcf
RM
53 +[0-9a-f]+: 64 48 8b 04 25 00 00[ ]+mov %fs:0x0,%rax
54 +[0-9a-f]+: 00 00 *
55 +[0-9a-f]+: 48 8d 80 80 ff ff ff[ ]+lea -0x80\(%rax\),%rax
bffbf940 56# sl1
5a68afcf
RM
57 +[0-9a-f]+: 90[ ]+nop *
58 +[0-9a-f]+: 90[ ]+nop *
59 +[0-9a-f]+: 90[ ]+nop *
60 +[0-9a-f]+: 90[ ]+nop *
bffbf940 61# GD -> LE with hidden variable defined in executable
5a68afcf
RM
62 +[0-9a-f]+: 64 48 8b 04 25 00 00[ ]+mov %fs:0x0,%rax
63 +[0-9a-f]+: 00 00 *
64 +[0-9a-f]+: 48 8d 80 a0 ff ff ff[ ]+lea -0x60\(%rax\),%rax
bffbf940 65# sh1
5a68afcf
RM
66 +[0-9a-f]+: 90[ ]+nop *
67 +[0-9a-f]+: 90[ ]+nop *
68 +[0-9a-f]+: 90[ ]+nop *
69 +[0-9a-f]+: 90[ ]+nop *
a45bb67d 70# LD -> LE
df18fdba 71 +[0-9a-f]+: 66 66 66 64 48 8b 04[ ]+data16 data16 data16 mov %fs:0x0,%rax
5a68afcf
RM
72 +[0-9a-f]+: 25 00 00 00 00 *
73 +[0-9a-f]+: 90[ ]+nop *
74 +[0-9a-f]+: 90[ ]+nop *
75 +[0-9a-f]+: 48 8d 90 81 ff ff ff[ ]+lea -0x7f\(%rax\),%rdx
bffbf940 76# sl1+1
5a68afcf
RM
77 +[0-9a-f]+: 90[ ]+nop *
78 +[0-9a-f]+: 90[ ]+nop *
79 +[0-9a-f]+: 4c 8d 88 86 ff ff ff[ ]+lea -0x7a\(%rax\),%r9
bffbf940 80# sl2+2
5a68afcf
RM
81 +[0-9a-f]+: 90[ ]+nop *
82 +[0-9a-f]+: 90[ ]+nop *
83 +[0-9a-f]+: 90[ ]+nop *
84 +[0-9a-f]+: 90[ ]+nop *
a45bb67d 85# LD -> LE against hidden variables
df18fdba 86 +[0-9a-f]+: 66 66 66 64 48 8b 04[ ]+data16 data16 data16 mov %fs:0x0,%rax
5a68afcf
RM
87 +[0-9a-f]+: 25 00 00 00 00 *
88 +[0-9a-f]+: 90[ ]+nop *
89 +[0-9a-f]+: 90[ ]+nop *
90 +[0-9a-f]+: 48 8d 90 a0 ff ff ff[ ]+lea -0x60\(%rax\),%rdx
bffbf940 91# sh1
5a68afcf
RM
92 +[0-9a-f]+: 90[ ]+nop *
93 +[0-9a-f]+: 90[ ]+nop *
94 +[0-9a-f]+: 48 8d 88 a7 ff ff ff[ ]+lea -0x59\(%rax\),%rcx
bffbf940 95# sh2+3
5a68afcf
RM
96 +[0-9a-f]+: 90[ ]+nop *
97 +[0-9a-f]+: 90[ ]+nop *
98 +[0-9a-f]+: 90[ ]+nop *
99 +[0-9a-f]+: 90[ ]+nop *
bffbf940 100# IE against global var
5a68afcf
RM
101 +[0-9a-f]+: 64 4c 8b 0c 25 00 00[ ]+mov %fs:0x0,%r9
102 +[0-9a-f]+: 00 00 *
103 +[0-9a-f]+: 90[ ]+nop *
104 +[0-9a-f]+: 90[ ]+nop *
a24bb4f0 105 +[0-9a-f]+: 4c 03 0d ([0-9a-f]{2} ){4}[ ]+add 0x[0-9a-f]+\(%rip\),%r9 +# [0-9a-f]+ <.*>
bffbf940 106# -> R_X86_64_TPOFF64 sG2
5a68afcf
RM
107 +[0-9a-f]+: 90[ ]+nop *
108 +[0-9a-f]+: 90[ ]+nop *
109 +[0-9a-f]+: 90[ ]+nop *
110 +[0-9a-f]+: 90[ ]+nop *
bffbf940 111# IE -> LE against global var defined in exec
5a68afcf
RM
112 +[0-9a-f]+: 64 4c 8b 14 25 00 00[ ]+mov %fs:0x0,%r10
113 +[0-9a-f]+: 00 00 *
114 +[0-9a-f]+: 90[ ]+nop *
115 +[0-9a-f]+: 90[ ]+nop *
116 +[0-9a-f]+: 4d 8d 92 60 ff ff ff[ ]+lea -0xa0\(%r10\),%r10
bffbf940 117# sg1
5a68afcf
RM
118 +[0-9a-f]+: 90[ ]+nop *
119 +[0-9a-f]+: 90[ ]+nop *
120 +[0-9a-f]+: 90[ ]+nop *
121 +[0-9a-f]+: 90[ ]+nop *
bffbf940 122# IE -> LE against local var
5a68afcf
RM
123 +[0-9a-f]+: 64 48 8b 04 25 00 00[ ]+mov %fs:0x0,%rax
124 +[0-9a-f]+: 00 00 *
125 +[0-9a-f]+: 90[ ]+nop *
126 +[0-9a-f]+: 90[ ]+nop *
127 +[0-9a-f]+: 48 8d 80 80 ff ff ff[ ]+lea -0x80\(%rax\),%rax
bffbf940 128# sl1
5a68afcf
RM
129 +[0-9a-f]+: 90[ ]+nop *
130 +[0-9a-f]+: 90[ ]+nop *
131 +[0-9a-f]+: 90[ ]+nop *
132 +[0-9a-f]+: 90[ ]+nop *
bffbf940 133# IE -> LE against hidden var
5a68afcf
RM
134 +[0-9a-f]+: 64 48 8b 0c 25 00 00[ ]+mov %fs:0x0,%rcx
135 +[0-9a-f]+: 00 00 *
136 +[0-9a-f]+: 90[ ]+nop *
137 +[0-9a-f]+: 90[ ]+nop *
138 +[0-9a-f]+: 48 8d 89 a0 ff ff ff[ ]+lea -0x60\(%rcx\),%rcx
bffbf940 139# sh1
5a68afcf
RM
140 +[0-9a-f]+: 90[ ]+nop *
141 +[0-9a-f]+: 90[ ]+nop *
142 +[0-9a-f]+: 90[ ]+nop *
143 +[0-9a-f]+: 90[ ]+nop *
bffbf940
JJ
144# Direct access through %fs
145# IE against global var
a24bb4f0 146 +[0-9a-f]+: 48 8b 0d ([0-9a-f]{2} ){4}[ ]+mov 0x[0-9a-f]+\(%rip\),%rcx +# [0-9a-f]+ <.*>
bffbf940 147# -> R_X86_64_TPOFF64 sG5
5a68afcf
RM
148 +[0-9a-f]+: 90[ ]+nop *
149 +[0-9a-f]+: 90[ ]+nop *
150 +[0-9a-f]+: 64 48 8b 11[ ]+mov %fs:\(%rcx\),%rdx
151 +[0-9a-f]+: 90[ ]+nop *
152 +[0-9a-f]+: 90[ ]+nop *
153 +[0-9a-f]+: 90[ ]+nop *
154 +[0-9a-f]+: 90[ ]+nop *
bffbf940 155# IE->LE against local var
5a68afcf 156 +[0-9a-f]+: 49 c7 c3 90 ff ff ff[ ]+mov \$0xf+90,%r11
bffbf940 157# sl5
5a68afcf
RM
158 +[0-9a-f]+: 90[ ]+nop *
159 +[0-9a-f]+: 90[ ]+nop *
160 +[0-9a-f]+: 64 4d 8b 23[ ]+mov %fs:\(%r11\),%r12
161 +[0-9a-f]+: 90[ ]+nop *
162 +[0-9a-f]+: 90[ ]+nop *
163 +[0-9a-f]+: 90[ ]+nop *
164 +[0-9a-f]+: 90[ ]+nop *
bffbf940 165# IE->LE against hidden var
5a68afcf
RM
166 +[0-9a-f]+: 48 c7 c2 b0 ff ff ff[ ]+mov \$0xf+b0,%rdx
167 +[0-9a-f]+: 90[ ]+nop *
168 +[0-9a-f]+: 90[ ]+nop *
169 +[0-9a-f]+: 64 48 8b 12[ ]+mov %fs:\(%rdx\),%rdx
bffbf940 170# sh5
5a68afcf
RM
171 +[0-9a-f]+: 90[ ]+nop *
172 +[0-9a-f]+: 90[ ]+nop *
173 +[0-9a-f]+: 90[ ]+nop *
174 +[0-9a-f]+: 90[ ]+nop *
175 +[0-9a-f]+: c9[ ]+leaveq *
176 +[0-9a-f]+: c3[ ]+retq *
bffbf940 177
5a68afcf
RM
178[0-9a-f]+ <_start>:
179 +[0-9a-f]+: 55[ ]+push %rbp
180 +[0-9a-f]+: 48 89 e5[ ]+mov %rsp,%rbp
bffbf940 181# IE against global var
5a68afcf
RM
182 +[0-9a-f]+: 64 4c 8b 1c 25 00 00[ ]+mov %fs:0x0,%r11
183 +[0-9a-f]+: 00 00 *
184 +[0-9a-f]+: 90[ ]+nop *
185 +[0-9a-f]+: 90[ ]+nop *
a24bb4f0 186 +[0-9a-f]+: 4c 03 1d ([0-9a-f]{2} ){4}[ ]+add 0x[0-9a-f]+\(%rip\),%r11 +# [0-9a-f]+ <.*>
bffbf940 187# -> R_X86_64_TPOFF64 sG6
5a68afcf
RM
188 +[0-9a-f]+: 90[ ]+nop *
189 +[0-9a-f]+: 90[ ]+nop *
190 +[0-9a-f]+: 90[ ]+nop *
191 +[0-9a-f]+: 90[ ]+nop *
bffbf940 192# IE -> LE against global var defined in exec
5a68afcf
RM
193 +[0-9a-f]+: 64 48 8b 14 25 00 00[ ]+mov %fs:0x0,%rdx
194 +[0-9a-f]+: 00 00 *
195 +[0-9a-f]+: 90[ ]+nop *
196 +[0-9a-f]+: 90[ ]+nop *
197 +[0-9a-f]+: 48 8d 92 d4 ff ff ff[ ]+lea -0x2c\(%rdx\),%rdx
bffbf940 198# bg6
5a68afcf
RM
199 +[0-9a-f]+: 90[ ]+nop *
200 +[0-9a-f]+: 90[ ]+nop *
201 +[0-9a-f]+: 90[ ]+nop *
202 +[0-9a-f]+: 90[ ]+nop *
bffbf940 203# IE -> LE against local var
5a68afcf
RM
204 +[0-9a-f]+: 64 4c 8b 24 25 00 00[ ]+mov %fs:0x0,%r12
205 +[0-9a-f]+: 00 00 *
206 +[0-9a-f]+: 90[ ]+nop *
207 +[0-9a-f]+: 90[ ]+nop *
208 +[0-9a-f]+: 49 81 c4 f4 ff ff ff[ ]+add \$0xf+f4,%r12
bffbf940 209# bl6
5a68afcf
RM
210 +[0-9a-f]+: 90[ ]+nop *
211 +[0-9a-f]+: 90[ ]+nop *
212 +[0-9a-f]+: 90[ ]+nop *
213 +[0-9a-f]+: 90[ ]+nop *
bffbf940 214# direct %fs access IE -> LE against local var
5a68afcf 215 +[0-9a-f]+: 48 c7 c2 fc ff ff ff[ ]+mov \$0xf+fc,%rdx
bffbf940 216# bl8
5a68afcf
RM
217 +[0-9a-f]+: 90[ ]+nop *
218 +[0-9a-f]+: 90[ ]+nop *
219 +[0-9a-f]+: 64 48 8b 02[ ]+mov %fs:\(%rdx\),%rax
220 +[0-9a-f]+: 90[ ]+nop *
221 +[0-9a-f]+: 90[ ]+nop *
222 +[0-9a-f]+: 90[ ]+nop *
223 +[0-9a-f]+: 90[ ]+nop *
bffbf940 224# IE -> LE against hidden but not local var
5a68afcf
RM
225 +[0-9a-f]+: 64 48 8b 14 25 00 00[ ]+mov %fs:0x0,%rdx
226 +[0-9a-f]+: 00 00 *
227 +[0-9a-f]+: 90[ ]+nop *
228 +[0-9a-f]+: 90[ ]+nop *
229 +[0-9a-f]+: 48 8d 92 b4 ff ff ff[ ]+lea -0x4c\(%rdx\),%rdx
bffbf940 230# sh6
5a68afcf
RM
231 +[0-9a-f]+: 90[ ]+nop *
232 +[0-9a-f]+: 90[ ]+nop *
233 +[0-9a-f]+: 90[ ]+nop *
234 +[0-9a-f]+: 90[ ]+nop *
bffbf940 235# direct %fs access IE -> LE against hidden but not local var
5a68afcf 236 +[0-9a-f]+: 48 c7 c2 bc ff ff ff[ ]+mov \$0xf+bc,%rdx
bffbf940 237# sh8
5a68afcf
RM
238 +[0-9a-f]+: 90[ ]+nop *
239 +[0-9a-f]+: 90[ ]+nop *
240 +[0-9a-f]+: 64 48 8b 02[ ]+mov %fs:\(%rdx\),%rax
241 +[0-9a-f]+: 90[ ]+nop *
242 +[0-9a-f]+: 90[ ]+nop *
243 +[0-9a-f]+: 90[ ]+nop *
244 +[0-9a-f]+: 90[ ]+nop *
bffbf940 245# LE, global var defined in exec
5a68afcf
RM
246 +[0-9a-f]+: 64 48 8b 04 25 00 00[ ]+mov %fs:0x0,%rax
247 +[0-9a-f]+: 00 00 *
248 +[0-9a-f]+: 90[ ]+nop *
249 +[0-9a-f]+: 90[ ]+nop *
250 +[0-9a-f]+: 48 8d 90 64 ff ff ff[ ]+lea -0x9c\(%rax\),%rdx
bffbf940 251# sg2
5a68afcf
RM
252 +[0-9a-f]+: 90[ ]+nop *
253 +[0-9a-f]+: 90[ ]+nop *
254 +[0-9a-f]+: 90[ ]+nop *
255 +[0-9a-f]+: 90[ ]+nop *
bffbf940 256# LE, local var, non-canonical sequence
5a68afcf 257 +[0-9a-f]+: 49 c7 c1 e6 ff ff ff[ ]+mov \$0xf+e6,%r9
bffbf940 258# bl2+2
5a68afcf
RM
259 +[0-9a-f]+: 90[ ]+nop *
260 +[0-9a-f]+: 90[ ]+nop *
261 +[0-9a-f]+: 64 48 8b 14 25 00 00[ ]+mov %fs:0x0,%rdx
262 +[0-9a-f]+: 00 00 *
263 +[0-9a-f]+: 90[ ]+nop *
264 +[0-9a-f]+: 90[ ]+nop *
265 +[0-9a-f]+: 4c 01 ca[ ]+add %r9,%rdx
266 +[0-9a-f]+: 90[ ]+nop *
267 +[0-9a-f]+: 90[ ]+nop *
268 +[0-9a-f]+: 90[ ]+nop *
269 +[0-9a-f]+: 90[ ]+nop *
bffbf940 270# LE, hidden var defined in exec, non-canonical sequence
5a68afcf
RM
271 +[0-9a-f]+: 64 48 8b 14 25 00 00[ ]+mov %fs:0x0,%rdx
272 +[0-9a-f]+: 00 00 *
273 +[0-9a-f]+: 90[ ]+nop *
274 +[0-9a-f]+: 90[ ]+nop *
275 +[0-9a-f]+: 48 81 c2 a5 ff ff ff[ ]+add \$0xf+a5,%rdx
bffbf940 276# sh2+1
5a68afcf
RM
277 +[0-9a-f]+: 90[ ]+nop *
278 +[0-9a-f]+: 90[ ]+nop *
279 +[0-9a-f]+: 90[ ]+nop *
280 +[0-9a-f]+: 90[ ]+nop *
bffbf940
JJ
281# Direct %fs access
282# LE, global var defined in exec
5a68afcf
RM
283 +[0-9a-f]+: 64 48 8b 04 25 68 ff[ ]+mov %fs:0xf+68,%rax
284 +[0-9a-f]+: ff ff *
bffbf940 285# sg3
5a68afcf
RM
286 +[0-9a-f]+: 90[ ]+nop *
287 +[0-9a-f]+: 90[ ]+nop *
288 +[0-9a-f]+: 90[ ]+nop *
289 +[0-9a-f]+: 90[ ]+nop *
bffbf940 290# LE, local var
5a68afcf
RM
291 +[0-9a-f]+: 64 4c 8b 14 25 eb ff[ ]+mov %fs:0xf+eb,%r10
292 +[0-9a-f]+: ff ff *
bffbf940 293# bl3+3
5a68afcf
RM
294 +[0-9a-f]+: 90[ ]+nop *
295 +[0-9a-f]+: 90[ ]+nop *
296 +[0-9a-f]+: 90[ ]+nop *
297 +[0-9a-f]+: 90[ ]+nop *
bffbf940 298# LE, hidden var defined in exec
5a68afcf
RM
299 +[0-9a-f]+: 64 48 8b 14 25 a9 ff[ ]+mov %fs:0xf+a9,%rdx
300 +[0-9a-f]+: ff ff *
bffbf940 301# sh3+1
5a68afcf
RM
302 +[0-9a-f]+: 90[ ]+nop *
303 +[0-9a-f]+: 90[ ]+nop *
304 +[0-9a-f]+: 90[ ]+nop *
305 +[0-9a-f]+: 90[ ]+nop *
6769d501 306# LE, large model
5a68afcf
RM
307 +[0-9a-f]+: 48 ba a5 ff ff ff ff[ ]+movabs \$0xffffffffffffffa5,%rdx
308 +[0-9a-f]+: ff ff ff *
309 +[0-9a-f]+: c9[ ]+leaveq *
310 +[0-9a-f]+: c3[ ]+retq *
This page took 0.853773 seconds and 4 git commands to generate.