Re-add support for lbarx, lharx, stbcx. and sthcx. insns back to the E6500 cpu.
[binutils-gdb.git] / ld / testsuite / ld-ia64 / tlspic1.s
blob5242d28b4665e2f940636d82f4298a75cc0a6b65
1 /* Force .data aligned to 4K, so .got very likely gets at 0x13190
2 (0x60 bytes .tdata and 0x130 bytes .dynamic) */
3 .data
4 .balign 4096
5 .section ".tdata", "awT", @progbits
6 .globl sg1, sg2, sg3, sg4, sg5, sg6, sg7, sg8
7 .globl sh1, sh2, sh3, sh4, sh5, sh6, sh7, sh8
8 .hidden sh1, sh2, sh3, sh4, sh5, sh6, sh7, sh8
9 sg1: .long 17
10 sg2: .long 18
11 sg3: .long 19
12 sg4: .long 20
13 sg5: .long 21
14 sg6: .long 22
15 sg7: .long 23
16 sg8: .long 24
17 sl1: .long 65
18 sl2: .long 66
19 sl3: .long 67
20 sl4: .long 68
21 sl5: .long 69
22 sl6: .long 70
23 sl7: .long 71
24 sl8: .long 72
25 sh1: .long 257
26 sh2: .long 258
27 sh3: .long 259
28 sh4: .long 260
29 sh5: .long 261
30 sh6: .long 262
31 sh7: .long 263
32 sh8: .long 264
33 .explicit
34 .pred.safe_across_calls p1-p5,p16-p63
35 /* Force .text aligned to 4K, so it very likely gets at 0x1000. */
36 .text
37 .balign 4096
38 .globl fn1#
39 .proc fn1#
40 fn1:
41 .prologue 12, 33
42 .mib
43 .save ar.pfs, r34
44 alloc r34 = ar.pfs, 0, 3, 2, 0
45 .save rp, r33
46 mov r33 = b0
48 /* GD */
49 addl r14 = @ltoff(@dtpmod(sg1#)), gp
50 addl r15 = @ltoff(@dtprel(sg1#)), gp
52 ld8 out0 = [r14]
53 ld8 out1 = [r15]
54 br.call.sptk.many b0 = __tls_get_addr#
57 /* GD against hidden symbol */
58 addl r14 = @ltoff(@dtpmod(sh2#)), gp
59 addl r15 = @ltoff(@dtprel(sh2#)), gp
61 ld8 out0 = [r14]
62 ld8 out1 = [r15]
63 br.call.sptk.many b0 = __tls_get_addr#
66 /* LD */
67 addl r14 = @ltoff(@dtpmod(sl1#)), gp
68 addl out1 = @dtprel(sl1#) + 1, r0
70 ld8 out0 = [r14]
71 br.call.sptk.many b0 = __tls_get_addr#
74 /* LD with 4 variables variables */
75 addl r14 = @ltoff(@dtpmod(sh1#)), gp
76 mov out1 = r0
78 ld8 out0 = [r14]
79 br.call.sptk.many b0 = __tls_get_addr#
81 mov r2 = r8
83 addl r14 = @dtprel(sh1#), r2
84 addl r15 = @dtprel(sH1#) + 2, r2
86 adds r14 = @dtprel(sh5#) + 3, r8
87 movl r15 = @dtprel(sH5#) + 1
89 add r15 = r15, r8
92 /* IE against global */
93 addl r14 = @ltoff(@tprel(sg2#)), gp
95 ld8 r15 = [r14]
97 add r14 = r15, r13
100 /* IE against local and hidden */
101 addl r14 = @ltoff(@tprel(sl2#)), gp
102 addl r15 = @ltoff(@tprel(sh2#)), gp
104 ld8 r14 = [r14]
105 ld8 r15 = [r15]
107 add r14 = r14, r13
108 add r15 = r15, r13
111 mov ar.pfs = r34
112 mov b0 = r33
113 br.ret.sptk.many b0
114 .endp fn1#