aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYufeng Zhang <yufeng.zhang@arm.com>2013-02-28 19:18:40 +0000
committerYufeng Zhang <yufeng.zhang@arm.com>2013-02-28 19:18:40 +0000
commite60bb1dd35da645e3449fda680291abc26e1cc60 (patch)
tree7fa30bf1469e3cf6f1ed3b1cf81edf259c58312c
parent86a3263fffd5fcd0c7896647dea4dca2b5902da5 (diff)
downloadgdb-e60bb1dd35da645e3449fda680291abc26e1cc60.zip
gdb-e60bb1dd35da645e3449fda680291abc26e1cc60.tar.gz
gdb-e60bb1dd35da645e3449fda680291abc26e1cc60.tar.bz2
include/opcode/
* aarch64.h (AARCH64_FEATURE_CRC): New macro. opcodes/ * aarch64-tbl.h (QL_I3SAMEW, QL_I3WWX): New macros. (aarch64_feature_crc): New static. (CRC): New macro. (aarch64_opcode_table): Add entries for the crc32b, crc32h, crc32w, crc32x, crc32cb, crc32ch, crc32cw and crc32cx instructions. * aarch64-asm-2.c: Re-generate. * aarch64-dis-2.c: Ditto. * aarch64-opc-2.c: Ditto. gas/ * config/tc-aarch64.c (aarch64_features): Add the 'crc' option. gas/testsuite/ * gas/aarch64/crc32.s: New test. * gas/aarch64/crc32.d: Ditto.
-rw-r--r--gas/ChangeLog4
-rw-r--r--gas/config/tc-aarch64.c1
-rw-r--r--gas/testsuite/ChangeLog5
-rw-r--r--gas/testsuite/gas/aarch64/crc32.d16
-rw-r--r--gas/testsuite/gas/aarch64/crc32.s31
-rw-r--r--include/opcode/ChangeLog4
-rw-r--r--include/opcode/aarch64.h1
-rw-r--r--opcodes/ChangeLog11
-rw-r--r--opcodes/aarch64-asm-2.c134
-rw-r--r--opcodes/aarch64-dis-2.c668
-rw-r--r--opcodes/aarch64-opc-2.c66
-rw-r--r--opcodes/aarch64-tbl.h24
12 files changed, 575 insertions, 390 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 3e2f60f..fe6741d 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,5 +1,9 @@
2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
+ * config/tc-aarch64.c (aarch64_features): Add the 'crc' option.
+
+2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
+
* config/tc-aarch64.c (parse_sys_reg): Allow the full range of CRn
for system registers.
diff --git a/gas/config/tc-aarch64.c b/gas/config/tc-aarch64.c
index 47c27fe..c10c723 100644
--- a/gas/config/tc-aarch64.c
+++ b/gas/config/tc-aarch64.c
@@ -6991,6 +6991,7 @@ struct aarch64_option_cpu_value_table
};
static const struct aarch64_option_cpu_value_table aarch64_features[] = {
+ {"crc", AARCH64_FEATURE (AARCH64_FEATURE_CRC, 0)},
{"crypto", AARCH64_FEATURE (AARCH64_FEATURE_CRYPTO, 0)},
{"fp", AARCH64_FEATURE (AARCH64_FEATURE_FP, 0)},
{"simd", AARCH64_FEATURE (AARCH64_FEATURE_SIMD, 0)},
diff --git a/gas/testsuite/ChangeLog b/gas/testsuite/ChangeLog
index 2cf4142..cb39336 100644
--- a/gas/testsuite/ChangeLog
+++ b/gas/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
+ * gas/aarch64/crc32.s: New test.
+ * gas/aarch64/crc32.d: Ditto.
+
+2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
+
* gas/aarch64/illegal.l: Delete the error message for
msr S3_1_C13_C15_1,x7.
* gas/aarch64/sysreg.s: Add new tests.
diff --git a/gas/testsuite/gas/aarch64/crc32.d b/gas/testsuite/gas/aarch64/crc32.d
new file mode 100644
index 0000000..bba83b2
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/crc32.d
@@ -0,0 +1,16 @@
+#objdump: -dr
+#as: -march=armv8-a+crc
+
+.*: file format .*
+
+Disassembly of section \.text:
+
+0000000000000000 <.*>:
+ 0: 1acf40e3 crc32b w3, w7, w15
+ 4: 1ac345e7 crc32h w7, w15, w3
+ 8: 1ac7486f crc32w w15, w3, w7
+ c: 9acf4ce3 crc32x w3, w7, x15
+ 10: 1acf50e3 crc32cb w3, w7, w15
+ 14: 1ac355e7 crc32ch w7, w15, w3
+ 18: 1ac7586f crc32cw w15, w3, w7
+ 1c: 9acf5ce3 crc32cx w3, w7, x15
diff --git a/gas/testsuite/gas/aarch64/crc32.s b/gas/testsuite/gas/aarch64/crc32.s
new file mode 100644
index 0000000..34d9d92
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/crc32.s
@@ -0,0 +1,31 @@
+/* crc32.s Test file for AArch64 CRC-32 and CRC-32C checksum instructions.
+
+ Copyright 2013 Free Software Foundation, Inc.
+ Contributed by ARM Ltd.
+
+ This file is part of GAS.
+
+ GAS is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 3 of the license, or
+ (at your option) any later version.
+
+ GAS is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; see the file COPYING3. If not,
+ see <http://www.gnu.org/licenses/>. */
+
+
+ .text
+ crc32b w3, w7, w15
+ crc32h w7, w15, w3
+ crc32w w15, w3, w7
+ crc32x w3, w7, x15
+ crc32cb w3, w7, w15
+ crc32ch w7, w15, w3
+ crc32cw w15, w3, w7
+ crc32cx w3, w7, x15
diff --git a/include/opcode/ChangeLog b/include/opcode/ChangeLog
index cef6986..fc2b40e 100644
--- a/include/opcode/ChangeLog
+++ b/include/opcode/ChangeLog
@@ -1,3 +1,7 @@
+2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
+
+ * aarch64.h (AARCH64_FEATURE_CRC): New macro.
+
2013-02-06 Sandra Loosemore <sandra@codesourcery.com>
Andrew Jenner <andrew@codesourcery.com>
diff --git a/include/opcode/aarch64.h b/include/opcode/aarch64.h
index 941e678..eaf3cda 100644
--- a/include/opcode/aarch64.h
+++ b/include/opcode/aarch64.h
@@ -37,6 +37,7 @@ typedef uint32_t aarch64_insn;
#define AARCH64_FEATURE_CRYPTO 0x00010000 /* Crypto instructions. */
#define AARCH64_FEATURE_FP 0x00020000 /* FP instructions. */
#define AARCH64_FEATURE_SIMD 0x00040000 /* SIMD instructions. */
+#define AARCH64_FEATURE_CRC 0x00080000 /* CRC instructions. */
/* Architectures are the sum of the base and extensions. */
#define AARCH64_ARCH_V8 AARCH64_FEATURE (AARCH64_FEATURE_V8, \
diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog
index 7208b28..374bf40 100644
--- a/opcodes/ChangeLog
+++ b/opcodes/ChangeLog
@@ -1,3 +1,14 @@
+2013-02-28 Yufeng Zhang <yufeng.zhang@arm.com>
+
+ * aarch64-tbl.h (QL_I3SAMEW, QL_I3WWX): New macros.
+ (aarch64_feature_crc): New static.
+ (CRC): New macro.
+ (aarch64_opcode_table): Add entries for the crc32b, crc32h, crc32w,
+ crc32x, crc32cb, crc32ch, crc32cw and crc32cx instructions.
+ * aarch64-asm-2.c: Re-generate.
+ * aarch64-dis-2.c: Ditto.
+ * aarch64-opc-2.c: Ditto.
+
2013-02-27 Alan Modra <amodra@gmail.com>
* rl78-decode.opc (rl78_decode_opcode): Fix typo.
diff --git a/opcodes/aarch64-asm-2.c b/opcodes/aarch64-asm-2.c
index d3280aa..9ad9e1e 100644
--- a/opcodes/aarch64-asm-2.c
+++ b/opcodes/aarch64-asm-2.c
@@ -134,101 +134,101 @@ aarch64_find_real_opcode (const aarch64_opcode *opcode)
case 563: /* ror */
value = 562; /* --> rorv. */
break;
- case 565: /* mul */
- value = 564; /* --> madd. */
+ case 573: /* mul */
+ value = 572; /* --> madd. */
break;
- case 567: /* mneg */
- value = 566; /* --> msub. */
+ case 575: /* mneg */
+ value = 574; /* --> msub. */
break;
- case 569: /* smull */
- value = 568; /* --> smaddl. */
+ case 577: /* smull */
+ value = 576; /* --> smaddl. */
break;
- case 571: /* smnegl */
- value = 570; /* --> smsubl. */
+ case 579: /* smnegl */
+ value = 578; /* --> smsubl. */
break;
- case 574: /* umull */
- value = 573; /* --> umaddl. */
+ case 582: /* umull */
+ value = 581; /* --> umaddl. */
break;
- case 576: /* umnegl */
- value = 575; /* --> umsubl. */
+ case 584: /* umnegl */
+ value = 583; /* --> umsubl. */
break;
- case 587: /* ror */
- value = 586; /* --> extr. */
+ case 595: /* ror */
+ value = 594; /* --> extr. */
break;
- case 687: /* strb */
- value = 685; /* --> sturb. */
+ case 695: /* strb */
+ value = 693; /* --> sturb. */
break;
- case 688: /* ldrb */
- value = 686; /* --> ldurb. */
+ case 696: /* ldrb */
+ value = 694; /* --> ldurb. */
break;
- case 690: /* ldrsb */
- value = 689; /* --> ldursb. */
+ case 698: /* ldrsb */
+ value = 697; /* --> ldursb. */
break;
- case 693: /* str */
- value = 691; /* --> stur. */
+ case 701: /* str */
+ value = 699; /* --> stur. */
break;
- case 694: /* ldr */
- value = 692; /* --> ldur. */
+ case 702: /* ldr */
+ value = 700; /* --> ldur. */
break;
- case 697: /* strh */
- value = 695; /* --> sturh. */
+ case 705: /* strh */
+ value = 703; /* --> sturh. */
break;
- case 698: /* ldrh */
- value = 696; /* --> ldurh. */
+ case 706: /* ldrh */
+ value = 704; /* --> ldurh. */
break;
- case 700: /* ldrsh */
- value = 699; /* --> ldursh. */
+ case 708: /* ldrsh */
+ value = 707; /* --> ldursh. */
break;
- case 703: /* str */
- value = 701; /* --> stur. */
+ case 711: /* str */
+ value = 709; /* --> stur. */
break;
- case 704: /* ldr */
- value = 702; /* --> ldur. */
+ case 712: /* ldr */
+ value = 710; /* --> ldur. */
break;
- case 706: /* ldrsw */
- value = 705; /* --> ldursw. */
+ case 714: /* ldrsw */
+ value = 713; /* --> ldursw. */
break;
- case 708: /* prfm */
- value = 707; /* --> prfum. */
+ case 716: /* prfm */
+ value = 715; /* --> prfum. */
break;
- case 750: /* bic */
- value = 749; /* --> and. */
+ case 758: /* bic */
+ value = 757; /* --> and. */
break;
- case 752: /* mov */
- value = 751; /* --> orr. */
+ case 760: /* mov */
+ value = 759; /* --> orr. */
break;
- case 755: /* tst */
- value = 754; /* --> ands. */
+ case 763: /* tst */
+ value = 762; /* --> ands. */
break;
- case 760: /* uxtw */
- case 759: /* mov */
- value = 758; /* --> orr. */
+ case 768: /* uxtw */
+ case 767: /* mov */
+ value = 766; /* --> orr. */
break;
- case 762: /* mvn */
- value = 761; /* --> orn. */
+ case 770: /* mvn */
+ value = 769; /* --> orn. */
break;
- case 766: /* tst */
- value = 765; /* --> ands. */
+ case 774: /* tst */
+ value = 773; /* --> ands. */
break;
- case 769: /* mov */
- value = 768; /* --> movn. */
+ case 777: /* mov */
+ value = 776; /* --> movn. */
break;
- case 771: /* mov */
- value = 770; /* --> movz. */
+ case 779: /* mov */
+ value = 778; /* --> movz. */
break;
- case 782: /* sevl */
- case 781: /* sev */
- case 780: /* wfi */
- case 779: /* wfe */
- case 778: /* yield */
- case 777: /* nop */
- value = 776; /* --> hint. */
+ case 790: /* sevl */
+ case 789: /* sev */
+ case 788: /* wfi */
+ case 787: /* wfe */
+ case 786: /* yield */
+ case 785: /* nop */
+ value = 784; /* --> hint. */
break;
- case 791: /* tlbi */
- case 790: /* ic */
- case 789: /* dc */
- case 788: /* at */
- value = 787; /* --> sys. */
+ case 799: /* tlbi */
+ case 798: /* ic */
+ case 797: /* dc */
+ case 796: /* at */
+ value = 795; /* --> sys. */
break;
default: return NULL;
}
diff --git a/opcodes/aarch64-dis-2.c b/opcodes/aarch64-dis-2.c
index 410bc3d..0d633eb 100644
--- a/opcodes/aarch64-dis-2.c
+++ b/opcodes/aarch64-dis-2.c
@@ -40,7 +40,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx0000xxx0
adr. */
- return 773;
+ return 781;
}
else
{
@@ -48,7 +48,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx0000xxx1
adrp. */
- return 774;
+ return 782;
}
}
else
@@ -115,7 +115,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx000x0010000
stxrb. */
- return 709;
+ return 717;
}
else
{
@@ -123,7 +123,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx000x0010010
stxrh. */
- return 715;
+ return 723;
}
}
else
@@ -132,7 +132,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx000x00100x1
stxr. */
- return 721;
+ return 729;
}
}
else
@@ -141,7 +141,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx100x00100xx
stxp. */
- return 723;
+ return 731;
}
}
else
@@ -156,7 +156,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx000x0010000
stlxrb. */
- return 710;
+ return 718;
}
else
{
@@ -164,7 +164,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx000x0010010
stlxrh. */
- return 716;
+ return 724;
}
}
else
@@ -173,7 +173,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx000x00100x1
stlxr. */
- return 722;
+ return 730;
}
}
else
@@ -182,7 +182,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx100x00100xx
stlxp. */
- return 724;
+ return 732;
}
}
}
@@ -192,7 +192,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx00x00101xx
stnp. */
- return 731;
+ return 739;
}
}
else
@@ -207,7 +207,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx01x0010000
stlrb. */
- return 713;
+ return 721;
}
else
{
@@ -215,7 +215,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx01x0010010
stlrh. */
- return 719;
+ return 727;
}
}
else
@@ -224,7 +224,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx01x00100x1
stlr. */
- return 729;
+ return 737;
}
}
else
@@ -233,7 +233,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx01x00101xx
stp. */
- return 740;
+ return 748;
}
}
}
@@ -255,7 +255,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx010x0010000
ldxrb. */
- return 711;
+ return 719;
}
else
{
@@ -263,7 +263,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx010x0010010
ldxrh. */
- return 717;
+ return 725;
}
}
else
@@ -272,7 +272,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx010x00100x1
ldxr. */
- return 725;
+ return 733;
}
}
else
@@ -281,7 +281,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx110x00100xx
ldxp. */
- return 727;
+ return 735;
}
}
else
@@ -296,7 +296,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx010x0010000
ldaxrb. */
- return 712;
+ return 720;
}
else
{
@@ -304,7 +304,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx010x0010010
ldaxrh. */
- return 718;
+ return 726;
}
}
else
@@ -313,7 +313,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx010x00100x1
ldaxr. */
- return 726;
+ return 734;
}
}
else
@@ -322,7 +322,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx110x00100xx
ldaxp. */
- return 728;
+ return 736;
}
}
}
@@ -334,7 +334,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx10x001010x
ldnp. */
- return 732;
+ return 740;
}
else
{
@@ -342,7 +342,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx10x001011x
ldpsw. */
- return 739;
+ return 747;
}
}
}
@@ -358,7 +358,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx11x0010000
ldarb. */
- return 714;
+ return 722;
}
else
{
@@ -366,7 +366,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx11x0010010
ldarh. */
- return 720;
+ return 728;
}
}
else
@@ -375,7 +375,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx11x00100x1
ldar. */
- return 730;
+ return 738;
}
}
else
@@ -386,7 +386,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx11x001010x
ldp. */
- return 741;
+ return 749;
}
else
{
@@ -394,7 +394,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx11x001011x
ldpsw. */
- return 744;
+ return 752;
}
}
}
@@ -412,7 +412,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx000110x0
ldr. */
- return 745;
+ return 753;
}
else
{
@@ -422,7 +422,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx00011001
ldrsw. */
- return 747;
+ return 755;
}
else
{
@@ -430,7 +430,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx00011011
prfm. */
- return 748;
+ return 756;
}
}
}
@@ -452,7 +452,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx0000011100
sturb. */
- return 685;
+ return 693;
}
else
{
@@ -460,7 +460,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx0000011110
sturh. */
- return 695;
+ return 703;
}
}
else
@@ -469,7 +469,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx00000111x1
stur. */
- return 701;
+ return 709;
}
}
else
@@ -482,7 +482,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx1000011100
ldurb. */
- return 686;
+ return 694;
}
else
{
@@ -490,7 +490,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx1000011110
ldurh. */
- return 696;
+ return 704;
}
}
else
@@ -499,7 +499,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx10000111x1
ldur. */
- return 702;
+ return 710;
}
}
}
@@ -513,7 +513,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxxx100011100
ldursb. */
- return 689;
+ return 697;
}
else
{
@@ -521,7 +521,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxxx100011101
ldursw. */
- return 705;
+ return 713;
}
}
else
@@ -532,7 +532,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxxx100011110
ldursh. */
- return 699;
+ return 707;
}
else
{
@@ -540,7 +540,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxxx100011111
prfum. */
- return 707;
+ return 715;
}
}
}
@@ -561,7 +561,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx00000011100
sttrb. */
- return 676;
+ return 684;
}
else
{
@@ -569,7 +569,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx00000011110
sttrh. */
- return 679;
+ return 687;
}
}
else
@@ -578,7 +578,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx000000111x1
sttr. */
- return 682;
+ return 690;
}
}
else
@@ -591,7 +591,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx01000011100
ldtrb. */
- return 677;
+ return 685;
}
else
{
@@ -599,7 +599,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx01000011110
ldtrh. */
- return 680;
+ return 688;
}
}
else
@@ -608,7 +608,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx010000111x1
ldtr. */
- return 683;
+ return 691;
}
}
}
@@ -622,7 +622,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx0x100011100
ldtrsb. */
- return 678;
+ return 686;
}
else
{
@@ -630,7 +630,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx0x100011101
ldtrsw. */
- return 684;
+ return 692;
}
}
else
@@ -639,7 +639,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx0x10001111x
ldtrsh. */
- return 681;
+ return 689;
}
}
}
@@ -657,7 +657,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx10000011100
strb. */
- return 664;
+ return 672;
}
else
{
@@ -665,7 +665,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx10000011110
strh. */
- return 669;
+ return 677;
}
}
else
@@ -674,7 +674,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx100000111x1
str. */
- return 672;
+ return 680;
}
}
else
@@ -687,7 +687,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx11000011100
ldrb. */
- return 665;
+ return 673;
}
else
{
@@ -695,7 +695,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx11000011110
ldrh. */
- return 670;
+ return 678;
}
}
else
@@ -704,7 +704,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx110000111x1
ldr. */
- return 673;
+ return 681;
}
}
}
@@ -718,7 +718,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx1x100011100
ldrsb. */
- return 666;
+ return 674;
}
else
{
@@ -726,7 +726,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx1x100011101
ldrsw. */
- return 674;
+ return 682;
}
}
else
@@ -737,7 +737,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx1x100011110
ldrsh. */
- return 671;
+ return 679;
}
else
{
@@ -745,7 +745,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxx1x100011111
prfm. */
- return 675;
+ return 683;
}
}
}
@@ -766,7 +766,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx0000011100
strb. */
- return 641;
+ return 649;
}
else
{
@@ -774,7 +774,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx0000011110
strh. */
- return 646;
+ return 654;
}
}
else
@@ -783,7 +783,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx00000111x1
str. */
- return 649;
+ return 657;
}
}
else
@@ -796,7 +796,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx1000011100
ldrb. */
- return 642;
+ return 650;
}
else
{
@@ -804,7 +804,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx1000011110
ldrh. */
- return 647;
+ return 655;
}
}
else
@@ -813,7 +813,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx10000111x1
ldr. */
- return 650;
+ return 658;
}
}
}
@@ -827,7 +827,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxxx100011100
ldrsb. */
- return 643;
+ return 651;
}
else
{
@@ -835,7 +835,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxxx100011101
ldrsw. */
- return 651;
+ return 659;
}
}
else
@@ -844,7 +844,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxxx10001111x
ldrsh. */
- return 648;
+ return 656;
}
}
}
@@ -864,7 +864,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx0010011x00
strb. */
- return 652;
+ return 660;
}
else
{
@@ -872,7 +872,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx0010011x10
strh. */
- return 657;
+ return 665;
}
}
else
@@ -881,7 +881,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx0010011xx1
str. */
- return 660;
+ return 668;
}
}
else
@@ -894,7 +894,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx1010011x00
ldrb. */
- return 653;
+ return 661;
}
else
{
@@ -902,7 +902,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx1010011x10
ldrh. */
- return 658;
+ return 666;
}
}
else
@@ -911,7 +911,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx1010011xx1
ldr. */
- return 661;
+ return 669;
}
}
}
@@ -925,7 +925,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx110011x00
ldrsb. */
- return 654;
+ return 662;
}
else
{
@@ -933,7 +933,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx110011x01
ldrsw. */
- return 662;
+ return 670;
}
}
else
@@ -944,7 +944,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx110011x10
ldrsh. */
- return 659;
+ return 667;
}
else
{
@@ -952,7 +952,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx110011x11
prfm. */
- return 663;
+ return 671;
}
}
}
@@ -976,7 +976,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx00100x00x
and. */
- return 749;
+ return 757;
}
else
{
@@ -984,7 +984,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx00100x01x
eor. */
- return 753;
+ return 761;
}
}
else
@@ -995,7 +995,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx00100x10x
orr. */
- return 751;
+ return 759;
}
else
{
@@ -1003,7 +1003,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx00100x11x
ands. */
- return 754;
+ return 762;
}
}
}
@@ -1017,7 +1017,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx10100x00x
movn. */
- return 768;
+ return 776;
}
else
{
@@ -1025,7 +1025,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx10100x01x
movz. */
- return 770;
+ return 778;
}
}
else
@@ -1034,7 +1034,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx10100x1xx
movk. */
- return 772;
+ return 780;
}
}
}
@@ -1052,7 +1052,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx0xx0101000x
and. */
- return 756;
+ return 764;
}
else
{
@@ -1060,7 +1060,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx0xx0101001x
eor. */
- return 763;
+ return 771;
}
}
else
@@ -1071,7 +1071,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx0xx0101010x
orr. */
- return 758;
+ return 766;
}
else
{
@@ -1079,7 +1079,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx0xx0101011x
ands. */
- return 765;
+ return 773;
}
}
}
@@ -1179,11 +1179,22 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxxxxxxxxx0000xxxxxxx01101011xxx
- rbit. */
- return 547;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx00000xxxxxx01101011xxx
+ rbit. */
+ return 547;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx00001xxxxxx01101011xxx
+ crc32b. */
+ return 564;
+ }
}
else
{
@@ -1196,11 +1207,22 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxxxxxxxxx001xxxxxxxx01101011xxx
- clz. */
- return 551;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx001x0xxxxxx01101011xxx
+ clz. */
+ return 551;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx001x1xxxxxx01101011xxx
+ crc32cb. */
+ return 568;
+ }
}
}
}
@@ -1228,43 +1250,65 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
- {
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxxxxxxxxx01x0xxxxxxx0x101011x0x
- udiv. */
- return 554;
- }
- else
+ if (((word >> 13) & 0x1) == 0)
{
- if (((word >> 31) & 0x1) == 0)
+ if (((word >> 14) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxxxxxxxxx01x0xxxxxxx0x101011x10
- rev. */
- return 549;
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx01000xxxxxx0x101011x0x
+ udiv. */
+ return 554;
+ }
+ else
+ {
+ if (((word >> 31) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx01000xxxxxx0x101011x10
+ rev. */
+ return 549;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx01000xxxxxx0x101011x11
+ rev32. */
+ return 553;
+ }
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxxxxxxxxx01x0xxxxxxx0x101011x11
- rev32. */
- return 553;
+ xxxxxxxxxx01001xxxxxx0x101011xxx
+ crc32w. */
+ return 566;
}
}
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx0101xxxxxxx0x101011xxx
+ asrv. */
+ return 560;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxxxxxxxxx01x1xxxxxxx0x101011xxx
- asrv. */
- return 560;
+ xxxxxxxxxx011xxxxxxxx0x101011xxx
+ crc32cw. */
+ return 570;
}
}
}
@@ -1298,11 +1342,22 @@ aarch64_opcode_lookup_1 (uint32_t word)
{
if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxxxxxxxxx1000xxxxxxx01x01011xxx
- rev16. */
- return 548;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx10000xxxxxx01x01011xxx
+ rev16. */
+ return 548;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx10001xxxxxx01x01011xxx
+ crc32h. */
+ return 565;
+ }
}
else
{
@@ -1315,42 +1370,75 @@ aarch64_opcode_lookup_1 (uint32_t word)
}
else
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxxxxxxxxx101xxxxxxxx01x01011xxx
- cls. */
- return 552;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx101x0xxxxxx01x01011xxx
+ cls. */
+ return 552;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx101x1xxxxxx01x01011xxx
+ crc32ch. */
+ return 569;
+ }
}
}
}
else
{
- if (((word >> 13) & 0x1) == 0)
+ if (((word >> 12) & 0x1) == 0)
{
- if (((word >> 30) & 0x1) == 0)
+ if (((word >> 13) & 0x1) == 0)
{
- /* 33222222222211111111110000000000
- 10987654321098765432109876543210
- xxxxxxxxxx11x0xxxxxxx0xx01011x0x
- sdiv. */
- return 555;
+ if (((word >> 14) & 0x1) == 0)
+ {
+ if (((word >> 30) & 0x1) == 0)
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx11000xxxxxx0xx01011x0x
+ sdiv. */
+ return 555;
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx11000xxxxxx0xx01011x1x
+ rev. */
+ return 550;
+ }
+ }
+ else
+ {
+ /* 33222222222211111111110000000000
+ 10987654321098765432109876543210
+ xxxxxxxxxx11001xxxxxx0xx01011xxx
+ crc32x. */
+ return 567;
+ }
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxxxxxxxxx11x0xxxxxxx0xx01011x1x
- rev. */
- return 550;
+ xxxxxxxxxx1101xxxxxxx0xx01011xxx
+ rorv. */
+ return 562;
}
}
else
{
/* 33222222222211111111110000000000
10987654321098765432109876543210
- xxxxxxxxxx11x1xxxxxxx0xx01011xxx
- rorv. */
- return 562;
+ xxxxxxxxxx111xxxxxxxx0xx01011xxx
+ crc32cx. */
+ return 571;
}
}
}
@@ -1366,7 +1454,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx1xx0101x00x
bic. */
- return 757;
+ return 765;
}
else
{
@@ -1374,7 +1462,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx1xx0101x01x
eon. */
- return 764;
+ return 772;
}
}
else
@@ -1385,7 +1473,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx1xx0101x10x
orn. */
- return 761;
+ return 769;
}
else
{
@@ -1393,7 +1481,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxx1xx0101x11x
bics. */
- return 767;
+ return 775;
}
}
}
@@ -1439,7 +1527,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxx11100xxxx
extr. */
- return 586;
+ return 594;
}
}
else
@@ -1497,7 +1585,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx00x11011xxx
madd. */
- return 564;
+ return 572;
}
else
{
@@ -1507,7 +1595,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx01011011xxx
smulh. */
- return 572;
+ return 580;
}
else
{
@@ -1515,7 +1603,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx01111011xxx
umulh. */
- return 577;
+ return 585;
}
}
}
@@ -1525,7 +1613,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx0xx11011xxx
msub. */
- return 566;
+ return 574;
}
}
}
@@ -1582,7 +1670,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx1x011011xxx
smaddl. */
- return 568;
+ return 576;
}
else
{
@@ -1590,7 +1678,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx1x011011xxx
smsubl. */
- return 570;
+ return 578;
}
}
}
@@ -1602,7 +1690,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx1x11101xxxx
umaddl. */
- return 573;
+ return 581;
}
else
{
@@ -1610,7 +1698,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx1x11101xxxx
umsubl. */
- return 575;
+ return 583;
}
}
}
@@ -1669,7 +1757,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
00xxxxxxxxxxxxxxxxxxx0xx0010x011
hlt. */
- return 582;
+ return 590;
}
else
{
@@ -1677,7 +1765,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
00xxxxxxxxxxxxxxxxxxx1xx0010x011
brk. */
- return 581;
+ return 589;
}
}
else
@@ -1688,7 +1776,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
01xxxxxxxxxxxxxxxxxxx0xx0010x011
hvc. */
- return 579;
+ return 587;
}
else
{
@@ -1696,7 +1784,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
01xxxxxxxxxxxxxxxxxxx1xx0010x011
dcps2. */
- return 584;
+ return 592;
}
}
}
@@ -1710,7 +1798,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
10xxxxxxxxxxxxxxxxxxx0xx0010x011
svc. */
- return 578;
+ return 586;
}
else
{
@@ -1718,7 +1806,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
10xxxxxxxxxxxxxxxxxxx1xx0010x011
dcps1. */
- return 583;
+ return 591;
}
}
else
@@ -1729,7 +1817,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
11xxxxxxxxxxxxxxxxxxx0xx0010x011
smc. */
- return 580;
+ return 588;
}
else
{
@@ -1737,7 +1825,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
11xxxxxxxxxxxxxxxxxxx1xx0010x011
dcps3. */
- return 585;
+ return 593;
}
}
}
@@ -1810,7 +1898,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxx00xxxxx00xxx1x10x01x
msr. */
- return 775;
+ return 783;
}
else
{
@@ -1818,7 +1906,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxx01xxxxx00xxx1x10x01x
hint. */
- return 776;
+ return 784;
}
}
else
@@ -1831,7 +1919,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxx00xxxxx1xxxxxx00xxx1x10x01x
dsb. */
- return 784;
+ return 792;
}
else
{
@@ -1841,7 +1929,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxx010xxxx1xxxxxx00xxx1x10x01x
clrex. */
- return 783;
+ return 791;
}
else
{
@@ -1849,7 +1937,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxx011xxxx1xxxxxx00xxx1x10x01x
isb. */
- return 786;
+ return 794;
}
}
}
@@ -1859,7 +1947,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxx1xxxxxx1xxxxxx00xxx1x10x01x
dmb. */
- return 785;
+ return 793;
}
}
}
@@ -1871,7 +1959,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxx100xx1x10x01x
sys. */
- return 787;
+ return 795;
}
else
{
@@ -1879,7 +1967,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxx101xx1x10x01x
sysl. */
- return 793;
+ return 801;
}
}
}
@@ -1891,7 +1979,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxx10xx1x10x01x
msr. */
- return 792;
+ return 800;
}
else
{
@@ -1899,7 +1987,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxx11xx1x10x01x
mrs. */
- return 794;
+ return 802;
}
}
}
@@ -1923,7 +2011,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx0110x1xx
tbz. */
- return 795;
+ return 803;
}
}
else
@@ -1942,7 +2030,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx1110x1xx
tbnz. */
- return 796;
+ return 804;
}
}
}
@@ -1973,7 +2061,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx00001101xx
stnp. */
- return 733;
+ return 741;
}
}
else
@@ -2025,7 +2113,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx00101101xx
stp. */
- return 737;
+ return 745;
}
}
}
@@ -2089,7 +2177,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx01x01101xx
stp. */
- return 742;
+ return 750;
}
}
}
@@ -2113,7 +2201,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx10001101xx
ldnp. */
- return 734;
+ return 742;
}
}
else
@@ -2165,7 +2253,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx10101101xx
ldp. */
- return 738;
+ return 746;
}
}
}
@@ -2229,7 +2317,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx11x01101xx
ldp. */
- return 743;
+ return 751;
}
}
}
@@ -2244,7 +2332,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxxxx001110xx
ldr. */
- return 746;
+ return 754;
}
else
{
@@ -2258,7 +2346,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx0x001111xx
stur. */
- return 691;
+ return 699;
}
else
{
@@ -2266,7 +2354,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00xxxxxxxxxx1x001111xx
ldur. */
- return 692;
+ return 700;
}
}
else
@@ -2277,7 +2365,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxxx0x001111xx
str. */
- return 667;
+ return 675;
}
else
{
@@ -2285,7 +2373,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx01xxxxxxxxxx1x001111xx
ldr. */
- return 668;
+ return 676;
}
}
}
@@ -2297,7 +2385,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx0x001111xx
str. */
- return 644;
+ return 652;
}
else
{
@@ -2305,7 +2393,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx1xxxxxxxxxxx1x001111xx
ldr. */
- return 645;
+ return 653;
}
}
}
@@ -2318,7 +2406,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx0x10111xxx
str. */
- return 655;
+ return 663;
}
else
{
@@ -2326,7 +2414,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxxxxxxxx1x10111xxx
ldr. */
- return 656;
+ return 664;
}
}
}
@@ -2511,7 +2599,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxx00xxx0xx01111x0x
fcvtzs. */
- return 590;
+ return 598;
}
else
{
@@ -2519,7 +2607,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxx01xxx0xx01111x0x
scvtf. */
- return 588;
+ return 596;
}
}
else
@@ -2530,7 +2618,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxx10xxx0xx01111x0x
fcvtzu. */
- return 591;
+ return 599;
}
else
{
@@ -2538,7 +2626,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxxx11xxx0xx01111x0x
ucvtf. */
- return 589;
+ return 597;
}
}
}
@@ -2700,7 +2788,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000000001xx01111xxx
fcvtns. */
- return 592;
+ return 600;
}
else
{
@@ -2708,7 +2796,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000000011xx01111xxx
fcvtms. */
- return 602;
+ return 610;
}
}
else
@@ -2719,7 +2807,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000000101xx01111xxx
fcvtps. */
- return 600;
+ return 608;
}
else
{
@@ -2727,7 +2815,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000000111xx01111xxx
fcvtzs. */
- return 604;
+ return 612;
}
}
}
@@ -2737,7 +2825,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000001xx1xx01111xxx
fcvtas. */
- return 596;
+ return 604;
}
}
else
@@ -2748,7 +2836,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000010xx1xx01111xxx
scvtf. */
- return 594;
+ return 602;
}
else
{
@@ -2758,7 +2846,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx0000000110x1xx01111xxx
fmov. */
- return 598;
+ return 606;
}
else
{
@@ -2766,7 +2854,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx0000000111x1xx01111xxx
fmov. */
- return 606;
+ return 614;
}
}
}
@@ -2785,7 +2873,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000100001xx01111xxx
fcvtnu. */
- return 593;
+ return 601;
}
else
{
@@ -2793,7 +2881,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000100011xx01111xxx
fcvtmu. */
- return 603;
+ return 611;
}
}
else
@@ -2804,7 +2892,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000100101xx01111xxx
fcvtpu. */
- return 601;
+ return 609;
}
else
{
@@ -2812,7 +2900,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000100111xx01111xxx
fcvtzu. */
- return 605;
+ return 613;
}
}
}
@@ -2822,7 +2910,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000101xx1xx01111xxx
fcvtau. */
- return 597;
+ return 605;
}
}
else
@@ -2833,7 +2921,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000000110xx1xx01111xxx
ucvtf. */
- return 595;
+ return 603;
}
else
{
@@ -2843,7 +2931,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx0000001110x1xx01111xxx
fmov. */
- return 599;
+ return 607;
}
else
{
@@ -2851,7 +2939,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx0000001111x1xx01111xxx
fmov. */
- return 607;
+ return 615;
}
}
}
@@ -3001,7 +3089,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000010000xx1xx01111xxx
fmov. */
- return 614;
+ return 622;
}
else
{
@@ -3009,7 +3097,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000010001xx1xx01111xxx
frintn. */
- return 619;
+ return 627;
}
}
else
@@ -3020,7 +3108,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000010100xx1xx01111xxx
fneg. */
- return 616;
+ return 624;
}
else
{
@@ -3028,7 +3116,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000010101xx1xx01111xxx
frintm. */
- return 621;
+ return 629;
}
}
}
@@ -3042,7 +3130,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000011000xx1xx01111xxx
fabs. */
- return 615;
+ return 623;
}
else
{
@@ -3050,7 +3138,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000011001xx1xx01111xxx
frintp. */
- return 620;
+ return 628;
}
}
else
@@ -3061,7 +3149,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000011100xx1xx01111xxx
fsqrt. */
- return 617;
+ return 625;
}
else
{
@@ -3069,7 +3157,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000011101xx1xx01111xxx
frintz. */
- return 622;
+ return 630;
}
}
}
@@ -3082,7 +3170,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx00001xx10xx1xx01111xxx
fcvt. */
- return 618;
+ return 626;
}
else
{
@@ -3094,7 +3182,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000010011xx1xx01111xxx
frinta. */
- return 623;
+ return 631;
}
else
{
@@ -3102,7 +3190,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000010111xx1xx01111xxx
frintx. */
- return 624;
+ return 632;
}
}
else
@@ -3111,7 +3199,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx000011x11xx1xx01111xxx
frinti. */
- return 625;
+ return 633;
}
}
}
@@ -3175,7 +3263,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxx00xxxxx000100xxxxx1xx01111xxx
fcmp. */
- return 610;
+ return 618;
}
else
{
@@ -3183,7 +3271,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxx01xxxxx000100xxxxx1xx01111xxx
fcmpe. */
- return 611;
+ return 619;
}
}
else
@@ -3194,7 +3282,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxx10xxxxx000100xxxxx1xx01111xxx
fcmp. */
- return 612;
+ return 620;
}
else
{
@@ -3202,7 +3290,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxx11xxxxx000100xxxxx1xx01111xxx
fcmpe. */
- return 613;
+ return 621;
}
}
}
@@ -3585,7 +3673,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx001xxxxxxxx1xx01111x0x
fmov. */
- return 639;
+ return 647;
}
else
{
@@ -3657,7 +3745,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx010000xxxxx1xx01111x0x
fmul. */
- return 626;
+ return 634;
}
else
{
@@ -3733,7 +3821,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx010001xxxxx1xx0111100x
fnmul. */
- return 634;
+ return 642;
}
else
{
@@ -3843,7 +3931,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx010010xxxxx1xx0111100x
fmax. */
- return 630;
+ return 638;
}
else
{
@@ -4096,7 +4184,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx010100xxxxx1xx0111100x
fadd. */
- return 628;
+ return 636;
}
else
{
@@ -4355,7 +4443,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx010110xxxxx1xx011110xx
fmaxnm. */
- return 632;
+ return 640;
}
else
{
@@ -4413,7 +4501,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx011000xxxxx1xx01111x0x
fdiv. */
- return 627;
+ return 635;
}
else
{
@@ -4562,7 +4650,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx011010xxxxx1xx01111xxx
fmin. */
- return 631;
+ return 639;
}
}
else
@@ -4786,7 +4874,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx011100xxxxx1xx0111100x
fsub. */
- return 629;
+ return 637;
}
else
{
@@ -5025,7 +5113,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx011110xxxxx1xx0111100x
fminnm. */
- return 633;
+ return 641;
}
else
{
@@ -5578,7 +5666,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxx0xxxxx10xxxxxxxxx1xx0111100x
fccmp. */
- return 608;
+ return 616;
}
else
{
@@ -5586,7 +5674,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxx1xxxxx10xxxxxxxxx1xx0111100x
fccmpe. */
- return 609;
+ return 617;
}
}
else
@@ -6167,7 +6255,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxx11xxxxxxxxx1xx0111100x
fcsel. */
- return 640;
+ return 648;
}
else
{
@@ -6589,7 +6677,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx0xx1111100x
fmadd. */
- return 635;
+ return 643;
}
else
{
@@ -6597,7 +6685,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx0xxxxx1xx1111100x
fnmadd. */
- return 637;
+ return 645;
}
}
else
@@ -7147,7 +7235,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx0xx1111100x
fmsub. */
- return 636;
+ return 644;
}
else
{
@@ -7155,7 +7243,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
10987654321098765432109876543210
xxxxxxxxxxxxxxx1xxxxx1xx1111100x
fnmsub. */
- return 638;
+ return 646;
}
}
else
@@ -7343,10 +7431,10 @@ aarch64_find_next_opcode (const aarch64_opcode *opcode)
int value;
switch (key)
{
- case 731: value = 735; break; /* stnp --> stp. */
- case 735: return NULL; /* stp --> NULL. */
- case 732: value = 736; break; /* ldnp --> ldp. */
- case 736: return NULL; /* ldp --> NULL. */
+ case 739: value = 743; break; /* stnp --> stp. */
+ case 743: return NULL; /* stp --> NULL. */
+ case 740: value = 744; break; /* ldnp --> ldp. */
+ case 744: return NULL; /* ldp --> NULL. */
case 355: value = 356; break; /* st4 --> st1. */
case 356: value = 357; break; /* st1 --> st2. */
case 357: value = 358; break; /* st2 --> st3. */
@@ -7462,35 +7550,35 @@ aarch64_find_alias_opcode (const aarch64_opcode *opcode)
case 558: value = 559; break; /* lsrv --> lsr. */
case 560: value = 561; break; /* asrv --> asr. */
case 562: value = 563; break; /* rorv --> ror. */
- case 564: value = 565; break; /* madd --> mul. */
- case 566: value = 567; break; /* msub --> mneg. */
- case 568: value = 569; break; /* smaddl --> smull. */
- case 570: value = 571; break; /* smsubl --> smnegl. */
- case 573: value = 574; break; /* umaddl --> umull. */
- case 575: value = 576; break; /* umsubl --> umnegl. */
- case 586: value = 587; break; /* extr --> ror. */
- case 685: value = 687; break; /* sturb --> strb. */
- case 686: value = 688; break; /* ldurb --> ldrb. */
- case 689: value = 690; break; /* ldursb --> ldrsb. */
- case 691: value = 693; break; /* stur --> str. */
- case 692: value = 694; break; /* ldur --> ldr. */
- case 695: value = 697; break; /* sturh --> strh. */
- case 696: value = 698; break; /* ldurh --> ldrh. */
- case 699: value = 700; break; /* ldursh --> ldrsh. */
- case 701: value = 703; break; /* stur --> str. */
- case 702: value = 704; break; /* ldur --> ldr. */
- case 705: value = 706; break; /* ldursw --> ldrsw. */
- case 707: value = 708; break; /* prfum --> prfm. */
- case 749: value = 750; break; /* and --> bic. */
- case 751: value = 752; break; /* orr --> mov. */
- case 754: value = 755; break; /* ands --> tst. */
- case 758: value = 760; break; /* orr --> uxtw. */
- case 761: value = 762; break; /* orn --> mvn. */
- case 765: value = 766; break; /* ands --> tst. */
- case 768: value = 769; break; /* movn --> mov. */
- case 770: value = 771; break; /* movz --> mov. */
- case 776: value = 782; break; /* hint --> sevl. */
- case 787: value = 791; break; /* sys --> tlbi. */
+ case 572: value = 573; break; /* madd --> mul. */
+ case 574: value = 575; break; /* msub --> mneg. */
+ case 576: value = 577; break; /* smaddl --> smull. */
+ case 578: value = 579; break; /* smsubl --> smnegl. */
+ case 581: value = 582; break; /* umaddl --> umull. */
+ case 583: value = 584; break; /* umsubl --> umnegl. */
+ case 594: value = 595; break; /* extr --> ror. */
+ case 693: value = 695; break; /* sturb --> strb. */
+ case 694: value = 696; break; /* ldurb --> ldrb. */
+ case 697: value = 698; break; /* ldursb --> ldrsb. */
+ case 699: value = 701; break; /* stur --> str. */
+ case 700: value = 702; break; /* ldur --> ldr. */
+ case 703: value = 705; break; /* sturh --> strh. */
+ case 704: value = 706; break; /* ldurh --> ldrh. */
+ case 707: value = 708; break; /* ldursh --> ldrsh. */
+ case 709: value = 711; break; /* stur --> str. */
+ case 710: value = 712; break; /* ldur --> ldr. */
+ case 713: value = 714; break; /* ldursw --> ldrsw. */
+ case 715: value = 716; break; /* prfum --> prfm. */
+ case 757: value = 758; break; /* and --> bic. */
+ case 759: value = 760; break; /* orr --> mov. */
+ case 762: value = 763; break; /* ands --> tst. */
+ case 766: value = 768; break; /* orr --> uxtw. */
+ case 769: value = 770; break; /* orn --> mvn. */
+ case 773: value = 774; break; /* ands --> tst. */
+ case 776: value = 777; break; /* movn --> mov. */
+ case 778: value = 779; break; /* movz --> mov. */
+ case 784: value = 790; break; /* hint --> sevl. */
+ case 795: value = 799; break; /* sys --> tlbi. */
default: return NULL;
}
@@ -7519,15 +7607,15 @@ aarch64_find_next_alias_opcode (const aarch64_opcode *opcode)
case 505: value = 504; break; /* ubfx --> ubfiz. */
case 527: value = 526; break; /* cset --> cinc. */
case 530: value = 529; break; /* csetm --> cinv. */
- case 760: value = 759; break; /* uxtw --> mov. */
- case 782: value = 781; break; /* sevl --> sev. */
- case 781: value = 780; break; /* sev --> wfi. */
- case 780: value = 779; break; /* wfi --> wfe. */
- case 779: value = 778; break; /* wfe --> yield. */
- case 778: value = 777; break; /* yield --> nop. */
- case 791: value = 790; break; /* tlbi --> ic. */
- case 790: value = 789; break; /* ic --> dc. */
- case 789: value = 788; break; /* dc --> at. */
+ case 768: value = 767; break; /* uxtw --> mov. */
+ case 790: value = 789; break; /* sevl --> sev. */
+ case 789: value = 788; break; /* sev --> wfi. */
+ case 788: value = 787; break; /* wfi --> wfe. */
+ case 787: value = 786; break; /* wfe --> yield. */
+ case 786: value = 785; break; /* yield --> nop. */
+ case 799: value = 798; break; /* tlbi --> ic. */
+ case 798: value = 797; break; /* ic --> dc. */
+ case 797: value = 796; break; /* dc --> at. */
default: return NULL;
}
diff --git a/opcodes/aarch64-opc-2.c b/opcodes/aarch64-opc-2.c
index 0b4263d..08010eb 100644
--- a/opcodes/aarch64-opc-2.c
+++ b/opcodes/aarch64-opc-2.c
@@ -119,48 +119,48 @@ const struct aarch64_operand aarch64_operands[] =
static const unsigned op_enum_table [] =
{
0,
- 652,
- 653,
- 654,
- 657,
- 658,
- 659,
660,
661,
- 655,
- 656,
662,
+ 665,
+ 666,
+ 667,
+ 668,
+ 669,
663,
- 685,
- 686,
- 689,
- 695,
- 696,
- 699,
- 701,
- 702,
- 691,
- 692,
- 705,
+ 664,
+ 670,
+ 671,
+ 693,
+ 694,
+ 697,
+ 703,
+ 704,
707,
- 745,
- 746,
- 747,
- 748,
+ 709,
+ 710,
+ 699,
+ 700,
+ 713,
+ 715,
+ 753,
+ 754,
+ 755,
+ 756,
12,
510,
511,
- 768,
- 770,
- 772,
- 752,
- 771,
- 769,
+ 776,
+ 778,
+ 780,
+ 760,
+ 779,
+ 777,
259,
499,
509,
508,
- 750,
+ 758,
505,
502,
495,
@@ -169,19 +169,19 @@ static const unsigned op_enum_table [] =
504,
506,
507,
- 760,
+ 768,
526,
529,
532,
527,
530,
- 618,
+ 626,
160,
161,
162,
163,
420,
- 587,
+ 595,
314,
316,
336,
diff --git a/opcodes/aarch64-tbl.h b/opcodes/aarch64-tbl.h
index 678ba78..7c77768 100644
--- a/opcodes/aarch64-tbl.h
+++ b/opcodes/aarch64-tbl.h
@@ -163,12 +163,24 @@
QLF2(X,X), \
}
+/* e.g. CRC32B <Wd>, <Wn>, <Wm>. */
+#define QL_I3SAMEW \
+{ \
+ QLF3(W,W,W), \
+}
+
/* e.g. SMULH <Xd>, <Xn>, <Xm>. */
#define QL_I3SAMEX \
{ \
QLF3(X,X,X), \
}
+/* e.g. CRC32X <Wd>, <Wn>, <Xm>. */
+#define QL_I3WWX \
+{ \
+ QLF3(W,W,X), \
+}
+
/* e.g. UDIV <Xd>, <Xn>, <Xm>. */
#define QL_I3SAMER \
{ \
@@ -1199,11 +1211,14 @@ static const aarch64_feature_set aarch64_feature_simd =
AARCH64_FEATURE (AARCH64_FEATURE_SIMD, 0);
static const aarch64_feature_set aarch64_feature_crypto =
AARCH64_FEATURE (AARCH64_FEATURE_CRYPTO, 0);
+static const aarch64_feature_set aarch64_feature_crc =
+ AARCH64_FEATURE (AARCH64_FEATURE_CRC, 0);
#define CORE &aarch64_feature_v8
#define FP &aarch64_feature_fp
#define SIMD &aarch64_feature_simd
#define CRYPTO &aarch64_feature_crypto
+#define CRC &aarch64_feature_crc
struct aarch64_opcode aarch64_opcode_table[] =
{
@@ -1810,6 +1825,15 @@ struct aarch64_opcode aarch64_opcode_table[] =
{"asr", 0x1ac02800, 0x7fe0fc00, dp_2src, 0, CORE, OP3 (Rd, Rn, Rm), QL_I3SAMER, F_SF | F_ALIAS},
{"rorv", 0x1ac02c00, 0x7fe0fc00, dp_2src, 0, CORE, OP3 (Rd, Rn, Rm), QL_I3SAMER, F_SF | F_HAS_ALIAS},
{"ror", 0x1ac02c00, 0x7fe0fc00, dp_2src, 0, CORE, OP3 (Rd, Rn, Rm), QL_I3SAMER, F_SF | F_ALIAS},
+ /* CRC instructions. */
+ {"crc32b", 0x1ac04000, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3SAMEW, 0},
+ {"crc32h", 0x1ac04400, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3SAMEW, 0},
+ {"crc32w", 0x1ac04800, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3SAMEW, 0},
+ {"crc32x", 0x9ac04c00, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3WWX, 0},
+ {"crc32cb", 0x1ac05000, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3SAMEW, 0},
+ {"crc32ch", 0x1ac05400, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3SAMEW, 0},
+ {"crc32cw", 0x1ac05800, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3SAMEW, 0},
+ {"crc32cx", 0x9ac05c00, 0xffe0fc00, dp_2src, 0, CRC, OP3 (Rd, Rn, Rm), QL_I3WWX, 0},
/* Data-processing (3 source). */
{"madd", 0x1b000000, 0x7fe08000, dp_3src, 0, CORE, OP4 (Rd, Rn, Rm, Ra), QL_I4SAMER, F_HAS_ALIAS | F_SF},
{"mul", 0x1b007c00, 0x7fe0fc00, dp_3src, 0, CORE, OP3 (Rd, Rn, Rm), QL_I3SAMER, F_ALIAS | F_SF},