mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
b4e87f2c1e
We currently use a padding NOP after a Thumb to Arm interworking veneer (BX pc). The NOP is never executed but may result in a performance penalty on some cores. For this reason this patch changes the NOPs after Thumb to Arm veneers into B .-2 and adds a note to this in the source code for future reference. bfd/ChangeLog: * elf32-arm.c (elf32_thumb2_plt_entry, elf32_arm_plt_thumb_stub, elf32_arm_stub_long_branch_v4t_thumb_thumb, elf32_arm_stub_long_branch_v4t_thumb_arm, elf32_arm_stub_short_branch_v4t_thumb_arm, elf32_arm_stub_long_branch_v4t_thumb_arm_pic, elf32_arm_stub_long_branch_v4t_thumb_thumb_pic, elf32_arm_stub_long_branch_v4t_thumb_tls_pic): Change nop to branch to previous instruction. ld/ChangeLog: * testsuite/ld-arm/cortex-a8-fix-b-plt.d: Update Testcase. * testsuite/ld-arm/cortex-a8-fix-b-rel-arm.d: Likewise. * testsuite/ld-arm/cortex-a8-fix-bcc-plt.d: Likewise. * testsuite/ld-arm/farcall-cond-thumb-arm.d: Likewise. * testsuite/ld-arm/farcall-mixed-app.d: Likewise. * testsuite/ld-arm/farcall-mixed-app2.d: Likewise. * testsuite/ld-arm/farcall-mixed-lib-v4t.d: Likewise. * testsuite/ld-arm/farcall-thumb-arm-pic-veneer.d: Likewise. * testsuite/ld-arm/farcall-thumb-arm-short.d: Likewise. * testsuite/ld-arm/farcall-thumb-arm.d: Likewise. * testsuite/ld-arm/farcall-thumb-thumb-pic-veneer.d: Likewise. * testsuite/ld-arm/farcall-thumb-thumb.d: Likewise. * testsuite/ld-arm/fix-arm1176-on.d: Likewise. * testsuite/ld-arm/ifunc-10.dd: Likewise. * testsuite/ld-arm/ifunc-2.dd: Likewise. * testsuite/ld-arm/ifunc-4.dd: Likewise. * testsuite/ld-arm/ifunc-6.dd: Likewise. * testsuite/ld-arm/ifunc-8.dd: Likewise. * testsuite/ld-arm/jump-reloc-veneers-long.d: Likewise. * testsuite/ld-arm/mixed-app.d: Likewise. * testsuite/ld-arm/thumb2-b-interwork.d: Likewise. * testsuite/ld-arm/tls-longplt.d: Likewise. * testsuite/ld-arm/tls-thumb1.d: Likewise.
34 lines
945 B
Makefile
34 lines
945 B
Makefile
|
|
.*
|
|
|
|
|
|
Disassembly of section \.plt:
|
|
|
|
00008000 <.plt>:
|
|
8000: e52de004 push {lr} ; \(str lr, \[sp, #-4\]!\)
|
|
8004: e59fe004 ldr lr, \[pc, #4\] ; 8010 <.*>
|
|
8008: e08fe00e add lr, pc, lr
|
|
800c: e5bef008 ldr pc, \[lr, #8\]!
|
|
8010: 00001004 \.word 0x00001004
|
|
00008014 <bar@plt>:
|
|
8014: 4778 bx pc
|
|
8016: e7fd b.n .+ <.+>
|
|
8018: e28fc600 add ip, pc, #0, 12
|
|
801c: e28cca01 add ip, ip, #4096 ; 0x1000
|
|
8020: e5bcf000 ldr pc, \[ip, #0\]!
|
|
|
|
Disassembly of section \.text:
|
|
|
|
00008ff0 <foo>:
|
|
8ff0: 46c0 nop ; \(mov r8, r8\)
|
|
8ff2: f240 0000 movw r0, #0
|
|
8ff6: f240 0000 movw r0, #0
|
|
8ffa: f240 0000 movw r0, #0
|
|
8ffe: f000 b803 b\.w 9008 <foo\+0x18>
|
|
9002: 0000 movs r0, r0
|
|
9004: 0000 movs r0, r0
|
|
9006: 0000 movs r0, r0
|
|
9008: d001 beq\.n 900e <foo\+0x1e>
|
|
900a: f7ff bffa b\.w 9002 <foo\+0x12>
|
|
900e: f7ff b801 b\.w 8014 <bar@plt>
|