public inbox for binutils@sourceware.org
 help / color / mirror / Atom feed
From: Richard Sandiford <richard.sandiford@arm.com>
To: binutils@sourceware.org
Cc: Richard Sandiford <richard.sandiford@arm.com>
Subject: [PATCH 18/31] aarch64: Add the SME2 MOPA and MOPS instructions
Date: Thu, 30 Mar 2023 11:26:33 +0100	[thread overview]
Message-ID: <20230330102646.3327818-19-richard.sandiford@arm.com> (raw)
In-Reply-To: <20230330102646.3327818-1-richard.sandiford@arm.com>

[BSU]MOP[AS] share the same format.
---
 gas/testsuite/gas/aarch64/sme2-21-invalid.d |    3 +
 gas/testsuite/gas/aarch64/sme2-21-invalid.l |   18 +
 gas/testsuite/gas/aarch64/sme2-21-invalid.s |   12 +
 gas/testsuite/gas/aarch64/sme2-21-noarch.d  |    3 +
 gas/testsuite/gas/aarch64/sme2-21-noarch.l  |   43 +
 gas/testsuite/gas/aarch64/sme2-21.d         |   51 +
 gas/testsuite/gas/aarch64/sme2-21.s         |   47 +
 opcodes/aarch64-dis-2.c                     | 1500 ++++++++++---------
 opcodes/aarch64-tbl.h                       |    6 +
 9 files changed, 966 insertions(+), 717 deletions(-)
 create mode 100644 gas/testsuite/gas/aarch64/sme2-21-invalid.d
 create mode 100644 gas/testsuite/gas/aarch64/sme2-21-invalid.l
 create mode 100644 gas/testsuite/gas/aarch64/sme2-21-invalid.s
 create mode 100644 gas/testsuite/gas/aarch64/sme2-21-noarch.d
 create mode 100644 gas/testsuite/gas/aarch64/sme2-21-noarch.l
 create mode 100644 gas/testsuite/gas/aarch64/sme2-21.d
 create mode 100644 gas/testsuite/gas/aarch64/sme2-21.s

diff --git a/gas/testsuite/gas/aarch64/sme2-21-invalid.d b/gas/testsuite/gas/aarch64/sme2-21-invalid.d
new file mode 100644
index 00000000000..5d1d1f4091e
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme2-21-invalid.d
@@ -0,0 +1,3 @@
+#as: -march=armv8-a
+#source: sme2-21-invalid.s
+#error_output: sme2-21-invalid.l
diff --git a/gas/testsuite/gas/aarch64/sme2-21-invalid.l b/gas/testsuite/gas/aarch64/sme2-21-invalid.l
new file mode 100644
index 00000000000..c148ab2ece7
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme2-21-invalid.l
@@ -0,0 +1,18 @@
+[^ :]+: Assembler messages:
+[^ :]+:[0-9]+: Error: expected a ZA tile at operand 1 -- `bmopa 0,p0/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: expected an SVE predicate register at operand 2 -- `bmopa za0\.s,0,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: expected an SVE predicate register at operand 3 -- `bmopa za0\.s,p0/m,0,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: expected an SVE vector register at operand 4 -- `bmopa za0\.s,p0/m,p0/m,0,z0\.s'
+[^ :]+:[0-9]+: Error: expected an SVE vector register at operand 5 -- `bmopa za0\.s,p0/m,p0/m,z0\.s,0'
+[^ :]+:[0-9]+: Error: operand mismatch -- `bmopa za0\.b,p0/m,p0/m,z0\.b,z0\.b'
+[^ :]+:[0-9]+: Info:    did you mean this\?
+[^ :]+:[0-9]+: Info:    	bmopa za0\.s, p0/m, p0/m, z0\.s, z0\.s
+[^ :]+:[0-9]+: Error: operand mismatch -- `bmopa za0\.b,p0/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Info:    did you mean this\?
+[^ :]+:[0-9]+: Info:    	bmopa za0\.s, p0/m, p0/m, z0\.s, z0\.s
+[^ :]+:[0-9]+: Error: operand mismatch -- `bmopa za0\.s,p0/m,p0/m,z0\.b,z0\.b'
+[^ :]+:[0-9]+: Info:    did you mean this\?
+[^ :]+:[0-9]+: Info:    	bmopa za0\.s, p0/m, p0/m, z0\.s, z0\.s
+[^ :]+:[0-9]+: Error: ZA tile number out of range at operand 1 -- `bmopa za4\.s,p0/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: p0-p7 expected at operand 2 -- `bmopa za0\.s,p8/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: ZA tile number out of range at operand 1 -- `bmopa za4\.s,p0/m,p8/m,z0\.s,z0\.s'
diff --git a/gas/testsuite/gas/aarch64/sme2-21-invalid.s b/gas/testsuite/gas/aarch64/sme2-21-invalid.s
new file mode 100644
index 00000000000..91a3e8f70c0
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme2-21-invalid.s
@@ -0,0 +1,12 @@
+	bmopa	0, p0/m, p0/m, z0.s, z0.s
+	bmopa	za0.s, 0, p0/m, z0.s, z0.s
+	bmopa	za0.s, p0/m, 0, z0.s, z0.s
+	bmopa	za0.s, p0/m, p0/m, 0, z0.s
+	bmopa	za0.s, p0/m, p0/m, z0.s, 0
+
+	bmopa	za0.b, p0/m, p0/m, z0.b, z0.b
+	bmopa	za0.b, p0/m, p0/m, z0.s, z0.s
+	bmopa	za0.s, p0/m, p0/m, z0.b, z0.b
+	bmopa	za4.s, p0/m, p0/m, z0.s, z0.s
+	bmopa	za0.s, p8/m, p0/m, z0.s, z0.s
+	bmopa	za4.s, p0/m, p8/m, z0.s, z0.s
diff --git a/gas/testsuite/gas/aarch64/sme2-21-noarch.d b/gas/testsuite/gas/aarch64/sme2-21-noarch.d
new file mode 100644
index 00000000000..830ef05c601
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme2-21-noarch.d
@@ -0,0 +1,3 @@
+#as: -march=armv8-a+sme
+#source: sme2-21.s
+#error_output: sme2-21-noarch.l
diff --git a/gas/testsuite/gas/aarch64/sme2-21-noarch.l b/gas/testsuite/gas/aarch64/sme2-21-noarch.l
new file mode 100644
index 00000000000..64842d9714c
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme2-21-noarch.l
@@ -0,0 +1,43 @@
+[^ :]+: Assembler messages:
+[^ :]+:[0-9]+: Error: selected processor does not support `bmopa za0\.s,p0/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmopa za3\.s,p0/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmopa za0\.s,p7/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmopa za0\.s,p0/m,p7/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmopa za0\.s,p0/m,p0/m,z31\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmopa za0\.s,p0/m,p0/m,z0\.s,z31\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmopa za2\.s,p6/m,p3/m,z19\.s,z8\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmops za0\.s,p0/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmops za3\.s,p0/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmops za0\.s,p7/m,p0/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmops za0\.s,p0/m,p7/m,z0\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmops za0\.s,p0/m,p0/m,z31\.s,z0\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmops za0\.s,p0/m,p0/m,z0\.s,z31\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `bmops za1\.s,p3/m,p5/m,z24\.s,z6\.s'
+[^ :]+:[0-9]+: Error: selected processor does not support `smopa za0\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smopa za3\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smopa za0\.s,p7/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smopa za0\.s,p0/m,p7/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smopa za0\.s,p0/m,p0/m,z31\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smopa za0\.s,p0/m,p0/m,z0\.h,z31\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smopa za1\.s,p2/m,p3/m,z14\.h,z25\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smops za0\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smops za3\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smops za0\.s,p7/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smops za0\.s,p0/m,p7/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smops za0\.s,p0/m,p0/m,z31\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smops za0\.s,p0/m,p0/m,z0\.h,z31\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `smops za1\.s,p2/m,p3/m,z14\.h,z25\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umopa za0\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umopa za3\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umopa za0\.s,p7/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umopa za0\.s,p0/m,p7/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umopa za0\.s,p0/m,p0/m,z31\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umopa za0\.s,p0/m,p0/m,z0\.h,z31\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umopa za1\.s,p2/m,p3/m,z14\.h,z25\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umops za0\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umops za3\.s,p0/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umops za0\.s,p7/m,p0/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umops za0\.s,p0/m,p7/m,z0\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umops za0\.s,p0/m,p0/m,z31\.h,z0\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umops za0\.s,p0/m,p0/m,z0\.h,z31\.h'
+[^ :]+:[0-9]+: Error: selected processor does not support `umops za1\.s,p2/m,p3/m,z14\.h,z25\.h'
diff --git a/gas/testsuite/gas/aarch64/sme2-21.d b/gas/testsuite/gas/aarch64/sme2-21.d
new file mode 100644
index 00000000000..255a56d9b70
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme2-21.d
@@ -0,0 +1,51 @@
+#as: -march=armv8-a+sme2
+#objdump: -dr
+
+[^:]+:     file format .*
+
+
+[^:]+:
+
+[^:]+:
+[^:]+:	80800008 	bmopa	za0\.s, p0/m, p0/m, z0\.s, z0\.s
+[^:]+:	8080000b 	bmopa	za3\.s, p0/m, p0/m, z0\.s, z0\.s
+[^:]+:	80801c08 	bmopa	za0\.s, p7/m, p0/m, z0\.s, z0\.s
+[^:]+:	8080e008 	bmopa	za0\.s, p0/m, p7/m, z0\.s, z0\.s
+[^:]+:	808003e8 	bmopa	za0\.s, p0/m, p0/m, z31\.s, z0\.s
+[^:]+:	809f0008 	bmopa	za0\.s, p0/m, p0/m, z0\.s, z31\.s
+[^:]+:	80887a6a 	bmopa	za2\.s, p6/m, p3/m, z19\.s, z8\.s
+[^:]+:	80800018 	bmops	za0\.s, p0/m, p0/m, z0\.s, z0\.s
+[^:]+:	8080001b 	bmops	za3\.s, p0/m, p0/m, z0\.s, z0\.s
+[^:]+:	80801c18 	bmops	za0\.s, p7/m, p0/m, z0\.s, z0\.s
+[^:]+:	8080e018 	bmops	za0\.s, p0/m, p7/m, z0\.s, z0\.s
+[^:]+:	808003f8 	bmops	za0\.s, p0/m, p0/m, z31\.s, z0\.s
+[^:]+:	809f0018 	bmops	za0\.s, p0/m, p0/m, z0\.s, z31\.s
+[^:]+:	8086af19 	bmops	za1\.s, p3/m, p5/m, z24\.s, z6\.s
+[^:]+:	a0800008 	smopa	za0\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a080000b 	smopa	za3\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a0801c08 	smopa	za0\.s, p7/m, p0/m, z0\.h, z0\.h
+[^:]+:	a080e008 	smopa	za0\.s, p0/m, p7/m, z0\.h, z0\.h
+[^:]+:	a08003e8 	smopa	za0\.s, p0/m, p0/m, z31\.h, z0\.h
+[^:]+:	a09f0008 	smopa	za0\.s, p0/m, p0/m, z0\.h, z31\.h
+[^:]+:	a09969c9 	smopa	za1\.s, p2/m, p3/m, z14\.h, z25\.h
+[^:]+:	a0800018 	smops	za0\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a080001b 	smops	za3\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a0801c18 	smops	za0\.s, p7/m, p0/m, z0\.h, z0\.h
+[^:]+:	a080e018 	smops	za0\.s, p0/m, p7/m, z0\.h, z0\.h
+[^:]+:	a08003f8 	smops	za0\.s, p0/m, p0/m, z31\.h, z0\.h
+[^:]+:	a09f0018 	smops	za0\.s, p0/m, p0/m, z0\.h, z31\.h
+[^:]+:	a09969d9 	smops	za1\.s, p2/m, p3/m, z14\.h, z25\.h
+[^:]+:	a1800008 	umopa	za0\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a180000b 	umopa	za3\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a1801c08 	umopa	za0\.s, p7/m, p0/m, z0\.h, z0\.h
+[^:]+:	a180e008 	umopa	za0\.s, p0/m, p7/m, z0\.h, z0\.h
+[^:]+:	a18003e8 	umopa	za0\.s, p0/m, p0/m, z31\.h, z0\.h
+[^:]+:	a19f0008 	umopa	za0\.s, p0/m, p0/m, z0\.h, z31\.h
+[^:]+:	a19969c9 	umopa	za1\.s, p2/m, p3/m, z14\.h, z25\.h
+[^:]+:	a1800018 	umops	za0\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a180001b 	umops	za3\.s, p0/m, p0/m, z0\.h, z0\.h
+[^:]+:	a1801c18 	umops	za0\.s, p7/m, p0/m, z0\.h, z0\.h
+[^:]+:	a180e018 	umops	za0\.s, p0/m, p7/m, z0\.h, z0\.h
+[^:]+:	a18003f8 	umops	za0\.s, p0/m, p0/m, z31\.h, z0\.h
+[^:]+:	a19f0018 	umops	za0\.s, p0/m, p0/m, z0\.h, z31\.h
+[^:]+:	a19969d9 	umops	za1\.s, p2/m, p3/m, z14\.h, z25\.h
diff --git a/gas/testsuite/gas/aarch64/sme2-21.s b/gas/testsuite/gas/aarch64/sme2-21.s
new file mode 100644
index 00000000000..a924b7d83a6
--- /dev/null
+++ b/gas/testsuite/gas/aarch64/sme2-21.s
@@ -0,0 +1,47 @@
+	bmopa	za0.s, p0/m, p0/m, z0.s, z0.s
+	bmopa	za3.s, p0/m, p0/m, z0.s, z0.s
+	bmopa	za0.s, p7/m, p0/m, z0.s, z0.s
+	bmopa	za0.s, p0/m, p7/m, z0.s, z0.s
+	bmopa	za0.s, p0/m, p0/m, z31.s, z0.s
+	bmopa	za0.s, p0/m, p0/m, z0.s, z31.s
+	bmopa	za2.s, p6/m, p3/m, z19.s, z8.s
+
+	bmops	za0.s, p0/m, p0/m, z0.s, z0.s
+	bmops	za3.s, p0/m, p0/m, z0.s, z0.s
+	bmops	za0.s, p7/m, p0/m, z0.s, z0.s
+	bmops	za0.s, p0/m, p7/m, z0.s, z0.s
+	bmops	za0.s, p0/m, p0/m, z31.s, z0.s
+	bmops	za0.s, p0/m, p0/m, z0.s, z31.s
+	bmops	za1.s, p3/m, p5/m, z24.s, z6.s
+
+	smopa	za0.s, p0/m, p0/m, z0.h, z0.h
+	smopa	za3.s, p0/m, p0/m, z0.h, z0.h
+	smopa	za0.s, p7/m, p0/m, z0.h, z0.h
+	smopa	za0.s, p0/m, p7/m, z0.h, z0.h
+	smopa	za0.s, p0/m, p0/m, z31.h, z0.h
+	smopa	za0.s, p0/m, p0/m, z0.h, z31.h
+	smopa	za1.s, p2/m, p3/m, z14.h, z25.h
+
+	smops	za0.s, p0/m, p0/m, z0.h, z0.h
+	smops	za3.s, p0/m, p0/m, z0.h, z0.h
+	smops	za0.s, p7/m, p0/m, z0.h, z0.h
+	smops	za0.s, p0/m, p7/m, z0.h, z0.h
+	smops	za0.s, p0/m, p0/m, z31.h, z0.h
+	smops	za0.s, p0/m, p0/m, z0.h, z31.h
+	smops	za1.s, p2/m, p3/m, z14.h, z25.h
+
+	umopa	za0.s, p0/m, p0/m, z0.h, z0.h
+	umopa	za3.s, p0/m, p0/m, z0.h, z0.h
+	umopa	za0.s, p7/m, p0/m, z0.h, z0.h
+	umopa	za0.s, p0/m, p7/m, z0.h, z0.h
+	umopa	za0.s, p0/m, p0/m, z31.h, z0.h
+	umopa	za0.s, p0/m, p0/m, z0.h, z31.h
+	umopa	za1.s, p2/m, p3/m, z14.h, z25.h
+
+	umops	za0.s, p0/m, p0/m, z0.h, z0.h
+	umops	za3.s, p0/m, p0/m, z0.h, z0.h
+	umops	za0.s, p7/m, p0/m, z0.h, z0.h
+	umops	za0.s, p0/m, p7/m, z0.h, z0.h
+	umops	za0.s, p0/m, p0/m, z31.h, z0.h
+	umops	za0.s, p0/m, p0/m, z0.h, z31.h
+	umops	za1.s, p2/m, p3/m, z14.h, z25.h
diff --git a/opcodes/aarch64-dis-2.c b/opcodes/aarch64-dis-2.c
index ddd0a68970a..672475aee5b 100644
--- a/opcodes/aarch64-dis-2.c
+++ b/opcodes/aarch64-dis-2.c
@@ -54,21 +54,43 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                         }
                                       else
                                         {
-                                          if (((word >> 4) & 0x1) == 0)
+                                          if (((word >> 3) & 0x1) == 0)
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 x0000000100xxxxxxxxxxxxxxxx0xxxx
-                                                 fmopa.  */
-                                              return 2365;
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x0000000100xxxxxxxxxxxxxxxx00xxx
+                                                     fmopa.  */
+                                                  return 2365;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x0000000100xxxxxxxxxxxxxxxx10xxx
+                                                     fmops.  */
+                                                  return 2368;
+                                                }
                                             }
                                           else
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 x0000000100xxxxxxxxxxxxxxxx1xxxx
-                                                 fmops.  */
-                                              return 2368;
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x0000000100xxxxxxxxxxxxxxxx01xxx
+                                                     bmopa.  */
+                                                  return 2459;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x0000000100xxxxxxxxxxxxxxxx11xxx
+                                                     bmops.  */
+                                                  return 2460;
+                                                }
                                             }
                                         }
                                     }
@@ -166,7 +188,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000x10x100xxxxxxxxxxxxxxxxx
                                                      zero.  */
-                                                  return 2833;
+                                                  return 2839;
                                                 }
                                             }
                                         }
@@ -190,7 +212,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x1000000x00x101xx0xxxxxxxxxxxxxx
                                                          luti4.  */
-                                                      return 2585;
+                                                      return 2587;
                                                     }
                                                   else
                                                     {
@@ -198,7 +220,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x1000000x00x101xx1xxxxxxxxxxxxxx
                                                          luti4.  */
-                                                      return 2584;
+                                                      return 2586;
                                                     }
                                                 }
                                               else
@@ -207,7 +229,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000x10x101xxxxxxxxxxxxxxxxx
                                                      luti4.  */
-                                                  return 2583;
+                                                  return 2585;
                                                 }
                                             }
                                         }
@@ -226,7 +248,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x1000000xx0x010xxxxx00xxxxxxxxxx
                                                          mov.  */
-                                                      return 2592;
+                                                      return 2594;
                                                     }
                                                   else
                                                     {
@@ -234,7 +256,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x1000000xx0x011xxxxx00xxxxxxxxxx
                                                          mov.  */
-                                                      return 2588;
+                                                      return 2590;
                                                     }
                                                 }
                                               else
@@ -247,7 +269,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000000x00x11xxx0xx00xxxxxxxxxx
                                                              luti2.  */
-                                                          return 2582;
+                                                          return 2584;
                                                         }
                                                       else
                                                         {
@@ -255,7 +277,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000000x00x11xxx1xx00xxxxxxxxxx
                                                              luti2.  */
-                                                          return 2581;
+                                                          return 2583;
                                                         }
                                                     }
                                                   else
@@ -268,7 +290,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000000010x110xxxxx00xxxxxxxxxx
                                                                  movt.  */
-                                                              return 2603;
+                                                              return 2605;
                                                             }
                                                           else
                                                             {
@@ -276,7 +298,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000000010x111xxxxx00xxxxxxxxxx
                                                                  movt.  */
-                                                              return 2602;
+                                                              return 2604;
                                                             }
                                                         }
                                                       else
@@ -285,7 +307,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000000110x11xxxxxx00xxxxxxxxxx
                                                              luti2.  */
-                                                          return 2580;
+                                                          return 2582;
                                                         }
                                                     }
                                                 }
@@ -298,7 +320,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000xx0xx10xxxxx10xxxxxxxxxx
                                                      mov.  */
-                                                  return 2590;
+                                                  return 2592;
                                                 }
                                               else
                                                 {
@@ -306,7 +328,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000xx0xx11xxxxx10xxxxxxxxxx
                                                      mov.  */
-                                                  return 2586;
+                                                  return 2588;
                                                 }
                                             }
                                         }
@@ -320,7 +342,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000xx0xx10xxxxx01xxxxxxxxxx
                                                      mov.  */
-                                                  return 2593;
+                                                  return 2595;
                                                 }
                                               else
                                                 {
@@ -328,7 +350,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000xx0xx11xxxxx01xxxxxxxxxx
                                                      mov.  */
-                                                  return 2589;
+                                                  return 2591;
                                                 }
                                             }
                                           else
@@ -339,7 +361,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000xx0xx10xxxxx11xxxxxxxxxx
                                                      mov.  */
-                                                  return 2591;
+                                                  return 2593;
                                                 }
                                               else
                                                 {
@@ -347,7 +369,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1000000xx0xx11xxxxx11xxxxxxxxxx
                                                      mov.  */
-                                                  return 2587;
+                                                  return 2589;
                                                 }
                                             }
                                         }
@@ -374,7 +396,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx000xxxxxxxxxxxx0
                                                              ld1b.  */
-                                                          return 2519;
+                                                          return 2521;
                                                         }
                                                       else
                                                         {
@@ -382,7 +404,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx100xxxxxxxxxxxx0
                                                              ld1b.  */
-                                                          return 2520;
+                                                          return 2522;
                                                         }
                                                     }
                                                   else
@@ -393,7 +415,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx010xxxxxxxxxxxx0
                                                              ld1w.  */
-                                                          return 2543;
+                                                          return 2545;
                                                         }
                                                       else
                                                         {
@@ -401,7 +423,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx110xxxxxxxxxxxx0
                                                              ld1w.  */
-                                                          return 2544;
+                                                          return 2546;
                                                         }
                                                     }
                                                 }
@@ -415,7 +437,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx001xxxxxxxxxxxx0
                                                              ld1h.  */
-                                                          return 2535;
+                                                          return 2537;
                                                         }
                                                       else
                                                         {
@@ -423,7 +445,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx101xxxxxxxxxxxx0
                                                              ld1h.  */
-                                                          return 2536;
+                                                          return 2538;
                                                         }
                                                     }
                                                   else
@@ -434,7 +456,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx011xxxxxxxxxxxx0
                                                              ld1d.  */
-                                                          return 2527;
+                                                          return 2529;
                                                         }
                                                       else
                                                         {
@@ -442,7 +464,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx111xxxxxxxxxxxx0
                                                              ld1d.  */
-                                                          return 2528;
+                                                          return 2530;
                                                         }
                                                     }
                                                 }
@@ -459,7 +481,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx000xxxxxxxxxxxx1
                                                              ldnt1b.  */
-                                                          return 2551;
+                                                          return 2553;
                                                         }
                                                       else
                                                         {
@@ -467,7 +489,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx100xxxxxxxxxxxx1
                                                              ldnt1b.  */
-                                                          return 2552;
+                                                          return 2554;
                                                         }
                                                     }
                                                   else
@@ -478,7 +500,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx010xxxxxxxxxxxx1
                                                              ldnt1w.  */
-                                                          return 2575;
+                                                          return 2577;
                                                         }
                                                       else
                                                         {
@@ -486,7 +508,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx110xxxxxxxxxxxx1
                                                              ldnt1w.  */
-                                                          return 2576;
+                                                          return 2578;
                                                         }
                                                     }
                                                 }
@@ -500,7 +522,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx001xxxxxxxxxxxx1
                                                              ldnt1h.  */
-                                                          return 2567;
+                                                          return 2569;
                                                         }
                                                       else
                                                         {
@@ -508,7 +530,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx101xxxxxxxxxxxx1
                                                              ldnt1h.  */
-                                                          return 2568;
+                                                          return 2570;
                                                         }
                                                     }
                                                   else
@@ -519,7 +541,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx011xxxxxxxxxxxx1
                                                              ldnt1d.  */
-                                                          return 2559;
+                                                          return 2561;
                                                         }
                                                       else
                                                         {
@@ -527,7 +549,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000000xxxxx111xxxxxxxxxxxx1
                                                              ldnt1d.  */
-                                                          return 2560;
+                                                          return 2562;
                                                         }
                                                     }
                                                 }
@@ -548,11 +570,22 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                         {
                                           if (((word >> 30) & 0x1) == 0)
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 x0100000100xxxxxxxxxxxxxxxx0xxxx
-                                                 smopa.  */
-                                              return 2372;
+                                              if (((word >> 3) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x0100000100xxxxxxxxxxxxxxxx00xxx
+                                                     smopa.  */
+                                                  return 2372;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     x0100000100xxxxxxxxxxxxxxxx01xxx
+                                                     smopa.  */
+                                                  return 2663;
+                                                }
                                             }
                                           else
                                             {
@@ -565,11 +598,22 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                         }
                                       else
                                         {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xx100000100xxxxxxxxxxxxxxxx1xxxx
-                                             smops.  */
-                                          return 2374;
+                                          if (((word >> 3) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xx100000100xxxxxxxxxxxxxxxx10xxx
+                                                 smops.  */
+                                              return 2374;
+                                            }
+                                          else
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xx100000100xxxxxxxxxxxxxxxx11xxx
+                                                 smops.  */
+                                              return 2664;
+                                            }
                                         }
                                     }
                                 }
@@ -591,7 +635,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx000xxxxxxxxxxxx0
                                                              ld1b.  */
-                                                          return 2515;
+                                                          return 2517;
                                                         }
                                                       else
                                                         {
@@ -599,7 +643,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx100xxxxxxxxxxxx0
                                                              ld1b.  */
-                                                          return 2516;
+                                                          return 2518;
                                                         }
                                                     }
                                                   else
@@ -610,7 +654,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx010xxxxxxxxxxxx0
                                                              ld1w.  */
-                                                          return 2539;
+                                                          return 2541;
                                                         }
                                                       else
                                                         {
@@ -618,7 +662,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx110xxxxxxxxxxxx0
                                                              ld1w.  */
-                                                          return 2540;
+                                                          return 2542;
                                                         }
                                                     }
                                                 }
@@ -632,7 +676,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx001xxxxxxxxxxxx0
                                                              ld1h.  */
-                                                          return 2531;
+                                                          return 2533;
                                                         }
                                                       else
                                                         {
@@ -640,7 +684,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx101xxxxxxxxxxxx0
                                                              ld1h.  */
-                                                          return 2532;
+                                                          return 2534;
                                                         }
                                                     }
                                                   else
@@ -651,7 +695,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx011xxxxxxxxxxxx0
                                                              ld1d.  */
-                                                          return 2523;
+                                                          return 2525;
                                                         }
                                                       else
                                                         {
@@ -659,7 +703,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx111xxxxxxxxxxxx0
                                                              ld1d.  */
-                                                          return 2524;
+                                                          return 2526;
                                                         }
                                                     }
                                                 }
@@ -676,7 +720,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx000xxxxxxxxxxxx1
                                                              ldnt1b.  */
-                                                          return 2547;
+                                                          return 2549;
                                                         }
                                                       else
                                                         {
@@ -684,7 +728,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx100xxxxxxxxxxxx1
                                                              ldnt1b.  */
-                                                          return 2548;
+                                                          return 2550;
                                                         }
                                                     }
                                                   else
@@ -695,7 +739,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx010xxxxxxxxxxxx1
                                                              ldnt1w.  */
-                                                          return 2571;
+                                                          return 2573;
                                                         }
                                                       else
                                                         {
@@ -703,7 +747,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx110xxxxxxxxxxxx1
                                                              ldnt1w.  */
-                                                          return 2572;
+                                                          return 2574;
                                                         }
                                                     }
                                                 }
@@ -717,7 +761,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx001xxxxxxxxxxxx1
                                                              ldnt1h.  */
-                                                          return 2563;
+                                                          return 2565;
                                                         }
                                                       else
                                                         {
@@ -725,7 +769,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx101xxxxxxxxxxxx1
                                                              ldnt1h.  */
-                                                          return 2564;
+                                                          return 2566;
                                                         }
                                                     }
                                                   else
@@ -736,7 +780,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx011xxxxxxxxxxxx1
                                                              ldnt1d.  */
-                                                          return 2555;
+                                                          return 2557;
                                                         }
                                                       else
                                                         {
@@ -744,7 +788,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100000010xxxxx111xxxxxxxxxxxx1
                                                              ldnt1d.  */
-                                                          return 2556;
+                                                          return 2558;
                                                         }
                                                     }
                                                 }
@@ -812,7 +856,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx000xxxxxxxxxxxx0
                                                          st1b.  */
-                                                      return 2673;
+                                                      return 2677;
                                                     }
                                                   else
                                                     {
@@ -820,7 +864,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx100xxxxxxxxxxxx0
                                                          st1b.  */
-                                                      return 2674;
+                                                      return 2678;
                                                     }
                                                 }
                                               else
@@ -831,7 +875,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx010xxxxxxxxxxxx0
                                                          st1w.  */
-                                                      return 2697;
+                                                      return 2701;
                                                     }
                                                   else
                                                     {
@@ -839,7 +883,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx110xxxxxxxxxxxx0
                                                          st1w.  */
-                                                      return 2698;
+                                                      return 2702;
                                                     }
                                                 }
                                             }
@@ -853,7 +897,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx001xxxxxxxxxxxx0
                                                          st1h.  */
-                                                      return 2689;
+                                                      return 2693;
                                                     }
                                                   else
                                                     {
@@ -861,7 +905,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx101xxxxxxxxxxxx0
                                                          st1h.  */
-                                                      return 2690;
+                                                      return 2694;
                                                     }
                                                 }
                                               else
@@ -872,7 +916,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx011xxxxxxxxxxxx0
                                                          st1d.  */
-                                                      return 2681;
+                                                      return 2685;
                                                     }
                                                   else
                                                     {
@@ -880,7 +924,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx111xxxxxxxxxxxx0
                                                          st1d.  */
-                                                      return 2682;
+                                                      return 2686;
                                                     }
                                                 }
                                             }
@@ -897,7 +941,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx000xxxxxxxxxxxx1
                                                          stnt1b.  */
-                                                      return 2705;
+                                                      return 2709;
                                                     }
                                                   else
                                                     {
@@ -905,7 +949,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx100xxxxxxxxxxxx1
                                                          stnt1b.  */
-                                                      return 2706;
+                                                      return 2710;
                                                     }
                                                 }
                                               else
@@ -916,7 +960,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx010xxxxxxxxxxxx1
                                                          stnt1w.  */
-                                                      return 2729;
+                                                      return 2733;
                                                     }
                                                   else
                                                     {
@@ -924,7 +968,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx110xxxxxxxxxxxx1
                                                          stnt1w.  */
-                                                      return 2730;
+                                                      return 2734;
                                                     }
                                                 }
                                             }
@@ -938,7 +982,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx001xxxxxxxxxxxx1
                                                          stnt1h.  */
-                                                      return 2721;
+                                                      return 2725;
                                                     }
                                                   else
                                                     {
@@ -946,7 +990,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx101xxxxxxxxxxxx1
                                                          stnt1h.  */
-                                                      return 2722;
+                                                      return 2726;
                                                     }
                                                 }
                                               else
@@ -957,7 +1001,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx011xxxxxxxxxxxx1
                                                          stnt1d.  */
-                                                      return 2713;
+                                                      return 2717;
                                                     }
                                                   else
                                                     {
@@ -965,7 +1009,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000001xxxxx111xxxxxxxxxxxx1
                                                          stnt1d.  */
-                                                      return 2714;
+                                                      return 2718;
                                                     }
                                                 }
                                             }
@@ -1029,7 +1073,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx000xxxxxxxxxxxx0
                                                          st1b.  */
-                                                      return 2669;
+                                                      return 2673;
                                                     }
                                                   else
                                                     {
@@ -1037,7 +1081,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx100xxxxxxxxxxxx0
                                                          st1b.  */
-                                                      return 2670;
+                                                      return 2674;
                                                     }
                                                 }
                                               else
@@ -1048,7 +1092,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx010xxxxxxxxxxxx0
                                                          st1w.  */
-                                                      return 2693;
+                                                      return 2697;
                                                     }
                                                   else
                                                     {
@@ -1056,7 +1100,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx110xxxxxxxxxxxx0
                                                          st1w.  */
-                                                      return 2694;
+                                                      return 2698;
                                                     }
                                                 }
                                             }
@@ -1070,7 +1114,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx001xxxxxxxxxxxx0
                                                          st1h.  */
-                                                      return 2685;
+                                                      return 2689;
                                                     }
                                                   else
                                                     {
@@ -1078,7 +1122,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx101xxxxxxxxxxxx0
                                                          st1h.  */
-                                                      return 2686;
+                                                      return 2690;
                                                     }
                                                 }
                                               else
@@ -1089,7 +1133,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx011xxxxxxxxxxxx0
                                                          st1d.  */
-                                                      return 2677;
+                                                      return 2681;
                                                     }
                                                   else
                                                     {
@@ -1097,7 +1141,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx111xxxxxxxxxxxx0
                                                          st1d.  */
-                                                      return 2678;
+                                                      return 2682;
                                                     }
                                                 }
                                             }
@@ -1114,7 +1158,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx000xxxxxxxxxxxx1
                                                          stnt1b.  */
-                                                      return 2701;
+                                                      return 2705;
                                                     }
                                                   else
                                                     {
@@ -1122,7 +1166,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx100xxxxxxxxxxxx1
                                                          stnt1b.  */
-                                                      return 2702;
+                                                      return 2706;
                                                     }
                                                 }
                                               else
@@ -1133,7 +1177,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx010xxxxxxxxxxxx1
                                                          stnt1w.  */
-                                                      return 2725;
+                                                      return 2729;
                                                     }
                                                   else
                                                     {
@@ -1141,7 +1185,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx110xxxxxxxxxxxx1
                                                          stnt1w.  */
-                                                      return 2726;
+                                                      return 2730;
                                                     }
                                                 }
                                             }
@@ -1155,7 +1199,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx001xxxxxxxxxxxx1
                                                          stnt1h.  */
-                                                      return 2717;
+                                                      return 2721;
                                                     }
                                                   else
                                                     {
@@ -1163,7 +1207,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx101xxxxxxxxxxxx1
                                                          stnt1h.  */
-                                                      return 2718;
+                                                      return 2722;
                                                     }
                                                 }
                                               else
@@ -1174,7 +1218,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx011xxxxxxxxxxxx1
                                                          stnt1d.  */
-                                                      return 2709;
+                                                      return 2713;
                                                     }
                                                   else
                                                     {
@@ -1182,7 +1226,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x0x00000011xxxxx111xxxxxxxxxxxx1
                                                          stnt1d.  */
-                                                      return 2710;
+                                                      return 2714;
                                                     }
                                                 }
                                             }
@@ -1274,7 +1318,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010000xxxxxxxxxxxxxxx000xx
                                                          smlall.  */
-                                                      return 2637;
+                                                      return 2639;
                                                     }
                                                   else
                                                     {
@@ -1282,7 +1326,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010000xxxxxxxxxxxxxxx001xx
                                                          usmlall.  */
-                                                      return 2814;
+                                                      return 2820;
                                                     }
                                                 }
                                               else
@@ -1295,7 +1339,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx0xxxxxxxxx000xxx
                                                              smlall.  */
-                                                          return 2638;
+                                                          return 2640;
                                                         }
                                                       else
                                                         {
@@ -1303,7 +1347,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx1xxxxxxxxx000xxx
                                                              smlall.  */
-                                                          return 2639;
+                                                          return 2641;
                                                         }
                                                     }
                                                   else
@@ -1314,7 +1358,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx0xxxxxxxxx100xxx
                                                              usmlall.  */
-                                                          return 2815;
+                                                          return 2821;
                                                         }
                                                       else
                                                         {
@@ -1322,7 +1366,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx1xxxxxxxxx100xxx
                                                              usmlall.  */
-                                                          return 2816;
+                                                          return 2822;
                                                         }
                                                     }
                                                 }
@@ -1337,7 +1381,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010000xxxxxxxxxxxxxxx100xx
                                                          umlall.  */
-                                                      return 2780;
+                                                      return 2784;
                                                     }
                                                   else
                                                     {
@@ -1345,7 +1389,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010000xxxxxxxxxxxxxxx101xx
                                                          sumlall.  */
-                                                      return 2744;
+                                                      return 2748;
                                                     }
                                                 }
                                               else
@@ -1358,7 +1402,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx0xxxxxxxxx010xxx
                                                              umlall.  */
-                                                          return 2781;
+                                                          return 2785;
                                                         }
                                                       else
                                                         {
@@ -1366,7 +1410,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx1xxxxxxxxx010xxx
                                                              umlall.  */
-                                                          return 2782;
+                                                          return 2786;
                                                         }
                                                     }
                                                   else
@@ -1377,7 +1421,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx0xxxxxxxxx110xxx
                                                              sumlall.  */
-                                                          return 2745;
+                                                          return 2749;
                                                         }
                                                       else
                                                         {
@@ -1385,7 +1429,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000010001xxxx1xxxxxxxxx110xxx
                                                              sumlall.  */
-                                                          return 2746;
+                                                          return 2750;
                                                         }
                                                     }
                                                 }
@@ -1401,7 +1445,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx0000010000xxxxxxxxxxxxxxx01xxx
                                                      smlsll.  */
-                                                  return 2653;
+                                                  return 2655;
                                                 }
                                               else
                                                 {
@@ -1411,7 +1455,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010001xxxx0xxxxxxxxxx01xxx
                                                          smlsll.  */
-                                                      return 2654;
+                                                      return 2656;
                                                     }
                                                   else
                                                     {
@@ -1419,7 +1463,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010001xxxx1xxxxxxxxxx01xxx
                                                          smlsll.  */
-                                                      return 2655;
+                                                      return 2657;
                                                     }
                                                 }
                                             }
@@ -1431,7 +1475,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx0000010000xxxxxxxxxxxxxxx11xxx
                                                      umlsll.  */
-                                                  return 2796;
+                                                  return 2800;
                                                 }
                                               else
                                                 {
@@ -1441,7 +1485,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010001xxxx0xxxxxxxxxx11xxx
                                                          umlsll.  */
-                                                      return 2797;
+                                                      return 2801;
                                                     }
                                                   else
                                                     {
@@ -1449,7 +1493,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000010001xxxx1xxxxxxxxxx11xxx
                                                          umlsll.  */
-                                                      return 2798;
+                                                      return 2802;
                                                     }
                                                 }
                                             }
@@ -1471,7 +1515,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx000xxxxxxxxx0xxx
                                                              ld1b.  */
-                                                          return 2521;
+                                                          return 2523;
                                                         }
                                                       else
                                                         {
@@ -1479,7 +1523,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx010xxxxxxxxx0xxx
                                                              ld1w.  */
-                                                          return 2545;
+                                                          return 2547;
                                                         }
                                                     }
                                                   else
@@ -1490,7 +1534,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx001xxxxxxxxx0xxx
                                                              ld1h.  */
-                                                          return 2537;
+                                                          return 2539;
                                                         }
                                                       else
                                                         {
@@ -1498,7 +1542,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx011xxxxxxxxx0xxx
                                                              ld1d.  */
-                                                          return 2529;
+                                                          return 2531;
                                                         }
                                                     }
                                                 }
@@ -1512,7 +1556,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx000xxxxxxxxx1xxx
                                                              ldnt1b.  */
-                                                          return 2553;
+                                                          return 2555;
                                                         }
                                                       else
                                                         {
@@ -1520,7 +1564,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx010xxxxxxxxx1xxx
                                                              ldnt1w.  */
-                                                          return 2577;
+                                                          return 2579;
                                                         }
                                                     }
                                                   else
@@ -1531,7 +1575,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx001xxxxxxxxx1xxx
                                                              ldnt1h.  */
-                                                          return 2569;
+                                                          return 2571;
                                                         }
                                                       else
                                                         {
@@ -1539,7 +1583,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx011xxxxxxxxx1xxx
                                                              ldnt1d.  */
-                                                          return 2561;
+                                                          return 2563;
                                                         }
                                                     }
                                                 }
@@ -1567,7 +1611,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001000xxxxx100xxxxxxxxx0xxx
                                                              ld1b.  */
-                                                          return 2522;
+                                                          return 2524;
                                                         }
                                                       else
                                                         {
@@ -1575,7 +1619,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1100001000xxxxx100xxxxxxxxx0xxx
                                                              ldr.  */
-                                                          return 2579;
+                                                          return 2581;
                                                         }
                                                     }
                                                   else
@@ -1584,7 +1628,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001000xxxxx110xxxxxxxxx0xxx
                                                          ld1w.  */
-                                                      return 2546;
+                                                      return 2548;
                                                     }
                                                 }
                                               else
@@ -1595,7 +1639,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001000xxxxx101xxxxxxxxx0xxx
                                                          ld1h.  */
-                                                      return 2538;
+                                                      return 2540;
                                                     }
                                                   else
                                                     {
@@ -1603,7 +1647,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001000xxxxx111xxxxxxxxx0xxx
                                                          ld1d.  */
-                                                      return 2530;
+                                                      return 2532;
                                                     }
                                                 }
                                             }
@@ -1617,7 +1661,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001000xxxxx100xxxxxxxxx1xxx
                                                          ldnt1b.  */
-                                                      return 2554;
+                                                      return 2556;
                                                     }
                                                   else
                                                     {
@@ -1625,7 +1669,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001000xxxxx110xxxxxxxxx1xxx
                                                          ldnt1w.  */
-                                                      return 2578;
+                                                      return 2580;
                                                     }
                                                 }
                                               else
@@ -1636,7 +1680,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001000xxxxx101xxxxxxxxx1xxx
                                                          ldnt1h.  */
-                                                      return 2570;
+                                                      return 2572;
                                                     }
                                                   else
                                                     {
@@ -1644,7 +1688,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001000xxxxx111xxxxxxxxx1xxx
                                                          ldnt1d.  */
-                                                      return 2562;
+                                                      return 2564;
                                                     }
                                                 }
                                             }
@@ -1677,7 +1721,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x10000011000xxxxxxx0xxxxxxx00xxx
                                                              smlall.  */
-                                                          return 2836;
+                                                          return 2842;
                                                         }
                                                       else
                                                         {
@@ -1687,7 +1731,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011001xxxx0xx0xxxxxxx00xxx
                                                                  smlall.  */
-                                                              return 2837;
+                                                              return 2843;
                                                             }
                                                           else
                                                             {
@@ -1695,7 +1739,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011001xxxx1xx0xxxxxxx00xxx
                                                                  smlall.  */
-                                                              return 2838;
+                                                              return 2844;
                                                             }
                                                         }
                                                     }
@@ -1707,7 +1751,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x10000011000xxxxxxx1xxxxxxx00xxx
                                                              fmlal.  */
-                                                          return 2490;
+                                                          return 2492;
                                                         }
                                                       else
                                                         {
@@ -1717,7 +1761,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011001xxxx0xx1xxxxxxx00xxx
                                                                  fmlal.  */
-                                                              return 2491;
+                                                              return 2493;
                                                             }
                                                           else
                                                             {
@@ -1725,7 +1769,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011001xxxx1xx1xxxxxxx00xxx
                                                                  fmlal.  */
-                                                              return 2492;
+                                                              return 2494;
                                                             }
                                                         }
                                                     }
@@ -1762,7 +1806,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x10000011000xxxxxxx0xxxxxxx10xxx
                                                              umlall.  */
-                                                          return 2845;
+                                                          return 2851;
                                                         }
                                                       else
                                                         {
@@ -1772,7 +1816,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011001xxxx0xx0xxxxxxx10xxx
                                                                  umlall.  */
-                                                              return 2846;
+                                                              return 2852;
                                                             }
                                                           else
                                                             {
@@ -1780,7 +1824,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011001xxxx1xx0xxxxxxx10xxx
                                                                  umlall.  */
-                                                              return 2847;
+                                                              return 2853;
                                                             }
                                                         }
                                                     }
@@ -1830,129 +1874,151 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                     {
                                       if (((word >> 4) & 0x1) == 0)
                                         {
-                                          if (((word >> 12) & 0x1) == 0)
+                                          if (((word >> 29) & 0x1) == 0)
                                             {
-                                              if (((word >> 20) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxx000011000xxxxxxx0xxxxxxx01xxx
-                                                     smlsll.  */
-                                                  return 2839;
-                                                }
-                                              else
+                                              if (((word >> 12) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 15) & 0x1) == 0)
+                                                  if (((word >> 20) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxx000011001xxxx0xx0xxxxxxx01xxx
+                                                         xx0000011000xxxxxxx0xxxxxxx01xxx
                                                          smlsll.  */
-                                                      return 2840;
+                                                      return 2845;
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxx000011001xxxx1xx0xxxxxxx01xxx
-                                                         smlsll.  */
-                                                      return 2841;
+                                                      if (((word >> 15) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx0xx0xxxxxxx01xxx
+                                                             smlsll.  */
+                                                          return 2846;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx1xx0xxxxxxx01xxx
+                                                             smlsll.  */
+                                                          return 2847;
+                                                        }
                                                     }
                                                 }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 20) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxx000011000xxxxxxx1xxxxxxx01xxx
-                                                     fmlsl.  */
-                                                  return 2504;
-                                                }
                                               else
                                                 {
-                                                  if (((word >> 15) & 0x1) == 0)
+                                                  if (((word >> 20) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxx000011001xxxx0xx1xxxxxxx01xxx
+                                                         xx0000011000xxxxxxx1xxxxxxx01xxx
                                                          fmlsl.  */
-                                                      return 2505;
+                                                      return 2506;
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxx000011001xxxx1xx1xxxxxxx01xxx
-                                                         fmlsl.  */
-                                                      return 2506;
+                                                      if (((word >> 15) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx0xx1xxxxxxx01xxx
+                                                             fmlsl.  */
+                                                          return 2507;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx1xx1xxxxxxx01xxx
+                                                             fmlsl.  */
+                                                          return 2508;
+                                                        }
                                                     }
                                                 }
                                             }
+                                          else
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xx100001100xxxxxxxxxxxxxxxx01xxx
+                                                 umopa.  */
+                                              return 2808;
+                                            }
                                         }
                                       else
                                         {
-                                          if (((word >> 12) & 0x1) == 0)
+                                          if (((word >> 29) & 0x1) == 0)
                                             {
-                                              if (((word >> 20) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxx000011000xxxxxxx0xxxxxxx11xxx
-                                                     umlsll.  */
-                                                  return 2848;
-                                                }
-                                              else
+                                              if (((word >> 12) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 15) & 0x1) == 0)
+                                                  if (((word >> 20) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxx000011001xxxx0xx0xxxxxxx11xxx
+                                                         xx0000011000xxxxxxx0xxxxxxx11xxx
                                                          umlsll.  */
-                                                      return 2849;
+                                                      return 2854;
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxx000011001xxxx1xx0xxxxxxx11xxx
-                                                         umlsll.  */
-                                                      return 2850;
+                                                      if (((word >> 15) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx0xx0xxxxxxx11xxx
+                                                             umlsll.  */
+                                                          return 2855;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx1xx0xxxxxxx11xxx
+                                                             umlsll.  */
+                                                          return 2856;
+                                                        }
                                                     }
                                                 }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 20) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxx000011000xxxxxxx1xxxxxxx11xxx
-                                                     bfmlsl.  */
-                                                  return 2450;
-                                                }
                                               else
                                                 {
-                                                  if (((word >> 15) & 0x1) == 0)
+                                                  if (((word >> 20) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxx000011001xxxx0xx1xxxxxxx11xxx
+                                                         xx0000011000xxxxxxx1xxxxxxx11xxx
                                                          bfmlsl.  */
-                                                      return 2451;
+                                                      return 2450;
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxx000011001xxxx1xx1xxxxxxx11xxx
-                                                         bfmlsl.  */
-                                                      return 2452;
+                                                      if (((word >> 15) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx0xx1xxxxxxx11xxx
+                                                             bfmlsl.  */
+                                                          return 2451;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xx0000011001xxxx1xx1xxxxxxx11xxx
+                                                             bfmlsl.  */
+                                                          return 2452;
+                                                        }
                                                     }
                                                 }
                                             }
+                                          else
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xx100001100xxxxxxxxxxxxxxxx11xxx
+                                                 umops.  */
+                                              return 2809;
+                                            }
                                         }
                                     }
                                 }
@@ -1975,7 +2041,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx000xxxxxxxxx0xxx
                                                          ld1b.  */
-                                                      return 2517;
+                                                      return 2519;
                                                     }
                                                   else
                                                     {
@@ -1983,7 +2049,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx010xxxxxxxxx0xxx
                                                          ld1w.  */
-                                                      return 2541;
+                                                      return 2543;
                                                     }
                                                 }
                                               else
@@ -1994,7 +2060,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx001xxxxxxxxx0xxx
                                                          ld1h.  */
-                                                      return 2533;
+                                                      return 2535;
                                                     }
                                                   else
                                                     {
@@ -2002,7 +2068,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx011xxxxxxxxx0xxx
                                                          ld1d.  */
-                                                      return 2525;
+                                                      return 2527;
                                                     }
                                                 }
                                             }
@@ -2018,7 +2084,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx0xxxxxx000xxx
                                                              fmla.  */
-                                                          return 2484;
+                                                          return 2486;
                                                         }
                                                       else
                                                         {
@@ -2026,7 +2092,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx1xxxxxx000xxx
                                                              sdot.  */
-                                                          return 2607;
+                                                          return 2609;
                                                         }
                                                     }
                                                   else
@@ -2037,7 +2103,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx0xxxxxx100xxx
                                                              svdot.  */
-                                                          return 2750;
+                                                          return 2754;
                                                         }
                                                       else
                                                         {
@@ -2045,7 +2111,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx1xxxxxx100xxx
                                                              sdot.  */
-                                                          return 2613;
+                                                          return 2615;
                                                         }
                                                     }
                                                 }
@@ -2059,7 +2125,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx0xxxxxx010xxx
                                                              fmls.  */
-                                                          return 2498;
+                                                          return 2500;
                                                         }
                                                       else
                                                         {
@@ -2067,7 +2133,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx1xxxxxx010xxx
                                                              udot.  */
-                                                          return 2752;
+                                                          return 2756;
                                                         }
                                                     }
                                                   else
@@ -2078,7 +2144,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx0xxxxxx110xxx
                                                              uvdot.  */
-                                                          return 2823;
+                                                          return 2829;
                                                         }
                                                       else
                                                         {
@@ -2086,7 +2152,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx1xxxxxx110xxx
                                                              udot.  */
-                                                          return 2758;
+                                                          return 2762;
                                                         }
                                                     }
                                                 }
@@ -2104,7 +2170,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx100xxxxxxxxx0xxx
                                                          ld1b.  */
-                                                      return 2518;
+                                                      return 2520;
                                                     }
                                                   else
                                                     {
@@ -2112,7 +2178,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx110xxxxxxxxx0xxx
                                                          ld1w.  */
-                                                      return 2542;
+                                                      return 2544;
                                                     }
                                                 }
                                               else
@@ -2123,7 +2189,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx101xxxxxxxxx0xxx
                                                          ld1h.  */
-                                                      return 2534;
+                                                      return 2536;
                                                     }
                                                   else
                                                     {
@@ -2131,7 +2197,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx111xxxxxxxxx0xxx
                                                          ld1d.  */
-                                                      return 2526;
+                                                      return 2528;
                                                     }
                                                 }
                                             }
@@ -2147,7 +2213,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx0xxxxxx000xxx
                                                              fmla.  */
-                                                          return 2485;
+                                                          return 2487;
                                                         }
                                                       else
                                                         {
@@ -2155,7 +2221,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx1xxxxxx000xxx
                                                              sdot.  */
-                                                          return 2608;
+                                                          return 2610;
                                                         }
                                                     }
                                                   else
@@ -2166,7 +2232,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx0xxxxxx100xxx
                                                              svdot.  */
-                                                          return 2751;
+                                                          return 2755;
                                                         }
                                                       else
                                                         {
@@ -2174,7 +2240,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx1xxxxxx100xxx
                                                              sdot.  */
-                                                          return 2614;
+                                                          return 2616;
                                                         }
                                                     }
                                                 }
@@ -2188,7 +2254,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx0xxxxxx010xxx
                                                              fmls.  */
-                                                          return 2499;
+                                                          return 2501;
                                                         }
                                                       else
                                                         {
@@ -2196,7 +2262,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx1xxxxxx010xxx
                                                              udot.  */
-                                                          return 2753;
+                                                          return 2757;
                                                         }
                                                     }
                                                   else
@@ -2207,7 +2273,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx0xxxxxx110xxx
                                                              uvdot.  */
-                                                          return 2824;
+                                                          return 2830;
                                                         }
                                                       else
                                                         {
@@ -2215,7 +2281,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx1xxxxxx110xxx
                                                              udot.  */
-                                                          return 2759;
+                                                          return 2763;
                                                         }
                                                     }
                                                 }
@@ -2236,7 +2302,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx000xxxxxxxxx1xxx
                                                          ldnt1b.  */
-                                                      return 2549;
+                                                      return 2551;
                                                     }
                                                   else
                                                     {
@@ -2244,7 +2310,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx010xxxxxxxxx1xxx
                                                          ldnt1w.  */
-                                                      return 2573;
+                                                      return 2575;
                                                     }
                                                 }
                                               else
@@ -2255,7 +2321,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx001xxxxxxxxx1xxx
                                                          ldnt1h.  */
-                                                      return 2565;
+                                                      return 2567;
                                                     }
                                                   else
                                                     {
@@ -2263,7 +2329,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx011xxxxxxxxx1xxx
                                                          ldnt1d.  */
-                                                      return 2557;
+                                                      return 2559;
                                                     }
                                                 }
                                             }
@@ -2279,7 +2345,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx0xxxxxx001xxx
                                                              fvdot.  */
-                                                          return 2514;
+                                                          return 2516;
                                                         }
                                                       else
                                                         {
@@ -2287,7 +2353,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx0xx1xxxxxx001xxx
                                                              fdot.  */
-                                                          return 2462;
+                                                          return 2464;
                                                         }
                                                     }
                                                   else
@@ -2296,7 +2362,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010101xxxx0xxxxxxxxx101xxx
                                                          usdot.  */
-                                                      return 2808;
+                                                      return 2814;
                                                     }
                                                 }
                                               else
@@ -2326,7 +2392,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010101xxxx0xxxxxxxxx111xxx
                                                          sudot.  */
-                                                      return 2740;
+                                                      return 2744;
                                                     }
                                                 }
                                             }
@@ -2343,7 +2409,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx100xxxxxxxxx1xxx
                                                          ldnt1b.  */
-                                                      return 2550;
+                                                      return 2552;
                                                     }
                                                   else
                                                     {
@@ -2351,7 +2417,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx110xxxxxxxxx1xxx
                                                          ldnt1w.  */
-                                                      return 2574;
+                                                      return 2576;
                                                     }
                                                 }
                                               else
@@ -2362,7 +2428,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx101xxxxxxxxx1xxx
                                                          ldnt1h.  */
-                                                      return 2566;
+                                                      return 2568;
                                                     }
                                                   else
                                                     {
@@ -2370,7 +2436,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010100xxxx111xxxxxxxxx1xxx
                                                          ldnt1d.  */
-                                                      return 2558;
+                                                      return 2560;
                                                     }
                                                 }
                                             }
@@ -2384,7 +2450,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000010101xxxx1xxxxxxxxx001xxx
                                                          fdot.  */
-                                                      return 2463;
+                                                      return 2465;
                                                     }
                                                   else
                                                     {
@@ -2394,7 +2460,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx0xxxxxx101xxx
                                                              usvdot.  */
-                                                          return 2822;
+                                                          return 2828;
                                                         }
                                                       else
                                                         {
@@ -2402,7 +2468,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx1xxxxxx101xxx
                                                              usdot.  */
-                                                          return 2809;
+                                                          return 2815;
                                                         }
                                                     }
                                                 }
@@ -2424,7 +2490,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx0xxxxxx111xxx
                                                              suvdot.  */
-                                                          return 2749;
+                                                          return 2753;
                                                         }
                                                       else
                                                         {
@@ -2432,7 +2498,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx000010101xxxx1xx1xxxxxx111xxx
                                                              sudot.  */
-                                                          return 2741;
+                                                          return 2745;
                                                         }
                                                     }
                                                 }
@@ -2456,7 +2522,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx000001110xxxxx0xx0xxxxxxx00xxx
                                                          fmla.  */
-                                                      return 2852;
+                                                      return 2858;
                                                     }
                                                   else
                                                     {
@@ -2464,7 +2530,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx000001110xxxxx1xx0xxxxxxx00xxx
                                                          fmla.  */
-                                                      return 2853;
+                                                      return 2859;
                                                     }
                                                 }
                                               else
@@ -2475,7 +2541,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000011100xxxxxxx1xxxxxxx00xxx
                                                          smlal.  */
-                                                      return 2629;
+                                                      return 2631;
                                                     }
                                                   else
                                                     {
@@ -2485,7 +2551,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000011101xxxx0xx1xxxxxxx00xxx
                                                              smlal.  */
-                                                          return 2630;
+                                                          return 2632;
                                                         }
                                                       else
                                                         {
@@ -2493,7 +2559,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000011101xxxx1xx1xxxxxxx00xxx
                                                              smlal.  */
-                                                          return 2631;
+                                                          return 2633;
                                                         }
                                                     }
                                                 }
@@ -2510,7 +2576,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx000001110xxxxx0xx00xxxxxx01xxx
                                                              sdot.  */
-                                                          return 2834;
+                                                          return 2840;
                                                         }
                                                       else
                                                         {
@@ -2518,7 +2584,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx000001110xxxxx1xx00xxxxxx01xxx
                                                              sdot.  */
-                                                          return 2835;
+                                                          return 2841;
                                                         }
                                                     }
                                                   else
@@ -2527,7 +2593,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx000001110xxxxxxxx01xxxxxx01xxx
                                                          svdot.  */
-                                                      return 2842;
+                                                      return 2848;
                                                     }
                                                 }
                                               else
@@ -2538,7 +2604,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000011100xxxxxxx1xxxxxxx01xxx
                                                          smlsl.  */
-                                                      return 2645;
+                                                      return 2647;
                                                     }
                                                   else
                                                     {
@@ -2548,7 +2614,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000011101xxxx0xx1xxxxxxx01xxx
                                                              smlsl.  */
-                                                          return 2646;
+                                                          return 2648;
                                                         }
                                                       else
                                                         {
@@ -2556,7 +2622,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000011101xxxx1xx1xxxxxxx01xxx
                                                              smlsl.  */
-                                                          return 2647;
+                                                          return 2649;
                                                         }
                                                     }
                                                 }
@@ -2596,7 +2662,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx000001110xxxxx0xx0xxxxxxx10xxx
                                                          fmls.  */
-                                                      return 2854;
+                                                      return 2860;
                                                     }
                                                   else
                                                     {
@@ -2604,7 +2670,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx000001110xxxxx1xx0xxxxxxx10xxx
                                                          fmls.  */
-                                                      return 2855;
+                                                      return 2861;
                                                     }
                                                 }
                                               else
@@ -2615,7 +2681,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0000011100xxxxxxx1xxxxxxx10xxx
                                                          umlal.  */
-                                                      return 2772;
+                                                      return 2776;
                                                     }
                                                   else
                                                     {
@@ -2625,7 +2691,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000011101xxxx0xx1xxxxxxx10xxx
                                                              umlal.  */
-                                                          return 2773;
+                                                          return 2777;
                                                         }
                                                       else
                                                         {
@@ -2633,7 +2699,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx0000011101xxxx1xx1xxxxxxx10xxx
                                                              umlal.  */
-                                                          return 2774;
+                                                          return 2778;
                                                         }
                                                     }
                                                 }
@@ -2659,7 +2725,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx00001110xxxxx0xx00xxxxxx11xxx
                                                          udot.  */
-                                                      return 2843;
+                                                      return 2849;
                                                     }
                                                   else
                                                     {
@@ -2667,7 +2733,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx00001110xxxxx1xx00xxxxxx11xxx
                                                          udot.  */
-                                                      return 2844;
+                                                      return 2850;
                                                     }
                                                 }
                                               else
@@ -2676,7 +2742,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxx00001110xxxxxxxx01xxxxxx11xxx
                                                      uvdot.  */
-                                                  return 2851;
+                                                  return 2857;
                                                 }
                                             }
                                           else
@@ -2687,7 +2753,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxx000011100xxxxxxx1xxxxxxx11xxx
                                                      umlsl.  */
-                                                  return 2788;
+                                                  return 2792;
                                                 }
                                               else
                                                 {
@@ -2697,7 +2763,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000011101xxxx0xx1xxxxxxx11xxx
                                                          umlsl.  */
-                                                      return 2789;
+                                                      return 2793;
                                                     }
                                                   else
                                                     {
@@ -2705,7 +2771,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx000011101xxxx1xx1xxxxxxx11xxx
                                                          umlsl.  */
-                                                      return 2790;
+                                                      return 2794;
                                                     }
                                                 }
                                             }
@@ -2761,7 +2827,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010x10xxxx0xx000xxxxx000xx
                                                                          smlall.  */
-                                                                      return 2641;
+                                                                      return 2643;
                                                                     }
                                                                   else
                                                                     {
@@ -2769,7 +2835,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010x11xxxx0xx000xxxxx000xx
                                                                          smlall.  */
-                                                                      return 2642;
+                                                                      return 2644;
                                                                     }
                                                                 }
                                                               else
@@ -2780,7 +2846,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000011x1xxxx00xx000xxxxx000xx
                                                                          smlall.  */
-                                                                      return 2643;
+                                                                      return 2645;
                                                                     }
                                                                   else
                                                                     {
@@ -2788,7 +2854,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000011x1xxxx10xx000xxxxx000xx
                                                                          smlall.  */
-                                                                      return 2644;
+                                                                      return 2646;
                                                                     }
                                                                 }
                                                             }
@@ -2802,7 +2868,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010x10xxxx0xx000xxxxx001xx
                                                                          usmlall.  */
-                                                                      return 2818;
+                                                                      return 2824;
                                                                     }
                                                                   else
                                                                     {
@@ -2810,7 +2876,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010x11xxxx0xx000xxxxx001xx
                                                                          usmlall.  */
-                                                                      return 2819;
+                                                                      return 2825;
                                                                     }
                                                                 }
                                                               else
@@ -2821,7 +2887,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000011x1xxxx00xx000xxxxx001xx
                                                                          usmlall.  */
-                                                                      return 2820;
+                                                                      return 2826;
                                                                     }
                                                                   else
                                                                     {
@@ -2829,7 +2895,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000011x1xxxx10xx000xxxxx001xx
                                                                          usmlall.  */
-                                                                      return 2821;
+                                                                      return 2827;
                                                                     }
                                                                 }
                                                             }
@@ -2844,7 +2910,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x10xxxx0xx100xxxxx00xxx
                                                                      fdot.  */
-                                                                  return 2464;
+                                                                  return 2466;
                                                                 }
                                                               else
                                                                 {
@@ -2852,7 +2918,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x11xxxx0xx100xxxxx00xxx
                                                                      fdot.  */
-                                                                  return 2465;
+                                                                  return 2467;
                                                                 }
                                                             }
                                                           else
@@ -2863,7 +2929,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx00xx100xxxxx00xxx
                                                                      fdot.  */
-                                                                  return 2466;
+                                                                  return 2468;
                                                                 }
                                                               else
                                                                 {
@@ -2871,7 +2937,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx10xx100xxxxx00xxx
                                                                      fdot.  */
-                                                                  return 2467;
+                                                                  return 2469;
                                                                 }
                                                             }
                                                         }
@@ -2890,7 +2956,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010010xxxx0xx010xxxxx00xxx
                                                                          fmlal.  */
-                                                                      return 2494;
+                                                                      return 2496;
                                                                     }
                                                                   else
                                                                     {
@@ -2898,7 +2964,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010011xxxx0xx010xxxxx00xxx
                                                                          fmlal.  */
-                                                                      return 2495;
+                                                                      return 2497;
                                                                     }
                                                                 }
                                                               else
@@ -2909,7 +2975,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001101xxxx00xx010xxxxx00xxx
                                                                          fmlal.  */
-                                                                      return 2496;
+                                                                      return 2498;
                                                                     }
                                                                   else
                                                                     {
@@ -2917,7 +2983,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001101xxxx10xx010xxxxx00xxx
                                                                          fmlal.  */
-                                                                      return 2497;
+                                                                      return 2499;
                                                                     }
                                                                 }
                                                             }
@@ -2931,7 +2997,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010110xxxx0xx010xxxxx00xxx
                                                                          smlal.  */
-                                                                      return 2633;
+                                                                      return 2635;
                                                                     }
                                                                   else
                                                                     {
@@ -2939,7 +3005,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010111xxxx0xx010xxxxx00xxx
                                                                          smlal.  */
-                                                                      return 2634;
+                                                                      return 2636;
                                                                     }
                                                                 }
                                                               else
@@ -2950,7 +3016,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx00xx010xxxxx00xxx
                                                                          smlal.  */
-                                                                      return 2635;
+                                                                      return 2637;
                                                                     }
                                                                   else
                                                                     {
@@ -2958,7 +3024,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx10xx010xxxxx00xxx
                                                                          smlal.  */
-                                                                      return 2636;
+                                                                      return 2638;
                                                                     }
                                                                 }
                                                             }
@@ -2973,7 +3039,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x10xxxx0xx110xxxxx00xxx
                                                                      fmla.  */
-                                                                  return 2486;
+                                                                  return 2488;
                                                                 }
                                                               else
                                                                 {
@@ -2981,7 +3047,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x11xxxx0xx110xxxxx00xxx
                                                                      fmla.  */
-                                                                  return 2487;
+                                                                  return 2489;
                                                                 }
                                                             }
                                                           else
@@ -2992,7 +3058,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx00xx110xxxxx00xxx
                                                                      fmla.  */
-                                                                  return 2488;
+                                                                  return 2490;
                                                                 }
                                                               else
                                                                 {
@@ -3000,7 +3066,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx10xx110xxxxx00xxx
                                                                      fmla.  */
-                                                                  return 2489;
+                                                                  return 2491;
                                                                 }
                                                             }
                                                         }
@@ -3018,7 +3084,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx0xx001xxxxx000xx
                                                                  smlall.  */
-                                                              return 2640;
+                                                              return 2642;
                                                             }
                                                           else
                                                             {
@@ -3026,7 +3092,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx0xx001xxxxx001xx
                                                                  usmlall.  */
-                                                              return 2817;
+                                                              return 2823;
                                                             }
                                                         }
                                                       else
@@ -3039,7 +3105,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x10xxxx0xx101xxxxx00xxx
                                                                      sdot.  */
-                                                                  return 2615;
+                                                                  return 2617;
                                                                 }
                                                               else
                                                                 {
@@ -3047,7 +3113,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x11xxxx0xx101xxxxx00xxx
                                                                      sdot.  */
-                                                                  return 2616;
+                                                                  return 2618;
                                                                 }
                                                             }
                                                           else
@@ -3058,7 +3124,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx00xx101xxxxx00xxx
                                                                      sdot.  */
-                                                                  return 2617;
+                                                                  return 2619;
                                                                 }
                                                               else
                                                                 {
@@ -3066,7 +3132,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx10xx101xxxxx00xxx
                                                                      sdot.  */
-                                                                  return 2618;
+                                                                  return 2620;
                                                                 }
                                                             }
                                                         }
@@ -3081,7 +3147,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001x01xxxxx0xx011xxxxx00xxx
                                                                  fmlal.  */
-                                                              return 2493;
+                                                              return 2495;
                                                             }
                                                           else
                                                             {
@@ -3089,7 +3155,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001x11xxxxx0xx011xxxxx00xxx
                                                                  smlal.  */
-                                                              return 2632;
+                                                              return 2634;
                                                             }
                                                         }
                                                       else
@@ -3100,7 +3166,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxx00xx111xxxxx00xxx
                                                                  fadd.  */
-                                                              return 2460;
+                                                              return 2462;
                                                             }
                                                           else
                                                             {
@@ -3108,7 +3174,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxx10xx111xxxxx00xxx
                                                                  fadd.  */
-                                                              return 2461;
+                                                              return 2463;
                                                             }
                                                         }
                                                     }
@@ -3132,7 +3198,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010x10xxxx0xx000xxxxx100xx
                                                                          umlall.  */
-                                                                      return 2784;
+                                                                      return 2788;
                                                                     }
                                                                   else
                                                                     {
@@ -3140,7 +3206,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010x11xxxx0xx000xxxxx100xx
                                                                          umlall.  */
-                                                                      return 2785;
+                                                                      return 2789;
                                                                     }
                                                                 }
                                                               else
@@ -3151,7 +3217,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000011x1xxxx00xx000xxxxx100xx
                                                                          umlall.  */
-                                                                      return 2786;
+                                                                      return 2790;
                                                                     }
                                                                   else
                                                                     {
@@ -3159,7 +3225,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000011x1xxxx10xx000xxxxx100xx
                                                                          umlall.  */
-                                                                      return 2787;
+                                                                      return 2791;
                                                                     }
                                                                 }
                                                             }
@@ -3171,7 +3237,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx10xxxx0xx000xxxxx101xx
                                                                      sumlall.  */
-                                                                  return 2747;
+                                                                  return 2751;
                                                                 }
                                                               else
                                                                 {
@@ -3179,7 +3245,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx11xxxx0xx000xxxxx101xx
                                                                      sumlall.  */
-                                                                  return 2748;
+                                                                  return 2752;
                                                                 }
                                                             }
                                                         }
@@ -3280,7 +3346,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010110xxxx0xx010xxxxx10xxx
                                                                          umlal.  */
-                                                                      return 2776;
+                                                                      return 2780;
                                                                     }
                                                                   else
                                                                     {
@@ -3288,7 +3354,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010111xxxx0xx010xxxxx10xxx
                                                                          umlal.  */
-                                                                      return 2777;
+                                                                      return 2781;
                                                                     }
                                                                 }
                                                               else
@@ -3299,7 +3365,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx00xx010xxxxx10xxx
                                                                          umlal.  */
-                                                                      return 2778;
+                                                                      return 2782;
                                                                     }
                                                                   else
                                                                     {
@@ -3307,7 +3373,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx10xx010xxxxx10xxx
                                                                          umlal.  */
-                                                                      return 2779;
+                                                                      return 2783;
                                                                     }
                                                                 }
                                                             }
@@ -3365,7 +3431,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx0xx001xxxxx10xxx
                                                              umlall.  */
-                                                          return 2783;
+                                                          return 2787;
                                                         }
                                                       else
                                                         {
@@ -3377,7 +3443,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x10xxxx0xx101xxxxx10xxx
                                                                      udot.  */
-                                                                  return 2760;
+                                                                  return 2764;
                                                                 }
                                                               else
                                                                 {
@@ -3385,7 +3451,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x11xxxx0xx101xxxxx10xxx
                                                                      udot.  */
-                                                                  return 2761;
+                                                                  return 2765;
                                                                 }
                                                             }
                                                           else
@@ -3396,7 +3462,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx00xx101xxxxx10xxx
                                                                      udot.  */
-                                                                  return 2762;
+                                                                  return 2766;
                                                                 }
                                                               else
                                                                 {
@@ -3404,7 +3470,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx10xx101xxxxx10xxx
                                                                      udot.  */
-                                                                  return 2763;
+                                                                  return 2767;
                                                                 }
                                                             }
                                                         }
@@ -3427,7 +3493,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001x11xxxxx0xx011xxxxx10xxx
                                                                  umlal.  */
-                                                              return 2775;
+                                                              return 2779;
                                                             }
                                                         }
                                                       else
@@ -3469,7 +3535,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000010x10xxxx0xxx00xxxxx01xxx
                                                                  smlsll.  */
-                                                              return 2657;
+                                                              return 2659;
                                                             }
                                                           else
                                                             {
@@ -3477,7 +3543,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000010x11xxxx0xxx00xxxxx01xxx
                                                                  smlsll.  */
-                                                              return 2658;
+                                                              return 2660;
                                                             }
                                                         }
                                                       else
@@ -3488,7 +3554,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011x1xxxx00xxx00xxxxx01xxx
                                                                  smlsll.  */
-                                                              return 2659;
+                                                              return 2661;
                                                             }
                                                           else
                                                             {
@@ -3496,7 +3562,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011x1xxxx10xxx00xxxxx01xxx
                                                                  smlsll.  */
-                                                              return 2660;
+                                                              return 2662;
                                                             }
                                                         }
                                                     }
@@ -3514,7 +3580,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010010xxxx0xx010xxxxx01xxx
                                                                          fmlsl.  */
-                                                                      return 2508;
+                                                                      return 2510;
                                                                     }
                                                                   else
                                                                     {
@@ -3522,7 +3588,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010011xxxx0xx010xxxxx01xxx
                                                                          fmlsl.  */
-                                                                      return 2509;
+                                                                      return 2511;
                                                                     }
                                                                 }
                                                               else
@@ -3533,7 +3599,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001101xxxx00xx010xxxxx01xxx
                                                                          fmlsl.  */
-                                                                      return 2510;
+                                                                      return 2512;
                                                                     }
                                                                   else
                                                                     {
@@ -3541,7 +3607,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001101xxxx10xx010xxxxx01xxx
                                                                          fmlsl.  */
-                                                                      return 2511;
+                                                                      return 2513;
                                                                     }
                                                                 }
                                                             }
@@ -3555,7 +3621,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010110xxxx0xx010xxxxx01xxx
                                                                          smlsl.  */
-                                                                      return 2649;
+                                                                      return 2651;
                                                                     }
                                                                   else
                                                                     {
@@ -3563,7 +3629,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010111xxxx0xx010xxxxx01xxx
                                                                          smlsl.  */
-                                                                      return 2650;
+                                                                      return 2652;
                                                                     }
                                                                 }
                                                               else
@@ -3574,7 +3640,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx00xx010xxxxx01xxx
                                                                          smlsl.  */
-                                                                      return 2651;
+                                                                      return 2653;
                                                                     }
                                                                   else
                                                                     {
@@ -3582,7 +3648,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx10xx010xxxxx01xxx
                                                                          smlsl.  */
-                                                                      return 2652;
+                                                                      return 2654;
                                                                     }
                                                                 }
                                                             }
@@ -3597,7 +3663,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x10xxxx0xx110xxxxx01xxx
                                                                      fmls.  */
-                                                                  return 2500;
+                                                                  return 2502;
                                                                 }
                                                               else
                                                                 {
@@ -3605,7 +3671,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x11xxxx0xx110xxxxx01xxx
                                                                      fmls.  */
-                                                                  return 2501;
+                                                                  return 2503;
                                                                 }
                                                             }
                                                           else
@@ -3616,7 +3682,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx00xx110xxxxx01xxx
                                                                      fmls.  */
-                                                                  return 2502;
+                                                                  return 2504;
                                                                 }
                                                               else
                                                                 {
@@ -3624,7 +3690,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx10xx110xxxxx01xxx
                                                                      fmls.  */
-                                                                  return 2503;
+                                                                  return 2505;
                                                                 }
                                                             }
                                                         }
@@ -3640,7 +3706,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx0xx001xxxxx01xxx
                                                              smlsll.  */
-                                                          return 2656;
+                                                          return 2658;
                                                         }
                                                       else
                                                         {
@@ -3654,7 +3720,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010010xxxx0xx101xxxxx01xxx
                                                                          usdot.  */
-                                                                      return 2810;
+                                                                      return 2816;
                                                                     }
                                                                   else
                                                                     {
@@ -3662,7 +3728,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010011xxxx0xx101xxxxx01xxx
                                                                          usdot.  */
-                                                                      return 2811;
+                                                                      return 2817;
                                                                     }
                                                                 }
                                                               else
@@ -3673,7 +3739,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001101xxxx00xx101xxxxx01xxx
                                                                          usdot.  */
-                                                                      return 2812;
+                                                                      return 2818;
                                                                     }
                                                                   else
                                                                     {
@@ -3681,7 +3747,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001101xxxx10xx101xxxxx01xxx
                                                                          usdot.  */
-                                                                      return 2813;
+                                                                      return 2819;
                                                                     }
                                                                 }
                                                             }
@@ -3695,7 +3761,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010110xxxx0xx101xxxxx01xxx
                                                                          sdot.  */
-                                                                      return 2609;
+                                                                      return 2611;
                                                                     }
                                                                   else
                                                                     {
@@ -3703,7 +3769,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010111xxxx0xx101xxxxx01xxx
                                                                          sdot.  */
-                                                                      return 2610;
+                                                                      return 2612;
                                                                     }
                                                                 }
                                                               else
@@ -3714,7 +3780,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx00xx101xxxxx01xxx
                                                                          sdot.  */
-                                                                      return 2611;
+                                                                      return 2613;
                                                                     }
                                                                   else
                                                                     {
@@ -3722,7 +3788,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx10xx101xxxxx01xxx
                                                                          sdot.  */
-                                                                      return 2612;
+                                                                      return 2614;
                                                                     }
                                                                 }
                                                             }
@@ -3738,7 +3804,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001x01xxxxx0xx011xxxxx01xxx
                                                                  fmlsl.  */
-                                                              return 2507;
+                                                              return 2509;
                                                             }
                                                           else
                                                             {
@@ -3746,7 +3812,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001x11xxxxx0xx011xxxxx01xxx
                                                                  smlsl.  */
-                                                              return 2648;
+                                                              return 2650;
                                                             }
                                                         }
                                                       else
@@ -3757,7 +3823,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxx00xx111xxxxx01xxx
                                                                  fsub.  */
-                                                              return 2512;
+                                                              return 2514;
                                                             }
                                                           else
                                                             {
@@ -3765,7 +3831,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxx10xx111xxxxx01xxx
                                                                  fsub.  */
-                                                              return 2513;
+                                                              return 2515;
                                                             }
                                                         }
                                                     }
@@ -3785,7 +3851,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000010x10xxxx0xxx00xxxxx11xxx
                                                                  umlsll.  */
-                                                              return 2800;
+                                                              return 2804;
                                                             }
                                                           else
                                                             {
@@ -3793,7 +3859,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000010x11xxxx0xxx00xxxxx11xxx
                                                                  umlsll.  */
-                                                              return 2801;
+                                                              return 2805;
                                                             }
                                                         }
                                                       else
@@ -3804,7 +3870,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011x1xxxx00xxx00xxxxx11xxx
                                                                  umlsll.  */
-                                                              return 2802;
+                                                              return 2806;
                                                             }
                                                           else
                                                             {
@@ -3812,7 +3878,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10000011x1xxxx10xxx00xxxxx11xxx
                                                                  umlsll.  */
-                                                              return 2803;
+                                                              return 2807;
                                                             }
                                                         }
                                                     }
@@ -3871,7 +3937,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010110xxxx0xx010xxxxx11xxx
                                                                          umlsl.  */
-                                                                      return 2792;
+                                                                      return 2796;
                                                                     }
                                                                   else
                                                                     {
@@ -3879,7 +3945,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010111xxxx0xx010xxxxx11xxx
                                                                          umlsl.  */
-                                                                      return 2793;
+                                                                      return 2797;
                                                                     }
                                                                 }
                                                               else
@@ -3890,7 +3956,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx00xx010xxxxx11xxx
                                                                          umlsl.  */
-                                                                      return 2794;
+                                                                      return 2798;
                                                                     }
                                                                   else
                                                                     {
@@ -3898,7 +3964,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx10xx010xxxxx11xxx
                                                                          umlsl.  */
-                                                                      return 2795;
+                                                                      return 2799;
                                                                     }
                                                                 }
                                                             }
@@ -3913,7 +3979,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x10xxxx0xx110xxxxx11xxx
                                                                      sub.  */
-                                                                  return 2736;
+                                                                  return 2740;
                                                                 }
                                                               else
                                                                 {
@@ -3921,7 +3987,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000010x11xxxx0xx110xxxxx11xxx
                                                                      sub.  */
-                                                                  return 2737;
+                                                                  return 2741;
                                                                 }
                                                             }
                                                           else
@@ -3932,7 +3998,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx00xx110xxxxx11xxx
                                                                      sub.  */
-                                                                  return 2738;
+                                                                  return 2742;
                                                                 }
                                                               else
                                                                 {
@@ -3940,7 +4006,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x10000011x1xxxx10xx110xxxxx11xxx
                                                                      sub.  */
-                                                                  return 2739;
+                                                                  return 2743;
                                                                 }
                                                             }
                                                         }
@@ -3956,7 +4022,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx0xx001xxxxx11xxx
                                                              umlsll.  */
-                                                          return 2799;
+                                                          return 2803;
                                                         }
                                                       else
                                                         {
@@ -3968,7 +4034,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001x010xxxx0xx101xxxxx11xxx
                                                                      sudot.  */
-                                                                  return 2742;
+                                                                  return 2746;
                                                                 }
                                                               else
                                                                 {
@@ -3976,7 +4042,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001x011xxxx0xx101xxxxx11xxx
                                                                      sudot.  */
-                                                                  return 2743;
+                                                                  return 2747;
                                                                 }
                                                             }
                                                           else
@@ -3989,7 +4055,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010110xxxx0xx101xxxxx11xxx
                                                                          udot.  */
-                                                                      return 2754;
+                                                                      return 2758;
                                                                     }
                                                                   else
                                                                     {
@@ -3997,7 +4063,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x10000010111xxxx0xx101xxxxx11xxx
                                                                          udot.  */
-                                                                      return 2755;
+                                                                      return 2759;
                                                                     }
                                                                 }
                                                               else
@@ -4008,7 +4074,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx00xx101xxxxx11xxx
                                                                          udot.  */
-                                                                      return 2756;
+                                                                      return 2760;
                                                                     }
                                                                   else
                                                                     {
@@ -4016,7 +4082,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          x1000001111xxxx10xx101xxxxx11xxx
                                                                          udot.  */
-                                                                      return 2757;
+                                                                      return 2761;
                                                                     }
                                                                 }
                                                             }
@@ -4040,7 +4106,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001x11xxxxx0xx011xxxxx11xxx
                                                                  umlsl.  */
-                                                              return 2791;
+                                                              return 2795;
                                                             }
                                                         }
                                                       else
@@ -4051,7 +4117,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxx00xx111xxxxx11xxx
                                                                  sub.  */
-                                                              return 2734;
+                                                              return 2738;
                                                             }
                                                           else
                                                             {
@@ -4059,7 +4125,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxx10xx111xxxxx11xxx
                                                                  sub.  */
-                                                              return 2735;
+                                                              return 2739;
                                                             }
                                                         }
                                                     }
@@ -4081,7 +4147,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x1000001xx1xxxx01x0xxxxxxx0xxxx0
                                                          sel.  */
-                                                      return 2619;
+                                                      return 2621;
                                                     }
                                                   else
                                                     {
@@ -4089,7 +4155,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          x1000001xx1xxxx11x0xxxxxxx0xxxx0
                                                          sel.  */
-                                                      return 2620;
+                                                      return 2622;
                                                     }
                                                 }
                                               else
@@ -4106,7 +4172,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1000x0xx0xxxx0
                                                                      smax.  */
-                                                                  return 2621;
+                                                                  return 2623;
                                                                 }
                                                               else
                                                                 {
@@ -4114,7 +4180,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1100x0xx0xxxx0
                                                                      smax.  */
-                                                                  return 2623;
+                                                                  return 2625;
                                                                 }
                                                             }
                                                           else
@@ -4125,7 +4191,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1010x0xx0xxxx0
                                                                      smax.  */
-                                                                  return 2622;
+                                                                  return 2624;
                                                                 }
                                                               else
                                                                 {
@@ -4133,7 +4199,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1110x0xx0xxxx0
                                                                      smax.  */
-                                                                  return 2624;
+                                                                  return 2626;
                                                                 }
                                                             }
                                                         }
@@ -4147,7 +4213,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1001x0xx0xxxx0
                                                                      sqdmulh.  */
-                                                                  return 2661;
+                                                                  return 2665;
                                                                 }
                                                               else
                                                                 {
@@ -4155,7 +4221,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1101x0xx0xxxx0
                                                                      sqdmulh.  */
-                                                                  return 2663;
+                                                                  return 2667;
                                                                 }
                                                             }
                                                           else
@@ -4166,7 +4232,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1011x0xx0xxxx0
                                                                      sqdmulh.  */
-                                                                  return 2662;
+                                                                  return 2666;
                                                                 }
                                                               else
                                                                 {
@@ -4174,7 +4240,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x1111x0xx0xxxx0
                                                                      sqdmulh.  */
-                                                                  return 2664;
+                                                                  return 2668;
                                                                 }
                                                             }
                                                         }
@@ -4191,7 +4257,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x100x01xx0xxxx0
                                                                      fmax.  */
-                                                                  return 2468;
+                                                                  return 2470;
                                                                 }
                                                               else
                                                                 {
@@ -4199,7 +4265,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x110x01xx0xxxx0
                                                                      fmax.  */
-                                                                  return 2470;
+                                                                  return 2472;
                                                                 }
                                                             }
                                                           else
@@ -4210,7 +4276,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x101x01xx0xxxx0
                                                                      fmax.  */
-                                                                  return 2469;
+                                                                  return 2471;
                                                                 }
                                                               else
                                                                 {
@@ -4218,7 +4284,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      x1000001xx1xxxxx1x111x01xx0xxxx0
                                                                      fmax.  */
-                                                                  return 2471;
+                                                                  return 2473;
                                                                 }
                                                             }
                                                         }
@@ -4258,7 +4324,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx00x00xx1xxxx0
                                                                  smin.  */
-                                                              return 2625;
+                                                              return 2627;
                                                             }
                                                           else
                                                             {
@@ -4266,7 +4332,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx10x00xx1xxxx0
                                                                  smin.  */
-                                                              return 2627;
+                                                              return 2629;
                                                             }
                                                         }
                                                       else
@@ -4277,7 +4343,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx01x00xx1xxxx0
                                                                  smin.  */
-                                                              return 2626;
+                                                              return 2628;
                                                             }
                                                           else
                                                             {
@@ -4285,7 +4351,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx11x00xx1xxxx0
                                                                  smin.  */
-                                                              return 2628;
+                                                              return 2630;
                                                             }
                                                         }
                                                     }
@@ -4299,7 +4365,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx00x10xx1xxxx0
                                                                  srshl.  */
-                                                              return 2665;
+                                                              return 2669;
                                                             }
                                                           else
                                                             {
@@ -4307,7 +4373,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx10x10xx1xxxx0
                                                                  srshl.  */
-                                                              return 2667;
+                                                              return 2671;
                                                             }
                                                         }
                                                       else
@@ -4318,7 +4384,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx01x10xx1xxxx0
                                                                  srshl.  */
-                                                              return 2666;
+                                                              return 2670;
                                                             }
                                                           else
                                                             {
@@ -4326,7 +4392,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx11x10xx1xxxx0
                                                                  srshl.  */
-                                                              return 2668;
+                                                              return 2672;
                                                             }
                                                         }
                                                     }
@@ -4341,7 +4407,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx00xx1xx1xxxx0
                                                              fmaxnm.  */
-                                                          return 2472;
+                                                          return 2474;
                                                         }
                                                       else
                                                         {
@@ -4349,7 +4415,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx10xx1xx1xxxx0
                                                              fmaxnm.  */
-                                                          return 2474;
+                                                          return 2476;
                                                         }
                                                     }
                                                   else
@@ -4360,7 +4426,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx01xx1xx1xxxx0
                                                              fmaxnm.  */
-                                                          return 2473;
+                                                          return 2475;
                                                         }
                                                       else
                                                         {
@@ -4368,7 +4434,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx11xx1xx1xxxx0
                                                              fmaxnm.  */
-                                                          return 2475;
+                                                          return 2477;
                                                         }
                                                     }
                                                 }
@@ -4388,7 +4454,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx00xx0xx0xxxx1
                                                              umax.  */
-                                                          return 2764;
+                                                          return 2768;
                                                         }
                                                       else
                                                         {
@@ -4396,7 +4462,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx10xx0xx0xxxx1
                                                              umax.  */
-                                                          return 2766;
+                                                          return 2770;
                                                         }
                                                     }
                                                   else
@@ -4407,7 +4473,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx01xx0xx0xxxx1
                                                              umax.  */
-                                                          return 2765;
+                                                          return 2769;
                                                         }
                                                       else
                                                         {
@@ -4415,7 +4481,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx11xx0xx0xxxx1
                                                              umax.  */
-                                                          return 2767;
+                                                          return 2771;
                                                         }
                                                     }
                                                 }
@@ -4429,7 +4495,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx00xx1xx0xxxx1
                                                              fmin.  */
-                                                          return 2476;
+                                                          return 2478;
                                                         }
                                                       else
                                                         {
@@ -4437,7 +4503,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx10xx1xx0xxxx1
                                                              fmin.  */
-                                                          return 2478;
+                                                          return 2480;
                                                         }
                                                     }
                                                   else
@@ -4448,7 +4514,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx01xx1xx0xxxx1
                                                              fmin.  */
-                                                          return 2477;
+                                                          return 2479;
                                                         }
                                                       else
                                                         {
@@ -4456,7 +4522,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx11xx1xx0xxxx1
                                                              fmin.  */
-                                                          return 2479;
+                                                          return 2481;
                                                         }
                                                     }
                                                 }
@@ -4475,7 +4541,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx00x00xx1xxxx1
                                                                  umin.  */
-                                                              return 2768;
+                                                              return 2772;
                                                             }
                                                           else
                                                             {
@@ -4483,7 +4549,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx10x00xx1xxxx1
                                                                  umin.  */
-                                                              return 2770;
+                                                              return 2774;
                                                             }
                                                         }
                                                       else
@@ -4494,7 +4560,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx01x00xx1xxxx1
                                                                  umin.  */
-                                                              return 2769;
+                                                              return 2773;
                                                             }
                                                           else
                                                             {
@@ -4502,7 +4568,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx11x00xx1xxxx1
                                                                  umin.  */
-                                                              return 2771;
+                                                              return 2775;
                                                             }
                                                         }
                                                     }
@@ -4516,7 +4582,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx00x10xx1xxxx1
                                                                  urshl.  */
-                                                              return 2804;
+                                                              return 2810;
                                                             }
                                                           else
                                                             {
@@ -4524,7 +4590,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx10x10xx1xxxx1
                                                                  urshl.  */
-                                                              return 2806;
+                                                              return 2812;
                                                             }
                                                         }
                                                       else
@@ -4535,7 +4601,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx01x10xx1xxxx1
                                                                  urshl.  */
-                                                              return 2805;
+                                                              return 2811;
                                                             }
                                                           else
                                                             {
@@ -4543,7 +4609,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1000001xx1xxxxx1xx11x10xx1xxxx1
                                                                  urshl.  */
-                                                              return 2807;
+                                                              return 2813;
                                                             }
                                                         }
                                                     }
@@ -4558,7 +4624,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx00xx1xx1xxxx1
                                                              fminnm.  */
-                                                          return 2480;
+                                                          return 2482;
                                                         }
                                                       else
                                                         {
@@ -4566,7 +4632,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx10xx1xx1xxxx1
                                                              fminnm.  */
-                                                          return 2482;
+                                                          return 2484;
                                                         }
                                                     }
                                                   else
@@ -4577,7 +4643,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx01xx1xx1xxxx1
                                                              fminnm.  */
-                                                          return 2481;
+                                                          return 2483;
                                                         }
                                                       else
                                                         {
@@ -4585,7 +4651,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1000001xx1xxxxx1xx11xx1xx1xxxx1
                                                              fminnm.  */
-                                                          return 2483;
+                                                          return 2485;
                                                         }
                                                     }
                                                 }
@@ -4614,7 +4680,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx000xxxxxxxxx0xxx
                                                              st1b.  */
-                                                          return 2675;
+                                                          return 2679;
                                                         }
                                                       else
                                                         {
@@ -4622,7 +4688,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx010xxxxxxxxx0xxx
                                                              st1w.  */
-                                                          return 2699;
+                                                          return 2703;
                                                         }
                                                     }
                                                   else
@@ -4633,7 +4699,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx001xxxxxxxxx0xxx
                                                              st1h.  */
-                                                          return 2691;
+                                                          return 2695;
                                                         }
                                                       else
                                                         {
@@ -4641,7 +4707,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx011xxxxxxxxx0xxx
                                                              st1d.  */
-                                                          return 2683;
+                                                          return 2687;
                                                         }
                                                     }
                                                 }
@@ -4655,7 +4721,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx000xxxxxxxxx1xxx
                                                              stnt1b.  */
-                                                          return 2707;
+                                                          return 2711;
                                                         }
                                                       else
                                                         {
@@ -4663,7 +4729,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx010xxxxxxxxx1xxx
                                                              stnt1w.  */
-                                                          return 2731;
+                                                          return 2735;
                                                         }
                                                     }
                                                   else
@@ -4674,7 +4740,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx001xxxxxxxxx1xxx
                                                              stnt1h.  */
-                                                          return 2723;
+                                                          return 2727;
                                                         }
                                                       else
                                                         {
@@ -4682,7 +4748,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx011xxxxxxxxx1xxx
                                                              stnt1d.  */
-                                                          return 2715;
+                                                          return 2719;
                                                         }
                                                     }
                                                 }
@@ -4710,7 +4776,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x0100001001xxxxx100xxxxxxxxx0xxx
                                                              st1b.  */
-                                                          return 2676;
+                                                          return 2680;
                                                         }
                                                       else
                                                         {
@@ -4718,7 +4784,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x1100001001xxxxx100xxxxxxxxx0xxx
                                                              str.  */
-                                                          return 2733;
+                                                          return 2737;
                                                         }
                                                     }
                                                   else
@@ -4727,7 +4793,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001001xxxxx110xxxxxxxxx0xxx
                                                          st1w.  */
-                                                      return 2700;
+                                                      return 2704;
                                                     }
                                                 }
                                               else
@@ -4738,7 +4804,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001001xxxxx101xxxxxxxxx0xxx
                                                          st1h.  */
-                                                      return 2692;
+                                                      return 2696;
                                                     }
                                                   else
                                                     {
@@ -4746,7 +4812,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001001xxxxx111xxxxxxxxx0xxx
                                                          st1d.  */
-                                                      return 2684;
+                                                      return 2688;
                                                     }
                                                 }
                                             }
@@ -4760,7 +4826,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001001xxxxx100xxxxxxxxx1xxx
                                                          stnt1b.  */
-                                                      return 2708;
+                                                      return 2712;
                                                     }
                                                   else
                                                     {
@@ -4768,7 +4834,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001001xxxxx110xxxxxxxxx1xxx
                                                          stnt1w.  */
-                                                      return 2732;
+                                                      return 2736;
                                                     }
                                                 }
                                               else
@@ -4779,7 +4845,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001001xxxxx101xxxxxxxxx1xxx
                                                          stnt1h.  */
-                                                      return 2724;
+                                                      return 2728;
                                                     }
                                                   else
                                                     {
@@ -4787,7 +4853,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001001xxxxx111xxxxxxxxx1xxx
                                                          stnt1d.  */
-                                                      return 2716;
+                                                      return 2720;
                                                     }
                                                 }
                                             }
@@ -4829,7 +4895,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx000xxxxxxxxx0xxx
                                                          st1b.  */
-                                                      return 2671;
+                                                      return 2675;
                                                     }
                                                   else
                                                     {
@@ -4837,7 +4903,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx100xxxxxxxxx0xxx
                                                          st1b.  */
-                                                      return 2672;
+                                                      return 2676;
                                                     }
                                                 }
                                               else
@@ -4848,7 +4914,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx010xxxxxxxxx0xxx
                                                          st1w.  */
-                                                      return 2695;
+                                                      return 2699;
                                                     }
                                                   else
                                                     {
@@ -4856,7 +4922,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx110xxxxxxxxx0xxx
                                                          st1w.  */
-                                                      return 2696;
+                                                      return 2700;
                                                     }
                                                 }
                                             }
@@ -4870,7 +4936,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx001xxxxxxxxx0xxx
                                                          st1h.  */
-                                                      return 2687;
+                                                      return 2691;
                                                     }
                                                   else
                                                     {
@@ -4878,7 +4944,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx101xxxxxxxxx0xxx
                                                          st1h.  */
-                                                      return 2688;
+                                                      return 2692;
                                                     }
                                                 }
                                               else
@@ -4889,7 +4955,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx011xxxxxxxxx0xxx
                                                          st1d.  */
-                                                      return 2679;
+                                                      return 2683;
                                                     }
                                                   else
                                                     {
@@ -4897,7 +4963,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx111xxxxxxxxx0xxx
                                                          st1d.  */
-                                                      return 2680;
+                                                      return 2684;
                                                     }
                                                 }
                                             }
@@ -4914,7 +4980,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx000xxxxxxxxx1xxx
                                                          stnt1b.  */
-                                                      return 2703;
+                                                      return 2707;
                                                     }
                                                   else
                                                     {
@@ -4922,7 +4988,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx100xxxxxxxxx1xxx
                                                          stnt1b.  */
-                                                      return 2704;
+                                                      return 2708;
                                                     }
                                                 }
                                               else
@@ -4933,7 +4999,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx010xxxxxxxxx1xxx
                                                          stnt1w.  */
-                                                      return 2727;
+                                                      return 2731;
                                                     }
                                                   else
                                                     {
@@ -4941,7 +5007,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx110xxxxxxxxx1xxx
                                                          stnt1w.  */
-                                                      return 2728;
+                                                      return 2732;
                                                     }
                                                 }
                                             }
@@ -4955,7 +5021,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx001xxxxxxxxx1xxx
                                                          stnt1h.  */
-                                                      return 2719;
+                                                      return 2723;
                                                     }
                                                   else
                                                     {
@@ -4963,7 +5029,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx101xxxxxxxxx1xxx
                                                          stnt1h.  */
-                                                      return 2720;
+                                                      return 2724;
                                                     }
                                                 }
                                               else
@@ -4974,7 +5040,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx011xxxxxxxxx1xxx
                                                          stnt1d.  */
-                                                      return 2711;
+                                                      return 2715;
                                                     }
                                                   else
                                                     {
@@ -4982,7 +5048,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx100001011xxxxx111xxxxxxxxx1xxx
                                                          stnt1d.  */
-                                                      return 2712;
+                                                      return 2716;
                                                     }
                                                 }
                                             }
@@ -7384,7 +7450,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          00011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlurb.  */
-                                                      return 2896;
+                                                      return 2902;
                                                     }
                                                   else
                                                     {
@@ -7392,7 +7458,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          10011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlur.  */
-                                                      return 2904;
+                                                      return 2910;
                                                     }
                                                 }
                                               else
@@ -7403,7 +7469,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          01011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlurh.  */
-                                                      return 2900;
+                                                      return 2906;
                                                     }
                                                   else
                                                     {
@@ -7411,7 +7477,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          11011001000xxxxxxxxx00xxxxxxxxxx
                                                          stlur.  */
-                                                      return 2907;
+                                                      return 2913;
                                                     }
                                                 }
                                             }
@@ -7449,7 +7515,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0000x1xxxxxxxxxx
                                                              cpyfp.  */
-                                                          return 2956;
+                                                          return 2962;
                                                         }
                                                       else
                                                         {
@@ -7457,7 +7523,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1000x1xxxxxxxxxx
                                                              cpyfprn.  */
-                                                          return 2962;
+                                                          return 2968;
                                                         }
                                                     }
                                                   else
@@ -7468,7 +7534,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0100x1xxxxxxxxxx
                                                              cpyfpwn.  */
-                                                          return 2959;
+                                                          return 2965;
                                                         }
                                                       else
                                                         {
@@ -7476,7 +7542,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1100x1xxxxxxxxxx
                                                              cpyfpn.  */
-                                                          return 2965;
+                                                          return 2971;
                                                         }
                                                     }
                                                 }
@@ -7490,7 +7556,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0010x1xxxxxxxxxx
                                                              cpyfprt.  */
-                                                          return 2980;
+                                                          return 2986;
                                                         }
                                                       else
                                                         {
@@ -7498,7 +7564,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1010x1xxxxxxxxxx
                                                              cpyfprtrn.  */
-                                                          return 2986;
+                                                          return 2992;
                                                         }
                                                     }
                                                   else
@@ -7509,7 +7575,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0110x1xxxxxxxxxx
                                                              cpyfprtwn.  */
-                                                          return 2983;
+                                                          return 2989;
                                                         }
                                                       else
                                                         {
@@ -7517,7 +7583,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1110x1xxxxxxxxxx
                                                              cpyfprtn.  */
-                                                          return 2989;
+                                                          return 2995;
                                                         }
                                                     }
                                                 }
@@ -7534,7 +7600,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0001x1xxxxxxxxxx
                                                              cpyfpwt.  */
-                                                          return 2968;
+                                                          return 2974;
                                                         }
                                                       else
                                                         {
@@ -7542,7 +7608,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1001x1xxxxxxxxxx
                                                              cpyfpwtrn.  */
-                                                          return 2974;
+                                                          return 2980;
                                                         }
                                                     }
                                                   else
@@ -7553,7 +7619,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0101x1xxxxxxxxxx
                                                              cpyfpwtwn.  */
-                                                          return 2971;
+                                                          return 2977;
                                                         }
                                                       else
                                                         {
@@ -7561,7 +7627,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1101x1xxxxxxxxxx
                                                              cpyfpwtn.  */
-                                                          return 2977;
+                                                          return 2983;
                                                         }
                                                     }
                                                 }
@@ -7575,7 +7641,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0011x1xxxxxxxxxx
                                                              cpyfpt.  */
-                                                          return 2992;
+                                                          return 2998;
                                                         }
                                                       else
                                                         {
@@ -7583,7 +7649,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1011x1xxxxxxxxxx
                                                              cpyfptrn.  */
-                                                          return 2998;
+                                                          return 3004;
                                                         }
                                                     }
                                                   else
@@ -7594,7 +7660,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx0111x1xxxxxxxxxx
                                                              cpyfptwn.  */
-                                                          return 2995;
+                                                          return 3001;
                                                         }
                                                       else
                                                         {
@@ -7602,7 +7668,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001000xxxxx1111x1xxxxxxxxxx
                                                              cpyfptn.  */
-                                                          return 3001;
+                                                          return 3007;
                                                         }
                                                     }
                                                 }
@@ -7667,7 +7733,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          00011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapurb.  */
-                                                      return 2897;
+                                                      return 2903;
                                                     }
                                                   else
                                                     {
@@ -7675,7 +7741,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          10011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapur.  */
-                                                      return 2905;
+                                                      return 2911;
                                                     }
                                                 }
                                               else
@@ -7686,7 +7752,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          01011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapurh.  */
-                                                      return 2901;
+                                                      return 2907;
                                                     }
                                                   else
                                                     {
@@ -7694,7 +7760,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          11011001010xxxxxxxxx00xxxxxxxxxx
                                                          ldapur.  */
-                                                      return 2908;
+                                                      return 2914;
                                                     }
                                                 }
                                             }
@@ -7732,7 +7798,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0000x1xxxxxxxxxx
                                                              cpyfm.  */
-                                                          return 2957;
+                                                          return 2963;
                                                         }
                                                       else
                                                         {
@@ -7740,7 +7806,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1000x1xxxxxxxxxx
                                                              cpyfmrn.  */
-                                                          return 2963;
+                                                          return 2969;
                                                         }
                                                     }
                                                   else
@@ -7751,7 +7817,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0100x1xxxxxxxxxx
                                                              cpyfmwn.  */
-                                                          return 2960;
+                                                          return 2966;
                                                         }
                                                       else
                                                         {
@@ -7759,7 +7825,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1100x1xxxxxxxxxx
                                                              cpyfmn.  */
-                                                          return 2966;
+                                                          return 2972;
                                                         }
                                                     }
                                                 }
@@ -7773,7 +7839,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0010x1xxxxxxxxxx
                                                              cpyfmrt.  */
-                                                          return 2981;
+                                                          return 2987;
                                                         }
                                                       else
                                                         {
@@ -7781,7 +7847,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1010x1xxxxxxxxxx
                                                              cpyfmrtrn.  */
-                                                          return 2987;
+                                                          return 2993;
                                                         }
                                                     }
                                                   else
@@ -7792,7 +7858,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0110x1xxxxxxxxxx
                                                              cpyfmrtwn.  */
-                                                          return 2984;
+                                                          return 2990;
                                                         }
                                                       else
                                                         {
@@ -7800,7 +7866,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1110x1xxxxxxxxxx
                                                              cpyfmrtn.  */
-                                                          return 2990;
+                                                          return 2996;
                                                         }
                                                     }
                                                 }
@@ -7817,7 +7883,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0001x1xxxxxxxxxx
                                                              cpyfmwt.  */
-                                                          return 2969;
+                                                          return 2975;
                                                         }
                                                       else
                                                         {
@@ -7825,7 +7891,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1001x1xxxxxxxxxx
                                                              cpyfmwtrn.  */
-                                                          return 2975;
+                                                          return 2981;
                                                         }
                                                     }
                                                   else
@@ -7836,7 +7902,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0101x1xxxxxxxxxx
                                                              cpyfmwtwn.  */
-                                                          return 2972;
+                                                          return 2978;
                                                         }
                                                       else
                                                         {
@@ -7844,7 +7910,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1101x1xxxxxxxxxx
                                                              cpyfmwtn.  */
-                                                          return 2978;
+                                                          return 2984;
                                                         }
                                                     }
                                                 }
@@ -7858,7 +7924,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0011x1xxxxxxxxxx
                                                              cpyfmt.  */
-                                                          return 2993;
+                                                          return 2999;
                                                         }
                                                       else
                                                         {
@@ -7866,7 +7932,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1011x1xxxxxxxxxx
                                                              cpyfmtrn.  */
-                                                          return 2999;
+                                                          return 3005;
                                                         }
                                                     }
                                                   else
@@ -7877,7 +7943,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx0111x1xxxxxxxxxx
                                                              cpyfmtwn.  */
-                                                          return 2996;
+                                                          return 3002;
                                                         }
                                                       else
                                                         {
@@ -7885,7 +7951,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001010xxxxx1111x1xxxxxxxxxx
                                                              cpyfmtn.  */
-                                                          return 3002;
+                                                          return 3008;
                                                         }
                                                     }
                                                 }
@@ -7953,7 +8019,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          00011001100xxxxxxxxx00xxxxxxxxxx
                                                          ldapursb.  */
-                                                      return 2899;
+                                                      return 2905;
                                                     }
                                                   else
                                                     {
@@ -7961,7 +8027,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          10011001100xxxxxxxxx00xxxxxxxxxx
                                                          ldapursw.  */
-                                                      return 2906;
+                                                      return 2912;
                                                     }
                                                 }
                                               else
@@ -7970,7 +8036,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1011001100xxxxxxxxx00xxxxxxxxxx
                                                      ldapursh.  */
-                                                  return 2903;
+                                                  return 2909;
                                                 }
                                             }
                                           else
@@ -7981,7 +8047,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0011001110xxxxxxxxx00xxxxxxxxxx
                                                      ldapursb.  */
-                                                  return 2898;
+                                                  return 2904;
                                                 }
                                               else
                                                 {
@@ -7989,7 +8055,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1011001110xxxxxxxxx00xxxxxxxxxx
                                                      ldapursh.  */
-                                                  return 2902;
+                                                  return 2908;
                                                 }
                                             }
                                         }
@@ -8051,7 +8117,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0000x1xxxxxxxxxx
                                                              cpyfe.  */
-                                                          return 2958;
+                                                          return 2964;
                                                         }
                                                       else
                                                         {
@@ -8059,7 +8125,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0000x1xxxxxxxxxx
                                                              setp.  */
-                                                          return 3052;
+                                                          return 3058;
                                                         }
                                                     }
                                                   else
@@ -8070,7 +8136,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx1000x1xxxxxxxxxx
                                                              cpyfern.  */
-                                                          return 2964;
+                                                          return 2970;
                                                         }
                                                       else
                                                         {
@@ -8078,7 +8144,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx1000x1xxxxxxxxxx
                                                              sete.  */
-                                                          return 3054;
+                                                          return 3060;
                                                         }
                                                     }
                                                 }
@@ -8092,7 +8158,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0100x1xxxxxxxxxx
                                                              cpyfewn.  */
-                                                          return 2961;
+                                                          return 2967;
                                                         }
                                                       else
                                                         {
@@ -8100,7 +8166,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0100x1xxxxxxxxxx
                                                              setm.  */
-                                                          return 3053;
+                                                          return 3059;
                                                         }
                                                     }
                                                   else
@@ -8109,7 +8175,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0110011x0xxxxx1100x1xxxxxxxxxx
                                                          cpyfen.  */
-                                                      return 2967;
+                                                      return 2973;
                                                     }
                                                 }
                                             }
@@ -8125,7 +8191,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0010x1xxxxxxxxxx
                                                              cpyfert.  */
-                                                          return 2982;
+                                                          return 2988;
                                                         }
                                                       else
                                                         {
@@ -8133,7 +8199,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0010x1xxxxxxxxxx
                                                              setpn.  */
-                                                          return 3058;
+                                                          return 3064;
                                                         }
                                                     }
                                                   else
@@ -8144,7 +8210,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx1010x1xxxxxxxxxx
                                                              cpyfertrn.  */
-                                                          return 2988;
+                                                          return 2994;
                                                         }
                                                       else
                                                         {
@@ -8152,7 +8218,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx1010x1xxxxxxxxxx
                                                              seten.  */
-                                                          return 3060;
+                                                          return 3066;
                                                         }
                                                     }
                                                 }
@@ -8166,7 +8232,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0110x1xxxxxxxxxx
                                                              cpyfertwn.  */
-                                                          return 2985;
+                                                          return 2991;
                                                         }
                                                       else
                                                         {
@@ -8174,7 +8240,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0110x1xxxxxxxxxx
                                                              setmn.  */
-                                                          return 3059;
+                                                          return 3065;
                                                         }
                                                     }
                                                   else
@@ -8183,7 +8249,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0110011x0xxxxx1110x1xxxxxxxxxx
                                                          cpyfertn.  */
-                                                      return 2991;
+                                                      return 2997;
                                                     }
                                                 }
                                             }
@@ -8202,7 +8268,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0001x1xxxxxxxxxx
                                                              cpyfewt.  */
-                                                          return 2970;
+                                                          return 2976;
                                                         }
                                                       else
                                                         {
@@ -8210,7 +8276,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0001x1xxxxxxxxxx
                                                              setpt.  */
-                                                          return 3055;
+                                                          return 3061;
                                                         }
                                                     }
                                                   else
@@ -8221,7 +8287,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx1001x1xxxxxxxxxx
                                                              cpyfewtrn.  */
-                                                          return 2976;
+                                                          return 2982;
                                                         }
                                                       else
                                                         {
@@ -8229,7 +8295,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx1001x1xxxxxxxxxx
                                                              setet.  */
-                                                          return 3057;
+                                                          return 3063;
                                                         }
                                                     }
                                                 }
@@ -8243,7 +8309,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0101x1xxxxxxxxxx
                                                              cpyfewtwn.  */
-                                                          return 2973;
+                                                          return 2979;
                                                         }
                                                       else
                                                         {
@@ -8251,7 +8317,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0101x1xxxxxxxxxx
                                                              setmt.  */
-                                                          return 3056;
+                                                          return 3062;
                                                         }
                                                     }
                                                   else
@@ -8260,7 +8326,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0110011x0xxxxx1101x1xxxxxxxxxx
                                                          cpyfewtn.  */
-                                                      return 2979;
+                                                      return 2985;
                                                     }
                                                 }
                                             }
@@ -8276,7 +8342,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0011x1xxxxxxxxxx
                                                              cpyfet.  */
-                                                          return 2994;
+                                                          return 3000;
                                                         }
                                                       else
                                                         {
@@ -8284,7 +8350,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0011x1xxxxxxxxxx
                                                              setptn.  */
-                                                          return 3061;
+                                                          return 3067;
                                                         }
                                                     }
                                                   else
@@ -8295,7 +8361,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx1011x1xxxxxxxxxx
                                                              cpyfetrn.  */
-                                                          return 3000;
+                                                          return 3006;
                                                         }
                                                       else
                                                         {
@@ -8303,7 +8369,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx1011x1xxxxxxxxxx
                                                              setetn.  */
-                                                          return 3063;
+                                                          return 3069;
                                                         }
                                                     }
                                                 }
@@ -8317,7 +8383,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001100xxxxx0111x1xxxxxxxxxx
                                                              cpyfetwn.  */
-                                                          return 2997;
+                                                          return 3003;
                                                         }
                                                       else
                                                         {
@@ -8325,7 +8391,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xx011001110xxxxx0111x1xxxxxxxxxx
                                                              setmtn.  */
-                                                          return 3062;
+                                                          return 3068;
                                                         }
                                                     }
                                                   else
@@ -8334,7 +8400,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx0110011x0xxxxx1111x1xxxxxxxxxx
                                                          cpyfetn.  */
-                                                      return 3003;
+                                                      return 3009;
                                                     }
                                                 }
                                             }
@@ -8707,7 +8773,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x1x11010110xxxx0x01000xxxxxxxxxx
                                                                  abs.  */
-                                                              return 3081;
+                                                              return 3087;
                                                             }
                                                           else
                                                             {
@@ -8725,7 +8791,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx11010110xxxxxx11000xxxxxxxxxx
                                                          smax.  */
-                                                      return 3084;
+                                                      return 3090;
                                                     }
                                                 }
                                             }
@@ -8805,7 +8871,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxx11010x00xxxxxx0xx10xxxxxxxxxx
                                              setf8.  */
-                                          return 2894;
+                                          return 2900;
                                         }
                                       else
                                         {
@@ -8813,7 +8879,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxx11010x00xxxxxx1xx10xxxxxxxxxx
                                              setf16.  */
-                                          return 2895;
+                                          return 2901;
                                         }
                                     }
                                   else
@@ -8920,7 +8986,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxx11010110xxxxxx11010xxxxxxxxxx
                                                          smin.  */
-                                                      return 3086;
+                                                      return 3092;
                                                     }
                                                 }
                                             }
@@ -8936,7 +9002,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxx11010110xxxx0x00110xxxxxxxxxx
                                                              ctz.  */
-                                                          return 3083;
+                                                          return 3089;
                                                         }
                                                       else
                                                         {
@@ -8981,7 +9047,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxx11010000xxxxxxxxx01xxxxxxxxxx
                                              rmif.  */
-                                          return 2893;
+                                          return 2899;
                                         }
                                       else
                                         {
@@ -9075,7 +9141,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxx11010x10xxxxxx11001xxxxxxxxxx
                                                      umax.  */
-                                                  return 3085;
+                                                  return 3091;
                                                 }
                                             }
                                         }
@@ -9205,7 +9271,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxx11010xx0xxxxxx11011xxxxxxxxxx
                                                  umin.  */
-                                              return 3087;
+                                              return 3093;
                                             }
                                         }
                                     }
@@ -9221,7 +9287,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxx11010xx0xxxx0x00111xxxxxxxxxx
                                                      cnt.  */
-                                                  return 3082;
+                                                  return 3088;
                                                 }
                                               else
                                                 {
@@ -10063,7 +10129,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  010001x01x1xxxxx000110xxxxxxxxxx
                                                                  usdot.  */
-                                                              return 2913;
+                                                              return 2919;
                                                             }
                                                         }
                                                     }
@@ -10137,7 +10203,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  010001x01x1xxxxx000111xxxxxxxxxx
                                                                  sudot.  */
-                                                              return 2914;
+                                                              return 2920;
                                                             }
                                                         }
                                                     }
@@ -12811,7 +12877,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              010001x0xx0xxxxx011110xxxxxxxxxx
                                                              usdot.  */
-                                                          return 2912;
+                                                          return 2918;
                                                         }
                                                     }
                                                 }
@@ -14515,7 +14581,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  011001x0100xxx10101xxxxxxxxxxxxx
                                                                  bfcvtnt.  */
-                                                              return 2941;
+                                                              return 2947;
                                                             }
                                                         }
                                                       else
@@ -14758,7 +14824,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  101001x00x1xxxxxx00xxxxxxxxxxxxx
                                                  ld1rob.  */
-                                              return 2917;
+                                              return 2923;
                                             }
                                           else
                                             {
@@ -14766,7 +14832,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  101001x01x1xxxxxx00xxxxxxxxxxxxx
                                                  ld1roh.  */
-                                              return 2918;
+                                              return 2924;
                                             }
                                         }
                                       else
@@ -14998,7 +15064,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0011xxxxx010xxxxxxxxxxxxx
                                                          bfdot.  */
-                                                      return 2938;
+                                                      return 2944;
                                                     }
                                                   else
                                                     {
@@ -15019,7 +15085,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              011001x0111xxxxx010xx0xxxxxxxxxx
                                                              bfmlalb.  */
-                                                          return 2945;
+                                                          return 2951;
                                                         }
                                                       else
                                                         {
@@ -15027,7 +15093,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              011001x0111xxxxx010xx1xxxxxxxxxx
                                                              bfmlalt.  */
-                                                          return 2944;
+                                                          return 2950;
                                                         }
                                                     }
                                                   else
@@ -15082,7 +15148,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  x11001x0011xxxxx1x0xxxxxxxxxxxxx
                                                  bfdot.  */
-                                              return 2937;
+                                              return 2943;
                                             }
                                           else
                                             {
@@ -15094,7 +15160,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0111xxxxx1x0xx0xxxxxxxxxx
                                                          bfmlalb.  */
-                                                      return 2943;
+                                                      return 2949;
                                                     }
                                                   else
                                                     {
@@ -15102,7 +15168,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0111xxxxx1x0xx1xxxxxxxxxx
                                                          bfmlalt.  */
-                                                      return 2942;
+                                                      return 2948;
                                                     }
                                                 }
                                               else
@@ -15153,7 +15219,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x00x1xxxxx001xxxxxxxxxxxxx
                                                      ld1rob.  */
-                                                  return 2921;
+                                                  return 2927;
                                                 }
                                               else
                                                 {
@@ -15161,7 +15227,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x01x1xxxxx001xxxxxxxxxxxxx
                                                      ld1roh.  */
-                                                  return 2922;
+                                                  return 2928;
                                                 }
                                             }
                                           else
@@ -15520,7 +15586,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0101xxxxx111xxxxxxxxxxxxx
                                                          fmmla.  */
-                                                      return 2915;
+                                                      return 2921;
                                                     }
                                                   else
                                                     {
@@ -15553,7 +15619,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0011xxxxx111xxxxxxxxxxxxx
                                                          bfmmla.  */
-                                                      return 2939;
+                                                      return 2945;
                                                     }
                                                   else
                                                     {
@@ -15583,7 +15649,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          011001x0111xxxxx111xxxxxxxxxxxxx
                                                          fmmla.  */
-                                                      return 2916;
+                                                      return 2922;
                                                     }
                                                   else
                                                     {
@@ -15712,7 +15778,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  000001x1101xxxxx000x00xxxxxxxxxx
                                                                  zip1.  */
-                                                              return 2925;
+                                                              return 2931;
                                                             }
                                                           else
                                                             {
@@ -15722,7 +15788,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000010xxxxxxxxxx
                                                                      uzp1.  */
-                                                                  return 2927;
+                                                                  return 2933;
                                                                 }
                                                               else
                                                                 {
@@ -15730,7 +15796,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000110xxxxxxxxxx
                                                                      trn1.  */
-                                                                  return 2929;
+                                                                  return 2935;
                                                                 }
                                                             }
                                                         }
@@ -15742,7 +15808,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  000001x1101xxxxx000x01xxxxxxxxxx
                                                                  zip2.  */
-                                                              return 2926;
+                                                              return 2932;
                                                             }
                                                           else
                                                             {
@@ -15752,7 +15818,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000011xxxxxxxxxx
                                                                      uzp2.  */
-                                                                  return 2928;
+                                                                  return 2934;
                                                                 }
                                                               else
                                                                 {
@@ -15760,7 +15826,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      000001x1101xxxxx000111xxxxxxxxxx
                                                                      trn2.  */
-                                                                  return 2930;
+                                                                  return 2936;
                                                                 }
                                                             }
                                                         }
@@ -16819,7 +16885,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      010001x1000xxxxx100110xxxxxxxxxx
                                                                      smmla.  */
-                                                                  return 2909;
+                                                                  return 2915;
                                                                 }
                                                               else
                                                                 {
@@ -16827,7 +16893,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      010001x1100xxxxx100110xxxxxxxxxx
                                                                      usmmla.  */
-                                                                  return 2911;
+                                                                  return 2917;
                                                                 }
                                                             }
                                                           else
@@ -16836,7 +16902,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  010001x1x10xxxxx100110xxxxxxxxxx
                                                                  ummla.  */
-                                                              return 2910;
+                                                              return 2916;
                                                             }
                                                         }
                                                     }
@@ -18332,7 +18398,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x10x1xxxxx000xxxxxxxxxxxxx
                                                      ld1row.  */
-                                                  return 2919;
+                                                  return 2925;
                                                 }
                                               else
                                                 {
@@ -18340,7 +18406,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x11x1xxxxx000xxxxxxxxxxxxx
                                                      ld1rod.  */
-                                                  return 2920;
+                                                  return 2926;
                                                 }
                                             }
                                         }
@@ -18714,7 +18780,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x10x1xxxxx001xxxxxxxxxxxxx
                                                      ld1row.  */
-                                                  return 2923;
+                                                  return 2929;
                                                 }
                                               else
                                                 {
@@ -18722,7 +18788,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      101001x11x1xxxxx001xxxxxxxxxxxxx
                                                      ld1rod.  */
-                                                  return 2924;
+                                                  return 2930;
                                                 }
                                             }
                                         }
@@ -19083,7 +19149,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x000xxxxx10xxx
                                                                  whilege.  */
-                                                              return 2825;
+                                                              return 2831;
                                                             }
                                                           else
                                                             {
@@ -19091,7 +19157,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x000xxxxx11xxx
                                                                  whilegt.  */
-                                                              return 2826;
+                                                              return 2832;
                                                             }
                                                         }
                                                       else
@@ -19121,7 +19187,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx011100xxxxx1xxxx
                                                                  pext.  */
-                                                              return 2604;
+                                                              return 2606;
                                                             }
                                                         }
                                                     }
@@ -19135,7 +19201,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x010xxxxx10xxx
                                                                  whilehs.  */
-                                                              return 2828;
+                                                              return 2834;
                                                             }
                                                           else
                                                             {
@@ -19143,7 +19209,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x010xxxxx11xxx
                                                                  whilehi.  */
-                                                              return 2827;
+                                                              return 2833;
                                                             }
                                                         }
                                                       else
@@ -19173,7 +19239,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx011110xxxxx1xxxx
                                                                  ptrue.  */
-                                                              return 2606;
+                                                              return 2608;
                                                             }
                                                         }
                                                     }
@@ -19190,7 +19256,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x001xxxxx10xxx
                                                                  whilelt.  */
-                                                              return 2832;
+                                                              return 2838;
                                                             }
                                                           else
                                                             {
@@ -19198,7 +19264,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x001xxxxx11xxx
                                                                  whilele.  */
-                                                              return 2829;
+                                                              return 2835;
                                                             }
                                                         }
                                                       else
@@ -19228,7 +19294,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx011101xxxxx1xxxx
                                                                  pext.  */
-                                                              return 2605;
+                                                              return 2607;
                                                             }
                                                         }
                                                     }
@@ -19242,7 +19308,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x011xxxxx10xxx
                                                                  whilelo.  */
-                                                              return 2830;
+                                                              return 2836;
                                                             }
                                                           else
                                                             {
@@ -19250,7 +19316,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  001001x1xx1xxxxx01x011xxxxx11xxx
                                                                  whilels.  */
-                                                              return 2831;
+                                                              return 2837;
                                                             }
                                                         }
                                                       else
@@ -20376,7 +20442,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          011001x110001x10101xxxxxxxxxxxxx
                                                                          bfcvt.  */
-                                                                      return 2940;
+                                                                      return 2946;
                                                                     }
                                                                 }
                                                               else
@@ -21035,7 +21101,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      001001x1xx10xxxx10xxxx1xxxxxxxxx
                                                      cntp.  */
-                                                  return 2459;
+                                                  return 2461;
                                                 }
                                             }
                                           else
@@ -21737,7 +21803,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                      10987654321098765432109876543210
                                      x1010100xxxxxxxxxxxxxxxxxxx1xxxx
                                      bc.c.  */
-                                  return 3076;
+                                  return 3082;
                                 }
                               else
                                 {
@@ -22317,7 +22383,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0000xxxxxxxxxxxx
                                                      cpyp.  */
-                                                  return 3004;
+                                                  return 3010;
                                                 }
                                               else
                                                 {
@@ -22325,7 +22391,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0000xxxxxxxxxxxx
                                                      cpye.  */
-                                                  return 3006;
+                                                  return 3012;
                                                 }
                                             }
                                           else
@@ -22336,7 +22402,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1000xxxxxxxxxxxx
                                                      cpyprn.  */
-                                                  return 3010;
+                                                  return 3016;
                                                 }
                                               else
                                                 {
@@ -22344,7 +22410,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1000xxxxxxxxxxxx
                                                      cpyern.  */
-                                                  return 3012;
+                                                  return 3018;
                                                 }
                                             }
                                         }
@@ -22358,7 +22424,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0100xxxxxxxxxxxx
                                                      cpypwn.  */
-                                                  return 3007;
+                                                  return 3013;
                                                 }
                                               else
                                                 {
@@ -22366,7 +22432,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0100xxxxxxxxxxxx
                                                      cpyewn.  */
-                                                  return 3009;
+                                                  return 3015;
                                                 }
                                             }
                                           else
@@ -22377,7 +22443,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1100xxxxxxxxxxxx
                                                      cpypn.  */
-                                                  return 3013;
+                                                  return 3019;
                                                 }
                                               else
                                                 {
@@ -22385,7 +22451,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1100xxxxxxxxxxxx
                                                      cpyen.  */
-                                                  return 3015;
+                                                  return 3021;
                                                 }
                                             }
                                         }
@@ -22402,7 +22468,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0010xxxxxxxxxxxx
                                                      cpyprt.  */
-                                                  return 3028;
+                                                  return 3034;
                                                 }
                                               else
                                                 {
@@ -22410,7 +22476,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0010xxxxxxxxxxxx
                                                      cpyert.  */
-                                                  return 3030;
+                                                  return 3036;
                                                 }
                                             }
                                           else
@@ -22421,7 +22487,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1010xxxxxxxxxxxx
                                                      cpyprtrn.  */
-                                                  return 3034;
+                                                  return 3040;
                                                 }
                                               else
                                                 {
@@ -22429,7 +22495,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1010xxxxxxxxxxxx
                                                      cpyertrn.  */
-                                                  return 3036;
+                                                  return 3042;
                                                 }
                                             }
                                         }
@@ -22443,7 +22509,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0110xxxxxxxxxxxx
                                                      cpyprtwn.  */
-                                                  return 3031;
+                                                  return 3037;
                                                 }
                                               else
                                                 {
@@ -22451,7 +22517,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0110xxxxxxxxxxxx
                                                      cpyertwn.  */
-                                                  return 3033;
+                                                  return 3039;
                                                 }
                                             }
                                           else
@@ -22462,7 +22528,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1110xxxxxxxxxxxx
                                                      cpyprtn.  */
-                                                  return 3037;
+                                                  return 3043;
                                                 }
                                               else
                                                 {
@@ -22470,7 +22536,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1110xxxxxxxxxxxx
                                                      cpyertn.  */
-                                                  return 3039;
+                                                  return 3045;
                                                 }
                                             }
                                         }
@@ -22490,7 +22556,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0001xxxxxxxxxxxx
                                                      cpypwt.  */
-                                                  return 3016;
+                                                  return 3022;
                                                 }
                                               else
                                                 {
@@ -22498,7 +22564,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0001xxxxxxxxxxxx
                                                      cpyewt.  */
-                                                  return 3018;
+                                                  return 3024;
                                                 }
                                             }
                                           else
@@ -22509,7 +22575,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1001xxxxxxxxxxxx
                                                      cpypwtrn.  */
-                                                  return 3022;
+                                                  return 3028;
                                                 }
                                               else
                                                 {
@@ -22517,7 +22583,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1001xxxxxxxxxxxx
                                                      cpyewtrn.  */
-                                                  return 3024;
+                                                  return 3030;
                                                 }
                                             }
                                         }
@@ -22531,7 +22597,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0101xxxxxxxxxxxx
                                                      cpypwtwn.  */
-                                                  return 3019;
+                                                  return 3025;
                                                 }
                                               else
                                                 {
@@ -22539,7 +22605,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0101xxxxxxxxxxxx
                                                      cpyewtwn.  */
-                                                  return 3021;
+                                                  return 3027;
                                                 }
                                             }
                                           else
@@ -22550,7 +22616,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1101xxxxxxxxxxxx
                                                      cpypwtn.  */
-                                                  return 3025;
+                                                  return 3031;
                                                 }
                                               else
                                                 {
@@ -22558,7 +22624,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1101xxxxxxxxxxxx
                                                      cpyewtn.  */
-                                                  return 3027;
+                                                  return 3033;
                                                 }
                                             }
                                         }
@@ -22575,7 +22641,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0011xxxxxxxxxxxx
                                                      cpypt.  */
-                                                  return 3040;
+                                                  return 3046;
                                                 }
                                               else
                                                 {
@@ -22583,7 +22649,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0011xxxxxxxxxxxx
                                                      cpyet.  */
-                                                  return 3042;
+                                                  return 3048;
                                                 }
                                             }
                                           else
@@ -22594,7 +22660,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1011xxxxxxxxxxxx
                                                      cpyptrn.  */
-                                                  return 3046;
+                                                  return 3052;
                                                 }
                                               else
                                                 {
@@ -22602,7 +22668,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1011xxxxxxxxxxxx
                                                      cpyetrn.  */
-                                                  return 3048;
+                                                  return 3054;
                                                 }
                                             }
                                         }
@@ -22616,7 +22682,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx0111xxxxxxxxxxxx
                                                      cpyptwn.  */
-                                                  return 3043;
+                                                  return 3049;
                                                 }
                                               else
                                                 {
@@ -22624,7 +22690,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx0111xxxxxxxxxxxx
                                                      cpyetwn.  */
-                                                  return 3045;
+                                                  return 3051;
                                                 }
                                             }
                                           else
@@ -22635,7 +22701,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110100xxxxxx1111xxxxxxxxxxxx
                                                      cpyptn.  */
-                                                  return 3049;
+                                                  return 3055;
                                                 }
                                               else
                                                 {
@@ -22643,7 +22709,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110110xxxxxx1111xxxxxxxxxxxx
                                                      cpyetn.  */
-                                                  return 3051;
+                                                  return 3057;
                                                 }
                                             }
                                         }
@@ -22677,7 +22743,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0000xxxxxxxxxxxx
                                                      cpym.  */
-                                                  return 3005;
+                                                  return 3011;
                                                 }
                                               else
                                                 {
@@ -22685,7 +22751,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0000xxxxxxxxxxxx
                                                      setgp.  */
-                                                  return 3064;
+                                                  return 3070;
                                                 }
                                             }
                                           else
@@ -22696,7 +22762,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx1000xxxxxxxxxxxx
                                                      cpymrn.  */
-                                                  return 3011;
+                                                  return 3017;
                                                 }
                                               else
                                                 {
@@ -22704,7 +22770,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx1000xxxxxxxxxxxx
                                                      setge.  */
-                                                  return 3066;
+                                                  return 3072;
                                                 }
                                             }
                                         }
@@ -22718,7 +22784,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0100xxxxxxxxxxxx
                                                      cpymwn.  */
-                                                  return 3008;
+                                                  return 3014;
                                                 }
                                               else
                                                 {
@@ -22726,7 +22792,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0100xxxxxxxxxxxx
                                                      setgm.  */
-                                                  return 3065;
+                                                  return 3071;
                                                 }
                                             }
                                           else
@@ -22735,7 +22801,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xx011101x1xxxxxx1100xxxxxxxxxxxx
                                                  cpymn.  */
-                                              return 3014;
+                                              return 3020;
                                             }
                                         }
                                     }
@@ -22751,7 +22817,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0010xxxxxxxxxxxx
                                                      cpymrt.  */
-                                                  return 3029;
+                                                  return 3035;
                                                 }
                                               else
                                                 {
@@ -22759,7 +22825,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0010xxxxxxxxxxxx
                                                      setgpn.  */
-                                                  return 3070;
+                                                  return 3076;
                                                 }
                                             }
                                           else
@@ -22770,7 +22836,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx1010xxxxxxxxxxxx
                                                      cpymrtrn.  */
-                                                  return 3035;
+                                                  return 3041;
                                                 }
                                               else
                                                 {
@@ -22778,7 +22844,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx1010xxxxxxxxxxxx
                                                      setgen.  */
-                                                  return 3072;
+                                                  return 3078;
                                                 }
                                             }
                                         }
@@ -22792,7 +22858,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0110xxxxxxxxxxxx
                                                      cpymrtwn.  */
-                                                  return 3032;
+                                                  return 3038;
                                                 }
                                               else
                                                 {
@@ -22800,7 +22866,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0110xxxxxxxxxxxx
                                                      setgmn.  */
-                                                  return 3071;
+                                                  return 3077;
                                                 }
                                             }
                                           else
@@ -22809,7 +22875,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xx011101x1xxxxxx1110xxxxxxxxxxxx
                                                  cpymrtn.  */
-                                              return 3038;
+                                              return 3044;
                                             }
                                         }
                                     }
@@ -22828,7 +22894,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0001xxxxxxxxxxxx
                                                      cpymwt.  */
-                                                  return 3017;
+                                                  return 3023;
                                                 }
                                               else
                                                 {
@@ -22836,7 +22902,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0001xxxxxxxxxxxx
                                                      setgpt.  */
-                                                  return 3067;
+                                                  return 3073;
                                                 }
                                             }
                                           else
@@ -22847,7 +22913,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx1001xxxxxxxxxxxx
                                                      cpymwtrn.  */
-                                                  return 3023;
+                                                  return 3029;
                                                 }
                                               else
                                                 {
@@ -22855,7 +22921,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx1001xxxxxxxxxxxx
                                                      setget.  */
-                                                  return 3069;
+                                                  return 3075;
                                                 }
                                             }
                                         }
@@ -22869,7 +22935,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0101xxxxxxxxxxxx
                                                      cpymwtwn.  */
-                                                  return 3020;
+                                                  return 3026;
                                                 }
                                               else
                                                 {
@@ -22877,7 +22943,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0101xxxxxxxxxxxx
                                                      setgmt.  */
-                                                  return 3068;
+                                                  return 3074;
                                                 }
                                             }
                                           else
@@ -22886,7 +22952,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xx011101x1xxxxxx1101xxxxxxxxxxxx
                                                  cpymwtn.  */
-                                              return 3026;
+                                              return 3032;
                                             }
                                         }
                                     }
@@ -22902,7 +22968,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0011xxxxxxxxxxxx
                                                      cpymt.  */
-                                                  return 3041;
+                                                  return 3047;
                                                 }
                                               else
                                                 {
@@ -22910,7 +22976,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0011xxxxxxxxxxxx
                                                      setgptn.  */
-                                                  return 3073;
+                                                  return 3079;
                                                 }
                                             }
                                           else
@@ -22921,7 +22987,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx1011xxxxxxxxxxxx
                                                      cpymtrn.  */
-                                                  return 3047;
+                                                  return 3053;
                                                 }
                                               else
                                                 {
@@ -22929,7 +22995,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx1011xxxxxxxxxxxx
                                                      setgetn.  */
-                                                  return 3075;
+                                                  return 3081;
                                                 }
                                             }
                                         }
@@ -22943,7 +23009,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110101xxxxxx0111xxxxxxxxxxxx
                                                      cpymtwn.  */
-                                                  return 3044;
+                                                  return 3050;
                                                 }
                                               else
                                                 {
@@ -22951,7 +23017,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx01110111xxxxxx0111xxxxxxxxxxxx
                                                      setgmtn.  */
-                                                  return 3074;
+                                                  return 3080;
                                                 }
                                             }
                                           else
@@ -22960,7 +23026,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xx011101x1xxxxxx1111xxxxxxxxxxxx
                                                  cpymtn.  */
-                                              return 3050;
+                                              return 3056;
                                             }
                                         }
                                     }
@@ -23127,7 +23193,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x1001xxxxxxxxxx
                                                          smmla.  */
-                                                      return 2931;
+                                                      return 2937;
                                                     }
                                                 }
                                             }
@@ -23160,7 +23226,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x0101xxxxxxxxxx
                                                          sdot.  */
-                                                      return 2857;
+                                                      return 2863;
                                                     }
                                                 }
                                               else
@@ -23234,7 +23300,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x1011xxxxxxxxxx
                                                          usmmla.  */
-                                                      return 2933;
+                                                      return 2939;
                                                     }
                                                 }
                                             }
@@ -23267,7 +23333,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          0x001110xx0xxxxx1x0111xxxxxxxxxx
                                                          usdot.  */
-                                                      return 2934;
+                                                      return 2940;
                                                     }
                                                 }
                                               else
@@ -23314,7 +23380,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              1x001110000xxxxxxxxxxxxxxxxxxxxx
                                              eor3.  */
-                                          return 2864;
+                                          return 2870;
                                         }
                                       else
                                         {
@@ -23322,7 +23388,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              1x001110100xxxxxxxxxxxxxxxxxxxxx
                                              xar.  */
-                                          return 2866;
+                                          return 2872;
                                         }
                                     }
                                   else
@@ -23333,7 +23399,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              1x001110x10xxxxx0xxxxxxxxxxxxxxx
                                              sm3ss1.  */
-                                          return 2868;
+                                          return 2874;
                                         }
                                       else
                                         {
@@ -23347,7 +23413,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110010xxxxx1xxx00xxxxxxxxxx
                                                          sm3tt1a.  */
-                                                      return 2869;
+                                                      return 2875;
                                                     }
                                                   else
                                                     {
@@ -23355,7 +23421,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110110xxxxx1xxx00xxxxxxxxxx
                                                          sha512su0.  */
-                                                      return 2862;
+                                                      return 2868;
                                                     }
                                                 }
                                               else
@@ -23364,7 +23430,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      1x001110x10xxxxx1xxx10xxxxxxxxxx
                                                      sm3tt2a.  */
-                                                  return 2871;
+                                                  return 2877;
                                                 }
                                             }
                                           else
@@ -23377,7 +23443,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110010xxxxx1xxx01xxxxxxxxxx
                                                          sm3tt1b.  */
-                                                      return 2870;
+                                                      return 2876;
                                                     }
                                                   else
                                                     {
@@ -23385,7 +23451,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          1x001110110xxxxx1xxx01xxxxxxxxxx
                                                          sm4e.  */
-                                                      return 2875;
+                                                      return 2881;
                                                     }
                                                 }
                                               else
@@ -23394,7 +23460,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      1x001110x10xxxxx1xxx11xxxxxxxxxx
                                                      sm3tt2b.  */
-                                                  return 2872;
+                                                  return 2878;
                                                 }
                                             }
                                         }
@@ -23575,7 +23641,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx101110xx0xxxxx100101xxxxxxxxxx
                                                          udot.  */
-                                                      return 2856;
+                                                      return 2862;
                                                     }
                                                 }
                                               else
@@ -23606,7 +23672,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx101110xx0xxxxx101x01xxxxxxxxxx
                                                      ummla.  */
-                                                  return 2932;
+                                                  return 2938;
                                                 }
                                               else
                                                 {
@@ -23625,7 +23691,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xx101110xx0xxxxx1x1011xxxxxxxxxx
                                                      bfmmla.  */
-                                                  return 2948;
+                                                  return 2954;
                                                 }
                                               else
                                                 {
@@ -23635,7 +23701,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx1011100x0xxxxx1x1111xxxxxxxxxx
                                                          bfdot.  */
-                                                      return 2946;
+                                                      return 2952;
                                                     }
                                                   else
                                                     {
@@ -23645,7 +23711,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x01011101x0xxxxx1x1111xxxxxxxxxx
                                                              bfmlalb.  */
-                                                          return 2953;
+                                                          return 2959;
                                                         }
                                                       else
                                                         {
@@ -23653,7 +23719,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x11011101x0xxxxx1x1111xxxxxxxxxx
                                                              bfmlalt.  */
-                                                          return 2952;
+                                                          return 2958;
                                                         }
                                                     }
                                                 }
@@ -24237,7 +24303,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          000011101x1xxxx1011010xxxxxxxxxx
                                                                          bfcvtn.  */
-                                                                      return 2949;
+                                                                      return 2955;
                                                                     }
                                                                   else
                                                                     {
@@ -24245,7 +24311,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          010011101x1xxxx1011010xxxxxxxxxx
                                                                          bfcvtn2.  */
-                                                                      return 2950;
+                                                                      return 2956;
                                                                     }
                                                                 }
                                                             }
@@ -24563,7 +24629,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                          10987654321098765432109876543210
                                          1x001110xx1xxxxx0xxxxxxxxxxxxxxx
                                          bcax.  */
-                                      return 2867;
+                                      return 2873;
                                     }
                                 }
                               else
@@ -25174,7 +25240,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  11001110xx1xxxxx100000xxxxxxxxxx
                                                                  sha512h.  */
-                                                              return 2860;
+                                                              return 2866;
                                                             }
                                                         }
                                                     }
@@ -25226,7 +25292,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  11001110xx1xxxxx110000xxxxxxxxxx
                                                                  sm3partw1.  */
-                                                              return 2873;
+                                                              return 2879;
                                                             }
                                                         }
                                                     }
@@ -25469,7 +25535,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              1x001110xx1xxxxx100010xxxxxxxxxx
                                                              sha512su1.  */
-                                                          return 2863;
+                                                          return 2869;
                                                         }
                                                     }
                                                   else
@@ -25545,7 +25611,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  1x0011100x1xxxxx110010xxxxxxxxxx
                                                                  sm4ekey.  */
-                                                              return 2876;
+                                                              return 2882;
                                                             }
                                                         }
                                                       else
@@ -26371,7 +26437,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              1x001110xx1xxxxx100001xxxxxxxxxx
                                                              sha512h2.  */
-                                                          return 2861;
+                                                          return 2867;
                                                         }
                                                     }
                                                   else
@@ -26403,7 +26469,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  1x0011100x1xxxxx110001xxxxxxxxxx
                                                                  sm3partw2.  */
-                                                              return 2874;
+                                                              return 2880;
                                                             }
                                                         }
                                                       else
@@ -26643,7 +26709,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              1x001110xx1xxxxx100011xxxxxxxxxx
                                                              rax1.  */
-                                                          return 2865;
+                                                          return 2871;
                                                         }
                                                     }
                                                   else
@@ -26675,7 +26741,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x01011100x1xxxxx110011xxxxxxxxxx
                                                                  fmlal2.  */
-                                                              return 2879;
+                                                              return 2885;
                                                             }
                                                           else
                                                             {
@@ -26683,7 +26749,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x11011100x1xxxxx110011xxxxxxxxxx
                                                                  fmlal2.  */
-                                                              return 2883;
+                                                              return 2889;
                                                             }
                                                         }
                                                     }
@@ -26705,7 +26771,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x01011101x1xxxxx110011xxxxxxxxxx
                                                                  fmlsl2.  */
-                                                              return 2880;
+                                                              return 2886;
                                                             }
                                                           else
                                                             {
@@ -26713,7 +26779,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x11011101x1xxxxx110011xxxxxxxxxx
                                                                  fmlsl2.  */
-                                                              return 2884;
+                                                              return 2890;
                                                             }
                                                         }
                                                     }
@@ -26752,7 +26818,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x00011100x1xxxxx111011xxxxxxxxxx
                                                                  fmlal.  */
-                                                              return 2877;
+                                                              return 2883;
                                                             }
                                                           else
                                                             {
@@ -26760,7 +26826,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10011100x1xxxxx111011xxxxxxxxxx
                                                                  fmlal.  */
-                                                              return 2881;
+                                                              return 2887;
                                                             }
                                                         }
                                                       else
@@ -26782,7 +26848,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x00011101x1xxxxx111011xxxxxxxxxx
                                                                  fmlsl.  */
-                                                              return 2878;
+                                                              return 2884;
                                                             }
                                                           else
                                                             {
@@ -26790,7 +26856,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  x10011101x1xxxxx111011xxxxxxxxxx
                                                                  fmlsl.  */
-                                                              return 2882;
+                                                              return 2888;
                                                             }
                                                         }
                                                       else
@@ -28598,7 +28664,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0001111xxxxxxxx0000x0xxxxxxxxxx
                                                      fmlal.  */
-                                                  return 2885;
+                                                  return 2891;
                                                 }
                                               else
                                                 {
@@ -28606,7 +28672,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1001111xxxxxxxx0000x0xxxxxxxxxx
                                                      fmlal.  */
-                                                  return 2889;
+                                                  return 2895;
                                                 }
                                             }
                                           else
@@ -28628,7 +28694,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0001111xxxxxxxx0100x0xxxxxxxxxx
                                                      fmlsl.  */
-                                                  return 2886;
+                                                  return 2892;
                                                 }
                                               else
                                                 {
@@ -28636,7 +28702,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1001111xxxxxxxx0100x0xxxxxxxxxx
                                                      fmlsl.  */
-                                                  return 2890;
+                                                  return 2896;
                                                 }
                                             }
                                           else
@@ -29142,7 +29208,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0101111xxxxxxxx1000x0xxxxxxxxxx
                                                      fmlal2.  */
-                                                  return 2887;
+                                                  return 2893;
                                                 }
                                               else
                                                 {
@@ -29150,7 +29216,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1101111xxxxxxxx1000x0xxxxxxxxxx
                                                      fmlal2.  */
-                                                  return 2891;
+                                                  return 2897;
                                                 }
                                             }
                                         }
@@ -29172,7 +29238,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x0101111xxxxxxxx1100x0xxxxxxxxxx
                                                      fmlsl2.  */
-                                                  return 2888;
+                                                  return 2894;
                                                 }
                                               else
                                                 {
@@ -29180,7 +29246,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      x1101111xxxxxxxx1100x0xxxxxxxxxx
                                                      fmlsl2.  */
-                                                  return 2892;
+                                                  return 2898;
                                                 }
                                             }
                                         }
@@ -29236,7 +29302,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xx001111xxxxxxxx1110x0xxxxxxxxxx
                                                  sdot.  */
-                                              return 2859;
+                                              return 2865;
                                             }
                                           else
                                             {
@@ -29244,7 +29310,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xx101111xxxxxxxx1110x0xxxxxxxxxx
                                                  udot.  */
-                                              return 2858;
+                                              return 2864;
                                             }
                                         }
                                     }
@@ -29347,7 +29413,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx00111100xxxxxx1111x0xxxxxxxxxx
                                                          sudot.  */
-                                                      return 2936;
+                                                      return 2942;
                                                     }
                                                   else
                                                     {
@@ -29355,7 +29421,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx00111110xxxxxx1111x0xxxxxxxxxx
                                                          usdot.  */
-                                                      return 2935;
+                                                      return 2941;
                                                     }
                                                 }
                                               else
@@ -29366,7 +29432,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xx00111101xxxxxx1111x0xxxxxxxxxx
                                                          bfdot.  */
-                                                      return 2947;
+                                                      return 2953;
                                                     }
                                                   else
                                                     {
@@ -29376,7 +29442,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x000111111xxxxxx1111x0xxxxxxxxxx
                                                              bfmlalb.  */
-                                                          return 2955;
+                                                          return 2961;
                                                         }
                                                       else
                                                         {
@@ -29384,7 +29450,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              x100111111xxxxxx1111x0xxxxxxxxxx
                                                              bfmlalt.  */
-                                                          return 2954;
+                                                          return 2960;
                                                         }
                                                     }
                                                 }
@@ -29875,22 +29941,22 @@ aarch64_find_next_opcode (const aarch64_opcode *opcode)
     case 2391: return NULL;		/* mova --> NULL.  */
     case 2388: value = 2390; break;	/* mov --> mova.  */
     case 2390: return NULL;		/* mova --> NULL.  */
+    case 2594: value = 2602; break;	/* mov --> mova.  */
+    case 2602: return NULL;		/* mova --> NULL.  */
+    case 2590: value = 2598; break;	/* mov --> mova.  */
+    case 2598: return NULL;		/* mova --> NULL.  */
     case 2592: value = 2600; break;	/* mov --> mova.  */
     case 2600: return NULL;		/* mova --> NULL.  */
     case 2588: value = 2596; break;	/* mov --> mova.  */
     case 2596: return NULL;		/* mova --> NULL.  */
-    case 2590: value = 2598; break;	/* mov --> mova.  */
-    case 2598: return NULL;		/* mova --> NULL.  */
-    case 2586: value = 2594; break;	/* mov --> mova.  */
-    case 2594: return NULL;		/* mova --> NULL.  */
+    case 2595: value = 2603; break;	/* mov --> mova.  */
+    case 2603: return NULL;		/* mova --> NULL.  */
+    case 2591: value = 2599; break;	/* mov --> mova.  */
+    case 2599: return NULL;		/* mova --> NULL.  */
     case 2593: value = 2601; break;	/* mov --> mova.  */
     case 2601: return NULL;		/* mova --> NULL.  */
     case 2589: value = 2597; break;	/* mov --> mova.  */
     case 2597: return NULL;		/* mova --> NULL.  */
-    case 2591: value = 2599; break;	/* mov --> mova.  */
-    case 2599: return NULL;		/* mova --> NULL.  */
-    case 2587: value = 2595; break;	/* mov --> mova.  */
-    case 2595: return NULL;		/* mova --> NULL.  */
     case 2393: value = 2398; break;	/* ld1b --> ld1b.  */
     case 2398: return NULL;		/* ld1b --> NULL.  */
     case 2395: value = 2400; break;	/* ld1w --> ld1w.  */
@@ -29912,11 +29978,11 @@ aarch64_find_next_opcode (const aarch64_opcode *opcode)
     case 2407: value = 2412; break;	/* st1q --> st1q.  */
     case 2412: return NULL;		/* st1q --> NULL.  */
     case 12: value = 19; break;	/* add --> addg.  */
-    case 19: value = 3077; break;	/* addg --> smax.  */
-    case 3077: value = 3078; break;	/* smax --> umax.  */
-    case 3078: value = 3079; break;	/* umax --> smin.  */
-    case 3079: value = 3080; break;	/* smin --> umin.  */
-    case 3080: return NULL;		/* umin --> NULL.  */
+    case 19: value = 3083; break;	/* addg --> smax.  */
+    case 3083: value = 3084; break;	/* smax --> umax.  */
+    case 3084: value = 3085; break;	/* umax --> smin.  */
+    case 3085: value = 3086; break;	/* smin --> umin.  */
+    case 3086: return NULL;		/* umin --> NULL.  */
     case 16: value = 20; break;	/* sub --> subg.  */
     case 20: return NULL;		/* subg --> NULL.  */
     case 971: value = 975; break;	/* stnp --> stp.  */
@@ -30074,8 +30140,8 @@ aarch64_find_next_opcode (const aarch64_opcode *opcode)
     case 824: return NULL;		/* fsqrt --> NULL.  */
     case 832: value = 833; break;	/* frintz --> frintz.  */
     case 833: return NULL;		/* frintz --> NULL.  */
-    case 825: value = 2951; break;	/* fcvt --> bfcvt.  */
-    case 2951: return NULL;		/* bfcvt --> NULL.  */
+    case 825: value = 2957; break;	/* fcvt --> bfcvt.  */
+    case 2957: return NULL;		/* bfcvt --> NULL.  */
     case 834: value = 835; break;	/* frinta --> frinta.  */
     case 835: return NULL;		/* frinta --> NULL.  */
     case 836: value = 837; break;	/* frintx --> frintx.  */
diff --git a/opcodes/aarch64-tbl.h b/opcodes/aarch64-tbl.h
index 51dfc60e116..cb6f0d65769 100644
--- a/opcodes/aarch64-tbl.h
+++ b/opcodes/aarch64-tbl.h
@@ -5372,6 +5372,8 @@ const struct aarch64_opcode aarch64_opcode_table[] =
   SME2_INSN ("bfmlsl", 0xc1a00818, 0xffe19c3c, sme_misc, 0, OP3 (SME_ZA_array_off2x2, SME_Znx2, SME_Zmx2), OP_SVE_SHH, F_OD (2), 0),
   SME2_INSN ("bfmlsl", 0xc1a10818, 0xffe39c7c, sme_misc, 0, OP3 (SME_ZA_array_off2x2, SME_Znx4, SME_Zmx4), OP_SVE_SHH, F_OD (4), 0),
   SME2_INSN ("bfvdot", 0xc1500018, 0xfff09038, sme_misc, 0, OP3 (SME_ZA_array_off3_0, SME_Znx2, SME_Zm_INDEX2), OP_SVE_SHH, F_OD (2), 0),
+  SME2_INSN ("bmopa", 0x80800008, 0xffe0001c, sme_misc, 0, OP5 (SME_ZAda_2b, SVE_Pg3, SME_Pm, SVE_Zn, SVE_Zm_16), OP_SVE_SMMSS, 0, 0),
+  SME2_INSN ("bmops", 0x80800018, 0xffe0001c, sme_misc, 0, OP5 (SME_ZAda_2b, SVE_Pg3, SME_Pm, SVE_Zn, SVE_Zm_16), OP_SVE_SMMSS, 0, 0),
   SME2_INSN ("cntp", 0x25208200, 0xff3ffa00, sme_size_22, 0, OP3 (Rd, SME_PNn, SME_VLxN_10), OP_SVE_XV_BHSD, 0, 0),
   SME2_INSN ("fadd", 0xc1a01c00, 0xffbf9c38, sme_fp_sd, 0, OP2 (SME_ZA_array_off3_0, SME_Znx2), OP_SVE_VVV_SD, F_OD (2), 0),
   SME2_INSN ("fadd", 0xc1a11c00, 0xffbf9c78, sme_fp_sd, 0, OP2 (SME_ZA_array_off3_0, SME_Znx4), OP_SVE_VVV_SD, F_OD (4), 0),
@@ -5574,6 +5576,8 @@ const struct aarch64_opcode aarch64_opcode_table[] =
   SME2_INSN ("smlsll", 0xc1300008, 0xffb09c1e, sme_int_sd, 0, OP3 (SME_ZA_array_off1x4, SVE_ZnxN, SME_Zm), OP_SVE_VVV_SD_BH, F_OD (4), 0),
   SME2_INSN ("smlsll", 0xc1a00008, 0xffa19c3e, sme_int_sd, 0, OP3 (SME_ZA_array_off1x4, SME_Znx2, SME_Zmx2), OP_SVE_VVV_SD_BH, F_OD (2), 0),
   SME2_INSN ("smlsll", 0xc1a10008, 0xffa39c7e, sme_int_sd, 0, OP3 (SME_ZA_array_off1x4, SME_Znx4, SME_Zmx4), OP_SVE_VVV_SD_BH, F_OD (4), 0),
+  SME2_INSN ("smopa", 0xa0800008, 0xffe0001c, sme_misc, 0, OP5 (SME_ZAda_2b, SVE_Pg3, SME_Pm, SVE_Zn, SVE_Zm_16), OP_SVE_SMMHH, 0, 0),
+  SME2_INSN ("smops", 0xa0800018, 0xffe0001c, sme_misc, 0, OP5 (SME_ZAda_2b, SVE_Pg3, SME_Pm, SVE_Zn, SVE_Zm_16), OP_SVE_SMMHH, 0, 0),
   SME2_INSN ("sqdmulh", 0xc120a400, 0xff30ffe1, sme_size_22, 0, OP3 (SME_Zdnx2, SME_Zdnx2, SME_Zm), OP_SVE_VVV_BHSD, 0, 1),
   SME2_INSN ("sqdmulh", 0xc120ac00, 0xff30ffe3, sme_size_22, 0, OP3 (SME_Zdnx4, SME_Zdnx4, SME_Zm), OP_SVE_VVV_BHSD, 0, 1),
   SME2_INSN ("sqdmulh", 0xc120b400, 0xff21ffe1, sme_size_22, 0, OP3 (SME_Zdnx2, SME_Zdnx2, SME_Zmx2), OP_SVE_VVV_BHSD, 0, 1),
@@ -5717,6 +5721,8 @@ const struct aarch64_opcode aarch64_opcode_table[] =
   SME2_INSN ("umlsll", 0xc1300018, 0xffb09c1e, sme_int_sd, 0, OP3 (SME_ZA_array_off1x4, SVE_ZnxN, SME_Zm), OP_SVE_VVV_SD_BH, F_OD (4), 0),
   SME2_INSN ("umlsll", 0xc1a00018, 0xffa19c3e, sme_int_sd, 0, OP3 (SME_ZA_array_off1x4, SME_Znx2, SME_Zmx2), OP_SVE_VVV_SD_BH, F_OD (2), 0),
   SME2_INSN ("umlsll", 0xc1a10018, 0xffa39c7e, sme_int_sd, 0, OP3 (SME_ZA_array_off1x4, SME_Znx4, SME_Zmx4), OP_SVE_VVV_SD_BH, F_OD (4), 0),
+  SME2_INSN ("umopa", 0xa1800008, 0xffe0001c, sme_misc, 0, OP5 (SME_ZAda_2b, SVE_Pg3, SME_Pm, SVE_Zn, SVE_Zm_16), OP_SVE_SMMHH, 0, 0),
+  SME2_INSN ("umops", 0xa1800018, 0xffe0001c, sme_misc, 0, OP5 (SME_ZAda_2b, SVE_Pg3, SME_Pm, SVE_Zn, SVE_Zm_16), OP_SVE_SMMHH, 0, 0),
   SME2_INSN ("urshl", 0xc120a221, 0xff30ffe1, sme_size_22, 0, OP3 (SME_Zdnx2, SME_Zdnx2, SME_Zm), OP_SVE_VVV_BHSD, 0, 1),
   SME2_INSN ("urshl", 0xc120aa21, 0xff30ffe3, sme_size_22, 0, OP3 (SME_Zdnx4, SME_Zdnx4, SME_Zm), OP_SVE_VVV_BHSD, 0, 1),
   SME2_INSN ("urshl", 0xc120b221, 0xff21ffe1, sme_size_22, 0, OP3 (SME_Zdnx2, SME_Zdnx2, SME_Zmx2), OP_SVE_VVV_BHSD, 0, 1),
-- 
2.25.1


  parent reply	other threads:[~2023-03-30 10:27 UTC|newest]

Thread overview: 40+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-03-30 10:26 [PATCH 00/31] aarch64: Add SME2 support Richard Sandiford
2023-03-30 10:26 ` [PATCH 01/31] aarch64: Add +sme2 Richard Sandiford
2023-03-30 10:26 ` [PATCH 02/31] aarch64: Add a _10 suffix to FLD_imm3 Richard Sandiford
2023-03-30 10:26 ` [PATCH 03/31] aarch64: Add _off4 suffix to AARCH64_OPND_SME_ZA_array Richard Sandiford
2023-03-30 10:26 ` [PATCH 04/31] aarch64: Add support for vgx2 and vgx4 Richard Sandiford
2023-03-30 10:26 ` [PATCH 05/31] aarch64; Add support for vector offset ranges Richard Sandiford
2023-03-30 10:26 ` [PATCH 06/31] aarch64: Add support for predicate-as-counter registers Richard Sandiford
2023-03-30 10:26 ` [PATCH 07/31] aarch64: Add the SME2 MOVA instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 08/31] aarch64: Add the SME2 multivector LD1 and ST1 instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 09/31] aarch64: Add the SME2 predicate-related instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 10/31] aarch64: Add the SME2 ZT0 instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 11/31] aarch64: Add the SME2 ADD and SUB instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 12/31] aarch64: Add the SME2 maximum/minimum instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 13/31] aarch64: Add the SME2 FMLA and FMLS instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 14/31] aarch64: Add the SME2 MLAL and MLSL instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 15/31] aarch64: Add the SME2 MLALL and MLSLL instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 16/31] aarch64: Add the SME2 dot-product instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 17/31] aarch64: Add the SME2 vertical " Richard Sandiford
2023-03-30 10:26 ` Richard Sandiford [this message]
2023-03-30 10:26 ` [PATCH 19/31] aarch64: Add the SME2 CLAMP instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 20/31] aarch64: Add the SME2 FP<->int conversion instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 21/31] aarch64: Add the SME2 FP<->FP " Richard Sandiford
2023-03-30 10:26 ` [PATCH 22/31] aarch64: Add the SME2 saturating " Richard Sandiford
2023-03-30 10:26 ` [PATCH 23/31] aarch64: Add the SME2 shift instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 24/31] aarch64: Add the SME2 UNPK instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 25/31] aarch64: Add the SME2 UZP and ZIP instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 26/31] aarch64: Add the SVE BFMLSL instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 27/31] aarch64: Add new SVE dot-product instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 28/31] aarch64: Add new SVE saturating conversion instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 29/31] aarch64: Add new SVE shift instructions Richard Sandiford
2023-03-30 10:26 ` [PATCH 30/31] aarch64: Add the SVE FCLAMP instruction Richard Sandiford
2023-03-30 10:26 ` [PATCH 31/31] aarch64: Add the RPRFM instruction Richard Sandiford
2023-04-02  9:35 ` [PATCH 00/31] aarch64: Add SME2 support Jan Beulich
2023-04-03  8:05   ` Richard Sandiford
2023-04-03  8:14     ` Jan Beulich
2023-04-03  8:27       ` Richard Sandiford
2023-04-03  8:37         ` Jan Beulich
2023-04-03  9:31           ` Richard Sandiford
2023-04-03  7:16 ` Jan Beulich
2023-04-03  8:13   ` Richard Sandiford

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20230330102646.3327818-19-richard.sandiford@arm.com \
    --to=richard.sandiford@arm.com \
    --cc=binutils@sourceware.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).