aboutsummaryrefslogtreecommitdiff
path: root/bfd/elflink.c
diff options
context:
space:
mode:
authorMaciej W. Rozycki <macro@imgtec.com>2017-02-28 00:14:08 +0000
committerMaciej W. Rozycki <macro@imgtec.com>2017-02-28 00:22:36 +0000
commit0e39210161e7c547ab53afb86997303e24a42c0c (patch)
treed9e7851d07bece63eb64bb4e283d70f7b59932ca /bfd/elflink.c
parent279a558a4d0fad268738ec916628c9c12cfcaf5b (diff)
downloadgdb-0e39210161e7c547ab53afb86997303e24a42c0c.zip
gdb-0e39210161e7c547ab53afb86997303e24a42c0c.tar.gz
gdb-0e39210161e7c547ab53afb86997303e24a42c0c.tar.bz2
MIPS/BFD: Also handle `jalr $0, $25' with R_MIPS_JALR
Interpret the `jalr $0, $25' instruction encoding with an R_MIPS_JALR relocation attached as an alias to `jr $25' and convert the jump to an equivalent branch where possible, consequently covering the MIPSr6 architecture for the purpose of this optimization too. bfd/ * elfxx-mips.c (mips_elf_perform_relocation): Also handle the `jalr $0, $25' instruction encoding. gas/ * testsuite/gas/mips/jalr4.s: Add `jalr $0, $25' instructions. * testsuite/gas/mips/jalr4.d: Adjust accordingly. Remove MIPSr6 encoding patterns. * testsuite/gas/mips/jalr4-n64.d: Likewise. * testsuite/gas/mips/mipsr6@jalr4.d: New test. * testsuite/gas/mips/mipsr6@jalr4-n32.d: New test. * testsuite/gas/mips/mipsr6@jalr4-n64.d: New test. ld/ * testsuite/ld-mips-elf/jalr4.dd: Adjust for `jalr $0, $25' instructions. * testsuite/ld-mips-elf/jalr4-r6.dd: New test. * testsuite/ld-mips-elf/mips-elf.exp: Run the new test.
Diffstat (limited to 'bfd/elflink.c')
0 files changed, 0 insertions, 0 deletions