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(33554555), // PACKY
1437 UINT64_C(2214592571), // PADD_B
1438 UINT64_C(2617253915), // PADD_BS
1439 UINT64_C(2214617115), // PADD_DB
1440 UINT64_C(469786651), // PADD_DBS
1441 UINT64_C(2147508251), // PADD_DH
1442 UINT64_C(402677787), // PADD_DHS
1443 UINT64_C(2181062683), // PADD_DW
1444 UINT64_C(436232219), // PADD_DWS
1445 UINT64_C(2147483707), // PADD_H
1446 UINT64_C(2550145051), // PADD_HS
1447 UINT64_C(2181038139), // PADD_W
1448 UINT64_C(2583699483), // PADD_WS
1449 UINT64_C(2618351643), // PASA_DHX
1450 UINT64_C(2617270331), // PASA_HX
1451 UINT64_C(2650824763), // PASA_WX
1452 UINT64_C(4227858491), // PASUBU_B
1453 UINT64_C(4227883035), // PASUBU_DB
1454 UINT64_C(4160774171), // PASUBU_DH
1455 UINT64_C(4194328603), // PASUBU_DW
1456 UINT64_C(4160749627), // PASUBU_H
1457 UINT64_C(4194304059), // PASUBU_W
1458 UINT64_C(3690987579), // PASUB_B
1459 UINT64_C(3691012123), // PASUB_DB
1460 UINT64_C(3623903259), // PASUB_DH
1461 UINT64_C(3657457691), // PASUB_DW
1462 UINT64_C(3623878715), // PASUB_H
1463 UINT64_C(3657433147), // PASUB_W
1464 UINT64_C(2148589595), // PAS_DHX
1465 UINT64_C(2147508283), // PAS_HX
1466 UINT64_C(2181062715), // PAS_WX
1467 UINT64_C(3019907099), // PLI_B
1468 UINT64_C(872423451), // PLI_DB
1469 UINT64_C(805314587), // PLI_DH
1470 UINT64_C(2952798235), // PLI_H
1471 UINT64_C(2986352667), // PLI_W
1472 UINT64_C(1879056411), // PLUI_DH
1473 UINT64_C(4026540059), // PLUI_H
1474 UINT64_C(4060094491), // PLUI_W
1475 UINT64_C(3892334651), // PM2ADDASU_H
1476 UINT64_C(3925889083), // PM2ADDASU_W
1477 UINT64_C(2818592827), // PM2ADDAU_H
1478 UINT64_C(2852147259), // PM2ADDAU_W
1479 UINT64_C(2281721915), // PM2ADDA_H
1480 UINT64_C(2550157371), // PM2ADDA_HX
1481 UINT64_C(2315276347), // PM2ADDA_W
1482 UINT64_C(2583711803), // PM2ADDA_WX
1483 UINT64_C(3758116923), // PM2ADDSU_H
1484 UINT64_C(3791671355), // PM2ADDSU_W
1485 UINT64_C(2684375099), // PM2ADDU_H
1486 UINT64_C(2717929531), // PM2ADDU_W
1487 UINT64_C(2147504187), // PM2ADD_H
1488 UINT64_C(2415939643), // PM2ADD_HX
1489 UINT64_C(2181058619), // PM2ADD_W
1490 UINT64_C(2449494075), // PM2ADD_WX
1491 UINT64_C(3288354875), // PM2SADD_H
1492 UINT64_C(3556790331), // PM2SADD_HX
1493 UINT64_C(3355463739), // PM2SUBA_H
1494 UINT64_C(3623899195), // PM2SUBA_HX
1495 UINT64_C(3389018171), // PM2SUBA_W
1496 UINT64_C(3657453627), // PM2SUBA_WX
1497 UINT64_C(3221246011), // PM2SUB_H
1498 UINT64_C(3489681467), // PM2SUB_HX
1499 UINT64_C(3254800443), // PM2SUB_W
1500 UINT64_C(3523235899), // PM2SUB_WX
1501 UINT64_C(1845502107), // PM2WADDASU_H
1502 UINT64_C(771760283), // PM2WADDAU_H
1503 UINT64_C(234889371), // PM2WADDA_H
1504 UINT64_C(503324827), // PM2WADDA_HX
1505 UINT64_C(1711284379), // PM2WADDSU_H
1506 UINT64_C(637542555), // PM2WADDU_H
1507 UINT64_C(100671643), // PM2WADD_H
1508 UINT64_C(369107099), // PM2WADD_HX
1509 UINT64_C(1308631195), // PM2WSUBA_H
1510 UINT64_C(1577066651), // PM2WSUBA_HX
1511 UINT64_C(1174413467), // PM2WSUB_H
1512 UINT64_C(1442848923), // PM2WSUB_HX
1513 UINT64_C(3959443515), // PM4ADDASU_B
1514 UINT64_C(3992997947), // PM4ADDASU_H
1515 UINT64_C(2885701691), // PM4ADDAU_B
1516 UINT64_C(2919256123), // PM4ADDAU_H
1517 UINT64_C(2348830779), // PM4ADDA_B
1518 UINT64_C(2382385211), // PM4ADDA_H
1519 UINT64_C(3825225787), // PM4ADDSU_B
1520 UINT64_C(3858780219), // PM4ADDSU_H
1521 UINT64_C(2751483963), // PM4ADDU_B
1522 UINT64_C(2785038395), // PM4ADDU_H
1523 UINT64_C(2214613051), // PM4ADD_B
1524 UINT64_C(2248167483), // PM4ADD_H
1525 UINT64_C(3925880891), // PMACCSU_W_H00
1526 UINT64_C(4194316347), // PMACCSU_W_H11
1527 UINT64_C(2852139067), // PMACCU_W_H00
1528 UINT64_C(3120566331), // PMACCU_W_H01
1529 UINT64_C(3120574523), // PMACCU_W_H11
1530 UINT64_C(2315268155), // PMACC_W_H00
1531 UINT64_C(2583695419), // PMACC_W_H01
1532 UINT64_C(2583703611), // PMACC_W_H11
1533 UINT64_C(4227883067), // PMAXU_B
1534 UINT64_C(4228964379), // PMAXU_DB
1535 UINT64_C(4161855515), // PMAXU_DH
1536 UINT64_C(4195409947), // PMAXU_DW
1537 UINT64_C(4160774203), // PMAXU_H
1538 UINT64_C(4194328635), // PMAXU_W
1539 UINT64_C(4093665339), // PMAX_B
1540 UINT64_C(4094746651), // PMAX_DB
1541 UINT64_C(4027637787), // PMAX_DH
1542 UINT64_C(4061192219), // PMAX_DW
1543 UINT64_C(4026556475), // PMAX_H
1544 UINT64_C(4060110907), // PMAX_W
1545 UINT64_C(3355471931), // PMHACCSU_H
1546 UINT64_C(2885709883), // PMHACCSU_H_B0
1547 UINT64_C(3154145339), // PMHACCSU_H_B1
1548 UINT64_C(3389026363), // PMHACCSU_W
1549 UINT64_C(2919264315), // PMHACCSU_W_H0
1550 UINT64_C(3187699771), // PMHACCSU_W_H1
1551 UINT64_C(2550165563), // PMHACCU_H
1552 UINT64_C(2583719995), // PMHACCU_W
1553 UINT64_C(2281730107), // PMHACC_H
1554 UINT64_C(2818601019), // PMHACC_H_B0
1555 UINT64_C(3087036475), // PMHACC_H_B1
1556 UINT64_C(2315284539), // PMHACC_W
1557 UINT64_C(2852155451), // PMHACC_W_H0
1558 UINT64_C(3120590907), // PMHACC_W_H1
1559 UINT64_C(3422580795), // PMHRACCSU_H
1560 UINT64_C(3456135227), // PMHRACCSU_W
1561 UINT64_C(2617274427), // PMHRACCU_H
1562 UINT64_C(2650828859), // PMHRACCU_W
1563 UINT64_C(2348838971), // PMHRACC_H
1564 UINT64_C(2382393403), // PMHRACC_W
1565 UINT64_C(3959447611), // PMINU_B
1566 UINT64_C(3960528923), // PMINU_DB
1567 UINT64_C(3893420059), // PMINU_DH
1568 UINT64_C(3926974491), // PMINU_DW
1569 UINT64_C(3892338747), // PMINU_H
1570 UINT64_C(3925893179), // PMINU_W
1571 UINT64_C(3825229883), // PMIN_B
1572 UINT64_C(3826311195), // PMIN_DB
1573 UINT64_C(3759202331), // PMIN_DH
1574 UINT64_C(3792756763), // PMIN_DW
1575 UINT64_C(3758121019), // PMIN_H
1576 UINT64_C(3791675451), // PMIN_W
1577 UINT64_C(3087028283), // PMQ2ADDA_H
1578 UINT64_C(3120582715), // PMQ2ADDA_W
1579 UINT64_C(2952810555), // PMQ2ADD_H
1580 UINT64_C(2986364987), // PMQ2ADD_W
1581 UINT64_C(3892342843), // PMQACC_W_H00
1582 UINT64_C(4160770107), // PMQACC_W_H01
1583 UINT64_C(4160778299), // PMQACC_W_H11
1584 UINT64_C(3154137147), // PMQR2ADDA_H
1585 UINT64_C(3187691579), // PMQR2ADDA_W
1586 UINT64_C(3019919419), // PMQR2ADD_H
1587 UINT64_C(3053473851), // PMQR2ADD_W
1588 UINT64_C(3959451707), // PMQRACC_W_H00
1589 UINT64_C(4227878971), // PMQRACC_W_H01
1590 UINT64_C(4227887163), // PMQRACC_W_H11
1591 UINT64_C(2080383131), // PMQRWACC_H
1592 UINT64_C(2013274267), // PMQWACC_H
1593 UINT64_C(3288358971), // PMSEQ_B
1594 UINT64_C(3289440283), // PMSEQ_DB
1595 UINT64_C(3222331419), // PMSEQ_DH
1596 UINT64_C(3255885851), // PMSEQ_DW
1597 UINT64_C(3221250107), // PMSEQ_H
1598 UINT64_C(3254804539), // PMSEQ_W
1599 UINT64_C(3691012155), // PMSLTU_B
1600 UINT64_C(3692093467), // PMSLTU_DB
1601 UINT64_C(3624984603), // PMSLTU_DH
1602 UINT64_C(3658539035), // PMSLTU_DW
1603 UINT64_C(3623903291), // PMSLTU_H
1604 UINT64_C(3657457723), // PMSLTU_W
1605 UINT64_C(3556794427), // PMSLT_B
1606 UINT64_C(3557875739), // PMSLT_DB
1607 UINT64_C(3490766875), // PMSLT_DH
1608 UINT64_C(3524321307), // PMSLT_DW
1609 UINT64_C(3489685563), // PMSLT_H
1610 UINT64_C(3523239995), // PMSLT_W
1611 UINT64_C(3288363067), // PMULHRSU_H
1612 UINT64_C(3321917499), // PMULHRSU_W
1613 UINT64_C(2483056699), // PMULHRU_H
1614 UINT64_C(2516611131), // PMULHRU_W
1615 UINT64_C(2214621243), // PMULHR_H
1616 UINT64_C(2248175675), // PMULHR_W
1617 UINT64_C(3221254203), // PMULHSU_H
1618 UINT64_C(2751492155), // PMULHSU_H_B0
1619 UINT64_C(3019927611), // PMULHSU_H_B1
1620 UINT64_C(3254808635), // PMULHSU_W
1621 UINT64_C(2785046587), // PMULHSU_W_H0
1622 UINT64_C(3053482043), // PMULHSU_W_H1
1623 UINT64_C(2415947835), // PMULHU_H
1624 UINT64_C(2449502267), // PMULHU_W
1625 UINT64_C(2147512379), // PMULH_H
1626 UINT64_C(2684383291), // PMULH_H_B0
1627 UINT64_C(2952818747), // PMULH_H_B1
1628 UINT64_C(2181066811), // PMULH_W
1629 UINT64_C(2717937723), // PMULH_W_H0
1630 UINT64_C(2986373179), // PMULH_W_H1
1631 UINT64_C(3556798523), // PMULQR_H
1632 UINT64_C(3590352955), // PMULQR_W
1633 UINT64_C(3489689659), // PMULQ_H
1634 UINT64_C(3523244091), // PMULQ_W
1635 UINT64_C(3758108731), // PMULSU_H_B00
1636 UINT64_C(4026544187), // PMULSU_H_B11
1637 UINT64_C(3791663163), // PMULSU_W_H00
1638 UINT64_C(4060098619), // PMULSU_W_H11
1639 UINT64_C(2684366907), // PMULU_H_B00
1640 UINT64_C(2952794171), // PMULU_H_B01
1641 UINT64_C(2952802363), // PMULU_H_B11
1642 UINT64_C(2717921339), // PMULU_W_H00
1643 UINT64_C(2986348603), // PMULU_W_H01
1644 UINT64_C(2986356795), // PMULU_W_H11
1645 UINT64_C(2147495995), // PMUL_H_B00
1646 UINT64_C(2415923259), // PMUL_H_B01
1647 UINT64_C(2415931451), // PMUL_H_B11
1648 UINT64_C(2181050427), // PMUL_W_H00
1649 UINT64_C(2449477691), // PMUL_W_H01
1650 UINT64_C(2449485883), // PMUL_W_H11
1651 UINT64_C(553697307), // PNCLIPIU_B
1652 UINT64_C(570474523), // PNCLIPIU_H
1653 UINT64_C(1627439131), // PNCLIPI_B
1654 UINT64_C(1644216347), // PNCLIPI_H
1655 UINT64_C(3221233723), // PNCLIPP_B
1656 UINT64_C(3254788155), // PNCLIPP_H
1657 UINT64_C(3321897019), // PNCLIPP_W
1658 UINT64_C(822132763), // PNCLIPRIU_B
1659 UINT64_C(838909979), // PNCLIPRIU_H
1660 UINT64_C(1895874587), // PNCLIPRI_B
1661 UINT64_C(1912651803), // PNCLIPRI_H
1662 UINT64_C(939573275), // PNCLIPRU_BS
1663 UINT64_C(973127707), // PNCLIPRU_HS
1664 UINT64_C(2013315099), // PNCLIPR_BS
1665 UINT64_C(2046869531), // PNCLIPR_HS
1666 UINT64_C(2147491899), // PNCLIPUP_B
1667 UINT64_C(2181046331), // PNCLIPUP_H
1668 UINT64_C(2248155195), // PNCLIPUP_W
1669 UINT64_C(671137819), // PNCLIPU_BS
1670 UINT64_C(704692251), // PNCLIPU_HS
1671 UINT64_C(1744879643), // PNCLIP_BS
1672 UINT64_C(1778434075), // PNCLIP_HS
1673 UINT64_C(1090568219), // PNSRAI_B
1674 UINT64_C(1107345435), // PNSRAI_H
1675 UINT64_C(1359003675), // PNSRARI_B
1676 UINT64_C(1375780891), // PNSRARI_H
1677 UINT64_C(1476444187), // PNSRAR_BS
1678 UINT64_C(1509998619), // PNSRAR_HS
1679 UINT64_C(1208008731), // PNSRA_BS
1680 UINT64_C(1241563163), // PNSRA_HS
1681 UINT64_C(16826395), // PNSRLI_B
1682 UINT64_C(33603611), // PNSRLI_H
1683 UINT64_C(134266907), // PNSRL_BS
1684 UINT64_C(167821339), // PNSRL_HS
1685 UINT64_C(2415935547), // PPAIREO_B
1686 UINT64_C(2415976475), // PPAIREO_DB
1687 UINT64_C(2449530907), // PPAIREO_DH
1688 UINT64_C(2449489979), // PPAIREO_H
1689 UINT64_C(2516598843), // PPAIREO_W
1690 UINT64_C(2147500091), // PPAIRE_B
1691 UINT64_C(2147541019), // PPAIRE_DB
1692 UINT64_C(2181095451), // PPAIRE_DH
1693 UINT64_C(2181054523), // PPAIRE_H
1694 UINT64_C(2684371003), // PPAIROE_B
1695 UINT64_C(2684411931), // PPAIROE_DB
1696 UINT64_C(2717966363), // PPAIROE_DH
1697 UINT64_C(2717925435), // PPAIROE_H
1698 UINT64_C(2785034299), // PPAIROE_W
1699 UINT64_C(2952806459), // PPAIRO_B
1700 UINT64_C(2952847387), // PPAIRO_DB
1701 UINT64_C(2986401819), // PPAIRO_DH
1702 UINT64_C(2986360891), // PPAIRO_H
1703 UINT64_C(3053469755), // PPAIRO_W
1704 UINT64_C(3154133019), // PREDSUMU_BS
1705 UINT64_C(1006649371), // PREDSUMU_DBS
1706 UINT64_C(939540507), // PREDSUMU_DHS
1707 UINT64_C(3087024155), // PREDSUMU_HS
1708 UINT64_C(3120578587), // PREDSUMU_WS
1709 UINT64_C(2617262107), // PREDSUM_BS
1710 UINT64_C(469778459), // PREDSUM_DBS
1711 UINT64_C(402669595), // PREDSUM_DHS
1712 UINT64_C(2550153243), // PREDSUM_HS
1713 UINT64_C(2583707675), // PREDSUM_WS
1714 UINT64_C(24595), // PREFETCH_I
1715 UINT64_C(1073171), // PREFETCH_R
1716 UINT64_C(3170323), // PREFETCH_W
1717 UINT64_C(3832553499), // PSABS_B
1718 UINT64_C(1685086235), // PSABS_DB
1719 UINT64_C(1617977371), // PSABS_DH
1720 UINT64_C(3765444635), // PSABS_H
1721 UINT64_C(3019898939), // PSADDU_B
1722 UINT64_C(3019923483), // PSADDU_DB
1723 UINT64_C(2952814619), // PSADDU_DH
1724 UINT64_C(2986369051), // PSADDU_DW
1725 UINT64_C(2952790075), // PSADDU_H
1726 UINT64_C(2986344507), // PSADDU_W
1727 UINT64_C(2483028027), // PSADD_B
1728 UINT64_C(2483052571), // PSADD_DB
1729 UINT64_C(2415943707), // PSADD_DH
1730 UINT64_C(2449498139), // PSADD_DW
1731 UINT64_C(2415919163), // PSADD_H
1732 UINT64_C(2449473595), // PSADD_W
1733 UINT64_C(2417025051), // PSAS_DHX
1734 UINT64_C(2415943739), // PSAS_HX
1735 UINT64_C(2449498171), // PSAS_WX
1736 UINT64_C(1627447323), // PSATI_DH
1737 UINT64_C(1644224539), // PSATI_DW
1738 UINT64_C(3774890011), // PSATI_H
1739 UINT64_C(3791667227), // PSATI_W
1740 UINT64_C(2215698459), // PSA_DHX
1741 UINT64_C(2214617147), // PSA_HX
1742 UINT64_C(2248171579), // PSA_WX
1743 UINT64_C(1614831643), // PSEXT_DH_B
1744 UINT64_C(1648386075), // PSEXT_DW_B
1745 UINT64_C(1649434651), // PSEXT_DW_H
1746 UINT64_C(3762298907), // PSEXT_H_B
1747 UINT64_C(3795853339), // PSEXT_W_B
1748 UINT64_C(3796901915), // PSEXT_W_H
1749 UINT64_C(2685427739), // PSH1ADD_DH
1750 UINT64_C(2718982171), // PSH1ADD_DW
1751 UINT64_C(2684362811), // PSH1ADD_H
1752 UINT64_C(2717917243), // PSH1ADD_W
1753 UINT64_C(2155880475), // PSLLI_B
1754 UINT64_C(8413211), // PSLLI_DB
1755 UINT64_C(16801819), // PSLLI_DH
1756 UINT64_C(33579035), // PSLLI_DW
1757 UINT64_C(2164269083), // PSLLI_H
1758 UINT64_C(2181046299), // PSLLI_W
1759 UINT64_C(2348818459), // PSLL_BS
1760 UINT64_C(201351195), // PSLL_DBS
1761 UINT64_C(134242331), // PSLL_DHS
1762 UINT64_C(167796763), // PSLL_DWS
1763 UINT64_C(2281709595), // PSLL_HS
1764 UINT64_C(2315264027), // PSLL_WS
1765 UINT64_C(3229630491), // PSRAI_B
1766 UINT64_C(1082187803), // PSRAI_DB
1767 UINT64_C(1090576411), // PSRAI_DH
1768 UINT64_C(1107353627), // PSRAI_DW
1769 UINT64_C(3238019099), // PSRAI_H
1770 UINT64_C(3254796315), // PSRAI_W
1771 UINT64_C(1359011867), // PSRARI_DH
1772 UINT64_C(1375789083), // PSRARI_DW
1773 UINT64_C(3506454555), // PSRARI_H
1774 UINT64_C(3523231771), // PSRARI_W
1775 UINT64_C(3422568475), // PSRA_BS
1776 UINT64_C(1275125787), // PSRA_DBS
1777 UINT64_C(1208016923), // PSRA_DHS
1778 UINT64_C(1241571355), // PSRA_DWS
1779 UINT64_C(3355459611), // PSRA_HS
1780 UINT64_C(3389014043), // PSRA_WS
1781 UINT64_C(2155888667), // PSRLI_B
1782 UINT64_C(8445979), // PSRLI_DB
1783 UINT64_C(16834587), // PSRLI_DH
1784 UINT64_C(33611803), // PSRLI_DW
1785 UINT64_C(2164277275), // PSRLI_H
1786 UINT64_C(2181054491), // PSRLI_W
1787 UINT64_C(2348826651), // PSRL_BS
1788 UINT64_C(201383963), // PSRL_DBS
1789 UINT64_C(134275099), // PSRL_DHS
1790 UINT64_C(167829531), // PSRL_DWS
1791 UINT64_C(2281717787), // PSRL_HS
1792 UINT64_C(2315272219), // PSRL_WS
1793 UINT64_C(2484133915), // PSSA_DHX
1794 UINT64_C(2483052603), // PSSA_HX
1795 UINT64_C(2516607035), // PSSA_WX
1796 UINT64_C(2953863195), // PSSH1SADD_DH
1797 UINT64_C(2987417627), // PSSH1SADD_DW
1798 UINT64_C(2952798267), // PSSH1SADD_H
1799 UINT64_C(2986352699), // PSSH1SADD_W
1800 UINT64_C(2013290523), // PSSHAR_DHS
1801 UINT64_C(2046844955), // PSSHAR_DWS
1802 UINT64_C(4160757787), // PSSHAR_HS
1803 UINT64_C(4194312219), // PSSHAR_WS
1804 UINT64_C(1744855067), // PSSHA_DHS
1805 UINT64_C(1778409499), // PSSHA_DWS
1806 UINT64_C(3892322331), // PSSHA_HS
1807 UINT64_C(3925876763), // PSSHA_WS
1808 UINT64_C(939548699), // PSSHLR_DHS
1809 UINT64_C(973103131), // PSSHLR_DWS
1810 UINT64_C(3087015963), // PSSHLR_HS
1811 UINT64_C(3120570395), // PSSHLR_WS
1812 UINT64_C(671113243), // PSSHL_DHS
1813 UINT64_C(704667675), // PSSHL_DWS
1814 UINT64_C(2818580507), // PSSHL_HS
1815 UINT64_C(2852134939), // PSSHL_WS
1816 UINT64_C(1358979099), // PSSLAI_DH
1817 UINT64_C(1375756315), // PSSLAI_DW
1818 UINT64_C(3506446363), // PSSLAI_H
1819 UINT64_C(3523223579), // PSSLAI_W
1820 UINT64_C(4093640763), // PSSUBU_B
1821 UINT64_C(4093665307), // PSSUBU_DB
1822 UINT64_C(4026556443), // PSSUBU_DH
1823 UINT64_C(4060110875), // PSSUBU_DW
1824 UINT64_C(4026531899), // PSSUBU_H
1825 UINT64_C(4060086331), // PSSUBU_W
1826 UINT64_C(3556769851), // PSSUB_B
1827 UINT64_C(3556794395), // PSSUB_DB
1828 UINT64_C(3489685531), // PSSUB_DH
1829 UINT64_C(3523239963), // PSSUB_DW
1830 UINT64_C(3489660987), // PSSUB_H
1831 UINT64_C(3523215419), // PSSUB_W
1832 UINT64_C(3288334395), // PSUB_B
1833 UINT64_C(3288358939), // PSUB_DB
1834 UINT64_C(3221250075), // PSUB_DH
1835 UINT64_C(3254804507), // PSUB_DW
1836 UINT64_C(3221225531), // PSUB_H
1837 UINT64_C(3254779963), // PSUB_W
1838 UINT64_C(553705499), // PUSATI_DH
1839 UINT64_C(570482715), // PUSATI_DW
1840 UINT64_C(2701148187), // PUSATI_H
1841 UINT64_C(2717925403), // PUSATI_W
1842 UINT64_C(469770395), // PWADDAU_B
1843 UINT64_C(402661531), // PWADDAU_H
1844 UINT64_C(201334939), // PWADDA_B
1845 UINT64_C(134226075), // PWADDA_H
1846 UINT64_C(335552667), // PWADDU_B
1847 UINT64_C(268443803), // PWADDU_H
1848 UINT64_C(67117211), // PWADD_B
1849 UINT64_C(8347), // PWADD_H
1850 UINT64_C(1744838811), // PWMACCSU_H
1851 UINT64_C(939532443), // PWMACCU_H
1852 UINT64_C(671096987), // PWMACC_H
1853 UINT64_C(1677729947), // PWMULSU_B
1854 UINT64_C(1610621083), // PWMULSU_H
1855 UINT64_C(872423579), // PWMULU_B
1856 UINT64_C(805314715), // PWMULU_H
1857 UINT64_C(603988123), // PWMUL_B
1858 UINT64_C(536879259), // PWMUL_H
1859 UINT64_C(1090527259), // PWSLAI_B
1860 UINT64_C(1107304475), // PWSLAI_H
1861 UINT64_C(1207967771), // PWSLA_BS
1862 UINT64_C(1241522203), // PWSLA_HS
1863 UINT64_C(16785435), // PWSLLI_B
1864 UINT64_C(33562651), // PWSLLI_H
1865 UINT64_C(134225947), // PWSLL_BS
1866 UINT64_C(167780379), // PWSLL_HS
1867 UINT64_C(1543512219), // PWSUBAU_B
1868 UINT64_C(1476403355), // PWSUBAU_H
1869 UINT64_C(1275076763), // PWSUBA_B
1870 UINT64_C(1207967899), // PWSUBA_H
1871 UINT64_C(1409294491), // PWSUBU_B
1872 UINT64_C(1342185627), // PWSUBU_H
1873 UINT64_C(1140859035), // PWSUB_B
1874 UINT64_C(1073750171), // PWSUB_H
1875 UINT64_C(469774347), // QC_ADDSAT
1876 UINT64_C(503328779), // QC_ADDUSAT
1877 UINT64_C(123), // QC_BEQI
1878 UINT64_C(20603), // QC_BGEI
1879 UINT64_C(28795), // QC_BGEUI
1880 UINT64_C(16507), // QC_BLTI
1881 UINT64_C(24699), // QC_BLTUI
1882 UINT64_C(4219), // QC_BNEI
1883 UINT64_C(201338891), // QC_BREV32
1884 UINT64_C(134230027), // QC_CLO
1885 UINT64_C(3456106611), // QC_CLRINTI
1886 UINT64_C(40962), // QC_CM_JALT
1887 UINT64_C(40962), // QC_CM_JT
1888 UINT64_C(44130), // QC_CM_MVA01S
1889 UINT64_C(44066), // QC_CM_MVSA01
1890 UINT64_C(47618), // QC_CM_POP
1891 UINT64_C(48642), // QC_CM_POPRET
1892 UINT64_C(48130), // QC_CM_POPRETZ
1893 UINT64_C(47106), // QC_CM_PUSH
1894 UINT64_C(47362), // QC_CM_PUSHFP
1895 UINT64_C(12299), // QC_COMPRESS2
1896 UINT64_C(33566731), // QC_COMPRESS3
1897 UINT64_C(2348810355), // QC_CSRRWR
1898 UINT64_C(2382364787), // QC_CSRRWRI
1899 UINT64_C(167784459), // QC_CTO
1900 UINT64_C(36865), // QC_C_BEXTI
1901 UINT64_C(37889), // QC_C_BSETI
1902 UINT64_C(4110), // QC_C_CLRINT
1903 UINT64_C(6930), // QC_C_DI
1904 UINT64_C(4098), // QC_C_DIR
1905 UINT64_C(7058), // QC_C_EI
1906 UINT64_C(4102), // QC_C_EIR
1907 UINT64_C(4098), // QC_C_EXTU
1908 UINT64_C(6162), // QC_C_MIENTER
1909 UINT64_C(6290), // QC_C_MIENTER_NEST
1910 UINT64_C(6674), // QC_C_MILEAVERET
1911 UINT64_C(6546), // QC_C_MNRET
1912 UINT64_C(6418), // QC_C_MRET
1913 UINT64_C(8194), // QC_C_MULIADD
1914 UINT64_C(44034), // QC_C_MVEQZ
1915 UINT64_C(4106), // QC_C_SETINT
1916 UINT64_C(32769), // QC_C_SYNC
1917 UINT64_C(33793), // QC_C_SYNCR
1918 UINT64_C(36865), // QC_C_SYNCWF
1919 UINT64_C(37889), // QC_C_SYNCWL
1920 UINT64_C(67121163), // QC_EXPAND2
1921 UINT64_C(100675595), // QC_EXPAND3
1922 UINT64_C(1073750027), // QC_EXT
1923 UINT64_C(3221233675), // QC_EXTD
1924 UINT64_C(268447755), // QC_EXTDPR
1925 UINT64_C(302002187), // QC_EXTDPRH
1926 UINT64_C(167784459), // QC_EXTDR
1927 UINT64_C(2147491851), // QC_EXTDU
1928 UINT64_C(201338891), // QC_EXTDUPR
1929 UINT64_C(234893323), // QC_EXTDUPRH
1930 UINT64_C(134230027), // QC_EXTDUR
1931 UINT64_C(8203), // QC_EXTU
1932 UINT64_C(8223), // QC_E_ADDAI
1933 UINT64_C(2147495967), // QC_E_ADDI
1934 UINT64_C(40991), // QC_E_ANDAI
1935 UINT64_C(3221237791), // QC_E_ANDI
1936 UINT64_C(25182239), // QC_E_BEQI
1937 UINT64_C(30425119), // QC_E_BGEI
1938 UINT64_C(32522271), // QC_E_BGEUI
1939 UINT64_C(29376543), // QC_E_BLTI
1940 UINT64_C(31473695), // QC_E_BLTUI
1941 UINT64_C(26230815), // QC_E_BNEI
1942 UINT64_C(16415), // QC_E_J
1943 UINT64_C(49183), // QC_E_JAL
1944 UINT64_C(20511), // QC_E_LB
1945 UINT64_C(1073762335), // QC_E_LBU
1946 UINT64_C(2147504159), // QC_E_LH
1947 UINT64_C(3221245983), // QC_E_LHU
1948 UINT64_C(31), // QC_E_LI
1949 UINT64_C(24607), // QC_E_LW
1950 UINT64_C(36895), // QC_E_ORAI
1951 UINT64_C(1073754143), // QC_E_ORI
1952 UINT64_C(1073766431), // QC_E_SB
1953 UINT64_C(2147508255), // QC_E_SH
1954 UINT64_C(3221250079), // QC_E_SW
1955 UINT64_C(4127), // QC_E_XORAI
1956 UINT64_C(12319), // QC_E_XORI
1957 UINT64_C(1073745931), // QC_INSB
1958 UINT64_C(2147487755), // QC_INSBH
1959 UINT64_C(33566731), // QC_INSBHR
1960 UINT64_C(4107), // QC_INSBI
1961 UINT64_C(67121163), // QC_INSBPR
1962 UINT64_C(100675595), // QC_INSBPRH
1963 UINT64_C(12299), // QC_INSBR
1964 UINT64_C(2147483659), // QC_INSBRI
1965 UINT64_C(20491), // QC_INW
1966 UINT64_C(27), // QC_LI
1967 UINT64_C(33554523), // QC_LIEQ
1968 UINT64_C(100663387), // QC_LIEQI
1969 UINT64_C(33575003), // QC_LIGE
1970 UINT64_C(100683867), // QC_LIGEI
1971 UINT64_C(33583195), // QC_LIGEU
1972 UINT64_C(100692059), // QC_LIGEUI
1973 UINT64_C(33570907), // QC_LILT
1974 UINT64_C(100679771), // QC_LILTI
1975 UINT64_C(33579099), // QC_LILTU
1976 UINT64_C(100687963), // QC_LILTUI
1977 UINT64_C(33558619), // QC_LINE
1978 UINT64_C(100667483), // QC_LINEI
1979 UINT64_C(2147512331), // QC_LRB
1980 UINT64_C(2952818699), // QC_LRBU
1981 UINT64_C(2415947787), // QC_LRH
1982 UINT64_C(3221254155), // QC_LRHU
1983 UINT64_C(2684383243), // QC_LRW
1984 UINT64_C(28683), // QC_LWM
1985 UINT64_C(1073770507), // QC_LWMI
1986 UINT64_C(24587), // QC_MULIADD
1987 UINT64_C(91), // QC_MVEQ
1988 UINT64_C(67108955), // QC_MVEQI
1989 UINT64_C(20571), // QC_MVGE
1990 UINT64_C(67129435), // QC_MVGEI
1991 UINT64_C(28763), // QC_MVGEU
1992 UINT64_C(67137627), // QC_MVGEUI
1993 UINT64_C(16475), // QC_MVLT
1994 UINT64_C(67125339), // QC_MVLTI
1995 UINT64_C(24667), // QC_MVLTU
1996 UINT64_C(67133531), // QC_MVLTUI
1997 UINT64_C(4187), // QC_MVNE
1998 UINT64_C(67113051), // QC_MVNEI
1999 UINT64_C(234893323), // QC_NORM
2000 UINT64_C(302002187), // QC_NORMEU
2001 UINT64_C(268447755), // QC_NORMU
2002 UINT64_C(16395), // QC_OUTW
2003 UINT64_C(1073750035), // QC_PPUTCI
2004 UINT64_C(67117147), // QC_SELECTEQI
2005 UINT64_C(33562715), // QC_SELECTIEQ
2006 UINT64_C(100671579), // QC_SELECTIEQI
2007 UINT64_C(8283), // QC_SELECTIIEQ
2008 UINT64_C(12379), // QC_SELECTIINE
2009 UINT64_C(33566811), // QC_SELECTINE
2010 UINT64_C(100675675), // QC_SELECTINEI
2011 UINT64_C(67121243), // QC_SELECTNEI
2012 UINT64_C(3422552179), // QC_SETINTI
2013 UINT64_C(2147512363), // QC_SETWM
2014 UINT64_C(3221254187), // QC_SETWMI
2015 UINT64_C(1073754123), // QC_SHLADD
2016 UINT64_C(335556619), // QC_SHLSAT
2017 UINT64_C(402665483), // QC_SHLUSAT
2018 UINT64_C(3489685547), // QC_SRB
2019 UINT64_C(3758121003), // QC_SRH
2020 UINT64_C(4026556459), // QC_SRW
2021 UINT64_C(536883211), // QC_SUBSAT
2022 UINT64_C(570437643), // QC_SUBUSAT
2023 UINT64_C(28715), // QC_SWM
2024 UINT64_C(1073770539), // QC_SWMI
2025 UINT64_C(268447763), // QC_SYNC
2026 UINT64_C(536883219), // QC_SYNCR
2027 UINT64_C(1073754131), // QC_SYNCWF
2028 UINT64_C(2147495955), // QC_SYNCWL
2029 UINT64_C(603992075), // QC_WRAP
2030 UINT64_C(11), // QC_WRAPI
2031 UINT64_C(8192), // QK_C_LBU
2032 UINT64_C(32768), // QK_C_LBUSP
2033 UINT64_C(8194), // QK_C_LHU
2034 UINT64_C(32800), // QK_C_LHUSP
2035 UINT64_C(40960), // QK_C_SB
2036 UINT64_C(32832), // QK_C_SBSP
2037 UINT64_C(40962), // QK_C_SH
2038 UINT64_C(32864), // QK_C_SHSP
2039 UINT64_C(33579059), // REM
2040 UINT64_C(33583155), // REMU
2041 UINT64_C(33583163), // REMUW
2042 UINT64_C(33579067), // REMW
2043 UINT64_C(1795182611), // REV16_RV64
2044 UINT64_C(1770016787), // REV8_RV32
2045 UINT64_C(1803571219), // REV8_RV64
2046 UINT64_C(1777356819), // REV_RV32
2047 UINT64_C(1810911251), // REV_RV64
2048 UINT64_C(1610616883), // ROL
2049 UINT64_C(1610616891), // ROLW
2050 UINT64_C(1610633267), // ROR
2051 UINT64_C(1610633235), // RORI
2052 UINT64_C(1610633243), // RORIW
2053 UINT64_C(1610633275), // RORW
2054 UINT64_C(2449473595), // SADD
2055 UINT64_C(2986344507), // SADDU
2056 UINT64_C(3791667227), // SATI_RV32
2057 UINT64_C(3825221659), // SATI_RV64
2058 UINT64_C(35), // SB
2059 UINT64_C(1040187439), // SB_AQRL
2060 UINT64_C(973078575), // SB_RL
2061 UINT64_C(272629875), // SCTRCLR
2062 UINT64_C(402665519), // SC_D
2063 UINT64_C(469774383), // SC_D_AQ
2064 UINT64_C(503328815), // SC_D_AQRL
2065 UINT64_C(436219951), // SC_D_RL
2066 UINT64_C(402661423), // SC_W
2067 UINT64_C(469770287), // SC_W_AQ
2068 UINT64_C(503324719), // SC_W_AQRL
2069 UINT64_C(436215855), // SC_W_RL
2070 UINT64_C(12323), // SD
2071 UINT64_C(1040199727), // SD_AQRL
2072 UINT64_C(973090863), // SD_RL
2073 UINT64_C(12323), // SD_RV32
2074 UINT64_C(1614811155), // SEXT_B
2075 UINT64_C(1615859731), // SEXT_H
2076 UINT64_C(403701875), // SFENCE_INVAL_IR
2077 UINT64_C(301990003), // SFENCE_VMA
2078 UINT64_C(402653299), // SFENCE_W_INVAL
2079 UINT64_C(4229955699), // SF_CDISCARD_D_L1
2080 UINT64_C(810549363), // SF_CEASE
2081 UINT64_C(4227858547), // SF_CFLUSH_D_L1
2082 UINT64_C(4261417207), // SF_MM_E4M3_E4M3
2083 UINT64_C(4261417079), // SF_MM_E4M3_E5M2
2084 UINT64_C(4194308343), // SF_MM_E5M2_E4M3
2085 UINT64_C(4194308215), // SF_MM_E5M2_E5M2
2086 UINT64_C(4060090487), // SF_MM_F_F
2087 UINT64_C(4127195383), // SF_MM_S_S
2088 UINT64_C(4127195255), // SF_MM_S_U
2089 UINT64_C(4060086519), // SF_MM_U_S
2090 UINT64_C(4060086391), // SF_MM_U_U
2091 UINT64_C(704663643), // SF_VC_FV
2092 UINT64_C(2852147291), // SF_VC_FVV
2093 UINT64_C(4194324571), // SF_VC_FVW
2094 UINT64_C(33566811), // SF_VC_I
2095 UINT64_C(570437723), // SF_VC_IV
2096 UINT64_C(2717921371), // SF_VC_IVV
2097 UINT64_C(4060098651), // SF_VC_IVW
2098 UINT64_C(570425435), // SF_VC_VV
2099 UINT64_C(2717909083), // SF_VC_VVV
2100 UINT64_C(4060086363), // SF_VC_VVW
2101 UINT64_C(671109211), // SF_VC_V_FV
2102 UINT64_C(2818592859), // SF_VC_V_FVV
2103 UINT64_C(4160770139), // SF_VC_V_FVW
2104 UINT64_C(12379), // SF_VC_V_I
2105 UINT64_C(536883291), // SF_VC_V_IV
2106 UINT64_C(2684366939), // SF_VC_V_IVV
2107 UINT64_C(4026544219), // SF_VC_V_IVW
2108 UINT64_C(536871003), // SF_VC_V_VV
2109 UINT64_C(2684354651), // SF_VC_V_VVV
2110 UINT64_C(4026531931), // SF_VC_V_VVW
2111 UINT64_C(16475), // SF_VC_V_X
2112 UINT64_C(536887387), // SF_VC_V_XV
2113 UINT64_C(2684371035), // SF_VC_V_XVV
2114 UINT64_C(4026548315), // SF_VC_V_XVW
2115 UINT64_C(33570907), // SF_VC_X
2116 UINT64_C(570441819), // SF_VC_XV
2117 UINT64_C(2717925467), // SF_VC_XVV
2118 UINT64_C(4060102747), // SF_VC_XVW
2119 UINT64_C(1275269207), // SF_VFEXPA_V
2120 UINT64_C(1275301975), // SF_VFEXP_V
2121 UINT64_C(2281721947), // SF_VFNRCLIP_XU_F_QF
2122 UINT64_C(2348830811), // SF_VFNRCLIP_X_F_QF
2123 UINT64_C(4060090459), // SF_VFWMACC_4x4x4
2124 UINT64_C(838889479), // SF_VLTE16
2125 UINT64_C(1375760391), // SF_VLTE32
2126 UINT64_C(1912631303), // SF_VLTE64
2127 UINT64_C(302018567), // SF_VLTE8
2128 UINT64_C(3187679323), // SF_VQMACCSU_2x8x2
2129 UINT64_C(4261421147), // SF_VQMACCSU_4x8x4
2130 UINT64_C(3120570459), // SF_VQMACCUS_2x8x2
2131 UINT64_C(4194312283), // SF_VQMACCUS_4x8x4
2132 UINT64_C(2986352731), // SF_VQMACCU_2x8x2
2133 UINT64_C(4060094555), // SF_VQMACCU_4x8x4
2134 UINT64_C(3053461595), // SF_VQMACC_2x8x2
2135 UINT64_C(4127203419), // SF_VQMACC_4x8x4
2136 UINT64_C(2216718423), // SF_VSETTK
2137 UINT64_C(2215669847), // SF_VSETTM
2138 UINT64_C(2214621271), // SF_VSETTN
2139 UINT64_C(838889511), // SF_VSTE16
2140 UINT64_C(1375760423), // SF_VSTE32
2141 UINT64_C(1912631335), // SF_VSTE64
2142 UINT64_C(302018599), // SF_VSTE8
2143 UINT64_C(1136681047), // SF_VTDISCARD
2144 UINT64_C(1577082967), // SF_VTMV_T_V
2145 UINT64_C(1139826775), // SF_VTMV_V_T
2146 UINT64_C(1138778199), // SF_VTZERO_T
2147 UINT64_C(4131), // SH
2148 UINT64_C(536879155), // SH1ADD
2149 UINT64_C(536879163), // SH1ADD_UW
2150 UINT64_C(536887347), // SH2ADD
2151 UINT64_C(536887355), // SH2ADD_UW
2152 UINT64_C(536895539), // SH3ADD
2153 UINT64_C(536895547), // SH3ADD_UW
2154 UINT64_C(3992985627), // SHA
2155 UINT64_C(270536723), // SHA256SIG0
2156 UINT64_C(271585299), // SHA256SIG1
2157 UINT64_C(268439571), // SHA256SUM0
2158 UINT64_C(269488147), // SHA256SUM1
2159 UINT64_C(274731027), // SHA512SIG0
2160 UINT64_C(1543503923), // SHA512SIG0H
2161 UINT64_C(1409286195), // SHA512SIG0L
2162 UINT64_C(275779603), // SHA512SIG1
2163 UINT64_C(1577058355), // SHA512SIG1H
2164 UINT64_C(1442840627), // SHA512SIG1L
2165 UINT64_C(272633875), // SHA512SUM0
2166 UINT64_C(1342177331), // SHA512SUM0R
2167 UINT64_C(273682451), // SHA512SUM1
2168 UINT64_C(1375731763), // SHA512SUM1R
2169 UINT64_C(4261421083), // SHAR
2170 UINT64_C(2919243803), // SHL
2171 UINT64_C(3187679259), // SHLR
2172 UINT64_C(1040191535), // SH_AQRL
2173 UINT64_C(4131), // SH_INX
2174 UINT64_C(973082671), // SH_RL
2175 UINT64_C(369098867), // SINVAL_VMA
2176 UINT64_C(4147), // SLL
2177 UINT64_C(4115), // SLLI
2178 UINT64_C(4123), // SLLIW
2179 UINT64_C(134221851), // SLLI_UW
2180 UINT64_C(4155), // SLLW
2181 UINT64_C(8243), // SLT
2182 UINT64_C(8211), // SLTI
2183 UINT64_C(12307), // SLTIU
2184 UINT64_C(12339), // SLTU
2185 UINT64_C(2382368827), // SLX
2186 UINT64_C(276828179), // SM3P0
2187 UINT64_C(277876755), // SM3P1
2188 UINT64_C(805306419), // SM4ED
2189 UINT64_C(872415283), // SM4KS
2190 UINT64_C(3791663147), // SMT_VMADOT
2191 UINT64_C(3858772011), // SMT_VMADOT1
2192 UINT64_C(3858767915), // SMT_VMADOT1SU
2193 UINT64_C(3858759723), // SMT_VMADOT1U
2194 UINT64_C(3858763819), // SMT_VMADOT1US
2195 UINT64_C(3858788395), // SMT_VMADOT2
2196 UINT64_C(3858784299), // SMT_VMADOT2SU
2197 UINT64_C(3858776107), // SMT_VMADOT2U
2198 UINT64_C(3858780203), // SMT_VMADOT2US
2199 UINT64_C(3858804779), // SMT_VMADOT3
2200 UINT64_C(3858800683), // SMT_VMADOT3SU
2201 UINT64_C(3858792491), // SMT_VMADOT3U
2202 UINT64_C(3858796587), // SMT_VMADOT3US
2203 UINT64_C(3791659051), // SMT_VMADOTSU
2204 UINT64_C(3791650859), // SMT_VMADOTU
2205 UINT64_C(3791654955), // SMT_VMADOTUS
2206 UINT64_C(1073762355), // SRA
2207 UINT64_C(1073762323), // SRAI
2208 UINT64_C(1073762331), // SRAIW
2209 UINT64_C(3523231771), // SRARI_RV32
2210 UINT64_C(3556786203), // SRARI_RV64
2211 UINT64_C(1073762363), // SRAW
2212 UINT64_C(270532723), // SRET
2213 UINT64_C(20531), // SRL
2214 UINT64_C(20499), // SRLI
2215 UINT64_C(20507), // SRLIW
2216 UINT64_C(20603), // SRLIY
2217 UINT64_C(20539), // SRLW
2218 UINT64_C(2919239739), // SRX
2219 UINT64_C(1207971887), // SSAMOSWAP_D
2220 UINT64_C(1275080751), // SSAMOSWAP_D_AQ
2221 UINT64_C(1308635183), // SSAMOSWAP_D_AQRL
2222 UINT64_C(1241526319), // SSAMOSWAP_D_RL
2223 UINT64_C(1207967791), // SSAMOSWAP_W
2224 UINT64_C(1275076655), // SSAMOSWAP_W_AQ
2225 UINT64_C(1308631087), // SSAMOSWAP_W_AQRL
2226 UINT64_C(1241522223), // SSAMOSWAP_W_RL
2227 UINT64_C(2986352699), // SSH1SADD
2228 UINT64_C(3925876763), // SSHA
2229 UINT64_C(4194312219), // SSHAR
2230 UINT64_C(2852134939), // SSHL
2231 UINT64_C(3120570395), // SSHLR
2232 UINT64_C(3523223579), // SSLAI
2233 UINT64_C(3451928691), // SSPOPCHK
2234 UINT64_C(3456122995), // SSPUSH
2235 UINT64_C(3451928691), // SSRDP
2236 UINT64_C(3523215419), // SSUB
2237 UINT64_C(4060086331), // SSUBU
2238 UINT64_C(1073741875), // SUB
2239 UINT64_C(3321913371), // SUBD
2240 UINT64_C(1073741883), // SUBW
2241 UINT64_C(8227), // SW
2242 UINT64_C(1040195631), // SW_AQRL
2243 UINT64_C(8227), // SW_INX
2244 UINT64_C(973086767), // SW_RL
2245 UINT64_C(4107), // TH_ADDSL
2246 UINT64_C(1048587), // TH_DCACHE_CALL
2247 UINT64_C(3145739), // TH_DCACHE_CIALL
2248 UINT64_C(45088779), // TH_DCACHE_CIPA
2249 UINT64_C(36700171), // TH_DCACHE_CISW
2250 UINT64_C(40894475), // TH_DCACHE_CIVA
2251 UINT64_C(42991627), // TH_DCACHE_CPA
2252 UINT64_C(41943051), // TH_DCACHE_CPAL1
2253 UINT64_C(34603019), // TH_DCACHE_CSW
2254 UINT64_C(38797323), // TH_DCACHE_CVA
2255 UINT64_C(37748747), // TH_DCACHE_CVAL1
2256 UINT64_C(2097163), // TH_DCACHE_IALL
2257 UINT64_C(44040203), // TH_DCACHE_IPA
2258 UINT64_C(35651595), // TH_DCACHE_ISW
2259 UINT64_C(39845899), // TH_DCACHE_IVA
2260 UINT64_C(8203), // TH_EXT
2261 UINT64_C(12299), // TH_EXTU
2262 UINT64_C(2214596619), // TH_FF0
2263 UINT64_C(2248151051), // TH_FF1
2264 UINT64_C(1610637323), // TH_FLRD
2265 UINT64_C(1073766411), // TH_FLRW
2266 UINT64_C(1879072779), // TH_FLURD
2267 UINT64_C(1342201867), // TH_FLURW
2268 UINT64_C(1610641419), // TH_FSRD
2269 UINT64_C(1073770507), // TH_FSRW
2270 UINT64_C(1879076875), // TH_FSURD
2271 UINT64_C(1342205963), // TH_FSURW
2272 UINT64_C(16777227), // TH_ICACHE_IALL
2273 UINT64_C(17825803), // TH_ICACHE_IALLS
2274 UINT64_C(58720267), // TH_ICACHE_IPA
2275 UINT64_C(50331659), // TH_ICACHE_IVA
2276 UINT64_C(22020107), // TH_L2CACHE_CALL
2277 UINT64_C(24117259), // TH_L2CACHE_CIALL
2278 UINT64_C(23068683), // TH_L2CACHE_IALL
2279 UINT64_C(402669579), // TH_LBIA
2280 UINT64_C(134234123), // TH_LBIB
2281 UINT64_C(2550153227), // TH_LBUIA
2282 UINT64_C(2281717771), // TH_LBUIB
2283 UINT64_C(4160765963), // TH_LDD
2284 UINT64_C(2013282315), // TH_LDIA
2285 UINT64_C(1744846859), // TH_LDIB
2286 UINT64_C(939540491), // TH_LHIA
2287 UINT64_C(671105035), // TH_LHIB
2288 UINT64_C(3087024139), // TH_LHUIA
2289 UINT64_C(2818588683), // TH_LHUIB
2290 UINT64_C(16395), // TH_LRB
2291 UINT64_C(2147500043), // TH_LRBU
2292 UINT64_C(1610629131), // TH_LRD
2293 UINT64_C(536887307), // TH_LRH
2294 UINT64_C(2684370955), // TH_LRHU
2295 UINT64_C(1073758219), // TH_LRW
2296 UINT64_C(3221241867), // TH_LRWU
2297 UINT64_C(268451851), // TH_LURB
2298 UINT64_C(2415935499), // TH_LURBU
2299 UINT64_C(1879064587), // TH_LURD
2300 UINT64_C(805322763), // TH_LURH
2301 UINT64_C(2952806411), // TH_LURHU
2302 UINT64_C(1342193675), // TH_LURW
2303 UINT64_C(3489677323), // TH_LURWU
2304 UINT64_C(3758112779), // TH_LWD
2305 UINT64_C(1476411403), // TH_LWIA
2306 UINT64_C(1207975947), // TH_LWIB
2307 UINT64_C(4026548235), // TH_LWUD
2308 UINT64_C(3623895051), // TH_LWUIA
2309 UINT64_C(3355459595), // TH_LWUIB
2310 UINT64_C(536875019), // TH_MULA
2311 UINT64_C(671092747), // TH_MULAH
2312 UINT64_C(603983883), // TH_MULAW
2313 UINT64_C(570429451), // TH_MULS
2314 UINT64_C(704647179), // TH_MULSH
2315 UINT64_C(637538315), // TH_MULSW
2316 UINT64_C(1073745931), // TH_MVEQZ
2317 UINT64_C(1107300363), // TH_MVNEZ
2318 UINT64_C(2181042187), // TH_REV
2319 UINT64_C(2415923211), // TH_REVW
2320 UINT64_C(402673675), // TH_SBIA
2321 UINT64_C(134238219), // TH_SBIB
2322 UINT64_C(4160770059), // TH_SDD
2323 UINT64_C(2013286411), // TH_SDIA
2324 UINT64_C(1744850955), // TH_SDIB
2325 UINT64_C(67108875), // TH_SFENCE_VMAS
2326 UINT64_C(939544587), // TH_SHIA
2327 UINT64_C(671109131), // TH_SHIB
2328 UINT64_C(20491), // TH_SRB
2329 UINT64_C(1610633227), // TH_SRD
2330 UINT64_C(536891403), // TH_SRH
2331 UINT64_C(268439563), // TH_SRRI
2332 UINT64_C(335548427), // TH_SRRIW
2333 UINT64_C(1073762315), // TH_SRW
2334 UINT64_C(268455947), // TH_SURB
2335 UINT64_C(1879068683), // TH_SURD
2336 UINT64_C(805326859), // TH_SURH
2337 UINT64_C(1342197771), // TH_SURW
2338 UINT64_C(3758116875), // TH_SWD
2339 UINT64_C(1476415499), // TH_SWIA
2340 UINT64_C(1207980043), // TH_SWIB
2341 UINT64_C(25165835), // TH_SYNC
2342 UINT64_C(27262987), // TH_SYNC_I
2343 UINT64_C(28311563), // TH_SYNC_IS
2344 UINT64_C(26214411), // TH_SYNC_S
2345 UINT64_C(2281705483), // TH_TST
2346 UINT64_C(2147487755), // TH_TSTNBZ
2347 UINT64_C(2415943691), // TH_VMAQASU_VV
2348 UINT64_C(2483052555), // TH_VMAQASU_VX
2349 UINT64_C(2617270283), // TH_VMAQAUS_VX
2350 UINT64_C(2281725963), // TH_VMAQAU_VV
2351 UINT64_C(2348834827), // TH_VMAQAU_VX
2352 UINT64_C(2147508235), // TH_VMAQA_VV
2353 UINT64_C(2214617099), // TH_VMAQA_VX
2354 UINT64_C(3221229683), // UNIMP
2355 UINT64_C(3858767931), // UNZIP16HP
2356 UINT64_C(3791659067), // UNZIP16P
2357 UINT64_C(3825213499), // UNZIP8HP
2358 UINT64_C(3758104635), // UNZIP8P
2359 UINT64_C(149966867), // UNZIP_RV32
2360 UINT64_C(2717925403), // USATI_RV32
2361 UINT64_C(2751479835), // USATI_RV64
2362 UINT64_C(3992977495), // V8WMMACC_VV
2363 UINT64_C(536879191), // VAADDU_VV
2364 UINT64_C(536895575), // VAADDU_VX
2365 UINT64_C(603988055), // VAADD_VV
2366 UINT64_C(604004439), // VAADD_VX
2367 UINT64_C(1275076695), // VABDU_VV
2368 UINT64_C(1140858967), // VABD_VV
2369 UINT64_C(1208492119), // VABS_V
2370 UINT64_C(1073754199), // VADC_VIM
2371 UINT64_C(1073741911), // VADC_VVM
2372 UINT64_C(1073758295), // VADC_VXM
2373 UINT64_C(12375), // VADD_VI
2374 UINT64_C(87), // VADD_VV
2375 UINT64_C(16471), // VADD_VX
2376 UINT64_C(2785058935), // VAESDF_VS
2377 UINT64_C(2717950071), // VAESDF_VV
2378 UINT64_C(2785026167), // VAESDM_VS
2379 UINT64_C(2717917303), // VAESDM_VV
2380 UINT64_C(2785124471), // VAESEF_VS
2381 UINT64_C(2718015607), // VAESEF_VV
2382 UINT64_C(2785091703), // VAESEM_VS
2383 UINT64_C(2717982839), // VAESEM_VV
2384 UINT64_C(2315264119), // VAESKF1_VI
2385 UINT64_C(2852135031), // VAESKF2_VI
2386 UINT64_C(2785255543), // VAESZ_VS
2387 UINT64_C(67108951), // VANDN_VV
2388 UINT64_C(67125335), // VANDN_VX
2389 UINT64_C(603992151), // VAND_VI
2390 UINT64_C(603979863), // VAND_VV
2391 UINT64_C(603996247), // VAND_VX
2392 UINT64_C(671096919), // VASUBU_VV
2393 UINT64_C(671113303), // VASUBU_VX
2394 UINT64_C(738205783), // VASUB_VV
2395 UINT64_C(738222167), // VASUB_VX
2396 UINT64_C(1208229975), // VBREV8_V
2397 UINT64_C(1208295511), // VBREV_V
2398 UINT64_C(872423511), // VCLMULH_VV
2399 UINT64_C(872439895), // VCLMULH_VX
2400 UINT64_C(805314647), // VCLMUL_VV
2401 UINT64_C(805331031), // VCLMUL_VX
2402 UINT64_C(1208361047), // VCLZ_V
2403 UINT64_C(1577066583), // VCOMPRESS_VM
2404 UINT64_C(1074274391), // VCPOP_M
2405 UINT64_C(1208426583), // VCPOP_V
2406 UINT64_C(1208393815), // VCTZ_V
2407 UINT64_C(2147491927), // VDIVU_VV
2408 UINT64_C(2147508311), // VDIVU_VX
2409 UINT64_C(2214600791), // VDIV_VV
2410 UINT64_C(2214617175), // VDIV_VX
2411 UINT64_C(2818580567), // VDOT4ASU_VV
2412 UINT64_C(2818596951), // VDOT4ASU_VX
2413 UINT64_C(3087032407), // VDOT4AUS_VX
2414 UINT64_C(2684362839), // VDOT4AU_VV
2415 UINT64_C(2684379223), // VDOT4AU_VX
2416 UINT64_C(2952798295), // VDOT4A_VV
2417 UINT64_C(2952814679), // VDOT4A_VX
2418 UINT64_C(3959423063), // VF8WIMMACC_VV
2419 UINT64_C(1577062487), // VF8WMMACC_VV
2420 UINT64_C(1543508055), // VF8WMMACC_VV_SCALE
2421 UINT64_C(20567), // VFADD_VF
2422 UINT64_C(4183), // VFADD_VV
2423 UINT64_C(2885685367), // VFBDOTA_VV
2424 UINT64_C(1275596887), // VFCLASS_V
2425 UINT64_C(1208029271), // VFCVT_F_XU_V
2426 UINT64_C(1208062039), // VFCVT_F_X_V
2427 UINT64_C(1208160343), // VFCVT_RTZ_XU_F_V
2428 UINT64_C(1208193111), // VFCVT_RTZ_X_F_V
2429 UINT64_C(1207963735), // VFCVT_XU_F_V
2430 UINT64_C(1207996503), // VFCVT_X_F_V
2431 UINT64_C(2147504215), // VFDIV_VF
2432 UINT64_C(2147487831), // VFDIV_VV
2433 UINT64_C(1074307159), // VFIRST_M
2434 UINT64_C(2952810583), // VFMACC_VF
2435 UINT64_C(2952794199), // VFMACC_VV
2436 UINT64_C(2684375127), // VFMADD_VF
2437 UINT64_C(2684358743), // VFMADD_VV
2438 UINT64_C(402673751), // VFMAX_VF
2439 UINT64_C(402657367), // VFMAX_VV
2440 UINT64_C(1543524439), // VFMERGE_VFM
2441 UINT64_C(268456023), // VFMIN_VF
2442 UINT64_C(268439639), // VFMIN_VV
2443 UINT64_C(1375735895), // VFMMACC_VV
2444 UINT64_C(3087028311), // VFMSAC_VF
2445 UINT64_C(3087011927), // VFMSAC_VV
2446 UINT64_C(2818592855), // VFMSUB_VF
2447 UINT64_C(2818576471), // VFMSUB_VV
2448 UINT64_C(2415939671), // VFMUL_VF
2449 UINT64_C(2415923287), // VFMUL_VV
2450 UINT64_C(1107300439), // VFMV_F_S
2451 UINT64_C(1107316823), // VFMV_S_F
2452 UINT64_C(1577078871), // VFMV_V_F
2453 UINT64_C(1208914007), // VFNCVTBF16_F_F_W
2454 UINT64_C(1208979543), // VFNCVTBF16_SAT_F_F_W
2455 UINT64_C(1208782935), // VFNCVT_F_F_Q
2456 UINT64_C(1208619095), // VFNCVT_F_F_W
2457 UINT64_C(1208553559), // VFNCVT_F_XU_W
2458 UINT64_C(1208586327), // VFNCVT_F_X_W
2459 UINT64_C(1208651863), // VFNCVT_ROD_F_F_W
2460 UINT64_C(1208684631), // VFNCVT_RTZ_XU_F_W
2461 UINT64_C(1208717399), // VFNCVT_RTZ_X_F_W
2462 UINT64_C(1208848471), // VFNCVT_SAT_F_F_Q
2463 UINT64_C(1208488023), // VFNCVT_XU_F_W
2464 UINT64_C(1208520791), // VFNCVT_X_F_W
2465 UINT64_C(3019919447), // VFNMACC_VF
2466 UINT64_C(3019903063), // VFNMACC_VV
2467 UINT64_C(2751483991), // VFNMADD_VF
2468 UINT64_C(2751467607), // VFNMADD_VV
2469 UINT64_C(3154137175), // VFNMSAC_VF
2470 UINT64_C(3154120791), // VFNMSAC_VV
2471 UINT64_C(2885701719), // VFNMSUB_VF
2472 UINT64_C(2885685335), // VFNMSUB_VV
2473 UINT64_C(3892314199), // VFQIMMACC_VV
2474 UINT64_C(1509953623), // VFQMMACC_VV
2475 UINT64_C(1476399191), // VFQMMACC_VV_SCALE
2476 UINT64_C(3154120823), // VFQWBDOTA_ALT_VV
2477 UINT64_C(3087011959), // VFQWBDOTA_VV
2478 UINT64_C(2617249911), // VFQWDOTA_ALT_VV
2479 UINT64_C(2550141047), // VFQWDOTA_VV
2480 UINT64_C(2214613079), // VFRDIV_VF
2481 UINT64_C(1275236439), // VFREC7_V
2482 UINT64_C(469766231), // VFREDMAX_VS
2483 UINT64_C(335548503), // VFREDMIN_VS
2484 UINT64_C(201330775), // VFREDOSUM_VS
2485 UINT64_C(67113047), // VFREDUSUM_VS
2486 UINT64_C(1275203671), // VFRSQRT7_V
2487 UINT64_C(2617266263), // VFRSUB_VF
2488 UINT64_C(604000343), // VFSGNJN_VF
2489 UINT64_C(603983959), // VFSGNJN_VV
2490 UINT64_C(671109207), // VFSGNJX_VF
2491 UINT64_C(671092823), // VFSGNJX_VV
2492 UINT64_C(536891479), // VFSGNJ_VF
2493 UINT64_C(536875095), // VFSGNJ_VV
2494 UINT64_C(1006653527), // VFSLIDE1DOWN_VF
2495 UINT64_C(939544663), // VFSLIDE1UP_VF
2496 UINT64_C(1275072599), // VFSQRT_V
2497 UINT64_C(134238295), // VFSUB_VF
2498 UINT64_C(134221911), // VFSUB_VV
2499 UINT64_C(3221246039), // VFWADD_VF
2500 UINT64_C(3221229655), // VFWADD_VV
2501 UINT64_C(3489681495), // VFWADD_WF
2502 UINT64_C(3489665111), // VFWADD_WV
2503 UINT64_C(2952794231), // VFWBDOTA_VV
2504 UINT64_C(1208389719), // VFWCVTBF16_F_F_V
2505 UINT64_C(1208356951), // VFWCVT_F_F_V
2506 UINT64_C(1208291415), // VFWCVT_F_XU_V
2507 UINT64_C(1208324183), // VFWCVT_F_X_V
2508 UINT64_C(1208422487), // VFWCVT_RTZ_XU_F_V
2509 UINT64_C(1208455255), // VFWCVT_RTZ_X_F_V
2510 UINT64_C(1208225879), // VFWCVT_XU_F_V
2511 UINT64_C(1208258647), // VFWCVT_X_F_V
2512 UINT64_C(2415923319), // VFWDOTA_VV
2513 UINT64_C(3825205335), // VFWIMMACC_VV
2514 UINT64_C(3959443543), // VFWMACCBF16_VF
2515 UINT64_C(3959427159), // VFWMACCBF16_VV
2516 UINT64_C(4026552407), // VFWMACC_VF
2517 UINT64_C(4026536023), // VFWMACC_VV
2518 UINT64_C(1442844759), // VFWMMACC_VV
2519 UINT64_C(1409290327), // VFWMMACC_VV_SCALE
2520 UINT64_C(4160770135), // VFWMSAC_VF
2521 UINT64_C(4160753751), // VFWMSAC_VV
2522 UINT64_C(3758116951), // VFWMUL_VF
2523 UINT64_C(3758100567), // VFWMUL_VV
2524 UINT64_C(4093661271), // VFWNMACC_VF
2525 UINT64_C(4093644887), // VFWNMACC_VV
2526 UINT64_C(4227878999), // VFWNMSAC_VF
2527 UINT64_C(4227862615), // VFWNMSAC_VV
2528 UINT64_C(3422556247), // VFWREDOSUM_VS
2529 UINT64_C(3288338519), // VFWREDUSUM_VS
2530 UINT64_C(3355463767), // VFWSUB_VF
2531 UINT64_C(3355447383), // VFWSUB_VV
2532 UINT64_C(3623899223), // VFWSUB_WF
2533 UINT64_C(3623882839), // VFWSUB_WV
2534 UINT64_C(2382372983), // VGHSH_VS
2535 UINT64_C(2986352759), // VGHSH_VV
2536 UINT64_C(2785583223), // VGMUL_VS
2537 UINT64_C(2718474359), // VGMUL_VV
2538 UINT64_C(1342742615), // VID_V
2539 UINT64_C(1342709847), // VIOTA_M
2540 UINT64_C(41963527), // VL1RE16_V
2541 UINT64_C(41967623), // VL1RE32_V
2542 UINT64_C(41971719), // VL1RE64_V
2543 UINT64_C(41943047), // VL1RE8_V
2544 UINT64_C(578834439), // VL2RE16_V
2545 UINT64_C(578838535), // VL2RE32_V
2546 UINT64_C(578842631), // VL2RE64_V
2547 UINT64_C(578813959), // VL2RE8_V
2548 UINT64_C(1652576263), // VL4RE16_V
2549 UINT64_C(1652580359), // VL4RE32_V
2550 UINT64_C(1652584455), // VL4RE64_V
2551 UINT64_C(1652555783), // VL4RE8_V
2552 UINT64_C(3800059911), // VL8RE16_V
2553 UINT64_C(3800064007), // VL8RE32_V
2554 UINT64_C(3800068103), // VL8RE64_V
2555 UINT64_C(3800039431), // VL8RE8_V
2556 UINT64_C(16797703), // VLE16FF_V
2557 UINT64_C(20487), // VLE16_V
2558 UINT64_C(16801799), // VLE32FF_V
2559 UINT64_C(24583), // VLE32_V
2560 UINT64_C(16805895), // VLE64FF_V
2561 UINT64_C(28679), // VLE64_V
2562 UINT64_C(16777223), // VLE8FF_V
2563 UINT64_C(7), // VLE8_V
2564 UINT64_C(45088775), // VLM_V
2565 UINT64_C(201347079), // VLOXEI16_V
2566 UINT64_C(201351175), // VLOXEI32_V
2567 UINT64_C(201355271), // VLOXEI64_V
2568 UINT64_C(201326599), // VLOXEI8_V
2569 UINT64_C(738217991), // VLOXSEG2EI16_V
2570 UINT64_C(738222087), // VLOXSEG2EI32_V
2571 UINT64_C(738226183), // VLOXSEG2EI64_V
2572 UINT64_C(738197511), // VLOXSEG2EI8_V
2573 UINT64_C(1275088903), // VLOXSEG3EI16_V
2574 UINT64_C(1275092999), // VLOXSEG3EI32_V
2575 UINT64_C(1275097095), // VLOXSEG3EI64_V
2576 UINT64_C(1275068423), // VLOXSEG3EI8_V
2577 UINT64_C(1811959815), // VLOXSEG4EI16_V
2578 UINT64_C(1811963911), // VLOXSEG4EI32_V
2579 UINT64_C(1811968007), // VLOXSEG4EI64_V
2580 UINT64_C(1811939335), // VLOXSEG4EI8_V
2581 UINT64_C(2348830727), // VLOXSEG5EI16_V
2582 UINT64_C(2348834823), // VLOXSEG5EI32_V
2583 UINT64_C(2348838919), // VLOXSEG5EI64_V
2584 UINT64_C(2348810247), // VLOXSEG5EI8_V
2585 UINT64_C(2885701639), // VLOXSEG6EI16_V
2586 UINT64_C(2885705735), // VLOXSEG6EI32_V
2587 UINT64_C(2885709831), // VLOXSEG6EI64_V
2588 UINT64_C(2885681159), // VLOXSEG6EI8_V
2589 UINT64_C(3422572551), // VLOXSEG7EI16_V
2590 UINT64_C(3422576647), // VLOXSEG7EI32_V
2591 UINT64_C(3422580743), // VLOXSEG7EI64_V
2592 UINT64_C(3422552071), // VLOXSEG7EI8_V
2593 UINT64_C(3959443463), // VLOXSEG8EI16_V
2594 UINT64_C(3959447559), // VLOXSEG8EI32_V
2595 UINT64_C(3959451655), // VLOXSEG8EI64_V
2596 UINT64_C(3959422983), // VLOXSEG8EI8_V
2597 UINT64_C(134238215), // VLSE16_V
2598 UINT64_C(134242311), // VLSE32_V
2599 UINT64_C(134246407), // VLSE64_V
2600 UINT64_C(134217735), // VLSE8_V
2601 UINT64_C(553668615), // VLSEG2E16FF_V
2602 UINT64_C(536891399), // VLSEG2E16_V
2603 UINT64_C(553672711), // VLSEG2E32FF_V
2604 UINT64_C(536895495), // VLSEG2E32_V
2605 UINT64_C(553676807), // VLSEG2E64FF_V
2606 UINT64_C(536899591), // VLSEG2E64_V
2607 UINT64_C(553648135), // VLSEG2E8FF_V
2608 UINT64_C(536870919), // VLSEG2E8_V
2609 UINT64_C(1090539527), // VLSEG3E16FF_V
2610 UINT64_C(1073762311), // VLSEG3E16_V
2611 UINT64_C(1090543623), // VLSEG3E32FF_V
2612 UINT64_C(1073766407), // VLSEG3E32_V
2613 UINT64_C(1090547719), // VLSEG3E64FF_V
2614 UINT64_C(1073770503), // VLSEG3E64_V
2615 UINT64_C(1090519047), // VLSEG3E8FF_V
2616 UINT64_C(1073741831), // VLSEG3E8_V
2617 UINT64_C(1627410439), // VLSEG4E16FF_V
2618 UINT64_C(1610633223), // VLSEG4E16_V
2619 UINT64_C(1627414535), // VLSEG4E32FF_V
2620 UINT64_C(1610637319), // VLSEG4E32_V
2621 UINT64_C(1627418631), // VLSEG4E64FF_V
2622 UINT64_C(1610641415), // VLSEG4E64_V
2623 UINT64_C(1627389959), // VLSEG4E8FF_V
2624 UINT64_C(1610612743), // VLSEG4E8_V
2625 UINT64_C(2164281351), // VLSEG5E16FF_V
2626 UINT64_C(2147504135), // VLSEG5E16_V
2627 UINT64_C(2164285447), // VLSEG5E32FF_V
2628 UINT64_C(2147508231), // VLSEG5E32_V
2629 UINT64_C(2164289543), // VLSEG5E64FF_V
2630 UINT64_C(2147512327), // VLSEG5E64_V
2631 UINT64_C(2164260871), // VLSEG5E8FF_V
2632 UINT64_C(2147483655), // VLSEG5E8_V
2633 UINT64_C(2701152263), // VLSEG6E16FF_V
2634 UINT64_C(2684375047), // VLSEG6E16_V
2635 UINT64_C(2701156359), // VLSEG6E32FF_V
2636 UINT64_C(2684379143), // VLSEG6E32_V
2637 UINT64_C(2701160455), // VLSEG6E64FF_V
2638 UINT64_C(2684383239), // VLSEG6E64_V
2639 UINT64_C(2701131783), // VLSEG6E8FF_V
2640 UINT64_C(2684354567), // VLSEG6E8_V
2641 UINT64_C(3238023175), // VLSEG7E16FF_V
2642 UINT64_C(3221245959), // VLSEG7E16_V
2643 UINT64_C(3238027271), // VLSEG7E32FF_V
2644 UINT64_C(3221250055), // VLSEG7E32_V
2645 UINT64_C(3238031367), // VLSEG7E64FF_V
2646 UINT64_C(3221254151), // VLSEG7E64_V
2647 UINT64_C(3238002695), // VLSEG7E8FF_V
2648 UINT64_C(3221225479), // VLSEG7E8_V
2649 UINT64_C(3774894087), // VLSEG8E16FF_V
2650 UINT64_C(3758116871), // VLSEG8E16_V
2651 UINT64_C(3774898183), // VLSEG8E32FF_V
2652 UINT64_C(3758120967), // VLSEG8E32_V
2653 UINT64_C(3774902279), // VLSEG8E64FF_V
2654 UINT64_C(3758125063), // VLSEG8E64_V
2655 UINT64_C(3774873607), // VLSEG8E8FF_V
2656 UINT64_C(3758096391), // VLSEG8E8_V
2657 UINT64_C(671109127), // VLSSEG2E16_V
2658 UINT64_C(671113223), // VLSSEG2E32_V
2659 UINT64_C(671117319), // VLSSEG2E64_V
2660 UINT64_C(671088647), // VLSSEG2E8_V
2661 UINT64_C(1207980039), // VLSSEG3E16_V
2662 UINT64_C(1207984135), // VLSSEG3E32_V
2663 UINT64_C(1207988231), // VLSSEG3E64_V
2664 UINT64_C(1207959559), // VLSSEG3E8_V
2665 UINT64_C(1744850951), // VLSSEG4E16_V
2666 UINT64_C(1744855047), // VLSSEG4E32_V
2667 UINT64_C(1744859143), // VLSSEG4E64_V
2668 UINT64_C(1744830471), // VLSSEG4E8_V
2669 UINT64_C(2281721863), // VLSSEG5E16_V
2670 UINT64_C(2281725959), // VLSSEG5E32_V
2671 UINT64_C(2281730055), // VLSSEG5E64_V
2672 UINT64_C(2281701383), // VLSSEG5E8_V
2673 UINT64_C(2818592775), // VLSSEG6E16_V
2674 UINT64_C(2818596871), // VLSSEG6E32_V
2675 UINT64_C(2818600967), // VLSSEG6E64_V
2676 UINT64_C(2818572295), // VLSSEG6E8_V
2677 UINT64_C(3355463687), // VLSSEG7E16_V
2678 UINT64_C(3355467783), // VLSSEG7E32_V
2679 UINT64_C(3355471879), // VLSSEG7E64_V
2680 UINT64_C(3355443207), // VLSSEG7E8_V
2681 UINT64_C(3892334599), // VLSSEG8E16_V
2682 UINT64_C(3892338695), // VLSSEG8E32_V
2683 UINT64_C(3892342791), // VLSSEG8E64_V
2684 UINT64_C(3892314119), // VLSSEG8E8_V
2685 UINT64_C(67129351), // VLUXEI16_V
2686 UINT64_C(67133447), // VLUXEI32_V
2687 UINT64_C(67137543), // VLUXEI64_V
2688 UINT64_C(67108871), // VLUXEI8_V
2689 UINT64_C(604000263), // VLUXSEG2EI16_V
2690 UINT64_C(604004359), // VLUXSEG2EI32_V
2691 UINT64_C(604008455), // VLUXSEG2EI64_V
2692 UINT64_C(603979783), // VLUXSEG2EI8_V
2693 UINT64_C(1140871175), // VLUXSEG3EI16_V
2694 UINT64_C(1140875271), // VLUXSEG3EI32_V
2695 UINT64_C(1140879367), // VLUXSEG3EI64_V
2696 UINT64_C(1140850695), // VLUXSEG3EI8_V
2697 UINT64_C(1677742087), // VLUXSEG4EI16_V
2698 UINT64_C(1677746183), // VLUXSEG4EI32_V
2699 UINT64_C(1677750279), // VLUXSEG4EI64_V
2700 UINT64_C(1677721607), // VLUXSEG4EI8_V
2701 UINT64_C(2214612999), // VLUXSEG5EI16_V
2702 UINT64_C(2214617095), // VLUXSEG5EI32_V
2703 UINT64_C(2214621191), // VLUXSEG5EI64_V
2704 UINT64_C(2214592519), // VLUXSEG5EI8_V
2705 UINT64_C(2751483911), // VLUXSEG6EI16_V
2706 UINT64_C(2751488007), // VLUXSEG6EI32_V
2707 UINT64_C(2751492103), // VLUXSEG6EI64_V
2708 UINT64_C(2751463431), // VLUXSEG6EI8_V
2709 UINT64_C(3288354823), // VLUXSEG7EI16_V
2710 UINT64_C(3288358919), // VLUXSEG7EI32_V
2711 UINT64_C(3288363015), // VLUXSEG7EI64_V
2712 UINT64_C(3288334343), // VLUXSEG7EI8_V
2713 UINT64_C(3825225735), // VLUXSEG8EI16_V
2714 UINT64_C(3825229831), // VLUXSEG8EI32_V
2715 UINT64_C(3825233927), // VLUXSEG8EI64_V
2716 UINT64_C(3825205255), // VLUXSEG8EI8_V
2717 UINT64_C(3019907159), // VMACC_VV
2718 UINT64_C(3019923543), // VMACC_VX
2719 UINT64_C(1174417495), // VMADC_VI
2720 UINT64_C(1140863063), // VMADC_VIM
2721 UINT64_C(1174405207), // VMADC_VV
2722 UINT64_C(1140850775), // VMADC_VVM
2723 UINT64_C(1174421591), // VMADC_VX
2724 UINT64_C(1140867159), // VMADC_VXM
2725 UINT64_C(2751471703), // VMADD_VV
2726 UINT64_C(2751488087), // VMADD_VX
2727 UINT64_C(1644175447), // VMANDN_MM
2728 UINT64_C(1711284311), // VMAND_MM
2729 UINT64_C(402653271), // VMAXU_VV
2730 UINT64_C(402669655), // VMAXU_VX
2731 UINT64_C(469762135), // VMAX_VV
2732 UINT64_C(469778519), // VMAX_VX
2733 UINT64_C(1543516247), // VMERGE_VIM
2734 UINT64_C(1543503959), // VMERGE_VVM
2735 UINT64_C(1543520343), // VMERGE_VXM
2736 UINT64_C(1610633303), // VMFEQ_VF
2737 UINT64_C(1610616919), // VMFEQ_VV
2738 UINT64_C(2080395351), // VMFGE_VF
2739 UINT64_C(1946177623), // VMFGT_VF
2740 UINT64_C(1677742167), // VMFLE_VF
2741 UINT64_C(1677725783), // VMFLE_VV
2742 UINT64_C(1811959895), // VMFLT_VF
2743 UINT64_C(1811943511), // VMFLT_VV
2744 UINT64_C(1879068759), // VMFNE_VF
2745 UINT64_C(1879052375), // VMFNE_VV
2746 UINT64_C(268435543), // VMINU_VV
2747 UINT64_C(268451927), // VMINU_VX
2748 UINT64_C(335544407), // VMIN_VV
2749 UINT64_C(335560791), // VMIN_VX
2750 UINT64_C(3791650903), // VMMACC_VV
2751 UINT64_C(1979719767), // VMNAND_MM
2752 UINT64_C(2046828631), // VMNOR_MM
2753 UINT64_C(1912610903), // VMORN_MM
2754 UINT64_C(1778393175), // VMOR_MM
2755 UINT64_C(1308622935), // VMSBC_VV
2756 UINT64_C(1275068503), // VMSBC_VVM
2757 UINT64_C(1308639319), // VMSBC_VX
2758 UINT64_C(1275084887), // VMSBC_VXM
2759 UINT64_C(1342218327), // VMSBF_M
2760 UINT64_C(1610625111), // VMSEQ_VI
2761 UINT64_C(1610612823), // VMSEQ_VV
2762 UINT64_C(1610629207), // VMSEQ_VX
2763 UINT64_C(2013278295), // VMSGTU_VI
2764 UINT64_C(2013282391), // VMSGTU_VX
2765 UINT64_C(2080387159), // VMSGT_VI
2766 UINT64_C(2080391255), // VMSGT_VX
2767 UINT64_C(1342283863), // VMSIF_M
2768 UINT64_C(1879060567), // VMSLEU_VI
2769 UINT64_C(1879048279), // VMSLEU_VV
2770 UINT64_C(1879064663), // VMSLEU_VX
2771 UINT64_C(1946169431), // VMSLE_VI
2772 UINT64_C(1946157143), // VMSLE_VV
2773 UINT64_C(1946173527), // VMSLE_VX
2774 UINT64_C(1744830551), // VMSLTU_VV
2775 UINT64_C(1744846935), // VMSLTU_VX
2776 UINT64_C(1811939415), // VMSLT_VV
2777 UINT64_C(1811955799), // VMSLT_VX
2778 UINT64_C(1677733975), // VMSNE_VI
2779 UINT64_C(1677721687), // VMSNE_VV
2780 UINT64_C(1677738071), // VMSNE_VX
2781 UINT64_C(1342251095), // VMSOF_M
2782 UINT64_C(268464135), // VMTL_V
2783 UINT64_C(268464167), // VMTS_V
2784 UINT64_C(335572999), // VMTTL_V
2785 UINT64_C(335573031), // VMTTS_V
2786 UINT64_C(2550145111), // VMULHSU_VV
2787 UINT64_C(2550161495), // VMULHSU_VX
2788 UINT64_C(2415927383), // VMULHU_VV
2789 UINT64_C(2415943767), // VMULHU_VX
2790 UINT64_C(2617253975), // VMULH_VV
2791 UINT64_C(2617270359), // VMULH_VX
2792 UINT64_C(2483036247), // VMUL_VV
2793 UINT64_C(2483052631), // VMUL_VX
2794 UINT64_C(2650812503), // VMV1R_V
2795 UINT64_C(2650845271), // VMV2R_V
2796 UINT64_C(2650910807), // VMV4R_V
2797 UINT64_C(2651041879), // VMV8R_V
2798 UINT64_C(1107320919), // VMV_S_X
2799 UINT64_C(1577070679), // VMV_V_I
2800 UINT64_C(1577058391), // VMV_V_V
2801 UINT64_C(1577074775), // VMV_V_X
2802 UINT64_C(1107304535), // VMV_X_S
2803 UINT64_C(2113937495), // VMXNOR_MM
2804 UINT64_C(1845502039), // VMXOR_MM
2805 UINT64_C(3087020119), // VNCLIPU_WI
2806 UINT64_C(3087007831), // VNCLIPU_WV
2807 UINT64_C(3087024215), // VNCLIPU_WX
2808 UINT64_C(3154128983), // VNCLIP_WI
2809 UINT64_C(3154116695), // VNCLIP_WV
2810 UINT64_C(3154133079), // VNCLIP_WX
2811 UINT64_C(3154124887), // VNMSAC_VV
2812 UINT64_C(3154141271), // VNMSAC_VX
2813 UINT64_C(2885689431), // VNMSUB_VV
2814 UINT64_C(2885705815), // VNMSUB_VX
2815 UINT64_C(3019911255), // VNSRA_WI
2816 UINT64_C(3019898967), // VNSRA_WV
2817 UINT64_C(3019915351), // VNSRA_WX
2818 UINT64_C(2952802391), // VNSRL_WI
2819 UINT64_C(2952790103), // VNSRL_WV
2820 UINT64_C(2952806487), // VNSRL_WX
2821 UINT64_C(671101015), // VOR_VI
2822 UINT64_C(671088727), // VOR_VV
2823 UINT64_C(671105111), // VOR_VX
2824 UINT64_C(1006633047), // VPAIRE_VV
2825 UINT64_C(1006641239), // VPAIRO_VV
2826 UINT64_C(3925868631), // VQMMACC_VV
2827 UINT64_C(3154116727), // VQWBDOTAS_VV
2828 UINT64_C(3087007863), // VQWBDOTAU_VV
2829 UINT64_C(2617245815), // VQWDOTAS_VV
2830 UINT64_C(2550136951), // VQWDOTAU_VV
2831 UINT64_C(67117143), // VREDAND_VS
2832 UINT64_C(402661463), // VREDMAXU_VS
2833 UINT64_C(469770327), // VREDMAX_VS
2834 UINT64_C(268443735), // VREDMINU_VS
2835 UINT64_C(335552599), // VREDMIN_VS
2836 UINT64_C(134226007), // VREDOR_VS
2837 UINT64_C(8279), // VREDSUM_VS
2838 UINT64_C(201334871), // VREDXOR_VS
2839 UINT64_C(2281709655), // VREMU_VV
2840 UINT64_C(2281726039), // VREMU_VX
2841 UINT64_C(2348818519), // VREM_VV
2842 UINT64_C(2348834903), // VREM_VX
2843 UINT64_C(1208262743), // VREV8_V
2844 UINT64_C(939524183), // VRGATHEREI16_VV
2845 UINT64_C(805318743), // VRGATHER_VI
2846 UINT64_C(805306455), // VRGATHER_VV
2847 UINT64_C(805322839), // VRGATHER_VX
2848 UINT64_C(1409286231), // VROL_VV
2849 UINT64_C(1409302615), // VROL_VX
2850 UINT64_C(1342189655), // VROR_VI
2851 UINT64_C(1342177367), // VROR_VV
2852 UINT64_C(1342193751), // VROR_VX
2853 UINT64_C(201338967), // VRSUB_VI
2854 UINT64_C(201343063), // VRSUB_VX
2855 UINT64_C(41943079), // VS1R_V
2856 UINT64_C(578813991), // VS2R_V
2857 UINT64_C(1652555815), // VS4R_V
2858 UINT64_C(3800039463), // VS8R_V
2859 UINT64_C(2147496023), // VSADDU_VI
2860 UINT64_C(2147483735), // VSADDU_VV
2861 UINT64_C(2147500119), // VSADDU_VX
2862 UINT64_C(2214604887), // VSADD_VI
2863 UINT64_C(2214592599), // VSADD_VV
2864 UINT64_C(2214608983), // VSADD_VX
2865 UINT64_C(1207959639), // VSBC_VVM
2866 UINT64_C(1207976023), // VSBC_VXM
2867 UINT64_C(20519), // VSE16_V
2868 UINT64_C(24615), // VSE32_V
2869 UINT64_C(28711), // VSE64_V
2870 UINT64_C(39), // VSE8_V
2871 UINT64_C(3221254231), // VSETIVLI
2872 UINT64_C(2147512407), // VSETVL
2873 UINT64_C(28759), // VSETVLI
2874 UINT64_C(1208197207), // VSEXT_VF2
2875 UINT64_C(1208131671), // VSEXT_VF4
2876 UINT64_C(1208066135), // VSEXT_VF8
2877 UINT64_C(3120570487), // VSHA2CH_VV
2878 UINT64_C(3187679351), // VSHA2CL_VV
2879 UINT64_C(3053461623), // VSHA2MS_VV
2880 UINT64_C(1006657623), // VSLIDE1DOWN_VX
2881 UINT64_C(939548759), // VSLIDE1UP_VX
2882 UINT64_C(1006645335), // VSLIDEDOWN_VI
2883 UINT64_C(1006649431), // VSLIDEDOWN_VX
2884 UINT64_C(939536471), // VSLIDEUP_VI
2885 UINT64_C(939540567), // VSLIDEUP_VX
2886 UINT64_C(2483040343), // VSLL_VI
2887 UINT64_C(2483028055), // VSLL_VV
2888 UINT64_C(2483044439), // VSLL_VX
2889 UINT64_C(2919243895), // VSM3C_VI
2890 UINT64_C(2181046391), // VSM3ME_VV
2891 UINT64_C(2248155255), // VSM4K_VI
2892 UINT64_C(2785550455), // VSM4R_VS
2893 UINT64_C(2718441591), // VSM4R_VV
2894 UINT64_C(2617245783), // VSMUL_VV
2895 UINT64_C(2617262167), // VSMUL_VX
2896 UINT64_C(45088807), // VSM_V
2897 UINT64_C(201347111), // VSOXEI16_V
2898 UINT64_C(201351207), // VSOXEI32_V
2899 UINT64_C(201355303), // VSOXEI64_V
2900 UINT64_C(201326631), // VSOXEI8_V
2901 UINT64_C(738218023), // VSOXSEG2EI16_V
2902 UINT64_C(738222119), // VSOXSEG2EI32_V
2903 UINT64_C(738226215), // VSOXSEG2EI64_V
2904 UINT64_C(738197543), // VSOXSEG2EI8_V
2905 UINT64_C(1275088935), // VSOXSEG3EI16_V
2906 UINT64_C(1275093031), // VSOXSEG3EI32_V
2907 UINT64_C(1275097127), // VSOXSEG3EI64_V
2908 UINT64_C(1275068455), // VSOXSEG3EI8_V
2909 UINT64_C(1811959847), // VSOXSEG4EI16_V
2910 UINT64_C(1811963943), // VSOXSEG4EI32_V
2911 UINT64_C(1811968039), // VSOXSEG4EI64_V
2912 UINT64_C(1811939367), // VSOXSEG4EI8_V
2913 UINT64_C(2348830759), // VSOXSEG5EI16_V
2914 UINT64_C(2348834855), // VSOXSEG5EI32_V
2915 UINT64_C(2348838951), // VSOXSEG5EI64_V
2916 UINT64_C(2348810279), // VSOXSEG5EI8_V
2917 UINT64_C(2885701671), // VSOXSEG6EI16_V
2918 UINT64_C(2885705767), // VSOXSEG6EI32_V
2919 UINT64_C(2885709863), // VSOXSEG6EI64_V
2920 UINT64_C(2885681191), // VSOXSEG6EI8_V
2921 UINT64_C(3422572583), // VSOXSEG7EI16_V
2922 UINT64_C(3422576679), // VSOXSEG7EI32_V
2923 UINT64_C(3422580775), // VSOXSEG7EI64_V
2924 UINT64_C(3422552103), // VSOXSEG7EI8_V
2925 UINT64_C(3959443495), // VSOXSEG8EI16_V
2926 UINT64_C(3959447591), // VSOXSEG8EI32_V
2927 UINT64_C(3959451687), // VSOXSEG8EI64_V
2928 UINT64_C(3959423015), // VSOXSEG8EI8_V
2929 UINT64_C(2751475799), // VSRA_VI
2930 UINT64_C(2751463511), // VSRA_VV
2931 UINT64_C(2751479895), // VSRA_VX
2932 UINT64_C(2684366935), // VSRL_VI
2933 UINT64_C(2684354647), // VSRL_VV
2934 UINT64_C(2684371031), // VSRL_VX
2935 UINT64_C(134238247), // VSSE16_V
2936 UINT64_C(134242343), // VSSE32_V
2937 UINT64_C(134246439), // VSSE64_V
2938 UINT64_C(134217767), // VSSE8_V
2939 UINT64_C(536891431), // VSSEG2E16_V
2940 UINT64_C(536895527), // VSSEG2E32_V
2941 UINT64_C(536899623), // VSSEG2E64_V
2942 UINT64_C(536870951), // VSSEG2E8_V
2943 UINT64_C(1073762343), // VSSEG3E16_V
2944 UINT64_C(1073766439), // VSSEG3E32_V
2945 UINT64_C(1073770535), // VSSEG3E64_V
2946 UINT64_C(1073741863), // VSSEG3E8_V
2947 UINT64_C(1610633255), // VSSEG4E16_V
2948 UINT64_C(1610637351), // VSSEG4E32_V
2949 UINT64_C(1610641447), // VSSEG4E64_V
2950 UINT64_C(1610612775), // VSSEG4E8_V
2951 UINT64_C(2147504167), // VSSEG5E16_V
2952 UINT64_C(2147508263), // VSSEG5E32_V
2953 UINT64_C(2147512359), // VSSEG5E64_V
2954 UINT64_C(2147483687), // VSSEG5E8_V
2955 UINT64_C(2684375079), // VSSEG6E16_V
2956 UINT64_C(2684379175), // VSSEG6E32_V
2957 UINT64_C(2684383271), // VSSEG6E64_V
2958 UINT64_C(2684354599), // VSSEG6E8_V
2959 UINT64_C(3221245991), // VSSEG7E16_V
2960 UINT64_C(3221250087), // VSSEG7E32_V
2961 UINT64_C(3221254183), // VSSEG7E64_V
2962 UINT64_C(3221225511), // VSSEG7E8_V
2963 UINT64_C(3758116903), // VSSEG8E16_V
2964 UINT64_C(3758120999), // VSSEG8E32_V
2965 UINT64_C(3758125095), // VSSEG8E64_V
2966 UINT64_C(3758096423), // VSSEG8E8_V
2967 UINT64_C(2885693527), // VSSRA_VI
2968 UINT64_C(2885681239), // VSSRA_VV
2969 UINT64_C(2885697623), // VSSRA_VX
2970 UINT64_C(2818584663), // VSSRL_VI
2971 UINT64_C(2818572375), // VSSRL_VV
2972 UINT64_C(2818588759), // VSSRL_VX
2973 UINT64_C(671109159), // VSSSEG2E16_V
2974 UINT64_C(671113255), // VSSSEG2E32_V
2975 UINT64_C(671117351), // VSSSEG2E64_V
2976 UINT64_C(671088679), // VSSSEG2E8_V
2977 UINT64_C(1207980071), // VSSSEG3E16_V
2978 UINT64_C(1207984167), // VSSSEG3E32_V
2979 UINT64_C(1207988263), // VSSSEG3E64_V
2980 UINT64_C(1207959591), // VSSSEG3E8_V
2981 UINT64_C(1744850983), // VSSSEG4E16_V
2982 UINT64_C(1744855079), // VSSSEG4E32_V
2983 UINT64_C(1744859175), // VSSSEG4E64_V
2984 UINT64_C(1744830503), // VSSSEG4E8_V
2985 UINT64_C(2281721895), // VSSSEG5E16_V
2986 UINT64_C(2281725991), // VSSSEG5E32_V
2987 UINT64_C(2281730087), // VSSSEG5E64_V
2988 UINT64_C(2281701415), // VSSSEG5E8_V
2989 UINT64_C(2818592807), // VSSSEG6E16_V
2990 UINT64_C(2818596903), // VSSSEG6E32_V
2991 UINT64_C(2818600999), // VSSSEG6E64_V
2992 UINT64_C(2818572327), // VSSSEG6E8_V
2993 UINT64_C(3355463719), // VSSSEG7E16_V
2994 UINT64_C(3355467815), // VSSSEG7E32_V
2995 UINT64_C(3355471911), // VSSSEG7E64_V
2996 UINT64_C(3355443239), // VSSSEG7E8_V
2997 UINT64_C(3892334631), // VSSSEG8E16_V
2998 UINT64_C(3892338727), // VSSSEG8E32_V
2999 UINT64_C(3892342823), // VSSSEG8E64_V
3000 UINT64_C(3892314151), // VSSSEG8E8_V
3001 UINT64_C(2281701463), // VSSUBU_VV
3002 UINT64_C(2281717847), // VSSUBU_VX
3003 UINT64_C(2348810327), // VSSUB_VV
3004 UINT64_C(2348826711), // VSSUB_VX
3005 UINT64_C(134217815), // VSUB_VV
3006 UINT64_C(134234199), // VSUB_VX
3007 UINT64_C(67129383), // VSUXEI16_V
3008 UINT64_C(67133479), // VSUXEI32_V
3009 UINT64_C(67137575), // VSUXEI64_V
3010 UINT64_C(67108903), // VSUXEI8_V
3011 UINT64_C(604000295), // VSUXSEG2EI16_V
3012 UINT64_C(604004391), // VSUXSEG2EI32_V
3013 UINT64_C(604008487), // VSUXSEG2EI64_V
3014 UINT64_C(603979815), // VSUXSEG2EI8_V
3015 UINT64_C(1140871207), // VSUXSEG3EI16_V
3016 UINT64_C(1140875303), // VSUXSEG3EI32_V
3017 UINT64_C(1140879399), // VSUXSEG3EI64_V
3018 UINT64_C(1140850727), // VSUXSEG3EI8_V
3019 UINT64_C(1677742119), // VSUXSEG4EI16_V
3020 UINT64_C(1677746215), // VSUXSEG4EI32_V
3021 UINT64_C(1677750311), // VSUXSEG4EI64_V
3022 UINT64_C(1677721639), // VSUXSEG4EI8_V
3023 UINT64_C(2214613031), // VSUXSEG5EI16_V
3024 UINT64_C(2214617127), // VSUXSEG5EI32_V
3025 UINT64_C(2214621223), // VSUXSEG5EI64_V
3026 UINT64_C(2214592551), // VSUXSEG5EI8_V
3027 UINT64_C(2751483943), // VSUXSEG6EI16_V
3028 UINT64_C(2751488039), // VSUXSEG6EI32_V
3029 UINT64_C(2751492135), // VSUXSEG6EI64_V
3030 UINT64_C(2751463463), // VSUXSEG6EI8_V
3031 UINT64_C(3288354855), // VSUXSEG7EI16_V
3032 UINT64_C(3288358951), // VSUXSEG7EI32_V
3033 UINT64_C(3288363047), // VSUXSEG7EI64_V
3034 UINT64_C(3288334375), // VSUXSEG7EI8_V
3035 UINT64_C(3825225767), // VSUXSEG8EI16_V
3036 UINT64_C(3825229863), // VSUXSEG8EI32_V
3037 UINT64_C(3825233959), // VSUXSEG8EI64_V
3038 UINT64_C(3825205287), // VSUXSEG8EI8_V
3039 UINT64_C(24699), // VT_MASKC
3040 UINT64_C(28795), // VT_MASKCN
3041 UINT64_C(1208328279), // VUNZIPE_V
3042 UINT64_C(1208459351), // VUNZIPO_V
3043 UINT64_C(1476403287), // VWABDAU_VV
3044 UINT64_C(1409294423), // VWABDA_VV
3045 UINT64_C(3221233751), // VWADDU_VV
3046 UINT64_C(3221250135), // VWADDU_VX
3047 UINT64_C(3489669207), // VWADDU_WV
3048 UINT64_C(3489685591), // VWADDU_WX
3049 UINT64_C(3288342615), // VWADD_VV
3050 UINT64_C(3288358999), // VWADD_VX
3051 UINT64_C(3556778071), // VWADD_WV
3052 UINT64_C(3556794455), // VWADD_WX
3053 UINT64_C(4227866711), // VWMACCSU_VV
3054 UINT64_C(4227883095), // VWMACCSU_VX
3055 UINT64_C(4160774231), // VWMACCUS_VX
3056 UINT64_C(4026540119), // VWMACCU_VV
3057 UINT64_C(4026556503), // VWMACCU_VX
3058 UINT64_C(4093648983), // VWMACC_VV
3059 UINT64_C(4093665367), // VWMACC_VX
3060 UINT64_C(3858759767), // VWMMACC_VV
3061 UINT64_C(3892322391), // VWMULSU_VV
3062 UINT64_C(3892338775), // VWMULSU_VX
3063 UINT64_C(3758104663), // VWMULU_VV
3064 UINT64_C(3758121047), // VWMULU_VX
3065 UINT64_C(3959431255), // VWMUL_VV
3066 UINT64_C(3959447639), // VWMUL_VX
3067 UINT64_C(3221225559), // VWREDSUMU_VS
3068 UINT64_C(3288334423), // VWREDSUM_VS
3069 UINT64_C(3556782167), // VWSLL_VI
3070 UINT64_C(3556769879), // VWSLL_VV
3071 UINT64_C(3556786263), // VWSLL_VX
3072 UINT64_C(3355451479), // VWSUBU_VV
3073 UINT64_C(3355467863), // VWSUBU_VX
3074 UINT64_C(3623886935), // VWSUBU_WV
3075 UINT64_C(3623903319), // VWSUBU_WX
3076 UINT64_C(3422560343), // VWSUB_VV
3077 UINT64_C(3422576727), // VWSUB_VX
3078 UINT64_C(3690995799), // VWSUB_WV
3079 UINT64_C(3691012183), // VWSUB_WX
3080 UINT64_C(738209879), // VXOR_VI
3081 UINT64_C(738197591), // VXOR_VV
3082 UINT64_C(738213975), // VXOR_VX
3083 UINT64_C(1208164439), // VZEXT_VF2
3084 UINT64_C(1208098903), // VZEXT_VF4
3085 UINT64_C(1208033367), // VZEXT_VF8
3086 UINT64_C(4160757847), // VZIP_VV
3087 UINT64_C(33562779), // WADD
3088 UINT64_C(167780507), // WADDA
3089 UINT64_C(436215963), // WADDAU
3090 UINT64_C(301998235), // WADDU
3091 UINT64_C(273678451), // WFI
3092 UINT64_C(704651419), // WMACC
3093 UINT64_C(1778393243), // WMACCSU
3094 UINT64_C(973086875), // WMACCU
3095 UINT64_C(570433691), // WMUL
3096 UINT64_C(1644175515), // WMULSU
3097 UINT64_C(838869147), // WMULU
3098 UINT64_C(13631603), // WRS_NTO
3099 UINT64_C(30408819), // WRS_STO
3100 UINT64_C(1308631067), // WSLA
3101 UINT64_C(1140858907), // WSLAI
3102 UINT64_C(234889243), // WSLL
3103 UINT64_C(67117083), // WSLLI
3104 UINT64_C(1107304603), // WSUB
3105 UINT64_C(1241522331), // WSUBA
3106 UINT64_C(1509957787), // WSUBAU
3107 UINT64_C(1375740059), // WSUBU
3108 UINT64_C(2046828571), // WZIP16P
3109 UINT64_C(2013274139), // WZIP8P
3110 UINT64_C(1073758259), // XNOR
3111 UINT64_C(16435), // XOR
3112 UINT64_C(16403), // XORI
3113 UINT64_C(671096883), // XPERM4
3114 UINT64_C(671105075), // XPERM8
3115 UINT64_C(100663419), // YADD
3116 UINT64_C(16507), // YADDI
3117 UINT64_C(369098875), // YADDRW
3118 UINT64_C(4026531963), // YAMASK
3119 UINT64_C(4093640827), // YBASER
3120 UINT64_C(503316603), // YBLD
3121 UINT64_C(1174405243), // YBNDSRW
3122 UINT64_C(905969787), // YBNDSW
3123 UINT64_C(3758116987), // YBNDSWI
3124 UINT64_C(201326715), // YEQ
3125 UINT64_C(4096786555), // YLENR
3126 UINT64_C(100663419), // YMV
3127 UINT64_C(637534331), // YPERMC
3128 UINT64_C(4094689403), // YPERMR
3129 UINT64_C(469762171), // YSS
3130 UINT64_C(234881147), // YSUNSEAL
3131 UINT64_C(4097835131), // YTAGR
3132 UINT64_C(4095737979), // YTOPR
3133 UINT64_C(4098883707), // YTYPER
3134 UINT64_C(134234163), // ZEXT_H_RV32
3135 UINT64_C(134234171), // ZEXT_H_RV64
3136 UINT64_C(4127203387), // ZIP16HP
3137 UINT64_C(4060094523), // ZIP16P
3138 UINT64_C(4093648955), // ZIP8HP
3139 UINT64_C(4026540091), // ZIP8P
3140 UINT64_C(149950483), // ZIP_RV32
3141 };
3142 constexpr unsigned FirstSupportedOpcode = 13723;
3143
3144 const unsigned opcode = MI.getOpcode();
3145 if (opcode < FirstSupportedOpcode)
3146 reportUnsupportedInst(Inst: MI);
3147 unsigned TableIndex = opcode - FirstSupportedOpcode;
3148 uint64_t Value = InstBits[TableIndex];
3149 uint64_t op = 0;
3150 (void)op; // suppress warning
3151 switch (opcode) {
3152 case RISCV::C_EBREAK:
3153 case RISCV::C_MOP_11:
3154 case RISCV::C_MOP_13:
3155 case RISCV::C_MOP_15:
3156 case RISCV::C_MOP_3:
3157 case RISCV::C_MOP_7:
3158 case RISCV::C_MOP_9:
3159 case RISCV::C_NOP:
3160 case RISCV::C_SSPOPCHK:
3161 case RISCV::C_SSPUSH:
3162 case RISCV::C_UNIMP:
3163 case RISCV::DRET:
3164 case RISCV::EBREAK:
3165 case RISCV::ECALL:
3166 case RISCV::FENCE_I:
3167 case RISCV::FENCE_TSO:
3168 case RISCV::MIPS_EHB:
3169 case RISCV::MIPS_IHB:
3170 case RISCV::MIPS_PAUSE:
3171 case RISCV::MNRET:
3172 case RISCV::MRET:
3173 case RISCV::QC_C_DI:
3174 case RISCV::QC_C_EI:
3175 case RISCV::QC_C_MIENTER:
3176 case RISCV::QC_C_MIENTER_NEST:
3177 case RISCV::QC_C_MILEAVERET:
3178 case RISCV::QC_C_MNRET:
3179 case RISCV::QC_C_MRET:
3180 case RISCV::SCTRCLR:
3181 case RISCV::SFENCE_INVAL_IR:
3182 case RISCV::SFENCE_W_INVAL:
3183 case RISCV::SF_CEASE:
3184 case RISCV::SF_VTDISCARD:
3185 case RISCV::SRET:
3186 case RISCV::TH_DCACHE_CALL:
3187 case RISCV::TH_DCACHE_CIALL:
3188 case RISCV::TH_DCACHE_IALL:
3189 case RISCV::TH_ICACHE_IALL:
3190 case RISCV::TH_ICACHE_IALLS:
3191 case RISCV::TH_L2CACHE_CALL:
3192 case RISCV::TH_L2CACHE_CIALL:
3193 case RISCV::TH_L2CACHE_IALL:
3194 case RISCV::TH_SYNC:
3195 case RISCV::TH_SYNC_I:
3196 case RISCV::TH_SYNC_IS:
3197 case RISCV::TH_SYNC_S:
3198 case RISCV::UNIMP:
3199 case RISCV::WFI:
3200 case RISCV::WRS_NTO:
3201 case RISCV::WRS_STO: {
3202 break;
3203 }
3204 case RISCV::AIF_FSWG_PS:
3205 case RISCV::AIF_FSWL_PS: {
3206 // op: fs3
3207 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3208 Value |= (op & 0x1f) << 7;
3209 // op: rs1
3210 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3211 Value |= (op & 0x1f) << 15;
3212 break;
3213 }
3214 case RISCV::C_NOP_HINT: {
3215 // op: imm
3216 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3217 Value |= (op & 0x20) << 7;
3218 Value |= (op & 0x1f) << 2;
3219 break;
3220 }
3221 case RISCV::C_LI:
3222 case RISCV::C_LUI: {
3223 // op: imm
3224 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3225 Value |= (op & 0x20) << 7;
3226 Value |= (op & 0x1f) << 2;
3227 // op: rd
3228 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3229 Value |= (op & 0x1f) << 7;
3230 break;
3231 }
3232 case RISCV::AIF_FSLLI_PI:
3233 case RISCV::AIF_FSRAI_PI:
3234 case RISCV::AIF_FSRLI_PI: {
3235 // op: imm
3236 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3237 Value |= (op & 0x1f) << 20;
3238 // op: rs1
3239 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3240 Value |= (op & 0x1f) << 15;
3241 // op: rd
3242 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3243 Value |= (op & 0x1f) << 7;
3244 break;
3245 }
3246 case RISCV::C_FLDSP:
3247 case RISCV::C_LDSP:
3248 case RISCV::C_LDSP_RV32: {
3249 // op: imm
3250 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3251 Value |= (op & 0x20) << 7;
3252 Value |= (op & 0x18) << 2;
3253 Value |= (op & 0x1c0) >> 4;
3254 // op: rd
3255 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3256 Value |= (op & 0x1f) << 7;
3257 break;
3258 }
3259 case RISCV::C_FLWSP:
3260 case RISCV::C_LWSP:
3261 case RISCV::C_LWSP_INX: {
3262 // op: imm
3263 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3264 Value |= (op & 0x20) << 7;
3265 Value |= (op & 0x1c) << 2;
3266 Value |= (op & 0xc0) >> 4;
3267 // op: rd
3268 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3269 Value |= (op & 0x1f) << 7;
3270 break;
3271 }
3272 case RISCV::C_ADDI:
3273 case RISCV::C_ADDIW: {
3274 // op: imm
3275 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3276 Value |= (op & 0x20) << 7;
3277 Value |= (op & 0x1f) << 2;
3278 // op: rd
3279 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3280 Value |= (op & 0x1f) << 7;
3281 break;
3282 }
3283 case RISCV::C_ANDI: {
3284 // op: imm
3285 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3286 Value |= (op & 0x20) << 7;
3287 Value |= (op & 0x1f) << 2;
3288 // op: rs1
3289 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3290 Value |= (op & 0x7) << 7;
3291 break;
3292 }
3293 case RISCV::C_ADDI16SP: {
3294 // op: imm
3295 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3296 Value |= (op & 0x200) << 3;
3297 Value |= (op & 0x10) << 2;
3298 Value |= (op & 0x40) >> 1;
3299 Value |= (op & 0x180) >> 4;
3300 Value |= (op & 0x20) >> 3;
3301 break;
3302 }
3303 case RISCV::C_ADDI4SPN: {
3304 // op: imm
3305 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3306 Value |= (op & 0x30) << 7;
3307 Value |= (op & 0x3c0) << 1;
3308 Value |= (op & 0x4) << 4;
3309 Value |= (op & 0x8) << 2;
3310 // op: rd
3311 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3312 Value |= (op & 0x7) << 2;
3313 break;
3314 }
3315 case RISCV::C_FSDSP:
3316 case RISCV::C_SDSP:
3317 case RISCV::C_SDSP_RV32: {
3318 // op: imm
3319 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3320 Value |= (op & 0x38) << 7;
3321 Value |= (op & 0x1c0) << 1;
3322 // op: rs2
3323 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3324 Value |= (op & 0x1f) << 2;
3325 break;
3326 }
3327 case RISCV::C_FSWSP:
3328 case RISCV::C_SWSP:
3329 case RISCV::C_SWSP_INX: {
3330 // op: imm
3331 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3332 Value |= (op & 0x3c) << 7;
3333 Value |= (op & 0xc0) << 1;
3334 // op: rs2
3335 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3336 Value |= (op & 0x1f) << 2;
3337 break;
3338 }
3339 case RISCV::AIF_FADDI_PI:
3340 case RISCV::AIF_FANDI_PI: {
3341 // op: imm
3342 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3343 Value |= (op & 0x3e0) << 22;
3344 Value |= (op & 0x1f) << 20;
3345 // op: rs1
3346 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3347 Value |= (op & 0x1f) << 15;
3348 // op: rd
3349 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3350 Value |= (op & 0x1f) << 7;
3351 break;
3352 }
3353 case RISCV::AIF_MOV_M_X: {
3354 // op: imm
3355 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3356 Value |= (op & 0xf8) << 17;
3357 Value |= (op & 0x7) << 12;
3358 // op: rs1
3359 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3360 Value |= (op & 0x1f) << 15;
3361 // op: rd
3362 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3363 Value |= (op & 0x7) << 7;
3364 break;
3365 }
3366 case RISCV::AIF_MASKPOPC_ET_RAST: {
3367 // op: imm
3368 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3369 Value |= (op & 0xc) << 21;
3370 Value |= (op & 0x3) << 18;
3371 // op: rs2
3372 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3373 Value |= (op & 0x7) << 20;
3374 // op: rs1
3375 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3376 Value |= (op & 0x7) << 15;
3377 // op: rd
3378 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3379 Value |= (op & 0x1f) << 7;
3380 break;
3381 }
3382 case RISCV::C_BEQZ:
3383 case RISCV::C_BNEZ: {
3384 // op: imm
3385 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3386 Value |= (op & 0x80) << 5;
3387 Value |= (op & 0xc) << 8;
3388 Value |= (op & 0x60);
3389 Value |= (op & 0x3) << 3;
3390 Value |= (op & 0x10) >> 2;
3391 // op: rs1
3392 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3393 Value |= (op & 0x7) << 7;
3394 break;
3395 }
3396 case RISCV::C_SLLI: {
3397 // op: imm
3398 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3399 Value |= (op & 0x20) << 7;
3400 Value |= (op & 0x1f) << 2;
3401 // op: rd
3402 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3403 Value |= (op & 0x1f) << 7;
3404 break;
3405 }
3406 case RISCV::C_SRAI:
3407 case RISCV::C_SRLI: {
3408 // op: imm
3409 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3410 Value |= (op & 0x20) << 7;
3411 Value |= (op & 0x1f) << 2;
3412 // op: rs1
3413 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3414 Value |= (op & 0x7) << 7;
3415 break;
3416 }
3417 case RISCV::QC_CLRINTI:
3418 case RISCV::QC_SETINTI: {
3419 // op: imm10
3420 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3421 Value |= (op & 0x3ff) << 15;
3422 break;
3423 }
3424 case RISCV::NDS_BEQC:
3425 case RISCV::NDS_BNEC: {
3426 // op: imm10
3427 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3428 Value |= (op & 0x200) << 22;
3429 Value |= (op & 0x1f0) << 21;
3430 Value |= (op & 0xf) << 8;
3431 // op: rs1
3432 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3433 Value |= (op & 0x1f) << 15;
3434 // op: cimm
3435 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3436 Value |= (op & 0x40) << 24;
3437 Value |= (op & 0x1f) << 20;
3438 Value |= (op & 0x20) << 2;
3439 break;
3440 }
3441 case RISCV::NDS_BBC:
3442 case RISCV::NDS_BBS: {
3443 // op: imm10
3444 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3445 Value |= (op & 0x200) << 22;
3446 Value |= (op & 0x1f0) << 21;
3447 Value |= (op & 0xf) << 8;
3448 // op: rs1
3449 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3450 Value |= (op & 0x1f) << 15;
3451 // op: cimm
3452 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3453 Value |= (op & 0x1f) << 20;
3454 Value |= (op & 0x20) << 2;
3455 break;
3456 }
3457 case RISCV::PREFETCH_I:
3458 case RISCV::PREFETCH_R:
3459 case RISCV::PREFETCH_W: {
3460 // op: imm12
3461 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3462 Value |= (op & 0xfe0) << 20;
3463 // op: rs1
3464 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3465 Value |= (op & 0x1f) << 15;
3466 break;
3467 }
3468 case RISCV::AIF_FSQ2:
3469 case RISCV::AIF_FSW_PS: {
3470 // op: imm12
3471 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3472 Value |= (op & 0xfe0) << 20;
3473 Value |= (op & 0x1f) << 7;
3474 // op: rs2
3475 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3476 Value |= (op & 0x1f) << 20;
3477 // op: rs1
3478 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3479 Value |= (op & 0x1f) << 15;
3480 break;
3481 }
3482 case RISCV::FSD:
3483 case RISCV::FSH:
3484 case RISCV::FSQ:
3485 case RISCV::FSW:
3486 case RISCV::SB:
3487 case RISCV::SD:
3488 case RISCV::SD_RV32:
3489 case RISCV::SH:
3490 case RISCV::SH_INX:
3491 case RISCV::SW:
3492 case RISCV::SW_INX: {
3493 // op: imm12
3494 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3495 Value |= (op & 0xfe0) << 20;
3496 Value |= (op & 0x1f) << 7;
3497 // op: rs2
3498 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3499 Value |= (op & 0x1f) << 20;
3500 // op: rs1
3501 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3502 Value |= (op & 0x1f) << 15;
3503 break;
3504 }
3505 case RISCV::CV_SB_ri_inc:
3506 case RISCV::CV_SH_ri_inc:
3507 case RISCV::CV_SW_ri_inc: {
3508 // op: imm12
3509 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3510 Value |= (op & 0xfe0) << 20;
3511 Value |= (op & 0x1f) << 7;
3512 // op: rs2
3513 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3514 Value |= (op & 0x1f) << 20;
3515 // op: rs1
3516 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3517 Value |= (op & 0x1f) << 15;
3518 break;
3519 }
3520 case RISCV::BEQI:
3521 case RISCV::BNEI: {
3522 // op: imm12
3523 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3524 Value |= (op & 0x800) << 20;
3525 Value |= (op & 0x3f0) << 21;
3526 Value |= (op & 0xf) << 8;
3527 Value |= (op & 0x400) >> 3;
3528 // op: cimm
3529 op = getImmOpValueZibi(MI, OpNo: 1, Fixups, STI);
3530 Value |= (op & 0x1f) << 20;
3531 // op: rs1
3532 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3533 Value |= (op & 0x1f) << 15;
3534 break;
3535 }
3536 case RISCV::CV_BEQIMM:
3537 case RISCV::CV_BNEIMM: {
3538 // op: imm12
3539 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3540 Value |= (op & 0x800) << 20;
3541 Value |= (op & 0x3f0) << 21;
3542 Value |= (op & 0xf) << 8;
3543 Value |= (op & 0x400) >> 3;
3544 // op: rs1
3545 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3546 Value |= (op & 0x1f) << 15;
3547 // op: imm5
3548 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3549 Value |= (op & 0x1f) << 20;
3550 break;
3551 }
3552 case RISCV::BEQ:
3553 case RISCV::BGE:
3554 case RISCV::BGEU:
3555 case RISCV::BLT:
3556 case RISCV::BLTU:
3557 case RISCV::BNE:
3558 case RISCV::QC_BEQI:
3559 case RISCV::QC_BGEI:
3560 case RISCV::QC_BGEUI:
3561 case RISCV::QC_BLTI:
3562 case RISCV::QC_BLTUI:
3563 case RISCV::QC_BNEI: {
3564 // op: imm12
3565 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3566 Value |= (op & 0x800) << 20;
3567 Value |= (op & 0x3f0) << 21;
3568 Value |= (op & 0xf) << 8;
3569 Value |= (op & 0x400) >> 3;
3570 // op: rs2
3571 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3572 Value |= (op & 0x1f) << 20;
3573 // op: rs1
3574 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3575 Value |= (op & 0x1f) << 15;
3576 break;
3577 }
3578 case RISCV::NDS_SHGP: {
3579 // op: imm17
3580 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3581 Value |= (op & 0x10000) << 15;
3582 Value |= (op & 0x3f0) << 21;
3583 Value |= (op & 0x3800) << 6;
3584 Value |= (op & 0xc000) << 1;
3585 Value |= (op & 0xf) << 8;
3586 Value |= (op & 0x400) >> 3;
3587 // op: rs2
3588 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3589 Value |= (op & 0x1f) << 20;
3590 break;
3591 }
3592 case RISCV::NDS_LHGP:
3593 case RISCV::NDS_LHUGP: {
3594 // op: imm17
3595 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3596 Value |= (op & 0x10000) << 15;
3597 Value |= (op & 0x3ff) << 21;
3598 Value |= (op & 0x400) << 10;
3599 Value |= (op & 0x3800) << 6;
3600 Value |= (op & 0xc000) << 1;
3601 // op: rd
3602 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3603 Value |= (op & 0x1f) << 7;
3604 break;
3605 }
3606 case RISCV::NDS_SWGP: {
3607 // op: imm17
3608 op = getImmOpValueAsrN<2>(MI, OpNo: 1, Fixups, STI);
3609 Value |= (op & 0x10000) << 15;
3610 Value |= (op & 0x1f8) << 22;
3611 Value |= (op & 0x1c00) << 7;
3612 Value |= (op & 0x6000) << 2;
3613 Value |= (op & 0x7) << 9;
3614 Value |= (op & 0x8000) >> 7;
3615 Value |= (op & 0x200) >> 2;
3616 // op: rs2
3617 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3618 Value |= (op & 0x1f) << 20;
3619 break;
3620 }
3621 case RISCV::NDS_LWGP:
3622 case RISCV::NDS_LWUGP: {
3623 // op: imm17
3624 op = getImmOpValueAsrN<2>(MI, OpNo: 1, Fixups, STI);
3625 Value |= (op & 0x10000) << 15;
3626 Value |= (op & 0x1ff) << 22;
3627 Value |= (op & 0x8000) << 6;
3628 Value |= (op & 0x200) << 11;
3629 Value |= (op & 0x1c00) << 7;
3630 Value |= (op & 0x6000) << 2;
3631 // op: rd
3632 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3633 Value |= (op & 0x1f) << 7;
3634 break;
3635 }
3636 case RISCV::NDS_SDGP: {
3637 // op: imm17
3638 op = getImmOpValueAsrN<3>(MI, OpNo: 1, Fixups, STI);
3639 Value |= (op & 0x10000) << 15;
3640 Value |= (op & 0xfc) << 23;
3641 Value |= (op & 0xe00) << 8;
3642 Value |= (op & 0x3000) << 3;
3643 Value |= (op & 0x3) << 10;
3644 Value |= (op & 0xc000) >> 6;
3645 Value |= (op & 0x100) >> 1;
3646 // op: rs2
3647 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3648 Value |= (op & 0x1f) << 20;
3649 break;
3650 }
3651 case RISCV::NDS_LDGP: {
3652 // op: imm17
3653 op = getImmOpValueAsrN<3>(MI, OpNo: 1, Fixups, STI);
3654 Value |= (op & 0x10000) << 15;
3655 Value |= (op & 0xff) << 23;
3656 Value |= (op & 0xc000) << 7;
3657 Value |= (op & 0x100) << 12;
3658 Value |= (op & 0xe00) << 8;
3659 Value |= (op & 0x3000) << 3;
3660 // op: rd
3661 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3662 Value |= (op & 0x1f) << 7;
3663 break;
3664 }
3665 case RISCV::NDS_SBGP: {
3666 // op: imm18
3667 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3668 Value |= (op & 0x20000) << 14;
3669 Value |= (op & 0x7e0) << 20;
3670 Value |= (op & 0x7000) << 5;
3671 Value |= (op & 0x18000);
3672 Value |= (op & 0x1) << 14;
3673 Value |= (op & 0x1e) << 7;
3674 Value |= (op & 0x800) >> 4;
3675 // op: rs2
3676 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3677 Value |= (op & 0x1f) << 20;
3678 break;
3679 }
3680 case RISCV::NDS_ADDIGP:
3681 case RISCV::NDS_LBGP:
3682 case RISCV::NDS_LBUGP: {
3683 // op: imm18
3684 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3685 Value |= (op & 0x20000) << 14;
3686 Value |= (op & 0x7fe) << 20;
3687 Value |= (op & 0x800) << 9;
3688 Value |= (op & 0x7000) << 5;
3689 Value |= (op & 0x18000);
3690 Value |= (op & 0x1) << 14;
3691 // op: rd
3692 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3693 Value |= (op & 0x1f) << 7;
3694 break;
3695 }
3696 case RISCV::QC_LI: {
3697 // op: imm20
3698 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3699 Value |= (op & 0x80000) << 12;
3700 Value |= (op & 0x7fff) << 16;
3701 Value |= (op & 0x78000) >> 3;
3702 // op: rd
3703 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3704 Value |= (op & 0x1f) << 7;
3705 break;
3706 }
3707 case RISCV::AIF_FBCI_PI:
3708 case RISCV::AIF_FBCI_PS:
3709 case RISCV::AUIPC:
3710 case RISCV::LUI: {
3711 // op: imm20
3712 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3713 Value |= (op & 0xfffff) << 12;
3714 // op: rd
3715 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3716 Value |= (op & 0x1f) << 7;
3717 break;
3718 }
3719 case RISCV::JAL: {
3720 // op: imm20
3721 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3722 Value |= (op & 0x80000) << 12;
3723 Value |= (op & 0x3ff) << 21;
3724 Value |= (op & 0x400) << 10;
3725 Value |= (op & 0x7f800) << 1;
3726 // op: rd
3727 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3728 Value |= (op & 0x1f) << 7;
3729 break;
3730 }
3731 case RISCV::QC_E_J:
3732 case RISCV::QC_E_JAL: {
3733 // op: imm31
3734 op = getImmOpValueAsrN<1>(MI, OpNo: 0, Fixups, STI);
3735 Value |= (op & 0x7fff8000) << 17;
3736 Value |= (op & 0x800) << 20;
3737 Value |= (op & 0x3f0) << 21;
3738 Value |= (op & 0x7000) << 5;
3739 Value |= (op & 0xf) << 8;
3740 Value |= (op & 0x400) >> 3;
3741 break;
3742 }
3743 case RISCV::QC_SYNC:
3744 case RISCV::QC_SYNCR:
3745 case RISCV::QC_SYNCWF:
3746 case RISCV::QC_SYNCWL: {
3747 // op: imm5
3748 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3749 Value |= (op & 0x1f) << 20;
3750 break;
3751 }
3752 case RISCV::MIPS_SDP: {
3753 // op: imm7
3754 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3755 Value |= (op & 0x60) << 20;
3756 Value |= (op & 0x18) << 7;
3757 // op: rs3
3758 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3759 Value |= (op & 0x1f) << 27;
3760 // op: rs2
3761 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3762 Value |= (op & 0x1f) << 20;
3763 // op: rs1
3764 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3765 Value |= (op & 0x1f) << 15;
3766 break;
3767 }
3768 case RISCV::MIPS_SWP: {
3769 // op: imm7
3770 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3771 Value |= (op & 0x60) << 20;
3772 Value |= (op & 0x1c) << 7;
3773 // op: rs3
3774 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3775 Value |= (op & 0x1f) << 27;
3776 // op: rs2
3777 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3778 Value |= (op & 0x1f) << 20;
3779 // op: rs1
3780 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3781 Value |= (op & 0x1f) << 15;
3782 break;
3783 }
3784 case RISCV::MIPS_LDP: {
3785 // op: imm7
3786 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3787 Value |= (op & 0x78) << 20;
3788 // op: rs1
3789 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3790 Value |= (op & 0x1f) << 15;
3791 // op: rd1
3792 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3793 Value |= (op & 0x1f) << 7;
3794 // op: rd2
3795 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3796 Value |= (op & 0x1f) << 27;
3797 break;
3798 }
3799 case RISCV::MIPS_LWP: {
3800 // op: imm7
3801 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3802 Value |= (op & 0x7c) << 20;
3803 // op: rs1
3804 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3805 Value |= (op & 0x1f) << 15;
3806 // op: rd1
3807 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3808 Value |= (op & 0x1f) << 7;
3809 // op: rd2
3810 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3811 Value |= (op & 0x1f) << 27;
3812 break;
3813 }
3814 case RISCV::QC_PPUTCI: {
3815 // op: imm8
3816 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3817 Value |= (op & 0xff) << 20;
3818 break;
3819 }
3820 case RISCV::MIPS_PREF: {
3821 // op: imm9
3822 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3823 Value |= (op & 0x1ff) << 20;
3824 // op: rs1
3825 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3826 Value |= (op & 0x1f) << 15;
3827 // op: hint
3828 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3829 Value |= (op & 0x1f) << 7;
3830 break;
3831 }
3832 case RISCV::CM_JT:
3833 case RISCV::QC_CM_JT: {
3834 // op: index
3835 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3836 Value |= (op & 0x1f) << 2;
3837 break;
3838 }
3839 case RISCV::CM_JALT:
3840 case RISCV::QC_CM_JALT: {
3841 // op: index
3842 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3843 Value |= (op & 0xff) << 2;
3844 break;
3845 }
3846 case RISCV::C_J:
3847 case RISCV::C_JAL: {
3848 // op: offset
3849 op = getImmOpValueAsrN<1>(MI, OpNo: 0, Fixups, STI);
3850 Value |= (op & 0x400) << 2;
3851 Value |= (op & 0x8) << 8;
3852 Value |= (op & 0x180) << 2;
3853 Value |= (op & 0x200) >> 1;
3854 Value |= (op & 0x20) << 2;
3855 Value |= (op & 0x40);
3856 Value |= (op & 0x7) << 3;
3857 Value |= (op & 0x10) >> 2;
3858 break;
3859 }
3860 case RISCV::InsnCJ: {
3861 // op: opcode
3862 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3863 Value |= (op & 0x3);
3864 // op: funct3
3865 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3866 Value |= (op & 0x7) << 13;
3867 // op: imm11
3868 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3869 Value |= (op & 0x400) << 2;
3870 Value |= (op & 0x8) << 8;
3871 Value |= (op & 0x180) << 2;
3872 Value |= (op & 0x200) >> 1;
3873 Value |= (op & 0x20) << 2;
3874 Value |= (op & 0x40);
3875 Value |= (op & 0x7) << 3;
3876 Value |= (op & 0x10) >> 2;
3877 break;
3878 }
3879 case RISCV::InsnCS: {
3880 // op: opcode
3881 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3882 Value |= (op & 0x3);
3883 // op: funct3
3884 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3885 Value |= (op & 0x7) << 13;
3886 // op: imm5
3887 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3888 Value |= (op & 0x1c) << 8;
3889 Value |= (op & 0x3) << 5;
3890 // op: rs2
3891 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3892 Value |= (op & 0x7) << 2;
3893 // op: rs1
3894 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3895 Value |= (op & 0x7) << 7;
3896 break;
3897 }
3898 case RISCV::InsnCSS: {
3899 // op: opcode
3900 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3901 Value |= (op & 0x3);
3902 // op: funct3
3903 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3904 Value |= (op & 0x7) << 13;
3905 // op: imm6
3906 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3907 Value |= (op & 0x3f) << 7;
3908 // op: rs2
3909 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3910 Value |= (op & 0x1f) << 2;
3911 break;
3912 }
3913 case RISCV::InsnCB: {
3914 // op: opcode
3915 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3916 Value |= (op & 0x3);
3917 // op: funct3
3918 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3919 Value |= (op & 0x7) << 13;
3920 // op: imm8
3921 op = getImmOpValueAsrN<1>(MI, OpNo: 3, Fixups, STI);
3922 Value |= (op & 0x80) << 5;
3923 Value |= (op & 0xc) << 8;
3924 Value |= (op & 0x60);
3925 Value |= (op & 0x3) << 3;
3926 Value |= (op & 0x10) >> 2;
3927 // op: rs1
3928 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3929 Value |= (op & 0x7) << 7;
3930 break;
3931 }
3932 case RISCV::InsnQC_EJ: {
3933 // op: opcode
3934 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3935 Value |= (op & 0x7f);
3936 // op: func3
3937 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3938 Value |= (op & 0x7) << 12;
3939 // op: func2
3940 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3941 Value |= (op & 0x3) << 15;
3942 // op: func5
3943 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3944 Value |= (op & 0x1f) << 20;
3945 // op: imm31
3946 op = getImmOpValueAsrN<1>(MI, OpNo: 4, Fixups, STI);
3947 Value |= (op & 0x7fff8000) << 17;
3948 Value |= (op & 0x800) << 20;
3949 Value |= (op & 0x3f0) << 21;
3950 Value |= (op & 0x7000) << 5;
3951 Value |= (op & 0xf) << 8;
3952 Value |= (op & 0x400) >> 3;
3953 break;
3954 }
3955 case RISCV::InsnQC_ES: {
3956 // op: opcode
3957 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3958 Value |= (op & 0x7f);
3959 // op: func3
3960 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3961 Value |= (op & 0x7) << 12;
3962 // op: func2
3963 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3964 Value |= (op & 0x3) << 30;
3965 // op: rs1
3966 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
3967 Value |= (op & 0x1f) << 15;
3968 // op: rs2
3969 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3970 Value |= (op & 0x1f) << 20;
3971 // op: imm26
3972 op = getImmOpValue(MI, OpNo: 5, Fixups, STI);
3973 Value |= (op & 0x3fffc00) << 22;
3974 Value |= (op & 0x3e0) << 20;
3975 Value |= (op & 0x1f) << 7;
3976 break;
3977 }
3978 case RISCV::InsnQC_EB: {
3979 // op: opcode
3980 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3981 Value |= (op & 0x7f);
3982 // op: func3
3983 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3984 Value |= (op & 0x7) << 12;
3985 // op: func5
3986 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3987 Value |= (op & 0x1f) << 20;
3988 // op: rs1
3989 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3990 Value |= (op & 0x1f) << 15;
3991 // op: imm12
3992 op = getImmOpValueAsrN<1>(MI, OpNo: 5, Fixups, STI);
3993 Value |= (op & 0x800) << 20;
3994 Value |= (op & 0x3f0) << 21;
3995 Value |= (op & 0xf) << 8;
3996 Value |= (op & 0x400) >> 3;
3997 // op: imm16
3998 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3999 Value |= (op & 0xffff) << 32;
4000 break;
4001 }
4002 case RISCV::InsnS: {
4003 // op: opcode
4004 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
4005 Value |= (op & 0x7f);
4006 // op: funct3
4007 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4008 Value |= (op & 0x7) << 12;
4009 // op: imm12
4010 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4011 Value |= (op & 0xfe0) << 20;
4012 Value |= (op & 0x1f) << 7;
4013 // op: rs2
4014 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4015 Value |= (op & 0x1f) << 20;
4016 // op: rs1
4017 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4018 Value |= (op & 0x1f) << 15;
4019 break;
4020 }
4021 case RISCV::InsnB: {
4022 // op: opcode
4023 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
4024 Value |= (op & 0x7f);
4025 // op: funct3
4026 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4027 Value |= (op & 0x7) << 12;
4028 // op: imm12
4029 op = getImmOpValueAsrN<1>(MI, OpNo: 4, Fixups, STI);
4030 Value |= (op & 0x800) << 20;
4031 Value |= (op & 0x3f0) << 21;
4032 Value |= (op & 0xf) << 8;
4033 Value |= (op & 0x400) >> 3;
4034 // op: rs2
4035 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4036 Value |= (op & 0x1f) << 20;
4037 // op: rs1
4038 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4039 Value |= (op & 0x1f) << 15;
4040 break;
4041 }
4042 case RISCV::InsnCL: {
4043 // op: opcode
4044 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4045 Value |= (op & 0x3);
4046 // op: funct3
4047 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4048 Value |= (op & 0x7) << 13;
4049 // op: imm5
4050 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4051 Value |= (op & 0x1c) << 8;
4052 Value |= (op & 0x3) << 5;
4053 // op: rd
4054 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4055 Value |= (op & 0x7) << 2;
4056 // op: rs1
4057 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4058 Value |= (op & 0x7) << 7;
4059 break;
4060 }
4061 case RISCV::InsnCI: {
4062 // op: opcode
4063 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4064 Value |= (op & 0x3);
4065 // op: funct3
4066 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4067 Value |= (op & 0x7) << 13;
4068 // op: imm6
4069 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4070 Value |= (op & 0x20) << 7;
4071 Value |= (op & 0x1f) << 2;
4072 // op: rd
4073 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4074 Value |= (op & 0x1f) << 7;
4075 break;
4076 }
4077 case RISCV::InsnCIW: {
4078 // op: opcode
4079 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4080 Value |= (op & 0x3);
4081 // op: funct3
4082 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4083 Value |= (op & 0x7) << 13;
4084 // op: imm8
4085 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4086 Value |= (op & 0xff) << 5;
4087 // op: rd
4088 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4089 Value |= (op & 0x7) << 2;
4090 break;
4091 }
4092 case RISCV::InsnCR: {
4093 // op: opcode
4094 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4095 Value |= (op & 0x3);
4096 // op: funct4
4097 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4098 Value |= (op & 0xf) << 12;
4099 // op: rs2
4100 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4101 Value |= (op & 0x1f) << 2;
4102 // op: rd
4103 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4104 Value |= (op & 0x1f) << 7;
4105 break;
4106 }
4107 case RISCV::InsnCA: {
4108 // op: opcode
4109 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4110 Value |= (op & 0x3);
4111 // op: funct6
4112 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4113 Value |= (op & 0x3f) << 10;
4114 // op: funct2
4115 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4116 Value |= (op & 0x3) << 5;
4117 // op: rd
4118 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4119 Value |= (op & 0x7) << 7;
4120 // op: rs2
4121 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4122 Value |= (op & 0x7) << 2;
4123 break;
4124 }
4125 case RISCV::InsnQC_EAI: {
4126 // op: opcode
4127 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4128 Value |= (op & 0x7f);
4129 // op: func3
4130 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4131 Value |= (op & 0x7) << 12;
4132 // op: func1
4133 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4134 Value |= (op & 0x1) << 15;
4135 // op: rd
4136 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4137 Value |= (op & 0x1f) << 7;
4138 // op: imm32
4139 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4140 Value |= (op & 0xffffffff) << 16;
4141 break;
4142 }
4143 case RISCV::InsnQC_EI:
4144 case RISCV::InsnQC_EI_Mem: {
4145 // op: opcode
4146 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4147 Value |= (op & 0x7f);
4148 // op: func3
4149 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4150 Value |= (op & 0x7) << 12;
4151 // op: func2
4152 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4153 Value |= (op & 0x3) << 30;
4154 // op: rd
4155 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4156 Value |= (op & 0x1f) << 7;
4157 // op: rs1
4158 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4159 Value |= (op & 0x1f) << 15;
4160 // op: imm26
4161 op = getImmOpValue(MI, OpNo: 5, Fixups, STI);
4162 Value |= (op & 0x3fffc00) << 22;
4163 Value |= (op & 0x3ff) << 20;
4164 break;
4165 }
4166 case RISCV::InsnR4: {
4167 // op: opcode
4168 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4169 Value |= (op & 0x7f);
4170 // op: funct2
4171 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4172 Value |= (op & 0x3) << 25;
4173 // op: funct3
4174 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4175 Value |= (op & 0x7) << 12;
4176 // op: rs3
4177 op = getMachineOpValue(MI, MO: MI.getOperand(i: 6), Fixups, STI);
4178 Value |= (op & 0x1f) << 27;
4179 // op: rs2
4180 op = getMachineOpValue(MI, MO: MI.getOperand(i: 5), Fixups, STI);
4181 Value |= (op & 0x1f) << 20;
4182 // op: rs1
4183 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4184 Value |= (op & 0x1f) << 15;
4185 // op: rd
4186 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4187 Value |= (op & 0x1f) << 7;
4188 break;
4189 }
4190 case RISCV::InsnI:
4191 case RISCV::InsnI_Mem: {
4192 // op: opcode
4193 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4194 Value |= (op & 0x7f);
4195 // op: funct3
4196 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4197 Value |= (op & 0x7) << 12;
4198 // op: imm12
4199 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4200 Value |= (op & 0xfff) << 20;
4201 // op: rs1
4202 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4203 Value |= (op & 0x1f) << 15;
4204 // op: rd
4205 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4206 Value |= (op & 0x1f) << 7;
4207 break;
4208 }
4209 case RISCV::InsnR: {
4210 // op: opcode
4211 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4212 Value |= (op & 0x7f);
4213 // op: funct7
4214 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4215 Value |= (op & 0x7f) << 25;
4216 // op: funct3
4217 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4218 Value |= (op & 0x7) << 12;
4219 // op: rs2
4220 op = getMachineOpValue(MI, MO: MI.getOperand(i: 5), Fixups, STI);
4221 Value |= (op & 0x1f) << 20;
4222 // op: rs1
4223 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4224 Value |= (op & 0x1f) << 15;
4225 // op: rd
4226 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4227 Value |= (op & 0x1f) << 7;
4228 break;
4229 }
4230 case RISCV::InsnU: {
4231 // op: opcode
4232 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4233 Value |= (op & 0x7f);
4234 // op: imm20
4235 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4236 Value |= (op & 0xfffff) << 12;
4237 // op: rd
4238 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4239 Value |= (op & 0x1f) << 7;
4240 break;
4241 }
4242 case RISCV::InsnJ: {
4243 // op: opcode
4244 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4245 Value |= (op & 0x7f);
4246 // op: imm20
4247 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
4248 Value |= (op & 0xfffff) << 12;
4249 // op: rd
4250 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4251 Value |= (op & 0x1f) << 7;
4252 break;
4253 }
4254 case RISCV::FENCE: {
4255 // op: pred
4256 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4257 Value |= (op & 0xf) << 24;
4258 // op: succ
4259 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4260 Value |= (op & 0xf) << 20;
4261 break;
4262 }
4263 case RISCV::PLUI_DH: {
4264 // op: rd
4265 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4266 Value |= (op & 0x1e) << 7;
4267 // op: imm10
4268 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4269 Value |= (op & 0x1) << 24;
4270 Value |= (op & 0x3fe) << 14;
4271 break;
4272 }
4273 case RISCV::PLI_DH: {
4274 // op: rd
4275 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4276 Value |= (op & 0x1e) << 7;
4277 // op: imm10
4278 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4279 Value |= (op & 0x1ff) << 16;
4280 Value |= (op & 0x200) << 6;
4281 break;
4282 }
4283 case RISCV::PLI_DB: {
4284 // op: rd
4285 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4286 Value |= (op & 0x1e) << 7;
4287 // op: imm8
4288 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4289 Value |= (op & 0xff) << 16;
4290 break;
4291 }
4292 case RISCV::AIF_MOVA_X_M:
4293 case RISCV::QC_C_DIR:
4294 case RISCV::SSRDP: {
4295 // op: rd
4296 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4297 Value |= (op & 0x1f) << 7;
4298 break;
4299 }
4300 case RISCV::QC_E_LI: {
4301 // op: rd
4302 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4303 Value |= (op & 0x1f) << 7;
4304 // op: imm
4305 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4306 Value |= (op & 0xffffffff) << 16;
4307 break;
4308 }
4309 case RISCV::FLI_D:
4310 case RISCV::FLI_H:
4311 case RISCV::FLI_Q:
4312 case RISCV::FLI_S: {
4313 // op: rd
4314 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4315 Value |= (op & 0x1f) << 7;
4316 // op: imm
4317 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4318 Value |= (op & 0x1f) << 15;
4319 break;
4320 }
4321 case RISCV::PLUI_H:
4322 case RISCV::PLUI_W: {
4323 // op: rd
4324 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4325 Value |= (op & 0x1f) << 7;
4326 // op: imm10
4327 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4328 Value |= (op & 0x1) << 24;
4329 Value |= (op & 0x3fe) << 14;
4330 break;
4331 }
4332 case RISCV::PLI_H:
4333 case RISCV::PLI_W: {
4334 // op: rd
4335 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4336 Value |= (op & 0x1f) << 7;
4337 // op: imm10
4338 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4339 Value |= (op & 0x1ff) << 16;
4340 Value |= (op & 0x200) << 6;
4341 break;
4342 }
4343 case RISCV::PLI_B: {
4344 // op: rd
4345 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4346 Value |= (op & 0x1f) << 7;
4347 // op: imm8
4348 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4349 Value |= (op & 0xff) << 16;
4350 break;
4351 }
4352 case RISCV::AIF_FMVS_X_PS:
4353 case RISCV::AIF_FMVZ_X_PS: {
4354 // op: rd
4355 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4356 Value |= (op & 0x1f) << 7;
4357 // op: rs1
4358 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4359 Value |= (op & 0x1f) << 15;
4360 // op: idx
4361 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4362 Value |= (op & 0x7) << 20;
4363 break;
4364 }
4365 case RISCV::QC_E_ADDI:
4366 case RISCV::QC_E_ANDI:
4367 case RISCV::QC_E_LB:
4368 case RISCV::QC_E_LBU:
4369 case RISCV::QC_E_LH:
4370 case RISCV::QC_E_LHU:
4371 case RISCV::QC_E_LW:
4372 case RISCV::QC_E_ORI:
4373 case RISCV::QC_E_XORI: {
4374 // op: rd
4375 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4376 Value |= (op & 0x1f) << 7;
4377 // op: rs1
4378 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4379 Value |= (op & 0x1f) << 15;
4380 // op: imm
4381 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4382 Value |= (op & 0x3fffc00) << 22;
4383 Value |= (op & 0x3ff) << 20;
4384 break;
4385 }
4386 case RISCV::AIF_FSWIZZ_PS: {
4387 // op: rd
4388 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4389 Value |= (op & 0x1f) << 7;
4390 // op: rs1
4391 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4392 Value |= (op & 0x1f) << 15;
4393 // op: imm
4394 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4395 Value |= (op & 0xf8) << 17;
4396 Value |= (op & 0x7) << 12;
4397 break;
4398 }
4399 case RISCV::NDS_BFOS:
4400 case RISCV::NDS_BFOZ: {
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: msb
4408 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4409 Value |= (op & 0x3f) << 26;
4410 // op: lsb
4411 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4412 Value |= (op & 0x3f) << 20;
4413 break;
4414 }
4415 case RISCV::AIF_FCVT_PS_PW:
4416 case RISCV::AIF_FCVT_PS_PWU:
4417 case RISCV::AIF_FCVT_PWU_PS:
4418 case RISCV::AIF_FCVT_PW_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: rm
4426 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4427 Value |= (op & 0x7) << 12;
4428 break;
4429 }
4430 case RISCV::AIF_FADD_PS:
4431 case RISCV::AIF_FDIV_PS:
4432 case RISCV::AIF_FMUL_PS:
4433 case RISCV::AIF_FSUB_PS: {
4434 // op: rd
4435 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4436 Value |= (op & 0x1f) << 7;
4437 // op: rs1
4438 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4439 Value |= (op & 0x1f) << 15;
4440 // op: rs2
4441 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4442 Value |= (op & 0x1f) << 20;
4443 // op: rm
4444 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4445 Value |= (op & 0x7) << 12;
4446 break;
4447 }
4448 case RISCV::AIF_FCMOV_PS: {
4449 // op: rd
4450 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4451 Value |= (op & 0x1f) << 7;
4452 // op: rs1
4453 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4454 Value |= (op & 0x1f) << 15;
4455 // op: rs2
4456 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4457 Value |= (op & 0x1f) << 20;
4458 // op: rs3
4459 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4460 Value |= (op & 0x1f) << 27;
4461 break;
4462 }
4463 case RISCV::AIF_FMADD_PS:
4464 case RISCV::AIF_FMSUB_PS:
4465 case RISCV::AIF_FNMADD_PS:
4466 case RISCV::AIF_FNMSUB_PS: {
4467 // op: rd
4468 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4469 Value |= (op & 0x1f) << 7;
4470 // op: rs1
4471 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4472 Value |= (op & 0x1f) << 15;
4473 // op: rs2
4474 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4475 Value |= (op & 0x1f) << 20;
4476 // op: rs3
4477 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4478 Value |= (op & 0x1f) << 27;
4479 // op: rm
4480 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4481 Value |= (op & 0x7) << 12;
4482 break;
4483 }
4484 case RISCV::VSETIVLI: {
4485 // op: rd
4486 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4487 Value |= (op & 0x1f) << 7;
4488 // op: uimm
4489 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4490 Value |= (op & 0x1f) << 15;
4491 // op: vtypei
4492 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4493 Value |= (op & 0x3ff) << 20;
4494 break;
4495 }
4496 case RISCV::VCPOP_M:
4497 case RISCV::VFIRST_M: {
4498 // op: rd
4499 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4500 Value |= (op & 0x1f) << 7;
4501 // op: vm
4502 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
4503 Value |= (op & 0x1) << 25;
4504 // op: vs2
4505 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4506 Value |= (op & 0x1f) << 20;
4507 break;
4508 }
4509 case RISCV::VFMV_F_S:
4510 case RISCV::VMV_X_S: {
4511 // op: rd
4512 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4513 Value |= (op & 0x1f) << 7;
4514 // op: vs2
4515 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4516 Value |= (op & 0x1f) << 20;
4517 break;
4518 }
4519 case RISCV::QK_C_LBU: {
4520 // op: rd
4521 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4522 Value |= (op & 0x7) << 2;
4523 // op: rs1
4524 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4525 Value |= (op & 0x7) << 7;
4526 // op: imm
4527 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4528 Value |= (op & 0x1) << 12;
4529 Value |= (op & 0x18) << 7;
4530 Value |= (op & 0x6) << 4;
4531 break;
4532 }
4533 case RISCV::C_LBU: {
4534 // op: rd
4535 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4536 Value |= (op & 0x7) << 2;
4537 // op: rs1
4538 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4539 Value |= (op & 0x7) << 7;
4540 // op: imm
4541 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4542 Value |= (op & 0x1) << 6;
4543 Value |= (op & 0x2) << 4;
4544 break;
4545 }
4546 case RISCV::C_LH:
4547 case RISCV::C_LHU:
4548 case RISCV::C_LH_INX: {
4549 // op: rd
4550 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4551 Value |= (op & 0x7) << 2;
4552 // op: rs1
4553 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4554 Value |= (op & 0x7) << 7;
4555 // op: imm
4556 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4557 Value |= (op & 0x2) << 4;
4558 break;
4559 }
4560 case RISCV::C_FLW:
4561 case RISCV::C_LW:
4562 case RISCV::C_LW_INX: {
4563 // op: rd
4564 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4565 Value |= (op & 0x7) << 2;
4566 // op: rs1
4567 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4568 Value |= (op & 0x7) << 7;
4569 // op: imm
4570 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4571 Value |= (op & 0x38) << 7;
4572 Value |= (op & 0x4) << 4;
4573 Value |= (op & 0x40) >> 1;
4574 break;
4575 }
4576 case RISCV::QK_C_LHU: {
4577 // op: rd
4578 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4579 Value |= (op & 0x7) << 2;
4580 // op: rs1
4581 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4582 Value |= (op & 0x7) << 7;
4583 // op: imm
4584 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4585 Value |= (op & 0x38) << 7;
4586 Value |= (op & 0x6) << 4;
4587 break;
4588 }
4589 case RISCV::C_FLD:
4590 case RISCV::C_LD:
4591 case RISCV::C_LD_RV32: {
4592 // op: rd
4593 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4594 Value |= (op & 0x7) << 2;
4595 // op: rs1
4596 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4597 Value |= (op & 0x7) << 7;
4598 // op: imm
4599 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4600 Value |= (op & 0x38) << 7;
4601 Value |= (op & 0xc0) >> 1;
4602 break;
4603 }
4604 case RISCV::SF_VTZERO_T: {
4605 // op: rd
4606 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4607 Value |= (op & 0xf) << 8;
4608 break;
4609 }
4610 case RISCV::QC_E_ADDAI:
4611 case RISCV::QC_E_ANDAI:
4612 case RISCV::QC_E_ORAI:
4613 case RISCV::QC_E_XORAI: {
4614 // op: rd
4615 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4616 Value |= (op & 0x1f) << 7;
4617 // op: imm
4618 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4619 Value |= (op & 0xffffffff) << 16;
4620 break;
4621 }
4622 case RISCV::QC_INSBI: {
4623 // op: rd
4624 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4625 Value |= (op & 0x1f) << 7;
4626 // op: imm5
4627 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4628 Value |= (op & 0x1f) << 15;
4629 // op: shamt
4630 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4631 Value |= (op & 0x1f) << 20;
4632 // op: width
4633 op = getImmOpValueMinus1(MI, OpNo: 3, Fixups, STI);
4634 Value |= (op & 0x1f) << 25;
4635 break;
4636 }
4637 case RISCV::QC_C_EXTU: {
4638 // op: rd
4639 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4640 Value |= (op & 0x1f) << 7;
4641 // op: width
4642 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
4643 Value |= (op & 0x1f) << 2;
4644 break;
4645 }
4646 case RISCV::QC_C_MVEQZ: {
4647 // op: rd
4648 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4649 Value |= (op & 0x7) << 2;
4650 // op: rs1
4651 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4652 Value |= (op & 0x7) << 7;
4653 break;
4654 }
4655 case RISCV::QC_C_MULIADD: {
4656 // op: rd
4657 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4658 Value |= (op & 0x7) << 2;
4659 // op: rs1
4660 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4661 Value |= (op & 0x7) << 7;
4662 // op: uimm
4663 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4664 Value |= (op & 0xe) << 9;
4665 Value |= (op & 0x1) << 6;
4666 Value |= (op & 0x10) << 1;
4667 break;
4668 }
4669 case RISCV::C_NOT:
4670 case RISCV::C_SEXT_B:
4671 case RISCV::C_SEXT_H:
4672 case RISCV::C_ZEXT_B:
4673 case RISCV::C_ZEXT_H:
4674 case RISCV::C_ZEXT_W: {
4675 // op: rd
4676 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4677 Value |= (op & 0x7) << 7;
4678 break;
4679 }
4680 case RISCV::QK_C_LHUSP:
4681 case RISCV::QK_C_SHSP: {
4682 // op: rd_rs2
4683 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4684 Value |= (op & 0x7) << 2;
4685 // op: imm
4686 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4687 Value |= (op & 0xe) << 7;
4688 Value |= (op & 0x10) << 3;
4689 break;
4690 }
4691 case RISCV::QK_C_LBUSP:
4692 case RISCV::QK_C_SBSP: {
4693 // op: rd_rs2
4694 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4695 Value |= (op & 0x7) << 2;
4696 // op: imm
4697 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4698 Value |= (op & 0xf) << 7;
4699 break;
4700 }
4701 case RISCV::CM_POP:
4702 case RISCV::CM_POPRET:
4703 case RISCV::CM_POPRETZ:
4704 case RISCV::CM_PUSH:
4705 case RISCV::QC_CM_POP:
4706 case RISCV::QC_CM_POPRET:
4707 case RISCV::QC_CM_POPRETZ:
4708 case RISCV::QC_CM_PUSH: {
4709 // op: rlist
4710 op = getRlistOpValue(MI, OpNo: 0, Fixups, STI);
4711 Value |= (op & 0xf) << 4;
4712 // op: stackadj
4713 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4714 Value |= (op & 0x30) >> 2;
4715 break;
4716 }
4717 case RISCV::QC_CM_PUSHFP: {
4718 // op: rlist
4719 op = getRlistS0OpValue(MI, OpNo: 0, Fixups, STI);
4720 Value |= (op & 0xf) << 4;
4721 // op: stackadj
4722 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4723 Value |= (op & 0x30) >> 2;
4724 break;
4725 }
4726 case RISCV::CSRRCI:
4727 case RISCV::CSRRSI:
4728 case RISCV::CSRRWI: {
4729 // op: rs1
4730 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4731 Value |= (op & 0x1f) << 15;
4732 // op: rd
4733 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4734 Value |= (op & 0x1f) << 7;
4735 // op: imm12
4736 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4737 Value |= (op & 0xfff) << 20;
4738 break;
4739 }
4740 case RISCV::AIF_MOVA_M_X:
4741 case RISCV::CBO_CLEAN:
4742 case RISCV::CBO_FLUSH:
4743 case RISCV::CBO_INVAL:
4744 case RISCV::CBO_ZERO:
4745 case RISCV::SF_CDISCARD_D_L1:
4746 case RISCV::SF_CFLUSH_D_L1:
4747 case RISCV::SSPOPCHK:
4748 case RISCV::TH_DCACHE_CIPA:
4749 case RISCV::TH_DCACHE_CISW:
4750 case RISCV::TH_DCACHE_CIVA:
4751 case RISCV::TH_DCACHE_CPA:
4752 case RISCV::TH_DCACHE_CPAL1:
4753 case RISCV::TH_DCACHE_CSW:
4754 case RISCV::TH_DCACHE_CVA:
4755 case RISCV::TH_DCACHE_CVAL1:
4756 case RISCV::TH_DCACHE_IPA:
4757 case RISCV::TH_DCACHE_ISW:
4758 case RISCV::TH_DCACHE_IVA:
4759 case RISCV::TH_ICACHE_IPA:
4760 case RISCV::TH_ICACHE_IVA: {
4761 // op: rs1
4762 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4763 Value |= (op & 0x1f) << 15;
4764 break;
4765 }
4766 case RISCV::QC_E_BEQI:
4767 case RISCV::QC_E_BGEI:
4768 case RISCV::QC_E_BGEUI:
4769 case RISCV::QC_E_BLTI:
4770 case RISCV::QC_E_BLTUI:
4771 case RISCV::QC_E_BNEI: {
4772 // op: rs1
4773 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4774 Value |= (op & 0x1f) << 15;
4775 // op: imm16
4776 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4777 Value |= (op & 0xffff) << 32;
4778 // op: imm12
4779 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
4780 Value |= (op & 0x800) << 20;
4781 Value |= (op & 0x3f0) << 21;
4782 Value |= (op & 0xf) << 8;
4783 Value |= (op & 0x400) >> 3;
4784 break;
4785 }
4786 case RISCV::C_JALR:
4787 case RISCV::C_JR:
4788 case RISCV::QC_C_CLRINT:
4789 case RISCV::QC_C_EIR:
4790 case RISCV::QC_C_SETINT: {
4791 // op: rs1
4792 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4793 Value |= (op & 0x1f) << 7;
4794 break;
4795 }
4796 case RISCV::C_MV: {
4797 // op: rs1
4798 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4799 Value |= (op & 0x1f) << 7;
4800 // op: rs2
4801 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4802 Value |= (op & 0x1f) << 2;
4803 break;
4804 }
4805 case RISCV::PSABS_DB:
4806 case RISCV::PSABS_DH:
4807 case RISCV::PSEXT_DH_B:
4808 case RISCV::PSEXT_DW_B:
4809 case RISCV::PSEXT_DW_H: {
4810 // op: rs1
4811 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4812 Value |= (op & 0x1e) << 15;
4813 // op: rd
4814 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4815 Value |= (op & 0x1e) << 7;
4816 break;
4817 }
4818 case RISCV::ADDD:
4819 case RISCV::PAADDU_DB:
4820 case RISCV::PAADDU_DH:
4821 case RISCV::PAADDU_DW:
4822 case RISCV::PAADD_DB:
4823 case RISCV::PAADD_DH:
4824 case RISCV::PAADD_DW:
4825 case RISCV::PAAS_DHX:
4826 case RISCV::PABDU_DB:
4827 case RISCV::PABDU_DH:
4828 case RISCV::PABD_DB:
4829 case RISCV::PABD_DH:
4830 case RISCV::PADD_DB:
4831 case RISCV::PADD_DH:
4832 case RISCV::PADD_DW:
4833 case RISCV::PASA_DHX:
4834 case RISCV::PASUBU_DB:
4835 case RISCV::PASUBU_DH:
4836 case RISCV::PASUBU_DW:
4837 case RISCV::PASUB_DB:
4838 case RISCV::PASUB_DH:
4839 case RISCV::PASUB_DW:
4840 case RISCV::PAS_DHX:
4841 case RISCV::PMAXU_DB:
4842 case RISCV::PMAXU_DH:
4843 case RISCV::PMAXU_DW:
4844 case RISCV::PMAX_DB:
4845 case RISCV::PMAX_DH:
4846 case RISCV::PMAX_DW:
4847 case RISCV::PMINU_DB:
4848 case RISCV::PMINU_DH:
4849 case RISCV::PMINU_DW:
4850 case RISCV::PMIN_DB:
4851 case RISCV::PMIN_DH:
4852 case RISCV::PMIN_DW:
4853 case RISCV::PMSEQ_DB:
4854 case RISCV::PMSEQ_DH:
4855 case RISCV::PMSEQ_DW:
4856 case RISCV::PMSLTU_DB:
4857 case RISCV::PMSLTU_DH:
4858 case RISCV::PMSLTU_DW:
4859 case RISCV::PMSLT_DB:
4860 case RISCV::PMSLT_DH:
4861 case RISCV::PMSLT_DW:
4862 case RISCV::PPAIREO_DB:
4863 case RISCV::PPAIREO_DH:
4864 case RISCV::PPAIRE_DB:
4865 case RISCV::PPAIRE_DH:
4866 case RISCV::PPAIROE_DB:
4867 case RISCV::PPAIROE_DH:
4868 case RISCV::PPAIRO_DB:
4869 case RISCV::PPAIRO_DH:
4870 case RISCV::PSADDU_DB:
4871 case RISCV::PSADDU_DH:
4872 case RISCV::PSADDU_DW:
4873 case RISCV::PSADD_DB:
4874 case RISCV::PSADD_DH:
4875 case RISCV::PSADD_DW:
4876 case RISCV::PSAS_DHX:
4877 case RISCV::PSA_DHX:
4878 case RISCV::PSH1ADD_DH:
4879 case RISCV::PSH1ADD_DW:
4880 case RISCV::PSSA_DHX:
4881 case RISCV::PSSH1SADD_DH:
4882 case RISCV::PSSH1SADD_DW:
4883 case RISCV::PSSUBU_DB:
4884 case RISCV::PSSUBU_DH:
4885 case RISCV::PSSUBU_DW:
4886 case RISCV::PSSUB_DB:
4887 case RISCV::PSSUB_DH:
4888 case RISCV::PSSUB_DW:
4889 case RISCV::PSUB_DB:
4890 case RISCV::PSUB_DH:
4891 case RISCV::PSUB_DW:
4892 case RISCV::SUBD: {
4893 // op: rs1
4894 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4895 Value |= (op & 0x1e) << 15;
4896 // op: rd
4897 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4898 Value |= (op & 0x1e) << 7;
4899 // op: rs2
4900 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4901 Value |= (op & 0x1e) << 20;
4902 break;
4903 }
4904 case RISCV::PADD_DBS:
4905 case RISCV::PADD_DHS:
4906 case RISCV::PADD_DWS:
4907 case RISCV::PSLL_DBS:
4908 case RISCV::PSLL_DHS:
4909 case RISCV::PSLL_DWS:
4910 case RISCV::PSRA_DBS:
4911 case RISCV::PSRA_DHS:
4912 case RISCV::PSRA_DWS:
4913 case RISCV::PSRL_DBS:
4914 case RISCV::PSRL_DHS:
4915 case RISCV::PSRL_DWS:
4916 case RISCV::PSSHAR_DHS:
4917 case RISCV::PSSHAR_DWS:
4918 case RISCV::PSSHA_DHS:
4919 case RISCV::PSSHA_DWS:
4920 case RISCV::PSSHLR_DHS:
4921 case RISCV::PSSHLR_DWS:
4922 case RISCV::PSSHL_DHS:
4923 case RISCV::PSSHL_DWS: {
4924 // op: rs1
4925 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4926 Value |= (op & 0x1e) << 15;
4927 // op: rd
4928 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4929 Value |= (op & 0x1e) << 7;
4930 // op: rs2
4931 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4932 Value |= (op & 0x1f) << 20;
4933 break;
4934 }
4935 case RISCV::PSATI_DW:
4936 case RISCV::PSLLI_DW:
4937 case RISCV::PSRAI_DW:
4938 case RISCV::PSRARI_DW:
4939 case RISCV::PSRLI_DW:
4940 case RISCV::PSSLAI_DW:
4941 case RISCV::PUSATI_DW: {
4942 // op: rs1
4943 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4944 Value |= (op & 0x1e) << 15;
4945 // op: rd
4946 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4947 Value |= (op & 0x1e) << 7;
4948 // op: shamt
4949 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4950 Value |= (op & 0x1f) << 20;
4951 break;
4952 }
4953 case RISCV::PSLLI_DB:
4954 case RISCV::PSRAI_DB:
4955 case RISCV::PSRLI_DB: {
4956 // op: rs1
4957 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4958 Value |= (op & 0x1e) << 15;
4959 // op: rd
4960 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4961 Value |= (op & 0x1e) << 7;
4962 // op: shamt
4963 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4964 Value |= (op & 0x7) << 20;
4965 break;
4966 }
4967 case RISCV::PSATI_DH:
4968 case RISCV::PSLLI_DH:
4969 case RISCV::PSRAI_DH:
4970 case RISCV::PSRARI_DH:
4971 case RISCV::PSRLI_DH:
4972 case RISCV::PSSLAI_DH:
4973 case RISCV::PUSATI_DH: {
4974 // op: rs1
4975 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4976 Value |= (op & 0x1e) << 15;
4977 // op: rd
4978 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4979 Value |= (op & 0x1e) << 7;
4980 // op: shamt
4981 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4982 Value |= (op & 0xf) << 20;
4983 break;
4984 }
4985 case RISCV::NCLIP:
4986 case RISCV::NCLIPR:
4987 case RISCV::NCLIPRU:
4988 case RISCV::NCLIPU:
4989 case RISCV::NSRA:
4990 case RISCV::NSRAR:
4991 case RISCV::NSRL:
4992 case RISCV::PNCLIPRU_BS:
4993 case RISCV::PNCLIPRU_HS:
4994 case RISCV::PNCLIPR_BS:
4995 case RISCV::PNCLIPR_HS:
4996 case RISCV::PNCLIPU_BS:
4997 case RISCV::PNCLIPU_HS:
4998 case RISCV::PNCLIP_BS:
4999 case RISCV::PNCLIP_HS:
5000 case RISCV::PNSRAR_BS:
5001 case RISCV::PNSRAR_HS:
5002 case RISCV::PNSRA_BS:
5003 case RISCV::PNSRA_HS:
5004 case RISCV::PNSRL_BS:
5005 case RISCV::PNSRL_HS:
5006 case RISCV::PREDSUMU_DBS:
5007 case RISCV::PREDSUMU_DHS:
5008 case RISCV::PREDSUM_DBS:
5009 case RISCV::PREDSUM_DHS: {
5010 // op: rs1
5011 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5012 Value |= (op & 0x1e) << 15;
5013 // op: rd
5014 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5015 Value |= (op & 0x1f) << 7;
5016 // op: rs2
5017 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5018 Value |= (op & 0x1f) << 20;
5019 break;
5020 }
5021 case RISCV::PNCLIPIU_H:
5022 case RISCV::PNCLIPI_H:
5023 case RISCV::PNCLIPRIU_H:
5024 case RISCV::PNCLIPRI_H:
5025 case RISCV::PNSRAI_H:
5026 case RISCV::PNSRARI_H:
5027 case RISCV::PNSRLI_H: {
5028 // op: rs1
5029 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5030 Value |= (op & 0x1e) << 15;
5031 // op: rd
5032 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5033 Value |= (op & 0x1f) << 7;
5034 // op: shamt
5035 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5036 Value |= (op & 0x1f) << 20;
5037 break;
5038 }
5039 case RISCV::NCLIPI:
5040 case RISCV::NCLIPIU:
5041 case RISCV::NCLIPRI:
5042 case RISCV::NCLIPRIU:
5043 case RISCV::NSRAI:
5044 case RISCV::NSRARI:
5045 case RISCV::NSRLI: {
5046 // op: rs1
5047 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5048 Value |= (op & 0x1e) << 15;
5049 // op: rd
5050 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5051 Value |= (op & 0x1f) << 7;
5052 // op: shamt
5053 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5054 Value |= (op & 0x3f) << 20;
5055 break;
5056 }
5057 case RISCV::PNCLIPIU_B:
5058 case RISCV::PNCLIPI_B:
5059 case RISCV::PNCLIPRIU_B:
5060 case RISCV::PNCLIPRI_B:
5061 case RISCV::PNSRAI_B:
5062 case RISCV::PNSRARI_B:
5063 case RISCV::PNSRLI_B: {
5064 // op: rs1
5065 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5066 Value |= (op & 0x1e) << 15;
5067 // op: rd
5068 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5069 Value |= (op & 0x1f) << 7;
5070 // op: shamt
5071 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5072 Value |= (op & 0xf) << 20;
5073 break;
5074 }
5075 case RISCV::FCVT_BF16_S:
5076 case RISCV::FCVT_D_H:
5077 case RISCV::FCVT_D_H_IN32X:
5078 case RISCV::FCVT_D_H_INX:
5079 case RISCV::FCVT_D_L:
5080 case RISCV::FCVT_D_LU:
5081 case RISCV::FCVT_D_LU_INX:
5082 case RISCV::FCVT_D_L_INX:
5083 case RISCV::FCVT_D_Q:
5084 case RISCV::FCVT_D_S:
5085 case RISCV::FCVT_D_S_IN32X:
5086 case RISCV::FCVT_D_S_INX:
5087 case RISCV::FCVT_D_W:
5088 case RISCV::FCVT_D_WU:
5089 case RISCV::FCVT_D_WU_IN32X:
5090 case RISCV::FCVT_D_WU_INX:
5091 case RISCV::FCVT_D_W_IN32X:
5092 case RISCV::FCVT_D_W_INX:
5093 case RISCV::FCVT_H_D:
5094 case RISCV::FCVT_H_D_IN32X:
5095 case RISCV::FCVT_H_D_INX:
5096 case RISCV::FCVT_H_L:
5097 case RISCV::FCVT_H_LU:
5098 case RISCV::FCVT_H_LU_INX:
5099 case RISCV::FCVT_H_L_INX:
5100 case RISCV::FCVT_H_S:
5101 case RISCV::FCVT_H_S_INX:
5102 case RISCV::FCVT_H_W:
5103 case RISCV::FCVT_H_WU:
5104 case RISCV::FCVT_H_WU_INX:
5105 case RISCV::FCVT_H_W_INX:
5106 case RISCV::FCVT_LU_D:
5107 case RISCV::FCVT_LU_D_INX:
5108 case RISCV::FCVT_LU_H:
5109 case RISCV::FCVT_LU_H_INX:
5110 case RISCV::FCVT_LU_Q:
5111 case RISCV::FCVT_LU_S:
5112 case RISCV::FCVT_LU_S_INX:
5113 case RISCV::FCVT_L_D:
5114 case RISCV::FCVT_L_D_INX:
5115 case RISCV::FCVT_L_H:
5116 case RISCV::FCVT_L_H_INX:
5117 case RISCV::FCVT_L_Q:
5118 case RISCV::FCVT_L_S:
5119 case RISCV::FCVT_L_S_INX:
5120 case RISCV::FCVT_Q_D:
5121 case RISCV::FCVT_Q_L:
5122 case RISCV::FCVT_Q_LU:
5123 case RISCV::FCVT_Q_S:
5124 case RISCV::FCVT_Q_W:
5125 case RISCV::FCVT_Q_WU:
5126 case RISCV::FCVT_S_BF16:
5127 case RISCV::FCVT_S_D:
5128 case RISCV::FCVT_S_D_IN32X:
5129 case RISCV::FCVT_S_D_INX:
5130 case RISCV::FCVT_S_H:
5131 case RISCV::FCVT_S_H_INX:
5132 case RISCV::FCVT_S_L:
5133 case RISCV::FCVT_S_LU:
5134 case RISCV::FCVT_S_LU_INX:
5135 case RISCV::FCVT_S_L_INX:
5136 case RISCV::FCVT_S_Q:
5137 case RISCV::FCVT_S_W:
5138 case RISCV::FCVT_S_WU:
5139 case RISCV::FCVT_S_WU_INX:
5140 case RISCV::FCVT_S_W_INX:
5141 case RISCV::FCVT_WU_D:
5142 case RISCV::FCVT_WU_D_IN32X:
5143 case RISCV::FCVT_WU_D_INX:
5144 case RISCV::FCVT_WU_H:
5145 case RISCV::FCVT_WU_H_INX:
5146 case RISCV::FCVT_WU_Q:
5147 case RISCV::FCVT_WU_S:
5148 case RISCV::FCVT_WU_S_INX:
5149 case RISCV::FCVT_W_D:
5150 case RISCV::FCVT_W_D_IN32X:
5151 case RISCV::FCVT_W_D_INX:
5152 case RISCV::FCVT_W_H:
5153 case RISCV::FCVT_W_H_INX:
5154 case RISCV::FCVT_W_Q:
5155 case RISCV::FCVT_W_S:
5156 case RISCV::FCVT_W_S_INX:
5157 case RISCV::FROUNDNX_D:
5158 case RISCV::FROUNDNX_H:
5159 case RISCV::FROUNDNX_Q:
5160 case RISCV::FROUNDNX_S:
5161 case RISCV::FROUND_D:
5162 case RISCV::FROUND_H:
5163 case RISCV::FROUND_Q:
5164 case RISCV::FROUND_S:
5165 case RISCV::FSQRT_D:
5166 case RISCV::FSQRT_D_IN32X:
5167 case RISCV::FSQRT_D_INX:
5168 case RISCV::FSQRT_H:
5169 case RISCV::FSQRT_H_INX:
5170 case RISCV::FSQRT_Q:
5171 case RISCV::FSQRT_S:
5172 case RISCV::FSQRT_S_INX: {
5173 // op: rs1
5174 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5175 Value |= (op & 0x1f) << 15;
5176 // op: frm
5177 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5178 Value |= (op & 0x7) << 12;
5179 // op: rd
5180 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5181 Value |= (op & 0x1f) << 7;
5182 break;
5183 }
5184 case RISCV::PWSLAI_H:
5185 case RISCV::PWSLLI_H: {
5186 // op: rs1
5187 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5188 Value |= (op & 0x1f) << 15;
5189 // op: rd
5190 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5191 Value |= (op & 0x1e) << 7;
5192 // op: shamt
5193 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5194 Value |= (op & 0x1f) << 20;
5195 break;
5196 }
5197 case RISCV::WSLAI:
5198 case RISCV::WSLLI: {
5199 // op: rs1
5200 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5201 Value |= (op & 0x1f) << 15;
5202 // op: rd
5203 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5204 Value |= (op & 0x1e) << 7;
5205 // op: shamt
5206 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5207 Value |= (op & 0x3f) << 20;
5208 break;
5209 }
5210 case RISCV::PWSLAI_B:
5211 case RISCV::PWSLLI_B: {
5212 // op: rs1
5213 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5214 Value |= (op & 0x1f) << 15;
5215 // op: rd
5216 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5217 Value |= (op & 0x1e) << 7;
5218 // op: shamt
5219 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5220 Value |= (op & 0xf) << 20;
5221 break;
5222 }
5223 case RISCV::ABS:
5224 case RISCV::ABSW:
5225 case RISCV::AES64IM:
5226 case RISCV::AIF_FBCX_PS:
5227 case RISCV::AIF_FCLASS_PS:
5228 case RISCV::AIF_FCVT_F10_PS:
5229 case RISCV::AIF_FCVT_F11_PS:
5230 case RISCV::AIF_FCVT_F16_PS:
5231 case RISCV::AIF_FCVT_PS_F10:
5232 case RISCV::AIF_FCVT_PS_F11:
5233 case RISCV::AIF_FCVT_PS_F16:
5234 case RISCV::AIF_FCVT_PS_RAST:
5235 case RISCV::AIF_FCVT_PS_SN16:
5236 case RISCV::AIF_FCVT_PS_SN8:
5237 case RISCV::AIF_FCVT_PS_UN10:
5238 case RISCV::AIF_FCVT_PS_UN16:
5239 case RISCV::AIF_FCVT_PS_UN2:
5240 case RISCV::AIF_FCVT_PS_UN24:
5241 case RISCV::AIF_FCVT_PS_UN8:
5242 case RISCV::AIF_FCVT_RAST_PS:
5243 case RISCV::AIF_FCVT_SN16_PS:
5244 case RISCV::AIF_FCVT_SN8_PS:
5245 case RISCV::AIF_FCVT_UN10_PS:
5246 case RISCV::AIF_FCVT_UN16_PS:
5247 case RISCV::AIF_FCVT_UN24_PS:
5248 case RISCV::AIF_FCVT_UN2_PS:
5249 case RISCV::AIF_FCVT_UN8_PS:
5250 case RISCV::AIF_FEXP_PS:
5251 case RISCV::AIF_FFRC_PS:
5252 case RISCV::AIF_FLOG_PS:
5253 case RISCV::AIF_FLWG_PS:
5254 case RISCV::AIF_FLWL_PS:
5255 case RISCV::AIF_FNOT_PI:
5256 case RISCV::AIF_FPACKREPB_PI:
5257 case RISCV::AIF_FPACKREPH_PI:
5258 case RISCV::AIF_FRCP_PS:
5259 case RISCV::AIF_FRSQ_PS:
5260 case RISCV::AIF_FSAT8_PI:
5261 case RISCV::AIF_FSATU8_PI:
5262 case RISCV::AIF_FSETM_PI:
5263 case RISCV::AIF_FSIN_PS:
5264 case RISCV::AIF_FSQRT_PS:
5265 case RISCV::BREV8:
5266 case RISCV::CLS:
5267 case RISCV::CLSW:
5268 case RISCV::CLZ:
5269 case RISCV::CLZW:
5270 case RISCV::CPOP:
5271 case RISCV::CPOPW:
5272 case RISCV::CTZ:
5273 case RISCV::CTZW:
5274 case RISCV::CV_ABS:
5275 case RISCV::CV_ABS_B:
5276 case RISCV::CV_ABS_H:
5277 case RISCV::CV_CLB:
5278 case RISCV::CV_CNT:
5279 case RISCV::CV_CPLXCONJ:
5280 case RISCV::CV_EXTBS:
5281 case RISCV::CV_EXTBZ:
5282 case RISCV::CV_EXTHS:
5283 case RISCV::CV_EXTHZ:
5284 case RISCV::CV_FF1:
5285 case RISCV::CV_FL1:
5286 case RISCV::FCLASS_D:
5287 case RISCV::FCLASS_D_IN32X:
5288 case RISCV::FCLASS_D_INX:
5289 case RISCV::FCLASS_H:
5290 case RISCV::FCLASS_H_INX:
5291 case RISCV::FCLASS_Q:
5292 case RISCV::FCLASS_S:
5293 case RISCV::FCLASS_S_INX:
5294 case RISCV::FCVTMOD_W_D:
5295 case RISCV::FMVH_X_D:
5296 case RISCV::FMVH_X_Q:
5297 case RISCV::FMV_D_X:
5298 case RISCV::FMV_H_X:
5299 case RISCV::FMV_W_X:
5300 case RISCV::FMV_X_D:
5301 case RISCV::FMV_X_H:
5302 case RISCV::FMV_X_W:
5303 case RISCV::FMV_X_W_FPR64:
5304 case RISCV::HLVX_HU:
5305 case RISCV::HLVX_WU:
5306 case RISCV::HLV_B:
5307 case RISCV::HLV_BU:
5308 case RISCV::HLV_D:
5309 case RISCV::HLV_H:
5310 case RISCV::HLV_HU:
5311 case RISCV::HLV_W:
5312 case RISCV::HLV_WU:
5313 case RISCV::LB_AQ:
5314 case RISCV::LB_AQRL:
5315 case RISCV::LD_AQ:
5316 case RISCV::LD_AQRL:
5317 case RISCV::LH_AQ:
5318 case RISCV::LH_AQRL:
5319 case RISCV::LR_D:
5320 case RISCV::LR_D_AQ:
5321 case RISCV::LR_D_AQRL:
5322 case RISCV::LR_D_RL:
5323 case RISCV::LR_W:
5324 case RISCV::LR_W_AQ:
5325 case RISCV::LR_W_AQRL:
5326 case RISCV::LR_W_RL:
5327 case RISCV::LW_AQ:
5328 case RISCV::LW_AQRL:
5329 case RISCV::MOP_R_0:
5330 case RISCV::MOP_R_1:
5331 case RISCV::MOP_R_10:
5332 case RISCV::MOP_R_11:
5333 case RISCV::MOP_R_12:
5334 case RISCV::MOP_R_13:
5335 case RISCV::MOP_R_14:
5336 case RISCV::MOP_R_15:
5337 case RISCV::MOP_R_16:
5338 case RISCV::MOP_R_17:
5339 case RISCV::MOP_R_18:
5340 case RISCV::MOP_R_19:
5341 case RISCV::MOP_R_2:
5342 case RISCV::MOP_R_20:
5343 case RISCV::MOP_R_21:
5344 case RISCV::MOP_R_22:
5345 case RISCV::MOP_R_23:
5346 case RISCV::MOP_R_24:
5347 case RISCV::MOP_R_25:
5348 case RISCV::MOP_R_26:
5349 case RISCV::MOP_R_27:
5350 case RISCV::MOP_R_28:
5351 case RISCV::MOP_R_29:
5352 case RISCV::MOP_R_3:
5353 case RISCV::MOP_R_30:
5354 case RISCV::MOP_R_31:
5355 case RISCV::MOP_R_4:
5356 case RISCV::MOP_R_5:
5357 case RISCV::MOP_R_6:
5358 case RISCV::MOP_R_7:
5359 case RISCV::MOP_R_8:
5360 case RISCV::MOP_R_9:
5361 case RISCV::NDS_FMV_BF16_X:
5362 case RISCV::NDS_FMV_X_BF16:
5363 case RISCV::ORC_B:
5364 case RISCV::PSABS_B:
5365 case RISCV::PSABS_H:
5366 case RISCV::PSEXT_H_B:
5367 case RISCV::PSEXT_W_B:
5368 case RISCV::PSEXT_W_H:
5369 case RISCV::QC_BREV32:
5370 case RISCV::QC_CLO:
5371 case RISCV::QC_COMPRESS2:
5372 case RISCV::QC_COMPRESS3:
5373 case RISCV::QC_CTO:
5374 case RISCV::QC_EXPAND2:
5375 case RISCV::QC_EXPAND3:
5376 case RISCV::QC_NORM:
5377 case RISCV::QC_NORMEU:
5378 case RISCV::QC_NORMU:
5379 case RISCV::REV16_RV64:
5380 case RISCV::REV8_RV32:
5381 case RISCV::REV8_RV64:
5382 case RISCV::REV_RV32:
5383 case RISCV::REV_RV64:
5384 case RISCV::SEXT_B:
5385 case RISCV::SEXT_H:
5386 case RISCV::SF_VSETTK:
5387 case RISCV::SF_VSETTM:
5388 case RISCV::SF_VSETTN:
5389 case RISCV::SHA256SIG0:
5390 case RISCV::SHA256SIG1:
5391 case RISCV::SHA256SUM0:
5392 case RISCV::SHA256SUM1:
5393 case RISCV::SHA512SIG0:
5394 case RISCV::SHA512SIG1:
5395 case RISCV::SHA512SUM0:
5396 case RISCV::SHA512SUM1:
5397 case RISCV::SM3P0:
5398 case RISCV::SM3P1:
5399 case RISCV::TH_FF0:
5400 case RISCV::TH_FF1:
5401 case RISCV::TH_REV:
5402 case RISCV::TH_REVW:
5403 case RISCV::TH_TSTNBZ:
5404 case RISCV::UNZIP_RV32:
5405 case RISCV::YAMASK:
5406 case RISCV::YBASER:
5407 case RISCV::YLENR:
5408 case RISCV::YMV:
5409 case RISCV::YPERMR:
5410 case RISCV::YTAGR:
5411 case RISCV::YTOPR:
5412 case RISCV::YTYPER:
5413 case RISCV::ZEXT_H_RV32:
5414 case RISCV::ZEXT_H_RV64:
5415 case RISCV::ZIP_RV32: {
5416 // op: rs1
5417 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5418 Value |= (op & 0x1f) << 15;
5419 // op: rd
5420 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5421 Value |= (op & 0x1f) << 7;
5422 break;
5423 }
5424 case RISCV::YBNDSWI: {
5425 // op: rs1
5426 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5427 Value |= (op & 0x1f) << 15;
5428 // op: rd
5429 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5430 Value |= (op & 0x1f) << 7;
5431 // op: imm
5432 op = getYBNDSWImmOpValue(MI, OpNo: 2, Fixups, STI);
5433 Value |= (op & 0x1ff) << 20;
5434 break;
5435 }
5436 case RISCV::QC_WRAPI: {
5437 // op: rs1
5438 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5439 Value |= (op & 0x1f) << 15;
5440 // op: rd
5441 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5442 Value |= (op & 0x1f) << 7;
5443 // op: imm11
5444 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5445 Value |= (op & 0x7ff) << 20;
5446 break;
5447 }
5448 case RISCV::ADDI:
5449 case RISCV::ADDIW:
5450 case RISCV::ANDI:
5451 case RISCV::CV_ELW:
5452 case RISCV::FLD:
5453 case RISCV::FLH:
5454 case RISCV::FLQ:
5455 case RISCV::FLW:
5456 case RISCV::JALR:
5457 case RISCV::LB:
5458 case RISCV::LBU:
5459 case RISCV::LD:
5460 case RISCV::LD_RV32:
5461 case RISCV::LH:
5462 case RISCV::LHU:
5463 case RISCV::LH_INX:
5464 case RISCV::LW:
5465 case RISCV::LWU:
5466 case RISCV::LW_INX:
5467 case RISCV::ORI:
5468 case RISCV::SLTI:
5469 case RISCV::SLTIU:
5470 case RISCV::XORI:
5471 case RISCV::YADDI: {
5472 // op: rs1
5473 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5474 Value |= (op & 0x1f) << 15;
5475 // op: rd
5476 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5477 Value |= (op & 0x1f) << 7;
5478 // op: imm12
5479 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5480 Value |= (op & 0xfff) << 20;
5481 break;
5482 }
5483 case RISCV::QC_INW: {
5484 // op: rs1
5485 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5486 Value |= (op & 0x1f) << 15;
5487 // op: rd
5488 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5489 Value |= (op & 0x1f) << 7;
5490 // op: imm14
5491 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5492 Value |= (op & 0x3ffc) << 18;
5493 break;
5494 }
5495 case RISCV::CV_CLIP:
5496 case RISCV::CV_CLIPU: {
5497 // op: rs1
5498 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5499 Value |= (op & 0x1f) << 15;
5500 // op: rd
5501 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5502 Value |= (op & 0x1f) << 7;
5503 // op: imm5
5504 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5505 Value |= (op & 0x1f) << 20;
5506 break;
5507 }
5508 case RISCV::CV_ADD_SCI_B:
5509 case RISCV::CV_ADD_SCI_H:
5510 case RISCV::CV_AND_SCI_B:
5511 case RISCV::CV_AND_SCI_H:
5512 case RISCV::CV_AVGU_SCI_B:
5513 case RISCV::CV_AVGU_SCI_H:
5514 case RISCV::CV_AVG_SCI_B:
5515 case RISCV::CV_AVG_SCI_H:
5516 case RISCV::CV_CMPEQ_SCI_B:
5517 case RISCV::CV_CMPEQ_SCI_H:
5518 case RISCV::CV_CMPGEU_SCI_B:
5519 case RISCV::CV_CMPGEU_SCI_H:
5520 case RISCV::CV_CMPGE_SCI_B:
5521 case RISCV::CV_CMPGE_SCI_H:
5522 case RISCV::CV_CMPGTU_SCI_B:
5523 case RISCV::CV_CMPGTU_SCI_H:
5524 case RISCV::CV_CMPGT_SCI_B:
5525 case RISCV::CV_CMPGT_SCI_H:
5526 case RISCV::CV_CMPLEU_SCI_B:
5527 case RISCV::CV_CMPLEU_SCI_H:
5528 case RISCV::CV_CMPLE_SCI_B:
5529 case RISCV::CV_CMPLE_SCI_H:
5530 case RISCV::CV_CMPLTU_SCI_B:
5531 case RISCV::CV_CMPLTU_SCI_H:
5532 case RISCV::CV_CMPLT_SCI_B:
5533 case RISCV::CV_CMPLT_SCI_H:
5534 case RISCV::CV_CMPNE_SCI_B:
5535 case RISCV::CV_CMPNE_SCI_H:
5536 case RISCV::CV_DOTSP_SCI_B:
5537 case RISCV::CV_DOTSP_SCI_H:
5538 case RISCV::CV_DOTUP_SCI_B:
5539 case RISCV::CV_DOTUP_SCI_H:
5540 case RISCV::CV_DOTUSP_SCI_B:
5541 case RISCV::CV_DOTUSP_SCI_H:
5542 case RISCV::CV_EXTRACTU_B:
5543 case RISCV::CV_EXTRACTU_H:
5544 case RISCV::CV_EXTRACT_B:
5545 case RISCV::CV_EXTRACT_H:
5546 case RISCV::CV_MAXU_SCI_B:
5547 case RISCV::CV_MAXU_SCI_H:
5548 case RISCV::CV_MAX_SCI_B:
5549 case RISCV::CV_MAX_SCI_H:
5550 case RISCV::CV_MINU_SCI_B:
5551 case RISCV::CV_MINU_SCI_H:
5552 case RISCV::CV_MIN_SCI_B:
5553 case RISCV::CV_MIN_SCI_H:
5554 case RISCV::CV_OR_SCI_B:
5555 case RISCV::CV_OR_SCI_H:
5556 case RISCV::CV_SHUFFLEI0_SCI_B:
5557 case RISCV::CV_SHUFFLEI1_SCI_B:
5558 case RISCV::CV_SHUFFLEI2_SCI_B:
5559 case RISCV::CV_SHUFFLEI3_SCI_B:
5560 case RISCV::CV_SHUFFLE_SCI_H:
5561 case RISCV::CV_SLL_SCI_B:
5562 case RISCV::CV_SLL_SCI_H:
5563 case RISCV::CV_SRA_SCI_B:
5564 case RISCV::CV_SRA_SCI_H:
5565 case RISCV::CV_SRL_SCI_B:
5566 case RISCV::CV_SRL_SCI_H:
5567 case RISCV::CV_SUB_SCI_B:
5568 case RISCV::CV_SUB_SCI_H:
5569 case RISCV::CV_XOR_SCI_B:
5570 case RISCV::CV_XOR_SCI_H: {
5571 // op: rs1
5572 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5573 Value |= (op & 0x1f) << 15;
5574 // op: rd
5575 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5576 Value |= (op & 0x1f) << 7;
5577 // op: imm6
5578 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5579 Value |= (op & 0x1) << 25;
5580 Value |= (op & 0x3e) << 19;
5581 break;
5582 }
5583 case RISCV::CV_BCLR:
5584 case RISCV::CV_BITREV:
5585 case RISCV::CV_BSET:
5586 case RISCV::CV_EXTRACT:
5587 case RISCV::CV_EXTRACTU: {
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: is3
5595 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5596 Value |= (op & 0x1f) << 25;
5597 // op: is2
5598 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
5599 Value |= (op & 0x1f) << 20;
5600 break;
5601 }
5602 case RISCV::TH_EXT:
5603 case RISCV::TH_EXTU: {
5604 // op: rs1
5605 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5606 Value |= (op & 0x1f) << 15;
5607 // op: rd
5608 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5609 Value |= (op & 0x1f) << 7;
5610 // op: msb
5611 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5612 Value |= (op & 0x3f) << 26;
5613 // op: lsb
5614 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
5615 Value |= (op & 0x3f) << 20;
5616 break;
5617 }
5618 case RISCV::AES64KS1I: {
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: rnum
5626 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5627 Value |= (op & 0xf) << 20;
5628 break;
5629 }
5630 case RISCV::PSLLI_W:
5631 case RISCV::PSRAI_W:
5632 case RISCV::PSRARI_W:
5633 case RISCV::PSRLI_W:
5634 case RISCV::PSSLAI_W:
5635 case RISCV::PUSATI_W:
5636 case RISCV::RORIW:
5637 case RISCV::SLLIW:
5638 case RISCV::SRAIW:
5639 case RISCV::SRARI_RV32:
5640 case RISCV::SRLIW:
5641 case RISCV::SSLAI:
5642 case RISCV::TH_SRRIW:
5643 case RISCV::USATI_RV32: {
5644 // op: rs1
5645 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5646 Value |= (op & 0x1f) << 15;
5647 // op: rd
5648 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5649 Value |= (op & 0x1f) << 7;
5650 // op: shamt
5651 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5652 Value |= (op & 0x1f) << 20;
5653 break;
5654 }
5655 case RISCV::SRARI_RV64:
5656 case RISCV::USATI_RV64: {
5657 // op: rs1
5658 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5659 Value |= (op & 0x1f) << 15;
5660 // op: rd
5661 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5662 Value |= (op & 0x1f) << 7;
5663 // op: shamt
5664 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5665 Value |= (op & 0x3f) << 20;
5666 break;
5667 }
5668 case RISCV::PSLLI_B:
5669 case RISCV::PSRAI_B:
5670 case RISCV::PSRLI_B: {
5671 // op: rs1
5672 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5673 Value |= (op & 0x1f) << 15;
5674 // op: rd
5675 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5676 Value |= (op & 0x1f) << 7;
5677 // op: shamt
5678 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5679 Value |= (op & 0x7) << 20;
5680 break;
5681 }
5682 case RISCV::SRLIY: {
5683 // op: rs1
5684 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5685 Value |= (op & 0x1f) << 15;
5686 // op: rd
5687 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5688 Value |= (op & 0x1f) << 7;
5689 // op: shamt
5690 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5691 Value |= (op & 0x7f) << 20;
5692 break;
5693 }
5694 case RISCV::PSLLI_H:
5695 case RISCV::PSRAI_H:
5696 case RISCV::PSRARI_H:
5697 case RISCV::PSRLI_H:
5698 case RISCV::PSSLAI_H:
5699 case RISCV::PUSATI_H: {
5700 // op: rs1
5701 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5702 Value |= (op & 0x1f) << 15;
5703 // op: rd
5704 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5705 Value |= (op & 0x1f) << 7;
5706 // op: shamt
5707 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5708 Value |= (op & 0xf) << 20;
5709 break;
5710 }
5711 case RISCV::QC_EXT:
5712 case RISCV::QC_EXTD:
5713 case RISCV::QC_EXTDU:
5714 case RISCV::QC_EXTU: {
5715 // op: rs1
5716 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5717 Value |= (op & 0x1f) << 15;
5718 // op: rd
5719 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5720 Value |= (op & 0x1f) << 7;
5721 // op: shamt
5722 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
5723 Value |= (op & 0x1f) << 20;
5724 // op: width
5725 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5726 Value |= (op & 0x1f) << 25;
5727 break;
5728 }
5729 case RISCV::PSATI_W:
5730 case RISCV::SATI_RV32: {
5731 // op: rs1
5732 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5733 Value |= (op & 0x1f) << 15;
5734 // op: rd
5735 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5736 Value |= (op & 0x1f) << 7;
5737 // op: shamt
5738 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5739 Value |= (op & 0x1f) << 20;
5740 break;
5741 }
5742 case RISCV::SATI_RV64: {
5743 // op: rs1
5744 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5745 Value |= (op & 0x1f) << 15;
5746 // op: rd
5747 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5748 Value |= (op & 0x1f) << 7;
5749 // op: shamt
5750 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5751 Value |= (op & 0x3f) << 20;
5752 break;
5753 }
5754 case RISCV::PSATI_H: {
5755 // op: rs1
5756 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5757 Value |= (op & 0x1f) << 15;
5758 // op: rd
5759 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5760 Value |= (op & 0x1f) << 7;
5761 // op: shamt
5762 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5763 Value |= (op & 0xf) << 20;
5764 break;
5765 }
5766 case RISCV::BCLRI:
5767 case RISCV::BEXTI:
5768 case RISCV::BINVI:
5769 case RISCV::BSETI:
5770 case RISCV::RORI:
5771 case RISCV::SLLI:
5772 case RISCV::SLLI_UW:
5773 case RISCV::SRAI:
5774 case RISCV::SRLI:
5775 case RISCV::TH_SRRI:
5776 case RISCV::TH_TST: {
5777 // op: rs1
5778 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5779 Value |= (op & 0x1f) << 15;
5780 // op: rd
5781 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5782 Value |= (op & 0x1f) << 7;
5783 // op: shamt
5784 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5785 Value |= (op & 0x3f) << 20;
5786 break;
5787 }
5788 case RISCV::VSETVLI: {
5789 // op: rs1
5790 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5791 Value |= (op & 0x1f) << 15;
5792 // op: rd
5793 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5794 Value |= (op & 0x1f) << 7;
5795 // op: vtypei
5796 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5797 Value |= (op & 0x7ff) << 20;
5798 break;
5799 }
5800 case RISCV::AIF_FROUND_PS: {
5801 // op: rs1
5802 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5803 Value |= (op & 0x1f) << 15;
5804 // op: rm
5805 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5806 Value |= (op & 0x7) << 12;
5807 // op: rd
5808 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5809 Value |= (op & 0x1f) << 7;
5810 break;
5811 }
5812 case RISCV::QC_E_SB:
5813 case RISCV::QC_E_SH:
5814 case RISCV::QC_E_SW: {
5815 // op: rs1
5816 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5817 Value |= (op & 0x1f) << 15;
5818 // op: rs2
5819 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5820 Value |= (op & 0x1f) << 20;
5821 // op: imm
5822 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5823 Value |= (op & 0x3fffc00) << 22;
5824 Value |= (op & 0x3e0) << 20;
5825 Value |= (op & 0x1f) << 7;
5826 break;
5827 }
5828 case RISCV::CV_SB_rr:
5829 case RISCV::CV_SH_rr:
5830 case RISCV::CV_SW_rr: {
5831 // op: rs1
5832 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5833 Value |= (op & 0x1f) << 15;
5834 // op: rs2
5835 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5836 Value |= (op & 0x1f) << 20;
5837 // op: rs3
5838 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5839 Value |= (op & 0x1f) << 7;
5840 break;
5841 }
5842 case RISCV::QC_OUTW: {
5843 // op: rs1
5844 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5845 Value |= (op & 0x1f) << 15;
5846 // op: rs2
5847 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5848 Value |= (op & 0x1f) << 7;
5849 // op: imm14
5850 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5851 Value |= (op & 0x3ffc) << 18;
5852 break;
5853 }
5854 case RISCV::AIF_FSC32B_PS:
5855 case RISCV::AIF_FSC32H_PS:
5856 case RISCV::AIF_FSC32W_PS:
5857 case RISCV::AIF_FSCBG_PS:
5858 case RISCV::AIF_FSCBL_PS:
5859 case RISCV::AIF_FSCB_PS:
5860 case RISCV::AIF_FSCHG_PS:
5861 case RISCV::AIF_FSCHL_PS:
5862 case RISCV::AIF_FSCH_PS:
5863 case RISCV::AIF_FSCWG_PS:
5864 case RISCV::AIF_FSCWL_PS:
5865 case RISCV::AIF_FSCW_PS: {
5866 // op: rs1
5867 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5868 Value |= (op & 0x1f) << 15;
5869 // op: rs2
5870 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5871 Value |= (op & 0x1f) << 20;
5872 // op: rs3
5873 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5874 Value |= (op & 0x1f) << 7;
5875 break;
5876 }
5877 case RISCV::NDS_VLE4_V:
5878 case RISCV::SF_VTMV_V_T:
5879 case RISCV::VL1RE16_V:
5880 case RISCV::VL1RE32_V:
5881 case RISCV::VL1RE64_V:
5882 case RISCV::VL1RE8_V:
5883 case RISCV::VL2RE16_V:
5884 case RISCV::VL2RE32_V:
5885 case RISCV::VL2RE64_V:
5886 case RISCV::VL2RE8_V:
5887 case RISCV::VL4RE16_V:
5888 case RISCV::VL4RE32_V:
5889 case RISCV::VL4RE64_V:
5890 case RISCV::VL4RE8_V:
5891 case RISCV::VL8RE16_V:
5892 case RISCV::VL8RE32_V:
5893 case RISCV::VL8RE64_V:
5894 case RISCV::VL8RE8_V:
5895 case RISCV::VLM_V: {
5896 // op: rs1
5897 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5898 Value |= (op & 0x1f) << 15;
5899 // op: vd
5900 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5901 Value |= (op & 0x1f) << 7;
5902 break;
5903 }
5904 case RISCV::NDS_VLN8_V:
5905 case RISCV::NDS_VLNU8_V:
5906 case RISCV::VLE16FF_V:
5907 case RISCV::VLE16_V:
5908 case RISCV::VLE32FF_V:
5909 case RISCV::VLE32_V:
5910 case RISCV::VLE64FF_V:
5911 case RISCV::VLE64_V:
5912 case RISCV::VLE8FF_V:
5913 case RISCV::VLE8_V:
5914 case RISCV::VLSEG2E16FF_V:
5915 case RISCV::VLSEG2E16_V:
5916 case RISCV::VLSEG2E32FF_V:
5917 case RISCV::VLSEG2E32_V:
5918 case RISCV::VLSEG2E64FF_V:
5919 case RISCV::VLSEG2E64_V:
5920 case RISCV::VLSEG2E8FF_V:
5921 case RISCV::VLSEG2E8_V:
5922 case RISCV::VLSEG3E16FF_V:
5923 case RISCV::VLSEG3E16_V:
5924 case RISCV::VLSEG3E32FF_V:
5925 case RISCV::VLSEG3E32_V:
5926 case RISCV::VLSEG3E64FF_V:
5927 case RISCV::VLSEG3E64_V:
5928 case RISCV::VLSEG3E8FF_V:
5929 case RISCV::VLSEG3E8_V:
5930 case RISCV::VLSEG4E16FF_V:
5931 case RISCV::VLSEG4E16_V:
5932 case RISCV::VLSEG4E32FF_V:
5933 case RISCV::VLSEG4E32_V:
5934 case RISCV::VLSEG4E64FF_V:
5935 case RISCV::VLSEG4E64_V:
5936 case RISCV::VLSEG4E8FF_V:
5937 case RISCV::VLSEG4E8_V:
5938 case RISCV::VLSEG5E16FF_V:
5939 case RISCV::VLSEG5E16_V:
5940 case RISCV::VLSEG5E32FF_V:
5941 case RISCV::VLSEG5E32_V:
5942 case RISCV::VLSEG5E64FF_V:
5943 case RISCV::VLSEG5E64_V:
5944 case RISCV::VLSEG5E8FF_V:
5945 case RISCV::VLSEG5E8_V:
5946 case RISCV::VLSEG6E16FF_V:
5947 case RISCV::VLSEG6E16_V:
5948 case RISCV::VLSEG6E32FF_V:
5949 case RISCV::VLSEG6E32_V:
5950 case RISCV::VLSEG6E64FF_V:
5951 case RISCV::VLSEG6E64_V:
5952 case RISCV::VLSEG6E8FF_V:
5953 case RISCV::VLSEG6E8_V:
5954 case RISCV::VLSEG7E16FF_V:
5955 case RISCV::VLSEG7E16_V:
5956 case RISCV::VLSEG7E32FF_V:
5957 case RISCV::VLSEG7E32_V:
5958 case RISCV::VLSEG7E64FF_V:
5959 case RISCV::VLSEG7E64_V:
5960 case RISCV::VLSEG7E8FF_V:
5961 case RISCV::VLSEG7E8_V:
5962 case RISCV::VLSEG8E16FF_V:
5963 case RISCV::VLSEG8E16_V:
5964 case RISCV::VLSEG8E32FF_V:
5965 case RISCV::VLSEG8E32_V:
5966 case RISCV::VLSEG8E64FF_V:
5967 case RISCV::VLSEG8E64_V:
5968 case RISCV::VLSEG8E8FF_V:
5969 case RISCV::VLSEG8E8_V: {
5970 // op: rs1
5971 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5972 Value |= (op & 0x1f) << 15;
5973 // op: vd
5974 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5975 Value |= (op & 0x1f) << 7;
5976 // op: vm
5977 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
5978 Value |= (op & 0x1) << 25;
5979 break;
5980 }
5981 case RISCV::VLSE16_V:
5982 case RISCV::VLSE32_V:
5983 case RISCV::VLSE64_V:
5984 case RISCV::VLSE8_V:
5985 case RISCV::VLSSEG2E16_V:
5986 case RISCV::VLSSEG2E32_V:
5987 case RISCV::VLSSEG2E64_V:
5988 case RISCV::VLSSEG2E8_V:
5989 case RISCV::VLSSEG3E16_V:
5990 case RISCV::VLSSEG3E32_V:
5991 case RISCV::VLSSEG3E64_V:
5992 case RISCV::VLSSEG3E8_V:
5993 case RISCV::VLSSEG4E16_V:
5994 case RISCV::VLSSEG4E32_V:
5995 case RISCV::VLSSEG4E64_V:
5996 case RISCV::VLSSEG4E8_V:
5997 case RISCV::VLSSEG5E16_V:
5998 case RISCV::VLSSEG5E32_V:
5999 case RISCV::VLSSEG5E64_V:
6000 case RISCV::VLSSEG5E8_V:
6001 case RISCV::VLSSEG6E16_V:
6002 case RISCV::VLSSEG6E32_V:
6003 case RISCV::VLSSEG6E64_V:
6004 case RISCV::VLSSEG6E8_V:
6005 case RISCV::VLSSEG7E16_V:
6006 case RISCV::VLSSEG7E32_V:
6007 case RISCV::VLSSEG7E64_V:
6008 case RISCV::VLSSEG7E8_V:
6009 case RISCV::VLSSEG8E16_V:
6010 case RISCV::VLSSEG8E32_V:
6011 case RISCV::VLSSEG8E64_V:
6012 case RISCV::VLSSEG8E8_V: {
6013 // op: rs1
6014 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6015 Value |= (op & 0x1f) << 15;
6016 // op: vd
6017 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6018 Value |= (op & 0x1f) << 7;
6019 // op: vm
6020 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6021 Value |= (op & 0x1) << 25;
6022 // op: rs2
6023 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6024 Value |= (op & 0x1f) << 20;
6025 break;
6026 }
6027 case RISCV::VLOXEI16_V:
6028 case RISCV::VLOXEI32_V:
6029 case RISCV::VLOXEI64_V:
6030 case RISCV::VLOXEI8_V:
6031 case RISCV::VLOXSEG2EI16_V:
6032 case RISCV::VLOXSEG2EI32_V:
6033 case RISCV::VLOXSEG2EI64_V:
6034 case RISCV::VLOXSEG2EI8_V:
6035 case RISCV::VLOXSEG3EI16_V:
6036 case RISCV::VLOXSEG3EI32_V:
6037 case RISCV::VLOXSEG3EI64_V:
6038 case RISCV::VLOXSEG3EI8_V:
6039 case RISCV::VLOXSEG4EI16_V:
6040 case RISCV::VLOXSEG4EI32_V:
6041 case RISCV::VLOXSEG4EI64_V:
6042 case RISCV::VLOXSEG4EI8_V:
6043 case RISCV::VLOXSEG5EI16_V:
6044 case RISCV::VLOXSEG5EI32_V:
6045 case RISCV::VLOXSEG5EI64_V:
6046 case RISCV::VLOXSEG5EI8_V:
6047 case RISCV::VLOXSEG6EI16_V:
6048 case RISCV::VLOXSEG6EI32_V:
6049 case RISCV::VLOXSEG6EI64_V:
6050 case RISCV::VLOXSEG6EI8_V:
6051 case RISCV::VLOXSEG7EI16_V:
6052 case RISCV::VLOXSEG7EI32_V:
6053 case RISCV::VLOXSEG7EI64_V:
6054 case RISCV::VLOXSEG7EI8_V:
6055 case RISCV::VLOXSEG8EI16_V:
6056 case RISCV::VLOXSEG8EI32_V:
6057 case RISCV::VLOXSEG8EI64_V:
6058 case RISCV::VLOXSEG8EI8_V:
6059 case RISCV::VLUXEI16_V:
6060 case RISCV::VLUXEI32_V:
6061 case RISCV::VLUXEI64_V:
6062 case RISCV::VLUXEI8_V:
6063 case RISCV::VLUXSEG2EI16_V:
6064 case RISCV::VLUXSEG2EI32_V:
6065 case RISCV::VLUXSEG2EI64_V:
6066 case RISCV::VLUXSEG2EI8_V:
6067 case RISCV::VLUXSEG3EI16_V:
6068 case RISCV::VLUXSEG3EI32_V:
6069 case RISCV::VLUXSEG3EI64_V:
6070 case RISCV::VLUXSEG3EI8_V:
6071 case RISCV::VLUXSEG4EI16_V:
6072 case RISCV::VLUXSEG4EI32_V:
6073 case RISCV::VLUXSEG4EI64_V:
6074 case RISCV::VLUXSEG4EI8_V:
6075 case RISCV::VLUXSEG5EI16_V:
6076 case RISCV::VLUXSEG5EI32_V:
6077 case RISCV::VLUXSEG5EI64_V:
6078 case RISCV::VLUXSEG5EI8_V:
6079 case RISCV::VLUXSEG6EI16_V:
6080 case RISCV::VLUXSEG6EI32_V:
6081 case RISCV::VLUXSEG6EI64_V:
6082 case RISCV::VLUXSEG6EI8_V:
6083 case RISCV::VLUXSEG7EI16_V:
6084 case RISCV::VLUXSEG7EI32_V:
6085 case RISCV::VLUXSEG7EI64_V:
6086 case RISCV::VLUXSEG7EI8_V:
6087 case RISCV::VLUXSEG8EI16_V:
6088 case RISCV::VLUXSEG8EI32_V:
6089 case RISCV::VLUXSEG8EI64_V:
6090 case RISCV::VLUXSEG8EI8_V: {
6091 // op: rs1
6092 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6093 Value |= (op & 0x1f) << 15;
6094 // op: vd
6095 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6096 Value |= (op & 0x1f) << 7;
6097 // op: vm
6098 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6099 Value |= (op & 0x1) << 25;
6100 // op: vs2
6101 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6102 Value |= (op & 0x1f) << 20;
6103 break;
6104 }
6105 case RISCV::VS1R_V:
6106 case RISCV::VS2R_V:
6107 case RISCV::VS4R_V:
6108 case RISCV::VS8R_V:
6109 case RISCV::VSM_V: {
6110 // op: rs1
6111 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6112 Value |= (op & 0x1f) << 15;
6113 // op: vs3
6114 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6115 Value |= (op & 0x1f) << 7;
6116 break;
6117 }
6118 case RISCV::VSE16_V:
6119 case RISCV::VSE32_V:
6120 case RISCV::VSE64_V:
6121 case RISCV::VSE8_V:
6122 case RISCV::VSSEG2E16_V:
6123 case RISCV::VSSEG2E32_V:
6124 case RISCV::VSSEG2E64_V:
6125 case RISCV::VSSEG2E8_V:
6126 case RISCV::VSSEG3E16_V:
6127 case RISCV::VSSEG3E32_V:
6128 case RISCV::VSSEG3E64_V:
6129 case RISCV::VSSEG3E8_V:
6130 case RISCV::VSSEG4E16_V:
6131 case RISCV::VSSEG4E32_V:
6132 case RISCV::VSSEG4E64_V:
6133 case RISCV::VSSEG4E8_V:
6134 case RISCV::VSSEG5E16_V:
6135 case RISCV::VSSEG5E32_V:
6136 case RISCV::VSSEG5E64_V:
6137 case RISCV::VSSEG5E8_V:
6138 case RISCV::VSSEG6E16_V:
6139 case RISCV::VSSEG6E32_V:
6140 case RISCV::VSSEG6E64_V:
6141 case RISCV::VSSEG6E8_V:
6142 case RISCV::VSSEG7E16_V:
6143 case RISCV::VSSEG7E32_V:
6144 case RISCV::VSSEG7E64_V:
6145 case RISCV::VSSEG7E8_V:
6146 case RISCV::VSSEG8E16_V:
6147 case RISCV::VSSEG8E32_V:
6148 case RISCV::VSSEG8E64_V:
6149 case RISCV::VSSEG8E8_V: {
6150 // op: rs1
6151 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6152 Value |= (op & 0x1f) << 15;
6153 // op: vs3
6154 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6155 Value |= (op & 0x1f) << 7;
6156 // op: vm
6157 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
6158 Value |= (op & 0x1) << 25;
6159 break;
6160 }
6161 case RISCV::VSSE16_V:
6162 case RISCV::VSSE32_V:
6163 case RISCV::VSSE64_V:
6164 case RISCV::VSSE8_V:
6165 case RISCV::VSSSEG2E16_V:
6166 case RISCV::VSSSEG2E32_V:
6167 case RISCV::VSSSEG2E64_V:
6168 case RISCV::VSSSEG2E8_V:
6169 case RISCV::VSSSEG3E16_V:
6170 case RISCV::VSSSEG3E32_V:
6171 case RISCV::VSSSEG3E64_V:
6172 case RISCV::VSSSEG3E8_V:
6173 case RISCV::VSSSEG4E16_V:
6174 case RISCV::VSSSEG4E32_V:
6175 case RISCV::VSSSEG4E64_V:
6176 case RISCV::VSSSEG4E8_V:
6177 case RISCV::VSSSEG5E16_V:
6178 case RISCV::VSSSEG5E32_V:
6179 case RISCV::VSSSEG5E64_V:
6180 case RISCV::VSSSEG5E8_V:
6181 case RISCV::VSSSEG6E16_V:
6182 case RISCV::VSSSEG6E32_V:
6183 case RISCV::VSSSEG6E64_V:
6184 case RISCV::VSSSEG6E8_V:
6185 case RISCV::VSSSEG7E16_V:
6186 case RISCV::VSSSEG7E32_V:
6187 case RISCV::VSSSEG7E64_V:
6188 case RISCV::VSSSEG7E8_V:
6189 case RISCV::VSSSEG8E16_V:
6190 case RISCV::VSSSEG8E32_V:
6191 case RISCV::VSSSEG8E64_V:
6192 case RISCV::VSSSEG8E8_V: {
6193 // op: rs1
6194 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6195 Value |= (op & 0x1f) << 15;
6196 // op: vs3
6197 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6198 Value |= (op & 0x1f) << 7;
6199 // op: vm
6200 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6201 Value |= (op & 0x1) << 25;
6202 // op: rs2
6203 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6204 Value |= (op & 0x1f) << 20;
6205 break;
6206 }
6207 case RISCV::VSOXEI16_V:
6208 case RISCV::VSOXEI32_V:
6209 case RISCV::VSOXEI64_V:
6210 case RISCV::VSOXEI8_V:
6211 case RISCV::VSOXSEG2EI16_V:
6212 case RISCV::VSOXSEG2EI32_V:
6213 case RISCV::VSOXSEG2EI64_V:
6214 case RISCV::VSOXSEG2EI8_V:
6215 case RISCV::VSOXSEG3EI16_V:
6216 case RISCV::VSOXSEG3EI32_V:
6217 case RISCV::VSOXSEG3EI64_V:
6218 case RISCV::VSOXSEG3EI8_V:
6219 case RISCV::VSOXSEG4EI16_V:
6220 case RISCV::VSOXSEG4EI32_V:
6221 case RISCV::VSOXSEG4EI64_V:
6222 case RISCV::VSOXSEG4EI8_V:
6223 case RISCV::VSOXSEG5EI16_V:
6224 case RISCV::VSOXSEG5EI32_V:
6225 case RISCV::VSOXSEG5EI64_V:
6226 case RISCV::VSOXSEG5EI8_V:
6227 case RISCV::VSOXSEG6EI16_V:
6228 case RISCV::VSOXSEG6EI32_V:
6229 case RISCV::VSOXSEG6EI64_V:
6230 case RISCV::VSOXSEG6EI8_V:
6231 case RISCV::VSOXSEG7EI16_V:
6232 case RISCV::VSOXSEG7EI32_V:
6233 case RISCV::VSOXSEG7EI64_V:
6234 case RISCV::VSOXSEG7EI8_V:
6235 case RISCV::VSOXSEG8EI16_V:
6236 case RISCV::VSOXSEG8EI32_V:
6237 case RISCV::VSOXSEG8EI64_V:
6238 case RISCV::VSOXSEG8EI8_V:
6239 case RISCV::VSUXEI16_V:
6240 case RISCV::VSUXEI32_V:
6241 case RISCV::VSUXEI64_V:
6242 case RISCV::VSUXEI8_V:
6243 case RISCV::VSUXSEG2EI16_V:
6244 case RISCV::VSUXSEG2EI32_V:
6245 case RISCV::VSUXSEG2EI64_V:
6246 case RISCV::VSUXSEG2EI8_V:
6247 case RISCV::VSUXSEG3EI16_V:
6248 case RISCV::VSUXSEG3EI32_V:
6249 case RISCV::VSUXSEG3EI64_V:
6250 case RISCV::VSUXSEG3EI8_V:
6251 case RISCV::VSUXSEG4EI16_V:
6252 case RISCV::VSUXSEG4EI32_V:
6253 case RISCV::VSUXSEG4EI64_V:
6254 case RISCV::VSUXSEG4EI8_V:
6255 case RISCV::VSUXSEG5EI16_V:
6256 case RISCV::VSUXSEG5EI32_V:
6257 case RISCV::VSUXSEG5EI64_V:
6258 case RISCV::VSUXSEG5EI8_V:
6259 case RISCV::VSUXSEG6EI16_V:
6260 case RISCV::VSUXSEG6EI32_V:
6261 case RISCV::VSUXSEG6EI64_V:
6262 case RISCV::VSUXSEG6EI8_V:
6263 case RISCV::VSUXSEG7EI16_V:
6264 case RISCV::VSUXSEG7EI32_V:
6265 case RISCV::VSUXSEG7EI64_V:
6266 case RISCV::VSUXSEG7EI8_V:
6267 case RISCV::VSUXSEG8EI16_V:
6268 case RISCV::VSUXSEG8EI32_V:
6269 case RISCV::VSUXSEG8EI64_V:
6270 case RISCV::VSUXSEG8EI8_V: {
6271 // op: rs1
6272 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6273 Value |= (op & 0x1f) << 15;
6274 // op: vs3
6275 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6276 Value |= (op & 0x1f) << 7;
6277 // op: vm
6278 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6279 Value |= (op & 0x1) << 25;
6280 // op: vs2
6281 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6282 Value |= (op & 0x1f) << 20;
6283 break;
6284 }
6285 case RISCV::C_ADD: {
6286 // op: rs1
6287 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6288 Value |= (op & 0x1f) << 7;
6289 // op: rs2
6290 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6291 Value |= (op & 0x1f) << 2;
6292 break;
6293 }
6294 case RISCV::AIF_MASKPOPC:
6295 case RISCV::AIF_MASKPOPCZ: {
6296 // op: rs1
6297 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6298 Value |= (op & 0x7) << 15;
6299 // op: rd
6300 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6301 Value |= (op & 0x1f) << 7;
6302 break;
6303 }
6304 case RISCV::AIF_MASKNOT: {
6305 // op: rs1
6306 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6307 Value |= (op & 0x7) << 15;
6308 // op: rd
6309 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6310 Value |= (op & 0x7) << 7;
6311 break;
6312 }
6313 case RISCV::QC_C_BEXTI:
6314 case RISCV::QC_C_BSETI: {
6315 // op: rs1
6316 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6317 Value |= (op & 0x7) << 7;
6318 // op: shamt
6319 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6320 Value |= (op & 0x1f) << 2;
6321 break;
6322 }
6323 case RISCV::AIF_FBC_PS:
6324 case RISCV::AIF_FLQ2:
6325 case RISCV::AIF_FLW_PS: {
6326 // op: rs1
6327 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6328 Value |= (op & 0x1f) << 15;
6329 // op: rd
6330 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6331 Value |= (op & 0x1f) << 7;
6332 // op: imm12
6333 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6334 Value |= (op & 0xfff) << 20;
6335 break;
6336 }
6337 case RISCV::CV_LBU_ri_inc:
6338 case RISCV::CV_LB_ri_inc:
6339 case RISCV::CV_LHU_ri_inc:
6340 case RISCV::CV_LH_ri_inc:
6341 case RISCV::CV_LW_ri_inc: {
6342 // op: rs1
6343 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6344 Value |= (op & 0x1f) << 15;
6345 // op: rd
6346 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6347 Value |= (op & 0x1f) << 7;
6348 // op: imm12
6349 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6350 Value |= (op & 0xfff) << 20;
6351 break;
6352 }
6353 case RISCV::CSRRC:
6354 case RISCV::CSRRS:
6355 case RISCV::CSRRW: {
6356 // op: rs1
6357 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6358 Value |= (op & 0x1f) << 15;
6359 // op: rd
6360 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6361 Value |= (op & 0x1f) << 7;
6362 // op: imm12
6363 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6364 Value |= (op & 0xfff) << 20;
6365 break;
6366 }
6367 case RISCV::TH_LBIA:
6368 case RISCV::TH_LBIB:
6369 case RISCV::TH_LBUIA:
6370 case RISCV::TH_LBUIB:
6371 case RISCV::TH_LDIA:
6372 case RISCV::TH_LDIB:
6373 case RISCV::TH_LHIA:
6374 case RISCV::TH_LHIB:
6375 case RISCV::TH_LHUIA:
6376 case RISCV::TH_LHUIB:
6377 case RISCV::TH_LWIA:
6378 case RISCV::TH_LWIB:
6379 case RISCV::TH_LWUIA:
6380 case RISCV::TH_LWUIB: {
6381 // op: rs1
6382 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6383 Value |= (op & 0x1f) << 15;
6384 // op: rd
6385 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6386 Value |= (op & 0x1f) << 7;
6387 // op: simm5
6388 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6389 Value |= (op & 0x1f) << 20;
6390 // op: uimm2
6391 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6392 Value |= (op & 0x3) << 25;
6393 break;
6394 }
6395 case RISCV::QC_INSBRI: {
6396 // op: rs1
6397 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6398 Value |= (op & 0x1f) << 15;
6399 // op: rd
6400 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6401 Value |= (op & 0x1f) << 7;
6402 // op: imm11
6403 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6404 Value |= (op & 0x7ff) << 20;
6405 break;
6406 }
6407 case RISCV::QC_MULIADD: {
6408 // op: rs1
6409 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6410 Value |= (op & 0x1f) << 15;
6411 // op: rd
6412 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6413 Value |= (op & 0x1f) << 7;
6414 // op: imm12
6415 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6416 Value |= (op & 0xfff) << 20;
6417 break;
6418 }
6419 case RISCV::CV_INSERT_B:
6420 case RISCV::CV_INSERT_H:
6421 case RISCV::CV_SDOTSP_SCI_B:
6422 case RISCV::CV_SDOTSP_SCI_H:
6423 case RISCV::CV_SDOTUP_SCI_B:
6424 case RISCV::CV_SDOTUP_SCI_H:
6425 case RISCV::CV_SDOTUSP_SCI_B:
6426 case RISCV::CV_SDOTUSP_SCI_H: {
6427 // op: rs1
6428 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6429 Value |= (op & 0x1f) << 15;
6430 // op: rd
6431 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6432 Value |= (op & 0x1f) << 7;
6433 // op: imm6
6434 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6435 Value |= (op & 0x1) << 25;
6436 Value |= (op & 0x3e) << 19;
6437 break;
6438 }
6439 case RISCV::CV_INSERT: {
6440 // op: rs1
6441 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6442 Value |= (op & 0x1f) << 15;
6443 // op: rd
6444 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6445 Value |= (op & 0x1f) << 7;
6446 // op: is3
6447 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6448 Value |= (op & 0x1f) << 25;
6449 // op: is2
6450 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6451 Value |= (op & 0x1f) << 20;
6452 break;
6453 }
6454 case RISCV::QC_INSB:
6455 case RISCV::QC_INSBH: {
6456 // op: rs1
6457 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6458 Value |= (op & 0x1f) << 15;
6459 // op: rd
6460 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6461 Value |= (op & 0x1f) << 7;
6462 // op: shamt
6463 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6464 Value |= (op & 0x1f) << 20;
6465 // op: width
6466 op = getImmOpValueMinus1(MI, OpNo: 3, Fixups, STI);
6467 Value |= (op & 0x1f) << 25;
6468 break;
6469 }
6470 case RISCV::QC_SELECTIIEQ:
6471 case RISCV::QC_SELECTIINE: {
6472 // op: rs1
6473 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6474 Value |= (op & 0x1f) << 15;
6475 // op: rd
6476 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6477 Value |= (op & 0x1f) << 7;
6478 // op: simm1
6479 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6480 Value |= (op & 0x1f) << 20;
6481 // op: simm2
6482 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6483 Value |= (op & 0x1f) << 27;
6484 break;
6485 }
6486 case RISCV::TH_SBIA:
6487 case RISCV::TH_SBIB:
6488 case RISCV::TH_SDIA:
6489 case RISCV::TH_SDIB:
6490 case RISCV::TH_SHIA:
6491 case RISCV::TH_SHIB:
6492 case RISCV::TH_SWIA:
6493 case RISCV::TH_SWIB: {
6494 // op: rs1
6495 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6496 Value |= (op & 0x1f) << 15;
6497 // op: rd
6498 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6499 Value |= (op & 0x1f) << 7;
6500 // op: simm5
6501 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6502 Value |= (op & 0x1f) << 20;
6503 // op: uimm2
6504 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6505 Value |= (op & 0x3) << 25;
6506 break;
6507 }
6508 case RISCV::QC_LIEQI:
6509 case RISCV::QC_LIGEI:
6510 case RISCV::QC_LIGEUI:
6511 case RISCV::QC_LILTI:
6512 case RISCV::QC_LILTUI:
6513 case RISCV::QC_LINEI: {
6514 // op: rs2
6515 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6516 Value |= (op & 0x1f) << 20;
6517 // op: rs1
6518 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6519 Value |= (op & 0x1f) << 15;
6520 // op: rd
6521 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6522 Value |= (op & 0x1f) << 7;
6523 // op: simm
6524 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6525 Value |= (op & 0x1f) << 27;
6526 break;
6527 }
6528 case RISCV::SSPUSH: {
6529 // op: rs2
6530 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6531 Value |= (op & 0x1f) << 20;
6532 break;
6533 }
6534 case RISCV::AIF_SBG:
6535 case RISCV::AIF_SBL:
6536 case RISCV::AIF_SHG:
6537 case RISCV::AIF_SHL:
6538 case RISCV::HSV_B:
6539 case RISCV::HSV_D:
6540 case RISCV::HSV_H:
6541 case RISCV::HSV_W:
6542 case RISCV::SB_AQRL:
6543 case RISCV::SB_RL:
6544 case RISCV::SD_AQRL:
6545 case RISCV::SD_RL:
6546 case RISCV::SF_VLTE16:
6547 case RISCV::SF_VLTE32:
6548 case RISCV::SF_VLTE64:
6549 case RISCV::SF_VLTE8:
6550 case RISCV::SF_VSTE16:
6551 case RISCV::SF_VSTE32:
6552 case RISCV::SF_VSTE64:
6553 case RISCV::SF_VSTE8:
6554 case RISCV::SH_AQRL:
6555 case RISCV::SH_RL:
6556 case RISCV::SW_AQRL:
6557 case RISCV::SW_RL: {
6558 // op: rs2
6559 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6560 Value |= (op & 0x1f) << 20;
6561 // op: rs1
6562 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6563 Value |= (op & 0x1f) << 15;
6564 break;
6565 }
6566 case RISCV::QK_C_SB: {
6567 // op: rs2
6568 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6569 Value |= (op & 0x7) << 2;
6570 // op: rs1
6571 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6572 Value |= (op & 0x7) << 7;
6573 // op: imm
6574 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6575 Value |= (op & 0x1) << 12;
6576 Value |= (op & 0x18) << 7;
6577 Value |= (op & 0x6) << 4;
6578 break;
6579 }
6580 case RISCV::C_SB: {
6581 // op: rs2
6582 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6583 Value |= (op & 0x7) << 2;
6584 // op: rs1
6585 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6586 Value |= (op & 0x7) << 7;
6587 // op: imm
6588 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6589 Value |= (op & 0x1) << 6;
6590 Value |= (op & 0x2) << 4;
6591 break;
6592 }
6593 case RISCV::C_SH:
6594 case RISCV::C_SH_INX: {
6595 // op: rs2
6596 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6597 Value |= (op & 0x7) << 2;
6598 // op: rs1
6599 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6600 Value |= (op & 0x7) << 7;
6601 // op: imm
6602 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6603 Value |= (op & 0x2) << 4;
6604 break;
6605 }
6606 case RISCV::C_FSW:
6607 case RISCV::C_SW:
6608 case RISCV::C_SW_INX: {
6609 // op: rs2
6610 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6611 Value |= (op & 0x7) << 2;
6612 // op: rs1
6613 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6614 Value |= (op & 0x7) << 7;
6615 // op: imm
6616 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6617 Value |= (op & 0x38) << 7;
6618 Value |= (op & 0x4) << 4;
6619 Value |= (op & 0x40) >> 1;
6620 break;
6621 }
6622 case RISCV::QK_C_SH: {
6623 // op: rs2
6624 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6625 Value |= (op & 0x7) << 2;
6626 // op: rs1
6627 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6628 Value |= (op & 0x7) << 7;
6629 // op: imm
6630 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6631 Value |= (op & 0x38) << 7;
6632 Value |= (op & 0x6) << 4;
6633 break;
6634 }
6635 case RISCV::C_FSD:
6636 case RISCV::C_SD:
6637 case RISCV::C_SD_RV32: {
6638 // op: rs2
6639 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6640 Value |= (op & 0x7) << 2;
6641 // op: rs1
6642 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6643 Value |= (op & 0x7) << 7;
6644 // op: imm
6645 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6646 Value |= (op & 0x38) << 7;
6647 Value |= (op & 0xc0) >> 1;
6648 break;
6649 }
6650 case RISCV::NDS_FCVT_BF16_S:
6651 case RISCV::NDS_FCVT_S_BF16: {
6652 // op: rs2
6653 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6654 Value |= (op & 0x1f) << 20;
6655 // op: rd
6656 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6657 Value |= (op & 0x1f) << 7;
6658 break;
6659 }
6660 case RISCV::HFENCE_GVMA:
6661 case RISCV::HFENCE_VVMA:
6662 case RISCV::HINVAL_GVMA:
6663 case RISCV::HINVAL_VVMA:
6664 case RISCV::SFENCE_VMA:
6665 case RISCV::SF_VTMV_T_V:
6666 case RISCV::SINVAL_VMA:
6667 case RISCV::TH_SFENCE_VMAS: {
6668 // op: rs2
6669 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6670 Value |= (op & 0x1f) << 20;
6671 // op: rs1
6672 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6673 Value |= (op & 0x1f) << 15;
6674 break;
6675 }
6676 case RISCV::AIF_AMOADDG_D:
6677 case RISCV::AIF_AMOADDG_W:
6678 case RISCV::AIF_AMOADDL_D:
6679 case RISCV::AIF_AMOADDL_W:
6680 case RISCV::AIF_AMOANDG_D:
6681 case RISCV::AIF_AMOANDG_W:
6682 case RISCV::AIF_AMOANDL_D:
6683 case RISCV::AIF_AMOANDL_W:
6684 case RISCV::AIF_AMOCMPSWAPG_D:
6685 case RISCV::AIF_AMOCMPSWAPG_W:
6686 case RISCV::AIF_AMOCMPSWAPL_D:
6687 case RISCV::AIF_AMOCMPSWAPL_W:
6688 case RISCV::AIF_AMOMAXG_D:
6689 case RISCV::AIF_AMOMAXG_W:
6690 case RISCV::AIF_AMOMAXL_D:
6691 case RISCV::AIF_AMOMAXL_W:
6692 case RISCV::AIF_AMOMAXUG_D:
6693 case RISCV::AIF_AMOMAXUG_W:
6694 case RISCV::AIF_AMOMAXUL_D:
6695 case RISCV::AIF_AMOMAXUL_W:
6696 case RISCV::AIF_AMOMING_D:
6697 case RISCV::AIF_AMOMING_W:
6698 case RISCV::AIF_AMOMINL_D:
6699 case RISCV::AIF_AMOMINL_W:
6700 case RISCV::AIF_AMOMINUG_D:
6701 case RISCV::AIF_AMOMINUG_W:
6702 case RISCV::AIF_AMOMINUL_D:
6703 case RISCV::AIF_AMOMINUL_W:
6704 case RISCV::AIF_AMOORG_D:
6705 case RISCV::AIF_AMOORG_W:
6706 case RISCV::AIF_AMOORL_D:
6707 case RISCV::AIF_AMOORL_W:
6708 case RISCV::AIF_AMOSWAPG_D:
6709 case RISCV::AIF_AMOSWAPG_W:
6710 case RISCV::AIF_AMOSWAPL_D:
6711 case RISCV::AIF_AMOSWAPL_W:
6712 case RISCV::AIF_AMOXORG_D:
6713 case RISCV::AIF_AMOXORG_W:
6714 case RISCV::AIF_AMOXORL_D:
6715 case RISCV::AIF_AMOXORL_W:
6716 case RISCV::AMOADD_B:
6717 case RISCV::AMOADD_B_AQ:
6718 case RISCV::AMOADD_B_AQRL:
6719 case RISCV::AMOADD_B_RL:
6720 case RISCV::AMOADD_D:
6721 case RISCV::AMOADD_D_AQ:
6722 case RISCV::AMOADD_D_AQRL:
6723 case RISCV::AMOADD_D_RL:
6724 case RISCV::AMOADD_H:
6725 case RISCV::AMOADD_H_AQ:
6726 case RISCV::AMOADD_H_AQRL:
6727 case RISCV::AMOADD_H_RL:
6728 case RISCV::AMOADD_W:
6729 case RISCV::AMOADD_W_AQ:
6730 case RISCV::AMOADD_W_AQRL:
6731 case RISCV::AMOADD_W_RL:
6732 case RISCV::AMOAND_B:
6733 case RISCV::AMOAND_B_AQ:
6734 case RISCV::AMOAND_B_AQRL:
6735 case RISCV::AMOAND_B_RL:
6736 case RISCV::AMOAND_D:
6737 case RISCV::AMOAND_D_AQ:
6738 case RISCV::AMOAND_D_AQRL:
6739 case RISCV::AMOAND_D_RL:
6740 case RISCV::AMOAND_H:
6741 case RISCV::AMOAND_H_AQ:
6742 case RISCV::AMOAND_H_AQRL:
6743 case RISCV::AMOAND_H_RL:
6744 case RISCV::AMOAND_W:
6745 case RISCV::AMOAND_W_AQ:
6746 case RISCV::AMOAND_W_AQRL:
6747 case RISCV::AMOAND_W_RL:
6748 case RISCV::AMOMAXU_B:
6749 case RISCV::AMOMAXU_B_AQ:
6750 case RISCV::AMOMAXU_B_AQRL:
6751 case RISCV::AMOMAXU_B_RL:
6752 case RISCV::AMOMAXU_D:
6753 case RISCV::AMOMAXU_D_AQ:
6754 case RISCV::AMOMAXU_D_AQRL:
6755 case RISCV::AMOMAXU_D_RL:
6756 case RISCV::AMOMAXU_H:
6757 case RISCV::AMOMAXU_H_AQ:
6758 case RISCV::AMOMAXU_H_AQRL:
6759 case RISCV::AMOMAXU_H_RL:
6760 case RISCV::AMOMAXU_W:
6761 case RISCV::AMOMAXU_W_AQ:
6762 case RISCV::AMOMAXU_W_AQRL:
6763 case RISCV::AMOMAXU_W_RL:
6764 case RISCV::AMOMAX_B:
6765 case RISCV::AMOMAX_B_AQ:
6766 case RISCV::AMOMAX_B_AQRL:
6767 case RISCV::AMOMAX_B_RL:
6768 case RISCV::AMOMAX_D:
6769 case RISCV::AMOMAX_D_AQ:
6770 case RISCV::AMOMAX_D_AQRL:
6771 case RISCV::AMOMAX_D_RL:
6772 case RISCV::AMOMAX_H:
6773 case RISCV::AMOMAX_H_AQ:
6774 case RISCV::AMOMAX_H_AQRL:
6775 case RISCV::AMOMAX_H_RL:
6776 case RISCV::AMOMAX_W:
6777 case RISCV::AMOMAX_W_AQ:
6778 case RISCV::AMOMAX_W_AQRL:
6779 case RISCV::AMOMAX_W_RL:
6780 case RISCV::AMOMINU_B:
6781 case RISCV::AMOMINU_B_AQ:
6782 case RISCV::AMOMINU_B_AQRL:
6783 case RISCV::AMOMINU_B_RL:
6784 case RISCV::AMOMINU_D:
6785 case RISCV::AMOMINU_D_AQ:
6786 case RISCV::AMOMINU_D_AQRL:
6787 case RISCV::AMOMINU_D_RL:
6788 case RISCV::AMOMINU_H:
6789 case RISCV::AMOMINU_H_AQ:
6790 case RISCV::AMOMINU_H_AQRL:
6791 case RISCV::AMOMINU_H_RL:
6792 case RISCV::AMOMINU_W:
6793 case RISCV::AMOMINU_W_AQ:
6794 case RISCV::AMOMINU_W_AQRL:
6795 case RISCV::AMOMINU_W_RL:
6796 case RISCV::AMOMIN_B:
6797 case RISCV::AMOMIN_B_AQ:
6798 case RISCV::AMOMIN_B_AQRL:
6799 case RISCV::AMOMIN_B_RL:
6800 case RISCV::AMOMIN_D:
6801 case RISCV::AMOMIN_D_AQ:
6802 case RISCV::AMOMIN_D_AQRL:
6803 case RISCV::AMOMIN_D_RL:
6804 case RISCV::AMOMIN_H:
6805 case RISCV::AMOMIN_H_AQ:
6806 case RISCV::AMOMIN_H_AQRL:
6807 case RISCV::AMOMIN_H_RL:
6808 case RISCV::AMOMIN_W:
6809 case RISCV::AMOMIN_W_AQ:
6810 case RISCV::AMOMIN_W_AQRL:
6811 case RISCV::AMOMIN_W_RL:
6812 case RISCV::AMOOR_B:
6813 case RISCV::AMOOR_B_AQ:
6814 case RISCV::AMOOR_B_AQRL:
6815 case RISCV::AMOOR_B_RL:
6816 case RISCV::AMOOR_D:
6817 case RISCV::AMOOR_D_AQ:
6818 case RISCV::AMOOR_D_AQRL:
6819 case RISCV::AMOOR_D_RL:
6820 case RISCV::AMOOR_H:
6821 case RISCV::AMOOR_H_AQ:
6822 case RISCV::AMOOR_H_AQRL:
6823 case RISCV::AMOOR_H_RL:
6824 case RISCV::AMOOR_W:
6825 case RISCV::AMOOR_W_AQ:
6826 case RISCV::AMOOR_W_AQRL:
6827 case RISCV::AMOOR_W_RL:
6828 case RISCV::AMOSWAP_B:
6829 case RISCV::AMOSWAP_B_AQ:
6830 case RISCV::AMOSWAP_B_AQRL:
6831 case RISCV::AMOSWAP_B_RL:
6832 case RISCV::AMOSWAP_D:
6833 case RISCV::AMOSWAP_D_AQ:
6834 case RISCV::AMOSWAP_D_AQRL:
6835 case RISCV::AMOSWAP_D_RL:
6836 case RISCV::AMOSWAP_H:
6837 case RISCV::AMOSWAP_H_AQ:
6838 case RISCV::AMOSWAP_H_AQRL:
6839 case RISCV::AMOSWAP_H_RL:
6840 case RISCV::AMOSWAP_W:
6841 case RISCV::AMOSWAP_W_AQ:
6842 case RISCV::AMOSWAP_W_AQRL:
6843 case RISCV::AMOSWAP_W_RL:
6844 case RISCV::AMOXOR_B:
6845 case RISCV::AMOXOR_B_AQ:
6846 case RISCV::AMOXOR_B_AQRL:
6847 case RISCV::AMOXOR_B_RL:
6848 case RISCV::AMOXOR_D:
6849 case RISCV::AMOXOR_D_AQ:
6850 case RISCV::AMOXOR_D_AQRL:
6851 case RISCV::AMOXOR_D_RL:
6852 case RISCV::AMOXOR_H:
6853 case RISCV::AMOXOR_H_AQ:
6854 case RISCV::AMOXOR_H_AQRL:
6855 case RISCV::AMOXOR_H_RL:
6856 case RISCV::AMOXOR_W:
6857 case RISCV::AMOXOR_W_AQ:
6858 case RISCV::AMOXOR_W_AQRL:
6859 case RISCV::AMOXOR_W_RL:
6860 case RISCV::NDS_LEA_B_ZE:
6861 case RISCV::NDS_LEA_D:
6862 case RISCV::NDS_LEA_D_ZE:
6863 case RISCV::NDS_LEA_H:
6864 case RISCV::NDS_LEA_H_ZE:
6865 case RISCV::NDS_LEA_W:
6866 case RISCV::NDS_LEA_W_ZE:
6867 case RISCV::SC_D:
6868 case RISCV::SC_D_AQ:
6869 case RISCV::SC_D_AQRL:
6870 case RISCV::SC_D_RL:
6871 case RISCV::SC_W:
6872 case RISCV::SC_W_AQ:
6873 case RISCV::SC_W_AQRL:
6874 case RISCV::SC_W_RL:
6875 case RISCV::SSAMOSWAP_D:
6876 case RISCV::SSAMOSWAP_D_AQ:
6877 case RISCV::SSAMOSWAP_D_AQRL:
6878 case RISCV::SSAMOSWAP_D_RL:
6879 case RISCV::SSAMOSWAP_W:
6880 case RISCV::SSAMOSWAP_W_AQ:
6881 case RISCV::SSAMOSWAP_W_AQRL:
6882 case RISCV::SSAMOSWAP_W_RL: {
6883 // op: rs2
6884 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6885 Value |= (op & 0x1f) << 20;
6886 // op: rs1
6887 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6888 Value |= (op & 0x1f) << 15;
6889 // op: rd
6890 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6891 Value |= (op & 0x1f) << 7;
6892 break;
6893 }
6894 case RISCV::TH_LDD:
6895 case RISCV::TH_LWD:
6896 case RISCV::TH_LWUD:
6897 case RISCV::TH_SDD:
6898 case RISCV::TH_SWD: {
6899 // op: rs2
6900 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6901 Value |= (op & 0x1f) << 20;
6902 // op: rs1
6903 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6904 Value |= (op & 0x1f) << 15;
6905 // op: rd
6906 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6907 Value |= (op & 0x1f) << 7;
6908 // op: uimm2
6909 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6910 Value |= (op & 0x3) << 25;
6911 break;
6912 }
6913 case RISCV::CM_MVA01S:
6914 case RISCV::CM_MVSA01:
6915 case RISCV::QC_CM_MVA01S:
6916 case RISCV::QC_CM_MVSA01: {
6917 // op: rs2
6918 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6919 Value |= (op & 0x7) << 2;
6920 // op: rs1
6921 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6922 Value |= (op & 0x7) << 7;
6923 break;
6924 }
6925 case RISCV::QC_CSRRWRI: {
6926 // op: rs2
6927 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6928 Value |= (op & 0x1f) << 20;
6929 // op: rs1
6930 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6931 Value |= (op & 0x1f) << 15;
6932 // op: rd
6933 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6934 Value |= (op & 0x1f) << 7;
6935 break;
6936 }
6937 case RISCV::FADD_D:
6938 case RISCV::FADD_D_IN32X:
6939 case RISCV::FADD_D_INX:
6940 case RISCV::FADD_H:
6941 case RISCV::FADD_H_INX:
6942 case RISCV::FADD_Q:
6943 case RISCV::FADD_S:
6944 case RISCV::FADD_S_INX:
6945 case RISCV::FDIV_D:
6946 case RISCV::FDIV_D_IN32X:
6947 case RISCV::FDIV_D_INX:
6948 case RISCV::FDIV_H:
6949 case RISCV::FDIV_H_INX:
6950 case RISCV::FDIV_Q:
6951 case RISCV::FDIV_S:
6952 case RISCV::FDIV_S_INX:
6953 case RISCV::FMUL_D:
6954 case RISCV::FMUL_D_IN32X:
6955 case RISCV::FMUL_D_INX:
6956 case RISCV::FMUL_H:
6957 case RISCV::FMUL_H_INX:
6958 case RISCV::FMUL_Q:
6959 case RISCV::FMUL_S:
6960 case RISCV::FMUL_S_INX:
6961 case RISCV::FSUB_D:
6962 case RISCV::FSUB_D_IN32X:
6963 case RISCV::FSUB_D_INX:
6964 case RISCV::FSUB_H:
6965 case RISCV::FSUB_H_INX:
6966 case RISCV::FSUB_Q:
6967 case RISCV::FSUB_S:
6968 case RISCV::FSUB_S_INX: {
6969 // op: rs2
6970 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6971 Value |= (op & 0x1f) << 20;
6972 // op: rs1
6973 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6974 Value |= (op & 0x1f) << 15;
6975 // op: frm
6976 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
6977 Value |= (op & 0x7) << 12;
6978 // op: rd
6979 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6980 Value |= (op & 0x1f) << 7;
6981 break;
6982 }
6983 case RISCV::PM2WADDSU_H:
6984 case RISCV::PM2WADDU_H:
6985 case RISCV::PM2WADD_H:
6986 case RISCV::PM2WADD_HX:
6987 case RISCV::PM2WSUB_H:
6988 case RISCV::PM2WSUB_HX:
6989 case RISCV::PWADDU_B:
6990 case RISCV::PWADDU_H:
6991 case RISCV::PWADD_B:
6992 case RISCV::PWADD_H:
6993 case RISCV::PWMULSU_B:
6994 case RISCV::PWMULSU_H:
6995 case RISCV::PWMULU_B:
6996 case RISCV::PWMULU_H:
6997 case RISCV::PWMUL_B:
6998 case RISCV::PWMUL_H:
6999 case RISCV::PWSLA_BS:
7000 case RISCV::PWSLA_HS:
7001 case RISCV::PWSLL_BS:
7002 case RISCV::PWSLL_HS:
7003 case RISCV::PWSUBU_B:
7004 case RISCV::PWSUBU_H:
7005 case RISCV::PWSUB_B:
7006 case RISCV::PWSUB_H:
7007 case RISCV::WADD:
7008 case RISCV::WADDU:
7009 case RISCV::WMUL:
7010 case RISCV::WMULSU:
7011 case RISCV::WMULU:
7012 case RISCV::WSLA:
7013 case RISCV::WSLL:
7014 case RISCV::WSUB:
7015 case RISCV::WSUBU:
7016 case RISCV::WZIP16P:
7017 case RISCV::WZIP8P: {
7018 // op: rs2
7019 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7020 Value |= (op & 0x1f) << 20;
7021 // op: rs1
7022 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7023 Value |= (op & 0x1f) << 15;
7024 // op: rd
7025 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7026 Value |= (op & 0x1e) << 7;
7027 break;
7028 }
7029 case RISCV::AADD:
7030 case RISCV::AADDU:
7031 case RISCV::ADD:
7032 case RISCV::ADDW:
7033 case RISCV::ADD_UW:
7034 case RISCV::AES64DS:
7035 case RISCV::AES64DSM:
7036 case RISCV::AES64ES:
7037 case RISCV::AES64ESM:
7038 case RISCV::AES64KS2:
7039 case RISCV::AIF_BITMIXB:
7040 case RISCV::AIF_CUBEFACEIDX_PS:
7041 case RISCV::AIF_CUBEFACE_PS:
7042 case RISCV::AIF_CUBESGNSC_PS:
7043 case RISCV::AIF_CUBESGNTC_PS:
7044 case RISCV::AIF_FADD_PI:
7045 case RISCV::AIF_FAMOADDG_PI:
7046 case RISCV::AIF_FAMOADDL_PI:
7047 case RISCV::AIF_FAMOANDG_PI:
7048 case RISCV::AIF_FAMOANDL_PI:
7049 case RISCV::AIF_FAMOMAXG_PI:
7050 case RISCV::AIF_FAMOMAXG_PS:
7051 case RISCV::AIF_FAMOMAXL_PI:
7052 case RISCV::AIF_FAMOMAXL_PS:
7053 case RISCV::AIF_FAMOMAXUG_PI:
7054 case RISCV::AIF_FAMOMAXUL_PI:
7055 case RISCV::AIF_FAMOMING_PI:
7056 case RISCV::AIF_FAMOMING_PS:
7057 case RISCV::AIF_FAMOMINL_PI:
7058 case RISCV::AIF_FAMOMINL_PS:
7059 case RISCV::AIF_FAMOMINUG_PI:
7060 case RISCV::AIF_FAMOMINUL_PI:
7061 case RISCV::AIF_FAMOORG_PI:
7062 case RISCV::AIF_FAMOORL_PI:
7063 case RISCV::AIF_FAMOSWAPG_PI:
7064 case RISCV::AIF_FAMOSWAPL_PI:
7065 case RISCV::AIF_FAMOXORG_PI:
7066 case RISCV::AIF_FAMOXORL_PI:
7067 case RISCV::AIF_FAND_PI:
7068 case RISCV::AIF_FCMOVM_PS:
7069 case RISCV::AIF_FDIVU_PI:
7070 case RISCV::AIF_FDIV_PI:
7071 case RISCV::AIF_FEQM_PS:
7072 case RISCV::AIF_FEQ_PI:
7073 case RISCV::AIF_FEQ_PS:
7074 case RISCV::AIF_FG32B_PS:
7075 case RISCV::AIF_FG32H_PS:
7076 case RISCV::AIF_FG32W_PS:
7077 case RISCV::AIF_FGBG_PS:
7078 case RISCV::AIF_FGBL_PS:
7079 case RISCV::AIF_FGB_PS:
7080 case RISCV::AIF_FGHG_PS:
7081 case RISCV::AIF_FGHL_PS:
7082 case RISCV::AIF_FGH_PS:
7083 case RISCV::AIF_FGWG_PS:
7084 case RISCV::AIF_FGWL_PS:
7085 case RISCV::AIF_FGW_PS:
7086 case RISCV::AIF_FLEM_PS:
7087 case RISCV::AIF_FLE_PI:
7088 case RISCV::AIF_FLE_PS:
7089 case RISCV::AIF_FLTM_PI:
7090 case RISCV::AIF_FLTM_PS:
7091 case RISCV::AIF_FLTU_PI:
7092 case RISCV::AIF_FLT_PI:
7093 case RISCV::AIF_FLT_PS:
7094 case RISCV::AIF_FMAXU_PI:
7095 case RISCV::AIF_FMAX_PI:
7096 case RISCV::AIF_FMAX_PS:
7097 case RISCV::AIF_FMINU_PI:
7098 case RISCV::AIF_FMIN_PI:
7099 case RISCV::AIF_FMIN_PS:
7100 case RISCV::AIF_FMULHU_PI:
7101 case RISCV::AIF_FMULH_PI:
7102 case RISCV::AIF_FMUL_PI:
7103 case RISCV::AIF_FOR_PI:
7104 case RISCV::AIF_FRCP_FIX_RAST:
7105 case RISCV::AIF_FREMU_PI:
7106 case RISCV::AIF_FREM_PI:
7107 case RISCV::AIF_FSGNJN_PS:
7108 case RISCV::AIF_FSGNJX_PS:
7109 case RISCV::AIF_FSGNJ_PS:
7110 case RISCV::AIF_FSLL_PI:
7111 case RISCV::AIF_FSRA_PI:
7112 case RISCV::AIF_FSRL_PI:
7113 case RISCV::AIF_FSUB_PI:
7114 case RISCV::AIF_FXOR_PI:
7115 case RISCV::AIF_PACKB:
7116 case RISCV::AND:
7117 case RISCV::ANDN:
7118 case RISCV::ASUB:
7119 case RISCV::ASUBU:
7120 case RISCV::BCLR:
7121 case RISCV::BEXT:
7122 case RISCV::BINV:
7123 case RISCV::BSET:
7124 case RISCV::CLMUL:
7125 case RISCV::CLMULH:
7126 case RISCV::CLMULR:
7127 case RISCV::CV_ADD_B:
7128 case RISCV::CV_ADD_DIV2:
7129 case RISCV::CV_ADD_DIV4:
7130 case RISCV::CV_ADD_DIV8:
7131 case RISCV::CV_ADD_H:
7132 case RISCV::CV_ADD_SC_B:
7133 case RISCV::CV_ADD_SC_H:
7134 case RISCV::CV_AND_B:
7135 case RISCV::CV_AND_H:
7136 case RISCV::CV_AND_SC_B:
7137 case RISCV::CV_AND_SC_H:
7138 case RISCV::CV_AVGU_B:
7139 case RISCV::CV_AVGU_H:
7140 case RISCV::CV_AVGU_SC_B:
7141 case RISCV::CV_AVGU_SC_H:
7142 case RISCV::CV_AVG_B:
7143 case RISCV::CV_AVG_H:
7144 case RISCV::CV_AVG_SC_B:
7145 case RISCV::CV_AVG_SC_H:
7146 case RISCV::CV_BCLRR:
7147 case RISCV::CV_BSETR:
7148 case RISCV::CV_CLIPR:
7149 case RISCV::CV_CLIPUR:
7150 case RISCV::CV_CMPEQ_B:
7151 case RISCV::CV_CMPEQ_H:
7152 case RISCV::CV_CMPEQ_SC_B:
7153 case RISCV::CV_CMPEQ_SC_H:
7154 case RISCV::CV_CMPGEU_B:
7155 case RISCV::CV_CMPGEU_H:
7156 case RISCV::CV_CMPGEU_SC_B:
7157 case RISCV::CV_CMPGEU_SC_H:
7158 case RISCV::CV_CMPGE_B:
7159 case RISCV::CV_CMPGE_H:
7160 case RISCV::CV_CMPGE_SC_B:
7161 case RISCV::CV_CMPGE_SC_H:
7162 case RISCV::CV_CMPGTU_B:
7163 case RISCV::CV_CMPGTU_H:
7164 case RISCV::CV_CMPGTU_SC_B:
7165 case RISCV::CV_CMPGTU_SC_H:
7166 case RISCV::CV_CMPGT_B:
7167 case RISCV::CV_CMPGT_H:
7168 case RISCV::CV_CMPGT_SC_B:
7169 case RISCV::CV_CMPGT_SC_H:
7170 case RISCV::CV_CMPLEU_B:
7171 case RISCV::CV_CMPLEU_H:
7172 case RISCV::CV_CMPLEU_SC_B:
7173 case RISCV::CV_CMPLEU_SC_H:
7174 case RISCV::CV_CMPLE_B:
7175 case RISCV::CV_CMPLE_H:
7176 case RISCV::CV_CMPLE_SC_B:
7177 case RISCV::CV_CMPLE_SC_H:
7178 case RISCV::CV_CMPLTU_B:
7179 case RISCV::CV_CMPLTU_H:
7180 case RISCV::CV_CMPLTU_SC_B:
7181 case RISCV::CV_CMPLTU_SC_H:
7182 case RISCV::CV_CMPLT_B:
7183 case RISCV::CV_CMPLT_H:
7184 case RISCV::CV_CMPLT_SC_B:
7185 case RISCV::CV_CMPLT_SC_H:
7186 case RISCV::CV_CMPNE_B:
7187 case RISCV::CV_CMPNE_H:
7188 case RISCV::CV_CMPNE_SC_B:
7189 case RISCV::CV_CMPNE_SC_H:
7190 case RISCV::CV_DOTSP_B:
7191 case RISCV::CV_DOTSP_H:
7192 case RISCV::CV_DOTSP_SC_B:
7193 case RISCV::CV_DOTSP_SC_H:
7194 case RISCV::CV_DOTUP_B:
7195 case RISCV::CV_DOTUP_H:
7196 case RISCV::CV_DOTUP_SC_B:
7197 case RISCV::CV_DOTUP_SC_H:
7198 case RISCV::CV_DOTUSP_B:
7199 case RISCV::CV_DOTUSP_H:
7200 case RISCV::CV_DOTUSP_SC_B:
7201 case RISCV::CV_DOTUSP_SC_H:
7202 case RISCV::CV_EXTRACTR:
7203 case RISCV::CV_EXTRACTUR:
7204 case RISCV::CV_LBU_rr:
7205 case RISCV::CV_LB_rr:
7206 case RISCV::CV_LHU_rr:
7207 case RISCV::CV_LH_rr:
7208 case RISCV::CV_LW_rr:
7209 case RISCV::CV_MAX:
7210 case RISCV::CV_MAXU:
7211 case RISCV::CV_MAXU_B:
7212 case RISCV::CV_MAXU_H:
7213 case RISCV::CV_MAXU_SC_B:
7214 case RISCV::CV_MAXU_SC_H:
7215 case RISCV::CV_MAX_B:
7216 case RISCV::CV_MAX_H:
7217 case RISCV::CV_MAX_SC_B:
7218 case RISCV::CV_MAX_SC_H:
7219 case RISCV::CV_MIN:
7220 case RISCV::CV_MINU:
7221 case RISCV::CV_MINU_B:
7222 case RISCV::CV_MINU_H:
7223 case RISCV::CV_MINU_SC_B:
7224 case RISCV::CV_MINU_SC_H:
7225 case RISCV::CV_MIN_B:
7226 case RISCV::CV_MIN_H:
7227 case RISCV::CV_MIN_SC_B:
7228 case RISCV::CV_MIN_SC_H:
7229 case RISCV::CV_OR_B:
7230 case RISCV::CV_OR_H:
7231 case RISCV::CV_OR_SC_B:
7232 case RISCV::CV_OR_SC_H:
7233 case RISCV::CV_PACK:
7234 case RISCV::CV_PACK_H:
7235 case RISCV::CV_ROR:
7236 case RISCV::CV_SHUFFLE_B:
7237 case RISCV::CV_SHUFFLE_H:
7238 case RISCV::CV_SLE:
7239 case RISCV::CV_SLEU:
7240 case RISCV::CV_SLL_B:
7241 case RISCV::CV_SLL_H:
7242 case RISCV::CV_SLL_SC_B:
7243 case RISCV::CV_SLL_SC_H:
7244 case RISCV::CV_SRA_B:
7245 case RISCV::CV_SRA_H:
7246 case RISCV::CV_SRA_SC_B:
7247 case RISCV::CV_SRA_SC_H:
7248 case RISCV::CV_SRL_B:
7249 case RISCV::CV_SRL_H:
7250 case RISCV::CV_SRL_SC_B:
7251 case RISCV::CV_SRL_SC_H:
7252 case RISCV::CV_SUBROTMJ:
7253 case RISCV::CV_SUBROTMJ_DIV2:
7254 case RISCV::CV_SUBROTMJ_DIV4:
7255 case RISCV::CV_SUBROTMJ_DIV8:
7256 case RISCV::CV_SUB_B:
7257 case RISCV::CV_SUB_DIV2:
7258 case RISCV::CV_SUB_DIV4:
7259 case RISCV::CV_SUB_DIV8:
7260 case RISCV::CV_SUB_H:
7261 case RISCV::CV_SUB_SC_B:
7262 case RISCV::CV_SUB_SC_H:
7263 case RISCV::CV_XOR_B:
7264 case RISCV::CV_XOR_H:
7265 case RISCV::CV_XOR_SC_B:
7266 case RISCV::CV_XOR_SC_H:
7267 case RISCV::CZERO_EQZ:
7268 case RISCV::CZERO_NEZ:
7269 case RISCV::DIV:
7270 case RISCV::DIVU:
7271 case RISCV::DIVUW:
7272 case RISCV::DIVW:
7273 case RISCV::FEQ_D:
7274 case RISCV::FEQ_D_IN32X:
7275 case RISCV::FEQ_D_INX:
7276 case RISCV::FEQ_H:
7277 case RISCV::FEQ_H_INX:
7278 case RISCV::FEQ_Q:
7279 case RISCV::FEQ_S:
7280 case RISCV::FEQ_S_INX:
7281 case RISCV::FLEQ_D:
7282 case RISCV::FLEQ_H:
7283 case RISCV::FLEQ_Q:
7284 case RISCV::FLEQ_S:
7285 case RISCV::FLE_D:
7286 case RISCV::FLE_D_IN32X:
7287 case RISCV::FLE_D_INX:
7288 case RISCV::FLE_H:
7289 case RISCV::FLE_H_INX:
7290 case RISCV::FLE_Q:
7291 case RISCV::FLE_S:
7292 case RISCV::FLE_S_INX:
7293 case RISCV::FLTQ_D:
7294 case RISCV::FLTQ_H:
7295 case RISCV::FLTQ_Q:
7296 case RISCV::FLTQ_S:
7297 case RISCV::FLT_D:
7298 case RISCV::FLT_D_IN32X:
7299 case RISCV::FLT_D_INX:
7300 case RISCV::FLT_H:
7301 case RISCV::FLT_H_INX:
7302 case RISCV::FLT_Q:
7303 case RISCV::FLT_S:
7304 case RISCV::FLT_S_INX:
7305 case RISCV::FMAXM_D:
7306 case RISCV::FMAXM_H:
7307 case RISCV::FMAXM_Q:
7308 case RISCV::FMAXM_S:
7309 case RISCV::FMAX_D:
7310 case RISCV::FMAX_D_IN32X:
7311 case RISCV::FMAX_D_INX:
7312 case RISCV::FMAX_H:
7313 case RISCV::FMAX_H_INX:
7314 case RISCV::FMAX_Q:
7315 case RISCV::FMAX_S:
7316 case RISCV::FMAX_S_INX:
7317 case RISCV::FMINM_D:
7318 case RISCV::FMINM_H:
7319 case RISCV::FMINM_Q:
7320 case RISCV::FMINM_S:
7321 case RISCV::FMIN_D:
7322 case RISCV::FMIN_D_IN32X:
7323 case RISCV::FMIN_D_INX:
7324 case RISCV::FMIN_H:
7325 case RISCV::FMIN_H_INX:
7326 case RISCV::FMIN_Q:
7327 case RISCV::FMIN_S:
7328 case RISCV::FMIN_S_INX:
7329 case RISCV::FMVP_D_X:
7330 case RISCV::FMVP_Q_X:
7331 case RISCV::FSGNJN_D:
7332 case RISCV::FSGNJN_D_IN32X:
7333 case RISCV::FSGNJN_D_INX:
7334 case RISCV::FSGNJN_H:
7335 case RISCV::FSGNJN_H_INX:
7336 case RISCV::FSGNJN_Q:
7337 case RISCV::FSGNJN_S:
7338 case RISCV::FSGNJN_S_INX:
7339 case RISCV::FSGNJX_D:
7340 case RISCV::FSGNJX_D_IN32X:
7341 case RISCV::FSGNJX_D_INX:
7342 case RISCV::FSGNJX_H:
7343 case RISCV::FSGNJX_H_INX:
7344 case RISCV::FSGNJX_Q:
7345 case RISCV::FSGNJX_S:
7346 case RISCV::FSGNJX_S_INX:
7347 case RISCV::FSGNJ_D:
7348 case RISCV::FSGNJ_D_IN32X:
7349 case RISCV::FSGNJ_D_INX:
7350 case RISCV::FSGNJ_H:
7351 case RISCV::FSGNJ_H_INX:
7352 case RISCV::FSGNJ_Q:
7353 case RISCV::FSGNJ_S:
7354 case RISCV::FSGNJ_S_INX:
7355 case RISCV::MAX:
7356 case RISCV::MAXU:
7357 case RISCV::MIN:
7358 case RISCV::MINU:
7359 case RISCV::MOP_RR_0:
7360 case RISCV::MOP_RR_1:
7361 case RISCV::MOP_RR_2:
7362 case RISCV::MOP_RR_3:
7363 case RISCV::MOP_RR_4:
7364 case RISCV::MOP_RR_5:
7365 case RISCV::MOP_RR_6:
7366 case RISCV::MOP_RR_7:
7367 case RISCV::MSEQ:
7368 case RISCV::MSLT:
7369 case RISCV::MSLTU:
7370 case RISCV::MUL:
7371 case RISCV::MULH:
7372 case RISCV::MULHR:
7373 case RISCV::MULHRSU:
7374 case RISCV::MULHRU:
7375 case RISCV::MULHSU:
7376 case RISCV::MULHSU_H0:
7377 case RISCV::MULHSU_H1:
7378 case RISCV::MULHU:
7379 case RISCV::MULH_H0:
7380 case RISCV::MULH_H1:
7381 case RISCV::MULQ:
7382 case RISCV::MULQR:
7383 case RISCV::MULSU_H00:
7384 case RISCV::MULSU_H11:
7385 case RISCV::MULSU_W00:
7386 case RISCV::MULSU_W11:
7387 case RISCV::MULU_H00:
7388 case RISCV::MULU_H01:
7389 case RISCV::MULU_H11:
7390 case RISCV::MULU_W00:
7391 case RISCV::MULU_W01:
7392 case RISCV::MULU_W11:
7393 case RISCV::MULW:
7394 case RISCV::MUL_H00:
7395 case RISCV::MUL_H01:
7396 case RISCV::MUL_H11:
7397 case RISCV::MUL_W00:
7398 case RISCV::MUL_W01:
7399 case RISCV::MUL_W11:
7400 case RISCV::NDS_FFB:
7401 case RISCV::NDS_FFMISM:
7402 case RISCV::NDS_FFZMISM:
7403 case RISCV::NDS_FLMISM:
7404 case RISCV::OR:
7405 case RISCV::ORN:
7406 case RISCV::PAADDU_B:
7407 case RISCV::PAADDU_H:
7408 case RISCV::PAADDU_W:
7409 case RISCV::PAADD_B:
7410 case RISCV::PAADD_H:
7411 case RISCV::PAADD_W:
7412 case RISCV::PAAS_HX:
7413 case RISCV::PAAS_WX:
7414 case RISCV::PABDSUMU_B:
7415 case RISCV::PABDU_B:
7416 case RISCV::PABDU_H:
7417 case RISCV::PABD_B:
7418 case RISCV::PABD_H:
7419 case RISCV::PACK:
7420 case RISCV::PACKH:
7421 case RISCV::PACKW:
7422 case RISCV::PACKY:
7423 case RISCV::PADD_B:
7424 case RISCV::PADD_BS:
7425 case RISCV::PADD_H:
7426 case RISCV::PADD_HS:
7427 case RISCV::PADD_W:
7428 case RISCV::PADD_WS:
7429 case RISCV::PASA_HX:
7430 case RISCV::PASA_WX:
7431 case RISCV::PASUBU_B:
7432 case RISCV::PASUBU_H:
7433 case RISCV::PASUBU_W:
7434 case RISCV::PASUB_B:
7435 case RISCV::PASUB_H:
7436 case RISCV::PASUB_W:
7437 case RISCV::PAS_HX:
7438 case RISCV::PAS_WX:
7439 case RISCV::PM2ADDSU_H:
7440 case RISCV::PM2ADDSU_W:
7441 case RISCV::PM2ADDU_H:
7442 case RISCV::PM2ADDU_W:
7443 case RISCV::PM2ADD_H:
7444 case RISCV::PM2ADD_HX:
7445 case RISCV::PM2ADD_W:
7446 case RISCV::PM2ADD_WX:
7447 case RISCV::PM2SADD_H:
7448 case RISCV::PM2SADD_HX:
7449 case RISCV::PM2SUB_H:
7450 case RISCV::PM2SUB_HX:
7451 case RISCV::PM2SUB_W:
7452 case RISCV::PM2SUB_WX:
7453 case RISCV::PM4ADDSU_B:
7454 case RISCV::PM4ADDSU_H:
7455 case RISCV::PM4ADDU_B:
7456 case RISCV::PM4ADDU_H:
7457 case RISCV::PM4ADD_B:
7458 case RISCV::PM4ADD_H:
7459 case RISCV::PMAXU_B:
7460 case RISCV::PMAXU_H:
7461 case RISCV::PMAXU_W:
7462 case RISCV::PMAX_B:
7463 case RISCV::PMAX_H:
7464 case RISCV::PMAX_W:
7465 case RISCV::PMINU_B:
7466 case RISCV::PMINU_H:
7467 case RISCV::PMINU_W:
7468 case RISCV::PMIN_B:
7469 case RISCV::PMIN_H:
7470 case RISCV::PMIN_W:
7471 case RISCV::PMQ2ADD_H:
7472 case RISCV::PMQ2ADD_W:
7473 case RISCV::PMQR2ADD_H:
7474 case RISCV::PMQR2ADD_W:
7475 case RISCV::PMSEQ_B:
7476 case RISCV::PMSEQ_H:
7477 case RISCV::PMSEQ_W:
7478 case RISCV::PMSLTU_B:
7479 case RISCV::PMSLTU_H:
7480 case RISCV::PMSLTU_W:
7481 case RISCV::PMSLT_B:
7482 case RISCV::PMSLT_H:
7483 case RISCV::PMSLT_W:
7484 case RISCV::PMULHRSU_H:
7485 case RISCV::PMULHRSU_W:
7486 case RISCV::PMULHRU_H:
7487 case RISCV::PMULHRU_W:
7488 case RISCV::PMULHR_H:
7489 case RISCV::PMULHR_W:
7490 case RISCV::PMULHSU_H:
7491 case RISCV::PMULHSU_H_B0:
7492 case RISCV::PMULHSU_H_B1:
7493 case RISCV::PMULHSU_W:
7494 case RISCV::PMULHSU_W_H0:
7495 case RISCV::PMULHSU_W_H1:
7496 case RISCV::PMULHU_H:
7497 case RISCV::PMULHU_W:
7498 case RISCV::PMULH_H:
7499 case RISCV::PMULH_H_B0:
7500 case RISCV::PMULH_H_B1:
7501 case RISCV::PMULH_W:
7502 case RISCV::PMULH_W_H0:
7503 case RISCV::PMULH_W_H1:
7504 case RISCV::PMULQR_H:
7505 case RISCV::PMULQR_W:
7506 case RISCV::PMULQ_H:
7507 case RISCV::PMULQ_W:
7508 case RISCV::PMULSU_H_B00:
7509 case RISCV::PMULSU_H_B11:
7510 case RISCV::PMULSU_W_H00:
7511 case RISCV::PMULSU_W_H11:
7512 case RISCV::PMULU_H_B00:
7513 case RISCV::PMULU_H_B01:
7514 case RISCV::PMULU_H_B11:
7515 case RISCV::PMULU_W_H00:
7516 case RISCV::PMULU_W_H01:
7517 case RISCV::PMULU_W_H11:
7518 case RISCV::PMUL_H_B00:
7519 case RISCV::PMUL_H_B01:
7520 case RISCV::PMUL_H_B11:
7521 case RISCV::PMUL_W_H00:
7522 case RISCV::PMUL_W_H01:
7523 case RISCV::PMUL_W_H11:
7524 case RISCV::PNCLIPP_B:
7525 case RISCV::PNCLIPP_H:
7526 case RISCV::PNCLIPP_W:
7527 case RISCV::PNCLIPUP_B:
7528 case RISCV::PNCLIPUP_H:
7529 case RISCV::PNCLIPUP_W:
7530 case RISCV::PPAIREO_B:
7531 case RISCV::PPAIREO_H:
7532 case RISCV::PPAIREO_W:
7533 case RISCV::PPAIRE_B:
7534 case RISCV::PPAIRE_H:
7535 case RISCV::PPAIROE_B:
7536 case RISCV::PPAIROE_H:
7537 case RISCV::PPAIROE_W:
7538 case RISCV::PPAIRO_B:
7539 case RISCV::PPAIRO_H:
7540 case RISCV::PPAIRO_W:
7541 case RISCV::PREDSUMU_BS:
7542 case RISCV::PREDSUMU_HS:
7543 case RISCV::PREDSUMU_WS:
7544 case RISCV::PREDSUM_BS:
7545 case RISCV::PREDSUM_HS:
7546 case RISCV::PREDSUM_WS:
7547 case RISCV::PSADDU_B:
7548 case RISCV::PSADDU_H:
7549 case RISCV::PSADDU_W:
7550 case RISCV::PSADD_B:
7551 case RISCV::PSADD_H:
7552 case RISCV::PSADD_W:
7553 case RISCV::PSAS_HX:
7554 case RISCV::PSAS_WX:
7555 case RISCV::PSA_HX:
7556 case RISCV::PSA_WX:
7557 case RISCV::PSH1ADD_H:
7558 case RISCV::PSH1ADD_W:
7559 case RISCV::PSLL_BS:
7560 case RISCV::PSLL_HS:
7561 case RISCV::PSLL_WS:
7562 case RISCV::PSRA_BS:
7563 case RISCV::PSRA_HS:
7564 case RISCV::PSRA_WS:
7565 case RISCV::PSRL_BS:
7566 case RISCV::PSRL_HS:
7567 case RISCV::PSRL_WS:
7568 case RISCV::PSSA_HX:
7569 case RISCV::PSSA_WX:
7570 case RISCV::PSSH1SADD_H:
7571 case RISCV::PSSH1SADD_W:
7572 case RISCV::PSSHAR_HS:
7573 case RISCV::PSSHAR_WS:
7574 case RISCV::PSSHA_HS:
7575 case RISCV::PSSHA_WS:
7576 case RISCV::PSSHLR_HS:
7577 case RISCV::PSSHLR_WS:
7578 case RISCV::PSSHL_HS:
7579 case RISCV::PSSHL_WS:
7580 case RISCV::PSSUBU_B:
7581 case RISCV::PSSUBU_H:
7582 case RISCV::PSSUBU_W:
7583 case RISCV::PSSUB_B:
7584 case RISCV::PSSUB_H:
7585 case RISCV::PSSUB_W:
7586 case RISCV::PSUB_B:
7587 case RISCV::PSUB_H:
7588 case RISCV::PSUB_W:
7589 case RISCV::QC_ADDSAT:
7590 case RISCV::QC_ADDUSAT:
7591 case RISCV::QC_CSRRWR:
7592 case RISCV::QC_EXTDPR:
7593 case RISCV::QC_EXTDPRH:
7594 case RISCV::QC_EXTDR:
7595 case RISCV::QC_EXTDUPR:
7596 case RISCV::QC_EXTDUPRH:
7597 case RISCV::QC_EXTDUR:
7598 case RISCV::QC_SHLSAT:
7599 case RISCV::QC_SHLUSAT:
7600 case RISCV::QC_SUBSAT:
7601 case RISCV::QC_SUBUSAT:
7602 case RISCV::QC_WRAP:
7603 case RISCV::REM:
7604 case RISCV::REMU:
7605 case RISCV::REMUW:
7606 case RISCV::REMW:
7607 case RISCV::ROL:
7608 case RISCV::ROLW:
7609 case RISCV::ROR:
7610 case RISCV::RORW:
7611 case RISCV::SADD:
7612 case RISCV::SADDU:
7613 case RISCV::SH1ADD:
7614 case RISCV::SH1ADD_UW:
7615 case RISCV::SH2ADD:
7616 case RISCV::SH2ADD_UW:
7617 case RISCV::SH3ADD:
7618 case RISCV::SH3ADD_UW:
7619 case RISCV::SHA:
7620 case RISCV::SHA512SIG0H:
7621 case RISCV::SHA512SIG0L:
7622 case RISCV::SHA512SIG1H:
7623 case RISCV::SHA512SIG1L:
7624 case RISCV::SHA512SUM0R:
7625 case RISCV::SHA512SUM1R:
7626 case RISCV::SHAR:
7627 case RISCV::SHL:
7628 case RISCV::SHLR:
7629 case RISCV::SLL:
7630 case RISCV::SLLW:
7631 case RISCV::SLT:
7632 case RISCV::SLTU:
7633 case RISCV::SRA:
7634 case RISCV::SRAW:
7635 case RISCV::SRL:
7636 case RISCV::SRLW:
7637 case RISCV::SSH1SADD:
7638 case RISCV::SSHA:
7639 case RISCV::SSHAR:
7640 case RISCV::SSHL:
7641 case RISCV::SSHLR:
7642 case RISCV::SSUB:
7643 case RISCV::SSUBU:
7644 case RISCV::SUB:
7645 case RISCV::SUBW:
7646 case RISCV::UNZIP16HP:
7647 case RISCV::UNZIP16P:
7648 case RISCV::UNZIP8HP:
7649 case RISCV::UNZIP8P:
7650 case RISCV::VSETVL:
7651 case RISCV::VT_MASKC:
7652 case RISCV::VT_MASKCN:
7653 case RISCV::XNOR:
7654 case RISCV::XOR:
7655 case RISCV::XPERM4:
7656 case RISCV::XPERM8:
7657 case RISCV::YADD:
7658 case RISCV::YADDRW:
7659 case RISCV::YBLD:
7660 case RISCV::YBNDSRW:
7661 case RISCV::YBNDSW:
7662 case RISCV::YEQ:
7663 case RISCV::YPERMC:
7664 case RISCV::YSS:
7665 case RISCV::YSUNSEAL:
7666 case RISCV::ZIP16HP:
7667 case RISCV::ZIP16P:
7668 case RISCV::ZIP8HP:
7669 case RISCV::ZIP8P: {
7670 // op: rs2
7671 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7672 Value |= (op & 0x1f) << 20;
7673 // op: rs1
7674 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7675 Value |= (op & 0x1f) << 15;
7676 // op: rd
7677 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7678 Value |= (op & 0x1f) << 7;
7679 break;
7680 }
7681 case RISCV::AES32DSI:
7682 case RISCV::AES32DSMI:
7683 case RISCV::AES32ESI:
7684 case RISCV::AES32ESMI:
7685 case RISCV::SM4ED:
7686 case RISCV::SM4KS: {
7687 // op: rs2
7688 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7689 Value |= (op & 0x1f) << 20;
7690 // op: rs1
7691 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7692 Value |= (op & 0x1f) << 15;
7693 // op: rd
7694 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7695 Value |= (op & 0x1f) << 7;
7696 // op: bs
7697 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7698 Value |= (op & 0x3) << 30;
7699 break;
7700 }
7701 case RISCV::QC_LWM:
7702 case RISCV::QC_LWMI:
7703 case RISCV::QC_SETWM:
7704 case RISCV::QC_SETWMI:
7705 case RISCV::QC_SWM:
7706 case RISCV::QC_SWMI: {
7707 // op: rs2
7708 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7709 Value |= (op & 0x1f) << 20;
7710 // op: rs1
7711 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7712 Value |= (op & 0x1f) << 15;
7713 // op: rd
7714 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7715 Value |= (op & 0x1f) << 7;
7716 // op: imm
7717 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7718 Value |= (op & 0x7c) << 23;
7719 break;
7720 }
7721 case RISCV::CV_ADDN:
7722 case RISCV::CV_ADDRN:
7723 case RISCV::CV_ADDUN:
7724 case RISCV::CV_ADDURN:
7725 case RISCV::CV_MULHHSN:
7726 case RISCV::CV_MULHHSRN:
7727 case RISCV::CV_MULHHUN:
7728 case RISCV::CV_MULHHURN:
7729 case RISCV::CV_MULSN:
7730 case RISCV::CV_MULSRN:
7731 case RISCV::CV_MULUN:
7732 case RISCV::CV_MULURN:
7733 case RISCV::CV_SUBN:
7734 case RISCV::CV_SUBRN:
7735 case RISCV::CV_SUBUN:
7736 case RISCV::CV_SUBURN: {
7737 // op: rs2
7738 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7739 Value |= (op & 0x1f) << 20;
7740 // op: rs1
7741 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7742 Value |= (op & 0x1f) << 15;
7743 // op: rd
7744 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7745 Value |= (op & 0x1f) << 7;
7746 // op: imm5
7747 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7748 Value |= (op & 0x1f) << 25;
7749 break;
7750 }
7751 case RISCV::QC_LRB:
7752 case RISCV::QC_LRBU:
7753 case RISCV::QC_LRH:
7754 case RISCV::QC_LRHU:
7755 case RISCV::QC_LRW:
7756 case RISCV::QC_SRB:
7757 case RISCV::QC_SRH:
7758 case RISCV::QC_SRW: {
7759 // op: rs2
7760 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7761 Value |= (op & 0x1f) << 20;
7762 // op: rs1
7763 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7764 Value |= (op & 0x1f) << 15;
7765 // op: rd
7766 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7767 Value |= (op & 0x1f) << 7;
7768 // op: shamt
7769 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7770 Value |= (op & 0x7) << 25;
7771 break;
7772 }
7773 case RISCV::QC_SHLADD: {
7774 // op: rs2
7775 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7776 Value |= (op & 0x1f) << 20;
7777 // op: rs1
7778 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7779 Value |= (op & 0x1f) << 15;
7780 // op: rd
7781 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7782 Value |= (op & 0x1f) << 7;
7783 // op: shamt
7784 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7785 Value |= (op & 0x1f) << 25;
7786 break;
7787 }
7788 case RISCV::TH_ADDSL:
7789 case RISCV::TH_FLRD:
7790 case RISCV::TH_FLRW:
7791 case RISCV::TH_FLURD:
7792 case RISCV::TH_FLURW:
7793 case RISCV::TH_FSRD:
7794 case RISCV::TH_FSRW:
7795 case RISCV::TH_FSURD:
7796 case RISCV::TH_FSURW:
7797 case RISCV::TH_LRB:
7798 case RISCV::TH_LRBU:
7799 case RISCV::TH_LRD:
7800 case RISCV::TH_LRH:
7801 case RISCV::TH_LRHU:
7802 case RISCV::TH_LRW:
7803 case RISCV::TH_LRWU:
7804 case RISCV::TH_LURB:
7805 case RISCV::TH_LURBU:
7806 case RISCV::TH_LURD:
7807 case RISCV::TH_LURH:
7808 case RISCV::TH_LURHU:
7809 case RISCV::TH_LURW:
7810 case RISCV::TH_LURWU:
7811 case RISCV::TH_SRB:
7812 case RISCV::TH_SRD:
7813 case RISCV::TH_SRH:
7814 case RISCV::TH_SRW:
7815 case RISCV::TH_SURB:
7816 case RISCV::TH_SURD:
7817 case RISCV::TH_SURH:
7818 case RISCV::TH_SURW: {
7819 // op: rs2
7820 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7821 Value |= (op & 0x1f) << 20;
7822 // op: rs1
7823 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7824 Value |= (op & 0x1f) << 15;
7825 // op: rd
7826 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7827 Value |= (op & 0x1f) << 7;
7828 // op: uimm2
7829 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7830 Value |= (op & 0x3) << 25;
7831 break;
7832 }
7833 case RISCV::AMOCAS_B:
7834 case RISCV::AMOCAS_B_AQ:
7835 case RISCV::AMOCAS_B_AQRL:
7836 case RISCV::AMOCAS_B_RL:
7837 case RISCV::AMOCAS_D_RV32:
7838 case RISCV::AMOCAS_D_RV32_AQ:
7839 case RISCV::AMOCAS_D_RV32_AQRL:
7840 case RISCV::AMOCAS_D_RV32_RL:
7841 case RISCV::AMOCAS_D_RV64:
7842 case RISCV::AMOCAS_D_RV64_AQ:
7843 case RISCV::AMOCAS_D_RV64_AQRL:
7844 case RISCV::AMOCAS_D_RV64_RL:
7845 case RISCV::AMOCAS_H:
7846 case RISCV::AMOCAS_H_AQ:
7847 case RISCV::AMOCAS_H_AQRL:
7848 case RISCV::AMOCAS_H_RL:
7849 case RISCV::AMOCAS_Q:
7850 case RISCV::AMOCAS_Q_AQ:
7851 case RISCV::AMOCAS_Q_AQRL:
7852 case RISCV::AMOCAS_Q_RL:
7853 case RISCV::AMOCAS_W:
7854 case RISCV::AMOCAS_W_AQ:
7855 case RISCV::AMOCAS_W_AQRL:
7856 case RISCV::AMOCAS_W_RL: {
7857 // op: rs2
7858 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7859 Value |= (op & 0x1f) << 20;
7860 // op: rs1
7861 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7862 Value |= (op & 0x1f) << 15;
7863 // op: rd
7864 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7865 Value |= (op & 0x1f) << 7;
7866 break;
7867 }
7868 case RISCV::AIF_MASKAND:
7869 case RISCV::AIF_MASKOR:
7870 case RISCV::AIF_MASKXOR: {
7871 // op: rs2
7872 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7873 Value |= (op & 0x7) << 20;
7874 // op: rs1
7875 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7876 Value |= (op & 0x7) << 15;
7877 // op: rd
7878 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7879 Value |= (op & 0x7) << 7;
7880 break;
7881 }
7882 case RISCV::C_ADDW:
7883 case RISCV::C_AND:
7884 case RISCV::C_MUL:
7885 case RISCV::C_OR:
7886 case RISCV::C_SUB:
7887 case RISCV::C_SUBW:
7888 case RISCV::C_XOR: {
7889 // op: rs2
7890 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7891 Value |= (op & 0x7) << 2;
7892 // op: rd
7893 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7894 Value |= (op & 0x7) << 7;
7895 break;
7896 }
7897 case RISCV::QC_SELECTIEQI:
7898 case RISCV::QC_SELECTINEI: {
7899 // op: rs2
7900 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7901 Value |= (op & 0x1f) << 20;
7902 // op: rd
7903 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7904 Value |= (op & 0x1f) << 7;
7905 // op: imm
7906 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
7907 Value |= (op & 0x1f) << 15;
7908 // op: simm2
7909 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
7910 Value |= (op & 0x1f) << 27;
7911 break;
7912 }
7913 case RISCV::CV_LBU_rr_inc:
7914 case RISCV::CV_LB_rr_inc:
7915 case RISCV::CV_LHU_rr_inc:
7916 case RISCV::CV_LH_rr_inc:
7917 case RISCV::CV_LW_rr_inc: {
7918 // op: rs2
7919 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7920 Value |= (op & 0x1f) << 20;
7921 // op: rs1
7922 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7923 Value |= (op & 0x1f) << 15;
7924 // op: rd
7925 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7926 Value |= (op & 0x1f) << 7;
7927 break;
7928 }
7929 case RISCV::MQRWACC:
7930 case RISCV::MQWACC:
7931 case RISCV::PM2WADDASU_H:
7932 case RISCV::PM2WADDAU_H:
7933 case RISCV::PM2WADDA_H:
7934 case RISCV::PM2WADDA_HX:
7935 case RISCV::PM2WSUBA_H:
7936 case RISCV::PM2WSUBA_HX:
7937 case RISCV::PMQRWACC_H:
7938 case RISCV::PMQWACC_H:
7939 case RISCV::PWADDAU_B:
7940 case RISCV::PWADDAU_H:
7941 case RISCV::PWADDA_B:
7942 case RISCV::PWADDA_H:
7943 case RISCV::PWMACCSU_H:
7944 case RISCV::PWMACCU_H:
7945 case RISCV::PWMACC_H:
7946 case RISCV::PWSUBAU_B:
7947 case RISCV::PWSUBAU_H:
7948 case RISCV::PWSUBA_B:
7949 case RISCV::PWSUBA_H:
7950 case RISCV::WADDA:
7951 case RISCV::WADDAU:
7952 case RISCV::WMACC:
7953 case RISCV::WMACCSU:
7954 case RISCV::WMACCU:
7955 case RISCV::WSUBA:
7956 case RISCV::WSUBAU: {
7957 // op: rs2
7958 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7959 Value |= (op & 0x1f) << 20;
7960 // op: rs1
7961 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7962 Value |= (op & 0x1f) << 15;
7963 // op: rd
7964 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7965 Value |= (op & 0x1e) << 7;
7966 break;
7967 }
7968 case RISCV::CV_ADDNR:
7969 case RISCV::CV_ADDRNR:
7970 case RISCV::CV_ADDUNR:
7971 case RISCV::CV_ADDURNR:
7972 case RISCV::CV_CPLXMUL_I:
7973 case RISCV::CV_CPLXMUL_I_DIV2:
7974 case RISCV::CV_CPLXMUL_I_DIV4:
7975 case RISCV::CV_CPLXMUL_I_DIV8:
7976 case RISCV::CV_CPLXMUL_R:
7977 case RISCV::CV_CPLXMUL_R_DIV2:
7978 case RISCV::CV_CPLXMUL_R_DIV4:
7979 case RISCV::CV_CPLXMUL_R_DIV8:
7980 case RISCV::CV_INSERTR:
7981 case RISCV::CV_MAC:
7982 case RISCV::CV_MSU:
7983 case RISCV::CV_PACKHI_B:
7984 case RISCV::CV_PACKLO_B:
7985 case RISCV::CV_SDOTSP_B:
7986 case RISCV::CV_SDOTSP_H:
7987 case RISCV::CV_SDOTSP_SC_B:
7988 case RISCV::CV_SDOTSP_SC_H:
7989 case RISCV::CV_SDOTUP_B:
7990 case RISCV::CV_SDOTUP_H:
7991 case RISCV::CV_SDOTUP_SC_B:
7992 case RISCV::CV_SDOTUP_SC_H:
7993 case RISCV::CV_SDOTUSP_B:
7994 case RISCV::CV_SDOTUSP_H:
7995 case RISCV::CV_SDOTUSP_SC_B:
7996 case RISCV::CV_SDOTUSP_SC_H:
7997 case RISCV::CV_SHUFFLE2_B:
7998 case RISCV::CV_SHUFFLE2_H:
7999 case RISCV::CV_SUBNR:
8000 case RISCV::CV_SUBRNR:
8001 case RISCV::CV_SUBUNR:
8002 case RISCV::CV_SUBURNR:
8003 case RISCV::MACCSU_H00:
8004 case RISCV::MACCSU_H11:
8005 case RISCV::MACCSU_W00:
8006 case RISCV::MACCSU_W11:
8007 case RISCV::MACCU_H00:
8008 case RISCV::MACCU_H01:
8009 case RISCV::MACCU_H11:
8010 case RISCV::MACCU_W00:
8011 case RISCV::MACCU_W01:
8012 case RISCV::MACCU_W11:
8013 case RISCV::MACC_H00:
8014 case RISCV::MACC_H01:
8015 case RISCV::MACC_H11:
8016 case RISCV::MACC_W00:
8017 case RISCV::MACC_W01:
8018 case RISCV::MACC_W11:
8019 case RISCV::MERGE:
8020 case RISCV::MHACC:
8021 case RISCV::MHACCSU:
8022 case RISCV::MHACCSU_H0:
8023 case RISCV::MHACCSU_H1:
8024 case RISCV::MHACCU:
8025 case RISCV::MHACC_H0:
8026 case RISCV::MHACC_H1:
8027 case RISCV::MHRACC:
8028 case RISCV::MHRACCSU:
8029 case RISCV::MHRACCU:
8030 case RISCV::MQACC_H00:
8031 case RISCV::MQACC_H01:
8032 case RISCV::MQACC_H11:
8033 case RISCV::MQACC_W00:
8034 case RISCV::MQACC_W01:
8035 case RISCV::MQACC_W11:
8036 case RISCV::MQRACC_H00:
8037 case RISCV::MQRACC_H01:
8038 case RISCV::MQRACC_H11:
8039 case RISCV::MQRACC_W00:
8040 case RISCV::MQRACC_W01:
8041 case RISCV::MQRACC_W11:
8042 case RISCV::MVM:
8043 case RISCV::MVMN:
8044 case RISCV::PABDSUMAU_B:
8045 case RISCV::PM2ADDASU_H:
8046 case RISCV::PM2ADDASU_W:
8047 case RISCV::PM2ADDAU_H:
8048 case RISCV::PM2ADDAU_W:
8049 case RISCV::PM2ADDA_H:
8050 case RISCV::PM2ADDA_HX:
8051 case RISCV::PM2ADDA_W:
8052 case RISCV::PM2ADDA_WX:
8053 case RISCV::PM2SUBA_H:
8054 case RISCV::PM2SUBA_HX:
8055 case RISCV::PM2SUBA_W:
8056 case RISCV::PM2SUBA_WX:
8057 case RISCV::PM4ADDASU_B:
8058 case RISCV::PM4ADDASU_H:
8059 case RISCV::PM4ADDAU_B:
8060 case RISCV::PM4ADDAU_H:
8061 case RISCV::PM4ADDA_B:
8062 case RISCV::PM4ADDA_H:
8063 case RISCV::PMACCSU_W_H00:
8064 case RISCV::PMACCSU_W_H11:
8065 case RISCV::PMACCU_W_H00:
8066 case RISCV::PMACCU_W_H01:
8067 case RISCV::PMACCU_W_H11:
8068 case RISCV::PMACC_W_H00:
8069 case RISCV::PMACC_W_H01:
8070 case RISCV::PMACC_W_H11:
8071 case RISCV::PMHACCSU_H:
8072 case RISCV::PMHACCSU_H_B0:
8073 case RISCV::PMHACCSU_H_B1:
8074 case RISCV::PMHACCSU_W:
8075 case RISCV::PMHACCSU_W_H0:
8076 case RISCV::PMHACCSU_W_H1:
8077 case RISCV::PMHACCU_H:
8078 case RISCV::PMHACCU_W:
8079 case RISCV::PMHACC_H:
8080 case RISCV::PMHACC_H_B0:
8081 case RISCV::PMHACC_H_B1:
8082 case RISCV::PMHACC_W:
8083 case RISCV::PMHACC_W_H0:
8084 case RISCV::PMHACC_W_H1:
8085 case RISCV::PMHRACCSU_H:
8086 case RISCV::PMHRACCSU_W:
8087 case RISCV::PMHRACCU_H:
8088 case RISCV::PMHRACCU_W:
8089 case RISCV::PMHRACC_H:
8090 case RISCV::PMHRACC_W:
8091 case RISCV::PMQ2ADDA_H:
8092 case RISCV::PMQ2ADDA_W:
8093 case RISCV::PMQACC_W_H00:
8094 case RISCV::PMQACC_W_H01:
8095 case RISCV::PMQACC_W_H11:
8096 case RISCV::PMQR2ADDA_H:
8097 case RISCV::PMQR2ADDA_W:
8098 case RISCV::PMQRACC_W_H00:
8099 case RISCV::PMQRACC_W_H01:
8100 case RISCV::PMQRACC_W_H11:
8101 case RISCV::QC_INSBHR:
8102 case RISCV::QC_INSBPR:
8103 case RISCV::QC_INSBPRH:
8104 case RISCV::QC_INSBR:
8105 case RISCV::SLX:
8106 case RISCV::SRX:
8107 case RISCV::TH_MULA:
8108 case RISCV::TH_MULAH:
8109 case RISCV::TH_MULAW:
8110 case RISCV::TH_MULS:
8111 case RISCV::TH_MULSH:
8112 case RISCV::TH_MULSW:
8113 case RISCV::TH_MVEQZ:
8114 case RISCV::TH_MVNEZ: {
8115 // op: rs2
8116 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8117 Value |= (op & 0x1f) << 20;
8118 // op: rs1
8119 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8120 Value |= (op & 0x1f) << 15;
8121 // op: rd
8122 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8123 Value |= (op & 0x1f) << 7;
8124 break;
8125 }
8126 case RISCV::CV_MACHHSN:
8127 case RISCV::CV_MACHHSRN:
8128 case RISCV::CV_MACHHUN:
8129 case RISCV::CV_MACHHURN:
8130 case RISCV::CV_MACSN:
8131 case RISCV::CV_MACSRN:
8132 case RISCV::CV_MACUN:
8133 case RISCV::CV_MACURN: {
8134 // op: rs2
8135 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8136 Value |= (op & 0x1f) << 20;
8137 // op: rs1
8138 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8139 Value |= (op & 0x1f) << 15;
8140 // op: rd
8141 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8142 Value |= (op & 0x1f) << 7;
8143 // op: imm5
8144 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8145 Value |= (op & 0x1f) << 25;
8146 break;
8147 }
8148 case RISCV::QC_LIEQ:
8149 case RISCV::QC_LIGE:
8150 case RISCV::QC_LIGEU:
8151 case RISCV::QC_LILT:
8152 case RISCV::QC_LILTU:
8153 case RISCV::QC_LINE: {
8154 // op: rs2
8155 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8156 Value |= (op & 0x1f) << 20;
8157 // op: rs1
8158 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8159 Value |= (op & 0x1f) << 15;
8160 // op: rd
8161 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8162 Value |= (op & 0x1f) << 7;
8163 // op: simm
8164 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8165 Value |= (op & 0x1f) << 27;
8166 break;
8167 }
8168 case RISCV::QC_SELECTIEQ:
8169 case RISCV::QC_SELECTINE: {
8170 // op: rs2
8171 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8172 Value |= (op & 0x1f) << 20;
8173 // op: rs1
8174 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8175 Value |= (op & 0x1f) << 15;
8176 // op: rd
8177 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8178 Value |= (op & 0x1f) << 7;
8179 // op: simm2
8180 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8181 Value |= (op & 0x1f) << 27;
8182 break;
8183 }
8184 case RISCV::FMADD_D:
8185 case RISCV::FMADD_D_IN32X:
8186 case RISCV::FMADD_D_INX:
8187 case RISCV::FMADD_H:
8188 case RISCV::FMADD_H_INX:
8189 case RISCV::FMADD_Q:
8190 case RISCV::FMADD_S:
8191 case RISCV::FMADD_S_INX:
8192 case RISCV::FMSUB_D:
8193 case RISCV::FMSUB_D_IN32X:
8194 case RISCV::FMSUB_D_INX:
8195 case RISCV::FMSUB_H:
8196 case RISCV::FMSUB_H_INX:
8197 case RISCV::FMSUB_Q:
8198 case RISCV::FMSUB_S:
8199 case RISCV::FMSUB_S_INX:
8200 case RISCV::FNMADD_D:
8201 case RISCV::FNMADD_D_IN32X:
8202 case RISCV::FNMADD_D_INX:
8203 case RISCV::FNMADD_H:
8204 case RISCV::FNMADD_H_INX:
8205 case RISCV::FNMADD_Q:
8206 case RISCV::FNMADD_S:
8207 case RISCV::FNMADD_S_INX:
8208 case RISCV::FNMSUB_D:
8209 case RISCV::FNMSUB_D_IN32X:
8210 case RISCV::FNMSUB_D_INX:
8211 case RISCV::FNMSUB_H:
8212 case RISCV::FNMSUB_H_INX:
8213 case RISCV::FNMSUB_Q:
8214 case RISCV::FNMSUB_S:
8215 case RISCV::FNMSUB_S_INX: {
8216 // op: rs3
8217 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8218 Value |= (op & 0x1f) << 27;
8219 // op: rs2
8220 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8221 Value |= (op & 0x1f) << 20;
8222 // op: rs1
8223 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8224 Value |= (op & 0x1f) << 15;
8225 // op: frm
8226 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8227 Value |= (op & 0x7) << 12;
8228 // op: rd
8229 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8230 Value |= (op & 0x1f) << 7;
8231 break;
8232 }
8233 case RISCV::MIPS_CCMOV: {
8234 // op: rs3
8235 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8236 Value |= (op & 0x1f) << 27;
8237 // op: rs2
8238 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8239 Value |= (op & 0x1f) << 20;
8240 // op: rs1
8241 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8242 Value |= (op & 0x1f) << 15;
8243 // op: rd
8244 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8245 Value |= (op & 0x1f) << 7;
8246 break;
8247 }
8248 case RISCV::CV_SB_rr_inc:
8249 case RISCV::CV_SH_rr_inc:
8250 case RISCV::CV_SW_rr_inc: {
8251 // op: rs3
8252 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8253 Value |= (op & 0x1f) << 7;
8254 // op: rs2
8255 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8256 Value |= (op & 0x1f) << 20;
8257 // op: rs1
8258 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8259 Value |= (op & 0x1f) << 15;
8260 break;
8261 }
8262 case RISCV::QC_MVEQI:
8263 case RISCV::QC_MVGEI:
8264 case RISCV::QC_MVGEUI:
8265 case RISCV::QC_MVLTI:
8266 case RISCV::QC_MVLTUI:
8267 case RISCV::QC_MVNEI: {
8268 // op: rs3
8269 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8270 Value |= (op & 0x1f) << 27;
8271 // op: rs1
8272 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8273 Value |= (op & 0x1f) << 15;
8274 // op: rd
8275 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8276 Value |= (op & 0x1f) << 7;
8277 // op: imm
8278 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
8279 Value |= (op & 0x1f) << 20;
8280 break;
8281 }
8282 case RISCV::QC_SELECTEQI:
8283 case RISCV::QC_SELECTNEI: {
8284 // op: rs3
8285 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8286 Value |= (op & 0x1f) << 27;
8287 // op: rs2
8288 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8289 Value |= (op & 0x1f) << 20;
8290 // op: rd
8291 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8292 Value |= (op & 0x1f) << 7;
8293 // op: imm
8294 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8295 Value |= (op & 0x1f) << 15;
8296 break;
8297 }
8298 case RISCV::QC_MVEQ:
8299 case RISCV::QC_MVGE:
8300 case RISCV::QC_MVGEU:
8301 case RISCV::QC_MVLT:
8302 case RISCV::QC_MVLTU:
8303 case RISCV::QC_MVNE: {
8304 // op: rs3
8305 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8306 Value |= (op & 0x1f) << 27;
8307 // op: rs2
8308 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8309 Value |= (op & 0x1f) << 20;
8310 // op: rs1
8311 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8312 Value |= (op & 0x1f) << 15;
8313 // op: rd
8314 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8315 Value |= (op & 0x1f) << 7;
8316 break;
8317 }
8318 case RISCV::QC_C_SYNC:
8319 case RISCV::QC_C_SYNCR:
8320 case RISCV::QC_C_SYNCWF:
8321 case RISCV::QC_C_SYNCWL: {
8322 // op: slist
8323 op = getImmOpValueSlist(MI, OpNo: 0, Fixups, STI);
8324 Value |= (op & 0x7) << 7;
8325 break;
8326 }
8327 case RISCV::Insn16: {
8328 // op: value
8329 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8330 Value |= (op & 0xffff);
8331 break;
8332 }
8333 case RISCV::Insn32: {
8334 // op: value
8335 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8336 Value |= (op & 0xffffffff);
8337 break;
8338 }
8339 case RISCV::Insn48: {
8340 // op: value
8341 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8342 Value |= (op & 0xffffffffffff);
8343 break;
8344 }
8345 case RISCV::Insn64: {
8346 // op: value
8347 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8348 Value |= (op & 0xffffffffffffffff);
8349 break;
8350 }
8351 case RISCV::VMV_V_I: {
8352 // op: vd
8353 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8354 Value |= (op & 0x1f) << 7;
8355 // op: imm
8356 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
8357 Value |= (op & 0x1f) << 15;
8358 break;
8359 }
8360 case RISCV::VFMV_V_F:
8361 case RISCV::VMV_V_X: {
8362 // op: vd
8363 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8364 Value |= (op & 0x1f) << 7;
8365 // op: rs1
8366 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8367 Value |= (op & 0x1f) << 15;
8368 break;
8369 }
8370 case RISCV::VMTL_V:
8371 case RISCV::VMTTL_V: {
8372 // op: vd
8373 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8374 Value |= (op & 0x1f) << 7;
8375 // op: rs1
8376 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8377 Value |= (op & 0x1f) << 15;
8378 // op: rs2
8379 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8380 Value |= (op & 0x1f) << 20;
8381 // op: vm
8382 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8383 Value |= (op & 0x1) << 25;
8384 // op: vlambda
8385 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
8386 Value |= (op & 0x7) << 29;
8387 break;
8388 }
8389 case RISCV::VID_V: {
8390 // op: vd
8391 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8392 Value |= (op & 0x1f) << 7;
8393 // op: vm
8394 op = getVMaskReg(MI, OpNo: 1, Fixups, STI);
8395 Value |= (op & 0x1) << 25;
8396 break;
8397 }
8398 case RISCV::SF_VFEXPA_V:
8399 case RISCV::SF_VFEXP_V:
8400 case RISCV::VABS_V:
8401 case RISCV::VBREV8_V:
8402 case RISCV::VBREV_V:
8403 case RISCV::VCLZ_V:
8404 case RISCV::VCPOP_V:
8405 case RISCV::VCTZ_V:
8406 case RISCV::VFCLASS_V:
8407 case RISCV::VFCVT_F_XU_V:
8408 case RISCV::VFCVT_F_X_V:
8409 case RISCV::VFCVT_RTZ_XU_F_V:
8410 case RISCV::VFCVT_RTZ_X_F_V:
8411 case RISCV::VFCVT_XU_F_V:
8412 case RISCV::VFCVT_X_F_V:
8413 case RISCV::VFNCVTBF16_F_F_W:
8414 case RISCV::VFNCVTBF16_SAT_F_F_W:
8415 case RISCV::VFNCVT_F_F_Q:
8416 case RISCV::VFNCVT_F_F_W:
8417 case RISCV::VFNCVT_F_XU_W:
8418 case RISCV::VFNCVT_F_X_W:
8419 case RISCV::VFNCVT_ROD_F_F_W:
8420 case RISCV::VFNCVT_RTZ_XU_F_W:
8421 case RISCV::VFNCVT_RTZ_X_F_W:
8422 case RISCV::VFNCVT_SAT_F_F_Q:
8423 case RISCV::VFNCVT_XU_F_W:
8424 case RISCV::VFNCVT_X_F_W:
8425 case RISCV::VFREC7_V:
8426 case RISCV::VFRSQRT7_V:
8427 case RISCV::VFSQRT_V:
8428 case RISCV::VFWCVTBF16_F_F_V:
8429 case RISCV::VFWCVT_F_F_V:
8430 case RISCV::VFWCVT_F_XU_V:
8431 case RISCV::VFWCVT_F_X_V:
8432 case RISCV::VFWCVT_RTZ_XU_F_V:
8433 case RISCV::VFWCVT_RTZ_X_F_V:
8434 case RISCV::VFWCVT_XU_F_V:
8435 case RISCV::VFWCVT_X_F_V:
8436 case RISCV::VIOTA_M:
8437 case RISCV::VMSBF_M:
8438 case RISCV::VMSIF_M:
8439 case RISCV::VMSOF_M:
8440 case RISCV::VREV8_V:
8441 case RISCV::VSEXT_VF2:
8442 case RISCV::VSEXT_VF4:
8443 case RISCV::VSEXT_VF8:
8444 case RISCV::VUNZIPE_V:
8445 case RISCV::VUNZIPO_V:
8446 case RISCV::VZEXT_VF2:
8447 case RISCV::VZEXT_VF4:
8448 case RISCV::VZEXT_VF8: {
8449 // op: vd
8450 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8451 Value |= (op & 0x1f) << 7;
8452 // op: vm
8453 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
8454 Value |= (op & 0x1) << 25;
8455 // op: vs2
8456 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8457 Value |= (op & 0x1f) << 20;
8458 break;
8459 }
8460 case RISCV::VADD_VI:
8461 case RISCV::VAND_VI:
8462 case RISCV::VMSEQ_VI:
8463 case RISCV::VMSGTU_VI:
8464 case RISCV::VMSGT_VI:
8465 case RISCV::VMSLEU_VI:
8466 case RISCV::VMSLE_VI:
8467 case RISCV::VMSNE_VI:
8468 case RISCV::VNCLIPU_WI:
8469 case RISCV::VNCLIP_WI:
8470 case RISCV::VNSRA_WI:
8471 case RISCV::VNSRL_WI:
8472 case RISCV::VOR_VI:
8473 case RISCV::VRGATHER_VI:
8474 case RISCV::VRSUB_VI:
8475 case RISCV::VSADDU_VI:
8476 case RISCV::VSADD_VI:
8477 case RISCV::VSLIDEDOWN_VI:
8478 case RISCV::VSLIDEUP_VI:
8479 case RISCV::VSLL_VI:
8480 case RISCV::VSRA_VI:
8481 case RISCV::VSRL_VI:
8482 case RISCV::VSSRA_VI:
8483 case RISCV::VSSRL_VI:
8484 case RISCV::VWSLL_VI:
8485 case RISCV::VXOR_VI: {
8486 // op: vd
8487 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8488 Value |= (op & 0x1f) << 7;
8489 // op: vm
8490 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8491 Value |= (op & 0x1) << 25;
8492 // op: vs2
8493 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8494 Value |= (op & 0x1f) << 20;
8495 // op: imm
8496 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8497 Value |= (op & 0x1f) << 15;
8498 break;
8499 }
8500 case RISCV::VROR_VI: {
8501 // op: vd
8502 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8503 Value |= (op & 0x1f) << 7;
8504 // op: vm
8505 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8506 Value |= (op & 0x1) << 25;
8507 // op: vs2
8508 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8509 Value |= (op & 0x1f) << 20;
8510 // op: imm
8511 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8512 Value |= (op & 0x20) << 21;
8513 Value |= (op & 0x1f) << 15;
8514 break;
8515 }
8516 case RISCV::SF_VFNRCLIP_XU_F_QF:
8517 case RISCV::SF_VFNRCLIP_X_F_QF:
8518 case RISCV::VAADDU_VX:
8519 case RISCV::VAADD_VX:
8520 case RISCV::VADD_VX:
8521 case RISCV::VANDN_VX:
8522 case RISCV::VAND_VX:
8523 case RISCV::VASUBU_VX:
8524 case RISCV::VASUB_VX:
8525 case RISCV::VCLMULH_VX:
8526 case RISCV::VCLMUL_VX:
8527 case RISCV::VDIVU_VX:
8528 case RISCV::VDIV_VX:
8529 case RISCV::VFADD_VF:
8530 case RISCV::VFDIV_VF:
8531 case RISCV::VFMAX_VF:
8532 case RISCV::VFMIN_VF:
8533 case RISCV::VFMUL_VF:
8534 case RISCV::VFRDIV_VF:
8535 case RISCV::VFRSUB_VF:
8536 case RISCV::VFSGNJN_VF:
8537 case RISCV::VFSGNJX_VF:
8538 case RISCV::VFSGNJ_VF:
8539 case RISCV::VFSLIDE1DOWN_VF:
8540 case RISCV::VFSLIDE1UP_VF:
8541 case RISCV::VFSUB_VF:
8542 case RISCV::VFWADD_VF:
8543 case RISCV::VFWADD_WF:
8544 case RISCV::VFWMUL_VF:
8545 case RISCV::VFWSUB_VF:
8546 case RISCV::VFWSUB_WF:
8547 case RISCV::VMAXU_VX:
8548 case RISCV::VMAX_VX:
8549 case RISCV::VMFEQ_VF:
8550 case RISCV::VMFGE_VF:
8551 case RISCV::VMFGT_VF:
8552 case RISCV::VMFLE_VF:
8553 case RISCV::VMFLT_VF:
8554 case RISCV::VMFNE_VF:
8555 case RISCV::VMINU_VX:
8556 case RISCV::VMIN_VX:
8557 case RISCV::VMSEQ_VX:
8558 case RISCV::VMSGTU_VX:
8559 case RISCV::VMSGT_VX:
8560 case RISCV::VMSLEU_VX:
8561 case RISCV::VMSLE_VX:
8562 case RISCV::VMSLTU_VX:
8563 case RISCV::VMSLT_VX:
8564 case RISCV::VMSNE_VX:
8565 case RISCV::VMULHSU_VX:
8566 case RISCV::VMULHU_VX:
8567 case RISCV::VMULH_VX:
8568 case RISCV::VMUL_VX:
8569 case RISCV::VNCLIPU_WX:
8570 case RISCV::VNCLIP_WX:
8571 case RISCV::VNSRA_WX:
8572 case RISCV::VNSRL_WX:
8573 case RISCV::VOR_VX:
8574 case RISCV::VREMU_VX:
8575 case RISCV::VREM_VX:
8576 case RISCV::VRGATHER_VX:
8577 case RISCV::VROL_VX:
8578 case RISCV::VROR_VX:
8579 case RISCV::VRSUB_VX:
8580 case RISCV::VSADDU_VX:
8581 case RISCV::VSADD_VX:
8582 case RISCV::VSLIDE1DOWN_VX:
8583 case RISCV::VSLIDE1UP_VX:
8584 case RISCV::VSLIDEDOWN_VX:
8585 case RISCV::VSLIDEUP_VX:
8586 case RISCV::VSLL_VX:
8587 case RISCV::VSMUL_VX:
8588 case RISCV::VSRA_VX:
8589 case RISCV::VSRL_VX:
8590 case RISCV::VSSRA_VX:
8591 case RISCV::VSSRL_VX:
8592 case RISCV::VSSUBU_VX:
8593 case RISCV::VSSUB_VX:
8594 case RISCV::VSUB_VX:
8595 case RISCV::VWADDU_VX:
8596 case RISCV::VWADDU_WX:
8597 case RISCV::VWADD_VX:
8598 case RISCV::VWADD_WX:
8599 case RISCV::VWMULSU_VX:
8600 case RISCV::VWMULU_VX:
8601 case RISCV::VWMUL_VX:
8602 case RISCV::VWSLL_VX:
8603 case RISCV::VWSUBU_VX:
8604 case RISCV::VWSUBU_WX:
8605 case RISCV::VWSUB_VX:
8606 case RISCV::VWSUB_WX:
8607 case RISCV::VXOR_VX: {
8608 // op: vd
8609 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8610 Value |= (op & 0x1f) << 7;
8611 // op: vm
8612 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8613 Value |= (op & 0x1) << 25;
8614 // op: vs2
8615 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8616 Value |= (op & 0x1f) << 20;
8617 // op: rs1
8618 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8619 Value |= (op & 0x1f) << 15;
8620 break;
8621 }
8622 case RISCV::VAADDU_VV:
8623 case RISCV::VAADD_VV:
8624 case RISCV::VABDU_VV:
8625 case RISCV::VABD_VV:
8626 case RISCV::VADD_VV:
8627 case RISCV::VANDN_VV:
8628 case RISCV::VAND_VV:
8629 case RISCV::VASUBU_VV:
8630 case RISCV::VASUB_VV:
8631 case RISCV::VCLMULH_VV:
8632 case RISCV::VCLMUL_VV:
8633 case RISCV::VDIVU_VV:
8634 case RISCV::VDIV_VV:
8635 case RISCV::VFADD_VV:
8636 case RISCV::VFDIV_VV:
8637 case RISCV::VFMAX_VV:
8638 case RISCV::VFMIN_VV:
8639 case RISCV::VFMUL_VV:
8640 case RISCV::VFREDMAX_VS:
8641 case RISCV::VFREDMIN_VS:
8642 case RISCV::VFREDOSUM_VS:
8643 case RISCV::VFREDUSUM_VS:
8644 case RISCV::VFSGNJN_VV:
8645 case RISCV::VFSGNJX_VV:
8646 case RISCV::VFSGNJ_VV:
8647 case RISCV::VFSUB_VV:
8648 case RISCV::VFWADD_VV:
8649 case RISCV::VFWADD_WV:
8650 case RISCV::VFWMUL_VV:
8651 case RISCV::VFWREDOSUM_VS:
8652 case RISCV::VFWREDUSUM_VS:
8653 case RISCV::VFWSUB_VV:
8654 case RISCV::VFWSUB_WV:
8655 case RISCV::VMAXU_VV:
8656 case RISCV::VMAX_VV:
8657 case RISCV::VMFEQ_VV:
8658 case RISCV::VMFLE_VV:
8659 case RISCV::VMFLT_VV:
8660 case RISCV::VMFNE_VV:
8661 case RISCV::VMINU_VV:
8662 case RISCV::VMIN_VV:
8663 case RISCV::VMSEQ_VV:
8664 case RISCV::VMSLEU_VV:
8665 case RISCV::VMSLE_VV:
8666 case RISCV::VMSLTU_VV:
8667 case RISCV::VMSLT_VV:
8668 case RISCV::VMSNE_VV:
8669 case RISCV::VMULHSU_VV:
8670 case RISCV::VMULHU_VV:
8671 case RISCV::VMULH_VV:
8672 case RISCV::VMUL_VV:
8673 case RISCV::VNCLIPU_WV:
8674 case RISCV::VNCLIP_WV:
8675 case RISCV::VNSRA_WV:
8676 case RISCV::VNSRL_WV:
8677 case RISCV::VOR_VV:
8678 case RISCV::VPAIRE_VV:
8679 case RISCV::VPAIRO_VV:
8680 case RISCV::VREDAND_VS:
8681 case RISCV::VREDMAXU_VS:
8682 case RISCV::VREDMAX_VS:
8683 case RISCV::VREDMINU_VS:
8684 case RISCV::VREDMIN_VS:
8685 case RISCV::VREDOR_VS:
8686 case RISCV::VREDSUM_VS:
8687 case RISCV::VREDXOR_VS:
8688 case RISCV::VREMU_VV:
8689 case RISCV::VREM_VV:
8690 case RISCV::VRGATHEREI16_VV:
8691 case RISCV::VRGATHER_VV:
8692 case RISCV::VROL_VV:
8693 case RISCV::VROR_VV:
8694 case RISCV::VSADDU_VV:
8695 case RISCV::VSADD_VV:
8696 case RISCV::VSLL_VV:
8697 case RISCV::VSMUL_VV:
8698 case RISCV::VSRA_VV:
8699 case RISCV::VSRL_VV:
8700 case RISCV::VSSRA_VV:
8701 case RISCV::VSSRL_VV:
8702 case RISCV::VSSUBU_VV:
8703 case RISCV::VSSUB_VV:
8704 case RISCV::VSUB_VV:
8705 case RISCV::VWABDAU_VV:
8706 case RISCV::VWABDA_VV:
8707 case RISCV::VWADDU_VV:
8708 case RISCV::VWADDU_WV:
8709 case RISCV::VWADD_VV:
8710 case RISCV::VWADD_WV:
8711 case RISCV::VWMULSU_VV:
8712 case RISCV::VWMULU_VV:
8713 case RISCV::VWMUL_VV:
8714 case RISCV::VWREDSUMU_VS:
8715 case RISCV::VWREDSUM_VS:
8716 case RISCV::VWSLL_VV:
8717 case RISCV::VWSUBU_VV:
8718 case RISCV::VWSUBU_WV:
8719 case RISCV::VWSUB_VV:
8720 case RISCV::VWSUB_WV:
8721 case RISCV::VXOR_VV:
8722 case RISCV::VZIP_VV: {
8723 // op: vd
8724 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8725 Value |= (op & 0x1f) << 7;
8726 // op: vm
8727 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8728 Value |= (op & 0x1) << 25;
8729 // op: vs2
8730 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8731 Value |= (op & 0x1f) << 20;
8732 // op: vs1
8733 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8734 Value |= (op & 0x1f) << 15;
8735 break;
8736 }
8737 case RISCV::VMV_V_V: {
8738 // op: vd
8739 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8740 Value |= (op & 0x1f) << 7;
8741 // op: vs1
8742 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8743 Value |= (op & 0x1f) << 15;
8744 break;
8745 }
8746 case RISCV::VMV1R_V:
8747 case RISCV::VMV2R_V:
8748 case RISCV::VMV4R_V:
8749 case RISCV::VMV8R_V: {
8750 // op: vd
8751 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8752 Value |= (op & 0x1f) << 7;
8753 // op: vs2
8754 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8755 Value |= (op & 0x1f) << 20;
8756 break;
8757 }
8758 case RISCV::VADC_VIM:
8759 case RISCV::VAESKF1_VI:
8760 case RISCV::VMADC_VI:
8761 case RISCV::VMADC_VIM:
8762 case RISCV::VMERGE_VIM:
8763 case RISCV::VSM4K_VI: {
8764 // op: vd
8765 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8766 Value |= (op & 0x1f) << 7;
8767 // op: vs2
8768 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8769 Value |= (op & 0x1f) << 20;
8770 // op: imm
8771 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8772 Value |= (op & 0x1f) << 15;
8773 break;
8774 }
8775 case RISCV::VADC_VXM:
8776 case RISCV::VFMERGE_VFM:
8777 case RISCV::VMADC_VX:
8778 case RISCV::VMADC_VXM:
8779 case RISCV::VMERGE_VXM:
8780 case RISCV::VMSBC_VX:
8781 case RISCV::VMSBC_VXM:
8782 case RISCV::VSBC_VXM: {
8783 // op: vd
8784 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8785 Value |= (op & 0x1f) << 7;
8786 // op: vs2
8787 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8788 Value |= (op & 0x1f) << 20;
8789 // op: rs1
8790 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8791 Value |= (op & 0x1f) << 15;
8792 break;
8793 }
8794 case RISCV::VADC_VVM:
8795 case RISCV::VCOMPRESS_VM:
8796 case RISCV::VMADC_VV:
8797 case RISCV::VMADC_VVM:
8798 case RISCV::VMANDN_MM:
8799 case RISCV::VMAND_MM:
8800 case RISCV::VMERGE_VVM:
8801 case RISCV::VMNAND_MM:
8802 case RISCV::VMNOR_MM:
8803 case RISCV::VMORN_MM:
8804 case RISCV::VMOR_MM:
8805 case RISCV::VMSBC_VV:
8806 case RISCV::VMSBC_VVM:
8807 case RISCV::VMXNOR_MM:
8808 case RISCV::VMXOR_MM:
8809 case RISCV::VSBC_VVM:
8810 case RISCV::VSM3ME_VV: {
8811 // op: vd
8812 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8813 Value |= (op & 0x1f) << 7;
8814 // op: vs2
8815 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8816 Value |= (op & 0x1f) << 20;
8817 // op: vs1
8818 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8819 Value |= (op & 0x1f) << 15;
8820 break;
8821 }
8822 case RISCV::VFMV_S_F:
8823 case RISCV::VMV_S_X: {
8824 // op: vd
8825 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8826 Value |= (op & 0x1f) << 7;
8827 // op: rs1
8828 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8829 Value |= (op & 0x1f) << 15;
8830 break;
8831 }
8832 case RISCV::VDOT4ASU_VX:
8833 case RISCV::VDOT4AUS_VX:
8834 case RISCV::VDOT4AU_VX:
8835 case RISCV::VDOT4A_VX: {
8836 // op: vd
8837 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8838 Value |= (op & 0x1f) << 7;
8839 // op: vm
8840 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8841 Value |= (op & 0x1) << 25;
8842 // op: vs2
8843 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8844 Value |= (op & 0x1f) << 20;
8845 // op: rs1
8846 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8847 Value |= (op & 0x1f) << 15;
8848 break;
8849 }
8850 case RISCV::VDOT4ASU_VV:
8851 case RISCV::VDOT4AU_VV:
8852 case RISCV::VDOT4A_VV:
8853 case RISCV::VFQWDOTA_ALT_VV:
8854 case RISCV::VFQWDOTA_VV:
8855 case RISCV::VFWDOTA_VV:
8856 case RISCV::VQWDOTAS_VV:
8857 case RISCV::VQWDOTAU_VV: {
8858 // op: vd
8859 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8860 Value |= (op & 0x1f) << 7;
8861 // op: vm
8862 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8863 Value |= (op & 0x1) << 25;
8864 // op: vs2
8865 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8866 Value |= (op & 0x1f) << 20;
8867 // op: vs1
8868 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8869 Value |= (op & 0x1f) << 15;
8870 break;
8871 }
8872 case RISCV::TH_VMAQASU_VX:
8873 case RISCV::TH_VMAQAUS_VX:
8874 case RISCV::TH_VMAQAU_VX:
8875 case RISCV::TH_VMAQA_VX:
8876 case RISCV::VFMACC_VF:
8877 case RISCV::VFMADD_VF:
8878 case RISCV::VFMSAC_VF:
8879 case RISCV::VFMSUB_VF:
8880 case RISCV::VFNMACC_VF:
8881 case RISCV::VFNMADD_VF:
8882 case RISCV::VFNMSAC_VF:
8883 case RISCV::VFNMSUB_VF:
8884 case RISCV::VFWMACCBF16_VF:
8885 case RISCV::VFWMACC_VF:
8886 case RISCV::VFWMSAC_VF:
8887 case RISCV::VFWNMACC_VF:
8888 case RISCV::VFWNMSAC_VF:
8889 case RISCV::VMACC_VX:
8890 case RISCV::VMADD_VX:
8891 case RISCV::VNMSAC_VX:
8892 case RISCV::VNMSUB_VX:
8893 case RISCV::VWMACCSU_VX:
8894 case RISCV::VWMACCUS_VX:
8895 case RISCV::VWMACCU_VX:
8896 case RISCV::VWMACC_VX: {
8897 // op: vd
8898 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8899 Value |= (op & 0x1f) << 7;
8900 // op: vm
8901 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8902 Value |= (op & 0x1) << 25;
8903 // op: vs2
8904 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8905 Value |= (op & 0x1f) << 20;
8906 // op: rs1
8907 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8908 Value |= (op & 0x1f) << 15;
8909 break;
8910 }
8911 case RISCV::TH_VMAQASU_VV:
8912 case RISCV::TH_VMAQAU_VV:
8913 case RISCV::TH_VMAQA_VV:
8914 case RISCV::VFMACC_VV:
8915 case RISCV::VFMADD_VV:
8916 case RISCV::VFMSAC_VV:
8917 case RISCV::VFMSUB_VV:
8918 case RISCV::VFNMACC_VV:
8919 case RISCV::VFNMADD_VV:
8920 case RISCV::VFNMSAC_VV:
8921 case RISCV::VFNMSUB_VV:
8922 case RISCV::VFWMACCBF16_VV:
8923 case RISCV::VFWMACC_VV:
8924 case RISCV::VFWMSAC_VV:
8925 case RISCV::VFWNMACC_VV:
8926 case RISCV::VFWNMSAC_VV:
8927 case RISCV::VMACC_VV:
8928 case RISCV::VMADD_VV:
8929 case RISCV::VNMSAC_VV:
8930 case RISCV::VNMSUB_VV:
8931 case RISCV::VWMACCSU_VV:
8932 case RISCV::VWMACCU_VV:
8933 case RISCV::VWMACC_VV: {
8934 // op: vd
8935 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8936 Value |= (op & 0x1f) << 7;
8937 // op: vm
8938 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8939 Value |= (op & 0x1) << 25;
8940 // op: vs2
8941 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8942 Value |= (op & 0x1f) << 20;
8943 // op: vs1
8944 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8945 Value |= (op & 0x1f) << 15;
8946 break;
8947 }
8948 case RISCV::VFBDOTA_VV:
8949 case RISCV::VFQWBDOTA_ALT_VV:
8950 case RISCV::VFQWBDOTA_VV:
8951 case RISCV::VFWBDOTA_VV:
8952 case RISCV::VQWBDOTAS_VV:
8953 case RISCV::VQWBDOTAU_VV: {
8954 // op: vd
8955 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8956 Value |= (op & 0x1f) << 7;
8957 // op: vm
8958 op = getVMaskReg(MI, OpNo: 5, Fixups, STI);
8959 Value |= (op & 0x1) << 25;
8960 // op: vs2
8961 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8962 Value |= (op & 0x18) << 20;
8963 // op: vs1
8964 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8965 Value |= (op & 0x1f) << 15;
8966 // op: ci
8967 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8968 Value |= (op & 0x7) << 20;
8969 break;
8970 }
8971 case RISCV::SMT_VMADOT1:
8972 case RISCV::SMT_VMADOT1SU:
8973 case RISCV::SMT_VMADOT1U:
8974 case RISCV::SMT_VMADOT1US:
8975 case RISCV::SMT_VMADOT2:
8976 case RISCV::SMT_VMADOT2SU:
8977 case RISCV::SMT_VMADOT2U:
8978 case RISCV::SMT_VMADOT2US:
8979 case RISCV::SMT_VMADOT3:
8980 case RISCV::SMT_VMADOT3SU:
8981 case RISCV::SMT_VMADOT3U:
8982 case RISCV::SMT_VMADOT3US: {
8983 // op: vd
8984 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8985 Value |= (op & 0x1f) << 7;
8986 // op: vs1
8987 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8988 Value |= (op & 0x1e) << 15;
8989 // op: vs2
8990 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8991 Value |= (op & 0x1f) << 20;
8992 break;
8993 }
8994 case RISCV::SMT_VMADOT:
8995 case RISCV::SMT_VMADOTSU:
8996 case RISCV::SMT_VMADOTU:
8997 case RISCV::SMT_VMADOTUS: {
8998 // op: vd
8999 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9000 Value |= (op & 0x1f) << 7;
9001 // op: vs1
9002 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9003 Value |= (op & 0x1f) << 15;
9004 // op: vs2
9005 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9006 Value |= (op & 0x1f) << 20;
9007 break;
9008 }
9009 case RISCV::VAESDF_VS:
9010 case RISCV::VAESDF_VV:
9011 case RISCV::VAESDM_VS:
9012 case RISCV::VAESDM_VV:
9013 case RISCV::VAESEF_VS:
9014 case RISCV::VAESEF_VV:
9015 case RISCV::VAESEM_VS:
9016 case RISCV::VAESEM_VV:
9017 case RISCV::VAESZ_VS:
9018 case RISCV::VGMUL_VS:
9019 case RISCV::VGMUL_VV:
9020 case RISCV::VSM4R_VS:
9021 case RISCV::VSM4R_VV: {
9022 // op: vd
9023 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9024 Value |= (op & 0x1f) << 7;
9025 // op: vs2
9026 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9027 Value |= (op & 0x1f) << 20;
9028 break;
9029 }
9030 case RISCV::VAESKF2_VI:
9031 case RISCV::VSM3C_VI: {
9032 // op: vd
9033 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9034 Value |= (op & 0x1f) << 7;
9035 // op: vs2
9036 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9037 Value |= (op & 0x1f) << 20;
9038 // op: imm
9039 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9040 Value |= (op & 0x1f) << 15;
9041 break;
9042 }
9043 case RISCV::VGHSH_VS:
9044 case RISCV::VGHSH_VV:
9045 case RISCV::VSHA2CH_VV:
9046 case RISCV::VSHA2CL_VV:
9047 case RISCV::VSHA2MS_VV: {
9048 // op: vd
9049 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9050 Value |= (op & 0x1f) << 7;
9051 // op: vs2
9052 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9053 Value |= (op & 0x1f) << 20;
9054 // op: vs1
9055 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9056 Value |= (op & 0x1f) << 15;
9057 break;
9058 }
9059 case RISCV::SF_VFWMACC_4x4x4:
9060 case RISCV::SF_VQMACCSU_2x8x2:
9061 case RISCV::SF_VQMACCSU_4x8x4:
9062 case RISCV::SF_VQMACCUS_2x8x2:
9063 case RISCV::SF_VQMACCUS_4x8x4:
9064 case RISCV::SF_VQMACCU_2x8x2:
9065 case RISCV::SF_VQMACCU_4x8x4:
9066 case RISCV::SF_VQMACC_2x8x2:
9067 case RISCV::SF_VQMACC_4x8x4:
9068 case RISCV::V8WMMACC_VV:
9069 case RISCV::VF8WIMMACC_VV:
9070 case RISCV::VF8WMMACC_VV:
9071 case RISCV::VF8WMMACC_VV_SCALE:
9072 case RISCV::VFMMACC_VV:
9073 case RISCV::VFQIMMACC_VV:
9074 case RISCV::VFQMMACC_VV:
9075 case RISCV::VFQMMACC_VV_SCALE:
9076 case RISCV::VFWIMMACC_VV:
9077 case RISCV::VFWMMACC_VV:
9078 case RISCV::VFWMMACC_VV_SCALE:
9079 case RISCV::VMMACC_VV:
9080 case RISCV::VQMMACC_VV:
9081 case RISCV::VWMMACC_VV: {
9082 // op: vd
9083 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9084 Value |= (op & 0x1f) << 7;
9085 // op: vs2
9086 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9087 Value |= (op & 0x1f) << 20;
9088 // op: vs1
9089 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9090 Value |= (op & 0x1f) << 15;
9091 break;
9092 }
9093 case RISCV::NDS_VFWCVT_F_B:
9094 case RISCV::NDS_VFWCVT_F_BU:
9095 case RISCV::NDS_VFWCVT_F_N:
9096 case RISCV::NDS_VFWCVT_F_NU: {
9097 // op: vs
9098 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9099 Value |= (op & 0x1f) << 20;
9100 // op: vd
9101 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9102 Value |= (op & 0x1f) << 7;
9103 // op: vm
9104 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
9105 Value |= (op & 0x1) << 25;
9106 break;
9107 }
9108 case RISCV::SF_VC_I: {
9109 // op: vs2
9110 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9111 Value |= (op & 0x1f) << 20;
9112 // op: vd
9113 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
9114 Value |= (op & 0x1f) << 7;
9115 // op: imm
9116 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9117 Value |= (op & 0x1f) << 15;
9118 // op: funct6_lo2
9119 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9120 Value |= (op & 0x3) << 26;
9121 break;
9122 }
9123 case RISCV::SF_VC_X: {
9124 // op: vs2
9125 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9126 Value |= (op & 0x1f) << 20;
9127 // op: vd
9128 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
9129 Value |= (op & 0x1f) << 7;
9130 // op: rs1
9131 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9132 Value |= (op & 0x1f) << 15;
9133 // op: funct6_lo2
9134 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9135 Value |= (op & 0x3) << 26;
9136 break;
9137 }
9138 case RISCV::SF_VC_V_I: {
9139 // op: vs2
9140 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
9141 Value |= (op & 0x1f) << 20;
9142 // op: vd
9143 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9144 Value |= (op & 0x1f) << 7;
9145 // op: imm
9146 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9147 Value |= (op & 0x1f) << 15;
9148 // op: funct6_lo2
9149 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9150 Value |= (op & 0x3) << 26;
9151 break;
9152 }
9153 case RISCV::SF_VC_V_X: {
9154 // op: vs2
9155 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
9156 Value |= (op & 0x1f) << 20;
9157 // op: vd
9158 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9159 Value |= (op & 0x1f) << 7;
9160 // op: rs1
9161 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9162 Value |= (op & 0x1f) << 15;
9163 // op: funct6_lo2
9164 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9165 Value |= (op & 0x3) << 26;
9166 break;
9167 }
9168 case RISCV::NDS_VFPMADB_VF:
9169 case RISCV::NDS_VFPMADT_VF: {
9170 // op: vs2
9171 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9172 Value |= (op & 0x1f) << 20;
9173 // op: rs1
9174 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9175 Value |= (op & 0x1f) << 15;
9176 // op: vd
9177 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9178 Value |= (op & 0x1f) << 7;
9179 // op: vm
9180 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
9181 Value |= (op & 0x1) << 25;
9182 break;
9183 }
9184 case RISCV::NDS_VFNCVT_BF16_S:
9185 case RISCV::NDS_VFWCVT_S_BF16: {
9186 // op: vs2
9187 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9188 Value |= (op & 0x1f) << 20;
9189 // op: vd
9190 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9191 Value |= (op & 0x1f) << 7;
9192 break;
9193 }
9194 case RISCV::SF_MM_E4M3_E4M3:
9195 case RISCV::SF_MM_E4M3_E5M2:
9196 case RISCV::SF_MM_E5M2_E4M3:
9197 case RISCV::SF_MM_E5M2_E5M2:
9198 case RISCV::SF_MM_S_S:
9199 case RISCV::SF_MM_S_U:
9200 case RISCV::SF_MM_U_S:
9201 case RISCV::SF_MM_U_U: {
9202 // op: vs2
9203 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9204 Value |= (op & 0x1f) << 20;
9205 // op: vs1
9206 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9207 Value |= (op & 0x1f) << 15;
9208 // op: rd
9209 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9210 Value |= (op & 0xc) << 8;
9211 break;
9212 }
9213 case RISCV::SF_MM_F_F: {
9214 // op: vs2
9215 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9216 Value |= (op & 0x1f) << 20;
9217 // op: vs1
9218 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9219 Value |= (op & 0x1f) << 15;
9220 // op: rd
9221 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9222 Value |= (op & 0xe) << 8;
9223 break;
9224 }
9225 case RISCV::SF_VC_IV: {
9226 // op: vs2
9227 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9228 Value |= (op & 0x1f) << 20;
9229 // op: vd
9230 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9231 Value |= (op & 0x1f) << 7;
9232 // op: imm
9233 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9234 Value |= (op & 0x1f) << 15;
9235 // op: funct6_lo2
9236 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9237 Value |= (op & 0x3) << 26;
9238 break;
9239 }
9240 case RISCV::SF_VC_FV: {
9241 // op: vs2
9242 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9243 Value |= (op & 0x1f) << 20;
9244 // op: vd
9245 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9246 Value |= (op & 0x1f) << 7;
9247 // op: rs1
9248 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9249 Value |= (op & 0x1f) << 15;
9250 // op: funct6_lo1
9251 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9252 Value |= (op & 0x1) << 26;
9253 break;
9254 }
9255 case RISCV::SF_VC_XV: {
9256 // op: vs2
9257 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9258 Value |= (op & 0x1f) << 20;
9259 // op: vd
9260 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9261 Value |= (op & 0x1f) << 7;
9262 // op: rs1
9263 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9264 Value |= (op & 0x1f) << 15;
9265 // op: funct6_lo2
9266 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9267 Value |= (op & 0x3) << 26;
9268 break;
9269 }
9270 case RISCV::SF_VC_VV: {
9271 // op: vs2
9272 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9273 Value |= (op & 0x1f) << 20;
9274 // op: vd
9275 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9276 Value |= (op & 0x1f) << 7;
9277 // op: vs1
9278 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9279 Value |= (op & 0x1f) << 15;
9280 // op: funct6_lo2
9281 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9282 Value |= (op & 0x3) << 26;
9283 break;
9284 }
9285 case RISCV::SF_VC_V_IV: {
9286 // op: vs2
9287 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9288 Value |= (op & 0x1f) << 20;
9289 // op: vd
9290 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9291 Value |= (op & 0x1f) << 7;
9292 // op: imm
9293 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9294 Value |= (op & 0x1f) << 15;
9295 // op: funct6_lo2
9296 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9297 Value |= (op & 0x3) << 26;
9298 break;
9299 }
9300 case RISCV::SF_VC_V_FV: {
9301 // op: vs2
9302 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9303 Value |= (op & 0x1f) << 20;
9304 // op: vd
9305 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9306 Value |= (op & 0x1f) << 7;
9307 // op: rs1
9308 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9309 Value |= (op & 0x1f) << 15;
9310 // op: funct6_lo1
9311 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9312 Value |= (op & 0x1) << 26;
9313 break;
9314 }
9315 case RISCV::SF_VC_V_XV: {
9316 // op: vs2
9317 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9318 Value |= (op & 0x1f) << 20;
9319 // op: vd
9320 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9321 Value |= (op & 0x1f) << 7;
9322 // op: rs1
9323 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9324 Value |= (op & 0x1f) << 15;
9325 // op: funct6_lo2
9326 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9327 Value |= (op & 0x3) << 26;
9328 break;
9329 }
9330 case RISCV::SF_VC_V_VV: {
9331 // op: vs2
9332 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9333 Value |= (op & 0x1f) << 20;
9334 // op: vd
9335 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9336 Value |= (op & 0x1f) << 7;
9337 // op: vs1
9338 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9339 Value |= (op & 0x1f) << 15;
9340 // op: funct6_lo2
9341 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9342 Value |= (op & 0x3) << 26;
9343 break;
9344 }
9345 case RISCV::SF_VC_IVV:
9346 case RISCV::SF_VC_IVW: {
9347 // op: vs2
9348 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9349 Value |= (op & 0x1f) << 20;
9350 // op: vd
9351 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9352 Value |= (op & 0x1f) << 7;
9353 // op: imm
9354 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9355 Value |= (op & 0x1f) << 15;
9356 // op: funct6_lo2
9357 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9358 Value |= (op & 0x3) << 26;
9359 break;
9360 }
9361 case RISCV::SF_VC_FVV:
9362 case RISCV::SF_VC_FVW: {
9363 // op: vs2
9364 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9365 Value |= (op & 0x1f) << 20;
9366 // op: vd
9367 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9368 Value |= (op & 0x1f) << 7;
9369 // op: rs1
9370 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9371 Value |= (op & 0x1f) << 15;
9372 // op: funct6_lo1
9373 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9374 Value |= (op & 0x1) << 26;
9375 break;
9376 }
9377 case RISCV::SF_VC_XVV:
9378 case RISCV::SF_VC_XVW: {
9379 // op: vs2
9380 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9381 Value |= (op & 0x1f) << 20;
9382 // op: vd
9383 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9384 Value |= (op & 0x1f) << 7;
9385 // op: rs1
9386 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9387 Value |= (op & 0x1f) << 15;
9388 // op: funct6_lo2
9389 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9390 Value |= (op & 0x3) << 26;
9391 break;
9392 }
9393 case RISCV::SF_VC_VVV:
9394 case RISCV::SF_VC_VVW: {
9395 // op: vs2
9396 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9397 Value |= (op & 0x1f) << 20;
9398 // op: vd
9399 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9400 Value |= (op & 0x1f) << 7;
9401 // op: vs1
9402 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9403 Value |= (op & 0x1f) << 15;
9404 // op: funct6_lo2
9405 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
9406 Value |= (op & 0x3) << 26;
9407 break;
9408 }
9409 case RISCV::NDS_VD4DOTSU_VV:
9410 case RISCV::NDS_VD4DOTS_VV:
9411 case RISCV::NDS_VD4DOTU_VV: {
9412 // op: vs2
9413 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9414 Value |= (op & 0x1f) << 20;
9415 // op: vs1
9416 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9417 Value |= (op & 0x1f) << 15;
9418 // op: vd
9419 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9420 Value |= (op & 0x1f) << 7;
9421 // op: vm
9422 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
9423 Value |= (op & 0x1) << 25;
9424 break;
9425 }
9426 case RISCV::SF_VC_V_IVV:
9427 case RISCV::SF_VC_V_IVW: {
9428 // op: vs2
9429 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9430 Value |= (op & 0x1f) << 20;
9431 // op: vd
9432 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9433 Value |= (op & 0x1f) << 7;
9434 // op: imm
9435 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
9436 Value |= (op & 0x1f) << 15;
9437 // op: funct6_lo2
9438 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9439 Value |= (op & 0x3) << 26;
9440 break;
9441 }
9442 case RISCV::SF_VC_V_FVV:
9443 case RISCV::SF_VC_V_FVW: {
9444 // op: vs2
9445 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9446 Value |= (op & 0x1f) << 20;
9447 // op: vd
9448 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9449 Value |= (op & 0x1f) << 7;
9450 // op: rs1
9451 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
9452 Value |= (op & 0x1f) << 15;
9453 // op: funct6_lo1
9454 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9455 Value |= (op & 0x1) << 26;
9456 break;
9457 }
9458 case RISCV::SF_VC_V_XVV:
9459 case RISCV::SF_VC_V_XVW: {
9460 // op: vs2
9461 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9462 Value |= (op & 0x1f) << 20;
9463 // op: vd
9464 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9465 Value |= (op & 0x1f) << 7;
9466 // op: rs1
9467 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
9468 Value |= (op & 0x1f) << 15;
9469 // op: funct6_lo2
9470 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9471 Value |= (op & 0x3) << 26;
9472 break;
9473 }
9474 case RISCV::SF_VC_V_VVV:
9475 case RISCV::SF_VC_V_VVW: {
9476 // op: vs2
9477 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9478 Value |= (op & 0x1f) << 20;
9479 // op: vd
9480 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9481 Value |= (op & 0x1f) << 7;
9482 // op: vs1
9483 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
9484 Value |= (op & 0x1f) << 15;
9485 // op: funct6_lo2
9486 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
9487 Value |= (op & 0x3) << 26;
9488 break;
9489 }
9490 case RISCV::VMTS_V:
9491 case RISCV::VMTTS_V: {
9492 // op: vs3
9493 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9494 Value |= (op & 0x1f) << 7;
9495 // op: rs1
9496 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9497 Value |= (op & 0x1f) << 15;
9498 // op: rs2
9499 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9500 Value |= (op & 0x1f) << 20;
9501 // op: vm
9502 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
9503 Value |= (op & 0x1) << 25;
9504 // op: vlambda
9505 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9506 Value |= (op & 0x7) << 29;
9507 break;
9508 }
9509 default:
9510 reportUnsupportedInst(Inst: MI);
9511 }
9512 return Value;
9513}
9514
9515#ifdef GET_OPERAND_BIT_OFFSET
9516#undef GET_OPERAND_BIT_OFFSET
9517
9518uint32_t RISCVMCCodeEmitter::getOperandBitOffset(const MCInst &MI,
9519 unsigned OpNum,
9520 const MCSubtargetInfo &STI) const {
9521 switch (MI.getOpcode()) {
9522 case RISCV::C_EBREAK:
9523 case RISCV::C_MOP_11:
9524 case RISCV::C_MOP_13:
9525 case RISCV::C_MOP_15:
9526 case RISCV::C_MOP_3:
9527 case RISCV::C_MOP_7:
9528 case RISCV::C_MOP_9:
9529 case RISCV::C_NOP:
9530 case RISCV::C_SSPOPCHK:
9531 case RISCV::C_SSPUSH:
9532 case RISCV::C_UNIMP:
9533 case RISCV::DRET:
9534 case RISCV::EBREAK:
9535 case RISCV::ECALL:
9536 case RISCV::FENCE_I:
9537 case RISCV::FENCE_TSO:
9538 case RISCV::MIPS_EHB:
9539 case RISCV::MIPS_IHB:
9540 case RISCV::MIPS_PAUSE:
9541 case RISCV::MNRET:
9542 case RISCV::MRET:
9543 case RISCV::QC_C_DI:
9544 case RISCV::QC_C_EI:
9545 case RISCV::QC_C_MIENTER:
9546 case RISCV::QC_C_MIENTER_NEST:
9547 case RISCV::QC_C_MILEAVERET:
9548 case RISCV::QC_C_MNRET:
9549 case RISCV::QC_C_MRET:
9550 case RISCV::SCTRCLR:
9551 case RISCV::SFENCE_INVAL_IR:
9552 case RISCV::SFENCE_W_INVAL:
9553 case RISCV::SF_CEASE:
9554 case RISCV::SF_VTDISCARD:
9555 case RISCV::SRET:
9556 case RISCV::TH_DCACHE_CALL:
9557 case RISCV::TH_DCACHE_CIALL:
9558 case RISCV::TH_DCACHE_IALL:
9559 case RISCV::TH_ICACHE_IALL:
9560 case RISCV::TH_ICACHE_IALLS:
9561 case RISCV::TH_L2CACHE_CALL:
9562 case RISCV::TH_L2CACHE_CIALL:
9563 case RISCV::TH_L2CACHE_IALL:
9564 case RISCV::TH_SYNC:
9565 case RISCV::TH_SYNC_I:
9566 case RISCV::TH_SYNC_IS:
9567 case RISCV::TH_SYNC_S:
9568 case RISCV::UNIMP:
9569 case RISCV::WFI:
9570 case RISCV::WRS_NTO:
9571 case RISCV::WRS_STO: {
9572 break;
9573 }
9574 case RISCV::AIF_FSWG_PS:
9575 case RISCV::AIF_FSWL_PS: {
9576 switch (OpNum) {
9577 case 0:
9578 // op: fs3
9579 return 7;
9580 case 1:
9581 // op: rs1
9582 return 15;
9583 }
9584 break;
9585 }
9586 case RISCV::C_NOP_HINT: {
9587 switch (OpNum) {
9588 case 0:
9589 // op: imm
9590 return 2;
9591 }
9592 break;
9593 }
9594 case RISCV::QC_CLRINTI:
9595 case RISCV::QC_SETINTI: {
9596 switch (OpNum) {
9597 case 0:
9598 // op: imm10
9599 return 15;
9600 }
9601 break;
9602 }
9603 case RISCV::QC_E_J:
9604 case RISCV::QC_E_JAL: {
9605 switch (OpNum) {
9606 case 0:
9607 // op: imm31
9608 return 7;
9609 }
9610 break;
9611 }
9612 case RISCV::QC_SYNC:
9613 case RISCV::QC_SYNCR:
9614 case RISCV::QC_SYNCWF:
9615 case RISCV::QC_SYNCWL: {
9616 switch (OpNum) {
9617 case 0:
9618 // op: imm5
9619 return 20;
9620 }
9621 break;
9622 }
9623 case RISCV::QC_PPUTCI: {
9624 switch (OpNum) {
9625 case 0:
9626 // op: imm8
9627 return 20;
9628 }
9629 break;
9630 }
9631 case RISCV::CM_JALT:
9632 case RISCV::CM_JT:
9633 case RISCV::QC_CM_JALT:
9634 case RISCV::QC_CM_JT: {
9635 switch (OpNum) {
9636 case 0:
9637 // op: index
9638 return 2;
9639 }
9640 break;
9641 }
9642 case RISCV::C_J:
9643 case RISCV::C_JAL: {
9644 switch (OpNum) {
9645 case 0:
9646 // op: offset
9647 return 2;
9648 }
9649 break;
9650 }
9651 case RISCV::InsnQC_EJ: {
9652 switch (OpNum) {
9653 case 0:
9654 // op: opcode
9655 return 0;
9656 case 1:
9657 // op: func3
9658 return 12;
9659 case 2:
9660 // op: func2
9661 return 15;
9662 case 3:
9663 // op: func5
9664 return 20;
9665 case 4:
9666 // op: imm31
9667 return 7;
9668 }
9669 break;
9670 }
9671 case RISCV::InsnQC_ES: {
9672 switch (OpNum) {
9673 case 0:
9674 // op: opcode
9675 return 0;
9676 case 1:
9677 // op: func3
9678 return 12;
9679 case 2:
9680 // op: func2
9681 return 30;
9682 case 4:
9683 // op: rs1
9684 return 15;
9685 case 3:
9686 // op: rs2
9687 return 20;
9688 case 5:
9689 // op: imm26
9690 return 7;
9691 }
9692 break;
9693 }
9694 case RISCV::InsnQC_EB: {
9695 switch (OpNum) {
9696 case 0:
9697 // op: opcode
9698 return 0;
9699 case 1:
9700 // op: func3
9701 return 12;
9702 case 2:
9703 // op: func5
9704 return 20;
9705 case 3:
9706 // op: rs1
9707 return 15;
9708 case 5:
9709 // op: imm12
9710 return 7;
9711 case 4:
9712 // op: imm16
9713 return 32;
9714 }
9715 break;
9716 }
9717 case RISCV::InsnS: {
9718 switch (OpNum) {
9719 case 0:
9720 // op: opcode
9721 return 0;
9722 case 1:
9723 // op: funct3
9724 return 12;
9725 case 4:
9726 // op: imm12
9727 return 7;
9728 case 2:
9729 // op: rs2
9730 return 20;
9731 case 3:
9732 // op: rs1
9733 return 15;
9734 }
9735 break;
9736 }
9737 case RISCV::InsnB: {
9738 switch (OpNum) {
9739 case 0:
9740 // op: opcode
9741 return 0;
9742 case 1:
9743 // op: funct3
9744 return 12;
9745 case 4:
9746 // op: imm12
9747 return 7;
9748 case 3:
9749 // op: rs2
9750 return 20;
9751 case 2:
9752 // op: rs1
9753 return 15;
9754 }
9755 break;
9756 }
9757 case RISCV::InsnCJ: {
9758 switch (OpNum) {
9759 case 0:
9760 // op: opcode
9761 return 0;
9762 case 1:
9763 // op: funct3
9764 return 13;
9765 case 2:
9766 // op: imm11
9767 return 2;
9768 }
9769 break;
9770 }
9771 case RISCV::InsnCSS: {
9772 switch (OpNum) {
9773 case 0:
9774 // op: opcode
9775 return 0;
9776 case 1:
9777 // op: funct3
9778 return 13;
9779 case 3:
9780 // op: imm6
9781 return 7;
9782 case 2:
9783 // op: rs2
9784 return 2;
9785 }
9786 break;
9787 }
9788 case RISCV::InsnCB: {
9789 switch (OpNum) {
9790 case 0:
9791 // op: opcode
9792 return 0;
9793 case 1:
9794 // op: funct3
9795 return 13;
9796 case 3:
9797 // op: imm8
9798 return 2;
9799 case 2:
9800 // op: rs1
9801 return 7;
9802 }
9803 break;
9804 }
9805 case RISCV::InsnCS: {
9806 switch (OpNum) {
9807 case 0:
9808 // op: opcode
9809 return 0;
9810 case 1:
9811 // op: funct3
9812 return 13;
9813 case 4:
9814 // op: imm5
9815 return 5;
9816 case 2:
9817 // op: rs2
9818 return 2;
9819 case 3:
9820 // op: rs1
9821 return 7;
9822 }
9823 break;
9824 }
9825 case RISCV::FENCE: {
9826 switch (OpNum) {
9827 case 0:
9828 // op: pred
9829 return 24;
9830 case 1:
9831 // op: succ
9832 return 20;
9833 }
9834 break;
9835 }
9836 case RISCV::C_FLD:
9837 case RISCV::C_FLW:
9838 case RISCV::C_LBU:
9839 case RISCV::C_LD:
9840 case RISCV::C_LD_RV32:
9841 case RISCV::C_LH:
9842 case RISCV::C_LHU:
9843 case RISCV::C_LH_INX:
9844 case RISCV::C_LW:
9845 case RISCV::C_LW_INX:
9846 case RISCV::QK_C_LBU:
9847 case RISCV::QK_C_LHU: {
9848 switch (OpNum) {
9849 case 0:
9850 // op: rd
9851 return 2;
9852 case 1:
9853 // op: rs1
9854 return 7;
9855 case 2:
9856 // op: imm
9857 return 5;
9858 }
9859 break;
9860 }
9861 case RISCV::FLI_D:
9862 case RISCV::FLI_H:
9863 case RISCV::FLI_Q:
9864 case RISCV::FLI_S: {
9865 switch (OpNum) {
9866 case 0:
9867 // op: rd
9868 return 7;
9869 case 1:
9870 // op: imm
9871 return 15;
9872 }
9873 break;
9874 }
9875 case RISCV::QC_E_LI: {
9876 switch (OpNum) {
9877 case 0:
9878 // op: rd
9879 return 7;
9880 case 1:
9881 // op: imm
9882 return 16;
9883 }
9884 break;
9885 }
9886 case RISCV::PLI_H:
9887 case RISCV::PLI_W:
9888 case RISCV::PLUI_H:
9889 case RISCV::PLUI_W: {
9890 switch (OpNum) {
9891 case 0:
9892 // op: rd
9893 return 7;
9894 case 1:
9895 // op: imm10
9896 return 15;
9897 }
9898 break;
9899 }
9900 case RISCV::PLI_B: {
9901 switch (OpNum) {
9902 case 0:
9903 // op: rd
9904 return 7;
9905 case 1:
9906 // op: imm8
9907 return 16;
9908 }
9909 break;
9910 }
9911 case RISCV::AIF_FMVS_X_PS:
9912 case RISCV::AIF_FMVZ_X_PS: {
9913 switch (OpNum) {
9914 case 0:
9915 // op: rd
9916 return 7;
9917 case 1:
9918 // op: rs1
9919 return 15;
9920 case 2:
9921 // op: idx
9922 return 20;
9923 }
9924 break;
9925 }
9926 case RISCV::AIF_FSWIZZ_PS: {
9927 switch (OpNum) {
9928 case 0:
9929 // op: rd
9930 return 7;
9931 case 1:
9932 // op: rs1
9933 return 15;
9934 case 2:
9935 // op: imm
9936 return 12;
9937 }
9938 break;
9939 }
9940 case RISCV::QC_E_ADDI:
9941 case RISCV::QC_E_ANDI:
9942 case RISCV::QC_E_LB:
9943 case RISCV::QC_E_LBU:
9944 case RISCV::QC_E_LH:
9945 case RISCV::QC_E_LHU:
9946 case RISCV::QC_E_LW:
9947 case RISCV::QC_E_ORI:
9948 case RISCV::QC_E_XORI: {
9949 switch (OpNum) {
9950 case 0:
9951 // op: rd
9952 return 7;
9953 case 1:
9954 // op: rs1
9955 return 15;
9956 case 2:
9957 // op: imm
9958 return 20;
9959 }
9960 break;
9961 }
9962 case RISCV::NDS_BFOS:
9963 case RISCV::NDS_BFOZ: {
9964 switch (OpNum) {
9965 case 0:
9966 // op: rd
9967 return 7;
9968 case 1:
9969 // op: rs1
9970 return 15;
9971 case 2:
9972 // op: msb
9973 return 26;
9974 case 3:
9975 // op: lsb
9976 return 20;
9977 }
9978 break;
9979 }
9980 case RISCV::AIF_FCVT_PS_PW:
9981 case RISCV::AIF_FCVT_PS_PWU:
9982 case RISCV::AIF_FCVT_PWU_PS:
9983 case RISCV::AIF_FCVT_PW_PS: {
9984 switch (OpNum) {
9985 case 0:
9986 // op: rd
9987 return 7;
9988 case 1:
9989 // op: rs1
9990 return 15;
9991 case 2:
9992 // op: rm
9993 return 12;
9994 }
9995 break;
9996 }
9997 case RISCV::AIF_FADD_PS:
9998 case RISCV::AIF_FDIV_PS:
9999 case RISCV::AIF_FMUL_PS:
10000 case RISCV::AIF_FSUB_PS: {
10001 switch (OpNum) {
10002 case 0:
10003 // op: rd
10004 return 7;
10005 case 1:
10006 // op: rs1
10007 return 15;
10008 case 2:
10009 // op: rs2
10010 return 20;
10011 case 3:
10012 // op: rm
10013 return 12;
10014 }
10015 break;
10016 }
10017 case RISCV::AIF_FMADD_PS:
10018 case RISCV::AIF_FMSUB_PS:
10019 case RISCV::AIF_FNMADD_PS:
10020 case RISCV::AIF_FNMSUB_PS: {
10021 switch (OpNum) {
10022 case 0:
10023 // op: rd
10024 return 7;
10025 case 1:
10026 // op: rs1
10027 return 15;
10028 case 2:
10029 // op: rs2
10030 return 20;
10031 case 3:
10032 // op: rs3
10033 return 27;
10034 case 4:
10035 // op: rm
10036 return 12;
10037 }
10038 break;
10039 }
10040 case RISCV::AIF_FCMOV_PS: {
10041 switch (OpNum) {
10042 case 0:
10043 // op: rd
10044 return 7;
10045 case 1:
10046 // op: rs1
10047 return 15;
10048 case 2:
10049 // op: rs2
10050 return 20;
10051 case 3:
10052 // op: rs3
10053 return 27;
10054 }
10055 break;
10056 }
10057 case RISCV::VSETIVLI: {
10058 switch (OpNum) {
10059 case 0:
10060 // op: rd
10061 return 7;
10062 case 1:
10063 // op: uimm
10064 return 15;
10065 case 2:
10066 // op: vtypei
10067 return 20;
10068 }
10069 break;
10070 }
10071 case RISCV::VFMV_F_S:
10072 case RISCV::VMV_X_S: {
10073 switch (OpNum) {
10074 case 0:
10075 // op: rd
10076 return 7;
10077 case 1:
10078 // op: vs2
10079 return 20;
10080 }
10081 break;
10082 }
10083 case RISCV::VCPOP_M:
10084 case RISCV::VFIRST_M: {
10085 switch (OpNum) {
10086 case 0:
10087 // op: rd
10088 return 7;
10089 case 2:
10090 // op: vm
10091 return 25;
10092 case 1:
10093 // op: vs2
10094 return 20;
10095 }
10096 break;
10097 }
10098 case RISCV::AIF_MOVA_X_M:
10099 case RISCV::QC_C_DIR:
10100 case RISCV::SSRDP: {
10101 switch (OpNum) {
10102 case 0:
10103 // op: rd
10104 return 7;
10105 }
10106 break;
10107 }
10108 case RISCV::PLI_DH:
10109 case RISCV::PLUI_DH: {
10110 switch (OpNum) {
10111 case 0:
10112 // op: rd
10113 return 8;
10114 case 1:
10115 // op: imm10
10116 return 15;
10117 }
10118 break;
10119 }
10120 case RISCV::PLI_DB: {
10121 switch (OpNum) {
10122 case 0:
10123 // op: rd
10124 return 8;
10125 case 1:
10126 // op: imm8
10127 return 16;
10128 }
10129 break;
10130 }
10131 case RISCV::SF_VTZERO_T: {
10132 switch (OpNum) {
10133 case 0:
10134 // op: rd
10135 return 8;
10136 }
10137 break;
10138 }
10139 case RISCV::QK_C_LBUSP:
10140 case RISCV::QK_C_LHUSP:
10141 case RISCV::QK_C_SBSP:
10142 case RISCV::QK_C_SHSP: {
10143 switch (OpNum) {
10144 case 0:
10145 // op: rd_rs2
10146 return 2;
10147 case 2:
10148 // op: imm
10149 return 7;
10150 }
10151 break;
10152 }
10153 case RISCV::CM_POP:
10154 case RISCV::CM_POPRET:
10155 case RISCV::CM_POPRETZ:
10156 case RISCV::CM_PUSH:
10157 case RISCV::QC_CM_POP:
10158 case RISCV::QC_CM_POPRET:
10159 case RISCV::QC_CM_POPRETZ:
10160 case RISCV::QC_CM_PUSH:
10161 case RISCV::QC_CM_PUSHFP: {
10162 switch (OpNum) {
10163 case 0:
10164 // op: rlist
10165 return 4;
10166 case 1:
10167 // op: stackadj
10168 return 2;
10169 }
10170 break;
10171 }
10172 case RISCV::QC_E_BEQI:
10173 case RISCV::QC_E_BGEI:
10174 case RISCV::QC_E_BGEUI:
10175 case RISCV::QC_E_BLTI:
10176 case RISCV::QC_E_BLTUI:
10177 case RISCV::QC_E_BNEI: {
10178 switch (OpNum) {
10179 case 0:
10180 // op: rs1
10181 return 15;
10182 case 1:
10183 // op: imm16
10184 return 32;
10185 case 2:
10186 // op: imm12
10187 return 7;
10188 }
10189 break;
10190 }
10191 case RISCV::AIF_MOVA_M_X:
10192 case RISCV::CBO_CLEAN:
10193 case RISCV::CBO_FLUSH:
10194 case RISCV::CBO_INVAL:
10195 case RISCV::CBO_ZERO:
10196 case RISCV::SF_CDISCARD_D_L1:
10197 case RISCV::SF_CFLUSH_D_L1:
10198 case RISCV::SSPOPCHK:
10199 case RISCV::TH_DCACHE_CIPA:
10200 case RISCV::TH_DCACHE_CISW:
10201 case RISCV::TH_DCACHE_CIVA:
10202 case RISCV::TH_DCACHE_CPA:
10203 case RISCV::TH_DCACHE_CPAL1:
10204 case RISCV::TH_DCACHE_CSW:
10205 case RISCV::TH_DCACHE_CVA:
10206 case RISCV::TH_DCACHE_CVAL1:
10207 case RISCV::TH_DCACHE_IPA:
10208 case RISCV::TH_DCACHE_ISW:
10209 case RISCV::TH_DCACHE_IVA:
10210 case RISCV::TH_ICACHE_IPA:
10211 case RISCV::TH_ICACHE_IVA: {
10212 switch (OpNum) {
10213 case 0:
10214 // op: rs1
10215 return 15;
10216 }
10217 break;
10218 }
10219 case RISCV::C_MV: {
10220 switch (OpNum) {
10221 case 0:
10222 // op: rs1
10223 return 7;
10224 case 1:
10225 // op: rs2
10226 return 2;
10227 }
10228 break;
10229 }
10230 case RISCV::C_JALR:
10231 case RISCV::C_JR:
10232 case RISCV::QC_C_CLRINT:
10233 case RISCV::QC_C_EIR:
10234 case RISCV::QC_C_SETINT: {
10235 switch (OpNum) {
10236 case 0:
10237 // op: rs1
10238 return 7;
10239 }
10240 break;
10241 }
10242 case RISCV::AIF_SBG:
10243 case RISCV::AIF_SBL:
10244 case RISCV::AIF_SHG:
10245 case RISCV::AIF_SHL:
10246 case RISCV::HSV_B:
10247 case RISCV::HSV_D:
10248 case RISCV::HSV_H:
10249 case RISCV::HSV_W:
10250 case RISCV::SB_AQRL:
10251 case RISCV::SB_RL:
10252 case RISCV::SD_AQRL:
10253 case RISCV::SD_RL:
10254 case RISCV::SF_VLTE16:
10255 case RISCV::SF_VLTE32:
10256 case RISCV::SF_VLTE64:
10257 case RISCV::SF_VLTE8:
10258 case RISCV::SF_VSTE16:
10259 case RISCV::SF_VSTE32:
10260 case RISCV::SF_VSTE64:
10261 case RISCV::SF_VSTE8:
10262 case RISCV::SH_AQRL:
10263 case RISCV::SH_RL:
10264 case RISCV::SW_AQRL:
10265 case RISCV::SW_RL: {
10266 switch (OpNum) {
10267 case 0:
10268 // op: rs2
10269 return 20;
10270 case 1:
10271 // op: rs1
10272 return 15;
10273 }
10274 break;
10275 }
10276 case RISCV::SSPUSH: {
10277 switch (OpNum) {
10278 case 0:
10279 // op: rs2
10280 return 20;
10281 }
10282 break;
10283 }
10284 case RISCV::C_FSD:
10285 case RISCV::C_FSW:
10286 case RISCV::C_SB:
10287 case RISCV::C_SD:
10288 case RISCV::C_SD_RV32:
10289 case RISCV::C_SH:
10290 case RISCV::C_SH_INX:
10291 case RISCV::C_SW:
10292 case RISCV::C_SW_INX:
10293 case RISCV::QK_C_SB:
10294 case RISCV::QK_C_SH: {
10295 switch (OpNum) {
10296 case 0:
10297 // op: rs2
10298 return 2;
10299 case 1:
10300 // op: rs1
10301 return 7;
10302 case 2:
10303 // op: imm
10304 return 5;
10305 }
10306 break;
10307 }
10308 case RISCV::QC_C_SYNC:
10309 case RISCV::QC_C_SYNCR:
10310 case RISCV::QC_C_SYNCWF:
10311 case RISCV::QC_C_SYNCWL: {
10312 switch (OpNum) {
10313 case 0:
10314 // op: slist
10315 return 7;
10316 }
10317 break;
10318 }
10319 case RISCV::Insn16:
10320 case RISCV::Insn32:
10321 case RISCV::Insn48:
10322 case RISCV::Insn64: {
10323 switch (OpNum) {
10324 case 0:
10325 // op: value
10326 return 0;
10327 }
10328 break;
10329 }
10330 case RISCV::VMV_V_I: {
10331 switch (OpNum) {
10332 case 0:
10333 // op: vd
10334 return 7;
10335 case 1:
10336 // op: imm
10337 return 15;
10338 }
10339 break;
10340 }
10341 case RISCV::VMTL_V:
10342 case RISCV::VMTTL_V: {
10343 switch (OpNum) {
10344 case 0:
10345 // op: vd
10346 return 7;
10347 case 1:
10348 // op: rs1
10349 return 15;
10350 case 2:
10351 // op: rs2
10352 return 20;
10353 case 4:
10354 // op: vm
10355 return 25;
10356 case 3:
10357 // op: vlambda
10358 return 29;
10359 }
10360 break;
10361 }
10362 case RISCV::VFMV_V_F:
10363 case RISCV::VMV_V_X: {
10364 switch (OpNum) {
10365 case 0:
10366 // op: vd
10367 return 7;
10368 case 1:
10369 // op: rs1
10370 return 15;
10371 }
10372 break;
10373 }
10374 case RISCV::VID_V: {
10375 switch (OpNum) {
10376 case 0:
10377 // op: vd
10378 return 7;
10379 case 1:
10380 // op: vm
10381 return 25;
10382 }
10383 break;
10384 }
10385 case RISCV::VMV_V_V: {
10386 switch (OpNum) {
10387 case 0:
10388 // op: vd
10389 return 7;
10390 case 1:
10391 // op: vs1
10392 return 15;
10393 }
10394 break;
10395 }
10396 case RISCV::VADC_VIM:
10397 case RISCV::VAESKF1_VI:
10398 case RISCV::VMADC_VI:
10399 case RISCV::VMADC_VIM:
10400 case RISCV::VMERGE_VIM:
10401 case RISCV::VSM4K_VI: {
10402 switch (OpNum) {
10403 case 0:
10404 // op: vd
10405 return 7;
10406 case 1:
10407 // op: vs2
10408 return 20;
10409 case 2:
10410 // op: imm
10411 return 15;
10412 }
10413 break;
10414 }
10415 case RISCV::VADC_VXM:
10416 case RISCV::VFMERGE_VFM:
10417 case RISCV::VMADC_VX:
10418 case RISCV::VMADC_VXM:
10419 case RISCV::VMERGE_VXM:
10420 case RISCV::VMSBC_VX:
10421 case RISCV::VMSBC_VXM:
10422 case RISCV::VSBC_VXM: {
10423 switch (OpNum) {
10424 case 0:
10425 // op: vd
10426 return 7;
10427 case 1:
10428 // op: vs2
10429 return 20;
10430 case 2:
10431 // op: rs1
10432 return 15;
10433 }
10434 break;
10435 }
10436 case RISCV::VADC_VVM:
10437 case RISCV::VCOMPRESS_VM:
10438 case RISCV::VMADC_VV:
10439 case RISCV::VMADC_VVM:
10440 case RISCV::VMANDN_MM:
10441 case RISCV::VMAND_MM:
10442 case RISCV::VMERGE_VVM:
10443 case RISCV::VMNAND_MM:
10444 case RISCV::VMNOR_MM:
10445 case RISCV::VMORN_MM:
10446 case RISCV::VMOR_MM:
10447 case RISCV::VMSBC_VV:
10448 case RISCV::VMSBC_VVM:
10449 case RISCV::VMXNOR_MM:
10450 case RISCV::VMXOR_MM:
10451 case RISCV::VSBC_VVM:
10452 case RISCV::VSM3ME_VV: {
10453 switch (OpNum) {
10454 case 0:
10455 // op: vd
10456 return 7;
10457 case 1:
10458 // op: vs2
10459 return 20;
10460 case 2:
10461 // op: vs1
10462 return 15;
10463 }
10464 break;
10465 }
10466 case RISCV::VMV1R_V:
10467 case RISCV::VMV2R_V:
10468 case RISCV::VMV4R_V:
10469 case RISCV::VMV8R_V: {
10470 switch (OpNum) {
10471 case 0:
10472 // op: vd
10473 return 7;
10474 case 1:
10475 // op: vs2
10476 return 20;
10477 }
10478 break;
10479 }
10480 case RISCV::SF_VFEXPA_V:
10481 case RISCV::SF_VFEXP_V:
10482 case RISCV::VABS_V:
10483 case RISCV::VBREV8_V:
10484 case RISCV::VBREV_V:
10485 case RISCV::VCLZ_V:
10486 case RISCV::VCPOP_V:
10487 case RISCV::VCTZ_V:
10488 case RISCV::VFCLASS_V:
10489 case RISCV::VFCVT_F_XU_V:
10490 case RISCV::VFCVT_F_X_V:
10491 case RISCV::VFCVT_RTZ_XU_F_V:
10492 case RISCV::VFCVT_RTZ_X_F_V:
10493 case RISCV::VFCVT_XU_F_V:
10494 case RISCV::VFCVT_X_F_V:
10495 case RISCV::VFNCVTBF16_F_F_W:
10496 case RISCV::VFNCVTBF16_SAT_F_F_W:
10497 case RISCV::VFNCVT_F_F_Q:
10498 case RISCV::VFNCVT_F_F_W:
10499 case RISCV::VFNCVT_F_XU_W:
10500 case RISCV::VFNCVT_F_X_W:
10501 case RISCV::VFNCVT_ROD_F_F_W:
10502 case RISCV::VFNCVT_RTZ_XU_F_W:
10503 case RISCV::VFNCVT_RTZ_X_F_W:
10504 case RISCV::VFNCVT_SAT_F_F_Q:
10505 case RISCV::VFNCVT_XU_F_W:
10506 case RISCV::VFNCVT_X_F_W:
10507 case RISCV::VFREC7_V:
10508 case RISCV::VFRSQRT7_V:
10509 case RISCV::VFSQRT_V:
10510 case RISCV::VFWCVTBF16_F_F_V:
10511 case RISCV::VFWCVT_F_F_V:
10512 case RISCV::VFWCVT_F_XU_V:
10513 case RISCV::VFWCVT_F_X_V:
10514 case RISCV::VFWCVT_RTZ_XU_F_V:
10515 case RISCV::VFWCVT_RTZ_X_F_V:
10516 case RISCV::VFWCVT_XU_F_V:
10517 case RISCV::VFWCVT_X_F_V:
10518 case RISCV::VIOTA_M:
10519 case RISCV::VMSBF_M:
10520 case RISCV::VMSIF_M:
10521 case RISCV::VMSOF_M:
10522 case RISCV::VREV8_V:
10523 case RISCV::VSEXT_VF2:
10524 case RISCV::VSEXT_VF4:
10525 case RISCV::VSEXT_VF8:
10526 case RISCV::VUNZIPE_V:
10527 case RISCV::VUNZIPO_V:
10528 case RISCV::VZEXT_VF2:
10529 case RISCV::VZEXT_VF4:
10530 case RISCV::VZEXT_VF8: {
10531 switch (OpNum) {
10532 case 0:
10533 // op: vd
10534 return 7;
10535 case 2:
10536 // op: vm
10537 return 25;
10538 case 1:
10539 // op: vs2
10540 return 20;
10541 }
10542 break;
10543 }
10544 case RISCV::VADD_VI:
10545 case RISCV::VAND_VI:
10546 case RISCV::VMSEQ_VI:
10547 case RISCV::VMSGTU_VI:
10548 case RISCV::VMSGT_VI:
10549 case RISCV::VMSLEU_VI:
10550 case RISCV::VMSLE_VI:
10551 case RISCV::VMSNE_VI:
10552 case RISCV::VNCLIPU_WI:
10553 case RISCV::VNCLIP_WI:
10554 case RISCV::VNSRA_WI:
10555 case RISCV::VNSRL_WI:
10556 case RISCV::VOR_VI:
10557 case RISCV::VRGATHER_VI:
10558 case RISCV::VROR_VI:
10559 case RISCV::VRSUB_VI:
10560 case RISCV::VSADDU_VI:
10561 case RISCV::VSADD_VI:
10562 case RISCV::VSLIDEDOWN_VI:
10563 case RISCV::VSLIDEUP_VI:
10564 case RISCV::VSLL_VI:
10565 case RISCV::VSRA_VI:
10566 case RISCV::VSRL_VI:
10567 case RISCV::VSSRA_VI:
10568 case RISCV::VSSRL_VI:
10569 case RISCV::VWSLL_VI:
10570 case RISCV::VXOR_VI: {
10571 switch (OpNum) {
10572 case 0:
10573 // op: vd
10574 return 7;
10575 case 3:
10576 // op: vm
10577 return 25;
10578 case 1:
10579 // op: vs2
10580 return 20;
10581 case 2:
10582 // op: imm
10583 return 15;
10584 }
10585 break;
10586 }
10587 case RISCV::SF_VFNRCLIP_XU_F_QF:
10588 case RISCV::SF_VFNRCLIP_X_F_QF:
10589 case RISCV::VAADDU_VX:
10590 case RISCV::VAADD_VX:
10591 case RISCV::VADD_VX:
10592 case RISCV::VANDN_VX:
10593 case RISCV::VAND_VX:
10594 case RISCV::VASUBU_VX:
10595 case RISCV::VASUB_VX:
10596 case RISCV::VCLMULH_VX:
10597 case RISCV::VCLMUL_VX:
10598 case RISCV::VDIVU_VX:
10599 case RISCV::VDIV_VX:
10600 case RISCV::VFADD_VF:
10601 case RISCV::VFDIV_VF:
10602 case RISCV::VFMAX_VF:
10603 case RISCV::VFMIN_VF:
10604 case RISCV::VFMUL_VF:
10605 case RISCV::VFRDIV_VF:
10606 case RISCV::VFRSUB_VF:
10607 case RISCV::VFSGNJN_VF:
10608 case RISCV::VFSGNJX_VF:
10609 case RISCV::VFSGNJ_VF:
10610 case RISCV::VFSLIDE1DOWN_VF:
10611 case RISCV::VFSLIDE1UP_VF:
10612 case RISCV::VFSUB_VF:
10613 case RISCV::VFWADD_VF:
10614 case RISCV::VFWADD_WF:
10615 case RISCV::VFWMUL_VF:
10616 case RISCV::VFWSUB_VF:
10617 case RISCV::VFWSUB_WF:
10618 case RISCV::VMAXU_VX:
10619 case RISCV::VMAX_VX:
10620 case RISCV::VMFEQ_VF:
10621 case RISCV::VMFGE_VF:
10622 case RISCV::VMFGT_VF:
10623 case RISCV::VMFLE_VF:
10624 case RISCV::VMFLT_VF:
10625 case RISCV::VMFNE_VF:
10626 case RISCV::VMINU_VX:
10627 case RISCV::VMIN_VX:
10628 case RISCV::VMSEQ_VX:
10629 case RISCV::VMSGTU_VX:
10630 case RISCV::VMSGT_VX:
10631 case RISCV::VMSLEU_VX:
10632 case RISCV::VMSLE_VX:
10633 case RISCV::VMSLTU_VX:
10634 case RISCV::VMSLT_VX:
10635 case RISCV::VMSNE_VX:
10636 case RISCV::VMULHSU_VX:
10637 case RISCV::VMULHU_VX:
10638 case RISCV::VMULH_VX:
10639 case RISCV::VMUL_VX:
10640 case RISCV::VNCLIPU_WX:
10641 case RISCV::VNCLIP_WX:
10642 case RISCV::VNSRA_WX:
10643 case RISCV::VNSRL_WX:
10644 case RISCV::VOR_VX:
10645 case RISCV::VREMU_VX:
10646 case RISCV::VREM_VX:
10647 case RISCV::VRGATHER_VX:
10648 case RISCV::VROL_VX:
10649 case RISCV::VROR_VX:
10650 case RISCV::VRSUB_VX:
10651 case RISCV::VSADDU_VX:
10652 case RISCV::VSADD_VX:
10653 case RISCV::VSLIDE1DOWN_VX:
10654 case RISCV::VSLIDE1UP_VX:
10655 case RISCV::VSLIDEDOWN_VX:
10656 case RISCV::VSLIDEUP_VX:
10657 case RISCV::VSLL_VX:
10658 case RISCV::VSMUL_VX:
10659 case RISCV::VSRA_VX:
10660 case RISCV::VSRL_VX:
10661 case RISCV::VSSRA_VX:
10662 case RISCV::VSSRL_VX:
10663 case RISCV::VSSUBU_VX:
10664 case RISCV::VSSUB_VX:
10665 case RISCV::VSUB_VX:
10666 case RISCV::VWADDU_VX:
10667 case RISCV::VWADDU_WX:
10668 case RISCV::VWADD_VX:
10669 case RISCV::VWADD_WX:
10670 case RISCV::VWMULSU_VX:
10671 case RISCV::VWMULU_VX:
10672 case RISCV::VWMUL_VX:
10673 case RISCV::VWSLL_VX:
10674 case RISCV::VWSUBU_VX:
10675 case RISCV::VWSUBU_WX:
10676 case RISCV::VWSUB_VX:
10677 case RISCV::VWSUB_WX:
10678 case RISCV::VXOR_VX: {
10679 switch (OpNum) {
10680 case 0:
10681 // op: vd
10682 return 7;
10683 case 3:
10684 // op: vm
10685 return 25;
10686 case 1:
10687 // op: vs2
10688 return 20;
10689 case 2:
10690 // op: rs1
10691 return 15;
10692 }
10693 break;
10694 }
10695 case RISCV::VAADDU_VV:
10696 case RISCV::VAADD_VV:
10697 case RISCV::VABDU_VV:
10698 case RISCV::VABD_VV:
10699 case RISCV::VADD_VV:
10700 case RISCV::VANDN_VV:
10701 case RISCV::VAND_VV:
10702 case RISCV::VASUBU_VV:
10703 case RISCV::VASUB_VV:
10704 case RISCV::VCLMULH_VV:
10705 case RISCV::VCLMUL_VV:
10706 case RISCV::VDIVU_VV:
10707 case RISCV::VDIV_VV:
10708 case RISCV::VFADD_VV:
10709 case RISCV::VFDIV_VV:
10710 case RISCV::VFMAX_VV:
10711 case RISCV::VFMIN_VV:
10712 case RISCV::VFMUL_VV:
10713 case RISCV::VFREDMAX_VS:
10714 case RISCV::VFREDMIN_VS:
10715 case RISCV::VFREDOSUM_VS:
10716 case RISCV::VFREDUSUM_VS:
10717 case RISCV::VFSGNJN_VV:
10718 case RISCV::VFSGNJX_VV:
10719 case RISCV::VFSGNJ_VV:
10720 case RISCV::VFSUB_VV:
10721 case RISCV::VFWADD_VV:
10722 case RISCV::VFWADD_WV:
10723 case RISCV::VFWMUL_VV:
10724 case RISCV::VFWREDOSUM_VS:
10725 case RISCV::VFWREDUSUM_VS:
10726 case RISCV::VFWSUB_VV:
10727 case RISCV::VFWSUB_WV:
10728 case RISCV::VMAXU_VV:
10729 case RISCV::VMAX_VV:
10730 case RISCV::VMFEQ_VV:
10731 case RISCV::VMFLE_VV:
10732 case RISCV::VMFLT_VV:
10733 case RISCV::VMFNE_VV:
10734 case RISCV::VMINU_VV:
10735 case RISCV::VMIN_VV:
10736 case RISCV::VMSEQ_VV:
10737 case RISCV::VMSLEU_VV:
10738 case RISCV::VMSLE_VV:
10739 case RISCV::VMSLTU_VV:
10740 case RISCV::VMSLT_VV:
10741 case RISCV::VMSNE_VV:
10742 case RISCV::VMULHSU_VV:
10743 case RISCV::VMULHU_VV:
10744 case RISCV::VMULH_VV:
10745 case RISCV::VMUL_VV:
10746 case RISCV::VNCLIPU_WV:
10747 case RISCV::VNCLIP_WV:
10748 case RISCV::VNSRA_WV:
10749 case RISCV::VNSRL_WV:
10750 case RISCV::VOR_VV:
10751 case RISCV::VPAIRE_VV:
10752 case RISCV::VPAIRO_VV:
10753 case RISCV::VREDAND_VS:
10754 case RISCV::VREDMAXU_VS:
10755 case RISCV::VREDMAX_VS:
10756 case RISCV::VREDMINU_VS:
10757 case RISCV::VREDMIN_VS:
10758 case RISCV::VREDOR_VS:
10759 case RISCV::VREDSUM_VS:
10760 case RISCV::VREDXOR_VS:
10761 case RISCV::VREMU_VV:
10762 case RISCV::VREM_VV:
10763 case RISCV::VRGATHEREI16_VV:
10764 case RISCV::VRGATHER_VV:
10765 case RISCV::VROL_VV:
10766 case RISCV::VROR_VV:
10767 case RISCV::VSADDU_VV:
10768 case RISCV::VSADD_VV:
10769 case RISCV::VSLL_VV:
10770 case RISCV::VSMUL_VV:
10771 case RISCV::VSRA_VV:
10772 case RISCV::VSRL_VV:
10773 case RISCV::VSSRA_VV:
10774 case RISCV::VSSRL_VV:
10775 case RISCV::VSSUBU_VV:
10776 case RISCV::VSSUB_VV:
10777 case RISCV::VSUB_VV:
10778 case RISCV::VWABDAU_VV:
10779 case RISCV::VWABDA_VV:
10780 case RISCV::VWADDU_VV:
10781 case RISCV::VWADDU_WV:
10782 case RISCV::VWADD_VV:
10783 case RISCV::VWADD_WV:
10784 case RISCV::VWMULSU_VV:
10785 case RISCV::VWMULU_VV:
10786 case RISCV::VWMUL_VV:
10787 case RISCV::VWREDSUMU_VS:
10788 case RISCV::VWREDSUM_VS:
10789 case RISCV::VWSLL_VV:
10790 case RISCV::VWSUBU_VV:
10791 case RISCV::VWSUBU_WV:
10792 case RISCV::VWSUB_VV:
10793 case RISCV::VWSUB_WV:
10794 case RISCV::VXOR_VV:
10795 case RISCV::VZIP_VV: {
10796 switch (OpNum) {
10797 case 0:
10798 // op: vd
10799 return 7;
10800 case 3:
10801 // op: vm
10802 return 25;
10803 case 1:
10804 // op: vs2
10805 return 20;
10806 case 2:
10807 // op: vs1
10808 return 15;
10809 }
10810 break;
10811 }
10812 case RISCV::VMTS_V:
10813 case RISCV::VMTTS_V: {
10814 switch (OpNum) {
10815 case 0:
10816 // op: vs3
10817 return 7;
10818 case 1:
10819 // op: rs1
10820 return 15;
10821 case 2:
10822 // op: rs2
10823 return 20;
10824 case 4:
10825 // op: vm
10826 return 25;
10827 case 3:
10828 // op: vlambda
10829 return 29;
10830 }
10831 break;
10832 }
10833 case RISCV::C_LI:
10834 case RISCV::C_LUI: {
10835 switch (OpNum) {
10836 case 1:
10837 // op: imm
10838 return 2;
10839 case 0:
10840 // op: rd
10841 return 7;
10842 }
10843 break;
10844 }
10845 case RISCV::C_BEQZ:
10846 case RISCV::C_BNEZ: {
10847 switch (OpNum) {
10848 case 1:
10849 // op: imm
10850 return 2;
10851 case 0:
10852 // op: rs1
10853 return 7;
10854 }
10855 break;
10856 }
10857 case RISCV::PREFETCH_I:
10858 case RISCV::PREFETCH_R:
10859 case RISCV::PREFETCH_W: {
10860 switch (OpNum) {
10861 case 1:
10862 // op: imm12
10863 return 25;
10864 case 0:
10865 // op: rs1
10866 return 15;
10867 }
10868 break;
10869 }
10870 case RISCV::AIF_FSQ2:
10871 case RISCV::AIF_FSW_PS: {
10872 switch (OpNum) {
10873 case 1:
10874 // op: imm12
10875 return 7;
10876 case 0:
10877 // op: rs2
10878 return 20;
10879 case 2:
10880 // op: rs1
10881 return 15;
10882 }
10883 break;
10884 }
10885 case RISCV::NDS_LDGP:
10886 case RISCV::NDS_LHGP:
10887 case RISCV::NDS_LHUGP:
10888 case RISCV::NDS_LWGP:
10889 case RISCV::NDS_LWUGP: {
10890 switch (OpNum) {
10891 case 1:
10892 // op: imm17
10893 return 15;
10894 case 0:
10895 // op: rd
10896 return 7;
10897 }
10898 break;
10899 }
10900 case RISCV::NDS_SDGP:
10901 case RISCV::NDS_SHGP:
10902 case RISCV::NDS_SWGP: {
10903 switch (OpNum) {
10904 case 1:
10905 // op: imm17
10906 return 7;
10907 case 0:
10908 // op: rs2
10909 return 20;
10910 }
10911 break;
10912 }
10913 case RISCV::NDS_ADDIGP:
10914 case RISCV::NDS_LBGP:
10915 case RISCV::NDS_LBUGP: {
10916 switch (OpNum) {
10917 case 1:
10918 // op: imm18
10919 return 14;
10920 case 0:
10921 // op: rd
10922 return 7;
10923 }
10924 break;
10925 }
10926 case RISCV::NDS_SBGP: {
10927 switch (OpNum) {
10928 case 1:
10929 // op: imm18
10930 return 7;
10931 case 0:
10932 // op: rs2
10933 return 20;
10934 }
10935 break;
10936 }
10937 case RISCV::AIF_FBCI_PI:
10938 case RISCV::AIF_FBCI_PS:
10939 case RISCV::AUIPC:
10940 case RISCV::JAL:
10941 case RISCV::LUI:
10942 case RISCV::QC_LI: {
10943 switch (OpNum) {
10944 case 1:
10945 // op: imm20
10946 return 12;
10947 case 0:
10948 // op: rd
10949 return 7;
10950 }
10951 break;
10952 }
10953 case RISCV::MIPS_PREF: {
10954 switch (OpNum) {
10955 case 1:
10956 // op: imm9
10957 return 20;
10958 case 0:
10959 // op: rs1
10960 return 15;
10961 case 2:
10962 // op: hint
10963 return 7;
10964 }
10965 break;
10966 }
10967 case RISCV::InsnQC_EAI: {
10968 switch (OpNum) {
10969 case 1:
10970 // op: opcode
10971 return 0;
10972 case 2:
10973 // op: func3
10974 return 12;
10975 case 3:
10976 // op: func1
10977 return 15;
10978 case 0:
10979 // op: rd
10980 return 7;
10981 case 4:
10982 // op: imm32
10983 return 16;
10984 }
10985 break;
10986 }
10987 case RISCV::InsnQC_EI:
10988 case RISCV::InsnQC_EI_Mem: {
10989 switch (OpNum) {
10990 case 1:
10991 // op: opcode
10992 return 0;
10993 case 2:
10994 // op: func3
10995 return 12;
10996 case 3:
10997 // op: func2
10998 return 30;
10999 case 0:
11000 // op: rd
11001 return 7;
11002 case 4:
11003 // op: rs1
11004 return 15;
11005 case 5:
11006 // op: imm26
11007 return 20;
11008 }
11009 break;
11010 }
11011 case RISCV::InsnI:
11012 case RISCV::InsnI_Mem: {
11013 switch (OpNum) {
11014 case 1:
11015 // op: opcode
11016 return 0;
11017 case 2:
11018 // op: funct3
11019 return 12;
11020 case 4:
11021 // op: imm12
11022 return 20;
11023 case 3:
11024 // op: rs1
11025 return 15;
11026 case 0:
11027 // op: rd
11028 return 7;
11029 }
11030 break;
11031 }
11032 case RISCV::InsnCI: {
11033 switch (OpNum) {
11034 case 1:
11035 // op: opcode
11036 return 0;
11037 case 2:
11038 // op: funct3
11039 return 13;
11040 case 3:
11041 // op: imm6
11042 return 2;
11043 case 0:
11044 // op: rd
11045 return 7;
11046 }
11047 break;
11048 }
11049 case RISCV::InsnCIW: {
11050 switch (OpNum) {
11051 case 1:
11052 // op: opcode
11053 return 0;
11054 case 2:
11055 // op: funct3
11056 return 13;
11057 case 3:
11058 // op: imm8
11059 return 5;
11060 case 0:
11061 // op: rd
11062 return 2;
11063 }
11064 break;
11065 }
11066 case RISCV::InsnCL: {
11067 switch (OpNum) {
11068 case 1:
11069 // op: opcode
11070 return 0;
11071 case 2:
11072 // op: funct3
11073 return 13;
11074 case 4:
11075 // op: imm5
11076 return 5;
11077 case 0:
11078 // op: rd
11079 return 2;
11080 case 3:
11081 // op: rs1
11082 return 7;
11083 }
11084 break;
11085 }
11086 case RISCV::InsnCR: {
11087 switch (OpNum) {
11088 case 1:
11089 // op: opcode
11090 return 0;
11091 case 2:
11092 // op: funct4
11093 return 12;
11094 case 3:
11095 // op: rs2
11096 return 2;
11097 case 0:
11098 // op: rd
11099 return 7;
11100 }
11101 break;
11102 }
11103 case RISCV::InsnCA: {
11104 switch (OpNum) {
11105 case 1:
11106 // op: opcode
11107 return 0;
11108 case 2:
11109 // op: funct6
11110 return 10;
11111 case 3:
11112 // op: funct2
11113 return 5;
11114 case 0:
11115 // op: rd
11116 return 7;
11117 case 4:
11118 // op: rs2
11119 return 2;
11120 }
11121 break;
11122 }
11123 case RISCV::InsnJ:
11124 case RISCV::InsnU: {
11125 switch (OpNum) {
11126 case 1:
11127 // op: opcode
11128 return 0;
11129 case 2:
11130 // op: imm20
11131 return 12;
11132 case 0:
11133 // op: rd
11134 return 7;
11135 }
11136 break;
11137 }
11138 case RISCV::InsnR4: {
11139 switch (OpNum) {
11140 case 1:
11141 // op: opcode
11142 return 0;
11143 case 3:
11144 // op: funct2
11145 return 25;
11146 case 2:
11147 // op: funct3
11148 return 12;
11149 case 6:
11150 // op: rs3
11151 return 27;
11152 case 5:
11153 // op: rs2
11154 return 20;
11155 case 4:
11156 // op: rs1
11157 return 15;
11158 case 0:
11159 // op: rd
11160 return 7;
11161 }
11162 break;
11163 }
11164 case RISCV::InsnR: {
11165 switch (OpNum) {
11166 case 1:
11167 // op: opcode
11168 return 0;
11169 case 3:
11170 // op: funct7
11171 return 25;
11172 case 2:
11173 // op: funct3
11174 return 12;
11175 case 5:
11176 // op: rs2
11177 return 20;
11178 case 4:
11179 // op: rs1
11180 return 15;
11181 case 0:
11182 // op: rd
11183 return 7;
11184 }
11185 break;
11186 }
11187 case RISCV::QC_C_MULIADD: {
11188 switch (OpNum) {
11189 case 1:
11190 // op: rd
11191 return 2;
11192 case 2:
11193 // op: rs1
11194 return 7;
11195 case 3:
11196 // op: uimm
11197 return 5;
11198 }
11199 break;
11200 }
11201 case RISCV::QC_C_MVEQZ: {
11202 switch (OpNum) {
11203 case 1:
11204 // op: rd
11205 return 2;
11206 case 2:
11207 // op: rs1
11208 return 7;
11209 }
11210 break;
11211 }
11212 case RISCV::QC_E_ADDAI:
11213 case RISCV::QC_E_ANDAI:
11214 case RISCV::QC_E_ORAI:
11215 case RISCV::QC_E_XORAI: {
11216 switch (OpNum) {
11217 case 1:
11218 // op: rd
11219 return 7;
11220 case 2:
11221 // op: imm
11222 return 16;
11223 }
11224 break;
11225 }
11226 case RISCV::QC_INSBI: {
11227 switch (OpNum) {
11228 case 1:
11229 // op: rd
11230 return 7;
11231 case 2:
11232 // op: imm5
11233 return 15;
11234 case 4:
11235 // op: shamt
11236 return 20;
11237 case 3:
11238 // op: width
11239 return 25;
11240 }
11241 break;
11242 }
11243 case RISCV::QC_C_EXTU: {
11244 switch (OpNum) {
11245 case 1:
11246 // op: rd
11247 return 7;
11248 case 2:
11249 // op: width
11250 return 2;
11251 }
11252 break;
11253 }
11254 case RISCV::C_NOT:
11255 case RISCV::C_SEXT_B:
11256 case RISCV::C_SEXT_H:
11257 case RISCV::C_ZEXT_B:
11258 case RISCV::C_ZEXT_H:
11259 case RISCV::C_ZEXT_W: {
11260 switch (OpNum) {
11261 case 1:
11262 // op: rd
11263 return 7;
11264 }
11265 break;
11266 }
11267 case RISCV::YBNDSWI: {
11268 switch (OpNum) {
11269 case 1:
11270 // op: rs1
11271 return 15;
11272 case 0:
11273 // op: rd
11274 return 7;
11275 case 2:
11276 // op: imm
11277 return 20;
11278 }
11279 break;
11280 }
11281 case RISCV::QC_WRAPI: {
11282 switch (OpNum) {
11283 case 1:
11284 // op: rs1
11285 return 15;
11286 case 0:
11287 // op: rd
11288 return 7;
11289 case 2:
11290 // op: imm11
11291 return 20;
11292 }
11293 break;
11294 }
11295 case RISCV::ADDI:
11296 case RISCV::ADDIW:
11297 case RISCV::ANDI:
11298 case RISCV::CV_ELW:
11299 case RISCV::FLD:
11300 case RISCV::FLH:
11301 case RISCV::FLQ:
11302 case RISCV::FLW:
11303 case RISCV::JALR:
11304 case RISCV::LB:
11305 case RISCV::LBU:
11306 case RISCV::LD:
11307 case RISCV::LD_RV32:
11308 case RISCV::LH:
11309 case RISCV::LHU:
11310 case RISCV::LH_INX:
11311 case RISCV::LW:
11312 case RISCV::LWU:
11313 case RISCV::LW_INX:
11314 case RISCV::ORI:
11315 case RISCV::SLTI:
11316 case RISCV::SLTIU:
11317 case RISCV::XORI:
11318 case RISCV::YADDI: {
11319 switch (OpNum) {
11320 case 1:
11321 // op: rs1
11322 return 15;
11323 case 0:
11324 // op: rd
11325 return 7;
11326 case 2:
11327 // op: imm12
11328 return 20;
11329 }
11330 break;
11331 }
11332 case RISCV::QC_INW: {
11333 switch (OpNum) {
11334 case 1:
11335 // op: rs1
11336 return 15;
11337 case 0:
11338 // op: rd
11339 return 7;
11340 case 2:
11341 // op: imm14
11342 return 20;
11343 }
11344 break;
11345 }
11346 case RISCV::CV_CLIP:
11347 case RISCV::CV_CLIPU: {
11348 switch (OpNum) {
11349 case 1:
11350 // op: rs1
11351 return 15;
11352 case 0:
11353 // op: rd
11354 return 7;
11355 case 2:
11356 // op: imm5
11357 return 20;
11358 }
11359 break;
11360 }
11361 case RISCV::CV_ADD_SCI_B:
11362 case RISCV::CV_ADD_SCI_H:
11363 case RISCV::CV_AND_SCI_B:
11364 case RISCV::CV_AND_SCI_H:
11365 case RISCV::CV_AVGU_SCI_B:
11366 case RISCV::CV_AVGU_SCI_H:
11367 case RISCV::CV_AVG_SCI_B:
11368 case RISCV::CV_AVG_SCI_H:
11369 case RISCV::CV_CMPEQ_SCI_B:
11370 case RISCV::CV_CMPEQ_SCI_H:
11371 case RISCV::CV_CMPGEU_SCI_B:
11372 case RISCV::CV_CMPGEU_SCI_H:
11373 case RISCV::CV_CMPGE_SCI_B:
11374 case RISCV::CV_CMPGE_SCI_H:
11375 case RISCV::CV_CMPGTU_SCI_B:
11376 case RISCV::CV_CMPGTU_SCI_H:
11377 case RISCV::CV_CMPGT_SCI_B:
11378 case RISCV::CV_CMPGT_SCI_H:
11379 case RISCV::CV_CMPLEU_SCI_B:
11380 case RISCV::CV_CMPLEU_SCI_H:
11381 case RISCV::CV_CMPLE_SCI_B:
11382 case RISCV::CV_CMPLE_SCI_H:
11383 case RISCV::CV_CMPLTU_SCI_B:
11384 case RISCV::CV_CMPLTU_SCI_H:
11385 case RISCV::CV_CMPLT_SCI_B:
11386 case RISCV::CV_CMPLT_SCI_H:
11387 case RISCV::CV_CMPNE_SCI_B:
11388 case RISCV::CV_CMPNE_SCI_H:
11389 case RISCV::CV_DOTSP_SCI_B:
11390 case RISCV::CV_DOTSP_SCI_H:
11391 case RISCV::CV_DOTUP_SCI_B:
11392 case RISCV::CV_DOTUP_SCI_H:
11393 case RISCV::CV_DOTUSP_SCI_B:
11394 case RISCV::CV_DOTUSP_SCI_H:
11395 case RISCV::CV_EXTRACTU_B:
11396 case RISCV::CV_EXTRACTU_H:
11397 case RISCV::CV_EXTRACT_B:
11398 case RISCV::CV_EXTRACT_H:
11399 case RISCV::CV_MAXU_SCI_B:
11400 case RISCV::CV_MAXU_SCI_H:
11401 case RISCV::CV_MAX_SCI_B:
11402 case RISCV::CV_MAX_SCI_H:
11403 case RISCV::CV_MINU_SCI_B:
11404 case RISCV::CV_MINU_SCI_H:
11405 case RISCV::CV_MIN_SCI_B:
11406 case RISCV::CV_MIN_SCI_H:
11407 case RISCV::CV_OR_SCI_B:
11408 case RISCV::CV_OR_SCI_H:
11409 case RISCV::CV_SHUFFLEI0_SCI_B:
11410 case RISCV::CV_SHUFFLEI1_SCI_B:
11411 case RISCV::CV_SHUFFLEI2_SCI_B:
11412 case RISCV::CV_SHUFFLEI3_SCI_B:
11413 case RISCV::CV_SHUFFLE_SCI_H:
11414 case RISCV::CV_SLL_SCI_B:
11415 case RISCV::CV_SLL_SCI_H:
11416 case RISCV::CV_SRA_SCI_B:
11417 case RISCV::CV_SRA_SCI_H:
11418 case RISCV::CV_SRL_SCI_B:
11419 case RISCV::CV_SRL_SCI_H:
11420 case RISCV::CV_SUB_SCI_B:
11421 case RISCV::CV_SUB_SCI_H:
11422 case RISCV::CV_XOR_SCI_B:
11423 case RISCV::CV_XOR_SCI_H: {
11424 switch (OpNum) {
11425 case 1:
11426 // op: rs1
11427 return 15;
11428 case 0:
11429 // op: rd
11430 return 7;
11431 case 2:
11432 // op: imm6
11433 return 20;
11434 }
11435 break;
11436 }
11437 case RISCV::CV_BCLR:
11438 case RISCV::CV_BITREV:
11439 case RISCV::CV_BSET:
11440 case RISCV::CV_EXTRACT:
11441 case RISCV::CV_EXTRACTU: {
11442 switch (OpNum) {
11443 case 1:
11444 // op: rs1
11445 return 15;
11446 case 0:
11447 // op: rd
11448 return 7;
11449 case 2:
11450 // op: is3
11451 return 25;
11452 case 3:
11453 // op: is2
11454 return 20;
11455 }
11456 break;
11457 }
11458 case RISCV::TH_EXT:
11459 case RISCV::TH_EXTU: {
11460 switch (OpNum) {
11461 case 1:
11462 // op: rs1
11463 return 15;
11464 case 0:
11465 // op: rd
11466 return 7;
11467 case 2:
11468 // op: msb
11469 return 26;
11470 case 3:
11471 // op: lsb
11472 return 20;
11473 }
11474 break;
11475 }
11476 case RISCV::AES64KS1I: {
11477 switch (OpNum) {
11478 case 1:
11479 // op: rs1
11480 return 15;
11481 case 0:
11482 // op: rd
11483 return 7;
11484 case 2:
11485 // op: rnum
11486 return 20;
11487 }
11488 break;
11489 }
11490 case RISCV::BCLRI:
11491 case RISCV::BEXTI:
11492 case RISCV::BINVI:
11493 case RISCV::BSETI:
11494 case RISCV::PSATI_H:
11495 case RISCV::PSATI_W:
11496 case RISCV::PSLLI_B:
11497 case RISCV::PSLLI_H:
11498 case RISCV::PSLLI_W:
11499 case RISCV::PSRAI_B:
11500 case RISCV::PSRAI_H:
11501 case RISCV::PSRAI_W:
11502 case RISCV::PSRARI_H:
11503 case RISCV::PSRARI_W:
11504 case RISCV::PSRLI_B:
11505 case RISCV::PSRLI_H:
11506 case RISCV::PSRLI_W:
11507 case RISCV::PSSLAI_H:
11508 case RISCV::PSSLAI_W:
11509 case RISCV::PUSATI_H:
11510 case RISCV::PUSATI_W:
11511 case RISCV::RORI:
11512 case RISCV::RORIW:
11513 case RISCV::SATI_RV32:
11514 case RISCV::SATI_RV64:
11515 case RISCV::SLLI:
11516 case RISCV::SLLIW:
11517 case RISCV::SLLI_UW:
11518 case RISCV::SRAI:
11519 case RISCV::SRAIW:
11520 case RISCV::SRARI_RV32:
11521 case RISCV::SRARI_RV64:
11522 case RISCV::SRLI:
11523 case RISCV::SRLIW:
11524 case RISCV::SRLIY:
11525 case RISCV::SSLAI:
11526 case RISCV::TH_SRRI:
11527 case RISCV::TH_SRRIW:
11528 case RISCV::TH_TST:
11529 case RISCV::USATI_RV32:
11530 case RISCV::USATI_RV64: {
11531 switch (OpNum) {
11532 case 1:
11533 // op: rs1
11534 return 15;
11535 case 0:
11536 // op: rd
11537 return 7;
11538 case 2:
11539 // op: shamt
11540 return 20;
11541 }
11542 break;
11543 }
11544 case RISCV::VSETVLI: {
11545 switch (OpNum) {
11546 case 1:
11547 // op: rs1
11548 return 15;
11549 case 0:
11550 // op: rd
11551 return 7;
11552 case 2:
11553 // op: vtypei
11554 return 20;
11555 }
11556 break;
11557 }
11558 case RISCV::QC_EXT:
11559 case RISCV::QC_EXTD:
11560 case RISCV::QC_EXTDU:
11561 case RISCV::QC_EXTU: {
11562 switch (OpNum) {
11563 case 1:
11564 // op: rs1
11565 return 15;
11566 case 0:
11567 // op: rd
11568 return 7;
11569 case 3:
11570 // op: shamt
11571 return 20;
11572 case 2:
11573 // op: width
11574 return 25;
11575 }
11576 break;
11577 }
11578 case RISCV::ABS:
11579 case RISCV::ABSW:
11580 case RISCV::AES64IM:
11581 case RISCV::AIF_FBCX_PS:
11582 case RISCV::AIF_FCLASS_PS:
11583 case RISCV::AIF_FCVT_F10_PS:
11584 case RISCV::AIF_FCVT_F11_PS:
11585 case RISCV::AIF_FCVT_F16_PS:
11586 case RISCV::AIF_FCVT_PS_F10:
11587 case RISCV::AIF_FCVT_PS_F11:
11588 case RISCV::AIF_FCVT_PS_F16:
11589 case RISCV::AIF_FCVT_PS_RAST:
11590 case RISCV::AIF_FCVT_PS_SN16:
11591 case RISCV::AIF_FCVT_PS_SN8:
11592 case RISCV::AIF_FCVT_PS_UN10:
11593 case RISCV::AIF_FCVT_PS_UN16:
11594 case RISCV::AIF_FCVT_PS_UN2:
11595 case RISCV::AIF_FCVT_PS_UN24:
11596 case RISCV::AIF_FCVT_PS_UN8:
11597 case RISCV::AIF_FCVT_RAST_PS:
11598 case RISCV::AIF_FCVT_SN16_PS:
11599 case RISCV::AIF_FCVT_SN8_PS:
11600 case RISCV::AIF_FCVT_UN10_PS:
11601 case RISCV::AIF_FCVT_UN16_PS:
11602 case RISCV::AIF_FCVT_UN24_PS:
11603 case RISCV::AIF_FCVT_UN2_PS:
11604 case RISCV::AIF_FCVT_UN8_PS:
11605 case RISCV::AIF_FEXP_PS:
11606 case RISCV::AIF_FFRC_PS:
11607 case RISCV::AIF_FLOG_PS:
11608 case RISCV::AIF_FLWG_PS:
11609 case RISCV::AIF_FLWL_PS:
11610 case RISCV::AIF_FNOT_PI:
11611 case RISCV::AIF_FPACKREPB_PI:
11612 case RISCV::AIF_FPACKREPH_PI:
11613 case RISCV::AIF_FRCP_PS:
11614 case RISCV::AIF_FRSQ_PS:
11615 case RISCV::AIF_FSAT8_PI:
11616 case RISCV::AIF_FSATU8_PI:
11617 case RISCV::AIF_FSETM_PI:
11618 case RISCV::AIF_FSIN_PS:
11619 case RISCV::AIF_FSQRT_PS:
11620 case RISCV::AIF_MASKNOT:
11621 case RISCV::AIF_MASKPOPC:
11622 case RISCV::AIF_MASKPOPCZ:
11623 case RISCV::BREV8:
11624 case RISCV::CLS:
11625 case RISCV::CLSW:
11626 case RISCV::CLZ:
11627 case RISCV::CLZW:
11628 case RISCV::CPOP:
11629 case RISCV::CPOPW:
11630 case RISCV::CTZ:
11631 case RISCV::CTZW:
11632 case RISCV::CV_ABS:
11633 case RISCV::CV_ABS_B:
11634 case RISCV::CV_ABS_H:
11635 case RISCV::CV_CLB:
11636 case RISCV::CV_CNT:
11637 case RISCV::CV_CPLXCONJ:
11638 case RISCV::CV_EXTBS:
11639 case RISCV::CV_EXTBZ:
11640 case RISCV::CV_EXTHS:
11641 case RISCV::CV_EXTHZ:
11642 case RISCV::CV_FF1:
11643 case RISCV::CV_FL1:
11644 case RISCV::FCLASS_D:
11645 case RISCV::FCLASS_D_IN32X:
11646 case RISCV::FCLASS_D_INX:
11647 case RISCV::FCLASS_H:
11648 case RISCV::FCLASS_H_INX:
11649 case RISCV::FCLASS_Q:
11650 case RISCV::FCLASS_S:
11651 case RISCV::FCLASS_S_INX:
11652 case RISCV::FCVTMOD_W_D:
11653 case RISCV::FMVH_X_D:
11654 case RISCV::FMVH_X_Q:
11655 case RISCV::FMV_D_X:
11656 case RISCV::FMV_H_X:
11657 case RISCV::FMV_W_X:
11658 case RISCV::FMV_X_D:
11659 case RISCV::FMV_X_H:
11660 case RISCV::FMV_X_W:
11661 case RISCV::FMV_X_W_FPR64:
11662 case RISCV::HLVX_HU:
11663 case RISCV::HLVX_WU:
11664 case RISCV::HLV_B:
11665 case RISCV::HLV_BU:
11666 case RISCV::HLV_D:
11667 case RISCV::HLV_H:
11668 case RISCV::HLV_HU:
11669 case RISCV::HLV_W:
11670 case RISCV::HLV_WU:
11671 case RISCV::LB_AQ:
11672 case RISCV::LB_AQRL:
11673 case RISCV::LD_AQ:
11674 case RISCV::LD_AQRL:
11675 case RISCV::LH_AQ:
11676 case RISCV::LH_AQRL:
11677 case RISCV::LR_D:
11678 case RISCV::LR_D_AQ:
11679 case RISCV::LR_D_AQRL:
11680 case RISCV::LR_D_RL:
11681 case RISCV::LR_W:
11682 case RISCV::LR_W_AQ:
11683 case RISCV::LR_W_AQRL:
11684 case RISCV::LR_W_RL:
11685 case RISCV::LW_AQ:
11686 case RISCV::LW_AQRL:
11687 case RISCV::MOP_R_0:
11688 case RISCV::MOP_R_1:
11689 case RISCV::MOP_R_10:
11690 case RISCV::MOP_R_11:
11691 case RISCV::MOP_R_12:
11692 case RISCV::MOP_R_13:
11693 case RISCV::MOP_R_14:
11694 case RISCV::MOP_R_15:
11695 case RISCV::MOP_R_16:
11696 case RISCV::MOP_R_17:
11697 case RISCV::MOP_R_18:
11698 case RISCV::MOP_R_19:
11699 case RISCV::MOP_R_2:
11700 case RISCV::MOP_R_20:
11701 case RISCV::MOP_R_21:
11702 case RISCV::MOP_R_22:
11703 case RISCV::MOP_R_23:
11704 case RISCV::MOP_R_24:
11705 case RISCV::MOP_R_25:
11706 case RISCV::MOP_R_26:
11707 case RISCV::MOP_R_27:
11708 case RISCV::MOP_R_28:
11709 case RISCV::MOP_R_29:
11710 case RISCV::MOP_R_3:
11711 case RISCV::MOP_R_30:
11712 case RISCV::MOP_R_31:
11713 case RISCV::MOP_R_4:
11714 case RISCV::MOP_R_5:
11715 case RISCV::MOP_R_6:
11716 case RISCV::MOP_R_7:
11717 case RISCV::MOP_R_8:
11718 case RISCV::MOP_R_9:
11719 case RISCV::NDS_FMV_BF16_X:
11720 case RISCV::NDS_FMV_X_BF16:
11721 case RISCV::ORC_B:
11722 case RISCV::PSABS_B:
11723 case RISCV::PSABS_H:
11724 case RISCV::PSEXT_H_B:
11725 case RISCV::PSEXT_W_B:
11726 case RISCV::PSEXT_W_H:
11727 case RISCV::QC_BREV32:
11728 case RISCV::QC_CLO:
11729 case RISCV::QC_COMPRESS2:
11730 case RISCV::QC_COMPRESS3:
11731 case RISCV::QC_CTO:
11732 case RISCV::QC_EXPAND2:
11733 case RISCV::QC_EXPAND3:
11734 case RISCV::QC_NORM:
11735 case RISCV::QC_NORMEU:
11736 case RISCV::QC_NORMU:
11737 case RISCV::REV16_RV64:
11738 case RISCV::REV8_RV32:
11739 case RISCV::REV8_RV64:
11740 case RISCV::REV_RV32:
11741 case RISCV::REV_RV64:
11742 case RISCV::SEXT_B:
11743 case RISCV::SEXT_H:
11744 case RISCV::SF_VSETTK:
11745 case RISCV::SF_VSETTM:
11746 case RISCV::SF_VSETTN:
11747 case RISCV::SHA256SIG0:
11748 case RISCV::SHA256SIG1:
11749 case RISCV::SHA256SUM0:
11750 case RISCV::SHA256SUM1:
11751 case RISCV::SHA512SIG0:
11752 case RISCV::SHA512SIG1:
11753 case RISCV::SHA512SUM0:
11754 case RISCV::SHA512SUM1:
11755 case RISCV::SM3P0:
11756 case RISCV::SM3P1:
11757 case RISCV::TH_FF0:
11758 case RISCV::TH_FF1:
11759 case RISCV::TH_REV:
11760 case RISCV::TH_REVW:
11761 case RISCV::TH_TSTNBZ:
11762 case RISCV::UNZIP_RV32:
11763 case RISCV::YAMASK:
11764 case RISCV::YBASER:
11765 case RISCV::YLENR:
11766 case RISCV::YMV:
11767 case RISCV::YPERMR:
11768 case RISCV::YTAGR:
11769 case RISCV::YTOPR:
11770 case RISCV::YTYPER:
11771 case RISCV::ZEXT_H_RV32:
11772 case RISCV::ZEXT_H_RV64:
11773 case RISCV::ZIP_RV32: {
11774 switch (OpNum) {
11775 case 1:
11776 // op: rs1
11777 return 15;
11778 case 0:
11779 // op: rd
11780 return 7;
11781 }
11782 break;
11783 }
11784 case RISCV::PWSLAI_B:
11785 case RISCV::PWSLAI_H:
11786 case RISCV::PWSLLI_B:
11787 case RISCV::PWSLLI_H:
11788 case RISCV::WSLAI:
11789 case RISCV::WSLLI: {
11790 switch (OpNum) {
11791 case 1:
11792 // op: rs1
11793 return 15;
11794 case 0:
11795 // op: rd
11796 return 8;
11797 case 2:
11798 // op: shamt
11799 return 20;
11800 }
11801 break;
11802 }
11803 case RISCV::QC_E_SB:
11804 case RISCV::QC_E_SH:
11805 case RISCV::QC_E_SW: {
11806 switch (OpNum) {
11807 case 1:
11808 // op: rs1
11809 return 15;
11810 case 0:
11811 // op: rs2
11812 return 20;
11813 case 2:
11814 // op: imm
11815 return 7;
11816 }
11817 break;
11818 }
11819 case RISCV::CV_SB_rr:
11820 case RISCV::CV_SH_rr:
11821 case RISCV::CV_SW_rr: {
11822 switch (OpNum) {
11823 case 1:
11824 // op: rs1
11825 return 15;
11826 case 0:
11827 // op: rs2
11828 return 20;
11829 case 2:
11830 // op: rs3
11831 return 7;
11832 }
11833 break;
11834 }
11835 case RISCV::QC_OUTW: {
11836 switch (OpNum) {
11837 case 1:
11838 // op: rs1
11839 return 15;
11840 case 0:
11841 // op: rs2
11842 return 7;
11843 case 2:
11844 // op: imm14
11845 return 20;
11846 }
11847 break;
11848 }
11849 case RISCV::NDS_VLN8_V:
11850 case RISCV::NDS_VLNU8_V:
11851 case RISCV::VLE16FF_V:
11852 case RISCV::VLE16_V:
11853 case RISCV::VLE32FF_V:
11854 case RISCV::VLE32_V:
11855 case RISCV::VLE64FF_V:
11856 case RISCV::VLE64_V:
11857 case RISCV::VLE8FF_V:
11858 case RISCV::VLE8_V:
11859 case RISCV::VLSEG2E16FF_V:
11860 case RISCV::VLSEG2E16_V:
11861 case RISCV::VLSEG2E32FF_V:
11862 case RISCV::VLSEG2E32_V:
11863 case RISCV::VLSEG2E64FF_V:
11864 case RISCV::VLSEG2E64_V:
11865 case RISCV::VLSEG2E8FF_V:
11866 case RISCV::VLSEG2E8_V:
11867 case RISCV::VLSEG3E16FF_V:
11868 case RISCV::VLSEG3E16_V:
11869 case RISCV::VLSEG3E32FF_V:
11870 case RISCV::VLSEG3E32_V:
11871 case RISCV::VLSEG3E64FF_V:
11872 case RISCV::VLSEG3E64_V:
11873 case RISCV::VLSEG3E8FF_V:
11874 case RISCV::VLSEG3E8_V:
11875 case RISCV::VLSEG4E16FF_V:
11876 case RISCV::VLSEG4E16_V:
11877 case RISCV::VLSEG4E32FF_V:
11878 case RISCV::VLSEG4E32_V:
11879 case RISCV::VLSEG4E64FF_V:
11880 case RISCV::VLSEG4E64_V:
11881 case RISCV::VLSEG4E8FF_V:
11882 case RISCV::VLSEG4E8_V:
11883 case RISCV::VLSEG5E16FF_V:
11884 case RISCV::VLSEG5E16_V:
11885 case RISCV::VLSEG5E32FF_V:
11886 case RISCV::VLSEG5E32_V:
11887 case RISCV::VLSEG5E64FF_V:
11888 case RISCV::VLSEG5E64_V:
11889 case RISCV::VLSEG5E8FF_V:
11890 case RISCV::VLSEG5E8_V:
11891 case RISCV::VLSEG6E16FF_V:
11892 case RISCV::VLSEG6E16_V:
11893 case RISCV::VLSEG6E32FF_V:
11894 case RISCV::VLSEG6E32_V:
11895 case RISCV::VLSEG6E64FF_V:
11896 case RISCV::VLSEG6E64_V:
11897 case RISCV::VLSEG6E8FF_V:
11898 case RISCV::VLSEG6E8_V:
11899 case RISCV::VLSEG7E16FF_V:
11900 case RISCV::VLSEG7E16_V:
11901 case RISCV::VLSEG7E32FF_V:
11902 case RISCV::VLSEG7E32_V:
11903 case RISCV::VLSEG7E64FF_V:
11904 case RISCV::VLSEG7E64_V:
11905 case RISCV::VLSEG7E8FF_V:
11906 case RISCV::VLSEG7E8_V:
11907 case RISCV::VLSEG8E16FF_V:
11908 case RISCV::VLSEG8E16_V:
11909 case RISCV::VLSEG8E32FF_V:
11910 case RISCV::VLSEG8E32_V:
11911 case RISCV::VLSEG8E64FF_V:
11912 case RISCV::VLSEG8E64_V:
11913 case RISCV::VLSEG8E8FF_V:
11914 case RISCV::VLSEG8E8_V: {
11915 switch (OpNum) {
11916 case 1:
11917 // op: rs1
11918 return 15;
11919 case 0:
11920 // op: vd
11921 return 7;
11922 case 2:
11923 // op: vm
11924 return 25;
11925 }
11926 break;
11927 }
11928 case RISCV::VLSE16_V:
11929 case RISCV::VLSE32_V:
11930 case RISCV::VLSE64_V:
11931 case RISCV::VLSE8_V:
11932 case RISCV::VLSSEG2E16_V:
11933 case RISCV::VLSSEG2E32_V:
11934 case RISCV::VLSSEG2E64_V:
11935 case RISCV::VLSSEG2E8_V:
11936 case RISCV::VLSSEG3E16_V:
11937 case RISCV::VLSSEG3E32_V:
11938 case RISCV::VLSSEG3E64_V:
11939 case RISCV::VLSSEG3E8_V:
11940 case RISCV::VLSSEG4E16_V:
11941 case RISCV::VLSSEG4E32_V:
11942 case RISCV::VLSSEG4E64_V:
11943 case RISCV::VLSSEG4E8_V:
11944 case RISCV::VLSSEG5E16_V:
11945 case RISCV::VLSSEG5E32_V:
11946 case RISCV::VLSSEG5E64_V:
11947 case RISCV::VLSSEG5E8_V:
11948 case RISCV::VLSSEG6E16_V:
11949 case RISCV::VLSSEG6E32_V:
11950 case RISCV::VLSSEG6E64_V:
11951 case RISCV::VLSSEG6E8_V:
11952 case RISCV::VLSSEG7E16_V:
11953 case RISCV::VLSSEG7E32_V:
11954 case RISCV::VLSSEG7E64_V:
11955 case RISCV::VLSSEG7E8_V:
11956 case RISCV::VLSSEG8E16_V:
11957 case RISCV::VLSSEG8E32_V:
11958 case RISCV::VLSSEG8E64_V:
11959 case RISCV::VLSSEG8E8_V: {
11960 switch (OpNum) {
11961 case 1:
11962 // op: rs1
11963 return 15;
11964 case 0:
11965 // op: vd
11966 return 7;
11967 case 3:
11968 // op: vm
11969 return 25;
11970 case 2:
11971 // op: rs2
11972 return 20;
11973 }
11974 break;
11975 }
11976 case RISCV::VLOXEI16_V:
11977 case RISCV::VLOXEI32_V:
11978 case RISCV::VLOXEI64_V:
11979 case RISCV::VLOXEI8_V:
11980 case RISCV::VLOXSEG2EI16_V:
11981 case RISCV::VLOXSEG2EI32_V:
11982 case RISCV::VLOXSEG2EI64_V:
11983 case RISCV::VLOXSEG2EI8_V:
11984 case RISCV::VLOXSEG3EI16_V:
11985 case RISCV::VLOXSEG3EI32_V:
11986 case RISCV::VLOXSEG3EI64_V:
11987 case RISCV::VLOXSEG3EI8_V:
11988 case RISCV::VLOXSEG4EI16_V:
11989 case RISCV::VLOXSEG4EI32_V:
11990 case RISCV::VLOXSEG4EI64_V:
11991 case RISCV::VLOXSEG4EI8_V:
11992 case RISCV::VLOXSEG5EI16_V:
11993 case RISCV::VLOXSEG5EI32_V:
11994 case RISCV::VLOXSEG5EI64_V:
11995 case RISCV::VLOXSEG5EI8_V:
11996 case RISCV::VLOXSEG6EI16_V:
11997 case RISCV::VLOXSEG6EI32_V:
11998 case RISCV::VLOXSEG6EI64_V:
11999 case RISCV::VLOXSEG6EI8_V:
12000 case RISCV::VLOXSEG7EI16_V:
12001 case RISCV::VLOXSEG7EI32_V:
12002 case RISCV::VLOXSEG7EI64_V:
12003 case RISCV::VLOXSEG7EI8_V:
12004 case RISCV::VLOXSEG8EI16_V:
12005 case RISCV::VLOXSEG8EI32_V:
12006 case RISCV::VLOXSEG8EI64_V:
12007 case RISCV::VLOXSEG8EI8_V:
12008 case RISCV::VLUXEI16_V:
12009 case RISCV::VLUXEI32_V:
12010 case RISCV::VLUXEI64_V:
12011 case RISCV::VLUXEI8_V:
12012 case RISCV::VLUXSEG2EI16_V:
12013 case RISCV::VLUXSEG2EI32_V:
12014 case RISCV::VLUXSEG2EI64_V:
12015 case RISCV::VLUXSEG2EI8_V:
12016 case RISCV::VLUXSEG3EI16_V:
12017 case RISCV::VLUXSEG3EI32_V:
12018 case RISCV::VLUXSEG3EI64_V:
12019 case RISCV::VLUXSEG3EI8_V:
12020 case RISCV::VLUXSEG4EI16_V:
12021 case RISCV::VLUXSEG4EI32_V:
12022 case RISCV::VLUXSEG4EI64_V:
12023 case RISCV::VLUXSEG4EI8_V:
12024 case RISCV::VLUXSEG5EI16_V:
12025 case RISCV::VLUXSEG5EI32_V:
12026 case RISCV::VLUXSEG5EI64_V:
12027 case RISCV::VLUXSEG5EI8_V:
12028 case RISCV::VLUXSEG6EI16_V:
12029 case RISCV::VLUXSEG6EI32_V:
12030 case RISCV::VLUXSEG6EI64_V:
12031 case RISCV::VLUXSEG6EI8_V:
12032 case RISCV::VLUXSEG7EI16_V:
12033 case RISCV::VLUXSEG7EI32_V:
12034 case RISCV::VLUXSEG7EI64_V:
12035 case RISCV::VLUXSEG7EI8_V:
12036 case RISCV::VLUXSEG8EI16_V:
12037 case RISCV::VLUXSEG8EI32_V:
12038 case RISCV::VLUXSEG8EI64_V:
12039 case RISCV::VLUXSEG8EI8_V: {
12040 switch (OpNum) {
12041 case 1:
12042 // op: rs1
12043 return 15;
12044 case 0:
12045 // op: vd
12046 return 7;
12047 case 3:
12048 // op: vm
12049 return 25;
12050 case 2:
12051 // op: vs2
12052 return 20;
12053 }
12054 break;
12055 }
12056 case RISCV::NDS_VLE4_V:
12057 case RISCV::SF_VTMV_V_T:
12058 case RISCV::VL1RE16_V:
12059 case RISCV::VL1RE32_V:
12060 case RISCV::VL1RE64_V:
12061 case RISCV::VL1RE8_V:
12062 case RISCV::VL2RE16_V:
12063 case RISCV::VL2RE32_V:
12064 case RISCV::VL2RE64_V:
12065 case RISCV::VL2RE8_V:
12066 case RISCV::VL4RE16_V:
12067 case RISCV::VL4RE32_V:
12068 case RISCV::VL4RE64_V:
12069 case RISCV::VL4RE8_V:
12070 case RISCV::VL8RE16_V:
12071 case RISCV::VL8RE32_V:
12072 case RISCV::VL8RE64_V:
12073 case RISCV::VL8RE8_V:
12074 case RISCV::VLM_V: {
12075 switch (OpNum) {
12076 case 1:
12077 // op: rs1
12078 return 15;
12079 case 0:
12080 // op: vd
12081 return 7;
12082 }
12083 break;
12084 }
12085 case RISCV::VSE16_V:
12086 case RISCV::VSE32_V:
12087 case RISCV::VSE64_V:
12088 case RISCV::VSE8_V:
12089 case RISCV::VSSEG2E16_V:
12090 case RISCV::VSSEG2E32_V:
12091 case RISCV::VSSEG2E64_V:
12092 case RISCV::VSSEG2E8_V:
12093 case RISCV::VSSEG3E16_V:
12094 case RISCV::VSSEG3E32_V:
12095 case RISCV::VSSEG3E64_V:
12096 case RISCV::VSSEG3E8_V:
12097 case RISCV::VSSEG4E16_V:
12098 case RISCV::VSSEG4E32_V:
12099 case RISCV::VSSEG4E64_V:
12100 case RISCV::VSSEG4E8_V:
12101 case RISCV::VSSEG5E16_V:
12102 case RISCV::VSSEG5E32_V:
12103 case RISCV::VSSEG5E64_V:
12104 case RISCV::VSSEG5E8_V:
12105 case RISCV::VSSEG6E16_V:
12106 case RISCV::VSSEG6E32_V:
12107 case RISCV::VSSEG6E64_V:
12108 case RISCV::VSSEG6E8_V:
12109 case RISCV::VSSEG7E16_V:
12110 case RISCV::VSSEG7E32_V:
12111 case RISCV::VSSEG7E64_V:
12112 case RISCV::VSSEG7E8_V:
12113 case RISCV::VSSEG8E16_V:
12114 case RISCV::VSSEG8E32_V:
12115 case RISCV::VSSEG8E64_V:
12116 case RISCV::VSSEG8E8_V: {
12117 switch (OpNum) {
12118 case 1:
12119 // op: rs1
12120 return 15;
12121 case 0:
12122 // op: vs3
12123 return 7;
12124 case 2:
12125 // op: vm
12126 return 25;
12127 }
12128 break;
12129 }
12130 case RISCV::VSSE16_V:
12131 case RISCV::VSSE32_V:
12132 case RISCV::VSSE64_V:
12133 case RISCV::VSSE8_V:
12134 case RISCV::VSSSEG2E16_V:
12135 case RISCV::VSSSEG2E32_V:
12136 case RISCV::VSSSEG2E64_V:
12137 case RISCV::VSSSEG2E8_V:
12138 case RISCV::VSSSEG3E16_V:
12139 case RISCV::VSSSEG3E32_V:
12140 case RISCV::VSSSEG3E64_V:
12141 case RISCV::VSSSEG3E8_V:
12142 case RISCV::VSSSEG4E16_V:
12143 case RISCV::VSSSEG4E32_V:
12144 case RISCV::VSSSEG4E64_V:
12145 case RISCV::VSSSEG4E8_V:
12146 case RISCV::VSSSEG5E16_V:
12147 case RISCV::VSSSEG5E32_V:
12148 case RISCV::VSSSEG5E64_V:
12149 case RISCV::VSSSEG5E8_V:
12150 case RISCV::VSSSEG6E16_V:
12151 case RISCV::VSSSEG6E32_V:
12152 case RISCV::VSSSEG6E64_V:
12153 case RISCV::VSSSEG6E8_V:
12154 case RISCV::VSSSEG7E16_V:
12155 case RISCV::VSSSEG7E32_V:
12156 case RISCV::VSSSEG7E64_V:
12157 case RISCV::VSSSEG7E8_V:
12158 case RISCV::VSSSEG8E16_V:
12159 case RISCV::VSSSEG8E32_V:
12160 case RISCV::VSSSEG8E64_V:
12161 case RISCV::VSSSEG8E8_V: {
12162 switch (OpNum) {
12163 case 1:
12164 // op: rs1
12165 return 15;
12166 case 0:
12167 // op: vs3
12168 return 7;
12169 case 3:
12170 // op: vm
12171 return 25;
12172 case 2:
12173 // op: rs2
12174 return 20;
12175 }
12176 break;
12177 }
12178 case RISCV::VSOXEI16_V:
12179 case RISCV::VSOXEI32_V:
12180 case RISCV::VSOXEI64_V:
12181 case RISCV::VSOXEI8_V:
12182 case RISCV::VSOXSEG2EI16_V:
12183 case RISCV::VSOXSEG2EI32_V:
12184 case RISCV::VSOXSEG2EI64_V:
12185 case RISCV::VSOXSEG2EI8_V:
12186 case RISCV::VSOXSEG3EI16_V:
12187 case RISCV::VSOXSEG3EI32_V:
12188 case RISCV::VSOXSEG3EI64_V:
12189 case RISCV::VSOXSEG3EI8_V:
12190 case RISCV::VSOXSEG4EI16_V:
12191 case RISCV::VSOXSEG4EI32_V:
12192 case RISCV::VSOXSEG4EI64_V:
12193 case RISCV::VSOXSEG4EI8_V:
12194 case RISCV::VSOXSEG5EI16_V:
12195 case RISCV::VSOXSEG5EI32_V:
12196 case RISCV::VSOXSEG5EI64_V:
12197 case RISCV::VSOXSEG5EI8_V:
12198 case RISCV::VSOXSEG6EI16_V:
12199 case RISCV::VSOXSEG6EI32_V:
12200 case RISCV::VSOXSEG6EI64_V:
12201 case RISCV::VSOXSEG6EI8_V:
12202 case RISCV::VSOXSEG7EI16_V:
12203 case RISCV::VSOXSEG7EI32_V:
12204 case RISCV::VSOXSEG7EI64_V:
12205 case RISCV::VSOXSEG7EI8_V:
12206 case RISCV::VSOXSEG8EI16_V:
12207 case RISCV::VSOXSEG8EI32_V:
12208 case RISCV::VSOXSEG8EI64_V:
12209 case RISCV::VSOXSEG8EI8_V:
12210 case RISCV::VSUXEI16_V:
12211 case RISCV::VSUXEI32_V:
12212 case RISCV::VSUXEI64_V:
12213 case RISCV::VSUXEI8_V:
12214 case RISCV::VSUXSEG2EI16_V:
12215 case RISCV::VSUXSEG2EI32_V:
12216 case RISCV::VSUXSEG2EI64_V:
12217 case RISCV::VSUXSEG2EI8_V:
12218 case RISCV::VSUXSEG3EI16_V:
12219 case RISCV::VSUXSEG3EI32_V:
12220 case RISCV::VSUXSEG3EI64_V:
12221 case RISCV::VSUXSEG3EI8_V:
12222 case RISCV::VSUXSEG4EI16_V:
12223 case RISCV::VSUXSEG4EI32_V:
12224 case RISCV::VSUXSEG4EI64_V:
12225 case RISCV::VSUXSEG4EI8_V:
12226 case RISCV::VSUXSEG5EI16_V:
12227 case RISCV::VSUXSEG5EI32_V:
12228 case RISCV::VSUXSEG5EI64_V:
12229 case RISCV::VSUXSEG5EI8_V:
12230 case RISCV::VSUXSEG6EI16_V:
12231 case RISCV::VSUXSEG6EI32_V:
12232 case RISCV::VSUXSEG6EI64_V:
12233 case RISCV::VSUXSEG6EI8_V:
12234 case RISCV::VSUXSEG7EI16_V:
12235 case RISCV::VSUXSEG7EI32_V:
12236 case RISCV::VSUXSEG7EI64_V:
12237 case RISCV::VSUXSEG7EI8_V:
12238 case RISCV::VSUXSEG8EI16_V:
12239 case RISCV::VSUXSEG8EI32_V:
12240 case RISCV::VSUXSEG8EI64_V:
12241 case RISCV::VSUXSEG8EI8_V: {
12242 switch (OpNum) {
12243 case 1:
12244 // op: rs1
12245 return 15;
12246 case 0:
12247 // op: vs3
12248 return 7;
12249 case 3:
12250 // op: vm
12251 return 25;
12252 case 2:
12253 // op: vs2
12254 return 20;
12255 }
12256 break;
12257 }
12258 case RISCV::VS1R_V:
12259 case RISCV::VS2R_V:
12260 case RISCV::VS4R_V:
12261 case RISCV::VS8R_V:
12262 case RISCV::VSM_V: {
12263 switch (OpNum) {
12264 case 1:
12265 // op: rs1
12266 return 15;
12267 case 0:
12268 // op: vs3
12269 return 7;
12270 }
12271 break;
12272 }
12273 case RISCV::FCVT_BF16_S:
12274 case RISCV::FCVT_D_H:
12275 case RISCV::FCVT_D_H_IN32X:
12276 case RISCV::FCVT_D_H_INX:
12277 case RISCV::FCVT_D_L:
12278 case RISCV::FCVT_D_LU:
12279 case RISCV::FCVT_D_LU_INX:
12280 case RISCV::FCVT_D_L_INX:
12281 case RISCV::FCVT_D_Q:
12282 case RISCV::FCVT_D_S:
12283 case RISCV::FCVT_D_S_IN32X:
12284 case RISCV::FCVT_D_S_INX:
12285 case RISCV::FCVT_D_W:
12286 case RISCV::FCVT_D_WU:
12287 case RISCV::FCVT_D_WU_IN32X:
12288 case RISCV::FCVT_D_WU_INX:
12289 case RISCV::FCVT_D_W_IN32X:
12290 case RISCV::FCVT_D_W_INX:
12291 case RISCV::FCVT_H_D:
12292 case RISCV::FCVT_H_D_IN32X:
12293 case RISCV::FCVT_H_D_INX:
12294 case RISCV::FCVT_H_L:
12295 case RISCV::FCVT_H_LU:
12296 case RISCV::FCVT_H_LU_INX:
12297 case RISCV::FCVT_H_L_INX:
12298 case RISCV::FCVT_H_S:
12299 case RISCV::FCVT_H_S_INX:
12300 case RISCV::FCVT_H_W:
12301 case RISCV::FCVT_H_WU:
12302 case RISCV::FCVT_H_WU_INX:
12303 case RISCV::FCVT_H_W_INX:
12304 case RISCV::FCVT_LU_D:
12305 case RISCV::FCVT_LU_D_INX:
12306 case RISCV::FCVT_LU_H:
12307 case RISCV::FCVT_LU_H_INX:
12308 case RISCV::FCVT_LU_Q:
12309 case RISCV::FCVT_LU_S:
12310 case RISCV::FCVT_LU_S_INX:
12311 case RISCV::FCVT_L_D:
12312 case RISCV::FCVT_L_D_INX:
12313 case RISCV::FCVT_L_H:
12314 case RISCV::FCVT_L_H_INX:
12315 case RISCV::FCVT_L_Q:
12316 case RISCV::FCVT_L_S:
12317 case RISCV::FCVT_L_S_INX:
12318 case RISCV::FCVT_Q_D:
12319 case RISCV::FCVT_Q_L:
12320 case RISCV::FCVT_Q_LU:
12321 case RISCV::FCVT_Q_S:
12322 case RISCV::FCVT_Q_W:
12323 case RISCV::FCVT_Q_WU:
12324 case RISCV::FCVT_S_BF16:
12325 case RISCV::FCVT_S_D:
12326 case RISCV::FCVT_S_D_IN32X:
12327 case RISCV::FCVT_S_D_INX:
12328 case RISCV::FCVT_S_H:
12329 case RISCV::FCVT_S_H_INX:
12330 case RISCV::FCVT_S_L:
12331 case RISCV::FCVT_S_LU:
12332 case RISCV::FCVT_S_LU_INX:
12333 case RISCV::FCVT_S_L_INX:
12334 case RISCV::FCVT_S_Q:
12335 case RISCV::FCVT_S_W:
12336 case RISCV::FCVT_S_WU:
12337 case RISCV::FCVT_S_WU_INX:
12338 case RISCV::FCVT_S_W_INX:
12339 case RISCV::FCVT_WU_D:
12340 case RISCV::FCVT_WU_D_IN32X:
12341 case RISCV::FCVT_WU_D_INX:
12342 case RISCV::FCVT_WU_H:
12343 case RISCV::FCVT_WU_H_INX:
12344 case RISCV::FCVT_WU_Q:
12345 case RISCV::FCVT_WU_S:
12346 case RISCV::FCVT_WU_S_INX:
12347 case RISCV::FCVT_W_D:
12348 case RISCV::FCVT_W_D_IN32X:
12349 case RISCV::FCVT_W_D_INX:
12350 case RISCV::FCVT_W_H:
12351 case RISCV::FCVT_W_H_INX:
12352 case RISCV::FCVT_W_Q:
12353 case RISCV::FCVT_W_S:
12354 case RISCV::FCVT_W_S_INX:
12355 case RISCV::FROUNDNX_D:
12356 case RISCV::FROUNDNX_H:
12357 case RISCV::FROUNDNX_Q:
12358 case RISCV::FROUNDNX_S:
12359 case RISCV::FROUND_D:
12360 case RISCV::FROUND_H:
12361 case RISCV::FROUND_Q:
12362 case RISCV::FROUND_S:
12363 case RISCV::FSQRT_D:
12364 case RISCV::FSQRT_D_IN32X:
12365 case RISCV::FSQRT_D_INX:
12366 case RISCV::FSQRT_H:
12367 case RISCV::FSQRT_H_INX:
12368 case RISCV::FSQRT_Q:
12369 case RISCV::FSQRT_S:
12370 case RISCV::FSQRT_S_INX: {
12371 switch (OpNum) {
12372 case 1:
12373 // op: rs1
12374 return 15;
12375 case 2:
12376 // op: frm
12377 return 12;
12378 case 0:
12379 // op: rd
12380 return 7;
12381 }
12382 break;
12383 }
12384 case RISCV::AIF_FROUND_PS: {
12385 switch (OpNum) {
12386 case 1:
12387 // op: rs1
12388 return 15;
12389 case 2:
12390 // op: rm
12391 return 12;
12392 case 0:
12393 // op: rd
12394 return 7;
12395 }
12396 break;
12397 }
12398 case RISCV::AIF_FSC32B_PS:
12399 case RISCV::AIF_FSC32H_PS:
12400 case RISCV::AIF_FSC32W_PS:
12401 case RISCV::AIF_FSCBG_PS:
12402 case RISCV::AIF_FSCBL_PS:
12403 case RISCV::AIF_FSCB_PS:
12404 case RISCV::AIF_FSCHG_PS:
12405 case RISCV::AIF_FSCHL_PS:
12406 case RISCV::AIF_FSCH_PS:
12407 case RISCV::AIF_FSCWG_PS:
12408 case RISCV::AIF_FSCWL_PS:
12409 case RISCV::AIF_FSCW_PS: {
12410 switch (OpNum) {
12411 case 1:
12412 // op: rs1
12413 return 15;
12414 case 2:
12415 // op: rs2
12416 return 20;
12417 case 0:
12418 // op: rs3
12419 return 7;
12420 }
12421 break;
12422 }
12423 case RISCV::NCLIP:
12424 case RISCV::NCLIPR:
12425 case RISCV::NCLIPRU:
12426 case RISCV::NCLIPU:
12427 case RISCV::NSRA:
12428 case RISCV::NSRAR:
12429 case RISCV::NSRL:
12430 case RISCV::PNCLIPRU_BS:
12431 case RISCV::PNCLIPRU_HS:
12432 case RISCV::PNCLIPR_BS:
12433 case RISCV::PNCLIPR_HS:
12434 case RISCV::PNCLIPU_BS:
12435 case RISCV::PNCLIPU_HS:
12436 case RISCV::PNCLIP_BS:
12437 case RISCV::PNCLIP_HS:
12438 case RISCV::PNSRAR_BS:
12439 case RISCV::PNSRAR_HS:
12440 case RISCV::PNSRA_BS:
12441 case RISCV::PNSRA_HS:
12442 case RISCV::PNSRL_BS:
12443 case RISCV::PNSRL_HS:
12444 case RISCV::PREDSUMU_DBS:
12445 case RISCV::PREDSUMU_DHS:
12446 case RISCV::PREDSUM_DBS:
12447 case RISCV::PREDSUM_DHS: {
12448 switch (OpNum) {
12449 case 1:
12450 // op: rs1
12451 return 16;
12452 case 0:
12453 // op: rd
12454 return 7;
12455 case 2:
12456 // op: rs2
12457 return 20;
12458 }
12459 break;
12460 }
12461 case RISCV::NCLIPI:
12462 case RISCV::NCLIPIU:
12463 case RISCV::NCLIPRI:
12464 case RISCV::NCLIPRIU:
12465 case RISCV::NSRAI:
12466 case RISCV::NSRARI:
12467 case RISCV::NSRLI:
12468 case RISCV::PNCLIPIU_B:
12469 case RISCV::PNCLIPIU_H:
12470 case RISCV::PNCLIPI_B:
12471 case RISCV::PNCLIPI_H:
12472 case RISCV::PNCLIPRIU_B:
12473 case RISCV::PNCLIPRIU_H:
12474 case RISCV::PNCLIPRI_B:
12475 case RISCV::PNCLIPRI_H:
12476 case RISCV::PNSRAI_B:
12477 case RISCV::PNSRAI_H:
12478 case RISCV::PNSRARI_B:
12479 case RISCV::PNSRARI_H:
12480 case RISCV::PNSRLI_B:
12481 case RISCV::PNSRLI_H: {
12482 switch (OpNum) {
12483 case 1:
12484 // op: rs1
12485 return 16;
12486 case 0:
12487 // op: rd
12488 return 7;
12489 case 2:
12490 // op: shamt
12491 return 20;
12492 }
12493 break;
12494 }
12495 case RISCV::PADD_DBS:
12496 case RISCV::PADD_DHS:
12497 case RISCV::PADD_DWS:
12498 case RISCV::PSLL_DBS:
12499 case RISCV::PSLL_DHS:
12500 case RISCV::PSLL_DWS:
12501 case RISCV::PSRA_DBS:
12502 case RISCV::PSRA_DHS:
12503 case RISCV::PSRA_DWS:
12504 case RISCV::PSRL_DBS:
12505 case RISCV::PSRL_DHS:
12506 case RISCV::PSRL_DWS:
12507 case RISCV::PSSHAR_DHS:
12508 case RISCV::PSSHAR_DWS:
12509 case RISCV::PSSHA_DHS:
12510 case RISCV::PSSHA_DWS:
12511 case RISCV::PSSHLR_DHS:
12512 case RISCV::PSSHLR_DWS:
12513 case RISCV::PSSHL_DHS:
12514 case RISCV::PSSHL_DWS: {
12515 switch (OpNum) {
12516 case 1:
12517 // op: rs1
12518 return 16;
12519 case 0:
12520 // op: rd
12521 return 8;
12522 case 2:
12523 // op: rs2
12524 return 20;
12525 }
12526 break;
12527 }
12528 case RISCV::ADDD:
12529 case RISCV::PAADDU_DB:
12530 case RISCV::PAADDU_DH:
12531 case RISCV::PAADDU_DW:
12532 case RISCV::PAADD_DB:
12533 case RISCV::PAADD_DH:
12534 case RISCV::PAADD_DW:
12535 case RISCV::PAAS_DHX:
12536 case RISCV::PABDU_DB:
12537 case RISCV::PABDU_DH:
12538 case RISCV::PABD_DB:
12539 case RISCV::PABD_DH:
12540 case RISCV::PADD_DB:
12541 case RISCV::PADD_DH:
12542 case RISCV::PADD_DW:
12543 case RISCV::PASA_DHX:
12544 case RISCV::PASUBU_DB:
12545 case RISCV::PASUBU_DH:
12546 case RISCV::PASUBU_DW:
12547 case RISCV::PASUB_DB:
12548 case RISCV::PASUB_DH:
12549 case RISCV::PASUB_DW:
12550 case RISCV::PAS_DHX:
12551 case RISCV::PMAXU_DB:
12552 case RISCV::PMAXU_DH:
12553 case RISCV::PMAXU_DW:
12554 case RISCV::PMAX_DB:
12555 case RISCV::PMAX_DH:
12556 case RISCV::PMAX_DW:
12557 case RISCV::PMINU_DB:
12558 case RISCV::PMINU_DH:
12559 case RISCV::PMINU_DW:
12560 case RISCV::PMIN_DB:
12561 case RISCV::PMIN_DH:
12562 case RISCV::PMIN_DW:
12563 case RISCV::PMSEQ_DB:
12564 case RISCV::PMSEQ_DH:
12565 case RISCV::PMSEQ_DW:
12566 case RISCV::PMSLTU_DB:
12567 case RISCV::PMSLTU_DH:
12568 case RISCV::PMSLTU_DW:
12569 case RISCV::PMSLT_DB:
12570 case RISCV::PMSLT_DH:
12571 case RISCV::PMSLT_DW:
12572 case RISCV::PPAIREO_DB:
12573 case RISCV::PPAIREO_DH:
12574 case RISCV::PPAIRE_DB:
12575 case RISCV::PPAIRE_DH:
12576 case RISCV::PPAIROE_DB:
12577 case RISCV::PPAIROE_DH:
12578 case RISCV::PPAIRO_DB:
12579 case RISCV::PPAIRO_DH:
12580 case RISCV::PSADDU_DB:
12581 case RISCV::PSADDU_DH:
12582 case RISCV::PSADDU_DW:
12583 case RISCV::PSADD_DB:
12584 case RISCV::PSADD_DH:
12585 case RISCV::PSADD_DW:
12586 case RISCV::PSAS_DHX:
12587 case RISCV::PSA_DHX:
12588 case RISCV::PSH1ADD_DH:
12589 case RISCV::PSH1ADD_DW:
12590 case RISCV::PSSA_DHX:
12591 case RISCV::PSSH1SADD_DH:
12592 case RISCV::PSSH1SADD_DW:
12593 case RISCV::PSSUBU_DB:
12594 case RISCV::PSSUBU_DH:
12595 case RISCV::PSSUBU_DW:
12596 case RISCV::PSSUB_DB:
12597 case RISCV::PSSUB_DH:
12598 case RISCV::PSSUB_DW:
12599 case RISCV::PSUB_DB:
12600 case RISCV::PSUB_DH:
12601 case RISCV::PSUB_DW:
12602 case RISCV::SUBD: {
12603 switch (OpNum) {
12604 case 1:
12605 // op: rs1
12606 return 16;
12607 case 0:
12608 // op: rd
12609 return 8;
12610 case 2:
12611 // op: rs2
12612 return 21;
12613 }
12614 break;
12615 }
12616 case RISCV::PSATI_DH:
12617 case RISCV::PSATI_DW:
12618 case RISCV::PSLLI_DB:
12619 case RISCV::PSLLI_DH:
12620 case RISCV::PSLLI_DW:
12621 case RISCV::PSRAI_DB:
12622 case RISCV::PSRAI_DH:
12623 case RISCV::PSRAI_DW:
12624 case RISCV::PSRARI_DH:
12625 case RISCV::PSRARI_DW:
12626 case RISCV::PSRLI_DB:
12627 case RISCV::PSRLI_DH:
12628 case RISCV::PSRLI_DW:
12629 case RISCV::PSSLAI_DH:
12630 case RISCV::PSSLAI_DW:
12631 case RISCV::PUSATI_DH:
12632 case RISCV::PUSATI_DW: {
12633 switch (OpNum) {
12634 case 1:
12635 // op: rs1
12636 return 16;
12637 case 0:
12638 // op: rd
12639 return 8;
12640 case 2:
12641 // op: shamt
12642 return 20;
12643 }
12644 break;
12645 }
12646 case RISCV::PSABS_DB:
12647 case RISCV::PSABS_DH:
12648 case RISCV::PSEXT_DH_B:
12649 case RISCV::PSEXT_DW_B:
12650 case RISCV::PSEXT_DW_H: {
12651 switch (OpNum) {
12652 case 1:
12653 // op: rs1
12654 return 16;
12655 case 0:
12656 // op: rd
12657 return 8;
12658 }
12659 break;
12660 }
12661 case RISCV::C_ADD: {
12662 switch (OpNum) {
12663 case 1:
12664 // op: rs1
12665 return 7;
12666 case 2:
12667 // op: rs2
12668 return 2;
12669 }
12670 break;
12671 }
12672 case RISCV::QC_C_BEXTI:
12673 case RISCV::QC_C_BSETI: {
12674 switch (OpNum) {
12675 case 1:
12676 // op: rs1
12677 return 7;
12678 case 2:
12679 // op: shamt
12680 return 2;
12681 }
12682 break;
12683 }
12684 case RISCV::NDS_FCVT_BF16_S:
12685 case RISCV::NDS_FCVT_S_BF16: {
12686 switch (OpNum) {
12687 case 1:
12688 // op: rs2
12689 return 20;
12690 case 0:
12691 // op: rd
12692 return 7;
12693 }
12694 break;
12695 }
12696 case RISCV::HFENCE_GVMA:
12697 case RISCV::HFENCE_VVMA:
12698 case RISCV::HINVAL_GVMA:
12699 case RISCV::HINVAL_VVMA:
12700 case RISCV::SFENCE_VMA:
12701 case RISCV::SF_VTMV_T_V:
12702 case RISCV::SINVAL_VMA:
12703 case RISCV::TH_SFENCE_VMAS: {
12704 switch (OpNum) {
12705 case 1:
12706 // op: rs2
12707 return 20;
12708 case 0:
12709 // op: rs1
12710 return 15;
12711 }
12712 break;
12713 }
12714 case RISCV::TH_LDD:
12715 case RISCV::TH_LWD:
12716 case RISCV::TH_LWUD:
12717 case RISCV::TH_SDD:
12718 case RISCV::TH_SWD: {
12719 switch (OpNum) {
12720 case 1:
12721 // op: rs2
12722 return 20;
12723 case 2:
12724 // op: rs1
12725 return 15;
12726 case 0:
12727 // op: rd
12728 return 7;
12729 case 3:
12730 // op: uimm2
12731 return 25;
12732 }
12733 break;
12734 }
12735 case RISCV::AIF_AMOADDG_D:
12736 case RISCV::AIF_AMOADDG_W:
12737 case RISCV::AIF_AMOADDL_D:
12738 case RISCV::AIF_AMOADDL_W:
12739 case RISCV::AIF_AMOANDG_D:
12740 case RISCV::AIF_AMOANDG_W:
12741 case RISCV::AIF_AMOANDL_D:
12742 case RISCV::AIF_AMOANDL_W:
12743 case RISCV::AIF_AMOCMPSWAPG_D:
12744 case RISCV::AIF_AMOCMPSWAPG_W:
12745 case RISCV::AIF_AMOCMPSWAPL_D:
12746 case RISCV::AIF_AMOCMPSWAPL_W:
12747 case RISCV::AIF_AMOMAXG_D:
12748 case RISCV::AIF_AMOMAXG_W:
12749 case RISCV::AIF_AMOMAXL_D:
12750 case RISCV::AIF_AMOMAXL_W:
12751 case RISCV::AIF_AMOMAXUG_D:
12752 case RISCV::AIF_AMOMAXUG_W:
12753 case RISCV::AIF_AMOMAXUL_D:
12754 case RISCV::AIF_AMOMAXUL_W:
12755 case RISCV::AIF_AMOMING_D:
12756 case RISCV::AIF_AMOMING_W:
12757 case RISCV::AIF_AMOMINL_D:
12758 case RISCV::AIF_AMOMINL_W:
12759 case RISCV::AIF_AMOMINUG_D:
12760 case RISCV::AIF_AMOMINUG_W:
12761 case RISCV::AIF_AMOMINUL_D:
12762 case RISCV::AIF_AMOMINUL_W:
12763 case RISCV::AIF_AMOORG_D:
12764 case RISCV::AIF_AMOORG_W:
12765 case RISCV::AIF_AMOORL_D:
12766 case RISCV::AIF_AMOORL_W:
12767 case RISCV::AIF_AMOSWAPG_D:
12768 case RISCV::AIF_AMOSWAPG_W:
12769 case RISCV::AIF_AMOSWAPL_D:
12770 case RISCV::AIF_AMOSWAPL_W:
12771 case RISCV::AIF_AMOXORG_D:
12772 case RISCV::AIF_AMOXORG_W:
12773 case RISCV::AIF_AMOXORL_D:
12774 case RISCV::AIF_AMOXORL_W:
12775 case RISCV::AMOADD_B:
12776 case RISCV::AMOADD_B_AQ:
12777 case RISCV::AMOADD_B_AQRL:
12778 case RISCV::AMOADD_B_RL:
12779 case RISCV::AMOADD_D:
12780 case RISCV::AMOADD_D_AQ:
12781 case RISCV::AMOADD_D_AQRL:
12782 case RISCV::AMOADD_D_RL:
12783 case RISCV::AMOADD_H:
12784 case RISCV::AMOADD_H_AQ:
12785 case RISCV::AMOADD_H_AQRL:
12786 case RISCV::AMOADD_H_RL:
12787 case RISCV::AMOADD_W:
12788 case RISCV::AMOADD_W_AQ:
12789 case RISCV::AMOADD_W_AQRL:
12790 case RISCV::AMOADD_W_RL:
12791 case RISCV::AMOAND_B:
12792 case RISCV::AMOAND_B_AQ:
12793 case RISCV::AMOAND_B_AQRL:
12794 case RISCV::AMOAND_B_RL:
12795 case RISCV::AMOAND_D:
12796 case RISCV::AMOAND_D_AQ:
12797 case RISCV::AMOAND_D_AQRL:
12798 case RISCV::AMOAND_D_RL:
12799 case RISCV::AMOAND_H:
12800 case RISCV::AMOAND_H_AQ:
12801 case RISCV::AMOAND_H_AQRL:
12802 case RISCV::AMOAND_H_RL:
12803 case RISCV::AMOAND_W:
12804 case RISCV::AMOAND_W_AQ:
12805 case RISCV::AMOAND_W_AQRL:
12806 case RISCV::AMOAND_W_RL:
12807 case RISCV::AMOMAXU_B:
12808 case RISCV::AMOMAXU_B_AQ:
12809 case RISCV::AMOMAXU_B_AQRL:
12810 case RISCV::AMOMAXU_B_RL:
12811 case RISCV::AMOMAXU_D:
12812 case RISCV::AMOMAXU_D_AQ:
12813 case RISCV::AMOMAXU_D_AQRL:
12814 case RISCV::AMOMAXU_D_RL:
12815 case RISCV::AMOMAXU_H:
12816 case RISCV::AMOMAXU_H_AQ:
12817 case RISCV::AMOMAXU_H_AQRL:
12818 case RISCV::AMOMAXU_H_RL:
12819 case RISCV::AMOMAXU_W:
12820 case RISCV::AMOMAXU_W_AQ:
12821 case RISCV::AMOMAXU_W_AQRL:
12822 case RISCV::AMOMAXU_W_RL:
12823 case RISCV::AMOMAX_B:
12824 case RISCV::AMOMAX_B_AQ:
12825 case RISCV::AMOMAX_B_AQRL:
12826 case RISCV::AMOMAX_B_RL:
12827 case RISCV::AMOMAX_D:
12828 case RISCV::AMOMAX_D_AQ:
12829 case RISCV::AMOMAX_D_AQRL:
12830 case RISCV::AMOMAX_D_RL:
12831 case RISCV::AMOMAX_H:
12832 case RISCV::AMOMAX_H_AQ:
12833 case RISCV::AMOMAX_H_AQRL:
12834 case RISCV::AMOMAX_H_RL:
12835 case RISCV::AMOMAX_W:
12836 case RISCV::AMOMAX_W_AQ:
12837 case RISCV::AMOMAX_W_AQRL:
12838 case RISCV::AMOMAX_W_RL:
12839 case RISCV::AMOMINU_B:
12840 case RISCV::AMOMINU_B_AQ:
12841 case RISCV::AMOMINU_B_AQRL:
12842 case RISCV::AMOMINU_B_RL:
12843 case RISCV::AMOMINU_D:
12844 case RISCV::AMOMINU_D_AQ:
12845 case RISCV::AMOMINU_D_AQRL:
12846 case RISCV::AMOMINU_D_RL:
12847 case RISCV::AMOMINU_H:
12848 case RISCV::AMOMINU_H_AQ:
12849 case RISCV::AMOMINU_H_AQRL:
12850 case RISCV::AMOMINU_H_RL:
12851 case RISCV::AMOMINU_W:
12852 case RISCV::AMOMINU_W_AQ:
12853 case RISCV::AMOMINU_W_AQRL:
12854 case RISCV::AMOMINU_W_RL:
12855 case RISCV::AMOMIN_B:
12856 case RISCV::AMOMIN_B_AQ:
12857 case RISCV::AMOMIN_B_AQRL:
12858 case RISCV::AMOMIN_B_RL:
12859 case RISCV::AMOMIN_D:
12860 case RISCV::AMOMIN_D_AQ:
12861 case RISCV::AMOMIN_D_AQRL:
12862 case RISCV::AMOMIN_D_RL:
12863 case RISCV::AMOMIN_H:
12864 case RISCV::AMOMIN_H_AQ:
12865 case RISCV::AMOMIN_H_AQRL:
12866 case RISCV::AMOMIN_H_RL:
12867 case RISCV::AMOMIN_W:
12868 case RISCV::AMOMIN_W_AQ:
12869 case RISCV::AMOMIN_W_AQRL:
12870 case RISCV::AMOMIN_W_RL:
12871 case RISCV::AMOOR_B:
12872 case RISCV::AMOOR_B_AQ:
12873 case RISCV::AMOOR_B_AQRL:
12874 case RISCV::AMOOR_B_RL:
12875 case RISCV::AMOOR_D:
12876 case RISCV::AMOOR_D_AQ:
12877 case RISCV::AMOOR_D_AQRL:
12878 case RISCV::AMOOR_D_RL:
12879 case RISCV::AMOOR_H:
12880 case RISCV::AMOOR_H_AQ:
12881 case RISCV::AMOOR_H_AQRL:
12882 case RISCV::AMOOR_H_RL:
12883 case RISCV::AMOOR_W:
12884 case RISCV::AMOOR_W_AQ:
12885 case RISCV::AMOOR_W_AQRL:
12886 case RISCV::AMOOR_W_RL:
12887 case RISCV::AMOSWAP_B:
12888 case RISCV::AMOSWAP_B_AQ:
12889 case RISCV::AMOSWAP_B_AQRL:
12890 case RISCV::AMOSWAP_B_RL:
12891 case RISCV::AMOSWAP_D:
12892 case RISCV::AMOSWAP_D_AQ:
12893 case RISCV::AMOSWAP_D_AQRL:
12894 case RISCV::AMOSWAP_D_RL:
12895 case RISCV::AMOSWAP_H:
12896 case RISCV::AMOSWAP_H_AQ:
12897 case RISCV::AMOSWAP_H_AQRL:
12898 case RISCV::AMOSWAP_H_RL:
12899 case RISCV::AMOSWAP_W:
12900 case RISCV::AMOSWAP_W_AQ:
12901 case RISCV::AMOSWAP_W_AQRL:
12902 case RISCV::AMOSWAP_W_RL:
12903 case RISCV::AMOXOR_B:
12904 case RISCV::AMOXOR_B_AQ:
12905 case RISCV::AMOXOR_B_AQRL:
12906 case RISCV::AMOXOR_B_RL:
12907 case RISCV::AMOXOR_D:
12908 case RISCV::AMOXOR_D_AQ:
12909 case RISCV::AMOXOR_D_AQRL:
12910 case RISCV::AMOXOR_D_RL:
12911 case RISCV::AMOXOR_H:
12912 case RISCV::AMOXOR_H_AQ:
12913 case RISCV::AMOXOR_H_AQRL:
12914 case RISCV::AMOXOR_H_RL:
12915 case RISCV::AMOXOR_W:
12916 case RISCV::AMOXOR_W_AQ:
12917 case RISCV::AMOXOR_W_AQRL:
12918 case RISCV::AMOXOR_W_RL:
12919 case RISCV::NDS_LEA_B_ZE:
12920 case RISCV::NDS_LEA_D:
12921 case RISCV::NDS_LEA_D_ZE:
12922 case RISCV::NDS_LEA_H:
12923 case RISCV::NDS_LEA_H_ZE:
12924 case RISCV::NDS_LEA_W:
12925 case RISCV::NDS_LEA_W_ZE:
12926 case RISCV::SC_D:
12927 case RISCV::SC_D_AQ:
12928 case RISCV::SC_D_AQRL:
12929 case RISCV::SC_D_RL:
12930 case RISCV::SC_W:
12931 case RISCV::SC_W_AQ:
12932 case RISCV::SC_W_AQRL:
12933 case RISCV::SC_W_RL:
12934 case RISCV::SSAMOSWAP_D:
12935 case RISCV::SSAMOSWAP_D_AQ:
12936 case RISCV::SSAMOSWAP_D_AQRL:
12937 case RISCV::SSAMOSWAP_D_RL:
12938 case RISCV::SSAMOSWAP_W:
12939 case RISCV::SSAMOSWAP_W_AQ:
12940 case RISCV::SSAMOSWAP_W_AQRL:
12941 case RISCV::SSAMOSWAP_W_RL: {
12942 switch (OpNum) {
12943 case 1:
12944 // op: rs2
12945 return 20;
12946 case 2:
12947 // op: rs1
12948 return 15;
12949 case 0:
12950 // op: rd
12951 return 7;
12952 }
12953 break;
12954 }
12955 case RISCV::CM_MVA01S:
12956 case RISCV::CM_MVSA01:
12957 case RISCV::QC_CM_MVA01S:
12958 case RISCV::QC_CM_MVSA01: {
12959 switch (OpNum) {
12960 case 1:
12961 // op: rs2
12962 return 2;
12963 case 0:
12964 // op: rs1
12965 return 7;
12966 }
12967 break;
12968 }
12969 case RISCV::VFMV_S_F:
12970 case RISCV::VMV_S_X: {
12971 switch (OpNum) {
12972 case 1:
12973 // op: vd
12974 return 7;
12975 case 2:
12976 // op: rs1
12977 return 15;
12978 }
12979 break;
12980 }
12981 case RISCV::SMT_VMADOT:
12982 case RISCV::SMT_VMADOTSU:
12983 case RISCV::SMT_VMADOTU:
12984 case RISCV::SMT_VMADOTUS: {
12985 switch (OpNum) {
12986 case 1:
12987 // op: vd
12988 return 7;
12989 case 2:
12990 // op: vs1
12991 return 15;
12992 case 3:
12993 // op: vs2
12994 return 20;
12995 }
12996 break;
12997 }
12998 case RISCV::SMT_VMADOT1:
12999 case RISCV::SMT_VMADOT1SU:
13000 case RISCV::SMT_VMADOT1U:
13001 case RISCV::SMT_VMADOT1US:
13002 case RISCV::SMT_VMADOT2:
13003 case RISCV::SMT_VMADOT2SU:
13004 case RISCV::SMT_VMADOT2U:
13005 case RISCV::SMT_VMADOT2US:
13006 case RISCV::SMT_VMADOT3:
13007 case RISCV::SMT_VMADOT3SU:
13008 case RISCV::SMT_VMADOT3U:
13009 case RISCV::SMT_VMADOT3US: {
13010 switch (OpNum) {
13011 case 1:
13012 // op: vd
13013 return 7;
13014 case 2:
13015 // op: vs1
13016 return 16;
13017 case 3:
13018 // op: vs2
13019 return 20;
13020 }
13021 break;
13022 }
13023 case RISCV::VAESKF2_VI:
13024 case RISCV::VSM3C_VI: {
13025 switch (OpNum) {
13026 case 1:
13027 // op: vd
13028 return 7;
13029 case 2:
13030 // op: vs2
13031 return 20;
13032 case 3:
13033 // op: imm
13034 return 15;
13035 }
13036 break;
13037 }
13038 case RISCV::VGHSH_VS:
13039 case RISCV::VGHSH_VV:
13040 case RISCV::VSHA2CH_VV:
13041 case RISCV::VSHA2CL_VV:
13042 case RISCV::VSHA2MS_VV: {
13043 switch (OpNum) {
13044 case 1:
13045 // op: vd
13046 return 7;
13047 case 2:
13048 // op: vs2
13049 return 20;
13050 case 3:
13051 // op: vs1
13052 return 15;
13053 }
13054 break;
13055 }
13056 case RISCV::VAESDF_VS:
13057 case RISCV::VAESDF_VV:
13058 case RISCV::VAESDM_VS:
13059 case RISCV::VAESDM_VV:
13060 case RISCV::VAESEF_VS:
13061 case RISCV::VAESEF_VV:
13062 case RISCV::VAESEM_VS:
13063 case RISCV::VAESEM_VV:
13064 case RISCV::VAESZ_VS:
13065 case RISCV::VGMUL_VS:
13066 case RISCV::VGMUL_VV:
13067 case RISCV::VSM4R_VS:
13068 case RISCV::VSM4R_VV: {
13069 switch (OpNum) {
13070 case 1:
13071 // op: vd
13072 return 7;
13073 case 2:
13074 // op: vs2
13075 return 20;
13076 }
13077 break;
13078 }
13079 case RISCV::SF_VFWMACC_4x4x4:
13080 case RISCV::SF_VQMACCSU_2x8x2:
13081 case RISCV::SF_VQMACCSU_4x8x4:
13082 case RISCV::SF_VQMACCUS_2x8x2:
13083 case RISCV::SF_VQMACCUS_4x8x4:
13084 case RISCV::SF_VQMACCU_2x8x2:
13085 case RISCV::SF_VQMACCU_4x8x4:
13086 case RISCV::SF_VQMACC_2x8x2:
13087 case RISCV::SF_VQMACC_4x8x4:
13088 case RISCV::V8WMMACC_VV:
13089 case RISCV::VF8WIMMACC_VV:
13090 case RISCV::VF8WMMACC_VV:
13091 case RISCV::VF8WMMACC_VV_SCALE:
13092 case RISCV::VFMMACC_VV:
13093 case RISCV::VFQIMMACC_VV:
13094 case RISCV::VFQMMACC_VV:
13095 case RISCV::VFQMMACC_VV_SCALE:
13096 case RISCV::VFWIMMACC_VV:
13097 case RISCV::VFWMMACC_VV:
13098 case RISCV::VFWMMACC_VV_SCALE:
13099 case RISCV::VMMACC_VV:
13100 case RISCV::VQMMACC_VV:
13101 case RISCV::VWMMACC_VV: {
13102 switch (OpNum) {
13103 case 1:
13104 // op: vd
13105 return 7;
13106 case 3:
13107 // op: vs2
13108 return 20;
13109 case 2:
13110 // op: vs1
13111 return 15;
13112 }
13113 break;
13114 }
13115 case RISCV::VDOT4ASU_VX:
13116 case RISCV::VDOT4AUS_VX:
13117 case RISCV::VDOT4AU_VX:
13118 case RISCV::VDOT4A_VX: {
13119 switch (OpNum) {
13120 case 1:
13121 // op: vd
13122 return 7;
13123 case 4:
13124 // op: vm
13125 return 25;
13126 case 2:
13127 // op: vs2
13128 return 20;
13129 case 3:
13130 // op: rs1
13131 return 15;
13132 }
13133 break;
13134 }
13135 case RISCV::VDOT4ASU_VV:
13136 case RISCV::VDOT4AU_VV:
13137 case RISCV::VDOT4A_VV:
13138 case RISCV::VFQWDOTA_ALT_VV:
13139 case RISCV::VFQWDOTA_VV:
13140 case RISCV::VFWDOTA_VV:
13141 case RISCV::VQWDOTAS_VV:
13142 case RISCV::VQWDOTAU_VV: {
13143 switch (OpNum) {
13144 case 1:
13145 // op: vd
13146 return 7;
13147 case 4:
13148 // op: vm
13149 return 25;
13150 case 2:
13151 // op: vs2
13152 return 20;
13153 case 3:
13154 // op: vs1
13155 return 15;
13156 }
13157 break;
13158 }
13159 case RISCV::TH_VMAQASU_VX:
13160 case RISCV::TH_VMAQAUS_VX:
13161 case RISCV::TH_VMAQAU_VX:
13162 case RISCV::TH_VMAQA_VX:
13163 case RISCV::VFMACC_VF:
13164 case RISCV::VFMADD_VF:
13165 case RISCV::VFMSAC_VF:
13166 case RISCV::VFMSUB_VF:
13167 case RISCV::VFNMACC_VF:
13168 case RISCV::VFNMADD_VF:
13169 case RISCV::VFNMSAC_VF:
13170 case RISCV::VFNMSUB_VF:
13171 case RISCV::VFWMACCBF16_VF:
13172 case RISCV::VFWMACC_VF:
13173 case RISCV::VFWMSAC_VF:
13174 case RISCV::VFWNMACC_VF:
13175 case RISCV::VFWNMSAC_VF:
13176 case RISCV::VMACC_VX:
13177 case RISCV::VMADD_VX:
13178 case RISCV::VNMSAC_VX:
13179 case RISCV::VNMSUB_VX:
13180 case RISCV::VWMACCSU_VX:
13181 case RISCV::VWMACCUS_VX:
13182 case RISCV::VWMACCU_VX:
13183 case RISCV::VWMACC_VX: {
13184 switch (OpNum) {
13185 case 1:
13186 // op: vd
13187 return 7;
13188 case 4:
13189 // op: vm
13190 return 25;
13191 case 3:
13192 // op: vs2
13193 return 20;
13194 case 2:
13195 // op: rs1
13196 return 15;
13197 }
13198 break;
13199 }
13200 case RISCV::TH_VMAQASU_VV:
13201 case RISCV::TH_VMAQAU_VV:
13202 case RISCV::TH_VMAQA_VV:
13203 case RISCV::VFMACC_VV:
13204 case RISCV::VFMADD_VV:
13205 case RISCV::VFMSAC_VV:
13206 case RISCV::VFMSUB_VV:
13207 case RISCV::VFNMACC_VV:
13208 case RISCV::VFNMADD_VV:
13209 case RISCV::VFNMSAC_VV:
13210 case RISCV::VFNMSUB_VV:
13211 case RISCV::VFWMACCBF16_VV:
13212 case RISCV::VFWMACC_VV:
13213 case RISCV::VFWMSAC_VV:
13214 case RISCV::VFWNMACC_VV:
13215 case RISCV::VFWNMSAC_VV:
13216 case RISCV::VMACC_VV:
13217 case RISCV::VMADD_VV:
13218 case RISCV::VNMSAC_VV:
13219 case RISCV::VNMSUB_VV:
13220 case RISCV::VWMACCSU_VV:
13221 case RISCV::VWMACCU_VV:
13222 case RISCV::VWMACC_VV: {
13223 switch (OpNum) {
13224 case 1:
13225 // op: vd
13226 return 7;
13227 case 4:
13228 // op: vm
13229 return 25;
13230 case 3:
13231 // op: vs2
13232 return 20;
13233 case 2:
13234 // op: vs1
13235 return 15;
13236 }
13237 break;
13238 }
13239 case RISCV::VFBDOTA_VV:
13240 case RISCV::VFQWBDOTA_ALT_VV:
13241 case RISCV::VFQWBDOTA_VV:
13242 case RISCV::VFWBDOTA_VV:
13243 case RISCV::VQWBDOTAS_VV:
13244 case RISCV::VQWBDOTAU_VV: {
13245 switch (OpNum) {
13246 case 1:
13247 // op: vd
13248 return 7;
13249 case 5:
13250 // op: vm
13251 return 25;
13252 case 2:
13253 // op: vs2
13254 return 23;
13255 case 3:
13256 // op: vs1
13257 return 15;
13258 case 4:
13259 // op: ci
13260 return 20;
13261 }
13262 break;
13263 }
13264 case RISCV::NDS_VFWCVT_F_B:
13265 case RISCV::NDS_VFWCVT_F_BU:
13266 case RISCV::NDS_VFWCVT_F_N:
13267 case RISCV::NDS_VFWCVT_F_NU: {
13268 switch (OpNum) {
13269 case 1:
13270 // op: vs
13271 return 20;
13272 case 0:
13273 // op: vd
13274 return 7;
13275 case 2:
13276 // op: vm
13277 return 25;
13278 }
13279 break;
13280 }
13281 case RISCV::NDS_VFNCVT_BF16_S:
13282 case RISCV::NDS_VFWCVT_S_BF16: {
13283 switch (OpNum) {
13284 case 1:
13285 // op: vs2
13286 return 20;
13287 case 0:
13288 // op: vd
13289 return 7;
13290 }
13291 break;
13292 }
13293 case RISCV::NDS_VFPMADB_VF:
13294 case RISCV::NDS_VFPMADT_VF: {
13295 switch (OpNum) {
13296 case 1:
13297 // op: vs2
13298 return 20;
13299 case 2:
13300 // op: rs1
13301 return 15;
13302 case 0:
13303 // op: vd
13304 return 7;
13305 case 3:
13306 // op: vm
13307 return 25;
13308 }
13309 break;
13310 }
13311 case RISCV::SF_VC_I: {
13312 switch (OpNum) {
13313 case 1:
13314 // op: vs2
13315 return 20;
13316 case 2:
13317 // op: vd
13318 return 7;
13319 case 3:
13320 // op: imm
13321 return 15;
13322 case 0:
13323 // op: funct6_lo2
13324 return 26;
13325 }
13326 break;
13327 }
13328 case RISCV::SF_VC_X: {
13329 switch (OpNum) {
13330 case 1:
13331 // op: vs2
13332 return 20;
13333 case 2:
13334 // op: vd
13335 return 7;
13336 case 3:
13337 // op: rs1
13338 return 15;
13339 case 0:
13340 // op: funct6_lo2
13341 return 26;
13342 }
13343 break;
13344 }
13345 case RISCV::SF_MM_E4M3_E4M3:
13346 case RISCV::SF_MM_E4M3_E5M2:
13347 case RISCV::SF_MM_E5M2_E4M3:
13348 case RISCV::SF_MM_E5M2_E5M2:
13349 case RISCV::SF_MM_S_S:
13350 case RISCV::SF_MM_S_U:
13351 case RISCV::SF_MM_U_S:
13352 case RISCV::SF_MM_U_U: {
13353 switch (OpNum) {
13354 case 1:
13355 // op: vs2
13356 return 20;
13357 case 2:
13358 // op: vs1
13359 return 15;
13360 case 0:
13361 // op: rd
13362 return 10;
13363 }
13364 break;
13365 }
13366 case RISCV::SF_MM_F_F: {
13367 switch (OpNum) {
13368 case 1:
13369 // op: vs2
13370 return 20;
13371 case 2:
13372 // op: vs1
13373 return 15;
13374 case 0:
13375 // op: rd
13376 return 9;
13377 }
13378 break;
13379 }
13380 case RISCV::AIF_MOV_M_X: {
13381 switch (OpNum) {
13382 case 2:
13383 // op: imm
13384 return 12;
13385 case 1:
13386 // op: rs1
13387 return 15;
13388 case 0:
13389 // op: rd
13390 return 7;
13391 }
13392 break;
13393 }
13394 case RISCV::AIF_FADDI_PI:
13395 case RISCV::AIF_FANDI_PI:
13396 case RISCV::AIF_FSLLI_PI:
13397 case RISCV::AIF_FSRAI_PI:
13398 case RISCV::AIF_FSRLI_PI: {
13399 switch (OpNum) {
13400 case 2:
13401 // op: imm
13402 return 20;
13403 case 1:
13404 // op: rs1
13405 return 15;
13406 case 0:
13407 // op: rd
13408 return 7;
13409 }
13410 break;
13411 }
13412 case RISCV::C_FLDSP:
13413 case RISCV::C_FLWSP:
13414 case RISCV::C_LDSP:
13415 case RISCV::C_LDSP_RV32:
13416 case RISCV::C_LWSP:
13417 case RISCV::C_LWSP_INX: {
13418 switch (OpNum) {
13419 case 2:
13420 // op: imm
13421 return 2;
13422 case 0:
13423 // op: rd
13424 return 7;
13425 }
13426 break;
13427 }
13428 case RISCV::C_ADDI:
13429 case RISCV::C_ADDIW:
13430 case RISCV::C_SLLI: {
13431 switch (OpNum) {
13432 case 2:
13433 // op: imm
13434 return 2;
13435 case 1:
13436 // op: rd
13437 return 7;
13438 }
13439 break;
13440 }
13441 case RISCV::C_ANDI:
13442 case RISCV::C_SRAI:
13443 case RISCV::C_SRLI: {
13444 switch (OpNum) {
13445 case 2:
13446 // op: imm
13447 return 2;
13448 case 1:
13449 // op: rs1
13450 return 7;
13451 }
13452 break;
13453 }
13454 case RISCV::C_ADDI16SP: {
13455 switch (OpNum) {
13456 case 2:
13457 // op: imm
13458 return 2;
13459 }
13460 break;
13461 }
13462 case RISCV::C_ADDI4SPN: {
13463 switch (OpNum) {
13464 case 2:
13465 // op: imm
13466 return 5;
13467 case 0:
13468 // op: rd
13469 return 2;
13470 }
13471 break;
13472 }
13473 case RISCV::C_FSDSP:
13474 case RISCV::C_FSWSP:
13475 case RISCV::C_SDSP:
13476 case RISCV::C_SDSP_RV32:
13477 case RISCV::C_SWSP:
13478 case RISCV::C_SWSP_INX: {
13479 switch (OpNum) {
13480 case 2:
13481 // op: imm
13482 return 7;
13483 case 0:
13484 // op: rs2
13485 return 2;
13486 }
13487 break;
13488 }
13489 case RISCV::NDS_BBC:
13490 case RISCV::NDS_BBS:
13491 case RISCV::NDS_BEQC:
13492 case RISCV::NDS_BNEC: {
13493 switch (OpNum) {
13494 case 2:
13495 // op: imm10
13496 return 8;
13497 case 0:
13498 // op: rs1
13499 return 15;
13500 case 1:
13501 // op: cimm
13502 return 7;
13503 }
13504 break;
13505 }
13506 case RISCV::CV_BEQIMM:
13507 case RISCV::CV_BNEIMM: {
13508 switch (OpNum) {
13509 case 2:
13510 // op: imm12
13511 return 7;
13512 case 0:
13513 // op: rs1
13514 return 15;
13515 case 1:
13516 // op: imm5
13517 return 20;
13518 }
13519 break;
13520 }
13521 case RISCV::FSD:
13522 case RISCV::FSH:
13523 case RISCV::FSQ:
13524 case RISCV::FSW:
13525 case RISCV::SB:
13526 case RISCV::SD:
13527 case RISCV::SD_RV32:
13528 case RISCV::SH:
13529 case RISCV::SH_INX:
13530 case RISCV::SW:
13531 case RISCV::SW_INX: {
13532 switch (OpNum) {
13533 case 2:
13534 // op: imm12
13535 return 7;
13536 case 0:
13537 // op: rs2
13538 return 20;
13539 case 1:
13540 // op: rs1
13541 return 15;
13542 }
13543 break;
13544 }
13545 case RISCV::BEQI:
13546 case RISCV::BNEI: {
13547 switch (OpNum) {
13548 case 2:
13549 // op: imm12
13550 return 7;
13551 case 1:
13552 // op: cimm
13553 return 20;
13554 case 0:
13555 // op: rs1
13556 return 15;
13557 }
13558 break;
13559 }
13560 case RISCV::BEQ:
13561 case RISCV::BGE:
13562 case RISCV::BGEU:
13563 case RISCV::BLT:
13564 case RISCV::BLTU:
13565 case RISCV::BNE:
13566 case RISCV::QC_BEQI:
13567 case RISCV::QC_BGEI:
13568 case RISCV::QC_BGEUI:
13569 case RISCV::QC_BLTI:
13570 case RISCV::QC_BLTUI:
13571 case RISCV::QC_BNEI: {
13572 switch (OpNum) {
13573 case 2:
13574 // op: imm12
13575 return 7;
13576 case 1:
13577 // op: rs2
13578 return 20;
13579 case 0:
13580 // op: rs1
13581 return 15;
13582 }
13583 break;
13584 }
13585 case RISCV::AIF_FBC_PS:
13586 case RISCV::AIF_FLQ2:
13587 case RISCV::AIF_FLW_PS:
13588 case RISCV::CSRRC:
13589 case RISCV::CSRRCI:
13590 case RISCV::CSRRS:
13591 case RISCV::CSRRSI:
13592 case RISCV::CSRRW:
13593 case RISCV::CSRRWI: {
13594 switch (OpNum) {
13595 case 2:
13596 // op: rs1
13597 return 15;
13598 case 0:
13599 // op: rd
13600 return 7;
13601 case 1:
13602 // op: imm12
13603 return 20;
13604 }
13605 break;
13606 }
13607 case RISCV::CV_LBU_ri_inc:
13608 case RISCV::CV_LB_ri_inc:
13609 case RISCV::CV_LHU_ri_inc:
13610 case RISCV::CV_LH_ri_inc:
13611 case RISCV::CV_LW_ri_inc: {
13612 switch (OpNum) {
13613 case 2:
13614 // op: rs1
13615 return 15;
13616 case 0:
13617 // op: rd
13618 return 7;
13619 case 3:
13620 // op: imm12
13621 return 20;
13622 }
13623 break;
13624 }
13625 case RISCV::TH_LBIA:
13626 case RISCV::TH_LBIB:
13627 case RISCV::TH_LBUIA:
13628 case RISCV::TH_LBUIB:
13629 case RISCV::TH_LDIA:
13630 case RISCV::TH_LDIB:
13631 case RISCV::TH_LHIA:
13632 case RISCV::TH_LHIB:
13633 case RISCV::TH_LHUIA:
13634 case RISCV::TH_LHUIB:
13635 case RISCV::TH_LWIA:
13636 case RISCV::TH_LWIB:
13637 case RISCV::TH_LWUIA:
13638 case RISCV::TH_LWUIB: {
13639 switch (OpNum) {
13640 case 2:
13641 // op: rs1
13642 return 15;
13643 case 0:
13644 // op: rd
13645 return 7;
13646 case 3:
13647 // op: simm5
13648 return 20;
13649 case 4:
13650 // op: uimm2
13651 return 25;
13652 }
13653 break;
13654 }
13655 case RISCV::QC_INSBRI: {
13656 switch (OpNum) {
13657 case 2:
13658 // op: rs1
13659 return 15;
13660 case 1:
13661 // op: rd
13662 return 7;
13663 case 3:
13664 // op: imm11
13665 return 20;
13666 }
13667 break;
13668 }
13669 case RISCV::QC_MULIADD: {
13670 switch (OpNum) {
13671 case 2:
13672 // op: rs1
13673 return 15;
13674 case 1:
13675 // op: rd
13676 return 7;
13677 case 3:
13678 // op: imm12
13679 return 20;
13680 }
13681 break;
13682 }
13683 case RISCV::CV_INSERT_B:
13684 case RISCV::CV_INSERT_H:
13685 case RISCV::CV_SDOTSP_SCI_B:
13686 case RISCV::CV_SDOTSP_SCI_H:
13687 case RISCV::CV_SDOTUP_SCI_B:
13688 case RISCV::CV_SDOTUP_SCI_H:
13689 case RISCV::CV_SDOTUSP_SCI_B:
13690 case RISCV::CV_SDOTUSP_SCI_H: {
13691 switch (OpNum) {
13692 case 2:
13693 // op: rs1
13694 return 15;
13695 case 1:
13696 // op: rd
13697 return 7;
13698 case 3:
13699 // op: imm6
13700 return 20;
13701 }
13702 break;
13703 }
13704 case RISCV::CV_INSERT: {
13705 switch (OpNum) {
13706 case 2:
13707 // op: rs1
13708 return 15;
13709 case 1:
13710 // op: rd
13711 return 7;
13712 case 3:
13713 // op: is3
13714 return 25;
13715 case 4:
13716 // op: is2
13717 return 20;
13718 }
13719 break;
13720 }
13721 case RISCV::QC_SELECTIIEQ:
13722 case RISCV::QC_SELECTIINE: {
13723 switch (OpNum) {
13724 case 2:
13725 // op: rs1
13726 return 15;
13727 case 1:
13728 // op: rd
13729 return 7;
13730 case 3:
13731 // op: simm1
13732 return 20;
13733 case 4:
13734 // op: simm2
13735 return 27;
13736 }
13737 break;
13738 }
13739 case RISCV::TH_SBIA:
13740 case RISCV::TH_SBIB:
13741 case RISCV::TH_SDIA:
13742 case RISCV::TH_SDIB:
13743 case RISCV::TH_SHIA:
13744 case RISCV::TH_SHIB:
13745 case RISCV::TH_SWIA:
13746 case RISCV::TH_SWIB: {
13747 switch (OpNum) {
13748 case 2:
13749 // op: rs1
13750 return 15;
13751 case 1:
13752 // op: rd
13753 return 7;
13754 case 3:
13755 // op: simm5
13756 return 20;
13757 case 4:
13758 // op: uimm2
13759 return 25;
13760 }
13761 break;
13762 }
13763 case RISCV::QC_INSB:
13764 case RISCV::QC_INSBH: {
13765 switch (OpNum) {
13766 case 2:
13767 // op: rs1
13768 return 15;
13769 case 1:
13770 // op: rd
13771 return 7;
13772 case 4:
13773 // op: shamt
13774 return 20;
13775 case 3:
13776 // op: width
13777 return 25;
13778 }
13779 break;
13780 }
13781 case RISCV::AES32DSI:
13782 case RISCV::AES32DSMI:
13783 case RISCV::AES32ESI:
13784 case RISCV::AES32ESMI:
13785 case RISCV::SM4ED:
13786 case RISCV::SM4KS: {
13787 switch (OpNum) {
13788 case 2:
13789 // op: rs2
13790 return 20;
13791 case 1:
13792 // op: rs1
13793 return 15;
13794 case 0:
13795 // op: rd
13796 return 7;
13797 case 3:
13798 // op: bs
13799 return 30;
13800 }
13801 break;
13802 }
13803 case RISCV::QC_LWM:
13804 case RISCV::QC_LWMI:
13805 case RISCV::QC_SETWM:
13806 case RISCV::QC_SETWMI:
13807 case RISCV::QC_SWM:
13808 case RISCV::QC_SWMI: {
13809 switch (OpNum) {
13810 case 2:
13811 // op: rs2
13812 return 20;
13813 case 1:
13814 // op: rs1
13815 return 15;
13816 case 0:
13817 // op: rd
13818 return 7;
13819 case 3:
13820 // op: imm
13821 return 25;
13822 }
13823 break;
13824 }
13825 case RISCV::CV_ADDN:
13826 case RISCV::CV_ADDRN:
13827 case RISCV::CV_ADDUN:
13828 case RISCV::CV_ADDURN:
13829 case RISCV::CV_MULHHSN:
13830 case RISCV::CV_MULHHSRN:
13831 case RISCV::CV_MULHHUN:
13832 case RISCV::CV_MULHHURN:
13833 case RISCV::CV_MULSN:
13834 case RISCV::CV_MULSRN:
13835 case RISCV::CV_MULUN:
13836 case RISCV::CV_MULURN:
13837 case RISCV::CV_SUBN:
13838 case RISCV::CV_SUBRN:
13839 case RISCV::CV_SUBUN:
13840 case RISCV::CV_SUBURN: {
13841 switch (OpNum) {
13842 case 2:
13843 // op: rs2
13844 return 20;
13845 case 1:
13846 // op: rs1
13847 return 15;
13848 case 0:
13849 // op: rd
13850 return 7;
13851 case 3:
13852 // op: imm5
13853 return 25;
13854 }
13855 break;
13856 }
13857 case RISCV::QC_LRB:
13858 case RISCV::QC_LRBU:
13859 case RISCV::QC_LRH:
13860 case RISCV::QC_LRHU:
13861 case RISCV::QC_LRW:
13862 case RISCV::QC_SHLADD:
13863 case RISCV::QC_SRB:
13864 case RISCV::QC_SRH:
13865 case RISCV::QC_SRW: {
13866 switch (OpNum) {
13867 case 2:
13868 // op: rs2
13869 return 20;
13870 case 1:
13871 // op: rs1
13872 return 15;
13873 case 0:
13874 // op: rd
13875 return 7;
13876 case 3:
13877 // op: shamt
13878 return 25;
13879 }
13880 break;
13881 }
13882 case RISCV::TH_ADDSL:
13883 case RISCV::TH_FLRD:
13884 case RISCV::TH_FLRW:
13885 case RISCV::TH_FLURD:
13886 case RISCV::TH_FLURW:
13887 case RISCV::TH_FSRD:
13888 case RISCV::TH_FSRW:
13889 case RISCV::TH_FSURD:
13890 case RISCV::TH_FSURW:
13891 case RISCV::TH_LRB:
13892 case RISCV::TH_LRBU:
13893 case RISCV::TH_LRD:
13894 case RISCV::TH_LRH:
13895 case RISCV::TH_LRHU:
13896 case RISCV::TH_LRW:
13897 case RISCV::TH_LRWU:
13898 case RISCV::TH_LURB:
13899 case RISCV::TH_LURBU:
13900 case RISCV::TH_LURD:
13901 case RISCV::TH_LURH:
13902 case RISCV::TH_LURHU:
13903 case RISCV::TH_LURW:
13904 case RISCV::TH_LURWU:
13905 case RISCV::TH_SRB:
13906 case RISCV::TH_SRD:
13907 case RISCV::TH_SRH:
13908 case RISCV::TH_SRW:
13909 case RISCV::TH_SURB:
13910 case RISCV::TH_SURD:
13911 case RISCV::TH_SURH:
13912 case RISCV::TH_SURW: {
13913 switch (OpNum) {
13914 case 2:
13915 // op: rs2
13916 return 20;
13917 case 1:
13918 // op: rs1
13919 return 15;
13920 case 0:
13921 // op: rd
13922 return 7;
13923 case 3:
13924 // op: uimm2
13925 return 25;
13926 }
13927 break;
13928 }
13929 case RISCV::AADD:
13930 case RISCV::AADDU:
13931 case RISCV::ADD:
13932 case RISCV::ADDW:
13933 case RISCV::ADD_UW:
13934 case RISCV::AES64DS:
13935 case RISCV::AES64DSM:
13936 case RISCV::AES64ES:
13937 case RISCV::AES64ESM:
13938 case RISCV::AES64KS2:
13939 case RISCV::AIF_BITMIXB:
13940 case RISCV::AIF_CUBEFACEIDX_PS:
13941 case RISCV::AIF_CUBEFACE_PS:
13942 case RISCV::AIF_CUBESGNSC_PS:
13943 case RISCV::AIF_CUBESGNTC_PS:
13944 case RISCV::AIF_FADD_PI:
13945 case RISCV::AIF_FAMOADDG_PI:
13946 case RISCV::AIF_FAMOADDL_PI:
13947 case RISCV::AIF_FAMOANDG_PI:
13948 case RISCV::AIF_FAMOANDL_PI:
13949 case RISCV::AIF_FAMOMAXG_PI:
13950 case RISCV::AIF_FAMOMAXG_PS:
13951 case RISCV::AIF_FAMOMAXL_PI:
13952 case RISCV::AIF_FAMOMAXL_PS:
13953 case RISCV::AIF_FAMOMAXUG_PI:
13954 case RISCV::AIF_FAMOMAXUL_PI:
13955 case RISCV::AIF_FAMOMING_PI:
13956 case RISCV::AIF_FAMOMING_PS:
13957 case RISCV::AIF_FAMOMINL_PI:
13958 case RISCV::AIF_FAMOMINL_PS:
13959 case RISCV::AIF_FAMOMINUG_PI:
13960 case RISCV::AIF_FAMOMINUL_PI:
13961 case RISCV::AIF_FAMOORG_PI:
13962 case RISCV::AIF_FAMOORL_PI:
13963 case RISCV::AIF_FAMOSWAPG_PI:
13964 case RISCV::AIF_FAMOSWAPL_PI:
13965 case RISCV::AIF_FAMOXORG_PI:
13966 case RISCV::AIF_FAMOXORL_PI:
13967 case RISCV::AIF_FAND_PI:
13968 case RISCV::AIF_FCMOVM_PS:
13969 case RISCV::AIF_FDIVU_PI:
13970 case RISCV::AIF_FDIV_PI:
13971 case RISCV::AIF_FEQM_PS:
13972 case RISCV::AIF_FEQ_PI:
13973 case RISCV::AIF_FEQ_PS:
13974 case RISCV::AIF_FG32B_PS:
13975 case RISCV::AIF_FG32H_PS:
13976 case RISCV::AIF_FG32W_PS:
13977 case RISCV::AIF_FGBG_PS:
13978 case RISCV::AIF_FGBL_PS:
13979 case RISCV::AIF_FGB_PS:
13980 case RISCV::AIF_FGHG_PS:
13981 case RISCV::AIF_FGHL_PS:
13982 case RISCV::AIF_FGH_PS:
13983 case RISCV::AIF_FGWG_PS:
13984 case RISCV::AIF_FGWL_PS:
13985 case RISCV::AIF_FGW_PS:
13986 case RISCV::AIF_FLEM_PS:
13987 case RISCV::AIF_FLE_PI:
13988 case RISCV::AIF_FLE_PS:
13989 case RISCV::AIF_FLTM_PI:
13990 case RISCV::AIF_FLTM_PS:
13991 case RISCV::AIF_FLTU_PI:
13992 case RISCV::AIF_FLT_PI:
13993 case RISCV::AIF_FLT_PS:
13994 case RISCV::AIF_FMAXU_PI:
13995 case RISCV::AIF_FMAX_PI:
13996 case RISCV::AIF_FMAX_PS:
13997 case RISCV::AIF_FMINU_PI:
13998 case RISCV::AIF_FMIN_PI:
13999 case RISCV::AIF_FMIN_PS:
14000 case RISCV::AIF_FMULHU_PI:
14001 case RISCV::AIF_FMULH_PI:
14002 case RISCV::AIF_FMUL_PI:
14003 case RISCV::AIF_FOR_PI:
14004 case RISCV::AIF_FRCP_FIX_RAST:
14005 case RISCV::AIF_FREMU_PI:
14006 case RISCV::AIF_FREM_PI:
14007 case RISCV::AIF_FSGNJN_PS:
14008 case RISCV::AIF_FSGNJX_PS:
14009 case RISCV::AIF_FSGNJ_PS:
14010 case RISCV::AIF_FSLL_PI:
14011 case RISCV::AIF_FSRA_PI:
14012 case RISCV::AIF_FSRL_PI:
14013 case RISCV::AIF_FSUB_PI:
14014 case RISCV::AIF_FXOR_PI:
14015 case RISCV::AIF_MASKAND:
14016 case RISCV::AIF_MASKOR:
14017 case RISCV::AIF_MASKXOR:
14018 case RISCV::AIF_PACKB:
14019 case RISCV::AND:
14020 case RISCV::ANDN:
14021 case RISCV::ASUB:
14022 case RISCV::ASUBU:
14023 case RISCV::BCLR:
14024 case RISCV::BEXT:
14025 case RISCV::BINV:
14026 case RISCV::BSET:
14027 case RISCV::CLMUL:
14028 case RISCV::CLMULH:
14029 case RISCV::CLMULR:
14030 case RISCV::CV_ADD_B:
14031 case RISCV::CV_ADD_DIV2:
14032 case RISCV::CV_ADD_DIV4:
14033 case RISCV::CV_ADD_DIV8:
14034 case RISCV::CV_ADD_H:
14035 case RISCV::CV_ADD_SC_B:
14036 case RISCV::CV_ADD_SC_H:
14037 case RISCV::CV_AND_B:
14038 case RISCV::CV_AND_H:
14039 case RISCV::CV_AND_SC_B:
14040 case RISCV::CV_AND_SC_H:
14041 case RISCV::CV_AVGU_B:
14042 case RISCV::CV_AVGU_H:
14043 case RISCV::CV_AVGU_SC_B:
14044 case RISCV::CV_AVGU_SC_H:
14045 case RISCV::CV_AVG_B:
14046 case RISCV::CV_AVG_H:
14047 case RISCV::CV_AVG_SC_B:
14048 case RISCV::CV_AVG_SC_H:
14049 case RISCV::CV_BCLRR:
14050 case RISCV::CV_BSETR:
14051 case RISCV::CV_CLIPR:
14052 case RISCV::CV_CLIPUR:
14053 case RISCV::CV_CMPEQ_B:
14054 case RISCV::CV_CMPEQ_H:
14055 case RISCV::CV_CMPEQ_SC_B:
14056 case RISCV::CV_CMPEQ_SC_H:
14057 case RISCV::CV_CMPGEU_B:
14058 case RISCV::CV_CMPGEU_H:
14059 case RISCV::CV_CMPGEU_SC_B:
14060 case RISCV::CV_CMPGEU_SC_H:
14061 case RISCV::CV_CMPGE_B:
14062 case RISCV::CV_CMPGE_H:
14063 case RISCV::CV_CMPGE_SC_B:
14064 case RISCV::CV_CMPGE_SC_H:
14065 case RISCV::CV_CMPGTU_B:
14066 case RISCV::CV_CMPGTU_H:
14067 case RISCV::CV_CMPGTU_SC_B:
14068 case RISCV::CV_CMPGTU_SC_H:
14069 case RISCV::CV_CMPGT_B:
14070 case RISCV::CV_CMPGT_H:
14071 case RISCV::CV_CMPGT_SC_B:
14072 case RISCV::CV_CMPGT_SC_H:
14073 case RISCV::CV_CMPLEU_B:
14074 case RISCV::CV_CMPLEU_H:
14075 case RISCV::CV_CMPLEU_SC_B:
14076 case RISCV::CV_CMPLEU_SC_H:
14077 case RISCV::CV_CMPLE_B:
14078 case RISCV::CV_CMPLE_H:
14079 case RISCV::CV_CMPLE_SC_B:
14080 case RISCV::CV_CMPLE_SC_H:
14081 case RISCV::CV_CMPLTU_B:
14082 case RISCV::CV_CMPLTU_H:
14083 case RISCV::CV_CMPLTU_SC_B:
14084 case RISCV::CV_CMPLTU_SC_H:
14085 case RISCV::CV_CMPLT_B:
14086 case RISCV::CV_CMPLT_H:
14087 case RISCV::CV_CMPLT_SC_B:
14088 case RISCV::CV_CMPLT_SC_H:
14089 case RISCV::CV_CMPNE_B:
14090 case RISCV::CV_CMPNE_H:
14091 case RISCV::CV_CMPNE_SC_B:
14092 case RISCV::CV_CMPNE_SC_H:
14093 case RISCV::CV_DOTSP_B:
14094 case RISCV::CV_DOTSP_H:
14095 case RISCV::CV_DOTSP_SC_B:
14096 case RISCV::CV_DOTSP_SC_H:
14097 case RISCV::CV_DOTUP_B:
14098 case RISCV::CV_DOTUP_H:
14099 case RISCV::CV_DOTUP_SC_B:
14100 case RISCV::CV_DOTUP_SC_H:
14101 case RISCV::CV_DOTUSP_B:
14102 case RISCV::CV_DOTUSP_H:
14103 case RISCV::CV_DOTUSP_SC_B:
14104 case RISCV::CV_DOTUSP_SC_H:
14105 case RISCV::CV_EXTRACTR:
14106 case RISCV::CV_EXTRACTUR:
14107 case RISCV::CV_LBU_rr:
14108 case RISCV::CV_LB_rr:
14109 case RISCV::CV_LHU_rr:
14110 case RISCV::CV_LH_rr:
14111 case RISCV::CV_LW_rr:
14112 case RISCV::CV_MAX:
14113 case RISCV::CV_MAXU:
14114 case RISCV::CV_MAXU_B:
14115 case RISCV::CV_MAXU_H:
14116 case RISCV::CV_MAXU_SC_B:
14117 case RISCV::CV_MAXU_SC_H:
14118 case RISCV::CV_MAX_B:
14119 case RISCV::CV_MAX_H:
14120 case RISCV::CV_MAX_SC_B:
14121 case RISCV::CV_MAX_SC_H:
14122 case RISCV::CV_MIN:
14123 case RISCV::CV_MINU:
14124 case RISCV::CV_MINU_B:
14125 case RISCV::CV_MINU_H:
14126 case RISCV::CV_MINU_SC_B:
14127 case RISCV::CV_MINU_SC_H:
14128 case RISCV::CV_MIN_B:
14129 case RISCV::CV_MIN_H:
14130 case RISCV::CV_MIN_SC_B:
14131 case RISCV::CV_MIN_SC_H:
14132 case RISCV::CV_OR_B:
14133 case RISCV::CV_OR_H:
14134 case RISCV::CV_OR_SC_B:
14135 case RISCV::CV_OR_SC_H:
14136 case RISCV::CV_PACK:
14137 case RISCV::CV_PACK_H:
14138 case RISCV::CV_ROR:
14139 case RISCV::CV_SHUFFLE_B:
14140 case RISCV::CV_SHUFFLE_H:
14141 case RISCV::CV_SLE:
14142 case RISCV::CV_SLEU:
14143 case RISCV::CV_SLL_B:
14144 case RISCV::CV_SLL_H:
14145 case RISCV::CV_SLL_SC_B:
14146 case RISCV::CV_SLL_SC_H:
14147 case RISCV::CV_SRA_B:
14148 case RISCV::CV_SRA_H:
14149 case RISCV::CV_SRA_SC_B:
14150 case RISCV::CV_SRA_SC_H:
14151 case RISCV::CV_SRL_B:
14152 case RISCV::CV_SRL_H:
14153 case RISCV::CV_SRL_SC_B:
14154 case RISCV::CV_SRL_SC_H:
14155 case RISCV::CV_SUBROTMJ:
14156 case RISCV::CV_SUBROTMJ_DIV2:
14157 case RISCV::CV_SUBROTMJ_DIV4:
14158 case RISCV::CV_SUBROTMJ_DIV8:
14159 case RISCV::CV_SUB_B:
14160 case RISCV::CV_SUB_DIV2:
14161 case RISCV::CV_SUB_DIV4:
14162 case RISCV::CV_SUB_DIV8:
14163 case RISCV::CV_SUB_H:
14164 case RISCV::CV_SUB_SC_B:
14165 case RISCV::CV_SUB_SC_H:
14166 case RISCV::CV_XOR_B:
14167 case RISCV::CV_XOR_H:
14168 case RISCV::CV_XOR_SC_B:
14169 case RISCV::CV_XOR_SC_H:
14170 case RISCV::CZERO_EQZ:
14171 case RISCV::CZERO_NEZ:
14172 case RISCV::DIV:
14173 case RISCV::DIVU:
14174 case RISCV::DIVUW:
14175 case RISCV::DIVW:
14176 case RISCV::FEQ_D:
14177 case RISCV::FEQ_D_IN32X:
14178 case RISCV::FEQ_D_INX:
14179 case RISCV::FEQ_H:
14180 case RISCV::FEQ_H_INX:
14181 case RISCV::FEQ_Q:
14182 case RISCV::FEQ_S:
14183 case RISCV::FEQ_S_INX:
14184 case RISCV::FLEQ_D:
14185 case RISCV::FLEQ_H:
14186 case RISCV::FLEQ_Q:
14187 case RISCV::FLEQ_S:
14188 case RISCV::FLE_D:
14189 case RISCV::FLE_D_IN32X:
14190 case RISCV::FLE_D_INX:
14191 case RISCV::FLE_H:
14192 case RISCV::FLE_H_INX:
14193 case RISCV::FLE_Q:
14194 case RISCV::FLE_S:
14195 case RISCV::FLE_S_INX:
14196 case RISCV::FLTQ_D:
14197 case RISCV::FLTQ_H:
14198 case RISCV::FLTQ_Q:
14199 case RISCV::FLTQ_S:
14200 case RISCV::FLT_D:
14201 case RISCV::FLT_D_IN32X:
14202 case RISCV::FLT_D_INX:
14203 case RISCV::FLT_H:
14204 case RISCV::FLT_H_INX:
14205 case RISCV::FLT_Q:
14206 case RISCV::FLT_S:
14207 case RISCV::FLT_S_INX:
14208 case RISCV::FMAXM_D:
14209 case RISCV::FMAXM_H:
14210 case RISCV::FMAXM_Q:
14211 case RISCV::FMAXM_S:
14212 case RISCV::FMAX_D:
14213 case RISCV::FMAX_D_IN32X:
14214 case RISCV::FMAX_D_INX:
14215 case RISCV::FMAX_H:
14216 case RISCV::FMAX_H_INX:
14217 case RISCV::FMAX_Q:
14218 case RISCV::FMAX_S:
14219 case RISCV::FMAX_S_INX:
14220 case RISCV::FMINM_D:
14221 case RISCV::FMINM_H:
14222 case RISCV::FMINM_Q:
14223 case RISCV::FMINM_S:
14224 case RISCV::FMIN_D:
14225 case RISCV::FMIN_D_IN32X:
14226 case RISCV::FMIN_D_INX:
14227 case RISCV::FMIN_H:
14228 case RISCV::FMIN_H_INX:
14229 case RISCV::FMIN_Q:
14230 case RISCV::FMIN_S:
14231 case RISCV::FMIN_S_INX:
14232 case RISCV::FMVP_D_X:
14233 case RISCV::FMVP_Q_X:
14234 case RISCV::FSGNJN_D:
14235 case RISCV::FSGNJN_D_IN32X:
14236 case RISCV::FSGNJN_D_INX:
14237 case RISCV::FSGNJN_H:
14238 case RISCV::FSGNJN_H_INX:
14239 case RISCV::FSGNJN_Q:
14240 case RISCV::FSGNJN_S:
14241 case RISCV::FSGNJN_S_INX:
14242 case RISCV::FSGNJX_D:
14243 case RISCV::FSGNJX_D_IN32X:
14244 case RISCV::FSGNJX_D_INX:
14245 case RISCV::FSGNJX_H:
14246 case RISCV::FSGNJX_H_INX:
14247 case RISCV::FSGNJX_Q:
14248 case RISCV::FSGNJX_S:
14249 case RISCV::FSGNJX_S_INX:
14250 case RISCV::FSGNJ_D:
14251 case RISCV::FSGNJ_D_IN32X:
14252 case RISCV::FSGNJ_D_INX:
14253 case RISCV::FSGNJ_H:
14254 case RISCV::FSGNJ_H_INX:
14255 case RISCV::FSGNJ_Q:
14256 case RISCV::FSGNJ_S:
14257 case RISCV::FSGNJ_S_INX:
14258 case RISCV::MAX:
14259 case RISCV::MAXU:
14260 case RISCV::MIN:
14261 case RISCV::MINU:
14262 case RISCV::MOP_RR_0:
14263 case RISCV::MOP_RR_1:
14264 case RISCV::MOP_RR_2:
14265 case RISCV::MOP_RR_3:
14266 case RISCV::MOP_RR_4:
14267 case RISCV::MOP_RR_5:
14268 case RISCV::MOP_RR_6:
14269 case RISCV::MOP_RR_7:
14270 case RISCV::MSEQ:
14271 case RISCV::MSLT:
14272 case RISCV::MSLTU:
14273 case RISCV::MUL:
14274 case RISCV::MULH:
14275 case RISCV::MULHR:
14276 case RISCV::MULHRSU:
14277 case RISCV::MULHRU:
14278 case RISCV::MULHSU:
14279 case RISCV::MULHSU_H0:
14280 case RISCV::MULHSU_H1:
14281 case RISCV::MULHU:
14282 case RISCV::MULH_H0:
14283 case RISCV::MULH_H1:
14284 case RISCV::MULQ:
14285 case RISCV::MULQR:
14286 case RISCV::MULSU_H00:
14287 case RISCV::MULSU_H11:
14288 case RISCV::MULSU_W00:
14289 case RISCV::MULSU_W11:
14290 case RISCV::MULU_H00:
14291 case RISCV::MULU_H01:
14292 case RISCV::MULU_H11:
14293 case RISCV::MULU_W00:
14294 case RISCV::MULU_W01:
14295 case RISCV::MULU_W11:
14296 case RISCV::MULW:
14297 case RISCV::MUL_H00:
14298 case RISCV::MUL_H01:
14299 case RISCV::MUL_H11:
14300 case RISCV::MUL_W00:
14301 case RISCV::MUL_W01:
14302 case RISCV::MUL_W11:
14303 case RISCV::NDS_FFB:
14304 case RISCV::NDS_FFMISM:
14305 case RISCV::NDS_FFZMISM:
14306 case RISCV::NDS_FLMISM:
14307 case RISCV::OR:
14308 case RISCV::ORN:
14309 case RISCV::PAADDU_B:
14310 case RISCV::PAADDU_H:
14311 case RISCV::PAADDU_W:
14312 case RISCV::PAADD_B:
14313 case RISCV::PAADD_H:
14314 case RISCV::PAADD_W:
14315 case RISCV::PAAS_HX:
14316 case RISCV::PAAS_WX:
14317 case RISCV::PABDSUMU_B:
14318 case RISCV::PABDU_B:
14319 case RISCV::PABDU_H:
14320 case RISCV::PABD_B:
14321 case RISCV::PABD_H:
14322 case RISCV::PACK:
14323 case RISCV::PACKH:
14324 case RISCV::PACKW:
14325 case RISCV::PACKY:
14326 case RISCV::PADD_B:
14327 case RISCV::PADD_BS:
14328 case RISCV::PADD_H:
14329 case RISCV::PADD_HS:
14330 case RISCV::PADD_W:
14331 case RISCV::PADD_WS:
14332 case RISCV::PASA_HX:
14333 case RISCV::PASA_WX:
14334 case RISCV::PASUBU_B:
14335 case RISCV::PASUBU_H:
14336 case RISCV::PASUBU_W:
14337 case RISCV::PASUB_B:
14338 case RISCV::PASUB_H:
14339 case RISCV::PASUB_W:
14340 case RISCV::PAS_HX:
14341 case RISCV::PAS_WX:
14342 case RISCV::PM2ADDSU_H:
14343 case RISCV::PM2ADDSU_W:
14344 case RISCV::PM2ADDU_H:
14345 case RISCV::PM2ADDU_W:
14346 case RISCV::PM2ADD_H:
14347 case RISCV::PM2ADD_HX:
14348 case RISCV::PM2ADD_W:
14349 case RISCV::PM2ADD_WX:
14350 case RISCV::PM2SADD_H:
14351 case RISCV::PM2SADD_HX:
14352 case RISCV::PM2SUB_H:
14353 case RISCV::PM2SUB_HX:
14354 case RISCV::PM2SUB_W:
14355 case RISCV::PM2SUB_WX:
14356 case RISCV::PM4ADDSU_B:
14357 case RISCV::PM4ADDSU_H:
14358 case RISCV::PM4ADDU_B:
14359 case RISCV::PM4ADDU_H:
14360 case RISCV::PM4ADD_B:
14361 case RISCV::PM4ADD_H:
14362 case RISCV::PMAXU_B:
14363 case RISCV::PMAXU_H:
14364 case RISCV::PMAXU_W:
14365 case RISCV::PMAX_B:
14366 case RISCV::PMAX_H:
14367 case RISCV::PMAX_W:
14368 case RISCV::PMINU_B:
14369 case RISCV::PMINU_H:
14370 case RISCV::PMINU_W:
14371 case RISCV::PMIN_B:
14372 case RISCV::PMIN_H:
14373 case RISCV::PMIN_W:
14374 case RISCV::PMQ2ADD_H:
14375 case RISCV::PMQ2ADD_W:
14376 case RISCV::PMQR2ADD_H:
14377 case RISCV::PMQR2ADD_W:
14378 case RISCV::PMSEQ_B:
14379 case RISCV::PMSEQ_H:
14380 case RISCV::PMSEQ_W:
14381 case RISCV::PMSLTU_B:
14382 case RISCV::PMSLTU_H:
14383 case RISCV::PMSLTU_W:
14384 case RISCV::PMSLT_B:
14385 case RISCV::PMSLT_H:
14386 case RISCV::PMSLT_W:
14387 case RISCV::PMULHRSU_H:
14388 case RISCV::PMULHRSU_W:
14389 case RISCV::PMULHRU_H:
14390 case RISCV::PMULHRU_W:
14391 case RISCV::PMULHR_H:
14392 case RISCV::PMULHR_W:
14393 case RISCV::PMULHSU_H:
14394 case RISCV::PMULHSU_H_B0:
14395 case RISCV::PMULHSU_H_B1:
14396 case RISCV::PMULHSU_W:
14397 case RISCV::PMULHSU_W_H0:
14398 case RISCV::PMULHSU_W_H1:
14399 case RISCV::PMULHU_H:
14400 case RISCV::PMULHU_W:
14401 case RISCV::PMULH_H:
14402 case RISCV::PMULH_H_B0:
14403 case RISCV::PMULH_H_B1:
14404 case RISCV::PMULH_W:
14405 case RISCV::PMULH_W_H0:
14406 case RISCV::PMULH_W_H1:
14407 case RISCV::PMULQR_H:
14408 case RISCV::PMULQR_W:
14409 case RISCV::PMULQ_H:
14410 case RISCV::PMULQ_W:
14411 case RISCV::PMULSU_H_B00:
14412 case RISCV::PMULSU_H_B11:
14413 case RISCV::PMULSU_W_H00:
14414 case RISCV::PMULSU_W_H11:
14415 case RISCV::PMULU_H_B00:
14416 case RISCV::PMULU_H_B01:
14417 case RISCV::PMULU_H_B11:
14418 case RISCV::PMULU_W_H00:
14419 case RISCV::PMULU_W_H01:
14420 case RISCV::PMULU_W_H11:
14421 case RISCV::PMUL_H_B00:
14422 case RISCV::PMUL_H_B01:
14423 case RISCV::PMUL_H_B11:
14424 case RISCV::PMUL_W_H00:
14425 case RISCV::PMUL_W_H01:
14426 case RISCV::PMUL_W_H11:
14427 case RISCV::PNCLIPP_B:
14428 case RISCV::PNCLIPP_H:
14429 case RISCV::PNCLIPP_W:
14430 case RISCV::PNCLIPUP_B:
14431 case RISCV::PNCLIPUP_H:
14432 case RISCV::PNCLIPUP_W:
14433 case RISCV::PPAIREO_B:
14434 case RISCV::PPAIREO_H:
14435 case RISCV::PPAIREO_W:
14436 case RISCV::PPAIRE_B:
14437 case RISCV::PPAIRE_H:
14438 case RISCV::PPAIROE_B:
14439 case RISCV::PPAIROE_H:
14440 case RISCV::PPAIROE_W:
14441 case RISCV::PPAIRO_B:
14442 case RISCV::PPAIRO_H:
14443 case RISCV::PPAIRO_W:
14444 case RISCV::PREDSUMU_BS:
14445 case RISCV::PREDSUMU_HS:
14446 case RISCV::PREDSUMU_WS:
14447 case RISCV::PREDSUM_BS:
14448 case RISCV::PREDSUM_HS:
14449 case RISCV::PREDSUM_WS:
14450 case RISCV::PSADDU_B:
14451 case RISCV::PSADDU_H:
14452 case RISCV::PSADDU_W:
14453 case RISCV::PSADD_B:
14454 case RISCV::PSADD_H:
14455 case RISCV::PSADD_W:
14456 case RISCV::PSAS_HX:
14457 case RISCV::PSAS_WX:
14458 case RISCV::PSA_HX:
14459 case RISCV::PSA_WX:
14460 case RISCV::PSH1ADD_H:
14461 case RISCV::PSH1ADD_W:
14462 case RISCV::PSLL_BS:
14463 case RISCV::PSLL_HS:
14464 case RISCV::PSLL_WS:
14465 case RISCV::PSRA_BS:
14466 case RISCV::PSRA_HS:
14467 case RISCV::PSRA_WS:
14468 case RISCV::PSRL_BS:
14469 case RISCV::PSRL_HS:
14470 case RISCV::PSRL_WS:
14471 case RISCV::PSSA_HX:
14472 case RISCV::PSSA_WX:
14473 case RISCV::PSSH1SADD_H:
14474 case RISCV::PSSH1SADD_W:
14475 case RISCV::PSSHAR_HS:
14476 case RISCV::PSSHAR_WS:
14477 case RISCV::PSSHA_HS:
14478 case RISCV::PSSHA_WS:
14479 case RISCV::PSSHLR_HS:
14480 case RISCV::PSSHLR_WS:
14481 case RISCV::PSSHL_HS:
14482 case RISCV::PSSHL_WS:
14483 case RISCV::PSSUBU_B:
14484 case RISCV::PSSUBU_H:
14485 case RISCV::PSSUBU_W:
14486 case RISCV::PSSUB_B:
14487 case RISCV::PSSUB_H:
14488 case RISCV::PSSUB_W:
14489 case RISCV::PSUB_B:
14490 case RISCV::PSUB_H:
14491 case RISCV::PSUB_W:
14492 case RISCV::QC_ADDSAT:
14493 case RISCV::QC_ADDUSAT:
14494 case RISCV::QC_CSRRWR:
14495 case RISCV::QC_CSRRWRI:
14496 case RISCV::QC_EXTDPR:
14497 case RISCV::QC_EXTDPRH:
14498 case RISCV::QC_EXTDR:
14499 case RISCV::QC_EXTDUPR:
14500 case RISCV::QC_EXTDUPRH:
14501 case RISCV::QC_EXTDUR:
14502 case RISCV::QC_SHLSAT:
14503 case RISCV::QC_SHLUSAT:
14504 case RISCV::QC_SUBSAT:
14505 case RISCV::QC_SUBUSAT:
14506 case RISCV::QC_WRAP:
14507 case RISCV::REM:
14508 case RISCV::REMU:
14509 case RISCV::REMUW:
14510 case RISCV::REMW:
14511 case RISCV::ROL:
14512 case RISCV::ROLW:
14513 case RISCV::ROR:
14514 case RISCV::RORW:
14515 case RISCV::SADD:
14516 case RISCV::SADDU:
14517 case RISCV::SH1ADD:
14518 case RISCV::SH1ADD_UW:
14519 case RISCV::SH2ADD:
14520 case RISCV::SH2ADD_UW:
14521 case RISCV::SH3ADD:
14522 case RISCV::SH3ADD_UW:
14523 case RISCV::SHA:
14524 case RISCV::SHA512SIG0H:
14525 case RISCV::SHA512SIG0L:
14526 case RISCV::SHA512SIG1H:
14527 case RISCV::SHA512SIG1L:
14528 case RISCV::SHA512SUM0R:
14529 case RISCV::SHA512SUM1R:
14530 case RISCV::SHAR:
14531 case RISCV::SHL:
14532 case RISCV::SHLR:
14533 case RISCV::SLL:
14534 case RISCV::SLLW:
14535 case RISCV::SLT:
14536 case RISCV::SLTU:
14537 case RISCV::SRA:
14538 case RISCV::SRAW:
14539 case RISCV::SRL:
14540 case RISCV::SRLW:
14541 case RISCV::SSH1SADD:
14542 case RISCV::SSHA:
14543 case RISCV::SSHAR:
14544 case RISCV::SSHL:
14545 case RISCV::SSHLR:
14546 case RISCV::SSUB:
14547 case RISCV::SSUBU:
14548 case RISCV::SUB:
14549 case RISCV::SUBW:
14550 case RISCV::UNZIP16HP:
14551 case RISCV::UNZIP16P:
14552 case RISCV::UNZIP8HP:
14553 case RISCV::UNZIP8P:
14554 case RISCV::VSETVL:
14555 case RISCV::VT_MASKC:
14556 case RISCV::VT_MASKCN:
14557 case RISCV::XNOR:
14558 case RISCV::XOR:
14559 case RISCV::XPERM4:
14560 case RISCV::XPERM8:
14561 case RISCV::YADD:
14562 case RISCV::YADDRW:
14563 case RISCV::YBLD:
14564 case RISCV::YBNDSRW:
14565 case RISCV::YBNDSW:
14566 case RISCV::YEQ:
14567 case RISCV::YPERMC:
14568 case RISCV::YSS:
14569 case RISCV::YSUNSEAL:
14570 case RISCV::ZIP16HP:
14571 case RISCV::ZIP16P:
14572 case RISCV::ZIP8HP:
14573 case RISCV::ZIP8P: {
14574 switch (OpNum) {
14575 case 2:
14576 // op: rs2
14577 return 20;
14578 case 1:
14579 // op: rs1
14580 return 15;
14581 case 0:
14582 // op: rd
14583 return 7;
14584 }
14585 break;
14586 }
14587 case RISCV::PM2WADDSU_H:
14588 case RISCV::PM2WADDU_H:
14589 case RISCV::PM2WADD_H:
14590 case RISCV::PM2WADD_HX:
14591 case RISCV::PM2WSUB_H:
14592 case RISCV::PM2WSUB_HX:
14593 case RISCV::PWADDU_B:
14594 case RISCV::PWADDU_H:
14595 case RISCV::PWADD_B:
14596 case RISCV::PWADD_H:
14597 case RISCV::PWMULSU_B:
14598 case RISCV::PWMULSU_H:
14599 case RISCV::PWMULU_B:
14600 case RISCV::PWMULU_H:
14601 case RISCV::PWMUL_B:
14602 case RISCV::PWMUL_H:
14603 case RISCV::PWSLA_BS:
14604 case RISCV::PWSLA_HS:
14605 case RISCV::PWSLL_BS:
14606 case RISCV::PWSLL_HS:
14607 case RISCV::PWSUBU_B:
14608 case RISCV::PWSUBU_H:
14609 case RISCV::PWSUB_B:
14610 case RISCV::PWSUB_H:
14611 case RISCV::WADD:
14612 case RISCV::WADDU:
14613 case RISCV::WMUL:
14614 case RISCV::WMULSU:
14615 case RISCV::WMULU:
14616 case RISCV::WSLA:
14617 case RISCV::WSLL:
14618 case RISCV::WSUB:
14619 case RISCV::WSUBU:
14620 case RISCV::WZIP16P:
14621 case RISCV::WZIP8P: {
14622 switch (OpNum) {
14623 case 2:
14624 // op: rs2
14625 return 20;
14626 case 1:
14627 // op: rs1
14628 return 15;
14629 case 0:
14630 // op: rd
14631 return 8;
14632 }
14633 break;
14634 }
14635 case RISCV::FADD_D:
14636 case RISCV::FADD_D_IN32X:
14637 case RISCV::FADD_D_INX:
14638 case RISCV::FADD_H:
14639 case RISCV::FADD_H_INX:
14640 case RISCV::FADD_Q:
14641 case RISCV::FADD_S:
14642 case RISCV::FADD_S_INX:
14643 case RISCV::FDIV_D:
14644 case RISCV::FDIV_D_IN32X:
14645 case RISCV::FDIV_D_INX:
14646 case RISCV::FDIV_H:
14647 case RISCV::FDIV_H_INX:
14648 case RISCV::FDIV_Q:
14649 case RISCV::FDIV_S:
14650 case RISCV::FDIV_S_INX:
14651 case RISCV::FMUL_D:
14652 case RISCV::FMUL_D_IN32X:
14653 case RISCV::FMUL_D_INX:
14654 case RISCV::FMUL_H:
14655 case RISCV::FMUL_H_INX:
14656 case RISCV::FMUL_Q:
14657 case RISCV::FMUL_S:
14658 case RISCV::FMUL_S_INX:
14659 case RISCV::FSUB_D:
14660 case RISCV::FSUB_D_IN32X:
14661 case RISCV::FSUB_D_INX:
14662 case RISCV::FSUB_H:
14663 case RISCV::FSUB_H_INX:
14664 case RISCV::FSUB_Q:
14665 case RISCV::FSUB_S:
14666 case RISCV::FSUB_S_INX: {
14667 switch (OpNum) {
14668 case 2:
14669 // op: rs2
14670 return 20;
14671 case 1:
14672 // op: rs1
14673 return 15;
14674 case 3:
14675 // op: frm
14676 return 12;
14677 case 0:
14678 // op: rd
14679 return 7;
14680 }
14681 break;
14682 }
14683 case RISCV::AMOCAS_B:
14684 case RISCV::AMOCAS_B_AQ:
14685 case RISCV::AMOCAS_B_AQRL:
14686 case RISCV::AMOCAS_B_RL:
14687 case RISCV::AMOCAS_D_RV32:
14688 case RISCV::AMOCAS_D_RV32_AQ:
14689 case RISCV::AMOCAS_D_RV32_AQRL:
14690 case RISCV::AMOCAS_D_RV32_RL:
14691 case RISCV::AMOCAS_D_RV64:
14692 case RISCV::AMOCAS_D_RV64_AQ:
14693 case RISCV::AMOCAS_D_RV64_AQRL:
14694 case RISCV::AMOCAS_D_RV64_RL:
14695 case RISCV::AMOCAS_H:
14696 case RISCV::AMOCAS_H_AQ:
14697 case RISCV::AMOCAS_H_AQRL:
14698 case RISCV::AMOCAS_H_RL:
14699 case RISCV::AMOCAS_Q:
14700 case RISCV::AMOCAS_Q_AQ:
14701 case RISCV::AMOCAS_Q_AQRL:
14702 case RISCV::AMOCAS_Q_RL:
14703 case RISCV::AMOCAS_W:
14704 case RISCV::AMOCAS_W_AQ:
14705 case RISCV::AMOCAS_W_AQRL:
14706 case RISCV::AMOCAS_W_RL: {
14707 switch (OpNum) {
14708 case 2:
14709 // op: rs2
14710 return 20;
14711 case 3:
14712 // op: rs1
14713 return 15;
14714 case 1:
14715 // op: rd
14716 return 7;
14717 }
14718 break;
14719 }
14720 case RISCV::C_ADDW:
14721 case RISCV::C_AND:
14722 case RISCV::C_MUL:
14723 case RISCV::C_OR:
14724 case RISCV::C_SUB:
14725 case RISCV::C_SUBW:
14726 case RISCV::C_XOR: {
14727 switch (OpNum) {
14728 case 2:
14729 // op: rs2
14730 return 2;
14731 case 1:
14732 // op: rd
14733 return 7;
14734 }
14735 break;
14736 }
14737 case RISCV::SF_VC_V_I:
14738 case RISCV::SF_VC_V_IV: {
14739 switch (OpNum) {
14740 case 2:
14741 // op: vs2
14742 return 20;
14743 case 0:
14744 // op: vd
14745 return 7;
14746 case 3:
14747 // op: imm
14748 return 15;
14749 case 1:
14750 // op: funct6_lo2
14751 return 26;
14752 }
14753 break;
14754 }
14755 case RISCV::SF_VC_V_FV: {
14756 switch (OpNum) {
14757 case 2:
14758 // op: vs2
14759 return 20;
14760 case 0:
14761 // op: vd
14762 return 7;
14763 case 3:
14764 // op: rs1
14765 return 15;
14766 case 1:
14767 // op: funct6_lo1
14768 return 26;
14769 }
14770 break;
14771 }
14772 case RISCV::SF_VC_V_X:
14773 case RISCV::SF_VC_V_XV: {
14774 switch (OpNum) {
14775 case 2:
14776 // op: vs2
14777 return 20;
14778 case 0:
14779 // op: vd
14780 return 7;
14781 case 3:
14782 // op: rs1
14783 return 15;
14784 case 1:
14785 // op: funct6_lo2
14786 return 26;
14787 }
14788 break;
14789 }
14790 case RISCV::SF_VC_V_VV: {
14791 switch (OpNum) {
14792 case 2:
14793 // op: vs2
14794 return 20;
14795 case 0:
14796 // op: vd
14797 return 7;
14798 case 3:
14799 // op: vs1
14800 return 15;
14801 case 1:
14802 // op: funct6_lo2
14803 return 26;
14804 }
14805 break;
14806 }
14807 case RISCV::SF_VC_IV:
14808 case RISCV::SF_VC_IVV:
14809 case RISCV::SF_VC_IVW: {
14810 switch (OpNum) {
14811 case 2:
14812 // op: vs2
14813 return 20;
14814 case 1:
14815 // op: vd
14816 return 7;
14817 case 3:
14818 // op: imm
14819 return 15;
14820 case 0:
14821 // op: funct6_lo2
14822 return 26;
14823 }
14824 break;
14825 }
14826 case RISCV::SF_VC_FV:
14827 case RISCV::SF_VC_FVV:
14828 case RISCV::SF_VC_FVW: {
14829 switch (OpNum) {
14830 case 2:
14831 // op: vs2
14832 return 20;
14833 case 1:
14834 // op: vd
14835 return 7;
14836 case 3:
14837 // op: rs1
14838 return 15;
14839 case 0:
14840 // op: funct6_lo1
14841 return 26;
14842 }
14843 break;
14844 }
14845 case RISCV::SF_VC_XV:
14846 case RISCV::SF_VC_XVV:
14847 case RISCV::SF_VC_XVW: {
14848 switch (OpNum) {
14849 case 2:
14850 // op: vs2
14851 return 20;
14852 case 1:
14853 // op: vd
14854 return 7;
14855 case 3:
14856 // op: rs1
14857 return 15;
14858 case 0:
14859 // op: funct6_lo2
14860 return 26;
14861 }
14862 break;
14863 }
14864 case RISCV::SF_VC_VV:
14865 case RISCV::SF_VC_VVV:
14866 case RISCV::SF_VC_VVW: {
14867 switch (OpNum) {
14868 case 2:
14869 // op: vs2
14870 return 20;
14871 case 1:
14872 // op: vd
14873 return 7;
14874 case 3:
14875 // op: vs1
14876 return 15;
14877 case 0:
14878 // op: funct6_lo2
14879 return 26;
14880 }
14881 break;
14882 }
14883 case RISCV::NDS_VD4DOTSU_VV:
14884 case RISCV::NDS_VD4DOTS_VV:
14885 case RISCV::NDS_VD4DOTU_VV: {
14886 switch (OpNum) {
14887 case 2:
14888 // op: vs2
14889 return 20;
14890 case 1:
14891 // op: vs1
14892 return 15;
14893 case 0:
14894 // op: vd
14895 return 7;
14896 case 3:
14897 // op: vm
14898 return 25;
14899 }
14900 break;
14901 }
14902 case RISCV::AIF_MASKPOPC_ET_RAST: {
14903 switch (OpNum) {
14904 case 3:
14905 // op: imm
14906 return 18;
14907 case 2:
14908 // op: rs2
14909 return 20;
14910 case 1:
14911 // op: rs1
14912 return 15;
14913 case 0:
14914 // op: rd
14915 return 7;
14916 }
14917 break;
14918 }
14919 case RISCV::CV_SB_ri_inc:
14920 case RISCV::CV_SH_ri_inc:
14921 case RISCV::CV_SW_ri_inc: {
14922 switch (OpNum) {
14923 case 3:
14924 // op: imm12
14925 return 7;
14926 case 1:
14927 // op: rs2
14928 return 20;
14929 case 2:
14930 // op: rs1
14931 return 15;
14932 }
14933 break;
14934 }
14935 case RISCV::MIPS_SDP: {
14936 switch (OpNum) {
14937 case 3:
14938 // op: imm7
14939 return 10;
14940 case 1:
14941 // op: rs3
14942 return 27;
14943 case 0:
14944 // op: rs2
14945 return 20;
14946 case 2:
14947 // op: rs1
14948 return 15;
14949 }
14950 break;
14951 }
14952 case RISCV::MIPS_LWP: {
14953 switch (OpNum) {
14954 case 3:
14955 // op: imm7
14956 return 22;
14957 case 2:
14958 // op: rs1
14959 return 15;
14960 case 0:
14961 // op: rd1
14962 return 7;
14963 case 1:
14964 // op: rd2
14965 return 27;
14966 }
14967 break;
14968 }
14969 case RISCV::MIPS_LDP: {
14970 switch (OpNum) {
14971 case 3:
14972 // op: imm7
14973 return 23;
14974 case 2:
14975 // op: rs1
14976 return 15;
14977 case 0:
14978 // op: rd1
14979 return 7;
14980 case 1:
14981 // op: rd2
14982 return 27;
14983 }
14984 break;
14985 }
14986 case RISCV::MIPS_SWP: {
14987 switch (OpNum) {
14988 case 3:
14989 // op: imm7
14990 return 9;
14991 case 1:
14992 // op: rs3
14993 return 27;
14994 case 0:
14995 // op: rs2
14996 return 20;
14997 case 2:
14998 // op: rs1
14999 return 15;
15000 }
15001 break;
15002 }
15003 case RISCV::QC_SELECTIEQI:
15004 case RISCV::QC_SELECTINEI: {
15005 switch (OpNum) {
15006 case 3:
15007 // op: rs2
15008 return 20;
15009 case 1:
15010 // op: rd
15011 return 7;
15012 case 2:
15013 // op: imm
15014 return 15;
15015 case 4:
15016 // op: simm2
15017 return 27;
15018 }
15019 break;
15020 }
15021 case RISCV::CV_LBU_rr_inc:
15022 case RISCV::CV_LB_rr_inc:
15023 case RISCV::CV_LHU_rr_inc:
15024 case RISCV::CV_LH_rr_inc:
15025 case RISCV::CV_LW_rr_inc: {
15026 switch (OpNum) {
15027 case 3:
15028 // op: rs2
15029 return 20;
15030 case 2:
15031 // op: rs1
15032 return 15;
15033 case 0:
15034 // op: rd
15035 return 7;
15036 }
15037 break;
15038 }
15039 case RISCV::CV_MACHHSN:
15040 case RISCV::CV_MACHHSRN:
15041 case RISCV::CV_MACHHUN:
15042 case RISCV::CV_MACHHURN:
15043 case RISCV::CV_MACSN:
15044 case RISCV::CV_MACSRN:
15045 case RISCV::CV_MACUN:
15046 case RISCV::CV_MACURN: {
15047 switch (OpNum) {
15048 case 3:
15049 // op: rs2
15050 return 20;
15051 case 2:
15052 // op: rs1
15053 return 15;
15054 case 1:
15055 // op: rd
15056 return 7;
15057 case 4:
15058 // op: imm5
15059 return 25;
15060 }
15061 break;
15062 }
15063 case RISCV::QC_LIEQ:
15064 case RISCV::QC_LIEQI:
15065 case RISCV::QC_LIGE:
15066 case RISCV::QC_LIGEI:
15067 case RISCV::QC_LIGEU:
15068 case RISCV::QC_LIGEUI:
15069 case RISCV::QC_LILT:
15070 case RISCV::QC_LILTI:
15071 case RISCV::QC_LILTU:
15072 case RISCV::QC_LILTUI:
15073 case RISCV::QC_LINE:
15074 case RISCV::QC_LINEI: {
15075 switch (OpNum) {
15076 case 3:
15077 // op: rs2
15078 return 20;
15079 case 2:
15080 // op: rs1
15081 return 15;
15082 case 1:
15083 // op: rd
15084 return 7;
15085 case 4:
15086 // op: simm
15087 return 27;
15088 }
15089 break;
15090 }
15091 case RISCV::QC_SELECTIEQ:
15092 case RISCV::QC_SELECTINE: {
15093 switch (OpNum) {
15094 case 3:
15095 // op: rs2
15096 return 20;
15097 case 2:
15098 // op: rs1
15099 return 15;
15100 case 1:
15101 // op: rd
15102 return 7;
15103 case 4:
15104 // op: simm2
15105 return 27;
15106 }
15107 break;
15108 }
15109 case RISCV::CV_ADDNR:
15110 case RISCV::CV_ADDRNR:
15111 case RISCV::CV_ADDUNR:
15112 case RISCV::CV_ADDURNR:
15113 case RISCV::CV_CPLXMUL_I:
15114 case RISCV::CV_CPLXMUL_I_DIV2:
15115 case RISCV::CV_CPLXMUL_I_DIV4:
15116 case RISCV::CV_CPLXMUL_I_DIV8:
15117 case RISCV::CV_CPLXMUL_R:
15118 case RISCV::CV_CPLXMUL_R_DIV2:
15119 case RISCV::CV_CPLXMUL_R_DIV4:
15120 case RISCV::CV_CPLXMUL_R_DIV8:
15121 case RISCV::CV_INSERTR:
15122 case RISCV::CV_MAC:
15123 case RISCV::CV_MSU:
15124 case RISCV::CV_PACKHI_B:
15125 case RISCV::CV_PACKLO_B:
15126 case RISCV::CV_SDOTSP_B:
15127 case RISCV::CV_SDOTSP_H:
15128 case RISCV::CV_SDOTSP_SC_B:
15129 case RISCV::CV_SDOTSP_SC_H:
15130 case RISCV::CV_SDOTUP_B:
15131 case RISCV::CV_SDOTUP_H:
15132 case RISCV::CV_SDOTUP_SC_B:
15133 case RISCV::CV_SDOTUP_SC_H:
15134 case RISCV::CV_SDOTUSP_B:
15135 case RISCV::CV_SDOTUSP_H:
15136 case RISCV::CV_SDOTUSP_SC_B:
15137 case RISCV::CV_SDOTUSP_SC_H:
15138 case RISCV::CV_SHUFFLE2_B:
15139 case RISCV::CV_SHUFFLE2_H:
15140 case RISCV::CV_SUBNR:
15141 case RISCV::CV_SUBRNR:
15142 case RISCV::CV_SUBUNR:
15143 case RISCV::CV_SUBURNR:
15144 case RISCV::MACCSU_H00:
15145 case RISCV::MACCSU_H11:
15146 case RISCV::MACCSU_W00:
15147 case RISCV::MACCSU_W11:
15148 case RISCV::MACCU_H00:
15149 case RISCV::MACCU_H01:
15150 case RISCV::MACCU_H11:
15151 case RISCV::MACCU_W00:
15152 case RISCV::MACCU_W01:
15153 case RISCV::MACCU_W11:
15154 case RISCV::MACC_H00:
15155 case RISCV::MACC_H01:
15156 case RISCV::MACC_H11:
15157 case RISCV::MACC_W00:
15158 case RISCV::MACC_W01:
15159 case RISCV::MACC_W11:
15160 case RISCV::MERGE:
15161 case RISCV::MHACC:
15162 case RISCV::MHACCSU:
15163 case RISCV::MHACCSU_H0:
15164 case RISCV::MHACCSU_H1:
15165 case RISCV::MHACCU:
15166 case RISCV::MHACC_H0:
15167 case RISCV::MHACC_H1:
15168 case RISCV::MHRACC:
15169 case RISCV::MHRACCSU:
15170 case RISCV::MHRACCU:
15171 case RISCV::MQACC_H00:
15172 case RISCV::MQACC_H01:
15173 case RISCV::MQACC_H11:
15174 case RISCV::MQACC_W00:
15175 case RISCV::MQACC_W01:
15176 case RISCV::MQACC_W11:
15177 case RISCV::MQRACC_H00:
15178 case RISCV::MQRACC_H01:
15179 case RISCV::MQRACC_H11:
15180 case RISCV::MQRACC_W00:
15181 case RISCV::MQRACC_W01:
15182 case RISCV::MQRACC_W11:
15183 case RISCV::MVM:
15184 case RISCV::MVMN:
15185 case RISCV::PABDSUMAU_B:
15186 case RISCV::PM2ADDASU_H:
15187 case RISCV::PM2ADDASU_W:
15188 case RISCV::PM2ADDAU_H:
15189 case RISCV::PM2ADDAU_W:
15190 case RISCV::PM2ADDA_H:
15191 case RISCV::PM2ADDA_HX:
15192 case RISCV::PM2ADDA_W:
15193 case RISCV::PM2ADDA_WX:
15194 case RISCV::PM2SUBA_H:
15195 case RISCV::PM2SUBA_HX:
15196 case RISCV::PM2SUBA_W:
15197 case RISCV::PM2SUBA_WX:
15198 case RISCV::PM4ADDASU_B:
15199 case RISCV::PM4ADDASU_H:
15200 case RISCV::PM4ADDAU_B:
15201 case RISCV::PM4ADDAU_H:
15202 case RISCV::PM4ADDA_B:
15203 case RISCV::PM4ADDA_H:
15204 case RISCV::PMACCSU_W_H00:
15205 case RISCV::PMACCSU_W_H11:
15206 case RISCV::PMACCU_W_H00:
15207 case RISCV::PMACCU_W_H01:
15208 case RISCV::PMACCU_W_H11:
15209 case RISCV::PMACC_W_H00:
15210 case RISCV::PMACC_W_H01:
15211 case RISCV::PMACC_W_H11:
15212 case RISCV::PMHACCSU_H:
15213 case RISCV::PMHACCSU_H_B0:
15214 case RISCV::PMHACCSU_H_B1:
15215 case RISCV::PMHACCSU_W:
15216 case RISCV::PMHACCSU_W_H0:
15217 case RISCV::PMHACCSU_W_H1:
15218 case RISCV::PMHACCU_H:
15219 case RISCV::PMHACCU_W:
15220 case RISCV::PMHACC_H:
15221 case RISCV::PMHACC_H_B0:
15222 case RISCV::PMHACC_H_B1:
15223 case RISCV::PMHACC_W:
15224 case RISCV::PMHACC_W_H0:
15225 case RISCV::PMHACC_W_H1:
15226 case RISCV::PMHRACCSU_H:
15227 case RISCV::PMHRACCSU_W:
15228 case RISCV::PMHRACCU_H:
15229 case RISCV::PMHRACCU_W:
15230 case RISCV::PMHRACC_H:
15231 case RISCV::PMHRACC_W:
15232 case RISCV::PMQ2ADDA_H:
15233 case RISCV::PMQ2ADDA_W:
15234 case RISCV::PMQACC_W_H00:
15235 case RISCV::PMQACC_W_H01:
15236 case RISCV::PMQACC_W_H11:
15237 case RISCV::PMQR2ADDA_H:
15238 case RISCV::PMQR2ADDA_W:
15239 case RISCV::PMQRACC_W_H00:
15240 case RISCV::PMQRACC_W_H01:
15241 case RISCV::PMQRACC_W_H11:
15242 case RISCV::QC_INSBHR:
15243 case RISCV::QC_INSBPR:
15244 case RISCV::QC_INSBPRH:
15245 case RISCV::QC_INSBR:
15246 case RISCV::SLX:
15247 case RISCV::SRX:
15248 case RISCV::TH_MULA:
15249 case RISCV::TH_MULAH:
15250 case RISCV::TH_MULAW:
15251 case RISCV::TH_MULS:
15252 case RISCV::TH_MULSH:
15253 case RISCV::TH_MULSW:
15254 case RISCV::TH_MVEQZ:
15255 case RISCV::TH_MVNEZ: {
15256 switch (OpNum) {
15257 case 3:
15258 // op: rs2
15259 return 20;
15260 case 2:
15261 // op: rs1
15262 return 15;
15263 case 1:
15264 // op: rd
15265 return 7;
15266 }
15267 break;
15268 }
15269 case RISCV::MQRWACC:
15270 case RISCV::MQWACC:
15271 case RISCV::PM2WADDASU_H:
15272 case RISCV::PM2WADDAU_H:
15273 case RISCV::PM2WADDA_H:
15274 case RISCV::PM2WADDA_HX:
15275 case RISCV::PM2WSUBA_H:
15276 case RISCV::PM2WSUBA_HX:
15277 case RISCV::PMQRWACC_H:
15278 case RISCV::PMQWACC_H:
15279 case RISCV::PWADDAU_B:
15280 case RISCV::PWADDAU_H:
15281 case RISCV::PWADDA_B:
15282 case RISCV::PWADDA_H:
15283 case RISCV::PWMACCSU_H:
15284 case RISCV::PWMACCU_H:
15285 case RISCV::PWMACC_H:
15286 case RISCV::PWSUBAU_B:
15287 case RISCV::PWSUBAU_H:
15288 case RISCV::PWSUBA_B:
15289 case RISCV::PWSUBA_H:
15290 case RISCV::WADDA:
15291 case RISCV::WADDAU:
15292 case RISCV::WMACC:
15293 case RISCV::WMACCSU:
15294 case RISCV::WMACCU:
15295 case RISCV::WSUBA:
15296 case RISCV::WSUBAU: {
15297 switch (OpNum) {
15298 case 3:
15299 // op: rs2
15300 return 20;
15301 case 2:
15302 // op: rs1
15303 return 15;
15304 case 1:
15305 // op: rd
15306 return 8;
15307 }
15308 break;
15309 }
15310 case RISCV::MIPS_CCMOV: {
15311 switch (OpNum) {
15312 case 3:
15313 // op: rs3
15314 return 27;
15315 case 2:
15316 // op: rs2
15317 return 20;
15318 case 1:
15319 // op: rs1
15320 return 15;
15321 case 0:
15322 // op: rd
15323 return 7;
15324 }
15325 break;
15326 }
15327 case RISCV::FMADD_D:
15328 case RISCV::FMADD_D_IN32X:
15329 case RISCV::FMADD_D_INX:
15330 case RISCV::FMADD_H:
15331 case RISCV::FMADD_H_INX:
15332 case RISCV::FMADD_Q:
15333 case RISCV::FMADD_S:
15334 case RISCV::FMADD_S_INX:
15335 case RISCV::FMSUB_D:
15336 case RISCV::FMSUB_D_IN32X:
15337 case RISCV::FMSUB_D_INX:
15338 case RISCV::FMSUB_H:
15339 case RISCV::FMSUB_H_INX:
15340 case RISCV::FMSUB_Q:
15341 case RISCV::FMSUB_S:
15342 case RISCV::FMSUB_S_INX:
15343 case RISCV::FNMADD_D:
15344 case RISCV::FNMADD_D_IN32X:
15345 case RISCV::FNMADD_D_INX:
15346 case RISCV::FNMADD_H:
15347 case RISCV::FNMADD_H_INX:
15348 case RISCV::FNMADD_Q:
15349 case RISCV::FNMADD_S:
15350 case RISCV::FNMADD_S_INX:
15351 case RISCV::FNMSUB_D:
15352 case RISCV::FNMSUB_D_IN32X:
15353 case RISCV::FNMSUB_D_INX:
15354 case RISCV::FNMSUB_H:
15355 case RISCV::FNMSUB_H_INX:
15356 case RISCV::FNMSUB_Q:
15357 case RISCV::FNMSUB_S:
15358 case RISCV::FNMSUB_S_INX: {
15359 switch (OpNum) {
15360 case 3:
15361 // op: rs3
15362 return 27;
15363 case 2:
15364 // op: rs2
15365 return 20;
15366 case 1:
15367 // op: rs1
15368 return 15;
15369 case 4:
15370 // op: frm
15371 return 12;
15372 case 0:
15373 // op: rd
15374 return 7;
15375 }
15376 break;
15377 }
15378 case RISCV::CV_SB_rr_inc:
15379 case RISCV::CV_SH_rr_inc:
15380 case RISCV::CV_SW_rr_inc: {
15381 switch (OpNum) {
15382 case 3:
15383 // op: rs3
15384 return 7;
15385 case 1:
15386 // op: rs2
15387 return 20;
15388 case 2:
15389 // op: rs1
15390 return 15;
15391 }
15392 break;
15393 }
15394 case RISCV::SF_VC_V_IVV:
15395 case RISCV::SF_VC_V_IVW: {
15396 switch (OpNum) {
15397 case 3:
15398 // op: vs2
15399 return 20;
15400 case 2:
15401 // op: vd
15402 return 7;
15403 case 4:
15404 // op: imm
15405 return 15;
15406 case 1:
15407 // op: funct6_lo2
15408 return 26;
15409 }
15410 break;
15411 }
15412 case RISCV::SF_VC_V_FVV:
15413 case RISCV::SF_VC_V_FVW: {
15414 switch (OpNum) {
15415 case 3:
15416 // op: vs2
15417 return 20;
15418 case 2:
15419 // op: vd
15420 return 7;
15421 case 4:
15422 // op: rs1
15423 return 15;
15424 case 1:
15425 // op: funct6_lo1
15426 return 26;
15427 }
15428 break;
15429 }
15430 case RISCV::SF_VC_V_XVV:
15431 case RISCV::SF_VC_V_XVW: {
15432 switch (OpNum) {
15433 case 3:
15434 // op: vs2
15435 return 20;
15436 case 2:
15437 // op: vd
15438 return 7;
15439 case 4:
15440 // op: rs1
15441 return 15;
15442 case 1:
15443 // op: funct6_lo2
15444 return 26;
15445 }
15446 break;
15447 }
15448 case RISCV::SF_VC_V_VVV:
15449 case RISCV::SF_VC_V_VVW: {
15450 switch (OpNum) {
15451 case 3:
15452 // op: vs2
15453 return 20;
15454 case 2:
15455 // op: vd
15456 return 7;
15457 case 4:
15458 // op: vs1
15459 return 15;
15460 case 1:
15461 // op: funct6_lo2
15462 return 26;
15463 }
15464 break;
15465 }
15466 case RISCV::QC_MVEQI:
15467 case RISCV::QC_MVGEI:
15468 case RISCV::QC_MVGEUI:
15469 case RISCV::QC_MVLTI:
15470 case RISCV::QC_MVLTUI:
15471 case RISCV::QC_MVNEI: {
15472 switch (OpNum) {
15473 case 4:
15474 // op: rs3
15475 return 27;
15476 case 2:
15477 // op: rs1
15478 return 15;
15479 case 1:
15480 // op: rd
15481 return 7;
15482 case 3:
15483 // op: imm
15484 return 20;
15485 }
15486 break;
15487 }
15488 case RISCV::QC_SELECTEQI:
15489 case RISCV::QC_SELECTNEI: {
15490 switch (OpNum) {
15491 case 4:
15492 // op: rs3
15493 return 27;
15494 case 3:
15495 // op: rs2
15496 return 20;
15497 case 1:
15498 // op: rd
15499 return 7;
15500 case 2:
15501 // op: imm
15502 return 15;
15503 }
15504 break;
15505 }
15506 case RISCV::QC_MVEQ:
15507 case RISCV::QC_MVGE:
15508 case RISCV::QC_MVGEU:
15509 case RISCV::QC_MVLT:
15510 case RISCV::QC_MVLTU:
15511 case RISCV::QC_MVNE: {
15512 switch (OpNum) {
15513 case 4:
15514 // op: rs3
15515 return 27;
15516 case 3:
15517 // op: rs2
15518 return 20;
15519 case 2:
15520 // op: rs1
15521 return 15;
15522 case 1:
15523 // op: rd
15524 return 7;
15525 }
15526 break;
15527 }
15528 default:
15529 reportUnsupportedInst(MI);
15530 }
15531 reportUnsupportedOperand(MI, OpNum);
15532}
15533
15534#endif // GET_OPERAND_BIT_OFFSET
15535
15536