diff options
author | Maciej W. Rozycki <macro@imgtec.com> | 2016-12-08 23:29:01 +0000 |
---|---|---|
committer | Maciej W. Rozycki <macro@imgtec.com> | 2016-12-08 23:30:57 +0000 |
commit | 860b03a8f357d1565bd9d79ae25121059b2d28ae (patch) | |
tree | c76f74a44626b05d308861754e7561fe8f73bcb3 /binutils | |
parent | 731f7c4ea30cc409c45412eec15e3d66afe051f5 (diff) | |
download | binutils-gdb-860b03a8f357d1565bd9d79ae25121059b2d28ae.tar.gz |
MIPS16/opcodes: Fix PC-relative operation delay-slot adjustment
Complement commit dd8b7c222e0e ("MIPS: mips16e jalrc/jrc opcodes"),
<https://sourceware.org/ml/binutils/2005-07/msg00349.html>, and stop the
disassembler making a delay-slot adjustment for PC-relative operations
following either MIPS16e compact jumps, or undefined RR/J(AL)R(C)
encodings that have the `l' (link) and `ra' (source register is `ra')
bits set both at a time. Adjust code description for accuracy. Add a
suitable test case.
opcodes/
* mips-dis.c (print_mips16_insn_arg): Avoid delay-slot
adjustment for PC-relative operations following MIPS16e compact
jumps or undefined RR/J(AL)R(C) encodings.
binutils/
* testsuite/binutils-all/mips/mips16-pcrel.d: New test.
* testsuite/binutils-all/mips/mips16-pcrel.s: New test source.
* testsuite/binutils-all/mips/mips.exp: Run the new test.
Diffstat (limited to 'binutils')
-rw-r--r-- | binutils/ChangeLog | 6 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/mips/mips.exp | 1 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/mips/mips16-pcrel.d | 200 | ||||
-rw-r--r-- | binutils/testsuite/binutils-all/mips/mips16-pcrel.s | 219 |
4 files changed, 426 insertions, 0 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog index ae19b532946..f41e4fff428 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,9 @@ +2016-12-08 Maciej W. Rozycki <macro@imgtec.com> + + * testsuite/binutils-all/mips/mips16-pcrel.d: New test. + * testsuite/binutils-all/mips/mips16-pcrel.s: New test source. + * testsuite/binutils-all/mips/mips.exp: Run the new test. + 2016-12-08 Étienne Buira <etienne.buira@gmail.com> * readelf.c (process_program_headers): Always use hex prefix when diff --git a/binutils/testsuite/binutils-all/mips/mips.exp b/binutils/testsuite/binutils-all/mips/mips.exp index 4dab9a60459..5dc872d7ef4 100644 --- a/binutils/testsuite/binutils-all/mips/mips.exp +++ b/binutils/testsuite/binutils-all/mips/mips.exp @@ -24,4 +24,5 @@ if [is_elf_format] { run_dump_test "mixed-micromips" run_dump_test "mixed-mips16-micromips" run_dump_test "mips16-undecoded" + run_dump_test "mips16-pcrel" } diff --git a/binutils/testsuite/binutils-all/mips/mips16-pcrel.d b/binutils/testsuite/binutils-all/mips/mips16-pcrel.d new file mode 100644 index 00000000000..6b8e96b4219 --- /dev/null +++ b/binutils/testsuite/binutils-all/mips/mips16-pcrel.d @@ -0,0 +1,200 @@ +#PROG: objcopy +#objdump: -d --prefix-addresses --show-raw-insn +#name: MIPS16 PC-relative instruction disassembly +#as: -32 + +# Verify delay-slot adjustment for PC-relative operations. + +.*: +file format .*mips.* + +Disassembly of section \.text: +00000000 <[^>]*> 6500 nop +00000002 <[^>]*> 6500 nop +00000004 <[^>]*> 0aff la v0,00000400 <foo0\+0x400> +00000006 <[^>]*> 6500 nop +00000008 <[^>]*> 6500 nop +0000000a <[^>]*> 6500 nop +0000000c <[^>]*> b3ff lw v1,00000408 <foo0\+0x408> +0000000e <[^>]*> 6500 nop +00000010 <[^>]*> 6500 nop +00000012 <[^>]*> 6500 nop +00000014 <[^>]*> fe9f dla a0,00000090 <foo0\+0x90> +00000016 <[^>]*> 6500 nop +00000018 <[^>]*> 6500 nop +0000001a <[^>]*> 6500 nop +0000001c <[^>]*> 6500 nop +0000001e <[^>]*> 6500 nop +00000020 <[^>]*> fcbf ld a1,00000118 <foo0\+0x118> + \.\.\. +00001000 <[^>]*> 1800 0000 jal 00000000 <foo0> +00001004 <[^>]*> 0aff la v0,000013fc <foo1\+0x3fc> +00001006 <[^>]*> 6500 nop +00001008 <[^>]*> 1800 0000 jal 00000000 <foo0> +0000100c <[^>]*> b3ff lw v1,00001404 <foo1\+0x404> +0000100e <[^>]*> 6500 nop +00001010 <[^>]*> 1800 0000 jal 00000000 <foo0> +00001014 <[^>]*> fe9f dla a0,0000108c <foo1\+0x8c> +00001016 <[^>]*> 6500 nop +00001018 <[^>]*> 6500 nop +0000101a <[^>]*> 6500 nop +0000101c <[^>]*> 1800 0000 jal 00000000 <foo0> +00001020 <[^>]*> fcbf ld a1,00001110 <foo1\+0x110> + \.\.\. +00002000 <[^>]*> 1c00 0000 jalx 00000000 <foo0> +00002004 <[^>]*> 0aff la v0,000023fc <foo2\+0x3fc> +00002006 <[^>]*> 6500 nop +00002008 <[^>]*> 1c00 0000 jalx 00000000 <foo0> +0000200c <[^>]*> b3ff lw v1,00002404 <foo2\+0x404> +0000200e <[^>]*> 6500 nop +00002010 <[^>]*> 1c00 0000 jalx 00000000 <foo0> +00002014 <[^>]*> fe9f dla a0,0000208c <foo2\+0x8c> +00002016 <[^>]*> 6500 nop +00002018 <[^>]*> 6500 nop +0000201a <[^>]*> 6500 nop +0000201c <[^>]*> 1c00 0000 jalx 00000000 <foo0> +00002020 <[^>]*> fcbf ld a1,00002110 <foo2\+0x110> + \.\.\. +00003000 <[^>]*> 6500 nop +00003002 <[^>]*> e800 jr s0 +00003004 <[^>]*> 0aff la v0,000033fc <foo3\+0x3fc> +00003006 <[^>]*> 6500 nop +00003008 <[^>]*> 6500 nop +0000300a <[^>]*> e800 jr s0 +0000300c <[^>]*> b3ff lw v1,00003404 <foo3\+0x404> +0000300e <[^>]*> 6500 nop +00003010 <[^>]*> 6500 nop +00003012 <[^>]*> e800 jr s0 +00003014 <[^>]*> fe9f dla a0,0000308c <foo3\+0x8c> +00003016 <[^>]*> 6500 nop +00003018 <[^>]*> 6500 nop +0000301a <[^>]*> 6500 nop +0000301c <[^>]*> 6500 nop +0000301e <[^>]*> e800 jr s0 +00003020 <[^>]*> fcbf ld a1,00003110 <foo3\+0x110> + \.\.\. +00004000 <[^>]*> 6500 nop +00004002 <[^>]*> e820 jr ra +00004004 <[^>]*> 0aff la v0,000043fc <foo4\+0x3fc> +00004006 <[^>]*> 6500 nop +00004008 <[^>]*> 6500 nop +0000400a <[^>]*> e820 jr ra +0000400c <[^>]*> b3ff lw v1,00004404 <foo4\+0x404> +0000400e <[^>]*> 6500 nop +00004010 <[^>]*> 6500 nop +00004012 <[^>]*> e820 jr ra +00004014 <[^>]*> fe9f dla a0,0000408c <foo4\+0x8c> +00004016 <[^>]*> 6500 nop +00004018 <[^>]*> 6500 nop +0000401a <[^>]*> 6500 nop +0000401c <[^>]*> 6500 nop +0000401e <[^>]*> e820 jr ra +00004020 <[^>]*> fcbf ld a1,00004110 <foo4\+0x110> + \.\.\. +00005000 <[^>]*> 6500 nop +00005002 <[^>]*> e840 jalr s0 +00005004 <[^>]*> 0aff la v0,000053fc <foo5\+0x3fc> +00005006 <[^>]*> 6500 nop +00005008 <[^>]*> 6500 nop +0000500a <[^>]*> e840 jalr s0 +0000500c <[^>]*> b3ff lw v1,00005404 <foo5\+0x404> +0000500e <[^>]*> 6500 nop +00005010 <[^>]*> 6500 nop +00005012 <[^>]*> e840 jalr s0 +00005014 <[^>]*> fe9f dla a0,0000508c <foo5\+0x8c> +00005016 <[^>]*> 6500 nop +00005018 <[^>]*> 6500 nop +0000501a <[^>]*> 6500 nop +0000501c <[^>]*> 6500 nop +0000501e <[^>]*> e840 jalr s0 +00005020 <[^>]*> fcbf ld a1,00005110 <foo5\+0x110> + \.\.\. +00006000 <[^>]*> 6500 nop +00006002 <[^>]*> e860 0xe860 +00006004 <[^>]*> 0aff la v0,00006400 <foo6\+0x400> +00006006 <[^>]*> 6500 nop +00006008 <[^>]*> 6500 nop +0000600a <[^>]*> e860 0xe860 +0000600c <[^>]*> b3ff lw v1,00006408 <foo6\+0x408> +0000600e <[^>]*> 6500 nop +00006010 <[^>]*> 6500 nop +00006012 <[^>]*> e860 0xe860 +00006014 <[^>]*> fe9f dla a0,00006090 <foo6\+0x90> +00006016 <[^>]*> 6500 nop +00006018 <[^>]*> 6500 nop +0000601a <[^>]*> 6500 nop +0000601c <[^>]*> 6500 nop +0000601e <[^>]*> e860 0xe860 +00006020 <[^>]*> fcbf ld a1,00006118 <foo6\+0x118> + \.\.\. +00007000 <[^>]*> 6500 nop +00007002 <[^>]*> e880 jrc s0 +00007004 <[^>]*> 0aff la v0,00007400 <foo7\+0x400> +00007006 <[^>]*> 6500 nop +00007008 <[^>]*> 6500 nop +0000700a <[^>]*> e880 jrc s0 +0000700c <[^>]*> b3ff lw v1,00007408 <foo7\+0x408> +0000700e <[^>]*> 6500 nop +00007010 <[^>]*> 6500 nop +00007012 <[^>]*> e880 jrc s0 +00007014 <[^>]*> fe9f dla a0,00007090 <foo7\+0x90> +00007016 <[^>]*> 6500 nop +00007018 <[^>]*> 6500 nop +0000701a <[^>]*> 6500 nop +0000701c <[^>]*> 6500 nop +0000701e <[^>]*> e880 jrc s0 +00007020 <[^>]*> fcbf ld a1,00007118 <foo7\+0x118> + \.\.\. +00008000 <[^>]*> 6500 nop +00008002 <[^>]*> e8a0 jrc ra +00008004 <[^>]*> 0aff la v0,00008400 <foo8\+0x400> +00008006 <[^>]*> 6500 nop +00008008 <[^>]*> 6500 nop +0000800a <[^>]*> e8a0 jrc ra +0000800c <[^>]*> b3ff lw v1,00008408 <foo8\+0x408> +0000800e <[^>]*> 6500 nop +00008010 <[^>]*> 6500 nop +00008012 <[^>]*> e8a0 jrc ra +00008014 <[^>]*> fe9f dla a0,00008090 <foo8\+0x90> +00008016 <[^>]*> 6500 nop +00008018 <[^>]*> 6500 nop +0000801a <[^>]*> 6500 nop +0000801c <[^>]*> 6500 nop +0000801e <[^>]*> e8a0 jrc ra +00008020 <[^>]*> fcbf ld a1,00008118 <foo8\+0x118> + \.\.\. +00009000 <[^>]*> 6500 nop +00009002 <[^>]*> e8c0 jalrc s0 +00009004 <[^>]*> 0aff la v0,00009400 <foo9\+0x400> +00009006 <[^>]*> 6500 nop +00009008 <[^>]*> 6500 nop +0000900a <[^>]*> e8c0 jalrc s0 +0000900c <[^>]*> b3ff lw v1,00009408 <foo9\+0x408> +0000900e <[^>]*> 6500 nop +00009010 <[^>]*> 6500 nop +00009012 <[^>]*> e8c0 jalrc s0 +00009014 <[^>]*> fe9f dla a0,00009090 <foo9\+0x90> +00009016 <[^>]*> 6500 nop +00009018 <[^>]*> 6500 nop +0000901a <[^>]*> 6500 nop +0000901c <[^>]*> 6500 nop +0000901e <[^>]*> e8c0 jalrc s0 +00009020 <[^>]*> fcbf ld a1,00009118 <foo9\+0x118> + \.\.\. +0000a000 <[^>]*> 6500 nop +0000a002 <[^>]*> e960 0xe960 +0000a004 <[^>]*> 0aff la v0,0000a400 <fooa\+0x400> +0000a006 <[^>]*> 6500 nop +0000a008 <[^>]*> 6500 nop +0000a00a <[^>]*> e960 0xe960 +0000a00c <[^>]*> b3ff lw v1,0000a408 <fooa\+0x408> +0000a00e <[^>]*> 6500 nop +0000a010 <[^>]*> 6500 nop +0000a012 <[^>]*> e960 0xe960 +0000a014 <[^>]*> fe9f dla a0,0000a090 <fooa\+0x90> +0000a016 <[^>]*> 6500 nop +0000a018 <[^>]*> 6500 nop +0000a01a <[^>]*> 6500 nop +0000a01c <[^>]*> 6500 nop +0000a01e <[^>]*> e960 0xe960 +0000a020 <[^>]*> fcbf ld a1,0000a118 <fooa\+0x118> + \.\.\. diff --git a/binutils/testsuite/binutils-all/mips/mips16-pcrel.s b/binutils/testsuite/binutils-all/mips/mips16-pcrel.s new file mode 100644 index 00000000000..f73aeaefc31 --- /dev/null +++ b/binutils/testsuite/binutils-all/mips/mips16-pcrel.s @@ -0,0 +1,219 @@ + .module mips64 + .set mips16 + .set noreorder + .set noautoextend + + .align 12, 0 +foo0: + nop + nop + addiu $2, $pc, 0x3fc + nop + nop + nop + lw $3, 0x3fc($pc) + nop + nop + nop + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + nop + ld $5, 0xf8($pc) + + .align 12, 0 +foo1: + jal bar0 + addiu $2, $pc, 0x3fc + nop + jal bar0 + lw $3, 0x3fc($pc) + nop + jal bar0 + daddiu $4, $pc, 0x7c + nop + nop + nop + jal bar0 + ld $5, 0xf8($pc) + + .align 12, 0 +foo2: + jalx bar1 + addiu $2, $pc, 0x3fc + nop + jalx bar1 + lw $3, 0x3fc($pc) + nop + jalx bar1 + daddiu $4, $pc, 0x7c + nop + nop + nop + jalx bar1 + ld $5, 0xf8($pc) + + .align 12, 0 +foo3: + nop + jr $16 + addiu $2, $pc, 0x3fc + nop + nop + jr $16 + lw $3, 0x3fc($pc) + nop + nop + jr $16 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + jr $16 + ld $5, 0xf8($pc) + + .align 12, 0 +foo4: + nop + jr $31 + addiu $2, $pc, 0x3fc + nop + nop + jr $31 + lw $3, 0x3fc($pc) + nop + nop + jr $31 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + jr $31 + ld $5, 0xf8($pc) + + .align 12, 0 +foo5: + nop + jalr $16 + addiu $2, $pc, 0x3fc + nop + nop + jalr $16 + lw $3, 0x3fc($pc) + nop + nop + jalr $16 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + jalr $16 + ld $5, 0xf8($pc) + + .align 12, 0 +foo6: + nop + .half 0xe860 + addiu $2, $pc, 0x3fc + nop + nop + .half 0xe860 + lw $3, 0x3fc($pc) + nop + nop + .half 0xe860 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + .half 0xe860 + ld $5, 0xf8($pc) + + .align 12, 0 +foo7: + nop + jrc $16 + addiu $2, $pc, 0x3fc + nop + nop + jrc $16 + lw $3, 0x3fc($pc) + nop + nop + jrc $16 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + jrc $16 + ld $5, 0xf8($pc) + + .align 12, 0 +foo8: + nop + jrc $31 + addiu $2, $pc, 0x3fc + nop + nop + jrc $31 + lw $3, 0x3fc($pc) + nop + nop + jrc $31 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + jrc $31 + ld $5, 0xf8($pc) + + .align 12, 0 +foo9: + nop + jalrc $16 + addiu $2, $pc, 0x3fc + nop + nop + jalrc $16 + lw $3, 0x3fc($pc) + nop + nop + jalrc $16 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + jalrc $16 + ld $5, 0xf8($pc) + + .align 12, 0 +fooa: + nop + .half 0xe960 + addiu $2, $pc, 0x3fc + nop + nop + .half 0xe960 + lw $3, 0x3fc($pc) + nop + nop + .half 0xe960 + daddiu $4, $pc, 0x7c + nop + nop + nop + nop + .half 0xe960 + ld $5, 0xf8($pc) + +# Force some (non-delay-slot) zero bytes, to make 'objdump' print ... + .align 12, 0 |