summaryrefslogtreecommitdiff
path: root/opcodes/aarch64-dis-2.c
diff options
context:
space:
mode:
authorTamar Christina <tamar.christina@arm.com>2017-11-16 16:07:07 +0000
committerTamar Christina <tamar.christina@arm.com>2017-11-16 16:27:35 +0000
commite9dbdd80cb02ac66cf7d4cd1207ec11928db2c95 (patch)
treee38fe9608a2a11b3e469c08c01013c05ea2adbc0 /opcodes/aarch64-dis-2.c
parente849ea896bcdc3da8caff02eb6dc91dc85dd8a7e (diff)
downloadbinutils-gdb-e9dbdd80cb02ac66cf7d4cd1207ec11928db2c95.tar.gz
Add assembler and disassembler support for the new Armv8.4-a instructions for AArch64.
Some of these instructions have been back-ported as optional extensions to Armv8.2-a and higher, but others are only available for Armv8.4-a. opcodes/ * aarch64-tbl.h (sha512h, sha512h2, sha512su0, sha512su1, eor3): New. (rax1, xar, bcax, sm3ss1, sm3tt1a, sm3tt1b, sm3tt2a, sm3tt2b): New. (sm3partw1, sm3partw2, sm4e, sm4ekey, fmlal, fmlsl): New. (fmlal2, fmlsl2, cfinv, rmif, setf8, setf16, stlurb): New. (ldapurb, ldapursb, stlurh, ldapurh, ldapursh, stlur): New. (ldapur, ldapursw, stlur): New. * aarch64-dis-2.c: Regenerate. gas/ * testsuite/gas/aarch64/armv8_4-a-illegal.d: New. * testsuite/gas/aarch64/armv8_4-a-illegal.l: New. * testsuite/gas/aarch64/armv8_4-a-illegal.s: New. * testsuite/gas/aarch64/armv8_4-a.d: New. * testsuite/gas/aarch64/armv8_4-a.s: New. * testsuite/gas/aarch64/armv8_2-a-crypto-fp16.s: New. * testsuite/gas/aarch64/armv8_2-a-crypto-fp16.d: New. * testsuite/gas/aarch64/armv8_3-a-crypto-fp16.d: New. * testsuite/gas/aarch64/armv8_4-a-crypto-fp16.d: New. * testsuite/gas/aarch64/armv8_2-a-crypto-fp16-illegal.s: New. * testsuite/gas/aarch64/armv8_2-a-crypto-fp16-illegal.l: New. * testsuite/gas/aarch64/armv8_2-a-crypto-fp16-illegal.d: New.
Diffstat (limited to 'opcodes/aarch64-dis-2.c')
-rw-r--r--opcodes/aarch64-dis-2.c6388
1 files changed, 3464 insertions, 2924 deletions
diff --git a/opcodes/aarch64-dis-2.c b/opcodes/aarch64-dis-2.c
index 8e058922747..224bb450f04 100644
--- a/opcodes/aarch64-dis-2.c
+++ b/opcodes/aarch64-dis-2.c
@@ -2330,103 +2330,246 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 22) & 0x1) == 0)
{
- if (((word >> 31) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
if (((word >> 30) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 00x1100100xxxxxxxxxxxxxxxxxxxxxx
- strb. */
- return 863;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0001100100xxxxxxxxxxxxxxxxxxxxxx
+ stlurb. */
+ return 2027;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1001100100xxxxxxxxxxxxxxxxxxxxxx
+ stlur. */
+ return 2035;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 01x1100100xxxxxxxxxxxxxxxxxxxxxx
- strh. */
- return 868;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0101100100xxxxxxxxxxxxxxxxxxxxxx
+ stlurh. */
+ return 2031;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1101100100xxxxxxxxxxxxxxxxxxxxxx
+ stlur. */
+ return 2038;
+ }
}
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 1xx1100100xxxxxxxxxxxxxxxxxxxxxx
- str. */
- return 871;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0011100100xxxxxxxxxxxxxxxxxxxxxx
+ strb. */
+ return 863;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0111100100xxxxxxxxxxxxxxxxxxxxxx
+ strh. */
+ return 868;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x11100100xxxxxxxxxxxxxxxxxxxxxx
+ str. */
+ return 871;
+ }
}
}
else
{
- if (((word >> 31) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
if (((word >> 30) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 00x1100101xxxxxxxxxxxxxxxxxxxxxx
- ldrb. */
- return 864;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0001100101xxxxxxxxxxxxxxxxxxxxxx
+ ldapurb. */
+ return 2028;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1001100101xxxxxxxxxxxxxxxxxxxxxx
+ ldapur. */
+ return 2036;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 01x1100101xxxxxxxxxxxxxxxxxxxxxx
- ldrh. */
- return 869;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0101100101xxxxxxxxxxxxxxxxxxxxxx
+ ldapurh. */
+ return 2032;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1101100101xxxxxxxxxxxxxxxxxxxxxx
+ ldapur. */
+ return 2039;
+ }
}
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 1xx1100101xxxxxxxxxxxxxxxxxxxxxx
- ldr. */
- return 872;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0011100101xxxxxxxxxxxxxxxxxxxxxx
+ ldrb. */
+ return 864;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0111100101xxxxxxxxxxxxxxxxxxxxxx
+ ldrh. */
+ return 869;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x11100101xxxxxxxxxxxxxxxxxxxxxx
+ ldr. */
+ return 872;
+ }
}
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
- if (((word >> 31) & 0x1) == 0)
+ if (((word >> 22) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 00x110011xxxxxxxxxxxxxxxxxxxxxxx
- ldrsb. */
- return 865;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0001100110xxxxxxxxxxxxxxxxxxxxxx
+ ldapursb. */
+ return 2030;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1001100110xxxxxxxxxxxxxxxxxxxxxx
+ ldapursw. */
+ return 2037;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x101100110xxxxxxxxxxxxxxxxxxxxxx
+ ldapursh. */
+ return 2034;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 10x110011xxxxxxxxxxxxxxxxxxxxxxx
- ldrsw. */
- return 873;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x001100111xxxxxxxxxxxxxxxxxxxxxx
+ ldapursb. */
+ return 2029;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x101100111xxxxxxxxxxxxxxxxxxxxxx
+ ldapursh. */
+ return 2033;
+ }
}
}
else
{
- if (((word >> 31) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 01x110011xxxxxxxxxxxxxxxxxxxxxxx
- ldrsh. */
- return 870;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 001110011xxxxxxxxxxxxxxxxxxxxxxx
+ ldrsb. */
+ return 865;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 101110011xxxxxxxxxxxxxxxxxxxxxxx
+ ldrsw. */
+ return 873;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 11x110011xxxxxxxxxxxxxxxxxxxxxxx
- prfm. */
- return 874;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 011110011xxxxxxxxxxxxxxxxxxxxxxx
+ ldrsh. */
+ return 870;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 111110011xxxxxxxxxxxxxxxxxxxxxxx
+ prfm. */
+ return 874;
+ }
}
}
}
@@ -2769,130 +2912,152 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 22) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0x110100x0xxxxxxxxx10xxxxxxxxxx
- ccmn. */
- return 652;
+ xxx11010x00xxxxxx0xx10xxxxxxxxxx
+ setf8. */
+ return 2025;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1x110100x0xxxxxxxxx10xxxxxxxxxx
- ccmp. */
- return 653;
+ xxx11010x00xxxxxx1xx10xxxxxxxxxx
+ setf16. */
+ return 2026;
}
}
else
{
- if (((word >> 12) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
- if (((word >> 14) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0x11010010xxxxxxxxx10xxxxxxxxxx
+ ccmn. */
+ return 652;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1x11010010xxxxxxxxx10xxxxxxxxxx
+ ccmp. */
+ return 653;
+ }
+ }
+ else
+ {
+ if (((word >> 12) & 0x1) == 0)
+ {
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x110101x0xxxxxx00010xxxxxxxxxx
- udiv. */
- return 705;
- }
- else
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 16) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
- if (((word >> 31) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0x11010110xxxxxx00010xxxxxxxxxx
+ udiv. */
+ return 705;
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- 01x110101x0xxxx0x00010xxxxxxxxxx
- rev. */
- return 681;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01x11010110xxxx0x00010xxxxxxxxxx
+ rev. */
+ return 681;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 11x11010110xxxx0x00010xxxxxxxxxx
+ rev32. */
+ return 686;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- 11x110101x0xxxx0x00010xxxxxxxxxx
- rev32. */
- return 686;
+ x1x11010110xxxx1x00010xxxxxxxxxx
+ pacda. */
+ return 689;
}
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x110101x0xxxx1x00010xxxxxxxxxx
- pacda. */
- return 689;
- }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11010110xxxxxx10010xxxxxxxxxx
+ crc32w. */
+ return 718;
}
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx110101x0xxxxxx10010xxxxxxxxxx
- crc32w. */
- return 718;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0x11010110xxxxxxx1010xxxxxxxxxx
+ asrv. */
+ return 711;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1x11010110xxxxxxx1010xxxxxxxxxx
+ pacdza. */
+ return 697;
+ }
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x110101x0xxxxxxx1010xxxxxxxxxx
- asrv. */
- return 711;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x110101x0xxxxxxx1010xxxxxxxxxx
- pacdza. */
- return 697;
- }
- }
- }
- else
- {
- if (((word >> 13) & 0x1) == 0)
- {
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx110101x0xxxxxx00110xxxxxxxxxx
- autda. */
- return 693;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11010110xxxxxx00110xxxxxxxxxx
+ autda. */
+ return 693;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11010110xxxxxx10110xxxxxxxxxx
+ crc32cw. */
+ return 722;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx110101x0xxxxxx10110xxxxxxxxxx
- crc32cw. */
- return 722;
+ xxx11010110xxxxxxx1110xxxxxxxxxx
+ autdza. */
+ return 701;
}
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx110101x0xxxxxxx1110xxxxxxxxxx
- autdza. */
- return 701;
- }
}
}
}
@@ -2903,21 +3068,32 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 22) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0x11010x00xxxxxxxxx01xxxxxxxxxx
- csinc. */
- return 657;
+ xxx11010000xxxxxxxxx01xxxxxxxxxx
+ rmif. */
+ return 2024;
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x11010x00xxxxxxxxx01xxxxxxxxxx
- csneg. */
- return 663;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0x11010100xxxxxxxxx01xxxxxxxxxx
+ csinc. */
+ return 657;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1x11010100xxxxxxxxx01xxxxxxxxxx
+ csneg. */
+ return 663;
+ }
}
}
else
@@ -12338,168 +12514,94 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 28) & 0x1) == 0)
{
- if (((word >> 10) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 31) & 0x1) == 0)
{
- if (((word >> 11) & 0x1) == 0)
- {
- if (((word >> 12) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx0xxxxxxxx000xxxxxxxxxx
- tbl. */
- return 414;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx0xxxxxxxx100xxxxxxxxxx
- tbx. */
- return 415;
- }
- }
- else
+ if (((word >> 10) & 0x1) == 0)
{
- if (((word >> 12) & 0x1) == 0)
+ if (((word >> 11) & 0x1) == 0)
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx0xxxxxx0x010xxxxxxxxxx
- trn1. */
- return 257;
+ 0x001110xx0xxxxxxxx000xxxxxxxxxx
+ tbl. */
+ return 414;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx0xxxxxx1x010xxxxxxxxxx
- trn2. */
- return 260;
+ 0x001110xx0xxxxxxxx100xxxxxxxxxx
+ tbx. */
+ return 415;
}
}
else
{
- if (((word >> 13) & 0x1) == 0)
- {
- if (((word >> 14) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx0xxxxxx00110xxxxxxxxxx
- uzp1. */
- return 256;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx0xxxxxx10110xxxxxxxxxx
- uzp2. */
- return 259;
- }
- }
- else
+ if (((word >> 12) & 0x1) == 0)
{
if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx0xxxxxx01110xxxxxxxxxx
- zip1. */
- return 258;
+ 0x001110xx0xxxxxx0x010xxxxxxxxxx
+ trn1. */
+ return 257;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx0xxxxxx11110xxxxxxxxxx
- zip2. */
- return 261;
+ 0x001110xx0xxxxxx1x010xxxxxxxxxx
+ trn2. */
+ return 260;
}
}
- }
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx0xxxxxxxxxx0xxxxxxxxxx
- ext. */
- return 130;
- }
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 22) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 11) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110x00xxxxx0xxx01xxxxxxxxxx
- dup. */
- return 147;
- }
else
{
- if (((word >> 12) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110x00xxxxx0x0011xxxxxxxxxx
- dup. */
- return 148;
+ 0x001110xx0xxxxxx00110xxxxxxxxxx
+ uzp1. */
+ return 256;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110x00xxxxx0x1011xxxxxxxxxx
- smov. */
- return 149;
+ 0x001110xx0xxxxxx10110xxxxxxxxxx
+ uzp2. */
+ return 259;
}
}
else
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110x00xxxxx0x0111xxxxxxxxxx
- ins. */
- return 152;
+ 0x001110xx0xxxxxx01110xxxxxxxxxx
+ zip1. */
+ return 258;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110x00xxxxx0x1111xxxxxxxxxx
- umov. */
- return 150;
+ 0x001110xx0xxxxxx11110xxxxxxxxxx
+ zip2. */
+ return 261;
}
}
}
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110x00xxxxx0xxxx1xxxxxxxxxx
- ins. */
- return 154;
- }
}
else
{
@@ -12509,13 +12611,21 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 22) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110x00xxxxxxx0001xxxxxxxxxx
+ dup. */
+ return 147;
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110010xxxxx0x0001xxxxxxxxxx
+ 0x001110010xxxxxxx0001xxxxxxxxxx
fmaxnm. */
return 286;
}
@@ -12523,135 +12633,366 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110010xxxxx0x0001xxxxxxxxxx
- fmaxnmp. */
- return 337;
+ 0x001110110xxxxxxx0001xxxxxxxxxx
+ fminnm. */
+ return 302;
}
}
- else
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx0xxxxxxx1001xxxxxxxxxx
+ fcmeq. */
+ return 294;
+ }
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 15) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110110xxxxx0x0001xxxxxxxxxx
- fminnm. */
- return 302;
+ 0x0011100x0xxxxx0x0101xxxxxxxxxx
+ fadd. */
+ return 290;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110110xxxxx0x0001xxxxxxxxxx
- fminnmp. */
- return 353;
+ 0x0011101x0xxxxx0x0101xxxxxxxxxx
+ fsub. */
+ return 306;
}
}
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx0xxxxx1x0101xxxxxxxxxx
+ sdot. */
+ return 1987;
+ }
}
else
{
if (((word >> 23) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011100x0xxxxxxx1101xxxxxxxxxx
+ fmax. */
+ return 296;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011101x0xxxxxxx1101xxxxxxxxxx
+ fmin. */
+ return 308;
+ }
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 12) & 0x1) == 0)
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 22) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110x00xxxxxxx0011xxxxxxxxxx
+ dup. */
+ return 148;
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110010xxxxx0x1001xxxxxxxxxx
- fcmeq. */
- return 294;
+ 0x001110010xxxxxxx0011xxxxxxxxxx
+ fmla. */
+ return 288;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110010xxxxx0x1001xxxxxxxxxx
- fcmge. */
- return 343;
+ 0x001110110xxxxxxx0011xxxxxxxxxx
+ fmls. */
+ return 304;
}
}
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx0xxxxxxx1011xxxxxxxxxx
+ smov. */
+ return 149;
+ }
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 22) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110x00xxxxxxx0111xxxxxxxxxx
+ ins. */
+ return 152;
+ }
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110110xxxxx0x1001xxxxxxxxxx
- fcmgt. */
- return 357;
+ 0x001110x10xxxxxxx0111xxxxxxxxxx
+ fmulx. */
+ return 292;
+ }
+ }
+ else
+ {
+ if (((word >> 22) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110x00xxxxxxx1111xxxxxxxxxx
+ umov. */
+ return 150;
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110010xxxxxxx1111xxxxxxxxxx
+ frecps. */
+ return 298;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110110xxxxxxx1111xxxxxxxxxx
+ frsqrts. */
+ return 310;
+ }
}
}
}
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 22) & 0x1) == 0)
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110000xxxxxxxxxxxxxxxxxxxxx
+ eor3. */
+ return 1994;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110100xxxxxxxxxxxxxxxxxxxxx
+ xar. */
+ return 1996;
+ }
+ }
+ else
+ {
+ if (((word >> 15) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110x10xxxxx0xxxxxxxxxxxxxxx
+ sm3ss1. */
+ return 1998;
+ }
+ else
+ {
+ if (((word >> 10) & 0x1) == 0)
+ {
+ if (((word >> 11) & 0x1) == 0)
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110010xxxxx1xxx00xxxxxxxxxx
+ sm3tt1a. */
+ return 1999;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110110xxxxx1xxx00xxxxxxxxxx
+ sha512su0. */
+ return 1992;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110x10xxxxx1xxx10xxxxxxxxxx
+ sm3tt2a. */
+ return 2001;
+ }
+ }
else
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 11) & 0x1) == 0)
{
if (((word >> 23) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110010xxxxx1xxx01xxxxxxxxxx
+ sm3tt1b. */
+ return 2000;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110110xxxxx1xxx01xxxxxxxxxx
+ sm4e. */
+ return 2005;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110x10xxxxx1xxx11xxxxxxxxxx
+ sm3tt2b. */
+ return 2002;
+ }
+ }
+ }
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 10) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx0xxxxxxxxxx0xxxxxxxxxx
+ ext. */
+ return 130;
+ }
+ else
+ {
+ if (((word >> 15) & 0x1) == 0)
+ {
+ if (((word >> 22) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110x00xxxxx0xxxx1xxxxxxxxxx
+ ins. */
+ return 154;
+ }
+ else
+ {
+ if (((word >> 11) & 0x1) == 0)
+ {
+ if (((word >> 12) & 0x1) == 0)
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110010xxxxx0x0101xxxxxxxxxx
- fadd. */
- return 290;
+ xx101110010xxxxx0x0001xxxxxxxxxx
+ fmaxnmp. */
+ return 337;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110010xxxxx0x0101xxxxxxxxxx
- faddp. */
- return 339;
+ xx101110110xxxxx0x0001xxxxxxxxxx
+ fminnmp. */
+ return 353;
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110110xxxxx0x0101xxxxxxxxxx
- fsub. */
- return 306;
+ xx101110010xxxxx0x1001xxxxxxxxxx
+ fcmge. */
+ return 343;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110110xxxxx0x0101xxxxxxxxxx
- fabd. */
- return 355;
+ xx101110110xxxxx0x1001xxxxxxxxxx
+ fcmgt. */
+ return 357;
}
}
}
else
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110010xxxxx0x1101xxxxxxxxxx
- fmax. */
- return 296;
+ xx101110010xxxxx0x0101xxxxxxxxxx
+ faddp. */
+ return 339;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110010xxxxx0x1101xxxxxxxxxx
- fmaxp. */
- return 347;
+ xx101110110xxxxx0x0101xxxxxxxxxx
+ fabd. */
+ return 355;
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110110xxxxx0x1101xxxxxxxxxx
- fmin. */
- return 308;
+ xx101110010xxxxx0x1101xxxxxxxxxx
+ fmaxp. */
+ return 347;
}
else
{
@@ -12664,37 +13005,15 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
}
}
- }
- else
- {
- if (((word >> 12) & 0x1) == 0)
+ else
{
- if (((word >> 13) & 0x1) == 0)
- {
- if (((word >> 23) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110010xxxxx0x0011xxxxxxxxxx
- fmla. */
- return 288;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110110xxxxx0x0011xxxxxxxxxx
- fmls. */
- return 304;
- }
- }
- else
+ if (((word >> 12) & 0x1) == 0)
{
if (((word >> 23) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110010xxxxx0x1011xxxxxxxxxx
+ xx101110010xxxxx0xx011xxxxxxxxxx
facge. */
return 345;
}
@@ -12702,25 +13021,14 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110110xxxxx0x1011xxxxxxxxxx
+ xx101110110xxxxx0xx011xxxxxxxxxx
facgt. */
return 359;
}
}
- }
- else
- {
- if (((word >> 13) & 0x1) == 0)
+ else
{
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110x10xxxxx0x0111xxxxxxxxxx
- fmulx. */
- return 292;
- }
- else
+ if (((word >> 13) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
@@ -12728,66 +13036,33 @@ aarch64_opcode_lookup_1 (uint32_t word)
fmul. */
return 341;
}
- }
- else
- {
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110010xxxxx0x1111xxxxxxxxxx
- frecps. */
- return 298;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110010xxxxx0x1111xxxxxxxxxx
- fdiv. */
- return 349;
- }
- }
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110110xxxxx0x1111xxxxxxxxxx
- frsqrts. */
- return 310;
+ xx101110x10xxxxx0x1111xxxxxxxxxx
+ fdiv. */
+ return 349;
}
}
}
}
}
- }
- else
- {
- if (((word >> 13) & 0x1) == 0)
+ else
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 11) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 12) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110xx0xxxxx100001xxxxxxxxxx
- sqrdmlah. */
- return 364;
- }
- else
+ if (((word >> 11) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx0xxxxx100101xxxxxxxxxx
- sdot. */
- return 1987;
+ xx101110xx0xxxxx100001xxxxxxxxxx
+ sqrdmlah. */
+ return 364;
}
else
{
@@ -12798,33 +13073,33 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 1986;
}
}
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx0xxxxx100x11xxxxxxxxxx
+ sqrdmlsh. */
+ return 365;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110xx0xxxxx100x11xxxxxxxxxx
- sqrdmlsh. */
- return 365;
+ xx101110xx0xxxxx110xx1xxxxxxxxxx
+ fcmla. */
+ return 366;
}
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110xx0xxxxx110xx1xxxxxxxxxx
- fcmla. */
- return 366;
+ xx101110xx0xxxxx1x1xx1xxxxxxxxxx
+ fcadd. */
+ return 367;
}
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110xx0xxxxx1x1xx1xxxxxxxxxx
- fcadd. */
- return 367;
- }
}
}
}
@@ -13081,309 +13356,661 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- if (((word >> 10) & 0x1) == 0)
+ if (((word >> 28) & 0x1) == 0)
{
- if (((word >> 11) & 0x1) == 0)
+ if (((word >> 15) & 0x1) == 0)
{
- if (((word >> 12) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 31) & 0x1) == 0)
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 10) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 11) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0001110xx1xxxxx000000xxxxxxxxxx
- saddl. */
- return 42;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxxx000000xxxxxxxxxx
+ saddl. */
+ return 42;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx000000xxxxxxxxxx
+ saddl2. */
+ return 43;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1001110xx1xxxxx000000xxxxxxxxxx
- saddl2. */
- return 43;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxxx010000xxxxxxxxxx
+ addhn. */
+ return 50;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx010000xxxxxxxxxx
+ addhn2. */
+ return 51;
+ }
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0101110xx1xxxxx000000xxxxxxxxxx
- uaddl. */
- return 74;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxxx001000xxxxxxxxxx
+ ssubl. */
+ return 46;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx001000xxxxxxxxxx
+ ssubl2. */
+ return 47;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1101110xx1xxxxx000000xxxxxxxxxx
- uaddl2. */
- return 75;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxxx011000xxxxxxxxxx
+ subhn. */
+ return 54;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx011000xxxxxxxxxx
+ subhn2. */
+ return 55;
+ }
}
}
}
else
{
- if (((word >> 16) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 17) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 18) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 20) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx100000000000xxxxxxxxxx
- fcvtns. */
- return 756;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx110000000000xxxxxxxxxx
- fcvtms. */
- return 776;
- }
- }
- else
- {
- if (((word >> 20) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx101000000000xxxxxxxxxx
- fcvtps. */
- return 772;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx111000000000xxxxxxxxxx
- fcvtzs. */
- return 780;
- }
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxxx000100xxxxxxxxxx
+ saddw. */
+ return 44;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx100000000xxxxxxxxxx
- fcvtas. */
- return 764;
+ 01001110xx1xxxxx000100xxxxxxxxxx
+ saddw2. */
+ return 45;
}
}
else
{
- if (((word >> 18) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx010000000xxxxxxxxxx
- scvtf. */
- return 760;
+ 00001110xx1xxxxx010100xxxxxxxxxx
+ sabal. */
+ return 52;
}
else
{
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx010100xxxxxxxxxx
+ sabal2. */
+ return 53;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxxx001100xxxxxxxxxx
+ ssubw. */
+ return 48;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx001100xxxxxxxxxx
+ ssubw2. */
+ return 49;
+ }
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxxx011100xxxxxxxxxx
+ sabdl. */
+ return 56;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx011100xxxxxxxxxx
+ sabdl2. */
+ return 57;
+ }
+ }
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 12) & 0x1) == 0)
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx000010xxxxxxxxxx
+ rev64. */
+ return 156;
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
if (((word >> 19) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1x0110000000xxxxxxxxxx
- fmov. */
- return 768;
+ 0x001110xx1x0xx0010010xxxxxxxxxx
+ cls. */
+ return 160;
}
else
{
- if (((word >> 20) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx101110000000xxxxxxxxxx
- fmov. */
- return 784;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx111110000000xxxxxxxxxx
- fjcvtzs. */
- return 786;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1x1xx0010010xxxxxxxxxx
+ aese. */
+ return 665;
+ }
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxx1010010xxxxxxxxxx
+ sqxtn. */
+ return 170;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxx1010010xxxxxxxxxx
+ sqxtn2. */
+ return 171;
}
}
}
}
else
{
- if (((word >> 17) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 18) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxx0001010xxxxxxxxxx
+ saddlp. */
+ return 158;
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxx1001010xxxxxxxxxx
+ xtn. */
+ return 168;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxx1001010xxxxxxxxxx
+ xtn2. */
+ return 169;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
{
if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 20) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx100001000000xxxxxxxxxx
- fcvtnu. */
- return 758;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx110001000000xxxxxxxxxx
- fcvtmu. */
- return 778;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1x0xx0011010xxxxxxxxxx
+ sadalp. */
+ return 162;
}
else
{
- if (((word >> 20) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx101001000000xxxxxxxxxx
- fcvtpu. */
- return 774;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx111001000000xxxxxxxxxx
- fcvtzu. */
- return 782;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1x1xx0011010xxxxxxxxxx
+ aesmc. */
+ return 667;
}
}
else
{
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxx1011010xxxxxxxxxx
+ fcvtn. */
+ return 172;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxx1011010xxxxxxxxxx
+ fcvtn2. */
+ return 173;
+ }
+ }
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx000110xxxxxxxxxx
+ rev16. */
+ return 157;
+ }
+ else
+ {
+ if (((word >> 19) & 0x1) == 0)
+ {
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx101000000xxxxxxxxxx
- fcvtau. */
- return 766;
+ 0x001110xx1x0xxx010110xxxxxxxxxx
+ cnt. */
+ return 161;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1x1xxx010110xxxxxxxxxx
+ aesd. */
+ return 666;
}
}
- else
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 18) & 0x1) == 0)
+ if (((word >> 20) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx011000000xxxxxxxxxx
- ucvtf. */
- return 762;
+ 0x001110xx10xxxx001110xxxxxxxxxx
+ suqadd. */
+ return 159;
}
else
{
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx11xxxx001110xxxxxxxxxx
+ saddlv. */
+ return 27;
+ }
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
if (((word >> 19) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1x0111000000xxxxxxxxxx
- fmov. */
- return 770;
+ 0x001110xx1x0xx0011110xxxxxxxxxx
+ sqabs. */
+ return 163;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1x1111000000xxxxxxxxxx
- fmov. */
- return 785;
+ 0x001110xx1x1xx0011110xxxxxxxxxx
+ aesimc. */
+ return 668;
+ }
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 00001110xx1xxxx1011110xxxxxxxxxx
+ fcvtl. */
+ return 174;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxx1011110xxxxxxxxxx
+ fcvtl2. */
+ return 175;
}
}
}
}
}
}
+ }
+ else
+ {
+ if (((word >> 11) & 0x1) == 0)
+ {
+ if (((word >> 12) & 0x1) == 0)
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx000001xxxxxxxxxx
+ shadd. */
+ return 262;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx010001xxxxxxxxxx
+ sshl. */
+ return 269;
+ }
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx001001xxxxxxxxxx
+ shsub. */
+ return 265;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx011001xxxxxxxxxx
+ smax. */
+ return 273;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx000101xxxxxxxxxx
+ srhadd. */
+ return 264;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx010101xxxxxxxxxx
+ srshl. */
+ return 271;
+ }
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx001101xxxxxxxxxx
+ cmgt. */
+ return 267;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx011101xxxxxxxxxx
+ sabd. */
+ return 275;
+ }
+ }
+ }
+ }
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x00x1110xx1xxxxx100000xxxxxxxxxx
- smlal. */
- return 58;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx000011xxxxxxxxxx
+ sqadd. */
+ return 263;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx010011xxxxxxxxxx
+ sqshl. */
+ return 270;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x10x1110xx1xxxxx100000xxxxxxxxxx
- smlal2. */
- return 59;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx001011xxxxxxxxxx
+ sqsub. */
+ return 266;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx011011xxxxxxxxxx
+ smin. */
+ return 274;
+ }
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x01x1110xx1xxxxx100000xxxxxxxxxx
- umlal. */
- return 90;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 22) & 0x1) == 0)
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110001xxxxx000111xxxxxxxxxx
+ and. */
+ return 299;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110101xxxxx000111xxxxxxxxxx
+ orr. */
+ return 311;
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110011xxxxx000111xxxxxxxxxx
+ bic. */
+ return 300;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110111xxxxx000111xxxxxxxxxx
+ orn. */
+ return 313;
+ }
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx010111xxxxxxxxxx
+ sqrshl. */
+ return 272;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x11x1110xx1xxxxx100000xxxxxxxxxx
- umlal2. */
- return 91;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx001111xxxxxxxxxx
+ cmge. */
+ return 268;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx011111xxxxxxxxxx
+ saba. */
+ return 276;
+ }
}
}
}
}
- else
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110xx1xxxxx0xxxxxxxxxxxxxxx
+ bcax. */
+ return 1997;
+ }
+ }
+ else
+ {
+ if (((word >> 10) & 0x1) == 0)
+ {
+ if (((word >> 11) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0001110xx1xxxxx010000xxxxxxxxxx
- addhn. */
- return 50;
+ x0101110xx1xxxxx000000xxxxxxxxxx
+ uaddl. */
+ return 74;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1001110xx1xxxxx010000xxxxxxxxxx
- addhn2. */
- return 51;
+ x1101110xx1xxxxx000000xxxxxxxxxx
+ uaddl2. */
+ return 75;
}
}
else
@@ -13408,23 +14035,23 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0001110xx1xxxxx110000xxxxxxxxxx
- smull. */
- return 66;
+ x0101110xx1xxxxx001000xxxxxxxxxx
+ usubl. */
+ return 78;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1001110xx1xxxxx110000xxxxxxxxxx
- smull2. */
- return 67;
+ x1101110xx1xxxxx001000xxxxxxxxxx
+ usubl2. */
+ return 79;
}
}
else
@@ -13433,63 +14060,181 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0101110xx1xxxxx110000xxxxxxxxxx
- umull. */
- return 94;
+ x0101110xx1xxxxx011000xxxxxxxxxx
+ rsubhn. */
+ return 86;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1101110xx1xxxxx110000xxxxxxxxxx
- umull2. */
- return 95;
+ x1101110xx1xxxxx011000xxxxxxxxxx
+ rsubhn2. */
+ return 87;
}
}
}
}
else
{
- if (((word >> 17) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101110xx1xxxxx000100xxxxxxxxxx
+ uaddw. */
+ return 76;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101110xx1xxxxx000100xxxxxxxxxx
+ uaddw2. */
+ return 77;
+ }
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101110xx1xxxxx010100xxxxxxxxxx
+ uabal. */
+ return 84;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101110xx1xxxxx010100xxxxxxxxxx
+ uabal2. */
+ return 85;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101110xx1xxxxx001100xxxxxxxxxx
+ usubw. */
+ return 80;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101110xx1xxxxx001100xxxxxxxxxx
+ usubw2. */
+ return 81;
+ }
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101110xx1xxxxx011100xxxxxxxxxx
+ uabdl. */
+ return 88;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101110xx1xxxxx011100xxxxxxxxxx
+ uabdl2. */
+ return 89;
+ }
+ }
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 12) & 0x1) == 0)
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx000010xxxxxxxxxx
+ rev32. */
+ return 207;
+ }
+ else
{
if (((word >> 16) & 0x1) == 0)
{
- if (((word >> 18) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxx0010010xxxxxxxxxx
+ clz. */
+ return 210;
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx000010000xxxxxxxxxx
- fmov. */
- return 799;
+ x0101110xx1xxxx1010010xxxxxxxxxx
+ uqxtn. */
+ return 220;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx100010000xxxxxxxxxx
- frintn. */
- return 808;
+ x1101110xx1xxxx1010010xxxxxxxxxx
+ uqxtn2. */
+ return 221;
}
}
+ }
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxx0001010xxxxxxxxxx
+ uaddlp. */
+ return 208;
+ }
else
{
- if (((word >> 18) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx001010000xxxxxxxxxx
- fneg. */
- return 803;
+ x0101110xx1xxxx1001010xxxxxxxxxx
+ sqxtun. */
+ return 216;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx101010000xxxxxxxxxx
- frintm. */
- return 812;
+ x1101110xx1xxxx1001010xxxxxxxxxx
+ sqxtun2. */
+ return 217;
}
}
}
@@ -13497,315 +14242,329 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 16) & 0x1) == 0)
{
- if (((word >> 18) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xx000110000xxxxxxxxxx
- fabs. */
- return 801;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xx100110000xxxxxxxxxx
- frintp. */
- return 810;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxx0011010xxxxxxxxxx
+ uadalp. */
+ return 211;
}
else
{
- if (((word >> 18) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx001110000xxxxxxxxxx
- fsqrt. */
- return 805;
+ x0101110xx1xxxx1011010xxxxxxxxxx
+ fcvtxn. */
+ return 222;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx101110000xxxxxxxxxx
- frintz. */
- return 814;
+ x1101110xx1xxxx1011010xxxxxxxxxx
+ fcvtxn2. */
+ return 223;
}
}
}
}
- else
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 18) & 0x1) == 0)
+ if (((word >> 22) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx01xx10000xxxxxxxxxx
- fcvt. */
- return 807;
+ xx101110x01xxxxx0x0110xxxxxxxxxx
+ not. */
+ return 236;
}
else
{
- if (((word >> 15) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110x11xxxxx0x0110xxxxxxxxxx
+ rbit. */
+ return 238;
+ }
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 16) & 0x1) == 0)
{
- if (((word >> 16) & 0x1) == 0)
+ if (((word >> 20) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx110010000xxxxxxxxxx
- frinta. */
- return 816;
+ xx101110xx10xxx0001110xxxxxxxxxx
+ usqadd. */
+ return 209;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1xx111010000xxxxxxxxxx
- frintx. */
- return 818;
+ xx101110xx11xxx0001110xxxxxxxxxx
+ uaddlv. */
+ return 31;
}
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xx11x110000xxxxxxxxxx
- frinti. */
- return 820;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101110xx1xxxx1001110xxxxxxxxxx
+ shll. */
+ return 218;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101110xx1xxxx1001110xxxxxxxxxx
+ shll2. */
+ return 219;
+ }
}
}
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx011110xxxxxxxxxx
+ sqneg. */
+ return 212;
+ }
}
}
}
}
else
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 11) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0001110xx1xxxxx001000xxxxxxxxxx
- ssubl. */
- return 46;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1001110xx1xxxxx001000xxxxxxxxxx
- ssubl2. */
- return 47;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx000001xxxxxxxxxx
+ uhadd. */
+ return 314;
}
else
{
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0101110xx1xxxxx001000xxxxxxxxxx
- usubl. */
- return 78;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1101110xx1xxxxx001000xxxxxxxxxx
- usubl2. */
- return 79;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx010001xxxxxxxxxx
+ ushl. */
+ return 321;
}
}
else
{
- if (((word >> 3) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 4) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xxxxx001000xxxxx00xxx
- fcmp. */
- return 791;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xxxxx001000xxxxx10xxx
- fcmpe. */
- return 793;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx001001xxxxxxxxxx
+ uhsub. */
+ return 317;
}
else
{
- if (((word >> 4) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xxxxx001000xxxxx01xxx
- fcmp. */
- return 795;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xxxxx001000xxxxx11xxx
- fcmpe. */
- return 797;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx011001xxxxxxxxxx
+ umax. */
+ return 325;
}
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x00x1110xx1xxxxx101000xxxxxxxxxx
- smlsl. */
- return 62;
+ xx101110xx1xxxxx000101xxxxxxxxxx
+ urhadd. */
+ return 316;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x10x1110xx1xxxxx101000xxxxxxxxxx
- smlsl2. */
- return 63;
+ xx101110xx1xxxxx010101xxxxxxxxxx
+ urshl. */
+ return 323;
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x01x1110xx1xxxxx101000xxxxxxxxxx
- umlsl. */
- return 92;
+ xx101110xx1xxxxx001101xxxxxxxxxx
+ cmhi. */
+ return 319;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x11x1110xx1xxxxx101000xxxxxxxxxx
- umlsl2. */
- return 93;
+ xx101110xx1xxxxx011101xxxxxxxxxx
+ uabd. */
+ return 327;
}
}
}
}
else
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x00x1110xx1xxxxx011000xxxxxxxxxx
- subhn. */
- return 54;
+ xx101110xx1xxxxx000011xxxxxxxxxx
+ uqadd. */
+ return 315;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x10x1110xx1xxxxx011000xxxxxxxxxx
- subhn2. */
- return 55;
+ xx101110xx1xxxxx010011xxxxxxxxxx
+ uqshl. */
+ return 322;
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x01x1110xx1xxxxx011000xxxxxxxxxx
- rsubhn. */
- return 86;
+ xx101110xx1xxxxx001011xxxxxxxxxx
+ uqsub. */
+ return 318;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x11x1110xx1xxxxx011000xxxxxxxxxx
- rsubhn2. */
- return 87;
+ xx101110xx1xxxxx011011xxxxxxxxxx
+ umin. */
+ return 326;
}
}
}
else
{
- if (((word >> 22) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0xx1110x01xxxxx111000xxxxxxxxxx
- pmull. */
- return 70;
+ if (((word >> 22) & 0x1) == 0)
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110001xxxxx000111xxxxxxxxxx
+ eor. */
+ return 350;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110101xxxxx000111xxxxxxxxxx
+ bit. */
+ return 362;
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110011xxxxx000111xxxxxxxxxx
+ bsl. */
+ return 351;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110111xxxxx000111xxxxxxxxxx
+ bif. */
+ return 363;
+ }
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1xx1110x01xxxxx111000xxxxxxxxxx
- pmull2. */
- return 72;
+ xx101110xx1xxxxx010111xxxxxxxxxx
+ uqrshl. */
+ return 324;
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0xx1110x11xxxxx111000xxxxxxxxxx
- pmull. */
- return 71;
+ xx101110xx1xxxxx001111xxxxxxxxxx
+ cmhs. */
+ return 320;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1xx1110x11xxxxx111000xxxxxxxxxx
- pmull2. */
- return 73;
+ xx101110xx1xxxxx011111xxxxxxxxxx
+ uaba. */
+ return 328;
}
}
}
}
}
}
- else
+ }
+ else
+ {
+ if (((word >> 10) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 11) & 0x1) == 0)
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -13813,17 +14572,28 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0001110xx1xxxxx000100xxxxxxxxxx
- saddw. */
- return 44;
+ x0001110xx1xxxxx100000xxxxxxxxxx
+ smlal. */
+ return 58;
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1001110xx1xxxxx000100xxxxxxxxxx
- saddw2. */
- return 45;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx100000xxxxxxxxxx
+ smlal2. */
+ return 59;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 11001110xx1xxxxx100000xxxxxxxxxx
+ sha512h. */
+ return 1990;
+ }
}
}
else
@@ -13832,43 +14602,76 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0101110xx1xxxxx000100xxxxxxxxxx
- uaddw. */
- return 76;
+ x0101110xx1xxxxx100000xxxxxxxxxx
+ umlal. */
+ return 90;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1101110xx1xxxxx000100xxxxxxxxxx
- uaddw2. */
- return 77;
+ x1101110xx1xxxxx100000xxxxxxxxxx
+ umlal2. */
+ return 91;
}
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x01110xx1xxxxx100100xxxxxxxxxx
- sqdmlal. */
- return 60;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0001110xx1xxxxx110000xxxxxxxxxx
+ smull. */
+ return 66;
+ }
+ else
+ {
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 01001110xx1xxxxx110000xxxxxxxxxx
+ smull2. */
+ return 67;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 11001110xx1xxxxx110000xxxxxxxxxx
+ sm3partw1. */
+ return 2003;
+ }
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x01110xx1xxxxx100100xxxxxxxxxx
- sqdmlal2. */
- return 61;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101110xx1xxxxx110000xxxxxxxxxx
+ umull. */
+ return 94;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101110xx1xxxxx110000xxxxxxxxxx
+ umull2. */
+ return 95;
+ }
}
}
}
else
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -13876,17 +14679,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0001110xx1xxxxx010100xxxxxxxxxx
- sabal. */
- return 52;
+ x0001110xx1xxxxx101000xxxxxxxxxx
+ smlsl. */
+ return 62;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1001110xx1xxxxx010100xxxxxxxxxx
- sabal2. */
- return 53;
+ x1001110xx1xxxxx101000xxxxxxxxxx
+ smlsl2. */
+ return 63;
}
}
else
@@ -13895,64 +14698,39 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0101110xx1xxxxx010100xxxxxxxxxx
- uabal. */
- return 84;
+ x0101110xx1xxxxx101000xxxxxxxxxx
+ umlsl. */
+ return 92;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1101110xx1xxxxx010100xxxxxxxxxx
- uabal2. */
- return 85;
+ x1101110xx1xxxxx101000xxxxxxxxxx
+ umlsl2. */
+ return 93;
}
}
}
else
{
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x01110xx1xxxxx110100xxxxxxxxxx
- sqdmull. */
- return 68;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x01110xx1xxxxx110100xxxxxxxxxx
- sqdmull2. */
- return 69;
- }
- }
- }
- }
- else
- {
- if (((word >> 14) & 0x1) == 0)
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 22) & 0x1) == 0)
{
if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0001110xx1xxxxx001100xxxxxxxxxx
- ssubw. */
- return 48;
+ x0x01110x01xxxxx111000xxxxxxxxxx
+ pmull. */
+ return 70;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1001110xx1xxxxx001100xxxxxxxxxx
- ssubw2. */
- return 49;
+ x1x01110x01xxxxx111000xxxxxxxxxx
+ pmull2. */
+ return 72;
}
}
else
@@ -13961,59 +14739,43 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0101110xx1xxxxx001100xxxxxxxxxx
- usubw. */
- return 80;
+ x0x01110x11xxxxx111000xxxxxxxxxx
+ pmull. */
+ return 71;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1101110xx1xxxxx001100xxxxxxxxxx
- usubw2. */
- return 81;
+ x1x01110x11xxxxx111000xxxxxxxxxx
+ pmull2. */
+ return 73;
}
}
}
- else
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x01110xx1xxxxx101100xxxxxxxxxx
- sqdmlsl. */
- return 64;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x01110xx1xxxxx101100xxxxxxxxxx
- sqdmlsl2. */
- return 65;
- }
- }
}
- else
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0001110xx1xxxxxx11100xxxxxxxxxx
- sabdl. */
- return 56;
+ x0x01110xx1xxxxx100100xxxxxxxxxx
+ sqdmlal. */
+ return 60;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1001110xx1xxxxxx11100xxxxxxxxxx
- sabdl2. */
- return 57;
+ x1x01110xx1xxxxx100100xxxxxxxxxx
+ sqdmlal2. */
+ return 61;
}
}
else
@@ -14022,410 +14784,242 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0101110xx1xxxxxx11100xxxxxxxxxx
- uabdl. */
- return 88;
+ x0x01110xx1xxxxx110100xxxxxxxxxx
+ sqdmull. */
+ return 68;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1101110xx1xxxxxx11100xxxxxxxxxx
- uabdl2. */
- return 89;
+ x1x01110xx1xxxxx110100xxxxxxxxxx
+ sqdmull2. */
+ return 69;
}
}
}
- }
- }
- else
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x11110xx1xxxxxxxx100xxxxxxxxxx
- fmov. */
- return 848;
- }
- else
- {
- if (((word >> 13) & 0x1) == 0)
+ else
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1x11110xx1xxxxxx00100xxxxxxxxxx
- sqdmlal. */
- return 416;
+ x0x01110xx1xxxxx1x1100xxxxxxxxxx
+ sqdmlsl. */
+ return 64;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1x11110xx1xxxxxx10100xxxxxxxxxx
- sqdmull. */
- return 418;
+ x1x01110xx1xxxxx1x1100xxxxxxxxxx
+ sqdmlsl2. */
+ return 65;
}
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x11110xx1xxxxxxx1100xxxxxxxxxx
- sqdmlsl. */
- return 417;
- }
}
}
- }
- }
- else
- {
- if (((word >> 12) & 0x1) == 0)
- {
- if (((word >> 13) & 0x1) == 0)
+ else
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx000010xxxxxxxxxx
- rev64. */
- return 156;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx000010xxxxxxxxxx
- rev32. */
- return 207;
- }
- }
- else
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x11110xx1xxxxx000010xxxxxxxxxx
- fmul. */
- return 822;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x11110xx1xxxxx000010xxxxxxxxxx
- sha1h. */
- return 669;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxx0100010xxxxxxxxxx
- cmgt. */
- return 164;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxx0100010xxxxxxxxxx
- cmge. */
- return 213;
- }
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
+ if (((word >> 31) & 0x1) == 0)
{
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0011100x1x0xx1100010xxxxxxxxxx
- frintn. */
- return 176;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1011100x1x0xx1100010xxxxxxxxxx
- frinta. */
- return 224;
- }
- }
- else
+ if (((word >> 16) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx011101x1x0xx1100010xxxxxxxxxx
- frintp. */
- return 196;
+ 0x001110xx1xxxx0100010xxxxxxxxxx
+ cmgt. */
+ return 164;
}
- }
- else
- {
- if (((word >> 23) & 0x1) == 0)
+ else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0011100x1x1xx1100010xxxxxxxxxx
- frintn. */
- return 177;
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011100x1x0xx1100010xxxxxxxxxx
+ frintn. */
+ return 176;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011101x1x0xx1100010xxxxxxxxxx
+ frintp. */
+ return 196;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1011100x1x1xx1100010xxxxxxxxxx
- frinta. */
- return 225;
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011100x1x1xx1100010xxxxxxxxxx
+ frintn. */
+ return 177;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011101x1x1xx1100010xxxxxxxxxx
+ frintp. */
+ return 197;
+ }
}
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx011101x1x1xx1100010xxxxxxxxxx
- frintp. */
- return 197;
- }
- }
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0011110xx1xxxxx100010xxxxxxxxxx
- fnmul. */
- return 838;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1011110xx1xxxxx100010xxxxxxxxxx
- cmgt. */
- return 476;
+ 1x001110xx1xxxxx100010xxxxxxxxxx
+ sha512su1. */
+ return 1993;
}
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxx100010xxxxxxxxxx
- cmge. */
- return 505;
- }
- }
- }
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1x0xx0010010xxxxxxxxxx
- cls. */
- return 160;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1x0xx0010010xxxxxxxxxx
- clz. */
- return 210;
- }
- }
- else
+ if (((word >> 16) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110xx1x1xx0010010xxxxxxxxxx
- aese. */
- return 665;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0001110xx1xxxx1010010xxxxxxxxxx
- sqxtn. */
- return 170;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1001110xx1xxxx1010010xxxxxxxxxx
- sqxtn2. */
- return 171;
- }
+ xx101110xx1xxxx0100010xxxxxxxxxx
+ cmge. */
+ return 213;
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0101110xx1xxxx1010010xxxxxxxxxx
- uqxtn. */
- return 220;
+ xx101110xx1x0xx1100010xxxxxxxxxx
+ frinta. */
+ return 224;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1101110xx1xxxx1010010xxxxxxxxxx
- uqxtn2. */
- return 221;
+ xx101110xx1x1xx1100010xxxxxxxxxx
+ frinta. */
+ return 225;
}
}
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0011110xx1xxxxx010010xxxxxxxxxx
- fmax. */
- return 830;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1011110xx1xxxxx010010xxxxxxxxxx
- sqxtn. */
- return 480;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxx010010xxxxxxxxxx
- uqxtn. */
- return 509;
- }
- }
- }
- else
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 19) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
- if (((word >> 20) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 31) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx100xx0110010xxxxxxxxxx
- fcmgt. */
- return 188;
+ 0x0011100x1xxxx0110010xxxxxxxxxx
+ fmaxnmv. */
+ return 35;
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx100xx0110010xxxxxxxxxx
- fcmge. */
- return 239;
+ if (((word >> 19) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011100x1x0xx1110010xxxxxxxxxx
+ fcvtas. */
+ return 184;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011100x1x1xx1110010xxxxxxxxxx
+ fcvtas. */
+ return 185;
+ }
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x0011100x1xxxxx110010xxxxxxxxxx
+ sm4ekey. */
+ return 2006;
+ }
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1011100x1xxxx0110010xxxxxxxxxx
+ fmaxnmv. */
+ return 34;
+ }
+ else
+ {
+ if (((word >> 19) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx011110xx100xx0110010xxxxxxxxxx
- fcmgt. */
- return 489;
+ xx1011100x1x0xx1110010xxxxxxxxxx
+ fcvtau. */
+ return 232;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx111110xx100xx0110010xxxxxxxxxx
- fcmge. */
- return 519;
+ xx1011100x1x1xx1110010xxxxxxxxxx
+ fcvtau. */
+ return 233;
}
}
}
- else
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 20) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0011100x110xx0110010xxxxxxxxxx
- fmaxnmv. */
- return 35;
+ xx0011101x100xx0110010xxxxxxxxxx
+ fcmgt. */
+ return 188;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx1011100x110xx0110010xxxxxxxxxx
- fmaxnmv. */
- return 34;
+ xx1011101x100xx0110010xxxxxxxxxx
+ fcmge. */
+ return 239;
}
}
else
@@ -14434,28 +15028,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x110xx0110010xxxxxxxxxx
- fmaxnmp. */
- return 533;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x110xx0110010xxxxxxxxxx
- fmaxnmp. */
- return 532;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xx0011101x110xx0110010xxxxxxxxxx
fminnmv. */
return 39;
@@ -14469,94 +15041,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 38;
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0111101x110xx0110010xxxxxxxxxx
- fminnmp. */
- return 539;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x110xx0110010xxxxxxxxxx
- fminnmp. */
- return 538;
- }
- }
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1x1xx0110010xxxxxxxxxx
- fcmgt. */
- return 189;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1x1xx0110010xxxxxxxxxx
- fcmge. */
- return 240;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx011110xx1x1xx0110010xxxxxxxxxx
- fcmgt. */
- return 490;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1x1xx0110010xxxxxxxxxx
- fcmge. */
- return 520;
- }
- }
- }
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0011100x1x0xx1110010xxxxxxxxxx
- fcvtas. */
- return 184;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1011100x1x0xx1110010xxxxxxxxxx
- fcvtau. */
- return 232;
- }
}
else
{
@@ -14564,17 +15048,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x1x0xx1110010xxxxxxxxxx
- fcvtas. */
- return 485;
+ xx0011101x1x1xx0110010xxxxxxxxxx
+ fcmgt. */
+ return 189;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx1111100x1x0xx1110010xxxxxxxxxx
- fcvtau. */
- return 515;
+ xx1011101x1x1xx0110010xxxxxxxxxx
+ fcmge. */
+ return 240;
}
}
}
@@ -14584,7 +15068,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0x11101x1x0xx1110010xxxxxxxxxx
+ xx0011101x1xxxx1110010xxxxxxxxxx
urecpe. */
return 204;
}
@@ -14592,209 +15076,55 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx1x11101x1x0xx1110010xxxxxxxxxx
+ xx1011101x1xxxx1110010xxxxxxxxxx
ursqrte. */
return 251;
}
}
}
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1x1xx1110010xxxxxxxxxx
- fcvtas. */
- return 185;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1x1xx1110010xxxxxxxxxx
- fcvtau. */
- return 233;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx011110xx1x1xx1110010xxxxxxxxxx
- fcvtas. */
- return 486;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1x1xx1110010xxxxxxxxxx
- fcvtau. */
- return 516;
- }
- }
- }
}
}
- }
- }
- else
- {
- if (((word >> 14) & 0x1) == 0)
- {
- if (((word >> 15) & 0x1) == 0)
+ else
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 16) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxx0001010xxxxxxxxxx
- saddlp. */
- return 158;
- }
- else
+ if (((word >> 20) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxx0001010xxxxxxxxxx
- uaddlp. */
- return 208;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0001110xx1xxxx1001010xxxxxxxxxx
- xtn. */
- return 168;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1001110xx1xxxx1001010xxxxxxxxxx
- xtn2. */
- return 169;
- }
+ xxx01110xx10xxx0101010xxxxxxxxxx
+ cmlt. */
+ return 166;
}
else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x0101110xx1xxxx1001010xxxxxxxxxx
- sqxtun. */
- return 216;
+ xx001110xx11xxx0101010xxxxxxxxxx
+ smaxv. */
+ return 28;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1101110xx1xxxx1001010xxxxxxxxxx
- sqxtun2. */
- return 217;
+ xx101110xx11xxx0101010xxxxxxxxxx
+ umaxv. */
+ return 32;
}
}
}
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0011110xx1xxxxx001010xxxxxxxxxx
- fadd. */
- return 826;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1011110xx1xxxxx001010xxxxxxxxxx
- sha256su0. */
- return 671;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxx001010xxxxxxxxxx
- sqxtun. */
- return 508;
- }
- }
- }
- else
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 20) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110xx10xxx0101010xxxxxxxxxx
- cmlt. */
- return 166;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx10xxx0101010xxxxxxxxxx
- cmlt. */
- return 478;
- }
- }
else
{
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x1110xx11xxx0101010xxxxxxxxxx
- smaxv. */
- return 28;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x1110xx11xxx0101010xxxxxxxxxx
- umaxv. */
- return 32;
- }
- }
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 20) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 20) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -14819,28 +15149,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x100xx1101010xxxxxxxxxx
- fcvtns. */
- return 481;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x100xx1101010xxxxxxxxxx
- fcvtnu. */
- return 511;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xx0011101x100xx1101010xxxxxxxxxx
fcvtps. */
return 200;
@@ -14854,93 +15162,49 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 247;
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0111101x100xx1101010xxxxxxxxxx
- fcvtps. */
- return 495;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x100xx1101010xxxxxxxxxx
- fcvtpu. */
- return 523;
- }
- }
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x1110xx110xx1101010xxxxxxxxxx
- sminv. */
- return 29;
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x1110xx110xx1101010xxxxxxxxxx
- uminv. */
- return 33;
- }
- }
- }
- else
- {
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0011100x1x1xx1101010xxxxxxxxxx
- fcvtns. */
- return 181;
+ xx001110xx110xx1101010xxxxxxxxxx
+ sminv. */
+ return 29;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx1011100x1x1xx1101010xxxxxxxxxx
- fcvtnu. */
- return 229;
+ xx101110xx110xx1101010xxxxxxxxxx
+ uminv. */
+ return 33;
}
}
- else
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x1x1xx1101010xxxxxxxxxx
+ xx0011100x1x1xx1101010xxxxxxxxxx
fcvtns. */
- return 482;
+ return 181;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx1111100x1x1xx1101010xxxxxxxxxx
+ xx1011100x1x1xx1101010xxxxxxxxxx
fcvtnu. */
- return 512;
+ return 229;
}
}
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
+ else
{
if (((word >> 29) & 0x1) == 0)
{
@@ -14959,133 +15223,12 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 248;
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0111101x1x1xx1101010xxxxxxxxxx
- fcvtps. */
- return 496;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x1x1xx1101010xxxxxxxxxx
- fcvtpu. */
- return 524;
- }
- }
- }
- }
- }
- }
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1x0xx0011010xxxxxxxxxx
- sadalp. */
- return 162;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1x0xx0011010xxxxxxxxxx
- uadalp. */
- return 211;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110xx1x1xx0011010xxxxxxxxxx
- aesmc. */
- return 667;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0001110xx1xxxx1011010xxxxxxxxxx
- fcvtn. */
- return 172;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1001110xx1xxxx1011010xxxxxxxxxx
- fcvtn2. */
- return 173;
- }
- }
- else
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0101110xx1xxxx1011010xxxxxxxxxx
- fcvtxn. */
- return 222;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1101110xx1xxxx1011010xxxxxxxxxx
- fcvtxn2. */
- return 223;
- }
}
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx011110xx1xxxxx011010xxxxxxxxxx
- fmaxnm. */
- return 834;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxx011010xxxxxxxxxx
- fcvtxn. */
- return 510;
- }
- }
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
@@ -15097,75 +15240,20 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1x0xxx111010xxxxxxxxxx
- fcmlt. */
- return 493;
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xxx01110xx1x1xxx111010xxxxxxxxxx
fcmlt. */
return 193;
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1x1xxx111010xxxxxxxxxx
- fcmlt. */
- return 494;
- }
}
}
}
- }
- }
- else
- {
- if (((word >> 13) & 0x1) == 0)
- {
- if (((word >> 14) & 0x1) == 0)
+ else
{
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110xx1xxxxx000110xxxxxxxxxx
- rev16. */
- return 157;
- }
- else
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x11110xx1xxxxx000110xxxxxxxxxx
- fdiv. */
- return 824;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x11110xx1xxxxx000110xxxxxxxxxx
- sha1su1. */
- return 670;
- }
- }
- }
- else
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 16) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -15186,190 +15274,25 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx011110xx1xxxx0100110xxxxxxxxxx
- cmeq. */
- return 477;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxx0100110xxxxxxxxxx
- cmle. */
- return 506;
- }
- }
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x11100x1x0xx1100110xxxxxxxxxx
- frintm. */
- return 178;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x11100x1x0xx1100110xxxxxxxxxx
- frintx. */
- return 226;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x11101x1x0xx1100110xxxxxxxxxx
- frintz. */
- return 198;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x11101x1x0xx1100110xxxxxxxxxx
- frinti. */
- return 245;
- }
- }
- }
- else
- {
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x11100x1x1xx1100110xxxxxxxxxx
- frintm. */
- return 179;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x11100x1x1xx1100110xxxxxxxxxx
- frintx. */
- return 227;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x11101x1x1xx1100110xxxxxxxxxx
- frintz. */
- return 199;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x11101x1x1xx1100110xxxxxxxxxx
- frinti. */
- return 246;
- }
- }
- }
- }
- }
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1x0xxx010110xxxxxxxxxx
- cnt. */
- return 161;
- }
- else
- {
- if (((word >> 22) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110x01x0xxx010110xxxxxxxxxx
- not. */
- return 236;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110x11x0xxx010110xxxxxxxxxx
- rbit. */
- return 238;
- }
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110xx1x1xxx010110xxxxxxxxxx
- aesd. */
- return 666;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1xxxxx010110xxxxxxxxxx
- fmin. */
- return 832;
- }
- }
- else
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 20) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx100xx0110110xxxxxxxxxx
- fcmeq. */
- return 190;
+ xx0011100x1x0xx1100110xxxxxxxxxx
+ frintm. */
+ return 178;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx100xx0110110xxxxxxxxxx
- fcmle. */
- return 241;
+ xx1011100x1x0xx1100110xxxxxxxxxx
+ frintx. */
+ return 226;
}
}
else
@@ -15378,59 +15301,84 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx011110xx100xx0110110xxxxxxxxxx
- fcmeq. */
- return 491;
+ xx0011101x1x0xx1100110xxxxxxxxxx
+ frintz. */
+ return 198;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx111110xx100xx0110110xxxxxxxxxx
- fcmle. */
- return 521;
+ xx1011101x1x0xx1100110xxxxxxxxxx
+ frinti. */
+ return 245;
}
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x1110xx110xx0110110xxxxxxxxxx
- faddp. */
- return 535;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0011100x1x1xx1100110xxxxxxxxxx
+ frintm. */
+ return 179;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1011100x1x1xx1100110xxxxxxxxxx
+ frintx. */
+ return 227;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x1110xx110xx0110110xxxxxxxxxx
- faddp. */
- return 534;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0011101x1x1xx1100110xxxxxxxxxx
+ frintz. */
+ return 199;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1011101x1x1xx1100110xxxxxxxxxx
+ frinti. */
+ return 246;
+ }
}
}
}
- else
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx1x1xx0110110xxxxxxxxxx
+ xx001110xx1x0xx0110110xxxxxxxxxx
fcmeq. */
- return 191;
+ return 190;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1x1xx0110110xxxxxxxxxx
+ xx101110xx1x0xx0110110xxxxxxxxxx
fcmle. */
- return 242;
+ return 241;
}
}
else
@@ -15439,28 +15387,25 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx011110xx1x1xx0110110xxxxxxxxxx
+ xx001110xx1x1xx0110110xxxxxxxxxx
fcmeq. */
- return 492;
+ return 191;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx111110xx1x1xx0110110xxxxxxxxxx
+ xx101110xx1x1xx0110110xxxxxxxxxx
fcmle. */
- return 522;
+ return 242;
}
}
}
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
+ else
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -15485,28 +15430,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x1x0xx1110110xxxxxxxxxx
- scvtf. */
- return 487;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x1x0xx1110110xxxxxxxxxx
- ucvtf. */
- return 517;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xx0011101x1x0xx1110110xxxxxxxxxx
frecpe. */
return 205;
@@ -15520,32 +15443,10 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 252;
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0111101x1x0xx1110110xxxxxxxxxx
- frecpe. */
- return 499;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x1x0xx1110110xxxxxxxxxx
- frsqrte. */
- return 527;
- }
- }
}
- }
- else
- {
- if (((word >> 23) & 0x1) == 0)
+ else
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -15570,28 +15471,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x1x1xx1110110xxxxxxxxxx
- scvtf. */
- return 488;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x1x1xx1110110xxxxxxxxxx
- ucvtf. */
- return 518;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xx0011101x1x1xx1110110xxxxxxxxxx
frecpe. */
return 206;
@@ -15605,136 +15484,15 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 253;
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0111101x1x1xx1110110xxxxxxxxxx
- frecpe. */
- return 500;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x1x1xx1110110xxxxxxxxxx
- frsqrte. */
- return 528;
- }
- }
- }
- }
- }
- }
- }
- }
- else
- {
- if (((word >> 14) & 0x1) == 0)
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 20) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx10xxx0001110xxxxxxxxxx
- suqadd. */
- return 159;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx10xxx0001110xxxxxxxxxx
- usqadd. */
- return 209;
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx11xxx0001110xxxxxxxxxx
- saddlv. */
- return 27;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx11xxx0001110xxxxxxxxxx
- uaddlv. */
- return 31;
- }
- }
- }
- else
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x01110xx1xxxx1001110xxxxxxxxxx
- shll. */
- return 218;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x01110xx1xxxx1001110xxxxxxxxxx
- shll2. */
- return 219;
}
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0011110xx1xxxxx001110xxxxxxxxxx
- fsub. */
- return 828;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1011110xx1xxxxx001110xxxxxxxxxx
- suqadd. */
- return 474;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxx001110xxxxxxxxxx
- usqadd. */
- return 503;
- }
- }
}
else
{
- if (((word >> 16) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -15755,33 +15513,11 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx011110xx1xxxx0101110xxxxxxxxxx
- abs. */
- return 479;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxx0101110xxxxxxxxxx
- neg. */
- return 507;
- }
- }
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 20) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 20) & 0x1) == 0)
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -15806,28 +15542,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x100xx1101110xxxxxxxxxx
- fcvtms. */
- return 483;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x100xx1101110xxxxxxxxxx
- fcvtmu. */
- return 513;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xx0011101x100xx1101110xxxxxxxxxx
fcvtzs. */
return 202;
@@ -15841,30 +15555,8 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 249;
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0111101x100xx1101110xxxxxxxxxx
- fcvtzs. */
- return 497;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x100xx1101110xxxxxxxxxx
- fcvtzu. */
- return 525;
- }
- }
}
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
+ else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
@@ -15872,21 +15564,10 @@ aarch64_opcode_lookup_1 (uint32_t word)
addv. */
return 30;
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx110xx1101110xxxxxxxxxx
- addp. */
- return 531;
- }
}
- }
- else
- {
- if (((word >> 23) & 0x1) == 0)
+ else
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -15911,28 +15592,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x1x1xx1101110xxxxxxxxxx
- fcvtms. */
- return 484;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x1x1xx1101110xxxxxxxxxx
- fcvtmu. */
- return 514;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xx0011101x1x1xx1101110xxxxxxxxxx
fcvtzs. */
return 203;
@@ -15946,147 +15605,37 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 250;
}
}
- else
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ if (((word >> 19) & 0x1) == 0)
+ {
+ if (((word >> 20) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111101x1x1xx1101110xxxxxxxxxx
- fcvtzs. */
- return 498;
+ xx001110xx100xx0111110xxxxxxxxxx
+ fabs. */
+ return 194;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx1111101x1x1xx1101110xxxxxxxxxx
- fcvtzu. */
- return 526;
+ xx101110xx100xx0111110xxxxxxxxxx
+ fneg. */
+ return 243;
}
}
- }
- }
- }
- }
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1x0xx0011110xxxxxxxxxx
- sqabs. */
- return 163;
- }
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1x0xx0011110xxxxxxxxxx
- sqneg. */
- return 212;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01110xx1x1xx0011110xxxxxxxxxx
- aesimc. */
- return 668;
- }
- }
- else
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0x01110xx1xxxx1011110xxxxxxxxxx
- fcvtl. */
- return 174;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1x01110xx1xxxx1011110xxxxxxxxxx
- fcvtl2. */
- return 175;
- }
- }
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0011110xx1xxxxx011110xxxxxxxxxx
- fminnm. */
- return 836;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1011110xx1xxxxx011110xxxxxxxxxx
- sqabs. */
- return 475;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxx011110xxxxxxxxxx
- sqneg. */
- return 504;
- }
- }
- }
- else
- {
- if (((word >> 16) & 0x1) == 0)
- {
- if (((word >> 19) & 0x1) == 0)
- {
- if (((word >> 20) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x1110xx100xx0111110xxxxxxxxxx
- fabs. */
- return 194;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x1110xx100xx0111110xxxxxxxxxx
- fneg. */
- return 243;
- }
- }
- else
- {
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -16111,28 +15660,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx0111100x110xx0111110xxxxxxxxxx
- fmaxp. */
- return 537;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x110xx0111110xxxxxxxxxx
- fmaxp. */
- return 536;
- }
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xx0011101x110xx0111110xxxxxxxxxx
fminv. */
return 41;
@@ -16146,53 +15673,31 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 40;
}
}
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0111101x110xx0111110xxxxxxxxxx
- fminp. */
- return 541;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x110xx0111110xxxxxxxxxx
- fminp. */
- return 540;
- }
- }
}
}
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0x1110xx1x1xx0111110xxxxxxxxxx
- fabs. */
- return 195;
- }
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1x1110xx1x1xx0111110xxxxxxxxxx
- fneg. */
- return 244;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx001110xx1x1xx0111110xxxxxxxxxx
+ fabs. */
+ return 195;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1x1xx0111110xxxxxxxxxx
+ fneg. */
+ return 244;
+ }
}
}
- }
- else
- {
- if (((word >> 19) & 0x1) == 0)
+ else
{
- if (((word >> 28) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
@@ -16204,77 +15709,44 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx11110xx1x0xx1111110xxxxxxxxxx
- frecpx. */
- return 501;
- }
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
xxx01110xx1x1xx1111110xxxxxxxxxx
fsqrt. */
return 255;
}
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx11110xx1x1xx1111110xxxxxxxxxx
- frecpx. */
- return 502;
- }
}
}
}
}
}
}
- }
- }
- else
- {
- if (((word >> 11) & 0x1) == 0)
- {
- if (((word >> 28) & 0x1) == 0)
+ else
{
- if (((word >> 12) & 0x1) == 0)
+ if (((word >> 11) & 0x1) == 0)
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx000001xxxxxxxxxx
- shadd. */
- return 262;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx000001xxxxxxxxxx
- uhadd. */
- return 314;
- }
- }
- else
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx100001xxxxxxxxxx
- add. */
- return 277;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx100001xxxxxxxxxx
+ add. */
+ return 277;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110xx1xxxxx100001xxxxxxxxxx
+ sha512h2. */
+ return 1991;
+ }
}
else
{
@@ -16285,39 +15757,28 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 329;
}
}
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx010001xxxxxxxxxx
- sshl. */
- return 269;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx010001xxxxxxxxxx
- ushl. */
- return 321;
- }
- }
else
{
if (((word >> 23) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0011100x1xxxxx110001xxxxxxxxxx
- fmaxnm. */
- return 285;
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x0011100x1xxxxx110001xxxxxxxxxx
+ fmaxnm. */
+ return 285;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x0011100x1xxxxx110001xxxxxxxxxx
+ sm3partw2. */
+ return 2004;
+ }
}
else
{
@@ -16349,31 +15810,9 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
}
}
- }
- else
- {
- if (((word >> 14) & 0x1) == 0)
+ else
{
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx001001xxxxxxxxxx
- shsub. */
- return 265;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx001001xxxxxxxxxx
- uhsub. */
- return 317;
- }
- }
- else
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -16392,28 +15831,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 333;
}
}
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx011001xxxxxxxxxx
- smax. */
- return 273;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx011001xxxxxxxxxx
- umax. */
- return 325;
- }
- }
else
{
if (((word >> 23) & 0x1) == 0)
@@ -16446,33 +15863,11 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
}
}
- }
- else
- {
- if (((word >> 13) & 0x1) == 0)
+ else
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx000101xxxxxxxxxx
- srhadd. */
- return 264;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx000101xxxxxxxxxx
- urhadd. */
- return 316;
- }
- }
- else
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -16491,28 +15886,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 331;
}
}
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx010101xxxxxxxxxx
- srshl. */
- return 271;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx010101xxxxxxxxxx
- urshl. */
- return 323;
- }
- }
else
{
if (((word >> 23) & 0x1) == 0)
@@ -16555,31 +15928,9 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
}
}
- }
- else
- {
- if (((word >> 14) & 0x1) == 0)
+ else
{
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx001101xxxxxxxxxx
- cmgt. */
- return 267;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx001101xxxxxxxxxx
- cmhi. */
- return 319;
- }
- }
- else
+ if (((word >> 14) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
@@ -16598,28 +15949,6 @@ aarch64_opcode_lookup_1 (uint32_t word)
return 335;
}
}
- }
- else
- {
- if (((word >> 15) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx011101xxxxxxxxxx
- sabd. */
- return 275;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx011101xxxxxxxxxx
- uabd. */
- return 327;
- }
- }
else
{
if (((word >> 23) & 0x1) == 0)
@@ -16664,184 +15993,690 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
}
}
- }
- else
- {
- if (((word >> 29) & 0x1) == 0)
+ else
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 4) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0011110xx1xxxxxxxxx01xxxxx0xxxx
- fccmp. */
- return 787;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 0x001110xx1xxxxx100011xxxxxxxxxx
+ cmtst. */
+ return 278;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ 1x001110xx1xxxxx100011xxxxxxxxxx
+ rax1. */
+ return 1995;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx100011xxxxxxxxxx
+ cmeq. */
+ return 330;
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0011100x1xxxxx110011xxxxxxxxxx
+ fmla. */
+ return 287;
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x01011100x1xxxxx110011xxxxxxxxxx
+ fmlal2. */
+ return 2009;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x11011100x1xxxxx110011xxxxxxxxxx
+ fmlal2. */
+ return 2013;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0011101x1xxxxx110011xxxxxxxxxx
+ fmls. */
+ return 303;
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x01011101x1xxxxx110011xxxxxxxxxx
+ fmlsl2. */
+ return 2010;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x11011101x1xxxxx110011xxxxxxxxxx
+ fmlsl2. */
+ return 2014;
+ }
+ }
+ }
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x0011110xx1xxxxxxxxx01xxxxx1xxxx
- fccmpe. */
- return 789;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx001110xx1xxxxx101011xxxxxxxxxx
+ sminp. */
+ return 282;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx101011xxxxxxxxxx
+ uminp. */
+ return 334;
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x00011100x1xxxxx111011xxxxxxxxxx
+ fmlal. */
+ return 2007;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x10011100x1xxxxx111011xxxxxxxxxx
+ fmlal. */
+ return 2011;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1011100x1xxxxx111011xxxxxxxxxx
+ facge. */
+ return 344;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x00011101x1xxxxx111011xxxxxxxxxx
+ fmlsl. */
+ return 2008;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x10011101x1xxxxx111011xxxxxxxxxx
+ fmlsl. */
+ return 2012;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1011101x1xxxxx111011xxxxxxxxxx
+ facgt. */
+ return 358;
+ }
+ }
+ }
}
}
else
{
- if (((word >> 12) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 29) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1011110xx1xxxxxx00001xxxxxxxxxx
- add. */
- return 559;
+ xx001110xx1xxxxx100111xxxxxxxxxx
+ mul. */
+ return 280;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1011110xx1xxxxxx10001xxxxxxxxxx
- sshl. */
- return 557;
+ xx101110xx1xxxxx100111xxxxxxxxxx
+ pmul. */
+ return 332;
}
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1011110xx1xxxxxxx1001xxxxxxxxxx
- fcmeq. */
- return 549;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx001110xx1xxxxx110111xxxxxxxxxx
+ fmulx. */
+ return 291;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101110xx1xxxxx110111xxxxxxxxxx
+ fmul. */
+ return 340;
+ }
}
}
else
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1011110xx1xxxxxxx0101xxxxxxxxxx
- srshl. */
- return 558;
+ xxx01110xx1xxxxx101111xxxxxxxxxx
+ addp. */
+ return 284;
}
else
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- x1011110xx1xxxxx0x1101xxxxxxxxxx
- cmgt. */
- return 555;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0011100x1xxxxx111111xxxxxxxxxx
+ frecps. */
+ return 297;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1011100x1xxxxx111111xxxxxxxxxx
+ fdiv. */
+ return 348;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- x1011110xx1xxxxx1x1101xxxxxxxxxx
- sqdmulh. */
- return 546;
+ xxx011101x1xxxxx111111xxxxxxxxxx
+ frsqrts. */
+ return 309;
}
}
}
}
}
- else
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 10) & 0x1) == 0)
+ {
+ if (((word >> 11) & 0x1) == 0)
+ {
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 12) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxxx00001xxxxxxxxxx
- sub. */
- return 580;
+ if (((word >> 17) & 0x1) == 0)
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ if (((word >> 19) & 0x1) == 0)
+ {
+ if (((word >> 20) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx100000x00000xxxxxxxxxx
+ fcvtns. */
+ return 756;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx110000x00000xxxxxxxxxx
+ fcvtms. */
+ return 776;
+ }
+ }
+ else
+ {
+ if (((word >> 20) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx101000x00000xxxxxxxxxx
+ fcvtps. */
+ return 772;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx111000x00000xxxxxxxxxx
+ fcvtzs. */
+ return 780;
+ }
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx100x00000xxxxxxxxxx
+ fcvtas. */
+ return 764;
+ }
+ }
+ else
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx010x00000xxxxxxxxxx
+ scvtf. */
+ return 760;
+ }
+ else
+ {
+ if (((word >> 19) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1x0110x00000xxxxxxxxxx
+ fmov. */
+ return 768;
+ }
+ else
+ {
+ if (((word >> 20) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx101110x00000xxxxxxxxxx
+ fmov. */
+ return 784;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx111110x00000xxxxxxxxxx
+ fjcvtzs. */
+ return 786;
+ }
+ }
+ }
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx111110xx1xxxxxx10001xxxxxxxxxx
- ushl. */
- return 578;
+ if (((word >> 17) & 0x1) == 0)
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ if (((word >> 19) & 0x1) == 0)
+ {
+ if (((word >> 20) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx100001x00000xxxxxxxxxx
+ fcvtnu. */
+ return 758;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx110001x00000xxxxxxxxxx
+ fcvtmu. */
+ return 778;
+ }
+ }
+ else
+ {
+ if (((word >> 20) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx101001x00000xxxxxxxxxx
+ fcvtpu. */
+ return 774;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx111001x00000xxxxxxxxxx
+ fcvtzu. */
+ return 782;
+ }
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx101x00000xxxxxxxxxx
+ fcvtau. */
+ return 766;
+ }
+ }
+ else
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx011x00000xxxxxxxxxx
+ ucvtf. */
+ return 762;
+ }
+ else
+ {
+ if (((word >> 19) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1x0111x00000xxxxxxxxxx
+ fmov. */
+ return 770;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1x1111x00000xxxxxxxxxx
+ fmov. */
+ return 785;
+ }
+ }
+ }
}
}
else
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 17) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111100x1xxxxxxx1001xxxxxxxxxx
- fcmge. */
- return 566;
+ if (((word >> 15) & 0x1) == 0)
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx000010000xxxxxxxxxx
+ fmov. */
+ return 799;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx100010000xxxxxxxxxx
+ frintn. */
+ return 808;
+ }
+ }
+ else
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx001010000xxxxxxxxxx
+ fneg. */
+ return 803;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx101010000xxxxxxxxxx
+ frintm. */
+ return 812;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx000110000xxxxxxxxxx
+ fabs. */
+ return 801;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx100110000xxxxxxxxxx
+ frintp. */
+ return 810;
+ }
+ }
+ else
+ {
+ if (((word >> 18) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx001110000xxxxxxxxxx
+ fsqrt. */
+ return 805;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx101110000xxxxxxxxxx
+ frintz. */
+ return 814;
+ }
+ }
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1111101x1xxxxxxx1001xxxxxxxxxx
- fcmgt. */
- return 572;
+ if (((word >> 18) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx01xx10000xxxxxxxxxx
+ fcvt. */
+ return 807;
+ }
+ else
+ {
+ if (((word >> 15) & 0x1) == 0)
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx110010000xxxxxxxxxx
+ frinta. */
+ return 816;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx111010000xxxxxxxxxx
+ frintx. */
+ return 818;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xx11x110000xxxxxxxxxx
+ frinti. */
+ return 820;
+ }
+ }
}
}
}
else
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 3) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 4) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx111110xx1xxxxx0x0101xxxxxxxxxx
- urshl. */
- return 579;
+ xxx11110xx1xxxxxxx1000xxxxx00xxx
+ fcmp. */
+ return 791;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx111110xx1xxxxx1x0101xxxxxxxxxx
- fabd. */
- return 570;
+ xxx11110xx1xxxxxxx1000xxxxx10xxx
+ fcmpe. */
+ return 793;
}
}
else
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 4) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx111110xx1xxxxx0x1101xxxxxxxxxx
- cmhi. */
- return 576;
+ xxx11110xx1xxxxxxx1000xxxxx01xxx
+ fcmp. */
+ return 795;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx111110xx1xxxxx1x1101xxxxxxxxxx
- sqrdmulh. */
- return 565;
+ xxx11110xx1xxxxxxx1000xxxxx11xxx
+ fcmpe. */
+ return 797;
+ }
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0x11110xx1xxxxxxxx100xxxxxxxxxx
+ fmov. */
+ return 848;
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1x11110xx1xxxxxx00100xxxxxxxxxx
+ sqdmlal. */
+ return 416;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1x11110xx1xxxxxx10100xxxxxxxxxx
+ sqdmull. */
+ return 418;
}
}
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1x11110xx1xxxxxxx1100xxxxxxxxxx
+ sqdmlsl. */
+ return 417;
+ }
}
}
}
- }
- else
- {
- if (((word >> 28) & 0x1) == 0)
+ else
{
if (((word >> 12) & 0x1) == 0)
{
@@ -16851,40 +16686,51 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 15) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx1xxxxx000011xxxxxxxxxx
- sqadd. */
- return 263;
+ x0x11110xx1xxxxx000010xxxxxxxxxx
+ fmul. */
+ return 822;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx000011xxxxxxxxxx
- uqadd. */
- return 315;
+ x1x11110xx1xxxxx000010xxxxxxxxxx
+ sha1h. */
+ return 669;
}
}
else
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx100011xxxxxxxxxx
- cmtst. */
- return 278;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0011110xx1xxxxx100010xxxxxxxxxx
+ fnmul. */
+ return 838;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1011110xx1xxxxx100010xxxxxxxxxx
+ cmgt. */
+ return 476;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx100011xxxxxxxxxx
- cmeq. */
- return 330;
+ xx111110xx1xxxxx100010xxxxxxxxxx
+ cmge. */
+ return 505;
}
}
}
@@ -16894,38 +16740,159 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx010011xxxxxxxxxx
- sqshl. */
- return 270;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0011110xx1xxxxx010010xxxxxxxxxx
+ fmax. */
+ return 830;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1011110xx1xxxxx010010xxxxxxxxxx
+ sqxtn. */
+ return 480;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx010011xxxxxxxxxx
- uqshl. */
- return 322;
+ xx111110xx1xxxxx010010xxxxxxxxxx
+ uqxtn. */
+ return 509;
}
}
else
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx011100x1xxxxx110011xxxxxxxxxx
- fmla. */
- return 287;
+ if (((word >> 19) & 0x1) == 0)
+ {
+ if (((word >> 20) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx100xx0110010xxxxxxxxxx
+ fcmgt. */
+ return 489;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx100xx0110010xxxxxxxxxx
+ fcmge. */
+ return 519;
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x110xx0110010xxxxxxxxxx
+ fmaxnmp. */
+ return 533;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x110xx0110010xxxxxxxxxx
+ fmaxnmp. */
+ return 532;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x110xx0110010xxxxxxxxxx
+ fminnmp. */
+ return 539;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x110xx0110010xxxxxxxxxx
+ fminnmp. */
+ return 538;
+ }
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx1x1xx0110010xxxxxxxxxx
+ fcmgt. */
+ return 490;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1x1xx0110010xxxxxxxxxx
+ fcmge. */
+ return 520;
+ }
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx011101x1xxxxx110011xxxxxxxxxx
- fmls. */
- return 303;
+ if (((word >> 19) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx1x0xx1110010xxxxxxxxxx
+ fcvtas. */
+ return 485;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1x0xx1110010xxxxxxxxxx
+ fcvtau. */
+ return 515;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx1x1xx1110010xxxxxxxxxx
+ fcvtas. */
+ return 486;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1x1xx1110010xxxxxxxxxx
+ fcvtau. */
+ return 516;
+ }
+ }
}
}
}
@@ -16938,38 +16905,126 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx001011xxxxxxxxxx
- sqsub. */
- return 266;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0011110xx1xxxxx001010xxxxxxxxxx
+ fadd. */
+ return 826;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1011110xx1xxxxx001010xxxxxxxxxx
+ sha256su0. */
+ return 671;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx001011xxxxxxxxxx
- uqsub. */
- return 318;
+ xx111110xx1xxxxx001010xxxxxxxxxx
+ sqxtun. */
+ return 508;
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx1xxxxx101011xxxxxxxxxx
- sminp. */
- return 282;
+ xxx11110xx1xxxx0101010xxxxxxxxxx
+ cmlt. */
+ return 478;
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx101011xxxxxxxxxx
- uminp. */
- return 334;
+ if (((word >> 19) & 0x1) == 0)
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x1x0xx1101010xxxxxxxxxx
+ fcvtns. */
+ return 481;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x1x0xx1101010xxxxxxxxxx
+ fcvtnu. */
+ return 511;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x1x0xx1101010xxxxxxxxxx
+ fcvtps. */
+ return 495;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x1x0xx1101010xxxxxxxxxx
+ fcvtpu. */
+ return 523;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x1x1xx1101010xxxxxxxxxx
+ fcvtns. */
+ return 482;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x1x1xx1101010xxxxxxxxxx
+ fcvtnu. */
+ return 512;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x1x1xx1101010xxxxxxxxxx
+ fcvtps. */
+ return 496;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x1x1xx1101010xxxxxxxxxx
+ fcvtpu. */
+ return 524;
+ }
+ }
+ }
}
}
}
@@ -16981,36 +17036,36 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx1xxxxx011011xxxxxxxxxx
- smin. */
- return 274;
+ xx011110xx1xxxxx011010xxxxxxxxxx
+ fmaxnm. */
+ return 834;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx011011xxxxxxxxxx
- umin. */
- return 326;
+ xx111110xx1xxxxx011010xxxxxxxxxx
+ fcvtxn. */
+ return 510;
}
}
else
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx011100x1xxxxx111011xxxxxxxxxx
- facge. */
- return 344;
+ xxx11110xx1x0xxx111010xxxxxxxxxx
+ fcmlt. */
+ return 493;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx011101x1xxxxx111011xxxxxxxxxx
- facgt. */
- return 358;
+ xxx11110xx1x1xxx111010xxxxxxxxxx
+ fcmlt. */
+ return 494;
}
}
}
@@ -17024,25 +17079,96 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 15) & 0x1) == 0)
{
- if (((word >> 22) & 0x1) == 0)
+ if (((word >> 30) & 0x1) == 0)
{
- if (((word >> 23) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0x11110xx1xxxxx000110xxxxxxxxxx
+ fdiv. */
+ return 824;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1x11110xx1xxxxx000110xxxxxxxxxx
+ sha1su1. */
+ return 670;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx1xxxxx100110xxxxxxxxxx
+ cmeq. */
+ return 477;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxxx100110xxxxxxxxxx
+ cmle. */
+ return 506;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 15) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1xxxxx010110xxxxxxxxxx
+ fmin. */
+ return 832;
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 20) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110001xxxxx000111xxxxxxxxxx
- and. */
- return 299;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx100xx0110110xxxxxxxxxx
+ fcmeq. */
+ return 491;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx100xx0110110xxxxxxxxxx
+ fcmle. */
+ return 521;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110001xxxxx000111xxxxxxxxxx
- eor. */
- return 350;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx110xx0110110xxxxxxxxxx
+ faddp. */
+ return 535;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx110xx0110110xxxxxxxxxx
+ faddp. */
+ return 534;
+ }
}
}
else
@@ -17051,79 +17177,258 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110101xxxxx000111xxxxxxxxxx
- orr. */
- return 311;
+ xx011110xx1x1xx0110110xxxxxxxxxx
+ fcmeq. */
+ return 492;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110101xxxxx000111xxxxxxxxxx
- bit. */
- return 362;
+ xx111110xx1x1xx0110110xxxxxxxxxx
+ fcmle. */
+ return 522;
}
}
}
else
{
- if (((word >> 23) & 0x1) == 0)
+ if (((word >> 19) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110011xxxxx000111xxxxxxxxxx
- bic. */
- return 300;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x1x0xx1110110xxxxxxxxxx
+ scvtf. */
+ return 487;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x1x0xx1110110xxxxxxxxxx
+ ucvtf. */
+ return 517;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110011xxxxx000111xxxxxxxxxx
- bsl. */
- return 351;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x1x0xx1110110xxxxxxxxxx
+ frecpe. */
+ return 499;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x1x0xx1110110xxxxxxxxxx
+ frsqrte. */
+ return 527;
+ }
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 23) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110111xxxxx000111xxxxxxxxxx
- orn. */
- return 313;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x1x1xx1110110xxxxxxxxxx
+ scvtf. */
+ return 488;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x1x1xx1110110xxxxxxxxxx
+ ucvtf. */
+ return 518;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110111xxxxx000111xxxxxxxxxx
- bif. */
- return 363;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x1x1xx1110110xxxxxxxxxx
+ frecpe. */
+ return 500;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x1x1xx1110110xxxxxxxxxx
+ frsqrte. */
+ return 528;
+ }
}
}
}
}
- else
+ }
+ }
+ else
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 15) & 0x1) == 0)
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx100111xxxxxxxxxx
- mul. */
- return 280;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0011110xx1xxxxx001110xxxxxxxxxx
+ fsub. */
+ return 828;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1011110xx1xxxxx001110xxxxxxxxxx
+ suqadd. */
+ return 474;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx100111xxxxxxxxxx
- pmul. */
- return 332;
+ xx111110xx1xxxxx001110xxxxxxxxxx
+ usqadd. */
+ return 503;
+ }
+ }
+ else
+ {
+ if (((word >> 16) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx011110xx1xxxx0101110xxxxxxxxxx
+ abs. */
+ return 479;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxx0101110xxxxxxxxxx
+ neg. */
+ return 507;
+ }
+ }
+ else
+ {
+ if (((word >> 19) & 0x1) == 0)
+ {
+ if (((word >> 20) & 0x1) == 0)
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x100xx1101110xxxxxxxxxx
+ fcvtms. */
+ return 483;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x100xx1101110xxxxxxxxxx
+ fcvtmu. */
+ return 513;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x100xx1101110xxxxxxxxxx
+ fcvtzs. */
+ return 497;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x100xx1101110xxxxxxxxxx
+ fcvtzu. */
+ return 525;
+ }
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx110xx1101110xxxxxxxxxx
+ addp. */
+ return 531;
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x1x1xx1101110xxxxxxxxxx
+ fcvtms. */
+ return 484;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x1x1xx1101110xxxxxxxxxx
+ fcvtmu. */
+ return 514;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x1x1xx1101110xxxxxxxxxx
+ fcvtzs. */
+ return 498;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x1x1xx1101110xxxxxxxxxx
+ fcvtzu. */
+ return 526;
+ }
+ }
+ }
}
}
}
@@ -17133,124 +17438,270 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 29) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx010111xxxxxxxxxx
- sqrshl. */
- return 272;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0011110xx1xxxxx011110xxxxxxxxxx
+ fminnm. */
+ return 836;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1011110xx1xxxxx011110xxxxxxxxxx
+ sqabs. */
+ return 475;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx010111xxxxxxxxxx
- uqrshl. */
- return 324;
+ xx111110xx1xxxxx011110xxxxxxxxxx
+ sqneg. */
+ return 504;
}
}
else
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 16) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx001110xx1xxxxx110111xxxxxxxxxx
- fmulx. */
- return 291;
+ if (((word >> 23) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111100x1xxxx0111110xxxxxxxxxx
+ fmaxp. */
+ return 537;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x1xxxx0111110xxxxxxxxxx
+ fmaxp. */
+ return 536;
+ }
+ }
+ else
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx0111101x1xxxx0111110xxxxxxxxxx
+ fminp. */
+ return 541;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x1xxxx0111110xxxxxxxxxx
+ fminp. */
+ return 540;
+ }
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx101110xx1xxxxx110111xxxxxxxxxx
- fmul. */
- return 340;
+ if (((word >> 19) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1x0xx1111110xxxxxxxxxx
+ frecpx. */
+ return 501;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxx11110xx1x1xx1111110xxxxxxxxxx
+ frecpx. */
+ return 502;
+ }
}
}
}
}
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 11) & 0x1) == 0)
+ {
+ if (((word >> 29) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ if (((word >> 4) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0011110xx1xxxxxxxxx01xxxxx0xxxx
+ fccmp. */
+ return 787;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0011110xx1xxxxxxxxx01xxxxx1xxxx
+ fccmpe. */
+ return 789;
+ }
+ }
else
{
- if (((word >> 14) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx1xxxxx001111xxxxxxxxxx
- cmge. */
- return 268;
+ x1011110xx1xxxxxx00001xxxxxxxxxx
+ add. */
+ return 559;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx001111xxxxxxxxxx
- cmhs. */
- return 320;
+ x1011110xx1xxxxxx10001xxxxxxxxxx
+ sshl. */
+ return 557;
}
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxx01110xx1xxxxx101111xxxxxxxxxx
- addp. */
- return 284;
+ x1011110xx1xxxxxxx1001xxxxxxxxxx
+ fcmeq. */
+ return 549;
}
}
else
{
- if (((word >> 15) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 29) & 0x1) == 0)
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1011110xx1xxxxxxx0101xxxxxxxxxx
+ srshl. */
+ return 558;
+ }
+ else
+ {
+ if (((word >> 15) & 0x1) == 0)
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx001110xx1xxxxx011111xxxxxxxxxx
- saba. */
- return 276;
+ x1011110xx1xxxxx0x1101xxxxxxxxxx
+ cmgt. */
+ return 555;
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xx101110xx1xxxxx011111xxxxxxxxxx
- uaba. */
- return 328;
+ x1011110xx1xxxxx1x1101xxxxxxxxxx
+ sqdmulh. */
+ return 546;
}
}
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 12) & 0x1) == 0)
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxxxx00001xxxxxxxxxx
+ sub. */
+ return 580;
+ }
else
{
- if (((word >> 23) & 0x1) == 0)
- {
- if (((word >> 29) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx0011100x1xxxxx111111xxxxxxxxxx
- frecps. */
- return 297;
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xx1011100x1xxxxx111111xxxxxxxxxx
- fdiv. */
- return 348;
- }
- }
- else
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx011101x1xxxxx111111xxxxxxxxxx
- frsqrts. */
- return 309;
- }
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxxxx10001xxxxxxxxxx
+ ushl. */
+ return 578;
+ }
+ }
+ else
+ {
+ if (((word >> 23) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111100x1xxxxxxx1001xxxxxxxxxx
+ fcmge. */
+ return 566;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx1111101x1xxxxxxx1001xxxxxxxxxx
+ fcmgt. */
+ return 572;
+ }
+ }
+ }
+ else
+ {
+ if (((word >> 13) & 0x1) == 0)
+ {
+ if (((word >> 15) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxxx0x0101xxxxxxxxxx
+ urshl. */
+ return 579;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxxx1x0101xxxxxxxxxx
+ fabd. */
+ return 570;
+ }
+ }
+ else
+ {
+ if (((word >> 15) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxxx0x1101xxxxxxxxxx
+ cmhi. */
+ return 576;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx111110xx1xxxxx1x1101xxxxxxxxxx
+ sqrdmulh. */
+ return 565;
}
}
}
@@ -17469,19 +17920,63 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 14) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01111xxxxxxxx0000x0xxxxxxxxxx
- mla. */
- return 117;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0001111xxxxxxxx0000x0xxxxxxxxxx
+ fmlal. */
+ return 2015;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1001111xxxxxxxx0000x0xxxxxxxxxx
+ fmlal. */
+ return 2019;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101111xxxxxxxx0000x0xxxxxxxxxx
+ mla. */
+ return 117;
+ }
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01111xxxxxxxx0100x0xxxxxxxxxx
- mls. */
- return 120;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0001111xxxxxxxx0100x0xxxxxxxxxx
+ fmlsl. */
+ return 2016;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1001111xxxxxxxx0100x0xxxxxxxxxx
+ fmlsl. */
+ return 2020;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx101111xxxxxxxx0100x0xxxxxxxxxx
+ mls. */
+ return 120;
+ }
}
}
else
@@ -17961,11 +18456,33 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01111xxxxxxxx1000x0xxxxxxxxxx
- mul. */
- return 104;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx001111xxxxxxxx1000x0xxxxxxxxxx
+ mul. */
+ return 104;
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101111xxxxxxxx1000x0xxxxxxxxxx
+ fmlal2. */
+ return 2017;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101111xxxxxxxx1000x0xxxxxxxxxx
+ fmlal2. */
+ return 2021;
+ }
+ }
}
else
{
@@ -18211,11 +18728,33 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 12) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxx01111xxxxxxxx1100x0xxxxxxxxxx
- sqdmulh. */
- return 109;
+ if (((word >> 29) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xx001111xxxxxxxx1100x0xxxxxxxxxx
+ sqdmulh. */
+ return 109;
+ }
+ else
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x0101111xxxxxxxx1100x0xxxxxxxxxx
+ fmlsl2. */
+ return 2018;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ x1101111xxxxxxxx1100x0xxxxxxxxxx
+ fmlsl2. */
+ return 2022;
+ }
+ }
}
else
{
@@ -18598,7 +19137,8 @@ aarch64_find_next_opcode (const aarch64_opcode *opcode)
case 1174: value = 1175; break; /* dmb --> isb. */
case 1175: value = 1176; break; /* isb --> sys. */
case 1176: value = 1181; break; /* sys --> msr. */
- case 1181: return NULL; /* msr --> NULL. */
+ case 1181: value = 2023; break; /* msr --> cfinv. */
+ case 2023: return NULL; /* cfinv --> NULL. */
case 1182: value = 1183; break; /* sysl --> mrs. */
case 1183: return NULL; /* mrs --> NULL. */
case 434: value = 435; break; /* st4 --> st1. */