2 Copyright (C) 2011-2023 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 * const riscv_gpr_names_numeric
[NGPR
] =
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 * const riscv_gpr_names_abi
[NGPR
] =
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 * const riscv_fpr_names_numeric
[NFPR
] =
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 * const riscv_fpr_names_abi
[NFPR
] =
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 * const riscv_vecr_names_numeric
[NVECR
] =
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 * const riscv_vecm_names_numeric
[NVECM
] =
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 /* The order of overloaded instructions matters. Label arguments and
114 register arguments look the same. Instructions that can have either
115 for arguments must apear in the correct order in this table for the
116 assembler to pick the right one. In other words, entries with
117 immediate operands must apear after the same instruction with
120 Because of the lookup algorithm used, entries with the same opcode
121 name must be contiguous. */
123 #define MASK_RS1 (OP_MASK_RS1 << OP_SH_RS1)
124 #define MASK_RS2 (OP_MASK_RS2 << OP_SH_RS2)
125 #define MASK_RD (OP_MASK_RD << OP_SH_RD)
126 #define MASK_CRS2 (OP_MASK_CRS2 << OP_SH_CRS2)
127 #define MASK_IMM ENCODE_ITYPE_IMM (-1U)
128 #define MASK_RVC_IMM ENCODE_CITYPE_IMM (-1U)
129 #define MASK_UIMM ENCODE_UTYPE_IMM (-1U)
130 #define MASK_RM (OP_MASK_RM << OP_SH_RM)
131 #define MASK_PRED (OP_MASK_PRED << OP_SH_PRED)
132 #define MASK_SUCC (OP_MASK_SUCC << OP_SH_SUCC)
133 #define MASK_AQ (OP_MASK_AQ << OP_SH_AQ)
134 #define MASK_RL (OP_MASK_RL << OP_SH_RL)
135 #define MASK_AQRL (MASK_AQ | MASK_RL)
136 #define MASK_SHAMT (OP_MASK_SHAMT << OP_SH_SHAMT)
137 #define MATCH_SHAMT_REV8_32 (0b11000 << OP_SH_SHAMT)
138 #define MATCH_SHAMT_REV8_64 (0b111000 << OP_SH_SHAMT)
139 #define MATCH_SHAMT_BREV8 (0b00111 << OP_SH_SHAMT)
140 #define MATCH_SHAMT_ZIP_32 (0b1111 << OP_SH_SHAMT)
141 #define MATCH_SHAMT_ORC_B (0b00111 << OP_SH_SHAMT)
142 #define MASK_VD (OP_MASK_VD << OP_SH_VD)
143 #define MASK_VS1 (OP_MASK_VS1 << OP_SH_VS1)
144 #define MASK_VS2 (OP_MASK_VS2 << OP_SH_VS2)
145 #define MASK_VMASK (OP_MASK_VMASK << OP_SH_VMASK)
148 match_opcode (const struct riscv_opcode
*op
, insn_t insn
)
150 return ((insn
^ op
->match
) & op
->mask
) == 0;
154 match_never (const struct riscv_opcode
*op ATTRIBUTE_UNUSED
,
155 insn_t insn ATTRIBUTE_UNUSED
)
161 match_rs1_eq_rs2 (const struct riscv_opcode
*op
, insn_t insn
)
163 int rs1
= (insn
& MASK_RS1
) >> OP_SH_RS1
;
164 int rs2
= (insn
& MASK_RS2
) >> OP_SH_RS2
;
165 return match_opcode (op
, insn
) && rs1
== rs2
;
169 match_rd_nonzero (const struct riscv_opcode
*op
, insn_t insn
)
171 return match_opcode (op
, insn
) && ((insn
& MASK_RD
) != 0);
175 match_c_add (const struct riscv_opcode
*op
, insn_t insn
)
177 return match_rd_nonzero (op
, insn
) && ((insn
& MASK_CRS2
) != 0);
180 /* We don't allow mv zero,X to become a c.mv hint, so we need a separate
181 matching function for this. */
184 match_c_add_with_hint (const struct riscv_opcode
*op
, insn_t insn
)
186 return match_opcode (op
, insn
) && ((insn
& MASK_CRS2
) != 0);
190 match_c_nop (const struct riscv_opcode
*op
, insn_t insn
)
192 return (match_opcode (op
, insn
)
193 && (((insn
& MASK_RD
) >> OP_SH_RD
) == 0));
197 match_c_addi16sp (const struct riscv_opcode
*op
, insn_t insn
)
199 return (match_opcode (op
, insn
)
200 && (((insn
& MASK_RD
) >> OP_SH_RD
) == 2));
204 match_c_lui (const struct riscv_opcode
*op
, insn_t insn
)
206 return (match_rd_nonzero (op
, insn
)
207 && (((insn
& MASK_RD
) >> OP_SH_RD
) != 2)
208 && EXTRACT_CITYPE_LUI_IMM (insn
) != 0);
211 /* We don't allow lui zero,X to become a c.lui hint, so we need a separate
212 matching function for this. */
215 match_c_lui_with_hint (const struct riscv_opcode
*op
, insn_t insn
)
217 return (match_opcode (op
, insn
)
218 && (((insn
& MASK_RD
) >> OP_SH_RD
) != 2)
219 && EXTRACT_CITYPE_LUI_IMM (insn
) != 0);
223 match_c_addi4spn (const struct riscv_opcode
*op
, insn_t insn
)
225 return match_opcode (op
, insn
) && EXTRACT_CIWTYPE_ADDI4SPN_IMM (insn
) != 0;
228 /* This requires a non-zero shift. A zero rd is a hint, so is allowed. */
231 match_c_slli (const struct riscv_opcode
*op
, insn_t insn
)
233 return match_opcode (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) != 0;
236 /* This requires a non-zero rd, and a non-zero shift. */
239 match_slli_as_c_slli (const struct riscv_opcode
*op
, insn_t insn
)
241 return match_rd_nonzero (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) != 0;
244 /* This requires a zero shift. A zero rd is a hint, so is allowed. */
247 match_c_slli64 (const struct riscv_opcode
*op
, insn_t insn
)
249 return match_opcode (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) == 0;
252 /* This is used for both srli and srai. This requires a non-zero shift.
253 A zero rd is not possible. */
256 match_srxi_as_c_srxi (const struct riscv_opcode
*op
, insn_t insn
)
258 return match_opcode (op
, insn
) && EXTRACT_CITYPE_IMM (insn
) != 0;
262 match_vs1_eq_vs2 (const struct riscv_opcode
*op
,
265 int vs1
= (insn
& MASK_VS1
) >> OP_SH_VS1
;
266 int vs2
= (insn
& MASK_VS2
) >> OP_SH_VS2
;
268 return match_opcode (op
, insn
) && vs1
== vs2
;
272 match_vd_eq_vs1_eq_vs2 (const struct riscv_opcode
*op
,
275 int vd
= (insn
& MASK_VD
) >> OP_SH_VD
;
276 int vs1
= (insn
& MASK_VS1
) >> OP_SH_VS1
;
277 int vs2
= (insn
& MASK_VS2
) >> OP_SH_VS2
;
279 return match_opcode (op
, insn
) && vd
== vs1
&& vs1
== vs2
;
283 match_th_load_inc(const struct riscv_opcode
*op
,
286 /* Load-increment has the following restriction:
287 * The values of rd and rs1 must not be the same. */
288 int rd
= (insn
& MASK_RD
) >> OP_SH_RD
;
289 int rs1
= (insn
& MASK_RS1
) >> OP_SH_RS1
;
291 return rd
!= rs1
&& match_opcode (op
, insn
);
295 match_th_load_pair(const struct riscv_opcode
*op
,
298 /* Load pair instructions use the following encoding:
299 * - rd1 = RD (insn[11:7])
300 * - rd2 = RS2 (insn[24:20])
301 * - rs = RS1 ([19:15])
302 * This function matches if the following restriction is met:
303 * The values of rd1, rd2, and rs1 must not be the same. */
304 int rd1
= (insn
& MASK_RD
) >> OP_SH_RD
;
305 int rd2
= (insn
& MASK_RS2
) >> OP_SH_RS2
;
306 int rs
= (insn
& MASK_RS1
) >> OP_SH_RS1
;
308 return rd1
!= rd2
&& rd1
!= rs
&& rd2
!= rs
&& match_opcode (op
, insn
);
311 const struct riscv_opcode riscv_opcodes
[] =
313 /* name, xlen, isa, operands, match, mask, match_func, pinfo. */
315 /* Standard hints. */
316 {"prefetch.i", 0, INSN_CLASS_ZICBOP
, "f(s)", MATCH_PREFETCH_I
, MASK_PREFETCH_I
, match_opcode
, 0 },
317 {"prefetch.r", 0, INSN_CLASS_ZICBOP
, "f(s)", MATCH_PREFETCH_R
, MASK_PREFETCH_R
, match_opcode
, 0 },
318 {"prefetch.w", 0, INSN_CLASS_ZICBOP
, "f(s)", MATCH_PREFETCH_W
, MASK_PREFETCH_W
, match_opcode
, 0 },
319 {"pause", 0, INSN_CLASS_ZIHINTPAUSE
, "", MATCH_PAUSE
, MASK_PAUSE
, match_opcode
, 0 },
321 /* Basic RVI instructions and aliases. */
322 {"unimp", 0, INSN_CLASS_C
, "", 0, 0xffffU
, match_opcode
, INSN_ALIAS
},
323 {"unimp", 0, INSN_CLASS_I
, "", MATCH_CSRRW
|(CSR_CYCLE
<< OP_SH_CSR
), 0xffffffffU
, match_opcode
, 0 }, /* csrw cycle, x0 */
324 {"ebreak", 0, INSN_CLASS_C
, "", MATCH_C_EBREAK
, MASK_C_EBREAK
, match_opcode
, INSN_ALIAS
},
325 {"ebreak", 0, INSN_CLASS_I
, "", MATCH_EBREAK
, MASK_EBREAK
, match_opcode
, 0 },
326 {"sbreak", 0, INSN_CLASS_C
, "", MATCH_C_EBREAK
, MASK_C_EBREAK
, match_opcode
, INSN_ALIAS
},
327 {"sbreak", 0, INSN_CLASS_I
, "", MATCH_EBREAK
, MASK_EBREAK
, match_opcode
, INSN_ALIAS
},
328 {"ret", 0, INSN_CLASS_C
, "", MATCH_C_JR
|(X_RA
<< OP_SH_RD
), MASK_C_JR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
329 {"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
},
330 {"jr", 0, INSN_CLASS_C
, "d", MATCH_C_JR
, MASK_C_JR
, match_rd_nonzero
, INSN_ALIAS
|INSN_BRANCH
},
331 {"jr", 0, INSN_CLASS_I
, "s", MATCH_JALR
, MASK_JALR
|MASK_RD
|MASK_IMM
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
332 {"jr", 0, INSN_CLASS_I
, "o(s)", MATCH_JALR
, MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
333 {"jr", 0, INSN_CLASS_I
, "s,j", MATCH_JALR
, MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
334 {"jalr", 0, INSN_CLASS_C
, "d", MATCH_C_JALR
, MASK_C_JALR
, match_rd_nonzero
, INSN_ALIAS
|INSN_JSR
},
335 {"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
},
336 {"jalr", 0, INSN_CLASS_I
, "o(s)", MATCH_JALR
|(X_RA
<< OP_SH_RD
), MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
337 {"jalr", 0, INSN_CLASS_I
, "s,j", MATCH_JALR
|(X_RA
<< OP_SH_RD
), MASK_JALR
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
338 {"jalr", 0, INSN_CLASS_I
, "d,s", MATCH_JALR
, MASK_JALR
|MASK_IMM
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
339 {"jalr", 0, INSN_CLASS_I
, "d,o(s)", MATCH_JALR
, MASK_JALR
, match_opcode
, INSN_JSR
},
340 {"jalr", 0, INSN_CLASS_I
, "d,s,j", MATCH_JALR
, MASK_JALR
, match_opcode
, INSN_JSR
},
341 {"j", 0, INSN_CLASS_C
, "Ca", MATCH_C_J
, MASK_C_J
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
342 {"j", 0, INSN_CLASS_I
, "a", MATCH_JAL
, MASK_JAL
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_BRANCH
},
343 {"jal", 32, INSN_CLASS_C
, "Ca", MATCH_C_JAL
, MASK_C_JAL
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
344 {"jal", 0, INSN_CLASS_I
, "a", MATCH_JAL
|(X_RA
<< OP_SH_RD
), MASK_JAL
|MASK_RD
, match_opcode
, INSN_ALIAS
|INSN_JSR
},
345 {"jal", 0, INSN_CLASS_I
, "d,a", MATCH_JAL
, MASK_JAL
, match_opcode
, INSN_JSR
},
346 {"call", 0, INSN_CLASS_I
, "d,c", (X_T1
<< OP_SH_RS1
), (int) M_CALL
, match_never
, INSN_MACRO
},
347 {"call", 0, INSN_CLASS_I
, "c", (X_RA
<< OP_SH_RS1
)|(X_RA
<< OP_SH_RD
), (int) M_CALL
, match_never
, INSN_MACRO
},
348 {"tail", 0, INSN_CLASS_I
, "c", (X_T1
<< OP_SH_RS1
), (int) M_CALL
, match_never
, INSN_MACRO
},
349 {"jump", 0, INSN_CLASS_I
, "c,s", 0, (int) M_CALL
, match_never
, INSN_MACRO
},
350 {"nop", 0, INSN_CLASS_C
, "", MATCH_C_ADDI
, 0xffff, match_opcode
, INSN_ALIAS
},
351 {"nop", 0, INSN_CLASS_I
, "", MATCH_ADDI
, MASK_ADDI
|MASK_RD
|MASK_RS1
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
352 {"lui", 0, INSN_CLASS_C
, "d,Cu", MATCH_C_LUI
, MASK_C_LUI
, match_c_lui
, INSN_ALIAS
},
353 {"lui", 0, INSN_CLASS_I
, "d,u", MATCH_LUI
, MASK_LUI
, match_opcode
, 0 },
354 {"li", 0, INSN_CLASS_C
, "d,Cv", MATCH_C_LUI
, MASK_C_LUI
, match_c_lui
, INSN_ALIAS
},
355 {"li", 0, INSN_CLASS_C
, "d,Co", MATCH_C_LI
, MASK_C_LI
, match_rd_nonzero
, INSN_ALIAS
},
356 {"li", 0, INSN_CLASS_I
, "d,j", MATCH_ADDI
, MASK_ADDI
|MASK_RS1
, match_opcode
, INSN_ALIAS
}, /* addi */
357 {"li", 0, INSN_CLASS_I
, "d,I", 0, (int) M_LI
, match_never
, INSN_MACRO
},
358 {"mv", 0, INSN_CLASS_C
, "d,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
359 {"mv", 0, INSN_CLASS_I
, "d,s", MATCH_ADDI
, MASK_ADDI
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
360 {"move", 0, INSN_CLASS_C
, "d,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
361 {"move", 0, INSN_CLASS_I
, "d,s", MATCH_ADDI
, MASK_ADDI
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
362 {"zext.b", 0, INSN_CLASS_I
, "d,s", MATCH_ANDI
|ENCODE_ITYPE_IMM (255), MASK_ANDI
| MASK_IMM
, match_opcode
, INSN_ALIAS
},
363 {"and", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_AND
, MASK_C_AND
, match_opcode
, INSN_ALIAS
},
364 {"and", 0, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_AND
, MASK_C_AND
, match_opcode
, INSN_ALIAS
},
365 {"and", 0, INSN_CLASS_C
, "Cs,Cw,Co", MATCH_C_ANDI
, MASK_C_ANDI
, match_opcode
, INSN_ALIAS
},
366 {"and", 0, INSN_CLASS_I
, "d,s,t", MATCH_AND
, MASK_AND
, match_opcode
, 0 },
367 {"and", 0, INSN_CLASS_I
, "d,s,j", MATCH_ANDI
, MASK_ANDI
, match_opcode
, INSN_ALIAS
},
368 {"andi", 0, INSN_CLASS_C
, "Cs,Cw,Co", MATCH_C_ANDI
, MASK_C_ANDI
, match_opcode
, INSN_ALIAS
},
369 {"andi", 0, INSN_CLASS_I
, "d,s,j", MATCH_ANDI
, MASK_ANDI
, match_opcode
, 0 },
370 {"beqz", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BEQZ
, MASK_C_BEQZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
371 {"beqz", 0, INSN_CLASS_I
, "s,p", MATCH_BEQ
, MASK_BEQ
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
372 {"beq", 0, INSN_CLASS_C
, "Cs,Cz,Cp", MATCH_C_BEQZ
, MASK_C_BEQZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
373 {"beq", 0, INSN_CLASS_I
, "s,t,p", MATCH_BEQ
, MASK_BEQ
, match_opcode
, INSN_CONDBRANCH
},
374 {"blez", 0, INSN_CLASS_I
, "t,p", MATCH_BGE
, MASK_BGE
|MASK_RS1
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
375 {"bgez", 0, INSN_CLASS_I
, "s,p", MATCH_BGE
, MASK_BGE
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
376 {"bge", 0, INSN_CLASS_I
, "s,t,p", MATCH_BGE
, MASK_BGE
, match_opcode
, INSN_CONDBRANCH
},
377 {"bgeu", 0, INSN_CLASS_I
, "s,t,p", MATCH_BGEU
, MASK_BGEU
, match_opcode
, INSN_CONDBRANCH
},
378 {"ble", 0, INSN_CLASS_I
, "t,s,p", MATCH_BGE
, MASK_BGE
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
379 {"bleu", 0, INSN_CLASS_I
, "t,s,p", MATCH_BGEU
, MASK_BGEU
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
380 {"bltz", 0, INSN_CLASS_I
, "s,p", MATCH_BLT
, MASK_BLT
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
381 {"bgtz", 0, INSN_CLASS_I
, "t,p", MATCH_BLT
, MASK_BLT
|MASK_RS1
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
382 {"blt", 0, INSN_CLASS_I
, "s,t,p", MATCH_BLT
, MASK_BLT
, match_opcode
, INSN_CONDBRANCH
},
383 {"bltu", 0, INSN_CLASS_I
, "s,t,p", MATCH_BLTU
, MASK_BLTU
, match_opcode
, INSN_CONDBRANCH
},
384 {"bgt", 0, INSN_CLASS_I
, "t,s,p", MATCH_BLT
, MASK_BLT
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
385 {"bgtu", 0, INSN_CLASS_I
, "t,s,p", MATCH_BLTU
, MASK_BLTU
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
386 {"bnez", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BNEZ
, MASK_C_BNEZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
387 {"bnez", 0, INSN_CLASS_I
, "s,p", MATCH_BNE
, MASK_BNE
|MASK_RS2
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
388 {"bne", 0, INSN_CLASS_C
, "Cs,Cz,Cp", MATCH_C_BNEZ
, MASK_C_BNEZ
, match_opcode
, INSN_ALIAS
|INSN_CONDBRANCH
},
389 {"bne", 0, INSN_CLASS_I
, "s,t,p", MATCH_BNE
, MASK_BNE
, match_opcode
, INSN_CONDBRANCH
},
390 {"add", 0, INSN_CLASS_C
, "d,CU,CV", MATCH_C_ADD
, MASK_C_ADD
, match_c_add
, INSN_ALIAS
},
391 {"add", 0, INSN_CLASS_C
, "d,CV,CU", MATCH_C_ADD
, MASK_C_ADD
, match_c_add
, INSN_ALIAS
},
392 {"add", 0, INSN_CLASS_C
, "d,CU,Co", MATCH_C_ADDI
, MASK_C_ADDI
, match_rd_nonzero
, INSN_ALIAS
},
393 {"add", 0, INSN_CLASS_C
, "Ct,Cc,CK", MATCH_C_ADDI4SPN
, MASK_C_ADDI4SPN
, match_c_addi4spn
, INSN_ALIAS
},
394 {"add", 0, INSN_CLASS_C
, "Cc,Cc,CL", MATCH_C_ADDI16SP
, MASK_C_ADDI16SP
, match_c_addi16sp
, INSN_ALIAS
},
395 {"add", 0, INSN_CLASS_C
, "d,Cz,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
396 {"add", 0, INSN_CLASS_I
, "d,s,t", MATCH_ADD
, MASK_ADD
, match_opcode
, 0 },
397 {"add", 0, INSN_CLASS_I
, "d,s,t,1", MATCH_ADD
, MASK_ADD
, match_opcode
, 0 },
398 {"add", 0, INSN_CLASS_I
, "d,s,j", MATCH_ADDI
, MASK_ADDI
, match_opcode
, INSN_ALIAS
},
399 {"addi", 0, INSN_CLASS_C
, "Ct,Cc,CK", MATCH_C_ADDI4SPN
, MASK_C_ADDI4SPN
, match_c_addi4spn
, INSN_ALIAS
},
400 {"addi", 0, INSN_CLASS_C
, "d,CU,Cj", MATCH_C_ADDI
, MASK_C_ADDI
, match_rd_nonzero
, INSN_ALIAS
},
401 {"addi", 0, INSN_CLASS_C
, "d,CU,z", MATCH_C_NOP
, MASK_C_ADDI
|MASK_RVC_IMM
, match_c_nop
, INSN_ALIAS
},
402 {"addi", 0, INSN_CLASS_C
, "Cc,Cc,CL", MATCH_C_ADDI16SP
, MASK_C_ADDI16SP
, match_c_addi16sp
, INSN_ALIAS
},
403 {"addi", 0, INSN_CLASS_C
, "d,Cz,Co", MATCH_C_LI
, MASK_C_LI
, match_rd_nonzero
, INSN_ALIAS
},
404 {"addi", 0, INSN_CLASS_C
, "d,CV,z", MATCH_C_MV
, MASK_C_MV
, match_c_add
, INSN_ALIAS
},
405 {"addi", 0, INSN_CLASS_I
, "d,s,j", MATCH_ADDI
, MASK_ADDI
, match_opcode
, 0 },
406 {"la", 0, INSN_CLASS_I
, "d,B", 0, (int) M_LA
, match_never
, INSN_MACRO
},
407 {"lla", 0, INSN_CLASS_I
, "d,B", 0, (int) M_LLA
, match_never
, INSN_MACRO
},
408 {"la.tls.gd", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LA_TLS_GD
, match_never
, INSN_MACRO
},
409 {"la.tls.ie", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LA_TLS_IE
, match_never
, INSN_MACRO
},
410 {"neg", 0, INSN_CLASS_I
, "d,t", MATCH_SUB
, MASK_SUB
|MASK_RS1
, match_opcode
, INSN_ALIAS
}, /* sub 0 */
411 {"sll", 0, INSN_CLASS_C
, "d,CU,C>", MATCH_C_SLLI
, MASK_C_SLLI
, match_slli_as_c_slli
, INSN_ALIAS
},
412 {"sll", 0, INSN_CLASS_I
, "d,s,t", MATCH_SLL
, MASK_SLL
, match_opcode
, 0 },
413 {"sll", 0, INSN_CLASS_I
, "d,s,>", MATCH_SLLI
, MASK_SLLI
, match_opcode
, INSN_ALIAS
},
414 {"slli", 0, INSN_CLASS_C
, "d,CU,C>", MATCH_C_SLLI
, MASK_C_SLLI
, match_slli_as_c_slli
, INSN_ALIAS
},
415 {"slli", 0, INSN_CLASS_I
, "d,s,>", MATCH_SLLI
, MASK_SLLI
, match_opcode
, 0 },
416 {"srl", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRLI
, MASK_C_SRLI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
417 {"srl", 0, INSN_CLASS_I
, "d,s,t", MATCH_SRL
, MASK_SRL
, match_opcode
, 0 },
418 {"srl", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRLI
, MASK_SRLI
, match_opcode
, INSN_ALIAS
},
419 {"srli", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRLI
, MASK_C_SRLI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
420 {"srli", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRLI
, MASK_SRLI
, match_opcode
, 0 },
421 {"sra", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRAI
, MASK_C_SRAI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
422 {"sra", 0, INSN_CLASS_I
, "d,s,t", MATCH_SRA
, MASK_SRA
, match_opcode
, 0 },
423 {"sra", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRAI
, MASK_SRAI
, match_opcode
, INSN_ALIAS
},
424 {"srai", 0, INSN_CLASS_C
, "Cs,Cw,C>", MATCH_C_SRAI
, MASK_C_SRAI
, match_srxi_as_c_srxi
, INSN_ALIAS
},
425 {"srai", 0, INSN_CLASS_I
, "d,s,>", MATCH_SRAI
, MASK_SRAI
, match_opcode
, 0 },
426 {"sub", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_SUB
, MASK_C_SUB
, match_opcode
, INSN_ALIAS
},
427 {"sub", 0, INSN_CLASS_I
, "d,s,t", MATCH_SUB
, MASK_SUB
, match_opcode
, 0 },
428 {"lb", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LB
, MASK_LB
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
429 {"lb", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LB
, match_never
, INSN_MACRO
},
430 {"lbu", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LBU
, MASK_LBU
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
431 {"lbu", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LBU
, match_never
, INSN_MACRO
},
432 {"lh", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LH
, MASK_LH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
433 {"lh", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LH
, match_never
, INSN_MACRO
},
434 {"lhu", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LHU
, MASK_LHU
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
435 {"lhu", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LHU
, match_never
, INSN_MACRO
},
436 {"lw", 0, INSN_CLASS_C
, "d,Cm(Cc)", MATCH_C_LWSP
, MASK_C_LWSP
, match_rd_nonzero
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
437 {"lw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_LW
, MASK_C_LW
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
438 {"lw", 0, INSN_CLASS_I
, "d,o(s)", MATCH_LW
, MASK_LW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
439 {"lw", 0, INSN_CLASS_I
, "d,A", 0, (int) M_LW
, match_never
, INSN_MACRO
},
440 {"not", 0, INSN_CLASS_I
, "d,s", MATCH_XORI
|MASK_IMM
, MASK_XORI
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
441 {"or", 0, INSN_CLASS_I
, "d,s,j", MATCH_ORI
, MASK_ORI
, match_opcode
, INSN_ALIAS
},
442 {"or", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_OR
, MASK_C_OR
, match_opcode
, INSN_ALIAS
},
443 {"or", 0, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_OR
, MASK_C_OR
, match_opcode
, INSN_ALIAS
},
444 {"or", 0, INSN_CLASS_I
, "d,s,t", MATCH_OR
, MASK_OR
, match_opcode
, 0 },
445 {"ori", 0, INSN_CLASS_I
, "d,s,j", MATCH_ORI
, MASK_ORI
, match_opcode
, 0 },
446 {"auipc", 0, INSN_CLASS_I
, "d,u", MATCH_AUIPC
, MASK_AUIPC
, match_opcode
, 0 },
447 {"seqz", 0, INSN_CLASS_I
, "d,s", MATCH_SLTIU
|ENCODE_ITYPE_IMM (1), MASK_SLTIU
| MASK_IMM
, match_opcode
, INSN_ALIAS
},
448 {"snez", 0, INSN_CLASS_I
, "d,t", MATCH_SLTU
, MASK_SLTU
|MASK_RS1
, match_opcode
, INSN_ALIAS
},
449 {"sltz", 0, INSN_CLASS_I
, "d,s", MATCH_SLT
, MASK_SLT
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
450 {"sgtz", 0, INSN_CLASS_I
, "d,t", MATCH_SLT
, MASK_SLT
|MASK_RS1
, match_opcode
, INSN_ALIAS
},
451 {"slti", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTI
, MASK_SLTI
, match_opcode
, 0 },
452 {"slt", 0, INSN_CLASS_I
, "d,s,t", MATCH_SLT
, MASK_SLT
, match_opcode
, 0 },
453 {"slt", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTI
, MASK_SLTI
, match_opcode
, INSN_ALIAS
},
454 {"sltiu", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTIU
, MASK_SLTIU
, match_opcode
, 0 },
455 {"sltu", 0, INSN_CLASS_I
, "d,s,t", MATCH_SLTU
, MASK_SLTU
, match_opcode
, 0 },
456 {"sltu", 0, INSN_CLASS_I
, "d,s,j", MATCH_SLTIU
, MASK_SLTIU
, match_opcode
, INSN_ALIAS
},
457 {"sgt", 0, INSN_CLASS_I
, "d,t,s", MATCH_SLT
, MASK_SLT
, match_opcode
, INSN_ALIAS
},
458 {"sgtu", 0, INSN_CLASS_I
, "d,t,s", MATCH_SLTU
, MASK_SLTU
, match_opcode
, INSN_ALIAS
},
459 {"sb", 0, INSN_CLASS_I
, "t,q(s)", MATCH_SB
, MASK_SB
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
460 {"sb", 0, INSN_CLASS_I
, "t,A,s", 0, (int) M_SB
, match_never
, INSN_MACRO
},
461 {"sh", 0, INSN_CLASS_I
, "t,q(s)", MATCH_SH
, MASK_SH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
462 {"sh", 0, INSN_CLASS_I
, "t,A,s", 0, (int) M_SH
, match_never
, INSN_MACRO
},
463 {"sw", 0, INSN_CLASS_C
, "CV,CM(Cc)", MATCH_C_SWSP
, MASK_C_SWSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
464 {"sw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_SW
, MASK_C_SW
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_4_BYTE
},
465 {"sw", 0, INSN_CLASS_I
, "t,q(s)", MATCH_SW
, MASK_SW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
466 {"sw", 0, INSN_CLASS_I
, "t,A,s", 0, (int) M_SW
, match_never
, INSN_MACRO
},
467 {"fence", 0, INSN_CLASS_I
, "", MATCH_FENCE
|MASK_PRED
|MASK_SUCC
, MASK_FENCE
|MASK_RD
|MASK_RS1
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
468 {"fence", 0, INSN_CLASS_I
, "P,Q", MATCH_FENCE
, MASK_FENCE
|MASK_RD
|MASK_RS1
|(MASK_IMM
& ~MASK_PRED
& ~MASK_SUCC
), match_opcode
, 0 },
469 {"fence.i", 0, INSN_CLASS_ZIFENCEI
, "", MATCH_FENCE_I
, MASK_FENCE
|MASK_RD
|MASK_RS1
|MASK_IMM
, match_opcode
, 0 },
470 {"fence.tso", 0, INSN_CLASS_I
, "", MATCH_FENCE_TSO
, MASK_FENCE_TSO
|MASK_RD
|MASK_RS1
, match_opcode
, 0 },
471 {"rdcycle", 0, INSN_CLASS_I
, "d", MATCH_RDCYCLE
, MASK_RDCYCLE
, match_opcode
, INSN_ALIAS
},
472 {"rdinstret", 0, INSN_CLASS_I
, "d", MATCH_RDINSTRET
, MASK_RDINSTRET
, match_opcode
, INSN_ALIAS
},
473 {"rdtime", 0, INSN_CLASS_I
, "d", MATCH_RDTIME
, MASK_RDTIME
, match_opcode
, INSN_ALIAS
},
474 {"rdcycleh", 32, INSN_CLASS_I
, "d", MATCH_RDCYCLEH
, MASK_RDCYCLEH
, match_opcode
, INSN_ALIAS
},
475 {"rdinstreth", 32, INSN_CLASS_I
, "d", MATCH_RDINSTRETH
, MASK_RDINSTRETH
, match_opcode
, INSN_ALIAS
},
476 {"rdtimeh", 32, INSN_CLASS_I
, "d", MATCH_RDTIMEH
, MASK_RDTIMEH
, match_opcode
, INSN_ALIAS
},
477 {"ecall", 0, INSN_CLASS_I
, "", MATCH_SCALL
, MASK_SCALL
, match_opcode
, 0 },
478 {"scall", 0, INSN_CLASS_I
, "", MATCH_SCALL
, MASK_SCALL
, match_opcode
, 0 },
479 {"xor", 0, INSN_CLASS_I
, "d,s,j", MATCH_XORI
, MASK_XORI
, match_opcode
, INSN_ALIAS
},
480 {"xor", 0, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_XOR
, MASK_C_XOR
, match_opcode
, INSN_ALIAS
},
481 {"xor", 0, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_XOR
, MASK_C_XOR
, match_opcode
, INSN_ALIAS
},
482 {"xor", 0, INSN_CLASS_I
, "d,s,t", MATCH_XOR
, MASK_XOR
, match_opcode
, 0 },
483 {"xori", 0, INSN_CLASS_I
, "d,s,j", MATCH_XORI
, MASK_XORI
, match_opcode
, 0 },
484 {"lwu", 64, INSN_CLASS_I
, "d,o(s)", MATCH_LWU
, MASK_LWU
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
485 {"lwu", 64, INSN_CLASS_I
, "d,A", 0, (int) M_LWU
, match_never
, INSN_MACRO
},
486 {"ld", 64, INSN_CLASS_C
, "d,Cn(Cc)", MATCH_C_LDSP
, MASK_C_LDSP
, match_rd_nonzero
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
487 {"ld", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_LD
, MASK_C_LD
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
488 {"ld", 64, INSN_CLASS_I
, "d,o(s)", MATCH_LD
, MASK_LD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
489 {"ld", 64, INSN_CLASS_I
, "d,A", 0, (int) M_LD
, match_never
, INSN_MACRO
},
490 {"sd", 64, INSN_CLASS_C
, "CV,CN(Cc)", MATCH_C_SDSP
, MASK_C_SDSP
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
491 {"sd", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_SD
, MASK_C_SD
, match_opcode
, INSN_ALIAS
|INSN_DREF
|INSN_8_BYTE
},
492 {"sd", 64, INSN_CLASS_I
, "t,q(s)", MATCH_SD
, MASK_SD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
493 {"sd", 64, INSN_CLASS_I
, "t,A,s", 0, (int) M_SD
, match_never
, INSN_MACRO
},
494 {"sext.w", 64, INSN_CLASS_C
, "d,CU", MATCH_C_ADDIW
, MASK_C_ADDIW
|MASK_RVC_IMM
, match_rd_nonzero
, INSN_ALIAS
},
495 {"sext.w", 64, INSN_CLASS_I
, "d,s", MATCH_ADDIW
, MASK_ADDIW
|MASK_IMM
, match_opcode
, INSN_ALIAS
},
496 {"addw", 64, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_ADDW
, MASK_C_ADDW
, match_opcode
, INSN_ALIAS
},
497 {"addw", 64, INSN_CLASS_C
, "Cs,Ct,Cw", MATCH_C_ADDW
, MASK_C_ADDW
, match_opcode
, INSN_ALIAS
},
498 {"addw", 64, INSN_CLASS_C
, "d,CU,Co", MATCH_C_ADDIW
, MASK_C_ADDIW
, match_rd_nonzero
, INSN_ALIAS
},
499 {"addw", 64, INSN_CLASS_I
, "d,s,t", MATCH_ADDW
, MASK_ADDW
, match_opcode
, 0 },
500 {"addw", 64, INSN_CLASS_I
, "d,s,j", MATCH_ADDIW
, MASK_ADDIW
, match_opcode
, INSN_ALIAS
},
501 {"addiw", 64, INSN_CLASS_C
, "d,CU,Co", MATCH_C_ADDIW
, MASK_C_ADDIW
, match_rd_nonzero
, INSN_ALIAS
},
502 {"addiw", 64, INSN_CLASS_I
, "d,s,j", MATCH_ADDIW
, MASK_ADDIW
, match_opcode
, 0 },
503 {"negw", 64, INSN_CLASS_I
, "d,t", MATCH_SUBW
, MASK_SUBW
|MASK_RS1
, match_opcode
, INSN_ALIAS
}, /* sub 0 */
504 {"sllw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SLLW
, MASK_SLLW
, match_opcode
, 0 },
505 {"sllw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SLLIW
, MASK_SLLIW
, match_opcode
, INSN_ALIAS
},
506 {"slliw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SLLIW
, MASK_SLLIW
, match_opcode
, 0 },
507 {"srlw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SRLW
, MASK_SRLW
, match_opcode
, 0 },
508 {"srlw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRLIW
, MASK_SRLIW
, match_opcode
, INSN_ALIAS
},
509 {"srliw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRLIW
, MASK_SRLIW
, match_opcode
, 0 },
510 {"sraw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SRAW
, MASK_SRAW
, match_opcode
, 0 },
511 {"sraw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRAIW
, MASK_SRAIW
, match_opcode
, INSN_ALIAS
},
512 {"sraiw", 64, INSN_CLASS_I
, "d,s,<", MATCH_SRAIW
, MASK_SRAIW
, match_opcode
, 0 },
513 {"subw", 64, INSN_CLASS_C
, "Cs,Cw,Ct", MATCH_C_SUBW
, MASK_C_SUBW
, match_opcode
, INSN_ALIAS
},
514 {"subw", 64, INSN_CLASS_I
, "d,s,t", MATCH_SUBW
, MASK_SUBW
, match_opcode
, 0 },
516 /* Atomic memory operation instruction subset. */
517 {"lr.w", 0, INSN_CLASS_A
, "d,0(s)", MATCH_LR_W
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
518 {"sc.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_W
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
519 {"amoadd.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_W
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
520 {"amoswap.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_W
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
521 {"amoand.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_W
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
522 {"amoor.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_W
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
523 {"amoxor.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_W
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
524 {"amomax.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_W
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
525 {"amomaxu.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_W
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
526 {"amomin.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_W
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
527 {"amominu.w", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_W
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
528 {"lr.w.aq", 0, INSN_CLASS_A
, "d,0(s)", MATCH_LR_W
|MASK_AQ
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
529 {"sc.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_W
|MASK_AQ
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
530 {"amoadd.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_W
|MASK_AQ
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
531 {"amoswap.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_W
|MASK_AQ
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
532 {"amoand.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_W
|MASK_AQ
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
533 {"amoor.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_W
|MASK_AQ
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
534 {"amoxor.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_W
|MASK_AQ
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
535 {"amomax.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_W
|MASK_AQ
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
536 {"amomaxu.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_W
|MASK_AQ
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
537 {"amomin.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_W
|MASK_AQ
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
538 {"amominu.w.aq", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_W
|MASK_AQ
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
539 {"lr.w.rl", 0, INSN_CLASS_A
, "d,0(s)", MATCH_LR_W
|MASK_RL
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
540 {"sc.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_W
|MASK_RL
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
541 {"amoadd.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_W
|MASK_RL
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
542 {"amoswap.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_W
|MASK_RL
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
543 {"amoand.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_W
|MASK_RL
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
544 {"amoor.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_W
|MASK_RL
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
545 {"amoxor.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_W
|MASK_RL
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
546 {"amomax.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_W
|MASK_RL
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
547 {"amomaxu.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_W
|MASK_RL
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
548 {"amomin.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_W
|MASK_RL
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
549 {"amominu.w.rl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_W
|MASK_RL
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
550 {"lr.w.aqrl", 0, INSN_CLASS_A
, "d,0(s)", MATCH_LR_W
|MASK_AQRL
, MASK_LR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
551 {"sc.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_W
|MASK_AQRL
, MASK_SC_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
552 {"amoadd.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_W
|MASK_AQRL
, MASK_AMOADD_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
553 {"amoswap.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_W
|MASK_AQRL
, MASK_AMOSWAP_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
554 {"amoand.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_W
|MASK_AQRL
, MASK_AMOAND_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
555 {"amoor.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_W
|MASK_AQRL
, MASK_AMOOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
556 {"amoxor.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_W
|MASK_AQRL
, MASK_AMOXOR_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
557 {"amomax.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_W
|MASK_AQRL
, MASK_AMOMAX_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
558 {"amomaxu.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_W
|MASK_AQRL
, MASK_AMOMAXU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
559 {"amomin.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_W
|MASK_AQRL
, MASK_AMOMIN_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
560 {"amominu.w.aqrl", 0, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_W
|MASK_AQRL
, MASK_AMOMINU_W
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
561 {"lr.d", 64, INSN_CLASS_A
, "d,0(s)", MATCH_LR_D
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
562 {"sc.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_D
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
563 {"amoadd.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_D
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
564 {"amoswap.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_D
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
565 {"amoand.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_D
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
566 {"amoor.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_D
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
567 {"amoxor.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_D
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
568 {"amomax.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_D
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
569 {"amomaxu.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_D
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
570 {"amomin.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_D
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
571 {"amominu.d", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_D
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
572 {"lr.d.aq", 64, INSN_CLASS_A
, "d,0(s)", MATCH_LR_D
|MASK_AQ
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
573 {"sc.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_D
|MASK_AQ
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
574 {"amoadd.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_D
|MASK_AQ
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
575 {"amoswap.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_D
|MASK_AQ
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
576 {"amoand.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_D
|MASK_AQ
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
577 {"amoor.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_D
|MASK_AQ
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
578 {"amoxor.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_D
|MASK_AQ
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
579 {"amomax.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_D
|MASK_AQ
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
580 {"amomaxu.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_D
|MASK_AQ
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
581 {"amomin.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_D
|MASK_AQ
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
582 {"amominu.d.aq", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_D
|MASK_AQ
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
583 {"lr.d.rl", 64, INSN_CLASS_A
, "d,0(s)", MATCH_LR_D
|MASK_RL
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
584 {"sc.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_D
|MASK_RL
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
585 {"amoadd.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_D
|MASK_RL
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
586 {"amoswap.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_D
|MASK_RL
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
587 {"amoand.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_D
|MASK_RL
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
588 {"amoor.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_D
|MASK_RL
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
589 {"amoxor.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_D
|MASK_RL
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
590 {"amomax.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_D
|MASK_RL
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
591 {"amomaxu.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_D
|MASK_RL
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
592 {"amomin.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_D
|MASK_RL
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
593 {"amominu.d.rl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_D
|MASK_RL
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
594 {"lr.d.aqrl", 64, INSN_CLASS_A
, "d,0(s)", MATCH_LR_D
|MASK_AQRL
, MASK_LR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
595 {"sc.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_SC_D
|MASK_AQRL
, MASK_SC_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
596 {"amoadd.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOADD_D
|MASK_AQRL
, MASK_AMOADD_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
597 {"amoswap.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOSWAP_D
|MASK_AQRL
, MASK_AMOSWAP_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
598 {"amoand.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOAND_D
|MASK_AQRL
, MASK_AMOAND_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
599 {"amoor.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOOR_D
|MASK_AQRL
, MASK_AMOOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
600 {"amoxor.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOXOR_D
|MASK_AQRL
, MASK_AMOXOR_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
601 {"amomax.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAX_D
|MASK_AQRL
, MASK_AMOMAX_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
602 {"amomaxu.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMAXU_D
|MASK_AQRL
, MASK_AMOMAXU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
603 {"amomin.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMIN_D
|MASK_AQRL
, MASK_AMOMIN_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
604 {"amominu.d.aqrl", 64, INSN_CLASS_A
, "d,t,0(s)", MATCH_AMOMINU_D
|MASK_AQRL
, MASK_AMOMINU_D
|MASK_AQRL
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
606 /* Multiply/Divide instruction subset. */
607 {"mul", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MUL
, MASK_MUL
, match_opcode
, 0 },
608 {"mulh", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULH
, MASK_MULH
, match_opcode
, 0 },
609 {"mulhu", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULHU
, MASK_MULHU
, match_opcode
, 0 },
610 {"mulhsu", 0, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULHSU
, MASK_MULHSU
, match_opcode
, 0 },
611 {"div", 0, INSN_CLASS_M
, "d,s,t", MATCH_DIV
, MASK_DIV
, match_opcode
, 0 },
612 {"divu", 0, INSN_CLASS_M
, "d,s,t", MATCH_DIVU
, MASK_DIVU
, match_opcode
, 0 },
613 {"rem", 0, INSN_CLASS_M
, "d,s,t", MATCH_REM
, MASK_REM
, match_opcode
, 0 },
614 {"remu", 0, INSN_CLASS_M
, "d,s,t", MATCH_REMU
, MASK_REMU
, match_opcode
, 0 },
615 {"mulw", 64, INSN_CLASS_ZMMUL
, "d,s,t", MATCH_MULW
, MASK_MULW
, match_opcode
, 0 },
616 {"divw", 64, INSN_CLASS_M
, "d,s,t", MATCH_DIVW
, MASK_DIVW
, match_opcode
, 0 },
617 {"divuw", 64, INSN_CLASS_M
, "d,s,t", MATCH_DIVUW
, MASK_DIVUW
, match_opcode
, 0 },
618 {"remw", 64, INSN_CLASS_M
, "d,s,t", MATCH_REMW
, MASK_REMW
, match_opcode
, 0 },
619 {"remuw", 64, INSN_CLASS_M
, "d,s,t", MATCH_REMUW
, MASK_REMUW
, match_opcode
, 0 },
621 /* Half-precision floating-point instruction subset. */
622 {"flh", 0, INSN_CLASS_ZFHMIN
, "D,o(s)", MATCH_FLH
, MASK_FLH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
623 {"flh", 0, INSN_CLASS_ZFHMIN
, "D,A,s", 0, (int) M_FLH
, match_never
, INSN_MACRO
},
624 {"fsh", 0, INSN_CLASS_ZFHMIN
, "T,q(s)", MATCH_FSH
, MASK_FSH
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
625 {"fsh", 0, INSN_CLASS_ZFHMIN
, "T,A,s", 0, (int) M_FSH
, match_never
, INSN_MACRO
},
626 {"fmv.x.h", 0, INSN_CLASS_ZFHMIN
, "d,S", MATCH_FMV_X_H
, MASK_FMV_X_H
, match_opcode
, 0 },
627 {"fmv.h.x", 0, INSN_CLASS_ZFHMIN
, "D,s", MATCH_FMV_H_X
, MASK_FMV_H_X
, match_opcode
, 0 },
628 {"fmv.h", 0, INSN_CLASS_ZFH_INX
, "D,U", MATCH_FSGNJ_H
, MASK_FSGNJ_H
, match_rs1_eq_rs2
, INSN_ALIAS
},
629 {"fneg.h", 0, INSN_CLASS_ZFH_INX
, "D,U", MATCH_FSGNJN_H
, MASK_FSGNJN_H
, match_rs1_eq_rs2
, INSN_ALIAS
},
630 {"fabs.h", 0, INSN_CLASS_ZFH_INX
, "D,U", MATCH_FSGNJX_H
, MASK_FSGNJX_H
, match_rs1_eq_rs2
, INSN_ALIAS
},
631 {"fsgnj.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSGNJ_H
, MASK_FSGNJ_H
, match_opcode
, 0 },
632 {"fsgnjn.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSGNJN_H
, MASK_FSGNJN_H
, match_opcode
, 0 },
633 {"fsgnjx.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSGNJX_H
, MASK_FSGNJX_H
, match_opcode
, 0 },
634 {"fadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FADD_H
|MASK_RM
, MASK_FADD_H
|MASK_RM
, match_opcode
, 0 },
635 {"fadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FADD_H
, MASK_FADD_H
, match_opcode
, 0 },
636 {"fsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FSUB_H
|MASK_RM
, MASK_FSUB_H
|MASK_RM
, match_opcode
, 0 },
637 {"fsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FSUB_H
, MASK_FSUB_H
, match_opcode
, 0 },
638 {"fmul.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FMUL_H
|MASK_RM
, MASK_FMUL_H
|MASK_RM
, match_opcode
, 0 },
639 {"fmul.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FMUL_H
, MASK_FMUL_H
, match_opcode
, 0 },
640 {"fdiv.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FDIV_H
|MASK_RM
, MASK_FDIV_H
|MASK_RM
, match_opcode
, 0 },
641 {"fdiv.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,m", MATCH_FDIV_H
, MASK_FDIV_H
, match_opcode
, 0 },
642 {"fsqrt.h", 0, INSN_CLASS_ZFH_INX
, "D,S", MATCH_FSQRT_H
|MASK_RM
, MASK_FSQRT_H
|MASK_RM
, match_opcode
, 0 },
643 {"fsqrt.h", 0, INSN_CLASS_ZFH_INX
, "D,S,m", MATCH_FSQRT_H
, MASK_FSQRT_H
, match_opcode
, 0 },
644 {"fmin.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FMIN_H
, MASK_FMIN_H
, match_opcode
, 0 },
645 {"fmax.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T", MATCH_FMAX_H
, MASK_FMAX_H
, match_opcode
, 0 },
646 {"fmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FMADD_H
|MASK_RM
, MASK_FMADD_H
|MASK_RM
, match_opcode
, 0 },
647 {"fmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FMADD_H
, MASK_FMADD_H
, match_opcode
, 0 },
648 {"fnmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FNMADD_H
|MASK_RM
, MASK_FNMADD_H
|MASK_RM
, match_opcode
, 0 },
649 {"fnmadd.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FNMADD_H
, MASK_FNMADD_H
, match_opcode
, 0 },
650 {"fmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FMSUB_H
|MASK_RM
, MASK_FMSUB_H
|MASK_RM
, match_opcode
, 0 },
651 {"fmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FMSUB_H
, MASK_FMSUB_H
, match_opcode
, 0 },
652 {"fnmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R", MATCH_FNMSUB_H
|MASK_RM
, MASK_FNMSUB_H
|MASK_RM
, match_opcode
, 0 },
653 {"fnmsub.h", 0, INSN_CLASS_ZFH_INX
, "D,S,T,R,m", MATCH_FNMSUB_H
, MASK_FNMSUB_H
, match_opcode
, 0 },
654 {"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 },
655 {"fcvt.w.h", 0, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_W_H
, MASK_FCVT_W_H
, match_opcode
, 0 },
656 {"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 },
657 {"fcvt.wu.h", 0, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_WU_H
, MASK_FCVT_WU_H
, match_opcode
, 0 },
658 {"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 },
659 {"fcvt.h.w", 0, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_W
, MASK_FCVT_H_W
, match_opcode
, 0 },
660 {"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 },
661 {"fcvt.h.wu", 0, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_WU
, MASK_FCVT_H_WU
, match_opcode
, 0 },
662 {"fcvt.s.h", 0, INSN_CLASS_ZFHMIN_INX
, "D,S", MATCH_FCVT_S_H
, MASK_FCVT_S_H
|MASK_RM
, match_opcode
, 0 },
663 {"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 },
664 {"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 },
665 {"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 },
666 {"fcvt.h.s", 0, INSN_CLASS_ZFHMIN_INX
, "D,S,m", MATCH_FCVT_H_S
, MASK_FCVT_H_S
, match_opcode
, 0 },
667 {"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 },
668 {"fcvt.h.d", 0, INSN_CLASS_ZFHMIN_AND_D_INX
, "D,S,m", MATCH_FCVT_H_D
, MASK_FCVT_H_D
, match_opcode
, 0 },
669 {"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 },
670 {"fcvt.h.q", 0, INSN_CLASS_ZFHMIN_AND_Q_INX
, "D,S,m", MATCH_FCVT_H_Q
, MASK_FCVT_H_Q
, match_opcode
, 0 },
671 {"fclass.h", 0, INSN_CLASS_ZFH_INX
, "d,S", MATCH_FCLASS_H
, MASK_FCLASS_H
, match_opcode
, 0 },
672 {"feq.h", 0, INSN_CLASS_ZFH_INX
, "d,S,T", MATCH_FEQ_H
, MASK_FEQ_H
, match_opcode
, 0 },
673 {"flt.h", 0, INSN_CLASS_ZFH_INX
, "d,S,T", MATCH_FLT_H
, MASK_FLT_H
, match_opcode
, 0 },
674 {"fle.h", 0, INSN_CLASS_ZFH_INX
, "d,S,T", MATCH_FLE_H
, MASK_FLE_H
, match_opcode
, 0 },
675 {"fgt.h", 0, INSN_CLASS_ZFH_INX
, "d,T,S", MATCH_FLT_H
, MASK_FLT_H
, match_opcode
, 0 },
676 {"fge.h", 0, INSN_CLASS_ZFH_INX
, "d,T,S", MATCH_FLE_H
, MASK_FLE_H
, match_opcode
, 0 },
677 {"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 },
678 {"fcvt.l.h", 64, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_L_H
, MASK_FCVT_L_H
, match_opcode
, 0 },
679 {"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 },
680 {"fcvt.lu.h", 64, INSN_CLASS_ZFH_INX
, "d,S,m", MATCH_FCVT_LU_H
, MASK_FCVT_LU_H
, match_opcode
, 0 },
681 {"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 },
682 {"fcvt.h.l", 64, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_L
, MASK_FCVT_H_L
, match_opcode
, 0 },
683 {"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 },
684 {"fcvt.h.lu", 64, INSN_CLASS_ZFH_INX
, "D,s,m", MATCH_FCVT_H_LU
, MASK_FCVT_H_LU
, match_opcode
, 0 },
686 /* Single-precision floating-point instruction subset. */
687 {"frcsr", 0, INSN_CLASS_F_INX
, "d", MATCH_FRCSR
, MASK_FRCSR
, match_opcode
, INSN_ALIAS
},
688 {"frsr", 0, INSN_CLASS_F_INX
, "d", MATCH_FRCSR
, MASK_FRCSR
, match_opcode
, INSN_ALIAS
},
689 {"fscsr", 0, INSN_CLASS_F_INX
, "s", MATCH_FSCSR
, MASK_FSCSR
|MASK_RD
, match_opcode
, INSN_ALIAS
},
690 {"fscsr", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSCSR
, MASK_FSCSR
, match_opcode
, INSN_ALIAS
},
691 {"fssr", 0, INSN_CLASS_F_INX
, "s", MATCH_FSCSR
, MASK_FSCSR
|MASK_RD
, match_opcode
, INSN_ALIAS
},
692 {"fssr", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSCSR
, MASK_FSCSR
, match_opcode
, INSN_ALIAS
},
693 {"frrm", 0, INSN_CLASS_F_INX
, "d", MATCH_FRRM
, MASK_FRRM
, match_opcode
, INSN_ALIAS
},
694 {"fsrm", 0, INSN_CLASS_F_INX
, "s", MATCH_FSRM
, MASK_FSRM
|MASK_RD
, match_opcode
, INSN_ALIAS
},
695 {"fsrm", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSRM
, MASK_FSRM
, match_opcode
, INSN_ALIAS
},
696 {"fsrmi", 0, INSN_CLASS_F_INX
, "d,Z", MATCH_FSRMI
, MASK_FSRMI
, match_opcode
, INSN_ALIAS
},
697 {"fsrmi", 0, INSN_CLASS_F_INX
, "Z", MATCH_FSRMI
, MASK_FSRMI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
698 {"frflags", 0, INSN_CLASS_F_INX
, "d", MATCH_FRFLAGS
, MASK_FRFLAGS
, match_opcode
, INSN_ALIAS
},
699 {"fsflags", 0, INSN_CLASS_F_INX
, "s", MATCH_FSFLAGS
, MASK_FSFLAGS
|MASK_RD
, match_opcode
, INSN_ALIAS
},
700 {"fsflags", 0, INSN_CLASS_F_INX
, "d,s", MATCH_FSFLAGS
, MASK_FSFLAGS
, match_opcode
, INSN_ALIAS
},
701 {"fsflagsi", 0, INSN_CLASS_F_INX
, "d,Z", MATCH_FSFLAGSI
, MASK_FSFLAGSI
, match_opcode
, INSN_ALIAS
},
702 {"fsflagsi", 0, INSN_CLASS_F_INX
, "Z", MATCH_FSFLAGSI
, MASK_FSFLAGSI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
703 {"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
},
704 {"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
},
705 {"flw", 0, INSN_CLASS_F
, "D,o(s)", MATCH_FLW
, MASK_FLW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
706 {"flw", 0, INSN_CLASS_F
, "D,A,s", 0, (int) M_FLW
, match_never
, INSN_MACRO
},
707 {"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
},
708 {"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
},
709 {"fsw", 0, INSN_CLASS_F
, "T,q(s)", MATCH_FSW
, MASK_FSW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
710 {"fsw", 0, INSN_CLASS_F
, "T,A,s", 0, (int) M_FSW
, match_never
, INSN_MACRO
},
711 {"fmv.x.w", 0, INSN_CLASS_F
, "d,S", MATCH_FMV_X_S
, MASK_FMV_X_S
, match_opcode
, 0 },
712 {"fmv.w.x", 0, INSN_CLASS_F
, "D,s", MATCH_FMV_S_X
, MASK_FMV_S_X
, match_opcode
, 0 },
713 {"fmv.x.s", 0, INSN_CLASS_F
, "d,S", MATCH_FMV_X_S
, MASK_FMV_X_S
, match_opcode
, 0 },
714 {"fmv.s.x", 0, INSN_CLASS_F
, "D,s", MATCH_FMV_S_X
, MASK_FMV_S_X
, match_opcode
, 0 },
715 {"fmv.s", 0, INSN_CLASS_F_INX
, "D,U", MATCH_FSGNJ_S
, MASK_FSGNJ_S
, match_rs1_eq_rs2
, INSN_ALIAS
},
716 {"fneg.s", 0, INSN_CLASS_F_INX
, "D,U", MATCH_FSGNJN_S
, MASK_FSGNJN_S
, match_rs1_eq_rs2
, INSN_ALIAS
},
717 {"fabs.s", 0, INSN_CLASS_F_INX
, "D,U", MATCH_FSGNJX_S
, MASK_FSGNJX_S
, match_rs1_eq_rs2
, INSN_ALIAS
},
718 {"fsgnj.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSGNJ_S
, MASK_FSGNJ_S
, match_opcode
, 0 },
719 {"fsgnjn.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSGNJN_S
, MASK_FSGNJN_S
, match_opcode
, 0 },
720 {"fsgnjx.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSGNJX_S
, MASK_FSGNJX_S
, match_opcode
, 0 },
721 {"fadd.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FADD_S
|MASK_RM
, MASK_FADD_S
|MASK_RM
, match_opcode
, 0 },
722 {"fadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FADD_S
, MASK_FADD_S
, match_opcode
, 0 },
723 {"fsub.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FSUB_S
|MASK_RM
, MASK_FSUB_S
|MASK_RM
, match_opcode
, 0 },
724 {"fsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FSUB_S
, MASK_FSUB_S
, match_opcode
, 0 },
725 {"fmul.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FMUL_S
|MASK_RM
, MASK_FMUL_S
|MASK_RM
, match_opcode
, 0 },
726 {"fmul.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FMUL_S
, MASK_FMUL_S
, match_opcode
, 0 },
727 {"fdiv.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FDIV_S
|MASK_RM
, MASK_FDIV_S
|MASK_RM
, match_opcode
, 0 },
728 {"fdiv.s", 0, INSN_CLASS_F_INX
, "D,S,T,m", MATCH_FDIV_S
, MASK_FDIV_S
, match_opcode
, 0 },
729 {"fsqrt.s", 0, INSN_CLASS_F_INX
, "D,S", MATCH_FSQRT_S
|MASK_RM
, MASK_FSQRT_S
|MASK_RM
, match_opcode
, 0 },
730 {"fsqrt.s", 0, INSN_CLASS_F_INX
, "D,S,m", MATCH_FSQRT_S
, MASK_FSQRT_S
, match_opcode
, 0 },
731 {"fmin.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FMIN_S
, MASK_FMIN_S
, match_opcode
, 0 },
732 {"fmax.s", 0, INSN_CLASS_F_INX
, "D,S,T", MATCH_FMAX_S
, MASK_FMAX_S
, match_opcode
, 0 },
733 {"fmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FMADD_S
|MASK_RM
, MASK_FMADD_S
|MASK_RM
, match_opcode
, 0 },
734 {"fmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FMADD_S
, MASK_FMADD_S
, match_opcode
, 0 },
735 {"fnmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FNMADD_S
|MASK_RM
, MASK_FNMADD_S
|MASK_RM
, match_opcode
, 0 },
736 {"fnmadd.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FNMADD_S
, MASK_FNMADD_S
, match_opcode
, 0 },
737 {"fmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FMSUB_S
|MASK_RM
, MASK_FMSUB_S
|MASK_RM
, match_opcode
, 0 },
738 {"fmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FMSUB_S
, MASK_FMSUB_S
, match_opcode
, 0 },
739 {"fnmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R", MATCH_FNMSUB_S
|MASK_RM
, MASK_FNMSUB_S
|MASK_RM
, match_opcode
, 0 },
740 {"fnmsub.s", 0, INSN_CLASS_F_INX
, "D,S,T,R,m", MATCH_FNMSUB_S
, MASK_FNMSUB_S
, match_opcode
, 0 },
741 {"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 },
742 {"fcvt.w.s", 0, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_W_S
, MASK_FCVT_W_S
, match_opcode
, 0 },
743 {"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 },
744 {"fcvt.wu.s", 0, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_WU_S
, MASK_FCVT_WU_S
, match_opcode
, 0 },
745 {"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 },
746 {"fcvt.s.w", 0, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_W
, MASK_FCVT_S_W
, match_opcode
, 0 },
747 {"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 },
748 {"fcvt.s.wu", 0, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_WU
, MASK_FCVT_S_WU
, match_opcode
, 0 },
749 {"fclass.s", 0, INSN_CLASS_F_INX
, "d,S", MATCH_FCLASS_S
, MASK_FCLASS_S
, match_opcode
, 0 },
750 {"feq.s", 0, INSN_CLASS_F_INX
, "d,S,T", MATCH_FEQ_S
, MASK_FEQ_S
, match_opcode
, 0 },
751 {"flt.s", 0, INSN_CLASS_F_INX
, "d,S,T", MATCH_FLT_S
, MASK_FLT_S
, match_opcode
, 0 },
752 {"fle.s", 0, INSN_CLASS_F_INX
, "d,S,T", MATCH_FLE_S
, MASK_FLE_S
, match_opcode
, 0 },
753 {"fgt.s", 0, INSN_CLASS_F_INX
, "d,T,S", MATCH_FLT_S
, MASK_FLT_S
, match_opcode
, 0 },
754 {"fge.s", 0, INSN_CLASS_F_INX
, "d,T,S", MATCH_FLE_S
, MASK_FLE_S
, match_opcode
, 0 },
755 {"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 },
756 {"fcvt.l.s", 64, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_L_S
, MASK_FCVT_L_S
, match_opcode
, 0 },
757 {"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 },
758 {"fcvt.lu.s", 64, INSN_CLASS_F_INX
, "d,S,m", MATCH_FCVT_LU_S
, MASK_FCVT_LU_S
, match_opcode
, 0 },
759 {"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 },
760 {"fcvt.s.l", 64, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_L
, MASK_FCVT_S_L
, match_opcode
, 0 },
761 {"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 },
762 {"fcvt.s.lu", 64, INSN_CLASS_F_INX
, "D,s,m", MATCH_FCVT_S_LU
, MASK_FCVT_S_LU
, match_opcode
, 0 },
764 /* Double-precision floating-point instruction subset. */
765 {"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
},
766 {"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
},
767 {"fld", 0, INSN_CLASS_D
, "D,o(s)", MATCH_FLD
, MASK_FLD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
768 {"fld", 0, INSN_CLASS_D
, "D,A,s", 0, (int) M_FLD
, match_never
, INSN_MACRO
},
769 {"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
},
770 {"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
},
771 {"fsd", 0, INSN_CLASS_D
, "T,q(s)", MATCH_FSD
, MASK_FSD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
772 {"fsd", 0, INSN_CLASS_D
, "T,A,s", 0, (int) M_FSD
, match_never
, INSN_MACRO
},
773 {"fmv.d", 0, INSN_CLASS_D_INX
, "D,U", MATCH_FSGNJ_D
, MASK_FSGNJ_D
, match_rs1_eq_rs2
, INSN_ALIAS
},
774 {"fneg.d", 0, INSN_CLASS_D_INX
, "D,U", MATCH_FSGNJN_D
, MASK_FSGNJN_D
, match_rs1_eq_rs2
, INSN_ALIAS
},
775 {"fabs.d", 0, INSN_CLASS_D_INX
, "D,U", MATCH_FSGNJX_D
, MASK_FSGNJX_D
, match_rs1_eq_rs2
, INSN_ALIAS
},
776 {"fsgnj.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSGNJ_D
, MASK_FSGNJ_D
, match_opcode
, 0 },
777 {"fsgnjn.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSGNJN_D
, MASK_FSGNJN_D
, match_opcode
, 0 },
778 {"fsgnjx.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSGNJX_D
, MASK_FSGNJX_D
, match_opcode
, 0 },
779 {"fadd.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FADD_D
|MASK_RM
, MASK_FADD_D
|MASK_RM
, match_opcode
, 0 },
780 {"fadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FADD_D
, MASK_FADD_D
, match_opcode
, 0 },
781 {"fsub.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FSUB_D
|MASK_RM
, MASK_FSUB_D
|MASK_RM
, match_opcode
, 0 },
782 {"fsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FSUB_D
, MASK_FSUB_D
, match_opcode
, 0 },
783 {"fmul.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FMUL_D
|MASK_RM
, MASK_FMUL_D
|MASK_RM
, match_opcode
, 0 },
784 {"fmul.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FMUL_D
, MASK_FMUL_D
, match_opcode
, 0 },
785 {"fdiv.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FDIV_D
|MASK_RM
, MASK_FDIV_D
|MASK_RM
, match_opcode
, 0 },
786 {"fdiv.d", 0, INSN_CLASS_D_INX
, "D,S,T,m", MATCH_FDIV_D
, MASK_FDIV_D
, match_opcode
, 0 },
787 {"fsqrt.d", 0, INSN_CLASS_D_INX
, "D,S", MATCH_FSQRT_D
|MASK_RM
, MASK_FSQRT_D
|MASK_RM
, match_opcode
, 0 },
788 {"fsqrt.d", 0, INSN_CLASS_D_INX
, "D,S,m", MATCH_FSQRT_D
, MASK_FSQRT_D
, match_opcode
, 0 },
789 {"fmin.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FMIN_D
, MASK_FMIN_D
, match_opcode
, 0 },
790 {"fmax.d", 0, INSN_CLASS_D_INX
, "D,S,T", MATCH_FMAX_D
, MASK_FMAX_D
, match_opcode
, 0 },
791 {"fmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FMADD_D
|MASK_RM
, MASK_FMADD_D
|MASK_RM
, match_opcode
, 0 },
792 {"fmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FMADD_D
, MASK_FMADD_D
, match_opcode
, 0 },
793 {"fnmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FNMADD_D
|MASK_RM
, MASK_FNMADD_D
|MASK_RM
, match_opcode
, 0 },
794 {"fnmadd.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FNMADD_D
, MASK_FNMADD_D
, match_opcode
, 0 },
795 {"fmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FMSUB_D
|MASK_RM
, MASK_FMSUB_D
|MASK_RM
, match_opcode
, 0 },
796 {"fmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FMSUB_D
, MASK_FMSUB_D
, match_opcode
, 0 },
797 {"fnmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R", MATCH_FNMSUB_D
|MASK_RM
, MASK_FNMSUB_D
|MASK_RM
, match_opcode
, 0 },
798 {"fnmsub.d", 0, INSN_CLASS_D_INX
, "D,S,T,R,m", MATCH_FNMSUB_D
, MASK_FNMSUB_D
, match_opcode
, 0 },
799 {"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 },
800 {"fcvt.w.d", 0, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_W_D
, MASK_FCVT_W_D
, match_opcode
, 0 },
801 {"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 },
802 {"fcvt.wu.d", 0, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_WU_D
, MASK_FCVT_WU_D
, match_opcode
, 0 },
803 {"fcvt.d.w", 0, INSN_CLASS_D_INX
, "D,s", MATCH_FCVT_D_W
, MASK_FCVT_D_W
|MASK_RM
, match_opcode
, 0 },
804 {"fcvt.d.wu", 0, INSN_CLASS_D_INX
, "D,s", MATCH_FCVT_D_WU
, MASK_FCVT_D_WU
|MASK_RM
, match_opcode
, 0 },
805 {"fcvt.d.s", 0, INSN_CLASS_D_INX
, "D,S", MATCH_FCVT_D_S
, MASK_FCVT_D_S
|MASK_RM
, match_opcode
, 0 },
806 {"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 },
807 {"fcvt.s.d", 0, INSN_CLASS_D_INX
, "D,S,m", MATCH_FCVT_S_D
, MASK_FCVT_S_D
, match_opcode
, 0 },
808 {"fclass.d", 0, INSN_CLASS_D_INX
, "d,S", MATCH_FCLASS_D
, MASK_FCLASS_D
, match_opcode
, 0 },
809 {"feq.d", 0, INSN_CLASS_D_INX
, "d,S,T", MATCH_FEQ_D
, MASK_FEQ_D
, match_opcode
, 0 },
810 {"flt.d", 0, INSN_CLASS_D_INX
, "d,S,T", MATCH_FLT_D
, MASK_FLT_D
, match_opcode
, 0 },
811 {"fle.d", 0, INSN_CLASS_D_INX
, "d,S,T", MATCH_FLE_D
, MASK_FLE_D
, match_opcode
, 0 },
812 {"fgt.d", 0, INSN_CLASS_D_INX
, "d,T,S", MATCH_FLT_D
, MASK_FLT_D
, match_opcode
, 0 },
813 {"fge.d", 0, INSN_CLASS_D_INX
, "d,T,S", MATCH_FLE_D
, MASK_FLE_D
, match_opcode
, 0 },
814 {"fmv.x.d", 64, INSN_CLASS_D
, "d,S", MATCH_FMV_X_D
, MASK_FMV_X_D
, match_opcode
, 0 },
815 {"fmv.d.x", 64, INSN_CLASS_D
, "D,s", MATCH_FMV_D_X
, MASK_FMV_D_X
, match_opcode
, 0 },
816 {"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 },
817 {"fcvt.l.d", 64, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_L_D
, MASK_FCVT_L_D
, match_opcode
, 0 },
818 {"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 },
819 {"fcvt.lu.d", 64, INSN_CLASS_D_INX
, "d,S,m", MATCH_FCVT_LU_D
, MASK_FCVT_LU_D
, match_opcode
, 0 },
820 {"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 },
821 {"fcvt.d.l", 64, INSN_CLASS_D_INX
, "D,s,m", MATCH_FCVT_D_L
, MASK_FCVT_D_L
, match_opcode
, 0 },
822 {"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 },
823 {"fcvt.d.lu", 64, INSN_CLASS_D_INX
, "D,s,m", MATCH_FCVT_D_LU
, MASK_FCVT_D_LU
, match_opcode
, 0 },
825 /* Quad-precision floating-point instruction subset. */
826 {"flq", 0, INSN_CLASS_Q
, "D,o(s)", MATCH_FLQ
, MASK_FLQ
, match_opcode
, INSN_DREF
|INSN_16_BYTE
},
827 {"flq", 0, INSN_CLASS_Q
, "D,A,s", 0, (int) M_FLQ
, match_never
, INSN_MACRO
},
828 {"fsq", 0, INSN_CLASS_Q
, "T,q(s)", MATCH_FSQ
, MASK_FSQ
, match_opcode
, INSN_DREF
|INSN_16_BYTE
},
829 {"fsq", 0, INSN_CLASS_Q
, "T,A,s", 0, (int) M_FSQ
, match_never
, INSN_MACRO
},
830 {"fmv.q", 0, INSN_CLASS_Q_INX
, "D,U", MATCH_FSGNJ_Q
, MASK_FSGNJ_Q
, match_rs1_eq_rs2
, INSN_ALIAS
},
831 {"fneg.q", 0, INSN_CLASS_Q_INX
, "D,U", MATCH_FSGNJN_Q
, MASK_FSGNJN_Q
, match_rs1_eq_rs2
, INSN_ALIAS
},
832 {"fabs.q", 0, INSN_CLASS_Q_INX
, "D,U", MATCH_FSGNJX_Q
, MASK_FSGNJX_Q
, match_rs1_eq_rs2
, INSN_ALIAS
},
833 {"fsgnj.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSGNJ_Q
, MASK_FSGNJ_Q
, match_opcode
, 0 },
834 {"fsgnjn.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSGNJN_Q
, MASK_FSGNJN_Q
, match_opcode
, 0 },
835 {"fsgnjx.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSGNJX_Q
, MASK_FSGNJX_Q
, match_opcode
, 0 },
836 {"fadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FADD_Q
|MASK_RM
, MASK_FADD_Q
|MASK_RM
, match_opcode
, 0 },
837 {"fadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FADD_Q
, MASK_FADD_Q
, match_opcode
, 0 },
838 {"fsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FSUB_Q
|MASK_RM
, MASK_FSUB_Q
|MASK_RM
, match_opcode
, 0 },
839 {"fsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FSUB_Q
, MASK_FSUB_Q
, match_opcode
, 0 },
840 {"fmul.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FMUL_Q
|MASK_RM
, MASK_FMUL_Q
|MASK_RM
, match_opcode
, 0 },
841 {"fmul.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FMUL_Q
, MASK_FMUL_Q
, match_opcode
, 0 },
842 {"fdiv.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FDIV_Q
|MASK_RM
, MASK_FDIV_Q
|MASK_RM
, match_opcode
, 0 },
843 {"fdiv.q", 0, INSN_CLASS_Q_INX
, "D,S,T,m", MATCH_FDIV_Q
, MASK_FDIV_Q
, match_opcode
, 0 },
844 {"fsqrt.q", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FSQRT_Q
|MASK_RM
, MASK_FSQRT_Q
|MASK_RM
, match_opcode
, 0 },
845 {"fsqrt.q", 0, INSN_CLASS_Q_INX
, "D,S,m", MATCH_FSQRT_Q
, MASK_FSQRT_Q
, match_opcode
, 0 },
846 {"fmin.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FMIN_Q
, MASK_FMIN_Q
, match_opcode
, 0 },
847 {"fmax.q", 0, INSN_CLASS_Q_INX
, "D,S,T", MATCH_FMAX_Q
, MASK_FMAX_Q
, match_opcode
, 0 },
848 {"fmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FMADD_Q
|MASK_RM
, MASK_FMADD_Q
|MASK_RM
, match_opcode
, 0 },
849 {"fmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FMADD_Q
, MASK_FMADD_Q
, match_opcode
, 0 },
850 {"fnmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FNMADD_Q
|MASK_RM
, MASK_FNMADD_Q
|MASK_RM
, match_opcode
, 0 },
851 {"fnmadd.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FNMADD_Q
, MASK_FNMADD_Q
, match_opcode
, 0 },
852 {"fmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FMSUB_Q
|MASK_RM
, MASK_FMSUB_Q
|MASK_RM
, match_opcode
, 0 },
853 {"fmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FMSUB_Q
, MASK_FMSUB_Q
, match_opcode
, 0 },
854 {"fnmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R", MATCH_FNMSUB_Q
|MASK_RM
, MASK_FNMSUB_Q
|MASK_RM
, match_opcode
, 0 },
855 {"fnmsub.q", 0, INSN_CLASS_Q_INX
, "D,S,T,R,m", MATCH_FNMSUB_Q
, MASK_FNMSUB_Q
, match_opcode
, 0 },
856 {"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 },
857 {"fcvt.w.q", 0, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_W_Q
, MASK_FCVT_W_Q
, match_opcode
, 0 },
858 {"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 },
859 {"fcvt.wu.q", 0, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_WU_Q
, MASK_FCVT_WU_Q
, match_opcode
, 0 },
860 {"fcvt.q.w", 0, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_W
, MASK_FCVT_Q_W
|MASK_RM
, match_opcode
, 0 },
861 {"fcvt.q.wu", 0, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_WU
, MASK_FCVT_Q_WU
|MASK_RM
, match_opcode
, 0 },
862 {"fcvt.q.s", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FCVT_Q_S
, MASK_FCVT_Q_S
|MASK_RM
, match_opcode
, 0 },
863 {"fcvt.q.d", 0, INSN_CLASS_Q_INX
, "D,S", MATCH_FCVT_Q_D
, MASK_FCVT_Q_D
|MASK_RM
, match_opcode
, 0 },
864 {"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 },
865 {"fcvt.s.q", 0, INSN_CLASS_Q_INX
, "D,S,m", MATCH_FCVT_S_Q
, MASK_FCVT_S_Q
, match_opcode
, 0 },
866 {"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 },
867 {"fcvt.d.q", 0, INSN_CLASS_Q_INX
, "D,S,m", MATCH_FCVT_D_Q
, MASK_FCVT_D_Q
, match_opcode
, 0 },
868 {"fclass.q", 0, INSN_CLASS_Q_INX
, "d,S", MATCH_FCLASS_Q
, MASK_FCLASS_Q
, match_opcode
, 0 },
869 {"feq.q", 0, INSN_CLASS_Q_INX
, "d,S,T", MATCH_FEQ_Q
, MASK_FEQ_Q
, match_opcode
, 0 },
870 {"flt.q", 0, INSN_CLASS_Q_INX
, "d,S,T", MATCH_FLT_Q
, MASK_FLT_Q
, match_opcode
, 0 },
871 {"fle.q", 0, INSN_CLASS_Q_INX
, "d,S,T", MATCH_FLE_Q
, MASK_FLE_Q
, match_opcode
, 0 },
872 {"fgt.q", 0, INSN_CLASS_Q_INX
, "d,T,S", MATCH_FLT_Q
, MASK_FLT_Q
, match_opcode
, 0 },
873 {"fge.q", 0, INSN_CLASS_Q_INX
, "d,T,S", MATCH_FLE_Q
, MASK_FLE_Q
, match_opcode
, 0 },
874 {"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 },
875 {"fcvt.l.q", 64, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_L_Q
, MASK_FCVT_L_Q
, match_opcode
, 0 },
876 {"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 },
877 {"fcvt.lu.q", 64, INSN_CLASS_Q_INX
, "d,S,m", MATCH_FCVT_LU_Q
, MASK_FCVT_LU_Q
, match_opcode
, 0 },
878 {"fcvt.q.l", 64, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_L
, MASK_FCVT_Q_L
|MASK_RM
, match_opcode
, 0 },
879 {"fcvt.q.l", 64, INSN_CLASS_Q_INX
, "D,s,m", MATCH_FCVT_Q_L
, MASK_FCVT_Q_L
, match_opcode
, 0 },
880 {"fcvt.q.lu", 64, INSN_CLASS_Q_INX
, "D,s", MATCH_FCVT_Q_LU
, MASK_FCVT_Q_LU
|MASK_RM
, match_opcode
, 0 },
881 {"fcvt.q.lu", 64, INSN_CLASS_Q_INX
, "D,s,m", MATCH_FCVT_Q_LU
, MASK_FCVT_Q_LU
, match_opcode
, 0 },
883 /* Compressed instructions. */
884 {"c.unimp", 0, INSN_CLASS_C
, "", 0, 0xffffU
, match_opcode
, 0 },
885 {"c.ebreak", 0, INSN_CLASS_C
, "", MATCH_C_EBREAK
, MASK_C_EBREAK
, match_opcode
, 0 },
886 {"c.jr", 0, INSN_CLASS_C
, "d", MATCH_C_JR
, MASK_C_JR
, match_rd_nonzero
, INSN_BRANCH
},
887 {"c.jalr", 0, INSN_CLASS_C
, "d", MATCH_C_JALR
, MASK_C_JALR
, match_rd_nonzero
, INSN_JSR
},
888 {"c.j", 0, INSN_CLASS_C
, "Ca", MATCH_C_J
, MASK_C_J
, match_opcode
, INSN_BRANCH
},
889 {"c.jal", 32, INSN_CLASS_C
, "Ca", MATCH_C_JAL
, MASK_C_JAL
, match_opcode
, INSN_JSR
},
890 {"c.beqz", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BEQZ
, MASK_C_BEQZ
, match_opcode
, INSN_CONDBRANCH
},
891 {"c.bnez", 0, INSN_CLASS_C
, "Cs,Cp", MATCH_C_BNEZ
, MASK_C_BNEZ
, match_opcode
, INSN_CONDBRANCH
},
892 {"c.lwsp", 0, INSN_CLASS_C
, "d,Cm(Cc)", MATCH_C_LWSP
, MASK_C_LWSP
, match_rd_nonzero
, 0 },
893 {"c.lw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_LW
, MASK_C_LW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
894 {"c.swsp", 0, INSN_CLASS_C
, "CV,CM(Cc)", MATCH_C_SWSP
, MASK_C_SWSP
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
895 {"c.sw", 0, INSN_CLASS_C
, "Ct,Ck(Cs)", MATCH_C_SW
, MASK_C_SW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
896 {"c.nop", 0, INSN_CLASS_C
, "", MATCH_C_ADDI
, 0xffff, match_opcode
, INSN_ALIAS
},
897 {"c.nop", 0, INSN_CLASS_C
, "Cj", MATCH_C_ADDI
, MASK_C_ADDI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
898 {"c.mv", 0, INSN_CLASS_C
, "d,CV", MATCH_C_MV
, MASK_C_MV
, match_c_add_with_hint
, 0 },
899 {"c.lui", 0, INSN_CLASS_C
, "d,Cu", MATCH_C_LUI
, MASK_C_LUI
, match_c_lui_with_hint
, 0 },
900 {"c.li", 0, INSN_CLASS_C
, "d,Co", MATCH_C_LI
, MASK_C_LI
, match_opcode
, 0 },
901 {"c.addi4spn", 0, INSN_CLASS_C
, "Ct,Cc,CK", MATCH_C_ADDI4SPN
, MASK_C_ADDI4SPN
, match_c_addi4spn
, 0 },
902 {"c.addi16sp", 0, INSN_CLASS_C
, "Cc,CL", MATCH_C_ADDI16SP
, MASK_C_ADDI16SP
, match_c_addi16sp
, 0 },
903 {"c.addi", 0, INSN_CLASS_C
, "d,Co", MATCH_C_ADDI
, MASK_C_ADDI
, match_opcode
, 0 },
904 {"c.add", 0, INSN_CLASS_C
, "d,CV", MATCH_C_ADD
, MASK_C_ADD
, match_c_add_with_hint
, 0 },
905 {"c.sub", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_SUB
, MASK_C_SUB
, match_opcode
, 0 },
906 {"c.and", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_AND
, MASK_C_AND
, match_opcode
, 0 },
907 {"c.or", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_OR
, MASK_C_OR
, match_opcode
, 0 },
908 {"c.xor", 0, INSN_CLASS_C
, "Cs,Ct", MATCH_C_XOR
, MASK_C_XOR
, match_opcode
, 0 },
909 {"c.slli", 0, INSN_CLASS_C
, "d,C>", MATCH_C_SLLI
, MASK_C_SLLI
, match_c_slli
, 0 },
910 {"c.srli", 0, INSN_CLASS_C
, "Cs,C>", MATCH_C_SRLI
, MASK_C_SRLI
, match_c_slli
, 0 },
911 {"c.srai", 0, INSN_CLASS_C
, "Cs,C>", MATCH_C_SRAI
, MASK_C_SRAI
, match_c_slli
, 0 },
912 {"c.slli64", 0, INSN_CLASS_C
, "d", MATCH_C_SLLI64
, MASK_C_SLLI64
, match_c_slli64
, 0 },
913 {"c.srli64", 0, INSN_CLASS_C
, "Cs", MATCH_C_SRLI64
, MASK_C_SRLI64
, match_c_slli64
, 0 },
914 {"c.srai64", 0, INSN_CLASS_C
, "Cs", MATCH_C_SRAI64
, MASK_C_SRAI64
, match_c_slli64
, 0 },
915 {"c.andi", 0, INSN_CLASS_C
, "Cs,Co", MATCH_C_ANDI
, MASK_C_ANDI
, match_opcode
, 0 },
916 {"c.addiw", 64, INSN_CLASS_C
, "d,Co", MATCH_C_ADDIW
, MASK_C_ADDIW
, match_rd_nonzero
, 0 },
917 {"c.addw", 64, INSN_CLASS_C
, "Cs,Ct", MATCH_C_ADDW
, MASK_C_ADDW
, match_opcode
, 0 },
918 {"c.subw", 64, INSN_CLASS_C
, "Cs,Ct", MATCH_C_SUBW
, MASK_C_SUBW
, match_opcode
, 0 },
919 {"c.ldsp", 64, INSN_CLASS_C
, "d,Cn(Cc)", MATCH_C_LDSP
, MASK_C_LDSP
, match_rd_nonzero
, INSN_DREF
|INSN_8_BYTE
},
920 {"c.ld", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_LD
, MASK_C_LD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
921 {"c.sdsp", 64, INSN_CLASS_C
, "CV,CN(Cc)", MATCH_C_SDSP
, MASK_C_SDSP
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
922 {"c.sd", 64, INSN_CLASS_C
, "Ct,Cl(Cs)", MATCH_C_SD
, MASK_C_SD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
923 {"c.fldsp", 0, INSN_CLASS_D_AND_C
, "D,Cn(Cc)", MATCH_C_FLDSP
, MASK_C_FLDSP
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
924 {"c.fld", 0, INSN_CLASS_D_AND_C
, "CD,Cl(Cs)", MATCH_C_FLD
, MASK_C_FLD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
925 {"c.fsdsp", 0, INSN_CLASS_D_AND_C
, "CT,CN(Cc)", MATCH_C_FSDSP
, MASK_C_FSDSP
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
926 {"c.fsd", 0, INSN_CLASS_D_AND_C
, "CD,Cl(Cs)", MATCH_C_FSD
, MASK_C_FSD
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
927 {"c.flwsp", 32, INSN_CLASS_F_AND_C
, "D,Cm(Cc)", MATCH_C_FLWSP
, MASK_C_FLWSP
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
928 {"c.flw", 32, INSN_CLASS_F_AND_C
, "CD,Ck(Cs)", MATCH_C_FLW
, MASK_C_FLW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
929 {"c.fswsp", 32, INSN_CLASS_F_AND_C
, "CT,CM(Cc)", MATCH_C_FSWSP
, MASK_C_FSWSP
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
930 {"c.fsw", 32, INSN_CLASS_F_AND_C
, "CD,Ck(Cs)", MATCH_C_FSW
, MASK_C_FSW
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
932 /* Zicbom and Zicboz instructions. */
933 {"cbo.clean", 0, INSN_CLASS_ZICBOM
, "0(s)", MATCH_CBO_CLEAN
, MASK_CBO_CLEAN
, match_opcode
, 0 },
934 {"cbo.flush", 0, INSN_CLASS_ZICBOM
, "0(s)", MATCH_CBO_FLUSH
, MASK_CBO_FLUSH
, match_opcode
, 0 },
935 {"cbo.inval", 0, INSN_CLASS_ZICBOM
, "0(s)", MATCH_CBO_INVAL
, MASK_CBO_INVAL
, match_opcode
, 0 },
936 {"cbo.zero", 0, INSN_CLASS_ZICBOZ
, "0(s)", MATCH_CBO_ZERO
, MASK_CBO_ZERO
, match_opcode
, 0 },
938 /* Zawrs instructions. */
939 {"wrs.nto", 0, INSN_CLASS_ZAWRS
, "", MATCH_WRS_NTO
, MASK_WRS_NTO
, match_opcode
, 0 },
940 {"wrs.sto", 0, INSN_CLASS_ZAWRS
, "", MATCH_WRS_STO
, MASK_WRS_STO
, match_opcode
, 0 },
942 /* Zbb or zbkb instructions. */
943 {"clz", 0, INSN_CLASS_ZBB
, "d,s", MATCH_CLZ
, MASK_CLZ
, match_opcode
, 0 },
944 {"ctz", 0, INSN_CLASS_ZBB
, "d,s", MATCH_CTZ
, MASK_CTZ
, match_opcode
, 0 },
945 {"cpop", 0, INSN_CLASS_ZBB
, "d,s", MATCH_CPOP
, MASK_CPOP
, match_opcode
, 0 },
946 {"min", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MIN
, MASK_MIN
, match_opcode
, 0 },
947 {"max", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MAX
, MASK_MAX
, match_opcode
, 0 },
948 {"minu", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MINU
, MASK_MINU
, match_opcode
, 0 },
949 {"maxu", 0, INSN_CLASS_ZBB
, "d,s,t", MATCH_MAXU
, MASK_MAXU
, match_opcode
, 0 },
950 {"sext.b", 0, INSN_CLASS_ZBB
, "d,s", MATCH_SEXT_B
, MASK_SEXT_B
, match_opcode
, 0 },
951 {"sext.b", 0, INSN_CLASS_I
, "d,s", 0, (int) M_SEXTB
, match_never
, INSN_MACRO
},
952 {"sext.h", 0, INSN_CLASS_ZBB
, "d,s", MATCH_SEXT_H
, MASK_SEXT_H
, match_opcode
, 0 },
953 {"sext.h", 0, INSN_CLASS_I
, "d,s", 0, (int) M_SEXTH
, match_never
, INSN_MACRO
},
954 {"zext.h", 32, INSN_CLASS_ZBB
, "d,s", MATCH_PACK
, MASK_PACK
| MASK_RS2
, match_opcode
, 0 },
955 {"zext.h", 64, INSN_CLASS_ZBB
, "d,s", MATCH_PACKW
, MASK_PACKW
| MASK_RS2
, match_opcode
, 0 },
956 {"zext.h", 0, INSN_CLASS_I
, "d,s", 0, (int) M_ZEXTH
, match_never
, INSN_MACRO
},
957 {"orc.b", 0, INSN_CLASS_ZBB
, "d,s", MATCH_GORCI
| MATCH_SHAMT_ORC_B
, MASK_GORCI
| MASK_SHAMT
, match_opcode
, 0 },
958 {"clzw", 64, INSN_CLASS_ZBB
, "d,s", MATCH_CLZW
, MASK_CLZW
, match_opcode
, 0 },
959 {"ctzw", 64, INSN_CLASS_ZBB
, "d,s", MATCH_CTZW
, MASK_CTZW
, match_opcode
, 0 },
960 {"cpopw", 64, INSN_CLASS_ZBB
, "d,s", MATCH_CPOPW
, MASK_CPOPW
, match_opcode
, 0 },
961 {"brev8", 32, INSN_CLASS_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_BREV8
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
962 {"brev8", 64, INSN_CLASS_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_BREV8
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
963 {"zip", 32, INSN_CLASS_ZBKB
, "d,s", MATCH_SHFLI
|MATCH_SHAMT_ZIP_32
, MASK_SHFLI
|MASK_SHAMT
, match_opcode
, 0 },
964 {"unzip", 32, INSN_CLASS_ZBKB
, "d,s", MATCH_UNSHFLI
|MATCH_SHAMT_ZIP_32
, MASK_UNSHFLI
|MASK_SHAMT
, match_opcode
, 0 },
965 {"pack", 0, INSN_CLASS_ZBKB
, "d,s,t", MATCH_PACK
, MASK_PACK
, match_opcode
, 0 },
966 {"packh", 0, INSN_CLASS_ZBKB
, "d,s,t", MATCH_PACKH
, MASK_PACKH
, match_opcode
, 0 },
967 {"packw", 64, INSN_CLASS_ZBKB
, "d,s,t", MATCH_PACKW
, MASK_PACKW
, match_opcode
, 0 },
968 {"andn", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ANDN
, MASK_ANDN
, match_opcode
, 0 },
969 {"orn", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ORN
, MASK_ORN
, match_opcode
, 0 },
970 {"xnor", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_XNOR
, MASK_XNOR
, match_opcode
, 0 },
971 {"rol", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ROL
, MASK_ROL
, match_opcode
, 0 },
972 {"ror", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ROR
, MASK_ROR
, match_opcode
, 0 },
973 {"ror", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,>", MATCH_RORI
, MASK_RORI
, match_opcode
, INSN_ALIAS
},
974 {"rori", 0, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,>", MATCH_RORI
, MASK_RORI
, match_opcode
, 0 },
975 {"rev8", 32, INSN_CLASS_ZBB_OR_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_REV8_32
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
976 {"rev8", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s", MATCH_GREVI
| MATCH_SHAMT_REV8_64
, MASK_GREVI
| MASK_SHAMT
, match_opcode
, 0 },
977 {"rolw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_ROLW
, MASK_ROLW
, match_opcode
, 0 },
978 {"rorw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,t", MATCH_RORW
, MASK_RORW
, match_opcode
, 0 },
979 {"rorw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,<", MATCH_RORIW
, MASK_RORIW
, match_opcode
, INSN_ALIAS
},
980 {"roriw", 64, INSN_CLASS_ZBB_OR_ZBKB
, "d,s,<", MATCH_RORIW
, MASK_RORIW
, match_opcode
, 0 },
982 /* Zba instructions. */
983 {"sh1add", 0, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH1ADD
, MASK_SH1ADD
, match_opcode
, 0 },
984 {"sh2add", 0, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH2ADD
, MASK_SH2ADD
, match_opcode
, 0 },
985 {"sh3add", 0, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH3ADD
, MASK_SH3ADD
, match_opcode
, 0 },
986 {"sh1add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH1ADD_UW
, MASK_SH1ADD_UW
, match_opcode
, 0 },
987 {"sh2add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH2ADD_UW
, MASK_SH2ADD_UW
, match_opcode
, 0 },
988 {"sh3add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_SH3ADD_UW
, MASK_SH3ADD_UW
, match_opcode
, 0 },
989 {"zext.w", 64, INSN_CLASS_ZBA
, "d,s", MATCH_ADD_UW
, MASK_ADD_UW
| MASK_RS2
, match_opcode
, INSN_ALIAS
},
990 {"zext.w", 64, INSN_CLASS_I
, "d,s", 0, (int) M_ZEXTW
, match_never
, INSN_MACRO
},
991 {"add.uw", 64, INSN_CLASS_ZBA
, "d,s,t", MATCH_ADD_UW
, MASK_ADD_UW
, match_opcode
, 0 },
992 {"slli.uw", 64, INSN_CLASS_ZBA
, "d,s,>", MATCH_SLLI_UW
, MASK_SLLI_UW
, match_opcode
, 0 },
994 /* Zbc or zbkc instructions. */
995 {"clmul", 0, INSN_CLASS_ZBC_OR_ZBKC
, "d,s,t", MATCH_CLMUL
, MASK_CLMUL
, match_opcode
, 0 },
996 {"clmulh", 0, INSN_CLASS_ZBC_OR_ZBKC
, "d,s,t", MATCH_CLMULH
, MASK_CLMULH
, match_opcode
, 0 },
997 {"clmulr", 0, INSN_CLASS_ZBC
, "d,s,t", MATCH_CLMULR
, MASK_CLMULR
, match_opcode
, 0 },
999 /* Zbs instructions. */
1000 {"bclr", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BCLR
, MASK_BCLR
, match_opcode
, 0 },
1001 {"bclr", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BCLRI
, MASK_BCLRI
, match_opcode
, INSN_ALIAS
},
1002 {"bclri", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BCLRI
, MASK_BCLRI
, match_opcode
, 0 },
1003 {"bset", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BSET
, MASK_BSET
, match_opcode
, 0 },
1004 {"bset", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BSETI
, MASK_BSETI
, match_opcode
, INSN_ALIAS
},
1005 {"bseti", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BSETI
, MASK_BSETI
, match_opcode
, 0 },
1006 {"binv", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BINV
, MASK_BINV
, match_opcode
, 0 },
1007 {"binv", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BINVI
, MASK_BINVI
, match_opcode
, INSN_ALIAS
},
1008 {"binvi", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BINVI
, MASK_BINVI
, match_opcode
, 0 },
1009 {"bext", 0, INSN_CLASS_ZBS
, "d,s,t", MATCH_BEXT
, MASK_BEXT
, match_opcode
, 0 },
1010 {"bext", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BEXTI
, MASK_BEXTI
, match_opcode
, INSN_ALIAS
},
1011 {"bexti", 0, INSN_CLASS_ZBS
, "d,s,>", MATCH_BEXTI
, MASK_BEXTI
, match_opcode
, 0 },
1013 /* Zbkx instructions. */
1014 {"xperm4", 0, INSN_CLASS_ZBKX
, "d,s,t", MATCH_XPERM4
, MASK_XPERM4
, match_opcode
, 0 },
1015 {"xperm8", 0, INSN_CLASS_ZBKX
, "d,s,t", MATCH_XPERM8
, MASK_XPERM8
, match_opcode
, 0 },
1017 /* Zknd instructions. */
1018 {"aes32dsi", 32, INSN_CLASS_ZKND
, "d,s,t,y", MATCH_AES32DSI
, MASK_AES32DSI
, match_opcode
, 0 },
1019 {"aes32dsmi", 32, INSN_CLASS_ZKND
, "d,s,t,y", MATCH_AES32DSMI
, MASK_AES32DSMI
, match_opcode
, 0 },
1020 {"aes64ds", 64, INSN_CLASS_ZKND
, "d,s,t", MATCH_AES64DS
, MASK_AES64DS
, match_opcode
, 0 },
1021 {"aes64dsm", 64, INSN_CLASS_ZKND
, "d,s,t", MATCH_AES64DSM
, MASK_AES64DSM
, match_opcode
, 0 },
1022 {"aes64im", 64, INSN_CLASS_ZKND
, "d,s", MATCH_AES64IM
, MASK_AES64IM
, match_opcode
, 0 },
1023 {"aes64ks1i", 64, INSN_CLASS_ZKND_OR_ZKNE
, "d,s,Y", MATCH_AES64KS1I
, MASK_AES64KS1I
, match_opcode
, 0 },
1024 {"aes64ks2", 64, INSN_CLASS_ZKND_OR_ZKNE
, "d,s,t", MATCH_AES64KS2
, MASK_AES64KS2
, match_opcode
, 0 },
1026 /* Zkne instructions. */
1027 {"aes32esi", 32, INSN_CLASS_ZKNE
, "d,s,t,y", MATCH_AES32ESI
, MASK_AES32ESI
, match_opcode
, 0 },
1028 {"aes32esmi", 32, INSN_CLASS_ZKNE
, "d,s,t,y", MATCH_AES32ESMI
, MASK_AES32ESMI
, match_opcode
, 0 },
1029 {"aes64es", 64, INSN_CLASS_ZKNE
, "d,s,t", MATCH_AES64ES
, MASK_AES64ES
, match_opcode
, 0 },
1030 {"aes64esm", 64, INSN_CLASS_ZKNE
, "d,s,t", MATCH_AES64ESM
, MASK_AES64ESM
, match_opcode
, 0 },
1032 /* Zknh instructions. */
1033 {"sha256sig0", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SIG0
, MASK_SHA256SIG0
, match_opcode
, 0 },
1034 {"sha256sig1", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SIG1
, MASK_SHA256SIG1
, match_opcode
, 0 },
1035 {"sha256sum0", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SUM0
, MASK_SHA256SUM0
, match_opcode
, 0 },
1036 {"sha256sum1", 0, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA256SUM1
, MASK_SHA256SUM1
, match_opcode
, 0 },
1037 {"sha512sig0h", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG0H
, MASK_SHA512SIG0H
, match_opcode
, 0 },
1038 {"sha512sig0l", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG0L
, MASK_SHA512SIG0L
, match_opcode
, 0 },
1039 {"sha512sig1h", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG1H
, MASK_SHA512SIG1H
, match_opcode
, 0 },
1040 {"sha512sig1l", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SIG1L
, MASK_SHA512SIG1L
, match_opcode
, 0 },
1041 {"sha512sum0r", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SUM0R
, MASK_SHA512SUM0R
, match_opcode
, 0 },
1042 {"sha512sum1r", 32, INSN_CLASS_ZKNH
, "d,s,t", MATCH_SHA512SUM1R
, MASK_SHA512SUM1R
, match_opcode
, 0 },
1043 {"sha512sig0", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SIG0
, MASK_SHA512SIG0
, match_opcode
, 0 },
1044 {"sha512sig1", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SIG1
, MASK_SHA512SIG1
, match_opcode
, 0 },
1045 {"sha512sum0", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SUM0
, MASK_SHA512SUM0
, match_opcode
, 0 },
1046 {"sha512sum1", 64, INSN_CLASS_ZKNH
, "d,s", MATCH_SHA512SUM1
, MASK_SHA512SUM1
, match_opcode
, 0 },
1048 /* Zksed instructions. */
1049 {"sm4ed", 0, INSN_CLASS_ZKSED
, "d,s,t,y", MATCH_SM4ED
, MASK_SM4ED
, match_opcode
, 0 },
1050 {"sm4ks", 0, INSN_CLASS_ZKSED
, "d,s,t,y", MATCH_SM4KS
, MASK_SM4KS
, match_opcode
, 0 },
1052 /* Zksh instructions */
1053 {"sm3p0", 0, INSN_CLASS_ZKSH
, "d,s", MATCH_SM3P0
, MASK_SM3P0
, match_opcode
, 0 },
1054 {"sm3p1", 0, INSN_CLASS_ZKSH
, "d,s", MATCH_SM3P1
, MASK_SM3P1
, match_opcode
, 0 },
1056 /* RVV instructions. */
1057 {"vsetvl", 0, INSN_CLASS_V
, "d,s,t", MATCH_VSETVL
, MASK_VSETVL
, match_opcode
, 0},
1058 {"vsetvli", 0, INSN_CLASS_V
, "d,s,Vc", MATCH_VSETVLI
, MASK_VSETVLI
, match_opcode
, 0},
1059 {"vsetivli", 0, INSN_CLASS_V
, "d,Z,Vb", MATCH_VSETIVLI
, MASK_VSETIVLI
, match_opcode
, 0},
1061 {"vlm.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VLMV
, MASK_VLMV
, match_opcode
, INSN_DREF
},
1062 {"vsm.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VSMV
, MASK_VSMV
, match_opcode
, INSN_DREF
},
1063 {"vle1.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VLMV
, MASK_VLMV
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1064 {"vse1.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VSMV
, MASK_VSMV
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1066 {"vle8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE8V
, MASK_VLE8V
, match_opcode
, INSN_DREF
},
1067 {"vle16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE16V
, MASK_VLE16V
, match_opcode
, INSN_DREF
},
1068 {"vle32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE32V
, MASK_VLE32V
, match_opcode
, INSN_DREF
},
1069 {"vle64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE64V
, MASK_VLE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1071 {"vse8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE8V
, MASK_VSE8V
, match_opcode
, INSN_DREF
},
1072 {"vse16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE16V
, MASK_VSE16V
, match_opcode
, INSN_DREF
},
1073 {"vse32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE32V
, MASK_VSE32V
, match_opcode
, INSN_DREF
},
1074 {"vse64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSE64V
, MASK_VSE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1076 {"vlse8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE8V
, MASK_VLSE8V
, match_opcode
, INSN_DREF
},
1077 {"vlse16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE16V
, MASK_VLSE16V
, match_opcode
, INSN_DREF
},
1078 {"vlse32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE32V
, MASK_VLSE32V
, match_opcode
, INSN_DREF
},
1079 {"vlse64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSE64V
, MASK_VLSE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1081 {"vsse8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE8V
, MASK_VSSE8V
, match_opcode
, INSN_DREF
},
1082 {"vsse16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE16V
, MASK_VSSE16V
, match_opcode
, INSN_DREF
},
1083 {"vsse32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE32V
, MASK_VSSE32V
, match_opcode
, INSN_DREF
},
1084 {"vsse64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSE64V
, MASK_VSSE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1086 {"vloxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI8V
, MASK_VLOXEI8V
, match_opcode
, INSN_DREF
},
1087 {"vloxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI16V
, MASK_VLOXEI16V
, match_opcode
, INSN_DREF
},
1088 {"vloxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI32V
, MASK_VLOXEI32V
, match_opcode
, INSN_DREF
},
1089 {"vloxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXEI64V
, MASK_VLOXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1091 {"vsoxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI8V
, MASK_VSOXEI8V
, match_opcode
, INSN_DREF
},
1092 {"vsoxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI16V
, MASK_VSOXEI16V
, match_opcode
, INSN_DREF
},
1093 {"vsoxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI32V
, MASK_VSOXEI32V
, match_opcode
, INSN_DREF
},
1094 {"vsoxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXEI64V
, MASK_VSOXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1096 {"vluxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI8V
, MASK_VLUXEI8V
, match_opcode
, INSN_DREF
},
1097 {"vluxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI16V
, MASK_VLUXEI16V
, match_opcode
, INSN_DREF
},
1098 {"vluxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI32V
, MASK_VLUXEI32V
, match_opcode
, INSN_DREF
},
1099 {"vluxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXEI64V
, MASK_VLUXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1101 {"vsuxei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI8V
, MASK_VSUXEI8V
, match_opcode
, INSN_DREF
},
1102 {"vsuxei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI16V
, MASK_VSUXEI16V
, match_opcode
, INSN_DREF
},
1103 {"vsuxei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI32V
, MASK_VSUXEI32V
, match_opcode
, INSN_DREF
},
1104 {"vsuxei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXEI64V
, MASK_VSUXEI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1106 {"vle8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE8FFV
, MASK_VLE8FFV
, match_opcode
, INSN_DREF
},
1107 {"vle16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE16FFV
, MASK_VLE16FFV
, match_opcode
, INSN_DREF
},
1108 {"vle32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE32FFV
, MASK_VLE32FFV
, match_opcode
, INSN_DREF
},
1109 {"vle64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLE64FFV
, MASK_VLE64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1111 {"vlseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E8V
, MASK_VLSEG2E8V
, match_opcode
, INSN_DREF
},
1112 {"vsseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E8V
, MASK_VSSEG2E8V
, match_opcode
, INSN_DREF
},
1113 {"vlseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E8V
, MASK_VLSEG3E8V
, match_opcode
, INSN_DREF
},
1114 {"vsseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E8V
, MASK_VSSEG3E8V
, match_opcode
, INSN_DREF
},
1115 {"vlseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E8V
, MASK_VLSEG4E8V
, match_opcode
, INSN_DREF
},
1116 {"vsseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E8V
, MASK_VSSEG4E8V
, match_opcode
, INSN_DREF
},
1117 {"vlseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E8V
, MASK_VLSEG5E8V
, match_opcode
, INSN_DREF
},
1118 {"vsseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E8V
, MASK_VSSEG5E8V
, match_opcode
, INSN_DREF
},
1119 {"vlseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E8V
, MASK_VLSEG6E8V
, match_opcode
, INSN_DREF
},
1120 {"vsseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E8V
, MASK_VSSEG6E8V
, match_opcode
, INSN_DREF
},
1121 {"vlseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E8V
, MASK_VLSEG7E8V
, match_opcode
, INSN_DREF
},
1122 {"vsseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E8V
, MASK_VSSEG7E8V
, match_opcode
, INSN_DREF
},
1123 {"vlseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E8V
, MASK_VLSEG8E8V
, match_opcode
, INSN_DREF
},
1124 {"vsseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E8V
, MASK_VSSEG8E8V
, match_opcode
, INSN_DREF
},
1126 {"vlseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E16V
, MASK_VLSEG2E16V
, match_opcode
, INSN_DREF
},
1127 {"vsseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E16V
, MASK_VSSEG2E16V
, match_opcode
, INSN_DREF
},
1128 {"vlseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E16V
, MASK_VLSEG3E16V
, match_opcode
, INSN_DREF
},
1129 {"vsseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E16V
, MASK_VSSEG3E16V
, match_opcode
, INSN_DREF
},
1130 {"vlseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E16V
, MASK_VLSEG4E16V
, match_opcode
, INSN_DREF
},
1131 {"vsseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E16V
, MASK_VSSEG4E16V
, match_opcode
, INSN_DREF
},
1132 {"vlseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E16V
, MASK_VLSEG5E16V
, match_opcode
, INSN_DREF
},
1133 {"vsseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E16V
, MASK_VSSEG5E16V
, match_opcode
, INSN_DREF
},
1134 {"vlseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E16V
, MASK_VLSEG6E16V
, match_opcode
, INSN_DREF
},
1135 {"vsseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E16V
, MASK_VSSEG6E16V
, match_opcode
, INSN_DREF
},
1136 {"vlseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E16V
, MASK_VLSEG7E16V
, match_opcode
, INSN_DREF
},
1137 {"vsseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E16V
, MASK_VSSEG7E16V
, match_opcode
, INSN_DREF
},
1138 {"vlseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E16V
, MASK_VLSEG8E16V
, match_opcode
, INSN_DREF
},
1139 {"vsseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E16V
, MASK_VSSEG8E16V
, match_opcode
, INSN_DREF
},
1141 {"vlseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E32V
, MASK_VLSEG2E32V
, match_opcode
, INSN_DREF
},
1142 {"vsseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E32V
, MASK_VSSEG2E32V
, match_opcode
, INSN_DREF
},
1143 {"vlseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E32V
, MASK_VLSEG3E32V
, match_opcode
, INSN_DREF
},
1144 {"vsseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E32V
, MASK_VSSEG3E32V
, match_opcode
, INSN_DREF
},
1145 {"vlseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E32V
, MASK_VLSEG4E32V
, match_opcode
, INSN_DREF
},
1146 {"vsseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E32V
, MASK_VSSEG4E32V
, match_opcode
, INSN_DREF
},
1147 {"vlseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E32V
, MASK_VLSEG5E32V
, match_opcode
, INSN_DREF
},
1148 {"vsseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E32V
, MASK_VSSEG5E32V
, match_opcode
, INSN_DREF
},
1149 {"vlseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E32V
, MASK_VLSEG6E32V
, match_opcode
, INSN_DREF
},
1150 {"vsseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E32V
, MASK_VSSEG6E32V
, match_opcode
, INSN_DREF
},
1151 {"vlseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E32V
, MASK_VLSEG7E32V
, match_opcode
, INSN_DREF
},
1152 {"vsseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E32V
, MASK_VSSEG7E32V
, match_opcode
, INSN_DREF
},
1153 {"vlseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E32V
, MASK_VLSEG8E32V
, match_opcode
, INSN_DREF
},
1154 {"vsseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E32V
, MASK_VSSEG8E32V
, match_opcode
, INSN_DREF
},
1156 {"vlseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E64V
, MASK_VLSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1157 {"vsseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG2E64V
, MASK_VSSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1158 {"vlseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E64V
, MASK_VLSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1159 {"vsseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG3E64V
, MASK_VSSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1160 {"vlseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E64V
, MASK_VLSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1161 {"vsseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG4E64V
, MASK_VSSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1162 {"vlseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E64V
, MASK_VLSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1163 {"vsseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG5E64V
, MASK_VSSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1164 {"vlseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E64V
, MASK_VLSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1165 {"vsseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG6E64V
, MASK_VSSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1166 {"vlseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E64V
, MASK_VLSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1167 {"vsseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG7E64V
, MASK_VSSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1168 {"vlseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E64V
, MASK_VLSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1169 {"vsseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VSSEG8E64V
, MASK_VSSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1171 {"vlsseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E8V
, MASK_VLSSEG2E8V
, match_opcode
, INSN_DREF
},
1172 {"vssseg2e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E8V
, MASK_VSSSEG2E8V
, match_opcode
, INSN_DREF
},
1173 {"vlsseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E8V
, MASK_VLSSEG3E8V
, match_opcode
, INSN_DREF
},
1174 {"vssseg3e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E8V
, MASK_VSSSEG3E8V
, match_opcode
, INSN_DREF
},
1175 {"vlsseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E8V
, MASK_VLSSEG4E8V
, match_opcode
, INSN_DREF
},
1176 {"vssseg4e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E8V
, MASK_VSSSEG4E8V
, match_opcode
, INSN_DREF
},
1177 {"vlsseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E8V
, MASK_VLSSEG5E8V
, match_opcode
, INSN_DREF
},
1178 {"vssseg5e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E8V
, MASK_VSSSEG5E8V
, match_opcode
, INSN_DREF
},
1179 {"vlsseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E8V
, MASK_VLSSEG6E8V
, match_opcode
, INSN_DREF
},
1180 {"vssseg6e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E8V
, MASK_VSSSEG6E8V
, match_opcode
, INSN_DREF
},
1181 {"vlsseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E8V
, MASK_VLSSEG7E8V
, match_opcode
, INSN_DREF
},
1182 {"vssseg7e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E8V
, MASK_VSSSEG7E8V
, match_opcode
, INSN_DREF
},
1183 {"vlsseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E8V
, MASK_VLSSEG8E8V
, match_opcode
, INSN_DREF
},
1184 {"vssseg8e8.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E8V
, MASK_VSSSEG8E8V
, match_opcode
, INSN_DREF
},
1186 {"vlsseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E16V
, MASK_VLSSEG2E16V
, match_opcode
, INSN_DREF
},
1187 {"vssseg2e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E16V
, MASK_VSSSEG2E16V
, match_opcode
, INSN_DREF
},
1188 {"vlsseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E16V
, MASK_VLSSEG3E16V
, match_opcode
, INSN_DREF
},
1189 {"vssseg3e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E16V
, MASK_VSSSEG3E16V
, match_opcode
, INSN_DREF
},
1190 {"vlsseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E16V
, MASK_VLSSEG4E16V
, match_opcode
, INSN_DREF
},
1191 {"vssseg4e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E16V
, MASK_VSSSEG4E16V
, match_opcode
, INSN_DREF
},
1192 {"vlsseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E16V
, MASK_VLSSEG5E16V
, match_opcode
, INSN_DREF
},
1193 {"vssseg5e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E16V
, MASK_VSSSEG5E16V
, match_opcode
, INSN_DREF
},
1194 {"vlsseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E16V
, MASK_VLSSEG6E16V
, match_opcode
, INSN_DREF
},
1195 {"vssseg6e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E16V
, MASK_VSSSEG6E16V
, match_opcode
, INSN_DREF
},
1196 {"vlsseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E16V
, MASK_VLSSEG7E16V
, match_opcode
, INSN_DREF
},
1197 {"vssseg7e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E16V
, MASK_VSSSEG7E16V
, match_opcode
, INSN_DREF
},
1198 {"vlsseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E16V
, MASK_VLSSEG8E16V
, match_opcode
, INSN_DREF
},
1199 {"vssseg8e16.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E16V
, MASK_VSSSEG8E16V
, match_opcode
, INSN_DREF
},
1201 {"vlsseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E32V
, MASK_VLSSEG2E32V
, match_opcode
, INSN_DREF
},
1202 {"vssseg2e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E32V
, MASK_VSSSEG2E32V
, match_opcode
, INSN_DREF
},
1203 {"vlsseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E32V
, MASK_VLSSEG3E32V
, match_opcode
, INSN_DREF
},
1204 {"vssseg3e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E32V
, MASK_VSSSEG3E32V
, match_opcode
, INSN_DREF
},
1205 {"vlsseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E32V
, MASK_VLSSEG4E32V
, match_opcode
, INSN_DREF
},
1206 {"vssseg4e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E32V
, MASK_VSSSEG4E32V
, match_opcode
, INSN_DREF
},
1207 {"vlsseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E32V
, MASK_VLSSEG5E32V
, match_opcode
, INSN_DREF
},
1208 {"vssseg5e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E32V
, MASK_VSSSEG5E32V
, match_opcode
, INSN_DREF
},
1209 {"vlsseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E32V
, MASK_VLSSEG6E32V
, match_opcode
, INSN_DREF
},
1210 {"vssseg6e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E32V
, MASK_VSSSEG6E32V
, match_opcode
, INSN_DREF
},
1211 {"vlsseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E32V
, MASK_VLSSEG7E32V
, match_opcode
, INSN_DREF
},
1212 {"vssseg7e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E32V
, MASK_VSSSEG7E32V
, match_opcode
, INSN_DREF
},
1213 {"vlsseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E32V
, MASK_VLSSEG8E32V
, match_opcode
, INSN_DREF
},
1214 {"vssseg8e32.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E32V
, MASK_VSSSEG8E32V
, match_opcode
, INSN_DREF
},
1216 {"vlsseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG2E64V
, MASK_VLSSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1217 {"vssseg2e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG2E64V
, MASK_VSSSEG2E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1218 {"vlsseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG3E64V
, MASK_VLSSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1219 {"vssseg3e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG3E64V
, MASK_VSSSEG3E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1220 {"vlsseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG4E64V
, MASK_VLSSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1221 {"vssseg4e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG4E64V
, MASK_VSSSEG4E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1222 {"vlsseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG5E64V
, MASK_VLSSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1223 {"vssseg5e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG5E64V
, MASK_VSSSEG5E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1224 {"vlsseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG6E64V
, MASK_VLSSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1225 {"vssseg6e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG6E64V
, MASK_VSSSEG6E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1226 {"vlsseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG7E64V
, MASK_VLSSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1227 {"vssseg7e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG7E64V
, MASK_VSSSEG7E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1228 {"vlsseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VLSSEG8E64V
, MASK_VLSSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1229 {"vssseg8e64.v", 0, INSN_CLASS_V
, "Vd,0(s),tVm", MATCH_VSSSEG8E64V
, MASK_VSSSEG8E64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1231 {"vloxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI8V
, MASK_VLOXSEG2EI8V
, match_opcode
, INSN_DREF
},
1232 {"vsoxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI8V
, MASK_VSOXSEG2EI8V
, match_opcode
, INSN_DREF
},
1233 {"vloxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI8V
, MASK_VLOXSEG3EI8V
, match_opcode
, INSN_DREF
},
1234 {"vsoxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI8V
, MASK_VSOXSEG3EI8V
, match_opcode
, INSN_DREF
},
1235 {"vloxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI8V
, MASK_VLOXSEG4EI8V
, match_opcode
, INSN_DREF
},
1236 {"vsoxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI8V
, MASK_VSOXSEG4EI8V
, match_opcode
, INSN_DREF
},
1237 {"vloxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI8V
, MASK_VLOXSEG5EI8V
, match_opcode
, INSN_DREF
},
1238 {"vsoxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI8V
, MASK_VSOXSEG5EI8V
, match_opcode
, INSN_DREF
},
1239 {"vloxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI8V
, MASK_VLOXSEG6EI8V
, match_opcode
, INSN_DREF
},
1240 {"vsoxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI8V
, MASK_VSOXSEG6EI8V
, match_opcode
, INSN_DREF
},
1241 {"vloxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI8V
, MASK_VLOXSEG7EI8V
, match_opcode
, INSN_DREF
},
1242 {"vsoxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI8V
, MASK_VSOXSEG7EI8V
, match_opcode
, INSN_DREF
},
1243 {"vloxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI8V
, MASK_VLOXSEG8EI8V
, match_opcode
, INSN_DREF
},
1244 {"vsoxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI8V
, MASK_VSOXSEG8EI8V
, match_opcode
, INSN_DREF
},
1246 {"vloxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI16V
, MASK_VLOXSEG2EI16V
, match_opcode
, INSN_DREF
},
1247 {"vsoxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI16V
, MASK_VSOXSEG2EI16V
, match_opcode
, INSN_DREF
},
1248 {"vloxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI16V
, MASK_VLOXSEG3EI16V
, match_opcode
, INSN_DREF
},
1249 {"vsoxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI16V
, MASK_VSOXSEG3EI16V
, match_opcode
, INSN_DREF
},
1250 {"vloxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI16V
, MASK_VLOXSEG4EI16V
, match_opcode
, INSN_DREF
},
1251 {"vsoxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI16V
, MASK_VSOXSEG4EI16V
, match_opcode
, INSN_DREF
},
1252 {"vloxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI16V
, MASK_VLOXSEG5EI16V
, match_opcode
, INSN_DREF
},
1253 {"vsoxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI16V
, MASK_VSOXSEG5EI16V
, match_opcode
, INSN_DREF
},
1254 {"vloxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI16V
, MASK_VLOXSEG6EI16V
, match_opcode
, INSN_DREF
},
1255 {"vsoxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI16V
, MASK_VSOXSEG6EI16V
, match_opcode
, INSN_DREF
},
1256 {"vloxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI16V
, MASK_VLOXSEG7EI16V
, match_opcode
, INSN_DREF
},
1257 {"vsoxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI16V
, MASK_VSOXSEG7EI16V
, match_opcode
, INSN_DREF
},
1258 {"vloxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI16V
, MASK_VLOXSEG8EI16V
, match_opcode
, INSN_DREF
},
1259 {"vsoxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI16V
, MASK_VSOXSEG8EI16V
, match_opcode
, INSN_DREF
},
1261 {"vloxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI32V
, MASK_VLOXSEG2EI32V
, match_opcode
, INSN_DREF
},
1262 {"vsoxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI32V
, MASK_VSOXSEG2EI32V
, match_opcode
, INSN_DREF
},
1263 {"vloxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI32V
, MASK_VLOXSEG3EI32V
, match_opcode
, INSN_DREF
},
1264 {"vsoxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI32V
, MASK_VSOXSEG3EI32V
, match_opcode
, INSN_DREF
},
1265 {"vloxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI32V
, MASK_VLOXSEG4EI32V
, match_opcode
, INSN_DREF
},
1266 {"vsoxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI32V
, MASK_VSOXSEG4EI32V
, match_opcode
, INSN_DREF
},
1267 {"vloxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI32V
, MASK_VLOXSEG5EI32V
, match_opcode
, INSN_DREF
},
1268 {"vsoxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI32V
, MASK_VSOXSEG5EI32V
, match_opcode
, INSN_DREF
},
1269 {"vloxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI32V
, MASK_VLOXSEG6EI32V
, match_opcode
, INSN_DREF
},
1270 {"vsoxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI32V
, MASK_VSOXSEG6EI32V
, match_opcode
, INSN_DREF
},
1271 {"vloxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI32V
, MASK_VLOXSEG7EI32V
, match_opcode
, INSN_DREF
},
1272 {"vsoxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI32V
, MASK_VSOXSEG7EI32V
, match_opcode
, INSN_DREF
},
1273 {"vloxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI32V
, MASK_VLOXSEG8EI32V
, match_opcode
, INSN_DREF
},
1274 {"vsoxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI32V
, MASK_VSOXSEG8EI32V
, match_opcode
, INSN_DREF
},
1276 {"vloxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG2EI64V
, MASK_VLOXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1277 {"vsoxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG2EI64V
, MASK_VSOXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1278 {"vloxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG3EI64V
, MASK_VLOXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1279 {"vsoxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG3EI64V
, MASK_VSOXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1280 {"vloxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG4EI64V
, MASK_VLOXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1281 {"vsoxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG4EI64V
, MASK_VSOXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1282 {"vloxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG5EI64V
, MASK_VLOXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1283 {"vsoxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG5EI64V
, MASK_VSOXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1284 {"vloxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG6EI64V
, MASK_VLOXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1285 {"vsoxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG6EI64V
, MASK_VSOXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1286 {"vloxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG7EI64V
, MASK_VLOXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1287 {"vsoxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG7EI64V
, MASK_VSOXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1288 {"vloxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLOXSEG8EI64V
, MASK_VLOXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1289 {"vsoxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSOXSEG8EI64V
, MASK_VSOXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1291 {"vluxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI8V
, MASK_VLUXSEG2EI8V
, match_opcode
, INSN_DREF
},
1292 {"vsuxseg2ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI8V
, MASK_VSUXSEG2EI8V
, match_opcode
, INSN_DREF
},
1293 {"vluxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI8V
, MASK_VLUXSEG3EI8V
, match_opcode
, INSN_DREF
},
1294 {"vsuxseg3ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI8V
, MASK_VSUXSEG3EI8V
, match_opcode
, INSN_DREF
},
1295 {"vluxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI8V
, MASK_VLUXSEG4EI8V
, match_opcode
, INSN_DREF
},
1296 {"vsuxseg4ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI8V
, MASK_VSUXSEG4EI8V
, match_opcode
, INSN_DREF
},
1297 {"vluxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI8V
, MASK_VLUXSEG5EI8V
, match_opcode
, INSN_DREF
},
1298 {"vsuxseg5ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI8V
, MASK_VSUXSEG5EI8V
, match_opcode
, INSN_DREF
},
1299 {"vluxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI8V
, MASK_VLUXSEG6EI8V
, match_opcode
, INSN_DREF
},
1300 {"vsuxseg6ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI8V
, MASK_VSUXSEG6EI8V
, match_opcode
, INSN_DREF
},
1301 {"vluxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI8V
, MASK_VLUXSEG7EI8V
, match_opcode
, INSN_DREF
},
1302 {"vsuxseg7ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI8V
, MASK_VSUXSEG7EI8V
, match_opcode
, INSN_DREF
},
1303 {"vluxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI8V
, MASK_VLUXSEG8EI8V
, match_opcode
, INSN_DREF
},
1304 {"vsuxseg8ei8.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI8V
, MASK_VSUXSEG8EI8V
, match_opcode
, INSN_DREF
},
1306 {"vluxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI16V
, MASK_VLUXSEG2EI16V
, match_opcode
, INSN_DREF
},
1307 {"vsuxseg2ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI16V
, MASK_VSUXSEG2EI16V
, match_opcode
, INSN_DREF
},
1308 {"vluxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI16V
, MASK_VLUXSEG3EI16V
, match_opcode
, INSN_DREF
},
1309 {"vsuxseg3ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI16V
, MASK_VSUXSEG3EI16V
, match_opcode
, INSN_DREF
},
1310 {"vluxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI16V
, MASK_VLUXSEG4EI16V
, match_opcode
, INSN_DREF
},
1311 {"vsuxseg4ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI16V
, MASK_VSUXSEG4EI16V
, match_opcode
, INSN_DREF
},
1312 {"vluxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI16V
, MASK_VLUXSEG5EI16V
, match_opcode
, INSN_DREF
},
1313 {"vsuxseg5ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI16V
, MASK_VSUXSEG5EI16V
, match_opcode
, INSN_DREF
},
1314 {"vluxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI16V
, MASK_VLUXSEG6EI16V
, match_opcode
, INSN_DREF
},
1315 {"vsuxseg6ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI16V
, MASK_VSUXSEG6EI16V
, match_opcode
, INSN_DREF
},
1316 {"vluxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI16V
, MASK_VLUXSEG7EI16V
, match_opcode
, INSN_DREF
},
1317 {"vsuxseg7ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI16V
, MASK_VSUXSEG7EI16V
, match_opcode
, INSN_DREF
},
1318 {"vluxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI16V
, MASK_VLUXSEG8EI16V
, match_opcode
, INSN_DREF
},
1319 {"vsuxseg8ei16.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI16V
, MASK_VSUXSEG8EI16V
, match_opcode
, INSN_DREF
},
1321 {"vluxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI32V
, MASK_VLUXSEG2EI32V
, match_opcode
, INSN_DREF
},
1322 {"vsuxseg2ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI32V
, MASK_VSUXSEG2EI32V
, match_opcode
, INSN_DREF
},
1323 {"vluxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI32V
, MASK_VLUXSEG3EI32V
, match_opcode
, INSN_DREF
},
1324 {"vsuxseg3ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI32V
, MASK_VSUXSEG3EI32V
, match_opcode
, INSN_DREF
},
1325 {"vluxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI32V
, MASK_VLUXSEG4EI32V
, match_opcode
, INSN_DREF
},
1326 {"vsuxseg4ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI32V
, MASK_VSUXSEG4EI32V
, match_opcode
, INSN_DREF
},
1327 {"vluxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI32V
, MASK_VLUXSEG5EI32V
, match_opcode
, INSN_DREF
},
1328 {"vsuxseg5ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI32V
, MASK_VSUXSEG5EI32V
, match_opcode
, INSN_DREF
},
1329 {"vluxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI32V
, MASK_VLUXSEG6EI32V
, match_opcode
, INSN_DREF
},
1330 {"vsuxseg6ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI32V
, MASK_VSUXSEG6EI32V
, match_opcode
, INSN_DREF
},
1331 {"vluxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI32V
, MASK_VLUXSEG7EI32V
, match_opcode
, INSN_DREF
},
1332 {"vsuxseg7ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI32V
, MASK_VSUXSEG7EI32V
, match_opcode
, INSN_DREF
},
1333 {"vluxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI32V
, MASK_VLUXSEG8EI32V
, match_opcode
, INSN_DREF
},
1334 {"vsuxseg8ei32.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI32V
, MASK_VSUXSEG8EI32V
, match_opcode
, INSN_DREF
},
1336 {"vluxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG2EI64V
, MASK_VLUXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1337 {"vsuxseg2ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG2EI64V
, MASK_VSUXSEG2EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1338 {"vluxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG3EI64V
, MASK_VLUXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1339 {"vsuxseg3ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG3EI64V
, MASK_VSUXSEG3EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1340 {"vluxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG4EI64V
, MASK_VLUXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1341 {"vsuxseg4ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG4EI64V
, MASK_VSUXSEG4EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1342 {"vluxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG5EI64V
, MASK_VLUXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1343 {"vsuxseg5ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG5EI64V
, MASK_VSUXSEG5EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1344 {"vluxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG6EI64V
, MASK_VLUXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1345 {"vsuxseg6ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG6EI64V
, MASK_VSUXSEG6EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1346 {"vluxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG7EI64V
, MASK_VLUXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1347 {"vsuxseg7ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG7EI64V
, MASK_VSUXSEG7EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1348 {"vluxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VLUXSEG8EI64V
, MASK_VLUXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1349 {"vsuxseg8ei64.v", 0, INSN_CLASS_V
, "Vd,0(s),VtVm", MATCH_VSUXSEG8EI64V
, MASK_VSUXSEG8EI64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1351 {"vlseg2e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E8FFV
, MASK_VLSEG2E8FFV
, match_opcode
, INSN_DREF
},
1352 {"vlseg3e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E8FFV
, MASK_VLSEG3E8FFV
, match_opcode
, INSN_DREF
},
1353 {"vlseg4e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E8FFV
, MASK_VLSEG4E8FFV
, match_opcode
, INSN_DREF
},
1354 {"vlseg5e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E8FFV
, MASK_VLSEG5E8FFV
, match_opcode
, INSN_DREF
},
1355 {"vlseg6e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E8FFV
, MASK_VLSEG6E8FFV
, match_opcode
, INSN_DREF
},
1356 {"vlseg7e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E8FFV
, MASK_VLSEG7E8FFV
, match_opcode
, INSN_DREF
},
1357 {"vlseg8e8ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E8FFV
, MASK_VLSEG8E8FFV
, match_opcode
, INSN_DREF
},
1359 {"vlseg2e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E16FFV
, MASK_VLSEG2E16FFV
, match_opcode
, INSN_DREF
},
1360 {"vlseg3e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E16FFV
, MASK_VLSEG3E16FFV
, match_opcode
, INSN_DREF
},
1361 {"vlseg4e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E16FFV
, MASK_VLSEG4E16FFV
, match_opcode
, INSN_DREF
},
1362 {"vlseg5e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E16FFV
, MASK_VLSEG5E16FFV
, match_opcode
, INSN_DREF
},
1363 {"vlseg6e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E16FFV
, MASK_VLSEG6E16FFV
, match_opcode
, INSN_DREF
},
1364 {"vlseg7e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E16FFV
, MASK_VLSEG7E16FFV
, match_opcode
, INSN_DREF
},
1365 {"vlseg8e16ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E16FFV
, MASK_VLSEG8E16FFV
, match_opcode
, INSN_DREF
},
1367 {"vlseg2e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E32FFV
, MASK_VLSEG2E32FFV
, match_opcode
, INSN_DREF
},
1368 {"vlseg3e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E32FFV
, MASK_VLSEG3E32FFV
, match_opcode
, INSN_DREF
},
1369 {"vlseg4e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E32FFV
, MASK_VLSEG4E32FFV
, match_opcode
, INSN_DREF
},
1370 {"vlseg5e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E32FFV
, MASK_VLSEG5E32FFV
, match_opcode
, INSN_DREF
},
1371 {"vlseg6e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E32FFV
, MASK_VLSEG6E32FFV
, match_opcode
, INSN_DREF
},
1372 {"vlseg7e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E32FFV
, MASK_VLSEG7E32FFV
, match_opcode
, INSN_DREF
},
1373 {"vlseg8e32ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E32FFV
, MASK_VLSEG8E32FFV
, match_opcode
, INSN_DREF
},
1375 {"vlseg2e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG2E64FFV
, MASK_VLSEG2E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1376 {"vlseg3e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG3E64FFV
, MASK_VLSEG3E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1377 {"vlseg4e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG4E64FFV
, MASK_VLSEG4E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1378 {"vlseg5e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG5E64FFV
, MASK_VLSEG5E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1379 {"vlseg6e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG6E64FFV
, MASK_VLSEG6E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1380 {"vlseg7e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG7E64FFV
, MASK_VLSEG7E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1381 {"vlseg8e64ff.v", 0, INSN_CLASS_V
, "Vd,0(s)Vm", MATCH_VLSEG8E64FFV
, MASK_VLSEG8E64FFV
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1383 {"vl1r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE8V
, MASK_VL1RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1384 {"vl1re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE8V
, MASK_VL1RE8V
, match_opcode
, INSN_DREF
},
1385 {"vl1re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE16V
, MASK_VL1RE16V
, match_opcode
, INSN_DREF
},
1386 {"vl1re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE32V
, MASK_VL1RE32V
, match_opcode
, INSN_DREF
},
1387 {"vl1re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL1RE64V
, MASK_VL1RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1389 {"vl2r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE8V
, MASK_VL2RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1390 {"vl2re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE8V
, MASK_VL2RE8V
, match_opcode
, INSN_DREF
},
1391 {"vl2re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE16V
, MASK_VL2RE16V
, match_opcode
, INSN_DREF
},
1392 {"vl2re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE32V
, MASK_VL2RE32V
, match_opcode
, INSN_DREF
},
1393 {"vl2re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL2RE64V
, MASK_VL2RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1395 {"vl4r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE8V
, MASK_VL4RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1396 {"vl4re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE8V
, MASK_VL4RE8V
, match_opcode
, INSN_DREF
},
1397 {"vl4re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE16V
, MASK_VL4RE16V
, match_opcode
, INSN_DREF
},
1398 {"vl4re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE32V
, MASK_VL4RE32V
, match_opcode
, INSN_DREF
},
1399 {"vl4re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL4RE64V
, MASK_VL4RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1401 {"vl8r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE8V
, MASK_VL8RE8V
, match_opcode
, INSN_DREF
|INSN_ALIAS
},
1402 {"vl8re8.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE8V
, MASK_VL8RE8V
, match_opcode
, INSN_DREF
},
1403 {"vl8re16.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE16V
, MASK_VL8RE16V
, match_opcode
, INSN_DREF
},
1404 {"vl8re32.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE32V
, MASK_VL8RE32V
, match_opcode
, INSN_DREF
},
1405 {"vl8re64.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VL8RE64V
, MASK_VL8RE64V
, match_opcode
, INSN_DREF
|INSN_V_EEW64
},
1407 {"vs1r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS1RV
, MASK_VS1RV
, match_opcode
, INSN_DREF
},
1408 {"vs2r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS2RV
, MASK_VS2RV
, match_opcode
, INSN_DREF
},
1409 {"vs4r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS4RV
, MASK_VS4RV
, match_opcode
, INSN_DREF
},
1410 {"vs8r.v", 0, INSN_CLASS_V
, "Vd,0(s)", MATCH_VS8RV
, MASK_VS8RV
, match_opcode
, INSN_DREF
},
1412 {"vneg.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VRSUBVX
, MASK_VRSUBVX
| MASK_RS1
, match_opcode
, INSN_ALIAS
},
1414 {"vadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VADDVV
, MASK_VADDVV
, match_opcode
, 0 },
1415 {"vadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VADDVX
, MASK_VADDVX
, match_opcode
, 0 },
1416 {"vadd.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VADDVI
, MASK_VADDVI
, match_opcode
, 0 },
1417 {"vsub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSUBVV
, MASK_VSUBVV
, match_opcode
, 0 },
1418 {"vsub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSUBVX
, MASK_VSUBVX
, match_opcode
, 0 },
1419 {"vrsub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VRSUBVX
, MASK_VRSUBVX
, match_opcode
, 0 },
1420 {"vrsub.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VRSUBVI
, MASK_VRSUBVI
, match_opcode
, 0 },
1422 {"vwcvt.x.x.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VWCVTXXV
, MASK_VWCVTXXV
, match_opcode
, INSN_ALIAS
},
1423 {"vwcvtu.x.x.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VWCVTUXXV
, MASK_VWCVTUXXV
, match_opcode
, INSN_ALIAS
},
1425 {"vwaddu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDUVV
, MASK_VWADDUVV
, match_opcode
, 0 },
1426 {"vwaddu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDUVX
, MASK_VWADDUVX
, match_opcode
, 0 },
1427 {"vwsubu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBUVV
, MASK_VWSUBUVV
, match_opcode
, 0 },
1428 {"vwsubu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBUVX
, MASK_VWSUBUVX
, match_opcode
, 0 },
1429 {"vwadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDVV
, MASK_VWADDVV
, match_opcode
, 0 },
1430 {"vwadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDVX
, MASK_VWADDVX
, match_opcode
, 0 },
1431 {"vwsub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBVV
, MASK_VWSUBVV
, match_opcode
, 0 },
1432 {"vwsub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBVX
, MASK_VWSUBVX
, match_opcode
, 0 },
1433 {"vwaddu.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDUWV
, MASK_VWADDUWV
, match_opcode
, 0 },
1434 {"vwaddu.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDUWX
, MASK_VWADDUWX
, match_opcode
, 0 },
1435 {"vwsubu.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBUWV
, MASK_VWSUBUWV
, match_opcode
, 0 },
1436 {"vwsubu.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBUWX
, MASK_VWSUBUWX
, match_opcode
, 0 },
1437 {"vwadd.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWADDWV
, MASK_VWADDWV
, match_opcode
, 0 },
1438 {"vwadd.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWADDWX
, MASK_VWADDWX
, match_opcode
, 0 },
1439 {"vwsub.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWSUBWV
, MASK_VWSUBWV
, match_opcode
, 0 },
1440 {"vwsub.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWSUBWX
, MASK_VWSUBWX
, match_opcode
, 0 },
1442 {"vzext.vf2", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VZEXT_VF2
, MASK_VZEXT_VF2
, match_opcode
, 0 },
1443 {"vsext.vf2", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VSEXT_VF2
, MASK_VSEXT_VF2
, match_opcode
, 0 },
1444 {"vzext.vf4", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VZEXT_VF4
, MASK_VZEXT_VF4
, match_opcode
, 0 },
1445 {"vsext.vf4", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VSEXT_VF4
, MASK_VSEXT_VF4
, match_opcode
, 0 },
1446 {"vzext.vf8", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VZEXT_VF8
, MASK_VZEXT_VF8
, match_opcode
, 0 },
1447 {"vsext.vf8", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VSEXT_VF8
, MASK_VSEXT_VF8
, match_opcode
, 0 },
1449 {"vadc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VADCVVM
, MASK_VADCVVM
, match_opcode
, 0 },
1450 {"vadc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VADCVXM
, MASK_VADCVXM
, match_opcode
, 0 },
1451 {"vadc.vim", 0, INSN_CLASS_V
, "Vd,Vt,Vi,V0", MATCH_VADCVIM
, MASK_VADCVIM
, match_opcode
, 0 },
1452 {"vmadc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VMADCVVM
, MASK_VMADCVVM
, match_opcode
, 0 },
1453 {"vmadc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VMADCVXM
, MASK_VMADCVXM
, match_opcode
, 0 },
1454 {"vmadc.vim", 0, INSN_CLASS_V
, "Vd,Vt,Vi,V0", MATCH_VMADCVIM
, MASK_VMADCVIM
, match_opcode
, 0 },
1455 {"vmadc.vv", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMADCVV
, MASK_VMADCVV
, match_opcode
, 0 },
1456 {"vmadc.vx", 0, INSN_CLASS_V
, "Vd,Vt,s", MATCH_VMADCVX
, MASK_VMADCVX
, match_opcode
, 0 },
1457 {"vmadc.vi", 0, INSN_CLASS_V
, "Vd,Vt,Vi", MATCH_VMADCVI
, MASK_VMADCVI
, match_opcode
, 0 },
1458 {"vsbc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VSBCVVM
, MASK_VSBCVVM
, match_opcode
, 0 },
1459 {"vsbc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VSBCVXM
, MASK_VSBCVXM
, match_opcode
, 0 },
1460 {"vmsbc.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VMSBCVVM
, MASK_VMSBCVVM
, match_opcode
, 0 },
1461 {"vmsbc.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VMSBCVXM
, MASK_VMSBCVXM
, match_opcode
, 0 },
1462 {"vmsbc.vv", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMSBCVV
, MASK_VMSBCVV
, match_opcode
, 0 },
1463 {"vmsbc.vx", 0, INSN_CLASS_V
, "Vd,Vt,s", MATCH_VMSBCVX
, MASK_VMSBCVX
, match_opcode
, 0 },
1465 {"vnot.v", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VNOTV
, MASK_VNOTV
, match_opcode
, INSN_ALIAS
},
1467 {"vand.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VANDVV
, MASK_VANDVV
, match_opcode
, 0 },
1468 {"vand.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VANDVX
, MASK_VANDVX
, match_opcode
, 0 },
1469 {"vand.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VANDVI
, MASK_VANDVI
, match_opcode
, 0 },
1470 {"vor.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VORVV
, MASK_VORVV
, match_opcode
, 0 },
1471 {"vor.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VORVX
, MASK_VORVX
, match_opcode
, 0 },
1472 {"vor.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VORVI
, MASK_VORVI
, match_opcode
, 0 },
1473 {"vxor.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VXORVV
, MASK_VXORVV
, match_opcode
, 0 },
1474 {"vxor.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VXORVX
, MASK_VXORVX
, match_opcode
, 0 },
1475 {"vxor.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VXORVI
, MASK_VXORVI
, match_opcode
, 0 },
1477 {"vsll.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSLLVV
, MASK_VSLLVV
, match_opcode
, 0 },
1478 {"vsll.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLLVX
, MASK_VSLLVX
, match_opcode
, 0 },
1479 {"vsll.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSLLVI
, MASK_VSLLVI
, match_opcode
, 0 },
1480 {"vsrl.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSRLVV
, MASK_VSRLVV
, match_opcode
, 0 },
1481 {"vsrl.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSRLVX
, MASK_VSRLVX
, match_opcode
, 0 },
1482 {"vsrl.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSRLVI
, MASK_VSRLVI
, match_opcode
, 0 },
1483 {"vsra.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSRAVV
, MASK_VSRAVV
, match_opcode
, 0 },
1484 {"vsra.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSRAVX
, MASK_VSRAVX
, match_opcode
, 0 },
1485 {"vsra.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSRAVI
, MASK_VSRAVI
, match_opcode
, 0 },
1487 {"vncvt.x.x.w",0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VNCVTXXW
, MASK_VNCVTXXW
, match_opcode
, INSN_ALIAS
},
1489 {"vnsrl.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNSRLWV
, MASK_VNSRLWV
, match_opcode
, 0 },
1490 {"vnsrl.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNSRLWX
, MASK_VNSRLWX
, match_opcode
, 0 },
1491 {"vnsrl.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNSRLWI
, MASK_VNSRLWI
, match_opcode
, 0 },
1492 {"vnsra.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNSRAWV
, MASK_VNSRAWV
, match_opcode
, 0 },
1493 {"vnsra.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNSRAWX
, MASK_VNSRAWX
, match_opcode
, 0 },
1494 {"vnsra.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNSRAWI
, MASK_VNSRAWI
, match_opcode
, 0 },
1496 {"vmseq.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSEQVV
, MASK_VMSEQVV
, match_opcode
, 0 },
1497 {"vmseq.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSEQVX
, MASK_VMSEQVX
, match_opcode
, 0 },
1498 {"vmseq.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSEQVI
, MASK_VMSEQVI
, match_opcode
, 0 },
1499 {"vmsne.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSNEVV
, MASK_VMSNEVV
, match_opcode
, 0 },
1500 {"vmsne.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSNEVX
, MASK_VMSNEVX
, match_opcode
, 0 },
1501 {"vmsne.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSNEVI
, MASK_VMSNEVI
, match_opcode
, 0 },
1502 {"vmsltu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLTUVV
, MASK_VMSLTUVV
, match_opcode
, 0 },
1503 {"vmsltu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLTUVX
, MASK_VMSLTUVX
, match_opcode
, 0 },
1504 {"vmslt.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLTVV
, MASK_VMSLTVV
, match_opcode
, 0 },
1505 {"vmslt.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLTVX
, MASK_VMSLTVX
, match_opcode
, 0 },
1506 {"vmsleu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLEUVV
, MASK_VMSLEUVV
, match_opcode
, 0 },
1507 {"vmsleu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLEUVX
, MASK_VMSLEUVX
, match_opcode
, 0 },
1508 {"vmsleu.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSLEUVI
, MASK_VMSLEUVI
, match_opcode
, 0 },
1509 {"vmsle.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMSLEVV
, MASK_VMSLEVV
, match_opcode
, 0 },
1510 {"vmsle.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSLEVX
, MASK_VMSLEVX
, match_opcode
, 0 },
1511 {"vmsle.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSLEVI
, MASK_VMSLEVI
, match_opcode
, 0 },
1512 {"vmsgtu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSGTUVX
, MASK_VMSGTUVX
, match_opcode
, 0 },
1513 {"vmsgtu.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSGTUVI
, MASK_VMSGTUVI
, match_opcode
, 0 },
1514 {"vmsgt.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMSGTVX
, MASK_VMSGTVX
, match_opcode
, 0 },
1515 {"vmsgt.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VMSGTVI
, MASK_VMSGTVI
, match_opcode
, 0 },
1516 {"vmsgt.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLTVV
, MASK_VMSLTVV
, match_opcode
, INSN_ALIAS
},
1517 {"vmsgtu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLTUVV
, MASK_VMSLTUVV
, match_opcode
, INSN_ALIAS
},
1518 {"vmsge.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLEVV
, MASK_VMSLEVV
, match_opcode
, INSN_ALIAS
},
1519 {"vmsgeu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMSLEUVV
, MASK_VMSLEUVV
, match_opcode
, INSN_ALIAS
},
1520 {"vmslt.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSLEVI
, MASK_VMSLEVI
, match_opcode
, INSN_ALIAS
},
1521 {"vmsltu.vi", 0, INSN_CLASS_V
, "Vd,Vu,0Vm", MATCH_VMSNEVV
, MASK_VMSNEVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1522 {"vmsltu.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSLEUVI
, MASK_VMSLEUVI
, match_opcode
, INSN_ALIAS
},
1523 {"vmsge.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSGTVI
, MASK_VMSGTVI
, match_opcode
, INSN_ALIAS
},
1524 {"vmsgeu.vi", 0, INSN_CLASS_V
, "Vd,Vu,0Vm", MATCH_VMSEQVV
, MASK_VMSEQVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1525 {"vmsgeu.vi", 0, INSN_CLASS_V
, "Vd,Vt,VkVm", MATCH_VMSGTUVI
, MASK_VMSGTUVI
, match_opcode
, INSN_ALIAS
},
1527 {"vmsge.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", 0, (int) M_VMSGE
, match_opcode
, INSN_MACRO
},
1528 {"vmsge.vx", 0, INSN_CLASS_V
, "Vd,Vt,s,VM,VT", 0, (int) M_VMSGE
, match_opcode
, INSN_MACRO
},
1529 {"vmsgeu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", 0, (int) M_VMSGEU
, match_opcode
, INSN_MACRO
},
1530 {"vmsgeu.vx", 0, INSN_CLASS_V
, "Vd,Vt,s,VM,VT", 0, (int) M_VMSGEU
, match_opcode
, INSN_MACRO
},
1532 {"vminu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMINUVV
, MASK_VMINUVV
, match_opcode
, 0},
1533 {"vminu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMINUVX
, MASK_VMINUVX
, match_opcode
, 0},
1534 {"vmin.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMINVV
, MASK_VMINVV
, match_opcode
, 0},
1535 {"vmin.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMINVX
, MASK_VMINVX
, match_opcode
, 0},
1536 {"vmaxu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMAXUVV
, MASK_VMAXUVV
, match_opcode
, 0},
1537 {"vmaxu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMAXUVX
, MASK_VMAXUVX
, match_opcode
, 0},
1538 {"vmax.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMAXVV
, MASK_VMAXVV
, match_opcode
, 0},
1539 {"vmax.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMAXVX
, MASK_VMAXVX
, match_opcode
, 0},
1541 {"vmul.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULVV
, MASK_VMULVV
, match_opcode
, 0 },
1542 {"vmul.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULVX
, MASK_VMULVX
, match_opcode
, 0 },
1543 {"vmulh.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULHVV
, MASK_VMULHVV
, match_opcode
, 0 },
1544 {"vmulh.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULHVX
, MASK_VMULHVX
, match_opcode
, 0 },
1545 {"vmulhu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULHUVV
, MASK_VMULHUVV
, match_opcode
, 0 },
1546 {"vmulhu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULHUVX
, MASK_VMULHUVX
, match_opcode
, 0 },
1547 {"vmulhsu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VMULHSUVV
, MASK_VMULHSUVV
, match_opcode
, 0 },
1548 {"vmulhsu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VMULHSUVX
, MASK_VMULHSUVX
, match_opcode
, 0 },
1550 {"vwmul.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWMULVV
, MASK_VWMULVV
, match_opcode
, 0 },
1551 {"vwmul.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWMULVX
, MASK_VWMULVX
, match_opcode
, 0 },
1552 {"vwmulu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWMULUVV
, MASK_VWMULUVV
, match_opcode
, 0 },
1553 {"vwmulu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWMULUVX
, MASK_VWMULUVX
, match_opcode
, 0 },
1554 {"vwmulsu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWMULSUVV
, MASK_VWMULSUVV
, match_opcode
, 0 },
1555 {"vwmulsu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VWMULSUVX
, MASK_VWMULSUVX
, match_opcode
, 0 },
1557 {"vmacc.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMACCVV
, MASK_VMACCVV
, match_opcode
, 0},
1558 {"vmacc.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VMACCVX
, MASK_VMACCVX
, match_opcode
, 0},
1559 {"vnmsac.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VNMSACVV
, MASK_VNMSACVV
, match_opcode
, 0},
1560 {"vnmsac.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VNMSACVX
, MASK_VNMSACVX
, match_opcode
, 0},
1561 {"vmadd.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VMADDVV
, MASK_VMADDVV
, match_opcode
, 0},
1562 {"vmadd.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VMADDVX
, MASK_VMADDVX
, match_opcode
, 0},
1563 {"vnmsub.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VNMSUBVV
, MASK_VNMSUBVV
, match_opcode
, 0},
1564 {"vnmsub.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VNMSUBVX
, MASK_VNMSUBVX
, match_opcode
, 0},
1566 {"vwmaccu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VWMACCUVV
, MASK_VWMACCUVV
, match_opcode
, 0},
1567 {"vwmaccu.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCUVX
, MASK_VWMACCUVX
, match_opcode
, 0},
1568 {"vwmacc.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VWMACCVV
, MASK_VWMACCVV
, match_opcode
, 0},
1569 {"vwmacc.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCVX
, MASK_VWMACCVX
, match_opcode
, 0},
1570 {"vwmaccsu.vv", 0, INSN_CLASS_V
, "Vd,Vs,VtVm", MATCH_VWMACCSUVV
, MASK_VWMACCSUVV
, match_opcode
, 0},
1571 {"vwmaccsu.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCSUVX
, MASK_VWMACCSUVX
, match_opcode
, 0},
1572 {"vwmaccus.vx", 0, INSN_CLASS_V
, "Vd,s,VtVm", MATCH_VWMACCUSVX
, MASK_VWMACCUSVX
, match_opcode
, 0},
1574 {"vdivu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VDIVUVV
, MASK_VDIVUVV
, match_opcode
, 0 },
1575 {"vdivu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VDIVUVX
, MASK_VDIVUVX
, match_opcode
, 0 },
1576 {"vdiv.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VDIVVV
, MASK_VDIVVV
, match_opcode
, 0 },
1577 {"vdiv.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VDIVVX
, MASK_VDIVVX
, match_opcode
, 0 },
1578 {"vremu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREMUVV
, MASK_VREMUVV
, match_opcode
, 0 },
1579 {"vremu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VREMUVX
, MASK_VREMUVX
, match_opcode
, 0 },
1580 {"vrem.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREMVV
, MASK_VREMVV
, match_opcode
, 0 },
1581 {"vrem.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VREMVX
, MASK_VREMVX
, match_opcode
, 0 },
1583 {"vmerge.vvm", 0, INSN_CLASS_V
, "Vd,Vt,Vs,V0", MATCH_VMERGEVVM
, MASK_VMERGEVVM
, match_opcode
, 0 },
1584 {"vmerge.vxm", 0, INSN_CLASS_V
, "Vd,Vt,s,V0", MATCH_VMERGEVXM
, MASK_VMERGEVXM
, match_opcode
, 0 },
1585 {"vmerge.vim", 0, INSN_CLASS_V
, "Vd,Vt,Vi,V0", MATCH_VMERGEVIM
, MASK_VMERGEVIM
, match_opcode
, 0 },
1587 {"vmv.v.v", 0, INSN_CLASS_V
, "Vd,Vs", MATCH_VMVVV
, MASK_VMVVV
, match_opcode
, 0 },
1588 {"vmv.v.x", 0, INSN_CLASS_V
, "Vd,s", MATCH_VMVVX
, MASK_VMVVX
, match_opcode
, 0 },
1589 {"vmv.v.i", 0, INSN_CLASS_V
, "Vd,Vi", MATCH_VMVVI
, MASK_VMVVI
, match_opcode
, 0 },
1591 {"vsaddu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSADDUVV
, MASK_VSADDUVV
, match_opcode
, 0 },
1592 {"vsaddu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSADDUVX
, MASK_VSADDUVX
, match_opcode
, 0 },
1593 {"vsaddu.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VSADDUVI
, MASK_VSADDUVI
, match_opcode
, 0 },
1594 {"vsadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSADDVV
, MASK_VSADDVV
, match_opcode
, 0 },
1595 {"vsadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSADDVX
, MASK_VSADDVX
, match_opcode
, 0 },
1596 {"vsadd.vi", 0, INSN_CLASS_V
, "Vd,Vt,ViVm", MATCH_VSADDVI
, MASK_VSADDVI
, match_opcode
, 0 },
1597 {"vssubu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSUBUVV
, MASK_VSSUBUVV
, match_opcode
, 0 },
1598 {"vssubu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSUBUVX
, MASK_VSSUBUVX
, match_opcode
, 0 },
1599 {"vssub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSUBVV
, MASK_VSSUBVV
, match_opcode
, 0 },
1600 {"vssub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSUBVX
, MASK_VSSUBVX
, match_opcode
, 0 },
1602 {"vaaddu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VAADDUVV
, MASK_VAADDUVV
, match_opcode
, 0 },
1603 {"vaaddu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VAADDUVX
, MASK_VAADDUVX
, match_opcode
, 0 },
1604 {"vaadd.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VAADDVV
, MASK_VAADDVV
, match_opcode
, 0 },
1605 {"vaadd.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VAADDVX
, MASK_VAADDVX
, match_opcode
, 0 },
1606 {"vasubu.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VASUBUVV
, MASK_VASUBUVV
, match_opcode
, 0 },
1607 {"vasubu.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VASUBUVX
, MASK_VASUBUVX
, match_opcode
, 0 },
1608 {"vasub.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VASUBVV
, MASK_VASUBVV
, match_opcode
, 0 },
1609 {"vasub.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VASUBVX
, MASK_VASUBVX
, match_opcode
, 0 },
1611 {"vsmul.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSMULVV
, MASK_VSMULVV
, match_opcode
, 0 },
1612 {"vsmul.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSMULVX
, MASK_VSMULVX
, match_opcode
, 0 },
1614 {"vssrl.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSRLVV
, MASK_VSSRLVV
, match_opcode
, 0 },
1615 {"vssrl.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSRLVX
, MASK_VSSRLVX
, match_opcode
, 0 },
1616 {"vssrl.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSSRLVI
, MASK_VSSRLVI
, match_opcode
, 0 },
1617 {"vssra.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VSSRAVV
, MASK_VSSRAVV
, match_opcode
, 0 },
1618 {"vssra.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSSRAVX
, MASK_VSSRAVX
, match_opcode
, 0 },
1619 {"vssra.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSSRAVI
, MASK_VSSRAVI
, match_opcode
, 0 },
1621 {"vnclipu.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNCLIPUWV
, MASK_VNCLIPUWV
, match_opcode
, 0 },
1622 {"vnclipu.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNCLIPUWX
, MASK_VNCLIPUWX
, match_opcode
, 0 },
1623 {"vnclipu.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNCLIPUWI
, MASK_VNCLIPUWI
, match_opcode
, 0 },
1624 {"vnclip.wv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VNCLIPWV
, MASK_VNCLIPWV
, match_opcode
, 0 },
1625 {"vnclip.wx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VNCLIPWX
, MASK_VNCLIPWX
, match_opcode
, 0 },
1626 {"vnclip.wi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VNCLIPWI
, MASK_VNCLIPWI
, match_opcode
, 0 },
1628 {"vfadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFADDVV
, MASK_VFADDVV
, match_opcode
, 0},
1629 {"vfadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFADDVF
, MASK_VFADDVF
, match_opcode
, 0},
1630 {"vfsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSUBVV
, MASK_VFSUBVV
, match_opcode
, 0},
1631 {"vfsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSUBVF
, MASK_VFSUBVF
, match_opcode
, 0},
1632 {"vfrsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFRSUBVF
, MASK_VFRSUBVF
, match_opcode
, 0},
1634 {"vfwadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWADDVV
, MASK_VFWADDVV
, match_opcode
, 0},
1635 {"vfwadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWADDVF
, MASK_VFWADDVF
, match_opcode
, 0},
1636 {"vfwsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWSUBVV
, MASK_VFWSUBVV
, match_opcode
, 0},
1637 {"vfwsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWSUBVF
, MASK_VFWSUBVF
, match_opcode
, 0},
1638 {"vfwadd.wv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWADDWV
, MASK_VFWADDWV
, match_opcode
, 0},
1639 {"vfwadd.wf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWADDWF
, MASK_VFWADDWF
, match_opcode
, 0},
1640 {"vfwsub.wv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWSUBWV
, MASK_VFWSUBWV
, match_opcode
, 0},
1641 {"vfwsub.wf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWSUBWF
, MASK_VFWSUBWF
, match_opcode
, 0},
1643 {"vfmul.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFMULVV
, MASK_VFMULVV
, match_opcode
, 0},
1644 {"vfmul.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFMULVF
, MASK_VFMULVF
, match_opcode
, 0},
1645 {"vfdiv.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFDIVVV
, MASK_VFDIVVV
, match_opcode
, 0},
1646 {"vfdiv.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFDIVVF
, MASK_VFDIVVF
, match_opcode
, 0},
1647 {"vfrdiv.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFRDIVVF
, MASK_VFRDIVVF
, match_opcode
, 0},
1649 {"vfwmul.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWMULVV
, MASK_VFWMULVV
, match_opcode
, 0},
1650 {"vfwmul.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFWMULVF
, MASK_VFWMULVF
, match_opcode
, 0},
1652 {"vfmadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMADDVV
, MASK_VFMADDVV
, match_opcode
, 0},
1653 {"vfmadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMADDVF
, MASK_VFMADDVF
, match_opcode
, 0},
1654 {"vfnmadd.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMADDVV
, MASK_VFNMADDVV
, match_opcode
, 0},
1655 {"vfnmadd.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMADDVF
, MASK_VFNMADDVF
, match_opcode
, 0},
1656 {"vfmsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMSUBVV
, MASK_VFMSUBVV
, match_opcode
, 0},
1657 {"vfmsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMSUBVF
, MASK_VFMSUBVF
, match_opcode
, 0},
1658 {"vfnmsub.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMSUBVV
, MASK_VFNMSUBVV
, match_opcode
, 0},
1659 {"vfnmsub.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMSUBVF
, MASK_VFNMSUBVF
, match_opcode
, 0},
1660 {"vfmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMACCVV
, MASK_VFMACCVV
, match_opcode
, 0},
1661 {"vfmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMACCVF
, MASK_VFMACCVF
, match_opcode
, 0},
1662 {"vfnmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMACCVV
, MASK_VFNMACCVV
, match_opcode
, 0},
1663 {"vfnmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMACCVF
, MASK_VFNMACCVF
, match_opcode
, 0},
1664 {"vfmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFMSACVV
, MASK_VFMSACVV
, match_opcode
, 0},
1665 {"vfmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFMSACVF
, MASK_VFMSACVF
, match_opcode
, 0},
1666 {"vfnmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFNMSACVV
, MASK_VFNMSACVV
, match_opcode
, 0},
1667 {"vfnmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFNMSACVF
, MASK_VFNMSACVF
, match_opcode
, 0},
1669 {"vfwmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWMACCVV
, MASK_VFWMACCVV
, match_opcode
, 0},
1670 {"vfwmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWMACCVF
, MASK_VFWMACCVF
, match_opcode
, 0},
1671 {"vfwnmacc.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWNMACCVV
, MASK_VFWNMACCVV
, match_opcode
, 0},
1672 {"vfwnmacc.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWNMACCVF
, MASK_VFWNMACCVF
, match_opcode
, 0},
1673 {"vfwmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWMSACVV
, MASK_VFWMSACVV
, match_opcode
, 0},
1674 {"vfwmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWMSACVF
, MASK_VFWMSACVF
, match_opcode
, 0},
1675 {"vfwnmsac.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VFWNMSACVV
, MASK_VFWNMSACVV
, match_opcode
, 0},
1676 {"vfwnmsac.vf", 0, INSN_CLASS_ZVEF
, "Vd,S,VtVm", MATCH_VFWNMSACVF
, MASK_VFWNMSACVF
, match_opcode
, 0},
1678 {"vfsqrt.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFSQRTV
, MASK_VFSQRTV
, match_opcode
, 0},
1679 {"vfrsqrt7.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFRSQRT7V
, MASK_VFRSQRT7V
, match_opcode
, 0},
1680 {"vfrsqrte7.v",0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFRSQRT7V
, MASK_VFRSQRT7V
, match_opcode
, 0},
1681 {"vfrec7.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFREC7V
, MASK_VFREC7V
, match_opcode
, 0},
1682 {"vfrece7.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFREC7V
, MASK_VFREC7V
, match_opcode
, 0},
1683 {"vfclass.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCLASSV
, MASK_VFCLASSV
, match_opcode
, 0},
1685 {"vfmin.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFMINVV
, MASK_VFMINVV
, match_opcode
, 0},
1686 {"vfmin.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFMINVF
, MASK_VFMINVF
, match_opcode
, 0},
1687 {"vfmax.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFMAXVV
, MASK_VFMAXVV
, match_opcode
, 0},
1688 {"vfmax.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFMAXVF
, MASK_VFMAXVF
, match_opcode
, 0},
1690 {"vfneg.v", 0, INSN_CLASS_ZVEF
, "Vd,VuVm", MATCH_VFSGNJNVV
, MASK_VFSGNJNVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1691 {"vfabs.v", 0, INSN_CLASS_ZVEF
, "Vd,VuVm", MATCH_VFSGNJXVV
, MASK_VFSGNJXVV
, match_vs1_eq_vs2
, INSN_ALIAS
},
1693 {"vfsgnj.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSGNJVV
, MASK_VFSGNJVV
, match_opcode
, 0},
1694 {"vfsgnj.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSGNJVF
, MASK_VFSGNJVF
, match_opcode
, 0},
1695 {"vfsgnjn.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSGNJNVV
, MASK_VFSGNJNVV
, match_opcode
, 0},
1696 {"vfsgnjn.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSGNJNVF
, MASK_VFSGNJNVF
, match_opcode
, 0},
1697 {"vfsgnjx.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFSGNJXVV
, MASK_VFSGNJXVV
, match_opcode
, 0},
1698 {"vfsgnjx.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSGNJXVF
, MASK_VFSGNJXVF
, match_opcode
, 0},
1700 {"vmfeq.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFEQVV
, MASK_VMFEQVV
, match_opcode
, 0},
1701 {"vmfeq.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFEQVF
, MASK_VMFEQVF
, match_opcode
, 0},
1702 {"vmfne.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFNEVV
, MASK_VMFNEVV
, match_opcode
, 0},
1703 {"vmfne.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFNEVF
, MASK_VMFNEVF
, match_opcode
, 0},
1704 {"vmflt.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFLTVV
, MASK_VMFLTVV
, match_opcode
, 0},
1705 {"vmflt.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFLTVF
, MASK_VMFLTVF
, match_opcode
, 0},
1706 {"vmfle.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VMFLEVV
, MASK_VMFLEVV
, match_opcode
, 0},
1707 {"vmfle.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFLEVF
, MASK_VMFLEVF
, match_opcode
, 0},
1708 {"vmfgt.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFGTVF
, MASK_VMFGTVF
, match_opcode
, 0},
1709 {"vmfge.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VMFGEVF
, MASK_VMFGEVF
, match_opcode
, 0},
1711 /* These aliases are for assembly but not disassembly. */
1712 {"vmfgt.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VMFLTVV
, MASK_VMFLTVV
, match_opcode
, INSN_ALIAS
},
1713 {"vmfge.vv", 0, INSN_CLASS_ZVEF
, "Vd,Vs,VtVm", MATCH_VMFLEVV
, MASK_VMFLEVV
, match_opcode
, INSN_ALIAS
},
1715 {"vfmerge.vfm",0, INSN_CLASS_ZVEF
, "Vd,Vt,S,V0", MATCH_VFMERGEVFM
, MASK_VFMERGEVFM
, match_opcode
, 0},
1716 {"vfmv.v.f", 0, INSN_CLASS_ZVEF
, "Vd,S", MATCH_VFMVVF
, MASK_VFMVVF
, match_opcode
, 0 },
1718 {"vfcvt.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTXUFV
, MASK_VFCVTXUFV
, match_opcode
, 0},
1719 {"vfcvt.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTXFV
, MASK_VFCVTXFV
, match_opcode
, 0},
1720 {"vfcvt.rtz.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTRTZXUFV
, MASK_VFCVTRTZXUFV
, match_opcode
, 0},
1721 {"vfcvt.rtz.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTRTZXFV
, MASK_VFCVTRTZXFV
, match_opcode
, 0},
1722 {"vfcvt.f.xu.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTFXUV
, MASK_VFCVTFXUV
, match_opcode
, 0},
1723 {"vfcvt.f.x.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFCVTFXV
, MASK_VFCVTFXV
, match_opcode
, 0},
1725 {"vfwcvt.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTXUFV
, MASK_VFWCVTXUFV
, match_opcode
, 0},
1726 {"vfwcvt.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTXFV
, MASK_VFWCVTXFV
, match_opcode
, 0},
1727 {"vfwcvt.rtz.xu.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTRTZXUFV
, MASK_VFWCVTRTZXUFV
, match_opcode
, 0},
1728 {"vfwcvt.rtz.x.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTRTZXFV
, MASK_VFWCVTRTZXFV
, match_opcode
, 0},
1729 {"vfwcvt.f.xu.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTFXUV
, MASK_VFWCVTFXUV
, match_opcode
, 0},
1730 {"vfwcvt.f.x.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTFXV
, MASK_VFWCVTFXV
, match_opcode
, 0},
1731 {"vfwcvt.f.f.v", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFWCVTFFV
, MASK_VFWCVTFFV
, match_opcode
, 0},
1733 {"vfncvt.xu.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTXUFW
, MASK_VFNCVTXUFW
, match_opcode
, 0},
1734 {"vfncvt.x.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTXFW
, MASK_VFNCVTXFW
, match_opcode
, 0},
1735 {"vfncvt.rtz.xu.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTRTZXUFW
, MASK_VFNCVTRTZXUFW
, match_opcode
, 0},
1736 {"vfncvt.rtz.x.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTRTZXFW
, MASK_VFNCVTRTZXFW
, match_opcode
, 0},
1737 {"vfncvt.f.xu.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTFXUW
, MASK_VFNCVTFXUW
, match_opcode
, 0},
1738 {"vfncvt.f.x.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTFXW
, MASK_VFNCVTFXW
, match_opcode
, 0},
1739 {"vfncvt.f.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTFFW
, MASK_VFNCVTFFW
, match_opcode
, 0},
1740 {"vfncvt.rod.f.f.w", 0, INSN_CLASS_ZVEF
, "Vd,VtVm", MATCH_VFNCVTRODFFW
, MASK_VFNCVTRODFFW
, match_opcode
, 0},
1742 {"vredsum.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDSUMVS
, MASK_VREDSUMVS
, match_opcode
, 0},
1743 {"vredmaxu.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMAXUVS
, MASK_VREDMAXUVS
, match_opcode
, 0},
1744 {"vredmax.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMAXVS
, MASK_VREDMAXVS
, match_opcode
, 0},
1745 {"vredminu.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMINUVS
, MASK_VREDMINUVS
, match_opcode
, 0},
1746 {"vredmin.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDMINVS
, MASK_VREDMINVS
, match_opcode
, 0},
1747 {"vredand.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDANDVS
, MASK_VREDANDVS
, match_opcode
, 0},
1748 {"vredor.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDORVS
, MASK_VREDORVS
, match_opcode
, 0},
1749 {"vredxor.vs", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VREDXORVS
, MASK_VREDXORVS
, match_opcode
, 0},
1751 {"vwredsumu.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWREDSUMUVS
, MASK_VWREDSUMUVS
, match_opcode
, 0},
1752 {"vwredsum.vs",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VWREDSUMVS
, MASK_VWREDSUMVS
, match_opcode
, 0},
1754 {"vfredosum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDOSUMVS
, MASK_VFREDOSUMVS
, match_opcode
, 0},
1755 {"vfredusum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDUSUMVS
, MASK_VFREDUSUMVS
, match_opcode
, 0},
1756 {"vfredsum.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDUSUMVS
, MASK_VFREDUSUMVS
, match_opcode
, INSN_ALIAS
},
1757 {"vfredmax.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDMAXVS
, MASK_VFREDMAXVS
, match_opcode
, 0},
1758 {"vfredmin.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFREDMINVS
, MASK_VFREDMINVS
, match_opcode
, 0},
1760 {"vfwredosum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWREDOSUMVS
, MASK_VFWREDOSUMVS
, match_opcode
, 0},
1761 {"vfwredusum.vs",0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWREDUSUMVS
, MASK_VFWREDUSUMVS
, match_opcode
, 0},
1762 {"vfwredsum.vs", 0, INSN_CLASS_ZVEF
, "Vd,Vt,VsVm", MATCH_VFWREDUSUMVS
, MASK_VFWREDUSUMVS
, match_opcode
, INSN_ALIAS
},
1764 {"vmmv.m", 0, INSN_CLASS_V
, "Vd,Vu", MATCH_VMANDMM
, MASK_VMANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
1765 {"vmcpy.m", 0, INSN_CLASS_V
, "Vd,Vu", MATCH_VMANDMM
, MASK_VMANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
1766 {"vmclr.m", 0, INSN_CLASS_V
, "Vv", MATCH_VMXORMM
, MASK_VMXORMM
, match_vd_eq_vs1_eq_vs2
, INSN_ALIAS
},
1767 {"vmset.m", 0, INSN_CLASS_V
, "Vv", MATCH_VMXNORMM
, MASK_VMXNORMM
, match_vd_eq_vs1_eq_vs2
, INSN_ALIAS
},
1768 {"vmnot.m", 0, INSN_CLASS_V
, "Vd,Vu", MATCH_VMNANDMM
, MASK_VMNANDMM
, match_vs1_eq_vs2
, INSN_ALIAS
},
1770 {"vmand.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMANDMM
, MASK_VMANDMM
, match_opcode
, 0},
1771 {"vmnand.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMNANDMM
, MASK_VMNANDMM
, match_opcode
, 0},
1772 {"vmandn.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMANDNMM
, MASK_VMANDNMM
, match_opcode
, 0},
1773 {"vmandnot.mm",0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMANDNMM
, MASK_VMANDNMM
, match_opcode
, INSN_ALIAS
},
1774 {"vmxor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMXORMM
, MASK_VMXORMM
, match_opcode
, 0},
1775 {"vmor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMORMM
, MASK_VMORMM
, match_opcode
, 0},
1776 {"vmnor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMNORMM
, MASK_VMNORMM
, match_opcode
, 0},
1777 {"vmorn.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMORNMM
, MASK_VMORNMM
, match_opcode
, 0},
1778 {"vmornot.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMORNMM
, MASK_VMORNMM
, match_opcode
, INSN_ALIAS
},
1779 {"vmxnor.mm", 0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VMXNORMM
, MASK_VMXNORMM
, match_opcode
, 0},
1781 {"vcpop.m", 0, INSN_CLASS_V
, "d,VtVm", MATCH_VCPOPM
, MASK_VCPOPM
, match_opcode
, 0},
1782 {"vpopc.m", 0, INSN_CLASS_V
, "d,VtVm", MATCH_VCPOPM
, MASK_VCPOPM
, match_opcode
, INSN_ALIAS
},
1783 {"vfirst.m", 0, INSN_CLASS_V
, "d,VtVm", MATCH_VFIRSTM
, MASK_VFIRSTM
, match_opcode
, 0},
1784 {"vmsbf.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VMSBFM
, MASK_VMSBFM
, match_opcode
, 0},
1785 {"vmsif.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VMSIFM
, MASK_VMSIFM
, match_opcode
, 0},
1786 {"vmsof.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VMSOFM
, MASK_VMSOFM
, match_opcode
, 0},
1787 {"viota.m", 0, INSN_CLASS_V
, "Vd,VtVm", MATCH_VIOTAM
, MASK_VIOTAM
, match_opcode
, 0},
1788 {"vid.v", 0, INSN_CLASS_V
, "VdVm", MATCH_VIDV
, MASK_VIDV
, match_opcode
, 0},
1790 {"vmv.x.s", 0, INSN_CLASS_V
, "d,Vt", MATCH_VMVXS
, MASK_VMVXS
, match_opcode
, 0},
1791 {"vmv.s.x", 0, INSN_CLASS_V
, "Vd,s", MATCH_VMVSX
, MASK_VMVSX
, match_opcode
, 0},
1793 {"vfmv.f.s", 0, INSN_CLASS_ZVEF
, "D,Vt", MATCH_VFMVFS
, MASK_VFMVFS
, match_opcode
, 0},
1794 {"vfmv.s.f", 0, INSN_CLASS_ZVEF
, "Vd,S", MATCH_VFMVSF
, MASK_VFMVSF
, match_opcode
, 0},
1796 {"vslideup.vx",0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDEUPVX
, MASK_VSLIDEUPVX
, match_opcode
, 0},
1797 {"vslideup.vi",0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSLIDEUPVI
, MASK_VSLIDEUPVI
, match_opcode
, 0},
1798 {"vslidedown.vx",0,INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDEDOWNVX
, MASK_VSLIDEDOWNVX
, match_opcode
, 0},
1799 {"vslidedown.vi",0,INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VSLIDEDOWNVI
, MASK_VSLIDEDOWNVI
, match_opcode
, 0},
1801 {"vslide1up.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDE1UPVX
, MASK_VSLIDE1UPVX
, match_opcode
, 0},
1802 {"vslide1down.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VSLIDE1DOWNVX
, MASK_VSLIDE1DOWNVX
, match_opcode
, 0},
1803 {"vfslide1up.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSLIDE1UPVF
, MASK_VFSLIDE1UPVF
, match_opcode
, 0},
1804 {"vfslide1down.vf", 0, INSN_CLASS_ZVEF
, "Vd,Vt,SVm", MATCH_VFSLIDE1DOWNVF
, MASK_VFSLIDE1DOWNVF
, match_opcode
, 0},
1806 {"vrgather.vv", 0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VRGATHERVV
, MASK_VRGATHERVV
, match_opcode
, 0},
1807 {"vrgather.vx", 0, INSN_CLASS_V
, "Vd,Vt,sVm", MATCH_VRGATHERVX
, MASK_VRGATHERVX
, match_opcode
, 0},
1808 {"vrgather.vi", 0, INSN_CLASS_V
, "Vd,Vt,VjVm", MATCH_VRGATHERVI
, MASK_VRGATHERVI
, match_opcode
, 0},
1809 {"vrgatherei16.vv",0, INSN_CLASS_V
, "Vd,Vt,VsVm", MATCH_VRGATHEREI16VV
, MASK_VRGATHEREI16VV
, match_opcode
, 0},
1811 {"vcompress.vm",0, INSN_CLASS_V
, "Vd,Vt,Vs", MATCH_VCOMPRESSVM
, MASK_VCOMPRESSVM
, match_opcode
, 0},
1813 {"vmv1r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV1RV
, MASK_VMV1RV
, match_opcode
, 0},
1814 {"vmv2r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV2RV
, MASK_VMV2RV
, match_opcode
, 0},
1815 {"vmv4r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV4RV
, MASK_VMV4RV
, match_opcode
, 0},
1816 {"vmv8r.v", 0, INSN_CLASS_V
, "Vd,Vt", MATCH_VMV8RV
, MASK_VMV8RV
, match_opcode
, 0},
1818 /* Supervisor instructions. */
1819 {"csrr", 0, INSN_CLASS_ZICSR
, "d,E", MATCH_CSRRS
, MASK_CSRRS
|MASK_RS1
, match_opcode
, INSN_ALIAS
},
1820 {"csrw", 0, INSN_CLASS_ZICSR
, "E,s", MATCH_CSRRW
, MASK_CSRRW
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1821 {"csrw", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRWI
, MASK_CSRRWI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1822 {"csrwi", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRWI
, MASK_CSRRWI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1823 {"csrs", 0, INSN_CLASS_ZICSR
, "E,s", MATCH_CSRRS
, MASK_CSRRS
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1824 {"csrs", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRSI
, MASK_CSRRSI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1825 {"csrsi", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRSI
, MASK_CSRRSI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1826 {"csrc", 0, INSN_CLASS_ZICSR
, "E,s", MATCH_CSRRC
, MASK_CSRRC
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1827 {"csrc", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRCI
, MASK_CSRRCI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1828 {"csrci", 0, INSN_CLASS_ZICSR
, "E,Z", MATCH_CSRRCI
, MASK_CSRRCI
|MASK_RD
, match_opcode
, INSN_ALIAS
},
1829 {"csrrw", 0, INSN_CLASS_ZICSR
, "d,E,s", MATCH_CSRRW
, MASK_CSRRW
, match_opcode
, 0 },
1830 {"csrrw", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRWI
, MASK_CSRRWI
, match_opcode
, INSN_ALIAS
},
1831 {"csrrwi", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRWI
, MASK_CSRRWI
, match_opcode
, 0 },
1832 {"csrrs", 0, INSN_CLASS_ZICSR
, "d,E,s", MATCH_CSRRS
, MASK_CSRRS
, match_opcode
, 0 },
1833 {"csrrs", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRSI
, MASK_CSRRSI
, match_opcode
, INSN_ALIAS
},
1834 {"csrrsi", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRSI
, MASK_CSRRSI
, match_opcode
, 0 },
1835 {"csrrc", 0, INSN_CLASS_ZICSR
, "d,E,s", MATCH_CSRRC
, MASK_CSRRC
, match_opcode
, 0 },
1836 {"csrrc", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRCI
, MASK_CSRRCI
, match_opcode
, INSN_ALIAS
},
1837 {"csrrci", 0, INSN_CLASS_ZICSR
, "d,E,Z", MATCH_CSRRCI
, MASK_CSRRCI
, match_opcode
, 0 },
1838 {"uret", 0, INSN_CLASS_I
, "", MATCH_URET
, MASK_URET
, match_opcode
, 0 },
1839 {"sret", 0, INSN_CLASS_I
, "", MATCH_SRET
, MASK_SRET
, match_opcode
, 0 },
1840 {"hret", 0, INSN_CLASS_I
, "", MATCH_HRET
, MASK_HRET
, match_opcode
, 0 },
1841 {"mret", 0, INSN_CLASS_I
, "", MATCH_MRET
, MASK_MRET
, match_opcode
, 0 },
1842 {"dret", 0, INSN_CLASS_I
, "", MATCH_DRET
, MASK_DRET
, match_opcode
, 0 },
1843 {"sfence.vm", 0, INSN_CLASS_I
, "", MATCH_SFENCE_VM
, MASK_SFENCE_VM
| MASK_RS1
, match_opcode
, 0 },
1844 {"sfence.vm", 0, INSN_CLASS_I
, "s", MATCH_SFENCE_VM
, MASK_SFENCE_VM
, match_opcode
, 0 },
1845 {"sfence.vma", 0, INSN_CLASS_I
, "", MATCH_SFENCE_VMA
, MASK_SFENCE_VMA
|MASK_RS1
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
1846 {"sfence.vma", 0, INSN_CLASS_I
, "s", MATCH_SFENCE_VMA
, MASK_SFENCE_VMA
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
1847 {"sfence.vma", 0, INSN_CLASS_I
, "s,t", MATCH_SFENCE_VMA
, MASK_SFENCE_VMA
, match_opcode
, 0 },
1848 {"wfi", 0, INSN_CLASS_I
, "", MATCH_WFI
, MASK_WFI
, match_opcode
, 0 },
1850 /* Svinval instructions. */
1851 {"sinval.vma", 0, INSN_CLASS_SVINVAL
, "s,t", MATCH_SINVAL_VMA
, MASK_SINVAL_VMA
, match_opcode
, 0 },
1852 {"sfence.w.inval", 0, INSN_CLASS_SVINVAL
, "", MATCH_SFENCE_W_INVAL
, MASK_SFENCE_W_INVAL
, match_opcode
, 0 },
1853 {"sfence.inval.ir", 0, INSN_CLASS_SVINVAL
, "", MATCH_SFENCE_INVAL_IR
, MASK_SFENCE_INVAL_IR
, match_opcode
, 0 },
1854 {"hinval.vvma", 0, INSN_CLASS_SVINVAL
, "s,t", MATCH_HINVAL_VVMA
, MASK_HINVAL_VVMA
, match_opcode
, 0 },
1855 {"hinval.gvma", 0, INSN_CLASS_SVINVAL
, "s,t", MATCH_HINVAL_GVMA
, MASK_HINVAL_GVMA
, match_opcode
, 0 },
1857 /* Hypervisor instructions. */
1858 {"hfence.vvma", 0, INSN_CLASS_H
, "", MATCH_HFENCE_VVMA
, MASK_HFENCE_VVMA
|MASK_RS1
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
1859 {"hfence.vvma", 0, INSN_CLASS_H
, "s", MATCH_HFENCE_VVMA
, MASK_HFENCE_VVMA
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
1860 {"hfence.vvma", 0, INSN_CLASS_H
, "s,t", MATCH_HFENCE_VVMA
, MASK_HFENCE_VVMA
, match_opcode
, 0 },
1861 {"hfence.gvma", 0, INSN_CLASS_H
, "", MATCH_HFENCE_GVMA
, MASK_HFENCE_GVMA
|MASK_RS1
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
1862 {"hfence.gvma", 0, INSN_CLASS_H
, "s", MATCH_HFENCE_GVMA
, MASK_HFENCE_GVMA
|MASK_RS2
, match_opcode
, INSN_ALIAS
},
1863 {"hfence.gvma", 0, INSN_CLASS_H
, "s,t", MATCH_HFENCE_GVMA
, MASK_HFENCE_GVMA
, match_opcode
, 0 },
1864 {"hlv.b", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_B
, MASK_HLV_B
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
1865 {"hlv.bu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_BU
, MASK_HLV_BU
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
1866 {"hlv.h", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_H
, MASK_HLV_H
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
1867 {"hlv.hu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_HU
, MASK_HLV_HU
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
1868 {"hlvx.hu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLVX_HU
, MASK_HLVX_HU
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
1869 {"hlv.w", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_W
, MASK_HLV_W
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1870 {"hlv.wu", 64, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_WU
, MASK_HLV_WU
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1871 {"hlvx.wu", 0, INSN_CLASS_H
, "d,0(s)", MATCH_HLVX_WU
, MASK_HLVX_WU
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1872 {"hlv.d", 64, INSN_CLASS_H
, "d,0(s)", MATCH_HLV_D
, MASK_HLV_D
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1873 {"hsv.b", 0, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_B
, MASK_HSV_B
, match_opcode
, INSN_DREF
|INSN_1_BYTE
},
1874 {"hsv.h", 0, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_H
, MASK_HSV_H
, match_opcode
, INSN_DREF
|INSN_2_BYTE
},
1875 {"hsv.w", 0, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_W
, MASK_HSV_W
, match_opcode
, INSN_DREF
|INSN_4_BYTE
},
1876 {"hsv.d", 64, INSN_CLASS_H
, "t,0(s)", MATCH_HSV_D
, MASK_HSV_D
, match_opcode
, INSN_DREF
|INSN_8_BYTE
},
1878 /* Vendor-specific (T-Head) XTheadBa instructions. */
1879 {"th.addsl", 0, INSN_CLASS_XTHEADBA
, "d,s,t,Xu2@25", MATCH_TH_ADDSL
, MASK_TH_ADDSL
, match_opcode
, 0},
1881 /* Vendor-specific (T-Head) XTheadBb instructions. */
1882 {"th.srri", 0, INSN_CLASS_XTHEADBB
, "d,s,Xu6@20", MATCH_TH_SRRI
, MASK_TH_SRRI
, match_opcode
, 0},
1883 {"th.srriw", 64, INSN_CLASS_XTHEADBB
, "d,s,Xu5@20", MATCH_TH_SRRIW
, MASK_TH_SRRIW
, match_opcode
, 0},
1884 {"th.ext", 0, INSN_CLASS_XTHEADBB
, "d,s,Xu6@26,Xu6@20", MATCH_TH_EXT
, MASK_TH_EXT
, match_opcode
, 0},
1885 {"th.extu", 0, INSN_CLASS_XTHEADBB
, "d,s,Xu6@26,Xu6@20", MATCH_TH_EXTU
, MASK_TH_EXTU
, match_opcode
, 0},
1886 {"th.ff0", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_FF0
, MASK_TH_FF0
, match_opcode
, 0},
1887 {"th.ff1", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_FF1
, MASK_TH_FF1
, match_opcode
, 0},
1888 {"th.rev", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_REV
, MASK_TH_REV
, match_opcode
, 0},
1889 {"th.revw", 64, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_REVW
, MASK_TH_REVW
, match_opcode
, 0},
1890 {"th.tstnbz", 0, INSN_CLASS_XTHEADBB
, "d,s", MATCH_TH_TSTNBZ
, MASK_TH_TSTNBZ
, match_opcode
, 0},
1892 /* Vendor-specific (T-Head) XTheadBs instructions. */
1893 {"th.tst", 0, INSN_CLASS_XTHEADBS
, "d,s,Xu6@20", MATCH_TH_TST
, MASK_TH_TST
, match_opcode
, 0},
1895 /* Vendor-specific (T-Head) XTheadCmo instructions. */
1896 {"th.dcache.call", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_DCACHE_CALL
, MASK_TH_DCACHE_CALL
, match_opcode
, 0},
1897 {"th.dcache.ciall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_DCACHE_CIALL
, MASK_TH_DCACHE_CIALL
, match_opcode
, 0},
1898 {"th.dcache.iall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_DCACHE_IALL
, MASK_TH_DCACHE_IALL
, match_opcode
, 0},
1899 {"th.dcache.cpa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CPA
, MASK_TH_DCACHE_CPA
, match_opcode
, 0},
1900 {"th.dcache.cipa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CIPA
, MASK_TH_DCACHE_CIPA
, match_opcode
, 0},
1901 {"th.dcache.ipa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_IPA
, MASK_TH_DCACHE_IPA
, match_opcode
, 0},
1902 {"th.dcache.cva", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CVA
, MASK_TH_DCACHE_CVA
, match_opcode
, 0},
1903 {"th.dcache.civa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CIVA
, MASK_TH_DCACHE_CIVA
, match_opcode
, 0},
1904 {"th.dcache.iva", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_IVA
, MASK_TH_DCACHE_IVA
, match_opcode
, 0},
1905 {"th.dcache.csw", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CSW
, MASK_TH_DCACHE_CSW
, match_opcode
, 0},
1906 {"th.dcache.cisw", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CISW
, MASK_TH_DCACHE_CISW
, match_opcode
, 0},
1907 {"th.dcache.isw", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_ISW
, MASK_TH_DCACHE_ISW
, match_opcode
, 0},
1908 {"th.dcache.cpal1", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CPAL1
, MASK_TH_DCACHE_CPAL1
, match_opcode
, 0},
1909 {"th.dcache.cval1", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_DCACHE_CVAL1
, MASK_TH_DCACHE_CVAL1
, match_opcode
, 0},
1911 {"th.icache.iall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_ICACHE_IALL
, MASK_TH_ICACHE_IALL
, match_opcode
, 0},
1912 {"th.icache.ialls", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_ICACHE_IALLS
, MASK_TH_ICACHE_IALLS
, match_opcode
, 0},
1913 {"th.icache.ipa", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_ICACHE_IPA
, MASK_TH_ICACHE_IPA
, match_opcode
, 0},
1914 {"th.icache.iva", 0, INSN_CLASS_XTHEADCMO
, "s", MATCH_TH_ICACHE_IVA
, MASK_TH_ICACHE_IVA
, match_opcode
, 0},
1916 {"th.l2cache.call", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_L2CACHE_CALL
, MASK_TH_L2CACHE_CALL
, match_opcode
, 0},
1917 {"th.l2cache.ciall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_L2CACHE_CIALL
, MASK_TH_L2CACHE_CIALL
, match_opcode
, 0},
1918 {"th.l2cache.iall", 0, INSN_CLASS_XTHEADCMO
, "", MATCH_TH_L2CACHE_IALL
, MASK_TH_L2CACHE_IALL
, match_opcode
, 0},
1920 /* Vendor-specific (T-Head) XTheadCondMov instructions. */
1921 {"th.mveqz", 0, INSN_CLASS_XTHEADCONDMOV
, "d,s,t", MATCH_TH_MVEQZ
, MASK_TH_MVEQZ
, match_opcode
, 0},
1922 {"th.mvnez", 0, INSN_CLASS_XTHEADCONDMOV
, "d,s,t", MATCH_TH_MVNEZ
, MASK_TH_MVNEZ
, match_opcode
, 0},
1924 /* Vendor-specific (T-Head) XTheadFMemIdx instructions. */
1925 {"th.flrd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FLRD
, MASK_TH_FLRD
, match_opcode
, 0},
1926 {"th.flrw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FLRW
, MASK_TH_FLRW
, match_opcode
, 0},
1927 {"th.flurd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FLURD
, MASK_TH_FLURD
, match_opcode
, 0},
1928 {"th.flurw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FLURW
, MASK_TH_FLURW
, match_opcode
, 0},
1929 {"th.fsrd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FSRD
, MASK_TH_FSRD
, match_opcode
, 0},
1930 {"th.fsrw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FSRW
, MASK_TH_FSRW
, match_opcode
, 0},
1931 {"th.fsurd", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FSURD
, MASK_TH_FSURD
, match_opcode
, 0},
1932 {"th.fsurw", 0, INSN_CLASS_XTHEADFMEMIDX
, "D,s,t,Xu2@25", MATCH_TH_FSURW
, MASK_TH_FSURW
, match_opcode
, 0},
1934 /* Vendor-specific (T-Head) XTheadFmv instructions. */
1935 {"th.fmv.hw.x", 32, INSN_CLASS_XTHEADFMV
, "d,S", MATCH_TH_FMV_HW_X
, MASK_TH_FMV_HW_X
, match_opcode
, 0},
1936 {"th.fmv.x.hw", 32, INSN_CLASS_XTHEADFMV
, "d,S", MATCH_TH_FMV_X_HW
, MASK_TH_FMV_X_HW
, match_opcode
, 0},
1938 /* Vendor-specific (T-Head) XTheadInt instructions. */
1939 {"th.ipop", 0, INSN_CLASS_XTHEADINT
, "", MATCH_TH_IPOP
, MASK_TH_IPOP
, match_opcode
, 0},
1940 {"th.ipush", 0, INSN_CLASS_XTHEADINT
, "", MATCH_TH_IPUSH
, MASK_TH_IPUSH
, match_opcode
, 0},
1942 /* Vendor-specific (T-Head) XTheadMemIdx instructions. */
1943 {"th.ldia", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LDIA
, MASK_TH_LDIA
, match_th_load_inc
, 0},
1944 {"th.ldib", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LDIB
, MASK_TH_LDIB
, match_th_load_inc
, 0},
1945 {"th.lwia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LWIA
, MASK_TH_LWIA
, match_th_load_inc
, 0},
1946 {"th.lwib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LWIB
, MASK_TH_LWIB
, match_th_load_inc
, 0},
1947 {"th.lwuia", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LWUIA
, MASK_TH_LWUIA
, match_th_load_inc
, 0},
1948 {"th.lwuib", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LWUIB
, MASK_TH_LWUIB
, match_th_load_inc
, 0},
1949 {"th.lhia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LHIA
, MASK_TH_LHIA
, match_th_load_inc
, 0},
1950 {"th.lhib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LHIB
, MASK_TH_LHIB
, match_th_load_inc
, 0},
1951 {"th.lhuia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LHUIA
, MASK_TH_LHUIA
, match_th_load_inc
, 0},
1952 {"th.lhuib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LHUIB
, MASK_TH_LHUIB
, match_th_load_inc
, 0},
1953 {"th.lbia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LBIA
, MASK_TH_LBIA
, match_th_load_inc
, 0},
1954 {"th.lbib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LBIB
, MASK_TH_LBIB
, match_th_load_inc
, 0},
1955 {"th.lbuia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LBUIA
, MASK_TH_LBUIA
, match_th_load_inc
, 0},
1956 {"th.lbuib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_LBUIB
, MASK_TH_LBUIB
, match_th_load_inc
, 0},
1957 {"th.sdia", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SDIA
, MASK_TH_SDIA
, match_opcode
, 0},
1958 {"th.sdib", 64, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SDIB
, MASK_TH_SDIB
, match_opcode
, 0},
1959 {"th.swia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SWIA
, MASK_TH_SWIA
, match_opcode
, 0},
1960 {"th.swib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SWIB
, MASK_TH_SWIB
, match_opcode
, 0},
1961 {"th.shia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SHIA
, MASK_TH_SHIA
, match_opcode
, 0},
1962 {"th.shib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SHIB
, MASK_TH_SHIB
, match_opcode
, 0},
1963 {"th.sbia", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SBIA
, MASK_TH_SBIA
, match_opcode
, 0},
1964 {"th.sbib", 0, INSN_CLASS_XTHEADMEMIDX
, "d,(s),Xs5@20,Xu2@25", MATCH_TH_SBIB
, MASK_TH_SBIB
, match_opcode
, 0},
1966 {"th.lrd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LRD
, MASK_TH_LRD
, match_opcode
, 0},
1967 {"th.lrw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LRW
, MASK_TH_LRW
, match_opcode
, 0},
1968 {"th.lrwu", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LRWU
, MASK_TH_LRWU
, match_opcode
, 0},
1969 {"th.lrh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LRH
, MASK_TH_LRH
, match_opcode
, 0},
1970 {"th.lrhu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LRHU
, MASK_TH_LRHU
, match_opcode
, 0},
1971 {"th.lrb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LRB
, MASK_TH_LRB
, match_opcode
, 0},
1972 {"th.lrbu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LRBU
, MASK_TH_LRBU
, match_opcode
, 0},
1973 {"th.srd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SRD
, MASK_TH_SRD
, match_opcode
, 0},
1974 {"th.srw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SRW
, MASK_TH_SRW
, match_opcode
, 0},
1975 {"th.srh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SRH
, MASK_TH_SRH
, match_opcode
, 0},
1976 {"th.srb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SRB
, MASK_TH_SRB
, match_opcode
, 0},
1978 {"th.lurd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LURD
, MASK_TH_LURD
, match_opcode
, 0},
1979 {"th.lurw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LURW
, MASK_TH_LURW
, match_opcode
, 0},
1980 {"th.lurwu", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LURWU
, MASK_TH_LURWU
, match_opcode
, 0},
1981 {"th.lurh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LURH
, MASK_TH_LURH
, match_opcode
, 0},
1982 {"th.lurhu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LURHU
, MASK_TH_LURHU
, match_opcode
, 0},
1983 {"th.lurb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LURB
, MASK_TH_LURB
, match_opcode
, 0},
1984 {"th.lurbu", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_LURBU
, MASK_TH_LURBU
, match_opcode
, 0},
1985 {"th.surd", 64, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SURD
, MASK_TH_SURD
, match_opcode
, 0},
1986 {"th.surw", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SURW
, MASK_TH_SURW
, match_opcode
, 0},
1987 {"th.surh", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SURH
, MASK_TH_SURH
, match_opcode
, 0},
1988 {"th.surb", 0, INSN_CLASS_XTHEADMEMIDX
, "d,s,t,Xu2@25", MATCH_TH_SURB
, MASK_TH_SURB
, match_opcode
, 0},
1990 /* Vendor-specific (T-Head) XTheadMemPair instructions. */
1991 {"th.ldd", 64, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xu2@25,Xl4", MATCH_TH_LDD
, MASK_TH_LDD
, match_th_load_pair
, 0},
1992 {"th.lwd", 0, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xu2@25,Xl3", MATCH_TH_LWD
, MASK_TH_LWD
, match_th_load_pair
, 0},
1993 {"th.lwud", 0, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xu2@25,Xl3", MATCH_TH_LWUD
, MASK_TH_LWUD
, match_th_load_pair
, 0},
1994 {"th.sdd", 64, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xu2@25,Xl4", MATCH_TH_SDD
, MASK_TH_SDD
, match_opcode
, 0},
1995 {"th.swd", 0, INSN_CLASS_XTHEADMEMPAIR
, "d,t,(s),Xu2@25,Xl3", MATCH_TH_SWD
, MASK_TH_SWD
, match_opcode
, 0},
1997 /* Vendor-specific (T-Head) XTheadMac instructions. */
1998 {"th.mula", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULA
, MASK_TH_MULA
, match_opcode
, 0},
1999 {"th.mulah", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULAH
, MASK_TH_MULAH
, match_opcode
, 0},
2000 {"th.mulaw", 64, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULAW
, MASK_TH_MULAW
, match_opcode
, 0},
2001 {"th.muls", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULS
, MASK_TH_MULS
, match_opcode
, 0},
2002 {"th.mulsh", 0, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULSH
, MASK_TH_MULSH
, match_opcode
, 0},
2003 {"th.mulsw", 64, INSN_CLASS_XTHEADMAC
, "d,s,t", MATCH_TH_MULSW
, MASK_TH_MULSW
, match_opcode
, 0},
2005 /* Vendor-specific (T-Head) XTheadSync instructions. */
2006 {"th.sfence.vmas", 0, INSN_CLASS_XTHEADSYNC
, "s,t",MATCH_TH_SFENCE_VMAS
, MASK_TH_SFENCE_VMAS
, match_opcode
, 0},
2007 {"th.sync", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC
, MASK_TH_SYNC
, match_opcode
, 0},
2008 {"th.sync.i", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC_I
, MASK_TH_SYNC_I
, match_opcode
, 0},
2009 {"th.sync.is", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC_IS
, MASK_TH_SYNC_IS
, match_opcode
, 0},
2010 {"th.sync.s", 0, INSN_CLASS_XTHEADSYNC
, "", MATCH_TH_SYNC_S
, MASK_TH_SYNC_S
, match_opcode
, 0},
2012 /* Terminate the list. */
2013 {0, 0, INSN_CLASS_NONE
, 0, 0, 0, 0, 0}
2016 /* Instruction format for .insn directive. */
2017 const struct riscv_opcode riscv_insn_types
[] =
2019 /* name, xlen, isa, operands, match, mask, match_func, pinfo. */
2020 {"r", 0, INSN_CLASS_I
, "O4,F3,F7,d,s,t", 0, 0, match_opcode
, 0 },
2021 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,s,t", 0, 0, match_opcode
, 0 },
2022 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,d,S,t", 0, 0, match_opcode
, 0 },
2023 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,S,t", 0, 0, match_opcode
, 0 },
2024 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,d,s,T", 0, 0, match_opcode
, 0 },
2025 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,s,T", 0, 0, match_opcode
, 0 },
2026 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,d,S,T", 0, 0, match_opcode
, 0 },
2027 {"r", 0, INSN_CLASS_F
, "O4,F3,F7,D,S,T", 0, 0, match_opcode
, 0 },
2028 {"r", 0, INSN_CLASS_I
, "O4,F3,F2,d,s,t,r", 0, 0, match_opcode
, 0 },
2029 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,r", 0, 0, match_opcode
, 0 },
2030 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,r", 0, 0, match_opcode
, 0 },
2031 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,r", 0, 0, match_opcode
, 0 },
2032 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,r", 0, 0, match_opcode
, 0 },
2033 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,r", 0, 0, match_opcode
, 0 },
2034 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,r", 0, 0, match_opcode
, 0 },
2035 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,r", 0, 0, match_opcode
, 0 },
2036 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,t,R", 0, 0, match_opcode
, 0 },
2037 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,R", 0, 0, match_opcode
, 0 },
2038 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,R", 0, 0, match_opcode
, 0 },
2039 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,R", 0, 0, match_opcode
, 0 },
2040 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,R", 0, 0, match_opcode
, 0 },
2041 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,R", 0, 0, match_opcode
, 0 },
2042 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,R", 0, 0, match_opcode
, 0 },
2043 {"r", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,R", 0, 0, match_opcode
, 0 },
2045 {"r4", 0, INSN_CLASS_I
, "O4,F3,F2,d,s,t,r", 0, 0, match_opcode
, 0 },
2046 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,r", 0, 0, match_opcode
, 0 },
2047 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,r", 0, 0, match_opcode
, 0 },
2048 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,r", 0, 0, match_opcode
, 0 },
2049 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,r", 0, 0, match_opcode
, 0 },
2050 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,r", 0, 0, match_opcode
, 0 },
2051 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,r", 0, 0, match_opcode
, 0 },
2052 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,r", 0, 0, match_opcode
, 0 },
2053 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,t,R", 0, 0, match_opcode
, 0 },
2054 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,t,R", 0, 0, match_opcode
, 0 },
2055 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,t,R", 0, 0, match_opcode
, 0 },
2056 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,t,R", 0, 0, match_opcode
, 0 },
2057 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,s,T,R", 0, 0, match_opcode
, 0 },
2058 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,s,T,R", 0, 0, match_opcode
, 0 },
2059 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,d,S,T,R", 0, 0, match_opcode
, 0 },
2060 {"r4", 0, INSN_CLASS_F
, "O4,F3,F2,D,S,T,R", 0, 0, match_opcode
, 0 },
2062 {"i", 0, INSN_CLASS_I
, "O4,F3,d,s,j", 0, 0, match_opcode
, 0 },
2063 {"i", 0, INSN_CLASS_F
, "O4,F3,D,s,j", 0, 0, match_opcode
, 0 },
2064 {"i", 0, INSN_CLASS_F
, "O4,F3,d,S,j", 0, 0, match_opcode
, 0 },
2065 {"i", 0, INSN_CLASS_F
, "O4,F3,D,S,j", 0, 0, match_opcode
, 0 },
2066 {"i", 0, INSN_CLASS_I
, "O4,F3,d,o(s)", 0, 0, match_opcode
, 0 },
2067 {"i", 0, INSN_CLASS_F
, "O4,F3,D,o(s)", 0, 0, match_opcode
, 0 },
2069 {"s", 0, INSN_CLASS_I
, "O4,F3,t,q(s)", 0, 0, match_opcode
, 0 },
2070 {"s", 0, INSN_CLASS_F
, "O4,F3,T,q(s)", 0, 0, match_opcode
, 0 },
2072 {"sb", 0, INSN_CLASS_I
, "O4,F3,s,t,p", 0, 0, match_opcode
, 0 },
2073 {"sb", 0, INSN_CLASS_F
, "O4,F3,S,t,p", 0, 0, match_opcode
, 0 },
2074 {"sb", 0, INSN_CLASS_F
, "O4,F3,s,T,p", 0, 0, match_opcode
, 0 },
2075 {"sb", 0, INSN_CLASS_F
, "O4,F3,S,T,p", 0, 0, match_opcode
, 0 },
2076 {"b", 0, INSN_CLASS_I
, "O4,F3,s,t,p", 0, 0, match_opcode
, 0 },
2077 {"b", 0, INSN_CLASS_F
, "O4,F3,S,t,p", 0, 0, match_opcode
, 0 },
2078 {"b", 0, INSN_CLASS_F
, "O4,F3,s,T,p", 0, 0, match_opcode
, 0 },
2079 {"b", 0, INSN_CLASS_F
, "O4,F3,S,T,p", 0, 0, match_opcode
, 0 },
2081 {"u", 0, INSN_CLASS_I
, "O4,d,u", 0, 0, match_opcode
, 0 },
2082 {"u", 0, INSN_CLASS_F
, "O4,D,u", 0, 0, match_opcode
, 0 },
2084 {"uj", 0, INSN_CLASS_I
, "O4,d,a", 0, 0, match_opcode
, 0 },
2085 {"uj", 0, INSN_CLASS_F
, "O4,D,a", 0, 0, match_opcode
, 0 },
2086 {"j", 0, INSN_CLASS_I
, "O4,d,a", 0, 0, match_opcode
, 0 },
2087 {"j", 0, INSN_CLASS_F
, "O4,D,a", 0, 0, match_opcode
, 0 },
2089 {"cr", 0, INSN_CLASS_C
, "O2,CF4,d,CV", 0, 0, match_opcode
, 0 },
2090 {"cr", 0, INSN_CLASS_F_AND_C
, "O2,CF4,D,CV", 0, 0, match_opcode
, 0 },
2091 {"cr", 0, INSN_CLASS_F_AND_C
, "O2,CF4,d,CT", 0, 0, match_opcode
, 0 },
2092 {"cr", 0, INSN_CLASS_F_AND_C
, "O2,CF4,D,CT", 0, 0, match_opcode
, 0 },
2094 {"ci", 0, INSN_CLASS_C
, "O2,CF3,d,Co", 0, 0, match_opcode
, 0 },
2095 {"ci", 0, INSN_CLASS_F_AND_C
, "O2,CF3,D,Co", 0, 0, match_opcode
, 0 },
2097 {"ciw", 0, INSN_CLASS_C
, "O2,CF3,Ct,C8", 0, 0, match_opcode
, 0 },
2098 {"ciw", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C8", 0, 0, match_opcode
, 0 },
2100 {"css", 0, INSN_CLASS_C
, "O2,CF3,CV,C6", 0, 0, match_opcode
, 0 },
2101 {"css", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CT,C6", 0, 0, match_opcode
, 0 },
2103 {"cl", 0, INSN_CLASS_C
, "O2,CF3,Ct,C5(Cs)", 0, 0, match_opcode
, 0 },
2104 {"cl", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(Cs)", 0, 0, match_opcode
, 0 },
2105 {"cl", 0, INSN_CLASS_F_AND_C
, "O2,CF3,Ct,C5(CS)", 0, 0, match_opcode
, 0 },
2106 {"cl", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(CS)", 0, 0, match_opcode
, 0 },
2108 {"cs", 0, INSN_CLASS_C
, "O2,CF3,Ct,C5(Cs)", 0, 0, match_opcode
, 0 },
2109 {"cs", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(Cs)", 0, 0, match_opcode
, 0 },
2110 {"cs", 0, INSN_CLASS_F_AND_C
, "O2,CF3,Ct,C5(CS)", 0, 0, match_opcode
, 0 },
2111 {"cs", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CD,C5(CS)", 0, 0, match_opcode
, 0 },
2113 {"ca", 0, INSN_CLASS_C
, "O2,CF6,CF2,Cs,Ct", 0, 0, match_opcode
, 0 },
2114 {"ca", 0, INSN_CLASS_F_AND_C
, "O2,CF6,CF2,CS,Ct", 0, 0, match_opcode
, 0 },
2115 {"ca", 0, INSN_CLASS_F_AND_C
, "O2,CF6,CF2,Cs,CD", 0, 0, match_opcode
, 0 },
2116 {"ca", 0, INSN_CLASS_F_AND_C
, "O2,CF6,CF2,CS,CD", 0, 0, match_opcode
, 0 },
2118 {"cb", 0, INSN_CLASS_C
, "O2,CF3,Cs,Cp", 0, 0, match_opcode
, 0 },
2119 {"cb", 0, INSN_CLASS_F_AND_C
, "O2,CF3,CS,Cp", 0, 0, match_opcode
, 0 },
2121 {"cj", 0, INSN_CLASS_C
, "O2,CF3,Ca", 0, 0, match_opcode
, 0 },
2123 /* Terminate the list. */
2124 {0, 0, INSN_CLASS_NONE
, 0, 0, 0, 0, 0}