.*: Error: selected processor does not support `fmmla z31.h,z0.b,z31.b'
.*: Error: selected processor does not support `fmmla z31.h,z31.b,z0.b'
.*: Error: selected processor does not support `fmmla z31.h,z31.b,z31.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.h,z1.b,z1.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.h,z1.b,z31.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.h,z31.b,z1.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.h,z31.b,z31.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.h,z0.b,z0.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.h,z0.b,z30.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.h,z30.b,z0.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.h,z30.b,z30.b'
.*: 647fe01f fmmla z31.h, z0.b, z31.b
.*: 6460e3ff fmmla z31.h, z31.b, z0.b
.*: 647fe3ff fmmla z31.h, z31.b, z31.b
+
+.* <b>:
+.*: 0420bde0 movprfx z0, z15
+.*: 6461e020 fmmla z0.h, z1.b, z1.b
+.*: 0420bde0 movprfx z0, z15
+.*: 647fe020 fmmla z0.h, z1.b, z31.b
+.*: 0420bde0 movprfx z0, z15
+.*: 6461e3e0 fmmla z0.h, z31.b, z1.b
+.*: 0420bde0 movprfx z0, z15
+.*: 647fe3e0 fmmla z0.h, z31.b, z31.b
+.*: 0420bdff movprfx z31, z15
+.*: 6460e01f fmmla z31.h, z0.b, z0.b
+.*: 0420bdff movprfx z31, z15
+.*: 647ee01f fmmla z31.h, z0.b, z30.b
+.*: 0420bdff movprfx z31, z15
+.*: 6460e3df fmmla z31.h, z30.b, z0.b
+.*: 0420bdff movprfx z31, z15
+.*: 647ee3df fmmla z31.h, z30.b, z30.b
fmmla z31.h, z0.b, z31.b
fmmla z31.h, z31.b, z0.b
fmmla z31.h, z31.b, z31.b
+
+b:
+ movprfx z0, z15
+ fmmla z0.h, z1.b, z1.b
+ movprfx z0, z15
+ fmmla z0.h, z1.b, z31.b
+ movprfx z0, z15
+ fmmla z0.h, z31.b, z1.b
+ movprfx z0, z15
+ fmmla z0.h, z31.b, z31.b
+ movprfx z31, z15
+ fmmla z31.h, z0.b, z0.b
+ movprfx z31, z15
+ fmmla z31.h, z0.b, z30.b
+ movprfx z31, z15
+ fmmla z31.h, z30.b, z0.b
+ movprfx z31, z15
+ fmmla z31.h, z30.b, z30.b
.*: Error: selected processor does not support `fmmla z31.s,z0.b,z31.b'
.*: Error: selected processor does not support `fmmla z31.s,z31.b,z0.b'
.*: Error: selected processor does not support `fmmla z31.s,z31.b,z31.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z1.b,z1.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z1.b,z31.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z31.b,z1.b'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z31.b,z31.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z0.b,z0.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z0.b,z30.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z30.b,z0.b'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z30.b,z30.b'
.*: 643fe01f fmmla z31.s, z0.b, z31.b
.*: 6420e3ff fmmla z31.s, z31.b, z0.b
.*: 643fe3ff fmmla z31.s, z31.b, z31.b
+
+.* <b>:
+.*: 0420bde0 movprfx z0, z15
+.*: 6421e020 fmmla z0.s, z1.b, z1.b
+.*: 0420bde0 movprfx z0, z15
+.*: 643fe020 fmmla z0.s, z1.b, z31.b
+.*: 0420bde0 movprfx z0, z15
+.*: 6421e3e0 fmmla z0.s, z31.b, z1.b
+.*: 0420bde0 movprfx z0, z15
+.*: 643fe3e0 fmmla z0.s, z31.b, z31.b
+.*: 0420bdff movprfx z31, z15
+.*: 6420e01f fmmla z31.s, z0.b, z0.b
+.*: 0420bdff movprfx z31, z15
+.*: 643ee01f fmmla z31.s, z0.b, z30.b
+.*: 0420bdff movprfx z31, z15
+.*: 6420e3df fmmla z31.s, z30.b, z0.b
+.*: 0420bdff movprfx z31, z15
+.*: 643ee3df fmmla z31.s, z30.b, z30.b
fmmla z31.s, z0.b, z31.b
fmmla z31.s, z31.b, z0.b
fmmla z31.s, z31.b, z31.b
+
+b:
+ movprfx z0, z15
+ fmmla z0.s, z1.b, z1.b
+ movprfx z0, z15
+ fmmla z0.s, z1.b, z31.b
+ movprfx z0, z15
+ fmmla z0.s, z31.b, z1.b
+ movprfx z0, z15
+ fmmla z0.s, z31.b, z31.b
+ movprfx z31, z15
+ fmmla z31.s, z0.b, z0.b
+ movprfx z31, z15
+ fmmla z31.s, z0.b, z30.b
+ movprfx z31, z15
+ fmmla z31.s, z30.b, z0.b
+ movprfx z31, z15
+ fmmla z31.s, z30.b, z30.b
.*: 650983ff bfscale z31.h, p0/m, z31.h, z31.h
.*: 65099c1f bfscale z31.h, p7/m, z31.h, z0.h
.*: 65099fff bfscale z31.h, p7/m, z31.h, z31.h
+.*: 0420bde0 movprfx z0, z15
+.*: 65098020 bfscale z0.h, p0/m, z0.h, z1.h
+.*: 0420bde0 movprfx z0, z15
+.*: 650983e0 bfscale z0.h, p0/m, z0.h, z31.h
+.*: 0420bde0 movprfx z0, z15
+.*: 65099c20 bfscale z0.h, p7/m, z0.h, z1.h
+.*: 0420bde0 movprfx z0, z15
+.*: 65099fe0 bfscale z0.h, p7/m, z0.h, z31.h
+.*: 0420bdff movprfx z31, z15
+.*: 6509801f bfscale z31.h, p0/m, z31.h, z0.h
+.*: 0420bdff movprfx z31, z15
+.*: 650983df bfscale z31.h, p0/m, z31.h, z30.h
+.*: 0420bdff movprfx z31, z15
+.*: 65099c1f bfscale z31.h, p7/m, z31.h, z0.h
+.*: 0420bdff movprfx z31, z15
+.*: 65099fdf bfscale z31.h, p7/m, z31.h, z30.h
+.*: 045021e0 movprfx z0.h, p0/z, z15.h
+.*: 65098020 bfscale z0.h, p0/m, z0.h, z1.h
+.*: 045121e0 movprfx z0.h, p0/m, z15.h
+.*: 650983e0 bfscale z0.h, p0/m, z0.h, z31.h
+.*: 04503de0 movprfx z0.h, p7/z, z15.h
+.*: 65099c20 bfscale z0.h, p7/m, z0.h, z1.h
+.*: 04513de0 movprfx z0.h, p7/m, z15.h
+.*: 65099fe0 bfscale z0.h, p7/m, z0.h, z31.h
+.*: 045021ff movprfx z31.h, p0/z, z15.h
+.*: 6509801f bfscale z31.h, p0/m, z31.h, z0.h
+.*: 045121ff movprfx z31.h, p0/m, z15.h
+.*: 650983df bfscale z31.h, p0/m, z31.h, z30.h
+.*: 04503dff movprfx z31.h, p7/z, z15.h
+.*: 65099c1f bfscale z31.h, p7/m, z31.h, z0.h
+.*: 04513dff movprfx z31.h, p7/m, z15.h
+.*: 65099fdf bfscale z31.h, p7/m, z31.h, z30.h
bfscale z31.h, p0/m, z31.h, z31.h
bfscale z31.h, p7/m, z31.h, z0.h
bfscale z31.h, p7/m, z31.h, z31.h
+
+ movprfx z0, z15
+ bfscale z0.h, p0/m, z0.h, z1.h
+ movprfx z0, z15
+ bfscale z0.h, p0/m, z0.h, z31.h
+ movprfx z0, z15
+ bfscale z0.h, p7/m, z0.h, z1.h
+ movprfx z0, z15
+ bfscale z0.h, p7/m, z0.h, z31.h
+ movprfx z31, z15
+ bfscale z31.h, p0/m, z31.h, z0.h
+ movprfx z31, z15
+ bfscale z31.h, p0/m, z31.h, z30.h
+ movprfx z31, z15
+ bfscale z31.h, p7/m, z31.h, z0.h
+ movprfx z31, z15
+ bfscale z31.h, p7/m, z31.h, z30.h
+
+ movprfx z0.h, p0/z, z15.h
+ bfscale z0.h, p0/m, z0.h, z1.h
+ movprfx z0.h, p0/m, z15.h
+ bfscale z0.h, p0/m, z0.h, z31.h
+ movprfx z0.h, p7/z, z15.h
+ bfscale z0.h, p7/m, z0.h, z1.h
+ movprfx z0.h, p7/m, z15.h
+ bfscale z0.h, p7/m, z0.h, z31.h
+ movprfx z31.h, p0/z, z15.h
+ bfscale z31.h, p0/m, z31.h, z0.h
+ movprfx z31.h, p0/m, z15.h
+ bfscale z31.h, p0/m, z31.h, z30.h
+ movprfx z31.h, p7/z, z15.h
+ bfscale z31.h, p7/m, z31.h, z0.h
+ movprfx z31.h, p7/m, z15.h
+ bfscale z31.h, p7/m, z31.h, z30.h
.*: Error: selected processor does not support `fmmla z31.s,z0.h,z31.h'
.*: Error: selected processor does not support `fmmla z31.s,z31.h,z0.h'
.*: Error: selected processor does not support `fmmla z31.s,z31.h,z31.h'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z1.h,z1.h'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z1.h,z31.h'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z31.h,z1.h'
+.*: Error: selected processor does not support `movprfx z0,z15'
+.*: Error: selected processor does not support `fmmla z0.s,z31.h,z31.h'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z0.h,z0.h'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z0.h,z30.h'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z30.h,z0.h'
+.*: Error: selected processor does not support `movprfx z31,z15'
+.*: Error: selected processor does not support `fmmla z31.s,z30.h,z30.h'
.*: 643fe41f fmmla z31.s, z0.h, z31.h
.*: 6420e7ff fmmla z31.s, z31.h, z0.h
.*: 643fe7ff fmmla z31.s, z31.h, z31.h
+
+.* <b>:
+.*: 0420bde0 movprfx z0, z15
+.*: 6421e420 fmmla z0.s, z1.h, z1.h
+.*: 0420bde0 movprfx z0, z15
+.*: 643fe420 fmmla z0.s, z1.h, z31.h
+.*: 0420bde0 movprfx z0, z15
+.*: 6421e7e0 fmmla z0.s, z31.h, z1.h
+.*: 0420bde0 movprfx z0, z15
+.*: 643fe7e0 fmmla z0.s, z31.h, z31.h
+.*: 0420bdff movprfx z31, z15
+.*: 6420e41f fmmla z31.s, z0.h, z0.h
+.*: 0420bdff movprfx z31, z15
+.*: 643ee41f fmmla z31.s, z0.h, z30.h
+.*: 0420bdff movprfx z31, z15
+.*: 6420e7df fmmla z31.s, z30.h, z0.h
+.*: 0420bdff movprfx z31, z15
+.*: 643ee7df fmmla z31.s, z30.h, z30.h
fmmla z31.s, z0.h, z31.h
fmmla z31.s, z31.h, z0.h
fmmla z31.s, z31.h, z31.h
+
+b:
+ movprfx z0, z15
+ fmmla z0.s, z1.h, z1.h
+ movprfx z0, z15
+ fmmla z0.s, z1.h, z31.h
+ movprfx z0, z15
+ fmmla z0.s, z31.h, z1.h
+ movprfx z0, z15
+ fmmla z0.s, z31.h, z31.h
+ movprfx z31, z15
+ fmmla z31.s, z0.h, z0.h
+ movprfx z31, z15
+ fmmla z31.s, z0.h, z30.h
+ movprfx z31, z15
+ fmmla z31.s, z30.h, z0.h
+ movprfx z31, z15
+ fmmla z31.s, z30.h, z30.h
#define SME2p1_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
{ NAME, OPCODE, MASK, CLASS, OP, SME2p1, OPS, QUALS, \
FLAGS | F_STRICT, 0, TIED, NULL }
-#define SVE_F16F32MM_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
- { NAME, OPCODE, MASK, CLASS, OP, SVE_F16F32MM, OPS, QUALS, FLAGS | F_STRICT, 0, 0, NULL }
+#define SVE_F16F32MM_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,CONSTRAINTS) \
+ { NAME, OPCODE, MASK, CLASS, OP, SVE_F16F32MM, OPS, QUALS, FLAGS | F_STRICT, CONSTRAINTS, 0, NULL }
#define F8F32MM_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
{ NAME, OPCODE, MASK, CLASS, OP, F8F32MM, OPS, QUALS, FLAGS, 0, 0, NULL }
-#define F8F32MM_SVE2_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
- { NAME, OPCODE, MASK, CLASS, OP, F8F32MM_SVE2, OPS, QUALS, FLAGS | F_STRICT, 0, 0, NULL }
+#define F8F32MM_SVE2_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,CONSTRAINTS) \
+ { NAME, OPCODE, MASK, CLASS, OP, F8F32MM_SVE2, OPS, QUALS, FLAGS | F_STRICT, CONSTRAINTS, 0, NULL }
#define F8F16MM_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
{ NAME, OPCODE, MASK, CLASS, OP, F8F16MM, OPS, QUALS, FLAGS, 0, 0, NULL }
-#define F8F16MM_SVE2_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
- { NAME, OPCODE, MASK, CLASS, OP, F8F16MM_SVE2, OPS, QUALS, FLAGS | F_STRICT, 0, 0, NULL }
+#define F8F16MM_SVE2_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,CONSTRAINTS) \
+ { NAME, OPCODE, MASK, CLASS, OP, F8F16MM_SVE2, OPS, QUALS, FLAGS | F_STRICT, CONSTRAINTS, 0, NULL }
#define SVE2_INSNC(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,CONSTRAINTS,TIED) \
{ NAME, OPCODE, MASK, CLASS, OP, SVE2, OPS, QUALS, \
FLAGS | F_STRICT | F_INVALID_IMM_SYMS_2, CONSTRAINTS, TIED, NULL }
#define SVE2BITPERM_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
{ NAME, OPCODE, MASK, CLASS, OP, SVE2_BITPERM, OPS, QUALS, \
FLAGS | F_STRICT, 0, TIED, NULL }
-#define SVE_BFSCALE_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS,TIED) \
- { NAME, OPCODE, MASK, CLASS, 0, SVE_BFSCALE, OPS, QUALS, FLAGS | F_STRICT, 0, TIED, NULL }
+#define SVE_BFSCALE_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS,CONSTRAINTS,TIED) \
+ { NAME, OPCODE, MASK, CLASS, 0, SVE_BFSCALE, OPS, QUALS, FLAGS | F_STRICT, CONSTRAINTS, TIED, NULL }
#define SVE_BFSCALE_SME2_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS,TIED) \
{ NAME, OPCODE, MASK, CLASS, 0, SVE_BFSCALE_SME2, OPS, QUALS, FLAGS | F_STRICT, 0, TIED, NULL }
-#define BFLOAT16_SVE_INSNC(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS, CONSTRAINTS, TIED) \
+#define BFLOAT16_SVE_INSNC(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS,CONSTRAINTS,TIED) \
{ NAME, OPCODE, MASK, CLASS, 0, BFLOAT16_SVE, OPS, QUALS, FLAGS | F_STRICT, \
CONSTRAINTS, TIED, NULL }
#define BFLOAT16_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
SME2_F64F64_INSN ("fmls", 0xc1d08010, 0xfff09878, sme_misc, 0, OP3 (SME_ZA_array_off3_0, SME_Znx4, SME_Zm_INDEX1), OP_SVE_DDD, F_OD (4), 0),
/* SVE_BFSCALE instructions. */
- SVE_BFSCALE_INSN ("bfscale", 0x65098000, 0xffffe000, sve_misc, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_HMHH, 0, 2),
+ SVE_BFSCALE_INSN ("bfscale", 0x65098000, 0xffffe000, sve_misc, OP4 (SVE_Zd, SVE_Pg3, SVE_Zd, SVE_Zm_5), OP_SVE_HMHH, 0, C_SCAN_MOVPRFX, 2),
SVE_BFSCALE_SME2_INSN ("bfscale", 0xc120a180, 0xfff0ffe1, sme_misc, OP3 (SME_Zdnx2, SME_Zdnx2, SME_Zm), OP_SVE_VVV_H, 0, 1),
SVE_BFSCALE_SME2_INSN ("bfscale", 0xc120a980, 0xfff0ffe3, sme_misc, OP3 (SME_Zdnx4, SME_Zdnx4, SME_Zm), OP_SVE_VVV_H, 0, 1),
SVE_BFSCALE_SME2_INSN ("bfscale", 0xc120b180, 0xffe1ffe1, sme_misc, OP3 (SME_Zdnx2, SME_Zdnx2, SME_Zmx2), OP_SVE_VVV_H, 0, 1),
BFLOAT16_INSN ("bfmlalb", 0x0fc0f000, 0xffc0f400, bfloat16, OP3 (Vd, Vn, Em16), QL_V3BFML4S, 0),
/* SVE_F16F32 Matrix Multiply-Accumulate. */
- SVE_F16F32MM_INSN ("fmmla", 0x6420e400, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_SHH, 0),
+ SVE_F16F32MM_INSN ("fmmla", 0x6420e400, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_SHH, 0, C_SCAN_MOVPRFX),
/* F8F32 Matrix Multiply-Accumulate. */
F8F32MM_INSN ("fmmla", 0x6e80ec00, 0xffe0fc00, asimdmisc, 0, OP3 (Vd, Vn, Vm), QL_V3FMLL4S, 0),
- F8F32MM_SVE2_INSN ("fmmla", 0x6420e000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_SBB, 0),
+ F8F32MM_SVE2_INSN ("fmmla", 0x6420e000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_SBB, 0, C_SCAN_MOVPRFX),
/* F8F16 Matrix Multiply-Accumulate. */
F8F16MM_INSN ("fmmla", 0x6e00ec00, 0xffe0fc00, asimdmisc, 0, OP3 (Vd, Vn, Vm), QL_V3FML8H, 0),
- F8F16MM_SVE2_INSN ("fmmla", 0x6460e000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_H_B, 0),
+ F8F16MM_SVE2_INSN ("fmmla", 0x6460e000, 0xffe0fc00, sve_misc, 0, OP3 (SVE_Zd, SVE_Zn, SVE_Zm_16), OP_SVE_VVV_H_B, 0, C_SCAN_MOVPRFX),
/* cpyfp cpyfprn cpyfpwn cpyfpn
cpyfm cpyfmrn cpyfmwn cpyfmn