2 Copyright (C) 2011-2024 Free Software Foundation, Inc.
4 Contributed by Andrew Waterman (andrew@sifive.com).
7 This file is part of the GNU opcodes library.
9 This library is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3, or (at your option)
14 It is distributed in the hope that it will be useful, but WITHOUT
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
16 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
17 License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program; see the file COPYING3. If not,
21 see <http://www.gnu.org/licenses/>. */
24 #include "opcode/riscv.h"
27 /* Register names used by gas and objdump. */
29 const char riscv_gpr_names_numeric
[NGPR
][NRC
] =
31 "x0", "x1", "x2", "x3", "x4", "x5", "x6", "x7",
32 "x8", "x9", "x10", "x11", "x12", "x13", "x14", "x15",
33 "x16", "x17", "x18", "x19", "x20", "x21", "x22", "x23",
34 "x24", "x25", "x26", "x27", "x28", "x29", "x30", "x31"
37 const char riscv_gpr_names_abi
[NGPR
][NRC
] =
39 "zero", "ra", "sp", "gp", "tp", "t0", "t1", "t2",
40 "s0", "s1", "a0", "a1", "a2", "a3", "a4", "a5",
41 "a6", "a7", "s2", "s3", "s4", "s5", "s6", "s7",
42 "s8", "s9", "s10", "s11", "t3", "t4", "t5", "t6"
45 const char riscv_fpr_names_numeric
[NFPR
][NRC
] =
47 "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
48 "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
49 "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
50 "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31"
53 const char riscv_fpr_names_abi
[NFPR
][NRC
] =
55 "ft0", "ft1", "ft2", "ft3", "ft4", "ft5", "ft6", "ft7",
56 "fs0", "fs1", "fa0", "fa1", "fa2", "fa3", "fa4", "fa5",
57 "fa6", "fa7", "fs2", "fs3", "fs4", "fs5", "fs6", "fs7",
58 "fs8", "fs9", "fs10", "fs11", "ft8", "ft9", "ft10", "ft11"
62 const char * const riscv_rm
[8] =
64 "rne", "rtz", "rdn", "rup", "rmm", 0, 0, "dyn"
67 /* FENCE: predecessor/successor sets. */
68 const char * const riscv_pred_succ
[16] =
70 0, "w", "r", "rw", "o", "ow", "or", "orw",
71 "i", "iw", "ir", "irw", "io", "iow", "ior", "iorw"
75 const char riscv_vecr_names_numeric
[NVECR
][NRC
] =
77 "v0", "v1", "v2", "v3", "v4", "v5", "v6", "v7",
78 "v8", "v9", "v10", "v11", "v12", "v13", "v14", "v15",
79 "v16", "v17", "v18", "v19", "v20", "v21", "v22", "v23",
80 "v24", "v25", "v26", "v27", "v28", "v29", "v30", "v31"
83 /* RVV mask registers. */
84 const char riscv_vecm_names_numeric
[NVECM
][NRC
] =
89 /* The vsetvli vsew constants. */
90 const char * const riscv_vsew
[8] =
92 "e8", "e16", "e32", "e64", NULL
, NULL
, NULL
, NULL
95 /* The vsetvli vlmul constants. */
96 const char * const riscv_vlmul
[8] =
98 "m1", "m2", "m4", "m8", NULL
, "mf8", "mf4", "mf2"
101 /* The vsetvli vta constants. */
102 const char * const riscv_vta
[2] =
107 /* The vsetvli vma constants. */
108 const char * const riscv_vma
[2] =
113 /* XTheadVector, List of vsetvli vlmul constants. */
114 const char * const riscv_th_vlen
[4] =
116 "m1", "m2", "m4", "m8"
119 /* XTheadVector, List of vsetvli vediv constants. */
120 const char * const riscv_th_vediv
[4] =
122 "d1", "d2", "d4", "d8"
125 /* The FLI.[HSDQ] symbolic constants (NULL for numeric constant). */
126 const char * const riscv_fli_symval
[32] =
128 NULL
, "min", NULL
, NULL
, NULL
, NULL
, NULL
, NULL
,
129 NULL
, NULL
, NULL
, NULL
, NULL
, NULL
, NULL
, NULL
,
130 NULL
, NULL
, NULL
, NULL
, NULL
, NULL
, NULL
, NULL
,
131 NULL
, NULL
, NULL
, NULL
, NULL
, NULL
, "inf", "nan",
134 /* The FLI.[HSDQ] numeric constants (0.0 for symbolic constants).
135 The constants use the hex floating-point literal representation
136 that is printed when using the printf %a format specifier,
137 which matches the output that is generated by the disassembler. */
138 const float riscv_fli_numval
[32] =
140 -0x1p
+0, 0x0p
+0, 0x1p
-16, 0x1p
-15, 0x1p
-8, 0x1p
-7, 0x1p
-4, 0x1p
-3,
141 0x1p
-2, 0x1.4p
-2, 0x1.8p
-2, 0x1.cp
-2, 0x1p
-1, 0x1.4p
-1, 0x1.8p
-1, 0x1.cp
-1,
142 0x1p
+0, 0x1.4p
+0, 0x1.8p
+0, 0x1.cp
+0, 0x1p
+1, 0x1.4p
+1, 0x1.8p
+1, 0x1p
+2,
143 0x1p
+3, 0x1p
+4, 0x1p
+7, 0x1p
+8, 0x1p
+15, 0x1p
+16, 0x0p
+0, 0x0p
+0
146 /* Get sp base adjustment. */
149 riscv_get_sp_base (insn_t opcode
, unsigned int xlen
)
151 unsigned reg_size
= xlen
/ 8;
152 unsigned reg_list
= EXTRACT_BITS (opcode
, OP_MASK_REG_LIST
, OP_SH_REG_LIST
);
153 unsigned min_sp_adj
= (reg_list
- 3) * reg_size
154 + (reg_list
== 15 ? reg_size
: 0);
155 return (((min_sp_adj
/ ZCMP_SP_ALIGNMENT
)
156 + (min_sp_adj
% ZCMP_SP_ALIGNMENT
!= 0))
157 * ZCMP_SP_ALIGNMENT
);
160 #define MASK_RS1 (OP_MASK_RS1 << OP_SH_RS1)
161 #define MASK_RS2 (OP_MASK_RS2 << OP_SH_RS2)
162 #define MASK_RD (OP_MASK_RD << OP_SH_RD)
163 #define MASK_CRS2 (OP_MASK_CRS2 << OP_SH_CRS2)
164 #define MASK_IMM ENCODE_ITYPE_IMM (-1U)
165 #define MASK_RVC_IMM ENCODE_CITYPE_IMM (-1U)
166 #define MASK_UIMM ENCODE_UTYPE_IMM (-1U)
167 #define MASK_RM (OP_MASK_RM << OP_SH_RM)
168 #define MASK_PRED (OP_MASK_PRED << OP_SH_PRED)
169 #define MASK_SUCC (OP_MASK_SUCC << OP_SH_SUCC)
170 #define MASK_AQ (OP_MASK_AQ << OP_SH_AQ)
171 #define MASK_RL (OP_MASK_RL << OP_SH_RL)
172 #define MASK_AQRL (MASK_AQ | MASK_RL)
173 #define MASK_SHAMT (OP_MASK_SHAMT << OP_SH_SHAMT)
174 #define MATCH_SHAMT_REV8_32 (0b11000 << OP_SH_SHAMT)
175 #define MATCH_SHAMT_REV8_64 (0b111000 << OP_SH_SHAMT)
176 #define MATCH_SHAMT_BREV8 (0b00111 << OP_SH_SHAMT)
177 #define MATCH_SHAMT_ZIP_32 (0b1111 << OP_SH_SHAMT)
178 #define MATCH_SHAMT_ORC_B (0b00111 << OP_SH_SHAMT)
179 #define MASK_VD (OP_MASK_VD << OP_SH_VD)
180 #define MASK_VS1 (OP_MASK_VS1 << OP_SH_VS1)
181 #define MASK_VS2 (OP_MASK_VS2 << OP_SH_VS2)
182 #define MASK_VMASK (OP_MASK_VMASK << OP_SH_VMASK)
183 /* Vendor-specific (CORE-V) masks. */
184 #define MASK_CV_IS3_UIMM5 ENCODE_CV_IS3_UIMM5 (-1U)
187 match_opcode (const struct riscv_opcode
*op
, insn_t insn
)
189 return ((insn
^ op
->match
) & op
->mask
) == 0;
193 match_rs1_eq_rs2 (const struct riscv_opcode
*op
, insn_t insn
)
195 int rs1
= (insn
& MASK_RS1
) >> OP_SH_RS1
;
196 int rs2
= (insn
& MASK_RS2
) >> OP_SH_RS2
;
197 return match_opcode (op
, insn
) && rs1
== rs2
;
201 match_rs2_rd_even (const struct riscv_opcode
*op
, insn_t insn
)
203 int rs2
= (insn
& MASK_RS2
) >> OP_SH_RS2
;
204 int rd
= (insn
& MASK_RD
) >> OP_SH_RD
;
205 return ((rs2
& 1) == 0) && ((rd
& 1) == 0) && match_opcode (op
, insn
);
209 match_rd_nonzero (const struct riscv_opcode
*op
, insn_t insn
)
211 return (op
->pinfo
== INSN_MACRO
|| match_opcode (op
, insn
))
212 && ((insn
& MASK_RD
) != 0);
216 match_rs1_nonzero (const struct riscv_opcode
*op ATTRIBUTE_UNUSED
, insn_t insn
)
218 return (insn
& MASK_RS1
) != 0;
222 match_c_add (const struct riscv_opcode
*op
, insn_t insn
)
224 return match_rd_nonzero (op
, insn
) && ((insn
& MASK_CRS2
) != 0);
227 /* We don't allow mv zero,X to become a c.mv hint, so we need a separate
228 matching function for this. */
231 match_c_add_with_hint (const struct riscv_opcode
*op
, insn_t insn
)
233 return match_opcode (op
, insn
) && ((insn
& MASK_CRS2
) != 0);
237 match_c_nop (const struct riscv_opcode
*op
, insn_t insn
)
239 return (match_opcode (op
, insn
)
240 && (((insn
& MASK_RD
) >> OP_SH_RD
) == 0));
244 match_c_addi16sp (const struct riscv_opcode
*op
, insn_t insn
)
246 return (match_opcode (op
, insn
)
247 && (((insn
& MASK_RD
) >> OP_SH_RD
) == 2));
251 match_c_lui (const struct riscv_opcode
*op
, insn_t insn
)
253 return (match_rd_nonzero (op
, insn
)
254 && (((insn
& MASK_RD
) >> OP_SH_RD
) != 2)
255 && EXTRACT_CITYPE_LUI_IMM (insn
) != 0);
258 /* We don't allow lui zero,X to become a c.lui hint, so we need a separate
259 matching function for this. */
262 match_c_lui_with_hint (const struct riscv_opcode
*op
, insn_t insn
)
264 return (match_opcode (op
, insn
)
265 && (((insn
& MASK_RD
) >> OP_SH_RD
) != 2)
266 && EXTRACT_CITYPE_LUI_IMM (insn
) != 0);
270 match_c_addi4spn (const struct riscv_opcode
*op
, insn_t insn
)
272 return match_opcode (op
, insn
) && EXTRACT_CIWTYPE_ADDI4SPN_IMM (insn
) != 0;
275 /* This requires a non-zero shift. A zero rd is a hint, so is allowed. */
278 match_c_slli (const struct riscv_opcode
*op
, insn_t insn
)
280 return match_opcode (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) != 0;
283 /* This requires a non-zero rd, and a non-zero shift. */
286 match_slli_as_c_slli (const struct riscv_opcode
*op
, insn_t insn
)
288 return match_rd_nonzero (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) != 0;
291 /* This requires a zero shift. A zero rd is a hint, so is allowed. */
294 match_c_slli64 (const struct riscv_opcode
*op
, insn_t insn
)
296 return match_opcode (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) == 0;
299 /* This is used for both srli and srai. This requires a non-zero shift.
300 A zero rd is not possible. */
303 match_srxi_as_c_srxi (const struct riscv_opcode
*op
, insn_t insn
)
305 return match_opcode (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) != 0;
309 match_vs1_eq_vs2 (const struct riscv_opcode
*op
,
312 int vs1
= (insn
& MASK_VS1
) >> OP_SH_VS1
;
313 int vs2
= (insn
& MASK_VS2
) >> OP_SH_VS2
;
315 return match_opcode (op
, insn
) && vs1
== vs2
;
319 match_vd_eq_vs1_eq_vs2 (const struct riscv_opcode
*op
,
322 int vd
= (insn
& MASK_VD
) >> OP_SH_VD
;
323 int vs1
= (insn
& MASK_VS1
) >> OP_SH_VS1
;
324 int vs2
= (insn
& MASK_VS2
) >> OP_SH_VS2
;
326 return match_opcode (op
, insn
) && vd
== vs1
&& vs1
== vs2
;
330 match_th_load_inc(const struct riscv_opcode
*op
,
333 /* Load-increment has the following restriction:
334 * The values of rd and rs1 must not be the same. */
335 int rd
= (insn
& MASK_RD
) >> OP_SH_RD
;
336 int rs1
= (insn
& MASK_RS1
) >> OP_SH_RS1
;
338 return rd
!= rs1
&& match_opcode (op
, insn
);
342 match_th_load_pair(const struct riscv_opcode
*op
,
345 /* Load pair instructions use the following encoding:
346 * - rd1 = RD (insn[11:7])
347 * - rd2 = RS2 (insn[24:20])
348 * - rs = RS1 ([19:15])
349 * This function matches if the following restriction is met:
350 * The values of rd1, rd2, and rs1 must not be the same. */
351 int rd1
= (insn
& MASK_RD
) >> OP_SH_RD
;
352 int rd2
= (insn
& MASK_RS2
) >> OP_SH_RS2
;
353 int rs
= (insn
& MASK_RS1
) >> OP_SH_RS1
;
355 return rd1
!= rd2
&& rd1
!= rs
&& rd2
!= rs
&& match_opcode (op
, insn
);
359 match_sreg1_not_eq_sreg2 (const struct riscv_opcode
*op
, insn_t insn
)
361 return match_opcode (op
, insn
)
362 && (EXTRACT_OPERAND (SREG1
, insn
) != EXTRACT_OPERAND (SREG2
, insn
));
365 /* This is used for cm.jt. This requires index operand to be less than 32. */
368 match_cm_jt (const struct riscv_opcode
*op
, insn_t insn
)
370 return match_opcode (op
, insn
)
371 && EXTRACT_ZCMT_INDEX (insn
) < 32;
374 /* This is used for cm.jalt. This requires index operand to be in 32 to 255. */
377 match_cm_jalt (const struct riscv_opcode
*op
, insn_t insn
)
379 return match_opcode (op
, insn
)
380 && EXTRACT_ZCMT_INDEX (insn
) >= 32
381 && EXTRACT_ZCMT_INDEX (insn
) < 256;
384 /* The order of overloaded instructions matters. Label arguments and
385 register arguments look the same. Instructions that can have either
386 for arguments must apear in the correct order in this table for the
387 assembler to pick the right one. In other words, entries with
388 immediate operands must apear after the same instruction with
391 Because of the lookup algorithm used, entries with the same opcode
392 name must be contiguous. */
394 const struct riscv_opcode riscv_opcodes
[] =
396 /* name, xlen, isa, operands, match, mask, match_func, pinfo. */
398 /* Standard hints. */
399 {"prefetch.i", 0, INSN_CLASS_ZICBOP
, "Wif(s)", MATCH_PREFETCH_I
, MASK_PREFETCH_I
, match_opcode
, 0 },
400 {"prefetch.r", 0, INSN_CLASS_ZICBOP
, "Wif(s)", MATCH_PREFETCH_R
, MASK_PREFETCH_R
, match_opcode
, 0 },
401 {"prefetch.w", 0, INSN_CLASS_ZICBOP
, "Wif(s)", MATCH_PREFETCH_W
, MASK_PREFETCH_W
, match_opcode
, 0 },
402 {"ntl.p1", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_P1
, MASK_C_NTL_P1
, match_opcode
, INSN_ALIAS
},
403 {"ntl.p1", 0, INSN_CLASS_ZIHINTNTL
, "", MATCH_NTL_P1
, MASK_NTL_P1
, match_opcode
, 0 },
404 {"ntl.pall", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_PALL
, MASK_C_NTL_PALL
, match_opcode
, INSN_ALIAS
},
405 {"ntl.pall", 0, INSN_CLASS_ZIHINTNTL
, "", MATCH_NTL_PALL
, MASK_NTL_PALL
, match_opcode
, 0 },
406 {"ntl.s1", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_S1
, MASK_C_NTL_S1
, match_opcode
, INSN_ALIAS
},
407 {"ntl.s1", 0, INSN_CLASS_ZIHINTNTL
, "", MATCH_NTL_S1
, MASK_NTL_S1
, match_opcode
, 0 },
408 {"ntl.all", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_ALL
, MASK_C_NTL_ALL
, match_opcode
, INSN_ALIAS
},
409 {"ntl.all", 0, INSN_CLASS_ZIHINTNTL
, "", MATCH_NTL_ALL
, MASK_NTL_ALL
, match_opcode
, 0 },
410 {"c.ntl.p1", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_P1
, MASK_C_NTL_P1
, match_opcode
, 0 },
411 {"c.ntl.pall", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_PALL
, MASK_C_NTL_PALL
, match_opcode
, 0 },
412 {"c.ntl.s1", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_S1
, MASK_C_NTL_S1
, match_opcode
, 0 },
413 {"c.ntl.all", 0, INSN_CLASS_ZIHINTNTL_AND_C
, "", MATCH_C_NTL_ALL
, MASK_C_NTL_ALL
, match_opcode
, 0 },
414 {"pause", 0, INSN_CLASS_ZIHINTPAUSE
, "", MATCH_PAUSE
, MASK_PAUSE
, match_opcode
, 0 },
416 /* Basic RVI instructions and aliases. */
417 {"unimp", 0, INSN_CLASS_C
, "", 0, 0xffffU
, match_opcode
, INSN_ALIAS
},
418 {"unimp", 0, INSN_CLASS_I
, "", MATCH_CSRRW
|(CSR_CYCLE
<< OP_SH_CSR
), 0xffffffffU
, match_opcode
, 0 }, /* csrw cycle, x0 */
419 {"ebreak", 0, INSN_CLASS_C
, "", MATCH_C_EBREAK
, MASK_C_EBREAK
, match_opcode
, INSN_ALIAS
},
420 {"ebreak", 0, INSN_CLASS_I
, "", MATCH_EBREAK
, MASK_EBREAK
, match_opcode
, 0 },
421 {"sbreak", 0, INSN_CLASS_C
, "", MATCH_C_EBREAK
, MASK_C_EBREAK
, match_opcode
, INSN_ALIAS
},
422 {"sbreak", 0, INSN_CLASS_I
, "", MATCH_EBREAK
, MASK_EBREAK
, match_opcode
, INSN_ALIAS
},
423 {"ret", 0, INSN_CLASS_C
, "", MATCH_C_JR
|(X_RA
<< OP_SH_RD
), MASK_C_JR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
424 {"ret", 0, INSN_CLASS_I
, "", MATCH_JALR
|(X_RA
<< OP_SH_RS1
), MASK_JALR
|MASK_RD
|MASK_RS1
|MASK_IMM
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
425 {"jr", 0, INSN_CLASS_C
, "d", MATCH_C_JR
, MASK_C_JR
, match_rd_nonzero
, INSN_ALIAS
|INSN_BRANCH
},
426 {"jr", 0, INSN_CLASS_I
, "s", MATCH_JALR
, MASK_JALR
|MASK_RD
|MASK_IMM
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
427 {"jr", 0, INSN_CLASS_I
, "o(s)", MATCH_JALR
, MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
428 {"jr", 0, INSN_CLASS_I
, "s,j", MATCH_JALR
, MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
429 {"jalr", 0, INSN_CLASS_C
, "d", MATCH_C_JALR
, MASK_C_JALR
, match_rd_nonzero
, INSN_ALIAS
|INSN_JSR
},
430 {"jalr", 0, INSN_CLASS_I
, "s", MATCH_JALR
|(X_RA
<< OP_SH_RD
), MASK_JALR
|MASK_RD
|MASK_IMM
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
431 {"jalr", 0, INSN_CLASS_I
, "o(s)", MATCH_JALR
|(X_RA
<< OP_SH_RD
), MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
432 {"jalr", 0, INSN_CLASS_I
, "s,j", MATCH_JALR
|(X_RA
<< OP_SH_RD
), MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
433 {"jalr", 0, INSN_CLASS_I
, "d,s", MATCH_JALR
, MASK_JALR
|MASK_IMM
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
434 {"jalr", 0, INSN_CLASS_I
, "d,o(s)", MATCH_JALR
, MASK_JALR
, match_opcode
, INSN_JSR
},
435 {"jalr", 0, INSN_CLASS_I
, "d,s,1", MATCH_JALR
, MASK_JALR
|MASK_IMM
, match_opcode
, INSN_JSR
},
436 {"jalr", 0, INSN_CLASS_I
, "d,s,j", MATCH_JALR
, MASK_JALR
, match_opcode
, INSN_JSR
},
437 {"j", 0, INSN_CLASS_C
, "Ca", MATCH_C_J
, MASK_C_J
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
438 {"j", 0, INSN_CLASS_I
, "a", MATCH_JAL
, MASK_JAL
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
439 {"jal", 32, INSN_CLASS_C
, "Ca", MATCH_C_JAL
, MASK_C_JAL
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
440 {"jal", 0, INSN_CLASS_I
, "a", MATCH_JAL
|(X_RA
<< OP_SH_RD
), MASK_JAL
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
441 {"jal", 0, INSN_CLASS_I
, "d,a", MATCH_JAL
, MASK_JAL
, match_opcode
, INSN_JSR
},
442 {"call", 0, INSN_CLASS_I
, "d,c", (X_T1
<< OP_SH_RS1
), (int) M_CALL
, NULL
, INSN_MACRO
},
443 {"call", 0, INSN_CLASS_I
, "c", (X_RA
<< OP_SH_RS1
)|(X_RA
<< OP_SH_RD
), (int) M_CALL
, NULL
, INSN_MACRO
},
444 {"tail", 0, INSN_CLASS_I
, "c", (X_T1
<< OP_SH_RS1
), (int) M_CALL
, NULL
, INSN_MACRO
},
445 {"jump", 0, INSN_CLASS_I
, "c,s", 0, (int) M_CALL
, match_rs1_nonzero
, INSN_MACRO
},
446 {"nop", 0, INSN_CLASS_C
, "", MATCH_C_ADDI
, 0xffff, match_opcode
, INSN_ALIAS
},
447 {"nop", 0, INSN_CLASS_I
, "", MATCH_ADDI
, MASK_ADDI
|MASK_RD
|MASK_RS1
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
448 {"lui", 0, INSN_CLASS_C
, "d,Cu", MATCH_C_LUI
, MASK_C_LUI
, match_c_lui
, INSN_ALIAS
},
449 {"lui", 0, INSN_CLASS_I
, "d,u", MATCH_LUI
, MASK_LUI
, match_opcode
, 0 },
450 {"li", 0, INSN_CLASS_C
, "d,Cv", MATCH_C_LUI
, MASK_C_LUI
, match_c_lui
, INSN_ALIAS
},
451 {"li", 0, INSN_CLASS_C
, "d,Co", MATCH_C_LI
, MASK_C_LI
, match_rd_nonzero
, INSN_ALIAS
},
452 {"li", 0, INSN_CLASS_I
, "d,j", MATCH_ADDI
, MASK_ADDI
|MASK_RS1
, match_opcode
, INSN_ALIAS
}, /* addi */
453 {"li", 0, INSN_CLASS_I
, "d,I", 0, (int) M_LI
, NULL
, INSN_MACRO
},
454 {"mv", 0, INSN_CLASS_C
, "d,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
455 {"mv", 0, INSN_CLASS_I
, "d,s", MATCH_ADDI
, MASK_ADDI
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
456 {"move", 0, INSN_CLASS_C
, "d,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
457 {"move", 0, INSN_CLASS_I
, "d,s", MATCH_ADDI
, MASK_ADDI
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
458 {"zext.b", 0, INSN_CLASS_ZCB
, "Cs,Cw", MATCH_C_ZEXT_B
, MASK_C_ZEXT_B
, match_opcode
, INSN_ALIAS
},
459 {"zext.b", 0, INSN_CLASS_I
, "d,s", MATCH_ANDI
|ENCODE_ITYPE_IMM (255), MASK_ANDI
| MASK_IMM
, match_opcode
, INSN_ALIAS
},
460 {"andi", 0, INSN_CLASS_ZCB
, "Cs,Cw,Wcf",MATCH_C_ZEXT_B
, MASK_C_ZEXT_B
, match_opcode
, INSN_ALIAS
},
461 {"andi", 0, INSN_CLASS_C
, "Cs,Cw,Co", MATCH_C_ANDI
, MASK_C_ANDI
, match_opcode
, INSN_ALIAS
},
462 {"andi", 0, INSN_CLASS_I
, "d,s,j", MATCH_ANDI
, MASK_ANDI
, match_opcode
, 0 },
463 {"and", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_AND
, MASK_C_AND
, match_opcode
, INSN_ALIAS
},
464 {"and", 0, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_AND
, MASK_C_AND
, match_opcode
, INSN_ALIAS
},
465 {"and", 0, INSN_CLASS_C
, "Cs,Cw,Co", MATCH_C_ANDI
, MASK_C_ANDI
, match_opcode
, INSN_ALIAS
},
466 {"and", 0, INSN_CLASS_I
, "d,s,t", MATCH_AND
, MASK_AND
, match_opcode
, 0 },
467 {"and", 0, INSN_CLASS_I
, "d,s,j", MATCH_ANDI
, MASK_ANDI
, match_opcode
, INSN_ALIAS
},
468 {"beqz", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BEQZ
, MASK_C_BEQZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
469 {"beqz", 0, INSN_CLASS_I
, "s,p", MATCH_BEQ
, MASK_BEQ
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
470 {"beq", 0, INSN_CLASS_C
, "Cs,Cz,Cp", MATCH_C_BEQZ
, MASK_C_BEQZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
471 {"beq", 0, INSN_CLASS_I
, "s,t,p", MATCH_BEQ
, MASK_BEQ
, match_opcode
, INSN_CONDBRANCH
},
472 {"blez", 0, INSN_CLASS_I
, "t,p", MATCH_BGE
, MASK_BGE
|MASK_RS1
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
473 {"bgez", 0, INSN_CLASS_I
, "s,p", MATCH_BGE
, MASK_BGE
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
474 {"bge", 0, INSN_CLASS_I
, "s,t,p", MATCH_BGE
, MASK_BGE
, match_opcode
, INSN_CONDBRANCH
},
475 {"bgeu", 0, INSN_CLASS_I
, "s,t,p", MATCH_BGEU
, MASK_BGEU
, match_opcode
, INSN_CONDBRANCH
},
476 {"ble", 0, INSN_CLASS_I
, "t,s,p", MATCH_BGE
, MASK_BGE
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
477 {"bleu", 0, INSN_CLASS_I
, "t,s,p", MATCH_BGEU
, MASK_BGEU
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
478 {"bltz", 0, INSN_CLASS_I
, "s,p", MATCH_BLT
, MASK_BLT
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
479 {"bgtz", 0, INSN_CLASS_I
, "t,p", MATCH_BLT
, MASK_BLT
|MASK_RS1
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
480 {"blt", 0, INSN_CLASS_I
, "s,t,p", MATCH_BLT
, MASK_BLT
, match_opcode
, INSN_CONDBRANCH
},
481 {"bltu", 0, INSN_CLASS_I
, "s,t,p", MATCH_BLTU
, MASK_BLTU
, match_opcode
, INSN_CONDBRANCH
},
482 {"bgt", 0, INSN_CLASS_I
, "t,s,p", MATCH_BLT
, MASK_BLT
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
483 {"bgtu", 0, INSN_CLASS_I
, "t,s,p", MATCH_BLTU
, MASK_BLTU
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
484 {"bnez", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BNEZ
, MASK_C_BNEZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
485 {"bnez", 0, INSN_CLASS_I
, "s,p", MATCH_BNE
, MASK_BNE
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
486 {"bne", 0, INSN_CLASS_C
, "Cs,Cz,Cp", MATCH_C_BNEZ
, MASK_C_BNEZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
487 {"bne", 0, INSN_CLASS_I
, "s,t,p", MATCH_BNE
, MASK_BNE
, match_opcode
, INSN_CONDBRANCH
},
488 {"addi", 0, INSN_CLASS_C
, "Ct,Cc,CK", MATCH_C_ADDI4SPN
, MASK_C_ADDI4SPN
, match_c_addi4spn
, INSN_ALIAS
},
489 {"addi", 0, INSN_CLASS_C
, "d,CU,Cj", MATCH_C_ADDI
, MASK_C_ADDI
, match_rd_nonzero
, INSN_ALIAS
},
490 {"addi", 0, INSN_CLASS_C
, "d,CU,z", MATCH_C_NOP
, MASK_C_ADDI
|MASK_RVC_IMM
, match_c_nop
, INSN_ALIAS
},
491 {"addi", 0, INSN_CLASS_C
, "Cc,Cc,CL", MATCH_C_ADDI16SP
, MASK_C_ADDI16SP
, match_c_addi16sp
, INSN_ALIAS
},
492 {"addi", 0, INSN_CLASS_C
, "d,Cz,Co", MATCH_C_LI
, MASK_C_LI
, match_rd_nonzero
, INSN_ALIAS
},
493 {"addi", 0, INSN_CLASS_C
, "d,CV,z", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
494 {"addi", 0, INSN_CLASS_I
, "d,s,j", MATCH_ADDI
, MASK_ADDI
, match_opcode
, 0 },
495 {"add", 0, INSN_CLASS_C
, "d,CU,CV", MATCH_C_ADD
, MASK_C_ADD
, match_c_add
, INSN_ALIAS
},
496 {"add", 0, INSN_CLASS_C
, "d,CV,CU", MATCH_C_ADD
, MASK_C_ADD
, match_c_add
, INSN_ALIAS
},
497 {"add", 0, INSN_CLASS_C
, "d,CU,Co", MATCH_C_ADDI
, MASK_C_ADDI
, match_rd_nonzero
, INSN_ALIAS
},
498 {"add", 0, INSN_CLASS_C
, "Ct,Cc,CK", MATCH_C_ADDI4SPN
, MASK_C_ADDI4SPN
, match_c_addi4spn
, INSN_ALIAS
},
499 {"add", 0, INSN_CLASS_C
, "Cc,Cc,CL", MATCH_C_ADDI16SP
, MASK_C_ADDI16SP
, match_c_addi16sp
, INSN_ALIAS
},
500 {"add", 0, INSN_CLASS_C
, "d,Cz,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
501 {"add", 0, INSN_CLASS_I
, "d,s,t", MATCH_ADD
, MASK_ADD
, match_opcode
, 0 },
502 {"add", 0, INSN_CLASS_I
, "d,s,t,1", MATCH_ADD
, MASK_ADD
, match_opcode
, 0 },
503 {"add", 0, INSN_CLASS_I
, "d,s,j", MATCH_ADDI
, MASK_ADDI
, match_opcode
, INSN_ALIAS
},
504 {"la", 0, INSN_CLASS_I
, "d,B", 0, (int) M_LA
, match_rd_nonzero
, INSN_MACRO
},
505 {"lla", 0, INSN_CLASS_I
, "d,B", 0, (int) M_LLA
, NULL
, INSN_MACRO
},
506 {"lga", 0, INSN_CLASS_I
, "d,B", 0, (int) M_LGA
, match_rd_nonzero
, INSN_MACRO
},
507 {"la.tls.gd", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LA_TLS_GD
, NULL
, INSN_MACRO
},
508 {"la.tls.ie", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LA_TLS_IE
, match_rd_nonzero
, INSN_MACRO
},
509 {"neg", 0, INSN_CLASS_I
, "d,t", MATCH_SUB
, MASK_SUB
|MASK_RS1
, match_opcode
, INSN_ALIAS
}, /* sub 0 */
510 {"slli", 0, INSN_CLASS_C
, "d,CU,C>", MATCH_C_SLLI
, MASK_C_SLLI
, match_slli_as_c_slli
, INSN_ALIAS
},
511 {"slli", 0, INSN_CLASS_I
, "d,s,>", MATCH_SLLI
, MASK_SLLI
, match_opcode
, 0 },
512 {"sll", 0, INSN_CLASS_C
, "d,CU,C>", MATCH_C_SLLI
, MASK_C_SLLI
, match_slli_as_c_slli
, INSN_ALIAS
},
513 {"sll", 0, INSN_CLASS_I
, "d,s,t", MATCH_SLL
, MASK_SLL
, match_opcode
, 0 },
514 {"sll", 0, INSN_CLASS_I
, "d,s,>", MATCH_SLLI
, MASK_SLLI
, match_opcode
, INSN_ALIAS
},
515 {"srli", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRLI
, MASK_C_SRLI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
516 {"srli", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRLI
, MASK_SRLI
, match_opcode
, 0 },
517 {"srl", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRLI
, MASK_C_SRLI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
518 {"srl", 0, INSN_CLASS_I
, "d,s,t", MATCH_SRL
, MASK_SRL
, match_opcode
, 0 },
519 {"srl", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRLI
, MASK_SRLI
, match_opcode
, INSN_ALIAS
},
520 {"srai", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRAI
, MASK_C_SRAI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
521 {"srai", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRAI
, MASK_SRAI
, match_opcode
, 0 },
522 {"sra", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRAI
, MASK_C_SRAI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
523 {"sra", 0, INSN_CLASS_I
, "d,s,t", MATCH_SRA
, MASK_SRA
, match_opcode
, 0 },
524 {"sra", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRAI
, MASK_SRAI
, match_opcode
, INSN_ALIAS
},
525 {"sub", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_SUB
, MASK_C_SUB
, match_opcode
, INSN_ALIAS
},
526 {"sub", 0, INSN_CLASS_I
, "d,s,t", MATCH_SUB
, MASK_SUB
, match_opcode
, 0 },
527 {"lb", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LB
, MASK_LB
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
528 {"lb", 0, INSN_CLASS_I
, "d,A", 0, (int) M_Lx
, match_rd_nonzero
, INSN_MACRO
},
529 {"lbu", 0, INSN_CLASS_ZCB
, "Ct,Wcb(Cs)", MATCH_C_LBU
, MASK_C_LBU
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_1_BYTE
},
530 {"lbu", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LBU
, MASK_LBU
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
531 {"lbu", 0, INSN_CLASS_I
, "d,A", 0, (int) M_Lx
, match_rd_nonzero
, INSN_MACRO
},
532 {"lh", 0, INSN_CLASS_ZCB
, "Ct,Wch(Cs)", MATCH_C_LH
, MASK_C_LH
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_2_BYTE
},
533 {"lh", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LH
, MASK_LH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
534 {"lh", 0, INSN_CLASS_I
, "d,A", 0, (int) M_Lx
, match_rd_nonzero
, INSN_MACRO
},
535 {"lhu", 0, INSN_CLASS_ZCB
, "Ct,Wch(Cs)", MATCH_C_LHU
, MASK_C_LHU
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_2_BYTE
},
536 {"lhu", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LHU
, MASK_LHU
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
537 {"lhu", 0, INSN_CLASS_I
, "d,A", 0, (int) M_Lx
, match_rd_nonzero
, INSN_MACRO
},
538 {"lw", 0, INSN_CLASS_C
, "d,Cm(Cc)", MATCH_C_LWSP
, MASK_C_LWSP
, match_rd_nonzero
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
539 {"lw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_LW
, MASK_C_LW
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
540 {"lw", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LW
, MASK_LW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
541 {"lw", 0, INSN_CLASS_I
, "d,A", 0, (int) M_Lx
, match_rd_nonzero
, INSN_MACRO
},
542 {"not", 0, INSN_CLASS_ZCB
, "Cs,Cw", MATCH_C_NOT
, MASK_C_NOT
, match_opcode
, INSN_ALIAS
},
543 {"not", 0, INSN_CLASS_I
, "d,s", MATCH_XORI
|MASK_IMM
, MASK_XORI
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
544 {"ori", 0, INSN_CLASS_I
, "d,s,j", MATCH_ORI
, MASK_ORI
, match_opcode
, 0 },
545 {"or", 0, INSN_CLASS_I
, "d,s,j", MATCH_ORI
, MASK_ORI
, match_opcode
, INSN_ALIAS
},
546 {"or", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_OR
, MASK_C_OR
, match_opcode
, INSN_ALIAS
},
547 {"or", 0, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_OR
, MASK_C_OR
, match_opcode
, INSN_ALIAS
},
548 {"or", 0, INSN_CLASS_I
, "d,s,t", MATCH_OR
, MASK_OR
, match_opcode
, 0 },
549 {"auipc", 0, INSN_CLASS_I
, "d,u", MATCH_AUIPC
, MASK_AUIPC
, match_opcode
, 0 },
550 {"seqz", 0, INSN_CLASS_I
, "d,s", MATCH_SLTIU
|ENCODE_ITYPE_IMM (1), MASK_SLTIU
| MASK_IMM
, match_opcode
, INSN_ALIAS
},
551 {"snez", 0, INSN_CLASS_I
, "d,t", MATCH_SLTU
, MASK_SLTU
|MASK_RS1
, match_opcode
, INSN_ALIAS
},
552 {"sltz", 0, INSN_CLASS_I
, "d,s", MATCH_SLT
, MASK_SLT
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
553 {"sgtz", 0, INSN_CLASS_I
, "d,t", MATCH_SLT
, MASK_SLT
|MASK_RS1
, match_opcode
, INSN_ALIAS
},
554 {"slti", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTI
, MASK_SLTI
, match_opcode
, 0 },
555 {"slt", 0, INSN_CLASS_I
, "d,s,t", MATCH_SLT
, MASK_SLT
, match_opcode
, 0 },
556 {"slt", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTI
, MASK_SLTI
, match_opcode
, INSN_ALIAS
},
557 {"sltiu", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTIU
, MASK_SLTIU
, match_opcode
, 0 },
558 {"sltu", 0, INSN_CLASS_I
, "d,s,t", MATCH_SLTU
, MASK_SLTU
, match_opcode
, 0 },
559 {"sltu", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTIU
, MASK_SLTIU
, match_opcode
, INSN_ALIAS
},
560 {"sgt", 0, INSN_CLASS_I
, "d,t,s", MATCH_SLT
, MASK_SLT
, match_opcode
, INSN_ALIAS
},
561 {"sgtu", 0, INSN_CLASS_I
, "d,t,s", MATCH_SLTU
, MASK_SLTU
, match_opcode
, INSN_ALIAS
},
562 {"sb", 0, INSN_CLASS_ZCB
, "Ct,Wcb(Cs)", MATCH_C_SB
, MASK_C_SB
, match_opcode
, INSN_DREF
|INSN_1_BYTE
|INSN_ALIAS
},
563 {"sb", 0, INSN_CLASS_I
, "t,q(s)", MATCH_SB
, MASK_SB
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
564 {"sb", 0, INSN_CLASS_I
, "t,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
565 {"sh", 0, INSN_CLASS_ZCB
, "Ct,Wch(Cs)", MATCH_C_SH
, MASK_C_SH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
|INSN_ALIAS
},
566 {"sh", 0, INSN_CLASS_I
, "t,q(s)", MATCH_SH
, MASK_SH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
567 {"sh", 0, INSN_CLASS_I
, "t,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
568 {"sw", 0, INSN_CLASS_C
, "CV,CM(Cc)", MATCH_C_SWSP
, MASK_C_SWSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
569 {"sw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_SW
, MASK_C_SW
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
570 {"sw", 0, INSN_CLASS_I
, "t,q(s)", MATCH_SW
, MASK_SW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
571 {"sw", 0, INSN_CLASS_I
, "t,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
572 {"fence", 0, INSN_CLASS_I
, "", MATCH_FENCE
|MASK_PRED
|MASK_SUCC
, MASK_FENCE
|MASK_RD
|MASK_RS1
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
573 {"fence", 0, INSN_CLASS_I
, "P,Q", MATCH_FENCE
, MASK_FENCE
|MASK_RD
|MASK_RS1
|(MASK_IMM
& ~MASK_PRED
& ~MASK_SUCC
), match_opcode
, 0 },
574 {"fence.i", 0, INSN_CLASS_ZIFENCEI
, "", MATCH_FENCE_I
, MASK_FENCE
|MASK_RD
|MASK_RS1
|MASK_IMM
, match_opcode
, 0 },
575 {"fence.tso", 0, INSN_CLASS_I
, "", MATCH_FENCE_TSO
, MASK_FENCE_TSO
|MASK_RD
|MASK_RS1
, match_opcode
, 0 },
576 {"rdcycle", 0, INSN_CLASS_I
, "d", MATCH_RDCYCLE
, MASK_RDCYCLE
, match_opcode
, INSN_ALIAS
},
577 {"rdinstret", 0, INSN_CLASS_I
, "d", MATCH_RDINSTRET
, MASK_RDINSTRET
, match_opcode
, INSN_ALIAS
},
578 {"rdtime", 0, INSN_CLASS_I
, "d", MATCH_RDTIME
, MASK_RDTIME
, match_opcode
, INSN_ALIAS
},
579 {"rdcycleh", 32, INSN_CLASS_I
, "d", MATCH_RDCYCLEH
, MASK_RDCYCLEH
, match_opcode
, INSN_ALIAS
},
580 {"rdinstreth", 32, INSN_CLASS_I
, "d", MATCH_RDINSTRETH
, MASK_RDINSTRETH
, match_opcode
, INSN_ALIAS
},
581 {"rdtimeh", 32, INSN_CLASS_I
, "d", MATCH_RDTIMEH
, MASK_RDTIMEH
, match_opcode
, INSN_ALIAS
},
582 {"ecall", 0, INSN_CLASS_I
, "", MATCH_SCALL
, MASK_SCALL
, match_opcode
, 0 },
583 {"scall", 0, INSN_CLASS_I
, "", MATCH_SCALL
, MASK_SCALL
, match_opcode
, 0 },
584 {"xori", 0, INSN_CLASS_I
, "d,s,j", MATCH_XORI
, MASK_XORI
, match_opcode
, 0 },
585 {"xor", 0, INSN_CLASS_I
, "d,s,j", MATCH_XORI
, MASK_XORI
, match_opcode
, INSN_ALIAS
},
586 {"xor", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_XOR
, MASK_C_XOR
, match_opcode
, INSN_ALIAS
},
587 {"xor", 0, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_XOR
, MASK_C_XOR
, match_opcode
, INSN_ALIAS
},
588 {"xor", 0, INSN_CLASS_I
, "d,s,t", MATCH_XOR
, MASK_XOR
, match_opcode
, 0 },
589 {"lwu", 64, INSN_CLASS_I
, "d,o(s)", MATCH_LWU
, MASK_LWU
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
590 {"lwu", 64, INSN_CLASS_I
, "d,A", 0, (int) M_Lx
, match_rd_nonzero
, INSN_MACRO
},
591 {"ld", 64, INSN_CLASS_C
, "d,Cn(Cc)", MATCH_C_LDSP
, MASK_C_LDSP
, match_rd_nonzero
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
592 {"ld", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_LD
, MASK_C_LD
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
593 {"ld", 64, INSN_CLASS_I
, "d,o(s)", MATCH_LD
, MASK_LD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
594 {"ld", 64, INSN_CLASS_I
, "d,A", 0, (int) M_Lx
, match_rd_nonzero
, INSN_MACRO
},
595 {"sd", 64, INSN_CLASS_C
, "CV,CN(Cc)", MATCH_C_SDSP
, MASK_C_SDSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
596 {"sd", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_SD
, MASK_C_SD
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
597 {"sd", 64, INSN_CLASS_I
, "t,q(s)", MATCH_SD
, MASK_SD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
598 {"sd", 64, INSN_CLASS_I
, "t,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
599 {"sext.w", 64, INSN_CLASS_C
, "d,CU", MATCH_C_ADDIW
, MASK_C_ADDIW
|MASK_RVC_IMM
, match_rd_nonzero
, INSN_ALIAS
},
600 {"sext.w", 64, INSN_CLASS_I
, "d,s", MATCH_ADDIW
, MASK_ADDIW
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
601 {"addiw", 64, INSN_CLASS_C
, "d,CU,Co", MATCH_C_ADDIW
, MASK_C_ADDIW
, match_rd_nonzero
, INSN_ALIAS
},
602 {"addiw", 64, INSN_CLASS_I
, "d,s,j", MATCH_ADDIW
, MASK_ADDIW
, match_opcode
, 0 },
603 {"addw", 64, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_ADDW
, MASK_C_ADDW
, match_opcode
, INSN_ALIAS
},
604 {"addw", 64, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_ADDW
, MASK_C_ADDW
, match_opcode
, INSN_ALIAS
},
605 {"addw", 64, INSN_CLASS_C
, "d,CU,Co", MATCH_C_ADDIW
, MASK_C_ADDIW
, match_rd_nonzero
, INSN_ALIAS
},
606 {"addw", 64, INSN_CLASS_I
, "d,s,t", MATCH_ADDW
, MASK_ADDW
, match_opcode
, 0 },
607 {"addw", 64, INSN_CLASS_I
, "d,s,j", MATCH_ADDIW
, MASK_ADDIW
, match_opcode
, INSN_ALIAS
},
608 {"negw", 64, INSN_CLASS_I
, "d,t", MATCH_SUBW
, MASK_SUBW
|MASK_RS1
, match_opcode
, INSN_ALIAS
}, /* sub 0 */
609 {"slliw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SLLIW
, MASK_SLLIW
, match_opcode
, 0 },
610 {"sllw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SLLW
, MASK_SLLW
, match_opcode
, 0 },
611 {"sllw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SLLIW
, MASK_SLLIW
, match_opcode
, INSN_ALIAS
},
612 {"srliw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRLIW
, MASK_SRLIW
, match_opcode
, 0 },
613 {"srlw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SRLW
, MASK_SRLW
, match_opcode
, 0 },
614 {"srlw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRLIW
, MASK_SRLIW
, match_opcode
, INSN_ALIAS
},
615 {"sraiw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRAIW
, MASK_SRAIW
, match_opcode
, 0 },
616 {"sraw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SRAW
, MASK_SRAW
, match_opcode
, 0 },
617 {"sraw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRAIW
, MASK_SRAIW
, match_opcode
, INSN_ALIAS
},
618 {"subw", 64, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_SUBW
, MASK_C_SUBW
, match_opcode
, INSN_ALIAS
},
619 {"subw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SUBW
, MASK_SUBW
, match_opcode
, 0 },
621 /* Atomic memory operation instruction subset. */
622 {"lr.w", 0, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_W
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
623 {"sc.w", 0, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_W
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
624 {"amoadd.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_W
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
625 {"amoswap.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_W
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
626 {"amoand.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_W
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
627 {"amoor.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_W
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
628 {"amoxor.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_W
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
629 {"amomax.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_W
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
630 {"amomaxu.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_W
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
631 {"amomin.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_W
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
632 {"amominu.w", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_W
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
633 {"lr.w.aq", 0, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_W
|MASK_AQ
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
634 {"sc.w.aq", 0, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_W
|MASK_AQ
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
635 {"amoadd.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_W
|MASK_AQ
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
636 {"amoswap.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_W
|MASK_AQ
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
637 {"amoand.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_W
|MASK_AQ
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
638 {"amoor.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_W
|MASK_AQ
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
639 {"amoxor.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_W
|MASK_AQ
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
640 {"amomax.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_W
|MASK_AQ
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
641 {"amomaxu.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_W
|MASK_AQ
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
642 {"amomin.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_W
|MASK_AQ
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
643 {"amominu.w.aq", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_W
|MASK_AQ
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
644 {"lr.w.rl", 0, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_W
|MASK_RL
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
645 {"sc.w.rl", 0, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_W
|MASK_RL
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
646 {"amoadd.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_W
|MASK_RL
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
647 {"amoswap.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_W
|MASK_RL
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
648 {"amoand.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_W
|MASK_RL
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
649 {"amoor.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_W
|MASK_RL
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
650 {"amoxor.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_W
|MASK_RL
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
651 {"amomax.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_W
|MASK_RL
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
652 {"amomaxu.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_W
|MASK_RL
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
653 {"amomin.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_W
|MASK_RL
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
654 {"amominu.w.rl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_W
|MASK_RL
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
655 {"lr.w.aqrl", 0, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_W
|MASK_AQRL
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
656 {"sc.w.aqrl", 0, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_W
|MASK_AQRL
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
657 {"amoadd.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_W
|MASK_AQRL
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
658 {"amoswap.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_W
|MASK_AQRL
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
659 {"amoand.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_W
|MASK_AQRL
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
660 {"amoor.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_W
|MASK_AQRL
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
661 {"amoxor.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_W
|MASK_AQRL
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
662 {"amomax.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_W
|MASK_AQRL
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
663 {"amomaxu.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_W
|MASK_AQRL
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
664 {"amomin.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_W
|MASK_AQRL
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
665 {"amominu.w.aqrl", 0, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_W
|MASK_AQRL
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
666 {"lr.d", 64, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_D
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
667 {"sc.d", 64, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_D
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
668 {"amoadd.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_D
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
669 {"amoswap.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_D
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
670 {"amoand.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_D
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
671 {"amoor.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_D
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
672 {"amoxor.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_D
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
673 {"amomax.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_D
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
674 {"amomaxu.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_D
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
675 {"amomin.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_D
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
676 {"amominu.d", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_D
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
677 {"lr.d.aq", 64, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_D
|MASK_AQ
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
678 {"sc.d.aq", 64, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_D
|MASK_AQ
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
679 {"amoadd.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_D
|MASK_AQ
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
680 {"amoswap.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_D
|MASK_AQ
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
681 {"amoand.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_D
|MASK_AQ
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
682 {"amoor.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_D
|MASK_AQ
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
683 {"amoxor.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_D
|MASK_AQ
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
684 {"amomax.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_D
|MASK_AQ
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
685 {"amomaxu.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_D
|MASK_AQ
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
686 {"amomin.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_D
|MASK_AQ
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
687 {"amominu.d.aq", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_D
|MASK_AQ
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
688 {"lr.d.rl", 64, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_D
|MASK_RL
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
689 {"sc.d.rl", 64, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_D
|MASK_RL
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
690 {"amoadd.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_D
|MASK_RL
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
691 {"amoswap.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_D
|MASK_RL
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
692 {"amoand.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_D
|MASK_RL
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
693 {"amoor.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_D
|MASK_RL
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
694 {"amoxor.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_D
|MASK_RL
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
695 {"amomax.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_D
|MASK_RL
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
696 {"amomaxu.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_D
|MASK_RL
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
697 {"amomin.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_D
|MASK_RL
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
698 {"amominu.d.rl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_D
|MASK_RL
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
699 {"lr.d.aqrl", 64, INSN_CLASS_ZALRSC
, "d,0(s)", MATCH_LR_D
|MASK_AQRL
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
700 {"sc.d.aqrl", 64, INSN_CLASS_ZALRSC
, "d,t,0(s)", MATCH_SC_D
|MASK_AQRL
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
701 {"amoadd.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOADD_D
|MASK_AQRL
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
702 {"amoswap.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOSWAP_D
|MASK_AQRL
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
703 {"amoand.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOAND_D
|MASK_AQRL
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
704 {"amoor.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOOR_D
|MASK_AQRL
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
705 {"amoxor.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOXOR_D
|MASK_AQRL
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
706 {"amomax.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAX_D
|MASK_AQRL
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
707 {"amomaxu.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMAXU_D
|MASK_AQRL
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
708 {"amomin.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMIN_D
|MASK_AQRL
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
709 {"amominu.d.aqrl", 64, INSN_CLASS_ZAAMO
, "d,t,0(s)", MATCH_AMOMINU_D
|MASK_AQRL
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
711 /* Byte and Halfword Atomic Memory Operations instruction subset. */
712 {"amoadd.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_B
, MASK_AMOADD_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
713 {"amoswap.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_B
, MASK_AMOSWAP_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
714 {"amoand.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_B
, MASK_AMOAND_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
715 {"amoor.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_B
, MASK_AMOOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
716 {"amoxor.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_B
, MASK_AMOXOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
717 {"amomax.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_B
, MASK_AMOMAX_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
718 {"amomaxu.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_B
, MASK_AMOMAXU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
719 {"amomin.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_B
, MASK_AMOMIN_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
720 {"amominu.b", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_B
, MASK_AMOMINU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
721 {"amocas.b", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_B
, MASK_AMOCAS_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
722 {"amoadd.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_B
|MASK_AQ
, MASK_AMOADD_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
723 {"amoswap.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_B
|MASK_AQ
, MASK_AMOSWAP_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
724 {"amoand.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_B
|MASK_AQ
, MASK_AMOAND_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
725 {"amoor.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_B
|MASK_AQ
, MASK_AMOOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
726 {"amoxor.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_B
|MASK_AQ
, MASK_AMOXOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
727 {"amomax.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_B
|MASK_AQ
, MASK_AMOMAX_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
728 {"amomaxu.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_B
|MASK_AQ
, MASK_AMOMAXU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
729 {"amomin.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_B
|MASK_AQ
, MASK_AMOMIN_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
730 {"amominu.b.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_B
|MASK_AQ
, MASK_AMOMINU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
731 {"amocas.b.aq", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_B
|MASK_AQ
, MASK_AMOCAS_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
732 {"amoadd.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_B
|MASK_RL
, MASK_AMOADD_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
733 {"amoswap.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_B
|MASK_RL
, MASK_AMOSWAP_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
734 {"amoand.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_B
|MASK_RL
, MASK_AMOAND_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
735 {"amoor.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_B
|MASK_RL
, MASK_AMOOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
736 {"amoxor.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_B
|MASK_RL
, MASK_AMOXOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
737 {"amomax.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_B
|MASK_RL
, MASK_AMOMAX_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
738 {"amomaxu.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_B
|MASK_RL
, MASK_AMOMAXU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
739 {"amomin.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_B
|MASK_RL
, MASK_AMOMIN_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
740 {"amominu.b.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_B
|MASK_RL
, MASK_AMOMINU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
741 {"amocas.b.rl", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_B
|MASK_RL
, MASK_AMOCAS_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
742 {"amoadd.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_B
|MASK_AQRL
, MASK_AMOADD_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
743 {"amoswap.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_B
|MASK_AQRL
, MASK_AMOSWAP_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
744 {"amoand.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_B
|MASK_AQRL
, MASK_AMOAND_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
745 {"amoor.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_B
|MASK_AQRL
, MASK_AMOOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
746 {"amoxor.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_B
|MASK_AQRL
, MASK_AMOXOR_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
747 {"amomax.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_B
|MASK_AQRL
, MASK_AMOMAX_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
748 {"amomaxu.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_B
|MASK_AQRL
, MASK_AMOMAXU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
749 {"amomin.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_B
|MASK_AQRL
, MASK_AMOMIN_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
750 {"amominu.b.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_B
|MASK_AQRL
, MASK_AMOMINU_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
751 {"amocas.b.aqrl", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_B
|MASK_AQRL
, MASK_AMOCAS_B
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
752 {"amoadd.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_H
, MASK_AMOADD_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
753 {"amoswap.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_H
, MASK_AMOSWAP_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
754 {"amoand.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_H
, MASK_AMOAND_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
755 {"amoor.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_H
, MASK_AMOOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
756 {"amoxor.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_H
, MASK_AMOXOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
757 {"amomax.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_H
, MASK_AMOMAX_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
758 {"amomaxu.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_H
, MASK_AMOMAXU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
759 {"amomin.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_H
, MASK_AMOMIN_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
760 {"amominu.h", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_H
, MASK_AMOMINU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
761 {"amocas.h", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_H
, MASK_AMOCAS_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
762 {"amoadd.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_H
|MASK_AQ
, MASK_AMOADD_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
763 {"amoswap.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_H
|MASK_AQ
, MASK_AMOSWAP_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
764 {"amoand.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_H
|MASK_AQ
, MASK_AMOAND_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
765 {"amoor.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_H
|MASK_AQ
, MASK_AMOOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
766 {"amoxor.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_H
|MASK_AQ
, MASK_AMOXOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
767 {"amomax.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_H
|MASK_AQ
, MASK_AMOMAX_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
768 {"amomaxu.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_H
|MASK_AQ
, MASK_AMOMAXU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
769 {"amomin.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_H
|MASK_AQ
, MASK_AMOMIN_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
770 {"amominu.h.aq", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_H
|MASK_AQ
, MASK_AMOMINU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
771 {"amocas.h.aq", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_H
|MASK_AQ
, MASK_AMOCAS_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
772 {"amoadd.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_H
|MASK_RL
, MASK_AMOADD_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
773 {"amoswap.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_H
|MASK_RL
, MASK_AMOSWAP_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
774 {"amoand.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_H
|MASK_RL
, MASK_AMOAND_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
775 {"amoor.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_H
|MASK_RL
, MASK_AMOOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
776 {"amoxor.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_H
|MASK_RL
, MASK_AMOXOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
777 {"amomax.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_H
|MASK_RL
, MASK_AMOMAX_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
778 {"amomaxu.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_H
|MASK_RL
, MASK_AMOMAXU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
779 {"amomin.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_H
|MASK_RL
, MASK_AMOMIN_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
780 {"amominu.h.rl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_H
|MASK_RL
, MASK_AMOMINU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
781 {"amocas.h.rl", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_H
|MASK_RL
, MASK_AMOCAS_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
782 {"amoadd.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOADD_H
|MASK_AQRL
, MASK_AMOADD_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
783 {"amoswap.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOSWAP_H
|MASK_AQRL
, MASK_AMOSWAP_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
784 {"amoand.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOAND_H
|MASK_AQRL
, MASK_AMOAND_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
785 {"amoor.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOOR_H
|MASK_AQRL
, MASK_AMOOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
786 {"amoxor.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOXOR_H
|MASK_AQRL
, MASK_AMOXOR_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
787 {"amomax.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAX_H
|MASK_AQRL
, MASK_AMOMAX_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
788 {"amomaxu.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMAXU_H
|MASK_AQRL
, MASK_AMOMAXU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
789 {"amomin.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMIN_H
|MASK_AQRL
, MASK_AMOMIN_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
790 {"amominu.h.aqrl", 0, INSN_CLASS_ZABHA
, "d,t,0(s)", MATCH_AMOMINU_H
|MASK_AQRL
, MASK_AMOMINU_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
791 {"amocas.h.aqrl", 0, INSN_CLASS_ZABHA_AND_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_H
|MASK_AQRL
, MASK_AMOCAS_H
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
793 /* Zacas instruction subset. */
794 {"amocas.w", 0, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_W
, MASK_AMOCAS_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
795 {"amocas.d", 32, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
, MASK_AMOCAS_D
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_8_BYTE
},
796 {"amocas.d", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
, MASK_AMOCAS_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
797 {"amocas.q", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_Q
, MASK_AMOCAS_Q
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_16_BYTE
},
798 {"amocas.w.aq", 0, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_W
|MASK_AQ
, MASK_AMOCAS_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
799 {"amocas.d.aq", 32, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
|MASK_AQ
, MASK_AMOCAS_D
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_8_BYTE
},
800 {"amocas.d.aq", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
|MASK_AQ
, MASK_AMOCAS_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
801 {"amocas.q.aq", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_Q
|MASK_AQ
, MASK_AMOCAS_Q
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_16_BYTE
},
802 {"amocas.w.rl", 0, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_W
|MASK_RL
, MASK_AMOCAS_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
803 {"amocas.d.rl", 32, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
|MASK_RL
, MASK_AMOCAS_D
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_8_BYTE
},
804 {"amocas.d.rl", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
|MASK_RL
, MASK_AMOCAS_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
805 {"amocas.q.rl", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_Q
|MASK_RL
, MASK_AMOCAS_Q
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_16_BYTE
},
806 {"amocas.w.aqrl", 0, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_W
|MASK_AQRL
, MASK_AMOCAS_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
807 {"amocas.d.aqrl", 32, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
|MASK_AQRL
, MASK_AMOCAS_D
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_8_BYTE
},
808 {"amocas.d.aqrl", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_D
|MASK_AQRL
, MASK_AMOCAS_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
809 {"amocas.q.aqrl", 64, INSN_CLASS_ZACAS
, "d,t,0(s)", MATCH_AMOCAS_Q
|MASK_AQRL
, MASK_AMOCAS_Q
|MASK_AQRL
, match_rs2_rd_even
, INSN_DREF
|INSN_16_BYTE
},
811 /* Multiply/Divide instruction subset. */
812 {"mul", 0, INSN_CLASS_ZCB_AND_ZMMUL
, "Cs,Cw,Ct", MATCH_C_MUL
, MASK_C_MUL
, match_opcode
, INSN_ALIAS
},
813 {"mul", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MUL
, MASK_MUL
, match_opcode
, 0 },
814 {"mulh", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULH
, MASK_MULH
, match_opcode
, 0 },
815 {"mulhu", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULHU
, MASK_MULHU
, match_opcode
, 0 },
816 {"mulhsu", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULHSU
, MASK_MULHSU
, match_opcode
, 0 },
817 {"div", 0, INSN_CLASS_M
, "d,s,t", MATCH_DIV
, MASK_DIV
, match_opcode
, 0 },
818 {"divu", 0, INSN_CLASS_M
, "d,s,t", MATCH_DIVU
, MASK_DIVU
, match_opcode
, 0 },
819 {"rem", 0, INSN_CLASS_M
, "d,s,t", MATCH_REM
, MASK_REM
, match_opcode
, 0 },
820 {"remu", 0, INSN_CLASS_M
, "d,s,t", MATCH_REMU
, MASK_REMU
, match_opcode
, 0 },
821 {"mulw", 64, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULW
, MASK_MULW
, match_opcode
, 0 },
822 {"divw", 64, INSN_CLASS_M
, "d,s,t", MATCH_DIVW
, MASK_DIVW
, match_opcode
, 0 },
823 {"divuw", 64, INSN_CLASS_M
, "d,s,t", MATCH_DIVUW
, MASK_DIVUW
, match_opcode
, 0 },
824 {"remw", 64, INSN_CLASS_M
, "d,s,t", MATCH_REMW
, MASK_REMW
, match_opcode
, 0 },
825 {"remuw", 64, INSN_CLASS_M
, "d,s,t", MATCH_REMUW
, MASK_REMUW
, match_opcode
, 0 },
827 /* Half-precision floating-point instruction subset. */
828 {"flh", 0, INSN_CLASS_ZFHMIN
, "D,o(s)", MATCH_FLH
, MASK_FLH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
829 {"flh", 0, INSN_CLASS_ZFHMIN
, "D,A,s", 0, (int) M_FLx
, match_rs1_nonzero
, INSN_MACRO
},
830 {"fsh", 0, INSN_CLASS_ZFHMIN
, "T,q(s)", MATCH_FSH
, MASK_FSH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
831 {"fsh", 0, INSN_CLASS_ZFHMIN
, "T,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
832 {"fmv.x.h", 0, INSN_CLASS_ZFHMIN
, "d,S", MATCH_FMV_X_H
, MASK_FMV_X_H
, match_opcode
, 0 },
833 {"fmv.h.x", 0, INSN_CLASS_ZFHMIN
, "D,s", MATCH_FMV_H_X
, MASK_FMV_H_X
, match_opcode
, 0 },
834 {"fmv.h", 0, INSN_CLASS_ZFH_INX
, "D,U", MATCH_FSGNJ_H
, MASK_FSGNJ_H
, match_rs1_eq_rs2
, INSN_ALIAS
},
835 {"fneg.h", 0, INSN_CLASS_ZFH_INX
, "D,U", MATCH_FSGNJN_H
, MASK_FSGNJN_H
, match_rs1_eq_rs2
, INSN_ALIAS
},
836 {"fabs.h", 0, INSN_CLASS_ZFH_INX
, "D,U", MATCH_FSGNJX_H
, MASK_FSGNJX_H
, match_rs1_eq_rs2
, INSN_ALIAS
},
837 {"fsgnj.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSGNJ_H
, MASK_FSGNJ_H
, match_opcode
, 0 },
838 {"fsgnjn.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSGNJN_H
, MASK_FSGNJN_H
, match_opcode
, 0 },
839 {"fsgnjx.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSGNJX_H
, MASK_FSGNJX_H
, match_opcode
, 0 },
840 {"fadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FADD_H
|MASK_RM
, MASK_FADD_H
|MASK_RM
, match_opcode
, 0 },
841 {"fadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FADD_H
, MASK_FADD_H
, match_opcode
, 0 },
842 {"fsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSUB_H
|MASK_RM
, MASK_FSUB_H
|MASK_RM
, match_opcode
, 0 },
843 {"fsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FSUB_H
, MASK_FSUB_H
, match_opcode
, 0 },
844 {"fmul.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FMUL_H
|MASK_RM
, MASK_FMUL_H
|MASK_RM
, match_opcode
, 0 },
845 {"fmul.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FMUL_H
, MASK_FMUL_H
, match_opcode
, 0 },
846 {"fdiv.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FDIV_H
|MASK_RM
, MASK_FDIV_H
|MASK_RM
, match_opcode
, 0 },
847 {"fdiv.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FDIV_H
, MASK_FDIV_H
, match_opcode
, 0 },
848 {"fsqrt.h", 0, INSN_CLASS_ZFH_INX
, "D,S", MATCH_FSQRT_H
|MASK_RM
, MASK_FSQRT_H
|MASK_RM
, match_opcode
, 0 },
849 {"fsqrt.h", 0, INSN_CLASS_ZFH_INX
, "D,S,m", MATCH_FSQRT_H
, MASK_FSQRT_H
, match_opcode
, 0 },
850 {"fmin.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FMIN_H
, MASK_FMIN_H
, match_opcode
, 0 },
851 {"fmax.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FMAX_H
, MASK_FMAX_H
, match_opcode
, 0 },
852 {"fmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FMADD_H
|MASK_RM
, MASK_FMADD_H
|MASK_RM
, match_opcode
, 0 },
853 {"fmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FMADD_H
, MASK_FMADD_H
, match_opcode
, 0 },
854 {"fnmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FNMADD_H
|MASK_RM
, MASK_FNMADD_H
|MASK_RM
, match_opcode
, 0 },
855 {"fnmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FNMADD_H
, MASK_FNMADD_H
, match_opcode
, 0 },
856 {"fmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FMSUB_H
|MASK_RM
, MASK_FMSUB_H
|MASK_RM
, match_opcode
, 0 },
857 {"fmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FMSUB_H
, MASK_FMSUB_H
, match_opcode
, 0 },
858 {"fnmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FNMSUB_H
|MASK_RM
, MASK_FNMSUB_H
|MASK_RM
, match_opcode
, 0 },
859 {"fnmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FNMSUB_H
, MASK_FNMSUB_H
, match_opcode
, 0 },
860 {"fcvt.w.h", 0, INSN_CLASS_ZFH_INX
, "d,S", MATCH_FCVT_W_H
|MASK_RM
, MASK_FCVT_W_H
|MASK_RM
, match_opcode
, 0 },
861 {"fcvt.w.h", 0, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_W_H
, MASK_FCVT_W_H
, match_opcode
, 0 },
862 {"fcvt.wu.h", 0, INSN_CLASS_ZFH_INX
, "d,S", MATCH_FCVT_WU_H
|MASK_RM
, MASK_FCVT_WU_H
|MASK_RM
, match_opcode
, 0 },
863 {"fcvt.wu.h", 0, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_WU_H
, MASK_FCVT_WU_H
, match_opcode
, 0 },
864 {"fcvt.h.w", 0, INSN_CLASS_ZFH_INX
, "D,s", MATCH_FCVT_H_W
|MASK_RM
, MASK_FCVT_H_W
|MASK_RM
, match_opcode
, 0 },
865 {"fcvt.h.w", 0, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_W
, MASK_FCVT_H_W
, match_opcode
, 0 },
866 {"fcvt.h.wu", 0, INSN_CLASS_ZFH_INX
, "D,s", MATCH_FCVT_H_WU
|MASK_RM
, MASK_FCVT_H_WU
|MASK_RM
, match_opcode
, 0 },
867 {"fcvt.h.wu", 0, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_WU
, MASK_FCVT_H_WU
, match_opcode
, 0 },
868 {"fcvt.s.h", 0, INSN_CLASS_ZFHMIN_INX
, "D,S", MATCH_FCVT_S_H
, MASK_FCVT_S_H
|MASK_RM
, match_opcode
, 0 },
869 {"fcvt.d.h", 0, INSN_CLASS_ZFHMIN_AND_D_INX
, "D,S", MATCH_FCVT_D_H
, MASK_FCVT_D_H
|MASK_RM
, match_opcode
, 0 },
870 {"fcvt.q.h", 0, INSN_CLASS_ZFHMIN_AND_Q_INX
, "D,S", MATCH_FCVT_Q_H
, MASK_FCVT_Q_H
|MASK_RM
, match_opcode
, 0 },
871 {"fcvt.h.s", 0, INSN_CLASS_ZFHMIN_INX
, "D,S", MATCH_FCVT_H_S
|MASK_RM
, MASK_FCVT_H_S
|MASK_RM
, match_opcode
, 0 },
872 {"fcvt.h.s", 0, INSN_CLASS_ZFHMIN_INX
, "D,S,m", MATCH_FCVT_H_S
, MASK_FCVT_H_S
, match_opcode
, 0 },
873 {"fcvt.h.d", 0, INSN_CLASS_ZFHMIN_AND_D_INX
, "D,S", MATCH_FCVT_H_D
|MASK_RM
, MASK_FCVT_H_D
|MASK_RM
, match_opcode
, 0 },
874 {"fcvt.h.d", 0, INSN_CLASS_ZFHMIN_AND_D_INX
, "D,S,m", MATCH_FCVT_H_D
, MASK_FCVT_H_D
, match_opcode
, 0 },
875 {"fcvt.h.q", 0, INSN_CLASS_ZFHMIN_AND_Q_INX
, "D,S", MATCH_FCVT_H_Q
|MASK_RM
, MASK_FCVT_H_Q
|MASK_RM
, match_opcode
, 0 },
876 {"fcvt.h.q", 0, INSN_CLASS_ZFHMIN_AND_Q_INX
, "D,S,m", MATCH_FCVT_H_Q
, MASK_FCVT_H_Q
, match_opcode
, 0 },
877 {"fclass.h", 0, INSN_CLASS_ZFH_INX
, "d,S", MATCH_FCLASS_H
, MASK_FCLASS_H
, match_opcode
, 0 },
878 {"feq.h", 0, INSN_CLASS_ZFH_INX
, "d,S,T", MATCH_FEQ_H
, MASK_FEQ_H
, match_opcode
, 0 },
879 {"flt.h", 0, INSN_CLASS_ZFH_INX
, "d,S,T", MATCH_FLT_H
, MASK_FLT_H
, match_opcode
, 0 },
880 {"fle.h", 0, INSN_CLASS_ZFH_INX
, "d,S,T", MATCH_FLE_H
, MASK_FLE_H
, match_opcode
, 0 },
881 {"fgt.h", 0, INSN_CLASS_ZFH_INX
, "d,T,S", MATCH_FLT_H
, MASK_FLT_H
, match_opcode
, 0 },
882 {"fge.h", 0, INSN_CLASS_ZFH_INX
, "d,T,S", MATCH_FLE_H
, MASK_FLE_H
, match_opcode
, 0 },
883 {"fcvt.l.h", 64, INSN_CLASS_ZFH_INX
, "d,S", MATCH_FCVT_L_H
|MASK_RM
, MASK_FCVT_L_H
|MASK_RM
, match_opcode
, 0 },
884 {"fcvt.l.h", 64, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_L_H
, MASK_FCVT_L_H
, match_opcode
, 0 },
885 {"fcvt.lu.h", 64, INSN_CLASS_ZFH_INX
, "d,S", MATCH_FCVT_LU_H
|MASK_RM
, MASK_FCVT_LU_H
|MASK_RM
, match_opcode
, 0 },
886 {"fcvt.lu.h", 64, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_LU_H
, MASK_FCVT_LU_H
, match_opcode
, 0 },
887 {"fcvt.h.l", 64, INSN_CLASS_ZFH_INX
, "D,s", MATCH_FCVT_H_L
|MASK_RM
, MASK_FCVT_H_L
|MASK_RM
, match_opcode
, 0 },
888 {"fcvt.h.l", 64, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_L
, MASK_FCVT_H_L
, match_opcode
, 0 },
889 {"fcvt.h.lu", 64, INSN_CLASS_ZFH_INX
, "D,s", MATCH_FCVT_H_LU
|MASK_RM
, MASK_FCVT_H_LU
|MASK_RM
, match_opcode
, 0 },
890 {"fcvt.h.lu", 64, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_LU
, MASK_FCVT_H_LU
, match_opcode
, 0 },
892 /* Zfbfmin instructions. */
893 {"fcvt.bf16.s", 0, INSN_CLASS_ZFBFMIN
, "D,S", MATCH_FCVT_BF16_S
|MASK_RM
, MASK_FCVT_BF16_S
|MASK_RM
, match_opcode
, 0 },
894 {"fcvt.bf16.s", 0, INSN_CLASS_ZFBFMIN
, "D,S,m", MATCH_FCVT_BF16_S
, MASK_FCVT_BF16_S
, match_opcode
, 0 },
895 {"fcvt.s.bf16", 0, INSN_CLASS_ZFBFMIN
, "D,S", MATCH_FCVT_S_BF16
, MASK_FCVT_S_BF16
|MASK_RM
, match_opcode
, 0 },
897 /* Single-precision floating-point instruction subset. */
898 {"frcsr", 0, INSN_CLASS_F_INX
, "d", MATCH_FRCSR
, MASK_FRCSR
, match_opcode
, INSN_ALIAS
},
899 {"frsr", 0, INSN_CLASS_F_INX
, "d", MATCH_FRCSR
, MASK_FRCSR
, match_opcode
, INSN_ALIAS
},
900 {"fscsr", 0, INSN_CLASS_F_INX
, "s", MATCH_FSCSR
, MASK_FSCSR
|MASK_RD
, match_opcode
, INSN_ALIAS
},
901 {"fscsr", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSCSR
, MASK_FSCSR
, match_opcode
, INSN_ALIAS
},
902 {"fssr", 0, INSN_CLASS_F_INX
, "s", MATCH_FSCSR
, MASK_FSCSR
|MASK_RD
, match_opcode
, INSN_ALIAS
},
903 {"fssr", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSCSR
, MASK_FSCSR
, match_opcode
, INSN_ALIAS
},
904 {"frrm", 0, INSN_CLASS_F_INX
, "d", MATCH_FRRM
, MASK_FRRM
, match_opcode
, INSN_ALIAS
},
905 {"fsrm", 0, INSN_CLASS_F_INX
, "s", MATCH_FSRM
, MASK_FSRM
|MASK_RD
, match_opcode
, INSN_ALIAS
},
906 {"fsrm", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSRM
, MASK_FSRM
, match_opcode
, INSN_ALIAS
},
907 {"fsrmi", 0, INSN_CLASS_F_INX
, "d,Z", MATCH_FSRMI
, MASK_FSRMI
, match_opcode
, INSN_ALIAS
},
908 {"fsrmi", 0, INSN_CLASS_F_INX
, "Z", MATCH_FSRMI
, MASK_FSRMI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
909 {"frflags", 0, INSN_CLASS_F_INX
, "d", MATCH_FRFLAGS
, MASK_FRFLAGS
, match_opcode
, INSN_ALIAS
},
910 {"fsflags", 0, INSN_CLASS_F_INX
, "s", MATCH_FSFLAGS
, MASK_FSFLAGS
|MASK_RD
, match_opcode
, INSN_ALIAS
},
911 {"fsflags", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSFLAGS
, MASK_FSFLAGS
, match_opcode
, INSN_ALIAS
},
912 {"fsflagsi", 0, INSN_CLASS_F_INX
, "d,Z", MATCH_FSFLAGSI
, MASK_FSFLAGSI
, match_opcode
, INSN_ALIAS
},
913 {"fsflagsi", 0, INSN_CLASS_F_INX
, "Z", MATCH_FSFLAGSI
, MASK_FSFLAGSI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
914 {"flw", 32, INSN_CLASS_F_AND_C
, "D,Cm(Cc)", MATCH_C_FLWSP
, MASK_C_FLWSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
915 {"flw", 32, INSN_CLASS_F_AND_C
, "CD,Ck(Cs)", MATCH_C_FLW
, MASK_C_FLW
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
916 {"flw", 0, INSN_CLASS_F
, "D,o(s)", MATCH_FLW
, MASK_FLW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
917 {"flw", 0, INSN_CLASS_F
, "D,A,s", 0, (int) M_FLx
, match_rs1_nonzero
, INSN_MACRO
},
918 {"fsw", 32, INSN_CLASS_F_AND_C
, "CT,CM(Cc)", MATCH_C_FSWSP
, MASK_C_FSWSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
919 {"fsw", 32, INSN_CLASS_F_AND_C
, "CD,Ck(Cs)", MATCH_C_FSW
, MASK_C_FSW
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
920 {"fsw", 0, INSN_CLASS_F
, "T,q(s)", MATCH_FSW
, MASK_FSW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
921 {"fsw", 0, INSN_CLASS_F
, "T,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
922 {"fmv.x.w", 0, INSN_CLASS_F
, "d,S", MATCH_FMV_X_S
, MASK_FMV_X_S
, match_opcode
, 0 },
923 {"fmv.w.x", 0, INSN_CLASS_F
, "D,s", MATCH_FMV_S_X
, MASK_FMV_S_X
, match_opcode
, 0 },
924 {"fmv.x.s", 0, INSN_CLASS_F
, "d,S", MATCH_FMV_X_S
, MASK_FMV_X_S
, match_opcode
, 0 },
925 {"fmv.s.x", 0, INSN_CLASS_F
, "D,s", MATCH_FMV_S_X
, MASK_FMV_S_X
, match_opcode
, 0 },
926 {"fmv.s", 0, INSN_CLASS_F_INX
, "D,U", MATCH_FSGNJ_S
, MASK_FSGNJ_S
, match_rs1_eq_rs2
, INSN_ALIAS
},
927 {"fneg.s", 0, INSN_CLASS_F_INX
, "D,U", MATCH_FSGNJN_S
, MASK_FSGNJN_S
, match_rs1_eq_rs2
, INSN_ALIAS
},
928 {"fabs.s", 0, INSN_CLASS_F_INX
, "D,U", MATCH_FSGNJX_S
, MASK_FSGNJX_S
, match_rs1_eq_rs2
, INSN_ALIAS
},
929 {"fsgnj.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSGNJ_S
, MASK_FSGNJ_S
, match_opcode
, 0 },
930 {"fsgnjn.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSGNJN_S
, MASK_FSGNJN_S
, match_opcode
, 0 },
931 {"fsgnjx.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSGNJX_S
, MASK_FSGNJX_S
, match_opcode
, 0 },
932 {"fadd.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FADD_S
|MASK_RM
, MASK_FADD_S
|MASK_RM
, match_opcode
, 0 },
933 {"fadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FADD_S
, MASK_FADD_S
, match_opcode
, 0 },
934 {"fsub.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSUB_S
|MASK_RM
, MASK_FSUB_S
|MASK_RM
, match_opcode
, 0 },
935 {"fsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FSUB_S
, MASK_FSUB_S
, match_opcode
, 0 },
936 {"fmul.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FMUL_S
|MASK_RM
, MASK_FMUL_S
|MASK_RM
, match_opcode
, 0 },
937 {"fmul.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FMUL_S
, MASK_FMUL_S
, match_opcode
, 0 },
938 {"fdiv.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FDIV_S
|MASK_RM
, MASK_FDIV_S
|MASK_RM
, match_opcode
, 0 },
939 {"fdiv.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FDIV_S
, MASK_FDIV_S
, match_opcode
, 0 },
940 {"fsqrt.s", 0, INSN_CLASS_F_INX
, "D,S", MATCH_FSQRT_S
|MASK_RM
, MASK_FSQRT_S
|MASK_RM
, match_opcode
, 0 },
941 {"fsqrt.s", 0, INSN_CLASS_F_INX
, "D,S,m", MATCH_FSQRT_S
, MASK_FSQRT_S
, match_opcode
, 0 },
942 {"fmin.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FMIN_S
, MASK_FMIN_S
, match_opcode
, 0 },
943 {"fmax.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FMAX_S
, MASK_FMAX_S
, match_opcode
, 0 },
944 {"fmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FMADD_S
|MASK_RM
, MASK_FMADD_S
|MASK_RM
, match_opcode
, 0 },
945 {"fmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FMADD_S
, MASK_FMADD_S
, match_opcode
, 0 },
946 {"fnmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FNMADD_S
|MASK_RM
, MASK_FNMADD_S
|MASK_RM
, match_opcode
, 0 },
947 {"fnmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FNMADD_S
, MASK_FNMADD_S
, match_opcode
, 0 },
948 {"fmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FMSUB_S
|MASK_RM
, MASK_FMSUB_S
|MASK_RM
, match_opcode
, 0 },
949 {"fmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FMSUB_S
, MASK_FMSUB_S
, match_opcode
, 0 },
950 {"fnmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FNMSUB_S
|MASK_RM
, MASK_FNMSUB_S
|MASK_RM
, match_opcode
, 0 },
951 {"fnmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FNMSUB_S
, MASK_FNMSUB_S
, match_opcode
, 0 },
952 {"fcvt.w.s", 0, INSN_CLASS_F_INX
, "d,S", MATCH_FCVT_W_S
|MASK_RM
, MASK_FCVT_W_S
|MASK_RM
, match_opcode
, 0 },
953 {"fcvt.w.s", 0, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_W_S
, MASK_FCVT_W_S
, match_opcode
, 0 },
954 {"fcvt.wu.s", 0, INSN_CLASS_F_INX
, "d,S", MATCH_FCVT_WU_S
|MASK_RM
, MASK_FCVT_WU_S
|MASK_RM
, match_opcode
, 0 },
955 {"fcvt.wu.s", 0, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_WU_S
, MASK_FCVT_WU_S
, match_opcode
, 0 },
956 {"fcvt.s.w", 0, INSN_CLASS_F_INX
, "D,s", MATCH_FCVT_S_W
|MASK_RM
, MASK_FCVT_S_W
|MASK_RM
, match_opcode
, 0 },
957 {"fcvt.s.w", 0, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_W
, MASK_FCVT_S_W
, match_opcode
, 0 },
958 {"fcvt.s.wu", 0, INSN_CLASS_F_INX
, "D,s", MATCH_FCVT_S_WU
|MASK_RM
, MASK_FCVT_S_WU
|MASK_RM
, match_opcode
, 0 },
959 {"fcvt.s.wu", 0, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_WU
, MASK_FCVT_S_WU
, match_opcode
, 0 },
960 {"fclass.s", 0, INSN_CLASS_F_INX
, "d,S", MATCH_FCLASS_S
, MASK_FCLASS_S
, match_opcode
, 0 },
961 {"feq.s", 0, INSN_CLASS_F_INX
, "d,S,T", MATCH_FEQ_S
, MASK_FEQ_S
, match_opcode
, 0 },
962 {"flt.s", 0, INSN_CLASS_F_INX
, "d,S,T", MATCH_FLT_S
, MASK_FLT_S
, match_opcode
, 0 },
963 {"fle.s", 0, INSN_CLASS_F_INX
, "d,S,T", MATCH_FLE_S
, MASK_FLE_S
, match_opcode
, 0 },
964 {"fgt.s", 0, INSN_CLASS_F_INX
, "d,T,S", MATCH_FLT_S
, MASK_FLT_S
, match_opcode
, 0 },
965 {"fge.s", 0, INSN_CLASS_F_INX
, "d,T,S", MATCH_FLE_S
, MASK_FLE_S
, match_opcode
, 0 },
966 {"fcvt.l.s", 64, INSN_CLASS_F_INX
, "d,S", MATCH_FCVT_L_S
|MASK_RM
, MASK_FCVT_L_S
|MASK_RM
, match_opcode
, 0 },
967 {"fcvt.l.s", 64, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_L_S
, MASK_FCVT_L_S
, match_opcode
, 0 },
968 {"fcvt.lu.s", 64, INSN_CLASS_F_INX
, "d,S", MATCH_FCVT_LU_S
|MASK_RM
, MASK_FCVT_LU_S
|MASK_RM
, match_opcode
, 0 },
969 {"fcvt.lu.s", 64, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_LU_S
, MASK_FCVT_LU_S
, match_opcode
, 0 },
970 {"fcvt.s.l", 64, INSN_CLASS_F_INX
, "D,s", MATCH_FCVT_S_L
|MASK_RM
, MASK_FCVT_S_L
|MASK_RM
, match_opcode
, 0 },
971 {"fcvt.s.l", 64, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_L
, MASK_FCVT_S_L
, match_opcode
, 0 },
972 {"fcvt.s.lu", 64, INSN_CLASS_F_INX
, "D,s", MATCH_FCVT_S_LU
|MASK_RM
, MASK_FCVT_S_LU
|MASK_RM
, match_opcode
, 0 },
973 {"fcvt.s.lu", 64, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_LU
, MASK_FCVT_S_LU
, match_opcode
, 0 },
975 /* Double-precision floating-point instruction subset. */
976 {"fld", 0, INSN_CLASS_D_AND_C
, "D,Cn(Cc)", MATCH_C_FLDSP
, MASK_C_FLDSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
977 {"fld", 0, INSN_CLASS_D_AND_C
, "CD,Cl(Cs)", MATCH_C_FLD
, MASK_C_FLD
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
978 {"fld", 0, INSN_CLASS_D
, "D,o(s)", MATCH_FLD
, MASK_FLD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
979 {"fld", 0, INSN_CLASS_D
, "D,A,s", 0, (int) M_FLx
, match_rs1_nonzero
, INSN_MACRO
},
980 {"fsd", 0, INSN_CLASS_D_AND_C
, "CT,CN(Cc)", MATCH_C_FSDSP
, MASK_C_FSDSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
981 {"fsd", 0, INSN_CLASS_D_AND_C
, "CD,Cl(Cs)", MATCH_C_FSD
, MASK_C_FSD
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
982 {"fsd", 0, INSN_CLASS_D
, "T,q(s)", MATCH_FSD
, MASK_FSD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
983 {"fsd", 0, INSN_CLASS_D
, "T,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
984 {"fmv.d", 0, INSN_CLASS_D_INX
, "D,U", MATCH_FSGNJ_D
, MASK_FSGNJ_D
, match_rs1_eq_rs2
, INSN_ALIAS
},
985 {"fneg.d", 0, INSN_CLASS_D_INX
, "D,U", MATCH_FSGNJN_D
, MASK_FSGNJN_D
, match_rs1_eq_rs2
, INSN_ALIAS
},
986 {"fabs.d", 0, INSN_CLASS_D_INX
, "D,U", MATCH_FSGNJX_D
, MASK_FSGNJX_D
, match_rs1_eq_rs2
, INSN_ALIAS
},
987 {"fsgnj.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSGNJ_D
, MASK_FSGNJ_D
, match_opcode
, 0 },
988 {"fsgnjn.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSGNJN_D
, MASK_FSGNJN_D
, match_opcode
, 0 },
989 {"fsgnjx.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSGNJX_D
, MASK_FSGNJX_D
, match_opcode
, 0 },
990 {"fadd.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FADD_D
|MASK_RM
, MASK_FADD_D
|MASK_RM
, match_opcode
, 0 },
991 {"fadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FADD_D
, MASK_FADD_D
, match_opcode
, 0 },
992 {"fsub.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSUB_D
|MASK_RM
, MASK_FSUB_D
|MASK_RM
, match_opcode
, 0 },
993 {"fsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FSUB_D
, MASK_FSUB_D
, match_opcode
, 0 },
994 {"fmul.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FMUL_D
|MASK_RM
, MASK_FMUL_D
|MASK_RM
, match_opcode
, 0 },
995 {"fmul.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FMUL_D
, MASK_FMUL_D
, match_opcode
, 0 },
996 {"fdiv.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FDIV_D
|MASK_RM
, MASK_FDIV_D
|MASK_RM
, match_opcode
, 0 },
997 {"fdiv.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FDIV_D
, MASK_FDIV_D
, match_opcode
, 0 },
998 {"fsqrt.d", 0, INSN_CLASS_D_INX
, "D,S", MATCH_FSQRT_D
|MASK_RM
, MASK_FSQRT_D
|MASK_RM
, match_opcode
, 0 },
999 {"fsqrt.d", 0, INSN_CLASS_D_INX
, "D,S,m", MATCH_FSQRT_D
, MASK_FSQRT_D
, match_opcode
, 0 },
1000 {"fmin.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FMIN_D
, MASK_FMIN_D
, match_opcode
, 0 },
1001 {"fmax.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FMAX_D
, MASK_FMAX_D
, match_opcode
, 0 },
1002 {"fmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FMADD_D
|MASK_RM
, MASK_FMADD_D
|MASK_RM
, match_opcode
, 0 },
1003 {"fmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FMADD_D
, MASK_FMADD_D
, match_opcode
, 0 },
1004 {"fnmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FNMADD_D
|MASK_RM
, MASK_FNMADD_D
|MASK_RM
, match_opcode
, 0 },
1005 {"fnmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FNMADD_D
, MASK_FNMADD_D
, match_opcode
, 0 },
1006 {"fmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FMSUB_D
|MASK_RM
, MASK_FMSUB_D
|MASK_RM
, match_opcode
, 0 },
1007 {"fmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FMSUB_D
, MASK_FMSUB_D
, match_opcode
, 0 },
1008 {"fnmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FNMSUB_D
|MASK_RM
, MASK_FNMSUB_D
|MASK_RM
, match_opcode
, 0 },
1009 {"fnmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FNMSUB_D
, MASK_FNMSUB_D
, match_opcode
, 0 },
1010 {"fcvt.w.d", 0, INSN_CLASS_D_INX
, "d,S", MATCH_FCVT_W_D
|MASK_RM
, MASK_FCVT_W_D
|MASK_RM
, match_opcode
, 0 },
1011 {"fcvt.w.d", 0, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_W_D
, MASK_FCVT_W_D
, match_opcode
, 0 },
1012 {"fcvt.wu.d", 0, INSN_CLASS_D_INX
, "d,S", MATCH_FCVT_WU_D
|MASK_RM
, MASK_FCVT_WU_D
|MASK_RM
, match_opcode
, 0 },
1013 {"fcvt.wu.d", 0, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_WU_D
, MASK_FCVT_WU_D
, match_opcode
, 0 },
1014 {"fcvt.d.w", 0, INSN_CLASS_D_INX
, "D,s", MATCH_FCVT_D_W
, MASK_FCVT_D_W
|MASK_RM
, match_opcode
, 0 },
1015 {"fcvt.d.wu", 0, INSN_CLASS_D_INX
, "D,s", MATCH_FCVT_D_WU
, MASK_FCVT_D_WU
|MASK_RM
, match_opcode
, 0 },
1016 {"fcvt.d.s", 0, INSN_CLASS_D_INX
, "D,S", MATCH_FCVT_D_S
, MASK_FCVT_D_S
|MASK_RM
, match_opcode
, 0 },
1017 {"fcvt.s.d", 0, INSN_CLASS_D_INX
, "D,S", MATCH_FCVT_S_D
|MASK_RM
, MASK_FCVT_S_D
|MASK_RM
, match_opcode
, 0 },
1018 {"fcvt.s.d", 0, INSN_CLASS_D_INX
, "D,S,m", MATCH_FCVT_S_D
, MASK_FCVT_S_D
, match_opcode
, 0 },
1019 {"fclass.d", 0, INSN_CLASS_D_INX
, "d,S", MATCH_FCLASS_D
, MASK_FCLASS_D
, match_opcode
, 0 },
1020 {"feq.d", 0, INSN_CLASS_D_INX
, "d,S,T", MATCH_FEQ_D
, MASK_FEQ_D
, match_opcode
, 0 },
1021 {"flt.d", 0, INSN_CLASS_D_INX
, "d,S,T", MATCH_FLT_D
, MASK_FLT_D
, match_opcode
, 0 },
1022 {"fle.d", 0, INSN_CLASS_D_INX
, "d,S,T", MATCH_FLE_D
, MASK_FLE_D
, match_opcode
, 0 },
1023 {"fgt.d", 0, INSN_CLASS_D_INX
, "d,T,S", MATCH_FLT_D
, MASK_FLT_D
, match_opcode
, 0 },
1024 {"fge.d", 0, INSN_CLASS_D_INX
, "d,T,S", MATCH_FLE_D
, MASK_FLE_D
, match_opcode
, 0 },
1025 {"fmv.x.d", 64, INSN_CLASS_D
, "d,S", MATCH_FMV_X_D
, MASK_FMV_X_D
, match_opcode
, 0 },
1026 {"fmv.d.x", 64, INSN_CLASS_D
, "D,s", MATCH_FMV_D_X
, MASK_FMV_D_X
, match_opcode
, 0 },
1027 {"fcvt.l.d", 64, INSN_CLASS_D_INX
, "d,S", MATCH_FCVT_L_D
|MASK_RM
, MASK_FCVT_L_D
|MASK_RM
, match_opcode
, 0 },
1028 {"fcvt.l.d", 64, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_L_D
, MASK_FCVT_L_D
, match_opcode
, 0 },
1029 {"fcvt.lu.d", 64, INSN_CLASS_D_INX
, "d,S", MATCH_FCVT_LU_D
|MASK_RM
, MASK_FCVT_LU_D
|MASK_RM
, match_opcode
, 0 },
1030 {"fcvt.lu.d", 64, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_LU_D
, MASK_FCVT_LU_D
, match_opcode
, 0 },
1031 {"fcvt.d.l", 64, INSN_CLASS_D_INX
, "D,s", MATCH_FCVT_D_L
|MASK_RM
, MASK_FCVT_D_L
|MASK_RM
, match_opcode
, 0 },
1032 {"fcvt.d.l", 64, INSN_CLASS_D_INX
, "D,s,m", MATCH_FCVT_D_L
, MASK_FCVT_D_L
, match_opcode
, 0 },
1033 {"fcvt.d.lu", 64, INSN_CLASS_D_INX
, "D,s", MATCH_FCVT_D_LU
|MASK_RM
, MASK_FCVT_D_LU
|MASK_RM
, match_opcode
, 0 },
1034 {"fcvt.d.lu", 64, INSN_CLASS_D_INX
, "D,s,m", MATCH_FCVT_D_LU
, MASK_FCVT_D_LU
, match_opcode
, 0 },
1036 /* Quad-precision floating-point instruction subset. */
1037 {"flq", 0, INSN_CLASS_Q
, "D,o(s)", MATCH_FLQ
, MASK_FLQ
, match_opcode
, INSN_DREF
|INSN_16_BYTE
},
1038 {"flq", 0, INSN_CLASS_Q
, "D,A,s", 0, (int) M_FLx
, match_rs1_nonzero
, INSN_MACRO
},
1039 {"fsq", 0, INSN_CLASS_Q
, "T,q(s)", MATCH_FSQ
, MASK_FSQ
, match_opcode
, INSN_DREF
|INSN_16_BYTE
},
1040 {"fsq", 0, INSN_CLASS_Q
, "T,A,s", 0, (int) M_Sx_FSx
, match_rs1_nonzero
, INSN_MACRO
},
1041 {"fmv.q", 0, INSN_CLASS_Q_INX
, "D,U", MATCH_FSGNJ_Q
, MASK_FSGNJ_Q
, match_rs1_eq_rs2
, INSN_ALIAS
},
1042 {"fneg.q", 0, INSN_CLASS_Q_INX
, "D,U", MATCH_FSGNJN_Q
, MASK_FSGNJN_Q
, match_rs1_eq_rs2
, INSN_ALIAS
},
1043 {"fabs.q", 0, INSN_CLASS_Q_INX
, "D,U", MATCH_FSGNJX_Q
, MASK_FSGNJX_Q
, match_rs1_eq_rs2
, INSN_ALIAS
},
1044 {"fsgnj.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSGNJ_Q
, MASK_FSGNJ_Q
, match_opcode
, 0 },
1045 {"fsgnjn.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSGNJN_Q
, MASK_FSGNJN_Q
, match_opcode
, 0 },
1046 {"fsgnjx.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSGNJX_Q
, MASK_FSGNJX_Q
, match_opcode
, 0 },
1047 {"fadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FADD_Q
|MASK_RM
, MASK_FADD_Q
|MASK_RM
, match_opcode
, 0 },
1048 {"fadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FADD_Q
, MASK_FADD_Q
, match_opcode
, 0 },
1049 {"fsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSUB_Q
|MASK_RM
, MASK_FSUB_Q
|MASK_RM
, match_opcode
, 0 },
1050 {"fsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FSUB_Q
, MASK_FSUB_Q
, match_opcode
, 0 },
1051 {"fmul.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FMUL_Q
|MASK_RM
, MASK_FMUL_Q
|MASK_RM
, match_opcode
, 0 },
1052 {"fmul.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FMUL_Q
, MASK_FMUL_Q
, match_opcode
, 0 },
1053 {"fdiv.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FDIV_Q
|MASK_RM
, MASK_FDIV_Q
|MASK_RM
, match_opcode
, 0 },
1054 {"fdiv.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FDIV_Q
, MASK_FDIV_Q
, match_opcode
, 0 },
1055 {"fsqrt.q", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FSQRT_Q
|MASK_RM
, MASK_FSQRT_Q
|MASK_RM
, match_opcode
, 0 },
1056 {"fsqrt.q", 0, INSN_CLASS_Q_INX
, "D,S,m", MATCH_FSQRT_Q
, MASK_FSQRT_Q
, match_opcode
, 0 },
1057 {"fmin.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FMIN_Q
, MASK_FMIN_Q
, match_opcode
, 0 },
1058 {"fmax.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FMAX_Q
, MASK_FMAX_Q
, match_opcode
, 0 },
1059 {"fmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FMADD_Q
|MASK_RM
, MASK_FMADD_Q
|MASK_RM
, match_opcode
, 0 },
1060 {"fmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FMADD_Q
, MASK_FMADD_Q
, match_opcode
, 0 },
1061 {"fnmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FNMADD_Q
|MASK_RM
, MASK_FNMADD_Q
|MASK_RM
, match_opcode
, 0 },
1062 {"fnmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FNMADD_Q
, MASK_FNMADD_Q
, match_opcode
, 0 },
1063 {"fmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FMSUB_Q
|MASK_RM
, MASK_FMSUB_Q
|MASK_RM
, match_opcode
, 0 },
1064 {"fmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FMSUB_Q
, MASK_FMSUB_Q
, match_opcode
, 0 },
1065 {"fnmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FNMSUB_Q
|MASK_RM
, MASK_FNMSUB_Q
|MASK_RM
, match_opcode
, 0 },
1066 {"fnmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FNMSUB_Q
, MASK_FNMSUB_Q
, match_opcode
, 0 },
1067 {"fcvt.w.q", 0, INSN_CLASS_Q_INX
, "d,S", MATCH_FCVT_W_Q
|MASK_RM
, MASK_FCVT_W_Q
|MASK_RM
, match_opcode
, 0 },
1068 {"fcvt.w.q", 0, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_W_Q
, MASK_FCVT_W_Q
, match_opcode
, 0 },
1069 {"fcvt.wu.q", 0, INSN_CLASS_Q_INX
, "d,S", MATCH_FCVT_WU_Q
|MASK_RM
, MASK_FCVT_WU_Q
|MASK_RM
, match_opcode
, 0 },
1070 {"fcvt.wu.q", 0, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_WU_Q
, MASK_FCVT_WU_Q
, match_opcode
, 0 },
1071 {"fcvt.q.w", 0, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_W
, MASK_FCVT_Q_W
|MASK_RM
, match_opcode
, 0 },
1072 {"fcvt.q.wu", 0, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_WU
, MASK_FCVT_Q_WU
|MASK_RM
, match_opcode
, 0 },
1073 {"fcvt.q.s", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FCVT_Q_S
, MASK_FCVT_Q_S
|MASK_RM
, match_opcode
, 0 },
1074 {"fcvt.q.d", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FCVT_Q_D
, MASK_FCVT_Q_D
|MASK_RM
, match_opcode
, 0 },
1075 {"fcvt.s.q", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FCVT_S_Q
|MASK_RM
, MASK_FCVT_S_Q
|MASK_RM
, match_opcode
, 0 },
1076 {"fcvt.s.q", 0, INSN_CLASS_Q_INX
, "D,S,m", MATCH_FCVT_S_Q
, MASK_FCVT_S_Q
, match_opcode
, 0 },
1077 {"fcvt.d.q", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FCVT_D_Q
|MASK_RM
, MASK_FCVT_D_Q
|MASK_RM
, match_opcode
, 0 },
1078 {"fcvt.d.q", 0, INSN_CLASS_Q_INX
, "D,S,m", MATCH_FCVT_D_Q
, MASK_FCVT_D_Q
, match_opcode
, 0 },
1079 {"fclass.q", 0, INSN_CLASS_Q_INX
, "d,S", MATCH_FCLASS_Q
, MASK_FCLASS_Q
, match_opcode
, 0 },
1080 {"feq.q", 0, INSN_CLASS_Q_INX
, "d,S,T", MATCH_FEQ_Q
, MASK_FEQ_Q
, match_opcode
, 0 },
1081 {"flt.q", 0, INSN_CLASS_Q_INX
, "d,S,T", MATCH_FLT_Q
, MASK_FLT_Q
, match_opcode
, 0 },
1082 {"fle.q", 0, INSN_CLASS_Q_INX
, "d,S,T", MATCH_FLE_Q
, MASK_FLE_Q
, match_opcode
, 0 },
1083 {"fgt.q", 0, INSN_CLASS_Q_INX
, "d,T,S", MATCH_FLT_Q
, MASK_FLT_Q
, match_opcode
, 0 },
1084 {"fge.q", 0, INSN_CLASS_Q_INX
, "d,T,S", MATCH_FLE_Q
, MASK_FLE_Q
, match_opcode
, 0 },
1085 {"fcvt.l.q", 64, INSN_CLASS_Q_INX
, "d,S", MATCH_FCVT_L_Q
|MASK_RM
, MASK_FCVT_L_Q
|MASK_RM
, match_opcode
, 0 },
1086 {"fcvt.l.q", 64, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_L_Q
, MASK_FCVT_L_Q
, match_opcode
, 0 },
1087 {"fcvt.lu.q", 64, INSN_CLASS_Q_INX
, "d,S", MATCH_FCVT_LU_Q
|MASK_RM
, MASK_FCVT_LU_Q
|MASK_RM
, match_opcode
, 0 },
1088 {"fcvt.lu.q", 64, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_LU_Q
, MASK_FCVT_LU_Q
, match_opcode
, 0 },
1089 {"fcvt.q.l", 64, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_L
, MASK_FCVT_Q_L
|MASK_RM
, match_opcode
, 0 },
1090 {"fcvt.q.l", 64, INSN_CLASS_Q_INX
, "D,s,m", MATCH_FCVT_Q_L
, MASK_FCVT_Q_L
, match_opcode
, 0 },
1091 {"fcvt.q.lu", 64, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_LU
, MASK_FCVT_Q_LU
|MASK_RM
, match_opcode
, 0 },
1092 {"fcvt.q.lu", 64, INSN_CLASS_Q_INX
, "D,s,m", MATCH_FCVT_Q_LU
, MASK_FCVT_Q_LU
, match_opcode
, 0 },
1094 /* Compressed instructions. */
1095 {"c.unimp", 0, INSN_CLASS_C
, "", 0, 0xffffU
, match_opcode
, 0 },
1096 {"c.ebreak", 0, INSN_CLASS_C
, "", MATCH_C_EBREAK
, MASK_C_EBREAK
, match_opcode
, 0 },
1097 {"c.jr", 0, INSN_CLASS_C
, "d", MATCH_C_JR
, MASK_C_JR
, match_rd_nonzero
, INSN_BRANCH
},
1098 {"c.jalr", 0, INSN_CLASS_C
, "d", MATCH_C_JALR
, MASK_C_JALR
, match_rd_nonzero
, INSN_JSR
},
1099 {"c.j", 0, INSN_CLASS_C
, "Ca", MATCH_C_J
, MASK_C_J
, match_opcode
, INSN_BRANCH
},
1100 {"c.jal", 32, INSN_CLASS_C
, "Ca", MATCH_C_JAL
, MASK_C_JAL
, match_opcode
, INSN_JSR
},
1101 {"c.beqz", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BEQZ
, MASK_C_BEQZ
, match_opcode
, INSN_CONDBRANCH
},
1102 {"c.bnez", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BNEZ
, MASK_C_BNEZ
, match_opcode
, INSN_CONDBRANCH
},
1103 {"c.lwsp", 0, INSN_CLASS_C
, "d,Cm(Cc)", MATCH_C_LWSP
, MASK_C_LWSP
, match_rd_nonzero
, 0 },
1104 {"c.lw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_LW
, MASK_C_LW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1105 {"c.swsp", 0, INSN_CLASS_C
, "CV,CM(Cc)", MATCH_C_SWSP
, MASK_C_SWSP
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1106 {"c.sw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_SW
, MASK_C_SW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1107 {"c.nop", 0, INSN_CLASS_C
, "", MATCH_C_ADDI
, 0xffff, match_opcode
, INSN_ALIAS
},
1108 {"c.nop", 0, INSN_CLASS_C
, "Cj", MATCH_C_ADDI
, MASK_C_ADDI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1109 {"c.mv", 0, INSN_CLASS_C
, "d,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add_with_hint
, 0 },
1110 {"c.lui", 0, INSN_CLASS_C
, "d,Cu", MATCH_C_LUI
, MASK_C_LUI
, match_c_lui_with_hint
, 0 },
1111 {"c.li", 0, INSN_CLASS_C
, "d,Co", MATCH_C_LI
, MASK_C_LI
, match_opcode
, 0 },
1112 {"c.addi4spn", 0, INSN_CLASS_C
, "Ct,Cc,CK", MATCH_C_ADDI4SPN
, MASK_C_ADDI4SPN
, match_c_addi4spn
, 0 },
1113 {"c.addi16sp", 0, INSN_CLASS_C
, "Cc,CL", MATCH_C_ADDI16SP
, MASK_C_ADDI16SP
, match_c_addi16sp
, 0 },
1114 {"c.addi", 0, INSN_CLASS_C
, "d,Co", MATCH_C_ADDI
, MASK_C_ADDI
, match_opcode
, 0 },
1115 {"c.add", 0, INSN_CLASS_C
, "d,CV", MATCH_C_ADD
, MASK_C_ADD
, match_c_add_with_hint
, 0 },
1116 {"c.sub", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_SUB
, MASK_C_SUB
, match_opcode
, 0 },
1117 {"c.and", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_AND
, MASK_C_AND
, match_opcode
, 0 },
1118 {"c.or", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_OR
, MASK_C_OR
, match_opcode
, 0 },
1119 {"c.xor", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_XOR
, MASK_C_XOR
, match_opcode
, 0 },
1120 {"c.slli", 0, INSN_CLASS_C
, "d,C>", MATCH_C_SLLI
, MASK_C_SLLI
, match_c_slli
, 0 },
1121 {"c.srli", 0, INSN_CLASS_C
, "Cs,C>", MATCH_C_SRLI
, MASK_C_SRLI
, match_c_slli
, 0 },
1122 {"c.srai", 0, INSN_CLASS_C
, "Cs,C>", MATCH_C_SRAI
, MASK_C_SRAI
, match_c_slli
, 0 },
1123 {"c.slli64", 0, INSN_CLASS_C
, "d", MATCH_C_SLLI64
, MASK_C_SLLI64
, match_c_slli64
, 0 },
1124 {"c.srli64", 0, INSN_CLASS_C
, "Cs", MATCH_C_SRLI64
, MASK_C_SRLI64
, match_c_slli64
, 0 },
1125 {"c.srai64", 0, INSN_CLASS_C
, "Cs", MATCH_C_SRAI64
, MASK_C_SRAI64
, match_c_slli64
, 0 },
1126 {"c.andi", 0, INSN_CLASS_C
, "Cs,Co", MATCH_C_ANDI
, MASK_C_ANDI
, match_opcode
, 0 },
1127 {"c.addiw", 64, INSN_CLASS_C
, "d,Co", MATCH_C_ADDIW
, MASK_C_ADDIW
, match_rd_nonzero
, 0 },
1128 {"c.addw", 64, INSN_CLASS_C
, "Cs,Ct", MATCH_C_ADDW
, MASK_C_ADDW
, match_opcode
, 0 },
1129 {"c.subw", 64, INSN_CLASS_C
, "Cs,Ct", MATCH_C_SUBW
, MASK_C_SUBW
, match_opcode
, 0 },
1130 {"c.ldsp", 64, INSN_CLASS_C
, "d,Cn(Cc)", MATCH_C_LDSP
, MASK_C_LDSP
, match_rd_nonzero
, INSN_DREF
|INSN_8_BYTE
},
1131 {"c.ld", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_LD
, MASK_C_LD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1132 {"c.sdsp", 64, INSN_CLASS_C
, "CV,CN(Cc)", MATCH_C_SDSP
, MASK_C_SDSP
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1133 {"c.sd", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_SD
, MASK_C_SD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1134 {"c.fldsp", 0, INSN_CLASS_D_AND_C
, "D,Cn(Cc)", MATCH_C_FLDSP
, MASK_C_FLDSP
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1135 {"c.fld", 0, INSN_CLASS_D_AND_C
, "CD,Cl(Cs)", MATCH_C_FLD
, MASK_C_FLD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1136 {"c.fsdsp", 0, INSN_CLASS_D_AND_C
, "CT,CN(Cc)", MATCH_C_FSDSP
, MASK_C_FSDSP
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1137 {"c.fsd", 0, INSN_CLASS_D_AND_C
, "CD,Cl(Cs)", MATCH_C_FSD
, MASK_C_FSD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1138 {"c.flwsp", 32, INSN_CLASS_F_AND_C
, "D,Cm(Cc)", MATCH_C_FLWSP
, MASK_C_FLWSP
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1139 {"c.flw", 32, INSN_CLASS_F_AND_C
, "CD,Ck(Cs)", MATCH_C_FLW
, MASK_C_FLW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1140 {"c.fswsp", 32, INSN_CLASS_F_AND_C
, "CT,CM(Cc)", MATCH_C_FSWSP
, MASK_C_FSWSP
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1141 {"c.fsw", 32, INSN_CLASS_F_AND_C
, "CD,Ck(Cs)", MATCH_C_FSW
, MASK_C_FSW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1143 /* Zicbom and Zicboz instructions. */
1144 {"cbo.clean", 0, INSN_CLASS_ZICBOM
, "0(s)", MATCH_CBO_CLEAN
, MASK_CBO_CLEAN
, match_opcode
, 0 },
1145 {"cbo.flush", 0, INSN_CLASS_ZICBOM
, "0(s)", MATCH_CBO_FLUSH
, MASK_CBO_FLUSH
, match_opcode
, 0 },
1146 {"cbo.inval", 0, INSN_CLASS_ZICBOM
, "0(s)", MATCH_CBO_INVAL
, MASK_CBO_INVAL
, match_opcode
, 0 },
1147 {"cbo.zero", 0, INSN_CLASS_ZICBOZ
, "0(s)", MATCH_CBO_ZERO
, MASK_CBO_ZERO
, match_opcode
, 0 },
1149 /* Zicond instructions. */
1150 {"czero.eqz", 0, INSN_CLASS_ZICOND
, "d,s,t", MATCH_CZERO_EQZ
, MASK_CZERO_EQZ
, match_opcode
, 0 },
1151 {"czero.nez", 0, INSN_CLASS_ZICOND
, "d,s,t", MATCH_CZERO_NEZ
, MASK_CZERO_NEZ
, match_opcode
, 0 },
1153 /* Zimop instructions. */
1154 {"mop.r.0", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_0
, MASK_MOP_R_0
, match_opcode
, 0 },
1155 {"mop.r.1", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_1
, MASK_MOP_R_1
, match_opcode
, 0 },
1156 {"mop.r.2", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_2
, MASK_MOP_R_2
, match_opcode
, 0 },
1157 {"mop.r.3", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_3
, MASK_MOP_R_3
, match_opcode
, 0 },
1158 {"mop.r.4", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_4
, MASK_MOP_R_4
, match_opcode
, 0 },
1159 {"mop.r.5", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_5
, MASK_MOP_R_5
, match_opcode
, 0 },
1160 {"mop.r.6", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_6
, MASK_MOP_R_6
, match_opcode
, 0 },
1161 {"mop.r.7", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_7
, MASK_MOP_R_7
, match_opcode
, 0 },
1162 {"mop.r.8", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_8
, MASK_MOP_R_8
, match_opcode
, 0 },
1163 {"mop.r.9", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_9
, MASK_MOP_R_9
, match_opcode
, 0 },
1164 {"mop.r.10", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_10
, MASK_MOP_R_10
, match_opcode
, 0 },
1165 {"mop.r.11", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_11
, MASK_MOP_R_11
, match_opcode
, 0 },
1166 {"mop.r.12", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_12
, MASK_MOP_R_12
, match_opcode
, 0 },
1167 {"mop.r.13", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_13
, MASK_MOP_R_13
, match_opcode
, 0 },
1168 {"mop.r.14", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_14
, MASK_MOP_R_14
, match_opcode
, 0 },
1169 {"mop.r.15", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_15
, MASK_MOP_R_15
, match_opcode
, 0 },
1170 {"mop.r.16", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_16
, MASK_MOP_R_16
, match_opcode
, 0 },
1171 {"mop.r.17", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_17
, MASK_MOP_R_17
, match_opcode
, 0 },
1172 {"mop.r.18", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_18
, MASK_MOP_R_18
, match_opcode
, 0 },
1173 {"mop.r.19", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_19
, MASK_MOP_R_19
, match_opcode
, 0 },
1174 {"mop.r.20", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_20
, MASK_MOP_R_20
, match_opcode
, 0 },
1175 {"mop.r.21", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_21
, MASK_MOP_R_21
, match_opcode
, 0 },
1176 {"mop.r.22", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_22
, MASK_MOP_R_22
, match_opcode
, 0 },
1177 {"mop.r.23", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_23
, MASK_MOP_R_23
, match_opcode
, 0 },
1178 {"mop.r.24", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_24
, MASK_MOP_R_24
, match_opcode
, 0 },
1179 {"mop.r.25", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_25
, MASK_MOP_R_25
, match_opcode
, 0 },
1180 {"mop.r.26", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_26
, MASK_MOP_R_26
, match_opcode
, 0 },
1181 {"mop.r.27", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_27
, MASK_MOP_R_27
, match_opcode
, 0 },
1182 {"mop.r.28", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_28
, MASK_MOP_R_28
, match_opcode
, 0 },
1183 {"mop.r.29", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_29
, MASK_MOP_R_29
, match_opcode
, 0 },
1184 {"mop.r.30", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_30
, MASK_MOP_R_30
, match_opcode
, 0 },
1185 {"mop.r.31", 0, INSN_CLASS_ZIMOP
, "d,s", MATCH_MOP_R_31
, MASK_MOP_R_31
, match_opcode
, 0 },
1186 {"mop.rr.0", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_0
, MASK_MOP_RR_0
, match_opcode
, 0 },
1187 {"mop.rr.1", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_1
, MASK_MOP_RR_1
, match_opcode
, 0 },
1188 {"mop.rr.2", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_2
, MASK_MOP_RR_2
, match_opcode
, 0 },
1189 {"mop.rr.3", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_3
, MASK_MOP_RR_3
, match_opcode
, 0 },
1190 {"mop.rr.4", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_4
, MASK_MOP_RR_4
, match_opcode
, 0 },
1191 {"mop.rr.5", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_5
, MASK_MOP_RR_5
, match_opcode
, 0 },
1192 {"mop.rr.6", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_6
, MASK_MOP_RR_6
, match_opcode
, 0 },
1193 {"mop.rr.7", 0, INSN_CLASS_ZIMOP
, "d,s,t", MATCH_MOP_RR_7
, MASK_MOP_RR_7
, match_opcode
, 0 },
1195 /* Zawrs instructions. */
1196 {"wrs.nto", 0, INSN_CLASS_ZAWRS
, "", MATCH_WRS_NTO
, MASK_WRS_NTO
, match_opcode
, 0 },
1197 {"wrs.sto", 0, INSN_CLASS_ZAWRS
, "", MATCH_WRS_STO
, MASK_WRS_STO
, match_opcode
, 0 },
1199 /* Zfa instructions. */
1200 {"fli.s", 0, INSN_CLASS_ZFA
, "D,Wfv", MATCH_FLI_S
, MASK_FLI_S
, match_opcode
, 0 },
1201 {"fli.d", 0, INSN_CLASS_D_AND_ZFA
, "D,Wfv", MATCH_FLI_D
, MASK_FLI_D
, match_opcode
, 0 },
1202 {"fli.q", 0, INSN_CLASS_Q_AND_ZFA
, "D,Wfv", MATCH_FLI_Q
, MASK_FLI_Q
, match_opcode
, 0 },
1203 {"fli.h", 0, INSN_CLASS_ZFH_OR_ZVFH_AND_ZFA
, "D,Wfv", MATCH_FLI_H
, MASK_FLI_H
, match_opcode
, 0 },
1204 {"fminm.s", 0, INSN_CLASS_ZFA
, "D,S,T", MATCH_FMINM_S
, MASK_FMINM_S
, match_opcode
, 0 },
1205 {"fmaxm.s", 0, INSN_CLASS_ZFA
, "D,S,T", MATCH_FMAXM_S
, MASK_FMAXM_S
, match_opcode
, 0 },
1206 {"fminm.d", 0, INSN_CLASS_D_AND_ZFA
, "D,S,T", MATCH_FMINM_D
, MASK_FMINM_D
, match_opcode
, 0 },
1207 {"fmaxm.d", 0, INSN_CLASS_D_AND_ZFA
, "D,S,T", MATCH_FMAXM_D
, MASK_FMAXM_D
, match_opcode
, 0 },
1208 {"fminm.q", 0, INSN_CLASS_Q_AND_ZFA
, "D,S,T", MATCH_FMINM_Q
, MASK_FMINM_Q
, match_opcode
, 0 },
1209 {"fmaxm.q", 0, INSN_CLASS_Q_AND_ZFA
, "D,S,T", MATCH_FMAXM_Q
, MASK_FMAXM_Q
, match_opcode
, 0 },
1210 {"fminm.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "D,S,T", MATCH_FMINM_H
, MASK_FMINM_H
, match_opcode
, 0 },
1211 {"fmaxm.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "D,S,T", MATCH_FMAXM_H
, MASK_FMAXM_H
, match_opcode
, 0 },
1212 {"fround.s", 0, INSN_CLASS_ZFA
, "D,S", MATCH_FROUND_S
|MASK_RM
, MASK_FROUND_S
|MASK_RM
, match_opcode
, 0 },
1213 {"fround.s", 0, INSN_CLASS_ZFA
, "D,S,m", MATCH_FROUND_S
, MASK_FROUND_S
, match_opcode
, 0 },
1214 {"froundnx.s", 0, INSN_CLASS_ZFA
, "D,S", MATCH_FROUNDNX_S
|MASK_RM
, MASK_FROUNDNX_S
|MASK_RM
, match_opcode
, 0 },
1215 {"froundnx.s", 0, INSN_CLASS_ZFA
, "D,S,m", MATCH_FROUNDNX_S
, MASK_FROUNDNX_S
, match_opcode
, 0 },
1216 {"fround.d", 0, INSN_CLASS_D_AND_ZFA
, "D,S", MATCH_FROUND_D
|MASK_RM
, MASK_FROUND_D
|MASK_RM
, match_opcode
, 0 },
1217 {"fround.d", 0, INSN_CLASS_D_AND_ZFA
, "D,S,m", MATCH_FROUND_D
, MASK_FROUND_D
, match_opcode
, 0 },
1218 {"froundnx.d", 0, INSN_CLASS_D_AND_ZFA
, "D,S", MATCH_FROUNDNX_D
|MASK_RM
, MASK_FROUNDNX_D
|MASK_RM
, match_opcode
, 0 },
1219 {"froundnx.d", 0, INSN_CLASS_D_AND_ZFA
, "D,S,m", MATCH_FROUNDNX_D
, MASK_FROUNDNX_D
, match_opcode
, 0 },
1220 {"fround.q", 0, INSN_CLASS_Q_AND_ZFA
, "D,S", MATCH_FROUND_Q
|MASK_RM
, MASK_FROUND_Q
|MASK_RM
, match_opcode
, 0 },
1221 {"fround.q", 0, INSN_CLASS_Q_AND_ZFA
, "D,S,m", MATCH_FROUND_Q
, MASK_FROUND_Q
, match_opcode
, 0 },
1222 {"froundnx.q", 0, INSN_CLASS_Q_AND_ZFA
, "D,S", MATCH_FROUNDNX_Q
|MASK_RM
, MASK_FROUNDNX_Q
|MASK_RM
, match_opcode
, 0 },
1223 {"froundnx.q", 0, INSN_CLASS_Q_AND_ZFA
, "D,S,m", MATCH_FROUNDNX_Q
, MASK_FROUNDNX_Q
, match_opcode
, 0 },
1224 {"fround.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "D,S", MATCH_FROUND_H
|MASK_RM
, MASK_FROUND_H
|MASK_RM
, match_opcode
, 0 },
1225 {"fround.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "D,S,m", MATCH_FROUND_H
, MASK_FROUND_H
, match_opcode
, 0 },
1226 {"froundnx.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "D,S", MATCH_FROUNDNX_H
|MASK_RM
, MASK_FROUNDNX_H
|MASK_RM
, match_opcode
, 0 },
1227 {"froundnx.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "D,S,m", MATCH_FROUNDNX_H
, MASK_FROUNDNX_H
, match_opcode
, 0 },
1228 {"fcvtmod.w.d", 0, INSN_CLASS_D_AND_ZFA
, "d,S,m", MATCH_FCVTMOD_W_D
, MASK_FCVTMOD_W_D
, match_opcode
, 0 },
1229 {"fmvh.x.d", 32, INSN_CLASS_D_AND_ZFA
, "d,S", MATCH_FMVH_X_D
, MASK_FMVH_X_D
, match_opcode
, 0 },
1230 {"fmvp.d.x", 32, INSN_CLASS_D_AND_ZFA
, "D,s,t", MATCH_FMVP_D_X
, MASK_FMVP_D_X
, match_opcode
, 0 },
1231 {"fmvh.x.q", 64, INSN_CLASS_Q_AND_ZFA
, "d,S", MATCH_FMVH_X_Q
, MASK_FMVH_X_Q
, match_opcode
, 0 },
1232 {"fmvp.q.x", 64, INSN_CLASS_Q_AND_ZFA
, "D,s,t", MATCH_FMVP_Q_X
, MASK_FMVP_Q_X
, match_opcode
, 0 },
1233 {"fltq.s", 0, INSN_CLASS_ZFA
, "d,S,T", MATCH_FLTQ_S
, MASK_FLTQ_S
, match_opcode
, 0 },
1234 {"fleq.s", 0, INSN_CLASS_ZFA
, "d,S,T", MATCH_FLEQ_S
, MASK_FLEQ_S
, match_opcode
, 0 },
1235 {"fltq.d", 0, INSN_CLASS_D_AND_ZFA
, "d,S,T", MATCH_FLTQ_D
, MASK_FLTQ_D
, match_opcode
, 0 },
1236 {"fleq.d", 0, INSN_CLASS_D_AND_ZFA
, "d,S,T", MATCH_FLEQ_D
, MASK_FLEQ_D
, match_opcode
, 0 },
1237 {"fltq.q", 0, INSN_CLASS_Q_AND_ZFA
, "d,S,T", MATCH_FLTQ_Q
, MASK_FLTQ_Q
, match_opcode
, 0 },
1238 {"fleq.q", 0, INSN_CLASS_Q_AND_ZFA
, "d,S,T", MATCH_FLEQ_Q
, MASK_FLEQ_Q
, match_opcode
, 0 },
1239 {"fltq.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "d,S,T", MATCH_FLTQ_H
, MASK_FLTQ_H
, match_opcode
, 0 },
1240 {"fleq.h", 0, INSN_CLASS_ZFH_AND_ZFA
, "d,S,T", MATCH_FLEQ_H
, MASK_FLEQ_H
, match_opcode
, 0 },
1242 /* Zbb or zbkb instructions. */
1243 {"clz", 0, INSN_CLASS_ZBB
, "d,s", MATCH_CLZ
, MASK_CLZ
, match_opcode
, 0 },
1244 {"ctz", 0, INSN_CLASS_ZBB
, "d,s", MATCH_CTZ
, MASK_CTZ
, match_opcode
, 0 },
1245 {"cpop", 0, INSN_CLASS_ZBB
, "d,s", MATCH_CPOP
, MASK_CPOP
, match_opcode
, 0 },
1246 {"min", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MIN
, MASK_MIN
, match_opcode
, 0 },
1247 {"max", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MAX
, MASK_MAX
, match_opcode
, 0 },
1248 {"minu", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MINU
, MASK_MINU
, match_opcode
, 0 },
1249 {"maxu", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MAXU
, MASK_MAXU
, match_opcode
, 0 },
1250 {"sext.b", 0, INSN_CLASS_ZCB_AND_ZBB
, "Cs,Cw", MATCH_C_SEXT_B
, MASK_C_SEXT_B
, match_opcode
, INSN_ALIAS
},
1251 {"sext.b", 0, INSN_CLASS_ZBB
, "d,s", MATCH_SEXT_B
, MASK_SEXT_B
, match_opcode
, 0 },
1252 {"sext.b", 0, INSN_CLASS_I
, "d,s", 0, (int) M_SEXTB
, NULL
, INSN_MACRO
},
1253 {"sext.h", 0, INSN_CLASS_ZCB_AND_ZBB
, "Cs,Cw", MATCH_C_SEXT_H
, MASK_C_SEXT_H
, match_opcode
, INSN_ALIAS
},
1254 {"sext.h", 0, INSN_CLASS_ZBB
, "d,s", MATCH_SEXT_H
, MASK_SEXT_H
, match_opcode
, 0 },
1255 {"sext.h", 0, INSN_CLASS_I
, "d,s", 0, (int) M_EXTH
, NULL
, INSN_MACRO
},
1256 {"zext.h", 0, INSN_CLASS_ZCB_AND_ZBB
, "Cs,Cw", MATCH_C_ZEXT_H
, MASK_C_ZEXT_H
, match_opcode
, INSN_ALIAS
},
1257 {"zext.h", 32, INSN_CLASS_ZBB_OR_ZBKB
, "d,s", MATCH_PACK
, MASK_PACK
| MASK_RS2
, match_opcode
, 0 },
1258 {"zext.h", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s", MATCH_PACKW
, MASK_PACKW
| MASK_RS2
, match_opcode
, 0 },
1259 {"zext.h", 0, INSN_CLASS_I
, "d,s", 0, (int) M_EXTH
, NULL
, INSN_MACRO
},
1260 {"orc.b", 0, INSN_CLASS_ZBB
, "d,s", MATCH_GORCI
| MATCH_SHAMT_ORC_B
, MASK_GORCI
| MASK_SHAMT
, match_opcode
, 0 },
1261 {"clzw", 64, INSN_CLASS_ZBB
, "d,s", MATCH_CLZW
, MASK_CLZW
, match_opcode
, 0 },
1262 {"ctzw", 64, INSN_CLASS_ZBB
, "d,s", MATCH_CTZW
, MASK_CTZW
, match_opcode
, 0 },
1263 {"cpopw", 64, INSN_CLASS_ZBB
, "d,s", MATCH_CPOPW
, MASK_CPOPW
, match_opcode
, 0 },
1264 {"brev8", 32, INSN_CLASS_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_BREV8
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
1265 {"brev8", 64, INSN_CLASS_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_BREV8
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
1266 {"zip", 32, INSN_CLASS_ZBKB
, "d,s", MATCH_SHFLI
|MATCH_SHAMT_ZIP_32
, MASK_SHFLI
|MASK_SHAMT
, match_opcode
, 0 },
1267 {"unzip", 32, INSN_CLASS_ZBKB
, "d,s", MATCH_UNSHFLI
|MATCH_SHAMT_ZIP_32
, MASK_UNSHFLI
|MASK_SHAMT
, match_opcode
, 0 },
1268 {"pack", 0, INSN_CLASS_ZBKB
, "d,s,t", MATCH_PACK
, MASK_PACK
, match_opcode
, 0 },
1269 {"packh", 0, INSN_CLASS_ZBKB
, "d,s,t", MATCH_PACKH
, MASK_PACKH
, match_opcode
, 0 },
1270 {"packw", 64, INSN_CLASS_ZBKB
, "d,s,t", MATCH_PACKW
, MASK_PACKW
, match_opcode
, 0 },
1271 {"andn", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ANDN
, MASK_ANDN
, match_opcode
, 0 },
1272 {"orn", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ORN
, MASK_ORN
, match_opcode
, 0 },
1273 {"xnor", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_XNOR
, MASK_XNOR
, match_opcode
, 0 },
1274 {"rol", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ROL
, MASK_ROL
, match_opcode
, 0 },
1275 {"rori", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,>", MATCH_RORI
, MASK_RORI
, match_opcode
, 0 },
1276 {"ror", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ROR
, MASK_ROR
, match_opcode
, 0 },
1277 {"ror", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,>", MATCH_RORI
, MASK_RORI
, match_opcode
, INSN_ALIAS
},
1278 {"rev8", 32, INSN_CLASS_ZBB_OR_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_REV8_32
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
1279 {"rev8", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_REV8_64
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
1280 {"rolw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ROLW
, MASK_ROLW
, match_opcode
, 0 },
1281 {"roriw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,<", MATCH_RORIW
, MASK_RORIW
, match_opcode
, 0 },
1282 {"rorw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_RORW
, MASK_RORW
, match_opcode
, 0 },
1283 {"rorw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,<", MATCH_RORIW
, MASK_RORIW
, match_opcode
, INSN_ALIAS
},
1285 /* Zba instructions. */
1286 {"sh1add", 0, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH1ADD
, MASK_SH1ADD
, match_opcode
, 0 },
1287 {"sh2add", 0, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH2ADD
, MASK_SH2ADD
, match_opcode
, 0 },
1288 {"sh3add", 0, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH3ADD
, MASK_SH3ADD
, match_opcode
, 0 },
1289 {"sh1add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH1ADD_UW
, MASK_SH1ADD_UW
, match_opcode
, 0 },
1290 {"sh2add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH2ADD_UW
, MASK_SH2ADD_UW
, match_opcode
, 0 },
1291 {"sh3add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH3ADD_UW
, MASK_SH3ADD_UW
, match_opcode
, 0 },
1292 {"zext.w", 64, INSN_CLASS_ZCB_AND_ZBA
, "Cs,Cw", MATCH_C_ZEXT_W
, MASK_C_ZEXT_W
, match_opcode
, INSN_ALIAS
},
1293 {"zext.w", 64, INSN_CLASS_ZBA
, "d,s", MATCH_ADD_UW
, MASK_ADD_UW
| MASK_RS2
, match_opcode
, INSN_ALIAS
},
1294 {"zext.w", 64, INSN_CLASS_I
, "d,s", 0, (int) M_ZEXTW
, NULL
, INSN_MACRO
},
1295 {"add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_ADD_UW
, MASK_ADD_UW
, match_opcode
, 0 },
1296 {"slli.uw", 64, INSN_CLASS_ZBA
, "d,s,>", MATCH_SLLI_UW
, MASK_SLLI_UW
, match_opcode
, 0 },
1298 /* Zbc or zbkc instructions. */
1299 {"clmul", 0, INSN_CLASS_ZBC_OR_ZBKC
, "d,s,t", MATCH_CLMUL
, MASK_CLMUL
, match_opcode
, 0 },
1300 {"clmulh", 0, INSN_CLASS_ZBC_OR_ZBKC
, "d,s,t", MATCH_CLMULH
, MASK_CLMULH
, match_opcode
, 0 },
1301 {"clmulr", 0, INSN_CLASS_ZBC
, "d,s,t", MATCH_CLMULR
, MASK_CLMULR
, match_opcode
, 0 },
1303 /* Zbs instructions. */
1304 {"bclri", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BCLRI
, MASK_BCLRI
, match_opcode
, 0 },
1305 {"bclr", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BCLR
, MASK_BCLR
, match_opcode
, 0 },
1306 {"bclr", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BCLRI
, MASK_BCLRI
, match_opcode
, INSN_ALIAS
},
1307 {"bseti", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BSETI
, MASK_BSETI
, match_opcode
, 0 },
1308 {"bset", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BSET
, MASK_BSET
, match_opcode
, 0 },
1309 {"bset", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BSETI
, MASK_BSETI
, match_opcode
, INSN_ALIAS
},
1310 {"binvi", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BINVI
, MASK_BINVI
, match_opcode
, 0 },
1311 {"binv", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BINV
, MASK_BINV
, match_opcode
, 0 },
1312 {"binv", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BINVI
, MASK_BINVI
, match_opcode
, INSN_ALIAS
},
1313 {"bexti", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BEXTI
, MASK_BEXTI
, match_opcode
, 0 },
1314 {"bext", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BEXT
, MASK_BEXT
, match_opcode
, 0 },
1315 {"bext", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BEXTI
, MASK_BEXTI
, match_opcode
, INSN_ALIAS
},
1317 /* Zbkx instructions. */
1318 {"xperm4", 0, INSN_CLASS_ZBKX
, "d,s,t", MATCH_XPERM4
, MASK_XPERM4
, match_opcode
, 0 },
1319 {"xperm8", 0, INSN_CLASS_ZBKX
, "d,s,t", MATCH_XPERM8
, MASK_XPERM8
, match_opcode
, 0 },
1321 /* Zknd instructions. */
1322 {"aes32dsi", 32, INSN_CLASS_ZKND
, "d,s,t,y", MATCH_AES32DSI
, MASK_AES32DSI
, match_opcode
, 0 },
1323 {"aes32dsmi", 32, INSN_CLASS_ZKND
, "d,s,t,y", MATCH_AES32DSMI
, MASK_AES32DSMI
, match_opcode
, 0 },
1324 {"aes64ds", 64, INSN_CLASS_ZKND
, "d,s,t", MATCH_AES64DS
, MASK_AES64DS
, match_opcode
, 0 },
1325 {"aes64dsm", 64, INSN_CLASS_ZKND
, "d,s,t", MATCH_AES64DSM
, MASK_AES64DSM
, match_opcode
, 0 },
1326 {"aes64im", 64, INSN_CLASS_ZKND
, "d,s", MATCH_AES64IM
, MASK_AES64IM
, match_opcode
, 0 },
1327 {"aes64ks1i", 64, INSN_CLASS_ZKND_OR_ZKNE
, "d,s,Y", MATCH_AES64KS1I
, MASK_AES64KS1I
, match_opcode
, 0 },
1328 {"aes64ks2", 64, INSN_CLASS_ZKND_OR_ZKNE
, "d,s,t", MATCH_AES64KS2
, MASK_AES64KS2
, match_opcode
, 0 },
1330 /* Zkne instructions. */
1331 {"aes32esi", 32, INSN_CLASS_ZKNE
, "d,s,t,y", MATCH_AES32ESI
, MASK_AES32ESI
, match_opcode
, 0 },
1332 {"aes32esmi", 32, INSN_CLASS_ZKNE
, "d,s,t,y", MATCH_AES32ESMI
, MASK_AES32ESMI
, match_opcode
, 0 },
1333 {"aes64es", 64, INSN_CLASS_ZKNE
, "d,s,t", MATCH_AES64ES
, MASK_AES64ES
, match_opcode
, 0 },
1334 {"aes64esm", 64, INSN_CLASS_ZKNE
, "d,s,t", MATCH_AES64ESM
, MASK_AES64ESM
, match_opcode
, 0 },
1336 /* Zknh instructions. */
1337 {"sha256sig0", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SIG0
, MASK_SHA256SIG0
, match_opcode
, 0 },
1338 {"sha256sig1", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SIG1
, MASK_SHA256SIG1
, match_opcode
, 0 },
1339 {"sha256sum0", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SUM0
, MASK_SHA256SUM0
, match_opcode
, 0 },
1340 {"sha256sum1", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SUM1
, MASK_SHA256SUM1
, match_opcode
, 0 },
1341 {"sha512sig0h", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG0H
, MASK_SHA512SIG0H
, match_opcode
, 0 },
1342 {"sha512sig0l", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG0L
, MASK_SHA512SIG0L
, match_opcode
, 0 },
1343 {"sha512sig1h", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG1H
, MASK_SHA512SIG1H
, match_opcode
, 0 },
1344 {"sha512sig1l", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG1L
, MASK_SHA512SIG1L
, match_opcode
, 0 },
1345 {"sha512sum0r", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SUM0R
, MASK_SHA512SUM0R
, match_opcode
, 0 },
1346 {"sha512sum1r", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SUM1R
, MASK_SHA512SUM1R
, match_opcode
, 0 },
1347 {"sha512sig0", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SIG0
, MASK_SHA512SIG0
, match_opcode
, 0 },
1348 {"sha512sig1", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SIG1
, MASK_SHA512SIG1
, match_opcode
, 0 },
1349 {"sha512sum0", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SUM0
, MASK_SHA512SUM0
, match_opcode
, 0 },
1350 {"sha512sum1", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SUM1
, MASK_SHA512SUM1
, match_opcode
, 0 },
1352 /* Zksed instructions. */
1353 {"sm4ed", 0, INSN_CLASS_ZKSED
, "d,s,t,y", MATCH_SM4ED
, MASK_SM4ED
, match_opcode
, 0 },
1354 {"sm4ks", 0, INSN_CLASS_ZKSED
, "d,s,t,y", MATCH_SM4KS
, MASK_SM4KS
, match_opcode
, 0 },
1356 /* Zksh instructions */
1357 {"sm3p0", 0, INSN_CLASS_ZKSH
, "d,s", MATCH_SM3P0
, MASK_SM3P0
, match_opcode
, 0 },
1358 {"sm3p1", 0, INSN_CLASS_ZKSH
, "d,s", MATCH_SM3P1
, MASK_SM3P1
, match_opcode
, 0 },
1360 /* RVV instructions. */
1361 {"vsetvl", 0, INSN_CLASS_V
, "d,s,t", MATCH_VSETVL
, MASK_VSETVL
, match_opcode
, 0},
1362 {"vsetvli", 0, INSN_CLASS_V
, "d,s,Vc", MATCH_VSETVLI
, MASK_VSETVLI
, match_opcode
, 0},
1363 {"vsetivli", 0, INSN_CLASS_V
, "d,Z,Vb", MATCH_VSETIVLI
, MASK_VSETIVLI
, match_opcode
, 0},
1365 {"vlm.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VLMV
, MASK_VLMV
, match_opcode
, INSN_DREF
},
1366 {"vsm.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VSMV
, MASK_VSMV
, match_opcode
, INSN_DREF
},
1367 {"vle1.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VLMV
, MASK_VLMV
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1368 {"vse1.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VSMV
, MASK_VSMV
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1370 {"vle8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE8V
, MASK_VLE8V
, match_opcode
, INSN_DREF
},
1371 {"vle16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE16V
, MASK_VLE16V
, match_opcode
, INSN_DREF
},
1372 {"vle32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE32V
, MASK_VLE32V
, match_opcode
, INSN_DREF
},
1373 {"vle64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE64V
, MASK_VLE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1375 {"vse8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE8V
, MASK_VSE8V
, match_opcode
, INSN_DREF
},
1376 {"vse16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE16V
, MASK_VSE16V
, match_opcode
, INSN_DREF
},
1377 {"vse32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE32V
, MASK_VSE32V
, match_opcode
, INSN_DREF
},
1378 {"vse64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE64V
, MASK_VSE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1380 {"vlse8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE8V
, MASK_VLSE8V
, match_opcode
, INSN_DREF
},
1381 {"vlse16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE16V
, MASK_VLSE16V
, match_opcode
, INSN_DREF
},
1382 {"vlse32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE32V
, MASK_VLSE32V
, match_opcode
, INSN_DREF
},
1383 {"vlse64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE64V
, MASK_VLSE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1385 {"vsse8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE8V
, MASK_VSSE8V
, match_opcode
, INSN_DREF
},
1386 {"vsse16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE16V
, MASK_VSSE16V
, match_opcode
, INSN_DREF
},
1387 {"vsse32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE32V
, MASK_VSSE32V
, match_opcode
, INSN_DREF
},
1388 {"vsse64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE64V
, MASK_VSSE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1390 {"vloxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI8V
, MASK_VLOXEI8V
, match_opcode
, INSN_DREF
},
1391 {"vloxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI16V
, MASK_VLOXEI16V
, match_opcode
, INSN_DREF
},
1392 {"vloxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI32V
, MASK_VLOXEI32V
, match_opcode
, INSN_DREF
},
1393 {"vloxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI64V
, MASK_VLOXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1395 {"vsoxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI8V
, MASK_VSOXEI8V
, match_opcode
, INSN_DREF
},
1396 {"vsoxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI16V
, MASK_VSOXEI16V
, match_opcode
, INSN_DREF
},
1397 {"vsoxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI32V
, MASK_VSOXEI32V
, match_opcode
, INSN_DREF
},
1398 {"vsoxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI64V
, MASK_VSOXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1400 {"vluxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI8V
, MASK_VLUXEI8V
, match_opcode
, INSN_DREF
},
1401 {"vluxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI16V
, MASK_VLUXEI16V
, match_opcode
, INSN_DREF
},
1402 {"vluxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI32V
, MASK_VLUXEI32V
, match_opcode
, INSN_DREF
},
1403 {"vluxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI64V
, MASK_VLUXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1405 {"vsuxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI8V
, MASK_VSUXEI8V
, match_opcode
, INSN_DREF
},
1406 {"vsuxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI16V
, MASK_VSUXEI16V
, match_opcode
, INSN_DREF
},
1407 {"vsuxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI32V
, MASK_VSUXEI32V
, match_opcode
, INSN_DREF
},
1408 {"vsuxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI64V
, MASK_VSUXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1410 {"vle8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE8FFV
, MASK_VLE8FFV
, match_opcode
, INSN_DREF
},
1411 {"vle16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE16FFV
, MASK_VLE16FFV
, match_opcode
, INSN_DREF
},
1412 {"vle32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE32FFV
, MASK_VLE32FFV
, match_opcode
, INSN_DREF
},
1413 {"vle64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE64FFV
, MASK_VLE64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1415 {"vlseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E8V
, MASK_VLSEG2E8V
, match_opcode
, INSN_DREF
},
1416 {"vsseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E8V
, MASK_VSSEG2E8V
, match_opcode
, INSN_DREF
},
1417 {"vlseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E8V
, MASK_VLSEG3E8V
, match_opcode
, INSN_DREF
},
1418 {"vsseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E8V
, MASK_VSSEG3E8V
, match_opcode
, INSN_DREF
},
1419 {"vlseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E8V
, MASK_VLSEG4E8V
, match_opcode
, INSN_DREF
},
1420 {"vsseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E8V
, MASK_VSSEG4E8V
, match_opcode
, INSN_DREF
},
1421 {"vlseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E8V
, MASK_VLSEG5E8V
, match_opcode
, INSN_DREF
},
1422 {"vsseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E8V
, MASK_VSSEG5E8V
, match_opcode
, INSN_DREF
},
1423 {"vlseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E8V
, MASK_VLSEG6E8V
, match_opcode
, INSN_DREF
},
1424 {"vsseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E8V
, MASK_VSSEG6E8V
, match_opcode
, INSN_DREF
},
1425 {"vlseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E8V
, MASK_VLSEG7E8V
, match_opcode
, INSN_DREF
},
1426 {"vsseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E8V
, MASK_VSSEG7E8V
, match_opcode
, INSN_DREF
},
1427 {"vlseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E8V
, MASK_VLSEG8E8V
, match_opcode
, INSN_DREF
},
1428 {"vsseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E8V
, MASK_VSSEG8E8V
, match_opcode
, INSN_DREF
},
1430 {"vlseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E16V
, MASK_VLSEG2E16V
, match_opcode
, INSN_DREF
},
1431 {"vsseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E16V
, MASK_VSSEG2E16V
, match_opcode
, INSN_DREF
},
1432 {"vlseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E16V
, MASK_VLSEG3E16V
, match_opcode
, INSN_DREF
},
1433 {"vsseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E16V
, MASK_VSSEG3E16V
, match_opcode
, INSN_DREF
},
1434 {"vlseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E16V
, MASK_VLSEG4E16V
, match_opcode
, INSN_DREF
},
1435 {"vsseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E16V
, MASK_VSSEG4E16V
, match_opcode
, INSN_DREF
},
1436 {"vlseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E16V
, MASK_VLSEG5E16V
, match_opcode
, INSN_DREF
},
1437 {"vsseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E16V
, MASK_VSSEG5E16V
, match_opcode
, INSN_DREF
},
1438 {"vlseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E16V
, MASK_VLSEG6E16V
, match_opcode
, INSN_DREF
},
1439 {"vsseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E16V
, MASK_VSSEG6E16V
, match_opcode
, INSN_DREF
},
1440 {"vlseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E16V
, MASK_VLSEG7E16V
, match_opcode
, INSN_DREF
},
1441 {"vsseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E16V
, MASK_VSSEG7E16V
, match_opcode
, INSN_DREF
},
1442 {"vlseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E16V
, MASK_VLSEG8E16V
, match_opcode
, INSN_DREF
},
1443 {"vsseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E16V
, MASK_VSSEG8E16V
, match_opcode
, INSN_DREF
},
1445 {"vlseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E32V
, MASK_VLSEG2E32V
, match_opcode
, INSN_DREF
},
1446 {"vsseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E32V
, MASK_VSSEG2E32V
, match_opcode
, INSN_DREF
},
1447 {"vlseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E32V
, MASK_VLSEG3E32V
, match_opcode
, INSN_DREF
},
1448 {"vsseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E32V
, MASK_VSSEG3E32V
, match_opcode
, INSN_DREF
},
1449 {"vlseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E32V
, MASK_VLSEG4E32V
, match_opcode
, INSN_DREF
},
1450 {"vsseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E32V
, MASK_VSSEG4E32V
, match_opcode
, INSN_DREF
},
1451 {"vlseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E32V
, MASK_VLSEG5E32V
, match_opcode
, INSN_DREF
},
1452 {"vsseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E32V
, MASK_VSSEG5E32V
, match_opcode
, INSN_DREF
},
1453 {"vlseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E32V
, MASK_VLSEG6E32V
, match_opcode
, INSN_DREF
},
1454 {"vsseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E32V
, MASK_VSSEG6E32V
, match_opcode
, INSN_DREF
},
1455 {"vlseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E32V
, MASK_VLSEG7E32V
, match_opcode
, INSN_DREF
},
1456 {"vsseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E32V
, MASK_VSSEG7E32V
, match_opcode
, INSN_DREF
},
1457 {"vlseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E32V
, MASK_VLSEG8E32V
, match_opcode
, INSN_DREF
},
1458 {"vsseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E32V
, MASK_VSSEG8E32V
, match_opcode
, INSN_DREF
},
1460 {"vlseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E64V
, MASK_VLSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1461 {"vsseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E64V
, MASK_VSSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1462 {"vlseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E64V
, MASK_VLSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1463 {"vsseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E64V
, MASK_VSSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1464 {"vlseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E64V
, MASK_VLSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1465 {"vsseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E64V
, MASK_VSSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1466 {"vlseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E64V
, MASK_VLSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1467 {"vsseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E64V
, MASK_VSSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1468 {"vlseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E64V
, MASK_VLSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1469 {"vsseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E64V
, MASK_VSSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1470 {"vlseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E64V
, MASK_VLSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1471 {"vsseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E64V
, MASK_VSSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1472 {"vlseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E64V
, MASK_VLSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1473 {"vsseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E64V
, MASK_VSSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1475 {"vlsseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E8V
, MASK_VLSSEG2E8V
, match_opcode
, INSN_DREF
},
1476 {"vssseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E8V
, MASK_VSSSEG2E8V
, match_opcode
, INSN_DREF
},
1477 {"vlsseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E8V
, MASK_VLSSEG3E8V
, match_opcode
, INSN_DREF
},
1478 {"vssseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E8V
, MASK_VSSSEG3E8V
, match_opcode
, INSN_DREF
},
1479 {"vlsseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E8V
, MASK_VLSSEG4E8V
, match_opcode
, INSN_DREF
},
1480 {"vssseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E8V
, MASK_VSSSEG4E8V
, match_opcode
, INSN_DREF
},
1481 {"vlsseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E8V
, MASK_VLSSEG5E8V
, match_opcode
, INSN_DREF
},
1482 {"vssseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E8V
, MASK_VSSSEG5E8V
, match_opcode
, INSN_DREF
},
1483 {"vlsseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E8V
, MASK_VLSSEG6E8V
, match_opcode
, INSN_DREF
},
1484 {"vssseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E8V
, MASK_VSSSEG6E8V
, match_opcode
, INSN_DREF
},
1485 {"vlsseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E8V
, MASK_VLSSEG7E8V
, match_opcode
, INSN_DREF
},
1486 {"vssseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E8V
, MASK_VSSSEG7E8V
, match_opcode
, INSN_DREF
},
1487 {"vlsseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E8V
, MASK_VLSSEG8E8V
, match_opcode
, INSN_DREF
},
1488 {"vssseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E8V
, MASK_VSSSEG8E8V
, match_opcode
, INSN_DREF
},
1490 {"vlsseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E16V
, MASK_VLSSEG2E16V
, match_opcode
, INSN_DREF
},
1491 {"vssseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E16V
, MASK_VSSSEG2E16V
, match_opcode
, INSN_DREF
},
1492 {"vlsseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E16V
, MASK_VLSSEG3E16V
, match_opcode
, INSN_DREF
},
1493 {"vssseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E16V
, MASK_VSSSEG3E16V
, match_opcode
, INSN_DREF
},
1494 {"vlsseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E16V
, MASK_VLSSEG4E16V
, match_opcode
, INSN_DREF
},
1495 {"vssseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E16V
, MASK_VSSSEG4E16V
, match_opcode
, INSN_DREF
},
1496 {"vlsseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E16V
, MASK_VLSSEG5E16V
, match_opcode
, INSN_DREF
},
1497 {"vssseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E16V
, MASK_VSSSEG5E16V
, match_opcode
, INSN_DREF
},
1498 {"vlsseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E16V
, MASK_VLSSEG6E16V
, match_opcode
, INSN_DREF
},
1499 {"vssseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E16V
, MASK_VSSSEG6E16V
, match_opcode
, INSN_DREF
},
1500 {"vlsseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E16V
, MASK_VLSSEG7E16V
, match_opcode
, INSN_DREF
},
1501 {"vssseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E16V
, MASK_VSSSEG7E16V
, match_opcode
, INSN_DREF
},
1502 {"vlsseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E16V
, MASK_VLSSEG8E16V
, match_opcode
, INSN_DREF
},
1503 {"vssseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E16V
, MASK_VSSSEG8E16V
, match_opcode
, INSN_DREF
},
1505 {"vlsseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E32V
, MASK_VLSSEG2E32V
, match_opcode
, INSN_DREF
},
1506 {"vssseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E32V
, MASK_VSSSEG2E32V
, match_opcode
, INSN_DREF
},
1507 {"vlsseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E32V
, MASK_VLSSEG3E32V
, match_opcode
, INSN_DREF
},
1508 {"vssseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E32V
, MASK_VSSSEG3E32V
, match_opcode
, INSN_DREF
},
1509 {"vlsseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E32V
, MASK_VLSSEG4E32V
, match_opcode
, INSN_DREF
},
1510 {"vssseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E32V
, MASK_VSSSEG4E32V
, match_opcode
, INSN_DREF
},
1511 {"vlsseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E32V
, MASK_VLSSEG5E32V
, match_opcode
, INSN_DREF
},
1512 {"vssseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E32V
, MASK_VSSSEG5E32V
, match_opcode
, INSN_DREF
},
1513 {"vlsseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E32V
, MASK_VLSSEG6E32V
, match_opcode
, INSN_DREF
},
1514 {"vssseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E32V
, MASK_VSSSEG6E32V
, match_opcode
, INSN_DREF
},
1515 {"vlsseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E32V
, MASK_VLSSEG7E32V
, match_opcode
, INSN_DREF
},
1516 {"vssseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E32V
, MASK_VSSSEG7E32V
, match_opcode
, INSN_DREF
},
1517 {"vlsseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E32V
, MASK_VLSSEG8E32V
, match_opcode
, INSN_DREF
},
1518 {"vssseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E32V
, MASK_VSSSEG8E32V
, match_opcode
, INSN_DREF
},
1520 {"vlsseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E64V
, MASK_VLSSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1521 {"vssseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E64V
, MASK_VSSSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1522 {"vlsseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E64V
, MASK_VLSSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1523 {"vssseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E64V
, MASK_VSSSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1524 {"vlsseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E64V
, MASK_VLSSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1525 {"vssseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E64V
, MASK_VSSSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1526 {"vlsseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E64V
, MASK_VLSSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1527 {"vssseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E64V
, MASK_VSSSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1528 {"vlsseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E64V
, MASK_VLSSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1529 {"vssseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E64V
, MASK_VSSSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1530 {"vlsseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E64V
, MASK_VLSSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1531 {"vssseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E64V
, MASK_VSSSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1532 {"vlsseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E64V
, MASK_VLSSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1533 {"vssseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E64V
, MASK_VSSSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1535 {"vloxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI8V
, MASK_VLOXSEG2EI8V
, match_opcode
, INSN_DREF
},
1536 {"vsoxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI8V
, MASK_VSOXSEG2EI8V
, match_opcode
, INSN_DREF
},
1537 {"vloxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI8V
, MASK_VLOXSEG3EI8V
, match_opcode
, INSN_DREF
},
1538 {"vsoxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI8V
, MASK_VSOXSEG3EI8V
, match_opcode
, INSN_DREF
},
1539 {"vloxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI8V
, MASK_VLOXSEG4EI8V
, match_opcode
, INSN_DREF
},
1540 {"vsoxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI8V
, MASK_VSOXSEG4EI8V
, match_opcode
, INSN_DREF
},
1541 {"vloxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI8V
, MASK_VLOXSEG5EI8V
, match_opcode
, INSN_DREF
},
1542 {"vsoxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI8V
, MASK_VSOXSEG5EI8V
, match_opcode
, INSN_DREF
},
1543 {"vloxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI8V
, MASK_VLOXSEG6EI8V
, match_opcode
, INSN_DREF
},
1544 {"vsoxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI8V
, MASK_VSOXSEG6EI8V
, match_opcode
, INSN_DREF
},
1545 {"vloxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI8V
, MASK_VLOXSEG7EI8V
, match_opcode
, INSN_DREF
},
1546 {"vsoxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI8V
, MASK_VSOXSEG7EI8V
, match_opcode
, INSN_DREF
},
1547 {"vloxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI8V
, MASK_VLOXSEG8EI8V
, match_opcode
, INSN_DREF
},
1548 {"vsoxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI8V
, MASK_VSOXSEG8EI8V
, match_opcode
, INSN_DREF
},
1550 {"vloxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI16V
, MASK_VLOXSEG2EI16V
, match_opcode
, INSN_DREF
},
1551 {"vsoxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI16V
, MASK_VSOXSEG2EI16V
, match_opcode
, INSN_DREF
},
1552 {"vloxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI16V
, MASK_VLOXSEG3EI16V
, match_opcode
, INSN_DREF
},
1553 {"vsoxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI16V
, MASK_VSOXSEG3EI16V
, match_opcode
, INSN_DREF
},
1554 {"vloxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI16V
, MASK_VLOXSEG4EI16V
, match_opcode
, INSN_DREF
},
1555 {"vsoxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI16V
, MASK_VSOXSEG4EI16V
, match_opcode
, INSN_DREF
},
1556 {"vloxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI16V
, MASK_VLOXSEG5EI16V
, match_opcode
, INSN_DREF
},
1557 {"vsoxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI16V
, MASK_VSOXSEG5EI16V
, match_opcode
, INSN_DREF
},
1558 {"vloxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI16V
, MASK_VLOXSEG6EI16V
, match_opcode
, INSN_DREF
},
1559 {"vsoxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI16V
, MASK_VSOXSEG6EI16V
, match_opcode
, INSN_DREF
},
1560 {"vloxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI16V
, MASK_VLOXSEG7EI16V
, match_opcode
, INSN_DREF
},
1561 {"vsoxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI16V
, MASK_VSOXSEG7EI16V
, match_opcode
, INSN_DREF
},
1562 {"vloxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI16V
, MASK_VLOXSEG8EI16V
, match_opcode
, INSN_DREF
},
1563 {"vsoxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI16V
, MASK_VSOXSEG8EI16V
, match_opcode
, INSN_DREF
},
1565 {"vloxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI32V
, MASK_VLOXSEG2EI32V
, match_opcode
, INSN_DREF
},
1566 {"vsoxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI32V
, MASK_VSOXSEG2EI32V
, match_opcode
, INSN_DREF
},
1567 {"vloxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI32V
, MASK_VLOXSEG3EI32V
, match_opcode
, INSN_DREF
},
1568 {"vsoxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI32V
, MASK_VSOXSEG3EI32V
, match_opcode
, INSN_DREF
},
1569 {"vloxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI32V
, MASK_VLOXSEG4EI32V
, match_opcode
, INSN_DREF
},
1570 {"vsoxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI32V
, MASK_VSOXSEG4EI32V
, match_opcode
, INSN_DREF
},
1571 {"vloxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI32V
, MASK_VLOXSEG5EI32V
, match_opcode
, INSN_DREF
},
1572 {"vsoxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI32V
, MASK_VSOXSEG5EI32V
, match_opcode
, INSN_DREF
},
1573 {"vloxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI32V
, MASK_VLOXSEG6EI32V
, match_opcode
, INSN_DREF
},
1574 {"vsoxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI32V
, MASK_VSOXSEG6EI32V
, match_opcode
, INSN_DREF
},
1575 {"vloxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI32V
, MASK_VLOXSEG7EI32V
, match_opcode
, INSN_DREF
},
1576 {"vsoxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI32V
, MASK_VSOXSEG7EI32V
, match_opcode
, INSN_DREF
},
1577 {"vloxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI32V
, MASK_VLOXSEG8EI32V
, match_opcode
, INSN_DREF
},
1578 {"vsoxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI32V
, MASK_VSOXSEG8EI32V
, match_opcode
, INSN_DREF
},
1580 {"vloxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI64V
, MASK_VLOXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1581 {"vsoxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI64V
, MASK_VSOXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1582 {"vloxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI64V
, MASK_VLOXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1583 {"vsoxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI64V
, MASK_VSOXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1584 {"vloxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI64V
, MASK_VLOXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1585 {"vsoxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI64V
, MASK_VSOXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1586 {"vloxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI64V
, MASK_VLOXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1587 {"vsoxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI64V
, MASK_VSOXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1588 {"vloxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI64V
, MASK_VLOXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1589 {"vsoxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI64V
, MASK_VSOXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1590 {"vloxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI64V
, MASK_VLOXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1591 {"vsoxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI64V
, MASK_VSOXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1592 {"vloxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI64V
, MASK_VLOXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1593 {"vsoxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI64V
, MASK_VSOXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1595 {"vluxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI8V
, MASK_VLUXSEG2EI8V
, match_opcode
, INSN_DREF
},
1596 {"vsuxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI8V
, MASK_VSUXSEG2EI8V
, match_opcode
, INSN_DREF
},
1597 {"vluxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI8V
, MASK_VLUXSEG3EI8V
, match_opcode
, INSN_DREF
},
1598 {"vsuxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI8V
, MASK_VSUXSEG3EI8V
, match_opcode
, INSN_DREF
},
1599 {"vluxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI8V
, MASK_VLUXSEG4EI8V
, match_opcode
, INSN_DREF
},
1600 {"vsuxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI8V
, MASK_VSUXSEG4EI8V
, match_opcode
, INSN_DREF
},
1601 {"vluxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI8V
, MASK_VLUXSEG5EI8V
, match_opcode
, INSN_DREF
},
1602 {"vsuxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI8V
, MASK_VSUXSEG5EI8V
, match_opcode
, INSN_DREF
},
1603 {"vluxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI8V
, MASK_VLUXSEG6EI8V
, match_opcode
, INSN_DREF
},
1604 {"vsuxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI8V
, MASK_VSUXSEG6EI8V
, match_opcode
, INSN_DREF
},
1605 {"vluxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI8V
, MASK_VLUXSEG7EI8V
, match_opcode
, INSN_DREF
},
1606 {"vsuxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI8V
, MASK_VSUXSEG7EI8V
, match_opcode
, INSN_DREF
},
1607 {"vluxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI8V
, MASK_VLUXSEG8EI8V
, match_opcode
, INSN_DREF
},
1608 {"vsuxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI8V
, MASK_VSUXSEG8EI8V
, match_opcode
, INSN_DREF
},
1610 {"vluxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI16V
, MASK_VLUXSEG2EI16V
, match_opcode
, INSN_DREF
},
1611 {"vsuxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI16V
, MASK_VSUXSEG2EI16V
, match_opcode
, INSN_DREF
},
1612 {"vluxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI16V
, MASK_VLUXSEG3EI16V
, match_opcode
, INSN_DREF
},
1613 {"vsuxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI16V
, MASK_VSUXSEG3EI16V
, match_opcode
, INSN_DREF
},
1614 {"vluxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI16V
, MASK_VLUXSEG4EI16V
, match_opcode
, INSN_DREF
},
1615 {"vsuxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI16V
, MASK_VSUXSEG4EI16V
, match_opcode
, INSN_DREF
},
1616 {"vluxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI16V
, MASK_VLUXSEG5EI16V
, match_opcode
, INSN_DREF
},
1617 {"vsuxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI16V
, MASK_VSUXSEG5EI16V
, match_opcode
, INSN_DREF
},
1618 {"vluxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI16V
, MASK_VLUXSEG6EI16V
, match_opcode
, INSN_DREF
},
1619 {"vsuxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI16V
, MASK_VSUXSEG6EI16V
, match_opcode
, INSN_DREF
},
1620 {"vluxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI16V
, MASK_VLUXSEG7EI16V
, match_opcode
, INSN_DREF
},
1621 {"vsuxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI16V
, MASK_VSUXSEG7EI16V
, match_opcode
, INSN_DREF
},
1622 {"vluxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI16V
, MASK_VLUXSEG8EI16V
, match_opcode
, INSN_DREF
},
1623 {"vsuxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI16V
, MASK_VSUXSEG8EI16V
, match_opcode
, INSN_DREF
},
1625 {"vluxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI32V
, MASK_VLUXSEG2EI32V
, match_opcode
, INSN_DREF
},
1626 {"vsuxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI32V
, MASK_VSUXSEG2EI32V
, match_opcode
, INSN_DREF
},
1627 {"vluxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI32V
, MASK_VLUXSEG3EI32V
, match_opcode
, INSN_DREF
},
1628 {"vsuxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI32V
, MASK_VSUXSEG3EI32V
, match_opcode
, INSN_DREF
},
1629 {"vluxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI32V
, MASK_VLUXSEG4EI32V
, match_opcode
, INSN_DREF
},
1630 {"vsuxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI32V
, MASK_VSUXSEG4EI32V
, match_opcode
, INSN_DREF
},
1631 {"vluxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI32V
, MASK_VLUXSEG5EI32V
, match_opcode
, INSN_DREF
},
1632 {"vsuxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI32V
, MASK_VSUXSEG5EI32V
, match_opcode
, INSN_DREF
},
1633 {"vluxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI32V
, MASK_VLUXSEG6EI32V
, match_opcode
, INSN_DREF
},
1634 {"vsuxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI32V
, MASK_VSUXSEG6EI32V
, match_opcode
, INSN_DREF
},
1635 {"vluxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI32V
, MASK_VLUXSEG7EI32V
, match_opcode
, INSN_DREF
},
1636 {"vsuxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI32V
, MASK_VSUXSEG7EI32V
, match_opcode
, INSN_DREF
},
1637 {"vluxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI32V
, MASK_VLUXSEG8EI32V
, match_opcode
, INSN_DREF
},
1638 {"vsuxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI32V
, MASK_VSUXSEG8EI32V
, match_opcode
, INSN_DREF
},
1640 {"vluxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI64V
, MASK_VLUXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1641 {"vsuxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI64V
, MASK_VSUXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1642 {"vluxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI64V
, MASK_VLUXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1643 {"vsuxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI64V
, MASK_VSUXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1644 {"vluxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI64V
, MASK_VLUXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1645 {"vsuxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI64V
, MASK_VSUXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1646 {"vluxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI64V
, MASK_VLUXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1647 {"vsuxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI64V
, MASK_VSUXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1648 {"vluxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI64V
, MASK_VLUXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1649 {"vsuxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI64V
, MASK_VSUXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1650 {"vluxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI64V
, MASK_VLUXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1651 {"vsuxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI64V
, MASK_VSUXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1652 {"vluxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI64V
, MASK_VLUXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1653 {"vsuxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI64V
, MASK_VSUXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1655 {"vlseg2e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E8FFV
, MASK_VLSEG2E8FFV
, match_opcode
, INSN_DREF
},
1656 {"vlseg3e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E8FFV
, MASK_VLSEG3E8FFV
, match_opcode
, INSN_DREF
},
1657 {"vlseg4e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E8FFV
, MASK_VLSEG4E8FFV
, match_opcode
, INSN_DREF
},
1658 {"vlseg5e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E8FFV
, MASK_VLSEG5E8FFV
, match_opcode
, INSN_DREF
},
1659 {"vlseg6e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E8FFV
, MASK_VLSEG6E8FFV
, match_opcode
, INSN_DREF
},
1660 {"vlseg7e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E8FFV
, MASK_VLSEG7E8FFV
, match_opcode
, INSN_DREF
},
1661 {"vlseg8e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E8FFV
, MASK_VLSEG8E8FFV
, match_opcode
, INSN_DREF
},
1663 {"vlseg2e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E16FFV
, MASK_VLSEG2E16FFV
, match_opcode
, INSN_DREF
},
1664 {"vlseg3e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E16FFV
, MASK_VLSEG3E16FFV
, match_opcode
, INSN_DREF
},
1665 {"vlseg4e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E16FFV
, MASK_VLSEG4E16FFV
, match_opcode
, INSN_DREF
},
1666 {"vlseg5e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E16FFV
, MASK_VLSEG5E16FFV
, match_opcode
, INSN_DREF
},
1667 {"vlseg6e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E16FFV
, MASK_VLSEG6E16FFV
, match_opcode
, INSN_DREF
},
1668 {"vlseg7e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E16FFV
, MASK_VLSEG7E16FFV
, match_opcode
, INSN_DREF
},
1669 {"vlseg8e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E16FFV
, MASK_VLSEG8E16FFV
, match_opcode
, INSN_DREF
},
1671 {"vlseg2e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E32FFV
, MASK_VLSEG2E32FFV
, match_opcode
, INSN_DREF
},
1672 {"vlseg3e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E32FFV
, MASK_VLSEG3E32FFV
, match_opcode
, INSN_DREF
},
1673 {"vlseg4e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E32FFV
, MASK_VLSEG4E32FFV
, match_opcode
, INSN_DREF
},
1674 {"vlseg5e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E32FFV
, MASK_VLSEG5E32FFV
, match_opcode
, INSN_DREF
},
1675 {"vlseg6e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E32FFV
, MASK_VLSEG6E32FFV
, match_opcode
, INSN_DREF
},
1676 {"vlseg7e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E32FFV
, MASK_VLSEG7E32FFV
, match_opcode
, INSN_DREF
},
1677 {"vlseg8e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E32FFV
, MASK_VLSEG8E32FFV
, match_opcode
, INSN_DREF
},
1679 {"vlseg2e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E64FFV
, MASK_VLSEG2E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1680 {"vlseg3e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E64FFV
, MASK_VLSEG3E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1681 {"vlseg4e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E64FFV
, MASK_VLSEG4E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1682 {"vlseg5e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E64FFV
, MASK_VLSEG5E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1683 {"vlseg6e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E64FFV
, MASK_VLSEG6E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1684 {"vlseg7e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E64FFV
, MASK_VLSEG7E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1685 {"vlseg8e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E64FFV
, MASK_VLSEG8E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1687 {"vl1r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE8V
, MASK_VL1RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1688 {"vl1re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE8V
, MASK_VL1RE8V
, match_opcode
, INSN_DREF
},
1689 {"vl1re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE16V
, MASK_VL1RE16V
, match_opcode
, INSN_DREF
},
1690 {"vl1re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE32V
, MASK_VL1RE32V
, match_opcode
, INSN_DREF
},
1691 {"vl1re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE64V
, MASK_VL1RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1693 {"vl2r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE8V
, MASK_VL2RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1694 {"vl2re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE8V
, MASK_VL2RE8V
, match_opcode
, INSN_DREF
},
1695 {"vl2re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE16V
, MASK_VL2RE16V
, match_opcode
, INSN_DREF
},
1696 {"vl2re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE32V
, MASK_VL2RE32V
, match_opcode
, INSN_DREF
},
1697 {"vl2re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE64V
, MASK_VL2RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1699 {"vl4r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE8V
, MASK_VL4RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1700 {"vl4re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE8V
, MASK_VL4RE8V
, match_opcode
, INSN_DREF
},
1701 {"vl4re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE16V
, MASK_VL4RE16V
, match_opcode
, INSN_DREF
},
1702 {"vl4re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE32V
, MASK_VL4RE32V
, match_opcode
, INSN_DREF
},
1703 {"vl4re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE64V
, MASK_VL4RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1705 {"vl8r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE8V
, MASK_VL8RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1706 {"vl8re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE8V
, MASK_VL8RE8V
, match_opcode
, INSN_DREF
},
1707 {"vl8re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE16V
, MASK_VL8RE16V
, match_opcode
, INSN_DREF
},
1708 {"vl8re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE32V
, MASK_VL8RE32V
, match_opcode
, INSN_DREF
},
1709 {"vl8re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE64V
, MASK_VL8RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1711 {"vs1r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS1RV
, MASK_VS1RV
, match_opcode
, INSN_DREF
},
1712 {"vs2r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS2RV
, MASK_VS2RV
, match_opcode
, INSN_DREF
},
1713 {"vs4r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS4RV
, MASK_VS4RV
, match_opcode
, INSN_DREF
},
1714 {"vs8r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS8RV
, MASK_VS8RV
, match_opcode
, INSN_DREF
},
1716 {"vneg.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VRSUBVX
, MASK_VRSUBVX
| MASK_RS1
, match_opcode
, INSN_ALIAS
},
1718 {"vadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VADDVV
, MASK_VADDVV
, match_opcode
, 0 },
1719 {"vadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VADDVX
, MASK_VADDVX
, match_opcode
, 0 },
1720 {"vadd.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VADDVI
, MASK_VADDVI
, match_opcode
, 0 },
1721 {"vsub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSUBVV
, MASK_VSUBVV
, match_opcode
, 0 },
1722 {"vsub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSUBVX
, MASK_VSUBVX
, match_opcode
, 0 },
1723 {"vrsub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VRSUBVX
, MASK_VRSUBVX
, match_opcode
, 0 },
1724 {"vrsub.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VRSUBVI
, MASK_VRSUBVI
, match_opcode
, 0 },
1726 {"vwcvt.x.x.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VWCVTXXV
, MASK_VWCVTXXV
, match_opcode
, INSN_ALIAS
},
1727 {"vwcvtu.x.x.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VWCVTUXXV
, MASK_VWCVTUXXV
, match_opcode
, INSN_ALIAS
},
1729 {"vwaddu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDUVV
, MASK_VWADDUVV
, match_opcode
, 0 },
1730 {"vwaddu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDUVX
, MASK_VWADDUVX
, match_opcode
, 0 },
1731 {"vwsubu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBUVV
, MASK_VWSUBUVV
, match_opcode
, 0 },
1732 {"vwsubu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBUVX
, MASK_VWSUBUVX
, match_opcode
, 0 },
1733 {"vwadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDVV
, MASK_VWADDVV
, match_opcode
, 0 },
1734 {"vwadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDVX
, MASK_VWADDVX
, match_opcode
, 0 },
1735 {"vwsub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBVV
, MASK_VWSUBVV
, match_opcode
, 0 },
1736 {"vwsub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBVX
, MASK_VWSUBVX
, match_opcode
, 0 },
1737 {"vwaddu.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDUWV
, MASK_VWADDUWV
, match_opcode
, 0 },
1738 {"vwaddu.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDUWX
, MASK_VWADDUWX
, match_opcode
, 0 },
1739 {"vwsubu.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBUWV
, MASK_VWSUBUWV
, match_opcode
, 0 },
1740 {"vwsubu.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBUWX
, MASK_VWSUBUWX
, match_opcode
, 0 },
1741 {"vwadd.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDWV
, MASK_VWADDWV
, match_opcode
, 0 },
1742 {"vwadd.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDWX
, MASK_VWADDWX
, match_opcode
, 0 },
1743 {"vwsub.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBWV
, MASK_VWSUBWV
, match_opcode
, 0 },
1744 {"vwsub.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBWX
, MASK_VWSUBWX
, match_opcode
, 0 },
1746 {"vzext.vf2", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VZEXT_VF2
, MASK_VZEXT_VF2
, match_opcode
, 0 },
1747 {"vsext.vf2", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VSEXT_VF2
, MASK_VSEXT_VF2
, match_opcode
, 0 },
1748 {"vzext.vf4", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VZEXT_VF4
, MASK_VZEXT_VF4
, match_opcode
, 0 },
1749 {"vsext.vf4", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VSEXT_VF4
, MASK_VSEXT_VF4
, match_opcode
, 0 },
1750 {"vzext.vf8", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VZEXT_VF8
, MASK_VZEXT_VF8
, match_opcode
, 0 },
1751 {"vsext.vf8", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VSEXT_VF8
, MASK_VSEXT_VF8
, match_opcode
, 0 },
1753 {"vadc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VADCVVM
, MASK_VADCVVM
, match_opcode
, 0 },
1754 {"vadc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VADCVXM
, MASK_VADCVXM
, match_opcode
, 0 },
1755 {"vadc.vim", 0, INSN_CLASS_V
, "Vd,Vt,Vi,V0", MATCH_VADCVIM
, MASK_VADCVIM
, match_opcode
, 0 },
1756 {"vmadc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VMADCVVM
, MASK_VMADCVVM
, match_opcode
, 0 },
1757 {"vmadc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VMADCVXM
, MASK_VMADCVXM
, match_opcode
, 0 },
1758 {"vmadc.vim", 0, INSN_CLASS_V
, "Vd,Vt,Vi,V0", MATCH_VMADCVIM
, MASK_VMADCVIM
, match_opcode
, 0 },
1759 {"vmadc.vv", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMADCVV
, MASK_VMADCVV
, match_opcode
, 0 },
1760 {"vmadc.vx", 0, INSN_CLASS_V
, "Vd,Vt,s", MATCH_VMADCVX
, MASK_VMADCVX
, match_opcode
, 0 },
1761 {"vmadc.vi", 0, INSN_CLASS_V
, "Vd,Vt,Vi", MATCH_VMADCVI
, MASK_VMADCVI
, match_opcode
, 0 },
1762 {"vsbc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VSBCVVM
, MASK_VSBCVVM
, match_opcode
, 0 },
1763 {"vsbc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VSBCVXM
, MASK_VSBCVXM
, match_opcode
, 0 },
1764 {"vmsbc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VMSBCVVM
, MASK_VMSBCVVM
, match_opcode
, 0 },
1765 {"vmsbc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VMSBCVXM
, MASK_VMSBCVXM
, match_opcode
, 0 },
1766 {"vmsbc.vv", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMSBCVV
, MASK_VMSBCVV
, match_opcode
, 0 },
1767 {"vmsbc.vx", 0, INSN_CLASS_V
, "Vd,Vt,s", MATCH_VMSBCVX
, MASK_VMSBCVX
, match_opcode
, 0 },
1769 {"vnot.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VNOTV
, MASK_VNOTV
, match_opcode
, INSN_ALIAS
},
1771 {"vand.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VANDVV
, MASK_VANDVV
, match_opcode
, 0 },
1772 {"vand.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VANDVX
, MASK_VANDVX
, match_opcode
, 0 },
1773 {"vand.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VANDVI
, MASK_VANDVI
, match_opcode
, 0 },
1774 {"vor.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VORVV
, MASK_VORVV
, match_opcode
, 0 },
1775 {"vor.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VORVX
, MASK_VORVX
, match_opcode
, 0 },
1776 {"vor.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VORVI
, MASK_VORVI
, match_opcode
, 0 },
1777 {"vxor.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VXORVV
, MASK_VXORVV
, match_opcode
, 0 },
1778 {"vxor.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VXORVX
, MASK_VXORVX
, match_opcode
, 0 },
1779 {"vxor.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VXORVI
, MASK_VXORVI
, match_opcode
, 0 },
1781 {"vsll.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSLLVV
, MASK_VSLLVV
, match_opcode
, 0 },
1782 {"vsll.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLLVX
, MASK_VSLLVX
, match_opcode
, 0 },
1783 {"vsll.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSLLVI
, MASK_VSLLVI
, match_opcode
, 0 },
1784 {"vsrl.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSRLVV
, MASK_VSRLVV
, match_opcode
, 0 },
1785 {"vsrl.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSRLVX
, MASK_VSRLVX
, match_opcode
, 0 },
1786 {"vsrl.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSRLVI
, MASK_VSRLVI
, match_opcode
, 0 },
1787 {"vsra.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSRAVV
, MASK_VSRAVV
, match_opcode
, 0 },
1788 {"vsra.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSRAVX
, MASK_VSRAVX
, match_opcode
, 0 },
1789 {"vsra.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSRAVI
, MASK_VSRAVI
, match_opcode
, 0 },
1791 {"vncvt.x.x.w",0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VNCVTXXW
, MASK_VNCVTXXW
, match_opcode
, INSN_ALIAS
},
1793 {"vnsrl.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNSRLWV
, MASK_VNSRLWV
, match_opcode
, 0 },
1794 {"vnsrl.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNSRLWX
, MASK_VNSRLWX
, match_opcode
, 0 },
1795 {"vnsrl.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNSRLWI
, MASK_VNSRLWI
, match_opcode
, 0 },
1796 {"vnsra.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNSRAWV
, MASK_VNSRAWV
, match_opcode
, 0 },
1797 {"vnsra.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNSRAWX
, MASK_VNSRAWX
, match_opcode
, 0 },
1798 {"vnsra.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNSRAWI
, MASK_VNSRAWI
, match_opcode
, 0 },
1800 {"vmseq.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSEQVV
, MASK_VMSEQVV
, match_opcode
, 0 },
1801 {"vmseq.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSEQVX
, MASK_VMSEQVX
, match_opcode
, 0 },
1802 {"vmseq.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSEQVI
, MASK_VMSEQVI
, match_opcode
, 0 },
1803 {"vmsne.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSNEVV
, MASK_VMSNEVV
, match_opcode
, 0 },
1804 {"vmsne.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSNEVX
, MASK_VMSNEVX
, match_opcode
, 0 },
1805 {"vmsne.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSNEVI
, MASK_VMSNEVI
, match_opcode
, 0 },
1806 {"vmsltu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLTUVV
, MASK_VMSLTUVV
, match_opcode
, 0 },
1807 {"vmsltu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLTUVX
, MASK_VMSLTUVX
, match_opcode
, 0 },
1808 {"vmslt.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLTVV
, MASK_VMSLTVV
, match_opcode
, 0 },
1809 {"vmslt.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLTVX
, MASK_VMSLTVX
, match_opcode
, 0 },
1810 {"vmsleu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLEUVV
, MASK_VMSLEUVV
, match_opcode
, 0 },
1811 {"vmsleu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLEUVX
, MASK_VMSLEUVX
, match_opcode
, 0 },
1812 {"vmsleu.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSLEUVI
, MASK_VMSLEUVI
, match_opcode
, 0 },
1813 {"vmsle.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLEVV
, MASK_VMSLEVV
, match_opcode
, 0 },
1814 {"vmsle.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLEVX
, MASK_VMSLEVX
, match_opcode
, 0 },
1815 {"vmsle.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSLEVI
, MASK_VMSLEVI
, match_opcode
, 0 },
1816 {"vmsgtu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSGTUVX
, MASK_VMSGTUVX
, match_opcode
, 0 },
1817 {"vmsgtu.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSGTUVI
, MASK_VMSGTUVI
, match_opcode
, 0 },
1818 {"vmsgt.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSGTVX
, MASK_VMSGTVX
, match_opcode
, 0 },
1819 {"vmsgt.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSGTVI
, MASK_VMSGTVI
, match_opcode
, 0 },
1820 {"vmsgt.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLTVV
, MASK_VMSLTVV
, match_opcode
, INSN_ALIAS
},
1821 {"vmsgtu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLTUVV
, MASK_VMSLTUVV
, match_opcode
, INSN_ALIAS
},
1822 {"vmsge.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLEVV
, MASK_VMSLEVV
, match_opcode
, INSN_ALIAS
},
1823 {"vmsgeu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLEUVV
, MASK_VMSLEUVV
, match_opcode
, INSN_ALIAS
},
1824 {"vmslt.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSLEVI
, MASK_VMSLEVI
, match_opcode
, INSN_ALIAS
},
1825 {"vmsltu.vi", 0, INSN_CLASS_V
, "Vd,Vu,0Vm", MATCH_VMSNEVV
, MASK_VMSNEVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1826 {"vmsltu.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSLEUVI
, MASK_VMSLEUVI
, match_opcode
, INSN_ALIAS
},
1827 {"vmsge.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSGTVI
, MASK_VMSGTVI
, match_opcode
, INSN_ALIAS
},
1828 {"vmsgeu.vi", 0, INSN_CLASS_V
, "Vd,Vu,0Vm", MATCH_VMSEQVV
, MASK_VMSEQVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1829 {"vmsgeu.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSGTUVI
, MASK_VMSGTUVI
, match_opcode
, INSN_ALIAS
},
1831 {"vmsge.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", 0, (int) M_VMSGE
, NULL
, INSN_MACRO
},
1832 {"vmsge.vx", 0, INSN_CLASS_V
, "Vd,Vt,s,VM,VT", 0, (int) M_VMSGE
, NULL
, INSN_MACRO
},
1833 {"vmsgeu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", 1, (int) M_VMSGE
, NULL
, INSN_MACRO
},
1834 {"vmsgeu.vx", 0, INSN_CLASS_V
, "Vd,Vt,s,VM,VT", 1, (int) M_VMSGE
, NULL
, INSN_MACRO
},
1836 {"vminu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMINUVV
, MASK_VMINUVV
, match_opcode
, 0},
1837 {"vminu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMINUVX
, MASK_VMINUVX
, match_opcode
, 0},
1838 {"vmin.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMINVV
, MASK_VMINVV
, match_opcode
, 0},
1839 {"vmin.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMINVX
, MASK_VMINVX
, match_opcode
, 0},
1840 {"vmaxu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMAXUVV
, MASK_VMAXUVV
, match_opcode
, 0},
1841 {"vmaxu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMAXUVX
, MASK_VMAXUVX
, match_opcode
, 0},
1842 {"vmax.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMAXVV
, MASK_VMAXVV
, match_opcode
, 0},
1843 {"vmax.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMAXVX
, MASK_VMAXVX
, match_opcode
, 0},
1845 {"vmul.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULVV
, MASK_VMULVV
, match_opcode
, 0 },
1846 {"vmul.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULVX
, MASK_VMULVX
, match_opcode
, 0 },
1847 {"vmulh.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULHVV
, MASK_VMULHVV
, match_opcode
, 0 },
1848 {"vmulh.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULHVX
, MASK_VMULHVX
, match_opcode
, 0 },
1849 {"vmulhu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULHUVV
, MASK_VMULHUVV
, match_opcode
, 0 },
1850 {"vmulhu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULHUVX
, MASK_VMULHUVX
, match_opcode
, 0 },
1851 {"vmulhsu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULHSUVV
, MASK_VMULHSUVV
, match_opcode
, 0 },
1852 {"vmulhsu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULHSUVX
, MASK_VMULHSUVX
, match_opcode
, 0 },
1854 {"vwmul.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWMULVV
, MASK_VWMULVV
, match_opcode
, 0 },
1855 {"vwmul.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWMULVX
, MASK_VWMULVX
, match_opcode
, 0 },
1856 {"vwmulu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWMULUVV
, MASK_VWMULUVV
, match_opcode
, 0 },
1857 {"vwmulu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWMULUVX
, MASK_VWMULUVX
, match_opcode
, 0 },
1858 {"vwmulsu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWMULSUVV
, MASK_VWMULSUVV
, match_opcode
, 0 },
1859 {"vwmulsu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWMULSUVX
, MASK_VWMULSUVX
, match_opcode
, 0 },
1861 {"vmacc.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMACCVV
, MASK_VMACCVV
, match_opcode
, 0},
1862 {"vmacc.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VMACCVX
, MASK_VMACCVX
, match_opcode
, 0},
1863 {"vnmsac.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VNMSACVV
, MASK_VNMSACVV
, match_opcode
, 0},
1864 {"vnmsac.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VNMSACVX
, MASK_VNMSACVX
, match_opcode
, 0},
1865 {"vmadd.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMADDVV
, MASK_VMADDVV
, match_opcode
, 0},
1866 {"vmadd.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VMADDVX
, MASK_VMADDVX
, match_opcode
, 0},
1867 {"vnmsub.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VNMSUBVV
, MASK_VNMSUBVV
, match_opcode
, 0},
1868 {"vnmsub.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VNMSUBVX
, MASK_VNMSUBVX
, match_opcode
, 0},
1870 {"vwmaccu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VWMACCUVV
, MASK_VWMACCUVV
, match_opcode
, 0},
1871 {"vwmaccu.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCUVX
, MASK_VWMACCUVX
, match_opcode
, 0},
1872 {"vwmacc.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VWMACCVV
, MASK_VWMACCVV
, match_opcode
, 0},
1873 {"vwmacc.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCVX
, MASK_VWMACCVX
, match_opcode
, 0},
1874 {"vwmaccsu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VWMACCSUVV
, MASK_VWMACCSUVV
, match_opcode
, 0},
1875 {"vwmaccsu.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCSUVX
, MASK_VWMACCSUVX
, match_opcode
, 0},
1876 {"vwmaccus.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCUSVX
, MASK_VWMACCUSVX
, match_opcode
, 0},
1878 {"vdivu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VDIVUVV
, MASK_VDIVUVV
, match_opcode
, 0 },
1879 {"vdivu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VDIVUVX
, MASK_VDIVUVX
, match_opcode
, 0 },
1880 {"vdiv.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VDIVVV
, MASK_VDIVVV
, match_opcode
, 0 },
1881 {"vdiv.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VDIVVX
, MASK_VDIVVX
, match_opcode
, 0 },
1882 {"vremu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREMUVV
, MASK_VREMUVV
, match_opcode
, 0 },
1883 {"vremu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VREMUVX
, MASK_VREMUVX
, match_opcode
, 0 },
1884 {"vrem.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREMVV
, MASK_VREMVV
, match_opcode
, 0 },
1885 {"vrem.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VREMVX
, MASK_VREMVX
, match_opcode
, 0 },
1887 {"vmerge.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VMERGEVVM
, MASK_VMERGEVVM
, match_opcode
, 0 },
1888 {"vmerge.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VMERGEVXM
, MASK_VMERGEVXM
, match_opcode
, 0 },
1889 {"vmerge.vim", 0, INSN_CLASS_V
, "Vd,Vt,Vi,V0", MATCH_VMERGEVIM
, MASK_VMERGEVIM
, match_opcode
, 0 },
1891 {"vmv.v.v", 0, INSN_CLASS_V
, "Vd,Vs", MATCH_VMVVV
, MASK_VMVVV
, match_opcode
, 0 },
1892 {"vmv.v.x", 0, INSN_CLASS_V
, "Vd,s", MATCH_VMVVX
, MASK_VMVVX
, match_opcode
, 0 },
1893 {"vmv.v.i", 0, INSN_CLASS_V
, "Vd,Vi", MATCH_VMVVI
, MASK_VMVVI
, match_opcode
, 0 },
1895 {"vsaddu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSADDUVV
, MASK_VSADDUVV
, match_opcode
, 0 },
1896 {"vsaddu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSADDUVX
, MASK_VSADDUVX
, match_opcode
, 0 },
1897 {"vsaddu.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VSADDUVI
, MASK_VSADDUVI
, match_opcode
, 0 },
1898 {"vsadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSADDVV
, MASK_VSADDVV
, match_opcode
, 0 },
1899 {"vsadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSADDVX
, MASK_VSADDVX
, match_opcode
, 0 },
1900 {"vsadd.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VSADDVI
, MASK_VSADDVI
, match_opcode
, 0 },
1901 {"vssubu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSUBUVV
, MASK_VSSUBUVV
, match_opcode
, 0 },
1902 {"vssubu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSUBUVX
, MASK_VSSUBUVX
, match_opcode
, 0 },
1903 {"vssub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSUBVV
, MASK_VSSUBVV
, match_opcode
, 0 },
1904 {"vssub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSUBVX
, MASK_VSSUBVX
, match_opcode
, 0 },
1906 {"vaaddu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VAADDUVV
, MASK_VAADDUVV
, match_opcode
, 0 },
1907 {"vaaddu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VAADDUVX
, MASK_VAADDUVX
, match_opcode
, 0 },
1908 {"vaadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VAADDVV
, MASK_VAADDVV
, match_opcode
, 0 },
1909 {"vaadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VAADDVX
, MASK_VAADDVX
, match_opcode
, 0 },
1910 {"vasubu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VASUBUVV
, MASK_VASUBUVV
, match_opcode
, 0 },
1911 {"vasubu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VASUBUVX
, MASK_VASUBUVX
, match_opcode
, 0 },
1912 {"vasub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VASUBVV
, MASK_VASUBVV
, match_opcode
, 0 },
1913 {"vasub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VASUBVX
, MASK_VASUBVX
, match_opcode
, 0 },
1915 {"vsmul.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSMULVV
, MASK_VSMULVV
, match_opcode
, 0 },
1916 {"vsmul.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSMULVX
, MASK_VSMULVX
, match_opcode
, 0 },
1918 {"vssrl.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSRLVV
, MASK_VSSRLVV
, match_opcode
, 0 },
1919 {"vssrl.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSRLVX
, MASK_VSSRLVX
, match_opcode
, 0 },
1920 {"vssrl.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSSRLVI
, MASK_VSSRLVI
, match_opcode
, 0 },
1921 {"vssra.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSRAVV
, MASK_VSSRAVV
, match_opcode
, 0 },
1922 {"vssra.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSRAVX
, MASK_VSSRAVX
, match_opcode
, 0 },
1923 {"vssra.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSSRAVI
, MASK_VSSRAVI
, match_opcode
, 0 },
1925 {"vnclipu.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNCLIPUWV
, MASK_VNCLIPUWV
, match_opcode
, 0 },
1926 {"vnclipu.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNCLIPUWX
, MASK_VNCLIPUWX
, match_opcode
, 0 },
1927 {"vnclipu.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNCLIPUWI
, MASK_VNCLIPUWI
, match_opcode
, 0 },
1928 {"vnclip.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNCLIPWV
, MASK_VNCLIPWV
, match_opcode
, 0 },
1929 {"vnclip.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNCLIPWX
, MASK_VNCLIPWX
, match_opcode
, 0 },
1930 {"vnclip.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNCLIPWI
, MASK_VNCLIPWI
, match_opcode
, 0 },
1932 {"vfadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFADDVV
, MASK_VFADDVV
, match_opcode
, 0},
1933 {"vfadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFADDVF
, MASK_VFADDVF
, match_opcode
, 0},
1934 {"vfsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSUBVV
, MASK_VFSUBVV
, match_opcode
, 0},
1935 {"vfsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSUBVF
, MASK_VFSUBVF
, match_opcode
, 0},
1936 {"vfrsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFRSUBVF
, MASK_VFRSUBVF
, match_opcode
, 0},
1938 {"vfwadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWADDVV
, MASK_VFWADDVV
, match_opcode
, 0},
1939 {"vfwadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWADDVF
, MASK_VFWADDVF
, match_opcode
, 0},
1940 {"vfwsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWSUBVV
, MASK_VFWSUBVV
, match_opcode
, 0},
1941 {"vfwsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWSUBVF
, MASK_VFWSUBVF
, match_opcode
, 0},
1942 {"vfwadd.wv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWADDWV
, MASK_VFWADDWV
, match_opcode
, 0},
1943 {"vfwadd.wf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWADDWF
, MASK_VFWADDWF
, match_opcode
, 0},
1944 {"vfwsub.wv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWSUBWV
, MASK_VFWSUBWV
, match_opcode
, 0},
1945 {"vfwsub.wf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWSUBWF
, MASK_VFWSUBWF
, match_opcode
, 0},
1947 {"vfmul.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFMULVV
, MASK_VFMULVV
, match_opcode
, 0},
1948 {"vfmul.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFMULVF
, MASK_VFMULVF
, match_opcode
, 0},
1949 {"vfdiv.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFDIVVV
, MASK_VFDIVVV
, match_opcode
, 0},
1950 {"vfdiv.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFDIVVF
, MASK_VFDIVVF
, match_opcode
, 0},
1951 {"vfrdiv.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFRDIVVF
, MASK_VFRDIVVF
, match_opcode
, 0},
1953 {"vfwmul.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWMULVV
, MASK_VFWMULVV
, match_opcode
, 0},
1954 {"vfwmul.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWMULVF
, MASK_VFWMULVF
, match_opcode
, 0},
1956 {"vfmadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMADDVV
, MASK_VFMADDVV
, match_opcode
, 0},
1957 {"vfmadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMADDVF
, MASK_VFMADDVF
, match_opcode
, 0},
1958 {"vfnmadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMADDVV
, MASK_VFNMADDVV
, match_opcode
, 0},
1959 {"vfnmadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMADDVF
, MASK_VFNMADDVF
, match_opcode
, 0},
1960 {"vfmsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMSUBVV
, MASK_VFMSUBVV
, match_opcode
, 0},
1961 {"vfmsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMSUBVF
, MASK_VFMSUBVF
, match_opcode
, 0},
1962 {"vfnmsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMSUBVV
, MASK_VFNMSUBVV
, match_opcode
, 0},
1963 {"vfnmsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMSUBVF
, MASK_VFNMSUBVF
, match_opcode
, 0},
1964 {"vfmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMACCVV
, MASK_VFMACCVV
, match_opcode
, 0},
1965 {"vfmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMACCVF
, MASK_VFMACCVF
, match_opcode
, 0},
1966 {"vfnmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMACCVV
, MASK_VFNMACCVV
, match_opcode
, 0},
1967 {"vfnmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMACCVF
, MASK_VFNMACCVF
, match_opcode
, 0},
1968 {"vfmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMSACVV
, MASK_VFMSACVV
, match_opcode
, 0},
1969 {"vfmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMSACVF
, MASK_VFMSACVF
, match_opcode
, 0},
1970 {"vfnmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMSACVV
, MASK_VFNMSACVV
, match_opcode
, 0},
1971 {"vfnmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMSACVF
, MASK_VFNMSACVF
, match_opcode
, 0},
1973 {"vfwmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWMACCVV
, MASK_VFWMACCVV
, match_opcode
, 0},
1974 {"vfwmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWMACCVF
, MASK_VFWMACCVF
, match_opcode
, 0},
1975 {"vfwnmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWNMACCVV
, MASK_VFWNMACCVV
, match_opcode
, 0},
1976 {"vfwnmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWNMACCVF
, MASK_VFWNMACCVF
, match_opcode
, 0},
1977 {"vfwmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWMSACVV
, MASK_VFWMSACVV
, match_opcode
, 0},
1978 {"vfwmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWMSACVF
, MASK_VFWMSACVF
, match_opcode
, 0},
1979 {"vfwnmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWNMSACVV
, MASK_VFWNMSACVV
, match_opcode
, 0},
1980 {"vfwnmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWNMSACVF
, MASK_VFWNMSACVF
, match_opcode
, 0},
1982 {"vfsqrt.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFSQRTV
, MASK_VFSQRTV
, match_opcode
, 0},
1983 {"vfrsqrt7.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFRSQRT7V
, MASK_VFRSQRT7V
, match_opcode
, 0},
1984 {"vfrsqrte7.v",0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFRSQRT7V
, MASK_VFRSQRT7V
, match_opcode
, 0},
1985 {"vfrec7.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFREC7V
, MASK_VFREC7V
, match_opcode
, 0},
1986 {"vfrece7.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFREC7V
, MASK_VFREC7V
, match_opcode
, 0},
1987 {"vfclass.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCLASSV
, MASK_VFCLASSV
, match_opcode
, 0},
1989 {"vfmin.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFMINVV
, MASK_VFMINVV
, match_opcode
, 0},
1990 {"vfmin.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFMINVF
, MASK_VFMINVF
, match_opcode
, 0},
1991 {"vfmax.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFMAXVV
, MASK_VFMAXVV
, match_opcode
, 0},
1992 {"vfmax.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFMAXVF
, MASK_VFMAXVF
, match_opcode
, 0},
1994 {"vfneg.v", 0, INSN_CLASS_ZVEF
, "Vd,VuVm", MATCH_VFSGNJNVV
, MASK_VFSGNJNVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1995 {"vfabs.v", 0, INSN_CLASS_ZVEF
, "Vd,VuVm", MATCH_VFSGNJXVV
, MASK_VFSGNJXVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1997 {"vfsgnj.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSGNJVV
, MASK_VFSGNJVV
, match_opcode
, 0},
1998 {"vfsgnj.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSGNJVF
, MASK_VFSGNJVF
, match_opcode
, 0},
1999 {"vfsgnjn.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSGNJNVV
, MASK_VFSGNJNVV
, match_opcode
, 0},
2000 {"vfsgnjn.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSGNJNVF
, MASK_VFSGNJNVF
, match_opcode
, 0},
2001 {"vfsgnjx.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSGNJXVV
, MASK_VFSGNJXVV
, match_opcode
, 0},
2002 {"vfsgnjx.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSGNJXVF
, MASK_VFSGNJXVF
, match_opcode
, 0},
2004 {"vmfeq.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFEQVV
, MASK_VMFEQVV
, match_opcode
, 0},
2005 {"vmfeq.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFEQVF
, MASK_VMFEQVF
, match_opcode
, 0},
2006 {"vmfne.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFNEVV
, MASK_VMFNEVV
, match_opcode
, 0},
2007 {"vmfne.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFNEVF
, MASK_VMFNEVF
, match_opcode
, 0},
2008 {"vmflt.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFLTVV
, MASK_VMFLTVV
, match_opcode
, 0},
2009 {"vmflt.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFLTVF
, MASK_VMFLTVF
, match_opcode
, 0},
2010 {"vmfle.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFLEVV
, MASK_VMFLEVV
, match_opcode
, 0},
2011 {"vmfle.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFLEVF
, MASK_VMFLEVF
, match_opcode
, 0},
2012 {"vmfgt.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFGTVF
, MASK_VMFGTVF
, match_opcode
, 0},
2013 {"vmfge.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFGEVF
, MASK_VMFGEVF
, match_opcode
, 0},
2015 /* These aliases are for assembly but not disassembly. */
2016 {"vmfgt.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VMFLTVV
, MASK_VMFLTVV
, match_opcode
, INSN_ALIAS
},
2017 {"vmfge.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VMFLEVV
, MASK_VMFLEVV
, match_opcode
, INSN_ALIAS
},
2019 {"vfmerge.vfm",0, INSN_CLASS_ZVEF
, "Vd,Vt,S,V0", MATCH_VFMERGEVFM
, MASK_VFMERGEVFM
, match_opcode
, 0},
2020 {"vfmv.v.f", 0, INSN_CLASS_ZVEF
, "Vd,S", MATCH_VFMVVF
, MASK_VFMVVF
, match_opcode
, 0 },
2022 {"vfcvt.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTXUFV
, MASK_VFCVTXUFV
, match_opcode
, 0},
2023 {"vfcvt.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTXFV
, MASK_VFCVTXFV
, match_opcode
, 0},
2024 {"vfcvt.rtz.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTRTZXUFV
, MASK_VFCVTRTZXUFV
, match_opcode
, 0},
2025 {"vfcvt.rtz.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTRTZXFV
, MASK_VFCVTRTZXFV
, match_opcode
, 0},
2026 {"vfcvt.f.xu.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTFXUV
, MASK_VFCVTFXUV
, match_opcode
, 0},
2027 {"vfcvt.f.x.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTFXV
, MASK_VFCVTFXV
, match_opcode
, 0},
2029 {"vfwcvt.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTXUFV
, MASK_VFWCVTXUFV
, match_opcode
, 0},
2030 {"vfwcvt.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTXFV
, MASK_VFWCVTXFV
, match_opcode
, 0},
2031 {"vfwcvt.rtz.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTRTZXUFV
, MASK_VFWCVTRTZXUFV
, match_opcode
, 0},
2032 {"vfwcvt.rtz.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTRTZXFV
, MASK_VFWCVTRTZXFV
, match_opcode
, 0},
2033 {"vfwcvt.f.xu.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTFXUV
, MASK_VFWCVTFXUV
, match_opcode
, 0},
2034 {"vfwcvt.f.x.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTFXV
, MASK_VFWCVTFXV
, match_opcode
, 0},
2035 {"vfwcvt.f.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTFFV
, MASK_VFWCVTFFV
, match_opcode
, 0},
2037 {"vfncvt.xu.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTXUFW
, MASK_VFNCVTXUFW
, match_opcode
, 0},
2038 {"vfncvt.x.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTXFW
, MASK_VFNCVTXFW
, match_opcode
, 0},
2039 {"vfncvt.rtz.xu.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTRTZXUFW
, MASK_VFNCVTRTZXUFW
, match_opcode
, 0},
2040 {"vfncvt.rtz.x.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTRTZXFW
, MASK_VFNCVTRTZXFW
, match_opcode
, 0},
2041 {"vfncvt.f.xu.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTFXUW
, MASK_VFNCVTFXUW
, match_opcode
, 0},
2042 {"vfncvt.f.x.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTFXW
, MASK_VFNCVTFXW
, match_opcode
, 0},
2043 {"vfncvt.f.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTFFW
, MASK_VFNCVTFFW
, match_opcode
, 0},
2044 {"vfncvt.rod.f.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTRODFFW
, MASK_VFNCVTRODFFW
, match_opcode
, 0},
2046 {"vredsum.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDSUMVS
, MASK_VREDSUMVS
, match_opcode
, 0},
2047 {"vredmaxu.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMAXUVS
, MASK_VREDMAXUVS
, match_opcode
, 0},
2048 {"vredmax.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMAXVS
, MASK_VREDMAXVS
, match_opcode
, 0},
2049 {"vredminu.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMINUVS
, MASK_VREDMINUVS
, match_opcode
, 0},
2050 {"vredmin.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMINVS
, MASK_VREDMINVS
, match_opcode
, 0},
2051 {"vredand.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDANDVS
, MASK_VREDANDVS
, match_opcode
, 0},
2052 {"vredor.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDORVS
, MASK_VREDORVS
, match_opcode
, 0},
2053 {"vredxor.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDXORVS
, MASK_VREDXORVS
, match_opcode
, 0},
2055 {"vwredsumu.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWREDSUMUVS
, MASK_VWREDSUMUVS
, match_opcode
, 0},
2056 {"vwredsum.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWREDSUMVS
, MASK_VWREDSUMVS
, match_opcode
, 0},
2058 {"vfredosum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDOSUMVS
, MASK_VFREDOSUMVS
, match_opcode
, 0},
2059 {"vfredusum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDUSUMVS
, MASK_VFREDUSUMVS
, match_opcode
, 0},
2060 {"vfredsum.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDUSUMVS
, MASK_VFREDUSUMVS
, match_opcode
, INSN_ALIAS
},
2061 {"vfredmax.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDMAXVS
, MASK_VFREDMAXVS
, match_opcode
, 0},
2062 {"vfredmin.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDMINVS
, MASK_VFREDMINVS
, match_opcode
, 0},
2064 {"vfwredosum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWREDOSUMVS
, MASK_VFWREDOSUMVS
, match_opcode
, 0},
2065 {"vfwredusum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWREDUSUMVS
, MASK_VFWREDUSUMVS
, match_opcode
, 0},
2066 {"vfwredsum.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWREDUSUMVS
, MASK_VFWREDUSUMVS
, match_opcode
, INSN_ALIAS
},
2068 {"vmmv.m", 0, INSN_CLASS_V
, "Vd,Vu", MATCH_VMANDMM
, MASK_VMANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
2069 {"vmcpy.m", 0, INSN_CLASS_V
, "Vd,Vu", MATCH_VMANDMM
, MASK_VMANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
2070 {"vmclr.m", 0, INSN_CLASS_V
, "Vv", MATCH_VMXORMM
, MASK_VMXORMM
, match_vd_eq_vs1_eq_vs2
, INSN_ALIAS
},
2071 {"vmset.m", 0, INSN_CLASS_V
, "Vv", MATCH_VMXNORMM
, MASK_VMXNORMM
, match_vd_eq_vs1_eq_vs2
, INSN_ALIAS
},
2072 {"vmnot.m", 0, INSN_CLASS_V
, "Vd,Vu", MATCH_VMNANDMM
, MASK_VMNANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
2074 {"vmand.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMANDMM
, MASK_VMANDMM
, match_opcode
, 0},
2075 {"vmnand.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMNANDMM
, MASK_VMNANDMM
, match_opcode
, 0},
2076 {"vmandn.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMANDNMM
, MASK_VMANDNMM
, match_opcode
, 0},
2077 {"vmandnot.mm",0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMANDNMM
, MASK_VMANDNMM
, match_opcode
, INSN_ALIAS
},
2078 {"vmxor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMXORMM
, MASK_VMXORMM
, match_opcode
, 0},
2079 {"vmor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMORMM
, MASK_VMORMM
, match_opcode
, 0},
2080 {"vmnor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMNORMM
, MASK_VMNORMM
, match_opcode
, 0},
2081 {"vmorn.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMORNMM
, MASK_VMORNMM
, match_opcode
, 0},
2082 {"vmornot.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMORNMM
, MASK_VMORNMM
, match_opcode
, INSN_ALIAS
},
2083 {"vmxnor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMXNORMM
, MASK_VMXNORMM
, match_opcode
, 0},
2085 {"vcpop.m", 0, INSN_CLASS_V
, "d,VtVm", MATCH_VCPOPM
, MASK_VCPOPM
, match_opcode
, 0},
2086 {"vpopc.m", 0, INSN_CLASS_V
, "d,VtVm", MATCH_VCPOPM
, MASK_VCPOPM
, match_opcode
, INSN_ALIAS
},
2087 {"vfirst.m", 0, INSN_CLASS_V
, "d,VtVm", MATCH_VFIRSTM
, MASK_VFIRSTM
, match_opcode
, 0},
2088 {"vmsbf.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VMSBFM
, MASK_VMSBFM
, match_opcode
, 0},
2089 {"vmsif.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VMSIFM
, MASK_VMSIFM
, match_opcode
, 0},
2090 {"vmsof.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VMSOFM
, MASK_VMSOFM
, match_opcode
, 0},
2091 {"viota.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VIOTAM
, MASK_VIOTAM
, match_opcode
, 0},
2092 {"vid.v", 0, INSN_CLASS_V
, "VdVm", MATCH_VIDV
, MASK_VIDV
, match_opcode
, 0},
2094 {"vmv.x.s", 0, INSN_CLASS_V
, "d,Vt", MATCH_VMVXS
, MASK_VMVXS
, match_opcode
, 0},
2095 {"vmv.s.x", 0, INSN_CLASS_V
, "Vd,s", MATCH_VMVSX
, MASK_VMVSX
, match_opcode
, 0},
2097 {"vfmv.f.s", 0, INSN_CLASS_ZVEF
, "D,Vt", MATCH_VFMVFS
, MASK_VFMVFS
, match_opcode
, 0},
2098 {"vfmv.s.f", 0, INSN_CLASS_ZVEF
, "Vd,S", MATCH_VFMVSF
, MASK_VFMVSF
, match_opcode
, 0},
2100 {"vslideup.vx",0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDEUPVX
, MASK_VSLIDEUPVX
, match_opcode
, 0},
2101 {"vslideup.vi",0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSLIDEUPVI
, MASK_VSLIDEUPVI
, match_opcode
, 0},
2102 {"vslidedown.vx",0,INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDEDOWNVX
, MASK_VSLIDEDOWNVX
, match_opcode
, 0},
2103 {"vslidedown.vi",0,INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSLIDEDOWNVI
, MASK_VSLIDEDOWNVI
, match_opcode
, 0},
2105 {"vslide1up.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDE1UPVX
, MASK_VSLIDE1UPVX
, match_opcode
, 0},
2106 {"vslide1down.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDE1DOWNVX
, MASK_VSLIDE1DOWNVX
, match_opcode
, 0},
2107 {"vfslide1up.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSLIDE1UPVF
, MASK_VFSLIDE1UPVF
, match_opcode
, 0},
2108 {"vfslide1down.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSLIDE1DOWNVF
, MASK_VFSLIDE1DOWNVF
, match_opcode
, 0},
2110 {"vrgather.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VRGATHERVV
, MASK_VRGATHERVV
, match_opcode
, 0},
2111 {"vrgather.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VRGATHERVX
, MASK_VRGATHERVX
, match_opcode
, 0},
2112 {"vrgather.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VRGATHERVI
, MASK_VRGATHERVI
, match_opcode
, 0},
2113 {"vrgatherei16.vv",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VRGATHEREI16VV
, MASK_VRGATHEREI16VV
, match_opcode
, 0},
2115 {"vcompress.vm",0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VCOMPRESSVM
, MASK_VCOMPRESSVM
, match_opcode
, 0},
2117 {"vmv1r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV1RV
, MASK_VMV1RV
, match_opcode
, 0},
2118 {"vmv2r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV2RV
, MASK_VMV2RV
, match_opcode
, 0},
2119 {"vmv4r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV4RV
, MASK_VMV4RV
, match_opcode
, 0},
2120 {"vmv8r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV8RV
, MASK_VMV8RV
, match_opcode
, 0},
2122 /* Zvfbfmin instructions. */
2123 {"vfncvtbf16.f.f.w", 0, INSN_CLASS_ZVFBFMIN
, "Vd,VtVm", MATCH_VFNCVTBF16_F_F_W
, MASK_VFNCVTBF16_F_F_W
, match_opcode
, 0},
2124 {"vfwcvtbf16.f.f.v", 0, INSN_CLASS_ZVFBFMIN
, "Vd,VtVm", MATCH_VFWCVTBF16_F_F_V
, MASK_VFWCVTBF16_F_F_V
, match_opcode
, 0},
2126 /* Zvfbfwma instructions. */
2127 {"vfwmaccbf16.vf", 0, INSN_CLASS_ZVFBFWMA
, "Vd,S,VtVm", MATCH_VFWMACCBF16_VF
, MASK_VFWMACCBF16_VF
, match_opcode
, 0},
2128 {"vfwmaccbf16.vv", 0, INSN_CLASS_ZVFBFWMA
, "Vd,Vs,VtVm", MATCH_VFWMACCBF16_VV
, MASK_VFWMACCBF16_VV
, match_opcode
, 0},
2130 /* Zvbb/Zvkb instructions. */
2131 {"vandn.vv", 0, INSN_CLASS_ZVKB
, "Vd,Vt,VsVm", MATCH_VANDN_VV
, MASK_VANDN_VV
, match_opcode
, 0},
2132 {"vandn.vx", 0, INSN_CLASS_ZVKB
, "Vd,Vt,sVm", MATCH_VANDN_VX
, MASK_VANDN_VX
, match_opcode
, 0},
2133 {"vbrev.v", 0, INSN_CLASS_ZVBB
, "Vd,VtVm", MATCH_VBREV_V
, MASK_VBREV_V
, match_opcode
, 0},
2134 {"vbrev8.v", 0, INSN_CLASS_ZVKB
, "Vd,VtVm", MATCH_VBREV8_V
, MASK_VBREV8_V
, match_opcode
, 0},
2135 {"vrev8.v", 0, INSN_CLASS_ZVKB
, "Vd,VtVm", MATCH_VREV8_V
, MASK_VREV8_V
, match_opcode
, 0},
2136 {"vclz.v", 0, INSN_CLASS_ZVBB
, "Vd,VtVm", MATCH_VCLZ_V
, MASK_VCLZ_V
, match_opcode
, 0},
2137 {"vctz.v", 0, INSN_CLASS_ZVBB
, "Vd,VtVm", MATCH_VCTZ_V
, MASK_VCTZ_V
, match_opcode
, 0},
2138 {"vcpop.v", 0, INSN_CLASS_ZVBB
, "Vd,VtVm", MATCH_VCPOP_V
, MASK_VCPOP_V
, match_opcode
, 0},
2139 {"vrol.vv", 0, INSN_CLASS_ZVKB
, "Vd,Vt,VsVm", MATCH_VROL_VV
, MASK_VROL_VV
, match_opcode
, 0},
2140 {"vrol.vx", 0, INSN_CLASS_ZVKB
, "Vd,Vt,sVm", MATCH_VROL_VX
, MASK_VROL_VX
, match_opcode
, 0},
2141 {"vror.vv", 0, INSN_CLASS_ZVKB
, "Vd,Vt,VsVm", MATCH_VROR_VV
, MASK_VROR_VV
, match_opcode
, 0},
2142 {"vror.vx", 0, INSN_CLASS_ZVKB
, "Vd,Vt,sVm", MATCH_VROR_VX
, MASK_VROR_VX
, match_opcode
, 0},
2143 {"vror.vi", 0, INSN_CLASS_ZVKB
, "Vd,Vt,VlVm", MATCH_VROR_VI
, MASK_VROR_VI
, match_opcode
, 0},
2144 {"vwsll.vv", 0, INSN_CLASS_ZVBB
, "Vd,Vt,VsVm", MATCH_VWSLL_VV
, MASK_VWSLL_VV
, match_opcode
, 0},
2145 {"vwsll.vx", 0, INSN_CLASS_ZVBB
, "Vd,Vt,sVm", MATCH_VWSLL_VX
, MASK_VWSLL_VX
, match_opcode
, 0},
2146 {"vwsll.vi", 0, INSN_CLASS_ZVBB
, "Vd,Vt,VjVm", MATCH_VWSLL_VI
, MASK_VWSLL_VI
, match_opcode
, 0},
2148 /* Zvbc instructions. */
2149 {"vclmul.vv", 0, INSN_CLASS_ZVBC
, "Vd,Vt,VsVm", MATCH_VCLMUL_VV
, MASK_VCLMUL_VV
, match_opcode
, 0},
2150 {"vclmul.vx", 0, INSN_CLASS_ZVBC
, "Vd,Vt,sVm", MATCH_VCLMUL_VX
, MASK_VCLMUL_VX
, match_opcode
, 0},
2151 {"vclmulh.vv", 0, INSN_CLASS_ZVBC
, "Vd,Vt,VsVm", MATCH_VCLMULH_VV
, MASK_VCLMULH_VV
, match_opcode
, 0},
2152 {"vclmulh.vx", 0, INSN_CLASS_ZVBC
, "Vd,Vt,sVm", MATCH_VCLMULH_VX
, MASK_VCLMULH_VX
, match_opcode
, 0},
2154 /* Zvkg instructions. */
2155 {"vghsh.vv", 0, INSN_CLASS_ZVKG
, "Vd,Vt,Vs", MATCH_VGHSH_VV
, MASK_VGHSH_VV
, match_opcode
, 0},
2156 {"vgmul.vv", 0, INSN_CLASS_ZVKG
, "Vd,Vt", MATCH_VGMUL_VV
, MASK_VGMUL_VV
, match_opcode
, 0},
2158 /* Zvkned instructions. */
2159 {"vaesdf.vv", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESDF_VV
, MASK_VAESDF_VV
, match_opcode
, 0},
2160 {"vaesdf.vs", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESDF_VS
, MASK_VAESDF_VV
, match_opcode
, 0},
2161 {"vaesdm.vv", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESDM_VV
, MASK_VAESDM_VV
, match_opcode
, 0},
2162 {"vaesdm.vs", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESDM_VS
, MASK_VAESDM_VV
, match_opcode
, 0},
2163 {"vaesef.vv", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESEF_VV
, MASK_VAESEF_VV
, match_opcode
, 0},
2164 {"vaesef.vs", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESEF_VS
, MASK_VAESEF_VV
, match_opcode
, 0},
2165 {"vaesem.vv", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESEM_VV
, MASK_VAESEM_VV
, match_opcode
, 0},
2166 {"vaesem.vs", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESEM_VS
, MASK_VAESEM_VV
, match_opcode
, 0},
2167 {"vaeskf1.vi", 0, INSN_CLASS_ZVKNED
, "Vd,Vt,Vj", MATCH_VAESKF1_VI
, MASK_VAESKF1_VI
, match_opcode
, 0},
2168 {"vaeskf2.vi", 0, INSN_CLASS_ZVKNED
, "Vd,Vt,Vj", MATCH_VAESKF2_VI
, MASK_VAESKF2_VI
, match_opcode
, 0},
2169 {"vaesz.vs", 0, INSN_CLASS_ZVKNED
, "Vd,Vt", MATCH_VAESZ_VS
, MASK_VAESZ_VS
, match_opcode
, 0},
2171 /* Zvknh[a,b] instructions. */
2172 {"vsha2ch.vv", 0, INSN_CLASS_ZVKNHA_OR_ZVKNHB
, "Vd,Vt,Vs", MATCH_VSHA2CH_VV
, MASK_VSHA2CH_VV
, match_opcode
, 0},
2173 {"vsha2cl.vv", 0, INSN_CLASS_ZVKNHA_OR_ZVKNHB
, "Vd,Vt,Vs", MATCH_VSHA2CL_VV
, MASK_VSHA2CL_VV
, match_opcode
, 0},
2174 {"vsha2ms.vv", 0, INSN_CLASS_ZVKNHA_OR_ZVKNHB
, "Vd,Vt,Vs", MATCH_VSHA2MS_VV
, MASK_VSHA2MS_VV
, match_opcode
, 0},
2176 /* Zvksed instructions. */
2177 {"vsm4k.vi", 0, INSN_CLASS_ZVKSED
, "Vd,Vt,Vj", MATCH_VSM4K_VI
, MASK_VSM4K_VI
, match_opcode
, 0},
2178 {"vsm4r.vv", 0, INSN_CLASS_ZVKSED
, "Vd,Vt", MATCH_VSM4R_VV
, MASK_VSM4R_VV
, match_opcode
, 0},
2179 {"vsm4r.vs", 0, INSN_CLASS_ZVKSED
, "Vd,Vt", MATCH_VSM4R_VS
, MASK_VSM4R_VS
, match_opcode
, 0},
2181 /* Zvksh instructions. */
2182 {"vsm3c.vi", 0, INSN_CLASS_ZVKSH
, "Vd,Vt,Vj", MATCH_VSM3C_VI
, MASK_VSM3C_VI
, match_opcode
, 0},
2183 {"vsm3me.vv", 0, INSN_CLASS_ZVKSH
, "Vd,Vt,Vs", MATCH_VSM3ME_VV
, MASK_VSM3ME_VV
, match_opcode
, 0},
2185 /* ZCB instructions. */
2186 {"c.lbu", 0, INSN_CLASS_ZCB
, "Ct,Wcb(Cs)", MATCH_C_LBU
, MASK_C_LBU
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
2187 {"c.lhu", 0, INSN_CLASS_ZCB
, "Ct,Wch(Cs)", MATCH_C_LHU
, MASK_C_LHU
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
2188 {"c.lh", 0, INSN_CLASS_ZCB
, "Ct,Wch(Cs)", MATCH_C_LH
, MASK_C_LH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
2189 {"c.sb", 0, INSN_CLASS_ZCB
, "Ct,Wcb(Cs)", MATCH_C_SB
, MASK_C_SB
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
2190 {"c.sh", 0, INSN_CLASS_ZCB
, "Ct,Wch(Cs)", MATCH_C_SH
, MASK_C_SH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
2191 {"c.not", 0, INSN_CLASS_ZCB
, "Cs", MATCH_C_NOT
, MASK_C_NOT
, match_opcode
, 0 },
2192 {"c.mul", 0, INSN_CLASS_ZCB_AND_ZMMUL
, "Cs,Ct", MATCH_C_MUL
, MASK_C_MUL
, match_opcode
, 0 },
2193 {"c.sext.b", 0, INSN_CLASS_ZCB_AND_ZBB
, "Cs", MATCH_C_SEXT_B
, MASK_C_SEXT_B
, match_opcode
, 0 },
2194 {"c.sext.h", 0, INSN_CLASS_ZCB_AND_ZBB
, "Cs", MATCH_C_SEXT_H
, MASK_C_SEXT_H
, match_opcode
, 0 },
2195 {"c.zext.h", 0, INSN_CLASS_ZCB_AND_ZBB
, "Cs", MATCH_C_ZEXT_H
, MASK_C_ZEXT_H
, match_opcode
, 0 },
2196 {"c.zext.w", 64, INSN_CLASS_ZCB_AND_ZBA
, "Cs", MATCH_C_ZEXT_W
, MASK_C_ZEXT_W
, match_opcode
, 0 },
2197 {"c.zext.b", 0, INSN_CLASS_ZCB
, "Cs", MATCH_C_ZEXT_B
, MASK_C_ZEXT_B
, match_opcode
, 0 },
2198 {"c.sext.w", 64, INSN_CLASS_ZCB
, "d", MATCH_C_ADDIW
, MASK_C_ADDIW
|MASK_RVC_IMM
, match_rd_nonzero
, INSN_ALIAS
},
2200 /* Zcmop instructions. */
2201 {"c.mop.1", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_1
, MASK_C_MOP_1
, match_opcode
, 0 },
2202 {"c.mop.3", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_3
, MASK_C_MOP_3
, match_opcode
, 0 },
2203 {"c.mop.5", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_5
, MASK_C_MOP_5
, match_opcode
, 0 },
2204 {"c.mop.7", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_7
, MASK_C_MOP_7
, match_opcode
, 0 },
2205 {"c.mop.9", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_9
, MASK_C_MOP_9
, match_opcode
, 0 },
2206 {"c.mop.11", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_11
, MASK_C_MOP_11
, match_opcode
, 0 },
2207 {"c.mop.13", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_13
, MASK_C_MOP_13
, match_opcode
, 0 },
2208 {"c.mop.15", 0, INSN_CLASS_ZCMOP
, "", MATCH_C_MOP_15
, MASK_C_MOP_15
, match_opcode
, 0 },
2210 /* Zcmp instructions. */
2211 {"cm.push", 0, INSN_CLASS_ZCMP
, "{Wcr},Wcp", MATCH_CM_PUSH
, MASK_CM_PUSH
, match_opcode
, 0 },
2212 {"cm.pop", 0, INSN_CLASS_ZCMP
, "{Wcr},Wcp", MATCH_CM_POP
, MASK_CM_POP
, match_opcode
, 0 },
2213 {"cm.popret", 0, INSN_CLASS_ZCMP
, "{Wcr},Wcp", MATCH_CM_POPRET
, MASK_CM_POPRET
, match_opcode
, 0 },
2214 {"cm.popretz", 0, INSN_CLASS_ZCMP
, "{Wcr},Wcp", MATCH_CM_POPRETZ
, MASK_CM_POPRETZ
, match_opcode
, 0 },
2215 {"cm.mva01s", 0, INSN_CLASS_ZCMP
, "Wc1,Wc2", MATCH_CM_MVA01S
, MASK_CM_MVA01S
, match_opcode
, 0 },
2216 {"cm.mvsa01", 0, INSN_CLASS_ZCMP
, "Wc1,Wc2", MATCH_CM_MVSA01
, MASK_CM_MVSA01
, match_sreg1_not_eq_sreg2
, 0 },
2218 /* Zcmt instructions */
2219 {"cm.jt", 0, INSN_CLASS_ZCMT
, "WcI", MATCH_CM_JT
, MASK_CM_JT
, match_cm_jt
, 0 },
2220 {"cm.jalt", 0, INSN_CLASS_ZCMT
, "Wci", MATCH_CM_JALT
, MASK_CM_JALT
, match_cm_jalt
, 0 },
2222 /* Supervisor instructions. */
2223 {"csrr", 0, INSN_CLASS_ZICSR
, "d,E", MATCH_CSRRS
, MASK_CSRRS
|MASK_RS1
, match_opcode
, INSN_ALIAS
},
2224 {"csrwi", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRWI
, MASK_CSRRWI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2225 {"csrw", 0, INSN_CLASS_ZICSR
, "E,s", MATCH_CSRRW
, MASK_CSRRW
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2226 {"csrw", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRWI
, MASK_CSRRWI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2227 {"csrsi", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRSI
, MASK_CSRRSI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2228 {"csrs", 0, INSN_CLASS_ZICSR
, "E,s", MATCH_CSRRS
, MASK_CSRRS
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2229 {"csrs", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRSI
, MASK_CSRRSI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2230 {"csrci", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRCI
, MASK_CSRRCI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2231 {"csrc", 0, INSN_CLASS_ZICSR
, "E,s", MATCH_CSRRC
, MASK_CSRRC
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2232 {"csrc", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRCI
, MASK_CSRRCI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
2233 {"csrrwi", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRWI
, MASK_CSRRWI
, match_opcode
, 0 },
2234 {"csrrw", 0, INSN_CLASS_ZICSR
, "d,E,s", MATCH_CSRRW
, MASK_CSRRW
, match_opcode
, 0 },
2235 {"csrrw", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRWI
, MASK_CSRRWI
, match_opcode
, INSN_ALIAS
},
2236 {"csrrsi", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRSI
, MASK_CSRRSI
, match_opcode
, 0 },
2237 {"csrrs", 0, INSN_CLASS_ZICSR
, "d,E,s", MATCH_CSRRS
, MASK_CSRRS
, match_opcode
, 0 },
2238 {"csrrs", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRSI
, MASK_CSRRSI
, match_opcode
, INSN_ALIAS
},
2239 {"csrrci", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRCI
, MASK_CSRRCI
, match_opcode
, 0 },
2240 {"csrrc", 0, INSN_CLASS_ZICSR
, "d,E,s", MATCH_CSRRC
, MASK_CSRRC
, match_opcode
, 0 },
2241 {"csrrc", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRCI
, MASK_CSRRCI
, match_opcode
, INSN_ALIAS
},
2242 {"uret", 0, INSN_CLASS_I
, "", MATCH_URET
, MASK_URET
, match_opcode
, 0 },
2243 {"sret", 0, INSN_CLASS_I
, "", MATCH_SRET
, MASK_SRET
, match_opcode
, 0 },
2244 {"hret", 0, INSN_CLASS_I
, "", MATCH_HRET
, MASK_HRET
, match_opcode
, 0 },
2245 {"mret", 0, INSN_CLASS_I
, "", MATCH_MRET
, MASK_MRET
, match_opcode
, 0 },
2246 {"dret", 0, INSN_CLASS_I
, "", MATCH_DRET
, MASK_DRET
, match_opcode
, 0 },
2247 {"sfence.vm", 0, INSN_CLASS_I
, "", MATCH_SFENCE_VM
, MASK_SFENCE_VM
| MASK_RS1
, match_opcode
, 0 },
2248 {"sfence.vm", 0, INSN_CLASS_I
, "s", MATCH_SFENCE_VM
, MASK_SFENCE_VM
, match_opcode
, 0 },
2249 {"sfence.vma", 0, INSN_CLASS_I
, "", MATCH_SFENCE_VMA
, MASK_SFENCE_VMA
|MASK_RS1
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
2250 {"sfence.vma", 0, INSN_CLASS_I
, "s", MATCH_SFENCE_VMA
, MASK_SFENCE_VMA
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
2251 {"sfence.vma", 0, INSN_CLASS_I
, "s,t", MATCH_SFENCE_VMA
, MASK_SFENCE_VMA
, match_opcode
, 0 },
2252 {"wfi", 0, INSN_CLASS_I
, "", MATCH_WFI
, MASK_WFI
, match_opcode
, 0 },
2254 /* Svinval instructions. */
2255 {"sinval.vma", 0, INSN_CLASS_SVINVAL
, "s,t", MATCH_SINVAL_VMA
, MASK_SINVAL_VMA
, match_opcode
, 0 },
2256 {"sfence.w.inval", 0, INSN_CLASS_SVINVAL
, "", MATCH_SFENCE_W_INVAL
, MASK_SFENCE_W_INVAL
, match_opcode
, 0 },
2257 {"sfence.inval.ir", 0, INSN_CLASS_SVINVAL
, "", MATCH_SFENCE_INVAL_IR
, MASK_SFENCE_INVAL_IR
, match_opcode
, 0 },
2258 {"hinval.vvma", 0, INSN_CLASS_SVINVAL
, "s,t", MATCH_HINVAL_VVMA
, MASK_HINVAL_VVMA
, match_opcode
, 0 },
2259 {"hinval.gvma", 0, INSN_CLASS_SVINVAL
, "s,t", MATCH_HINVAL_GVMA
, MASK_HINVAL_GVMA
, match_opcode
, 0 },
2261 /* Hypervisor instructions. */
2262 {"hfence.vvma", 0, INSN_CLASS_H
, "", MATCH_HFENCE_VVMA
, MASK_HFENCE_VVMA
|MASK_RS1
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
2263 {"hfence.vvma", 0, INSN_CLASS_H
, "s", MATCH_HFENCE_VVMA
, MASK_HFENCE_VVMA
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
2264 {"hfence.vvma", 0, INSN_CLASS_H
, "s,t", MATCH_HFENCE_VVMA
, MASK_HFENCE_VVMA
, match_opcode
, 0 },
2265 {"hfence.gvma", 0, INSN_CLASS_H
, "", MATCH_HFENCE_GVMA
, MASK_HFENCE_GVMA
|MASK_RS1
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
2266 {"hfence.gvma", 0, INSN_CLASS_H
, "s", MATCH_HFENCE_GVMA
, MASK_HFENCE_GVMA
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
2267 {"hfence.gvma", 0, INSN_CLASS_H
, "s,t", MATCH_HFENCE_GVMA
, MASK_HFENCE_GVMA
, match_opcode
, 0 },
2268 {"hlv.b", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_B
, MASK_HLV_B
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
2269 {"hlv.bu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_BU
, MASK_HLV_BU
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
2270 {"hlv.h", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_H
, MASK_HLV_H
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
2271 {"hlv.hu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_HU
, MASK_HLV_HU
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
2272 {"hlvx.hu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLVX_HU
, MASK_HLVX_HU
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
2273 {"hlv.w", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_W
, MASK_HLV_W
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
2274 {"hlv.wu", 64, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_WU
, MASK_HLV_WU
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
2275 {"hlvx.wu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLVX_WU
, MASK_HLVX_WU
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
2276 {"hlv.d", 64, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_D
, MASK_HLV_D
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
2277 {"hsv.b", 0, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_B
, MASK_HSV_B
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
2278 {"hsv.h", 0, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_H
, MASK_HSV_H
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
2279 {"hsv.w", 0, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_W
, MASK_HSV_W
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
2280 {"hsv.d", 64, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_D
, MASK_HSV_D
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
2282 /* Vendor-specific (CORE-V) Xcvmac instructions. */
2283 {"cv.mac", 0, INSN_CLASS_XCVMAC
, "d,s,t", MATCH_CV_MAC
, MASK_CV_MAC
, match_opcode
, 0},
2284 {"cv.msu", 0, INSN_CLASS_XCVMAC
, "d,s,t", MATCH_CV_MSU
, MASK_CV_MSU
, match_opcode
, 0},
2285 {"cv.mulsn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULSN
, MASK_CV_MULSN
, match_opcode
, 0},
2286 {"cv.muls", 0, INSN_CLASS_XCVMAC
, "d,s,t", MATCH_CV_MULSN
, MASK_CV_MULSN
|MASK_CV_IS3_UIMM5
, match_opcode
, INSN_ALIAS
},
2287 {"cv.mulsrn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULSRN
, MASK_CV_MULSRN
, match_opcode
, 0},
2288 {"cv.mulhhsn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULHHSN
, MASK_CV_MULHHSN
, match_opcode
, 0},
2289 {"cv.mulhhs", 0, INSN_CLASS_XCVMAC
, "d,s,t", MATCH_CV_MULHHSN
, MASK_CV_MULHHSN
|MASK_CV_IS3_UIMM5
, match_opcode
, INSN_ALIAS
},
2290 {"cv.mulhhsrn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULHHSRN
, MASK_CV_MULHHSRN
, match_opcode
, 0},
2291 {"cv.mulun", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULUN
, MASK_CV_MULUN
, match_opcode
, 0},
2292 {"cv.mulu", 0, INSN_CLASS_XCVMAC
, "d,s,t", MATCH_CV_MULUN
, MASK_CV_MULUN
|MASK_CV_IS3_UIMM5
, match_opcode
, INSN_ALIAS
},
2293 {"cv.mulurn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULURN
, MASK_CV_MULURN
, match_opcode
, 0},
2294 {"cv.mulhhun", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULHHUN
, MASK_CV_MULHHUN
, match_opcode
, 0},
2295 {"cv.mulhhu", 0, INSN_CLASS_XCVMAC
, "d,s,t", MATCH_CV_MULHHUN
, MASK_CV_MULHHUN
|MASK_CV_IS3_UIMM5
, match_opcode
, INSN_ALIAS
},
2296 {"cv.mulhhurn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MULHHURN
, MASK_CV_MULHHURN
, match_opcode
, 0},
2297 {"cv.macsn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACSN
, MASK_CV_MACSN
, match_opcode
, 0},
2298 {"cv.machhsn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACHHSN
, MASK_CV_MACHHSN
, match_opcode
, 0},
2299 {"cv.macsrn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACSRN
, MASK_CV_MACSRN
, match_opcode
, 0},
2300 {"cv.machhsrn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACHHSRN
, MASK_CV_MACHHSRN
, match_opcode
, 0},
2301 {"cv.macun", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACUN
, MASK_CV_MACUN
, match_opcode
, 0},
2302 {"cv.machhun", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACHHUN
, MASK_CV_MACHHUN
, match_opcode
, 0},
2303 {"cv.macurn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACURN
, MASK_CV_MACURN
, match_opcode
, 0},
2304 {"cv.machhurn", 0, INSN_CLASS_XCVMAC
, "d,s,t,Xc3", MATCH_CV_MACHHURN
, MASK_CV_MACHHURN
, match_opcode
, 0},
2306 /* Vendor-specific (CORE-V) Xcvalu instructions. */
2307 {"cv.abs", 0, INSN_CLASS_XCVALU
, "d,s", MATCH_CV_ABS
, MASK_CV_ABS
, match_opcode
, 0},
2308 {"cv.exths", 0, INSN_CLASS_XCVALU
, "d,s", MATCH_CV_EXTHS
, MASK_CV_EXTHS
, match_opcode
, 0},
2309 {"cv.exthz", 0, INSN_CLASS_XCVALU
, "d,s", MATCH_CV_EXTHZ
, MASK_CV_EXTHZ
, match_opcode
, 0},
2310 {"cv.extbs", 0, INSN_CLASS_XCVALU
, "d,s", MATCH_CV_EXTBS
, MASK_CV_EXTBS
, match_opcode
, 0},
2311 {"cv.extbz", 0, INSN_CLASS_XCVALU
, "d,s", MATCH_CV_EXTBZ
, MASK_CV_EXTBZ
, match_opcode
, 0},
2312 {"cv.sle", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SLE
, MASK_CV_SLE
, match_opcode
, 0},
2313 {"cv.slet", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SLET
, MASK_CV_SLET
, match_opcode
, INSN_ALIAS
},
2314 {"cv.sleu", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SLEU
, MASK_CV_SLEU
, match_opcode
, 0},
2315 {"cv.sletu", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SLETU
, MASK_CV_SLETU
, match_opcode
, INSN_ALIAS
},
2316 {"cv.min", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_MIN
, MASK_CV_MIN
, match_opcode
, 0},
2317 {"cv.minu", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_MINU
, MASK_CV_MINU
, match_opcode
, 0},
2318 {"cv.max", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_MAX
, MASK_CV_MAX
, match_opcode
, 0},
2319 {"cv.maxu", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_MAXU
, MASK_CV_MAXU
, match_opcode
, 0},
2320 {"cv.clip", 0, INSN_CLASS_XCVALU
, "d,s,Xc2", MATCH_CV_CLIP
, MASK_CV_CLIP
, match_opcode
, 0},
2321 {"cv.clipu", 0, INSN_CLASS_XCVALU
, "d,s,Xc2", MATCH_CV_CLIPU
, MASK_CV_CLIPU
, match_opcode
, 0},
2322 {"cv.clipr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_CLIPR
, MASK_CV_CLIPR
, match_opcode
, 0},
2323 {"cv.clipur", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_CLIPUR
, MASK_CV_CLIPUR
, match_opcode
, 0},
2324 {"cv.addn", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_ADDN
, MASK_CV_ADDN
, match_opcode
, 0},
2325 {"cv.addun", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_ADDUN
, MASK_CV_ADDUN
, match_opcode
, 0},
2326 {"cv.addunr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_ADDUNR
, MASK_CV_ADDUNR
, match_opcode
, 0},
2327 {"cv.addrn", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_ADDRN
, MASK_CV_ADDRN
, match_opcode
, 0},
2328 {"cv.addurn", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_ADDURN
, MASK_CV_ADDURN
, match_opcode
, 0},
2329 {"cv.addnr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_ADDNR
, MASK_CV_ADDNR
, match_opcode
, 0},
2330 {"cv.addrnr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_ADDRNR
, MASK_CV_ADDRNR
, match_opcode
, 0},
2331 {"cv.addurnr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_ADDURNR
, MASK_CV_ADDURNR
, match_opcode
, 0},
2332 {"cv.subn", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_SUBN
, MASK_CV_SUBN
, match_opcode
, 0},
2333 {"cv.subun", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_SUBUN
, MASK_CV_SUBUN
, match_opcode
, 0},
2334 {"cv.subrn", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_SUBRN
, MASK_CV_SUBRN
, match_opcode
, 0},
2335 {"cv.suburn", 0, INSN_CLASS_XCVALU
, "d,s,t,Xc3", MATCH_CV_SUBURN
, MASK_CV_SUBURN
, match_opcode
, 0},
2336 {"cv.subnr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SUBNR
, MASK_CV_SUBNR
, match_opcode
, 0},
2337 {"cv.subunr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SUBUNR
, MASK_CV_SUBUNR
, match_opcode
, 0},
2338 {"cv.subrnr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SUBRNR
, MASK_CV_SUBRNR
, match_opcode
, 0},
2339 {"cv.suburnr", 0, INSN_CLASS_XCVALU
, "d,s,t", MATCH_CV_SUBURNR
, MASK_CV_SUBURNR
, match_opcode
, 0},
2341 /* Vendor-specific (CORE-V) Xcvelw instructions. */
2342 {"cv.elw", 0, INSN_CLASS_XCVELW
, "d,o(s)", MATCH_CV_ELW
, MASK_CV_ELW
, match_opcode
, 0},
2344 /* Vendor-specific (CORE-V) Xcvbi instructions. */
2345 {"cv.beqimm", 0, INSN_CLASS_XCVBI
, "s,Xc4,p", MATCH_CV_BEQIMM
, MASK_CV_BEQIMM
, match_opcode
, 0},
2346 {"cv.bneimm", 0, INSN_CLASS_XCVBI
, "s,Xc4,p", MATCH_CV_BNEIMM
, MASK_CV_BNEIMM
, match_opcode
, 0},
2348 /* Vendor-specific (CORE-V) Xcvmem instructions. */
2349 {"cv.lb", 0, INSN_CLASS_XCVMEM
, "d,(s),o", MATCH_CV_LBPOST
, MASK_CV_LBPOST
, match_opcode
, 0},
2350 {"cv.lb", 0, INSN_CLASS_XCVMEM
, "d,(s),t", MATCH_CV_LBRRPOST
, MASK_CV_LBRRPOST
, match_opcode
, 0},
2351 {"cv.lb", 0, INSN_CLASS_XCVMEM
, "d,t(s)", MATCH_CV_LBRR
, MASK_CV_LBRR
, match_opcode
, 0},
2352 {"cv.lbu",0, INSN_CLASS_XCVMEM
, "d,(s),o", MATCH_CV_LBUPOST
, MASK_CV_LBUPOST
, match_opcode
, 0},
2353 {"cv.lbu",0, INSN_CLASS_XCVMEM
, "d,(s),t", MATCH_CV_LBURRPOST
, MASK_CV_LBURRPOST
, match_opcode
, 0},
2354 {"cv.lbu",0, INSN_CLASS_XCVMEM
, "d,t(s)", MATCH_CV_LBURR
, MASK_CV_LBURR
, match_opcode
, 0},
2355 {"cv.lh", 0, INSN_CLASS_XCVMEM
, "d,(s),o", MATCH_CV_LHPOST
, MASK_CV_LHPOST
, match_opcode
, 0},
2356 {"cv.lh", 0, INSN_CLASS_XCVMEM
, "d,(s),t", MATCH_CV_LHRRPOST
, MASK_CV_LHRRPOST
, match_opcode
, 0},
2357 {"cv.lh", 0, INSN_CLASS_XCVMEM
, "d,t(s)", MATCH_CV_LHRR
, MASK_CV_LHRR
, match_opcode
, 0},
2358 {"cv.lhu",0, INSN_CLASS_XCVMEM
, "d,(s),o", MATCH_CV_LHUPOST
, MASK_CV_LHUPOST
, match_opcode
, 0},
2359 {"cv.lhu",0, INSN_CLASS_XCVMEM
, "d,(s),t", MATCH_CV_LHURRPOST
, MASK_CV_LHURRPOST
, match_opcode
, 0},
2360 {"cv.lhu",0, INSN_CLASS_XCVMEM
, "d,t(s)", MATCH_CV_LHURR
, MASK_CV_LHURR
, match_opcode
, 0},
2361 {"cv.lw", 0, INSN_CLASS_XCVMEM
, "d,(s),o", MATCH_CV_LWPOST
, MASK_CV_LWPOST
, match_opcode
, 0},
2362 {"cv.lw", 0, INSN_CLASS_XCVMEM
, "d,(s),t", MATCH_CV_LWRRPOST
, MASK_CV_LWRRPOST
, match_opcode
, 0},
2363 {"cv.lw", 0, INSN_CLASS_XCVMEM
, "d,t(s)", MATCH_CV_LWRR
, MASK_CV_LWRR
, match_opcode
, 0},
2364 {"cv.sb", 0, INSN_CLASS_XCVMEM
, "t,(s),q", MATCH_CV_SBPOST
, MASK_CV_SBPOST
, match_opcode
, 0},
2365 {"cv.sb", 0, INSN_CLASS_XCVMEM
, "t,d(s)", MATCH_CV_SBRR
, MASK_CV_SBRR
, match_opcode
, 0},
2366 {"cv.sb", 0, INSN_CLASS_XCVMEM
, "t,(s),d", MATCH_CV_SBRRPOST
, MASK_CV_SBRRPOST
, match_opcode
, 0},
2367 {"cv.sh", 0, INSN_CLASS_XCVMEM
, "t,(s),q", MATCH_CV_SHPOST
, MASK_CV_SHPOST
, match_opcode
, 0},
2368 {"cv.sh", 0, INSN_CLASS_XCVMEM
, "t,d(s)", MATCH_CV_SHRR
, MASK_CV_SHRR
, match_opcode
, 0},
2369 {"cv.sh", 0, INSN_CLASS_XCVMEM
, "t,(s),d", MATCH_CV_SHRRPOST
, MASK_CV_SHRRPOST
, match_opcode
, 0},
2370 {"cv.sw", 0, INSN_CLASS_XCVMEM
, "t,(s),q", MATCH_CV_SWPOST
, MASK_CV_SWPOST
, match_opcode
, 0},
2371 {"cv.sw", 0, INSN_CLASS_XCVMEM
, "t,d(s)", MATCH_CV_SWRR
, MASK_CV_SWRR
, match_opcode
, 0},
2372 {"cv.sw", 0, INSN_CLASS_XCVMEM
, "t,(s),d", MATCH_CV_SWRRPOST
, MASK_CV_SWRRPOST
, match_opcode
, 0},
2374 /* Vendor-specific (CORE-V) Xcvbitmanip instructions. */
2375 {"cv.extractr", 0, INSN_CLASS_XCVBITMANIP
, "d,s,t", MATCH_CV_EXTRACTR
, MASK_CV_EXTRACTR
, match_opcode
, 0},
2376 {"cv.extractur", 0, INSN_CLASS_XCVBITMANIP
, "d,s,t", MATCH_CV_EXTRACTUR
, MASK_CV_EXTRACTUR
, match_opcode
, 0},
2377 {"cv.insertr", 0, INSN_CLASS_XCVBITMANIP
, "d,s,t", MATCH_CV_INSERTR
, MASK_CV_INSERTR
, match_opcode
, 0},
2378 {"cv.bclrr", 0, INSN_CLASS_XCVBITMANIP
, "d,s,t", MATCH_CV_BCLRR
, MASK_CV_BCLRR
, match_opcode
, 0},
2379 {"cv.bsetr", 0, INSN_CLASS_XCVBITMANIP
, "d,s,t", MATCH_CV_BSETR
, MASK_CV_BSETR
, match_opcode
, 0},
2380 {"cv.ror", 0, INSN_CLASS_XCVBITMANIP
, "d,s,t", MATCH_CV_ROR
, MASK_CV_ROR
, match_opcode
, 0},
2381 {"cv.ff1", 0, INSN_CLASS_XCVBITMANIP
, "d,s", MATCH_CV_FF1
, MASK_CV_FF1
, match_opcode
, 0},
2382 {"cv.fl1", 0, INSN_CLASS_XCVBITMANIP
, "d,s", MATCH_CV_FL1
, MASK_CV_FL1
, match_opcode
, 0},
2383 {"cv.clb", 0, INSN_CLASS_XCVBITMANIP
, "d,s", MATCH_CV_CLB
, MASK_CV_CLB
, match_opcode
, 0},
2384 {"cv.cnt", 0, INSN_CLASS_XCVBITMANIP
, "d,s", MATCH_CV_CNT
, MASK_CV_CNT
, match_opcode
, 0},
2386 {"cv.extract", 0, INSN_CLASS_XCVBITMANIP
, "d,s,Xc6,Xc2", MATCH_CV_EXTRACT
, MASK_CV_EXTRACT
, match_opcode
, 0},
2387 {"cv.extractu", 0, INSN_CLASS_XCVBITMANIP
, "d,s,Xc6,Xc2", MATCH_CV_EXTRACTU
, MASK_CV_EXTRACTU
, match_opcode
, 0},
2388 {"cv.insert", 0, INSN_CLASS_XCVBITMANIP
, "d,s,Xc6,Xc2", MATCH_CV_INSERT
, MASK_CV_INSERT
, match_opcode
, 0},
2389 {"cv.bclr", 0, INSN_CLASS_XCVBITMANIP
, "d,s,Xc6,Xc2", MATCH_CV_BCLR
, MASK_CV_BCLR
, match_opcode
, 0},
2390 {"cv.bset", 0, INSN_CLASS_XCVBITMANIP
, "d,s,Xc6,Xc2", MATCH_CV_BSET
, MASK_CV_BSET
, match_opcode
, 0},
2391 {"cv.bitrev", 0, INSN_CLASS_XCVBITMANIP
, "d,s,Xc7,Xc2", MATCH_CV_BITREV
, MASK_CV_BITREV
, match_opcode
, 0},
2393 /* Vendor-specific (CORE-V) Xcvsimd Instructions */
2394 {"cv.add.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_ADD_H
, MASK_CV_ADD_H
, match_opcode
, 0},
2395 {"cv.add.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_ADD_B
, MASK_CV_ADD_B
, match_opcode
, 0},
2396 {"cv.add.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_ADD_SC_H
, MASK_CV_ADD_SC_H
, match_opcode
, 0},
2397 {"cv.add.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_ADD_SC_B
, MASK_CV_ADD_SC_B
, match_opcode
, 0},
2398 {"cv.add.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_ADD_SCI_H
, MASK_CV_ADD_SCI_H
, match_opcode
, 0},
2399 {"cv.add.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_ADD_SCI_B
, MASK_CV_ADD_SCI_B
, match_opcode
, 0},
2400 {"cv.sub.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUB_H
, MASK_CV_SUB_H
, match_opcode
, 0},
2401 {"cv.sub.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUB_B
, MASK_CV_SUB_B
, match_opcode
, 0},
2402 {"cv.sub.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUB_SC_H
, MASK_CV_SUB_SC_H
, match_opcode
, 0},
2403 {"cv.sub.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUB_SC_B
, MASK_CV_SUB_SC_B
, match_opcode
, 0},
2404 {"cv.sub.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_SUB_SCI_H
, MASK_CV_SUB_SCI_H
, match_opcode
, 0},
2405 {"cv.sub.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_SUB_SCI_B
, MASK_CV_SUB_SCI_B
, match_opcode
, 0},
2406 {"cv.avg.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVG_H
, MASK_CV_AVG_H
, match_opcode
, 0},
2407 {"cv.avg.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVG_B
, MASK_CV_AVG_B
, match_opcode
, 0},
2408 {"cv.avg.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVG_SC_H
, MASK_CV_AVG_SC_H
, match_opcode
, 0},
2409 {"cv.avg.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVG_SC_B
, MASK_CV_AVG_SC_B
, match_opcode
, 0},
2410 {"cv.avg.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_AVG_SCI_H
, MASK_CV_AVG_SCI_H
, match_opcode
, 0},
2411 {"cv.avg.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_AVG_SCI_B
, MASK_CV_AVG_SCI_B
, match_opcode
, 0},
2412 {"cv.avgu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVGU_H
, MASK_CV_AVGU_H
, match_opcode
, 0},
2413 {"cv.avgu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVGU_B
, MASK_CV_AVGU_B
, match_opcode
, 0},
2414 {"cv.avgu.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVGU_SC_H
, MASK_CV_AVGU_SC_H
, match_opcode
, 0},
2415 {"cv.avgu.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AVGU_SC_B
, MASK_CV_AVGU_SC_B
, match_opcode
, 0},
2416 {"cv.avgu.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_AVGU_SCI_H
, MASK_CV_AVGU_SCI_H
, match_opcode
, 0},
2417 {"cv.avgu.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_AVGU_SCI_B
, MASK_CV_AVGU_SCI_B
, match_opcode
, 0},
2418 {"cv.min.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MIN_H
, MASK_CV_MIN_H
, match_opcode
, 0},
2419 {"cv.min.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MIN_B
, MASK_CV_MIN_B
, match_opcode
, 0},
2420 {"cv.min.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MIN_SC_H
, MASK_CV_MIN_SC_H
, match_opcode
, 0},
2421 {"cv.min.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MIN_SC_B
, MASK_CV_MIN_SC_B
, match_opcode
, 0},
2422 {"cv.min.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_MIN_SCI_H
, MASK_CV_MIN_SCI_H
, match_opcode
, 0},
2423 {"cv.min.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_MIN_SCI_B
, MASK_CV_MIN_SCI_B
, match_opcode
, 0},
2424 {"cv.minu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MINU_H
, MASK_CV_MINU_H
, match_opcode
, 0},
2425 {"cv.minu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MINU_B
, MASK_CV_MINU_B
, match_opcode
, 0},
2426 {"cv.minu.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MINU_SC_H
, MASK_CV_MINU_SC_H
, match_opcode
, 0},
2427 {"cv.minu.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MINU_SC_B
, MASK_CV_MINU_SC_B
, match_opcode
, 0},
2428 {"cv.minu.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_MINU_SCI_H
, MASK_CV_MINU_SCI_H
, match_opcode
, 0},
2429 {"cv.minu.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_MINU_SCI_B
, MASK_CV_MINU_SCI_B
, match_opcode
, 0},
2430 {"cv.max.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAX_H
, MASK_CV_MAX_H
, match_opcode
, 0},
2431 {"cv.max.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAX_B
, MASK_CV_MAX_B
, match_opcode
, 0},
2432 {"cv.max.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAX_SC_H
, MASK_CV_MAX_SC_H
, match_opcode
, 0},
2433 {"cv.max.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAX_SC_B
, MASK_CV_MAX_SC_B
, match_opcode
, 0},
2434 {"cv.max.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_MAX_SCI_H
, MASK_CV_MAX_SCI_H
, match_opcode
, 0},
2435 {"cv.max.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_MAX_SCI_B
, MASK_CV_MAX_SCI_B
, match_opcode
, 0},
2436 {"cv.maxu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAXU_H
, MASK_CV_MAXU_H
, match_opcode
, 0},
2437 {"cv.maxu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAXU_B
, MASK_CV_MAXU_B
, match_opcode
, 0},
2438 {"cv.maxu.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAXU_SC_H
, MASK_CV_MAXU_SC_H
, match_opcode
, 0},
2439 {"cv.maxu.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_MAXU_SC_B
, MASK_CV_MAXU_SC_B
, match_opcode
, 0},
2440 {"cv.maxu.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_MAXU_SCI_H
, MASK_CV_MAXU_SCI_H
, match_opcode
, 0},
2441 {"cv.maxu.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_MAXU_SCI_B
, MASK_CV_MAXU_SCI_B
, match_opcode
, 0},
2442 {"cv.srl.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRL_H
, MASK_CV_SRL_H
, match_opcode
, 0},
2443 {"cv.srl.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRL_B
, MASK_CV_SRL_B
, match_opcode
, 0},
2444 {"cv.srl.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRL_SC_H
, MASK_CV_SRL_SC_H
, match_opcode
, 0},
2445 {"cv.srl.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRL_SC_B
, MASK_CV_SRL_SC_B
, match_opcode
, 0},
2446 {"cv.srl.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc84", MATCH_CV_SRL_SCI_H
, MASK_CV_SRL_SCI_H
, match_opcode
, 0},
2447 {"cv.srl.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc83", MATCH_CV_SRL_SCI_B
, MASK_CV_SRL_SCI_B
, match_opcode
, 0},
2448 {"cv.sra.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRA_H
, MASK_CV_SRA_H
, match_opcode
, 0},
2449 {"cv.sra.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRA_B
, MASK_CV_SRA_B
, match_opcode
, 0},
2450 {"cv.sra.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRA_SC_H
, MASK_CV_SRA_SC_H
, match_opcode
, 0},
2451 {"cv.sra.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SRA_SC_B
, MASK_CV_SRA_SC_B
, match_opcode
, 0},
2452 {"cv.sra.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc84", MATCH_CV_SRA_SCI_H
, MASK_CV_SRA_SCI_H
, match_opcode
, 0},
2453 {"cv.sra.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc83", MATCH_CV_SRA_SCI_B
, MASK_CV_SRA_SCI_B
, match_opcode
, 0},
2454 {"cv.sll.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SLL_H
, MASK_CV_SLL_H
, match_opcode
, 0},
2455 {"cv.sll.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SLL_B
, MASK_CV_SLL_B
, match_opcode
, 0},
2456 {"cv.sll.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SLL_SC_H
, MASK_CV_SLL_SC_H
, match_opcode
, 0},
2457 {"cv.sll.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SLL_SC_B
, MASK_CV_SLL_SC_B
, match_opcode
, 0},
2458 {"cv.sll.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc84", MATCH_CV_SLL_SCI_H
, MASK_CV_SLL_SCI_H
, match_opcode
, 0},
2459 {"cv.sll.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc83", MATCH_CV_SLL_SCI_B
, MASK_CV_SLL_SCI_B
, match_opcode
, 0},
2460 {"cv.or.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_OR_H
, MASK_CV_OR_H
, match_opcode
, 0},
2461 {"cv.or.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_OR_B
, MASK_CV_OR_B
, match_opcode
, 0},
2462 {"cv.or.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_OR_SC_H
, MASK_CV_OR_SC_H
, match_opcode
, 0},
2463 {"cv.or.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_OR_SC_B
, MASK_CV_OR_SC_B
, match_opcode
, 0},
2464 {"cv.or.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_OR_SCI_H
, MASK_CV_OR_SCI_H
, match_opcode
, 0},
2465 {"cv.or.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_OR_SCI_B
, MASK_CV_OR_SCI_B
, match_opcode
, 0},
2466 {"cv.xor.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_XOR_H
, MASK_CV_XOR_H
, match_opcode
, 0},
2467 {"cv.xor.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_XOR_B
, MASK_CV_XOR_B
, match_opcode
, 0},
2468 {"cv.xor.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_XOR_SC_H
, MASK_CV_XOR_SC_H
, match_opcode
, 0},
2469 {"cv.xor.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_XOR_SC_B
, MASK_CV_XOR_SC_B
, match_opcode
, 0},
2470 {"cv.xor.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_XOR_SCI_H
, MASK_CV_XOR_SCI_H
, match_opcode
, 0},
2471 {"cv.xor.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_XOR_SCI_B
, MASK_CV_XOR_SCI_B
, match_opcode
, 0},
2472 {"cv.and.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AND_H
, MASK_CV_AND_H
, match_opcode
, 0},
2473 {"cv.and.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AND_B
, MASK_CV_AND_B
, match_opcode
, 0},
2474 {"cv.and.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AND_SC_H
, MASK_CV_AND_SC_H
, match_opcode
, 0},
2475 {"cv.and.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_AND_SC_B
, MASK_CV_AND_SC_B
, match_opcode
, 0},
2476 {"cv.and.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_AND_SCI_H
, MASK_CV_AND_SCI_H
, match_opcode
, 0},
2477 {"cv.and.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_AND_SCI_B
, MASK_CV_AND_SCI_B
, match_opcode
, 0},
2478 {"cv.abs.h", 0, INSN_CLASS_XCVSIMD
, "d,s", MATCH_CV_ABS_H
, MASK_CV_ABS_H
, match_opcode
, 0},
2479 {"cv.abs.b", 0, INSN_CLASS_XCVSIMD
, "d,s", MATCH_CV_ABS_B
, MASK_CV_ABS_B
, match_opcode
, 0},
2480 {"cv.dotup.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUP_H
, MASK_CV_DOTUP_H
, match_opcode
, 0},
2481 {"cv.dotup.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUP_B
, MASK_CV_DOTUP_B
, match_opcode
, 0},
2482 {"cv.dotup.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUP_SC_H
, MASK_CV_DOTUP_SC_H
, match_opcode
, 0},
2483 {"cv.dotup.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUP_SC_B
, MASK_CV_DOTUP_SC_B
, match_opcode
, 0},
2484 {"cv.dotup.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_DOTUP_SCI_H
, MASK_CV_DOTUP_SCI_H
, match_opcode
, 0},
2485 {"cv.dotup.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_DOTUP_SCI_B
, MASK_CV_DOTUP_SCI_B
, match_opcode
, 0},
2486 {"cv.dotusp.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUSP_H
, MASK_CV_DOTUSP_H
, match_opcode
, 0},
2487 {"cv.dotusp.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUSP_B
, MASK_CV_DOTUSP_B
, match_opcode
, 0},
2488 {"cv.dotusp.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUSP_SC_H
, MASK_CV_DOTUSP_SC_H
, match_opcode
, 0},
2489 {"cv.dotusp.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTUSP_SC_B
, MASK_CV_DOTUSP_SC_B
, match_opcode
, 0},
2490 {"cv.dotusp.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_DOTUSP_SCI_H
, MASK_CV_DOTUSP_SCI_H
, match_opcode
, 0},
2491 {"cv.dotusp.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_DOTUSP_SCI_B
, MASK_CV_DOTUSP_SCI_B
, match_opcode
, 0},
2492 {"cv.dotsp.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTSP_H
, MASK_CV_DOTSP_H
, match_opcode
, 0},
2493 {"cv.dotsp.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTSP_B
, MASK_CV_DOTSP_B
, match_opcode
, 0},
2494 {"cv.dotsp.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTSP_SC_H
, MASK_CV_DOTSP_SC_H
, match_opcode
, 0},
2495 {"cv.dotsp.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_DOTSP_SC_B
, MASK_CV_DOTSP_SC_B
, match_opcode
, 0},
2496 {"cv.dotsp.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_DOTSP_SCI_H
, MASK_CV_DOTSP_SCI_H
, match_opcode
, 0},
2497 {"cv.dotsp.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_DOTSP_SCI_B
, MASK_CV_DOTSP_SCI_B
, match_opcode
, 0},
2498 {"cv.sdotup.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUP_H
, MASK_CV_SDOTUP_H
, match_opcode
, 0},
2499 {"cv.sdotup.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUP_B
, MASK_CV_SDOTUP_B
, match_opcode
, 0},
2500 {"cv.sdotup.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUP_SC_H
, MASK_CV_SDOTUP_SC_H
, match_opcode
, 0},
2501 {"cv.sdotup.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUP_SC_B
, MASK_CV_SDOTUP_SC_B
, match_opcode
, 0},
2502 {"cv.sdotup.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_SDOTUP_SCI_H
, MASK_CV_SDOTUP_SCI_H
, match_opcode
, 0},
2503 {"cv.sdotup.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_SDOTUP_SCI_B
, MASK_CV_SDOTUP_SCI_B
, match_opcode
, 0},
2504 {"cv.sdotusp.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUSP_H
, MASK_CV_SDOTUSP_H
, match_opcode
, 0},
2505 {"cv.sdotusp.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUSP_B
, MASK_CV_SDOTUSP_B
, match_opcode
, 0},
2506 {"cv.sdotusp.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUSP_SC_H
, MASK_CV_SDOTUSP_SC_H
, match_opcode
, 0},
2507 {"cv.sdotusp.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTUSP_SC_B
, MASK_CV_SDOTUSP_SC_B
, match_opcode
, 0},
2508 {"cv.sdotusp.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_SDOTUSP_SCI_H
, MASK_CV_SDOTUSP_SCI_H
, match_opcode
, 0},
2509 {"cv.sdotusp.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_SDOTUSP_SCI_B
, MASK_CV_SDOTUSP_SCI_B
, match_opcode
, 0},
2510 {"cv.sdotsp.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTSP_H
, MASK_CV_SDOTSP_H
, match_opcode
, 0},
2511 {"cv.sdotsp.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTSP_B
, MASK_CV_SDOTSP_B
, match_opcode
, 0},
2512 {"cv.sdotsp.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTSP_SC_H
, MASK_CV_SDOTSP_SC_H
, match_opcode
, 0},
2513 {"cv.sdotsp.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SDOTSP_SC_B
, MASK_CV_SDOTSP_SC_B
, match_opcode
, 0},
2514 {"cv.sdotsp.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_SDOTSP_SCI_H
, MASK_CV_SDOTSP_SCI_H
, match_opcode
, 0},
2515 {"cv.sdotsp.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_SDOTSP_SCI_B
, MASK_CV_SDOTSP_SCI_B
, match_opcode
, 0},
2516 {"cv.extract.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc81", MATCH_CV_EXTRACT_H
, MASK_CV_EXTRACT_H
, match_opcode
, 0},
2517 {"cv.extract.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc82", MATCH_CV_EXTRACT_B
, MASK_CV_EXTRACT_B
, match_opcode
, 0},
2518 {"cv.extractu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc81", MATCH_CV_EXTRACTU_H
, MASK_CV_EXTRACTU_H
, match_opcode
, 0},
2519 {"cv.extractu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc82", MATCH_CV_EXTRACTU_B
, MASK_CV_EXTRACTU_B
, match_opcode
, 0},
2520 {"cv.insert.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc81", MATCH_CV_INSERT_H
, MASK_CV_INSERT_H
, match_opcode
, 0},
2521 {"cv.insert.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc82", MATCH_CV_INSERT_B
, MASK_CV_INSERT_B
, match_opcode
, 0},
2522 {"cv.shuffle.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SHUFFLE_H
, MASK_CV_SHUFFLE_H
, match_opcode
, 0},
2523 {"cv.shuffle.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SHUFFLE_B
, MASK_CV_SHUFFLE_B
, match_opcode
, 0},
2524 {"cv.shuffle.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc82", MATCH_CV_SHUFFLE_SCI_H
, MASK_CV_SHUFFLE_SCI_H
, match_opcode
, 0},
2525 {"cv.shufflei0.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_SHUFFLEI0_SCI_B
, MASK_CV_SHUFFLEI0_SCI_B
, match_opcode
, 0},
2526 {"cv.shufflei1.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_SHUFFLEI1_SCI_B
, MASK_CV_SHUFFLEI1_SCI_B
, match_opcode
, 0},
2527 {"cv.shufflei2.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_SHUFFLEI2_SCI_B
, MASK_CV_SHUFFLEI2_SCI_B
, match_opcode
, 0},
2528 {"cv.shufflei3.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_SHUFFLEI3_SCI_B
, MASK_CV_SHUFFLEI3_SCI_B
, match_opcode
, 0},
2529 {"cv.shuffle2.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SHUFFLE2_H
, MASK_CV_SHUFFLE2_H
, match_opcode
, 0},
2530 {"cv.shuffle2.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SHUFFLE2_B
, MASK_CV_SHUFFLE2_B
, match_opcode
, 0},
2531 {"cv.pack", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_PACK
, MASK_CV_PACK
, match_opcode
, 0},
2532 {"cv.pack.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_PACK_H
, MASK_CV_PACK_H
, match_opcode
, 0},
2533 {"cv.packhi.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_PACKHI_B
, MASK_CV_PACKHI_B
, match_opcode
, 0},
2534 {"cv.packlo.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_PACKLO_B
, MASK_CV_PACKLO_B
, match_opcode
, 0},
2535 {"cv.cmpeq.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPEQ_H
, MASK_CV_CMPEQ_H
, match_opcode
, 0},
2536 {"cv.cmpeq.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPEQ_B
, MASK_CV_CMPEQ_B
, match_opcode
, 0},
2537 {"cv.cmpeq.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPEQ_SC_H
, MASK_CV_CMPEQ_SC_H
, match_opcode
, 0},
2538 {"cv.cmpeq.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPEQ_SC_B
, MASK_CV_CMPEQ_SC_B
, match_opcode
, 0},
2539 {"cv.cmpeq.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPEQ_SCI_H
, MASK_CV_CMPEQ_SCI_H
, match_opcode
, 0},
2540 {"cv.cmpeq.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPEQ_SCI_B
, MASK_CV_CMPEQ_SCI_B
, match_opcode
, 0},
2541 {"cv.cmpne.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPNE_H
, MASK_CV_CMPNE_H
, match_opcode
, 0},
2542 {"cv.cmpne.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPNE_B
, MASK_CV_CMPNE_B
, match_opcode
, 0},
2543 {"cv.cmpne.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPNE_SC_H
, MASK_CV_CMPNE_SC_H
, match_opcode
, 0},
2544 {"cv.cmpne.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPNE_SC_B
, MASK_CV_CMPNE_SC_B
, match_opcode
, 0},
2545 {"cv.cmpne.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPNE_SCI_H
, MASK_CV_CMPNE_SCI_H
, match_opcode
, 0},
2546 {"cv.cmpne.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPNE_SCI_B
, MASK_CV_CMPNE_SCI_B
, match_opcode
, 0},
2547 {"cv.cmpgt.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGT_H
, MASK_CV_CMPGT_H
, match_opcode
, 0},
2548 {"cv.cmpgt.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGT_B
, MASK_CV_CMPGT_B
, match_opcode
, 0},
2549 {"cv.cmpgt.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGT_SC_H
, MASK_CV_CMPGT_SC_H
, match_opcode
, 0},
2550 {"cv.cmpgt.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGT_SC_B
, MASK_CV_CMPGT_SC_B
, match_opcode
, 0},
2551 {"cv.cmpgt.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPGT_SCI_H
, MASK_CV_CMPGT_SCI_H
, match_opcode
, 0},
2552 {"cv.cmpgt.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPGT_SCI_B
, MASK_CV_CMPGT_SCI_B
, match_opcode
, 0},
2553 {"cv.cmpge.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGE_H
, MASK_CV_CMPGE_H
, match_opcode
, 0},
2554 {"cv.cmpge.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGE_B
, MASK_CV_CMPGE_B
, match_opcode
, 0},
2555 {"cv.cmpge.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGE_SC_H
, MASK_CV_CMPGE_SC_H
, match_opcode
, 0},
2556 {"cv.cmpge.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGE_SC_B
, MASK_CV_CMPGE_SC_B
, match_opcode
, 0},
2557 {"cv.cmpge.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPGE_SCI_H
, MASK_CV_CMPGE_SCI_H
, match_opcode
, 0},
2558 {"cv.cmpge.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPGE_SCI_B
, MASK_CV_CMPGE_SCI_B
, match_opcode
, 0},
2559 {"cv.cmplt.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLT_H
, MASK_CV_CMPLT_H
, match_opcode
, 0},
2560 {"cv.cmplt.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLT_B
, MASK_CV_CMPLT_B
, match_opcode
, 0},
2561 {"cv.cmplt.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLT_SC_H
, MASK_CV_CMPLT_SC_H
, match_opcode
, 0},
2562 {"cv.cmplt.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLT_SC_B
, MASK_CV_CMPLT_SC_B
, match_opcode
, 0},
2563 {"cv.cmplt.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPLT_SCI_H
, MASK_CV_CMPLT_SCI_H
, match_opcode
, 0},
2564 {"cv.cmplt.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPLT_SCI_B
, MASK_CV_CMPLT_SCI_B
, match_opcode
, 0},
2565 {"cv.cmple.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLE_H
, MASK_CV_CMPLE_H
, match_opcode
, 0},
2566 {"cv.cmple.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLE_B
, MASK_CV_CMPLE_B
, match_opcode
, 0},
2567 {"cv.cmple.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLE_SC_H
, MASK_CV_CMPLE_SC_H
, match_opcode
, 0},
2568 {"cv.cmple.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLE_SC_B
, MASK_CV_CMPLE_SC_B
, match_opcode
, 0},
2569 {"cv.cmple.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPLE_SCI_H
, MASK_CV_CMPLE_SCI_H
, match_opcode
, 0},
2570 {"cv.cmple.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc5", MATCH_CV_CMPLE_SCI_B
, MASK_CV_CMPLE_SCI_B
, match_opcode
, 0},
2571 {"cv.cmpgtu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGTU_H
, MASK_CV_CMPGTU_H
, match_opcode
, 0},
2572 {"cv.cmpgtu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGTU_B
, MASK_CV_CMPGTU_B
, match_opcode
, 0},
2573 {"cv.cmpgtu.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGTU_SC_H
, MASK_CV_CMPGTU_SC_H
, match_opcode
, 0},
2574 {"cv.cmpgtu.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGTU_SC_B
, MASK_CV_CMPGTU_SC_B
, match_opcode
, 0},
2575 {"cv.cmpgtu.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPGTU_SCI_H
, MASK_CV_CMPGTU_SCI_H
, match_opcode
, 0},
2576 {"cv.cmpgtu.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPGTU_SCI_B
, MASK_CV_CMPGTU_SCI_B
, match_opcode
, 0},
2577 {"cv.cmpgeu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGEU_H
, MASK_CV_CMPGEU_H
, match_opcode
, 0},
2578 {"cv.cmpgeu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGEU_B
, MASK_CV_CMPGEU_B
, match_opcode
, 0},
2579 {"cv.cmpgeu.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGEU_SC_H
, MASK_CV_CMPGEU_SC_H
, match_opcode
, 0},
2580 {"cv.cmpgeu.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPGEU_SC_B
, MASK_CV_CMPGEU_SC_B
, match_opcode
, 0},
2581 {"cv.cmpgeu.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPGEU_SCI_H
, MASK_CV_CMPGEU_SCI_H
, match_opcode
, 0},
2582 {"cv.cmpgeu.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPGEU_SCI_B
, MASK_CV_CMPGEU_SCI_B
, match_opcode
, 0},
2583 {"cv.cmpltu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLTU_H
, MASK_CV_CMPLTU_H
, match_opcode
, 0},
2584 {"cv.cmpltu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLTU_B
, MASK_CV_CMPLTU_B
, match_opcode
, 0},
2585 {"cv.cmpltu.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLTU_SC_H
, MASK_CV_CMPLTU_SC_H
, match_opcode
, 0},
2586 {"cv.cmpltu.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLTU_SC_B
, MASK_CV_CMPLTU_SC_B
, match_opcode
, 0},
2587 {"cv.cmpltu.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPLTU_SCI_H
, MASK_CV_CMPLTU_SCI_H
, match_opcode
, 0},
2588 {"cv.cmpltu.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPLTU_SCI_B
, MASK_CV_CMPLTU_SCI_B
, match_opcode
, 0},
2589 {"cv.cmpleu.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLEU_H
, MASK_CV_CMPLEU_H
, match_opcode
, 0},
2590 {"cv.cmpleu.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLEU_B
, MASK_CV_CMPLEU_B
, match_opcode
, 0},
2591 {"cv.cmpleu.sc.h", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLEU_SC_H
, MASK_CV_CMPLEU_SC_H
, match_opcode
, 0},
2592 {"cv.cmpleu.sc.b", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CMPLEU_SC_B
, MASK_CV_CMPLEU_SC_B
, match_opcode
, 0},
2593 {"cv.cmpleu.sci.h", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPLEU_SCI_H
, MASK_CV_CMPLEU_SCI_H
, match_opcode
, 0},
2594 {"cv.cmpleu.sci.b", 0, INSN_CLASS_XCVSIMD
, "d,s,Xc80", MATCH_CV_CMPLEU_SCI_B
, MASK_CV_CMPLEU_SCI_B
, match_opcode
, 0},
2595 {"cv.cplxmul.r", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_R
, MASK_CV_CPLXMUL_R
, match_opcode
, 0},
2596 {"cv.cplxmul.i", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_I
, MASK_CV_CPLXMUL_I
, match_opcode
, 0},
2597 {"cv.cplxmul.r.div2", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_R_DIV2
, MASK_CV_CPLXMUL_R_DIV2
, match_opcode
, 0},
2598 {"cv.cplxmul.i.div2", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_I_DIV2
, MASK_CV_CPLXMUL_I_DIV2
, match_opcode
, 0},
2599 {"cv.cplxmul.r.div4", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_R_DIV4
, MASK_CV_CPLXMUL_R_DIV4
, match_opcode
, 0},
2600 {"cv.cplxmul.i.div4", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_I_DIV4
, MASK_CV_CPLXMUL_I_DIV4
, match_opcode
, 0},
2601 {"cv.cplxmul.r.div8", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_R_DIV8
, MASK_CV_CPLXMUL_R_DIV8
, match_opcode
, 0},
2602 {"cv.cplxmul.i.div8", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_CPLXMUL_I_DIV8
, MASK_CV_CPLXMUL_I_DIV8
, match_opcode
, 0},
2603 {"cv.cplxconj", 0, INSN_CLASS_XCVSIMD
, "d,s", MATCH_CV_CPLXCONJ
, MASK_CV_CPLXCONJ
, match_opcode
, 0},
2604 {"cv.subrotmj", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUBROTMJ
, MASK_CV_SUBROTMJ
, match_opcode
, 0},
2605 {"cv.subrotmj.div2", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUBROTMJ_DIV2
, MASK_CV_SUBROTMJ_DIV2
, match_opcode
, 0},
2606 {"cv.subrotmj.div4", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUBROTMJ_DIV4
, MASK_CV_SUBROTMJ_DIV4
, match_opcode
, 0},
2607 {"cv.subrotmj.div8", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUBROTMJ_DIV8
, MASK_CV_SUBROTMJ_DIV8
, match_opcode
, 0},
2608 {"cv.add.div2", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_ADD_DIV2
, MASK_CV_ADD_DIV2
, match_opcode
, 0},
2609 {"cv.add.div4", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_ADD_DIV4
, MASK_CV_ADD_DIV4
, match_opcode
, 0},
2610 {"cv.add.div8", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_ADD_DIV8
, MASK_CV_ADD_DIV8
, match_opcode
, 0},
2611 {"cv.sub.div2", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUB_DIV2
, MASK_CV_SUB_DIV2
, match_opcode
, 0},
2612 {"cv.sub.div4", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUB_DIV4
, MASK_CV_SUB_DIV4
, match_opcode
, 0},
2613 {"cv.sub.div8", 0, INSN_CLASS_XCVSIMD
, "d,s,t", MATCH_CV_SUB_DIV8
, MASK_CV_SUB_DIV8
, match_opcode
, 0},
2615 /* Vendor-specific (T-Head) XTheadBa instructions. */
2616 {"th.addsl", 0, INSN_CLASS_XTHEADBA
, "d,s,t,Xtu2@25", MATCH_TH_ADDSL
, MASK_TH_ADDSL
, match_opcode
, 0},
2618 /* Vendor-specific (T-Head) XTheadBb instructions. */
2619 {"th.srri", 0, INSN_CLASS_XTHEADBB
, "d,s,Xtu6@20", MATCH_TH_SRRI
, MASK_TH_SRRI
, match_opcode
, 0},
2620 {"th.srriw", 64, INSN_CLASS_XTHEADBB
, "d,s,Xtu5@20", MATCH_TH_SRRIW
, MASK_TH_SRRIW
, match_opcode
, 0},
2621 {"th.ext", 0, INSN_CLASS_XTHEADBB
, "d,s,Xtu6@26,Xtu6@20", MATCH_TH_EXT
, MASK_TH_EXT
, match_opcode
, 0},
2622 {"th.extu", 0, INSN_CLASS_XTHEADBB
, "d,s,Xtu6@26,Xtu6@20", MATCH_TH_EXTU
, MASK_TH_EXTU
, match_opcode
, 0},
2623 {"th.ff0", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_FF0
, MASK_TH_FF0
, match_opcode
, 0},
2624 {"th.ff1", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_FF1
, MASK_TH_FF1
, match_opcode
, 0},
2625 {"th.rev", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_REV
, MASK_TH_REV
, match_opcode
, 0},
2626 {"th.revw", 64, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_REVW
, MASK_TH_REVW
, match_opcode
, 0},
2627 {"th.tstnbz", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_TSTNBZ
, MASK_TH_TSTNBZ
, match_opcode
, 0},
2629 /* Vendor-specific (T-Head) XTheadBs instructions. */
2630 {"th.tst", 0, INSN_CLASS_XTHEADBS
, "d,s,Xtu6@20", MATCH_TH_TST
, MASK_TH_TST
, match_opcode
, 0},
2632 /* Vendor-specific (T-Head) XTheadCmo instructions. */
2633 {"th.dcache.call", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_DCACHE_CALL
, MASK_TH_DCACHE_CALL
, match_opcode
, 0},
2634 {"th.dcache.ciall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_DCACHE_CIALL
, MASK_TH_DCACHE_CIALL
, match_opcode
, 0},
2635 {"th.dcache.iall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_DCACHE_IALL
, MASK_TH_DCACHE_IALL
, match_opcode
, 0},
2636 {"th.dcache.cpa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CPA
, MASK_TH_DCACHE_CPA
, match_opcode
, 0},
2637 {"th.dcache.cipa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CIPA
, MASK_TH_DCACHE_CIPA
, match_opcode
, 0},
2638 {"th.dcache.ipa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_IPA
, MASK_TH_DCACHE_IPA
, match_opcode
, 0},
2639 {"th.dcache.cva", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CVA
, MASK_TH_DCACHE_CVA
, match_opcode
, 0},
2640 {"th.dcache.civa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CIVA
, MASK_TH_DCACHE_CIVA
, match_opcode
, 0},
2641 {"th.dcache.iva", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_IVA
, MASK_TH_DCACHE_IVA
, match_opcode
, 0},
2642 {"th.dcache.csw", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CSW
, MASK_TH_DCACHE_CSW
, match_opcode
, 0},
2643 {"th.dcache.cisw", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CISW
, MASK_TH_DCACHE_CISW
, match_opcode
, 0},
2644 {"th.dcache.isw", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_ISW
, MASK_TH_DCACHE_ISW
, match_opcode
, 0},
2645 {"th.dcache.cpal1", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CPAL1
, MASK_TH_DCACHE_CPAL1
, match_opcode
, 0},
2646 {"th.dcache.cval1", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CVAL1
, MASK_TH_DCACHE_CVAL1
, match_opcode
, 0},
2648 {"th.icache.iall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_ICACHE_IALL
, MASK_TH_ICACHE_IALL
, match_opcode
, 0},
2649 {"th.icache.ialls", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_ICACHE_IALLS
, MASK_TH_ICACHE_IALLS
, match_opcode
, 0},
2650 {"th.icache.ipa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_ICACHE_IPA
, MASK_TH_ICACHE_IPA
, match_opcode
, 0},
2651 {"th.icache.iva", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_ICACHE_IVA
, MASK_TH_ICACHE_IVA
, match_opcode
, 0},
2653 {"th.l2cache.call", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_L2CACHE_CALL
, MASK_TH_L2CACHE_CALL
, match_opcode
, 0},
2654 {"th.l2cache.ciall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_L2CACHE_CIALL
, MASK_TH_L2CACHE_CIALL
, match_opcode
, 0},
2655 {"th.l2cache.iall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_L2CACHE_IALL
, MASK_TH_L2CACHE_IALL
, match_opcode
, 0},
2657 /* Vendor-specific (T-Head) XTheadCondMov instructions. */
2658 {"th.mveqz", 0, INSN_CLASS_XTHEADCONDMOV
, "d,s,t", MATCH_TH_MVEQZ
, MASK_TH_MVEQZ
, match_opcode
, 0},
2659 {"th.mvnez", 0, INSN_CLASS_XTHEADCONDMOV
, "d,s,t", MATCH_TH_MVNEZ
, MASK_TH_MVNEZ
, match_opcode
, 0},
2661 /* Vendor-specific (T-Head) XTheadFMemIdx instructions. */
2662 {"th.flrd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FLRD
, MASK_TH_FLRD
, match_opcode
, 0},
2663 {"th.flrw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FLRW
, MASK_TH_FLRW
, match_opcode
, 0},
2664 {"th.flurd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FLURD
, MASK_TH_FLURD
, match_opcode
, 0},
2665 {"th.flurw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FLURW
, MASK_TH_FLURW
, match_opcode
, 0},
2666 {"th.fsrd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FSRD
, MASK_TH_FSRD
, match_opcode
, 0},
2667 {"th.fsrw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FSRW
, MASK_TH_FSRW
, match_opcode
, 0},
2668 {"th.fsurd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FSURD
, MASK_TH_FSURD
, match_opcode
, 0},
2669 {"th.fsurw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xtu2@25", MATCH_TH_FSURW
, MASK_TH_FSURW
, match_opcode
, 0},
2671 /* Vendor-specific (T-Head) XTheadFmv instructions. */
2672 {"th.fmv.hw.x", 32, INSN_CLASS_XTHEADFMV
, "D,s", MATCH_TH_FMV_HW_X
, MASK_TH_FMV_HW_X
, match_opcode
, 0},
2673 {"th.fmv.x.hw", 32, INSN_CLASS_XTHEADFMV
, "d,S", MATCH_TH_FMV_X_HW
, MASK_TH_FMV_X_HW
, match_opcode
, 0},
2675 /* Vendor-specific (T-Head) XTheadInt instructions. */
2676 {"th.ipop", 0, INSN_CLASS_XTHEADINT
, "", MATCH_TH_IPOP
, MASK_TH_IPOP
, match_opcode
, 0},
2677 {"th.ipush", 0, INSN_CLASS_XTHEADINT
, "", MATCH_TH_IPUSH
, MASK_TH_IPUSH
, match_opcode
, 0},
2679 /* Vendor-specific (T-Head) XTheadMemIdx instructions. */
2680 {"th.ldia", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LDIA
, MASK_TH_LDIA
, match_th_load_inc
, 0},
2681 {"th.ldib", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LDIB
, MASK_TH_LDIB
, match_th_load_inc
, 0},
2682 {"th.lwia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LWIA
, MASK_TH_LWIA
, match_th_load_inc
, 0},
2683 {"th.lwib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LWIB
, MASK_TH_LWIB
, match_th_load_inc
, 0},
2684 {"th.lwuia", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LWUIA
, MASK_TH_LWUIA
, match_th_load_inc
, 0},
2685 {"th.lwuib", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LWUIB
, MASK_TH_LWUIB
, match_th_load_inc
, 0},
2686 {"th.lhia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LHIA
, MASK_TH_LHIA
, match_th_load_inc
, 0},
2687 {"th.lhib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LHIB
, MASK_TH_LHIB
, match_th_load_inc
, 0},
2688 {"th.lhuia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LHUIA
, MASK_TH_LHUIA
, match_th_load_inc
, 0},
2689 {"th.lhuib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LHUIB
, MASK_TH_LHUIB
, match_th_load_inc
, 0},
2690 {"th.lbia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LBIA
, MASK_TH_LBIA
, match_th_load_inc
, 0},
2691 {"th.lbib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LBIB
, MASK_TH_LBIB
, match_th_load_inc
, 0},
2692 {"th.lbuia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LBUIA
, MASK_TH_LBUIA
, match_th_load_inc
, 0},
2693 {"th.lbuib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_LBUIB
, MASK_TH_LBUIB
, match_th_load_inc
, 0},
2694 {"th.sdia", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SDIA
, MASK_TH_SDIA
, match_opcode
, 0},
2695 {"th.sdib", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SDIB
, MASK_TH_SDIB
, match_opcode
, 0},
2696 {"th.swia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SWIA
, MASK_TH_SWIA
, match_opcode
, 0},
2697 {"th.swib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SWIB
, MASK_TH_SWIB
, match_opcode
, 0},
2698 {"th.shia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SHIA
, MASK_TH_SHIA
, match_opcode
, 0},
2699 {"th.shib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SHIB
, MASK_TH_SHIB
, match_opcode
, 0},
2700 {"th.sbia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SBIA
, MASK_TH_SBIA
, match_opcode
, 0},
2701 {"th.sbib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xts5@20,Xtu2@25", MATCH_TH_SBIB
, MASK_TH_SBIB
, match_opcode
, 0},
2703 {"th.lrd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LRD
, MASK_TH_LRD
, match_opcode
, 0},
2704 {"th.lrw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LRW
, MASK_TH_LRW
, match_opcode
, 0},
2705 {"th.lrwu", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LRWU
, MASK_TH_LRWU
, match_opcode
, 0},
2706 {"th.lrh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LRH
, MASK_TH_LRH
, match_opcode
, 0},
2707 {"th.lrhu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LRHU
, MASK_TH_LRHU
, match_opcode
, 0},
2708 {"th.lrb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LRB
, MASK_TH_LRB
, match_opcode
, 0},
2709 {"th.lrbu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LRBU
, MASK_TH_LRBU
, match_opcode
, 0},
2710 {"th.srd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SRD
, MASK_TH_SRD
, match_opcode
, 0},
2711 {"th.srw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SRW
, MASK_TH_SRW
, match_opcode
, 0},
2712 {"th.srh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SRH
, MASK_TH_SRH
, match_opcode
, 0},
2713 {"th.srb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SRB
, MASK_TH_SRB
, match_opcode
, 0},
2715 {"th.lurd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LURD
, MASK_TH_LURD
, match_opcode
, 0},
2716 {"th.lurw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LURW
, MASK_TH_LURW
, match_opcode
, 0},
2717 {"th.lurwu", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LURWU
, MASK_TH_LURWU
, match_opcode
, 0},
2718 {"th.lurh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LURH
, MASK_TH_LURH
, match_opcode
, 0},
2719 {"th.lurhu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LURHU
, MASK_TH_LURHU
, match_opcode
, 0},
2720 {"th.lurb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LURB
, MASK_TH_LURB
, match_opcode
, 0},
2721 {"th.lurbu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_LURBU
, MASK_TH_LURBU
, match_opcode
, 0},
2722 {"th.surd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SURD
, MASK_TH_SURD
, match_opcode
, 0},
2723 {"th.surw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SURW
, MASK_TH_SURW
, match_opcode
, 0},
2724 {"th.surh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SURH
, MASK_TH_SURH
, match_opcode
, 0},
2725 {"th.surb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xtu2@25", MATCH_TH_SURB
, MASK_TH_SURB
, match_opcode
, 0},
2727 /* Vendor-specific (T-Head) XTheadMemPair instructions. */
2728 {"th.ldd", 64, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xtu2@25,Xtl4", MATCH_TH_LDD
, MASK_TH_LDD
, match_th_load_pair
, 0},
2729 {"th.lwd", 0, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xtu2@25,Xtl3", MATCH_TH_LWD
, MASK_TH_LWD
, match_th_load_pair
, 0},
2730 {"th.lwud", 0, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xtu2@25,Xtl3", MATCH_TH_LWUD
, MASK_TH_LWUD
, match_th_load_pair
, 0},
2731 {"th.sdd", 64, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xtu2@25,Xtl4", MATCH_TH_SDD
, MASK_TH_SDD
, match_opcode
, 0},
2732 {"th.swd", 0, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xtu2@25,Xtl3", MATCH_TH_SWD
, MASK_TH_SWD
, match_opcode
, 0},
2734 /* Vendor-specific (T-Head) XTheadMac instructions. */
2735 {"th.mula", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULA
, MASK_TH_MULA
, match_opcode
, 0},
2736 {"th.mulah", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULAH
, MASK_TH_MULAH
, match_opcode
, 0},
2737 {"th.mulaw", 64, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULAW
, MASK_TH_MULAW
, match_opcode
, 0},
2738 {"th.muls", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULS
, MASK_TH_MULS
, match_opcode
, 0},
2739 {"th.mulsh", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULSH
, MASK_TH_MULSH
, match_opcode
, 0},
2740 {"th.mulsw", 64, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULSW
, MASK_TH_MULSW
, match_opcode
, 0},
2742 /* Vendor-specific (T-Head) XTheadSync instructions. */
2743 {"th.sfence.vmas", 0, INSN_CLASS_XTHEADSYNC
, "s,t",MATCH_TH_SFENCE_VMAS
, MASK_TH_SFENCE_VMAS
, match_opcode
, 0},
2744 {"th.sync", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC
, MASK_TH_SYNC
, match_opcode
, 0},
2745 {"th.sync.i", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC_I
, MASK_TH_SYNC_I
, match_opcode
, 0},
2746 {"th.sync.is", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC_IS
, MASK_TH_SYNC_IS
, match_opcode
, 0},
2747 {"th.sync.s", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC_S
, MASK_TH_SYNC_S
, match_opcode
, 0},
2749 /* Vendor-specific (T-Head) XTheadVector instructions. */
2750 {"th.vsetvl", 0, INSN_CLASS_XTHEADVECTOR
, "d,s,t", MATCH_VSETVL
, MASK_VSETVL
, match_opcode
, 0},
2751 {"th.vsetvli", 0, INSN_CLASS_XTHEADVECTOR
, "d,s,XtVc", MATCH_VSETVLI
, MASK_VSETVLI
, match_opcode
, 0},
2752 {"th.vlb.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLBV
, MASK_TH_VLBV
, match_opcode
, INSN_DREF
},
2753 {"th.vlh.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLHV
, MASK_TH_VLHV
, match_opcode
, INSN_DREF
},
2754 {"th.vlw.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLWV
, MASK_TH_VLWV
, match_opcode
, INSN_DREF
},
2755 {"th.vlbu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE8V
, MASK_VLE8V
, match_opcode
, INSN_DREF
},
2756 {"th.vlhu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE16V
, MASK_VLE16V
, match_opcode
, INSN_DREF
},
2757 {"th.vlwu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE32V
, MASK_VLE32V
, match_opcode
, INSN_DREF
},
2758 {"th.vle.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE64V
, MASK_VLE64V
, match_opcode
, INSN_DREF
},
2759 {"th.vsb.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSE8V
, MASK_VSE8V
, match_opcode
, INSN_DREF
},
2760 {"th.vsh.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSE16V
, MASK_VSE16V
, match_opcode
, INSN_DREF
},
2761 {"th.vsw.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSE32V
, MASK_VSE32V
, match_opcode
, INSN_DREF
},
2762 {"th.vse.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSE64V
, MASK_VSE64V
, match_opcode
, INSN_DREF
},
2763 {"th.vlsb.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSBV
, MASK_TH_VLSBV
, match_opcode
, INSN_DREF
},
2764 {"th.vlsh.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSHV
, MASK_TH_VLSHV
, match_opcode
, INSN_DREF
},
2765 {"th.vlsw.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSWV
, MASK_TH_VLSWV
, match_opcode
, INSN_DREF
},
2766 {"th.vlsbu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSE8V
, MASK_VLSE8V
, match_opcode
, INSN_DREF
},
2767 {"th.vlshu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSE16V
, MASK_VLSE16V
, match_opcode
, INSN_DREF
},
2768 {"th.vlswu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSE32V
, MASK_VLSE32V
, match_opcode
, INSN_DREF
},
2769 {"th.vlse.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSE64V
, MASK_VLSE64V
, match_opcode
, INSN_DREF
},
2770 {"th.vssb.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSE8V
, MASK_VSSE8V
, match_opcode
, INSN_DREF
},
2771 {"th.vssh.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSE16V
, MASK_VSSE16V
, match_opcode
, INSN_DREF
},
2772 {"th.vssw.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSE32V
, MASK_VSSE32V
, match_opcode
, INSN_DREF
},
2773 {"th.vsse.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSE64V
, MASK_VSSE64V
, match_opcode
, INSN_DREF
},
2774 {"th.vlxb.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXBV
, MASK_TH_VLXBV
, match_opcode
, INSN_DREF
},
2775 {"th.vlxh.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXHV
, MASK_TH_VLXHV
, match_opcode
, INSN_DREF
},
2776 {"th.vlxw.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXWV
, MASK_TH_VLXWV
, match_opcode
, INSN_DREF
},
2777 {"th.vlxbu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXEI8V
, MASK_VLOXEI8V
, match_opcode
, INSN_DREF
},
2778 {"th.vlxhu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXEI16V
, MASK_VLOXEI16V
, match_opcode
, INSN_DREF
},
2779 {"th.vlxwu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXEI32V
, MASK_VLOXEI32V
, match_opcode
, INSN_DREF
},
2780 {"th.vlxe.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXEI64V
, MASK_VLOXEI64V
, match_opcode
, INSN_DREF
},
2781 {"th.vsxb.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXEI8V
, MASK_VSOXEI8V
, match_opcode
, INSN_DREF
},
2782 {"th.vsxh.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXEI16V
, MASK_VSOXEI16V
, match_opcode
, INSN_DREF
},
2783 {"th.vsxw.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXEI32V
, MASK_VSOXEI32V
, match_opcode
, INSN_DREF
},
2784 {"th.vsxe.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXEI64V
, MASK_VSOXEI64V
, match_opcode
, INSN_DREF
},
2785 {"th.vsuxb.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VSUXBV
, MASK_TH_VSUXBV
, match_opcode
, INSN_DREF
},
2786 {"th.vsuxh.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VSUXHV
, MASK_TH_VSUXHV
, match_opcode
, INSN_DREF
},
2787 {"th.vsuxw.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VSUXWV
, MASK_TH_VSUXWV
, match_opcode
, INSN_DREF
},
2788 {"th.vsuxe.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VSUXEV
, MASK_TH_VSUXEV
, match_opcode
, INSN_DREF
},
2789 {"th.vlbff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLBFFV
, MASK_TH_VLBFFV
, match_opcode
, INSN_DREF
},
2790 {"th.vlhff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLHFFV
, MASK_TH_VLHFFV
, match_opcode
, INSN_DREF
},
2791 {"th.vlwff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLWFFV
, MASK_TH_VLWFFV
, match_opcode
, INSN_DREF
},
2792 {"th.vlbuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE8FFV
, MASK_VLE8FFV
, match_opcode
, INSN_DREF
},
2793 {"th.vlhuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE16FFV
, MASK_VLE16FFV
, match_opcode
, INSN_DREF
},
2794 {"th.vlwuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE32FFV
, MASK_VLE32FFV
, match_opcode
, INSN_DREF
},
2795 {"th.vleff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLE64FFV
, MASK_VLE64FFV
, match_opcode
, INSN_DREF
},
2796 {"th.vlseg2b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG2BV
, MASK_TH_VLSEG2BV
, match_opcode
, INSN_DREF
},
2797 {"th.vlseg2h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG2HV
, MASK_TH_VLSEG2HV
, match_opcode
, INSN_DREF
},
2798 {"th.vlseg2w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG2WV
, MASK_TH_VLSEG2WV
, match_opcode
, INSN_DREF
},
2799 {"th.vlseg2bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E8V
, MASK_VLSEG2E8V
, match_opcode
, INSN_DREF
},
2800 {"th.vlseg2hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E16V
, MASK_VLSEG2E16V
, match_opcode
, INSN_DREF
},
2801 {"th.vlseg2wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E32V
, MASK_VLSEG2E32V
, match_opcode
, INSN_DREF
},
2802 {"th.vlseg2e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E64V
, MASK_VLSEG2E64V
, match_opcode
, INSN_DREF
},
2803 {"th.vsseg2b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG2E8V
, MASK_VSSEG2E8V
, match_opcode
, INSN_DREF
},
2804 {"th.vsseg2h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG2E16V
, MASK_VSSEG2E16V
, match_opcode
, INSN_DREF
},
2805 {"th.vsseg2w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG2E32V
, MASK_VSSEG2E32V
, match_opcode
, INSN_DREF
},
2806 {"th.vsseg2e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG2E64V
, MASK_VSSEG2E64V
, match_opcode
, INSN_DREF
},
2807 {"th.vlseg3b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG3BV
, MASK_TH_VLSEG3BV
, match_opcode
, INSN_DREF
},
2808 {"th.vlseg3h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG3HV
, MASK_TH_VLSEG3HV
, match_opcode
, INSN_DREF
},
2809 {"th.vlseg3w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG3WV
, MASK_TH_VLSEG3WV
, match_opcode
, INSN_DREF
},
2810 {"th.vlseg3bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E8V
, MASK_VLSEG3E8V
, match_opcode
, INSN_DREF
},
2811 {"th.vlseg3hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E16V
, MASK_VLSEG3E16V
, match_opcode
, INSN_DREF
},
2812 {"th.vlseg3wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E32V
, MASK_VLSEG3E32V
, match_opcode
, INSN_DREF
},
2813 {"th.vlseg3e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E64V
, MASK_VLSEG3E64V
, match_opcode
, INSN_DREF
},
2814 {"th.vsseg3b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG3E8V
, MASK_VSSEG3E8V
, match_opcode
, INSN_DREF
},
2815 {"th.vsseg3h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG3E16V
, MASK_VSSEG3E16V
, match_opcode
, INSN_DREF
},
2816 {"th.vsseg3w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG3E32V
, MASK_VSSEG3E32V
, match_opcode
, INSN_DREF
},
2817 {"th.vsseg3e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG3E64V
, MASK_VSSEG3E64V
, match_opcode
, INSN_DREF
},
2818 {"th.vlseg4b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG4BV
, MASK_TH_VLSEG4BV
, match_opcode
, INSN_DREF
},
2819 {"th.vlseg4h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG4HV
, MASK_TH_VLSEG4HV
, match_opcode
, INSN_DREF
},
2820 {"th.vlseg4w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG4WV
, MASK_TH_VLSEG4WV
, match_opcode
, INSN_DREF
},
2821 {"th.vlseg4bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E8V
, MASK_VLSEG4E8V
, match_opcode
, INSN_DREF
},
2822 {"th.vlseg4hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E16V
, MASK_VLSEG4E16V
, match_opcode
, INSN_DREF
},
2823 {"th.vlseg4wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E32V
, MASK_VLSEG4E32V
, match_opcode
, INSN_DREF
},
2824 {"th.vlseg4e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E64V
, MASK_VLSEG4E64V
, match_opcode
, INSN_DREF
},
2825 {"th.vsseg4b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG4E8V
, MASK_VSSEG4E8V
, match_opcode
, INSN_DREF
},
2826 {"th.vsseg4h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG4E16V
, MASK_VSSEG4E16V
, match_opcode
, INSN_DREF
},
2827 {"th.vsseg4w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG4E32V
, MASK_VSSEG4E32V
, match_opcode
, INSN_DREF
},
2828 {"th.vsseg4e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG4E64V
, MASK_VSSEG4E64V
, match_opcode
, INSN_DREF
},
2829 {"th.vlseg5b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG5BV
, MASK_TH_VLSEG5BV
, match_opcode
, INSN_DREF
},
2830 {"th.vlseg5h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG5HV
, MASK_TH_VLSEG5HV
, match_opcode
, INSN_DREF
},
2831 {"th.vlseg5w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG5WV
, MASK_TH_VLSEG5WV
, match_opcode
, INSN_DREF
},
2832 {"th.vlseg5bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E8V
, MASK_VLSEG5E8V
, match_opcode
, INSN_DREF
},
2833 {"th.vlseg5hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E16V
, MASK_VLSEG5E16V
, match_opcode
, INSN_DREF
},
2834 {"th.vlseg5wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E32V
, MASK_VLSEG5E32V
, match_opcode
, INSN_DREF
},
2835 {"th.vlseg5e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E64V
, MASK_VLSEG5E64V
, match_opcode
, INSN_DREF
},
2836 {"th.vsseg5b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG5E8V
, MASK_VSSEG5E8V
, match_opcode
, INSN_DREF
},
2837 {"th.vsseg5h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG5E16V
, MASK_VSSEG5E16V
, match_opcode
, INSN_DREF
},
2838 {"th.vsseg5w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG5E32V
, MASK_VSSEG5E32V
, match_opcode
, INSN_DREF
},
2839 {"th.vsseg5e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG5E64V
, MASK_VSSEG5E64V
, match_opcode
, INSN_DREF
},
2840 {"th.vlseg6b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG6BV
, MASK_TH_VLSEG6BV
, match_opcode
, INSN_DREF
},
2841 {"th.vlseg6h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG6HV
, MASK_TH_VLSEG6HV
, match_opcode
, INSN_DREF
},
2842 {"th.vlseg6w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG6WV
, MASK_TH_VLSEG6WV
, match_opcode
, INSN_DREF
},
2843 {"th.vlseg6bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E8V
, MASK_VLSEG6E8V
, match_opcode
, INSN_DREF
},
2844 {"th.vlseg6hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E16V
, MASK_VLSEG6E16V
, match_opcode
, INSN_DREF
},
2845 {"th.vlseg6wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E32V
, MASK_VLSEG6E32V
, match_opcode
, INSN_DREF
},
2846 {"th.vlseg6e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E64V
, MASK_VLSEG6E64V
, match_opcode
, INSN_DREF
},
2847 {"th.vsseg6b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG6E8V
, MASK_VSSEG6E8V
, match_opcode
, INSN_DREF
},
2848 {"th.vsseg6h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG6E16V
, MASK_VSSEG6E16V
, match_opcode
, INSN_DREF
},
2849 {"th.vsseg6w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG6E32V
, MASK_VSSEG6E32V
, match_opcode
, INSN_DREF
},
2850 {"th.vsseg6e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG6E64V
, MASK_VSSEG6E64V
, match_opcode
, INSN_DREF
},
2851 {"th.vlseg7b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG7BV
, MASK_TH_VLSEG7BV
, match_opcode
, INSN_DREF
},
2852 {"th.vlseg7h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG7HV
, MASK_TH_VLSEG7HV
, match_opcode
, INSN_DREF
},
2853 {"th.vlseg7w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG7WV
, MASK_TH_VLSEG7WV
, match_opcode
, INSN_DREF
},
2854 {"th.vlseg7bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E8V
, MASK_VLSEG7E8V
, match_opcode
, INSN_DREF
},
2855 {"th.vlseg7hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E16V
, MASK_VLSEG7E16V
, match_opcode
, INSN_DREF
},
2856 {"th.vlseg7wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E32V
, MASK_VLSEG7E32V
, match_opcode
, INSN_DREF
},
2857 {"th.vlseg7e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E64V
, MASK_VLSEG7E64V
, match_opcode
, INSN_DREF
},
2858 {"th.vsseg7b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG7E8V
, MASK_VSSEG7E8V
, match_opcode
, INSN_DREF
},
2859 {"th.vsseg7h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG7E16V
, MASK_VSSEG7E16V
, match_opcode
, INSN_DREF
},
2860 {"th.vsseg7w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG7E32V
, MASK_VSSEG7E32V
, match_opcode
, INSN_DREF
},
2861 {"th.vsseg7e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG7E64V
, MASK_VSSEG7E64V
, match_opcode
, INSN_DREF
},
2862 {"th.vlseg8b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG8BV
, MASK_TH_VLSEG8BV
, match_opcode
, INSN_DREF
},
2863 {"th.vlseg8h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG8HV
, MASK_TH_VLSEG8HV
, match_opcode
, INSN_DREF
},
2864 {"th.vlseg8w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG8WV
, MASK_TH_VLSEG8WV
, match_opcode
, INSN_DREF
},
2865 {"th.vlseg8bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E8V
, MASK_VLSEG8E8V
, match_opcode
, INSN_DREF
},
2866 {"th.vlseg8hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E16V
, MASK_VLSEG8E16V
, match_opcode
, INSN_DREF
},
2867 {"th.vlseg8wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E32V
, MASK_VLSEG8E32V
, match_opcode
, INSN_DREF
},
2868 {"th.vlseg8e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E64V
, MASK_VLSEG8E64V
, match_opcode
, INSN_DREF
},
2869 {"th.vsseg8b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG8E8V
, MASK_VSSEG8E8V
, match_opcode
, INSN_DREF
},
2870 {"th.vsseg8h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG8E16V
, MASK_VSSEG8E16V
, match_opcode
, INSN_DREF
},
2871 {"th.vsseg8w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG8E32V
, MASK_VSSEG8E32V
, match_opcode
, INSN_DREF
},
2872 {"th.vsseg8e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VSSEG8E64V
, MASK_VSSEG8E64V
, match_opcode
, INSN_DREF
},
2873 {"th.vlsseg2b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG2BV
, MASK_TH_VLSSEG2BV
, match_opcode
, INSN_DREF
},
2874 {"th.vlsseg2h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG2HV
, MASK_TH_VLSSEG2HV
, match_opcode
, INSN_DREF
},
2875 {"th.vlsseg2w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG2WV
, MASK_TH_VLSSEG2WV
, match_opcode
, INSN_DREF
},
2876 {"th.vlsseg2bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG2E8V
, MASK_VLSSEG2E8V
, match_opcode
, INSN_DREF
},
2877 {"th.vlsseg2hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG2E16V
, MASK_VLSSEG2E16V
, match_opcode
, INSN_DREF
},
2878 {"th.vlsseg2wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG2E32V
, MASK_VLSSEG2E32V
, match_opcode
, INSN_DREF
},
2879 {"th.vlsseg2e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG2E64V
, MASK_VLSSEG2E64V
, match_opcode
, INSN_DREF
},
2880 {"th.vssseg2b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG2E8V
, MASK_VSSSEG2E8V
, match_opcode
, INSN_DREF
},
2881 {"th.vssseg2h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG2E16V
, MASK_VSSSEG2E16V
, match_opcode
, INSN_DREF
},
2882 {"th.vssseg2w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG2E32V
, MASK_VSSSEG2E32V
, match_opcode
, INSN_DREF
},
2883 {"th.vssseg2e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG2E64V
, MASK_VSSSEG2E64V
, match_opcode
, INSN_DREF
},
2884 {"th.vlsseg3b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG3BV
, MASK_TH_VLSSEG3BV
, match_opcode
, INSN_DREF
},
2885 {"th.vlsseg3h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG3HV
, MASK_TH_VLSSEG3HV
, match_opcode
, INSN_DREF
},
2886 {"th.vlsseg3w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG3WV
, MASK_TH_VLSSEG3WV
, match_opcode
, INSN_DREF
},
2887 {"th.vlsseg3bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG3E8V
, MASK_VLSSEG3E8V
, match_opcode
, INSN_DREF
},
2888 {"th.vlsseg3hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG3E16V
, MASK_VLSSEG3E16V
, match_opcode
, INSN_DREF
},
2889 {"th.vlsseg3wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG3E32V
, MASK_VLSSEG3E32V
, match_opcode
, INSN_DREF
},
2890 {"th.vlsseg3e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG3E64V
, MASK_VLSSEG3E64V
, match_opcode
, INSN_DREF
},
2891 {"th.vssseg3b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG3E8V
, MASK_VSSSEG3E8V
, match_opcode
, INSN_DREF
},
2892 {"th.vssseg3h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG3E16V
, MASK_VSSSEG3E16V
, match_opcode
, INSN_DREF
},
2893 {"th.vssseg3w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG3E32V
, MASK_VSSSEG3E32V
, match_opcode
, INSN_DREF
},
2894 {"th.vssseg3e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG3E64V
, MASK_VSSSEG3E64V
, match_opcode
, INSN_DREF
},
2895 {"th.vlsseg4b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG4BV
, MASK_TH_VLSSEG4BV
, match_opcode
, INSN_DREF
},
2896 {"th.vlsseg4h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG4HV
, MASK_TH_VLSSEG4HV
, match_opcode
, INSN_DREF
},
2897 {"th.vlsseg4w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG4WV
, MASK_TH_VLSSEG4WV
, match_opcode
, INSN_DREF
},
2898 {"th.vlsseg4bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG4E8V
, MASK_VLSSEG4E8V
, match_opcode
, INSN_DREF
},
2899 {"th.vlsseg4hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG4E16V
, MASK_VLSSEG4E16V
, match_opcode
, INSN_DREF
},
2900 {"th.vlsseg4wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG4E32V
, MASK_VLSSEG4E32V
, match_opcode
, INSN_DREF
},
2901 {"th.vlsseg4e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG4E64V
, MASK_VLSSEG4E64V
, match_opcode
, INSN_DREF
},
2902 {"th.vssseg4b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG4E8V
, MASK_VSSSEG4E8V
, match_opcode
, INSN_DREF
},
2903 {"th.vssseg4h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG4E16V
, MASK_VSSSEG4E16V
, match_opcode
, INSN_DREF
},
2904 {"th.vssseg4w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG4E32V
, MASK_VSSSEG4E32V
, match_opcode
, INSN_DREF
},
2905 {"th.vssseg4e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG4E64V
, MASK_VSSSEG4E64V
, match_opcode
, INSN_DREF
},
2906 {"th.vlsseg5b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG5BV
, MASK_TH_VLSSEG5BV
, match_opcode
, INSN_DREF
},
2907 {"th.vlsseg5h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG5HV
, MASK_TH_VLSSEG5HV
, match_opcode
, INSN_DREF
},
2908 {"th.vlsseg5w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG5WV
, MASK_TH_VLSSEG5WV
, match_opcode
, INSN_DREF
},
2909 {"th.vlsseg5bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG5E8V
, MASK_VLSSEG5E8V
, match_opcode
, INSN_DREF
},
2910 {"th.vlsseg5hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG5E16V
, MASK_VLSSEG5E16V
, match_opcode
, INSN_DREF
},
2911 {"th.vlsseg5wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG5E32V
, MASK_VLSSEG5E32V
, match_opcode
, INSN_DREF
},
2912 {"th.vlsseg5e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG5E64V
, MASK_VLSSEG5E64V
, match_opcode
, INSN_DREF
},
2913 {"th.vssseg5b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG5E8V
, MASK_VSSSEG5E8V
, match_opcode
, INSN_DREF
},
2914 {"th.vssseg5h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG5E16V
, MASK_VSSSEG5E16V
, match_opcode
, INSN_DREF
},
2915 {"th.vssseg5w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG5E32V
, MASK_VSSSEG5E32V
, match_opcode
, INSN_DREF
},
2916 {"th.vssseg5e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG5E64V
, MASK_VSSSEG5E64V
, match_opcode
, INSN_DREF
},
2917 {"th.vlsseg6b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG6BV
, MASK_TH_VLSSEG6BV
, match_opcode
, INSN_DREF
},
2918 {"th.vlsseg6h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG6HV
, MASK_TH_VLSSEG6HV
, match_opcode
, INSN_DREF
},
2919 {"th.vlsseg6w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG6WV
, MASK_TH_VLSSEG6WV
, match_opcode
, INSN_DREF
},
2920 {"th.vlsseg6bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG6E8V
, MASK_VLSSEG6E8V
, match_opcode
, INSN_DREF
},
2921 {"th.vlsseg6hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG6E16V
, MASK_VLSSEG6E16V
, match_opcode
, INSN_DREF
},
2922 {"th.vlsseg6wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG6E32V
, MASK_VLSSEG6E32V
, match_opcode
, INSN_DREF
},
2923 {"th.vlsseg6e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG6E64V
, MASK_VLSSEG6E64V
, match_opcode
, INSN_DREF
},
2924 {"th.vssseg6b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG6E8V
, MASK_VSSSEG6E8V
, match_opcode
, INSN_DREF
},
2925 {"th.vssseg6h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG6E16V
, MASK_VSSSEG6E16V
, match_opcode
, INSN_DREF
},
2926 {"th.vssseg6w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG6E32V
, MASK_VSSSEG6E32V
, match_opcode
, INSN_DREF
},
2927 {"th.vssseg6e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG6E64V
, MASK_VSSSEG6E64V
, match_opcode
, INSN_DREF
},
2928 {"th.vlsseg7b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG7BV
, MASK_TH_VLSSEG7BV
, match_opcode
, INSN_DREF
},
2929 {"th.vlsseg7h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG7HV
, MASK_TH_VLSSEG7HV
, match_opcode
, INSN_DREF
},
2930 {"th.vlsseg7w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG7WV
, MASK_TH_VLSSEG7WV
, match_opcode
, INSN_DREF
},
2931 {"th.vlsseg7bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG7E8V
, MASK_VLSSEG7E8V
, match_opcode
, INSN_DREF
},
2932 {"th.vlsseg7hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG7E16V
, MASK_VLSSEG7E16V
, match_opcode
, INSN_DREF
},
2933 {"th.vlsseg7wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG7E32V
, MASK_VLSSEG7E32V
, match_opcode
, INSN_DREF
},
2934 {"th.vlsseg7e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG7E64V
, MASK_VLSSEG7E64V
, match_opcode
, INSN_DREF
},
2935 {"th.vssseg7b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG7E8V
, MASK_VSSSEG7E8V
, match_opcode
, INSN_DREF
},
2936 {"th.vssseg7h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG7E16V
, MASK_VSSSEG7E16V
, match_opcode
, INSN_DREF
},
2937 {"th.vssseg7w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG7E32V
, MASK_VSSSEG7E32V
, match_opcode
, INSN_DREF
},
2938 {"th.vssseg7e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG7E64V
, MASK_VSSSEG7E64V
, match_opcode
, INSN_DREF
},
2939 {"th.vlsseg8b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG8BV
, MASK_TH_VLSSEG8BV
, match_opcode
, INSN_DREF
},
2940 {"th.vlsseg8h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG8HV
, MASK_TH_VLSSEG8HV
, match_opcode
, INSN_DREF
},
2941 {"th.vlsseg8w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_TH_VLSSEG8WV
, MASK_TH_VLSSEG8WV
, match_opcode
, INSN_DREF
},
2942 {"th.vlsseg8bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG8E8V
, MASK_VLSSEG8E8V
, match_opcode
, INSN_DREF
},
2943 {"th.vlsseg8hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG8E16V
, MASK_VLSSEG8E16V
, match_opcode
, INSN_DREF
},
2944 {"th.vlsseg8wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG8E32V
, MASK_VLSSEG8E32V
, match_opcode
, INSN_DREF
},
2945 {"th.vlsseg8e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VLSSEG8E64V
, MASK_VLSSEG8E64V
, match_opcode
, INSN_DREF
},
2946 {"th.vssseg8b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG8E8V
, MASK_VSSSEG8E8V
, match_opcode
, INSN_DREF
},
2947 {"th.vssseg8h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG8E16V
, MASK_VSSSEG8E16V
, match_opcode
, INSN_DREF
},
2948 {"th.vssseg8w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG8E32V
, MASK_VSSSEG8E32V
, match_opcode
, INSN_DREF
},
2949 {"th.vssseg8e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),tVm", MATCH_VSSSEG8E64V
, MASK_VSSSEG8E64V
, match_opcode
, INSN_DREF
},
2950 {"th.vlxseg2b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG2BV
, MASK_TH_VLXSEG2BV
, match_opcode
, INSN_DREF
},
2951 {"th.vlxseg2h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG2HV
, MASK_TH_VLXSEG2HV
, match_opcode
, INSN_DREF
},
2952 {"th.vlxseg2w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG2WV
, MASK_TH_VLXSEG2WV
, match_opcode
, INSN_DREF
},
2953 {"th.vlxseg2bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI8V
, MASK_VLOXSEG2EI8V
, match_opcode
, INSN_DREF
},
2954 {"th.vlxseg2hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI16V
, MASK_VLOXSEG2EI16V
, match_opcode
, INSN_DREF
},
2955 {"th.vlxseg2wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI32V
, MASK_VLOXSEG2EI32V
, match_opcode
, INSN_DREF
},
2956 {"th.vlxseg2e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI64V
, MASK_VLOXSEG2EI64V
, match_opcode
, INSN_DREF
},
2957 {"th.vsxseg2b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI8V
, MASK_VSOXSEG2EI8V
, match_opcode
, INSN_DREF
},
2958 {"th.vsxseg2h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI16V
, MASK_VSOXSEG2EI16V
, match_opcode
, INSN_DREF
},
2959 {"th.vsxseg2w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI32V
, MASK_VSOXSEG2EI32V
, match_opcode
, INSN_DREF
},
2960 {"th.vsxseg2e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI64V
, MASK_VSOXSEG2EI64V
, match_opcode
, INSN_DREF
},
2961 {"th.vlxseg3b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG3BV
, MASK_TH_VLXSEG3BV
, match_opcode
, INSN_DREF
},
2962 {"th.vlxseg3h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG3HV
, MASK_TH_VLXSEG3HV
, match_opcode
, INSN_DREF
},
2963 {"th.vlxseg3w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG3WV
, MASK_TH_VLXSEG3WV
, match_opcode
, INSN_DREF
},
2964 {"th.vlxseg3bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI8V
, MASK_VLOXSEG3EI8V
, match_opcode
, INSN_DREF
},
2965 {"th.vlxseg3hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI16V
, MASK_VLOXSEG3EI16V
, match_opcode
, INSN_DREF
},
2966 {"th.vlxseg3wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI32V
, MASK_VLOXSEG3EI32V
, match_opcode
, INSN_DREF
},
2967 {"th.vlxseg3e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI64V
, MASK_VLOXSEG3EI64V
, match_opcode
, INSN_DREF
},
2968 {"th.vsxseg3b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI8V
, MASK_VSOXSEG3EI8V
, match_opcode
, INSN_DREF
},
2969 {"th.vsxseg3h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI16V
, MASK_VSOXSEG3EI16V
, match_opcode
, INSN_DREF
},
2970 {"th.vsxseg3w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI32V
, MASK_VSOXSEG3EI32V
, match_opcode
, INSN_DREF
},
2971 {"th.vsxseg3e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI64V
, MASK_VSOXSEG3EI64V
, match_opcode
, INSN_DREF
},
2972 {"th.vlxseg4b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG4BV
, MASK_TH_VLXSEG4BV
, match_opcode
, INSN_DREF
},
2973 {"th.vlxseg4h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG4HV
, MASK_TH_VLXSEG4HV
, match_opcode
, INSN_DREF
},
2974 {"th.vlxseg4w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG4WV
, MASK_TH_VLXSEG4WV
, match_opcode
, INSN_DREF
},
2975 {"th.vlxseg4bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI8V
, MASK_VLOXSEG4EI8V
, match_opcode
, INSN_DREF
},
2976 {"th.vlxseg4hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI16V
, MASK_VLOXSEG4EI16V
, match_opcode
, INSN_DREF
},
2977 {"th.vlxseg4wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI32V
, MASK_VLOXSEG4EI32V
, match_opcode
, INSN_DREF
},
2978 {"th.vlxseg4e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI64V
, MASK_VLOXSEG4EI64V
, match_opcode
, INSN_DREF
},
2979 {"th.vsxseg4b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI8V
, MASK_VSOXSEG4EI8V
, match_opcode
, INSN_DREF
},
2980 {"th.vsxseg4h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI16V
, MASK_VSOXSEG4EI16V
, match_opcode
, INSN_DREF
},
2981 {"th.vsxseg4w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI32V
, MASK_VSOXSEG4EI32V
, match_opcode
, INSN_DREF
},
2982 {"th.vsxseg4e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI64V
, MASK_VSOXSEG4EI64V
, match_opcode
, INSN_DREF
},
2983 {"th.vlxseg5b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG5BV
, MASK_TH_VLXSEG5BV
, match_opcode
, INSN_DREF
},
2984 {"th.vlxseg5h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG5HV
, MASK_TH_VLXSEG5HV
, match_opcode
, INSN_DREF
},
2985 {"th.vlxseg5w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG5WV
, MASK_TH_VLXSEG5WV
, match_opcode
, INSN_DREF
},
2986 {"th.vlxseg5bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI8V
, MASK_VLOXSEG5EI8V
, match_opcode
, INSN_DREF
},
2987 {"th.vlxseg5hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI16V
, MASK_VLOXSEG5EI16V
, match_opcode
, INSN_DREF
},
2988 {"th.vlxseg5wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI32V
, MASK_VLOXSEG5EI32V
, match_opcode
, INSN_DREF
},
2989 {"th.vlxseg5e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI64V
, MASK_VLOXSEG5EI64V
, match_opcode
, INSN_DREF
},
2990 {"th.vsxseg5b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI8V
, MASK_VSOXSEG5EI8V
, match_opcode
, INSN_DREF
},
2991 {"th.vsxseg5h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI16V
, MASK_VSOXSEG5EI16V
, match_opcode
, INSN_DREF
},
2992 {"th.vsxseg5w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI32V
, MASK_VSOXSEG5EI32V
, match_opcode
, INSN_DREF
},
2993 {"th.vsxseg5e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI64V
, MASK_VSOXSEG5EI64V
, match_opcode
, INSN_DREF
},
2994 {"th.vlxseg6b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG6BV
, MASK_TH_VLXSEG6BV
, match_opcode
, INSN_DREF
},
2995 {"th.vlxseg6h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG6HV
, MASK_TH_VLXSEG6HV
, match_opcode
, INSN_DREF
},
2996 {"th.vlxseg6w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG6WV
, MASK_TH_VLXSEG6WV
, match_opcode
, INSN_DREF
},
2997 {"th.vlxseg6bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI8V
, MASK_VLOXSEG6EI8V
, match_opcode
, INSN_DREF
},
2998 {"th.vlxseg6hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI16V
, MASK_VLOXSEG6EI16V
, match_opcode
, INSN_DREF
},
2999 {"th.vlxseg6wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI32V
, MASK_VLOXSEG6EI32V
, match_opcode
, INSN_DREF
},
3000 {"th.vlxseg6e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI64V
, MASK_VLOXSEG6EI64V
, match_opcode
, INSN_DREF
},
3001 {"th.vsxseg6b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI8V
, MASK_VSOXSEG6EI8V
, match_opcode
, INSN_DREF
},
3002 {"th.vsxseg6h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI16V
, MASK_VSOXSEG6EI16V
, match_opcode
, INSN_DREF
},
3003 {"th.vsxseg6w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI32V
, MASK_VSOXSEG6EI32V
, match_opcode
, INSN_DREF
},
3004 {"th.vsxseg6e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI64V
, MASK_VSOXSEG6EI64V
, match_opcode
, INSN_DREF
},
3005 {"th.vlxseg7b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG7BV
, MASK_TH_VLXSEG7BV
, match_opcode
, INSN_DREF
},
3006 {"th.vlxseg7h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG7HV
, MASK_TH_VLXSEG7HV
, match_opcode
, INSN_DREF
},
3007 {"th.vlxseg7w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG7WV
, MASK_TH_VLXSEG7WV
, match_opcode
, INSN_DREF
},
3008 {"th.vlxseg7bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI8V
, MASK_VLOXSEG7EI8V
, match_opcode
, INSN_DREF
},
3009 {"th.vlxseg7hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI16V
, MASK_VLOXSEG7EI16V
, match_opcode
, INSN_DREF
},
3010 {"th.vlxseg7wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI32V
, MASK_VLOXSEG7EI32V
, match_opcode
, INSN_DREF
},
3011 {"th.vlxseg7e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI64V
, MASK_VLOXSEG7EI64V
, match_opcode
, INSN_DREF
},
3012 {"th.vsxseg7b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI8V
, MASK_VSOXSEG7EI8V
, match_opcode
, INSN_DREF
},
3013 {"th.vsxseg7h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI16V
, MASK_VSOXSEG7EI16V
, match_opcode
, INSN_DREF
},
3014 {"th.vsxseg7w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI32V
, MASK_VSOXSEG7EI32V
, match_opcode
, INSN_DREF
},
3015 {"th.vsxseg7e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI64V
, MASK_VSOXSEG7EI64V
, match_opcode
, INSN_DREF
},
3016 {"th.vlxseg8b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG8BV
, MASK_TH_VLXSEG8BV
, match_opcode
, INSN_DREF
},
3017 {"th.vlxseg8h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG8HV
, MASK_TH_VLXSEG8HV
, match_opcode
, INSN_DREF
},
3018 {"th.vlxseg8w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_TH_VLXSEG8WV
, MASK_TH_VLXSEG8WV
, match_opcode
, INSN_DREF
},
3019 {"th.vlxseg8bu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI8V
, MASK_VLOXSEG8EI8V
, match_opcode
, INSN_DREF
},
3020 {"th.vlxseg8hu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI16V
, MASK_VLOXSEG8EI16V
, match_opcode
, INSN_DREF
},
3021 {"th.vlxseg8wu.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI32V
, MASK_VLOXSEG8EI32V
, match_opcode
, INSN_DREF
},
3022 {"th.vlxseg8e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI64V
, MASK_VLOXSEG8EI64V
, match_opcode
, INSN_DREF
},
3023 {"th.vsxseg8b.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI8V
, MASK_VSOXSEG8EI8V
, match_opcode
, INSN_DREF
},
3024 {"th.vsxseg8h.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI16V
, MASK_VSOXSEG8EI16V
, match_opcode
, INSN_DREF
},
3025 {"th.vsxseg8w.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI32V
, MASK_VSOXSEG8EI32V
, match_opcode
, INSN_DREF
},
3026 {"th.vsxseg8e.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI64V
, MASK_VSOXSEG8EI64V
, match_opcode
, INSN_DREF
},
3027 {"th.vlseg2bff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG2BFFV
, MASK_TH_VLSEG2BFFV
, match_opcode
, INSN_DREF
},
3028 {"th.vlseg2hff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG2HFFV
, MASK_TH_VLSEG2HFFV
, match_opcode
, INSN_DREF
},
3029 {"th.vlseg2wff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG2WFFV
, MASK_TH_VLSEG2WFFV
, match_opcode
, INSN_DREF
},
3030 {"th.vlseg2buff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E8FFV
, MASK_VLSEG2E8FFV
, match_opcode
, INSN_DREF
},
3031 {"th.vlseg2huff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E16FFV
, MASK_VLSEG2E16FFV
, match_opcode
, INSN_DREF
},
3032 {"th.vlseg2wuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E32FFV
, MASK_VLSEG2E32FFV
, match_opcode
, INSN_DREF
},
3033 {"th.vlseg2eff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG2E64FFV
, MASK_VLSEG2E64FFV
, match_opcode
, INSN_DREF
},
3034 {"th.vlseg3bff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG3BFFV
, MASK_TH_VLSEG3BFFV
, match_opcode
, INSN_DREF
},
3035 {"th.vlseg3hff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG3HFFV
, MASK_TH_VLSEG3HFFV
, match_opcode
, INSN_DREF
},
3036 {"th.vlseg3wff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG3WFFV
, MASK_TH_VLSEG3WFFV
, match_opcode
, INSN_DREF
},
3037 {"th.vlseg3buff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E8FFV
, MASK_VLSEG3E8FFV
, match_opcode
, INSN_DREF
},
3038 {"th.vlseg3huff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E16FFV
, MASK_VLSEG3E16FFV
, match_opcode
, INSN_DREF
},
3039 {"th.vlseg3wuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E32FFV
, MASK_VLSEG3E32FFV
, match_opcode
, INSN_DREF
},
3040 {"th.vlseg3eff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG3E64FFV
, MASK_VLSEG3E64FFV
, match_opcode
, INSN_DREF
},
3041 {"th.vlseg4bff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG4BFFV
, MASK_TH_VLSEG4BFFV
, match_opcode
, INSN_DREF
},
3042 {"th.vlseg4hff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG4HFFV
, MASK_TH_VLSEG4HFFV
, match_opcode
, INSN_DREF
},
3043 {"th.vlseg4wff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG4WFFV
, MASK_TH_VLSEG4WFFV
, match_opcode
, INSN_DREF
},
3044 {"th.vlseg4buff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E8FFV
, MASK_VLSEG4E8FFV
, match_opcode
, INSN_DREF
},
3045 {"th.vlseg4huff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E16FFV
, MASK_VLSEG4E16FFV
, match_opcode
, INSN_DREF
},
3046 {"th.vlseg4wuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E32FFV
, MASK_VLSEG4E32FFV
, match_opcode
, INSN_DREF
},
3047 {"th.vlseg4eff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG4E64FFV
, MASK_VLSEG4E64FFV
, match_opcode
, INSN_DREF
},
3048 {"th.vlseg5bff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG5BFFV
, MASK_TH_VLSEG5BFFV
, match_opcode
, INSN_DREF
},
3049 {"th.vlseg5hff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG5HFFV
, MASK_TH_VLSEG5HFFV
, match_opcode
, INSN_DREF
},
3050 {"th.vlseg5wff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG5WFFV
, MASK_TH_VLSEG5WFFV
, match_opcode
, INSN_DREF
},
3051 {"th.vlseg5buff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E8FFV
, MASK_VLSEG5E8FFV
, match_opcode
, INSN_DREF
},
3052 {"th.vlseg5huff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E16FFV
, MASK_VLSEG5E16FFV
, match_opcode
, INSN_DREF
},
3053 {"th.vlseg5wuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E32FFV
, MASK_VLSEG5E32FFV
, match_opcode
, INSN_DREF
},
3054 {"th.vlseg5eff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG5E64FFV
, MASK_VLSEG5E64FFV
, match_opcode
, INSN_DREF
},
3055 {"th.vlseg6bff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG6BFFV
, MASK_TH_VLSEG6BFFV
, match_opcode
, INSN_DREF
},
3056 {"th.vlseg6hff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG6HFFV
, MASK_TH_VLSEG6HFFV
, match_opcode
, INSN_DREF
},
3057 {"th.vlseg6wff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG6WFFV
, MASK_TH_VLSEG6WFFV
, match_opcode
, INSN_DREF
},
3058 {"th.vlseg6buff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E8FFV
, MASK_VLSEG6E8FFV
, match_opcode
, INSN_DREF
},
3059 {"th.vlseg6huff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E16FFV
, MASK_VLSEG6E16FFV
, match_opcode
, INSN_DREF
},
3060 {"th.vlseg6wuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E32FFV
, MASK_VLSEG6E32FFV
, match_opcode
, INSN_DREF
},
3061 {"th.vlseg6eff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG6E64FFV
, MASK_VLSEG6E64FFV
, match_opcode
, INSN_DREF
},
3062 {"th.vlseg7bff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG7BFFV
, MASK_TH_VLSEG7BFFV
, match_opcode
, INSN_DREF
},
3063 {"th.vlseg7hff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG7HFFV
, MASK_TH_VLSEG7HFFV
, match_opcode
, INSN_DREF
},
3064 {"th.vlseg7wff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG7WFFV
, MASK_TH_VLSEG7WFFV
, match_opcode
, INSN_DREF
},
3065 {"th.vlseg7buff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E8FFV
, MASK_VLSEG7E8FFV
, match_opcode
, INSN_DREF
},
3066 {"th.vlseg7huff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E16FFV
, MASK_VLSEG7E16FFV
, match_opcode
, INSN_DREF
},
3067 {"th.vlseg7wuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E32FFV
, MASK_VLSEG7E32FFV
, match_opcode
, INSN_DREF
},
3068 {"th.vlseg7eff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG7E64FFV
, MASK_VLSEG7E64FFV
, match_opcode
, INSN_DREF
},
3069 {"th.vlseg8bff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG8BFFV
, MASK_TH_VLSEG8BFFV
, match_opcode
, INSN_DREF
},
3070 {"th.vlseg8hff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG8HFFV
, MASK_TH_VLSEG8HFFV
, match_opcode
, INSN_DREF
},
3071 {"th.vlseg8wff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_TH_VLSEG8WFFV
, MASK_TH_VLSEG8WFFV
, match_opcode
, INSN_DREF
},
3072 {"th.vlseg8buff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E8FFV
, MASK_VLSEG8E8FFV
, match_opcode
, INSN_DREF
},
3073 {"th.vlseg8huff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E16FFV
, MASK_VLSEG8E16FFV
, match_opcode
, INSN_DREF
},
3074 {"th.vlseg8wuff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E32FFV
, MASK_VLSEG8E32FFV
, match_opcode
, INSN_DREF
},
3075 {"th.vlseg8eff.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,0(s)Vm", MATCH_VLSEG8E64FFV
, MASK_VLSEG8E64FFV
, match_opcode
, INSN_DREF
},
3076 {"th.vamoaddw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOADDWV
, MASK_TH_VAMOADDWV
, match_opcode
, INSN_DREF
},
3077 {"th.vamoaddd.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOADDDV
, MASK_TH_VAMOADDDV
, match_opcode
, INSN_DREF
},
3078 {"th.vamoswapw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOSWAPWV
, MASK_TH_VAMOSWAPWV
, match_opcode
, INSN_DREF
},
3079 {"th.vamoswapd.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOSWAPDV
, MASK_TH_VAMOSWAPDV
, match_opcode
, INSN_DREF
},
3080 {"th.vamoxorw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOXORWV
, MASK_TH_VAMOXORWV
, match_opcode
, INSN_DREF
},
3081 {"th.vamoxord.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOXORDV
, MASK_TH_VAMOXORDV
, match_opcode
, INSN_DREF
},
3082 {"th.vamoandw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOANDWV
, MASK_TH_VAMOANDWV
, match_opcode
, INSN_DREF
},
3083 {"th.vamoandd.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOANDDV
, MASK_TH_VAMOANDDV
, match_opcode
, INSN_DREF
},
3084 {"th.vamoorw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOORWV
, MASK_TH_VAMOORWV
, match_opcode
, INSN_DREF
},
3085 {"th.vamoord.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOORDV
, MASK_TH_VAMOORDV
, match_opcode
, INSN_DREF
},
3086 {"th.vamominw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMINWV
, MASK_TH_VAMOMINWV
, match_opcode
, INSN_DREF
},
3087 {"th.vamomind.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMINDV
, MASK_TH_VAMOMINDV
, match_opcode
, INSN_DREF
},
3088 {"th.vamomaxw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMAXWV
, MASK_TH_VAMOMAXWV
, match_opcode
, INSN_DREF
},
3089 {"th.vamomaxd.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMAXDV
, MASK_TH_VAMOMAXDV
, match_opcode
, INSN_DREF
},
3090 {"th.vamominuw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMINUWV
, MASK_TH_VAMOMINUWV
, match_opcode
, INSN_DREF
},
3091 {"th.vamominud.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMINUDV
, MASK_TH_VAMOMINUDV
, match_opcode
, INSN_DREF
},
3092 {"th.vamomaxuw.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMAXUWV
, MASK_TH_VAMOMAXUWV
, match_opcode
, INSN_DREF
},
3093 {"th.vamomaxud.v", 0, INSN_CLASS_XTHEADZVAMO
, "Ve,Vt,(s),VfVm", MATCH_TH_VAMOMAXUDV
, MASK_TH_VAMOMAXUDV
, match_opcode
, INSN_DREF
},
3094 {"th.vneg.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_VRSUBVX
, MASK_VRSUBVX
| MASK_RS1
, match_opcode
, INSN_ALIAS
},
3095 {"th.vadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VADDVV
, MASK_VADDVV
, match_opcode
, 0 },
3096 {"th.vadd.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VADDVX
, MASK_VADDVX
, match_opcode
, 0 },
3097 {"th.vadd.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VADDVI
, MASK_VADDVI
, match_opcode
, 0 },
3098 {"th.vsub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSUBVV
, MASK_VSUBVV
, match_opcode
, 0 },
3099 {"th.vsub.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSUBVX
, MASK_VSUBVX
, match_opcode
, 0 },
3100 {"th.vrsub.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VRSUBVX
, MASK_VRSUBVX
, match_opcode
, 0 },
3101 {"th.vrsub.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VRSUBVI
, MASK_VRSUBVI
, match_opcode
, 0 },
3102 {"th.vwcvt.x.x.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_VWCVTXXV
, MASK_VWCVTXXV
, match_opcode
, INSN_ALIAS
},
3103 {"th.vwcvtu.x.x.v",0,INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_VWCVTUXXV
, MASK_VWCVTUXXV
, match_opcode
, INSN_ALIAS
},
3104 {"th.vwaddu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWADDUVV
, MASK_VWADDUVV
, match_opcode
, 0 },
3105 {"th.vwaddu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWADDUVX
, MASK_VWADDUVX
, match_opcode
, 0 },
3106 {"th.vwsubu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWSUBUVV
, MASK_VWSUBUVV
, match_opcode
, 0 },
3107 {"th.vwsubu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWSUBUVX
, MASK_VWSUBUVX
, match_opcode
, 0 },
3108 {"th.vwadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWADDVV
, MASK_VWADDVV
, match_opcode
, 0 },
3109 {"th.vwadd.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWADDVX
, MASK_VWADDVX
, match_opcode
, 0 },
3110 {"th.vwsub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWSUBVV
, MASK_VWSUBVV
, match_opcode
, 0 },
3111 {"th.vwsub.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWSUBVX
, MASK_VWSUBVX
, match_opcode
, 0 },
3112 {"th.vwaddu.wv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWADDUWV
, MASK_VWADDUWV
, match_opcode
, 0 },
3113 {"th.vwaddu.wx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWADDUWX
, MASK_VWADDUWX
, match_opcode
, 0 },
3114 {"th.vwsubu.wv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWSUBUWV
, MASK_VWSUBUWV
, match_opcode
, 0 },
3115 {"th.vwsubu.wx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWSUBUWX
, MASK_VWSUBUWX
, match_opcode
, 0 },
3116 {"th.vwadd.wv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWADDWV
, MASK_VWADDWV
, match_opcode
, 0 },
3117 {"th.vwadd.wx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWADDWX
, MASK_VWADDWX
, match_opcode
, 0 },
3118 {"th.vwsub.wv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWSUBWV
, MASK_VWSUBWV
, match_opcode
, 0 },
3119 {"th.vwsub.wx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWSUBWX
, MASK_VWSUBWX
, match_opcode
, 0 },
3120 {"th.vadc.vvm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs,V0", MATCH_TH_VADCVVM
, MASK_TH_VADCVVM
, match_opcode
, 0 },
3121 {"th.vadc.vxm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,s,V0", MATCH_TH_VADCVXM
, MASK_TH_VADCVXM
, match_opcode
, 0 },
3122 {"th.vadc.vim", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vi,V0", MATCH_TH_VADCVIM
, MASK_TH_VADCVIM
, match_opcode
, 0 },
3123 {"th.vmadc.vvm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs,V0", MATCH_VMADCVV
, MASK_VMADCVV
, match_opcode
, 0 },
3124 {"th.vmadc.vxm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,s,V0", MATCH_VMADCVX
, MASK_VMADCVX
, match_opcode
, 0 },
3125 {"th.vmadc.vim", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vi,V0", MATCH_VMADCVI
, MASK_VMADCVI
, match_opcode
, 0 },
3126 {"th.vsbc.vvm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs,V0", MATCH_TH_VSBCVVM
, MASK_TH_VSBCVVM
, match_opcode
, 0 },
3127 {"th.vsbc.vxm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,s,V0", MATCH_TH_VSBCVXM
, MASK_TH_VSBCVXM
, match_opcode
, 0 },
3128 {"th.vmsbc.vvm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs,V0", MATCH_VMSBCVV
, MASK_VMSBCVV
, match_opcode
, 0 },
3129 {"th.vmsbc.vxm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,s,V0", MATCH_VMSBCVX
, MASK_VMSBCVX
, match_opcode
, 0 },
3130 {"th.vnot.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_VNOTV
, MASK_VNOTV
, match_opcode
, INSN_ALIAS
},
3131 {"th.vand.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VANDVV
, MASK_VANDVV
, match_opcode
, 0 },
3132 {"th.vand.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VANDVX
, MASK_VANDVX
, match_opcode
, 0 },
3133 {"th.vand.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VANDVI
, MASK_VANDVI
, match_opcode
, 0 },
3134 {"th.vor.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VORVV
, MASK_VORVV
, match_opcode
, 0 },
3135 {"th.vor.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VORVX
, MASK_VORVX
, match_opcode
, 0 },
3136 {"th.vor.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VORVI
, MASK_VORVI
, match_opcode
, 0 },
3137 {"th.vxor.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VXORVV
, MASK_VXORVV
, match_opcode
, 0 },
3138 {"th.vxor.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VXORVX
, MASK_VXORVX
, match_opcode
, 0 },
3139 {"th.vxor.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VXORVI
, MASK_VXORVI
, match_opcode
, 0 },
3140 {"th.vsll.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSLLVV
, MASK_VSLLVV
, match_opcode
, 0 },
3141 {"th.vsll.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSLLVX
, MASK_VSLLVX
, match_opcode
, 0 },
3142 {"th.vsll.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VSLLVI
, MASK_VSLLVI
, match_opcode
, 0 },
3143 {"th.vsrl.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSRLVV
, MASK_VSRLVV
, match_opcode
, 0 },
3144 {"th.vsrl.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSRLVX
, MASK_VSRLVX
, match_opcode
, 0 },
3145 {"th.vsrl.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VSRLVI
, MASK_VSRLVI
, match_opcode
, 0 },
3146 {"th.vsra.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSRAVV
, MASK_VSRAVV
, match_opcode
, 0 },
3147 {"th.vsra.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSRAVX
, MASK_VSRAVX
, match_opcode
, 0 },
3148 {"th.vsra.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VSRAVI
, MASK_VSRAVI
, match_opcode
, 0 },
3149 {"th.vncvt.x.x.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_VNCVTXXW
, MASK_VNCVTXXW
, match_opcode
, INSN_ALIAS
},
3150 {"th.vnsrl.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VNSRLWV
, MASK_VNSRLWV
, match_opcode
, 0 },
3151 {"th.vnsrl.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VNSRLWX
, MASK_VNSRLWX
, match_opcode
, 0 },
3152 {"th.vnsrl.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VNSRLWI
, MASK_VNSRLWI
, match_opcode
, 0 },
3153 {"th.vnsra.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VNSRAWV
, MASK_VNSRAWV
, match_opcode
, 0 },
3154 {"th.vnsra.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VNSRAWX
, MASK_VNSRAWX
, match_opcode
, 0 },
3155 {"th.vnsra.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VNSRAWI
, MASK_VNSRAWI
, match_opcode
, 0 },
3156 {"th.vmseq.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMSEQVV
, MASK_VMSEQVV
, match_opcode
, 0 },
3157 {"th.vmseq.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSEQVX
, MASK_VMSEQVX
, match_opcode
, 0 },
3158 {"th.vmseq.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VMSEQVI
, MASK_VMSEQVI
, match_opcode
, 0 },
3159 {"th.vmsne.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMSNEVV
, MASK_VMSNEVV
, match_opcode
, 0 },
3160 {"th.vmsne.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSNEVX
, MASK_VMSNEVX
, match_opcode
, 0 },
3161 {"th.vmsne.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VMSNEVI
, MASK_VMSNEVI
, match_opcode
, 0 },
3162 {"th.vmsltu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMSLTUVV
, MASK_VMSLTUVV
, match_opcode
, 0 },
3163 {"th.vmsltu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSLTUVX
, MASK_VMSLTUVX
, match_opcode
, 0 },
3164 {"th.vmslt.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMSLTVV
, MASK_VMSLTVV
, match_opcode
, 0 },
3165 {"th.vmslt.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSLTVX
, MASK_VMSLTVX
, match_opcode
, 0 },
3166 {"th.vmsleu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMSLEUVV
, MASK_VMSLEUVV
, match_opcode
, 0 },
3167 {"th.vmsleu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSLEUVX
, MASK_VMSLEUVX
, match_opcode
, 0 },
3168 {"th.vmsleu.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VMSLEUVI
, MASK_VMSLEUVI
, match_opcode
, 0 },
3169 {"th.vmsle.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMSLEVV
, MASK_VMSLEVV
, match_opcode
, 0 },
3170 {"th.vmsle.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSLEVX
, MASK_VMSLEVX
, match_opcode
, 0 },
3171 {"th.vmsle.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VMSLEVI
, MASK_VMSLEVI
, match_opcode
, 0 },
3172 {"th.vmsgtu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSGTUVX
, MASK_VMSGTUVX
, match_opcode
, 0 },
3173 {"th.vmsgtu.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VMSGTUVI
, MASK_VMSGTUVI
, match_opcode
, 0 },
3174 {"th.vmsgt.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMSGTVX
, MASK_VMSGTVX
, match_opcode
, 0 },
3175 {"th.vmsgt.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VMSGTVI
, MASK_VMSGTVI
, match_opcode
, 0 },
3176 {"th.vmsgt.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMSLTVV
, MASK_VMSLTVV
, match_opcode
, INSN_ALIAS
},
3177 {"th.vmsgtu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMSLTUVV
, MASK_VMSLTUVV
, match_opcode
, INSN_ALIAS
},
3178 {"th.vmsge.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMSLEVV
, MASK_VMSLEVV
, match_opcode
, INSN_ALIAS
},
3179 {"th.vmsgeu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMSLEUVV
, MASK_VMSLEUVV
, match_opcode
, INSN_ALIAS
},
3180 {"th.vmslt.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VkVm", MATCH_VMSLEVI
, MASK_VMSLEVI
, match_opcode
, INSN_ALIAS
},
3181 {"th.vmsltu.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VkVm", MATCH_VMSLEUVI
, MASK_VMSLEUVI
, match_opcode
, INSN_ALIAS
},
3182 {"th.vmsge.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VkVm", MATCH_VMSGTVI
, MASK_VMSGTVI
, match_opcode
, INSN_ALIAS
},
3183 {"th.vmsgeu.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VkVm", MATCH_VMSGTUVI
, MASK_VMSGTUVI
, match_opcode
, INSN_ALIAS
},
3184 {"th.vmsge.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", 0, (int) M_VMSGE
, NULL
, INSN_MACRO
},
3185 {"th.vmsge.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,s,VM,VT", 0, (int) M_VMSGE
, NULL
, INSN_MACRO
},
3186 {"th.vmsgeu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", 1, (int) M_VMSGE
, NULL
, INSN_MACRO
},
3187 {"th.vmsgeu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,s,VM,VT", 1, (int) M_VMSGE
, NULL
, INSN_MACRO
},
3188 {"th.vminu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMINUVV
, MASK_VMINUVV
, match_opcode
, 0},
3189 {"th.vminu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMINUVX
, MASK_VMINUVX
, match_opcode
, 0},
3190 {"th.vmin.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMINVV
, MASK_VMINVV
, match_opcode
, 0},
3191 {"th.vmin.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMINVX
, MASK_VMINVX
, match_opcode
, 0},
3192 {"th.vmaxu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMAXUVV
, MASK_VMAXUVV
, match_opcode
, 0},
3193 {"th.vmaxu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMAXUVX
, MASK_VMAXUVX
, match_opcode
, 0},
3194 {"th.vmax.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMAXVV
, MASK_VMAXVV
, match_opcode
, 0},
3195 {"th.vmax.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMAXVX
, MASK_VMAXVX
, match_opcode
, 0},
3196 {"th.vmul.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMULVV
, MASK_VMULVV
, match_opcode
, 0 },
3197 {"th.vmul.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMULVX
, MASK_VMULVX
, match_opcode
, 0 },
3198 {"th.vmulh.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMULHVV
, MASK_VMULHVV
, match_opcode
, 0 },
3199 {"th.vmulh.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMULHVX
, MASK_VMULHVX
, match_opcode
, 0 },
3200 {"th.vmulhu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMULHUVV
, MASK_VMULHUVV
, match_opcode
, 0 },
3201 {"th.vmulhu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMULHUVX
, MASK_VMULHUVX
, match_opcode
, 0 },
3202 {"th.vmulhsu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMULHSUVV
, MASK_VMULHSUVV
, match_opcode
, 0 },
3203 {"th.vmulhsu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VMULHSUVX
, MASK_VMULHSUVX
, match_opcode
, 0 },
3204 {"th.vwmul.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWMULVV
, MASK_VWMULVV
, match_opcode
, 0 },
3205 {"th.vwmul.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWMULVX
, MASK_VWMULVX
, match_opcode
, 0 },
3206 {"th.vwmulu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWMULUVV
, MASK_VWMULUVV
, match_opcode
, 0 },
3207 {"th.vwmulu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWMULUVX
, MASK_VWMULUVX
, match_opcode
, 0 },
3208 {"th.vwmulsu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWMULSUVV
, MASK_VWMULSUVV
, match_opcode
, 0 },
3209 {"th.vwmulsu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VWMULSUVX
, MASK_VWMULSUVX
, match_opcode
, 0 },
3210 {"th.vmacc.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMACCVV
, MASK_VMACCVV
, match_opcode
, 0},
3211 {"th.vmacc.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VMACCVX
, MASK_VMACCVX
, match_opcode
, 0},
3212 {"th.vnmsac.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VNMSACVV
, MASK_VNMSACVV
, match_opcode
, 0},
3213 {"th.vnmsac.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VNMSACVX
, MASK_VNMSACVX
, match_opcode
, 0},
3214 {"th.vmadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMADDVV
, MASK_VMADDVV
, match_opcode
, 0},
3215 {"th.vmadd.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VMADDVX
, MASK_VMADDVX
, match_opcode
, 0},
3216 {"th.vnmsub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VNMSUBVV
, MASK_VNMSUBVV
, match_opcode
, 0},
3217 {"th.vnmsub.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VNMSUBVX
, MASK_VNMSUBVX
, match_opcode
, 0},
3218 {"th.vwmaccu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VWMACCUVV
, MASK_VWMACCUVV
, match_opcode
, 0},
3219 {"th.vwmaccu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VWMACCUVX
, MASK_VWMACCUVX
, match_opcode
, 0},
3220 {"th.vwmacc.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VWMACCVV
, MASK_VWMACCVV
, match_opcode
, 0},
3221 {"th.vwmacc.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VWMACCVX
, MASK_VWMACCVX
, match_opcode
, 0},
3222 {"th.vwmaccsu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_TH_VWMACCSUVV
, MASK_TH_VWMACCSUVV
, match_opcode
, 0},
3223 {"th.vwmaccsu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VWMACCUSVX
, MASK_VWMACCUSVX
, match_opcode
, 0},
3224 {"th.vwmaccus.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VWMACCSUVX
, MASK_VWMACCSUVX
, match_opcode
, 0},
3225 {"th.vdivu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VDIVUVV
, MASK_VDIVUVV
, match_opcode
, 0 },
3226 {"th.vdivu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VDIVUVX
, MASK_VDIVUVX
, match_opcode
, 0 },
3227 {"th.vdiv.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VDIVVV
, MASK_VDIVVV
, match_opcode
, 0 },
3228 {"th.vdiv.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VDIVVX
, MASK_VDIVVX
, match_opcode
, 0 },
3229 {"th.vremu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREMUVV
, MASK_VREMUVV
, match_opcode
, 0 },
3230 {"th.vremu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VREMUVX
, MASK_VREMUVX
, match_opcode
, 0 },
3231 {"th.vrem.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREMVV
, MASK_VREMVV
, match_opcode
, 0 },
3232 {"th.vrem.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VREMVX
, MASK_VREMVX
, match_opcode
, 0 },
3233 {"th.vmerge.vvm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs,V0", MATCH_VMERGEVVM
, MASK_VMERGEVVM
, match_opcode
, 0 },
3234 {"th.vmerge.vxm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,s,V0", MATCH_VMERGEVXM
, MASK_VMERGEVXM
, match_opcode
, 0 },
3235 {"th.vmerge.vim", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vi,V0", MATCH_VMERGEVIM
, MASK_VMERGEVIM
, match_opcode
, 0 },
3236 {"th.vmv.v.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs", MATCH_VMVVV
, MASK_VMVVV
, match_opcode
, 0 },
3237 {"th.vmv.v.x", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s", MATCH_VMVVX
, MASK_VMVVX
, match_opcode
, 0 },
3238 {"th.vmv.v.i", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vi", MATCH_VMVVI
, MASK_VMVVI
, match_opcode
, 0 },
3239 {"th.vsaddu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSADDUVV
, MASK_VSADDUVV
, match_opcode
, 0 },
3240 {"th.vsaddu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSADDUVX
, MASK_VSADDUVX
, match_opcode
, 0 },
3241 {"th.vsaddu.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VSADDUVI
, MASK_VSADDUVI
, match_opcode
, 0 },
3242 {"th.vsadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSADDVV
, MASK_VSADDVV
, match_opcode
, 0 },
3243 {"th.vsadd.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSADDVX
, MASK_VSADDVX
, match_opcode
, 0 },
3244 {"th.vsadd.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_VSADDVI
, MASK_VSADDVI
, match_opcode
, 0 },
3245 {"th.vssubu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSSUBUVV
, MASK_VSSUBUVV
, match_opcode
, 0 },
3246 {"th.vssubu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSSUBUVX
, MASK_VSSUBUVX
, match_opcode
, 0 },
3247 {"th.vssub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSSUBVV
, MASK_VSSUBVV
, match_opcode
, 0 },
3248 {"th.vssub.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSSUBVX
, MASK_VSSUBVX
, match_opcode
, 0 },
3249 {"th.vaadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_TH_VAADDVV
, MASK_TH_VAADDVV
, match_opcode
, 0 },
3250 {"th.vaadd.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_TH_VAADDVX
, MASK_TH_VAADDVX
, match_opcode
, 0 },
3251 {"th.vaadd.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,ViVm", MATCH_TH_VAADDVI
, MASK_TH_VAADDVI
, match_opcode
, 0 },
3252 {"th.vasub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_TH_VASUBVV
, MASK_TH_VASUBVV
, match_opcode
, 0 },
3253 {"th.vasub.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_TH_VASUBVX
, MASK_TH_VASUBVX
, match_opcode
, 0 },
3254 {"th.vsmul.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSMULVV
, MASK_VSMULVV
, match_opcode
, 0 },
3255 {"th.vsmul.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSMULVX
, MASK_VSMULVX
, match_opcode
, 0 },
3256 {"th.vwsmaccu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VQMACCUVV
, MASK_VQMACCUVV
, match_opcode
, 0 },
3257 {"th.vwsmaccu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VQMACCUVX
, MASK_VQMACCUVX
, match_opcode
, 0 },
3258 {"th.vwsmacc.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VQMACCVV
, MASK_VQMACCVV
, match_opcode
, 0 },
3259 {"th.vwsmacc.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VQMACCVX
, MASK_VQMACCVX
, match_opcode
, 0 },
3260 {"th.vwsmaccsu.vv",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_TH_VWSMACCSUVV
, MASK_TH_VWSMACCSUVV
, match_opcode
, 0 },
3261 {"th.vwsmaccsu.vx",0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VQMACCUSVX
, MASK_VQMACCUSVX
, match_opcode
, 0 },
3262 {"th.vwsmaccus.vx",0, INSN_CLASS_XTHEADVECTOR
, "Vd,s,VtVm", MATCH_VQMACCSUVX
, MASK_VQMACCSUVX
, match_opcode
, 0 },
3263 {"th.vssrl.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSSRLVV
, MASK_VSSRLVV
, match_opcode
, 0 },
3264 {"th.vssrl.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSSRLVX
, MASK_VSSRLVX
, match_opcode
, 0 },
3265 {"th.vssrl.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VSSRLVI
, MASK_VSSRLVI
, match_opcode
, 0 },
3266 {"th.vssra.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VSSRAVV
, MASK_VSSRAVV
, match_opcode
, 0 },
3267 {"th.vssra.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSSRAVX
, MASK_VSSRAVX
, match_opcode
, 0 },
3268 {"th.vssra.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VSSRAVI
, MASK_VSSRAVI
, match_opcode
, 0 },
3269 {"th.vnclipu.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VNCLIPUWV
, MASK_VNCLIPUWV
, match_opcode
, 0 },
3270 {"th.vnclipu.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VNCLIPUWX
, MASK_VNCLIPUWX
, match_opcode
, 0 },
3271 {"th.vnclipu.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VNCLIPUWI
, MASK_VNCLIPUWI
, match_opcode
, 0 },
3272 {"th.vnclip.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VNCLIPWV
, MASK_VNCLIPWV
, match_opcode
, 0 },
3273 {"th.vnclip.vx", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VNCLIPWX
, MASK_VNCLIPWX
, match_opcode
, 0 },
3274 {"th.vnclip.vi", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VNCLIPWI
, MASK_VNCLIPWI
, match_opcode
, 0 },
3275 {"th.vfadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFADDVV
, MASK_VFADDVV
, match_opcode
, 0},
3276 {"th.vfadd.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFADDVF
, MASK_VFADDVF
, match_opcode
, 0},
3277 {"th.vfsub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFSUBVV
, MASK_VFSUBVV
, match_opcode
, 0},
3278 {"th.vfsub.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFSUBVF
, MASK_VFSUBVF
, match_opcode
, 0},
3279 {"th.vfrsub.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFRSUBVF
, MASK_VFRSUBVF
, match_opcode
, 0},
3280 {"th.vfwadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFWADDVV
, MASK_VFWADDVV
, match_opcode
, 0},
3281 {"th.vfwadd.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFWADDVF
, MASK_VFWADDVF
, match_opcode
, 0},
3282 {"th.vfwsub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFWSUBVV
, MASK_VFWSUBVV
, match_opcode
, 0},
3283 {"th.vfwsub.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFWSUBVF
, MASK_VFWSUBVF
, match_opcode
, 0},
3284 {"th.vfwadd.wv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFWADDWV
, MASK_VFWADDWV
, match_opcode
, 0},
3285 {"th.vfwsub.wv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFWSUBWV
, MASK_VFWSUBWV
, match_opcode
, 0},
3286 {"th.vfwadd.wf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFWADDWF
, MASK_VFWADDWF
, match_opcode
, 0},
3287 {"th.vfwsub.wf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFWSUBWF
, MASK_VFWSUBWF
, match_opcode
, 0},
3288 {"th.vfmul.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFMULVV
, MASK_VFMULVV
, match_opcode
, 0},
3289 {"th.vfmul.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFMULVF
, MASK_VFMULVF
, match_opcode
, 0},
3290 {"th.vfdiv.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFDIVVV
, MASK_VFDIVVV
, match_opcode
, 0},
3291 {"th.vfdiv.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFDIVVF
, MASK_VFDIVVF
, match_opcode
, 0},
3292 {"th.vfrdiv.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFRDIVVF
, MASK_VFRDIVVF
, match_opcode
, 0},
3293 {"th.vfwmul.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFWMULVV
, MASK_VFWMULVV
, match_opcode
, 0},
3294 {"th.vfwmul.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFWMULVF
, MASK_VFWMULVF
, match_opcode
, 0},
3295 {"th.vfmadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFMADDVV
, MASK_VFMADDVV
, match_opcode
, 0},
3296 {"th.vfmadd.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFMADDVF
, MASK_VFMADDVF
, match_opcode
, 0},
3297 {"th.vfnmadd.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFNMADDVV
, MASK_VFNMADDVV
, match_opcode
, 0},
3298 {"th.vfnmadd.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFNMADDVF
, MASK_VFNMADDVF
, match_opcode
, 0},
3299 {"th.vfmsub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFMSUBVV
, MASK_VFMSUBVV
, match_opcode
, 0},
3300 {"th.vfmsub.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFMSUBVF
, MASK_VFMSUBVF
, match_opcode
, 0},
3301 {"th.vfnmsub.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFNMSUBVV
, MASK_VFNMSUBVV
, match_opcode
, 0},
3302 {"th.vfnmsub.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFNMSUBVF
, MASK_VFNMSUBVF
, match_opcode
, 0},
3303 {"th.vfmacc.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFMACCVV
, MASK_VFMACCVV
, match_opcode
, 0},
3304 {"th.vfmacc.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFMACCVF
, MASK_VFMACCVF
, match_opcode
, 0},
3305 {"th.vfnmacc.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFNMACCVV
, MASK_VFNMACCVV
, match_opcode
, 0},
3306 {"th.vfnmacc.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFNMACCVF
, MASK_VFNMACCVF
, match_opcode
, 0},
3307 {"th.vfmsac.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFMSACVV
, MASK_VFMSACVV
, match_opcode
, 0},
3308 {"th.vfmsac.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFMSACVF
, MASK_VFMSACVF
, match_opcode
, 0},
3309 {"th.vfnmsac.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFNMSACVV
, MASK_VFNMSACVV
, match_opcode
, 0},
3310 {"th.vfnmsac.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFNMSACVF
, MASK_VFNMSACVF
, match_opcode
, 0},
3311 {"th.vfwmacc.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFWMACCVV
, MASK_VFWMACCVV
, match_opcode
, 0},
3312 {"th.vfwmacc.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFWMACCVF
, MASK_VFWMACCVF
, match_opcode
, 0},
3313 {"th.vfwnmacc.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFWNMACCVV
, MASK_VFWNMACCVV
, match_opcode
, 0},
3314 {"th.vfwnmacc.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFWNMACCVF
, MASK_VFWNMACCVF
, match_opcode
, 0},
3315 {"th.vfwmsac.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFWMSACVV
, MASK_VFWMSACVV
, match_opcode
, 0},
3316 {"th.vfwmsac.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFWMSACVF
, MASK_VFWMSACVF
, match_opcode
, 0},
3317 {"th.vfwnmsac.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VFWNMSACVV
, MASK_VFWNMSACVV
, match_opcode
, 0},
3318 {"th.vfwnmsac.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S,VtVm", MATCH_VFWNMSACVF
, MASK_VFWNMSACVF
, match_opcode
, 0},
3319 {"th.vfsqrt.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFSQRTV
, MASK_TH_VFSQRTV
, match_opcode
, 0},
3320 {"th.vfmin.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFMINVV
, MASK_VFMINVV
, match_opcode
, 0},
3321 {"th.vfmin.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFMINVF
, MASK_VFMINVF
, match_opcode
, 0},
3322 {"th.vfmax.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFMAXVV
, MASK_VFMAXVV
, match_opcode
, 0},
3323 {"th.vfmax.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFMAXVF
, MASK_VFMAXVF
, match_opcode
, 0},
3324 {"th.vfneg.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VuVm", MATCH_VFSGNJNVV
, MASK_VFSGNJNVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
3325 {"th.vfabs.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VuVm", MATCH_VFSGNJXVV
, MASK_VFSGNJXVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
3326 {"th.vfsgnj.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFSGNJVV
, MASK_VFSGNJVV
, match_opcode
, 0},
3327 {"th.vfsgnj.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFSGNJVF
, MASK_VFSGNJVF
, match_opcode
, 0},
3328 {"th.vfsgnjn.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFSGNJNVV
, MASK_VFSGNJNVV
, match_opcode
, 0},
3329 {"th.vfsgnjn.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFSGNJNVF
, MASK_VFSGNJNVF
, match_opcode
, 0},
3330 {"th.vfsgnjx.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFSGNJXVV
, MASK_VFSGNJXVV
, match_opcode
, 0},
3331 {"th.vfsgnjx.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VFSGNJXVF
, MASK_VFSGNJXVF
, match_opcode
, 0},
3332 {"th.vmfeq.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMFEQVV
, MASK_VMFEQVV
, match_opcode
, 0},
3333 {"th.vmfeq.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VMFEQVF
, MASK_VMFEQVF
, match_opcode
, 0},
3334 {"th.vmfne.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMFNEVV
, MASK_VMFNEVV
, match_opcode
, 0},
3335 {"th.vmfne.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VMFNEVF
, MASK_VMFNEVF
, match_opcode
, 0},
3336 {"th.vmflt.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMFLTVV
, MASK_VMFLTVV
, match_opcode
, 0},
3337 {"th.vmflt.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VMFLTVF
, MASK_VMFLTVF
, match_opcode
, 0},
3338 {"th.vmfle.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VMFLEVV
, MASK_VMFLEVV
, match_opcode
, 0},
3339 {"th.vmfle.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VMFLEVF
, MASK_VMFLEVF
, match_opcode
, 0},
3340 {"th.vmfgt.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VMFGTVF
, MASK_VMFGTVF
, match_opcode
, 0},
3341 {"th.vmfge.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_VMFGEVF
, MASK_VMFGEVF
, match_opcode
, 0},
3342 {"th.vmfgt.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMFLTVV
, MASK_VMFLTVV
, match_opcode
, INSN_ALIAS
},
3343 {"th.vmfge.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vs,VtVm", MATCH_VMFLEVV
, MASK_VMFLEVV
, match_opcode
, INSN_ALIAS
},
3344 {"th.vmford.vv", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_TH_VMFORDVV
, MASK_TH_VMFORDVV
, match_opcode
, 0},
3345 {"th.vmford.vf", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,SVm", MATCH_TH_VMFORDVF
, MASK_TH_VMFORDVF
, match_opcode
, 0},
3346 {"th.vfclass.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFCLASSV
, MASK_TH_VFCLASSV
, match_opcode
, 0},
3347 {"th.vfmerge.vfm",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,S,V0", MATCH_VFMERGEVFM
, MASK_VFMERGEVFM
, match_opcode
, 0},
3348 {"th.vfmv.v.f", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S", MATCH_VFMVVF
, MASK_VFMVVF
, match_opcode
, 0 },
3349 {"th.vfcvt.xu.f.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFCVTXUFV
, MASK_TH_VFCVTXUFV
, match_opcode
, 0},
3350 {"th.vfcvt.x.f.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFCVTXFV
, MASK_TH_VFCVTXFV
, match_opcode
, 0},
3351 {"th.vfcvt.f.xu.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFCVTFXUV
, MASK_TH_VFCVTFXUV
, match_opcode
, 0},
3352 {"th.vfcvt.f.x.v", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFCVTFXV
, MASK_TH_VFCVTFXV
, match_opcode
, 0},
3353 {"th.vfwcvt.xu.f.v",0,INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFWCVTXUFV
, MASK_TH_VFWCVTXUFV
, match_opcode
, 0},
3354 {"th.vfwcvt.x.f.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFWCVTXFV
, MASK_TH_VFWCVTXFV
, match_opcode
, 0},
3355 {"th.vfwcvt.f.xu.v",0,INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFWCVTFXUV
, MASK_TH_VFWCVTFXUV
, match_opcode
, 0},
3356 {"th.vfwcvt.f.x.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFWCVTFXV
, MASK_TH_VFWCVTFXV
, match_opcode
, 0},
3357 {"th.vfwcvt.f.f.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFWCVTFFV
, MASK_TH_VFWCVTFFV
, match_opcode
, 0},
3358 {"th.vfncvt.xu.f.v",0,INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFNCVTXUFV
, MASK_TH_VFNCVTXUFV
, match_opcode
, 0},
3359 {"th.vfncvt.x.f.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFNCVTXFV
, MASK_TH_VFNCVTXFV
, match_opcode
, 0},
3360 {"th.vfncvt.f.xu.v",0,INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFNCVTFXUV
, MASK_TH_VFNCVTFXUV
, match_opcode
, 0},
3361 {"th.vfncvt.f.x.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFNCVTFXV
, MASK_TH_VFNCVTFXV
, match_opcode
, 0},
3362 {"th.vfncvt.f.f.v",0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VFNCVTFFV
, MASK_TH_VFNCVTFFV
, match_opcode
, 0},
3363 {"th.vredsum.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDSUMVS
, MASK_VREDSUMVS
, match_opcode
, 0},
3364 {"th.vredmaxu.vs",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDMAXUVS
, MASK_VREDMAXUVS
, match_opcode
, 0},
3365 {"th.vredmax.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDMAXVS
, MASK_VREDMAXVS
, match_opcode
, 0},
3366 {"th.vredminu.vs",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDMINUVS
, MASK_VREDMINUVS
, match_opcode
, 0},
3367 {"th.vredmin.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDMINVS
, MASK_VREDMINVS
, match_opcode
, 0},
3368 {"th.vredand.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDANDVS
, MASK_VREDANDVS
, match_opcode
, 0},
3369 {"th.vredor.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDORVS
, MASK_VREDORVS
, match_opcode
, 0},
3370 {"th.vredxor.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VREDXORVS
, MASK_VREDXORVS
, match_opcode
, 0},
3371 {"th.vwredsumu.vs",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWREDSUMUVS
, MASK_VWREDSUMUVS
, match_opcode
, 0},
3372 {"th.vwredsum.vs",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VWREDSUMVS
, MASK_VWREDSUMVS
, match_opcode
, 0},
3373 {"th.vfredosum.vs",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFREDOSUMVS
, MASK_VFREDOSUMVS
, match_opcode
, 0},
3374 {"th.vfredsum.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFREDUSUMVS
, MASK_VFREDUSUMVS
, match_opcode
, 0},
3375 {"th.vfredmax.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFREDMAXVS
, MASK_VFREDMAXVS
, match_opcode
, 0},
3376 {"th.vfredmin.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFREDMINVS
, MASK_VFREDMINVS
, match_opcode
, 0},
3377 {"th.vfwredosum.vs",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFWREDOSUMVS
, MASK_VFWREDOSUMVS
, match_opcode
, 0},
3378 {"th.vfwredsum.vs", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VFWREDUSUMVS
, MASK_VFWREDUSUMVS
, match_opcode
, 0},
3379 {"th.vmcpy.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vu", MATCH_VMANDMM
, MASK_VMANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
3380 {"th.vmmv.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vu", MATCH_VMANDMM
, MASK_VMANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
3381 {"th.vmclr.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vv", MATCH_VMXORMM
, MASK_VMXORMM
, match_vd_eq_vs1_eq_vs2
, INSN_ALIAS
},
3382 {"th.vmset.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vv", MATCH_VMXNORMM
, MASK_VMXNORMM
, match_vd_eq_vs1_eq_vs2
, INSN_ALIAS
},
3383 {"th.vmnot.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vu", MATCH_VMNANDMM
, MASK_VMNANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
3384 {"th.vmand.mm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMANDMM
, MASK_VMANDMM
, match_opcode
, 0},
3385 {"th.vmnand.mm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMNANDMM
, MASK_VMNANDMM
, match_opcode
, 0},
3386 {"th.vmandnot.mm",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMANDNMM
, MASK_VMANDNMM
, match_opcode
, 0},
3387 {"th.vmxor.mm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMXORMM
, MASK_VMXORMM
, match_opcode
, 0},
3388 {"th.vmor.mm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMORMM
, MASK_VMORMM
, match_opcode
, 0},
3389 {"th.vmnor.mm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMNORMM
, MASK_VMNORMM
, match_opcode
, 0},
3390 {"th.vmornot.mm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMORNMM
, MASK_VMORNMM
, match_opcode
, 0},
3391 {"th.vmxnor.mm", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VMXNORMM
, MASK_VMXNORMM
, match_opcode
, 0},
3392 {"th.vmpopc.m", 0, INSN_CLASS_XTHEADVECTOR
, "d,VtVm", MATCH_TH_VMPOPCM
, MASK_TH_VMPOPCM
, match_opcode
, 0},
3393 {"th.vmfirst.m", 0, INSN_CLASS_XTHEADVECTOR
, "d,VtVm", MATCH_TH_VMFIRSTM
, MASK_TH_VMFIRSTM
, match_opcode
, 0},
3394 {"th.vmsbf.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VMSBFM
, MASK_TH_VMSBFM
, match_opcode
, 0},
3395 {"th.vmsif.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VMSIFM
, MASK_TH_VMSIFM
, match_opcode
, 0},
3396 {"th.vmsof.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VMSOFM
, MASK_TH_VMSOFM
, match_opcode
, 0},
3397 {"th.viota.m", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,VtVm", MATCH_TH_VIOTAM
, MASK_TH_VIOTAM
, match_opcode
, 0},
3398 {"th.vid.v", 0, INSN_CLASS_XTHEADVECTOR
, "VdVm", MATCH_TH_VIDV
, MASK_TH_VIDV
, match_opcode
, 0},
3399 {"th.vmv.x.s", 0, INSN_CLASS_XTHEADVECTOR
, "d,Vt", MATCH_TH_VMVXS
, MASK_TH_VMVXS
, match_opcode
, INSN_ALIAS
},
3400 {"th.vext.x.v", 0, INSN_CLASS_XTHEADVECTOR
, "d,Vt,s", MATCH_TH_VEXTXV
, MASK_TH_VEXTXV
, match_opcode
, 0},
3401 {"th.vmv.s.x", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,s", MATCH_TH_VMVSX
, MASK_TH_VMVSX
, match_opcode
, 0},
3402 {"th.vfmv.f.s", 0, INSN_CLASS_XTHEADVECTOR
, "D,Vt", MATCH_TH_VFMVFS
, MASK_TH_VFMVFS
, match_opcode
, 0},
3403 {"th.vfmv.s.f", 0, INSN_CLASS_XTHEADVECTOR
, "Vd,S", MATCH_TH_VFMVSF
, MASK_TH_VFMVSF
, match_opcode
, 0},
3404 {"th.vslideup.vx",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSLIDEUPVX
, MASK_VSLIDEUPVX
, match_opcode
, 0},
3405 {"th.vslideup.vi",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VSLIDEUPVI
, MASK_VSLIDEUPVI
, match_opcode
, 0},
3406 {"th.vslidedown.vx",0,INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSLIDEDOWNVX
, MASK_VSLIDEDOWNVX
, match_opcode
, 0},
3407 {"th.vslidedown.vi",0,INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VSLIDEDOWNVI
, MASK_VSLIDEDOWNVI
, match_opcode
, 0},
3408 {"th.vslide1up.vx",0 ,INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSLIDE1UPVX
, MASK_VSLIDE1UPVX
, match_opcode
, 0},
3409 {"th.vslide1down.vx",0,INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VSLIDE1DOWNVX
, MASK_VSLIDE1DOWNVX
, match_opcode
, 0},
3410 {"th.vrgather.vv",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VsVm", MATCH_VRGATHERVV
, MASK_VRGATHERVV
, match_opcode
, 0},
3411 {"th.vrgather.vx",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,sVm", MATCH_VRGATHERVX
, MASK_VRGATHERVX
, match_opcode
, 0},
3412 {"th.vrgather.vi",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,VjVm", MATCH_VRGATHERVI
, MASK_VRGATHERVI
, match_opcode
, 0},
3413 {"th.vcompress.vm",0, INSN_CLASS_XTHEADVECTOR
, "Vd,Vt,Vs", MATCH_VCOMPRESSVM
, MASK_VCOMPRESSVM
, match_opcode
, 0},
3415 /* Vendor-specific (Ventana Microsystems) XVentanaCondOps instructions */
3416 {"vt.maskc", 64, INSN_CLASS_XVENTANACONDOPS
, "d,s,t", MATCH_VT_MASKC
, MASK_VT_MASKC
, match_opcode
, 0 },
3417 {"vt.maskcn", 64, INSN_CLASS_XVENTANACONDOPS
, "d,s,t", MATCH_VT_MASKCN
, MASK_VT_MASKCN
, match_opcode
, 0 },
3419 /* Vendor-specific (SiFive) vector coprocessor interface instructions. */
3420 {"sf.vc.x", 0, INSN_CLASS_XSFVCP
, "XsO2,Xst,Xsd,s", MATCH_SF_VC_X
, MASK_SF_VC_X
, match_opcode
, 0 },
3421 {"sf.vc.v.x", 0, INSN_CLASS_XSFVCP
, "XsO2,Xst,Vd,s", MATCH_SF_VC_V_X
, MASK_SF_VC_V_X
, match_opcode
, 0 },
3422 {"sf.vc.i", 0, INSN_CLASS_XSFVCP
, "XsO2,Xst,Xsd,Vi", MATCH_SF_VC_I
, MASK_SF_VC_I
, match_opcode
, 0 },
3423 {"sf.vc.v.i", 0, INSN_CLASS_XSFVCP
, "XsO2,Xst,Vd,Vi", MATCH_SF_VC_V_I
, MASK_SF_VC_V_I
, match_opcode
, 0 },
3424 {"sf.vc.vv", 0, INSN_CLASS_XSFVCP
, "XsO2,Xsd,Vt,Vs", MATCH_SF_VC_VV
, MASK_SF_VC_VV
, match_opcode
, 0 },
3425 {"sf.vc.v.vv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vs", MATCH_SF_VC_V_VV
, MASK_SF_VC_V_VV
, match_opcode
, 0 },
3426 {"sf.vc.xv", 0, INSN_CLASS_XSFVCP
, "XsO2,Xsd,Vt,s", MATCH_SF_VC_XV
, MASK_SF_VC_XV
, match_opcode
, 0 },
3427 {"sf.vc.v.xv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,s", MATCH_SF_VC_V_XV
, MASK_SF_VC_V_XV
, match_opcode
, 0 },
3428 {"sf.vc.iv", 0, INSN_CLASS_XSFVCP
, "XsO2,Xsd,Vt,Vi", MATCH_SF_VC_IV
, MASK_SF_VC_IV
, match_opcode
, 0 },
3429 {"sf.vc.v.iv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vi", MATCH_SF_VC_V_IV
, MASK_SF_VC_V_IV
, match_opcode
, 0 },
3430 {"sf.vc.fv", 0, INSN_CLASS_XSFVCP
, "XsO1,Xsd,Vt,S", MATCH_SF_VC_FV
, MASK_SF_VC_FV
, match_opcode
, 0 },
3431 {"sf.vc.v.fv", 0, INSN_CLASS_XSFVCP
, "XsO1,Vd,Vt,S", MATCH_SF_VC_V_FV
, MASK_SF_VC_V_FV
, match_opcode
, 0 },
3432 {"sf.vc.vvv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vs", MATCH_SF_VC_VVV
, MASK_SF_VC_VVV
, match_opcode
, 0 },
3433 {"sf.vc.v.vvv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vs", MATCH_SF_VC_V_VVV
, MASK_SF_VC_V_VVV
, match_opcode
, 0 },
3434 {"sf.vc.xvv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,s", MATCH_SF_VC_XVV
, MASK_SF_VC_XVV
, match_opcode
, 0 },
3435 {"sf.vc.v.xvv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,s", MATCH_SF_VC_V_XVV
, MASK_SF_VC_V_XVV
, match_opcode
, 0 },
3436 {"sf.vc.ivv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vi", MATCH_SF_VC_IVV
, MASK_SF_VC_IVV
, match_opcode
, 0 },
3437 {"sf.vc.v.ivv", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vi", MATCH_SF_VC_V_IVV
, MASK_SF_VC_V_IVV
, match_opcode
, 0 },
3438 {"sf.vc.fvv", 0, INSN_CLASS_XSFVCP
, "XsO1,Vd,Vt,S", MATCH_SF_VC_FVV
, MASK_SF_VC_FVV
, match_opcode
, 0 },
3439 {"sf.vc.v.fvv", 0, INSN_CLASS_XSFVCP
, "XsO1,Vd,Vt,S", MATCH_SF_VC_V_FVV
, MASK_SF_VC_V_FVV
, match_opcode
, 0 },
3440 {"sf.vc.vvw", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vs", MATCH_SF_VC_VVW
, MASK_SF_VC_VVW
, match_opcode
, 0 },
3441 {"sf.vc.v.vvw", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vs", MATCH_SF_VC_V_VVW
, MASK_SF_VC_V_VVW
, match_opcode
, 0 },
3442 {"sf.vc.xvw", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,s", MATCH_SF_VC_XVW
, MASK_SF_VC_XVW
, match_opcode
, 0 },
3443 {"sf.vc.v.xvw", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,s", MATCH_SF_VC_V_XVW
, MASK_SF_VC_V_XVW
, match_opcode
, 0 },
3444 {"sf.vc.ivw", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vi", MATCH_SF_VC_IVW
, MASK_SF_VC_IVW
, match_opcode
, 0 },
3445 {"sf.vc.v.ivw", 0, INSN_CLASS_XSFVCP
, "XsO2,Vd,Vt,Vi", MATCH_SF_VC_V_IVW
, MASK_SF_VC_V_IVW
, match_opcode
, 0 },
3446 {"sf.vc.fvw", 0, INSN_CLASS_XSFVCP
, "XsO1,Vd,Vt,S", MATCH_SF_VC_FVW
, MASK_SF_VC_FVW
, match_opcode
, 0 },
3447 {"sf.vc.v.fvw", 0, INSN_CLASS_XSFVCP
, "XsO1,Vd,Vt,S", MATCH_SF_VC_V_FVW
, MASK_SF_VC_V_FVW
, match_opcode
, 0 },
3449 /* Vendor-specific (SiFive) cease instruction. */
3450 {"sf.cease", 0, INSN_CLASS_XSFCEASE
, "", MATCH_SF_CEASE
, MASK_SF_CEASE
, match_opcode
, 0 },
3452 /* SiFive custom int8 matrix-multiply instructions. */
3453 {"sf.vqmaccu.4x8x4", 0, INSN_CLASS_XSFVQMACCQOQ
, "Vd,Vs,Vt", MATCH_SFVQMACCU4X8X4
, MASK_SFVQMACCU4X8X4
, match_opcode
, 0},
3454 {"sf.vqmacc.4x8x4", 0, INSN_CLASS_XSFVQMACCQOQ
, "Vd,Vs,Vt", MATCH_SFVQMACC4X8X4
, MASK_SFVQMACC4X8X4
, match_opcode
, 0},
3455 {"sf.vqmaccus.4x8x4", 0, INSN_CLASS_XSFVQMACCQOQ
, "Vd,Vs,Vt", MATCH_SFVQMACCUS4X8X4
, MASK_SFVQMACCUS4X8X4
, match_opcode
, 0},
3456 {"sf.vqmaccsu.4x8x4", 0, INSN_CLASS_XSFVQMACCQOQ
, "Vd,Vs,Vt", MATCH_SFVQMACCSU4X8X4
, MASK_SFVQMACCSU4X8X4
, match_opcode
, 0},
3457 {"sf.vqmaccu.2x8x2", 0, INSN_CLASS_XSFVQMACCDOD
, "Vd,Vs,Vt", MATCH_SFVQMACCU2X8X2
, MASK_SFVQMACCU2X8X2
, match_opcode
, 0},
3458 {"sf.vqmacc.2x8x2", 0, INSN_CLASS_XSFVQMACCDOD
, "Vd,Vs,Vt", MATCH_SFVQMACC2X8X2
, MASK_SFVQMACC2X8X2
, match_opcode
, 0},
3459 {"sf.vqmaccus.2x8x2", 0, INSN_CLASS_XSFVQMACCDOD
, "Vd,Vs,Vt", MATCH_SFVQMACCUS2X8X2
, MASK_SFVQMACCUS2X8X2
, match_opcode
, 0},
3460 {"sf.vqmaccsu.2x8x2", 0, INSN_CLASS_XSFVQMACCDOD
, "Vd,Vs,Vt", MATCH_SFVQMACCSU2X8X2
, MASK_SFVQMACCSU2X8X2
, match_opcode
, 0},
3462 /* SiFive FP32-to-int8 ranged clip instructions (Xsfvfnrclipxfqf). */
3463 {"sf.vfnrclip.xu.f.qf", 0, INSN_CLASS_XSFVFNRCLIPXFQF
, "Vd,Vt,S", MATCH_SFVFNRCLIPXUFQF
, MASK_SFVFNRCLIPXUFQF
, match_opcode
, 0},
3464 {"sf.vfnrclip.x.f.qf", 0, INSN_CLASS_XSFVFNRCLIPXFQF
, "Vd,Vt,S", MATCH_SFVFNRCLIPXFQF
, MASK_SFVFNRCLIPXFQF
, match_opcode
, 0},
3466 /* Terminate the list. */
3467 {0, 0, INSN_CLASS_NONE
, 0, 0, 0, 0, 0}
3470 /* Instruction format for .insn directive. */
3471 const struct riscv_opcode riscv_insn_types
[] =
3473 /* name, xlen, isa, operands, match, mask, match_func, pinfo. */
3474 {"r", 0, INSN_CLASS_I
, "O4,F3,F7,d,s,t", 0, 0, NULL
, 0 },
3475 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,s,t", 0, 0, NULL
, 0 },
3476 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,d,S,t", 0, 0, NULL
, 0 },
3477 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,S,t", 0, 0, NULL
, 0 },
3478 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,d,s,T", 0, 0, NULL
, 0 },
3479 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,s,T", 0, 0, NULL
, 0 },
3480 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,d,S,T", 0, 0, NULL
, 0 },
3481 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,S,T", 0, 0, NULL
, 0 },
3482 {"r", 0, INSN_CLASS_I
, "O4,F3,F2,d,s,t,r", 0, 0, NULL
, 0 },
3483 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,r", 0, 0, NULL
, 0 },
3484 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,r", 0, 0, NULL
, 0 },
3485 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,r", 0, 0, NULL
, 0 },
3486 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,r", 0, 0, NULL
, 0 },
3487 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,r", 0, 0, NULL
, 0 },
3488 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,r", 0, 0, NULL
, 0 },
3489 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,r", 0, 0, NULL
, 0 },
3490 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,t,R", 0, 0, NULL
, 0 },
3491 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,R", 0, 0, NULL
, 0 },
3492 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,R", 0, 0, NULL
, 0 },
3493 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,R", 0, 0, NULL
, 0 },
3494 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,R", 0, 0, NULL
, 0 },
3495 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,R", 0, 0, NULL
, 0 },
3496 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,R", 0, 0, NULL
, 0 },
3497 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,R", 0, 0, NULL
, 0 },
3499 {"r4", 0, INSN_CLASS_I
, "O4,F3,F2,d,s,t,r", 0, 0, NULL
, 0 },
3500 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,r", 0, 0, NULL
, 0 },
3501 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,r", 0, 0, NULL
, 0 },
3502 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,r", 0, 0, NULL
, 0 },
3503 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,r", 0, 0, NULL
, 0 },
3504 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,r", 0, 0, NULL
, 0 },
3505 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,r", 0, 0, NULL
, 0 },
3506 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,r", 0, 0, NULL
, 0 },
3507 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,t,R", 0, 0, NULL
, 0 },
3508 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,R", 0, 0, NULL
, 0 },
3509 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,R", 0, 0, NULL
, 0 },
3510 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,R", 0, 0, NULL
, 0 },
3511 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,R", 0, 0, NULL
, 0 },
3512 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,R", 0, 0, NULL
, 0 },
3513 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,R", 0, 0, NULL
, 0 },
3514 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,R", 0, 0, NULL
, 0 },
3516 {"i", 0, INSN_CLASS_I
, "O4,F3,d,s,j", 0, 0, NULL
, 0 },
3517 {"i", 0, INSN_CLASS_F
, "O4,F3,D,s,j", 0, 0, NULL
, 0 },
3518 {"i", 0, INSN_CLASS_F
, "O4,F3,d,S,j", 0, 0, NULL
, 0 },
3519 {"i", 0, INSN_CLASS_F
, "O4,F3,D,S,j", 0, 0, NULL
, 0 },
3520 {"i", 0, INSN_CLASS_I
, "O4,F3,d,o(s)", 0, 0, NULL
, 0 },
3521 {"i", 0, INSN_CLASS_F
, "O4,F3,D,o(s)", 0, 0, NULL
, 0 },
3523 {"s", 0, INSN_CLASS_I
, "O4,F3,t,q(s)", 0, 0, NULL
, 0 },
3524 {"s", 0, INSN_CLASS_F
, "O4,F3,T,q(s)", 0, 0, NULL
, 0 },
3526 {"sb", 0, INSN_CLASS_I
, "O4,F3,s,t,p", 0, 0, NULL
, 0 },
3527 {"sb", 0, INSN_CLASS_F
, "O4,F3,S,t,p", 0, 0, NULL
, 0 },
3528 {"sb", 0, INSN_CLASS_F
, "O4,F3,s,T,p", 0, 0, NULL
, 0 },
3529 {"sb", 0, INSN_CLASS_F
, "O4,F3,S,T,p", 0, 0, NULL
, 0 },
3530 {"b", 0, INSN_CLASS_I
, "O4,F3,s,t,p", 0, 0, NULL
, 0 },
3531 {"b", 0, INSN_CLASS_F
, "O4,F3,S,t,p", 0, 0, NULL
, 0 },
3532 {"b", 0, INSN_CLASS_F
, "O4,F3,s,T,p", 0, 0, NULL
, 0 },
3533 {"b", 0, INSN_CLASS_F
, "O4,F3,S,T,p", 0, 0, NULL
, 0 },
3535 {"u", 0, INSN_CLASS_I
, "O4,d,u", 0, 0, NULL
, 0 },
3536 {"u", 0, INSN_CLASS_F
, "O4,D,u", 0, 0, NULL
, 0 },
3538 {"uj", 0, INSN_CLASS_I
, "O4,d,a", 0, 0, NULL
, 0 },
3539 {"uj", 0, INSN_CLASS_F
, "O4,D,a", 0, 0, NULL
, 0 },
3540 {"j", 0, INSN_CLASS_I
, "O4,d,a", 0, 0, NULL
, 0 },
3541 {"j", 0, INSN_CLASS_F
, "O4,D,a", 0, 0, NULL
, 0 },
3543 {"cr", 0, INSN_CLASS_C
, "O2,CF4,d,CV", 0, 0, NULL
, 0 },
3544 {"cr", 0, INSN_CLASS_F_AND_C
, "O2,CF4,D,CV", 0, 0, NULL
, 0 },
3545 {"cr", 0, INSN_CLASS_F_AND_C
, "O2,CF4,d,CT", 0, 0, NULL
, 0 },
3546 {"cr", 0, INSN_CLASS_F_AND_C
, "O2,CF4,D,CT", 0, 0, NULL
, 0 },
3548 {"ci", 0, INSN_CLASS_C
, "O2,CF3,d,Co", 0, 0, NULL
, 0 },
3549 {"ci", 0, INSN_CLASS_F_AND_C
, "O2,CF3,D,Co", 0, 0, NULL
, 0 },
3551 {"ciw", 0, INSN_CLASS_C
, "O2,CF3,Ct,C8", 0, 0, NULL
, 0 },
3552 {"ciw", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C8", 0, 0, NULL
, 0 },
3554 {"css", 0, INSN_CLASS_C
, "O2,CF3,CV,C6", 0, 0, NULL
, 0 },
3555 {"css", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CT,C6", 0, 0, NULL
, 0 },
3557 {"cl", 0, INSN_CLASS_C
, "O2,CF3,Ct,C5(Cs)", 0, 0, NULL
, 0 },
3558 {"cl", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(Cs)", 0, 0, NULL
, 0 },
3559 {"cl", 0, INSN_CLASS_F_AND_C
, "O2,CF3,Ct,C5(CS)", 0, 0, NULL
, 0 },
3560 {"cl", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(CS)", 0, 0, NULL
, 0 },
3562 {"cs", 0, INSN_CLASS_C
, "O2,CF3,Ct,C5(Cs)", 0, 0, NULL
, 0 },
3563 {"cs", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(Cs)", 0, 0, NULL
, 0 },
3564 {"cs", 0, INSN_CLASS_F_AND_C
, "O2,CF3,Ct,C5(CS)", 0, 0, NULL
, 0 },
3565 {"cs", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(CS)", 0, 0, NULL
, 0 },
3567 {"ca", 0, INSN_CLASS_C
, "O2,CF6,CF2,Cs,Ct", 0, 0, NULL
, 0 },
3568 {"ca", 0, INSN_CLASS_F_AND_C
, "O2,CF6,CF2,CS,Ct", 0, 0, NULL
, 0 },
3569 {"ca", 0, INSN_CLASS_F_AND_C
, "O2,CF6,CF2,Cs,CD", 0, 0, NULL
, 0 },
3570 {"ca", 0, INSN_CLASS_F_AND_C
, "O2,CF6,CF2,CS,CD", 0, 0, NULL
, 0 },
3572 {"cb", 0, INSN_CLASS_C
, "O2,CF3,Cs,Cp", 0, 0, NULL
, 0 },
3573 {"cb", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CS,Cp", 0, 0, NULL
, 0 },
3575 {"cj", 0, INSN_CLASS_C
, "O2,CF3,Ca", 0, 0, NULL
, 0 },
3577 /* Terminate the list. */
3578 {0, 0, INSN_CLASS_NONE
, 0, 0, 0, 0, 0}