commit
292676c15a615b5a95bede9ee91004d3f7ee7dfd
Author: H.J. Lu <hjl.tools@gmail.com>
Date: Thu Feb 13 13:44:17 2020 -0800
x86: Resolve PLT32 reloc aganst local symbol to section
resolved PLT32 relocation against local symbol to section and
commit
2585b7a5ce5830e60a089aa2316a329558902f0c
Author: H.J. Lu <hjl.tools@gmail.com>
Date: Sun Jul 19 06:51:19 2020 -0700
x86: Change PLT32 reloc against section to PC32
turned PLT32 relocation against section into PC32 relocation. But these
transformations are valid only for PC-relative relocations. Add fx_pcrel
check for PC-relative relocations when performing these transformations
to keep PLT32 relocation in `movq $foo@PLT, %rax`.
gas/
PR gas/32196
* config/tc-i386.c (tc_i386_fix_adjustable): Return fixP->fx_pcrel
for PLT32 relocations.
(i386_validate_fix): Turn PLT32 relocation into PC32 relocation
only if fixp->fx_pcrel is set.
* testsuite/gas/i386/reloc32.d: Updated.
* testsuite/gas/i386/reloc64.d: Likewise.
* testsuite/gas/i386/reloc32.s: Add PR gas/32196 test.
* testsuite/gas/i386/reloc64.s: Likewise.
ld/
PR gas/32196
* testsuite/ld-x86-64/plt3.s: New file.
* testsuite/ld-x86-64/x86-64.exp: Run plt3.
Signed-off-by: H.J. Lu <hjl.tools@gmail.com>
|| fixP->fx_r_type == BFD_RELOC_VTABLE_INHERIT
|| fixP->fx_r_type == BFD_RELOC_VTABLE_ENTRY)
return 0;
+ /* Resolve PLT32 relocation against local symbol to section only for
+ PC-relative relocations. */
+ if (fixP->fx_r_type == BFD_RELOC_386_PLT32
+ || fixP->fx_r_type == BFD_RELOC_X86_64_PLT32)
+ return fixP->fx_pcrel;
return 1;
}
#endif
{
/* NB: Commit 292676c1 resolved PLT32 reloc aganst local symbol
to section. Since PLT32 relocation must be against symbols,
- turn such PLT32 relocation into PC32 relocation. */
+ turn such PLT32 relocation into PC32 relocation. NB: We can
+ turn PLT32 relocation into PC32 relocation only for PC-relative
+ relocations since non-PC-relative relocations need PLT entries.
+ */
if (fixp->fx_addsy
+ && fixp->fx_pcrel
&& (fixp->fx_r_type == BFD_RELOC_386_PLT32
|| fixp->fx_r_type == BFD_RELOC_X86_64_PLT32)
&& symbol_section_p (fixp->fx_addsy))
.*[ ]+R_386_TLS_LE[ ]+xtrn
.*[ ]+R_386_TLS_LE_32[ ]+xtrn
.*[ ]+R_386_TLS_LE_32[ ]+xtrn
+.*[ ]+R_386_PLT32[ ]+ptr
Disassembly of section \.data:
#...
.*[ ]+R_386_32[ ]+xtrn
.long xtrn@got + 4
.long xtrn@got - 4
bad .long xtrn@plt - .
+
+ .text
+ movl $ptr@PLT, %eax
+
+ .data
+ptr:
+ .dc.a 0
.*[ ]+R_X86_64_32[ ]+xtrn
.*[ ]+R_X86_64_GOT64[ ]+ptr
.*[ ]+R_X86_64_GOTOFF64[ ]+Ldst
+.*[ ]+R_X86_64_PLT32[ ]+ptr
Disassembly of section \.data:
#...
.*[ ]+R_X86_64_64[ ]+xtrn
.text
movabs $ptr@GOT, %rax
movabs $Ldst@GOTOFF, %rdx
+ movq $ptr@PLT, %rax
+
.data
ptr:
.quad 0
--- /dev/null
+ .text
+ .global _start
+_start:
+ movq $foo@PLT, %rax
+ leaq -11(%rip), %rbx
+ leaq (%rbx, %rax), %rax
+ call *%rax
+
+ # Write out "PASS\n".
+ movl $5, %edx
+ movl $.LC0, %esi
+ movl $1, %edi
+ movl $1, %eax
+ syscall
+
+ # exit
+ movq $60, %rax
+ movq $0, %rdi
+ syscall
+
+foo:
+ ret
+
+ .section .rodata.str1.1,"aMS",@progbits,1
+.LC0:
+ .string "PASS\n"
+ .section .note.GNU-stack,"",@progbits
"pr32189" \
"pass.out" \
] \
+ [list \
+ "Run plt3" \
+ "$NOPIE_LDFLAGS -nostdlib -nostartfiles" \
+ "" \
+ { plt3.s } \
+ "plt3" \
+ "pass.out" \
+ ] \
]
# Run-time tests which require working ifunc attribute support.