1/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
2|* *|
3|* Machine Code Emitter *|
4|* *|
5|* Automatically generated file, do not edit! *|
6|* *|
7\*===----------------------------------------------------------------------===*/
8
9uint64_t RISCVMCCodeEmitter::getBinaryCodeForInstr(const MCInst &MI,
10 SmallVectorImpl<MCFixup> &Fixups,
11 const MCSubtargetInfo &STI) const {
12 static const uint64_t InstBits[] = {
13 UINT64_C(2583691323), // AADD
14 UINT64_C(3120562235), // AADDU
15 UINT64_C(1617956883), // ABS
16 UINT64_C(1617956891), // ABSW
17 UINT64_C(51), // ADD
18 UINT64_C(2248171547), // ADDD
19 UINT64_C(19), // ADDI
20 UINT64_C(27), // ADDIW
21 UINT64_C(59), // ADDW
22 UINT64_C(134217787), // ADD_UW
23 UINT64_C(704643123), // AES32DSI
24 UINT64_C(771751987), // AES32DSMI
25 UINT64_C(570425395), // AES32ESI
26 UINT64_C(637534259), // AES32ESMI
27 UINT64_C(973078579), // AES64DS
28 UINT64_C(1040187443), // AES64DSM
29 UINT64_C(838860851), // AES64ES
30 UINT64_C(905969715), // AES64ESM
31 UINT64_C(805310483), // AES64IM
32 UINT64_C(822087699), // AES64KS1I
33 UINT64_C(2113929267), // AES64KS2
34 UINT64_C(33566779), // AIF_AMOADDG_D
35 UINT64_C(33562683), // AIF_AMOADDG_W
36 UINT64_C(12347), // AIF_AMOADDL_D
37 UINT64_C(8251), // AIF_AMOADDL_W
38 UINT64_C(1644179515), // AIF_AMOANDG_D
39 UINT64_C(1644175419), // AIF_AMOANDG_W
40 UINT64_C(1610625083), // AIF_AMOANDL_D
41 UINT64_C(1610620987), // AIF_AMOANDL_W
42 UINT64_C(4060098619), // AIF_AMOCMPSWAPG_D
43 UINT64_C(4060094523), // AIF_AMOCMPSWAPG_W
44 UINT64_C(4026544187), // AIF_AMOCMPSWAPL_D
45 UINT64_C(4026540091), // AIF_AMOCMPSWAPL_W
46 UINT64_C(2717921339), // AIF_AMOMAXG_D
47 UINT64_C(2717917243), // AIF_AMOMAXG_W
48 UINT64_C(2684366907), // AIF_AMOMAXL_D
49 UINT64_C(2684362811), // AIF_AMOMAXL_W
50 UINT64_C(3791663163), // AIF_AMOMAXUG_D
51 UINT64_C(3791659067), // AIF_AMOMAXUG_W
52 UINT64_C(3758108731), // AIF_AMOMAXUL_D
53 UINT64_C(3758104635), // AIF_AMOMAXUL_W
54 UINT64_C(2181050427), // AIF_AMOMING_D
55 UINT64_C(2181046331), // AIF_AMOMING_W
56 UINT64_C(2147495995), // AIF_AMOMINL_D
57 UINT64_C(2147491899), // AIF_AMOMINL_W
58 UINT64_C(3254792251), // AIF_AMOMINUG_D
59 UINT64_C(3254788155), // AIF_AMOMINUG_W
60 UINT64_C(3221237819), // AIF_AMOMINUL_D
61 UINT64_C(3221233723), // AIF_AMOMINUL_W
62 UINT64_C(1107308603), // AIF_AMOORG_D
63 UINT64_C(1107304507), // AIF_AMOORG_W
64 UINT64_C(1073754171), // AIF_AMOORL_D
65 UINT64_C(1073750075), // AIF_AMOORL_W
66 UINT64_C(167784507), // AIF_AMOSWAPG_D
67 UINT64_C(167780411), // AIF_AMOSWAPG_W
68 UINT64_C(134230075), // AIF_AMOSWAPL_D
69 UINT64_C(134225979), // AIF_AMOSWAPL_W
70 UINT64_C(570437691), // AIF_AMOXORG_D
71 UINT64_C(570433595), // AIF_AMOXORG_W
72 UINT64_C(536883259), // AIF_AMOXORL_D
73 UINT64_C(536879163), // AIF_AMOXORL_W
74 UINT64_C(2147512379), // AIF_BITMIXB
75 UINT64_C(2281705595), // AIF_CUBEFACEIDX_PS
76 UINT64_C(2281701499), // AIF_CUBEFACE_PS
77 UINT64_C(2281709691), // AIF_CUBESGNSC_PS
78 UINT64_C(2281713787), // AIF_CUBESGNTC_PS
79 UINT64_C(67108927), // AIF_FADDI_PI
80 UINT64_C(100663419), // AIF_FADD_PI
81 UINT64_C(123), // AIF_FADD_PS
82 UINT64_C(2248163339), // AIF_FAMOADDG_PI
83 UINT64_C(100679691), // AIF_FAMOADDL_PI
84 UINT64_C(2516598795), // AIF_FAMOANDG_PI
85 UINT64_C(369115147), // AIF_FAMOANDL_PI
86 UINT64_C(3053469707), // AIF_FAMOMAXG_PI
87 UINT64_C(2818588683), // AIF_FAMOMAXG_PS
88 UINT64_C(905986059), // AIF_FAMOMAXL_PI
89 UINT64_C(671105035), // AIF_FAMOMAXL_PS
90 UINT64_C(3321905163), // AIF_FAMOMAXUG_PI
91 UINT64_C(1174421515), // AIF_FAMOMAXUL_PI
92 UINT64_C(2919251979), // AIF_FAMOMING_PI
93 UINT64_C(2952806411), // AIF_FAMOMING_PS
94 UINT64_C(771768331), // AIF_FAMOMINL_PI
95 UINT64_C(805322763), // AIF_FAMOMINL_PS
96 UINT64_C(3187687435), // AIF_FAMOMINUG_PI
97 UINT64_C(1040203787), // AIF_FAMOMINUL_PI
98 UINT64_C(2650816523), // AIF_FAMOORG_PI
99 UINT64_C(503332875), // AIF_FAMOORL_PI
100 UINT64_C(2382381067), // AIF_FAMOSWAPG_PI
101 UINT64_C(234897419), // AIF_FAMOSWAPL_PI
102 UINT64_C(2785034251), // AIF_FAMOXORG_PI
103 UINT64_C(637550603), // AIF_FAMOXORL_PI
104 UINT64_C(67113023), // AIF_FANDI_PI
105 UINT64_C(100692091), // AIF_FAND_PI
106 UINT64_C(95), // AIF_FBCI_PI
107 UINT64_C(31), // AIF_FBCI_PS
108 UINT64_C(12299), // AIF_FBCX_PS
109 UINT64_C(11), // AIF_FBC_PS
110 UINT64_C(3758100603), // AIF_FCLASS_PS
111 UINT64_C(119), // AIF_FCMOVM_PS
112 UINT64_C(67117119), // AIF_FCMOV_PS
113 UINT64_C(3635413115), // AIF_FCVT_F10_PS
114 UINT64_C(3632267387), // AIF_FCVT_F11_PS
115 UINT64_C(3633315963), // AIF_FCVT_F16_PS
116 UINT64_C(3498049659), // AIF_FCVT_PS_F10
117 UINT64_C(3499098235), // AIF_FCVT_PS_F11
118 UINT64_C(3500146811), // AIF_FCVT_PS_F16
119 UINT64_C(3489661051), // AIF_FCVT_PS_PW
120 UINT64_C(3490709627), // AIF_FCVT_PS_PWU
121 UINT64_C(3491758203), // AIF_FCVT_PS_RAST
122 UINT64_C(3515875451), // AIF_FCVT_PS_SN16
123 UINT64_C(3517972603), // AIF_FCVT_PS_SN8
124 UINT64_C(3508535419), // AIF_FCVT_PS_UN10
125 UINT64_C(3507486843), // AIF_FCVT_PS_UN16
126 UINT64_C(3513778299), // AIF_FCVT_PS_UN2
127 UINT64_C(3506438267), // AIF_FCVT_PS_UN24
128 UINT64_C(3509583995), // AIF_FCVT_PS_UN8
129 UINT64_C(3222274171), // AIF_FCVT_PWU_PS
130 UINT64_C(3221225595), // AIF_FCVT_PW_PS
131 UINT64_C(3223322747), // AIF_FCVT_RAST_PS
132 UINT64_C(3650093179), // AIF_FCVT_SN16_PS
133 UINT64_C(3652190331), // AIF_FCVT_SN8_PS
134 UINT64_C(3642753147), // AIF_FCVT_UN10_PS
135 UINT64_C(3641704571), // AIF_FCVT_UN16_PS
136 UINT64_C(3640655995), // AIF_FCVT_UN24_PS
137 UINT64_C(3647996027), // AIF_FCVT_UN2_PS
138 UINT64_C(3643801723), // AIF_FCVT_UN8_PS
139 UINT64_C(503320699), // AIF_FDIVU_PI
140 UINT64_C(503316603), // AIF_FDIV_PI
141 UINT64_C(402653307), // AIF_FDIV_PS
142 UINT64_C(2684379259), // AIF_FEQM_PS
143 UINT64_C(2785026171), // AIF_FEQ_PI
144 UINT64_C(2684362875), // AIF_FEQ_PS
145 UINT64_C(1480589435), // AIF_FEXP_PS
146 UINT64_C(1478492283), // AIF_FFRC_PS
147 UINT64_C(134221835), // AIF_FG32B_PS
148 UINT64_C(268439563), // AIF_FG32H_PS
149 UINT64_C(536875019), // AIF_FG32W_PS
150 UINT64_C(2181066763), // AIF_FGBG_PS
151 UINT64_C(2147512331), // AIF_FGBL_PS
152 UINT64_C(1207963659), // AIF_FGB_PS
153 UINT64_C(2315284491), // AIF_FGHG_PS
154 UINT64_C(2281730059), // AIF_FGHL_PS
155 UINT64_C(1342181387), // AIF_FGH_PS
156 UINT64_C(2449502219), // AIF_FGWG_PS
157 UINT64_C(2415947787), // AIF_FGWL_PS
158 UINT64_C(1610616843), // AIF_FGW_PS
159 UINT64_C(2684371067), // AIF_FLEM_PS
160 UINT64_C(2785017979), // AIF_FLE_PI
161 UINT64_C(2684354683), // AIF_FLE_PS
162 UINT64_C(1479540859), // AIF_FLOG_PS
163 UINT64_C(20487), // AIF_FLQ2
164 UINT64_C(1040187515), // AIF_FLTM_PI
165 UINT64_C(2684375163), // AIF_FLTM_PS
166 UINT64_C(2785030267), // AIF_FLTU_PI
167 UINT64_C(2785022075), // AIF_FLT_PI
168 UINT64_C(2684358779), // AIF_FLT_PS
169 UINT64_C(302018571), // AIF_FLWG_PS
170 UINT64_C(268464139), // AIF_FLWL_PS
171 UINT64_C(8203), // AIF_FLW_PS
172 UINT64_C(91), // AIF_FMADD_PS
173 UINT64_C(771764347), // AIF_FMAXU_PI
174 UINT64_C(771756155), // AIF_FMAX_PI
175 UINT64_C(671092859), // AIF_FMAX_PS
176 UINT64_C(771760251), // AIF_FMINU_PI
177 UINT64_C(771752059), // AIF_FMIN_PI
178 UINT64_C(671088763), // AIF_FMIN_PS
179 UINT64_C(33554523), // AIF_FMSUB_PS
180 UINT64_C(369107067), // AIF_FMULHU_PI
181 UINT64_C(369102971), // AIF_FMULH_PI
182 UINT64_C(369098875), // AIF_FMUL_PI
183 UINT64_C(268435579), // AIF_FMUL_PS
184 UINT64_C(3758104699), // AIF_FMVS_X_PS
185 UINT64_C(3758096507), // AIF_FMVZ_X_PS
186 UINT64_C(100663387), // AIF_FNMADD_PS
187 UINT64_C(67108955), // AIF_FNMSUB_PS
188 UINT64_C(100671611), // AIF_FNOT_PI
189 UINT64_C(100687995), // AIF_FOR_PI
190 UINT64_C(637534331), // AIF_FPACKREPB_PI
191 UINT64_C(637538427), // AIF_FPACKREPH_PI
192 UINT64_C(805306491), // AIF_FRCP_FIX_RAST
193 UINT64_C(1483735163), // AIF_FRCP_PS
194 UINT64_C(503328891), // AIF_FREMU_PI
195 UINT64_C(503324795), // AIF_FREM_PI
196 UINT64_C(1477443707), // AIF_FROUND_PS
197 UINT64_C(1484783739), // AIF_FRSQ_PS
198 UINT64_C(100675707), // AIF_FSAT8_PI
199 UINT64_C(101724283), // AIF_FSATU8_PI
200 UINT64_C(2281705483), // AIF_FSC32B_PS
201 UINT64_C(2415923211), // AIF_FSC32H_PS
202 UINT64_C(2684358667), // AIF_FSC32W_PS
203 UINT64_C(3254808587), // AIF_FSCBG_PS
204 UINT64_C(3221254155), // AIF_FSCBL_PS
205 UINT64_C(3355447307), // AIF_FSCB_PS
206 UINT64_C(3389026315), // AIF_FSCHG_PS
207 UINT64_C(3355471883), // AIF_FSCHL_PS
208 UINT64_C(3489665035), // AIF_FSCH_PS
209 UINT64_C(3523244043), // AIF_FSCWG_PS
210 UINT64_C(3489689611), // AIF_FSCWL_PS
211 UINT64_C(3758100491), // AIF_FSCW_PS
212 UINT64_C(2785034363), // AIF_FSETM_PI
213 UINT64_C(536875131), // AIF_FSGNJN_PS
214 UINT64_C(536879227), // AIF_FSGNJX_PS
215 UINT64_C(536871035), // AIF_FSGNJ_PS
216 UINT64_C(1482686587), // AIF_FSIN_PS
217 UINT64_C(1308627067), // AIF_FSLLI_PI
218 UINT64_C(100667515), // AIF_FSLL_PI
219 UINT64_C(20519), // AIF_FSQ2
220 UINT64_C(1476395131), // AIF_FSQRT_PS
221 UINT64_C(1308651643), // AIF_FSRAI_PI
222 UINT64_C(234901627), // AIF_FSRA_PI
223 UINT64_C(1308643451), // AIF_FSRLI_PI
224 UINT64_C(100683899), // AIF_FSRL_PI
225 UINT64_C(234881147), // AIF_FSUB_PI
226 UINT64_C(134217851), // AIF_FSUB_PS
227 UINT64_C(1375760395), // AIF_FSWG_PS
228 UINT64_C(3858759803), // AIF_FSWIZZ_PS
229 UINT64_C(1342205963), // AIF_FSWL_PS
230 UINT64_C(24587), // AIF_FSW_PS
231 UINT64_C(100679803), // AIF_FXOR_PI
232 UINT64_C(1711304827), // AIF_MASKAND
233 UINT64_C(1711284347), // AIF_MASKNOT
234 UINT64_C(1711300731), // AIF_MASKOR
235 UINT64_C(1375731835), // AIF_MASKPOPC
236 UINT64_C(1409286267), // AIF_MASKPOPCZ
237 UINT64_C(1577058427), // AIF_MASKPOPC_ET_RAST
238 UINT64_C(1711292539), // AIF_MASKXOR
239 UINT64_C(3590328443), // AIF_MOVA_M_X
240 UINT64_C(3590324347), // AIF_MOVA_X_M
241 UINT64_C(1442840699), // AIF_MOV_M_X
242 UINT64_C(2147508283), // AIF_PACKB
243 UINT64_C(302002235), // AIF_SBG
244 UINT64_C(268447803), // AIF_SBL
245 UINT64_C(436219963), // AIF_SHG
246 UINT64_C(402665531), // AIF_SHL
247 UINT64_C(47), // AMOADD_B
248 UINT64_C(67108911), // AMOADD_B_AQ
249 UINT64_C(100663343), // AMOADD_B_AQRL
250 UINT64_C(33554479), // AMOADD_B_RL
251 UINT64_C(12335), // AMOADD_D
252 UINT64_C(67121199), // AMOADD_D_AQ
253 UINT64_C(100675631), // AMOADD_D_AQRL
254 UINT64_C(33566767), // AMOADD_D_RL
255 UINT64_C(4143), // AMOADD_H
256 UINT64_C(67113007), // AMOADD_H_AQ
257 UINT64_C(100667439), // AMOADD_H_AQRL
258 UINT64_C(33558575), // AMOADD_H_RL
259 UINT64_C(8239), // AMOADD_W
260 UINT64_C(67117103), // AMOADD_W_AQ
261 UINT64_C(100671535), // AMOADD_W_AQRL
262 UINT64_C(33562671), // AMOADD_W_RL
263 UINT64_C(1610612783), // AMOAND_B
264 UINT64_C(1677721647), // AMOAND_B_AQ
265 UINT64_C(1711276079), // AMOAND_B_AQRL
266 UINT64_C(1644167215), // AMOAND_B_RL
267 UINT64_C(1610625071), // AMOAND_D
268 UINT64_C(1677733935), // AMOAND_D_AQ
269 UINT64_C(1711288367), // AMOAND_D_AQRL
270 UINT64_C(1644179503), // AMOAND_D_RL
271 UINT64_C(1610616879), // AMOAND_H
272 UINT64_C(1677725743), // AMOAND_H_AQ
273 UINT64_C(1711280175), // AMOAND_H_AQRL
274 UINT64_C(1644171311), // AMOAND_H_RL
275 UINT64_C(1610620975), // AMOAND_W
276 UINT64_C(1677729839), // AMOAND_W_AQ
277 UINT64_C(1711284271), // AMOAND_W_AQRL
278 UINT64_C(1644175407), // AMOAND_W_RL
279 UINT64_C(671088687), // AMOCAS_B
280 UINT64_C(738197551), // AMOCAS_B_AQ
281 UINT64_C(771751983), // AMOCAS_B_AQRL
282 UINT64_C(704643119), // AMOCAS_B_RL
283 UINT64_C(671100975), // AMOCAS_D_RV32
284 UINT64_C(738209839), // AMOCAS_D_RV32_AQ
285 UINT64_C(771764271), // AMOCAS_D_RV32_AQRL
286 UINT64_C(704655407), // AMOCAS_D_RV32_RL
287 UINT64_C(671100975), // AMOCAS_D_RV64
288 UINT64_C(738209839), // AMOCAS_D_RV64_AQ
289 UINT64_C(771764271), // AMOCAS_D_RV64_AQRL
290 UINT64_C(704655407), // AMOCAS_D_RV64_RL
291 UINT64_C(671092783), // AMOCAS_H
292 UINT64_C(738201647), // AMOCAS_H_AQ
293 UINT64_C(771756079), // AMOCAS_H_AQRL
294 UINT64_C(704647215), // AMOCAS_H_RL
295 UINT64_C(671105071), // AMOCAS_Q
296 UINT64_C(738213935), // AMOCAS_Q_AQ
297 UINT64_C(771768367), // AMOCAS_Q_AQRL
298 UINT64_C(704659503), // AMOCAS_Q_RL
299 UINT64_C(671096879), // AMOCAS_W
300 UINT64_C(738205743), // AMOCAS_W_AQ
301 UINT64_C(771760175), // AMOCAS_W_AQRL
302 UINT64_C(704651311), // AMOCAS_W_RL
303 UINT64_C(3758096431), // AMOMAXU_B
304 UINT64_C(3825205295), // AMOMAXU_B_AQ
305 UINT64_C(3858759727), // AMOMAXU_B_AQRL
306 UINT64_C(3791650863), // AMOMAXU_B_RL
307 UINT64_C(3758108719), // AMOMAXU_D
308 UINT64_C(3825217583), // AMOMAXU_D_AQ
309 UINT64_C(3858772015), // AMOMAXU_D_AQRL
310 UINT64_C(3791663151), // AMOMAXU_D_RL
311 UINT64_C(3758100527), // AMOMAXU_H
312 UINT64_C(3825209391), // AMOMAXU_H_AQ
313 UINT64_C(3858763823), // AMOMAXU_H_AQRL
314 UINT64_C(3791654959), // AMOMAXU_H_RL
315 UINT64_C(3758104623), // AMOMAXU_W
316 UINT64_C(3825213487), // AMOMAXU_W_AQ
317 UINT64_C(3858767919), // AMOMAXU_W_AQRL
318 UINT64_C(3791659055), // AMOMAXU_W_RL
319 UINT64_C(2684354607), // AMOMAX_B
320 UINT64_C(2751463471), // AMOMAX_B_AQ
321 UINT64_C(2785017903), // AMOMAX_B_AQRL
322 UINT64_C(2717909039), // AMOMAX_B_RL
323 UINT64_C(2684366895), // AMOMAX_D
324 UINT64_C(2751475759), // AMOMAX_D_AQ
325 UINT64_C(2785030191), // AMOMAX_D_AQRL
326 UINT64_C(2717921327), // AMOMAX_D_RL
327 UINT64_C(2684358703), // AMOMAX_H
328 UINT64_C(2751467567), // AMOMAX_H_AQ
329 UINT64_C(2785021999), // AMOMAX_H_AQRL
330 UINT64_C(2717913135), // AMOMAX_H_RL
331 UINT64_C(2684362799), // AMOMAX_W
332 UINT64_C(2751471663), // AMOMAX_W_AQ
333 UINT64_C(2785026095), // AMOMAX_W_AQRL
334 UINT64_C(2717917231), // AMOMAX_W_RL
335 UINT64_C(3221225519), // AMOMINU_B
336 UINT64_C(3288334383), // AMOMINU_B_AQ
337 UINT64_C(3321888815), // AMOMINU_B_AQRL
338 UINT64_C(3254779951), // AMOMINU_B_RL
339 UINT64_C(3221237807), // AMOMINU_D
340 UINT64_C(3288346671), // AMOMINU_D_AQ
341 UINT64_C(3321901103), // AMOMINU_D_AQRL
342 UINT64_C(3254792239), // AMOMINU_D_RL
343 UINT64_C(3221229615), // AMOMINU_H
344 UINT64_C(3288338479), // AMOMINU_H_AQ
345 UINT64_C(3321892911), // AMOMINU_H_AQRL
346 UINT64_C(3254784047), // AMOMINU_H_RL
347 UINT64_C(3221233711), // AMOMINU_W
348 UINT64_C(3288342575), // AMOMINU_W_AQ
349 UINT64_C(3321897007), // AMOMINU_W_AQRL
350 UINT64_C(3254788143), // AMOMINU_W_RL
351 UINT64_C(2147483695), // AMOMIN_B
352 UINT64_C(2214592559), // AMOMIN_B_AQ
353 UINT64_C(2248146991), // AMOMIN_B_AQRL
354 UINT64_C(2181038127), // AMOMIN_B_RL
355 UINT64_C(2147495983), // AMOMIN_D
356 UINT64_C(2214604847), // AMOMIN_D_AQ
357 UINT64_C(2248159279), // AMOMIN_D_AQRL
358 UINT64_C(2181050415), // AMOMIN_D_RL
359 UINT64_C(2147487791), // AMOMIN_H
360 UINT64_C(2214596655), // AMOMIN_H_AQ
361 UINT64_C(2248151087), // AMOMIN_H_AQRL
362 UINT64_C(2181042223), // AMOMIN_H_RL
363 UINT64_C(2147491887), // AMOMIN_W
364 UINT64_C(2214600751), // AMOMIN_W_AQ
365 UINT64_C(2248155183), // AMOMIN_W_AQRL
366 UINT64_C(2181046319), // AMOMIN_W_RL
367 UINT64_C(1073741871), // AMOOR_B
368 UINT64_C(1140850735), // AMOOR_B_AQ
369 UINT64_C(1174405167), // AMOOR_B_AQRL
370 UINT64_C(1107296303), // AMOOR_B_RL
371 UINT64_C(1073754159), // AMOOR_D
372 UINT64_C(1140863023), // AMOOR_D_AQ
373 UINT64_C(1174417455), // AMOOR_D_AQRL
374 UINT64_C(1107308591), // AMOOR_D_RL
375 UINT64_C(1073745967), // AMOOR_H
376 UINT64_C(1140854831), // AMOOR_H_AQ
377 UINT64_C(1174409263), // AMOOR_H_AQRL
378 UINT64_C(1107300399), // AMOOR_H_RL
379 UINT64_C(1073750063), // AMOOR_W
380 UINT64_C(1140858927), // AMOOR_W_AQ
381 UINT64_C(1174413359), // AMOOR_W_AQRL
382 UINT64_C(1107304495), // AMOOR_W_RL
383 UINT64_C(134217775), // AMOSWAP_B
384 UINT64_C(201326639), // AMOSWAP_B_AQ
385 UINT64_C(234881071), // AMOSWAP_B_AQRL
386 UINT64_C(167772207), // AMOSWAP_B_RL
387 UINT64_C(134230063), // AMOSWAP_D
388 UINT64_C(201338927), // AMOSWAP_D_AQ
389 UINT64_C(234893359), // AMOSWAP_D_AQRL
390 UINT64_C(167784495), // AMOSWAP_D_RL
391 UINT64_C(134221871), // AMOSWAP_H
392 UINT64_C(201330735), // AMOSWAP_H_AQ
393 UINT64_C(234885167), // AMOSWAP_H_AQRL
394 UINT64_C(167776303), // AMOSWAP_H_RL
395 UINT64_C(134225967), // AMOSWAP_W
396 UINT64_C(201334831), // AMOSWAP_W_AQ
397 UINT64_C(234889263), // AMOSWAP_W_AQRL
398 UINT64_C(167780399), // AMOSWAP_W_RL
399 UINT64_C(536870959), // AMOXOR_B
400 UINT64_C(603979823), // AMOXOR_B_AQ
401 UINT64_C(637534255), // AMOXOR_B_AQRL
402 UINT64_C(570425391), // AMOXOR_B_RL
403 UINT64_C(536883247), // AMOXOR_D
404 UINT64_C(603992111), // AMOXOR_D_AQ
405 UINT64_C(637546543), // AMOXOR_D_AQRL
406 UINT64_C(570437679), // AMOXOR_D_RL
407 UINT64_C(536875055), // AMOXOR_H
408 UINT64_C(603983919), // AMOXOR_H_AQ
409 UINT64_C(637538351), // AMOXOR_H_AQRL
410 UINT64_C(570429487), // AMOXOR_H_RL
411 UINT64_C(536879151), // AMOXOR_W
412 UINT64_C(603988015), // AMOXOR_W_AQ
413 UINT64_C(637542447), // AMOXOR_W_AQRL
414 UINT64_C(570433583), // AMOXOR_W_RL
415 UINT64_C(28723), // AND
416 UINT64_C(28691), // ANDI
417 UINT64_C(1073770547), // ANDN
418 UINT64_C(3657433147), // ASUB
419 UINT64_C(4194304059), // ASUBU
420 UINT64_C(23), // AUIPC
421 UINT64_C(1207963699), // BCLR
422 UINT64_C(1207963667), // BCLRI
423 UINT64_C(99), // BEQ
424 UINT64_C(8291), // BEQI
425 UINT64_C(1207980083), // BEXT
426 UINT64_C(1207980051), // BEXTI
427 UINT64_C(20579), // BGE
428 UINT64_C(28771), // BGEU
429 UINT64_C(1744834611), // BINV
430 UINT64_C(1744834579), // BINVI
431 UINT64_C(16483), // BLT
432 UINT64_C(24675), // BLTU
433 UINT64_C(4195), // BNE
434 UINT64_C(12387), // BNEI
435 UINT64_C(1752190995), // BREV8
436 UINT64_C(671092787), // BSET
437 UINT64_C(671092755), // BSETI
438 UINT64_C(1056783), // CBO_CLEAN
439 UINT64_C(2105359), // CBO_FLUSH
440 UINT64_C(8207), // CBO_INVAL
441 UINT64_C(4202511), // CBO_ZERO
442 UINT64_C(167776307), // CLMUL
443 UINT64_C(167784499), // CLMULH
444 UINT64_C(167780403), // CLMULR
445 UINT64_C(1613762579), // CLS
446 UINT64_C(1613762587), // CLSW
447 UINT64_C(1610616851), // CLZ
448 UINT64_C(1610616859), // CLZW
449 UINT64_C(40962), // CM_JALT
450 UINT64_C(40962), // CM_JT
451 UINT64_C(44130), // CM_MVA01S
452 UINT64_C(44066), // CM_MVSA01
453 UINT64_C(47618), // CM_POP
454 UINT64_C(48642), // CM_POPRET
455 UINT64_C(48130), // CM_POPRETZ
456 UINT64_C(47106), // CM_PUSH
457 UINT64_C(1612714003), // CPOP
458 UINT64_C(1612714011), // CPOPW
459 UINT64_C(12403), // CSRRC
460 UINT64_C(28787), // CSRRCI
461 UINT64_C(8307), // CSRRS
462 UINT64_C(24691), // CSRRSI
463 UINT64_C(4211), // CSRRW
464 UINT64_C(20595), // CSRRWI
465 UINT64_C(1611665427), // CTZ
466 UINT64_C(1611665435), // CTZW
467 UINT64_C(1342189611), // CV_ABS
468 UINT64_C(1879052411), // CV_ABS_B
469 UINT64_C(1879048315), // CV_ABS_H
470 UINT64_C(8283), // CV_ADDN
471 UINT64_C(2147495979), // CV_ADDNR
472 UINT64_C(2147491931), // CV_ADDRN
473 UINT64_C(2214604843), // CV_ADDRNR
474 UINT64_C(1073750107), // CV_ADDUN
475 UINT64_C(2181050411), // CV_ADDUNR
476 UINT64_C(3221233755), // CV_ADDURN
477 UINT64_C(2248159275), // CV_ADDURNR
478 UINT64_C(4219), // CV_ADD_B
479 UINT64_C(1811947643), // CV_ADD_DIV2
480 UINT64_C(1811955835), // CV_ADD_DIV4
481 UINT64_C(1811964027), // CV_ADD_DIV8
482 UINT64_C(123), // CV_ADD_H
483 UINT64_C(28795), // CV_ADD_SCI_B
484 UINT64_C(24699), // CV_ADD_SCI_H
485 UINT64_C(20603), // CV_ADD_SC_B
486 UINT64_C(16507), // CV_ADD_SC_H
487 UINT64_C(1744834683), // CV_AND_B
488 UINT64_C(1744830587), // CV_AND_H
489 UINT64_C(1744859259), // CV_AND_SCI_B
490 UINT64_C(1744855163), // CV_AND_SCI_H
491 UINT64_C(1744851067), // CV_AND_SC_B
492 UINT64_C(1744846971), // CV_AND_SC_H
493 UINT64_C(402657403), // CV_AVGU_B
494 UINT64_C(402653307), // CV_AVGU_H
495 UINT64_C(402681979), // CV_AVGU_SCI_B
496 UINT64_C(402677883), // CV_AVGU_SCI_H
497 UINT64_C(402673787), // CV_AVGU_SC_B
498 UINT64_C(402669691), // CV_AVGU_SC_H
499 UINT64_C(268439675), // CV_AVG_B
500 UINT64_C(268435579), // CV_AVG_H
501 UINT64_C(268464251), // CV_AVG_SCI_B
502 UINT64_C(268460155), // CV_AVG_SCI_H
503 UINT64_C(268456059), // CV_AVG_SC_B
504 UINT64_C(268451963), // CV_AVG_SC_H
505 UINT64_C(4187), // CV_BCLR
506 UINT64_C(939536427), // CV_BCLRR
507 UINT64_C(24587), // CV_BEQIMM
508 UINT64_C(3221229659), // CV_BITREV
509 UINT64_C(28683), // CV_BNEIMM
510 UINT64_C(1073746011), // CV_BSET
511 UINT64_C(973090859), // CV_BSETR
512 UINT64_C(1174417451), // CV_CLB
513 UINT64_C(1879060523), // CV_CLIP
514 UINT64_C(1946169387), // CV_CLIPR
515 UINT64_C(1912614955), // CV_CLIPU
516 UINT64_C(1979723819), // CV_CLIPUR
517 UINT64_C(67113083), // CV_CMPEQ_B
518 UINT64_C(67108987), // CV_CMPEQ_H
519 UINT64_C(67137659), // CV_CMPEQ_SCI_B
520 UINT64_C(67133563), // CV_CMPEQ_SCI_H
521 UINT64_C(67129467), // CV_CMPEQ_SC_B
522 UINT64_C(67125371), // CV_CMPEQ_SC_H
523 UINT64_C(1006637179), // CV_CMPGEU_B
524 UINT64_C(1006633083), // CV_CMPGEU_H
525 UINT64_C(1006661755), // CV_CMPGEU_SCI_B
526 UINT64_C(1006657659), // CV_CMPGEU_SCI_H
527 UINT64_C(1006653563), // CV_CMPGEU_SC_B
528 UINT64_C(1006649467), // CV_CMPGEU_SC_H
529 UINT64_C(469766267), // CV_CMPGE_B
530 UINT64_C(469762171), // CV_CMPGE_H
531 UINT64_C(469790843), // CV_CMPGE_SCI_B
532 UINT64_C(469786747), // CV_CMPGE_SCI_H
533 UINT64_C(469782651), // CV_CMPGE_SC_B
534 UINT64_C(469778555), // CV_CMPGE_SC_H
535 UINT64_C(872419451), // CV_CMPGTU_B
536 UINT64_C(872415355), // CV_CMPGTU_H
537 UINT64_C(872444027), // CV_CMPGTU_SCI_B
538 UINT64_C(872439931), // CV_CMPGTU_SCI_H
539 UINT64_C(872435835), // CV_CMPGTU_SC_B
540 UINT64_C(872431739), // CV_CMPGTU_SC_H
541 UINT64_C(335548539), // CV_CMPGT_B
542 UINT64_C(335544443), // CV_CMPGT_H
543 UINT64_C(335573115), // CV_CMPGT_SCI_B
544 UINT64_C(335569019), // CV_CMPGT_SCI_H
545 UINT64_C(335564923), // CV_CMPGT_SC_B
546 UINT64_C(335560827), // CV_CMPGT_SC_H
547 UINT64_C(1275072635), // CV_CMPLEU_B
548 UINT64_C(1275068539), // CV_CMPLEU_H
549 UINT64_C(1275097211), // CV_CMPLEU_SCI_B
550 UINT64_C(1275093115), // CV_CMPLEU_SCI_H
551 UINT64_C(1275089019), // CV_CMPLEU_SC_B
552 UINT64_C(1275084923), // CV_CMPLEU_SC_H
553 UINT64_C(738201723), // CV_CMPLE_B
554 UINT64_C(738197627), // CV_CMPLE_H
555 UINT64_C(738226299), // CV_CMPLE_SCI_B
556 UINT64_C(738222203), // CV_CMPLE_SCI_H
557 UINT64_C(738218107), // CV_CMPLE_SC_B
558 UINT64_C(738214011), // CV_CMPLE_SC_H
559 UINT64_C(1140854907), // CV_CMPLTU_B
560 UINT64_C(1140850811), // CV_CMPLTU_H
561 UINT64_C(1140879483), // CV_CMPLTU_SCI_B
562 UINT64_C(1140875387), // CV_CMPLTU_SCI_H
563 UINT64_C(1140871291), // CV_CMPLTU_SC_B
564 UINT64_C(1140867195), // CV_CMPLTU_SC_H
565 UINT64_C(603983995), // CV_CMPLT_B
566 UINT64_C(603979899), // CV_CMPLT_H
567 UINT64_C(604008571), // CV_CMPLT_SCI_B
568 UINT64_C(604004475), // CV_CMPLT_SCI_H
569 UINT64_C(604000379), // CV_CMPLT_SC_B
570 UINT64_C(603996283), // CV_CMPLT_SC_H
571 UINT64_C(201330811), // CV_CMPNE_B
572 UINT64_C(201326715), // CV_CMPNE_H
573 UINT64_C(201355387), // CV_CMPNE_SCI_B
574 UINT64_C(201351291), // CV_CMPNE_SCI_H
575 UINT64_C(201347195), // CV_CMPNE_SC_B
576 UINT64_C(201343099), // CV_CMPNE_SC_H
577 UINT64_C(1207971883), // CV_CNT
578 UINT64_C(1543503995), // CV_CPLXCONJ
579 UINT64_C(1442840699), // CV_CPLXMUL_I
580 UINT64_C(1442848891), // CV_CPLXMUL_I_DIV2
581 UINT64_C(1442857083), // CV_CPLXMUL_I_DIV4
582 UINT64_C(1442865275), // CV_CPLXMUL_I_DIV8
583 UINT64_C(1409286267), // CV_CPLXMUL_R
584 UINT64_C(1409294459), // CV_CPLXMUL_R_DIV2
585 UINT64_C(1409302651), // CV_CPLXMUL_R_DIV4
586 UINT64_C(1409310843), // CV_CPLXMUL_R_DIV8
587 UINT64_C(2415923323), // CV_DOTSP_B
588 UINT64_C(2415919227), // CV_DOTSP_H
589 UINT64_C(2415947899), // CV_DOTSP_SCI_B
590 UINT64_C(2415943803), // CV_DOTSP_SCI_H
591 UINT64_C(2415939707), // CV_DOTSP_SC_B
592 UINT64_C(2415935611), // CV_DOTSP_SC_H
593 UINT64_C(2147487867), // CV_DOTUP_B
594 UINT64_C(2147483771), // CV_DOTUP_H
595 UINT64_C(2147512443), // CV_DOTUP_SCI_B
596 UINT64_C(2147508347), // CV_DOTUP_SCI_H
597 UINT64_C(2147504251), // CV_DOTUP_SC_B
598 UINT64_C(2147500155), // CV_DOTUP_SC_H
599 UINT64_C(2281705595), // CV_DOTUSP_B
600 UINT64_C(2281701499), // CV_DOTUSP_H
601 UINT64_C(2281730171), // CV_DOTUSP_SCI_B
602 UINT64_C(2281726075), // CV_DOTUSP_SCI_H
603 UINT64_C(2281721979), // CV_DOTUSP_SC_B
604 UINT64_C(2281717883), // CV_DOTUSP_SC_H
605 UINT64_C(12299), // CV_ELW
606 UINT64_C(1677733931), // CV_EXTBS
607 UINT64_C(1711288363), // CV_EXTBZ
608 UINT64_C(1610625067), // CV_EXTHS
609 UINT64_C(1644179499), // CV_EXTHZ
610 UINT64_C(91), // CV_EXTRACT
611 UINT64_C(805318699), // CV_EXTRACTR
612 UINT64_C(1073741915), // CV_EXTRACTU
613 UINT64_C(838873131), // CV_EXTRACTUR
614 UINT64_C(3087020155), // CV_EXTRACTU_B
615 UINT64_C(3087016059), // CV_EXTRACTU_H
616 UINT64_C(3087011963), // CV_EXTRACT_B
617 UINT64_C(3087007867), // CV_EXTRACT_H
618 UINT64_C(1107308587), // CV_FF1
619 UINT64_C(1140863019), // CV_FL1
620 UINT64_C(2147483739), // CV_INSERT
621 UINT64_C(872427563), // CV_INSERTR
622 UINT64_C(3087028347), // CV_INSERT_B
623 UINT64_C(3087024251), // CV_INSERT_H
624 UINT64_C(16395), // CV_LBU_ri_inc
625 UINT64_C(402665515), // CV_LBU_rr
626 UINT64_C(268447787), // CV_LBU_rr_inc
627 UINT64_C(11), // CV_LB_ri_inc
628 UINT64_C(134230059), // CV_LB_rr
629 UINT64_C(12331), // CV_LB_rr_inc
630 UINT64_C(20491), // CV_LHU_ri_inc
631 UINT64_C(436219947), // CV_LHU_rr
632 UINT64_C(302002219), // CV_LHU_rr_inc
633 UINT64_C(4107), // CV_LH_ri_inc
634 UINT64_C(167784491), // CV_LH_rr
635 UINT64_C(33566763), // CV_LH_rr_inc
636 UINT64_C(8203), // CV_LW_ri_inc
637 UINT64_C(201338923), // CV_LW_rr
638 UINT64_C(67121195), // CV_LW_rr_inc
639 UINT64_C(2415931435), // CV_MAC
640 UINT64_C(1073766491), // CV_MACHHSN
641 UINT64_C(3221250139), // CV_MACHHSRN
642 UINT64_C(1073770587), // CV_MACHHUN
643 UINT64_C(3221254235), // CV_MACHHURN
644 UINT64_C(24667), // CV_MACSN
645 UINT64_C(2147508315), // CV_MACSRN
646 UINT64_C(28763), // CV_MACUN
647 UINT64_C(2147512411), // CV_MACURN
648 UINT64_C(1509961771), // CV_MAX
649 UINT64_C(1543516203), // CV_MAXU
650 UINT64_C(939528315), // CV_MAXU_B
651 UINT64_C(939524219), // CV_MAXU_H
652 UINT64_C(939552891), // CV_MAXU_SCI_B
653 UINT64_C(939548795), // CV_MAXU_SCI_H
654 UINT64_C(939544699), // CV_MAXU_SC_B
655 UINT64_C(939540603), // CV_MAXU_SC_H
656 UINT64_C(805310587), // CV_MAX_B
657 UINT64_C(805306491), // CV_MAX_H
658 UINT64_C(805335163), // CV_MAX_SCI_B
659 UINT64_C(805331067), // CV_MAX_SCI_H
660 UINT64_C(805326971), // CV_MAX_SC_B
661 UINT64_C(805322875), // CV_MAX_SC_H
662 UINT64_C(1442852907), // CV_MIN
663 UINT64_C(1476407339), // CV_MINU
664 UINT64_C(671092859), // CV_MINU_B
665 UINT64_C(671088763), // CV_MINU_H
666 UINT64_C(671117435), // CV_MINU_SCI_B
667 UINT64_C(671113339), // CV_MINU_SCI_H
668 UINT64_C(671109243), // CV_MINU_SC_B
669 UINT64_C(671105147), // CV_MINU_SC_H
670 UINT64_C(536875131), // CV_MIN_B
671 UINT64_C(536871035), // CV_MIN_H
672 UINT64_C(536899707), // CV_MIN_SCI_B
673 UINT64_C(536895611), // CV_MIN_SCI_H
674 UINT64_C(536891515), // CV_MIN_SC_B
675 UINT64_C(536887419), // CV_MIN_SC_H
676 UINT64_C(2449485867), // CV_MSU
677 UINT64_C(1073758299), // CV_MULHHSN
678 UINT64_C(3221241947), // CV_MULHHSRN
679 UINT64_C(1073762395), // CV_MULHHUN
680 UINT64_C(3221246043), // CV_MULHHURN
681 UINT64_C(16475), // CV_MULSN
682 UINT64_C(2147500123), // CV_MULSRN
683 UINT64_C(20571), // CV_MULUN
684 UINT64_C(2147504219), // CV_MULURN
685 UINT64_C(1476399227), // CV_OR_B
686 UINT64_C(1476395131), // CV_OR_H
687 UINT64_C(1476423803), // CV_OR_SCI_B
688 UINT64_C(1476419707), // CV_OR_SCI_H
689 UINT64_C(1476415611), // CV_OR_SC_B
690 UINT64_C(1476411515), // CV_OR_SC_H
691 UINT64_C(4026531963), // CV_PACK
692 UINT64_C(4194308219), // CV_PACKHI_B
693 UINT64_C(4160753787), // CV_PACKLO_B
694 UINT64_C(4060086395), // CV_PACK_H
695 UINT64_C(1073754155), // CV_ROR
696 UINT64_C(43), // CV_SB_ri_inc
697 UINT64_C(671100971), // CV_SB_rr
698 UINT64_C(536883243), // CV_SB_rr_inc
699 UINT64_C(2818576507), // CV_SDOTSP_B
700 UINT64_C(2818572411), // CV_SDOTSP_H
701 UINT64_C(2818601083), // CV_SDOTSP_SCI_B
702 UINT64_C(2818596987), // CV_SDOTSP_SCI_H
703 UINT64_C(2818592891), // CV_SDOTSP_SC_B
704 UINT64_C(2818588795), // CV_SDOTSP_SC_H
705 UINT64_C(2550141051), // CV_SDOTUP_B
706 UINT64_C(2550136955), // CV_SDOTUP_H
707 UINT64_C(2550165627), // CV_SDOTUP_SCI_B
708 UINT64_C(2550161531), // CV_SDOTUP_SCI_H
709 UINT64_C(2550157435), // CV_SDOTUP_SC_B
710 UINT64_C(2550153339), // CV_SDOTUP_SC_H
711 UINT64_C(2684358779), // CV_SDOTUSP_B
712 UINT64_C(2684354683), // CV_SDOTUSP_H
713 UINT64_C(2684383355), // CV_SDOTUSP_SCI_B
714 UINT64_C(2684379259), // CV_SDOTUSP_SCI_H
715 UINT64_C(2684375163), // CV_SDOTUSP_SC_B
716 UINT64_C(2684371067), // CV_SDOTUSP_SC_H
717 UINT64_C(3758100603), // CV_SHUFFLE2_B
718 UINT64_C(3758096507), // CV_SHUFFLE2_H
719 UINT64_C(3221254267), // CV_SHUFFLEI0_SCI_B
720 UINT64_C(3355471995), // CV_SHUFFLEI1_SCI_B
721 UINT64_C(3489689723), // CV_SHUFFLEI2_SCI_B
722 UINT64_C(3623907451), // CV_SHUFFLEI3_SCI_B
723 UINT64_C(3221229691), // CV_SHUFFLE_B
724 UINT64_C(3221225595), // CV_SHUFFLE_H
725 UINT64_C(3221250171), // CV_SHUFFLE_SCI_H
726 UINT64_C(4139), // CV_SH_ri_inc
727 UINT64_C(704655403), // CV_SH_rr
728 UINT64_C(570437675), // CV_SH_rr_inc
729 UINT64_C(1375744043), // CV_SLE
730 UINT64_C(1409298475), // CV_SLEU
731 UINT64_C(1342181499), // CV_SLL_B
732 UINT64_C(1342177403), // CV_SLL_H
733 UINT64_C(1342206075), // CV_SLL_SCI_B
734 UINT64_C(1342201979), // CV_SLL_SCI_H
735 UINT64_C(1342197883), // CV_SLL_SC_B
736 UINT64_C(1342193787), // CV_SLL_SC_H
737 UINT64_C(1207963771), // CV_SRA_B
738 UINT64_C(1207959675), // CV_SRA_H
739 UINT64_C(1207988347), // CV_SRA_SCI_B
740 UINT64_C(1207984251), // CV_SRA_SCI_H
741 UINT64_C(1207980155), // CV_SRA_SC_B
742 UINT64_C(1207976059), // CV_SRA_SC_H
743 UINT64_C(1073746043), // CV_SRL_B
744 UINT64_C(1073741947), // CV_SRL_H
745 UINT64_C(1073770619), // CV_SRL_SCI_B
746 UINT64_C(1073766523), // CV_SRL_SCI_H
747 UINT64_C(1073762427), // CV_SRL_SC_B
748 UINT64_C(1073758331), // CV_SRL_SC_H
749 UINT64_C(12379), // CV_SUBN
750 UINT64_C(2281713707), // CV_SUBNR
751 UINT64_C(2147496027), // CV_SUBRN
752 UINT64_C(2348822571), // CV_SUBRNR
753 UINT64_C(1677721723), // CV_SUBROTMJ
754 UINT64_C(1677729915), // CV_SUBROTMJ_DIV2
755 UINT64_C(1677738107), // CV_SUBROTMJ_DIV4
756 UINT64_C(1677746299), // CV_SUBROTMJ_DIV8
757 UINT64_C(1073754203), // CV_SUBUN
758 UINT64_C(2315268139), // CV_SUBUNR
759 UINT64_C(3221237851), // CV_SUBURN
760 UINT64_C(2382377003), // CV_SUBURNR
761 UINT64_C(134221947), // CV_SUB_B
762 UINT64_C(1946165371), // CV_SUB_DIV2
763 UINT64_C(1946173563), // CV_SUB_DIV4
764 UINT64_C(1946181755), // CV_SUB_DIV8
765 UINT64_C(134217851), // CV_SUB_H
766 UINT64_C(134246523), // CV_SUB_SCI_B
767 UINT64_C(134242427), // CV_SUB_SCI_H
768 UINT64_C(134238331), // CV_SUB_SC_B
769 UINT64_C(134234235), // CV_SUB_SC_H
770 UINT64_C(8235), // CV_SW_ri_inc
771 UINT64_C(738209835), // CV_SW_rr
772 UINT64_C(603992107), // CV_SW_rr_inc
773 UINT64_C(1610616955), // CV_XOR_B
774 UINT64_C(1610612859), // CV_XOR_H
775 UINT64_C(1610641531), // CV_XOR_SCI_B
776 UINT64_C(1610637435), // CV_XOR_SCI_H
777 UINT64_C(1610633339), // CV_XOR_SC_B
778 UINT64_C(1610629243), // CV_XOR_SC_H
779 UINT64_C(234901555), // CZERO_EQZ
780 UINT64_C(234909747), // CZERO_NEZ
781 UINT64_C(36866), // C_ADD
782 UINT64_C(1), // C_ADDI
783 UINT64_C(24833), // C_ADDI16SP
784 UINT64_C(0), // C_ADDI4SPN
785 UINT64_C(8193), // C_ADDIW
786 UINT64_C(39969), // C_ADDW
787 UINT64_C(35937), // C_AND
788 UINT64_C(34817), // C_ANDI
789 UINT64_C(49153), // C_BEQZ
790 UINT64_C(57345), // C_BNEZ
791 UINT64_C(36866), // C_EBREAK
792 UINT64_C(8192), // C_FLD
793 UINT64_C(8194), // C_FLDSP
794 UINT64_C(24576), // C_FLW
795 UINT64_C(24578), // C_FLWSP
796 UINT64_C(40960), // C_FSD
797 UINT64_C(40962), // C_FSDSP
798 UINT64_C(57344), // C_FSW
799 UINT64_C(57346), // C_FSWSP
800 UINT64_C(40961), // C_J
801 UINT64_C(8193), // C_JAL
802 UINT64_C(36866), // C_JALR
803 UINT64_C(32770), // C_JR
804 UINT64_C(32768), // C_LBU
805 UINT64_C(24576), // C_LD
806 UINT64_C(24578), // C_LDSP
807 UINT64_C(24578), // C_LDSP_RV32
808 UINT64_C(24576), // C_LD_RV32
809 UINT64_C(33856), // C_LH
810 UINT64_C(33792), // C_LHU
811 UINT64_C(33856), // C_LH_INX
812 UINT64_C(16385), // C_LI
813 UINT64_C(24577), // C_LUI
814 UINT64_C(16384), // C_LW
815 UINT64_C(16386), // C_LWSP
816 UINT64_C(16386), // C_LWSP_INX
817 UINT64_C(16384), // C_LW_INX
818 UINT64_C(25985), // C_MOP_11
819 UINT64_C(26241), // C_MOP_13
820 UINT64_C(26497), // C_MOP_15
821 UINT64_C(24961), // C_MOP_3
822 UINT64_C(25473), // C_MOP_7
823 UINT64_C(25729), // C_MOP_9
824 UINT64_C(40001), // C_MUL
825 UINT64_C(32770), // C_MV
826 UINT64_C(1), // C_NOP
827 UINT64_C(1), // C_NOP_HINT
828 UINT64_C(40053), // C_NOT
829 UINT64_C(35905), // C_OR
830 UINT64_C(34816), // C_SB
831 UINT64_C(57344), // C_SD
832 UINT64_C(57346), // C_SDSP
833 UINT64_C(57346), // C_SDSP_RV32
834 UINT64_C(57344), // C_SD_RV32
835 UINT64_C(40037), // C_SEXT_B
836 UINT64_C(40045), // C_SEXT_H
837 UINT64_C(35840), // C_SH
838 UINT64_C(35840), // C_SH_INX
839 UINT64_C(2), // C_SLLI
840 UINT64_C(33793), // C_SRAI
841 UINT64_C(32769), // C_SRLI
842 UINT64_C(25217), // C_SSPOPCHK
843 UINT64_C(24705), // C_SSPUSH
844 UINT64_C(35841), // C_SUB
845 UINT64_C(39937), // C_SUBW
846 UINT64_C(49152), // C_SW
847 UINT64_C(49154), // C_SWSP
848 UINT64_C(49154), // C_SWSP_INX
849 UINT64_C(49152), // C_SW_INX
850 UINT64_C(0), // C_UNIMP
851 UINT64_C(35873), // C_XOR
852 UINT64_C(40033), // C_ZEXT_B
853 UINT64_C(40041), // C_ZEXT_H
854 UINT64_C(40049), // C_ZEXT_W
855 UINT64_C(33570867), // DIV
856 UINT64_C(33574963), // DIVU
857 UINT64_C(33574971), // DIVUW
858 UINT64_C(33570875), // DIVW
859 UINT64_C(2065694835), // DRET
860 UINT64_C(1048691), // EBREAK
861 UINT64_C(115), // ECALL
862 UINT64_C(33554515), // FADD_D
863 UINT64_C(33554515), // FADD_D_IN32X
864 UINT64_C(33554515), // FADD_D_INX
865 UINT64_C(67108947), // FADD_H
866 UINT64_C(67108947), // FADD_H_INX
867 UINT64_C(100663379), // FADD_Q
868 UINT64_C(83), // FADD_S
869 UINT64_C(83), // FADD_S_INX
870 UINT64_C(3791654995), // FCLASS_D
871 UINT64_C(3791654995), // FCLASS_D_IN32X
872 UINT64_C(3791654995), // FCLASS_D_INX
873 UINT64_C(3825209427), // FCLASS_H
874 UINT64_C(3825209427), // FCLASS_H_INX
875 UINT64_C(3858763859), // FCLASS_Q
876 UINT64_C(3758100563), // FCLASS_S
877 UINT64_C(3758100563), // FCLASS_S_INX
878 UINT64_C(3263172691), // FCVTMOD_W_D
879 UINT64_C(1149239379), // FCVT_BF16_S
880 UINT64_C(1109393491), // FCVT_D_H
881 UINT64_C(1109393491), // FCVT_D_H_IN32X
882 UINT64_C(1109393491), // FCVT_D_H_INX
883 UINT64_C(3525312595), // FCVT_D_L
884 UINT64_C(3526361171), // FCVT_D_LU
885 UINT64_C(3526361171), // FCVT_D_LU_INX
886 UINT64_C(3525312595), // FCVT_D_L_INX
887 UINT64_C(1110442067), // FCVT_D_Q
888 UINT64_C(1107296339), // FCVT_D_S
889 UINT64_C(1107296339), // FCVT_D_S_IN32X
890 UINT64_C(1107296339), // FCVT_D_S_INX
891 UINT64_C(3523215443), // FCVT_D_W
892 UINT64_C(3524264019), // FCVT_D_WU
893 UINT64_C(3524264019), // FCVT_D_WU_IN32X
894 UINT64_C(3524264019), // FCVT_D_WU_INX
895 UINT64_C(3523215443), // FCVT_D_W_IN32X
896 UINT64_C(3523215443), // FCVT_D_W_INX
897 UINT64_C(1141899347), // FCVT_H_D
898 UINT64_C(1141899347), // FCVT_H_D_IN32X
899 UINT64_C(1141899347), // FCVT_H_D_INX
900 UINT64_C(3558867027), // FCVT_H_L
901 UINT64_C(3559915603), // FCVT_H_LU
902 UINT64_C(3559915603), // FCVT_H_LU_INX
903 UINT64_C(3558867027), // FCVT_H_L_INX
904 UINT64_C(1140850771), // FCVT_H_S
905 UINT64_C(1140850771), // FCVT_H_S_INX
906 UINT64_C(3556769875), // FCVT_H_W
907 UINT64_C(3557818451), // FCVT_H_WU
908 UINT64_C(3557818451), // FCVT_H_WU_INX
909 UINT64_C(3556769875), // FCVT_H_W_INX
910 UINT64_C(3257925715), // FCVT_LU_D
911 UINT64_C(3257925715), // FCVT_LU_D_INX
912 UINT64_C(3291480147), // FCVT_LU_H
913 UINT64_C(3291480147), // FCVT_LU_H_INX
914 UINT64_C(3325034579), // FCVT_LU_Q
915 UINT64_C(3224371283), // FCVT_LU_S
916 UINT64_C(3224371283), // FCVT_LU_S_INX
917 UINT64_C(3256877139), // FCVT_L_D
918 UINT64_C(3256877139), // FCVT_L_D_INX
919 UINT64_C(3290431571), // FCVT_L_H
920 UINT64_C(3290431571), // FCVT_L_H_INX
921 UINT64_C(3323986003), // FCVT_L_Q
922 UINT64_C(3223322707), // FCVT_L_S
923 UINT64_C(3223322707), // FCVT_L_S_INX
924 UINT64_C(1175453779), // FCVT_Q_D
925 UINT64_C(3592421459), // FCVT_Q_L
926 UINT64_C(3593470035), // FCVT_Q_LU
927 UINT64_C(1174405203), // FCVT_Q_S
928 UINT64_C(3590324307), // FCVT_Q_W
929 UINT64_C(3591372883), // FCVT_Q_WU
930 UINT64_C(1080033363), // FCVT_S_BF16
931 UINT64_C(1074790483), // FCVT_S_D
932 UINT64_C(1074790483), // FCVT_S_D_IN32X
933 UINT64_C(1074790483), // FCVT_S_D_INX
934 UINT64_C(1075839059), // FCVT_S_H
935 UINT64_C(1075839059), // FCVT_S_H_INX
936 UINT64_C(3491758163), // FCVT_S_L
937 UINT64_C(3492806739), // FCVT_S_LU
938 UINT64_C(3492806739), // FCVT_S_LU_INX
939 UINT64_C(3491758163), // FCVT_S_L_INX
940 UINT64_C(1076887635), // FCVT_S_Q
941 UINT64_C(3489661011), // FCVT_S_W
942 UINT64_C(3490709587), // FCVT_S_WU
943 UINT64_C(3490709587), // FCVT_S_WU_INX
944 UINT64_C(3489661011), // FCVT_S_W_INX
945 UINT64_C(3255828563), // FCVT_WU_D
946 UINT64_C(3255828563), // FCVT_WU_D_IN32X
947 UINT64_C(3255828563), // FCVT_WU_D_INX
948 UINT64_C(3289382995), // FCVT_WU_H
949 UINT64_C(3289382995), // FCVT_WU_H_INX
950 UINT64_C(3322937427), // FCVT_WU_Q
951 UINT64_C(3222274131), // FCVT_WU_S
952 UINT64_C(3222274131), // FCVT_WU_S_INX
953 UINT64_C(3254779987), // FCVT_W_D
954 UINT64_C(3254779987), // FCVT_W_D_IN32X
955 UINT64_C(3254779987), // FCVT_W_D_INX
956 UINT64_C(3288334419), // FCVT_W_H
957 UINT64_C(3288334419), // FCVT_W_H_INX
958 UINT64_C(3321888851), // FCVT_W_Q
959 UINT64_C(3221225555), // FCVT_W_S
960 UINT64_C(3221225555), // FCVT_W_S_INX
961 UINT64_C(436207699), // FDIV_D
962 UINT64_C(436207699), // FDIV_D_IN32X
963 UINT64_C(436207699), // FDIV_D_INX
964 UINT64_C(469762131), // FDIV_H
965 UINT64_C(469762131), // FDIV_H_INX
966 UINT64_C(503316563), // FDIV_Q
967 UINT64_C(402653267), // FDIV_S
968 UINT64_C(402653267), // FDIV_S_INX
969 UINT64_C(15), // FENCE
970 UINT64_C(4111), // FENCE_I
971 UINT64_C(2200961039), // FENCE_TSO
972 UINT64_C(2717917267), // FEQ_D
973 UINT64_C(2717917267), // FEQ_D_IN32X
974 UINT64_C(2717917267), // FEQ_D_INX
975 UINT64_C(2751471699), // FEQ_H
976 UINT64_C(2751471699), // FEQ_H_INX
977 UINT64_C(2785026131), // FEQ_Q
978 UINT64_C(2684362835), // FEQ_S
979 UINT64_C(2684362835), // FEQ_S_INX
980 UINT64_C(12295), // FLD
981 UINT64_C(2717925459), // FLEQ_D
982 UINT64_C(2751479891), // FLEQ_H
983 UINT64_C(2785034323), // FLEQ_Q
984 UINT64_C(2684371027), // FLEQ_S
985 UINT64_C(2717909075), // FLE_D
986 UINT64_C(2717909075), // FLE_D_IN32X
987 UINT64_C(2717909075), // FLE_D_INX
988 UINT64_C(2751463507), // FLE_H
989 UINT64_C(2751463507), // FLE_H_INX
990 UINT64_C(2785017939), // FLE_Q
991 UINT64_C(2684354643), // FLE_S
992 UINT64_C(2684354643), // FLE_S_INX
993 UINT64_C(4103), // FLH
994 UINT64_C(4061134931), // FLI_D
995 UINT64_C(4094689363), // FLI_H
996 UINT64_C(4128243795), // FLI_Q
997 UINT64_C(4027580499), // FLI_S
998 UINT64_C(16391), // FLQ
999 UINT64_C(2717929555), // FLTQ_D
1000 UINT64_C(2751483987), // FLTQ_H
1001 UINT64_C(2785038419), // FLTQ_Q
1002 UINT64_C(2684375123), // FLTQ_S
1003 UINT64_C(2717913171), // FLT_D
1004 UINT64_C(2717913171), // FLT_D_IN32X
1005 UINT64_C(2717913171), // FLT_D_INX
1006 UINT64_C(2751467603), // FLT_H
1007 UINT64_C(2751467603), // FLT_H_INX
1008 UINT64_C(2785022035), // FLT_Q
1009 UINT64_C(2684358739), // FLT_S
1010 UINT64_C(2684358739), // FLT_S_INX
1011 UINT64_C(8199), // FLW
1012 UINT64_C(33554499), // FMADD_D
1013 UINT64_C(33554499), // FMADD_D_IN32X
1014 UINT64_C(33554499), // FMADD_D_INX
1015 UINT64_C(67108931), // FMADD_H
1016 UINT64_C(67108931), // FMADD_H_INX
1017 UINT64_C(100663363), // FMADD_Q
1018 UINT64_C(67), // FMADD_S
1019 UINT64_C(67), // FMADD_S_INX
1020 UINT64_C(704655443), // FMAXM_D
1021 UINT64_C(738209875), // FMAXM_H
1022 UINT64_C(771764307), // FMAXM_Q
1023 UINT64_C(671101011), // FMAXM_S
1024 UINT64_C(704647251), // FMAX_D
1025 UINT64_C(704647251), // FMAX_D_IN32X
1026 UINT64_C(704647251), // FMAX_D_INX
1027 UINT64_C(738201683), // FMAX_H
1028 UINT64_C(738201683), // FMAX_H_INX
1029 UINT64_C(771756115), // FMAX_Q
1030 UINT64_C(671092819), // FMAX_S
1031 UINT64_C(671092819), // FMAX_S_INX
1032 UINT64_C(704651347), // FMINM_D
1033 UINT64_C(738205779), // FMINM_H
1034 UINT64_C(771760211), // FMINM_Q
1035 UINT64_C(671096915), // FMINM_S
1036 UINT64_C(704643155), // FMIN_D
1037 UINT64_C(704643155), // FMIN_D_IN32X
1038 UINT64_C(704643155), // FMIN_D_INX
1039 UINT64_C(738197587), // FMIN_H
1040 UINT64_C(738197587), // FMIN_H_INX
1041 UINT64_C(771752019), // FMIN_Q
1042 UINT64_C(671088723), // FMIN_S
1043 UINT64_C(671088723), // FMIN_S_INX
1044 UINT64_C(33554503), // FMSUB_D
1045 UINT64_C(33554503), // FMSUB_D_IN32X
1046 UINT64_C(33554503), // FMSUB_D_INX
1047 UINT64_C(67108935), // FMSUB_H
1048 UINT64_C(67108935), // FMSUB_H_INX
1049 UINT64_C(100663367), // FMSUB_Q
1050 UINT64_C(71), // FMSUB_S
1051 UINT64_C(71), // FMSUB_S_INX
1052 UINT64_C(301989971), // FMUL_D
1053 UINT64_C(301989971), // FMUL_D_IN32X
1054 UINT64_C(301989971), // FMUL_D_INX
1055 UINT64_C(335544403), // FMUL_H
1056 UINT64_C(335544403), // FMUL_H_INX
1057 UINT64_C(369098835), // FMUL_Q
1058 UINT64_C(268435539), // FMUL_S
1059 UINT64_C(268435539), // FMUL_S_INX
1060 UINT64_C(3792699475), // FMVH_X_D
1061 UINT64_C(3859808339), // FMVH_X_Q
1062 UINT64_C(2986344531), // FMVP_D_X
1063 UINT64_C(3053453395), // FMVP_Q_X
1064 UINT64_C(4060086355), // FMV_D_X
1065 UINT64_C(4093640787), // FMV_H_X
1066 UINT64_C(4026531923), // FMV_W_X
1067 UINT64_C(3791650899), // FMV_X_D
1068 UINT64_C(3825205331), // FMV_X_H
1069 UINT64_C(3758096467), // FMV_X_W
1070 UINT64_C(3758096467), // FMV_X_W_FPR64
1071 UINT64_C(33554511), // FNMADD_D
1072 UINT64_C(33554511), // FNMADD_D_IN32X
1073 UINT64_C(33554511), // FNMADD_D_INX
1074 UINT64_C(67108943), // FNMADD_H
1075 UINT64_C(67108943), // FNMADD_H_INX
1076 UINT64_C(100663375), // FNMADD_Q
1077 UINT64_C(79), // FNMADD_S
1078 UINT64_C(79), // FNMADD_S_INX
1079 UINT64_C(33554507), // FNMSUB_D
1080 UINT64_C(33554507), // FNMSUB_D_IN32X
1081 UINT64_C(33554507), // FNMSUB_D_INX
1082 UINT64_C(67108939), // FNMSUB_H
1083 UINT64_C(67108939), // FNMSUB_H_INX
1084 UINT64_C(100663371), // FNMSUB_Q
1085 UINT64_C(75), // FNMSUB_S
1086 UINT64_C(75), // FNMSUB_S_INX
1087 UINT64_C(1112539219), // FROUNDNX_D
1088 UINT64_C(1146093651), // FROUNDNX_H
1089 UINT64_C(1179648083), // FROUNDNX_Q
1090 UINT64_C(1078984787), // FROUNDNX_S
1091 UINT64_C(1111490643), // FROUND_D
1092 UINT64_C(1145045075), // FROUND_H
1093 UINT64_C(1178599507), // FROUND_Q
1094 UINT64_C(1077936211), // FROUND_S
1095 UINT64_C(12327), // FSD
1096 UINT64_C(570429523), // FSGNJN_D
1097 UINT64_C(570429523), // FSGNJN_D_IN32X
1098 UINT64_C(570429523), // FSGNJN_D_INX
1099 UINT64_C(603983955), // FSGNJN_H
1100 UINT64_C(603983955), // FSGNJN_H_INX
1101 UINT64_C(637538387), // FSGNJN_Q
1102 UINT64_C(536875091), // FSGNJN_S
1103 UINT64_C(536875091), // FSGNJN_S_INX
1104 UINT64_C(570433619), // FSGNJX_D
1105 UINT64_C(570433619), // FSGNJX_D_IN32X
1106 UINT64_C(570433619), // FSGNJX_D_INX
1107 UINT64_C(603988051), // FSGNJX_H
1108 UINT64_C(603988051), // FSGNJX_H_INX
1109 UINT64_C(637542483), // FSGNJX_Q
1110 UINT64_C(536879187), // FSGNJX_S
1111 UINT64_C(536879187), // FSGNJX_S_INX
1112 UINT64_C(570425427), // FSGNJ_D
1113 UINT64_C(570425427), // FSGNJ_D_IN32X
1114 UINT64_C(570425427), // FSGNJ_D_INX
1115 UINT64_C(603979859), // FSGNJ_H
1116 UINT64_C(603979859), // FSGNJ_H_INX
1117 UINT64_C(637534291), // FSGNJ_Q
1118 UINT64_C(536870995), // FSGNJ_S
1119 UINT64_C(536870995), // FSGNJ_S_INX
1120 UINT64_C(4135), // FSH
1121 UINT64_C(16423), // FSQ
1122 UINT64_C(1509949523), // FSQRT_D
1123 UINT64_C(1509949523), // FSQRT_D_IN32X
1124 UINT64_C(1509949523), // FSQRT_D_INX
1125 UINT64_C(1543503955), // FSQRT_H
1126 UINT64_C(1543503955), // FSQRT_H_INX
1127 UINT64_C(1577058387), // FSQRT_Q
1128 UINT64_C(1476395091), // FSQRT_S
1129 UINT64_C(1476395091), // FSQRT_S_INX
1130 UINT64_C(167772243), // FSUB_D
1131 UINT64_C(167772243), // FSUB_D_IN32X
1132 UINT64_C(167772243), // FSUB_D_INX
1133 UINT64_C(201326675), // FSUB_H
1134 UINT64_C(201326675), // FSUB_H_INX
1135 UINT64_C(234881107), // FSUB_Q
1136 UINT64_C(134217811), // FSUB_S
1137 UINT64_C(134217811), // FSUB_S_INX
1138 UINT64_C(8231), // FSW
1139 UINT64_C(1644167283), // HFENCE_GVMA
1140 UINT64_C(570425459), // HFENCE_VVMA
1141 UINT64_C(1711276147), // HINVAL_GVMA
1142 UINT64_C(637534323), // HINVAL_VVMA
1143 UINT64_C(1680883827), // HLVX_HU
1144 UINT64_C(1747992691), // HLVX_WU
1145 UINT64_C(1610629235), // HLV_B
1146 UINT64_C(1611677811), // HLV_BU
1147 UINT64_C(1811955827), // HLV_D
1148 UINT64_C(1677738099), // HLV_H
1149 UINT64_C(1678786675), // HLV_HU
1150 UINT64_C(1744846963), // HLV_W
1151 UINT64_C(1745895539), // HLV_WU
1152 UINT64_C(1644183667), // HSV_B
1153 UINT64_C(1845510259), // HSV_D
1154 UINT64_C(1711292531), // HSV_H
1155 UINT64_C(1778401395), // HSV_W
1156 UINT64_C(0), // Insn16
1157 UINT64_C(0), // Insn32
1158 UINT64_C(0), // Insn48
1159 UINT64_C(0), // Insn64
1160 UINT64_C(0), // InsnB
1161 UINT64_C(0), // InsnCA
1162 UINT64_C(0), // InsnCB
1163 UINT64_C(0), // InsnCI
1164 UINT64_C(0), // InsnCIW
1165 UINT64_C(0), // InsnCJ
1166 UINT64_C(0), // InsnCL
1167 UINT64_C(0), // InsnCR
1168 UINT64_C(0), // InsnCS
1169 UINT64_C(0), // InsnCSS
1170 UINT64_C(0), // InsnI
1171 UINT64_C(0), // InsnI_Mem
1172 UINT64_C(0), // InsnJ
1173 UINT64_C(0), // InsnQC_EAI
1174 UINT64_C(0), // InsnQC_EB
1175 UINT64_C(0), // InsnQC_EI
1176 UINT64_C(0), // InsnQC_EI_Mem
1177 UINT64_C(0), // InsnQC_EJ
1178 UINT64_C(0), // InsnQC_ES
1179 UINT64_C(0), // InsnR
1180 UINT64_C(0), // InsnR4
1181 UINT64_C(0), // InsnS
1182 UINT64_C(0), // InsnU
1183 UINT64_C(111), // JAL
1184 UINT64_C(103), // JALR
1185 UINT64_C(3), // LB
1186 UINT64_C(16387), // LBU
1187 UINT64_C(872415279), // LB_AQ
1188 UINT64_C(905969711), // LB_AQRL
1189 UINT64_C(12291), // LD
1190 UINT64_C(872427567), // LD_AQ
1191 UINT64_C(905981999), // LD_AQRL
1192 UINT64_C(12291), // LD_RV32
1193 UINT64_C(4099), // LH
1194 UINT64_C(20483), // LHU
1195 UINT64_C(872419375), // LH_AQ
1196 UINT64_C(905973807), // LH_AQRL
1197 UINT64_C(4099), // LH_INX
1198 UINT64_C(268447791), // LR_D
1199 UINT64_C(335556655), // LR_D_AQ
1200 UINT64_C(369111087), // LR_D_AQRL
1201 UINT64_C(302002223), // LR_D_RL
1202 UINT64_C(268443695), // LR_W
1203 UINT64_C(335552559), // LR_W_AQ
1204 UINT64_C(369106991), // LR_W_AQRL
1205 UINT64_C(301998127), // LR_W_RL
1206 UINT64_C(55), // LUI
1207 UINT64_C(8195), // LW
1208 UINT64_C(24579), // LWU
1209 UINT64_C(872423471), // LW_AQ
1210 UINT64_C(905977903), // LW_AQRL
1211 UINT64_C(8195), // LW_INX
1212 UINT64_C(3925880891), // MACCSU_H00
1213 UINT64_C(4194316347), // MACCSU_H11
1214 UINT64_C(3992989755), // MACCSU_W00
1215 UINT64_C(4261425211), // MACCSU_W11
1216 UINT64_C(2852139067), // MACCU_H00
1217 UINT64_C(3120566331), // MACCU_H01
1218 UINT64_C(3120574523), // MACCU_H11
1219 UINT64_C(2919247931), // MACCU_W00
1220 UINT64_C(3187675195), // MACCU_W01
1221 UINT64_C(3187683387), // MACCU_W11
1222 UINT64_C(2315268155), // MACC_H00
1223 UINT64_C(2583695419), // MACC_H01
1224 UINT64_C(2583703611), // MACC_H11
1225 UINT64_C(2382377019), // MACC_W00
1226 UINT64_C(2650804283), // MACC_W01
1227 UINT64_C(2650812475), // MACC_W11
1228 UINT64_C(167796787), // MAX
1229 UINT64_C(167800883), // MAXU
1230 UINT64_C(2885685307), // MERGE
1231 UINT64_C(2315284539), // MHACC
1232 UINT64_C(3389026363), // MHACCSU
1233 UINT64_C(2919264315), // MHACCSU_H0
1234 UINT64_C(3187699771), // MHACCSU_H1
1235 UINT64_C(2583719995), // MHACCU
1236 UINT64_C(2852155451), // MHACC_H0
1237 UINT64_C(3120590907), // MHACC_H1
1238 UINT64_C(2382393403), // MHRACC
1239 UINT64_C(3456135227), // MHRACCSU
1240 UINT64_C(2650828859), // MHRACCU
1241 UINT64_C(167788595), // MIN
1242 UINT64_C(167792691), // MINU
1243 UINT64_C(100675595), // MIPS_CCMOV
1244 UINT64_C(3149843), // MIPS_EHB
1245 UINT64_C(1052691), // MIPS_IHB
1246 UINT64_C(16395), // MIPS_LDP
1247 UINT64_C(1064971), // MIPS_LWP
1248 UINT64_C(5246995), // MIPS_PAUSE
1249 UINT64_C(11), // MIPS_PREF
1250 UINT64_C(20491), // MIPS_SDP
1251 UINT64_C(20619), // MIPS_SWP
1252 UINT64_C(1881145459), // MNRET
1253 UINT64_C(2181054579), // MOP_RR_0
1254 UINT64_C(2248163443), // MOP_RR_1
1255 UINT64_C(2315272307), // MOP_RR_2
1256 UINT64_C(2382381171), // MOP_RR_3
1257 UINT64_C(3254796403), // MOP_RR_4
1258 UINT64_C(3321905267), // MOP_RR_5
1259 UINT64_C(3389014131), // MOP_RR_6
1260 UINT64_C(3456122995), // MOP_RR_7
1261 UINT64_C(2176860275), // MOP_R_0
1262 UINT64_C(2177908851), // MOP_R_1
1263 UINT64_C(2313175155), // MOP_R_10
1264 UINT64_C(2314223731), // MOP_R_11
1265 UINT64_C(2378186867), // MOP_R_12
1266 UINT64_C(2379235443), // MOP_R_13
1267 UINT64_C(2380284019), // MOP_R_14
1268 UINT64_C(2381332595), // MOP_R_15
1269 UINT64_C(3250602099), // MOP_R_16
1270 UINT64_C(3251650675), // MOP_R_17
1271 UINT64_C(3252699251), // MOP_R_18
1272 UINT64_C(3253747827), // MOP_R_19
1273 UINT64_C(2178957427), // MOP_R_2
1274 UINT64_C(3317710963), // MOP_R_20
1275 UINT64_C(3318759539), // MOP_R_21
1276 UINT64_C(3319808115), // MOP_R_22
1277 UINT64_C(3320856691), // MOP_R_23
1278 UINT64_C(3384819827), // MOP_R_24
1279 UINT64_C(3385868403), // MOP_R_25
1280 UINT64_C(3386916979), // MOP_R_26
1281 UINT64_C(3387965555), // MOP_R_27
1282 UINT64_C(3451928691), // MOP_R_28
1283 UINT64_C(3452977267), // MOP_R_29
1284 UINT64_C(2180006003), // MOP_R_3
1285 UINT64_C(3454025843), // MOP_R_30
1286 UINT64_C(3455074419), // MOP_R_31
1287 UINT64_C(2243969139), // MOP_R_4
1288 UINT64_C(2245017715), // MOP_R_5
1289 UINT64_C(2246066291), // MOP_R_6
1290 UINT64_C(2247114867), // MOP_R_7
1291 UINT64_C(2311078003), // MOP_R_8
1292 UINT64_C(2312126579), // MOP_R_9
1293 UINT64_C(3892342843), // MQACC_H00
1294 UINT64_C(4160770107), // MQACC_H01
1295 UINT64_C(4160778299), // MQACC_H11
1296 UINT64_C(3925897275), // MQACC_W00
1297 UINT64_C(4194324539), // MQACC_W01
1298 UINT64_C(4194332731), // MQACC_W11
1299 UINT64_C(3959451707), // MQRACC_H00
1300 UINT64_C(4227878971), // MQRACC_H01
1301 UINT64_C(4227887163), // MQRACC_H11
1302 UINT64_C(3993006139), // MQRACC_W00
1303 UINT64_C(4261433403), // MQRACC_W01
1304 UINT64_C(4261441595), // MQRACC_W11
1305 UINT64_C(2113937563), // MQRWACC
1306 UINT64_C(2046828699), // MQWACC
1307 UINT64_C(807403635), // MRET
1308 UINT64_C(3254804539), // MSEQ
1309 UINT64_C(3523239995), // MSLT
1310 UINT64_C(3657457723), // MSLTU
1311 UINT64_C(33554483), // MUL
1312 UINT64_C(33558579), // MULH
1313 UINT64_C(2248175675), // MULHR
1314 UINT64_C(3321917499), // MULHRSU
1315 UINT64_C(2516611131), // MULHRU
1316 UINT64_C(33562675), // MULHSU
1317 UINT64_C(2785046587), // MULHSU_H0
1318 UINT64_C(3053482043), // MULHSU_H1
1319 UINT64_C(33566771), // MULHU
1320 UINT64_C(2717937723), // MULH_H0
1321 UINT64_C(2986373179), // MULH_H1
1322 UINT64_C(3523244091), // MULQ
1323 UINT64_C(3590352955), // MULQR
1324 UINT64_C(3791663163), // MULSU_H00
1325 UINT64_C(4060098619), // MULSU_H11
1326 UINT64_C(3858772027), // MULSU_W00
1327 UINT64_C(4127207483), // MULSU_W11
1328 UINT64_C(2717921339), // MULU_H00
1329 UINT64_C(2986348603), // MULU_H01
1330 UINT64_C(2986356795), // MULU_H11
1331 UINT64_C(2785030203), // MULU_W00
1332 UINT64_C(3053457467), // MULU_W01
1333 UINT64_C(3053465659), // MULU_W11
1334 UINT64_C(33554491), // MULW
1335 UINT64_C(2181050427), // MUL_H00
1336 UINT64_C(2449477691), // MUL_H01
1337 UINT64_C(2449485883), // MUL_H11
1338 UINT64_C(2248159291), // MUL_W00
1339 UINT64_C(2516586555), // MUL_W01
1340 UINT64_C(2516594747), // MUL_W11
1341 UINT64_C(2818576443), // MVM
1342 UINT64_C(2852130875), // MVMN
1343 UINT64_C(1845542939), // NCLIP
1344 UINT64_C(1677770779), // NCLIPI
1345 UINT64_C(604028955), // NCLIPIU
1346 UINT64_C(2113978395), // NCLIPR
1347 UINT64_C(1946206235), // NCLIPRI
1348 UINT64_C(872464411), // NCLIPRIU
1349 UINT64_C(1040236571), // NCLIPRU
1350 UINT64_C(771801115), // NCLIPU
1351 UINT64_C(4107), // NDS_ADDIGP
1352 UINT64_C(28763), // NDS_BBC
1353 UINT64_C(1073770587), // NDS_BBS
1354 UINT64_C(20571), // NDS_BEQC
1355 UINT64_C(12379), // NDS_BFOS
1356 UINT64_C(8283), // NDS_BFOZ
1357 UINT64_C(24667), // NDS_BNEC
1358 UINT64_C(114779), // NDS_FCVT_BF16_S
1359 UINT64_C(82011), // NDS_FCVT_S_BF16
1360 UINT64_C(536871003), // NDS_FFB
1361 UINT64_C(603979867), // NDS_FFMISM
1362 UINT64_C(570425435), // NDS_FFZMISM
1363 UINT64_C(637534299), // NDS_FLMISM
1364 UINT64_C(4026531923), // NDS_FMV_BF16_X
1365 UINT64_C(3758096467), // NDS_FMV_X_BF16
1366 UINT64_C(11), // NDS_LBGP
1367 UINT64_C(8203), // NDS_LBUGP
1368 UINT64_C(12331), // NDS_LDGP
1369 UINT64_C(268435547), // NDS_LEA_B_ZE
1370 UINT64_C(234881115), // NDS_LEA_D
1371 UINT64_C(369098843), // NDS_LEA_D_ZE
1372 UINT64_C(167772251), // NDS_LEA_H
1373 UINT64_C(301989979), // NDS_LEA_H_ZE
1374 UINT64_C(201326683), // NDS_LEA_W
1375 UINT64_C(335544411), // NDS_LEA_W_ZE
1376 UINT64_C(4139), // NDS_LHGP
1377 UINT64_C(20523), // NDS_LHUGP
1378 UINT64_C(8235), // NDS_LWGP
1379 UINT64_C(24619), // NDS_LWUGP
1380 UINT64_C(12299), // NDS_SBGP
1381 UINT64_C(28715), // NDS_SDGP
1382 UINT64_C(43), // NDS_SHGP
1383 UINT64_C(16427), // NDS_SWGP
1384 UINT64_C(335560795), // NDS_VD4DOTSU_VV
1385 UINT64_C(268451931), // NDS_VD4DOTS_VV
1386 UINT64_C(469778523), // NDS_VD4DOTU_VV
1387 UINT64_C(49243), // NDS_VFNCVT_BF16_S
1388 UINT64_C(201343067), // NDS_VFPMADB_VF
1389 UINT64_C(134234203), // NDS_VFPMADT_VF
1390 UINT64_C(213083), // NDS_VFWCVT_F_B
1391 UINT64_C(245851), // NDS_VFWCVT_F_BU
1392 UINT64_C(147547), // NDS_VFWCVT_F_N
1393 UINT64_C(180315), // NDS_VFWCVT_F_NU
1394 UINT64_C(16475), // NDS_VFWCVT_S_BF16
1395 UINT64_C(100679771), // NDS_VLE4_V
1396 UINT64_C(69222491), // NDS_VLN8_V
1397 UINT64_C(70271067), // NDS_VLNU8_V
1398 UINT64_C(1308672027), // NSRA
1399 UINT64_C(1140899867), // NSRAI
1400 UINT64_C(1577107483), // NSRAR
1401 UINT64_C(1409335323), // NSRARI
1402 UINT64_C(234930203), // NSRL
1403 UINT64_C(67158043), // NSRLI
1404 UINT64_C(24627), // OR
1405 UINT64_C(678449171), // ORC_B
1406 UINT64_C(24595), // ORI
1407 UINT64_C(1073766451), // ORN
1408 UINT64_C(3154116667), // PAADDU_B
1409 UINT64_C(3154141211), // PAADDU_DB
1410 UINT64_C(3087032347), // PAADDU_DH
1411 UINT64_C(3120586779), // PAADDU_DW
1412 UINT64_C(3087007803), // PAADDU_H
1413 UINT64_C(3120562235), // PAADDU_W
1414 UINT64_C(2617245755), // PAADD_B
1415 UINT64_C(2617270299), // PAADD_DB
1416 UINT64_C(2550161435), // PAADD_DH
1417 UINT64_C(2583715867), // PAADD_DW
1418 UINT64_C(2550136891), // PAADD_H
1419 UINT64_C(2583691323), // PAADD_W
1420 UINT64_C(2551242779), // PAAS_DHX
1421 UINT64_C(2550161467), // PAAS_HX
1422 UINT64_C(2583715899), // PAAS_WX
1423 UINT64_C(3154120763), // PABDSUMAU_B
1424 UINT64_C(3019903035), // PABDSUMU_B
1425 UINT64_C(3959423035), // PABDU_B
1426 UINT64_C(3959447579), // PABDU_DB
1427 UINT64_C(3892338715), // PABDU_DH
1428 UINT64_C(3892314171), // PABDU_H
1429 UINT64_C(3422552123), // PABD_B
1430 UINT64_C(3422576667), // PABD_DB
1431 UINT64_C(3355467803), // PABD_DH
1432 UINT64_C(3355443259), // PABD_H
1433 UINT64_C(134234163), // PACK
1434 UINT64_C(134246451), // PACKH
1435 UINT64_C(134234171), // PACKW
1436 UINT64_C(2214592571), // PADD_B
1437 UINT64_C(2617253915), // PADD_BS
1438 UINT64_C(2214617115), // PADD_DB
1439 UINT64_C(469786651), // PADD_DBS
1440 UINT64_C(2147508251), // PADD_DH
1441 UINT64_C(402677787), // PADD_DHS
1442 UINT64_C(2181062683), // PADD_DW
1443 UINT64_C(436232219), // PADD_DWS
1444 UINT64_C(2147483707), // PADD_H
1445 UINT64_C(2550145051), // PADD_HS
1446 UINT64_C(2181038139), // PADD_W
1447 UINT64_C(2583699483), // PADD_WS
1448 UINT64_C(2618351643), // PASA_DHX
1449 UINT64_C(2617270331), // PASA_HX
1450 UINT64_C(2650824763), // PASA_WX
1451 UINT64_C(4227858491), // PASUBU_B
1452 UINT64_C(4227883035), // PASUBU_DB
1453 UINT64_C(4160774171), // PASUBU_DH
1454 UINT64_C(4194328603), // PASUBU_DW
1455 UINT64_C(4160749627), // PASUBU_H
1456 UINT64_C(4194304059), // PASUBU_W
1457 UINT64_C(3690987579), // PASUB_B
1458 UINT64_C(3691012123), // PASUB_DB
1459 UINT64_C(3623903259), // PASUB_DH
1460 UINT64_C(3657457691), // PASUB_DW
1461 UINT64_C(3623878715), // PASUB_H
1462 UINT64_C(3657433147), // PASUB_W
1463 UINT64_C(2148589595), // PAS_DHX
1464 UINT64_C(2147508283), // PAS_HX
1465 UINT64_C(2181062715), // PAS_WX
1466 UINT64_C(3019907099), // PLI_B
1467 UINT64_C(872423451), // PLI_DB
1468 UINT64_C(805314587), // PLI_DH
1469 UINT64_C(2952798235), // PLI_H
1470 UINT64_C(2986352667), // PLI_W
1471 UINT64_C(1879056411), // PLUI_DH
1472 UINT64_C(4026540059), // PLUI_H
1473 UINT64_C(4060094491), // PLUI_W
1474 UINT64_C(3892334651), // PM2ADDASU_H
1475 UINT64_C(3925889083), // PM2ADDASU_W
1476 UINT64_C(2818592827), // PM2ADDAU_H
1477 UINT64_C(2852147259), // PM2ADDAU_W
1478 UINT64_C(2281721915), // PM2ADDA_H
1479 UINT64_C(2550157371), // PM2ADDA_HX
1480 UINT64_C(2315276347), // PM2ADDA_W
1481 UINT64_C(2583711803), // PM2ADDA_WX
1482 UINT64_C(3758116923), // PM2ADDSU_H
1483 UINT64_C(3791671355), // PM2ADDSU_W
1484 UINT64_C(2684375099), // PM2ADDU_H
1485 UINT64_C(2717929531), // PM2ADDU_W
1486 UINT64_C(2147504187), // PM2ADD_H
1487 UINT64_C(2415939643), // PM2ADD_HX
1488 UINT64_C(2181058619), // PM2ADD_W
1489 UINT64_C(2449494075), // PM2ADD_WX
1490 UINT64_C(3288354875), // PM2SADD_H
1491 UINT64_C(3556790331), // PM2SADD_HX
1492 UINT64_C(3355463739), // PM2SUBA_H
1493 UINT64_C(3623899195), // PM2SUBA_HX
1494 UINT64_C(3389018171), // PM2SUBA_W
1495 UINT64_C(3657453627), // PM2SUBA_WX
1496 UINT64_C(3221246011), // PM2SUB_H
1497 UINT64_C(3489681467), // PM2SUB_HX
1498 UINT64_C(3254800443), // PM2SUB_W
1499 UINT64_C(3523235899), // PM2SUB_WX
1500 UINT64_C(1845502107), // PM2WADDASU_H
1501 UINT64_C(771760283), // PM2WADDAU_H
1502 UINT64_C(234889371), // PM2WADDA_H
1503 UINT64_C(503324827), // PM2WADDA_HX
1504 UINT64_C(1711284379), // PM2WADDSU_H
1505 UINT64_C(637542555), // PM2WADDU_H
1506 UINT64_C(100671643), // PM2WADD_H
1507 UINT64_C(369107099), // PM2WADD_HX
1508 UINT64_C(1308631195), // PM2WSUBA_H
1509 UINT64_C(1577066651), // PM2WSUBA_HX
1510 UINT64_C(1174413467), // PM2WSUB_H
1511 UINT64_C(1442848923), // PM2WSUB_HX
1512 UINT64_C(3959443515), // PM4ADDASU_B
1513 UINT64_C(3992997947), // PM4ADDASU_H
1514 UINT64_C(2885701691), // PM4ADDAU_B
1515 UINT64_C(2919256123), // PM4ADDAU_H
1516 UINT64_C(2348830779), // PM4ADDA_B
1517 UINT64_C(2382385211), // PM4ADDA_H
1518 UINT64_C(3825225787), // PM4ADDSU_B
1519 UINT64_C(3858780219), // PM4ADDSU_H
1520 UINT64_C(2751483963), // PM4ADDU_B
1521 UINT64_C(2785038395), // PM4ADDU_H
1522 UINT64_C(2214613051), // PM4ADD_B
1523 UINT64_C(2248167483), // PM4ADD_H
1524 UINT64_C(3925880891), // PMACCSU_W_H00
1525 UINT64_C(4194316347), // PMACCSU_W_H11
1526 UINT64_C(2852139067), // PMACCU_W_H00
1527 UINT64_C(3120566331), // PMACCU_W_H01
1528 UINT64_C(3120574523), // PMACCU_W_H11
1529 UINT64_C(2315268155), // PMACC_W_H00
1530 UINT64_C(2583695419), // PMACC_W_H01
1531 UINT64_C(2583703611), // PMACC_W_H11
1532 UINT64_C(4227883067), // PMAXU_B
1533 UINT64_C(4228964379), // PMAXU_DB
1534 UINT64_C(4161855515), // PMAXU_DH
1535 UINT64_C(4195409947), // PMAXU_DW
1536 UINT64_C(4160774203), // PMAXU_H
1537 UINT64_C(4194328635), // PMAXU_W
1538 UINT64_C(4093665339), // PMAX_B
1539 UINT64_C(4094746651), // PMAX_DB
1540 UINT64_C(4027637787), // PMAX_DH
1541 UINT64_C(4061192219), // PMAX_DW
1542 UINT64_C(4026556475), // PMAX_H
1543 UINT64_C(4060110907), // PMAX_W
1544 UINT64_C(3355471931), // PMHACCSU_H
1545 UINT64_C(2885709883), // PMHACCSU_H_B0
1546 UINT64_C(3154145339), // PMHACCSU_H_B1
1547 UINT64_C(3389026363), // PMHACCSU_W
1548 UINT64_C(2919264315), // PMHACCSU_W_H0
1549 UINT64_C(3187699771), // PMHACCSU_W_H1
1550 UINT64_C(2550165563), // PMHACCU_H
1551 UINT64_C(2583719995), // PMHACCU_W
1552 UINT64_C(2281730107), // PMHACC_H
1553 UINT64_C(2818601019), // PMHACC_H_B0
1554 UINT64_C(3087036475), // PMHACC_H_B1
1555 UINT64_C(2315284539), // PMHACC_W
1556 UINT64_C(2852155451), // PMHACC_W_H0
1557 UINT64_C(3120590907), // PMHACC_W_H1
1558 UINT64_C(3422580795), // PMHRACCSU_H
1559 UINT64_C(3456135227), // PMHRACCSU_W
1560 UINT64_C(2617274427), // PMHRACCU_H
1561 UINT64_C(2650828859), // PMHRACCU_W
1562 UINT64_C(2348838971), // PMHRACC_H
1563 UINT64_C(2382393403), // PMHRACC_W
1564 UINT64_C(3959447611), // PMINU_B
1565 UINT64_C(3960528923), // PMINU_DB
1566 UINT64_C(3893420059), // PMINU_DH
1567 UINT64_C(3926974491), // PMINU_DW
1568 UINT64_C(3892338747), // PMINU_H
1569 UINT64_C(3925893179), // PMINU_W
1570 UINT64_C(3825229883), // PMIN_B
1571 UINT64_C(3826311195), // PMIN_DB
1572 UINT64_C(3759202331), // PMIN_DH
1573 UINT64_C(3792756763), // PMIN_DW
1574 UINT64_C(3758121019), // PMIN_H
1575 UINT64_C(3791675451), // PMIN_W
1576 UINT64_C(3087028283), // PMQ2ADDA_H
1577 UINT64_C(3120582715), // PMQ2ADDA_W
1578 UINT64_C(2952810555), // PMQ2ADD_H
1579 UINT64_C(2986364987), // PMQ2ADD_W
1580 UINT64_C(3892342843), // PMQACC_W_H00
1581 UINT64_C(4160770107), // PMQACC_W_H01
1582 UINT64_C(4160778299), // PMQACC_W_H11
1583 UINT64_C(3154137147), // PMQR2ADDA_H
1584 UINT64_C(3187691579), // PMQR2ADDA_W
1585 UINT64_C(3019919419), // PMQR2ADD_H
1586 UINT64_C(3053473851), // PMQR2ADD_W
1587 UINT64_C(3959451707), // PMQRACC_W_H00
1588 UINT64_C(4227878971), // PMQRACC_W_H01
1589 UINT64_C(4227887163), // PMQRACC_W_H11
1590 UINT64_C(2080383131), // PMQRWACC_H
1591 UINT64_C(2013274267), // PMQWACC_H
1592 UINT64_C(3288358971), // PMSEQ_B
1593 UINT64_C(3289440283), // PMSEQ_DB
1594 UINT64_C(3222331419), // PMSEQ_DH
1595 UINT64_C(3255885851), // PMSEQ_DW
1596 UINT64_C(3221250107), // PMSEQ_H
1597 UINT64_C(3254804539), // PMSEQ_W
1598 UINT64_C(3691012155), // PMSLTU_B
1599 UINT64_C(3692093467), // PMSLTU_DB
1600 UINT64_C(3624984603), // PMSLTU_DH
1601 UINT64_C(3658539035), // PMSLTU_DW
1602 UINT64_C(3623903291), // PMSLTU_H
1603 UINT64_C(3657457723), // PMSLTU_W
1604 UINT64_C(3556794427), // PMSLT_B
1605 UINT64_C(3557875739), // PMSLT_DB
1606 UINT64_C(3490766875), // PMSLT_DH
1607 UINT64_C(3524321307), // PMSLT_DW
1608 UINT64_C(3489685563), // PMSLT_H
1609 UINT64_C(3523239995), // PMSLT_W
1610 UINT64_C(3288363067), // PMULHRSU_H
1611 UINT64_C(3321917499), // PMULHRSU_W
1612 UINT64_C(2483056699), // PMULHRU_H
1613 UINT64_C(2516611131), // PMULHRU_W
1614 UINT64_C(2214621243), // PMULHR_H
1615 UINT64_C(2248175675), // PMULHR_W
1616 UINT64_C(3221254203), // PMULHSU_H
1617 UINT64_C(2751492155), // PMULHSU_H_B0
1618 UINT64_C(3019927611), // PMULHSU_H_B1
1619 UINT64_C(3254808635), // PMULHSU_W
1620 UINT64_C(2785046587), // PMULHSU_W_H0
1621 UINT64_C(3053482043), // PMULHSU_W_H1
1622 UINT64_C(2415947835), // PMULHU_H
1623 UINT64_C(2449502267), // PMULHU_W
1624 UINT64_C(2147512379), // PMULH_H
1625 UINT64_C(2684383291), // PMULH_H_B0
1626 UINT64_C(2952818747), // PMULH_H_B1
1627 UINT64_C(2181066811), // PMULH_W
1628 UINT64_C(2717937723), // PMULH_W_H0
1629 UINT64_C(2986373179), // PMULH_W_H1
1630 UINT64_C(3556798523), // PMULQR_H
1631 UINT64_C(3590352955), // PMULQR_W
1632 UINT64_C(3489689659), // PMULQ_H
1633 UINT64_C(3523244091), // PMULQ_W
1634 UINT64_C(3758108731), // PMULSU_H_B00
1635 UINT64_C(4026544187), // PMULSU_H_B11
1636 UINT64_C(3791663163), // PMULSU_W_H00
1637 UINT64_C(4060098619), // PMULSU_W_H11
1638 UINT64_C(2684366907), // PMULU_H_B00
1639 UINT64_C(2952794171), // PMULU_H_B01
1640 UINT64_C(2952802363), // PMULU_H_B11
1641 UINT64_C(2717921339), // PMULU_W_H00
1642 UINT64_C(2986348603), // PMULU_W_H01
1643 UINT64_C(2986356795), // PMULU_W_H11
1644 UINT64_C(2147495995), // PMUL_H_B00
1645 UINT64_C(2415923259), // PMUL_H_B01
1646 UINT64_C(2415931451), // PMUL_H_B11
1647 UINT64_C(2181050427), // PMUL_W_H00
1648 UINT64_C(2449477691), // PMUL_W_H01
1649 UINT64_C(2449485883), // PMUL_W_H11
1650 UINT64_C(553697307), // PNCLIPIU_B
1651 UINT64_C(570474523), // PNCLIPIU_H
1652 UINT64_C(1627439131), // PNCLIPI_B
1653 UINT64_C(1644216347), // PNCLIPI_H
1654 UINT64_C(3221233723), // PNCLIPP_B
1655 UINT64_C(3254788155), // PNCLIPP_H
1656 UINT64_C(3321897019), // PNCLIPP_W
1657 UINT64_C(822132763), // PNCLIPRIU_B
1658 UINT64_C(838909979), // PNCLIPRIU_H
1659 UINT64_C(1895874587), // PNCLIPRI_B
1660 UINT64_C(1912651803), // PNCLIPRI_H
1661 UINT64_C(939573275), // PNCLIPRU_BS
1662 UINT64_C(973127707), // PNCLIPRU_HS
1663 UINT64_C(2013315099), // PNCLIPR_BS
1664 UINT64_C(2046869531), // PNCLIPR_HS
1665 UINT64_C(2147491899), // PNCLIPUP_B
1666 UINT64_C(2181046331), // PNCLIPUP_H
1667 UINT64_C(2248155195), // PNCLIPUP_W
1668 UINT64_C(671137819), // PNCLIPU_BS
1669 UINT64_C(704692251), // PNCLIPU_HS
1670 UINT64_C(1744879643), // PNCLIP_BS
1671 UINT64_C(1778434075), // PNCLIP_HS
1672 UINT64_C(1090568219), // PNSRAI_B
1673 UINT64_C(1107345435), // PNSRAI_H
1674 UINT64_C(1359003675), // PNSRARI_B
1675 UINT64_C(1375780891), // PNSRARI_H
1676 UINT64_C(1476444187), // PNSRAR_BS
1677 UINT64_C(1509998619), // PNSRAR_HS
1678 UINT64_C(1208008731), // PNSRA_BS
1679 UINT64_C(1241563163), // PNSRA_HS
1680 UINT64_C(16826395), // PNSRLI_B
1681 UINT64_C(33603611), // PNSRLI_H
1682 UINT64_C(134266907), // PNSRL_BS
1683 UINT64_C(167821339), // PNSRL_HS
1684 UINT64_C(2415935547), // PPAIREO_B
1685 UINT64_C(2415976475), // PPAIREO_DB
1686 UINT64_C(2449530907), // PPAIREO_DH
1687 UINT64_C(2449489979), // PPAIREO_H
1688 UINT64_C(2516598843), // PPAIREO_W
1689 UINT64_C(2147500091), // PPAIRE_B
1690 UINT64_C(2147541019), // PPAIRE_DB
1691 UINT64_C(2181095451), // PPAIRE_DH
1692 UINT64_C(2181054523), // PPAIRE_H
1693 UINT64_C(2684371003), // PPAIROE_B
1694 UINT64_C(2684411931), // PPAIROE_DB
1695 UINT64_C(2717966363), // PPAIROE_DH
1696 UINT64_C(2717925435), // PPAIROE_H
1697 UINT64_C(2785034299), // PPAIROE_W
1698 UINT64_C(2952806459), // PPAIRO_B
1699 UINT64_C(2952847387), // PPAIRO_DB
1700 UINT64_C(2986401819), // PPAIRO_DH
1701 UINT64_C(2986360891), // PPAIRO_H
1702 UINT64_C(3053469755), // PPAIRO_W
1703 UINT64_C(3154133019), // PREDSUMU_BS
1704 UINT64_C(1006649371), // PREDSUMU_DBS
1705 UINT64_C(939540507), // PREDSUMU_DHS
1706 UINT64_C(3087024155), // PREDSUMU_HS
1707 UINT64_C(3120578587), // PREDSUMU_WS
1708 UINT64_C(2617262107), // PREDSUM_BS
1709 UINT64_C(469778459), // PREDSUM_DBS
1710 UINT64_C(402669595), // PREDSUM_DHS
1711 UINT64_C(2550153243), // PREDSUM_HS
1712 UINT64_C(2583707675), // PREDSUM_WS
1713 UINT64_C(24595), // PREFETCH_I
1714 UINT64_C(1073171), // PREFETCH_R
1715 UINT64_C(3170323), // PREFETCH_W
1716 UINT64_C(3832553499), // PSABS_B
1717 UINT64_C(1685086235), // PSABS_DB
1718 UINT64_C(1617977371), // PSABS_DH
1719 UINT64_C(3765444635), // PSABS_H
1720 UINT64_C(3019898939), // PSADDU_B
1721 UINT64_C(3019923483), // PSADDU_DB
1722 UINT64_C(2952814619), // PSADDU_DH
1723 UINT64_C(2986369051), // PSADDU_DW
1724 UINT64_C(2952790075), // PSADDU_H
1725 UINT64_C(2986344507), // PSADDU_W
1726 UINT64_C(2483028027), // PSADD_B
1727 UINT64_C(2483052571), // PSADD_DB
1728 UINT64_C(2415943707), // PSADD_DH
1729 UINT64_C(2449498139), // PSADD_DW
1730 UINT64_C(2415919163), // PSADD_H
1731 UINT64_C(2449473595), // PSADD_W
1732 UINT64_C(2417025051), // PSAS_DHX
1733 UINT64_C(2415943739), // PSAS_HX
1734 UINT64_C(2449498171), // PSAS_WX
1735 UINT64_C(1627447323), // PSATI_DH
1736 UINT64_C(1644224539), // PSATI_DW
1737 UINT64_C(3774890011), // PSATI_H
1738 UINT64_C(3791667227), // PSATI_W
1739 UINT64_C(2215698459), // PSA_DHX
1740 UINT64_C(2214617147), // PSA_HX
1741 UINT64_C(2248171579), // PSA_WX
1742 UINT64_C(1614831643), // PSEXT_DH_B
1743 UINT64_C(1648386075), // PSEXT_DW_B
1744 UINT64_C(1649434651), // PSEXT_DW_H
1745 UINT64_C(3762298907), // PSEXT_H_B
1746 UINT64_C(3795853339), // PSEXT_W_B
1747 UINT64_C(3796901915), // PSEXT_W_H
1748 UINT64_C(2685427739), // PSH1ADD_DH
1749 UINT64_C(2718982171), // PSH1ADD_DW
1750 UINT64_C(2684362811), // PSH1ADD_H
1751 UINT64_C(2717917243), // PSH1ADD_W
1752 UINT64_C(2155880475), // PSLLI_B
1753 UINT64_C(8413211), // PSLLI_DB
1754 UINT64_C(16801819), // PSLLI_DH
1755 UINT64_C(33579035), // PSLLI_DW
1756 UINT64_C(2164269083), // PSLLI_H
1757 UINT64_C(2181046299), // PSLLI_W
1758 UINT64_C(2348818459), // PSLL_BS
1759 UINT64_C(201351195), // PSLL_DBS
1760 UINT64_C(134242331), // PSLL_DHS
1761 UINT64_C(167796763), // PSLL_DWS
1762 UINT64_C(2281709595), // PSLL_HS
1763 UINT64_C(2315264027), // PSLL_WS
1764 UINT64_C(3229630491), // PSRAI_B
1765 UINT64_C(1082187803), // PSRAI_DB
1766 UINT64_C(1090576411), // PSRAI_DH
1767 UINT64_C(1107353627), // PSRAI_DW
1768 UINT64_C(3238019099), // PSRAI_H
1769 UINT64_C(3254796315), // PSRAI_W
1770 UINT64_C(1359011867), // PSRARI_DH
1771 UINT64_C(1375789083), // PSRARI_DW
1772 UINT64_C(3506454555), // PSRARI_H
1773 UINT64_C(3523231771), // PSRARI_W
1774 UINT64_C(3422568475), // PSRA_BS
1775 UINT64_C(1275125787), // PSRA_DBS
1776 UINT64_C(1208016923), // PSRA_DHS
1777 UINT64_C(1241571355), // PSRA_DWS
1778 UINT64_C(3355459611), // PSRA_HS
1779 UINT64_C(3389014043), // PSRA_WS
1780 UINT64_C(2155888667), // PSRLI_B
1781 UINT64_C(8445979), // PSRLI_DB
1782 UINT64_C(16834587), // PSRLI_DH
1783 UINT64_C(33611803), // PSRLI_DW
1784 UINT64_C(2164277275), // PSRLI_H
1785 UINT64_C(2181054491), // PSRLI_W
1786 UINT64_C(2348826651), // PSRL_BS
1787 UINT64_C(201383963), // PSRL_DBS
1788 UINT64_C(134275099), // PSRL_DHS
1789 UINT64_C(167829531), // PSRL_DWS
1790 UINT64_C(2281717787), // PSRL_HS
1791 UINT64_C(2315272219), // PSRL_WS
1792 UINT64_C(2484133915), // PSSA_DHX
1793 UINT64_C(2483052603), // PSSA_HX
1794 UINT64_C(2516607035), // PSSA_WX
1795 UINT64_C(2953863195), // PSSH1SADD_DH
1796 UINT64_C(2987417627), // PSSH1SADD_DW
1797 UINT64_C(2952798267), // PSSH1SADD_H
1798 UINT64_C(2986352699), // PSSH1SADD_W
1799 UINT64_C(2013290523), // PSSHAR_DHS
1800 UINT64_C(2046844955), // PSSHAR_DWS
1801 UINT64_C(4160757787), // PSSHAR_HS
1802 UINT64_C(4194312219), // PSSHAR_WS
1803 UINT64_C(1744855067), // PSSHA_DHS
1804 UINT64_C(1778409499), // PSSHA_DWS
1805 UINT64_C(3892322331), // PSSHA_HS
1806 UINT64_C(3925876763), // PSSHA_WS
1807 UINT64_C(939548699), // PSSHLR_DHS
1808 UINT64_C(973103131), // PSSHLR_DWS
1809 UINT64_C(3087015963), // PSSHLR_HS
1810 UINT64_C(3120570395), // PSSHLR_WS
1811 UINT64_C(671113243), // PSSHL_DHS
1812 UINT64_C(704667675), // PSSHL_DWS
1813 UINT64_C(2818580507), // PSSHL_HS
1814 UINT64_C(2852134939), // PSSHL_WS
1815 UINT64_C(1358979099), // PSSLAI_DH
1816 UINT64_C(1375756315), // PSSLAI_DW
1817 UINT64_C(3506446363), // PSSLAI_H
1818 UINT64_C(3523223579), // PSSLAI_W
1819 UINT64_C(4093640763), // PSSUBU_B
1820 UINT64_C(4093665307), // PSSUBU_DB
1821 UINT64_C(4026556443), // PSSUBU_DH
1822 UINT64_C(4060110875), // PSSUBU_DW
1823 UINT64_C(4026531899), // PSSUBU_H
1824 UINT64_C(4060086331), // PSSUBU_W
1825 UINT64_C(3556769851), // PSSUB_B
1826 UINT64_C(3556794395), // PSSUB_DB
1827 UINT64_C(3489685531), // PSSUB_DH
1828 UINT64_C(3523239963), // PSSUB_DW
1829 UINT64_C(3489660987), // PSSUB_H
1830 UINT64_C(3523215419), // PSSUB_W
1831 UINT64_C(3288334395), // PSUB_B
1832 UINT64_C(3288358939), // PSUB_DB
1833 UINT64_C(3221250075), // PSUB_DH
1834 UINT64_C(3254804507), // PSUB_DW
1835 UINT64_C(3221225531), // PSUB_H
1836 UINT64_C(3254779963), // PSUB_W
1837 UINT64_C(553705499), // PUSATI_DH
1838 UINT64_C(570482715), // PUSATI_DW
1839 UINT64_C(2701148187), // PUSATI_H
1840 UINT64_C(2717925403), // PUSATI_W
1841 UINT64_C(469770395), // PWADDAU_B
1842 UINT64_C(402661531), // PWADDAU_H
1843 UINT64_C(201334939), // PWADDA_B
1844 UINT64_C(134226075), // PWADDA_H
1845 UINT64_C(335552667), // PWADDU_B
1846 UINT64_C(268443803), // PWADDU_H
1847 UINT64_C(67117211), // PWADD_B
1848 UINT64_C(8347), // PWADD_H
1849 UINT64_C(1744838811), // PWMACCSU_H
1850 UINT64_C(939532443), // PWMACCU_H
1851 UINT64_C(671096987), // PWMACC_H
1852 UINT64_C(1677729947), // PWMULSU_B
1853 UINT64_C(1610621083), // PWMULSU_H
1854 UINT64_C(872423579), // PWMULU_B
1855 UINT64_C(805314715), // PWMULU_H
1856 UINT64_C(603988123), // PWMUL_B
1857 UINT64_C(536879259), // PWMUL_H
1858 UINT64_C(1090527259), // PWSLAI_B
1859 UINT64_C(1107304475), // PWSLAI_H
1860 UINT64_C(1207967771), // PWSLA_BS
1861 UINT64_C(1241522203), // PWSLA_HS
1862 UINT64_C(16785435), // PWSLLI_B
1863 UINT64_C(33562651), // PWSLLI_H
1864 UINT64_C(134225947), // PWSLL_BS
1865 UINT64_C(167780379), // PWSLL_HS
1866 UINT64_C(1543512219), // PWSUBAU_B
1867 UINT64_C(1476403355), // PWSUBAU_H
1868 UINT64_C(1275076763), // PWSUBA_B
1869 UINT64_C(1207967899), // PWSUBA_H
1870 UINT64_C(1409294491), // PWSUBU_B
1871 UINT64_C(1342185627), // PWSUBU_H
1872 UINT64_C(1140859035), // PWSUB_B
1873 UINT64_C(1073750171), // PWSUB_H
1874 UINT64_C(469774347), // QC_ADDSAT
1875 UINT64_C(503328779), // QC_ADDUSAT
1876 UINT64_C(123), // QC_BEQI
1877 UINT64_C(20603), // QC_BGEI
1878 UINT64_C(28795), // QC_BGEUI
1879 UINT64_C(16507), // QC_BLTI
1880 UINT64_C(24699), // QC_BLTUI
1881 UINT64_C(4219), // QC_BNEI
1882 UINT64_C(201338891), // QC_BREV32
1883 UINT64_C(134230027), // QC_CLO
1884 UINT64_C(3456106611), // QC_CLRINTI
1885 UINT64_C(44130), // QC_CM_MVA01S
1886 UINT64_C(44066), // QC_CM_MVSA01
1887 UINT64_C(47618), // QC_CM_POP
1888 UINT64_C(48642), // QC_CM_POPRET
1889 UINT64_C(48130), // QC_CM_POPRETZ
1890 UINT64_C(47106), // QC_CM_PUSH
1891 UINT64_C(47362), // QC_CM_PUSHFP
1892 UINT64_C(12299), // QC_COMPRESS2
1893 UINT64_C(33566731), // QC_COMPRESS3
1894 UINT64_C(2348810355), // QC_CSRRWR
1895 UINT64_C(2382364787), // QC_CSRRWRI
1896 UINT64_C(167784459), // QC_CTO
1897 UINT64_C(36865), // QC_C_BEXTI
1898 UINT64_C(37889), // QC_C_BSETI
1899 UINT64_C(4110), // QC_C_CLRINT
1900 UINT64_C(6930), // QC_C_DI
1901 UINT64_C(4098), // QC_C_DIR
1902 UINT64_C(7058), // QC_C_EI
1903 UINT64_C(4102), // QC_C_EIR
1904 UINT64_C(4098), // QC_C_EXTU
1905 UINT64_C(6162), // QC_C_MIENTER
1906 UINT64_C(6290), // QC_C_MIENTER_NEST
1907 UINT64_C(6674), // QC_C_MILEAVERET
1908 UINT64_C(6546), // QC_C_MNRET
1909 UINT64_C(6418), // QC_C_MRET
1910 UINT64_C(8194), // QC_C_MULIADD
1911 UINT64_C(44034), // QC_C_MVEQZ
1912 UINT64_C(4106), // QC_C_SETINT
1913 UINT64_C(32769), // QC_C_SYNC
1914 UINT64_C(33793), // QC_C_SYNCR
1915 UINT64_C(36865), // QC_C_SYNCWF
1916 UINT64_C(37889), // QC_C_SYNCWL
1917 UINT64_C(67121163), // QC_EXPAND2
1918 UINT64_C(100675595), // QC_EXPAND3
1919 UINT64_C(1073750027), // QC_EXT
1920 UINT64_C(3221233675), // QC_EXTD
1921 UINT64_C(268447755), // QC_EXTDPR
1922 UINT64_C(302002187), // QC_EXTDPRH
1923 UINT64_C(167784459), // QC_EXTDR
1924 UINT64_C(2147491851), // QC_EXTDU
1925 UINT64_C(201338891), // QC_EXTDUPR
1926 UINT64_C(234893323), // QC_EXTDUPRH
1927 UINT64_C(134230027), // QC_EXTDUR
1928 UINT64_C(8203), // QC_EXTU
1929 UINT64_C(8223), // QC_E_ADDAI
1930 UINT64_C(2147495967), // QC_E_ADDI
1931 UINT64_C(40991), // QC_E_ANDAI
1932 UINT64_C(3221237791), // QC_E_ANDI
1933 UINT64_C(25182239), // QC_E_BEQI
1934 UINT64_C(30425119), // QC_E_BGEI
1935 UINT64_C(32522271), // QC_E_BGEUI
1936 UINT64_C(29376543), // QC_E_BLTI
1937 UINT64_C(31473695), // QC_E_BLTUI
1938 UINT64_C(26230815), // QC_E_BNEI
1939 UINT64_C(16415), // QC_E_J
1940 UINT64_C(49183), // QC_E_JAL
1941 UINT64_C(20511), // QC_E_LB
1942 UINT64_C(1073762335), // QC_E_LBU
1943 UINT64_C(2147504159), // QC_E_LH
1944 UINT64_C(3221245983), // QC_E_LHU
1945 UINT64_C(31), // QC_E_LI
1946 UINT64_C(24607), // QC_E_LW
1947 UINT64_C(36895), // QC_E_ORAI
1948 UINT64_C(1073754143), // QC_E_ORI
1949 UINT64_C(1073766431), // QC_E_SB
1950 UINT64_C(2147508255), // QC_E_SH
1951 UINT64_C(3221250079), // QC_E_SW
1952 UINT64_C(4127), // QC_E_XORAI
1953 UINT64_C(12319), // QC_E_XORI
1954 UINT64_C(1073745931), // QC_INSB
1955 UINT64_C(2147487755), // QC_INSBH
1956 UINT64_C(33566731), // QC_INSBHR
1957 UINT64_C(4107), // QC_INSBI
1958 UINT64_C(67121163), // QC_INSBPR
1959 UINT64_C(100675595), // QC_INSBPRH
1960 UINT64_C(12299), // QC_INSBR
1961 UINT64_C(2147483659), // QC_INSBRI
1962 UINT64_C(20491), // QC_INW
1963 UINT64_C(27), // QC_LI
1964 UINT64_C(33554523), // QC_LIEQ
1965 UINT64_C(100663387), // QC_LIEQI
1966 UINT64_C(33575003), // QC_LIGE
1967 UINT64_C(100683867), // QC_LIGEI
1968 UINT64_C(33583195), // QC_LIGEU
1969 UINT64_C(100692059), // QC_LIGEUI
1970 UINT64_C(33570907), // QC_LILT
1971 UINT64_C(100679771), // QC_LILTI
1972 UINT64_C(33579099), // QC_LILTU
1973 UINT64_C(100687963), // QC_LILTUI
1974 UINT64_C(33558619), // QC_LINE
1975 UINT64_C(100667483), // QC_LINEI
1976 UINT64_C(2147512331), // QC_LRB
1977 UINT64_C(2952818699), // QC_LRBU
1978 UINT64_C(2415947787), // QC_LRH
1979 UINT64_C(3221254155), // QC_LRHU
1980 UINT64_C(2684383243), // QC_LRW
1981 UINT64_C(28683), // QC_LWM
1982 UINT64_C(1073770507), // QC_LWMI
1983 UINT64_C(24587), // QC_MULIADD
1984 UINT64_C(91), // QC_MVEQ
1985 UINT64_C(67108955), // QC_MVEQI
1986 UINT64_C(20571), // QC_MVGE
1987 UINT64_C(67129435), // QC_MVGEI
1988 UINT64_C(28763), // QC_MVGEU
1989 UINT64_C(67137627), // QC_MVGEUI
1990 UINT64_C(16475), // QC_MVLT
1991 UINT64_C(67125339), // QC_MVLTI
1992 UINT64_C(24667), // QC_MVLTU
1993 UINT64_C(67133531), // QC_MVLTUI
1994 UINT64_C(4187), // QC_MVNE
1995 UINT64_C(67113051), // QC_MVNEI
1996 UINT64_C(234893323), // QC_NORM
1997 UINT64_C(302002187), // QC_NORMEU
1998 UINT64_C(268447755), // QC_NORMU
1999 UINT64_C(16395), // QC_OUTW
2000 UINT64_C(1073750035), // QC_PPUTCI
2001 UINT64_C(67117147), // QC_SELECTEQI
2002 UINT64_C(33562715), // QC_SELECTIEQ
2003 UINT64_C(100671579), // QC_SELECTIEQI
2004 UINT64_C(8283), // QC_SELECTIIEQ
2005 UINT64_C(12379), // QC_SELECTIINE
2006 UINT64_C(33566811), // QC_SELECTINE
2007 UINT64_C(100675675), // QC_SELECTINEI
2008 UINT64_C(67121243), // QC_SELECTNEI
2009 UINT64_C(3422552179), // QC_SETINTI
2010 UINT64_C(2147512363), // QC_SETWM
2011 UINT64_C(3221254187), // QC_SETWMI
2012 UINT64_C(1073754123), // QC_SHLADD
2013 UINT64_C(335556619), // QC_SHLSAT
2014 UINT64_C(402665483), // QC_SHLUSAT
2015 UINT64_C(3489685547), // QC_SRB
2016 UINT64_C(3758121003), // QC_SRH
2017 UINT64_C(4026556459), // QC_SRW
2018 UINT64_C(536883211), // QC_SUBSAT
2019 UINT64_C(570437643), // QC_SUBUSAT
2020 UINT64_C(28715), // QC_SWM
2021 UINT64_C(1073770539), // QC_SWMI
2022 UINT64_C(268447763), // QC_SYNC
2023 UINT64_C(536883219), // QC_SYNCR
2024 UINT64_C(1073754131), // QC_SYNCWF
2025 UINT64_C(2147495955), // QC_SYNCWL
2026 UINT64_C(603992075), // QC_WRAP
2027 UINT64_C(11), // QC_WRAPI
2028 UINT64_C(8192), // QK_C_LBU
2029 UINT64_C(32768), // QK_C_LBUSP
2030 UINT64_C(8194), // QK_C_LHU
2031 UINT64_C(32800), // QK_C_LHUSP
2032 UINT64_C(40960), // QK_C_SB
2033 UINT64_C(32832), // QK_C_SBSP
2034 UINT64_C(40962), // QK_C_SH
2035 UINT64_C(32864), // QK_C_SHSP
2036 UINT64_C(33579059), // REM
2037 UINT64_C(33583155), // REMU
2038 UINT64_C(33583163), // REMUW
2039 UINT64_C(33579067), // REMW
2040 UINT64_C(1795182611), // REV16
2041 UINT64_C(1770016787), // REV8_RV32
2042 UINT64_C(1803571219), // REV8_RV64
2043 UINT64_C(1777356819), // REV_RV32
2044 UINT64_C(1810911251), // REV_RV64
2045 UINT64_C(536871003), // RI_VUNZIP2A_VV
2046 UINT64_C(1610612827), // RI_VUNZIP2B_VV
2047 UINT64_C(268435547), // RI_VZIP2A_VV
2048 UINT64_C(1342177371), // RI_VZIP2B_VV
2049 UINT64_C(805306459), // RI_VZIPEVEN_VV
2050 UINT64_C(1879048283), // RI_VZIPODD_VV
2051 UINT64_C(1610616883), // ROL
2052 UINT64_C(1610616891), // ROLW
2053 UINT64_C(1610633267), // ROR
2054 UINT64_C(1610633235), // RORI
2055 UINT64_C(1610633243), // RORIW
2056 UINT64_C(1610633275), // RORW
2057 UINT64_C(2449473595), // SADD
2058 UINT64_C(2986344507), // SADDU
2059 UINT64_C(3791667227), // SATI_RV32
2060 UINT64_C(3825221659), // SATI_RV64
2061 UINT64_C(35), // SB
2062 UINT64_C(1040187439), // SB_AQRL
2063 UINT64_C(973078575), // SB_RL
2064 UINT64_C(272629875), // SCTRCLR
2065 UINT64_C(402665519), // SC_D
2066 UINT64_C(469774383), // SC_D_AQ
2067 UINT64_C(503328815), // SC_D_AQRL
2068 UINT64_C(436219951), // SC_D_RL
2069 UINT64_C(402661423), // SC_W
2070 UINT64_C(469770287), // SC_W_AQ
2071 UINT64_C(503324719), // SC_W_AQRL
2072 UINT64_C(436215855), // SC_W_RL
2073 UINT64_C(12323), // SD
2074 UINT64_C(1040199727), // SD_AQRL
2075 UINT64_C(973090863), // SD_RL
2076 UINT64_C(12323), // SD_RV32
2077 UINT64_C(1614811155), // SEXT_B
2078 UINT64_C(1615859731), // SEXT_H
2079 UINT64_C(403701875), // SFENCE_INVAL_IR
2080 UINT64_C(301990003), // SFENCE_VMA
2081 UINT64_C(402653299), // SFENCE_W_INVAL
2082 UINT64_C(4229955699), // SF_CDISCARD_D_L1
2083 UINT64_C(810549363), // SF_CEASE
2084 UINT64_C(4227858547), // SF_CFLUSH_D_L1
2085 UINT64_C(4261417207), // SF_MM_E4M3_E4M3
2086 UINT64_C(4261417079), // SF_MM_E4M3_E5M2
2087 UINT64_C(4194308343), // SF_MM_E5M2_E4M3
2088 UINT64_C(4194308215), // SF_MM_E5M2_E5M2
2089 UINT64_C(4060090487), // SF_MM_F_F
2090 UINT64_C(4127195383), // SF_MM_S_S
2091 UINT64_C(4127195255), // SF_MM_S_U
2092 UINT64_C(4060086519), // SF_MM_U_S
2093 UINT64_C(4060086391), // SF_MM_U_U
2094 UINT64_C(704663643), // SF_VC_FV
2095 UINT64_C(2852147291), // SF_VC_FVV
2096 UINT64_C(4194324571), // SF_VC_FVW
2097 UINT64_C(33566811), // SF_VC_I
2098 UINT64_C(570437723), // SF_VC_IV
2099 UINT64_C(2717921371), // SF_VC_IVV
2100 UINT64_C(4060098651), // SF_VC_IVW
2101 UINT64_C(570425435), // SF_VC_VV
2102 UINT64_C(2717909083), // SF_VC_VVV
2103 UINT64_C(4060086363), // SF_VC_VVW
2104 UINT64_C(671109211), // SF_VC_V_FV
2105 UINT64_C(2818592859), // SF_VC_V_FVV
2106 UINT64_C(4160770139), // SF_VC_V_FVW
2107 UINT64_C(12379), // SF_VC_V_I
2108 UINT64_C(536883291), // SF_VC_V_IV
2109 UINT64_C(2684366939), // SF_VC_V_IVV
2110 UINT64_C(4026544219), // SF_VC_V_IVW
2111 UINT64_C(536871003), // SF_VC_V_VV
2112 UINT64_C(2684354651), // SF_VC_V_VVV
2113 UINT64_C(4026531931), // SF_VC_V_VVW
2114 UINT64_C(16475), // SF_VC_V_X
2115 UINT64_C(536887387), // SF_VC_V_XV
2116 UINT64_C(2684371035), // SF_VC_V_XVV
2117 UINT64_C(4026548315), // SF_VC_V_XVW
2118 UINT64_C(33570907), // SF_VC_X
2119 UINT64_C(570441819), // SF_VC_XV
2120 UINT64_C(2717925467), // SF_VC_XVV
2121 UINT64_C(4060102747), // SF_VC_XVW
2122 UINT64_C(1275269207), // SF_VFEXPA_V
2123 UINT64_C(1275301975), // SF_VFEXP_V
2124 UINT64_C(2281721947), // SF_VFNRCLIP_XU_F_QF
2125 UINT64_C(2348830811), // SF_VFNRCLIP_X_F_QF
2126 UINT64_C(4060090459), // SF_VFWMACC_4x4x4
2127 UINT64_C(838889479), // SF_VLTE16
2128 UINT64_C(1375760391), // SF_VLTE32
2129 UINT64_C(1912631303), // SF_VLTE64
2130 UINT64_C(302018567), // SF_VLTE8
2131 UINT64_C(3187679323), // SF_VQMACCSU_2x8x2
2132 UINT64_C(4261421147), // SF_VQMACCSU_4x8x4
2133 UINT64_C(3120570459), // SF_VQMACCUS_2x8x2
2134 UINT64_C(4194312283), // SF_VQMACCUS_4x8x4
2135 UINT64_C(2986352731), // SF_VQMACCU_2x8x2
2136 UINT64_C(4060094555), // SF_VQMACCU_4x8x4
2137 UINT64_C(3053461595), // SF_VQMACC_2x8x2
2138 UINT64_C(4127203419), // SF_VQMACC_4x8x4
2139 UINT64_C(2216718423), // SF_VSETTK
2140 UINT64_C(2215669847), // SF_VSETTM
2141 UINT64_C(2214621271), // SF_VSETTN
2142 UINT64_C(838889511), // SF_VSTE16
2143 UINT64_C(1375760423), // SF_VSTE32
2144 UINT64_C(1912631335), // SF_VSTE64
2145 UINT64_C(302018599), // SF_VSTE8
2146 UINT64_C(1136681047), // SF_VTDISCARD
2147 UINT64_C(1577082967), // SF_VTMV_T_V
2148 UINT64_C(1139826775), // SF_VTMV_V_T
2149 UINT64_C(1138778199), // SF_VTZERO_T
2150 UINT64_C(4131), // SH
2151 UINT64_C(536879155), // SH1ADD
2152 UINT64_C(536879163), // SH1ADD_UW
2153 UINT64_C(536887347), // SH2ADD
2154 UINT64_C(536887355), // SH2ADD_UW
2155 UINT64_C(536895539), // SH3ADD
2156 UINT64_C(536895547), // SH3ADD_UW
2157 UINT64_C(3992985627), // SHA
2158 UINT64_C(270536723), // SHA256SIG0
2159 UINT64_C(271585299), // SHA256SIG1
2160 UINT64_C(268439571), // SHA256SUM0
2161 UINT64_C(269488147), // SHA256SUM1
2162 UINT64_C(274731027), // SHA512SIG0
2163 UINT64_C(1543503923), // SHA512SIG0H
2164 UINT64_C(1409286195), // SHA512SIG0L
2165 UINT64_C(275779603), // SHA512SIG1
2166 UINT64_C(1577058355), // SHA512SIG1H
2167 UINT64_C(1442840627), // SHA512SIG1L
2168 UINT64_C(272633875), // SHA512SUM0
2169 UINT64_C(1342177331), // SHA512SUM0R
2170 UINT64_C(273682451), // SHA512SUM1
2171 UINT64_C(1375731763), // SHA512SUM1R
2172 UINT64_C(4261421083), // SHAR
2173 UINT64_C(2919243803), // SHL
2174 UINT64_C(3187679259), // SHLR
2175 UINT64_C(1040191535), // SH_AQRL
2176 UINT64_C(4131), // SH_INX
2177 UINT64_C(973082671), // SH_RL
2178 UINT64_C(369098867), // SINVAL_VMA
2179 UINT64_C(4147), // SLL
2180 UINT64_C(4115), // SLLI
2181 UINT64_C(4123), // SLLIW
2182 UINT64_C(134221851), // SLLI_UW
2183 UINT64_C(4155), // SLLW
2184 UINT64_C(8243), // SLT
2185 UINT64_C(8211), // SLTI
2186 UINT64_C(12307), // SLTIU
2187 UINT64_C(12339), // SLTU
2188 UINT64_C(2382368827), // SLX
2189 UINT64_C(276828179), // SM3P0
2190 UINT64_C(277876755), // SM3P1
2191 UINT64_C(805306419), // SM4ED
2192 UINT64_C(872415283), // SM4KS
2193 UINT64_C(3791663147), // SMT_VMADOT
2194 UINT64_C(3858772011), // SMT_VMADOT1
2195 UINT64_C(3858767915), // SMT_VMADOT1SU
2196 UINT64_C(3858759723), // SMT_VMADOT1U
2197 UINT64_C(3858763819), // SMT_VMADOT1US
2198 UINT64_C(3858788395), // SMT_VMADOT2
2199 UINT64_C(3858784299), // SMT_VMADOT2SU
2200 UINT64_C(3858776107), // SMT_VMADOT2U
2201 UINT64_C(3858780203), // SMT_VMADOT2US
2202 UINT64_C(3858804779), // SMT_VMADOT3
2203 UINT64_C(3858800683), // SMT_VMADOT3SU
2204 UINT64_C(3858792491), // SMT_VMADOT3U
2205 UINT64_C(3858796587), // SMT_VMADOT3US
2206 UINT64_C(3791659051), // SMT_VMADOTSU
2207 UINT64_C(3791650859), // SMT_VMADOTU
2208 UINT64_C(3791654955), // SMT_VMADOTUS
2209 UINT64_C(1073762355), // SRA
2210 UINT64_C(1073762323), // SRAI
2211 UINT64_C(1073762331), // SRAIW
2212 UINT64_C(3523231771), // SRARI_RV32
2213 UINT64_C(3556786203), // SRARI_RV64
2214 UINT64_C(1073762363), // SRAW
2215 UINT64_C(270532723), // SRET
2216 UINT64_C(20531), // SRL
2217 UINT64_C(20499), // SRLI
2218 UINT64_C(20507), // SRLIW
2219 UINT64_C(20539), // SRLW
2220 UINT64_C(2919239739), // SRX
2221 UINT64_C(1207971887), // SSAMOSWAP_D
2222 UINT64_C(1275080751), // SSAMOSWAP_D_AQ
2223 UINT64_C(1308635183), // SSAMOSWAP_D_AQRL
2224 UINT64_C(1241526319), // SSAMOSWAP_D_RL
2225 UINT64_C(1207967791), // SSAMOSWAP_W
2226 UINT64_C(1275076655), // SSAMOSWAP_W_AQ
2227 UINT64_C(1308631087), // SSAMOSWAP_W_AQRL
2228 UINT64_C(1241522223), // SSAMOSWAP_W_RL
2229 UINT64_C(2986352699), // SSH1SADD
2230 UINT64_C(3925876763), // SSHA
2231 UINT64_C(4194312219), // SSHAR
2232 UINT64_C(2852134939), // SSHL
2233 UINT64_C(3120570395), // SSHLR
2234 UINT64_C(3523223579), // SSLAI
2235 UINT64_C(3451928691), // SSPOPCHK
2236 UINT64_C(3456122995), // SSPUSH
2237 UINT64_C(3451928691), // SSRDP
2238 UINT64_C(3523215419), // SSUB
2239 UINT64_C(4060086331), // SSUBU
2240 UINT64_C(1073741875), // SUB
2241 UINT64_C(3321913371), // SUBD
2242 UINT64_C(1073741883), // SUBW
2243 UINT64_C(8227), // SW
2244 UINT64_C(1040195631), // SW_AQRL
2245 UINT64_C(8227), // SW_INX
2246 UINT64_C(973086767), // SW_RL
2247 UINT64_C(4107), // TH_ADDSL
2248 UINT64_C(1048587), // TH_DCACHE_CALL
2249 UINT64_C(3145739), // TH_DCACHE_CIALL
2250 UINT64_C(45088779), // TH_DCACHE_CIPA
2251 UINT64_C(36700171), // TH_DCACHE_CISW
2252 UINT64_C(40894475), // TH_DCACHE_CIVA
2253 UINT64_C(42991627), // TH_DCACHE_CPA
2254 UINT64_C(41943051), // TH_DCACHE_CPAL1
2255 UINT64_C(34603019), // TH_DCACHE_CSW
2256 UINT64_C(38797323), // TH_DCACHE_CVA
2257 UINT64_C(37748747), // TH_DCACHE_CVAL1
2258 UINT64_C(2097163), // TH_DCACHE_IALL
2259 UINT64_C(44040203), // TH_DCACHE_IPA
2260 UINT64_C(35651595), // TH_DCACHE_ISW
2261 UINT64_C(39845899), // TH_DCACHE_IVA
2262 UINT64_C(8203), // TH_EXT
2263 UINT64_C(12299), // TH_EXTU
2264 UINT64_C(2214596619), // TH_FF0
2265 UINT64_C(2248151051), // TH_FF1
2266 UINT64_C(1610637323), // TH_FLRD
2267 UINT64_C(1073766411), // TH_FLRW
2268 UINT64_C(1879072779), // TH_FLURD
2269 UINT64_C(1342201867), // TH_FLURW
2270 UINT64_C(1610641419), // TH_FSRD
2271 UINT64_C(1073770507), // TH_FSRW
2272 UINT64_C(1879076875), // TH_FSURD
2273 UINT64_C(1342205963), // TH_FSURW
2274 UINT64_C(16777227), // TH_ICACHE_IALL
2275 UINT64_C(17825803), // TH_ICACHE_IALLS
2276 UINT64_C(58720267), // TH_ICACHE_IPA
2277 UINT64_C(50331659), // TH_ICACHE_IVA
2278 UINT64_C(22020107), // TH_L2CACHE_CALL
2279 UINT64_C(24117259), // TH_L2CACHE_CIALL
2280 UINT64_C(23068683), // TH_L2CACHE_IALL
2281 UINT64_C(402669579), // TH_LBIA
2282 UINT64_C(134234123), // TH_LBIB
2283 UINT64_C(2550153227), // TH_LBUIA
2284 UINT64_C(2281717771), // TH_LBUIB
2285 UINT64_C(4160765963), // TH_LDD
2286 UINT64_C(2013282315), // TH_LDIA
2287 UINT64_C(1744846859), // TH_LDIB
2288 UINT64_C(939540491), // TH_LHIA
2289 UINT64_C(671105035), // TH_LHIB
2290 UINT64_C(3087024139), // TH_LHUIA
2291 UINT64_C(2818588683), // TH_LHUIB
2292 UINT64_C(16395), // TH_LRB
2293 UINT64_C(2147500043), // TH_LRBU
2294 UINT64_C(1610629131), // TH_LRD
2295 UINT64_C(536887307), // TH_LRH
2296 UINT64_C(2684370955), // TH_LRHU
2297 UINT64_C(1073758219), // TH_LRW
2298 UINT64_C(3221241867), // TH_LRWU
2299 UINT64_C(268451851), // TH_LURB
2300 UINT64_C(2415935499), // TH_LURBU
2301 UINT64_C(1879064587), // TH_LURD
2302 UINT64_C(805322763), // TH_LURH
2303 UINT64_C(2952806411), // TH_LURHU
2304 UINT64_C(1342193675), // TH_LURW
2305 UINT64_C(3489677323), // TH_LURWU
2306 UINT64_C(3758112779), // TH_LWD
2307 UINT64_C(1476411403), // TH_LWIA
2308 UINT64_C(1207975947), // TH_LWIB
2309 UINT64_C(4026548235), // TH_LWUD
2310 UINT64_C(3623895051), // TH_LWUIA
2311 UINT64_C(3355459595), // TH_LWUIB
2312 UINT64_C(536875019), // TH_MULA
2313 UINT64_C(671092747), // TH_MULAH
2314 UINT64_C(603983883), // TH_MULAW
2315 UINT64_C(570429451), // TH_MULS
2316 UINT64_C(704647179), // TH_MULSH
2317 UINT64_C(637538315), // TH_MULSW
2318 UINT64_C(1073745931), // TH_MVEQZ
2319 UINT64_C(1107300363), // TH_MVNEZ
2320 UINT64_C(2181042187), // TH_REV
2321 UINT64_C(2415923211), // TH_REVW
2322 UINT64_C(402673675), // TH_SBIA
2323 UINT64_C(134238219), // TH_SBIB
2324 UINT64_C(4160770059), // TH_SDD
2325 UINT64_C(2013286411), // TH_SDIA
2326 UINT64_C(1744850955), // TH_SDIB
2327 UINT64_C(67108875), // TH_SFENCE_VMAS
2328 UINT64_C(939544587), // TH_SHIA
2329 UINT64_C(671109131), // TH_SHIB
2330 UINT64_C(20491), // TH_SRB
2331 UINT64_C(1610633227), // TH_SRD
2332 UINT64_C(536891403), // TH_SRH
2333 UINT64_C(268439563), // TH_SRRI
2334 UINT64_C(335548427), // TH_SRRIW
2335 UINT64_C(1073762315), // TH_SRW
2336 UINT64_C(268455947), // TH_SURB
2337 UINT64_C(1879068683), // TH_SURD
2338 UINT64_C(805326859), // TH_SURH
2339 UINT64_C(1342197771), // TH_SURW
2340 UINT64_C(3758116875), // TH_SWD
2341 UINT64_C(1476415499), // TH_SWIA
2342 UINT64_C(1207980043), // TH_SWIB
2343 UINT64_C(25165835), // TH_SYNC
2344 UINT64_C(27262987), // TH_SYNC_I
2345 UINT64_C(28311563), // TH_SYNC_IS
2346 UINT64_C(26214411), // TH_SYNC_S
2347 UINT64_C(2281705483), // TH_TST
2348 UINT64_C(2147487755), // TH_TSTNBZ
2349 UINT64_C(2415943691), // TH_VMAQASU_VV
2350 UINT64_C(2483052555), // TH_VMAQASU_VX
2351 UINT64_C(2617270283), // TH_VMAQAUS_VX
2352 UINT64_C(2281725963), // TH_VMAQAU_VV
2353 UINT64_C(2348834827), // TH_VMAQAU_VX
2354 UINT64_C(2147508235), // TH_VMAQA_VV
2355 UINT64_C(2214617099), // TH_VMAQA_VX
2356 UINT64_C(3221229683), // UNIMP
2357 UINT64_C(3858767931), // UNZIP16HP
2358 UINT64_C(3791659067), // UNZIP16P
2359 UINT64_C(3825213499), // UNZIP8HP
2360 UINT64_C(3758104635), // UNZIP8P
2361 UINT64_C(149966867), // UNZIP_RV32
2362 UINT64_C(2717925403), // USATI_RV32
2363 UINT64_C(2751479835), // USATI_RV64
2364 UINT64_C(536879191), // VAADDU_VV
2365 UINT64_C(536895575), // VAADDU_VX
2366 UINT64_C(603988055), // VAADD_VV
2367 UINT64_C(604004439), // VAADD_VX
2368 UINT64_C(1275076695), // VABDU_VV
2369 UINT64_C(1140858967), // VABD_VV
2370 UINT64_C(1208492119), // VABS_V
2371 UINT64_C(1073754199), // VADC_VIM
2372 UINT64_C(1073741911), // VADC_VVM
2373 UINT64_C(1073758295), // VADC_VXM
2374 UINT64_C(12375), // VADD_VI
2375 UINT64_C(87), // VADD_VV
2376 UINT64_C(16471), // VADD_VX
2377 UINT64_C(2785058935), // VAESDF_VS
2378 UINT64_C(2717950071), // VAESDF_VV
2379 UINT64_C(2785026167), // VAESDM_VS
2380 UINT64_C(2717917303), // VAESDM_VV
2381 UINT64_C(2785124471), // VAESEF_VS
2382 UINT64_C(2718015607), // VAESEF_VV
2383 UINT64_C(2785091703), // VAESEM_VS
2384 UINT64_C(2717982839), // VAESEM_VV
2385 UINT64_C(2315264119), // VAESKF1_VI
2386 UINT64_C(2852135031), // VAESKF2_VI
2387 UINT64_C(2785255543), // VAESZ_VS
2388 UINT64_C(67108951), // VANDN_VV
2389 UINT64_C(67125335), // VANDN_VX
2390 UINT64_C(603992151), // VAND_VI
2391 UINT64_C(603979863), // VAND_VV
2392 UINT64_C(603996247), // VAND_VX
2393 UINT64_C(671096919), // VASUBU_VV
2394 UINT64_C(671113303), // VASUBU_VX
2395 UINT64_C(738205783), // VASUB_VV
2396 UINT64_C(738222167), // VASUB_VX
2397 UINT64_C(1208229975), // VBREV8_V
2398 UINT64_C(1208295511), // VBREV_V
2399 UINT64_C(872423511), // VCLMULH_VV
2400 UINT64_C(872439895), // VCLMULH_VX
2401 UINT64_C(805314647), // VCLMUL_VV
2402 UINT64_C(805331031), // VCLMUL_VX
2403 UINT64_C(1208361047), // VCLZ_V
2404 UINT64_C(1577066583), // VCOMPRESS_VM
2405 UINT64_C(1074274391), // VCPOP_M
2406 UINT64_C(1208426583), // VCPOP_V
2407 UINT64_C(1208393815), // VCTZ_V
2408 UINT64_C(2147491927), // VDIVU_VV
2409 UINT64_C(2147508311), // VDIVU_VX
2410 UINT64_C(2214600791), // VDIV_VV
2411 UINT64_C(2214617175), // VDIV_VX
2412 UINT64_C(2818580567), // VDOTA4SU_VV
2413 UINT64_C(2818596951), // VDOTA4SU_VX
2414 UINT64_C(3087032407), // VDOTA4US_VX
2415 UINT64_C(2684362839), // VDOTA4U_VV
2416 UINT64_C(2684379223), // VDOTA4U_VX
2417 UINT64_C(2952798295), // VDOTA4_VV
2418 UINT64_C(2952814679), // VDOTA4_VX
2419 UINT64_C(20567), // VFADD_VF
2420 UINT64_C(4183), // VFADD_VV
2421 UINT64_C(1275596887), // VFCLASS_V
2422 UINT64_C(1208029271), // VFCVT_F_XU_V
2423 UINT64_C(1208062039), // VFCVT_F_X_V
2424 UINT64_C(1208160343), // VFCVT_RTZ_XU_F_V
2425 UINT64_C(1208193111), // VFCVT_RTZ_X_F_V
2426 UINT64_C(1207963735), // VFCVT_XU_F_V
2427 UINT64_C(1207996503), // VFCVT_X_F_V
2428 UINT64_C(2147504215), // VFDIV_VF
2429 UINT64_C(2147487831), // VFDIV_VV
2430 UINT64_C(1074307159), // VFIRST_M
2431 UINT64_C(2952810583), // VFMACC_VF
2432 UINT64_C(2952794199), // VFMACC_VV
2433 UINT64_C(2684375127), // VFMADD_VF
2434 UINT64_C(2684358743), // VFMADD_VV
2435 UINT64_C(402673751), // VFMAX_VF
2436 UINT64_C(402657367), // VFMAX_VV
2437 UINT64_C(1543524439), // VFMERGE_VFM
2438 UINT64_C(268456023), // VFMIN_VF
2439 UINT64_C(268439639), // VFMIN_VV
2440 UINT64_C(3087028311), // VFMSAC_VF
2441 UINT64_C(3087011927), // VFMSAC_VV
2442 UINT64_C(2818592855), // VFMSUB_VF
2443 UINT64_C(2818576471), // VFMSUB_VV
2444 UINT64_C(2415939671), // VFMUL_VF
2445 UINT64_C(2415923287), // VFMUL_VV
2446 UINT64_C(1107300439), // VFMV_F_S
2447 UINT64_C(1107316823), // VFMV_S_F
2448 UINT64_C(1577078871), // VFMV_V_F
2449 UINT64_C(1208914007), // VFNCVTBF16_F_F_W
2450 UINT64_C(1208979543), // VFNCVTBF16_SAT_F_F_W
2451 UINT64_C(1208782935), // VFNCVT_F_F_Q
2452 UINT64_C(1208619095), // VFNCVT_F_F_W
2453 UINT64_C(1208553559), // VFNCVT_F_XU_W
2454 UINT64_C(1208586327), // VFNCVT_F_X_W
2455 UINT64_C(1208651863), // VFNCVT_ROD_F_F_W
2456 UINT64_C(1208684631), // VFNCVT_RTZ_XU_F_W
2457 UINT64_C(1208717399), // VFNCVT_RTZ_X_F_W
2458 UINT64_C(1208848471), // VFNCVT_SAT_F_F_Q
2459 UINT64_C(1208488023), // VFNCVT_XU_F_W
2460 UINT64_C(1208520791), // VFNCVT_X_F_W
2461 UINT64_C(3019919447), // VFNMACC_VF
2462 UINT64_C(3019903063), // VFNMACC_VV
2463 UINT64_C(2751483991), // VFNMADD_VF
2464 UINT64_C(2751467607), // VFNMADD_VV
2465 UINT64_C(3154137175), // VFNMSAC_VF
2466 UINT64_C(3154120791), // VFNMSAC_VV
2467 UINT64_C(2885701719), // VFNMSUB_VF
2468 UINT64_C(2885685335), // VFNMSUB_VV
2469 UINT64_C(2214613079), // VFRDIV_VF
2470 UINT64_C(1275236439), // VFREC7_V
2471 UINT64_C(469766231), // VFREDMAX_VS
2472 UINT64_C(335548503), // VFREDMIN_VS
2473 UINT64_C(201330775), // VFREDOSUM_VS
2474 UINT64_C(67113047), // VFREDUSUM_VS
2475 UINT64_C(1275203671), // VFRSQRT7_V
2476 UINT64_C(2617266263), // VFRSUB_VF
2477 UINT64_C(604000343), // VFSGNJN_VF
2478 UINT64_C(603983959), // VFSGNJN_VV
2479 UINT64_C(671109207), // VFSGNJX_VF
2480 UINT64_C(671092823), // VFSGNJX_VV
2481 UINT64_C(536891479), // VFSGNJ_VF
2482 UINT64_C(536875095), // VFSGNJ_VV
2483 UINT64_C(1006653527), // VFSLIDE1DOWN_VF
2484 UINT64_C(939544663), // VFSLIDE1UP_VF
2485 UINT64_C(1275072599), // VFSQRT_V
2486 UINT64_C(134238295), // VFSUB_VF
2487 UINT64_C(134221911), // VFSUB_VV
2488 UINT64_C(3221246039), // VFWADD_VF
2489 UINT64_C(3221229655), // VFWADD_VV
2490 UINT64_C(3489681495), // VFWADD_WF
2491 UINT64_C(3489665111), // VFWADD_WV
2492 UINT64_C(1208389719), // VFWCVTBF16_F_F_V
2493 UINT64_C(1208356951), // VFWCVT_F_F_V
2494 UINT64_C(1208291415), // VFWCVT_F_XU_V
2495 UINT64_C(1208324183), // VFWCVT_F_X_V
2496 UINT64_C(1208422487), // VFWCVT_RTZ_XU_F_V
2497 UINT64_C(1208455255), // VFWCVT_RTZ_X_F_V
2498 UINT64_C(1208225879), // VFWCVT_XU_F_V
2499 UINT64_C(1208258647), // VFWCVT_X_F_V
2500 UINT64_C(3959443543), // VFWMACCBF16_VF
2501 UINT64_C(3959427159), // VFWMACCBF16_VV
2502 UINT64_C(4026552407), // VFWMACC_VF
2503 UINT64_C(4026536023), // VFWMACC_VV
2504 UINT64_C(4160770135), // VFWMSAC_VF
2505 UINT64_C(4160753751), // VFWMSAC_VV
2506 UINT64_C(3758116951), // VFWMUL_VF
2507 UINT64_C(3758100567), // VFWMUL_VV
2508 UINT64_C(4093661271), // VFWNMACC_VF
2509 UINT64_C(4093644887), // VFWNMACC_VV
2510 UINT64_C(4227878999), // VFWNMSAC_VF
2511 UINT64_C(4227862615), // VFWNMSAC_VV
2512 UINT64_C(3422556247), // VFWREDOSUM_VS
2513 UINT64_C(3288338519), // VFWREDUSUM_VS
2514 UINT64_C(3355463767), // VFWSUB_VF
2515 UINT64_C(3355447383), // VFWSUB_VV
2516 UINT64_C(3623899223), // VFWSUB_WF
2517 UINT64_C(3623882839), // VFWSUB_WV
2518 UINT64_C(2382372983), // VGHSH_VS
2519 UINT64_C(2986352759), // VGHSH_VV
2520 UINT64_C(2785583223), // VGMUL_VS
2521 UINT64_C(2718474359), // VGMUL_VV
2522 UINT64_C(1342742615), // VID_V
2523 UINT64_C(1342709847), // VIOTA_M
2524 UINT64_C(41963527), // VL1RE16_V
2525 UINT64_C(41967623), // VL1RE32_V
2526 UINT64_C(41971719), // VL1RE64_V
2527 UINT64_C(41943047), // VL1RE8_V
2528 UINT64_C(578834439), // VL2RE16_V
2529 UINT64_C(578838535), // VL2RE32_V
2530 UINT64_C(578842631), // VL2RE64_V
2531 UINT64_C(578813959), // VL2RE8_V
2532 UINT64_C(1652576263), // VL4RE16_V
2533 UINT64_C(1652580359), // VL4RE32_V
2534 UINT64_C(1652584455), // VL4RE64_V
2535 UINT64_C(1652555783), // VL4RE8_V
2536 UINT64_C(3800059911), // VL8RE16_V
2537 UINT64_C(3800064007), // VL8RE32_V
2538 UINT64_C(3800068103), // VL8RE64_V
2539 UINT64_C(3800039431), // VL8RE8_V
2540 UINT64_C(16797703), // VLE16FF_V
2541 UINT64_C(20487), // VLE16_V
2542 UINT64_C(16801799), // VLE32FF_V
2543 UINT64_C(24583), // VLE32_V
2544 UINT64_C(16805895), // VLE64FF_V
2545 UINT64_C(28679), // VLE64_V
2546 UINT64_C(16777223), // VLE8FF_V
2547 UINT64_C(7), // VLE8_V
2548 UINT64_C(45088775), // VLM_V
2549 UINT64_C(201347079), // VLOXEI16_V
2550 UINT64_C(201351175), // VLOXEI32_V
2551 UINT64_C(201355271), // VLOXEI64_V
2552 UINT64_C(201326599), // VLOXEI8_V
2553 UINT64_C(738217991), // VLOXSEG2EI16_V
2554 UINT64_C(738222087), // VLOXSEG2EI32_V
2555 UINT64_C(738226183), // VLOXSEG2EI64_V
2556 UINT64_C(738197511), // VLOXSEG2EI8_V
2557 UINT64_C(1275088903), // VLOXSEG3EI16_V
2558 UINT64_C(1275092999), // VLOXSEG3EI32_V
2559 UINT64_C(1275097095), // VLOXSEG3EI64_V
2560 UINT64_C(1275068423), // VLOXSEG3EI8_V
2561 UINT64_C(1811959815), // VLOXSEG4EI16_V
2562 UINT64_C(1811963911), // VLOXSEG4EI32_V
2563 UINT64_C(1811968007), // VLOXSEG4EI64_V
2564 UINT64_C(1811939335), // VLOXSEG4EI8_V
2565 UINT64_C(2348830727), // VLOXSEG5EI16_V
2566 UINT64_C(2348834823), // VLOXSEG5EI32_V
2567 UINT64_C(2348838919), // VLOXSEG5EI64_V
2568 UINT64_C(2348810247), // VLOXSEG5EI8_V
2569 UINT64_C(2885701639), // VLOXSEG6EI16_V
2570 UINT64_C(2885705735), // VLOXSEG6EI32_V
2571 UINT64_C(2885709831), // VLOXSEG6EI64_V
2572 UINT64_C(2885681159), // VLOXSEG6EI8_V
2573 UINT64_C(3422572551), // VLOXSEG7EI16_V
2574 UINT64_C(3422576647), // VLOXSEG7EI32_V
2575 UINT64_C(3422580743), // VLOXSEG7EI64_V
2576 UINT64_C(3422552071), // VLOXSEG7EI8_V
2577 UINT64_C(3959443463), // VLOXSEG8EI16_V
2578 UINT64_C(3959447559), // VLOXSEG8EI32_V
2579 UINT64_C(3959451655), // VLOXSEG8EI64_V
2580 UINT64_C(3959422983), // VLOXSEG8EI8_V
2581 UINT64_C(134238215), // VLSE16_V
2582 UINT64_C(134242311), // VLSE32_V
2583 UINT64_C(134246407), // VLSE64_V
2584 UINT64_C(134217735), // VLSE8_V
2585 UINT64_C(553668615), // VLSEG2E16FF_V
2586 UINT64_C(536891399), // VLSEG2E16_V
2587 UINT64_C(553672711), // VLSEG2E32FF_V
2588 UINT64_C(536895495), // VLSEG2E32_V
2589 UINT64_C(553676807), // VLSEG2E64FF_V
2590 UINT64_C(536899591), // VLSEG2E64_V
2591 UINT64_C(553648135), // VLSEG2E8FF_V
2592 UINT64_C(536870919), // VLSEG2E8_V
2593 UINT64_C(1090539527), // VLSEG3E16FF_V
2594 UINT64_C(1073762311), // VLSEG3E16_V
2595 UINT64_C(1090543623), // VLSEG3E32FF_V
2596 UINT64_C(1073766407), // VLSEG3E32_V
2597 UINT64_C(1090547719), // VLSEG3E64FF_V
2598 UINT64_C(1073770503), // VLSEG3E64_V
2599 UINT64_C(1090519047), // VLSEG3E8FF_V
2600 UINT64_C(1073741831), // VLSEG3E8_V
2601 UINT64_C(1627410439), // VLSEG4E16FF_V
2602 UINT64_C(1610633223), // VLSEG4E16_V
2603 UINT64_C(1627414535), // VLSEG4E32FF_V
2604 UINT64_C(1610637319), // VLSEG4E32_V
2605 UINT64_C(1627418631), // VLSEG4E64FF_V
2606 UINT64_C(1610641415), // VLSEG4E64_V
2607 UINT64_C(1627389959), // VLSEG4E8FF_V
2608 UINT64_C(1610612743), // VLSEG4E8_V
2609 UINT64_C(2164281351), // VLSEG5E16FF_V
2610 UINT64_C(2147504135), // VLSEG5E16_V
2611 UINT64_C(2164285447), // VLSEG5E32FF_V
2612 UINT64_C(2147508231), // VLSEG5E32_V
2613 UINT64_C(2164289543), // VLSEG5E64FF_V
2614 UINT64_C(2147512327), // VLSEG5E64_V
2615 UINT64_C(2164260871), // VLSEG5E8FF_V
2616 UINT64_C(2147483655), // VLSEG5E8_V
2617 UINT64_C(2701152263), // VLSEG6E16FF_V
2618 UINT64_C(2684375047), // VLSEG6E16_V
2619 UINT64_C(2701156359), // VLSEG6E32FF_V
2620 UINT64_C(2684379143), // VLSEG6E32_V
2621 UINT64_C(2701160455), // VLSEG6E64FF_V
2622 UINT64_C(2684383239), // VLSEG6E64_V
2623 UINT64_C(2701131783), // VLSEG6E8FF_V
2624 UINT64_C(2684354567), // VLSEG6E8_V
2625 UINT64_C(3238023175), // VLSEG7E16FF_V
2626 UINT64_C(3221245959), // VLSEG7E16_V
2627 UINT64_C(3238027271), // VLSEG7E32FF_V
2628 UINT64_C(3221250055), // VLSEG7E32_V
2629 UINT64_C(3238031367), // VLSEG7E64FF_V
2630 UINT64_C(3221254151), // VLSEG7E64_V
2631 UINT64_C(3238002695), // VLSEG7E8FF_V
2632 UINT64_C(3221225479), // VLSEG7E8_V
2633 UINT64_C(3774894087), // VLSEG8E16FF_V
2634 UINT64_C(3758116871), // VLSEG8E16_V
2635 UINT64_C(3774898183), // VLSEG8E32FF_V
2636 UINT64_C(3758120967), // VLSEG8E32_V
2637 UINT64_C(3774902279), // VLSEG8E64FF_V
2638 UINT64_C(3758125063), // VLSEG8E64_V
2639 UINT64_C(3774873607), // VLSEG8E8FF_V
2640 UINT64_C(3758096391), // VLSEG8E8_V
2641 UINT64_C(671109127), // VLSSEG2E16_V
2642 UINT64_C(671113223), // VLSSEG2E32_V
2643 UINT64_C(671117319), // VLSSEG2E64_V
2644 UINT64_C(671088647), // VLSSEG2E8_V
2645 UINT64_C(1207980039), // VLSSEG3E16_V
2646 UINT64_C(1207984135), // VLSSEG3E32_V
2647 UINT64_C(1207988231), // VLSSEG3E64_V
2648 UINT64_C(1207959559), // VLSSEG3E8_V
2649 UINT64_C(1744850951), // VLSSEG4E16_V
2650 UINT64_C(1744855047), // VLSSEG4E32_V
2651 UINT64_C(1744859143), // VLSSEG4E64_V
2652 UINT64_C(1744830471), // VLSSEG4E8_V
2653 UINT64_C(2281721863), // VLSSEG5E16_V
2654 UINT64_C(2281725959), // VLSSEG5E32_V
2655 UINT64_C(2281730055), // VLSSEG5E64_V
2656 UINT64_C(2281701383), // VLSSEG5E8_V
2657 UINT64_C(2818592775), // VLSSEG6E16_V
2658 UINT64_C(2818596871), // VLSSEG6E32_V
2659 UINT64_C(2818600967), // VLSSEG6E64_V
2660 UINT64_C(2818572295), // VLSSEG6E8_V
2661 UINT64_C(3355463687), // VLSSEG7E16_V
2662 UINT64_C(3355467783), // VLSSEG7E32_V
2663 UINT64_C(3355471879), // VLSSEG7E64_V
2664 UINT64_C(3355443207), // VLSSEG7E8_V
2665 UINT64_C(3892334599), // VLSSEG8E16_V
2666 UINT64_C(3892338695), // VLSSEG8E32_V
2667 UINT64_C(3892342791), // VLSSEG8E64_V
2668 UINT64_C(3892314119), // VLSSEG8E8_V
2669 UINT64_C(67129351), // VLUXEI16_V
2670 UINT64_C(67133447), // VLUXEI32_V
2671 UINT64_C(67137543), // VLUXEI64_V
2672 UINT64_C(67108871), // VLUXEI8_V
2673 UINT64_C(604000263), // VLUXSEG2EI16_V
2674 UINT64_C(604004359), // VLUXSEG2EI32_V
2675 UINT64_C(604008455), // VLUXSEG2EI64_V
2676 UINT64_C(603979783), // VLUXSEG2EI8_V
2677 UINT64_C(1140871175), // VLUXSEG3EI16_V
2678 UINT64_C(1140875271), // VLUXSEG3EI32_V
2679 UINT64_C(1140879367), // VLUXSEG3EI64_V
2680 UINT64_C(1140850695), // VLUXSEG3EI8_V
2681 UINT64_C(1677742087), // VLUXSEG4EI16_V
2682 UINT64_C(1677746183), // VLUXSEG4EI32_V
2683 UINT64_C(1677750279), // VLUXSEG4EI64_V
2684 UINT64_C(1677721607), // VLUXSEG4EI8_V
2685 UINT64_C(2214612999), // VLUXSEG5EI16_V
2686 UINT64_C(2214617095), // VLUXSEG5EI32_V
2687 UINT64_C(2214621191), // VLUXSEG5EI64_V
2688 UINT64_C(2214592519), // VLUXSEG5EI8_V
2689 UINT64_C(2751483911), // VLUXSEG6EI16_V
2690 UINT64_C(2751488007), // VLUXSEG6EI32_V
2691 UINT64_C(2751492103), // VLUXSEG6EI64_V
2692 UINT64_C(2751463431), // VLUXSEG6EI8_V
2693 UINT64_C(3288354823), // VLUXSEG7EI16_V
2694 UINT64_C(3288358919), // VLUXSEG7EI32_V
2695 UINT64_C(3288363015), // VLUXSEG7EI64_V
2696 UINT64_C(3288334343), // VLUXSEG7EI8_V
2697 UINT64_C(3825225735), // VLUXSEG8EI16_V
2698 UINT64_C(3825229831), // VLUXSEG8EI32_V
2699 UINT64_C(3825233927), // VLUXSEG8EI64_V
2700 UINT64_C(3825205255), // VLUXSEG8EI8_V
2701 UINT64_C(3019907159), // VMACC_VV
2702 UINT64_C(3019923543), // VMACC_VX
2703 UINT64_C(1174417495), // VMADC_VI
2704 UINT64_C(1140863063), // VMADC_VIM
2705 UINT64_C(1174405207), // VMADC_VV
2706 UINT64_C(1140850775), // VMADC_VVM
2707 UINT64_C(1174421591), // VMADC_VX
2708 UINT64_C(1140867159), // VMADC_VXM
2709 UINT64_C(2751471703), // VMADD_VV
2710 UINT64_C(2751488087), // VMADD_VX
2711 UINT64_C(1644175447), // VMANDN_MM
2712 UINT64_C(1711284311), // VMAND_MM
2713 UINT64_C(402653271), // VMAXU_VV
2714 UINT64_C(402669655), // VMAXU_VX
2715 UINT64_C(469762135), // VMAX_VV
2716 UINT64_C(469778519), // VMAX_VX
2717 UINT64_C(1543516247), // VMERGE_VIM
2718 UINT64_C(1543503959), // VMERGE_VVM
2719 UINT64_C(1543520343), // VMERGE_VXM
2720 UINT64_C(1610633303), // VMFEQ_VF
2721 UINT64_C(1610616919), // VMFEQ_VV
2722 UINT64_C(2080395351), // VMFGE_VF
2723 UINT64_C(1946177623), // VMFGT_VF
2724 UINT64_C(1677742167), // VMFLE_VF
2725 UINT64_C(1677725783), // VMFLE_VV
2726 UINT64_C(1811959895), // VMFLT_VF
2727 UINT64_C(1811943511), // VMFLT_VV
2728 UINT64_C(1879068759), // VMFNE_VF
2729 UINT64_C(1879052375), // VMFNE_VV
2730 UINT64_C(268435543), // VMINU_VV
2731 UINT64_C(268451927), // VMINU_VX
2732 UINT64_C(335544407), // VMIN_VV
2733 UINT64_C(335560791), // VMIN_VX
2734 UINT64_C(1979719767), // VMNAND_MM
2735 UINT64_C(2046828631), // VMNOR_MM
2736 UINT64_C(1912610903), // VMORN_MM
2737 UINT64_C(1778393175), // VMOR_MM
2738 UINT64_C(1308622935), // VMSBC_VV
2739 UINT64_C(1275068503), // VMSBC_VVM
2740 UINT64_C(1308639319), // VMSBC_VX
2741 UINT64_C(1275084887), // VMSBC_VXM
2742 UINT64_C(1342218327), // VMSBF_M
2743 UINT64_C(1610625111), // VMSEQ_VI
2744 UINT64_C(1610612823), // VMSEQ_VV
2745 UINT64_C(1610629207), // VMSEQ_VX
2746 UINT64_C(2013278295), // VMSGTU_VI
2747 UINT64_C(2013282391), // VMSGTU_VX
2748 UINT64_C(2080387159), // VMSGT_VI
2749 UINT64_C(2080391255), // VMSGT_VX
2750 UINT64_C(1342283863), // VMSIF_M
2751 UINT64_C(1879060567), // VMSLEU_VI
2752 UINT64_C(1879048279), // VMSLEU_VV
2753 UINT64_C(1879064663), // VMSLEU_VX
2754 UINT64_C(1946169431), // VMSLE_VI
2755 UINT64_C(1946157143), // VMSLE_VV
2756 UINT64_C(1946173527), // VMSLE_VX
2757 UINT64_C(1744830551), // VMSLTU_VV
2758 UINT64_C(1744846935), // VMSLTU_VX
2759 UINT64_C(1811939415), // VMSLT_VV
2760 UINT64_C(1811955799), // VMSLT_VX
2761 UINT64_C(1677733975), // VMSNE_VI
2762 UINT64_C(1677721687), // VMSNE_VV
2763 UINT64_C(1677738071), // VMSNE_VX
2764 UINT64_C(1342251095), // VMSOF_M
2765 UINT64_C(2550145111), // VMULHSU_VV
2766 UINT64_C(2550161495), // VMULHSU_VX
2767 UINT64_C(2415927383), // VMULHU_VV
2768 UINT64_C(2415943767), // VMULHU_VX
2769 UINT64_C(2617253975), // VMULH_VV
2770 UINT64_C(2617270359), // VMULH_VX
2771 UINT64_C(2483036247), // VMUL_VV
2772 UINT64_C(2483052631), // VMUL_VX
2773 UINT64_C(2650812503), // VMV1R_V
2774 UINT64_C(2650845271), // VMV2R_V
2775 UINT64_C(2650910807), // VMV4R_V
2776 UINT64_C(2651041879), // VMV8R_V
2777 UINT64_C(1107320919), // VMV_S_X
2778 UINT64_C(1577070679), // VMV_V_I
2779 UINT64_C(1577058391), // VMV_V_V
2780 UINT64_C(1577074775), // VMV_V_X
2781 UINT64_C(1107304535), // VMV_X_S
2782 UINT64_C(2113937495), // VMXNOR_MM
2783 UINT64_C(1845502039), // VMXOR_MM
2784 UINT64_C(3087020119), // VNCLIPU_WI
2785 UINT64_C(3087007831), // VNCLIPU_WV
2786 UINT64_C(3087024215), // VNCLIPU_WX
2787 UINT64_C(3154128983), // VNCLIP_WI
2788 UINT64_C(3154116695), // VNCLIP_WV
2789 UINT64_C(3154133079), // VNCLIP_WX
2790 UINT64_C(3154124887), // VNMSAC_VV
2791 UINT64_C(3154141271), // VNMSAC_VX
2792 UINT64_C(2885689431), // VNMSUB_VV
2793 UINT64_C(2885705815), // VNMSUB_VX
2794 UINT64_C(3019911255), // VNSRA_WI
2795 UINT64_C(3019898967), // VNSRA_WV
2796 UINT64_C(3019915351), // VNSRA_WX
2797 UINT64_C(2952802391), // VNSRL_WI
2798 UINT64_C(2952790103), // VNSRL_WV
2799 UINT64_C(2952806487), // VNSRL_WX
2800 UINT64_C(671101015), // VOR_VI
2801 UINT64_C(671088727), // VOR_VV
2802 UINT64_C(671105111), // VOR_VX
2803 UINT64_C(1006633047), // VPAIRE_VV
2804 UINT64_C(1006641239), // VPAIRO_VV
2805 UINT64_C(67117143), // VREDAND_VS
2806 UINT64_C(402661463), // VREDMAXU_VS
2807 UINT64_C(469770327), // VREDMAX_VS
2808 UINT64_C(268443735), // VREDMINU_VS
2809 UINT64_C(335552599), // VREDMIN_VS
2810 UINT64_C(134226007), // VREDOR_VS
2811 UINT64_C(8279), // VREDSUM_VS
2812 UINT64_C(201334871), // VREDXOR_VS
2813 UINT64_C(2281709655), // VREMU_VV
2814 UINT64_C(2281726039), // VREMU_VX
2815 UINT64_C(2348818519), // VREM_VV
2816 UINT64_C(2348834903), // VREM_VX
2817 UINT64_C(1208262743), // VREV8_V
2818 UINT64_C(939524183), // VRGATHEREI16_VV
2819 UINT64_C(805318743), // VRGATHER_VI
2820 UINT64_C(805306455), // VRGATHER_VV
2821 UINT64_C(805322839), // VRGATHER_VX
2822 UINT64_C(1409286231), // VROL_VV
2823 UINT64_C(1409302615), // VROL_VX
2824 UINT64_C(1342189655), // VROR_VI
2825 UINT64_C(1342177367), // VROR_VV
2826 UINT64_C(1342193751), // VROR_VX
2827 UINT64_C(201338967), // VRSUB_VI
2828 UINT64_C(201343063), // VRSUB_VX
2829 UINT64_C(41943079), // VS1R_V
2830 UINT64_C(578813991), // VS2R_V
2831 UINT64_C(1652555815), // VS4R_V
2832 UINT64_C(3800039463), // VS8R_V
2833 UINT64_C(2147496023), // VSADDU_VI
2834 UINT64_C(2147483735), // VSADDU_VV
2835 UINT64_C(2147500119), // VSADDU_VX
2836 UINT64_C(2214604887), // VSADD_VI
2837 UINT64_C(2214592599), // VSADD_VV
2838 UINT64_C(2214608983), // VSADD_VX
2839 UINT64_C(1207959639), // VSBC_VVM
2840 UINT64_C(1207976023), // VSBC_VXM
2841 UINT64_C(20519), // VSE16_V
2842 UINT64_C(24615), // VSE32_V
2843 UINT64_C(28711), // VSE64_V
2844 UINT64_C(39), // VSE8_V
2845 UINT64_C(3221254231), // VSETIVLI
2846 UINT64_C(2147512407), // VSETVL
2847 UINT64_C(28759), // VSETVLI
2848 UINT64_C(1208197207), // VSEXT_VF2
2849 UINT64_C(1208131671), // VSEXT_VF4
2850 UINT64_C(1208066135), // VSEXT_VF8
2851 UINT64_C(3120570487), // VSHA2CH_VV
2852 UINT64_C(3187679351), // VSHA2CL_VV
2853 UINT64_C(3053461623), // VSHA2MS_VV
2854 UINT64_C(1006657623), // VSLIDE1DOWN_VX
2855 UINT64_C(939548759), // VSLIDE1UP_VX
2856 UINT64_C(1006645335), // VSLIDEDOWN_VI
2857 UINT64_C(1006649431), // VSLIDEDOWN_VX
2858 UINT64_C(939536471), // VSLIDEUP_VI
2859 UINT64_C(939540567), // VSLIDEUP_VX
2860 UINT64_C(2483040343), // VSLL_VI
2861 UINT64_C(2483028055), // VSLL_VV
2862 UINT64_C(2483044439), // VSLL_VX
2863 UINT64_C(2919243895), // VSM3C_VI
2864 UINT64_C(2181046391), // VSM3ME_VV
2865 UINT64_C(2248155255), // VSM4K_VI
2866 UINT64_C(2785550455), // VSM4R_VS
2867 UINT64_C(2718441591), // VSM4R_VV
2868 UINT64_C(2617245783), // VSMUL_VV
2869 UINT64_C(2617262167), // VSMUL_VX
2870 UINT64_C(45088807), // VSM_V
2871 UINT64_C(201347111), // VSOXEI16_V
2872 UINT64_C(201351207), // VSOXEI32_V
2873 UINT64_C(201355303), // VSOXEI64_V
2874 UINT64_C(201326631), // VSOXEI8_V
2875 UINT64_C(738218023), // VSOXSEG2EI16_V
2876 UINT64_C(738222119), // VSOXSEG2EI32_V
2877 UINT64_C(738226215), // VSOXSEG2EI64_V
2878 UINT64_C(738197543), // VSOXSEG2EI8_V
2879 UINT64_C(1275088935), // VSOXSEG3EI16_V
2880 UINT64_C(1275093031), // VSOXSEG3EI32_V
2881 UINT64_C(1275097127), // VSOXSEG3EI64_V
2882 UINT64_C(1275068455), // VSOXSEG3EI8_V
2883 UINT64_C(1811959847), // VSOXSEG4EI16_V
2884 UINT64_C(1811963943), // VSOXSEG4EI32_V
2885 UINT64_C(1811968039), // VSOXSEG4EI64_V
2886 UINT64_C(1811939367), // VSOXSEG4EI8_V
2887 UINT64_C(2348830759), // VSOXSEG5EI16_V
2888 UINT64_C(2348834855), // VSOXSEG5EI32_V
2889 UINT64_C(2348838951), // VSOXSEG5EI64_V
2890 UINT64_C(2348810279), // VSOXSEG5EI8_V
2891 UINT64_C(2885701671), // VSOXSEG6EI16_V
2892 UINT64_C(2885705767), // VSOXSEG6EI32_V
2893 UINT64_C(2885709863), // VSOXSEG6EI64_V
2894 UINT64_C(2885681191), // VSOXSEG6EI8_V
2895 UINT64_C(3422572583), // VSOXSEG7EI16_V
2896 UINT64_C(3422576679), // VSOXSEG7EI32_V
2897 UINT64_C(3422580775), // VSOXSEG7EI64_V
2898 UINT64_C(3422552103), // VSOXSEG7EI8_V
2899 UINT64_C(3959443495), // VSOXSEG8EI16_V
2900 UINT64_C(3959447591), // VSOXSEG8EI32_V
2901 UINT64_C(3959451687), // VSOXSEG8EI64_V
2902 UINT64_C(3959423015), // VSOXSEG8EI8_V
2903 UINT64_C(2751475799), // VSRA_VI
2904 UINT64_C(2751463511), // VSRA_VV
2905 UINT64_C(2751479895), // VSRA_VX
2906 UINT64_C(2684366935), // VSRL_VI
2907 UINT64_C(2684354647), // VSRL_VV
2908 UINT64_C(2684371031), // VSRL_VX
2909 UINT64_C(134238247), // VSSE16_V
2910 UINT64_C(134242343), // VSSE32_V
2911 UINT64_C(134246439), // VSSE64_V
2912 UINT64_C(134217767), // VSSE8_V
2913 UINT64_C(536891431), // VSSEG2E16_V
2914 UINT64_C(536895527), // VSSEG2E32_V
2915 UINT64_C(536899623), // VSSEG2E64_V
2916 UINT64_C(536870951), // VSSEG2E8_V
2917 UINT64_C(1073762343), // VSSEG3E16_V
2918 UINT64_C(1073766439), // VSSEG3E32_V
2919 UINT64_C(1073770535), // VSSEG3E64_V
2920 UINT64_C(1073741863), // VSSEG3E8_V
2921 UINT64_C(1610633255), // VSSEG4E16_V
2922 UINT64_C(1610637351), // VSSEG4E32_V
2923 UINT64_C(1610641447), // VSSEG4E64_V
2924 UINT64_C(1610612775), // VSSEG4E8_V
2925 UINT64_C(2147504167), // VSSEG5E16_V
2926 UINT64_C(2147508263), // VSSEG5E32_V
2927 UINT64_C(2147512359), // VSSEG5E64_V
2928 UINT64_C(2147483687), // VSSEG5E8_V
2929 UINT64_C(2684375079), // VSSEG6E16_V
2930 UINT64_C(2684379175), // VSSEG6E32_V
2931 UINT64_C(2684383271), // VSSEG6E64_V
2932 UINT64_C(2684354599), // VSSEG6E8_V
2933 UINT64_C(3221245991), // VSSEG7E16_V
2934 UINT64_C(3221250087), // VSSEG7E32_V
2935 UINT64_C(3221254183), // VSSEG7E64_V
2936 UINT64_C(3221225511), // VSSEG7E8_V
2937 UINT64_C(3758116903), // VSSEG8E16_V
2938 UINT64_C(3758120999), // VSSEG8E32_V
2939 UINT64_C(3758125095), // VSSEG8E64_V
2940 UINT64_C(3758096423), // VSSEG8E8_V
2941 UINT64_C(2885693527), // VSSRA_VI
2942 UINT64_C(2885681239), // VSSRA_VV
2943 UINT64_C(2885697623), // VSSRA_VX
2944 UINT64_C(2818584663), // VSSRL_VI
2945 UINT64_C(2818572375), // VSSRL_VV
2946 UINT64_C(2818588759), // VSSRL_VX
2947 UINT64_C(671109159), // VSSSEG2E16_V
2948 UINT64_C(671113255), // VSSSEG2E32_V
2949 UINT64_C(671117351), // VSSSEG2E64_V
2950 UINT64_C(671088679), // VSSSEG2E8_V
2951 UINT64_C(1207980071), // VSSSEG3E16_V
2952 UINT64_C(1207984167), // VSSSEG3E32_V
2953 UINT64_C(1207988263), // VSSSEG3E64_V
2954 UINT64_C(1207959591), // VSSSEG3E8_V
2955 UINT64_C(1744850983), // VSSSEG4E16_V
2956 UINT64_C(1744855079), // VSSSEG4E32_V
2957 UINT64_C(1744859175), // VSSSEG4E64_V
2958 UINT64_C(1744830503), // VSSSEG4E8_V
2959 UINT64_C(2281721895), // VSSSEG5E16_V
2960 UINT64_C(2281725991), // VSSSEG5E32_V
2961 UINT64_C(2281730087), // VSSSEG5E64_V
2962 UINT64_C(2281701415), // VSSSEG5E8_V
2963 UINT64_C(2818592807), // VSSSEG6E16_V
2964 UINT64_C(2818596903), // VSSSEG6E32_V
2965 UINT64_C(2818600999), // VSSSEG6E64_V
2966 UINT64_C(2818572327), // VSSSEG6E8_V
2967 UINT64_C(3355463719), // VSSSEG7E16_V
2968 UINT64_C(3355467815), // VSSSEG7E32_V
2969 UINT64_C(3355471911), // VSSSEG7E64_V
2970 UINT64_C(3355443239), // VSSSEG7E8_V
2971 UINT64_C(3892334631), // VSSSEG8E16_V
2972 UINT64_C(3892338727), // VSSSEG8E32_V
2973 UINT64_C(3892342823), // VSSSEG8E64_V
2974 UINT64_C(3892314151), // VSSSEG8E8_V
2975 UINT64_C(2281701463), // VSSUBU_VV
2976 UINT64_C(2281717847), // VSSUBU_VX
2977 UINT64_C(2348810327), // VSSUB_VV
2978 UINT64_C(2348826711), // VSSUB_VX
2979 UINT64_C(134217815), // VSUB_VV
2980 UINT64_C(134234199), // VSUB_VX
2981 UINT64_C(67129383), // VSUXEI16_V
2982 UINT64_C(67133479), // VSUXEI32_V
2983 UINT64_C(67137575), // VSUXEI64_V
2984 UINT64_C(67108903), // VSUXEI8_V
2985 UINT64_C(604000295), // VSUXSEG2EI16_V
2986 UINT64_C(604004391), // VSUXSEG2EI32_V
2987 UINT64_C(604008487), // VSUXSEG2EI64_V
2988 UINT64_C(603979815), // VSUXSEG2EI8_V
2989 UINT64_C(1140871207), // VSUXSEG3EI16_V
2990 UINT64_C(1140875303), // VSUXSEG3EI32_V
2991 UINT64_C(1140879399), // VSUXSEG3EI64_V
2992 UINT64_C(1140850727), // VSUXSEG3EI8_V
2993 UINT64_C(1677742119), // VSUXSEG4EI16_V
2994 UINT64_C(1677746215), // VSUXSEG4EI32_V
2995 UINT64_C(1677750311), // VSUXSEG4EI64_V
2996 UINT64_C(1677721639), // VSUXSEG4EI8_V
2997 UINT64_C(2214613031), // VSUXSEG5EI16_V
2998 UINT64_C(2214617127), // VSUXSEG5EI32_V
2999 UINT64_C(2214621223), // VSUXSEG5EI64_V
3000 UINT64_C(2214592551), // VSUXSEG5EI8_V
3001 UINT64_C(2751483943), // VSUXSEG6EI16_V
3002 UINT64_C(2751488039), // VSUXSEG6EI32_V
3003 UINT64_C(2751492135), // VSUXSEG6EI64_V
3004 UINT64_C(2751463463), // VSUXSEG6EI8_V
3005 UINT64_C(3288354855), // VSUXSEG7EI16_V
3006 UINT64_C(3288358951), // VSUXSEG7EI32_V
3007 UINT64_C(3288363047), // VSUXSEG7EI64_V
3008 UINT64_C(3288334375), // VSUXSEG7EI8_V
3009 UINT64_C(3825225767), // VSUXSEG8EI16_V
3010 UINT64_C(3825229863), // VSUXSEG8EI32_V
3011 UINT64_C(3825233959), // VSUXSEG8EI64_V
3012 UINT64_C(3825205287), // VSUXSEG8EI8_V
3013 UINT64_C(24699), // VT_MASKC
3014 UINT64_C(28795), // VT_MASKCN
3015 UINT64_C(1208328279), // VUNZIPE_V
3016 UINT64_C(1208459351), // VUNZIPO_V
3017 UINT64_C(1476403287), // VWABDAU_VV
3018 UINT64_C(1409294423), // VWABDA_VV
3019 UINT64_C(3221233751), // VWADDU_VV
3020 UINT64_C(3221250135), // VWADDU_VX
3021 UINT64_C(3489669207), // VWADDU_WV
3022 UINT64_C(3489685591), // VWADDU_WX
3023 UINT64_C(3288342615), // VWADD_VV
3024 UINT64_C(3288358999), // VWADD_VX
3025 UINT64_C(3556778071), // VWADD_WV
3026 UINT64_C(3556794455), // VWADD_WX
3027 UINT64_C(4227866711), // VWMACCSU_VV
3028 UINT64_C(4227883095), // VWMACCSU_VX
3029 UINT64_C(4160774231), // VWMACCUS_VX
3030 UINT64_C(4026540119), // VWMACCU_VV
3031 UINT64_C(4026556503), // VWMACCU_VX
3032 UINT64_C(4093648983), // VWMACC_VV
3033 UINT64_C(4093665367), // VWMACC_VX
3034 UINT64_C(3892322391), // VWMULSU_VV
3035 UINT64_C(3892338775), // VWMULSU_VX
3036 UINT64_C(3758104663), // VWMULU_VV
3037 UINT64_C(3758121047), // VWMULU_VX
3038 UINT64_C(3959431255), // VWMUL_VV
3039 UINT64_C(3959447639), // VWMUL_VX
3040 UINT64_C(3221225559), // VWREDSUMU_VS
3041 UINT64_C(3288334423), // VWREDSUM_VS
3042 UINT64_C(3556782167), // VWSLL_VI
3043 UINT64_C(3556769879), // VWSLL_VV
3044 UINT64_C(3556786263), // VWSLL_VX
3045 UINT64_C(3355451479), // VWSUBU_VV
3046 UINT64_C(3355467863), // VWSUBU_VX
3047 UINT64_C(3623886935), // VWSUBU_WV
3048 UINT64_C(3623903319), // VWSUBU_WX
3049 UINT64_C(3422560343), // VWSUB_VV
3050 UINT64_C(3422576727), // VWSUB_VX
3051 UINT64_C(3690995799), // VWSUB_WV
3052 UINT64_C(3691012183), // VWSUB_WX
3053 UINT64_C(738209879), // VXOR_VI
3054 UINT64_C(738197591), // VXOR_VV
3055 UINT64_C(738213975), // VXOR_VX
3056 UINT64_C(1208164439), // VZEXT_VF2
3057 UINT64_C(1208098903), // VZEXT_VF4
3058 UINT64_C(1208033367), // VZEXT_VF8
3059 UINT64_C(4160757847), // VZIP_VV
3060 UINT64_C(33562779), // WADD
3061 UINT64_C(167780507), // WADDA
3062 UINT64_C(436215963), // WADDAU
3063 UINT64_C(301998235), // WADDU
3064 UINT64_C(273678451), // WFI
3065 UINT64_C(704651419), // WMACC
3066 UINT64_C(1778393243), // WMACCSU
3067 UINT64_C(973086875), // WMACCU
3068 UINT64_C(570433691), // WMUL
3069 UINT64_C(1644175515), // WMULSU
3070 UINT64_C(838869147), // WMULU
3071 UINT64_C(13631603), // WRS_NTO
3072 UINT64_C(30408819), // WRS_STO
3073 UINT64_C(1308631067), // WSLA
3074 UINT64_C(1140858907), // WSLAI
3075 UINT64_C(234889243), // WSLL
3076 UINT64_C(67117083), // WSLLI
3077 UINT64_C(1107304603), // WSUB
3078 UINT64_C(1241522331), // WSUBA
3079 UINT64_C(1509957787), // WSUBAU
3080 UINT64_C(1375740059), // WSUBU
3081 UINT64_C(2046828571), // WZIP16P
3082 UINT64_C(2013274139), // WZIP8P
3083 UINT64_C(1073758259), // XNOR
3084 UINT64_C(16435), // XOR
3085 UINT64_C(16403), // XORI
3086 UINT64_C(671096883), // XPERM4
3087 UINT64_C(671105075), // XPERM8
3088 UINT64_C(134234163), // ZEXT_H_RV32
3089 UINT64_C(134234171), // ZEXT_H_RV64
3090 UINT64_C(4127203387), // ZIP16HP
3091 UINT64_C(4060094523), // ZIP16P
3092 UINT64_C(4093648955), // ZIP8HP
3093 UINT64_C(4026540091), // ZIP8P
3094 UINT64_C(149950483), // ZIP_RV32
3095 };
3096 constexpr unsigned FirstSupportedOpcode = 13719;
3097
3098 const unsigned opcode = MI.getOpcode();
3099 if (opcode < FirstSupportedOpcode)
3100 reportUnsupportedInst(Inst: MI);
3101 unsigned TableIndex = opcode - FirstSupportedOpcode;
3102 uint64_t Value = InstBits[TableIndex];
3103 uint64_t op = 0;
3104 (void)op; // suppress warning
3105 switch (opcode) {
3106 case RISCV::C_EBREAK:
3107 case RISCV::C_MOP_11:
3108 case RISCV::C_MOP_13:
3109 case RISCV::C_MOP_15:
3110 case RISCV::C_MOP_3:
3111 case RISCV::C_MOP_7:
3112 case RISCV::C_MOP_9:
3113 case RISCV::C_NOP:
3114 case RISCV::C_SSPOPCHK:
3115 case RISCV::C_SSPUSH:
3116 case RISCV::C_UNIMP:
3117 case RISCV::DRET:
3118 case RISCV::EBREAK:
3119 case RISCV::ECALL:
3120 case RISCV::FENCE_I:
3121 case RISCV::FENCE_TSO:
3122 case RISCV::MIPS_EHB:
3123 case RISCV::MIPS_IHB:
3124 case RISCV::MIPS_PAUSE:
3125 case RISCV::MNRET:
3126 case RISCV::MRET:
3127 case RISCV::QC_C_DI:
3128 case RISCV::QC_C_EI:
3129 case RISCV::QC_C_MIENTER:
3130 case RISCV::QC_C_MIENTER_NEST:
3131 case RISCV::QC_C_MILEAVERET:
3132 case RISCV::QC_C_MNRET:
3133 case RISCV::QC_C_MRET:
3134 case RISCV::SCTRCLR:
3135 case RISCV::SFENCE_INVAL_IR:
3136 case RISCV::SFENCE_W_INVAL:
3137 case RISCV::SF_CEASE:
3138 case RISCV::SF_VTDISCARD:
3139 case RISCV::SRET:
3140 case RISCV::TH_DCACHE_CALL:
3141 case RISCV::TH_DCACHE_CIALL:
3142 case RISCV::TH_DCACHE_IALL:
3143 case RISCV::TH_ICACHE_IALL:
3144 case RISCV::TH_ICACHE_IALLS:
3145 case RISCV::TH_L2CACHE_CALL:
3146 case RISCV::TH_L2CACHE_CIALL:
3147 case RISCV::TH_L2CACHE_IALL:
3148 case RISCV::TH_SYNC:
3149 case RISCV::TH_SYNC_I:
3150 case RISCV::TH_SYNC_IS:
3151 case RISCV::TH_SYNC_S:
3152 case RISCV::UNIMP:
3153 case RISCV::WFI:
3154 case RISCV::WRS_NTO:
3155 case RISCV::WRS_STO: {
3156 break;
3157 }
3158 case RISCV::AIF_FSWG_PS:
3159 case RISCV::AIF_FSWL_PS: {
3160 // op: fs3
3161 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3162 Value |= (op & 0x1f) << 7;
3163 // op: rs1
3164 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3165 Value |= (op & 0x1f) << 15;
3166 break;
3167 }
3168 case RISCV::C_NOP_HINT: {
3169 // op: imm
3170 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3171 Value |= (op & 0x20) << 7;
3172 Value |= (op & 0x1f) << 2;
3173 break;
3174 }
3175 case RISCV::C_LI:
3176 case RISCV::C_LUI: {
3177 // op: imm
3178 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3179 Value |= (op & 0x20) << 7;
3180 Value |= (op & 0x1f) << 2;
3181 // op: rd
3182 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3183 Value |= (op & 0x1f) << 7;
3184 break;
3185 }
3186 case RISCV::AIF_FSLLI_PI:
3187 case RISCV::AIF_FSRAI_PI:
3188 case RISCV::AIF_FSRLI_PI: {
3189 // op: imm
3190 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3191 Value |= (op & 0x1f) << 20;
3192 // op: rs1
3193 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3194 Value |= (op & 0x1f) << 15;
3195 // op: rd
3196 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3197 Value |= (op & 0x1f) << 7;
3198 break;
3199 }
3200 case RISCV::C_FLDSP:
3201 case RISCV::C_LDSP:
3202 case RISCV::C_LDSP_RV32: {
3203 // op: imm
3204 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3205 Value |= (op & 0x20) << 7;
3206 Value |= (op & 0x18) << 2;
3207 Value |= (op & 0x1c0) >> 4;
3208 // op: rd
3209 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3210 Value |= (op & 0x1f) << 7;
3211 break;
3212 }
3213 case RISCV::C_FLWSP:
3214 case RISCV::C_LWSP:
3215 case RISCV::C_LWSP_INX: {
3216 // op: imm
3217 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3218 Value |= (op & 0x20) << 7;
3219 Value |= (op & 0x1c) << 2;
3220 Value |= (op & 0xc0) >> 4;
3221 // op: rd
3222 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3223 Value |= (op & 0x1f) << 7;
3224 break;
3225 }
3226 case RISCV::C_ADDI:
3227 case RISCV::C_ADDIW: {
3228 // op: imm
3229 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3230 Value |= (op & 0x20) << 7;
3231 Value |= (op & 0x1f) << 2;
3232 // op: rd
3233 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3234 Value |= (op & 0x1f) << 7;
3235 break;
3236 }
3237 case RISCV::C_ANDI: {
3238 // op: imm
3239 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3240 Value |= (op & 0x20) << 7;
3241 Value |= (op & 0x1f) << 2;
3242 // op: rs1
3243 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3244 Value |= (op & 0x7) << 7;
3245 break;
3246 }
3247 case RISCV::C_ADDI16SP: {
3248 // op: imm
3249 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3250 Value |= (op & 0x200) << 3;
3251 Value |= (op & 0x10) << 2;
3252 Value |= (op & 0x40) >> 1;
3253 Value |= (op & 0x180) >> 4;
3254 Value |= (op & 0x20) >> 3;
3255 break;
3256 }
3257 case RISCV::C_ADDI4SPN: {
3258 // op: imm
3259 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3260 Value |= (op & 0x30) << 7;
3261 Value |= (op & 0x3c0) << 1;
3262 Value |= (op & 0x4) << 4;
3263 Value |= (op & 0x8) << 2;
3264 // op: rd
3265 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3266 Value |= (op & 0x7) << 2;
3267 break;
3268 }
3269 case RISCV::C_FSDSP:
3270 case RISCV::C_SDSP:
3271 case RISCV::C_SDSP_RV32: {
3272 // op: imm
3273 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3274 Value |= (op & 0x38) << 7;
3275 Value |= (op & 0x1c0) << 1;
3276 // op: rs2
3277 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3278 Value |= (op & 0x1f) << 2;
3279 break;
3280 }
3281 case RISCV::C_FSWSP:
3282 case RISCV::C_SWSP:
3283 case RISCV::C_SWSP_INX: {
3284 // op: imm
3285 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3286 Value |= (op & 0x3c) << 7;
3287 Value |= (op & 0xc0) << 1;
3288 // op: rs2
3289 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3290 Value |= (op & 0x1f) << 2;
3291 break;
3292 }
3293 case RISCV::AIF_FADDI_PI:
3294 case RISCV::AIF_FANDI_PI: {
3295 // op: imm
3296 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3297 Value |= (op & 0x3e0) << 22;
3298 Value |= (op & 0x1f) << 20;
3299 // op: rs1
3300 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3301 Value |= (op & 0x1f) << 15;
3302 // op: rd
3303 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3304 Value |= (op & 0x1f) << 7;
3305 break;
3306 }
3307 case RISCV::AIF_MOV_M_X: {
3308 // op: imm
3309 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3310 Value |= (op & 0xf8) << 17;
3311 Value |= (op & 0x7) << 12;
3312 // op: rs1
3313 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3314 Value |= (op & 0x1f) << 15;
3315 // op: rd
3316 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3317 Value |= (op & 0x7) << 7;
3318 break;
3319 }
3320 case RISCV::AIF_MASKPOPC_ET_RAST: {
3321 // op: imm
3322 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3323 Value |= (op & 0xc) << 21;
3324 Value |= (op & 0x3) << 18;
3325 // op: rs2
3326 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3327 Value |= (op & 0x7) << 20;
3328 // op: rs1
3329 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3330 Value |= (op & 0x7) << 15;
3331 // op: rd
3332 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3333 Value |= (op & 0x1f) << 7;
3334 break;
3335 }
3336 case RISCV::C_BEQZ:
3337 case RISCV::C_BNEZ: {
3338 // op: imm
3339 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3340 Value |= (op & 0x80) << 5;
3341 Value |= (op & 0xc) << 8;
3342 Value |= (op & 0x60);
3343 Value |= (op & 0x3) << 3;
3344 Value |= (op & 0x10) >> 2;
3345 // op: rs1
3346 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3347 Value |= (op & 0x7) << 7;
3348 break;
3349 }
3350 case RISCV::C_SLLI: {
3351 // op: imm
3352 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3353 Value |= (op & 0x20) << 7;
3354 Value |= (op & 0x1f) << 2;
3355 // op: rd
3356 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3357 Value |= (op & 0x1f) << 7;
3358 break;
3359 }
3360 case RISCV::C_SRAI:
3361 case RISCV::C_SRLI: {
3362 // op: imm
3363 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3364 Value |= (op & 0x20) << 7;
3365 Value |= (op & 0x1f) << 2;
3366 // op: rs1
3367 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3368 Value |= (op & 0x7) << 7;
3369 break;
3370 }
3371 case RISCV::QC_CLRINTI:
3372 case RISCV::QC_SETINTI: {
3373 // op: imm10
3374 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3375 Value |= (op & 0x3ff) << 15;
3376 break;
3377 }
3378 case RISCV::NDS_BEQC:
3379 case RISCV::NDS_BNEC: {
3380 // op: imm10
3381 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3382 Value |= (op & 0x200) << 22;
3383 Value |= (op & 0x1f0) << 21;
3384 Value |= (op & 0xf) << 8;
3385 // op: rs1
3386 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3387 Value |= (op & 0x1f) << 15;
3388 // op: cimm
3389 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3390 Value |= (op & 0x40) << 24;
3391 Value |= (op & 0x1f) << 20;
3392 Value |= (op & 0x20) << 2;
3393 break;
3394 }
3395 case RISCV::NDS_BBC:
3396 case RISCV::NDS_BBS: {
3397 // op: imm10
3398 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3399 Value |= (op & 0x200) << 22;
3400 Value |= (op & 0x1f0) << 21;
3401 Value |= (op & 0xf) << 8;
3402 // op: rs1
3403 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3404 Value |= (op & 0x1f) << 15;
3405 // op: cimm
3406 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3407 Value |= (op & 0x1f) << 20;
3408 Value |= (op & 0x20) << 2;
3409 break;
3410 }
3411 case RISCV::PREFETCH_I:
3412 case RISCV::PREFETCH_R:
3413 case RISCV::PREFETCH_W: {
3414 // op: imm12
3415 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3416 Value |= (op & 0xfe0) << 20;
3417 // op: rs1
3418 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3419 Value |= (op & 0x1f) << 15;
3420 break;
3421 }
3422 case RISCV::AIF_FSQ2:
3423 case RISCV::AIF_FSW_PS: {
3424 // op: imm12
3425 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3426 Value |= (op & 0xfe0) << 20;
3427 Value |= (op & 0x1f) << 7;
3428 // op: rs2
3429 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3430 Value |= (op & 0x1f) << 20;
3431 // op: rs1
3432 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3433 Value |= (op & 0x1f) << 15;
3434 break;
3435 }
3436 case RISCV::FSD:
3437 case RISCV::FSH:
3438 case RISCV::FSQ:
3439 case RISCV::FSW:
3440 case RISCV::SB:
3441 case RISCV::SD:
3442 case RISCV::SD_RV32:
3443 case RISCV::SH:
3444 case RISCV::SH_INX:
3445 case RISCV::SW:
3446 case RISCV::SW_INX: {
3447 // op: imm12
3448 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3449 Value |= (op & 0xfe0) << 20;
3450 Value |= (op & 0x1f) << 7;
3451 // op: rs2
3452 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3453 Value |= (op & 0x1f) << 20;
3454 // op: rs1
3455 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3456 Value |= (op & 0x1f) << 15;
3457 break;
3458 }
3459 case RISCV::CV_SB_ri_inc:
3460 case RISCV::CV_SH_ri_inc:
3461 case RISCV::CV_SW_ri_inc: {
3462 // op: imm12
3463 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3464 Value |= (op & 0xfe0) << 20;
3465 Value |= (op & 0x1f) << 7;
3466 // op: rs2
3467 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3468 Value |= (op & 0x1f) << 20;
3469 // op: rs1
3470 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3471 Value |= (op & 0x1f) << 15;
3472 break;
3473 }
3474 case RISCV::BEQI:
3475 case RISCV::BNEI: {
3476 // op: imm12
3477 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3478 Value |= (op & 0x800) << 20;
3479 Value |= (op & 0x3f0) << 21;
3480 Value |= (op & 0xf) << 8;
3481 Value |= (op & 0x400) >> 3;
3482 // op: cimm
3483 op = getImmOpValueZibi(MI, OpNo: 1, Fixups, STI);
3484 Value |= (op & 0x1f) << 20;
3485 // op: rs1
3486 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3487 Value |= (op & 0x1f) << 15;
3488 break;
3489 }
3490 case RISCV::CV_BEQIMM:
3491 case RISCV::CV_BNEIMM: {
3492 // op: imm12
3493 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3494 Value |= (op & 0x800) << 20;
3495 Value |= (op & 0x3f0) << 21;
3496 Value |= (op & 0xf) << 8;
3497 Value |= (op & 0x400) >> 3;
3498 // op: rs1
3499 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3500 Value |= (op & 0x1f) << 15;
3501 // op: imm5
3502 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3503 Value |= (op & 0x1f) << 20;
3504 break;
3505 }
3506 case RISCV::BEQ:
3507 case RISCV::BGE:
3508 case RISCV::BGEU:
3509 case RISCV::BLT:
3510 case RISCV::BLTU:
3511 case RISCV::BNE:
3512 case RISCV::QC_BEQI:
3513 case RISCV::QC_BGEI:
3514 case RISCV::QC_BGEUI:
3515 case RISCV::QC_BLTI:
3516 case RISCV::QC_BLTUI:
3517 case RISCV::QC_BNEI: {
3518 // op: imm12
3519 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3520 Value |= (op & 0x800) << 20;
3521 Value |= (op & 0x3f0) << 21;
3522 Value |= (op & 0xf) << 8;
3523 Value |= (op & 0x400) >> 3;
3524 // op: rs2
3525 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3526 Value |= (op & 0x1f) << 20;
3527 // op: rs1
3528 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3529 Value |= (op & 0x1f) << 15;
3530 break;
3531 }
3532 case RISCV::NDS_SHGP: {
3533 // op: imm17
3534 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3535 Value |= (op & 0x10000) << 15;
3536 Value |= (op & 0x3f0) << 21;
3537 Value |= (op & 0x3800) << 6;
3538 Value |= (op & 0xc000) << 1;
3539 Value |= (op & 0xf) << 8;
3540 Value |= (op & 0x400) >> 3;
3541 // op: rs2
3542 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3543 Value |= (op & 0x1f) << 20;
3544 break;
3545 }
3546 case RISCV::NDS_LHGP:
3547 case RISCV::NDS_LHUGP: {
3548 // op: imm17
3549 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3550 Value |= (op & 0x10000) << 15;
3551 Value |= (op & 0x3ff) << 21;
3552 Value |= (op & 0x400) << 10;
3553 Value |= (op & 0x3800) << 6;
3554 Value |= (op & 0xc000) << 1;
3555 // op: rd
3556 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3557 Value |= (op & 0x1f) << 7;
3558 break;
3559 }
3560 case RISCV::NDS_SWGP: {
3561 // op: imm17
3562 op = getImmOpValueAsrN<2>(MI, OpNo: 1, Fixups, STI);
3563 Value |= (op & 0x10000) << 15;
3564 Value |= (op & 0x1f8) << 22;
3565 Value |= (op & 0x1c00) << 7;
3566 Value |= (op & 0x6000) << 2;
3567 Value |= (op & 0x7) << 9;
3568 Value |= (op & 0x8000) >> 7;
3569 Value |= (op & 0x200) >> 2;
3570 // op: rs2
3571 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3572 Value |= (op & 0x1f) << 20;
3573 break;
3574 }
3575 case RISCV::NDS_LWGP:
3576 case RISCV::NDS_LWUGP: {
3577 // op: imm17
3578 op = getImmOpValueAsrN<2>(MI, OpNo: 1, Fixups, STI);
3579 Value |= (op & 0x10000) << 15;
3580 Value |= (op & 0x1ff) << 22;
3581 Value |= (op & 0x8000) << 6;
3582 Value |= (op & 0x200) << 11;
3583 Value |= (op & 0x1c00) << 7;
3584 Value |= (op & 0x6000) << 2;
3585 // op: rd
3586 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3587 Value |= (op & 0x1f) << 7;
3588 break;
3589 }
3590 case RISCV::NDS_SDGP: {
3591 // op: imm17
3592 op = getImmOpValueAsrN<3>(MI, OpNo: 1, Fixups, STI);
3593 Value |= (op & 0x10000) << 15;
3594 Value |= (op & 0xfc) << 23;
3595 Value |= (op & 0xe00) << 8;
3596 Value |= (op & 0x3000) << 3;
3597 Value |= (op & 0x3) << 10;
3598 Value |= (op & 0xc000) >> 6;
3599 Value |= (op & 0x100) >> 1;
3600 // op: rs2
3601 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3602 Value |= (op & 0x1f) << 20;
3603 break;
3604 }
3605 case RISCV::NDS_LDGP: {
3606 // op: imm17
3607 op = getImmOpValueAsrN<3>(MI, OpNo: 1, Fixups, STI);
3608 Value |= (op & 0x10000) << 15;
3609 Value |= (op & 0xff) << 23;
3610 Value |= (op & 0xc000) << 7;
3611 Value |= (op & 0x100) << 12;
3612 Value |= (op & 0xe00) << 8;
3613 Value |= (op & 0x3000) << 3;
3614 // op: rd
3615 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3616 Value |= (op & 0x1f) << 7;
3617 break;
3618 }
3619 case RISCV::NDS_SBGP: {
3620 // op: imm18
3621 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3622 Value |= (op & 0x20000) << 14;
3623 Value |= (op & 0x7e0) << 20;
3624 Value |= (op & 0x7000) << 5;
3625 Value |= (op & 0x18000);
3626 Value |= (op & 0x1) << 14;
3627 Value |= (op & 0x1e) << 7;
3628 Value |= (op & 0x800) >> 4;
3629 // op: rs2
3630 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3631 Value |= (op & 0x1f) << 20;
3632 break;
3633 }
3634 case RISCV::NDS_ADDIGP:
3635 case RISCV::NDS_LBGP:
3636 case RISCV::NDS_LBUGP: {
3637 // op: imm18
3638 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3639 Value |= (op & 0x20000) << 14;
3640 Value |= (op & 0x7fe) << 20;
3641 Value |= (op & 0x800) << 9;
3642 Value |= (op & 0x7000) << 5;
3643 Value |= (op & 0x18000);
3644 Value |= (op & 0x1) << 14;
3645 // op: rd
3646 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3647 Value |= (op & 0x1f) << 7;
3648 break;
3649 }
3650 case RISCV::QC_LI: {
3651 // op: imm20
3652 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3653 Value |= (op & 0x80000) << 12;
3654 Value |= (op & 0x7fff) << 16;
3655 Value |= (op & 0x78000) >> 3;
3656 // op: rd
3657 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3658 Value |= (op & 0x1f) << 7;
3659 break;
3660 }
3661 case RISCV::AIF_FBCI_PI:
3662 case RISCV::AIF_FBCI_PS:
3663 case RISCV::AUIPC:
3664 case RISCV::LUI: {
3665 // op: imm20
3666 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3667 Value |= (op & 0xfffff) << 12;
3668 // op: rd
3669 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3670 Value |= (op & 0x1f) << 7;
3671 break;
3672 }
3673 case RISCV::JAL: {
3674 // op: imm20
3675 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3676 Value |= (op & 0x80000) << 12;
3677 Value |= (op & 0x3ff) << 21;
3678 Value |= (op & 0x400) << 10;
3679 Value |= (op & 0x7f800) << 1;
3680 // op: rd
3681 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3682 Value |= (op & 0x1f) << 7;
3683 break;
3684 }
3685 case RISCV::QC_E_J:
3686 case RISCV::QC_E_JAL: {
3687 // op: imm31
3688 op = getImmOpValueAsrN<1>(MI, OpNo: 0, Fixups, STI);
3689 Value |= (op & 0x7fff8000) << 17;
3690 Value |= (op & 0x800) << 20;
3691 Value |= (op & 0x3f0) << 21;
3692 Value |= (op & 0x7000) << 5;
3693 Value |= (op & 0xf) << 8;
3694 Value |= (op & 0x400) >> 3;
3695 break;
3696 }
3697 case RISCV::QC_SYNC:
3698 case RISCV::QC_SYNCR:
3699 case RISCV::QC_SYNCWF:
3700 case RISCV::QC_SYNCWL: {
3701 // op: imm5
3702 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3703 Value |= (op & 0x1f) << 20;
3704 break;
3705 }
3706 case RISCV::MIPS_SDP: {
3707 // op: imm7
3708 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3709 Value |= (op & 0x60) << 20;
3710 Value |= (op & 0x18) << 7;
3711 // op: rs3
3712 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3713 Value |= (op & 0x1f) << 27;
3714 // op: rs2
3715 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3716 Value |= (op & 0x1f) << 20;
3717 // op: rs1
3718 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3719 Value |= (op & 0x1f) << 15;
3720 break;
3721 }
3722 case RISCV::MIPS_SWP: {
3723 // op: imm7
3724 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3725 Value |= (op & 0x60) << 20;
3726 Value |= (op & 0x1c) << 7;
3727 // op: rs3
3728 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3729 Value |= (op & 0x1f) << 27;
3730 // op: rs2
3731 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3732 Value |= (op & 0x1f) << 20;
3733 // op: rs1
3734 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3735 Value |= (op & 0x1f) << 15;
3736 break;
3737 }
3738 case RISCV::MIPS_LDP: {
3739 // op: imm7
3740 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3741 Value |= (op & 0x78) << 20;
3742 // op: rs1
3743 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3744 Value |= (op & 0x1f) << 15;
3745 // op: rd1
3746 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3747 Value |= (op & 0x1f) << 7;
3748 // op: rd2
3749 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3750 Value |= (op & 0x1f) << 27;
3751 break;
3752 }
3753 case RISCV::MIPS_LWP: {
3754 // op: imm7
3755 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3756 Value |= (op & 0x7c) << 20;
3757 // op: rs1
3758 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3759 Value |= (op & 0x1f) << 15;
3760 // op: rd1
3761 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3762 Value |= (op & 0x1f) << 7;
3763 // op: rd2
3764 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3765 Value |= (op & 0x1f) << 27;
3766 break;
3767 }
3768 case RISCV::QC_PPUTCI: {
3769 // op: imm8
3770 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3771 Value |= (op & 0xff) << 20;
3772 break;
3773 }
3774 case RISCV::MIPS_PREF: {
3775 // op: imm9
3776 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3777 Value |= (op & 0x1ff) << 20;
3778 // op: rs1
3779 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3780 Value |= (op & 0x1f) << 15;
3781 // op: hint
3782 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3783 Value |= (op & 0x1f) << 7;
3784 break;
3785 }
3786 case RISCV::CM_JT: {
3787 // op: index
3788 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3789 Value |= (op & 0x1f) << 2;
3790 break;
3791 }
3792 case RISCV::CM_JALT: {
3793 // op: index
3794 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3795 Value |= (op & 0xff) << 2;
3796 break;
3797 }
3798 case RISCV::C_J:
3799 case RISCV::C_JAL: {
3800 // op: offset
3801 op = getImmOpValueAsrN<1>(MI, OpNo: 0, Fixups, STI);
3802 Value |= (op & 0x400) << 2;
3803 Value |= (op & 0x8) << 8;
3804 Value |= (op & 0x180) << 2;
3805 Value |= (op & 0x200) >> 1;
3806 Value |= (op & 0x20) << 2;
3807 Value |= (op & 0x40);
3808 Value |= (op & 0x7) << 3;
3809 Value |= (op & 0x10) >> 2;
3810 break;
3811 }
3812 case RISCV::InsnCJ: {
3813 // op: opcode
3814 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3815 Value |= (op & 0x3);
3816 // op: funct3
3817 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3818 Value |= (op & 0x7) << 13;
3819 // op: imm11
3820 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3821 Value |= (op & 0x400) << 2;
3822 Value |= (op & 0x8) << 8;
3823 Value |= (op & 0x180) << 2;
3824 Value |= (op & 0x200) >> 1;
3825 Value |= (op & 0x20) << 2;
3826 Value |= (op & 0x40);
3827 Value |= (op & 0x7) << 3;
3828 Value |= (op & 0x10) >> 2;
3829 break;
3830 }
3831 case RISCV::InsnCS: {
3832 // op: opcode
3833 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3834 Value |= (op & 0x3);
3835 // op: funct3
3836 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3837 Value |= (op & 0x7) << 13;
3838 // op: imm5
3839 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3840 Value |= (op & 0x1c) << 8;
3841 Value |= (op & 0x3) << 5;
3842 // op: rs2
3843 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3844 Value |= (op & 0x7) << 2;
3845 // op: rs1
3846 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3847 Value |= (op & 0x7) << 7;
3848 break;
3849 }
3850 case RISCV::InsnCSS: {
3851 // op: opcode
3852 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3853 Value |= (op & 0x3);
3854 // op: funct3
3855 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3856 Value |= (op & 0x7) << 13;
3857 // op: imm6
3858 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3859 Value |= (op & 0x3f) << 7;
3860 // op: rs2
3861 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3862 Value |= (op & 0x1f) << 2;
3863 break;
3864 }
3865 case RISCV::InsnCB: {
3866 // op: opcode
3867 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3868 Value |= (op & 0x3);
3869 // op: funct3
3870 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3871 Value |= (op & 0x7) << 13;
3872 // op: imm8
3873 op = getImmOpValueAsrN<1>(MI, OpNo: 3, Fixups, STI);
3874 Value |= (op & 0x80) << 5;
3875 Value |= (op & 0xc) << 8;
3876 Value |= (op & 0x60);
3877 Value |= (op & 0x3) << 3;
3878 Value |= (op & 0x10) >> 2;
3879 // op: rs1
3880 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3881 Value |= (op & 0x7) << 7;
3882 break;
3883 }
3884 case RISCV::InsnQC_EJ: {
3885 // op: opcode
3886 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3887 Value |= (op & 0x7f);
3888 // op: func3
3889 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3890 Value |= (op & 0x7) << 12;
3891 // op: func2
3892 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3893 Value |= (op & 0x3) << 15;
3894 // op: func5
3895 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3896 Value |= (op & 0x1f) << 20;
3897 // op: imm31
3898 op = getImmOpValueAsrN<1>(MI, OpNo: 4, Fixups, STI);
3899 Value |= (op & 0x7fff8000) << 17;
3900 Value |= (op & 0x800) << 20;
3901 Value |= (op & 0x3f0) << 21;
3902 Value |= (op & 0x7000) << 5;
3903 Value |= (op & 0xf) << 8;
3904 Value |= (op & 0x400) >> 3;
3905 break;
3906 }
3907 case RISCV::InsnQC_ES: {
3908 // op: opcode
3909 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3910 Value |= (op & 0x7f);
3911 // op: func3
3912 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3913 Value |= (op & 0x7) << 12;
3914 // op: func2
3915 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3916 Value |= (op & 0x3) << 30;
3917 // op: rs1
3918 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
3919 Value |= (op & 0x1f) << 15;
3920 // op: rs2
3921 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3922 Value |= (op & 0x1f) << 20;
3923 // op: imm26
3924 op = getImmOpValue(MI, OpNo: 5, Fixups, STI);
3925 Value |= (op & 0x3fffc00) << 22;
3926 Value |= (op & 0x3e0) << 20;
3927 Value |= (op & 0x1f) << 7;
3928 break;
3929 }
3930 case RISCV::InsnQC_EB: {
3931 // op: opcode
3932 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3933 Value |= (op & 0x7f);
3934 // op: func3
3935 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3936 Value |= (op & 0x7) << 12;
3937 // op: func5
3938 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3939 Value |= (op & 0x1f) << 20;
3940 // op: rs1
3941 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3942 Value |= (op & 0x1f) << 15;
3943 // op: imm12
3944 op = getImmOpValueAsrN<1>(MI, OpNo: 5, Fixups, STI);
3945 Value |= (op & 0x800) << 20;
3946 Value |= (op & 0x3f0) << 21;
3947 Value |= (op & 0xf) << 8;
3948 Value |= (op & 0x400) >> 3;
3949 // op: imm16
3950 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3951 Value |= (op & 0xffff) << 32;
3952 break;
3953 }
3954 case RISCV::InsnS: {
3955 // op: opcode
3956 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3957 Value |= (op & 0x7f);
3958 // op: funct3
3959 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3960 Value |= (op & 0x7) << 12;
3961 // op: imm12
3962 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3963 Value |= (op & 0xfe0) << 20;
3964 Value |= (op & 0x1f) << 7;
3965 // op: rs2
3966 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3967 Value |= (op & 0x1f) << 20;
3968 // op: rs1
3969 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3970 Value |= (op & 0x1f) << 15;
3971 break;
3972 }
3973 case RISCV::InsnB: {
3974 // op: opcode
3975 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3976 Value |= (op & 0x7f);
3977 // op: funct3
3978 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3979 Value |= (op & 0x7) << 12;
3980 // op: imm12
3981 op = getImmOpValueAsrN<1>(MI, OpNo: 4, Fixups, STI);
3982 Value |= (op & 0x800) << 20;
3983 Value |= (op & 0x3f0) << 21;
3984 Value |= (op & 0xf) << 8;
3985 Value |= (op & 0x400) >> 3;
3986 // op: rs2
3987 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3988 Value |= (op & 0x1f) << 20;
3989 // op: rs1
3990 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3991 Value |= (op & 0x1f) << 15;
3992 break;
3993 }
3994 case RISCV::InsnCL: {
3995 // op: opcode
3996 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3997 Value |= (op & 0x3);
3998 // op: funct3
3999 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4000 Value |= (op & 0x7) << 13;
4001 // op: imm5
4002 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4003 Value |= (op & 0x1c) << 8;
4004 Value |= (op & 0x3) << 5;
4005 // op: rd
4006 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4007 Value |= (op & 0x7) << 2;
4008 // op: rs1
4009 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4010 Value |= (op & 0x7) << 7;
4011 break;
4012 }
4013 case RISCV::InsnCI: {
4014 // op: opcode
4015 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4016 Value |= (op & 0x3);
4017 // op: funct3
4018 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4019 Value |= (op & 0x7) << 13;
4020 // op: imm6
4021 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4022 Value |= (op & 0x20) << 7;
4023 Value |= (op & 0x1f) << 2;
4024 // op: rd
4025 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4026 Value |= (op & 0x1f) << 7;
4027 break;
4028 }
4029 case RISCV::InsnCIW: {
4030 // op: opcode
4031 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4032 Value |= (op & 0x3);
4033 // op: funct3
4034 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4035 Value |= (op & 0x7) << 13;
4036 // op: imm8
4037 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4038 Value |= (op & 0xff) << 5;
4039 // op: rd
4040 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4041 Value |= (op & 0x7) << 2;
4042 break;
4043 }
4044 case RISCV::InsnCR: {
4045 // op: opcode
4046 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4047 Value |= (op & 0x3);
4048 // op: funct4
4049 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4050 Value |= (op & 0xf) << 12;
4051 // op: rs2
4052 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4053 Value |= (op & 0x1f) << 2;
4054 // op: rd
4055 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4056 Value |= (op & 0x1f) << 7;
4057 break;
4058 }
4059 case RISCV::InsnCA: {
4060 // op: opcode
4061 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4062 Value |= (op & 0x3);
4063 // op: funct6
4064 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4065 Value |= (op & 0x3f) << 10;
4066 // op: funct2
4067 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4068 Value |= (op & 0x3) << 5;
4069 // op: rd
4070 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4071 Value |= (op & 0x7) << 7;
4072 // op: rs2
4073 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4074 Value |= (op & 0x7) << 2;
4075 break;
4076 }
4077 case RISCV::InsnQC_EAI: {
4078 // op: opcode
4079 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4080 Value |= (op & 0x7f);
4081 // op: func3
4082 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4083 Value |= (op & 0x7) << 12;
4084 // op: func1
4085 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4086 Value |= (op & 0x1) << 15;
4087 // op: rd
4088 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4089 Value |= (op & 0x1f) << 7;
4090 // op: imm32
4091 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4092 Value |= (op & 0xffffffff) << 16;
4093 break;
4094 }
4095 case RISCV::InsnQC_EI:
4096 case RISCV::InsnQC_EI_Mem: {
4097 // op: opcode
4098 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4099 Value |= (op & 0x7f);
4100 // op: func3
4101 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4102 Value |= (op & 0x7) << 12;
4103 // op: func2
4104 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4105 Value |= (op & 0x3) << 30;
4106 // op: rd
4107 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4108 Value |= (op & 0x1f) << 7;
4109 // op: rs1
4110 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4111 Value |= (op & 0x1f) << 15;
4112 // op: imm26
4113 op = getImmOpValue(MI, OpNo: 5, Fixups, STI);
4114 Value |= (op & 0x3fffc00) << 22;
4115 Value |= (op & 0x3ff) << 20;
4116 break;
4117 }
4118 case RISCV::InsnR4: {
4119 // op: opcode
4120 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4121 Value |= (op & 0x7f);
4122 // op: funct2
4123 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4124 Value |= (op & 0x3) << 25;
4125 // op: funct3
4126 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4127 Value |= (op & 0x7) << 12;
4128 // op: rs3
4129 op = getMachineOpValue(MI, MO: MI.getOperand(i: 6), Fixups, STI);
4130 Value |= (op & 0x1f) << 27;
4131 // op: rs2
4132 op = getMachineOpValue(MI, MO: MI.getOperand(i: 5), Fixups, STI);
4133 Value |= (op & 0x1f) << 20;
4134 // op: rs1
4135 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4136 Value |= (op & 0x1f) << 15;
4137 // op: rd
4138 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4139 Value |= (op & 0x1f) << 7;
4140 break;
4141 }
4142 case RISCV::InsnI:
4143 case RISCV::InsnI_Mem: {
4144 // op: opcode
4145 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4146 Value |= (op & 0x7f);
4147 // op: funct3
4148 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4149 Value |= (op & 0x7) << 12;
4150 // op: imm12
4151 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4152 Value |= (op & 0xfff) << 20;
4153 // op: rs1
4154 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4155 Value |= (op & 0x1f) << 15;
4156 // op: rd
4157 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4158 Value |= (op & 0x1f) << 7;
4159 break;
4160 }
4161 case RISCV::InsnR: {
4162 // op: opcode
4163 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4164 Value |= (op & 0x7f);
4165 // op: funct7
4166 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4167 Value |= (op & 0x7f) << 25;
4168 // op: funct3
4169 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4170 Value |= (op & 0x7) << 12;
4171 // op: rs2
4172 op = getMachineOpValue(MI, MO: MI.getOperand(i: 5), Fixups, STI);
4173 Value |= (op & 0x1f) << 20;
4174 // op: rs1
4175 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4176 Value |= (op & 0x1f) << 15;
4177 // op: rd
4178 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4179 Value |= (op & 0x1f) << 7;
4180 break;
4181 }
4182 case RISCV::InsnU: {
4183 // op: opcode
4184 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4185 Value |= (op & 0x7f);
4186 // op: imm20
4187 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4188 Value |= (op & 0xfffff) << 12;
4189 // op: rd
4190 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4191 Value |= (op & 0x1f) << 7;
4192 break;
4193 }
4194 case RISCV::InsnJ: {
4195 // op: opcode
4196 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4197 Value |= (op & 0x7f);
4198 // op: imm20
4199 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
4200 Value |= (op & 0xfffff) << 12;
4201 // op: rd
4202 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4203 Value |= (op & 0x1f) << 7;
4204 break;
4205 }
4206 case RISCV::FENCE: {
4207 // op: pred
4208 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4209 Value |= (op & 0xf) << 24;
4210 // op: succ
4211 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4212 Value |= (op & 0xf) << 20;
4213 break;
4214 }
4215 case RISCV::PLUI_DH: {
4216 // op: rd
4217 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4218 Value |= (op & 0x1e) << 7;
4219 // op: imm10
4220 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4221 Value |= (op & 0x1) << 24;
4222 Value |= (op & 0x3fe) << 14;
4223 break;
4224 }
4225 case RISCV::PLI_DH: {
4226 // op: rd
4227 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4228 Value |= (op & 0x1e) << 7;
4229 // op: imm10
4230 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4231 Value |= (op & 0x1ff) << 16;
4232 Value |= (op & 0x200) << 6;
4233 break;
4234 }
4235 case RISCV::PLI_DB: {
4236 // op: rd
4237 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4238 Value |= (op & 0x1e) << 7;
4239 // op: imm8
4240 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4241 Value |= (op & 0xff) << 16;
4242 break;
4243 }
4244 case RISCV::AIF_MOVA_X_M:
4245 case RISCV::QC_C_DIR:
4246 case RISCV::SSRDP: {
4247 // op: rd
4248 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4249 Value |= (op & 0x1f) << 7;
4250 break;
4251 }
4252 case RISCV::QC_E_LI: {
4253 // op: rd
4254 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4255 Value |= (op & 0x1f) << 7;
4256 // op: imm
4257 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4258 Value |= (op & 0xffffffff) << 16;
4259 break;
4260 }
4261 case RISCV::FLI_D:
4262 case RISCV::FLI_H:
4263 case RISCV::FLI_Q:
4264 case RISCV::FLI_S: {
4265 // op: rd
4266 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4267 Value |= (op & 0x1f) << 7;
4268 // op: imm
4269 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4270 Value |= (op & 0x1f) << 15;
4271 break;
4272 }
4273 case RISCV::PLUI_H:
4274 case RISCV::PLUI_W: {
4275 // op: rd
4276 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4277 Value |= (op & 0x1f) << 7;
4278 // op: imm10
4279 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4280 Value |= (op & 0x1) << 24;
4281 Value |= (op & 0x3fe) << 14;
4282 break;
4283 }
4284 case RISCV::PLI_H:
4285 case RISCV::PLI_W: {
4286 // op: rd
4287 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4288 Value |= (op & 0x1f) << 7;
4289 // op: imm10
4290 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4291 Value |= (op & 0x1ff) << 16;
4292 Value |= (op & 0x200) << 6;
4293 break;
4294 }
4295 case RISCV::PLI_B: {
4296 // op: rd
4297 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4298 Value |= (op & 0x1f) << 7;
4299 // op: imm8
4300 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4301 Value |= (op & 0xff) << 16;
4302 break;
4303 }
4304 case RISCV::AIF_FMVS_X_PS:
4305 case RISCV::AIF_FMVZ_X_PS: {
4306 // op: rd
4307 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4308 Value |= (op & 0x1f) << 7;
4309 // op: rs1
4310 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4311 Value |= (op & 0x1f) << 15;
4312 // op: idx
4313 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4314 Value |= (op & 0x7) << 20;
4315 break;
4316 }
4317 case RISCV::QC_E_ADDI:
4318 case RISCV::QC_E_ANDI:
4319 case RISCV::QC_E_LB:
4320 case RISCV::QC_E_LBU:
4321 case RISCV::QC_E_LH:
4322 case RISCV::QC_E_LHU:
4323 case RISCV::QC_E_LW:
4324 case RISCV::QC_E_ORI:
4325 case RISCV::QC_E_XORI: {
4326 // op: rd
4327 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4328 Value |= (op & 0x1f) << 7;
4329 // op: rs1
4330 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4331 Value |= (op & 0x1f) << 15;
4332 // op: imm
4333 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4334 Value |= (op & 0x3fffc00) << 22;
4335 Value |= (op & 0x3ff) << 20;
4336 break;
4337 }
4338 case RISCV::AIF_FSWIZZ_PS: {
4339 // op: rd
4340 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4341 Value |= (op & 0x1f) << 7;
4342 // op: rs1
4343 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4344 Value |= (op & 0x1f) << 15;
4345 // op: imm
4346 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4347 Value |= (op & 0xf8) << 17;
4348 Value |= (op & 0x7) << 12;
4349 break;
4350 }
4351 case RISCV::NDS_BFOS:
4352 case RISCV::NDS_BFOZ: {
4353 // op: rd
4354 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4355 Value |= (op & 0x1f) << 7;
4356 // op: rs1
4357 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4358 Value |= (op & 0x1f) << 15;
4359 // op: msb
4360 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4361 Value |= (op & 0x3f) << 26;
4362 // op: lsb
4363 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4364 Value |= (op & 0x3f) << 20;
4365 break;
4366 }
4367 case RISCV::AIF_FCVT_PS_PW:
4368 case RISCV::AIF_FCVT_PS_PWU:
4369 case RISCV::AIF_FCVT_PWU_PS:
4370 case RISCV::AIF_FCVT_PW_PS: {
4371 // op: rd
4372 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4373 Value |= (op & 0x1f) << 7;
4374 // op: rs1
4375 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4376 Value |= (op & 0x1f) << 15;
4377 // op: rm
4378 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4379 Value |= (op & 0x7) << 12;
4380 break;
4381 }
4382 case RISCV::AIF_FADD_PS:
4383 case RISCV::AIF_FDIV_PS:
4384 case RISCV::AIF_FMUL_PS:
4385 case RISCV::AIF_FSUB_PS: {
4386 // op: rd
4387 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4388 Value |= (op & 0x1f) << 7;
4389 // op: rs1
4390 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4391 Value |= (op & 0x1f) << 15;
4392 // op: rs2
4393 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4394 Value |= (op & 0x1f) << 20;
4395 // op: rm
4396 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4397 Value |= (op & 0x7) << 12;
4398 break;
4399 }
4400 case RISCV::AIF_FCMOV_PS: {
4401 // op: rd
4402 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4403 Value |= (op & 0x1f) << 7;
4404 // op: rs1
4405 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4406 Value |= (op & 0x1f) << 15;
4407 // op: rs2
4408 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4409 Value |= (op & 0x1f) << 20;
4410 // op: rs3
4411 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4412 Value |= (op & 0x1f) << 27;
4413 break;
4414 }
4415 case RISCV::AIF_FMADD_PS:
4416 case RISCV::AIF_FMSUB_PS:
4417 case RISCV::AIF_FNMADD_PS:
4418 case RISCV::AIF_FNMSUB_PS: {
4419 // op: rd
4420 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4421 Value |= (op & 0x1f) << 7;
4422 // op: rs1
4423 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4424 Value |= (op & 0x1f) << 15;
4425 // op: rs2
4426 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4427 Value |= (op & 0x1f) << 20;
4428 // op: rs3
4429 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4430 Value |= (op & 0x1f) << 27;
4431 // op: rm
4432 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4433 Value |= (op & 0x7) << 12;
4434 break;
4435 }
4436 case RISCV::VSETIVLI: {
4437 // op: rd
4438 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4439 Value |= (op & 0x1f) << 7;
4440 // op: uimm
4441 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4442 Value |= (op & 0x1f) << 15;
4443 // op: vtypei
4444 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4445 Value |= (op & 0x3ff) << 20;
4446 break;
4447 }
4448 case RISCV::VCPOP_M:
4449 case RISCV::VFIRST_M: {
4450 // op: rd
4451 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4452 Value |= (op & 0x1f) << 7;
4453 // op: vm
4454 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
4455 Value |= (op & 0x1) << 25;
4456 // op: vs2
4457 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4458 Value |= (op & 0x1f) << 20;
4459 break;
4460 }
4461 case RISCV::VFMV_F_S:
4462 case RISCV::VMV_X_S: {
4463 // op: rd
4464 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4465 Value |= (op & 0x1f) << 7;
4466 // op: vs2
4467 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4468 Value |= (op & 0x1f) << 20;
4469 break;
4470 }
4471 case RISCV::QK_C_LBU: {
4472 // op: rd
4473 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4474 Value |= (op & 0x7) << 2;
4475 // op: rs1
4476 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4477 Value |= (op & 0x7) << 7;
4478 // op: imm
4479 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4480 Value |= (op & 0x1) << 12;
4481 Value |= (op & 0x18) << 7;
4482 Value |= (op & 0x6) << 4;
4483 break;
4484 }
4485 case RISCV::C_LBU: {
4486 // op: rd
4487 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4488 Value |= (op & 0x7) << 2;
4489 // op: rs1
4490 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4491 Value |= (op & 0x7) << 7;
4492 // op: imm
4493 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4494 Value |= (op & 0x1) << 6;
4495 Value |= (op & 0x2) << 4;
4496 break;
4497 }
4498 case RISCV::C_LH:
4499 case RISCV::C_LHU:
4500 case RISCV::C_LH_INX: {
4501 // op: rd
4502 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4503 Value |= (op & 0x7) << 2;
4504 // op: rs1
4505 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4506 Value |= (op & 0x7) << 7;
4507 // op: imm
4508 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4509 Value |= (op & 0x2) << 4;
4510 break;
4511 }
4512 case RISCV::C_FLW:
4513 case RISCV::C_LW:
4514 case RISCV::C_LW_INX: {
4515 // op: rd
4516 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4517 Value |= (op & 0x7) << 2;
4518 // op: rs1
4519 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4520 Value |= (op & 0x7) << 7;
4521 // op: imm
4522 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4523 Value |= (op & 0x38) << 7;
4524 Value |= (op & 0x4) << 4;
4525 Value |= (op & 0x40) >> 1;
4526 break;
4527 }
4528 case RISCV::QK_C_LHU: {
4529 // op: rd
4530 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4531 Value |= (op & 0x7) << 2;
4532 // op: rs1
4533 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4534 Value |= (op & 0x7) << 7;
4535 // op: imm
4536 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4537 Value |= (op & 0x38) << 7;
4538 Value |= (op & 0x6) << 4;
4539 break;
4540 }
4541 case RISCV::C_FLD:
4542 case RISCV::C_LD:
4543 case RISCV::C_LD_RV32: {
4544 // op: rd
4545 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4546 Value |= (op & 0x7) << 2;
4547 // op: rs1
4548 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4549 Value |= (op & 0x7) << 7;
4550 // op: imm
4551 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4552 Value |= (op & 0x38) << 7;
4553 Value |= (op & 0xc0) >> 1;
4554 break;
4555 }
4556 case RISCV::SF_VTZERO_T: {
4557 // op: rd
4558 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4559 Value |= (op & 0xf) << 8;
4560 break;
4561 }
4562 case RISCV::QC_E_ADDAI:
4563 case RISCV::QC_E_ANDAI:
4564 case RISCV::QC_E_ORAI:
4565 case RISCV::QC_E_XORAI: {
4566 // op: rd
4567 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4568 Value |= (op & 0x1f) << 7;
4569 // op: imm
4570 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4571 Value |= (op & 0xffffffff) << 16;
4572 break;
4573 }
4574 case RISCV::QC_INSBI: {
4575 // op: rd
4576 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4577 Value |= (op & 0x1f) << 7;
4578 // op: imm5
4579 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4580 Value |= (op & 0x1f) << 15;
4581 // op: shamt
4582 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4583 Value |= (op & 0x1f) << 20;
4584 // op: width
4585 op = getImmOpValueMinus1(MI, OpNo: 3, Fixups, STI);
4586 Value |= (op & 0x1f) << 25;
4587 break;
4588 }
4589 case RISCV::QC_C_EXTU: {
4590 // op: rd
4591 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4592 Value |= (op & 0x1f) << 7;
4593 // op: width
4594 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
4595 Value |= (op & 0x1f) << 2;
4596 break;
4597 }
4598 case RISCV::QC_C_MVEQZ: {
4599 // op: rd
4600 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4601 Value |= (op & 0x7) << 2;
4602 // op: rs1
4603 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4604 Value |= (op & 0x7) << 7;
4605 break;
4606 }
4607 case RISCV::QC_C_MULIADD: {
4608 // op: rd
4609 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4610 Value |= (op & 0x7) << 2;
4611 // op: rs1
4612 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4613 Value |= (op & 0x7) << 7;
4614 // op: uimm
4615 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4616 Value |= (op & 0xe) << 9;
4617 Value |= (op & 0x1) << 6;
4618 Value |= (op & 0x10) << 1;
4619 break;
4620 }
4621 case RISCV::C_NOT:
4622 case RISCV::C_SEXT_B:
4623 case RISCV::C_SEXT_H:
4624 case RISCV::C_ZEXT_B:
4625 case RISCV::C_ZEXT_H:
4626 case RISCV::C_ZEXT_W: {
4627 // op: rd
4628 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4629 Value |= (op & 0x7) << 7;
4630 break;
4631 }
4632 case RISCV::QK_C_LHUSP:
4633 case RISCV::QK_C_SHSP: {
4634 // op: rd_rs2
4635 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4636 Value |= (op & 0x7) << 2;
4637 // op: imm
4638 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4639 Value |= (op & 0xe) << 7;
4640 Value |= (op & 0x10) << 3;
4641 break;
4642 }
4643 case RISCV::QK_C_LBUSP:
4644 case RISCV::QK_C_SBSP: {
4645 // op: rd_rs2
4646 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4647 Value |= (op & 0x7) << 2;
4648 // op: imm
4649 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4650 Value |= (op & 0xf) << 7;
4651 break;
4652 }
4653 case RISCV::CM_POP:
4654 case RISCV::CM_POPRET:
4655 case RISCV::CM_POPRETZ:
4656 case RISCV::CM_PUSH:
4657 case RISCV::QC_CM_POP:
4658 case RISCV::QC_CM_POPRET:
4659 case RISCV::QC_CM_POPRETZ:
4660 case RISCV::QC_CM_PUSH: {
4661 // op: rlist
4662 op = getRlistOpValue(MI, OpNo: 0, Fixups, STI);
4663 Value |= (op & 0xf) << 4;
4664 // op: stackadj
4665 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4666 Value |= (op & 0x30) >> 2;
4667 break;
4668 }
4669 case RISCV::QC_CM_PUSHFP: {
4670 // op: rlist
4671 op = getRlistS0OpValue(MI, OpNo: 0, Fixups, STI);
4672 Value |= (op & 0xf) << 4;
4673 // op: stackadj
4674 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4675 Value |= (op & 0x30) >> 2;
4676 break;
4677 }
4678 case RISCV::CSRRCI:
4679 case RISCV::CSRRSI:
4680 case RISCV::CSRRWI: {
4681 // op: rs1
4682 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4683 Value |= (op & 0x1f) << 15;
4684 // op: rd
4685 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4686 Value |= (op & 0x1f) << 7;
4687 // op: imm12
4688 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4689 Value |= (op & 0xfff) << 20;
4690 break;
4691 }
4692 case RISCV::AIF_MOVA_M_X:
4693 case RISCV::CBO_CLEAN:
4694 case RISCV::CBO_FLUSH:
4695 case RISCV::CBO_INVAL:
4696 case RISCV::CBO_ZERO:
4697 case RISCV::SF_CDISCARD_D_L1:
4698 case RISCV::SF_CFLUSH_D_L1:
4699 case RISCV::SSPOPCHK:
4700 case RISCV::TH_DCACHE_CIPA:
4701 case RISCV::TH_DCACHE_CISW:
4702 case RISCV::TH_DCACHE_CIVA:
4703 case RISCV::TH_DCACHE_CPA:
4704 case RISCV::TH_DCACHE_CPAL1:
4705 case RISCV::TH_DCACHE_CSW:
4706 case RISCV::TH_DCACHE_CVA:
4707 case RISCV::TH_DCACHE_CVAL1:
4708 case RISCV::TH_DCACHE_IPA:
4709 case RISCV::TH_DCACHE_ISW:
4710 case RISCV::TH_DCACHE_IVA:
4711 case RISCV::TH_ICACHE_IPA:
4712 case RISCV::TH_ICACHE_IVA: {
4713 // op: rs1
4714 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4715 Value |= (op & 0x1f) << 15;
4716 break;
4717 }
4718 case RISCV::QC_E_BEQI:
4719 case RISCV::QC_E_BGEI:
4720 case RISCV::QC_E_BGEUI:
4721 case RISCV::QC_E_BLTI:
4722 case RISCV::QC_E_BLTUI:
4723 case RISCV::QC_E_BNEI: {
4724 // op: rs1
4725 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4726 Value |= (op & 0x1f) << 15;
4727 // op: imm16
4728 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4729 Value |= (op & 0xffff) << 32;
4730 // op: imm12
4731 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
4732 Value |= (op & 0x800) << 20;
4733 Value |= (op & 0x3f0) << 21;
4734 Value |= (op & 0xf) << 8;
4735 Value |= (op & 0x400) >> 3;
4736 break;
4737 }
4738 case RISCV::C_JALR:
4739 case RISCV::C_JR:
4740 case RISCV::QC_C_CLRINT:
4741 case RISCV::QC_C_EIR:
4742 case RISCV::QC_C_SETINT: {
4743 // op: rs1
4744 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4745 Value |= (op & 0x1f) << 7;
4746 break;
4747 }
4748 case RISCV::C_MV: {
4749 // op: rs1
4750 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4751 Value |= (op & 0x1f) << 7;
4752 // op: rs2
4753 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4754 Value |= (op & 0x1f) << 2;
4755 break;
4756 }
4757 case RISCV::PSABS_DB:
4758 case RISCV::PSABS_DH:
4759 case RISCV::PSEXT_DH_B:
4760 case RISCV::PSEXT_DW_B:
4761 case RISCV::PSEXT_DW_H: {
4762 // op: rs1
4763 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4764 Value |= (op & 0x1e) << 15;
4765 // op: rd
4766 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4767 Value |= (op & 0x1e) << 7;
4768 break;
4769 }
4770 case RISCV::ADDD:
4771 case RISCV::PAADDU_DB:
4772 case RISCV::PAADDU_DH:
4773 case RISCV::PAADDU_DW:
4774 case RISCV::PAADD_DB:
4775 case RISCV::PAADD_DH:
4776 case RISCV::PAADD_DW:
4777 case RISCV::PAAS_DHX:
4778 case RISCV::PABDU_DB:
4779 case RISCV::PABDU_DH:
4780 case RISCV::PABD_DB:
4781 case RISCV::PABD_DH:
4782 case RISCV::PADD_DB:
4783 case RISCV::PADD_DH:
4784 case RISCV::PADD_DW:
4785 case RISCV::PASA_DHX:
4786 case RISCV::PASUBU_DB:
4787 case RISCV::PASUBU_DH:
4788 case RISCV::PASUBU_DW:
4789 case RISCV::PASUB_DB:
4790 case RISCV::PASUB_DH:
4791 case RISCV::PASUB_DW:
4792 case RISCV::PAS_DHX:
4793 case RISCV::PMAXU_DB:
4794 case RISCV::PMAXU_DH:
4795 case RISCV::PMAXU_DW:
4796 case RISCV::PMAX_DB:
4797 case RISCV::PMAX_DH:
4798 case RISCV::PMAX_DW:
4799 case RISCV::PMINU_DB:
4800 case RISCV::PMINU_DH:
4801 case RISCV::PMINU_DW:
4802 case RISCV::PMIN_DB:
4803 case RISCV::PMIN_DH:
4804 case RISCV::PMIN_DW:
4805 case RISCV::PMSEQ_DB:
4806 case RISCV::PMSEQ_DH:
4807 case RISCV::PMSEQ_DW:
4808 case RISCV::PMSLTU_DB:
4809 case RISCV::PMSLTU_DH:
4810 case RISCV::PMSLTU_DW:
4811 case RISCV::PMSLT_DB:
4812 case RISCV::PMSLT_DH:
4813 case RISCV::PMSLT_DW:
4814 case RISCV::PPAIREO_DB:
4815 case RISCV::PPAIREO_DH:
4816 case RISCV::PPAIRE_DB:
4817 case RISCV::PPAIRE_DH:
4818 case RISCV::PPAIROE_DB:
4819 case RISCV::PPAIROE_DH:
4820 case RISCV::PPAIRO_DB:
4821 case RISCV::PPAIRO_DH:
4822 case RISCV::PSADDU_DB:
4823 case RISCV::PSADDU_DH:
4824 case RISCV::PSADDU_DW:
4825 case RISCV::PSADD_DB:
4826 case RISCV::PSADD_DH:
4827 case RISCV::PSADD_DW:
4828 case RISCV::PSAS_DHX:
4829 case RISCV::PSA_DHX:
4830 case RISCV::PSH1ADD_DH:
4831 case RISCV::PSH1ADD_DW:
4832 case RISCV::PSSA_DHX:
4833 case RISCV::PSSH1SADD_DH:
4834 case RISCV::PSSH1SADD_DW:
4835 case RISCV::PSSUBU_DB:
4836 case RISCV::PSSUBU_DH:
4837 case RISCV::PSSUBU_DW:
4838 case RISCV::PSSUB_DB:
4839 case RISCV::PSSUB_DH:
4840 case RISCV::PSSUB_DW:
4841 case RISCV::PSUB_DB:
4842 case RISCV::PSUB_DH:
4843 case RISCV::PSUB_DW:
4844 case RISCV::SUBD: {
4845 // op: rs1
4846 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4847 Value |= (op & 0x1e) << 15;
4848 // op: rd
4849 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4850 Value |= (op & 0x1e) << 7;
4851 // op: rs2
4852 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4853 Value |= (op & 0x1e) << 20;
4854 break;
4855 }
4856 case RISCV::PADD_DBS:
4857 case RISCV::PADD_DHS:
4858 case RISCV::PADD_DWS:
4859 case RISCV::PSLL_DBS:
4860 case RISCV::PSLL_DHS:
4861 case RISCV::PSLL_DWS:
4862 case RISCV::PSRA_DBS:
4863 case RISCV::PSRA_DHS:
4864 case RISCV::PSRA_DWS:
4865 case RISCV::PSRL_DBS:
4866 case RISCV::PSRL_DHS:
4867 case RISCV::PSRL_DWS:
4868 case RISCV::PSSHAR_DHS:
4869 case RISCV::PSSHAR_DWS:
4870 case RISCV::PSSHA_DHS:
4871 case RISCV::PSSHA_DWS:
4872 case RISCV::PSSHLR_DHS:
4873 case RISCV::PSSHLR_DWS:
4874 case RISCV::PSSHL_DHS:
4875 case RISCV::PSSHL_DWS: {
4876 // op: rs1
4877 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4878 Value |= (op & 0x1e) << 15;
4879 // op: rd
4880 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4881 Value |= (op & 0x1e) << 7;
4882 // op: rs2
4883 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4884 Value |= (op & 0x1f) << 20;
4885 break;
4886 }
4887 case RISCV::PSATI_DW:
4888 case RISCV::PSLLI_DW:
4889 case RISCV::PSRAI_DW:
4890 case RISCV::PSRARI_DW:
4891 case RISCV::PSRLI_DW:
4892 case RISCV::PSSLAI_DW:
4893 case RISCV::PUSATI_DW: {
4894 // op: rs1
4895 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4896 Value |= (op & 0x1e) << 15;
4897 // op: rd
4898 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4899 Value |= (op & 0x1e) << 7;
4900 // op: shamt
4901 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4902 Value |= (op & 0x1f) << 20;
4903 break;
4904 }
4905 case RISCV::PSLLI_DB:
4906 case RISCV::PSRAI_DB:
4907 case RISCV::PSRLI_DB: {
4908 // op: rs1
4909 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4910 Value |= (op & 0x1e) << 15;
4911 // op: rd
4912 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4913 Value |= (op & 0x1e) << 7;
4914 // op: shamt
4915 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4916 Value |= (op & 0x7) << 20;
4917 break;
4918 }
4919 case RISCV::PSATI_DH:
4920 case RISCV::PSLLI_DH:
4921 case RISCV::PSRAI_DH:
4922 case RISCV::PSRARI_DH:
4923 case RISCV::PSRLI_DH:
4924 case RISCV::PSSLAI_DH:
4925 case RISCV::PUSATI_DH: {
4926 // op: rs1
4927 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4928 Value |= (op & 0x1e) << 15;
4929 // op: rd
4930 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4931 Value |= (op & 0x1e) << 7;
4932 // op: shamt
4933 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4934 Value |= (op & 0xf) << 20;
4935 break;
4936 }
4937 case RISCV::NCLIP:
4938 case RISCV::NCLIPR:
4939 case RISCV::NCLIPRU:
4940 case RISCV::NCLIPU:
4941 case RISCV::NSRA:
4942 case RISCV::NSRAR:
4943 case RISCV::NSRL:
4944 case RISCV::PNCLIPRU_BS:
4945 case RISCV::PNCLIPRU_HS:
4946 case RISCV::PNCLIPR_BS:
4947 case RISCV::PNCLIPR_HS:
4948 case RISCV::PNCLIPU_BS:
4949 case RISCV::PNCLIPU_HS:
4950 case RISCV::PNCLIP_BS:
4951 case RISCV::PNCLIP_HS:
4952 case RISCV::PNSRAR_BS:
4953 case RISCV::PNSRAR_HS:
4954 case RISCV::PNSRA_BS:
4955 case RISCV::PNSRA_HS:
4956 case RISCV::PNSRL_BS:
4957 case RISCV::PNSRL_HS:
4958 case RISCV::PREDSUMU_DBS:
4959 case RISCV::PREDSUMU_DHS:
4960 case RISCV::PREDSUM_DBS:
4961 case RISCV::PREDSUM_DHS: {
4962 // op: rs1
4963 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4964 Value |= (op & 0x1e) << 15;
4965 // op: rd
4966 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4967 Value |= (op & 0x1f) << 7;
4968 // op: rs2
4969 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4970 Value |= (op & 0x1f) << 20;
4971 break;
4972 }
4973 case RISCV::PNCLIPIU_H:
4974 case RISCV::PNCLIPI_H:
4975 case RISCV::PNCLIPRIU_H:
4976 case RISCV::PNCLIPRI_H:
4977 case RISCV::PNSRAI_H:
4978 case RISCV::PNSRARI_H:
4979 case RISCV::PNSRLI_H: {
4980 // op: rs1
4981 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4982 Value |= (op & 0x1e) << 15;
4983 // op: rd
4984 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4985 Value |= (op & 0x1f) << 7;
4986 // op: shamt
4987 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4988 Value |= (op & 0x1f) << 20;
4989 break;
4990 }
4991 case RISCV::NCLIPI:
4992 case RISCV::NCLIPIU:
4993 case RISCV::NCLIPRI:
4994 case RISCV::NCLIPRIU:
4995 case RISCV::NSRAI:
4996 case RISCV::NSRARI:
4997 case RISCV::NSRLI: {
4998 // op: rs1
4999 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5000 Value |= (op & 0x1e) << 15;
5001 // op: rd
5002 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5003 Value |= (op & 0x1f) << 7;
5004 // op: shamt
5005 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5006 Value |= (op & 0x3f) << 20;
5007 break;
5008 }
5009 case RISCV::PNCLIPIU_B:
5010 case RISCV::PNCLIPI_B:
5011 case RISCV::PNCLIPRIU_B:
5012 case RISCV::PNCLIPRI_B:
5013 case RISCV::PNSRAI_B:
5014 case RISCV::PNSRARI_B:
5015 case RISCV::PNSRLI_B: {
5016 // op: rs1
5017 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5018 Value |= (op & 0x1e) << 15;
5019 // op: rd
5020 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5021 Value |= (op & 0x1f) << 7;
5022 // op: shamt
5023 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5024 Value |= (op & 0xf) << 20;
5025 break;
5026 }
5027 case RISCV::FCVT_BF16_S:
5028 case RISCV::FCVT_D_H:
5029 case RISCV::FCVT_D_H_IN32X:
5030 case RISCV::FCVT_D_H_INX:
5031 case RISCV::FCVT_D_L:
5032 case RISCV::FCVT_D_LU:
5033 case RISCV::FCVT_D_LU_INX:
5034 case RISCV::FCVT_D_L_INX:
5035 case RISCV::FCVT_D_Q:
5036 case RISCV::FCVT_D_S:
5037 case RISCV::FCVT_D_S_IN32X:
5038 case RISCV::FCVT_D_S_INX:
5039 case RISCV::FCVT_D_W:
5040 case RISCV::FCVT_D_WU:
5041 case RISCV::FCVT_D_WU_IN32X:
5042 case RISCV::FCVT_D_WU_INX:
5043 case RISCV::FCVT_D_W_IN32X:
5044 case RISCV::FCVT_D_W_INX:
5045 case RISCV::FCVT_H_D:
5046 case RISCV::FCVT_H_D_IN32X:
5047 case RISCV::FCVT_H_D_INX:
5048 case RISCV::FCVT_H_L:
5049 case RISCV::FCVT_H_LU:
5050 case RISCV::FCVT_H_LU_INX:
5051 case RISCV::FCVT_H_L_INX:
5052 case RISCV::FCVT_H_S:
5053 case RISCV::FCVT_H_S_INX:
5054 case RISCV::FCVT_H_W:
5055 case RISCV::FCVT_H_WU:
5056 case RISCV::FCVT_H_WU_INX:
5057 case RISCV::FCVT_H_W_INX:
5058 case RISCV::FCVT_LU_D:
5059 case RISCV::FCVT_LU_D_INX:
5060 case RISCV::FCVT_LU_H:
5061 case RISCV::FCVT_LU_H_INX:
5062 case RISCV::FCVT_LU_Q:
5063 case RISCV::FCVT_LU_S:
5064 case RISCV::FCVT_LU_S_INX:
5065 case RISCV::FCVT_L_D:
5066 case RISCV::FCVT_L_D_INX:
5067 case RISCV::FCVT_L_H:
5068 case RISCV::FCVT_L_H_INX:
5069 case RISCV::FCVT_L_Q:
5070 case RISCV::FCVT_L_S:
5071 case RISCV::FCVT_L_S_INX:
5072 case RISCV::FCVT_Q_D:
5073 case RISCV::FCVT_Q_L:
5074 case RISCV::FCVT_Q_LU:
5075 case RISCV::FCVT_Q_S:
5076 case RISCV::FCVT_Q_W:
5077 case RISCV::FCVT_Q_WU:
5078 case RISCV::FCVT_S_BF16:
5079 case RISCV::FCVT_S_D:
5080 case RISCV::FCVT_S_D_IN32X:
5081 case RISCV::FCVT_S_D_INX:
5082 case RISCV::FCVT_S_H:
5083 case RISCV::FCVT_S_H_INX:
5084 case RISCV::FCVT_S_L:
5085 case RISCV::FCVT_S_LU:
5086 case RISCV::FCVT_S_LU_INX:
5087 case RISCV::FCVT_S_L_INX:
5088 case RISCV::FCVT_S_Q:
5089 case RISCV::FCVT_S_W:
5090 case RISCV::FCVT_S_WU:
5091 case RISCV::FCVT_S_WU_INX:
5092 case RISCV::FCVT_S_W_INX:
5093 case RISCV::FCVT_WU_D:
5094 case RISCV::FCVT_WU_D_IN32X:
5095 case RISCV::FCVT_WU_D_INX:
5096 case RISCV::FCVT_WU_H:
5097 case RISCV::FCVT_WU_H_INX:
5098 case RISCV::FCVT_WU_Q:
5099 case RISCV::FCVT_WU_S:
5100 case RISCV::FCVT_WU_S_INX:
5101 case RISCV::FCVT_W_D:
5102 case RISCV::FCVT_W_D_IN32X:
5103 case RISCV::FCVT_W_D_INX:
5104 case RISCV::FCVT_W_H:
5105 case RISCV::FCVT_W_H_INX:
5106 case RISCV::FCVT_W_Q:
5107 case RISCV::FCVT_W_S:
5108 case RISCV::FCVT_W_S_INX:
5109 case RISCV::FROUNDNX_D:
5110 case RISCV::FROUNDNX_H:
5111 case RISCV::FROUNDNX_Q:
5112 case RISCV::FROUNDNX_S:
5113 case RISCV::FROUND_D:
5114 case RISCV::FROUND_H:
5115 case RISCV::FROUND_Q:
5116 case RISCV::FROUND_S:
5117 case RISCV::FSQRT_D:
5118 case RISCV::FSQRT_D_IN32X:
5119 case RISCV::FSQRT_D_INX:
5120 case RISCV::FSQRT_H:
5121 case RISCV::FSQRT_H_INX:
5122 case RISCV::FSQRT_Q:
5123 case RISCV::FSQRT_S:
5124 case RISCV::FSQRT_S_INX: {
5125 // op: rs1
5126 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5127 Value |= (op & 0x1f) << 15;
5128 // op: frm
5129 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5130 Value |= (op & 0x7) << 12;
5131 // op: rd
5132 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5133 Value |= (op & 0x1f) << 7;
5134 break;
5135 }
5136 case RISCV::PWSLAI_H:
5137 case RISCV::PWSLLI_H: {
5138 // op: rs1
5139 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5140 Value |= (op & 0x1f) << 15;
5141 // op: rd
5142 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5143 Value |= (op & 0x1e) << 7;
5144 // op: shamt
5145 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5146 Value |= (op & 0x1f) << 20;
5147 break;
5148 }
5149 case RISCV::WSLAI:
5150 case RISCV::WSLLI: {
5151 // op: rs1
5152 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5153 Value |= (op & 0x1f) << 15;
5154 // op: rd
5155 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5156 Value |= (op & 0x1e) << 7;
5157 // op: shamt
5158 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5159 Value |= (op & 0x3f) << 20;
5160 break;
5161 }
5162 case RISCV::PWSLAI_B:
5163 case RISCV::PWSLLI_B: {
5164 // op: rs1
5165 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5166 Value |= (op & 0x1f) << 15;
5167 // op: rd
5168 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5169 Value |= (op & 0x1e) << 7;
5170 // op: shamt
5171 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5172 Value |= (op & 0xf) << 20;
5173 break;
5174 }
5175 case RISCV::ABS:
5176 case RISCV::ABSW:
5177 case RISCV::AES64IM:
5178 case RISCV::AIF_FBCX_PS:
5179 case RISCV::AIF_FCLASS_PS:
5180 case RISCV::AIF_FCVT_F10_PS:
5181 case RISCV::AIF_FCVT_F11_PS:
5182 case RISCV::AIF_FCVT_F16_PS:
5183 case RISCV::AIF_FCVT_PS_F10:
5184 case RISCV::AIF_FCVT_PS_F11:
5185 case RISCV::AIF_FCVT_PS_F16:
5186 case RISCV::AIF_FCVT_PS_RAST:
5187 case RISCV::AIF_FCVT_PS_SN16:
5188 case RISCV::AIF_FCVT_PS_SN8:
5189 case RISCV::AIF_FCVT_PS_UN10:
5190 case RISCV::AIF_FCVT_PS_UN16:
5191 case RISCV::AIF_FCVT_PS_UN2:
5192 case RISCV::AIF_FCVT_PS_UN24:
5193 case RISCV::AIF_FCVT_PS_UN8:
5194 case RISCV::AIF_FCVT_RAST_PS:
5195 case RISCV::AIF_FCVT_SN16_PS:
5196 case RISCV::AIF_FCVT_SN8_PS:
5197 case RISCV::AIF_FCVT_UN10_PS:
5198 case RISCV::AIF_FCVT_UN16_PS:
5199 case RISCV::AIF_FCVT_UN24_PS:
5200 case RISCV::AIF_FCVT_UN2_PS:
5201 case RISCV::AIF_FCVT_UN8_PS:
5202 case RISCV::AIF_FEXP_PS:
5203 case RISCV::AIF_FFRC_PS:
5204 case RISCV::AIF_FLOG_PS:
5205 case RISCV::AIF_FLWG_PS:
5206 case RISCV::AIF_FLWL_PS:
5207 case RISCV::AIF_FNOT_PI:
5208 case RISCV::AIF_FPACKREPB_PI:
5209 case RISCV::AIF_FPACKREPH_PI:
5210 case RISCV::AIF_FRCP_PS:
5211 case RISCV::AIF_FRSQ_PS:
5212 case RISCV::AIF_FSAT8_PI:
5213 case RISCV::AIF_FSATU8_PI:
5214 case RISCV::AIF_FSETM_PI:
5215 case RISCV::AIF_FSIN_PS:
5216 case RISCV::AIF_FSQRT_PS:
5217 case RISCV::BREV8:
5218 case RISCV::CLS:
5219 case RISCV::CLSW:
5220 case RISCV::CLZ:
5221 case RISCV::CLZW:
5222 case RISCV::CPOP:
5223 case RISCV::CPOPW:
5224 case RISCV::CTZ:
5225 case RISCV::CTZW:
5226 case RISCV::CV_ABS:
5227 case RISCV::CV_ABS_B:
5228 case RISCV::CV_ABS_H:
5229 case RISCV::CV_CLB:
5230 case RISCV::CV_CNT:
5231 case RISCV::CV_CPLXCONJ:
5232 case RISCV::CV_EXTBS:
5233 case RISCV::CV_EXTBZ:
5234 case RISCV::CV_EXTHS:
5235 case RISCV::CV_EXTHZ:
5236 case RISCV::CV_FF1:
5237 case RISCV::CV_FL1:
5238 case RISCV::FCLASS_D:
5239 case RISCV::FCLASS_D_IN32X:
5240 case RISCV::FCLASS_D_INX:
5241 case RISCV::FCLASS_H:
5242 case RISCV::FCLASS_H_INX:
5243 case RISCV::FCLASS_Q:
5244 case RISCV::FCLASS_S:
5245 case RISCV::FCLASS_S_INX:
5246 case RISCV::FCVTMOD_W_D:
5247 case RISCV::FMVH_X_D:
5248 case RISCV::FMVH_X_Q:
5249 case RISCV::FMV_D_X:
5250 case RISCV::FMV_H_X:
5251 case RISCV::FMV_W_X:
5252 case RISCV::FMV_X_D:
5253 case RISCV::FMV_X_H:
5254 case RISCV::FMV_X_W:
5255 case RISCV::FMV_X_W_FPR64:
5256 case RISCV::HLVX_HU:
5257 case RISCV::HLVX_WU:
5258 case RISCV::HLV_B:
5259 case RISCV::HLV_BU:
5260 case RISCV::HLV_D:
5261 case RISCV::HLV_H:
5262 case RISCV::HLV_HU:
5263 case RISCV::HLV_W:
5264 case RISCV::HLV_WU:
5265 case RISCV::LB_AQ:
5266 case RISCV::LB_AQRL:
5267 case RISCV::LD_AQ:
5268 case RISCV::LD_AQRL:
5269 case RISCV::LH_AQ:
5270 case RISCV::LH_AQRL:
5271 case RISCV::LR_D:
5272 case RISCV::LR_D_AQ:
5273 case RISCV::LR_D_AQRL:
5274 case RISCV::LR_D_RL:
5275 case RISCV::LR_W:
5276 case RISCV::LR_W_AQ:
5277 case RISCV::LR_W_AQRL:
5278 case RISCV::LR_W_RL:
5279 case RISCV::LW_AQ:
5280 case RISCV::LW_AQRL:
5281 case RISCV::MOP_R_0:
5282 case RISCV::MOP_R_1:
5283 case RISCV::MOP_R_10:
5284 case RISCV::MOP_R_11:
5285 case RISCV::MOP_R_12:
5286 case RISCV::MOP_R_13:
5287 case RISCV::MOP_R_14:
5288 case RISCV::MOP_R_15:
5289 case RISCV::MOP_R_16:
5290 case RISCV::MOP_R_17:
5291 case RISCV::MOP_R_18:
5292 case RISCV::MOP_R_19:
5293 case RISCV::MOP_R_2:
5294 case RISCV::MOP_R_20:
5295 case RISCV::MOP_R_21:
5296 case RISCV::MOP_R_22:
5297 case RISCV::MOP_R_23:
5298 case RISCV::MOP_R_24:
5299 case RISCV::MOP_R_25:
5300 case RISCV::MOP_R_26:
5301 case RISCV::MOP_R_27:
5302 case RISCV::MOP_R_28:
5303 case RISCV::MOP_R_29:
5304 case RISCV::MOP_R_3:
5305 case RISCV::MOP_R_30:
5306 case RISCV::MOP_R_31:
5307 case RISCV::MOP_R_4:
5308 case RISCV::MOP_R_5:
5309 case RISCV::MOP_R_6:
5310 case RISCV::MOP_R_7:
5311 case RISCV::MOP_R_8:
5312 case RISCV::MOP_R_9:
5313 case RISCV::NDS_FMV_BF16_X:
5314 case RISCV::NDS_FMV_X_BF16:
5315 case RISCV::ORC_B:
5316 case RISCV::PSABS_B:
5317 case RISCV::PSABS_H:
5318 case RISCV::PSEXT_H_B:
5319 case RISCV::PSEXT_W_B:
5320 case RISCV::PSEXT_W_H:
5321 case RISCV::QC_BREV32:
5322 case RISCV::QC_CLO:
5323 case RISCV::QC_COMPRESS2:
5324 case RISCV::QC_COMPRESS3:
5325 case RISCV::QC_CTO:
5326 case RISCV::QC_EXPAND2:
5327 case RISCV::QC_EXPAND3:
5328 case RISCV::QC_NORM:
5329 case RISCV::QC_NORMEU:
5330 case RISCV::QC_NORMU:
5331 case RISCV::REV16:
5332 case RISCV::REV8_RV32:
5333 case RISCV::REV8_RV64:
5334 case RISCV::REV_RV32:
5335 case RISCV::REV_RV64:
5336 case RISCV::SEXT_B:
5337 case RISCV::SEXT_H:
5338 case RISCV::SF_VSETTK:
5339 case RISCV::SF_VSETTM:
5340 case RISCV::SF_VSETTN:
5341 case RISCV::SHA256SIG0:
5342 case RISCV::SHA256SIG1:
5343 case RISCV::SHA256SUM0:
5344 case RISCV::SHA256SUM1:
5345 case RISCV::SHA512SIG0:
5346 case RISCV::SHA512SIG1:
5347 case RISCV::SHA512SUM0:
5348 case RISCV::SHA512SUM1:
5349 case RISCV::SM3P0:
5350 case RISCV::SM3P1:
5351 case RISCV::TH_FF0:
5352 case RISCV::TH_FF1:
5353 case RISCV::TH_REV:
5354 case RISCV::TH_REVW:
5355 case RISCV::TH_TSTNBZ:
5356 case RISCV::UNZIP_RV32:
5357 case RISCV::ZEXT_H_RV32:
5358 case RISCV::ZEXT_H_RV64:
5359 case RISCV::ZIP_RV32: {
5360 // op: rs1
5361 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5362 Value |= (op & 0x1f) << 15;
5363 // op: rd
5364 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5365 Value |= (op & 0x1f) << 7;
5366 break;
5367 }
5368 case RISCV::QC_WRAPI: {
5369 // op: rs1
5370 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5371 Value |= (op & 0x1f) << 15;
5372 // op: rd
5373 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5374 Value |= (op & 0x1f) << 7;
5375 // op: imm11
5376 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5377 Value |= (op & 0x7ff) << 20;
5378 break;
5379 }
5380 case RISCV::ADDI:
5381 case RISCV::ADDIW:
5382 case RISCV::ANDI:
5383 case RISCV::CV_ELW:
5384 case RISCV::FLD:
5385 case RISCV::FLH:
5386 case RISCV::FLQ:
5387 case RISCV::FLW:
5388 case RISCV::JALR:
5389 case RISCV::LB:
5390 case RISCV::LBU:
5391 case RISCV::LD:
5392 case RISCV::LD_RV32:
5393 case RISCV::LH:
5394 case RISCV::LHU:
5395 case RISCV::LH_INX:
5396 case RISCV::LW:
5397 case RISCV::LWU:
5398 case RISCV::LW_INX:
5399 case RISCV::ORI:
5400 case RISCV::SLTI:
5401 case RISCV::SLTIU:
5402 case RISCV::XORI: {
5403 // op: rs1
5404 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5405 Value |= (op & 0x1f) << 15;
5406 // op: rd
5407 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5408 Value |= (op & 0x1f) << 7;
5409 // op: imm12
5410 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5411 Value |= (op & 0xfff) << 20;
5412 break;
5413 }
5414 case RISCV::QC_INW: {
5415 // op: rs1
5416 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5417 Value |= (op & 0x1f) << 15;
5418 // op: rd
5419 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5420 Value |= (op & 0x1f) << 7;
5421 // op: imm14
5422 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5423 Value |= (op & 0x3ffc) << 18;
5424 break;
5425 }
5426 case RISCV::CV_CLIP:
5427 case RISCV::CV_CLIPU: {
5428 // op: rs1
5429 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5430 Value |= (op & 0x1f) << 15;
5431 // op: rd
5432 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5433 Value |= (op & 0x1f) << 7;
5434 // op: imm5
5435 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5436 Value |= (op & 0x1f) << 20;
5437 break;
5438 }
5439 case RISCV::CV_ADD_SCI_B:
5440 case RISCV::CV_ADD_SCI_H:
5441 case RISCV::CV_AND_SCI_B:
5442 case RISCV::CV_AND_SCI_H:
5443 case RISCV::CV_AVGU_SCI_B:
5444 case RISCV::CV_AVGU_SCI_H:
5445 case RISCV::CV_AVG_SCI_B:
5446 case RISCV::CV_AVG_SCI_H:
5447 case RISCV::CV_CMPEQ_SCI_B:
5448 case RISCV::CV_CMPEQ_SCI_H:
5449 case RISCV::CV_CMPGEU_SCI_B:
5450 case RISCV::CV_CMPGEU_SCI_H:
5451 case RISCV::CV_CMPGE_SCI_B:
5452 case RISCV::CV_CMPGE_SCI_H:
5453 case RISCV::CV_CMPGTU_SCI_B:
5454 case RISCV::CV_CMPGTU_SCI_H:
5455 case RISCV::CV_CMPGT_SCI_B:
5456 case RISCV::CV_CMPGT_SCI_H:
5457 case RISCV::CV_CMPLEU_SCI_B:
5458 case RISCV::CV_CMPLEU_SCI_H:
5459 case RISCV::CV_CMPLE_SCI_B:
5460 case RISCV::CV_CMPLE_SCI_H:
5461 case RISCV::CV_CMPLTU_SCI_B:
5462 case RISCV::CV_CMPLTU_SCI_H:
5463 case RISCV::CV_CMPLT_SCI_B:
5464 case RISCV::CV_CMPLT_SCI_H:
5465 case RISCV::CV_CMPNE_SCI_B:
5466 case RISCV::CV_CMPNE_SCI_H:
5467 case RISCV::CV_DOTSP_SCI_B:
5468 case RISCV::CV_DOTSP_SCI_H:
5469 case RISCV::CV_DOTUP_SCI_B:
5470 case RISCV::CV_DOTUP_SCI_H:
5471 case RISCV::CV_DOTUSP_SCI_B:
5472 case RISCV::CV_DOTUSP_SCI_H:
5473 case RISCV::CV_EXTRACTU_B:
5474 case RISCV::CV_EXTRACTU_H:
5475 case RISCV::CV_EXTRACT_B:
5476 case RISCV::CV_EXTRACT_H:
5477 case RISCV::CV_MAXU_SCI_B:
5478 case RISCV::CV_MAXU_SCI_H:
5479 case RISCV::CV_MAX_SCI_B:
5480 case RISCV::CV_MAX_SCI_H:
5481 case RISCV::CV_MINU_SCI_B:
5482 case RISCV::CV_MINU_SCI_H:
5483 case RISCV::CV_MIN_SCI_B:
5484 case RISCV::CV_MIN_SCI_H:
5485 case RISCV::CV_OR_SCI_B:
5486 case RISCV::CV_OR_SCI_H:
5487 case RISCV::CV_SHUFFLEI0_SCI_B:
5488 case RISCV::CV_SHUFFLEI1_SCI_B:
5489 case RISCV::CV_SHUFFLEI2_SCI_B:
5490 case RISCV::CV_SHUFFLEI3_SCI_B:
5491 case RISCV::CV_SHUFFLE_SCI_H:
5492 case RISCV::CV_SLL_SCI_B:
5493 case RISCV::CV_SLL_SCI_H:
5494 case RISCV::CV_SRA_SCI_B:
5495 case RISCV::CV_SRA_SCI_H:
5496 case RISCV::CV_SRL_SCI_B:
5497 case RISCV::CV_SRL_SCI_H:
5498 case RISCV::CV_SUB_SCI_B:
5499 case RISCV::CV_SUB_SCI_H:
5500 case RISCV::CV_XOR_SCI_B:
5501 case RISCV::CV_XOR_SCI_H: {
5502 // op: rs1
5503 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5504 Value |= (op & 0x1f) << 15;
5505 // op: rd
5506 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5507 Value |= (op & 0x1f) << 7;
5508 // op: imm6
5509 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5510 Value |= (op & 0x1) << 25;
5511 Value |= (op & 0x3e) << 19;
5512 break;
5513 }
5514 case RISCV::CV_BCLR:
5515 case RISCV::CV_BITREV:
5516 case RISCV::CV_BSET:
5517 case RISCV::CV_EXTRACT:
5518 case RISCV::CV_EXTRACTU: {
5519 // op: rs1
5520 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5521 Value |= (op & 0x1f) << 15;
5522 // op: rd
5523 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5524 Value |= (op & 0x1f) << 7;
5525 // op: is3
5526 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5527 Value |= (op & 0x1f) << 25;
5528 // op: is2
5529 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
5530 Value |= (op & 0x1f) << 20;
5531 break;
5532 }
5533 case RISCV::TH_EXT:
5534 case RISCV::TH_EXTU: {
5535 // op: rs1
5536 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5537 Value |= (op & 0x1f) << 15;
5538 // op: rd
5539 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5540 Value |= (op & 0x1f) << 7;
5541 // op: msb
5542 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5543 Value |= (op & 0x3f) << 26;
5544 // op: lsb
5545 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
5546 Value |= (op & 0x3f) << 20;
5547 break;
5548 }
5549 case RISCV::AES64KS1I: {
5550 // op: rs1
5551 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5552 Value |= (op & 0x1f) << 15;
5553 // op: rd
5554 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5555 Value |= (op & 0x1f) << 7;
5556 // op: rnum
5557 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5558 Value |= (op & 0xf) << 20;
5559 break;
5560 }
5561 case RISCV::PSLLI_W:
5562 case RISCV::PSRAI_W:
5563 case RISCV::PSRARI_W:
5564 case RISCV::PSRLI_W:
5565 case RISCV::PSSLAI_W:
5566 case RISCV::PUSATI_W:
5567 case RISCV::RORIW:
5568 case RISCV::SLLIW:
5569 case RISCV::SRAIW:
5570 case RISCV::SRARI_RV32:
5571 case RISCV::SRLIW:
5572 case RISCV::SSLAI:
5573 case RISCV::TH_SRRIW:
5574 case RISCV::USATI_RV32: {
5575 // op: rs1
5576 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5577 Value |= (op & 0x1f) << 15;
5578 // op: rd
5579 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5580 Value |= (op & 0x1f) << 7;
5581 // op: shamt
5582 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5583 Value |= (op & 0x1f) << 20;
5584 break;
5585 }
5586 case RISCV::SRARI_RV64:
5587 case RISCV::USATI_RV64: {
5588 // op: rs1
5589 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5590 Value |= (op & 0x1f) << 15;
5591 // op: rd
5592 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5593 Value |= (op & 0x1f) << 7;
5594 // op: shamt
5595 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5596 Value |= (op & 0x3f) << 20;
5597 break;
5598 }
5599 case RISCV::PSLLI_B:
5600 case RISCV::PSRAI_B:
5601 case RISCV::PSRLI_B: {
5602 // op: rs1
5603 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5604 Value |= (op & 0x1f) << 15;
5605 // op: rd
5606 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5607 Value |= (op & 0x1f) << 7;
5608 // op: shamt
5609 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5610 Value |= (op & 0x7) << 20;
5611 break;
5612 }
5613 case RISCV::PSLLI_H:
5614 case RISCV::PSRAI_H:
5615 case RISCV::PSRARI_H:
5616 case RISCV::PSRLI_H:
5617 case RISCV::PSSLAI_H:
5618 case RISCV::PUSATI_H: {
5619 // op: rs1
5620 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5621 Value |= (op & 0x1f) << 15;
5622 // op: rd
5623 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5624 Value |= (op & 0x1f) << 7;
5625 // op: shamt
5626 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5627 Value |= (op & 0xf) << 20;
5628 break;
5629 }
5630 case RISCV::QC_EXT:
5631 case RISCV::QC_EXTD:
5632 case RISCV::QC_EXTDU:
5633 case RISCV::QC_EXTU: {
5634 // op: rs1
5635 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5636 Value |= (op & 0x1f) << 15;
5637 // op: rd
5638 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5639 Value |= (op & 0x1f) << 7;
5640 // op: shamt
5641 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
5642 Value |= (op & 0x1f) << 20;
5643 // op: width
5644 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5645 Value |= (op & 0x1f) << 25;
5646 break;
5647 }
5648 case RISCV::PSATI_W:
5649 case RISCV::SATI_RV32: {
5650 // op: rs1
5651 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5652 Value |= (op & 0x1f) << 15;
5653 // op: rd
5654 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5655 Value |= (op & 0x1f) << 7;
5656 // op: shamt
5657 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5658 Value |= (op & 0x1f) << 20;
5659 break;
5660 }
5661 case RISCV::SATI_RV64: {
5662 // op: rs1
5663 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5664 Value |= (op & 0x1f) << 15;
5665 // op: rd
5666 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5667 Value |= (op & 0x1f) << 7;
5668 // op: shamt
5669 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5670 Value |= (op & 0x3f) << 20;
5671 break;
5672 }
5673 case RISCV::PSATI_H: {
5674 // op: rs1
5675 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5676 Value |= (op & 0x1f) << 15;
5677 // op: rd
5678 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5679 Value |= (op & 0x1f) << 7;
5680 // op: shamt
5681 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5682 Value |= (op & 0xf) << 20;
5683 break;
5684 }
5685 case RISCV::BCLRI:
5686 case RISCV::BEXTI:
5687 case RISCV::BINVI:
5688 case RISCV::BSETI:
5689 case RISCV::RORI:
5690 case RISCV::SLLI:
5691 case RISCV::SLLI_UW:
5692 case RISCV::SRAI:
5693 case RISCV::SRLI:
5694 case RISCV::TH_SRRI:
5695 case RISCV::TH_TST: {
5696 // op: rs1
5697 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5698 Value |= (op & 0x1f) << 15;
5699 // op: rd
5700 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5701 Value |= (op & 0x1f) << 7;
5702 // op: shamt
5703 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5704 Value |= (op & 0x3f) << 20;
5705 break;
5706 }
5707 case RISCV::VSETVLI: {
5708 // op: rs1
5709 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5710 Value |= (op & 0x1f) << 15;
5711 // op: rd
5712 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5713 Value |= (op & 0x1f) << 7;
5714 // op: vtypei
5715 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5716 Value |= (op & 0x7ff) << 20;
5717 break;
5718 }
5719 case RISCV::AIF_FROUND_PS: {
5720 // op: rs1
5721 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5722 Value |= (op & 0x1f) << 15;
5723 // op: rm
5724 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5725 Value |= (op & 0x7) << 12;
5726 // op: rd
5727 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5728 Value |= (op & 0x1f) << 7;
5729 break;
5730 }
5731 case RISCV::QC_E_SB:
5732 case RISCV::QC_E_SH:
5733 case RISCV::QC_E_SW: {
5734 // op: rs1
5735 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5736 Value |= (op & 0x1f) << 15;
5737 // op: rs2
5738 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5739 Value |= (op & 0x1f) << 20;
5740 // op: imm
5741 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5742 Value |= (op & 0x3fffc00) << 22;
5743 Value |= (op & 0x3e0) << 20;
5744 Value |= (op & 0x1f) << 7;
5745 break;
5746 }
5747 case RISCV::CV_SB_rr:
5748 case RISCV::CV_SH_rr:
5749 case RISCV::CV_SW_rr: {
5750 // op: rs1
5751 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5752 Value |= (op & 0x1f) << 15;
5753 // op: rs2
5754 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5755 Value |= (op & 0x1f) << 20;
5756 // op: rs3
5757 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5758 Value |= (op & 0x1f) << 7;
5759 break;
5760 }
5761 case RISCV::QC_OUTW: {
5762 // op: rs1
5763 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5764 Value |= (op & 0x1f) << 15;
5765 // op: rs2
5766 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5767 Value |= (op & 0x1f) << 7;
5768 // op: imm14
5769 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5770 Value |= (op & 0x3ffc) << 18;
5771 break;
5772 }
5773 case RISCV::AIF_FSC32B_PS:
5774 case RISCV::AIF_FSC32H_PS:
5775 case RISCV::AIF_FSC32W_PS:
5776 case RISCV::AIF_FSCBG_PS:
5777 case RISCV::AIF_FSCBL_PS:
5778 case RISCV::AIF_FSCB_PS:
5779 case RISCV::AIF_FSCHG_PS:
5780 case RISCV::AIF_FSCHL_PS:
5781 case RISCV::AIF_FSCH_PS:
5782 case RISCV::AIF_FSCWG_PS:
5783 case RISCV::AIF_FSCWL_PS:
5784 case RISCV::AIF_FSCW_PS: {
5785 // op: rs1
5786 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5787 Value |= (op & 0x1f) << 15;
5788 // op: rs2
5789 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5790 Value |= (op & 0x1f) << 20;
5791 // op: rs3
5792 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5793 Value |= (op & 0x1f) << 7;
5794 break;
5795 }
5796 case RISCV::NDS_VLE4_V:
5797 case RISCV::SF_VTMV_V_T:
5798 case RISCV::VL1RE16_V:
5799 case RISCV::VL1RE32_V:
5800 case RISCV::VL1RE64_V:
5801 case RISCV::VL1RE8_V:
5802 case RISCV::VL2RE16_V:
5803 case RISCV::VL2RE32_V:
5804 case RISCV::VL2RE64_V:
5805 case RISCV::VL2RE8_V:
5806 case RISCV::VL4RE16_V:
5807 case RISCV::VL4RE32_V:
5808 case RISCV::VL4RE64_V:
5809 case RISCV::VL4RE8_V:
5810 case RISCV::VL8RE16_V:
5811 case RISCV::VL8RE32_V:
5812 case RISCV::VL8RE64_V:
5813 case RISCV::VL8RE8_V:
5814 case RISCV::VLM_V: {
5815 // op: rs1
5816 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5817 Value |= (op & 0x1f) << 15;
5818 // op: vd
5819 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5820 Value |= (op & 0x1f) << 7;
5821 break;
5822 }
5823 case RISCV::NDS_VLN8_V:
5824 case RISCV::NDS_VLNU8_V:
5825 case RISCV::VLE16FF_V:
5826 case RISCV::VLE16_V:
5827 case RISCV::VLE32FF_V:
5828 case RISCV::VLE32_V:
5829 case RISCV::VLE64FF_V:
5830 case RISCV::VLE64_V:
5831 case RISCV::VLE8FF_V:
5832 case RISCV::VLE8_V:
5833 case RISCV::VLSEG2E16FF_V:
5834 case RISCV::VLSEG2E16_V:
5835 case RISCV::VLSEG2E32FF_V:
5836 case RISCV::VLSEG2E32_V:
5837 case RISCV::VLSEG2E64FF_V:
5838 case RISCV::VLSEG2E64_V:
5839 case RISCV::VLSEG2E8FF_V:
5840 case RISCV::VLSEG2E8_V:
5841 case RISCV::VLSEG3E16FF_V:
5842 case RISCV::VLSEG3E16_V:
5843 case RISCV::VLSEG3E32FF_V:
5844 case RISCV::VLSEG3E32_V:
5845 case RISCV::VLSEG3E64FF_V:
5846 case RISCV::VLSEG3E64_V:
5847 case RISCV::VLSEG3E8FF_V:
5848 case RISCV::VLSEG3E8_V:
5849 case RISCV::VLSEG4E16FF_V:
5850 case RISCV::VLSEG4E16_V:
5851 case RISCV::VLSEG4E32FF_V:
5852 case RISCV::VLSEG4E32_V:
5853 case RISCV::VLSEG4E64FF_V:
5854 case RISCV::VLSEG4E64_V:
5855 case RISCV::VLSEG4E8FF_V:
5856 case RISCV::VLSEG4E8_V:
5857 case RISCV::VLSEG5E16FF_V:
5858 case RISCV::VLSEG5E16_V:
5859 case RISCV::VLSEG5E32FF_V:
5860 case RISCV::VLSEG5E32_V:
5861 case RISCV::VLSEG5E64FF_V:
5862 case RISCV::VLSEG5E64_V:
5863 case RISCV::VLSEG5E8FF_V:
5864 case RISCV::VLSEG5E8_V:
5865 case RISCV::VLSEG6E16FF_V:
5866 case RISCV::VLSEG6E16_V:
5867 case RISCV::VLSEG6E32FF_V:
5868 case RISCV::VLSEG6E32_V:
5869 case RISCV::VLSEG6E64FF_V:
5870 case RISCV::VLSEG6E64_V:
5871 case RISCV::VLSEG6E8FF_V:
5872 case RISCV::VLSEG6E8_V:
5873 case RISCV::VLSEG7E16FF_V:
5874 case RISCV::VLSEG7E16_V:
5875 case RISCV::VLSEG7E32FF_V:
5876 case RISCV::VLSEG7E32_V:
5877 case RISCV::VLSEG7E64FF_V:
5878 case RISCV::VLSEG7E64_V:
5879 case RISCV::VLSEG7E8FF_V:
5880 case RISCV::VLSEG7E8_V:
5881 case RISCV::VLSEG8E16FF_V:
5882 case RISCV::VLSEG8E16_V:
5883 case RISCV::VLSEG8E32FF_V:
5884 case RISCV::VLSEG8E32_V:
5885 case RISCV::VLSEG8E64FF_V:
5886 case RISCV::VLSEG8E64_V:
5887 case RISCV::VLSEG8E8FF_V:
5888 case RISCV::VLSEG8E8_V: {
5889 // op: rs1
5890 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5891 Value |= (op & 0x1f) << 15;
5892 // op: vd
5893 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5894 Value |= (op & 0x1f) << 7;
5895 // op: vm
5896 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
5897 Value |= (op & 0x1) << 25;
5898 break;
5899 }
5900 case RISCV::VLSE16_V:
5901 case RISCV::VLSE32_V:
5902 case RISCV::VLSE64_V:
5903 case RISCV::VLSE8_V:
5904 case RISCV::VLSSEG2E16_V:
5905 case RISCV::VLSSEG2E32_V:
5906 case RISCV::VLSSEG2E64_V:
5907 case RISCV::VLSSEG2E8_V:
5908 case RISCV::VLSSEG3E16_V:
5909 case RISCV::VLSSEG3E32_V:
5910 case RISCV::VLSSEG3E64_V:
5911 case RISCV::VLSSEG3E8_V:
5912 case RISCV::VLSSEG4E16_V:
5913 case RISCV::VLSSEG4E32_V:
5914 case RISCV::VLSSEG4E64_V:
5915 case RISCV::VLSSEG4E8_V:
5916 case RISCV::VLSSEG5E16_V:
5917 case RISCV::VLSSEG5E32_V:
5918 case RISCV::VLSSEG5E64_V:
5919 case RISCV::VLSSEG5E8_V:
5920 case RISCV::VLSSEG6E16_V:
5921 case RISCV::VLSSEG6E32_V:
5922 case RISCV::VLSSEG6E64_V:
5923 case RISCV::VLSSEG6E8_V:
5924 case RISCV::VLSSEG7E16_V:
5925 case RISCV::VLSSEG7E32_V:
5926 case RISCV::VLSSEG7E64_V:
5927 case RISCV::VLSSEG7E8_V:
5928 case RISCV::VLSSEG8E16_V:
5929 case RISCV::VLSSEG8E32_V:
5930 case RISCV::VLSSEG8E64_V:
5931 case RISCV::VLSSEG8E8_V: {
5932 // op: rs1
5933 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5934 Value |= (op & 0x1f) << 15;
5935 // op: vd
5936 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5937 Value |= (op & 0x1f) << 7;
5938 // op: vm
5939 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
5940 Value |= (op & 0x1) << 25;
5941 // op: rs2
5942 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5943 Value |= (op & 0x1f) << 20;
5944 break;
5945 }
5946 case RISCV::VLOXEI16_V:
5947 case RISCV::VLOXEI32_V:
5948 case RISCV::VLOXEI64_V:
5949 case RISCV::VLOXEI8_V:
5950 case RISCV::VLOXSEG2EI16_V:
5951 case RISCV::VLOXSEG2EI32_V:
5952 case RISCV::VLOXSEG2EI64_V:
5953 case RISCV::VLOXSEG2EI8_V:
5954 case RISCV::VLOXSEG3EI16_V:
5955 case RISCV::VLOXSEG3EI32_V:
5956 case RISCV::VLOXSEG3EI64_V:
5957 case RISCV::VLOXSEG3EI8_V:
5958 case RISCV::VLOXSEG4EI16_V:
5959 case RISCV::VLOXSEG4EI32_V:
5960 case RISCV::VLOXSEG4EI64_V:
5961 case RISCV::VLOXSEG4EI8_V:
5962 case RISCV::VLOXSEG5EI16_V:
5963 case RISCV::VLOXSEG5EI32_V:
5964 case RISCV::VLOXSEG5EI64_V:
5965 case RISCV::VLOXSEG5EI8_V:
5966 case RISCV::VLOXSEG6EI16_V:
5967 case RISCV::VLOXSEG6EI32_V:
5968 case RISCV::VLOXSEG6EI64_V:
5969 case RISCV::VLOXSEG6EI8_V:
5970 case RISCV::VLOXSEG7EI16_V:
5971 case RISCV::VLOXSEG7EI32_V:
5972 case RISCV::VLOXSEG7EI64_V:
5973 case RISCV::VLOXSEG7EI8_V:
5974 case RISCV::VLOXSEG8EI16_V:
5975 case RISCV::VLOXSEG8EI32_V:
5976 case RISCV::VLOXSEG8EI64_V:
5977 case RISCV::VLOXSEG8EI8_V:
5978 case RISCV::VLUXEI16_V:
5979 case RISCV::VLUXEI32_V:
5980 case RISCV::VLUXEI64_V:
5981 case RISCV::VLUXEI8_V:
5982 case RISCV::VLUXSEG2EI16_V:
5983 case RISCV::VLUXSEG2EI32_V:
5984 case RISCV::VLUXSEG2EI64_V:
5985 case RISCV::VLUXSEG2EI8_V:
5986 case RISCV::VLUXSEG3EI16_V:
5987 case RISCV::VLUXSEG3EI32_V:
5988 case RISCV::VLUXSEG3EI64_V:
5989 case RISCV::VLUXSEG3EI8_V:
5990 case RISCV::VLUXSEG4EI16_V:
5991 case RISCV::VLUXSEG4EI32_V:
5992 case RISCV::VLUXSEG4EI64_V:
5993 case RISCV::VLUXSEG4EI8_V:
5994 case RISCV::VLUXSEG5EI16_V:
5995 case RISCV::VLUXSEG5EI32_V:
5996 case RISCV::VLUXSEG5EI64_V:
5997 case RISCV::VLUXSEG5EI8_V:
5998 case RISCV::VLUXSEG6EI16_V:
5999 case RISCV::VLUXSEG6EI32_V:
6000 case RISCV::VLUXSEG6EI64_V:
6001 case RISCV::VLUXSEG6EI8_V:
6002 case RISCV::VLUXSEG7EI16_V:
6003 case RISCV::VLUXSEG7EI32_V:
6004 case RISCV::VLUXSEG7EI64_V:
6005 case RISCV::VLUXSEG7EI8_V:
6006 case RISCV::VLUXSEG8EI16_V:
6007 case RISCV::VLUXSEG8EI32_V:
6008 case RISCV::VLUXSEG8EI64_V:
6009 case RISCV::VLUXSEG8EI8_V: {
6010 // op: rs1
6011 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6012 Value |= (op & 0x1f) << 15;
6013 // op: vd
6014 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6015 Value |= (op & 0x1f) << 7;
6016 // op: vm
6017 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6018 Value |= (op & 0x1) << 25;
6019 // op: vs2
6020 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6021 Value |= (op & 0x1f) << 20;
6022 break;
6023 }
6024 case RISCV::VS1R_V:
6025 case RISCV::VS2R_V:
6026 case RISCV::VS4R_V:
6027 case RISCV::VS8R_V:
6028 case RISCV::VSM_V: {
6029 // op: rs1
6030 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6031 Value |= (op & 0x1f) << 15;
6032 // op: vs3
6033 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6034 Value |= (op & 0x1f) << 7;
6035 break;
6036 }
6037 case RISCV::VSE16_V:
6038 case RISCV::VSE32_V:
6039 case RISCV::VSE64_V:
6040 case RISCV::VSE8_V:
6041 case RISCV::VSSEG2E16_V:
6042 case RISCV::VSSEG2E32_V:
6043 case RISCV::VSSEG2E64_V:
6044 case RISCV::VSSEG2E8_V:
6045 case RISCV::VSSEG3E16_V:
6046 case RISCV::VSSEG3E32_V:
6047 case RISCV::VSSEG3E64_V:
6048 case RISCV::VSSEG3E8_V:
6049 case RISCV::VSSEG4E16_V:
6050 case RISCV::VSSEG4E32_V:
6051 case RISCV::VSSEG4E64_V:
6052 case RISCV::VSSEG4E8_V:
6053 case RISCV::VSSEG5E16_V:
6054 case RISCV::VSSEG5E32_V:
6055 case RISCV::VSSEG5E64_V:
6056 case RISCV::VSSEG5E8_V:
6057 case RISCV::VSSEG6E16_V:
6058 case RISCV::VSSEG6E32_V:
6059 case RISCV::VSSEG6E64_V:
6060 case RISCV::VSSEG6E8_V:
6061 case RISCV::VSSEG7E16_V:
6062 case RISCV::VSSEG7E32_V:
6063 case RISCV::VSSEG7E64_V:
6064 case RISCV::VSSEG7E8_V:
6065 case RISCV::VSSEG8E16_V:
6066 case RISCV::VSSEG8E32_V:
6067 case RISCV::VSSEG8E64_V:
6068 case RISCV::VSSEG8E8_V: {
6069 // op: rs1
6070 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6071 Value |= (op & 0x1f) << 15;
6072 // op: vs3
6073 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6074 Value |= (op & 0x1f) << 7;
6075 // op: vm
6076 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
6077 Value |= (op & 0x1) << 25;
6078 break;
6079 }
6080 case RISCV::VSSE16_V:
6081 case RISCV::VSSE32_V:
6082 case RISCV::VSSE64_V:
6083 case RISCV::VSSE8_V:
6084 case RISCV::VSSSEG2E16_V:
6085 case RISCV::VSSSEG2E32_V:
6086 case RISCV::VSSSEG2E64_V:
6087 case RISCV::VSSSEG2E8_V:
6088 case RISCV::VSSSEG3E16_V:
6089 case RISCV::VSSSEG3E32_V:
6090 case RISCV::VSSSEG3E64_V:
6091 case RISCV::VSSSEG3E8_V:
6092 case RISCV::VSSSEG4E16_V:
6093 case RISCV::VSSSEG4E32_V:
6094 case RISCV::VSSSEG4E64_V:
6095 case RISCV::VSSSEG4E8_V:
6096 case RISCV::VSSSEG5E16_V:
6097 case RISCV::VSSSEG5E32_V:
6098 case RISCV::VSSSEG5E64_V:
6099 case RISCV::VSSSEG5E8_V:
6100 case RISCV::VSSSEG6E16_V:
6101 case RISCV::VSSSEG6E32_V:
6102 case RISCV::VSSSEG6E64_V:
6103 case RISCV::VSSSEG6E8_V:
6104 case RISCV::VSSSEG7E16_V:
6105 case RISCV::VSSSEG7E32_V:
6106 case RISCV::VSSSEG7E64_V:
6107 case RISCV::VSSSEG7E8_V:
6108 case RISCV::VSSSEG8E16_V:
6109 case RISCV::VSSSEG8E32_V:
6110 case RISCV::VSSSEG8E64_V:
6111 case RISCV::VSSSEG8E8_V: {
6112 // op: rs1
6113 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6114 Value |= (op & 0x1f) << 15;
6115 // op: vs3
6116 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6117 Value |= (op & 0x1f) << 7;
6118 // op: vm
6119 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6120 Value |= (op & 0x1) << 25;
6121 // op: rs2
6122 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6123 Value |= (op & 0x1f) << 20;
6124 break;
6125 }
6126 case RISCV::VSOXEI16_V:
6127 case RISCV::VSOXEI32_V:
6128 case RISCV::VSOXEI64_V:
6129 case RISCV::VSOXEI8_V:
6130 case RISCV::VSOXSEG2EI16_V:
6131 case RISCV::VSOXSEG2EI32_V:
6132 case RISCV::VSOXSEG2EI64_V:
6133 case RISCV::VSOXSEG2EI8_V:
6134 case RISCV::VSOXSEG3EI16_V:
6135 case RISCV::VSOXSEG3EI32_V:
6136 case RISCV::VSOXSEG3EI64_V:
6137 case RISCV::VSOXSEG3EI8_V:
6138 case RISCV::VSOXSEG4EI16_V:
6139 case RISCV::VSOXSEG4EI32_V:
6140 case RISCV::VSOXSEG4EI64_V:
6141 case RISCV::VSOXSEG4EI8_V:
6142 case RISCV::VSOXSEG5EI16_V:
6143 case RISCV::VSOXSEG5EI32_V:
6144 case RISCV::VSOXSEG5EI64_V:
6145 case RISCV::VSOXSEG5EI8_V:
6146 case RISCV::VSOXSEG6EI16_V:
6147 case RISCV::VSOXSEG6EI32_V:
6148 case RISCV::VSOXSEG6EI64_V:
6149 case RISCV::VSOXSEG6EI8_V:
6150 case RISCV::VSOXSEG7EI16_V:
6151 case RISCV::VSOXSEG7EI32_V:
6152 case RISCV::VSOXSEG7EI64_V:
6153 case RISCV::VSOXSEG7EI8_V:
6154 case RISCV::VSOXSEG8EI16_V:
6155 case RISCV::VSOXSEG8EI32_V:
6156 case RISCV::VSOXSEG8EI64_V:
6157 case RISCV::VSOXSEG8EI8_V:
6158 case RISCV::VSUXEI16_V:
6159 case RISCV::VSUXEI32_V:
6160 case RISCV::VSUXEI64_V:
6161 case RISCV::VSUXEI8_V:
6162 case RISCV::VSUXSEG2EI16_V:
6163 case RISCV::VSUXSEG2EI32_V:
6164 case RISCV::VSUXSEG2EI64_V:
6165 case RISCV::VSUXSEG2EI8_V:
6166 case RISCV::VSUXSEG3EI16_V:
6167 case RISCV::VSUXSEG3EI32_V:
6168 case RISCV::VSUXSEG3EI64_V:
6169 case RISCV::VSUXSEG3EI8_V:
6170 case RISCV::VSUXSEG4EI16_V:
6171 case RISCV::VSUXSEG4EI32_V:
6172 case RISCV::VSUXSEG4EI64_V:
6173 case RISCV::VSUXSEG4EI8_V:
6174 case RISCV::VSUXSEG5EI16_V:
6175 case RISCV::VSUXSEG5EI32_V:
6176 case RISCV::VSUXSEG5EI64_V:
6177 case RISCV::VSUXSEG5EI8_V:
6178 case RISCV::VSUXSEG6EI16_V:
6179 case RISCV::VSUXSEG6EI32_V:
6180 case RISCV::VSUXSEG6EI64_V:
6181 case RISCV::VSUXSEG6EI8_V:
6182 case RISCV::VSUXSEG7EI16_V:
6183 case RISCV::VSUXSEG7EI32_V:
6184 case RISCV::VSUXSEG7EI64_V:
6185 case RISCV::VSUXSEG7EI8_V:
6186 case RISCV::VSUXSEG8EI16_V:
6187 case RISCV::VSUXSEG8EI32_V:
6188 case RISCV::VSUXSEG8EI64_V:
6189 case RISCV::VSUXSEG8EI8_V: {
6190 // op: rs1
6191 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6192 Value |= (op & 0x1f) << 15;
6193 // op: vs3
6194 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6195 Value |= (op & 0x1f) << 7;
6196 // op: vm
6197 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6198 Value |= (op & 0x1) << 25;
6199 // op: vs2
6200 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6201 Value |= (op & 0x1f) << 20;
6202 break;
6203 }
6204 case RISCV::C_ADD: {
6205 // op: rs1
6206 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6207 Value |= (op & 0x1f) << 7;
6208 // op: rs2
6209 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6210 Value |= (op & 0x1f) << 2;
6211 break;
6212 }
6213 case RISCV::AIF_MASKPOPC:
6214 case RISCV::AIF_MASKPOPCZ: {
6215 // op: rs1
6216 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6217 Value |= (op & 0x7) << 15;
6218 // op: rd
6219 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6220 Value |= (op & 0x1f) << 7;
6221 break;
6222 }
6223 case RISCV::AIF_MASKNOT: {
6224 // op: rs1
6225 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6226 Value |= (op & 0x7) << 15;
6227 // op: rd
6228 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6229 Value |= (op & 0x7) << 7;
6230 break;
6231 }
6232 case RISCV::QC_C_BEXTI:
6233 case RISCV::QC_C_BSETI: {
6234 // op: rs1
6235 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6236 Value |= (op & 0x7) << 7;
6237 // op: shamt
6238 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6239 Value |= (op & 0x1f) << 2;
6240 break;
6241 }
6242 case RISCV::AIF_FBC_PS:
6243 case RISCV::AIF_FLQ2:
6244 case RISCV::AIF_FLW_PS: {
6245 // op: rs1
6246 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6247 Value |= (op & 0x1f) << 15;
6248 // op: rd
6249 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6250 Value |= (op & 0x1f) << 7;
6251 // op: imm12
6252 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6253 Value |= (op & 0xfff) << 20;
6254 break;
6255 }
6256 case RISCV::CV_LBU_ri_inc:
6257 case RISCV::CV_LB_ri_inc:
6258 case RISCV::CV_LHU_ri_inc:
6259 case RISCV::CV_LH_ri_inc:
6260 case RISCV::CV_LW_ri_inc: {
6261 // op: rs1
6262 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6263 Value |= (op & 0x1f) << 15;
6264 // op: rd
6265 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6266 Value |= (op & 0x1f) << 7;
6267 // op: imm12
6268 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6269 Value |= (op & 0xfff) << 20;
6270 break;
6271 }
6272 case RISCV::CSRRC:
6273 case RISCV::CSRRS:
6274 case RISCV::CSRRW: {
6275 // op: rs1
6276 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6277 Value |= (op & 0x1f) << 15;
6278 // op: rd
6279 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6280 Value |= (op & 0x1f) << 7;
6281 // op: imm12
6282 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6283 Value |= (op & 0xfff) << 20;
6284 break;
6285 }
6286 case RISCV::TH_LBIA:
6287 case RISCV::TH_LBIB:
6288 case RISCV::TH_LBUIA:
6289 case RISCV::TH_LBUIB:
6290 case RISCV::TH_LDIA:
6291 case RISCV::TH_LDIB:
6292 case RISCV::TH_LHIA:
6293 case RISCV::TH_LHIB:
6294 case RISCV::TH_LHUIA:
6295 case RISCV::TH_LHUIB:
6296 case RISCV::TH_LWIA:
6297 case RISCV::TH_LWIB:
6298 case RISCV::TH_LWUIA:
6299 case RISCV::TH_LWUIB: {
6300 // op: rs1
6301 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6302 Value |= (op & 0x1f) << 15;
6303 // op: rd
6304 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6305 Value |= (op & 0x1f) << 7;
6306 // op: simm5
6307 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6308 Value |= (op & 0x1f) << 20;
6309 // op: uimm2
6310 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6311 Value |= (op & 0x3) << 25;
6312 break;
6313 }
6314 case RISCV::QC_INSBRI: {
6315 // op: rs1
6316 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6317 Value |= (op & 0x1f) << 15;
6318 // op: rd
6319 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6320 Value |= (op & 0x1f) << 7;
6321 // op: imm11
6322 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6323 Value |= (op & 0x7ff) << 20;
6324 break;
6325 }
6326 case RISCV::QC_MULIADD: {
6327 // op: rs1
6328 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6329 Value |= (op & 0x1f) << 15;
6330 // op: rd
6331 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6332 Value |= (op & 0x1f) << 7;
6333 // op: imm12
6334 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6335 Value |= (op & 0xfff) << 20;
6336 break;
6337 }
6338 case RISCV::CV_INSERT_B:
6339 case RISCV::CV_INSERT_H:
6340 case RISCV::CV_SDOTSP_SCI_B:
6341 case RISCV::CV_SDOTSP_SCI_H:
6342 case RISCV::CV_SDOTUP_SCI_B:
6343 case RISCV::CV_SDOTUP_SCI_H:
6344 case RISCV::CV_SDOTUSP_SCI_B:
6345 case RISCV::CV_SDOTUSP_SCI_H: {
6346 // op: rs1
6347 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6348 Value |= (op & 0x1f) << 15;
6349 // op: rd
6350 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6351 Value |= (op & 0x1f) << 7;
6352 // op: imm6
6353 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6354 Value |= (op & 0x1) << 25;
6355 Value |= (op & 0x3e) << 19;
6356 break;
6357 }
6358 case RISCV::CV_INSERT: {
6359 // op: rs1
6360 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6361 Value |= (op & 0x1f) << 15;
6362 // op: rd
6363 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6364 Value |= (op & 0x1f) << 7;
6365 // op: is3
6366 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6367 Value |= (op & 0x1f) << 25;
6368 // op: is2
6369 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6370 Value |= (op & 0x1f) << 20;
6371 break;
6372 }
6373 case RISCV::QC_INSB:
6374 case RISCV::QC_INSBH: {
6375 // op: rs1
6376 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6377 Value |= (op & 0x1f) << 15;
6378 // op: rd
6379 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6380 Value |= (op & 0x1f) << 7;
6381 // op: shamt
6382 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6383 Value |= (op & 0x1f) << 20;
6384 // op: width
6385 op = getImmOpValueMinus1(MI, OpNo: 3, Fixups, STI);
6386 Value |= (op & 0x1f) << 25;
6387 break;
6388 }
6389 case RISCV::QC_SELECTIIEQ:
6390 case RISCV::QC_SELECTIINE: {
6391 // op: rs1
6392 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6393 Value |= (op & 0x1f) << 15;
6394 // op: rd
6395 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6396 Value |= (op & 0x1f) << 7;
6397 // op: simm1
6398 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6399 Value |= (op & 0x1f) << 20;
6400 // op: simm2
6401 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6402 Value |= (op & 0x1f) << 27;
6403 break;
6404 }
6405 case RISCV::TH_SBIA:
6406 case RISCV::TH_SBIB:
6407 case RISCV::TH_SDIA:
6408 case RISCV::TH_SDIB:
6409 case RISCV::TH_SHIA:
6410 case RISCV::TH_SHIB:
6411 case RISCV::TH_SWIA:
6412 case RISCV::TH_SWIB: {
6413 // op: rs1
6414 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6415 Value |= (op & 0x1f) << 15;
6416 // op: rd
6417 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6418 Value |= (op & 0x1f) << 7;
6419 // op: simm5
6420 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6421 Value |= (op & 0x1f) << 20;
6422 // op: uimm2
6423 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6424 Value |= (op & 0x3) << 25;
6425 break;
6426 }
6427 case RISCV::QC_LIEQI:
6428 case RISCV::QC_LIGEI:
6429 case RISCV::QC_LIGEUI:
6430 case RISCV::QC_LILTI:
6431 case RISCV::QC_LILTUI:
6432 case RISCV::QC_LINEI: {
6433 // op: rs2
6434 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6435 Value |= (op & 0x1f) << 20;
6436 // op: rs1
6437 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6438 Value |= (op & 0x1f) << 15;
6439 // op: rd
6440 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6441 Value |= (op & 0x1f) << 7;
6442 // op: simm
6443 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6444 Value |= (op & 0x1f) << 27;
6445 break;
6446 }
6447 case RISCV::SSPUSH: {
6448 // op: rs2
6449 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6450 Value |= (op & 0x1f) << 20;
6451 break;
6452 }
6453 case RISCV::AIF_SBG:
6454 case RISCV::AIF_SBL:
6455 case RISCV::AIF_SHG:
6456 case RISCV::AIF_SHL:
6457 case RISCV::HSV_B:
6458 case RISCV::HSV_D:
6459 case RISCV::HSV_H:
6460 case RISCV::HSV_W:
6461 case RISCV::SB_AQRL:
6462 case RISCV::SB_RL:
6463 case RISCV::SD_AQRL:
6464 case RISCV::SD_RL:
6465 case RISCV::SF_VLTE16:
6466 case RISCV::SF_VLTE32:
6467 case RISCV::SF_VLTE64:
6468 case RISCV::SF_VLTE8:
6469 case RISCV::SF_VSTE16:
6470 case RISCV::SF_VSTE32:
6471 case RISCV::SF_VSTE64:
6472 case RISCV::SF_VSTE8:
6473 case RISCV::SH_AQRL:
6474 case RISCV::SH_RL:
6475 case RISCV::SW_AQRL:
6476 case RISCV::SW_RL: {
6477 // op: rs2
6478 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6479 Value |= (op & 0x1f) << 20;
6480 // op: rs1
6481 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6482 Value |= (op & 0x1f) << 15;
6483 break;
6484 }
6485 case RISCV::QK_C_SB: {
6486 // op: rs2
6487 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6488 Value |= (op & 0x7) << 2;
6489 // op: rs1
6490 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6491 Value |= (op & 0x7) << 7;
6492 // op: imm
6493 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6494 Value |= (op & 0x1) << 12;
6495 Value |= (op & 0x18) << 7;
6496 Value |= (op & 0x6) << 4;
6497 break;
6498 }
6499 case RISCV::C_SB: {
6500 // op: rs2
6501 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6502 Value |= (op & 0x7) << 2;
6503 // op: rs1
6504 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6505 Value |= (op & 0x7) << 7;
6506 // op: imm
6507 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6508 Value |= (op & 0x1) << 6;
6509 Value |= (op & 0x2) << 4;
6510 break;
6511 }
6512 case RISCV::C_SH:
6513 case RISCV::C_SH_INX: {
6514 // op: rs2
6515 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6516 Value |= (op & 0x7) << 2;
6517 // op: rs1
6518 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6519 Value |= (op & 0x7) << 7;
6520 // op: imm
6521 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6522 Value |= (op & 0x2) << 4;
6523 break;
6524 }
6525 case RISCV::C_FSW:
6526 case RISCV::C_SW:
6527 case RISCV::C_SW_INX: {
6528 // op: rs2
6529 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6530 Value |= (op & 0x7) << 2;
6531 // op: rs1
6532 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6533 Value |= (op & 0x7) << 7;
6534 // op: imm
6535 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6536 Value |= (op & 0x38) << 7;
6537 Value |= (op & 0x4) << 4;
6538 Value |= (op & 0x40) >> 1;
6539 break;
6540 }
6541 case RISCV::QK_C_SH: {
6542 // op: rs2
6543 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6544 Value |= (op & 0x7) << 2;
6545 // op: rs1
6546 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6547 Value |= (op & 0x7) << 7;
6548 // op: imm
6549 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6550 Value |= (op & 0x38) << 7;
6551 Value |= (op & 0x6) << 4;
6552 break;
6553 }
6554 case RISCV::C_FSD:
6555 case RISCV::C_SD:
6556 case RISCV::C_SD_RV32: {
6557 // op: rs2
6558 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6559 Value |= (op & 0x7) << 2;
6560 // op: rs1
6561 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6562 Value |= (op & 0x7) << 7;
6563 // op: imm
6564 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6565 Value |= (op & 0x38) << 7;
6566 Value |= (op & 0xc0) >> 1;
6567 break;
6568 }
6569 case RISCV::NDS_FCVT_BF16_S:
6570 case RISCV::NDS_FCVT_S_BF16: {
6571 // op: rs2
6572 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6573 Value |= (op & 0x1f) << 20;
6574 // op: rd
6575 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6576 Value |= (op & 0x1f) << 7;
6577 break;
6578 }
6579 case RISCV::HFENCE_GVMA:
6580 case RISCV::HFENCE_VVMA:
6581 case RISCV::HINVAL_GVMA:
6582 case RISCV::HINVAL_VVMA:
6583 case RISCV::SFENCE_VMA:
6584 case RISCV::SF_VTMV_T_V:
6585 case RISCV::SINVAL_VMA:
6586 case RISCV::TH_SFENCE_VMAS: {
6587 // op: rs2
6588 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6589 Value |= (op & 0x1f) << 20;
6590 // op: rs1
6591 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6592 Value |= (op & 0x1f) << 15;
6593 break;
6594 }
6595 case RISCV::AIF_AMOADDG_D:
6596 case RISCV::AIF_AMOADDG_W:
6597 case RISCV::AIF_AMOADDL_D:
6598 case RISCV::AIF_AMOADDL_W:
6599 case RISCV::AIF_AMOANDG_D:
6600 case RISCV::AIF_AMOANDG_W:
6601 case RISCV::AIF_AMOANDL_D:
6602 case RISCV::AIF_AMOANDL_W:
6603 case RISCV::AIF_AMOCMPSWAPG_D:
6604 case RISCV::AIF_AMOCMPSWAPG_W:
6605 case RISCV::AIF_AMOCMPSWAPL_D:
6606 case RISCV::AIF_AMOCMPSWAPL_W:
6607 case RISCV::AIF_AMOMAXG_D:
6608 case RISCV::AIF_AMOMAXG_W:
6609 case RISCV::AIF_AMOMAXL_D:
6610 case RISCV::AIF_AMOMAXL_W:
6611 case RISCV::AIF_AMOMAXUG_D:
6612 case RISCV::AIF_AMOMAXUG_W:
6613 case RISCV::AIF_AMOMAXUL_D:
6614 case RISCV::AIF_AMOMAXUL_W:
6615 case RISCV::AIF_AMOMING_D:
6616 case RISCV::AIF_AMOMING_W:
6617 case RISCV::AIF_AMOMINL_D:
6618 case RISCV::AIF_AMOMINL_W:
6619 case RISCV::AIF_AMOMINUG_D:
6620 case RISCV::AIF_AMOMINUG_W:
6621 case RISCV::AIF_AMOMINUL_D:
6622 case RISCV::AIF_AMOMINUL_W:
6623 case RISCV::AIF_AMOORG_D:
6624 case RISCV::AIF_AMOORG_W:
6625 case RISCV::AIF_AMOORL_D:
6626 case RISCV::AIF_AMOORL_W:
6627 case RISCV::AIF_AMOSWAPG_D:
6628 case RISCV::AIF_AMOSWAPG_W:
6629 case RISCV::AIF_AMOSWAPL_D:
6630 case RISCV::AIF_AMOSWAPL_W:
6631 case RISCV::AIF_AMOXORG_D:
6632 case RISCV::AIF_AMOXORG_W:
6633 case RISCV::AIF_AMOXORL_D:
6634 case RISCV::AIF_AMOXORL_W:
6635 case RISCV::AMOADD_B:
6636 case RISCV::AMOADD_B_AQ:
6637 case RISCV::AMOADD_B_AQRL:
6638 case RISCV::AMOADD_B_RL:
6639 case RISCV::AMOADD_D:
6640 case RISCV::AMOADD_D_AQ:
6641 case RISCV::AMOADD_D_AQRL:
6642 case RISCV::AMOADD_D_RL:
6643 case RISCV::AMOADD_H:
6644 case RISCV::AMOADD_H_AQ:
6645 case RISCV::AMOADD_H_AQRL:
6646 case RISCV::AMOADD_H_RL:
6647 case RISCV::AMOADD_W:
6648 case RISCV::AMOADD_W_AQ:
6649 case RISCV::AMOADD_W_AQRL:
6650 case RISCV::AMOADD_W_RL:
6651 case RISCV::AMOAND_B:
6652 case RISCV::AMOAND_B_AQ:
6653 case RISCV::AMOAND_B_AQRL:
6654 case RISCV::AMOAND_B_RL:
6655 case RISCV::AMOAND_D:
6656 case RISCV::AMOAND_D_AQ:
6657 case RISCV::AMOAND_D_AQRL:
6658 case RISCV::AMOAND_D_RL:
6659 case RISCV::AMOAND_H:
6660 case RISCV::AMOAND_H_AQ:
6661 case RISCV::AMOAND_H_AQRL:
6662 case RISCV::AMOAND_H_RL:
6663 case RISCV::AMOAND_W:
6664 case RISCV::AMOAND_W_AQ:
6665 case RISCV::AMOAND_W_AQRL:
6666 case RISCV::AMOAND_W_RL:
6667 case RISCV::AMOMAXU_B:
6668 case RISCV::AMOMAXU_B_AQ:
6669 case RISCV::AMOMAXU_B_AQRL:
6670 case RISCV::AMOMAXU_B_RL:
6671 case RISCV::AMOMAXU_D:
6672 case RISCV::AMOMAXU_D_AQ:
6673 case RISCV::AMOMAXU_D_AQRL:
6674 case RISCV::AMOMAXU_D_RL:
6675 case RISCV::AMOMAXU_H:
6676 case RISCV::AMOMAXU_H_AQ:
6677 case RISCV::AMOMAXU_H_AQRL:
6678 case RISCV::AMOMAXU_H_RL:
6679 case RISCV::AMOMAXU_W:
6680 case RISCV::AMOMAXU_W_AQ:
6681 case RISCV::AMOMAXU_W_AQRL:
6682 case RISCV::AMOMAXU_W_RL:
6683 case RISCV::AMOMAX_B:
6684 case RISCV::AMOMAX_B_AQ:
6685 case RISCV::AMOMAX_B_AQRL:
6686 case RISCV::AMOMAX_B_RL:
6687 case RISCV::AMOMAX_D:
6688 case RISCV::AMOMAX_D_AQ:
6689 case RISCV::AMOMAX_D_AQRL:
6690 case RISCV::AMOMAX_D_RL:
6691 case RISCV::AMOMAX_H:
6692 case RISCV::AMOMAX_H_AQ:
6693 case RISCV::AMOMAX_H_AQRL:
6694 case RISCV::AMOMAX_H_RL:
6695 case RISCV::AMOMAX_W:
6696 case RISCV::AMOMAX_W_AQ:
6697 case RISCV::AMOMAX_W_AQRL:
6698 case RISCV::AMOMAX_W_RL:
6699 case RISCV::AMOMINU_B:
6700 case RISCV::AMOMINU_B_AQ:
6701 case RISCV::AMOMINU_B_AQRL:
6702 case RISCV::AMOMINU_B_RL:
6703 case RISCV::AMOMINU_D:
6704 case RISCV::AMOMINU_D_AQ:
6705 case RISCV::AMOMINU_D_AQRL:
6706 case RISCV::AMOMINU_D_RL:
6707 case RISCV::AMOMINU_H:
6708 case RISCV::AMOMINU_H_AQ:
6709 case RISCV::AMOMINU_H_AQRL:
6710 case RISCV::AMOMINU_H_RL:
6711 case RISCV::AMOMINU_W:
6712 case RISCV::AMOMINU_W_AQ:
6713 case RISCV::AMOMINU_W_AQRL:
6714 case RISCV::AMOMINU_W_RL:
6715 case RISCV::AMOMIN_B:
6716 case RISCV::AMOMIN_B_AQ:
6717 case RISCV::AMOMIN_B_AQRL:
6718 case RISCV::AMOMIN_B_RL:
6719 case RISCV::AMOMIN_D:
6720 case RISCV::AMOMIN_D_AQ:
6721 case RISCV::AMOMIN_D_AQRL:
6722 case RISCV::AMOMIN_D_RL:
6723 case RISCV::AMOMIN_H:
6724 case RISCV::AMOMIN_H_AQ:
6725 case RISCV::AMOMIN_H_AQRL:
6726 case RISCV::AMOMIN_H_RL:
6727 case RISCV::AMOMIN_W:
6728 case RISCV::AMOMIN_W_AQ:
6729 case RISCV::AMOMIN_W_AQRL:
6730 case RISCV::AMOMIN_W_RL:
6731 case RISCV::AMOOR_B:
6732 case RISCV::AMOOR_B_AQ:
6733 case RISCV::AMOOR_B_AQRL:
6734 case RISCV::AMOOR_B_RL:
6735 case RISCV::AMOOR_D:
6736 case RISCV::AMOOR_D_AQ:
6737 case RISCV::AMOOR_D_AQRL:
6738 case RISCV::AMOOR_D_RL:
6739 case RISCV::AMOOR_H:
6740 case RISCV::AMOOR_H_AQ:
6741 case RISCV::AMOOR_H_AQRL:
6742 case RISCV::AMOOR_H_RL:
6743 case RISCV::AMOOR_W:
6744 case RISCV::AMOOR_W_AQ:
6745 case RISCV::AMOOR_W_AQRL:
6746 case RISCV::AMOOR_W_RL:
6747 case RISCV::AMOSWAP_B:
6748 case RISCV::AMOSWAP_B_AQ:
6749 case RISCV::AMOSWAP_B_AQRL:
6750 case RISCV::AMOSWAP_B_RL:
6751 case RISCV::AMOSWAP_D:
6752 case RISCV::AMOSWAP_D_AQ:
6753 case RISCV::AMOSWAP_D_AQRL:
6754 case RISCV::AMOSWAP_D_RL:
6755 case RISCV::AMOSWAP_H:
6756 case RISCV::AMOSWAP_H_AQ:
6757 case RISCV::AMOSWAP_H_AQRL:
6758 case RISCV::AMOSWAP_H_RL:
6759 case RISCV::AMOSWAP_W:
6760 case RISCV::AMOSWAP_W_AQ:
6761 case RISCV::AMOSWAP_W_AQRL:
6762 case RISCV::AMOSWAP_W_RL:
6763 case RISCV::AMOXOR_B:
6764 case RISCV::AMOXOR_B_AQ:
6765 case RISCV::AMOXOR_B_AQRL:
6766 case RISCV::AMOXOR_B_RL:
6767 case RISCV::AMOXOR_D:
6768 case RISCV::AMOXOR_D_AQ:
6769 case RISCV::AMOXOR_D_AQRL:
6770 case RISCV::AMOXOR_D_RL:
6771 case RISCV::AMOXOR_H:
6772 case RISCV::AMOXOR_H_AQ:
6773 case RISCV::AMOXOR_H_AQRL:
6774 case RISCV::AMOXOR_H_RL:
6775 case RISCV::AMOXOR_W:
6776 case RISCV::AMOXOR_W_AQ:
6777 case RISCV::AMOXOR_W_AQRL:
6778 case RISCV::AMOXOR_W_RL:
6779 case RISCV::NDS_LEA_B_ZE:
6780 case RISCV::NDS_LEA_D:
6781 case RISCV::NDS_LEA_D_ZE:
6782 case RISCV::NDS_LEA_H:
6783 case RISCV::NDS_LEA_H_ZE:
6784 case RISCV::NDS_LEA_W:
6785 case RISCV::NDS_LEA_W_ZE:
6786 case RISCV::SC_D:
6787 case RISCV::SC_D_AQ:
6788 case RISCV::SC_D_AQRL:
6789 case RISCV::SC_D_RL:
6790 case RISCV::SC_W:
6791 case RISCV::SC_W_AQ:
6792 case RISCV::SC_W_AQRL:
6793 case RISCV::SC_W_RL:
6794 case RISCV::SSAMOSWAP_D:
6795 case RISCV::SSAMOSWAP_D_AQ:
6796 case RISCV::SSAMOSWAP_D_AQRL:
6797 case RISCV::SSAMOSWAP_D_RL:
6798 case RISCV::SSAMOSWAP_W:
6799 case RISCV::SSAMOSWAP_W_AQ:
6800 case RISCV::SSAMOSWAP_W_AQRL:
6801 case RISCV::SSAMOSWAP_W_RL: {
6802 // op: rs2
6803 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6804 Value |= (op & 0x1f) << 20;
6805 // op: rs1
6806 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6807 Value |= (op & 0x1f) << 15;
6808 // op: rd
6809 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6810 Value |= (op & 0x1f) << 7;
6811 break;
6812 }
6813 case RISCV::TH_LDD:
6814 case RISCV::TH_LWD:
6815 case RISCV::TH_LWUD:
6816 case RISCV::TH_SDD:
6817 case RISCV::TH_SWD: {
6818 // op: rs2
6819 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6820 Value |= (op & 0x1f) << 20;
6821 // op: rs1
6822 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6823 Value |= (op & 0x1f) << 15;
6824 // op: rd
6825 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6826 Value |= (op & 0x1f) << 7;
6827 // op: uimm2
6828 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6829 Value |= (op & 0x3) << 25;
6830 break;
6831 }
6832 case RISCV::CM_MVA01S:
6833 case RISCV::CM_MVSA01:
6834 case RISCV::QC_CM_MVA01S:
6835 case RISCV::QC_CM_MVSA01: {
6836 // op: rs2
6837 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6838 Value |= (op & 0x7) << 2;
6839 // op: rs1
6840 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6841 Value |= (op & 0x7) << 7;
6842 break;
6843 }
6844 case RISCV::QC_CSRRWRI: {
6845 // op: rs2
6846 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6847 Value |= (op & 0x1f) << 20;
6848 // op: rs1
6849 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6850 Value |= (op & 0x1f) << 15;
6851 // op: rd
6852 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6853 Value |= (op & 0x1f) << 7;
6854 break;
6855 }
6856 case RISCV::FADD_D:
6857 case RISCV::FADD_D_IN32X:
6858 case RISCV::FADD_D_INX:
6859 case RISCV::FADD_H:
6860 case RISCV::FADD_H_INX:
6861 case RISCV::FADD_Q:
6862 case RISCV::FADD_S:
6863 case RISCV::FADD_S_INX:
6864 case RISCV::FDIV_D:
6865 case RISCV::FDIV_D_IN32X:
6866 case RISCV::FDIV_D_INX:
6867 case RISCV::FDIV_H:
6868 case RISCV::FDIV_H_INX:
6869 case RISCV::FDIV_Q:
6870 case RISCV::FDIV_S:
6871 case RISCV::FDIV_S_INX:
6872 case RISCV::FMUL_D:
6873 case RISCV::FMUL_D_IN32X:
6874 case RISCV::FMUL_D_INX:
6875 case RISCV::FMUL_H:
6876 case RISCV::FMUL_H_INX:
6877 case RISCV::FMUL_Q:
6878 case RISCV::FMUL_S:
6879 case RISCV::FMUL_S_INX:
6880 case RISCV::FSUB_D:
6881 case RISCV::FSUB_D_IN32X:
6882 case RISCV::FSUB_D_INX:
6883 case RISCV::FSUB_H:
6884 case RISCV::FSUB_H_INX:
6885 case RISCV::FSUB_Q:
6886 case RISCV::FSUB_S:
6887 case RISCV::FSUB_S_INX: {
6888 // op: rs2
6889 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6890 Value |= (op & 0x1f) << 20;
6891 // op: rs1
6892 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6893 Value |= (op & 0x1f) << 15;
6894 // op: frm
6895 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
6896 Value |= (op & 0x7) << 12;
6897 // op: rd
6898 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6899 Value |= (op & 0x1f) << 7;
6900 break;
6901 }
6902 case RISCV::PM2WADDSU_H:
6903 case RISCV::PM2WADDU_H:
6904 case RISCV::PM2WADD_H:
6905 case RISCV::PM2WADD_HX:
6906 case RISCV::PM2WSUB_H:
6907 case RISCV::PM2WSUB_HX:
6908 case RISCV::PWADDU_B:
6909 case RISCV::PWADDU_H:
6910 case RISCV::PWADD_B:
6911 case RISCV::PWADD_H:
6912 case RISCV::PWMULSU_B:
6913 case RISCV::PWMULSU_H:
6914 case RISCV::PWMULU_B:
6915 case RISCV::PWMULU_H:
6916 case RISCV::PWMUL_B:
6917 case RISCV::PWMUL_H:
6918 case RISCV::PWSLA_BS:
6919 case RISCV::PWSLA_HS:
6920 case RISCV::PWSLL_BS:
6921 case RISCV::PWSLL_HS:
6922 case RISCV::PWSUBU_B:
6923 case RISCV::PWSUBU_H:
6924 case RISCV::PWSUB_B:
6925 case RISCV::PWSUB_H:
6926 case RISCV::WADD:
6927 case RISCV::WADDU:
6928 case RISCV::WMUL:
6929 case RISCV::WMULSU:
6930 case RISCV::WMULU:
6931 case RISCV::WSLA:
6932 case RISCV::WSLL:
6933 case RISCV::WSUB:
6934 case RISCV::WSUBU:
6935 case RISCV::WZIP16P:
6936 case RISCV::WZIP8P: {
6937 // op: rs2
6938 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6939 Value |= (op & 0x1f) << 20;
6940 // op: rs1
6941 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6942 Value |= (op & 0x1f) << 15;
6943 // op: rd
6944 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6945 Value |= (op & 0x1e) << 7;
6946 break;
6947 }
6948 case RISCV::AADD:
6949 case RISCV::AADDU:
6950 case RISCV::ADD:
6951 case RISCV::ADDW:
6952 case RISCV::ADD_UW:
6953 case RISCV::AES64DS:
6954 case RISCV::AES64DSM:
6955 case RISCV::AES64ES:
6956 case RISCV::AES64ESM:
6957 case RISCV::AES64KS2:
6958 case RISCV::AIF_BITMIXB:
6959 case RISCV::AIF_CUBEFACEIDX_PS:
6960 case RISCV::AIF_CUBEFACE_PS:
6961 case RISCV::AIF_CUBESGNSC_PS:
6962 case RISCV::AIF_CUBESGNTC_PS:
6963 case RISCV::AIF_FADD_PI:
6964 case RISCV::AIF_FAMOADDG_PI:
6965 case RISCV::AIF_FAMOADDL_PI:
6966 case RISCV::AIF_FAMOANDG_PI:
6967 case RISCV::AIF_FAMOANDL_PI:
6968 case RISCV::AIF_FAMOMAXG_PI:
6969 case RISCV::AIF_FAMOMAXG_PS:
6970 case RISCV::AIF_FAMOMAXL_PI:
6971 case RISCV::AIF_FAMOMAXL_PS:
6972 case RISCV::AIF_FAMOMAXUG_PI:
6973 case RISCV::AIF_FAMOMAXUL_PI:
6974 case RISCV::AIF_FAMOMING_PI:
6975 case RISCV::AIF_FAMOMING_PS:
6976 case RISCV::AIF_FAMOMINL_PI:
6977 case RISCV::AIF_FAMOMINL_PS:
6978 case RISCV::AIF_FAMOMINUG_PI:
6979 case RISCV::AIF_FAMOMINUL_PI:
6980 case RISCV::AIF_FAMOORG_PI:
6981 case RISCV::AIF_FAMOORL_PI:
6982 case RISCV::AIF_FAMOSWAPG_PI:
6983 case RISCV::AIF_FAMOSWAPL_PI:
6984 case RISCV::AIF_FAMOXORG_PI:
6985 case RISCV::AIF_FAMOXORL_PI:
6986 case RISCV::AIF_FAND_PI:
6987 case RISCV::AIF_FCMOVM_PS:
6988 case RISCV::AIF_FDIVU_PI:
6989 case RISCV::AIF_FDIV_PI:
6990 case RISCV::AIF_FEQM_PS:
6991 case RISCV::AIF_FEQ_PI:
6992 case RISCV::AIF_FEQ_PS:
6993 case RISCV::AIF_FG32B_PS:
6994 case RISCV::AIF_FG32H_PS:
6995 case RISCV::AIF_FG32W_PS:
6996 case RISCV::AIF_FGBG_PS:
6997 case RISCV::AIF_FGBL_PS:
6998 case RISCV::AIF_FGB_PS:
6999 case RISCV::AIF_FGHG_PS:
7000 case RISCV::AIF_FGHL_PS:
7001 case RISCV::AIF_FGH_PS:
7002 case RISCV::AIF_FGWG_PS:
7003 case RISCV::AIF_FGWL_PS:
7004 case RISCV::AIF_FGW_PS:
7005 case RISCV::AIF_FLEM_PS:
7006 case RISCV::AIF_FLE_PI:
7007 case RISCV::AIF_FLE_PS:
7008 case RISCV::AIF_FLTM_PI:
7009 case RISCV::AIF_FLTM_PS:
7010 case RISCV::AIF_FLTU_PI:
7011 case RISCV::AIF_FLT_PI:
7012 case RISCV::AIF_FLT_PS:
7013 case RISCV::AIF_FMAXU_PI:
7014 case RISCV::AIF_FMAX_PI:
7015 case RISCV::AIF_FMAX_PS:
7016 case RISCV::AIF_FMINU_PI:
7017 case RISCV::AIF_FMIN_PI:
7018 case RISCV::AIF_FMIN_PS:
7019 case RISCV::AIF_FMULHU_PI:
7020 case RISCV::AIF_FMULH_PI:
7021 case RISCV::AIF_FMUL_PI:
7022 case RISCV::AIF_FOR_PI:
7023 case RISCV::AIF_FRCP_FIX_RAST:
7024 case RISCV::AIF_FREMU_PI:
7025 case RISCV::AIF_FREM_PI:
7026 case RISCV::AIF_FSGNJN_PS:
7027 case RISCV::AIF_FSGNJX_PS:
7028 case RISCV::AIF_FSGNJ_PS:
7029 case RISCV::AIF_FSLL_PI:
7030 case RISCV::AIF_FSRA_PI:
7031 case RISCV::AIF_FSRL_PI:
7032 case RISCV::AIF_FSUB_PI:
7033 case RISCV::AIF_FXOR_PI:
7034 case RISCV::AIF_PACKB:
7035 case RISCV::AND:
7036 case RISCV::ANDN:
7037 case RISCV::ASUB:
7038 case RISCV::ASUBU:
7039 case RISCV::BCLR:
7040 case RISCV::BEXT:
7041 case RISCV::BINV:
7042 case RISCV::BSET:
7043 case RISCV::CLMUL:
7044 case RISCV::CLMULH:
7045 case RISCV::CLMULR:
7046 case RISCV::CV_ADD_B:
7047 case RISCV::CV_ADD_DIV2:
7048 case RISCV::CV_ADD_DIV4:
7049 case RISCV::CV_ADD_DIV8:
7050 case RISCV::CV_ADD_H:
7051 case RISCV::CV_ADD_SC_B:
7052 case RISCV::CV_ADD_SC_H:
7053 case RISCV::CV_AND_B:
7054 case RISCV::CV_AND_H:
7055 case RISCV::CV_AND_SC_B:
7056 case RISCV::CV_AND_SC_H:
7057 case RISCV::CV_AVGU_B:
7058 case RISCV::CV_AVGU_H:
7059 case RISCV::CV_AVGU_SC_B:
7060 case RISCV::CV_AVGU_SC_H:
7061 case RISCV::CV_AVG_B:
7062 case RISCV::CV_AVG_H:
7063 case RISCV::CV_AVG_SC_B:
7064 case RISCV::CV_AVG_SC_H:
7065 case RISCV::CV_BCLRR:
7066 case RISCV::CV_BSETR:
7067 case RISCV::CV_CLIPR:
7068 case RISCV::CV_CLIPUR:
7069 case RISCV::CV_CMPEQ_B:
7070 case RISCV::CV_CMPEQ_H:
7071 case RISCV::CV_CMPEQ_SC_B:
7072 case RISCV::CV_CMPEQ_SC_H:
7073 case RISCV::CV_CMPGEU_B:
7074 case RISCV::CV_CMPGEU_H:
7075 case RISCV::CV_CMPGEU_SC_B:
7076 case RISCV::CV_CMPGEU_SC_H:
7077 case RISCV::CV_CMPGE_B:
7078 case RISCV::CV_CMPGE_H:
7079 case RISCV::CV_CMPGE_SC_B:
7080 case RISCV::CV_CMPGE_SC_H:
7081 case RISCV::CV_CMPGTU_B:
7082 case RISCV::CV_CMPGTU_H:
7083 case RISCV::CV_CMPGTU_SC_B:
7084 case RISCV::CV_CMPGTU_SC_H:
7085 case RISCV::CV_CMPGT_B:
7086 case RISCV::CV_CMPGT_H:
7087 case RISCV::CV_CMPGT_SC_B:
7088 case RISCV::CV_CMPGT_SC_H:
7089 case RISCV::CV_CMPLEU_B:
7090 case RISCV::CV_CMPLEU_H:
7091 case RISCV::CV_CMPLEU_SC_B:
7092 case RISCV::CV_CMPLEU_SC_H:
7093 case RISCV::CV_CMPLE_B:
7094 case RISCV::CV_CMPLE_H:
7095 case RISCV::CV_CMPLE_SC_B:
7096 case RISCV::CV_CMPLE_SC_H:
7097 case RISCV::CV_CMPLTU_B:
7098 case RISCV::CV_CMPLTU_H:
7099 case RISCV::CV_CMPLTU_SC_B:
7100 case RISCV::CV_CMPLTU_SC_H:
7101 case RISCV::CV_CMPLT_B:
7102 case RISCV::CV_CMPLT_H:
7103 case RISCV::CV_CMPLT_SC_B:
7104 case RISCV::CV_CMPLT_SC_H:
7105 case RISCV::CV_CMPNE_B:
7106 case RISCV::CV_CMPNE_H:
7107 case RISCV::CV_CMPNE_SC_B:
7108 case RISCV::CV_CMPNE_SC_H:
7109 case RISCV::CV_DOTSP_B:
7110 case RISCV::CV_DOTSP_H:
7111 case RISCV::CV_DOTSP_SC_B:
7112 case RISCV::CV_DOTSP_SC_H:
7113 case RISCV::CV_DOTUP_B:
7114 case RISCV::CV_DOTUP_H:
7115 case RISCV::CV_DOTUP_SC_B:
7116 case RISCV::CV_DOTUP_SC_H:
7117 case RISCV::CV_DOTUSP_B:
7118 case RISCV::CV_DOTUSP_H:
7119 case RISCV::CV_DOTUSP_SC_B:
7120 case RISCV::CV_DOTUSP_SC_H:
7121 case RISCV::CV_EXTRACTR:
7122 case RISCV::CV_EXTRACTUR:
7123 case RISCV::CV_LBU_rr:
7124 case RISCV::CV_LB_rr:
7125 case RISCV::CV_LHU_rr:
7126 case RISCV::CV_LH_rr:
7127 case RISCV::CV_LW_rr:
7128 case RISCV::CV_MAX:
7129 case RISCV::CV_MAXU:
7130 case RISCV::CV_MAXU_B:
7131 case RISCV::CV_MAXU_H:
7132 case RISCV::CV_MAXU_SC_B:
7133 case RISCV::CV_MAXU_SC_H:
7134 case RISCV::CV_MAX_B:
7135 case RISCV::CV_MAX_H:
7136 case RISCV::CV_MAX_SC_B:
7137 case RISCV::CV_MAX_SC_H:
7138 case RISCV::CV_MIN:
7139 case RISCV::CV_MINU:
7140 case RISCV::CV_MINU_B:
7141 case RISCV::CV_MINU_H:
7142 case RISCV::CV_MINU_SC_B:
7143 case RISCV::CV_MINU_SC_H:
7144 case RISCV::CV_MIN_B:
7145 case RISCV::CV_MIN_H:
7146 case RISCV::CV_MIN_SC_B:
7147 case RISCV::CV_MIN_SC_H:
7148 case RISCV::CV_OR_B:
7149 case RISCV::CV_OR_H:
7150 case RISCV::CV_OR_SC_B:
7151 case RISCV::CV_OR_SC_H:
7152 case RISCV::CV_PACK:
7153 case RISCV::CV_PACK_H:
7154 case RISCV::CV_ROR:
7155 case RISCV::CV_SHUFFLE_B:
7156 case RISCV::CV_SHUFFLE_H:
7157 case RISCV::CV_SLE:
7158 case RISCV::CV_SLEU:
7159 case RISCV::CV_SLL_B:
7160 case RISCV::CV_SLL_H:
7161 case RISCV::CV_SLL_SC_B:
7162 case RISCV::CV_SLL_SC_H:
7163 case RISCV::CV_SRA_B:
7164 case RISCV::CV_SRA_H:
7165 case RISCV::CV_SRA_SC_B:
7166 case RISCV::CV_SRA_SC_H:
7167 case RISCV::CV_SRL_B:
7168 case RISCV::CV_SRL_H:
7169 case RISCV::CV_SRL_SC_B:
7170 case RISCV::CV_SRL_SC_H:
7171 case RISCV::CV_SUBROTMJ:
7172 case RISCV::CV_SUBROTMJ_DIV2:
7173 case RISCV::CV_SUBROTMJ_DIV4:
7174 case RISCV::CV_SUBROTMJ_DIV8:
7175 case RISCV::CV_SUB_B:
7176 case RISCV::CV_SUB_DIV2:
7177 case RISCV::CV_SUB_DIV4:
7178 case RISCV::CV_SUB_DIV8:
7179 case RISCV::CV_SUB_H:
7180 case RISCV::CV_SUB_SC_B:
7181 case RISCV::CV_SUB_SC_H:
7182 case RISCV::CV_XOR_B:
7183 case RISCV::CV_XOR_H:
7184 case RISCV::CV_XOR_SC_B:
7185 case RISCV::CV_XOR_SC_H:
7186 case RISCV::CZERO_EQZ:
7187 case RISCV::CZERO_NEZ:
7188 case RISCV::DIV:
7189 case RISCV::DIVU:
7190 case RISCV::DIVUW:
7191 case RISCV::DIVW:
7192 case RISCV::FEQ_D:
7193 case RISCV::FEQ_D_IN32X:
7194 case RISCV::FEQ_D_INX:
7195 case RISCV::FEQ_H:
7196 case RISCV::FEQ_H_INX:
7197 case RISCV::FEQ_Q:
7198 case RISCV::FEQ_S:
7199 case RISCV::FEQ_S_INX:
7200 case RISCV::FLEQ_D:
7201 case RISCV::FLEQ_H:
7202 case RISCV::FLEQ_Q:
7203 case RISCV::FLEQ_S:
7204 case RISCV::FLE_D:
7205 case RISCV::FLE_D_IN32X:
7206 case RISCV::FLE_D_INX:
7207 case RISCV::FLE_H:
7208 case RISCV::FLE_H_INX:
7209 case RISCV::FLE_Q:
7210 case RISCV::FLE_S:
7211 case RISCV::FLE_S_INX:
7212 case RISCV::FLTQ_D:
7213 case RISCV::FLTQ_H:
7214 case RISCV::FLTQ_Q:
7215 case RISCV::FLTQ_S:
7216 case RISCV::FLT_D:
7217 case RISCV::FLT_D_IN32X:
7218 case RISCV::FLT_D_INX:
7219 case RISCV::FLT_H:
7220 case RISCV::FLT_H_INX:
7221 case RISCV::FLT_Q:
7222 case RISCV::FLT_S:
7223 case RISCV::FLT_S_INX:
7224 case RISCV::FMAXM_D:
7225 case RISCV::FMAXM_H:
7226 case RISCV::FMAXM_Q:
7227 case RISCV::FMAXM_S:
7228 case RISCV::FMAX_D:
7229 case RISCV::FMAX_D_IN32X:
7230 case RISCV::FMAX_D_INX:
7231 case RISCV::FMAX_H:
7232 case RISCV::FMAX_H_INX:
7233 case RISCV::FMAX_Q:
7234 case RISCV::FMAX_S:
7235 case RISCV::FMAX_S_INX:
7236 case RISCV::FMINM_D:
7237 case RISCV::FMINM_H:
7238 case RISCV::FMINM_Q:
7239 case RISCV::FMINM_S:
7240 case RISCV::FMIN_D:
7241 case RISCV::FMIN_D_IN32X:
7242 case RISCV::FMIN_D_INX:
7243 case RISCV::FMIN_H:
7244 case RISCV::FMIN_H_INX:
7245 case RISCV::FMIN_Q:
7246 case RISCV::FMIN_S:
7247 case RISCV::FMIN_S_INX:
7248 case RISCV::FMVP_D_X:
7249 case RISCV::FMVP_Q_X:
7250 case RISCV::FSGNJN_D:
7251 case RISCV::FSGNJN_D_IN32X:
7252 case RISCV::FSGNJN_D_INX:
7253 case RISCV::FSGNJN_H:
7254 case RISCV::FSGNJN_H_INX:
7255 case RISCV::FSGNJN_Q:
7256 case RISCV::FSGNJN_S:
7257 case RISCV::FSGNJN_S_INX:
7258 case RISCV::FSGNJX_D:
7259 case RISCV::FSGNJX_D_IN32X:
7260 case RISCV::FSGNJX_D_INX:
7261 case RISCV::FSGNJX_H:
7262 case RISCV::FSGNJX_H_INX:
7263 case RISCV::FSGNJX_Q:
7264 case RISCV::FSGNJX_S:
7265 case RISCV::FSGNJX_S_INX:
7266 case RISCV::FSGNJ_D:
7267 case RISCV::FSGNJ_D_IN32X:
7268 case RISCV::FSGNJ_D_INX:
7269 case RISCV::FSGNJ_H:
7270 case RISCV::FSGNJ_H_INX:
7271 case RISCV::FSGNJ_Q:
7272 case RISCV::FSGNJ_S:
7273 case RISCV::FSGNJ_S_INX:
7274 case RISCV::MAX:
7275 case RISCV::MAXU:
7276 case RISCV::MIN:
7277 case RISCV::MINU:
7278 case RISCV::MOP_RR_0:
7279 case RISCV::MOP_RR_1:
7280 case RISCV::MOP_RR_2:
7281 case RISCV::MOP_RR_3:
7282 case RISCV::MOP_RR_4:
7283 case RISCV::MOP_RR_5:
7284 case RISCV::MOP_RR_6:
7285 case RISCV::MOP_RR_7:
7286 case RISCV::MSEQ:
7287 case RISCV::MSLT:
7288 case RISCV::MSLTU:
7289 case RISCV::MUL:
7290 case RISCV::MULH:
7291 case RISCV::MULHR:
7292 case RISCV::MULHRSU:
7293 case RISCV::MULHRU:
7294 case RISCV::MULHSU:
7295 case RISCV::MULHSU_H0:
7296 case RISCV::MULHSU_H1:
7297 case RISCV::MULHU:
7298 case RISCV::MULH_H0:
7299 case RISCV::MULH_H1:
7300 case RISCV::MULQ:
7301 case RISCV::MULQR:
7302 case RISCV::MULSU_H00:
7303 case RISCV::MULSU_H11:
7304 case RISCV::MULSU_W00:
7305 case RISCV::MULSU_W11:
7306 case RISCV::MULU_H00:
7307 case RISCV::MULU_H01:
7308 case RISCV::MULU_H11:
7309 case RISCV::MULU_W00:
7310 case RISCV::MULU_W01:
7311 case RISCV::MULU_W11:
7312 case RISCV::MULW:
7313 case RISCV::MUL_H00:
7314 case RISCV::MUL_H01:
7315 case RISCV::MUL_H11:
7316 case RISCV::MUL_W00:
7317 case RISCV::MUL_W01:
7318 case RISCV::MUL_W11:
7319 case RISCV::NDS_FFB:
7320 case RISCV::NDS_FFMISM:
7321 case RISCV::NDS_FFZMISM:
7322 case RISCV::NDS_FLMISM:
7323 case RISCV::OR:
7324 case RISCV::ORN:
7325 case RISCV::PAADDU_B:
7326 case RISCV::PAADDU_H:
7327 case RISCV::PAADDU_W:
7328 case RISCV::PAADD_B:
7329 case RISCV::PAADD_H:
7330 case RISCV::PAADD_W:
7331 case RISCV::PAAS_HX:
7332 case RISCV::PAAS_WX:
7333 case RISCV::PABDSUMU_B:
7334 case RISCV::PABDU_B:
7335 case RISCV::PABDU_H:
7336 case RISCV::PABD_B:
7337 case RISCV::PABD_H:
7338 case RISCV::PACK:
7339 case RISCV::PACKH:
7340 case RISCV::PACKW:
7341 case RISCV::PADD_B:
7342 case RISCV::PADD_BS:
7343 case RISCV::PADD_H:
7344 case RISCV::PADD_HS:
7345 case RISCV::PADD_W:
7346 case RISCV::PADD_WS:
7347 case RISCV::PASA_HX:
7348 case RISCV::PASA_WX:
7349 case RISCV::PASUBU_B:
7350 case RISCV::PASUBU_H:
7351 case RISCV::PASUBU_W:
7352 case RISCV::PASUB_B:
7353 case RISCV::PASUB_H:
7354 case RISCV::PASUB_W:
7355 case RISCV::PAS_HX:
7356 case RISCV::PAS_WX:
7357 case RISCV::PM2ADDSU_H:
7358 case RISCV::PM2ADDSU_W:
7359 case RISCV::PM2ADDU_H:
7360 case RISCV::PM2ADDU_W:
7361 case RISCV::PM2ADD_H:
7362 case RISCV::PM2ADD_HX:
7363 case RISCV::PM2ADD_W:
7364 case RISCV::PM2ADD_WX:
7365 case RISCV::PM2SADD_H:
7366 case RISCV::PM2SADD_HX:
7367 case RISCV::PM2SUB_H:
7368 case RISCV::PM2SUB_HX:
7369 case RISCV::PM2SUB_W:
7370 case RISCV::PM2SUB_WX:
7371 case RISCV::PM4ADDSU_B:
7372 case RISCV::PM4ADDSU_H:
7373 case RISCV::PM4ADDU_B:
7374 case RISCV::PM4ADDU_H:
7375 case RISCV::PM4ADD_B:
7376 case RISCV::PM4ADD_H:
7377 case RISCV::PMAXU_B:
7378 case RISCV::PMAXU_H:
7379 case RISCV::PMAXU_W:
7380 case RISCV::PMAX_B:
7381 case RISCV::PMAX_H:
7382 case RISCV::PMAX_W:
7383 case RISCV::PMINU_B:
7384 case RISCV::PMINU_H:
7385 case RISCV::PMINU_W:
7386 case RISCV::PMIN_B:
7387 case RISCV::PMIN_H:
7388 case RISCV::PMIN_W:
7389 case RISCV::PMQ2ADD_H:
7390 case RISCV::PMQ2ADD_W:
7391 case RISCV::PMQR2ADD_H:
7392 case RISCV::PMQR2ADD_W:
7393 case RISCV::PMSEQ_B:
7394 case RISCV::PMSEQ_H:
7395 case RISCV::PMSEQ_W:
7396 case RISCV::PMSLTU_B:
7397 case RISCV::PMSLTU_H:
7398 case RISCV::PMSLTU_W:
7399 case RISCV::PMSLT_B:
7400 case RISCV::PMSLT_H:
7401 case RISCV::PMSLT_W:
7402 case RISCV::PMULHRSU_H:
7403 case RISCV::PMULHRSU_W:
7404 case RISCV::PMULHRU_H:
7405 case RISCV::PMULHRU_W:
7406 case RISCV::PMULHR_H:
7407 case RISCV::PMULHR_W:
7408 case RISCV::PMULHSU_H:
7409 case RISCV::PMULHSU_H_B0:
7410 case RISCV::PMULHSU_H_B1:
7411 case RISCV::PMULHSU_W:
7412 case RISCV::PMULHSU_W_H0:
7413 case RISCV::PMULHSU_W_H1:
7414 case RISCV::PMULHU_H:
7415 case RISCV::PMULHU_W:
7416 case RISCV::PMULH_H:
7417 case RISCV::PMULH_H_B0:
7418 case RISCV::PMULH_H_B1:
7419 case RISCV::PMULH_W:
7420 case RISCV::PMULH_W_H0:
7421 case RISCV::PMULH_W_H1:
7422 case RISCV::PMULQR_H:
7423 case RISCV::PMULQR_W:
7424 case RISCV::PMULQ_H:
7425 case RISCV::PMULQ_W:
7426 case RISCV::PMULSU_H_B00:
7427 case RISCV::PMULSU_H_B11:
7428 case RISCV::PMULSU_W_H00:
7429 case RISCV::PMULSU_W_H11:
7430 case RISCV::PMULU_H_B00:
7431 case RISCV::PMULU_H_B01:
7432 case RISCV::PMULU_H_B11:
7433 case RISCV::PMULU_W_H00:
7434 case RISCV::PMULU_W_H01:
7435 case RISCV::PMULU_W_H11:
7436 case RISCV::PMUL_H_B00:
7437 case RISCV::PMUL_H_B01:
7438 case RISCV::PMUL_H_B11:
7439 case RISCV::PMUL_W_H00:
7440 case RISCV::PMUL_W_H01:
7441 case RISCV::PMUL_W_H11:
7442 case RISCV::PNCLIPP_B:
7443 case RISCV::PNCLIPP_H:
7444 case RISCV::PNCLIPP_W:
7445 case RISCV::PNCLIPUP_B:
7446 case RISCV::PNCLIPUP_H:
7447 case RISCV::PNCLIPUP_W:
7448 case RISCV::PPAIREO_B:
7449 case RISCV::PPAIREO_H:
7450 case RISCV::PPAIREO_W:
7451 case RISCV::PPAIRE_B:
7452 case RISCV::PPAIRE_H:
7453 case RISCV::PPAIROE_B:
7454 case RISCV::PPAIROE_H:
7455 case RISCV::PPAIROE_W:
7456 case RISCV::PPAIRO_B:
7457 case RISCV::PPAIRO_H:
7458 case RISCV::PPAIRO_W:
7459 case RISCV::PREDSUMU_BS:
7460 case RISCV::PREDSUMU_HS:
7461 case RISCV::PREDSUMU_WS:
7462 case RISCV::PREDSUM_BS:
7463 case RISCV::PREDSUM_HS:
7464 case RISCV::PREDSUM_WS:
7465 case RISCV::PSADDU_B:
7466 case RISCV::PSADDU_H:
7467 case RISCV::PSADDU_W:
7468 case RISCV::PSADD_B:
7469 case RISCV::PSADD_H:
7470 case RISCV::PSADD_W:
7471 case RISCV::PSAS_HX:
7472 case RISCV::PSAS_WX:
7473 case RISCV::PSA_HX:
7474 case RISCV::PSA_WX:
7475 case RISCV::PSH1ADD_H:
7476 case RISCV::PSH1ADD_W:
7477 case RISCV::PSLL_BS:
7478 case RISCV::PSLL_HS:
7479 case RISCV::PSLL_WS:
7480 case RISCV::PSRA_BS:
7481 case RISCV::PSRA_HS:
7482 case RISCV::PSRA_WS:
7483 case RISCV::PSRL_BS:
7484 case RISCV::PSRL_HS:
7485 case RISCV::PSRL_WS:
7486 case RISCV::PSSA_HX:
7487 case RISCV::PSSA_WX:
7488 case RISCV::PSSH1SADD_H:
7489 case RISCV::PSSH1SADD_W:
7490 case RISCV::PSSHAR_HS:
7491 case RISCV::PSSHAR_WS:
7492 case RISCV::PSSHA_HS:
7493 case RISCV::PSSHA_WS:
7494 case RISCV::PSSHLR_HS:
7495 case RISCV::PSSHLR_WS:
7496 case RISCV::PSSHL_HS:
7497 case RISCV::PSSHL_WS:
7498 case RISCV::PSSUBU_B:
7499 case RISCV::PSSUBU_H:
7500 case RISCV::PSSUBU_W:
7501 case RISCV::PSSUB_B:
7502 case RISCV::PSSUB_H:
7503 case RISCV::PSSUB_W:
7504 case RISCV::PSUB_B:
7505 case RISCV::PSUB_H:
7506 case RISCV::PSUB_W:
7507 case RISCV::QC_ADDSAT:
7508 case RISCV::QC_ADDUSAT:
7509 case RISCV::QC_CSRRWR:
7510 case RISCV::QC_EXTDPR:
7511 case RISCV::QC_EXTDPRH:
7512 case RISCV::QC_EXTDR:
7513 case RISCV::QC_EXTDUPR:
7514 case RISCV::QC_EXTDUPRH:
7515 case RISCV::QC_EXTDUR:
7516 case RISCV::QC_SHLSAT:
7517 case RISCV::QC_SHLUSAT:
7518 case RISCV::QC_SUBSAT:
7519 case RISCV::QC_SUBUSAT:
7520 case RISCV::QC_WRAP:
7521 case RISCV::REM:
7522 case RISCV::REMU:
7523 case RISCV::REMUW:
7524 case RISCV::REMW:
7525 case RISCV::ROL:
7526 case RISCV::ROLW:
7527 case RISCV::ROR:
7528 case RISCV::RORW:
7529 case RISCV::SADD:
7530 case RISCV::SADDU:
7531 case RISCV::SH1ADD:
7532 case RISCV::SH1ADD_UW:
7533 case RISCV::SH2ADD:
7534 case RISCV::SH2ADD_UW:
7535 case RISCV::SH3ADD:
7536 case RISCV::SH3ADD_UW:
7537 case RISCV::SHA:
7538 case RISCV::SHA512SIG0H:
7539 case RISCV::SHA512SIG0L:
7540 case RISCV::SHA512SIG1H:
7541 case RISCV::SHA512SIG1L:
7542 case RISCV::SHA512SUM0R:
7543 case RISCV::SHA512SUM1R:
7544 case RISCV::SHAR:
7545 case RISCV::SHL:
7546 case RISCV::SHLR:
7547 case RISCV::SLL:
7548 case RISCV::SLLW:
7549 case RISCV::SLT:
7550 case RISCV::SLTU:
7551 case RISCV::SRA:
7552 case RISCV::SRAW:
7553 case RISCV::SRL:
7554 case RISCV::SRLW:
7555 case RISCV::SSH1SADD:
7556 case RISCV::SSHA:
7557 case RISCV::SSHAR:
7558 case RISCV::SSHL:
7559 case RISCV::SSHLR:
7560 case RISCV::SSUB:
7561 case RISCV::SSUBU:
7562 case RISCV::SUB:
7563 case RISCV::SUBW:
7564 case RISCV::UNZIP16HP:
7565 case RISCV::UNZIP16P:
7566 case RISCV::UNZIP8HP:
7567 case RISCV::UNZIP8P:
7568 case RISCV::VSETVL:
7569 case RISCV::VT_MASKC:
7570 case RISCV::VT_MASKCN:
7571 case RISCV::XNOR:
7572 case RISCV::XOR:
7573 case RISCV::XPERM4:
7574 case RISCV::XPERM8:
7575 case RISCV::ZIP16HP:
7576 case RISCV::ZIP16P:
7577 case RISCV::ZIP8HP:
7578 case RISCV::ZIP8P: {
7579 // op: rs2
7580 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7581 Value |= (op & 0x1f) << 20;
7582 // op: rs1
7583 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7584 Value |= (op & 0x1f) << 15;
7585 // op: rd
7586 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7587 Value |= (op & 0x1f) << 7;
7588 break;
7589 }
7590 case RISCV::AES32DSI:
7591 case RISCV::AES32DSMI:
7592 case RISCV::AES32ESI:
7593 case RISCV::AES32ESMI:
7594 case RISCV::SM4ED:
7595 case RISCV::SM4KS: {
7596 // op: rs2
7597 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7598 Value |= (op & 0x1f) << 20;
7599 // op: rs1
7600 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7601 Value |= (op & 0x1f) << 15;
7602 // op: rd
7603 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7604 Value |= (op & 0x1f) << 7;
7605 // op: bs
7606 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7607 Value |= (op & 0x3) << 30;
7608 break;
7609 }
7610 case RISCV::QC_LWM:
7611 case RISCV::QC_LWMI:
7612 case RISCV::QC_SETWM:
7613 case RISCV::QC_SETWMI:
7614 case RISCV::QC_SWM:
7615 case RISCV::QC_SWMI: {
7616 // op: rs2
7617 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7618 Value |= (op & 0x1f) << 20;
7619 // op: rs1
7620 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7621 Value |= (op & 0x1f) << 15;
7622 // op: rd
7623 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7624 Value |= (op & 0x1f) << 7;
7625 // op: imm
7626 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7627 Value |= (op & 0x7c) << 23;
7628 break;
7629 }
7630 case RISCV::CV_ADDN:
7631 case RISCV::CV_ADDRN:
7632 case RISCV::CV_ADDUN:
7633 case RISCV::CV_ADDURN:
7634 case RISCV::CV_MULHHSN:
7635 case RISCV::CV_MULHHSRN:
7636 case RISCV::CV_MULHHUN:
7637 case RISCV::CV_MULHHURN:
7638 case RISCV::CV_MULSN:
7639 case RISCV::CV_MULSRN:
7640 case RISCV::CV_MULUN:
7641 case RISCV::CV_MULURN:
7642 case RISCV::CV_SUBN:
7643 case RISCV::CV_SUBRN:
7644 case RISCV::CV_SUBUN:
7645 case RISCV::CV_SUBURN: {
7646 // op: rs2
7647 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7648 Value |= (op & 0x1f) << 20;
7649 // op: rs1
7650 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7651 Value |= (op & 0x1f) << 15;
7652 // op: rd
7653 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7654 Value |= (op & 0x1f) << 7;
7655 // op: imm5
7656 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7657 Value |= (op & 0x1f) << 25;
7658 break;
7659 }
7660 case RISCV::QC_LRB:
7661 case RISCV::QC_LRBU:
7662 case RISCV::QC_LRH:
7663 case RISCV::QC_LRHU:
7664 case RISCV::QC_LRW:
7665 case RISCV::QC_SRB:
7666 case RISCV::QC_SRH:
7667 case RISCV::QC_SRW: {
7668 // op: rs2
7669 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7670 Value |= (op & 0x1f) << 20;
7671 // op: rs1
7672 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7673 Value |= (op & 0x1f) << 15;
7674 // op: rd
7675 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7676 Value |= (op & 0x1f) << 7;
7677 // op: shamt
7678 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7679 Value |= (op & 0x7) << 25;
7680 break;
7681 }
7682 case RISCV::QC_SHLADD: {
7683 // op: rs2
7684 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7685 Value |= (op & 0x1f) << 20;
7686 // op: rs1
7687 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7688 Value |= (op & 0x1f) << 15;
7689 // op: rd
7690 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7691 Value |= (op & 0x1f) << 7;
7692 // op: shamt
7693 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7694 Value |= (op & 0x1f) << 25;
7695 break;
7696 }
7697 case RISCV::TH_ADDSL:
7698 case RISCV::TH_FLRD:
7699 case RISCV::TH_FLRW:
7700 case RISCV::TH_FLURD:
7701 case RISCV::TH_FLURW:
7702 case RISCV::TH_FSRD:
7703 case RISCV::TH_FSRW:
7704 case RISCV::TH_FSURD:
7705 case RISCV::TH_FSURW:
7706 case RISCV::TH_LRB:
7707 case RISCV::TH_LRBU:
7708 case RISCV::TH_LRD:
7709 case RISCV::TH_LRH:
7710 case RISCV::TH_LRHU:
7711 case RISCV::TH_LRW:
7712 case RISCV::TH_LRWU:
7713 case RISCV::TH_LURB:
7714 case RISCV::TH_LURBU:
7715 case RISCV::TH_LURD:
7716 case RISCV::TH_LURH:
7717 case RISCV::TH_LURHU:
7718 case RISCV::TH_LURW:
7719 case RISCV::TH_LURWU:
7720 case RISCV::TH_SRB:
7721 case RISCV::TH_SRD:
7722 case RISCV::TH_SRH:
7723 case RISCV::TH_SRW:
7724 case RISCV::TH_SURB:
7725 case RISCV::TH_SURD:
7726 case RISCV::TH_SURH:
7727 case RISCV::TH_SURW: {
7728 // op: rs2
7729 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7730 Value |= (op & 0x1f) << 20;
7731 // op: rs1
7732 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7733 Value |= (op & 0x1f) << 15;
7734 // op: rd
7735 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7736 Value |= (op & 0x1f) << 7;
7737 // op: uimm2
7738 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7739 Value |= (op & 0x3) << 25;
7740 break;
7741 }
7742 case RISCV::AMOCAS_B:
7743 case RISCV::AMOCAS_B_AQ:
7744 case RISCV::AMOCAS_B_AQRL:
7745 case RISCV::AMOCAS_B_RL:
7746 case RISCV::AMOCAS_D_RV32:
7747 case RISCV::AMOCAS_D_RV32_AQ:
7748 case RISCV::AMOCAS_D_RV32_AQRL:
7749 case RISCV::AMOCAS_D_RV32_RL:
7750 case RISCV::AMOCAS_D_RV64:
7751 case RISCV::AMOCAS_D_RV64_AQ:
7752 case RISCV::AMOCAS_D_RV64_AQRL:
7753 case RISCV::AMOCAS_D_RV64_RL:
7754 case RISCV::AMOCAS_H:
7755 case RISCV::AMOCAS_H_AQ:
7756 case RISCV::AMOCAS_H_AQRL:
7757 case RISCV::AMOCAS_H_RL:
7758 case RISCV::AMOCAS_Q:
7759 case RISCV::AMOCAS_Q_AQ:
7760 case RISCV::AMOCAS_Q_AQRL:
7761 case RISCV::AMOCAS_Q_RL:
7762 case RISCV::AMOCAS_W:
7763 case RISCV::AMOCAS_W_AQ:
7764 case RISCV::AMOCAS_W_AQRL:
7765 case RISCV::AMOCAS_W_RL: {
7766 // op: rs2
7767 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7768 Value |= (op & 0x1f) << 20;
7769 // op: rs1
7770 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7771 Value |= (op & 0x1f) << 15;
7772 // op: rd
7773 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7774 Value |= (op & 0x1f) << 7;
7775 break;
7776 }
7777 case RISCV::AIF_MASKAND:
7778 case RISCV::AIF_MASKOR:
7779 case RISCV::AIF_MASKXOR: {
7780 // op: rs2
7781 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7782 Value |= (op & 0x7) << 20;
7783 // op: rs1
7784 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7785 Value |= (op & 0x7) << 15;
7786 // op: rd
7787 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7788 Value |= (op & 0x7) << 7;
7789 break;
7790 }
7791 case RISCV::C_ADDW:
7792 case RISCV::C_AND:
7793 case RISCV::C_MUL:
7794 case RISCV::C_OR:
7795 case RISCV::C_SUB:
7796 case RISCV::C_SUBW:
7797 case RISCV::C_XOR: {
7798 // op: rs2
7799 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7800 Value |= (op & 0x7) << 2;
7801 // op: rd
7802 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7803 Value |= (op & 0x7) << 7;
7804 break;
7805 }
7806 case RISCV::QC_SELECTIEQI:
7807 case RISCV::QC_SELECTINEI: {
7808 // op: rs2
7809 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7810 Value |= (op & 0x1f) << 20;
7811 // op: rd
7812 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7813 Value |= (op & 0x1f) << 7;
7814 // op: imm
7815 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
7816 Value |= (op & 0x1f) << 15;
7817 // op: simm2
7818 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
7819 Value |= (op & 0x1f) << 27;
7820 break;
7821 }
7822 case RISCV::CV_LBU_rr_inc:
7823 case RISCV::CV_LB_rr_inc:
7824 case RISCV::CV_LHU_rr_inc:
7825 case RISCV::CV_LH_rr_inc:
7826 case RISCV::CV_LW_rr_inc: {
7827 // op: rs2
7828 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7829 Value |= (op & 0x1f) << 20;
7830 // op: rs1
7831 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7832 Value |= (op & 0x1f) << 15;
7833 // op: rd
7834 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7835 Value |= (op & 0x1f) << 7;
7836 break;
7837 }
7838 case RISCV::MQRWACC:
7839 case RISCV::MQWACC:
7840 case RISCV::PM2WADDASU_H:
7841 case RISCV::PM2WADDAU_H:
7842 case RISCV::PM2WADDA_H:
7843 case RISCV::PM2WADDA_HX:
7844 case RISCV::PM2WSUBA_H:
7845 case RISCV::PM2WSUBA_HX:
7846 case RISCV::PMQRWACC_H:
7847 case RISCV::PMQWACC_H:
7848 case RISCV::PWADDAU_B:
7849 case RISCV::PWADDAU_H:
7850 case RISCV::PWADDA_B:
7851 case RISCV::PWADDA_H:
7852 case RISCV::PWMACCSU_H:
7853 case RISCV::PWMACCU_H:
7854 case RISCV::PWMACC_H:
7855 case RISCV::PWSUBAU_B:
7856 case RISCV::PWSUBAU_H:
7857 case RISCV::PWSUBA_B:
7858 case RISCV::PWSUBA_H:
7859 case RISCV::WADDA:
7860 case RISCV::WADDAU:
7861 case RISCV::WMACC:
7862 case RISCV::WMACCSU:
7863 case RISCV::WMACCU:
7864 case RISCV::WSUBA:
7865 case RISCV::WSUBAU: {
7866 // op: rs2
7867 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7868 Value |= (op & 0x1f) << 20;
7869 // op: rs1
7870 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7871 Value |= (op & 0x1f) << 15;
7872 // op: rd
7873 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7874 Value |= (op & 0x1e) << 7;
7875 break;
7876 }
7877 case RISCV::CV_ADDNR:
7878 case RISCV::CV_ADDRNR:
7879 case RISCV::CV_ADDUNR:
7880 case RISCV::CV_ADDURNR:
7881 case RISCV::CV_CPLXMUL_I:
7882 case RISCV::CV_CPLXMUL_I_DIV2:
7883 case RISCV::CV_CPLXMUL_I_DIV4:
7884 case RISCV::CV_CPLXMUL_I_DIV8:
7885 case RISCV::CV_CPLXMUL_R:
7886 case RISCV::CV_CPLXMUL_R_DIV2:
7887 case RISCV::CV_CPLXMUL_R_DIV4:
7888 case RISCV::CV_CPLXMUL_R_DIV8:
7889 case RISCV::CV_INSERTR:
7890 case RISCV::CV_MAC:
7891 case RISCV::CV_MSU:
7892 case RISCV::CV_PACKHI_B:
7893 case RISCV::CV_PACKLO_B:
7894 case RISCV::CV_SDOTSP_B:
7895 case RISCV::CV_SDOTSP_H:
7896 case RISCV::CV_SDOTSP_SC_B:
7897 case RISCV::CV_SDOTSP_SC_H:
7898 case RISCV::CV_SDOTUP_B:
7899 case RISCV::CV_SDOTUP_H:
7900 case RISCV::CV_SDOTUP_SC_B:
7901 case RISCV::CV_SDOTUP_SC_H:
7902 case RISCV::CV_SDOTUSP_B:
7903 case RISCV::CV_SDOTUSP_H:
7904 case RISCV::CV_SDOTUSP_SC_B:
7905 case RISCV::CV_SDOTUSP_SC_H:
7906 case RISCV::CV_SHUFFLE2_B:
7907 case RISCV::CV_SHUFFLE2_H:
7908 case RISCV::CV_SUBNR:
7909 case RISCV::CV_SUBRNR:
7910 case RISCV::CV_SUBUNR:
7911 case RISCV::CV_SUBURNR:
7912 case RISCV::MACCSU_H00:
7913 case RISCV::MACCSU_H11:
7914 case RISCV::MACCSU_W00:
7915 case RISCV::MACCSU_W11:
7916 case RISCV::MACCU_H00:
7917 case RISCV::MACCU_H01:
7918 case RISCV::MACCU_H11:
7919 case RISCV::MACCU_W00:
7920 case RISCV::MACCU_W01:
7921 case RISCV::MACCU_W11:
7922 case RISCV::MACC_H00:
7923 case RISCV::MACC_H01:
7924 case RISCV::MACC_H11:
7925 case RISCV::MACC_W00:
7926 case RISCV::MACC_W01:
7927 case RISCV::MACC_W11:
7928 case RISCV::MERGE:
7929 case RISCV::MHACC:
7930 case RISCV::MHACCSU:
7931 case RISCV::MHACCSU_H0:
7932 case RISCV::MHACCSU_H1:
7933 case RISCV::MHACCU:
7934 case RISCV::MHACC_H0:
7935 case RISCV::MHACC_H1:
7936 case RISCV::MHRACC:
7937 case RISCV::MHRACCSU:
7938 case RISCV::MHRACCU:
7939 case RISCV::MQACC_H00:
7940 case RISCV::MQACC_H01:
7941 case RISCV::MQACC_H11:
7942 case RISCV::MQACC_W00:
7943 case RISCV::MQACC_W01:
7944 case RISCV::MQACC_W11:
7945 case RISCV::MQRACC_H00:
7946 case RISCV::MQRACC_H01:
7947 case RISCV::MQRACC_H11:
7948 case RISCV::MQRACC_W00:
7949 case RISCV::MQRACC_W01:
7950 case RISCV::MQRACC_W11:
7951 case RISCV::MVM:
7952 case RISCV::MVMN:
7953 case RISCV::PABDSUMAU_B:
7954 case RISCV::PM2ADDASU_H:
7955 case RISCV::PM2ADDASU_W:
7956 case RISCV::PM2ADDAU_H:
7957 case RISCV::PM2ADDAU_W:
7958 case RISCV::PM2ADDA_H:
7959 case RISCV::PM2ADDA_HX:
7960 case RISCV::PM2ADDA_W:
7961 case RISCV::PM2ADDA_WX:
7962 case RISCV::PM2SUBA_H:
7963 case RISCV::PM2SUBA_HX:
7964 case RISCV::PM2SUBA_W:
7965 case RISCV::PM2SUBA_WX:
7966 case RISCV::PM4ADDASU_B:
7967 case RISCV::PM4ADDASU_H:
7968 case RISCV::PM4ADDAU_B:
7969 case RISCV::PM4ADDAU_H:
7970 case RISCV::PM4ADDA_B:
7971 case RISCV::PM4ADDA_H:
7972 case RISCV::PMACCSU_W_H00:
7973 case RISCV::PMACCSU_W_H11:
7974 case RISCV::PMACCU_W_H00:
7975 case RISCV::PMACCU_W_H01:
7976 case RISCV::PMACCU_W_H11:
7977 case RISCV::PMACC_W_H00:
7978 case RISCV::PMACC_W_H01:
7979 case RISCV::PMACC_W_H11:
7980 case RISCV::PMHACCSU_H:
7981 case RISCV::PMHACCSU_H_B0:
7982 case RISCV::PMHACCSU_H_B1:
7983 case RISCV::PMHACCSU_W:
7984 case RISCV::PMHACCSU_W_H0:
7985 case RISCV::PMHACCSU_W_H1:
7986 case RISCV::PMHACCU_H:
7987 case RISCV::PMHACCU_W:
7988 case RISCV::PMHACC_H:
7989 case RISCV::PMHACC_H_B0:
7990 case RISCV::PMHACC_H_B1:
7991 case RISCV::PMHACC_W:
7992 case RISCV::PMHACC_W_H0:
7993 case RISCV::PMHACC_W_H1:
7994 case RISCV::PMHRACCSU_H:
7995 case RISCV::PMHRACCSU_W:
7996 case RISCV::PMHRACCU_H:
7997 case RISCV::PMHRACCU_W:
7998 case RISCV::PMHRACC_H:
7999 case RISCV::PMHRACC_W:
8000 case RISCV::PMQ2ADDA_H:
8001 case RISCV::PMQ2ADDA_W:
8002 case RISCV::PMQACC_W_H00:
8003 case RISCV::PMQACC_W_H01:
8004 case RISCV::PMQACC_W_H11:
8005 case RISCV::PMQR2ADDA_H:
8006 case RISCV::PMQR2ADDA_W:
8007 case RISCV::PMQRACC_W_H00:
8008 case RISCV::PMQRACC_W_H01:
8009 case RISCV::PMQRACC_W_H11:
8010 case RISCV::QC_INSBHR:
8011 case RISCV::QC_INSBPR:
8012 case RISCV::QC_INSBPRH:
8013 case RISCV::QC_INSBR:
8014 case RISCV::SLX:
8015 case RISCV::SRX:
8016 case RISCV::TH_MULA:
8017 case RISCV::TH_MULAH:
8018 case RISCV::TH_MULAW:
8019 case RISCV::TH_MULS:
8020 case RISCV::TH_MULSH:
8021 case RISCV::TH_MULSW:
8022 case RISCV::TH_MVEQZ:
8023 case RISCV::TH_MVNEZ: {
8024 // op: rs2
8025 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8026 Value |= (op & 0x1f) << 20;
8027 // op: rs1
8028 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8029 Value |= (op & 0x1f) << 15;
8030 // op: rd
8031 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8032 Value |= (op & 0x1f) << 7;
8033 break;
8034 }
8035 case RISCV::CV_MACHHSN:
8036 case RISCV::CV_MACHHSRN:
8037 case RISCV::CV_MACHHUN:
8038 case RISCV::CV_MACHHURN:
8039 case RISCV::CV_MACSN:
8040 case RISCV::CV_MACSRN:
8041 case RISCV::CV_MACUN:
8042 case RISCV::CV_MACURN: {
8043 // op: rs2
8044 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8045 Value |= (op & 0x1f) << 20;
8046 // op: rs1
8047 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8048 Value |= (op & 0x1f) << 15;
8049 // op: rd
8050 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8051 Value |= (op & 0x1f) << 7;
8052 // op: imm5
8053 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8054 Value |= (op & 0x1f) << 25;
8055 break;
8056 }
8057 case RISCV::QC_LIEQ:
8058 case RISCV::QC_LIGE:
8059 case RISCV::QC_LIGEU:
8060 case RISCV::QC_LILT:
8061 case RISCV::QC_LILTU:
8062 case RISCV::QC_LINE: {
8063 // op: rs2
8064 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8065 Value |= (op & 0x1f) << 20;
8066 // op: rs1
8067 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8068 Value |= (op & 0x1f) << 15;
8069 // op: rd
8070 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8071 Value |= (op & 0x1f) << 7;
8072 // op: simm
8073 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8074 Value |= (op & 0x1f) << 27;
8075 break;
8076 }
8077 case RISCV::QC_SELECTIEQ:
8078 case RISCV::QC_SELECTINE: {
8079 // op: rs2
8080 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8081 Value |= (op & 0x1f) << 20;
8082 // op: rs1
8083 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8084 Value |= (op & 0x1f) << 15;
8085 // op: rd
8086 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8087 Value |= (op & 0x1f) << 7;
8088 // op: simm2
8089 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8090 Value |= (op & 0x1f) << 27;
8091 break;
8092 }
8093 case RISCV::FMADD_D:
8094 case RISCV::FMADD_D_IN32X:
8095 case RISCV::FMADD_D_INX:
8096 case RISCV::FMADD_H:
8097 case RISCV::FMADD_H_INX:
8098 case RISCV::FMADD_Q:
8099 case RISCV::FMADD_S:
8100 case RISCV::FMADD_S_INX:
8101 case RISCV::FMSUB_D:
8102 case RISCV::FMSUB_D_IN32X:
8103 case RISCV::FMSUB_D_INX:
8104 case RISCV::FMSUB_H:
8105 case RISCV::FMSUB_H_INX:
8106 case RISCV::FMSUB_Q:
8107 case RISCV::FMSUB_S:
8108 case RISCV::FMSUB_S_INX:
8109 case RISCV::FNMADD_D:
8110 case RISCV::FNMADD_D_IN32X:
8111 case RISCV::FNMADD_D_INX:
8112 case RISCV::FNMADD_H:
8113 case RISCV::FNMADD_H_INX:
8114 case RISCV::FNMADD_Q:
8115 case RISCV::FNMADD_S:
8116 case RISCV::FNMADD_S_INX:
8117 case RISCV::FNMSUB_D:
8118 case RISCV::FNMSUB_D_IN32X:
8119 case RISCV::FNMSUB_D_INX:
8120 case RISCV::FNMSUB_H:
8121 case RISCV::FNMSUB_H_INX:
8122 case RISCV::FNMSUB_Q:
8123 case RISCV::FNMSUB_S:
8124 case RISCV::FNMSUB_S_INX: {
8125 // op: rs3
8126 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8127 Value |= (op & 0x1f) << 27;
8128 // op: rs2
8129 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8130 Value |= (op & 0x1f) << 20;
8131 // op: rs1
8132 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8133 Value |= (op & 0x1f) << 15;
8134 // op: frm
8135 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8136 Value |= (op & 0x7) << 12;
8137 // op: rd
8138 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8139 Value |= (op & 0x1f) << 7;
8140 break;
8141 }
8142 case RISCV::MIPS_CCMOV: {
8143 // op: rs3
8144 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8145 Value |= (op & 0x1f) << 27;
8146 // op: rs2
8147 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8148 Value |= (op & 0x1f) << 20;
8149 // op: rs1
8150 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8151 Value |= (op & 0x1f) << 15;
8152 // op: rd
8153 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8154 Value |= (op & 0x1f) << 7;
8155 break;
8156 }
8157 case RISCV::CV_SB_rr_inc:
8158 case RISCV::CV_SH_rr_inc:
8159 case RISCV::CV_SW_rr_inc: {
8160 // op: rs3
8161 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8162 Value |= (op & 0x1f) << 7;
8163 // op: rs2
8164 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8165 Value |= (op & 0x1f) << 20;
8166 // op: rs1
8167 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8168 Value |= (op & 0x1f) << 15;
8169 break;
8170 }
8171 case RISCV::QC_MVEQI:
8172 case RISCV::QC_MVGEI:
8173 case RISCV::QC_MVGEUI:
8174 case RISCV::QC_MVLTI:
8175 case RISCV::QC_MVLTUI:
8176 case RISCV::QC_MVNEI: {
8177 // op: rs3
8178 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8179 Value |= (op & 0x1f) << 27;
8180 // op: rs1
8181 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8182 Value |= (op & 0x1f) << 15;
8183 // op: rd
8184 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8185 Value |= (op & 0x1f) << 7;
8186 // op: imm
8187 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
8188 Value |= (op & 0x1f) << 20;
8189 break;
8190 }
8191 case RISCV::QC_SELECTEQI:
8192 case RISCV::QC_SELECTNEI: {
8193 // op: rs3
8194 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8195 Value |= (op & 0x1f) << 27;
8196 // op: rs2
8197 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8198 Value |= (op & 0x1f) << 20;
8199 // op: rd
8200 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8201 Value |= (op & 0x1f) << 7;
8202 // op: imm
8203 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8204 Value |= (op & 0x1f) << 15;
8205 break;
8206 }
8207 case RISCV::QC_MVEQ:
8208 case RISCV::QC_MVGE:
8209 case RISCV::QC_MVGEU:
8210 case RISCV::QC_MVLT:
8211 case RISCV::QC_MVLTU:
8212 case RISCV::QC_MVNE: {
8213 // op: rs3
8214 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8215 Value |= (op & 0x1f) << 27;
8216 // op: rs2
8217 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8218 Value |= (op & 0x1f) << 20;
8219 // op: rs1
8220 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8221 Value |= (op & 0x1f) << 15;
8222 // op: rd
8223 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8224 Value |= (op & 0x1f) << 7;
8225 break;
8226 }
8227 case RISCV::QC_C_SYNC:
8228 case RISCV::QC_C_SYNCR:
8229 case RISCV::QC_C_SYNCWF:
8230 case RISCV::QC_C_SYNCWL: {
8231 // op: slist
8232 op = getImmOpValueSlist(MI, OpNo: 0, Fixups, STI);
8233 Value |= (op & 0x7) << 7;
8234 break;
8235 }
8236 case RISCV::Insn16: {
8237 // op: value
8238 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8239 Value |= (op & 0xffff);
8240 break;
8241 }
8242 case RISCV::Insn32: {
8243 // op: value
8244 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8245 Value |= (op & 0xffffffff);
8246 break;
8247 }
8248 case RISCV::Insn48: {
8249 // op: value
8250 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8251 Value |= (op & 0xffffffffffff);
8252 break;
8253 }
8254 case RISCV::Insn64: {
8255 // op: value
8256 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8257 Value |= (op & 0xffffffffffffffff);
8258 break;
8259 }
8260 case RISCV::VMV_V_I: {
8261 // op: vd
8262 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8263 Value |= (op & 0x1f) << 7;
8264 // op: imm
8265 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
8266 Value |= (op & 0x1f) << 15;
8267 break;
8268 }
8269 case RISCV::VFMV_V_F:
8270 case RISCV::VMV_V_X: {
8271 // op: vd
8272 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8273 Value |= (op & 0x1f) << 7;
8274 // op: rs1
8275 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8276 Value |= (op & 0x1f) << 15;
8277 break;
8278 }
8279 case RISCV::VID_V: {
8280 // op: vd
8281 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8282 Value |= (op & 0x1f) << 7;
8283 // op: vm
8284 op = getVMaskReg(MI, OpNo: 1, Fixups, STI);
8285 Value |= (op & 0x1) << 25;
8286 break;
8287 }
8288 case RISCV::SF_VFEXPA_V:
8289 case RISCV::SF_VFEXP_V:
8290 case RISCV::VABS_V:
8291 case RISCV::VBREV8_V:
8292 case RISCV::VBREV_V:
8293 case RISCV::VCLZ_V:
8294 case RISCV::VCPOP_V:
8295 case RISCV::VCTZ_V:
8296 case RISCV::VFCLASS_V:
8297 case RISCV::VFCVT_F_XU_V:
8298 case RISCV::VFCVT_F_X_V:
8299 case RISCV::VFCVT_RTZ_XU_F_V:
8300 case RISCV::VFCVT_RTZ_X_F_V:
8301 case RISCV::VFCVT_XU_F_V:
8302 case RISCV::VFCVT_X_F_V:
8303 case RISCV::VFNCVTBF16_F_F_W:
8304 case RISCV::VFNCVTBF16_SAT_F_F_W:
8305 case RISCV::VFNCVT_F_F_Q:
8306 case RISCV::VFNCVT_F_F_W:
8307 case RISCV::VFNCVT_F_XU_W:
8308 case RISCV::VFNCVT_F_X_W:
8309 case RISCV::VFNCVT_ROD_F_F_W:
8310 case RISCV::VFNCVT_RTZ_XU_F_W:
8311 case RISCV::VFNCVT_RTZ_X_F_W:
8312 case RISCV::VFNCVT_SAT_F_F_Q:
8313 case RISCV::VFNCVT_XU_F_W:
8314 case RISCV::VFNCVT_X_F_W:
8315 case RISCV::VFREC7_V:
8316 case RISCV::VFRSQRT7_V:
8317 case RISCV::VFSQRT_V:
8318 case RISCV::VFWCVTBF16_F_F_V:
8319 case RISCV::VFWCVT_F_F_V:
8320 case RISCV::VFWCVT_F_XU_V:
8321 case RISCV::VFWCVT_F_X_V:
8322 case RISCV::VFWCVT_RTZ_XU_F_V:
8323 case RISCV::VFWCVT_RTZ_X_F_V:
8324 case RISCV::VFWCVT_XU_F_V:
8325 case RISCV::VFWCVT_X_F_V:
8326 case RISCV::VIOTA_M:
8327 case RISCV::VMSBF_M:
8328 case RISCV::VMSIF_M:
8329 case RISCV::VMSOF_M:
8330 case RISCV::VREV8_V:
8331 case RISCV::VSEXT_VF2:
8332 case RISCV::VSEXT_VF4:
8333 case RISCV::VSEXT_VF8:
8334 case RISCV::VUNZIPE_V:
8335 case RISCV::VUNZIPO_V:
8336 case RISCV::VZEXT_VF2:
8337 case RISCV::VZEXT_VF4:
8338 case RISCV::VZEXT_VF8: {
8339 // op: vd
8340 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8341 Value |= (op & 0x1f) << 7;
8342 // op: vm
8343 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
8344 Value |= (op & 0x1) << 25;
8345 // op: vs2
8346 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8347 Value |= (op & 0x1f) << 20;
8348 break;
8349 }
8350 case RISCV::VADD_VI:
8351 case RISCV::VAND_VI:
8352 case RISCV::VMSEQ_VI:
8353 case RISCV::VMSGTU_VI:
8354 case RISCV::VMSGT_VI:
8355 case RISCV::VMSLEU_VI:
8356 case RISCV::VMSLE_VI:
8357 case RISCV::VMSNE_VI:
8358 case RISCV::VNCLIPU_WI:
8359 case RISCV::VNCLIP_WI:
8360 case RISCV::VNSRA_WI:
8361 case RISCV::VNSRL_WI:
8362 case RISCV::VOR_VI:
8363 case RISCV::VRGATHER_VI:
8364 case RISCV::VRSUB_VI:
8365 case RISCV::VSADDU_VI:
8366 case RISCV::VSADD_VI:
8367 case RISCV::VSLIDEDOWN_VI:
8368 case RISCV::VSLIDEUP_VI:
8369 case RISCV::VSLL_VI:
8370 case RISCV::VSRA_VI:
8371 case RISCV::VSRL_VI:
8372 case RISCV::VSSRA_VI:
8373 case RISCV::VSSRL_VI:
8374 case RISCV::VWSLL_VI:
8375 case RISCV::VXOR_VI: {
8376 // op: vd
8377 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8378 Value |= (op & 0x1f) << 7;
8379 // op: vm
8380 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8381 Value |= (op & 0x1) << 25;
8382 // op: vs2
8383 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8384 Value |= (op & 0x1f) << 20;
8385 // op: imm
8386 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8387 Value |= (op & 0x1f) << 15;
8388 break;
8389 }
8390 case RISCV::VROR_VI: {
8391 // op: vd
8392 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8393 Value |= (op & 0x1f) << 7;
8394 // op: vm
8395 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8396 Value |= (op & 0x1) << 25;
8397 // op: vs2
8398 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8399 Value |= (op & 0x1f) << 20;
8400 // op: imm
8401 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8402 Value |= (op & 0x20) << 21;
8403 Value |= (op & 0x1f) << 15;
8404 break;
8405 }
8406 case RISCV::SF_VFNRCLIP_XU_F_QF:
8407 case RISCV::SF_VFNRCLIP_X_F_QF:
8408 case RISCV::VAADDU_VX:
8409 case RISCV::VAADD_VX:
8410 case RISCV::VADD_VX:
8411 case RISCV::VANDN_VX:
8412 case RISCV::VAND_VX:
8413 case RISCV::VASUBU_VX:
8414 case RISCV::VASUB_VX:
8415 case RISCV::VCLMULH_VX:
8416 case RISCV::VCLMUL_VX:
8417 case RISCV::VDIVU_VX:
8418 case RISCV::VDIV_VX:
8419 case RISCV::VFADD_VF:
8420 case RISCV::VFDIV_VF:
8421 case RISCV::VFMAX_VF:
8422 case RISCV::VFMIN_VF:
8423 case RISCV::VFMUL_VF:
8424 case RISCV::VFRDIV_VF:
8425 case RISCV::VFRSUB_VF:
8426 case RISCV::VFSGNJN_VF:
8427 case RISCV::VFSGNJX_VF:
8428 case RISCV::VFSGNJ_VF:
8429 case RISCV::VFSLIDE1DOWN_VF:
8430 case RISCV::VFSLIDE1UP_VF:
8431 case RISCV::VFSUB_VF:
8432 case RISCV::VFWADD_VF:
8433 case RISCV::VFWADD_WF:
8434 case RISCV::VFWMUL_VF:
8435 case RISCV::VFWSUB_VF:
8436 case RISCV::VFWSUB_WF:
8437 case RISCV::VMAXU_VX:
8438 case RISCV::VMAX_VX:
8439 case RISCV::VMFEQ_VF:
8440 case RISCV::VMFGE_VF:
8441 case RISCV::VMFGT_VF:
8442 case RISCV::VMFLE_VF:
8443 case RISCV::VMFLT_VF:
8444 case RISCV::VMFNE_VF:
8445 case RISCV::VMINU_VX:
8446 case RISCV::VMIN_VX:
8447 case RISCV::VMSEQ_VX:
8448 case RISCV::VMSGTU_VX:
8449 case RISCV::VMSGT_VX:
8450 case RISCV::VMSLEU_VX:
8451 case RISCV::VMSLE_VX:
8452 case RISCV::VMSLTU_VX:
8453 case RISCV::VMSLT_VX:
8454 case RISCV::VMSNE_VX:
8455 case RISCV::VMULHSU_VX:
8456 case RISCV::VMULHU_VX:
8457 case RISCV::VMULH_VX:
8458 case RISCV::VMUL_VX:
8459 case RISCV::VNCLIPU_WX:
8460 case RISCV::VNCLIP_WX:
8461 case RISCV::VNSRA_WX:
8462 case RISCV::VNSRL_WX:
8463 case RISCV::VOR_VX:
8464 case RISCV::VREMU_VX:
8465 case RISCV::VREM_VX:
8466 case RISCV::VRGATHER_VX:
8467 case RISCV::VROL_VX:
8468 case RISCV::VROR_VX:
8469 case RISCV::VRSUB_VX:
8470 case RISCV::VSADDU_VX:
8471 case RISCV::VSADD_VX:
8472 case RISCV::VSLIDE1DOWN_VX:
8473 case RISCV::VSLIDE1UP_VX:
8474 case RISCV::VSLIDEDOWN_VX:
8475 case RISCV::VSLIDEUP_VX:
8476 case RISCV::VSLL_VX:
8477 case RISCV::VSMUL_VX:
8478 case RISCV::VSRA_VX:
8479 case RISCV::VSRL_VX:
8480 case RISCV::VSSRA_VX:
8481 case RISCV::VSSRL_VX:
8482 case RISCV::VSSUBU_VX:
8483 case RISCV::VSSUB_VX:
8484 case RISCV::VSUB_VX:
8485 case RISCV::VWADDU_VX:
8486 case RISCV::VWADDU_WX:
8487 case RISCV::VWADD_VX:
8488 case RISCV::VWADD_WX:
8489 case RISCV::VWMULSU_VX:
8490 case RISCV::VWMULU_VX:
8491 case RISCV::VWMUL_VX:
8492 case RISCV::VWSLL_VX:
8493 case RISCV::VWSUBU_VX:
8494 case RISCV::VWSUBU_WX:
8495 case RISCV::VWSUB_VX:
8496 case RISCV::VWSUB_WX:
8497 case RISCV::VXOR_VX: {
8498 // op: vd
8499 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8500 Value |= (op & 0x1f) << 7;
8501 // op: vm
8502 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8503 Value |= (op & 0x1) << 25;
8504 // op: vs2
8505 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8506 Value |= (op & 0x1f) << 20;
8507 // op: rs1
8508 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8509 Value |= (op & 0x1f) << 15;
8510 break;
8511 }
8512 case RISCV::RI_VUNZIP2A_VV:
8513 case RISCV::RI_VUNZIP2B_VV:
8514 case RISCV::RI_VZIP2A_VV:
8515 case RISCV::RI_VZIP2B_VV:
8516 case RISCV::RI_VZIPEVEN_VV:
8517 case RISCV::RI_VZIPODD_VV:
8518 case RISCV::VAADDU_VV:
8519 case RISCV::VAADD_VV:
8520 case RISCV::VABDU_VV:
8521 case RISCV::VABD_VV:
8522 case RISCV::VADD_VV:
8523 case RISCV::VANDN_VV:
8524 case RISCV::VAND_VV:
8525 case RISCV::VASUBU_VV:
8526 case RISCV::VASUB_VV:
8527 case RISCV::VCLMULH_VV:
8528 case RISCV::VCLMUL_VV:
8529 case RISCV::VDIVU_VV:
8530 case RISCV::VDIV_VV:
8531 case RISCV::VFADD_VV:
8532 case RISCV::VFDIV_VV:
8533 case RISCV::VFMAX_VV:
8534 case RISCV::VFMIN_VV:
8535 case RISCV::VFMUL_VV:
8536 case RISCV::VFREDMAX_VS:
8537 case RISCV::VFREDMIN_VS:
8538 case RISCV::VFREDOSUM_VS:
8539 case RISCV::VFREDUSUM_VS:
8540 case RISCV::VFSGNJN_VV:
8541 case RISCV::VFSGNJX_VV:
8542 case RISCV::VFSGNJ_VV:
8543 case RISCV::VFSUB_VV:
8544 case RISCV::VFWADD_VV:
8545 case RISCV::VFWADD_WV:
8546 case RISCV::VFWMUL_VV:
8547 case RISCV::VFWREDOSUM_VS:
8548 case RISCV::VFWREDUSUM_VS:
8549 case RISCV::VFWSUB_VV:
8550 case RISCV::VFWSUB_WV:
8551 case RISCV::VMAXU_VV:
8552 case RISCV::VMAX_VV:
8553 case RISCV::VMFEQ_VV:
8554 case RISCV::VMFLE_VV:
8555 case RISCV::VMFLT_VV:
8556 case RISCV::VMFNE_VV:
8557 case RISCV::VMINU_VV:
8558 case RISCV::VMIN_VV:
8559 case RISCV::VMSEQ_VV:
8560 case RISCV::VMSLEU_VV:
8561 case RISCV::VMSLE_VV:
8562 case RISCV::VMSLTU_VV:
8563 case RISCV::VMSLT_VV:
8564 case RISCV::VMSNE_VV:
8565 case RISCV::VMULHSU_VV:
8566 case RISCV::VMULHU_VV:
8567 case RISCV::VMULH_VV:
8568 case RISCV::VMUL_VV:
8569 case RISCV::VNCLIPU_WV:
8570 case RISCV::VNCLIP_WV:
8571 case RISCV::VNSRA_WV:
8572 case RISCV::VNSRL_WV:
8573 case RISCV::VOR_VV:
8574 case RISCV::VPAIRE_VV:
8575 case RISCV::VPAIRO_VV:
8576 case RISCV::VREDAND_VS:
8577 case RISCV::VREDMAXU_VS:
8578 case RISCV::VREDMAX_VS:
8579 case RISCV::VREDMINU_VS:
8580 case RISCV::VREDMIN_VS:
8581 case RISCV::VREDOR_VS:
8582 case RISCV::VREDSUM_VS:
8583 case RISCV::VREDXOR_VS:
8584 case RISCV::VREMU_VV:
8585 case RISCV::VREM_VV:
8586 case RISCV::VRGATHEREI16_VV:
8587 case RISCV::VRGATHER_VV:
8588 case RISCV::VROL_VV:
8589 case RISCV::VROR_VV:
8590 case RISCV::VSADDU_VV:
8591 case RISCV::VSADD_VV:
8592 case RISCV::VSLL_VV:
8593 case RISCV::VSMUL_VV:
8594 case RISCV::VSRA_VV:
8595 case RISCV::VSRL_VV:
8596 case RISCV::VSSRA_VV:
8597 case RISCV::VSSRL_VV:
8598 case RISCV::VSSUBU_VV:
8599 case RISCV::VSSUB_VV:
8600 case RISCV::VSUB_VV:
8601 case RISCV::VWABDAU_VV:
8602 case RISCV::VWABDA_VV:
8603 case RISCV::VWADDU_VV:
8604 case RISCV::VWADDU_WV:
8605 case RISCV::VWADD_VV:
8606 case RISCV::VWADD_WV:
8607 case RISCV::VWMULSU_VV:
8608 case RISCV::VWMULU_VV:
8609 case RISCV::VWMUL_VV:
8610 case RISCV::VWREDSUMU_VS:
8611 case RISCV::VWREDSUM_VS:
8612 case RISCV::VWSLL_VV:
8613 case RISCV::VWSUBU_VV:
8614 case RISCV::VWSUBU_WV:
8615 case RISCV::VWSUB_VV:
8616 case RISCV::VWSUB_WV:
8617 case RISCV::VXOR_VV:
8618 case RISCV::VZIP_VV: {
8619 // op: vd
8620 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8621 Value |= (op & 0x1f) << 7;
8622 // op: vm
8623 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8624 Value |= (op & 0x1) << 25;
8625 // op: vs2
8626 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8627 Value |= (op & 0x1f) << 20;
8628 // op: vs1
8629 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8630 Value |= (op & 0x1f) << 15;
8631 break;
8632 }
8633 case RISCV::VMV_V_V: {
8634 // op: vd
8635 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8636 Value |= (op & 0x1f) << 7;
8637 // op: vs1
8638 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8639 Value |= (op & 0x1f) << 15;
8640 break;
8641 }
8642 case RISCV::VMV1R_V:
8643 case RISCV::VMV2R_V:
8644 case RISCV::VMV4R_V:
8645 case RISCV::VMV8R_V: {
8646 // op: vd
8647 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8648 Value |= (op & 0x1f) << 7;
8649 // op: vs2
8650 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8651 Value |= (op & 0x1f) << 20;
8652 break;
8653 }
8654 case RISCV::VADC_VIM:
8655 case RISCV::VAESKF1_VI:
8656 case RISCV::VMADC_VI:
8657 case RISCV::VMADC_VIM:
8658 case RISCV::VMERGE_VIM:
8659 case RISCV::VSM4K_VI: {
8660 // op: vd
8661 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8662 Value |= (op & 0x1f) << 7;
8663 // op: vs2
8664 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8665 Value |= (op & 0x1f) << 20;
8666 // op: imm
8667 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8668 Value |= (op & 0x1f) << 15;
8669 break;
8670 }
8671 case RISCV::VADC_VXM:
8672 case RISCV::VFMERGE_VFM:
8673 case RISCV::VMADC_VX:
8674 case RISCV::VMADC_VXM:
8675 case RISCV::VMERGE_VXM:
8676 case RISCV::VMSBC_VX:
8677 case RISCV::VMSBC_VXM:
8678 case RISCV::VSBC_VXM: {
8679 // op: vd
8680 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8681 Value |= (op & 0x1f) << 7;
8682 // op: vs2
8683 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8684 Value |= (op & 0x1f) << 20;
8685 // op: rs1
8686 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8687 Value |= (op & 0x1f) << 15;
8688 break;
8689 }
8690 case RISCV::VADC_VVM:
8691 case RISCV::VCOMPRESS_VM:
8692 case RISCV::VMADC_VV:
8693 case RISCV::VMADC_VVM:
8694 case RISCV::VMANDN_MM:
8695 case RISCV::VMAND_MM:
8696 case RISCV::VMERGE_VVM:
8697 case RISCV::VMNAND_MM:
8698 case RISCV::VMNOR_MM:
8699 case RISCV::VMORN_MM:
8700 case RISCV::VMOR_MM:
8701 case RISCV::VMSBC_VV:
8702 case RISCV::VMSBC_VVM:
8703 case RISCV::VMXNOR_MM:
8704 case RISCV::VMXOR_MM:
8705 case RISCV::VSBC_VVM:
8706 case RISCV::VSM3ME_VV: {
8707 // op: vd
8708 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8709 Value |= (op & 0x1f) << 7;
8710 // op: vs2
8711 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8712 Value |= (op & 0x1f) << 20;
8713 // op: vs1
8714 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8715 Value |= (op & 0x1f) << 15;
8716 break;
8717 }
8718 case RISCV::VFMV_S_F:
8719 case RISCV::VMV_S_X: {
8720 // op: vd
8721 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8722 Value |= (op & 0x1f) << 7;
8723 // op: rs1
8724 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8725 Value |= (op & 0x1f) << 15;
8726 break;
8727 }
8728 case RISCV::VDOTA4SU_VX:
8729 case RISCV::VDOTA4US_VX:
8730 case RISCV::VDOTA4U_VX:
8731 case RISCV::VDOTA4_VX: {
8732 // op: vd
8733 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8734 Value |= (op & 0x1f) << 7;
8735 // op: vm
8736 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8737 Value |= (op & 0x1) << 25;
8738 // op: vs2
8739 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8740 Value |= (op & 0x1f) << 20;
8741 // op: rs1
8742 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8743 Value |= (op & 0x1f) << 15;
8744 break;
8745 }
8746 case RISCV::VDOTA4SU_VV:
8747 case RISCV::VDOTA4U_VV:
8748 case RISCV::VDOTA4_VV: {
8749 // op: vd
8750 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8751 Value |= (op & 0x1f) << 7;
8752 // op: vm
8753 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8754 Value |= (op & 0x1) << 25;
8755 // op: vs2
8756 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8757 Value |= (op & 0x1f) << 20;
8758 // op: vs1
8759 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8760 Value |= (op & 0x1f) << 15;
8761 break;
8762 }
8763 case RISCV::TH_VMAQASU_VX:
8764 case RISCV::TH_VMAQAUS_VX:
8765 case RISCV::TH_VMAQAU_VX:
8766 case RISCV::TH_VMAQA_VX:
8767 case RISCV::VFMACC_VF:
8768 case RISCV::VFMADD_VF:
8769 case RISCV::VFMSAC_VF:
8770 case RISCV::VFMSUB_VF:
8771 case RISCV::VFNMACC_VF:
8772 case RISCV::VFNMADD_VF:
8773 case RISCV::VFNMSAC_VF:
8774 case RISCV::VFNMSUB_VF:
8775 case RISCV::VFWMACCBF16_VF:
8776 case RISCV::VFWMACC_VF:
8777 case RISCV::VFWMSAC_VF:
8778 case RISCV::VFWNMACC_VF:
8779 case RISCV::VFWNMSAC_VF:
8780 case RISCV::VMACC_VX:
8781 case RISCV::VMADD_VX:
8782 case RISCV::VNMSAC_VX:
8783 case RISCV::VNMSUB_VX:
8784 case RISCV::VWMACCSU_VX:
8785 case RISCV::VWMACCUS_VX:
8786 case RISCV::VWMACCU_VX:
8787 case RISCV::VWMACC_VX: {
8788 // op: vd
8789 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8790 Value |= (op & 0x1f) << 7;
8791 // op: vm
8792 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8793 Value |= (op & 0x1) << 25;
8794 // op: vs2
8795 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8796 Value |= (op & 0x1f) << 20;
8797 // op: rs1
8798 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8799 Value |= (op & 0x1f) << 15;
8800 break;
8801 }
8802 case RISCV::TH_VMAQASU_VV:
8803 case RISCV::TH_VMAQAU_VV:
8804 case RISCV::TH_VMAQA_VV:
8805 case RISCV::VFMACC_VV:
8806 case RISCV::VFMADD_VV:
8807 case RISCV::VFMSAC_VV:
8808 case RISCV::VFMSUB_VV:
8809 case RISCV::VFNMACC_VV:
8810 case RISCV::VFNMADD_VV:
8811 case RISCV::VFNMSAC_VV:
8812 case RISCV::VFNMSUB_VV:
8813 case RISCV::VFWMACCBF16_VV:
8814 case RISCV::VFWMACC_VV:
8815 case RISCV::VFWMSAC_VV:
8816 case RISCV::VFWNMACC_VV:
8817 case RISCV::VFWNMSAC_VV:
8818 case RISCV::VMACC_VV:
8819 case RISCV::VMADD_VV:
8820 case RISCV::VNMSAC_VV:
8821 case RISCV::VNMSUB_VV:
8822 case RISCV::VWMACCSU_VV:
8823 case RISCV::VWMACCU_VV:
8824 case RISCV::VWMACC_VV: {
8825 // op: vd
8826 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8827 Value |= (op & 0x1f) << 7;
8828 // op: vm
8829 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8830 Value |= (op & 0x1) << 25;
8831 // op: vs2
8832 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8833 Value |= (op & 0x1f) << 20;
8834 // op: vs1
8835 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8836 Value |= (op & 0x1f) << 15;
8837 break;
8838 }
8839 case RISCV::SMT_VMADOT1:
8840 case RISCV::SMT_VMADOT1SU:
8841 case RISCV::SMT_VMADOT1U:
8842 case RISCV::SMT_VMADOT1US:
8843 case RISCV::SMT_VMADOT2:
8844 case RISCV::SMT_VMADOT2SU:
8845 case RISCV::SMT_VMADOT2U:
8846 case RISCV::SMT_VMADOT2US:
8847 case RISCV::SMT_VMADOT3:
8848 case RISCV::SMT_VMADOT3SU:
8849 case RISCV::SMT_VMADOT3U:
8850 case RISCV::SMT_VMADOT3US: {
8851 // op: vd
8852 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8853 Value |= (op & 0x1f) << 7;
8854 // op: vs1
8855 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8856 Value |= (op & 0x1e) << 15;
8857 // op: vs2
8858 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8859 Value |= (op & 0x1f) << 20;
8860 break;
8861 }
8862 case RISCV::SMT_VMADOT:
8863 case RISCV::SMT_VMADOTSU:
8864 case RISCV::SMT_VMADOTU:
8865 case RISCV::SMT_VMADOTUS: {
8866 // op: vd
8867 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8868 Value |= (op & 0x1f) << 7;
8869 // op: vs1
8870 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8871 Value |= (op & 0x1f) << 15;
8872 // op: vs2
8873 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8874 Value |= (op & 0x1f) << 20;
8875 break;
8876 }
8877 case RISCV::VAESDF_VS:
8878 case RISCV::VAESDF_VV:
8879 case RISCV::VAESDM_VS:
8880 case RISCV::VAESDM_VV:
8881 case RISCV::VAESEF_VS:
8882 case RISCV::VAESEF_VV:
8883 case RISCV::VAESEM_VS:
8884 case RISCV::VAESEM_VV:
8885 case RISCV::VAESZ_VS:
8886 case RISCV::VGMUL_VS:
8887 case RISCV::VGMUL_VV:
8888 case RISCV::VSM4R_VS:
8889 case RISCV::VSM4R_VV: {
8890 // op: vd
8891 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8892 Value |= (op & 0x1f) << 7;
8893 // op: vs2
8894 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8895 Value |= (op & 0x1f) << 20;
8896 break;
8897 }
8898 case RISCV::VAESKF2_VI:
8899 case RISCV::VSM3C_VI: {
8900 // op: vd
8901 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8902 Value |= (op & 0x1f) << 7;
8903 // op: vs2
8904 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8905 Value |= (op & 0x1f) << 20;
8906 // op: imm
8907 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
8908 Value |= (op & 0x1f) << 15;
8909 break;
8910 }
8911 case RISCV::VGHSH_VS:
8912 case RISCV::VGHSH_VV:
8913 case RISCV::VSHA2CH_VV:
8914 case RISCV::VSHA2CL_VV:
8915 case RISCV::VSHA2MS_VV: {
8916 // op: vd
8917 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8918 Value |= (op & 0x1f) << 7;
8919 // op: vs2
8920 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8921 Value |= (op & 0x1f) << 20;
8922 // op: vs1
8923 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8924 Value |= (op & 0x1f) << 15;
8925 break;
8926 }
8927 case RISCV::SF_VFWMACC_4x4x4:
8928 case RISCV::SF_VQMACCSU_2x8x2:
8929 case RISCV::SF_VQMACCSU_4x8x4:
8930 case RISCV::SF_VQMACCUS_2x8x2:
8931 case RISCV::SF_VQMACCUS_4x8x4:
8932 case RISCV::SF_VQMACCU_2x8x2:
8933 case RISCV::SF_VQMACCU_4x8x4:
8934 case RISCV::SF_VQMACC_2x8x2:
8935 case RISCV::SF_VQMACC_4x8x4: {
8936 // op: vd
8937 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8938 Value |= (op & 0x1f) << 7;
8939 // op: vs2
8940 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8941 Value |= (op & 0x1f) << 20;
8942 // op: vs1
8943 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8944 Value |= (op & 0x1f) << 15;
8945 break;
8946 }
8947 case RISCV::NDS_VFWCVT_F_B:
8948 case RISCV::NDS_VFWCVT_F_BU:
8949 case RISCV::NDS_VFWCVT_F_N:
8950 case RISCV::NDS_VFWCVT_F_NU: {
8951 // op: vs
8952 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8953 Value |= (op & 0x1f) << 20;
8954 // op: vd
8955 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8956 Value |= (op & 0x1f) << 7;
8957 // op: vm
8958 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
8959 Value |= (op & 0x1) << 25;
8960 break;
8961 }
8962 case RISCV::SF_VC_I: {
8963 // op: vs2
8964 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
8965 Value |= (op & 0x1f) << 20;
8966 // op: vd
8967 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8968 Value |= (op & 0x1f) << 7;
8969 // op: imm
8970 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
8971 Value |= (op & 0x1f) << 15;
8972 // op: funct6_lo2
8973 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8974 Value |= (op & 0x3) << 26;
8975 break;
8976 }
8977 case RISCV::SF_VC_X: {
8978 // op: vs2
8979 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
8980 Value |= (op & 0x1f) << 20;
8981 // op: vd
8982 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8983 Value |= (op & 0x1f) << 7;
8984 // op: rs1
8985 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8986 Value |= (op & 0x1f) << 15;
8987 // op: funct6_lo2
8988 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8989 Value |= (op & 0x3) << 26;
8990 break;
8991 }
8992 case RISCV::SF_VC_V_I: {
8993 // op: vs2
8994 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8995 Value |= (op & 0x1f) << 20;
8996 // op: vd
8997 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8998 Value |= (op & 0x1f) << 7;
8999 // op: imm
9000 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9001 Value |= (op & 0x1f) << 15;
9002 // op: funct6_lo2
9003 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9004 Value |= (op & 0x3) << 26;
9005 break;
9006 }
9007 case RISCV::SF_VC_V_X: {
9008 // op: vs2
9009 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
9010 Value |= (op & 0x1f) << 20;
9011 // op: vd
9012 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9013 Value |= (op & 0x1f) << 7;
9014 // op: rs1
9015 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9016 Value |= (op & 0x1f) << 15;
9017 // op: funct6_lo2
9018 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9019 Value |= (op & 0x3) << 26;
9020 break;
9021 }
9022 case RISCV::NDS_VFPMADB_VF:
9023 case RISCV::NDS_VFPMADT_VF: {
9024 // op: vs2
9025 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9026 Value |= (op & 0x1f) << 20;
9027 // op: rs1
9028 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9029 Value |= (op & 0x1f) << 15;
9030 // op: vd
9031 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9032 Value |= (op & 0x1f) << 7;
9033 // op: vm
9034 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
9035 Value |= (op & 0x1) << 25;
9036 break;
9037 }
9038 case RISCV::NDS_VFNCVT_BF16_S:
9039 case RISCV::NDS_VFWCVT_S_BF16: {
9040 // op: vs2
9041 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9042 Value |= (op & 0x1f) << 20;
9043 // op: vd
9044 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9045 Value |= (op & 0x1f) << 7;
9046 break;
9047 }
9048 case RISCV::SF_MM_E4M3_E4M3:
9049 case RISCV::SF_MM_E4M3_E5M2:
9050 case RISCV::SF_MM_E5M2_E4M3:
9051 case RISCV::SF_MM_E5M2_E5M2:
9052 case RISCV::SF_MM_S_S:
9053 case RISCV::SF_MM_S_U:
9054 case RISCV::SF_MM_U_S:
9055 case RISCV::SF_MM_U_U: {
9056 // op: vs2
9057 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9058 Value |= (op & 0x1f) << 20;
9059 // op: vs1
9060 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9061 Value |= (op & 0x1f) << 15;
9062 // op: rd
9063 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9064 Value |= (op & 0xc) << 8;
9065 break;
9066 }
9067 case RISCV::SF_MM_F_F: {
9068 // op: vs2
9069 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9070 Value |= (op & 0x1f) << 20;
9071 // op: vs1
9072 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9073 Value |= (op & 0x1f) << 15;
9074 // op: rd
9075 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9076 Value |= (op & 0xe) << 8;
9077 break;
9078 }
9079 case RISCV::SF_VC_IV: {
9080 // op: vs2
9081 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9082 Value |= (op & 0x1f) << 20;
9083 // op: vd
9084 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9085 Value |= (op & 0x1f) << 7;
9086 // op: imm
9087 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9088 Value |= (op & 0x1f) << 15;
9089 // op: funct6_lo2
9090 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9091 Value |= (op & 0x3) << 26;
9092 break;
9093 }
9094 case RISCV::SF_VC_FV: {
9095 // op: vs2
9096 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9097 Value |= (op & 0x1f) << 20;
9098 // op: vd
9099 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9100 Value |= (op & 0x1f) << 7;
9101 // op: rs1
9102 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9103 Value |= (op & 0x1f) << 15;
9104 // op: funct6_lo1
9105 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9106 Value |= (op & 0x1) << 26;
9107 break;
9108 }
9109 case RISCV::SF_VC_XV: {
9110 // op: vs2
9111 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9112 Value |= (op & 0x1f) << 20;
9113 // op: vd
9114 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9115 Value |= (op & 0x1f) << 7;
9116 // op: rs1
9117 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9118 Value |= (op & 0x1f) << 15;
9119 // op: funct6_lo2
9120 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9121 Value |= (op & 0x3) << 26;
9122 break;
9123 }
9124 case RISCV::SF_VC_VV: {
9125 // op: vs2
9126 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9127 Value |= (op & 0x1f) << 20;
9128 // op: vd
9129 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9130 Value |= (op & 0x1f) << 7;
9131 // op: vs1
9132 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9133 Value |= (op & 0x1f) << 15;
9134 // op: funct6_lo2
9135 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9136 Value |= (op & 0x3) << 26;
9137 break;
9138 }
9139 case RISCV::SF_VC_V_IV: {
9140 // op: vs2
9141 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9142 Value |= (op & 0x1f) << 20;
9143 // op: vd
9144 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9145 Value |= (op & 0x1f) << 7;
9146 // op: imm
9147 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9148 Value |= (op & 0x1f) << 15;
9149 // op: funct6_lo2
9150 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9151 Value |= (op & 0x3) << 26;
9152 break;
9153 }
9154 case RISCV::SF_VC_V_FV: {
9155 // op: vs2
9156 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9157 Value |= (op & 0x1f) << 20;
9158 // op: vd
9159 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9160 Value |= (op & 0x1f) << 7;
9161 // op: rs1
9162 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9163 Value |= (op & 0x1f) << 15;
9164 // op: funct6_lo1
9165 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9166 Value |= (op & 0x1) << 26;
9167 break;
9168 }
9169 case RISCV::SF_VC_V_XV: {
9170 // op: vs2
9171 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9172 Value |= (op & 0x1f) << 20;
9173 // op: vd
9174 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9175 Value |= (op & 0x1f) << 7;
9176 // op: rs1
9177 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9178 Value |= (op & 0x1f) << 15;
9179 // op: funct6_lo2
9180 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9181 Value |= (op & 0x3) << 26;
9182 break;
9183 }
9184 case RISCV::SF_VC_V_VV: {
9185 // op: vs2
9186 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9187 Value |= (op & 0x1f) << 20;
9188 // op: vd
9189 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9190 Value |= (op & 0x1f) << 7;
9191 // op: vs1
9192 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9193 Value |= (op & 0x1f) << 15;
9194 // op: funct6_lo2
9195 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9196 Value |= (op & 0x3) << 26;
9197 break;
9198 }
9199 case RISCV::SF_VC_IVV:
9200 case RISCV::SF_VC_IVW: {
9201 // op: vs2
9202 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9203 Value |= (op & 0x1f) << 20;
9204 // op: vd
9205 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9206 Value |= (op & 0x1f) << 7;
9207 // op: imm
9208 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9209 Value |= (op & 0x1f) << 15;
9210 // op: funct6_lo2
9211 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9212 Value |= (op & 0x3) << 26;
9213 break;
9214 }
9215 case RISCV::SF_VC_FVV:
9216 case RISCV::SF_VC_FVW: {
9217 // op: vs2
9218 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9219 Value |= (op & 0x1f) << 20;
9220 // op: vd
9221 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9222 Value |= (op & 0x1f) << 7;
9223 // op: rs1
9224 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9225 Value |= (op & 0x1f) << 15;
9226 // op: funct6_lo1
9227 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9228 Value |= (op & 0x1) << 26;
9229 break;
9230 }
9231 case RISCV::SF_VC_XVV:
9232 case RISCV::SF_VC_XVW: {
9233 // op: vs2
9234 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9235 Value |= (op & 0x1f) << 20;
9236 // op: vd
9237 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9238 Value |= (op & 0x1f) << 7;
9239 // op: rs1
9240 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9241 Value |= (op & 0x1f) << 15;
9242 // op: funct6_lo2
9243 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9244 Value |= (op & 0x3) << 26;
9245 break;
9246 }
9247 case RISCV::SF_VC_VVV:
9248 case RISCV::SF_VC_VVW: {
9249 // op: vs2
9250 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9251 Value |= (op & 0x1f) << 20;
9252 // op: vd
9253 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9254 Value |= (op & 0x1f) << 7;
9255 // op: vs1
9256 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9257 Value |= (op & 0x1f) << 15;
9258 // op: funct6_lo2
9259 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9260 Value |= (op & 0x3) << 26;
9261 break;
9262 }
9263 case RISCV::NDS_VD4DOTSU_VV:
9264 case RISCV::NDS_VD4DOTS_VV:
9265 case RISCV::NDS_VD4DOTU_VV: {
9266 // op: vs2
9267 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9268 Value |= (op & 0x1f) << 20;
9269 // op: vs1
9270 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9271 Value |= (op & 0x1f) << 15;
9272 // op: vd
9273 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9274 Value |= (op & 0x1f) << 7;
9275 // op: vm
9276 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
9277 Value |= (op & 0x1) << 25;
9278 break;
9279 }
9280 case RISCV::SF_VC_V_IVV:
9281 case RISCV::SF_VC_V_IVW: {
9282 // op: vs2
9283 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9284 Value |= (op & 0x1f) << 20;
9285 // op: vd
9286 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9287 Value |= (op & 0x1f) << 7;
9288 // op: imm
9289 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
9290 Value |= (op & 0x1f) << 15;
9291 // op: funct6_lo2
9292 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9293 Value |= (op & 0x3) << 26;
9294 break;
9295 }
9296 case RISCV::SF_VC_V_FVV:
9297 case RISCV::SF_VC_V_FVW: {
9298 // op: vs2
9299 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9300 Value |= (op & 0x1f) << 20;
9301 // op: vd
9302 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9303 Value |= (op & 0x1f) << 7;
9304 // op: rs1
9305 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
9306 Value |= (op & 0x1f) << 15;
9307 // op: funct6_lo1
9308 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9309 Value |= (op & 0x1) << 26;
9310 break;
9311 }
9312 case RISCV::SF_VC_V_XVV:
9313 case RISCV::SF_VC_V_XVW: {
9314 // op: vs2
9315 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9316 Value |= (op & 0x1f) << 20;
9317 // op: vd
9318 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9319 Value |= (op & 0x1f) << 7;
9320 // op: rs1
9321 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
9322 Value |= (op & 0x1f) << 15;
9323 // op: funct6_lo2
9324 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9325 Value |= (op & 0x3) << 26;
9326 break;
9327 }
9328 case RISCV::SF_VC_V_VVV:
9329 case RISCV::SF_VC_V_VVW: {
9330 // op: vs2
9331 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9332 Value |= (op & 0x1f) << 20;
9333 // op: vd
9334 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9335 Value |= (op & 0x1f) << 7;
9336 // op: vs1
9337 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
9338 Value |= (op & 0x1f) << 15;
9339 // op: funct6_lo2
9340 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9341 Value |= (op & 0x3) << 26;
9342 break;
9343 }
9344 default:
9345 reportUnsupportedInst(Inst: MI);
9346 }
9347 return Value;
9348}
9349
9350#ifdef GET_OPERAND_BIT_OFFSET
9351#undef GET_OPERAND_BIT_OFFSET
9352
9353uint32_t RISCVMCCodeEmitter::getOperandBitOffset(const MCInst &MI,
9354 unsigned OpNum,
9355 const MCSubtargetInfo &STI) const {
9356 switch (MI.getOpcode()) {
9357 case RISCV::C_EBREAK:
9358 case RISCV::C_MOP_11:
9359 case RISCV::C_MOP_13:
9360 case RISCV::C_MOP_15:
9361 case RISCV::C_MOP_3:
9362 case RISCV::C_MOP_7:
9363 case RISCV::C_MOP_9:
9364 case RISCV::C_NOP:
9365 case RISCV::C_SSPOPCHK:
9366 case RISCV::C_SSPUSH:
9367 case RISCV::C_UNIMP:
9368 case RISCV::DRET:
9369 case RISCV::EBREAK:
9370 case RISCV::ECALL:
9371 case RISCV::FENCE_I:
9372 case RISCV::FENCE_TSO:
9373 case RISCV::MIPS_EHB:
9374 case RISCV::MIPS_IHB:
9375 case RISCV::MIPS_PAUSE:
9376 case RISCV::MNRET:
9377 case RISCV::MRET:
9378 case RISCV::QC_C_DI:
9379 case RISCV::QC_C_EI:
9380 case RISCV::QC_C_MIENTER:
9381 case RISCV::QC_C_MIENTER_NEST:
9382 case RISCV::QC_C_MILEAVERET:
9383 case RISCV::QC_C_MNRET:
9384 case RISCV::QC_C_MRET:
9385 case RISCV::SCTRCLR:
9386 case RISCV::SFENCE_INVAL_IR:
9387 case RISCV::SFENCE_W_INVAL:
9388 case RISCV::SF_CEASE:
9389 case RISCV::SF_VTDISCARD:
9390 case RISCV::SRET:
9391 case RISCV::TH_DCACHE_CALL:
9392 case RISCV::TH_DCACHE_CIALL:
9393 case RISCV::TH_DCACHE_IALL:
9394 case RISCV::TH_ICACHE_IALL:
9395 case RISCV::TH_ICACHE_IALLS:
9396 case RISCV::TH_L2CACHE_CALL:
9397 case RISCV::TH_L2CACHE_CIALL:
9398 case RISCV::TH_L2CACHE_IALL:
9399 case RISCV::TH_SYNC:
9400 case RISCV::TH_SYNC_I:
9401 case RISCV::TH_SYNC_IS:
9402 case RISCV::TH_SYNC_S:
9403 case RISCV::UNIMP:
9404 case RISCV::WFI:
9405 case RISCV::WRS_NTO:
9406 case RISCV::WRS_STO: {
9407 break;
9408 }
9409 case RISCV::AIF_FSWG_PS:
9410 case RISCV::AIF_FSWL_PS: {
9411 switch (OpNum) {
9412 case 0:
9413 // op: fs3
9414 return 7;
9415 case 1:
9416 // op: rs1
9417 return 15;
9418 }
9419 break;
9420 }
9421 case RISCV::C_NOP_HINT: {
9422 switch (OpNum) {
9423 case 0:
9424 // op: imm
9425 return 2;
9426 }
9427 break;
9428 }
9429 case RISCV::QC_CLRINTI:
9430 case RISCV::QC_SETINTI: {
9431 switch (OpNum) {
9432 case 0:
9433 // op: imm10
9434 return 15;
9435 }
9436 break;
9437 }
9438 case RISCV::QC_E_J:
9439 case RISCV::QC_E_JAL: {
9440 switch (OpNum) {
9441 case 0:
9442 // op: imm31
9443 return 7;
9444 }
9445 break;
9446 }
9447 case RISCV::QC_SYNC:
9448 case RISCV::QC_SYNCR:
9449 case RISCV::QC_SYNCWF:
9450 case RISCV::QC_SYNCWL: {
9451 switch (OpNum) {
9452 case 0:
9453 // op: imm5
9454 return 20;
9455 }
9456 break;
9457 }
9458 case RISCV::QC_PPUTCI: {
9459 switch (OpNum) {
9460 case 0:
9461 // op: imm8
9462 return 20;
9463 }
9464 break;
9465 }
9466 case RISCV::CM_JALT:
9467 case RISCV::CM_JT: {
9468 switch (OpNum) {
9469 case 0:
9470 // op: index
9471 return 2;
9472 }
9473 break;
9474 }
9475 case RISCV::C_J:
9476 case RISCV::C_JAL: {
9477 switch (OpNum) {
9478 case 0:
9479 // op: offset
9480 return 2;
9481 }
9482 break;
9483 }
9484 case RISCV::InsnQC_EJ: {
9485 switch (OpNum) {
9486 case 0:
9487 // op: opcode
9488 return 0;
9489 case 1:
9490 // op: func3
9491 return 12;
9492 case 2:
9493 // op: func2
9494 return 15;
9495 case 3:
9496 // op: func5
9497 return 20;
9498 case 4:
9499 // op: imm31
9500 return 7;
9501 }
9502 break;
9503 }
9504 case RISCV::InsnQC_ES: {
9505 switch (OpNum) {
9506 case 0:
9507 // op: opcode
9508 return 0;
9509 case 1:
9510 // op: func3
9511 return 12;
9512 case 2:
9513 // op: func2
9514 return 30;
9515 case 4:
9516 // op: rs1
9517 return 15;
9518 case 3:
9519 // op: rs2
9520 return 20;
9521 case 5:
9522 // op: imm26
9523 return 7;
9524 }
9525 break;
9526 }
9527 case RISCV::InsnQC_EB: {
9528 switch (OpNum) {
9529 case 0:
9530 // op: opcode
9531 return 0;
9532 case 1:
9533 // op: func3
9534 return 12;
9535 case 2:
9536 // op: func5
9537 return 20;
9538 case 3:
9539 // op: rs1
9540 return 15;
9541 case 5:
9542 // op: imm12
9543 return 7;
9544 case 4:
9545 // op: imm16
9546 return 32;
9547 }
9548 break;
9549 }
9550 case RISCV::InsnS: {
9551 switch (OpNum) {
9552 case 0:
9553 // op: opcode
9554 return 0;
9555 case 1:
9556 // op: funct3
9557 return 12;
9558 case 4:
9559 // op: imm12
9560 return 7;
9561 case 2:
9562 // op: rs2
9563 return 20;
9564 case 3:
9565 // op: rs1
9566 return 15;
9567 }
9568 break;
9569 }
9570 case RISCV::InsnB: {
9571 switch (OpNum) {
9572 case 0:
9573 // op: opcode
9574 return 0;
9575 case 1:
9576 // op: funct3
9577 return 12;
9578 case 4:
9579 // op: imm12
9580 return 7;
9581 case 3:
9582 // op: rs2
9583 return 20;
9584 case 2:
9585 // op: rs1
9586 return 15;
9587 }
9588 break;
9589 }
9590 case RISCV::InsnCJ: {
9591 switch (OpNum) {
9592 case 0:
9593 // op: opcode
9594 return 0;
9595 case 1:
9596 // op: funct3
9597 return 13;
9598 case 2:
9599 // op: imm11
9600 return 2;
9601 }
9602 break;
9603 }
9604 case RISCV::InsnCSS: {
9605 switch (OpNum) {
9606 case 0:
9607 // op: opcode
9608 return 0;
9609 case 1:
9610 // op: funct3
9611 return 13;
9612 case 3:
9613 // op: imm6
9614 return 7;
9615 case 2:
9616 // op: rs2
9617 return 2;
9618 }
9619 break;
9620 }
9621 case RISCV::InsnCB: {
9622 switch (OpNum) {
9623 case 0:
9624 // op: opcode
9625 return 0;
9626 case 1:
9627 // op: funct3
9628 return 13;
9629 case 3:
9630 // op: imm8
9631 return 2;
9632 case 2:
9633 // op: rs1
9634 return 7;
9635 }
9636 break;
9637 }
9638 case RISCV::InsnCS: {
9639 switch (OpNum) {
9640 case 0:
9641 // op: opcode
9642 return 0;
9643 case 1:
9644 // op: funct3
9645 return 13;
9646 case 4:
9647 // op: imm5
9648 return 5;
9649 case 2:
9650 // op: rs2
9651 return 2;
9652 case 3:
9653 // op: rs1
9654 return 7;
9655 }
9656 break;
9657 }
9658 case RISCV::FENCE: {
9659 switch (OpNum) {
9660 case 0:
9661 // op: pred
9662 return 24;
9663 case 1:
9664 // op: succ
9665 return 20;
9666 }
9667 break;
9668 }
9669 case RISCV::C_FLD:
9670 case RISCV::C_FLW:
9671 case RISCV::C_LBU:
9672 case RISCV::C_LD:
9673 case RISCV::C_LD_RV32:
9674 case RISCV::C_LH:
9675 case RISCV::C_LHU:
9676 case RISCV::C_LH_INX:
9677 case RISCV::C_LW:
9678 case RISCV::C_LW_INX:
9679 case RISCV::QK_C_LBU:
9680 case RISCV::QK_C_LHU: {
9681 switch (OpNum) {
9682 case 0:
9683 // op: rd
9684 return 2;
9685 case 1:
9686 // op: rs1
9687 return 7;
9688 case 2:
9689 // op: imm
9690 return 5;
9691 }
9692 break;
9693 }
9694 case RISCV::FLI_D:
9695 case RISCV::FLI_H:
9696 case RISCV::FLI_Q:
9697 case RISCV::FLI_S: {
9698 switch (OpNum) {
9699 case 0:
9700 // op: rd
9701 return 7;
9702 case 1:
9703 // op: imm
9704 return 15;
9705 }
9706 break;
9707 }
9708 case RISCV::QC_E_LI: {
9709 switch (OpNum) {
9710 case 0:
9711 // op: rd
9712 return 7;
9713 case 1:
9714 // op: imm
9715 return 16;
9716 }
9717 break;
9718 }
9719 case RISCV::PLI_H:
9720 case RISCV::PLI_W:
9721 case RISCV::PLUI_H:
9722 case RISCV::PLUI_W: {
9723 switch (OpNum) {
9724 case 0:
9725 // op: rd
9726 return 7;
9727 case 1:
9728 // op: imm10
9729 return 15;
9730 }
9731 break;
9732 }
9733 case RISCV::PLI_B: {
9734 switch (OpNum) {
9735 case 0:
9736 // op: rd
9737 return 7;
9738 case 1:
9739 // op: imm8
9740 return 16;
9741 }
9742 break;
9743 }
9744 case RISCV::AIF_FMVS_X_PS:
9745 case RISCV::AIF_FMVZ_X_PS: {
9746 switch (OpNum) {
9747 case 0:
9748 // op: rd
9749 return 7;
9750 case 1:
9751 // op: rs1
9752 return 15;
9753 case 2:
9754 // op: idx
9755 return 20;
9756 }
9757 break;
9758 }
9759 case RISCV::AIF_FSWIZZ_PS: {
9760 switch (OpNum) {
9761 case 0:
9762 // op: rd
9763 return 7;
9764 case 1:
9765 // op: rs1
9766 return 15;
9767 case 2:
9768 // op: imm
9769 return 12;
9770 }
9771 break;
9772 }
9773 case RISCV::QC_E_ADDI:
9774 case RISCV::QC_E_ANDI:
9775 case RISCV::QC_E_LB:
9776 case RISCV::QC_E_LBU:
9777 case RISCV::QC_E_LH:
9778 case RISCV::QC_E_LHU:
9779 case RISCV::QC_E_LW:
9780 case RISCV::QC_E_ORI:
9781 case RISCV::QC_E_XORI: {
9782 switch (OpNum) {
9783 case 0:
9784 // op: rd
9785 return 7;
9786 case 1:
9787 // op: rs1
9788 return 15;
9789 case 2:
9790 // op: imm
9791 return 20;
9792 }
9793 break;
9794 }
9795 case RISCV::NDS_BFOS:
9796 case RISCV::NDS_BFOZ: {
9797 switch (OpNum) {
9798 case 0:
9799 // op: rd
9800 return 7;
9801 case 1:
9802 // op: rs1
9803 return 15;
9804 case 2:
9805 // op: msb
9806 return 26;
9807 case 3:
9808 // op: lsb
9809 return 20;
9810 }
9811 break;
9812 }
9813 case RISCV::AIF_FCVT_PS_PW:
9814 case RISCV::AIF_FCVT_PS_PWU:
9815 case RISCV::AIF_FCVT_PWU_PS:
9816 case RISCV::AIF_FCVT_PW_PS: {
9817 switch (OpNum) {
9818 case 0:
9819 // op: rd
9820 return 7;
9821 case 1:
9822 // op: rs1
9823 return 15;
9824 case 2:
9825 // op: rm
9826 return 12;
9827 }
9828 break;
9829 }
9830 case RISCV::AIF_FADD_PS:
9831 case RISCV::AIF_FDIV_PS:
9832 case RISCV::AIF_FMUL_PS:
9833 case RISCV::AIF_FSUB_PS: {
9834 switch (OpNum) {
9835 case 0:
9836 // op: rd
9837 return 7;
9838 case 1:
9839 // op: rs1
9840 return 15;
9841 case 2:
9842 // op: rs2
9843 return 20;
9844 case 3:
9845 // op: rm
9846 return 12;
9847 }
9848 break;
9849 }
9850 case RISCV::AIF_FMADD_PS:
9851 case RISCV::AIF_FMSUB_PS:
9852 case RISCV::AIF_FNMADD_PS:
9853 case RISCV::AIF_FNMSUB_PS: {
9854 switch (OpNum) {
9855 case 0:
9856 // op: rd
9857 return 7;
9858 case 1:
9859 // op: rs1
9860 return 15;
9861 case 2:
9862 // op: rs2
9863 return 20;
9864 case 3:
9865 // op: rs3
9866 return 27;
9867 case 4:
9868 // op: rm
9869 return 12;
9870 }
9871 break;
9872 }
9873 case RISCV::AIF_FCMOV_PS: {
9874 switch (OpNum) {
9875 case 0:
9876 // op: rd
9877 return 7;
9878 case 1:
9879 // op: rs1
9880 return 15;
9881 case 2:
9882 // op: rs2
9883 return 20;
9884 case 3:
9885 // op: rs3
9886 return 27;
9887 }
9888 break;
9889 }
9890 case RISCV::VSETIVLI: {
9891 switch (OpNum) {
9892 case 0:
9893 // op: rd
9894 return 7;
9895 case 1:
9896 // op: uimm
9897 return 15;
9898 case 2:
9899 // op: vtypei
9900 return 20;
9901 }
9902 break;
9903 }
9904 case RISCV::VFMV_F_S:
9905 case RISCV::VMV_X_S: {
9906 switch (OpNum) {
9907 case 0:
9908 // op: rd
9909 return 7;
9910 case 1:
9911 // op: vs2
9912 return 20;
9913 }
9914 break;
9915 }
9916 case RISCV::VCPOP_M:
9917 case RISCV::VFIRST_M: {
9918 switch (OpNum) {
9919 case 0:
9920 // op: rd
9921 return 7;
9922 case 2:
9923 // op: vm
9924 return 25;
9925 case 1:
9926 // op: vs2
9927 return 20;
9928 }
9929 break;
9930 }
9931 case RISCV::AIF_MOVA_X_M:
9932 case RISCV::QC_C_DIR:
9933 case RISCV::SSRDP: {
9934 switch (OpNum) {
9935 case 0:
9936 // op: rd
9937 return 7;
9938 }
9939 break;
9940 }
9941 case RISCV::PLI_DH:
9942 case RISCV::PLUI_DH: {
9943 switch (OpNum) {
9944 case 0:
9945 // op: rd
9946 return 8;
9947 case 1:
9948 // op: imm10
9949 return 15;
9950 }
9951 break;
9952 }
9953 case RISCV::PLI_DB: {
9954 switch (OpNum) {
9955 case 0:
9956 // op: rd
9957 return 8;
9958 case 1:
9959 // op: imm8
9960 return 16;
9961 }
9962 break;
9963 }
9964 case RISCV::SF_VTZERO_T: {
9965 switch (OpNum) {
9966 case 0:
9967 // op: rd
9968 return 8;
9969 }
9970 break;
9971 }
9972 case RISCV::QK_C_LBUSP:
9973 case RISCV::QK_C_LHUSP:
9974 case RISCV::QK_C_SBSP:
9975 case RISCV::QK_C_SHSP: {
9976 switch (OpNum) {
9977 case 0:
9978 // op: rd_rs2
9979 return 2;
9980 case 2:
9981 // op: imm
9982 return 7;
9983 }
9984 break;
9985 }
9986 case RISCV::CM_POP:
9987 case RISCV::CM_POPRET:
9988 case RISCV::CM_POPRETZ:
9989 case RISCV::CM_PUSH:
9990 case RISCV::QC_CM_POP:
9991 case RISCV::QC_CM_POPRET:
9992 case RISCV::QC_CM_POPRETZ:
9993 case RISCV::QC_CM_PUSH:
9994 case RISCV::QC_CM_PUSHFP: {
9995 switch (OpNum) {
9996 case 0:
9997 // op: rlist
9998 return 4;
9999 case 1:
10000 // op: stackadj
10001 return 2;
10002 }
10003 break;
10004 }
10005 case RISCV::QC_E_BEQI:
10006 case RISCV::QC_E_BGEI:
10007 case RISCV::QC_E_BGEUI:
10008 case RISCV::QC_E_BLTI:
10009 case RISCV::QC_E_BLTUI:
10010 case RISCV::QC_E_BNEI: {
10011 switch (OpNum) {
10012 case 0:
10013 // op: rs1
10014 return 15;
10015 case 1:
10016 // op: imm16
10017 return 32;
10018 case 2:
10019 // op: imm12
10020 return 7;
10021 }
10022 break;
10023 }
10024 case RISCV::AIF_MOVA_M_X:
10025 case RISCV::CBO_CLEAN:
10026 case RISCV::CBO_FLUSH:
10027 case RISCV::CBO_INVAL:
10028 case RISCV::CBO_ZERO:
10029 case RISCV::SF_CDISCARD_D_L1:
10030 case RISCV::SF_CFLUSH_D_L1:
10031 case RISCV::SSPOPCHK:
10032 case RISCV::TH_DCACHE_CIPA:
10033 case RISCV::TH_DCACHE_CISW:
10034 case RISCV::TH_DCACHE_CIVA:
10035 case RISCV::TH_DCACHE_CPA:
10036 case RISCV::TH_DCACHE_CPAL1:
10037 case RISCV::TH_DCACHE_CSW:
10038 case RISCV::TH_DCACHE_CVA:
10039 case RISCV::TH_DCACHE_CVAL1:
10040 case RISCV::TH_DCACHE_IPA:
10041 case RISCV::TH_DCACHE_ISW:
10042 case RISCV::TH_DCACHE_IVA:
10043 case RISCV::TH_ICACHE_IPA:
10044 case RISCV::TH_ICACHE_IVA: {
10045 switch (OpNum) {
10046 case 0:
10047 // op: rs1
10048 return 15;
10049 }
10050 break;
10051 }
10052 case RISCV::C_MV: {
10053 switch (OpNum) {
10054 case 0:
10055 // op: rs1
10056 return 7;
10057 case 1:
10058 // op: rs2
10059 return 2;
10060 }
10061 break;
10062 }
10063 case RISCV::C_JALR:
10064 case RISCV::C_JR:
10065 case RISCV::QC_C_CLRINT:
10066 case RISCV::QC_C_EIR:
10067 case RISCV::QC_C_SETINT: {
10068 switch (OpNum) {
10069 case 0:
10070 // op: rs1
10071 return 7;
10072 }
10073 break;
10074 }
10075 case RISCV::AIF_SBG:
10076 case RISCV::AIF_SBL:
10077 case RISCV::AIF_SHG:
10078 case RISCV::AIF_SHL:
10079 case RISCV::HSV_B:
10080 case RISCV::HSV_D:
10081 case RISCV::HSV_H:
10082 case RISCV::HSV_W:
10083 case RISCV::SB_AQRL:
10084 case RISCV::SB_RL:
10085 case RISCV::SD_AQRL:
10086 case RISCV::SD_RL:
10087 case RISCV::SF_VLTE16:
10088 case RISCV::SF_VLTE32:
10089 case RISCV::SF_VLTE64:
10090 case RISCV::SF_VLTE8:
10091 case RISCV::SF_VSTE16:
10092 case RISCV::SF_VSTE32:
10093 case RISCV::SF_VSTE64:
10094 case RISCV::SF_VSTE8:
10095 case RISCV::SH_AQRL:
10096 case RISCV::SH_RL:
10097 case RISCV::SW_AQRL:
10098 case RISCV::SW_RL: {
10099 switch (OpNum) {
10100 case 0:
10101 // op: rs2
10102 return 20;
10103 case 1:
10104 // op: rs1
10105 return 15;
10106 }
10107 break;
10108 }
10109 case RISCV::SSPUSH: {
10110 switch (OpNum) {
10111 case 0:
10112 // op: rs2
10113 return 20;
10114 }
10115 break;
10116 }
10117 case RISCV::C_FSD:
10118 case RISCV::C_FSW:
10119 case RISCV::C_SB:
10120 case RISCV::C_SD:
10121 case RISCV::C_SD_RV32:
10122 case RISCV::C_SH:
10123 case RISCV::C_SH_INX:
10124 case RISCV::C_SW:
10125 case RISCV::C_SW_INX:
10126 case RISCV::QK_C_SB:
10127 case RISCV::QK_C_SH: {
10128 switch (OpNum) {
10129 case 0:
10130 // op: rs2
10131 return 2;
10132 case 1:
10133 // op: rs1
10134 return 7;
10135 case 2:
10136 // op: imm
10137 return 5;
10138 }
10139 break;
10140 }
10141 case RISCV::QC_C_SYNC:
10142 case RISCV::QC_C_SYNCR:
10143 case RISCV::QC_C_SYNCWF:
10144 case RISCV::QC_C_SYNCWL: {
10145 switch (OpNum) {
10146 case 0:
10147 // op: slist
10148 return 7;
10149 }
10150 break;
10151 }
10152 case RISCV::Insn16:
10153 case RISCV::Insn32:
10154 case RISCV::Insn48:
10155 case RISCV::Insn64: {
10156 switch (OpNum) {
10157 case 0:
10158 // op: value
10159 return 0;
10160 }
10161 break;
10162 }
10163 case RISCV::VMV_V_I: {
10164 switch (OpNum) {
10165 case 0:
10166 // op: vd
10167 return 7;
10168 case 1:
10169 // op: imm
10170 return 15;
10171 }
10172 break;
10173 }
10174 case RISCV::VFMV_V_F:
10175 case RISCV::VMV_V_X: {
10176 switch (OpNum) {
10177 case 0:
10178 // op: vd
10179 return 7;
10180 case 1:
10181 // op: rs1
10182 return 15;
10183 }
10184 break;
10185 }
10186 case RISCV::VID_V: {
10187 switch (OpNum) {
10188 case 0:
10189 // op: vd
10190 return 7;
10191 case 1:
10192 // op: vm
10193 return 25;
10194 }
10195 break;
10196 }
10197 case RISCV::VMV_V_V: {
10198 switch (OpNum) {
10199 case 0:
10200 // op: vd
10201 return 7;
10202 case 1:
10203 // op: vs1
10204 return 15;
10205 }
10206 break;
10207 }
10208 case RISCV::VADC_VIM:
10209 case RISCV::VAESKF1_VI:
10210 case RISCV::VMADC_VI:
10211 case RISCV::VMADC_VIM:
10212 case RISCV::VMERGE_VIM:
10213 case RISCV::VSM4K_VI: {
10214 switch (OpNum) {
10215 case 0:
10216 // op: vd
10217 return 7;
10218 case 1:
10219 // op: vs2
10220 return 20;
10221 case 2:
10222 // op: imm
10223 return 15;
10224 }
10225 break;
10226 }
10227 case RISCV::VADC_VXM:
10228 case RISCV::VFMERGE_VFM:
10229 case RISCV::VMADC_VX:
10230 case RISCV::VMADC_VXM:
10231 case RISCV::VMERGE_VXM:
10232 case RISCV::VMSBC_VX:
10233 case RISCV::VMSBC_VXM:
10234 case RISCV::VSBC_VXM: {
10235 switch (OpNum) {
10236 case 0:
10237 // op: vd
10238 return 7;
10239 case 1:
10240 // op: vs2
10241 return 20;
10242 case 2:
10243 // op: rs1
10244 return 15;
10245 }
10246 break;
10247 }
10248 case RISCV::VADC_VVM:
10249 case RISCV::VCOMPRESS_VM:
10250 case RISCV::VMADC_VV:
10251 case RISCV::VMADC_VVM:
10252 case RISCV::VMANDN_MM:
10253 case RISCV::VMAND_MM:
10254 case RISCV::VMERGE_VVM:
10255 case RISCV::VMNAND_MM:
10256 case RISCV::VMNOR_MM:
10257 case RISCV::VMORN_MM:
10258 case RISCV::VMOR_MM:
10259 case RISCV::VMSBC_VV:
10260 case RISCV::VMSBC_VVM:
10261 case RISCV::VMXNOR_MM:
10262 case RISCV::VMXOR_MM:
10263 case RISCV::VSBC_VVM:
10264 case RISCV::VSM3ME_VV: {
10265 switch (OpNum) {
10266 case 0:
10267 // op: vd
10268 return 7;
10269 case 1:
10270 // op: vs2
10271 return 20;
10272 case 2:
10273 // op: vs1
10274 return 15;
10275 }
10276 break;
10277 }
10278 case RISCV::VMV1R_V:
10279 case RISCV::VMV2R_V:
10280 case RISCV::VMV4R_V:
10281 case RISCV::VMV8R_V: {
10282 switch (OpNum) {
10283 case 0:
10284 // op: vd
10285 return 7;
10286 case 1:
10287 // op: vs2
10288 return 20;
10289 }
10290 break;
10291 }
10292 case RISCV::SF_VFEXPA_V:
10293 case RISCV::SF_VFEXP_V:
10294 case RISCV::VABS_V:
10295 case RISCV::VBREV8_V:
10296 case RISCV::VBREV_V:
10297 case RISCV::VCLZ_V:
10298 case RISCV::VCPOP_V:
10299 case RISCV::VCTZ_V:
10300 case RISCV::VFCLASS_V:
10301 case RISCV::VFCVT_F_XU_V:
10302 case RISCV::VFCVT_F_X_V:
10303 case RISCV::VFCVT_RTZ_XU_F_V:
10304 case RISCV::VFCVT_RTZ_X_F_V:
10305 case RISCV::VFCVT_XU_F_V:
10306 case RISCV::VFCVT_X_F_V:
10307 case RISCV::VFNCVTBF16_F_F_W:
10308 case RISCV::VFNCVTBF16_SAT_F_F_W:
10309 case RISCV::VFNCVT_F_F_Q:
10310 case RISCV::VFNCVT_F_F_W:
10311 case RISCV::VFNCVT_F_XU_W:
10312 case RISCV::VFNCVT_F_X_W:
10313 case RISCV::VFNCVT_ROD_F_F_W:
10314 case RISCV::VFNCVT_RTZ_XU_F_W:
10315 case RISCV::VFNCVT_RTZ_X_F_W:
10316 case RISCV::VFNCVT_SAT_F_F_Q:
10317 case RISCV::VFNCVT_XU_F_W:
10318 case RISCV::VFNCVT_X_F_W:
10319 case RISCV::VFREC7_V:
10320 case RISCV::VFRSQRT7_V:
10321 case RISCV::VFSQRT_V:
10322 case RISCV::VFWCVTBF16_F_F_V:
10323 case RISCV::VFWCVT_F_F_V:
10324 case RISCV::VFWCVT_F_XU_V:
10325 case RISCV::VFWCVT_F_X_V:
10326 case RISCV::VFWCVT_RTZ_XU_F_V:
10327 case RISCV::VFWCVT_RTZ_X_F_V:
10328 case RISCV::VFWCVT_XU_F_V:
10329 case RISCV::VFWCVT_X_F_V:
10330 case RISCV::VIOTA_M:
10331 case RISCV::VMSBF_M:
10332 case RISCV::VMSIF_M:
10333 case RISCV::VMSOF_M:
10334 case RISCV::VREV8_V:
10335 case RISCV::VSEXT_VF2:
10336 case RISCV::VSEXT_VF4:
10337 case RISCV::VSEXT_VF8:
10338 case RISCV::VUNZIPE_V:
10339 case RISCV::VUNZIPO_V:
10340 case RISCV::VZEXT_VF2:
10341 case RISCV::VZEXT_VF4:
10342 case RISCV::VZEXT_VF8: {
10343 switch (OpNum) {
10344 case 0:
10345 // op: vd
10346 return 7;
10347 case 2:
10348 // op: vm
10349 return 25;
10350 case 1:
10351 // op: vs2
10352 return 20;
10353 }
10354 break;
10355 }
10356 case RISCV::VADD_VI:
10357 case RISCV::VAND_VI:
10358 case RISCV::VMSEQ_VI:
10359 case RISCV::VMSGTU_VI:
10360 case RISCV::VMSGT_VI:
10361 case RISCV::VMSLEU_VI:
10362 case RISCV::VMSLE_VI:
10363 case RISCV::VMSNE_VI:
10364 case RISCV::VNCLIPU_WI:
10365 case RISCV::VNCLIP_WI:
10366 case RISCV::VNSRA_WI:
10367 case RISCV::VNSRL_WI:
10368 case RISCV::VOR_VI:
10369 case RISCV::VRGATHER_VI:
10370 case RISCV::VROR_VI:
10371 case RISCV::VRSUB_VI:
10372 case RISCV::VSADDU_VI:
10373 case RISCV::VSADD_VI:
10374 case RISCV::VSLIDEDOWN_VI:
10375 case RISCV::VSLIDEUP_VI:
10376 case RISCV::VSLL_VI:
10377 case RISCV::VSRA_VI:
10378 case RISCV::VSRL_VI:
10379 case RISCV::VSSRA_VI:
10380 case RISCV::VSSRL_VI:
10381 case RISCV::VWSLL_VI:
10382 case RISCV::VXOR_VI: {
10383 switch (OpNum) {
10384 case 0:
10385 // op: vd
10386 return 7;
10387 case 3:
10388 // op: vm
10389 return 25;
10390 case 1:
10391 // op: vs2
10392 return 20;
10393 case 2:
10394 // op: imm
10395 return 15;
10396 }
10397 break;
10398 }
10399 case RISCV::SF_VFNRCLIP_XU_F_QF:
10400 case RISCV::SF_VFNRCLIP_X_F_QF:
10401 case RISCV::VAADDU_VX:
10402 case RISCV::VAADD_VX:
10403 case RISCV::VADD_VX:
10404 case RISCV::VANDN_VX:
10405 case RISCV::VAND_VX:
10406 case RISCV::VASUBU_VX:
10407 case RISCV::VASUB_VX:
10408 case RISCV::VCLMULH_VX:
10409 case RISCV::VCLMUL_VX:
10410 case RISCV::VDIVU_VX:
10411 case RISCV::VDIV_VX:
10412 case RISCV::VFADD_VF:
10413 case RISCV::VFDIV_VF:
10414 case RISCV::VFMAX_VF:
10415 case RISCV::VFMIN_VF:
10416 case RISCV::VFMUL_VF:
10417 case RISCV::VFRDIV_VF:
10418 case RISCV::VFRSUB_VF:
10419 case RISCV::VFSGNJN_VF:
10420 case RISCV::VFSGNJX_VF:
10421 case RISCV::VFSGNJ_VF:
10422 case RISCV::VFSLIDE1DOWN_VF:
10423 case RISCV::VFSLIDE1UP_VF:
10424 case RISCV::VFSUB_VF:
10425 case RISCV::VFWADD_VF:
10426 case RISCV::VFWADD_WF:
10427 case RISCV::VFWMUL_VF:
10428 case RISCV::VFWSUB_VF:
10429 case RISCV::VFWSUB_WF:
10430 case RISCV::VMAXU_VX:
10431 case RISCV::VMAX_VX:
10432 case RISCV::VMFEQ_VF:
10433 case RISCV::VMFGE_VF:
10434 case RISCV::VMFGT_VF:
10435 case RISCV::VMFLE_VF:
10436 case RISCV::VMFLT_VF:
10437 case RISCV::VMFNE_VF:
10438 case RISCV::VMINU_VX:
10439 case RISCV::VMIN_VX:
10440 case RISCV::VMSEQ_VX:
10441 case RISCV::VMSGTU_VX:
10442 case RISCV::VMSGT_VX:
10443 case RISCV::VMSLEU_VX:
10444 case RISCV::VMSLE_VX:
10445 case RISCV::VMSLTU_VX:
10446 case RISCV::VMSLT_VX:
10447 case RISCV::VMSNE_VX:
10448 case RISCV::VMULHSU_VX:
10449 case RISCV::VMULHU_VX:
10450 case RISCV::VMULH_VX:
10451 case RISCV::VMUL_VX:
10452 case RISCV::VNCLIPU_WX:
10453 case RISCV::VNCLIP_WX:
10454 case RISCV::VNSRA_WX:
10455 case RISCV::VNSRL_WX:
10456 case RISCV::VOR_VX:
10457 case RISCV::VREMU_VX:
10458 case RISCV::VREM_VX:
10459 case RISCV::VRGATHER_VX:
10460 case RISCV::VROL_VX:
10461 case RISCV::VROR_VX:
10462 case RISCV::VRSUB_VX:
10463 case RISCV::VSADDU_VX:
10464 case RISCV::VSADD_VX:
10465 case RISCV::VSLIDE1DOWN_VX:
10466 case RISCV::VSLIDE1UP_VX:
10467 case RISCV::VSLIDEDOWN_VX:
10468 case RISCV::VSLIDEUP_VX:
10469 case RISCV::VSLL_VX:
10470 case RISCV::VSMUL_VX:
10471 case RISCV::VSRA_VX:
10472 case RISCV::VSRL_VX:
10473 case RISCV::VSSRA_VX:
10474 case RISCV::VSSRL_VX:
10475 case RISCV::VSSUBU_VX:
10476 case RISCV::VSSUB_VX:
10477 case RISCV::VSUB_VX:
10478 case RISCV::VWADDU_VX:
10479 case RISCV::VWADDU_WX:
10480 case RISCV::VWADD_VX:
10481 case RISCV::VWADD_WX:
10482 case RISCV::VWMULSU_VX:
10483 case RISCV::VWMULU_VX:
10484 case RISCV::VWMUL_VX:
10485 case RISCV::VWSLL_VX:
10486 case RISCV::VWSUBU_VX:
10487 case RISCV::VWSUBU_WX:
10488 case RISCV::VWSUB_VX:
10489 case RISCV::VWSUB_WX:
10490 case RISCV::VXOR_VX: {
10491 switch (OpNum) {
10492 case 0:
10493 // op: vd
10494 return 7;
10495 case 3:
10496 // op: vm
10497 return 25;
10498 case 1:
10499 // op: vs2
10500 return 20;
10501 case 2:
10502 // op: rs1
10503 return 15;
10504 }
10505 break;
10506 }
10507 case RISCV::RI_VUNZIP2A_VV:
10508 case RISCV::RI_VUNZIP2B_VV:
10509 case RISCV::RI_VZIP2A_VV:
10510 case RISCV::RI_VZIP2B_VV:
10511 case RISCV::RI_VZIPEVEN_VV:
10512 case RISCV::RI_VZIPODD_VV:
10513 case RISCV::VAADDU_VV:
10514 case RISCV::VAADD_VV:
10515 case RISCV::VABDU_VV:
10516 case RISCV::VABD_VV:
10517 case RISCV::VADD_VV:
10518 case RISCV::VANDN_VV:
10519 case RISCV::VAND_VV:
10520 case RISCV::VASUBU_VV:
10521 case RISCV::VASUB_VV:
10522 case RISCV::VCLMULH_VV:
10523 case RISCV::VCLMUL_VV:
10524 case RISCV::VDIVU_VV:
10525 case RISCV::VDIV_VV:
10526 case RISCV::VFADD_VV:
10527 case RISCV::VFDIV_VV:
10528 case RISCV::VFMAX_VV:
10529 case RISCV::VFMIN_VV:
10530 case RISCV::VFMUL_VV:
10531 case RISCV::VFREDMAX_VS:
10532 case RISCV::VFREDMIN_VS:
10533 case RISCV::VFREDOSUM_VS:
10534 case RISCV::VFREDUSUM_VS:
10535 case RISCV::VFSGNJN_VV:
10536 case RISCV::VFSGNJX_VV:
10537 case RISCV::VFSGNJ_VV:
10538 case RISCV::VFSUB_VV:
10539 case RISCV::VFWADD_VV:
10540 case RISCV::VFWADD_WV:
10541 case RISCV::VFWMUL_VV:
10542 case RISCV::VFWREDOSUM_VS:
10543 case RISCV::VFWREDUSUM_VS:
10544 case RISCV::VFWSUB_VV:
10545 case RISCV::VFWSUB_WV:
10546 case RISCV::VMAXU_VV:
10547 case RISCV::VMAX_VV:
10548 case RISCV::VMFEQ_VV:
10549 case RISCV::VMFLE_VV:
10550 case RISCV::VMFLT_VV:
10551 case RISCV::VMFNE_VV:
10552 case RISCV::VMINU_VV:
10553 case RISCV::VMIN_VV:
10554 case RISCV::VMSEQ_VV:
10555 case RISCV::VMSLEU_VV:
10556 case RISCV::VMSLE_VV:
10557 case RISCV::VMSLTU_VV:
10558 case RISCV::VMSLT_VV:
10559 case RISCV::VMSNE_VV:
10560 case RISCV::VMULHSU_VV:
10561 case RISCV::VMULHU_VV:
10562 case RISCV::VMULH_VV:
10563 case RISCV::VMUL_VV:
10564 case RISCV::VNCLIPU_WV:
10565 case RISCV::VNCLIP_WV:
10566 case RISCV::VNSRA_WV:
10567 case RISCV::VNSRL_WV:
10568 case RISCV::VOR_VV:
10569 case RISCV::VPAIRE_VV:
10570 case RISCV::VPAIRO_VV:
10571 case RISCV::VREDAND_VS:
10572 case RISCV::VREDMAXU_VS:
10573 case RISCV::VREDMAX_VS:
10574 case RISCV::VREDMINU_VS:
10575 case RISCV::VREDMIN_VS:
10576 case RISCV::VREDOR_VS:
10577 case RISCV::VREDSUM_VS:
10578 case RISCV::VREDXOR_VS:
10579 case RISCV::VREMU_VV:
10580 case RISCV::VREM_VV:
10581 case RISCV::VRGATHEREI16_VV:
10582 case RISCV::VRGATHER_VV:
10583 case RISCV::VROL_VV:
10584 case RISCV::VROR_VV:
10585 case RISCV::VSADDU_VV:
10586 case RISCV::VSADD_VV:
10587 case RISCV::VSLL_VV:
10588 case RISCV::VSMUL_VV:
10589 case RISCV::VSRA_VV:
10590 case RISCV::VSRL_VV:
10591 case RISCV::VSSRA_VV:
10592 case RISCV::VSSRL_VV:
10593 case RISCV::VSSUBU_VV:
10594 case RISCV::VSSUB_VV:
10595 case RISCV::VSUB_VV:
10596 case RISCV::VWABDAU_VV:
10597 case RISCV::VWABDA_VV:
10598 case RISCV::VWADDU_VV:
10599 case RISCV::VWADDU_WV:
10600 case RISCV::VWADD_VV:
10601 case RISCV::VWADD_WV:
10602 case RISCV::VWMULSU_VV:
10603 case RISCV::VWMULU_VV:
10604 case RISCV::VWMUL_VV:
10605 case RISCV::VWREDSUMU_VS:
10606 case RISCV::VWREDSUM_VS:
10607 case RISCV::VWSLL_VV:
10608 case RISCV::VWSUBU_VV:
10609 case RISCV::VWSUBU_WV:
10610 case RISCV::VWSUB_VV:
10611 case RISCV::VWSUB_WV:
10612 case RISCV::VXOR_VV:
10613 case RISCV::VZIP_VV: {
10614 switch (OpNum) {
10615 case 0:
10616 // op: vd
10617 return 7;
10618 case 3:
10619 // op: vm
10620 return 25;
10621 case 1:
10622 // op: vs2
10623 return 20;
10624 case 2:
10625 // op: vs1
10626 return 15;
10627 }
10628 break;
10629 }
10630 case RISCV::C_LI:
10631 case RISCV::C_LUI: {
10632 switch (OpNum) {
10633 case 1:
10634 // op: imm
10635 return 2;
10636 case 0:
10637 // op: rd
10638 return 7;
10639 }
10640 break;
10641 }
10642 case RISCV::C_BEQZ:
10643 case RISCV::C_BNEZ: {
10644 switch (OpNum) {
10645 case 1:
10646 // op: imm
10647 return 2;
10648 case 0:
10649 // op: rs1
10650 return 7;
10651 }
10652 break;
10653 }
10654 case RISCV::PREFETCH_I:
10655 case RISCV::PREFETCH_R:
10656 case RISCV::PREFETCH_W: {
10657 switch (OpNum) {
10658 case 1:
10659 // op: imm12
10660 return 25;
10661 case 0:
10662 // op: rs1
10663 return 15;
10664 }
10665 break;
10666 }
10667 case RISCV::AIF_FSQ2:
10668 case RISCV::AIF_FSW_PS: {
10669 switch (OpNum) {
10670 case 1:
10671 // op: imm12
10672 return 7;
10673 case 0:
10674 // op: rs2
10675 return 20;
10676 case 2:
10677 // op: rs1
10678 return 15;
10679 }
10680 break;
10681 }
10682 case RISCV::NDS_LDGP:
10683 case RISCV::NDS_LHGP:
10684 case RISCV::NDS_LHUGP:
10685 case RISCV::NDS_LWGP:
10686 case RISCV::NDS_LWUGP: {
10687 switch (OpNum) {
10688 case 1:
10689 // op: imm17
10690 return 15;
10691 case 0:
10692 // op: rd
10693 return 7;
10694 }
10695 break;
10696 }
10697 case RISCV::NDS_SDGP:
10698 case RISCV::NDS_SHGP:
10699 case RISCV::NDS_SWGP: {
10700 switch (OpNum) {
10701 case 1:
10702 // op: imm17
10703 return 7;
10704 case 0:
10705 // op: rs2
10706 return 20;
10707 }
10708 break;
10709 }
10710 case RISCV::NDS_ADDIGP:
10711 case RISCV::NDS_LBGP:
10712 case RISCV::NDS_LBUGP: {
10713 switch (OpNum) {
10714 case 1:
10715 // op: imm18
10716 return 14;
10717 case 0:
10718 // op: rd
10719 return 7;
10720 }
10721 break;
10722 }
10723 case RISCV::NDS_SBGP: {
10724 switch (OpNum) {
10725 case 1:
10726 // op: imm18
10727 return 7;
10728 case 0:
10729 // op: rs2
10730 return 20;
10731 }
10732 break;
10733 }
10734 case RISCV::AIF_FBCI_PI:
10735 case RISCV::AIF_FBCI_PS:
10736 case RISCV::AUIPC:
10737 case RISCV::JAL:
10738 case RISCV::LUI:
10739 case RISCV::QC_LI: {
10740 switch (OpNum) {
10741 case 1:
10742 // op: imm20
10743 return 12;
10744 case 0:
10745 // op: rd
10746 return 7;
10747 }
10748 break;
10749 }
10750 case RISCV::MIPS_PREF: {
10751 switch (OpNum) {
10752 case 1:
10753 // op: imm9
10754 return 20;
10755 case 0:
10756 // op: rs1
10757 return 15;
10758 case 2:
10759 // op: hint
10760 return 7;
10761 }
10762 break;
10763 }
10764 case RISCV::InsnQC_EAI: {
10765 switch (OpNum) {
10766 case 1:
10767 // op: opcode
10768 return 0;
10769 case 2:
10770 // op: func3
10771 return 12;
10772 case 3:
10773 // op: func1
10774 return 15;
10775 case 0:
10776 // op: rd
10777 return 7;
10778 case 4:
10779 // op: imm32
10780 return 16;
10781 }
10782 break;
10783 }
10784 case RISCV::InsnQC_EI:
10785 case RISCV::InsnQC_EI_Mem: {
10786 switch (OpNum) {
10787 case 1:
10788 // op: opcode
10789 return 0;
10790 case 2:
10791 // op: func3
10792 return 12;
10793 case 3:
10794 // op: func2
10795 return 30;
10796 case 0:
10797 // op: rd
10798 return 7;
10799 case 4:
10800 // op: rs1
10801 return 15;
10802 case 5:
10803 // op: imm26
10804 return 20;
10805 }
10806 break;
10807 }
10808 case RISCV::InsnI:
10809 case RISCV::InsnI_Mem: {
10810 switch (OpNum) {
10811 case 1:
10812 // op: opcode
10813 return 0;
10814 case 2:
10815 // op: funct3
10816 return 12;
10817 case 4:
10818 // op: imm12
10819 return 20;
10820 case 3:
10821 // op: rs1
10822 return 15;
10823 case 0:
10824 // op: rd
10825 return 7;
10826 }
10827 break;
10828 }
10829 case RISCV::InsnCI: {
10830 switch (OpNum) {
10831 case 1:
10832 // op: opcode
10833 return 0;
10834 case 2:
10835 // op: funct3
10836 return 13;
10837 case 3:
10838 // op: imm6
10839 return 2;
10840 case 0:
10841 // op: rd
10842 return 7;
10843 }
10844 break;
10845 }
10846 case RISCV::InsnCIW: {
10847 switch (OpNum) {
10848 case 1:
10849 // op: opcode
10850 return 0;
10851 case 2:
10852 // op: funct3
10853 return 13;
10854 case 3:
10855 // op: imm8
10856 return 5;
10857 case 0:
10858 // op: rd
10859 return 2;
10860 }
10861 break;
10862 }
10863 case RISCV::InsnCL: {
10864 switch (OpNum) {
10865 case 1:
10866 // op: opcode
10867 return 0;
10868 case 2:
10869 // op: funct3
10870 return 13;
10871 case 4:
10872 // op: imm5
10873 return 5;
10874 case 0:
10875 // op: rd
10876 return 2;
10877 case 3:
10878 // op: rs1
10879 return 7;
10880 }
10881 break;
10882 }
10883 case RISCV::InsnCR: {
10884 switch (OpNum) {
10885 case 1:
10886 // op: opcode
10887 return 0;
10888 case 2:
10889 // op: funct4
10890 return 12;
10891 case 3:
10892 // op: rs2
10893 return 2;
10894 case 0:
10895 // op: rd
10896 return 7;
10897 }
10898 break;
10899 }
10900 case RISCV::InsnCA: {
10901 switch (OpNum) {
10902 case 1:
10903 // op: opcode
10904 return 0;
10905 case 2:
10906 // op: funct6
10907 return 10;
10908 case 3:
10909 // op: funct2
10910 return 5;
10911 case 0:
10912 // op: rd
10913 return 7;
10914 case 4:
10915 // op: rs2
10916 return 2;
10917 }
10918 break;
10919 }
10920 case RISCV::InsnJ:
10921 case RISCV::InsnU: {
10922 switch (OpNum) {
10923 case 1:
10924 // op: opcode
10925 return 0;
10926 case 2:
10927 // op: imm20
10928 return 12;
10929 case 0:
10930 // op: rd
10931 return 7;
10932 }
10933 break;
10934 }
10935 case RISCV::InsnR4: {
10936 switch (OpNum) {
10937 case 1:
10938 // op: opcode
10939 return 0;
10940 case 3:
10941 // op: funct2
10942 return 25;
10943 case 2:
10944 // op: funct3
10945 return 12;
10946 case 6:
10947 // op: rs3
10948 return 27;
10949 case 5:
10950 // op: rs2
10951 return 20;
10952 case 4:
10953 // op: rs1
10954 return 15;
10955 case 0:
10956 // op: rd
10957 return 7;
10958 }
10959 break;
10960 }
10961 case RISCV::InsnR: {
10962 switch (OpNum) {
10963 case 1:
10964 // op: opcode
10965 return 0;
10966 case 3:
10967 // op: funct7
10968 return 25;
10969 case 2:
10970 // op: funct3
10971 return 12;
10972 case 5:
10973 // op: rs2
10974 return 20;
10975 case 4:
10976 // op: rs1
10977 return 15;
10978 case 0:
10979 // op: rd
10980 return 7;
10981 }
10982 break;
10983 }
10984 case RISCV::QC_C_MULIADD: {
10985 switch (OpNum) {
10986 case 1:
10987 // op: rd
10988 return 2;
10989 case 2:
10990 // op: rs1
10991 return 7;
10992 case 3:
10993 // op: uimm
10994 return 5;
10995 }
10996 break;
10997 }
10998 case RISCV::QC_C_MVEQZ: {
10999 switch (OpNum) {
11000 case 1:
11001 // op: rd
11002 return 2;
11003 case 2:
11004 // op: rs1
11005 return 7;
11006 }
11007 break;
11008 }
11009 case RISCV::QC_E_ADDAI:
11010 case RISCV::QC_E_ANDAI:
11011 case RISCV::QC_E_ORAI:
11012 case RISCV::QC_E_XORAI: {
11013 switch (OpNum) {
11014 case 1:
11015 // op: rd
11016 return 7;
11017 case 2:
11018 // op: imm
11019 return 16;
11020 }
11021 break;
11022 }
11023 case RISCV::QC_INSBI: {
11024 switch (OpNum) {
11025 case 1:
11026 // op: rd
11027 return 7;
11028 case 2:
11029 // op: imm5
11030 return 15;
11031 case 4:
11032 // op: shamt
11033 return 20;
11034 case 3:
11035 // op: width
11036 return 25;
11037 }
11038 break;
11039 }
11040 case RISCV::QC_C_EXTU: {
11041 switch (OpNum) {
11042 case 1:
11043 // op: rd
11044 return 7;
11045 case 2:
11046 // op: width
11047 return 2;
11048 }
11049 break;
11050 }
11051 case RISCV::C_NOT:
11052 case RISCV::C_SEXT_B:
11053 case RISCV::C_SEXT_H:
11054 case RISCV::C_ZEXT_B:
11055 case RISCV::C_ZEXT_H:
11056 case RISCV::C_ZEXT_W: {
11057 switch (OpNum) {
11058 case 1:
11059 // op: rd
11060 return 7;
11061 }
11062 break;
11063 }
11064 case RISCV::QC_WRAPI: {
11065 switch (OpNum) {
11066 case 1:
11067 // op: rs1
11068 return 15;
11069 case 0:
11070 // op: rd
11071 return 7;
11072 case 2:
11073 // op: imm11
11074 return 20;
11075 }
11076 break;
11077 }
11078 case RISCV::ADDI:
11079 case RISCV::ADDIW:
11080 case RISCV::ANDI:
11081 case RISCV::CV_ELW:
11082 case RISCV::FLD:
11083 case RISCV::FLH:
11084 case RISCV::FLQ:
11085 case RISCV::FLW:
11086 case RISCV::JALR:
11087 case RISCV::LB:
11088 case RISCV::LBU:
11089 case RISCV::LD:
11090 case RISCV::LD_RV32:
11091 case RISCV::LH:
11092 case RISCV::LHU:
11093 case RISCV::LH_INX:
11094 case RISCV::LW:
11095 case RISCV::LWU:
11096 case RISCV::LW_INX:
11097 case RISCV::ORI:
11098 case RISCV::SLTI:
11099 case RISCV::SLTIU:
11100 case RISCV::XORI: {
11101 switch (OpNum) {
11102 case 1:
11103 // op: rs1
11104 return 15;
11105 case 0:
11106 // op: rd
11107 return 7;
11108 case 2:
11109 // op: imm12
11110 return 20;
11111 }
11112 break;
11113 }
11114 case RISCV::QC_INW: {
11115 switch (OpNum) {
11116 case 1:
11117 // op: rs1
11118 return 15;
11119 case 0:
11120 // op: rd
11121 return 7;
11122 case 2:
11123 // op: imm14
11124 return 20;
11125 }
11126 break;
11127 }
11128 case RISCV::CV_CLIP:
11129 case RISCV::CV_CLIPU: {
11130 switch (OpNum) {
11131 case 1:
11132 // op: rs1
11133 return 15;
11134 case 0:
11135 // op: rd
11136 return 7;
11137 case 2:
11138 // op: imm5
11139 return 20;
11140 }
11141 break;
11142 }
11143 case RISCV::CV_ADD_SCI_B:
11144 case RISCV::CV_ADD_SCI_H:
11145 case RISCV::CV_AND_SCI_B:
11146 case RISCV::CV_AND_SCI_H:
11147 case RISCV::CV_AVGU_SCI_B:
11148 case RISCV::CV_AVGU_SCI_H:
11149 case RISCV::CV_AVG_SCI_B:
11150 case RISCV::CV_AVG_SCI_H:
11151 case RISCV::CV_CMPEQ_SCI_B:
11152 case RISCV::CV_CMPEQ_SCI_H:
11153 case RISCV::CV_CMPGEU_SCI_B:
11154 case RISCV::CV_CMPGEU_SCI_H:
11155 case RISCV::CV_CMPGE_SCI_B:
11156 case RISCV::CV_CMPGE_SCI_H:
11157 case RISCV::CV_CMPGTU_SCI_B:
11158 case RISCV::CV_CMPGTU_SCI_H:
11159 case RISCV::CV_CMPGT_SCI_B:
11160 case RISCV::CV_CMPGT_SCI_H:
11161 case RISCV::CV_CMPLEU_SCI_B:
11162 case RISCV::CV_CMPLEU_SCI_H:
11163 case RISCV::CV_CMPLE_SCI_B:
11164 case RISCV::CV_CMPLE_SCI_H:
11165 case RISCV::CV_CMPLTU_SCI_B:
11166 case RISCV::CV_CMPLTU_SCI_H:
11167 case RISCV::CV_CMPLT_SCI_B:
11168 case RISCV::CV_CMPLT_SCI_H:
11169 case RISCV::CV_CMPNE_SCI_B:
11170 case RISCV::CV_CMPNE_SCI_H:
11171 case RISCV::CV_DOTSP_SCI_B:
11172 case RISCV::CV_DOTSP_SCI_H:
11173 case RISCV::CV_DOTUP_SCI_B:
11174 case RISCV::CV_DOTUP_SCI_H:
11175 case RISCV::CV_DOTUSP_SCI_B:
11176 case RISCV::CV_DOTUSP_SCI_H:
11177 case RISCV::CV_EXTRACTU_B:
11178 case RISCV::CV_EXTRACTU_H:
11179 case RISCV::CV_EXTRACT_B:
11180 case RISCV::CV_EXTRACT_H:
11181 case RISCV::CV_MAXU_SCI_B:
11182 case RISCV::CV_MAXU_SCI_H:
11183 case RISCV::CV_MAX_SCI_B:
11184 case RISCV::CV_MAX_SCI_H:
11185 case RISCV::CV_MINU_SCI_B:
11186 case RISCV::CV_MINU_SCI_H:
11187 case RISCV::CV_MIN_SCI_B:
11188 case RISCV::CV_MIN_SCI_H:
11189 case RISCV::CV_OR_SCI_B:
11190 case RISCV::CV_OR_SCI_H:
11191 case RISCV::CV_SHUFFLEI0_SCI_B:
11192 case RISCV::CV_SHUFFLEI1_SCI_B:
11193 case RISCV::CV_SHUFFLEI2_SCI_B:
11194 case RISCV::CV_SHUFFLEI3_SCI_B:
11195 case RISCV::CV_SHUFFLE_SCI_H:
11196 case RISCV::CV_SLL_SCI_B:
11197 case RISCV::CV_SLL_SCI_H:
11198 case RISCV::CV_SRA_SCI_B:
11199 case RISCV::CV_SRA_SCI_H:
11200 case RISCV::CV_SRL_SCI_B:
11201 case RISCV::CV_SRL_SCI_H:
11202 case RISCV::CV_SUB_SCI_B:
11203 case RISCV::CV_SUB_SCI_H:
11204 case RISCV::CV_XOR_SCI_B:
11205 case RISCV::CV_XOR_SCI_H: {
11206 switch (OpNum) {
11207 case 1:
11208 // op: rs1
11209 return 15;
11210 case 0:
11211 // op: rd
11212 return 7;
11213 case 2:
11214 // op: imm6
11215 return 20;
11216 }
11217 break;
11218 }
11219 case RISCV::CV_BCLR:
11220 case RISCV::CV_BITREV:
11221 case RISCV::CV_BSET:
11222 case RISCV::CV_EXTRACT:
11223 case RISCV::CV_EXTRACTU: {
11224 switch (OpNum) {
11225 case 1:
11226 // op: rs1
11227 return 15;
11228 case 0:
11229 // op: rd
11230 return 7;
11231 case 2:
11232 // op: is3
11233 return 25;
11234 case 3:
11235 // op: is2
11236 return 20;
11237 }
11238 break;
11239 }
11240 case RISCV::TH_EXT:
11241 case RISCV::TH_EXTU: {
11242 switch (OpNum) {
11243 case 1:
11244 // op: rs1
11245 return 15;
11246 case 0:
11247 // op: rd
11248 return 7;
11249 case 2:
11250 // op: msb
11251 return 26;
11252 case 3:
11253 // op: lsb
11254 return 20;
11255 }
11256 break;
11257 }
11258 case RISCV::AES64KS1I: {
11259 switch (OpNum) {
11260 case 1:
11261 // op: rs1
11262 return 15;
11263 case 0:
11264 // op: rd
11265 return 7;
11266 case 2:
11267 // op: rnum
11268 return 20;
11269 }
11270 break;
11271 }
11272 case RISCV::BCLRI:
11273 case RISCV::BEXTI:
11274 case RISCV::BINVI:
11275 case RISCV::BSETI:
11276 case RISCV::PSATI_H:
11277 case RISCV::PSATI_W:
11278 case RISCV::PSLLI_B:
11279 case RISCV::PSLLI_H:
11280 case RISCV::PSLLI_W:
11281 case RISCV::PSRAI_B:
11282 case RISCV::PSRAI_H:
11283 case RISCV::PSRAI_W:
11284 case RISCV::PSRARI_H:
11285 case RISCV::PSRARI_W:
11286 case RISCV::PSRLI_B:
11287 case RISCV::PSRLI_H:
11288 case RISCV::PSRLI_W:
11289 case RISCV::PSSLAI_H:
11290 case RISCV::PSSLAI_W:
11291 case RISCV::PUSATI_H:
11292 case RISCV::PUSATI_W:
11293 case RISCV::RORI:
11294 case RISCV::RORIW:
11295 case RISCV::SATI_RV32:
11296 case RISCV::SATI_RV64:
11297 case RISCV::SLLI:
11298 case RISCV::SLLIW:
11299 case RISCV::SLLI_UW:
11300 case RISCV::SRAI:
11301 case RISCV::SRAIW:
11302 case RISCV::SRARI_RV32:
11303 case RISCV::SRARI_RV64:
11304 case RISCV::SRLI:
11305 case RISCV::SRLIW:
11306 case RISCV::SSLAI:
11307 case RISCV::TH_SRRI:
11308 case RISCV::TH_SRRIW:
11309 case RISCV::TH_TST:
11310 case RISCV::USATI_RV32:
11311 case RISCV::USATI_RV64: {
11312 switch (OpNum) {
11313 case 1:
11314 // op: rs1
11315 return 15;
11316 case 0:
11317 // op: rd
11318 return 7;
11319 case 2:
11320 // op: shamt
11321 return 20;
11322 }
11323 break;
11324 }
11325 case RISCV::VSETVLI: {
11326 switch (OpNum) {
11327 case 1:
11328 // op: rs1
11329 return 15;
11330 case 0:
11331 // op: rd
11332 return 7;
11333 case 2:
11334 // op: vtypei
11335 return 20;
11336 }
11337 break;
11338 }
11339 case RISCV::QC_EXT:
11340 case RISCV::QC_EXTD:
11341 case RISCV::QC_EXTDU:
11342 case RISCV::QC_EXTU: {
11343 switch (OpNum) {
11344 case 1:
11345 // op: rs1
11346 return 15;
11347 case 0:
11348 // op: rd
11349 return 7;
11350 case 3:
11351 // op: shamt
11352 return 20;
11353 case 2:
11354 // op: width
11355 return 25;
11356 }
11357 break;
11358 }
11359 case RISCV::ABS:
11360 case RISCV::ABSW:
11361 case RISCV::AES64IM:
11362 case RISCV::AIF_FBCX_PS:
11363 case RISCV::AIF_FCLASS_PS:
11364 case RISCV::AIF_FCVT_F10_PS:
11365 case RISCV::AIF_FCVT_F11_PS:
11366 case RISCV::AIF_FCVT_F16_PS:
11367 case RISCV::AIF_FCVT_PS_F10:
11368 case RISCV::AIF_FCVT_PS_F11:
11369 case RISCV::AIF_FCVT_PS_F16:
11370 case RISCV::AIF_FCVT_PS_RAST:
11371 case RISCV::AIF_FCVT_PS_SN16:
11372 case RISCV::AIF_FCVT_PS_SN8:
11373 case RISCV::AIF_FCVT_PS_UN10:
11374 case RISCV::AIF_FCVT_PS_UN16:
11375 case RISCV::AIF_FCVT_PS_UN2:
11376 case RISCV::AIF_FCVT_PS_UN24:
11377 case RISCV::AIF_FCVT_PS_UN8:
11378 case RISCV::AIF_FCVT_RAST_PS:
11379 case RISCV::AIF_FCVT_SN16_PS:
11380 case RISCV::AIF_FCVT_SN8_PS:
11381 case RISCV::AIF_FCVT_UN10_PS:
11382 case RISCV::AIF_FCVT_UN16_PS:
11383 case RISCV::AIF_FCVT_UN24_PS:
11384 case RISCV::AIF_FCVT_UN2_PS:
11385 case RISCV::AIF_FCVT_UN8_PS:
11386 case RISCV::AIF_FEXP_PS:
11387 case RISCV::AIF_FFRC_PS:
11388 case RISCV::AIF_FLOG_PS:
11389 case RISCV::AIF_FLWG_PS:
11390 case RISCV::AIF_FLWL_PS:
11391 case RISCV::AIF_FNOT_PI:
11392 case RISCV::AIF_FPACKREPB_PI:
11393 case RISCV::AIF_FPACKREPH_PI:
11394 case RISCV::AIF_FRCP_PS:
11395 case RISCV::AIF_FRSQ_PS:
11396 case RISCV::AIF_FSAT8_PI:
11397 case RISCV::AIF_FSATU8_PI:
11398 case RISCV::AIF_FSETM_PI:
11399 case RISCV::AIF_FSIN_PS:
11400 case RISCV::AIF_FSQRT_PS:
11401 case RISCV::AIF_MASKNOT:
11402 case RISCV::AIF_MASKPOPC:
11403 case RISCV::AIF_MASKPOPCZ:
11404 case RISCV::BREV8:
11405 case RISCV::CLS:
11406 case RISCV::CLSW:
11407 case RISCV::CLZ:
11408 case RISCV::CLZW:
11409 case RISCV::CPOP:
11410 case RISCV::CPOPW:
11411 case RISCV::CTZ:
11412 case RISCV::CTZW:
11413 case RISCV::CV_ABS:
11414 case RISCV::CV_ABS_B:
11415 case RISCV::CV_ABS_H:
11416 case RISCV::CV_CLB:
11417 case RISCV::CV_CNT:
11418 case RISCV::CV_CPLXCONJ:
11419 case RISCV::CV_EXTBS:
11420 case RISCV::CV_EXTBZ:
11421 case RISCV::CV_EXTHS:
11422 case RISCV::CV_EXTHZ:
11423 case RISCV::CV_FF1:
11424 case RISCV::CV_FL1:
11425 case RISCV::FCLASS_D:
11426 case RISCV::FCLASS_D_IN32X:
11427 case RISCV::FCLASS_D_INX:
11428 case RISCV::FCLASS_H:
11429 case RISCV::FCLASS_H_INX:
11430 case RISCV::FCLASS_Q:
11431 case RISCV::FCLASS_S:
11432 case RISCV::FCLASS_S_INX:
11433 case RISCV::FCVTMOD_W_D:
11434 case RISCV::FMVH_X_D:
11435 case RISCV::FMVH_X_Q:
11436 case RISCV::FMV_D_X:
11437 case RISCV::FMV_H_X:
11438 case RISCV::FMV_W_X:
11439 case RISCV::FMV_X_D:
11440 case RISCV::FMV_X_H:
11441 case RISCV::FMV_X_W:
11442 case RISCV::FMV_X_W_FPR64:
11443 case RISCV::HLVX_HU:
11444 case RISCV::HLVX_WU:
11445 case RISCV::HLV_B:
11446 case RISCV::HLV_BU:
11447 case RISCV::HLV_D:
11448 case RISCV::HLV_H:
11449 case RISCV::HLV_HU:
11450 case RISCV::HLV_W:
11451 case RISCV::HLV_WU:
11452 case RISCV::LB_AQ:
11453 case RISCV::LB_AQRL:
11454 case RISCV::LD_AQ:
11455 case RISCV::LD_AQRL:
11456 case RISCV::LH_AQ:
11457 case RISCV::LH_AQRL:
11458 case RISCV::LR_D:
11459 case RISCV::LR_D_AQ:
11460 case RISCV::LR_D_AQRL:
11461 case RISCV::LR_D_RL:
11462 case RISCV::LR_W:
11463 case RISCV::LR_W_AQ:
11464 case RISCV::LR_W_AQRL:
11465 case RISCV::LR_W_RL:
11466 case RISCV::LW_AQ:
11467 case RISCV::LW_AQRL:
11468 case RISCV::MOP_R_0:
11469 case RISCV::MOP_R_1:
11470 case RISCV::MOP_R_10:
11471 case RISCV::MOP_R_11:
11472 case RISCV::MOP_R_12:
11473 case RISCV::MOP_R_13:
11474 case RISCV::MOP_R_14:
11475 case RISCV::MOP_R_15:
11476 case RISCV::MOP_R_16:
11477 case RISCV::MOP_R_17:
11478 case RISCV::MOP_R_18:
11479 case RISCV::MOP_R_19:
11480 case RISCV::MOP_R_2:
11481 case RISCV::MOP_R_20:
11482 case RISCV::MOP_R_21:
11483 case RISCV::MOP_R_22:
11484 case RISCV::MOP_R_23:
11485 case RISCV::MOP_R_24:
11486 case RISCV::MOP_R_25:
11487 case RISCV::MOP_R_26:
11488 case RISCV::MOP_R_27:
11489 case RISCV::MOP_R_28:
11490 case RISCV::MOP_R_29:
11491 case RISCV::MOP_R_3:
11492 case RISCV::MOP_R_30:
11493 case RISCV::MOP_R_31:
11494 case RISCV::MOP_R_4:
11495 case RISCV::MOP_R_5:
11496 case RISCV::MOP_R_6:
11497 case RISCV::MOP_R_7:
11498 case RISCV::MOP_R_8:
11499 case RISCV::MOP_R_9:
11500 case RISCV::NDS_FMV_BF16_X:
11501 case RISCV::NDS_FMV_X_BF16:
11502 case RISCV::ORC_B:
11503 case RISCV::PSABS_B:
11504 case RISCV::PSABS_H:
11505 case RISCV::PSEXT_H_B:
11506 case RISCV::PSEXT_W_B:
11507 case RISCV::PSEXT_W_H:
11508 case RISCV::QC_BREV32:
11509 case RISCV::QC_CLO:
11510 case RISCV::QC_COMPRESS2:
11511 case RISCV::QC_COMPRESS3:
11512 case RISCV::QC_CTO:
11513 case RISCV::QC_EXPAND2:
11514 case RISCV::QC_EXPAND3:
11515 case RISCV::QC_NORM:
11516 case RISCV::QC_NORMEU:
11517 case RISCV::QC_NORMU:
11518 case RISCV::REV16:
11519 case RISCV::REV8_RV32:
11520 case RISCV::REV8_RV64:
11521 case RISCV::REV_RV32:
11522 case RISCV::REV_RV64:
11523 case RISCV::SEXT_B:
11524 case RISCV::SEXT_H:
11525 case RISCV::SF_VSETTK:
11526 case RISCV::SF_VSETTM:
11527 case RISCV::SF_VSETTN:
11528 case RISCV::SHA256SIG0:
11529 case RISCV::SHA256SIG1:
11530 case RISCV::SHA256SUM0:
11531 case RISCV::SHA256SUM1:
11532 case RISCV::SHA512SIG0:
11533 case RISCV::SHA512SIG1:
11534 case RISCV::SHA512SUM0:
11535 case RISCV::SHA512SUM1:
11536 case RISCV::SM3P0:
11537 case RISCV::SM3P1:
11538 case RISCV::TH_FF0:
11539 case RISCV::TH_FF1:
11540 case RISCV::TH_REV:
11541 case RISCV::TH_REVW:
11542 case RISCV::TH_TSTNBZ:
11543 case RISCV::UNZIP_RV32:
11544 case RISCV::ZEXT_H_RV32:
11545 case RISCV::ZEXT_H_RV64:
11546 case RISCV::ZIP_RV32: {
11547 switch (OpNum) {
11548 case 1:
11549 // op: rs1
11550 return 15;
11551 case 0:
11552 // op: rd
11553 return 7;
11554 }
11555 break;
11556 }
11557 case RISCV::PWSLAI_B:
11558 case RISCV::PWSLAI_H:
11559 case RISCV::PWSLLI_B:
11560 case RISCV::PWSLLI_H:
11561 case RISCV::WSLAI:
11562 case RISCV::WSLLI: {
11563 switch (OpNum) {
11564 case 1:
11565 // op: rs1
11566 return 15;
11567 case 0:
11568 // op: rd
11569 return 8;
11570 case 2:
11571 // op: shamt
11572 return 20;
11573 }
11574 break;
11575 }
11576 case RISCV::QC_E_SB:
11577 case RISCV::QC_E_SH:
11578 case RISCV::QC_E_SW: {
11579 switch (OpNum) {
11580 case 1:
11581 // op: rs1
11582 return 15;
11583 case 0:
11584 // op: rs2
11585 return 20;
11586 case 2:
11587 // op: imm
11588 return 7;
11589 }
11590 break;
11591 }
11592 case RISCV::CV_SB_rr:
11593 case RISCV::CV_SH_rr:
11594 case RISCV::CV_SW_rr: {
11595 switch (OpNum) {
11596 case 1:
11597 // op: rs1
11598 return 15;
11599 case 0:
11600 // op: rs2
11601 return 20;
11602 case 2:
11603 // op: rs3
11604 return 7;
11605 }
11606 break;
11607 }
11608 case RISCV::QC_OUTW: {
11609 switch (OpNum) {
11610 case 1:
11611 // op: rs1
11612 return 15;
11613 case 0:
11614 // op: rs2
11615 return 7;
11616 case 2:
11617 // op: imm14
11618 return 20;
11619 }
11620 break;
11621 }
11622 case RISCV::NDS_VLN8_V:
11623 case RISCV::NDS_VLNU8_V:
11624 case RISCV::VLE16FF_V:
11625 case RISCV::VLE16_V:
11626 case RISCV::VLE32FF_V:
11627 case RISCV::VLE32_V:
11628 case RISCV::VLE64FF_V:
11629 case RISCV::VLE64_V:
11630 case RISCV::VLE8FF_V:
11631 case RISCV::VLE8_V:
11632 case RISCV::VLSEG2E16FF_V:
11633 case RISCV::VLSEG2E16_V:
11634 case RISCV::VLSEG2E32FF_V:
11635 case RISCV::VLSEG2E32_V:
11636 case RISCV::VLSEG2E64FF_V:
11637 case RISCV::VLSEG2E64_V:
11638 case RISCV::VLSEG2E8FF_V:
11639 case RISCV::VLSEG2E8_V:
11640 case RISCV::VLSEG3E16FF_V:
11641 case RISCV::VLSEG3E16_V:
11642 case RISCV::VLSEG3E32FF_V:
11643 case RISCV::VLSEG3E32_V:
11644 case RISCV::VLSEG3E64FF_V:
11645 case RISCV::VLSEG3E64_V:
11646 case RISCV::VLSEG3E8FF_V:
11647 case RISCV::VLSEG3E8_V:
11648 case RISCV::VLSEG4E16FF_V:
11649 case RISCV::VLSEG4E16_V:
11650 case RISCV::VLSEG4E32FF_V:
11651 case RISCV::VLSEG4E32_V:
11652 case RISCV::VLSEG4E64FF_V:
11653 case RISCV::VLSEG4E64_V:
11654 case RISCV::VLSEG4E8FF_V:
11655 case RISCV::VLSEG4E8_V:
11656 case RISCV::VLSEG5E16FF_V:
11657 case RISCV::VLSEG5E16_V:
11658 case RISCV::VLSEG5E32FF_V:
11659 case RISCV::VLSEG5E32_V:
11660 case RISCV::VLSEG5E64FF_V:
11661 case RISCV::VLSEG5E64_V:
11662 case RISCV::VLSEG5E8FF_V:
11663 case RISCV::VLSEG5E8_V:
11664 case RISCV::VLSEG6E16FF_V:
11665 case RISCV::VLSEG6E16_V:
11666 case RISCV::VLSEG6E32FF_V:
11667 case RISCV::VLSEG6E32_V:
11668 case RISCV::VLSEG6E64FF_V:
11669 case RISCV::VLSEG6E64_V:
11670 case RISCV::VLSEG6E8FF_V:
11671 case RISCV::VLSEG6E8_V:
11672 case RISCV::VLSEG7E16FF_V:
11673 case RISCV::VLSEG7E16_V:
11674 case RISCV::VLSEG7E32FF_V:
11675 case RISCV::VLSEG7E32_V:
11676 case RISCV::VLSEG7E64FF_V:
11677 case RISCV::VLSEG7E64_V:
11678 case RISCV::VLSEG7E8FF_V:
11679 case RISCV::VLSEG7E8_V:
11680 case RISCV::VLSEG8E16FF_V:
11681 case RISCV::VLSEG8E16_V:
11682 case RISCV::VLSEG8E32FF_V:
11683 case RISCV::VLSEG8E32_V:
11684 case RISCV::VLSEG8E64FF_V:
11685 case RISCV::VLSEG8E64_V:
11686 case RISCV::VLSEG8E8FF_V:
11687 case RISCV::VLSEG8E8_V: {
11688 switch (OpNum) {
11689 case 1:
11690 // op: rs1
11691 return 15;
11692 case 0:
11693 // op: vd
11694 return 7;
11695 case 2:
11696 // op: vm
11697 return 25;
11698 }
11699 break;
11700 }
11701 case RISCV::VLSE16_V:
11702 case RISCV::VLSE32_V:
11703 case RISCV::VLSE64_V:
11704 case RISCV::VLSE8_V:
11705 case RISCV::VLSSEG2E16_V:
11706 case RISCV::VLSSEG2E32_V:
11707 case RISCV::VLSSEG2E64_V:
11708 case RISCV::VLSSEG2E8_V:
11709 case RISCV::VLSSEG3E16_V:
11710 case RISCV::VLSSEG3E32_V:
11711 case RISCV::VLSSEG3E64_V:
11712 case RISCV::VLSSEG3E8_V:
11713 case RISCV::VLSSEG4E16_V:
11714 case RISCV::VLSSEG4E32_V:
11715 case RISCV::VLSSEG4E64_V:
11716 case RISCV::VLSSEG4E8_V:
11717 case RISCV::VLSSEG5E16_V:
11718 case RISCV::VLSSEG5E32_V:
11719 case RISCV::VLSSEG5E64_V:
11720 case RISCV::VLSSEG5E8_V:
11721 case RISCV::VLSSEG6E16_V:
11722 case RISCV::VLSSEG6E32_V:
11723 case RISCV::VLSSEG6E64_V:
11724 case RISCV::VLSSEG6E8_V:
11725 case RISCV::VLSSEG7E16_V:
11726 case RISCV::VLSSEG7E32_V:
11727 case RISCV::VLSSEG7E64_V:
11728 case RISCV::VLSSEG7E8_V:
11729 case RISCV::VLSSEG8E16_V:
11730 case RISCV::VLSSEG8E32_V:
11731 case RISCV::VLSSEG8E64_V:
11732 case RISCV::VLSSEG8E8_V: {
11733 switch (OpNum) {
11734 case 1:
11735 // op: rs1
11736 return 15;
11737 case 0:
11738 // op: vd
11739 return 7;
11740 case 3:
11741 // op: vm
11742 return 25;
11743 case 2:
11744 // op: rs2
11745 return 20;
11746 }
11747 break;
11748 }
11749 case RISCV::VLOXEI16_V:
11750 case RISCV::VLOXEI32_V:
11751 case RISCV::VLOXEI64_V:
11752 case RISCV::VLOXEI8_V:
11753 case RISCV::VLOXSEG2EI16_V:
11754 case RISCV::VLOXSEG2EI32_V:
11755 case RISCV::VLOXSEG2EI64_V:
11756 case RISCV::VLOXSEG2EI8_V:
11757 case RISCV::VLOXSEG3EI16_V:
11758 case RISCV::VLOXSEG3EI32_V:
11759 case RISCV::VLOXSEG3EI64_V:
11760 case RISCV::VLOXSEG3EI8_V:
11761 case RISCV::VLOXSEG4EI16_V:
11762 case RISCV::VLOXSEG4EI32_V:
11763 case RISCV::VLOXSEG4EI64_V:
11764 case RISCV::VLOXSEG4EI8_V:
11765 case RISCV::VLOXSEG5EI16_V:
11766 case RISCV::VLOXSEG5EI32_V:
11767 case RISCV::VLOXSEG5EI64_V:
11768 case RISCV::VLOXSEG5EI8_V:
11769 case RISCV::VLOXSEG6EI16_V:
11770 case RISCV::VLOXSEG6EI32_V:
11771 case RISCV::VLOXSEG6EI64_V:
11772 case RISCV::VLOXSEG6EI8_V:
11773 case RISCV::VLOXSEG7EI16_V:
11774 case RISCV::VLOXSEG7EI32_V:
11775 case RISCV::VLOXSEG7EI64_V:
11776 case RISCV::VLOXSEG7EI8_V:
11777 case RISCV::VLOXSEG8EI16_V:
11778 case RISCV::VLOXSEG8EI32_V:
11779 case RISCV::VLOXSEG8EI64_V:
11780 case RISCV::VLOXSEG8EI8_V:
11781 case RISCV::VLUXEI16_V:
11782 case RISCV::VLUXEI32_V:
11783 case RISCV::VLUXEI64_V:
11784 case RISCV::VLUXEI8_V:
11785 case RISCV::VLUXSEG2EI16_V:
11786 case RISCV::VLUXSEG2EI32_V:
11787 case RISCV::VLUXSEG2EI64_V:
11788 case RISCV::VLUXSEG2EI8_V:
11789 case RISCV::VLUXSEG3EI16_V:
11790 case RISCV::VLUXSEG3EI32_V:
11791 case RISCV::VLUXSEG3EI64_V:
11792 case RISCV::VLUXSEG3EI8_V:
11793 case RISCV::VLUXSEG4EI16_V:
11794 case RISCV::VLUXSEG4EI32_V:
11795 case RISCV::VLUXSEG4EI64_V:
11796 case RISCV::VLUXSEG4EI8_V:
11797 case RISCV::VLUXSEG5EI16_V:
11798 case RISCV::VLUXSEG5EI32_V:
11799 case RISCV::VLUXSEG5EI64_V:
11800 case RISCV::VLUXSEG5EI8_V:
11801 case RISCV::VLUXSEG6EI16_V:
11802 case RISCV::VLUXSEG6EI32_V:
11803 case RISCV::VLUXSEG6EI64_V:
11804 case RISCV::VLUXSEG6EI8_V:
11805 case RISCV::VLUXSEG7EI16_V:
11806 case RISCV::VLUXSEG7EI32_V:
11807 case RISCV::VLUXSEG7EI64_V:
11808 case RISCV::VLUXSEG7EI8_V:
11809 case RISCV::VLUXSEG8EI16_V:
11810 case RISCV::VLUXSEG8EI32_V:
11811 case RISCV::VLUXSEG8EI64_V:
11812 case RISCV::VLUXSEG8EI8_V: {
11813 switch (OpNum) {
11814 case 1:
11815 // op: rs1
11816 return 15;
11817 case 0:
11818 // op: vd
11819 return 7;
11820 case 3:
11821 // op: vm
11822 return 25;
11823 case 2:
11824 // op: vs2
11825 return 20;
11826 }
11827 break;
11828 }
11829 case RISCV::NDS_VLE4_V:
11830 case RISCV::SF_VTMV_V_T:
11831 case RISCV::VL1RE16_V:
11832 case RISCV::VL1RE32_V:
11833 case RISCV::VL1RE64_V:
11834 case RISCV::VL1RE8_V:
11835 case RISCV::VL2RE16_V:
11836 case RISCV::VL2RE32_V:
11837 case RISCV::VL2RE64_V:
11838 case RISCV::VL2RE8_V:
11839 case RISCV::VL4RE16_V:
11840 case RISCV::VL4RE32_V:
11841 case RISCV::VL4RE64_V:
11842 case RISCV::VL4RE8_V:
11843 case RISCV::VL8RE16_V:
11844 case RISCV::VL8RE32_V:
11845 case RISCV::VL8RE64_V:
11846 case RISCV::VL8RE8_V:
11847 case RISCV::VLM_V: {
11848 switch (OpNum) {
11849 case 1:
11850 // op: rs1
11851 return 15;
11852 case 0:
11853 // op: vd
11854 return 7;
11855 }
11856 break;
11857 }
11858 case RISCV::VSE16_V:
11859 case RISCV::VSE32_V:
11860 case RISCV::VSE64_V:
11861 case RISCV::VSE8_V:
11862 case RISCV::VSSEG2E16_V:
11863 case RISCV::VSSEG2E32_V:
11864 case RISCV::VSSEG2E64_V:
11865 case RISCV::VSSEG2E8_V:
11866 case RISCV::VSSEG3E16_V:
11867 case RISCV::VSSEG3E32_V:
11868 case RISCV::VSSEG3E64_V:
11869 case RISCV::VSSEG3E8_V:
11870 case RISCV::VSSEG4E16_V:
11871 case RISCV::VSSEG4E32_V:
11872 case RISCV::VSSEG4E64_V:
11873 case RISCV::VSSEG4E8_V:
11874 case RISCV::VSSEG5E16_V:
11875 case RISCV::VSSEG5E32_V:
11876 case RISCV::VSSEG5E64_V:
11877 case RISCV::VSSEG5E8_V:
11878 case RISCV::VSSEG6E16_V:
11879 case RISCV::VSSEG6E32_V:
11880 case RISCV::VSSEG6E64_V:
11881 case RISCV::VSSEG6E8_V:
11882 case RISCV::VSSEG7E16_V:
11883 case RISCV::VSSEG7E32_V:
11884 case RISCV::VSSEG7E64_V:
11885 case RISCV::VSSEG7E8_V:
11886 case RISCV::VSSEG8E16_V:
11887 case RISCV::VSSEG8E32_V:
11888 case RISCV::VSSEG8E64_V:
11889 case RISCV::VSSEG8E8_V: {
11890 switch (OpNum) {
11891 case 1:
11892 // op: rs1
11893 return 15;
11894 case 0:
11895 // op: vs3
11896 return 7;
11897 case 2:
11898 // op: vm
11899 return 25;
11900 }
11901 break;
11902 }
11903 case RISCV::VSSE16_V:
11904 case RISCV::VSSE32_V:
11905 case RISCV::VSSE64_V:
11906 case RISCV::VSSE8_V:
11907 case RISCV::VSSSEG2E16_V:
11908 case RISCV::VSSSEG2E32_V:
11909 case RISCV::VSSSEG2E64_V:
11910 case RISCV::VSSSEG2E8_V:
11911 case RISCV::VSSSEG3E16_V:
11912 case RISCV::VSSSEG3E32_V:
11913 case RISCV::VSSSEG3E64_V:
11914 case RISCV::VSSSEG3E8_V:
11915 case RISCV::VSSSEG4E16_V:
11916 case RISCV::VSSSEG4E32_V:
11917 case RISCV::VSSSEG4E64_V:
11918 case RISCV::VSSSEG4E8_V:
11919 case RISCV::VSSSEG5E16_V:
11920 case RISCV::VSSSEG5E32_V:
11921 case RISCV::VSSSEG5E64_V:
11922 case RISCV::VSSSEG5E8_V:
11923 case RISCV::VSSSEG6E16_V:
11924 case RISCV::VSSSEG6E32_V:
11925 case RISCV::VSSSEG6E64_V:
11926 case RISCV::VSSSEG6E8_V:
11927 case RISCV::VSSSEG7E16_V:
11928 case RISCV::VSSSEG7E32_V:
11929 case RISCV::VSSSEG7E64_V:
11930 case RISCV::VSSSEG7E8_V:
11931 case RISCV::VSSSEG8E16_V:
11932 case RISCV::VSSSEG8E32_V:
11933 case RISCV::VSSSEG8E64_V:
11934 case RISCV::VSSSEG8E8_V: {
11935 switch (OpNum) {
11936 case 1:
11937 // op: rs1
11938 return 15;
11939 case 0:
11940 // op: vs3
11941 return 7;
11942 case 3:
11943 // op: vm
11944 return 25;
11945 case 2:
11946 // op: rs2
11947 return 20;
11948 }
11949 break;
11950 }
11951 case RISCV::VSOXEI16_V:
11952 case RISCV::VSOXEI32_V:
11953 case RISCV::VSOXEI64_V:
11954 case RISCV::VSOXEI8_V:
11955 case RISCV::VSOXSEG2EI16_V:
11956 case RISCV::VSOXSEG2EI32_V:
11957 case RISCV::VSOXSEG2EI64_V:
11958 case RISCV::VSOXSEG2EI8_V:
11959 case RISCV::VSOXSEG3EI16_V:
11960 case RISCV::VSOXSEG3EI32_V:
11961 case RISCV::VSOXSEG3EI64_V:
11962 case RISCV::VSOXSEG3EI8_V:
11963 case RISCV::VSOXSEG4EI16_V:
11964 case RISCV::VSOXSEG4EI32_V:
11965 case RISCV::VSOXSEG4EI64_V:
11966 case RISCV::VSOXSEG4EI8_V:
11967 case RISCV::VSOXSEG5EI16_V:
11968 case RISCV::VSOXSEG5EI32_V:
11969 case RISCV::VSOXSEG5EI64_V:
11970 case RISCV::VSOXSEG5EI8_V:
11971 case RISCV::VSOXSEG6EI16_V:
11972 case RISCV::VSOXSEG6EI32_V:
11973 case RISCV::VSOXSEG6EI64_V:
11974 case RISCV::VSOXSEG6EI8_V:
11975 case RISCV::VSOXSEG7EI16_V:
11976 case RISCV::VSOXSEG7EI32_V:
11977 case RISCV::VSOXSEG7EI64_V:
11978 case RISCV::VSOXSEG7EI8_V:
11979 case RISCV::VSOXSEG8EI16_V:
11980 case RISCV::VSOXSEG8EI32_V:
11981 case RISCV::VSOXSEG8EI64_V:
11982 case RISCV::VSOXSEG8EI8_V:
11983 case RISCV::VSUXEI16_V:
11984 case RISCV::VSUXEI32_V:
11985 case RISCV::VSUXEI64_V:
11986 case RISCV::VSUXEI8_V:
11987 case RISCV::VSUXSEG2EI16_V:
11988 case RISCV::VSUXSEG2EI32_V:
11989 case RISCV::VSUXSEG2EI64_V:
11990 case RISCV::VSUXSEG2EI8_V:
11991 case RISCV::VSUXSEG3EI16_V:
11992 case RISCV::VSUXSEG3EI32_V:
11993 case RISCV::VSUXSEG3EI64_V:
11994 case RISCV::VSUXSEG3EI8_V:
11995 case RISCV::VSUXSEG4EI16_V:
11996 case RISCV::VSUXSEG4EI32_V:
11997 case RISCV::VSUXSEG4EI64_V:
11998 case RISCV::VSUXSEG4EI8_V:
11999 case RISCV::VSUXSEG5EI16_V:
12000 case RISCV::VSUXSEG5EI32_V:
12001 case RISCV::VSUXSEG5EI64_V:
12002 case RISCV::VSUXSEG5EI8_V:
12003 case RISCV::VSUXSEG6EI16_V:
12004 case RISCV::VSUXSEG6EI32_V:
12005 case RISCV::VSUXSEG6EI64_V:
12006 case RISCV::VSUXSEG6EI8_V:
12007 case RISCV::VSUXSEG7EI16_V:
12008 case RISCV::VSUXSEG7EI32_V:
12009 case RISCV::VSUXSEG7EI64_V:
12010 case RISCV::VSUXSEG7EI8_V:
12011 case RISCV::VSUXSEG8EI16_V:
12012 case RISCV::VSUXSEG8EI32_V:
12013 case RISCV::VSUXSEG8EI64_V:
12014 case RISCV::VSUXSEG8EI8_V: {
12015 switch (OpNum) {
12016 case 1:
12017 // op: rs1
12018 return 15;
12019 case 0:
12020 // op: vs3
12021 return 7;
12022 case 3:
12023 // op: vm
12024 return 25;
12025 case 2:
12026 // op: vs2
12027 return 20;
12028 }
12029 break;
12030 }
12031 case RISCV::VS1R_V:
12032 case RISCV::VS2R_V:
12033 case RISCV::VS4R_V:
12034 case RISCV::VS8R_V:
12035 case RISCV::VSM_V: {
12036 switch (OpNum) {
12037 case 1:
12038 // op: rs1
12039 return 15;
12040 case 0:
12041 // op: vs3
12042 return 7;
12043 }
12044 break;
12045 }
12046 case RISCV::FCVT_BF16_S:
12047 case RISCV::FCVT_D_H:
12048 case RISCV::FCVT_D_H_IN32X:
12049 case RISCV::FCVT_D_H_INX:
12050 case RISCV::FCVT_D_L:
12051 case RISCV::FCVT_D_LU:
12052 case RISCV::FCVT_D_LU_INX:
12053 case RISCV::FCVT_D_L_INX:
12054 case RISCV::FCVT_D_Q:
12055 case RISCV::FCVT_D_S:
12056 case RISCV::FCVT_D_S_IN32X:
12057 case RISCV::FCVT_D_S_INX:
12058 case RISCV::FCVT_D_W:
12059 case RISCV::FCVT_D_WU:
12060 case RISCV::FCVT_D_WU_IN32X:
12061 case RISCV::FCVT_D_WU_INX:
12062 case RISCV::FCVT_D_W_IN32X:
12063 case RISCV::FCVT_D_W_INX:
12064 case RISCV::FCVT_H_D:
12065 case RISCV::FCVT_H_D_IN32X:
12066 case RISCV::FCVT_H_D_INX:
12067 case RISCV::FCVT_H_L:
12068 case RISCV::FCVT_H_LU:
12069 case RISCV::FCVT_H_LU_INX:
12070 case RISCV::FCVT_H_L_INX:
12071 case RISCV::FCVT_H_S:
12072 case RISCV::FCVT_H_S_INX:
12073 case RISCV::FCVT_H_W:
12074 case RISCV::FCVT_H_WU:
12075 case RISCV::FCVT_H_WU_INX:
12076 case RISCV::FCVT_H_W_INX:
12077 case RISCV::FCVT_LU_D:
12078 case RISCV::FCVT_LU_D_INX:
12079 case RISCV::FCVT_LU_H:
12080 case RISCV::FCVT_LU_H_INX:
12081 case RISCV::FCVT_LU_Q:
12082 case RISCV::FCVT_LU_S:
12083 case RISCV::FCVT_LU_S_INX:
12084 case RISCV::FCVT_L_D:
12085 case RISCV::FCVT_L_D_INX:
12086 case RISCV::FCVT_L_H:
12087 case RISCV::FCVT_L_H_INX:
12088 case RISCV::FCVT_L_Q:
12089 case RISCV::FCVT_L_S:
12090 case RISCV::FCVT_L_S_INX:
12091 case RISCV::FCVT_Q_D:
12092 case RISCV::FCVT_Q_L:
12093 case RISCV::FCVT_Q_LU:
12094 case RISCV::FCVT_Q_S:
12095 case RISCV::FCVT_Q_W:
12096 case RISCV::FCVT_Q_WU:
12097 case RISCV::FCVT_S_BF16:
12098 case RISCV::FCVT_S_D:
12099 case RISCV::FCVT_S_D_IN32X:
12100 case RISCV::FCVT_S_D_INX:
12101 case RISCV::FCVT_S_H:
12102 case RISCV::FCVT_S_H_INX:
12103 case RISCV::FCVT_S_L:
12104 case RISCV::FCVT_S_LU:
12105 case RISCV::FCVT_S_LU_INX:
12106 case RISCV::FCVT_S_L_INX:
12107 case RISCV::FCVT_S_Q:
12108 case RISCV::FCVT_S_W:
12109 case RISCV::FCVT_S_WU:
12110 case RISCV::FCVT_S_WU_INX:
12111 case RISCV::FCVT_S_W_INX:
12112 case RISCV::FCVT_WU_D:
12113 case RISCV::FCVT_WU_D_IN32X:
12114 case RISCV::FCVT_WU_D_INX:
12115 case RISCV::FCVT_WU_H:
12116 case RISCV::FCVT_WU_H_INX:
12117 case RISCV::FCVT_WU_Q:
12118 case RISCV::FCVT_WU_S:
12119 case RISCV::FCVT_WU_S_INX:
12120 case RISCV::FCVT_W_D:
12121 case RISCV::FCVT_W_D_IN32X:
12122 case RISCV::FCVT_W_D_INX:
12123 case RISCV::FCVT_W_H:
12124 case RISCV::FCVT_W_H_INX:
12125 case RISCV::FCVT_W_Q:
12126 case RISCV::FCVT_W_S:
12127 case RISCV::FCVT_W_S_INX:
12128 case RISCV::FROUNDNX_D:
12129 case RISCV::FROUNDNX_H:
12130 case RISCV::FROUNDNX_Q:
12131 case RISCV::FROUNDNX_S:
12132 case RISCV::FROUND_D:
12133 case RISCV::FROUND_H:
12134 case RISCV::FROUND_Q:
12135 case RISCV::FROUND_S:
12136 case RISCV::FSQRT_D:
12137 case RISCV::FSQRT_D_IN32X:
12138 case RISCV::FSQRT_D_INX:
12139 case RISCV::FSQRT_H:
12140 case RISCV::FSQRT_H_INX:
12141 case RISCV::FSQRT_Q:
12142 case RISCV::FSQRT_S:
12143 case RISCV::FSQRT_S_INX: {
12144 switch (OpNum) {
12145 case 1:
12146 // op: rs1
12147 return 15;
12148 case 2:
12149 // op: frm
12150 return 12;
12151 case 0:
12152 // op: rd
12153 return 7;
12154 }
12155 break;
12156 }
12157 case RISCV::AIF_FROUND_PS: {
12158 switch (OpNum) {
12159 case 1:
12160 // op: rs1
12161 return 15;
12162 case 2:
12163 // op: rm
12164 return 12;
12165 case 0:
12166 // op: rd
12167 return 7;
12168 }
12169 break;
12170 }
12171 case RISCV::AIF_FSC32B_PS:
12172 case RISCV::AIF_FSC32H_PS:
12173 case RISCV::AIF_FSC32W_PS:
12174 case RISCV::AIF_FSCBG_PS:
12175 case RISCV::AIF_FSCBL_PS:
12176 case RISCV::AIF_FSCB_PS:
12177 case RISCV::AIF_FSCHG_PS:
12178 case RISCV::AIF_FSCHL_PS:
12179 case RISCV::AIF_FSCH_PS:
12180 case RISCV::AIF_FSCWG_PS:
12181 case RISCV::AIF_FSCWL_PS:
12182 case RISCV::AIF_FSCW_PS: {
12183 switch (OpNum) {
12184 case 1:
12185 // op: rs1
12186 return 15;
12187 case 2:
12188 // op: rs2
12189 return 20;
12190 case 0:
12191 // op: rs3
12192 return 7;
12193 }
12194 break;
12195 }
12196 case RISCV::NCLIP:
12197 case RISCV::NCLIPR:
12198 case RISCV::NCLIPRU:
12199 case RISCV::NCLIPU:
12200 case RISCV::NSRA:
12201 case RISCV::NSRAR:
12202 case RISCV::NSRL:
12203 case RISCV::PNCLIPRU_BS:
12204 case RISCV::PNCLIPRU_HS:
12205 case RISCV::PNCLIPR_BS:
12206 case RISCV::PNCLIPR_HS:
12207 case RISCV::PNCLIPU_BS:
12208 case RISCV::PNCLIPU_HS:
12209 case RISCV::PNCLIP_BS:
12210 case RISCV::PNCLIP_HS:
12211 case RISCV::PNSRAR_BS:
12212 case RISCV::PNSRAR_HS:
12213 case RISCV::PNSRA_BS:
12214 case RISCV::PNSRA_HS:
12215 case RISCV::PNSRL_BS:
12216 case RISCV::PNSRL_HS:
12217 case RISCV::PREDSUMU_DBS:
12218 case RISCV::PREDSUMU_DHS:
12219 case RISCV::PREDSUM_DBS:
12220 case RISCV::PREDSUM_DHS: {
12221 switch (OpNum) {
12222 case 1:
12223 // op: rs1
12224 return 16;
12225 case 0:
12226 // op: rd
12227 return 7;
12228 case 2:
12229 // op: rs2
12230 return 20;
12231 }
12232 break;
12233 }
12234 case RISCV::NCLIPI:
12235 case RISCV::NCLIPIU:
12236 case RISCV::NCLIPRI:
12237 case RISCV::NCLIPRIU:
12238 case RISCV::NSRAI:
12239 case RISCV::NSRARI:
12240 case RISCV::NSRLI:
12241 case RISCV::PNCLIPIU_B:
12242 case RISCV::PNCLIPIU_H:
12243 case RISCV::PNCLIPI_B:
12244 case RISCV::PNCLIPI_H:
12245 case RISCV::PNCLIPRIU_B:
12246 case RISCV::PNCLIPRIU_H:
12247 case RISCV::PNCLIPRI_B:
12248 case RISCV::PNCLIPRI_H:
12249 case RISCV::PNSRAI_B:
12250 case RISCV::PNSRAI_H:
12251 case RISCV::PNSRARI_B:
12252 case RISCV::PNSRARI_H:
12253 case RISCV::PNSRLI_B:
12254 case RISCV::PNSRLI_H: {
12255 switch (OpNum) {
12256 case 1:
12257 // op: rs1
12258 return 16;
12259 case 0:
12260 // op: rd
12261 return 7;
12262 case 2:
12263 // op: shamt
12264 return 20;
12265 }
12266 break;
12267 }
12268 case RISCV::PADD_DBS:
12269 case RISCV::PADD_DHS:
12270 case RISCV::PADD_DWS:
12271 case RISCV::PSLL_DBS:
12272 case RISCV::PSLL_DHS:
12273 case RISCV::PSLL_DWS:
12274 case RISCV::PSRA_DBS:
12275 case RISCV::PSRA_DHS:
12276 case RISCV::PSRA_DWS:
12277 case RISCV::PSRL_DBS:
12278 case RISCV::PSRL_DHS:
12279 case RISCV::PSRL_DWS:
12280 case RISCV::PSSHAR_DHS:
12281 case RISCV::PSSHAR_DWS:
12282 case RISCV::PSSHA_DHS:
12283 case RISCV::PSSHA_DWS:
12284 case RISCV::PSSHLR_DHS:
12285 case RISCV::PSSHLR_DWS:
12286 case RISCV::PSSHL_DHS:
12287 case RISCV::PSSHL_DWS: {
12288 switch (OpNum) {
12289 case 1:
12290 // op: rs1
12291 return 16;
12292 case 0:
12293 // op: rd
12294 return 8;
12295 case 2:
12296 // op: rs2
12297 return 20;
12298 }
12299 break;
12300 }
12301 case RISCV::ADDD:
12302 case RISCV::PAADDU_DB:
12303 case RISCV::PAADDU_DH:
12304 case RISCV::PAADDU_DW:
12305 case RISCV::PAADD_DB:
12306 case RISCV::PAADD_DH:
12307 case RISCV::PAADD_DW:
12308 case RISCV::PAAS_DHX:
12309 case RISCV::PABDU_DB:
12310 case RISCV::PABDU_DH:
12311 case RISCV::PABD_DB:
12312 case RISCV::PABD_DH:
12313 case RISCV::PADD_DB:
12314 case RISCV::PADD_DH:
12315 case RISCV::PADD_DW:
12316 case RISCV::PASA_DHX:
12317 case RISCV::PASUBU_DB:
12318 case RISCV::PASUBU_DH:
12319 case RISCV::PASUBU_DW:
12320 case RISCV::PASUB_DB:
12321 case RISCV::PASUB_DH:
12322 case RISCV::PASUB_DW:
12323 case RISCV::PAS_DHX:
12324 case RISCV::PMAXU_DB:
12325 case RISCV::PMAXU_DH:
12326 case RISCV::PMAXU_DW:
12327 case RISCV::PMAX_DB:
12328 case RISCV::PMAX_DH:
12329 case RISCV::PMAX_DW:
12330 case RISCV::PMINU_DB:
12331 case RISCV::PMINU_DH:
12332 case RISCV::PMINU_DW:
12333 case RISCV::PMIN_DB:
12334 case RISCV::PMIN_DH:
12335 case RISCV::PMIN_DW:
12336 case RISCV::PMSEQ_DB:
12337 case RISCV::PMSEQ_DH:
12338 case RISCV::PMSEQ_DW:
12339 case RISCV::PMSLTU_DB:
12340 case RISCV::PMSLTU_DH:
12341 case RISCV::PMSLTU_DW:
12342 case RISCV::PMSLT_DB:
12343 case RISCV::PMSLT_DH:
12344 case RISCV::PMSLT_DW:
12345 case RISCV::PPAIREO_DB:
12346 case RISCV::PPAIREO_DH:
12347 case RISCV::PPAIRE_DB:
12348 case RISCV::PPAIRE_DH:
12349 case RISCV::PPAIROE_DB:
12350 case RISCV::PPAIROE_DH:
12351 case RISCV::PPAIRO_DB:
12352 case RISCV::PPAIRO_DH:
12353 case RISCV::PSADDU_DB:
12354 case RISCV::PSADDU_DH:
12355 case RISCV::PSADDU_DW:
12356 case RISCV::PSADD_DB:
12357 case RISCV::PSADD_DH:
12358 case RISCV::PSADD_DW:
12359 case RISCV::PSAS_DHX:
12360 case RISCV::PSA_DHX:
12361 case RISCV::PSH1ADD_DH:
12362 case RISCV::PSH1ADD_DW:
12363 case RISCV::PSSA_DHX:
12364 case RISCV::PSSH1SADD_DH:
12365 case RISCV::PSSH1SADD_DW:
12366 case RISCV::PSSUBU_DB:
12367 case RISCV::PSSUBU_DH:
12368 case RISCV::PSSUBU_DW:
12369 case RISCV::PSSUB_DB:
12370 case RISCV::PSSUB_DH:
12371 case RISCV::PSSUB_DW:
12372 case RISCV::PSUB_DB:
12373 case RISCV::PSUB_DH:
12374 case RISCV::PSUB_DW:
12375 case RISCV::SUBD: {
12376 switch (OpNum) {
12377 case 1:
12378 // op: rs1
12379 return 16;
12380 case 0:
12381 // op: rd
12382 return 8;
12383 case 2:
12384 // op: rs2
12385 return 21;
12386 }
12387 break;
12388 }
12389 case RISCV::PSATI_DH:
12390 case RISCV::PSATI_DW:
12391 case RISCV::PSLLI_DB:
12392 case RISCV::PSLLI_DH:
12393 case RISCV::PSLLI_DW:
12394 case RISCV::PSRAI_DB:
12395 case RISCV::PSRAI_DH:
12396 case RISCV::PSRAI_DW:
12397 case RISCV::PSRARI_DH:
12398 case RISCV::PSRARI_DW:
12399 case RISCV::PSRLI_DB:
12400 case RISCV::PSRLI_DH:
12401 case RISCV::PSRLI_DW:
12402 case RISCV::PSSLAI_DH:
12403 case RISCV::PSSLAI_DW:
12404 case RISCV::PUSATI_DH:
12405 case RISCV::PUSATI_DW: {
12406 switch (OpNum) {
12407 case 1:
12408 // op: rs1
12409 return 16;
12410 case 0:
12411 // op: rd
12412 return 8;
12413 case 2:
12414 // op: shamt
12415 return 20;
12416 }
12417 break;
12418 }
12419 case RISCV::PSABS_DB:
12420 case RISCV::PSABS_DH:
12421 case RISCV::PSEXT_DH_B:
12422 case RISCV::PSEXT_DW_B:
12423 case RISCV::PSEXT_DW_H: {
12424 switch (OpNum) {
12425 case 1:
12426 // op: rs1
12427 return 16;
12428 case 0:
12429 // op: rd
12430 return 8;
12431 }
12432 break;
12433 }
12434 case RISCV::C_ADD: {
12435 switch (OpNum) {
12436 case 1:
12437 // op: rs1
12438 return 7;
12439 case 2:
12440 // op: rs2
12441 return 2;
12442 }
12443 break;
12444 }
12445 case RISCV::QC_C_BEXTI:
12446 case RISCV::QC_C_BSETI: {
12447 switch (OpNum) {
12448 case 1:
12449 // op: rs1
12450 return 7;
12451 case 2:
12452 // op: shamt
12453 return 2;
12454 }
12455 break;
12456 }
12457 case RISCV::NDS_FCVT_BF16_S:
12458 case RISCV::NDS_FCVT_S_BF16: {
12459 switch (OpNum) {
12460 case 1:
12461 // op: rs2
12462 return 20;
12463 case 0:
12464 // op: rd
12465 return 7;
12466 }
12467 break;
12468 }
12469 case RISCV::HFENCE_GVMA:
12470 case RISCV::HFENCE_VVMA:
12471 case RISCV::HINVAL_GVMA:
12472 case RISCV::HINVAL_VVMA:
12473 case RISCV::SFENCE_VMA:
12474 case RISCV::SF_VTMV_T_V:
12475 case RISCV::SINVAL_VMA:
12476 case RISCV::TH_SFENCE_VMAS: {
12477 switch (OpNum) {
12478 case 1:
12479 // op: rs2
12480 return 20;
12481 case 0:
12482 // op: rs1
12483 return 15;
12484 }
12485 break;
12486 }
12487 case RISCV::TH_LDD:
12488 case RISCV::TH_LWD:
12489 case RISCV::TH_LWUD:
12490 case RISCV::TH_SDD:
12491 case RISCV::TH_SWD: {
12492 switch (OpNum) {
12493 case 1:
12494 // op: rs2
12495 return 20;
12496 case 2:
12497 // op: rs1
12498 return 15;
12499 case 0:
12500 // op: rd
12501 return 7;
12502 case 3:
12503 // op: uimm2
12504 return 25;
12505 }
12506 break;
12507 }
12508 case RISCV::AIF_AMOADDG_D:
12509 case RISCV::AIF_AMOADDG_W:
12510 case RISCV::AIF_AMOADDL_D:
12511 case RISCV::AIF_AMOADDL_W:
12512 case RISCV::AIF_AMOANDG_D:
12513 case RISCV::AIF_AMOANDG_W:
12514 case RISCV::AIF_AMOANDL_D:
12515 case RISCV::AIF_AMOANDL_W:
12516 case RISCV::AIF_AMOCMPSWAPG_D:
12517 case RISCV::AIF_AMOCMPSWAPG_W:
12518 case RISCV::AIF_AMOCMPSWAPL_D:
12519 case RISCV::AIF_AMOCMPSWAPL_W:
12520 case RISCV::AIF_AMOMAXG_D:
12521 case RISCV::AIF_AMOMAXG_W:
12522 case RISCV::AIF_AMOMAXL_D:
12523 case RISCV::AIF_AMOMAXL_W:
12524 case RISCV::AIF_AMOMAXUG_D:
12525 case RISCV::AIF_AMOMAXUG_W:
12526 case RISCV::AIF_AMOMAXUL_D:
12527 case RISCV::AIF_AMOMAXUL_W:
12528 case RISCV::AIF_AMOMING_D:
12529 case RISCV::AIF_AMOMING_W:
12530 case RISCV::AIF_AMOMINL_D:
12531 case RISCV::AIF_AMOMINL_W:
12532 case RISCV::AIF_AMOMINUG_D:
12533 case RISCV::AIF_AMOMINUG_W:
12534 case RISCV::AIF_AMOMINUL_D:
12535 case RISCV::AIF_AMOMINUL_W:
12536 case RISCV::AIF_AMOORG_D:
12537 case RISCV::AIF_AMOORG_W:
12538 case RISCV::AIF_AMOORL_D:
12539 case RISCV::AIF_AMOORL_W:
12540 case RISCV::AIF_AMOSWAPG_D:
12541 case RISCV::AIF_AMOSWAPG_W:
12542 case RISCV::AIF_AMOSWAPL_D:
12543 case RISCV::AIF_AMOSWAPL_W:
12544 case RISCV::AIF_AMOXORG_D:
12545 case RISCV::AIF_AMOXORG_W:
12546 case RISCV::AIF_AMOXORL_D:
12547 case RISCV::AIF_AMOXORL_W:
12548 case RISCV::AMOADD_B:
12549 case RISCV::AMOADD_B_AQ:
12550 case RISCV::AMOADD_B_AQRL:
12551 case RISCV::AMOADD_B_RL:
12552 case RISCV::AMOADD_D:
12553 case RISCV::AMOADD_D_AQ:
12554 case RISCV::AMOADD_D_AQRL:
12555 case RISCV::AMOADD_D_RL:
12556 case RISCV::AMOADD_H:
12557 case RISCV::AMOADD_H_AQ:
12558 case RISCV::AMOADD_H_AQRL:
12559 case RISCV::AMOADD_H_RL:
12560 case RISCV::AMOADD_W:
12561 case RISCV::AMOADD_W_AQ:
12562 case RISCV::AMOADD_W_AQRL:
12563 case RISCV::AMOADD_W_RL:
12564 case RISCV::AMOAND_B:
12565 case RISCV::AMOAND_B_AQ:
12566 case RISCV::AMOAND_B_AQRL:
12567 case RISCV::AMOAND_B_RL:
12568 case RISCV::AMOAND_D:
12569 case RISCV::AMOAND_D_AQ:
12570 case RISCV::AMOAND_D_AQRL:
12571 case RISCV::AMOAND_D_RL:
12572 case RISCV::AMOAND_H:
12573 case RISCV::AMOAND_H_AQ:
12574 case RISCV::AMOAND_H_AQRL:
12575 case RISCV::AMOAND_H_RL:
12576 case RISCV::AMOAND_W:
12577 case RISCV::AMOAND_W_AQ:
12578 case RISCV::AMOAND_W_AQRL:
12579 case RISCV::AMOAND_W_RL:
12580 case RISCV::AMOMAXU_B:
12581 case RISCV::AMOMAXU_B_AQ:
12582 case RISCV::AMOMAXU_B_AQRL:
12583 case RISCV::AMOMAXU_B_RL:
12584 case RISCV::AMOMAXU_D:
12585 case RISCV::AMOMAXU_D_AQ:
12586 case RISCV::AMOMAXU_D_AQRL:
12587 case RISCV::AMOMAXU_D_RL:
12588 case RISCV::AMOMAXU_H:
12589 case RISCV::AMOMAXU_H_AQ:
12590 case RISCV::AMOMAXU_H_AQRL:
12591 case RISCV::AMOMAXU_H_RL:
12592 case RISCV::AMOMAXU_W:
12593 case RISCV::AMOMAXU_W_AQ:
12594 case RISCV::AMOMAXU_W_AQRL:
12595 case RISCV::AMOMAXU_W_RL:
12596 case RISCV::AMOMAX_B:
12597 case RISCV::AMOMAX_B_AQ:
12598 case RISCV::AMOMAX_B_AQRL:
12599 case RISCV::AMOMAX_B_RL:
12600 case RISCV::AMOMAX_D:
12601 case RISCV::AMOMAX_D_AQ:
12602 case RISCV::AMOMAX_D_AQRL:
12603 case RISCV::AMOMAX_D_RL:
12604 case RISCV::AMOMAX_H:
12605 case RISCV::AMOMAX_H_AQ:
12606 case RISCV::AMOMAX_H_AQRL:
12607 case RISCV::AMOMAX_H_RL:
12608 case RISCV::AMOMAX_W:
12609 case RISCV::AMOMAX_W_AQ:
12610 case RISCV::AMOMAX_W_AQRL:
12611 case RISCV::AMOMAX_W_RL:
12612 case RISCV::AMOMINU_B:
12613 case RISCV::AMOMINU_B_AQ:
12614 case RISCV::AMOMINU_B_AQRL:
12615 case RISCV::AMOMINU_B_RL:
12616 case RISCV::AMOMINU_D:
12617 case RISCV::AMOMINU_D_AQ:
12618 case RISCV::AMOMINU_D_AQRL:
12619 case RISCV::AMOMINU_D_RL:
12620 case RISCV::AMOMINU_H:
12621 case RISCV::AMOMINU_H_AQ:
12622 case RISCV::AMOMINU_H_AQRL:
12623 case RISCV::AMOMINU_H_RL:
12624 case RISCV::AMOMINU_W:
12625 case RISCV::AMOMINU_W_AQ:
12626 case RISCV::AMOMINU_W_AQRL:
12627 case RISCV::AMOMINU_W_RL:
12628 case RISCV::AMOMIN_B:
12629 case RISCV::AMOMIN_B_AQ:
12630 case RISCV::AMOMIN_B_AQRL:
12631 case RISCV::AMOMIN_B_RL:
12632 case RISCV::AMOMIN_D:
12633 case RISCV::AMOMIN_D_AQ:
12634 case RISCV::AMOMIN_D_AQRL:
12635 case RISCV::AMOMIN_D_RL:
12636 case RISCV::AMOMIN_H:
12637 case RISCV::AMOMIN_H_AQ:
12638 case RISCV::AMOMIN_H_AQRL:
12639 case RISCV::AMOMIN_H_RL:
12640 case RISCV::AMOMIN_W:
12641 case RISCV::AMOMIN_W_AQ:
12642 case RISCV::AMOMIN_W_AQRL:
12643 case RISCV::AMOMIN_W_RL:
12644 case RISCV::AMOOR_B:
12645 case RISCV::AMOOR_B_AQ:
12646 case RISCV::AMOOR_B_AQRL:
12647 case RISCV::AMOOR_B_RL:
12648 case RISCV::AMOOR_D:
12649 case RISCV::AMOOR_D_AQ:
12650 case RISCV::AMOOR_D_AQRL:
12651 case RISCV::AMOOR_D_RL:
12652 case RISCV::AMOOR_H:
12653 case RISCV::AMOOR_H_AQ:
12654 case RISCV::AMOOR_H_AQRL:
12655 case RISCV::AMOOR_H_RL:
12656 case RISCV::AMOOR_W:
12657 case RISCV::AMOOR_W_AQ:
12658 case RISCV::AMOOR_W_AQRL:
12659 case RISCV::AMOOR_W_RL:
12660 case RISCV::AMOSWAP_B:
12661 case RISCV::AMOSWAP_B_AQ:
12662 case RISCV::AMOSWAP_B_AQRL:
12663 case RISCV::AMOSWAP_B_RL:
12664 case RISCV::AMOSWAP_D:
12665 case RISCV::AMOSWAP_D_AQ:
12666 case RISCV::AMOSWAP_D_AQRL:
12667 case RISCV::AMOSWAP_D_RL:
12668 case RISCV::AMOSWAP_H:
12669 case RISCV::AMOSWAP_H_AQ:
12670 case RISCV::AMOSWAP_H_AQRL:
12671 case RISCV::AMOSWAP_H_RL:
12672 case RISCV::AMOSWAP_W:
12673 case RISCV::AMOSWAP_W_AQ:
12674 case RISCV::AMOSWAP_W_AQRL:
12675 case RISCV::AMOSWAP_W_RL:
12676 case RISCV::AMOXOR_B:
12677 case RISCV::AMOXOR_B_AQ:
12678 case RISCV::AMOXOR_B_AQRL:
12679 case RISCV::AMOXOR_B_RL:
12680 case RISCV::AMOXOR_D:
12681 case RISCV::AMOXOR_D_AQ:
12682 case RISCV::AMOXOR_D_AQRL:
12683 case RISCV::AMOXOR_D_RL:
12684 case RISCV::AMOXOR_H:
12685 case RISCV::AMOXOR_H_AQ:
12686 case RISCV::AMOXOR_H_AQRL:
12687 case RISCV::AMOXOR_H_RL:
12688 case RISCV::AMOXOR_W:
12689 case RISCV::AMOXOR_W_AQ:
12690 case RISCV::AMOXOR_W_AQRL:
12691 case RISCV::AMOXOR_W_RL:
12692 case RISCV::NDS_LEA_B_ZE:
12693 case RISCV::NDS_LEA_D:
12694 case RISCV::NDS_LEA_D_ZE:
12695 case RISCV::NDS_LEA_H:
12696 case RISCV::NDS_LEA_H_ZE:
12697 case RISCV::NDS_LEA_W:
12698 case RISCV::NDS_LEA_W_ZE:
12699 case RISCV::SC_D:
12700 case RISCV::SC_D_AQ:
12701 case RISCV::SC_D_AQRL:
12702 case RISCV::SC_D_RL:
12703 case RISCV::SC_W:
12704 case RISCV::SC_W_AQ:
12705 case RISCV::SC_W_AQRL:
12706 case RISCV::SC_W_RL:
12707 case RISCV::SSAMOSWAP_D:
12708 case RISCV::SSAMOSWAP_D_AQ:
12709 case RISCV::SSAMOSWAP_D_AQRL:
12710 case RISCV::SSAMOSWAP_D_RL:
12711 case RISCV::SSAMOSWAP_W:
12712 case RISCV::SSAMOSWAP_W_AQ:
12713 case RISCV::SSAMOSWAP_W_AQRL:
12714 case RISCV::SSAMOSWAP_W_RL: {
12715 switch (OpNum) {
12716 case 1:
12717 // op: rs2
12718 return 20;
12719 case 2:
12720 // op: rs1
12721 return 15;
12722 case 0:
12723 // op: rd
12724 return 7;
12725 }
12726 break;
12727 }
12728 case RISCV::CM_MVA01S:
12729 case RISCV::CM_MVSA01:
12730 case RISCV::QC_CM_MVA01S:
12731 case RISCV::QC_CM_MVSA01: {
12732 switch (OpNum) {
12733 case 1:
12734 // op: rs2
12735 return 2;
12736 case 0:
12737 // op: rs1
12738 return 7;
12739 }
12740 break;
12741 }
12742 case RISCV::VFMV_S_F:
12743 case RISCV::VMV_S_X: {
12744 switch (OpNum) {
12745 case 1:
12746 // op: vd
12747 return 7;
12748 case 2:
12749 // op: rs1
12750 return 15;
12751 }
12752 break;
12753 }
12754 case RISCV::SMT_VMADOT:
12755 case RISCV::SMT_VMADOTSU:
12756 case RISCV::SMT_VMADOTU:
12757 case RISCV::SMT_VMADOTUS: {
12758 switch (OpNum) {
12759 case 1:
12760 // op: vd
12761 return 7;
12762 case 2:
12763 // op: vs1
12764 return 15;
12765 case 3:
12766 // op: vs2
12767 return 20;
12768 }
12769 break;
12770 }
12771 case RISCV::SMT_VMADOT1:
12772 case RISCV::SMT_VMADOT1SU:
12773 case RISCV::SMT_VMADOT1U:
12774 case RISCV::SMT_VMADOT1US:
12775 case RISCV::SMT_VMADOT2:
12776 case RISCV::SMT_VMADOT2SU:
12777 case RISCV::SMT_VMADOT2U:
12778 case RISCV::SMT_VMADOT2US:
12779 case RISCV::SMT_VMADOT3:
12780 case RISCV::SMT_VMADOT3SU:
12781 case RISCV::SMT_VMADOT3U:
12782 case RISCV::SMT_VMADOT3US: {
12783 switch (OpNum) {
12784 case 1:
12785 // op: vd
12786 return 7;
12787 case 2:
12788 // op: vs1
12789 return 16;
12790 case 3:
12791 // op: vs2
12792 return 20;
12793 }
12794 break;
12795 }
12796 case RISCV::VAESKF2_VI:
12797 case RISCV::VSM3C_VI: {
12798 switch (OpNum) {
12799 case 1:
12800 // op: vd
12801 return 7;
12802 case 2:
12803 // op: vs2
12804 return 20;
12805 case 3:
12806 // op: imm
12807 return 15;
12808 }
12809 break;
12810 }
12811 case RISCV::VGHSH_VS:
12812 case RISCV::VGHSH_VV:
12813 case RISCV::VSHA2CH_VV:
12814 case RISCV::VSHA2CL_VV:
12815 case RISCV::VSHA2MS_VV: {
12816 switch (OpNum) {
12817 case 1:
12818 // op: vd
12819 return 7;
12820 case 2:
12821 // op: vs2
12822 return 20;
12823 case 3:
12824 // op: vs1
12825 return 15;
12826 }
12827 break;
12828 }
12829 case RISCV::VAESDF_VS:
12830 case RISCV::VAESDF_VV:
12831 case RISCV::VAESDM_VS:
12832 case RISCV::VAESDM_VV:
12833 case RISCV::VAESEF_VS:
12834 case RISCV::VAESEF_VV:
12835 case RISCV::VAESEM_VS:
12836 case RISCV::VAESEM_VV:
12837 case RISCV::VAESZ_VS:
12838 case RISCV::VGMUL_VS:
12839 case RISCV::VGMUL_VV:
12840 case RISCV::VSM4R_VS:
12841 case RISCV::VSM4R_VV: {
12842 switch (OpNum) {
12843 case 1:
12844 // op: vd
12845 return 7;
12846 case 2:
12847 // op: vs2
12848 return 20;
12849 }
12850 break;
12851 }
12852 case RISCV::SF_VFWMACC_4x4x4:
12853 case RISCV::SF_VQMACCSU_2x8x2:
12854 case RISCV::SF_VQMACCSU_4x8x4:
12855 case RISCV::SF_VQMACCUS_2x8x2:
12856 case RISCV::SF_VQMACCUS_4x8x4:
12857 case RISCV::SF_VQMACCU_2x8x2:
12858 case RISCV::SF_VQMACCU_4x8x4:
12859 case RISCV::SF_VQMACC_2x8x2:
12860 case RISCV::SF_VQMACC_4x8x4: {
12861 switch (OpNum) {
12862 case 1:
12863 // op: vd
12864 return 7;
12865 case 3:
12866 // op: vs2
12867 return 20;
12868 case 2:
12869 // op: vs1
12870 return 15;
12871 }
12872 break;
12873 }
12874 case RISCV::VDOTA4SU_VX:
12875 case RISCV::VDOTA4US_VX:
12876 case RISCV::VDOTA4U_VX:
12877 case RISCV::VDOTA4_VX: {
12878 switch (OpNum) {
12879 case 1:
12880 // op: vd
12881 return 7;
12882 case 4:
12883 // op: vm
12884 return 25;
12885 case 2:
12886 // op: vs2
12887 return 20;
12888 case 3:
12889 // op: rs1
12890 return 15;
12891 }
12892 break;
12893 }
12894 case RISCV::VDOTA4SU_VV:
12895 case RISCV::VDOTA4U_VV:
12896 case RISCV::VDOTA4_VV: {
12897 switch (OpNum) {
12898 case 1:
12899 // op: vd
12900 return 7;
12901 case 4:
12902 // op: vm
12903 return 25;
12904 case 2:
12905 // op: vs2
12906 return 20;
12907 case 3:
12908 // op: vs1
12909 return 15;
12910 }
12911 break;
12912 }
12913 case RISCV::TH_VMAQASU_VX:
12914 case RISCV::TH_VMAQAUS_VX:
12915 case RISCV::TH_VMAQAU_VX:
12916 case RISCV::TH_VMAQA_VX:
12917 case RISCV::VFMACC_VF:
12918 case RISCV::VFMADD_VF:
12919 case RISCV::VFMSAC_VF:
12920 case RISCV::VFMSUB_VF:
12921 case RISCV::VFNMACC_VF:
12922 case RISCV::VFNMADD_VF:
12923 case RISCV::VFNMSAC_VF:
12924 case RISCV::VFNMSUB_VF:
12925 case RISCV::VFWMACCBF16_VF:
12926 case RISCV::VFWMACC_VF:
12927 case RISCV::VFWMSAC_VF:
12928 case RISCV::VFWNMACC_VF:
12929 case RISCV::VFWNMSAC_VF:
12930 case RISCV::VMACC_VX:
12931 case RISCV::VMADD_VX:
12932 case RISCV::VNMSAC_VX:
12933 case RISCV::VNMSUB_VX:
12934 case RISCV::VWMACCSU_VX:
12935 case RISCV::VWMACCUS_VX:
12936 case RISCV::VWMACCU_VX:
12937 case RISCV::VWMACC_VX: {
12938 switch (OpNum) {
12939 case 1:
12940 // op: vd
12941 return 7;
12942 case 4:
12943 // op: vm
12944 return 25;
12945 case 3:
12946 // op: vs2
12947 return 20;
12948 case 2:
12949 // op: rs1
12950 return 15;
12951 }
12952 break;
12953 }
12954 case RISCV::TH_VMAQASU_VV:
12955 case RISCV::TH_VMAQAU_VV:
12956 case RISCV::TH_VMAQA_VV:
12957 case RISCV::VFMACC_VV:
12958 case RISCV::VFMADD_VV:
12959 case RISCV::VFMSAC_VV:
12960 case RISCV::VFMSUB_VV:
12961 case RISCV::VFNMACC_VV:
12962 case RISCV::VFNMADD_VV:
12963 case RISCV::VFNMSAC_VV:
12964 case RISCV::VFNMSUB_VV:
12965 case RISCV::VFWMACCBF16_VV:
12966 case RISCV::VFWMACC_VV:
12967 case RISCV::VFWMSAC_VV:
12968 case RISCV::VFWNMACC_VV:
12969 case RISCV::VFWNMSAC_VV:
12970 case RISCV::VMACC_VV:
12971 case RISCV::VMADD_VV:
12972 case RISCV::VNMSAC_VV:
12973 case RISCV::VNMSUB_VV:
12974 case RISCV::VWMACCSU_VV:
12975 case RISCV::VWMACCU_VV:
12976 case RISCV::VWMACC_VV: {
12977 switch (OpNum) {
12978 case 1:
12979 // op: vd
12980 return 7;
12981 case 4:
12982 // op: vm
12983 return 25;
12984 case 3:
12985 // op: vs2
12986 return 20;
12987 case 2:
12988 // op: vs1
12989 return 15;
12990 }
12991 break;
12992 }
12993 case RISCV::NDS_VFWCVT_F_B:
12994 case RISCV::NDS_VFWCVT_F_BU:
12995 case RISCV::NDS_VFWCVT_F_N:
12996 case RISCV::NDS_VFWCVT_F_NU: {
12997 switch (OpNum) {
12998 case 1:
12999 // op: vs
13000 return 20;
13001 case 0:
13002 // op: vd
13003 return 7;
13004 case 2:
13005 // op: vm
13006 return 25;
13007 }
13008 break;
13009 }
13010 case RISCV::NDS_VFNCVT_BF16_S:
13011 case RISCV::NDS_VFWCVT_S_BF16: {
13012 switch (OpNum) {
13013 case 1:
13014 // op: vs2
13015 return 20;
13016 case 0:
13017 // op: vd
13018 return 7;
13019 }
13020 break;
13021 }
13022 case RISCV::NDS_VFPMADB_VF:
13023 case RISCV::NDS_VFPMADT_VF: {
13024 switch (OpNum) {
13025 case 1:
13026 // op: vs2
13027 return 20;
13028 case 2:
13029 // op: rs1
13030 return 15;
13031 case 0:
13032 // op: vd
13033 return 7;
13034 case 3:
13035 // op: vm
13036 return 25;
13037 }
13038 break;
13039 }
13040 case RISCV::SF_VC_I: {
13041 switch (OpNum) {
13042 case 1:
13043 // op: vs2
13044 return 20;
13045 case 2:
13046 // op: vd
13047 return 7;
13048 case 3:
13049 // op: imm
13050 return 15;
13051 case 0:
13052 // op: funct6_lo2
13053 return 26;
13054 }
13055 break;
13056 }
13057 case RISCV::SF_VC_X: {
13058 switch (OpNum) {
13059 case 1:
13060 // op: vs2
13061 return 20;
13062 case 2:
13063 // op: vd
13064 return 7;
13065 case 3:
13066 // op: rs1
13067 return 15;
13068 case 0:
13069 // op: funct6_lo2
13070 return 26;
13071 }
13072 break;
13073 }
13074 case RISCV::SF_MM_E4M3_E4M3:
13075 case RISCV::SF_MM_E4M3_E5M2:
13076 case RISCV::SF_MM_E5M2_E4M3:
13077 case RISCV::SF_MM_E5M2_E5M2:
13078 case RISCV::SF_MM_S_S:
13079 case RISCV::SF_MM_S_U:
13080 case RISCV::SF_MM_U_S:
13081 case RISCV::SF_MM_U_U: {
13082 switch (OpNum) {
13083 case 1:
13084 // op: vs2
13085 return 20;
13086 case 2:
13087 // op: vs1
13088 return 15;
13089 case 0:
13090 // op: rd
13091 return 10;
13092 }
13093 break;
13094 }
13095 case RISCV::SF_MM_F_F: {
13096 switch (OpNum) {
13097 case 1:
13098 // op: vs2
13099 return 20;
13100 case 2:
13101 // op: vs1
13102 return 15;
13103 case 0:
13104 // op: rd
13105 return 9;
13106 }
13107 break;
13108 }
13109 case RISCV::AIF_MOV_M_X: {
13110 switch (OpNum) {
13111 case 2:
13112 // op: imm
13113 return 12;
13114 case 1:
13115 // op: rs1
13116 return 15;
13117 case 0:
13118 // op: rd
13119 return 7;
13120 }
13121 break;
13122 }
13123 case RISCV::AIF_FADDI_PI:
13124 case RISCV::AIF_FANDI_PI:
13125 case RISCV::AIF_FSLLI_PI:
13126 case RISCV::AIF_FSRAI_PI:
13127 case RISCV::AIF_FSRLI_PI: {
13128 switch (OpNum) {
13129 case 2:
13130 // op: imm
13131 return 20;
13132 case 1:
13133 // op: rs1
13134 return 15;
13135 case 0:
13136 // op: rd
13137 return 7;
13138 }
13139 break;
13140 }
13141 case RISCV::C_FLDSP:
13142 case RISCV::C_FLWSP:
13143 case RISCV::C_LDSP:
13144 case RISCV::C_LDSP_RV32:
13145 case RISCV::C_LWSP:
13146 case RISCV::C_LWSP_INX: {
13147 switch (OpNum) {
13148 case 2:
13149 // op: imm
13150 return 2;
13151 case 0:
13152 // op: rd
13153 return 7;
13154 }
13155 break;
13156 }
13157 case RISCV::C_ADDI:
13158 case RISCV::C_ADDIW:
13159 case RISCV::C_SLLI: {
13160 switch (OpNum) {
13161 case 2:
13162 // op: imm
13163 return 2;
13164 case 1:
13165 // op: rd
13166 return 7;
13167 }
13168 break;
13169 }
13170 case RISCV::C_ANDI:
13171 case RISCV::C_SRAI:
13172 case RISCV::C_SRLI: {
13173 switch (OpNum) {
13174 case 2:
13175 // op: imm
13176 return 2;
13177 case 1:
13178 // op: rs1
13179 return 7;
13180 }
13181 break;
13182 }
13183 case RISCV::C_ADDI16SP: {
13184 switch (OpNum) {
13185 case 2:
13186 // op: imm
13187 return 2;
13188 }
13189 break;
13190 }
13191 case RISCV::C_ADDI4SPN: {
13192 switch (OpNum) {
13193 case 2:
13194 // op: imm
13195 return 5;
13196 case 0:
13197 // op: rd
13198 return 2;
13199 }
13200 break;
13201 }
13202 case RISCV::C_FSDSP:
13203 case RISCV::C_FSWSP:
13204 case RISCV::C_SDSP:
13205 case RISCV::C_SDSP_RV32:
13206 case RISCV::C_SWSP:
13207 case RISCV::C_SWSP_INX: {
13208 switch (OpNum) {
13209 case 2:
13210 // op: imm
13211 return 7;
13212 case 0:
13213 // op: rs2
13214 return 2;
13215 }
13216 break;
13217 }
13218 case RISCV::NDS_BBC:
13219 case RISCV::NDS_BBS:
13220 case RISCV::NDS_BEQC:
13221 case RISCV::NDS_BNEC: {
13222 switch (OpNum) {
13223 case 2:
13224 // op: imm10
13225 return 8;
13226 case 0:
13227 // op: rs1
13228 return 15;
13229 case 1:
13230 // op: cimm
13231 return 7;
13232 }
13233 break;
13234 }
13235 case RISCV::CV_BEQIMM:
13236 case RISCV::CV_BNEIMM: {
13237 switch (OpNum) {
13238 case 2:
13239 // op: imm12
13240 return 7;
13241 case 0:
13242 // op: rs1
13243 return 15;
13244 case 1:
13245 // op: imm5
13246 return 20;
13247 }
13248 break;
13249 }
13250 case RISCV::FSD:
13251 case RISCV::FSH:
13252 case RISCV::FSQ:
13253 case RISCV::FSW:
13254 case RISCV::SB:
13255 case RISCV::SD:
13256 case RISCV::SD_RV32:
13257 case RISCV::SH:
13258 case RISCV::SH_INX:
13259 case RISCV::SW:
13260 case RISCV::SW_INX: {
13261 switch (OpNum) {
13262 case 2:
13263 // op: imm12
13264 return 7;
13265 case 0:
13266 // op: rs2
13267 return 20;
13268 case 1:
13269 // op: rs1
13270 return 15;
13271 }
13272 break;
13273 }
13274 case RISCV::BEQI:
13275 case RISCV::BNEI: {
13276 switch (OpNum) {
13277 case 2:
13278 // op: imm12
13279 return 7;
13280 case 1:
13281 // op: cimm
13282 return 20;
13283 case 0:
13284 // op: rs1
13285 return 15;
13286 }
13287 break;
13288 }
13289 case RISCV::BEQ:
13290 case RISCV::BGE:
13291 case RISCV::BGEU:
13292 case RISCV::BLT:
13293 case RISCV::BLTU:
13294 case RISCV::BNE:
13295 case RISCV::QC_BEQI:
13296 case RISCV::QC_BGEI:
13297 case RISCV::QC_BGEUI:
13298 case RISCV::QC_BLTI:
13299 case RISCV::QC_BLTUI:
13300 case RISCV::QC_BNEI: {
13301 switch (OpNum) {
13302 case 2:
13303 // op: imm12
13304 return 7;
13305 case 1:
13306 // op: rs2
13307 return 20;
13308 case 0:
13309 // op: rs1
13310 return 15;
13311 }
13312 break;
13313 }
13314 case RISCV::AIF_FBC_PS:
13315 case RISCV::AIF_FLQ2:
13316 case RISCV::AIF_FLW_PS:
13317 case RISCV::CSRRC:
13318 case RISCV::CSRRCI:
13319 case RISCV::CSRRS:
13320 case RISCV::CSRRSI:
13321 case RISCV::CSRRW:
13322 case RISCV::CSRRWI: {
13323 switch (OpNum) {
13324 case 2:
13325 // op: rs1
13326 return 15;
13327 case 0:
13328 // op: rd
13329 return 7;
13330 case 1:
13331 // op: imm12
13332 return 20;
13333 }
13334 break;
13335 }
13336 case RISCV::CV_LBU_ri_inc:
13337 case RISCV::CV_LB_ri_inc:
13338 case RISCV::CV_LHU_ri_inc:
13339 case RISCV::CV_LH_ri_inc:
13340 case RISCV::CV_LW_ri_inc: {
13341 switch (OpNum) {
13342 case 2:
13343 // op: rs1
13344 return 15;
13345 case 0:
13346 // op: rd
13347 return 7;
13348 case 3:
13349 // op: imm12
13350 return 20;
13351 }
13352 break;
13353 }
13354 case RISCV::TH_LBIA:
13355 case RISCV::TH_LBIB:
13356 case RISCV::TH_LBUIA:
13357 case RISCV::TH_LBUIB:
13358 case RISCV::TH_LDIA:
13359 case RISCV::TH_LDIB:
13360 case RISCV::TH_LHIA:
13361 case RISCV::TH_LHIB:
13362 case RISCV::TH_LHUIA:
13363 case RISCV::TH_LHUIB:
13364 case RISCV::TH_LWIA:
13365 case RISCV::TH_LWIB:
13366 case RISCV::TH_LWUIA:
13367 case RISCV::TH_LWUIB: {
13368 switch (OpNum) {
13369 case 2:
13370 // op: rs1
13371 return 15;
13372 case 0:
13373 // op: rd
13374 return 7;
13375 case 3:
13376 // op: simm5
13377 return 20;
13378 case 4:
13379 // op: uimm2
13380 return 25;
13381 }
13382 break;
13383 }
13384 case RISCV::QC_INSBRI: {
13385 switch (OpNum) {
13386 case 2:
13387 // op: rs1
13388 return 15;
13389 case 1:
13390 // op: rd
13391 return 7;
13392 case 3:
13393 // op: imm11
13394 return 20;
13395 }
13396 break;
13397 }
13398 case RISCV::QC_MULIADD: {
13399 switch (OpNum) {
13400 case 2:
13401 // op: rs1
13402 return 15;
13403 case 1:
13404 // op: rd
13405 return 7;
13406 case 3:
13407 // op: imm12
13408 return 20;
13409 }
13410 break;
13411 }
13412 case RISCV::CV_INSERT_B:
13413 case RISCV::CV_INSERT_H:
13414 case RISCV::CV_SDOTSP_SCI_B:
13415 case RISCV::CV_SDOTSP_SCI_H:
13416 case RISCV::CV_SDOTUP_SCI_B:
13417 case RISCV::CV_SDOTUP_SCI_H:
13418 case RISCV::CV_SDOTUSP_SCI_B:
13419 case RISCV::CV_SDOTUSP_SCI_H: {
13420 switch (OpNum) {
13421 case 2:
13422 // op: rs1
13423 return 15;
13424 case 1:
13425 // op: rd
13426 return 7;
13427 case 3:
13428 // op: imm6
13429 return 20;
13430 }
13431 break;
13432 }
13433 case RISCV::CV_INSERT: {
13434 switch (OpNum) {
13435 case 2:
13436 // op: rs1
13437 return 15;
13438 case 1:
13439 // op: rd
13440 return 7;
13441 case 3:
13442 // op: is3
13443 return 25;
13444 case 4:
13445 // op: is2
13446 return 20;
13447 }
13448 break;
13449 }
13450 case RISCV::QC_SELECTIIEQ:
13451 case RISCV::QC_SELECTIINE: {
13452 switch (OpNum) {
13453 case 2:
13454 // op: rs1
13455 return 15;
13456 case 1:
13457 // op: rd
13458 return 7;
13459 case 3:
13460 // op: simm1
13461 return 20;
13462 case 4:
13463 // op: simm2
13464 return 27;
13465 }
13466 break;
13467 }
13468 case RISCV::TH_SBIA:
13469 case RISCV::TH_SBIB:
13470 case RISCV::TH_SDIA:
13471 case RISCV::TH_SDIB:
13472 case RISCV::TH_SHIA:
13473 case RISCV::TH_SHIB:
13474 case RISCV::TH_SWIA:
13475 case RISCV::TH_SWIB: {
13476 switch (OpNum) {
13477 case 2:
13478 // op: rs1
13479 return 15;
13480 case 1:
13481 // op: rd
13482 return 7;
13483 case 3:
13484 // op: simm5
13485 return 20;
13486 case 4:
13487 // op: uimm2
13488 return 25;
13489 }
13490 break;
13491 }
13492 case RISCV::QC_INSB:
13493 case RISCV::QC_INSBH: {
13494 switch (OpNum) {
13495 case 2:
13496 // op: rs1
13497 return 15;
13498 case 1:
13499 // op: rd
13500 return 7;
13501 case 4:
13502 // op: shamt
13503 return 20;
13504 case 3:
13505 // op: width
13506 return 25;
13507 }
13508 break;
13509 }
13510 case RISCV::AES32DSI:
13511 case RISCV::AES32DSMI:
13512 case RISCV::AES32ESI:
13513 case RISCV::AES32ESMI:
13514 case RISCV::SM4ED:
13515 case RISCV::SM4KS: {
13516 switch (OpNum) {
13517 case 2:
13518 // op: rs2
13519 return 20;
13520 case 1:
13521 // op: rs1
13522 return 15;
13523 case 0:
13524 // op: rd
13525 return 7;
13526 case 3:
13527 // op: bs
13528 return 30;
13529 }
13530 break;
13531 }
13532 case RISCV::QC_LWM:
13533 case RISCV::QC_LWMI:
13534 case RISCV::QC_SETWM:
13535 case RISCV::QC_SETWMI:
13536 case RISCV::QC_SWM:
13537 case RISCV::QC_SWMI: {
13538 switch (OpNum) {
13539 case 2:
13540 // op: rs2
13541 return 20;
13542 case 1:
13543 // op: rs1
13544 return 15;
13545 case 0:
13546 // op: rd
13547 return 7;
13548 case 3:
13549 // op: imm
13550 return 25;
13551 }
13552 break;
13553 }
13554 case RISCV::CV_ADDN:
13555 case RISCV::CV_ADDRN:
13556 case RISCV::CV_ADDUN:
13557 case RISCV::CV_ADDURN:
13558 case RISCV::CV_MULHHSN:
13559 case RISCV::CV_MULHHSRN:
13560 case RISCV::CV_MULHHUN:
13561 case RISCV::CV_MULHHURN:
13562 case RISCV::CV_MULSN:
13563 case RISCV::CV_MULSRN:
13564 case RISCV::CV_MULUN:
13565 case RISCV::CV_MULURN:
13566 case RISCV::CV_SUBN:
13567 case RISCV::CV_SUBRN:
13568 case RISCV::CV_SUBUN:
13569 case RISCV::CV_SUBURN: {
13570 switch (OpNum) {
13571 case 2:
13572 // op: rs2
13573 return 20;
13574 case 1:
13575 // op: rs1
13576 return 15;
13577 case 0:
13578 // op: rd
13579 return 7;
13580 case 3:
13581 // op: imm5
13582 return 25;
13583 }
13584 break;
13585 }
13586 case RISCV::QC_LRB:
13587 case RISCV::QC_LRBU:
13588 case RISCV::QC_LRH:
13589 case RISCV::QC_LRHU:
13590 case RISCV::QC_LRW:
13591 case RISCV::QC_SHLADD:
13592 case RISCV::QC_SRB:
13593 case RISCV::QC_SRH:
13594 case RISCV::QC_SRW: {
13595 switch (OpNum) {
13596 case 2:
13597 // op: rs2
13598 return 20;
13599 case 1:
13600 // op: rs1
13601 return 15;
13602 case 0:
13603 // op: rd
13604 return 7;
13605 case 3:
13606 // op: shamt
13607 return 25;
13608 }
13609 break;
13610 }
13611 case RISCV::TH_ADDSL:
13612 case RISCV::TH_FLRD:
13613 case RISCV::TH_FLRW:
13614 case RISCV::TH_FLURD:
13615 case RISCV::TH_FLURW:
13616 case RISCV::TH_FSRD:
13617 case RISCV::TH_FSRW:
13618 case RISCV::TH_FSURD:
13619 case RISCV::TH_FSURW:
13620 case RISCV::TH_LRB:
13621 case RISCV::TH_LRBU:
13622 case RISCV::TH_LRD:
13623 case RISCV::TH_LRH:
13624 case RISCV::TH_LRHU:
13625 case RISCV::TH_LRW:
13626 case RISCV::TH_LRWU:
13627 case RISCV::TH_LURB:
13628 case RISCV::TH_LURBU:
13629 case RISCV::TH_LURD:
13630 case RISCV::TH_LURH:
13631 case RISCV::TH_LURHU:
13632 case RISCV::TH_LURW:
13633 case RISCV::TH_LURWU:
13634 case RISCV::TH_SRB:
13635 case RISCV::TH_SRD:
13636 case RISCV::TH_SRH:
13637 case RISCV::TH_SRW:
13638 case RISCV::TH_SURB:
13639 case RISCV::TH_SURD:
13640 case RISCV::TH_SURH:
13641 case RISCV::TH_SURW: {
13642 switch (OpNum) {
13643 case 2:
13644 // op: rs2
13645 return 20;
13646 case 1:
13647 // op: rs1
13648 return 15;
13649 case 0:
13650 // op: rd
13651 return 7;
13652 case 3:
13653 // op: uimm2
13654 return 25;
13655 }
13656 break;
13657 }
13658 case RISCV::AADD:
13659 case RISCV::AADDU:
13660 case RISCV::ADD:
13661 case RISCV::ADDW:
13662 case RISCV::ADD_UW:
13663 case RISCV::AES64DS:
13664 case RISCV::AES64DSM:
13665 case RISCV::AES64ES:
13666 case RISCV::AES64ESM:
13667 case RISCV::AES64KS2:
13668 case RISCV::AIF_BITMIXB:
13669 case RISCV::AIF_CUBEFACEIDX_PS:
13670 case RISCV::AIF_CUBEFACE_PS:
13671 case RISCV::AIF_CUBESGNSC_PS:
13672 case RISCV::AIF_CUBESGNTC_PS:
13673 case RISCV::AIF_FADD_PI:
13674 case RISCV::AIF_FAMOADDG_PI:
13675 case RISCV::AIF_FAMOADDL_PI:
13676 case RISCV::AIF_FAMOANDG_PI:
13677 case RISCV::AIF_FAMOANDL_PI:
13678 case RISCV::AIF_FAMOMAXG_PI:
13679 case RISCV::AIF_FAMOMAXG_PS:
13680 case RISCV::AIF_FAMOMAXL_PI:
13681 case RISCV::AIF_FAMOMAXL_PS:
13682 case RISCV::AIF_FAMOMAXUG_PI:
13683 case RISCV::AIF_FAMOMAXUL_PI:
13684 case RISCV::AIF_FAMOMING_PI:
13685 case RISCV::AIF_FAMOMING_PS:
13686 case RISCV::AIF_FAMOMINL_PI:
13687 case RISCV::AIF_FAMOMINL_PS:
13688 case RISCV::AIF_FAMOMINUG_PI:
13689 case RISCV::AIF_FAMOMINUL_PI:
13690 case RISCV::AIF_FAMOORG_PI:
13691 case RISCV::AIF_FAMOORL_PI:
13692 case RISCV::AIF_FAMOSWAPG_PI:
13693 case RISCV::AIF_FAMOSWAPL_PI:
13694 case RISCV::AIF_FAMOXORG_PI:
13695 case RISCV::AIF_FAMOXORL_PI:
13696 case RISCV::AIF_FAND_PI:
13697 case RISCV::AIF_FCMOVM_PS:
13698 case RISCV::AIF_FDIVU_PI:
13699 case RISCV::AIF_FDIV_PI:
13700 case RISCV::AIF_FEQM_PS:
13701 case RISCV::AIF_FEQ_PI:
13702 case RISCV::AIF_FEQ_PS:
13703 case RISCV::AIF_FG32B_PS:
13704 case RISCV::AIF_FG32H_PS:
13705 case RISCV::AIF_FG32W_PS:
13706 case RISCV::AIF_FGBG_PS:
13707 case RISCV::AIF_FGBL_PS:
13708 case RISCV::AIF_FGB_PS:
13709 case RISCV::AIF_FGHG_PS:
13710 case RISCV::AIF_FGHL_PS:
13711 case RISCV::AIF_FGH_PS:
13712 case RISCV::AIF_FGWG_PS:
13713 case RISCV::AIF_FGWL_PS:
13714 case RISCV::AIF_FGW_PS:
13715 case RISCV::AIF_FLEM_PS:
13716 case RISCV::AIF_FLE_PI:
13717 case RISCV::AIF_FLE_PS:
13718 case RISCV::AIF_FLTM_PI:
13719 case RISCV::AIF_FLTM_PS:
13720 case RISCV::AIF_FLTU_PI:
13721 case RISCV::AIF_FLT_PI:
13722 case RISCV::AIF_FLT_PS:
13723 case RISCV::AIF_FMAXU_PI:
13724 case RISCV::AIF_FMAX_PI:
13725 case RISCV::AIF_FMAX_PS:
13726 case RISCV::AIF_FMINU_PI:
13727 case RISCV::AIF_FMIN_PI:
13728 case RISCV::AIF_FMIN_PS:
13729 case RISCV::AIF_FMULHU_PI:
13730 case RISCV::AIF_FMULH_PI:
13731 case RISCV::AIF_FMUL_PI:
13732 case RISCV::AIF_FOR_PI:
13733 case RISCV::AIF_FRCP_FIX_RAST:
13734 case RISCV::AIF_FREMU_PI:
13735 case RISCV::AIF_FREM_PI:
13736 case RISCV::AIF_FSGNJN_PS:
13737 case RISCV::AIF_FSGNJX_PS:
13738 case RISCV::AIF_FSGNJ_PS:
13739 case RISCV::AIF_FSLL_PI:
13740 case RISCV::AIF_FSRA_PI:
13741 case RISCV::AIF_FSRL_PI:
13742 case RISCV::AIF_FSUB_PI:
13743 case RISCV::AIF_FXOR_PI:
13744 case RISCV::AIF_MASKAND:
13745 case RISCV::AIF_MASKOR:
13746 case RISCV::AIF_MASKXOR:
13747 case RISCV::AIF_PACKB:
13748 case RISCV::AND:
13749 case RISCV::ANDN:
13750 case RISCV::ASUB:
13751 case RISCV::ASUBU:
13752 case RISCV::BCLR:
13753 case RISCV::BEXT:
13754 case RISCV::BINV:
13755 case RISCV::BSET:
13756 case RISCV::CLMUL:
13757 case RISCV::CLMULH:
13758 case RISCV::CLMULR:
13759 case RISCV::CV_ADD_B:
13760 case RISCV::CV_ADD_DIV2:
13761 case RISCV::CV_ADD_DIV4:
13762 case RISCV::CV_ADD_DIV8:
13763 case RISCV::CV_ADD_H:
13764 case RISCV::CV_ADD_SC_B:
13765 case RISCV::CV_ADD_SC_H:
13766 case RISCV::CV_AND_B:
13767 case RISCV::CV_AND_H:
13768 case RISCV::CV_AND_SC_B:
13769 case RISCV::CV_AND_SC_H:
13770 case RISCV::CV_AVGU_B:
13771 case RISCV::CV_AVGU_H:
13772 case RISCV::CV_AVGU_SC_B:
13773 case RISCV::CV_AVGU_SC_H:
13774 case RISCV::CV_AVG_B:
13775 case RISCV::CV_AVG_H:
13776 case RISCV::CV_AVG_SC_B:
13777 case RISCV::CV_AVG_SC_H:
13778 case RISCV::CV_BCLRR:
13779 case RISCV::CV_BSETR:
13780 case RISCV::CV_CLIPR:
13781 case RISCV::CV_CLIPUR:
13782 case RISCV::CV_CMPEQ_B:
13783 case RISCV::CV_CMPEQ_H:
13784 case RISCV::CV_CMPEQ_SC_B:
13785 case RISCV::CV_CMPEQ_SC_H:
13786 case RISCV::CV_CMPGEU_B:
13787 case RISCV::CV_CMPGEU_H:
13788 case RISCV::CV_CMPGEU_SC_B:
13789 case RISCV::CV_CMPGEU_SC_H:
13790 case RISCV::CV_CMPGE_B:
13791 case RISCV::CV_CMPGE_H:
13792 case RISCV::CV_CMPGE_SC_B:
13793 case RISCV::CV_CMPGE_SC_H:
13794 case RISCV::CV_CMPGTU_B:
13795 case RISCV::CV_CMPGTU_H:
13796 case RISCV::CV_CMPGTU_SC_B:
13797 case RISCV::CV_CMPGTU_SC_H:
13798 case RISCV::CV_CMPGT_B:
13799 case RISCV::CV_CMPGT_H:
13800 case RISCV::CV_CMPGT_SC_B:
13801 case RISCV::CV_CMPGT_SC_H:
13802 case RISCV::CV_CMPLEU_B:
13803 case RISCV::CV_CMPLEU_H:
13804 case RISCV::CV_CMPLEU_SC_B:
13805 case RISCV::CV_CMPLEU_SC_H:
13806 case RISCV::CV_CMPLE_B:
13807 case RISCV::CV_CMPLE_H:
13808 case RISCV::CV_CMPLE_SC_B:
13809 case RISCV::CV_CMPLE_SC_H:
13810 case RISCV::CV_CMPLTU_B:
13811 case RISCV::CV_CMPLTU_H:
13812 case RISCV::CV_CMPLTU_SC_B:
13813 case RISCV::CV_CMPLTU_SC_H:
13814 case RISCV::CV_CMPLT_B:
13815 case RISCV::CV_CMPLT_H:
13816 case RISCV::CV_CMPLT_SC_B:
13817 case RISCV::CV_CMPLT_SC_H:
13818 case RISCV::CV_CMPNE_B:
13819 case RISCV::CV_CMPNE_H:
13820 case RISCV::CV_CMPNE_SC_B:
13821 case RISCV::CV_CMPNE_SC_H:
13822 case RISCV::CV_DOTSP_B:
13823 case RISCV::CV_DOTSP_H:
13824 case RISCV::CV_DOTSP_SC_B:
13825 case RISCV::CV_DOTSP_SC_H:
13826 case RISCV::CV_DOTUP_B:
13827 case RISCV::CV_DOTUP_H:
13828 case RISCV::CV_DOTUP_SC_B:
13829 case RISCV::CV_DOTUP_SC_H:
13830 case RISCV::CV_DOTUSP_B:
13831 case RISCV::CV_DOTUSP_H:
13832 case RISCV::CV_DOTUSP_SC_B:
13833 case RISCV::CV_DOTUSP_SC_H:
13834 case RISCV::CV_EXTRACTR:
13835 case RISCV::CV_EXTRACTUR:
13836 case RISCV::CV_LBU_rr:
13837 case RISCV::CV_LB_rr:
13838 case RISCV::CV_LHU_rr:
13839 case RISCV::CV_LH_rr:
13840 case RISCV::CV_LW_rr:
13841 case RISCV::CV_MAX:
13842 case RISCV::CV_MAXU:
13843 case RISCV::CV_MAXU_B:
13844 case RISCV::CV_MAXU_H:
13845 case RISCV::CV_MAXU_SC_B:
13846 case RISCV::CV_MAXU_SC_H:
13847 case RISCV::CV_MAX_B:
13848 case RISCV::CV_MAX_H:
13849 case RISCV::CV_MAX_SC_B:
13850 case RISCV::CV_MAX_SC_H:
13851 case RISCV::CV_MIN:
13852 case RISCV::CV_MINU:
13853 case RISCV::CV_MINU_B:
13854 case RISCV::CV_MINU_H:
13855 case RISCV::CV_MINU_SC_B:
13856 case RISCV::CV_MINU_SC_H:
13857 case RISCV::CV_MIN_B:
13858 case RISCV::CV_MIN_H:
13859 case RISCV::CV_MIN_SC_B:
13860 case RISCV::CV_MIN_SC_H:
13861 case RISCV::CV_OR_B:
13862 case RISCV::CV_OR_H:
13863 case RISCV::CV_OR_SC_B:
13864 case RISCV::CV_OR_SC_H:
13865 case RISCV::CV_PACK:
13866 case RISCV::CV_PACK_H:
13867 case RISCV::CV_ROR:
13868 case RISCV::CV_SHUFFLE_B:
13869 case RISCV::CV_SHUFFLE_H:
13870 case RISCV::CV_SLE:
13871 case RISCV::CV_SLEU:
13872 case RISCV::CV_SLL_B:
13873 case RISCV::CV_SLL_H:
13874 case RISCV::CV_SLL_SC_B:
13875 case RISCV::CV_SLL_SC_H:
13876 case RISCV::CV_SRA_B:
13877 case RISCV::CV_SRA_H:
13878 case RISCV::CV_SRA_SC_B:
13879 case RISCV::CV_SRA_SC_H:
13880 case RISCV::CV_SRL_B:
13881 case RISCV::CV_SRL_H:
13882 case RISCV::CV_SRL_SC_B:
13883 case RISCV::CV_SRL_SC_H:
13884 case RISCV::CV_SUBROTMJ:
13885 case RISCV::CV_SUBROTMJ_DIV2:
13886 case RISCV::CV_SUBROTMJ_DIV4:
13887 case RISCV::CV_SUBROTMJ_DIV8:
13888 case RISCV::CV_SUB_B:
13889 case RISCV::CV_SUB_DIV2:
13890 case RISCV::CV_SUB_DIV4:
13891 case RISCV::CV_SUB_DIV8:
13892 case RISCV::CV_SUB_H:
13893 case RISCV::CV_SUB_SC_B:
13894 case RISCV::CV_SUB_SC_H:
13895 case RISCV::CV_XOR_B:
13896 case RISCV::CV_XOR_H:
13897 case RISCV::CV_XOR_SC_B:
13898 case RISCV::CV_XOR_SC_H:
13899 case RISCV::CZERO_EQZ:
13900 case RISCV::CZERO_NEZ:
13901 case RISCV::DIV:
13902 case RISCV::DIVU:
13903 case RISCV::DIVUW:
13904 case RISCV::DIVW:
13905 case RISCV::FEQ_D:
13906 case RISCV::FEQ_D_IN32X:
13907 case RISCV::FEQ_D_INX:
13908 case RISCV::FEQ_H:
13909 case RISCV::FEQ_H_INX:
13910 case RISCV::FEQ_Q:
13911 case RISCV::FEQ_S:
13912 case RISCV::FEQ_S_INX:
13913 case RISCV::FLEQ_D:
13914 case RISCV::FLEQ_H:
13915 case RISCV::FLEQ_Q:
13916 case RISCV::FLEQ_S:
13917 case RISCV::FLE_D:
13918 case RISCV::FLE_D_IN32X:
13919 case RISCV::FLE_D_INX:
13920 case RISCV::FLE_H:
13921 case RISCV::FLE_H_INX:
13922 case RISCV::FLE_Q:
13923 case RISCV::FLE_S:
13924 case RISCV::FLE_S_INX:
13925 case RISCV::FLTQ_D:
13926 case RISCV::FLTQ_H:
13927 case RISCV::FLTQ_Q:
13928 case RISCV::FLTQ_S:
13929 case RISCV::FLT_D:
13930 case RISCV::FLT_D_IN32X:
13931 case RISCV::FLT_D_INX:
13932 case RISCV::FLT_H:
13933 case RISCV::FLT_H_INX:
13934 case RISCV::FLT_Q:
13935 case RISCV::FLT_S:
13936 case RISCV::FLT_S_INX:
13937 case RISCV::FMAXM_D:
13938 case RISCV::FMAXM_H:
13939 case RISCV::FMAXM_Q:
13940 case RISCV::FMAXM_S:
13941 case RISCV::FMAX_D:
13942 case RISCV::FMAX_D_IN32X:
13943 case RISCV::FMAX_D_INX:
13944 case RISCV::FMAX_H:
13945 case RISCV::FMAX_H_INX:
13946 case RISCV::FMAX_Q:
13947 case RISCV::FMAX_S:
13948 case RISCV::FMAX_S_INX:
13949 case RISCV::FMINM_D:
13950 case RISCV::FMINM_H:
13951 case RISCV::FMINM_Q:
13952 case RISCV::FMINM_S:
13953 case RISCV::FMIN_D:
13954 case RISCV::FMIN_D_IN32X:
13955 case RISCV::FMIN_D_INX:
13956 case RISCV::FMIN_H:
13957 case RISCV::FMIN_H_INX:
13958 case RISCV::FMIN_Q:
13959 case RISCV::FMIN_S:
13960 case RISCV::FMIN_S_INX:
13961 case RISCV::FMVP_D_X:
13962 case RISCV::FMVP_Q_X:
13963 case RISCV::FSGNJN_D:
13964 case RISCV::FSGNJN_D_IN32X:
13965 case RISCV::FSGNJN_D_INX:
13966 case RISCV::FSGNJN_H:
13967 case RISCV::FSGNJN_H_INX:
13968 case RISCV::FSGNJN_Q:
13969 case RISCV::FSGNJN_S:
13970 case RISCV::FSGNJN_S_INX:
13971 case RISCV::FSGNJX_D:
13972 case RISCV::FSGNJX_D_IN32X:
13973 case RISCV::FSGNJX_D_INX:
13974 case RISCV::FSGNJX_H:
13975 case RISCV::FSGNJX_H_INX:
13976 case RISCV::FSGNJX_Q:
13977 case RISCV::FSGNJX_S:
13978 case RISCV::FSGNJX_S_INX:
13979 case RISCV::FSGNJ_D:
13980 case RISCV::FSGNJ_D_IN32X:
13981 case RISCV::FSGNJ_D_INX:
13982 case RISCV::FSGNJ_H:
13983 case RISCV::FSGNJ_H_INX:
13984 case RISCV::FSGNJ_Q:
13985 case RISCV::FSGNJ_S:
13986 case RISCV::FSGNJ_S_INX:
13987 case RISCV::MAX:
13988 case RISCV::MAXU:
13989 case RISCV::MIN:
13990 case RISCV::MINU:
13991 case RISCV::MOP_RR_0:
13992 case RISCV::MOP_RR_1:
13993 case RISCV::MOP_RR_2:
13994 case RISCV::MOP_RR_3:
13995 case RISCV::MOP_RR_4:
13996 case RISCV::MOP_RR_5:
13997 case RISCV::MOP_RR_6:
13998 case RISCV::MOP_RR_7:
13999 case RISCV::MSEQ:
14000 case RISCV::MSLT:
14001 case RISCV::MSLTU:
14002 case RISCV::MUL:
14003 case RISCV::MULH:
14004 case RISCV::MULHR:
14005 case RISCV::MULHRSU:
14006 case RISCV::MULHRU:
14007 case RISCV::MULHSU:
14008 case RISCV::MULHSU_H0:
14009 case RISCV::MULHSU_H1:
14010 case RISCV::MULHU:
14011 case RISCV::MULH_H0:
14012 case RISCV::MULH_H1:
14013 case RISCV::MULQ:
14014 case RISCV::MULQR:
14015 case RISCV::MULSU_H00:
14016 case RISCV::MULSU_H11:
14017 case RISCV::MULSU_W00:
14018 case RISCV::MULSU_W11:
14019 case RISCV::MULU_H00:
14020 case RISCV::MULU_H01:
14021 case RISCV::MULU_H11:
14022 case RISCV::MULU_W00:
14023 case RISCV::MULU_W01:
14024 case RISCV::MULU_W11:
14025 case RISCV::MULW:
14026 case RISCV::MUL_H00:
14027 case RISCV::MUL_H01:
14028 case RISCV::MUL_H11:
14029 case RISCV::MUL_W00:
14030 case RISCV::MUL_W01:
14031 case RISCV::MUL_W11:
14032 case RISCV::NDS_FFB:
14033 case RISCV::NDS_FFMISM:
14034 case RISCV::NDS_FFZMISM:
14035 case RISCV::NDS_FLMISM:
14036 case RISCV::OR:
14037 case RISCV::ORN:
14038 case RISCV::PAADDU_B:
14039 case RISCV::PAADDU_H:
14040 case RISCV::PAADDU_W:
14041 case RISCV::PAADD_B:
14042 case RISCV::PAADD_H:
14043 case RISCV::PAADD_W:
14044 case RISCV::PAAS_HX:
14045 case RISCV::PAAS_WX:
14046 case RISCV::PABDSUMU_B:
14047 case RISCV::PABDU_B:
14048 case RISCV::PABDU_H:
14049 case RISCV::PABD_B:
14050 case RISCV::PABD_H:
14051 case RISCV::PACK:
14052 case RISCV::PACKH:
14053 case RISCV::PACKW:
14054 case RISCV::PADD_B:
14055 case RISCV::PADD_BS:
14056 case RISCV::PADD_H:
14057 case RISCV::PADD_HS:
14058 case RISCV::PADD_W:
14059 case RISCV::PADD_WS:
14060 case RISCV::PASA_HX:
14061 case RISCV::PASA_WX:
14062 case RISCV::PASUBU_B:
14063 case RISCV::PASUBU_H:
14064 case RISCV::PASUBU_W:
14065 case RISCV::PASUB_B:
14066 case RISCV::PASUB_H:
14067 case RISCV::PASUB_W:
14068 case RISCV::PAS_HX:
14069 case RISCV::PAS_WX:
14070 case RISCV::PM2ADDSU_H:
14071 case RISCV::PM2ADDSU_W:
14072 case RISCV::PM2ADDU_H:
14073 case RISCV::PM2ADDU_W:
14074 case RISCV::PM2ADD_H:
14075 case RISCV::PM2ADD_HX:
14076 case RISCV::PM2ADD_W:
14077 case RISCV::PM2ADD_WX:
14078 case RISCV::PM2SADD_H:
14079 case RISCV::PM2SADD_HX:
14080 case RISCV::PM2SUB_H:
14081 case RISCV::PM2SUB_HX:
14082 case RISCV::PM2SUB_W:
14083 case RISCV::PM2SUB_WX:
14084 case RISCV::PM4ADDSU_B:
14085 case RISCV::PM4ADDSU_H:
14086 case RISCV::PM4ADDU_B:
14087 case RISCV::PM4ADDU_H:
14088 case RISCV::PM4ADD_B:
14089 case RISCV::PM4ADD_H:
14090 case RISCV::PMAXU_B:
14091 case RISCV::PMAXU_H:
14092 case RISCV::PMAXU_W:
14093 case RISCV::PMAX_B:
14094 case RISCV::PMAX_H:
14095 case RISCV::PMAX_W:
14096 case RISCV::PMINU_B:
14097 case RISCV::PMINU_H:
14098 case RISCV::PMINU_W:
14099 case RISCV::PMIN_B:
14100 case RISCV::PMIN_H:
14101 case RISCV::PMIN_W:
14102 case RISCV::PMQ2ADD_H:
14103 case RISCV::PMQ2ADD_W:
14104 case RISCV::PMQR2ADD_H:
14105 case RISCV::PMQR2ADD_W:
14106 case RISCV::PMSEQ_B:
14107 case RISCV::PMSEQ_H:
14108 case RISCV::PMSEQ_W:
14109 case RISCV::PMSLTU_B:
14110 case RISCV::PMSLTU_H:
14111 case RISCV::PMSLTU_W:
14112 case RISCV::PMSLT_B:
14113 case RISCV::PMSLT_H:
14114 case RISCV::PMSLT_W:
14115 case RISCV::PMULHRSU_H:
14116 case RISCV::PMULHRSU_W:
14117 case RISCV::PMULHRU_H:
14118 case RISCV::PMULHRU_W:
14119 case RISCV::PMULHR_H:
14120 case RISCV::PMULHR_W:
14121 case RISCV::PMULHSU_H:
14122 case RISCV::PMULHSU_H_B0:
14123 case RISCV::PMULHSU_H_B1:
14124 case RISCV::PMULHSU_W:
14125 case RISCV::PMULHSU_W_H0:
14126 case RISCV::PMULHSU_W_H1:
14127 case RISCV::PMULHU_H:
14128 case RISCV::PMULHU_W:
14129 case RISCV::PMULH_H:
14130 case RISCV::PMULH_H_B0:
14131 case RISCV::PMULH_H_B1:
14132 case RISCV::PMULH_W:
14133 case RISCV::PMULH_W_H0:
14134 case RISCV::PMULH_W_H1:
14135 case RISCV::PMULQR_H:
14136 case RISCV::PMULQR_W:
14137 case RISCV::PMULQ_H:
14138 case RISCV::PMULQ_W:
14139 case RISCV::PMULSU_H_B00:
14140 case RISCV::PMULSU_H_B11:
14141 case RISCV::PMULSU_W_H00:
14142 case RISCV::PMULSU_W_H11:
14143 case RISCV::PMULU_H_B00:
14144 case RISCV::PMULU_H_B01:
14145 case RISCV::PMULU_H_B11:
14146 case RISCV::PMULU_W_H00:
14147 case RISCV::PMULU_W_H01:
14148 case RISCV::PMULU_W_H11:
14149 case RISCV::PMUL_H_B00:
14150 case RISCV::PMUL_H_B01:
14151 case RISCV::PMUL_H_B11:
14152 case RISCV::PMUL_W_H00:
14153 case RISCV::PMUL_W_H01:
14154 case RISCV::PMUL_W_H11:
14155 case RISCV::PNCLIPP_B:
14156 case RISCV::PNCLIPP_H:
14157 case RISCV::PNCLIPP_W:
14158 case RISCV::PNCLIPUP_B:
14159 case RISCV::PNCLIPUP_H:
14160 case RISCV::PNCLIPUP_W:
14161 case RISCV::PPAIREO_B:
14162 case RISCV::PPAIREO_H:
14163 case RISCV::PPAIREO_W:
14164 case RISCV::PPAIRE_B:
14165 case RISCV::PPAIRE_H:
14166 case RISCV::PPAIROE_B:
14167 case RISCV::PPAIROE_H:
14168 case RISCV::PPAIROE_W:
14169 case RISCV::PPAIRO_B:
14170 case RISCV::PPAIRO_H:
14171 case RISCV::PPAIRO_W:
14172 case RISCV::PREDSUMU_BS:
14173 case RISCV::PREDSUMU_HS:
14174 case RISCV::PREDSUMU_WS:
14175 case RISCV::PREDSUM_BS:
14176 case RISCV::PREDSUM_HS:
14177 case RISCV::PREDSUM_WS:
14178 case RISCV::PSADDU_B:
14179 case RISCV::PSADDU_H:
14180 case RISCV::PSADDU_W:
14181 case RISCV::PSADD_B:
14182 case RISCV::PSADD_H:
14183 case RISCV::PSADD_W:
14184 case RISCV::PSAS_HX:
14185 case RISCV::PSAS_WX:
14186 case RISCV::PSA_HX:
14187 case RISCV::PSA_WX:
14188 case RISCV::PSH1ADD_H:
14189 case RISCV::PSH1ADD_W:
14190 case RISCV::PSLL_BS:
14191 case RISCV::PSLL_HS:
14192 case RISCV::PSLL_WS:
14193 case RISCV::PSRA_BS:
14194 case RISCV::PSRA_HS:
14195 case RISCV::PSRA_WS:
14196 case RISCV::PSRL_BS:
14197 case RISCV::PSRL_HS:
14198 case RISCV::PSRL_WS:
14199 case RISCV::PSSA_HX:
14200 case RISCV::PSSA_WX:
14201 case RISCV::PSSH1SADD_H:
14202 case RISCV::PSSH1SADD_W:
14203 case RISCV::PSSHAR_HS:
14204 case RISCV::PSSHAR_WS:
14205 case RISCV::PSSHA_HS:
14206 case RISCV::PSSHA_WS:
14207 case RISCV::PSSHLR_HS:
14208 case RISCV::PSSHLR_WS:
14209 case RISCV::PSSHL_HS:
14210 case RISCV::PSSHL_WS:
14211 case RISCV::PSSUBU_B:
14212 case RISCV::PSSUBU_H:
14213 case RISCV::PSSUBU_W:
14214 case RISCV::PSSUB_B:
14215 case RISCV::PSSUB_H:
14216 case RISCV::PSSUB_W:
14217 case RISCV::PSUB_B:
14218 case RISCV::PSUB_H:
14219 case RISCV::PSUB_W:
14220 case RISCV::QC_ADDSAT:
14221 case RISCV::QC_ADDUSAT:
14222 case RISCV::QC_CSRRWR:
14223 case RISCV::QC_CSRRWRI:
14224 case RISCV::QC_EXTDPR:
14225 case RISCV::QC_EXTDPRH:
14226 case RISCV::QC_EXTDR:
14227 case RISCV::QC_EXTDUPR:
14228 case RISCV::QC_EXTDUPRH:
14229 case RISCV::QC_EXTDUR:
14230 case RISCV::QC_SHLSAT:
14231 case RISCV::QC_SHLUSAT:
14232 case RISCV::QC_SUBSAT:
14233 case RISCV::QC_SUBUSAT:
14234 case RISCV::QC_WRAP:
14235 case RISCV::REM:
14236 case RISCV::REMU:
14237 case RISCV::REMUW:
14238 case RISCV::REMW:
14239 case RISCV::ROL:
14240 case RISCV::ROLW:
14241 case RISCV::ROR:
14242 case RISCV::RORW:
14243 case RISCV::SADD:
14244 case RISCV::SADDU:
14245 case RISCV::SH1ADD:
14246 case RISCV::SH1ADD_UW:
14247 case RISCV::SH2ADD:
14248 case RISCV::SH2ADD_UW:
14249 case RISCV::SH3ADD:
14250 case RISCV::SH3ADD_UW:
14251 case RISCV::SHA:
14252 case RISCV::SHA512SIG0H:
14253 case RISCV::SHA512SIG0L:
14254 case RISCV::SHA512SIG1H:
14255 case RISCV::SHA512SIG1L:
14256 case RISCV::SHA512SUM0R:
14257 case RISCV::SHA512SUM1R:
14258 case RISCV::SHAR:
14259 case RISCV::SHL:
14260 case RISCV::SHLR:
14261 case RISCV::SLL:
14262 case RISCV::SLLW:
14263 case RISCV::SLT:
14264 case RISCV::SLTU:
14265 case RISCV::SRA:
14266 case RISCV::SRAW:
14267 case RISCV::SRL:
14268 case RISCV::SRLW:
14269 case RISCV::SSH1SADD:
14270 case RISCV::SSHA:
14271 case RISCV::SSHAR:
14272 case RISCV::SSHL:
14273 case RISCV::SSHLR:
14274 case RISCV::SSUB:
14275 case RISCV::SSUBU:
14276 case RISCV::SUB:
14277 case RISCV::SUBW:
14278 case RISCV::UNZIP16HP:
14279 case RISCV::UNZIP16P:
14280 case RISCV::UNZIP8HP:
14281 case RISCV::UNZIP8P:
14282 case RISCV::VSETVL:
14283 case RISCV::VT_MASKC:
14284 case RISCV::VT_MASKCN:
14285 case RISCV::XNOR:
14286 case RISCV::XOR:
14287 case RISCV::XPERM4:
14288 case RISCV::XPERM8:
14289 case RISCV::ZIP16HP:
14290 case RISCV::ZIP16P:
14291 case RISCV::ZIP8HP:
14292 case RISCV::ZIP8P: {
14293 switch (OpNum) {
14294 case 2:
14295 // op: rs2
14296 return 20;
14297 case 1:
14298 // op: rs1
14299 return 15;
14300 case 0:
14301 // op: rd
14302 return 7;
14303 }
14304 break;
14305 }
14306 case RISCV::PM2WADDSU_H:
14307 case RISCV::PM2WADDU_H:
14308 case RISCV::PM2WADD_H:
14309 case RISCV::PM2WADD_HX:
14310 case RISCV::PM2WSUB_H:
14311 case RISCV::PM2WSUB_HX:
14312 case RISCV::PWADDU_B:
14313 case RISCV::PWADDU_H:
14314 case RISCV::PWADD_B:
14315 case RISCV::PWADD_H:
14316 case RISCV::PWMULSU_B:
14317 case RISCV::PWMULSU_H:
14318 case RISCV::PWMULU_B:
14319 case RISCV::PWMULU_H:
14320 case RISCV::PWMUL_B:
14321 case RISCV::PWMUL_H:
14322 case RISCV::PWSLA_BS:
14323 case RISCV::PWSLA_HS:
14324 case RISCV::PWSLL_BS:
14325 case RISCV::PWSLL_HS:
14326 case RISCV::PWSUBU_B:
14327 case RISCV::PWSUBU_H:
14328 case RISCV::PWSUB_B:
14329 case RISCV::PWSUB_H:
14330 case RISCV::WADD:
14331 case RISCV::WADDU:
14332 case RISCV::WMUL:
14333 case RISCV::WMULSU:
14334 case RISCV::WMULU:
14335 case RISCV::WSLA:
14336 case RISCV::WSLL:
14337 case RISCV::WSUB:
14338 case RISCV::WSUBU:
14339 case RISCV::WZIP16P:
14340 case RISCV::WZIP8P: {
14341 switch (OpNum) {
14342 case 2:
14343 // op: rs2
14344 return 20;
14345 case 1:
14346 // op: rs1
14347 return 15;
14348 case 0:
14349 // op: rd
14350 return 8;
14351 }
14352 break;
14353 }
14354 case RISCV::FADD_D:
14355 case RISCV::FADD_D_IN32X:
14356 case RISCV::FADD_D_INX:
14357 case RISCV::FADD_H:
14358 case RISCV::FADD_H_INX:
14359 case RISCV::FADD_Q:
14360 case RISCV::FADD_S:
14361 case RISCV::FADD_S_INX:
14362 case RISCV::FDIV_D:
14363 case RISCV::FDIV_D_IN32X:
14364 case RISCV::FDIV_D_INX:
14365 case RISCV::FDIV_H:
14366 case RISCV::FDIV_H_INX:
14367 case RISCV::FDIV_Q:
14368 case RISCV::FDIV_S:
14369 case RISCV::FDIV_S_INX:
14370 case RISCV::FMUL_D:
14371 case RISCV::FMUL_D_IN32X:
14372 case RISCV::FMUL_D_INX:
14373 case RISCV::FMUL_H:
14374 case RISCV::FMUL_H_INX:
14375 case RISCV::FMUL_Q:
14376 case RISCV::FMUL_S:
14377 case RISCV::FMUL_S_INX:
14378 case RISCV::FSUB_D:
14379 case RISCV::FSUB_D_IN32X:
14380 case RISCV::FSUB_D_INX:
14381 case RISCV::FSUB_H:
14382 case RISCV::FSUB_H_INX:
14383 case RISCV::FSUB_Q:
14384 case RISCV::FSUB_S:
14385 case RISCV::FSUB_S_INX: {
14386 switch (OpNum) {
14387 case 2:
14388 // op: rs2
14389 return 20;
14390 case 1:
14391 // op: rs1
14392 return 15;
14393 case 3:
14394 // op: frm
14395 return 12;
14396 case 0:
14397 // op: rd
14398 return 7;
14399 }
14400 break;
14401 }
14402 case RISCV::AMOCAS_B:
14403 case RISCV::AMOCAS_B_AQ:
14404 case RISCV::AMOCAS_B_AQRL:
14405 case RISCV::AMOCAS_B_RL:
14406 case RISCV::AMOCAS_D_RV32:
14407 case RISCV::AMOCAS_D_RV32_AQ:
14408 case RISCV::AMOCAS_D_RV32_AQRL:
14409 case RISCV::AMOCAS_D_RV32_RL:
14410 case RISCV::AMOCAS_D_RV64:
14411 case RISCV::AMOCAS_D_RV64_AQ:
14412 case RISCV::AMOCAS_D_RV64_AQRL:
14413 case RISCV::AMOCAS_D_RV64_RL:
14414 case RISCV::AMOCAS_H:
14415 case RISCV::AMOCAS_H_AQ:
14416 case RISCV::AMOCAS_H_AQRL:
14417 case RISCV::AMOCAS_H_RL:
14418 case RISCV::AMOCAS_Q:
14419 case RISCV::AMOCAS_Q_AQ:
14420 case RISCV::AMOCAS_Q_AQRL:
14421 case RISCV::AMOCAS_Q_RL:
14422 case RISCV::AMOCAS_W:
14423 case RISCV::AMOCAS_W_AQ:
14424 case RISCV::AMOCAS_W_AQRL:
14425 case RISCV::AMOCAS_W_RL: {
14426 switch (OpNum) {
14427 case 2:
14428 // op: rs2
14429 return 20;
14430 case 3:
14431 // op: rs1
14432 return 15;
14433 case 1:
14434 // op: rd
14435 return 7;
14436 }
14437 break;
14438 }
14439 case RISCV::C_ADDW:
14440 case RISCV::C_AND:
14441 case RISCV::C_MUL:
14442 case RISCV::C_OR:
14443 case RISCV::C_SUB:
14444 case RISCV::C_SUBW:
14445 case RISCV::C_XOR: {
14446 switch (OpNum) {
14447 case 2:
14448 // op: rs2
14449 return 2;
14450 case 1:
14451 // op: rd
14452 return 7;
14453 }
14454 break;
14455 }
14456 case RISCV::SF_VC_V_I:
14457 case RISCV::SF_VC_V_IV: {
14458 switch (OpNum) {
14459 case 2:
14460 // op: vs2
14461 return 20;
14462 case 0:
14463 // op: vd
14464 return 7;
14465 case 3:
14466 // op: imm
14467 return 15;
14468 case 1:
14469 // op: funct6_lo2
14470 return 26;
14471 }
14472 break;
14473 }
14474 case RISCV::SF_VC_V_FV: {
14475 switch (OpNum) {
14476 case 2:
14477 // op: vs2
14478 return 20;
14479 case 0:
14480 // op: vd
14481 return 7;
14482 case 3:
14483 // op: rs1
14484 return 15;
14485 case 1:
14486 // op: funct6_lo1
14487 return 26;
14488 }
14489 break;
14490 }
14491 case RISCV::SF_VC_V_X:
14492 case RISCV::SF_VC_V_XV: {
14493 switch (OpNum) {
14494 case 2:
14495 // op: vs2
14496 return 20;
14497 case 0:
14498 // op: vd
14499 return 7;
14500 case 3:
14501 // op: rs1
14502 return 15;
14503 case 1:
14504 // op: funct6_lo2
14505 return 26;
14506 }
14507 break;
14508 }
14509 case RISCV::SF_VC_V_VV: {
14510 switch (OpNum) {
14511 case 2:
14512 // op: vs2
14513 return 20;
14514 case 0:
14515 // op: vd
14516 return 7;
14517 case 3:
14518 // op: vs1
14519 return 15;
14520 case 1:
14521 // op: funct6_lo2
14522 return 26;
14523 }
14524 break;
14525 }
14526 case RISCV::SF_VC_IV:
14527 case RISCV::SF_VC_IVV:
14528 case RISCV::SF_VC_IVW: {
14529 switch (OpNum) {
14530 case 2:
14531 // op: vs2
14532 return 20;
14533 case 1:
14534 // op: vd
14535 return 7;
14536 case 3:
14537 // op: imm
14538 return 15;
14539 case 0:
14540 // op: funct6_lo2
14541 return 26;
14542 }
14543 break;
14544 }
14545 case RISCV::SF_VC_FV:
14546 case RISCV::SF_VC_FVV:
14547 case RISCV::SF_VC_FVW: {
14548 switch (OpNum) {
14549 case 2:
14550 // op: vs2
14551 return 20;
14552 case 1:
14553 // op: vd
14554 return 7;
14555 case 3:
14556 // op: rs1
14557 return 15;
14558 case 0:
14559 // op: funct6_lo1
14560 return 26;
14561 }
14562 break;
14563 }
14564 case RISCV::SF_VC_XV:
14565 case RISCV::SF_VC_XVV:
14566 case RISCV::SF_VC_XVW: {
14567 switch (OpNum) {
14568 case 2:
14569 // op: vs2
14570 return 20;
14571 case 1:
14572 // op: vd
14573 return 7;
14574 case 3:
14575 // op: rs1
14576 return 15;
14577 case 0:
14578 // op: funct6_lo2
14579 return 26;
14580 }
14581 break;
14582 }
14583 case RISCV::SF_VC_VV:
14584 case RISCV::SF_VC_VVV:
14585 case RISCV::SF_VC_VVW: {
14586 switch (OpNum) {
14587 case 2:
14588 // op: vs2
14589 return 20;
14590 case 1:
14591 // op: vd
14592 return 7;
14593 case 3:
14594 // op: vs1
14595 return 15;
14596 case 0:
14597 // op: funct6_lo2
14598 return 26;
14599 }
14600 break;
14601 }
14602 case RISCV::NDS_VD4DOTSU_VV:
14603 case RISCV::NDS_VD4DOTS_VV:
14604 case RISCV::NDS_VD4DOTU_VV: {
14605 switch (OpNum) {
14606 case 2:
14607 // op: vs2
14608 return 20;
14609 case 1:
14610 // op: vs1
14611 return 15;
14612 case 0:
14613 // op: vd
14614 return 7;
14615 case 3:
14616 // op: vm
14617 return 25;
14618 }
14619 break;
14620 }
14621 case RISCV::AIF_MASKPOPC_ET_RAST: {
14622 switch (OpNum) {
14623 case 3:
14624 // op: imm
14625 return 18;
14626 case 2:
14627 // op: rs2
14628 return 20;
14629 case 1:
14630 // op: rs1
14631 return 15;
14632 case 0:
14633 // op: rd
14634 return 7;
14635 }
14636 break;
14637 }
14638 case RISCV::CV_SB_ri_inc:
14639 case RISCV::CV_SH_ri_inc:
14640 case RISCV::CV_SW_ri_inc: {
14641 switch (OpNum) {
14642 case 3:
14643 // op: imm12
14644 return 7;
14645 case 1:
14646 // op: rs2
14647 return 20;
14648 case 2:
14649 // op: rs1
14650 return 15;
14651 }
14652 break;
14653 }
14654 case RISCV::MIPS_SDP: {
14655 switch (OpNum) {
14656 case 3:
14657 // op: imm7
14658 return 10;
14659 case 1:
14660 // op: rs3
14661 return 27;
14662 case 0:
14663 // op: rs2
14664 return 20;
14665 case 2:
14666 // op: rs1
14667 return 15;
14668 }
14669 break;
14670 }
14671 case RISCV::MIPS_LWP: {
14672 switch (OpNum) {
14673 case 3:
14674 // op: imm7
14675 return 22;
14676 case 2:
14677 // op: rs1
14678 return 15;
14679 case 0:
14680 // op: rd1
14681 return 7;
14682 case 1:
14683 // op: rd2
14684 return 27;
14685 }
14686 break;
14687 }
14688 case RISCV::MIPS_LDP: {
14689 switch (OpNum) {
14690 case 3:
14691 // op: imm7
14692 return 23;
14693 case 2:
14694 // op: rs1
14695 return 15;
14696 case 0:
14697 // op: rd1
14698 return 7;
14699 case 1:
14700 // op: rd2
14701 return 27;
14702 }
14703 break;
14704 }
14705 case RISCV::MIPS_SWP: {
14706 switch (OpNum) {
14707 case 3:
14708 // op: imm7
14709 return 9;
14710 case 1:
14711 // op: rs3
14712 return 27;
14713 case 0:
14714 // op: rs2
14715 return 20;
14716 case 2:
14717 // op: rs1
14718 return 15;
14719 }
14720 break;
14721 }
14722 case RISCV::QC_SELECTIEQI:
14723 case RISCV::QC_SELECTINEI: {
14724 switch (OpNum) {
14725 case 3:
14726 // op: rs2
14727 return 20;
14728 case 1:
14729 // op: rd
14730 return 7;
14731 case 2:
14732 // op: imm
14733 return 15;
14734 case 4:
14735 // op: simm2
14736 return 27;
14737 }
14738 break;
14739 }
14740 case RISCV::CV_LBU_rr_inc:
14741 case RISCV::CV_LB_rr_inc:
14742 case RISCV::CV_LHU_rr_inc:
14743 case RISCV::CV_LH_rr_inc:
14744 case RISCV::CV_LW_rr_inc: {
14745 switch (OpNum) {
14746 case 3:
14747 // op: rs2
14748 return 20;
14749 case 2:
14750 // op: rs1
14751 return 15;
14752 case 0:
14753 // op: rd
14754 return 7;
14755 }
14756 break;
14757 }
14758 case RISCV::CV_MACHHSN:
14759 case RISCV::CV_MACHHSRN:
14760 case RISCV::CV_MACHHUN:
14761 case RISCV::CV_MACHHURN:
14762 case RISCV::CV_MACSN:
14763 case RISCV::CV_MACSRN:
14764 case RISCV::CV_MACUN:
14765 case RISCV::CV_MACURN: {
14766 switch (OpNum) {
14767 case 3:
14768 // op: rs2
14769 return 20;
14770 case 2:
14771 // op: rs1
14772 return 15;
14773 case 1:
14774 // op: rd
14775 return 7;
14776 case 4:
14777 // op: imm5
14778 return 25;
14779 }
14780 break;
14781 }
14782 case RISCV::QC_LIEQ:
14783 case RISCV::QC_LIEQI:
14784 case RISCV::QC_LIGE:
14785 case RISCV::QC_LIGEI:
14786 case RISCV::QC_LIGEU:
14787 case RISCV::QC_LIGEUI:
14788 case RISCV::QC_LILT:
14789 case RISCV::QC_LILTI:
14790 case RISCV::QC_LILTU:
14791 case RISCV::QC_LILTUI:
14792 case RISCV::QC_LINE:
14793 case RISCV::QC_LINEI: {
14794 switch (OpNum) {
14795 case 3:
14796 // op: rs2
14797 return 20;
14798 case 2:
14799 // op: rs1
14800 return 15;
14801 case 1:
14802 // op: rd
14803 return 7;
14804 case 4:
14805 // op: simm
14806 return 27;
14807 }
14808 break;
14809 }
14810 case RISCV::QC_SELECTIEQ:
14811 case RISCV::QC_SELECTINE: {
14812 switch (OpNum) {
14813 case 3:
14814 // op: rs2
14815 return 20;
14816 case 2:
14817 // op: rs1
14818 return 15;
14819 case 1:
14820 // op: rd
14821 return 7;
14822 case 4:
14823 // op: simm2
14824 return 27;
14825 }
14826 break;
14827 }
14828 case RISCV::CV_ADDNR:
14829 case RISCV::CV_ADDRNR:
14830 case RISCV::CV_ADDUNR:
14831 case RISCV::CV_ADDURNR:
14832 case RISCV::CV_CPLXMUL_I:
14833 case RISCV::CV_CPLXMUL_I_DIV2:
14834 case RISCV::CV_CPLXMUL_I_DIV4:
14835 case RISCV::CV_CPLXMUL_I_DIV8:
14836 case RISCV::CV_CPLXMUL_R:
14837 case RISCV::CV_CPLXMUL_R_DIV2:
14838 case RISCV::CV_CPLXMUL_R_DIV4:
14839 case RISCV::CV_CPLXMUL_R_DIV8:
14840 case RISCV::CV_INSERTR:
14841 case RISCV::CV_MAC:
14842 case RISCV::CV_MSU:
14843 case RISCV::CV_PACKHI_B:
14844 case RISCV::CV_PACKLO_B:
14845 case RISCV::CV_SDOTSP_B:
14846 case RISCV::CV_SDOTSP_H:
14847 case RISCV::CV_SDOTSP_SC_B:
14848 case RISCV::CV_SDOTSP_SC_H:
14849 case RISCV::CV_SDOTUP_B:
14850 case RISCV::CV_SDOTUP_H:
14851 case RISCV::CV_SDOTUP_SC_B:
14852 case RISCV::CV_SDOTUP_SC_H:
14853 case RISCV::CV_SDOTUSP_B:
14854 case RISCV::CV_SDOTUSP_H:
14855 case RISCV::CV_SDOTUSP_SC_B:
14856 case RISCV::CV_SDOTUSP_SC_H:
14857 case RISCV::CV_SHUFFLE2_B:
14858 case RISCV::CV_SHUFFLE2_H:
14859 case RISCV::CV_SUBNR:
14860 case RISCV::CV_SUBRNR:
14861 case RISCV::CV_SUBUNR:
14862 case RISCV::CV_SUBURNR:
14863 case RISCV::MACCSU_H00:
14864 case RISCV::MACCSU_H11:
14865 case RISCV::MACCSU_W00:
14866 case RISCV::MACCSU_W11:
14867 case RISCV::MACCU_H00:
14868 case RISCV::MACCU_H01:
14869 case RISCV::MACCU_H11:
14870 case RISCV::MACCU_W00:
14871 case RISCV::MACCU_W01:
14872 case RISCV::MACCU_W11:
14873 case RISCV::MACC_H00:
14874 case RISCV::MACC_H01:
14875 case RISCV::MACC_H11:
14876 case RISCV::MACC_W00:
14877 case RISCV::MACC_W01:
14878 case RISCV::MACC_W11:
14879 case RISCV::MERGE:
14880 case RISCV::MHACC:
14881 case RISCV::MHACCSU:
14882 case RISCV::MHACCSU_H0:
14883 case RISCV::MHACCSU_H1:
14884 case RISCV::MHACCU:
14885 case RISCV::MHACC_H0:
14886 case RISCV::MHACC_H1:
14887 case RISCV::MHRACC:
14888 case RISCV::MHRACCSU:
14889 case RISCV::MHRACCU:
14890 case RISCV::MQACC_H00:
14891 case RISCV::MQACC_H01:
14892 case RISCV::MQACC_H11:
14893 case RISCV::MQACC_W00:
14894 case RISCV::MQACC_W01:
14895 case RISCV::MQACC_W11:
14896 case RISCV::MQRACC_H00:
14897 case RISCV::MQRACC_H01:
14898 case RISCV::MQRACC_H11:
14899 case RISCV::MQRACC_W00:
14900 case RISCV::MQRACC_W01:
14901 case RISCV::MQRACC_W11:
14902 case RISCV::MVM:
14903 case RISCV::MVMN:
14904 case RISCV::PABDSUMAU_B:
14905 case RISCV::PM2ADDASU_H:
14906 case RISCV::PM2ADDASU_W:
14907 case RISCV::PM2ADDAU_H:
14908 case RISCV::PM2ADDAU_W:
14909 case RISCV::PM2ADDA_H:
14910 case RISCV::PM2ADDA_HX:
14911 case RISCV::PM2ADDA_W:
14912 case RISCV::PM2ADDA_WX:
14913 case RISCV::PM2SUBA_H:
14914 case RISCV::PM2SUBA_HX:
14915 case RISCV::PM2SUBA_W:
14916 case RISCV::PM2SUBA_WX:
14917 case RISCV::PM4ADDASU_B:
14918 case RISCV::PM4ADDASU_H:
14919 case RISCV::PM4ADDAU_B:
14920 case RISCV::PM4ADDAU_H:
14921 case RISCV::PM4ADDA_B:
14922 case RISCV::PM4ADDA_H:
14923 case RISCV::PMACCSU_W_H00:
14924 case RISCV::PMACCSU_W_H11:
14925 case RISCV::PMACCU_W_H00:
14926 case RISCV::PMACCU_W_H01:
14927 case RISCV::PMACCU_W_H11:
14928 case RISCV::PMACC_W_H00:
14929 case RISCV::PMACC_W_H01:
14930 case RISCV::PMACC_W_H11:
14931 case RISCV::PMHACCSU_H:
14932 case RISCV::PMHACCSU_H_B0:
14933 case RISCV::PMHACCSU_H_B1:
14934 case RISCV::PMHACCSU_W:
14935 case RISCV::PMHACCSU_W_H0:
14936 case RISCV::PMHACCSU_W_H1:
14937 case RISCV::PMHACCU_H:
14938 case RISCV::PMHACCU_W:
14939 case RISCV::PMHACC_H:
14940 case RISCV::PMHACC_H_B0:
14941 case RISCV::PMHACC_H_B1:
14942 case RISCV::PMHACC_W:
14943 case RISCV::PMHACC_W_H0:
14944 case RISCV::PMHACC_W_H1:
14945 case RISCV::PMHRACCSU_H:
14946 case RISCV::PMHRACCSU_W:
14947 case RISCV::PMHRACCU_H:
14948 case RISCV::PMHRACCU_W:
14949 case RISCV::PMHRACC_H:
14950 case RISCV::PMHRACC_W:
14951 case RISCV::PMQ2ADDA_H:
14952 case RISCV::PMQ2ADDA_W:
14953 case RISCV::PMQACC_W_H00:
14954 case RISCV::PMQACC_W_H01:
14955 case RISCV::PMQACC_W_H11:
14956 case RISCV::PMQR2ADDA_H:
14957 case RISCV::PMQR2ADDA_W:
14958 case RISCV::PMQRACC_W_H00:
14959 case RISCV::PMQRACC_W_H01:
14960 case RISCV::PMQRACC_W_H11:
14961 case RISCV::QC_INSBHR:
14962 case RISCV::QC_INSBPR:
14963 case RISCV::QC_INSBPRH:
14964 case RISCV::QC_INSBR:
14965 case RISCV::SLX:
14966 case RISCV::SRX:
14967 case RISCV::TH_MULA:
14968 case RISCV::TH_MULAH:
14969 case RISCV::TH_MULAW:
14970 case RISCV::TH_MULS:
14971 case RISCV::TH_MULSH:
14972 case RISCV::TH_MULSW:
14973 case RISCV::TH_MVEQZ:
14974 case RISCV::TH_MVNEZ: {
14975 switch (OpNum) {
14976 case 3:
14977 // op: rs2
14978 return 20;
14979 case 2:
14980 // op: rs1
14981 return 15;
14982 case 1:
14983 // op: rd
14984 return 7;
14985 }
14986 break;
14987 }
14988 case RISCV::MQRWACC:
14989 case RISCV::MQWACC:
14990 case RISCV::PM2WADDASU_H:
14991 case RISCV::PM2WADDAU_H:
14992 case RISCV::PM2WADDA_H:
14993 case RISCV::PM2WADDA_HX:
14994 case RISCV::PM2WSUBA_H:
14995 case RISCV::PM2WSUBA_HX:
14996 case RISCV::PMQRWACC_H:
14997 case RISCV::PMQWACC_H:
14998 case RISCV::PWADDAU_B:
14999 case RISCV::PWADDAU_H:
15000 case RISCV::PWADDA_B:
15001 case RISCV::PWADDA_H:
15002 case RISCV::PWMACCSU_H:
15003 case RISCV::PWMACCU_H:
15004 case RISCV::PWMACC_H:
15005 case RISCV::PWSUBAU_B:
15006 case RISCV::PWSUBAU_H:
15007 case RISCV::PWSUBA_B:
15008 case RISCV::PWSUBA_H:
15009 case RISCV::WADDA:
15010 case RISCV::WADDAU:
15011 case RISCV::WMACC:
15012 case RISCV::WMACCSU:
15013 case RISCV::WMACCU:
15014 case RISCV::WSUBA:
15015 case RISCV::WSUBAU: {
15016 switch (OpNum) {
15017 case 3:
15018 // op: rs2
15019 return 20;
15020 case 2:
15021 // op: rs1
15022 return 15;
15023 case 1:
15024 // op: rd
15025 return 8;
15026 }
15027 break;
15028 }
15029 case RISCV::MIPS_CCMOV: {
15030 switch (OpNum) {
15031 case 3:
15032 // op: rs3
15033 return 27;
15034 case 2:
15035 // op: rs2
15036 return 20;
15037 case 1:
15038 // op: rs1
15039 return 15;
15040 case 0:
15041 // op: rd
15042 return 7;
15043 }
15044 break;
15045 }
15046 case RISCV::FMADD_D:
15047 case RISCV::FMADD_D_IN32X:
15048 case RISCV::FMADD_D_INX:
15049 case RISCV::FMADD_H:
15050 case RISCV::FMADD_H_INX:
15051 case RISCV::FMADD_Q:
15052 case RISCV::FMADD_S:
15053 case RISCV::FMADD_S_INX:
15054 case RISCV::FMSUB_D:
15055 case RISCV::FMSUB_D_IN32X:
15056 case RISCV::FMSUB_D_INX:
15057 case RISCV::FMSUB_H:
15058 case RISCV::FMSUB_H_INX:
15059 case RISCV::FMSUB_Q:
15060 case RISCV::FMSUB_S:
15061 case RISCV::FMSUB_S_INX:
15062 case RISCV::FNMADD_D:
15063 case RISCV::FNMADD_D_IN32X:
15064 case RISCV::FNMADD_D_INX:
15065 case RISCV::FNMADD_H:
15066 case RISCV::FNMADD_H_INX:
15067 case RISCV::FNMADD_Q:
15068 case RISCV::FNMADD_S:
15069 case RISCV::FNMADD_S_INX:
15070 case RISCV::FNMSUB_D:
15071 case RISCV::FNMSUB_D_IN32X:
15072 case RISCV::FNMSUB_D_INX:
15073 case RISCV::FNMSUB_H:
15074 case RISCV::FNMSUB_H_INX:
15075 case RISCV::FNMSUB_Q:
15076 case RISCV::FNMSUB_S:
15077 case RISCV::FNMSUB_S_INX: {
15078 switch (OpNum) {
15079 case 3:
15080 // op: rs3
15081 return 27;
15082 case 2:
15083 // op: rs2
15084 return 20;
15085 case 1:
15086 // op: rs1
15087 return 15;
15088 case 4:
15089 // op: frm
15090 return 12;
15091 case 0:
15092 // op: rd
15093 return 7;
15094 }
15095 break;
15096 }
15097 case RISCV::CV_SB_rr_inc:
15098 case RISCV::CV_SH_rr_inc:
15099 case RISCV::CV_SW_rr_inc: {
15100 switch (OpNum) {
15101 case 3:
15102 // op: rs3
15103 return 7;
15104 case 1:
15105 // op: rs2
15106 return 20;
15107 case 2:
15108 // op: rs1
15109 return 15;
15110 }
15111 break;
15112 }
15113 case RISCV::SF_VC_V_IVV:
15114 case RISCV::SF_VC_V_IVW: {
15115 switch (OpNum) {
15116 case 3:
15117 // op: vs2
15118 return 20;
15119 case 2:
15120 // op: vd
15121 return 7;
15122 case 4:
15123 // op: imm
15124 return 15;
15125 case 1:
15126 // op: funct6_lo2
15127 return 26;
15128 }
15129 break;
15130 }
15131 case RISCV::SF_VC_V_FVV:
15132 case RISCV::SF_VC_V_FVW: {
15133 switch (OpNum) {
15134 case 3:
15135 // op: vs2
15136 return 20;
15137 case 2:
15138 // op: vd
15139 return 7;
15140 case 4:
15141 // op: rs1
15142 return 15;
15143 case 1:
15144 // op: funct6_lo1
15145 return 26;
15146 }
15147 break;
15148 }
15149 case RISCV::SF_VC_V_XVV:
15150 case RISCV::SF_VC_V_XVW: {
15151 switch (OpNum) {
15152 case 3:
15153 // op: vs2
15154 return 20;
15155 case 2:
15156 // op: vd
15157 return 7;
15158 case 4:
15159 // op: rs1
15160 return 15;
15161 case 1:
15162 // op: funct6_lo2
15163 return 26;
15164 }
15165 break;
15166 }
15167 case RISCV::SF_VC_V_VVV:
15168 case RISCV::SF_VC_V_VVW: {
15169 switch (OpNum) {
15170 case 3:
15171 // op: vs2
15172 return 20;
15173 case 2:
15174 // op: vd
15175 return 7;
15176 case 4:
15177 // op: vs1
15178 return 15;
15179 case 1:
15180 // op: funct6_lo2
15181 return 26;
15182 }
15183 break;
15184 }
15185 case RISCV::QC_MVEQI:
15186 case RISCV::QC_MVGEI:
15187 case RISCV::QC_MVGEUI:
15188 case RISCV::QC_MVLTI:
15189 case RISCV::QC_MVLTUI:
15190 case RISCV::QC_MVNEI: {
15191 switch (OpNum) {
15192 case 4:
15193 // op: rs3
15194 return 27;
15195 case 2:
15196 // op: rs1
15197 return 15;
15198 case 1:
15199 // op: rd
15200 return 7;
15201 case 3:
15202 // op: imm
15203 return 20;
15204 }
15205 break;
15206 }
15207 case RISCV::QC_SELECTEQI:
15208 case RISCV::QC_SELECTNEI: {
15209 switch (OpNum) {
15210 case 4:
15211 // op: rs3
15212 return 27;
15213 case 3:
15214 // op: rs2
15215 return 20;
15216 case 1:
15217 // op: rd
15218 return 7;
15219 case 2:
15220 // op: imm
15221 return 15;
15222 }
15223 break;
15224 }
15225 case RISCV::QC_MVEQ:
15226 case RISCV::QC_MVGE:
15227 case RISCV::QC_MVGEU:
15228 case RISCV::QC_MVLT:
15229 case RISCV::QC_MVLTU:
15230 case RISCV::QC_MVNE: {
15231 switch (OpNum) {
15232 case 4:
15233 // op: rs3
15234 return 27;
15235 case 3:
15236 // op: rs2
15237 return 20;
15238 case 2:
15239 // op: rs1
15240 return 15;
15241 case 1:
15242 // op: rd
15243 return 7;
15244 }
15245 break;
15246 }
15247 default:
15248 reportUnsupportedInst(MI);
15249 }
15250 reportUnsupportedOperand(MI, OpNum);
15251}
15252
15253#endif // GET_OPERAND_BIT_OFFSET
15254
15255