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