binutils-gdb/ld/testsuite/ld-powerpc/tls32.s
Alan Modra 9a23f96e91 PowerPC TPREL16_HA/LO reloc optimization
In the TLS GD/LD to LE optimization, ld replaces a sequence like

 addi 3,2,x@got@tlsgd		R_PPC64_GOT_TLSGD16	x
 bl __tls_get_addr(x@tlsgd)	R_PPC64_TLSGD		x
				R_PPC64_REL24		__tls_get_addr
 nop

with

 addis 3,13,x@tprel@ha		R_PPC64_TPREL16_HA	x
 addi 3,3,x@tprel@l		R_PPC64_TPREL16_LO	x
 nop

When the tprel offset is small, this can be further optimized to

 nop
 addi 3,13,x@tprel
 nop

bfd/
	* elf64-ppc.c (struct ppc_link_hash_table): Add do_tls_opt.
	(ppc64_elf_tls_optimize): Set it.
	(ppc64_elf_relocate_section): Nop addis on TPREL16_HA, and convert
	insn on TPREL16_LO and TPREL16_LO_DS relocs to use r13 when
	addis would add zero.
	* elf32-ppc.c (struct ppc_elf_link_hash_table): Add do_tls_opt.
	(ppc_elf_tls_optimize): Set it.
	(ppc_elf_relocate_section): Nop addis on TPREL16_HA, and convert
	insn on TPREL16_LO relocs to use r2 when addis would add zero.
gold/
	* powerpc.cc (Target_powerpc::Relocate::relocate): Nop addis on
	TPREL16_HA, and convert insn on TPREL16_LO and TPREL16_LO_DS
	relocs to use r2/r13 when addis would add zero.
ld/
	* testsuite/ld-powerpc/tls.s: Add calls with tls markers.
	* testsuite/ld-powerpc/tls32.s: Likewise.
	* testsuite/ld-powerpc/powerpc.exp: Run tls marker tests.
	* testsuite/ld-powerpc/tls.d: Adjust for TPREL16_HA/LO optimization.
	* testsuite/ld-powerpc/tlsexe.d: Likewise.
	* testsuite/ld-powerpc/tlsexetoc.d: Likewise.
	* testsuite/ld-powerpc/tlsld.d: Likewise.
	* testsuite/ld-powerpc/tlsmark.d: Likewise.
	* testsuite/ld-powerpc/tlsopt4.d: Likewise.
	* testsuite/ld-powerpc/tlstoc.d: Likewise.
2017-08-30 20:43:31 +09:30

120 lines
2.6 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
bl __tls_get_addr+0x8000(ld0@tlsld)@plt #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