binutils-gdb/ld/testsuite/ld-ifunc/pr17154-i386-now.d
Jan Beulich 36938cabf0 x86: avoid attaching suffixes to unambiguous insns
"Unambiguous" is is in particular taking as reference the assembler,
which also accepts certain insns - despite them allowing for varying
operand size, and hence in principle being ambiguous - without any
suffix. For example, from the very beginning of the life of x86-64 I had
trouble understanding why a plain and simple RET had to be printed as
RETQ. In case someone really used the 16-bit form, RETW disambiguates
the two quite fine.
2020-07-15 08:53:55 +02:00

53 lines
1.4 KiB
Makefile

#source: pr17154-x86.s
#ld: -z now -m elf_i386 -shared --hash-style=sysv -z noseparate-code
#as: --32
#objdump: -dw
#target: x86_64-*-* i?86-*-*
#notarget: *-*-lynxos *-*-nto*
.*: +file format .*
Disassembly of section .plt:
0+180 <.plt>:
+[a-f0-9]+: ff b3 04 00 00 00 push 0x4\(%ebx\)
+[a-f0-9]+: ff a3 08 00 00 00 jmp \*0x8\(%ebx\)
+[a-f0-9]+: 00 00 add %al,\(%eax\)
...
0+190 <\*ABS\*@plt>:
+[a-f0-9]+: ff a3 0c 00 00 00 jmp \*0xc\(%ebx\)
+[a-f0-9]+: 68 18 00 00 00 push \$0x18
+[a-f0-9]+: e9 e0 ff ff ff jmp 180 <.plt>
0+1a0 <func1@plt>:
+[a-f0-9]+: ff a3 10 00 00 00 jmp \*0x10\(%ebx\)
+[a-f0-9]+: 68 00 00 00 00 push \$0x0
+[a-f0-9]+: e9 d0 ff ff ff jmp 180 <.plt>
0+1b0 <func2@plt>:
+[a-f0-9]+: ff a3 14 00 00 00 jmp \*0x14\(%ebx\)
+[a-f0-9]+: 68 08 00 00 00 push \$0x8
+[a-f0-9]+: e9 c0 ff ff ff jmp 180 <.plt>
0+1c0 <\*ABS\*@plt>:
+[a-f0-9]+: ff a3 18 00 00 00 jmp \*0x18\(%ebx\)
+[a-f0-9]+: 68 10 00 00 00 push \$0x10
+[a-f0-9]+: e9 b0 ff ff ff jmp 180 <.plt>
Disassembly of section .text:
0+1d0 <resolve1>:
+[a-f0-9]+: e8 cb ff ff ff call 1a0 <func1@plt>
0+1d5 <g1>:
+[a-f0-9]+: e9 e6 ff ff ff jmp 1c0 <\*ABS\*@plt>
0+1da <resolve2>:
+[a-f0-9]+: e8 d1 ff ff ff call 1b0 <func2@plt>
0+1df <g2>:
+[a-f0-9]+: e9 ac ff ff ff jmp 190 <\*ABS\*@plt>
#pass