mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
7fd5392005
Switch to 32-bit MIPS16 opcode table entry interpretation, similar to how the microMIPS opcode table is handled, for both the `match' and `mask' fields, removing special casing for JAL and JALX instructions and their `a' and `i' operand codes throughout, while retaining automatic processing of extendable opcodes in assembly and disassembly. In assembly disallow size enforcement suffixes as appropriate: `.t' for both 32-bit instructions and macros and `.e' for macros only, making macro handling consistent with the microMIPS instruction set. In disassembly fully decode EXTEND prefixes prepended to unsupported instruction encodings (according to the ISA selection) rather than dumping them as hexadecimal data along with the following instruction, removing all special casing for the EXTEND prefix and making its handling rely on its opcode table entry, except where it is considered a part of an extendable instruction. include/ * opcode/mips.h (mips_opcode_32bit_p): New inline function. gas/ * config/tc-mips.c (micromips_insn_length): Use `mips_opcode_32bit_p'. (is_size_valid): Adjust description. (is_size_valid_16): New function. (validate_mips_insn): Use `mips_opcode_32bit_p' in MIPS16 operand decoding. (validate_mips16_insn): Remove `a' and `i' operand code special casing, use `mips_opcode_32bit_p' to determine instruction width. (append_insn): Adjust forced MIPS16 instruction size determination. (match_mips16_insn): Likewise. Don't shift the instruction's opcode with the `a' and `i' operand codes. Use `mips_opcode_32bit_p' in operand decoding. (match_mips16_insns): Check for forced instruction size's validity. (mips16_ip): Don't force instruction size in the `noautoextend' mode. * testsuite/gas/mips/mips16-jal-e.d: New test. * testsuite/gas/mips/mips16-jal-t.d: New test. * testsuite/gas/mips/mips16-macro-e.d: New test. * testsuite/gas/mips/mips16-macro-t.d: New test. * testsuite/gas/mips/mips16-jal-t.l: New stderr output. * testsuite/gas/mips/mips16-macro-e.l: New stderr output. * testsuite/gas/mips/mips16-macro-t.l: New stderr output. * testsuite/gas/mips/mips16-jal-e.s: New test source. * testsuite/gas/mips/mips16-jal-t.s: New test source. * testsuite/gas/mips/mips16-macro-e.s: New test source. * testsuite/gas/mips/mips16-macro-t.s: New test source. * testsuite/gas/mips/mips.exp: Run the new tests. opcodes/ * mips-dis.c (print_mips16_insn_arg): Always handle `extend' and `insn' together, with `extend' as the high-order 16 bits. (match_kind): New enum. (print_insn_mips16): Rework for 32-bit instruction matching. Do not dump EXTEND prefixes here. * mips16-opc.c (mips16_opcodes): Move "extend" entry to the end. Recode `match' and `mask' fields as 32-bit in absolute "jal" and "jalx" entries. binutils/ * testsuite/binutils-all/mips/mips16-extend-noinsn.d: Adjust test for separate EXTEND prefix disassembly.
40 lines
1.3 KiB
Makefile
40 lines
1.3 KiB
Makefile
#PROG: objcopy
|
|
#objdump: -d --prefix-addresses --show-raw-insn
|
|
#name: MIPS16 unsupported EXTEND and undefined opcode disassembly
|
|
#as: -32
|
|
|
|
# Verify raw hexadecimal EXTEND and inexistent opcode disassembly.
|
|
|
|
.*: +file format .*mips.*
|
|
|
|
Disassembly of section \.text:
|
|
[0-9a-f]+ <[^>]*> 6500 nop
|
|
[0-9a-f]+ <[^>]*> f123 extend 0x123
|
|
[0-9a-f]+ <[^>]*> f456 extend 0x456
|
|
[0-9a-f]+ <[^>]*> f765 extend 0x765
|
|
[0-9a-f]+ <[^>]*> 1800 0000 jal 00000000 <foo>
|
|
[0-9a-f]+ <[^>]*> 6500 nop
|
|
[0-9a-f]+ <[^>]*> f432 extend 0x432
|
|
[0-9a-f]+ <[^>]*> 1c00 0000 jalx 00000000 <foo>
|
|
[0-9a-f]+ <[^>]*> 6500 nop
|
|
[0-9a-f]+ <[^>]*> f123 extend 0x123
|
|
[0-9a-f]+ <[^>]*> 6621 0x6621
|
|
[0-9a-f]+ <[^>]*> f456 extend 0x456
|
|
[0-9a-f]+ <[^>]*> e935 0xe935
|
|
[0-9a-f]+ <[^>]*> f765 extend 0x765
|
|
[0-9a-f]+ <[^>]*> ea60 0xea60
|
|
[0-9a-f]+ <[^>]*> f432 extend 0x432
|
|
[0-9a-f]+ <[^>]*> ece0 0xece0
|
|
[0-9a-f]+ <[^>]*> f5aa extend 0x5aa
|
|
[0-9a-f]+ <[^>]*> e971 0xe971
|
|
[0-9a-f]+ <[^>]*> f655 extend 0x655
|
|
[0-9a-f]+ <[^>]*> ebf1 0xebf1
|
|
[0-9a-f]+ <[^>]*> 6621 0x6621
|
|
[0-9a-f]+ <[^>]*> e935 0xe935
|
|
[0-9a-f]+ <[^>]*> ea60 0xea60
|
|
[0-9a-f]+ <[^>]*> ece0 0xece0
|
|
[0-9a-f]+ <[^>]*> e971 0xe971
|
|
[0-9a-f]+ <[^>]*> ebf1 0xebf1
|
|
[0-9a-f]+ <[^>]*> 6500 nop
|
|
\.\.\.
|