]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commit - opcodes/sparc-dis.c
Increase the accuracy of sparc instruction aliases.
authorDavid S. Miller <davem@redhat.com>
Sat, 6 Apr 2013 22:22:03 +0000 (22:22 +0000)
committerDavid S. Miller <davem@redhat.com>
Sat, 6 Apr 2013 22:22:03 +0000 (22:22 +0000)
commit0afd121540f24f7fba577e017f0466f274af31ff
tree686aa0375643b2ebaa207d2c8819980165e048c3
parentcba5a7bf0f7caf3f0b64267f4d9bb90bdfef980d
Increase the accuracy of sparc instruction aliases.

Make current with UA2011 specification.

Add an F_PREFERRED opcode flag that indicates a preferred alias
when multiple aliases for the same opcode exists.

For 'lzd':

Add 'lzcnt' as primary instruction, and make 'lzd' an alias.

Add 'ldtw', 'ldtwa', 'sttw', 'sttwa':

The modern opcode for for 'ldd', 'ldda', 'std', and 'stda' on
integer registers.  Mark the latter now as aliases.

For 'flush':

Support "[address]" syntax as well as plain "address".

Rework 'mov' aliases for 'wr':

Eliminate bogus three operand moves, and encode the
instructions properly for the "mov REG, %ASR" cases,
specifically we should encode the register in rs2 not rs1 as
per The SPARC V8 Architecture Manual.

Add missing cbcond aliases:

c{w,x}bz, c{w,x}blu, c{w,x}bnz, c{w,x}bgeu

Add 'd' suffix VIS logical ops:

The primary opcode for 'fzero' is now 'fzerod' (compare with
'fzeros'), for example.  And thus 'fzero' is now an alias.

Add modern opcodes for condition code setting edge instructions:

They are now edgeN{,l}cc instead of plain edgeN{,l}.

Add modern opcodes for VIS comparisons:

All VIS comparisons now start with prefix "fp", retain the
older variants as aliases.

The signed variants for equal and not-equal have "u" aliases
to show that these comparisons are equally suited for unsigned
compares.

Update existing test cases as needed, and add several new ones.

include/opcode/

* sparc.h (F_PREFERRED): Define.
(F_PREF_ALIAS): Define.

opcodes/

* sparc-dis.c (compare_opcodes): When encountering multiple aliases
of an opcode, prefer the one with F_PREFERRED set.
* sparc-opc.c (sparc_opcodes): Add ldtw, ldtwa, sttw, sttwa,
lzcnt, flush with '[address]' syntax, and missing cbcond pseudo
ops.  Make 64-bit VIS logical ops have "d" suffix in their names,
mark existing mnenomics as aliases.  Add "cc" suffix to edge
instructions generating condition codes, mark existing mnenomics
as aliases.  Add "fp" prefix to VIS compare instructions, mark
existing mnenomics as aliases.

gas/testsuite/

* gas/sparc/cbcond.s: Add tests for new opcode aliases.
* gas/sparc/cbcond.d: Updated.
* gas/sparc/hpcvis3.s: Add tests for new opcode aliases.
* gas/sparc/hpcvis3.d: Updated.
* gas/sparc/v8-movwr-imm.d: Fix expected disassembly.
* gas/sparc/edge.s: New test.
* gas/sparc/edge.d: Expected disassembly.
* gas/sparc/flush.s: New test.
* gas/sparc/flush.d: Expected disassembly.
* gas/sparc/ldd_std.s: New test.
* gas/sparc/ldd_std.d: Expected disassembly.
* gas/sparc/ldtw_sttw.s: New test.
* gas/sparc/ldtw_sttw.d: Expected disassembly.
* gas/sparc/sparc.exp: Run new tests.
20 files changed:
gas/testsuite/ChangeLog
gas/testsuite/gas/sparc/cbcond.d
gas/testsuite/gas/sparc/cbcond.s
gas/testsuite/gas/sparc/edge.d [new file with mode: 0644]
gas/testsuite/gas/sparc/edge.s [new file with mode: 0644]
gas/testsuite/gas/sparc/flush.d [new file with mode: 0644]
gas/testsuite/gas/sparc/flush.s [new file with mode: 0644]
gas/testsuite/gas/sparc/hpcvis3.d
gas/testsuite/gas/sparc/hpcvis3.s
gas/testsuite/gas/sparc/ldd_std.d [new file with mode: 0644]
gas/testsuite/gas/sparc/ldd_std.s [new file with mode: 0644]
gas/testsuite/gas/sparc/ldtw_sttw.d [new file with mode: 0644]
gas/testsuite/gas/sparc/ldtw_sttw.s [new file with mode: 0644]
gas/testsuite/gas/sparc/sparc.exp
gas/testsuite/gas/sparc/v8-movwr-imm.d
include/opcode/ChangeLog
include/opcode/sparc.h
opcodes/ChangeLog
opcodes/sparc-dis.c
opcodes/sparc-opc.c