binutils-gdb/ld/testsuite/ld-powerpc/tlsdesc2.wf
Alan Modra 3cd7c7d7ef PPC64_OPT_LOCALENTRY is incompatible with tail calls
The save of r2 in __glink_PLTresolve is the culprit.  Remove it,
unless we know we need it for --plt-localentry.  --plt-localentry
should not be used with power10 pc-relative code that makes tail
calls.

The patch also removes use of r2 as a scratch reg in the ELFv2
__glink_PLTresolve.  Using r2 isn't a problem, this is just reducing
the number of scratch regs.

bfd/
	* elf64-ppc.c (GLINK_PLTRESOLVE_SIZE): Depend on has_plt_localentry0.
	(LD_R0_0R11, ADD_R11_R0_R11): Define.
	(ppc64_elf_tls_setup): Disable params->plt_localentry0 when power10
	code detected.
	(ppc64_elf_size_stubs): Update __glink_PLTresolve eh_frame.
	(ppc64_elf_build_stubs): Move r2 save to start of __glink_PLTresolve,
	and only emit for has_plt_localentry0.  Don't use r2 in the stub.
ld/
	* testsuite/ld-powerpc/elfv2so.d,
	* testsuite/ld-powerpc/notoc2.d,
	* testsuite/ld-powerpc/tlsdesc.wf,
	* testsuite/ld-powerpc/tlsdesc2.d,
	* testsuite/ld-powerpc/tlsdesc2.wf,
	* testsuite/ld-powerpc/tlsopt5.d,
	* testsuite/ld-powerpc/tlsopt5.wf,
	* testsuite/ld-powerpc/tlsopt6.d,
	* testsuite/ld-powerpc/tlsopt6.wf: Update __glink_PLTresolve.
2020-09-26 19:03:02 +09:30

50 lines
1.2 KiB
Plaintext

Contents of the \.eh_frame section:
0+ 0+10 0+ CIE
Version: 1
Augmentation: "zR"
Code alignment factor: 4
Data alignment factor: -8
Return address column: 65
Augmentation data: 1b
DW_CFA_def_cfa: r1 ofs 0
0+14 0+34 0+18 FDE cie=0+ pc=0+260\.\.0+300
DW_CFA_advance_loc: 72 to 0+2a8
DW_CFA_def_cfa_offset: 96
DW_CFA_offset_extended_sf: r65 at cfa\+16
DW_CFA_offset: r4 at cfa-64
DW_CFA_offset: r5 at cfa-56
DW_CFA_offset: r6 at cfa-48
DW_CFA_offset: r7 at cfa-40
DW_CFA_offset: r8 at cfa-32
DW_CFA_offset: r9 at cfa-24
DW_CFA_offset: r10 at cfa-16
DW_CFA_offset: r11 at cfa-8
DW_CFA_advance_loc: 56 to 0+2e0
DW_CFA_def_cfa_offset: 0
DW_CFA_restore: r4
DW_CFA_restore: r5
DW_CFA_restore: r6
DW_CFA_restore: r7
DW_CFA_restore: r8
DW_CFA_restore: r9
DW_CFA_restore: r10
DW_CFA_restore: r11
DW_CFA_advance_loc: 8 to 0+2e8
DW_CFA_restore_extended: r65
DW_CFA_nop
DW_CFA_nop
DW_CFA_nop
0+4c 0+14 0+50 FDE cie=0+ pc=0+318\.\.0+350
DW_CFA_advance_loc: 8 to 0+320
DW_CFA_register: r65 in r0
DW_CFA_advance_loc: 8 to 0+328
DW_CFA_restore_extended: r65
0+64 0+10 0+68 FDE cie=0+ pc=0+300\.\.0+30c
DW_CFA_nop
DW_CFA_nop
DW_CFA_nop