mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
1c4f3780f7
This patch adds the following target relocations: - BFD_RELOC_HI16_S High 16-bit relocation, for used with signed asm: ha() lower. - BFD_RELOC_HI16_S_GOTOFF High 16-bit GOT offset relocation for local asm: gotoffha() symbols, for use with signed lower. - BFD_RELOC_OR1K_TLS_IE_AHI16 High 16-bit TLS relocation with initial asm: gottpoffha() executable calculation, for use with signed lower. - BFD_RELOC_OR1K_TLS_LE_AHI16 High 16-bit TLS relocation for local executable asm: tpoffha() variables, for use with signed lower. - BFD_RELOC_OR1K_SLO16 Split lower 16-bit relocation, used with asm: lo() OpenRISC store instructions. - BFD_RELOC_OR1K_GOTOFF_SLO16 Split lower 16-bit GOT offset relocation for asm: gotofflo() local symbols, used with OpenRISC store instructions. - BFD_RELOC_OR1K_TLS_LE_SLO16 Split lower 16-bit relocation for TLS local asm: tpofflo() executable variables, used with OpenRISC store instructions. bfd/ChangeLog: yyyy-mm-dd Richard Henderson <rth@twiddle.net> Stafford Horne <shorne@gmail.com> * bfd-in2.h: Regenerated. * elf32-or1k.c (N_ONES): New macro. (or1k_elf_howto_table): Fix R_OR1K_PLT26 to complain on overflow. Add definitions for R_OR1K_TLS_TPOFF, R_OR1K_TLS_DTPOFF, R_OR1K_TLS_DTPMOD, R_OR1K_AHI16, R_OR1K_GOTOFF_AHI16, R_OR1K_TLS_IE_AHI16, R_OR1K_TLS_LE_AHI16, R_OR1K_SLO16, R_OR1K_GOTOFF_SLO16, R_OR1K_TLS_LE_SLO16. (or1k_reloc_map): Add entries for BFD_RELOC_HI16_S, BFD_RELOC_LO16_GOTOFF, BFD_RELOC_HI16_GOTOFF, BFD_RELOC_HI16_S_GOTOFF, BFD_RELOC_OR1K_TLS_IE_AHI16, BFD_RELOC_OR1K_TLS_LE_AHI16, BFD_RELOC_OR1K_SLO16, BFD_RELOC_OR1K_GOTOFF_SLO16, BFD_RELOC_OR1K_TLS_LE_SLO16. (or1k_reloc_type_lookup): Change search loop to start ad index 0 and also check results before returning. (or1k_reloc_name_lookup): Simplify loop to use R_OR1K_max as index limit. (or1k_final_link_relocate): New function. (or1k_elf_relocate_section): Add support for new AHI and SLO relocations. Use or1k_final_link_relocate instead of generic _bfd_final_link_relocate. (or1k_elf_check_relocs): Add support for new AHI and SLO relocations. * reloc.c: Add new enums for BFD_RELOC_OR1K_SLO16, BFD_RELOC_OR1K_GOTOFF_SLO16, BFD_RELOC_OR1K_TLS_IE_AHI16, BFD_RELOC_OR1K_TLS_IE_AHI16, BFD_RELOC_OR1K_TLS_LE_AHI16, BFD_RELOC_OR1K_TLS_LE_SLO16. Remove unused BFD_RELOC_OR1K_GOTOFF_HI16 and BFD_RELOC_OR1K_GOTOFF_LO16. * libbfd.h: Regenerated. cpu/ChangeLog: yyyy-mm-dd Richard Henderson <rth@twiddle.net> * or1k.opc: Add RTYPE_ enum. (INVALID_STORE_RELOC): New string. (or1k_imm16_relocs): New array array. (parse_reloc): New static function that just does the parsing. (parse_imm16): New static function for generic parsing. (parse_simm16): Change to just call parse_imm16. (parse_simm16_split): New function. (parse_uimm16): Change to call parse_imm16. (parse_uimm16_split): New function. * or1korbis.cpu (simm16-split): Change to use new simm16_split. (uimm16-split): Change to use new uimm16_split. gas/ChangeLog: yyyy-mm-dd Richard Henderson <rth@twiddle.net> * testsuite/gas/or1k/allinsn.d (l_ha): Add result for ha() relocation. * testsuite/gas/or1k/allinsn.s (l_ha): Add test for ha() relocations. * testsuite/gas/or1k/allinsn.exp: Renamed to or1k.exp. * testsuite/gas/or1k/or1k.exp: Add reloc-2 list test. * testsuite/gas/or1k/reloc-1.d: New file. * testsuite/gas/or1k/reloc-1.s: New file. * testsuite/gas/or1k/reloc-2.l: New file. * testsuite/gas/or1k/reloc-2.s: New file. include/ChangeLog: yyyy-mm-dd Richard Henderson <rth@twiddle.net> * elf/or1k.h (elf_or1k_reloc_type): Add R_OR1K_AHI16, R_OR1K_GOTOFF_AHI16, R_OR1K_TLS_IE_AHI16, R_OR1K_TLS_LE_AHI16, R_OR1K_SLO16, R_OR1K_GOTOFF_SLO16, R_OR1K_TLS_LE_SLO16. ld/ChangeLog: yyyy-mm-dd Richard Henderson <rth@twiddle.net> * testsuite/ld-or1k/offsets1.d: New file. * testsuite/ld-or1k/offsets1.s: New file. * testsuite/ld-or1k/or1k.exp: New file. opcodes/ChangeLog: yyyy-mm-dd Richard Henderson <rth@twiddle.net> * or1k-asm.c: Regenerate.
213 lines
6.9 KiB
Makefile
213 lines
6.9 KiB
Makefile
#source: store1.s
|
|
#as:
|
|
#ld:
|
|
#objdump: -drj.text
|
|
#target: or1k*-*-*
|
|
|
|
.*: +file format elf32-or1k
|
|
|
|
|
|
Disassembly of section \.text:
|
|
|
|
.* <_start>:
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 03 00 00 l.sw 0\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 03 03 e8 l.sw 1000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 03 07 d0 l.sw 2000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 23 03 b8 l.sw 3000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 23 07 a0 l.sw 4000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 43 03 88 l.sw 5000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 43 07 70 l.sw 6000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 63 03 58 l.sw 7000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 63 07 40 l.sw 8000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 83 03 28 l.sw 9000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 83 07 10 l.sw 10000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 a3 02 f8 l.sw 11000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 a3 06 e0 l.sw 12000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 c3 02 c8 l.sw 13000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 c3 06 b0 l.sw 14000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 e3 02 98 l.sw 15000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d4 e3 06 80 l.sw 16000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 03 02 68 l.sw 17000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 03 06 50 l.sw 18000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 23 02 38 l.sw 19000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 23 06 20 l.sw 20000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 43 02 08 l.sw 21000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 43 05 f0 l.sw 22000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 63 01 d8 l.sw 23000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 63 05 c0 l.sw 24000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 83 01 a8 l.sw 25000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 83 05 90 l.sw 26000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 a3 01 78 l.sw 27000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 a3 05 60 l.sw 28000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 c3 01 48 l.sw 29000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 c3 05 30 l.sw 30000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 e3 01 18 l.sw 31000\(r3\),r0
|
|
.*: 18 60 00 01 l.movhi r3,0x1
|
|
.*: d5 e3 05 00 l.sw 32000\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 03 00 e8 l.sw -32536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 03 04 d0 l.sw -31536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 23 00 b8 l.sw -30536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 23 04 a0 l.sw -29536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 43 00 88 l.sw -28536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 43 04 70 l.sw -27536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 63 00 58 l.sw -26536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 63 04 40 l.sw -25536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 83 00 28 l.sw -24536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 83 04 10 l.sw -23536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 83 07 f8 l.sw -22536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 a3 03 e0 l.sw -21536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 a3 07 c8 l.sw -20536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 c3 03 b0 l.sw -19536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 c3 07 98 l.sw -18536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 e3 03 80 l.sw -17536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d6 e3 07 68 l.sw -16536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 03 03 50 l.sw -15536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 03 07 38 l.sw -14536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 23 03 20 l.sw -13536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 23 07 08 l.sw -12536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 43 02 f0 l.sw -11536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 43 06 d8 l.sw -10536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 63 02 c0 l.sw -9536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 63 06 a8 l.sw -8536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 83 02 90 l.sw -7536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 83 06 78 l.sw -6536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 a3 02 60 l.sw -5536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 a3 06 48 l.sw -4536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 c3 02 30 l.sw -3536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 c3 06 18 l.sw -2536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 e3 02 00 l.sw -1536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d7 e3 05 e8 l.sw -536\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 03 01 d0 l.sw 464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 03 05 b8 l.sw 1464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 23 01 a0 l.sw 2464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 23 05 88 l.sw 3464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 43 01 70 l.sw 4464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 43 05 58 l.sw 5464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 63 01 40 l.sw 6464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 63 05 28 l.sw 7464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 83 01 10 l.sw 8464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 83 04 f8 l.sw 9464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 a3 00 e0 l.sw 10464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 a3 04 c8 l.sw 11464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 c3 00 b0 l.sw 12464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 c3 04 98 l.sw 13464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 e3 00 80 l.sw 14464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d4 e3 04 68 l.sw 15464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 03 00 50 l.sw 16464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 03 04 38 l.sw 17464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 23 00 20 l.sw 18464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 23 04 08 l.sw 19464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 23 07 f0 l.sw 20464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 43 03 d8 l.sw 21464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 43 07 c0 l.sw 22464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 63 03 a8 l.sw 23464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 63 07 90 l.sw 24464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 83 03 78 l.sw 25464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 83 07 60 l.sw 26464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 a3 03 48 l.sw 27464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 a3 07 30 l.sw 28464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 c3 03 18 l.sw 29464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 c3 07 00 l.sw 30464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 e3 02 e8 l.sw 31464\(r3\),r0
|
|
.*: 18 60 00 02 l.movhi r3,0x2
|
|
.*: d5 e3 06 d0 l.sw 32464\(r3\),r0
|
|
.*: 18 60 00 03 l.movhi r3,0x3
|
|
.*: d6 03 02 b8 l.sw -32072\(r3\),r0
|