mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
e9c11d58b9
Since MPX support has been removed from x86-64 psABI, remove BND from 64-bit IBT PLT by using x32 IBT PLT. bfd/ PR ld/29851 * elf64-x86-64.c (elf_x86_64_get_synthetic_symtab): Also check x32 IBT PLT for 64-bit. (elf_x86_64_link_setup_gnu_properties): Always use x32 IBT PLT. ld/ PR ld/29851 * testsuite/ld-x86-64/ibt-plt-1.d: Updated. * testsuite/ld-x86-64/ibt-plt-2a.d: Likewise. * testsuite/ld-x86-64/ibt-plt-2b.d: Likewise. * testsuite/ld-x86-64/ibt-plt-2c.d: Likewise. * testsuite/ld-x86-64/ibt-plt-2d.d: Likewise. * testsuite/ld-x86-64/ibt-plt-3a.d: Likewise. * testsuite/ld-x86-64/ibt-plt-3b.d: Likewise. * testsuite/ld-x86-64/ibt-plt-3c.d: Likewise. * testsuite/ld-x86-64/ibt-plt-3d.d: Likewise. * testsuite/ld-x86-64/plt-main-ibt-x32.dd: Moved to ... * testsuite/ld-x86-64/plt-main-ibt.dd: This. * testsuite/ld-x86-64/x86-64.exp: Don't use plt-main-ibt-x32.dd.
44 lines
1.6 KiB
D
44 lines
1.6 KiB
D
#source: ibt-plt-3.s
|
|
#as: --64 -defsym __64_bit__=1
|
|
#ld: -shared -m elf_x86_64 -z ibt --hash-style=sysv -z max-page-size=0x200000 -z noseparate-code
|
|
#objdump: -dw
|
|
|
|
.*: +file format .*
|
|
|
|
|
|
Disassembly of section .plt:
|
|
|
|
[a-f0-9]+ <.plt>:
|
|
+[a-f0-9]+: ff 35 ([0-9a-f]{2} ){4}[ ]+push 0x[a-f0-9]+\(%rip\) # [a-f0-9]+ <_GLOBAL_OFFSET_TABLE_\+0x8>
|
|
+[a-f0-9]+: ff 25 ([0-9a-f]{2} ){4}[ ]+jmp \*0x[a-f0-9]+\(%rip\) # [a-f0-9]+ <_GLOBAL_OFFSET_TABLE_\+0x10>
|
|
+[a-f0-9]+: 0f 1f 40 00 nopl 0x0\(%rax\)
|
|
+[a-f0-9]+: f3 0f 1e fa endbr64
|
|
+[a-f0-9]+: 68 00 00 00 00 push \$0x0
|
|
+[a-f0-9]+: e9 e2 ff ff ff jmp [a-f0-9]+ <.*>
|
|
+[a-f0-9]+: 66 90 xchg %ax,%ax
|
|
+[a-f0-9]+: f3 0f 1e fa endbr64
|
|
+[a-f0-9]+: 68 01 00 00 00 push \$0x1
|
|
+[a-f0-9]+: e9 d2 ff ff ff jmp [a-f0-9]+ <.*>
|
|
+[a-f0-9]+: 66 90 xchg %ax,%ax
|
|
|
|
Disassembly of section .plt.sec:
|
|
|
|
[a-f0-9]+ <bar1@plt>:
|
|
+[a-f0-9]+: f3 0f 1e fa endbr64
|
|
+[a-f0-9]+: ff 25 ([0-9a-f]{2} ){4}[ ]+jmp \*0x[a-f0-9]+\(%rip\) # [a-f0-9]+ <bar1>
|
|
+[a-f0-9]+: 66 0f 1f 44 00 00 nopw 0x0\(%rax,%rax,1\)
|
|
|
|
[a-f0-9]+ <bar2@plt>:
|
|
+[a-f0-9]+: f3 0f 1e fa endbr64
|
|
+[a-f0-9]+: ff 25 ([0-9a-f]{2} ){4}[ ]+jmp \*0x[a-f0-9]+\(%rip\) # [a-f0-9]+ <bar2>
|
|
+[a-f0-9]+: 66 0f 1f 44 00 00 nopw 0x0\(%rax,%rax,1\)
|
|
|
|
Disassembly of section .text:
|
|
|
|
[a-f0-9]+ <foo>:
|
|
+[a-f0-9]+: 48 83 ec 08 sub \$0x8,%rsp
|
|
+[a-f0-9]+: e8 e7 ff ff ff call [a-f0-9]+ <bar2@plt>
|
|
+[a-f0-9]+: 48 83 c4 08 add \$0x8,%rsp
|
|
+[a-f0-9]+: e9 ce ff ff ff jmp [a-f0-9]+ <bar1@plt>
|
|
#pass
|