binutils-gdb/ld/testsuite/ld-powerpc/abs-shared.d
Alan Modra 3a3a4c1fe4 PowerPC64 treatment of absolute symbols
Supporting -static-pie on PowerPC64 requires the linker to properly
treat SHN_ABS symbols for cases like glibc's _nl_current_LC_CTYPE_used
absolute symbol.  I've been slow to fix the linker on powerpc because
there is some chance that this will break some shared libraries or
PIEs.

bfd/
	* elf64-ppc.c (ppc64_elf_check_relocs): Consolidate local sym
	handling code.  Don't count dyn relocs against non-dynamic
	absolute symbols.
	(dec_dynrel_count): Adjust to suit.
	(ppc64_elf_edit_toc): Don't remove entries for absolute symbols
	when pic.
	(allocate_got): Don't allocate space for got relocs against
	non-dynamic absolute syms.
	(ppc64_elf_layout_multitoc): Likewise.
	(got_and_plt_relr): Likewise.
	(ppc64_elf_size_dynamic_sections): Likewise for local got.
	(got_and_plt_relr_for_local_syms): Likewise.
	(ppc64_elf_size_stubs): Don't allocate space for relr either.
	(ppc64_elf_relocate_section): Don't write relocs against non-dynamic
	absolute symbols.  Don't optimise got and toc code sequences
	loading absolute symbol entries.
ld/
	* testsuite/ld-powerpc/abs-reloc.s,
	* testsuite/ld-powerpc/abs-static.d,
	* testsuite/ld-powerpc/abs-static.r,
	* testsuite/ld-powerpc/abs-pie.d,
	* testsuite/ld-powerpc/abs-pie.r,
	* testsuite/ld-powerpc/abs-shared.d,
	* testsuite/ld-powerpc/abs-shared.r,
	* testsuite/ld-powerpc/abs-pie-relr.d,
	* testsuite/ld-powerpc/abs-pie-relr.r,
	* testsuite/ld-powerpc/abs-shared-relr.d,
	* testsuite/ld-powerpc/abs-shared-relr.r: New tests.
	* testsuite/ld-powerpc/powerpc.exp: Run them.
2022-02-03 13:40:41 +10:30

35 lines
1.4 KiB
Makefile

#source: abs-reloc.s
#as: -a64
#ld: -melf64ppc -shared --hash-style=sysv --defsym a=1 --defsym 'HIDDEN(b=2)' --defsym c=0x123456789abcdef0
#objdump: -sdr
#...
Contents of section \.got:
.* (00000000 00018400|00840100 00000000) 00000000 00000000 .*
.* (00000000 00000002|02000000 00000000) 00000000 00000000 .*
.* (00000000 00000002|02000000 00000000) 00000000 00000000 .*
.* 00000000 00000000 .*
Contents of section \.data:
.* (00000000 00010438|38040100 00000000) 00000000 00000000 .*
.* (00000000 00000002|02000000 00000000) 00000000 00000000 .*
#...
.* <_start>:
.*: (3c 4c 00 02|02 00 4c 3c) addis r2,r12,2
.*: (38 42 81 a0|a0 81 42 38) addi r2,r2,-32352
.*: (60 00 00 00|00 00 00 60) nop
.*: (38 62 80 38|38 80 62 38) addi r3,r2,-32712
.*: (60 00 00 00|00 00 00 60) nop
.*: (e8 82 80 08|08 80 82 e8) ld r4,-32760\(r2\)
.*: (60 00 00 00|00 00 00 60) nop
.*: (e8 a2 80 10|10 80 a2 e8) ld r5,-32752\(r2\)
.*: (60 00 00 00|00 00 00 60) nop
.*: (e8 c2 80 18|18 80 c2 e8) ld r6,-32744\(r2\)
.*: (60 00 00 00|00 00 00 60) nop
.*: (38 e2 80 38|38 80 e2 38) addi r7,r2,-32712
.*: (3d 02 00 00|00 00 02 3d) addis r8,r2,0
.*: (e9 08 80 30|30 80 08 e9) ld r8,-32720\(r8\)
.*: (3d 22 00 00|00 00 22 3d) addis r9,r2,0
.*: (e9 29 80 20|20 80 29 e9) ld r9,-32736\(r9\)
.*: (3d 42 00 00|00 00 42 3d) addis r10,r2,0
.*: (e9 4a 80 28|28 80 4a e9) ld r10,-32728\(r10\)