[AArch64] Additional SVE instructions
authorRichard Sandiford <richard.sandiford@arm.com>
Fri, 24 Feb 2017 18:29:00 +0000 (18:29 +0000)
committerRichard Sandiford <richard.sandiford@arm.com>
Fri, 24 Feb 2017 18:29:00 +0000 (18:29 +0000)
This patch supports some additions to the SVE architecture prior to
its public release.

include/
* opcode/aarch64.h (AARCH64_OPND_SVE_ADDR_RI_S4x16)
(AARCH64_OPND_SVE_IMM_ROT1, AARCH64_OPND_SVE_IMM_ROT2)
(AARCH64_OPND_SVE_Zm3_INDEX, AARCH64_OPND_SVE_Zm3_22_INDEX)
(AARCH64_OPND_SVE_Zm4_INDEX): New aarch64_opnds.

opcodes/
* aarch64-tbl.h (OP_SVE_HMH, OP_SVE_VMU_HSD, OP_SVE_VMVU_HSD)
(OP_SVE_VMVV_HSD, OP_SVE_VMVVU_HSD, OP_SVE_VM_HSD, OP_SVE_VUVV_HSD)
(OP_SVE_VUV_HSD, OP_SVE_VU_HSD, OP_SVE_VVVU_H, OP_SVE_VVVU_S)
(OP_SVE_VVVU_HSD, OP_SVE_VVV_D, OP_SVE_VVV_D_H, OP_SVE_VVV_H)
(OP_SVE_VVV_HSD, OP_SVE_VVV_S, OP_SVE_VVV_S_B, OP_SVE_VVV_SD_BH)
(OP_SVE_VV_BHSDQ, OP_SVE_VV_HSD, OP_SVE_VZVV_HSD, OP_SVE_VZV_HSD)
(OP_SVE_V_HSD): New macros.
(OP_SVE_VMU_SD, OP_SVE_VMVU_SD, OP_SVE_VM_SD, OP_SVE_VUVV_SD)
(OP_SVE_VU_SD, OP_SVE_VVVU_SD, OP_SVE_VVV_SD, OP_SVE_VZVV_SD)
(OP_SVE_VZV_SD, OP_SVE_V_SD): Delete.
(aarch64_opcode_table): Add new SVE instructions.
(aarch64_opcode_table): Use imm_rotate{1,2} instead of imm_rotate
for rotation operands.  Add new SVE operands.
* aarch64-asm.h (ins_sve_addr_ri_s4): New inserter.
(ins_sve_quad_index): Likewise.
(ins_imm_rotate): Split into...
(ins_imm_rotate1, ins_imm_rotate2): ...these two inserters.
* aarch64-asm.c (aarch64_ins_imm_rotate): Split into...
(aarch64_ins_imm_rotate1, aarch64_ins_imm_rotate2): ...these two
functions.
(aarch64_ins_sve_addr_ri_s4): New function.
(aarch64_ins_sve_quad_index): Likewise.
(do_misc_encoding): Handle "MOV Zn.Q, Qm".
* aarch64-asm-2.c: Regenerate.
* aarch64-dis.h (ext_sve_addr_ri_s4): New extractor.
(ext_sve_quad_index): Likewise.
(ext_imm_rotate): Split into...
(ext_imm_rotate1, ext_imm_rotate2): ...these two extractors.
* aarch64-dis.c (aarch64_ext_imm_rotate): Split into...
(aarch64_ext_imm_rotate1, aarch64_ext_imm_rotate2): ...these two
functions.
(aarch64_ext_sve_addr_ri_s4): New function.
(aarch64_ext_sve_quad_index): Likewise.
(aarch64_ext_sve_index): Allow quad indices.
(do_misc_decoding): Likewise.
* aarch64-dis-2.c: Regenerate.
* aarch64-opc.h (FLD_SVE_i3h, FLD_SVE_rot1, FLD_SVE_rot2): New
aarch64_field_kinds.
(OPD_F_OD_MASK): Widen by one bit.
(OPD_F_NO_ZR): Bump accordingly.
(get_operand_field_width): New function.
* aarch64-opc.c (fields): Add new SVE fields.
(operand_general_constraint_met_p): Handle new SVE operands.
(aarch64_print_operand): Likewise.
* aarch64-opc-2.c: Regenerate.

gas/
* doc/c-aarch64.texi: Document that sve implies fp16, simd and compnum.
* config/tc-aarch64.c (parse_vector_type_for_operand): Allow .q
to be used with SVE registers.
(parse_operands): Handle new SVE operands.
(aarch64_features): Make "sve" require F16 rather than FP.  Also
require COMPNUM.
* testsuite/gas/aarch64/sve.s: Add tests for new instructions.
Include compnum tests.
* testsuite/gas/aarch64/sve.d: Update accordingly.
* testsuite/gas/aarch64/sve-invalid.s: Add tests for new instructions.
* testsuite/gas/aarch64/sve-invalid.l: Update accordingly.  Also
update expected output for new FMOV and MOV alternatives.

20 files changed:
gas/ChangeLog
gas/config/tc-aarch64.c
gas/doc/c-aarch64.texi
gas/testsuite/gas/aarch64/sve-invalid.l
gas/testsuite/gas/aarch64/sve-invalid.s
gas/testsuite/gas/aarch64/sve.d
gas/testsuite/gas/aarch64/sve.s
include/ChangeLog
include/opcode/aarch64.h
opcodes/ChangeLog
opcodes/aarch64-asm-2.c
opcodes/aarch64-asm.c
opcodes/aarch64-asm.h
opcodes/aarch64-dis-2.c
opcodes/aarch64-dis.c
opcodes/aarch64-dis.h
opcodes/aarch64-opc-2.c
opcodes/aarch64-opc.c
opcodes/aarch64-opc.h
opcodes/aarch64-tbl.h

index 92137405c14791c878a4e066ecfd3a7c3fb71b07..09f7771d9ed6a03a77ed65113edbad04a06c53d1 100644 (file)
@@ -1,3 +1,18 @@
+2017-02-24  Richard Sandiford  <richard.sandiford@arm.com>
+
+       * doc/c-aarch64.texi: Document that sve implies fp16, simd and compnum.
+       * config/tc-aarch64.c (parse_vector_type_for_operand): Allow .q
+       to be used with SVE registers.
+       (parse_operands): Handle new SVE operands.
+       (aarch64_features): Make "sve" require F16 rather than FP.  Also
+       require COMPNUM.
+       * testsuite/gas/aarch64/sve.s: Add tests for new instructions.
+       Include compnum tests.
+       * testsuite/gas/aarch64/sve.d: Update accordingly.
+       * testsuite/gas/aarch64/sve-invalid.s: Add tests for new instructions.
+       * testsuite/gas/aarch64/sve-invalid.l: Update accordingly.  Also
+       update expected output for new FMOV and MOV alternatives.
+
 2017-02-24  Richard Sandiford  <richard.sandiford@arm.com>
 
        * doc/c-aarch64.texi: Add a "compnum" entry.
index 46b1e701e4afadedda3189caeba6315c61c260be..969c18cfedaf53641e2162d5ef75f351c441f66b 100644 (file)
@@ -837,7 +837,7 @@ elt_size:
       element_size = 64;
       break;
     case 'q':
-      if (width == 1)
+      if (reg_type == REG_TYPE_ZN || width == 1)
        {
          type = NT_q;
          element_size = 128;
@@ -5431,6 +5431,9 @@ parse_operands (char *str, const aarch64_opcode *opcode)
          info->qualifier = AARCH64_OPND_QLF_S_D;
          break;
 
+       case AARCH64_OPND_SVE_Zm3_INDEX:
+       case AARCH64_OPND_SVE_Zm3_22_INDEX:
+       case AARCH64_OPND_SVE_Zm4_INDEX:
        case AARCH64_OPND_SVE_Zn_INDEX:
          reg_type = REG_TYPE_ZN;
          goto vector_reg_index;
@@ -5567,6 +5570,8 @@ parse_operands (char *str, const aarch64_opcode *opcode)
        case AARCH64_OPND_IMM_ROT1:
        case AARCH64_OPND_IMM_ROT2:
        case AARCH64_OPND_IMM_ROT3:
+       case AARCH64_OPND_SVE_IMM_ROT1:
+       case AARCH64_OPND_SVE_IMM_ROT2:
          po_imm_nc_or_fail ();
          info->imm.value = val;
          break;
@@ -6090,6 +6095,7 @@ parse_operands (char *str, const aarch64_opcode *opcode)
          /* No qualifier.  */
          break;
 
+       case AARCH64_OPND_SVE_ADDR_RI_S4x16:
        case AARCH64_OPND_SVE_ADDR_RI_S4xVL:
        case AARCH64_OPND_SVE_ADDR_RI_S4x2xVL:
        case AARCH64_OPND_SVE_ADDR_RI_S4x3xVL:
@@ -8436,8 +8442,9 @@ static const struct aarch64_option_cpu_value_table aarch64_features[] = {
   {"profile",          AARCH64_FEATURE (AARCH64_FEATURE_PROFILE, 0),
                        AARCH64_ARCH_NONE},
   {"sve",              AARCH64_FEATURE (AARCH64_FEATURE_SVE, 0),
-                       AARCH64_FEATURE (AARCH64_FEATURE_FP
-                                        | AARCH64_FEATURE_SIMD, 0)},
+                       AARCH64_FEATURE (AARCH64_FEATURE_F16
+                                        | AARCH64_FEATURE_SIMD
+                                        | AARCH64_FEATURE_COMPNUM, 0)},
   {"compnum",          AARCH64_FEATURE (AARCH64_FEATURE_COMPNUM, 0),
                        AARCH64_FEATURE (AARCH64_FEATURE_F16
                                         | AARCH64_FEATURE_SIMD, 0)},
index 71d8072f43350ca9620db860d76a70442618b3a5..f5be0d43bf57caf4a055002f1a2b1803ca97b7a8 100644 (file)
@@ -158,8 +158,9 @@ automatically cause those extensions to be disabled.
  @tab Enable ARMv8.1 Advanced SIMD extensions.  This implies @code{simd}.
 @item @code{simd} @tab ARMv8-A @tab ARMv8-A or later
  @tab Enable Advanced SIMD extensions.  This implies @code{fp}.
-@item @code{sve} @tab ARMv8-A @tab No
- @tab Enable the Scalable Vector Extensions.  This implies @code{simd}.
+@item @code{sve} @tab ARMv8.2-A @tab No
+ @tab Enable the Scalable Vector Extensions.  This implies @code{fp16},
+ @code{simd} and @code{compnum}.
 @end multitable
 
 @node AArch64 Syntax
index 58739b370da7bc3a7545d0ab07ffc305b072f866..6e614c3f6ee1d2dd14ee8caa5b64efa95117063d 100644 (file)
@@ -2,13 +2,15 @@
 .*: Error: operand 2 must be an SVE predicate register -- `fmov z1,z2'
 .*: Error: operand mismatch -- `fmov z1,#1\.0'
 .*: Info:    did you mean this\?
-.*: Info:      fmov z1\.s, #1\.000000000000000000e\+00
+.*: Info:      fmov z1\.h, #1\.000000000000000000e\+00
 .*: Info:    other valid variant\(s\):
+.*: Info:      fmov z1\.s, #1\.000000000000000000e\+00
 .*: Info:      fmov z1\.d, #1\.000000000000000000e\+00
 .*: Error: operand mismatch -- `fmov z1,#0\.0'
 .*: Info:    did you mean this\?
-.*: Info:      fmov z1\.s, #0\.0
+.*: Info:      fmov z1\.h, #0\.0
 .*: Info:    other valid variant\(s\):
+.*: Info:      fmov z1\.s, #0\.0
 .*: Info:      fmov z1\.d, #0\.0
 .*: Error: missing predication type at operand 2 -- `not z0\.s,p1/'
 .*: Error: missing predication type at operand 2 -- `not z0\.s,p1/,z2\.s'
 .*: Info:      mov z0\.h, h0
 .*: Info:      mov z0\.s, s0
 .*: Info:      mov z0\.d, d0
+.*: Info:      mov z0\.q, q0
 .*: Error: operand mismatch -- `mov z0,z1'
 .*: Info:    did you mean this\?
 .*: Info:      mov z0\.d, z1\.d
 .*: Error: register element index out of range 0 to 7 at operand 2 -- `dup z0\.d,z1\.d\[-1\]'
 .*: Error: register element index out of range 0 to 7 at operand 2 -- `dup z0\.d,z1\.d\[8\]'
 .*: Error: constant expression required at operand 2 -- `dup z0\.d,z1\.d\[x0\]'
+.*: Error: operand mismatch -- `fabd z0\.b,p0/m,z0\.b,z0\.b'
+.*: Info:    did you mean this\?
+.*: Info:      fabd z0\.h, p0/m, z0\.h, z0\.h
+.*: Info:    other valid variant\(s\):
+.*: Info:      fabd z0\.s, p0/m, z0\.s, z0\.s
+.*: Info:      fabd z0\.d, p0/m, z0\.d, z0\.d
+.*: Error: operand mismatch -- `fabd z0\.q,p0/m,z0\.q,z0\.q'
+.*: Info:    did you mean this\?
+.*: Info:      fabd z0\.h, p0/m, z0\.h, z0\.h
+.*: Info:    other valid variant\(s\):
+.*: Info:      fabd z0\.s, p0/m, z0\.s, z0\.s
+.*: Info:      fabd z0\.d, p0/m, z0\.d, z0\.d
+.*: Error: operand mismatch -- `fcadd z0\.b,p0/m,z0\.b,z0\.b,#90'
+.*: Info:    did you mean this\?
+.*: Info:      fcadd z0\.h, p0/m, z0\.h, z0\.h, #90
+.*: Info:    other valid variant\(s\):
+.*: Info:      fcadd z0\.s, p0/m, z0\.s, z0\.s, #90
+.*: Info:      fcadd z0\.d, p0/m, z0\.d, z0\.d, #90
+.*: Error: rotate expected to be 90 or 270 at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#-180'
+.*: Error: rotate expected to be 90 or 270 at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#-90'
+.*: Error: rotate expected to be 90 or 270 at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#0'
+.*: Error: rotate expected to be 90 or 270 at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#89'
+.*: Error: unexpected characters following instruction at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#90\.0'
+.*: Error: rotate expected to be 90 or 270 at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#180'
+.*: Error: rotate expected to be 90 or 270 at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#360'
+.*: Error: rotate expected to be 90 or 270 at operand 5 -- `fcadd z0\.h,p0/m,z0\.h,z0\.h,#450'
+.*: Error: operand mismatch -- `fcadd z0\.h,p0/z,z0\.h,z0\.h,#90'
+.*: Info:    did you mean this\?
+.*: Info:      fcadd z0\.h, p0/m, z0\.h, z0\.h, #90
+.*: Info:    other valid variant\(s\):
+.*: Info:      fcadd z0\.s, p0/m, z0\.s, z0\.s, #90
+.*: Info:      fcadd z0\.d, p0/m, z0\.d, z0\.d, #90
+.*: Error: operand 3 must be the same register as operand 1 -- `fcadd z0\.h,p0/m,z1\.h,z0\.h,#90'
+.*: Error: operand mismatch -- `fcadd z0\.q,p0/m,z0\.q,z0\.q,#90'
+.*: Info:    did you mean this\?
+.*: Info:      fcadd z0\.h, p0/m, z0\.h, z0\.h, #90
+.*: Info:    other valid variant\(s\):
+.*: Info:      fcadd z0\.s, p0/m, z0\.s, z0\.s, #90
+.*: Info:      fcadd z0\.d, p0/m, z0\.d, z0\.d, #90
+.*: Error: operand mismatch -- `fcmla z0\.b,p0/m,z0\.b,z0\.b,#90'
+.*: Info:    did you mean this\?
+.*: Info:      fcmla z0\.h, p0/m, z0\.h, z0\.h, #90
+.*: Info:    other valid variant\(s\):
+.*: Info:      fcmla z0\.s, p0/m, z0\.s, z0\.s, #90
+.*: Info:      fcmla z0\.d, p0/m, z0\.d, z0\.d, #90
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 5 -- `fcmla z0\.h,p0/m,z0\.h,z0\.h,#-180'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 5 -- `fcmla z0\.h,p0/m,z0\.h,z0\.h,#-90'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 5 -- `fcmla z0\.h,p0/m,z0\.h,z0\.h,#89'
+.*: Error: unexpected characters following instruction at operand 5 -- `fcmla z0\.h,p0/m,z0\.h,z0\.h,#90\.0'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 5 -- `fcmla z0\.h,p0/m,z0\.h,z0\.h,#360'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 5 -- `fcmla z0\.h,p0/m,z0\.h,z0\.h,#450'
+.*: Error: operand mismatch -- `fcmla z0\.h,p0/z,z0\.h,z0\.h,#90'
+.*: Info:    did you mean this\?
+.*: Info:      fcmla z0\.h, p0/m, z0\.h, z0\.h, #90
+.*: Info:    other valid variant\(s\):
+.*: Info:      fcmla z0\.s, p0/m, z0\.s, z0\.s, #90
+.*: Info:      fcmla z0\.d, p0/m, z0\.d, z0\.d, #90
+.*: Error: operand mismatch -- `fcmla z0\.q,p0/m,z0\.q,z0\.q,#90'
+.*: Info:    did you mean this\?
+.*: Info:      fcmla z0\.h, p0/m, z0\.h, z0\.h, #90
+.*: Info:    other valid variant\(s\):
+.*: Info:      fcmla z0\.s, p0/m, z0\.s, z0\.s, #90
+.*: Info:      fcmla z0\.d, p0/m, z0\.d, z0\.d, #90
+.*: Error: operand mismatch -- `fcmla z0\.b,z1\.b,z2\.b\[0\],#0'
+.*: Info:    did you mean this\?
+.*: Info:      fcmla z0\.h, z1\.h, z2\.h\[0\], #0
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fcmla z0\.h,z1\.h,z2\.h\[-1\],#0'
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fcmla z0\.h,z1\.h,z2\.h\[4\],#0'
+.*: Error: z0-z7 expected at operand 3 -- `fcmla z0\.h,z1\.h,z8\.h\[0\],#0'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.h,z1\.h,z2\.h\[0\],#-180'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.h,z1\.h,z2\.h\[0\],#-90'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.h,z1\.h,z2\.h\[0\],#89'
+.*: Error: unexpected characters following instruction at operand 4 -- `fcmla z0\.h,z1\.h,z2\.h\[0\],#90\.0'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.h,z1\.h,z2\.h\[0\],#360'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.h,z1\.h,z2\.h\[0\],#450'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fcmla z0\.s,z1\.s,z2\.s\[-1\],#0'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fcmla z0\.s,z1\.s,z2\.s\[2\],#0'
+.*: Error: z0-z15 expected at operand 3 -- `fcmla z0\.s,z1\.s,z16\.s\[0\],#0'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.s,z1\.s,z2\.s\[0\],#-180'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.s,z1\.s,z2\.s\[0\],#-90'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.s,z1\.s,z2\.s\[0\],#89'
+.*: Error: unexpected characters following instruction at operand 4 -- `fcmla z0\.s,z1\.s,z2\.s\[0\],#90\.0'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.s,z1\.s,z2\.s\[0\],#360'
+.*: Error: rotate expected to be 0, 90, 180 or 270 at operand 4 -- `fcmla z0\.s,z1\.s,z2\.s\[0\],#450'
+.*: Error: operand mismatch -- `fcmla z0\.q,z1\.q,z2\.q\[0\],#0'
+.*: Info:    did you mean this\?
+.*: Info:      fcmla z0\.h, z1\.h, z2\.h\[0\], #0
+.*: Error: operand mismatch -- `fmla z0\.b,z1\.b,z2\.b\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      fmla z0\.h, z1\.h, z2\.h\[0\]
+.*: Error: register element index out of range 0 to 7 at operand 3 -- `fmla z0\.h,z1\.h,z2\.h\[-1\]'
+.*: Error: register element index out of range 0 to 7 at operand 3 -- `fmla z0\.h,z1\.h,z2\.h\[8\]'
+.*: Error: z0-z7 expected at operand 3 -- `fmla z0\.h,z1\.h,z8\.h\[0\]'
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fmla z0\.s,z1\.s,z2\.s\[-1\]'
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fmla z0\.s,z1\.s,z2\.s\[4\]'
+.*: Error: z0-z7 expected at operand 3 -- `fmla z0\.s,z1\.s,z8\.s\[0\]'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fmla z0\.d,z1\.d,z2\.d\[-1\]'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fmla z0\.d,z1\.d,z2\.d\[2\]'
+.*: Error: z0-z15 expected at operand 3 -- `fmla z0\.d,z1\.d,z16\.d\[0\]'
+.*: Error: operand mismatch -- `fmla z0\.q,z1\.q,z2\.q\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      fmla z0\.h, z1\.h, z2\.h\[0\]
+.*: Error: operand mismatch -- `fmls z0\.b,z1\.b,z2\.b\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      fmls z0\.h, z1\.h, z2\.h\[0\]
+.*: Error: register element index out of range 0 to 7 at operand 3 -- `fmls z0\.h,z1\.h,z2\.h\[-1\]'
+.*: Error: register element index out of range 0 to 7 at operand 3 -- `fmls z0\.h,z1\.h,z2\.h\[8\]'
+.*: Error: z0-z7 expected at operand 3 -- `fmls z0\.h,z1\.h,z8\.h\[0\]'
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fmls z0\.s,z1\.s,z2\.s\[-1\]'
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fmls z0\.s,z1\.s,z2\.s\[4\]'
+.*: Error: z0-z7 expected at operand 3 -- `fmls z0\.s,z1\.s,z8\.s\[0\]'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fmls z0\.d,z1\.d,z2\.d\[-1\]'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fmls z0\.d,z1\.d,z2\.d\[2\]'
+.*: Error: z0-z15 expected at operand 3 -- `fmls z0\.d,z1\.d,z16\.d\[0\]'
+.*: Error: operand mismatch -- `fmls z0\.q,z1\.q,z2\.q\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      fmls z0\.h, z1\.h, z2\.h\[0\]
+.*: Error: operand mismatch -- `fmul z0\.b,z1\.b,z2\.b\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      fmul z0\.h, z1\.h, z2\.h\[0\]
+.*: Error: register element index out of range 0 to 7 at operand 3 -- `fmul z0\.h,z1\.h,z2\.h\[-1\]'
+.*: Error: register element index out of range 0 to 7 at operand 3 -- `fmul z0\.h,z1\.h,z2\.h\[8\]'
+.*: Error: z0-z7 expected at operand 3 -- `fmul z0\.h,z1\.h,z8\.h\[0\]'
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fmul z0\.s,z1\.s,z2\.s\[-1\]'
+.*: Error: register element index out of range 0 to 3 at operand 3 -- `fmul z0\.s,z1\.s,z2\.s\[4\]'
+.*: Error: z0-z7 expected at operand 3 -- `fmul z0\.s,z1\.s,z8\.s\[0\]'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fmul z0\.d,z1\.d,z2\.d\[-1\]'
+.*: Error: register element index out of range 0 to 1 at operand 3 -- `fmul z0\.d,z1\.d,z2\.d\[2\]'
+.*: Error: z0-z15 expected at operand 3 -- `fmul z0\.d,z1\.d,z16\.d\[0\]'
+.*: Error: operand mismatch -- `fmul z0\.q,z1\.q,z2\.q\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      fmul z0\.h, z1\.h, z2\.h\[0\]
+.*: Error: operand mismatch -- `ld1rqb {z0\.b},p0,\[x0,#0\]'
+.*: Info:    did you mean this\?
+.*: Info:      ld1rqb {z0\.b}, p0/z, \[x0\]
+.*: Error: operand mismatch -- `ld1rqb {z0\.b},p0/m,\[x0,#0\]'
+.*: Info:    did you mean this\?
+.*: Info:      ld1rqb {z0\.b}, p0/z, \[x0\]
+.*: Error: p0-p7 expected at operand 2 -- `ld1rqb {z0\.b},p8/z,\[x0,#0\]'
+.*: Error: immediate offset out of range -128 to 112 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-144\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-15\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-14\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-13\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-12\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-11\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-10\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-9\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-8\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-7\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-6\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-5\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-4\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-3\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-2\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#-1\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#1\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#2\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#3\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#4\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#5\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#6\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#7\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#8\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#9\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#10\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#11\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#12\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#13\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#14\]'
+.*: Error: immediate value must be a multiple of 16 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#15\]'
+.*: Error: immediate offset out of range -128 to 112 at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,#128\]'
+.*: Error: operand mismatch -- `ld1rqb {z0\.h},p0/z,\[x0,#0\]'
+.*: Info:    did you mean this\?
+.*: Info:      ld1rqb {z0\.b}, p0/z, \[x0\]
+.*: Error: operand mismatch -- `ld1rqb {z0\.s},p0/z,\[x0,#0\]'
+.*: Info:    did you mean this\?
+.*: Info:      ld1rqb {z0\.b}, p0/z, \[x0\]
+.*: Error: operand mismatch -- `ld1rqb {z0\.d},p0/z,\[x0,#0\]'
+.*: Info:    did you mean this\?
+.*: Info:      ld1rqb {z0\.b}, p0/z, \[x0\]
+.*: Error: operand mismatch -- `ld1rqb {z0\.q},p0/z,\[x0,#0\]'
+.*: Info:    did you mean this\?
+.*: Info:      ld1rqb {z0\.b}, p0/z, \[x0\]
+.*: Error: index register xzr is not allowed at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,xzr\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,x1,lsl#1\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,x1,lsl#2\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqb {z0\.b},p0/z,\[x0,x1,lsl#3\]'
+.*: Error: index register xzr is not allowed at operand 3 -- `ld1rqh {z0\.h},p0/z,\[x0,xzr,lsl#1\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqh {z0\.h},p0/z,\[x0,x1\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqh {z0\.h},p0/z,\[x0,x1,lsl#2\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqh {z0\.h},p0/z,\[x0,x1,lsl#3\]'
+.*: Error: index register xzr is not allowed at operand 3 -- `ld1rqw {z0\.s},p0/z,\[x0,xzr,lsl#2\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqw {z0\.s},p0/z,\[x0,x1\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqw {z0\.s},p0/z,\[x0,x1,lsl#1\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqw {z0\.s},p0/z,\[x0,x1,lsl#3\]'
+.*: Error: index register xzr is not allowed at operand 3 -- `ld1rqd {z0\.d},p0/z,\[x0,xzr,lsl#3\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqd {z0\.d},p0/z,\[x0,x1\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqd {z0\.d},p0/z,\[x0,x1,lsl#1\]'
+.*: Error: invalid addressing mode at operand 3 -- `ld1rqd {z0\.d},p0/z,\[x0,x1,lsl#2\]'
+.*: Error: operand mismatch -- `sdot z0\.b,z1\.b,z2\.b'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.s, z1\.b, z2\.b
+.*: Info:    other valid variant\(s\):
+.*: Info:      sdot z0\.d, z1\.h, z2\.h
+.*: Error: operand mismatch -- `sdot z0\.h,z1\.h,z2\.h'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.d, z1\.h, z2\.h
+.*: Info:    other valid variant\(s\):
+.*: Info:      sdot z0\.s, z1\.b, z2\.b
+.*: Error: operand mismatch -- `sdot z0\.s,z1\.s,z2\.s'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.s, z1\.b, z2\.b
+.*: Info:    other valid variant\(s\):
+.*: Info:      sdot z0\.d, z1\.h, z2\.h
+.*: Error: operand mismatch -- `sdot z0\.d,z1\.d,z2\.d'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.d, z1\.h, z2\.h
+.*: Info:    other valid variant\(s\):
+.*: Info:      sdot z0\.s, z1\.b, z2\.b
+.*: Error: operand mismatch -- `sdot z0\.b,z1\.b,z2\.b\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.s, z1\.b, z2\.b\[0\]
+.*: Error: operand mismatch -- `sdot z0\.h,z1\.h,z2\.h\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.s, z1\.b, z2\.b\[0\]
+.*: Error: operand mismatch -- `sdot z0\.s,z1\.s,z2\.s\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.s, z1\.b, z2\.b\[0\]
+.*: Error: operand mismatch -- `sdot z0\.d,z1\.d,z2\.d\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      sdot z0\.s, z1\.b, z2\.b\[0\]
+.*: Error: operand mismatch -- `udot z0\.b,z1\.b,z2\.b'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.s, z1\.b, z2\.b
+.*: Info:    other valid variant\(s\):
+.*: Info:      udot z0\.d, z1\.h, z2\.h
+.*: Error: operand mismatch -- `udot z0\.h,z1\.h,z2\.h'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.d, z1\.h, z2\.h
+.*: Info:    other valid variant\(s\):
+.*: Info:      udot z0\.s, z1\.b, z2\.b
+.*: Error: operand mismatch -- `udot z0\.s,z1\.s,z2\.s'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.s, z1\.b, z2\.b
+.*: Info:    other valid variant\(s\):
+.*: Info:      udot z0\.d, z1\.h, z2\.h
+.*: Error: operand mismatch -- `udot z0\.d,z1\.d,z2\.d'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.d, z1\.h, z2\.h
+.*: Info:    other valid variant\(s\):
+.*: Info:      udot z0\.s, z1\.b, z2\.b
+.*: Error: operand mismatch -- `udot z0\.b,z1\.b,z2\.b\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.s, z1\.b, z2\.b\[0\]
+.*: Error: operand mismatch -- `udot z0\.h,z1\.h,z2\.h\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.s, z1\.b, z2\.b\[0\]
+.*: Error: operand mismatch -- `udot z0\.s,z1\.s,z2\.s\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.s, z1\.b, z2\.b\[0\]
+.*: Error: operand mismatch -- `udot z0\.d,z1\.d,z2\.d\[0\]'
+.*: Info:    did you mean this\?
+.*: Info:      udot z0\.s, z1\.b, z2\.b\[0\]
index 0912c520102aa0735ca7b07703016626564b9600..148dbc85ac2e2c7ce2e5c5ebe9b2c77ea7603d77 100644 (file)
        dup     z0.d, z1.d[7]                           // OK
        dup     z0.d, z1.d[8]
        dup     z0.d, z1.d[x0]
+
+       fabd    z0.b, p0/m, z0.b, z0.b
+       fabd    z0.q, p0/m, z0.q, z0.q
+
+       fcadd   z0.b, p0/m, z0.b, z0.b, #90
+       fcadd   z0.h, p0/m, z0.h, z0.h, #-180
+       fcadd   z0.h, p0/m, z0.h, z0.h, #-90
+       fcadd   z0.h, p0/m, z0.h, z0.h, #0
+       fcadd   z0.h, p0/m, z0.h, z0.h, #89
+       fcadd   z0.h, p0/m, z0.h, z0.h, #90.0
+       fcadd   z0.h, p0/m, z0.h, z0.h, #180
+       fcadd   z0.h, p0/m, z0.h, z0.h, #360
+       fcadd   z0.h, p0/m, z0.h, z0.h, #450
+       fcadd   z0.h, p0/z, z0.h, z0.h, #90
+       fcadd   z0.h, p0/m, z1.h, z0.h, #90
+       fcadd   z0.q, p0/m, z0.q, z0.q, #90
+
+       fcmla   z0.b, p0/m, z0.b, z0.b, #90
+       fcmla   z0.h, p0/m, z0.h, z0.h, #-180
+       fcmla   z0.h, p0/m, z0.h, z0.h, #-90
+       fcmla   z0.h, p0/m, z0.h, z0.h, #89
+       fcmla   z0.h, p0/m, z0.h, z0.h, #90.0
+       fcmla   z0.h, p0/m, z0.h, z0.h, #360
+       fcmla   z0.h, p0/m, z0.h, z0.h, #450
+       fcmla   z0.h, p0/z, z0.h, z0.h, #90
+       fcmla   z0.q, p0/m, z0.q, z0.q, #90
+
+       fcmla   z0.b, z1.b, z2.b[0], #0
+       fcmla   z0.h, z1.h, z2.h[-1], #0
+       fcmla   z0.h, z1.h, z2.h[4], #0
+       fcmla   z0.h, z1.h, z8.h[0], #0
+       fcmla   z0.h, z1.h, z2.h[0], #-180
+       fcmla   z0.h, z1.h, z2.h[0], #-90
+       fcmla   z0.h, z1.h, z2.h[0], #89
+       fcmla   z0.h, z1.h, z2.h[0], #90.0
+       fcmla   z0.h, z1.h, z2.h[0], #360
+       fcmla   z0.h, z1.h, z2.h[0], #450
+       fcmla   z0.s, z1.s, z2.s[-1], #0
+       fcmla   z0.s, z1.s, z2.s[2], #0
+       fcmla   z0.s, z1.s, z16.s[0], #0
+       fcmla   z0.s, z1.s, z2.s[0], #-180
+       fcmla   z0.s, z1.s, z2.s[0], #-90
+       fcmla   z0.s, z1.s, z2.s[0], #89
+       fcmla   z0.s, z1.s, z2.s[0], #90.0
+       fcmla   z0.s, z1.s, z2.s[0], #360
+       fcmla   z0.s, z1.s, z2.s[0], #450
+       fcmla   z0.q, z1.q, z2.q[0], #0
+
+       fmla    z0.b, z1.b, z2.b[0]
+       fmla    z0.h, z1.h, z2.h[-1]
+       fmla    z0.h, z1.h, z2.h[8]
+       fmla    z0.h, z1.h, z8.h[0]
+       fmla    z0.s, z1.s, z2.s[-1]
+       fmla    z0.s, z1.s, z2.s[4]
+       fmla    z0.s, z1.s, z8.s[0]
+       fmla    z0.d, z1.d, z2.d[-1]
+       fmla    z0.d, z1.d, z2.d[2]
+       fmla    z0.d, z1.d, z16.d[0]
+       fmla    z0.q, z1.q, z2.q[0]
+
+       fmls    z0.b, z1.b, z2.b[0]
+       fmls    z0.h, z1.h, z2.h[-1]
+       fmls    z0.h, z1.h, z2.h[8]
+       fmls    z0.h, z1.h, z8.h[0]
+       fmls    z0.s, z1.s, z2.s[-1]
+       fmls    z0.s, z1.s, z2.s[4]
+       fmls    z0.s, z1.s, z8.s[0]
+       fmls    z0.d, z1.d, z2.d[-1]
+       fmls    z0.d, z1.d, z2.d[2]
+       fmls    z0.d, z1.d, z16.d[0]
+       fmls    z0.q, z1.q, z2.q[0]
+
+       fmul    z0.b, z1.b, z2.b[0]
+       fmul    z0.h, z1.h, z2.h[-1]
+       fmul    z0.h, z1.h, z2.h[8]
+       fmul    z0.h, z1.h, z8.h[0]
+       fmul    z0.s, z1.s, z2.s[-1]
+       fmul    z0.s, z1.s, z2.s[4]
+       fmul    z0.s, z1.s, z8.s[0]
+       fmul    z0.d, z1.d, z2.d[-1]
+       fmul    z0.d, z1.d, z2.d[2]
+       fmul    z0.d, z1.d, z16.d[0]
+       fmul    z0.q, z1.q, z2.q[0]
+
+       ld1rqb  {z0.b}, p0, [x0, #0]
+       ld1rqb  {z0.b}, p0/m, [x0, #0]
+       ld1rqb  {z0.b}, p8/z, [x0, #0]
+       ld1rqb  {z0.b}, p0/z, [x0, #-144]
+       ld1rqb  {z0.b}, p0/z, [x0, #-15]
+       ld1rqb  {z0.b}, p0/z, [x0, #-14]
+       ld1rqb  {z0.b}, p0/z, [x0, #-13]
+       ld1rqb  {z0.b}, p0/z, [x0, #-12]
+       ld1rqb  {z0.b}, p0/z, [x0, #-11]
+       ld1rqb  {z0.b}, p0/z, [x0, #-10]
+       ld1rqb  {z0.b}, p0/z, [x0, #-9]
+       ld1rqb  {z0.b}, p0/z, [x0, #-8]
+       ld1rqb  {z0.b}, p0/z, [x0, #-7]
+       ld1rqb  {z0.b}, p0/z, [x0, #-6]
+       ld1rqb  {z0.b}, p0/z, [x0, #-5]
+       ld1rqb  {z0.b}, p0/z, [x0, #-4]
+       ld1rqb  {z0.b}, p0/z, [x0, #-3]
+       ld1rqb  {z0.b}, p0/z, [x0, #-2]
+       ld1rqb  {z0.b}, p0/z, [x0, #-1]
+       ld1rqb  {z0.b}, p0/z, [x0, #1]
+       ld1rqb  {z0.b}, p0/z, [x0, #2]
+       ld1rqb  {z0.b}, p0/z, [x0, #3]
+       ld1rqb  {z0.b}, p0/z, [x0, #4]
+       ld1rqb  {z0.b}, p0/z, [x0, #5]
+       ld1rqb  {z0.b}, p0/z, [x0, #6]
+       ld1rqb  {z0.b}, p0/z, [x0, #7]
+       ld1rqb  {z0.b}, p0/z, [x0, #8]
+       ld1rqb  {z0.b}, p0/z, [x0, #9]
+       ld1rqb  {z0.b}, p0/z, [x0, #10]
+       ld1rqb  {z0.b}, p0/z, [x0, #11]
+       ld1rqb  {z0.b}, p0/z, [x0, #12]
+       ld1rqb  {z0.b}, p0/z, [x0, #13]
+       ld1rqb  {z0.b}, p0/z, [x0, #14]
+       ld1rqb  {z0.b}, p0/z, [x0, #15]
+       ld1rqb  {z0.b}, p0/z, [x0, #128]
+       ld1rqb  {z0.h}, p0/z, [x0, #0]
+       ld1rqb  {z0.s}, p0/z, [x0, #0]
+       ld1rqb  {z0.d}, p0/z, [x0, #0]
+       ld1rqb  {z0.q}, p0/z, [x0, #0]
+
+       ld1rqb  {z0.b}, p0/z, [x0, xzr]
+       ld1rqb  {z0.b}, p0/z, [x0, x1, lsl #1]
+       ld1rqb  {z0.b}, p0/z, [x0, x1, lsl #2]
+       ld1rqb  {z0.b}, p0/z, [x0, x1, lsl #3]
+
+       ld1rqh  {z0.h}, p0/z, [x0, xzr, lsl #1]
+       ld1rqh  {z0.h}, p0/z, [x0, x1]
+       ld1rqh  {z0.h}, p0/z, [x0, x1, lsl #2]
+       ld1rqh  {z0.h}, p0/z, [x0, x1, lsl #3]
+
+       ld1rqw  {z0.s}, p0/z, [x0, xzr, lsl #2]
+       ld1rqw  {z0.s}, p0/z, [x0, x1]
+       ld1rqw  {z0.s}, p0/z, [x0, x1, lsl #1]
+       ld1rqw  {z0.s}, p0/z, [x0, x1, lsl #3]
+
+       ld1rqd  {z0.d}, p0/z, [x0, xzr, lsl #3]
+       ld1rqd  {z0.d}, p0/z, [x0, x1]
+       ld1rqd  {z0.d}, p0/z, [x0, x1, lsl #1]
+       ld1rqd  {z0.d}, p0/z, [x0, x1, lsl #2]
+
+       sdot    z0.b, z1.b, z2.b
+       sdot    z0.h, z1.h, z2.h
+       sdot    z0.s, z1.s, z2.s
+       sdot    z0.d, z1.d, z2.d
+
+       sdot    z0.b, z1.b, z2.b[0]
+       sdot    z0.h, z1.h, z2.h[0]
+       sdot    z0.s, z1.s, z2.s[0]
+       sdot    z0.d, z1.d, z2.d[0]
+
+       udot    z0.b, z1.b, z2.b
+       udot    z0.h, z1.h, z2.h
+       udot    z0.s, z1.s, z2.s
+       udot    z0.d, z1.d, z2.d
+
+       udot    z0.b, z1.b, z2.b[0]
+       udot    z0.h, z1.h, z2.h[0]
+       udot    z0.s, z1.s, z2.s[0]
+       udot    z0.d, z1.d, z2.d[0]
index 4b976efc6d7adee69466ab4e886aff528a026c2f..5c7c519828033004c648556db43502fb29ffc730 100644 (file)
@@ -1,4 +1,4 @@
-#as: -march=armv8-a+sve
+#as: -march=armv8-a+sve -I$srcdir/$subdir
 #objdump: -dr
 
 .* file format .*
@@ -6,6 +6,24 @@
 Disassembly of section .*:
 
 0+ <.*>:
+.*:    2579c000        fmov    z0\.h, #2\.0+e\+00
+.*:    2579c000        fmov    z0\.h, #2\.0+e\+00
+.*:    2579c001        fmov    z1\.h, #2\.0+e\+00
+.*:    2579c001        fmov    z1\.h, #2\.0+e\+00
+.*:    2579c01f        fmov    z31\.h, #2\.0+e\+00
+.*:    2579c01f        fmov    z31\.h, #2\.0+e\+00
+.*:    2579c600        fmov    z0\.h, #1\.60+e\+01
+.*:    2579c600        fmov    z0\.h, #1\.60+e\+01
+.*:    2579c900        fmov    z0\.h, #1\.8750+e-01
+.*:    2579c900        fmov    z0\.h, #1\.8750+e-01
+.*:    2579cfe0        fmov    z0\.h, #1\.93750+e\+00
+.*:    2579cfe0        fmov    z0\.h, #1\.93750+e\+00
+.*:    2579d100        fmov    z0\.h, #-3\.0+e\+00
+.*:    2579d100        fmov    z0\.h, #-3\.0+e\+00
+.*:    2579d800        fmov    z0\.h, #-1\.250+e-01
+.*:    2579d800        fmov    z0\.h, #-1\.250+e-01
+.*:    2579dfe0        fmov    z0\.h, #-1\.93750+e\+00
+.*:    2579dfe0        fmov    z0\.h, #-1\.93750+e\+00
 .*:    25b9c000        fmov    z0\.s, #2\.0+e\+00
 .*:    25b9c000        fmov    z0\.s, #2\.0+e\+00
 .*:    25b9c001        fmov    z1\.s, #2\.0+e\+00
@@ -42,6 +60,28 @@ Disassembly of section .*:
 .*:    25f9d800        fmov    z0\.d, #-1\.250+e-01
 .*:    25f9dfe0        fmov    z0\.d, #-1\.93750+e\+00
 .*:    25f9dfe0        fmov    z0\.d, #-1\.93750+e\+00
+.*:    0550c000        fmov    z0\.h, p0/m, #2\.0+e\+00
+.*:    0550c000        fmov    z0\.h, p0/m, #2\.0+e\+00
+.*:    0550c001        fmov    z1\.h, p0/m, #2\.0+e\+00
+.*:    0550c001        fmov    z1\.h, p0/m, #2\.0+e\+00
+.*:    0550c01f        fmov    z31\.h, p0/m, #2\.0+e\+00
+.*:    0550c01f        fmov    z31\.h, p0/m, #2\.0+e\+00
+.*:    0552c000        fmov    z0\.h, p2/m, #2\.0+e\+00
+.*:    0552c000        fmov    z0\.h, p2/m, #2\.0+e\+00
+.*:    055fc000        fmov    z0\.h, p15/m, #2\.0+e\+00
+.*:    055fc000        fmov    z0\.h, p15/m, #2\.0+e\+00
+.*:    0550c600        fmov    z0\.h, p0/m, #1\.60+e\+01
+.*:    0550c600        fmov    z0\.h, p0/m, #1\.60+e\+01
+.*:    0550c900        fmov    z0\.h, p0/m, #1\.8750+e-01
+.*:    0550c900        fmov    z0\.h, p0/m, #1\.8750+e-01
+.*:    0550cfe0        fmov    z0\.h, p0/m, #1\.93750+e\+00
+.*:    0550cfe0        fmov    z0\.h, p0/m, #1\.93750+e\+00
+.*:    0550d100        fmov    z0\.h, p0/m, #-3\.0+e\+00
+.*:    0550d100        fmov    z0\.h, p0/m, #-3\.0+e\+00
+.*:    0550d800        fmov    z0\.h, p0/m, #-1\.250+e-01
+.*:    0550d800        fmov    z0\.h, p0/m, #-1\.250+e-01
+.*:    0550dfe0        fmov    z0\.h, p0/m, #-1\.93750+e\+00
+.*:    0550dfe0        fmov    z0\.h, p0/m, #-1\.93750+e\+00
 .*:    0590c000        fmov    z0\.s, p0/m, #2\.0+e\+00
 .*:    0590c000        fmov    z0\.s, p0/m, #2\.0+e\+00
 .*:    0590c001        fmov    z1\.s, p0/m, #2\.0+e\+00
@@ -136,6 +176,16 @@ Disassembly of section .*:
 .*:    05282040        mov     z0\.d, d2
 .*:    052823e0        mov     z0\.d, d31
 .*:    052823e0        mov     z0\.d, d31
+.*:    05302000        mov     z0\.q, q0
+.*:    05302000        mov     z0\.q, q0
+.*:    05302001        mov     z1\.q, q0
+.*:    05302001        mov     z1\.q, q0
+.*:    0530201f        mov     z31\.q, q0
+.*:    0530201f        mov     z31\.q, q0
+.*:    05302040        mov     z0\.q, q2
+.*:    05302040        mov     z0\.q, q2
+.*:    053023e0        mov     z0\.q, q31
+.*:    053023e0        mov     z0\.q, q31
 .*:    05203800        mov     z0\.b, w0
 .*:    05203800        mov     z0\.b, w0
 .*:    05203801        mov     z1\.b, w0
@@ -314,6 +364,22 @@ Disassembly of section .*:
 .*:    052f23e0        mov     z0\.b, z31\.b\[7\]
 .*:    05312000        mov     z0\.b, z0\.b\[8\]
 .*:    05312000        mov     z0\.b, z0\.b\[8\]
+.*:    05702000        mov     z0\.q, z0\.q\[1\]
+.*:    05702000        mov     z0\.q, z0\.q\[1\]
+.*:    05702001        mov     z1\.q, z0\.q\[1\]
+.*:    05702001        mov     z1\.q, z0\.q\[1\]
+.*:    0570201f        mov     z31\.q, z0\.q\[1\]
+.*:    0570201f        mov     z31\.q, z0\.q\[1\]
+.*:    05702040        mov     z0\.q, z2\.q\[1\]
+.*:    05702040        mov     z0\.q, z2\.q\[1\]
+.*:    057023e0        mov     z0\.q, z31\.q\[1\]
+.*:    057023e0        mov     z0\.q, z31\.q\[1\]
+.*:    05302000        mov     z0\.q, q0
+.*:    05302000        mov     z0\.q, q0
+.*:    05b02000        mov     z0\.q, z0\.q\[2\]
+.*:    05b02000        mov     z0\.q, z0\.q\[2\]
+.*:    05f02000        mov     z0\.q, z0\.q\[3\]
+.*:    05f02000        mov     z0\.q, z0\.q\[3\]
 .*:    05c000e0        mov     z0\.s, #0xff
 .*:    05c000e0        mov     z0\.s, #0xff
 .*:    05c000e0        mov     z0\.s, #0xff
@@ -7645,6 +7711,22 @@ Disassembly of section .*:
 .*:    052f23e0        mov     z0\.b, z31\.b\[7\]
 .*:    05312000        mov     z0\.b, z0\.b\[8\]
 .*:    05312000        mov     z0\.b, z0\.b\[8\]
+.*:    05702000        mov     z0\.q, z0\.q\[1\]
+.*:    05702000        mov     z0\.q, z0\.q\[1\]
+.*:    05702001        mov     z1\.q, z0\.q\[1\]
+.*:    05702001        mov     z1\.q, z0\.q\[1\]
+.*:    0570201f        mov     z31\.q, z0\.q\[1\]
+.*:    0570201f        mov     z31\.q, z0\.q\[1\]
+.*:    05702040        mov     z0\.q, z2\.q\[1\]
+.*:    05702040        mov     z0\.q, z2\.q\[1\]
+.*:    057023e0        mov     z0\.q, z31\.q\[1\]
+.*:    057023e0        mov     z0\.q, z31\.q\[1\]
+.*:    05302000        mov     z0\.q, q0
+.*:    05302000        mov     z0\.q, q0
+.*:    05b02000        mov     z0\.q, z0\.q\[2\]
+.*:    05b02000        mov     z0\.q, z0\.q\[2\]
+.*:    05f02000        mov     z0\.q, z0\.q\[3\]
+.*:    05f02000        mov     z0\.q, z0\.q\[3\]
 .*:    2538c000        mov     z0\.b, #0
 .*:    2538c000        mov     z0\.b, #0
 .*:    2538c000        mov     z0\.b, #0
@@ -8092,6 +8174,22 @@ Disassembly of section .*:
 .*:    05300400        ext     z0\.b, z0\.b, z0\.b, #129
 .*:    053f1c00        ext     z0\.b, z0\.b, z0\.b, #255
 .*:    053f1c00        ext     z0\.b, z0\.b, z0\.b, #255
+.*:    65488000        fabd    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65488000        fabd    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65488001        fabd    z1\.h, p0/m, z1\.h, z0\.h
+.*:    65488001        fabd    z1\.h, p0/m, z1\.h, z0\.h
+.*:    6548801f        fabd    z31\.h, p0/m, z31\.h, z0\.h
+.*:    6548801f        fabd    z31\.h, p0/m, z31\.h, z0\.h
+.*:    65488800        fabd    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65488800        fabd    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65489c00        fabd    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65489c00        fabd    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65488003        fabd    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65488003        fabd    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65488080        fabd    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65488080        fabd    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654883e0        fabd    z0\.h, p0/m, z0\.h, z31\.h
+.*:    654883e0        fabd    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65888000        fabd    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65888000        fabd    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65888001        fabd    z1\.s, p0/m, z1\.s, z0\.s
@@ -8124,6 +8222,20 @@ Disassembly of section .*:
 .*:    65c88080        fabd    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c883e0        fabd    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c883e0        fabd    z0\.d, p0/m, z0\.d, z31\.d
+.*:    045ca000        fabs    z0\.h, p0/m, z0\.h
+.*:    045ca000        fabs    z0\.h, p0/m, z0\.h
+.*:    045ca001        fabs    z1\.h, p0/m, z0\.h
+.*:    045ca001        fabs    z1\.h, p0/m, z0\.h
+.*:    045ca01f        fabs    z31\.h, p0/m, z0\.h
+.*:    045ca01f        fabs    z31\.h, p0/m, z0\.h
+.*:    045ca800        fabs    z0\.h, p2/m, z0\.h
+.*:    045ca800        fabs    z0\.h, p2/m, z0\.h
+.*:    045cbc00        fabs    z0\.h, p7/m, z0\.h
+.*:    045cbc00        fabs    z0\.h, p7/m, z0\.h
+.*:    045ca060        fabs    z0\.h, p0/m, z3\.h
+.*:    045ca060        fabs    z0\.h, p0/m, z3\.h
+.*:    045ca3e0        fabs    z0\.h, p0/m, z31\.h
+.*:    045ca3e0        fabs    z0\.h, p0/m, z31\.h
 .*:    049ca000        fabs    z0\.s, p0/m, z0\.s
 .*:    049ca000        fabs    z0\.s, p0/m, z0\.s
 .*:    049ca001        fabs    z1\.s, p0/m, z0\.s
@@ -8152,6 +8264,24 @@ Disassembly of section .*:
 .*:    04dca060        fabs    z0\.d, p0/m, z3\.d
 .*:    04dca3e0        fabs    z0\.d, p0/m, z31\.d
 .*:    04dca3e0        fabs    z0\.d, p0/m, z31\.d
+.*:    6540c010        facge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540c010        facge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540c011        facge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540c011        facge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540c01f        facge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540c01f        facge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540c810        facge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540c810        facge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540dc10        facge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540dc10        facge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540c070        facge   p0\.h, p0/z, z3\.h, z0\.h
+.*:    6540c070        facge   p0\.h, p0/z, z3\.h, z0\.h
+.*:    6540c3f0        facge   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6540c3f0        facge   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6544c010        facge   p0\.h, p0/z, z0\.h, z4\.h
+.*:    6544c010        facge   p0\.h, p0/z, z0\.h, z4\.h
+.*:    655fc010        facge   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655fc010        facge   p0\.h, p0/z, z0\.h, z31\.h
 .*:    6580c010        facge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580c010        facge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580c011        facge   p1\.s, p0/z, z0\.s, z0\.s
@@ -8188,6 +8318,24 @@ Disassembly of section .*:
 .*:    65c4c010        facge   p0\.d, p0/z, z0\.d, z4\.d
 .*:    65dfc010        facge   p0\.d, p0/z, z0\.d, z31\.d
 .*:    65dfc010        facge   p0\.d, p0/z, z0\.d, z31\.d
+.*:    6540e010        facgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540e010        facgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540e011        facgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540e011        facgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540e01f        facgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540e01f        facgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540e810        facgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540e810        facgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540fc10        facgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540fc10        facgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540e070        facgt   p0\.h, p0/z, z3\.h, z0\.h
+.*:    6540e070        facgt   p0\.h, p0/z, z3\.h, z0\.h
+.*:    6540e3f0        facgt   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6540e3f0        facgt   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6544e010        facgt   p0\.h, p0/z, z0\.h, z4\.h
+.*:    6544e010        facgt   p0\.h, p0/z, z0\.h, z4\.h
+.*:    655fe010        facgt   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655fe010        facgt   p0\.h, p0/z, z0\.h, z31\.h
 .*:    6580e010        facgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580e010        facgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580e011        facgt   p1\.s, p0/z, z0\.s, z0\.s
@@ -8224,6 +8372,20 @@ Disassembly of section .*:
 .*:    65c4e010        facgt   p0\.d, p0/z, z0\.d, z4\.d
 .*:    65dfe010        facgt   p0\.d, p0/z, z0\.d, z31\.d
 .*:    65dfe010        facgt   p0\.d, p0/z, z0\.d, z31\.d
+.*:    65400000        fadd    z0\.h, z0\.h, z0\.h
+.*:    65400000        fadd    z0\.h, z0\.h, z0\.h
+.*:    65400001        fadd    z1\.h, z0\.h, z0\.h
+.*:    65400001        fadd    z1\.h, z0\.h, z0\.h
+.*:    6540001f        fadd    z31\.h, z0\.h, z0\.h
+.*:    6540001f        fadd    z31\.h, z0\.h, z0\.h
+.*:    65400040        fadd    z0\.h, z2\.h, z0\.h
+.*:    65400040        fadd    z0\.h, z2\.h, z0\.h
+.*:    654003e0        fadd    z0\.h, z31\.h, z0\.h
+.*:    654003e0        fadd    z0\.h, z31\.h, z0\.h
+.*:    65430000        fadd    z0\.h, z0\.h, z3\.h
+.*:    65430000        fadd    z0\.h, z0\.h, z3\.h
+.*:    655f0000        fadd    z0\.h, z0\.h, z31\.h
+.*:    655f0000        fadd    z0\.h, z0\.h, z31\.h
 .*:    65800000        fadd    z0\.s, z0\.s, z0\.s
 .*:    65800000        fadd    z0\.s, z0\.s, z0\.s
 .*:    65800001        fadd    z1\.s, z0\.s, z0\.s
@@ -8252,6 +8414,22 @@ Disassembly of section .*:
 .*:    65c30000        fadd    z0\.d, z0\.d, z3\.d
 .*:    65df0000        fadd    z0\.d, z0\.d, z31\.d
 .*:    65df0000        fadd    z0\.d, z0\.d, z31\.d
+.*:    65408000        fadd    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65408000        fadd    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65408001        fadd    z1\.h, p0/m, z1\.h, z0\.h
+.*:    65408001        fadd    z1\.h, p0/m, z1\.h, z0\.h
+.*:    6540801f        fadd    z31\.h, p0/m, z31\.h, z0\.h
+.*:    6540801f        fadd    z31\.h, p0/m, z31\.h, z0\.h
+.*:    65408800        fadd    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65408800        fadd    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65409c00        fadd    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65409c00        fadd    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65408003        fadd    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65408003        fadd    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65408080        fadd    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65408080        fadd    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654083e0        fadd    z0\.h, p0/m, z0\.h, z31\.h
+.*:    654083e0        fadd    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65808000        fadd    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65808000        fadd    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65808001        fadd    z1\.s, p0/m, z1\.s, z0\.s
@@ -8284,6 +8462,34 @@ Disassembly of section .*:
 .*:    65c08080        fadd    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c083e0        fadd    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c083e0        fadd    z0\.d, p0/m, z0\.d, z31\.d
+.*:    65588000        fadd    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65588000        fadd    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65588000        fadd    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65588000        fadd    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65588001        fadd    z1\.h, p0/m, z1\.h, #0\.5
+.*:    65588001        fadd    z1\.h, p0/m, z1\.h, #0\.5
+.*:    65588001        fadd    z1\.h, p0/m, z1\.h, #0\.5
+.*:    65588001        fadd    z1\.h, p0/m, z1\.h, #0\.5
+.*:    6558801f        fadd    z31\.h, p0/m, z31\.h, #0\.5
+.*:    6558801f        fadd    z31\.h, p0/m, z31\.h, #0\.5
+.*:    6558801f        fadd    z31\.h, p0/m, z31\.h, #0\.5
+.*:    6558801f        fadd    z31\.h, p0/m, z31\.h, #0\.5
+.*:    65588800        fadd    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65588800        fadd    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65588800        fadd    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65588800        fadd    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65589c00        fadd    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65589c00        fadd    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65589c00        fadd    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65589c00        fadd    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65588003        fadd    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65588003        fadd    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65588003        fadd    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65588003        fadd    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65588020        fadd    z0\.h, p0/m, z0\.h, #1\.0
+.*:    65588020        fadd    z0\.h, p0/m, z0\.h, #1\.0
+.*:    65588020        fadd    z0\.h, p0/m, z0\.h, #1\.0
+.*:    65588020        fadd    z0\.h, p0/m, z0\.h, #1\.0
 .*:    65988000        fadd    z0\.s, p0/m, z0\.s, #0\.5
 .*:    65988000        fadd    z0\.s, p0/m, z0\.s, #0\.5
 .*:    65988000        fadd    z0\.s, p0/m, z0\.s, #0\.5
@@ -8340,6 +8546,22 @@ Disassembly of section .*:
 .*:    65d88020        fadd    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65d88020        fadd    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65d88020        fadd    z0\.d, p0/m, z0\.d, #1\.0
+.*:    65582000        fadda   h0, p0, h0, z0\.h
+.*:    65582000        fadda   h0, p0, h0, z0\.h
+.*:    65582001        fadda   h1, p0, h1, z0\.h
+.*:    65582001        fadda   h1, p0, h1, z0\.h
+.*:    6558201f        fadda   h31, p0, h31, z0\.h
+.*:    6558201f        fadda   h31, p0, h31, z0\.h
+.*:    65582800        fadda   h0, p2, h0, z0\.h
+.*:    65582800        fadda   h0, p2, h0, z0\.h
+.*:    65583c00        fadda   h0, p7, h0, z0\.h
+.*:    65583c00        fadda   h0, p7, h0, z0\.h
+.*:    65582003        fadda   h3, p0, h3, z0\.h
+.*:    65582003        fadda   h3, p0, h3, z0\.h
+.*:    65582080        fadda   h0, p0, h0, z4\.h
+.*:    65582080        fadda   h0, p0, h0, z4\.h
+.*:    655823e0        fadda   h0, p0, h0, z31\.h
+.*:    655823e0        fadda   h0, p0, h0, z31\.h
 .*:    65982000        fadda   s0, p0, s0, z0\.s
 .*:    65982000        fadda   s0, p0, s0, z0\.s
 .*:    65982001        fadda   s1, p0, s1, z0\.s
@@ -8372,6 +8594,20 @@ Disassembly of section .*:
 .*:    65d82080        fadda   d0, p0, d0, z4\.d
 .*:    65d823e0        fadda   d0, p0, d0, z31\.d
 .*:    65d823e0        fadda   d0, p0, d0, z31\.d
+.*:    65402000        faddv   h0, p0, z0\.h
+.*:    65402000        faddv   h0, p0, z0\.h
+.*:    65402001        faddv   h1, p0, z0\.h
+.*:    65402001        faddv   h1, p0, z0\.h
+.*:    6540201f        faddv   h31, p0, z0\.h
+.*:    6540201f        faddv   h31, p0, z0\.h
+.*:    65402800        faddv   h0, p2, z0\.h
+.*:    65402800        faddv   h0, p2, z0\.h
+.*:    65403c00        faddv   h0, p7, z0\.h
+.*:    65403c00        faddv   h0, p7, z0\.h
+.*:    65402060        faddv   h0, p0, z3\.h
+.*:    65402060        faddv   h0, p0, z3\.h
+.*:    654023e0        faddv   h0, p0, z31\.h
+.*:    654023e0        faddv   h0, p0, z31\.h
 .*:    65802000        faddv   s0, p0, z0\.s
 .*:    65802000        faddv   s0, p0, z0\.s
 .*:    65802001        faddv   s1, p0, z0\.s
@@ -8400,6 +8636,202 @@ Disassembly of section .*:
 .*:    65c02060        faddv   d0, p0, z3\.d
 .*:    65c023e0        faddv   d0, p0, z31\.d
 .*:    65c023e0        faddv   d0, p0, z31\.d
+.*:    64408000        fcadd   z0\.h, p0/m, z0\.h, z0\.h, #90
+.*:    64408000        fcadd   z0\.h, p0/m, z0\.h, z0\.h, #90
+.*:    64408001        fcadd   z1\.h, p0/m, z1\.h, z0\.h, #90
+.*:    64408001        fcadd   z1\.h, p0/m, z1\.h, z0\.h, #90
+.*:    6440801f        fcadd   z31\.h, p0/m, z31\.h, z0\.h, #90
+.*:    6440801f        fcadd   z31\.h, p0/m, z31\.h, z0\.h, #90
+.*:    64408800        fcadd   z0\.h, p2/m, z0\.h, z0\.h, #90
+.*:    64408800        fcadd   z0\.h, p2/m, z0\.h, z0\.h, #90
+.*:    64409c00        fcadd   z0\.h, p7/m, z0\.h, z0\.h, #90
+.*:    64409c00        fcadd   z0\.h, p7/m, z0\.h, z0\.h, #90
+.*:    64408003        fcadd   z3\.h, p0/m, z3\.h, z0\.h, #90
+.*:    64408003        fcadd   z3\.h, p0/m, z3\.h, z0\.h, #90
+.*:    64408080        fcadd   z0\.h, p0/m, z0\.h, z4\.h, #90
+.*:    64408080        fcadd   z0\.h, p0/m, z0\.h, z4\.h, #90
+.*:    644083e0        fcadd   z0\.h, p0/m, z0\.h, z31\.h, #90
+.*:    644083e0        fcadd   z0\.h, p0/m, z0\.h, z31\.h, #90
+.*:    64418000        fcadd   z0\.h, p0/m, z0\.h, z0\.h, #270
+.*:    64418000        fcadd   z0\.h, p0/m, z0\.h, z0\.h, #270
+.*:    64808000        fcadd   z0\.s, p0/m, z0\.s, z0\.s, #90
+.*:    64808000        fcadd   z0\.s, p0/m, z0\.s, z0\.s, #90
+.*:    64808001        fcadd   z1\.s, p0/m, z1\.s, z0\.s, #90
+.*:    64808001        fcadd   z1\.s, p0/m, z1\.s, z0\.s, #90
+.*:    6480801f        fcadd   z31\.s, p0/m, z31\.s, z0\.s, #90
+.*:    6480801f        fcadd   z31\.s, p0/m, z31\.s, z0\.s, #90
+.*:    64808800        fcadd   z0\.s, p2/m, z0\.s, z0\.s, #90
+.*:    64808800        fcadd   z0\.s, p2/m, z0\.s, z0\.s, #90
+.*:    64809c00        fcadd   z0\.s, p7/m, z0\.s, z0\.s, #90
+.*:    64809c00        fcadd   z0\.s, p7/m, z0\.s, z0\.s, #90
+.*:    64808003        fcadd   z3\.s, p0/m, z3\.s, z0\.s, #90
+.*:    64808003        fcadd   z3\.s, p0/m, z3\.s, z0\.s, #90
+.*:    64808080        fcadd   z0\.s, p0/m, z0\.s, z4\.s, #90
+.*:    64808080        fcadd   z0\.s, p0/m, z0\.s, z4\.s, #90
+.*:    648083e0        fcadd   z0\.s, p0/m, z0\.s, z31\.s, #90
+.*:    648083e0        fcadd   z0\.s, p0/m, z0\.s, z31\.s, #90
+.*:    64818000        fcadd   z0\.s, p0/m, z0\.s, z0\.s, #270
+.*:    64818000        fcadd   z0\.s, p0/m, z0\.s, z0\.s, #270
+.*:    64c08000        fcadd   z0\.d, p0/m, z0\.d, z0\.d, #90
+.*:    64c08000        fcadd   z0\.d, p0/m, z0\.d, z0\.d, #90
+.*:    64c08001        fcadd   z1\.d, p0/m, z1\.d, z0\.d, #90
+.*:    64c08001        fcadd   z1\.d, p0/m, z1\.d, z0\.d, #90
+.*:    64c0801f        fcadd   z31\.d, p0/m, z31\.d, z0\.d, #90
+.*:    64c0801f        fcadd   z31\.d, p0/m, z31\.d, z0\.d, #90
+.*:    64c08800        fcadd   z0\.d, p2/m, z0\.d, z0\.d, #90
+.*:    64c08800        fcadd   z0\.d, p2/m, z0\.d, z0\.d, #90
+.*:    64c09c00        fcadd   z0\.d, p7/m, z0\.d, z0\.d, #90
+.*:    64c09c00        fcadd   z0\.d, p7/m, z0\.d, z0\.d, #90
+.*:    64c08003        fcadd   z3\.d, p0/m, z3\.d, z0\.d, #90
+.*:    64c08003        fcadd   z3\.d, p0/m, z3\.d, z0\.d, #90
+.*:    64c08080        fcadd   z0\.d, p0/m, z0\.d, z4\.d, #90
+.*:    64c08080        fcadd   z0\.d, p0/m, z0\.d, z4\.d, #90
+.*:    64c083e0        fcadd   z0\.d, p0/m, z0\.d, z31\.d, #90
+.*:    64c083e0        fcadd   z0\.d, p0/m, z0\.d, z31\.d, #90
+.*:    64c18000        fcadd   z0\.d, p0/m, z0\.d, z0\.d, #270
+.*:    64c18000        fcadd   z0\.d, p0/m, z0\.d, z0\.d, #270
+.*:    64400000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #0
+.*:    64400000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #0
+.*:    64400001        fcmla   z1\.h, p0/m, z0\.h, z0\.h, #0
+.*:    64400001        fcmla   z1\.h, p0/m, z0\.h, z0\.h, #0
+.*:    6440001f        fcmla   z31\.h, p0/m, z0\.h, z0\.h, #0
+.*:    6440001f        fcmla   z31\.h, p0/m, z0\.h, z0\.h, #0
+.*:    64400800        fcmla   z0\.h, p2/m, z0\.h, z0\.h, #0
+.*:    64400800        fcmla   z0\.h, p2/m, z0\.h, z0\.h, #0
+.*:    64401c00        fcmla   z0\.h, p7/m, z0\.h, z0\.h, #0
+.*:    64401c00        fcmla   z0\.h, p7/m, z0\.h, z0\.h, #0
+.*:    64400060        fcmla   z0\.h, p0/m, z3\.h, z0\.h, #0
+.*:    64400060        fcmla   z0\.h, p0/m, z3\.h, z0\.h, #0
+.*:    644003e0        fcmla   z0\.h, p0/m, z31\.h, z0\.h, #0
+.*:    644003e0        fcmla   z0\.h, p0/m, z31\.h, z0\.h, #0
+.*:    64440000        fcmla   z0\.h, p0/m, z0\.h, z4\.h, #0
+.*:    64440000        fcmla   z0\.h, p0/m, z0\.h, z4\.h, #0
+.*:    645f0000        fcmla   z0\.h, p0/m, z0\.h, z31\.h, #0
+.*:    645f0000        fcmla   z0\.h, p0/m, z0\.h, z31\.h, #0
+.*:    64402000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #90
+.*:    64402000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #90
+.*:    64404000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #180
+.*:    64404000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #180
+.*:    64406000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #270
+.*:    64406000        fcmla   z0\.h, p0/m, z0\.h, z0\.h, #270
+.*:    64800000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #0
+.*:    64800000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #0
+.*:    64800001        fcmla   z1\.s, p0/m, z0\.s, z0\.s, #0
+.*:    64800001        fcmla   z1\.s, p0/m, z0\.s, z0\.s, #0
+.*:    6480001f        fcmla   z31\.s, p0/m, z0\.s, z0\.s, #0
+.*:    6480001f        fcmla   z31\.s, p0/m, z0\.s, z0\.s, #0
+.*:    64800800        fcmla   z0\.s, p2/m, z0\.s, z0\.s, #0
+.*:    64800800        fcmla   z0\.s, p2/m, z0\.s, z0\.s, #0
+.*:    64801c00        fcmla   z0\.s, p7/m, z0\.s, z0\.s, #0
+.*:    64801c00        fcmla   z0\.s, p7/m, z0\.s, z0\.s, #0
+.*:    64800060        fcmla   z0\.s, p0/m, z3\.s, z0\.s, #0
+.*:    64800060        fcmla   z0\.s, p0/m, z3\.s, z0\.s, #0
+.*:    648003e0        fcmla   z0\.s, p0/m, z31\.s, z0\.s, #0
+.*:    648003e0        fcmla   z0\.s, p0/m, z31\.s, z0\.s, #0
+.*:    64840000        fcmla   z0\.s, p0/m, z0\.s, z4\.s, #0
+.*:    64840000        fcmla   z0\.s, p0/m, z0\.s, z4\.s, #0
+.*:    649f0000        fcmla   z0\.s, p0/m, z0\.s, z31\.s, #0
+.*:    649f0000        fcmla   z0\.s, p0/m, z0\.s, z31\.s, #0
+.*:    64802000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #90
+.*:    64802000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #90
+.*:    64804000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #180
+.*:    64804000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #180
+.*:    64806000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #270
+.*:    64806000        fcmla   z0\.s, p0/m, z0\.s, z0\.s, #270
+.*:    64c00000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #0
+.*:    64c00000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #0
+.*:    64c00001        fcmla   z1\.d, p0/m, z0\.d, z0\.d, #0
+.*:    64c00001        fcmla   z1\.d, p0/m, z0\.d, z0\.d, #0
+.*:    64c0001f        fcmla   z31\.d, p0/m, z0\.d, z0\.d, #0
+.*:    64c0001f        fcmla   z31\.d, p0/m, z0\.d, z0\.d, #0
+.*:    64c00800        fcmla   z0\.d, p2/m, z0\.d, z0\.d, #0
+.*:    64c00800        fcmla   z0\.d, p2/m, z0\.d, z0\.d, #0
+.*:    64c01c00        fcmla   z0\.d, p7/m, z0\.d, z0\.d, #0
+.*:    64c01c00        fcmla   z0\.d, p7/m, z0\.d, z0\.d, #0
+.*:    64c00060        fcmla   z0\.d, p0/m, z3\.d, z0\.d, #0
+.*:    64c00060        fcmla   z0\.d, p0/m, z3\.d, z0\.d, #0
+.*:    64c003e0        fcmla   z0\.d, p0/m, z31\.d, z0\.d, #0
+.*:    64c003e0        fcmla   z0\.d, p0/m, z31\.d, z0\.d, #0
+.*:    64c40000        fcmla   z0\.d, p0/m, z0\.d, z4\.d, #0
+.*:    64c40000        fcmla   z0\.d, p0/m, z0\.d, z4\.d, #0
+.*:    64df0000        fcmla   z0\.d, p0/m, z0\.d, z31\.d, #0
+.*:    64df0000        fcmla   z0\.d, p0/m, z0\.d, z31\.d, #0
+.*:    64c02000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #90
+.*:    64c02000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #90
+.*:    64c04000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #180
+.*:    64c04000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #180
+.*:    64c06000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #270
+.*:    64c06000        fcmla   z0\.d, p0/m, z0\.d, z0\.d, #270
+.*:    64a01000        fcmla   z0\.h, z0\.h, z0\.h\[0\], #0
+.*:    64a01000        fcmla   z0\.h, z0\.h, z0\.h\[0\], #0
+.*:    64a01001        fcmla   z1\.h, z0\.h, z0\.h\[0\], #0
+.*:    64a01001        fcmla   z1\.h, z0\.h, z0\.h\[0\], #0
+.*:    64a0101f        fcmla   z31\.h, z0\.h, z0\.h\[0\], #0
+.*:    64a0101f        fcmla   z31\.h, z0\.h, z0\.h\[0\], #0
+.*:    64a01040        fcmla   z0\.h, z2\.h, z0\.h\[0\], #0
+.*:    64a01040        fcmla   z0\.h, z2\.h, z0\.h\[0\], #0
+.*:    64a013e0        fcmla   z0\.h, z31\.h, z0\.h\[0\], #0
+.*:    64a013e0        fcmla   z0\.h, z31\.h, z0\.h\[0\], #0
+.*:    64a31000        fcmla   z0\.h, z0\.h, z3\.h\[0\], #0
+.*:    64a31000        fcmla   z0\.h, z0\.h, z3\.h\[0\], #0
+.*:    64a71000        fcmla   z0\.h, z0\.h, z7\.h\[0\], #0
+.*:    64a71000        fcmla   z0\.h, z0\.h, z7\.h\[0\], #0
+.*:    64a81000        fcmla   z0\.h, z0\.h, z0\.h\[1\], #0
+.*:    64a81000        fcmla   z0\.h, z0\.h, z0\.h\[1\], #0
+.*:    64ad1000        fcmla   z0\.h, z0\.h, z5\.h\[1\], #0
+.*:    64ad1000        fcmla   z0\.h, z0\.h, z5\.h\[1\], #0
+.*:    64b01000        fcmla   z0\.h, z0\.h, z0\.h\[2\], #0
+.*:    64b01000        fcmla   z0\.h, z0\.h, z0\.h\[2\], #0
+.*:    64b31000        fcmla   z0\.h, z0\.h, z3\.h\[2\], #0
+.*:    64b31000        fcmla   z0\.h, z0\.h, z3\.h\[2\], #0
+.*:    64b81000        fcmla   z0\.h, z0\.h, z0\.h\[3\], #0
+.*:    64b81000        fcmla   z0\.h, z0\.h, z0\.h\[3\], #0
+.*:    64be1000        fcmla   z0\.h, z0\.h, z6\.h\[3\], #0
+.*:    64be1000        fcmla   z0\.h, z0\.h, z6\.h\[3\], #0
+.*:    64a01400        fcmla   z0\.h, z0\.h, z0\.h\[0\], #90
+.*:    64a01400        fcmla   z0\.h, z0\.h, z0\.h\[0\], #90
+.*:    64a01800        fcmla   z0\.h, z0\.h, z0\.h\[0\], #180
+.*:    64a01800        fcmla   z0\.h, z0\.h, z0\.h\[0\], #180
+.*:    64a01c00        fcmla   z0\.h, z0\.h, z0\.h\[0\], #270
+.*:    64a01c00        fcmla   z0\.h, z0\.h, z0\.h\[0\], #270
+.*:    64e01000        fcmla   z0\.s, z0\.s, z0\.s\[0\], #0
+.*:    64e01000        fcmla   z0\.s, z0\.s, z0\.s\[0\], #0
+.*:    64e01001        fcmla   z1\.s, z0\.s, z0\.s\[0\], #0
+.*:    64e01001        fcmla   z1\.s, z0\.s, z0\.s\[0\], #0
+.*:    64e0101f        fcmla   z31\.s, z0\.s, z0\.s\[0\], #0
+.*:    64e0101f        fcmla   z31\.s, z0\.s, z0\.s\[0\], #0
+.*:    64e01040        fcmla   z0\.s, z2\.s, z0\.s\[0\], #0
+.*:    64e01040        fcmla   z0\.s, z2\.s, z0\.s\[0\], #0
+.*:    64e013e0        fcmla   z0\.s, z31\.s, z0\.s\[0\], #0
+.*:    64e013e0        fcmla   z0\.s, z31\.s, z0\.s\[0\], #0
+.*:    64e31000        fcmla   z0\.s, z0\.s, z3\.s\[0\], #0
+.*:    64e31000        fcmla   z0\.s, z0\.s, z3\.s\[0\], #0
+.*:    64ef1000        fcmla   z0\.s, z0\.s, z15\.s\[0\], #0
+.*:    64ef1000        fcmla   z0\.s, z0\.s, z15\.s\[0\], #0
+.*:    64f01000        fcmla   z0\.s, z0\.s, z0\.s\[1\], #0
+.*:    64f01000        fcmla   z0\.s, z0\.s, z0\.s\[1\], #0
+.*:    64fb1000        fcmla   z0\.s, z0\.s, z11\.s\[1\], #0
+.*:    64fb1000        fcmla   z0\.s, z0\.s, z11\.s\[1\], #0
+.*:    64e01400        fcmla   z0\.s, z0\.s, z0\.s\[0\], #90
+.*:    64e01400        fcmla   z0\.s, z0\.s, z0\.s\[0\], #90
+.*:    64e01800        fcmla   z0\.s, z0\.s, z0\.s\[0\], #180
+.*:    64e01800        fcmla   z0\.s, z0\.s, z0\.s\[0\], #180
+.*:    64e01c00        fcmla   z0\.s, z0\.s, z0\.s\[0\], #270
+.*:    64e01c00        fcmla   z0\.s, z0\.s, z0\.s\[0\], #270
+.*:    65522000        fcmeq   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65522000        fcmeq   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65522001        fcmeq   p1\.h, p0/z, z0\.h, #0\.0
+.*:    65522001        fcmeq   p1\.h, p0/z, z0\.h, #0\.0
+.*:    6552200f        fcmeq   p15\.h, p0/z, z0\.h, #0\.0
+.*:    6552200f        fcmeq   p15\.h, p0/z, z0\.h, #0\.0
+.*:    65522800        fcmeq   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65522800        fcmeq   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65523c00        fcmeq   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65523c00        fcmeq   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65522060        fcmeq   p0\.h, p0/z, z3\.h, #0\.0
+.*:    65522060        fcmeq   p0\.h, p0/z, z3\.h, #0\.0
+.*:    655223e0        fcmeq   p0\.h, p0/z, z31\.h, #0\.0
+.*:    655223e0        fcmeq   p0\.h, p0/z, z31\.h, #0\.0
 .*:    65922000        fcmeq   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65922000        fcmeq   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65922001        fcmeq   p1\.s, p0/z, z0\.s, #0\.0
@@ -8428,6 +8860,24 @@ Disassembly of section .*:
 .*:    65d22060        fcmeq   p0\.d, p0/z, z3\.d, #0\.0
 .*:    65d223e0        fcmeq   p0\.d, p0/z, z31\.d, #0\.0
 .*:    65d223e0        fcmeq   p0\.d, p0/z, z31\.d, #0\.0
+.*:    65406000        fcmeq   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65406000        fcmeq   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65406001        fcmeq   p1\.h, p0/z, z0\.h, z0\.h
+.*:    65406001        fcmeq   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540600f        fcmeq   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540600f        fcmeq   p15\.h, p0/z, z0\.h, z0\.h
+.*:    65406800        fcmeq   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65406800        fcmeq   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65407c00        fcmeq   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65407c00        fcmeq   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65406060        fcmeq   p0\.h, p0/z, z3\.h, z0\.h
+.*:    65406060        fcmeq   p0\.h, p0/z, z3\.h, z0\.h
+.*:    654063e0        fcmeq   p0\.h, p0/z, z31\.h, z0\.h
+.*:    654063e0        fcmeq   p0\.h, p0/z, z31\.h, z0\.h
+.*:    65446000        fcmeq   p0\.h, p0/z, z0\.h, z4\.h
+.*:    65446000        fcmeq   p0\.h, p0/z, z0\.h, z4\.h
+.*:    655f6000        fcmeq   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655f6000        fcmeq   p0\.h, p0/z, z0\.h, z31\.h
 .*:    65806000        fcmeq   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65806000        fcmeq   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65806001        fcmeq   p1\.s, p0/z, z0\.s, z0\.s
@@ -8464,6 +8914,20 @@ Disassembly of section .*:
 .*:    65c46000        fcmeq   p0\.d, p0/z, z0\.d, z4\.d
 .*:    65df6000        fcmeq   p0\.d, p0/z, z0\.d, z31\.d
 .*:    65df6000        fcmeq   p0\.d, p0/z, z0\.d, z31\.d
+.*:    65502000        fcmge   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65502000        fcmge   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65502001        fcmge   p1\.h, p0/z, z0\.h, #0\.0
+.*:    65502001        fcmge   p1\.h, p0/z, z0\.h, #0\.0
+.*:    6550200f        fcmge   p15\.h, p0/z, z0\.h, #0\.0
+.*:    6550200f        fcmge   p15\.h, p0/z, z0\.h, #0\.0
+.*:    65502800        fcmge   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65502800        fcmge   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65503c00        fcmge   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65503c00        fcmge   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65502060        fcmge   p0\.h, p0/z, z3\.h, #0\.0
+.*:    65502060        fcmge   p0\.h, p0/z, z3\.h, #0\.0
+.*:    655023e0        fcmge   p0\.h, p0/z, z31\.h, #0\.0
+.*:    655023e0        fcmge   p0\.h, p0/z, z31\.h, #0\.0
 .*:    65902000        fcmge   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65902000        fcmge   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65902001        fcmge   p1\.s, p0/z, z0\.s, #0\.0
@@ -8492,6 +8956,24 @@ Disassembly of section .*:
 .*:    65d02060        fcmge   p0\.d, p0/z, z3\.d, #0\.0
 .*:    65d023e0        fcmge   p0\.d, p0/z, z31\.d, #0\.0
 .*:    65d023e0        fcmge   p0\.d, p0/z, z31\.d, #0\.0
+.*:    65404000        fcmge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404000        fcmge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404001        fcmge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    65404001        fcmge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540400f        fcmge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540400f        fcmge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    65404800        fcmge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65404800        fcmge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65405c00        fcmge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65405c00        fcmge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65404060        fcmge   p0\.h, p0/z, z3\.h, z0\.h
+.*:    65404060        fcmge   p0\.h, p0/z, z3\.h, z0\.h
+.*:    654043e0        fcmge   p0\.h, p0/z, z31\.h, z0\.h
+.*:    654043e0        fcmge   p0\.h, p0/z, z31\.h, z0\.h
+.*:    65444000        fcmge   p0\.h, p0/z, z0\.h, z4\.h
+.*:    65444000        fcmge   p0\.h, p0/z, z0\.h, z4\.h
+.*:    655f4000        fcmge   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655f4000        fcmge   p0\.h, p0/z, z0\.h, z31\.h
 .*:    65804000        fcmge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804000        fcmge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804001        fcmge   p1\.s, p0/z, z0\.s, z0\.s
@@ -8528,6 +9010,20 @@ Disassembly of section .*:
 .*:    65c44000        fcmge   p0\.d, p0/z, z0\.d, z4\.d
 .*:    65df4000        fcmge   p0\.d, p0/z, z0\.d, z31\.d
 .*:    65df4000        fcmge   p0\.d, p0/z, z0\.d, z31\.d
+.*:    65502010        fcmgt   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65502010        fcmgt   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65502011        fcmgt   p1\.h, p0/z, z0\.h, #0\.0
+.*:    65502011        fcmgt   p1\.h, p0/z, z0\.h, #0\.0
+.*:    6550201f        fcmgt   p15\.h, p0/z, z0\.h, #0\.0
+.*:    6550201f        fcmgt   p15\.h, p0/z, z0\.h, #0\.0
+.*:    65502810        fcmgt   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65502810        fcmgt   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65503c10        fcmgt   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65503c10        fcmgt   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65502070        fcmgt   p0\.h, p0/z, z3\.h, #0\.0
+.*:    65502070        fcmgt   p0\.h, p0/z, z3\.h, #0\.0
+.*:    655023f0        fcmgt   p0\.h, p0/z, z31\.h, #0\.0
+.*:    655023f0        fcmgt   p0\.h, p0/z, z31\.h, #0\.0
 .*:    65902010        fcmgt   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65902010        fcmgt   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65902011        fcmgt   p1\.s, p0/z, z0\.s, #0\.0
@@ -8556,6 +9052,24 @@ Disassembly of section .*:
 .*:    65d02070        fcmgt   p0\.d, p0/z, z3\.d, #0\.0
 .*:    65d023f0        fcmgt   p0\.d, p0/z, z31\.d, #0\.0
 .*:    65d023f0        fcmgt   p0\.d, p0/z, z31\.d, #0\.0
+.*:    65404010        fcmgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404010        fcmgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404011        fcmgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    65404011        fcmgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540401f        fcmgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540401f        fcmgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    65404810        fcmgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65404810        fcmgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65405c10        fcmgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65405c10        fcmgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65404070        fcmgt   p0\.h, p0/z, z3\.h, z0\.h
+.*:    65404070        fcmgt   p0\.h, p0/z, z3\.h, z0\.h
+.*:    654043f0        fcmgt   p0\.h, p0/z, z31\.h, z0\.h
+.*:    654043f0        fcmgt   p0\.h, p0/z, z31\.h, z0\.h
+.*:    65444010        fcmgt   p0\.h, p0/z, z0\.h, z4\.h
+.*:    65444010        fcmgt   p0\.h, p0/z, z0\.h, z4\.h
+.*:    655f4010        fcmgt   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655f4010        fcmgt   p0\.h, p0/z, z0\.h, z31\.h
 .*:    65804010        fcmgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804010        fcmgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804011        fcmgt   p1\.s, p0/z, z0\.s, z0\.s
@@ -8592,6 +9106,20 @@ Disassembly of section .*:
 .*:    65c44010        fcmgt   p0\.d, p0/z, z0\.d, z4\.d
 .*:    65df4010        fcmgt   p0\.d, p0/z, z0\.d, z31\.d
 .*:    65df4010        fcmgt   p0\.d, p0/z, z0\.d, z31\.d
+.*:    65512010        fcmle   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65512010        fcmle   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65512011        fcmle   p1\.h, p0/z, z0\.h, #0\.0
+.*:    65512011        fcmle   p1\.h, p0/z, z0\.h, #0\.0
+.*:    6551201f        fcmle   p15\.h, p0/z, z0\.h, #0\.0
+.*:    6551201f        fcmle   p15\.h, p0/z, z0\.h, #0\.0
+.*:    65512810        fcmle   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65512810        fcmle   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65513c10        fcmle   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65513c10        fcmle   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65512070        fcmle   p0\.h, p0/z, z3\.h, #0\.0
+.*:    65512070        fcmle   p0\.h, p0/z, z3\.h, #0\.0
+.*:    655123f0        fcmle   p0\.h, p0/z, z31\.h, #0\.0
+.*:    655123f0        fcmle   p0\.h, p0/z, z31\.h, #0\.0
 .*:    65912010        fcmle   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65912010        fcmle   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65912011        fcmle   p1\.s, p0/z, z0\.s, #0\.0
@@ -8620,6 +9148,20 @@ Disassembly of section .*:
 .*:    65d12070        fcmle   p0\.d, p0/z, z3\.d, #0\.0
 .*:    65d123f0        fcmle   p0\.d, p0/z, z31\.d, #0\.0
 .*:    65d123f0        fcmle   p0\.d, p0/z, z31\.d, #0\.0
+.*:    65512000        fcmlt   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65512000        fcmlt   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65512001        fcmlt   p1\.h, p0/z, z0\.h, #0\.0
+.*:    65512001        fcmlt   p1\.h, p0/z, z0\.h, #0\.0
+.*:    6551200f        fcmlt   p15\.h, p0/z, z0\.h, #0\.0
+.*:    6551200f        fcmlt   p15\.h, p0/z, z0\.h, #0\.0
+.*:    65512800        fcmlt   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65512800        fcmlt   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65513c00        fcmlt   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65513c00        fcmlt   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65512060        fcmlt   p0\.h, p0/z, z3\.h, #0\.0
+.*:    65512060        fcmlt   p0\.h, p0/z, z3\.h, #0\.0
+.*:    655123e0        fcmlt   p0\.h, p0/z, z31\.h, #0\.0
+.*:    655123e0        fcmlt   p0\.h, p0/z, z31\.h, #0\.0
 .*:    65912000        fcmlt   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65912000        fcmlt   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65912001        fcmlt   p1\.s, p0/z, z0\.s, #0\.0
@@ -8648,6 +9190,20 @@ Disassembly of section .*:
 .*:    65d12060        fcmlt   p0\.d, p0/z, z3\.d, #0\.0
 .*:    65d123e0        fcmlt   p0\.d, p0/z, z31\.d, #0\.0
 .*:    65d123e0        fcmlt   p0\.d, p0/z, z31\.d, #0\.0
+.*:    65532000        fcmne   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65532000        fcmne   p0\.h, p0/z, z0\.h, #0\.0
+.*:    65532001        fcmne   p1\.h, p0/z, z0\.h, #0\.0
+.*:    65532001        fcmne   p1\.h, p0/z, z0\.h, #0\.0
+.*:    6553200f        fcmne   p15\.h, p0/z, z0\.h, #0\.0
+.*:    6553200f        fcmne   p15\.h, p0/z, z0\.h, #0\.0
+.*:    65532800        fcmne   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65532800        fcmne   p0\.h, p2/z, z0\.h, #0\.0
+.*:    65533c00        fcmne   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65533c00        fcmne   p0\.h, p7/z, z0\.h, #0\.0
+.*:    65532060        fcmne   p0\.h, p0/z, z3\.h, #0\.0
+.*:    65532060        fcmne   p0\.h, p0/z, z3\.h, #0\.0
+.*:    655323e0        fcmne   p0\.h, p0/z, z31\.h, #0\.0
+.*:    655323e0        fcmne   p0\.h, p0/z, z31\.h, #0\.0
 .*:    65932000        fcmne   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65932000        fcmne   p0\.s, p0/z, z0\.s, #0\.0
 .*:    65932001        fcmne   p1\.s, p0/z, z0\.s, #0\.0
@@ -8676,6 +9232,24 @@ Disassembly of section .*:
 .*:    65d32060        fcmne   p0\.d, p0/z, z3\.d, #0\.0
 .*:    65d323e0        fcmne   p0\.d, p0/z, z31\.d, #0\.0
 .*:    65d323e0        fcmne   p0\.d, p0/z, z31\.d, #0\.0
+.*:    65406010        fcmne   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65406010        fcmne   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65406011        fcmne   p1\.h, p0/z, z0\.h, z0\.h
+.*:    65406011        fcmne   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540601f        fcmne   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540601f        fcmne   p15\.h, p0/z, z0\.h, z0\.h
+.*:    65406810        fcmne   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65406810        fcmne   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65407c10        fcmne   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65407c10        fcmne   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65406070        fcmne   p0\.h, p0/z, z3\.h, z0\.h
+.*:    65406070        fcmne   p0\.h, p0/z, z3\.h, z0\.h
+.*:    654063f0        fcmne   p0\.h, p0/z, z31\.h, z0\.h
+.*:    654063f0        fcmne   p0\.h, p0/z, z31\.h, z0\.h
+.*:    65446010        fcmne   p0\.h, p0/z, z0\.h, z4\.h
+.*:    65446010        fcmne   p0\.h, p0/z, z0\.h, z4\.h
+.*:    655f6010        fcmne   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655f6010        fcmne   p0\.h, p0/z, z0\.h, z31\.h
 .*:    65806010        fcmne   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65806010        fcmne   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65806011        fcmne   p1\.s, p0/z, z0\.s, z0\.s
@@ -8712,6 +9286,24 @@ Disassembly of section .*:
 .*:    65c46010        fcmne   p0\.d, p0/z, z0\.d, z4\.d
 .*:    65df6010        fcmne   p0\.d, p0/z, z0\.d, z31\.d
 .*:    65df6010        fcmne   p0\.d, p0/z, z0\.d, z31\.d
+.*:    6540c000        fcmuo   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540c000        fcmuo   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540c001        fcmuo   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540c001        fcmuo   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540c00f        fcmuo   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540c00f        fcmuo   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540c800        fcmuo   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540c800        fcmuo   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540dc00        fcmuo   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540dc00        fcmuo   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540c060        fcmuo   p0\.h, p0/z, z3\.h, z0\.h
+.*:    6540c060        fcmuo   p0\.h, p0/z, z3\.h, z0\.h
+.*:    6540c3e0        fcmuo   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6540c3e0        fcmuo   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6544c000        fcmuo   p0\.h, p0/z, z0\.h, z4\.h
+.*:    6544c000        fcmuo   p0\.h, p0/z, z0\.h, z4\.h
+.*:    655fc000        fcmuo   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655fc000        fcmuo   p0\.h, p0/z, z0\.h, z31\.h
 .*:    6580c000        fcmuo   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580c000        fcmuo   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580c001        fcmuo   p1\.s, p0/z, z0\.s, z0\.s
@@ -8748,6 +9340,28 @@ Disassembly of section .*:
 .*:    65c4c000        fcmuo   p0\.d, p0/z, z0\.d, z4\.d
 .*:    65dfc000        fcmuo   p0\.d, p0/z, z0\.d, z31\.d
 .*:    65dfc000        fcmuo   p0\.d, p0/z, z0\.d, z31\.d
+.*:    0550c000        fmov    z0\.h, p0/m, #2\.0+e\+00
+.*:    0550c000        fmov    z0\.h, p0/m, #2\.0+e\+00
+.*:    0550c001        fmov    z1\.h, p0/m, #2\.0+e\+00
+.*:    0550c001        fmov    z1\.h, p0/m, #2\.0+e\+00
+.*:    0550c01f        fmov    z31\.h, p0/m, #2\.0+e\+00
+.*:    0550c01f        fmov    z31\.h, p0/m, #2\.0+e\+00
+.*:    0552c000        fmov    z0\.h, p2/m, #2\.0+e\+00
+.*:    0552c000        fmov    z0\.h, p2/m, #2\.0+e\+00
+.*:    055fc000        fmov    z0\.h, p15/m, #2\.0+e\+00
+.*:    055fc000        fmov    z0\.h, p15/m, #2\.0+e\+00
+.*:    0550c600        fmov    z0\.h, p0/m, #1\.60+e\+01
+.*:    0550c600        fmov    z0\.h, p0/m, #1\.60+e\+01
+.*:    0550c900        fmov    z0\.h, p0/m, #1\.8750+e-01
+.*:    0550c900        fmov    z0\.h, p0/m, #1\.8750+e-01
+.*:    0550cfe0        fmov    z0\.h, p0/m, #1\.93750+e\+00
+.*:    0550cfe0        fmov    z0\.h, p0/m, #1\.93750+e\+00
+.*:    0550d100        fmov    z0\.h, p0/m, #-3\.0+e\+00
+.*:    0550d100        fmov    z0\.h, p0/m, #-3\.0+e\+00
+.*:    0550d800        fmov    z0\.h, p0/m, #-1\.250+e-01
+.*:    0550d800        fmov    z0\.h, p0/m, #-1\.250+e-01
+.*:    0550dfe0        fmov    z0\.h, p0/m, #-1\.93750+e\+00
+.*:    0550dfe0        fmov    z0\.h, p0/m, #-1\.93750+e\+00
 .*:    0590c000        fmov    z0\.s, p0/m, #2\.0+e\+00
 .*:    0590c000        fmov    z0\.s, p0/m, #2\.0+e\+00
 .*:    0590c001        fmov    z1\.s, p0/m, #2\.0+e\+00
@@ -8876,6 +9490,48 @@ Disassembly of section .*:
 .*:    65cba060        fcvt    z0\.d, p0/m, z3\.s
 .*:    65cba3e0        fcvt    z0\.d, p0/m, z31\.s
 .*:    65cba3e0        fcvt    z0\.d, p0/m, z31\.s
+.*:    655aa000        fcvtzs  z0\.h, p0/m, z0\.h
+.*:    655aa000        fcvtzs  z0\.h, p0/m, z0\.h
+.*:    655aa001        fcvtzs  z1\.h, p0/m, z0\.h
+.*:    655aa001        fcvtzs  z1\.h, p0/m, z0\.h
+.*:    655aa01f        fcvtzs  z31\.h, p0/m, z0\.h
+.*:    655aa01f        fcvtzs  z31\.h, p0/m, z0\.h
+.*:    655aa800        fcvtzs  z0\.h, p2/m, z0\.h
+.*:    655aa800        fcvtzs  z0\.h, p2/m, z0\.h
+.*:    655abc00        fcvtzs  z0\.h, p7/m, z0\.h
+.*:    655abc00        fcvtzs  z0\.h, p7/m, z0\.h
+.*:    655aa060        fcvtzs  z0\.h, p0/m, z3\.h
+.*:    655aa060        fcvtzs  z0\.h, p0/m, z3\.h
+.*:    655aa3e0        fcvtzs  z0\.h, p0/m, z31\.h
+.*:    655aa3e0        fcvtzs  z0\.h, p0/m, z31\.h
+.*:    655ca000        fcvtzs  z0\.s, p0/m, z0\.h
+.*:    655ca000        fcvtzs  z0\.s, p0/m, z0\.h
+.*:    655ca001        fcvtzs  z1\.s, p0/m, z0\.h
+.*:    655ca001        fcvtzs  z1\.s, p0/m, z0\.h
+.*:    655ca01f        fcvtzs  z31\.s, p0/m, z0\.h
+.*:    655ca01f        fcvtzs  z31\.s, p0/m, z0\.h
+.*:    655ca800        fcvtzs  z0\.s, p2/m, z0\.h
+.*:    655ca800        fcvtzs  z0\.s, p2/m, z0\.h
+.*:    655cbc00        fcvtzs  z0\.s, p7/m, z0\.h
+.*:    655cbc00        fcvtzs  z0\.s, p7/m, z0\.h
+.*:    655ca060        fcvtzs  z0\.s, p0/m, z3\.h
+.*:    655ca060        fcvtzs  z0\.s, p0/m, z3\.h
+.*:    655ca3e0        fcvtzs  z0\.s, p0/m, z31\.h
+.*:    655ca3e0        fcvtzs  z0\.s, p0/m, z31\.h
+.*:    655ea000        fcvtzs  z0\.d, p0/m, z0\.h
+.*:    655ea000        fcvtzs  z0\.d, p0/m, z0\.h
+.*:    655ea001        fcvtzs  z1\.d, p0/m, z0\.h
+.*:    655ea001        fcvtzs  z1\.d, p0/m, z0\.h
+.*:    655ea01f        fcvtzs  z31\.d, p0/m, z0\.h
+.*:    655ea01f        fcvtzs  z31\.d, p0/m, z0\.h
+.*:    655ea800        fcvtzs  z0\.d, p2/m, z0\.h
+.*:    655ea800        fcvtzs  z0\.d, p2/m, z0\.h
+.*:    655ebc00        fcvtzs  z0\.d, p7/m, z0\.h
+.*:    655ebc00        fcvtzs  z0\.d, p7/m, z0\.h
+.*:    655ea060        fcvtzs  z0\.d, p0/m, z3\.h
+.*:    655ea060        fcvtzs  z0\.d, p0/m, z3\.h
+.*:    655ea3e0        fcvtzs  z0\.d, p0/m, z31\.h
+.*:    655ea3e0        fcvtzs  z0\.d, p0/m, z31\.h
 .*:    659ca000        fcvtzs  z0\.s, p0/m, z0\.s
 .*:    659ca000        fcvtzs  z0\.s, p0/m, z0\.s
 .*:    659ca001        fcvtzs  z1\.s, p0/m, z0\.s
@@ -8932,6 +9588,48 @@ Disassembly of section .*:
 .*:    65dea060        fcvtzs  z0\.d, p0/m, z3\.d
 .*:    65dea3e0        fcvtzs  z0\.d, p0/m, z31\.d
 .*:    65dea3e0        fcvtzs  z0\.d, p0/m, z31\.d
+.*:    655ba000        fcvtzu  z0\.h, p0/m, z0\.h
+.*:    655ba000        fcvtzu  z0\.h, p0/m, z0\.h
+.*:    655ba001        fcvtzu  z1\.h, p0/m, z0\.h
+.*:    655ba001        fcvtzu  z1\.h, p0/m, z0\.h
+.*:    655ba01f        fcvtzu  z31\.h, p0/m, z0\.h
+.*:    655ba01f        fcvtzu  z31\.h, p0/m, z0\.h
+.*:    655ba800        fcvtzu  z0\.h, p2/m, z0\.h
+.*:    655ba800        fcvtzu  z0\.h, p2/m, z0\.h
+.*:    655bbc00        fcvtzu  z0\.h, p7/m, z0\.h
+.*:    655bbc00        fcvtzu  z0\.h, p7/m, z0\.h
+.*:    655ba060        fcvtzu  z0\.h, p0/m, z3\.h
+.*:    655ba060        fcvtzu  z0\.h, p0/m, z3\.h
+.*:    655ba3e0        fcvtzu  z0\.h, p0/m, z31\.h
+.*:    655ba3e0        fcvtzu  z0\.h, p0/m, z31\.h
+.*:    655da000        fcvtzu  z0\.s, p0/m, z0\.h
+.*:    655da000        fcvtzu  z0\.s, p0/m, z0\.h
+.*:    655da001        fcvtzu  z1\.s, p0/m, z0\.h
+.*:    655da001        fcvtzu  z1\.s, p0/m, z0\.h
+.*:    655da01f        fcvtzu  z31\.s, p0/m, z0\.h
+.*:    655da01f        fcvtzu  z31\.s, p0/m, z0\.h
+.*:    655da800        fcvtzu  z0\.s, p2/m, z0\.h
+.*:    655da800        fcvtzu  z0\.s, p2/m, z0\.h
+.*:    655dbc00        fcvtzu  z0\.s, p7/m, z0\.h
+.*:    655dbc00        fcvtzu  z0\.s, p7/m, z0\.h
+.*:    655da060        fcvtzu  z0\.s, p0/m, z3\.h
+.*:    655da060        fcvtzu  z0\.s, p0/m, z3\.h
+.*:    655da3e0        fcvtzu  z0\.s, p0/m, z31\.h
+.*:    655da3e0        fcvtzu  z0\.s, p0/m, z31\.h
+.*:    655fa000        fcvtzu  z0\.d, p0/m, z0\.h
+.*:    655fa000        fcvtzu  z0\.d, p0/m, z0\.h
+.*:    655fa001        fcvtzu  z1\.d, p0/m, z0\.h
+.*:    655fa001        fcvtzu  z1\.d, p0/m, z0\.h
+.*:    655fa01f        fcvtzu  z31\.d, p0/m, z0\.h
+.*:    655fa01f        fcvtzu  z31\.d, p0/m, z0\.h
+.*:    655fa800        fcvtzu  z0\.d, p2/m, z0\.h
+.*:    655fa800        fcvtzu  z0\.d, p2/m, z0\.h
+.*:    655fbc00        fcvtzu  z0\.d, p7/m, z0\.h
+.*:    655fbc00        fcvtzu  z0\.d, p7/m, z0\.h
+.*:    655fa060        fcvtzu  z0\.d, p0/m, z3\.h
+.*:    655fa060        fcvtzu  z0\.d, p0/m, z3\.h
+.*:    655fa3e0        fcvtzu  z0\.d, p0/m, z31\.h
+.*:    655fa3e0        fcvtzu  z0\.d, p0/m, z31\.h
 .*:    659da000        fcvtzu  z0\.s, p0/m, z0\.s
 .*:    659da000        fcvtzu  z0\.s, p0/m, z0\.s
 .*:    659da001        fcvtzu  z1\.s, p0/m, z0\.s
@@ -8988,6 +9686,22 @@ Disassembly of section .*:
 .*:    65dfa060        fcvtzu  z0\.d, p0/m, z3\.d
 .*:    65dfa3e0        fcvtzu  z0\.d, p0/m, z31\.d
 .*:    65dfa3e0        fcvtzu  z0\.d, p0/m, z31\.d
+.*:    654d8000        fdiv    z0\.h, p0/m, z0\.h, z0\.h
+.*:    654d8000        fdiv    z0\.h, p0/m, z0\.h, z0\.h
+.*:    654d8001        fdiv    z1\.h, p0/m, z1\.h, z0\.h
+.*:    654d8001        fdiv    z1\.h, p0/m, z1\.h, z0\.h
+.*:    654d801f        fdiv    z31\.h, p0/m, z31\.h, z0\.h
+.*:    654d801f        fdiv    z31\.h, p0/m, z31\.h, z0\.h
+.*:    654d8800        fdiv    z0\.h, p2/m, z0\.h, z0\.h
+.*:    654d8800        fdiv    z0\.h, p2/m, z0\.h, z0\.h
+.*:    654d9c00        fdiv    z0\.h, p7/m, z0\.h, z0\.h
+.*:    654d9c00        fdiv    z0\.h, p7/m, z0\.h, z0\.h
+.*:    654d8003        fdiv    z3\.h, p0/m, z3\.h, z0\.h
+.*:    654d8003        fdiv    z3\.h, p0/m, z3\.h, z0\.h
+.*:    654d8080        fdiv    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654d8080        fdiv    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654d83e0        fdiv    z0\.h, p0/m, z0\.h, z31\.h
+.*:    654d83e0        fdiv    z0\.h, p0/m, z0\.h, z31\.h
 .*:    658d8000        fdiv    z0\.s, p0/m, z0\.s, z0\.s
 .*:    658d8000        fdiv    z0\.s, p0/m, z0\.s, z0\.s
 .*:    658d8001        fdiv    z1\.s, p0/m, z1\.s, z0\.s
@@ -9020,6 +9734,22 @@ Disassembly of section .*:
 .*:    65cd8080        fdiv    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65cd83e0        fdiv    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65cd83e0        fdiv    z0\.d, p0/m, z0\.d, z31\.d
+.*:    654c8000        fdivr   z0\.h, p0/m, z0\.h, z0\.h
+.*:    654c8000        fdivr   z0\.h, p0/m, z0\.h, z0\.h
+.*:    654c8001        fdivr   z1\.h, p0/m, z1\.h, z0\.h
+.*:    654c8001        fdivr   z1\.h, p0/m, z1\.h, z0\.h
+.*:    654c801f        fdivr   z31\.h, p0/m, z31\.h, z0\.h
+.*:    654c801f        fdivr   z31\.h, p0/m, z31\.h, z0\.h
+.*:    654c8800        fdivr   z0\.h, p2/m, z0\.h, z0\.h
+.*:    654c8800        fdivr   z0\.h, p2/m, z0\.h, z0\.h
+.*:    654c9c00        fdivr   z0\.h, p7/m, z0\.h, z0\.h
+.*:    654c9c00        fdivr   z0\.h, p7/m, z0\.h, z0\.h
+.*:    654c8003        fdivr   z3\.h, p0/m, z3\.h, z0\.h
+.*:    654c8003        fdivr   z3\.h, p0/m, z3\.h, z0\.h
+.*:    654c8080        fdivr   z0\.h, p0/m, z0\.h, z4\.h
+.*:    654c8080        fdivr   z0\.h, p0/m, z0\.h, z4\.h
+.*:    654c83e0        fdivr   z0\.h, p0/m, z0\.h, z31\.h
+.*:    654c83e0        fdivr   z0\.h, p0/m, z0\.h, z31\.h
 .*:    658c8000        fdivr   z0\.s, p0/m, z0\.s, z0\.s
 .*:    658c8000        fdivr   z0\.s, p0/m, z0\.s, z0\.s
 .*:    658c8001        fdivr   z1\.s, p0/m, z1\.s, z0\.s
@@ -9052,6 +9782,24 @@ Disassembly of section .*:
 .*:    65cc8080        fdivr   z0\.d, p0/m, z0\.d, z4\.d
 .*:    65cc83e0        fdivr   z0\.d, p0/m, z0\.d, z31\.d
 .*:    65cc83e0        fdivr   z0\.d, p0/m, z0\.d, z31\.d
+.*:    2579c000        fmov    z0\.h, #2\.0+e\+00
+.*:    2579c000        fmov    z0\.h, #2\.0+e\+00
+.*:    2579c001        fmov    z1\.h, #2\.0+e\+00
+.*:    2579c001        fmov    z1\.h, #2\.0+e\+00
+.*:    2579c01f        fmov    z31\.h, #2\.0+e\+00
+.*:    2579c01f        fmov    z31\.h, #2\.0+e\+00
+.*:    2579c600        fmov    z0\.h, #1\.60+e\+01
+.*:    2579c600        fmov    z0\.h, #1\.60+e\+01
+.*:    2579c900        fmov    z0\.h, #1\.8750+e-01
+.*:    2579c900        fmov    z0\.h, #1\.8750+e-01
+.*:    2579cfe0        fmov    z0\.h, #1\.93750+e\+00
+.*:    2579cfe0        fmov    z0\.h, #1\.93750+e\+00
+.*:    2579d100        fmov    z0\.h, #-3\.0+e\+00
+.*:    2579d100        fmov    z0\.h, #-3\.0+e\+00
+.*:    2579d800        fmov    z0\.h, #-1\.250+e-01
+.*:    2579d800        fmov    z0\.h, #-1\.250+e-01
+.*:    2579dfe0        fmov    z0\.h, #-1\.93750+e\+00
+.*:    2579dfe0        fmov    z0\.h, #-1\.93750+e\+00
 .*:    25b9c000        fmov    z0\.s, #2\.0+e\+00
 .*:    25b9c000        fmov    z0\.s, #2\.0+e\+00
 .*:    25b9c001        fmov    z1\.s, #2\.0+e\+00
@@ -9088,6 +9836,16 @@ Disassembly of section .*:
 .*:    25f9d800        fmov    z0\.d, #-1\.250+e-01
 .*:    25f9dfe0        fmov    z0\.d, #-1\.93750+e\+00
 .*:    25f9dfe0        fmov    z0\.d, #-1\.93750+e\+00
+.*:    0460b800        fexpa   z0\.h, z0\.h
+.*:    0460b800        fexpa   z0\.h, z0\.h
+.*:    0460b801        fexpa   z1\.h, z0\.h
+.*:    0460b801        fexpa   z1\.h, z0\.h
+.*:    0460b81f        fexpa   z31\.h, z0\.h
+.*:    0460b81f        fexpa   z31\.h, z0\.h
+.*:    0460b840        fexpa   z0\.h, z2\.h
+.*:    0460b840        fexpa   z0\.h, z2\.h
+.*:    0460bbe0        fexpa   z0\.h, z31\.h
+.*:    0460bbe0        fexpa   z0\.h, z31\.h
 .*:    04a0b800        fexpa   z0\.s, z0\.s
 .*:    04a0b800        fexpa   z0\.s, z0\.s
 .*:    04a0b801        fexpa   z1\.s, z0\.s
@@ -9108,6 +9866,24 @@ Disassembly of section .*:
 .*:    04e0b840        fexpa   z0\.d, z2\.d
 .*:    04e0bbe0        fexpa   z0\.d, z31\.d
 .*:    04e0bbe0        fexpa   z0\.d, z31\.d
+.*:    65608000        fmad    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65608000        fmad    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65608001        fmad    z1\.h, p0/m, z0\.h, z0\.h
+.*:    65608001        fmad    z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560801f        fmad    z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560801f        fmad    z31\.h, p0/m, z0\.h, z0\.h
+.*:    65608800        fmad    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65608800        fmad    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65609c00        fmad    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65609c00        fmad    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65608060        fmad    z0\.h, p0/m, z3\.h, z0\.h
+.*:    65608060        fmad    z0\.h, p0/m, z3\.h, z0\.h
+.*:    656083e0        fmad    z0\.h, p0/m, z31\.h, z0\.h
+.*:    656083e0        fmad    z0\.h, p0/m, z31\.h, z0\.h
+.*:    65648000        fmad    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65648000        fmad    z0\.h, p0/m, z0\.h, z4\.h
+.*:    657f8000        fmad    z0\.h, p0/m, z0\.h, z31\.h
+.*:    657f8000        fmad    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a08000        fmad    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a08000        fmad    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a08001        fmad    z1\.s, p0/m, z0\.s, z0\.s
@@ -9144,6 +9920,22 @@ Disassembly of section .*:
 .*:    65e48000        fmad    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ff8000        fmad    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ff8000        fmad    z0\.d, p0/m, z0\.d, z31\.d
+.*:    65468000        fmax    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65468000        fmax    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65468001        fmax    z1\.h, p0/m, z1\.h, z0\.h
+.*:    65468001        fmax    z1\.h, p0/m, z1\.h, z0\.h
+.*:    6546801f        fmax    z31\.h, p0/m, z31\.h, z0\.h
+.*:    6546801f        fmax    z31\.h, p0/m, z31\.h, z0\.h
+.*:    65468800        fmax    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65468800        fmax    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65469c00        fmax    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65469c00        fmax    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65468003        fmax    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65468003        fmax    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65468080        fmax    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65468080        fmax    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654683e0        fmax    z0\.h, p0/m, z0\.h, z31\.h
+.*:    654683e0        fmax    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65868000        fmax    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65868000        fmax    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65868001        fmax    z1\.s, p0/m, z1\.s, z0\.s
@@ -9176,6 +9968,34 @@ Disassembly of section .*:
 .*:    65c68080        fmax    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c683e0        fmax    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c683e0        fmax    z0\.d, p0/m, z0\.d, z31\.d
+.*:    655e8000        fmax    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655e8000        fmax    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655e8000        fmax    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655e8000        fmax    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655e8001        fmax    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655e8001        fmax    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655e8001        fmax    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655e8001        fmax    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655e801f        fmax    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655e801f        fmax    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655e801f        fmax    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655e801f        fmax    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655e8800        fmax    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655e8800        fmax    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655e8800        fmax    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655e8800        fmax    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655e9c00        fmax    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655e9c00        fmax    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655e9c00        fmax    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655e9c00        fmax    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655e8003        fmax    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655e8003        fmax    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655e8003        fmax    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655e8003        fmax    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655e8020        fmax    z0\.h, p0/m, z0\.h, #1\.0
+.*:    655e8020        fmax    z0\.h, p0/m, z0\.h, #1\.0
+.*:    655e8020        fmax    z0\.h, p0/m, z0\.h, #1\.0
+.*:    655e8020        fmax    z0\.h, p0/m, z0\.h, #1\.0
 .*:    659e8000        fmax    z0\.s, p0/m, z0\.s, #0\.0
 .*:    659e8000        fmax    z0\.s, p0/m, z0\.s, #0\.0
 .*:    659e8000        fmax    z0\.s, p0/m, z0\.s, #0\.0
@@ -9232,6 +10052,22 @@ Disassembly of section .*:
 .*:    65de8020        fmax    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65de8020        fmax    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65de8020        fmax    z0\.d, p0/m, z0\.d, #1\.0
+.*:    65448000        fmaxnm  z0\.h, p0/m, z0\.h, z0\.h
+.*:    65448000        fmaxnm  z0\.h, p0/m, z0\.h, z0\.h
+.*:    65448001        fmaxnm  z1\.h, p0/m, z1\.h, z0\.h
+.*:    65448001        fmaxnm  z1\.h, p0/m, z1\.h, z0\.h
+.*:    6544801f        fmaxnm  z31\.h, p0/m, z31\.h, z0\.h
+.*:    6544801f        fmaxnm  z31\.h, p0/m, z31\.h, z0\.h
+.*:    65448800        fmaxnm  z0\.h, p2/m, z0\.h, z0\.h
+.*:    65448800        fmaxnm  z0\.h, p2/m, z0\.h, z0\.h
+.*:    65449c00        fmaxnm  z0\.h, p7/m, z0\.h, z0\.h
+.*:    65449c00        fmaxnm  z0\.h, p7/m, z0\.h, z0\.h
+.*:    65448003        fmaxnm  z3\.h, p0/m, z3\.h, z0\.h
+.*:    65448003        fmaxnm  z3\.h, p0/m, z3\.h, z0\.h
+.*:    65448080        fmaxnm  z0\.h, p0/m, z0\.h, z4\.h
+.*:    65448080        fmaxnm  z0\.h, p0/m, z0\.h, z4\.h
+.*:    654483e0        fmaxnm  z0\.h, p0/m, z0\.h, z31\.h
+.*:    654483e0        fmaxnm  z0\.h, p0/m, z0\.h, z31\.h
 .*:    65848000        fmaxnm  z0\.s, p0/m, z0\.s, z0\.s
 .*:    65848000        fmaxnm  z0\.s, p0/m, z0\.s, z0\.s
 .*:    65848001        fmaxnm  z1\.s, p0/m, z1\.s, z0\.s
@@ -9264,6 +10100,34 @@ Disassembly of section .*:
 .*:    65c48080        fmaxnm  z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c483e0        fmaxnm  z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c483e0        fmaxnm  z0\.d, p0/m, z0\.d, z31\.d
+.*:    655c8000        fmaxnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655c8000        fmaxnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655c8000        fmaxnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655c8000        fmaxnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655c8001        fmaxnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655c8001        fmaxnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655c8001        fmaxnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655c8001        fmaxnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655c801f        fmaxnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655c801f        fmaxnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655c801f        fmaxnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655c801f        fmaxnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655c8800        fmaxnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655c8800        fmaxnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655c8800        fmaxnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655c8800        fmaxnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655c9c00        fmaxnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655c9c00        fmaxnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655c9c00        fmaxnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655c9c00        fmaxnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655c8003        fmaxnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655c8003        fmaxnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655c8003        fmaxnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655c8003        fmaxnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655c8020        fmaxnm  z0\.h, p0/m, z0\.h, #1\.0
+.*:    655c8020        fmaxnm  z0\.h, p0/m, z0\.h, #1\.0
+.*:    655c8020        fmaxnm  z0\.h, p0/m, z0\.h, #1\.0
+.*:    655c8020        fmaxnm  z0\.h, p0/m, z0\.h, #1\.0
 .*:    659c8000        fmaxnm  z0\.s, p0/m, z0\.s, #0\.0
 .*:    659c8000        fmaxnm  z0\.s, p0/m, z0\.s, #0\.0
 .*:    659c8000        fmaxnm  z0\.s, p0/m, z0\.s, #0\.0
@@ -9320,6 +10184,20 @@ Disassembly of section .*:
 .*:    65dc8020        fmaxnm  z0\.d, p0/m, z0\.d, #1\.0
 .*:    65dc8020        fmaxnm  z0\.d, p0/m, z0\.d, #1\.0
 .*:    65dc8020        fmaxnm  z0\.d, p0/m, z0\.d, #1\.0
+.*:    65442000        fmaxnmv h0, p0, z0\.h
+.*:    65442000        fmaxnmv h0, p0, z0\.h
+.*:    65442001        fmaxnmv h1, p0, z0\.h
+.*:    65442001        fmaxnmv h1, p0, z0\.h
+.*:    6544201f        fmaxnmv h31, p0, z0\.h
+.*:    6544201f        fmaxnmv h31, p0, z0\.h
+.*:    65442800        fmaxnmv h0, p2, z0\.h
+.*:    65442800        fmaxnmv h0, p2, z0\.h
+.*:    65443c00        fmaxnmv h0, p7, z0\.h
+.*:    65443c00        fmaxnmv h0, p7, z0\.h
+.*:    65442060        fmaxnmv h0, p0, z3\.h
+.*:    65442060        fmaxnmv h0, p0, z3\.h
+.*:    654423e0        fmaxnmv h0, p0, z31\.h
+.*:    654423e0        fmaxnmv h0, p0, z31\.h
 .*:    65842000        fmaxnmv s0, p0, z0\.s
 .*:    65842000        fmaxnmv s0, p0, z0\.s
 .*:    65842001        fmaxnmv s1, p0, z0\.s
@@ -9348,6 +10226,20 @@ Disassembly of section .*:
 .*:    65c42060        fmaxnmv d0, p0, z3\.d
 .*:    65c423e0        fmaxnmv d0, p0, z31\.d
 .*:    65c423e0        fmaxnmv d0, p0, z31\.d
+.*:    65462000        fmaxv   h0, p0, z0\.h
+.*:    65462000        fmaxv   h0, p0, z0\.h
+.*:    65462001        fmaxv   h1, p0, z0\.h
+.*:    65462001        fmaxv   h1, p0, z0\.h
+.*:    6546201f        fmaxv   h31, p0, z0\.h
+.*:    6546201f        fmaxv   h31, p0, z0\.h
+.*:    65462800        fmaxv   h0, p2, z0\.h
+.*:    65462800        fmaxv   h0, p2, z0\.h
+.*:    65463c00        fmaxv   h0, p7, z0\.h
+.*:    65463c00        fmaxv   h0, p7, z0\.h
+.*:    65462060        fmaxv   h0, p0, z3\.h
+.*:    65462060        fmaxv   h0, p0, z3\.h
+.*:    654623e0        fmaxv   h0, p0, z31\.h
+.*:    654623e0        fmaxv   h0, p0, z31\.h
 .*:    65862000        fmaxv   s0, p0, z0\.s
 .*:    65862000        fmaxv   s0, p0, z0\.s
 .*:    65862001        fmaxv   s1, p0, z0\.s
@@ -9376,6 +10268,22 @@ Disassembly of section .*:
 .*:    65c62060        fmaxv   d0, p0, z3\.d
 .*:    65c623e0        fmaxv   d0, p0, z31\.d
 .*:    65c623e0        fmaxv   d0, p0, z31\.d
+.*:    65478000        fmin    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65478000        fmin    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65478001        fmin    z1\.h, p0/m, z1\.h, z0\.h
+.*:    65478001        fmin    z1\.h, p0/m, z1\.h, z0\.h
+.*:    6547801f        fmin    z31\.h, p0/m, z31\.h, z0\.h
+.*:    6547801f        fmin    z31\.h, p0/m, z31\.h, z0\.h
+.*:    65478800        fmin    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65478800        fmin    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65479c00        fmin    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65479c00        fmin    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65478003        fmin    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65478003        fmin    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65478080        fmin    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65478080        fmin    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654783e0        fmin    z0\.h, p0/m, z0\.h, z31\.h
+.*:    654783e0        fmin    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65878000        fmin    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65878000        fmin    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65878001        fmin    z1\.s, p0/m, z1\.s, z0\.s
@@ -9408,6 +10316,34 @@ Disassembly of section .*:
 .*:    65c78080        fmin    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c783e0        fmin    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c783e0        fmin    z0\.d, p0/m, z0\.d, z31\.d
+.*:    655f8000        fmin    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655f8000        fmin    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655f8000        fmin    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655f8000        fmin    z0\.h, p0/m, z0\.h, #0\.0
+.*:    655f8001        fmin    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655f8001        fmin    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655f8001        fmin    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655f8001        fmin    z1\.h, p0/m, z1\.h, #0\.0
+.*:    655f801f        fmin    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655f801f        fmin    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655f801f        fmin    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655f801f        fmin    z31\.h, p0/m, z31\.h, #0\.0
+.*:    655f8800        fmin    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655f8800        fmin    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655f8800        fmin    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655f8800        fmin    z0\.h, p2/m, z0\.h, #0\.0
+.*:    655f9c00        fmin    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655f9c00        fmin    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655f9c00        fmin    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655f9c00        fmin    z0\.h, p7/m, z0\.h, #0\.0
+.*:    655f8003        fmin    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655f8003        fmin    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655f8003        fmin    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655f8003        fmin    z3\.h, p0/m, z3\.h, #0\.0
+.*:    655f8020        fmin    z0\.h, p0/m, z0\.h, #1\.0
+.*:    655f8020        fmin    z0\.h, p0/m, z0\.h, #1\.0
+.*:    655f8020        fmin    z0\.h, p0/m, z0\.h, #1\.0
+.*:    655f8020        fmin    z0\.h, p0/m, z0\.h, #1\.0
 .*:    659f8000        fmin    z0\.s, p0/m, z0\.s, #0\.0
 .*:    659f8000        fmin    z0\.s, p0/m, z0\.s, #0\.0
 .*:    659f8000        fmin    z0\.s, p0/m, z0\.s, #0\.0
@@ -9464,6 +10400,22 @@ Disassembly of section .*:
 .*:    65df8020        fmin    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65df8020        fmin    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65df8020        fmin    z0\.d, p0/m, z0\.d, #1\.0
+.*:    65458000        fminnm  z0\.h, p0/m, z0\.h, z0\.h
+.*:    65458000        fminnm  z0\.h, p0/m, z0\.h, z0\.h
+.*:    65458001        fminnm  z1\.h, p0/m, z1\.h, z0\.h
+.*:    65458001        fminnm  z1\.h, p0/m, z1\.h, z0\.h
+.*:    6545801f        fminnm  z31\.h, p0/m, z31\.h, z0\.h
+.*:    6545801f        fminnm  z31\.h, p0/m, z31\.h, z0\.h
+.*:    65458800        fminnm  z0\.h, p2/m, z0\.h, z0\.h
+.*:    65458800        fminnm  z0\.h, p2/m, z0\.h, z0\.h
+.*:    65459c00        fminnm  z0\.h, p7/m, z0\.h, z0\.h
+.*:    65459c00        fminnm  z0\.h, p7/m, z0\.h, z0\.h
+.*:    65458003        fminnm  z3\.h, p0/m, z3\.h, z0\.h
+.*:    65458003        fminnm  z3\.h, p0/m, z3\.h, z0\.h
+.*:    65458080        fminnm  z0\.h, p0/m, z0\.h, z4\.h
+.*:    65458080        fminnm  z0\.h, p0/m, z0\.h, z4\.h
+.*:    654583e0        fminnm  z0\.h, p0/m, z0\.h, z31\.h
+.*:    654583e0        fminnm  z0\.h, p0/m, z0\.h, z31\.h
 .*:    65858000        fminnm  z0\.s, p0/m, z0\.s, z0\.s
 .*:    65858000        fminnm  z0\.s, p0/m, z0\.s, z0\.s
 .*:    65858001        fminnm  z1\.s, p0/m, z1\.s, z0\.s
@@ -9496,6 +10448,34 @@ Disassembly of section .*:
 .*:    65c58080        fminnm  z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c583e0        fminnm  z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c583e0        fminnm  z0\.d, p0/m, z0\.d, z31\.d
+.*:    655d8000        fminnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655d8000        fminnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655d8000        fminnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655d8000        fminnm  z0\.h, p0/m, z0\.h, #0\.0
+.*:    655d8001        fminnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655d8001        fminnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655d8001        fminnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655d8001        fminnm  z1\.h, p0/m, z1\.h, #0\.0
+.*:    655d801f        fminnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655d801f        fminnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655d801f        fminnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655d801f        fminnm  z31\.h, p0/m, z31\.h, #0\.0
+.*:    655d8800        fminnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655d8800        fminnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655d8800        fminnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655d8800        fminnm  z0\.h, p2/m, z0\.h, #0\.0
+.*:    655d9c00        fminnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655d9c00        fminnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655d9c00        fminnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655d9c00        fminnm  z0\.h, p7/m, z0\.h, #0\.0
+.*:    655d8003        fminnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655d8003        fminnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655d8003        fminnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655d8003        fminnm  z3\.h, p0/m, z3\.h, #0\.0
+.*:    655d8020        fminnm  z0\.h, p0/m, z0\.h, #1\.0
+.*:    655d8020        fminnm  z0\.h, p0/m, z0\.h, #1\.0
+.*:    655d8020        fminnm  z0\.h, p0/m, z0\.h, #1\.0
+.*:    655d8020        fminnm  z0\.h, p0/m, z0\.h, #1\.0
 .*:    659d8000        fminnm  z0\.s, p0/m, z0\.s, #0\.0
 .*:    659d8000        fminnm  z0\.s, p0/m, z0\.s, #0\.0
 .*:    659d8000        fminnm  z0\.s, p0/m, z0\.s, #0\.0
@@ -9552,6 +10532,20 @@ Disassembly of section .*:
 .*:    65dd8020        fminnm  z0\.d, p0/m, z0\.d, #1\.0
 .*:    65dd8020        fminnm  z0\.d, p0/m, z0\.d, #1\.0
 .*:    65dd8020        fminnm  z0\.d, p0/m, z0\.d, #1\.0
+.*:    65452000        fminnmv h0, p0, z0\.h
+.*:    65452000        fminnmv h0, p0, z0\.h
+.*:    65452001        fminnmv h1, p0, z0\.h
+.*:    65452001        fminnmv h1, p0, z0\.h
+.*:    6545201f        fminnmv h31, p0, z0\.h
+.*:    6545201f        fminnmv h31, p0, z0\.h
+.*:    65452800        fminnmv h0, p2, z0\.h
+.*:    65452800        fminnmv h0, p2, z0\.h
+.*:    65453c00        fminnmv h0, p7, z0\.h
+.*:    65453c00        fminnmv h0, p7, z0\.h
+.*:    65452060        fminnmv h0, p0, z3\.h
+.*:    65452060        fminnmv h0, p0, z3\.h
+.*:    654523e0        fminnmv h0, p0, z31\.h
+.*:    654523e0        fminnmv h0, p0, z31\.h
 .*:    65852000        fminnmv s0, p0, z0\.s
 .*:    65852000        fminnmv s0, p0, z0\.s
 .*:    65852001        fminnmv s1, p0, z0\.s
@@ -9580,6 +10574,20 @@ Disassembly of section .*:
 .*:    65c52060        fminnmv d0, p0, z3\.d
 .*:    65c523e0        fminnmv d0, p0, z31\.d
 .*:    65c523e0        fminnmv d0, p0, z31\.d
+.*:    65472000        fminv   h0, p0, z0\.h
+.*:    65472000        fminv   h0, p0, z0\.h
+.*:    65472001        fminv   h1, p0, z0\.h
+.*:    65472001        fminv   h1, p0, z0\.h
+.*:    6547201f        fminv   h31, p0, z0\.h
+.*:    6547201f        fminv   h31, p0, z0\.h
+.*:    65472800        fminv   h0, p2, z0\.h
+.*:    65472800        fminv   h0, p2, z0\.h
+.*:    65473c00        fminv   h0, p7, z0\.h
+.*:    65473c00        fminv   h0, p7, z0\.h
+.*:    65472060        fminv   h0, p0, z3\.h
+.*:    65472060        fminv   h0, p0, z3\.h
+.*:    654723e0        fminv   h0, p0, z31\.h
+.*:    654723e0        fminv   h0, p0, z31\.h
 .*:    65872000        fminv   s0, p0, z0\.s
 .*:    65872000        fminv   s0, p0, z0\.s
 .*:    65872001        fminv   s1, p0, z0\.s
@@ -9608,6 +10616,24 @@ Disassembly of section .*:
 .*:    65c72060        fminv   d0, p0, z3\.d
 .*:    65c723e0        fminv   d0, p0, z31\.d
 .*:    65c723e0        fminv   d0, p0, z31\.d
+.*:    65600000        fmla    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65600000        fmla    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65600001        fmla    z1\.h, p0/m, z0\.h, z0\.h
+.*:    65600001        fmla    z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560001f        fmla    z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560001f        fmla    z31\.h, p0/m, z0\.h, z0\.h
+.*:    65600800        fmla    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65600800        fmla    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65601c00        fmla    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65601c00        fmla    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65600060        fmla    z0\.h, p0/m, z3\.h, z0\.h
+.*:    65600060        fmla    z0\.h, p0/m, z3\.h, z0\.h
+.*:    656003e0        fmla    z0\.h, p0/m, z31\.h, z0\.h
+.*:    656003e0        fmla    z0\.h, p0/m, z31\.h, z0\.h
+.*:    65640000        fmla    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65640000        fmla    z0\.h, p0/m, z0\.h, z4\.h
+.*:    657f0000        fmla    z0\.h, p0/m, z0\.h, z31\.h
+.*:    657f0000        fmla    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a00000        fmla    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a00000        fmla    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a00001        fmla    z1\.s, p0/m, z0\.s, z0\.s
@@ -9644,6 +10670,90 @@ Disassembly of section .*:
 .*:    65e40000        fmla    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ff0000        fmla    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ff0000        fmla    z0\.d, p0/m, z0\.d, z31\.d
+.*:    64200000        fmla    z0\.h, z0\.h, z0\.h\[0\]
+.*:    64200000        fmla    z0\.h, z0\.h, z0\.h\[0\]
+.*:    64200001        fmla    z1\.h, z0\.h, z0\.h\[0\]
+.*:    64200001        fmla    z1\.h, z0\.h, z0\.h\[0\]
+.*:    6420001f        fmla    z31\.h, z0\.h, z0\.h\[0\]
+.*:    6420001f        fmla    z31\.h, z0\.h, z0\.h\[0\]
+.*:    64200040        fmla    z0\.h, z2\.h, z0\.h\[0\]
+.*:    64200040        fmla    z0\.h, z2\.h, z0\.h\[0\]
+.*:    642003e0        fmla    z0\.h, z31\.h, z0\.h\[0\]
+.*:    642003e0        fmla    z0\.h, z31\.h, z0\.h\[0\]
+.*:    64230000        fmla    z0\.h, z0\.h, z3\.h\[0\]
+.*:    64230000        fmla    z0\.h, z0\.h, z3\.h\[0\]
+.*:    64270000        fmla    z0\.h, z0\.h, z7\.h\[0\]
+.*:    64270000        fmla    z0\.h, z0\.h, z7\.h\[0\]
+.*:    64280000        fmla    z0\.h, z0\.h, z0\.h\[1\]
+.*:    64280000        fmla    z0\.h, z0\.h, z0\.h\[1\]
+.*:    642c0000        fmla    z0\.h, z0\.h, z4\.h\[1\]
+.*:    642c0000        fmla    z0\.h, z0\.h, z4\.h\[1\]
+.*:    64630000        fmla    z0\.h, z0\.h, z3\.h\[4\]
+.*:    64630000        fmla    z0\.h, z0\.h, z3\.h\[4\]
+.*:    64780000        fmla    z0\.h, z0\.h, z0\.h\[7\]
+.*:    64780000        fmla    z0\.h, z0\.h, z0\.h\[7\]
+.*:    647d0000        fmla    z0\.h, z0\.h, z5\.h\[7\]
+.*:    647d0000        fmla    z0\.h, z0\.h, z5\.h\[7\]
+.*:    64a00000        fmla    z0\.s, z0\.s, z0\.s\[0\]
+.*:    64a00000        fmla    z0\.s, z0\.s, z0\.s\[0\]
+.*:    64a00001        fmla    z1\.s, z0\.s, z0\.s\[0\]
+.*:    64a00001        fmla    z1\.s, z0\.s, z0\.s\[0\]
+.*:    64a0001f        fmla    z31\.s, z0\.s, z0\.s\[0\]
+.*:    64a0001f        fmla    z31\.s, z0\.s, z0\.s\[0\]
+.*:    64a00040        fmla    z0\.s, z2\.s, z0\.s\[0\]
+.*:    64a00040        fmla    z0\.s, z2\.s, z0\.s\[0\]
+.*:    64a003e0        fmla    z0\.s, z31\.s, z0\.s\[0\]
+.*:    64a003e0        fmla    z0\.s, z31\.s, z0\.s\[0\]
+.*:    64a30000        fmla    z0\.s, z0\.s, z3\.s\[0\]
+.*:    64a30000        fmla    z0\.s, z0\.s, z3\.s\[0\]
+.*:    64a70000        fmla    z0\.s, z0\.s, z7\.s\[0\]
+.*:    64a70000        fmla    z0\.s, z0\.s, z7\.s\[0\]
+.*:    64a80000        fmla    z0\.s, z0\.s, z0\.s\[1\]
+.*:    64a80000        fmla    z0\.s, z0\.s, z0\.s\[1\]
+.*:    64ac0000        fmla    z0\.s, z0\.s, z4\.s\[1\]
+.*:    64ac0000        fmla    z0\.s, z0\.s, z4\.s\[1\]
+.*:    64b30000        fmla    z0\.s, z0\.s, z3\.s\[2\]
+.*:    64b30000        fmla    z0\.s, z0\.s, z3\.s\[2\]
+.*:    64b80000        fmla    z0\.s, z0\.s, z0\.s\[3\]
+.*:    64b80000        fmla    z0\.s, z0\.s, z0\.s\[3\]
+.*:    64bd0000        fmla    z0\.s, z0\.s, z5\.s\[3\]
+.*:    64bd0000        fmla    z0\.s, z0\.s, z5\.s\[3\]
+.*:    64e00000        fmla    z0\.d, z0\.d, z0\.d\[0\]
+.*:    64e00000        fmla    z0\.d, z0\.d, z0\.d\[0\]
+.*:    64e00001        fmla    z1\.d, z0\.d, z0\.d\[0\]
+.*:    64e00001        fmla    z1\.d, z0\.d, z0\.d\[0\]
+.*:    64e0001f        fmla    z31\.d, z0\.d, z0\.d\[0\]
+.*:    64e0001f        fmla    z31\.d, z0\.d, z0\.d\[0\]
+.*:    64e00040        fmla    z0\.d, z2\.d, z0\.d\[0\]
+.*:    64e00040        fmla    z0\.d, z2\.d, z0\.d\[0\]
+.*:    64e003e0        fmla    z0\.d, z31\.d, z0\.d\[0\]
+.*:    64e003e0        fmla    z0\.d, z31\.d, z0\.d\[0\]
+.*:    64e30000        fmla    z0\.d, z0\.d, z3\.d\[0\]
+.*:    64e30000        fmla    z0\.d, z0\.d, z3\.d\[0\]
+.*:    64ef0000        fmla    z0\.d, z0\.d, z15\.d\[0\]
+.*:    64ef0000        fmla    z0\.d, z0\.d, z15\.d\[0\]
+.*:    64f00000        fmla    z0\.d, z0\.d, z0\.d\[1\]
+.*:    64f00000        fmla    z0\.d, z0\.d, z0\.d\[1\]
+.*:    64fb0000        fmla    z0\.d, z0\.d, z11\.d\[1\]
+.*:    64fb0000        fmla    z0\.d, z0\.d, z11\.d\[1\]
+.*:    65602000        fmls    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65602000        fmls    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65602001        fmls    z1\.h, p0/m, z0\.h, z0\.h
+.*:    65602001        fmls    z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560201f        fmls    z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560201f        fmls    z31\.h, p0/m, z0\.h, z0\.h
+.*:    65602800        fmls    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65602800        fmls    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65603c00        fmls    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65603c00        fmls    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65602060        fmls    z0\.h, p0/m, z3\.h, z0\.h
+.*:    65602060        fmls    z0\.h, p0/m, z3\.h, z0\.h
+.*:    656023e0        fmls    z0\.h, p0/m, z31\.h, z0\.h
+.*:    656023e0        fmls    z0\.h, p0/m, z31\.h, z0\.h
+.*:    65642000        fmls    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65642000        fmls    z0\.h, p0/m, z0\.h, z4\.h
+.*:    657f2000        fmls    z0\.h, p0/m, z0\.h, z31\.h
+.*:    657f2000        fmls    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a02000        fmls    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a02000        fmls    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a02001        fmls    z1\.s, p0/m, z0\.s, z0\.s
@@ -9680,6 +10790,90 @@ Disassembly of section .*:
 .*:    65e42000        fmls    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ff2000        fmls    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ff2000        fmls    z0\.d, p0/m, z0\.d, z31\.d
+.*:    64200400        fmls    z0\.h, z0\.h, z0\.h\[0\]
+.*:    64200400        fmls    z0\.h, z0\.h, z0\.h\[0\]
+.*:    64200401        fmls    z1\.h, z0\.h, z0\.h\[0\]
+.*:    64200401        fmls    z1\.h, z0\.h, z0\.h\[0\]
+.*:    6420041f        fmls    z31\.h, z0\.h, z0\.h\[0\]
+.*:    6420041f        fmls    z31\.h, z0\.h, z0\.h\[0\]
+.*:    64200440        fmls    z0\.h, z2\.h, z0\.h\[0\]
+.*:    64200440        fmls    z0\.h, z2\.h, z0\.h\[0\]
+.*:    642007e0        fmls    z0\.h, z31\.h, z0\.h\[0\]
+.*:    642007e0        fmls    z0\.h, z31\.h, z0\.h\[0\]
+.*:    64230400        fmls    z0\.h, z0\.h, z3\.h\[0\]
+.*:    64230400        fmls    z0\.h, z0\.h, z3\.h\[0\]
+.*:    64270400        fmls    z0\.h, z0\.h, z7\.h\[0\]
+.*:    64270400        fmls    z0\.h, z0\.h, z7\.h\[0\]
+.*:    64280400        fmls    z0\.h, z0\.h, z0\.h\[1\]
+.*:    64280400        fmls    z0\.h, z0\.h, z0\.h\[1\]
+.*:    642c0400        fmls    z0\.h, z0\.h, z4\.h\[1\]
+.*:    642c0400        fmls    z0\.h, z0\.h, z4\.h\[1\]
+.*:    64630400        fmls    z0\.h, z0\.h, z3\.h\[4\]
+.*:    64630400        fmls    z0\.h, z0\.h, z3\.h\[4\]
+.*:    64780400        fmls    z0\.h, z0\.h, z0\.h\[7\]
+.*:    64780400        fmls    z0\.h, z0\.h, z0\.h\[7\]
+.*:    647d0400        fmls    z0\.h, z0\.h, z5\.h\[7\]
+.*:    647d0400        fmls    z0\.h, z0\.h, z5\.h\[7\]
+.*:    64a00400        fmls    z0\.s, z0\.s, z0\.s\[0\]
+.*:    64a00400        fmls    z0\.s, z0\.s, z0\.s\[0\]
+.*:    64a00401        fmls    z1\.s, z0\.s, z0\.s\[0\]
+.*:    64a00401        fmls    z1\.s, z0\.s, z0\.s\[0\]
+.*:    64a0041f        fmls    z31\.s, z0\.s, z0\.s\[0\]
+.*:    64a0041f        fmls    z31\.s, z0\.s, z0\.s\[0\]
+.*:    64a00440        fmls    z0\.s, z2\.s, z0\.s\[0\]
+.*:    64a00440        fmls    z0\.s, z2\.s, z0\.s\[0\]
+.*:    64a007e0        fmls    z0\.s, z31\.s, z0\.s\[0\]
+.*:    64a007e0        fmls    z0\.s, z31\.s, z0\.s\[0\]
+.*:    64a30400        fmls    z0\.s, z0\.s, z3\.s\[0\]
+.*:    64a30400        fmls    z0\.s, z0\.s, z3\.s\[0\]
+.*:    64a70400        fmls    z0\.s, z0\.s, z7\.s\[0\]
+.*:    64a70400        fmls    z0\.s, z0\.s, z7\.s\[0\]
+.*:    64a80400        fmls    z0\.s, z0\.s, z0\.s\[1\]
+.*:    64a80400        fmls    z0\.s, z0\.s, z0\.s\[1\]
+.*:    64ac0400        fmls    z0\.s, z0\.s, z4\.s\[1\]
+.*:    64ac0400        fmls    z0\.s, z0\.s, z4\.s\[1\]
+.*:    64b30400        fmls    z0\.s, z0\.s, z3\.s\[2\]
+.*:    64b30400        fmls    z0\.s, z0\.s, z3\.s\[2\]
+.*:    64b80400        fmls    z0\.s, z0\.s, z0\.s\[3\]
+.*:    64b80400        fmls    z0\.s, z0\.s, z0\.s\[3\]
+.*:    64bd0400        fmls    z0\.s, z0\.s, z5\.s\[3\]
+.*:    64bd0400        fmls    z0\.s, z0\.s, z5\.s\[3\]
+.*:    64e00400        fmls    z0\.d, z0\.d, z0\.d\[0\]
+.*:    64e00400        fmls    z0\.d, z0\.d, z0\.d\[0\]
+.*:    64e00401        fmls    z1\.d, z0\.d, z0\.d\[0\]
+.*:    64e00401        fmls    z1\.d, z0\.d, z0\.d\[0\]
+.*:    64e0041f        fmls    z31\.d, z0\.d, z0\.d\[0\]
+.*:    64e0041f        fmls    z31\.d, z0\.d, z0\.d\[0\]
+.*:    64e00440        fmls    z0\.d, z2\.d, z0\.d\[0\]
+.*:    64e00440        fmls    z0\.d, z2\.d, z0\.d\[0\]
+.*:    64e007e0        fmls    z0\.d, z31\.d, z0\.d\[0\]
+.*:    64e007e0        fmls    z0\.d, z31\.d, z0\.d\[0\]
+.*:    64e30400        fmls    z0\.d, z0\.d, z3\.d\[0\]
+.*:    64e30400        fmls    z0\.d, z0\.d, z3\.d\[0\]
+.*:    64ef0400        fmls    z0\.d, z0\.d, z15\.d\[0\]
+.*:    64ef0400        fmls    z0\.d, z0\.d, z15\.d\[0\]
+.*:    64f00400        fmls    z0\.d, z0\.d, z0\.d\[1\]
+.*:    64f00400        fmls    z0\.d, z0\.d, z0\.d\[1\]
+.*:    64fb0400        fmls    z0\.d, z0\.d, z11\.d\[1\]
+.*:    64fb0400        fmls    z0\.d, z0\.d, z11\.d\[1\]
+.*:    6560a000        fmsb    z0\.h, p0/m, z0\.h, z0\.h
+.*:    6560a000        fmsb    z0\.h, p0/m, z0\.h, z0\.h
+.*:    6560a001        fmsb    z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560a001        fmsb    z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560a01f        fmsb    z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560a01f        fmsb    z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560a800        fmsb    z0\.h, p2/m, z0\.h, z0\.h
+.*:    6560a800        fmsb    z0\.h, p2/m, z0\.h, z0\.h
+.*:    6560bc00        fmsb    z0\.h, p7/m, z0\.h, z0\.h
+.*:    6560bc00        fmsb    z0\.h, p7/m, z0\.h, z0\.h
+.*:    6560a060        fmsb    z0\.h, p0/m, z3\.h, z0\.h
+.*:    6560a060        fmsb    z0\.h, p0/m, z3\.h, z0\.h
+.*:    6560a3e0        fmsb    z0\.h, p0/m, z31\.h, z0\.h
+.*:    6560a3e0        fmsb    z0\.h, p0/m, z31\.h, z0\.h
+.*:    6564a000        fmsb    z0\.h, p0/m, z0\.h, z4\.h
+.*:    6564a000        fmsb    z0\.h, p0/m, z0\.h, z4\.h
+.*:    657fa000        fmsb    z0\.h, p0/m, z0\.h, z31\.h
+.*:    657fa000        fmsb    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a0a000        fmsb    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a0a000        fmsb    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a0a001        fmsb    z1\.s, p0/m, z0\.s, z0\.s
@@ -9716,6 +10910,20 @@ Disassembly of section .*:
 .*:    65e4a000        fmsb    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ffa000        fmsb    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ffa000        fmsb    z0\.d, p0/m, z0\.d, z31\.d
+.*:    65400800        fmul    z0\.h, z0\.h, z0\.h
+.*:    65400800        fmul    z0\.h, z0\.h, z0\.h
+.*:    65400801        fmul    z1\.h, z0\.h, z0\.h
+.*:    65400801        fmul    z1\.h, z0\.h, z0\.h
+.*:    6540081f        fmul    z31\.h, z0\.h, z0\.h
+.*:    6540081f        fmul    z31\.h, z0\.h, z0\.h
+.*:    65400840        fmul    z0\.h, z2\.h, z0\.h
+.*:    65400840        fmul    z0\.h, z2\.h, z0\.h
+.*:    65400be0        fmul    z0\.h, z31\.h, z0\.h
+.*:    65400be0        fmul    z0\.h, z31\.h, z0\.h
+.*:    65430800        fmul    z0\.h, z0\.h, z3\.h
+.*:    65430800        fmul    z0\.h, z0\.h, z3\.h
+.*:    655f0800        fmul    z0\.h, z0\.h, z31\.h
+.*:    655f0800        fmul    z0\.h, z0\.h, z31\.h
 .*:    65800800        fmul    z0\.s, z0\.s, z0\.s
 .*:    65800800        fmul    z0\.s, z0\.s, z0\.s
 .*:    65800801        fmul    z1\.s, z0\.s, z0\.s
@@ -9744,6 +10952,22 @@ Disassembly of section .*:
 .*:    65c30800        fmul    z0\.d, z0\.d, z3\.d
 .*:    65df0800        fmul    z0\.d, z0\.d, z31\.d
 .*:    65df0800        fmul    z0\.d, z0\.d, z31\.d
+.*:    65428000        fmul    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65428000        fmul    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65428001        fmul    z1\.h, p0/m, z1\.h, z0\.h
+.*:    65428001        fmul    z1\.h, p0/m, z1\.h, z0\.h
+.*:    6542801f        fmul    z31\.h, p0/m, z31\.h, z0\.h
+.*:    6542801f        fmul    z31\.h, p0/m, z31\.h, z0\.h
+.*:    65428800        fmul    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65428800        fmul    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65429c00        fmul    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65429c00        fmul    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65428003        fmul    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65428003        fmul    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65428080        fmul    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65428080        fmul    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654283e0        fmul    z0\.h, p0/m, z0\.h, z31\.h
+.*:    654283e0        fmul    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65828000        fmul    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65828000        fmul    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65828001        fmul    z1\.s, p0/m, z1\.s, z0\.s
@@ -9776,6 +11000,34 @@ Disassembly of section .*:
 .*:    65c28080        fmul    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c283e0        fmul    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c283e0        fmul    z0\.d, p0/m, z0\.d, z31\.d
+.*:    655a8000        fmul    z0\.h, p0/m, z0\.h, #0\.5
+.*:    655a8000        fmul    z0\.h, p0/m, z0\.h, #0\.5
+.*:    655a8000        fmul    z0\.h, p0/m, z0\.h, #0\.5
+.*:    655a8000        fmul    z0\.h, p0/m, z0\.h, #0\.5
+.*:    655a8001        fmul    z1\.h, p0/m, z1\.h, #0\.5
+.*:    655a8001        fmul    z1\.h, p0/m, z1\.h, #0\.5
+.*:    655a8001        fmul    z1\.h, p0/m, z1\.h, #0\.5
+.*:    655a8001        fmul    z1\.h, p0/m, z1\.h, #0\.5
+.*:    655a801f        fmul    z31\.h, p0/m, z31\.h, #0\.5
+.*:    655a801f        fmul    z31\.h, p0/m, z31\.h, #0\.5
+.*:    655a801f        fmul    z31\.h, p0/m, z31\.h, #0\.5
+.*:    655a801f        fmul    z31\.h, p0/m, z31\.h, #0\.5
+.*:    655a8800        fmul    z0\.h, p2/m, z0\.h, #0\.5
+.*:    655a8800        fmul    z0\.h, p2/m, z0\.h, #0\.5
+.*:    655a8800        fmul    z0\.h, p2/m, z0\.h, #0\.5
+.*:    655a8800        fmul    z0\.h, p2/m, z0\.h, #0\.5
+.*:    655a9c00        fmul    z0\.h, p7/m, z0\.h, #0\.5
+.*:    655a9c00        fmul    z0\.h, p7/m, z0\.h, #0\.5
+.*:    655a9c00        fmul    z0\.h, p7/m, z0\.h, #0\.5
+.*:    655a9c00        fmul    z0\.h, p7/m, z0\.h, #0\.5
+.*:    655a8003        fmul    z3\.h, p0/m, z3\.h, #0\.5
+.*:    655a8003        fmul    z3\.h, p0/m, z3\.h, #0\.5
+.*:    655a8003        fmul    z3\.h, p0/m, z3\.h, #0\.5
+.*:    655a8003        fmul    z3\.h, p0/m, z3\.h, #0\.5
+.*:    655a8020        fmul    z0\.h, p0/m, z0\.h, #2\.0
+.*:    655a8020        fmul    z0\.h, p0/m, z0\.h, #2\.0
+.*:    655a8020        fmul    z0\.h, p0/m, z0\.h, #2\.0
+.*:    655a8020        fmul    z0\.h, p0/m, z0\.h, #2\.0
 .*:    659a8000        fmul    z0\.s, p0/m, z0\.s, #0\.5
 .*:    659a8000        fmul    z0\.s, p0/m, z0\.s, #0\.5
 .*:    659a8000        fmul    z0\.s, p0/m, z0\.s, #0\.5
@@ -9832,6 +11084,88 @@ Disassembly of section .*:
 .*:    65da8020        fmul    z0\.d, p0/m, z0\.d, #2\.0
 .*:    65da8020        fmul    z0\.d, p0/m, z0\.d, #2\.0
 .*:    65da8020        fmul    z0\.d, p0/m, z0\.d, #2\.0
+.*:    64202000        fmul    z0\.h, z0\.h, z0\.h\[0\]
+.*:    64202000        fmul    z0\.h, z0\.h, z0\.h\[0\]
+.*:    64202001        fmul    z1\.h, z0\.h, z0\.h\[0\]
+.*:    64202001        fmul    z1\.h, z0\.h, z0\.h\[0\]
+.*:    6420201f        fmul    z31\.h, z0\.h, z0\.h\[0\]
+.*:    6420201f        fmul    z31\.h, z0\.h, z0\.h\[0\]
+.*:    64202040        fmul    z0\.h, z2\.h, z0\.h\[0\]
+.*:    64202040        fmul    z0\.h, z2\.h, z0\.h\[0\]
+.*:    642023e0        fmul    z0\.h, z31\.h, z0\.h\[0\]
+.*:    642023e0        fmul    z0\.h, z31\.h, z0\.h\[0\]
+.*:    64232000        fmul    z0\.h, z0\.h, z3\.h\[0\]
+.*:    64232000        fmul    z0\.h, z0\.h, z3\.h\[0\]
+.*:    64272000        fmul    z0\.h, z0\.h, z7\.h\[0\]
+.*:    64272000        fmul    z0\.h, z0\.h, z7\.h\[0\]
+.*:    64282000        fmul    z0\.h, z0\.h, z0\.h\[1\]
+.*:    64282000        fmul    z0\.h, z0\.h, z0\.h\[1\]
+.*:    642c2000        fmul    z0\.h, z0\.h, z4\.h\[1\]
+.*:    642c2000        fmul    z0\.h, z0\.h, z4\.h\[1\]
+.*:    64632000        fmul    z0\.h, z0\.h, z3\.h\[4\]
+.*:    64632000        fmul    z0\.h, z0\.h, z3\.h\[4\]
+.*:    64782000        fmul    z0\.h, z0\.h, z0\.h\[7\]
+.*:    64782000        fmul    z0\.h, z0\.h, z0\.h\[7\]
+.*:    647d2000        fmul    z0\.h, z0\.h, z5\.h\[7\]
+.*:    647d2000        fmul    z0\.h, z0\.h, z5\.h\[7\]
+.*:    64a02000        fmul    z0\.s, z0\.s, z0\.s\[0\]
+.*:    64a02000        fmul    z0\.s, z0\.s, z0\.s\[0\]
+.*:    64a02001        fmul    z1\.s, z0\.s, z0\.s\[0\]
+.*:    64a02001        fmul    z1\.s, z0\.s, z0\.s\[0\]
+.*:    64a0201f        fmul    z31\.s, z0\.s, z0\.s\[0\]
+.*:    64a0201f        fmul    z31\.s, z0\.s, z0\.s\[0\]
+.*:    64a02040        fmul    z0\.s, z2\.s, z0\.s\[0\]
+.*:    64a02040        fmul    z0\.s, z2\.s, z0\.s\[0\]
+.*:    64a023e0        fmul    z0\.s, z31\.s, z0\.s\[0\]
+.*:    64a023e0        fmul    z0\.s, z31\.s, z0\.s\[0\]
+.*:    64a32000        fmul    z0\.s, z0\.s, z3\.s\[0\]
+.*:    64a32000        fmul    z0\.s, z0\.s, z3\.s\[0\]
+.*:    64a72000        fmul    z0\.s, z0\.s, z7\.s\[0\]
+.*:    64a72000        fmul    z0\.s, z0\.s, z7\.s\[0\]
+.*:    64a82000        fmul    z0\.s, z0\.s, z0\.s\[1\]
+.*:    64a82000        fmul    z0\.s, z0\.s, z0\.s\[1\]
+.*:    64ac2000        fmul    z0\.s, z0\.s, z4\.s\[1\]
+.*:    64ac2000        fmul    z0\.s, z0\.s, z4\.s\[1\]
+.*:    64b32000        fmul    z0\.s, z0\.s, z3\.s\[2\]
+.*:    64b32000        fmul    z0\.s, z0\.s, z3\.s\[2\]
+.*:    64b82000        fmul    z0\.s, z0\.s, z0\.s\[3\]
+.*:    64b82000        fmul    z0\.s, z0\.s, z0\.s\[3\]
+.*:    64bd2000        fmul    z0\.s, z0\.s, z5\.s\[3\]
+.*:    64bd2000        fmul    z0\.s, z0\.s, z5\.s\[3\]
+.*:    64e02000        fmul    z0\.d, z0\.d, z0\.d\[0\]
+.*:    64e02000        fmul    z0\.d, z0\.d, z0\.d\[0\]
+.*:    64e02001        fmul    z1\.d, z0\.d, z0\.d\[0\]
+.*:    64e02001        fmul    z1\.d, z0\.d, z0\.d\[0\]
+.*:    64e0201f        fmul    z31\.d, z0\.d, z0\.d\[0\]
+.*:    64e0201f        fmul    z31\.d, z0\.d, z0\.d\[0\]
+.*:    64e02040        fmul    z0\.d, z2\.d, z0\.d\[0\]
+.*:    64e02040        fmul    z0\.d, z2\.d, z0\.d\[0\]
+.*:    64e023e0        fmul    z0\.d, z31\.d, z0\.d\[0\]
+.*:    64e023e0        fmul    z0\.d, z31\.d, z0\.d\[0\]
+.*:    64e32000        fmul    z0\.d, z0\.d, z3\.d\[0\]
+.*:    64e32000        fmul    z0\.d, z0\.d, z3\.d\[0\]
+.*:    64ef2000        fmul    z0\.d, z0\.d, z15\.d\[0\]
+.*:    64ef2000        fmul    z0\.d, z0\.d, z15\.d\[0\]
+.*:    64f02000        fmul    z0\.d, z0\.d, z0\.d\[1\]
+.*:    64f02000        fmul    z0\.d, z0\.d, z0\.d\[1\]
+.*:    64fb2000        fmul    z0\.d, z0\.d, z11\.d\[1\]
+.*:    64fb2000        fmul    z0\.d, z0\.d, z11\.d\[1\]
+.*:    654a8000        fmulx   z0\.h, p0/m, z0\.h, z0\.h
+.*:    654a8000        fmulx   z0\.h, p0/m, z0\.h, z0\.h
+.*:    654a8001        fmulx   z1\.h, p0/m, z1\.h, z0\.h
+.*:    654a8001        fmulx   z1\.h, p0/m, z1\.h, z0\.h
+.*:    654a801f        fmulx   z31\.h, p0/m, z31\.h, z0\.h
+.*:    654a801f        fmulx   z31\.h, p0/m, z31\.h, z0\.h
+.*:    654a8800        fmulx   z0\.h, p2/m, z0\.h, z0\.h
+.*:    654a8800        fmulx   z0\.h, p2/m, z0\.h, z0\.h
+.*:    654a9c00        fmulx   z0\.h, p7/m, z0\.h, z0\.h
+.*:    654a9c00        fmulx   z0\.h, p7/m, z0\.h, z0\.h
+.*:    654a8003        fmulx   z3\.h, p0/m, z3\.h, z0\.h
+.*:    654a8003        fmulx   z3\.h, p0/m, z3\.h, z0\.h
+.*:    654a8080        fmulx   z0\.h, p0/m, z0\.h, z4\.h
+.*:    654a8080        fmulx   z0\.h, p0/m, z0\.h, z4\.h
+.*:    654a83e0        fmulx   z0\.h, p0/m, z0\.h, z31\.h
+.*:    654a83e0        fmulx   z0\.h, p0/m, z0\.h, z31\.h
 .*:    658a8000        fmulx   z0\.s, p0/m, z0\.s, z0\.s
 .*:    658a8000        fmulx   z0\.s, p0/m, z0\.s, z0\.s
 .*:    658a8001        fmulx   z1\.s, p0/m, z1\.s, z0\.s
@@ -9864,6 +11198,20 @@ Disassembly of section .*:
 .*:    65ca8080        fmulx   z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ca83e0        fmulx   z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ca83e0        fmulx   z0\.d, p0/m, z0\.d, z31\.d
+.*:    045da000        fneg    z0\.h, p0/m, z0\.h
+.*:    045da000        fneg    z0\.h, p0/m, z0\.h
+.*:    045da001        fneg    z1\.h, p0/m, z0\.h
+.*:    045da001        fneg    z1\.h, p0/m, z0\.h
+.*:    045da01f        fneg    z31\.h, p0/m, z0\.h
+.*:    045da01f        fneg    z31\.h, p0/m, z0\.h
+.*:    045da800        fneg    z0\.h, p2/m, z0\.h
+.*:    045da800        fneg    z0\.h, p2/m, z0\.h
+.*:    045dbc00        fneg    z0\.h, p7/m, z0\.h
+.*:    045dbc00        fneg    z0\.h, p7/m, z0\.h
+.*:    045da060        fneg    z0\.h, p0/m, z3\.h
+.*:    045da060        fneg    z0\.h, p0/m, z3\.h
+.*:    045da3e0        fneg    z0\.h, p0/m, z31\.h
+.*:    045da3e0        fneg    z0\.h, p0/m, z31\.h
 .*:    049da000        fneg    z0\.s, p0/m, z0\.s
 .*:    049da000        fneg    z0\.s, p0/m, z0\.s
 .*:    049da001        fneg    z1\.s, p0/m, z0\.s
@@ -9892,6 +11240,24 @@ Disassembly of section .*:
 .*:    04dda060        fneg    z0\.d, p0/m, z3\.d
 .*:    04dda3e0        fneg    z0\.d, p0/m, z31\.d
 .*:    04dda3e0        fneg    z0\.d, p0/m, z31\.d
+.*:    6560c000        fnmad   z0\.h, p0/m, z0\.h, z0\.h
+.*:    6560c000        fnmad   z0\.h, p0/m, z0\.h, z0\.h
+.*:    6560c001        fnmad   z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560c001        fnmad   z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560c01f        fnmad   z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560c01f        fnmad   z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560c800        fnmad   z0\.h, p2/m, z0\.h, z0\.h
+.*:    6560c800        fnmad   z0\.h, p2/m, z0\.h, z0\.h
+.*:    6560dc00        fnmad   z0\.h, p7/m, z0\.h, z0\.h
+.*:    6560dc00        fnmad   z0\.h, p7/m, z0\.h, z0\.h
+.*:    6560c060        fnmad   z0\.h, p0/m, z3\.h, z0\.h
+.*:    6560c060        fnmad   z0\.h, p0/m, z3\.h, z0\.h
+.*:    6560c3e0        fnmad   z0\.h, p0/m, z31\.h, z0\.h
+.*:    6560c3e0        fnmad   z0\.h, p0/m, z31\.h, z0\.h
+.*:    6564c000        fnmad   z0\.h, p0/m, z0\.h, z4\.h
+.*:    6564c000        fnmad   z0\.h, p0/m, z0\.h, z4\.h
+.*:    657fc000        fnmad   z0\.h, p0/m, z0\.h, z31\.h
+.*:    657fc000        fnmad   z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a0c000        fnmad   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a0c000        fnmad   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a0c001        fnmad   z1\.s, p0/m, z0\.s, z0\.s
@@ -9928,6 +11294,24 @@ Disassembly of section .*:
 .*:    65e4c000        fnmad   z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ffc000        fnmad   z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ffc000        fnmad   z0\.d, p0/m, z0\.d, z31\.d
+.*:    65604000        fnmla   z0\.h, p0/m, z0\.h, z0\.h
+.*:    65604000        fnmla   z0\.h, p0/m, z0\.h, z0\.h
+.*:    65604001        fnmla   z1\.h, p0/m, z0\.h, z0\.h
+.*:    65604001        fnmla   z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560401f        fnmla   z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560401f        fnmla   z31\.h, p0/m, z0\.h, z0\.h
+.*:    65604800        fnmla   z0\.h, p2/m, z0\.h, z0\.h
+.*:    65604800        fnmla   z0\.h, p2/m, z0\.h, z0\.h
+.*:    65605c00        fnmla   z0\.h, p7/m, z0\.h, z0\.h
+.*:    65605c00        fnmla   z0\.h, p7/m, z0\.h, z0\.h
+.*:    65604060        fnmla   z0\.h, p0/m, z3\.h, z0\.h
+.*:    65604060        fnmla   z0\.h, p0/m, z3\.h, z0\.h
+.*:    656043e0        fnmla   z0\.h, p0/m, z31\.h, z0\.h
+.*:    656043e0        fnmla   z0\.h, p0/m, z31\.h, z0\.h
+.*:    65644000        fnmla   z0\.h, p0/m, z0\.h, z4\.h
+.*:    65644000        fnmla   z0\.h, p0/m, z0\.h, z4\.h
+.*:    657f4000        fnmla   z0\.h, p0/m, z0\.h, z31\.h
+.*:    657f4000        fnmla   z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a04000        fnmla   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a04000        fnmla   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a04001        fnmla   z1\.s, p0/m, z0\.s, z0\.s
@@ -9964,6 +11348,24 @@ Disassembly of section .*:
 .*:    65e44000        fnmla   z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ff4000        fnmla   z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ff4000        fnmla   z0\.d, p0/m, z0\.d, z31\.d
+.*:    65606000        fnmls   z0\.h, p0/m, z0\.h, z0\.h
+.*:    65606000        fnmls   z0\.h, p0/m, z0\.h, z0\.h
+.*:    65606001        fnmls   z1\.h, p0/m, z0\.h, z0\.h
+.*:    65606001        fnmls   z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560601f        fnmls   z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560601f        fnmls   z31\.h, p0/m, z0\.h, z0\.h
+.*:    65606800        fnmls   z0\.h, p2/m, z0\.h, z0\.h
+.*:    65606800        fnmls   z0\.h, p2/m, z0\.h, z0\.h
+.*:    65607c00        fnmls   z0\.h, p7/m, z0\.h, z0\.h
+.*:    65607c00        fnmls   z0\.h, p7/m, z0\.h, z0\.h
+.*:    65606060        fnmls   z0\.h, p0/m, z3\.h, z0\.h
+.*:    65606060        fnmls   z0\.h, p0/m, z3\.h, z0\.h
+.*:    656063e0        fnmls   z0\.h, p0/m, z31\.h, z0\.h
+.*:    656063e0        fnmls   z0\.h, p0/m, z31\.h, z0\.h
+.*:    65646000        fnmls   z0\.h, p0/m, z0\.h, z4\.h
+.*:    65646000        fnmls   z0\.h, p0/m, z0\.h, z4\.h
+.*:    657f6000        fnmls   z0\.h, p0/m, z0\.h, z31\.h
+.*:    657f6000        fnmls   z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a06000        fnmls   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a06000        fnmls   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a06001        fnmls   z1\.s, p0/m, z0\.s, z0\.s
@@ -10000,6 +11402,24 @@ Disassembly of section .*:
 .*:    65e46000        fnmls   z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ff6000        fnmls   z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ff6000        fnmls   z0\.d, p0/m, z0\.d, z31\.d
+.*:    6560e000        fnmsb   z0\.h, p0/m, z0\.h, z0\.h
+.*:    6560e000        fnmsb   z0\.h, p0/m, z0\.h, z0\.h
+.*:    6560e001        fnmsb   z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560e001        fnmsb   z1\.h, p0/m, z0\.h, z0\.h
+.*:    6560e01f        fnmsb   z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560e01f        fnmsb   z31\.h, p0/m, z0\.h, z0\.h
+.*:    6560e800        fnmsb   z0\.h, p2/m, z0\.h, z0\.h
+.*:    6560e800        fnmsb   z0\.h, p2/m, z0\.h, z0\.h
+.*:    6560fc00        fnmsb   z0\.h, p7/m, z0\.h, z0\.h
+.*:    6560fc00        fnmsb   z0\.h, p7/m, z0\.h, z0\.h
+.*:    6560e060        fnmsb   z0\.h, p0/m, z3\.h, z0\.h
+.*:    6560e060        fnmsb   z0\.h, p0/m, z3\.h, z0\.h
+.*:    6560e3e0        fnmsb   z0\.h, p0/m, z31\.h, z0\.h
+.*:    6560e3e0        fnmsb   z0\.h, p0/m, z31\.h, z0\.h
+.*:    6564e000        fnmsb   z0\.h, p0/m, z0\.h, z4\.h
+.*:    6564e000        fnmsb   z0\.h, p0/m, z0\.h, z4\.h
+.*:    657fe000        fnmsb   z0\.h, p0/m, z0\.h, z31\.h
+.*:    657fe000        fnmsb   z0\.h, p0/m, z0\.h, z31\.h
 .*:    65a0e000        fnmsb   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a0e000        fnmsb   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65a0e001        fnmsb   z1\.s, p0/m, z0\.s, z0\.s
@@ -10036,6 +11456,16 @@ Disassembly of section .*:
 .*:    65e4e000        fnmsb   z0\.d, p0/m, z0\.d, z4\.d
 .*:    65ffe000        fnmsb   z0\.d, p0/m, z0\.d, z31\.d
 .*:    65ffe000        fnmsb   z0\.d, p0/m, z0\.d, z31\.d
+.*:    654e3000        frecpe  z0\.h, z0\.h
+.*:    654e3000        frecpe  z0\.h, z0\.h
+.*:    654e3001        frecpe  z1\.h, z0\.h
+.*:    654e3001        frecpe  z1\.h, z0\.h
+.*:    654e301f        frecpe  z31\.h, z0\.h
+.*:    654e301f        frecpe  z31\.h, z0\.h
+.*:    654e3040        frecpe  z0\.h, z2\.h
+.*:    654e3040        frecpe  z0\.h, z2\.h
+.*:    654e33e0        frecpe  z0\.h, z31\.h
+.*:    654e33e0        frecpe  z0\.h, z31\.h
 .*:    658e3000        frecpe  z0\.s, z0\.s
 .*:    658e3000        frecpe  z0\.s, z0\.s
 .*:    658e3001        frecpe  z1\.s, z0\.s
@@ -10056,6 +11486,20 @@ Disassembly of section .*:
 .*:    65ce3040        frecpe  z0\.d, z2\.d
 .*:    65ce33e0        frecpe  z0\.d, z31\.d
 .*:    65ce33e0        frecpe  z0\.d, z31\.d
+.*:    65401800        frecps  z0\.h, z0\.h, z0\.h
+.*:    65401800        frecps  z0\.h, z0\.h, z0\.h
+.*:    65401801        frecps  z1\.h, z0\.h, z0\.h
+.*:    65401801        frecps  z1\.h, z0\.h, z0\.h
+.*:    6540181f        frecps  z31\.h, z0\.h, z0\.h
+.*:    6540181f        frecps  z31\.h, z0\.h, z0\.h
+.*:    65401840        frecps  z0\.h, z2\.h, z0\.h
+.*:    65401840        frecps  z0\.h, z2\.h, z0\.h
+.*:    65401be0        frecps  z0\.h, z31\.h, z0\.h
+.*:    65401be0        frecps  z0\.h, z31\.h, z0\.h
+.*:    65431800        frecps  z0\.h, z0\.h, z3\.h
+.*:    65431800        frecps  z0\.h, z0\.h, z3\.h
+.*:    655f1800        frecps  z0\.h, z0\.h, z31\.h
+.*:    655f1800        frecps  z0\.h, z0\.h, z31\.h
 .*:    65801800        frecps  z0\.s, z0\.s, z0\.s
 .*:    65801800        frecps  z0\.s, z0\.s, z0\.s
 .*:    65801801        frecps  z1\.s, z0\.s, z0\.s
@@ -10084,6 +11528,20 @@ Disassembly of section .*:
 .*:    65c31800        frecps  z0\.d, z0\.d, z3\.d
 .*:    65df1800        frecps  z0\.d, z0\.d, z31\.d
 .*:    65df1800        frecps  z0\.d, z0\.d, z31\.d
+.*:    654ca000        frecpx  z0\.h, p0/m, z0\.h
+.*:    654ca000        frecpx  z0\.h, p0/m, z0\.h
+.*:    654ca001        frecpx  z1\.h, p0/m, z0\.h
+.*:    654ca001        frecpx  z1\.h, p0/m, z0\.h
+.*:    654ca01f        frecpx  z31\.h, p0/m, z0\.h
+.*:    654ca01f        frecpx  z31\.h, p0/m, z0\.h
+.*:    654ca800        frecpx  z0\.h, p2/m, z0\.h
+.*:    654ca800        frecpx  z0\.h, p2/m, z0\.h
+.*:    654cbc00        frecpx  z0\.h, p7/m, z0\.h
+.*:    654cbc00        frecpx  z0\.h, p7/m, z0\.h
+.*:    654ca060        frecpx  z0\.h, p0/m, z3\.h
+.*:    654ca060        frecpx  z0\.h, p0/m, z3\.h
+.*:    654ca3e0        frecpx  z0\.h, p0/m, z31\.h
+.*:    654ca3e0        frecpx  z0\.h, p0/m, z31\.h
 .*:    658ca000        frecpx  z0\.s, p0/m, z0\.s
 .*:    658ca000        frecpx  z0\.s, p0/m, z0\.s
 .*:    658ca001        frecpx  z1\.s, p0/m, z0\.s
@@ -10112,6 +11570,20 @@ Disassembly of section .*:
 .*:    65cca060        frecpx  z0\.d, p0/m, z3\.d
 .*:    65cca3e0        frecpx  z0\.d, p0/m, z31\.d
 .*:    65cca3e0        frecpx  z0\.d, p0/m, z31\.d
+.*:    6544a000        frinta  z0\.h, p0/m, z0\.h
+.*:    6544a000        frinta  z0\.h, p0/m, z0\.h
+.*:    6544a001        frinta  z1\.h, p0/m, z0\.h
+.*:    6544a001        frinta  z1\.h, p0/m, z0\.h
+.*:    6544a01f        frinta  z31\.h, p0/m, z0\.h
+.*:    6544a01f        frinta  z31\.h, p0/m, z0\.h
+.*:    6544a800        frinta  z0\.h, p2/m, z0\.h
+.*:    6544a800        frinta  z0\.h, p2/m, z0\.h
+.*:    6544bc00        frinta  z0\.h, p7/m, z0\.h
+.*:    6544bc00        frinta  z0\.h, p7/m, z0\.h
+.*:    6544a060        frinta  z0\.h, p0/m, z3\.h
+.*:    6544a060        frinta  z0\.h, p0/m, z3\.h
+.*:    6544a3e0        frinta  z0\.h, p0/m, z31\.h
+.*:    6544a3e0        frinta  z0\.h, p0/m, z31\.h
 .*:    6584a000        frinta  z0\.s, p0/m, z0\.s
 .*:    6584a000        frinta  z0\.s, p0/m, z0\.s
 .*:    6584a001        frinta  z1\.s, p0/m, z0\.s
@@ -10140,6 +11612,20 @@ Disassembly of section .*:
 .*:    65c4a060        frinta  z0\.d, p0/m, z3\.d
 .*:    65c4a3e0        frinta  z0\.d, p0/m, z31\.d
 .*:    65c4a3e0        frinta  z0\.d, p0/m, z31\.d
+.*:    6547a000        frinti  z0\.h, p0/m, z0\.h
+.*:    6547a000        frinti  z0\.h, p0/m, z0\.h
+.*:    6547a001        frinti  z1\.h, p0/m, z0\.h
+.*:    6547a001        frinti  z1\.h, p0/m, z0\.h
+.*:    6547a01f        frinti  z31\.h, p0/m, z0\.h
+.*:    6547a01f        frinti  z31\.h, p0/m, z0\.h
+.*:    6547a800        frinti  z0\.h, p2/m, z0\.h
+.*:    6547a800        frinti  z0\.h, p2/m, z0\.h
+.*:    6547bc00        frinti  z0\.h, p7/m, z0\.h
+.*:    6547bc00        frinti  z0\.h, p7/m, z0\.h
+.*:    6547a060        frinti  z0\.h, p0/m, z3\.h
+.*:    6547a060        frinti  z0\.h, p0/m, z3\.h
+.*:    6547a3e0        frinti  z0\.h, p0/m, z31\.h
+.*:    6547a3e0        frinti  z0\.h, p0/m, z31\.h
 .*:    6587a000        frinti  z0\.s, p0/m, z0\.s
 .*:    6587a000        frinti  z0\.s, p0/m, z0\.s
 .*:    6587a001        frinti  z1\.s, p0/m, z0\.s
@@ -10168,6 +11654,20 @@ Disassembly of section .*:
 .*:    65c7a060        frinti  z0\.d, p0/m, z3\.d
 .*:    65c7a3e0        frinti  z0\.d, p0/m, z31\.d
 .*:    65c7a3e0        frinti  z0\.d, p0/m, z31\.d
+.*:    6542a000        frintm  z0\.h, p0/m, z0\.h
+.*:    6542a000        frintm  z0\.h, p0/m, z0\.h
+.*:    6542a001        frintm  z1\.h, p0/m, z0\.h
+.*:    6542a001        frintm  z1\.h, p0/m, z0\.h
+.*:    6542a01f        frintm  z31\.h, p0/m, z0\.h
+.*:    6542a01f        frintm  z31\.h, p0/m, z0\.h
+.*:    6542a800        frintm  z0\.h, p2/m, z0\.h
+.*:    6542a800        frintm  z0\.h, p2/m, z0\.h
+.*:    6542bc00        frintm  z0\.h, p7/m, z0\.h
+.*:    6542bc00        frintm  z0\.h, p7/m, z0\.h
+.*:    6542a060        frintm  z0\.h, p0/m, z3\.h
+.*:    6542a060        frintm  z0\.h, p0/m, z3\.h
+.*:    6542a3e0        frintm  z0\.h, p0/m, z31\.h
+.*:    6542a3e0        frintm  z0\.h, p0/m, z31\.h
 .*:    6582a000        frintm  z0\.s, p0/m, z0\.s
 .*:    6582a000        frintm  z0\.s, p0/m, z0\.s
 .*:    6582a001        frintm  z1\.s, p0/m, z0\.s
@@ -10196,6 +11696,20 @@ Disassembly of section .*:
 .*:    65c2a060        frintm  z0\.d, p0/m, z3\.d
 .*:    65c2a3e0        frintm  z0\.d, p0/m, z31\.d
 .*:    65c2a3e0        frintm  z0\.d, p0/m, z31\.d
+.*:    6540a000        frintn  z0\.h, p0/m, z0\.h
+.*:    6540a000        frintn  z0\.h, p0/m, z0\.h
+.*:    6540a001        frintn  z1\.h, p0/m, z0\.h
+.*:    6540a001        frintn  z1\.h, p0/m, z0\.h
+.*:    6540a01f        frintn  z31\.h, p0/m, z0\.h
+.*:    6540a01f        frintn  z31\.h, p0/m, z0\.h
+.*:    6540a800        frintn  z0\.h, p2/m, z0\.h
+.*:    6540a800        frintn  z0\.h, p2/m, z0\.h
+.*:    6540bc00        frintn  z0\.h, p7/m, z0\.h
+.*:    6540bc00        frintn  z0\.h, p7/m, z0\.h
+.*:    6540a060        frintn  z0\.h, p0/m, z3\.h
+.*:    6540a060        frintn  z0\.h, p0/m, z3\.h
+.*:    6540a3e0        frintn  z0\.h, p0/m, z31\.h
+.*:    6540a3e0        frintn  z0\.h, p0/m, z31\.h
 .*:    6580a000        frintn  z0\.s, p0/m, z0\.s
 .*:    6580a000        frintn  z0\.s, p0/m, z0\.s
 .*:    6580a001        frintn  z1\.s, p0/m, z0\.s
@@ -10224,6 +11738,20 @@ Disassembly of section .*:
 .*:    65c0a060        frintn  z0\.d, p0/m, z3\.d
 .*:    65c0a3e0        frintn  z0\.d, p0/m, z31\.d
 .*:    65c0a3e0        frintn  z0\.d, p0/m, z31\.d
+.*:    6541a000        frintp  z0\.h, p0/m, z0\.h
+.*:    6541a000        frintp  z0\.h, p0/m, z0\.h
+.*:    6541a001        frintp  z1\.h, p0/m, z0\.h
+.*:    6541a001        frintp  z1\.h, p0/m, z0\.h
+.*:    6541a01f        frintp  z31\.h, p0/m, z0\.h
+.*:    6541a01f        frintp  z31\.h, p0/m, z0\.h
+.*:    6541a800        frintp  z0\.h, p2/m, z0\.h
+.*:    6541a800        frintp  z0\.h, p2/m, z0\.h
+.*:    6541bc00        frintp  z0\.h, p7/m, z0\.h
+.*:    6541bc00        frintp  z0\.h, p7/m, z0\.h
+.*:    6541a060        frintp  z0\.h, p0/m, z3\.h
+.*:    6541a060        frintp  z0\.h, p0/m, z3\.h
+.*:    6541a3e0        frintp  z0\.h, p0/m, z31\.h
+.*:    6541a3e0        frintp  z0\.h, p0/m, z31\.h
 .*:    6581a000        frintp  z0\.s, p0/m, z0\.s
 .*:    6581a000        frintp  z0\.s, p0/m, z0\.s
 .*:    6581a001        frintp  z1\.s, p0/m, z0\.s
@@ -10252,6 +11780,20 @@ Disassembly of section .*:
 .*:    65c1a060        frintp  z0\.d, p0/m, z3\.d
 .*:    65c1a3e0        frintp  z0\.d, p0/m, z31\.d
 .*:    65c1a3e0        frintp  z0\.d, p0/m, z31\.d
+.*:    6546a000        frintx  z0\.h, p0/m, z0\.h
+.*:    6546a000        frintx  z0\.h, p0/m, z0\.h
+.*:    6546a001        frintx  z1\.h, p0/m, z0\.h
+.*:    6546a001        frintx  z1\.h, p0/m, z0\.h
+.*:    6546a01f        frintx  z31\.h, p0/m, z0\.h
+.*:    6546a01f        frintx  z31\.h, p0/m, z0\.h
+.*:    6546a800        frintx  z0\.h, p2/m, z0\.h
+.*:    6546a800        frintx  z0\.h, p2/m, z0\.h
+.*:    6546bc00        frintx  z0\.h, p7/m, z0\.h
+.*:    6546bc00        frintx  z0\.h, p7/m, z0\.h
+.*:    6546a060        frintx  z0\.h, p0/m, z3\.h
+.*:    6546a060        frintx  z0\.h, p0/m, z3\.h
+.*:    6546a3e0        frintx  z0\.h, p0/m, z31\.h
+.*:    6546a3e0        frintx  z0\.h, p0/m, z31\.h
 .*:    6586a000        frintx  z0\.s, p0/m, z0\.s
 .*:    6586a000        frintx  z0\.s, p0/m, z0\.s
 .*:    6586a001        frintx  z1\.s, p0/m, z0\.s
@@ -10280,6 +11822,20 @@ Disassembly of section .*:
 .*:    65c6a060        frintx  z0\.d, p0/m, z3\.d
 .*:    65c6a3e0        frintx  z0\.d, p0/m, z31\.d
 .*:    65c6a3e0        frintx  z0\.d, p0/m, z31\.d
+.*:    6543a000        frintz  z0\.h, p0/m, z0\.h
+.*:    6543a000        frintz  z0\.h, p0/m, z0\.h
+.*:    6543a001        frintz  z1\.h, p0/m, z0\.h
+.*:    6543a001        frintz  z1\.h, p0/m, z0\.h
+.*:    6543a01f        frintz  z31\.h, p0/m, z0\.h
+.*:    6543a01f        frintz  z31\.h, p0/m, z0\.h
+.*:    6543a800        frintz  z0\.h, p2/m, z0\.h
+.*:    6543a800        frintz  z0\.h, p2/m, z0\.h
+.*:    6543bc00        frintz  z0\.h, p7/m, z0\.h
+.*:    6543bc00        frintz  z0\.h, p7/m, z0\.h
+.*:    6543a060        frintz  z0\.h, p0/m, z3\.h
+.*:    6543a060        frintz  z0\.h, p0/m, z3\.h
+.*:    6543a3e0        frintz  z0\.h, p0/m, z31\.h
+.*:    6543a3e0        frintz  z0\.h, p0/m, z31\.h
 .*:    6583a000        frintz  z0\.s, p0/m, z0\.s
 .*:    6583a000        frintz  z0\.s, p0/m, z0\.s
 .*:    6583a001        frintz  z1\.s, p0/m, z0\.s
@@ -10308,6 +11864,16 @@ Disassembly of section .*:
 .*:    65c3a060        frintz  z0\.d, p0/m, z3\.d
 .*:    65c3a3e0        frintz  z0\.d, p0/m, z31\.d
 .*:    65c3a3e0        frintz  z0\.d, p0/m, z31\.d
+.*:    654f3000        frsqrte z0\.h, z0\.h
+.*:    654f3000        frsqrte z0\.h, z0\.h
+.*:    654f3001        frsqrte z1\.h, z0\.h
+.*:    654f3001        frsqrte z1\.h, z0\.h
+.*:    654f301f        frsqrte z31\.h, z0\.h
+.*:    654f301f        frsqrte z31\.h, z0\.h
+.*:    654f3040        frsqrte z0\.h, z2\.h
+.*:    654f3040        frsqrte z0\.h, z2\.h
+.*:    654f33e0        frsqrte z0\.h, z31\.h
+.*:    654f33e0        frsqrte z0\.h, z31\.h
 .*:    658f3000        frsqrte z0\.s, z0\.s
 .*:    658f3000        frsqrte z0\.s, z0\.s
 .*:    658f3001        frsqrte z1\.s, z0\.s
@@ -10328,6 +11894,20 @@ Disassembly of section .*:
 .*:    65cf3040        frsqrte z0\.d, z2\.d
 .*:    65cf33e0        frsqrte z0\.d, z31\.d
 .*:    65cf33e0        frsqrte z0\.d, z31\.d
+.*:    65401c00        frsqrts z0\.h, z0\.h, z0\.h
+.*:    65401c00        frsqrts z0\.h, z0\.h, z0\.h
+.*:    65401c01        frsqrts z1\.h, z0\.h, z0\.h
+.*:    65401c01        frsqrts z1\.h, z0\.h, z0\.h
+.*:    65401c1f        frsqrts z31\.h, z0\.h, z0\.h
+.*:    65401c1f        frsqrts z31\.h, z0\.h, z0\.h
+.*:    65401c40        frsqrts z0\.h, z2\.h, z0\.h
+.*:    65401c40        frsqrts z0\.h, z2\.h, z0\.h
+.*:    65401fe0        frsqrts z0\.h, z31\.h, z0\.h
+.*:    65401fe0        frsqrts z0\.h, z31\.h, z0\.h
+.*:    65431c00        frsqrts z0\.h, z0\.h, z3\.h
+.*:    65431c00        frsqrts z0\.h, z0\.h, z3\.h
+.*:    655f1c00        frsqrts z0\.h, z0\.h, z31\.h
+.*:    655f1c00        frsqrts z0\.h, z0\.h, z31\.h
 .*:    65801c00        frsqrts z0\.s, z0\.s, z0\.s
 .*:    65801c00        frsqrts z0\.s, z0\.s, z0\.s
 .*:    65801c01        frsqrts z1\.s, z0\.s, z0\.s
@@ -10356,6 +11936,22 @@ Disassembly of section .*:
 .*:    65c31c00        frsqrts z0\.d, z0\.d, z3\.d
 .*:    65df1c00        frsqrts z0\.d, z0\.d, z31\.d
 .*:    65df1c00        frsqrts z0\.d, z0\.d, z31\.d
+.*:    65498000        fscale  z0\.h, p0/m, z0\.h, z0\.h
+.*:    65498000        fscale  z0\.h, p0/m, z0\.h, z0\.h
+.*:    65498001        fscale  z1\.h, p0/m, z1\.h, z0\.h
+.*:    65498001        fscale  z1\.h, p0/m, z1\.h, z0\.h
+.*:    6549801f        fscale  z31\.h, p0/m, z31\.h, z0\.h
+.*:    6549801f        fscale  z31\.h, p0/m, z31\.h, z0\.h
+.*:    65498800        fscale  z0\.h, p2/m, z0\.h, z0\.h
+.*:    65498800        fscale  z0\.h, p2/m, z0\.h, z0\.h
+.*:    65499c00        fscale  z0\.h, p7/m, z0\.h, z0\.h
+.*:    65499c00        fscale  z0\.h, p7/m, z0\.h, z0\.h
+.*:    65498003        fscale  z3\.h, p0/m, z3\.h, z0\.h
+.*:    65498003        fscale  z3\.h, p0/m, z3\.h, z0\.h
+.*:    65498080        fscale  z0\.h, p0/m, z0\.h, z4\.h
+.*:    65498080        fscale  z0\.h, p0/m, z0\.h, z4\.h
+.*:    654983e0        fscale  z0\.h, p0/m, z0\.h, z31\.h
+.*:    654983e0        fscale  z0\.h, p0/m, z0\.h, z31\.h
 .*:    65898000        fscale  z0\.s, p0/m, z0\.s, z0\.s
 .*:    65898000        fscale  z0\.s, p0/m, z0\.s, z0\.s
 .*:    65898001        fscale  z1\.s, p0/m, z1\.s, z0\.s
@@ -10388,6 +11984,20 @@ Disassembly of section .*:
 .*:    65c98080        fscale  z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c983e0        fscale  z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c983e0        fscale  z0\.d, p0/m, z0\.d, z31\.d
+.*:    654da000        fsqrt   z0\.h, p0/m, z0\.h
+.*:    654da000        fsqrt   z0\.h, p0/m, z0\.h
+.*:    654da001        fsqrt   z1\.h, p0/m, z0\.h
+.*:    654da001        fsqrt   z1\.h, p0/m, z0\.h
+.*:    654da01f        fsqrt   z31\.h, p0/m, z0\.h
+.*:    654da01f        fsqrt   z31\.h, p0/m, z0\.h
+.*:    654da800        fsqrt   z0\.h, p2/m, z0\.h
+.*:    654da800        fsqrt   z0\.h, p2/m, z0\.h
+.*:    654dbc00        fsqrt   z0\.h, p7/m, z0\.h
+.*:    654dbc00        fsqrt   z0\.h, p7/m, z0\.h
+.*:    654da060        fsqrt   z0\.h, p0/m, z3\.h
+.*:    654da060        fsqrt   z0\.h, p0/m, z3\.h
+.*:    654da3e0        fsqrt   z0\.h, p0/m, z31\.h
+.*:    654da3e0        fsqrt   z0\.h, p0/m, z31\.h
 .*:    658da000        fsqrt   z0\.s, p0/m, z0\.s
 .*:    658da000        fsqrt   z0\.s, p0/m, z0\.s
 .*:    658da001        fsqrt   z1\.s, p0/m, z0\.s
@@ -10416,6 +12026,20 @@ Disassembly of section .*:
 .*:    65cda060        fsqrt   z0\.d, p0/m, z3\.d
 .*:    65cda3e0        fsqrt   z0\.d, p0/m, z31\.d
 .*:    65cda3e0        fsqrt   z0\.d, p0/m, z31\.d
+.*:    65400400        fsub    z0\.h, z0\.h, z0\.h
+.*:    65400400        fsub    z0\.h, z0\.h, z0\.h
+.*:    65400401        fsub    z1\.h, z0\.h, z0\.h
+.*:    65400401        fsub    z1\.h, z0\.h, z0\.h
+.*:    6540041f        fsub    z31\.h, z0\.h, z0\.h
+.*:    6540041f        fsub    z31\.h, z0\.h, z0\.h
+.*:    65400440        fsub    z0\.h, z2\.h, z0\.h
+.*:    65400440        fsub    z0\.h, z2\.h, z0\.h
+.*:    654007e0        fsub    z0\.h, z31\.h, z0\.h
+.*:    654007e0        fsub    z0\.h, z31\.h, z0\.h
+.*:    65430400        fsub    z0\.h, z0\.h, z3\.h
+.*:    65430400        fsub    z0\.h, z0\.h, z3\.h
+.*:    655f0400        fsub    z0\.h, z0\.h, z31\.h
+.*:    655f0400        fsub    z0\.h, z0\.h, z31\.h
 .*:    65800400        fsub    z0\.s, z0\.s, z0\.s
 .*:    65800400        fsub    z0\.s, z0\.s, z0\.s
 .*:    65800401        fsub    z1\.s, z0\.s, z0\.s
@@ -10444,6 +12068,22 @@ Disassembly of section .*:
 .*:    65c30400        fsub    z0\.d, z0\.d, z3\.d
 .*:    65df0400        fsub    z0\.d, z0\.d, z31\.d
 .*:    65df0400        fsub    z0\.d, z0\.d, z31\.d
+.*:    65418000        fsub    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65418000        fsub    z0\.h, p0/m, z0\.h, z0\.h
+.*:    65418001        fsub    z1\.h, p0/m, z1\.h, z0\.h
+.*:    65418001        fsub    z1\.h, p0/m, z1\.h, z0\.h
+.*:    6541801f        fsub    z31\.h, p0/m, z31\.h, z0\.h
+.*:    6541801f        fsub    z31\.h, p0/m, z31\.h, z0\.h
+.*:    65418800        fsub    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65418800        fsub    z0\.h, p2/m, z0\.h, z0\.h
+.*:    65419c00        fsub    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65419c00        fsub    z0\.h, p7/m, z0\.h, z0\.h
+.*:    65418003        fsub    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65418003        fsub    z3\.h, p0/m, z3\.h, z0\.h
+.*:    65418080        fsub    z0\.h, p0/m, z0\.h, z4\.h
+.*:    65418080        fsub    z0\.h, p0/m, z0\.h, z4\.h
+.*:    654183e0        fsub    z0\.h, p0/m, z0\.h, z31\.h
+.*:    654183e0        fsub    z0\.h, p0/m, z0\.h, z31\.h
 .*:    65818000        fsub    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65818000        fsub    z0\.s, p0/m, z0\.s, z0\.s
 .*:    65818001        fsub    z1\.s, p0/m, z1\.s, z0\.s
@@ -10476,6 +12116,34 @@ Disassembly of section .*:
 .*:    65c18080        fsub    z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c183e0        fsub    z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c183e0        fsub    z0\.d, p0/m, z0\.d, z31\.d
+.*:    65598000        fsub    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65598000        fsub    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65598000        fsub    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65598000        fsub    z0\.h, p0/m, z0\.h, #0\.5
+.*:    65598001        fsub    z1\.h, p0/m, z1\.h, #0\.5
+.*:    65598001        fsub    z1\.h, p0/m, z1\.h, #0\.5
+.*:    65598001        fsub    z1\.h, p0/m, z1\.h, #0\.5
+.*:    65598001        fsub    z1\.h, p0/m, z1\.h, #0\.5
+.*:    6559801f        fsub    z31\.h, p0/m, z31\.h, #0\.5
+.*:    6559801f        fsub    z31\.h, p0/m, z31\.h, #0\.5
+.*:    6559801f        fsub    z31\.h, p0/m, z31\.h, #0\.5
+.*:    6559801f        fsub    z31\.h, p0/m, z31\.h, #0\.5
+.*:    65598800        fsub    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65598800        fsub    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65598800        fsub    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65598800        fsub    z0\.h, p2/m, z0\.h, #0\.5
+.*:    65599c00        fsub    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65599c00        fsub    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65599c00        fsub    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65599c00        fsub    z0\.h, p7/m, z0\.h, #0\.5
+.*:    65598003        fsub    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65598003        fsub    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65598003        fsub    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65598003        fsub    z3\.h, p0/m, z3\.h, #0\.5
+.*:    65598020        fsub    z0\.h, p0/m, z0\.h, #1\.0
+.*:    65598020        fsub    z0\.h, p0/m, z0\.h, #1\.0
+.*:    65598020        fsub    z0\.h, p0/m, z0\.h, #1\.0
+.*:    65598020        fsub    z0\.h, p0/m, z0\.h, #1\.0
 .*:    65998000        fsub    z0\.s, p0/m, z0\.s, #0\.5
 .*:    65998000        fsub    z0\.s, p0/m, z0\.s, #0\.5
 .*:    65998000        fsub    z0\.s, p0/m, z0\.s, #0\.5
@@ -10532,6 +12200,22 @@ Disassembly of section .*:
 .*:    65d98020        fsub    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65d98020        fsub    z0\.d, p0/m, z0\.d, #1\.0
 .*:    65d98020        fsub    z0\.d, p0/m, z0\.d, #1\.0
+.*:    65438000        fsubr   z0\.h, p0/m, z0\.h, z0\.h
+.*:    65438000        fsubr   z0\.h, p0/m, z0\.h, z0\.h
+.*:    65438001        fsubr   z1\.h, p0/m, z1\.h, z0\.h
+.*:    65438001        fsubr   z1\.h, p0/m, z1\.h, z0\.h
+.*:    6543801f        fsubr   z31\.h, p0/m, z31\.h, z0\.h
+.*:    6543801f        fsubr   z31\.h, p0/m, z31\.h, z0\.h
+.*:    65438800        fsubr   z0\.h, p2/m, z0\.h, z0\.h
+.*:    65438800        fsubr   z0\.h, p2/m, z0\.h, z0\.h
+.*:    65439c00        fsubr   z0\.h, p7/m, z0\.h, z0\.h
+.*:    65439c00        fsubr   z0\.h, p7/m, z0\.h, z0\.h
+.*:    65438003        fsubr   z3\.h, p0/m, z3\.h, z0\.h
+.*:    65438003        fsubr   z3\.h, p0/m, z3\.h, z0\.h
+.*:    65438080        fsubr   z0\.h, p0/m, z0\.h, z4\.h
+.*:    65438080        fsubr   z0\.h, p0/m, z0\.h, z4\.h
+.*:    654383e0        fsubr   z0\.h, p0/m, z0\.h, z31\.h
+.*:    654383e0        fsubr   z0\.h, p0/m, z0\.h, z31\.h
 .*:    65838000        fsubr   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65838000        fsubr   z0\.s, p0/m, z0\.s, z0\.s
 .*:    65838001        fsubr   z1\.s, p0/m, z1\.s, z0\.s
@@ -10564,6 +12248,34 @@ Disassembly of section .*:
 .*:    65c38080        fsubr   z0\.d, p0/m, z0\.d, z4\.d
 .*:    65c383e0        fsubr   z0\.d, p0/m, z0\.d, z31\.d
 .*:    65c383e0        fsubr   z0\.d, p0/m, z0\.d, z31\.d
+.*:    655b8000        fsubr   z0\.h, p0/m, z0\.h, #0\.5
+.*:    655b8000        fsubr   z0\.h, p0/m, z0\.h, #0\.5
+.*:    655b8000        fsubr   z0\.h, p0/m, z0\.h, #0\.5
+.*:    655b8000        fsubr   z0\.h, p0/m, z0\.h, #0\.5
+.*:    655b8001        fsubr   z1\.h, p0/m, z1\.h, #0\.5
+.*:    655b8001        fsubr   z1\.h, p0/m, z1\.h, #0\.5
+.*:    655b8001        fsubr   z1\.h, p0/m, z1\.h, #0\.5
+.*:    655b8001        fsubr   z1\.h, p0/m, z1\.h, #0\.5
+.*:    655b801f        fsubr   z31\.h, p0/m, z31\.h, #0\.5
+.*:    655b801f        fsubr   z31\.h, p0/m, z31\.h, #0\.5
+.*:    655b801f        fsubr   z31\.h, p0/m, z31\.h, #0\.5
+.*:    655b801f        fsubr   z31\.h, p0/m, z31\.h, #0\.5
+.*:    655b8800        fsubr   z0\.h, p2/m, z0\.h, #0\.5
+.*:    655b8800        fsubr   z0\.h, p2/m, z0\.h, #0\.5
+.*:    655b8800        fsubr   z0\.h, p2/m, z0\.h, #0\.5
+.*:    655b8800        fsubr   z0\.h, p2/m, z0\.h, #0\.5
+.*:    655b9c00        fsubr   z0\.h, p7/m, z0\.h, #0\.5
+.*:    655b9c00        fsubr   z0\.h, p7/m, z0\.h, #0\.5
+.*:    655b9c00        fsubr   z0\.h, p7/m, z0\.h, #0\.5
+.*:    655b9c00        fsubr   z0\.h, p7/m, z0\.h, #0\.5
+.*:    655b8003        fsubr   z3\.h, p0/m, z3\.h, #0\.5
+.*:    655b8003        fsubr   z3\.h, p0/m, z3\.h, #0\.5
+.*:    655b8003        fsubr   z3\.h, p0/m, z3\.h, #0\.5
+.*:    655b8003        fsubr   z3\.h, p0/m, z3\.h, #0\.5
+.*:    655b8020        fsubr   z0\.h, p0/m, z0\.h, #1\.0
+.*:    655b8020        fsubr   z0\.h, p0/m, z0\.h, #1\.0
+.*:    655b8020        fsubr   z0\.h, p0/m, z0\.h, #1\.0
+.*:    655b8020        fsubr   z0\.h, p0/m, z0\.h, #1\.0
 .*:    659b8000        fsubr   z0\.s, p0/m, z0\.s, #0\.5
 .*:    659b8000        fsubr   z0\.s, p0/m, z0\.s, #0\.5
 .*:    659b8000        fsubr   z0\.s, p0/m, z0\.s, #0\.5
@@ -10620,6 +12332,26 @@ Disassembly of section .*:
 .*:    65db8020        fsubr   z0\.d, p0/m, z0\.d, #1\.0
 .*:    65db8020        fsubr   z0\.d, p0/m, z0\.d, #1\.0
 .*:    65db8020        fsubr   z0\.d, p0/m, z0\.d, #1\.0
+.*:    65508000        ftmad   z0\.h, z0\.h, z0\.h, #0
+.*:    65508000        ftmad   z0\.h, z0\.h, z0\.h, #0
+.*:    65508001        ftmad   z1\.h, z1\.h, z0\.h, #0
+.*:    65508001        ftmad   z1\.h, z1\.h, z0\.h, #0
+.*:    6550801f        ftmad   z31\.h, z31\.h, z0\.h, #0
+.*:    6550801f        ftmad   z31\.h, z31\.h, z0\.h, #0
+.*:    65508002        ftmad   z2\.h, z2\.h, z0\.h, #0
+.*:    65508002        ftmad   z2\.h, z2\.h, z0\.h, #0
+.*:    65508060        ftmad   z0\.h, z0\.h, z3\.h, #0
+.*:    65508060        ftmad   z0\.h, z0\.h, z3\.h, #0
+.*:    655083e0        ftmad   z0\.h, z0\.h, z31\.h, #0
+.*:    655083e0        ftmad   z0\.h, z0\.h, z31\.h, #0
+.*:    65538000        ftmad   z0\.h, z0\.h, z0\.h, #3
+.*:    65538000        ftmad   z0\.h, z0\.h, z0\.h, #3
+.*:    65548000        ftmad   z0\.h, z0\.h, z0\.h, #4
+.*:    65548000        ftmad   z0\.h, z0\.h, z0\.h, #4
+.*:    65558000        ftmad   z0\.h, z0\.h, z0\.h, #5
+.*:    65558000        ftmad   z0\.h, z0\.h, z0\.h, #5
+.*:    65578000        ftmad   z0\.h, z0\.h, z0\.h, #7
+.*:    65578000        ftmad   z0\.h, z0\.h, z0\.h, #7
 .*:    65908000        ftmad   z0\.s, z0\.s, z0\.s, #0
 .*:    65908000        ftmad   z0\.s, z0\.s, z0\.s, #0
 .*:    65908001        ftmad   z1\.s, z1\.s, z0\.s, #0
@@ -10660,6 +12392,20 @@ Disassembly of section .*:
 .*:    65d58000        ftmad   z0\.d, z0\.d, z0\.d, #5
 .*:    65d78000        ftmad   z0\.d, z0\.d, z0\.d, #7
 .*:    65d78000        ftmad   z0\.d, z0\.d, z0\.d, #7
+.*:    65400c00        ftsmul  z0\.h, z0\.h, z0\.h
+.*:    65400c00        ftsmul  z0\.h, z0\.h, z0\.h
+.*:    65400c01        ftsmul  z1\.h, z0\.h, z0\.h
+.*:    65400c01        ftsmul  z1\.h, z0\.h, z0\.h
+.*:    65400c1f        ftsmul  z31\.h, z0\.h, z0\.h
+.*:    65400c1f        ftsmul  z31\.h, z0\.h, z0\.h
+.*:    65400c40        ftsmul  z0\.h, z2\.h, z0\.h
+.*:    65400c40        ftsmul  z0\.h, z2\.h, z0\.h
+.*:    65400fe0        ftsmul  z0\.h, z31\.h, z0\.h
+.*:    65400fe0        ftsmul  z0\.h, z31\.h, z0\.h
+.*:    65430c00        ftsmul  z0\.h, z0\.h, z3\.h
+.*:    65430c00        ftsmul  z0\.h, z0\.h, z3\.h
+.*:    655f0c00        ftsmul  z0\.h, z0\.h, z31\.h
+.*:    655f0c00        ftsmul  z0\.h, z0\.h, z31\.h
 .*:    65800c00        ftsmul  z0\.s, z0\.s, z0\.s
 .*:    65800c00        ftsmul  z0\.s, z0\.s, z0\.s
 .*:    65800c01        ftsmul  z1\.s, z0\.s, z0\.s
@@ -10688,6 +12434,20 @@ Disassembly of section .*:
 .*:    65c30c00        ftsmul  z0\.d, z0\.d, z3\.d
 .*:    65df0c00        ftsmul  z0\.d, z0\.d, z31\.d
 .*:    65df0c00        ftsmul  z0\.d, z0\.d, z31\.d
+.*:    0460b000        ftssel  z0\.h, z0\.h, z0\.h
+.*:    0460b000        ftssel  z0\.h, z0\.h, z0\.h
+.*:    0460b001        ftssel  z1\.h, z0\.h, z0\.h
+.*:    0460b001        ftssel  z1\.h, z0\.h, z0\.h
+.*:    0460b01f        ftssel  z31\.h, z0\.h, z0\.h
+.*:    0460b01f        ftssel  z31\.h, z0\.h, z0\.h
+.*:    0460b040        ftssel  z0\.h, z2\.h, z0\.h
+.*:    0460b040        ftssel  z0\.h, z2\.h, z0\.h
+.*:    0460b3e0        ftssel  z0\.h, z31\.h, z0\.h
+.*:    0460b3e0        ftssel  z0\.h, z31\.h, z0\.h
+.*:    0463b000        ftssel  z0\.h, z0\.h, z3\.h
+.*:    0463b000        ftssel  z0\.h, z0\.h, z3\.h
+.*:    047fb000        ftssel  z0\.h, z0\.h, z31\.h
+.*:    047fb000        ftssel  z0\.h, z0\.h, z31\.h
 .*:    04a0b000        ftssel  z0\.s, z0\.s, z0\.s
 .*:    04a0b000        ftssel  z0\.s, z0\.s, z0\.s
 .*:    04a0b001        ftssel  z1\.s, z0\.s, z0\.s
@@ -13837,6 +15597,227 @@ Disassembly of section .*:
 .*:    84e18000        ld1rsw  \{z0\.d\}, p0/z, \[x0, #132\]
 .*:    84ff8000        ld1rsw  \{z0\.d\}, p0/z, \[x0, #252\]
 .*:    84ff8000        ld1rsw  \{z0\.d\}, p0/z, \[x0, #252\]
+.*:    a4002000        ld1rqb  \{z0\.b\}, p0/z, \[x0\]
+.*:    a4002000        ld1rqb  \{z0\.b\}, p0/z, \[x0\]
+.*:    a4002000        ld1rqb  \{z0\.b\}, p0/z, \[x0\]
+.*:    a4002000        ld1rqb  \{z0\.b\}, p0/z, \[x0\]
+.*:    a4002001        ld1rqb  \{z1\.b\}, p0/z, \[x0\]
+.*:    a4002001        ld1rqb  \{z1\.b\}, p0/z, \[x0\]
+.*:    a4002001        ld1rqb  \{z1\.b\}, p0/z, \[x0\]
+.*:    a4002001        ld1rqb  \{z1\.b\}, p0/z, \[x0\]
+.*:    a400201f        ld1rqb  \{z31\.b\}, p0/z, \[x0\]
+.*:    a400201f        ld1rqb  \{z31\.b\}, p0/z, \[x0\]
+.*:    a400201f        ld1rqb  \{z31\.b\}, p0/z, \[x0\]
+.*:    a400201f        ld1rqb  \{z31\.b\}, p0/z, \[x0\]
+.*:    a4002800        ld1rqb  \{z0\.b\}, p2/z, \[x0\]
+.*:    a4002800        ld1rqb  \{z0\.b\}, p2/z, \[x0\]
+.*:    a4002800        ld1rqb  \{z0\.b\}, p2/z, \[x0\]
+.*:    a4003c00        ld1rqb  \{z0\.b\}, p7/z, \[x0\]
+.*:    a4003c00        ld1rqb  \{z0\.b\}, p7/z, \[x0\]
+.*:    a4003c00        ld1rqb  \{z0\.b\}, p7/z, \[x0\]
+.*:    a4002060        ld1rqb  \{z0\.b\}, p0/z, \[x3\]
+.*:    a4002060        ld1rqb  \{z0\.b\}, p0/z, \[x3\]
+.*:    a4002060        ld1rqb  \{z0\.b\}, p0/z, \[x3\]
+.*:    a40023e0        ld1rqb  \{z0\.b\}, p0/z, \[sp\]
+.*:    a40023e0        ld1rqb  \{z0\.b\}, p0/z, \[sp\]
+.*:    a40023e0        ld1rqb  \{z0\.b\}, p0/z, \[sp\]
+.*:    a4082000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #-128\]
+.*:    a4082000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #-128\]
+.*:    a40f2000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #-16\]
+.*:    a40f2000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #-16\]
+.*:    a4012000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #16\]
+.*:    a4012000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #16\]
+.*:    a4072000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #112\]
+.*:    a4072000        ld1rqb  \{z0\.b\}, p0/z, \[x0, #112\]
+.*:    a4000000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x0\]
+.*:    a4000000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x0\]
+.*:    a4000000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x0\]
+.*:    a4000000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x0\]
+.*:    a4000001        ld1rqb  \{z1\.b\}, p0/z, \[x0, x0\]
+.*:    a4000001        ld1rqb  \{z1\.b\}, p0/z, \[x0, x0\]
+.*:    a4000001        ld1rqb  \{z1\.b\}, p0/z, \[x0, x0\]
+.*:    a4000001        ld1rqb  \{z1\.b\}, p0/z, \[x0, x0\]
+.*:    a400001f        ld1rqb  \{z31\.b\}, p0/z, \[x0, x0\]
+.*:    a400001f        ld1rqb  \{z31\.b\}, p0/z, \[x0, x0\]
+.*:    a400001f        ld1rqb  \{z31\.b\}, p0/z, \[x0, x0\]
+.*:    a400001f        ld1rqb  \{z31\.b\}, p0/z, \[x0, x0\]
+.*:    a4000800        ld1rqb  \{z0\.b\}, p2/z, \[x0, x0\]
+.*:    a4000800        ld1rqb  \{z0\.b\}, p2/z, \[x0, x0\]
+.*:    a4000800        ld1rqb  \{z0\.b\}, p2/z, \[x0, x0\]
+.*:    a4001c00        ld1rqb  \{z0\.b\}, p7/z, \[x0, x0\]
+.*:    a4001c00        ld1rqb  \{z0\.b\}, p7/z, \[x0, x0\]
+.*:    a4001c00        ld1rqb  \{z0\.b\}, p7/z, \[x0, x0\]
+.*:    a4000060        ld1rqb  \{z0\.b\}, p0/z, \[x3, x0\]
+.*:    a4000060        ld1rqb  \{z0\.b\}, p0/z, \[x3, x0\]
+.*:    a4000060        ld1rqb  \{z0\.b\}, p0/z, \[x3, x0\]
+.*:    a40003e0        ld1rqb  \{z0\.b\}, p0/z, \[sp, x0\]
+.*:    a40003e0        ld1rqb  \{z0\.b\}, p0/z, \[sp, x0\]
+.*:    a40003e0        ld1rqb  \{z0\.b\}, p0/z, \[sp, x0\]
+.*:    a4040000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x4\]
+.*:    a4040000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x4\]
+.*:    a4040000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x4\]
+.*:    a41e0000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x30\]
+.*:    a41e0000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x30\]
+.*:    a41e0000        ld1rqb  \{z0\.b\}, p0/z, \[x0, x30\]
+.*:    a5802000        ld1rqd  \{z0\.d\}, p0/z, \[x0\]
+.*:    a5802000        ld1rqd  \{z0\.d\}, p0/z, \[x0\]
+.*:    a5802000        ld1rqd  \{z0\.d\}, p0/z, \[x0\]
+.*:    a5802000        ld1rqd  \{z0\.d\}, p0/z, \[x0\]
+.*:    a5802001        ld1rqd  \{z1\.d\}, p0/z, \[x0\]
+.*:    a5802001        ld1rqd  \{z1\.d\}, p0/z, \[x0\]
+.*:    a5802001        ld1rqd  \{z1\.d\}, p0/z, \[x0\]
+.*:    a5802001        ld1rqd  \{z1\.d\}, p0/z, \[x0\]
+.*:    a580201f        ld1rqd  \{z31\.d\}, p0/z, \[x0\]
+.*:    a580201f        ld1rqd  \{z31\.d\}, p0/z, \[x0\]
+.*:    a580201f        ld1rqd  \{z31\.d\}, p0/z, \[x0\]
+.*:    a580201f        ld1rqd  \{z31\.d\}, p0/z, \[x0\]
+.*:    a5802800        ld1rqd  \{z0\.d\}, p2/z, \[x0\]
+.*:    a5802800        ld1rqd  \{z0\.d\}, p2/z, \[x0\]
+.*:    a5802800        ld1rqd  \{z0\.d\}, p2/z, \[x0\]
+.*:    a5803c00        ld1rqd  \{z0\.d\}, p7/z, \[x0\]
+.*:    a5803c00        ld1rqd  \{z0\.d\}, p7/z, \[x0\]
+.*:    a5803c00        ld1rqd  \{z0\.d\}, p7/z, \[x0\]
+.*:    a5802060        ld1rqd  \{z0\.d\}, p0/z, \[x3\]
+.*:    a5802060        ld1rqd  \{z0\.d\}, p0/z, \[x3\]
+.*:    a5802060        ld1rqd  \{z0\.d\}, p0/z, \[x3\]
+.*:    a58023e0        ld1rqd  \{z0\.d\}, p0/z, \[sp\]
+.*:    a58023e0        ld1rqd  \{z0\.d\}, p0/z, \[sp\]
+.*:    a58023e0        ld1rqd  \{z0\.d\}, p0/z, \[sp\]
+.*:    a5882000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #-128\]
+.*:    a5882000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #-128\]
+.*:    a58f2000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #-16\]
+.*:    a58f2000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #-16\]
+.*:    a5812000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #16\]
+.*:    a5812000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #16\]
+.*:    a5872000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #112\]
+.*:    a5872000        ld1rqd  \{z0\.d\}, p0/z, \[x0, #112\]
+.*:    a5800000        ld1rqd  \{z0\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a5800000        ld1rqd  \{z0\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a5800000        ld1rqd  \{z0\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a5800001        ld1rqd  \{z1\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a5800001        ld1rqd  \{z1\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a5800001        ld1rqd  \{z1\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a580001f        ld1rqd  \{z31\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a580001f        ld1rqd  \{z31\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a580001f        ld1rqd  \{z31\.d\}, p0/z, \[x0, x0, lsl #3\]
+.*:    a5800800        ld1rqd  \{z0\.d\}, p2/z, \[x0, x0, lsl #3\]
+.*:    a5800800        ld1rqd  \{z0\.d\}, p2/z, \[x0, x0, lsl #3\]
+.*:    a5801c00        ld1rqd  \{z0\.d\}, p7/z, \[x0, x0, lsl #3\]
+.*:    a5801c00        ld1rqd  \{z0\.d\}, p7/z, \[x0, x0, lsl #3\]
+.*:    a5800060        ld1rqd  \{z0\.d\}, p0/z, \[x3, x0, lsl #3\]
+.*:    a5800060        ld1rqd  \{z0\.d\}, p0/z, \[x3, x0, lsl #3\]
+.*:    a58003e0        ld1rqd  \{z0\.d\}, p0/z, \[sp, x0, lsl #3\]
+.*:    a58003e0        ld1rqd  \{z0\.d\}, p0/z, \[sp, x0, lsl #3\]
+.*:    a5840000        ld1rqd  \{z0\.d\}, p0/z, \[x0, x4, lsl #3\]
+.*:    a5840000        ld1rqd  \{z0\.d\}, p0/z, \[x0, x4, lsl #3\]
+.*:    a59e0000        ld1rqd  \{z0\.d\}, p0/z, \[x0, x30, lsl #3\]
+.*:    a59e0000        ld1rqd  \{z0\.d\}, p0/z, \[x0, x30, lsl #3\]
+.*:    a4802000        ld1rqh  \{z0\.h\}, p0/z, \[x0\]
+.*:    a4802000        ld1rqh  \{z0\.h\}, p0/z, \[x0\]
+.*:    a4802000        ld1rqh  \{z0\.h\}, p0/z, \[x0\]
+.*:    a4802000        ld1rqh  \{z0\.h\}, p0/z, \[x0\]
+.*:    a4802001        ld1rqh  \{z1\.h\}, p0/z, \[x0\]
+.*:    a4802001        ld1rqh  \{z1\.h\}, p0/z, \[x0\]
+.*:    a4802001        ld1rqh  \{z1\.h\}, p0/z, \[x0\]
+.*:    a4802001        ld1rqh  \{z1\.h\}, p0/z, \[x0\]
+.*:    a480201f        ld1rqh  \{z31\.h\}, p0/z, \[x0\]
+.*:    a480201f        ld1rqh  \{z31\.h\}, p0/z, \[x0\]
+.*:    a480201f        ld1rqh  \{z31\.h\}, p0/z, \[x0\]
+.*:    a480201f        ld1rqh  \{z31\.h\}, p0/z, \[x0\]
+.*:    a4802800        ld1rqh  \{z0\.h\}, p2/z, \[x0\]
+.*:    a4802800        ld1rqh  \{z0\.h\}, p2/z, \[x0\]
+.*:    a4802800        ld1rqh  \{z0\.h\}, p2/z, \[x0\]
+.*:    a4803c00        ld1rqh  \{z0\.h\}, p7/z, \[x0\]
+.*:    a4803c00        ld1rqh  \{z0\.h\}, p7/z, \[x0\]
+.*:    a4803c00        ld1rqh  \{z0\.h\}, p7/z, \[x0\]
+.*:    a4802060        ld1rqh  \{z0\.h\}, p0/z, \[x3\]
+.*:    a4802060        ld1rqh  \{z0\.h\}, p0/z, \[x3\]
+.*:    a4802060        ld1rqh  \{z0\.h\}, p0/z, \[x3\]
+.*:    a48023e0        ld1rqh  \{z0\.h\}, p0/z, \[sp\]
+.*:    a48023e0        ld1rqh  \{z0\.h\}, p0/z, \[sp\]
+.*:    a48023e0        ld1rqh  \{z0\.h\}, p0/z, \[sp\]
+.*:    a4882000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #-128\]
+.*:    a4882000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #-128\]
+.*:    a48f2000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #-16\]
+.*:    a48f2000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #-16\]
+.*:    a4812000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #16\]
+.*:    a4812000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #16\]
+.*:    a4872000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #112\]
+.*:    a4872000        ld1rqh  \{z0\.h\}, p0/z, \[x0, #112\]
+.*:    a4800000        ld1rqh  \{z0\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a4800000        ld1rqh  \{z0\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a4800000        ld1rqh  \{z0\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a4800001        ld1rqh  \{z1\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a4800001        ld1rqh  \{z1\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a4800001        ld1rqh  \{z1\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a480001f        ld1rqh  \{z31\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a480001f        ld1rqh  \{z31\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a480001f        ld1rqh  \{z31\.h\}, p0/z, \[x0, x0, lsl #1\]
+.*:    a4800800        ld1rqh  \{z0\.h\}, p2/z, \[x0, x0, lsl #1\]
+.*:    a4800800        ld1rqh  \{z0\.h\}, p2/z, \[x0, x0, lsl #1\]
+.*:    a4801c00        ld1rqh  \{z0\.h\}, p7/z, \[x0, x0, lsl #1\]
+.*:    a4801c00        ld1rqh  \{z0\.h\}, p7/z, \[x0, x0, lsl #1\]
+.*:    a4800060        ld1rqh  \{z0\.h\}, p0/z, \[x3, x0, lsl #1\]
+.*:    a4800060        ld1rqh  \{z0\.h\}, p0/z, \[x3, x0, lsl #1\]
+.*:    a48003e0        ld1rqh  \{z0\.h\}, p0/z, \[sp, x0, lsl #1\]
+.*:    a48003e0        ld1rqh  \{z0\.h\}, p0/z, \[sp, x0, lsl #1\]
+.*:    a4840000        ld1rqh  \{z0\.h\}, p0/z, \[x0, x4, lsl #1\]
+.*:    a4840000        ld1rqh  \{z0\.h\}, p0/z, \[x0, x4, lsl #1\]
+.*:    a49e0000        ld1rqh  \{z0\.h\}, p0/z, \[x0, x30, lsl #1\]
+.*:    a49e0000        ld1rqh  \{z0\.h\}, p0/z, \[x0, x30, lsl #1\]
+.*:    a5002000        ld1rqw  \{z0\.s\}, p0/z, \[x0\]
+.*:    a5002000        ld1rqw  \{z0\.s\}, p0/z, \[x0\]
+.*:    a5002000        ld1rqw  \{z0\.s\}, p0/z, \[x0\]
+.*:    a5002000        ld1rqw  \{z0\.s\}, p0/z, \[x0\]
+.*:    a5002001        ld1rqw  \{z1\.s\}, p0/z, \[x0\]
+.*:    a5002001        ld1rqw  \{z1\.s\}, p0/z, \[x0\]
+.*:    a5002001        ld1rqw  \{z1\.s\}, p0/z, \[x0\]
+.*:    a5002001        ld1rqw  \{z1\.s\}, p0/z, \[x0\]
+.*:    a500201f        ld1rqw  \{z31\.s\}, p0/z, \[x0\]
+.*:    a500201f        ld1rqw  \{z31\.s\}, p0/z, \[x0\]
+.*:    a500201f        ld1rqw  \{z31\.s\}, p0/z, \[x0\]
+.*:    a500201f        ld1rqw  \{z31\.s\}, p0/z, \[x0\]
+.*:    a5002800        ld1rqw  \{z0\.s\}, p2/z, \[x0\]
+.*:    a5002800        ld1rqw  \{z0\.s\}, p2/z, \[x0\]
+.*:    a5002800        ld1rqw  \{z0\.s\}, p2/z, \[x0\]
+.*:    a5003c00        ld1rqw  \{z0\.s\}, p7/z, \[x0\]
+.*:    a5003c00        ld1rqw  \{z0\.s\}, p7/z, \[x0\]
+.*:    a5003c00        ld1rqw  \{z0\.s\}, p7/z, \[x0\]
+.*:    a5002060        ld1rqw  \{z0\.s\}, p0/z, \[x3\]
+.*:    a5002060        ld1rqw  \{z0\.s\}, p0/z, \[x3\]
+.*:    a5002060        ld1rqw  \{z0\.s\}, p0/z, \[x3\]
+.*:    a50023e0        ld1rqw  \{z0\.s\}, p0/z, \[sp\]
+.*:    a50023e0        ld1rqw  \{z0\.s\}, p0/z, \[sp\]
+.*:    a50023e0        ld1rqw  \{z0\.s\}, p0/z, \[sp\]
+.*:    a5082000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #-128\]
+.*:    a5082000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #-128\]
+.*:    a50f2000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #-16\]
+.*:    a50f2000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #-16\]
+.*:    a5012000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #16\]
+.*:    a5012000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #16\]
+.*:    a5072000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #112\]
+.*:    a5072000        ld1rqw  \{z0\.s\}, p0/z, \[x0, #112\]
+.*:    a5000000        ld1rqw  \{z0\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a5000000        ld1rqw  \{z0\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a5000000        ld1rqw  \{z0\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a5000001        ld1rqw  \{z1\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a5000001        ld1rqw  \{z1\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a5000001        ld1rqw  \{z1\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a500001f        ld1rqw  \{z31\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a500001f        ld1rqw  \{z31\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a500001f        ld1rqw  \{z31\.s\}, p0/z, \[x0, x0, lsl #2\]
+.*:    a5000800        ld1rqw  \{z0\.s\}, p2/z, \[x0, x0, lsl #2\]
+.*:    a5000800        ld1rqw  \{z0\.s\}, p2/z, \[x0, x0, lsl #2\]
+.*:    a5001c00        ld1rqw  \{z0\.s\}, p7/z, \[x0, x0, lsl #2\]
+.*:    a5001c00        ld1rqw  \{z0\.s\}, p7/z, \[x0, x0, lsl #2\]
+.*:    a5000060        ld1rqw  \{z0\.s\}, p0/z, \[x3, x0, lsl #2\]
+.*:    a5000060        ld1rqw  \{z0\.s\}, p0/z, \[x3, x0, lsl #2\]
+.*:    a50003e0        ld1rqw  \{z0\.s\}, p0/z, \[sp, x0, lsl #2\]
+.*:    a50003e0        ld1rqw  \{z0\.s\}, p0/z, \[sp, x0, lsl #2\]
+.*:    a5040000        ld1rqw  \{z0\.s\}, p0/z, \[x0, x4, lsl #2\]
+.*:    a5040000        ld1rqw  \{z0\.s\}, p0/z, \[x0, x4, lsl #2\]
+.*:    a51e0000        ld1rqw  \{z0\.s\}, p0/z, \[x0, x30, lsl #2\]
+.*:    a51e0000        ld1rqw  \{z0\.s\}, p0/z, \[x0, x30, lsl #2\]
 .*:    8540c000        ld1rw   \{z0\.s\}, p0/z, \[x0\]
 .*:    8540c000        ld1rw   \{z0\.s\}, p0/z, \[x0\]
 .*:    8540c000        ld1rw   \{z0\.s\}, p0/z, \[x0\]
@@ -25018,6 +26999,34 @@ Disassembly of section .*:
 .*:    04802060        saddv   d0, p0, z3\.s
 .*:    048023e0        saddv   d0, p0, z31\.s
 .*:    048023e0        saddv   d0, p0, z31\.s
+.*:    6552a000        scvtf   z0\.h, p0/m, z0\.h
+.*:    6552a000        scvtf   z0\.h, p0/m, z0\.h
+.*:    6552a001        scvtf   z1\.h, p0/m, z0\.h
+.*:    6552a001        scvtf   z1\.h, p0/m, z0\.h
+.*:    6552a01f        scvtf   z31\.h, p0/m, z0\.h
+.*:    6552a01f        scvtf   z31\.h, p0/m, z0\.h
+.*:    6552a800        scvtf   z0\.h, p2/m, z0\.h
+.*:    6552a800        scvtf   z0\.h, p2/m, z0\.h
+.*:    6552bc00        scvtf   z0\.h, p7/m, z0\.h
+.*:    6552bc00        scvtf   z0\.h, p7/m, z0\.h
+.*:    6552a060        scvtf   z0\.h, p0/m, z3\.h
+.*:    6552a060        scvtf   z0\.h, p0/m, z3\.h
+.*:    6552a3e0        scvtf   z0\.h, p0/m, z31\.h
+.*:    6552a3e0        scvtf   z0\.h, p0/m, z31\.h
+.*:    6554a000        scvtf   z0\.h, p0/m, z0\.s
+.*:    6554a000        scvtf   z0\.h, p0/m, z0\.s
+.*:    6554a001        scvtf   z1\.h, p0/m, z0\.s
+.*:    6554a001        scvtf   z1\.h, p0/m, z0\.s
+.*:    6554a01f        scvtf   z31\.h, p0/m, z0\.s
+.*:    6554a01f        scvtf   z31\.h, p0/m, z0\.s
+.*:    6554a800        scvtf   z0\.h, p2/m, z0\.s
+.*:    6554a800        scvtf   z0\.h, p2/m, z0\.s
+.*:    6554bc00        scvtf   z0\.h, p7/m, z0\.s
+.*:    6554bc00        scvtf   z0\.h, p7/m, z0\.s
+.*:    6554a060        scvtf   z0\.h, p0/m, z3\.s
+.*:    6554a060        scvtf   z0\.h, p0/m, z3\.s
+.*:    6554a3e0        scvtf   z0\.h, p0/m, z31\.s
+.*:    6554a3e0        scvtf   z0\.h, p0/m, z31\.s
 .*:    6594a000        scvtf   z0\.s, p0/m, z0\.s
 .*:    6594a000        scvtf   z0\.s, p0/m, z0\.s
 .*:    6594a001        scvtf   z1\.s, p0/m, z0\.s
@@ -25046,6 +27055,20 @@ Disassembly of section .*:
 .*:    65d0a060        scvtf   z0\.d, p0/m, z3\.s
 .*:    65d0a3e0        scvtf   z0\.d, p0/m, z31\.s
 .*:    65d0a3e0        scvtf   z0\.d, p0/m, z31\.s
+.*:    6556a000        scvtf   z0\.h, p0/m, z0\.d
+.*:    6556a000        scvtf   z0\.h, p0/m, z0\.d
+.*:    6556a001        scvtf   z1\.h, p0/m, z0\.d
+.*:    6556a001        scvtf   z1\.h, p0/m, z0\.d
+.*:    6556a01f        scvtf   z31\.h, p0/m, z0\.d
+.*:    6556a01f        scvtf   z31\.h, p0/m, z0\.d
+.*:    6556a800        scvtf   z0\.h, p2/m, z0\.d
+.*:    6556a800        scvtf   z0\.h, p2/m, z0\.d
+.*:    6556bc00        scvtf   z0\.h, p7/m, z0\.d
+.*:    6556bc00        scvtf   z0\.h, p7/m, z0\.d
+.*:    6556a060        scvtf   z0\.h, p0/m, z3\.d
+.*:    6556a060        scvtf   z0\.h, p0/m, z3\.d
+.*:    6556a3e0        scvtf   z0\.h, p0/m, z31\.d
+.*:    6556a3e0        scvtf   z0\.h, p0/m, z31\.d
 .*:    65d4a000        scvtf   z0\.s, p0/m, z0\.d
 .*:    65d4a000        scvtf   z0\.s, p0/m, z0\.d
 .*:    65d4a001        scvtf   z1\.s, p0/m, z0\.d
@@ -25138,6 +27161,76 @@ Disassembly of section .*:
 .*:    04d60080        sdivr   z0\.d, p0/m, z0\.d, z4\.d
 .*:    04d603e0        sdivr   z0\.d, p0/m, z0\.d, z31\.d
 .*:    04d603e0        sdivr   z0\.d, p0/m, z0\.d, z31\.d
+.*:    44800000        sdot    z0\.s, z0\.b, z0\.b
+.*:    44800000        sdot    z0\.s, z0\.b, z0\.b
+.*:    44800001        sdot    z1\.s, z0\.b, z0\.b
+.*:    44800001        sdot    z1\.s, z0\.b, z0\.b
+.*:    4480001f        sdot    z31\.s, z0\.b, z0\.b
+.*:    4480001f        sdot    z31\.s, z0\.b, z0\.b
+.*:    44800040        sdot    z0\.s, z2\.b, z0\.b
+.*:    44800040        sdot    z0\.s, z2\.b, z0\.b
+.*:    448003e0        sdot    z0\.s, z31\.b, z0\.b
+.*:    448003e0        sdot    z0\.s, z31\.b, z0\.b
+.*:    44830000        sdot    z0\.s, z0\.b, z3\.b
+.*:    44830000        sdot    z0\.s, z0\.b, z3\.b
+.*:    449f0000        sdot    z0\.s, z0\.b, z31\.b
+.*:    449f0000        sdot    z0\.s, z0\.b, z31\.b
+.*:    44c00000        sdot    z0\.d, z0\.h, z0\.h
+.*:    44c00000        sdot    z0\.d, z0\.h, z0\.h
+.*:    44c00001        sdot    z1\.d, z0\.h, z0\.h
+.*:    44c00001        sdot    z1\.d, z0\.h, z0\.h
+.*:    44c0001f        sdot    z31\.d, z0\.h, z0\.h
+.*:    44c0001f        sdot    z31\.d, z0\.h, z0\.h
+.*:    44c00040        sdot    z0\.d, z2\.h, z0\.h
+.*:    44c00040        sdot    z0\.d, z2\.h, z0\.h
+.*:    44c003e0        sdot    z0\.d, z31\.h, z0\.h
+.*:    44c003e0        sdot    z0\.d, z31\.h, z0\.h
+.*:    44c30000        sdot    z0\.d, z0\.h, z3\.h
+.*:    44c30000        sdot    z0\.d, z0\.h, z3\.h
+.*:    44df0000        sdot    z0\.d, z0\.h, z31\.h
+.*:    44df0000        sdot    z0\.d, z0\.h, z31\.h
+.*:    44a00000        sdot    z0\.s, z0\.b, z0\.b\[0\]
+.*:    44a00000        sdot    z0\.s, z0\.b, z0\.b\[0\]
+.*:    44a00001        sdot    z1\.s, z0\.b, z0\.b\[0\]
+.*:    44a00001        sdot    z1\.s, z0\.b, z0\.b\[0\]
+.*:    44a0001f        sdot    z31\.s, z0\.b, z0\.b\[0\]
+.*:    44a0001f        sdot    z31\.s, z0\.b, z0\.b\[0\]
+.*:    44a00040        sdot    z0\.s, z2\.b, z0\.b\[0\]
+.*:    44a00040        sdot    z0\.s, z2\.b, z0\.b\[0\]
+.*:    44a003e0        sdot    z0\.s, z31\.b, z0\.b\[0\]
+.*:    44a003e0        sdot    z0\.s, z31\.b, z0\.b\[0\]
+.*:    44a30000        sdot    z0\.s, z0\.b, z3\.b\[0\]
+.*:    44a30000        sdot    z0\.s, z0\.b, z3\.b\[0\]
+.*:    44a70000        sdot    z0\.s, z0\.b, z7\.b\[0\]
+.*:    44a70000        sdot    z0\.s, z0\.b, z7\.b\[0\]
+.*:    44a80000        sdot    z0\.s, z0\.b, z0\.b\[1\]
+.*:    44a80000        sdot    z0\.s, z0\.b, z0\.b\[1\]
+.*:    44ac0000        sdot    z0\.s, z0\.b, z4\.b\[1\]
+.*:    44ac0000        sdot    z0\.s, z0\.b, z4\.b\[1\]
+.*:    44b30000        sdot    z0\.s, z0\.b, z3\.b\[2\]
+.*:    44b30000        sdot    z0\.s, z0\.b, z3\.b\[2\]
+.*:    44b80000        sdot    z0\.s, z0\.b, z0\.b\[3\]
+.*:    44b80000        sdot    z0\.s, z0\.b, z0\.b\[3\]
+.*:    44bd0000        sdot    z0\.s, z0\.b, z5\.b\[3\]
+.*:    44bd0000        sdot    z0\.s, z0\.b, z5\.b\[3\]
+.*:    44e00000        sdot    z0\.d, z0\.h, z0\.h\[0\]
+.*:    44e00000        sdot    z0\.d, z0\.h, z0\.h\[0\]
+.*:    44e00001        sdot    z1\.d, z0\.h, z0\.h\[0\]
+.*:    44e00001        sdot    z1\.d, z0\.h, z0\.h\[0\]
+.*:    44e0001f        sdot    z31\.d, z0\.h, z0\.h\[0\]
+.*:    44e0001f        sdot    z31\.d, z0\.h, z0\.h\[0\]
+.*:    44e00040        sdot    z0\.d, z2\.h, z0\.h\[0\]
+.*:    44e00040        sdot    z0\.d, z2\.h, z0\.h\[0\]
+.*:    44e003e0        sdot    z0\.d, z31\.h, z0\.h\[0\]
+.*:    44e003e0        sdot    z0\.d, z31\.h, z0\.h\[0\]
+.*:    44e30000        sdot    z0\.d, z0\.h, z3\.h\[0\]
+.*:    44e30000        sdot    z0\.d, z0\.h, z3\.h\[0\]
+.*:    44ef0000        sdot    z0\.d, z0\.h, z15\.h\[0\]
+.*:    44ef0000        sdot    z0\.d, z0\.h, z15\.h\[0\]
+.*:    44f00000        sdot    z0\.d, z0\.h, z0\.h\[1\]
+.*:    44f00000        sdot    z0\.d, z0\.h, z0\.h\[1\]
+.*:    44fb0000        sdot    z0\.d, z0\.h, z11\.h\[1\]
+.*:    44fb0000        sdot    z0\.d, z0\.h, z11\.h\[1\]
 .*:    0520c000        mov     z0\.b, p0/m, z0\.b
 .*:    0520c000        mov     z0\.b, p0/m, z0\.b
 .*:    0520c001        sel     z1\.b, p0, z0\.b, z0\.b
@@ -32917,6 +35010,34 @@ Disassembly of section .*:
 .*:    04c12060        uaddv   d0, p0, z3\.d
 .*:    04c123e0        uaddv   d0, p0, z31\.d
 .*:    04c123e0        uaddv   d0, p0, z31\.d
+.*:    6553a000        ucvtf   z0\.h, p0/m, z0\.h
+.*:    6553a000        ucvtf   z0\.h, p0/m, z0\.h
+.*:    6553a001        ucvtf   z1\.h, p0/m, z0\.h
+.*:    6553a001        ucvtf   z1\.h, p0/m, z0\.h
+.*:    6553a01f        ucvtf   z31\.h, p0/m, z0\.h
+.*:    6553a01f        ucvtf   z31\.h, p0/m, z0\.h
+.*:    6553a800        ucvtf   z0\.h, p2/m, z0\.h
+.*:    6553a800        ucvtf   z0\.h, p2/m, z0\.h
+.*:    6553bc00        ucvtf   z0\.h, p7/m, z0\.h
+.*:    6553bc00        ucvtf   z0\.h, p7/m, z0\.h
+.*:    6553a060        ucvtf   z0\.h, p0/m, z3\.h
+.*:    6553a060        ucvtf   z0\.h, p0/m, z3\.h
+.*:    6553a3e0        ucvtf   z0\.h, p0/m, z31\.h
+.*:    6553a3e0        ucvtf   z0\.h, p0/m, z31\.h
+.*:    6555a000        ucvtf   z0\.h, p0/m, z0\.s
+.*:    6555a000        ucvtf   z0\.h, p0/m, z0\.s
+.*:    6555a001        ucvtf   z1\.h, p0/m, z0\.s
+.*:    6555a001        ucvtf   z1\.h, p0/m, z0\.s
+.*:    6555a01f        ucvtf   z31\.h, p0/m, z0\.s
+.*:    6555a01f        ucvtf   z31\.h, p0/m, z0\.s
+.*:    6555a800        ucvtf   z0\.h, p2/m, z0\.s
+.*:    6555a800        ucvtf   z0\.h, p2/m, z0\.s
+.*:    6555bc00        ucvtf   z0\.h, p7/m, z0\.s
+.*:    6555bc00        ucvtf   z0\.h, p7/m, z0\.s
+.*:    6555a060        ucvtf   z0\.h, p0/m, z3\.s
+.*:    6555a060        ucvtf   z0\.h, p0/m, z3\.s
+.*:    6555a3e0        ucvtf   z0\.h, p0/m, z31\.s
+.*:    6555a3e0        ucvtf   z0\.h, p0/m, z31\.s
 .*:    6595a000        ucvtf   z0\.s, p0/m, z0\.s
 .*:    6595a000        ucvtf   z0\.s, p0/m, z0\.s
 .*:    6595a001        ucvtf   z1\.s, p0/m, z0\.s
@@ -32945,6 +35066,20 @@ Disassembly of section .*:
 .*:    65d1a060        ucvtf   z0\.d, p0/m, z3\.s
 .*:    65d1a3e0        ucvtf   z0\.d, p0/m, z31\.s
 .*:    65d1a3e0        ucvtf   z0\.d, p0/m, z31\.s
+.*:    6557a000        ucvtf   z0\.h, p0/m, z0\.d
+.*:    6557a000        ucvtf   z0\.h, p0/m, z0\.d
+.*:    6557a001        ucvtf   z1\.h, p0/m, z0\.d
+.*:    6557a001        ucvtf   z1\.h, p0/m, z0\.d
+.*:    6557a01f        ucvtf   z31\.h, p0/m, z0\.d
+.*:    6557a01f        ucvtf   z31\.h, p0/m, z0\.d
+.*:    6557a800        ucvtf   z0\.h, p2/m, z0\.d
+.*:    6557a800        ucvtf   z0\.h, p2/m, z0\.d
+.*:    6557bc00        ucvtf   z0\.h, p7/m, z0\.d
+.*:    6557bc00        ucvtf   z0\.h, p7/m, z0\.d
+.*:    6557a060        ucvtf   z0\.h, p0/m, z3\.d
+.*:    6557a060        ucvtf   z0\.h, p0/m, z3\.d
+.*:    6557a3e0        ucvtf   z0\.h, p0/m, z31\.d
+.*:    6557a3e0        ucvtf   z0\.h, p0/m, z31\.d
 .*:    65d5a000        ucvtf   z0\.s, p0/m, z0\.d
 .*:    65d5a000        ucvtf   z0\.s, p0/m, z0\.d
 .*:    65d5a001        ucvtf   z1\.s, p0/m, z0\.d
@@ -33037,6 +35172,76 @@ Disassembly of section .*:
 .*:    04d70080        udivr   z0\.d, p0/m, z0\.d, z4\.d
 .*:    04d703e0        udivr   z0\.d, p0/m, z0\.d, z31\.d
 .*:    04d703e0        udivr   z0\.d, p0/m, z0\.d, z31\.d
+.*:    44800400        udot    z0\.s, z0\.b, z0\.b
+.*:    44800400        udot    z0\.s, z0\.b, z0\.b
+.*:    44800401        udot    z1\.s, z0\.b, z0\.b
+.*:    44800401        udot    z1\.s, z0\.b, z0\.b
+.*:    4480041f        udot    z31\.s, z0\.b, z0\.b
+.*:    4480041f        udot    z31\.s, z0\.b, z0\.b
+.*:    44800440        udot    z0\.s, z2\.b, z0\.b
+.*:    44800440        udot    z0\.s, z2\.b, z0\.b
+.*:    448007e0        udot    z0\.s, z31\.b, z0\.b
+.*:    448007e0        udot    z0\.s, z31\.b, z0\.b
+.*:    44830400        udot    z0\.s, z0\.b, z3\.b
+.*:    44830400        udot    z0\.s, z0\.b, z3\.b
+.*:    449f0400        udot    z0\.s, z0\.b, z31\.b
+.*:    449f0400        udot    z0\.s, z0\.b, z31\.b
+.*:    44c00400        udot    z0\.d, z0\.h, z0\.h
+.*:    44c00400        udot    z0\.d, z0\.h, z0\.h
+.*:    44c00401        udot    z1\.d, z0\.h, z0\.h
+.*:    44c00401        udot    z1\.d, z0\.h, z0\.h
+.*:    44c0041f        udot    z31\.d, z0\.h, z0\.h
+.*:    44c0041f        udot    z31\.d, z0\.h, z0\.h
+.*:    44c00440        udot    z0\.d, z2\.h, z0\.h
+.*:    44c00440        udot    z0\.d, z2\.h, z0\.h
+.*:    44c007e0        udot    z0\.d, z31\.h, z0\.h
+.*:    44c007e0        udot    z0\.d, z31\.h, z0\.h
+.*:    44c30400        udot    z0\.d, z0\.h, z3\.h
+.*:    44c30400        udot    z0\.d, z0\.h, z3\.h
+.*:    44df0400        udot    z0\.d, z0\.h, z31\.h
+.*:    44df0400        udot    z0\.d, z0\.h, z31\.h
+.*:    44a00400        udot    z0\.s, z0\.b, z0\.b\[0\]
+.*:    44a00400        udot    z0\.s, z0\.b, z0\.b\[0\]
+.*:    44a00401        udot    z1\.s, z0\.b, z0\.b\[0\]
+.*:    44a00401        udot    z1\.s, z0\.b, z0\.b\[0\]
+.*:    44a0041f        udot    z31\.s, z0\.b, z0\.b\[0\]
+.*:    44a0041f        udot    z31\.s, z0\.b, z0\.b\[0\]
+.*:    44a00440        udot    z0\.s, z2\.b, z0\.b\[0\]
+.*:    44a00440        udot    z0\.s, z2\.b, z0\.b\[0\]
+.*:    44a007e0        udot    z0\.s, z31\.b, z0\.b\[0\]
+.*:    44a007e0        udot    z0\.s, z31\.b, z0\.b\[0\]
+.*:    44a30400        udot    z0\.s, z0\.b, z3\.b\[0\]
+.*:    44a30400        udot    z0\.s, z0\.b, z3\.b\[0\]
+.*:    44a70400        udot    z0\.s, z0\.b, z7\.b\[0\]
+.*:    44a70400        udot    z0\.s, z0\.b, z7\.b\[0\]
+.*:    44a80400        udot    z0\.s, z0\.b, z0\.b\[1\]
+.*:    44a80400        udot    z0\.s, z0\.b, z0\.b\[1\]
+.*:    44ac0400        udot    z0\.s, z0\.b, z4\.b\[1\]
+.*:    44ac0400        udot    z0\.s, z0\.b, z4\.b\[1\]
+.*:    44b30400        udot    z0\.s, z0\.b, z3\.b\[2\]
+.*:    44b30400        udot    z0\.s, z0\.b, z3\.b\[2\]
+.*:    44b80400        udot    z0\.s, z0\.b, z0\.b\[3\]
+.*:    44b80400        udot    z0\.s, z0\.b, z0\.b\[3\]
+.*:    44bd0400        udot    z0\.s, z0\.b, z5\.b\[3\]
+.*:    44bd0400        udot    z0\.s, z0\.b, z5\.b\[3\]
+.*:    44e00400        udot    z0\.d, z0\.h, z0\.h\[0\]
+.*:    44e00400        udot    z0\.d, z0\.h, z0\.h\[0\]
+.*:    44e00401        udot    z1\.d, z0\.h, z0\.h\[0\]
+.*:    44e00401        udot    z1\.d, z0\.h, z0\.h\[0\]
+.*:    44e0041f        udot    z31\.d, z0\.h, z0\.h\[0\]
+.*:    44e0041f        udot    z31\.d, z0\.h, z0\.h\[0\]
+.*:    44e00440        udot    z0\.d, z2\.h, z0\.h\[0\]
+.*:    44e00440        udot    z0\.d, z2\.h, z0\.h\[0\]
+.*:    44e007e0        udot    z0\.d, z31\.h, z0\.h\[0\]
+.*:    44e007e0        udot    z0\.d, z31\.h, z0\.h\[0\]
+.*:    44e30400        udot    z0\.d, z0\.h, z3\.h\[0\]
+.*:    44e30400        udot    z0\.d, z0\.h, z3\.h\[0\]
+.*:    44ef0400        udot    z0\.d, z0\.h, z15\.h\[0\]
+.*:    44ef0400        udot    z0\.d, z0\.h, z15\.h\[0\]
+.*:    44f00400        udot    z0\.d, z0\.h, z0\.h\[1\]
+.*:    44f00400        udot    z0\.d, z0\.h, z0\.h\[1\]
+.*:    44fb0400        udot    z0\.d, z0\.h, z11\.h\[1\]
+.*:    44fb0400        udot    z0\.d, z0\.h, z11\.h\[1\]
 .*:    2529c000        umax    z0\.b, z0\.b, #0
 .*:    2529c000        umax    z0\.b, z0\.b, #0
 .*:    2529c001        umax    z1\.b, z1\.b, #0
@@ -37999,6 +40204,24 @@ Disassembly of section .*:
 .*:    0540bbc0        eor     z0\.s, z0\.s, #0xfffffeff
 .*:    0543ffc0        eor     z0\.d, z0\.d, #0xfffffffffffffffe
 .*:    0543ffc0        eor     z0\.d, z0\.d, #0xfffffffffffffffe
+.*:    6540c010        facge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540c010        facge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540c011        facge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540c011        facge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540c01f        facge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540c01f        facge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540c810        facge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540c810        facge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540dc10        facge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540dc10        facge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6543c010        facge   p0\.h, p0/z, z0\.h, z3\.h
+.*:    6543c010        facge   p0\.h, p0/z, z0\.h, z3\.h
+.*:    655fc010        facge   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655fc010        facge   p0\.h, p0/z, z0\.h, z31\.h
+.*:    6540c090        facge   p0\.h, p0/z, z4\.h, z0\.h
+.*:    6540c090        facge   p0\.h, p0/z, z4\.h, z0\.h
+.*:    6540c3f0        facge   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6540c3f0        facge   p0\.h, p0/z, z31\.h, z0\.h
 .*:    6580c010        facge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580c010        facge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580c011        facge   p1\.s, p0/z, z0\.s, z0\.s
@@ -38035,6 +40258,24 @@ Disassembly of section .*:
 .*:    65c0c090        facge   p0\.d, p0/z, z4\.d, z0\.d
 .*:    65c0c3f0        facge   p0\.d, p0/z, z31\.d, z0\.d
 .*:    65c0c3f0        facge   p0\.d, p0/z, z31\.d, z0\.d
+.*:    6540e010        facgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540e010        facgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    6540e011        facgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540e011        facgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540e01f        facgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540e01f        facgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540e810        facgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540e810        facgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    6540fc10        facgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6540fc10        facgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    6543e010        facgt   p0\.h, p0/z, z0\.h, z3\.h
+.*:    6543e010        facgt   p0\.h, p0/z, z0\.h, z3\.h
+.*:    655fe010        facgt   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655fe010        facgt   p0\.h, p0/z, z0\.h, z31\.h
+.*:    6540e090        facgt   p0\.h, p0/z, z4\.h, z0\.h
+.*:    6540e090        facgt   p0\.h, p0/z, z4\.h, z0\.h
+.*:    6540e3f0        facgt   p0\.h, p0/z, z31\.h, z0\.h
+.*:    6540e3f0        facgt   p0\.h, p0/z, z31\.h, z0\.h
 .*:    6580e010        facgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580e010        facgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    6580e011        facgt   p1\.s, p0/z, z0\.s, z0\.s
@@ -38071,6 +40312,24 @@ Disassembly of section .*:
 .*:    65c0e090        facgt   p0\.d, p0/z, z4\.d, z0\.d
 .*:    65c0e3f0        facgt   p0\.d, p0/z, z31\.d, z0\.d
 .*:    65c0e3f0        facgt   p0\.d, p0/z, z31\.d, z0\.d
+.*:    65404000        fcmge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404000        fcmge   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404001        fcmge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    65404001        fcmge   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540400f        fcmge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540400f        fcmge   p15\.h, p0/z, z0\.h, z0\.h
+.*:    65404800        fcmge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65404800        fcmge   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65405c00        fcmge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65405c00        fcmge   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65434000        fcmge   p0\.h, p0/z, z0\.h, z3\.h
+.*:    65434000        fcmge   p0\.h, p0/z, z0\.h, z3\.h
+.*:    655f4000        fcmge   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655f4000        fcmge   p0\.h, p0/z, z0\.h, z31\.h
+.*:    65404080        fcmge   p0\.h, p0/z, z4\.h, z0\.h
+.*:    65404080        fcmge   p0\.h, p0/z, z4\.h, z0\.h
+.*:    654043e0        fcmge   p0\.h, p0/z, z31\.h, z0\.h
+.*:    654043e0        fcmge   p0\.h, p0/z, z31\.h, z0\.h
 .*:    65804000        fcmge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804000        fcmge   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804001        fcmge   p1\.s, p0/z, z0\.s, z0\.s
@@ -38107,6 +40366,24 @@ Disassembly of section .*:
 .*:    65c04080        fcmge   p0\.d, p0/z, z4\.d, z0\.d
 .*:    65c043e0        fcmge   p0\.d, p0/z, z31\.d, z0\.d
 .*:    65c043e0        fcmge   p0\.d, p0/z, z31\.d, z0\.d
+.*:    65404010        fcmgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404010        fcmgt   p0\.h, p0/z, z0\.h, z0\.h
+.*:    65404011        fcmgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    65404011        fcmgt   p1\.h, p0/z, z0\.h, z0\.h
+.*:    6540401f        fcmgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    6540401f        fcmgt   p15\.h, p0/z, z0\.h, z0\.h
+.*:    65404810        fcmgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65404810        fcmgt   p0\.h, p2/z, z0\.h, z0\.h
+.*:    65405c10        fcmgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65405c10        fcmgt   p0\.h, p7/z, z0\.h, z0\.h
+.*:    65434010        fcmgt   p0\.h, p0/z, z0\.h, z3\.h
+.*:    65434010        fcmgt   p0\.h, p0/z, z0\.h, z3\.h
+.*:    655f4010        fcmgt   p0\.h, p0/z, z0\.h, z31\.h
+.*:    655f4010        fcmgt   p0\.h, p0/z, z0\.h, z31\.h
+.*:    65404090        fcmgt   p0\.h, p0/z, z4\.h, z0\.h
+.*:    65404090        fcmgt   p0\.h, p0/z, z4\.h, z0\.h
+.*:    654043f0        fcmgt   p0\.h, p0/z, z31\.h, z0\.h
+.*:    654043f0        fcmgt   p0\.h, p0/z, z31\.h, z0\.h
 .*:    65804010        fcmgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804010        fcmgt   p0\.s, p0/z, z0\.s, z0\.s
 .*:    65804011        fcmgt   p1\.s, p0/z, z0\.s, z0\.s
@@ -38143,6 +40420,12 @@ Disassembly of section .*:
 .*:    65c04090        fcmgt   p0\.d, p0/z, z4\.d, z0\.d
 .*:    65c043f0        fcmgt   p0\.d, p0/z, z31\.d, z0\.d
 .*:    65c043f0        fcmgt   p0\.d, p0/z, z31\.d, z0\.d
+.*:    2578c000        mov     z0\.h, #0
+.*:    2578c000        mov     z0\.h, #0
+.*:    2578c001        mov     z1\.h, #0
+.*:    2578c001        mov     z1\.h, #0
+.*:    2578c01f        mov     z31\.h, #0
+.*:    2578c01f        mov     z31\.h, #0
 .*:    25b8c000        mov     z0\.s, #0
 .*:    25b8c000        mov     z0\.s, #0
 .*:    25b8c001        mov     z1\.s, #0
@@ -38155,6 +40438,16 @@ Disassembly of section .*:
 .*:    25f8c001        mov     z1\.d, #0
 .*:    25f8c01f        mov     z31\.d, #0
 .*:    25f8c01f        mov     z31\.d, #0
+.*:    05504000        mov     z0\.h, p0/m, #0
+.*:    05504000        mov     z0\.h, p0/m, #0
+.*:    05504001        mov     z1\.h, p0/m, #0
+.*:    05504001        mov     z1\.h, p0/m, #0
+.*:    0550401f        mov     z31\.h, p0/m, #0
+.*:    0550401f        mov     z31\.h, p0/m, #0
+.*:    05524000        mov     z0\.h, p2/m, #0
+.*:    05524000        mov     z0\.h, p2/m, #0
+.*:    055f4000        mov     z0\.h, p15/m, #0
+.*:    055f4000        mov     z0\.h, p15/m, #0
 .*:    05904000        mov     z0\.s, p0/m, #0
 .*:    05904000        mov     z0\.s, p0/m, #0
 .*:    05904001        mov     z1\.s, p0/m, #0
@@ -38236,3 +40529,36 @@ Disassembly of section .*:
 .*:    0500bbc0        orr     z0\.s, z0\.s, #0xfffffeff
 .*:    0503ffc0        orr     z0\.d, z0\.d, #0xfffffffffffffffe
 .*:    0503ffc0        orr     z0\.d, z0\.d, #0xfffffffffffffffe
+
+.*:    6ec3c441        fcmla   v1\.2d, v2\.2d, v3\.2d, #0
+.*:    6ec3cc41        fcmla   v1\.2d, v2\.2d, v3\.2d, #90
+.*:    6ec3d441        fcmla   v1\.2d, v2\.2d, v3\.2d, #180
+.*:    6ec3dc41        fcmla   v1\.2d, v2\.2d, v3\.2d, #270
+.*:    2e83cc41        fcmla   v1\.2s, v2\.2s, v3\.2s, #90
+.*:    6e83cc41        fcmla   v1\.4s, v2\.4s, v3\.4s, #90
+.*:    2e43cc41        fcmla   v1\.4h, v2\.4h, v3\.4h, #90
+.*:    6e43cc41        fcmla   v1\.8h, v2\.8h, v3\.8h, #90
+.*:    6f831041        fcmla   v1\.4s, v2\.4s, v3\.s\[0\], #0
+.*:    6f833041        fcmla   v1\.4s, v2\.4s, v3\.s\[0\], #90
+.*:    6f835041        fcmla   v1\.4s, v2\.4s, v3\.s\[0\], #180
+.*:    6f837041        fcmla   v1\.4s, v2\.4s, v3\.s\[0\], #270
+.*:    6f833841        fcmla   v1\.4s, v2\.4s, v3\.s\[1\], #90
+.*:    2f433041        fcmla   v1\.4h, v2\.4h, v3\.h\[0\], #90
+.*:    2f633041        fcmla   v1\.4h, v2\.4h, v3\.h\[1\], #90
+.*:    6f433041        fcmla   v1\.8h, v2\.8h, v3\.h\[0\], #90
+.*:    6f633041        fcmla   v1\.8h, v2\.8h, v3\.h\[1\], #90
+.*:    6f433841        fcmla   v1\.8h, v2\.8h, v3\.h\[2\], #90
+.*:    6f633841        fcmla   v1\.8h, v2\.8h, v3\.h\[3\], #90
+.*:    6ec3e441        fcadd   v1\.2d, v2\.2d, v3\.2d, #90
+.*:    6ec3f441        fcadd   v1\.2d, v2\.2d, v3\.2d, #270
+.*:    2e83e441        fcadd   v1\.2s, v2\.2s, v3\.2s, #90
+.*:    6e83e441        fcadd   v1\.4s, v2\.4s, v3\.4s, #90
+.*:    2e43e441        fcadd   v1\.4h, v2\.4h, v3\.4h, #90
+.*:    6e43e441        fcadd   v1\.8h, v2\.8h, v3\.8h, #90
+.*:    4e63d441        fadd    v1\.2d, v2\.2d, v3\.2d
+.*:    0e23d441        fadd    v1\.2s, v2\.2s, v3\.2s
+.*:    4e23d441        fadd    v1\.4s, v2\.4s, v3\.4s
+.*:    0e401400        fadd    v0\.4h, v0\.4h, v0\.4h
+.*:    0e431441        fadd    v1\.4h, v2\.4h, v3\.4h
+.*:    4e401400        fadd    v0\.8h, v0\.8h, v0\.8h
+.*:    4e431441        fadd    v1\.8h, v2\.8h, v3\.8h
index e2c3fd02f6c37771038aa1c5019299f208d5b00a..2130b0d09d5ab26a09c74d19a4237c339dc0fa4e 100644 (file)
        .equ    w0, 1
        .equ    x0, 1
 
+       fmov      z0.h, #2.0000000000
+       FMOV      Z0.H, #2.0000000000
+       fmov      z1.h, #2.0000000000
+       FMOV      Z1.H, #2.0000000000
+       fmov      z31.h, #2.0000000000
+       FMOV      Z31.H, #2.0000000000
+       fmov      z0.h, #16.0000000000
+       FMOV      Z0.H, #16.0000000000
+       fmov      z0.h, #0.1875000000
+       FMOV      Z0.H, #0.1875000000
+       fmov      z0.h, #1.9375000000
+       FMOV      Z0.H, #1.9375000000
+       fmov      z0.h, #-3.0000000000
+       FMOV      Z0.H, #-3.0000000000
+       fmov      z0.h, #-0.1250000000
+       FMOV      Z0.H, #-0.1250000000
+       fmov      z0.h, #-1.9375000000
+       FMOV      Z0.H, #-1.9375000000
        fmov      z0.s, #2.0000000000
        FMOV      Z0.S, #2.0000000000
        fmov      z1.s, #2.0000000000
        FMOV      Z0.D, #-0.1250000000
        fmov      z0.d, #-1.9375000000
        FMOV      Z0.D, #-1.9375000000
+       fmov      z0.h, p0/m, #2.0000000000
+       FMOV      Z0.H, P0/M, #2.0000000000
+       fmov      z1.h, p0/m, #2.0000000000
+       FMOV      Z1.H, P0/M, #2.0000000000
+       fmov      z31.h, p0/m, #2.0000000000
+       FMOV      Z31.H, P0/M, #2.0000000000
+       fmov      z0.h, p2/m, #2.0000000000
+       FMOV      Z0.H, P2/M, #2.0000000000
+       fmov      z0.h, p15/m, #2.0000000000
+       FMOV      Z0.H, P15/M, #2.0000000000
+       fmov      z0.h, p0/m, #16.0000000000
+       FMOV      Z0.H, P0/M, #16.0000000000
+       fmov      z0.h, p0/m, #0.1875000000
+       FMOV      Z0.H, P0/M, #0.1875000000
+       fmov      z0.h, p0/m, #1.9375000000
+       FMOV      Z0.H, P0/M, #1.9375000000
+       fmov      z0.h, p0/m, #-3.0000000000
+       FMOV      Z0.H, P0/M, #-3.0000000000
+       fmov      z0.h, p0/m, #-0.1250000000
+       FMOV      Z0.H, P0/M, #-0.1250000000
+       fmov      z0.h, p0/m, #-1.9375000000
+       FMOV      Z0.H, P0/M, #-1.9375000000
        fmov      z0.s, p0/m, #2.0000000000
        FMOV      Z0.S, P0/M, #2.0000000000
        fmov      z1.s, p0/m, #2.0000000000
        MOV       Z0.D, D2
        mov       z0.d, d31
        MOV       Z0.D, D31
+       mov       z0.q, q0
+       mov       z0.Q, Q0
+       mov       z1.q, q0
+       mov       z1.Q, Q0
+       mov       z31.q, q0
+       mov       z31.Q, Q0
+       mov       z0.q, q2
+       mov       z0.Q, Q2
+       mov       z0.q, q31
+       mov       z0.Q, Q31
        mov       z0.b, w0
        MOV       Z0.B, W0
        mov       z1.b, w0
        MOV       Z0.B, Z31.B[7]
        mov       z0.b, z0.b[8]
        MOV       Z0.B, Z0.B[8]
+       mov       z0.q, z0.q[1]
+       MOV       Z0.Q, Z0.Q[1]
+       mov       z1.q, z0.q[1]
+       MOV       Z1.Q, Z0.Q[1]
+       mov       z31.q, z0.q[1]
+       MOV       Z31.Q, Z0.Q[1]
+       mov       z0.q, z2.q[1]
+       MOV       Z0.Q, Z2.Q[1]
+       mov       z0.q, z31.q[1]
+       MOV       Z0.Q, Z31.Q[1]
+       mov       z0.q, z0.q[0]
+       MOV       Z0.Q, Z0.Q[0]
+       mov       z0.q, z0.q[2]
+       MOV       Z0.Q, Z0.Q[2]
+       mov       z0.q, z0.q[3]
+       MOV       Z0.Q, Z0.Q[3]
        mov       z0.s, #0xff
        MOV       Z0.S, #0XFF
        mov       z0.d, #0xff000000ff
        DUP       Z0.B, Z31.B[7]
        dup       z0.b, z0.b[8]
        DUP       Z0.B, Z0.B[8]
+       dup       z0.q, z0.q[1]
+       DUP       Z0.Q, Z0.Q[1]
+       dup       z1.q, z0.q[1]
+       DUP       Z1.Q, Z0.Q[1]
+       dup       z31.q, z0.q[1]
+       DUP       Z31.Q, Z0.Q[1]
+       dup       z0.q, z2.q[1]
+       DUP       Z0.Q, Z2.Q[1]
+       dup       z0.q, z31.q[1]
+       DUP       Z0.Q, Z31.Q[1]
+       dup       z0.q, z0.q[0]
+       DUP       Z0.Q, Z0.Q[0]
+       dup       z0.q, z0.q[2]
+       DUP       Z0.Q, Z0.Q[2]
+       dup       z0.q, z0.q[3]
+       DUP       Z0.Q, Z0.Q[3]
        dup       z0.b, #0
        DUP       Z0.B, #0
        dup       z0.b, #0, lsl #0
        EXT       Z0.B, Z0.B, Z0.B, #129
        ext       z0.b, z0.b, z0.b, #255
        EXT       Z0.B, Z0.B, Z0.B, #255
+       fabd      z0.h, p0/m, z0.h, z0.h
+       FABD      Z0.H, P0/M, Z0.H, Z0.H
+       fabd      z1.h, p0/m, z1.h, z0.h
+       FABD      Z1.H, P0/M, Z1.H, Z0.H
+       fabd      z31.h, p0/m, z31.h, z0.h
+       FABD      Z31.H, P0/M, Z31.H, Z0.H
+       fabd      z0.h, p2/m, z0.h, z0.h
+       FABD      Z0.H, P2/M, Z0.H, Z0.H
+       fabd      z0.h, p7/m, z0.h, z0.h
+       FABD      Z0.H, P7/M, Z0.H, Z0.H
+       fabd      z3.h, p0/m, z3.h, z0.h
+       FABD      Z3.H, P0/M, Z3.H, Z0.H
+       fabd      z0.h, p0/m, z0.h, z4.h
+       FABD      Z0.H, P0/M, Z0.H, Z4.H
+       fabd      z0.h, p0/m, z0.h, z31.h
+       FABD      Z0.H, P0/M, Z0.H, Z31.H
        fabd      z0.s, p0/m, z0.s, z0.s
        FABD      Z0.S, P0/M, Z0.S, Z0.S
        fabd      z1.s, p0/m, z1.s, z0.s
        FABD      Z0.D, P0/M, Z0.D, Z4.D
        fabd      z0.d, p0/m, z0.d, z31.d
        FABD      Z0.D, P0/M, Z0.D, Z31.D
+       fabs      z0.h, p0/m, z0.h
+       FABS      Z0.H, P0/M, Z0.H
+       fabs      z1.h, p0/m, z0.h
+       FABS      Z1.H, P0/M, Z0.H
+       fabs      z31.h, p0/m, z0.h
+       FABS      Z31.H, P0/M, Z0.H
+       fabs      z0.h, p2/m, z0.h
+       FABS      Z0.H, P2/M, Z0.H
+       fabs      z0.h, p7/m, z0.h
+       FABS      Z0.H, P7/M, Z0.H
+       fabs      z0.h, p0/m, z3.h
+       FABS      Z0.H, P0/M, Z3.H
+       fabs      z0.h, p0/m, z31.h
+       FABS      Z0.H, P0/M, Z31.H
        fabs      z0.s, p0/m, z0.s
        FABS      Z0.S, P0/M, Z0.S
        fabs      z1.s, p0/m, z0.s
        FABS      Z0.D, P0/M, Z3.D
        fabs      z0.d, p0/m, z31.d
        FABS      Z0.D, P0/M, Z31.D
+       facge     p0.h, p0/z, z0.h, z0.h
+       FACGE     P0.H, P0/Z, Z0.H, Z0.H
+       facge     p1.h, p0/z, z0.h, z0.h
+       FACGE     P1.H, P0/Z, Z0.H, Z0.H
+       facge     p15.h, p0/z, z0.h, z0.h
+       FACGE     P15.H, P0/Z, Z0.H, Z0.H
+       facge     p0.h, p2/z, z0.h, z0.h
+       FACGE     P0.H, P2/Z, Z0.H, Z0.H
+       facge     p0.h, p7/z, z0.h, z0.h
+       FACGE     P0.H, P7/Z, Z0.H, Z0.H
+       facge     p0.h, p0/z, z3.h, z0.h
+       FACGE     P0.H, P0/Z, Z3.H, Z0.H
+       facge     p0.h, p0/z, z31.h, z0.h
+       FACGE     P0.H, P0/Z, Z31.H, Z0.H
+       facge     p0.h, p0/z, z0.h, z4.h
+       FACGE     P0.H, P0/Z, Z0.H, Z4.H
+       facge     p0.h, p0/z, z0.h, z31.h
+       FACGE     P0.H, P0/Z, Z0.H, Z31.H
        facge     p0.s, p0/z, z0.s, z0.s
        FACGE     P0.S, P0/Z, Z0.S, Z0.S
        facge     p1.s, p0/z, z0.s, z0.s
        FACGE     P0.D, P0/Z, Z0.D, Z4.D
        facge     p0.d, p0/z, z0.d, z31.d
        FACGE     P0.D, P0/Z, Z0.D, Z31.D
+       facgt     p0.h, p0/z, z0.h, z0.h
+       FACGT     P0.H, P0/Z, Z0.H, Z0.H
+       facgt     p1.h, p0/z, z0.h, z0.h
+       FACGT     P1.H, P0/Z, Z0.H, Z0.H
+       facgt     p15.h, p0/z, z0.h, z0.h
+       FACGT     P15.H, P0/Z, Z0.H, Z0.H
+       facgt     p0.h, p2/z, z0.h, z0.h
+       FACGT     P0.H, P2/Z, Z0.H, Z0.H
+       facgt     p0.h, p7/z, z0.h, z0.h
+       FACGT     P0.H, P7/Z, Z0.H, Z0.H
+       facgt     p0.h, p0/z, z3.h, z0.h
+       FACGT     P0.H, P0/Z, Z3.H, Z0.H
+       facgt     p0.h, p0/z, z31.h, z0.h
+       FACGT     P0.H, P0/Z, Z31.H, Z0.H
+       facgt     p0.h, p0/z, z0.h, z4.h
+       FACGT     P0.H, P0/Z, Z0.H, Z4.H
+       facgt     p0.h, p0/z, z0.h, z31.h
+       FACGT     P0.H, P0/Z, Z0.H, Z31.H
        facgt     p0.s, p0/z, z0.s, z0.s
        FACGT     P0.S, P0/Z, Z0.S, Z0.S
        facgt     p1.s, p0/z, z0.s, z0.s
        FACGT     P0.D, P0/Z, Z0.D, Z4.D
        facgt     p0.d, p0/z, z0.d, z31.d
        FACGT     P0.D, P0/Z, Z0.D, Z31.D
+       fadd      z0.h, z0.h, z0.h
+       FADD      Z0.H, Z0.H, Z0.H
+       fadd      z1.h, z0.h, z0.h
+       FADD      Z1.H, Z0.H, Z0.H
+       fadd      z31.h, z0.h, z0.h
+       FADD      Z31.H, Z0.H, Z0.H
+       fadd      z0.h, z2.h, z0.h
+       FADD      Z0.H, Z2.H, Z0.H
+       fadd      z0.h, z31.h, z0.h
+       FADD      Z0.H, Z31.H, Z0.H
+       fadd      z0.h, z0.h, z3.h
+       FADD      Z0.H, Z0.H, Z3.H
+       fadd      z0.h, z0.h, z31.h
+       FADD      Z0.H, Z0.H, Z31.H
        fadd      z0.s, z0.s, z0.s
        FADD      Z0.S, Z0.S, Z0.S
        fadd      z1.s, z0.s, z0.s
        FADD      Z0.D, Z0.D, Z3.D
        fadd      z0.d, z0.d, z31.d
        FADD      Z0.D, Z0.D, Z31.D
+       fadd      z0.h, p0/m, z0.h, z0.h
+       FADD      Z0.H, P0/M, Z0.H, Z0.H
+       fadd      z1.h, p0/m, z1.h, z0.h
+       FADD      Z1.H, P0/M, Z1.H, Z0.H
+       fadd      z31.h, p0/m, z31.h, z0.h
+       FADD      Z31.H, P0/M, Z31.H, Z0.H
+       fadd      z0.h, p2/m, z0.h, z0.h
+       FADD      Z0.H, P2/M, Z0.H, Z0.H
+       fadd      z0.h, p7/m, z0.h, z0.h
+       FADD      Z0.H, P7/M, Z0.H, Z0.H
+       fadd      z3.h, p0/m, z3.h, z0.h
+       FADD      Z3.H, P0/M, Z3.H, Z0.H
+       fadd      z0.h, p0/m, z0.h, z4.h
+       FADD      Z0.H, P0/M, Z0.H, Z4.H
+       fadd      z0.h, p0/m, z0.h, z31.h
+       FADD      Z0.H, P0/M, Z0.H, Z31.H
        fadd      z0.s, p0/m, z0.s, z0.s
        FADD      Z0.S, P0/M, Z0.S, Z0.S
        fadd      z1.s, p0/m, z1.s, z0.s
        FADD      Z0.D, P0/M, Z0.D, Z4.D
        fadd      z0.d, p0/m, z0.d, z31.d
        FADD      Z0.D, P0/M, Z0.D, Z31.D
+       fadd      z0.h, p0/m, z0.h, #0.5
+       FADD      Z0.H, P0/M, Z0.H, #0.5
+       fadd      z0.h, p0/m, z0.h, #0.50000
+       fadd      z0.h, p0/m, z0.h, #5.0000000000e-01
+       fadd      z1.h, p0/m, z1.h, #0.5
+       FADD      Z1.H, P0/M, Z1.H, #0.5
+       fadd      z1.h, p0/m, z1.h, #0.50000
+       fadd      z1.h, p0/m, z1.h, #5.0000000000e-01
+       fadd      z31.h, p0/m, z31.h, #0.5
+       FADD      Z31.H, P0/M, Z31.H, #0.5
+       fadd      z31.h, p0/m, z31.h, #0.50000
+       fadd      z31.h, p0/m, z31.h, #5.0000000000e-01
+       fadd      z0.h, p2/m, z0.h, #0.5
+       FADD      Z0.H, P2/M, Z0.H, #0.5
+       fadd      z0.h, p2/m, z0.h, #0.50000
+       fadd      z0.h, p2/m, z0.h, #5.0000000000e-01
+       fadd      z0.h, p7/m, z0.h, #0.5
+       FADD      Z0.H, P7/M, Z0.H, #0.5
+       fadd      z0.h, p7/m, z0.h, #0.50000
+       fadd      z0.h, p7/m, z0.h, #5.0000000000e-01
+       fadd      z3.h, p0/m, z3.h, #0.5
+       FADD      Z3.H, P0/M, Z3.H, #0.5
+       fadd      z3.h, p0/m, z3.h, #0.50000
+       fadd      z3.h, p0/m, z3.h, #5.0000000000e-01
+       fadd      z0.h, p0/m, z0.h, #1.0
+       FADD      Z0.H, P0/M, Z0.H, #1.0
+       fadd      z0.h, p0/m, z0.h, #1.00000
+       fadd      z0.h, p0/m, z0.h, #1.0000000000e+00
        fadd      z0.s, p0/m, z0.s, #0.5
        FADD      Z0.S, P0/M, Z0.S, #0.5
        fadd      z0.s, p0/m, z0.s, #0.50000
        FADD      Z0.D, P0/M, Z0.D, #1.0
        fadd      z0.d, p0/m, z0.d, #1.00000
        fadd      z0.d, p0/m, z0.d, #1.0000000000e+00
+       fadda     h0, p0, h0, z0.h
+       FADDA     H0, P0, H0, Z0.H
+       fadda     h1, p0, h1, z0.h
+       FADDA     H1, P0, H1, Z0.H
+       fadda     h31, p0, h31, z0.h
+       FADDA     H31, P0, H31, Z0.H
+       fadda     h0, p2, h0, z0.h
+       FADDA     H0, P2, H0, Z0.H
+       fadda     h0, p7, h0, z0.h
+       FADDA     H0, P7, H0, Z0.H
+       fadda     h3, p0, h3, z0.h
+       FADDA     H3, P0, H3, Z0.H
+       fadda     h0, p0, h0, z4.h
+       FADDA     H0, P0, H0, Z4.H
+       fadda     h0, p0, h0, z31.h
+       FADDA     H0, P0, H0, Z31.H
        fadda     s0, p0, s0, z0.s
        FADDA     S0, P0, S0, Z0.S
        fadda     s1, p0, s1, z0.s
        FADDA     D0, P0, D0, Z4.D
        fadda     d0, p0, d0, z31.d
        FADDA     D0, P0, D0, Z31.D
+       faddv     h0, p0, z0.h
+       FADDV     H0, P0, Z0.H
+       faddv     h1, p0, z0.h
+       FADDV     H1, P0, Z0.H
+       faddv     h31, p0, z0.h
+       FADDV     H31, P0, Z0.H
+       faddv     h0, p2, z0.h
+       FADDV     H0, P2, Z0.H
+       faddv     h0, p7, z0.h
+       FADDV     H0, P7, Z0.H
+       faddv     h0, p0, z3.h
+       FADDV     H0, P0, Z3.H
+       faddv     h0, p0, z31.h
+       FADDV     H0, P0, Z31.H
        faddv     s0, p0, z0.s
        FADDV     S0, P0, Z0.S
        faddv     s1, p0, z0.s
        FADDV     D0, P0, Z3.D
        faddv     d0, p0, z31.d
        FADDV     D0, P0, Z31.D
+       fcadd     z0.h, p0/m, z0.h, z0.h, #90
+       FCADD     Z0.H, P0/M, Z0.H, Z0.H, #90
+       fcadd     z1.h, p0/m, z1.h, z0.h, #90
+       FCADD     Z1.H, P0/M, Z1.H, Z0.H, #90
+       fcadd     z31.h, p0/m, z31.h, z0.h, #90
+       FCADD     Z31.H, P0/M, Z31.H, Z0.H, #90
+       fcadd     z0.h, p2/m, z0.h, z0.h, #90
+       FCADD     Z0.H, P2/M, Z0.H, Z0.H, #90
+       fcadd     z0.h, p7/m, z0.h, z0.h, #90
+       FCADD     Z0.H, P7/M, Z0.H, Z0.H, #90
+       fcadd     z3.h, p0/m, z3.h, z0.h, #90
+       FCADD     Z3.H, P0/M, Z3.H, Z0.H, #90
+       fcadd     z0.h, p0/m, z0.h, z4.h, #90
+       FCADD     Z0.H, P0/M, Z0.H, Z4.H, #90
+       fcadd     z0.h, p0/m, z0.h, z31.h, #90
+       FCADD     Z0.H, P0/M, Z0.H, Z31.H, #90
+       fcadd     z0.h, p0/m, z0.h, z0.h, #270
+       FCADD     Z0.H, P0/M, Z0.H, Z0.H, #270
+       fcadd     z0.s, p0/m, z0.s, z0.s, #90
+       FCADD     Z0.S, P0/M, Z0.S, Z0.S, #90
+       fcadd     z1.s, p0/m, z1.s, z0.s, #90
+       FCADD     Z1.S, P0/M, Z1.S, Z0.S, #90
+       fcadd     z31.s, p0/m, z31.s, z0.s, #90
+       FCADD     Z31.S, P0/M, Z31.S, Z0.S, #90
+       fcadd     z0.s, p2/m, z0.s, z0.s, #90
+       FCADD     Z0.S, P2/M, Z0.S, Z0.S, #90
+       fcadd     z0.s, p7/m, z0.s, z0.s, #90
+       FCADD     Z0.S, P7/M, Z0.S, Z0.S, #90
+       fcadd     z3.s, p0/m, z3.s, z0.s, #90
+       FCADD     Z3.S, P0/M, Z3.S, Z0.S, #90
+       fcadd     z0.s, p0/m, z0.s, z4.s, #90
+       FCADD     Z0.S, P0/M, Z0.S, Z4.S, #90
+       fcadd     z0.s, p0/m, z0.s, z31.s, #90
+       FCADD     Z0.S, P0/M, Z0.S, Z31.S, #90
+       fcadd     z0.s, p0/m, z0.s, z0.s, #270
+       FCADD     Z0.S, P0/M, Z0.S, Z0.S, #270
+       fcadd     z0.d, p0/m, z0.d, z0.d, #90
+       FCADD     Z0.D, P0/M, Z0.D, Z0.D, #90
+       fcadd     z1.d, p0/m, z1.d, z0.d, #90
+       FCADD     Z1.D, P0/M, Z1.D, Z0.D, #90
+       fcadd     z31.d, p0/m, z31.d, z0.d, #90
+       FCADD     Z31.D, P0/M, Z31.D, Z0.D, #90
+       fcadd     z0.d, p2/m, z0.d, z0.d, #90
+       FCADD     Z0.D, P2/M, Z0.D, Z0.D, #90
+       fcadd     z0.d, p7/m, z0.d, z0.d, #90
+       FCADD     Z0.D, P7/M, Z0.D, Z0.D, #90
+       fcadd     z3.d, p0/m, z3.d, z0.d, #90
+       FCADD     Z3.D, P0/M, Z3.D, Z0.D, #90
+       fcadd     z0.d, p0/m, z0.d, z4.d, #90
+       FCADD     Z0.D, P0/M, Z0.D, Z4.D, #90
+       fcadd     z0.d, p0/m, z0.d, z31.d, #90
+       FCADD     Z0.D, P0/M, Z0.D, Z31.D, #90
+       fcadd     z0.d, p0/m, z0.d, z0.d, #270
+       FCADD     Z0.D, P0/M, Z0.D, Z0.D, #270
+       fcmla     z0.h, p0/m, z0.h, z0.h, #0
+       FCMLA     Z0.H, P0/M, Z0.H, Z0.H, #0
+       fcmla     z1.h, p0/m, z0.h, z0.h, #0
+       FCMLA     Z1.H, P0/M, Z0.H, Z0.H, #0
+       fcmla     z31.h, p0/m, z0.h, z0.h, #0
+       FCMLA     Z31.H, P0/M, Z0.H, Z0.H, #0
+       fcmla     z0.h, p2/m, z0.h, z0.h, #0
+       FCMLA     Z0.H, P2/M, Z0.H, Z0.H, #0
+       fcmla     z0.h, p7/m, z0.h, z0.h, #0
+       FCMLA     Z0.H, P7/M, Z0.H, Z0.H, #0
+       fcmla     z0.h, p0/m, z3.h, z0.h, #0
+       FCMLA     Z0.H, P0/M, Z3.H, Z0.H, #0
+       fcmla     z0.h, p0/m, z31.h, z0.h, #0
+       FCMLA     Z0.H, P0/M, Z31.H, Z0.H, #0
+       fcmla     z0.h, p0/m, z0.h, z4.h, #0
+       FCMLA     Z0.H, P0/M, Z0.H, Z4.H, #0
+       fcmla     z0.h, p0/m, z0.h, z31.h, #0
+       FCMLA     Z0.H, P0/M, Z0.H, Z31.H, #0
+       fcmla     z0.h, p0/m, z0.h, z0.h, #90
+       FCMLA     Z0.H, P0/M, Z0.H, Z0.H, #90
+       fcmla     z0.h, p0/m, z0.h, z0.h, #180
+       FCMLA     Z0.H, P0/M, Z0.H, Z0.H, #180
+       fcmla     z0.h, p0/m, z0.h, z0.h, #270
+       FCMLA     Z0.H, P0/M, Z0.H, Z0.H, #270
+       fcmla     z0.s, p0/m, z0.s, z0.s, #0
+       FCMLA     Z0.S, P0/M, Z0.S, Z0.S, #0
+       fcmla     z1.s, p0/m, z0.s, z0.s, #0
+       FCMLA     Z1.S, P0/M, Z0.S, Z0.S, #0
+       fcmla     z31.s, p0/m, z0.s, z0.s, #0
+       FCMLA     Z31.S, P0/M, Z0.S, Z0.S, #0
+       fcmla     z0.s, p2/m, z0.s, z0.s, #0
+       FCMLA     Z0.S, P2/M, Z0.S, Z0.S, #0
+       fcmla     z0.s, p7/m, z0.s, z0.s, #0
+       FCMLA     Z0.S, P7/M, Z0.S, Z0.S, #0
+       fcmla     z0.s, p0/m, z3.s, z0.s, #0
+       FCMLA     Z0.S, P0/M, Z3.S, Z0.S, #0
+       fcmla     z0.s, p0/m, z31.s, z0.s, #0
+       FCMLA     Z0.S, P0/M, Z31.S, Z0.S, #0
+       fcmla     z0.s, p0/m, z0.s, z4.s, #0
+       FCMLA     Z0.S, P0/M, Z0.S, Z4.S, #0
+       fcmla     z0.s, p0/m, z0.s, z31.s, #0
+       FCMLA     Z0.S, P0/M, Z0.S, Z31.S, #0
+       fcmla     z0.s, p0/m, z0.s, z0.s, #90
+       FCMLA     Z0.S, P0/M, Z0.S, Z0.S, #90
+       fcmla     z0.s, p0/m, z0.s, z0.s, #180
+       FCMLA     Z0.S, P0/M, Z0.S, Z0.S, #180
+       fcmla     z0.s, p0/m, z0.s, z0.s, #270
+       FCMLA     Z0.S, P0/M, Z0.S, Z0.S, #270
+       fcmla     z0.d, p0/m, z0.d, z0.d, #0
+       FCMLA     Z0.D, P0/M, Z0.D, Z0.D, #0
+       fcmla     z1.d, p0/m, z0.d, z0.d, #0
+       FCMLA     Z1.D, P0/M, Z0.D, Z0.D, #0
+       fcmla     z31.d, p0/m, z0.d, z0.d, #0
+       FCMLA     Z31.D, P0/M, Z0.D, Z0.D, #0
+       fcmla     z0.d, p2/m, z0.d, z0.d, #0
+       FCMLA     Z0.D, P2/M, Z0.D, Z0.D, #0
+       fcmla     z0.d, p7/m, z0.d, z0.d, #0
+       FCMLA     Z0.D, P7/M, Z0.D, Z0.D, #0
+       fcmla     z0.d, p0/m, z3.d, z0.d, #0
+       FCMLA     Z0.D, P0/M, Z3.D, Z0.D, #0
+       fcmla     z0.d, p0/m, z31.d, z0.d, #0
+       FCMLA     Z0.D, P0/M, Z31.D, Z0.D, #0
+       fcmla     z0.d, p0/m, z0.d, z4.d, #0
+       FCMLA     Z0.D, P0/M, Z0.D, Z4.D, #0
+       fcmla     z0.d, p0/m, z0.d, z31.d, #0
+       FCMLA     Z0.D, P0/M, Z0.D, Z31.D, #0
+       fcmla     z0.d, p0/m, z0.d, z0.d, #90
+       FCMLA     Z0.D, P0/M, Z0.D, Z0.D, #90
+       fcmla     z0.d, p0/m, z0.d, z0.d, #180
+       FCMLA     Z0.D, P0/M, Z0.D, Z0.D, #180
+       fcmla     z0.d, p0/m, z0.d, z0.d, #270
+       FCMLA     Z0.D, P0/M, Z0.D, Z0.D, #270
+       fcmla     z0.h, z0.h, z0.h[0], #0
+       FCMLA     Z0.H, Z0.H, Z0.H[0], #0
+       fcmla     z1.h, z0.h, z0.h[0], #0
+       FCMLA     Z1.H, Z0.H, Z0.H[0], #0
+       fcmla     z31.h, z0.h, z0.h[0], #0
+       FCMLA     Z31.H, Z0.H, Z0.H[0], #0
+       fcmla     z0.h, z2.h, z0.h[0], #0
+       FCMLA     Z0.H, Z2.H, Z0.H[0], #0
+       fcmla     z0.h, z31.h, z0.h[0], #0
+       FCMLA     Z0.H, Z31.H, Z0.H[0], #0
+       fcmla     z0.h, z0.h, z3.h[0], #0
+       FCMLA     Z0.H, Z0.H, Z3.H[0], #0
+       fcmla     z0.h, z0.h, z7.h[0], #0
+       FCMLA     Z0.H, Z0.H, Z7.H[0], #0
+       fcmla     z0.h, z0.h, z0.h[1], #0
+       FCMLA     Z0.H, Z0.H, Z0.H[1], #0
+       fcmla     z0.h, z0.h, z5.h[1], #0
+       FCMLA     Z0.H, Z0.H, Z5.H[1], #0
+       fcmla     z0.h, z0.h, z0.h[2], #0
+       FCMLA     Z0.H, Z0.H, Z0.H[2], #0
+       fcmla     z0.h, z0.h, z3.h[2], #0
+       FCMLA     Z0.H, Z0.H, Z3.H[2], #0
+       fcmla     z0.h, z0.h, z0.h[3], #0
+       FCMLA     Z0.H, Z0.H, Z0.H[3], #0
+       fcmla     z0.h, z0.h, z6.h[3], #0
+       FCMLA     Z0.H, Z0.H, Z6.H[3], #0
+       fcmla     z0.h, z0.h, z0.h[0], #90
+       FCMLA     Z0.H, Z0.H, Z0.H[0], #90
+       fcmla     z0.h, z0.h, z0.h[0], #180
+       FCMLA     Z0.H, Z0.H, Z0.H[0], #180
+       fcmla     z0.h, z0.h, z0.h[0], #270
+       FCMLA     Z0.H, Z0.H, Z0.H[0], #270
+       fcmla     z0.s, z0.s, z0.s[0], #0
+       FCMLA     Z0.S, Z0.S, Z0.S[0], #0
+       fcmla     z1.s, z0.s, z0.s[0], #0
+       FCMLA     Z1.S, Z0.S, Z0.S[0], #0
+       fcmla     z31.s, z0.s, z0.s[0], #0
+       FCMLA     Z31.S, Z0.S, Z0.S[0], #0
+       fcmla     z0.s, z2.s, z0.s[0], #0
+       FCMLA     Z0.S, Z2.S, Z0.S[0], #0
+       fcmla     z0.s, z31.s, z0.s[0], #0
+       FCMLA     Z0.S, Z31.S, Z0.S[0], #0
+       fcmla     z0.s, z0.s, z3.s[0], #0
+       FCMLA     Z0.S, Z0.S, Z3.S[0], #0
+       fcmla     z0.s, z0.s, z15.s[0], #0
+       FCMLA     Z0.S, Z0.S, Z15.S[0], #0
+       fcmla     z0.s, z0.s, z0.s[1], #0
+       FCMLA     Z0.S, Z0.S, Z0.S[1], #0
+       fcmla     z0.s, z0.s, z11.s[1], #0
+       FCMLA     Z0.S, Z0.S, Z11.S[1], #0
+       fcmla     z0.s, z0.s, z0.s[0], #90
+       FCMLA     Z0.S, Z0.S, Z0.S[0], #90
+       fcmla     z0.s, z0.s, z0.s[0], #180
+       FCMLA     Z0.S, Z0.S, Z0.S[0], #180
+       fcmla     z0.s, z0.s, z0.s[0], #270
+       FCMLA     Z0.S, Z0.S, Z0.S[0], #270
+       fcmeq     p0.h, p0/z, z0.h, #0.0
+       FCMEQ     P0.H, P0/Z, Z0.H, #0.0
+       fcmeq     p1.h, p0/z, z0.h, #0.0
+       FCMEQ     P1.H, P0/Z, Z0.H, #0.0
+       fcmeq     p15.h, p0/z, z0.h, #0.0
+       FCMEQ     P15.H, P0/Z, Z0.H, #0.0
+       fcmeq     p0.h, p2/z, z0.h, #0.0
+       FCMEQ     P0.H, P2/Z, Z0.H, #0.0
+       fcmeq     p0.h, p7/z, z0.h, #0.0
+       FCMEQ     P0.H, P7/Z, Z0.H, #0.0
+       fcmeq     p0.h, p0/z, z3.h, #0.0
+       FCMEQ     P0.H, P0/Z, Z3.H, #0.0
+       fcmeq     p0.h, p0/z, z31.h, #0.0
+       FCMEQ     P0.H, P0/Z, Z31.H, #0.0
        fcmeq     p0.s, p0/z, z0.s, #0.0
        FCMEQ     P0.S, P0/Z, Z0.S, #0.0
        fcmeq     p1.s, p0/z, z0.s, #0.0
        FCMEQ     P0.D, P0/Z, Z3.D, #0.0
        fcmeq     p0.d, p0/z, z31.d, #0.0
        FCMEQ     P0.D, P0/Z, Z31.D, #0.0
+       fcmeq     p0.h, p0/z, z0.h, z0.h
+       FCMEQ     P0.H, P0/Z, Z0.H, Z0.H
+       fcmeq     p1.h, p0/z, z0.h, z0.h
+       FCMEQ     P1.H, P0/Z, Z0.H, Z0.H
+       fcmeq     p15.h, p0/z, z0.h, z0.h
+       FCMEQ     P15.H, P0/Z, Z0.H, Z0.H
+       fcmeq     p0.h, p2/z, z0.h, z0.h
+       FCMEQ     P0.H, P2/Z, Z0.H, Z0.H
+       fcmeq     p0.h, p7/z, z0.h, z0.h
+       FCMEQ     P0.H, P7/Z, Z0.H, Z0.H
+       fcmeq     p0.h, p0/z, z3.h, z0.h
+       FCMEQ     P0.H, P0/Z, Z3.H, Z0.H
+       fcmeq     p0.h, p0/z, z31.h, z0.h
+       FCMEQ     P0.H, P0/Z, Z31.H, Z0.H
+       fcmeq     p0.h, p0/z, z0.h, z4.h
+       FCMEQ     P0.H, P0/Z, Z0.H, Z4.H
+       fcmeq     p0.h, p0/z, z0.h, z31.h
+       FCMEQ     P0.H, P0/Z, Z0.H, Z31.H
        fcmeq     p0.s, p0/z, z0.s, z0.s
        FCMEQ     P0.S, P0/Z, Z0.S, Z0.S
        fcmeq     p1.s, p0/z, z0.s, z0.s
        FCMEQ     P0.D, P0/Z, Z0.D, Z4.D
        fcmeq     p0.d, p0/z, z0.d, z31.d
        FCMEQ     P0.D, P0/Z, Z0.D, Z31.D
+       fcmge     p0.h, p0/z, z0.h, #0.0
+       FCMGE     P0.H, P0/Z, Z0.H, #0.0
+       fcmge     p1.h, p0/z, z0.h, #0.0
+       FCMGE     P1.H, P0/Z, Z0.H, #0.0
+       fcmge     p15.h, p0/z, z0.h, #0.0
+       FCMGE     P15.H, P0/Z, Z0.H, #0.0
+       fcmge     p0.h, p2/z, z0.h, #0.0
+       FCMGE     P0.H, P2/Z, Z0.H, #0.0
+       fcmge     p0.h, p7/z, z0.h, #0.0
+       FCMGE     P0.H, P7/Z, Z0.H, #0.0
+       fcmge     p0.h, p0/z, z3.h, #0.0
+       FCMGE     P0.H, P0/Z, Z3.H, #0.0
+       fcmge     p0.h, p0/z, z31.h, #0.0
+       FCMGE     P0.H, P0/Z, Z31.H, #0.0
        fcmge     p0.s, p0/z, z0.s, #0.0
        FCMGE     P0.S, P0/Z, Z0.S, #0.0
        fcmge     p1.s, p0/z, z0.s, #0.0
        FCMGE     P0.D, P0/Z, Z3.D, #0.0
        fcmge     p0.d, p0/z, z31.d, #0.0
        FCMGE     P0.D, P0/Z, Z31.D, #0.0
+       fcmge     p0.h, p0/z, z0.h, z0.h
+       FCMGE     P0.H, P0/Z, Z0.H, Z0.H
+       fcmge     p1.h, p0/z, z0.h, z0.h
+       FCMGE     P1.H, P0/Z, Z0.H, Z0.H
+       fcmge     p15.h, p0/z, z0.h, z0.h
+       FCMGE     P15.H, P0/Z, Z0.H, Z0.H
+       fcmge     p0.h, p2/z, z0.h, z0.h
+       FCMGE     P0.H, P2/Z, Z0.H, Z0.H
+       fcmge     p0.h, p7/z, z0.h, z0.h
+       FCMGE     P0.H, P7/Z, Z0.H, Z0.H
+       fcmge     p0.h, p0/z, z3.h, z0.h
+       FCMGE     P0.H, P0/Z, Z3.H, Z0.H
+       fcmge     p0.h, p0/z, z31.h, z0.h
+       FCMGE     P0.H, P0/Z, Z31.H, Z0.H
+       fcmge     p0.h, p0/z, z0.h, z4.h
+       FCMGE     P0.H, P0/Z, Z0.H, Z4.H
+       fcmge     p0.h, p0/z, z0.h, z31.h
+       FCMGE     P0.H, P0/Z, Z0.H, Z31.H
        fcmge     p0.s, p0/z, z0.s, z0.s
        FCMGE     P0.S, P0/Z, Z0.S, Z0.S
        fcmge     p1.s, p0/z, z0.s, z0.s
        FCMGE     P0.D, P0/Z, Z0.D, Z4.D
        fcmge     p0.d, p0/z, z0.d, z31.d
        FCMGE     P0.D, P0/Z, Z0.D, Z31.D
+       fcmgt     p0.h, p0/z, z0.h, #0.0
+       FCMGT     P0.H, P0/Z, Z0.H, #0.0
+       fcmgt     p1.h, p0/z, z0.h, #0.0
+       FCMGT     P1.H, P0/Z, Z0.H, #0.0
+       fcmgt     p15.h, p0/z, z0.h, #0.0
+       FCMGT     P15.H, P0/Z, Z0.H, #0.0
+       fcmgt     p0.h, p2/z, z0.h, #0.0
+       FCMGT     P0.H, P2/Z, Z0.H, #0.0
+       fcmgt     p0.h, p7/z, z0.h, #0.0
+       FCMGT     P0.H, P7/Z, Z0.H, #0.0
+       fcmgt     p0.h, p0/z, z3.h, #0.0
+       FCMGT     P0.H, P0/Z, Z3.H, #0.0
+       fcmgt     p0.h, p0/z, z31.h, #0.0
+       FCMGT     P0.H, P0/Z, Z31.H, #0.0
        fcmgt     p0.s, p0/z, z0.s, #0.0
        FCMGT     P0.S, P0/Z, Z0.S, #0.0
        fcmgt     p1.s, p0/z, z0.s, #0.0
        FCMGT     P0.D, P0/Z, Z3.D, #0.0
        fcmgt     p0.d, p0/z, z31.d, #0.0
        FCMGT     P0.D, P0/Z, Z31.D, #0.0
+       fcmgt     p0.h, p0/z, z0.h, z0.h
+       FCMGT     P0.H, P0/Z, Z0.H, Z0.H
+       fcmgt     p1.h, p0/z, z0.h, z0.h
+       FCMGT     P1.H, P0/Z, Z0.H, Z0.H
+       fcmgt     p15.h, p0/z, z0.h, z0.h
+       FCMGT     P15.H, P0/Z, Z0.H, Z0.H
+       fcmgt     p0.h, p2/z, z0.h, z0.h
+       FCMGT     P0.H, P2/Z, Z0.H, Z0.H
+       fcmgt     p0.h, p7/z, z0.h, z0.h
+       FCMGT     P0.H, P7/Z, Z0.H, Z0.H
+       fcmgt     p0.h, p0/z, z3.h, z0.h
+       FCMGT     P0.H, P0/Z, Z3.H, Z0.H
+       fcmgt     p0.h, p0/z, z31.h, z0.h
+       FCMGT     P0.H, P0/Z, Z31.H, Z0.H
+       fcmgt     p0.h, p0/z, z0.h, z4.h
+       FCMGT     P0.H, P0/Z, Z0.H, Z4.H
+       fcmgt     p0.h, p0/z, z0.h, z31.h
+       FCMGT     P0.H, P0/Z, Z0.H, Z31.H
        fcmgt     p0.s, p0/z, z0.s, z0.s
        FCMGT     P0.S, P0/Z, Z0.S, Z0.S
        fcmgt     p1.s, p0/z, z0.s, z0.s
        FCMGT     P0.D, P0/Z, Z0.D, Z4.D
        fcmgt     p0.d, p0/z, z0.d, z31.d
        FCMGT     P0.D, P0/Z, Z0.D, Z31.D
+       fcmle     p0.h, p0/z, z0.h, #0.0
+       FCMLE     P0.H, P0/Z, Z0.H, #0.0
+       fcmle     p1.h, p0/z, z0.h, #0.0
+       FCMLE     P1.H, P0/Z, Z0.H, #0.0
+       fcmle     p15.h, p0/z, z0.h, #0.0
+       FCMLE     P15.H, P0/Z, Z0.H, #0.0
+       fcmle     p0.h, p2/z, z0.h, #0.0
+       FCMLE     P0.H, P2/Z, Z0.H, #0.0
+       fcmle     p0.h, p7/z, z0.h, #0.0
+       FCMLE     P0.H, P7/Z, Z0.H, #0.0
+       fcmle     p0.h, p0/z, z3.h, #0.0
+       FCMLE     P0.H, P0/Z, Z3.H, #0.0
+       fcmle     p0.h, p0/z, z31.h, #0.0
+       FCMLE     P0.H, P0/Z, Z31.H, #0.0
        fcmle     p0.s, p0/z, z0.s, #0.0
        FCMLE     P0.S, P0/Z, Z0.S, #0.0
        fcmle     p1.s, p0/z, z0.s, #0.0
        FCMLE     P0.D, P0/Z, Z3.D, #0.0
        fcmle     p0.d, p0/z, z31.d, #0.0
        FCMLE     P0.D, P0/Z, Z31.D, #0.0
+       fcmlt     p0.h, p0/z, z0.h, #0.0
+       FCMLT     P0.H, P0/Z, Z0.H, #0.0
+       fcmlt     p1.h, p0/z, z0.h, #0.0
+       FCMLT     P1.H, P0/Z, Z0.H, #0.0
+       fcmlt     p15.h, p0/z, z0.h, #0.0
+       FCMLT     P15.H, P0/Z, Z0.H, #0.0
+       fcmlt     p0.h, p2/z, z0.h, #0.0
+       FCMLT     P0.H, P2/Z, Z0.H, #0.0
+       fcmlt     p0.h, p7/z, z0.h, #0.0
+       FCMLT     P0.H, P7/Z, Z0.H, #0.0
+       fcmlt     p0.h, p0/z, z3.h, #0.0
+       FCMLT     P0.H, P0/Z, Z3.H, #0.0
+       fcmlt     p0.h, p0/z, z31.h, #0.0
+       FCMLT     P0.H, P0/Z, Z31.H, #0.0
        fcmlt     p0.s, p0/z, z0.s, #0.0
        FCMLT     P0.S, P0/Z, Z0.S, #0.0
        fcmlt     p1.s, p0/z, z0.s, #0.0
        FCMLT     P0.D, P0/Z, Z3.D, #0.0
        fcmlt     p0.d, p0/z, z31.d, #0.0
        FCMLT     P0.D, P0/Z, Z31.D, #0.0
+       fcmne     p0.h, p0/z, z0.h, #0.0
+       FCMNE     P0.H, P0/Z, Z0.H, #0.0
+       fcmne     p1.h, p0/z, z0.h, #0.0
+       FCMNE     P1.H, P0/Z, Z0.H, #0.0
+       fcmne     p15.h, p0/z, z0.h, #0.0
+       FCMNE     P15.H, P0/Z, Z0.H, #0.0
+       fcmne     p0.h, p2/z, z0.h, #0.0
+       FCMNE     P0.H, P2/Z, Z0.H, #0.0
+       fcmne     p0.h, p7/z, z0.h, #0.0
+       FCMNE     P0.H, P7/Z, Z0.H, #0.0
+       fcmne     p0.h, p0/z, z3.h, #0.0
+       FCMNE     P0.H, P0/Z, Z3.H, #0.0
+       fcmne     p0.h, p0/z, z31.h, #0.0
+       FCMNE     P0.H, P0/Z, Z31.H, #0.0
        fcmne     p0.s, p0/z, z0.s, #0.0
        FCMNE     P0.S, P0/Z, Z0.S, #0.0
        fcmne     p1.s, p0/z, z0.s, #0.0
        FCMNE     P0.D, P0/Z, Z3.D, #0.0
        fcmne     p0.d, p0/z, z31.d, #0.0
        FCMNE     P0.D, P0/Z, Z31.D, #0.0
+       fcmne     p0.h, p0/z, z0.h, z0.h
+       FCMNE     P0.H, P0/Z, Z0.H, Z0.H
+       fcmne     p1.h, p0/z, z0.h, z0.h
+       FCMNE     P1.H, P0/Z, Z0.H, Z0.H
+       fcmne     p15.h, p0/z, z0.h, z0.h
+       FCMNE     P15.H, P0/Z, Z0.H, Z0.H
+       fcmne     p0.h, p2/z, z0.h, z0.h
+       FCMNE     P0.H, P2/Z, Z0.H, Z0.H
+       fcmne     p0.h, p7/z, z0.h, z0.h
+       FCMNE     P0.H, P7/Z, Z0.H, Z0.H
+       fcmne     p0.h, p0/z, z3.h, z0.h
+       FCMNE     P0.H, P0/Z, Z3.H, Z0.H
+       fcmne     p0.h, p0/z, z31.h, z0.h
+       FCMNE     P0.H, P0/Z, Z31.H, Z0.H
+       fcmne     p0.h, p0/z, z0.h, z4.h
+       FCMNE     P0.H, P0/Z, Z0.H, Z4.H
+       fcmne     p0.h, p0/z, z0.h, z31.h
+       FCMNE     P0.H, P0/Z, Z0.H, Z31.H
        fcmne     p0.s, p0/z, z0.s, z0.s
        FCMNE     P0.S, P0/Z, Z0.S, Z0.S
        fcmne     p1.s, p0/z, z0.s, z0.s
        FCMNE     P0.D, P0/Z, Z0.D, Z4.D
        fcmne     p0.d, p0/z, z0.d, z31.d
        FCMNE     P0.D, P0/Z, Z0.D, Z31.D
+       fcmuo     p0.h, p0/z, z0.h, z0.h
+       FCMUO     P0.H, P0/Z, Z0.H, Z0.H
+       fcmuo     p1.h, p0/z, z0.h, z0.h
+       FCMUO     P1.H, P0/Z, Z0.H, Z0.H
+       fcmuo     p15.h, p0/z, z0.h, z0.h
+       FCMUO     P15.H, P0/Z, Z0.H, Z0.H
+       fcmuo     p0.h, p2/z, z0.h, z0.h
+       FCMUO     P0.H, P2/Z, Z0.H, Z0.H
+       fcmuo     p0.h, p7/z, z0.h, z0.h
+       FCMUO     P0.H, P7/Z, Z0.H, Z0.H
+       fcmuo     p0.h, p0/z, z3.h, z0.h
+       FCMUO     P0.H, P0/Z, Z3.H, Z0.H
+       fcmuo     p0.h, p0/z, z31.h, z0.h
+       FCMUO     P0.H, P0/Z, Z31.H, Z0.H
+       fcmuo     p0.h, p0/z, z0.h, z4.h
+       FCMUO     P0.H, P0/Z, Z0.H, Z4.H
+       fcmuo     p0.h, p0/z, z0.h, z31.h
+       FCMUO     P0.H, P0/Z, Z0.H, Z31.H
        fcmuo     p0.s, p0/z, z0.s, z0.s
        FCMUO     P0.S, P0/Z, Z0.S, Z0.S
        fcmuo     p1.s, p0/z, z0.s, z0.s
        FCMUO     P0.D, P0/Z, Z0.D, Z4.D
        fcmuo     p0.d, p0/z, z0.d, z31.d
        FCMUO     P0.D, P0/Z, Z0.D, Z31.D
+       fcpy      z0.h, p0/m, #2.0000000000
+       FCPY      Z0.H, P0/M, #2.0000000000
+       fcpy      z1.h, p0/m, #2.0000000000
+       FCPY      Z1.H, P0/M, #2.0000000000
+       fcpy      z31.h, p0/m, #2.0000000000
+       FCPY      Z31.H, P0/M, #2.0000000000
+       fcpy      z0.h, p2/m, #2.0000000000
+       FCPY      Z0.H, P2/M, #2.0000000000
+       fcpy      z0.h, p15/m, #2.0000000000
+       FCPY      Z0.H, P15/M, #2.0000000000
+       fcpy      z0.h, p0/m, #16.0000000000
+       FCPY      Z0.H, P0/M, #16.0000000000
+       fcpy      z0.h, p0/m, #0.1875000000
+       FCPY      Z0.H, P0/M, #0.1875000000
+       fcpy      z0.h, p0/m, #1.9375000000
+       FCPY      Z0.H, P0/M, #1.9375000000
+       fcpy      z0.h, p0/m, #-3.0000000000
+       FCPY      Z0.H, P0/M, #-3.0000000000
+       fcpy      z0.h, p0/m, #-0.1250000000
+       FCPY      Z0.H, P0/M, #-0.1250000000
+       fcpy      z0.h, p0/m, #-1.9375000000
+       FCPY      Z0.H, P0/M, #-1.9375000000
        fcpy      z0.s, p0/m, #2.0000000000
        FCPY      Z0.S, P0/M, #2.0000000000
        fcpy      z1.s, p0/m, #2.0000000000
        FCVT      Z0.D, P0/M, Z3.S
        fcvt      z0.d, p0/m, z31.s
        FCVT      Z0.D, P0/M, Z31.S
+       fcvtzs    z0.h, p0/m, z0.h
+       FCVTZS    Z0.H, P0/M, Z0.H
+       fcvtzs    z1.h, p0/m, z0.h
+       FCVTZS    Z1.H, P0/M, Z0.H
+       fcvtzs    z31.h, p0/m, z0.h
+       FCVTZS    Z31.H, P0/M, Z0.H
+       fcvtzs    z0.h, p2/m, z0.h
+       FCVTZS    Z0.H, P2/M, Z0.H
+       fcvtzs    z0.h, p7/m, z0.h
+       FCVTZS    Z0.H, P7/M, Z0.H
+       fcvtzs    z0.h, p0/m, z3.h
+       FCVTZS    Z0.H, P0/M, Z3.H
+       fcvtzs    z0.h, p0/m, z31.h
+       FCVTZS    Z0.H, P0/M, Z31.H
+       fcvtzs    z0.s, p0/m, z0.h
+       FCVTZS    Z0.S, P0/M, Z0.H
+       fcvtzs    z1.s, p0/m, z0.h
+       FCVTZS    Z1.S, P0/M, Z0.H
+       fcvtzs    z31.s, p0/m, z0.h
+       FCVTZS    Z31.S, P0/M, Z0.H
+       fcvtzs    z0.s, p2/m, z0.h
+       FCVTZS    Z0.S, P2/M, Z0.H
+       fcvtzs    z0.s, p7/m, z0.h
+       FCVTZS    Z0.S, P7/M, Z0.H
+       fcvtzs    z0.s, p0/m, z3.h
+       FCVTZS    Z0.S, P0/M, Z3.H
+       fcvtzs    z0.s, p0/m, z31.h
+       FCVTZS    Z0.S, P0/M, Z31.H
+       fcvtzs    z0.d, p0/m, z0.h
+       FCVTZS    Z0.D, P0/M, Z0.H
+       fcvtzs    z1.d, p0/m, z0.h
+       FCVTZS    Z1.D, P0/M, Z0.H
+       fcvtzs    z31.d, p0/m, z0.h
+       FCVTZS    Z31.D, P0/M, Z0.H
+       fcvtzs    z0.d, p2/m, z0.h
+       FCVTZS    Z0.D, P2/M, Z0.H
+       fcvtzs    z0.d, p7/m, z0.h
+       FCVTZS    Z0.D, P7/M, Z0.H
+       fcvtzs    z0.d, p0/m, z3.h
+       FCVTZS    Z0.D, P0/M, Z3.H
+       fcvtzs    z0.d, p0/m, z31.h
+       FCVTZS    Z0.D, P0/M, Z31.H
        fcvtzs    z0.s, p0/m, z0.s
        FCVTZS    Z0.S, P0/M, Z0.S
        fcvtzs    z1.s, p0/m, z0.s
        FCVTZS    Z0.D, P0/M, Z3.D
        fcvtzs    z0.d, p0/m, z31.d
        FCVTZS    Z0.D, P0/M, Z31.D
+       fcvtzu    z0.h, p0/m, z0.h
+       FCVTZU    Z0.H, P0/M, Z0.H
+       fcvtzu    z1.h, p0/m, z0.h
+       FCVTZU    Z1.H, P0/M, Z0.H
+       fcvtzu    z31.h, p0/m, z0.h
+       FCVTZU    Z31.H, P0/M, Z0.H
+       fcvtzu    z0.h, p2/m, z0.h
+       FCVTZU    Z0.H, P2/M, Z0.H
+       fcvtzu    z0.h, p7/m, z0.h
+       FCVTZU    Z0.H, P7/M, Z0.H
+       fcvtzu    z0.h, p0/m, z3.h
+       FCVTZU    Z0.H, P0/M, Z3.H
+       fcvtzu    z0.h, p0/m, z31.h
+       FCVTZU    Z0.H, P0/M, Z31.H
+       fcvtzu    z0.s, p0/m, z0.h
+       FCVTZU    Z0.S, P0/M, Z0.H
+       fcvtzu    z1.s, p0/m, z0.h
+       FCVTZU    Z1.S, P0/M, Z0.H
+       fcvtzu    z31.s, p0/m, z0.h
+       FCVTZU    Z31.S, P0/M, Z0.H
+       fcvtzu    z0.s, p2/m, z0.h
+       FCVTZU    Z0.S, P2/M, Z0.H
+       fcvtzu    z0.s, p7/m, z0.h
+       FCVTZU    Z0.S, P7/M, Z0.H
+       fcvtzu    z0.s, p0/m, z3.h
+       FCVTZU    Z0.S, P0/M, Z3.H
+       fcvtzu    z0.s, p0/m, z31.h
+       FCVTZU    Z0.S, P0/M, Z31.H
+       fcvtzu    z0.d, p0/m, z0.h
+       FCVTZU    Z0.D, P0/M, Z0.H
+       fcvtzu    z1.d, p0/m, z0.h
+       FCVTZU    Z1.D, P0/M, Z0.H
+       fcvtzu    z31.d, p0/m, z0.h
+       FCVTZU    Z31.D, P0/M, Z0.H
+       fcvtzu    z0.d, p2/m, z0.h
+       FCVTZU    Z0.D, P2/M, Z0.H
+       fcvtzu    z0.d, p7/m, z0.h
+       FCVTZU    Z0.D, P7/M, Z0.H
+       fcvtzu    z0.d, p0/m, z3.h
+       FCVTZU    Z0.D, P0/M, Z3.H
+       fcvtzu    z0.d, p0/m, z31.h
+       FCVTZU    Z0.D, P0/M, Z31.H
        fcvtzu    z0.s, p0/m, z0.s
        FCVTZU    Z0.S, P0/M, Z0.S
        fcvtzu    z1.s, p0/m, z0.s
        FCVTZU    Z0.D, P0/M, Z3.D
        fcvtzu    z0.d, p0/m, z31.d
        FCVTZU    Z0.D, P0/M, Z31.D
+       fdiv      z0.h, p0/m, z0.h, z0.h
+       FDIV      Z0.H, P0/M, Z0.H, Z0.H
+       fdiv      z1.h, p0/m, z1.h, z0.h
+       FDIV      Z1.H, P0/M, Z1.H, Z0.H
+       fdiv      z31.h, p0/m, z31.h, z0.h
+       FDIV      Z31.H, P0/M, Z31.H, Z0.H
+       fdiv      z0.h, p2/m, z0.h, z0.h
+       FDIV      Z0.H, P2/M, Z0.H, Z0.H
+       fdiv      z0.h, p7/m, z0.h, z0.h
+       FDIV      Z0.H, P7/M, Z0.H, Z0.H
+       fdiv      z3.h, p0/m, z3.h, z0.h
+       FDIV      Z3.H, P0/M, Z3.H, Z0.H
+       fdiv      z0.h, p0/m, z0.h, z4.h
+       FDIV      Z0.H, P0/M, Z0.H, Z4.H
+       fdiv      z0.h, p0/m, z0.h, z31.h
+       FDIV      Z0.H, P0/M, Z0.H, Z31.H
        fdiv      z0.s, p0/m, z0.s, z0.s
        FDIV      Z0.S, P0/M, Z0.S, Z0.S
        fdiv      z1.s, p0/m, z1.s, z0.s
        FDIV      Z0.D, P0/M, Z0.D, Z4.D
        fdiv      z0.d, p0/m, z0.d, z31.d
        FDIV      Z0.D, P0/M, Z0.D, Z31.D
+       fdivr     z0.h, p0/m, z0.h, z0.h
+       FDIVR     Z0.H, P0/M, Z0.H, Z0.H
+       fdivr     z1.h, p0/m, z1.h, z0.h
+       FDIVR     Z1.H, P0/M, Z1.H, Z0.H
+       fdivr     z31.h, p0/m, z31.h, z0.h
+       FDIVR     Z31.H, P0/M, Z31.H, Z0.H
+       fdivr     z0.h, p2/m, z0.h, z0.h
+       FDIVR     Z0.H, P2/M, Z0.H, Z0.H
+       fdivr     z0.h, p7/m, z0.h, z0.h
+       FDIVR     Z0.H, P7/M, Z0.H, Z0.H
+       fdivr     z3.h, p0/m, z3.h, z0.h
+       FDIVR     Z3.H, P0/M, Z3.H, Z0.H
+       fdivr     z0.h, p0/m, z0.h, z4.h
+       FDIVR     Z0.H, P0/M, Z0.H, Z4.H
+       fdivr     z0.h, p0/m, z0.h, z31.h
+       FDIVR     Z0.H, P0/M, Z0.H, Z31.H
        fdivr     z0.s, p0/m, z0.s, z0.s
        FDIVR     Z0.S, P0/M, Z0.S, Z0.S
        fdivr     z1.s, p0/m, z1.s, z0.s
        FDIVR     Z0.D, P0/M, Z0.D, Z4.D
        fdivr     z0.d, p0/m, z0.d, z31.d
        FDIVR     Z0.D, P0/M, Z0.D, Z31.D
+       fdup      z0.h, #2.0000000000
+       FDUP      Z0.H, #2.0000000000
+       fdup      z1.h, #2.0000000000
+       FDUP      Z1.H, #2.0000000000
+       fdup      z31.h, #2.0000000000
+       FDUP      Z31.H, #2.0000000000
+       fdup      z0.h, #16.0000000000
+       FDUP      Z0.H, #16.0000000000
+       fdup      z0.h, #0.1875000000
+       FDUP      Z0.H, #0.1875000000
+       fdup      z0.h, #1.9375000000
+       FDUP      Z0.H, #1.9375000000
+       fdup      z0.h, #-3.0000000000
+       FDUP      Z0.H, #-3.0000000000
+       fdup      z0.h, #-0.1250000000
+       FDUP      Z0.H, #-0.1250000000
+       fdup      z0.h, #-1.9375000000
+       FDUP      Z0.H, #-1.9375000000
        fdup      z0.s, #2.0000000000
        FDUP      Z0.S, #2.0000000000
        fdup      z1.s, #2.0000000000
        FDUP      Z0.D, #-0.1250000000
        fdup      z0.d, #-1.9375000000
        FDUP      Z0.D, #-1.9375000000
+       fexpa     z0.h, z0.h
+       FEXPA     Z0.H, Z0.H
+       fexpa     z1.h, z0.h
+       FEXPA     Z1.H, Z0.H
+       fexpa     z31.h, z0.h
+       FEXPA     Z31.H, Z0.H
+       fexpa     z0.h, z2.h
+       FEXPA     Z0.H, Z2.H
+       fexpa     z0.h, z31.h
+       FEXPA     Z0.H, Z31.H
        fexpa     z0.s, z0.s
        FEXPA     Z0.S, Z0.S
        fexpa     z1.s, z0.s
        FEXPA     Z0.D, Z2.D
        fexpa     z0.d, z31.d
        FEXPA     Z0.D, Z31.D
+       fmad      z0.h, p0/m, z0.h, z0.h
+       FMAD      Z0.H, P0/M, Z0.H, Z0.H
+       fmad      z1.h, p0/m, z0.h, z0.h
+       FMAD      Z1.H, P0/M, Z0.H, Z0.H
+       fmad      z31.h, p0/m, z0.h, z0.h
+       FMAD      Z31.H, P0/M, Z0.H, Z0.H
+       fmad      z0.h, p2/m, z0.h, z0.h
+       FMAD      Z0.H, P2/M, Z0.H, Z0.H
+       fmad      z0.h, p7/m, z0.h, z0.h
+       FMAD      Z0.H, P7/M, Z0.H, Z0.H
+       fmad      z0.h, p0/m, z3.h, z0.h
+       FMAD      Z0.H, P0/M, Z3.H, Z0.H
+       fmad      z0.h, p0/m, z31.h, z0.h
+       FMAD      Z0.H, P0/M, Z31.H, Z0.H
+       fmad      z0.h, p0/m, z0.h, z4.h
+       FMAD      Z0.H, P0/M, Z0.H, Z4.H
+       fmad      z0.h, p0/m, z0.h, z31.h
+       FMAD      Z0.H, P0/M, Z0.H, Z31.H
        fmad      z0.s, p0/m, z0.s, z0.s
        FMAD      Z0.S, P0/M, Z0.S, Z0.S
        fmad      z1.s, p0/m, z0.s, z0.s
        FMAD      Z0.D, P0/M, Z0.D, Z4.D
        fmad      z0.d, p0/m, z0.d, z31.d
        FMAD      Z0.D, P0/M, Z0.D, Z31.D
+       fmax      z0.h, p0/m, z0.h, z0.h
+       FMAX      Z0.H, P0/M, Z0.H, Z0.H
+       fmax      z1.h, p0/m, z1.h, z0.h
+       FMAX      Z1.H, P0/M, Z1.H, Z0.H
+       fmax      z31.h, p0/m, z31.h, z0.h
+       FMAX      Z31.H, P0/M, Z31.H, Z0.H
+       fmax      z0.h, p2/m, z0.h, z0.h
+       FMAX      Z0.H, P2/M, Z0.H, Z0.H
+       fmax      z0.h, p7/m, z0.h, z0.h
+       FMAX      Z0.H, P7/M, Z0.H, Z0.H
+       fmax      z3.h, p0/m, z3.h, z0.h
+       FMAX      Z3.H, P0/M, Z3.H, Z0.H
+       fmax      z0.h, p0/m, z0.h, z4.h
+       FMAX      Z0.H, P0/M, Z0.H, Z4.H
+       fmax      z0.h, p0/m, z0.h, z31.h
+       FMAX      Z0.H, P0/M, Z0.H, Z31.H
        fmax      z0.s, p0/m, z0.s, z0.s
        FMAX      Z0.S, P0/M, Z0.S, Z0.S
        fmax      z1.s, p0/m, z1.s, z0.s
        FMAX      Z0.D, P0/M, Z0.D, Z4.D
        fmax      z0.d, p0/m, z0.d, z31.d
        FMAX      Z0.D, P0/M, Z0.D, Z31.D
+       fmax      z0.h, p0/m, z0.h, #0.0
+       FMAX      Z0.H, P0/M, Z0.H, #0.0
+       fmax      z0.h, p0/m, z0.h, #0.00000
+       fmax      z0.h, p0/m, z0.h, #0.0000000000e+00
+       fmax      z1.h, p0/m, z1.h, #0.0
+       FMAX      Z1.H, P0/M, Z1.H, #0.0
+       fmax      z1.h, p0/m, z1.h, #0.00000
+       fmax      z1.h, p0/m, z1.h, #0.0000000000e+00
+       fmax      z31.h, p0/m, z31.h, #0.0
+       FMAX      Z31.H, P0/M, Z31.H, #0.0
+       fmax      z31.h, p0/m, z31.h, #0.00000
+       fmax      z31.h, p0/m, z31.h, #0.0000000000e+00
+       fmax      z0.h, p2/m, z0.h, #0.0
+       FMAX      Z0.H, P2/M, Z0.H, #0.0
+       fmax      z0.h, p2/m, z0.h, #0.00000
+       fmax      z0.h, p2/m, z0.h, #0.0000000000e+00
+       fmax      z0.h, p7/m, z0.h, #0.0
+       FMAX      Z0.H, P7/M, Z0.H, #0.0
+       fmax      z0.h, p7/m, z0.h, #0.00000
+       fmax      z0.h, p7/m, z0.h, #0.0000000000e+00
+       fmax      z3.h, p0/m, z3.h, #0.0
+       FMAX      Z3.H, P0/M, Z3.H, #0.0
+       fmax      z3.h, p0/m, z3.h, #0.00000
+       fmax      z3.h, p0/m, z3.h, #0.0000000000e+00
+       fmax      z0.h, p0/m, z0.h, #1.0
+       FMAX      Z0.H, P0/M, Z0.H, #1.0
+       fmax      z0.h, p0/m, z0.h, #1.00000
+       fmax      z0.h, p0/m, z0.h, #1.0000000000e+00
        fmax      z0.s, p0/m, z0.s, #0.0
        FMAX      Z0.S, P0/M, Z0.S, #0.0
        fmax      z0.s, p0/m, z0.s, #0.00000
        FMAX      Z0.D, P0/M, Z0.D, #1.0
        fmax      z0.d, p0/m, z0.d, #1.00000
        fmax      z0.d, p0/m, z0.d, #1.0000000000e+00
+       fmaxnm    z0.h, p0/m, z0.h, z0.h
+       FMAXNM    Z0.H, P0/M, Z0.H, Z0.H
+       fmaxnm    z1.h, p0/m, z1.h, z0.h
+       FMAXNM    Z1.H, P0/M, Z1.H, Z0.H
+       fmaxnm    z31.h, p0/m, z31.h, z0.h
+       FMAXNM    Z31.H, P0/M, Z31.H, Z0.H
+       fmaxnm    z0.h, p2/m, z0.h, z0.h
+       FMAXNM    Z0.H, P2/M, Z0.H, Z0.H
+       fmaxnm    z0.h, p7/m, z0.h, z0.h
+       FMAXNM    Z0.H, P7/M, Z0.H, Z0.H
+       fmaxnm    z3.h, p0/m, z3.h, z0.h
+       FMAXNM    Z3.H, P0/M, Z3.H, Z0.H
+       fmaxnm    z0.h, p0/m, z0.h, z4.h
+       FMAXNM    Z0.H, P0/M, Z0.H, Z4.H
+       fmaxnm    z0.h, p0/m, z0.h, z31.h
+       FMAXNM    Z0.H, P0/M, Z0.H, Z31.H
        fmaxnm    z0.s, p0/m, z0.s, z0.s
        FMAXNM    Z0.S, P0/M, Z0.S, Z0.S
        fmaxnm    z1.s, p0/m, z1.s, z0.s
        FMAXNM    Z0.D, P0/M, Z0.D, Z4.D
        fmaxnm    z0.d, p0/m, z0.d, z31.d
        FMAXNM    Z0.D, P0/M, Z0.D, Z31.D
+       fmaxnm    z0.h, p0/m, z0.h, #0.0
+       FMAXNM    Z0.H, P0/M, Z0.H, #0.0
+       fmaxnm    z0.h, p0/m, z0.h, #0.00000
+       fmaxnm    z0.h, p0/m, z0.h, #0.0000000000e+00
+       fmaxnm    z1.h, p0/m, z1.h, #0.0
+       FMAXNM    Z1.H, P0/M, Z1.H, #0.0
+       fmaxnm    z1.h, p0/m, z1.h, #0.00000
+       fmaxnm    z1.h, p0/m, z1.h, #0.0000000000e+00
+       fmaxnm    z31.h, p0/m, z31.h, #0.0
+       FMAXNM    Z31.H, P0/M, Z31.H, #0.0
+       fmaxnm    z31.h, p0/m, z31.h, #0.00000
+       fmaxnm    z31.h, p0/m, z31.h, #0.0000000000e+00
+       fmaxnm    z0.h, p2/m, z0.h, #0.0
+       FMAXNM    Z0.H, P2/M, Z0.H, #0.0
+       fmaxnm    z0.h, p2/m, z0.h, #0.00000
+       fmaxnm    z0.h, p2/m, z0.h, #0.0000000000e+00
+       fmaxnm    z0.h, p7/m, z0.h, #0.0
+       FMAXNM    Z0.H, P7/M, Z0.H, #0.0
+       fmaxnm    z0.h, p7/m, z0.h, #0.00000
+       fmaxnm    z0.h, p7/m, z0.h, #0.0000000000e+00
+       fmaxnm    z3.h, p0/m, z3.h, #0.0
+       FMAXNM    Z3.H, P0/M, Z3.H, #0.0
+       fmaxnm    z3.h, p0/m, z3.h, #0.00000
+       fmaxnm    z3.h, p0/m, z3.h, #0.0000000000e+00
+       fmaxnm    z0.h, p0/m, z0.h, #1.0
+       FMAXNM    Z0.H, P0/M, Z0.H, #1.0
+       fmaxnm    z0.h, p0/m, z0.h, #1.00000
+       fmaxnm    z0.h, p0/m, z0.h, #1.0000000000e+00
        fmaxnm    z0.s, p0/m, z0.s, #0.0
        FMAXNM    Z0.S, P0/M, Z0.S, #0.0
        fmaxnm    z0.s, p0/m, z0.s, #0.00000
        FMAXNM    Z0.D, P0/M, Z0.D, #1.0
        fmaxnm    z0.d, p0/m, z0.d, #1.00000
        fmaxnm    z0.d, p0/m, z0.d, #1.0000000000e+00
+       fmaxnmv   h0, p0, z0.h
+       FMAXNMV   H0, P0, Z0.H
+       fmaxnmv   h1, p0, z0.h
+       FMAXNMV   H1, P0, Z0.H
+       fmaxnmv   h31, p0, z0.h
+       FMAXNMV   H31, P0, Z0.H
+       fmaxnmv   h0, p2, z0.h
+       FMAXNMV   H0, P2, Z0.H
+       fmaxnmv   h0, p7, z0.h
+       FMAXNMV   H0, P7, Z0.H
+       fmaxnmv   h0, p0, z3.h
+       FMAXNMV   H0, P0, Z3.H
+       fmaxnmv   h0, p0, z31.h
+       FMAXNMV   H0, P0, Z31.H
        fmaxnmv   s0, p0, z0.s
        FMAXNMV   S0, P0, Z0.S
        fmaxnmv   s1, p0, z0.s
        FMAXNMV   D0, P0, Z3.D
        fmaxnmv   d0, p0, z31.d
        FMAXNMV   D0, P0, Z31.D
+       fmaxv     h0, p0, z0.h
+       FMAXV     H0, P0, Z0.H
+       fmaxv     h1, p0, z0.h
+       FMAXV     H1, P0, Z0.H
+       fmaxv     h31, p0, z0.h
+       FMAXV     H31, P0, Z0.H
+       fmaxv     h0, p2, z0.h
+       FMAXV     H0, P2, Z0.H
+       fmaxv     h0, p7, z0.h
+       FMAXV     H0, P7, Z0.H
+       fmaxv     h0, p0, z3.h
+       FMAXV     H0, P0, Z3.H
+       fmaxv     h0, p0, z31.h
+       FMAXV     H0, P0, Z31.H
        fmaxv     s0, p0, z0.s
        FMAXV     S0, P0, Z0.S
        fmaxv     s1, p0, z0.s
        FMAXV     D0, P0, Z3.D
        fmaxv     d0, p0, z31.d
        FMAXV     D0, P0, Z31.D
+       fmin      z0.h, p0/m, z0.h, z0.h
+       FMIN      Z0.H, P0/M, Z0.H, Z0.H
+       fmin      z1.h, p0/m, z1.h, z0.h
+       FMIN      Z1.H, P0/M, Z1.H, Z0.H
+       fmin      z31.h, p0/m, z31.h, z0.h
+       FMIN      Z31.H, P0/M, Z31.H, Z0.H
+       fmin      z0.h, p2/m, z0.h, z0.h
+       FMIN      Z0.H, P2/M, Z0.H, Z0.H
+       fmin      z0.h, p7/m, z0.h, z0.h
+       FMIN      Z0.H, P7/M, Z0.H, Z0.H
+       fmin      z3.h, p0/m, z3.h, z0.h
+       FMIN      Z3.H, P0/M, Z3.H, Z0.H
+       fmin      z0.h, p0/m, z0.h, z4.h
+       FMIN      Z0.H, P0/M, Z0.H, Z4.H
+       fmin      z0.h, p0/m, z0.h, z31.h
+       FMIN      Z0.H, P0/M, Z0.H, Z31.H
        fmin      z0.s, p0/m, z0.s, z0.s
        FMIN      Z0.S, P0/M, Z0.S, Z0.S
        fmin      z1.s, p0/m, z1.s, z0.s
        FMIN      Z0.D, P0/M, Z0.D, Z4.D
        fmin      z0.d, p0/m, z0.d, z31.d
        FMIN      Z0.D, P0/M, Z0.D, Z31.D
+       fmin      z0.h, p0/m, z0.h, #0.0
+       FMIN      Z0.H, P0/M, Z0.H, #0.0
+       fmin      z0.h, p0/m, z0.h, #0.00000
+       fmin      z0.h, p0/m, z0.h, #0.0000000000e+00
+       fmin      z1.h, p0/m, z1.h, #0.0
+       FMIN      Z1.H, P0/M, Z1.H, #0.0
+       fmin      z1.h, p0/m, z1.h, #0.00000
+       fmin      z1.h, p0/m, z1.h, #0.0000000000e+00
+       fmin      z31.h, p0/m, z31.h, #0.0
+       FMIN      Z31.H, P0/M, Z31.H, #0.0
+       fmin      z31.h, p0/m, z31.h, #0.00000
+       fmin      z31.h, p0/m, z31.h, #0.0000000000e+00
+       fmin      z0.h, p2/m, z0.h, #0.0
+       FMIN      Z0.H, P2/M, Z0.H, #0.0
+       fmin      z0.h, p2/m, z0.h, #0.00000
+       fmin      z0.h, p2/m, z0.h, #0.0000000000e+00
+       fmin      z0.h, p7/m, z0.h, #0.0
+       FMIN      Z0.H, P7/M, Z0.H, #0.0
+       fmin      z0.h, p7/m, z0.h, #0.00000
+       fmin      z0.h, p7/m, z0.h, #0.0000000000e+00
+       fmin      z3.h, p0/m, z3.h, #0.0
+       FMIN      Z3.H, P0/M, Z3.H, #0.0
+       fmin      z3.h, p0/m, z3.h, #0.00000
+       fmin      z3.h, p0/m, z3.h, #0.0000000000e+00
+       fmin      z0.h, p0/m, z0.h, #1.0
+       FMIN      Z0.H, P0/M, Z0.H, #1.0
+       fmin      z0.h, p0/m, z0.h, #1.00000
+       fmin      z0.h, p0/m, z0.h, #1.0000000000e+00
        fmin      z0.s, p0/m, z0.s, #0.0
        FMIN      Z0.S, P0/M, Z0.S, #0.0
        fmin      z0.s, p0/m, z0.s, #0.00000
        FMIN      Z0.D, P0/M, Z0.D, #1.0
        fmin      z0.d, p0/m, z0.d, #1.00000
        fmin      z0.d, p0/m, z0.d, #1.0000000000e+00
+       fminnm    z0.h, p0/m, z0.h, z0.h
+       FMINNM    Z0.H, P0/M, Z0.H, Z0.H
+       fminnm    z1.h, p0/m, z1.h, z0.h
+       FMINNM    Z1.H, P0/M, Z1.H, Z0.H
+       fminnm    z31.h, p0/m, z31.h, z0.h
+       FMINNM    Z31.H, P0/M, Z31.H, Z0.H
+       fminnm    z0.h, p2/m, z0.h, z0.h
+       FMINNM    Z0.H, P2/M, Z0.H, Z0.H
+       fminnm    z0.h, p7/m, z0.h, z0.h
+       FMINNM    Z0.H, P7/M, Z0.H, Z0.H
+       fminnm    z3.h, p0/m, z3.h, z0.h
+       FMINNM    Z3.H, P0/M, Z3.H, Z0.H
+       fminnm    z0.h, p0/m, z0.h, z4.h
+       FMINNM    Z0.H, P0/M, Z0.H, Z4.H
+       fminnm    z0.h, p0/m, z0.h, z31.h
+       FMINNM    Z0.H, P0/M, Z0.H, Z31.H
        fminnm    z0.s, p0/m, z0.s, z0.s
        FMINNM    Z0.S, P0/M, Z0.S, Z0.S
        fminnm    z1.s, p0/m, z1.s, z0.s
        FMINNM    Z0.D, P0/M, Z0.D, Z4.D
        fminnm    z0.d, p0/m, z0.d, z31.d
        FMINNM    Z0.D, P0/M, Z0.D, Z31.D
+       fminnm    z0.h, p0/m, z0.h, #0.0
+       FMINNM    Z0.H, P0/M, Z0.H, #0.0
+       fminnm    z0.h, p0/m, z0.h, #0.00000
+       fminnm    z0.h, p0/m, z0.h, #0.0000000000e+00
+       fminnm    z1.h, p0/m, z1.h, #0.0
+       FMINNM    Z1.H, P0/M, Z1.H, #0.0
+       fminnm    z1.h, p0/m, z1.h, #0.00000
+       fminnm    z1.h, p0/m, z1.h, #0.0000000000e+00
+       fminnm    z31.h, p0/m, z31.h, #0.0
+       FMINNM    Z31.H, P0/M, Z31.H, #0.0
+       fminnm    z31.h, p0/m, z31.h, #0.00000
+       fminnm    z31.h, p0/m, z31.h, #0.0000000000e+00
+       fminnm    z0.h, p2/m, z0.h, #0.0
+       FMINNM    Z0.H, P2/M, Z0.H, #0.0
+       fminnm    z0.h, p2/m, z0.h, #0.00000
+       fminnm    z0.h, p2/m, z0.h, #0.0000000000e+00
+       fminnm    z0.h, p7/m, z0.h, #0.0
+       FMINNM    Z0.H, P7/M, Z0.H, #0.0
+       fminnm    z0.h, p7/m, z0.h, #0.00000
+       fminnm    z0.h, p7/m, z0.h, #0.0000000000e+00
+       fminnm    z3.h, p0/m, z3.h, #0.0
+       FMINNM    Z3.H, P0/M, Z3.H, #0.0
+       fminnm    z3.h, p0/m, z3.h, #0.00000
+       fminnm    z3.h, p0/m, z3.h, #0.0000000000e+00
+       fminnm    z0.h, p0/m, z0.h, #1.0
+       FMINNM    Z0.H, P0/M, Z0.H, #1.0
+       fminnm    z0.h, p0/m, z0.h, #1.00000
+       fminnm    z0.h, p0/m, z0.h, #1.0000000000e+00
        fminnm    z0.s, p0/m, z0.s, #0.0
        FMINNM    Z0.S, P0/M, Z0.S, #0.0
        fminnm    z0.s, p0/m, z0.s, #0.00000
        FMINNM    Z0.D, P0/M, Z0.D, #1.0
        fminnm    z0.d, p0/m, z0.d, #1.00000
        fminnm    z0.d, p0/m, z0.d, #1.0000000000e+00
+       fminnmv   h0, p0, z0.h
+       FMINNMV   h0, P0, Z0.H
+       fminnmv   h1, p0, z0.h
+       FMINNMV   h1, P0, Z0.H
+       fminnmv   h31, p0, z0.h
+       FMINNMV   h31, P0, Z0.H
+       fminnmv   h0, p2, z0.h
+       FMINNMV   h0, P2, Z0.H
+       fminnmv   h0, p7, z0.h
+       FMINNMV   h0, P7, Z0.H
+       fminnmv   h0, p0, z3.h
+       FMINNMV   h0, P0, Z3.H
+       fminnmv   h0, p0, z31.h
+       FMINNMV   h0, P0, Z31.H
        fminnmv   s0, p0, z0.s
        FMINNMV   S0, P0, Z0.S
        fminnmv   s1, p0, z0.s
        FMINNMV   D0, P0, Z3.D
        fminnmv   d0, p0, z31.d
        FMINNMV   D0, P0, Z31.D
+       fminv     h0, p0, z0.h
+       FMINV     H0, P0, Z0.H
+       fminv     h1, p0, z0.h
+       FMINV     H1, P0, Z0.H
+       fminv     h31, p0, z0.h
+       FMINV     H31, P0, Z0.H
+       fminv     h0, p2, z0.h
+       FMINV     H0, P2, Z0.H
+       fminv     h0, p7, z0.h
+       FMINV     H0, P7, Z0.H
+       fminv     h0, p0, z3.h
+       FMINV     H0, P0, Z3.H
+       fminv     h0, p0, z31.h
+       FMINV     H0, P0, Z31.H
        fminv     s0, p0, z0.s
        FMINV     S0, P0, Z0.S
        fminv     s1, p0, z0.s
        FMINV     D0, P0, Z3.D
        fminv     d0, p0, z31.d
        FMINV     D0, P0, Z31.D
+       fmla      z0.h, p0/m, z0.h, z0.h
+       FMLA      Z0.H, P0/M, Z0.H, Z0.H
+       fmla      z1.h, p0/m, z0.h, z0.h
+       FMLA      Z1.H, P0/M, Z0.H, Z0.H
+       fmla      z31.h, p0/m, z0.h, z0.h
+       FMLA      Z31.H, P0/M, Z0.H, Z0.H
+       fmla      z0.h, p2/m, z0.h, z0.h
+       FMLA      Z0.H, P2/M, Z0.H, Z0.H
+       fmla      z0.h, p7/m, z0.h, z0.h
+       FMLA      Z0.H, P7/M, Z0.H, Z0.H
+       fmla      z0.h, p0/m, z3.h, z0.h
+       FMLA      Z0.H, P0/M, Z3.H, Z0.H
+       fmla      z0.h, p0/m, z31.h, z0.h
+       FMLA      Z0.H, P0/M, Z31.H, Z0.H
+       fmla      z0.h, p0/m, z0.h, z4.h
+       FMLA      Z0.H, P0/M, Z0.H, Z4.H
+       fmla      z0.h, p0/m, z0.h, z31.h
+       FMLA      Z0.H, P0/M, Z0.H, Z31.H
        fmla      z0.s, p0/m, z0.s, z0.s
        FMLA      Z0.S, P0/M, Z0.S, Z0.S
        fmla      z1.s, p0/m, z0.s, z0.s
        FMLA      Z0.D, P0/M, Z0.D, Z4.D
        fmla      z0.d, p0/m, z0.d, z31.d
        FMLA      Z0.D, P0/M, Z0.D, Z31.D
+       fmla      z0.h, z0.h, z0.h[0]
+       FMLA      Z0.H, Z0.H, Z0.H[0]
+       fmla      z1.h, z0.h, z0.h[0]
+       FMLA      Z1.H, Z0.H, Z0.H[0]
+       fmla      z31.h, z0.h, z0.h[0]
+       FMLA      Z31.H, Z0.H, Z0.H[0]
+       fmla      z0.h, z2.h, z0.h[0]
+       FMLA      Z0.H, Z2.H, Z0.H[0]
+       fmla      z0.h, z31.h, z0.h[0]
+       FMLA      Z0.H, Z31.H, Z0.H[0]
+       fmla      z0.h, z0.h, z3.h[0]
+       FMLA      Z0.H, Z0.H, Z3.H[0]
+       fmla      z0.h, z0.h, z7.h[0]
+       FMLA      Z0.H, Z0.H, Z7.H[0]
+       fmla      z0.h, z0.h, z0.h[1]
+       FMLA      Z0.H, Z0.H, Z0.H[1]
+       fmla      z0.h, z0.h, z4.h[1]
+       FMLA      Z0.H, Z0.H, Z4.H[1]
+       fmla      z0.h, z0.h, z3.h[4]
+       FMLA      Z0.H, Z0.H, Z3.H[4]
+       fmla      z0.h, z0.h, z0.h[7]
+       FMLA      Z0.H, Z0.H, Z0.H[7]
+       fmla      z0.h, z0.h, z5.h[7]
+       FMLA      Z0.H, Z0.H, Z5.H[7]
+       fmla      z0.s, z0.s, z0.s[0]
+       FMLA      Z0.S, Z0.S, Z0.S[0]
+       fmla      z1.s, z0.s, z0.s[0]
+       FMLA      Z1.S, Z0.S, Z0.S[0]
+       fmla      z31.s, z0.s, z0.s[0]
+       FMLA      Z31.S, Z0.S, Z0.S[0]
+       fmla      z0.s, z2.s, z0.s[0]
+       FMLA      Z0.S, Z2.S, Z0.S[0]
+       fmla      z0.s, z31.s, z0.s[0]
+       FMLA      Z0.S, Z31.S, Z0.S[0]
+       fmla      z0.s, z0.s, z3.s[0]
+       FMLA      Z0.S, Z0.S, Z3.S[0]
+       fmla      z0.s, z0.s, z7.s[0]
+       FMLA      Z0.S, Z0.S, Z7.S[0]
+       fmla      z0.s, z0.s, z0.s[1]
+       FMLA      Z0.S, Z0.S, Z0.S[1]
+       fmla      z0.s, z0.s, z4.s[1]
+       FMLA      Z0.S, Z0.S, Z4.S[1]
+       fmla      z0.s, z0.s, z3.s[2]
+       FMLA      Z0.S, Z0.S, Z3.S[2]
+       fmla      z0.s, z0.s, z0.s[3]
+       FMLA      Z0.S, Z0.S, Z0.S[3]
+       fmla      z0.s, z0.s, z5.s[3]
+       FMLA      Z0.S, Z0.S, Z5.S[3]
+       fmla      z0.d, z0.d, z0.d[0]
+       FMLA      Z0.D, Z0.D, Z0.D[0]
+       fmla      z1.d, z0.d, z0.d[0]
+       FMLA      Z1.D, Z0.D, Z0.D[0]
+       fmla      z31.d, z0.d, z0.d[0]
+       FMLA      Z31.D, Z0.D, Z0.D[0]
+       fmla      z0.d, z2.d, z0.d[0]
+       FMLA      Z0.D, Z2.D, Z0.D[0]
+       fmla      z0.d, z31.d, z0.d[0]
+       FMLA      Z0.D, Z31.D, Z0.D[0]
+       fmla      z0.d, z0.d, z3.d[0]
+       FMLA      Z0.D, Z0.D, Z3.D[0]
+       fmla      z0.d, z0.d, z15.d[0]
+       FMLA      Z0.D, Z0.D, Z15.D[0]
+       fmla      z0.d, z0.d, z0.d[1]
+       FMLA      Z0.D, Z0.D, Z0.D[1]
+       fmla      z0.d, z0.d, z11.d[1]
+       FMLA      Z0.D, Z0.D, Z11.D[1]
+       fmls      z0.h, p0/m, z0.h, z0.h
+       FMLS      Z0.H, P0/M, Z0.H, Z0.H
+       fmls      z1.h, p0/m, z0.h, z0.h
+       FMLS      Z1.H, P0/M, Z0.H, Z0.H
+       fmls      z31.h, p0/m, z0.h, z0.h
+       FMLS      Z31.H, P0/M, Z0.H, Z0.H
+       fmls      z0.h, p2/m, z0.h, z0.h
+       FMLS      Z0.H, P2/M, Z0.H, Z0.H
+       fmls      z0.h, p7/m, z0.h, z0.h
+       FMLS      Z0.H, P7/M, Z0.H, Z0.H
+       fmls      z0.h, p0/m, z3.h, z0.h
+       FMLS      Z0.H, P0/M, Z3.H, Z0.H
+       fmls      z0.h, p0/m, z31.h, z0.h
+       FMLS      Z0.H, P0/M, Z31.H, Z0.H
+       fmls      z0.h, p0/m, z0.h, z4.h
+       FMLS      Z0.H, P0/M, Z0.H, Z4.H
+       fmls      z0.h, p0/m, z0.h, z31.h
+       FMLS      Z0.H, P0/M, Z0.H, Z31.H
        fmls      z0.s, p0/m, z0.s, z0.s
        FMLS      Z0.S, P0/M, Z0.S, Z0.S
        fmls      z1.s, p0/m, z0.s, z0.s
        FMLS      Z0.D, P0/M, Z0.D, Z4.D
        fmls      z0.d, p0/m, z0.d, z31.d
        FMLS      Z0.D, P0/M, Z0.D, Z31.D
+       fmls      z0.h, z0.h, z0.h[0]
+       FMLS      Z0.H, Z0.H, Z0.H[0]
+       fmls      z1.h, z0.h, z0.h[0]
+       FMLS      Z1.H, Z0.H, Z0.H[0]
+       fmls      z31.h, z0.h, z0.h[0]
+       FMLS      Z31.H, Z0.H, Z0.H[0]
+       fmls      z0.h, z2.h, z0.h[0]
+       FMLS      Z0.H, Z2.H, Z0.H[0]
+       fmls      z0.h, z31.h, z0.h[0]
+       FMLS      Z0.H, Z31.H, Z0.H[0]
+       fmls      z0.h, z0.h, z3.h[0]
+       FMLS      Z0.H, Z0.H, Z3.H[0]
+       fmls      z0.h, z0.h, z7.h[0]
+       FMLS      Z0.H, Z0.H, Z7.H[0]
+       fmls      z0.h, z0.h, z0.h[1]
+       FMLS      Z0.H, Z0.H, Z0.H[1]
+       fmls      z0.h, z0.h, z4.h[1]
+       FMLS      Z0.H, Z0.H, Z4.H[1]
+       fmls      z0.h, z0.h, z3.h[4]
+       FMLS      Z0.H, Z0.H, Z3.H[4]
+       fmls      z0.h, z0.h, z0.h[7]
+       FMLS      Z0.H, Z0.H, Z0.H[7]
+       fmls      z0.h, z0.h, z5.h[7]
+       FMLS      Z0.H, Z0.H, Z5.H[7]
+       fmls      z0.s, z0.s, z0.s[0]
+       FMLS      Z0.S, Z0.S, Z0.S[0]
+       fmls      z1.s, z0.s, z0.s[0]
+       FMLS      Z1.S, Z0.S, Z0.S[0]
+       fmls      z31.s, z0.s, z0.s[0]
+       FMLS      Z31.S, Z0.S, Z0.S[0]
+       fmls      z0.s, z2.s, z0.s[0]
+       FMLS      Z0.S, Z2.S, Z0.S[0]
+       fmls      z0.s, z31.s, z0.s[0]
+       FMLS      Z0.S, Z31.S, Z0.S[0]
+       fmls      z0.s, z0.s, z3.s[0]
+       FMLS      Z0.S, Z0.S, Z3.S[0]
+       fmls      z0.s, z0.s, z7.s[0]
+       FMLS      Z0.S, Z0.S, Z7.S[0]
+       fmls      z0.s, z0.s, z0.s[1]
+       FMLS      Z0.S, Z0.S, Z0.S[1]
+       fmls      z0.s, z0.s, z4.s[1]
+       FMLS      Z0.S, Z0.S, Z4.S[1]
+       fmls      z0.s, z0.s, z3.s[2]
+       FMLS      Z0.S, Z0.S, Z3.S[2]
+       fmls      z0.s, z0.s, z0.s[3]
+       FMLS      Z0.S, Z0.S, Z0.S[3]
+       fmls      z0.s, z0.s, z5.s[3]
+       FMLS      Z0.S, Z0.S, Z5.S[3]
+       fmls      z0.d, z0.d, z0.d[0]
+       FMLS      Z0.D, Z0.D, Z0.D[0]
+       fmls      z1.d, z0.d, z0.d[0]
+       FMLS      Z1.D, Z0.D, Z0.D[0]
+       fmls      z31.d, z0.d, z0.d[0]
+       FMLS      Z31.D, Z0.D, Z0.D[0]
+       fmls      z0.d, z2.d, z0.d[0]
+       FMLS      Z0.D, Z2.D, Z0.D[0]
+       fmls      z0.d, z31.d, z0.d[0]
+       FMLS      Z0.D, Z31.D, Z0.D[0]
+       fmls      z0.d, z0.d, z3.d[0]
+       FMLS      Z0.D, Z0.D, Z3.D[0]
+       fmls      z0.d, z0.d, z15.d[0]
+       FMLS      Z0.D, Z0.D, Z15.D[0]
+       fmls      z0.d, z0.d, z0.d[1]
+       FMLS      Z0.D, Z0.D, Z0.D[1]
+       fmls      z0.d, z0.d, z11.d[1]
+       FMLS      Z0.D, Z0.D, Z11.D[1]
+       fmsb      z0.h, p0/m, z0.h, z0.h
+       FMSB      Z0.H, P0/M, Z0.H, Z0.H
+       fmsb      z1.h, p0/m, z0.h, z0.h
+       FMSB      Z1.H, P0/M, Z0.H, Z0.H
+       fmsb      z31.h, p0/m, z0.h, z0.h
+       FMSB      Z31.H, P0/M, Z0.H, Z0.H
+       fmsb      z0.h, p2/m, z0.h, z0.h
+       FMSB      Z0.H, P2/M, Z0.H, Z0.H
+       fmsb      z0.h, p7/m, z0.h, z0.h
+       FMSB      Z0.H, P7/M, Z0.H, Z0.H
+       fmsb      z0.h, p0/m, z3.h, z0.h
+       FMSB      Z0.H, P0/M, Z3.H, Z0.H
+       fmsb      z0.h, p0/m, z31.h, z0.h
+       FMSB      Z0.H, P0/M, Z31.H, Z0.H
+       fmsb      z0.h, p0/m, z0.h, z4.h
+       FMSB      Z0.H, P0/M, Z0.H, Z4.H
+       fmsb      z0.h, p0/m, z0.h, z31.h
+       FMSB      Z0.H, P0/M, Z0.H, Z31.H
        fmsb      z0.s, p0/m, z0.s, z0.s
        FMSB      Z0.S, P0/M, Z0.S, Z0.S
        fmsb      z1.s, p0/m, z0.s, z0.s
        FMSB      Z0.D, P0/M, Z0.D, Z4.D
        fmsb      z0.d, p0/m, z0.d, z31.d
        FMSB      Z0.D, P0/M, Z0.D, Z31.D
+       fmul      z0.h, z0.h, z0.h
+       FMUL      Z0.H, Z0.H, Z0.H
+       fmul      z1.h, z0.h, z0.h
+       FMUL      Z1.H, Z0.H, Z0.H
+       fmul      z31.h, z0.h, z0.h
+       FMUL      Z31.H, Z0.H, Z0.H
+       fmul      z0.h, z2.h, z0.h
+       FMUL      Z0.H, Z2.H, Z0.H
+       fmul      z0.h, z31.h, z0.h
+       FMUL      Z0.H, Z31.H, Z0.H
+       fmul      z0.h, z0.h, z3.h
+       FMUL      Z0.H, Z0.H, Z3.H
+       fmul      z0.h, z0.h, z31.h
+       FMUL      Z0.H, Z0.H, Z31.H
        fmul      z0.s, z0.s, z0.s
        FMUL      Z0.S, Z0.S, Z0.S
        fmul      z1.s, z0.s, z0.s
        FMUL      Z0.D, Z0.D, Z3.D
        fmul      z0.d, z0.d, z31.d
        FMUL      Z0.D, Z0.D, Z31.D
+       fmul      z0.h, p0/m, z0.h, z0.h
+       FMUL      Z0.H, P0/M, Z0.H, Z0.H
+       fmul      z1.h, p0/m, z1.h, z0.h
+       FMUL      Z1.H, P0/M, Z1.H, Z0.H
+       fmul      z31.h, p0/m, z31.h, z0.h
+       FMUL      Z31.H, P0/M, Z31.H, Z0.H
+       fmul      z0.h, p2/m, z0.h, z0.h
+       FMUL      Z0.H, P2/M, Z0.H, Z0.H
+       fmul      z0.h, p7/m, z0.h, z0.h
+       FMUL      Z0.H, P7/M, Z0.H, Z0.H
+       fmul      z3.h, p0/m, z3.h, z0.h
+       FMUL      Z3.H, P0/M, Z3.H, Z0.H
+       fmul      z0.h, p0/m, z0.h, z4.h
+       FMUL      Z0.H, P0/M, Z0.H, Z4.H
+       fmul      z0.h, p0/m, z0.h, z31.h
+       FMUL      Z0.H, P0/M, Z0.H, Z31.H
        fmul      z0.s, p0/m, z0.s, z0.s
        FMUL      Z0.S, P0/M, Z0.S, Z0.S
        fmul      z1.s, p0/m, z1.s, z0.s
        FMUL      Z0.D, P0/M, Z0.D, Z4.D
        fmul      z0.d, p0/m, z0.d, z31.d
        FMUL      Z0.D, P0/M, Z0.D, Z31.D
+       fmul      z0.h, p0/m, z0.h, #0.5
+       FMUL      Z0.H, P0/M, Z0.H, #0.5
+       fmul      z0.h, p0/m, z0.h, #0.50000
+       fmul      z0.h, p0/m, z0.h, #5.0000000000e-01
+       fmul      z1.h, p0/m, z1.h, #0.5
+       FMUL      Z1.H, P0/M, Z1.H, #0.5
+       fmul      z1.h, p0/m, z1.h, #0.50000
+       fmul      z1.h, p0/m, z1.h, #5.0000000000e-01
+       fmul      z31.h, p0/m, z31.h, #0.5
+       FMUL      Z31.H, P0/M, Z31.H, #0.5
+       fmul      z31.h, p0/m, z31.h, #0.50000
+       fmul      z31.h, p0/m, z31.h, #5.0000000000e-01
+       fmul      z0.h, p2/m, z0.h, #0.5
+       FMUL      Z0.H, P2/M, Z0.H, #0.5
+       fmul      z0.h, p2/m, z0.h, #0.50000
+       fmul      z0.h, p2/m, z0.h, #5.0000000000e-01
+       fmul      z0.h, p7/m, z0.h, #0.5
+       FMUL      Z0.H, P7/M, Z0.H, #0.5
+       fmul      z0.h, p7/m, z0.h, #0.50000
+       fmul      z0.h, p7/m, z0.h, #5.0000000000e-01
+       fmul      z3.h, p0/m, z3.h, #0.5
+       FMUL      Z3.H, P0/M, Z3.H, #0.5
+       fmul      z3.h, p0/m, z3.h, #0.50000
+       fmul      z3.h, p0/m, z3.h, #5.0000000000e-01
+       fmul      z0.h, p0/m, z0.h, #2.0
+       FMUL      Z0.H, P0/M, Z0.H, #2.0
+       fmul      z0.h, p0/m, z0.h, #2.00000
+       fmul      z0.h, p0/m, z0.h, #2.0000000000e+00
        fmul      z0.s, p0/m, z0.s, #0.5
        FMUL      Z0.S, P0/M, Z0.S, #0.5
        fmul      z0.s, p0/m, z0.s, #0.50000
        FMUL      Z0.D, P0/M, Z0.D, #2.0
        fmul      z0.d, p0/m, z0.d, #2.00000
        fmul      z0.d, p0/m, z0.d, #2.0000000000e+00
+       fmul      z0.h, z0.h, z0.h[0]
+       FMUL      Z0.H, Z0.H, Z0.H[0]
+       fmul      z1.h, z0.h, z0.h[0]
+       FMUL      Z1.H, Z0.H, Z0.H[0]
+       fmul      z31.h, z0.h, z0.h[0]
+       FMUL      Z31.H, Z0.H, Z0.H[0]
+       fmul      z0.h, z2.h, z0.h[0]
+       FMUL      Z0.H, Z2.H, Z0.H[0]
+       fmul      z0.h, z31.h, z0.h[0]
+       FMUL      Z0.H, Z31.H, Z0.H[0]
+       fmul      z0.h, z0.h, z3.h[0]
+       FMUL      Z0.H, Z0.H, Z3.H[0]
+       fmul      z0.h, z0.h, z7.h[0]
+       FMUL      Z0.H, Z0.H, Z7.H[0]
+       fmul      z0.h, z0.h, z0.h[1]
+       FMUL      Z0.H, Z0.H, Z0.H[1]
+       fmul      z0.h, z0.h, z4.h[1]
+       FMUL      Z0.H, Z0.H, Z4.H[1]
+       fmul      z0.h, z0.h, z3.h[4]
+       FMUL      Z0.H, Z0.H, Z3.H[4]
+       fmul      z0.h, z0.h, z0.h[7]
+       FMUL      Z0.H, Z0.H, Z0.H[7]
+       fmul      z0.h, z0.h, z5.h[7]
+       FMUL      Z0.H, Z0.H, Z5.H[7]
+       fmul      z0.s, z0.s, z0.s[0]
+       FMUL      Z0.S, Z0.S, Z0.S[0]
+       fmul      z1.s, z0.s, z0.s[0]
+       FMUL      Z1.S, Z0.S, Z0.S[0]
+       fmul      z31.s, z0.s, z0.s[0]
+       FMUL      Z31.S, Z0.S, Z0.S[0]
+       fmul      z0.s, z2.s, z0.s[0]
+       FMUL      Z0.S, Z2.S, Z0.S[0]
+       fmul      z0.s, z31.s, z0.s[0]
+       FMUL      Z0.S, Z31.S, Z0.S[0]
+       fmul      z0.s, z0.s, z3.s[0]
+       FMUL      Z0.S, Z0.S, Z3.S[0]
+       fmul      z0.s, z0.s, z7.s[0]
+       FMUL      Z0.S, Z0.S, Z7.S[0]
+       fmul      z0.s, z0.s, z0.s[1]
+       FMUL      Z0.S, Z0.S, Z0.S[1]
+       fmul      z0.s, z0.s, z4.s[1]
+       FMUL      Z0.S, Z0.S, Z4.S[1]
+       fmul      z0.s, z0.s, z3.s[2]
+       FMUL      Z0.S, Z0.S, Z3.S[2]
+       fmul      z0.s, z0.s, z0.s[3]
+       FMUL      Z0.S, Z0.S, Z0.S[3]
+       fmul      z0.s, z0.s, z5.s[3]
+       FMUL      Z0.S, Z0.S, Z5.S[3]
+       fmul      z0.d, z0.d, z0.d[0]
+       FMUL      Z0.D, Z0.D, Z0.D[0]
+       fmul      z1.d, z0.d, z0.d[0]
+       FMUL      Z1.D, Z0.D, Z0.D[0]
+       fmul      z31.d, z0.d, z0.d[0]
+       FMUL      Z31.D, Z0.D, Z0.D[0]
+       fmul      z0.d, z2.d, z0.d[0]
+       FMUL      Z0.D, Z2.D, Z0.D[0]
+       fmul      z0.d, z31.d, z0.d[0]
+       FMUL      Z0.D, Z31.D, Z0.D[0]
+       fmul      z0.d, z0.d, z3.d[0]
+       FMUL      Z0.D, Z0.D, Z3.D[0]
+       fmul      z0.d, z0.d, z15.d[0]
+       FMUL      Z0.D, Z0.D, Z15.D[0]
+       fmul      z0.d, z0.d, z0.d[1]
+       FMUL      Z0.D, Z0.D, Z0.D[1]
+       fmul      z0.d, z0.d, z11.d[1]
+       FMUL      Z0.D, Z0.D, Z11.D[1]
+       fmulx     z0.h, p0/m, z0.h, z0.h
+       FMULX     Z0.H, P0/M, Z0.H, Z0.H
+       fmulx     z1.h, p0/m, z1.h, z0.h
+       FMULX     Z1.H, P0/M, Z1.H, Z0.H
+       fmulx     z31.h, p0/m, z31.h, z0.h
+       FMULX     Z31.H, P0/M, Z31.H, Z0.H
+       fmulx     z0.h, p2/m, z0.h, z0.h
+       FMULX     Z0.H, P2/M, Z0.H, Z0.H
+       fmulx     z0.h, p7/m, z0.h, z0.h
+       FMULX     Z0.H, P7/M, Z0.H, Z0.H
+       fmulx     z3.h, p0/m, z3.h, z0.h
+       FMULX     Z3.H, P0/M, Z3.H, Z0.H
+       fmulx     z0.h, p0/m, z0.h, z4.h
+       FMULX     Z0.H, P0/M, Z0.H, Z4.H
+       fmulx     z0.h, p0/m, z0.h, z31.h
+       FMULX     Z0.H, P0/M, Z0.H, Z31.H
        fmulx     z0.s, p0/m, z0.s, z0.s
        FMULX     Z0.S, P0/M, Z0.S, Z0.S
        fmulx     z1.s, p0/m, z1.s, z0.s
        FMULX     Z0.D, P0/M, Z0.D, Z4.D
        fmulx     z0.d, p0/m, z0.d, z31.d
        FMULX     Z0.D, P0/M, Z0.D, Z31.D
+       fneg      z0.h, p0/m, z0.h
+       FNEG      Z0.H, P0/M, Z0.H
+       fneg      z1.h, p0/m, z0.h
+       FNEG      Z1.H, P0/M, Z0.H
+       fneg      z31.h, p0/m, z0.h
+       FNEG      Z31.H, P0/M, Z0.H
+       fneg      z0.h, p2/m, z0.h
+       FNEG      Z0.H, P2/M, Z0.H
+       fneg      z0.h, p7/m, z0.h
+       FNEG      Z0.H, P7/M, Z0.H
+       fneg      z0.h, p0/m, z3.h
+       FNEG      Z0.H, P0/M, Z3.H
+       fneg      z0.h, p0/m, z31.h
+       FNEG      Z0.H, P0/M, Z31.H
        fneg      z0.s, p0/m, z0.s
        FNEG      Z0.S, P0/M, Z0.S
        fneg      z1.s, p0/m, z0.s
        FNEG      Z0.D, P0/M, Z3.D
        fneg      z0.d, p0/m, z31.d
        FNEG      Z0.D, P0/M, Z31.D
+       fnmad     z0.h, p0/m, z0.h, z0.h
+       FNMAD     Z0.H, P0/M, Z0.H, Z0.H
+       fnmad     z1.h, p0/m, z0.h, z0.h
+       FNMAD     Z1.H, P0/M, Z0.H, Z0.H
+       fnmad     z31.h, p0/m, z0.h, z0.h
+       FNMAD     Z31.H, P0/M, Z0.H, Z0.H
+       fnmad     z0.h, p2/m, z0.h, z0.h
+       FNMAD     Z0.H, P2/M, Z0.H, Z0.H
+       fnmad     z0.h, p7/m, z0.h, z0.h
+       FNMAD     Z0.H, P7/M, Z0.H, Z0.H
+       fnmad     z0.h, p0/m, z3.h, z0.h
+       FNMAD     Z0.H, P0/M, Z3.H, Z0.H
+       fnmad     z0.h, p0/m, z31.h, z0.h
+       FNMAD     Z0.H, P0/M, Z31.H, Z0.H
+       fnmad     z0.h, p0/m, z0.h, z4.h
+       FNMAD     Z0.H, P0/M, Z0.H, Z4.H
+       fnmad     z0.h, p0/m, z0.h, z31.h
+       FNMAD     Z0.H, P0/M, Z0.H, Z31.H
        fnmad     z0.s, p0/m, z0.s, z0.s
        FNMAD     Z0.S, P0/M, Z0.S, Z0.S
        fnmad     z1.s, p0/m, z0.s, z0.s
        FNMAD     Z0.D, P0/M, Z0.D, Z4.D
        fnmad     z0.d, p0/m, z0.d, z31.d
        FNMAD     Z0.D, P0/M, Z0.D, Z31.D
+       fnmla     z0.h, p0/m, z0.h, z0.h
+       FNMLA     Z0.H, P0/M, Z0.H, Z0.H
+       fnmla     z1.h, p0/m, z0.h, z0.h
+       FNMLA     Z1.H, P0/M, Z0.H, Z0.H
+       fnmla     z31.h, p0/m, z0.h, z0.h
+       FNMLA     Z31.H, P0/M, Z0.H, Z0.H
+       fnmla     z0.h, p2/m, z0.h, z0.h
+       FNMLA     Z0.H, P2/M, Z0.H, Z0.H
+       fnmla     z0.h, p7/m, z0.h, z0.h
+       FNMLA     Z0.H, P7/M, Z0.H, Z0.H
+       fnmla     z0.h, p0/m, z3.h, z0.h
+       FNMLA     Z0.H, P0/M, Z3.H, Z0.H
+       fnmla     z0.h, p0/m, z31.h, z0.h
+       FNMLA     Z0.H, P0/M, Z31.H, Z0.H
+       fnmla     z0.h, p0/m, z0.h, z4.h
+       FNMLA     Z0.H, P0/M, Z0.H, Z4.H
+       fnmla     z0.h, p0/m, z0.h, z31.h
+       FNMLA     Z0.H, P0/M, Z0.H, Z31.H
        fnmla     z0.s, p0/m, z0.s, z0.s
        FNMLA     Z0.S, P0/M, Z0.S, Z0.S
        fnmla     z1.s, p0/m, z0.s, z0.s
        FNMLA     Z0.D, P0/M, Z0.D, Z4.D
        fnmla     z0.d, p0/m, z0.d, z31.d
        FNMLA     Z0.D, P0/M, Z0.D, Z31.D
+       fnmls     z0.h, p0/m, z0.h, z0.h
+       FNMLS     Z0.H, P0/M, Z0.H, Z0.H
+       fnmls     z1.h, p0/m, z0.h, z0.h
+       FNMLS     Z1.H, P0/M, Z0.H, Z0.H
+       fnmls     z31.h, p0/m, z0.h, z0.h
+       FNMLS     Z31.H, P0/M, Z0.H, Z0.H
+       fnmls     z0.h, p2/m, z0.h, z0.h
+       FNMLS     Z0.H, P2/M, Z0.H, Z0.H
+       fnmls     z0.h, p7/m, z0.h, z0.h
+       FNMLS     Z0.H, P7/M, Z0.H, Z0.H
+       fnmls     z0.h, p0/m, z3.h, z0.h
+       FNMLS     Z0.H, P0/M, Z3.H, Z0.H
+       fnmls     z0.h, p0/m, z31.h, z0.h
+       FNMLS     Z0.H, P0/M, Z31.H, Z0.H
+       fnmls     z0.h, p0/m, z0.h, z4.h
+       FNMLS     Z0.H, P0/M, Z0.H, Z4.H
+       fnmls     z0.h, p0/m, z0.h, z31.h
+       FNMLS     Z0.H, P0/M, Z0.H, Z31.H
        fnmls     z0.s, p0/m, z0.s, z0.s
        FNMLS     Z0.S, P0/M, Z0.S, Z0.S
        fnmls     z1.s, p0/m, z0.s, z0.s
        FNMLS     Z0.D, P0/M, Z0.D, Z4.D
        fnmls     z0.d, p0/m, z0.d, z31.d
        FNMLS     Z0.D, P0/M, Z0.D, Z31.D
+       fnmsb     z0.h, p0/m, z0.h, z0.h
+       FNMSB     Z0.H, P0/M, Z0.H, Z0.H
+       fnmsb     z1.h, p0/m, z0.h, z0.h
+       FNMSB     Z1.H, P0/M, Z0.H, Z0.H
+       fnmsb     z31.h, p0/m, z0.h, z0.h
+       FNMSB     Z31.H, P0/M, Z0.H, Z0.H
+       fnmsb     z0.h, p2/m, z0.h, z0.h
+       FNMSB     Z0.H, P2/M, Z0.H, Z0.H
+       fnmsb     z0.h, p7/m, z0.h, z0.h
+       FNMSB     Z0.H, P7/M, Z0.H, Z0.H
+       fnmsb     z0.h, p0/m, z3.h, z0.h
+       FNMSB     Z0.H, P0/M, Z3.H, Z0.H
+       fnmsb     z0.h, p0/m, z31.h, z0.h
+       FNMSB     Z0.H, P0/M, Z31.H, Z0.H
+       fnmsb     z0.h, p0/m, z0.h, z4.h
+       FNMSB     Z0.H, P0/M, Z0.H, Z4.H
+       fnmsb     z0.h, p0/m, z0.h, z31.h
+       FNMSB     Z0.H, P0/M, Z0.H, Z31.H
        fnmsb     z0.s, p0/m, z0.s, z0.s
        FNMSB     Z0.S, P0/M, Z0.S, Z0.S
        fnmsb     z1.s, p0/m, z0.s, z0.s
        FNMSB     Z0.D, P0/M, Z0.D, Z4.D
        fnmsb     z0.d, p0/m, z0.d, z31.d
        FNMSB     Z0.D, P0/M, Z0.D, Z31.D
+       frecpe    z0.h, z0.h
+       FRECPE    Z0.H, Z0.H
+       frecpe    z1.h, z0.h
+       FRECPE    Z1.H, Z0.H
+       frecpe    z31.h, z0.h
+       FRECPE    Z31.H, Z0.H
+       frecpe    z0.h, z2.h
+       FRECPE    Z0.H, Z2.H
+       frecpe    z0.h, z31.h
+       FRECPE    Z0.H, Z31.H
        frecpe    z0.s, z0.s
        FRECPE    Z0.S, Z0.S
        frecpe    z1.s, z0.s
        FRECPE    Z0.D, Z2.D
        frecpe    z0.d, z31.d
        FRECPE    Z0.D, Z31.D
+       frecps    z0.h, z0.h, z0.h
+       FRECPS    Z0.H, Z0.H, Z0.H
+       frecps    z1.h, z0.h, z0.h
+       FRECPS    Z1.H, Z0.H, Z0.H
+       frecps    z31.h, z0.h, z0.h
+       FRECPS    Z31.H, Z0.H, Z0.H
+       frecps    z0.h, z2.h, z0.h
+       FRECPS    Z0.H, Z2.H, Z0.H
+       frecps    z0.h, z31.h, z0.h
+       FRECPS    Z0.H, Z31.H, Z0.H
+       frecps    z0.h, z0.h, z3.h
+       FRECPS    Z0.H, Z0.H, Z3.H
+       frecps    z0.h, z0.h, z31.h
+       FRECPS    Z0.H, Z0.H, Z31.H
        frecps    z0.s, z0.s, z0.s
        FRECPS    Z0.S, Z0.S, Z0.S
        frecps    z1.s, z0.s, z0.s
        FRECPS    Z0.D, Z0.D, Z3.D
        frecps    z0.d, z0.d, z31.d
        FRECPS    Z0.D, Z0.D, Z31.D
+       frecpx    z0.h, p0/m, z0.h
+       FRECPX    Z0.H, P0/M, Z0.H
+       frecpx    z1.h, p0/m, z0.h
+       FRECPX    Z1.H, P0/M, Z0.H
+       frecpx    z31.h, p0/m, z0.h
+       FRECPX    Z31.H, P0/M, Z0.H
+       frecpx    z0.h, p2/m, z0.h
+       FRECPX    Z0.H, P2/M, Z0.H
+       frecpx    z0.h, p7/m, z0.h
+       FRECPX    Z0.H, P7/M, Z0.H
+       frecpx    z0.h, p0/m, z3.h
+       FRECPX    Z0.H, P0/M, Z3.H
+       frecpx    z0.h, p0/m, z31.h
+       FRECPX    Z0.H, P0/M, Z31.H
        frecpx    z0.s, p0/m, z0.s
        FRECPX    Z0.S, P0/M, Z0.S
        frecpx    z1.s, p0/m, z0.s
        FRECPX    Z0.D, P0/M, Z3.D
        frecpx    z0.d, p0/m, z31.d
        FRECPX    Z0.D, P0/M, Z31.D
+       frinta    z0.h, p0/m, z0.h
+       FRINTA    Z0.H, P0/M, Z0.H
+       frinta    z1.h, p0/m, z0.h
+       FRINTA    Z1.H, P0/M, Z0.H
+       frinta    z31.h, p0/m, z0.h
+       FRINTA    Z31.H, P0/M, Z0.H
+       frinta    z0.h, p2/m, z0.h
+       FRINTA    Z0.H, P2/M, Z0.H
+       frinta    z0.h, p7/m, z0.h
+       FRINTA    Z0.H, P7/M, Z0.H
+       frinta    z0.h, p0/m, z3.h
+       FRINTA    Z0.H, P0/M, Z3.H
+       frinta    z0.h, p0/m, z31.h
+       FRINTA    Z0.H, P0/M, Z31.H
        frinta    z0.s, p0/m, z0.s
        FRINTA    Z0.S, P0/M, Z0.S
        frinta    z1.s, p0/m, z0.s
        FRINTA    Z0.D, P0/M, Z3.D
        frinta    z0.d, p0/m, z31.d
        FRINTA    Z0.D, P0/M, Z31.D
+       frinti    z0.h, p0/m, z0.h
+       FRINTI    Z0.H, P0/M, Z0.H
+       frinti    z1.h, p0/m, z0.h
+       FRINTI    Z1.H, P0/M, Z0.H
+       frinti    z31.h, p0/m, z0.h
+       FRINTI    Z31.H, P0/M, Z0.H
+       frinti    z0.h, p2/m, z0.h
+       FRINTI    Z0.H, P2/M, Z0.H
+       frinti    z0.h, p7/m, z0.h
+       FRINTI    Z0.H, P7/M, Z0.H
+       frinti    z0.h, p0/m, z3.h
+       FRINTI    Z0.H, P0/M, Z3.H
+       frinti    z0.h, p0/m, z31.h
+       FRINTI    Z0.H, P0/M, Z31.H
        frinti    z0.s, p0/m, z0.s
        FRINTI    Z0.S, P0/M, Z0.S
        frinti    z1.s, p0/m, z0.s
        FRINTI    Z0.D, P0/M, Z3.D
        frinti    z0.d, p0/m, z31.d
        FRINTI    Z0.D, P0/M, Z31.D
+       frintm    z0.h, p0/m, z0.h
+       FRINTM    Z0.H, P0/M, Z0.H
+       frintm    z1.h, p0/m, z0.h
+       FRINTM    Z1.H, P0/M, Z0.H
+       frintm    z31.h, p0/m, z0.h
+       FRINTM    Z31.H, P0/M, Z0.H
+       frintm    z0.h, p2/m, z0.h
+       FRINTM    Z0.H, P2/M, Z0.H
+       frintm    z0.h, p7/m, z0.h
+       FRINTM    Z0.H, P7/M, Z0.H
+       frintm    z0.h, p0/m, z3.h
+       FRINTM    Z0.H, P0/M, Z3.H
+       frintm    z0.h, p0/m, z31.h
+       FRINTM    Z0.H, P0/M, Z31.H
        frintm    z0.s, p0/m, z0.s
        FRINTM    Z0.S, P0/M, Z0.S
        frintm    z1.s, p0/m, z0.s
        FRINTM    Z0.D, P0/M, Z3.D
        frintm    z0.d, p0/m, z31.d
        FRINTM    Z0.D, P0/M, Z31.D
+       frintn    z0.h, p0/m, z0.h
+       FRINTN    Z0.H, P0/M, Z0.H
+       frintn    z1.h, p0/m, z0.h
+       FRINTN    Z1.H, P0/M, Z0.H
+       frintn    z31.h, p0/m, z0.h
+       FRINTN    Z31.H, P0/M, Z0.H
+       frintn    z0.h, p2/m, z0.h
+       FRINTN    Z0.H, P2/M, Z0.H
+       frintn    z0.h, p7/m, z0.h
+       FRINTN    Z0.H, P7/M, Z0.H
+       frintn    z0.h, p0/m, z3.h
+       FRINTN    Z0.H, P0/M, Z3.H
+       frintn    z0.h, p0/m, z31.h
+       FRINTN    Z0.H, P0/M, Z31.H
        frintn    z0.s, p0/m, z0.s
        FRINTN    Z0.S, P0/M, Z0.S
        frintn    z1.s, p0/m, z0.s
        FRINTN    Z0.D, P0/M, Z3.D
        frintn    z0.d, p0/m, z31.d
        FRINTN    Z0.D, P0/M, Z31.D
+       frintp    z0.h, p0/m, z0.h
+       FRINTP    Z0.H, P0/M, Z0.H
+       frintp    z1.h, p0/m, z0.h
+       FRINTP    Z1.H, P0/M, Z0.H
+       frintp    z31.h, p0/m, z0.h
+       FRINTP    Z31.H, P0/M, Z0.H
+       frintp    z0.h, p2/m, z0.h
+       FRINTP    Z0.H, P2/M, Z0.H
+       frintp    z0.h, p7/m, z0.h
+       FRINTP    Z0.H, P7/M, Z0.H
+       frintp    z0.h, p0/m, z3.h
+       FRINTP    Z0.H, P0/M, Z3.H
+       frintp    z0.h, p0/m, z31.h
+       FRINTP    Z0.H, P0/M, Z31.H
        frintp    z0.s, p0/m, z0.s
        FRINTP    Z0.S, P0/M, Z0.S
        frintp    z1.s, p0/m, z0.s
        FRINTP    Z0.D, P0/M, Z3.D
        frintp    z0.d, p0/m, z31.d
        FRINTP    Z0.D, P0/M, Z31.D
+       frintx    z0.h, p0/m, z0.h
+       FRINTX    Z0.H, P0/M, Z0.H
+       frintx    z1.h, p0/m, z0.h
+       FRINTX    Z1.H, P0/M, Z0.H
+       frintx    z31.h, p0/m, z0.h
+       FRINTX    Z31.H, P0/M, Z0.H
+       frintx    z0.h, p2/m, z0.h
+       FRINTX    Z0.H, P2/M, Z0.H
+       frintx    z0.h, p7/m, z0.h
+       FRINTX    Z0.H, P7/M, Z0.H
+       frintx    z0.h, p0/m, z3.h
+       FRINTX    Z0.H, P0/M, Z3.H
+       frintx    z0.h, p0/m, z31.h
+       FRINTX    Z0.H, P0/M, Z31.H
        frintx    z0.s, p0/m, z0.s
        FRINTX    Z0.S, P0/M, Z0.S
        frintx    z1.s, p0/m, z0.s
        FRINTX    Z0.D, P0/M, Z3.D
        frintx    z0.d, p0/m, z31.d
        FRINTX    Z0.D, P0/M, Z31.D
+       frintz    z0.h, p0/m, z0.h
+       FRINTZ    Z0.H, P0/M, Z0.H
+       frintz    z1.h, p0/m, z0.h
+       FRINTZ    Z1.H, P0/M, Z0.H
+       frintz    z31.h, p0/m, z0.h
+       FRINTZ    Z31.H, P0/M, Z0.H
+       frintz    z0.h, p2/m, z0.h
+       FRINTZ    Z0.H, P2/M, Z0.H
+       frintz    z0.h, p7/m, z0.h
+       FRINTZ    Z0.H, P7/M, Z0.H
+       frintz    z0.h, p0/m, z3.h
+       FRINTZ    Z0.H, P0/M, Z3.H
+       frintz    z0.h, p0/m, z31.h
+       FRINTZ    Z0.H, P0/M, Z31.H
        frintz    z0.s, p0/m, z0.s
        FRINTZ    Z0.S, P0/M, Z0.S
        frintz    z1.s, p0/m, z0.s
        FRINTZ    Z0.D, P0/M, Z3.D
        frintz    z0.d, p0/m, z31.d
        FRINTZ    Z0.D, P0/M, Z31.D
+       frsqrte   z0.h, z0.h
+       FRSQRTE   Z0.H, Z0.H
+       frsqrte   z1.h, z0.h
+       FRSQRTE   Z1.H, Z0.H
+       frsqrte   z31.h, z0.h
+       FRSQRTE   Z31.H, Z0.H
+       frsqrte   z0.h, z2.h
+       FRSQRTE   Z0.H, Z2.H
+       frsqrte   z0.h, z31.h
+       FRSQRTE   Z0.H, Z31.H
        frsqrte   z0.s, z0.s
        FRSQRTE   Z0.S, Z0.S
        frsqrte   z1.s, z0.s
        FRSQRTE   Z0.D, Z2.D
        frsqrte   z0.d, z31.d
        FRSQRTE   Z0.D, Z31.D
+       frsqrts   z0.h, z0.h, z0.h
+       FRSQRTS   Z0.H, Z0.H, Z0.H
+       frsqrts   z1.h, z0.h, z0.h
+       FRSQRTS   Z1.H, Z0.H, Z0.H
+       frsqrts   z31.h, z0.h, z0.h
+       FRSQRTS   Z31.H, Z0.H, Z0.H
+       frsqrts   z0.h, z2.h, z0.h
+       FRSQRTS   Z0.H, Z2.H, Z0.H
+       frsqrts   z0.h, z31.h, z0.h
+       FRSQRTS   Z0.H, Z31.H, Z0.H
+       frsqrts   z0.h, z0.h, z3.h
+       FRSQRTS   Z0.H, Z0.H, Z3.H
+       frsqrts   z0.h, z0.h, z31.h
+       FRSQRTS   Z0.H, Z0.H, Z31.H
        frsqrts   z0.s, z0.s, z0.s
        FRSQRTS   Z0.S, Z0.S, Z0.S
        frsqrts   z1.s, z0.s, z0.s
        FRSQRTS   Z0.D, Z0.D, Z3.D
        frsqrts   z0.d, z0.d, z31.d
        FRSQRTS   Z0.D, Z0.D, Z31.D
+       fscale    z0.h, p0/m, z0.h, z0.h
+       FSCALE    Z0.H, P0/M, Z0.H, Z0.H
+       fscale    z1.h, p0/m, z1.h, z0.h
+       FSCALE    Z1.H, P0/M, Z1.H, Z0.H
+       fscale    z31.h, p0/m, z31.h, z0.h
+       FSCALE    Z31.H, P0/M, Z31.H, Z0.H
+       fscale    z0.h, p2/m, z0.h, z0.h
+       FSCALE    Z0.H, P2/M, Z0.H, Z0.H
+       fscale    z0.h, p7/m, z0.h, z0.h
+       FSCALE    Z0.H, P7/M, Z0.H, Z0.H
+       fscale    z3.h, p0/m, z3.h, z0.h
+       FSCALE    Z3.H, P0/M, Z3.H, Z0.H
+       fscale    z0.h, p0/m, z0.h, z4.h
+       FSCALE    Z0.H, P0/M, Z0.H, Z4.H
+       fscale    z0.h, p0/m, z0.h, z31.h
+       FSCALE    Z0.H, P0/M, Z0.H, Z31.H
        fscale    z0.s, p0/m, z0.s, z0.s
        FSCALE    Z0.S, P0/M, Z0.S, Z0.S
        fscale    z1.s, p0/m, z1.s, z0.s
        FSCALE    Z0.D, P0/M, Z0.D, Z4.D
        fscale    z0.d, p0/m, z0.d, z31.d
        FSCALE    Z0.D, P0/M, Z0.D, Z31.D
+       fsqrt     z0.h, p0/m, z0.h
+       FSQRT     Z0.H, P0/M, Z0.H
+       fsqrt     z1.h, p0/m, z0.h
+       FSQRT     Z1.H, P0/M, Z0.H
+       fsqrt     z31.h, p0/m, z0.h
+       FSQRT     Z31.H, P0/M, Z0.H
+       fsqrt     z0.h, p2/m, z0.h
+       FSQRT     Z0.H, P2/M, Z0.H
+       fsqrt     z0.h, p7/m, z0.h
+       FSQRT     Z0.H, P7/M, Z0.H
+       fsqrt     z0.h, p0/m, z3.h
+       FSQRT     Z0.H, P0/M, Z3.H
+       fsqrt     z0.h, p0/m, z31.h
+       FSQRT     Z0.H, P0/M, Z31.H
        fsqrt     z0.s, p0/m, z0.s
        FSQRT     Z0.S, P0/M, Z0.S
        fsqrt     z1.s, p0/m, z0.s
        FSQRT     Z0.D, P0/M, Z3.D
        fsqrt     z0.d, p0/m, z31.d
        FSQRT     Z0.D, P0/M, Z31.D
+       fsub      z0.h, z0.h, z0.h
+       FSUB      Z0.H, Z0.H, Z0.H
+       fsub      z1.h, z0.h, z0.h
+       FSUB      Z1.H, Z0.H, Z0.H
+       fsub      z31.h, z0.h, z0.h
+       FSUB      Z31.H, Z0.H, Z0.H
+       fsub      z0.h, z2.h, z0.h
+       FSUB      Z0.H, Z2.H, Z0.H
+       fsub      z0.h, z31.h, z0.h
+       FSUB      Z0.H, Z31.H, Z0.H
+       fsub      z0.h, z0.h, z3.h
+       FSUB      Z0.H, Z0.H, Z3.H
+       fsub      z0.h, z0.h, z31.h
+       FSUB      Z0.H, Z0.H, Z31.H
        fsub      z0.s, z0.s, z0.s
        FSUB      Z0.S, Z0.S, Z0.S
        fsub      z1.s, z0.s, z0.s
        FSUB      Z0.D, Z0.D, Z3.D
        fsub      z0.d, z0.d, z31.d
        FSUB      Z0.D, Z0.D, Z31.D
+       fsub      z0.h, p0/m, z0.h, z0.h
+       FSUB      Z0.H, P0/M, Z0.H, Z0.H
+       fsub      z1.h, p0/m, z1.h, z0.h
+       FSUB      Z1.H, P0/M, Z1.H, Z0.H
+       fsub      z31.h, p0/m, z31.h, z0.h
+       FSUB      Z31.H, P0/M, Z31.H, Z0.H
+       fsub      z0.h, p2/m, z0.h, z0.h
+       FSUB      Z0.H, P2/M, Z0.H, Z0.H
+       fsub      z0.h, p7/m, z0.h, z0.h
+       FSUB      Z0.H, P7/M, Z0.H, Z0.H
+       fsub      z3.h, p0/m, z3.h, z0.h
+       FSUB      Z3.H, P0/M, Z3.H, Z0.H
+       fsub      z0.h, p0/m, z0.h, z4.h
+       FSUB      Z0.H, P0/M, Z0.H, Z4.H
+       fsub      z0.h, p0/m, z0.h, z31.h
+       FSUB      Z0.H, P0/M, Z0.H, Z31.H
        fsub      z0.s, p0/m, z0.s, z0.s
        FSUB      Z0.S, P0/M, Z0.S, Z0.S
        fsub      z1.s, p0/m, z1.s, z0.s
        FSUB      Z0.D, P0/M, Z0.D, Z4.D
        fsub      z0.d, p0/m, z0.d, z31.d
        FSUB      Z0.D, P0/M, Z0.D, Z31.D
+       fsub      z0.h, p0/m, z0.h, #0.5
+       FSUB      Z0.H, P0/M, Z0.H, #0.5
+       fsub      z0.h, p0/m, z0.h, #0.50000
+       fsub      z0.h, p0/m, z0.h, #5.0000000000e-01
+       fsub      z1.h, p0/m, z1.h, #0.5
+       FSUB      Z1.H, P0/M, Z1.H, #0.5
+       fsub      z1.h, p0/m, z1.h, #0.50000
+       fsub      z1.h, p0/m, z1.h, #5.0000000000e-01
+       fsub      z31.h, p0/m, z31.h, #0.5
+       FSUB      Z31.H, P0/M, Z31.H, #0.5
+       fsub      z31.h, p0/m, z31.h, #0.50000
+       fsub      z31.h, p0/m, z31.h, #5.0000000000e-01
+       fsub      z0.h, p2/m, z0.h, #0.5
+       FSUB      Z0.H, P2/M, Z0.H, #0.5
+       fsub      z0.h, p2/m, z0.h, #0.50000
+       fsub      z0.h, p2/m, z0.h, #5.0000000000e-01
+       fsub      z0.h, p7/m, z0.h, #0.5
+       FSUB      Z0.H, P7/M, Z0.H, #0.5
+       fsub      z0.h, p7/m, z0.h, #0.50000
+       fsub      z0.h, p7/m, z0.h, #5.0000000000e-01
+       fsub      z3.h, p0/m, z3.h, #0.5
+       FSUB      Z3.H, P0/M, Z3.H, #0.5
+       fsub      z3.h, p0/m, z3.h, #0.50000
+       fsub      z3.h, p0/m, z3.h, #5.0000000000e-01
+       fsub      z0.h, p0/m, z0.h, #1.0
+       FSUB      Z0.H, P0/M, Z0.H, #1.0
+       fsub      z0.h, p0/m, z0.h, #1.00000
+       fsub      z0.h, p0/m, z0.h, #1.0000000000e+00
        fsub      z0.s, p0/m, z0.s, #0.5
        FSUB      Z0.S, P0/M, Z0.S, #0.5
        fsub      z0.s, p0/m, z0.s, #0.50000
        FSUB      Z0.D, P0/M, Z0.D, #1.0
        fsub      z0.d, p0/m, z0.d, #1.00000
        fsub      z0.d, p0/m, z0.d, #1.0000000000e+00
+       fsubr     z0.h, p0/m, z0.h, z0.h
+       FSUBR     Z0.H, P0/M, Z0.H, Z0.H
+       fsubr     z1.h, p0/m, z1.h, z0.h
+       FSUBR     Z1.H, P0/M, Z1.H, Z0.H
+       fsubr     z31.h, p0/m, z31.h, z0.h
+       FSUBR     Z31.H, P0/M, Z31.H, Z0.H
+       fsubr     z0.h, p2/m, z0.h, z0.h
+       FSUBR     Z0.H, P2/M, Z0.H, Z0.H
+       fsubr     z0.h, p7/m, z0.h, z0.h
+       FSUBR     Z0.H, P7/M, Z0.H, Z0.H
+       fsubr     z3.h, p0/m, z3.h, z0.h
+       FSUBR     Z3.H, P0/M, Z3.H, Z0.H
+       fsubr     z0.h, p0/m, z0.h, z4.h
+       FSUBR     Z0.H, P0/M, Z0.H, Z4.H
+       fsubr     z0.h, p0/m, z0.h, z31.h
+       FSUBR     Z0.H, P0/M, Z0.H, Z31.H
        fsubr     z0.s, p0/m, z0.s, z0.s
        FSUBR     Z0.S, P0/M, Z0.S, Z0.S
        fsubr     z1.s, p0/m, z1.s, z0.s
        FSUBR     Z0.D, P0/M, Z0.D, Z4.D
        fsubr     z0.d, p0/m, z0.d, z31.d
        FSUBR     Z0.D, P0/M, Z0.D, Z31.D
+       fsubr     z0.h, p0/m, z0.h, #0.5
+       FSUBR     Z0.H, P0/M, Z0.H, #0.5
+       fsubr     z0.h, p0/m, z0.h, #0.50000
+       fsubr     z0.h, p0/m, z0.h, #5.0000000000e-01
+       fsubr     z1.h, p0/m, z1.h, #0.5
+       FSUBR     Z1.H, P0/M, Z1.H, #0.5
+       fsubr     z1.h, p0/m, z1.h, #0.50000
+       fsubr     z1.h, p0/m, z1.h, #5.0000000000e-01
+       fsubr     z31.h, p0/m, z31.h, #0.5
+       FSUBR     Z31.H, P0/M, Z31.H, #0.5
+       fsubr     z31.h, p0/m, z31.h, #0.50000
+       fsubr     z31.h, p0/m, z31.h, #5.0000000000e-01
+       fsubr     z0.h, p2/m, z0.h, #0.5
+       FSUBR     Z0.H, P2/M, Z0.H, #0.5
+       fsubr     z0.h, p2/m, z0.h, #0.50000
+       fsubr     z0.h, p2/m, z0.h, #5.0000000000e-01
+       fsubr     z0.h, p7/m, z0.h, #0.5
+       FSUBR     Z0.H, P7/M, Z0.H, #0.5
+       fsubr     z0.h, p7/m, z0.h, #0.50000
+       fsubr     z0.h, p7/m, z0.h, #5.0000000000e-01
+       fsubr     z3.h, p0/m, z3.h, #0.5
+       FSUBR     Z3.H, P0/M, Z3.H, #0.5
+       fsubr     z3.h, p0/m, z3.h, #0.50000
+       fsubr     z3.h, p0/m, z3.h, #5.0000000000e-01
+       fsubr     z0.h, p0/m, z0.h, #1.0
+       FSUBR     Z0.H, P0/M, Z0.H, #1.0
+       fsubr     z0.h, p0/m, z0.h, #1.00000
+       fsubr     z0.h, p0/m, z0.h, #1.0000000000e+00
        fsubr     z0.s, p0/m, z0.s, #0.5
        FSUBR     Z0.S, P0/M, Z0.S, #0.5
        fsubr     z0.s, p0/m, z0.s, #0.50000
        FSUBR     Z0.D, P0/M, Z0.D, #1.0
        fsubr     z0.d, p0/m, z0.d, #1.00000
        fsubr     z0.d, p0/m, z0.d, #1.0000000000e+00
+       ftmad     z0.h, z0.h, z0.h, #0
+       FTMAD     Z0.H, Z0.H, Z0.H, #0
+       ftmad     z1.h, z1.h, z0.h, #0
+       FTMAD     Z1.H, Z1.H, Z0.H, #0
+       ftmad     z31.h, z31.h, z0.h, #0
+       FTMAD     Z31.H, Z31.H, Z0.H, #0
+       ftmad     z2.h, z2.h, z0.h, #0
+       FTMAD     Z2.H, Z2.H, Z0.H, #0
+       ftmad     z0.h, z0.h, z3.h, #0
+       FTMAD     Z0.H, Z0.H, Z3.H, #0
+       ftmad     z0.h, z0.h, z31.h, #0
+       FTMAD     Z0.H, Z0.H, Z31.H, #0
+       ftmad     z0.h, z0.h, z0.h, #3
+       FTMAD     Z0.H, Z0.H, Z0.H, #3
+       ftmad     z0.h, z0.h, z0.h, #4
+       FTMAD     Z0.H, Z0.H, Z0.H, #4
+       ftmad     z0.h, z0.h, z0.h, #5
+       FTMAD     Z0.H, Z0.H, Z0.H, #5
+       ftmad     z0.h, z0.h, z0.h, #7
+       FTMAD     Z0.H, Z0.H, Z0.H, #7
        ftmad     z0.s, z0.s, z0.s, #0
        FTMAD     Z0.S, Z0.S, Z0.S, #0
        ftmad     z1.s, z1.s, z0.s, #0
        FTMAD     Z0.D, Z0.D, Z0.D, #5
        ftmad     z0.d, z0.d, z0.d, #7
        FTMAD     Z0.D, Z0.D, Z0.D, #7
+       ftsmul    z0.h, z0.h, z0.h
+       FTSMUL    Z0.H, Z0.H, Z0.H
+       ftsmul    z1.h, z0.h, z0.h
+       FTSMUL    Z1.H, Z0.H, Z0.H
+       ftsmul    z31.h, z0.h, z0.h
+       FTSMUL    Z31.H, Z0.H, Z0.H
+       ftsmul    z0.h, z2.h, z0.h
+       FTSMUL    Z0.H, Z2.H, Z0.H
+       ftsmul    z0.h, z31.h, z0.h
+       FTSMUL    Z0.H, Z31.H, Z0.H
+       ftsmul    z0.h, z0.h, z3.h
+       FTSMUL    Z0.H, Z0.H, Z3.H
+       ftsmul    z0.h, z0.h, z31.h
+       FTSMUL    Z0.H, Z0.H, Z31.H
        ftsmul    z0.s, z0.s, z0.s
        FTSMUL    Z0.S, Z0.S, Z0.S
        ftsmul    z1.s, z0.s, z0.s
        FTSMUL    Z0.D, Z0.D, Z3.D
        ftsmul    z0.d, z0.d, z31.d
        FTSMUL    Z0.D, Z0.D, Z31.D
+       ftssel    z0.h, z0.h, z0.h
+       FTSSEL    Z0.H, Z0.H, Z0.H
+       ftssel    z1.h, z0.h, z0.h
+       FTSSEL    Z1.H, Z0.H, Z0.H
+       ftssel    z31.h, z0.h, z0.h
+       FTSSEL    Z31.H, Z0.H, Z0.H
+       ftssel    z0.h, z2.h, z0.h
+       FTSSEL    Z0.H, Z2.H, Z0.H
+       ftssel    z0.h, z31.h, z0.h
+       FTSSEL    Z0.H, Z31.H, Z0.H
+       ftssel    z0.h, z0.h, z3.h
+       FTSSEL    Z0.H, Z0.H, Z3.H
+       ftssel    z0.h, z0.h, z31.h
+       FTSSEL    Z0.H, Z0.H, Z31.H
        ftssel    z0.s, z0.s, z0.s
        FTSSEL    Z0.S, Z0.S, Z0.S
        ftssel    z1.s, z0.s, z0.s
        LD1RSW    {Z0.D}, P0/Z, [X0,#132]
        ld1rsw    {z0.d}, p0/z, [x0,#252]
        LD1RSW    {Z0.D}, P0/Z, [X0,#252]
+       ld1rqb    z0.b, p0/z, [x0,#0]
+       ld1rqb    {z0.b}, p0/z, [x0,#0]
+       LD1RQB    {Z0.B}, P0/Z, [X0,#0]
+       ld1rqb    {z0.b}, p0/z, [x0]
+       ld1rqb    z1.b, p0/z, [x0,#0]
+       ld1rqb    {z1.b}, p0/z, [x0,#0]
+       LD1RQB    {Z1.B}, P0/Z, [X0,#0]
+       ld1rqb    {z1.b}, p0/z, [x0]
+       ld1rqb    z31.b, p0/z, [x0,#0]
+       ld1rqb    {z31.b}, p0/z, [x0,#0]
+       LD1RQB    {Z31.B}, P0/Z, [X0,#0]
+       ld1rqb    {z31.b}, p0/z, [x0]
+       ld1rqb    {z0.b}, p2/z, [x0,#0]
+       LD1RQB    {Z0.B}, P2/Z, [X0,#0]
+       ld1rqb    {z0.b}, p2/z, [x0]
+       ld1rqb    {z0.b}, p7/z, [x0,#0]
+       LD1RQB    {Z0.B}, P7/Z, [X0,#0]
+       ld1rqb    {z0.b}, p7/z, [x0]
+       ld1rqb    {z0.b}, p0/z, [x3,#0]
+       LD1RQB    {Z0.B}, P0/Z, [X3,#0]
+       ld1rqb    {z0.b}, p0/z, [x3]
+       ld1rqb    {z0.b}, p0/z, [sp,#0]
+       LD1RQB    {Z0.B}, P0/Z, [SP,#0]
+       ld1rqb    {z0.b}, p0/z, [sp]
+       ld1rqb    {z0.b}, p0/z, [x0,#-128]
+       LD1RQB    {Z0.B}, P0/Z, [X0,#-128]
+       ld1rqb    {z0.b}, p0/z, [x0,#-16]
+       LD1RQB    {Z0.B}, P0/Z, [X0,#-16]
+       ld1rqb    {z0.b}, p0/z, [x0,#16]
+       LD1RQB    {Z0.B}, P0/Z, [X0,#16]
+       ld1rqb    {z0.b}, p0/z, [x0,#112]
+       LD1RQB    {Z0.B}, P0/Z, [X0,#112]
+       ld1rqb    z0.b, p0/z, [x0,x0]
+       ld1rqb    {z0.b}, p0/z, [x0,x0]
+       LD1RQB    {Z0.B}, P0/Z, [X0,X0]
+       ld1rqb    {z0.b}, p0/z, [x0,x0,lsl #0]
+       ld1rqb    z1.b, p0/z, [x0,x0]
+       ld1rqb    {z1.b}, p0/z, [x0,x0]
+       LD1RQB    {Z1.B}, P0/Z, [X0,X0]
+       ld1rqb    {z1.b}, p0/z, [x0,x0,lsl #0]
+       ld1rqb    z31.b, p0/z, [x0,x0]
+       ld1rqb    {z31.b}, p0/z, [x0,x0]
+       LD1RQB    {Z31.B}, P0/Z, [X0,X0]
+       ld1rqb    {z31.b}, p0/z, [x0,x0,lsl #0]
+       ld1rqb    {z0.b}, p2/z, [x0,x0]
+       LD1RQB    {Z0.B}, P2/Z, [X0,X0]
+       ld1rqb    {z0.b}, p2/z, [x0,x0,lsl #0]
+       ld1rqb    {z0.b}, p7/z, [x0,x0]
+       LD1RQB    {Z0.B}, P7/Z, [X0,X0]
+       ld1rqb    {z0.b}, p7/z, [x0,x0,lsl #0]
+       ld1rqb    {z0.b}, p0/z, [x3,x0]
+       LD1RQB    {Z0.B}, P0/Z, [X3,X0]
+       ld1rqb    {z0.b}, p0/z, [x3,x0,lsl #0]
+       ld1rqb    {z0.b}, p0/z, [sp,x0]
+       LD1RQB    {Z0.B}, P0/Z, [SP,X0]
+       ld1rqb    {z0.b}, p0/z, [sp,x0,lsl #0]
+       ld1rqb    {z0.b}, p0/z, [x0,x4]
+       LD1RQB    {Z0.B}, P0/Z, [X0,X4]
+       ld1rqb    {z0.b}, p0/z, [x0,x4,lsl #0]
+       ld1rqb    {z0.b}, p0/z, [x0,x30]
+       LD1RQB    {Z0.B}, P0/Z, [X0,X30]
+       ld1rqb    {z0.b}, p0/z, [x0,x30,lsl #0]
+       ld1rqd    z0.d, p0/z, [x0,#0]
+       ld1rqd    {z0.d}, p0/z, [x0,#0]
+       LD1RQD    {Z0.D}, P0/Z, [X0,#0]
+       ld1rqd    {z0.d}, p0/z, [x0]
+       ld1rqd    z1.d, p0/z, [x0,#0]
+       ld1rqd    {z1.d}, p0/z, [x0,#0]
+       LD1RQD    {Z1.D}, P0/Z, [X0,#0]
+       ld1rqd    {z1.d}, p0/z, [x0]
+       ld1rqd    z31.d, p0/z, [x0,#0]
+       ld1rqd    {z31.d}, p0/z, [x0,#0]
+       LD1RQD    {Z31.D}, P0/Z, [X0,#0]
+       ld1rqd    {z31.d}, p0/z, [x0]
+       ld1rqd    {z0.d}, p2/z, [x0,#0]
+       LD1RQD    {Z0.D}, P2/Z, [X0,#0]
+       ld1rqd    {z0.d}, p2/z, [x0]
+       ld1rqd    {z0.d}, p7/z, [x0,#0]
+       LD1RQD    {Z0.D}, P7/Z, [X0,#0]
+       ld1rqd    {z0.d}, p7/z, [x0]
+       ld1rqd    {z0.d}, p0/z, [x3,#0]
+       LD1RQD    {Z0.D}, P0/Z, [X3,#0]
+       ld1rqd    {z0.d}, p0/z, [x3]
+       ld1rqd    {z0.d}, p0/z, [sp,#0]
+       LD1RQD    {Z0.D}, P0/Z, [SP,#0]
+       ld1rqd    {z0.d}, p0/z, [sp]
+       ld1rqd    {z0.d}, p0/z, [x0,#-128]
+       LD1RQD    {Z0.D}, P0/Z, [X0,#-128]
+       ld1rqd    {z0.d}, p0/z, [x0,#-16]
+       LD1RQD    {Z0.D}, P0/Z, [X0,#-16]
+       ld1rqd    {z0.d}, p0/z, [x0,#16]
+       LD1RQD    {Z0.D}, P0/Z, [X0,#16]
+       ld1rqd    {z0.d}, p0/z, [x0,#112]
+       LD1RQD    {Z0.D}, P0/Z, [X0,#112]
+       ld1rqd    z0.d, p0/z, [x0,x0,lsl #3]
+       ld1rqd    {z0.d}, p0/z, [x0,x0,lsl #3]
+       LD1RQD    {Z0.D}, P0/Z, [X0,X0,LSL #3]
+       ld1rqd    z1.d, p0/z, [x0,x0,lsl #3]
+       ld1rqd    {z1.d}, p0/z, [x0,x0,lsl #3]
+       LD1RQD    {Z1.D}, P0/Z, [X0,X0,LSL #3]
+       ld1rqd    z31.d, p0/z, [x0,x0,lsl #3]
+       ld1rqd    {z31.d}, p0/z, [x0,x0,lsl #3]
+       LD1RQD    {Z31.D}, P0/Z, [X0,X0,LSL #3]
+       ld1rqd    {z0.d}, p2/z, [x0,x0,lsl #3]
+       LD1RQD    {Z0.D}, P2/Z, [X0,X0,LSL #3]
+       ld1rqd    {z0.d}, p7/z, [x0,x0,lsl #3]
+       LD1RQD    {Z0.D}, P7/Z, [X0,X0,LSL #3]
+       ld1rqd    {z0.d}, p0/z, [x3,x0,lsl #3]
+       LD1RQD    {Z0.D}, P0/Z, [X3,X0,LSL #3]
+       ld1rqd    {z0.d}, p0/z, [sp,x0,lsl #3]
+       LD1RQD    {Z0.D}, P0/Z, [SP,X0,LSL #3]
+       ld1rqd    {z0.d}, p0/z, [x0,x4,lsl #3]
+       LD1RQD    {Z0.D}, P0/Z, [X0,X4,LSL #3]
+       ld1rqd    {z0.d}, p0/z, [x0,x30,lsl #3]
+       LD1RQD    {Z0.D}, P0/Z, [X0,X30,LSL #3]
+       ld1rqh    z0.h, p0/z, [x0,#0]
+       ld1rqh    {z0.h}, p0/z, [x0,#0]
+       LD1RQH    {Z0.H}, P0/Z, [X0,#0]
+       ld1rqh    {z0.h}, p0/z, [x0]
+       ld1rqh    z1.h, p0/z, [x0,#0]
+       ld1rqh    {z1.h}, p0/z, [x0,#0]
+       LD1RQH    {Z1.H}, P0/Z, [X0,#0]
+       ld1rqh    {z1.h}, p0/z, [x0]
+       ld1rqh    z31.h, p0/z, [x0,#0]
+       ld1rqh    {z31.h}, p0/z, [x0,#0]
+       LD1RQH    {Z31.H}, P0/Z, [X0,#0]
+       ld1rqh    {z31.h}, p0/z, [x0]
+       ld1rqh    {z0.h}, p2/z, [x0,#0]
+       LD1RQH    {Z0.H}, P2/Z, [X0,#0]
+       ld1rqh    {z0.h}, p2/z, [x0]
+       ld1rqh    {z0.h}, p7/z, [x0,#0]
+       LD1RQH    {Z0.H}, P7/Z, [X0,#0]
+       ld1rqh    {z0.h}, p7/z, [x0]
+       ld1rqh    {z0.h}, p0/z, [x3,#0]
+       LD1RQH    {Z0.H}, P0/Z, [X3,#0]
+       ld1rqh    {z0.h}, p0/z, [x3]
+       ld1rqh    {z0.h}, p0/z, [sp,#0]
+       LD1RQH    {Z0.H}, P0/Z, [SP,#0]
+       ld1rqh    {z0.h}, p0/z, [sp]
+       ld1rqh    {z0.h}, p0/z, [x0,#-128]
+       LD1RQH    {Z0.H}, P0/Z, [X0,#-128]
+       ld1rqh    {z0.h}, p0/z, [x0,#-16]
+       LD1RQH    {Z0.H}, P0/Z, [X0,#-16]
+       ld1rqh    {z0.h}, p0/z, [x0,#16]
+       LD1RQH    {Z0.H}, P0/Z, [X0,#16]
+       ld1rqh    {z0.h}, p0/z, [x0,#112]
+       LD1RQH    {Z0.H}, P0/Z, [X0,#112]
+       ld1rqh    z0.h, p0/z, [x0,x0,lsl #1]
+       ld1rqh    {z0.h}, p0/z, [x0,x0,lsl #1]
+       LD1RQH    {Z0.H}, P0/Z, [X0,X0,LSL #1]
+       ld1rqh    z1.h, p0/z, [x0,x0,lsl #1]
+       ld1rqh    {z1.h}, p0/z, [x0,x0,lsl #1]
+       LD1RQH    {Z1.H}, P0/Z, [X0,X0,LSL #1]
+       ld1rqh    z31.h, p0/z, [x0,x0,lsl #1]
+       ld1rqh    {z31.h}, p0/z, [x0,x0,lsl #1]
+       LD1RQH    {Z31.H}, P0/Z, [X0,X0,LSL #1]
+       ld1rqh    {z0.h}, p2/z, [x0,x0,lsl #1]
+       LD1RQH    {Z0.H}, P2/Z, [X0,X0,LSL #1]
+       ld1rqh    {z0.h}, p7/z, [x0,x0,lsl #1]
+       LD1RQH    {Z0.H}, P7/Z, [X0,X0,LSL #1]
+       ld1rqh    {z0.h}, p0/z, [x3,x0,lsl #1]
+       LD1RQH    {Z0.H}, P0/Z, [X3,X0,LSL #1]
+       ld1rqh    {z0.h}, p0/z, [sp,x0,lsl #1]
+       LD1RQH    {Z0.H}, P0/Z, [SP,X0,LSL #1]
+       ld1rqh    {z0.h}, p0/z, [x0,x4,lsl #1]
+       LD1RQH    {Z0.H}, P0/Z, [X0,X4,LSL #1]
+       ld1rqh    {z0.h}, p0/z, [x0,x30,lsl #1]
+       LD1RQH    {Z0.H}, P0/Z, [X0,X30,LSL #1]
+       ld1rqw    z0.s, p0/z, [x0,#0]
+       ld1rqw    {z0.s}, p0/z, [x0,#0]
+       LD1RQW    {Z0.S}, P0/Z, [X0,#0]
+       ld1rqw    {z0.s}, p0/z, [x0]
+       ld1rqw    z1.s, p0/z, [x0,#0]
+       ld1rqw    {z1.s}, p0/z, [x0,#0]
+       LD1RQW    {Z1.S}, P0/Z, [X0,#0]
+       ld1rqw    {z1.s}, p0/z, [x0]
+       ld1rqw    z31.s, p0/z, [x0,#0]
+       ld1rqw    {z31.s}, p0/z, [x0,#0]
+       LD1RQW    {Z31.S}, P0/Z, [X0,#0]
+       ld1rqw    {z31.s}, p0/z, [x0]
+       ld1rqw    {z0.s}, p2/z, [x0,#0]
+       LD1RQW    {Z0.S}, P2/Z, [X0,#0]
+       ld1rqw    {z0.s}, p2/z, [x0]
+       ld1rqw    {z0.s}, p7/z, [x0,#0]
+       LD1RQW    {Z0.S}, P7/Z, [X0,#0]
+       ld1rqw    {z0.s}, p7/z, [x0]
+       ld1rqw    {z0.s}, p0/z, [x3,#0]
+       LD1RQW    {Z0.S}, P0/Z, [X3,#0]
+       ld1rqw    {z0.s}, p0/z, [x3]
+       ld1rqw    {z0.s}, p0/z, [sp,#0]
+       LD1RQW    {Z0.S}, P0/Z, [SP,#0]
+       ld1rqw    {z0.s}, p0/z, [sp]
+       ld1rqw    {z0.s}, p0/z, [x0,#-128]
+       LD1RQW    {Z0.S}, P0/Z, [X0,#-128]
+       ld1rqw    {z0.s}, p0/z, [x0,#-16]
+       LD1RQW    {Z0.S}, P0/Z, [X0,#-16]
+       ld1rqw    {z0.s}, p0/z, [x0,#16]
+       LD1RQW    {Z0.S}, P0/Z, [X0,#16]
+       ld1rqw    {z0.s}, p0/z, [x0,#112]
+       LD1RQW    {Z0.S}, P0/Z, [X0,#112]
+       ld1rqw    z0.s, p0/z, [x0,x0,lsl #2]
+       ld1rqw    {z0.s}, p0/z, [x0,x0,lsl #2]
+       LD1RQW    {Z0.S}, P0/Z, [X0,X0,LSL #2]
+       ld1rqw    z1.s, p0/z, [x0,x0,lsl #2]
+       ld1rqw    {z1.s}, p0/z, [x0,x0,lsl #2]
+       LD1RQW    {Z1.S}, P0/Z, [X0,X0,LSL #2]
+       ld1rqw    z31.s, p0/z, [x0,x0,lsl #2]
+       ld1rqw    {z31.s}, p0/z, [x0,x0,lsl #2]
+       LD1RQW    {Z31.S}, P0/Z, [X0,X0,LSL #2]
+       ld1rqw    {z0.s}, p2/z, [x0,x0,lsl #2]
+       LD1RQW    {Z0.S}, P2/Z, [X0,X0,LSL #2]
+       ld1rqw    {z0.s}, p7/z, [x0,x0,lsl #2]
+       LD1RQW    {Z0.S}, P7/Z, [X0,X0,LSL #2]
+       ld1rqw    {z0.s}, p0/z, [x3,x0,lsl #2]
+       LD1RQW    {Z0.S}, P0/Z, [X3,X0,LSL #2]
+       ld1rqw    {z0.s}, p0/z, [sp,x0,lsl #2]
+       LD1RQW    {Z0.S}, P0/Z, [SP,X0,LSL #2]
+       ld1rqw    {z0.s}, p0/z, [x0,x4,lsl #2]
+       LD1RQW    {Z0.S}, P0/Z, [X0,X4,LSL #2]
+       ld1rqw    {z0.s}, p0/z, [x0,x30,lsl #2]
+       LD1RQW    {Z0.S}, P0/Z, [X0,X30,LSL #2]
        ld1rw     z0.s, p0/z, [x0,#0]
        ld1rw     {z0.s}, p0/z, [x0,#0]
        LD1RW     {Z0.S}, P0/Z, [X0,#0]
        SADDV     D0, P0, Z3.S
        saddv     d0, p0, z31.s
        SADDV     D0, P0, Z31.S
+       scvtf     z0.h, p0/m, z0.h
+       SCVTF     Z0.H, P0/M, Z0.H
+       scvtf     z1.h, p0/m, z0.h
+       SCVTF     Z1.H, P0/M, Z0.H
+       scvtf     z31.h, p0/m, z0.h
+       SCVTF     Z31.H, P0/M, Z0.H
+       scvtf     z0.h, p2/m, z0.h
+       SCVTF     Z0.H, P2/M, Z0.H
+       scvtf     z0.h, p7/m, z0.h
+       SCVTF     Z0.H, P7/M, Z0.H
+       scvtf     z0.h, p0/m, z3.h
+       SCVTF     Z0.H, P0/M, Z3.H
+       scvtf     z0.h, p0/m, z31.h
+       SCVTF     Z0.H, P0/M, Z31.H
+       scvtf     z0.h, p0/m, z0.s
+       SCVTF     Z0.H, P0/M, Z0.S
+       scvtf     z1.h, p0/m, z0.s
+       SCVTF     Z1.H, P0/M, Z0.S
+       scvtf     z31.h, p0/m, z0.s
+       SCVTF     Z31.H, P0/M, Z0.S
+       scvtf     z0.h, p2/m, z0.s
+       SCVTF     Z0.H, P2/M, Z0.S
+       scvtf     z0.h, p7/m, z0.s
+       SCVTF     Z0.H, P7/M, Z0.S
+       scvtf     z0.h, p0/m, z3.s
+       SCVTF     Z0.H, P0/M, Z3.S
+       scvtf     z0.h, p0/m, z31.s
+       SCVTF     Z0.H, P0/M, Z31.S
        scvtf     z0.s, p0/m, z0.s
        SCVTF     Z0.S, P0/M, Z0.S
        scvtf     z1.s, p0/m, z0.s
        SCVTF     Z0.D, P0/M, Z3.S
        scvtf     z0.d, p0/m, z31.s
        SCVTF     Z0.D, P0/M, Z31.S
+       scvtf     z0.h, p0/m, z0.d
+       SCVTF     Z0.H, P0/M, Z0.D
+       scvtf     z1.h, p0/m, z0.d
+       SCVTF     Z1.H, P0/M, Z0.D
+       scvtf     z31.h, p0/m, z0.d
+       SCVTF     Z31.H, P0/M, Z0.D
+       scvtf     z0.h, p2/m, z0.d
+       SCVTF     Z0.H, P2/M, Z0.D
+       scvtf     z0.h, p7/m, z0.d
+       SCVTF     Z0.H, P7/M, Z0.D
+       scvtf     z0.h, p0/m, z3.d
+       SCVTF     Z0.H, P0/M, Z3.D
+       scvtf     z0.h, p0/m, z31.d
+       SCVTF     Z0.H, P0/M, Z31.D
        scvtf     z0.s, p0/m, z0.d
        SCVTF     Z0.S, P0/M, Z0.D
        scvtf     z1.s, p0/m, z0.d
        SDIVR     Z0.D, P0/M, Z0.D, Z4.D
        sdivr     z0.d, p0/m, z0.d, z31.d
        SDIVR     Z0.D, P0/M, Z0.D, Z31.D
+       sdot      z0.s, z0.b, z0.b
+       SDOT      Z0.S, Z0.B, Z0.B
+       sdot      z1.s, z0.b, z0.b
+       SDOT      Z1.S, Z0.B, Z0.B
+       sdot      z31.s, z0.b, z0.b
+       SDOT      Z31.S, Z0.B, Z0.B
+       sdot      z0.s, z2.b, z0.b
+       SDOT      Z0.S, Z2.B, Z0.B
+       sdot      z0.s, z31.b, z0.b
+       SDOT      Z0.S, Z31.B, Z0.B
+       sdot      z0.s, z0.b, z3.b
+       SDOT      Z0.S, Z0.B, Z3.B
+       sdot      z0.s, z0.b, z31.b
+       SDOT      Z0.S, Z0.B, Z31.B
+       sdot      z0.d, z0.h, z0.h
+       SDOT      Z0.D, Z0.H, Z0.H
+       sdot      z1.d, z0.h, z0.h
+       SDOT      Z1.D, Z0.H, Z0.H
+       sdot      z31.d, z0.h, z0.h
+       SDOT      Z31.D, Z0.H, Z0.H
+       sdot      z0.d, z2.h, z0.h
+       SDOT      Z0.D, Z2.H, Z0.H
+       sdot      z0.d, z31.h, z0.h
+       SDOT      Z0.D, Z31.H, Z0.H
+       sdot      z0.d, z0.h, z3.h
+       SDOT      Z0.D, Z0.H, Z3.H
+       sdot      z0.d, z0.h, z31.h
+       SDOT      Z0.D, Z0.H, Z31.H
+       sdot      z0.s, z0.b, z0.b[0]
+       SDOT      Z0.S, Z0.B, Z0.B[0]
+       sdot      z1.s, z0.b, z0.b[0]
+       SDOT      Z1.S, Z0.B, Z0.B[0]
+       sdot      z31.s, z0.b, z0.b[0]
+       SDOT      Z31.S, Z0.B, Z0.B[0]
+       sdot      z0.s, z2.b, z0.b[0]
+       SDOT      Z0.S, Z2.B, Z0.B[0]
+       sdot      z0.s, z31.b, z0.b[0]
+       SDOT      Z0.S, Z31.B, Z0.B[0]
+       sdot      z0.s, z0.b, z3.b[0]
+       SDOT      Z0.S, Z0.B, Z3.B[0]
+       sdot      z0.s, z0.b, z7.b[0]
+       SDOT      Z0.S, Z0.B, Z7.B[0]
+       sdot      z0.s, z0.b, z0.b[1]
+       SDOT      Z0.S, Z0.B, Z0.B[1]
+       sdot      z0.s, z0.b, z4.b[1]
+       SDOT      Z0.S, Z0.B, Z4.B[1]
+       sdot      z0.s, z0.b, z3.b[2]
+       SDOT      Z0.S, Z0.B, Z3.B[2]
+       sdot      z0.s, z0.b, z0.b[3]
+       SDOT      Z0.S, Z0.B, Z0.B[3]
+       sdot      z0.s, z0.b, z5.b[3]
+       SDOT      Z0.S, Z0.B, Z5.B[3]
+       sdot      z0.d, z0.h, z0.h[0]
+       SDOT      Z0.D, Z0.H, Z0.H[0]
+       sdot      z1.d, z0.h, z0.h[0]
+       SDOT      Z1.D, Z0.H, Z0.H[0]
+       sdot      z31.d, z0.h, z0.h[0]
+       SDOT      Z31.D, Z0.H, Z0.H[0]
+       sdot      z0.d, z2.h, z0.h[0]
+       SDOT      Z0.D, Z2.H, Z0.H[0]
+       sdot      z0.d, z31.h, z0.h[0]
+       SDOT      Z0.D, Z31.H, Z0.H[0]
+       sdot      z0.d, z0.h, z3.h[0]
+       SDOT      Z0.D, Z0.H, Z3.H[0]
+       sdot      z0.d, z0.h, z15.h[0]
+       SDOT      Z0.D, Z0.H, Z15.H[0]
+       sdot      z0.d, z0.h, z0.h[1]
+       SDOT      Z0.D, Z0.H, Z0.H[1]
+       sdot      z0.d, z0.h, z11.h[1]
+       SDOT      Z0.D, Z0.H, Z11.H[1]
        sel       z0.b, p0, z0.b, z0.b
        SEL       Z0.B, P0, Z0.B, Z0.B
        sel       z1.b, p0, z0.b, z0.b
        UADDV     D0, P0, Z3.D
        uaddv     d0, p0, z31.d
        UADDV     D0, P0, Z31.D
+       ucvtf     z0.h, p0/m, z0.h
+       UCVTF     Z0.H, P0/M, Z0.H
+       ucvtf     z1.h, p0/m, z0.h
+       UCVTF     Z1.H, P0/M, Z0.H
+       ucvtf     z31.h, p0/m, z0.h
+       UCVTF     Z31.H, P0/M, Z0.H
+       ucvtf     z0.h, p2/m, z0.h
+       UCVTF     Z0.H, P2/M, Z0.H
+       ucvtf     z0.h, p7/m, z0.h
+       UCVTF     Z0.H, P7/M, Z0.H
+       ucvtf     z0.h, p0/m, z3.h
+       UCVTF     Z0.H, P0/M, Z3.H
+       ucvtf     z0.h, p0/m, z31.h
+       UCVTF     Z0.H, P0/M, Z31.H
+       ucvtf     z0.h, p0/m, z0.s
+       UCVTF     Z0.H, P0/M, Z0.S
+       ucvtf     z1.h, p0/m, z0.s
+       UCVTF     Z1.H, P0/M, Z0.S
+       ucvtf     z31.h, p0/m, z0.s
+       UCVTF     Z31.H, P0/M, Z0.S
+       ucvtf     z0.h, p2/m, z0.s
+       UCVTF     Z0.H, P2/M, Z0.S
+       ucvtf     z0.h, p7/m, z0.s
+       UCVTF     Z0.H, P7/M, Z0.S
+       ucvtf     z0.h, p0/m, z3.s
+       UCVTF     Z0.H, P0/M, Z3.S
+       ucvtf     z0.h, p0/m, z31.s
+       UCVTF     Z0.H, P0/M, Z31.S
        ucvtf     z0.s, p0/m, z0.s
        UCVTF     Z0.S, P0/M, Z0.S
        ucvtf     z1.s, p0/m, z0.s
        UCVTF     Z0.D, P0/M, Z3.S
        ucvtf     z0.d, p0/m, z31.s
        UCVTF     Z0.D, P0/M, Z31.S
+       ucvtf     z0.h, p0/m, z0.d
+       UCVTF     Z0.H, P0/M, Z0.D
+       ucvtf     z1.h, p0/m, z0.d
+       UCVTF     Z1.H, P0/M, Z0.D
+       ucvtf     z31.h, p0/m, z0.d
+       UCVTF     Z31.H, P0/M, Z0.D
+       ucvtf     z0.h, p2/m, z0.d
+       UCVTF     Z0.H, P2/M, Z0.D
+       ucvtf     z0.h, p7/m, z0.d
+       UCVTF     Z0.H, P7/M, Z0.D
+       ucvtf     z0.h, p0/m, z3.d
+       UCVTF     Z0.H, P0/M, Z3.D
+       ucvtf     z0.h, p0/m, z31.d
+       UCVTF     Z0.H, P0/M, Z31.D
        ucvtf     z0.s, p0/m, z0.d
        UCVTF     Z0.S, P0/M, Z0.D
        ucvtf     z1.s, p0/m, z0.d
        UDIVR     Z0.D, P0/M, Z0.D, Z4.D
        udivr     z0.d, p0/m, z0.d, z31.d
        UDIVR     Z0.D, P0/M, Z0.D, Z31.D
+       udot      z0.s, z0.b, z0.b
+       UDOT      Z0.S, Z0.B, Z0.B
+       udot      z1.s, z0.b, z0.b
+       UDOT      Z1.S, Z0.B, Z0.B
+       udot      z31.s, z0.b, z0.b
+       UDOT      Z31.S, Z0.B, Z0.B
+       udot      z0.s, z2.b, z0.b
+       UDOT      Z0.S, Z2.B, Z0.B
+       udot      z0.s, z31.b, z0.b
+       UDOT      Z0.S, Z31.B, Z0.B
+       udot      z0.s, z0.b, z3.b
+       UDOT      Z0.S, Z0.B, Z3.B
+       udot      z0.s, z0.b, z31.b
+       UDOT      Z0.S, Z0.B, Z31.B
+       udot      z0.d, z0.h, z0.h
+       UDOT      Z0.D, Z0.H, Z0.H
+       udot      z1.d, z0.h, z0.h
+       UDOT      Z1.D, Z0.H, Z0.H
+       udot      z31.d, z0.h, z0.h
+       UDOT      Z31.D, Z0.H, Z0.H
+       udot      z0.d, z2.h, z0.h
+       UDOT      Z0.D, Z2.H, Z0.H
+       udot      z0.d, z31.h, z0.h
+       UDOT      Z0.D, Z31.H, Z0.H
+       udot      z0.d, z0.h, z3.h
+       UDOT      Z0.D, Z0.H, Z3.H
+       udot      z0.d, z0.h, z31.h
+       UDOT      Z0.D, Z0.H, Z31.H
+       udot      z0.s, z0.b, z0.b[0]
+       UDOT      Z0.S, Z0.B, Z0.B[0]
+       udot      z1.s, z0.b, z0.b[0]
+       UDOT      Z1.S, Z0.B, Z0.B[0]
+       udot      z31.s, z0.b, z0.b[0]
+       UDOT      Z31.S, Z0.B, Z0.B[0]
+       udot      z0.s, z2.b, z0.b[0]
+       UDOT      Z0.S, Z2.B, Z0.B[0]
+       udot      z0.s, z31.b, z0.b[0]
+       UDOT      Z0.S, Z31.B, Z0.B[0]
+       udot      z0.s, z0.b, z3.b[0]
+       UDOT      Z0.S, Z0.B, Z3.B[0]
+       udot      z0.s, z0.b, z7.b[0]
+       UDOT      Z0.S, Z0.B, Z7.B[0]
+       udot      z0.s, z0.b, z0.b[1]
+       UDOT      Z0.S, Z0.B, Z0.B[1]
+       udot      z0.s, z0.b, z4.b[1]
+       UDOT      Z0.S, Z0.B, Z4.B[1]
+       udot      z0.s, z0.b, z3.b[2]
+       UDOT      Z0.S, Z0.B, Z3.B[2]
+       udot      z0.s, z0.b, z0.b[3]
+       UDOT      Z0.S, Z0.B, Z0.B[3]
+       udot      z0.s, z0.b, z5.b[3]
+       UDOT      Z0.S, Z0.B, Z5.B[3]
+       udot      z0.d, z0.h, z0.h[0]
+       UDOT      Z0.D, Z0.H, Z0.H[0]
+       udot      z1.d, z0.h, z0.h[0]
+       UDOT      Z1.D, Z0.H, Z0.H[0]
+       udot      z31.d, z0.h, z0.h[0]
+       UDOT      Z31.D, Z0.H, Z0.H[0]
+       udot      z0.d, z2.h, z0.h[0]
+       UDOT      Z0.D, Z2.H, Z0.H[0]
+       udot      z0.d, z31.h, z0.h[0]
+       UDOT      Z0.D, Z31.H, Z0.H[0]
+       udot      z0.d, z0.h, z3.h[0]
+       UDOT      Z0.D, Z0.H, Z3.H[0]
+       udot      z0.d, z0.h, z15.h[0]
+       UDOT      Z0.D, Z0.H, Z15.H[0]
+       udot      z0.d, z0.h, z0.h[1]
+       UDOT      Z0.D, Z0.H, Z0.H[1]
+       udot      z0.d, z0.h, z11.h[1]
+       UDOT      Z0.D, Z0.H, Z11.H[1]
        umax      z0.b, z0.b, #0
        UMAX      Z0.B, Z0.B, #0
        umax      z1.b, z1.b, #0
        eon       z0.d, z0.d, #0x10000000100
        eon       z0.d, z0.d, #0x1
        EON       Z0.D, Z0.D, #0X1
+       facle     p0.h, p0/z, z0.h, z0.h
+       FACLE     P0.H, P0/Z, Z0.H, Z0.H
+       facle     p1.h, p0/z, z0.h, z0.h
+       FACLE     P1.H, P0/Z, Z0.H, Z0.H
+       facle     p15.h, p0/z, z0.h, z0.h
+       FACLE     P15.H, P0/Z, Z0.H, Z0.H
+       facle     p0.h, p2/z, z0.h, z0.h
+       FACLE     P0.H, P2/Z, Z0.H, Z0.H
+       facle     p0.h, p7/z, z0.h, z0.h
+       FACLE     P0.H, P7/Z, Z0.H, Z0.H
+       facle     p0.h, p0/z, z3.h, z0.h
+       FACLE     P0.H, P0/Z, Z3.H, Z0.H
+       facle     p0.h, p0/z, z31.h, z0.h
+       FACLE     P0.H, P0/Z, Z31.H, Z0.H
+       facle     p0.h, p0/z, z0.h, z4.h
+       FACLE     P0.H, P0/Z, Z0.H, Z4.H
+       facle     p0.h, p0/z, z0.h, z31.h
+       FACLE     P0.H, P0/Z, Z0.H, Z31.H
        facle     p0.s, p0/z, z0.s, z0.s
        FACLE     P0.S, P0/Z, Z0.S, Z0.S
        facle     p1.s, p0/z, z0.s, z0.s
        FACLE     P0.D, P0/Z, Z0.D, Z4.D
        facle     p0.d, p0/z, z0.d, z31.d
        FACLE     P0.D, P0/Z, Z0.D, Z31.D
+       faclt     p0.h, p0/z, z0.h, z0.h
+       FACLT     P0.H, P0/Z, Z0.H, Z0.H
+       faclt     p1.h, p0/z, z0.h, z0.h
+       FACLT     P1.H, P0/Z, Z0.H, Z0.H
+       faclt     p15.h, p0/z, z0.h, z0.h
+       FACLT     P15.H, P0/Z, Z0.H, Z0.H
+       faclt     p0.h, p2/z, z0.h, z0.h
+       FACLT     P0.H, P2/Z, Z0.H, Z0.H
+       faclt     p0.h, p7/z, z0.h, z0.h
+       FACLT     P0.H, P7/Z, Z0.H, Z0.H
+       faclt     p0.h, p0/z, z3.h, z0.h
+       FACLT     P0.H, P0/Z, Z3.H, Z0.H
+       faclt     p0.h, p0/z, z31.h, z0.h
+       FACLT     P0.H, P0/Z, Z31.H, Z0.H
+       faclt     p0.h, p0/z, z0.h, z4.h
+       FACLT     P0.H, P0/Z, Z0.H, Z4.H
+       faclt     p0.h, p0/z, z0.h, z31.h
+       FACLT     P0.H, P0/Z, Z0.H, Z31.H
        faclt     p0.s, p0/z, z0.s, z0.s
        FACLT     P0.S, P0/Z, Z0.S, Z0.S
        faclt     p1.s, p0/z, z0.s, z0.s
        FACLT     P0.D, P0/Z, Z0.D, Z4.D
        faclt     p0.d, p0/z, z0.d, z31.d
        FACLT     P0.D, P0/Z, Z0.D, Z31.D
+       fcmle     p0.h, p0/z, z0.h, z0.h
+       FCMLE     P0.H, P0/Z, Z0.H, Z0.H
+       fcmle     p1.h, p0/z, z0.h, z0.h
+       FCMLE     P1.H, P0/Z, Z0.H, Z0.H
+       fcmle     p15.h, p0/z, z0.h, z0.h
+       FCMLE     P15.H, P0/Z, Z0.H, Z0.H
+       fcmle     p0.h, p2/z, z0.h, z0.h
+       FCMLE     P0.H, P2/Z, Z0.H, Z0.H
+       fcmle     p0.h, p7/z, z0.h, z0.h
+       FCMLE     P0.H, P7/Z, Z0.H, Z0.H
+       fcmle     p0.h, p0/z, z3.h, z0.h
+       FCMLE     P0.H, P0/Z, Z3.H, Z0.H
+       fcmle     p0.h, p0/z, z31.h, z0.h
+       FCMLE     P0.H, P0/Z, Z31.H, Z0.H
+       fcmle     p0.h, p0/z, z0.h, z4.h
+       FCMLE     P0.H, P0/Z, Z0.H, Z4.H
+       fcmle     p0.h, p0/z, z0.h, z31.h
+       FCMLE     P0.H, P0/Z, Z0.H, Z31.H
        fcmle     p0.s, p0/z, z0.s, z0.s
        FCMLE     P0.S, P0/Z, Z0.S, Z0.S
        fcmle     p1.s, p0/z, z0.s, z0.s
        FCMLE     P0.D, P0/Z, Z0.D, Z4.D
        fcmle     p0.d, p0/z, z0.d, z31.d
        FCMLE     P0.D, P0/Z, Z0.D, Z31.D
+       fcmlt     p0.h, p0/z, z0.h, z0.h
+       FCMLT     P0.H, P0/Z, Z0.H, Z0.H
+       fcmlt     p1.h, p0/z, z0.h, z0.h
+       FCMLT     P1.H, P0/Z, Z0.H, Z0.H
+       fcmlt     p15.h, p0/z, z0.h, z0.h
+       FCMLT     P15.H, P0/Z, Z0.H, Z0.H
+       fcmlt     p0.h, p2/z, z0.h, z0.h
+       FCMLT     P0.H, P2/Z, Z0.H, Z0.H
+       fcmlt     p0.h, p7/z, z0.h, z0.h
+       FCMLT     P0.H, P7/Z, Z0.H, Z0.H
+       fcmlt     p0.h, p0/z, z3.h, z0.h
+       FCMLT     P0.H, P0/Z, Z3.H, Z0.H
+       fcmlt     p0.h, p0/z, z31.h, z0.h
+       FCMLT     P0.H, P0/Z, Z31.H, Z0.H
+       fcmlt     p0.h, p0/z, z0.h, z4.h
+       FCMLT     P0.H, P0/Z, Z0.H, Z4.H
+       fcmlt     p0.h, p0/z, z0.h, z31.h
+       FCMLT     P0.H, P0/Z, Z0.H, Z31.H
        fcmlt     p0.s, p0/z, z0.s, z0.s
        FCMLT     P0.S, P0/Z, Z0.S, Z0.S
        fcmlt     p1.s, p0/z, z0.s, z0.s
        FCMLT     P0.D, P0/Z, Z0.D, Z4.D
        fcmlt     p0.d, p0/z, z0.d, z31.d
        FCMLT     P0.D, P0/Z, Z0.D, Z31.D
+       fmov      z0.h, #0.0
+       FMOV      Z0.H, #0.0
+       fmov      z1.h, #0.0
+       FMOV      Z1.H, #0.0
+       fmov      z31.h, #0.0
+       FMOV      Z31.H, #0.0
        fmov      z0.s, #0.0
        FMOV      Z0.S, #0.0
        fmov      z1.s, #0.0
        FMOV      Z1.D, #0.0
        fmov      z31.d, #0.0
        FMOV      Z31.D, #0.0
+       fmov      z0.h, p0/m, #0.0
+       FMOV      Z0.H, P0/M, #0.0
+       fmov      z1.h, p0/m, #0.0
+       FMOV      Z1.H, P0/M, #0.0
+       fmov      z31.h, p0/m, #0.0
+       FMOV      Z31.H, P0/M, #0.0
+       fmov      z0.h, p2/m, #0.0
+       FMOV      Z0.H, P2/M, #0.0
+       fmov      z0.h, p15/m, #0.0
+       FMOV      Z0.H, P15/M, #0.0
        fmov      z0.s, p0/m, #0.0
        FMOV      Z0.S, P0/M, #0.0
        fmov      z1.s, p0/m, #0.0
        orn       z0.d, z0.d, #0x10000000100
        orn       z0.d, z0.d, #0x1
        ORN       Z0.D, Z0.D, #0X1
+
+       .include  "advsimd-compnum.s"
index 5a4d1e1b162ad26295414cff66a8a3470374d88b..44f242c4029a561311c29a3b0a828586c4800a03 100644 (file)
@@ -1,3 +1,10 @@
+2017-02-24  Richard Sandiford  <richard.sandiford@arm.com>
+
+       * opcode/aarch64.h (AARCH64_OPND_SVE_ADDR_RI_S4x16)
+       (AARCH64_OPND_SVE_IMM_ROT1, AARCH64_OPND_SVE_IMM_ROT2)
+       (AARCH64_OPND_SVE_Zm3_INDEX, AARCH64_OPND_SVE_Zm3_22_INDEX)
+       (AARCH64_OPND_SVE_Zm4_INDEX): New aarch64_opnds.
+
 2017-02-24  Richard Sandiford  <richard.sandiford@arm.com>
 
        * opcode/aarch64.h (AARCH64_FEATURE_COMPNUM): New macro.
index 8dbb540b3ceb1d1ca42b476c6504c94c386429c8..37e2486b3c483765c3c117a4fc3d0f90e902890c 100644 (file)
@@ -247,6 +247,7 @@ enum aarch64_opnd
   AARCH64_OPND_PRFOP,          /* Prefetch operation.  */
   AARCH64_OPND_BARRIER_PSB,    /* Barrier operand for PSB.  */
 
+  AARCH64_OPND_SVE_ADDR_RI_S4x16,   /* SVE [<Xn|SP>, #<simm4>*16].  */
   AARCH64_OPND_SVE_ADDR_RI_S4xVL,   /* SVE [<Xn|SP>, #<simm4>, MUL VL].  */
   AARCH64_OPND_SVE_ADDR_RI_S4x2xVL, /* SVE [<Xn|SP>, #<simm4>*2, MUL VL].  */
   AARCH64_OPND_SVE_ADDR_RI_S4x3xVL, /* SVE [<Xn|SP>, #<simm4>*3, MUL VL].  */
@@ -298,6 +299,8 @@ enum aarch64_opnd
   AARCH64_OPND_SVE_I1_HALF_ONE,        /* SVE choice between 0.5 and 1.0.  */
   AARCH64_OPND_SVE_I1_HALF_TWO,        /* SVE choice between 0.5 and 2.0.  */
   AARCH64_OPND_SVE_I1_ZERO_ONE,        /* SVE choice between 0.0 and 1.0.  */
+  AARCH64_OPND_SVE_IMM_ROT1,   /* SVE 1-bit rotate operand (90 or 270).  */
+  AARCH64_OPND_SVE_IMM_ROT2,   /* SVE 2-bit rotate operand (N*90).  */
   AARCH64_OPND_SVE_INV_LIMM,   /* SVE inverted logical immediate.  */
   AARCH64_OPND_SVE_LIMM,       /* SVE logical immediate.  */
   AARCH64_OPND_SVE_LIMM_MOV,   /* SVE logical immediate for MOV.  */
@@ -335,6 +338,9 @@ enum aarch64_opnd
   AARCH64_OPND_SVE_Zd,         /* SVE vector register in Zd.  */
   AARCH64_OPND_SVE_Zm_5,       /* SVE vector register in Zm, bits [9,5].  */
   AARCH64_OPND_SVE_Zm_16,      /* SVE vector register in Zm, bits [20,16].  */
+  AARCH64_OPND_SVE_Zm3_INDEX,  /* z0-z7[0-3] in Zm, bits [20,16].  */
+  AARCH64_OPND_SVE_Zm3_22_INDEX, /* z0-z7[0-7] in Zm3_INDEX plus bit 22.  */
+  AARCH64_OPND_SVE_Zm4_INDEX,  /* z0-z15[0-1] in Zm, bits [20,16].  */
   AARCH64_OPND_SVE_Zn,         /* SVE vector register in Zn.  */
   AARCH64_OPND_SVE_Zn_INDEX,   /* Indexed SVE vector register, for DUP.  */
   AARCH64_OPND_SVE_ZnxN,       /* SVE vector register list in Zn.  */
index b680f2426f75e3a378f80143b0ae0d37440ca0ec..2be13610a30d2b1afaf340b2f98d0041c652af17 100644 (file)
@@ -1,3 +1,51 @@
+2017-02-24  Richard Sandiford  <richard.sandiford@arm.com>
+
+       * aarch64-tbl.h (OP_SVE_HMH, OP_SVE_VMU_HSD, OP_SVE_VMVU_HSD)
+       (OP_SVE_VMVV_HSD, OP_SVE_VMVVU_HSD, OP_SVE_VM_HSD, OP_SVE_VUVV_HSD)
+       (OP_SVE_VUV_HSD, OP_SVE_VU_HSD, OP_SVE_VVVU_H, OP_SVE_VVVU_S)
+       (OP_SVE_VVVU_HSD, OP_SVE_VVV_D, OP_SVE_VVV_D_H, OP_SVE_VVV_H)
+       (OP_SVE_VVV_HSD, OP_SVE_VVV_S, OP_SVE_VVV_S_B, OP_SVE_VVV_SD_BH)
+       (OP_SVE_VV_BHSDQ, OP_SVE_VV_HSD, OP_SVE_VZVV_HSD, OP_SVE_VZV_HSD)
+       (OP_SVE_V_HSD): New macros.
+       (OP_SVE_VMU_SD, OP_SVE_VMVU_SD, OP_SVE_VM_SD, OP_SVE_VUVV_SD)
+       (OP_SVE_VU_SD, OP_SVE_VVVU_SD, OP_SVE_VVV_SD, OP_SVE_VZVV_SD)
+       (OP_SVE_VZV_SD, OP_SVE_V_SD): Delete.
+       (aarch64_opcode_table): Add new SVE instructions.
+       (aarch64_opcode_table): Use imm_rotate{1,2} instead of imm_rotate
+       for rotation operands.  Add new SVE operands.
+       * aarch64-asm.h (ins_sve_addr_ri_s4): New inserter.
+       (ins_sve_quad_index): Likewise.
+       (ins_imm_rotate): Split into...
+       (ins_imm_rotate1, ins_imm_rotate2): ...these two inserters.
+       * aarch64-asm.c (aarch64_ins_imm_rotate): Split into...
+       (aarch64_ins_imm_rotate1, aarch64_ins_imm_rotate2): ...these two
+       functions.
+       (aarch64_ins_sve_addr_ri_s4): New function.
+       (aarch64_ins_sve_quad_index): Likewise.
+       (do_misc_encoding): Handle "MOV Zn.Q, Qm".
+       * aarch64-asm-2.c: Regenerate.
+       * aarch64-dis.h (ext_sve_addr_ri_s4): New extractor.
+       (ext_sve_quad_index): Likewise.
+       (ext_imm_rotate): Split into...
+       (ext_imm_rotate1, ext_imm_rotate2): ...these two extractors.
+       * aarch64-dis.c (aarch64_ext_imm_rotate): Split into...
+       (aarch64_ext_imm_rotate1, aarch64_ext_imm_rotate2): ...these two
+       functions.
+       (aarch64_ext_sve_addr_ri_s4): New function.
+       (aarch64_ext_sve_quad_index): Likewise.
+       (aarch64_ext_sve_index): Allow quad indices.
+       (do_misc_decoding): Likewise.
+       * aarch64-dis-2.c: Regenerate.
+       * aarch64-opc.h (FLD_SVE_i3h, FLD_SVE_rot1, FLD_SVE_rot2): New
+       aarch64_field_kinds.
+       (OPD_F_OD_MASK): Widen by one bit.
+       (OPD_F_NO_ZR): Bump accordingly.
+       (get_operand_field_width): New function.
+       * aarch64-opc.c (fields): Add new SVE fields.
+       (operand_general_constraint_met_p): Handle new SVE operands.
+       (aarch64_print_operand): Likewise.
+       * aarch64-opc-2.c: Regenerate.
+
 2017-02-24  Richard Sandiford  <richard.sandiford@arm.com>
 
        * aarch64-tbl.h (aarch64_feature_simd_v8_3): Replace with...
index c697763a6f0ec24a33a49f5f2839e56a7a1be1ba..c5d9e6f1361039bd81e050d7caadd4c3a392ffc4 100644 (file)
@@ -453,7 +453,7 @@ aarch64_find_real_opcode (const aarch64_opcode *opcode)
     case 1176: /* sys */
       value = 1176;    /* --> sys.  */
       break;
-    case 1934: /* bic */
+    case 1973: /* bic */
     case 1239: /* and */
       value = 1239;    /* --> and.  */
       break;
@@ -465,19 +465,19 @@ aarch64_find_real_opcode (const aarch64_opcode *opcode)
     case 1242: /* ands */
       value = 1242;    /* --> ands.  */
       break;
-    case 1935: /* cmple */
+    case 1974: /* cmple */
     case 1277: /* cmpge */
       value = 1277;    /* --> cmpge.  */
       break;
-    case 1938: /* cmplt */
+    case 1977: /* cmplt */
     case 1280: /* cmpgt */
       value = 1280;    /* --> cmpgt.  */
       break;
-    case 1936: /* cmplo */
+    case 1975: /* cmplo */
     case 1282: /* cmphi */
       value = 1282;    /* --> cmphi.  */
       break;
-    case 1937: /* cmpls */
+    case 1976: /* cmpls */
     case 1285: /* cmphs */
       value = 1285;    /* --> cmphs.  */
       break;
@@ -489,7 +489,7 @@ aarch64_find_real_opcode (const aarch64_opcode *opcode)
     case 1308: /* cpy */
       value = 1308;    /* --> cpy.  */
       break;
-    case 1945: /* fmov */
+    case 1984: /* fmov */
     case 1224: /* mov */
     case 1309: /* cpy */
       value = 1309;    /* --> cpy.  */
@@ -503,7 +503,7 @@ aarch64_find_real_opcode (const aarch64_opcode *opcode)
     case 1322: /* dup */
       value = 1322;    /* --> dup.  */
       break;
-    case 1944: /* fmov */
+    case 1983: /* fmov */
     case 1218: /* mov */
     case 1323: /* dup */
       value = 1323;    /* --> dup.  */
@@ -512,7 +512,7 @@ aarch64_find_real_opcode (const aarch64_opcode *opcode)
     case 1324: /* dupm */
       value = 1324;    /* --> dupm.  */
       break;
-    case 1939: /* eon */
+    case 1978: /* eon */
     case 1326: /* eor */
       value = 1326;    /* --> eor.  */
       break;
@@ -524,53 +524,53 @@ aarch64_find_real_opcode (const aarch64_opcode *opcode)
     case 1329: /* eors */
       value = 1329;    /* --> eors.  */
       break;
-    case 1940: /* facle */
+    case 1979: /* facle */
     case 1334: /* facge */
       value = 1334;    /* --> facge.  */
       break;
-    case 1941: /* faclt */
+    case 1980: /* faclt */
     case 1335: /* facgt */
       value = 1335;    /* --> facgt.  */
       break;
-    case 1942: /* fcmle */
-    case 1344: /* fcmge */
-      value = 1344;    /* --> fcmge.  */
+    case 1981: /* fcmle */
+    case 1348: /* fcmge */
+      value = 1348;    /* --> fcmge.  */
       break;
-    case 1943: /* fcmlt */
-    case 1346: /* fcmgt */
-      value = 1346;    /* --> fcmgt.  */
+    case 1982: /* fcmlt */
+    case 1350: /* fcmgt */
+      value = 1350;    /* --> fcmgt.  */
       break;
     case 1211: /* fmov */
-    case 1352: /* fcpy */
-      value = 1352;    /* --> fcpy.  */
+    case 1356: /* fcpy */
+      value = 1356;    /* --> fcpy.  */
       break;
     case 1210: /* fmov */
-    case 1369: /* fdup */
-      value = 1369;    /* --> fdup.  */
+    case 1379: /* fdup */
+      value = 1379;    /* --> fdup.  */
       break;
     case 1212: /* mov */
-    case 1667: /* orr */
-      value = 1667;    /* --> orr.  */
+    case 1694: /* orr */
+      value = 1694;    /* --> orr.  */
       break;
-    case 1946: /* orn */
-    case 1668: /* orr */
-      value = 1668;    /* --> orr.  */
+    case 1985: /* orn */
+    case 1695: /* orr */
+      value = 1695;    /* --> orr.  */
       break;
     case 1215: /* mov */
-    case 1670: /* orr */
-      value = 1670;    /* --> orr.  */
+    case 1697: /* orr */
+      value = 1697;    /* --> orr.  */
       break;
     case 1225: /* movs */
-    case 1671: /* orrs */
-      value = 1671;    /* --> orrs.  */
+    case 1698: /* orrs */
+      value = 1698;    /* --> orrs.  */
       break;
     case 1220: /* mov */
-    case 1727: /* sel */
-      value = 1727;    /* --> sel.  */
+    case 1760: /* sel */
+      value = 1760;    /* --> sel.  */
       break;
     case 1223: /* mov */
-    case 1728: /* sel */
-      value = 1728;    /* --> sel.  */
+    case 1761: /* sel */
+      value = 1761;    /* --> sel.  */
       break;
     default: return NULL;
     }
@@ -611,9 +611,6 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 26:
     case 27:
     case 28:
-    case 144:
-    case 145:
-    case 146:
     case 147:
     case 148:
     case 149:
@@ -621,9 +618,9 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 151:
     case 152:
     case 153:
-    case 166:
-    case 167:
-    case 168:
+    case 154:
+    case 155:
+    case 156:
     case 169:
     case 170:
     case 171:
@@ -631,7 +628,10 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 173:
     case 174:
     case 175:
-    case 178:
+    case 176:
+    case 177:
+    case 181:
+    case 184:
       return aarch64_ins_regno (self, info, code, inst);
     case 13:
       return aarch64_ins_reg_extended (self, info, code, inst);
@@ -671,16 +671,16 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 73:
     case 74:
     case 75:
-    case 141:
-    case 143:
-    case 158:
-    case 159:
-    case 160:
+    case 144:
+    case 146:
     case 161:
     case 162:
     case 163:
     case 164:
     case 165:
+    case 166:
+    case 167:
+    case 168:
       return aarch64_ins_imm (self, info, code, inst);
     case 39:
     case 40:
@@ -690,10 +690,10 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 43:
       return aarch64_ins_advsimd_imm_modified (self, info, code, inst);
     case 47:
-    case 134:
+    case 135:
       return aarch64_ins_fpimm (self, info, code, inst);
     case 61:
-    case 139:
+    case 142:
       return aarch64_ins_limm (self, info, code, inst);
     case 62:
       return aarch64_ins_aimm (self, info, code, inst);
@@ -703,8 +703,11 @@ aarch64_insert_operand (const aarch64_operand *self,
       return aarch64_ins_fbits (self, info, code, inst);
     case 66:
     case 67:
+    case 140:
+      return aarch64_ins_imm_rotate2 (self, info, code, inst);
     case 68:
-      return aarch64_ins_imm_rotate (self, info, code, inst);
+    case 139:
+      return aarch64_ins_imm_rotate1 (self, info, code, inst);
     case 69:
     case 70:
       return aarch64_ins_cond (self, info, code, inst);
@@ -740,20 +743,21 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 94:
       return aarch64_ins_hint (self, info, code, inst);
     case 95:
+      return aarch64_ins_sve_addr_ri_s4 (self, info, code, inst);
     case 96:
     case 97:
     case 98:
-      return aarch64_ins_sve_addr_ri_s4xvl (self, info, code, inst);
     case 99:
-      return aarch64_ins_sve_addr_ri_s6xvl (self, info, code, inst);
+      return aarch64_ins_sve_addr_ri_s4xvl (self, info, code, inst);
     case 100:
-      return aarch64_ins_sve_addr_ri_s9xvl (self, info, code, inst);
+      return aarch64_ins_sve_addr_ri_s6xvl (self, info, code, inst);
     case 101:
+      return aarch64_ins_sve_addr_ri_s9xvl (self, info, code, inst);
     case 102:
     case 103:
     case 104:
-      return aarch64_ins_sve_addr_ri_u6 (self, info, code, inst);
     case 105:
+      return aarch64_ins_sve_addr_ri_u6 (self, info, code, inst);
     case 106:
     case 107:
     case 108:
@@ -765,8 +769,8 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 114:
     case 115:
     case 116:
-      return aarch64_ins_sve_addr_rr_lsl (self, info, code, inst);
     case 117:
+      return aarch64_ins_sve_addr_rr_lsl (self, info, code, inst);
     case 118:
     case 119:
     case 120:
@@ -774,44 +778,49 @@ aarch64_insert_operand (const aarch64_operand *self,
     case 122:
     case 123:
     case 124:
-      return aarch64_ins_sve_addr_rz_xtw (self, info, code, inst);
     case 125:
+      return aarch64_ins_sve_addr_rz_xtw (self, info, code, inst);
     case 126:
     case 127:
     case 128:
-      return aarch64_ins_sve_addr_zi_u5 (self, info, code, inst);
     case 129:
-      return aarch64_ins_sve_addr_zz_lsl (self, info, code, inst);
+      return aarch64_ins_sve_addr_zi_u5 (self, info, code, inst);
     case 130:
-      return aarch64_ins_sve_addr_zz_sxtw (self, info, code, inst);
+      return aarch64_ins_sve_addr_zz_lsl (self, info, code, inst);
     case 131:
-      return aarch64_ins_sve_addr_zz_uxtw (self, info, code, inst);
+      return aarch64_ins_sve_addr_zz_sxtw (self, info, code, inst);
     case 132:
-      return aarch64_ins_sve_aimm (self, info, code, inst);
+      return aarch64_ins_sve_addr_zz_uxtw (self, info, code, inst);
     case 133:
+      return aarch64_ins_sve_aimm (self, info, code, inst);
+    case 134:
       return aarch64_ins_sve_asimm (self, info, code, inst);
-    case 135:
-      return aarch64_ins_sve_float_half_one (self, info, code, inst);
     case 136:
-      return aarch64_ins_sve_float_half_two (self, info, code, inst);
+      return aarch64_ins_sve_float_half_one (self, info, code, inst);
     case 137:
-      return aarch64_ins_sve_float_zero_one (self, info, code, inst);
+      return aarch64_ins_sve_float_half_two (self, info, code, inst);
     case 138:
+      return aarch64_ins_sve_float_zero_one (self, info, code, inst);
+    case 141:
       return aarch64_ins_inv_limm (self, info, code, inst);
-    case 140:
+    case 143:
       return aarch64_ins_sve_limm_mov (self, info, code, inst);
-    case 142:
+    case 145:
       return aarch64_ins_sve_scale (self, info, code, inst);
-    case 154:
-    case 155:
-      return aarch64_ins_sve_shlimm (self, info, code, inst);
-    case 156:
     case 157:
+    case 158:
+      return aarch64_ins_sve_shlimm (self, info, code, inst);
+    case 159:
+    case 160:
       return aarch64_ins_sve_shrimm (self, info, code, inst);
-    case 176:
-      return aarch64_ins_sve_index (self, info, code, inst);
-    case 177:
+    case 178:
     case 179:
+    case 180:
+      return aarch64_ins_sve_quad_index (self, info, code, inst);
+    case 182:
+      return aarch64_ins_sve_index (self, info, code, inst);
+    case 183:
+    case 185:
       return aarch64_ins_sve_reglist (self, info, code, inst);
     default: assert (0); abort ();
     }
index 47d56f947beb1f12b14fd4f726cc97275026ee82..516bdabbacb56b2c590fa3cd5a501c6b548e8d48 100644 (file)
@@ -436,38 +436,27 @@ aarch64_ins_fpimm (const aarch64_operand *self, const aarch64_opnd_info *info,
   return NULL;
 }
 
-/* Insert field rot for the rotate immediate in
-   FCMLA <Vd>.<T>, <Vn>.<T>, <Vm>.<T>, #<rotate>.  */
+/* Insert 1-bit rotation immediate (#90 or #270).  */
 const char *
-aarch64_ins_imm_rotate (const aarch64_operand *self,
-                       const aarch64_opnd_info *info,
-                       aarch64_insn *code, const aarch64_inst *inst)
+aarch64_ins_imm_rotate1 (const aarch64_operand *self,
+                        const aarch64_opnd_info *info,
+                        aarch64_insn *code, const aarch64_inst *inst)
 {
-  uint64_t rot = info->imm.value / 90;
-
-  switch (info->type)
-    {
-    case AARCH64_OPND_IMM_ROT1:
-    case AARCH64_OPND_IMM_ROT2:
-      /* value rot
-        0      0
-        90     1
-        180    2
-        270    3  */
-      assert (rot < 4U);
-      break;
-    case AARCH64_OPND_IMM_ROT3:
-      /* value rot
-        90     0
-        270    1  */
-      rot = (rot - 1) / 2;
-      assert (rot < 2U);
-      break;
-    default:
-      assert (0);
-    }
+  uint64_t rot = (info->imm.value - 90) / 180;
+  assert (rot < 2U);
   insert_field (self->fields[0], code, rot, inst->opcode->mask);
+  return NULL;
+}
 
+/* Insert 2-bit rotation immediate (#0, #90, #180 or #270).  */
+const char *
+aarch64_ins_imm_rotate2 (const aarch64_operand *self,
+                        const aarch64_opnd_info *info,
+                        aarch64_insn *code, const aarch64_inst *inst)
+{
+  uint64_t rot = info->imm.value / 90;
+  assert (rot < 4U);
+  insert_field (self->fields[0], code, rot, inst->opcode->mask);
   return NULL;
 }
 
@@ -883,6 +872,20 @@ aarch64_ins_sve_addr_ri_s9xvl (const aarch64_operand *self,
   return NULL;
 }
 
+/* Encode an SVE address [X<n>, #<SVE_imm4> << <shift>], where <SVE_imm4>
+   is a 4-bit signed number and where <shift> is SELF's operand-dependent
+   value.  fields[0] specifies the base register field.  */
+const char *
+aarch64_ins_sve_addr_ri_s4 (const aarch64_operand *self,
+                           const aarch64_opnd_info *info, aarch64_insn *code,
+                           const aarch64_inst *inst ATTRIBUTE_UNUSED)
+{
+  int factor = 1 << get_operand_specific_data (self);
+  insert_field (self->fields[0], code, info->addr.base_regno, 0);
+  insert_field (FLD_SVE_imm4, code, info->addr.offset.imm / factor, 0);
+  return NULL;
+}
+
 /* Encode an SVE address [X<n>, #<SVE_imm6> << <shift>], where <SVE_imm6>
    is a 6-bit unsigned number and where <shift> is SELF's operand-dependent
    value.  fields[0] specifies the base register field.  */
@@ -1040,6 +1043,21 @@ aarch64_ins_sve_limm_mov (const aarch64_operand *self,
   return aarch64_ins_limm (self, info, code, inst);
 }
 
+/* Encode Zn[MM], where Zn occupies the least-significant part of the field
+   and where MM occupies the most-significant part.  The operand-dependent
+   value specifies the number of bits in Zn.  */
+const char *
+aarch64_ins_sve_quad_index (const aarch64_operand *self,
+                           const aarch64_opnd_info *info, aarch64_insn *code,
+                           const aarch64_inst *inst ATTRIBUTE_UNUSED)
+{
+  unsigned int reg_bits = get_operand_specific_data (self);
+  assert (info->reglane.regno < (1U << reg_bits));
+  unsigned int val = (info->reglane.index << reg_bits) + info->reglane.regno;
+  insert_all_fields (self, code, val);
+  return NULL;
+}
+
 /* Encode {Zn.<T> - Zm.<T>}.  The fields array specifies which field
    to use for Zn.  */
 const char *
@@ -1265,8 +1283,8 @@ do_misc_encoding (aarch64_inst *inst)
       break;
     case OP_MOV_Z_V:
       /* Fill in the zero immediate.  */
-      insert_field (FLD_SVE_tsz, &inst->value,
-                   1 << aarch64_get_variant (inst), 0);
+      insert_fields (&inst->value, 1 << aarch64_get_variant (inst), 0,
+                    2, FLD_imm5, FLD_SVE_tszh);
       break;
     case OP_MOV_Z_Z:
       /* Copy Zn to Zm.  */
index df49db42eb38d6b64b40303ee9fb1ff05ca623f2..45749e51d6648bab31b84d0c3ba14dbfb8a65eb5 100644 (file)
@@ -71,6 +71,7 @@ AARCH64_DECL_OPD_INSERTER (ins_hint);
 AARCH64_DECL_OPD_INSERTER (ins_prfop);
 AARCH64_DECL_OPD_INSERTER (ins_reg_extended);
 AARCH64_DECL_OPD_INSERTER (ins_reg_shifted);
+AARCH64_DECL_OPD_INSERTER (ins_sve_addr_ri_s4);
 AARCH64_DECL_OPD_INSERTER (ins_sve_addr_ri_s4xvl);
 AARCH64_DECL_OPD_INSERTER (ins_sve_addr_ri_s6xvl);
 AARCH64_DECL_OPD_INSERTER (ins_sve_addr_ri_s9xvl);
@@ -88,11 +89,13 @@ AARCH64_DECL_OPD_INSERTER (ins_sve_float_half_two);
 AARCH64_DECL_OPD_INSERTER (ins_sve_float_zero_one);
 AARCH64_DECL_OPD_INSERTER (ins_sve_index);
 AARCH64_DECL_OPD_INSERTER (ins_sve_limm_mov);
+AARCH64_DECL_OPD_INSERTER (ins_sve_quad_index);
 AARCH64_DECL_OPD_INSERTER (ins_sve_reglist);
 AARCH64_DECL_OPD_INSERTER (ins_sve_scale);
 AARCH64_DECL_OPD_INSERTER (ins_sve_shlimm);
 AARCH64_DECL_OPD_INSERTER (ins_sve_shrimm);
-AARCH64_DECL_OPD_INSERTER (ins_imm_rotate);
+AARCH64_DECL_OPD_INSERTER (ins_imm_rotate1);
+AARCH64_DECL_OPD_INSERTER (ins_imm_rotate2);
 
 #undef AARCH64_DECL_OPD_INSERTER
 
index 395c340e50ce7bda1fd2d50c70ee7d1c95dd621d..fe71ebc5189c769c8190918d22e61719c7efed54 100644 (file)
@@ -3397,9 +3397,9 @@ aarch64_opcode_lookup_1 (uint32_t word)
             {
               if (((word >> 24) & 0x1) == 0)
                 {
-                  if (((word >> 13) & 0x1) == 0)
+                  if (((word >> 29) & 0x1) == 0)
                     {
-                      if (((word >> 29) & 0x1) == 0)
+                      if (((word >> 13) & 0x1) == 0)
                         {
                           if (((word >> 14) & 0x1) == 0)
                             {
@@ -3433,7 +3433,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000000010xx0x100000
                                                                      mul.  */
-                                                                  return 1658;
+                                                                  return 1685;
                                                                 }
                                                             }
                                                           else
@@ -3444,7 +3444,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000000100xx0x100000
                                                                      smax.  */
-                                                                  return 1731;
+                                                                  return 1764;
                                                                 }
                                                               else
                                                                 {
@@ -3452,7 +3452,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000000110xx0x100000
                                                                      orr.  */
-                                                                  return 1669;
+                                                                  return 1696;
                                                                 }
                                                             }
                                                         }
@@ -3464,7 +3464,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0000010x0xx0x100000
                                                                  sdiv.  */
-                                                              return 1725;
+                                                              return 1755;
                                                             }
                                                           else
                                                             {
@@ -3472,7 +3472,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0000011x0xx0x100000
                                                                  sabd.  */
-                                                              return 1719;
+                                                              return 1746;
                                                             }
                                                         }
                                                     }
@@ -3486,7 +3486,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0000100x0xx0x100000
                                                                  smulh.  */
-                                                              return 1736;
+                                                              return 1769;
                                                             }
                                                           else
                                                             {
@@ -3496,7 +3496,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000010100xx0x100000
                                                                      smin.  */
-                                                                  return 1734;
+                                                                  return 1767;
                                                                 }
                                                               else
                                                                 {
@@ -3514,7 +3514,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx000011xx0xx0x100000
                                                              sdivr.  */
-                                                          return 1726;
+                                                          return 1756;
                                                         }
                                                     }
                                                 }
@@ -3530,7 +3530,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0001000x0xx0x100000
                                                                  sub.  */
-                                                              return 1852;
+                                                              return 1885;
                                                             }
                                                           else
                                                             {
@@ -3540,7 +3540,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000100100xx0x100000
                                                                      umax.  */
-                                                                  return 1874;
+                                                                  return 1913;
                                                                 }
                                                               else
                                                                 {
@@ -3560,7 +3560,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0001010x0xx0x100000
                                                                  udiv.  */
-                                                              return 1871;
+                                                              return 1907;
                                                             }
                                                           else
                                                             {
@@ -3568,7 +3568,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0001011x0xx0x100000
                                                                  uabd.  */
-                                                              return 1865;
+                                                              return 1898;
                                                             }
                                                         }
                                                     }
@@ -3584,7 +3584,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000110000xx0x100000
                                                                      subr.  */
-                                                                  return 1854;
+                                                                  return 1887;
                                                                 }
                                                               else
                                                                 {
@@ -3592,7 +3592,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000110010xx0x100000
                                                                      umulh.  */
-                                                                  return 1879;
+                                                                  return 1918;
                                                                 }
                                                             }
                                                           else
@@ -3603,7 +3603,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx000110100xx0x100000
                                                                      umin.  */
-                                                                  return 1877;
+                                                                  return 1916;
                                                                 }
                                                               else
                                                                 {
@@ -3621,7 +3621,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx000111xx0xx0x100000
                                                              udivr.  */
-                                                          return 1872;
+                                                          return 1908;
                                                         }
                                                     }
                                                 }
@@ -3634,7 +3634,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx000xxxxx0x00x100001
                                                      ld1sb.  */
-                                                  return 1487;
+                                                  return 1514;
                                                 }
                                               else
                                                 {
@@ -3642,7 +3642,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx000xxxxx0x10x100001
                                                      ld1sh.  */
-                                                  return 1498;
+                                                  return 1525;
                                                 }
                                             }
                                         }
@@ -3654,15 +3654,37 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx000xxxxx0x00x10001x
                                                  ld1sb.  */
-                                              return 1491;
+                                              return 1518;
                                             }
                                           else
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx000xxxxx0x10x10001x
-                                                 ld1sh.  */
-                                              return 1502;
+                                              if (((word >> 31) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 10) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxx0xx000xxxxx0x10x100010
+                                                         sdot.  */
+                                                      return 1757;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxx1xx000xxxxx0x10x100010
+                                                         udot.  */
+                                                      return 1909;
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx000xxxxx0x10x100011
+                                                     ld1sh.  */
+                                                  return 1529;
+                                                }
                                             }
                                         }
                                     }
@@ -3690,7 +3712,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx001000xxxxx1xx0x100000
                                                              sqadd.  */
-                                                          return 1738;
+                                                          return 1771;
                                                         }
                                                     }
                                                   else
@@ -3699,7 +3721,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx01x000xxxxx1xx0x100000
                                                          sqsub.  */
-                                                      return 1768;
+                                                      return 1801;
                                                     }
                                                 }
                                               else
@@ -3712,7 +3734,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx100000xxxxx1xx0x100000
                                                              sub.  */
-                                                          return 1850;
+                                                          return 1883;
                                                         }
                                                       else
                                                         {
@@ -3720,7 +3742,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx101000xxxxx1xx0x100000
                                                              uqadd.  */
-                                                          return 1880;
+                                                          return 1919;
                                                         }
                                                     }
                                                   else
@@ -3729,7 +3751,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx11x000xxxxx1xx0x100000
                                                          uqsub.  */
-                                                      return 1910;
+                                                      return 1949;
                                                     }
                                                 }
                                             }
@@ -3741,7 +3763,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx000xxxxx1x00x100001
                                                      prfb.  */
-                                                  return 1677;
+                                                  return 1704;
                                                 }
                                               else
                                                 {
@@ -3749,7 +3771,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx000xxxxx1x10x100001
                                                      ld1sh.  */
-                                                  return 1499;
+                                                  return 1526;
                                                 }
                                             }
                                         }
@@ -3761,15 +3783,59 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx000xxxxx1x00x10001x
                                                  prfb.  */
-                                              return 1678;
+                                              return 1705;
                                             }
                                           else
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx000xxxxx1x10x10001x
-                                                 ld1sh.  */
-                                              return 1503;
+                                              if (((word >> 31) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 10) & 0x1) == 0)
+                                                    {
+                                                      if (((word >> 22) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx0xx000xxxxx1010x100010
+                                                             sdot.  */
+                                                          return 1758;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx0xx000xxxxx1110x100010
+                                                             sdot.  */
+                                                          return 1759;
+                                                        }
+                                                    }
+                                                  else
+                                                    {
+                                                      if (((word >> 22) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx1xx000xxxxx1010x100010
+                                                             udot.  */
+                                                          return 1910;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx1xx000xxxxx1110x100010
+                                                             udot.  */
+                                                          return 1911;
+                                                        }
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx000xxxxx1x10x100011
+                                                     ld1sh.  */
+                                                  return 1530;
+                                                }
                                             }
                                         }
                                     }
@@ -3848,7 +3914,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx001100000xx0x100000
                                                                      lsr.  */
-                                                                  return 1649;
+                                                                  return 1676;
                                                                 }
                                                               else
                                                                 {
@@ -3856,7 +3922,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx001100010xx0x100000
                                                                      lsr.  */
-                                                                  return 1647;
+                                                                  return 1674;
                                                                 }
                                                             }
                                                           else
@@ -3865,7 +3931,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0011001x0xx0x100000
                                                                  lsr.  */
-                                                              return 1648;
+                                                              return 1675;
                                                             }
                                                         }
                                                       else
@@ -3874,7 +3940,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx001101xx0xx0x100000
                                                              lsrr.  */
-                                                          return 1650;
+                                                          return 1677;
                                                         }
                                                     }
                                                   else
@@ -3889,7 +3955,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx001110000xx0x100000
                                                                      lsl.  */
-                                                                  return 1643;
+                                                                  return 1670;
                                                                 }
                                                               else
                                                                 {
@@ -3897,7 +3963,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx001110010xx0x100000
                                                                      lsl.  */
-                                                                  return 1641;
+                                                                  return 1668;
                                                                 }
                                                             }
                                                           else
@@ -3906,7 +3972,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0011101x0xx0x100000
                                                                  lsl.  */
-                                                              return 1642;
+                                                              return 1669;
                                                             }
                                                         }
                                                       else
@@ -3915,7 +3981,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx001111xx0xx0x100000
                                                              lslr.  */
-                                                          return 1644;
+                                                          return 1671;
                                                         }
                                                     }
                                                 }
@@ -3951,7 +4017,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx100001xxxxx1xx0x100000
                                                              lsr.  */
-                                                          return 1645;
+                                                          return 1672;
                                                         }
                                                       else
                                                         {
@@ -3959,7 +4025,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx101001xxxxx1xx0x100000
                                                              lsr.  */
-                                                          return 1646;
+                                                          return 1673;
                                                         }
                                                     }
                                                   else
@@ -3970,7 +4036,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx110001xxxxx1xx0x100000
                                                              lsl.  */
-                                                          return 1639;
+                                                          return 1666;
                                                         }
                                                       else
                                                         {
@@ -3978,7 +4044,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx111001xxxxx1xx0x100000
                                                              lsl.  */
-                                                          return 1640;
+                                                          return 1667;
                                                         }
                                                     }
                                                 }
@@ -3994,7 +4060,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxxx000x100001
                                                      ld1sb.  */
-                                                  return 1493;
+                                                  return 1520;
                                                 }
                                               else
                                                 {
@@ -4002,7 +4068,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxxx010x100001
                                                      ld1sh.  */
-                                                  return 1506;
+                                                  return 1533;
                                                 }
                                             }
                                           else
@@ -4013,7 +4079,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxxx100x100001
                                                      ld1rb.  */
-                                                  return 1471;
+                                                  return 1490;
                                                 }
                                               else
                                                 {
@@ -4021,7 +4087,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxxx110x100001
                                                      ld1rsw.  */
-                                                  return 1484;
+                                                  return 1511;
                                                 }
                                             }
                                         }
@@ -4036,7 +4102,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx001xxxxx0x00x10001x
                                                  ld1sb.  */
-                                              return 1492;
+                                              return 1519;
                                             }
                                           else
                                             {
@@ -4044,7 +4110,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx001xxxxx0x10x10001x
                                                  ld1sh.  */
-                                              return 1504;
+                                              return 1531;
                                             }
                                         }
                                       else
@@ -4057,7 +4123,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxx1000x10001x
                                                      ld1sb.  */
-                                                  return 1497;
+                                                  return 1524;
                                                 }
                                               else
                                                 {
@@ -4065,7 +4131,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxx1010x10001x
                                                      ld1sh.  */
-                                                  return 1509;
+                                                  return 1536;
                                                 }
                                             }
                                           else
@@ -4076,7 +4142,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxx1100x10001x
                                                      prfb.  */
-                                                  return 1679;
+                                                  return 1706;
                                                 }
                                               else
                                                 {
@@ -4084,7 +4150,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx001xxxxx1110x10001x
                                                      ld1sh.  */
-                                                  return 1505;
+                                                  return 1532;
                                                 }
                                             }
                                         }
@@ -4105,7 +4171,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx0xx0x100000
                                                  mla.  */
-                                              return 1652;
+                                              return 1679;
                                             }
                                           else
                                             {
@@ -4115,7 +4181,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxx0x00x100001
                                                      ld1b.  */
-                                                  return 1437;
+                                                  return 1456;
                                                 }
                                               else
                                                 {
@@ -4123,7 +4189,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxx0x10x100001
                                                      ld1h.  */
-                                                  return 1457;
+                                                  return 1476;
                                                 }
                                             }
                                         }
@@ -4135,7 +4201,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx0x00x10001x
                                                  ld1b.  */
-                                              return 1442;
+                                              return 1461;
                                             }
                                           else
                                             {
@@ -4143,7 +4209,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx0x10x10001x
                                                  ld1h.  */
-                                              return 1462;
+                                              return 1481;
                                             }
                                         }
                                     }
@@ -4163,7 +4229,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx000010xxxxx1xx0x100000
                                                              index.  */
-                                                          return 1428;
+                                                          return 1447;
                                                         }
                                                       else
                                                         {
@@ -4171,7 +4237,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx100010xxxxx1xx0x100000
                                                              index.  */
-                                                          return 1429;
+                                                          return 1448;
                                                         }
                                                     }
                                                   else
@@ -4192,7 +4258,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxx01010xxxxx1010x100000
                                                                  rdvl.  */
-                                                              return 1713;
+                                                              return 1740;
                                                             }
                                                         }
                                                       else
@@ -4213,7 +4279,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx01x010xxxxx1xx0x100000
                                                          index.  */
-                                                      return 1430;
+                                                      return 1449;
                                                     }
                                                   else
                                                     {
@@ -4221,7 +4287,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx11x010xxxxx1xx0x100000
                                                          index.  */
-                                                      return 1427;
+                                                      return 1446;
                                                     }
                                                 }
                                             }
@@ -4233,7 +4299,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxx1x00x100001
                                                      prfw.  */
-                                                  return 1697;
+                                                  return 1724;
                                                 }
                                               else
                                                 {
@@ -4241,7 +4307,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxx1x10x100001
                                                      ld1h.  */
-                                                  return 1458;
+                                                  return 1477;
                                                 }
                                             }
                                         }
@@ -4253,7 +4319,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx1x00x10001x
                                                  prfw.  */
-                                              return 1699;
+                                              return 1726;
                                             }
                                           else
                                             {
@@ -4261,7 +4327,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx1x10x10001x
                                                  ld1h.  */
-                                              return 1463;
+                                              return 1482;
                                             }
                                         }
                                     }
@@ -4278,7 +4344,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx011xxxxx0xx0x100000
                                                  mad.  */
-                                              return 1651;
+                                              return 1678;
                                             }
                                           else
                                             {
@@ -4294,7 +4360,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx00x011xxxx010x0x100000
                                                                  sqincw.  */
-                                                              return 1765;
+                                                              return 1798;
                                                             }
                                                           else
                                                             {
@@ -4304,7 +4370,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx00x011xxxx01100x100000
                                                                      sqinch.  */
-                                                                  return 1759;
+                                                                  return 1792;
                                                                 }
                                                               else
                                                                 {
@@ -4312,7 +4378,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx00x011xxxx01110x100000
                                                                      sqincd.  */
-                                                                  return 1756;
+                                                                  return 1789;
                                                                 }
                                                             }
                                                         }
@@ -4324,7 +4390,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx00x011xxxx110x0x100000
                                                                  incw.  */
-                                                              return 1425;
+                                                              return 1444;
                                                             }
                                                           else
                                                             {
@@ -4334,7 +4400,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx00x011xxxx11100x100000
                                                                      inch.  */
-                                                                  return 1421;
+                                                                  return 1440;
                                                                 }
                                                               else
                                                                 {
@@ -4342,7 +4408,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx00x011xxxx11110x100000
                                                                      incd.  */
-                                                                  return 1419;
+                                                                  return 1438;
                                                                 }
                                                             }
                                                         }
@@ -4355,7 +4421,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx01x011xxxxx10x0x100000
                                                              sqdecw.  */
-                                                          return 1751;
+                                                          return 1784;
                                                         }
                                                       else
                                                         {
@@ -4365,7 +4431,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx01x011xxxxx1100x100000
                                                                  sqdech.  */
-                                                              return 1745;
+                                                              return 1778;
                                                             }
                                                           else
                                                             {
@@ -4373,7 +4439,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx01x011xxxxx1110x100000
                                                                  sqdecd.  */
-                                                              return 1742;
+                                                              return 1775;
                                                             }
                                                         }
                                                     }
@@ -4390,7 +4456,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx10x011xxxx010x0x100000
                                                                  uqincw.  */
-                                                              return 1907;
+                                                              return 1946;
                                                             }
                                                           else
                                                             {
@@ -4400,7 +4466,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx10x011xxxx01100x100000
                                                                      uqinch.  */
-                                                                  return 1901;
+                                                                  return 1940;
                                                                 }
                                                               else
                                                                 {
@@ -4408,7 +4474,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx10x011xxxx01110x100000
                                                                      uqincd.  */
-                                                                  return 1898;
+                                                                  return 1937;
                                                                 }
                                                             }
                                                         }
@@ -4451,7 +4517,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx11x011xxxxx10x0x100000
                                                              uqdecw.  */
-                                                          return 1893;
+                                                          return 1932;
                                                         }
                                                       else
                                                         {
@@ -4461,7 +4527,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx11x011xxxxx1100x100000
                                                                  uqdech.  */
-                                                              return 1887;
+                                                              return 1926;
                                                             }
                                                           else
                                                             {
@@ -4469,7 +4535,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx11x011xxxxx1110x100000
                                                                  uqdecd.  */
-                                                              return 1884;
+                                                              return 1923;
                                                             }
                                                         }
                                                     }
@@ -4488,7 +4554,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0000x100001
                                                          prfb.  */
-                                                      return 1676;
+                                                      return 1703;
                                                     }
                                                   else
                                                     {
@@ -4496,7 +4562,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0010x100001
                                                          prfh.  */
-                                                      return 1691;
+                                                      return 1718;
                                                     }
                                                 }
                                               else
@@ -4507,7 +4573,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx1000x100001
                                                          ld1b.  */
-                                                      return 1444;
+                                                      return 1463;
                                                     }
                                                   else
                                                     {
@@ -4515,7 +4581,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx1010x100001
                                                          ld1h.  */
-                                                      return 1466;
+                                                      return 1485;
                                                     }
                                                 }
                                             }
@@ -4527,7 +4593,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxxx100x100001
                                                      ld1rb.  */
-                                                  return 1473;
+                                                  return 1492;
                                                 }
                                               else
                                                 {
@@ -4535,7 +4601,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxxx110x100001
                                                      ld1rh.  */
-                                                  return 1477;
+                                                  return 1496;
                                                 }
                                             }
                                         }
@@ -4550,7 +4616,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx011xxxxx0x00x10001x
                                                  ld1b.  */
-                                              return 1443;
+                                              return 1462;
                                             }
                                           else
                                             {
@@ -4558,7 +4624,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx011xxxxx0x10x10001x
                                                  ld1h.  */
-                                              return 1464;
+                                              return 1483;
                                             }
                                         }
                                       else
@@ -4571,7 +4637,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1000x10001x
                                                      ld1b.  */
-                                                  return 1449;
+                                                  return 1468;
                                                 }
                                               else
                                                 {
@@ -4579,7 +4645,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1010x10001x
                                                      ld1h.  */
-                                                  return 1470;
+                                                  return 1489;
                                                 }
                                             }
                                           else
@@ -4590,7 +4656,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1100x10001x
                                                      prfw.  */
-                                                  return 1700;
+                                                  return 1727;
                                                 }
                                               else
                                                 {
@@ -4598,7 +4664,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1110x10001x
                                                      ld1h.  */
-                                                  return 1465;
+                                                  return 1484;
                                                 }
                                             }
                                         }
@@ -4608,672 +4674,680 @@ aarch64_opcode_lookup_1 (uint32_t word)
                         }
                       else
                         {
-                          if (((word >> 21) & 0x1) == 0)
+                          if (((word >> 14) & 0x1) == 0)
                             {
                               if (((word >> 15) & 0x1) == 0)
                                 {
-                                  if (((word >> 14) & 0x1) == 0)
-                                    {
-                                      if (((word >> 4) & 0x1) == 0)
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxx0xxxxxxxx000xxxxx0xx0x1001xx
-                                             cmphs.  */
-                                          return 1285;
-                                        }
-                                      else
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxx1xxxxxxxx000xxxxx0xx0x1001xx
-                                             cmphi.  */
-                                          return 1282;
-                                        }
-                                    }
-                                  else
+                                  if (((word >> 21) & 0x1) == 0)
                                     {
                                       if (((word >> 30) & 0x1) == 0)
                                         {
                                           if (((word >> 31) & 0x1) == 0)
                                             {
-                                              if (((word >> 4) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxx0xxxxxxxx010xxxxx0xx0x100100
-                                                     cmpge.  */
-                                                  return 1276;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxx1xxxxxxxx010xxxxx0xx0x100100
-                                                     cmpgt.  */
-                                                  return 1279;
-                                                }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 22) & 0x1) == 0)
+                                              if (((word >> 17) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 23) & 0x1) == 0)
+                                                  if (((word >> 19) & 0x1) == 0)
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx010xxxxx0000x100101
-                                                         ld1b.  */
-                                                      return 1438;
+                                                      if (((word >> 20) & 0x1) == 0)
+                                                        {
+                                                          if (((word >> 16) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx10000x000xx0x100000
+                                                                 saddv.  */
+                                                              return 1747;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx10010x000xx0x100000
+                                                                 uaddv.  */
+                                                              return 1899;
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx100x0x010xx0x100000
+                                                             movprfx.  */
+                                                          return 1682;
+                                                        }
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx010xxxxx0010x100101
-                                                         ld1sw.  */
-                                                      return 1510;
+                                                      if (((word >> 16) & 0x1) == 0)
+                                                        {
+                                                          if (((word >> 20) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx10000x100xx0x100000
+                                                                 smaxv.  */
+                                                              return 1765;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx10000x110xx0x100000
+                                                                 orv.  */
+                                                              return 1699;
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 20) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx10010x100xx0x100000
+                                                                 umaxv.  */
+                                                              return 1914;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx10010x110xx0x100000
+                                                                 eorv.  */
+                                                              return 1330;
+                                                            }
+                                                        }
                                                     }
                                                 }
                                               else
                                                 {
-                                                  if (((word >> 23) & 0x1) == 0)
+                                                  if (((word >> 16) & 0x1) == 0)
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx010xxxxx0100x100101
-                                                         ld1b.  */
-                                                      return 1440;
+                                                      if (((word >> 20) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx10001xx00xx0x100000
+                                                             sminv.  */
+                                                          return 1768;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx10001xx10xx0x100000
+                                                             andv.  */
+                                                          return 1243;
+                                                        }
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx010xxxxx0110x100101
-                                                         ld1h.  */
-                                                      return 1460;
+                                                         xxxxxxxxxxxxx10011xxx0xx0x100000
+                                                         uminv.  */
+                                                      return 1917;
                                                     }
                                                 }
                                             }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx010xxxxx00x0x10011x
-                                                 st1b.  */
-                                              return 1770;
-                                            }
                                           else
                                             {
                                               if (((word >> 23) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxx0100x10011x
-                                                     st1b.  */
-                                                  return 1774;
+                                                     xxxxxxxxxxxxx100xxxxx0x00x100001
+                                                     ldff1sb.  */
+                                                  return 1606;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxx0110x10011x
-                                                     st1h.  */
-                                                  return 1795;
+                                                     xxxxxxxxxxxxx100xxxxx0x10x100001
+                                                     ldff1sh.  */
+                                                  return 1614;
                                                 }
                                             }
                                         }
-                                    }
-                                }
-                              else
-                                {
-                                  if (((word >> 30) & 0x1) == 0)
-                                    {
-                                      if (((word >> 14) & 0x1) == 0)
+                                      else
                                         {
-                                          if (((word >> 4) & 0x1) == 0)
+                                          if (((word >> 23) & 0x1) == 0)
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxx0xxxxxxxx001xxxxx0xx0x10010x
-                                                 cmpge.  */
-                                              return 1277;
+                                                 xxxxxxxxxxxxx100xxxxx0x00x10001x
+                                                 ldff1sb.  */
+                                              return 1610;
                                             }
                                           else
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxx1xxxxxxxx001xxxxx0xx0x10010x
-                                                 cmpgt.  */
-                                              return 1280;
+                                                 xxxxxxxxxxxxx100xxxxx0x10x10001x
+                                                 ldff1sh.  */
+                                              return 1618;
                                             }
                                         }
-                                      else
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 23) & 0x1) == 0)
                                         {
-                                          if (((word >> 31) & 0x1) == 0)
-                                            {
-                                              if (((word >> 4) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxx0xxxxxxxx011xxxxx0xx0x100100
-                                                     cmphs.  */
-                                                  return 1286;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxx1xxxxxxxx011xxxxx0xx0x100100
-                                                     cmphi.  */
-                                                  return 1283;
-                                                }
-                                            }
-                                          else
+                                          if (((word >> 30) & 0x1) == 0)
                                             {
-                                              if (((word >> 22) & 0x1) == 0)
-                                                {
-                                                  if (((word >> 23) & 0x1) == 0)
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx011xxxxx0000x100101
-                                                         ldnt1b.  */
-                                                      return 1629;
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx011xxxxx0010x100101
-                                                         ldnt1h.  */
-                                                      return 1633;
-                                                    }
-                                                }
-                                              else
+                                              if (((word >> 31) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 23) & 0x1) == 0)
+                                                  if (((word >> 22) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx011xxxxx0100x100101
-                                                         ld3b.  */
-                                                      return 1537;
+                                                         xxxxxxxxxxxxx100xxxxx1000x100000
+                                                         and.  */
+                                                      return 1238;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx011xxxxx0110x100101
-                                                         ld3h.  */
-                                                      return 1541;
+                                                         xxxxxxxxxxxxx100xxxxx1100x100000
+                                                         orr.  */
+                                                      return 1694;
                                                     }
                                                 }
-                                            }
-                                        }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 22) & 0x1) == 0)
-                                        {
-                                          if (((word >> 23) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx0000x10011x
-                                                 st1b.  */
-                                              return 1771;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx0010x10011x
-                                                 st1h.  */
-                                              return 1790;
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 23) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx0100x10011x
-                                                 st1b.  */
-                                              return 1775;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx0110x10011x
-                                                 st1h.  */
-                                              return 1796;
-                                            }
-                                        }
-                                    }
-                                }
-                            }
-                          else
-                            {
-                              if (((word >> 30) & 0x1) == 0)
-                                {
-                                  if (((word >> 31) & 0x1) == 0)
-                                    {
-                                      if (((word >> 4) & 0x1) == 0)
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxx0xxxxxxxx0xxxxxxx1xx0x100100
-                                             cmphs.  */
-                                          return 1287;
-                                        }
-                                      else
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxx1xxxxxxxx0xxxxxxx1xx0x100100
-                                             cmphi.  */
-                                          return 1284;
-                                        }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 15) & 0x1) == 0)
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x0xxxxx1000x100101
-                                                     ld1b.  */
-                                                  return 1439;
-                                                }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x0xxxxx1010x100101
-                                                     ld1h.  */
-                                                  return 1459;
+                                                     xxxxxxxxxxxxx100xxxxx1x00x100001
+                                                     prfh.  */
+                                                  return 1717;
                                                 }
                                             }
                                           else
                                             {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x0xxxxx1100x100101
-                                                     ld1b.  */
-                                                  return 1441;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x0xxxxx1110x100101
-                                                     ld1h.  */
-                                                  return 1461;
-                                                }
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx100xxxxx1x00x10001x
+                                                 prfh.  */
+                                              return 1719;
                                             }
                                         }
                                       else
                                         {
-                                          if (((word >> 22) & 0x1) == 0)
+                                          if (((word >> 30) & 0x1) == 0)
                                             {
-                                              if (((word >> 23) & 0x1) == 0)
+                                              if (((word >> 31) & 0x1) == 0)
                                                 {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x1xxxxx1000x100101
-                                                     ld2b.  */
-                                                  return 1529;
+                                                  if (((word >> 22) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx100xxxxx1010x100000
+                                                         eor.  */
+                                                      return 1325;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx100xxxxx1110x100000
+                                                         bic.  */
+                                                      return 1251;
+                                                    }
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x1xxxxx1010x100101
-                                                     ld2h.  */
-                                                  return 1533;
+                                                     xxxxxxxxxxxxx100xxxxx1x10x100001
+                                                     ldff1sh.  */
+                                                  return 1615;
                                                 }
                                             }
                                           else
                                             {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x1xxxxx1100x100101
-                                                     ld4b.  */
-                                                  return 1545;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx0x1xxxxx1110x100101
-                                                     ld4h.  */
-                                                  return 1549;
-                                                }
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx100xxxxx1x10x10001x
+                                                 ldff1sh.  */
+                                              return 1619;
                                             }
                                         }
                                     }
                                 }
                               else
                                 {
-                                  if (((word >> 15) & 0x1) == 0)
+                                  if (((word >> 30) & 0x1) == 0)
                                     {
-                                      if (((word >> 22) & 0x1) == 0)
-                                        {
-                                          if (((word >> 23) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x0xxxxx1000x10011x
-                                                 st1b.  */
-                                              return 1773;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x0xxxxx1010x10011x
-                                                 st1h.  */
-                                              return 1792;
-                                            }
-                                        }
-                                      else
+                                      if (((word >> 31) & 0x1) == 0)
                                         {
-                                          if (((word >> 23) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x0xxxxx1100x10011x
-                                                 st1b.  */
-                                              return 1776;
-                                            }
-                                          else
+                                          if (((word >> 21) & 0x1) == 0)
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x0xxxxx1110x10011x
-                                                 st1h.  */
-                                              return 1797;
-                                            }
-                                        }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 22) & 0x1) == 0)
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxxxxxxxxxxx0x1xxxxx10x0x10011x
-                                             st1h.  */
-                                          return 1793;
-                                        }
-                                      else
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxxxxxxxxxxx0x1xxxxx11x0x10011x
-                                             st1h.  */
-                                          return 1798;
-                                        }
-                                    }
-                                }
-                            }
-                        }
-                    }
-                  else
-                    {
-                      if (((word >> 29) & 0x1) == 0)
-                        {
-                          if (((word >> 14) & 0x1) == 0)
-                            {
-                              if (((word >> 15) & 0x1) == 0)
-                                {
-                                  if (((word >> 21) & 0x1) == 0)
-                                    {
-                                      if (((word >> 30) & 0x1) == 0)
-                                        {
-                                          if (((word >> 31) & 0x1) == 0)
-                                            {
-                                              if (((word >> 17) & 0x1) == 0)
+                                              if (((word >> 16) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 19) & 0x1) == 0)
+                                                  if (((word >> 17) & 0x1) == 0)
                                                     {
-                                                      if (((word >> 20) & 0x1) == 0)
+                                                      if (((word >> 18) & 0x1) == 0)
                                                         {
-                                                          if (((word >> 16) & 0x1) == 0)
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
                                                               /* 33222222222211111111110000000000
                                                                  10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx10000x000xx0x100000
-                                                                 saddv.  */
-                                                              return 1720;
+                                                                 xxxxxxxxxxxxx1010000x0xx0x100000
+                                                                 sxtb.  */
+                                                              return 1890;
                                                             }
                                                           else
                                                             {
                                                               /* 33222222222211111111110000000000
                                                                  10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx10010x000xx0x100000
-                                                                 uaddv.  */
-                                                              return 1866;
+                                                                 xxxxxxxxxxxxx1010001x0xx0x100000
+                                                                 cls.  */
+                                                              return 1271;
                                                             }
                                                         }
                                                       else
                                                         {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx100x0x010xx0x100000
-                                                             movprfx.  */
-                                                          return 1655;
+                                                          if (((word >> 19) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1010010x0xx0x100000
+                                                                 sxtw.  */
+                                                              return 1892;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1010011x0xx0x100000
+                                                                 fabs.  */
+                                                              return 1333;
+                                                            }
                                                         }
                                                     }
                                                   else
                                                     {
-                                                      if (((word >> 16) & 0x1) == 0)
+                                                      if (((word >> 18) & 0x1) == 0)
                                                         {
-                                                          if (((word >> 20) & 0x1) == 0)
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
                                                               /* 33222222222211111111110000000000
                                                                  10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx10000x100xx0x100000
-                                                                 smaxv.  */
-                                                              return 1732;
+                                                                 xxxxxxxxxxxxx1010100x0xx0x100000
+                                                                 sxth.  */
+                                                              return 1891;
                                                             }
                                                           else
                                                             {
                                                               /* 33222222222211111111110000000000
                                                                  10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx10000x110xx0x100000
-                                                                 orv.  */
-                                                              return 1672;
+                                                                 xxxxxxxxxxxxx1010101x0xx0x100000
+                                                                 cnt.  */
+                                                              return 1300;
                                                             }
                                                         }
                                                       else
                                                         {
-                                                          if (((word >> 20) & 0x1) == 0)
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
                                                               /* 33222222222211111111110000000000
                                                                  10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx10010x100xx0x100000
-                                                                 umaxv.  */
-                                                              return 1875;
+                                                                 xxxxxxxxxxxxx1010110x0xx0x100000
+                                                                 abs.  */
+                                                              return 1229;
                                                             }
                                                           else
                                                             {
                                                               /* 33222222222211111111110000000000
                                                                  10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx10010x110xx0x100000
-                                                                 eorv.  */
-                                                              return 1330;
+                                                                 xxxxxxxxxxxxx1010111x0xx0x100000
+                                                                 not.  */
+                                                              return 1691;
                                                             }
                                                         }
                                                     }
                                                 }
                                               else
                                                 {
-                                                  if (((word >> 16) & 0x1) == 0)
+                                                  if (((word >> 17) & 0x1) == 0)
                                                     {
-                                                      if (((word >> 20) & 0x1) == 0)
+                                                      if (((word >> 18) & 0x1) == 0)
+                                                        {
+                                                          if (((word >> 19) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1011000x0xx0x100000
+                                                                 uxtb.  */
+                                                              return 1953;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1011001x0xx0x100000
+                                                                 clz.  */
+                                                              return 1272;
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 19) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1011010x0xx0x100000
+                                                                 uxtw.  */
+                                                              return 1955;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1011011x0xx0x100000
+                                                                 fneg.  */
+                                                              return 1410;
+                                                            }
+                                                        }
+                                                    }
+                                                  else
+                                                    {
+                                                      if (((word >> 18) & 0x1) == 0)
+                                                        {
+                                                          if (((word >> 19) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1011100x0xx0x100000
+                                                                 uxth.  */
+                                                              return 1954;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx1011101x0xx0x100000
+                                                                 cnot.  */
+                                                              return 1299;
+                                                            }
+                                                        }
+                                                      else
                                                         {
                                                           /* 33222222222211111111110000000000
                                                              10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx10001xx00xx0x100000
-                                                             sminv.  */
-                                                          return 1735;
+                                                             xxxxxxxxxxxxx101111xx0xx0x100000
+                                                             neg.  */
+                                                          return 1688;
+                                                        }
+                                                    }
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 12) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      if (((word >> 22) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxx0101xxxxx1000x100000
+                                                             adr.  */
+                                                          return 1235;
                                                         }
                                                       else
                                                         {
                                                           /* 33222222222211111111110000000000
                                                              10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx10001xx10xx0x100000
-                                                             andv.  */
-                                                          return 1243;
+                                                             xxxxxxxxxxxx0101xxxxx1100x100000
+                                                             adr.  */
+                                                          return 1236;
                                                         }
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx10011xxx0xx0x100000
-                                                         uminv.  */
-                                                      return 1878;
+                                                         xxxxxxxxxxxx0101xxxxx1x10x100000
+                                                         adr.  */
+                                                      return 1237;
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 10) & 0x1) == 0)
+                                                    {
+                                                      if (((word >> 11) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx001101xxxxx1xx0x100000
+                                                             ftssel.  */
+                                                          return 1436;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx011101xxxxx1xx0x100000
+                                                             fexpa.  */
+                                                          return 1380;
+                                                        }
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxx1x1101xxxxx1xx0x100000
+                                                         movprfx.  */
+                                                      return 1681;
                                                     }
                                                 }
                                             }
-                                          else
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
                                             {
                                               if (((word >> 23) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx100xxxxx0x00x100001
+                                                     xxxxxxxxxxxxx101xxxxxx000x100001
                                                      ldff1sb.  */
-                                                  return 1579;
+                                                  return 1612;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx100xxxxx0x10x100001
+                                                     xxxxxxxxxxxxx101xxxxxx010x100001
                                                      ldff1sh.  */
-                                                  return 1587;
+                                                  return 1622;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx101xxxxxx100x100001
+                                                     ld1rb.  */
+                                                  return 1491;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx101xxxxxx110x100001
+                                                     ld1rh.  */
+                                                  return 1495;
                                                 }
                                             }
                                         }
-                                      else
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 21) & 0x1) == 0)
                                         {
                                           if (((word >> 23) & 0x1) == 0)
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx100xxxxx0x00x10001x
+                                                 xxxxxxxxxxxxx101xxxxx0x00x10001x
                                                  ldff1sb.  */
-                                              return 1583;
+                                              return 1611;
                                             }
                                           else
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx100xxxxx0x10x10001x
+                                                 xxxxxxxxxxxxx101xxxxx0x10x10001x
                                                  ldff1sh.  */
-                                              return 1591;
+                                              return 1620;
                                             }
                                         }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 23) & 0x1) == 0)
+                                      else
                                         {
-                                          if (((word >> 30) & 0x1) == 0)
+                                          if (((word >> 22) & 0x1) == 0)
                                             {
-                                              if (((word >> 31) & 0x1) == 0)
+                                              if (((word >> 23) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx100xxxxx1000x100000
-                                                         and.  */
-                                                      return 1238;
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx100xxxxx1100x100000
-                                                         orr.  */
-                                                      return 1667;
-                                                    }
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx101xxxxx1000x10001x
+                                                     ldff1sb.  */
+                                                  return 1613;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx100xxxxx1x00x100001
-                                                     prfh.  */
-                                                  return 1690;
+                                                     xxxxxxxxxxxxx101xxxxx1010x10001x
+                                                     ldff1sh.  */
+                                                  return 1623;
                                                 }
                                             }
                                           else
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx100xxxxx1x00x10001x
-                                                 prfh.  */
-                                              return 1692;
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx101xxxxx1100x10001x
+                                                     prfh.  */
+                                                  return 1720;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx101xxxxx1110x10001x
+                                                     ldff1sh.  */
+                                                  return 1621;
+                                                }
                                             }
                                         }
-                                      else
+                                    }
+                                }
+                            }
+                          else
+                            {
+                              if (((word >> 15) & 0x1) == 0)
+                                {
+                                  if (((word >> 21) & 0x1) == 0)
+                                    {
+                                      if (((word >> 30) & 0x1) == 0)
                                         {
-                                          if (((word >> 30) & 0x1) == 0)
+                                          if (((word >> 31) & 0x1) == 0)
                                             {
-                                              if (((word >> 31) & 0x1) == 0)
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx110xxxxx0xx0x100000
+                                                 mls.  */
+                                              return 1680;
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx100xxxxx1010x100000
-                                                         eor.  */
-                                                      return 1325;
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx100xxxxx1110x100000
-                                                         bic.  */
-                                                      return 1251;
-                                                    }
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx110xxxxx0x00x100001
+                                                     ldff1b.  */
+                                                  return 1580;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx100xxxxx1x10x100001
-                                                     ldff1sh.  */
-                                                  return 1588;
+                                                     xxxxxxxxxxxxx110xxxxx0x10x100001
+                                                     ldff1h.  */
+                                                  return 1595;
                                                 }
                                             }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 23) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx110xxxxx0x00x10001x
+                                                 ldff1b.  */
+                                              return 1585;
+                                            }
                                           else
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx100xxxxx1x10x10001x
-                                                 ldff1sh.  */
-                                              return 1592;
+                                                 xxxxxxxxxxxxx110xxxxx0x10x10001x
+                                                 ldff1h.  */
+                                              return 1600;
+                                            }
+                                        }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 23) & 0x1) == 0)
+                                        {
+                                          if (((word >> 30) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx110xxxxx1x00x10000x
+                                                 prfd.  */
+                                              return 1710;
+                                            }
+                                          else
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx110xxxxx1x00x10001x
+                                                 prfd.  */
+                                              return 1712;
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 30) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx110xxxxx1x10x10000x
+                                                 ldff1h.  */
+                                              return 1596;
+                                            }
+                                          else
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx110xxxxx1x10x10001x
+                                                 ldff1h.  */
+                                              return 1601;
                                             }
                                         }
                                     }
@@ -5286,543 +5360,106 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                         {
                                           if (((word >> 21) & 0x1) == 0)
                                             {
-                                              if (((word >> 16) & 0x1) == 0)
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx111xxxxx0xx0x100000
+                                                 msb.  */
+                                              return 1683;
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 10) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 17) & 0x1) == 0)
+                                                  if (((word >> 11) & 0x1) == 0)
                                                     {
-                                                      if (((word >> 18) & 0x1) == 0)
+                                                      if (((word >> 12) & 0x1) == 0)
                                                         {
-                                                          if (((word >> 19) & 0x1) == 0)
+                                                          if (((word >> 20) & 0x1) == 0)
                                                             {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010000x0xx0x100000
-                                                                 sxtb.  */
-                                                              return 1857;
+                                                              if (((word >> 22) & 0x1) == 0)
+                                                                {
+                                                                  if (((word >> 23) & 0x1) == 0)
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx01000x100000
+                                                                         cntb.  */
+                                                                      return 1301;
+                                                                    }
+                                                                  else
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx01010x100000
+                                                                         cntw.  */
+                                                                      return 1305;
+                                                                    }
+                                                                }
+                                                              else
+                                                                {
+                                                                  if (((word >> 23) & 0x1) == 0)
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx01100x100000
+                                                                         cnth.  */
+                                                                      return 1303;
+                                                                    }
+                                                                  else
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx01110x100000
+                                                                         cntd.  */
+                                                                      return 1302;
+                                                                    }
+                                                                }
                                                             }
                                                           else
                                                             {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010001x0xx0x100000
-                                                                 cls.  */
-                                                              return 1271;
+                                                              if (((word >> 22) & 0x1) == 0)
+                                                                {
+                                                                  if (((word >> 23) & 0x1) == 0)
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx11000x100000
+                                                                         incb.  */
+                                                                      return 1437;
+                                                                    }
+                                                                  else
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx11010x100000
+                                                                         incw.  */
+                                                                      return 1445;
+                                                                    }
+                                                                }
+                                                              else
+                                                                {
+                                                                  if (((word >> 23) & 0x1) == 0)
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx11100x100000
+                                                                         inch.  */
+                                                                      return 1441;
+                                                                    }
+                                                                  else
+                                                                    {
+                                                                      /* 33222222222211111111110000000000
+                                                                         10987654321098765432109876543210
+                                                                         xxxxxxxxxx000111xxxx11110x100000
+                                                                         incd.  */
+                                                                      return 1439;
+                                                                    }
+                                                                }
                                                             }
                                                         }
                                                       else
                                                         {
-                                                          if (((word >> 19) & 0x1) == 0)
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010010x0xx0x100000
-                                                                 sxtw.  */
-                                                              return 1859;
-                                                            }
-                                                          else
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010011x0xx0x100000
-                                                                 fabs.  */
-                                                              return 1333;
-                                                            }
-                                                        }
-                                                    }
-                                                  else
-                                                    {
-                                                      if (((word >> 18) & 0x1) == 0)
-                                                        {
-                                                          if (((word >> 19) & 0x1) == 0)
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010100x0xx0x100000
-                                                                 sxth.  */
-                                                              return 1858;
-                                                            }
-                                                          else
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010101x0xx0x100000
-                                                                 cnt.  */
-                                                              return 1300;
-                                                            }
-                                                        }
-                                                      else
-                                                        {
-                                                          if (((word >> 19) & 0x1) == 0)
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010110x0xx0x100000
-                                                                 abs.  */
-                                                              return 1229;
-                                                            }
-                                                          else
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1010111x0xx0x100000
-                                                                 not.  */
-                                                              return 1664;
-                                                            }
-                                                        }
-                                                    }
-                                                }
-                                              else
-                                                {
-                                                  if (((word >> 17) & 0x1) == 0)
-                                                    {
-                                                      if (((word >> 18) & 0x1) == 0)
-                                                        {
-                                                          if (((word >> 19) & 0x1) == 0)
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1011000x0xx0x100000
-                                                                 uxtb.  */
-                                                              return 1914;
-                                                            }
-                                                          else
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1011001x0xx0x100000
-                                                                 clz.  */
-                                                              return 1272;
-                                                            }
-                                                        }
-                                                      else
-                                                        {
-                                                          if (((word >> 19) & 0x1) == 0)
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1011010x0xx0x100000
-                                                                 uxtw.  */
-                                                              return 1916;
-                                                            }
-                                                          else
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1011011x0xx0x100000
-                                                                 fneg.  */
-                                                              return 1391;
-                                                            }
-                                                        }
-                                                    }
-                                                  else
-                                                    {
-                                                      if (((word >> 18) & 0x1) == 0)
-                                                        {
-                                                          if (((word >> 19) & 0x1) == 0)
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1011100x0xx0x100000
-                                                                 uxth.  */
-                                                              return 1915;
-                                                            }
-                                                          else
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxxxxxxxxxxx1011101x0xx0x100000
-                                                                 cnot.  */
-                                                              return 1299;
-                                                            }
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101111xx0xx0x100000
-                                                             neg.  */
-                                                          return 1661;
-                                                        }
-                                                    }
-                                                }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 12) & 0x1) == 0)
-                                                {
-                                                  if (((word >> 23) & 0x1) == 0)
-                                                    {
-                                                      if (((word >> 22) & 0x1) == 0)
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxx0101xxxxx1000x100000
-                                                             adr.  */
-                                                          return 1235;
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxx0101xxxxx1100x100000
-                                                             adr.  */
-                                                          return 1236;
-                                                        }
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxx0101xxxxx1x10x100000
-                                                         adr.  */
-                                                      return 1237;
-                                                    }
-                                                }
-                                              else
-                                                {
-                                                  if (((word >> 10) & 0x1) == 0)
-                                                    {
-                                                      if (((word >> 11) & 0x1) == 0)
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxx001101xxxxx1xx0x100000
-                                                             ftssel.  */
-                                                          return 1417;
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxx011101xxxxx1xx0x100000
-                                                             fexpa.  */
-                                                          return 1370;
-                                                        }
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxx1x1101xxxxx1xx0x100000
-                                                         movprfx.  */
-                                                      return 1654;
-                                                    }
-                                                }
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxxx000x100001
-                                                     ldff1sb.  */
-                                                  return 1585;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxxx010x100001
-                                                     ldff1sh.  */
-                                                  return 1595;
-                                                }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxxx100x100001
-                                                     ld1rb.  */
-                                                  return 1472;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxxx110x100001
-                                                     ld1rh.  */
-                                                  return 1476;
-                                                }
-                                            }
-                                        }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 21) & 0x1) == 0)
-                                        {
-                                          if (((word >> 23) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx101xxxxx0x00x10001x
-                                                 ldff1sb.  */
-                                              return 1584;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx101xxxxx0x10x10001x
-                                                 ldff1sh.  */
-                                              return 1593;
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1000x10001x
-                                                     ldff1sb.  */
-                                                  return 1586;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1010x10001x
-                                                     ldff1sh.  */
-                                                  return 1596;
-                                                }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1100x10001x
-                                                     prfh.  */
-                                                  return 1693;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1110x10001x
-                                                     ldff1sh.  */
-                                                  return 1594;
-                                                }
-                                            }
-                                        }
-                                    }
-                                }
-                            }
-                          else
-                            {
-                              if (((word >> 15) & 0x1) == 0)
-                                {
-                                  if (((word >> 21) & 0x1) == 0)
-                                    {
-                                      if (((word >> 30) & 0x1) == 0)
-                                        {
-                                          if (((word >> 31) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx110xxxxx0xx0x100000
-                                                 mls.  */
-                                              return 1653;
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx0x00x100001
-                                                     ldff1b.  */
-                                                  return 1553;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx0x10x100001
-                                                     ldff1h.  */
-                                                  return 1568;
-                                                }
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 23) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx110xxxxx0x00x10001x
-                                                 ldff1b.  */
-                                              return 1558;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx110xxxxx0x10x10001x
-                                                 ldff1h.  */
-                                              return 1573;
-                                            }
-                                        }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 23) & 0x1) == 0)
-                                        {
-                                          if (((word >> 30) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx110xxxxx1x00x10000x
-                                                 prfd.  */
-                                              return 1683;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx110xxxxx1x00x10001x
-                                                 prfd.  */
-                                              return 1685;
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 30) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx110xxxxx1x10x10000x
-                                                 ldff1h.  */
-                                              return 1569;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx110xxxxx1x10x10001x
-                                                 ldff1h.  */
-                                              return 1574;
-                                            }
-                                        }
-                                    }
-                                }
-                              else
-                                {
-                                  if (((word >> 30) & 0x1) == 0)
-                                    {
-                                      if (((word >> 31) & 0x1) == 0)
-                                        {
-                                          if (((word >> 21) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx111xxxxx0xx0x100000
-                                                 msb.  */
-                                              return 1656;
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 10) & 0x1) == 0)
-                                                {
-                                                  if (((word >> 11) & 0x1) == 0)
-                                                    {
-                                                      if (((word >> 12) & 0x1) == 0)
-                                                        {
-                                                          if (((word >> 20) & 0x1) == 0)
-                                                            {
-                                                              if (((word >> 22) & 0x1) == 0)
-                                                                {
-                                                                  if (((word >> 23) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx01000x100000
-                                                                         cntb.  */
-                                                                      return 1301;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx01010x100000
-                                                                         cntw.  */
-                                                                      return 1305;
-                                                                    }
-                                                                }
-                                                              else
-                                                                {
-                                                                  if (((word >> 23) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx01100x100000
-                                                                         cnth.  */
-                                                                      return 1303;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx01110x100000
-                                                                         cntd.  */
-                                                                      return 1302;
-                                                                    }
-                                                                }
-                                                            }
-                                                          else
-                                                            {
-                                                              if (((word >> 22) & 0x1) == 0)
-                                                                {
-                                                                  if (((word >> 23) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx11000x100000
-                                                                         incb.  */
-                                                                      return 1418;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx11010x100000
-                                                                         incw.  */
-                                                                      return 1426;
-                                                                    }
-                                                                }
-                                                              else
-                                                                {
-                                                                  if (((word >> 23) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx11100x100000
-                                                                         inch.  */
-                                                                      return 1422;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxx000111xxxx11110x100000
-                                                                         incd.  */
-                                                                      return 1420;
-                                                                    }
-                                                                }
-                                                            }
-                                                        }
-                                                      else
-                                                        {
-                                                          if (((word >> 20) & 0x1) == 0)
+                                                          if (((word >> 20) & 0x1) == 0)
                                                             {
                                                               if (((word >> 22) & 0x1) == 0)
                                                                 {
@@ -5832,7 +5469,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx01000x100000
                                                                          sqincb.  */
-                                                                      return 1755;
+                                                                      return 1788;
                                                                     }
                                                                   else
                                                                     {
@@ -5840,7 +5477,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx01010x100000
                                                                          sqincw.  */
-                                                                      return 1767;
+                                                                      return 1800;
                                                                     }
                                                                 }
                                                               else
@@ -5851,7 +5488,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx01100x100000
                                                                          sqinch.  */
-                                                                      return 1761;
+                                                                      return 1794;
                                                                     }
                                                                   else
                                                                     {
@@ -5859,7 +5496,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx01110x100000
                                                                          sqincd.  */
-                                                                      return 1758;
+                                                                      return 1791;
                                                                     }
                                                                 }
                                                             }
@@ -5873,7 +5510,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx11000x100000
                                                                          sqincb.  */
-                                                                      return 1754;
+                                                                      return 1787;
                                                                     }
                                                                   else
                                                                     {
@@ -5881,7 +5518,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx11010x100000
                                                                          sqincw.  */
-                                                                      return 1766;
+                                                                      return 1799;
                                                                     }
                                                                 }
                                                               else
@@ -5892,7 +5529,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx11100x100000
                                                                          sqinch.  */
-                                                                      return 1760;
+                                                                      return 1793;
                                                                     }
                                                                   else
                                                                     {
@@ -5900,7 +5537,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx001111xxxx11110x100000
                                                                          sqincd.  */
-                                                                      return 1757;
+                                                                      return 1790;
                                                                     }
                                                                 }
                                                             }
@@ -5918,7 +5555,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx01000x100000
                                                                      sqdecb.  */
-                                                                  return 1741;
+                                                                  return 1774;
                                                                 }
                                                               else
                                                                 {
@@ -5926,7 +5563,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx01010x100000
                                                                      sqdecw.  */
-                                                                  return 1753;
+                                                                  return 1786;
                                                                 }
                                                             }
                                                           else
@@ -5937,7 +5574,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx01100x100000
                                                                      sqdech.  */
-                                                                  return 1747;
+                                                                  return 1780;
                                                                 }
                                                               else
                                                                 {
@@ -5945,7 +5582,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx01110x100000
                                                                      sqdecd.  */
-                                                                  return 1744;
+                                                                  return 1777;
                                                                 }
                                                             }
                                                         }
@@ -5959,7 +5596,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx11000x100000
                                                                      sqdecb.  */
-                                                                  return 1740;
+                                                                  return 1773;
                                                                 }
                                                               else
                                                                 {
@@ -5967,7 +5604,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx11010x100000
                                                                      sqdecw.  */
-                                                                  return 1752;
+                                                                  return 1785;
                                                                 }
                                                             }
                                                           else
@@ -5978,7 +5615,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx11100x100000
                                                                      sqdech.  */
-                                                                  return 1746;
+                                                                  return 1779;
                                                                 }
                                                               else
                                                                 {
@@ -5986,7 +5623,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01x111xxxx11110x100000
                                                                      sqdecd.  */
-                                                                  return 1743;
+                                                                  return 1776;
                                                                 }
                                                             }
                                                         }
@@ -6049,7 +5686,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx01000x100000
                                                                          uqincb.  */
-                                                                      return 1896;
+                                                                      return 1935;
                                                                     }
                                                                   else
                                                                     {
@@ -6057,7 +5694,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx01010x100000
                                                                          uqincw.  */
-                                                                      return 1908;
+                                                                      return 1947;
                                                                     }
                                                                 }
                                                               else
@@ -6068,7 +5705,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx01100x100000
                                                                          uqinch.  */
-                                                                      return 1902;
+                                                                      return 1941;
                                                                     }
                                                                   else
                                                                     {
@@ -6076,7 +5713,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx01110x100000
                                                                          uqincd.  */
-                                                                      return 1899;
+                                                                      return 1938;
                                                                     }
                                                                 }
                                                             }
@@ -6090,7 +5727,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx11000x100000
                                                                          uqincb.  */
-                                                                      return 1897;
+                                                                      return 1936;
                                                                     }
                                                                   else
                                                                     {
@@ -6098,7 +5735,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx11010x100000
                                                                          uqincw.  */
-                                                                      return 1909;
+                                                                      return 1948;
                                                                     }
                                                                 }
                                                               else
@@ -6109,7 +5746,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx11100x100000
                                                                          uqinch.  */
-                                                                      return 1903;
+                                                                      return 1942;
                                                                     }
                                                                   else
                                                                     {
@@ -6117,7 +5754,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx101111xxxx11110x100000
                                                                          uqincd.  */
-                                                                      return 1900;
+                                                                      return 1939;
                                                                     }
                                                                 }
                                                             }
@@ -6135,7 +5772,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx01000x100000
                                                                      uqdecb.  */
-                                                                  return 1882;
+                                                                  return 1921;
                                                                 }
                                                               else
                                                                 {
@@ -6143,7 +5780,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx01010x100000
                                                                      uqdecw.  */
-                                                                  return 1894;
+                                                                  return 1933;
                                                                 }
                                                             }
                                                           else
@@ -6154,7 +5791,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx01100x100000
                                                                      uqdech.  */
-                                                                  return 1888;
+                                                                  return 1927;
                                                                 }
                                                               else
                                                                 {
@@ -6162,7 +5799,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx01110x100000
                                                                      uqdecd.  */
-                                                                  return 1885;
+                                                                  return 1924;
                                                                 }
                                                             }
                                                         }
@@ -6176,7 +5813,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx11000x100000
                                                                      uqdecb.  */
-                                                                  return 1883;
+                                                                  return 1922;
                                                                 }
                                                               else
                                                                 {
@@ -6184,7 +5821,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx11010x100000
                                                                      uqdecw.  */
-                                                                  return 1895;
+                                                                  return 1934;
                                                                 }
                                                             }
                                                           else
@@ -6195,7 +5832,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx11100x100000
                                                                      uqdech.  */
-                                                                  return 1889;
+                                                                  return 1928;
                                                                 }
                                                               else
                                                                 {
@@ -6203,7 +5840,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx11x111xxxx11110x100000
                                                                      uqdecd.  */
-                                                                  return 1886;
+                                                                  return 1925;
                                                                 }
                                                             }
                                                         }
@@ -6215,23 +5852,246 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                         {
                                           if (((word >> 22) & 0x1) == 0)
                                             {
-                                              if (((word >> 21) & 0x1) == 0)
+                                              if (((word >> 21) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx0000x100001
+                                                         prfb.  */
+                                                      return 1707;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx0010x100001
+                                                         prfh.  */
+                                                      return 1721;
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx1000x100001
+                                                         ldff1b.  */
+                                                      return 1587;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx1010x100001
+                                                         ldff1h.  */
+                                                      return 1604;
+                                                    }
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxxx100x100001
+                                                     ld1rb.  */
+                                                  return 1493;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxxx110x100001
+                                                     ld1rh.  */
+                                                  return 1497;
+                                                }
+                                            }
+                                        }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 21) & 0x1) == 0)
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx0000x10001x
+                                                     prfb.  */
+                                                  return 1709;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx0010x10001x
+                                                     prfh.  */
+                                                  return 1723;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx0100x10001x
+                                                     ldff1b.  */
+                                                  return 1586;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx0110x10001x
+                                                     ldff1h.  */
+                                                  return 1602;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx1000x10001x
+                                                     ldff1b.  */
+                                                  return 1588;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx1010x10001x
+                                                     ldff1h.  */
+                                                  return 1605;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx1100x10001x
+                                                     prfd.  */
+                                                  return 1713;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx111xxxxx1110x10001x
+                                                     ldff1h.  */
+                                                  return 1603;
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                    }
+                  else
+                    {
+                      if (((word >> 21) & 0x1) == 0)
+                        {
+                          if (((word >> 15) & 0x1) == 0)
+                            {
+                              if (((word >> 30) & 0x1) == 0)
+                                {
+                                  if (((word >> 13) & 0x1) == 0)
+                                    {
+                                      if (((word >> 14) & 0x1) == 0)
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx0xxxxxxxx000xxxxx0xx0x100100
+                                                     cmphs.  */
+                                                  return 1285;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx1xxxxxxxx000xxxxx0xx0x100100
+                                                     cmphi.  */
+                                                  return 1282;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx000xxxxx0x00x100101
+                                                     ld1rqb.  */
+                                                  return 1499;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx000xxxxx0x10x100101
+                                                     ld1rqh.  */
+                                                  return 1503;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx0xxxxxxxx010xxxxx0xx0x100100
+                                                     cmpge.  */
+                                                  return 1276;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx1xxxxxxxx010xxxxx0xx0x100100
+                                                     cmpgt.  */
+                                                  return 1279;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 22) & 0x1) == 0)
                                                 {
                                                   if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0000x100001
-                                                         prfb.  */
-                                                      return 1680;
+                                                         xxxxxxxxxxxxx010xxxxx0000x100101
+                                                         ld1b.  */
+                                                      return 1457;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0010x100001
-                                                         prfh.  */
-                                                      return 1694;
+                                                         xxxxxxxxxxxxx010xxxxx0010x100101
+                                                         ld1sw.  */
+                                                      return 1537;
                                                     }
                                                 }
                                               else
@@ -6240,63 +6100,151 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx1000x100001
-                                                         ldff1b.  */
-                                                      return 1560;
+                                                         xxxxxxxxxxxxx010xxxxx0100x100101
+                                                         ld1b.  */
+                                                      return 1459;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx1010x100001
-                                                         ldff1h.  */
-                                                      return 1577;
+                                                         xxxxxxxxxxxxx010xxxxx0110x100101
+                                                         ld1h.  */
+                                                      return 1479;
                                                     }
                                                 }
                                             }
+                                        }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 14) & 0x1) == 0)
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx0xxxxxxxx100xxxxx0xx0x100100
+                                                     cmpeq.  */
+                                                  return 1273;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx1xxxxxxxx100xxxxx0xx0x100100
+                                                     cmpne.  */
+                                                  return 1296;
+                                                }
+                                            }
                                           else
                                             {
                                               if (((word >> 23) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxxx100x100001
-                                                     ld1rb.  */
-                                                  return 1474;
+                                                     xxxxxxxxxxxxx100xxxxx0x00x100101
+                                                     ld1rqb.  */
+                                                  return 1498;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxxx110x100001
-                                                     ld1rh.  */
-                                                  return 1478;
+                                                     xxxxxxxxxxxxx100xxxxx0x10x100101
+                                                     ld1rqh.  */
+                                                  return 1502;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx0xxxxxxxx110xxxxx0xx0x100100
+                                                     cmplt.  */
+                                                  return 1294;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx1xxxxxxxx110xxxxx0xx0x100100
+                                                     cmple.  */
+                                                  return 1288;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 22) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx110xxxxx0000x100101
+                                                         ldff1b.  */
+                                                      return 1581;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx110xxxxx0010x100101
+                                                         ldff1sw.  */
+                                                      return 1624;
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx110xxxxx0100x100101
+                                                         ldff1b.  */
+                                                      return 1583;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx110xxxxx0110x100101
+                                                         ldff1h.  */
+                                                      return 1598;
+                                                    }
                                                 }
                                             }
                                         }
                                     }
+                                }
+                              else
+                                {
+                                  if (((word >> 31) & 0x1) == 0)
+                                    {
+                                      /* 33222222222211111111110000000000
+                                         10987654321098765432109876543210
+                                         xxxxxxxxxxxxxxx0xxxxx0xx0x100110
+                                         fcmla.  */
+                                      return 1342;
+                                    }
                                   else
                                     {
-                                      if (((word >> 21) & 0x1) == 0)
+                                      if (((word >> 13) & 0x1) == 0)
                                         {
                                           if (((word >> 22) & 0x1) == 0)
                                             {
-                                              if (((word >> 23) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx0000x10001x
-                                                     prfb.  */
-                                                  return 1682;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx0010x10001x
-                                                     prfh.  */
-                                                  return 1696;
-                                                }
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx0x0xxxxx00x0x100111
+                                                 st1b.  */
+                                              return 1803;
                                             }
                                           else
                                             {
@@ -6304,17 +6252,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx0100x10001x
-                                                     ldff1b.  */
-                                                  return 1559;
+                                                     xxxxxxxxxxxxx0x0xxxxx0100x100111
+                                                     st1b.  */
+                                                  return 1807;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx0110x10001x
-                                                     ldff1h.  */
-                                                  return 1575;
+                                                     xxxxxxxxxxxxx0x0xxxxx0110x100111
+                                                     st1h.  */
+                                                  return 1828;
                                                 }
                                             }
                                         }
@@ -6326,17 +6274,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx1000x10001x
-                                                     ldff1b.  */
-                                                  return 1561;
+                                                     xxxxxxxxxxxxx1x0xxxxx0000x100111
+                                                     stnt1b.  */
+                                                  return 1873;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx1010x10001x
-                                                     ldff1h.  */
-                                                  return 1578;
+                                                     xxxxxxxxxxxxx1x0xxxxx0010x100111
+                                                     stnt1h.  */
+                                                  return 1877;
                                                 }
                                             }
                                           else
@@ -6345,52 +6293,49 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx1100x10001x
-                                                     prfd.  */
-                                                  return 1686;
+                                                     xxxxxxxxxxxxx1x0xxxxx0100x100111
+                                                     st3b.  */
+                                                  return 1857;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx1110x10001x
-                                                     ldff1h.  */
-                                                  return 1576;
+                                                     xxxxxxxxxxxxx1x0xxxxx0110x100111
+                                                     st3h.  */
+                                                  return 1861;
                                                 }
                                             }
                                         }
                                     }
                                 }
                             }
-                        }
-                      else
-                        {
-                          if (((word >> 21) & 0x1) == 0)
+                          else
                             {
-                              if (((word >> 14) & 0x1) == 0)
+                              if (((word >> 13) & 0x1) == 0)
                                 {
-                                  if (((word >> 15) & 0x1) == 0)
+                                  if (((word >> 30) & 0x1) == 0)
                                     {
-                                      if (((word >> 4) & 0x1) == 0)
+                                      if (((word >> 14) & 0x1) == 0)
                                         {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxx0xxxxxxxx100xxxxx0xx0x1001xx
-                                             cmpeq.  */
-                                          return 1273;
+                                          if (((word >> 4) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxx0xxxxxxxx001xxxxx0xx0x10010x
+                                                 cmpge.  */
+                                              return 1277;
+                                            }
+                                          else
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxx1xxxxxxxx001xxxxx0xx0x10010x
+                                                 cmpgt.  */
+                                              return 1280;
+                                            }
                                         }
                                       else
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxx1xxxxxxxx100xxxxx0xx0x1001xx
-                                             cmpne.  */
-                                          return 1296;
-                                        }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 30) & 0x1) == 0)
                                         {
                                           if (((word >> 31) & 0x1) == 0)
                                             {
@@ -6398,105 +6343,72 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxx0xxxxxxxx101xxxxx0xx0x100100
-                                                     cmpeq.  */
-                                                  return 1274;
+                                                     xxxx0xxxxxxxx011xxxxx0xx0x100100
+                                                     cmphs.  */
+                                                  return 1286;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxx1xxxxxxxx101xxxxx0xx0x100100
-                                                     cmpne.  */
-                                                  return 1297;
+                                                     xxxx1xxxxxxxx011xxxxx0xx0x100100
+                                                     cmphi.  */
+                                                  return 1283;
                                                 }
                                             }
                                           else
                                             {
-                                              if (((word >> 20) & 0x1) == 0)
+                                              if (((word >> 22) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
-                                                      if (((word >> 23) & 0x1) == 0)
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx00000x100101
-                                                             ld1b.  */
-                                                          return 1445;
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx00010x100101
-                                                             ld1sw.  */
-                                                          return 1515;
-                                                        }
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx011xxxxx0000x100101
+                                                         ldnt1b.  */
+                                                      return 1656;
                                                     }
                                                   else
                                                     {
-                                                      if (((word >> 23) & 0x1) == 0)
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx00100x100101
-                                                             ld1b.  */
-                                                          return 1447;
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx00110x100101
-                                                             ld1h.  */
-                                                          return 1468;
-                                                        }
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx011xxxxx0010x100101
+                                                         ldnt1h.  */
+                                                      return 1660;
                                                     }
                                                 }
                                               else
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
-                                                      if (((word >> 23) & 0x1) == 0)
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx10000x100101
-                                                             ldnf1b.  */
-                                                          return 1613;
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx10010x100101
-                                                             ldnf1sw.  */
-                                                          return 1626;
-                                                        }
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx011xxxxx0100x100101
+                                                         ld3b.  */
+                                                      return 1564;
                                                     }
                                                   else
                                                     {
-                                                      if (((word >> 23) & 0x1) == 0)
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx10100x100101
-                                                             ldnf1b.  */
-                                                          return 1615;
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx101xxxx10110x100101
-                                                             ldnf1h.  */
-                                                          return 1619;
-                                                        }
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx011xxxxx0110x100101
+                                                         ld3h.  */
+                                                      return 1568;
                                                     }
                                                 }
                                             }
                                         }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 31) & 0x1) == 0)
+                                        {
+                                          /* 33222222222211111111110000000000
+                                             10987654321098765432109876543210
+                                             xxxxxxxxxxxxx0x1xxxxx0xx0x100110
+                                             fcadd.  */
+                                          return 1341;
+                                        }
                                       else
                                         {
                                           if (((word >> 22) & 0x1) == 0)
@@ -6505,17 +6417,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx0000x10011x
+                                                     xxxxxxxxxxxxx0x1xxxxx0000x100111
                                                      st1b.  */
-                                                  return 1772;
+                                                  return 1804;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx0010x10011x
+                                                     xxxxxxxxxxxxx0x1xxxxx0010x100111
                                                      st1h.  */
-                                                  return 1791;
+                                                  return 1823;
                                                 }
                                             }
                                           else
@@ -6524,17 +6436,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx0100x10011x
+                                                     xxxxxxxxxxxxx0x1xxxxx0100x100111
                                                      st1b.  */
-                                                  return 1779;
+                                                  return 1808;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx0110x10011x
+                                                     xxxxxxxxxxxxx0x1xxxxx0110x100111
                                                      st1h.  */
-                                                  return 1800;
+                                                  return 1829;
                                                 }
                                             }
                                         }
@@ -6542,7 +6454,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                 }
                               else
                                 {
-                                  if (((word >> 15) & 0x1) == 0)
+                                  if (((word >> 14) & 0x1) == 0)
                                     {
                                       if (((word >> 30) & 0x1) == 0)
                                         {
@@ -6552,57 +6464,101 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxx0xxxxxxxx110xxxxx0xx0x100100
-                                                     cmplt.  */
-                                                  return 1294;
+                                                     xxxx0xxxxxxxx101xxxxx0xx0x100100
+                                                     cmpeq.  */
+                                                  return 1274;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxx1xxxxxxxx110xxxxx0xx0x100100
-                                                     cmple.  */
-                                                  return 1288;
+                                                     xxxx1xxxxxxxx101xxxxx0xx0x100100
+                                                     cmpne.  */
+                                                  return 1297;
                                                 }
                                             }
                                           else
                                             {
-                                              if (((word >> 22) & 0x1) == 0)
+                                              if (((word >> 20) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 23) & 0x1) == 0)
+                                                  if (((word >> 22) & 0x1) == 0)
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx0000x100101
-                                                         ldff1b.  */
-                                                      return 1554;
+                                                      if (((word >> 23) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx00000x100101
+                                                             ld1b.  */
+                                                          return 1464;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx00010x100101
+                                                             ld1sw.  */
+                                                          return 1542;
+                                                        }
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx0010x100101
-                                                         ldff1sw.  */
-                                                      return 1597;
+                                                      if (((word >> 23) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx00100x100101
+                                                             ld1b.  */
+                                                          return 1466;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx00110x100101
+                                                             ld1h.  */
+                                                          return 1487;
+                                                        }
                                                     }
                                                 }
                                               else
                                                 {
-                                                  if (((word >> 23) & 0x1) == 0)
+                                                  if (((word >> 22) & 0x1) == 0)
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx0100x100101
-                                                         ldff1b.  */
-                                                      return 1556;
+                                                      if (((word >> 23) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx10000x100101
+                                                             ldnf1b.  */
+                                                          return 1640;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx10010x100101
+                                                             ldnf1sw.  */
+                                                          return 1653;
+                                                        }
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx0110x100101
-                                                         ldff1h.  */
-                                                      return 1571;
+                                                      if (((word >> 23) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx10100x100101
+                                                             ldnf1b.  */
+                                                          return 1642;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx101xxxx10110x100101
+                                                             ldnf1h.  */
+                                                          return 1646;
+                                                        }
                                                     }
                                                 }
                                             }
@@ -6615,17 +6571,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx0000x10011x
-                                                     stnt1b.  */
-                                                  return 1840;
+                                                     xxxxxxxxxxxxx101xxxxx0000x10011x
+                                                     st1b.  */
+                                                  return 1805;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx0010x10011x
-                                                     stnt1h.  */
-                                                  return 1844;
+                                                     xxxxxxxxxxxxx101xxxxx0010x10011x
+                                                     st1h.  */
+                                                  return 1824;
                                                 }
                                             }
                                           else
@@ -6634,17 +6590,17 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx0100x10011x
-                                                     st3b.  */
-                                                  return 1824;
+                                                     xxxxxxxxxxxxx101xxxxx0100x10011x
+                                                     st1b.  */
+                                                  return 1812;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx0110x10011x
-                                                     st3h.  */
-                                                  return 1828;
+                                                     xxxxxxxxxxxxx101xxxxx0110x10011x
+                                                     st1h.  */
+                                                  return 1833;
                                                 }
                                             }
                                         }
@@ -6682,7 +6638,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx0000x100101
                                                          ldnt1b.  */
-                                                      return 1630;
+                                                      return 1657;
                                                     }
                                                   else
                                                     {
@@ -6690,7 +6646,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx0010x100101
                                                          ldnt1h.  */
-                                                      return 1634;
+                                                      return 1661;
                                                     }
                                                 }
                                               else
@@ -6701,7 +6657,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx0100x100101
                                                          ld3b.  */
-                                                      return 1538;
+                                                      return 1565;
                                                     }
                                                   else
                                                     {
@@ -6709,7 +6665,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx0110x100101
                                                          ld3h.  */
-                                                      return 1542;
+                                                      return 1569;
                                                     }
                                                 }
                                             }
@@ -6724,7 +6680,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxx000x0x10011x
                                                      st1b.  */
-                                                  return 1777;
+                                                  return 1810;
                                                 }
                                               else
                                                 {
@@ -6734,7 +6690,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx00100x10011x
                                                          st1b.  */
-                                                      return 1780;
+                                                      return 1813;
                                                     }
                                                   else
                                                     {
@@ -6742,7 +6698,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx00110x10011x
                                                          st1h.  */
-                                                      return 1801;
+                                                      return 1834;
                                                     }
                                                 }
                                             }
@@ -6756,7 +6712,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx10000x10011x
                                                          stnt1b.  */
-                                                      return 1841;
+                                                      return 1874;
                                                     }
                                                   else
                                                     {
@@ -6764,7 +6720,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx10010x10011x
                                                          stnt1h.  */
-                                                      return 1845;
+                                                      return 1878;
                                                     }
                                                 }
                                               else
@@ -6775,7 +6731,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx10100x10011x
                                                          st3b.  */
-                                                      return 1825;
+                                                      return 1858;
                                                     }
                                                   else
                                                     {
@@ -6783,10 +6739,274 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx10110x10011x
                                                          st3h.  */
-                                                      return 1829;
+                                                      return 1862;
+                                                    }
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                            }
+                        }
+                      else
+                        {
+                          if (((word >> 13) & 0x1) == 0)
+                            {
+                              if (((word >> 30) & 0x1) == 0)
+                                {
+                                  if (((word >> 31) & 0x1) == 0)
+                                    {
+                                      if (((word >> 4) & 0x1) == 0)
+                                        {
+                                          /* 33222222222211111111110000000000
+                                             10987654321098765432109876543210
+                                             xxxx0xxxxxxxx0xxxxxxx1xx0x100100
+                                             cmphs.  */
+                                          return 1287;
+                                        }
+                                      else
+                                        {
+                                          /* 33222222222211111111110000000000
+                                             10987654321098765432109876543210
+                                             xxxx1xxxxxxxx0xxxxxxx1xx0x100100
+                                             cmphi.  */
+                                          return 1284;
+                                        }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 15) & 0x1) == 0)
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x0xxxxx1000x100101
+                                                     ld1b.  */
+                                                  return 1458;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x0xxxxx1010x100101
+                                                     ld1h.  */
+                                                  return 1478;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x0xxxxx1100x100101
+                                                     ld1b.  */
+                                                  return 1460;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x0xxxxx1110x100101
+                                                     ld1h.  */
+                                                  return 1480;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x1xxxxx1000x100101
+                                                     ld2b.  */
+                                                  return 1556;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x1xxxxx1010x100101
+                                                     ld2h.  */
+                                                  return 1560;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x1xxxxx1100x100101
+                                                     ld4b.  */
+                                                  return 1572;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx0x1xxxxx1110x100101
+                                                     ld4h.  */
+                                                  return 1576;
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                              else
+                                {
+                                  if (((word >> 15) & 0x1) == 0)
+                                    {
+                                      if (((word >> 14) & 0x1) == 0)
+                                        {
+                                          if (((word >> 12) & 0x1) == 0)
+                                            {
+                                              if (((word >> 10) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxx0x0000xxxxx1x00x10011x
+                                                         fmla.  */
+                                                      return 1395;
+                                                    }
+                                                  else
+                                                    {
+                                                      if (((word >> 22) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx0x0000xxxxx1010x10011x
+                                                             fmla.  */
+                                                          return 1396;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx0x0000xxxxx1110x10011x
+                                                             fmla.  */
+                                                          return 1397;
+                                                        }
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxx1x0000xxxxx1x00x10011x
+                                                         fmls.  */
+                                                      return 1399;
+                                                    }
+                                                  else
+                                                    {
+                                                      if (((word >> 22) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx1x0000xxxxx1010x10011x
+                                                             fmls.  */
+                                                          return 1400;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxx1x0000xxxxx1110x10011x
+                                                             fmls.  */
+                                                          return 1401;
+                                                        }
                                                     }
                                                 }
                                             }
+                                          else
+                                            {
+                                              if (((word >> 22) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxx1000xxxxx10x0x10011x
+                                                     fcmla.  */
+                                                  return 1343;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxx1000xxxxx11x0x10011x
+                                                     fcmla.  */
+                                                  return 1344;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx1000x10011x
+                                                     st1b.  */
+                                                  return 1806;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx1010x10011x
+                                                     st1h.  */
+                                                  return 1825;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx1100x10011x
+                                                     st1b.  */
+                                                  return 1809;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx1110x10011x
+                                                     st1h.  */
+                                                  return 1830;
+                                                }
+                                            }
+                                        }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 22) & 0x1) == 0)
+                                        {
+                                          /* 33222222222211111111110000000000
+                                             10987654321098765432109876543210
+                                             xxxxxxxxxxxxx0x1xxxxx10x0x10011x
+                                             st1h.  */
+                                          return 1826;
+                                        }
+                                      else
+                                        {
+                                          /* 33222222222211111111110000000000
+                                             10987654321098765432109876543210
+                                             xxxxxxxxxxxxx0x1xxxxx11x0x10011x
+                                             st1h.  */
+                                          return 1831;
                                         }
                                     }
                                 }
@@ -6828,7 +7048,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx01000x100101
                                                          ld1b.  */
-                                                      return 1446;
+                                                      return 1465;
                                                     }
                                                   else
                                                     {
@@ -6836,7 +7056,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx01010x100101
                                                          ld1h.  */
-                                                      return 1467;
+                                                      return 1486;
                                                     }
                                                 }
                                               else
@@ -6847,7 +7067,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx01100x100101
                                                          ld1b.  */
-                                                      return 1448;
+                                                      return 1467;
                                                     }
                                                   else
                                                     {
@@ -6855,7 +7075,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx01110x100101
                                                          ld1h.  */
-                                                      return 1469;
+                                                      return 1488;
                                                     }
                                                 }
                                             }
@@ -6869,7 +7089,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx11000x100101
                                                          ldnf1b.  */
-                                                      return 1614;
+                                                      return 1641;
                                                     }
                                                   else
                                                     {
@@ -6877,7 +7097,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx11010x100101
                                                          ldnf1h.  */
-                                                      return 1618;
+                                                      return 1645;
                                                     }
                                                 }
                                               else
@@ -6888,7 +7108,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx11100x100101
                                                          ldnf1b.  */
-                                                      return 1616;
+                                                      return 1643;
                                                     }
                                                   else
                                                     {
@@ -6896,7 +7116,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx10xxxxx11110x100101
                                                          ldnf1h.  */
-                                                      return 1620;
+                                                      return 1647;
                                                     }
                                                 }
                                             }
@@ -6913,7 +7133,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx1000x100101
                                                          ldff1b.  */
-                                                      return 1555;
+                                                      return 1582;
                                                     }
                                                   else
                                                     {
@@ -6921,7 +7141,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx1010x100101
                                                          ldff1h.  */
-                                                      return 1570;
+                                                      return 1597;
                                                     }
                                                 }
                                               else
@@ -6932,7 +7152,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx1100x100101
                                                          ldff1b.  */
-                                                      return 1557;
+                                                      return 1584;
                                                     }
                                                   else
                                                     {
@@ -6940,7 +7160,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx1110x100101
                                                          ldff1h.  */
-                                                      return 1572;
+                                                      return 1599;
                                                     }
                                                 }
                                             }
@@ -6954,7 +7174,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1000x100101
                                                          ld2b.  */
-                                                      return 1530;
+                                                      return 1557;
                                                     }
                                                   else
                                                     {
@@ -6962,7 +7182,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1010x100101
                                                          ld2h.  */
-                                                      return 1534;
+                                                      return 1561;
                                                     }
                                                 }
                                               else
@@ -6973,7 +7193,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1100x100101
                                                          ld4b.  */
-                                                      return 1546;
+                                                      return 1573;
                                                     }
                                                   else
                                                     {
@@ -6981,7 +7201,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1110x100101
                                                          ld4h.  */
-                                                      return 1550;
+                                                      return 1577;
                                                     }
                                                 }
                                             }
@@ -6992,31 +7212,64 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                 {
                                   if (((word >> 14) & 0x1) == 0)
                                     {
-                                      if (((word >> 22) & 0x1) == 0)
-                                        {
-                                          /* 33222222222211111111110000000000
-                                             10987654321098765432109876543210
-                                             xxxxxxxxxxxxx10xxxxxx10x0x10011x
-                                             st1h.  */
-                                          return 1794;
-                                        }
-                                      else
+                                      if (((word >> 15) & 0x1) == 0)
                                         {
                                           if (((word >> 23) & 0x1) == 0)
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx10xxxxxx1100x10011x
-                                                 st1b.  */
-                                              return 1781;
+                                                 xxxxxxxxxxxxx100xxxxx1x00x10011x
+                                                 fmul.  */
+                                              return 1406;
                                             }
                                           else
+                                            {
+                                              if (((word >> 22) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx100xxxxx1010x10011x
+                                                     fmul.  */
+                                                  return 1407;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx100xxxxx1110x10011x
+                                                     fmul.  */
+                                                  return 1408;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx10xxxxxx1110x10011x
+                                                 xxxxxxxxxxxxx101xxxxx10x0x10011x
                                                  st1h.  */
-                                              return 1802;
+                                              return 1827;
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx101xxxxx1100x10011x
+                                                     st1b.  */
+                                                  return 1814;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx101xxxxx1110x10011x
+                                                     st1h.  */
+                                                  return 1835;
+                                                }
                                             }
                                         }
                                     }
@@ -7032,7 +7285,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx110xxxxx1000x10011x
                                                      st2b.  */
-                                                  return 1816;
+                                                  return 1849;
                                                 }
                                               else
                                                 {
@@ -7040,7 +7293,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx110xxxxx1010x10011x
                                                      st2h.  */
-                                                  return 1820;
+                                                  return 1853;
                                                 }
                                             }
                                           else
@@ -7051,7 +7304,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx110xxxxx1100x10011x
                                                      st4b.  */
-                                                  return 1832;
+                                                  return 1865;
                                                 }
                                               else
                                                 {
@@ -7059,7 +7312,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx110xxxxx1110x10011x
                                                      st4h.  */
-                                                  return 1836;
+                                                  return 1869;
                                                 }
                                             }
                                         }
@@ -7075,7 +7328,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx01000x10011x
                                                          st1b.  */
-                                                      return 1778;
+                                                      return 1811;
                                                     }
                                                   else
                                                     {
@@ -7083,7 +7336,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx01010x10011x
                                                          st1h.  */
-                                                      return 1799;
+                                                      return 1832;
                                                     }
                                                 }
                                               else
@@ -7094,7 +7347,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx01100x10011x
                                                          st1b.  */
-                                                      return 1782;
+                                                      return 1815;
                                                     }
                                                   else
                                                     {
@@ -7102,7 +7355,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx01110x10011x
                                                          st1h.  */
-                                                      return 1803;
+                                                      return 1836;
                                                     }
                                                 }
                                             }
@@ -7116,7 +7369,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx11000x10011x
                                                          st2b.  */
-                                                      return 1817;
+                                                      return 1850;
                                                     }
                                                   else
                                                     {
@@ -7124,7 +7377,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx11010x10011x
                                                          st2h.  */
-                                                      return 1821;
+                                                      return 1854;
                                                     }
                                                 }
                                               else
@@ -7135,7 +7388,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx11100x10011x
                                                          st4b.  */
-                                                      return 1833;
+                                                      return 1866;
                                                     }
                                                   else
                                                     {
@@ -7143,7 +7396,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxx11110x10011x
                                                          st4h.  */
-                                                      return 1837;
+                                                      return 1870;
                                                     }
                                                 }
                                             }
@@ -7174,7 +7427,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxxxxxxxxx00001x100000
                                                  orr.  */
-                                              return 1668;
+                                              return 1695;
                                             }
                                           else
                                             {
@@ -7221,7 +7474,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxxxx1xxxx10xx1x100000
                                              fcpy.  */
-                                          return 1352;
+                                          return 1356;
                                         }
                                     }
                                 }
@@ -7272,7 +7525,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0010010x1xx1x100000
                                                                  revb.  */
-                                                              return 1716;
+                                                              return 1743;
                                                             }
                                                           else
                                                             {
@@ -7280,7 +7533,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0010011x1xx1x100000
                                                                  splice.  */
-                                                              return 1737;
+                                                              return 1770;
                                                             }
                                                         }
                                                     }
@@ -7294,7 +7547,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0010100x1xx1x100000
                                                                  lasta.  */
-                                                              return 1434;
+                                                              return 1453;
                                                             }
                                                           else
                                                             {
@@ -7311,7 +7564,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx001011xx1xx1x100000
                                                              revw.  */
-                                                          return 1718;
+                                                          return 1745;
                                                         }
                                                     }
                                                 }
@@ -7344,7 +7597,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx001101xx1xx1x100000
                                                              revh.  */
-                                                          return 1717;
+                                                          return 1744;
                                                         }
                                                     }
                                                   else
@@ -7357,7 +7610,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxx0011100x1xx1x100000
                                                                  lastb.  */
-                                                              return 1436;
+                                                              return 1455;
                                                             }
                                                           else
                                                             {
@@ -7374,7 +7627,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx001111xx1xx1x100000
                                                              rbit.  */
-                                                          return 1709;
+                                                          return 1736;
                                                         }
                                                     }
                                                 }
@@ -7400,7 +7653,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxx01100xxxxx1xx1x100000
                                                          tbl.  */
-                                                      return 1860;
+                                                      return 1893;
                                                     }
                                                 }
                                               else
@@ -7427,7 +7680,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxxx1x100000011xx1x100000
                                                                          sunpklo.  */
-                                                                      return 1856;
+                                                                      return 1889;
                                                                     }
                                                                 }
                                                               else
@@ -7436,7 +7689,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxx1x1000001x1xx1x100000
                                                                      rev.  */
-                                                                  return 1715;
+                                                                  return 1742;
                                                                 }
                                                             }
                                                           else
@@ -7447,7 +7700,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxx1x100001x01xx1x100000
                                                                      insr.  */
-                                                                  return 1431;
+                                                                  return 1450;
                                                                 }
                                                               else
                                                                 {
@@ -7455,7 +7708,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxx1x100001x11xx1x100000
                                                                      insr.  */
-                                                                  return 1432;
+                                                                  return 1451;
                                                                 }
                                                             }
                                                         }
@@ -7465,7 +7718,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxx1x10001xxx1xx1x100000
                                                              uunpklo.  */
-                                                          return 1913;
+                                                          return 1952;
                                                         }
                                                     }
                                                   else
@@ -7476,7 +7729,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxx1x10010xxx1xx1x100000
                                                              sunpkhi.  */
-                                                          return 1855;
+                                                          return 1888;
                                                         }
                                                       else
                                                         {
@@ -7484,7 +7737,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxx1x10011xxx1xx1x100000
                                                              uunpkhi.  */
-                                                          return 1912;
+                                                          return 1951;
                                                         }
                                                     }
                                                 }
@@ -7501,7 +7754,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx1010xx001xx1x100000
                                                              lasta.  */
-                                                          return 1433;
+                                                          return 1452;
                                                         }
                                                       else
                                                         {
@@ -7529,7 +7782,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx1011xxx01xx1x100000
                                                          lastb.  */
-                                                      return 1435;
+                                                      return 1454;
                                                     }
                                                   else
                                                     {
@@ -7561,7 +7814,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx000010xxxx01xx1x100000
                                                                  zip1.  */
-                                                              return 1930;
+                                                              return 1969;
                                                             }
                                                           else
                                                             {
@@ -7573,7 +7826,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx0000100x0x11xx1x100000
                                                                          punpklo.  */
-                                                                      return 1708;
+                                                                      return 1735;
                                                                     }
                                                                   else
                                                                     {
@@ -7581,7 +7834,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx0000100x1x11xx1x100000
                                                                          rev.  */
-                                                                      return 1714;
+                                                                      return 1741;
                                                                     }
                                                                 }
                                                               else
@@ -7590,7 +7843,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx0000101xxx11xx1x100000
                                                                      punpkhi.  */
-                                                                  return 1707;
+                                                                  return 1734;
                                                                 }
                                                             }
                                                         }
@@ -7600,7 +7853,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx000110xxxxx1xx1x100000
                                                              zip1.  */
-                                                          return 1931;
+                                                          return 1970;
                                                         }
                                                     }
                                                   else
@@ -7611,7 +7864,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx001010xxxxx1xx1x100000
                                                              trn1.  */
-                                                          return 1861;
+                                                          return 1894;
                                                         }
                                                       else
                                                         {
@@ -7619,7 +7872,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx001110xxxxx1xx1x100000
                                                              trn1.  */
-                                                          return 1862;
+                                                          return 1895;
                                                         }
                                                     }
                                                 }
@@ -7631,7 +7884,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx01x010xxxxx1xx1x100000
                                                          uzp1.  */
-                                                      return 1917;
+                                                      return 1956;
                                                     }
                                                   else
                                                     {
@@ -7639,7 +7892,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx01x110xxxxx1xx1x100000
                                                          uzp1.  */
-                                                      return 1918;
+                                                      return 1957;
                                                     }
                                                 }
                                             }
@@ -7655,7 +7908,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx100010xxxxx1xx1x100000
                                                              zip2.  */
-                                                          return 1932;
+                                                          return 1971;
                                                         }
                                                       else
                                                         {
@@ -7663,7 +7916,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx100110xxxxx1xx1x100000
                                                              zip2.  */
-                                                          return 1933;
+                                                          return 1972;
                                                         }
                                                     }
                                                   else
@@ -7674,7 +7927,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx101010xxxxx1xx1x100000
                                                              trn2.  */
-                                                          return 1863;
+                                                          return 1896;
                                                         }
                                                       else
                                                         {
@@ -7682,7 +7935,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx101110xxxxx1xx1x100000
                                                              trn2.  */
-                                                          return 1864;
+                                                          return 1897;
                                                         }
                                                     }
                                                 }
@@ -7694,7 +7947,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx11x010xxxxx1xx1x100000
                                                          uzp2.  */
-                                                      return 1919;
+                                                      return 1958;
                                                     }
                                                   else
                                                     {
@@ -7702,7 +7955,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx11x110xxxxx1xx1x100000
                                                          uzp2.  */
-                                                      return 1920;
+                                                      return 1959;
                                                     }
                                                 }
                                             }
@@ -7713,7 +7966,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxxx11xxxxx1xx1x100000
                                              sel.  */
-                                          return 1727;
+                                          return 1760;
                                         }
                                     }
                                 }
@@ -7732,7 +7985,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx000xxxxxx0x1x100001
                                                  ldr.  */
-                                              return 1637;
+                                              return 1664;
                                             }
                                           else
                                             {
@@ -7740,7 +7993,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx000xxxxxx1x1x100001
                                                  prfb.  */
-                                              return 1681;
+                                              return 1708;
                                             }
                                         }
                                       else
@@ -7751,7 +8004,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx001xxxxxxx01x100001
                                                  ld1rsh.  */
-                                              return 1482;
+                                              return 1509;
                                             }
                                           else
                                             {
@@ -7759,7 +8012,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx001xxxxxxx11x100001
                                                  ld1rsb.  */
-                                              return 1479;
+                                              return 1506;
                                             }
                                         }
                                     }
@@ -7775,7 +8028,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxx0x01x100001
                                                      ld1w.  */
-                                                  return 1517;
+                                                  return 1544;
                                                 }
                                               else
                                                 {
@@ -7783,7 +8036,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxx1x01x100001
                                                      ld1w.  */
-                                                  return 1518;
+                                                  return 1545;
                                                 }
                                             }
                                           else
@@ -7794,7 +8047,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxxx011x100001
                                                      ldr.  */
-                                                  return 1638;
+                                                  return 1665;
                                                 }
                                               else
                                                 {
@@ -7802,7 +8055,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxxx111x100001
                                                      prfw.  */
-                                                  return 1702;
+                                                  return 1729;
                                                 }
                                             }
                                         }
@@ -7818,7 +8071,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0001x100001
                                                          prfw.  */
-                                                      return 1698;
+                                                      return 1725;
                                                     }
                                                   else
                                                     {
@@ -7826,7 +8079,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0011x100001
                                                          prfd.  */
-                                                      return 1684;
+                                                      return 1711;
                                                     }
                                                 }
                                               else
@@ -7835,7 +8088,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx10x1x100001
                                                      ld1w.  */
-                                                  return 1525;
+                                                  return 1552;
                                                 }
                                             }
                                           else
@@ -7846,7 +8099,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxxx101x100001
                                                      ld1rw.  */
-                                                  return 1485;
+                                                  return 1512;
                                                 }
                                               else
                                                 {
@@ -7854,7 +8107,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxxx111x100001
                                                      ld1rsb.  */
-                                                  return 1481;
+                                                  return 1508;
                                                 }
                                             }
                                         }
@@ -7870,7 +8123,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx100xxxxxxxx1x100001
                                              prfh.  */
-                                          return 1695;
+                                          return 1722;
                                         }
                                       else
                                         {
@@ -7880,7 +8133,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx101xxxxxxx01x100001
                                                  ld1rsh.  */
-                                              return 1483;
+                                              return 1510;
                                             }
                                           else
                                             {
@@ -7888,7 +8141,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx101xxxxxxx11x100001
                                                  ld1rsb.  */
-                                              return 1480;
+                                              return 1507;
                                             }
                                         }
                                     }
@@ -7904,7 +8157,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx110xxxxx0x01x100001
                                                      ldff1w.  */
-                                                  return 1603;
+                                                  return 1630;
                                                 }
                                               else
                                                 {
@@ -7912,7 +8165,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx110xxxxx1x01x100001
                                                      ldff1w.  */
-                                                  return 1604;
+                                                  return 1631;
                                                 }
                                             }
                                           else
@@ -7921,7 +8174,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx110xxxxxxx11x100001
                                                  prfd.  */
-                                              return 1688;
+                                              return 1715;
                                             }
                                         }
                                       else
@@ -7936,7 +8189,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx0001x100001
                                                          prfw.  */
-                                                      return 1701;
+                                                      return 1728;
                                                     }
                                                   else
                                                     {
@@ -7944,7 +8197,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx0011x100001
                                                          prfd.  */
-                                                      return 1687;
+                                                      return 1714;
                                                     }
                                                 }
                                               else
@@ -7953,7 +8206,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx10x1x100001
                                                      ldff1w.  */
-                                                  return 1611;
+                                                  return 1638;
                                                 }
                                             }
                                           else
@@ -7964,7 +8217,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxxx101x100001
                                                      ld1rw.  */
-                                                  return 1486;
+                                                  return 1513;
                                                 }
                                               else
                                                 {
@@ -7972,7 +8225,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxxx111x100001
                                                      ld1rd.  */
-                                                  return 1475;
+                                                  return 1494;
                                                 }
                                             }
                                         }
@@ -7994,7 +8247,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx000xxxxx0xx1x10001x
                                              ld1sw.  */
-                                          return 1511;
+                                          return 1538;
                                         }
                                       else
                                         {
@@ -8002,7 +8255,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx000xxxxx1xx1x10001x
                                              ld1sw.  */
-                                          return 1512;
+                                          return 1539;
                                         }
                                     }
                                   else
@@ -8013,7 +8266,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx001xxxxx0xx1x10001x
                                              ld1sw.  */
-                                          return 1513;
+                                          return 1540;
                                         }
                                       else
                                         {
@@ -8023,7 +8276,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx001xxxxx10x1x10001x
                                                  ld1sw.  */
-                                              return 1516;
+                                              return 1543;
                                             }
                                           else
                                             {
@@ -8031,7 +8284,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx001xxxxx11x1x10001x
                                                  ld1sw.  */
-                                              return 1514;
+                                              return 1541;
                                             }
                                         }
                                     }
@@ -8048,7 +8301,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx0x01x10001x
                                                  ld1w.  */
-                                              return 1521;
+                                              return 1548;
                                             }
                                           else
                                             {
@@ -8056,7 +8309,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx0x11x10001x
                                                  ld1d.  */
-                                              return 1451;
+                                              return 1470;
                                             }
                                         }
                                       else
@@ -8067,7 +8320,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx1x01x10001x
                                                  ld1w.  */
-                                              return 1522;
+                                              return 1549;
                                             }
                                           else
                                             {
@@ -8075,7 +8328,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx010xxxxx1x11x10001x
                                                  ld1d.  */
-                                              return 1452;
+                                              return 1471;
                                             }
                                         }
                                     }
@@ -8089,7 +8342,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx011xxxxx0x01x10001x
                                                  ld1w.  */
-                                              return 1523;
+                                              return 1550;
                                             }
                                           else
                                             {
@@ -8097,7 +8350,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx011xxxxx0x11x10001x
                                                  ld1d.  */
-                                              return 1453;
+                                              return 1472;
                                             }
                                         }
                                       else
@@ -8110,7 +8363,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1001x10001x
                                                      ld1w.  */
-                                                  return 1528;
+                                                  return 1555;
                                                 }
                                               else
                                                 {
@@ -8118,7 +8371,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1011x10001x
                                                      ld1d.  */
-                                                  return 1456;
+                                                  return 1475;
                                                 }
                                             }
                                           else
@@ -8129,7 +8382,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1101x10001x
                                                      ld1w.  */
-                                                  return 1524;
+                                                  return 1551;
                                                 }
                                               else
                                                 {
@@ -8137,7 +8390,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx011xxxxx1111x10001x
                                                      ld1d.  */
-                                                  return 1454;
+                                                  return 1473;
                                                 }
                                             }
                                         }
@@ -8156,7 +8409,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx100xxxxx0xx1x10001x
                                              ldff1sw.  */
-                                          return 1598;
+                                          return 1625;
                                         }
                                       else
                                         {
@@ -8164,7 +8417,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx100xxxxx1xx1x10001x
                                              ldff1sw.  */
-                                          return 1599;
+                                          return 1626;
                                         }
                                     }
                                   else
@@ -8175,7 +8428,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx101xxxxx0xx1x10001x
                                              ldff1sw.  */
-                                          return 1600;
+                                          return 1627;
                                         }
                                       else
                                         {
@@ -8185,7 +8438,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx101xxxxx10x1x10001x
                                                  ldff1sw.  */
-                                              return 1602;
+                                              return 1629;
                                             }
                                           else
                                             {
@@ -8193,7 +8446,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx101xxxxx11x1x10001x
                                                  ldff1sw.  */
-                                              return 1601;
+                                              return 1628;
                                             }
                                         }
                                     }
@@ -8210,7 +8463,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx110xxxxx0x01x10001x
                                                  ldff1w.  */
-                                              return 1607;
+                                              return 1634;
                                             }
                                           else
                                             {
@@ -8218,7 +8471,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx110xxxxx0x11x10001x
                                                  ldff1d.  */
-                                              return 1563;
+                                              return 1590;
                                             }
                                         }
                                       else
@@ -8229,7 +8482,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx110xxxxx1x01x10001x
                                                  ldff1w.  */
-                                              return 1608;
+                                              return 1635;
                                             }
                                           else
                                             {
@@ -8237,7 +8490,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx110xxxxx1x11x10001x
                                                  ldff1d.  */
-                                              return 1564;
+                                              return 1591;
                                             }
                                         }
                                     }
@@ -8253,7 +8506,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx0001x10001x
                                                      prfw.  */
-                                                  return 1703;
+                                                  return 1730;
                                                 }
                                               else
                                                 {
@@ -8261,7 +8514,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx0011x10001x
                                                      prfd.  */
-                                                  return 1689;
+                                                  return 1716;
                                                 }
                                             }
                                           else
@@ -8272,7 +8525,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx0101x10001x
                                                      ldff1w.  */
-                                                  return 1609;
+                                                  return 1636;
                                                 }
                                               else
                                                 {
@@ -8280,7 +8533,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx0111x10001x
                                                      ldff1d.  */
-                                                  return 1565;
+                                                  return 1592;
                                                 }
                                             }
                                         }
@@ -8294,7 +8547,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx1001x10001x
                                                      ldff1w.  */
-                                                  return 1612;
+                                                  return 1639;
                                                 }
                                               else
                                                 {
@@ -8302,7 +8555,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx1011x10001x
                                                      ldff1d.  */
-                                                  return 1567;
+                                                  return 1594;
                                                 }
                                             }
                                           else
@@ -8313,7 +8566,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx1101x10001x
                                                      ldff1w.  */
-                                                  return 1610;
+                                                  return 1637;
                                                 }
                                               else
                                                 {
@@ -8321,7 +8574,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx111xxxxx1111x10001x
                                                      ldff1d.  */
-                                                  return 1566;
+                                                  return 1593;
                                                 }
                                             }
                                         }
@@ -8340,17 +8593,50 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                 {
                                   if (((word >> 30) & 0x1) == 0)
                                     {
-                                      if (((word >> 4) & 0x1) == 0)
+                                      if (((word >> 21) & 0x1) == 0)
                                         {
-                                          if (((word >> 21) & 0x1) == 0)
+                                          if (((word >> 31) & 0x1) == 0)
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxx0xxxxxxxx000xxxxx0xx1x10010x
-                                                 cmpge.  */
-                                              return 1278;
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx0xxxxxxxx000xxxxx0xx1x100100
+                                                     cmpge.  */
+                                                  return 1278;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx1xxxxxxxx000xxxxx0xx1x100100
+                                                     cmpgt.  */
+                                                  return 1281;
+                                                }
                                             }
                                           else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx000xxxxx0x01x100101
+                                                     ld1rqw.  */
+                                                  return 1505;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx000xxxxx0x11x100101
+                                                     ld1rqd.  */
+                                                  return 1501;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 4) & 0x1) == 0)
                                             {
                                               if (((word >> 11) & 0x1) == 0)
                                                 {
@@ -8360,7 +8646,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx0xxxxxx00000xxxxx1xx1x10010x
                                                          whilelt.  */
-                                                      return 1927;
+                                                      return 1966;
                                                     }
                                                   else
                                                     {
@@ -8368,7 +8654,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx0xxxxxx01000xxxxx1xx1x10010x
                                                          whilelt.  */
-                                                      return 1928;
+                                                      return 1967;
                                                     }
                                                 }
                                               else
@@ -8379,7 +8665,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx0xxxxxx10000xxxxx1xx1x10010x
                                                          whilelo.  */
-                                                      return 1923;
+                                                      return 1962;
                                                     }
                                                   else
                                                     {
@@ -8387,21 +8673,10 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx0xxxxxx11000xxxxx1xx1x10010x
                                                          whilelo.  */
-                                                      return 1924;
+                                                      return 1963;
                                                     }
                                                 }
                                             }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 21) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxx1xxxxxxxx000xxxxx0xx1x10010x
-                                                 cmpgt.  */
-                                              return 1281;
-                                            }
                                           else
                                             {
                                               if (((word >> 11) & 0x1) == 0)
@@ -8412,7 +8687,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx1xxxxxx00000xxxxx1xx1x10010x
                                                          whilele.  */
-                                                      return 1921;
+                                                      return 1960;
                                                     }
                                                   else
                                                     {
@@ -8420,7 +8695,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx1xxxxxx01000xxxxx1xx1x10010x
                                                          whilele.  */
-                                                      return 1922;
+                                                      return 1961;
                                                     }
                                                 }
                                               else
@@ -8431,7 +8706,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx1xxxxxx10000xxxxx1xx1x10010x
                                                          whilels.  */
-                                                      return 1925;
+                                                      return 1964;
                                                     }
                                                   else
                                                     {
@@ -8439,7 +8714,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxx1xxxxxx11000xxxxx1xx1x10010x
                                                          whilels.  */
-                                                      return 1926;
+                                                      return 1965;
                                                     }
                                                 }
                                             }
@@ -8469,7 +8744,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx010000xxxxx0xx1x100110
                                                              fmul.  */
-                                                          return 1387;
+                                                          return 1403;
                                                         }
                                                       else
                                                         {
@@ -8477,7 +8752,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx011000xxxxx0xx1x100110
                                                              frecps.  */
-                                                          return 1397;
+                                                          return 1416;
                                                         }
                                                     }
                                                 }
@@ -8489,7 +8764,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxx10x000xxxxx0xx1x100110
                                                          fsub.  */
-                                                      return 1410;
+                                                      return 1429;
                                                     }
                                                   else
                                                     {
@@ -8499,7 +8774,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx110000xxxxx0xx1x100110
                                                              ftsmul.  */
-                                                          return 1416;
+                                                          return 1435;
                                                         }
                                                       else
                                                         {
@@ -8507,7 +8782,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx111000xxxxx0xx1x100110
                                                              frsqrts.  */
-                                                          return 1407;
+                                                          return 1426;
                                                         }
                                                     }
                                                 }
@@ -8518,7 +8793,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                  10987654321098765432109876543210
                                                  xxxxxxxxxxxxx000xxxxx1xx1x100110
                                                  fmla.  */
-                                              return 1384;
+                                              return 1394;
                                             }
                                         }
                                       else
@@ -8527,7 +8802,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx000xxxxxxxx1x100111
                                              str.  */
-                                          return 1848;
+                                          return 1881;
                                         }
                                     }
                                 }
@@ -8537,21 +8812,43 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                     {
                                       if (((word >> 30) & 0x1) == 0)
                                         {
-                                          if (((word >> 4) & 0x1) == 0)
+                                          if (((word >> 31) & 0x1) == 0)
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxx0xxxxxxxx100xxxxx0xx1x10010x
-                                                 cmplt.  */
-                                              return 1295;
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx0xxxxxxxx100xxxxx0xx1x100100
+                                                     cmplt.  */
+                                                  return 1295;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx1xxxxxxxx100xxxxx0xx1x100100
+                                                     cmple.  */
+                                                  return 1289;
+                                                }
                                             }
                                           else
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxx1xxxxxxxx100xxxxx0xx1x10010x
-                                                 cmple.  */
-                                              return 1289;
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx100xxxxx0x01x100101
+                                                     ld1rqw.  */
+                                                  return 1504;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx100xxxxx0x11x100101
+                                                     ld1rqd.  */
+                                                  return 1500;
+                                                }
                                             }
                                         }
                                       else
@@ -8580,7 +8877,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxx0xxxxxxxx100000010xx1x10011x
                                                                      fcmge.  */
-                                                                  return 1343;
+                                                                  return 1347;
                                                                 }
                                                               else
                                                                 {
@@ -8588,7 +8885,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxx1xxxxxxxx100000010xx1x10011x
                                                                      fcmgt.  */
-                                                                  return 1345;
+                                                                  return 1349;
                                                                 }
                                                             }
                                                         }
@@ -8607,7 +8904,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx100001xx0xx1x10011x
                                                          fmaxnmv.  */
-                                                      return 1376;
+                                                      return 1386;
                                                     }
                                                 }
                                               else
@@ -8618,7 +8915,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx100010xx0xx1x10011x
                                                          fcmeq.  */
-                                                      return 1341;
+                                                      return 1345;
                                                     }
                                                   else
                                                     {
@@ -8628,7 +8925,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx1000110x0xx1x10011x
                                                              fmaxv.  */
-                                                          return 1377;
+                                                          return 1387;
                                                         }
                                                       else
                                                         {
@@ -8636,7 +8933,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx1000111x0xx1x10011x
                                                              frecpe.  */
-                                                          return 1396;
+                                                          return 1415;
                                                         }
                                                     }
                                                 }
@@ -8653,7 +8950,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxx0xxxxxxxx100100xx0xx1x10011x
                                                              fcmlt.  */
-                                                          return 1348;
+                                                          return 1352;
                                                         }
                                                       else
                                                         {
@@ -8661,7 +8958,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxx1xxxxxxxx100100xx0xx1x10011x
                                                              fcmle.  */
-                                                          return 1347;
+                                                          return 1351;
                                                         }
                                                     }
                                                   else
@@ -8670,7 +8967,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx100101xx0xx1x10011x
                                                          fminnmv.  */
-                                                      return 1382;
+                                                      return 1392;
                                                     }
                                                 }
                                               else
@@ -8681,7 +8978,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx100110xx0xx1x10011x
                                                          fcmne.  */
-                                                      return 1349;
+                                                      return 1353;
                                                     }
                                                   else
                                                     {
@@ -8691,7 +8988,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx1001110x0xx1x10011x
                                                              fminv.  */
-                                                          return 1383;
+                                                          return 1393;
                                                         }
                                                       else
                                                         {
@@ -8699,7 +8996,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx1001111x0xx1x10011x
                                                              frsqrte.  */
-                                                          return 1406;
+                                                          return 1425;
                                                         }
                                                     }
                                                 }
@@ -8733,20 +9030,20 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                              10987654321098765432109876543210
                                              xxxxxxxxxxxxx100xxxxx1xx1x10011x
                                              fmls.  */
-                                          return 1385;
+                                          return 1398;
                                         }
                                     }
                                 }
                             }
                           else
                             {
-                              if (((word >> 23) & 0x1) == 0)
+                              if (((word >> 30) & 0x1) == 0)
                                 {
                                   if (((word >> 21) & 0x1) == 0)
                                     {
                                       if (((word >> 22) & 0x1) == 0)
                                         {
-                                          if (((word >> 30) & 0x1) == 0)
+                                          if (((word >> 23) & 0x1) == 0)
                                             {
                                               if (((word >> 31) & 0x1) == 0)
                                                 {
@@ -8797,17 +9094,91 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                         {
                                                           /* 33222222222211111111110000000000
                                                              10987654321098765432109876543210
-                                                             xxxx0xxxx1xxxx10xxxxx0001x100100
-                                                             eor.  */
-                                                          return 1328;
+                                                             xxxx0xxxx1xxxx10xxxxx0001x100100
+                                                             eor.  */
+                                                          return 1328;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxx1xxxx1xxxx10xxxxx0001x100100
+                                                             sel.  */
+                                                          return 1761;
+                                                        }
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 13) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx010xxxxx0001x100101
+                                                         ld1sh.  */
+                                                      return 1527;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx110xxxxx0001x100101
+                                                         ldff1sh.  */
+                                                      return 1616;
+                                                    }
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 31) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 9) & 0x1) == 0)
+                                                    {
+                                                      if (((word >> 20) & 0x1) == 0)
+                                                        {
+                                                          if (((word >> 4) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxx0xxxx0xxxx10xxxx00011x100100
+                                                                 orr.  */
+                                                              return 1697;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxx1xxxx0xxxx10xxxx00011x100100
+                                                                 orn.  */
+                                                              return 1692;
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxx0xxxx10xxxx10011x100100
+                                                             brkb.  */
+                                                          return 1257;
+                                                        }
+                                                    }
+                                                  else
+                                                    {
+                                                      if (((word >> 4) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxx0xxxx1xxxx10xxxxx0011x100100
+                                                             nor.  */
+                                                          return 1689;
                                                         }
                                                       else
                                                         {
                                                           /* 33222222222211111111110000000000
                                                              10987654321098765432109876543210
-                                                             xxxx1xxxx1xxxx10xxxxx0001x100100
-                                                             sel.  */
-                                                          return 1728;
+                                                             xxxx1xxxx1xxxx10xxxxx0011x100100
+                                                             nand.  */
+                                                          return 1686;
                                                         }
                                                     }
                                                 }
@@ -8817,32 +9188,24 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx010xxxxx0001x100101
-                                                         ld1sh.  */
-                                                      return 1500;
+                                                         xxxxxxxxxxxxx010xxxxx0011x100101
+                                                         ld1sb.  */
+                                                      return 1515;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx0001x100101
-                                                         ldff1sh.  */
-                                                      return 1589;
+                                                         xxxxxxxxxxxxx110xxxxx0011x100101
+                                                         ldff1sb.  */
+                                                      return 1607;
                                                     }
                                                 }
                                             }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxxx10xxxxx0001x10011x
-                                                 stnt1w.  */
-                                              return 1846;
-                                            }
                                         }
                                       else
                                         {
-                                          if (((word >> 30) & 0x1) == 0)
+                                          if (((word >> 23) & 0x1) == 0)
                                             {
                                               if (((word >> 31) & 0x1) == 0)
                                                 {
@@ -8904,7 +9267,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx010xxxxx0101x100101
                                                          ld1w.  */
-                                                      return 1519;
+                                                      return 1546;
                                                     }
                                                   else
                                                     {
@@ -8912,183 +9275,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx0101x100101
                                                          ldff1w.  */
-                                                      return 1605;
-                                                    }
-                                                }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 13) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxx0101x10011x
-                                                     st1w.  */
-                                                  return 1808;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx0101x10011x
-                                                     st3w.  */
-                                                  return 1830;
-                                                }
-                                            }
-                                        }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 13) & 0x1) == 0)
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx010xxxxx1001x1001xx
-                                                 ld1sh.  */
-                                              return 1501;
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 30) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxx1101x10010x
-                                                     ld1w.  */
-                                                  return 1520;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxx1101x10011x
-                                                     st1w.  */
-                                                  return 1810;
-                                                }
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              if (((word >> 30) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx1001x10010x
-                                                     ldff1sh.  */
-                                                  return 1590;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx1001x10011x
-                                                     st2w.  */
-                                                  return 1822;
-                                                }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 30) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx1101x10010x
-                                                     ldff1w.  */
-                                                  return 1606;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx1101x10011x
-                                                     st4w.  */
-                                                  return 1838;
-                                                }
-                                            }
-                                        }
-                                    }
-                                }
-                              else
-                                {
-                                  if (((word >> 30) & 0x1) == 0)
-                                    {
-                                      if (((word >> 21) & 0x1) == 0)
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              if (((word >> 31) & 0x1) == 0)
-                                                {
-                                                  if (((word >> 9) & 0x1) == 0)
-                                                    {
-                                                      if (((word >> 20) & 0x1) == 0)
-                                                        {
-                                                          if (((word >> 4) & 0x1) == 0)
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxx0xxxx0xxxx10xxxx00011x100100
-                                                                 orr.  */
-                                                              return 1670;
-                                                            }
-                                                          else
-                                                            {
-                                                              /* 33222222222211111111110000000000
-                                                                 10987654321098765432109876543210
-                                                                 xxxx1xxxx0xxxx10xxxx00011x100100
-                                                                 orn.  */
-                                                              return 1665;
-                                                            }
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxx0xxxx10xxxx10011x100100
-                                                             brkb.  */
-                                                          return 1257;
-                                                        }
-                                                    }
-                                                  else
-                                                    {
-                                                      if (((word >> 4) & 0x1) == 0)
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxx0xxxx1xxxx10xxxxx0011x100100
-                                                             nor.  */
-                                                          return 1662;
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxx1xxxx1xxxx10xxxxx0011x100100
-                                                             nand.  */
-                                                          return 1659;
-                                                        }
-                                                    }
-                                                }
-                                              else
-                                                {
-                                                  if (((word >> 13) & 0x1) == 0)
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx010xxxxx0011x100101
-                                                         ld1sb.  */
-                                                      return 1488;
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx0011x100101
-                                                         ldff1sb.  */
-                                                      return 1580;
+                                                      return 1632;
                                                     }
                                                 }
                                             }
@@ -9106,7 +9293,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxx0xxxx0xxxx10xxxx00111x100100
                                                                  orrs.  */
-                                                              return 1671;
+                                                              return 1698;
                                                             }
                                                           else
                                                             {
@@ -9123,7 +9310,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxx0xxxx1xxxx10xxxxx0111x100100
                                                              nors.  */
-                                                          return 1663;
+                                                          return 1690;
                                                         }
                                                     }
                                                   else
@@ -9134,7 +9321,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxx1xxxx0xxxx10xxxxx0111x100100
                                                              orns.  */
-                                                          return 1666;
+                                                          return 1693;
                                                         }
                                                       else
                                                         {
@@ -9142,7 +9329,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxx1xxxx1xxxx10xxxxx0111x100100
                                                              nands.  */
-                                                          return 1660;
+                                                          return 1687;
                                                         }
                                                     }
                                                 }
@@ -9154,7 +9341,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx010xxxxx0111x100101
                                                          ld1sb.  */
-                                                      return 1490;
+                                                      return 1517;
                                                     }
                                                   else
                                                     {
@@ -9162,139 +9349,227 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx0111x100101
                                                          ldff1sb.  */
-                                                      return 1582;
+                                                      return 1609;
                                                     }
                                                 }
                                             }
                                         }
-                                      else
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 13) & 0x1) == 0)
                                         {
-                                          if (((word >> 13) & 0x1) == 0)
+                                          if (((word >> 22) & 0x1) == 0)
                                             {
-                                              if (((word >> 22) & 0x1) == 0)
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx1001x10010x
+                                                     ld1sh.  */
+                                                  return 1528;
+                                                }
+                                              else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxx010xxxxx1011x10010x
                                                      ld1sb.  */
-                                                  return 1489;
+                                                  return 1516;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx1101x10010x
+                                                     ld1w.  */
+                                                  return 1547;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx1111x10010x
+                                                     ld1d.  */
+                                                  return 1469;
+                                                }
+                                            }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 22) & 0x1) == 0)
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx110xxxxx1001x10010x
+                                                     ldff1sh.  */
+                                                  return 1617;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx110xxxxx1011x10010x
+                                                     ldff1sb.  */
+                                                  return 1608;
+                                                }
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 23) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx110xxxxx1101x10010x
+                                                     ldff1w.  */
+                                                  return 1633;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxx1111x10010x
-                                                     ld1d.  */
-                                                  return 1450;
+                                                     xxxxxxxxxxxxx110xxxxx1111x10010x
+                                                     ldff1d.  */
+                                                  return 1589;
                                                 }
                                             }
-                                          else
+                                        }
+                                    }
+                                }
+                              else
+                                {
+                                  if (((word >> 13) & 0x1) == 0)
+                                    {
+                                      if (((word >> 31) & 0x1) == 0)
+                                        {
+                                          if (((word >> 21) & 0x1) == 0)
                                             {
-                                              if (((word >> 22) & 0x1) == 0)
+                                              if (((word >> 4) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx1011x10010x
-                                                     ldff1sb.  */
-                                                  return 1581;
+                                                     xxxx0xxxxxxxx010xxxxx0xx1x100110
+                                                     fcmge.  */
+                                                  return 1348;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx1111x10010x
-                                                     ldff1d.  */
-                                                  return 1562;
+                                                     xxxx1xxxxxxxx010xxxxx0xx1x100110
+                                                     fcmgt.  */
+                                                  return 1350;
                                                 }
                                             }
+                                          else
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx010xxxxx1xx1x100110
+                                                 fnmla.  */
+                                              return 1412;
+                                            }
                                         }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 13) & 0x1) == 0)
+                                      else
                                         {
-                                          if (((word >> 31) & 0x1) == 0)
+                                          if (((word >> 22) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx010xxxxxx0x1x100111
+                                                 str.  */
+                                              return 1882;
+                                            }
+                                          else
                                             {
                                               if (((word >> 21) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 4) & 0x1) == 0)
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxxxxxxxxxxx010xxxxx01x1x100111
+                                                     st1w.  */
+                                                  return 1841;
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxx0xxxxxxxx010xxxxx0x11x100110
-                                                         fcmge.  */
-                                                      return 1344;
+                                                         xxxxxxxxxxxxx010xxxxx1101x100111
+                                                         st1w.  */
+                                                      return 1843;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxx1xxxxxxxx010xxxxx0x11x100110
-                                                         fcmgt.  */
-                                                      return 1346;
+                                                         xxxxxxxxxxxxx010xxxxx1111x100111
+                                                         st1d.  */
+                                                      return 1820;
                                                     }
                                                 }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxx1x11x100110
-                                                     fnmla.  */
-                                                  return 1393;
-                                                }
                                             }
-                                          else
+                                        }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 21) & 0x1) == 0)
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
                                             {
-                                              if (((word >> 22) & 0x1) == 0)
+                                              if (((word >> 4) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxxx011x100111
-                                                     str.  */
-                                                  return 1849;
+                                                     xxxx0xxxxxxxx110xxxxx0xx1x100110
+                                                     fcmeq.  */
+                                                  return 1346;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx010xxxxxx111x100111
-                                                     st1d.  */
-                                                  return 1787;
+                                                     xxxx1xxxxxxxx110xxxxx0xx1x100110
+                                                     fcmne.  */
+                                                  return 1354;
                                                 }
                                             }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 21) & 0x1) == 0)
+                                          else
                                             {
-                                              if (((word >> 31) & 0x1) == 0)
+                                              if (((word >> 22) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 4) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxx0xxxxxxxx110xxxxx0x11x100110
-                                                         fcmeq.  */
-                                                      return 1342;
+                                                         xxxxxxxxxxxxx110xxxxx0001x100111
+                                                         stnt1w.  */
+                                                      return 1879;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxx1xxxxxxxx110xxxxx0x11x100110
-                                                         fcmne.  */
-                                                      return 1350;
+                                                         xxxxxxxxxxxxx110xxxxx0011x100111
+                                                         stnt1d.  */
+                                                      return 1875;
                                                     }
                                                 }
                                               else
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx0011x100111
-                                                         stnt1d.  */
-                                                      return 1842;
+                                                         xxxxxxxxxxxxx110xxxxx0101x100111
+                                                         st3w.  */
+                                                      return 1863;
                                                     }
                                                   else
                                                     {
@@ -9302,29 +9577,51 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx0111x100111
                                                          st3d.  */
-                                                      return 1826;
+                                                      return 1859;
                                                     }
                                                 }
                                             }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx110xxxxx1xx1x100110
+                                                 fnmls.  */
+                                              return 1413;
+                                            }
                                           else
                                             {
-                                              if (((word >> 31) & 0x1) == 0)
+                                              if (((word >> 22) & 0x1) == 0)
                                                 {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx110xxxxx1x11x100110
-                                                     fnmls.  */
-                                                  return 1394;
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx110xxxxx1001x100111
+                                                         st2w.  */
+                                                      return 1855;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx110xxxxx1011x100111
+                                                         st2d.  */
+                                                      return 1851;
+                                                    }
                                                 }
                                               else
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx110xxxxx1011x100111
-                                                         st2d.  */
-                                                      return 1818;
+                                                         xxxxxxxxxxxxx110xxxxx1101x100111
+                                                         st4w.  */
+                                                      return 1871;
                                                     }
                                                   else
                                                     {
@@ -9332,7 +9629,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx110xxxxx1111x100111
                                                          st4d.  */
-                                                      return 1834;
+                                                      return 1867;
                                                     }
                                                 }
                                             }
@@ -9380,7 +9677,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx00001x10010x
                                                          ld1sh.  */
-                                                      return 1507;
+                                                      return 1534;
                                                     }
                                                   else
                                                     {
@@ -9388,7 +9685,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx00011x10010x
                                                          ld1sb.  */
-                                                      return 1494;
+                                                      return 1521;
                                                     }
                                                 }
                                               else
@@ -9399,7 +9696,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx00101x10010x
                                                          ld1w.  */
-                                                      return 1526;
+                                                      return 1553;
                                                     }
                                                   else
                                                     {
@@ -9407,7 +9704,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx00111x10010x
                                                          ld1sb.  */
-                                                      return 1496;
+                                                      return 1523;
                                                     }
                                                 }
                                             }
@@ -9421,7 +9718,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx10001x10010x
                                                          ldnf1sh.  */
-                                                      return 1624;
+                                                      return 1651;
                                                     }
                                                   else
                                                     {
@@ -9429,7 +9726,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx10011x10010x
                                                          ldnf1sb.  */
-                                                      return 1621;
+                                                      return 1648;
                                                     }
                                                 }
                                               else
@@ -9440,7 +9737,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx10101x10010x
                                                          ldnf1w.  */
-                                                      return 1627;
+                                                      return 1654;
                                                     }
                                                   else
                                                     {
@@ -9448,7 +9745,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx101xxxx10111x10010x
                                                          ldnf1sb.  */
-                                                      return 1623;
+                                                      return 1650;
                                                     }
                                                 }
                                             }
@@ -9489,7 +9786,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxx0xxxxxxxxx110xx010xx1x100100
                                                              ptest.  */
-                                                          return 1704;
+                                                          return 1731;
                                                         }
                                                       else
                                                         {
@@ -9503,7 +9800,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxx0xxxxx0x00110xx110xx1x100100
                                                                          pfirst.  */
-                                                                      return 1674;
+                                                                      return 1701;
                                                                     }
                                                                   else
                                                                     {
@@ -9511,7 +9808,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxx0xxxxx0x01110xx110xx1x100100
                                                                          ptrue.  */
-                                                                      return 1705;
+                                                                      return 1732;
                                                                     }
                                                                 }
                                                               else
@@ -9522,7 +9819,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxx0xxxxx0x1x110xx1100x1x100100
                                                                          rdffr.  */
-                                                                      return 1711;
+                                                                      return 1738;
                                                                     }
                                                                   else
                                                                     {
@@ -9530,7 +9827,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxx0xxxxx0x1x110xx1101x1x100100
                                                                          rdffrs.  */
-                                                                      return 1712;
+                                                                      return 1739;
                                                                     }
                                                                 }
                                                             }
@@ -9540,7 +9837,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxx0xxxxx1xxx110xx110xx1x100100
                                                                  pfalse.  */
-                                                              return 1673;
+                                                              return 1700;
                                                             }
                                                         }
                                                     }
@@ -9554,7 +9851,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxx0xxxxx0x0x111xxx10xx1x100100
                                                                  ptrues.  */
-                                                              return 1706;
+                                                              return 1733;
                                                             }
                                                           else
                                                             {
@@ -9562,7 +9859,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxx0xxxxx0x1x111xxx10xx1x100100
                                                                  rdffr.  */
-                                                              return 1710;
+                                                              return 1737;
                                                             }
                                                         }
                                                       else
@@ -9571,7 +9868,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxx0xxxxx1xxx111xxx10xx1x100100
                                                              pnext.  */
-                                                          return 1675;
+                                                          return 1702;
                                                         }
                                                     }
                                                 }
@@ -9608,7 +9905,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0001x100101
                                                          ldnt1w.  */
-                                                      return 1635;
+                                                      return 1662;
                                                     }
                                                   else
                                                     {
@@ -9616,7 +9913,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0011x100101
                                                          ldnt1d.  */
-                                                      return 1631;
+                                                      return 1658;
                                                     }
                                                 }
                                               else
@@ -9627,7 +9924,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0101x100101
                                                          ld3w.  */
-                                                      return 1543;
+                                                      return 1570;
                                                     }
                                                   else
                                                     {
@@ -9635,180 +9932,65 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx0111x100101
                                                          ld3d.  */
-                                                      return 1539;
+                                                      return 1566;
                                                     }
                                                 }
                                             }
                                           else
                                             {
                                               if (((word >> 22) & 0x1) == 0)
-                                                {
-                                                  if (((word >> 23) & 0x1) == 0)
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0001x100101
-                                                         ldnt1w.  */
-                                                      return 1636;
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0011x100101
-                                                         ldnt1d.  */
-                                                      return 1632;
-                                                    }
-                                                }
-                                              else
-                                                {
-                                                  if (((word >> 23) & 0x1) == 0)
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0101x100101
-                                                         ld3w.  */
-                                                      return 1544;
-                                                    }
-                                                  else
-                                                    {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0111x100101
-                                                         ld3d.  */
-                                                      return 1540;
-                                                    }
-                                                }
-                                            }
-                                        }
-                                    }
-                                }
-                              else
-                                {
-                                  if (((word >> 13) & 0x1) == 0)
-                                    {
-                                      if (((word >> 23) & 0x1) == 0)
-                                        {
-                                          if (((word >> 22) & 0x1) == 0)
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx0001x10011x
-                                                 st1w.  */
-                                              return 1804;
-                                            }
-                                          else
-                                            {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx0101x10011x
-                                                 st1w.  */
-                                              return 1809;
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 31) & 0x1) == 0)
-                                            {
-                                              if (((word >> 14) & 0x1) == 0)
-                                                {
-                                                  if (((word >> 19) & 0x1) == 0)
-                                                    {
-                                                      if (((word >> 20) & 0x1) == 0)
-                                                        {
-                                                          if (((word >> 16) & 0x1) == 0)
-                                                            {
-                                                              if (((word >> 17) & 0x1) == 0)
-                                                                {
-                                                                  if (((word >> 18) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001000000x11x100110
-                                                                         fadd.  */
-                                                                      return 1337;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001001000x11x100110
-                                                                         fmaxnm.  */
-                                                                      return 1374;
-                                                                    }
-                                                                }
-                                                              else
-                                                                {
-                                                                  if (((word >> 18) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001010000x11x100110
-                                                                         fmul.  */
-                                                                      return 1388;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001011000x11x100110
-                                                                         fmax.  */
-                                                                      return 1372;
-                                                                    }
-                                                                }
-                                                            }
-                                                          else
-                                                            {
-                                                              if (((word >> 17) & 0x1) == 0)
-                                                                {
-                                                                  if (((word >> 18) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001100000x11x100110
-                                                                         fsub.  */
-                                                                      return 1411;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001101000x11x100110
-                                                                         fminnm.  */
-                                                                      return 1380;
-                                                                    }
-                                                                }
-                                                              else
-                                                                {
-                                                                  if (((word >> 18) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001110000x11x100110
-                                                                         fsubr.  */
-                                                                      return 1413;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001111000x11x100110
-                                                                         fmin.  */
-                                                                      return 1378;
-                                                                    }
-                                                                }
-                                                            }
-                                                        }
-                                                      else
-                                                        {
-                                                          /* 33222222222211111111110000000000
-                                                             10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx001xxx010x11x100110
-                                                             ftmad.  */
-                                                          return 1415;
-                                                        }
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx0001x100101
+                                                         ldnt1w.  */
+                                                      return 1663;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx0011x100101
+                                                         ldnt1d.  */
+                                                      return 1659;
+                                                    }
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx0101x100101
+                                                         ld3w.  */
+                                                      return 1571;
                                                     }
                                                   else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx111xxxxx0111x100101
+                                                         ld3d.  */
+                                                      return 1567;
+                                                    }
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                              else
+                                {
+                                  if (((word >> 13) & 0x1) == 0)
+                                    {
+                                      if (((word >> 31) & 0x1) == 0)
+                                        {
+                                          if (((word >> 14) & 0x1) == 0)
+                                            {
+                                              if (((word >> 19) & 0x1) == 0)
+                                                {
+                                                  if (((word >> 20) & 0x1) == 0)
                                                     {
                                                       if (((word >> 16) & 0x1) == 0)
                                                         {
@@ -9816,71 +9998,38 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                             {
                                                               if (((word >> 18) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001000100x11x100110
-                                                                         fabd.  */
-                                                                      return 1332;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001000110x11x100110
-                                                                         fadd.  */
-                                                                      return 1338;
-                                                                    }
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001000000xx1x100110
+                                                                     fadd.  */
+                                                                  return 1337;
                                                                 }
                                                               else
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001001100x11x100110
-                                                                         fdivr.  */
-                                                                      return 1368;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001001110x11x100110
-                                                                         fmaxnm.  */
-                                                                      return 1375;
-                                                                    }
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001001000xx1x100110
+                                                                     fmaxnm.  */
+                                                                  return 1384;
                                                                 }
                                                             }
                                                           else
                                                             {
                                                               if (((word >> 18) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001010100x11x100110
-                                                                         fmulx.  */
-                                                                      return 1390;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001010110x11x100110
-                                                                         fmul.  */
-                                                                      return 1389;
-                                                                    }
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001010000xx1x100110
+                                                                     fmul.  */
+                                                                  return 1404;
                                                                 }
                                                               else
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
-                                                                     xxxxxxxxxxxxx0010111x0x11x100110
+                                                                     xxxxxxxxxxxxx001011000xx1x100110
                                                                      fmax.  */
-                                                                  return 1373;
+                                                                  return 1382;
                                                                 }
                                                             }
                                                         }
@@ -9890,41 +10039,19 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                             {
                                                               if (((word >> 18) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001100100x11x100110
-                                                                         fscale.  */
-                                                                      return 1408;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001100110x11x100110
-                                                                         fsub.  */
-                                                                      return 1412;
-                                                                    }
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001100000xx1x100110
+                                                                     fsub.  */
+                                                                  return 1430;
                                                                 }
                                                               else
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001101100x11x100110
-                                                                         fdiv.  */
-                                                                      return 1367;
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx001101110x11x100110
-                                                                         fminnm.  */
-                                                                      return 1381;
-                                                                    }
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001101000xx1x100110
+                                                                     fminnm.  */
+                                                                  return 1390;
                                                                 }
                                                             }
                                                           else
@@ -9933,156 +10060,315 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
-                                                                     xxxxxxxxxxxxx0011101x0x11x100110
+                                                                     xxxxxxxxxxxxx001110000xx1x100110
                                                                      fsubr.  */
-                                                                  return 1414;
+                                                                  return 1432;
                                                                 }
                                                               else
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
-                                                                     xxxxxxxxxxxxx0011111x0x11x100110
+                                                                     xxxxxxxxxxxxx001111000xx1x100110
                                                                      fmin.  */
-                                                                  return 1379;
+                                                                  return 1388;
                                                                 }
                                                             }
                                                         }
                                                     }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx001xxx010xx1x100110
+                                                         ftmad.  */
+                                                      return 1434;
+                                                    }
                                                 }
                                               else
                                                 {
-                                                  if (((word >> 4) & 0x1) == 0)
+                                                  if (((word >> 16) & 0x1) == 0)
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxx0xxxxxxxx011xxxxx0x11x100110
-                                                         fcmuo.  */
-                                                      return 1351;
+                                                      if (((word >> 17) & 0x1) == 0)
+                                                        {
+                                                          if (((word >> 18) & 0x1) == 0)
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001000100xx1x100110
+                                                                     fabd.  */
+                                                                  return 1332;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001000110xx1x100110
+                                                                     fadd.  */
+                                                                  return 1338;
+                                                                }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001001100xx1x100110
+                                                                     fdivr.  */
+                                                                  return 1378;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001001110xx1x100110
+                                                                     fmaxnm.  */
+                                                                  return 1385;
+                                                                }
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 18) & 0x1) == 0)
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001010100xx1x100110
+                                                                     fmulx.  */
+                                                                  return 1409;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001010110xx1x100110
+                                                                     fmul.  */
+                                                                  return 1405;
+                                                                }
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx0010111x0xx1x100110
+                                                                 fmax.  */
+                                                              return 1383;
+                                                            }
+                                                        }
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxx1xxxxxxxx011xxxxx0x11x100110
-                                                         facge.  */
-                                                      return 1334;
+                                                      if (((word >> 17) & 0x1) == 0)
+                                                        {
+                                                          if (((word >> 18) & 0x1) == 0)
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001100100xx1x100110
+                                                                     fscale.  */
+                                                                  return 1427;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001100110xx1x100110
+                                                                     fsub.  */
+                                                                  return 1431;
+                                                                }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001101100xx1x100110
+                                                                     fdiv.  */
+                                                                  return 1377;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx001101110xx1x100110
+                                                                     fminnm.  */
+                                                                  return 1391;
+                                                                }
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 18) & 0x1) == 0)
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx0011101x0xx1x100110
+                                                                 fsubr.  */
+                                                              return 1433;
+                                                            }
+                                                          else
+                                                            {
+                                                              /* 33222222222211111111110000000000
+                                                                 10987654321098765432109876543210
+                                                                 xxxxxxxxxxxxx0011111x0xx1x100110
+                                                                 fmin.  */
+                                                              return 1389;
+                                                            }
+                                                        }
                                                     }
                                                 }
                                             }
                                           else
                                             {
-                                              /* 33222222222211111111110000000000
-                                                 10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx0x11x100111
-                                                 st1d.  */
-                                              return 1783;
+                                              if (((word >> 4) & 0x1) == 0)
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx0xxxxxxxx011xxxxx0xx1x100110
+                                                     fcmuo.  */
+                                                  return 1355;
+                                                }
+                                              else
+                                                {
+                                                  /* 33222222222211111111110000000000
+                                                     10987654321098765432109876543210
+                                                     xxxx1xxxxxxxx011xxxxx0xx1x100110
+                                                     facge.  */
+                                                  return 1334;
+                                                }
                                             }
                                         }
-                                    }
-                                  else
-                                    {
-                                      if (((word >> 14) & 0x1) == 0)
+                                      else
                                         {
-                                          if (((word >> 23) & 0x1) == 0)
+                                          if (((word >> 22) & 0x1) == 0)
                                             {
-                                              if (((word >> 22) & 0x1) == 0)
+                                              if (((word >> 23) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx0001x10011x
+                                                     xxxxxxxxxxxxx0x1xxxxx0001x100111
                                                      st1w.  */
-                                                  return 1805;
+                                                  return 1837;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx0101x10011x
-                                                     st1w.  */
-                                                  return 1812;
+                                                     xxxxxxxxxxxxx0x1xxxxx0011x100111
+                                                     st1d.  */
+                                                  return 1816;
                                                 }
                                             }
                                           else
                                             {
-                                              if (((word >> 31) & 0x1) == 0)
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx0x1xxxxx01x1x100111
+                                                 st1w.  */
+                                              return 1842;
+                                            }
+                                        }
+                                    }
+                                  else
+                                    {
+                                      if (((word >> 14) & 0x1) == 0)
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              if (((word >> 16) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 16) & 0x1) == 0)
+                                                  if (((word >> 17) & 0x1) == 0)
                                                     {
-                                                      if (((word >> 17) & 0x1) == 0)
+                                                      if (((word >> 18) & 0x1) == 0)
                                                         {
-                                                          if (((word >> 18) & 0x1) == 0)
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 20) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101000000xx1x100110
+                                                                     frintn.  */
+                                                                  return 1421;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101000010xx1x100110
+                                                                     scvtf.  */
+                                                                  return 1751;
+                                                                }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  if (((word >> 22) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101000000x11x100110
-                                                                         frintn.  */
-                                                                      return 1402;
+                                                                         xxxxxxxxxxxxx1010001000x1x100110
+                                                                         fcvt.  */
+                                                                      return 1357;
                                                                     }
                                                                   else
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101000010x11x100110
-                                                                         scvtf.  */
-                                                                      return 1722;
+                                                                         xxxxxxxxxxxxx1010001001x1x100110
+                                                                         fcvt.  */
+                                                                      return 1359;
                                                                     }
                                                                 }
                                                               else
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
-                                                                    {
-                                                                      if (((word >> 22) & 0x1) == 0)
-                                                                        {
-                                                                          /* 33222222222211111111110000000000
-                                                                             10987654321098765432109876543210
-                                                                             xxxxxxxxxxxxx101000100011x100110
-                                                                             fcvt.  */
-                                                                          return 1353;
-                                                                        }
-                                                                      else
-                                                                        {
-                                                                          /* 33222222222211111111110000000000
-                                                                             10987654321098765432109876543210
-                                                                             xxxxxxxxxxxxx101000100111x100110
-                                                                             fcvt.  */
-                                                                          return 1355;
-                                                                        }
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101000110x11x100110
-                                                                         fcvtzs.  */
-                                                                      return 1360;
-                                                                    }
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101000110xx1x100110
+                                                                     fcvtzs.  */
+                                                                  return 1367;
                                                                 }
                                                             }
-                                                          else
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 20) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101001000xx1x100110
+                                                                     frinta.  */
+                                                                  return 1418;
+                                                                }
+                                                              else
+                                                                {
+                                                                  if (((word >> 22) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101001000x11x100110
-                                                                         frinta.  */
-                                                                      return 1399;
+                                                                         xxxxxxxxxxxxx1010010100x1x100110
+                                                                         scvtf.  */
+                                                                      return 1750;
                                                                     }
                                                                   else
                                                                     {
-                                                                      if (((word >> 22) & 0x1) == 0)
+                                                                      if (((word >> 23) & 0x1) == 0)
                                                                         {
                                                                           /* 33222222222211111111110000000000
                                                                              10987654321098765432109876543210
-                                                                             xxxxxxxxxxxxx101001010011x100110
+                                                                             xxxxxxxxxxxxx101001010101x100110
                                                                              scvtf.  */
-                                                                          return 1721;
+                                                                          return 1749;
                                                                         }
                                                                       else
                                                                         {
@@ -10090,29 +10376,40 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                              10987654321098765432109876543210
                                                                              xxxxxxxxxxxxx101001010111x100110
                                                                              scvtf.  */
-                                                                          return 1723;
+                                                                          return 1753;
                                                                         }
                                                                     }
                                                                 }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101001100xx1x100110
+                                                                     frecpx.  */
+                                                                  return 1417;
+                                                                }
                                                               else
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
+                                                                  if (((word >> 22) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101001100x11x100110
-                                                                         frecpx.  */
-                                                                      return 1398;
+                                                                         xxxxxxxxxxxxx1010011100x1x100110
+                                                                         fcvtzs.  */
+                                                                      return 1366;
                                                                     }
                                                                   else
                                                                     {
-                                                                      if (((word >> 22) & 0x1) == 0)
+                                                                      if (((word >> 23) & 0x1) == 0)
                                                                         {
                                                                           /* 33222222222211111111110000000000
                                                                              10987654321098765432109876543210
-                                                                             xxxxxxxxxxxxx101001110011x100110
+                                                                             xxxxxxxxxxxxx101001110101x100110
                                                                              fcvtzs.  */
-                                                                          return 1359;
+                                                                          return 1364;
                                                                         }
                                                                       else
                                                                         {
@@ -10120,44 +10417,77 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                              10987654321098765432109876543210
                                                                              xxxxxxxxxxxxx101001110111x100110
                                                                              fcvtzs.  */
-                                                                          return 1361;
+                                                                          return 1368;
                                                                         }
                                                                     }
                                                                 }
                                                             }
                                                         }
-                                                      else
+                                                    }
+                                                  else
+                                                    {
+                                                      if (((word >> 18) & 0x1) == 0)
                                                         {
-                                                          if (((word >> 18) & 0x1) == 0)
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 20) & 0x1) == 0)
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
-                                                                     xxxxxxxxxxxxx1010100x0x11x100110
+                                                                     xxxxxxxxxxxxx101010000xx1x100110
                                                                      frintm.  */
-                                                                  return 1401;
+                                                                  return 1420;
                                                                 }
                                                               else
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
-                                                                     xxxxxxxxxxxxx1010101x0x11x100110
-                                                                     fcvt.  */
-                                                                  return 1357;
+                                                                     xxxxxxxxxxxxx101010010xx1x100110
+                                                                     scvtf.  */
+                                                                  return 1748;
                                                                 }
                                                             }
                                                           else
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 20) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101010100xx1x100110
+                                                                     fcvt.  */
+                                                                  return 1361;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101010110xx1x100110
+                                                                     fcvtzs.  */
+                                                                  return 1363;
+                                                                }
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 19) & 0x1) == 0)
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101011000xx1x100110
+                                                                     frintx.  */
+                                                                  return 1423;
+                                                                }
+                                                              else
+                                                                {
+                                                                  if (((word >> 23) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101011000x11x100110
-                                                                         frintx.  */
-                                                                      return 1404;
+                                                                         xxxxxxxxxxxxx101011010x01x100110
+                                                                         scvtf.  */
+                                                                      return 1752;
                                                                     }
                                                                   else
                                                                     {
@@ -10165,87 +10495,109 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxxxxx101011010x11x100110
                                                                          scvtf.  */
-                                                                      return 1724;
+                                                                      return 1754;
                                                                     }
                                                                 }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 23) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx1010111x0x01x100110
+                                                                     fcvtzs.  */
+                                                                  return 1365;
+                                                                }
                                                               else
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx1010111x0x11x100110
                                                                      fcvtzs.  */
-                                                                  return 1362;
+                                                                  return 1369;
                                                                 }
                                                             }
                                                         }
                                                     }
-                                                  else
+                                                }
+                                              else
+                                                {
+                                                  if (((word >> 17) & 0x1) == 0)
                                                     {
-                                                      if (((word >> 17) & 0x1) == 0)
+                                                      if (((word >> 18) & 0x1) == 0)
                                                         {
-                                                          if (((word >> 18) & 0x1) == 0)
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 20) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101100000xx1x100110
+                                                                     frintp.  */
+                                                                  return 1422;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101100010xx1x100110
+                                                                     ucvtf.  */
+                                                                  return 1903;
+                                                                }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  if (((word >> 22) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101100000x11x100110
-                                                                         frintp.  */
-                                                                      return 1403;
+                                                                         xxxxxxxxxxxxx1011001000x1x100110
+                                                                         fcvt.  */
+                                                                      return 1358;
                                                                     }
                                                                   else
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101100010x11x100110
-                                                                         ucvtf.  */
-                                                                      return 1868;
+                                                                         xxxxxxxxxxxxx1011001001x1x100110
+                                                                         fcvt.  */
+                                                                      return 1360;
                                                                     }
                                                                 }
                                                               else
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
-                                                                    {
-                                                                      if (((word >> 22) & 0x1) == 0)
-                                                                        {
-                                                                          /* 33222222222211111111110000000000
-                                                                             10987654321098765432109876543210
-                                                                             xxxxxxxxxxxxx101100100011x100110
-                                                                             fcvt.  */
-                                                                          return 1354;
-                                                                        }
-                                                                      else
-                                                                        {
-                                                                          /* 33222222222211111111110000000000
-                                                                             10987654321098765432109876543210
-                                                                             xxxxxxxxxxxxx101100100111x100110
-                                                                             fcvt.  */
-                                                                          return 1356;
-                                                                        }
-                                                                    }
-                                                                  else
-                                                                    {
-                                                                      /* 33222222222211111111110000000000
-                                                                         10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101100110x11x100110
-                                                                         fcvtzu.  */
-                                                                      return 1364;
-                                                                    }
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101100110xx1x100110
+                                                                     fcvtzu.  */
+                                                                  return 1374;
                                                                 }
                                                             }
-                                                          else
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 22) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 22) & 0x1) == 0)
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx1011010x00x1x100110
+                                                                     ucvtf.  */
+                                                                  return 1902;
+                                                                }
+                                                              else
+                                                                {
+                                                                  if (((word >> 23) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx1011010x0011x100110
+                                                                         xxxxxxxxxxxxx1011010x0101x100110
                                                                          ucvtf.  */
-                                                                      return 1867;
+                                                                      return 1901;
                                                                     }
                                                                   else
                                                                     {
@@ -10253,28 +10605,39 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxxxxx1011010x0111x100110
                                                                          ucvtf.  */
-                                                                      return 1869;
+                                                                      return 1905;
                                                                     }
                                                                 }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101101100xx1x100110
+                                                                     fsqrt.  */
+                                                                  return 1428;
+                                                                }
                                                               else
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
+                                                                  if (((word >> 22) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101101100x11x100110
-                                                                         fsqrt.  */
-                                                                      return 1409;
+                                                                         xxxxxxxxxxxxx1011011100x1x100110
+                                                                         fcvtzu.  */
+                                                                      return 1373;
                                                                     }
                                                                   else
                                                                     {
-                                                                      if (((word >> 22) & 0x1) == 0)
+                                                                      if (((word >> 23) & 0x1) == 0)
                                                                         {
                                                                           /* 33222222222211111111110000000000
                                                                              10987654321098765432109876543210
-                                                                             xxxxxxxxxxxxx101101110011x100110
+                                                                             xxxxxxxxxxxxx101101110101x100110
                                                                              fcvtzu.  */
-                                                                          return 1363;
+                                                                          return 1371;
                                                                         }
                                                                       else
                                                                         {
@@ -10282,44 +10645,77 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                              10987654321098765432109876543210
                                                                              xxxxxxxxxxxxx101101110111x100110
                                                                              fcvtzu.  */
-                                                                          return 1365;
+                                                                          return 1375;
                                                                         }
                                                                     }
                                                                 }
                                                             }
                                                         }
-                                                      else
+                                                    }
+                                                  else
+                                                    {
+                                                      if (((word >> 18) & 0x1) == 0)
                                                         {
-                                                          if (((word >> 18) & 0x1) == 0)
+                                                          if (((word >> 19) & 0x1) == 0)
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 20) & 0x1) == 0)
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
-                                                                     xxxxxxxxxxxxx1011100x0x11x100110
+                                                                     xxxxxxxxxxxxx101110000xx1x100110
                                                                      frintz.  */
-                                                                  return 1405;
+                                                                  return 1424;
                                                                 }
                                                               else
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
-                                                                     xxxxxxxxxxxxx1011101x0x11x100110
-                                                                     fcvt.  */
-                                                                  return 1358;
+                                                                     xxxxxxxxxxxxx101110010xx1x100110
+                                                                     ucvtf.  */
+                                                                  return 1900;
                                                                 }
                                                             }
                                                           else
                                                             {
-                                                              if (((word >> 19) & 0x1) == 0)
+                                                              if (((word >> 20) & 0x1) == 0)
                                                                 {
-                                                                  if (((word >> 20) & 0x1) == 0)
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101110100xx1x100110
+                                                                     fcvt.  */
+                                                                  return 1362;
+                                                                }
+                                                              else
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101110110xx1x100110
+                                                                     fcvtzu.  */
+                                                                  return 1370;
+                                                                }
+                                                            }
+                                                        }
+                                                      else
+                                                        {
+                                                          if (((word >> 19) & 0x1) == 0)
+                                                            {
+                                                              if (((word >> 20) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx101111000xx1x100110
+                                                                     frinti.  */
+                                                                  return 1419;
+                                                                }
+                                                              else
+                                                                {
+                                                                  if (((word >> 23) & 0x1) == 0)
                                                                     {
                                                                       /* 33222222222211111111110000000000
                                                                          10987654321098765432109876543210
-                                                                         xxxxxxxxxxxxx101111000x11x100110
-                                                                         frinti.  */
-                                                                      return 1400;
+                                                                         xxxxxxxxxxxxx101111010x01x100110
+                                                                         ucvtf.  */
+                                                                      return 1904;
                                                                     }
                                                                   else
                                                                     {
@@ -10327,101 +10723,134 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxxxxx101111010x11x100110
                                                                          ucvtf.  */
-                                                                      return 1870;
+                                                                      return 1906;
                                                                     }
                                                                 }
+                                                            }
+                                                          else
+                                                            {
+                                                              if (((word >> 23) & 0x1) == 0)
+                                                                {
+                                                                  /* 33222222222211111111110000000000
+                                                                     10987654321098765432109876543210
+                                                                     xxxxxxxxxxxxx1011111x0x01x100110
+                                                                     fcvtzu.  */
+                                                                  return 1372;
+                                                                }
                                                               else
                                                                 {
                                                                   /* 33222222222211111111110000000000
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxxxx1011111x0x11x100110
                                                                      fcvtzu.  */
-                                                                  return 1366;
+                                                                  return 1376;
                                                                 }
                                                             }
                                                         }
                                                     }
                                                 }
-                                              else
+                                            }
+                                          else
+                                            {
+                                              if (((word >> 22) & 0x1) == 0)
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx101xxxxx0011x100111
-                                                         st1d.  */
-                                                      return 1784;
+                                                         xxxxxxxxxxxxx101xxxxx0001x100111
+                                                         st1w.  */
+                                                      return 1838;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx101xxxxx0111x100111
+                                                         xxxxxxxxxxxxx101xxxxx0011x100111
                                                          st1d.  */
-                                                      return 1788;
+                                                      return 1817;
                                                     }
                                                 }
-                                            }
-                                        }
-                                      else
-                                        {
-                                          if (((word >> 23) & 0x1) == 0)
-                                            {
-                                              if (((word >> 20) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxx00x01x10011x
-                                                     st1w.  */
-                                                  return 1813;
-                                                }
                                               else
                                                 {
-                                                  if (((word >> 22) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxx10001x10011x
-                                                         stnt1w.  */
-                                                      return 1847;
+                                                         xxxxxxxxxxxxx101xxxxx0101x100111
+                                                         st1w.  */
+                                                      return 1845;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxx10101x10011x
-                                                         st3w.  */
-                                                      return 1831;
+                                                         xxxxxxxxxxxxx101xxxxx0111x100111
+                                                         st1d.  */
+                                                      return 1821;
                                                     }
                                                 }
                                             }
+                                        }
+                                      else
+                                        {
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx111xxxxx0xx1x100110
+                                                 facgt.  */
+                                              return 1335;
+                                            }
                                           else
                                             {
-                                              if (((word >> 31) & 0x1) == 0)
+                                              if (((word >> 20) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx0x11x100110
-                                                     facgt.  */
-                                                  return 1335;
+                                                     xxxxxxxxxxxxx111xxxx00xx1x100111
+                                                     st1w.  */
+                                                  return 1846;
                                                 }
                                               else
                                                 {
                                                   if (((word >> 22) & 0x1) == 0)
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0011x100111
-                                                         stnt1d.  */
-                                                      return 1843;
+                                                      if (((word >> 23) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx111xxxx10001x100111
+                                                             stnt1w.  */
+                                                          return 1880;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx111xxxx10011x100111
+                                                             stnt1d.  */
+                                                          return 1876;
+                                                        }
                                                     }
                                                   else
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxxx0111x100111
-                                                         st3d.  */
-                                                      return 1827;
+                                                      if (((word >> 23) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx111xxxx10101x100111
+                                                             st3w.  */
+                                                          return 1864;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx111xxxx10111x100111
+                                                             st3d.  */
+                                                          return 1860;
+                                                        }
                                                     }
                                                 }
                                             }
@@ -10465,7 +10894,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                              10987654321098765432109876543210
                                                                              xxxxxxxxxx000x01000101xx1x100100
                                                                              sqincp.  */
-                                                                          return 1762;
+                                                                          return 1795;
                                                                         }
                                                                       else
                                                                         {
@@ -10473,7 +10902,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                              10987654321098765432109876543210
                                                                              xxxxxxxxxx001x01000101xx1x100100
                                                                              wrffr.  */
-                                                                          return 1929;
+                                                                          return 1968;
                                                                         }
                                                                     }
                                                                   else
@@ -10482,7 +10911,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                          10987654321098765432109876543210
                                                                          xxxxxxxxxx01xx01000101xx1x100100
                                                                          sqincp.  */
-                                                                      return 1764;
+                                                                      return 1797;
                                                                     }
                                                                 }
                                                               else
@@ -10491,7 +10920,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx1xxx01000101xx1x100100
                                                                      sqincp.  */
-                                                                  return 1763;
+                                                                  return 1796;
                                                                 }
                                                             }
                                                         }
@@ -10505,7 +10934,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxx00x01001x01xx1x100100
                                                                      incp.  */
-                                                                  return 1423;
+                                                                  return 1442;
                                                                 }
                                                               else
                                                                 {
@@ -10513,7 +10942,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxxx01x01001x01xx1x100100
                                                                      setffr.  */
-                                                                  return 1729;
+                                                                  return 1762;
                                                                 }
                                                             }
                                                           else
@@ -10522,7 +10951,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxx1xx01001x01xx1x100100
                                                                  incp.  */
-                                                              return 1424;
+                                                              return 1443;
                                                             }
                                                         }
                                                     }
@@ -10536,7 +10965,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx00xx0101xx01xx1x100100
                                                                  sqdecp.  */
-                                                              return 1748;
+                                                              return 1781;
                                                             }
                                                           else
                                                             {
@@ -10544,7 +10973,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx01xx0101xx01xx1x100100
                                                                  sqdecp.  */
-                                                              return 1750;
+                                                              return 1783;
                                                             }
                                                         }
                                                       else
@@ -10553,7 +10982,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx1xxx0101xx01xx1x100100
                                                              sqdecp.  */
-                                                          return 1749;
+                                                          return 1782;
                                                         }
                                                     }
                                                 }
@@ -10571,7 +11000,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx00xx01100x01xx1x100100
                                                                      uqincp.  */
-                                                                  return 1904;
+                                                                  return 1943;
                                                                 }
                                                               else
                                                                 {
@@ -10588,7 +11017,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx00xx0111xx01xx1x100100
                                                                  uqdecp.  */
-                                                              return 1890;
+                                                              return 1929;
                                                             }
                                                         }
                                                       else
@@ -10601,7 +11030,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                      10987654321098765432109876543210
                                                                      xxxxxxxxxx01xx01100x01xx1x100100
                                                                      uqincp.  */
-                                                                  return 1905;
+                                                                  return 1944;
                                                                 }
                                                               else
                                                                 {
@@ -10618,7 +11047,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxx01xx0111xx01xx1x100100
                                                                  uqdecp.  */
-                                                              return 1891;
+                                                              return 1930;
                                                             }
                                                         }
                                                     }
@@ -10630,7 +11059,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx1xxx0110xx01xx1x100100
                                                              uqincp.  */
-                                                          return 1906;
+                                                          return 1945;
                                                         }
                                                       else
                                                         {
@@ -10638,7 +11067,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxx1xxx0111xx01xx1x100100
                                                              uqdecp.  */
-                                                          return 1892;
+                                                          return 1931;
                                                         }
                                                     }
                                                 }
@@ -10653,7 +11082,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx01xxxx01001x100101
                                                          ld1sh.  */
-                                                      return 1508;
+                                                      return 1535;
                                                     }
                                                   else
                                                     {
@@ -10661,7 +11090,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx01xxxx01011x100101
                                                          ld1sb.  */
-                                                      return 1495;
+                                                      return 1522;
                                                     }
                                                 }
                                               else
@@ -10672,7 +11101,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx01xxxx01101x100101
                                                          ld1w.  */
-                                                      return 1527;
+                                                      return 1554;
                                                     }
                                                   else
                                                     {
@@ -10680,7 +11109,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx01xxxx01111x100101
                                                          ld1d.  */
-                                                      return 1455;
+                                                      return 1474;
                                                     }
                                                 }
                                             }
@@ -10695,7 +11124,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxxx01xxxx11001x10010x
                                                      ldnf1sh.  */
-                                                  return 1625;
+                                                  return 1652;
                                                 }
                                               else
                                                 {
@@ -10703,7 +11132,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxxx01xxxx11011x10010x
                                                      ldnf1sb.  */
-                                                  return 1622;
+                                                  return 1649;
                                                 }
                                             }
                                           else
@@ -10714,7 +11143,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxxx01xxxx11101x10010x
                                                      ldnf1w.  */
-                                                  return 1628;
+                                                  return 1655;
                                                 }
                                               else
                                                 {
@@ -10722,7 +11151,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                      10987654321098765432109876543210
                                                      xxxxxxxxxxxxxx01xxxx11111x10010x
                                                      ldnf1d.  */
-                                                  return 1617;
+                                                  return 1644;
                                                 }
                                             }
                                         }
@@ -10753,7 +11182,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxxx11000011xx1x100100
                                                                  mul.  */
-                                                              return 1657;
+                                                              return 1684;
                                                             }
                                                         }
                                                       else
@@ -10764,7 +11193,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxxx11000101xx1x100100
                                                                  smax.  */
-                                                              return 1730;
+                                                              return 1763;
                                                             }
                                                           else
                                                             {
@@ -10782,7 +11211,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx11001xx1xx1x100100
                                                          sqadd.  */
-                                                      return 1739;
+                                                      return 1772;
                                                     }
                                                 }
                                               else
@@ -10793,7 +11222,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx11010xx1xx1x100100
                                                          smin.  */
-                                                      return 1733;
+                                                      return 1766;
                                                     }
                                                   else
                                                     {
@@ -10801,7 +11230,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx11011xx1xx1x100100
                                                          sqsub.  */
-                                                      return 1769;
+                                                      return 1802;
                                                     }
                                                 }
                                             }
@@ -10817,7 +11246,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxxx111000x1xx1x100100
                                                              sub.  */
-                                                          return 1851;
+                                                          return 1884;
                                                         }
                                                       else
                                                         {
@@ -10827,7 +11256,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxxx11100101xx1x100100
                                                                  umax.  */
-                                                              return 1873;
+                                                              return 1912;
                                                             }
                                                           else
                                                             {
@@ -10835,7 +11264,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                                  10987654321098765432109876543210
                                                                  xxxxxxxxxxxxxx11100111xx1x100100
                                                                  fdup.  */
-                                                              return 1369;
+                                                              return 1379;
                                                             }
                                                         }
                                                     }
@@ -10845,7 +11274,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx11101xx1xx1x100100
                                                          uqadd.  */
-                                                      return 1881;
+                                                      return 1920;
                                                     }
                                                 }
                                               else
@@ -10858,7 +11287,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxxx111100x1xx1x100100
                                                              subr.  */
-                                                          return 1853;
+                                                          return 1886;
                                                         }
                                                       else
                                                         {
@@ -10866,7 +11295,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxxx111101x1xx1x100100
                                                              umin.  */
-                                                          return 1876;
+                                                          return 1915;
                                                         }
                                                     }
                                                   else
@@ -10875,7 +11304,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxxx11111xx1xx1x100100
                                                          uqsub.  */
-                                                      return 1911;
+                                                      return 1950;
                                                     }
                                                 }
                                             }
@@ -10892,7 +11321,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx1001x100101
                                                          ld2w.  */
-                                                      return 1535;
+                                                      return 1562;
                                                     }
                                                   else
                                                     {
@@ -10900,7 +11329,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx1011x100101
                                                          ld2d.  */
-                                                      return 1531;
+                                                      return 1558;
                                                     }
                                                 }
                                               else
@@ -10911,7 +11340,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx1101x100101
                                                          ld4w.  */
-                                                      return 1551;
+                                                      return 1578;
                                                     }
                                                   else
                                                     {
@@ -10919,7 +11348,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx011xxxxx1111x100101
                                                          ld4d.  */
-                                                      return 1547;
+                                                      return 1574;
                                                     }
                                                 }
                                             }
@@ -10933,7 +11362,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1001x100101
                                                          ld2w.  */
-                                                      return 1536;
+                                                      return 1563;
                                                     }
                                                   else
                                                     {
@@ -10941,7 +11370,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1011x100101
                                                          ld2d.  */
-                                                      return 1532;
+                                                      return 1559;
                                                     }
                                                 }
                                               else
@@ -10952,7 +11381,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1101x100101
                                                          ld4w.  */
-                                                      return 1552;
+                                                      return 1579;
                                                     }
                                                   else
                                                     {
@@ -10960,7 +11389,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                          10987654321098765432109876543210
                                                          xxxxxxxxxxxxx111xxxxx1111x100101
                                                          ld4d.  */
-                                                      return 1548;
+                                                      return 1575;
                                                     }
                                                 }
                                             }
@@ -10971,53 +11400,53 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                 {
                                   if (((word >> 13) & 0x1) == 0)
                                     {
-                                      if (((word >> 23) & 0x1) == 0)
+                                      if (((word >> 31) & 0x1) == 0)
                                         {
-                                          if (((word >> 22) & 0x1) == 0)
+                                          if (((word >> 14) & 0x1) == 0)
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx1001x10011x
-                                                 st1w.  */
-                                              return 1806;
+                                                 xxxxxxxxxxxxx001xxxxx1xx1x100110
+                                                 fmad.  */
+                                              return 1381;
                                             }
                                           else
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx1101x10011x
-                                                 st1w.  */
-                                              return 1811;
+                                                 xxxxxxxxxxxxx011xxxxx1xx1x100110
+                                                 fnmad.  */
+                                              return 1411;
                                             }
                                         }
                                       else
                                         {
-                                          if (((word >> 31) & 0x1) == 0)
+                                          if (((word >> 22) & 0x1) == 0)
                                             {
-                                              if (((word >> 14) & 0x1) == 0)
+                                              if (((word >> 23) & 0x1) == 0)
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx001xxxxx1x11x100110
-                                                     fmad.  */
-                                                  return 1371;
+                                                     xxxxxxxxxxxxx0x1xxxxx1001x100111
+                                                     st1w.  */
+                                                  return 1839;
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx011xxxxx1x11x100110
-                                                     fnmad.  */
-                                                  return 1392;
+                                                     xxxxxxxxxxxxx0x1xxxxx1011x100111
+                                                     st1d.  */
+                                                  return 1818;
                                                 }
                                             }
                                           else
                                             {
                                               /* 33222222222211111111110000000000
                                                  10987654321098765432109876543210
-                                                 xxxxxxxxxxxxx0x1xxxxx1x11x100111
-                                                 st1d.  */
-                                              return 1785;
+                                                 xxxxxxxxxxxxx0x1xxxxx11x1x100111
+                                                 st1w.  */
+                                              return 1844;
                                             }
                                         }
                                     }
@@ -11025,106 +11454,106 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                     {
                                       if (((word >> 14) & 0x1) == 0)
                                         {
-                                          if (((word >> 23) & 0x1) == 0)
+                                          if (((word >> 31) & 0x1) == 0)
                                             {
-                                              if (((word >> 22) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1001x10011x
-                                                     st1w.  */
-                                                  return 1807;
-                                                }
-                                              else
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1101x10011x
-                                                     st1w.  */
-                                                  return 1814;
-                                                }
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx101xxxxx1xx1x100110
+                                                 fmsb.  */
+                                              return 1402;
                                             }
                                           else
                                             {
-                                              if (((word >> 31) & 0x1) == 0)
+                                              if (((word >> 22) & 0x1) == 0)
                                                 {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1x11x100110
-                                                     fmsb.  */
-                                                  return 1386;
+                                                  if (((word >> 23) & 0x1) == 0)
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx101xxxxx1001x100111
+                                                         st1w.  */
+                                                      return 1840;
+                                                    }
+                                                  else
+                                                    {
+                                                      /* 33222222222211111111110000000000
+                                                         10987654321098765432109876543210
+                                                         xxxxxxxxxxxxx101xxxxx1011x100111
+                                                         st1d.  */
+                                                      return 1819;
+                                                    }
                                                 }
                                               else
                                                 {
                                                   /* 33222222222211111111110000000000
                                                      10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx101xxxxx1x11x100111
-                                                     st1d.  */
-                                                  return 1786;
+                                                     xxxxxxxxxxxxx101xxxxx11x1x100111
+                                                     st1w.  */
+                                                  return 1847;
                                                 }
                                             }
                                         }
                                       else
                                         {
-                                          if (((word >> 23) & 0x1) == 0)
+                                          if (((word >> 31) & 0x1) == 0)
+                                            {
+                                              /* 33222222222211111111110000000000
+                                                 10987654321098765432109876543210
+                                                 xxxxxxxxxxxxx111xxxxx1xx1x100110
+                                                 fnmsb.  */
+                                              return 1414;
+                                            }
+                                          else
                                             {
                                               if (((word >> 20) & 0x1) == 0)
                                                 {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxx01x01x10011x
-                                                     st1w.  */
-                                                  return 1815;
-                                                }
-                                              else
-                                                {
-                                                  if (((word >> 22) & 0x1) == 0)
+                                                  if (((word >> 23) & 0x1) == 0)
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxx11001x10011x
-                                                         st2w.  */
-                                                      return 1823;
+                                                         xxxxxxxxxxxxx111xxxx01x01x100111
+                                                         st1w.  */
+                                                      return 1848;
                                                     }
                                                   else
                                                     {
                                                       /* 33222222222211111111110000000000
                                                          10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxx11101x10011x
-                                                         st4w.  */
-                                                      return 1839;
+                                                         xxxxxxxxxxxxx111xxxx01x11x100111
+                                                         st1d.  */
+                                                      return 1822;
                                                     }
                                                 }
-                                            }
-                                          else
-                                            {
-                                              if (((word >> 31) & 0x1) == 0)
-                                                {
-                                                  /* 33222222222211111111110000000000
-                                                     10987654321098765432109876543210
-                                                     xxxxxxxxxxxxx111xxxxx1x11x100110
-                                                     fnmsb.  */
-                                                  return 1395;
-                                                }
                                               else
                                                 {
-                                                  if (((word >> 20) & 0x1) == 0)
+                                                  if (((word >> 22) & 0x1) == 0)
                                                     {
-                                                      /* 33222222222211111111110000000000
-                                                         10987654321098765432109876543210
-                                                         xxxxxxxxxxxxx111xxxx01x11x100111
-                                                         st1d.  */
-                                                      return 1789;
+                                                      if (((word >> 23) & 0x1) == 0)
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx111xxxx11001x100111
+                                                             st2w.  */
+                                                          return 1856;
+                                                        }
+                                                      else
+                                                        {
+                                                          /* 33222222222211111111110000000000
+                                                             10987654321098765432109876543210
+                                                             xxxxxxxxxxxxx111xxxx11011x100111
+                                                             st2d.  */
+                                                          return 1852;
+                                                        }
                                                     }
                                                   else
                                                     {
-                                                      if (((word >> 22) & 0x1) == 0)
+                                                      if (((word >> 23) & 0x1) == 0)
                                                         {
                                                           /* 33222222222211111111110000000000
                                                              10987654321098765432109876543210
-                                                             xxxxxxxxxxxxx111xxxx11011x100111
-                                                             st2d.  */
-                                                          return 1819;
+                                                             xxxxxxxxxxxxx111xxxx11101x100111
+                                                             st4w.  */
+                                                          return 1872;
                                                         }
                                                       else
                                                         {
@@ -11132,7 +11561,7 @@ aarch64_opcode_lookup_1 (uint32_t word)
                                                              10987654321098765432109876543210
                                                              xxxxxxxxxxxxx111xxxx11111x100111
                                                              st4d.  */
-                                                          return 1835;
+                                                          return 1868;
                                                         }
                                                     }
                                                 }
@@ -18446,35 +18875,35 @@ aarch64_find_alias_opcode (const aarch64_opcode *opcode)
     case 1152: value = 1153; break;    /* movz --> mov.  */
     case 1158: value = 1191; break;    /* hint --> autibsp.  */
     case 1176: value = 1180; break;    /* sys --> tlbi.  */
-    case 1239: value = 1934; break;    /* and --> bic.  */
+    case 1239: value = 1973; break;    /* and --> bic.  */
     case 1241: value = 1222; break;    /* and --> mov.  */
     case 1242: value = 1226; break;    /* ands --> movs.  */
-    case 1277: value = 1935; break;    /* cmpge --> cmple.  */
-    case 1280: value = 1938; break;    /* cmpgt --> cmplt.  */
-    case 1282: value = 1936; break;    /* cmphi --> cmplo.  */
-    case 1285: value = 1937; break;    /* cmphs --> cmpls.  */
+    case 1277: value = 1974; break;    /* cmpge --> cmple.  */
+    case 1280: value = 1977; break;    /* cmpgt --> cmplt.  */
+    case 1282: value = 1975; break;    /* cmphi --> cmplo.  */
+    case 1285: value = 1976; break;    /* cmphs --> cmpls.  */
     case 1307: value = 1219; break;    /* cpy --> mov.  */
     case 1308: value = 1221; break;    /* cpy --> mov.  */
-    case 1309: value = 1945; break;    /* cpy --> fmov.  */
+    case 1309: value = 1984; break;    /* cpy --> fmov.  */
     case 1321: value = 1214; break;    /* dup --> mov.  */
     case 1322: value = 1216; break;    /* dup --> mov.  */
-    case 1323: value = 1944; break;    /* dup --> fmov.  */
+    case 1323: value = 1983; break;    /* dup --> fmov.  */
     case 1324: value = 1217; break;    /* dupm --> mov.  */
-    case 1326: value = 1939; break;    /* eor --> eon.  */
+    case 1326: value = 1978; break;    /* eor --> eon.  */
     case 1328: value = 1227; break;    /* eor --> not.  */
     case 1329: value = 1228; break;    /* eors --> nots.  */
-    case 1334: value = 1940; break;    /* facge --> facle.  */
-    case 1335: value = 1941; break;    /* facgt --> faclt.  */
-    case 1344: value = 1942; break;    /* fcmge --> fcmle.  */
-    case 1346: value = 1943; break;    /* fcmgt --> fcmlt.  */
-    case 1352: value = 1211; break;    /* fcpy --> fmov.  */
-    case 1369: value = 1210; break;    /* fdup --> fmov.  */
-    case 1667: value = 1212; break;    /* orr --> mov.  */
-    case 1668: value = 1946; break;    /* orr --> orn.  */
-    case 1670: value = 1215; break;    /* orr --> mov.  */
-    case 1671: value = 1225; break;    /* orrs --> movs.  */
-    case 1727: value = 1220; break;    /* sel --> mov.  */
-    case 1728: value = 1223; break;    /* sel --> mov.  */
+    case 1334: value = 1979; break;    /* facge --> facle.  */
+    case 1335: value = 1980; break;    /* facgt --> faclt.  */
+    case 1348: value = 1981; break;    /* fcmge --> fcmle.  */
+    case 1350: value = 1982; break;    /* fcmgt --> fcmlt.  */
+    case 1356: value = 1211; break;    /* fcpy --> fmov.  */
+    case 1379: value = 1210; break;    /* fdup --> fmov.  */
+    case 1694: value = 1212; break;    /* orr --> mov.  */
+    case 1695: value = 1985; break;    /* orr --> orn.  */
+    case 1697: value = 1215; break;    /* orr --> mov.  */
+    case 1698: value = 1225; break;    /* orrs --> movs.  */
+    case 1760: value = 1220; break;    /* sel --> mov.  */
+    case 1761: value = 1223; break;    /* sel --> mov.  */
     default: return NULL;
     }
 
@@ -18624,38 +19053,38 @@ aarch64_find_next_alias_opcode (const aarch64_opcode *opcode)
     case 1179: value = 1178; break;    /* ic --> dc.  */
     case 1178: value = 1177; break;    /* dc --> at.  */
     case 1177: value = 1176; break;    /* at --> sys.  */
-    case 1934: value = 1239; break;    /* bic --> and.  */
+    case 1973: value = 1239; break;    /* bic --> and.  */
     case 1222: value = 1241; break;    /* mov --> and.  */
     case 1226: value = 1242; break;    /* movs --> ands.  */
-    case 1935: value = 1277; break;    /* cmple --> cmpge.  */
-    case 1938: value = 1280; break;    /* cmplt --> cmpgt.  */
-    case 1936: value = 1282; break;    /* cmplo --> cmphi.  */
-    case 1937: value = 1285; break;    /* cmpls --> cmphs.  */
+    case 1974: value = 1277; break;    /* cmple --> cmpge.  */
+    case 1977: value = 1280; break;    /* cmplt --> cmpgt.  */
+    case 1975: value = 1282; break;    /* cmplo --> cmphi.  */
+    case 1976: value = 1285; break;    /* cmpls --> cmphs.  */
     case 1219: value = 1307; break;    /* mov --> cpy.  */
     case 1221: value = 1308; break;    /* mov --> cpy.  */
-    case 1945: value = 1224; break;    /* fmov --> mov.  */
+    case 1984: value = 1224; break;    /* fmov --> mov.  */
     case 1224: value = 1309; break;    /* mov --> cpy.  */
     case 1214: value = 1321; break;    /* mov --> dup.  */
     case 1216: value = 1213; break;    /* mov --> mov.  */
     case 1213: value = 1322; break;    /* mov --> dup.  */
-    case 1944: value = 1218; break;    /* fmov --> mov.  */
+    case 1983: value = 1218; break;    /* fmov --> mov.  */
     case 1218: value = 1323; break;    /* mov --> dup.  */
     case 1217: value = 1324; break;    /* mov --> dupm.  */
-    case 1939: value = 1326; break;    /* eon --> eor.  */
+    case 1978: value = 1326; break;    /* eon --> eor.  */
     case 1227: value = 1328; break;    /* not --> eor.  */
     case 1228: value = 1329; break;    /* nots --> eors.  */
-    case 1940: value = 1334; break;    /* facle --> facge.  */
-    case 1941: value = 1335; break;    /* faclt --> facgt.  */
-    case 1942: value = 1344; break;    /* fcmle --> fcmge.  */
-    case 1943: value = 1346; break;    /* fcmlt --> fcmgt.  */
-    case 1211: value = 1352; break;    /* fmov --> fcpy.  */
-    case 1210: value = 1369; break;    /* fmov --> fdup.  */
-    case 1212: value = 1667; break;    /* mov --> orr.  */
-    case 1946: value = 1668; break;    /* orn --> orr.  */
-    case 1215: value = 1670; break;    /* mov --> orr.  */
-    case 1225: value = 1671; break;    /* movs --> orrs.  */
-    case 1220: value = 1727; break;    /* mov --> sel.  */
-    case 1223: value = 1728; break;    /* mov --> sel.  */
+    case 1979: value = 1334; break;    /* facle --> facge.  */
+    case 1980: value = 1335; break;    /* faclt --> facgt.  */
+    case 1981: value = 1348; break;    /* fcmle --> fcmge.  */
+    case 1982: value = 1350; break;    /* fcmlt --> fcmgt.  */
+    case 1211: value = 1356; break;    /* fmov --> fcpy.  */
+    case 1210: value = 1379; break;    /* fmov --> fdup.  */
+    case 1212: value = 1694; break;    /* mov --> orr.  */
+    case 1985: value = 1695; break;    /* orn --> orr.  */
+    case 1215: value = 1697; break;    /* mov --> orr.  */
+    case 1225: value = 1698; break;    /* movs --> orrs.  */
+    case 1220: value = 1760; break;    /* mov --> sel.  */
+    case 1223: value = 1761; break;    /* mov --> sel.  */
     default: return NULL;
     }
 
@@ -18694,9 +19123,6 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 26:
     case 27:
     case 28:
-    case 144:
-    case 145:
-    case 146:
     case 147:
     case 148:
     case 149:
@@ -18704,9 +19130,9 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 151:
     case 152:
     case 153:
-    case 166:
-    case 167:
-    case 168:
+    case 154:
+    case 155:
+    case 156:
     case 169:
     case 170:
     case 171:
@@ -18714,7 +19140,10 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 173:
     case 174:
     case 175:
-    case 178:
+    case 176:
+    case 177:
+    case 181:
+    case 184:
       return aarch64_ext_regno (self, info, code, inst);
     case 8:
       return aarch64_ext_regrt_sysins (self, info, code, inst);
@@ -18759,16 +19188,16 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 73:
     case 74:
     case 75:
-    case 141:
-    case 143:
-    case 158:
-    case 159:
-    case 160:
+    case 144:
+    case 146:
     case 161:
     case 162:
     case 163:
     case 164:
     case 165:
+    case 166:
+    case 167:
+    case 168:
       return aarch64_ext_imm (self, info, code, inst);
     case 39:
     case 40:
@@ -18780,10 +19209,10 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 44:
       return aarch64_ext_shll_imm (self, info, code, inst);
     case 47:
-    case 134:
+    case 135:
       return aarch64_ext_fpimm (self, info, code, inst);
     case 61:
-    case 139:
+    case 142:
       return aarch64_ext_limm (self, info, code, inst);
     case 62:
       return aarch64_ext_aimm (self, info, code, inst);
@@ -18793,8 +19222,11 @@ aarch64_extract_operand (const aarch64_operand *self,
       return aarch64_ext_fbits (self, info, code, inst);
     case 66:
     case 67:
+    case 140:
+      return aarch64_ext_imm_rotate2 (self, info, code, inst);
     case 68:
-      return aarch64_ext_imm_rotate (self, info, code, inst);
+    case 139:
+      return aarch64_ext_imm_rotate1 (self, info, code, inst);
     case 69:
     case 70:
       return aarch64_ext_cond (self, info, code, inst);
@@ -18830,20 +19262,21 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 94:
       return aarch64_ext_hint (self, info, code, inst);
     case 95:
+      return aarch64_ext_sve_addr_ri_s4 (self, info, code, inst);
     case 96:
     case 97:
     case 98:
-      return aarch64_ext_sve_addr_ri_s4xvl (self, info, code, inst);
     case 99:
-      return aarch64_ext_sve_addr_ri_s6xvl (self, info, code, inst);
+      return aarch64_ext_sve_addr_ri_s4xvl (self, info, code, inst);
     case 100:
-      return aarch64_ext_sve_addr_ri_s9xvl (self, info, code, inst);
+      return aarch64_ext_sve_addr_ri_s6xvl (self, info, code, inst);
     case 101:
+      return aarch64_ext_sve_addr_ri_s9xvl (self, info, code, inst);
     case 102:
     case 103:
     case 104:
-      return aarch64_ext_sve_addr_ri_u6 (self, info, code, inst);
     case 105:
+      return aarch64_ext_sve_addr_ri_u6 (self, info, code, inst);
     case 106:
     case 107:
     case 108:
@@ -18855,8 +19288,8 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 114:
     case 115:
     case 116:
-      return aarch64_ext_sve_addr_rr_lsl (self, info, code, inst);
     case 117:
+      return aarch64_ext_sve_addr_rr_lsl (self, info, code, inst);
     case 118:
     case 119:
     case 120:
@@ -18864,44 +19297,49 @@ aarch64_extract_operand (const aarch64_operand *self,
     case 122:
     case 123:
     case 124:
-      return aarch64_ext_sve_addr_rz_xtw (self, info, code, inst);
     case 125:
+      return aarch64_ext_sve_addr_rz_xtw (self, info, code, inst);
     case 126:
     case 127:
     case 128:
-      return aarch64_ext_sve_addr_zi_u5 (self, info, code, inst);
     case 129:
-      return aarch64_ext_sve_addr_zz_lsl (self, info, code, inst);
+      return aarch64_ext_sve_addr_zi_u5 (self, info, code, inst);
     case 130:
-      return aarch64_ext_sve_addr_zz_sxtw (self, info, code, inst);
+      return aarch64_ext_sve_addr_zz_lsl (self, info, code, inst);
     case 131:
-      return aarch64_ext_sve_addr_zz_uxtw (self, info, code, inst);
+      return aarch64_ext_sve_addr_zz_sxtw (self, info, code, inst);
     case 132:
-      return aarch64_ext_sve_aimm (self, info, code, inst);
+      return aarch64_ext_sve_addr_zz_uxtw (self, info, code, inst);
     case 133:
+      return aarch64_ext_sve_aimm (self, info, code, inst);
+    case 134:
       return aarch64_ext_sve_asimm (self, info, code, inst);
-    case 135:
-      return aarch64_ext_sve_float_half_one (self, info, code, inst);
     case 136:
-      return aarch64_ext_sve_float_half_two (self, info, code, inst);
+      return aarch64_ext_sve_float_half_one (self, info, code, inst);
     case 137:
-      return aarch64_ext_sve_float_zero_one (self, info, code, inst);
+      return aarch64_ext_sve_float_half_two (self, info, code, inst);
     case 138:
+      return aarch64_ext_sve_float_zero_one (self, info, code, inst);
+    case 141:
       return aarch64_ext_inv_limm (self, info, code, inst);
-    case 140:
+    case 143:
       return aarch64_ext_sve_limm_mov (self, info, code, inst);
-    case 142:
+    case 145:
       return aarch64_ext_sve_scale (self, info, code, inst);
-    case 154:
-    case 155:
-      return aarch64_ext_sve_shlimm (self, info, code, inst);
-    case 156:
     case 157:
+    case 158:
+      return aarch64_ext_sve_shlimm (self, info, code, inst);
+    case 159:
+    case 160:
       return aarch64_ext_sve_shrimm (self, info, code, inst);
-    case 176:
-      return aarch64_ext_sve_index (self, info, code, inst);
-    case 177:
+    case 178:
     case 179:
+    case 180:
+      return aarch64_ext_sve_quad_index (self, info, code, inst);
+    case 182:
+      return aarch64_ext_sve_index (self, info, code, inst);
+    case 183:
+    case 185:
       return aarch64_ext_sve_reglist (self, info, code, inst);
     default: assert (0); abort ();
     }
index d08e81f89df10e7ca94d874eaad6ec1441701557..b528af61e901fea9402aef0be5210f18e28f3177 100644 (file)
@@ -711,36 +711,26 @@ aarch64_ext_fpimm (const aarch64_operand *self, aarch64_opnd_info *info,
   return 1;
 }
 
-/* Decode rotate immediate for FCMLA <Vd>.<T>, <Vn>.<T>, <Vm>.<T>, #rotate.  */
+/* Decode a 1-bit rotate immediate (#90 or #270).  */
 int
-aarch64_ext_imm_rotate (const aarch64_operand *self, aarch64_opnd_info *info,
-                       const aarch64_insn code,
-                       const aarch64_inst *inst ATTRIBUTE_UNUSED)
+aarch64_ext_imm_rotate1 (const aarch64_operand *self, aarch64_opnd_info *info,
+                        const aarch64_insn code,
+                        const aarch64_inst *inst ATTRIBUTE_UNUSED)
 {
   uint64_t rot = extract_field (self->fields[0], code, 0);
+  assert (rot < 2U);
+  info->imm.value = rot * 180 + 90;
+  return 1;
+}
 
-  switch (info->type)
-    {
-    case AARCH64_OPND_IMM_ROT1:
-    case AARCH64_OPND_IMM_ROT2:
-      /* rot   value
-        0      0
-        1      90
-        2      180
-        3      270  */
-      assert (rot < 4U);
-      break;
-    case AARCH64_OPND_IMM_ROT3:
-      /* rot   value
-        0      90
-        1      270  */
-      assert (rot < 2U);
-      rot = 2 * rot + 1;
-      break;
-    default:
-      assert (0);
-      return 0;
-    }
+/* Decode a 2-bit rotate immediate (#0, #90, #180 or #270).  */
+int
+aarch64_ext_imm_rotate2 (const aarch64_operand *self, aarch64_opnd_info *info,
+                        const aarch64_insn code,
+                        const aarch64_inst *inst ATTRIBUTE_UNUSED)
+{
+  uint64_t rot = extract_field (self->fields[0], code, 0);
+  assert (rot < 4U);
   info->imm.value = rot * 90;
   return 1;
 }
@@ -1364,6 +1354,18 @@ aarch64_ext_sve_addr_reg_imm (const aarch64_operand *self,
   return 1;
 }
 
+/* Decode an SVE address [X<n>, #<SVE_imm4> << <shift>], where <SVE_imm4>
+   is a 4-bit signed number and where <shift> is SELF's operand-dependent
+   value.  fields[0] specifies the base register field.  */
+int
+aarch64_ext_sve_addr_ri_s4 (const aarch64_operand *self,
+                           aarch64_opnd_info *info, aarch64_insn code,
+                           const aarch64_inst *inst ATTRIBUTE_UNUSED)
+{
+  int offset = sign_extend (extract_field (FLD_SVE_imm4, code, 0), 3);
+  return aarch64_ext_sve_addr_reg_imm (self, info, code, offset);
+}
+
 /* Decode an SVE address [X<n>, #<SVE_imm6> << <shift>], where <SVE_imm6>
    is a 6-bit unsigned number and where <shift> is SELF's operand-dependent
    value.  fields[0] specifies the base register field.  */
@@ -1591,7 +1593,7 @@ aarch64_ext_sve_index (const aarch64_operand *self,
 
   info->reglane.regno = extract_field (self->fields[0], code, 0);
   val = extract_fields (code, 0, 2, FLD_SVE_tszh, FLD_imm5);
-  if ((val & 15) == 0)
+  if ((val & 31) == 0)
     return 0;
   while ((val & 1) == 0)
     val /= 2;
@@ -1610,6 +1612,21 @@ aarch64_ext_sve_limm_mov (const aarch64_operand *self,
          && aarch64_sve_dupm_mov_immediate_p (info->imm.value, esize));
 }
 
+/* Decode Zn[MM], where Zn occupies the least-significant part of the field
+   and where MM occupies the most-significant part.  The operand-dependent
+   value specifies the number of bits in Zn.  */
+int
+aarch64_ext_sve_quad_index (const aarch64_operand *self,
+                           aarch64_opnd_info *info, aarch64_insn code,
+                           const aarch64_inst *inst ATTRIBUTE_UNUSED)
+{
+  unsigned int reg_bits = get_operand_specific_data (self);
+  unsigned int val = extract_all_fields (self, code);
+  info->reglane.regno = val & ((1 << reg_bits) - 1);
+  info->reglane.index = val >> reg_bits;
+  return 1;
+}
+
 /* Decode {Zn.<T> - Zm.<T>}.  The fields array specifies which field
    to use for Zn.  The opcode-dependent value specifies the number
    of registers in the list.  */
@@ -1907,7 +1924,7 @@ do_misc_decoding (aarch64_inst *inst)
     case OP_MOV_Z_V:
       /* Index must be zero.  */
       value = extract_fields (inst->value, 0, 2, FLD_SVE_tszh, FLD_imm5);
-      return value == 1 || value == 2 || value == 4 || value == 8;
+      return value > 0 && value <= 16 && value == (value & -value);
 
     case OP_MOV_Z_Z:
       return (extract_field (FLD_SVE_Zn, inst->value, 0)
@@ -1916,7 +1933,7 @@ do_misc_decoding (aarch64_inst *inst)
     case OP_MOV_Z_Zi:
       /* Index must be nonzero.  */
       value = extract_fields (inst->value, 0, 2, FLD_SVE_tszh, FLD_imm5);
-      return value != 1 && value != 2 && value != 4 && value != 8;
+      return value > 0 && value != (value & -value);
 
     case OP_MOVM_P_P_P:
       return (extract_field (FLD_SVE_Pd, inst->value, 0)
@@ -2573,8 +2590,8 @@ aarch64_decode_variant_using_iclass (aarch64_inst *inst)
       break;
 
     case sve_index:
-      i = extract_field (FLD_SVE_tsz, inst->value, 0);
-      if (i == 0)
+      i = extract_fields (inst->value, 0, 2, FLD_SVE_tszh, FLD_imm5);
+      if ((i & 31) == 0)
        return FALSE;
       while ((i & 1) == 0)
        {
index ddf70dcd59e8fee5e541ed4f5d87428fbe1fd130..6411c7a98356bb5c19c290dfd3cb48aad92e7edf 100644 (file)
@@ -93,6 +93,7 @@ AARCH64_DECL_OPD_EXTRACTOR (ext_hint);
 AARCH64_DECL_OPD_EXTRACTOR (ext_prfop);
 AARCH64_DECL_OPD_EXTRACTOR (ext_reg_extended);
 AARCH64_DECL_OPD_EXTRACTOR (ext_reg_shifted);
+AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s4);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s4xvl);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s6xvl);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_addr_ri_s9xvl);
@@ -110,11 +111,13 @@ AARCH64_DECL_OPD_EXTRACTOR (ext_sve_float_half_two);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_float_zero_one);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_index);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_limm_mov);
+AARCH64_DECL_OPD_EXTRACTOR (ext_sve_quad_index);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_reglist);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_scale);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_shlimm);
 AARCH64_DECL_OPD_EXTRACTOR (ext_sve_shrimm);
-AARCH64_DECL_OPD_EXTRACTOR (ext_imm_rotate);
+AARCH64_DECL_OPD_EXTRACTOR (ext_imm_rotate1);
+AARCH64_DECL_OPD_EXTRACTOR (ext_imm_rotate2);
 
 #undef AARCH64_DECL_OPD_EXTRACTOR
 
index 937e835fc93d09c0c12665647e3b4363539584eb..1553ce6c7a8c0243b9d46ae25bd26ea568ab353e 100644 (file)
@@ -119,6 +119,7 @@ const struct aarch64_operand aarch64_operands[] =
   {AARCH64_OPND_CLASS_SYSTEM, "BARRIER_ISB", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {}, "the ISB option name SY or an optional 4-bit unsigned immediate"},
   {AARCH64_OPND_CLASS_SYSTEM, "PRFOP", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {}, "a prefetch operation specifier"},
   {AARCH64_OPND_CLASS_SYSTEM, "BARRIER_PSB", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {}, "the PSB option name CSYNC"},
+  {AARCH64_OPND_CLASS_ADDRESS, "SVE_ADDR_RI_S4x16", 4 << OPD_F_OD_LSB | OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_Rn}, "an address with a 4-bit signed offset, multiplied by 16"},
   {AARCH64_OPND_CLASS_ADDRESS, "SVE_ADDR_RI_S4xVL", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_Rn}, "an address with a 4-bit signed offset, multiplied by VL"},
   {AARCH64_OPND_CLASS_ADDRESS, "SVE_ADDR_RI_S4x2xVL", 1 << OPD_F_OD_LSB | OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_Rn}, "an address with a 4-bit signed offset, multiplied by 2*VL"},
   {AARCH64_OPND_CLASS_ADDRESS, "SVE_ADDR_RI_S4x3xVL", 2 << OPD_F_OD_LSB | OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_Rn}, "an address with a 4-bit signed offset, multiplied by 3*VL"},
@@ -162,6 +163,8 @@ const struct aarch64_operand aarch64_operands[] =
   {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_I1_HALF_ONE", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_i1}, "either 0.5 or 1.0"},
   {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_I1_HALF_TWO", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_i1}, "either 0.5 or 2.0"},
   {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_I1_ZERO_ONE", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_i1}, "either 0.0 or 1.0"},
+  {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_IMM_ROT1", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_rot1}, "a 1-bit rotation specifier for complex arithmetic operations"},
+  {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_IMM_ROT2", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_rot2}, "a 2-bit rotation specifier for complex arithmetic operations"},
   {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_INV_LIMM", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_N,FLD_SVE_immr,FLD_SVE_imms}, "an inverted 13-bit logical immediate"},
   {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_LIMM", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_N,FLD_SVE_immr,FLD_SVE_imms}, "a 13-bit logical immediate"},
   {AARCH64_OPND_CLASS_IMMEDIATE, "SVE_LIMM_MOV", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_N,FLD_SVE_immr,FLD_SVE_imms}, "a 13-bit logical move immediate"},
@@ -199,6 +202,9 @@ const struct aarch64_operand aarch64_operands[] =
   {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zd", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zd}, "an SVE vector register"},
   {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zm_5", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zm_5}, "an SVE vector register"},
   {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zm_16", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zm_16}, "an SVE vector register"},
+  {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zm3_INDEX", 3 << OPD_F_OD_LSB | OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zm_16}, "an indexed SVE vector register"},
+  {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zm3_22_INDEX", 3 << OPD_F_OD_LSB | OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_i3h, FLD_SVE_Zm_16}, "an indexed SVE vector register"},
+  {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zm4_INDEX", 4 << OPD_F_OD_LSB | OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zm_16}, "an indexed SVE vector register"},
   {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zn", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zn}, "an SVE vector register"},
   {AARCH64_OPND_CLASS_SVE_REG, "SVE_Zn_INDEX", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zn}, "an indexed SVE vector register"},
   {AARCH64_OPND_CLASS_SVE_REG, "SVE_ZnxN", OPD_F_HAS_INSERTER | OPD_F_HAS_EXTRACTOR, {FLD_SVE_Zn}, "a list of SVE vector registers"},
index dac61593f91b8f475a3e0adfd371e98ec7f9083a..cc99c101236c542ff94bb9c0abc09df521ced330 100644 (file)
@@ -290,6 +290,7 @@ const aarch64_field fields[] =
     {  5,  5 }, /* SVE_Zn: SVE vector register, bits [9,5].  */
     {  0,  5 }, /* SVE_Zt: SVE vector register, bits [4,0].  */
     {  5,  1 }, /* SVE_i1: single-bit immediate.  */
+    { 22,  1 }, /* SVE_i3h: high bit of 3-bit immediate.  */
     { 16,  3 }, /* SVE_imm3: 3-bit immediate field.  */
     { 16,  4 }, /* SVE_imm4: 4-bit immediate field.  */
     {  5,  5 }, /* SVE_imm5: 5-bit immediate field.  */
@@ -303,6 +304,8 @@ const aarch64_field fields[] =
     { 10,  2 }, /* SVE_msz: 2-bit shift amount for ADR.  */
     {  5,  5 }, /* SVE_pattern: vector pattern enumeration.  */
     {  0,  4 }, /* SVE_prfop: prefetch operation for SVE PRF[BHWD].  */
+    { 16,  1 }, /* SVE_rot1: 1-bit rotation amount.  */
+    { 10,  2 }, /* SVE_rot2: 2-bit rotation amount.  */
     { 22,  1 }, /* SVE_sz: 1-bit element size select.  */
     { 16,  4 }, /* SVE_tsz: triangular size select.  */
     { 22,  2 }, /* SVE_tszh: triangular size select high, bits [23,22].  */
@@ -1474,6 +1477,29 @@ operand_general_constraint_met_p (const aarch64_opnd_info *opnds, int idx,
     case AARCH64_OPND_CLASS_SVE_REG:
       switch (type)
        {
+       case AARCH64_OPND_SVE_Zm3_INDEX:
+       case AARCH64_OPND_SVE_Zm3_22_INDEX:
+       case AARCH64_OPND_SVE_Zm4_INDEX:
+         size = get_operand_fields_width (get_operand_from_code (type));
+         shift = get_operand_specific_data (&aarch64_operands[type]);
+         mask = (1 << shift) - 1;
+         if (opnd->reg.regno > mask)
+           {
+             assert (mask == 7 || mask == 15);
+             set_other_error (mismatch_detail, idx,
+                              mask == 15
+                              ? _("z0-z15 expected")
+                              : _("z0-z7 expected"));
+             return 0;
+           }
+         mask = (1 << (size - shift)) - 1;
+         if (!value_in_range_p (opnd->reglane.index, 0, mask))
+           {
+             set_elem_idx_out_of_range_error (mismatch_detail, idx, 0, mask);
+             return 0;
+           }
+         break;
+
        case AARCH64_OPND_SVE_Zn_INDEX:
          size = aarch64_get_qualifier_esize (opnd->qualifier);
          if (!value_in_range_p (opnd->reglane.index, 0, 64 / size - 1))
@@ -1798,6 +1824,11 @@ operand_general_constraint_met_p (const aarch64_opnd_info *opnds, int idx,
            }
          break;
 
+       case AARCH64_OPND_SVE_ADDR_RI_S4x16:
+         min_value = -8;
+         max_value = 7;
+         goto sve_imm_offset;
+
        case AARCH64_OPND_SVE_ADDR_RR:
        case AARCH64_OPND_SVE_ADDR_RR_LSL1:
        case AARCH64_OPND_SVE_ADDR_RR_LSL2:
@@ -2103,6 +2134,7 @@ operand_general_constraint_met_p (const aarch64_opnd_info *opnds, int idx,
 
        case AARCH64_OPND_IMM_ROT1:
        case AARCH64_OPND_IMM_ROT2:
+       case AARCH64_OPND_SVE_IMM_ROT2:
          if (opnd->imm.value != 0
              && opnd->imm.value != 90
              && opnd->imm.value != 180
@@ -2115,6 +2147,7 @@ operand_general_constraint_met_p (const aarch64_opnd_info *opnds, int idx,
          break;
 
        case AARCH64_OPND_IMM_ROT3:
+       case AARCH64_OPND_SVE_IMM_ROT1:
          if (opnd->imm.value != 90 && opnd->imm.value != 270)
            {
              set_other_error (mismatch_detail, idx,
@@ -3174,6 +3207,9 @@ aarch64_print_operand (char *buf, size_t size, bfd_vma pc,
       print_register_list (buf, size, opnd, "z");
       break;
 
+    case AARCH64_OPND_SVE_Zm3_INDEX:
+    case AARCH64_OPND_SVE_Zm3_22_INDEX:
+    case AARCH64_OPND_SVE_Zm4_INDEX:
     case AARCH64_OPND_SVE_Zn_INDEX:
       snprintf (buf, size, "z%d.%s[%" PRIi64 "]", opnd->reglane.regno,
                aarch64_get_qualifier_name (opnd->qualifier),
@@ -3214,6 +3250,8 @@ aarch64_print_operand (char *buf, size_t size, bfd_vma pc,
     case AARCH64_OPND_IMM_ROT1:
     case AARCH64_OPND_IMM_ROT2:
     case AARCH64_OPND_IMM_ROT3:
+    case AARCH64_OPND_SVE_IMM_ROT1:
+    case AARCH64_OPND_SVE_IMM_ROT2:
       snprintf (buf, size, "#%" PRIi64, opnd->imm.value);
       break;
 
@@ -3461,6 +3499,7 @@ aarch64_print_operand (char *buf, size_t size, bfd_vma pc,
     case AARCH64_OPND_ADDR_SIMM9:
     case AARCH64_OPND_ADDR_SIMM9_2:
     case AARCH64_OPND_ADDR_SIMM10:
+    case AARCH64_OPND_SVE_ADDR_RI_S4x16:
     case AARCH64_OPND_SVE_ADDR_RI_S4xVL:
     case AARCH64_OPND_SVE_ADDR_RI_S4x2xVL:
     case AARCH64_OPND_SVE_ADDR_RI_S4x3xVL:
index 2129e7b3569691382a7845edb49b50099397f6be..9f73ebac4ab4fddcd0622090ad8d26f312009f0a 100644 (file)
@@ -117,6 +117,7 @@ enum aarch64_field_kind
   FLD_SVE_Zn,
   FLD_SVE_Zt,
   FLD_SVE_i1,
+  FLD_SVE_i3h,
   FLD_SVE_imm3,
   FLD_SVE_imm4,
   FLD_SVE_imm5,
@@ -130,6 +131,8 @@ enum aarch64_field_kind
   FLD_SVE_msz,
   FLD_SVE_pattern,
   FLD_SVE_prfop,
+  FLD_SVE_rot1,
+  FLD_SVE_rot2,
   FLD_SVE_sz,
   FLD_SVE_tsz,
   FLD_SVE_tszh,
@@ -186,9 +189,9 @@ extern const aarch64_operand aarch64_operands[];
                                                   value by 2 to get the value
                                                   of an immediate operand.  */
 #define OPD_F_MAYBE_SP         0x00000010      /* May potentially be SP.  */
-#define OPD_F_OD_MASK          0x00000060      /* Operand-dependent data.  */
+#define OPD_F_OD_MASK          0x000000e0      /* Operand-dependent data.  */
 #define OPD_F_OD_LSB           5
-#define OPD_F_NO_ZR            0x00000080      /* ZR index not allowed.  */
+#define OPD_F_NO_ZR            0x00000100      /* ZR index not allowed.  */
 
 static inline bfd_boolean
 operand_has_inserter (const aarch64_operand *operand)
@@ -227,6 +230,14 @@ get_operand_specific_data (const aarch64_operand *operand)
   return (operand->flags & OPD_F_OD_MASK) >> OPD_F_OD_LSB;
 }
 
+/* Return the width of field number N of operand *OPERAND.  */
+static inline unsigned
+get_operand_field_width (const aarch64_operand *operand, unsigned n)
+{
+  assert (operand->fields[n] != FLD_NIL);
+  return fields[operand->fields[n]].width;
+}
+
 /* Return the total width of the operand *OPERAND.  */
 static inline unsigned
 get_operand_fields_width (const aarch64_operand *operand)
index 705ace63422dea689b2f9585b2c591e8fb980433..72b9952f9d1b580f10860b9536547ecaac669ac9 100644 (file)
 {                                                       \
   QLF2(S_H,S_B),                                        \
 }
+#define OP_SVE_HMH                                      \
+{                                                       \
+  QLF3(S_H,P_M,S_H),                                    \
+}
 #define OP_SVE_HMD                                      \
 {                                                       \
   QLF3(S_H,P_M,S_D),                                    \
   QLF3(S_S,P_M,W),                                      \
   QLF3(S_D,P_M,X),                                      \
 }
-#define OP_SVE_VMU_SD                                   \
+#define OP_SVE_VMU_HSD                                  \
 {                                                       \
+  QLF3(S_H,P_M,NIL),                                    \
   QLF3(S_S,P_M,NIL),                                    \
   QLF3(S_D,P_M,NIL),                                    \
 }
   QLF4(S_S,P_M,S_S,NIL),                                \
   QLF4(S_D,P_M,S_D,NIL),                                \
 }
-#define OP_SVE_VMVU_SD                                  \
+#define OP_SVE_VMVU_HSD                                 \
 {                                                       \
+  QLF4(S_H,P_M,S_H,NIL),                                \
   QLF4(S_S,P_M,S_S,NIL),                                \
   QLF4(S_D,P_M,S_D,NIL),                                \
 }
   QLF4(S_S,P_M,S_S,S_S),                                \
   QLF4(S_D,P_M,S_D,S_D),                                \
 }
+#define OP_SVE_VMVV_HSD                                 \
+{                                                       \
+  QLF4(S_H,P_M,S_H,S_H),                                \
+  QLF4(S_S,P_M,S_S,S_S),                                \
+  QLF4(S_D,P_M,S_D,S_D),                                \
+}
 #define OP_SVE_VMVV_SD                                  \
 {                                                       \
   QLF4(S_S,P_M,S_S,S_S),                                \
   QLF4(S_D,P_M,S_D,S_D),                                \
 }
+#define OP_SVE_VMVVU_HSD                                \
+{                                                       \
+  QLF5(S_H,P_M,S_H,S_H,NIL),                            \
+  QLF5(S_S,P_M,S_S,S_S,NIL),                            \
+  QLF5(S_D,P_M,S_D,S_D,NIL),                            \
+}
 #define OP_SVE_VMV_BHSD                                 \
 {                                                       \
   QLF3(S_B,P_M,S_B),                                    \
   QLF3(S_S,P_M,S_S),                                    \
   QLF3(S_D,P_M,S_D),                                    \
 }
-#define OP_SVE_VM_SD                                    \
+#define OP_SVE_VM_HSD                                   \
 {                                                       \
+  QLF2(S_H,P_M),                                        \
   QLF2(S_S,P_M),                                        \
   QLF2(S_D,P_M),                                        \
 }
   QLF4(S_S,NIL,S_S,S_S),                                \
   QLF4(S_D,NIL,S_D,S_D),                                \
 }
-#define OP_SVE_VUVV_SD                                  \
+#define OP_SVE_VUVV_HSD                                 \
 {                                                       \
+  QLF4(S_H,NIL,S_H,S_H),                                \
   QLF4(S_S,NIL,S_S,S_S),                                \
   QLF4(S_D,NIL,S_D,S_D),                                \
 }
   QLF3(S_S,NIL,S_S),                                    \
   QLF3(S_D,NIL,S_D),                                    \
 }
+#define OP_SVE_VUV_HSD                                  \
+{                                                       \
+  QLF3(S_H,NIL,S_H),                                    \
+  QLF3(S_S,NIL,S_S),                                    \
+  QLF3(S_D,NIL,S_D),                                    \
+}
 #define OP_SVE_VUV_SD                                   \
 {                                                       \
   QLF3(S_S,NIL,S_S),                                    \
   QLF2(S_S,NIL),                                        \
   QLF2(S_D,NIL),                                        \
 }
-#define OP_SVE_VU_SD                                    \
+#define OP_SVE_VU_HSD                                   \
 {                                                       \
+  QLF2(S_H,NIL),                                        \
   QLF2(S_S,NIL),                                        \
   QLF2(S_D,NIL),                                        \
 }
   QLF3(S_S,S_S,NIL),                                    \
   QLF3(S_D,S_D,NIL),                                    \
 }
-#define OP_SVE_VVVU_SD                                  \
+#define OP_SVE_VVVU_H                                   \
+{                                                       \
+  QLF4(S_H,S_H,S_H,NIL),                                \
+}
+#define OP_SVE_VVVU_S                                   \
 {                                                       \
   QLF4(S_S,S_S,S_S,NIL),                                \
+}
+#define OP_SVE_VVVU_HSD                                 \
+{                                                       \
+  QLF4(S_H,S_H,S_H,NIL),                                \
+  QLF4(S_S,S_S,S_S,NIL),                                \
   QLF4(S_D,S_D,S_D,NIL),                                \
 }
 #define OP_SVE_VVV_BHSD                                 \
   QLF3(S_S,S_S,S_S),                                    \
   QLF3(S_D,S_D,S_D),                                    \
 }
-#define OP_SVE_VVV_SD                                   \
+#define OP_SVE_VVV_D                                    \
+{                                                       \
+  QLF3(S_D,S_D,S_D),                                    \
+}
+#define OP_SVE_VVV_D_H                                  \
+{                                                       \
+  QLF3(S_D,S_H,S_H),                                    \
+}
+#define OP_SVE_VVV_H                                    \
 {                                                       \
+  QLF3(S_H,S_H,S_H),                                    \
+}
+#define OP_SVE_VVV_HSD                                  \
+{                                                       \
+  QLF3(S_H,S_H,S_H),                                    \
   QLF3(S_S,S_S,S_S),                                    \
   QLF3(S_D,S_D,S_D),                                    \
 }
+#define OP_SVE_VVV_S                                    \
+{                                                       \
+  QLF3(S_S,S_S,S_S),                                    \
+}
+#define OP_SVE_VVV_S_B                                  \
+{                                                       \
+  QLF3(S_S,S_B,S_B),                                    \
+}
+#define OP_SVE_VVV_SD_BH                                \
+{                                                       \
+  QLF3(S_S,S_B,S_B),                                    \
+  QLF3(S_D,S_H,S_H),                                    \
+}
 #define OP_SVE_VV_BHSD                                  \
 {                                                       \
   QLF2(S_B,S_B),                                        \
   QLF2(S_S,S_S),                                        \
   QLF2(S_D,S_D),                                        \
 }
+#define OP_SVE_VV_BHSDQ                                 \
+{                                                       \
+  QLF2(S_B,S_B),                                        \
+  QLF2(S_H,S_H),                                        \
+  QLF2(S_S,S_S),                                        \
+  QLF2(S_D,S_D),                                        \
+  QLF2(S_Q,S_Q),                                        \
+}
+#define OP_SVE_VV_HSD                                   \
+{                                                       \
+  QLF2(S_H,S_H),                                        \
+  QLF2(S_S,S_S),                                        \
+  QLF2(S_D,S_D),                                        \
+}
 #define OP_SVE_VV_HSD_BHS                               \
 {                                                       \
   QLF2(S_H,S_B),                                        \
   QLF4(S_S,P_Z,S_S,S_S),                                \
   QLF4(S_D,P_Z,S_D,S_D),                                \
 }
-#define OP_SVE_VZVV_SD                                  \
+#define OP_SVE_VZVV_HSD                                 \
 {                                                       \
+  QLF4(S_H,P_Z,S_H,S_H),                                \
   QLF4(S_S,P_Z,S_S,S_S),                                \
   QLF4(S_D,P_Z,S_D,S_D),                                \
 }
-#define OP_SVE_VZV_SD                                   \
+#define OP_SVE_VZV_HSD                                  \
 {                                                       \
+  QLF3(S_H,P_Z,S_H),                                    \
   QLF3(S_S,P_Z,S_S),                                    \
   QLF3(S_D,P_Z,S_D),                                    \
 }
-#define OP_SVE_V_SD                                     \
+#define OP_SVE_V_HSD                                    \
 {                                                       \
+  QLF1(S_H),                                            \
   QLF1(S_S),                                            \
   QLF1(S_D),                                            \
 }
@@ -3281,13 +3360,13 @@ struct aarch64_opcode aarch64_opcode_table[] =
   CORE_INSN ("bgt", 0x5400000c, 0xff00001f, condbranch, 0, OP1 (ADDR_PCREL19), QL_PCREL_NIL, F_ALIAS | F_PSEUDO),
   CORE_INSN ("ble", 0x5400000d, 0xff00001f, condbranch, 0, OP1 (ADDR_PCREL19), QL_PCREL_NIL, F_ALIAS | F_PSEUDO),
   /* SVE instructions.  */
-  _SVE_INSN ("fmov", 0x25b9c000, 0xffbfe000, sve_size_sd, 0, OP2 (SVE_Zd, SVE_FPIMM8), OP_SVE_VU_SD, F_ALIAS, 0),
-  _SVE_INSN ("fmov", 0x0590c000, 0xffb0e000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg4_16, SVE_FPIMM8), OP_SVE_VMU_SD, F_ALIAS, 0),
+  _SVE_INSN ("fmov", 0x2539c000, 0xff3fe000, sve_size_hsd, 0, OP2 (SVE_Zd, SVE_FPIMM8), OP_SVE_VU_HSD, F_ALIAS, 0),
+  _SVE_INSN ("fmov", 0x0510c000, 0xff30e000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg4_16, SVE_FPIMM8), OP_SVE_VMU_HSD, F_ALIAS, 0),
   _SVE_INSN ("mov", 0x04603000, 0xffe0fc00, sve_misc, OP_MOV_Z_Z, OP2 (SVE_Zd, SVE_Zn), OP_SVE_DD, F_ALIAS | F_MISC, 0),
-  _SVE_INSN ("mov", 0x05202000, 0xff20fc00, sve_index, OP_MOV_Z_V, OP2 (SVE_Zd, SVE_VZn), OP_SVE_VV_BHSD, F_ALIAS | F_MISC, 0),
+  _SVE_INSN ("mov", 0x05202000, 0xff20fc00, sve_index, OP_MOV_Z_V, OP2 (SVE_Zd, SVE_VZn), OP_SVE_VV_BHSDQ, F_ALIAS | F_MISC, 0),
   _SVE_INSN ("mov", 0x05203800, 0xff3ffc00, sve_size_bhsd, 0, OP2 (SVE_Zd, Rn_SP), OP_SVE_VR_BHSD, F_ALIAS, 0),
   _SVE_INSN ("mov", 0x25804000, 0xfff0c210, sve_misc, OP_MOV_P_P, OP2 (SVE_Pd, SVE_Pn), OP_SVE_BB, F_ALIAS | F_MISC, 0),
-  _SVE_INSN ("mov", 0x05202000, 0xff20fc00, sve_index, OP_MOV_Z_Zi, OP2 (SVE_Zd, SVE_Zn_INDEX), OP_SVE_VV_BHSD, F_ALIAS | F_MISC, 0),
+  _SVE_INSN ("mov", 0x05202000, 0xff20fc00, sve_index, OP_MOV_Z_Zi, OP2 (SVE_Zd, SVE_Zn_INDEX), OP_SVE_VV_BHSDQ, F_ALIAS | F_MISC, 0),
   _SVE_INSN ("mov", 0x05c00000, 0xfffc0000, sve_limm, 0, OP2 (SVE_Zd, SVE_LIMM_MOV), OP_SVE_VU_BHSD, F_ALIAS, 0),
   _SVE_INSN ("mov", 0x2538c000, 0xff3fc000, sve_size_bhsd, 0, OP2 (SVE_Zd, SVE_ASIMM), OP_SVE_VU_BHSD, F_ALIAS, 0),
   _SVE_INSN ("mov", 0x05208000, 0xff3fe000, sve_size_bhsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Vn), OP_SVE_VMV_BHSD, F_ALIAS, 0),
@@ -3393,7 +3472,7 @@ struct aarch64_opcode aarch64_opcode_table[] =
   _SVE_INSN ("decw", 0x04b0c400, 0xfff0fc00, sve_misc, 0, OP2 (SVE_Zd, SVE_PATTERN_SCALED), OP_SVE_SU, F_OPD1_OPT | F_DEFAULT(31), 0),
   _SVE_INSN ("decw", 0x04b0e400, 0xfff0fc00, sve_misc, 0, OP2 (Rd, SVE_PATTERN_SCALED), OP_SVE_XU, F_OPD1_OPT | F_DEFAULT(31), 0),
   _SVE_INSN ("dup", 0x05203800, 0xff3ffc00, sve_size_bhsd, 0, OP2 (SVE_Zd, Rn_SP), OP_SVE_VR_BHSD, F_HAS_ALIAS, 0),
-  _SVE_INSN ("dup", 0x05202000, 0xff20fc00, sve_index, 0, OP2 (SVE_Zd, SVE_Zn_INDEX), OP_SVE_VV_BHSD, F_HAS_ALIAS, 0),
+  _SVE_INSN ("dup", 0x05202000, 0xff20fc00, sve_index, 0, OP2 (SVE_Zd, SVE_Zn_INDEX), OP_SVE_VV_BHSDQ, F_HAS_ALIAS, 0),
   _SVE_INSN ("dup", 0x2538c000, 0xff3fc000, sve_size_bhsd, 0, OP2 (SVE_Zd, SVE_ASIMM), OP_SVE_VU_BHSD, F_HAS_ALIAS, 0),
   _SVE_INSN ("dupm", 0x05c00000, 0xfffc0000, sve_limm, 0, OP2 (SVE_Zd, SVE_LIMM), OP_SVE_VU_BHSD, F_HAS_ALIAS, 0),
   _SVE_INSN ("eor", 0x04a03000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_DDD, 0, 0),
@@ -3403,92 +3482,111 @@ struct aarch64_opcode aarch64_opcode_table[] =
   _SVE_INSN ("eors", 0x25404200, 0xfff0c210, sve_misc, 0, OP4 (SVE_Pd, SVE_Pg4_10, SVE_Pn, SVE_Pm), OP_SVE_BZBB, F_HAS_ALIAS, 0),
   _SVE_INSN ("eorv", 0x04192000, 0xff3fe000, sve_size_bhsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_BHSD, 0, 0),
   _SVE_INSN ("ext", 0x05200000, 0xffe0e000, sve_misc, 0, OP4 (SVE_Zd, SVE_Zd, SVE_Zm_5, SVE_UIMM8_53), OP_SVE_BBBU, 0, 1),
-  _SVE_INSN ("fabd", 0x65888000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fabs", 0x049ca000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("facge", 0x6580c010, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_SD, F_HAS_ALIAS, 0),
-  _SVE_INSN ("facgt", 0x6580e010, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_SD, F_HAS_ALIAS, 0),
-  _SVE_INSN ("fadd", 0x65800000, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD, 0, 0),
-  _SVE_INSN ("fadd", 0x65808000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fadd", 0x65988000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_ONE), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("fadda", 0x65982000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Vd, SVE_Pg3, SVE_Vd, SVE_Zm_5), OP_SVE_VUVV_SD, 0, 2),
-  _SVE_INSN ("faddv", 0x65802000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_SD, 0, 0),
-  _SVE_INSN ("fcmeq", 0x65922000, 0xffbfe010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_SD, 0, 0),
-  _SVE_INSN ("fcmeq", 0x65806000, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_SD, 0, 0),
-  _SVE_INSN ("fcmge", 0x65902000, 0xffbfe010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_SD, 0, 0),
-  _SVE_INSN ("fcmge", 0x65804000, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_SD, F_HAS_ALIAS, 0),
-  _SVE_INSN ("fcmgt", 0x65902010, 0xffbfe010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_SD, 0, 0),
-  _SVE_INSN ("fcmgt", 0x65804010, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_SD, F_HAS_ALIAS, 0),
-  _SVE_INSN ("fcmle", 0x65912010, 0xffbfe010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_SD, 0, 0),
-  _SVE_INSN ("fcmlt", 0x65912000, 0xffbfe010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_SD, 0, 0),
-  _SVE_INSN ("fcmne", 0x65932000, 0xffbfe010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_SD, 0, 0),
-  _SVE_INSN ("fcmne", 0x65806010, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_SD, 0, 0),
-  _SVE_INSN ("fcmuo", 0x6580c000, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_SD, 0, 0),
-  _SVE_INSN ("fcpy", 0x0590c000, 0xffb0e000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg4_16, SVE_FPIMM8), OP_SVE_VMU_SD, F_HAS_ALIAS, 0),
+  _SVE_INSN ("fabd", 0x65088000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fabs", 0x041ca000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("facge", 0x6500c010, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_HSD, F_HAS_ALIAS, 0),
+  _SVE_INSN ("facgt", 0x6500e010, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_HSD, F_HAS_ALIAS, 0),
+  _SVE_INSN ("fadd", 0x65000000, 0xff20fc00, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_HSD, 0, 0),
+  _SVE_INSN ("fadd", 0x65008000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fadd", 0x65188000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_ONE), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("fadda", 0x65182000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Vd, SVE_Pg3, SVE_Vd, SVE_Zm_5), OP_SVE_VUVV_HSD, 0, 2),
+  _SVE_INSN ("faddv", 0x65002000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_HSD, 0, 0),
+  _SVE_INSN ("fcadd", 0x64008000, 0xff3ee000, sve_size_hsd, 0, OP5 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5, SVE_IMM_ROT1), OP_SVE_VMVVU_HSD, 0, 2),
+  _SVE_INSN ("fcmla", 0x64000000, 0xff208000, sve_size_hsd, 0, OP5 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16, IMM_ROT2), OP_SVE_VMVVU_HSD, 0, 0),
+  _SVE_INSN ("fcmla", 0x64a01000, 0xffe0f000, sve_misc, 0, OP4 (SVE_Zd, SVE_Zn, SVE_Zm3_INDEX, SVE_IMM_ROT2), OP_SVE_VVVU_H, 0, 0),
+  _SVE_INSN ("fcmla", 0x64e01000, 0xffe0f000, sve_misc, 0, OP4 (SVE_Zd, SVE_Zn, SVE_Zm4_INDEX, SVE_IMM_ROT2), OP_SVE_VVVU_S, 0, 0),
+  _SVE_INSN ("fcmeq", 0x65122000, 0xff3fe010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_HSD, 0, 0),
+  _SVE_INSN ("fcmeq", 0x65006000, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_HSD, 0, 0),
+  _SVE_INSN ("fcmge", 0x65102000, 0xff3fe010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_HSD, 0, 0),
+  _SVE_INSN ("fcmge", 0x65004000, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_HSD, F_HAS_ALIAS, 0),
+  _SVE_INSN ("fcmgt", 0x65102010, 0xff3fe010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_HSD, 0, 0),
+  _SVE_INSN ("fcmgt", 0x65004010, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_HSD, F_HAS_ALIAS, 0),
+  _SVE_INSN ("fcmle", 0x65112010, 0xff3fe010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_HSD, 0, 0),
+  _SVE_INSN ("fcmlt", 0x65112000, 0xff3fe010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_HSD, 0, 0),
+  _SVE_INSN ("fcmne", 0x65132000, 0xff3fe010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, FPIMM0), OP_SVE_VZV_HSD, 0, 0),
+  _SVE_INSN ("fcmne", 0x65006010, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_HSD, 0, 0),
+  _SVE_INSN ("fcmuo", 0x6500c000, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VZVV_HSD, 0, 0),
+  _SVE_INSN ("fcpy", 0x0510c000, 0xff30e000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg4_16, SVE_FPIMM8), OP_SVE_VMU_HSD, F_HAS_ALIAS, 0),
   _SVE_INSN ("fcvt", 0x6588a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMS, 0, 0),
   _SVE_INSN ("fcvt", 0x6589a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMH, 0, 0),
   _SVE_INSN ("fcvt", 0x65c8a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMD, 0, 0),
   _SVE_INSN ("fcvt", 0x65c9a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMH, 0, 0),
   _SVE_INSN ("fcvt", 0x65caa000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMD, 0, 0),
   _SVE_INSN ("fcvt", 0x65cba000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMS, 0, 0),
+  _SVE_INSN ("fcvtzs", 0x655aa000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMH, 0, 0),
+  _SVE_INSN ("fcvtzs", 0x655ca000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMH, 0, 0),
+  _SVE_INSN ("fcvtzs", 0x655ea000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMH, 0, 0),
   _SVE_INSN ("fcvtzs", 0x659ca000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMS, 0, 0),
   _SVE_INSN ("fcvtzs", 0x65d8a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMD, 0, 0),
   _SVE_INSN ("fcvtzs", 0x65dca000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMS, 0, 0),
   _SVE_INSN ("fcvtzs", 0x65dea000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMD, 0, 0),
+  _SVE_INSN ("fcvtzu", 0x655ba000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMH, 0, 0),
+  _SVE_INSN ("fcvtzu", 0x655da000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMH, 0, 0),
+  _SVE_INSN ("fcvtzu", 0x655fa000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMH, 0, 0),
   _SVE_INSN ("fcvtzu", 0x659da000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMS, 0, 0),
   _SVE_INSN ("fcvtzu", 0x65d9a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMD, 0, 0),
   _SVE_INSN ("fcvtzu", 0x65dda000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMS, 0, 0),
   _SVE_INSN ("fcvtzu", 0x65dfa000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMD, 0, 0),
-  _SVE_INSN ("fdiv", 0x658d8000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fdivr", 0x658c8000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fdup", 0x25b9c000, 0xffbfe000, sve_size_sd, 0, OP2 (SVE_Zd, SVE_FPIMM8), OP_SVE_VU_SD, F_HAS_ALIAS, 0),
-  _SVE_INSN ("fexpa", 0x04a0b800, 0xffbffc00, sve_size_sd, 0, OP2 (SVE_Zd, SVE_Zn), OP_SVE_VV_SD, 0, 0),
-  _SVE_INSN ("fmad", 0x65a08000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("fmax", 0x65868000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fmax", 0x659e8000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("fmaxnm", 0x65848000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fmaxnm", 0x659c8000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("fmaxnmv", 0x65842000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_SD, 0, 0),
-  _SVE_INSN ("fmaxv", 0x65862000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_SD, 0, 0),
-  _SVE_INSN ("fmin", 0x65878000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fmin", 0x659f8000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("fminnm", 0x65858000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fminnm", 0x659d8000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("fminnmv", 0x65852000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_SD, 0, 0),
-  _SVE_INSN ("fminv", 0x65872000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_SD, 0, 0),
-  _SVE_INSN ("fmla", 0x65a00000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("fmls", 0x65a02000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("fmsb", 0x65a0a000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("fmul", 0x65800800, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD, 0, 0),
-  _SVE_INSN ("fmul", 0x65828000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fmul", 0x659a8000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_TWO), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("fmulx", 0x658a8000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fneg", 0x049da000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("fnmad", 0x65a0c000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("fnmla", 0x65a04000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("fnmls", 0x65a06000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("fnmsb", 0x65a0e000, 0xffa0e000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_SD, 0, 0),
-  _SVE_INSN ("frecpe", 0x658e3000, 0xffbffc00, sve_size_sd, 0, OP2 (SVE_Zd, SVE_Zn), OP_SVE_VV_SD, 0, 0),
-  _SVE_INSN ("frecps", 0x65801800, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD, 0, 0),
-  _SVE_INSN ("frecpx", 0x658ca000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frinta", 0x6584a000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frinti", 0x6587a000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frintm", 0x6582a000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frintn", 0x6580a000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frintp", 0x6581a000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frintx", 0x6586a000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frintz", 0x6583a000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("frsqrte", 0x658f3000, 0xffbffc00, sve_size_sd, 0, OP2 (SVE_Zd, SVE_Zn), OP_SVE_VV_SD, 0, 0),
-  _SVE_INSN ("frsqrts", 0x65801c00, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD, 0, 0),
-  _SVE_INSN ("fscale", 0x65898000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fsqrt", 0x658da000, 0xffbfe000, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_SD, 0, 0),
-  _SVE_INSN ("fsub", 0x65800400, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD, 0, 0),
-  _SVE_INSN ("fsub", 0x65818000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fsub", 0x65998000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_ONE), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("fsubr", 0x65838000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
-  _SVE_INSN ("fsubr", 0x659b8000, 0xffbfe3c0, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_ONE), OP_SVE_VMVU_SD, 0, 2),
-  _SVE_INSN ("ftmad", 0x65908000, 0xffb8fc00, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Zd, SVE_Zm_5, SVE_UIMM3), OP_SVE_VVVU_SD, 0, 1),
-  _SVE_INSN ("ftsmul", 0x65800c00, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD, 0, 0),
-  _SVE_INSN ("ftssel", 0x04a0b000, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD, 0, 0),
+  _SVE_INSN ("fdiv", 0x650d8000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fdivr", 0x650c8000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fdup", 0x2539c000, 0xff3fe000, sve_size_hsd, 0, OP2 (SVE_Zd, SVE_FPIMM8), OP_SVE_VU_HSD, F_HAS_ALIAS, 0),
+  _SVE_INSN ("fexpa", 0x0420b800, 0xff3ffc00, sve_size_hsd, 0, OP2 (SVE_Zd, SVE_Zn), OP_SVE_VV_HSD, 0, 0),
+  _SVE_INSN ("fmad", 0x65208000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("fmax", 0x65068000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fmax", 0x651e8000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("fmaxnm", 0x65048000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fmaxnm", 0x651c8000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("fmaxnmv", 0x65042000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_HSD, 0, 0),
+  _SVE_INSN ("fmaxv", 0x65062000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_HSD, 0, 0),
+  _SVE_INSN ("fmin", 0x65078000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fmin", 0x651f8000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("fminnm", 0x65058000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fminnm", 0x651d8000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_ZERO_ONE), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("fminnmv", 0x65052000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_HSD, 0, 0),
+  _SVE_INSN ("fminv", 0x65072000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_HSD, 0, 0),
+  _SVE_INSN ("fmla", 0x65200000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("fmla", 0x64200000, 0xffa0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_22_INDEX), OP_SVE_VVV_H, 0, 0),
+  _SVE_INSN ("fmla", 0x64a00000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_INDEX), OP_SVE_VVV_S, 0, 0),
+  _SVE_INSN ("fmla", 0x64e00000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm4_INDEX), OP_SVE_VVV_D, 0, 0),
+  _SVE_INSN ("fmls", 0x65202000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("fmls", 0x64200400, 0xffa0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_22_INDEX), OP_SVE_VVV_H, 0, 0),
+  _SVE_INSN ("fmls", 0x64a00400, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_INDEX), OP_SVE_VVV_S, 0, 0),
+  _SVE_INSN ("fmls", 0x64e00400, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm4_INDEX), OP_SVE_VVV_D, 0, 0),
+  _SVE_INSN ("fmsb", 0x6520a000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("fmul", 0x65000800, 0xff20fc00, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_HSD, 0, 0),
+  _SVE_INSN ("fmul", 0x65028000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fmul", 0x651a8000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_TWO), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("fmul", 0x64202000, 0xffa0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_22_INDEX), OP_SVE_VVV_H, 0, 0),
+  _SVE_INSN ("fmul", 0x64a02000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_INDEX), OP_SVE_VVV_S, 0, 0),
+  _SVE_INSN ("fmul", 0x64e02000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm4_INDEX), OP_SVE_VVV_D, 0, 0),
+  _SVE_INSN ("fmulx", 0x650a8000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fneg", 0x041da000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("fnmad", 0x6520c000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("fnmla", 0x65204000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("fnmls", 0x65206000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zn, SVE_Zm_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("fnmsb", 0x6520e000, 0xff20e000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zm_5, SVE_Za_16), OP_SVE_VMVV_HSD, 0, 0),
+  _SVE_INSN ("frecpe", 0x650e3000, 0xff3ffc00, sve_size_hsd, 0, OP2 (SVE_Zd, SVE_Zn), OP_SVE_VV_HSD, 0, 0),
+  _SVE_INSN ("frecps", 0x65001800, 0xff20fc00, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_HSD, 0, 0),
+  _SVE_INSN ("frecpx", 0x650ca000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frinta", 0x6504a000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frinti", 0x6507a000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frintm", 0x6502a000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frintn", 0x6500a000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frintp", 0x6501a000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frintx", 0x6506a000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frintz", 0x6503a000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("frsqrte", 0x650f3000, 0xff3ffc00, sve_size_hsd, 0, OP2 (SVE_Zd, SVE_Zn), OP_SVE_VV_HSD, 0, 0),
+  _SVE_INSN ("frsqrts", 0x65001c00, 0xff20fc00, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_HSD, 0, 0),
+  _SVE_INSN ("fscale", 0x65098000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fsqrt", 0x650da000, 0xff3fe000, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_VMV_HSD, 0, 0),
+  _SVE_INSN ("fsub", 0x65000400, 0xff20fc00, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_HSD, 0, 0),
+  _SVE_INSN ("fsub", 0x65018000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fsub", 0x65198000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_ONE), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("fsubr", 0x65038000, 0xff3fe000, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_HSD, 0, 2),
+  _SVE_INSN ("fsubr", 0x651b8000, 0xff3fe3c0, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_I1_HALF_ONE), OP_SVE_VMVU_HSD, 0, 2),
+  _SVE_INSN ("ftmad", 0x65108000, 0xff38fc00, sve_size_hsd, 0, OP4 (SVE_Zd, SVE_Zd, SVE_Zm_5, SVE_UIMM3), OP_SVE_VVVU_HSD, 0, 1),
+  _SVE_INSN ("ftsmul", 0x65000c00, 0xff20fc00, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_HSD, 0, 0),
+  _SVE_INSN ("ftssel", 0x0420b000, 0xff20fc00, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_HSD, 0, 0),
   _SVE_INSN ("incb", 0x0430e000, 0xfff0fc00, sve_misc, 0, OP2 (Rd, SVE_PATTERN_SCALED), OP_SVE_XU, F_OPD1_OPT | F_DEFAULT(31), 0),
   _SVE_INSN ("incd", 0x04f0c000, 0xfff0fc00, sve_misc, 0, OP2 (SVE_Zd, SVE_PATTERN_SCALED), OP_SVE_DU, F_OPD1_OPT | F_DEFAULT(31), 0),
   _SVE_INSN ("incd", 0x04f0e000, 0xfff0fc00, sve_misc, 0, OP2 (Rd, SVE_PATTERN_SCALED), OP_SVE_XU, F_OPD1_OPT | F_DEFAULT(31), 0),
@@ -3550,6 +3648,14 @@ struct aarch64_opcode aarch64_opcode_table[] =
   _SVE_INSN ("ld1rh", 0x84c0a000, 0xffc0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_U6x2), OP_SVE_HZU, F_OD(1), 0),
   _SVE_INSN ("ld1rh", 0x84c0c000, 0xffc0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_U6x2), OP_SVE_SZU, F_OD(1), 0),
   _SVE_INSN ("ld1rh", 0x84c0e000, 0xffc0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_U6x2), OP_SVE_DZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqb", 0xa4002000, 0xfff0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_S4x16), OP_SVE_BZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqb", 0xa4000000, 0xffe0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RX), OP_SVE_BZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqd", 0xa5802000, 0xfff0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_S4x16), OP_SVE_DZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqd", 0xa5800000, 0xffe0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RX_LSL3), OP_SVE_DZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqh", 0xa4802000, 0xfff0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_S4x16), OP_SVE_HZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqh", 0xa4800000, 0xffe0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RX_LSL1), OP_SVE_HZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqw", 0xa5002000, 0xfff0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_S4x16), OP_SVE_SZU, F_OD(1), 0),
+  _SVE_INSN ("ld1rqw", 0xa5000000, 0xffe0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RX_LSL2), OP_SVE_SZU, F_OD(1), 0),
   _SVE_INSN ("ld1rsb", 0x85c08000, 0xffc0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_U6), OP_SVE_DZU, F_OD(1), 0),
   _SVE_INSN ("ld1rsb", 0x85c0a000, 0xffc0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_U6), OP_SVE_SZU, F_OD(1), 0),
   _SVE_INSN ("ld1rsb", 0x85c0c000, 0xffc0e000, sve_misc, 0, OP3 (SVE_ZtxN, SVE_Pg3, SVE_ADDR_RI_U6), OP_SVE_HZU, F_OD(1), 0),
@@ -3792,12 +3898,18 @@ struct aarch64_opcode aarch64_opcode_table[] =
   _SVE_INSN ("revw", 0x05e68000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMD, 0, 0),
   _SVE_INSN ("sabd", 0x040c0000, 0xff3fe000, sve_size_bhsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_BHSD, 0, 2),
   _SVE_INSN ("saddv", 0x04002000, 0xff3fe000, sve_size_bhs, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_DUV_BHS, 0, 0),
+  _SVE_INSN ("scvtf", 0x6552a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMH, 0, 0),
+  _SVE_INSN ("scvtf", 0x6554a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMS, 0, 0),
   _SVE_INSN ("scvtf", 0x6594a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMS, 0, 0),
   _SVE_INSN ("scvtf", 0x65d0a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMS, 0, 0),
+  _SVE_INSN ("scvtf", 0x6556a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMD, 0, 0),
   _SVE_INSN ("scvtf", 0x65d4a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMD, 0, 0),
   _SVE_INSN ("scvtf", 0x65d6a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMD, 0, 0),
   _SVE_INSN ("sdiv", 0x04940000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
   _SVE_INSN ("sdivr", 0x04960000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
+  _SVE_INSN ("sdot", 0x44800000, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD_BH, 0, 0),
+  _SVE_INSN ("sdot", 0x44a00000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_INDEX), OP_SVE_VVV_S_B, 0, 0),
+  _SVE_INSN ("sdot", 0x44e00000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm4_INDEX), OP_SVE_VVV_D_H, 0, 0),
   _SVE_INSN ("sel", 0x0520c000, 0xff20c000, sve_size_bhsd, 0, OP4 (SVE_Zd, SVE_Pg4_10, SVE_Zn, SVE_Zm_16), OP_SVE_VUVV_BHSD, F_HAS_ALIAS, 0),
   _SVE_INSN ("sel", 0x25004210, 0xfff0c210, sve_misc, 0, OP4 (SVE_Pd, SVE_Pg4_10, SVE_Pn, SVE_Pm), OP_SVE_BUBB, F_HAS_ALIAS, 0),
   _SVE_INSN ("setffr", 0x252c9000, 0xffffffff, sve_misc, 0, OP0 (), {}, 0, 0),
@@ -3938,12 +4050,18 @@ struct aarch64_opcode aarch64_opcode_table[] =
   _SVE_INSN ("trn2", 0x05207400, 0xff20fc00, sve_size_bhsd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_BHSD, 0, 0),
   _SVE_INSN ("uabd", 0x040d0000, 0xff3fe000, sve_size_bhsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_BHSD, 0, 2),
   _SVE_INSN ("uaddv", 0x04012000, 0xff3fe000, sve_size_bhsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_DUV_BHSD, 0, 0),
+  _SVE_INSN ("ucvtf", 0x6553a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMH, 0, 0),
+  _SVE_INSN ("ucvtf", 0x6555a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMS, 0, 0),
   _SVE_INSN ("ucvtf", 0x6595a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMS, 0, 0),
   _SVE_INSN ("ucvtf", 0x65d1a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMS, 0, 0),
+  _SVE_INSN ("ucvtf", 0x6557a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_HMD, 0, 0),
   _SVE_INSN ("ucvtf", 0x65d5a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_SMD, 0, 0),
   _SVE_INSN ("ucvtf", 0x65d7a000, 0xffffe000, sve_misc, 0, OP3 (SVE_Zd, SVE_Pg3, SVE_Zn), OP_SVE_DMD, 0, 0),
   _SVE_INSN ("udiv", 0x04950000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
   _SVE_INSN ("udivr", 0x04970000, 0xffbfe000, sve_size_sd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_SD, 0, 2),
+  _SVE_INSN ("udot", 0x44800400, 0xffa0fc00, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_SD_BH, 0, 0),
+  _SVE_INSN ("udot", 0x44a00400, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm3_INDEX), OP_SVE_VVV_S_B, 0, 0),
+  _SVE_INSN ("udot", 0x44e00400, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm4_INDEX), OP_SVE_VVV_D_H, 0, 0),
   _SVE_INSN ("umax", 0x2529c000, 0xff3fe000, sve_size_bhsd, 0, OP3 (SVE_Zd, SVE_Zd, SVE_UIMM8), OP_SVE_VVU_BHSD, 0, 1),
   _SVE_INSN ("umax", 0x04090000, 0xff3fe000, sve_size_bhsd, 0, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_VMVV_BHSD, 0, 2),
   _SVE_INSN ("umaxv", 0x04092000, 0xff3fe000, sve_size_bhsd, 0, OP3 (SVE_Vd, SVE_Pg3, SVE_Zn), OP_SVE_VUV_BHSD, 0, 0),
@@ -4011,12 +4129,12 @@ struct aarch64_opcode aarch64_opcode_table[] =
   _SVE_INSN ("cmpls", 0x24000000, 0xff20e010, sve_size_bhsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_BHSD, F_ALIAS | F_PSEUDO, 0),
   _SVE_INSN ("cmplt", 0x24008010, 0xff20e010, sve_size_bhsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_BHSD, F_ALIAS | F_PSEUDO, 0),
   _SVE_INSN ("eon", 0x05400000, 0xfffc0000, sve_limm, 0, OP3 (SVE_Zd, SVE_Zd, SVE_INV_LIMM), OP_SVE_VVU_BHSD, F_ALIAS | F_PSEUDO, 1),
-  _SVE_INSN ("facle", 0x6580c010, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_SD, F_ALIAS | F_PSEUDO, 0),
-  _SVE_INSN ("faclt", 0x6580e010, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_SD, F_ALIAS | F_PSEUDO, 0),
-  _SVE_INSN ("fcmle", 0x65804000, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_SD, F_ALIAS | F_PSEUDO, 0),
-  _SVE_INSN ("fcmlt", 0x65804010, 0xffa0e010, sve_size_sd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_SD, F_ALIAS | F_PSEUDO, 0),
-  _SVE_INSN ("fmov", 0x25b8c000, 0xffbfffe0, sve_size_sd, 0, OP2 (SVE_Zd, FPIMM0), OP_SVE_V_SD, F_ALIAS | F_PSEUDO, 0),
-  _SVE_INSN ("fmov", 0x05904000, 0xffb0ffe0, sve_size_sd, 0, OP3 (SVE_Zd, SVE_Pg4_16, FPIMM0), OP_SVE_VM_SD, F_ALIAS | F_PSEUDO, 0),
+  _SVE_INSN ("facle", 0x6500c010, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_HSD, F_ALIAS | F_PSEUDO, 0),
+  _SVE_INSN ("faclt", 0x6500e010, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_HSD, F_ALIAS | F_PSEUDO, 0),
+  _SVE_INSN ("fcmle", 0x65004000, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_HSD, F_ALIAS | F_PSEUDO, 0),
+  _SVE_INSN ("fcmlt", 0x65004010, 0xff20e010, sve_size_hsd, 0, OP4 (SVE_Pd, SVE_Pg3, SVE_Zm_16, SVE_Zn), OP_SVE_VZVV_HSD, F_ALIAS | F_PSEUDO, 0),
+  _SVE_INSN ("fmov", 0x2538c000, 0xff3fffe0, sve_size_hsd, 0, OP2 (SVE_Zd, FPIMM0), OP_SVE_V_HSD, F_ALIAS | F_PSEUDO, 0),
+  _SVE_INSN ("fmov", 0x05104000, 0xff30ffe0, sve_size_hsd, 0, OP3 (SVE_Zd, SVE_Pg4_16, FPIMM0), OP_SVE_VM_HSD, F_ALIAS | F_PSEUDO, 0),
   _SVE_INSN ("orn", 0x05000000, 0xfffc0000, sve_limm, 0, OP3 (SVE_Zd, SVE_Zd, SVE_INV_LIMM), OP_SVE_VVU_BHSD, F_ALIAS | F_PSEUDO, 1),
 
   {0, 0, 0, 0, 0, 0, {}, {}, 0, 0, NULL},
@@ -4147,11 +4265,11 @@ struct aarch64_opcode aarch64_opcode_table[] =
     Y(IMMEDIATE, fbits, "FBITS", 0, F(FLD_scale),                      \
       "the number of bits after the binary point in the fixed-point value")\
     X(IMMEDIATE, 0, 0, "IMM_MOV", 0, F(), "an immediate")              \
-    Y(IMMEDIATE, imm_rotate, "IMM_ROT1", 0, F(FLD_rotate1),            \
+    Y(IMMEDIATE, imm_rotate2, "IMM_ROT1", 0, F(FLD_rotate1),           \
       "a 2-bit rotation specifier for complex arithmetic operations")  \
-    Y(IMMEDIATE, imm_rotate, "IMM_ROT2", 0, F(FLD_rotate2),            \
+    Y(IMMEDIATE, imm_rotate2, "IMM_ROT2", 0, F(FLD_rotate2),           \
       "a 2-bit rotation specifier for complex arithmetic operations")  \
-    Y(IMMEDIATE, imm_rotate, "IMM_ROT3", 0, F(FLD_rotate3),            \
+    Y(IMMEDIATE, imm_rotate1, "IMM_ROT3", 0, F(FLD_rotate3),           \
       "a 1-bit rotation specifier for complex arithmetic operations")  \
     Y(COND, cond, "COND", 0, F(), "a condition")                       \
     Y(COND, cond, "COND1", 0, F(),                                     \
@@ -4203,6 +4321,9 @@ struct aarch64_opcode aarch64_opcode_table[] =
       "a prefetch operation specifier")                                        \
     Y(SYSTEM, hint, "BARRIER_PSB", 0, F (),                            \
       "the PSB option name CSYNC")                                     \
+    Y(ADDRESS, sve_addr_ri_s4, "SVE_ADDR_RI_S4x16",                    \
+      4 << OPD_F_OD_LSB, F(FLD_Rn),                                    \
+      "an address with a 4-bit signed offset, multiplied by 16")       \
     Y(ADDRESS, sve_addr_ri_s4xvl, "SVE_ADDR_RI_S4xVL",                 \
       0 << OPD_F_OD_LSB, F(FLD_Rn),                                    \
       "an address with a 4-bit signed offset, multiplied by VL")       \
@@ -4320,6 +4441,10 @@ struct aarch64_opcode aarch64_opcode_table[] =
       F(FLD_SVE_i1), "either 0.5 or 2.0")                              \
     Y(IMMEDIATE, sve_float_zero_one, "SVE_I1_ZERO_ONE", 0,             \
       F(FLD_SVE_i1), "either 0.0 or 1.0")                              \
+    Y(IMMEDIATE, imm_rotate1, "SVE_IMM_ROT1", 0, F(FLD_SVE_rot1),      \
+      "a 1-bit rotation specifier for complex arithmetic operations")  \
+    Y(IMMEDIATE, imm_rotate2, "SVE_IMM_ROT2", 0, F(FLD_SVE_rot2),      \
+      "a 2-bit rotation specifier for complex arithmetic operations")  \
     Y(IMMEDIATE, inv_limm, "SVE_INV_LIMM", 0,                          \
       F(FLD_SVE_N,FLD_SVE_immr,FLD_SVE_imms),                          \
       "an inverted 13-bit logical immediate")                          \
@@ -4393,6 +4518,15 @@ struct aarch64_opcode aarch64_opcode_table[] =
       "an SVE vector register")                                                \
     Y(SVE_REG, regno, "SVE_Zm_16", 0, F(FLD_SVE_Zm_16),                        \
       "an SVE vector register")                                                \
+    Y(SVE_REG, sve_quad_index, "SVE_Zm3_INDEX",                                \
+      3 << OPD_F_OD_LSB, F(FLD_SVE_Zm_16),                             \
+      "an indexed SVE vector register")                                        \
+    Y(SVE_REG, sve_quad_index, "SVE_Zm3_22_INDEX",                     \
+      3 << OPD_F_OD_LSB, F(FLD_SVE_i3h, FLD_SVE_Zm_16),                        \
+      "an indexed SVE vector register")                                        \
+    Y(SVE_REG, sve_quad_index, "SVE_Zm4_INDEX",                        \
+      4 << OPD_F_OD_LSB, F(FLD_SVE_Zm_16),                             \
+      "an indexed SVE vector register")                                        \
     Y(SVE_REG, regno, "SVE_Zn", 0, F(FLD_SVE_Zn),                      \
       "an SVE vector register")                                                \
     Y(SVE_REG, sve_index, "SVE_Zn_INDEX", 0, F(FLD_SVE_Zn),            \