Eric Botcazou c20c30f615 Fix PR ld/22263 on SPARC.
This is -fpie -pie generating dynamic relocations in the text section,
simply because no TLS transitions are applied in PIE mode.  The meat
of the patch is to turn calls to bfd_link_pic (info) in TLS-related code
into !bfd_link_executable (info) and there are quite a lot of them...

bfd/
	* elfxx-sparc.c (sparc_elf_tls_transition): Turn call to bfd_link_pic
	into call to !bfd_link_executable and tidy up.
	(_bfd_sparc_elf_check_relocs): Fix formatting and tidy up.
	<R_SPARC_TLS_LE_HIX22>: Turn call to bfd_link_pic into call to
	!bfd_link_executable.
	<R_SPARC_TLS_IE_HI22>: Likewise.
	<GOT relocations>: Remove useless code, tidy and merge blocks.
	<R_SPARC_TLS_GD_CALL>: Turn call to bfd_link_pic into call to
	!bfd_link_executable.
	<R_SPARC_WPLT30>: Tidy up.
	(_bfd_sparc_elf_gc_mark_hook): Turn call to bfd_link_pic into call
	to !bfd_link_executable.
	(allocate_dynrelocs): Likewise.
	(_bfd_sparc_elf_relocate_section): Fix formatting and tidy up.
	<R_SPARC_TLS_GD_HI22>: Merge into...
	<R_SPARC_TLS_GD_LO10>: ...this.  Adjust 4th argument in call to
	sparc_elf_tls_transition and remove redundant code.
	<R_SPARC_TLS_LDM_HI22>: Turn call to bfd_link_pic into call to
	!bfd_link_executable.
	<R_SPARC_TLS_LDO_HIX22>: Likewise.
	<R_SPARC_TLS_LE_HIX22>: Likewise.  Tidy up.
	<R_SPARC_TLS_LDM_CALL>: Likewise.
	<R_SPARC_TLS_GD_CALL>: Likewise.  Tidy up.
	<R_SPARC_TLS_GD_ADD>: Likewise.
	<R_SPARC_TLS_LDM_ADD>: Likewise.
	<R_SPARC_TLS_LDO_ADD>: Likewise.
	<R_SPARC_TLS_IE_LD>: Likewise.
ld/
	* testsuite/ld-elf/tls.exp (AFLAGS_PIC): Define on SPARC.
	(pr22263-1): Pass AFLAGS_PIC to the assembler.
	* testsuite/ld-sparc/tlspie32.s: Add test for other 3 transitions.
	* testsuite/ld-sparc/tlspie32.dd: Adjust to above.
	* testsuite/ld-sparc/tlspie64.s: Add test for other 3 transitions.
	* testsuite/ld-sparc/tlspie64.dd: Adjust to above.
2018-02-06 18:17:39 +01:00

66 lines
2.0 KiB
Plaintext

#source: tlspie64.s
#source: tlspic.s
#as: --64 -Av9 -K PIC
#ld: -shared -melf64_sparc
#objdump: -drj.text
#target: sparc*-*-*
.*: +file format elf64-sparc
Disassembly of section .text:
0[0-9a-f]+ <foo-0x8>:
+[0-9a-f]+: 81 c3 e0 08 retl
+[0-9a-f]+: ae 03 c0 17 add %o7, %l7, %l7
0[0-9a-f]+ <foo>:
+[0-9a-f]+: 9d e3 bf 60 save %sp, -160, %sp
+[0-9a-f]+: 2f 00 04 00 sethi %hi\(0x100000\), %l7
+[0-9a-f]+: 7f ff ff fc call [0-9a-f]+ <.*>
+[0-9a-f]+: ae 05 e2 08 add %l7, 0x208, %l7 ! 100208 <.*>
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 03 00 00 00 sethi %hi\(0\), %g1
+[0-9a-f]+: 82 00 60 08 add %g1, 8, %g1 ! 8 <.*>
+[0-9a-f]+: d0 5d c0 01 ldx \[ %l7 \+ %g1 ], %o0
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 90 01 c0 08 add %g7, %o0, %o0
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 03 00 00 00 sethi %hi\(0\), %g1
+[0-9a-f]+: 82 18 7f f4 xor %g1, -12, %g1
+[0-9a-f]+: 90 01 c0 01 add %g7, %g1, %o0
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 90 10 00 00 mov %g0, %o0
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 03 00 00 00 sethi %hi\(0\), %g1
+[0-9a-f]+: 82 18 7f f8 xor %g1, -8, %g1
+[0-9a-f]+: 82 01 c0 01 add %g7, %g1, %g1
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 03 00 00 00 sethi %hi\(0\), %g1
+[0-9a-f]+: 82 18 7f fc xor %g1, -4, %g1
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 82 01 c0 01 add %g7, %g1, %g1
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 01 00 00 00 nop
+[0-9a-f]+: 81 c7 e0 08 ret
+[0-9a-f]+: 81 e8 00 00 restore