mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
160eba9301
The syntax we ended up with for -m32 -fPIC calls to __tls_get_addr is rather weird. bl __tls_get_addr+0x8000(gd0@tlsgd)@plt This came about by accident, probably due to requiring the arg reloc before the call reloc. Of course the @plt really belongs with __tls_get_addr since it affects the call rather than the call arg, and it isn't a great deal of trouble to ensure the relocs are emitted in the correct order. This patch supports a newer syntax, like so: bl __tls_get_addr+0x8000@plt(gd0@tlsgd) gas/ * config/tc-ppc.c (parse_tls_arg): New function, extracted.. (md_assembler): ..from here. Call it after parsing other suffix modifiers too. ld/ * testsuite/ld-powerpc/tls32.s: Test new @plt syntax.
121 lines
2.7 KiB
ArmAsm
121 lines
2.7 KiB
ArmAsm
.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
|
|
|