1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
|
.section ".tbss","awT",@nobits
.global _start,gd0,ld0,ld1,ld2,ie0,le0,le1
.align 2
gd0: .space 4
ld0: .space 4
ld1: .space 4
ld2: .space 4
ie0: .space 4
le0: .space 4
le1: .space 4
.section ".tdata","awT",@progbits
.align 2
gd4: .long 0x12345678
ld4: .long 0x23456789
ld5: .long 0x3456789a
ld6: .long 0x456789ab
ie4: .long 0x56789abc
le4: .long 0x6789abcd
le5: .long 0x789abcde
.section ".got2","aw"
.LCTOC1 = .+32768
.text
_start:
bcl 20,31,0f
0:
mflr 30
addis 30,30,.LCTOC1-0b@ha
addi 30,30,.LCTOC1-0b@l
#extern syms
#GD
addi 3,31,gd@got@tlsgd #R_PPC_GOT_TLSGD16 gd
.ifdef TLSMARK
bl __tls_get_addr(gd@tlsgd) #R_PPC_TLSGD gd
#R_PPC_REL24 __tls_get_addr
.else
bl __tls_get_addr #R_PPC_REL24 __tls_get_addr
.endif
#LD
addi 3,31,ld@got@tlsld #R_PPC_GOT_TLSLD16 ld
.ifdef TLSMARK
bl __tls_get_addr(ld@tlsld) #R_PPC_TLSLD ld
#R_PPC_REL24 __tls_get_addr
.else
bl __tls_get_addr #R_PPC_REL24 __tls_get_addr
.endif
#global syms
#GD
addi 3,31,gd0@got@tlsgd #R_PPC_GOT_TLSGD16 gd0
.ifdef TLSMARK
bl __tls_get_addr+0x8000(gd0@tlsgd)@plt #R_PPC_TLSGD gd0
#R_PPC_PLTREL24 __tls_get_addr+0x8000
.else
bl __tls_get_addr+0x8000@plt #R_PPC_PLTREL24 __tls_get_addr+0x8000
.endif
#LD
addi 3,31,ld0@got@tlsld #R_PPC_GOT_TLSLD16 ld0
.ifdef TLSMARK
#exercise saner new syntax with @plt before the arg
bl __tls_get_addr+0x8000@plt(ld0@tlsld) #R_PPC_TLSLD ld0
#R_PPC_PLTREL24 __tls_get_addr+0x8000
.else
bl __tls_get_addr+0x8000@plt #R_PPC_PLTREL24 __tls_get_addr+0x8000
.endif
addi 9,3,ld0@dtprel #R_PPC_DTPREL16 ld0
addis 9,3,ld1@dtprel@ha #R_PPC_DTPREL16_HA ld1
lwz 10,ld1@dtprel@l(9) #R_PPC_DTPREL16_LO ld1
#IE
lwz 9,ie0@got@tprel(31) #R_PPC_GOT_TPREL16 ie0
lhzx 10,9,ie0@tls #R_PPC_TLS ie0
#LE
lbz 10,le0@tprel(2) #R_PPC_TPREL16 le0
addis 9,2,le1@tprel@ha #R_PPC_TPREL16_HA le1
stb 10,le1@tprel@l(9) #R_PPC_TPREL16_LO le1
#local syms, use a different got reg too.
#GD
addi 3,30,gd4@got@tlsgd #R_PPC_GOT_TLSGD16 gd4
.ifdef TLSMARK
bl __tls_get_addr(gd4@tlsgd) #R_PPC_TLSGD gd4
#R_PPC_REL24 __tls_get_addr
.else
bl __tls_get_addr #R_PPC_REL24 __tls_get_addr
.endif
#LD
addi 3,30,ld4@got@tlsld #R_PPC_GOT_TLSLD16 ld4
.ifdef TLSMARK
bl __tls_get_addr(ld4@tlsld) #R_PPC_TLSLD ld4
#R_PPC_REL24 __tls_get_addr
.else
bl __tls_get_addr #R_PPC_REL24 __tls_get_addr
.endif
stw 10,ld4@dtprel(3) #R_PPC_DTPREL16 ld4
addis 9,3,ld5@dtprel@ha #R_PPC_DTPREL16_HA ld5
stw 10,ld5@dtprel@l(9) #R_PPC_DTPREL16_LO ld5
#IE
lwz 9,ie0@got@tprel(30) #R_PPC_GOT_TPREL16 ie4
sthx 10,9,ie0@tls #R_PPC_TLS ie4
#LE
lhz 10,le4@tprel(2) #R_PPC_TPREL16 le4
addis 9,2,le5@tprel@ha #R_PPC_TPREL16_HA le5
lha 10,le5@tprel@l(9) #R_PPC_TPREL16_LO le5
|