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(1409335323), // NSARI
1399 UINT64_C(1308672027), // NSRA
1400 UINT64_C(1140899867), // NSRAI
1401 UINT64_C(1577107483), // NSRAR
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(2550161467), // PAAS_HX
1421 UINT64_C(2583715899), // PAAS_WX
1422 UINT64_C(2551242779), // PAAX_DHX
1423 UINT64_C(3154120763), // PABDSUMAU_B
1424 UINT64_C(3019903035), // PABDSUMU_B
1425 UINT64_C(3959423035), // PABDU_B
1426 UINT64_C(3959447579), // PABDU_DB
1427 UINT64_C(3892338715), // PABDU_DH
1428 UINT64_C(3892314171), // PABDU_H
1429 UINT64_C(3422552123), // PABD_B
1430 UINT64_C(3422576667), // PABD_DB
1431 UINT64_C(3355467803), // PABD_DH
1432 UINT64_C(3355443259), // PABD_H
1433 UINT64_C(134234163), // PACK
1434 UINT64_C(134246451), // PACKH
1435 UINT64_C(134234171), // PACKW
1436 UINT64_C(2214592571), // PADD_B
1437 UINT64_C(2617253915), // PADD_BS
1438 UINT64_C(2214617115), // PADD_DB
1439 UINT64_C(469786651), // PADD_DBS
1440 UINT64_C(2147508251), // PADD_DH
1441 UINT64_C(402677787), // PADD_DHS
1442 UINT64_C(2181062683), // PADD_DW
1443 UINT64_C(436232219), // PADD_DWS
1444 UINT64_C(2147483707), // PADD_H
1445 UINT64_C(2550145051), // PADD_HS
1446 UINT64_C(2181038139), // PADD_W
1447 UINT64_C(2583699483), // PADD_WS
1448 UINT64_C(2618351643), // PASA_DHX
1449 UINT64_C(2617270331), // PASA_HX
1450 UINT64_C(2650824763), // PASA_WX
1451 UINT64_C(4227858491), // PASUBU_B
1452 UINT64_C(4227883035), // PASUBU_DB
1453 UINT64_C(4160774171), // PASUBU_DH
1454 UINT64_C(4194328603), // PASUBU_DW
1455 UINT64_C(4160749627), // PASUBU_H
1456 UINT64_C(4194304059), // PASUBU_W
1457 UINT64_C(3690987579), // PASUB_B
1458 UINT64_C(3691012123), // PASUB_DB
1459 UINT64_C(3623903259), // PASUB_DH
1460 UINT64_C(3657457691), // PASUB_DW
1461 UINT64_C(3623878715), // PASUB_H
1462 UINT64_C(3657433147), // PASUB_W
1463 UINT64_C(2148589595), // PAS_DHX
1464 UINT64_C(2147508283), // PAS_HX
1465 UINT64_C(2181062715), // PAS_WX
1466 UINT64_C(3019907099), // PLI_B
1467 UINT64_C(872423451), // PLI_DB
1468 UINT64_C(805314587), // PLI_DH
1469 UINT64_C(2952798235), // PLI_H
1470 UINT64_C(2986352667), // PLI_W
1471 UINT64_C(1879056411), // PLUI_DH
1472 UINT64_C(4026540059), // PLUI_H
1473 UINT64_C(4060094491), // PLUI_W
1474 UINT64_C(3892334651), // PM2ADDASU_H
1475 UINT64_C(3925889083), // PM2ADDASU_W
1476 UINT64_C(2818592827), // PM2ADDAU_H
1477 UINT64_C(2852147259), // PM2ADDAU_W
1478 UINT64_C(2281721915), // PM2ADDA_H
1479 UINT64_C(2550157371), // PM2ADDA_HX
1480 UINT64_C(2315276347), // PM2ADDA_W
1481 UINT64_C(2583711803), // PM2ADDA_WX
1482 UINT64_C(3758116923), // PM2ADDSU_H
1483 UINT64_C(3791671355), // PM2ADDSU_W
1484 UINT64_C(2684375099), // PM2ADDU_H
1485 UINT64_C(2717929531), // PM2ADDU_W
1486 UINT64_C(2147504187), // PM2ADD_H
1487 UINT64_C(2415939643), // PM2ADD_HX
1488 UINT64_C(2181058619), // PM2ADD_W
1489 UINT64_C(2449494075), // PM2ADD_WX
1490 UINT64_C(3288354875), // PM2SADD_H
1491 UINT64_C(3556790331), // PM2SADD_HX
1492 UINT64_C(3355463739), // PM2SUBA_H
1493 UINT64_C(3623899195), // PM2SUBA_HX
1494 UINT64_C(3389018171), // PM2SUBA_W
1495 UINT64_C(3657453627), // PM2SUBA_WX
1496 UINT64_C(3221246011), // PM2SUB_H
1497 UINT64_C(3489681467), // PM2SUB_HX
1498 UINT64_C(3254800443), // PM2SUB_W
1499 UINT64_C(3523235899), // PM2SUB_WX
1500 UINT64_C(1845502107), // PM2WADDASU_H
1501 UINT64_C(771760283), // PM2WADDAU_H
1502 UINT64_C(234889371), // PM2WADDA_H
1503 UINT64_C(503324827), // PM2WADDA_HX
1504 UINT64_C(1711284379), // PM2WADDSU_H
1505 UINT64_C(637542555), // PM2WADDU_H
1506 UINT64_C(100671643), // PM2WADD_H
1507 UINT64_C(369107099), // PM2WADD_HX
1508 UINT64_C(1308631195), // PM2WSUBA_H
1509 UINT64_C(1577066651), // PM2WSUBA_HX
1510 UINT64_C(1174413467), // PM2WSUB_H
1511 UINT64_C(1442848923), // PM2WSUB_HX
1512 UINT64_C(3959443515), // PM4ADDASU_B
1513 UINT64_C(3992997947), // PM4ADDASU_H
1514 UINT64_C(2885701691), // PM4ADDAU_B
1515 UINT64_C(2919256123), // PM4ADDAU_H
1516 UINT64_C(2348830779), // PM4ADDA_B
1517 UINT64_C(2382385211), // PM4ADDA_H
1518 UINT64_C(3825225787), // PM4ADDSU_B
1519 UINT64_C(3858780219), // PM4ADDSU_H
1520 UINT64_C(2751483963), // PM4ADDU_B
1521 UINT64_C(2785038395), // PM4ADDU_H
1522 UINT64_C(2214613051), // PM4ADD_B
1523 UINT64_C(2248167483), // PM4ADD_H
1524 UINT64_C(3925880891), // PMACCSU_W_H00
1525 UINT64_C(4194316347), // PMACCSU_W_H11
1526 UINT64_C(2852139067), // PMACCU_W_H00
1527 UINT64_C(3120566331), // PMACCU_W_H01
1528 UINT64_C(3120574523), // PMACCU_W_H11
1529 UINT64_C(2315268155), // PMACC_W_H00
1530 UINT64_C(2583695419), // PMACC_W_H01
1531 UINT64_C(2583703611), // PMACC_W_H11
1532 UINT64_C(4227883067), // PMAXU_B
1533 UINT64_C(4228964379), // PMAXU_DB
1534 UINT64_C(4161855515), // PMAXU_DH
1535 UINT64_C(4195409947), // PMAXU_DW
1536 UINT64_C(4160774203), // PMAXU_H
1537 UINT64_C(4194328635), // PMAXU_W
1538 UINT64_C(4093665339), // PMAX_B
1539 UINT64_C(4094746651), // PMAX_DB
1540 UINT64_C(4027637787), // PMAX_DH
1541 UINT64_C(4061192219), // PMAX_DW
1542 UINT64_C(4026556475), // PMAX_H
1543 UINT64_C(4060110907), // PMAX_W
1544 UINT64_C(3355471931), // PMHACCSU_H
1545 UINT64_C(2885709883), // PMHACCSU_H_B0
1546 UINT64_C(3154145339), // PMHACCSU_H_B1
1547 UINT64_C(3389026363), // PMHACCSU_W
1548 UINT64_C(2919264315), // PMHACCSU_W_H0
1549 UINT64_C(3187699771), // PMHACCSU_W_H1
1550 UINT64_C(2550165563), // PMHACCU_H
1551 UINT64_C(2583719995), // PMHACCU_W
1552 UINT64_C(2281730107), // PMHACC_H
1553 UINT64_C(2818601019), // PMHACC_H_B0
1554 UINT64_C(3087036475), // PMHACC_H_B1
1555 UINT64_C(2315284539), // PMHACC_W
1556 UINT64_C(2852155451), // PMHACC_W_H0
1557 UINT64_C(3120590907), // PMHACC_W_H1
1558 UINT64_C(3422580795), // PMHRACCSU_H
1559 UINT64_C(3456135227), // PMHRACCSU_W
1560 UINT64_C(2617274427), // PMHRACCU_H
1561 UINT64_C(2650828859), // PMHRACCU_W
1562 UINT64_C(2348838971), // PMHRACC_H
1563 UINT64_C(2382393403), // PMHRACC_W
1564 UINT64_C(3959447611), // PMINU_B
1565 UINT64_C(3960528923), // PMINU_DB
1566 UINT64_C(3893420059), // PMINU_DH
1567 UINT64_C(3926974491), // PMINU_DW
1568 UINT64_C(3892338747), // PMINU_H
1569 UINT64_C(3925893179), // PMINU_W
1570 UINT64_C(3825229883), // PMIN_B
1571 UINT64_C(3826311195), // PMIN_DB
1572 UINT64_C(3759202331), // PMIN_DH
1573 UINT64_C(3792756763), // PMIN_DW
1574 UINT64_C(3758121019), // PMIN_H
1575 UINT64_C(3791675451), // PMIN_W
1576 UINT64_C(3087028283), // PMQ2ADDA_H
1577 UINT64_C(3120582715), // PMQ2ADDA_W
1578 UINT64_C(2952810555), // PMQ2ADD_H
1579 UINT64_C(2986364987), // PMQ2ADD_W
1580 UINT64_C(3892342843), // PMQACC_W_H00
1581 UINT64_C(4160770107), // PMQACC_W_H01
1582 UINT64_C(4160778299), // PMQACC_W_H11
1583 UINT64_C(3154137147), // PMQR2ADDA_H
1584 UINT64_C(3187691579), // PMQR2ADDA_W
1585 UINT64_C(3019919419), // PMQR2ADD_H
1586 UINT64_C(3053473851), // PMQR2ADD_W
1587 UINT64_C(3959451707), // PMQRACC_W_H00
1588 UINT64_C(4227878971), // PMQRACC_W_H01
1589 UINT64_C(4227887163), // PMQRACC_W_H11
1590 UINT64_C(2080383131), // PMQRWACC_H
1591 UINT64_C(2013274267), // PMQWACC_H
1592 UINT64_C(3288358971), // PMSEQ_B
1593 UINT64_C(3289440283), // PMSEQ_DB
1594 UINT64_C(3222331419), // PMSEQ_DH
1595 UINT64_C(3255885851), // PMSEQ_DW
1596 UINT64_C(3221250107), // PMSEQ_H
1597 UINT64_C(3254804539), // PMSEQ_W
1598 UINT64_C(3691012155), // PMSLTU_B
1599 UINT64_C(3692093467), // PMSLTU_DB
1600 UINT64_C(3624984603), // PMSLTU_DH
1601 UINT64_C(3658539035), // PMSLTU_DW
1602 UINT64_C(3623903291), // PMSLTU_H
1603 UINT64_C(3657457723), // PMSLTU_W
1604 UINT64_C(3556794427), // PMSLT_B
1605 UINT64_C(3557875739), // PMSLT_DB
1606 UINT64_C(3490766875), // PMSLT_DH
1607 UINT64_C(3524321307), // PMSLT_DW
1608 UINT64_C(3489685563), // PMSLT_H
1609 UINT64_C(3523239995), // PMSLT_W
1610 UINT64_C(3288363067), // PMULHRSU_H
1611 UINT64_C(3321917499), // PMULHRSU_W
1612 UINT64_C(2483056699), // PMULHRU_H
1613 UINT64_C(2516611131), // PMULHRU_W
1614 UINT64_C(2214621243), // PMULHR_H
1615 UINT64_C(2248175675), // PMULHR_W
1616 UINT64_C(3221254203), // PMULHSU_H
1617 UINT64_C(2751492155), // PMULHSU_H_B0
1618 UINT64_C(3019927611), // PMULHSU_H_B1
1619 UINT64_C(3254808635), // PMULHSU_W
1620 UINT64_C(2785046587), // PMULHSU_W_H0
1621 UINT64_C(3053482043), // PMULHSU_W_H1
1622 UINT64_C(2415947835), // PMULHU_H
1623 UINT64_C(2449502267), // PMULHU_W
1624 UINT64_C(2147512379), // PMULH_H
1625 UINT64_C(2684383291), // PMULH_H_B0
1626 UINT64_C(2952818747), // PMULH_H_B1
1627 UINT64_C(2181066811), // PMULH_W
1628 UINT64_C(2717937723), // PMULH_W_H0
1629 UINT64_C(2986373179), // PMULH_W_H1
1630 UINT64_C(3556798523), // PMULQR_H
1631 UINT64_C(3590352955), // PMULQR_W
1632 UINT64_C(3489689659), // PMULQ_H
1633 UINT64_C(3523244091), // PMULQ_W
1634 UINT64_C(3758108731), // PMULSU_H_B00
1635 UINT64_C(4026544187), // PMULSU_H_B11
1636 UINT64_C(3791663163), // PMULSU_W_H00
1637 UINT64_C(4060098619), // PMULSU_W_H11
1638 UINT64_C(2684366907), // PMULU_H_B00
1639 UINT64_C(2952794171), // PMULU_H_B01
1640 UINT64_C(2952802363), // PMULU_H_B11
1641 UINT64_C(2717921339), // PMULU_W_H00
1642 UINT64_C(2986348603), // PMULU_W_H01
1643 UINT64_C(2986356795), // PMULU_W_H11
1644 UINT64_C(2147495995), // PMUL_H_B00
1645 UINT64_C(2415923259), // PMUL_H_B01
1646 UINT64_C(2415931451), // PMUL_H_B11
1647 UINT64_C(2181050427), // PMUL_W_H00
1648 UINT64_C(2449477691), // PMUL_W_H01
1649 UINT64_C(2449485883), // PMUL_W_H11
1650 UINT64_C(553697307), // PNCLIPIU_B
1651 UINT64_C(570474523), // PNCLIPIU_H
1652 UINT64_C(1627439131), // PNCLIPI_B
1653 UINT64_C(1644216347), // PNCLIPI_H
1654 UINT64_C(822132763), // PNCLIPRIU_B
1655 UINT64_C(838909979), // PNCLIPRIU_H
1656 UINT64_C(1895874587), // PNCLIPRI_B
1657 UINT64_C(1912651803), // PNCLIPRI_H
1658 UINT64_C(939573275), // PNCLIPRU_BS
1659 UINT64_C(973127707), // PNCLIPRU_HS
1660 UINT64_C(2013315099), // PNCLIPR_BS
1661 UINT64_C(2046869531), // PNCLIPR_HS
1662 UINT64_C(671137819), // PNCLIPU_BS
1663 UINT64_C(704692251), // PNCLIPU_HS
1664 UINT64_C(1744879643), // PNCLIP_BS
1665 UINT64_C(1778434075), // PNCLIP_HS
1666 UINT64_C(1359003675), // PNSARI_B
1667 UINT64_C(1375780891), // PNSARI_H
1668 UINT64_C(1090568219), // PNSRAI_B
1669 UINT64_C(1107345435), // PNSRAI_H
1670 UINT64_C(1476444187), // PNSRAR_BS
1671 UINT64_C(1509998619), // PNSRAR_HS
1672 UINT64_C(1208008731), // PNSRA_BS
1673 UINT64_C(1241563163), // PNSRA_HS
1674 UINT64_C(16826395), // PNSRLI_B
1675 UINT64_C(33603611), // PNSRLI_H
1676 UINT64_C(134266907), // PNSRL_BS
1677 UINT64_C(167821339), // PNSRL_HS
1678 UINT64_C(2415935547), // PPAIREO_B
1679 UINT64_C(2415976475), // PPAIREO_DB
1680 UINT64_C(2449530907), // PPAIREO_DH
1681 UINT64_C(2449489979), // PPAIREO_H
1682 UINT64_C(2516598843), // PPAIREO_W
1683 UINT64_C(2147500091), // PPAIRE_B
1684 UINT64_C(2147541019), // PPAIRE_DB
1685 UINT64_C(2181095451), // PPAIRE_DH
1686 UINT64_C(2181054523), // PPAIRE_H
1687 UINT64_C(2684371003), // PPAIROE_B
1688 UINT64_C(2684411931), // PPAIROE_DB
1689 UINT64_C(2717966363), // PPAIROE_DH
1690 UINT64_C(2717925435), // PPAIROE_H
1691 UINT64_C(2785034299), // PPAIROE_W
1692 UINT64_C(2952806459), // PPAIRO_B
1693 UINT64_C(2952847387), // PPAIRO_DB
1694 UINT64_C(2986401819), // PPAIRO_DH
1695 UINT64_C(2986360891), // PPAIRO_H
1696 UINT64_C(3053469755), // PPAIRO_W
1697 UINT64_C(3154133019), // PREDSUMU_BS
1698 UINT64_C(1006649371), // PREDSUMU_DBS
1699 UINT64_C(939540507), // PREDSUMU_DHS
1700 UINT64_C(3087024155), // PREDSUMU_HS
1701 UINT64_C(3120578587), // PREDSUMU_WS
1702 UINT64_C(2617262107), // PREDSUM_BS
1703 UINT64_C(469778459), // PREDSUM_DBS
1704 UINT64_C(402669595), // PREDSUM_DHS
1705 UINT64_C(2550153243), // PREDSUM_HS
1706 UINT64_C(2583707675), // PREDSUM_WS
1707 UINT64_C(24595), // PREFETCH_I
1708 UINT64_C(1073171), // PREFETCH_R
1709 UINT64_C(3170323), // PREFETCH_W
1710 UINT64_C(3832553499), // PSABS_B
1711 UINT64_C(1685086235), // PSABS_DB
1712 UINT64_C(1617977371), // PSABS_DH
1713 UINT64_C(3765444635), // PSABS_H
1714 UINT64_C(3019898939), // PSADDU_B
1715 UINT64_C(3019923483), // PSADDU_DB
1716 UINT64_C(2952814619), // PSADDU_DH
1717 UINT64_C(2986369051), // PSADDU_DW
1718 UINT64_C(2952790075), // PSADDU_H
1719 UINT64_C(2986344507), // PSADDU_W
1720 UINT64_C(2483028027), // PSADD_B
1721 UINT64_C(2483052571), // PSADD_DB
1722 UINT64_C(2415943707), // PSADD_DH
1723 UINT64_C(2449498139), // PSADD_DW
1724 UINT64_C(2415919163), // PSADD_H
1725 UINT64_C(2449473595), // PSADD_W
1726 UINT64_C(2417025051), // PSAS_DHX
1727 UINT64_C(2415943739), // PSAS_HX
1728 UINT64_C(2449498171), // PSAS_WX
1729 UINT64_C(1627447323), // PSATI_DH
1730 UINT64_C(1644224539), // PSATI_DW
1731 UINT64_C(3774890011), // PSATI_H
1732 UINT64_C(3791667227), // PSATI_W
1733 UINT64_C(2215698459), // PSA_DHX
1734 UINT64_C(2214617147), // PSA_HX
1735 UINT64_C(2248171579), // PSA_WX
1736 UINT64_C(1614831643), // PSEXT_DH_B
1737 UINT64_C(1648386075), // PSEXT_DW_B
1738 UINT64_C(1649434651), // PSEXT_DW_H
1739 UINT64_C(3762298907), // PSEXT_H_B
1740 UINT64_C(3795853339), // PSEXT_W_B
1741 UINT64_C(3796901915), // PSEXT_W_H
1742 UINT64_C(2685427739), // PSH1ADD_DH
1743 UINT64_C(2718982171), // PSH1ADD_DW
1744 UINT64_C(2684362811), // PSH1ADD_H
1745 UINT64_C(2717917243), // PSH1ADD_W
1746 UINT64_C(2155880475), // PSLLI_B
1747 UINT64_C(8413211), // PSLLI_DB
1748 UINT64_C(16801819), // PSLLI_DH
1749 UINT64_C(33579035), // PSLLI_DW
1750 UINT64_C(2164269083), // PSLLI_H
1751 UINT64_C(2181046299), // PSLLI_W
1752 UINT64_C(2348818459), // PSLL_BS
1753 UINT64_C(201351195), // PSLL_DBS
1754 UINT64_C(134242331), // PSLL_DHS
1755 UINT64_C(167796763), // PSLL_DWS
1756 UINT64_C(2281709595), // PSLL_HS
1757 UINT64_C(2315264027), // PSLL_WS
1758 UINT64_C(3229630491), // PSRAI_B
1759 UINT64_C(1082187803), // PSRAI_DB
1760 UINT64_C(1090576411), // PSRAI_DH
1761 UINT64_C(1107353627), // PSRAI_DW
1762 UINT64_C(3238019099), // PSRAI_H
1763 UINT64_C(3254796315), // PSRAI_W
1764 UINT64_C(1359011867), // PSRARI_DH
1765 UINT64_C(1375789083), // PSRARI_DW
1766 UINT64_C(3506454555), // PSRARI_H
1767 UINT64_C(3523231771), // PSRARI_W
1768 UINT64_C(3422568475), // PSRA_BS
1769 UINT64_C(1275125787), // PSRA_DBS
1770 UINT64_C(1208016923), // PSRA_DHS
1771 UINT64_C(1241571355), // PSRA_DWS
1772 UINT64_C(3355459611), // PSRA_HS
1773 UINT64_C(3389014043), // PSRA_WS
1774 UINT64_C(2155888667), // PSRLI_B
1775 UINT64_C(8445979), // PSRLI_DB
1776 UINT64_C(16834587), // PSRLI_DH
1777 UINT64_C(33611803), // PSRLI_DW
1778 UINT64_C(2164277275), // PSRLI_H
1779 UINT64_C(2181054491), // PSRLI_W
1780 UINT64_C(2348826651), // PSRL_BS
1781 UINT64_C(201383963), // PSRL_DBS
1782 UINT64_C(134275099), // PSRL_DHS
1783 UINT64_C(167829531), // PSRL_DWS
1784 UINT64_C(2281717787), // PSRL_HS
1785 UINT64_C(2315272219), // PSRL_WS
1786 UINT64_C(2484133915), // PSSA_DHX
1787 UINT64_C(2483052603), // PSSA_HX
1788 UINT64_C(2516607035), // PSSA_WX
1789 UINT64_C(2953863195), // PSSH1SADD_DH
1790 UINT64_C(2987417627), // PSSH1SADD_DW
1791 UINT64_C(2952798267), // PSSH1SADD_H
1792 UINT64_C(2986352699), // PSSH1SADD_W
1793 UINT64_C(2013290523), // PSSHAR_DHS
1794 UINT64_C(2046844955), // PSSHAR_DWS
1795 UINT64_C(4160757787), // PSSHAR_HS
1796 UINT64_C(4194312219), // PSSHAR_WS
1797 UINT64_C(1744855067), // PSSHA_DHS
1798 UINT64_C(1778409499), // PSSHA_DWS
1799 UINT64_C(3892322331), // PSSHA_HS
1800 UINT64_C(3925876763), // PSSHA_WS
1801 UINT64_C(1358979099), // PSSLAI_DH
1802 UINT64_C(1375756315), // PSSLAI_DW
1803 UINT64_C(3506446363), // PSSLAI_H
1804 UINT64_C(3523223579), // PSSLAI_W
1805 UINT64_C(4093640763), // PSSUBU_B
1806 UINT64_C(4093665307), // PSSUBU_DB
1807 UINT64_C(4026556443), // PSSUBU_DH
1808 UINT64_C(4060110875), // PSSUBU_DW
1809 UINT64_C(4026531899), // PSSUBU_H
1810 UINT64_C(4060086331), // PSSUBU_W
1811 UINT64_C(3556769851), // PSSUB_B
1812 UINT64_C(3556794395), // PSSUB_DB
1813 UINT64_C(3489685531), // PSSUB_DH
1814 UINT64_C(3523239963), // PSSUB_DW
1815 UINT64_C(3489660987), // PSSUB_H
1816 UINT64_C(3523215419), // PSSUB_W
1817 UINT64_C(3288334395), // PSUB_B
1818 UINT64_C(3288358939), // PSUB_DB
1819 UINT64_C(3221250075), // PSUB_DH
1820 UINT64_C(3254804507), // PSUB_DW
1821 UINT64_C(3221225531), // PSUB_H
1822 UINT64_C(3254779963), // PSUB_W
1823 UINT64_C(553705499), // PUSATI_DH
1824 UINT64_C(570482715), // PUSATI_DW
1825 UINT64_C(2701148187), // PUSATI_H
1826 UINT64_C(2717925403), // PUSATI_W
1827 UINT64_C(469770395), // PWADDAU_B
1828 UINT64_C(402661531), // PWADDAU_H
1829 UINT64_C(201334939), // PWADDA_B
1830 UINT64_C(134226075), // PWADDA_H
1831 UINT64_C(335552667), // PWADDU_B
1832 UINT64_C(268443803), // PWADDU_H
1833 UINT64_C(67117211), // PWADD_B
1834 UINT64_C(8347), // PWADD_H
1835 UINT64_C(1744838811), // PWMACCSU_H
1836 UINT64_C(939532443), // PWMACCU_H
1837 UINT64_C(671096987), // PWMACC_H
1838 UINT64_C(1677729947), // PWMULSU_B
1839 UINT64_C(1610621083), // PWMULSU_H
1840 UINT64_C(872423579), // PWMULU_B
1841 UINT64_C(805314715), // PWMULU_H
1842 UINT64_C(603988123), // PWMUL_B
1843 UINT64_C(536879259), // PWMUL_H
1844 UINT64_C(1090527259), // PWSLAI_B
1845 UINT64_C(1107304475), // PWSLAI_H
1846 UINT64_C(1207967771), // PWSLA_BS
1847 UINT64_C(1241522203), // PWSLA_HS
1848 UINT64_C(16785435), // PWSLLI_B
1849 UINT64_C(33562651), // PWSLLI_H
1850 UINT64_C(134225947), // PWSLL_BS
1851 UINT64_C(167780379), // PWSLL_HS
1852 UINT64_C(1543512219), // PWSUBAU_B
1853 UINT64_C(1476403355), // PWSUBAU_H
1854 UINT64_C(1275076763), // PWSUBA_B
1855 UINT64_C(1207967899), // PWSUBA_H
1856 UINT64_C(1409294491), // PWSUBU_B
1857 UINT64_C(1342185627), // PWSUBU_H
1858 UINT64_C(1140859035), // PWSUB_B
1859 UINT64_C(1073750171), // PWSUB_H
1860 UINT64_C(469774347), // QC_ADDSAT
1861 UINT64_C(503328779), // QC_ADDUSAT
1862 UINT64_C(123), // QC_BEQI
1863 UINT64_C(20603), // QC_BGEI
1864 UINT64_C(28795), // QC_BGEUI
1865 UINT64_C(16507), // QC_BLTI
1866 UINT64_C(24699), // QC_BLTUI
1867 UINT64_C(4219), // QC_BNEI
1868 UINT64_C(201338891), // QC_BREV32
1869 UINT64_C(134230027), // QC_CLO
1870 UINT64_C(3456106611), // QC_CLRINTI
1871 UINT64_C(44130), // QC_CM_MVA01S
1872 UINT64_C(44066), // QC_CM_MVSA01
1873 UINT64_C(47618), // QC_CM_POP
1874 UINT64_C(48642), // QC_CM_POPRET
1875 UINT64_C(48130), // QC_CM_POPRETZ
1876 UINT64_C(47106), // QC_CM_PUSH
1877 UINT64_C(47362), // QC_CM_PUSHFP
1878 UINT64_C(12299), // QC_COMPRESS2
1879 UINT64_C(33566731), // QC_COMPRESS3
1880 UINT64_C(2348810355), // QC_CSRRWR
1881 UINT64_C(2382364787), // QC_CSRRWRI
1882 UINT64_C(167784459), // QC_CTO
1883 UINT64_C(36865), // QC_C_BEXTI
1884 UINT64_C(37889), // QC_C_BSETI
1885 UINT64_C(4110), // QC_C_CLRINT
1886 UINT64_C(6930), // QC_C_DI
1887 UINT64_C(4098), // QC_C_DIR
1888 UINT64_C(7058), // QC_C_EI
1889 UINT64_C(4102), // QC_C_EIR
1890 UINT64_C(4098), // QC_C_EXTU
1891 UINT64_C(6162), // QC_C_MIENTER
1892 UINT64_C(6290), // QC_C_MIENTER_NEST
1893 UINT64_C(6674), // QC_C_MILEAVERET
1894 UINT64_C(6546), // QC_C_MNRET
1895 UINT64_C(6418), // QC_C_MRET
1896 UINT64_C(8194), // QC_C_MULIADD
1897 UINT64_C(44034), // QC_C_MVEQZ
1898 UINT64_C(4106), // QC_C_SETINT
1899 UINT64_C(32769), // QC_C_SYNC
1900 UINT64_C(33793), // QC_C_SYNCR
1901 UINT64_C(36865), // QC_C_SYNCWF
1902 UINT64_C(37889), // QC_C_SYNCWL
1903 UINT64_C(67121163), // QC_EXPAND2
1904 UINT64_C(100675595), // QC_EXPAND3
1905 UINT64_C(1073750027), // QC_EXT
1906 UINT64_C(3221233675), // QC_EXTD
1907 UINT64_C(268447755), // QC_EXTDPR
1908 UINT64_C(302002187), // QC_EXTDPRH
1909 UINT64_C(167784459), // QC_EXTDR
1910 UINT64_C(2147491851), // QC_EXTDU
1911 UINT64_C(201338891), // QC_EXTDUPR
1912 UINT64_C(234893323), // QC_EXTDUPRH
1913 UINT64_C(134230027), // QC_EXTDUR
1914 UINT64_C(8203), // QC_EXTU
1915 UINT64_C(8223), // QC_E_ADDAI
1916 UINT64_C(2147495967), // QC_E_ADDI
1917 UINT64_C(40991), // QC_E_ANDAI
1918 UINT64_C(3221237791), // QC_E_ANDI
1919 UINT64_C(25182239), // QC_E_BEQI
1920 UINT64_C(30425119), // QC_E_BGEI
1921 UINT64_C(32522271), // QC_E_BGEUI
1922 UINT64_C(29376543), // QC_E_BLTI
1923 UINT64_C(31473695), // QC_E_BLTUI
1924 UINT64_C(26230815), // QC_E_BNEI
1925 UINT64_C(16415), // QC_E_J
1926 UINT64_C(49183), // QC_E_JAL
1927 UINT64_C(20511), // QC_E_LB
1928 UINT64_C(1073762335), // QC_E_LBU
1929 UINT64_C(2147504159), // QC_E_LH
1930 UINT64_C(3221245983), // QC_E_LHU
1931 UINT64_C(31), // QC_E_LI
1932 UINT64_C(24607), // QC_E_LW
1933 UINT64_C(36895), // QC_E_ORAI
1934 UINT64_C(1073754143), // QC_E_ORI
1935 UINT64_C(1073766431), // QC_E_SB
1936 UINT64_C(2147508255), // QC_E_SH
1937 UINT64_C(3221250079), // QC_E_SW
1938 UINT64_C(4127), // QC_E_XORAI
1939 UINT64_C(12319), // QC_E_XORI
1940 UINT64_C(1073745931), // QC_INSB
1941 UINT64_C(2147487755), // QC_INSBH
1942 UINT64_C(33566731), // QC_INSBHR
1943 UINT64_C(4107), // QC_INSBI
1944 UINT64_C(67121163), // QC_INSBPR
1945 UINT64_C(100675595), // QC_INSBPRH
1946 UINT64_C(12299), // QC_INSBR
1947 UINT64_C(2147483659), // QC_INSBRI
1948 UINT64_C(20491), // QC_INW
1949 UINT64_C(27), // QC_LI
1950 UINT64_C(33554523), // QC_LIEQ
1951 UINT64_C(100663387), // QC_LIEQI
1952 UINT64_C(33575003), // QC_LIGE
1953 UINT64_C(100683867), // QC_LIGEI
1954 UINT64_C(33583195), // QC_LIGEU
1955 UINT64_C(100692059), // QC_LIGEUI
1956 UINT64_C(33570907), // QC_LILT
1957 UINT64_C(100679771), // QC_LILTI
1958 UINT64_C(33579099), // QC_LILTU
1959 UINT64_C(100687963), // QC_LILTUI
1960 UINT64_C(33558619), // QC_LINE
1961 UINT64_C(100667483), // QC_LINEI
1962 UINT64_C(2147512331), // QC_LRB
1963 UINT64_C(2952818699), // QC_LRBU
1964 UINT64_C(2415947787), // QC_LRH
1965 UINT64_C(3221254155), // QC_LRHU
1966 UINT64_C(2684383243), // QC_LRW
1967 UINT64_C(28683), // QC_LWM
1968 UINT64_C(1073770507), // QC_LWMI
1969 UINT64_C(24587), // QC_MULIADD
1970 UINT64_C(91), // QC_MVEQ
1971 UINT64_C(67108955), // QC_MVEQI
1972 UINT64_C(20571), // QC_MVGE
1973 UINT64_C(67129435), // QC_MVGEI
1974 UINT64_C(28763), // QC_MVGEU
1975 UINT64_C(67137627), // QC_MVGEUI
1976 UINT64_C(16475), // QC_MVLT
1977 UINT64_C(67125339), // QC_MVLTI
1978 UINT64_C(24667), // QC_MVLTU
1979 UINT64_C(67133531), // QC_MVLTUI
1980 UINT64_C(4187), // QC_MVNE
1981 UINT64_C(67113051), // QC_MVNEI
1982 UINT64_C(234893323), // QC_NORM
1983 UINT64_C(302002187), // QC_NORMEU
1984 UINT64_C(268447755), // QC_NORMU
1985 UINT64_C(16395), // QC_OUTW
1986 UINT64_C(1073750035), // QC_PPUTCI
1987 UINT64_C(67117147), // QC_SELECTEQI
1988 UINT64_C(33562715), // QC_SELECTIEQ
1989 UINT64_C(100671579), // QC_SELECTIEQI
1990 UINT64_C(8283), // QC_SELECTIIEQ
1991 UINT64_C(12379), // QC_SELECTIINE
1992 UINT64_C(33566811), // QC_SELECTINE
1993 UINT64_C(100675675), // QC_SELECTINEI
1994 UINT64_C(67121243), // QC_SELECTNEI
1995 UINT64_C(3422552179), // QC_SETINTI
1996 UINT64_C(2147512363), // QC_SETWM
1997 UINT64_C(3221254187), // QC_SETWMI
1998 UINT64_C(1073754123), // QC_SHLADD
1999 UINT64_C(335556619), // QC_SHLSAT
2000 UINT64_C(402665483), // QC_SHLUSAT
2001 UINT64_C(3489685547), // QC_SRB
2002 UINT64_C(3758121003), // QC_SRH
2003 UINT64_C(4026556459), // QC_SRW
2004 UINT64_C(536883211), // QC_SUBSAT
2005 UINT64_C(570437643), // QC_SUBUSAT
2006 UINT64_C(28715), // QC_SWM
2007 UINT64_C(1073770539), // QC_SWMI
2008 UINT64_C(268447763), // QC_SYNC
2009 UINT64_C(536883219), // QC_SYNCR
2010 UINT64_C(1073754131), // QC_SYNCWF
2011 UINT64_C(2147495955), // QC_SYNCWL
2012 UINT64_C(603992075), // QC_WRAP
2013 UINT64_C(11), // QC_WRAPI
2014 UINT64_C(8192), // QK_C_LBU
2015 UINT64_C(32768), // QK_C_LBUSP
2016 UINT64_C(8194), // QK_C_LHU
2017 UINT64_C(32800), // QK_C_LHUSP
2018 UINT64_C(40960), // QK_C_SB
2019 UINT64_C(32832), // QK_C_SBSP
2020 UINT64_C(40962), // QK_C_SH
2021 UINT64_C(32864), // QK_C_SHSP
2022 UINT64_C(33579059), // REM
2023 UINT64_C(33583155), // REMU
2024 UINT64_C(33583163), // REMUW
2025 UINT64_C(33579067), // REMW
2026 UINT64_C(1795182611), // REV16
2027 UINT64_C(1770016787), // REV8_RV32
2028 UINT64_C(1803571219), // REV8_RV64
2029 UINT64_C(1777356819), // REV_RV32
2030 UINT64_C(1810911251), // REV_RV64
2031 UINT64_C(1577066587), // RI_VEXTRACT
2032 UINT64_C(1073766491), // RI_VINSERT
2033 UINT64_C(536871003), // RI_VUNZIP2A_VV
2034 UINT64_C(1610612827), // RI_VUNZIP2B_VV
2035 UINT64_C(28763), // RI_VZERO
2036 UINT64_C(268435547), // RI_VZIP2A_VV
2037 UINT64_C(1342177371), // RI_VZIP2B_VV
2038 UINT64_C(805306459), // RI_VZIPEVEN_VV
2039 UINT64_C(1879048283), // RI_VZIPODD_VV
2040 UINT64_C(1610616883), // ROL
2041 UINT64_C(1610616891), // ROLW
2042 UINT64_C(1610633267), // ROR
2043 UINT64_C(1610633235), // RORI
2044 UINT64_C(1610633243), // RORIW
2045 UINT64_C(1610633275), // RORW
2046 UINT64_C(2449473595), // SADD
2047 UINT64_C(2986344507), // SADDU
2048 UINT64_C(3791667227), // SATI_RV32
2049 UINT64_C(3825221659), // SATI_RV64
2050 UINT64_C(35), // SB
2051 UINT64_C(1040187439), // SB_AQRL
2052 UINT64_C(973078575), // SB_RL
2053 UINT64_C(272629875), // SCTRCLR
2054 UINT64_C(402665519), // SC_D
2055 UINT64_C(469774383), // SC_D_AQ
2056 UINT64_C(503328815), // SC_D_AQRL
2057 UINT64_C(436219951), // SC_D_RL
2058 UINT64_C(402661423), // SC_W
2059 UINT64_C(469770287), // SC_W_AQ
2060 UINT64_C(503324719), // SC_W_AQRL
2061 UINT64_C(436215855), // SC_W_RL
2062 UINT64_C(12323), // SD
2063 UINT64_C(1040199727), // SD_AQRL
2064 UINT64_C(973090863), // SD_RL
2065 UINT64_C(12323), // SD_RV32
2066 UINT64_C(1614811155), // SEXT_B
2067 UINT64_C(1615859731), // SEXT_H
2068 UINT64_C(403701875), // SFENCE_INVAL_IR
2069 UINT64_C(301990003), // SFENCE_VMA
2070 UINT64_C(402653299), // SFENCE_W_INVAL
2071 UINT64_C(4229955699), // SF_CDISCARD_D_L1
2072 UINT64_C(810549363), // SF_CEASE
2073 UINT64_C(4227858547), // SF_CFLUSH_D_L1
2074 UINT64_C(4261417207), // SF_MM_E4M3_E4M3
2075 UINT64_C(4261417079), // SF_MM_E4M3_E5M2
2076 UINT64_C(4194308343), // SF_MM_E5M2_E4M3
2077 UINT64_C(4194308215), // SF_MM_E5M2_E5M2
2078 UINT64_C(4060090487), // SF_MM_F_F
2079 UINT64_C(4127195383), // SF_MM_S_S
2080 UINT64_C(4127195255), // SF_MM_S_U
2081 UINT64_C(4060086519), // SF_MM_U_S
2082 UINT64_C(4060086391), // SF_MM_U_U
2083 UINT64_C(704663643), // SF_VC_FV
2084 UINT64_C(2852147291), // SF_VC_FVV
2085 UINT64_C(4194324571), // SF_VC_FVW
2086 UINT64_C(33566811), // SF_VC_I
2087 UINT64_C(570437723), // SF_VC_IV
2088 UINT64_C(2717921371), // SF_VC_IVV
2089 UINT64_C(4060098651), // SF_VC_IVW
2090 UINT64_C(570425435), // SF_VC_VV
2091 UINT64_C(2717909083), // SF_VC_VVV
2092 UINT64_C(4060086363), // SF_VC_VVW
2093 UINT64_C(671109211), // SF_VC_V_FV
2094 UINT64_C(2818592859), // SF_VC_V_FVV
2095 UINT64_C(4160770139), // SF_VC_V_FVW
2096 UINT64_C(12379), // SF_VC_V_I
2097 UINT64_C(536883291), // SF_VC_V_IV
2098 UINT64_C(2684366939), // SF_VC_V_IVV
2099 UINT64_C(4026544219), // SF_VC_V_IVW
2100 UINT64_C(536871003), // SF_VC_V_VV
2101 UINT64_C(2684354651), // SF_VC_V_VVV
2102 UINT64_C(4026531931), // SF_VC_V_VVW
2103 UINT64_C(16475), // SF_VC_V_X
2104 UINT64_C(536887387), // SF_VC_V_XV
2105 UINT64_C(2684371035), // SF_VC_V_XVV
2106 UINT64_C(4026548315), // SF_VC_V_XVW
2107 UINT64_C(33570907), // SF_VC_X
2108 UINT64_C(570441819), // SF_VC_XV
2109 UINT64_C(2717925467), // SF_VC_XVV
2110 UINT64_C(4060102747), // SF_VC_XVW
2111 UINT64_C(1275269207), // SF_VFEXPA_V
2112 UINT64_C(1275301975), // SF_VFEXP_V
2113 UINT64_C(2281721947), // SF_VFNRCLIP_XU_F_QF
2114 UINT64_C(2348830811), // SF_VFNRCLIP_X_F_QF
2115 UINT64_C(4060090459), // SF_VFWMACC_4x4x4
2116 UINT64_C(838889479), // SF_VLTE16
2117 UINT64_C(1375760391), // SF_VLTE32
2118 UINT64_C(1912631303), // SF_VLTE64
2119 UINT64_C(302018567), // SF_VLTE8
2120 UINT64_C(3187679323), // SF_VQMACCSU_2x8x2
2121 UINT64_C(4261421147), // SF_VQMACCSU_4x8x4
2122 UINT64_C(3120570459), // SF_VQMACCUS_2x8x2
2123 UINT64_C(4194312283), // SF_VQMACCUS_4x8x4
2124 UINT64_C(2986352731), // SF_VQMACCU_2x8x2
2125 UINT64_C(4060094555), // SF_VQMACCU_4x8x4
2126 UINT64_C(3053461595), // SF_VQMACC_2x8x2
2127 UINT64_C(4127203419), // SF_VQMACC_4x8x4
2128 UINT64_C(2216718423), // SF_VSETTK
2129 UINT64_C(2215669847), // SF_VSETTM
2130 UINT64_C(2214621271), // SF_VSETTN
2131 UINT64_C(838889511), // SF_VSTE16
2132 UINT64_C(1375760423), // SF_VSTE32
2133 UINT64_C(1912631335), // SF_VSTE64
2134 UINT64_C(302018599), // SF_VSTE8
2135 UINT64_C(1136681047), // SF_VTDISCARD
2136 UINT64_C(1577082967), // SF_VTMV_T_V
2137 UINT64_C(1139826775), // SF_VTMV_V_T
2138 UINT64_C(1138778199), // SF_VTZERO_T
2139 UINT64_C(4131), // SH
2140 UINT64_C(536879155), // SH1ADD
2141 UINT64_C(536879163), // SH1ADD_UW
2142 UINT64_C(536887347), // SH2ADD
2143 UINT64_C(536887355), // SH2ADD_UW
2144 UINT64_C(536895539), // SH3ADD
2145 UINT64_C(536895547), // SH3ADD_UW
2146 UINT64_C(3992985627), // SHA
2147 UINT64_C(270536723), // SHA256SIG0
2148 UINT64_C(271585299), // SHA256SIG1
2149 UINT64_C(268439571), // SHA256SUM0
2150 UINT64_C(269488147), // SHA256SUM1
2151 UINT64_C(274731027), // SHA512SIG0
2152 UINT64_C(1543503923), // SHA512SIG0H
2153 UINT64_C(1409286195), // SHA512SIG0L
2154 UINT64_C(275779603), // SHA512SIG1
2155 UINT64_C(1577058355), // SHA512SIG1H
2156 UINT64_C(1442840627), // SHA512SIG1L
2157 UINT64_C(272633875), // SHA512SUM0
2158 UINT64_C(1342177331), // SHA512SUM0R
2159 UINT64_C(273682451), // SHA512SUM1
2160 UINT64_C(1375731763), // SHA512SUM1R
2161 UINT64_C(4261421083), // SHAR
2162 UINT64_C(1040191535), // SH_AQRL
2163 UINT64_C(4131), // SH_INX
2164 UINT64_C(973082671), // SH_RL
2165 UINT64_C(369098867), // SINVAL_VMA
2166 UINT64_C(4147), // SLL
2167 UINT64_C(4115), // SLLI
2168 UINT64_C(4123), // SLLIW
2169 UINT64_C(134221851), // SLLI_UW
2170 UINT64_C(4155), // SLLW
2171 UINT64_C(8243), // SLT
2172 UINT64_C(8211), // SLTI
2173 UINT64_C(12307), // SLTIU
2174 UINT64_C(12339), // SLTU
2175 UINT64_C(2382368827), // SLX
2176 UINT64_C(276828179), // SM3P0
2177 UINT64_C(277876755), // SM3P1
2178 UINT64_C(805306419), // SM4ED
2179 UINT64_C(872415283), // SM4KS
2180 UINT64_C(3791663147), // SMT_VMADOT
2181 UINT64_C(3858772011), // SMT_VMADOT1
2182 UINT64_C(3858767915), // SMT_VMADOT1SU
2183 UINT64_C(3858759723), // SMT_VMADOT1U
2184 UINT64_C(3858763819), // SMT_VMADOT1US
2185 UINT64_C(3858788395), // SMT_VMADOT2
2186 UINT64_C(3858784299), // SMT_VMADOT2SU
2187 UINT64_C(3858776107), // SMT_VMADOT2U
2188 UINT64_C(3858780203), // SMT_VMADOT2US
2189 UINT64_C(3858804779), // SMT_VMADOT3
2190 UINT64_C(3858800683), // SMT_VMADOT3SU
2191 UINT64_C(3858792491), // SMT_VMADOT3U
2192 UINT64_C(3858796587), // SMT_VMADOT3US
2193 UINT64_C(3791659051), // SMT_VMADOTSU
2194 UINT64_C(3791650859), // SMT_VMADOTU
2195 UINT64_C(3791654955), // SMT_VMADOTUS
2196 UINT64_C(1073762355), // SRA
2197 UINT64_C(1073762323), // SRAI
2198 UINT64_C(1073762331), // SRAIW
2199 UINT64_C(3523231771), // SRARI_RV32
2200 UINT64_C(3556786203), // SRARI_RV64
2201 UINT64_C(1073762363), // SRAW
2202 UINT64_C(270532723), // SRET
2203 UINT64_C(20531), // SRL
2204 UINT64_C(20499), // SRLI
2205 UINT64_C(20507), // SRLIW
2206 UINT64_C(20539), // SRLW
2207 UINT64_C(2919239739), // SRX
2208 UINT64_C(1207971887), // SSAMOSWAP_D
2209 UINT64_C(1275080751), // SSAMOSWAP_D_AQ
2210 UINT64_C(1308635183), // SSAMOSWAP_D_AQRL
2211 UINT64_C(1241526319), // SSAMOSWAP_D_RL
2212 UINT64_C(1207967791), // SSAMOSWAP_W
2213 UINT64_C(1275076655), // SSAMOSWAP_W_AQ
2214 UINT64_C(1308631087), // SSAMOSWAP_W_AQRL
2215 UINT64_C(1241522223), // SSAMOSWAP_W_RL
2216 UINT64_C(2986352699), // SSH1SADD
2217 UINT64_C(3925876763), // SSHA
2218 UINT64_C(4194312219), // SSHAR
2219 UINT64_C(3523223579), // SSLAI
2220 UINT64_C(3451928691), // SSPOPCHK
2221 UINT64_C(3456122995), // SSPUSH
2222 UINT64_C(3451928691), // SSRDP
2223 UINT64_C(3523215419), // SSUB
2224 UINT64_C(4060086331), // SSUBU
2225 UINT64_C(1073741875), // SUB
2226 UINT64_C(3321913371), // SUBD
2227 UINT64_C(1073741883), // SUBW
2228 UINT64_C(8227), // SW
2229 UINT64_C(1040195631), // SW_AQRL
2230 UINT64_C(8227), // SW_INX
2231 UINT64_C(973086767), // SW_RL
2232 UINT64_C(4107), // TH_ADDSL
2233 UINT64_C(1048587), // TH_DCACHE_CALL
2234 UINT64_C(3145739), // TH_DCACHE_CIALL
2235 UINT64_C(45088779), // TH_DCACHE_CIPA
2236 UINT64_C(36700171), // TH_DCACHE_CISW
2237 UINT64_C(40894475), // TH_DCACHE_CIVA
2238 UINT64_C(42991627), // TH_DCACHE_CPA
2239 UINT64_C(41943051), // TH_DCACHE_CPAL1
2240 UINT64_C(34603019), // TH_DCACHE_CSW
2241 UINT64_C(38797323), // TH_DCACHE_CVA
2242 UINT64_C(37748747), // TH_DCACHE_CVAL1
2243 UINT64_C(2097163), // TH_DCACHE_IALL
2244 UINT64_C(44040203), // TH_DCACHE_IPA
2245 UINT64_C(35651595), // TH_DCACHE_ISW
2246 UINT64_C(39845899), // TH_DCACHE_IVA
2247 UINT64_C(8203), // TH_EXT
2248 UINT64_C(12299), // TH_EXTU
2249 UINT64_C(2214596619), // TH_FF0
2250 UINT64_C(2248151051), // TH_FF1
2251 UINT64_C(1610637323), // TH_FLRD
2252 UINT64_C(1073766411), // TH_FLRW
2253 UINT64_C(1879072779), // TH_FLURD
2254 UINT64_C(1342201867), // TH_FLURW
2255 UINT64_C(1610641419), // TH_FSRD
2256 UINT64_C(1073770507), // TH_FSRW
2257 UINT64_C(1879076875), // TH_FSURD
2258 UINT64_C(1342205963), // TH_FSURW
2259 UINT64_C(16777227), // TH_ICACHE_IALL
2260 UINT64_C(17825803), // TH_ICACHE_IALLS
2261 UINT64_C(58720267), // TH_ICACHE_IPA
2262 UINT64_C(50331659), // TH_ICACHE_IVA
2263 UINT64_C(22020107), // TH_L2CACHE_CALL
2264 UINT64_C(24117259), // TH_L2CACHE_CIALL
2265 UINT64_C(23068683), // TH_L2CACHE_IALL
2266 UINT64_C(402669579), // TH_LBIA
2267 UINT64_C(134234123), // TH_LBIB
2268 UINT64_C(2550153227), // TH_LBUIA
2269 UINT64_C(2281717771), // TH_LBUIB
2270 UINT64_C(4160765963), // TH_LDD
2271 UINT64_C(2013282315), // TH_LDIA
2272 UINT64_C(1744846859), // TH_LDIB
2273 UINT64_C(939540491), // TH_LHIA
2274 UINT64_C(671105035), // TH_LHIB
2275 UINT64_C(3087024139), // TH_LHUIA
2276 UINT64_C(2818588683), // TH_LHUIB
2277 UINT64_C(16395), // TH_LRB
2278 UINT64_C(2147500043), // TH_LRBU
2279 UINT64_C(1610629131), // TH_LRD
2280 UINT64_C(536887307), // TH_LRH
2281 UINT64_C(2684370955), // TH_LRHU
2282 UINT64_C(1073758219), // TH_LRW
2283 UINT64_C(3221241867), // TH_LRWU
2284 UINT64_C(268451851), // TH_LURB
2285 UINT64_C(2415935499), // TH_LURBU
2286 UINT64_C(1879064587), // TH_LURD
2287 UINT64_C(805322763), // TH_LURH
2288 UINT64_C(2952806411), // TH_LURHU
2289 UINT64_C(1342193675), // TH_LURW
2290 UINT64_C(3489677323), // TH_LURWU
2291 UINT64_C(3758112779), // TH_LWD
2292 UINT64_C(1476411403), // TH_LWIA
2293 UINT64_C(1207975947), // TH_LWIB
2294 UINT64_C(4026548235), // TH_LWUD
2295 UINT64_C(3623895051), // TH_LWUIA
2296 UINT64_C(3355459595), // TH_LWUIB
2297 UINT64_C(536875019), // TH_MULA
2298 UINT64_C(671092747), // TH_MULAH
2299 UINT64_C(603983883), // TH_MULAW
2300 UINT64_C(570429451), // TH_MULS
2301 UINT64_C(704647179), // TH_MULSH
2302 UINT64_C(637538315), // TH_MULSW
2303 UINT64_C(1073745931), // TH_MVEQZ
2304 UINT64_C(1107300363), // TH_MVNEZ
2305 UINT64_C(2181042187), // TH_REV
2306 UINT64_C(2415923211), // TH_REVW
2307 UINT64_C(402673675), // TH_SBIA
2308 UINT64_C(134238219), // TH_SBIB
2309 UINT64_C(4160770059), // TH_SDD
2310 UINT64_C(2013286411), // TH_SDIA
2311 UINT64_C(1744850955), // TH_SDIB
2312 UINT64_C(67108875), // TH_SFENCE_VMAS
2313 UINT64_C(939544587), // TH_SHIA
2314 UINT64_C(671109131), // TH_SHIB
2315 UINT64_C(20491), // TH_SRB
2316 UINT64_C(1610633227), // TH_SRD
2317 UINT64_C(536891403), // TH_SRH
2318 UINT64_C(268439563), // TH_SRRI
2319 UINT64_C(335548427), // TH_SRRIW
2320 UINT64_C(1073762315), // TH_SRW
2321 UINT64_C(268455947), // TH_SURB
2322 UINT64_C(1879068683), // TH_SURD
2323 UINT64_C(805326859), // TH_SURH
2324 UINT64_C(1342197771), // TH_SURW
2325 UINT64_C(3758116875), // TH_SWD
2326 UINT64_C(1476415499), // TH_SWIA
2327 UINT64_C(1207980043), // TH_SWIB
2328 UINT64_C(25165835), // TH_SYNC
2329 UINT64_C(27262987), // TH_SYNC_I
2330 UINT64_C(28311563), // TH_SYNC_IS
2331 UINT64_C(26214411), // TH_SYNC_S
2332 UINT64_C(2281705483), // TH_TST
2333 UINT64_C(2147487755), // TH_TSTNBZ
2334 UINT64_C(2415943691), // TH_VMAQASU_VV
2335 UINT64_C(2483052555), // TH_VMAQASU_VX
2336 UINT64_C(2617270283), // TH_VMAQAUS_VX
2337 UINT64_C(2281725963), // TH_VMAQAU_VV
2338 UINT64_C(2348834827), // TH_VMAQAU_VX
2339 UINT64_C(2147508235), // TH_VMAQA_VV
2340 UINT64_C(2214617099), // TH_VMAQA_VX
2341 UINT64_C(3221229683), // UNIMP
2342 UINT64_C(3858767931), // UNZIP16HP
2343 UINT64_C(3791659067), // UNZIP16P
2344 UINT64_C(3825213499), // UNZIP8HP
2345 UINT64_C(3758104635), // UNZIP8P
2346 UINT64_C(149966867), // UNZIP_RV32
2347 UINT64_C(2717925403), // USATI_RV32
2348 UINT64_C(2751479835), // USATI_RV64
2349 UINT64_C(536879191), // VAADDU_VV
2350 UINT64_C(536895575), // VAADDU_VX
2351 UINT64_C(603988055), // VAADD_VV
2352 UINT64_C(604004439), // VAADD_VX
2353 UINT64_C(1073754199), // VADC_VIM
2354 UINT64_C(1073741911), // VADC_VVM
2355 UINT64_C(1073758295), // VADC_VXM
2356 UINT64_C(12375), // VADD_VI
2357 UINT64_C(87), // VADD_VV
2358 UINT64_C(16471), // VADD_VX
2359 UINT64_C(2785058935), // VAESDF_VS
2360 UINT64_C(2717950071), // VAESDF_VV
2361 UINT64_C(2785026167), // VAESDM_VS
2362 UINT64_C(2717917303), // VAESDM_VV
2363 UINT64_C(2785124471), // VAESEF_VS
2364 UINT64_C(2718015607), // VAESEF_VV
2365 UINT64_C(2785091703), // VAESEM_VS
2366 UINT64_C(2717982839), // VAESEM_VV
2367 UINT64_C(2315264119), // VAESKF1_VI
2368 UINT64_C(2852135031), // VAESKF2_VI
2369 UINT64_C(2785255543), // VAESZ_VS
2370 UINT64_C(67108951), // VANDN_VV
2371 UINT64_C(67125335), // VANDN_VX
2372 UINT64_C(603992151), // VAND_VI
2373 UINT64_C(603979863), // VAND_VV
2374 UINT64_C(603996247), // VAND_VX
2375 UINT64_C(671096919), // VASUBU_VV
2376 UINT64_C(671113303), // VASUBU_VX
2377 UINT64_C(738205783), // VASUB_VV
2378 UINT64_C(738222167), // VASUB_VX
2379 UINT64_C(1208229975), // VBREV8_V
2380 UINT64_C(1208295511), // VBREV_V
2381 UINT64_C(872423511), // VCLMULH_VV
2382 UINT64_C(872439895), // VCLMULH_VX
2383 UINT64_C(805314647), // VCLMUL_VV
2384 UINT64_C(805331031), // VCLMUL_VX
2385 UINT64_C(1208361047), // VCLZ_V
2386 UINT64_C(1577066583), // VCOMPRESS_VM
2387 UINT64_C(1074274391), // VCPOP_M
2388 UINT64_C(1208426583), // VCPOP_V
2389 UINT64_C(1208393815), // VCTZ_V
2390 UINT64_C(2147491927), // VDIVU_VV
2391 UINT64_C(2147508311), // VDIVU_VX
2392 UINT64_C(2214600791), // VDIV_VV
2393 UINT64_C(2214617175), // VDIV_VX
2394 UINT64_C(20567), // VFADD_VF
2395 UINT64_C(4183), // VFADD_VV
2396 UINT64_C(1275596887), // VFCLASS_V
2397 UINT64_C(1208029271), // VFCVT_F_XU_V
2398 UINT64_C(1208062039), // VFCVT_F_X_V
2399 UINT64_C(1208160343), // VFCVT_RTZ_XU_F_V
2400 UINT64_C(1208193111), // VFCVT_RTZ_X_F_V
2401 UINT64_C(1207963735), // VFCVT_XU_F_V
2402 UINT64_C(1207996503), // VFCVT_X_F_V
2403 UINT64_C(2147504215), // VFDIV_VF
2404 UINT64_C(2147487831), // VFDIV_VV
2405 UINT64_C(1074307159), // VFIRST_M
2406 UINT64_C(2952810583), // VFMACC_VF
2407 UINT64_C(2952794199), // VFMACC_VV
2408 UINT64_C(2684375127), // VFMADD_VF
2409 UINT64_C(2684358743), // VFMADD_VV
2410 UINT64_C(402673751), // VFMAX_VF
2411 UINT64_C(402657367), // VFMAX_VV
2412 UINT64_C(1543524439), // VFMERGE_VFM
2413 UINT64_C(268456023), // VFMIN_VF
2414 UINT64_C(268439639), // VFMIN_VV
2415 UINT64_C(3087028311), // VFMSAC_VF
2416 UINT64_C(3087011927), // VFMSAC_VV
2417 UINT64_C(2818592855), // VFMSUB_VF
2418 UINT64_C(2818576471), // VFMSUB_VV
2419 UINT64_C(2415939671), // VFMUL_VF
2420 UINT64_C(2415923287), // VFMUL_VV
2421 UINT64_C(1107300439), // VFMV_F_S
2422 UINT64_C(1107316823), // VFMV_S_F
2423 UINT64_C(1577078871), // VFMV_V_F
2424 UINT64_C(1208914007), // VFNCVTBF16_F_F_W
2425 UINT64_C(1208979543), // VFNCVTBF16_SAT_F_F_W
2426 UINT64_C(1208782935), // VFNCVT_F_F_Q
2427 UINT64_C(1208619095), // VFNCVT_F_F_W
2428 UINT64_C(1208553559), // VFNCVT_F_XU_W
2429 UINT64_C(1208586327), // VFNCVT_F_X_W
2430 UINT64_C(1208651863), // VFNCVT_ROD_F_F_W
2431 UINT64_C(1208684631), // VFNCVT_RTZ_XU_F_W
2432 UINT64_C(1208717399), // VFNCVT_RTZ_X_F_W
2433 UINT64_C(1208848471), // VFNCVT_SAT_F_F_Q
2434 UINT64_C(1208488023), // VFNCVT_XU_F_W
2435 UINT64_C(1208520791), // VFNCVT_X_F_W
2436 UINT64_C(3019919447), // VFNMACC_VF
2437 UINT64_C(3019903063), // VFNMACC_VV
2438 UINT64_C(2751483991), // VFNMADD_VF
2439 UINT64_C(2751467607), // VFNMADD_VV
2440 UINT64_C(3154137175), // VFNMSAC_VF
2441 UINT64_C(3154120791), // VFNMSAC_VV
2442 UINT64_C(2885701719), // VFNMSUB_VF
2443 UINT64_C(2885685335), // VFNMSUB_VV
2444 UINT64_C(2214613079), // VFRDIV_VF
2445 UINT64_C(1275236439), // VFREC7_V
2446 UINT64_C(469766231), // VFREDMAX_VS
2447 UINT64_C(335548503), // VFREDMIN_VS
2448 UINT64_C(201330775), // VFREDOSUM_VS
2449 UINT64_C(67113047), // VFREDUSUM_VS
2450 UINT64_C(1275203671), // VFRSQRT7_V
2451 UINT64_C(2617266263), // VFRSUB_VF
2452 UINT64_C(604000343), // VFSGNJN_VF
2453 UINT64_C(603983959), // VFSGNJN_VV
2454 UINT64_C(671109207), // VFSGNJX_VF
2455 UINT64_C(671092823), // VFSGNJX_VV
2456 UINT64_C(536891479), // VFSGNJ_VF
2457 UINT64_C(536875095), // VFSGNJ_VV
2458 UINT64_C(1006653527), // VFSLIDE1DOWN_VF
2459 UINT64_C(939544663), // VFSLIDE1UP_VF
2460 UINT64_C(1275072599), // VFSQRT_V
2461 UINT64_C(134238295), // VFSUB_VF
2462 UINT64_C(134221911), // VFSUB_VV
2463 UINT64_C(3221246039), // VFWADD_VF
2464 UINT64_C(3221229655), // VFWADD_VV
2465 UINT64_C(3489681495), // VFWADD_WF
2466 UINT64_C(3489665111), // VFWADD_WV
2467 UINT64_C(1208389719), // VFWCVTBF16_F_F_V
2468 UINT64_C(1208356951), // VFWCVT_F_F_V
2469 UINT64_C(1208291415), // VFWCVT_F_XU_V
2470 UINT64_C(1208324183), // VFWCVT_F_X_V
2471 UINT64_C(1208422487), // VFWCVT_RTZ_XU_F_V
2472 UINT64_C(1208455255), // VFWCVT_RTZ_X_F_V
2473 UINT64_C(1208225879), // VFWCVT_XU_F_V
2474 UINT64_C(1208258647), // VFWCVT_X_F_V
2475 UINT64_C(3959443543), // VFWMACCBF16_VF
2476 UINT64_C(3959427159), // VFWMACCBF16_VV
2477 UINT64_C(4026552407), // VFWMACC_VF
2478 UINT64_C(4026536023), // VFWMACC_VV
2479 UINT64_C(4160770135), // VFWMSAC_VF
2480 UINT64_C(4160753751), // VFWMSAC_VV
2481 UINT64_C(3758116951), // VFWMUL_VF
2482 UINT64_C(3758100567), // VFWMUL_VV
2483 UINT64_C(4093661271), // VFWNMACC_VF
2484 UINT64_C(4093644887), // VFWNMACC_VV
2485 UINT64_C(4227878999), // VFWNMSAC_VF
2486 UINT64_C(4227862615), // VFWNMSAC_VV
2487 UINT64_C(3422556247), // VFWREDOSUM_VS
2488 UINT64_C(3288338519), // VFWREDUSUM_VS
2489 UINT64_C(3355463767), // VFWSUB_VF
2490 UINT64_C(3355447383), // VFWSUB_VV
2491 UINT64_C(3623899223), // VFWSUB_WF
2492 UINT64_C(3623882839), // VFWSUB_WV
2493 UINT64_C(2382372983), // VGHSH_VS
2494 UINT64_C(2986352759), // VGHSH_VV
2495 UINT64_C(2785583223), // VGMUL_VS
2496 UINT64_C(2718474359), // VGMUL_VV
2497 UINT64_C(1342742615), // VID_V
2498 UINT64_C(1342709847), // VIOTA_M
2499 UINT64_C(41963527), // VL1RE16_V
2500 UINT64_C(41967623), // VL1RE32_V
2501 UINT64_C(41971719), // VL1RE64_V
2502 UINT64_C(41943047), // VL1RE8_V
2503 UINT64_C(578834439), // VL2RE16_V
2504 UINT64_C(578838535), // VL2RE32_V
2505 UINT64_C(578842631), // VL2RE64_V
2506 UINT64_C(578813959), // VL2RE8_V
2507 UINT64_C(1652576263), // VL4RE16_V
2508 UINT64_C(1652580359), // VL4RE32_V
2509 UINT64_C(1652584455), // VL4RE64_V
2510 UINT64_C(1652555783), // VL4RE8_V
2511 UINT64_C(3800059911), // VL8RE16_V
2512 UINT64_C(3800064007), // VL8RE32_V
2513 UINT64_C(3800068103), // VL8RE64_V
2514 UINT64_C(3800039431), // VL8RE8_V
2515 UINT64_C(16797703), // VLE16FF_V
2516 UINT64_C(20487), // VLE16_V
2517 UINT64_C(16801799), // VLE32FF_V
2518 UINT64_C(24583), // VLE32_V
2519 UINT64_C(16805895), // VLE64FF_V
2520 UINT64_C(28679), // VLE64_V
2521 UINT64_C(16777223), // VLE8FF_V
2522 UINT64_C(7), // VLE8_V
2523 UINT64_C(45088775), // VLM_V
2524 UINT64_C(201347079), // VLOXEI16_V
2525 UINT64_C(201351175), // VLOXEI32_V
2526 UINT64_C(201355271), // VLOXEI64_V
2527 UINT64_C(201326599), // VLOXEI8_V
2528 UINT64_C(738217991), // VLOXSEG2EI16_V
2529 UINT64_C(738222087), // VLOXSEG2EI32_V
2530 UINT64_C(738226183), // VLOXSEG2EI64_V
2531 UINT64_C(738197511), // VLOXSEG2EI8_V
2532 UINT64_C(1275088903), // VLOXSEG3EI16_V
2533 UINT64_C(1275092999), // VLOXSEG3EI32_V
2534 UINT64_C(1275097095), // VLOXSEG3EI64_V
2535 UINT64_C(1275068423), // VLOXSEG3EI8_V
2536 UINT64_C(1811959815), // VLOXSEG4EI16_V
2537 UINT64_C(1811963911), // VLOXSEG4EI32_V
2538 UINT64_C(1811968007), // VLOXSEG4EI64_V
2539 UINT64_C(1811939335), // VLOXSEG4EI8_V
2540 UINT64_C(2348830727), // VLOXSEG5EI16_V
2541 UINT64_C(2348834823), // VLOXSEG5EI32_V
2542 UINT64_C(2348838919), // VLOXSEG5EI64_V
2543 UINT64_C(2348810247), // VLOXSEG5EI8_V
2544 UINT64_C(2885701639), // VLOXSEG6EI16_V
2545 UINT64_C(2885705735), // VLOXSEG6EI32_V
2546 UINT64_C(2885709831), // VLOXSEG6EI64_V
2547 UINT64_C(2885681159), // VLOXSEG6EI8_V
2548 UINT64_C(3422572551), // VLOXSEG7EI16_V
2549 UINT64_C(3422576647), // VLOXSEG7EI32_V
2550 UINT64_C(3422580743), // VLOXSEG7EI64_V
2551 UINT64_C(3422552071), // VLOXSEG7EI8_V
2552 UINT64_C(3959443463), // VLOXSEG8EI16_V
2553 UINT64_C(3959447559), // VLOXSEG8EI32_V
2554 UINT64_C(3959451655), // VLOXSEG8EI64_V
2555 UINT64_C(3959422983), // VLOXSEG8EI8_V
2556 UINT64_C(134238215), // VLSE16_V
2557 UINT64_C(134242311), // VLSE32_V
2558 UINT64_C(134246407), // VLSE64_V
2559 UINT64_C(134217735), // VLSE8_V
2560 UINT64_C(553668615), // VLSEG2E16FF_V
2561 UINT64_C(536891399), // VLSEG2E16_V
2562 UINT64_C(553672711), // VLSEG2E32FF_V
2563 UINT64_C(536895495), // VLSEG2E32_V
2564 UINT64_C(553676807), // VLSEG2E64FF_V
2565 UINT64_C(536899591), // VLSEG2E64_V
2566 UINT64_C(553648135), // VLSEG2E8FF_V
2567 UINT64_C(536870919), // VLSEG2E8_V
2568 UINT64_C(1090539527), // VLSEG3E16FF_V
2569 UINT64_C(1073762311), // VLSEG3E16_V
2570 UINT64_C(1090543623), // VLSEG3E32FF_V
2571 UINT64_C(1073766407), // VLSEG3E32_V
2572 UINT64_C(1090547719), // VLSEG3E64FF_V
2573 UINT64_C(1073770503), // VLSEG3E64_V
2574 UINT64_C(1090519047), // VLSEG3E8FF_V
2575 UINT64_C(1073741831), // VLSEG3E8_V
2576 UINT64_C(1627410439), // VLSEG4E16FF_V
2577 UINT64_C(1610633223), // VLSEG4E16_V
2578 UINT64_C(1627414535), // VLSEG4E32FF_V
2579 UINT64_C(1610637319), // VLSEG4E32_V
2580 UINT64_C(1627418631), // VLSEG4E64FF_V
2581 UINT64_C(1610641415), // VLSEG4E64_V
2582 UINT64_C(1627389959), // VLSEG4E8FF_V
2583 UINT64_C(1610612743), // VLSEG4E8_V
2584 UINT64_C(2164281351), // VLSEG5E16FF_V
2585 UINT64_C(2147504135), // VLSEG5E16_V
2586 UINT64_C(2164285447), // VLSEG5E32FF_V
2587 UINT64_C(2147508231), // VLSEG5E32_V
2588 UINT64_C(2164289543), // VLSEG5E64FF_V
2589 UINT64_C(2147512327), // VLSEG5E64_V
2590 UINT64_C(2164260871), // VLSEG5E8FF_V
2591 UINT64_C(2147483655), // VLSEG5E8_V
2592 UINT64_C(2701152263), // VLSEG6E16FF_V
2593 UINT64_C(2684375047), // VLSEG6E16_V
2594 UINT64_C(2701156359), // VLSEG6E32FF_V
2595 UINT64_C(2684379143), // VLSEG6E32_V
2596 UINT64_C(2701160455), // VLSEG6E64FF_V
2597 UINT64_C(2684383239), // VLSEG6E64_V
2598 UINT64_C(2701131783), // VLSEG6E8FF_V
2599 UINT64_C(2684354567), // VLSEG6E8_V
2600 UINT64_C(3238023175), // VLSEG7E16FF_V
2601 UINT64_C(3221245959), // VLSEG7E16_V
2602 UINT64_C(3238027271), // VLSEG7E32FF_V
2603 UINT64_C(3221250055), // VLSEG7E32_V
2604 UINT64_C(3238031367), // VLSEG7E64FF_V
2605 UINT64_C(3221254151), // VLSEG7E64_V
2606 UINT64_C(3238002695), // VLSEG7E8FF_V
2607 UINT64_C(3221225479), // VLSEG7E8_V
2608 UINT64_C(3774894087), // VLSEG8E16FF_V
2609 UINT64_C(3758116871), // VLSEG8E16_V
2610 UINT64_C(3774898183), // VLSEG8E32FF_V
2611 UINT64_C(3758120967), // VLSEG8E32_V
2612 UINT64_C(3774902279), // VLSEG8E64FF_V
2613 UINT64_C(3758125063), // VLSEG8E64_V
2614 UINT64_C(3774873607), // VLSEG8E8FF_V
2615 UINT64_C(3758096391), // VLSEG8E8_V
2616 UINT64_C(671109127), // VLSSEG2E16_V
2617 UINT64_C(671113223), // VLSSEG2E32_V
2618 UINT64_C(671117319), // VLSSEG2E64_V
2619 UINT64_C(671088647), // VLSSEG2E8_V
2620 UINT64_C(1207980039), // VLSSEG3E16_V
2621 UINT64_C(1207984135), // VLSSEG3E32_V
2622 UINT64_C(1207988231), // VLSSEG3E64_V
2623 UINT64_C(1207959559), // VLSSEG3E8_V
2624 UINT64_C(1744850951), // VLSSEG4E16_V
2625 UINT64_C(1744855047), // VLSSEG4E32_V
2626 UINT64_C(1744859143), // VLSSEG4E64_V
2627 UINT64_C(1744830471), // VLSSEG4E8_V
2628 UINT64_C(2281721863), // VLSSEG5E16_V
2629 UINT64_C(2281725959), // VLSSEG5E32_V
2630 UINT64_C(2281730055), // VLSSEG5E64_V
2631 UINT64_C(2281701383), // VLSSEG5E8_V
2632 UINT64_C(2818592775), // VLSSEG6E16_V
2633 UINT64_C(2818596871), // VLSSEG6E32_V
2634 UINT64_C(2818600967), // VLSSEG6E64_V
2635 UINT64_C(2818572295), // VLSSEG6E8_V
2636 UINT64_C(3355463687), // VLSSEG7E16_V
2637 UINT64_C(3355467783), // VLSSEG7E32_V
2638 UINT64_C(3355471879), // VLSSEG7E64_V
2639 UINT64_C(3355443207), // VLSSEG7E8_V
2640 UINT64_C(3892334599), // VLSSEG8E16_V
2641 UINT64_C(3892338695), // VLSSEG8E32_V
2642 UINT64_C(3892342791), // VLSSEG8E64_V
2643 UINT64_C(3892314119), // VLSSEG8E8_V
2644 UINT64_C(67129351), // VLUXEI16_V
2645 UINT64_C(67133447), // VLUXEI32_V
2646 UINT64_C(67137543), // VLUXEI64_V
2647 UINT64_C(67108871), // VLUXEI8_V
2648 UINT64_C(604000263), // VLUXSEG2EI16_V
2649 UINT64_C(604004359), // VLUXSEG2EI32_V
2650 UINT64_C(604008455), // VLUXSEG2EI64_V
2651 UINT64_C(603979783), // VLUXSEG2EI8_V
2652 UINT64_C(1140871175), // VLUXSEG3EI16_V
2653 UINT64_C(1140875271), // VLUXSEG3EI32_V
2654 UINT64_C(1140879367), // VLUXSEG3EI64_V
2655 UINT64_C(1140850695), // VLUXSEG3EI8_V
2656 UINT64_C(1677742087), // VLUXSEG4EI16_V
2657 UINT64_C(1677746183), // VLUXSEG4EI32_V
2658 UINT64_C(1677750279), // VLUXSEG4EI64_V
2659 UINT64_C(1677721607), // VLUXSEG4EI8_V
2660 UINT64_C(2214612999), // VLUXSEG5EI16_V
2661 UINT64_C(2214617095), // VLUXSEG5EI32_V
2662 UINT64_C(2214621191), // VLUXSEG5EI64_V
2663 UINT64_C(2214592519), // VLUXSEG5EI8_V
2664 UINT64_C(2751483911), // VLUXSEG6EI16_V
2665 UINT64_C(2751488007), // VLUXSEG6EI32_V
2666 UINT64_C(2751492103), // VLUXSEG6EI64_V
2667 UINT64_C(2751463431), // VLUXSEG6EI8_V
2668 UINT64_C(3288354823), // VLUXSEG7EI16_V
2669 UINT64_C(3288358919), // VLUXSEG7EI32_V
2670 UINT64_C(3288363015), // VLUXSEG7EI64_V
2671 UINT64_C(3288334343), // VLUXSEG7EI8_V
2672 UINT64_C(3825225735), // VLUXSEG8EI16_V
2673 UINT64_C(3825229831), // VLUXSEG8EI32_V
2674 UINT64_C(3825233927), // VLUXSEG8EI64_V
2675 UINT64_C(3825205255), // VLUXSEG8EI8_V
2676 UINT64_C(3019907159), // VMACC_VV
2677 UINT64_C(3019923543), // VMACC_VX
2678 UINT64_C(1174417495), // VMADC_VI
2679 UINT64_C(1140863063), // VMADC_VIM
2680 UINT64_C(1174405207), // VMADC_VV
2681 UINT64_C(1140850775), // VMADC_VVM
2682 UINT64_C(1174421591), // VMADC_VX
2683 UINT64_C(1140867159), // VMADC_VXM
2684 UINT64_C(2751471703), // VMADD_VV
2685 UINT64_C(2751488087), // VMADD_VX
2686 UINT64_C(1644175447), // VMANDN_MM
2687 UINT64_C(1711284311), // VMAND_MM
2688 UINT64_C(402653271), // VMAXU_VV
2689 UINT64_C(402669655), // VMAXU_VX
2690 UINT64_C(469762135), // VMAX_VV
2691 UINT64_C(469778519), // VMAX_VX
2692 UINT64_C(1543516247), // VMERGE_VIM
2693 UINT64_C(1543503959), // VMERGE_VVM
2694 UINT64_C(1543520343), // VMERGE_VXM
2695 UINT64_C(1610633303), // VMFEQ_VF
2696 UINT64_C(1610616919), // VMFEQ_VV
2697 UINT64_C(2080395351), // VMFGE_VF
2698 UINT64_C(1946177623), // VMFGT_VF
2699 UINT64_C(1677742167), // VMFLE_VF
2700 UINT64_C(1677725783), // VMFLE_VV
2701 UINT64_C(1811959895), // VMFLT_VF
2702 UINT64_C(1811943511), // VMFLT_VV
2703 UINT64_C(1879068759), // VMFNE_VF
2704 UINT64_C(1879052375), // VMFNE_VV
2705 UINT64_C(268435543), // VMINU_VV
2706 UINT64_C(268451927), // VMINU_VX
2707 UINT64_C(335544407), // VMIN_VV
2708 UINT64_C(335560791), // VMIN_VX
2709 UINT64_C(1979719767), // VMNAND_MM
2710 UINT64_C(2046828631), // VMNOR_MM
2711 UINT64_C(1912610903), // VMORN_MM
2712 UINT64_C(1778393175), // VMOR_MM
2713 UINT64_C(1308622935), // VMSBC_VV
2714 UINT64_C(1275068503), // VMSBC_VVM
2715 UINT64_C(1308639319), // VMSBC_VX
2716 UINT64_C(1275084887), // VMSBC_VXM
2717 UINT64_C(1342218327), // VMSBF_M
2718 UINT64_C(1610625111), // VMSEQ_VI
2719 UINT64_C(1610612823), // VMSEQ_VV
2720 UINT64_C(1610629207), // VMSEQ_VX
2721 UINT64_C(2013278295), // VMSGTU_VI
2722 UINT64_C(2013282391), // VMSGTU_VX
2723 UINT64_C(2080387159), // VMSGT_VI
2724 UINT64_C(2080391255), // VMSGT_VX
2725 UINT64_C(1342283863), // VMSIF_M
2726 UINT64_C(1879060567), // VMSLEU_VI
2727 UINT64_C(1879048279), // VMSLEU_VV
2728 UINT64_C(1879064663), // VMSLEU_VX
2729 UINT64_C(1946169431), // VMSLE_VI
2730 UINT64_C(1946157143), // VMSLE_VV
2731 UINT64_C(1946173527), // VMSLE_VX
2732 UINT64_C(1744830551), // VMSLTU_VV
2733 UINT64_C(1744846935), // VMSLTU_VX
2734 UINT64_C(1811939415), // VMSLT_VV
2735 UINT64_C(1811955799), // VMSLT_VX
2736 UINT64_C(1677733975), // VMSNE_VI
2737 UINT64_C(1677721687), // VMSNE_VV
2738 UINT64_C(1677738071), // VMSNE_VX
2739 UINT64_C(1342251095), // VMSOF_M
2740 UINT64_C(2550145111), // VMULHSU_VV
2741 UINT64_C(2550161495), // VMULHSU_VX
2742 UINT64_C(2415927383), // VMULHU_VV
2743 UINT64_C(2415943767), // VMULHU_VX
2744 UINT64_C(2617253975), // VMULH_VV
2745 UINT64_C(2617270359), // VMULH_VX
2746 UINT64_C(2483036247), // VMUL_VV
2747 UINT64_C(2483052631), // VMUL_VX
2748 UINT64_C(2650812503), // VMV1R_V
2749 UINT64_C(2650845271), // VMV2R_V
2750 UINT64_C(2650910807), // VMV4R_V
2751 UINT64_C(2651041879), // VMV8R_V
2752 UINT64_C(1107320919), // VMV_S_X
2753 UINT64_C(1577070679), // VMV_V_I
2754 UINT64_C(1577058391), // VMV_V_V
2755 UINT64_C(1577074775), // VMV_V_X
2756 UINT64_C(1107304535), // VMV_X_S
2757 UINT64_C(2113937495), // VMXNOR_MM
2758 UINT64_C(1845502039), // VMXOR_MM
2759 UINT64_C(3087020119), // VNCLIPU_WI
2760 UINT64_C(3087007831), // VNCLIPU_WV
2761 UINT64_C(3087024215), // VNCLIPU_WX
2762 UINT64_C(3154128983), // VNCLIP_WI
2763 UINT64_C(3154116695), // VNCLIP_WV
2764 UINT64_C(3154133079), // VNCLIP_WX
2765 UINT64_C(3154124887), // VNMSAC_VV
2766 UINT64_C(3154141271), // VNMSAC_VX
2767 UINT64_C(2885689431), // VNMSUB_VV
2768 UINT64_C(2885705815), // VNMSUB_VX
2769 UINT64_C(3019911255), // VNSRA_WI
2770 UINT64_C(3019898967), // VNSRA_WV
2771 UINT64_C(3019915351), // VNSRA_WX
2772 UINT64_C(2952802391), // VNSRL_WI
2773 UINT64_C(2952790103), // VNSRL_WV
2774 UINT64_C(2952806487), // VNSRL_WX
2775 UINT64_C(671101015), // VOR_VI
2776 UINT64_C(671088727), // VOR_VV
2777 UINT64_C(671105111), // VOR_VX
2778 UINT64_C(2818580567), // VQDOTSU_VV
2779 UINT64_C(2818596951), // VQDOTSU_VX
2780 UINT64_C(3087032407), // VQDOTUS_VX
2781 UINT64_C(2684362839), // VQDOTU_VV
2782 UINT64_C(2684379223), // VQDOTU_VX
2783 UINT64_C(2952798295), // VQDOT_VV
2784 UINT64_C(2952814679), // VQDOT_VX
2785 UINT64_C(67117143), // VREDAND_VS
2786 UINT64_C(402661463), // VREDMAXU_VS
2787 UINT64_C(469770327), // VREDMAX_VS
2788 UINT64_C(268443735), // VREDMINU_VS
2789 UINT64_C(335552599), // VREDMIN_VS
2790 UINT64_C(134226007), // VREDOR_VS
2791 UINT64_C(8279), // VREDSUM_VS
2792 UINT64_C(201334871), // VREDXOR_VS
2793 UINT64_C(2281709655), // VREMU_VV
2794 UINT64_C(2281726039), // VREMU_VX
2795 UINT64_C(2348818519), // VREM_VV
2796 UINT64_C(2348834903), // VREM_VX
2797 UINT64_C(1208262743), // VREV8_V
2798 UINT64_C(939524183), // VRGATHEREI16_VV
2799 UINT64_C(805318743), // VRGATHER_VI
2800 UINT64_C(805306455), // VRGATHER_VV
2801 UINT64_C(805322839), // VRGATHER_VX
2802 UINT64_C(1409286231), // VROL_VV
2803 UINT64_C(1409302615), // VROL_VX
2804 UINT64_C(1342189655), // VROR_VI
2805 UINT64_C(1342177367), // VROR_VV
2806 UINT64_C(1342193751), // VROR_VX
2807 UINT64_C(201338967), // VRSUB_VI
2808 UINT64_C(201343063), // VRSUB_VX
2809 UINT64_C(41943079), // VS1R_V
2810 UINT64_C(578813991), // VS2R_V
2811 UINT64_C(1652555815), // VS4R_V
2812 UINT64_C(3800039463), // VS8R_V
2813 UINT64_C(2147496023), // VSADDU_VI
2814 UINT64_C(2147483735), // VSADDU_VV
2815 UINT64_C(2147500119), // VSADDU_VX
2816 UINT64_C(2214604887), // VSADD_VI
2817 UINT64_C(2214592599), // VSADD_VV
2818 UINT64_C(2214608983), // VSADD_VX
2819 UINT64_C(1207959639), // VSBC_VVM
2820 UINT64_C(1207976023), // VSBC_VXM
2821 UINT64_C(20519), // VSE16_V
2822 UINT64_C(24615), // VSE32_V
2823 UINT64_C(28711), // VSE64_V
2824 UINT64_C(39), // VSE8_V
2825 UINT64_C(3221254231), // VSETIVLI
2826 UINT64_C(2147512407), // VSETVL
2827 UINT64_C(28759), // VSETVLI
2828 UINT64_C(1208197207), // VSEXT_VF2
2829 UINT64_C(1208131671), // VSEXT_VF4
2830 UINT64_C(1208066135), // VSEXT_VF8
2831 UINT64_C(3120570487), // VSHA2CH_VV
2832 UINT64_C(3187679351), // VSHA2CL_VV
2833 UINT64_C(3053461623), // VSHA2MS_VV
2834 UINT64_C(1006657623), // VSLIDE1DOWN_VX
2835 UINT64_C(939548759), // VSLIDE1UP_VX
2836 UINT64_C(1006645335), // VSLIDEDOWN_VI
2837 UINT64_C(1006649431), // VSLIDEDOWN_VX
2838 UINT64_C(939536471), // VSLIDEUP_VI
2839 UINT64_C(939540567), // VSLIDEUP_VX
2840 UINT64_C(2483040343), // VSLL_VI
2841 UINT64_C(2483028055), // VSLL_VV
2842 UINT64_C(2483044439), // VSLL_VX
2843 UINT64_C(2919243895), // VSM3C_VI
2844 UINT64_C(2181046391), // VSM3ME_VV
2845 UINT64_C(2248155255), // VSM4K_VI
2846 UINT64_C(2785550455), // VSM4R_VS
2847 UINT64_C(2718441591), // VSM4R_VV
2848 UINT64_C(2617245783), // VSMUL_VV
2849 UINT64_C(2617262167), // VSMUL_VX
2850 UINT64_C(45088807), // VSM_V
2851 UINT64_C(201347111), // VSOXEI16_V
2852 UINT64_C(201351207), // VSOXEI32_V
2853 UINT64_C(201355303), // VSOXEI64_V
2854 UINT64_C(201326631), // VSOXEI8_V
2855 UINT64_C(738218023), // VSOXSEG2EI16_V
2856 UINT64_C(738222119), // VSOXSEG2EI32_V
2857 UINT64_C(738226215), // VSOXSEG2EI64_V
2858 UINT64_C(738197543), // VSOXSEG2EI8_V
2859 UINT64_C(1275088935), // VSOXSEG3EI16_V
2860 UINT64_C(1275093031), // VSOXSEG3EI32_V
2861 UINT64_C(1275097127), // VSOXSEG3EI64_V
2862 UINT64_C(1275068455), // VSOXSEG3EI8_V
2863 UINT64_C(1811959847), // VSOXSEG4EI16_V
2864 UINT64_C(1811963943), // VSOXSEG4EI32_V
2865 UINT64_C(1811968039), // VSOXSEG4EI64_V
2866 UINT64_C(1811939367), // VSOXSEG4EI8_V
2867 UINT64_C(2348830759), // VSOXSEG5EI16_V
2868 UINT64_C(2348834855), // VSOXSEG5EI32_V
2869 UINT64_C(2348838951), // VSOXSEG5EI64_V
2870 UINT64_C(2348810279), // VSOXSEG5EI8_V
2871 UINT64_C(2885701671), // VSOXSEG6EI16_V
2872 UINT64_C(2885705767), // VSOXSEG6EI32_V
2873 UINT64_C(2885709863), // VSOXSEG6EI64_V
2874 UINT64_C(2885681191), // VSOXSEG6EI8_V
2875 UINT64_C(3422572583), // VSOXSEG7EI16_V
2876 UINT64_C(3422576679), // VSOXSEG7EI32_V
2877 UINT64_C(3422580775), // VSOXSEG7EI64_V
2878 UINT64_C(3422552103), // VSOXSEG7EI8_V
2879 UINT64_C(3959443495), // VSOXSEG8EI16_V
2880 UINT64_C(3959447591), // VSOXSEG8EI32_V
2881 UINT64_C(3959451687), // VSOXSEG8EI64_V
2882 UINT64_C(3959423015), // VSOXSEG8EI8_V
2883 UINT64_C(2751475799), // VSRA_VI
2884 UINT64_C(2751463511), // VSRA_VV
2885 UINT64_C(2751479895), // VSRA_VX
2886 UINT64_C(2684366935), // VSRL_VI
2887 UINT64_C(2684354647), // VSRL_VV
2888 UINT64_C(2684371031), // VSRL_VX
2889 UINT64_C(134238247), // VSSE16_V
2890 UINT64_C(134242343), // VSSE32_V
2891 UINT64_C(134246439), // VSSE64_V
2892 UINT64_C(134217767), // VSSE8_V
2893 UINT64_C(536891431), // VSSEG2E16_V
2894 UINT64_C(536895527), // VSSEG2E32_V
2895 UINT64_C(536899623), // VSSEG2E64_V
2896 UINT64_C(536870951), // VSSEG2E8_V
2897 UINT64_C(1073762343), // VSSEG3E16_V
2898 UINT64_C(1073766439), // VSSEG3E32_V
2899 UINT64_C(1073770535), // VSSEG3E64_V
2900 UINT64_C(1073741863), // VSSEG3E8_V
2901 UINT64_C(1610633255), // VSSEG4E16_V
2902 UINT64_C(1610637351), // VSSEG4E32_V
2903 UINT64_C(1610641447), // VSSEG4E64_V
2904 UINT64_C(1610612775), // VSSEG4E8_V
2905 UINT64_C(2147504167), // VSSEG5E16_V
2906 UINT64_C(2147508263), // VSSEG5E32_V
2907 UINT64_C(2147512359), // VSSEG5E64_V
2908 UINT64_C(2147483687), // VSSEG5E8_V
2909 UINT64_C(2684375079), // VSSEG6E16_V
2910 UINT64_C(2684379175), // VSSEG6E32_V
2911 UINT64_C(2684383271), // VSSEG6E64_V
2912 UINT64_C(2684354599), // VSSEG6E8_V
2913 UINT64_C(3221245991), // VSSEG7E16_V
2914 UINT64_C(3221250087), // VSSEG7E32_V
2915 UINT64_C(3221254183), // VSSEG7E64_V
2916 UINT64_C(3221225511), // VSSEG7E8_V
2917 UINT64_C(3758116903), // VSSEG8E16_V
2918 UINT64_C(3758120999), // VSSEG8E32_V
2919 UINT64_C(3758125095), // VSSEG8E64_V
2920 UINT64_C(3758096423), // VSSEG8E8_V
2921 UINT64_C(2885693527), // VSSRA_VI
2922 UINT64_C(2885681239), // VSSRA_VV
2923 UINT64_C(2885697623), // VSSRA_VX
2924 UINT64_C(2818584663), // VSSRL_VI
2925 UINT64_C(2818572375), // VSSRL_VV
2926 UINT64_C(2818588759), // VSSRL_VX
2927 UINT64_C(671109159), // VSSSEG2E16_V
2928 UINT64_C(671113255), // VSSSEG2E32_V
2929 UINT64_C(671117351), // VSSSEG2E64_V
2930 UINT64_C(671088679), // VSSSEG2E8_V
2931 UINT64_C(1207980071), // VSSSEG3E16_V
2932 UINT64_C(1207984167), // VSSSEG3E32_V
2933 UINT64_C(1207988263), // VSSSEG3E64_V
2934 UINT64_C(1207959591), // VSSSEG3E8_V
2935 UINT64_C(1744850983), // VSSSEG4E16_V
2936 UINT64_C(1744855079), // VSSSEG4E32_V
2937 UINT64_C(1744859175), // VSSSEG4E64_V
2938 UINT64_C(1744830503), // VSSSEG4E8_V
2939 UINT64_C(2281721895), // VSSSEG5E16_V
2940 UINT64_C(2281725991), // VSSSEG5E32_V
2941 UINT64_C(2281730087), // VSSSEG5E64_V
2942 UINT64_C(2281701415), // VSSSEG5E8_V
2943 UINT64_C(2818592807), // VSSSEG6E16_V
2944 UINT64_C(2818596903), // VSSSEG6E32_V
2945 UINT64_C(2818600999), // VSSSEG6E64_V
2946 UINT64_C(2818572327), // VSSSEG6E8_V
2947 UINT64_C(3355463719), // VSSSEG7E16_V
2948 UINT64_C(3355467815), // VSSSEG7E32_V
2949 UINT64_C(3355471911), // VSSSEG7E64_V
2950 UINT64_C(3355443239), // VSSSEG7E8_V
2951 UINT64_C(3892334631), // VSSSEG8E16_V
2952 UINT64_C(3892338727), // VSSSEG8E32_V
2953 UINT64_C(3892342823), // VSSSEG8E64_V
2954 UINT64_C(3892314151), // VSSSEG8E8_V
2955 UINT64_C(2281701463), // VSSUBU_VV
2956 UINT64_C(2281717847), // VSSUBU_VX
2957 UINT64_C(2348810327), // VSSUB_VV
2958 UINT64_C(2348826711), // VSSUB_VX
2959 UINT64_C(134217815), // VSUB_VV
2960 UINT64_C(134234199), // VSUB_VX
2961 UINT64_C(67129383), // VSUXEI16_V
2962 UINT64_C(67133479), // VSUXEI32_V
2963 UINT64_C(67137575), // VSUXEI64_V
2964 UINT64_C(67108903), // VSUXEI8_V
2965 UINT64_C(604000295), // VSUXSEG2EI16_V
2966 UINT64_C(604004391), // VSUXSEG2EI32_V
2967 UINT64_C(604008487), // VSUXSEG2EI64_V
2968 UINT64_C(603979815), // VSUXSEG2EI8_V
2969 UINT64_C(1140871207), // VSUXSEG3EI16_V
2970 UINT64_C(1140875303), // VSUXSEG3EI32_V
2971 UINT64_C(1140879399), // VSUXSEG3EI64_V
2972 UINT64_C(1140850727), // VSUXSEG3EI8_V
2973 UINT64_C(1677742119), // VSUXSEG4EI16_V
2974 UINT64_C(1677746215), // VSUXSEG4EI32_V
2975 UINT64_C(1677750311), // VSUXSEG4EI64_V
2976 UINT64_C(1677721639), // VSUXSEG4EI8_V
2977 UINT64_C(2214613031), // VSUXSEG5EI16_V
2978 UINT64_C(2214617127), // VSUXSEG5EI32_V
2979 UINT64_C(2214621223), // VSUXSEG5EI64_V
2980 UINT64_C(2214592551), // VSUXSEG5EI8_V
2981 UINT64_C(2751483943), // VSUXSEG6EI16_V
2982 UINT64_C(2751488039), // VSUXSEG6EI32_V
2983 UINT64_C(2751492135), // VSUXSEG6EI64_V
2984 UINT64_C(2751463463), // VSUXSEG6EI8_V
2985 UINT64_C(3288354855), // VSUXSEG7EI16_V
2986 UINT64_C(3288358951), // VSUXSEG7EI32_V
2987 UINT64_C(3288363047), // VSUXSEG7EI64_V
2988 UINT64_C(3288334375), // VSUXSEG7EI8_V
2989 UINT64_C(3825225767), // VSUXSEG8EI16_V
2990 UINT64_C(3825229863), // VSUXSEG8EI32_V
2991 UINT64_C(3825233959), // VSUXSEG8EI64_V
2992 UINT64_C(3825205287), // VSUXSEG8EI8_V
2993 UINT64_C(24699), // VT_MASKC
2994 UINT64_C(28795), // VT_MASKCN
2995 UINT64_C(3221233751), // VWADDU_VV
2996 UINT64_C(3221250135), // VWADDU_VX
2997 UINT64_C(3489669207), // VWADDU_WV
2998 UINT64_C(3489685591), // VWADDU_WX
2999 UINT64_C(3288342615), // VWADD_VV
3000 UINT64_C(3288358999), // VWADD_VX
3001 UINT64_C(3556778071), // VWADD_WV
3002 UINT64_C(3556794455), // VWADD_WX
3003 UINT64_C(4227866711), // VWMACCSU_VV
3004 UINT64_C(4227883095), // VWMACCSU_VX
3005 UINT64_C(4160774231), // VWMACCUS_VX
3006 UINT64_C(4026540119), // VWMACCU_VV
3007 UINT64_C(4026556503), // VWMACCU_VX
3008 UINT64_C(4093648983), // VWMACC_VV
3009 UINT64_C(4093665367), // VWMACC_VX
3010 UINT64_C(3892322391), // VWMULSU_VV
3011 UINT64_C(3892338775), // VWMULSU_VX
3012 UINT64_C(3758104663), // VWMULU_VV
3013 UINT64_C(3758121047), // VWMULU_VX
3014 UINT64_C(3959431255), // VWMUL_VV
3015 UINT64_C(3959447639), // VWMUL_VX
3016 UINT64_C(3221225559), // VWREDSUMU_VS
3017 UINT64_C(3288334423), // VWREDSUM_VS
3018 UINT64_C(3556782167), // VWSLL_VI
3019 UINT64_C(3556769879), // VWSLL_VV
3020 UINT64_C(3556786263), // VWSLL_VX
3021 UINT64_C(3355451479), // VWSUBU_VV
3022 UINT64_C(3355467863), // VWSUBU_VX
3023 UINT64_C(3623886935), // VWSUBU_WV
3024 UINT64_C(3623903319), // VWSUBU_WX
3025 UINT64_C(3422560343), // VWSUB_VV
3026 UINT64_C(3422576727), // VWSUB_VX
3027 UINT64_C(3690995799), // VWSUB_WV
3028 UINT64_C(3691012183), // VWSUB_WX
3029 UINT64_C(738209879), // VXOR_VI
3030 UINT64_C(738197591), // VXOR_VV
3031 UINT64_C(738213975), // VXOR_VX
3032 UINT64_C(1208164439), // VZEXT_VF2
3033 UINT64_C(1208098903), // VZEXT_VF4
3034 UINT64_C(1208033367), // VZEXT_VF8
3035 UINT64_C(33562779), // WADD
3036 UINT64_C(167780507), // WADDA
3037 UINT64_C(436215963), // WADDAU
3038 UINT64_C(301998235), // WADDU
3039 UINT64_C(273678451), // WFI
3040 UINT64_C(704651419), // WMACC
3041 UINT64_C(1778393243), // WMACCSU
3042 UINT64_C(973086875), // WMACCU
3043 UINT64_C(570433691), // WMUL
3044 UINT64_C(1644175515), // WMULSU
3045 UINT64_C(838869147), // WMULU
3046 UINT64_C(13631603), // WRS_NTO
3047 UINT64_C(30408819), // WRS_STO
3048 UINT64_C(1308631067), // WSLA
3049 UINT64_C(1140858907), // WSLAI
3050 UINT64_C(234889243), // WSLL
3051 UINT64_C(67117083), // WSLLI
3052 UINT64_C(1107304603), // WSUB
3053 UINT64_C(1241522331), // WSUBA
3054 UINT64_C(1509957787), // WSUBAU
3055 UINT64_C(1375740059), // WSUBU
3056 UINT64_C(2046828571), // WZIP16P
3057 UINT64_C(2013274139), // WZIP8P
3058 UINT64_C(1073758259), // XNOR
3059 UINT64_C(16435), // XOR
3060 UINT64_C(16403), // XORI
3061 UINT64_C(671096883), // XPERM4
3062 UINT64_C(671105075), // XPERM8
3063 UINT64_C(134234163), // ZEXT_H_RV32
3064 UINT64_C(134234171), // ZEXT_H_RV64
3065 UINT64_C(4127203387), // ZIP16HP
3066 UINT64_C(4060094523), // ZIP16P
3067 UINT64_C(4093648955), // ZIP8HP
3068 UINT64_C(4026540091), // ZIP8P
3069 UINT64_C(149950483), // ZIP_RV32
3070 };
3071 constexpr unsigned FirstSupportedOpcode = 13662;
3072
3073 const unsigned opcode = MI.getOpcode();
3074 if (opcode < FirstSupportedOpcode)
3075 reportUnsupportedInst(Inst: MI);
3076 unsigned TableIndex = opcode - FirstSupportedOpcode;
3077 uint64_t Value = InstBits[TableIndex];
3078 uint64_t op = 0;
3079 (void)op; // suppress warning
3080 switch (opcode) {
3081 case RISCV::C_EBREAK:
3082 case RISCV::C_MOP_11:
3083 case RISCV::C_MOP_13:
3084 case RISCV::C_MOP_15:
3085 case RISCV::C_MOP_3:
3086 case RISCV::C_MOP_7:
3087 case RISCV::C_MOP_9:
3088 case RISCV::C_NOP:
3089 case RISCV::C_SSPOPCHK:
3090 case RISCV::C_SSPUSH:
3091 case RISCV::C_UNIMP:
3092 case RISCV::DRET:
3093 case RISCV::EBREAK:
3094 case RISCV::ECALL:
3095 case RISCV::FENCE_I:
3096 case RISCV::FENCE_TSO:
3097 case RISCV::MIPS_EHB:
3098 case RISCV::MIPS_IHB:
3099 case RISCV::MIPS_PAUSE:
3100 case RISCV::MNRET:
3101 case RISCV::MRET:
3102 case RISCV::QC_C_DI:
3103 case RISCV::QC_C_EI:
3104 case RISCV::QC_C_MIENTER:
3105 case RISCV::QC_C_MIENTER_NEST:
3106 case RISCV::QC_C_MILEAVERET:
3107 case RISCV::QC_C_MNRET:
3108 case RISCV::QC_C_MRET:
3109 case RISCV::SCTRCLR:
3110 case RISCV::SFENCE_INVAL_IR:
3111 case RISCV::SFENCE_W_INVAL:
3112 case RISCV::SF_CEASE:
3113 case RISCV::SF_VTDISCARD:
3114 case RISCV::SRET:
3115 case RISCV::TH_DCACHE_CALL:
3116 case RISCV::TH_DCACHE_CIALL:
3117 case RISCV::TH_DCACHE_IALL:
3118 case RISCV::TH_ICACHE_IALL:
3119 case RISCV::TH_ICACHE_IALLS:
3120 case RISCV::TH_L2CACHE_CALL:
3121 case RISCV::TH_L2CACHE_CIALL:
3122 case RISCV::TH_L2CACHE_IALL:
3123 case RISCV::TH_SYNC:
3124 case RISCV::TH_SYNC_I:
3125 case RISCV::TH_SYNC_IS:
3126 case RISCV::TH_SYNC_S:
3127 case RISCV::UNIMP:
3128 case RISCV::WFI:
3129 case RISCV::WRS_NTO:
3130 case RISCV::WRS_STO: {
3131 break;
3132 }
3133 case RISCV::AIF_FSWG_PS:
3134 case RISCV::AIF_FSWL_PS: {
3135 // op: fs3
3136 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3137 Value |= (op & 0x1f) << 7;
3138 // op: rs1
3139 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3140 Value |= (op & 0x1f) << 15;
3141 break;
3142 }
3143 case RISCV::C_NOP_HINT: {
3144 // op: imm
3145 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3146 Value |= (op & 0x20) << 7;
3147 Value |= (op & 0x1f) << 2;
3148 break;
3149 }
3150 case RISCV::C_LI:
3151 case RISCV::C_LUI: {
3152 // op: imm
3153 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3154 Value |= (op & 0x20) << 7;
3155 Value |= (op & 0x1f) << 2;
3156 // op: rd
3157 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3158 Value |= (op & 0x1f) << 7;
3159 break;
3160 }
3161 case RISCV::RI_VEXTRACT: {
3162 // op: imm
3163 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3164 Value |= (op & 0x1f) << 15;
3165 // op: vs2
3166 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3167 Value |= (op & 0x1f) << 20;
3168 // op: rd
3169 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3170 Value |= (op & 0x1f) << 7;
3171 break;
3172 }
3173 case RISCV::AIF_FSLLI_PI:
3174 case RISCV::AIF_FSRAI_PI:
3175 case RISCV::AIF_FSRLI_PI: {
3176 // op: imm
3177 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3178 Value |= (op & 0x1f) << 20;
3179 // op: rs1
3180 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3181 Value |= (op & 0x1f) << 15;
3182 // op: rd
3183 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3184 Value |= (op & 0x1f) << 7;
3185 break;
3186 }
3187 case RISCV::C_FLDSP:
3188 case RISCV::C_LDSP:
3189 case RISCV::C_LDSP_RV32: {
3190 // op: imm
3191 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3192 Value |= (op & 0x20) << 7;
3193 Value |= (op & 0x18) << 2;
3194 Value |= (op & 0x1c0) >> 4;
3195 // op: rd
3196 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3197 Value |= (op & 0x1f) << 7;
3198 break;
3199 }
3200 case RISCV::C_FLWSP:
3201 case RISCV::C_LWSP:
3202 case RISCV::C_LWSP_INX: {
3203 // op: imm
3204 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3205 Value |= (op & 0x20) << 7;
3206 Value |= (op & 0x1c) << 2;
3207 Value |= (op & 0xc0) >> 4;
3208 // op: rd
3209 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3210 Value |= (op & 0x1f) << 7;
3211 break;
3212 }
3213 case RISCV::C_ADDI:
3214 case RISCV::C_ADDIW: {
3215 // op: imm
3216 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3217 Value |= (op & 0x20) << 7;
3218 Value |= (op & 0x1f) << 2;
3219 // op: rd
3220 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3221 Value |= (op & 0x1f) << 7;
3222 break;
3223 }
3224 case RISCV::C_ANDI: {
3225 // op: imm
3226 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3227 Value |= (op & 0x20) << 7;
3228 Value |= (op & 0x1f) << 2;
3229 // op: rs1
3230 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3231 Value |= (op & 0x7) << 7;
3232 break;
3233 }
3234 case RISCV::C_ADDI16SP: {
3235 // op: imm
3236 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3237 Value |= (op & 0x200) << 3;
3238 Value |= (op & 0x10) << 2;
3239 Value |= (op & 0x40) >> 1;
3240 Value |= (op & 0x180) >> 4;
3241 Value |= (op & 0x20) >> 3;
3242 break;
3243 }
3244 case RISCV::C_ADDI4SPN: {
3245 // op: imm
3246 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3247 Value |= (op & 0x30) << 7;
3248 Value |= (op & 0x3c0) << 1;
3249 Value |= (op & 0x4) << 4;
3250 Value |= (op & 0x8) << 2;
3251 // op: rd
3252 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3253 Value |= (op & 0x7) << 2;
3254 break;
3255 }
3256 case RISCV::C_FSDSP:
3257 case RISCV::C_SDSP:
3258 case RISCV::C_SDSP_RV32: {
3259 // op: imm
3260 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3261 Value |= (op & 0x38) << 7;
3262 Value |= (op & 0x1c0) << 1;
3263 // op: rs2
3264 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3265 Value |= (op & 0x1f) << 2;
3266 break;
3267 }
3268 case RISCV::C_FSWSP:
3269 case RISCV::C_SWSP:
3270 case RISCV::C_SWSP_INX: {
3271 // op: imm
3272 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3273 Value |= (op & 0x3c) << 7;
3274 Value |= (op & 0xc0) << 1;
3275 // op: rs2
3276 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3277 Value |= (op & 0x1f) << 2;
3278 break;
3279 }
3280 case RISCV::AIF_FADDI_PI:
3281 case RISCV::AIF_FANDI_PI: {
3282 // op: imm
3283 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3284 Value |= (op & 0x3e0) << 22;
3285 Value |= (op & 0x1f) << 20;
3286 // op: rs1
3287 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3288 Value |= (op & 0x1f) << 15;
3289 // op: rd
3290 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3291 Value |= (op & 0x1f) << 7;
3292 break;
3293 }
3294 case RISCV::AIF_MOV_M_X: {
3295 // op: imm
3296 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3297 Value |= (op & 0xf8) << 17;
3298 Value |= (op & 0x7) << 12;
3299 // op: rs1
3300 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3301 Value |= (op & 0x1f) << 15;
3302 // op: rd
3303 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3304 Value |= (op & 0x7) << 7;
3305 break;
3306 }
3307 case RISCV::RI_VINSERT: {
3308 // op: imm
3309 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3310 Value |= (op & 0x1f) << 20;
3311 // op: rs1
3312 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3313 Value |= (op & 0x1f) << 15;
3314 // op: vd
3315 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3316 Value |= (op & 0x1f) << 7;
3317 break;
3318 }
3319 case RISCV::AIF_MASKPOPC_ET_RAST: {
3320 // op: imm
3321 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3322 Value |= (op & 0xc) << 21;
3323 Value |= (op & 0x3) << 18;
3324 // op: rs2
3325 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3326 Value |= (op & 0x7) << 20;
3327 // op: rs1
3328 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3329 Value |= (op & 0x7) << 15;
3330 // op: rd
3331 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3332 Value |= (op & 0x1f) << 7;
3333 break;
3334 }
3335 case RISCV::C_BEQZ:
3336 case RISCV::C_BNEZ: {
3337 // op: imm
3338 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3339 Value |= (op & 0x80) << 5;
3340 Value |= (op & 0xc) << 8;
3341 Value |= (op & 0x60);
3342 Value |= (op & 0x3) << 3;
3343 Value |= (op & 0x10) >> 2;
3344 // op: rs1
3345 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3346 Value |= (op & 0x7) << 7;
3347 break;
3348 }
3349 case RISCV::C_SLLI: {
3350 // op: imm
3351 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3352 Value |= (op & 0x20) << 7;
3353 Value |= (op & 0x1f) << 2;
3354 // op: rd
3355 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3356 Value |= (op & 0x1f) << 7;
3357 break;
3358 }
3359 case RISCV::C_SRAI:
3360 case RISCV::C_SRLI: {
3361 // op: imm
3362 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3363 Value |= (op & 0x20) << 7;
3364 Value |= (op & 0x1f) << 2;
3365 // op: rs1
3366 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3367 Value |= (op & 0x7) << 7;
3368 break;
3369 }
3370 case RISCV::QC_CLRINTI:
3371 case RISCV::QC_SETINTI: {
3372 // op: imm10
3373 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3374 Value |= (op & 0x3ff) << 15;
3375 break;
3376 }
3377 case RISCV::NDS_BEQC:
3378 case RISCV::NDS_BNEC: {
3379 // op: imm10
3380 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3381 Value |= (op & 0x200) << 22;
3382 Value |= (op & 0x1f0) << 21;
3383 Value |= (op & 0xf) << 8;
3384 // op: rs1
3385 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3386 Value |= (op & 0x1f) << 15;
3387 // op: cimm
3388 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3389 Value |= (op & 0x40) << 24;
3390 Value |= (op & 0x1f) << 20;
3391 Value |= (op & 0x20) << 2;
3392 break;
3393 }
3394 case RISCV::NDS_BBC:
3395 case RISCV::NDS_BBS: {
3396 // op: imm10
3397 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3398 Value |= (op & 0x200) << 22;
3399 Value |= (op & 0x1f0) << 21;
3400 Value |= (op & 0xf) << 8;
3401 // op: rs1
3402 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3403 Value |= (op & 0x1f) << 15;
3404 // op: cimm
3405 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3406 Value |= (op & 0x1f) << 20;
3407 Value |= (op & 0x20) << 2;
3408 break;
3409 }
3410 case RISCV::PREFETCH_I:
3411 case RISCV::PREFETCH_R:
3412 case RISCV::PREFETCH_W: {
3413 // op: imm12
3414 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3415 Value |= (op & 0xfe0) << 20;
3416 // op: rs1
3417 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3418 Value |= (op & 0x1f) << 15;
3419 break;
3420 }
3421 case RISCV::AIF_FSQ2:
3422 case RISCV::AIF_FSW_PS: {
3423 // op: imm12
3424 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3425 Value |= (op & 0xfe0) << 20;
3426 Value |= (op & 0x1f) << 7;
3427 // op: rs2
3428 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3429 Value |= (op & 0x1f) << 20;
3430 // op: rs1
3431 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3432 Value |= (op & 0x1f) << 15;
3433 break;
3434 }
3435 case RISCV::FSD:
3436 case RISCV::FSH:
3437 case RISCV::FSQ:
3438 case RISCV::FSW:
3439 case RISCV::SB:
3440 case RISCV::SD:
3441 case RISCV::SD_RV32:
3442 case RISCV::SH:
3443 case RISCV::SH_INX:
3444 case RISCV::SW:
3445 case RISCV::SW_INX: {
3446 // op: imm12
3447 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3448 Value |= (op & 0xfe0) << 20;
3449 Value |= (op & 0x1f) << 7;
3450 // op: rs2
3451 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3452 Value |= (op & 0x1f) << 20;
3453 // op: rs1
3454 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3455 Value |= (op & 0x1f) << 15;
3456 break;
3457 }
3458 case RISCV::CV_SB_ri_inc:
3459 case RISCV::CV_SH_ri_inc:
3460 case RISCV::CV_SW_ri_inc: {
3461 // op: imm12
3462 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3463 Value |= (op & 0xfe0) << 20;
3464 Value |= (op & 0x1f) << 7;
3465 // op: rs2
3466 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3467 Value |= (op & 0x1f) << 20;
3468 // op: rs1
3469 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3470 Value |= (op & 0x1f) << 15;
3471 break;
3472 }
3473 case RISCV::BEQI:
3474 case RISCV::BNEI: {
3475 // op: imm12
3476 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3477 Value |= (op & 0x800) << 20;
3478 Value |= (op & 0x3f0) << 21;
3479 Value |= (op & 0xf) << 8;
3480 Value |= (op & 0x400) >> 3;
3481 // op: cimm
3482 op = getImmOpValueZibi(MI, OpNo: 1, Fixups, STI);
3483 Value |= (op & 0x1f) << 20;
3484 // op: rs1
3485 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3486 Value |= (op & 0x1f) << 15;
3487 break;
3488 }
3489 case RISCV::CV_BEQIMM:
3490 case RISCV::CV_BNEIMM: {
3491 // op: imm12
3492 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3493 Value |= (op & 0x800) << 20;
3494 Value |= (op & 0x3f0) << 21;
3495 Value |= (op & 0xf) << 8;
3496 Value |= (op & 0x400) >> 3;
3497 // op: rs1
3498 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3499 Value |= (op & 0x1f) << 15;
3500 // op: imm5
3501 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3502 Value |= (op & 0x1f) << 20;
3503 break;
3504 }
3505 case RISCV::BEQ:
3506 case RISCV::BGE:
3507 case RISCV::BGEU:
3508 case RISCV::BLT:
3509 case RISCV::BLTU:
3510 case RISCV::BNE:
3511 case RISCV::QC_BEQI:
3512 case RISCV::QC_BGEI:
3513 case RISCV::QC_BGEUI:
3514 case RISCV::QC_BLTI:
3515 case RISCV::QC_BLTUI:
3516 case RISCV::QC_BNEI: {
3517 // op: imm12
3518 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3519 Value |= (op & 0x800) << 20;
3520 Value |= (op & 0x3f0) << 21;
3521 Value |= (op & 0xf) << 8;
3522 Value |= (op & 0x400) >> 3;
3523 // op: rs2
3524 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3525 Value |= (op & 0x1f) << 20;
3526 // op: rs1
3527 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3528 Value |= (op & 0x1f) << 15;
3529 break;
3530 }
3531 case RISCV::NDS_SHGP: {
3532 // op: imm17
3533 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3534 Value |= (op & 0x10000) << 15;
3535 Value |= (op & 0x3f0) << 21;
3536 Value |= (op & 0x3800) << 6;
3537 Value |= (op & 0xc000) << 1;
3538 Value |= (op & 0xf) << 8;
3539 Value |= (op & 0x400) >> 3;
3540 // op: rs2
3541 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3542 Value |= (op & 0x1f) << 20;
3543 break;
3544 }
3545 case RISCV::NDS_LHGP:
3546 case RISCV::NDS_LHUGP: {
3547 // op: imm17
3548 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3549 Value |= (op & 0x10000) << 15;
3550 Value |= (op & 0x3ff) << 21;
3551 Value |= (op & 0x400) << 10;
3552 Value |= (op & 0x3800) << 6;
3553 Value |= (op & 0xc000) << 1;
3554 // op: rd
3555 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3556 Value |= (op & 0x1f) << 7;
3557 break;
3558 }
3559 case RISCV::NDS_SWGP: {
3560 // op: imm17
3561 op = getImmOpValueAsrN<2>(MI, OpNo: 1, Fixups, STI);
3562 Value |= (op & 0x10000) << 15;
3563 Value |= (op & 0x1f8) << 22;
3564 Value |= (op & 0x1c00) << 7;
3565 Value |= (op & 0x6000) << 2;
3566 Value |= (op & 0x7) << 9;
3567 Value |= (op & 0x8000) >> 7;
3568 Value |= (op & 0x200) >> 2;
3569 // op: rs2
3570 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3571 Value |= (op & 0x1f) << 20;
3572 break;
3573 }
3574 case RISCV::NDS_LWGP:
3575 case RISCV::NDS_LWUGP: {
3576 // op: imm17
3577 op = getImmOpValueAsrN<2>(MI, OpNo: 1, Fixups, STI);
3578 Value |= (op & 0x10000) << 15;
3579 Value |= (op & 0x1ff) << 22;
3580 Value |= (op & 0x8000) << 6;
3581 Value |= (op & 0x200) << 11;
3582 Value |= (op & 0x1c00) << 7;
3583 Value |= (op & 0x6000) << 2;
3584 // op: rd
3585 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3586 Value |= (op & 0x1f) << 7;
3587 break;
3588 }
3589 case RISCV::NDS_SDGP: {
3590 // op: imm17
3591 op = getImmOpValueAsrN<3>(MI, OpNo: 1, Fixups, STI);
3592 Value |= (op & 0x10000) << 15;
3593 Value |= (op & 0xfc) << 23;
3594 Value |= (op & 0xe00) << 8;
3595 Value |= (op & 0x3000) << 3;
3596 Value |= (op & 0x3) << 10;
3597 Value |= (op & 0xc000) >> 6;
3598 Value |= (op & 0x100) >> 1;
3599 // op: rs2
3600 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3601 Value |= (op & 0x1f) << 20;
3602 break;
3603 }
3604 case RISCV::NDS_LDGP: {
3605 // op: imm17
3606 op = getImmOpValueAsrN<3>(MI, OpNo: 1, Fixups, STI);
3607 Value |= (op & 0x10000) << 15;
3608 Value |= (op & 0xff) << 23;
3609 Value |= (op & 0xc000) << 7;
3610 Value |= (op & 0x100) << 12;
3611 Value |= (op & 0xe00) << 8;
3612 Value |= (op & 0x3000) << 3;
3613 // op: rd
3614 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3615 Value |= (op & 0x1f) << 7;
3616 break;
3617 }
3618 case RISCV::NDS_SBGP: {
3619 // op: imm18
3620 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3621 Value |= (op & 0x20000) << 14;
3622 Value |= (op & 0x7e0) << 20;
3623 Value |= (op & 0x7000) << 5;
3624 Value |= (op & 0x18000);
3625 Value |= (op & 0x1) << 14;
3626 Value |= (op & 0x1e) << 7;
3627 Value |= (op & 0x800) >> 4;
3628 // op: rs2
3629 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3630 Value |= (op & 0x1f) << 20;
3631 break;
3632 }
3633 case RISCV::NDS_ADDIGP:
3634 case RISCV::NDS_LBGP:
3635 case RISCV::NDS_LBUGP: {
3636 // op: imm18
3637 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3638 Value |= (op & 0x20000) << 14;
3639 Value |= (op & 0x7fe) << 20;
3640 Value |= (op & 0x800) << 9;
3641 Value |= (op & 0x7000) << 5;
3642 Value |= (op & 0x18000);
3643 Value |= (op & 0x1) << 14;
3644 // op: rd
3645 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3646 Value |= (op & 0x1f) << 7;
3647 break;
3648 }
3649 case RISCV::QC_LI: {
3650 // op: imm20
3651 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3652 Value |= (op & 0x80000) << 12;
3653 Value |= (op & 0x7fff) << 16;
3654 Value |= (op & 0x78000) >> 3;
3655 // op: rd
3656 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3657 Value |= (op & 0x1f) << 7;
3658 break;
3659 }
3660 case RISCV::AIF_FBCI_PI:
3661 case RISCV::AIF_FBCI_PS:
3662 case RISCV::AUIPC:
3663 case RISCV::LUI: {
3664 // op: imm20
3665 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3666 Value |= (op & 0xfffff) << 12;
3667 // op: rd
3668 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3669 Value |= (op & 0x1f) << 7;
3670 break;
3671 }
3672 case RISCV::JAL: {
3673 // op: imm20
3674 op = getImmOpValueAsrN<1>(MI, OpNo: 1, Fixups, STI);
3675 Value |= (op & 0x80000) << 12;
3676 Value |= (op & 0x3ff) << 21;
3677 Value |= (op & 0x400) << 10;
3678 Value |= (op & 0x7f800) << 1;
3679 // op: rd
3680 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3681 Value |= (op & 0x1f) << 7;
3682 break;
3683 }
3684 case RISCV::QC_E_J:
3685 case RISCV::QC_E_JAL: {
3686 // op: imm31
3687 op = getImmOpValueAsrN<1>(MI, OpNo: 0, Fixups, STI);
3688 Value |= (op & 0x7fff8000) << 17;
3689 Value |= (op & 0x800) << 20;
3690 Value |= (op & 0x3f0) << 21;
3691 Value |= (op & 0x7000) << 5;
3692 Value |= (op & 0xf) << 8;
3693 Value |= (op & 0x400) >> 3;
3694 break;
3695 }
3696 case RISCV::QC_SYNC:
3697 case RISCV::QC_SYNCR:
3698 case RISCV::QC_SYNCWF:
3699 case RISCV::QC_SYNCWL: {
3700 // op: imm5
3701 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3702 Value |= (op & 0x1f) << 20;
3703 break;
3704 }
3705 case RISCV::MIPS_SDP: {
3706 // op: imm7
3707 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3708 Value |= (op & 0x60) << 20;
3709 Value |= (op & 0x18) << 7;
3710 // op: rs3
3711 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3712 Value |= (op & 0x1f) << 27;
3713 // op: rs2
3714 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3715 Value |= (op & 0x1f) << 20;
3716 // op: rs1
3717 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3718 Value |= (op & 0x1f) << 15;
3719 break;
3720 }
3721 case RISCV::MIPS_SWP: {
3722 // op: imm7
3723 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3724 Value |= (op & 0x60) << 20;
3725 Value |= (op & 0x1c) << 7;
3726 // op: rs3
3727 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3728 Value |= (op & 0x1f) << 27;
3729 // op: rs2
3730 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3731 Value |= (op & 0x1f) << 20;
3732 // op: rs1
3733 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3734 Value |= (op & 0x1f) << 15;
3735 break;
3736 }
3737 case RISCV::MIPS_LDP: {
3738 // op: imm7
3739 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3740 Value |= (op & 0x78) << 20;
3741 // op: rs1
3742 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3743 Value |= (op & 0x1f) << 15;
3744 // op: rd1
3745 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3746 Value |= (op & 0x1f) << 7;
3747 // op: rd2
3748 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3749 Value |= (op & 0x1f) << 27;
3750 break;
3751 }
3752 case RISCV::MIPS_LWP: {
3753 // op: imm7
3754 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3755 Value |= (op & 0x7c) << 20;
3756 // op: rs1
3757 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3758 Value |= (op & 0x1f) << 15;
3759 // op: rd1
3760 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3761 Value |= (op & 0x1f) << 7;
3762 // op: rd2
3763 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
3764 Value |= (op & 0x1f) << 27;
3765 break;
3766 }
3767 case RISCV::QC_PPUTCI: {
3768 // op: imm8
3769 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3770 Value |= (op & 0xff) << 20;
3771 break;
3772 }
3773 case RISCV::MIPS_PREF: {
3774 // op: imm9
3775 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3776 Value |= (op & 0x1ff) << 20;
3777 // op: rs1
3778 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3779 Value |= (op & 0x1f) << 15;
3780 // op: hint
3781 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3782 Value |= (op & 0x1f) << 7;
3783 break;
3784 }
3785 case RISCV::CM_JT: {
3786 // op: index
3787 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3788 Value |= (op & 0x1f) << 2;
3789 break;
3790 }
3791 case RISCV::CM_JALT: {
3792 // op: index
3793 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
3794 Value |= (op & 0xff) << 2;
3795 break;
3796 }
3797 case RISCV::C_J:
3798 case RISCV::C_JAL: {
3799 // op: offset
3800 op = getImmOpValueAsrN<1>(MI, OpNo: 0, Fixups, STI);
3801 Value |= (op & 0x400) << 2;
3802 Value |= (op & 0x8) << 8;
3803 Value |= (op & 0x180) << 2;
3804 Value |= (op & 0x200) >> 1;
3805 Value |= (op & 0x20) << 2;
3806 Value |= (op & 0x40);
3807 Value |= (op & 0x7) << 3;
3808 Value |= (op & 0x10) >> 2;
3809 break;
3810 }
3811 case RISCV::InsnCJ: {
3812 // op: opcode
3813 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3814 Value |= (op & 0x3);
3815 // op: funct3
3816 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3817 Value |= (op & 0x7) << 13;
3818 // op: imm11
3819 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
3820 Value |= (op & 0x400) << 2;
3821 Value |= (op & 0x8) << 8;
3822 Value |= (op & 0x180) << 2;
3823 Value |= (op & 0x200) >> 1;
3824 Value |= (op & 0x20) << 2;
3825 Value |= (op & 0x40);
3826 Value |= (op & 0x7) << 3;
3827 Value |= (op & 0x10) >> 2;
3828 break;
3829 }
3830 case RISCV::InsnCS: {
3831 // op: opcode
3832 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3833 Value |= (op & 0x3);
3834 // op: funct3
3835 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3836 Value |= (op & 0x7) << 13;
3837 // op: imm5
3838 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3839 Value |= (op & 0x1c) << 8;
3840 Value |= (op & 0x3) << 5;
3841 // op: rs2
3842 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3843 Value |= (op & 0x7) << 2;
3844 // op: rs1
3845 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3846 Value |= (op & 0x7) << 7;
3847 break;
3848 }
3849 case RISCV::InsnCSS: {
3850 // op: opcode
3851 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3852 Value |= (op & 0x3);
3853 // op: funct3
3854 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3855 Value |= (op & 0x7) << 13;
3856 // op: imm6
3857 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3858 Value |= (op & 0x3f) << 7;
3859 // op: rs2
3860 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3861 Value |= (op & 0x1f) << 2;
3862 break;
3863 }
3864 case RISCV::InsnCB: {
3865 // op: opcode
3866 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3867 Value |= (op & 0x3);
3868 // op: funct3
3869 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3870 Value |= (op & 0x7) << 13;
3871 // op: imm8
3872 op = getImmOpValueAsrN<1>(MI, OpNo: 3, Fixups, STI);
3873 Value |= (op & 0x80) << 5;
3874 Value |= (op & 0xc) << 8;
3875 Value |= (op & 0x60);
3876 Value |= (op & 0x3) << 3;
3877 Value |= (op & 0x10) >> 2;
3878 // op: rs1
3879 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3880 Value |= (op & 0x7) << 7;
3881 break;
3882 }
3883 case RISCV::InsnQC_EJ: {
3884 // op: opcode
3885 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3886 Value |= (op & 0x7f);
3887 // op: func3
3888 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3889 Value |= (op & 0x7) << 12;
3890 // op: func2
3891 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3892 Value |= (op & 0x3) << 15;
3893 // op: func5
3894 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
3895 Value |= (op & 0x1f) << 20;
3896 // op: imm31
3897 op = getImmOpValueAsrN<1>(MI, OpNo: 4, Fixups, STI);
3898 Value |= (op & 0x7fff8000) << 17;
3899 Value |= (op & 0x800) << 20;
3900 Value |= (op & 0x3f0) << 21;
3901 Value |= (op & 0x7000) << 5;
3902 Value |= (op & 0xf) << 8;
3903 Value |= (op & 0x400) >> 3;
3904 break;
3905 }
3906 case RISCV::InsnQC_ES: {
3907 // op: opcode
3908 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3909 Value |= (op & 0x7f);
3910 // op: func3
3911 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3912 Value |= (op & 0x7) << 12;
3913 // op: func2
3914 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3915 Value |= (op & 0x3) << 30;
3916 // op: rs1
3917 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
3918 Value |= (op & 0x1f) << 15;
3919 // op: rs2
3920 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3921 Value |= (op & 0x1f) << 20;
3922 // op: imm26
3923 op = getImmOpValue(MI, OpNo: 5, Fixups, STI);
3924 Value |= (op & 0x3fffc00) << 22;
3925 Value |= (op & 0x3e0) << 20;
3926 Value |= (op & 0x1f) << 7;
3927 break;
3928 }
3929 case RISCV::InsnQC_EB: {
3930 // op: opcode
3931 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3932 Value |= (op & 0x7f);
3933 // op: func3
3934 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3935 Value |= (op & 0x7) << 12;
3936 // op: func5
3937 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3938 Value |= (op & 0x1f) << 20;
3939 // op: rs1
3940 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3941 Value |= (op & 0x1f) << 15;
3942 // op: imm12
3943 op = getImmOpValueAsrN<1>(MI, OpNo: 5, Fixups, STI);
3944 Value |= (op & 0x800) << 20;
3945 Value |= (op & 0x3f0) << 21;
3946 Value |= (op & 0xf) << 8;
3947 Value |= (op & 0x400) >> 3;
3948 // op: imm16
3949 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3950 Value |= (op & 0xffff) << 32;
3951 break;
3952 }
3953 case RISCV::InsnS: {
3954 // op: opcode
3955 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3956 Value |= (op & 0x7f);
3957 // op: funct3
3958 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3959 Value |= (op & 0x7) << 12;
3960 // op: imm12
3961 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
3962 Value |= (op & 0xfe0) << 20;
3963 Value |= (op & 0x1f) << 7;
3964 // op: rs2
3965 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3966 Value |= (op & 0x1f) << 20;
3967 // op: rs1
3968 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3969 Value |= (op & 0x1f) << 15;
3970 break;
3971 }
3972 case RISCV::InsnB: {
3973 // op: opcode
3974 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
3975 Value |= (op & 0x7f);
3976 // op: funct3
3977 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3978 Value |= (op & 0x7) << 12;
3979 // op: imm12
3980 op = getImmOpValueAsrN<1>(MI, OpNo: 4, Fixups, STI);
3981 Value |= (op & 0x800) << 20;
3982 Value |= (op & 0x3f0) << 21;
3983 Value |= (op & 0xf) << 8;
3984 Value |= (op & 0x400) >> 3;
3985 // op: rs2
3986 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
3987 Value |= (op & 0x1f) << 20;
3988 // op: rs1
3989 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
3990 Value |= (op & 0x1f) << 15;
3991 break;
3992 }
3993 case RISCV::InsnCL: {
3994 // op: opcode
3995 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
3996 Value |= (op & 0x3);
3997 // op: funct3
3998 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
3999 Value |= (op & 0x7) << 13;
4000 // op: imm5
4001 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4002 Value |= (op & 0x1c) << 8;
4003 Value |= (op & 0x3) << 5;
4004 // op: rd
4005 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4006 Value |= (op & 0x7) << 2;
4007 // op: rs1
4008 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4009 Value |= (op & 0x7) << 7;
4010 break;
4011 }
4012 case RISCV::InsnCI: {
4013 // op: opcode
4014 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4015 Value |= (op & 0x3);
4016 // op: funct3
4017 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4018 Value |= (op & 0x7) << 13;
4019 // op: imm6
4020 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4021 Value |= (op & 0x20) << 7;
4022 Value |= (op & 0x1f) << 2;
4023 // op: rd
4024 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4025 Value |= (op & 0x1f) << 7;
4026 break;
4027 }
4028 case RISCV::InsnCIW: {
4029 // op: opcode
4030 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4031 Value |= (op & 0x3);
4032 // op: funct3
4033 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4034 Value |= (op & 0x7) << 13;
4035 // op: imm8
4036 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4037 Value |= (op & 0xff) << 5;
4038 // op: rd
4039 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4040 Value |= (op & 0x7) << 2;
4041 break;
4042 }
4043 case RISCV::InsnCR: {
4044 // op: opcode
4045 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4046 Value |= (op & 0x3);
4047 // op: funct4
4048 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4049 Value |= (op & 0xf) << 12;
4050 // op: rs2
4051 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4052 Value |= (op & 0x1f) << 2;
4053 // op: rd
4054 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4055 Value |= (op & 0x1f) << 7;
4056 break;
4057 }
4058 case RISCV::InsnCA: {
4059 // op: opcode
4060 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4061 Value |= (op & 0x3);
4062 // op: funct6
4063 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4064 Value |= (op & 0x3f) << 10;
4065 // op: funct2
4066 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4067 Value |= (op & 0x3) << 5;
4068 // op: rd
4069 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4070 Value |= (op & 0x7) << 7;
4071 // op: rs2
4072 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4073 Value |= (op & 0x7) << 2;
4074 break;
4075 }
4076 case RISCV::InsnQC_EAI: {
4077 // op: opcode
4078 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4079 Value |= (op & 0x7f);
4080 // op: func3
4081 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4082 Value |= (op & 0x7) << 12;
4083 // op: func1
4084 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4085 Value |= (op & 0x1) << 15;
4086 // op: rd
4087 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4088 Value |= (op & 0x1f) << 7;
4089 // op: imm32
4090 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4091 Value |= (op & 0xffffffff) << 16;
4092 break;
4093 }
4094 case RISCV::InsnQC_EI:
4095 case RISCV::InsnQC_EI_Mem: {
4096 // op: opcode
4097 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4098 Value |= (op & 0x7f);
4099 // op: func3
4100 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4101 Value |= (op & 0x7) << 12;
4102 // op: func2
4103 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4104 Value |= (op & 0x3) << 30;
4105 // op: rd
4106 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4107 Value |= (op & 0x1f) << 7;
4108 // op: rs1
4109 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4110 Value |= (op & 0x1f) << 15;
4111 // op: imm26
4112 op = getImmOpValue(MI, OpNo: 5, Fixups, STI);
4113 Value |= (op & 0x3fffc00) << 22;
4114 Value |= (op & 0x3ff) << 20;
4115 break;
4116 }
4117 case RISCV::InsnR4: {
4118 // op: opcode
4119 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4120 Value |= (op & 0x7f);
4121 // op: funct2
4122 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4123 Value |= (op & 0x3) << 25;
4124 // op: funct3
4125 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4126 Value |= (op & 0x7) << 12;
4127 // op: rs3
4128 op = getMachineOpValue(MI, MO: MI.getOperand(i: 6), Fixups, STI);
4129 Value |= (op & 0x1f) << 27;
4130 // op: rs2
4131 op = getMachineOpValue(MI, MO: MI.getOperand(i: 5), Fixups, STI);
4132 Value |= (op & 0x1f) << 20;
4133 // op: rs1
4134 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4135 Value |= (op & 0x1f) << 15;
4136 // op: rd
4137 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4138 Value |= (op & 0x1f) << 7;
4139 break;
4140 }
4141 case RISCV::InsnI:
4142 case RISCV::InsnI_Mem: {
4143 // op: opcode
4144 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4145 Value |= (op & 0x7f);
4146 // op: funct3
4147 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4148 Value |= (op & 0x7) << 12;
4149 // op: imm12
4150 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4151 Value |= (op & 0xfff) << 20;
4152 // op: rs1
4153 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4154 Value |= (op & 0x1f) << 15;
4155 // op: rd
4156 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4157 Value |= (op & 0x1f) << 7;
4158 break;
4159 }
4160 case RISCV::InsnR: {
4161 // op: opcode
4162 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4163 Value |= (op & 0x7f);
4164 // op: funct7
4165 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4166 Value |= (op & 0x7f) << 25;
4167 // op: funct3
4168 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4169 Value |= (op & 0x7) << 12;
4170 // op: rs2
4171 op = getMachineOpValue(MI, MO: MI.getOperand(i: 5), Fixups, STI);
4172 Value |= (op & 0x1f) << 20;
4173 // op: rs1
4174 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4175 Value |= (op & 0x1f) << 15;
4176 // op: rd
4177 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4178 Value |= (op & 0x1f) << 7;
4179 break;
4180 }
4181 case RISCV::InsnU: {
4182 // op: opcode
4183 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4184 Value |= (op & 0x7f);
4185 // op: imm20
4186 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4187 Value |= (op & 0xfffff) << 12;
4188 // op: rd
4189 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4190 Value |= (op & 0x1f) << 7;
4191 break;
4192 }
4193 case RISCV::InsnJ: {
4194 // op: opcode
4195 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4196 Value |= (op & 0x7f);
4197 // op: imm20
4198 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
4199 Value |= (op & 0xfffff) << 12;
4200 // op: rd
4201 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4202 Value |= (op & 0x1f) << 7;
4203 break;
4204 }
4205 case RISCV::FENCE: {
4206 // op: pred
4207 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4208 Value |= (op & 0xf) << 24;
4209 // op: succ
4210 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4211 Value |= (op & 0xf) << 20;
4212 break;
4213 }
4214 case RISCV::PLUI_DH: {
4215 // op: rd
4216 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4217 Value |= (op & 0x1e) << 7;
4218 // op: imm10
4219 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4220 Value |= (op & 0x1) << 24;
4221 Value |= (op & 0x3fe) << 14;
4222 break;
4223 }
4224 case RISCV::PLI_DH: {
4225 // op: rd
4226 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4227 Value |= (op & 0x1e) << 7;
4228 // op: imm10
4229 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4230 Value |= (op & 0x1ff) << 16;
4231 Value |= (op & 0x200) << 6;
4232 break;
4233 }
4234 case RISCV::PLI_DB: {
4235 // op: rd
4236 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4237 Value |= (op & 0x1e) << 7;
4238 // op: imm8
4239 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4240 Value |= (op & 0xff) << 16;
4241 break;
4242 }
4243 case RISCV::AIF_MOVA_X_M:
4244 case RISCV::QC_C_DIR:
4245 case RISCV::SSRDP: {
4246 // op: rd
4247 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4248 Value |= (op & 0x1f) << 7;
4249 break;
4250 }
4251 case RISCV::QC_E_LI: {
4252 // op: rd
4253 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4254 Value |= (op & 0x1f) << 7;
4255 // op: imm
4256 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4257 Value |= (op & 0xffffffff) << 16;
4258 break;
4259 }
4260 case RISCV::FLI_D:
4261 case RISCV::FLI_H:
4262 case RISCV::FLI_Q:
4263 case RISCV::FLI_S: {
4264 // op: rd
4265 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4266 Value |= (op & 0x1f) << 7;
4267 // op: imm
4268 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4269 Value |= (op & 0x1f) << 15;
4270 break;
4271 }
4272 case RISCV::PLUI_H:
4273 case RISCV::PLUI_W: {
4274 // op: rd
4275 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4276 Value |= (op & 0x1f) << 7;
4277 // op: imm10
4278 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4279 Value |= (op & 0x1) << 24;
4280 Value |= (op & 0x3fe) << 14;
4281 break;
4282 }
4283 case RISCV::PLI_H:
4284 case RISCV::PLI_W: {
4285 // op: rd
4286 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4287 Value |= (op & 0x1f) << 7;
4288 // op: imm10
4289 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4290 Value |= (op & 0x1ff) << 16;
4291 Value |= (op & 0x200) << 6;
4292 break;
4293 }
4294 case RISCV::PLI_B: {
4295 // op: rd
4296 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4297 Value |= (op & 0x1f) << 7;
4298 // op: imm8
4299 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4300 Value |= (op & 0xff) << 16;
4301 break;
4302 }
4303 case RISCV::AIF_FMVS_X_PS:
4304 case RISCV::AIF_FMVZ_X_PS: {
4305 // op: rd
4306 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4307 Value |= (op & 0x1f) << 7;
4308 // op: rs1
4309 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4310 Value |= (op & 0x1f) << 15;
4311 // op: idx
4312 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4313 Value |= (op & 0x7) << 20;
4314 break;
4315 }
4316 case RISCV::QC_E_ADDI:
4317 case RISCV::QC_E_ANDI:
4318 case RISCV::QC_E_LB:
4319 case RISCV::QC_E_LBU:
4320 case RISCV::QC_E_LH:
4321 case RISCV::QC_E_LHU:
4322 case RISCV::QC_E_LW:
4323 case RISCV::QC_E_ORI:
4324 case RISCV::QC_E_XORI: {
4325 // op: rd
4326 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4327 Value |= (op & 0x1f) << 7;
4328 // op: rs1
4329 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4330 Value |= (op & 0x1f) << 15;
4331 // op: imm
4332 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4333 Value |= (op & 0x3fffc00) << 22;
4334 Value |= (op & 0x3ff) << 20;
4335 break;
4336 }
4337 case RISCV::AIF_FSWIZZ_PS: {
4338 // op: rd
4339 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4340 Value |= (op & 0x1f) << 7;
4341 // op: rs1
4342 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4343 Value |= (op & 0x1f) << 15;
4344 // op: imm
4345 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4346 Value |= (op & 0xf8) << 17;
4347 Value |= (op & 0x7) << 12;
4348 break;
4349 }
4350 case RISCV::NDS_BFOS:
4351 case RISCV::NDS_BFOZ: {
4352 // op: rd
4353 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4354 Value |= (op & 0x1f) << 7;
4355 // op: rs1
4356 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4357 Value |= (op & 0x1f) << 15;
4358 // op: msb
4359 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4360 Value |= (op & 0x3f) << 26;
4361 // op: lsb
4362 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4363 Value |= (op & 0x3f) << 20;
4364 break;
4365 }
4366 case RISCV::AIF_FCVT_PS_PW:
4367 case RISCV::AIF_FCVT_PS_PWU:
4368 case RISCV::AIF_FCVT_PWU_PS:
4369 case RISCV::AIF_FCVT_PW_PS: {
4370 // op: rd
4371 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4372 Value |= (op & 0x1f) << 7;
4373 // op: rs1
4374 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4375 Value |= (op & 0x1f) << 15;
4376 // op: rm
4377 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4378 Value |= (op & 0x7) << 12;
4379 break;
4380 }
4381 case RISCV::AIF_FADD_PS:
4382 case RISCV::AIF_FDIV_PS:
4383 case RISCV::AIF_FMUL_PS:
4384 case RISCV::AIF_FSUB_PS: {
4385 // op: rd
4386 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4387 Value |= (op & 0x1f) << 7;
4388 // op: rs1
4389 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4390 Value |= (op & 0x1f) << 15;
4391 // op: rs2
4392 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4393 Value |= (op & 0x1f) << 20;
4394 // op: rm
4395 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4396 Value |= (op & 0x7) << 12;
4397 break;
4398 }
4399 case RISCV::AIF_FCMOV_PS: {
4400 // op: rd
4401 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4402 Value |= (op & 0x1f) << 7;
4403 // op: rs1
4404 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4405 Value |= (op & 0x1f) << 15;
4406 // op: rs2
4407 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4408 Value |= (op & 0x1f) << 20;
4409 // op: rs3
4410 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4411 Value |= (op & 0x1f) << 27;
4412 break;
4413 }
4414 case RISCV::AIF_FMADD_PS:
4415 case RISCV::AIF_FMSUB_PS:
4416 case RISCV::AIF_FNMADD_PS:
4417 case RISCV::AIF_FNMSUB_PS: {
4418 // op: rd
4419 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4420 Value |= (op & 0x1f) << 7;
4421 // op: rs1
4422 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4423 Value |= (op & 0x1f) << 15;
4424 // op: rs2
4425 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4426 Value |= (op & 0x1f) << 20;
4427 // op: rs3
4428 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
4429 Value |= (op & 0x1f) << 27;
4430 // op: rm
4431 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
4432 Value |= (op & 0x7) << 12;
4433 break;
4434 }
4435 case RISCV::VSETIVLI: {
4436 // op: rd
4437 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4438 Value |= (op & 0x1f) << 7;
4439 // op: uimm
4440 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
4441 Value |= (op & 0x1f) << 15;
4442 // op: vtypei
4443 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4444 Value |= (op & 0x3ff) << 20;
4445 break;
4446 }
4447 case RISCV::VCPOP_M:
4448 case RISCV::VFIRST_M: {
4449 // op: rd
4450 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4451 Value |= (op & 0x1f) << 7;
4452 // op: vm
4453 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
4454 Value |= (op & 0x1) << 25;
4455 // op: vs2
4456 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4457 Value |= (op & 0x1f) << 20;
4458 break;
4459 }
4460 case RISCV::VFMV_F_S:
4461 case RISCV::VMV_X_S: {
4462 // op: rd
4463 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4464 Value |= (op & 0x1f) << 7;
4465 // op: vs2
4466 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4467 Value |= (op & 0x1f) << 20;
4468 break;
4469 }
4470 case RISCV::QK_C_LBU: {
4471 // op: rd
4472 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4473 Value |= (op & 0x7) << 2;
4474 // op: rs1
4475 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4476 Value |= (op & 0x7) << 7;
4477 // op: imm
4478 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4479 Value |= (op & 0x1) << 12;
4480 Value |= (op & 0x18) << 7;
4481 Value |= (op & 0x6) << 4;
4482 break;
4483 }
4484 case RISCV::C_LBU: {
4485 // op: rd
4486 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4487 Value |= (op & 0x7) << 2;
4488 // op: rs1
4489 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4490 Value |= (op & 0x7) << 7;
4491 // op: imm
4492 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4493 Value |= (op & 0x1) << 6;
4494 Value |= (op & 0x2) << 4;
4495 break;
4496 }
4497 case RISCV::C_LH:
4498 case RISCV::C_LHU:
4499 case RISCV::C_LH_INX: {
4500 // op: rd
4501 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4502 Value |= (op & 0x7) << 2;
4503 // op: rs1
4504 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4505 Value |= (op & 0x7) << 7;
4506 // op: imm
4507 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4508 Value |= (op & 0x2) << 4;
4509 break;
4510 }
4511 case RISCV::C_FLW:
4512 case RISCV::C_LW:
4513 case RISCV::C_LW_INX: {
4514 // op: rd
4515 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4516 Value |= (op & 0x7) << 2;
4517 // op: rs1
4518 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4519 Value |= (op & 0x7) << 7;
4520 // op: imm
4521 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4522 Value |= (op & 0x38) << 7;
4523 Value |= (op & 0x4) << 4;
4524 Value |= (op & 0x40) >> 1;
4525 break;
4526 }
4527 case RISCV::QK_C_LHU: {
4528 // op: rd
4529 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4530 Value |= (op & 0x7) << 2;
4531 // op: rs1
4532 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4533 Value |= (op & 0x7) << 7;
4534 // op: imm
4535 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4536 Value |= (op & 0x38) << 7;
4537 Value |= (op & 0x6) << 4;
4538 break;
4539 }
4540 case RISCV::C_FLD:
4541 case RISCV::C_LD:
4542 case RISCV::C_LD_RV32: {
4543 // op: rd
4544 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4545 Value |= (op & 0x7) << 2;
4546 // op: rs1
4547 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4548 Value |= (op & 0x7) << 7;
4549 // op: imm
4550 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4551 Value |= (op & 0x38) << 7;
4552 Value |= (op & 0xc0) >> 1;
4553 break;
4554 }
4555 case RISCV::SF_VTZERO_T: {
4556 // op: rd
4557 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4558 Value |= (op & 0xf) << 8;
4559 break;
4560 }
4561 case RISCV::QC_E_ADDAI:
4562 case RISCV::QC_E_ANDAI:
4563 case RISCV::QC_E_ORAI:
4564 case RISCV::QC_E_XORAI: {
4565 // op: rd
4566 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4567 Value |= (op & 0x1f) << 7;
4568 // op: imm
4569 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4570 Value |= (op & 0xffffffff) << 16;
4571 break;
4572 }
4573 case RISCV::QC_INSBI: {
4574 // op: rd
4575 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4576 Value |= (op & 0x1f) << 7;
4577 // op: imm5
4578 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4579 Value |= (op & 0x1f) << 15;
4580 // op: shamt
4581 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
4582 Value |= (op & 0x1f) << 20;
4583 // op: width
4584 op = getImmOpValueMinus1(MI, OpNo: 3, Fixups, STI);
4585 Value |= (op & 0x1f) << 25;
4586 break;
4587 }
4588 case RISCV::QC_C_EXTU: {
4589 // op: rd
4590 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4591 Value |= (op & 0x1f) << 7;
4592 // op: width
4593 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
4594 Value |= (op & 0x1f) << 2;
4595 break;
4596 }
4597 case RISCV::QC_C_MVEQZ: {
4598 // op: rd
4599 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4600 Value |= (op & 0x7) << 2;
4601 // op: rs1
4602 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4603 Value |= (op & 0x7) << 7;
4604 break;
4605 }
4606 case RISCV::QC_C_MULIADD: {
4607 // op: rd
4608 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4609 Value |= (op & 0x7) << 2;
4610 // op: rs1
4611 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4612 Value |= (op & 0x7) << 7;
4613 // op: uimm
4614 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
4615 Value |= (op & 0xe) << 9;
4616 Value |= (op & 0x1) << 6;
4617 Value |= (op & 0x10) << 1;
4618 break;
4619 }
4620 case RISCV::C_NOT:
4621 case RISCV::C_SEXT_B:
4622 case RISCV::C_SEXT_H:
4623 case RISCV::C_ZEXT_B:
4624 case RISCV::C_ZEXT_H:
4625 case RISCV::C_ZEXT_W: {
4626 // op: rd
4627 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4628 Value |= (op & 0x7) << 7;
4629 break;
4630 }
4631 case RISCV::QK_C_LHUSP:
4632 case RISCV::QK_C_SHSP: {
4633 // op: rd_rs2
4634 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4635 Value |= (op & 0x7) << 2;
4636 // op: imm
4637 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4638 Value |= (op & 0xe) << 7;
4639 Value |= (op & 0x10) << 3;
4640 break;
4641 }
4642 case RISCV::QK_C_LBUSP:
4643 case RISCV::QK_C_SBSP: {
4644 // op: rd_rs2
4645 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4646 Value |= (op & 0x7) << 2;
4647 // op: imm
4648 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4649 Value |= (op & 0xf) << 7;
4650 break;
4651 }
4652 case RISCV::CM_POP:
4653 case RISCV::CM_POPRET:
4654 case RISCV::CM_POPRETZ:
4655 case RISCV::CM_PUSH:
4656 case RISCV::QC_CM_POP:
4657 case RISCV::QC_CM_POPRET:
4658 case RISCV::QC_CM_POPRETZ:
4659 case RISCV::QC_CM_PUSH: {
4660 // op: rlist
4661 op = getRlistOpValue(MI, OpNo: 0, Fixups, STI);
4662 Value |= (op & 0xf) << 4;
4663 // op: stackadj
4664 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4665 Value |= (op & 0x30) >> 2;
4666 break;
4667 }
4668 case RISCV::QC_CM_PUSHFP: {
4669 // op: rlist
4670 op = getRlistS0OpValue(MI, OpNo: 0, Fixups, STI);
4671 Value |= (op & 0xf) << 4;
4672 // op: stackadj
4673 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4674 Value |= (op & 0x30) >> 2;
4675 break;
4676 }
4677 case RISCV::CSRRCI:
4678 case RISCV::CSRRSI:
4679 case RISCV::CSRRWI: {
4680 // op: rs1
4681 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4682 Value |= (op & 0x1f) << 15;
4683 // op: rd
4684 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4685 Value |= (op & 0x1f) << 7;
4686 // op: imm12
4687 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4688 Value |= (op & 0xfff) << 20;
4689 break;
4690 }
4691 case RISCV::AIF_MOVA_M_X:
4692 case RISCV::CBO_CLEAN:
4693 case RISCV::CBO_FLUSH:
4694 case RISCV::CBO_INVAL:
4695 case RISCV::CBO_ZERO:
4696 case RISCV::SF_CDISCARD_D_L1:
4697 case RISCV::SF_CFLUSH_D_L1:
4698 case RISCV::SSPOPCHK:
4699 case RISCV::TH_DCACHE_CIPA:
4700 case RISCV::TH_DCACHE_CISW:
4701 case RISCV::TH_DCACHE_CIVA:
4702 case RISCV::TH_DCACHE_CPA:
4703 case RISCV::TH_DCACHE_CPAL1:
4704 case RISCV::TH_DCACHE_CSW:
4705 case RISCV::TH_DCACHE_CVA:
4706 case RISCV::TH_DCACHE_CVAL1:
4707 case RISCV::TH_DCACHE_IPA:
4708 case RISCV::TH_DCACHE_ISW:
4709 case RISCV::TH_DCACHE_IVA:
4710 case RISCV::TH_ICACHE_IPA:
4711 case RISCV::TH_ICACHE_IVA: {
4712 // op: rs1
4713 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4714 Value |= (op & 0x1f) << 15;
4715 break;
4716 }
4717 case RISCV::QC_E_BEQI:
4718 case RISCV::QC_E_BGEI:
4719 case RISCV::QC_E_BGEUI:
4720 case RISCV::QC_E_BLTI:
4721 case RISCV::QC_E_BLTUI:
4722 case RISCV::QC_E_BNEI: {
4723 // op: rs1
4724 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4725 Value |= (op & 0x1f) << 15;
4726 // op: imm16
4727 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4728 Value |= (op & 0xffff) << 32;
4729 // op: imm12
4730 op = getImmOpValueAsrN<1>(MI, OpNo: 2, Fixups, STI);
4731 Value |= (op & 0x800) << 20;
4732 Value |= (op & 0x3f0) << 21;
4733 Value |= (op & 0xf) << 8;
4734 Value |= (op & 0x400) >> 3;
4735 break;
4736 }
4737 case RISCV::C_JALR:
4738 case RISCV::C_JR:
4739 case RISCV::QC_C_CLRINT:
4740 case RISCV::QC_C_EIR:
4741 case RISCV::QC_C_SETINT: {
4742 // op: rs1
4743 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4744 Value |= (op & 0x1f) << 7;
4745 break;
4746 }
4747 case RISCV::C_MV: {
4748 // op: rs1
4749 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4750 Value |= (op & 0x1f) << 7;
4751 // op: rs2
4752 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4753 Value |= (op & 0x1f) << 2;
4754 break;
4755 }
4756 case RISCV::PSABS_DB:
4757 case RISCV::PSABS_DH:
4758 case RISCV::PSEXT_DH_B:
4759 case RISCV::PSEXT_DW_B:
4760 case RISCV::PSEXT_DW_H: {
4761 // op: rs1
4762 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4763 Value |= (op & 0x1e) << 15;
4764 // op: rd
4765 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4766 Value |= (op & 0x1e) << 7;
4767 break;
4768 }
4769 case RISCV::ADDD:
4770 case RISCV::PAADDU_DB:
4771 case RISCV::PAADDU_DH:
4772 case RISCV::PAADDU_DW:
4773 case RISCV::PAADD_DB:
4774 case RISCV::PAADD_DH:
4775 case RISCV::PAADD_DW:
4776 case RISCV::PAAX_DHX:
4777 case RISCV::PABDU_DB:
4778 case RISCV::PABDU_DH:
4779 case RISCV::PABD_DB:
4780 case RISCV::PABD_DH:
4781 case RISCV::PADD_DB:
4782 case RISCV::PADD_DH:
4783 case RISCV::PADD_DW:
4784 case RISCV::PASA_DHX:
4785 case RISCV::PASUBU_DB:
4786 case RISCV::PASUBU_DH:
4787 case RISCV::PASUBU_DW:
4788 case RISCV::PASUB_DB:
4789 case RISCV::PASUB_DH:
4790 case RISCV::PASUB_DW:
4791 case RISCV::PAS_DHX:
4792 case RISCV::PMAXU_DB:
4793 case RISCV::PMAXU_DH:
4794 case RISCV::PMAXU_DW:
4795 case RISCV::PMAX_DB:
4796 case RISCV::PMAX_DH:
4797 case RISCV::PMAX_DW:
4798 case RISCV::PMINU_DB:
4799 case RISCV::PMINU_DH:
4800 case RISCV::PMINU_DW:
4801 case RISCV::PMIN_DB:
4802 case RISCV::PMIN_DH:
4803 case RISCV::PMIN_DW:
4804 case RISCV::PMSEQ_DB:
4805 case RISCV::PMSEQ_DH:
4806 case RISCV::PMSEQ_DW:
4807 case RISCV::PMSLTU_DB:
4808 case RISCV::PMSLTU_DH:
4809 case RISCV::PMSLTU_DW:
4810 case RISCV::PMSLT_DB:
4811 case RISCV::PMSLT_DH:
4812 case RISCV::PMSLT_DW:
4813 case RISCV::PPAIREO_DB:
4814 case RISCV::PPAIREO_DH:
4815 case RISCV::PPAIRE_DB:
4816 case RISCV::PPAIRE_DH:
4817 case RISCV::PPAIROE_DB:
4818 case RISCV::PPAIROE_DH:
4819 case RISCV::PPAIRO_DB:
4820 case RISCV::PPAIRO_DH:
4821 case RISCV::PSADDU_DB:
4822 case RISCV::PSADDU_DH:
4823 case RISCV::PSADDU_DW:
4824 case RISCV::PSADD_DB:
4825 case RISCV::PSADD_DH:
4826 case RISCV::PSADD_DW:
4827 case RISCV::PSAS_DHX:
4828 case RISCV::PSA_DHX:
4829 case RISCV::PSH1ADD_DH:
4830 case RISCV::PSH1ADD_DW:
4831 case RISCV::PSSA_DHX:
4832 case RISCV::PSSH1SADD_DH:
4833 case RISCV::PSSH1SADD_DW:
4834 case RISCV::PSSUBU_DB:
4835 case RISCV::PSSUBU_DH:
4836 case RISCV::PSSUBU_DW:
4837 case RISCV::PSSUB_DB:
4838 case RISCV::PSSUB_DH:
4839 case RISCV::PSSUB_DW:
4840 case RISCV::PSUB_DB:
4841 case RISCV::PSUB_DH:
4842 case RISCV::PSUB_DW:
4843 case RISCV::SUBD: {
4844 // op: rs1
4845 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4846 Value |= (op & 0x1e) << 15;
4847 // op: rd
4848 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4849 Value |= (op & 0x1e) << 7;
4850 // op: rs2
4851 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4852 Value |= (op & 0x1e) << 20;
4853 break;
4854 }
4855 case RISCV::PADD_DBS:
4856 case RISCV::PADD_DHS:
4857 case RISCV::PADD_DWS:
4858 case RISCV::PSLL_DBS:
4859 case RISCV::PSLL_DHS:
4860 case RISCV::PSLL_DWS:
4861 case RISCV::PSRA_DBS:
4862 case RISCV::PSRA_DHS:
4863 case RISCV::PSRA_DWS:
4864 case RISCV::PSRL_DBS:
4865 case RISCV::PSRL_DHS:
4866 case RISCV::PSRL_DWS:
4867 case RISCV::PSSHAR_DHS:
4868 case RISCV::PSSHAR_DWS:
4869 case RISCV::PSSHA_DHS:
4870 case RISCV::PSSHA_DWS: {
4871 // op: rs1
4872 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4873 Value |= (op & 0x1e) << 15;
4874 // op: rd
4875 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4876 Value |= (op & 0x1e) << 7;
4877 // op: rs2
4878 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4879 Value |= (op & 0x1f) << 20;
4880 break;
4881 }
4882 case RISCV::PSATI_DW:
4883 case RISCV::PSLLI_DW:
4884 case RISCV::PSRAI_DW:
4885 case RISCV::PSRARI_DW:
4886 case RISCV::PSRLI_DW:
4887 case RISCV::PSSLAI_DW:
4888 case RISCV::PUSATI_DW: {
4889 // op: rs1
4890 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4891 Value |= (op & 0x1e) << 15;
4892 // op: rd
4893 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4894 Value |= (op & 0x1e) << 7;
4895 // op: shamt
4896 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4897 Value |= (op & 0x1f) << 20;
4898 break;
4899 }
4900 case RISCV::PSLLI_DB:
4901 case RISCV::PSRAI_DB:
4902 case RISCV::PSRLI_DB: {
4903 // op: rs1
4904 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4905 Value |= (op & 0x1e) << 15;
4906 // op: rd
4907 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4908 Value |= (op & 0x1e) << 7;
4909 // op: shamt
4910 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4911 Value |= (op & 0x7) << 20;
4912 break;
4913 }
4914 case RISCV::PSATI_DH:
4915 case RISCV::PSLLI_DH:
4916 case RISCV::PSRAI_DH:
4917 case RISCV::PSRARI_DH:
4918 case RISCV::PSRLI_DH:
4919 case RISCV::PSSLAI_DH:
4920 case RISCV::PUSATI_DH: {
4921 // op: rs1
4922 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4923 Value |= (op & 0x1e) << 15;
4924 // op: rd
4925 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4926 Value |= (op & 0x1e) << 7;
4927 // op: shamt
4928 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4929 Value |= (op & 0xf) << 20;
4930 break;
4931 }
4932 case RISCV::NCLIP:
4933 case RISCV::NCLIPR:
4934 case RISCV::NCLIPRU:
4935 case RISCV::NCLIPU:
4936 case RISCV::NSRA:
4937 case RISCV::NSRAR:
4938 case RISCV::NSRL:
4939 case RISCV::PNCLIPRU_BS:
4940 case RISCV::PNCLIPRU_HS:
4941 case RISCV::PNCLIPR_BS:
4942 case RISCV::PNCLIPR_HS:
4943 case RISCV::PNCLIPU_BS:
4944 case RISCV::PNCLIPU_HS:
4945 case RISCV::PNCLIP_BS:
4946 case RISCV::PNCLIP_HS:
4947 case RISCV::PNSRAR_BS:
4948 case RISCV::PNSRAR_HS:
4949 case RISCV::PNSRA_BS:
4950 case RISCV::PNSRA_HS:
4951 case RISCV::PNSRL_BS:
4952 case RISCV::PNSRL_HS:
4953 case RISCV::PREDSUMU_DBS:
4954 case RISCV::PREDSUMU_DHS:
4955 case RISCV::PREDSUM_DBS:
4956 case RISCV::PREDSUM_DHS: {
4957 // op: rs1
4958 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4959 Value |= (op & 0x1e) << 15;
4960 // op: rd
4961 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4962 Value |= (op & 0x1f) << 7;
4963 // op: rs2
4964 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
4965 Value |= (op & 0x1f) << 20;
4966 break;
4967 }
4968 case RISCV::PNCLIPIU_H:
4969 case RISCV::PNCLIPI_H:
4970 case RISCV::PNCLIPRIU_H:
4971 case RISCV::PNCLIPRI_H:
4972 case RISCV::PNSARI_H:
4973 case RISCV::PNSRAI_H:
4974 case RISCV::PNSRLI_H: {
4975 // op: rs1
4976 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4977 Value |= (op & 0x1e) << 15;
4978 // op: rd
4979 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4980 Value |= (op & 0x1f) << 7;
4981 // op: shamt
4982 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
4983 Value |= (op & 0x1f) << 20;
4984 break;
4985 }
4986 case RISCV::NCLIPI:
4987 case RISCV::NCLIPIU:
4988 case RISCV::NCLIPRI:
4989 case RISCV::NCLIPRIU:
4990 case RISCV::NSARI:
4991 case RISCV::NSRAI:
4992 case RISCV::NSRLI: {
4993 // op: rs1
4994 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
4995 Value |= (op & 0x1e) << 15;
4996 // op: rd
4997 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
4998 Value |= (op & 0x1f) << 7;
4999 // op: shamt
5000 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5001 Value |= (op & 0x3f) << 20;
5002 break;
5003 }
5004 case RISCV::PNCLIPIU_B:
5005 case RISCV::PNCLIPI_B:
5006 case RISCV::PNCLIPRIU_B:
5007 case RISCV::PNCLIPRI_B:
5008 case RISCV::PNSARI_B:
5009 case RISCV::PNSRAI_B:
5010 case RISCV::PNSRLI_B: {
5011 // op: rs1
5012 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5013 Value |= (op & 0x1e) << 15;
5014 // op: rd
5015 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5016 Value |= (op & 0x1f) << 7;
5017 // op: shamt
5018 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5019 Value |= (op & 0xf) << 20;
5020 break;
5021 }
5022 case RISCV::FCVT_BF16_S:
5023 case RISCV::FCVT_D_H:
5024 case RISCV::FCVT_D_H_IN32X:
5025 case RISCV::FCVT_D_H_INX:
5026 case RISCV::FCVT_D_L:
5027 case RISCV::FCVT_D_LU:
5028 case RISCV::FCVT_D_LU_INX:
5029 case RISCV::FCVT_D_L_INX:
5030 case RISCV::FCVT_D_Q:
5031 case RISCV::FCVT_D_S:
5032 case RISCV::FCVT_D_S_IN32X:
5033 case RISCV::FCVT_D_S_INX:
5034 case RISCV::FCVT_D_W:
5035 case RISCV::FCVT_D_WU:
5036 case RISCV::FCVT_D_WU_IN32X:
5037 case RISCV::FCVT_D_WU_INX:
5038 case RISCV::FCVT_D_W_IN32X:
5039 case RISCV::FCVT_D_W_INX:
5040 case RISCV::FCVT_H_D:
5041 case RISCV::FCVT_H_D_IN32X:
5042 case RISCV::FCVT_H_D_INX:
5043 case RISCV::FCVT_H_L:
5044 case RISCV::FCVT_H_LU:
5045 case RISCV::FCVT_H_LU_INX:
5046 case RISCV::FCVT_H_L_INX:
5047 case RISCV::FCVT_H_S:
5048 case RISCV::FCVT_H_S_INX:
5049 case RISCV::FCVT_H_W:
5050 case RISCV::FCVT_H_WU:
5051 case RISCV::FCVT_H_WU_INX:
5052 case RISCV::FCVT_H_W_INX:
5053 case RISCV::FCVT_LU_D:
5054 case RISCV::FCVT_LU_D_INX:
5055 case RISCV::FCVT_LU_H:
5056 case RISCV::FCVT_LU_H_INX:
5057 case RISCV::FCVT_LU_Q:
5058 case RISCV::FCVT_LU_S:
5059 case RISCV::FCVT_LU_S_INX:
5060 case RISCV::FCVT_L_D:
5061 case RISCV::FCVT_L_D_INX:
5062 case RISCV::FCVT_L_H:
5063 case RISCV::FCVT_L_H_INX:
5064 case RISCV::FCVT_L_Q:
5065 case RISCV::FCVT_L_S:
5066 case RISCV::FCVT_L_S_INX:
5067 case RISCV::FCVT_Q_D:
5068 case RISCV::FCVT_Q_L:
5069 case RISCV::FCVT_Q_LU:
5070 case RISCV::FCVT_Q_S:
5071 case RISCV::FCVT_Q_W:
5072 case RISCV::FCVT_Q_WU:
5073 case RISCV::FCVT_S_BF16:
5074 case RISCV::FCVT_S_D:
5075 case RISCV::FCVT_S_D_IN32X:
5076 case RISCV::FCVT_S_D_INX:
5077 case RISCV::FCVT_S_H:
5078 case RISCV::FCVT_S_H_INX:
5079 case RISCV::FCVT_S_L:
5080 case RISCV::FCVT_S_LU:
5081 case RISCV::FCVT_S_LU_INX:
5082 case RISCV::FCVT_S_L_INX:
5083 case RISCV::FCVT_S_Q:
5084 case RISCV::FCVT_S_W:
5085 case RISCV::FCVT_S_WU:
5086 case RISCV::FCVT_S_WU_INX:
5087 case RISCV::FCVT_S_W_INX:
5088 case RISCV::FCVT_WU_D:
5089 case RISCV::FCVT_WU_D_IN32X:
5090 case RISCV::FCVT_WU_D_INX:
5091 case RISCV::FCVT_WU_H:
5092 case RISCV::FCVT_WU_H_INX:
5093 case RISCV::FCVT_WU_Q:
5094 case RISCV::FCVT_WU_S:
5095 case RISCV::FCVT_WU_S_INX:
5096 case RISCV::FCVT_W_D:
5097 case RISCV::FCVT_W_D_IN32X:
5098 case RISCV::FCVT_W_D_INX:
5099 case RISCV::FCVT_W_H:
5100 case RISCV::FCVT_W_H_INX:
5101 case RISCV::FCVT_W_Q:
5102 case RISCV::FCVT_W_S:
5103 case RISCV::FCVT_W_S_INX:
5104 case RISCV::FROUNDNX_D:
5105 case RISCV::FROUNDNX_H:
5106 case RISCV::FROUNDNX_Q:
5107 case RISCV::FROUNDNX_S:
5108 case RISCV::FROUND_D:
5109 case RISCV::FROUND_H:
5110 case RISCV::FROUND_Q:
5111 case RISCV::FROUND_S:
5112 case RISCV::FSQRT_D:
5113 case RISCV::FSQRT_D_IN32X:
5114 case RISCV::FSQRT_D_INX:
5115 case RISCV::FSQRT_H:
5116 case RISCV::FSQRT_H_INX:
5117 case RISCV::FSQRT_Q:
5118 case RISCV::FSQRT_S:
5119 case RISCV::FSQRT_S_INX: {
5120 // op: rs1
5121 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5122 Value |= (op & 0x1f) << 15;
5123 // op: frm
5124 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5125 Value |= (op & 0x7) << 12;
5126 // op: rd
5127 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5128 Value |= (op & 0x1f) << 7;
5129 break;
5130 }
5131 case RISCV::PWSLAI_H:
5132 case RISCV::PWSLLI_H: {
5133 // op: rs1
5134 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5135 Value |= (op & 0x1f) << 15;
5136 // op: rd
5137 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5138 Value |= (op & 0x1e) << 7;
5139 // op: shamt
5140 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5141 Value |= (op & 0x1f) << 20;
5142 break;
5143 }
5144 case RISCV::WSLAI:
5145 case RISCV::WSLLI: {
5146 // op: rs1
5147 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5148 Value |= (op & 0x1f) << 15;
5149 // op: rd
5150 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5151 Value |= (op & 0x1e) << 7;
5152 // op: shamt
5153 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5154 Value |= (op & 0x3f) << 20;
5155 break;
5156 }
5157 case RISCV::PWSLAI_B:
5158 case RISCV::PWSLLI_B: {
5159 // op: rs1
5160 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5161 Value |= (op & 0x1f) << 15;
5162 // op: rd
5163 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5164 Value |= (op & 0x1e) << 7;
5165 // op: shamt
5166 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5167 Value |= (op & 0xf) << 20;
5168 break;
5169 }
5170 case RISCV::ABS:
5171 case RISCV::ABSW:
5172 case RISCV::AES64IM:
5173 case RISCV::AIF_FBCX_PS:
5174 case RISCV::AIF_FCLASS_PS:
5175 case RISCV::AIF_FCVT_F10_PS:
5176 case RISCV::AIF_FCVT_F11_PS:
5177 case RISCV::AIF_FCVT_F16_PS:
5178 case RISCV::AIF_FCVT_PS_F10:
5179 case RISCV::AIF_FCVT_PS_F11:
5180 case RISCV::AIF_FCVT_PS_F16:
5181 case RISCV::AIF_FCVT_PS_RAST:
5182 case RISCV::AIF_FCVT_PS_SN16:
5183 case RISCV::AIF_FCVT_PS_SN8:
5184 case RISCV::AIF_FCVT_PS_UN10:
5185 case RISCV::AIF_FCVT_PS_UN16:
5186 case RISCV::AIF_FCVT_PS_UN2:
5187 case RISCV::AIF_FCVT_PS_UN24:
5188 case RISCV::AIF_FCVT_PS_UN8:
5189 case RISCV::AIF_FCVT_RAST_PS:
5190 case RISCV::AIF_FCVT_SN16_PS:
5191 case RISCV::AIF_FCVT_SN8_PS:
5192 case RISCV::AIF_FCVT_UN10_PS:
5193 case RISCV::AIF_FCVT_UN16_PS:
5194 case RISCV::AIF_FCVT_UN24_PS:
5195 case RISCV::AIF_FCVT_UN2_PS:
5196 case RISCV::AIF_FCVT_UN8_PS:
5197 case RISCV::AIF_FEXP_PS:
5198 case RISCV::AIF_FFRC_PS:
5199 case RISCV::AIF_FLOG_PS:
5200 case RISCV::AIF_FLWG_PS:
5201 case RISCV::AIF_FLWL_PS:
5202 case RISCV::AIF_FNOT_PI:
5203 case RISCV::AIF_FPACKREPB_PI:
5204 case RISCV::AIF_FPACKREPH_PI:
5205 case RISCV::AIF_FRCP_PS:
5206 case RISCV::AIF_FRSQ_PS:
5207 case RISCV::AIF_FSAT8_PI:
5208 case RISCV::AIF_FSATU8_PI:
5209 case RISCV::AIF_FSETM_PI:
5210 case RISCV::AIF_FSIN_PS:
5211 case RISCV::AIF_FSQRT_PS:
5212 case RISCV::BREV8:
5213 case RISCV::CLS:
5214 case RISCV::CLSW:
5215 case RISCV::CLZ:
5216 case RISCV::CLZW:
5217 case RISCV::CPOP:
5218 case RISCV::CPOPW:
5219 case RISCV::CTZ:
5220 case RISCV::CTZW:
5221 case RISCV::CV_ABS:
5222 case RISCV::CV_ABS_B:
5223 case RISCV::CV_ABS_H:
5224 case RISCV::CV_CLB:
5225 case RISCV::CV_CNT:
5226 case RISCV::CV_CPLXCONJ:
5227 case RISCV::CV_EXTBS:
5228 case RISCV::CV_EXTBZ:
5229 case RISCV::CV_EXTHS:
5230 case RISCV::CV_EXTHZ:
5231 case RISCV::CV_FF1:
5232 case RISCV::CV_FL1:
5233 case RISCV::FCLASS_D:
5234 case RISCV::FCLASS_D_IN32X:
5235 case RISCV::FCLASS_D_INX:
5236 case RISCV::FCLASS_H:
5237 case RISCV::FCLASS_H_INX:
5238 case RISCV::FCLASS_Q:
5239 case RISCV::FCLASS_S:
5240 case RISCV::FCLASS_S_INX:
5241 case RISCV::FCVTMOD_W_D:
5242 case RISCV::FMVH_X_D:
5243 case RISCV::FMVH_X_Q:
5244 case RISCV::FMV_D_X:
5245 case RISCV::FMV_H_X:
5246 case RISCV::FMV_W_X:
5247 case RISCV::FMV_X_D:
5248 case RISCV::FMV_X_H:
5249 case RISCV::FMV_X_W:
5250 case RISCV::FMV_X_W_FPR64:
5251 case RISCV::HLVX_HU:
5252 case RISCV::HLVX_WU:
5253 case RISCV::HLV_B:
5254 case RISCV::HLV_BU:
5255 case RISCV::HLV_D:
5256 case RISCV::HLV_H:
5257 case RISCV::HLV_HU:
5258 case RISCV::HLV_W:
5259 case RISCV::HLV_WU:
5260 case RISCV::LB_AQ:
5261 case RISCV::LB_AQRL:
5262 case RISCV::LD_AQ:
5263 case RISCV::LD_AQRL:
5264 case RISCV::LH_AQ:
5265 case RISCV::LH_AQRL:
5266 case RISCV::LR_D:
5267 case RISCV::LR_D_AQ:
5268 case RISCV::LR_D_AQRL:
5269 case RISCV::LR_D_RL:
5270 case RISCV::LR_W:
5271 case RISCV::LR_W_AQ:
5272 case RISCV::LR_W_AQRL:
5273 case RISCV::LR_W_RL:
5274 case RISCV::LW_AQ:
5275 case RISCV::LW_AQRL:
5276 case RISCV::MOP_R_0:
5277 case RISCV::MOP_R_1:
5278 case RISCV::MOP_R_10:
5279 case RISCV::MOP_R_11:
5280 case RISCV::MOP_R_12:
5281 case RISCV::MOP_R_13:
5282 case RISCV::MOP_R_14:
5283 case RISCV::MOP_R_15:
5284 case RISCV::MOP_R_16:
5285 case RISCV::MOP_R_17:
5286 case RISCV::MOP_R_18:
5287 case RISCV::MOP_R_19:
5288 case RISCV::MOP_R_2:
5289 case RISCV::MOP_R_20:
5290 case RISCV::MOP_R_21:
5291 case RISCV::MOP_R_22:
5292 case RISCV::MOP_R_23:
5293 case RISCV::MOP_R_24:
5294 case RISCV::MOP_R_25:
5295 case RISCV::MOP_R_26:
5296 case RISCV::MOP_R_27:
5297 case RISCV::MOP_R_28:
5298 case RISCV::MOP_R_29:
5299 case RISCV::MOP_R_3:
5300 case RISCV::MOP_R_30:
5301 case RISCV::MOP_R_31:
5302 case RISCV::MOP_R_4:
5303 case RISCV::MOP_R_5:
5304 case RISCV::MOP_R_6:
5305 case RISCV::MOP_R_7:
5306 case RISCV::MOP_R_8:
5307 case RISCV::MOP_R_9:
5308 case RISCV::NDS_FMV_BF16_X:
5309 case RISCV::NDS_FMV_X_BF16:
5310 case RISCV::ORC_B:
5311 case RISCV::PSABS_B:
5312 case RISCV::PSABS_H:
5313 case RISCV::PSEXT_H_B:
5314 case RISCV::PSEXT_W_B:
5315 case RISCV::PSEXT_W_H:
5316 case RISCV::QC_BREV32:
5317 case RISCV::QC_CLO:
5318 case RISCV::QC_COMPRESS2:
5319 case RISCV::QC_COMPRESS3:
5320 case RISCV::QC_CTO:
5321 case RISCV::QC_EXPAND2:
5322 case RISCV::QC_EXPAND3:
5323 case RISCV::QC_NORM:
5324 case RISCV::QC_NORMEU:
5325 case RISCV::QC_NORMU:
5326 case RISCV::REV16:
5327 case RISCV::REV8_RV32:
5328 case RISCV::REV8_RV64:
5329 case RISCV::REV_RV32:
5330 case RISCV::REV_RV64:
5331 case RISCV::SEXT_B:
5332 case RISCV::SEXT_H:
5333 case RISCV::SF_VSETTK:
5334 case RISCV::SF_VSETTM:
5335 case RISCV::SF_VSETTN:
5336 case RISCV::SHA256SIG0:
5337 case RISCV::SHA256SIG1:
5338 case RISCV::SHA256SUM0:
5339 case RISCV::SHA256SUM1:
5340 case RISCV::SHA512SIG0:
5341 case RISCV::SHA512SIG1:
5342 case RISCV::SHA512SUM0:
5343 case RISCV::SHA512SUM1:
5344 case RISCV::SM3P0:
5345 case RISCV::SM3P1:
5346 case RISCV::TH_FF0:
5347 case RISCV::TH_FF1:
5348 case RISCV::TH_REV:
5349 case RISCV::TH_REVW:
5350 case RISCV::TH_TSTNBZ:
5351 case RISCV::UNZIP_RV32:
5352 case RISCV::ZEXT_H_RV32:
5353 case RISCV::ZEXT_H_RV64:
5354 case RISCV::ZIP_RV32: {
5355 // op: rs1
5356 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5357 Value |= (op & 0x1f) << 15;
5358 // op: rd
5359 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5360 Value |= (op & 0x1f) << 7;
5361 break;
5362 }
5363 case RISCV::QC_WRAPI: {
5364 // op: rs1
5365 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5366 Value |= (op & 0x1f) << 15;
5367 // op: rd
5368 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5369 Value |= (op & 0x1f) << 7;
5370 // op: imm11
5371 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5372 Value |= (op & 0x7ff) << 20;
5373 break;
5374 }
5375 case RISCV::ADDI:
5376 case RISCV::ADDIW:
5377 case RISCV::ANDI:
5378 case RISCV::CV_ELW:
5379 case RISCV::FLD:
5380 case RISCV::FLH:
5381 case RISCV::FLQ:
5382 case RISCV::FLW:
5383 case RISCV::JALR:
5384 case RISCV::LB:
5385 case RISCV::LBU:
5386 case RISCV::LD:
5387 case RISCV::LD_RV32:
5388 case RISCV::LH:
5389 case RISCV::LHU:
5390 case RISCV::LH_INX:
5391 case RISCV::LW:
5392 case RISCV::LWU:
5393 case RISCV::LW_INX:
5394 case RISCV::ORI:
5395 case RISCV::SLTI:
5396 case RISCV::SLTIU:
5397 case RISCV::XORI: {
5398 // op: rs1
5399 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5400 Value |= (op & 0x1f) << 15;
5401 // op: rd
5402 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5403 Value |= (op & 0x1f) << 7;
5404 // op: imm12
5405 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5406 Value |= (op & 0xfff) << 20;
5407 break;
5408 }
5409 case RISCV::QC_INW: {
5410 // op: rs1
5411 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5412 Value |= (op & 0x1f) << 15;
5413 // op: rd
5414 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5415 Value |= (op & 0x1f) << 7;
5416 // op: imm14
5417 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5418 Value |= (op & 0x3ffc) << 18;
5419 break;
5420 }
5421 case RISCV::CV_CLIP:
5422 case RISCV::CV_CLIPU: {
5423 // op: rs1
5424 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5425 Value |= (op & 0x1f) << 15;
5426 // op: rd
5427 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5428 Value |= (op & 0x1f) << 7;
5429 // op: imm5
5430 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5431 Value |= (op & 0x1f) << 20;
5432 break;
5433 }
5434 case RISCV::CV_ADD_SCI_B:
5435 case RISCV::CV_ADD_SCI_H:
5436 case RISCV::CV_AND_SCI_B:
5437 case RISCV::CV_AND_SCI_H:
5438 case RISCV::CV_AVGU_SCI_B:
5439 case RISCV::CV_AVGU_SCI_H:
5440 case RISCV::CV_AVG_SCI_B:
5441 case RISCV::CV_AVG_SCI_H:
5442 case RISCV::CV_CMPEQ_SCI_B:
5443 case RISCV::CV_CMPEQ_SCI_H:
5444 case RISCV::CV_CMPGEU_SCI_B:
5445 case RISCV::CV_CMPGEU_SCI_H:
5446 case RISCV::CV_CMPGE_SCI_B:
5447 case RISCV::CV_CMPGE_SCI_H:
5448 case RISCV::CV_CMPGTU_SCI_B:
5449 case RISCV::CV_CMPGTU_SCI_H:
5450 case RISCV::CV_CMPGT_SCI_B:
5451 case RISCV::CV_CMPGT_SCI_H:
5452 case RISCV::CV_CMPLEU_SCI_B:
5453 case RISCV::CV_CMPLEU_SCI_H:
5454 case RISCV::CV_CMPLE_SCI_B:
5455 case RISCV::CV_CMPLE_SCI_H:
5456 case RISCV::CV_CMPLTU_SCI_B:
5457 case RISCV::CV_CMPLTU_SCI_H:
5458 case RISCV::CV_CMPLT_SCI_B:
5459 case RISCV::CV_CMPLT_SCI_H:
5460 case RISCV::CV_CMPNE_SCI_B:
5461 case RISCV::CV_CMPNE_SCI_H:
5462 case RISCV::CV_DOTSP_SCI_B:
5463 case RISCV::CV_DOTSP_SCI_H:
5464 case RISCV::CV_DOTUP_SCI_B:
5465 case RISCV::CV_DOTUP_SCI_H:
5466 case RISCV::CV_DOTUSP_SCI_B:
5467 case RISCV::CV_DOTUSP_SCI_H:
5468 case RISCV::CV_EXTRACTU_B:
5469 case RISCV::CV_EXTRACTU_H:
5470 case RISCV::CV_EXTRACT_B:
5471 case RISCV::CV_EXTRACT_H:
5472 case RISCV::CV_MAXU_SCI_B:
5473 case RISCV::CV_MAXU_SCI_H:
5474 case RISCV::CV_MAX_SCI_B:
5475 case RISCV::CV_MAX_SCI_H:
5476 case RISCV::CV_MINU_SCI_B:
5477 case RISCV::CV_MINU_SCI_H:
5478 case RISCV::CV_MIN_SCI_B:
5479 case RISCV::CV_MIN_SCI_H:
5480 case RISCV::CV_OR_SCI_B:
5481 case RISCV::CV_OR_SCI_H:
5482 case RISCV::CV_SHUFFLEI0_SCI_B:
5483 case RISCV::CV_SHUFFLEI1_SCI_B:
5484 case RISCV::CV_SHUFFLEI2_SCI_B:
5485 case RISCV::CV_SHUFFLEI3_SCI_B:
5486 case RISCV::CV_SHUFFLE_SCI_H:
5487 case RISCV::CV_SLL_SCI_B:
5488 case RISCV::CV_SLL_SCI_H:
5489 case RISCV::CV_SRA_SCI_B:
5490 case RISCV::CV_SRA_SCI_H:
5491 case RISCV::CV_SRL_SCI_B:
5492 case RISCV::CV_SRL_SCI_H:
5493 case RISCV::CV_SUB_SCI_B:
5494 case RISCV::CV_SUB_SCI_H:
5495 case RISCV::CV_XOR_SCI_B:
5496 case RISCV::CV_XOR_SCI_H: {
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: imm6
5504 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5505 Value |= (op & 0x1) << 25;
5506 Value |= (op & 0x3e) << 19;
5507 break;
5508 }
5509 case RISCV::CV_BCLR:
5510 case RISCV::CV_BITREV:
5511 case RISCV::CV_BSET:
5512 case RISCV::CV_EXTRACT:
5513 case RISCV::CV_EXTRACTU: {
5514 // op: rs1
5515 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5516 Value |= (op & 0x1f) << 15;
5517 // op: rd
5518 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5519 Value |= (op & 0x1f) << 7;
5520 // op: is3
5521 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5522 Value |= (op & 0x1f) << 25;
5523 // op: is2
5524 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
5525 Value |= (op & 0x1f) << 20;
5526 break;
5527 }
5528 case RISCV::TH_EXT:
5529 case RISCV::TH_EXTU: {
5530 // op: rs1
5531 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5532 Value |= (op & 0x1f) << 15;
5533 // op: rd
5534 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5535 Value |= (op & 0x1f) << 7;
5536 // op: msb
5537 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5538 Value |= (op & 0x3f) << 26;
5539 // op: lsb
5540 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
5541 Value |= (op & 0x3f) << 20;
5542 break;
5543 }
5544 case RISCV::AES64KS1I: {
5545 // op: rs1
5546 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5547 Value |= (op & 0x1f) << 15;
5548 // op: rd
5549 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5550 Value |= (op & 0x1f) << 7;
5551 // op: rnum
5552 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5553 Value |= (op & 0xf) << 20;
5554 break;
5555 }
5556 case RISCV::PSATI_W:
5557 case RISCV::PSLLI_W:
5558 case RISCV::PSRAI_W:
5559 case RISCV::PSRARI_W:
5560 case RISCV::PSRLI_W:
5561 case RISCV::PSSLAI_W:
5562 case RISCV::PUSATI_W:
5563 case RISCV::RORIW:
5564 case RISCV::SATI_RV32:
5565 case RISCV::SLLIW:
5566 case RISCV::SRAIW:
5567 case RISCV::SRARI_RV32:
5568 case RISCV::SRLIW:
5569 case RISCV::SSLAI:
5570 case RISCV::TH_SRRIW:
5571 case RISCV::USATI_RV32: {
5572 // op: rs1
5573 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5574 Value |= (op & 0x1f) << 15;
5575 // op: rd
5576 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5577 Value |= (op & 0x1f) << 7;
5578 // op: shamt
5579 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5580 Value |= (op & 0x1f) << 20;
5581 break;
5582 }
5583 case RISCV::SATI_RV64:
5584 case RISCV::SRARI_RV64:
5585 case RISCV::USATI_RV64: {
5586 // op: rs1
5587 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5588 Value |= (op & 0x1f) << 15;
5589 // op: rd
5590 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5591 Value |= (op & 0x1f) << 7;
5592 // op: shamt
5593 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5594 Value |= (op & 0x3f) << 20;
5595 break;
5596 }
5597 case RISCV::PSLLI_B:
5598 case RISCV::PSRAI_B:
5599 case RISCV::PSRLI_B: {
5600 // op: rs1
5601 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5602 Value |= (op & 0x1f) << 15;
5603 // op: rd
5604 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5605 Value |= (op & 0x1f) << 7;
5606 // op: shamt
5607 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5608 Value |= (op & 0x7) << 20;
5609 break;
5610 }
5611 case RISCV::PSATI_H:
5612 case RISCV::PSLLI_H:
5613 case RISCV::PSRAI_H:
5614 case RISCV::PSRARI_H:
5615 case RISCV::PSRLI_H:
5616 case RISCV::PSSLAI_H:
5617 case RISCV::PUSATI_H: {
5618 // op: rs1
5619 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5620 Value |= (op & 0x1f) << 15;
5621 // op: rd
5622 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5623 Value |= (op & 0x1f) << 7;
5624 // op: shamt
5625 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5626 Value |= (op & 0xf) << 20;
5627 break;
5628 }
5629 case RISCV::QC_EXT:
5630 case RISCV::QC_EXTD:
5631 case RISCV::QC_EXTDU:
5632 case RISCV::QC_EXTU: {
5633 // op: rs1
5634 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5635 Value |= (op & 0x1f) << 15;
5636 // op: rd
5637 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5638 Value |= (op & 0x1f) << 7;
5639 // op: shamt
5640 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
5641 Value |= (op & 0x1f) << 20;
5642 // op: width
5643 op = getImmOpValueMinus1(MI, OpNo: 2, Fixups, STI);
5644 Value |= (op & 0x1f) << 25;
5645 break;
5646 }
5647 case RISCV::BCLRI:
5648 case RISCV::BEXTI:
5649 case RISCV::BINVI:
5650 case RISCV::BSETI:
5651 case RISCV::RORI:
5652 case RISCV::SLLI:
5653 case RISCV::SLLI_UW:
5654 case RISCV::SRAI:
5655 case RISCV::SRLI:
5656 case RISCV::TH_SRRI:
5657 case RISCV::TH_TST: {
5658 // op: rs1
5659 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5660 Value |= (op & 0x1f) << 15;
5661 // op: rd
5662 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5663 Value |= (op & 0x1f) << 7;
5664 // op: shamt
5665 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5666 Value |= (op & 0x3f) << 20;
5667 break;
5668 }
5669 case RISCV::VSETVLI: {
5670 // op: rs1
5671 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5672 Value |= (op & 0x1f) << 15;
5673 // op: rd
5674 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5675 Value |= (op & 0x1f) << 7;
5676 // op: vtypei
5677 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5678 Value |= (op & 0x7ff) << 20;
5679 break;
5680 }
5681 case RISCV::AIF_FROUND_PS: {
5682 // op: rs1
5683 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5684 Value |= (op & 0x1f) << 15;
5685 // op: rm
5686 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5687 Value |= (op & 0x7) << 12;
5688 // op: rd
5689 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5690 Value |= (op & 0x1f) << 7;
5691 break;
5692 }
5693 case RISCV::QC_E_SB:
5694 case RISCV::QC_E_SH:
5695 case RISCV::QC_E_SW: {
5696 // op: rs1
5697 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5698 Value |= (op & 0x1f) << 15;
5699 // op: rs2
5700 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5701 Value |= (op & 0x1f) << 20;
5702 // op: imm
5703 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5704 Value |= (op & 0x3fffc00) << 22;
5705 Value |= (op & 0x3e0) << 20;
5706 Value |= (op & 0x1f) << 7;
5707 break;
5708 }
5709 case RISCV::CV_SB_rr:
5710 case RISCV::CV_SH_rr:
5711 case RISCV::CV_SW_rr: {
5712 // op: rs1
5713 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5714 Value |= (op & 0x1f) << 15;
5715 // op: rs2
5716 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5717 Value |= (op & 0x1f) << 20;
5718 // op: rs3
5719 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5720 Value |= (op & 0x1f) << 7;
5721 break;
5722 }
5723 case RISCV::QC_OUTW: {
5724 // op: rs1
5725 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5726 Value |= (op & 0x1f) << 15;
5727 // op: rs2
5728 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5729 Value |= (op & 0x1f) << 7;
5730 // op: imm14
5731 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
5732 Value |= (op & 0x3ffc) << 18;
5733 break;
5734 }
5735 case RISCV::AIF_FSC32B_PS:
5736 case RISCV::AIF_FSC32H_PS:
5737 case RISCV::AIF_FSC32W_PS:
5738 case RISCV::AIF_FSCBG_PS:
5739 case RISCV::AIF_FSCBL_PS:
5740 case RISCV::AIF_FSCB_PS:
5741 case RISCV::AIF_FSCHG_PS:
5742 case RISCV::AIF_FSCHL_PS:
5743 case RISCV::AIF_FSCH_PS:
5744 case RISCV::AIF_FSCWG_PS:
5745 case RISCV::AIF_FSCWL_PS:
5746 case RISCV::AIF_FSCW_PS: {
5747 // op: rs1
5748 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5749 Value |= (op & 0x1f) << 15;
5750 // op: rs2
5751 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5752 Value |= (op & 0x1f) << 20;
5753 // op: rs3
5754 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5755 Value |= (op & 0x1f) << 7;
5756 break;
5757 }
5758 case RISCV::NDS_VLE4_V:
5759 case RISCV::SF_VTMV_V_T:
5760 case RISCV::VL1RE16_V:
5761 case RISCV::VL1RE32_V:
5762 case RISCV::VL1RE64_V:
5763 case RISCV::VL1RE8_V:
5764 case RISCV::VL2RE16_V:
5765 case RISCV::VL2RE32_V:
5766 case RISCV::VL2RE64_V:
5767 case RISCV::VL2RE8_V:
5768 case RISCV::VL4RE16_V:
5769 case RISCV::VL4RE32_V:
5770 case RISCV::VL4RE64_V:
5771 case RISCV::VL4RE8_V:
5772 case RISCV::VL8RE16_V:
5773 case RISCV::VL8RE32_V:
5774 case RISCV::VL8RE64_V:
5775 case RISCV::VL8RE8_V:
5776 case RISCV::VLM_V: {
5777 // op: rs1
5778 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5779 Value |= (op & 0x1f) << 15;
5780 // op: vd
5781 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5782 Value |= (op & 0x1f) << 7;
5783 break;
5784 }
5785 case RISCV::NDS_VLN8_V:
5786 case RISCV::NDS_VLNU8_V:
5787 case RISCV::VLE16FF_V:
5788 case RISCV::VLE16_V:
5789 case RISCV::VLE32FF_V:
5790 case RISCV::VLE32_V:
5791 case RISCV::VLE64FF_V:
5792 case RISCV::VLE64_V:
5793 case RISCV::VLE8FF_V:
5794 case RISCV::VLE8_V:
5795 case RISCV::VLSEG2E16FF_V:
5796 case RISCV::VLSEG2E16_V:
5797 case RISCV::VLSEG2E32FF_V:
5798 case RISCV::VLSEG2E32_V:
5799 case RISCV::VLSEG2E64FF_V:
5800 case RISCV::VLSEG2E64_V:
5801 case RISCV::VLSEG2E8FF_V:
5802 case RISCV::VLSEG2E8_V:
5803 case RISCV::VLSEG3E16FF_V:
5804 case RISCV::VLSEG3E16_V:
5805 case RISCV::VLSEG3E32FF_V:
5806 case RISCV::VLSEG3E32_V:
5807 case RISCV::VLSEG3E64FF_V:
5808 case RISCV::VLSEG3E64_V:
5809 case RISCV::VLSEG3E8FF_V:
5810 case RISCV::VLSEG3E8_V:
5811 case RISCV::VLSEG4E16FF_V:
5812 case RISCV::VLSEG4E16_V:
5813 case RISCV::VLSEG4E32FF_V:
5814 case RISCV::VLSEG4E32_V:
5815 case RISCV::VLSEG4E64FF_V:
5816 case RISCV::VLSEG4E64_V:
5817 case RISCV::VLSEG4E8FF_V:
5818 case RISCV::VLSEG4E8_V:
5819 case RISCV::VLSEG5E16FF_V:
5820 case RISCV::VLSEG5E16_V:
5821 case RISCV::VLSEG5E32FF_V:
5822 case RISCV::VLSEG5E32_V:
5823 case RISCV::VLSEG5E64FF_V:
5824 case RISCV::VLSEG5E64_V:
5825 case RISCV::VLSEG5E8FF_V:
5826 case RISCV::VLSEG5E8_V:
5827 case RISCV::VLSEG6E16FF_V:
5828 case RISCV::VLSEG6E16_V:
5829 case RISCV::VLSEG6E32FF_V:
5830 case RISCV::VLSEG6E32_V:
5831 case RISCV::VLSEG6E64FF_V:
5832 case RISCV::VLSEG6E64_V:
5833 case RISCV::VLSEG6E8FF_V:
5834 case RISCV::VLSEG6E8_V:
5835 case RISCV::VLSEG7E16FF_V:
5836 case RISCV::VLSEG7E16_V:
5837 case RISCV::VLSEG7E32FF_V:
5838 case RISCV::VLSEG7E32_V:
5839 case RISCV::VLSEG7E64FF_V:
5840 case RISCV::VLSEG7E64_V:
5841 case RISCV::VLSEG7E8FF_V:
5842 case RISCV::VLSEG7E8_V:
5843 case RISCV::VLSEG8E16FF_V:
5844 case RISCV::VLSEG8E16_V:
5845 case RISCV::VLSEG8E32FF_V:
5846 case RISCV::VLSEG8E32_V:
5847 case RISCV::VLSEG8E64FF_V:
5848 case RISCV::VLSEG8E64_V:
5849 case RISCV::VLSEG8E8FF_V:
5850 case RISCV::VLSEG8E8_V: {
5851 // op: rs1
5852 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5853 Value |= (op & 0x1f) << 15;
5854 // op: vd
5855 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5856 Value |= (op & 0x1f) << 7;
5857 // op: vm
5858 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
5859 Value |= (op & 0x1) << 25;
5860 break;
5861 }
5862 case RISCV::VLSE16_V:
5863 case RISCV::VLSE32_V:
5864 case RISCV::VLSE64_V:
5865 case RISCV::VLSE8_V:
5866 case RISCV::VLSSEG2E16_V:
5867 case RISCV::VLSSEG2E32_V:
5868 case RISCV::VLSSEG2E64_V:
5869 case RISCV::VLSSEG2E8_V:
5870 case RISCV::VLSSEG3E16_V:
5871 case RISCV::VLSSEG3E32_V:
5872 case RISCV::VLSSEG3E64_V:
5873 case RISCV::VLSSEG3E8_V:
5874 case RISCV::VLSSEG4E16_V:
5875 case RISCV::VLSSEG4E32_V:
5876 case RISCV::VLSSEG4E64_V:
5877 case RISCV::VLSSEG4E8_V:
5878 case RISCV::VLSSEG5E16_V:
5879 case RISCV::VLSSEG5E32_V:
5880 case RISCV::VLSSEG5E64_V:
5881 case RISCV::VLSSEG5E8_V:
5882 case RISCV::VLSSEG6E16_V:
5883 case RISCV::VLSSEG6E32_V:
5884 case RISCV::VLSSEG6E64_V:
5885 case RISCV::VLSSEG6E8_V:
5886 case RISCV::VLSSEG7E16_V:
5887 case RISCV::VLSSEG7E32_V:
5888 case RISCV::VLSSEG7E64_V:
5889 case RISCV::VLSSEG7E8_V:
5890 case RISCV::VLSSEG8E16_V:
5891 case RISCV::VLSSEG8E32_V:
5892 case RISCV::VLSSEG8E64_V:
5893 case RISCV::VLSSEG8E8_V: {
5894 // op: rs1
5895 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5896 Value |= (op & 0x1f) << 15;
5897 // op: vd
5898 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5899 Value |= (op & 0x1f) << 7;
5900 // op: vm
5901 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
5902 Value |= (op & 0x1) << 25;
5903 // op: rs2
5904 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5905 Value |= (op & 0x1f) << 20;
5906 break;
5907 }
5908 case RISCV::VLOXEI16_V:
5909 case RISCV::VLOXEI32_V:
5910 case RISCV::VLOXEI64_V:
5911 case RISCV::VLOXEI8_V:
5912 case RISCV::VLOXSEG2EI16_V:
5913 case RISCV::VLOXSEG2EI32_V:
5914 case RISCV::VLOXSEG2EI64_V:
5915 case RISCV::VLOXSEG2EI8_V:
5916 case RISCV::VLOXSEG3EI16_V:
5917 case RISCV::VLOXSEG3EI32_V:
5918 case RISCV::VLOXSEG3EI64_V:
5919 case RISCV::VLOXSEG3EI8_V:
5920 case RISCV::VLOXSEG4EI16_V:
5921 case RISCV::VLOXSEG4EI32_V:
5922 case RISCV::VLOXSEG4EI64_V:
5923 case RISCV::VLOXSEG4EI8_V:
5924 case RISCV::VLOXSEG5EI16_V:
5925 case RISCV::VLOXSEG5EI32_V:
5926 case RISCV::VLOXSEG5EI64_V:
5927 case RISCV::VLOXSEG5EI8_V:
5928 case RISCV::VLOXSEG6EI16_V:
5929 case RISCV::VLOXSEG6EI32_V:
5930 case RISCV::VLOXSEG6EI64_V:
5931 case RISCV::VLOXSEG6EI8_V:
5932 case RISCV::VLOXSEG7EI16_V:
5933 case RISCV::VLOXSEG7EI32_V:
5934 case RISCV::VLOXSEG7EI64_V:
5935 case RISCV::VLOXSEG7EI8_V:
5936 case RISCV::VLOXSEG8EI16_V:
5937 case RISCV::VLOXSEG8EI32_V:
5938 case RISCV::VLOXSEG8EI64_V:
5939 case RISCV::VLOXSEG8EI8_V:
5940 case RISCV::VLUXEI16_V:
5941 case RISCV::VLUXEI32_V:
5942 case RISCV::VLUXEI64_V:
5943 case RISCV::VLUXEI8_V:
5944 case RISCV::VLUXSEG2EI16_V:
5945 case RISCV::VLUXSEG2EI32_V:
5946 case RISCV::VLUXSEG2EI64_V:
5947 case RISCV::VLUXSEG2EI8_V:
5948 case RISCV::VLUXSEG3EI16_V:
5949 case RISCV::VLUXSEG3EI32_V:
5950 case RISCV::VLUXSEG3EI64_V:
5951 case RISCV::VLUXSEG3EI8_V:
5952 case RISCV::VLUXSEG4EI16_V:
5953 case RISCV::VLUXSEG4EI32_V:
5954 case RISCV::VLUXSEG4EI64_V:
5955 case RISCV::VLUXSEG4EI8_V:
5956 case RISCV::VLUXSEG5EI16_V:
5957 case RISCV::VLUXSEG5EI32_V:
5958 case RISCV::VLUXSEG5EI64_V:
5959 case RISCV::VLUXSEG5EI8_V:
5960 case RISCV::VLUXSEG6EI16_V:
5961 case RISCV::VLUXSEG6EI32_V:
5962 case RISCV::VLUXSEG6EI64_V:
5963 case RISCV::VLUXSEG6EI8_V:
5964 case RISCV::VLUXSEG7EI16_V:
5965 case RISCV::VLUXSEG7EI32_V:
5966 case RISCV::VLUXSEG7EI64_V:
5967 case RISCV::VLUXSEG7EI8_V:
5968 case RISCV::VLUXSEG8EI16_V:
5969 case RISCV::VLUXSEG8EI32_V:
5970 case RISCV::VLUXSEG8EI64_V:
5971 case RISCV::VLUXSEG8EI8_V: {
5972 // op: rs1
5973 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5974 Value |= (op & 0x1f) << 15;
5975 // op: vd
5976 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5977 Value |= (op & 0x1f) << 7;
5978 // op: vm
5979 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
5980 Value |= (op & 0x1) << 25;
5981 // op: vs2
5982 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
5983 Value |= (op & 0x1f) << 20;
5984 break;
5985 }
5986 case RISCV::VS1R_V:
5987 case RISCV::VS2R_V:
5988 case RISCV::VS4R_V:
5989 case RISCV::VS8R_V:
5990 case RISCV::VSM_V: {
5991 // op: rs1
5992 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
5993 Value |= (op & 0x1f) << 15;
5994 // op: vs3
5995 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
5996 Value |= (op & 0x1f) << 7;
5997 break;
5998 }
5999 case RISCV::VSE16_V:
6000 case RISCV::VSE32_V:
6001 case RISCV::VSE64_V:
6002 case RISCV::VSE8_V:
6003 case RISCV::VSSEG2E16_V:
6004 case RISCV::VSSEG2E32_V:
6005 case RISCV::VSSEG2E64_V:
6006 case RISCV::VSSEG2E8_V:
6007 case RISCV::VSSEG3E16_V:
6008 case RISCV::VSSEG3E32_V:
6009 case RISCV::VSSEG3E64_V:
6010 case RISCV::VSSEG3E8_V:
6011 case RISCV::VSSEG4E16_V:
6012 case RISCV::VSSEG4E32_V:
6013 case RISCV::VSSEG4E64_V:
6014 case RISCV::VSSEG4E8_V:
6015 case RISCV::VSSEG5E16_V:
6016 case RISCV::VSSEG5E32_V:
6017 case RISCV::VSSEG5E64_V:
6018 case RISCV::VSSEG5E8_V:
6019 case RISCV::VSSEG6E16_V:
6020 case RISCV::VSSEG6E32_V:
6021 case RISCV::VSSEG6E64_V:
6022 case RISCV::VSSEG6E8_V:
6023 case RISCV::VSSEG7E16_V:
6024 case RISCV::VSSEG7E32_V:
6025 case RISCV::VSSEG7E64_V:
6026 case RISCV::VSSEG7E8_V:
6027 case RISCV::VSSEG8E16_V:
6028 case RISCV::VSSEG8E32_V:
6029 case RISCV::VSSEG8E64_V:
6030 case RISCV::VSSEG8E8_V: {
6031 // op: rs1
6032 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6033 Value |= (op & 0x1f) << 15;
6034 // op: vs3
6035 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6036 Value |= (op & 0x1f) << 7;
6037 // op: vm
6038 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
6039 Value |= (op & 0x1) << 25;
6040 break;
6041 }
6042 case RISCV::VSSE16_V:
6043 case RISCV::VSSE32_V:
6044 case RISCV::VSSE64_V:
6045 case RISCV::VSSE8_V:
6046 case RISCV::VSSSEG2E16_V:
6047 case RISCV::VSSSEG2E32_V:
6048 case RISCV::VSSSEG2E64_V:
6049 case RISCV::VSSSEG2E8_V:
6050 case RISCV::VSSSEG3E16_V:
6051 case RISCV::VSSSEG3E32_V:
6052 case RISCV::VSSSEG3E64_V:
6053 case RISCV::VSSSEG3E8_V:
6054 case RISCV::VSSSEG4E16_V:
6055 case RISCV::VSSSEG4E32_V:
6056 case RISCV::VSSSEG4E64_V:
6057 case RISCV::VSSSEG4E8_V:
6058 case RISCV::VSSSEG5E16_V:
6059 case RISCV::VSSSEG5E32_V:
6060 case RISCV::VSSSEG5E64_V:
6061 case RISCV::VSSSEG5E8_V:
6062 case RISCV::VSSSEG6E16_V:
6063 case RISCV::VSSSEG6E32_V:
6064 case RISCV::VSSSEG6E64_V:
6065 case RISCV::VSSSEG6E8_V:
6066 case RISCV::VSSSEG7E16_V:
6067 case RISCV::VSSSEG7E32_V:
6068 case RISCV::VSSSEG7E64_V:
6069 case RISCV::VSSSEG7E8_V:
6070 case RISCV::VSSSEG8E16_V:
6071 case RISCV::VSSSEG8E32_V:
6072 case RISCV::VSSSEG8E64_V:
6073 case RISCV::VSSSEG8E8_V: {
6074 // op: rs1
6075 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6076 Value |= (op & 0x1f) << 15;
6077 // op: vs3
6078 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6079 Value |= (op & 0x1f) << 7;
6080 // op: vm
6081 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6082 Value |= (op & 0x1) << 25;
6083 // op: rs2
6084 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6085 Value |= (op & 0x1f) << 20;
6086 break;
6087 }
6088 case RISCV::VSOXEI16_V:
6089 case RISCV::VSOXEI32_V:
6090 case RISCV::VSOXEI64_V:
6091 case RISCV::VSOXEI8_V:
6092 case RISCV::VSOXSEG2EI16_V:
6093 case RISCV::VSOXSEG2EI32_V:
6094 case RISCV::VSOXSEG2EI64_V:
6095 case RISCV::VSOXSEG2EI8_V:
6096 case RISCV::VSOXSEG3EI16_V:
6097 case RISCV::VSOXSEG3EI32_V:
6098 case RISCV::VSOXSEG3EI64_V:
6099 case RISCV::VSOXSEG3EI8_V:
6100 case RISCV::VSOXSEG4EI16_V:
6101 case RISCV::VSOXSEG4EI32_V:
6102 case RISCV::VSOXSEG4EI64_V:
6103 case RISCV::VSOXSEG4EI8_V:
6104 case RISCV::VSOXSEG5EI16_V:
6105 case RISCV::VSOXSEG5EI32_V:
6106 case RISCV::VSOXSEG5EI64_V:
6107 case RISCV::VSOXSEG5EI8_V:
6108 case RISCV::VSOXSEG6EI16_V:
6109 case RISCV::VSOXSEG6EI32_V:
6110 case RISCV::VSOXSEG6EI64_V:
6111 case RISCV::VSOXSEG6EI8_V:
6112 case RISCV::VSOXSEG7EI16_V:
6113 case RISCV::VSOXSEG7EI32_V:
6114 case RISCV::VSOXSEG7EI64_V:
6115 case RISCV::VSOXSEG7EI8_V:
6116 case RISCV::VSOXSEG8EI16_V:
6117 case RISCV::VSOXSEG8EI32_V:
6118 case RISCV::VSOXSEG8EI64_V:
6119 case RISCV::VSOXSEG8EI8_V:
6120 case RISCV::VSUXEI16_V:
6121 case RISCV::VSUXEI32_V:
6122 case RISCV::VSUXEI64_V:
6123 case RISCV::VSUXEI8_V:
6124 case RISCV::VSUXSEG2EI16_V:
6125 case RISCV::VSUXSEG2EI32_V:
6126 case RISCV::VSUXSEG2EI64_V:
6127 case RISCV::VSUXSEG2EI8_V:
6128 case RISCV::VSUXSEG3EI16_V:
6129 case RISCV::VSUXSEG3EI32_V:
6130 case RISCV::VSUXSEG3EI64_V:
6131 case RISCV::VSUXSEG3EI8_V:
6132 case RISCV::VSUXSEG4EI16_V:
6133 case RISCV::VSUXSEG4EI32_V:
6134 case RISCV::VSUXSEG4EI64_V:
6135 case RISCV::VSUXSEG4EI8_V:
6136 case RISCV::VSUXSEG5EI16_V:
6137 case RISCV::VSUXSEG5EI32_V:
6138 case RISCV::VSUXSEG5EI64_V:
6139 case RISCV::VSUXSEG5EI8_V:
6140 case RISCV::VSUXSEG6EI16_V:
6141 case RISCV::VSUXSEG6EI32_V:
6142 case RISCV::VSUXSEG6EI64_V:
6143 case RISCV::VSUXSEG6EI8_V:
6144 case RISCV::VSUXSEG7EI16_V:
6145 case RISCV::VSUXSEG7EI32_V:
6146 case RISCV::VSUXSEG7EI64_V:
6147 case RISCV::VSUXSEG7EI8_V:
6148 case RISCV::VSUXSEG8EI16_V:
6149 case RISCV::VSUXSEG8EI32_V:
6150 case RISCV::VSUXSEG8EI64_V:
6151 case RISCV::VSUXSEG8EI8_V: {
6152 // op: rs1
6153 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6154 Value |= (op & 0x1f) << 15;
6155 // op: vs3
6156 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6157 Value |= (op & 0x1f) << 7;
6158 // op: vm
6159 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
6160 Value |= (op & 0x1) << 25;
6161 // op: vs2
6162 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6163 Value |= (op & 0x1f) << 20;
6164 break;
6165 }
6166 case RISCV::C_ADD: {
6167 // op: rs1
6168 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6169 Value |= (op & 0x1f) << 7;
6170 // op: rs2
6171 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6172 Value |= (op & 0x1f) << 2;
6173 break;
6174 }
6175 case RISCV::AIF_MASKPOPC:
6176 case RISCV::AIF_MASKPOPCZ: {
6177 // op: rs1
6178 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6179 Value |= (op & 0x7) << 15;
6180 // op: rd
6181 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6182 Value |= (op & 0x1f) << 7;
6183 break;
6184 }
6185 case RISCV::AIF_MASKNOT: {
6186 // op: rs1
6187 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6188 Value |= (op & 0x7) << 15;
6189 // op: rd
6190 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6191 Value |= (op & 0x7) << 7;
6192 break;
6193 }
6194 case RISCV::QC_C_BEXTI:
6195 case RISCV::QC_C_BSETI: {
6196 // op: rs1
6197 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6198 Value |= (op & 0x7) << 7;
6199 // op: shamt
6200 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6201 Value |= (op & 0x1f) << 2;
6202 break;
6203 }
6204 case RISCV::AIF_FBC_PS:
6205 case RISCV::AIF_FLQ2:
6206 case RISCV::AIF_FLW_PS: {
6207 // op: rs1
6208 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6209 Value |= (op & 0x1f) << 15;
6210 // op: rd
6211 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6212 Value |= (op & 0x1f) << 7;
6213 // op: imm12
6214 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6215 Value |= (op & 0xfff) << 20;
6216 break;
6217 }
6218 case RISCV::CV_LBU_ri_inc:
6219 case RISCV::CV_LB_ri_inc:
6220 case RISCV::CV_LHU_ri_inc:
6221 case RISCV::CV_LH_ri_inc:
6222 case RISCV::CV_LW_ri_inc: {
6223 // op: rs1
6224 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6225 Value |= (op & 0x1f) << 15;
6226 // op: rd
6227 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6228 Value |= (op & 0x1f) << 7;
6229 // op: imm12
6230 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6231 Value |= (op & 0xfff) << 20;
6232 break;
6233 }
6234 case RISCV::CSRRC:
6235 case RISCV::CSRRS:
6236 case RISCV::CSRRW: {
6237 // op: rs1
6238 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6239 Value |= (op & 0x1f) << 15;
6240 // op: rd
6241 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6242 Value |= (op & 0x1f) << 7;
6243 // op: imm12
6244 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6245 Value |= (op & 0xfff) << 20;
6246 break;
6247 }
6248 case RISCV::TH_LBIA:
6249 case RISCV::TH_LBIB:
6250 case RISCV::TH_LBUIA:
6251 case RISCV::TH_LBUIB:
6252 case RISCV::TH_LDIA:
6253 case RISCV::TH_LDIB:
6254 case RISCV::TH_LHIA:
6255 case RISCV::TH_LHIB:
6256 case RISCV::TH_LHUIA:
6257 case RISCV::TH_LHUIB:
6258 case RISCV::TH_LWIA:
6259 case RISCV::TH_LWIB:
6260 case RISCV::TH_LWUIA:
6261 case RISCV::TH_LWUIB: {
6262 // op: rs1
6263 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6264 Value |= (op & 0x1f) << 15;
6265 // op: rd
6266 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6267 Value |= (op & 0x1f) << 7;
6268 // op: simm5
6269 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6270 Value |= (op & 0x1f) << 20;
6271 // op: uimm2
6272 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6273 Value |= (op & 0x3) << 25;
6274 break;
6275 }
6276 case RISCV::QC_INSBRI: {
6277 // op: rs1
6278 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6279 Value |= (op & 0x1f) << 15;
6280 // op: rd
6281 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6282 Value |= (op & 0x1f) << 7;
6283 // op: imm11
6284 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6285 Value |= (op & 0x7ff) << 20;
6286 break;
6287 }
6288 case RISCV::QC_MULIADD: {
6289 // op: rs1
6290 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6291 Value |= (op & 0x1f) << 15;
6292 // op: rd
6293 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6294 Value |= (op & 0x1f) << 7;
6295 // op: imm12
6296 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6297 Value |= (op & 0xfff) << 20;
6298 break;
6299 }
6300 case RISCV::CV_INSERT_B:
6301 case RISCV::CV_INSERT_H:
6302 case RISCV::CV_SDOTSP_SCI_B:
6303 case RISCV::CV_SDOTSP_SCI_H:
6304 case RISCV::CV_SDOTUP_SCI_B:
6305 case RISCV::CV_SDOTUP_SCI_H:
6306 case RISCV::CV_SDOTUSP_SCI_B:
6307 case RISCV::CV_SDOTUSP_SCI_H: {
6308 // op: rs1
6309 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6310 Value |= (op & 0x1f) << 15;
6311 // op: rd
6312 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6313 Value |= (op & 0x1f) << 7;
6314 // op: imm6
6315 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6316 Value |= (op & 0x1) << 25;
6317 Value |= (op & 0x3e) << 19;
6318 break;
6319 }
6320 case RISCV::CV_INSERT: {
6321 // op: rs1
6322 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6323 Value |= (op & 0x1f) << 15;
6324 // op: rd
6325 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6326 Value |= (op & 0x1f) << 7;
6327 // op: is3
6328 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6329 Value |= (op & 0x1f) << 25;
6330 // op: is2
6331 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6332 Value |= (op & 0x1f) << 20;
6333 break;
6334 }
6335 case RISCV::QC_INSB:
6336 case RISCV::QC_INSBH: {
6337 // op: rs1
6338 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6339 Value |= (op & 0x1f) << 15;
6340 // op: rd
6341 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6342 Value |= (op & 0x1f) << 7;
6343 // op: shamt
6344 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6345 Value |= (op & 0x1f) << 20;
6346 // op: width
6347 op = getImmOpValueMinus1(MI, OpNo: 3, Fixups, STI);
6348 Value |= (op & 0x1f) << 25;
6349 break;
6350 }
6351 case RISCV::QC_SELECTIIEQ:
6352 case RISCV::QC_SELECTIINE: {
6353 // op: rs1
6354 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6355 Value |= (op & 0x1f) << 15;
6356 // op: rd
6357 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6358 Value |= (op & 0x1f) << 7;
6359 // op: simm1
6360 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6361 Value |= (op & 0x1f) << 20;
6362 // op: simm2
6363 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6364 Value |= (op & 0x1f) << 27;
6365 break;
6366 }
6367 case RISCV::TH_SBIA:
6368 case RISCV::TH_SBIB:
6369 case RISCV::TH_SDIA:
6370 case RISCV::TH_SDIB:
6371 case RISCV::TH_SHIA:
6372 case RISCV::TH_SHIB:
6373 case RISCV::TH_SWIA:
6374 case RISCV::TH_SWIB: {
6375 // op: rs1
6376 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6377 Value |= (op & 0x1f) << 15;
6378 // op: rd
6379 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6380 Value |= (op & 0x1f) << 7;
6381 // op: simm5
6382 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6383 Value |= (op & 0x1f) << 20;
6384 // op: uimm2
6385 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6386 Value |= (op & 0x3) << 25;
6387 break;
6388 }
6389 case RISCV::SF_VC_I: {
6390 // op: rs2
6391 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6392 Value |= (op & 0x1f) << 20;
6393 // op: rs1
6394 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6395 Value |= (op & 0x1f) << 15;
6396 // op: rd
6397 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6398 Value |= (op & 0x1f) << 7;
6399 // op: funct6_lo2
6400 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
6401 Value |= (op & 0x3) << 26;
6402 break;
6403 }
6404 case RISCV::SF_VC_X: {
6405 // op: rs2
6406 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6407 Value |= (op & 0x1f) << 20;
6408 // op: rs1
6409 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
6410 Value |= (op & 0x1f) << 15;
6411 // op: rd
6412 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6413 Value |= (op & 0x1f) << 7;
6414 // op: funct6_lo2
6415 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
6416 Value |= (op & 0x3) << 26;
6417 break;
6418 }
6419 case RISCV::SF_VC_V_I: {
6420 // op: rs2
6421 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6422 Value |= (op & 0x1f) << 20;
6423 // op: rs1
6424 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6425 Value |= (op & 0x1f) << 15;
6426 // op: rd
6427 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6428 Value |= (op & 0x1f) << 7;
6429 // op: funct6_lo2
6430 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6431 Value |= (op & 0x3) << 26;
6432 break;
6433 }
6434 case RISCV::SF_VC_V_X: {
6435 // op: rs2
6436 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6437 Value |= (op & 0x1f) << 20;
6438 // op: rs1
6439 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
6440 Value |= (op & 0x1f) << 15;
6441 // op: rd
6442 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6443 Value |= (op & 0x1f) << 7;
6444 // op: funct6_lo2
6445 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6446 Value |= (op & 0x3) << 26;
6447 break;
6448 }
6449 case RISCV::QC_LIEQI:
6450 case RISCV::QC_LIGEI:
6451 case RISCV::QC_LIGEUI:
6452 case RISCV::QC_LILTI:
6453 case RISCV::QC_LILTUI:
6454 case RISCV::QC_LINEI: {
6455 // op: rs2
6456 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6457 Value |= (op & 0x1f) << 20;
6458 // op: rs1
6459 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6460 Value |= (op & 0x1f) << 15;
6461 // op: rd
6462 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6463 Value |= (op & 0x1f) << 7;
6464 // op: simm
6465 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
6466 Value |= (op & 0x1f) << 27;
6467 break;
6468 }
6469 case RISCV::SSPUSH: {
6470 // op: rs2
6471 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6472 Value |= (op & 0x1f) << 20;
6473 break;
6474 }
6475 case RISCV::AIF_SBG:
6476 case RISCV::AIF_SBL:
6477 case RISCV::AIF_SHG:
6478 case RISCV::AIF_SHL:
6479 case RISCV::HSV_B:
6480 case RISCV::HSV_D:
6481 case RISCV::HSV_H:
6482 case RISCV::HSV_W:
6483 case RISCV::SB_AQRL:
6484 case RISCV::SB_RL:
6485 case RISCV::SD_AQRL:
6486 case RISCV::SD_RL:
6487 case RISCV::SF_VLTE16:
6488 case RISCV::SF_VLTE32:
6489 case RISCV::SF_VLTE64:
6490 case RISCV::SF_VLTE8:
6491 case RISCV::SF_VSTE16:
6492 case RISCV::SF_VSTE32:
6493 case RISCV::SF_VSTE64:
6494 case RISCV::SF_VSTE8:
6495 case RISCV::SH_AQRL:
6496 case RISCV::SH_RL:
6497 case RISCV::SW_AQRL:
6498 case RISCV::SW_RL: {
6499 // op: rs2
6500 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6501 Value |= (op & 0x1f) << 20;
6502 // op: rs1
6503 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6504 Value |= (op & 0x1f) << 15;
6505 break;
6506 }
6507 case RISCV::QK_C_SB: {
6508 // op: rs2
6509 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6510 Value |= (op & 0x7) << 2;
6511 // op: rs1
6512 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6513 Value |= (op & 0x7) << 7;
6514 // op: imm
6515 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6516 Value |= (op & 0x1) << 12;
6517 Value |= (op & 0x18) << 7;
6518 Value |= (op & 0x6) << 4;
6519 break;
6520 }
6521 case RISCV::C_SB: {
6522 // op: rs2
6523 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6524 Value |= (op & 0x7) << 2;
6525 // op: rs1
6526 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6527 Value |= (op & 0x7) << 7;
6528 // op: imm
6529 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6530 Value |= (op & 0x1) << 6;
6531 Value |= (op & 0x2) << 4;
6532 break;
6533 }
6534 case RISCV::C_SH:
6535 case RISCV::C_SH_INX: {
6536 // op: rs2
6537 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6538 Value |= (op & 0x7) << 2;
6539 // op: rs1
6540 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6541 Value |= (op & 0x7) << 7;
6542 // op: imm
6543 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6544 Value |= (op & 0x2) << 4;
6545 break;
6546 }
6547 case RISCV::C_FSW:
6548 case RISCV::C_SW:
6549 case RISCV::C_SW_INX: {
6550 // op: rs2
6551 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6552 Value |= (op & 0x7) << 2;
6553 // op: rs1
6554 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6555 Value |= (op & 0x7) << 7;
6556 // op: imm
6557 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6558 Value |= (op & 0x38) << 7;
6559 Value |= (op & 0x4) << 4;
6560 Value |= (op & 0x40) >> 1;
6561 break;
6562 }
6563 case RISCV::QK_C_SH: {
6564 // op: rs2
6565 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6566 Value |= (op & 0x7) << 2;
6567 // op: rs1
6568 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6569 Value |= (op & 0x7) << 7;
6570 // op: imm
6571 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6572 Value |= (op & 0x38) << 7;
6573 Value |= (op & 0x6) << 4;
6574 break;
6575 }
6576 case RISCV::C_FSD:
6577 case RISCV::C_SD:
6578 case RISCV::C_SD_RV32: {
6579 // op: rs2
6580 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6581 Value |= (op & 0x7) << 2;
6582 // op: rs1
6583 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6584 Value |= (op & 0x7) << 7;
6585 // op: imm
6586 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
6587 Value |= (op & 0x38) << 7;
6588 Value |= (op & 0xc0) >> 1;
6589 break;
6590 }
6591 case RISCV::NDS_FCVT_BF16_S:
6592 case RISCV::NDS_FCVT_S_BF16: {
6593 // op: rs2
6594 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6595 Value |= (op & 0x1f) << 20;
6596 // op: rd
6597 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6598 Value |= (op & 0x1f) << 7;
6599 break;
6600 }
6601 case RISCV::HFENCE_GVMA:
6602 case RISCV::HFENCE_VVMA:
6603 case RISCV::HINVAL_GVMA:
6604 case RISCV::HINVAL_VVMA:
6605 case RISCV::SFENCE_VMA:
6606 case RISCV::SF_VTMV_T_V:
6607 case RISCV::SINVAL_VMA:
6608 case RISCV::TH_SFENCE_VMAS: {
6609 // op: rs2
6610 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6611 Value |= (op & 0x1f) << 20;
6612 // op: rs1
6613 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6614 Value |= (op & 0x1f) << 15;
6615 break;
6616 }
6617 case RISCV::AIF_AMOADDG_D:
6618 case RISCV::AIF_AMOADDG_W:
6619 case RISCV::AIF_AMOADDL_D:
6620 case RISCV::AIF_AMOADDL_W:
6621 case RISCV::AIF_AMOANDG_D:
6622 case RISCV::AIF_AMOANDG_W:
6623 case RISCV::AIF_AMOANDL_D:
6624 case RISCV::AIF_AMOANDL_W:
6625 case RISCV::AIF_AMOCMPSWAPG_D:
6626 case RISCV::AIF_AMOCMPSWAPG_W:
6627 case RISCV::AIF_AMOCMPSWAPL_D:
6628 case RISCV::AIF_AMOCMPSWAPL_W:
6629 case RISCV::AIF_AMOMAXG_D:
6630 case RISCV::AIF_AMOMAXG_W:
6631 case RISCV::AIF_AMOMAXL_D:
6632 case RISCV::AIF_AMOMAXL_W:
6633 case RISCV::AIF_AMOMAXUG_D:
6634 case RISCV::AIF_AMOMAXUG_W:
6635 case RISCV::AIF_AMOMAXUL_D:
6636 case RISCV::AIF_AMOMAXUL_W:
6637 case RISCV::AIF_AMOMING_D:
6638 case RISCV::AIF_AMOMING_W:
6639 case RISCV::AIF_AMOMINL_D:
6640 case RISCV::AIF_AMOMINL_W:
6641 case RISCV::AIF_AMOMINUG_D:
6642 case RISCV::AIF_AMOMINUG_W:
6643 case RISCV::AIF_AMOMINUL_D:
6644 case RISCV::AIF_AMOMINUL_W:
6645 case RISCV::AIF_AMOORG_D:
6646 case RISCV::AIF_AMOORG_W:
6647 case RISCV::AIF_AMOORL_D:
6648 case RISCV::AIF_AMOORL_W:
6649 case RISCV::AIF_AMOSWAPG_D:
6650 case RISCV::AIF_AMOSWAPG_W:
6651 case RISCV::AIF_AMOSWAPL_D:
6652 case RISCV::AIF_AMOSWAPL_W:
6653 case RISCV::AIF_AMOXORG_D:
6654 case RISCV::AIF_AMOXORG_W:
6655 case RISCV::AIF_AMOXORL_D:
6656 case RISCV::AIF_AMOXORL_W:
6657 case RISCV::AMOADD_B:
6658 case RISCV::AMOADD_B_AQ:
6659 case RISCV::AMOADD_B_AQRL:
6660 case RISCV::AMOADD_B_RL:
6661 case RISCV::AMOADD_D:
6662 case RISCV::AMOADD_D_AQ:
6663 case RISCV::AMOADD_D_AQRL:
6664 case RISCV::AMOADD_D_RL:
6665 case RISCV::AMOADD_H:
6666 case RISCV::AMOADD_H_AQ:
6667 case RISCV::AMOADD_H_AQRL:
6668 case RISCV::AMOADD_H_RL:
6669 case RISCV::AMOADD_W:
6670 case RISCV::AMOADD_W_AQ:
6671 case RISCV::AMOADD_W_AQRL:
6672 case RISCV::AMOADD_W_RL:
6673 case RISCV::AMOAND_B:
6674 case RISCV::AMOAND_B_AQ:
6675 case RISCV::AMOAND_B_AQRL:
6676 case RISCV::AMOAND_B_RL:
6677 case RISCV::AMOAND_D:
6678 case RISCV::AMOAND_D_AQ:
6679 case RISCV::AMOAND_D_AQRL:
6680 case RISCV::AMOAND_D_RL:
6681 case RISCV::AMOAND_H:
6682 case RISCV::AMOAND_H_AQ:
6683 case RISCV::AMOAND_H_AQRL:
6684 case RISCV::AMOAND_H_RL:
6685 case RISCV::AMOAND_W:
6686 case RISCV::AMOAND_W_AQ:
6687 case RISCV::AMOAND_W_AQRL:
6688 case RISCV::AMOAND_W_RL:
6689 case RISCV::AMOMAXU_B:
6690 case RISCV::AMOMAXU_B_AQ:
6691 case RISCV::AMOMAXU_B_AQRL:
6692 case RISCV::AMOMAXU_B_RL:
6693 case RISCV::AMOMAXU_D:
6694 case RISCV::AMOMAXU_D_AQ:
6695 case RISCV::AMOMAXU_D_AQRL:
6696 case RISCV::AMOMAXU_D_RL:
6697 case RISCV::AMOMAXU_H:
6698 case RISCV::AMOMAXU_H_AQ:
6699 case RISCV::AMOMAXU_H_AQRL:
6700 case RISCV::AMOMAXU_H_RL:
6701 case RISCV::AMOMAXU_W:
6702 case RISCV::AMOMAXU_W_AQ:
6703 case RISCV::AMOMAXU_W_AQRL:
6704 case RISCV::AMOMAXU_W_RL:
6705 case RISCV::AMOMAX_B:
6706 case RISCV::AMOMAX_B_AQ:
6707 case RISCV::AMOMAX_B_AQRL:
6708 case RISCV::AMOMAX_B_RL:
6709 case RISCV::AMOMAX_D:
6710 case RISCV::AMOMAX_D_AQ:
6711 case RISCV::AMOMAX_D_AQRL:
6712 case RISCV::AMOMAX_D_RL:
6713 case RISCV::AMOMAX_H:
6714 case RISCV::AMOMAX_H_AQ:
6715 case RISCV::AMOMAX_H_AQRL:
6716 case RISCV::AMOMAX_H_RL:
6717 case RISCV::AMOMAX_W:
6718 case RISCV::AMOMAX_W_AQ:
6719 case RISCV::AMOMAX_W_AQRL:
6720 case RISCV::AMOMAX_W_RL:
6721 case RISCV::AMOMINU_B:
6722 case RISCV::AMOMINU_B_AQ:
6723 case RISCV::AMOMINU_B_AQRL:
6724 case RISCV::AMOMINU_B_RL:
6725 case RISCV::AMOMINU_D:
6726 case RISCV::AMOMINU_D_AQ:
6727 case RISCV::AMOMINU_D_AQRL:
6728 case RISCV::AMOMINU_D_RL:
6729 case RISCV::AMOMINU_H:
6730 case RISCV::AMOMINU_H_AQ:
6731 case RISCV::AMOMINU_H_AQRL:
6732 case RISCV::AMOMINU_H_RL:
6733 case RISCV::AMOMINU_W:
6734 case RISCV::AMOMINU_W_AQ:
6735 case RISCV::AMOMINU_W_AQRL:
6736 case RISCV::AMOMINU_W_RL:
6737 case RISCV::AMOMIN_B:
6738 case RISCV::AMOMIN_B_AQ:
6739 case RISCV::AMOMIN_B_AQRL:
6740 case RISCV::AMOMIN_B_RL:
6741 case RISCV::AMOMIN_D:
6742 case RISCV::AMOMIN_D_AQ:
6743 case RISCV::AMOMIN_D_AQRL:
6744 case RISCV::AMOMIN_D_RL:
6745 case RISCV::AMOMIN_H:
6746 case RISCV::AMOMIN_H_AQ:
6747 case RISCV::AMOMIN_H_AQRL:
6748 case RISCV::AMOMIN_H_RL:
6749 case RISCV::AMOMIN_W:
6750 case RISCV::AMOMIN_W_AQ:
6751 case RISCV::AMOMIN_W_AQRL:
6752 case RISCV::AMOMIN_W_RL:
6753 case RISCV::AMOOR_B:
6754 case RISCV::AMOOR_B_AQ:
6755 case RISCV::AMOOR_B_AQRL:
6756 case RISCV::AMOOR_B_RL:
6757 case RISCV::AMOOR_D:
6758 case RISCV::AMOOR_D_AQ:
6759 case RISCV::AMOOR_D_AQRL:
6760 case RISCV::AMOOR_D_RL:
6761 case RISCV::AMOOR_H:
6762 case RISCV::AMOOR_H_AQ:
6763 case RISCV::AMOOR_H_AQRL:
6764 case RISCV::AMOOR_H_RL:
6765 case RISCV::AMOOR_W:
6766 case RISCV::AMOOR_W_AQ:
6767 case RISCV::AMOOR_W_AQRL:
6768 case RISCV::AMOOR_W_RL:
6769 case RISCV::AMOSWAP_B:
6770 case RISCV::AMOSWAP_B_AQ:
6771 case RISCV::AMOSWAP_B_AQRL:
6772 case RISCV::AMOSWAP_B_RL:
6773 case RISCV::AMOSWAP_D:
6774 case RISCV::AMOSWAP_D_AQ:
6775 case RISCV::AMOSWAP_D_AQRL:
6776 case RISCV::AMOSWAP_D_RL:
6777 case RISCV::AMOSWAP_H:
6778 case RISCV::AMOSWAP_H_AQ:
6779 case RISCV::AMOSWAP_H_AQRL:
6780 case RISCV::AMOSWAP_H_RL:
6781 case RISCV::AMOSWAP_W:
6782 case RISCV::AMOSWAP_W_AQ:
6783 case RISCV::AMOSWAP_W_AQRL:
6784 case RISCV::AMOSWAP_W_RL:
6785 case RISCV::AMOXOR_B:
6786 case RISCV::AMOXOR_B_AQ:
6787 case RISCV::AMOXOR_B_AQRL:
6788 case RISCV::AMOXOR_B_RL:
6789 case RISCV::AMOXOR_D:
6790 case RISCV::AMOXOR_D_AQ:
6791 case RISCV::AMOXOR_D_AQRL:
6792 case RISCV::AMOXOR_D_RL:
6793 case RISCV::AMOXOR_H:
6794 case RISCV::AMOXOR_H_AQ:
6795 case RISCV::AMOXOR_H_AQRL:
6796 case RISCV::AMOXOR_H_RL:
6797 case RISCV::AMOXOR_W:
6798 case RISCV::AMOXOR_W_AQ:
6799 case RISCV::AMOXOR_W_AQRL:
6800 case RISCV::AMOXOR_W_RL:
6801 case RISCV::NDS_LEA_B_ZE:
6802 case RISCV::NDS_LEA_D:
6803 case RISCV::NDS_LEA_D_ZE:
6804 case RISCV::NDS_LEA_H:
6805 case RISCV::NDS_LEA_H_ZE:
6806 case RISCV::NDS_LEA_W:
6807 case RISCV::NDS_LEA_W_ZE:
6808 case RISCV::SC_D:
6809 case RISCV::SC_D_AQ:
6810 case RISCV::SC_D_AQRL:
6811 case RISCV::SC_D_RL:
6812 case RISCV::SC_W:
6813 case RISCV::SC_W_AQ:
6814 case RISCV::SC_W_AQRL:
6815 case RISCV::SC_W_RL:
6816 case RISCV::SSAMOSWAP_D:
6817 case RISCV::SSAMOSWAP_D_AQ:
6818 case RISCV::SSAMOSWAP_D_AQRL:
6819 case RISCV::SSAMOSWAP_D_RL:
6820 case RISCV::SSAMOSWAP_W:
6821 case RISCV::SSAMOSWAP_W_AQ:
6822 case RISCV::SSAMOSWAP_W_AQRL:
6823 case RISCV::SSAMOSWAP_W_RL: {
6824 // op: rs2
6825 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6826 Value |= (op & 0x1f) << 20;
6827 // op: rs1
6828 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6829 Value |= (op & 0x1f) << 15;
6830 // op: rd
6831 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6832 Value |= (op & 0x1f) << 7;
6833 break;
6834 }
6835 case RISCV::TH_LDD:
6836 case RISCV::TH_LWD:
6837 case RISCV::TH_LWUD:
6838 case RISCV::TH_SDD:
6839 case RISCV::TH_SWD: {
6840 // op: rs2
6841 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6842 Value |= (op & 0x1f) << 20;
6843 // op: rs1
6844 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6845 Value |= (op & 0x1f) << 15;
6846 // op: rd
6847 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6848 Value |= (op & 0x1f) << 7;
6849 // op: uimm2
6850 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6851 Value |= (op & 0x3) << 25;
6852 break;
6853 }
6854 case RISCV::CM_MVA01S:
6855 case RISCV::CM_MVSA01:
6856 case RISCV::QC_CM_MVA01S:
6857 case RISCV::QC_CM_MVSA01: {
6858 // op: rs2
6859 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6860 Value |= (op & 0x7) << 2;
6861 // op: rs1
6862 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6863 Value |= (op & 0x7) << 7;
6864 break;
6865 }
6866 case RISCV::QC_CSRRWRI: {
6867 // op: rs2
6868 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6869 Value |= (op & 0x1f) << 20;
6870 // op: rs1
6871 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6872 Value |= (op & 0x1f) << 15;
6873 // op: rd
6874 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6875 Value |= (op & 0x1f) << 7;
6876 break;
6877 }
6878 case RISCV::SF_VC_IV: {
6879 // op: rs2
6880 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6881 Value |= (op & 0x1f) << 20;
6882 // op: rs1
6883 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6884 Value |= (op & 0x1f) << 15;
6885 // op: rd
6886 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6887 Value |= (op & 0x1f) << 7;
6888 // op: funct6_lo2
6889 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
6890 Value |= (op & 0x3) << 26;
6891 break;
6892 }
6893 case RISCV::SF_VC_V_IV: {
6894 // op: rs2
6895 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6896 Value |= (op & 0x1f) << 20;
6897 // op: rs1
6898 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6899 Value |= (op & 0x1f) << 15;
6900 // op: rd
6901 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6902 Value |= (op & 0x1f) << 7;
6903 // op: funct6_lo2
6904 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
6905 Value |= (op & 0x3) << 26;
6906 break;
6907 }
6908 case RISCV::SF_VC_IVV:
6909 case RISCV::SF_VC_IVW: {
6910 // op: rs2
6911 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6912 Value |= (op & 0x1f) << 20;
6913 // op: rs1
6914 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
6915 Value |= (op & 0x1f) << 15;
6916 // op: rd
6917 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6918 Value |= (op & 0x1f) << 7;
6919 // op: funct6_lo2
6920 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
6921 Value |= (op & 0x3) << 26;
6922 break;
6923 }
6924 case RISCV::FADD_D:
6925 case RISCV::FADD_D_IN32X:
6926 case RISCV::FADD_D_INX:
6927 case RISCV::FADD_H:
6928 case RISCV::FADD_H_INX:
6929 case RISCV::FADD_Q:
6930 case RISCV::FADD_S:
6931 case RISCV::FADD_S_INX:
6932 case RISCV::FDIV_D:
6933 case RISCV::FDIV_D_IN32X:
6934 case RISCV::FDIV_D_INX:
6935 case RISCV::FDIV_H:
6936 case RISCV::FDIV_H_INX:
6937 case RISCV::FDIV_Q:
6938 case RISCV::FDIV_S:
6939 case RISCV::FDIV_S_INX:
6940 case RISCV::FMUL_D:
6941 case RISCV::FMUL_D_IN32X:
6942 case RISCV::FMUL_D_INX:
6943 case RISCV::FMUL_H:
6944 case RISCV::FMUL_H_INX:
6945 case RISCV::FMUL_Q:
6946 case RISCV::FMUL_S:
6947 case RISCV::FMUL_S_INX:
6948 case RISCV::FSUB_D:
6949 case RISCV::FSUB_D_IN32X:
6950 case RISCV::FSUB_D_INX:
6951 case RISCV::FSUB_H:
6952 case RISCV::FSUB_H_INX:
6953 case RISCV::FSUB_Q:
6954 case RISCV::FSUB_S:
6955 case RISCV::FSUB_S_INX: {
6956 // op: rs2
6957 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
6958 Value |= (op & 0x1f) << 20;
6959 // op: rs1
6960 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
6961 Value |= (op & 0x1f) << 15;
6962 // op: frm
6963 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
6964 Value |= (op & 0x7) << 12;
6965 // op: rd
6966 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
6967 Value |= (op & 0x1f) << 7;
6968 break;
6969 }
6970 case RISCV::PM2WADDSU_H:
6971 case RISCV::PM2WADDU_H:
6972 case RISCV::PM2WADD_H:
6973 case RISCV::PM2WADD_HX:
6974 case RISCV::PM2WSUB_H:
6975 case RISCV::PM2WSUB_HX:
6976 case RISCV::PWADDU_B:
6977 case RISCV::PWADDU_H:
6978 case RISCV::PWADD_B:
6979 case RISCV::PWADD_H:
6980 case RISCV::PWMULSU_B:
6981 case RISCV::PWMULSU_H:
6982 case RISCV::PWMULU_B:
6983 case RISCV::PWMULU_H:
6984 case RISCV::PWMUL_B:
6985 case RISCV::PWMUL_H:
6986 case RISCV::PWSLA_BS:
6987 case RISCV::PWSLA_HS:
6988 case RISCV::PWSLL_BS:
6989 case RISCV::PWSLL_HS:
6990 case RISCV::PWSUBU_B:
6991 case RISCV::PWSUBU_H:
6992 case RISCV::PWSUB_B:
6993 case RISCV::PWSUB_H:
6994 case RISCV::WADD:
6995 case RISCV::WADDU:
6996 case RISCV::WMUL:
6997 case RISCV::WMULSU:
6998 case RISCV::WMULU:
6999 case RISCV::WSLA:
7000 case RISCV::WSLL:
7001 case RISCV::WSUB:
7002 case RISCV::WSUBU:
7003 case RISCV::WZIP16P:
7004 case RISCV::WZIP8P: {
7005 // op: rs2
7006 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7007 Value |= (op & 0x1f) << 20;
7008 // op: rs1
7009 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7010 Value |= (op & 0x1f) << 15;
7011 // op: rd
7012 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7013 Value |= (op & 0x1e) << 7;
7014 break;
7015 }
7016 case RISCV::AADD:
7017 case RISCV::AADDU:
7018 case RISCV::ADD:
7019 case RISCV::ADDW:
7020 case RISCV::ADD_UW:
7021 case RISCV::AES64DS:
7022 case RISCV::AES64DSM:
7023 case RISCV::AES64ES:
7024 case RISCV::AES64ESM:
7025 case RISCV::AES64KS2:
7026 case RISCV::AIF_BITMIXB:
7027 case RISCV::AIF_CUBEFACEIDX_PS:
7028 case RISCV::AIF_CUBEFACE_PS:
7029 case RISCV::AIF_CUBESGNSC_PS:
7030 case RISCV::AIF_CUBESGNTC_PS:
7031 case RISCV::AIF_FADD_PI:
7032 case RISCV::AIF_FAMOADDG_PI:
7033 case RISCV::AIF_FAMOADDL_PI:
7034 case RISCV::AIF_FAMOANDG_PI:
7035 case RISCV::AIF_FAMOANDL_PI:
7036 case RISCV::AIF_FAMOMAXG_PI:
7037 case RISCV::AIF_FAMOMAXG_PS:
7038 case RISCV::AIF_FAMOMAXL_PI:
7039 case RISCV::AIF_FAMOMAXL_PS:
7040 case RISCV::AIF_FAMOMAXUG_PI:
7041 case RISCV::AIF_FAMOMAXUL_PI:
7042 case RISCV::AIF_FAMOMING_PI:
7043 case RISCV::AIF_FAMOMING_PS:
7044 case RISCV::AIF_FAMOMINL_PI:
7045 case RISCV::AIF_FAMOMINL_PS:
7046 case RISCV::AIF_FAMOMINUG_PI:
7047 case RISCV::AIF_FAMOMINUL_PI:
7048 case RISCV::AIF_FAMOORG_PI:
7049 case RISCV::AIF_FAMOORL_PI:
7050 case RISCV::AIF_FAMOSWAPG_PI:
7051 case RISCV::AIF_FAMOSWAPL_PI:
7052 case RISCV::AIF_FAMOXORG_PI:
7053 case RISCV::AIF_FAMOXORL_PI:
7054 case RISCV::AIF_FAND_PI:
7055 case RISCV::AIF_FCMOVM_PS:
7056 case RISCV::AIF_FDIVU_PI:
7057 case RISCV::AIF_FDIV_PI:
7058 case RISCV::AIF_FEQM_PS:
7059 case RISCV::AIF_FEQ_PI:
7060 case RISCV::AIF_FEQ_PS:
7061 case RISCV::AIF_FG32B_PS:
7062 case RISCV::AIF_FG32H_PS:
7063 case RISCV::AIF_FG32W_PS:
7064 case RISCV::AIF_FGBG_PS:
7065 case RISCV::AIF_FGBL_PS:
7066 case RISCV::AIF_FGB_PS:
7067 case RISCV::AIF_FGHG_PS:
7068 case RISCV::AIF_FGHL_PS:
7069 case RISCV::AIF_FGH_PS:
7070 case RISCV::AIF_FGWG_PS:
7071 case RISCV::AIF_FGWL_PS:
7072 case RISCV::AIF_FGW_PS:
7073 case RISCV::AIF_FLEM_PS:
7074 case RISCV::AIF_FLE_PI:
7075 case RISCV::AIF_FLE_PS:
7076 case RISCV::AIF_FLTM_PI:
7077 case RISCV::AIF_FLTM_PS:
7078 case RISCV::AIF_FLTU_PI:
7079 case RISCV::AIF_FLT_PI:
7080 case RISCV::AIF_FLT_PS:
7081 case RISCV::AIF_FMAXU_PI:
7082 case RISCV::AIF_FMAX_PI:
7083 case RISCV::AIF_FMAX_PS:
7084 case RISCV::AIF_FMINU_PI:
7085 case RISCV::AIF_FMIN_PI:
7086 case RISCV::AIF_FMIN_PS:
7087 case RISCV::AIF_FMULHU_PI:
7088 case RISCV::AIF_FMULH_PI:
7089 case RISCV::AIF_FMUL_PI:
7090 case RISCV::AIF_FOR_PI:
7091 case RISCV::AIF_FRCP_FIX_RAST:
7092 case RISCV::AIF_FREMU_PI:
7093 case RISCV::AIF_FREM_PI:
7094 case RISCV::AIF_FSGNJN_PS:
7095 case RISCV::AIF_FSGNJX_PS:
7096 case RISCV::AIF_FSGNJ_PS:
7097 case RISCV::AIF_FSLL_PI:
7098 case RISCV::AIF_FSRA_PI:
7099 case RISCV::AIF_FSRL_PI:
7100 case RISCV::AIF_FSUB_PI:
7101 case RISCV::AIF_FXOR_PI:
7102 case RISCV::AIF_PACKB:
7103 case RISCV::AND:
7104 case RISCV::ANDN:
7105 case RISCV::ASUB:
7106 case RISCV::ASUBU:
7107 case RISCV::BCLR:
7108 case RISCV::BEXT:
7109 case RISCV::BINV:
7110 case RISCV::BSET:
7111 case RISCV::CLMUL:
7112 case RISCV::CLMULH:
7113 case RISCV::CLMULR:
7114 case RISCV::CV_ADD_B:
7115 case RISCV::CV_ADD_DIV2:
7116 case RISCV::CV_ADD_DIV4:
7117 case RISCV::CV_ADD_DIV8:
7118 case RISCV::CV_ADD_H:
7119 case RISCV::CV_ADD_SC_B:
7120 case RISCV::CV_ADD_SC_H:
7121 case RISCV::CV_AND_B:
7122 case RISCV::CV_AND_H:
7123 case RISCV::CV_AND_SC_B:
7124 case RISCV::CV_AND_SC_H:
7125 case RISCV::CV_AVGU_B:
7126 case RISCV::CV_AVGU_H:
7127 case RISCV::CV_AVGU_SC_B:
7128 case RISCV::CV_AVGU_SC_H:
7129 case RISCV::CV_AVG_B:
7130 case RISCV::CV_AVG_H:
7131 case RISCV::CV_AVG_SC_B:
7132 case RISCV::CV_AVG_SC_H:
7133 case RISCV::CV_BCLRR:
7134 case RISCV::CV_BSETR:
7135 case RISCV::CV_CLIPR:
7136 case RISCV::CV_CLIPUR:
7137 case RISCV::CV_CMPEQ_B:
7138 case RISCV::CV_CMPEQ_H:
7139 case RISCV::CV_CMPEQ_SC_B:
7140 case RISCV::CV_CMPEQ_SC_H:
7141 case RISCV::CV_CMPGEU_B:
7142 case RISCV::CV_CMPGEU_H:
7143 case RISCV::CV_CMPGEU_SC_B:
7144 case RISCV::CV_CMPGEU_SC_H:
7145 case RISCV::CV_CMPGE_B:
7146 case RISCV::CV_CMPGE_H:
7147 case RISCV::CV_CMPGE_SC_B:
7148 case RISCV::CV_CMPGE_SC_H:
7149 case RISCV::CV_CMPGTU_B:
7150 case RISCV::CV_CMPGTU_H:
7151 case RISCV::CV_CMPGTU_SC_B:
7152 case RISCV::CV_CMPGTU_SC_H:
7153 case RISCV::CV_CMPGT_B:
7154 case RISCV::CV_CMPGT_H:
7155 case RISCV::CV_CMPGT_SC_B:
7156 case RISCV::CV_CMPGT_SC_H:
7157 case RISCV::CV_CMPLEU_B:
7158 case RISCV::CV_CMPLEU_H:
7159 case RISCV::CV_CMPLEU_SC_B:
7160 case RISCV::CV_CMPLEU_SC_H:
7161 case RISCV::CV_CMPLE_B:
7162 case RISCV::CV_CMPLE_H:
7163 case RISCV::CV_CMPLE_SC_B:
7164 case RISCV::CV_CMPLE_SC_H:
7165 case RISCV::CV_CMPLTU_B:
7166 case RISCV::CV_CMPLTU_H:
7167 case RISCV::CV_CMPLTU_SC_B:
7168 case RISCV::CV_CMPLTU_SC_H:
7169 case RISCV::CV_CMPLT_B:
7170 case RISCV::CV_CMPLT_H:
7171 case RISCV::CV_CMPLT_SC_B:
7172 case RISCV::CV_CMPLT_SC_H:
7173 case RISCV::CV_CMPNE_B:
7174 case RISCV::CV_CMPNE_H:
7175 case RISCV::CV_CMPNE_SC_B:
7176 case RISCV::CV_CMPNE_SC_H:
7177 case RISCV::CV_DOTSP_B:
7178 case RISCV::CV_DOTSP_H:
7179 case RISCV::CV_DOTSP_SC_B:
7180 case RISCV::CV_DOTSP_SC_H:
7181 case RISCV::CV_DOTUP_B:
7182 case RISCV::CV_DOTUP_H:
7183 case RISCV::CV_DOTUP_SC_B:
7184 case RISCV::CV_DOTUP_SC_H:
7185 case RISCV::CV_DOTUSP_B:
7186 case RISCV::CV_DOTUSP_H:
7187 case RISCV::CV_DOTUSP_SC_B:
7188 case RISCV::CV_DOTUSP_SC_H:
7189 case RISCV::CV_EXTRACTR:
7190 case RISCV::CV_EXTRACTUR:
7191 case RISCV::CV_LBU_rr:
7192 case RISCV::CV_LB_rr:
7193 case RISCV::CV_LHU_rr:
7194 case RISCV::CV_LH_rr:
7195 case RISCV::CV_LW_rr:
7196 case RISCV::CV_MAX:
7197 case RISCV::CV_MAXU:
7198 case RISCV::CV_MAXU_B:
7199 case RISCV::CV_MAXU_H:
7200 case RISCV::CV_MAXU_SC_B:
7201 case RISCV::CV_MAXU_SC_H:
7202 case RISCV::CV_MAX_B:
7203 case RISCV::CV_MAX_H:
7204 case RISCV::CV_MAX_SC_B:
7205 case RISCV::CV_MAX_SC_H:
7206 case RISCV::CV_MIN:
7207 case RISCV::CV_MINU:
7208 case RISCV::CV_MINU_B:
7209 case RISCV::CV_MINU_H:
7210 case RISCV::CV_MINU_SC_B:
7211 case RISCV::CV_MINU_SC_H:
7212 case RISCV::CV_MIN_B:
7213 case RISCV::CV_MIN_H:
7214 case RISCV::CV_MIN_SC_B:
7215 case RISCV::CV_MIN_SC_H:
7216 case RISCV::CV_OR_B:
7217 case RISCV::CV_OR_H:
7218 case RISCV::CV_OR_SC_B:
7219 case RISCV::CV_OR_SC_H:
7220 case RISCV::CV_PACK:
7221 case RISCV::CV_PACK_H:
7222 case RISCV::CV_ROR:
7223 case RISCV::CV_SHUFFLE_B:
7224 case RISCV::CV_SHUFFLE_H:
7225 case RISCV::CV_SLE:
7226 case RISCV::CV_SLEU:
7227 case RISCV::CV_SLL_B:
7228 case RISCV::CV_SLL_H:
7229 case RISCV::CV_SLL_SC_B:
7230 case RISCV::CV_SLL_SC_H:
7231 case RISCV::CV_SRA_B:
7232 case RISCV::CV_SRA_H:
7233 case RISCV::CV_SRA_SC_B:
7234 case RISCV::CV_SRA_SC_H:
7235 case RISCV::CV_SRL_B:
7236 case RISCV::CV_SRL_H:
7237 case RISCV::CV_SRL_SC_B:
7238 case RISCV::CV_SRL_SC_H:
7239 case RISCV::CV_SUBROTMJ:
7240 case RISCV::CV_SUBROTMJ_DIV2:
7241 case RISCV::CV_SUBROTMJ_DIV4:
7242 case RISCV::CV_SUBROTMJ_DIV8:
7243 case RISCV::CV_SUB_B:
7244 case RISCV::CV_SUB_DIV2:
7245 case RISCV::CV_SUB_DIV4:
7246 case RISCV::CV_SUB_DIV8:
7247 case RISCV::CV_SUB_H:
7248 case RISCV::CV_SUB_SC_B:
7249 case RISCV::CV_SUB_SC_H:
7250 case RISCV::CV_XOR_B:
7251 case RISCV::CV_XOR_H:
7252 case RISCV::CV_XOR_SC_B:
7253 case RISCV::CV_XOR_SC_H:
7254 case RISCV::CZERO_EQZ:
7255 case RISCV::CZERO_NEZ:
7256 case RISCV::DIV:
7257 case RISCV::DIVU:
7258 case RISCV::DIVUW:
7259 case RISCV::DIVW:
7260 case RISCV::FEQ_D:
7261 case RISCV::FEQ_D_IN32X:
7262 case RISCV::FEQ_D_INX:
7263 case RISCV::FEQ_H:
7264 case RISCV::FEQ_H_INX:
7265 case RISCV::FEQ_Q:
7266 case RISCV::FEQ_S:
7267 case RISCV::FEQ_S_INX:
7268 case RISCV::FLEQ_D:
7269 case RISCV::FLEQ_H:
7270 case RISCV::FLEQ_Q:
7271 case RISCV::FLEQ_S:
7272 case RISCV::FLE_D:
7273 case RISCV::FLE_D_IN32X:
7274 case RISCV::FLE_D_INX:
7275 case RISCV::FLE_H:
7276 case RISCV::FLE_H_INX:
7277 case RISCV::FLE_Q:
7278 case RISCV::FLE_S:
7279 case RISCV::FLE_S_INX:
7280 case RISCV::FLTQ_D:
7281 case RISCV::FLTQ_H:
7282 case RISCV::FLTQ_Q:
7283 case RISCV::FLTQ_S:
7284 case RISCV::FLT_D:
7285 case RISCV::FLT_D_IN32X:
7286 case RISCV::FLT_D_INX:
7287 case RISCV::FLT_H:
7288 case RISCV::FLT_H_INX:
7289 case RISCV::FLT_Q:
7290 case RISCV::FLT_S:
7291 case RISCV::FLT_S_INX:
7292 case RISCV::FMAXM_D:
7293 case RISCV::FMAXM_H:
7294 case RISCV::FMAXM_Q:
7295 case RISCV::FMAXM_S:
7296 case RISCV::FMAX_D:
7297 case RISCV::FMAX_D_IN32X:
7298 case RISCV::FMAX_D_INX:
7299 case RISCV::FMAX_H:
7300 case RISCV::FMAX_H_INX:
7301 case RISCV::FMAX_Q:
7302 case RISCV::FMAX_S:
7303 case RISCV::FMAX_S_INX:
7304 case RISCV::FMINM_D:
7305 case RISCV::FMINM_H:
7306 case RISCV::FMINM_Q:
7307 case RISCV::FMINM_S:
7308 case RISCV::FMIN_D:
7309 case RISCV::FMIN_D_IN32X:
7310 case RISCV::FMIN_D_INX:
7311 case RISCV::FMIN_H:
7312 case RISCV::FMIN_H_INX:
7313 case RISCV::FMIN_Q:
7314 case RISCV::FMIN_S:
7315 case RISCV::FMIN_S_INX:
7316 case RISCV::FMVP_D_X:
7317 case RISCV::FMVP_Q_X:
7318 case RISCV::FSGNJN_D:
7319 case RISCV::FSGNJN_D_IN32X:
7320 case RISCV::FSGNJN_D_INX:
7321 case RISCV::FSGNJN_H:
7322 case RISCV::FSGNJN_H_INX:
7323 case RISCV::FSGNJN_Q:
7324 case RISCV::FSGNJN_S:
7325 case RISCV::FSGNJN_S_INX:
7326 case RISCV::FSGNJX_D:
7327 case RISCV::FSGNJX_D_IN32X:
7328 case RISCV::FSGNJX_D_INX:
7329 case RISCV::FSGNJX_H:
7330 case RISCV::FSGNJX_H_INX:
7331 case RISCV::FSGNJX_Q:
7332 case RISCV::FSGNJX_S:
7333 case RISCV::FSGNJX_S_INX:
7334 case RISCV::FSGNJ_D:
7335 case RISCV::FSGNJ_D_IN32X:
7336 case RISCV::FSGNJ_D_INX:
7337 case RISCV::FSGNJ_H:
7338 case RISCV::FSGNJ_H_INX:
7339 case RISCV::FSGNJ_Q:
7340 case RISCV::FSGNJ_S:
7341 case RISCV::FSGNJ_S_INX:
7342 case RISCV::MAX:
7343 case RISCV::MAXU:
7344 case RISCV::MIN:
7345 case RISCV::MINU:
7346 case RISCV::MOP_RR_0:
7347 case RISCV::MOP_RR_1:
7348 case RISCV::MOP_RR_2:
7349 case RISCV::MOP_RR_3:
7350 case RISCV::MOP_RR_4:
7351 case RISCV::MOP_RR_5:
7352 case RISCV::MOP_RR_6:
7353 case RISCV::MOP_RR_7:
7354 case RISCV::MSEQ:
7355 case RISCV::MSLT:
7356 case RISCV::MSLTU:
7357 case RISCV::MUL:
7358 case RISCV::MULH:
7359 case RISCV::MULHR:
7360 case RISCV::MULHRSU:
7361 case RISCV::MULHRU:
7362 case RISCV::MULHSU:
7363 case RISCV::MULHSU_H0:
7364 case RISCV::MULHSU_H1:
7365 case RISCV::MULHU:
7366 case RISCV::MULH_H0:
7367 case RISCV::MULH_H1:
7368 case RISCV::MULQ:
7369 case RISCV::MULQR:
7370 case RISCV::MULSU_H00:
7371 case RISCV::MULSU_H11:
7372 case RISCV::MULSU_W00:
7373 case RISCV::MULSU_W11:
7374 case RISCV::MULU_H00:
7375 case RISCV::MULU_H01:
7376 case RISCV::MULU_H11:
7377 case RISCV::MULU_W00:
7378 case RISCV::MULU_W01:
7379 case RISCV::MULU_W11:
7380 case RISCV::MULW:
7381 case RISCV::MUL_H00:
7382 case RISCV::MUL_H01:
7383 case RISCV::MUL_H11:
7384 case RISCV::MUL_W00:
7385 case RISCV::MUL_W01:
7386 case RISCV::MUL_W11:
7387 case RISCV::NDS_FFB:
7388 case RISCV::NDS_FFMISM:
7389 case RISCV::NDS_FFZMISM:
7390 case RISCV::NDS_FLMISM:
7391 case RISCV::OR:
7392 case RISCV::ORN:
7393 case RISCV::PAADDU_B:
7394 case RISCV::PAADDU_H:
7395 case RISCV::PAADDU_W:
7396 case RISCV::PAADD_B:
7397 case RISCV::PAADD_H:
7398 case RISCV::PAADD_W:
7399 case RISCV::PAAS_HX:
7400 case RISCV::PAAS_WX:
7401 case RISCV::PABDSUMU_B:
7402 case RISCV::PABDU_B:
7403 case RISCV::PABDU_H:
7404 case RISCV::PABD_B:
7405 case RISCV::PABD_H:
7406 case RISCV::PACK:
7407 case RISCV::PACKH:
7408 case RISCV::PACKW:
7409 case RISCV::PADD_B:
7410 case RISCV::PADD_BS:
7411 case RISCV::PADD_H:
7412 case RISCV::PADD_HS:
7413 case RISCV::PADD_W:
7414 case RISCV::PADD_WS:
7415 case RISCV::PASA_HX:
7416 case RISCV::PASA_WX:
7417 case RISCV::PASUBU_B:
7418 case RISCV::PASUBU_H:
7419 case RISCV::PASUBU_W:
7420 case RISCV::PASUB_B:
7421 case RISCV::PASUB_H:
7422 case RISCV::PASUB_W:
7423 case RISCV::PAS_HX:
7424 case RISCV::PAS_WX:
7425 case RISCV::PM2ADDSU_H:
7426 case RISCV::PM2ADDSU_W:
7427 case RISCV::PM2ADDU_H:
7428 case RISCV::PM2ADDU_W:
7429 case RISCV::PM2ADD_H:
7430 case RISCV::PM2ADD_HX:
7431 case RISCV::PM2ADD_W:
7432 case RISCV::PM2ADD_WX:
7433 case RISCV::PM2SADD_H:
7434 case RISCV::PM2SADD_HX:
7435 case RISCV::PM2SUB_H:
7436 case RISCV::PM2SUB_HX:
7437 case RISCV::PM2SUB_W:
7438 case RISCV::PM2SUB_WX:
7439 case RISCV::PM4ADDSU_B:
7440 case RISCV::PM4ADDSU_H:
7441 case RISCV::PM4ADDU_B:
7442 case RISCV::PM4ADDU_H:
7443 case RISCV::PM4ADD_B:
7444 case RISCV::PM4ADD_H:
7445 case RISCV::PMAXU_B:
7446 case RISCV::PMAXU_H:
7447 case RISCV::PMAXU_W:
7448 case RISCV::PMAX_B:
7449 case RISCV::PMAX_H:
7450 case RISCV::PMAX_W:
7451 case RISCV::PMINU_B:
7452 case RISCV::PMINU_H:
7453 case RISCV::PMINU_W:
7454 case RISCV::PMIN_B:
7455 case RISCV::PMIN_H:
7456 case RISCV::PMIN_W:
7457 case RISCV::PMQ2ADD_H:
7458 case RISCV::PMQ2ADD_W:
7459 case RISCV::PMQR2ADD_H:
7460 case RISCV::PMQR2ADD_W:
7461 case RISCV::PMSEQ_B:
7462 case RISCV::PMSEQ_H:
7463 case RISCV::PMSEQ_W:
7464 case RISCV::PMSLTU_B:
7465 case RISCV::PMSLTU_H:
7466 case RISCV::PMSLTU_W:
7467 case RISCV::PMSLT_B:
7468 case RISCV::PMSLT_H:
7469 case RISCV::PMSLT_W:
7470 case RISCV::PMULHRSU_H:
7471 case RISCV::PMULHRSU_W:
7472 case RISCV::PMULHRU_H:
7473 case RISCV::PMULHRU_W:
7474 case RISCV::PMULHR_H:
7475 case RISCV::PMULHR_W:
7476 case RISCV::PMULHSU_H:
7477 case RISCV::PMULHSU_H_B0:
7478 case RISCV::PMULHSU_H_B1:
7479 case RISCV::PMULHSU_W:
7480 case RISCV::PMULHSU_W_H0:
7481 case RISCV::PMULHSU_W_H1:
7482 case RISCV::PMULHU_H:
7483 case RISCV::PMULHU_W:
7484 case RISCV::PMULH_H:
7485 case RISCV::PMULH_H_B0:
7486 case RISCV::PMULH_H_B1:
7487 case RISCV::PMULH_W:
7488 case RISCV::PMULH_W_H0:
7489 case RISCV::PMULH_W_H1:
7490 case RISCV::PMULQR_H:
7491 case RISCV::PMULQR_W:
7492 case RISCV::PMULQ_H:
7493 case RISCV::PMULQ_W:
7494 case RISCV::PMULSU_H_B00:
7495 case RISCV::PMULSU_H_B11:
7496 case RISCV::PMULSU_W_H00:
7497 case RISCV::PMULSU_W_H11:
7498 case RISCV::PMULU_H_B00:
7499 case RISCV::PMULU_H_B01:
7500 case RISCV::PMULU_H_B11:
7501 case RISCV::PMULU_W_H00:
7502 case RISCV::PMULU_W_H01:
7503 case RISCV::PMULU_W_H11:
7504 case RISCV::PMUL_H_B00:
7505 case RISCV::PMUL_H_B01:
7506 case RISCV::PMUL_H_B11:
7507 case RISCV::PMUL_W_H00:
7508 case RISCV::PMUL_W_H01:
7509 case RISCV::PMUL_W_H11:
7510 case RISCV::PPAIREO_B:
7511 case RISCV::PPAIREO_H:
7512 case RISCV::PPAIREO_W:
7513 case RISCV::PPAIRE_B:
7514 case RISCV::PPAIRE_H:
7515 case RISCV::PPAIROE_B:
7516 case RISCV::PPAIROE_H:
7517 case RISCV::PPAIROE_W:
7518 case RISCV::PPAIRO_B:
7519 case RISCV::PPAIRO_H:
7520 case RISCV::PPAIRO_W:
7521 case RISCV::PREDSUMU_BS:
7522 case RISCV::PREDSUMU_HS:
7523 case RISCV::PREDSUMU_WS:
7524 case RISCV::PREDSUM_BS:
7525 case RISCV::PREDSUM_HS:
7526 case RISCV::PREDSUM_WS:
7527 case RISCV::PSADDU_B:
7528 case RISCV::PSADDU_H:
7529 case RISCV::PSADDU_W:
7530 case RISCV::PSADD_B:
7531 case RISCV::PSADD_H:
7532 case RISCV::PSADD_W:
7533 case RISCV::PSAS_HX:
7534 case RISCV::PSAS_WX:
7535 case RISCV::PSA_HX:
7536 case RISCV::PSA_WX:
7537 case RISCV::PSH1ADD_H:
7538 case RISCV::PSH1ADD_W:
7539 case RISCV::PSLL_BS:
7540 case RISCV::PSLL_HS:
7541 case RISCV::PSLL_WS:
7542 case RISCV::PSRA_BS:
7543 case RISCV::PSRA_HS:
7544 case RISCV::PSRA_WS:
7545 case RISCV::PSRL_BS:
7546 case RISCV::PSRL_HS:
7547 case RISCV::PSRL_WS:
7548 case RISCV::PSSA_HX:
7549 case RISCV::PSSA_WX:
7550 case RISCV::PSSH1SADD_H:
7551 case RISCV::PSSH1SADD_W:
7552 case RISCV::PSSHAR_HS:
7553 case RISCV::PSSHAR_WS:
7554 case RISCV::PSSHA_HS:
7555 case RISCV::PSSHA_WS:
7556 case RISCV::PSSUBU_B:
7557 case RISCV::PSSUBU_H:
7558 case RISCV::PSSUBU_W:
7559 case RISCV::PSSUB_B:
7560 case RISCV::PSSUB_H:
7561 case RISCV::PSSUB_W:
7562 case RISCV::PSUB_B:
7563 case RISCV::PSUB_H:
7564 case RISCV::PSUB_W:
7565 case RISCV::QC_ADDSAT:
7566 case RISCV::QC_ADDUSAT:
7567 case RISCV::QC_CSRRWR:
7568 case RISCV::QC_EXTDPR:
7569 case RISCV::QC_EXTDPRH:
7570 case RISCV::QC_EXTDR:
7571 case RISCV::QC_EXTDUPR:
7572 case RISCV::QC_EXTDUPRH:
7573 case RISCV::QC_EXTDUR:
7574 case RISCV::QC_SHLSAT:
7575 case RISCV::QC_SHLUSAT:
7576 case RISCV::QC_SUBSAT:
7577 case RISCV::QC_SUBUSAT:
7578 case RISCV::QC_WRAP:
7579 case RISCV::REM:
7580 case RISCV::REMU:
7581 case RISCV::REMUW:
7582 case RISCV::REMW:
7583 case RISCV::ROL:
7584 case RISCV::ROLW:
7585 case RISCV::ROR:
7586 case RISCV::RORW:
7587 case RISCV::SADD:
7588 case RISCV::SADDU:
7589 case RISCV::SF_VFWMACC_4x4x4:
7590 case RISCV::SF_VQMACCSU_2x8x2:
7591 case RISCV::SF_VQMACCSU_4x8x4:
7592 case RISCV::SF_VQMACCUS_2x8x2:
7593 case RISCV::SF_VQMACCUS_4x8x4:
7594 case RISCV::SF_VQMACCU_2x8x2:
7595 case RISCV::SF_VQMACCU_4x8x4:
7596 case RISCV::SF_VQMACC_2x8x2:
7597 case RISCV::SF_VQMACC_4x8x4:
7598 case RISCV::SH1ADD:
7599 case RISCV::SH1ADD_UW:
7600 case RISCV::SH2ADD:
7601 case RISCV::SH2ADD_UW:
7602 case RISCV::SH3ADD:
7603 case RISCV::SH3ADD_UW:
7604 case RISCV::SHA:
7605 case RISCV::SHA512SIG0H:
7606 case RISCV::SHA512SIG0L:
7607 case RISCV::SHA512SIG1H:
7608 case RISCV::SHA512SIG1L:
7609 case RISCV::SHA512SUM0R:
7610 case RISCV::SHA512SUM1R:
7611 case RISCV::SHAR:
7612 case RISCV::SLL:
7613 case RISCV::SLLW:
7614 case RISCV::SLT:
7615 case RISCV::SLTU:
7616 case RISCV::SRA:
7617 case RISCV::SRAW:
7618 case RISCV::SRL:
7619 case RISCV::SRLW:
7620 case RISCV::SSH1SADD:
7621 case RISCV::SSHA:
7622 case RISCV::SSHAR:
7623 case RISCV::SSUB:
7624 case RISCV::SSUBU:
7625 case RISCV::SUB:
7626 case RISCV::SUBW:
7627 case RISCV::UNZIP16HP:
7628 case RISCV::UNZIP16P:
7629 case RISCV::UNZIP8HP:
7630 case RISCV::UNZIP8P:
7631 case RISCV::VSETVL:
7632 case RISCV::VT_MASKC:
7633 case RISCV::VT_MASKCN:
7634 case RISCV::XNOR:
7635 case RISCV::XOR:
7636 case RISCV::XPERM4:
7637 case RISCV::XPERM8:
7638 case RISCV::ZIP16HP:
7639 case RISCV::ZIP16P:
7640 case RISCV::ZIP8HP:
7641 case RISCV::ZIP8P: {
7642 // op: rs2
7643 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7644 Value |= (op & 0x1f) << 20;
7645 // op: rs1
7646 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7647 Value |= (op & 0x1f) << 15;
7648 // op: rd
7649 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7650 Value |= (op & 0x1f) << 7;
7651 break;
7652 }
7653 case RISCV::AES32DSI:
7654 case RISCV::AES32DSMI:
7655 case RISCV::AES32ESI:
7656 case RISCV::AES32ESMI:
7657 case RISCV::SM4ED:
7658 case RISCV::SM4KS: {
7659 // op: rs2
7660 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7661 Value |= (op & 0x1f) << 20;
7662 // op: rs1
7663 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7664 Value |= (op & 0x1f) << 15;
7665 // op: rd
7666 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7667 Value |= (op & 0x1f) << 7;
7668 // op: bs
7669 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7670 Value |= (op & 0x3) << 30;
7671 break;
7672 }
7673 case RISCV::QC_LWM:
7674 case RISCV::QC_LWMI:
7675 case RISCV::QC_SETWM:
7676 case RISCV::QC_SETWMI:
7677 case RISCV::QC_SWM:
7678 case RISCV::QC_SWMI: {
7679 // op: rs2
7680 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7681 Value |= (op & 0x1f) << 20;
7682 // op: rs1
7683 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7684 Value |= (op & 0x1f) << 15;
7685 // op: rd
7686 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7687 Value |= (op & 0x1f) << 7;
7688 // op: imm
7689 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7690 Value |= (op & 0x7c) << 23;
7691 break;
7692 }
7693 case RISCV::CV_ADDN:
7694 case RISCV::CV_ADDRN:
7695 case RISCV::CV_ADDUN:
7696 case RISCV::CV_ADDURN:
7697 case RISCV::CV_MULHHSN:
7698 case RISCV::CV_MULHHSRN:
7699 case RISCV::CV_MULHHUN:
7700 case RISCV::CV_MULHHURN:
7701 case RISCV::CV_MULSN:
7702 case RISCV::CV_MULSRN:
7703 case RISCV::CV_MULUN:
7704 case RISCV::CV_MULURN:
7705 case RISCV::CV_SUBN:
7706 case RISCV::CV_SUBRN:
7707 case RISCV::CV_SUBUN:
7708 case RISCV::CV_SUBURN: {
7709 // op: rs2
7710 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7711 Value |= (op & 0x1f) << 20;
7712 // op: rs1
7713 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7714 Value |= (op & 0x1f) << 15;
7715 // op: rd
7716 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7717 Value |= (op & 0x1f) << 7;
7718 // op: imm5
7719 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7720 Value |= (op & 0x1f) << 25;
7721 break;
7722 }
7723 case RISCV::QC_LRB:
7724 case RISCV::QC_LRBU:
7725 case RISCV::QC_LRH:
7726 case RISCV::QC_LRHU:
7727 case RISCV::QC_LRW:
7728 case RISCV::QC_SRB:
7729 case RISCV::QC_SRH:
7730 case RISCV::QC_SRW: {
7731 // op: rs2
7732 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7733 Value |= (op & 0x1f) << 20;
7734 // op: rs1
7735 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7736 Value |= (op & 0x1f) << 15;
7737 // op: rd
7738 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7739 Value |= (op & 0x1f) << 7;
7740 // op: shamt
7741 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7742 Value |= (op & 0x7) << 25;
7743 break;
7744 }
7745 case RISCV::QC_SHLADD: {
7746 // op: rs2
7747 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7748 Value |= (op & 0x1f) << 20;
7749 // op: rs1
7750 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7751 Value |= (op & 0x1f) << 15;
7752 // op: rd
7753 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7754 Value |= (op & 0x1f) << 7;
7755 // op: shamt
7756 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7757 Value |= (op & 0x1f) << 25;
7758 break;
7759 }
7760 case RISCV::TH_ADDSL:
7761 case RISCV::TH_FLRD:
7762 case RISCV::TH_FLRW:
7763 case RISCV::TH_FLURD:
7764 case RISCV::TH_FLURW:
7765 case RISCV::TH_FSRD:
7766 case RISCV::TH_FSRW:
7767 case RISCV::TH_FSURD:
7768 case RISCV::TH_FSURW:
7769 case RISCV::TH_LRB:
7770 case RISCV::TH_LRBU:
7771 case RISCV::TH_LRD:
7772 case RISCV::TH_LRH:
7773 case RISCV::TH_LRHU:
7774 case RISCV::TH_LRW:
7775 case RISCV::TH_LRWU:
7776 case RISCV::TH_LURB:
7777 case RISCV::TH_LURBU:
7778 case RISCV::TH_LURD:
7779 case RISCV::TH_LURH:
7780 case RISCV::TH_LURHU:
7781 case RISCV::TH_LURW:
7782 case RISCV::TH_LURWU:
7783 case RISCV::TH_SRB:
7784 case RISCV::TH_SRD:
7785 case RISCV::TH_SRH:
7786 case RISCV::TH_SRW:
7787 case RISCV::TH_SURB:
7788 case RISCV::TH_SURD:
7789 case RISCV::TH_SURH:
7790 case RISCV::TH_SURW: {
7791 // op: rs2
7792 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7793 Value |= (op & 0x1f) << 20;
7794 // op: rs1
7795 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7796 Value |= (op & 0x1f) << 15;
7797 // op: rd
7798 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7799 Value |= (op & 0x1f) << 7;
7800 // op: uimm2
7801 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
7802 Value |= (op & 0x3) << 25;
7803 break;
7804 }
7805 case RISCV::SF_VC_FV: {
7806 // op: rs2
7807 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7808 Value |= (op & 0x1f) << 20;
7809 // op: rs1
7810 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7811 Value |= (op & 0x1f) << 15;
7812 // op: rd
7813 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
7814 Value |= (op & 0x1f) << 7;
7815 // op: funct6_lo1
7816 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
7817 Value |= (op & 0x1) << 26;
7818 break;
7819 }
7820 case RISCV::SF_VC_VV:
7821 case RISCV::SF_VC_XV: {
7822 // op: rs2
7823 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7824 Value |= (op & 0x1f) << 20;
7825 // op: rs1
7826 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7827 Value |= (op & 0x1f) << 15;
7828 // op: rd
7829 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
7830 Value |= (op & 0x1f) << 7;
7831 // op: funct6_lo2
7832 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
7833 Value |= (op & 0x3) << 26;
7834 break;
7835 }
7836 case RISCV::SF_VC_V_FV: {
7837 // op: rs2
7838 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7839 Value |= (op & 0x1f) << 20;
7840 // op: rs1
7841 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7842 Value |= (op & 0x1f) << 15;
7843 // op: rd
7844 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7845 Value |= (op & 0x1f) << 7;
7846 // op: funct6_lo1
7847 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
7848 Value |= (op & 0x1) << 26;
7849 break;
7850 }
7851 case RISCV::SF_VC_V_VV:
7852 case RISCV::SF_VC_V_XV: {
7853 // op: rs2
7854 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7855 Value |= (op & 0x1f) << 20;
7856 // op: rs1
7857 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7858 Value |= (op & 0x1f) << 15;
7859 // op: rd
7860 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7861 Value |= (op & 0x1f) << 7;
7862 // op: funct6_lo2
7863 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
7864 Value |= (op & 0x3) << 26;
7865 break;
7866 }
7867 case RISCV::AMOCAS_B:
7868 case RISCV::AMOCAS_B_AQ:
7869 case RISCV::AMOCAS_B_AQRL:
7870 case RISCV::AMOCAS_B_RL:
7871 case RISCV::AMOCAS_D_RV32:
7872 case RISCV::AMOCAS_D_RV32_AQ:
7873 case RISCV::AMOCAS_D_RV32_AQRL:
7874 case RISCV::AMOCAS_D_RV32_RL:
7875 case RISCV::AMOCAS_D_RV64:
7876 case RISCV::AMOCAS_D_RV64_AQ:
7877 case RISCV::AMOCAS_D_RV64_AQRL:
7878 case RISCV::AMOCAS_D_RV64_RL:
7879 case RISCV::AMOCAS_H:
7880 case RISCV::AMOCAS_H_AQ:
7881 case RISCV::AMOCAS_H_AQRL:
7882 case RISCV::AMOCAS_H_RL:
7883 case RISCV::AMOCAS_Q:
7884 case RISCV::AMOCAS_Q_AQ:
7885 case RISCV::AMOCAS_Q_AQRL:
7886 case RISCV::AMOCAS_Q_RL:
7887 case RISCV::AMOCAS_W:
7888 case RISCV::AMOCAS_W_AQ:
7889 case RISCV::AMOCAS_W_AQRL:
7890 case RISCV::AMOCAS_W_RL: {
7891 // op: rs2
7892 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7893 Value |= (op & 0x1f) << 20;
7894 // op: rs1
7895 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7896 Value |= (op & 0x1f) << 15;
7897 // op: rd
7898 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7899 Value |= (op & 0x1f) << 7;
7900 break;
7901 }
7902 case RISCV::SF_VC_FVV:
7903 case RISCV::SF_VC_FVW: {
7904 // op: rs2
7905 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7906 Value |= (op & 0x1f) << 20;
7907 // op: rs1
7908 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7909 Value |= (op & 0x1f) << 15;
7910 // op: rd
7911 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7912 Value |= (op & 0x1f) << 7;
7913 // op: funct6_lo1
7914 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
7915 Value |= (op & 0x1) << 26;
7916 break;
7917 }
7918 case RISCV::SF_VC_VVV:
7919 case RISCV::SF_VC_VVW:
7920 case RISCV::SF_VC_XVV:
7921 case RISCV::SF_VC_XVW: {
7922 // op: rs2
7923 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7924 Value |= (op & 0x1f) << 20;
7925 // op: rs1
7926 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7927 Value |= (op & 0x1f) << 15;
7928 // op: rd
7929 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7930 Value |= (op & 0x1f) << 7;
7931 // op: funct6_lo2
7932 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
7933 Value |= (op & 0x3) << 26;
7934 break;
7935 }
7936 case RISCV::AIF_MASKAND:
7937 case RISCV::AIF_MASKOR:
7938 case RISCV::AIF_MASKXOR: {
7939 // op: rs2
7940 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7941 Value |= (op & 0x7) << 20;
7942 // op: rs1
7943 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7944 Value |= (op & 0x7) << 15;
7945 // op: rd
7946 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
7947 Value |= (op & 0x7) << 7;
7948 break;
7949 }
7950 case RISCV::C_ADDW:
7951 case RISCV::C_AND:
7952 case RISCV::C_MUL:
7953 case RISCV::C_OR:
7954 case RISCV::C_SUB:
7955 case RISCV::C_SUBW:
7956 case RISCV::C_XOR: {
7957 // op: rs2
7958 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7959 Value |= (op & 0x7) << 2;
7960 // op: rd
7961 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7962 Value |= (op & 0x7) << 7;
7963 break;
7964 }
7965 case RISCV::QC_SELECTIEQI:
7966 case RISCV::QC_SELECTINEI: {
7967 // op: rs2
7968 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7969 Value |= (op & 0x1f) << 20;
7970 // op: rd
7971 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
7972 Value |= (op & 0x1f) << 7;
7973 // op: imm
7974 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
7975 Value |= (op & 0x1f) << 15;
7976 // op: simm2
7977 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
7978 Value |= (op & 0x1f) << 27;
7979 break;
7980 }
7981 case RISCV::SF_VC_V_IVV:
7982 case RISCV::SF_VC_V_IVW: {
7983 // op: rs2
7984 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
7985 Value |= (op & 0x1f) << 20;
7986 // op: rs1
7987 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
7988 Value |= (op & 0x1f) << 15;
7989 // op: rd
7990 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
7991 Value |= (op & 0x1f) << 7;
7992 // op: funct6_lo2
7993 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
7994 Value |= (op & 0x3) << 26;
7995 break;
7996 }
7997 case RISCV::CV_LBU_rr_inc:
7998 case RISCV::CV_LB_rr_inc:
7999 case RISCV::CV_LHU_rr_inc:
8000 case RISCV::CV_LH_rr_inc:
8001 case RISCV::CV_LW_rr_inc: {
8002 // op: rs2
8003 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8004 Value |= (op & 0x1f) << 20;
8005 // op: rs1
8006 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8007 Value |= (op & 0x1f) << 15;
8008 // op: rd
8009 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8010 Value |= (op & 0x1f) << 7;
8011 break;
8012 }
8013 case RISCV::MQRWACC:
8014 case RISCV::MQWACC:
8015 case RISCV::PM2WADDASU_H:
8016 case RISCV::PM2WADDAU_H:
8017 case RISCV::PM2WADDA_H:
8018 case RISCV::PM2WADDA_HX:
8019 case RISCV::PM2WSUBA_H:
8020 case RISCV::PM2WSUBA_HX:
8021 case RISCV::PMQRWACC_H:
8022 case RISCV::PMQWACC_H:
8023 case RISCV::PWADDAU_B:
8024 case RISCV::PWADDAU_H:
8025 case RISCV::PWADDA_B:
8026 case RISCV::PWADDA_H:
8027 case RISCV::PWMACCSU_H:
8028 case RISCV::PWMACCU_H:
8029 case RISCV::PWMACC_H:
8030 case RISCV::PWSUBAU_B:
8031 case RISCV::PWSUBAU_H:
8032 case RISCV::PWSUBA_B:
8033 case RISCV::PWSUBA_H:
8034 case RISCV::WADDA:
8035 case RISCV::WADDAU:
8036 case RISCV::WMACC:
8037 case RISCV::WMACCSU:
8038 case RISCV::WMACCU:
8039 case RISCV::WSUBA:
8040 case RISCV::WSUBAU: {
8041 // op: rs2
8042 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8043 Value |= (op & 0x1f) << 20;
8044 // op: rs1
8045 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8046 Value |= (op & 0x1f) << 15;
8047 // op: rd
8048 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8049 Value |= (op & 0x1e) << 7;
8050 break;
8051 }
8052 case RISCV::CV_ADDNR:
8053 case RISCV::CV_ADDRNR:
8054 case RISCV::CV_ADDUNR:
8055 case RISCV::CV_ADDURNR:
8056 case RISCV::CV_CPLXMUL_I:
8057 case RISCV::CV_CPLXMUL_I_DIV2:
8058 case RISCV::CV_CPLXMUL_I_DIV4:
8059 case RISCV::CV_CPLXMUL_I_DIV8:
8060 case RISCV::CV_CPLXMUL_R:
8061 case RISCV::CV_CPLXMUL_R_DIV2:
8062 case RISCV::CV_CPLXMUL_R_DIV4:
8063 case RISCV::CV_CPLXMUL_R_DIV8:
8064 case RISCV::CV_INSERTR:
8065 case RISCV::CV_MAC:
8066 case RISCV::CV_MSU:
8067 case RISCV::CV_PACKHI_B:
8068 case RISCV::CV_PACKLO_B:
8069 case RISCV::CV_SDOTSP_B:
8070 case RISCV::CV_SDOTSP_H:
8071 case RISCV::CV_SDOTSP_SC_B:
8072 case RISCV::CV_SDOTSP_SC_H:
8073 case RISCV::CV_SDOTUP_B:
8074 case RISCV::CV_SDOTUP_H:
8075 case RISCV::CV_SDOTUP_SC_B:
8076 case RISCV::CV_SDOTUP_SC_H:
8077 case RISCV::CV_SDOTUSP_B:
8078 case RISCV::CV_SDOTUSP_H:
8079 case RISCV::CV_SDOTUSP_SC_B:
8080 case RISCV::CV_SDOTUSP_SC_H:
8081 case RISCV::CV_SHUFFLE2_B:
8082 case RISCV::CV_SHUFFLE2_H:
8083 case RISCV::CV_SUBNR:
8084 case RISCV::CV_SUBRNR:
8085 case RISCV::CV_SUBUNR:
8086 case RISCV::CV_SUBURNR:
8087 case RISCV::MACCSU_H00:
8088 case RISCV::MACCSU_H11:
8089 case RISCV::MACCSU_W00:
8090 case RISCV::MACCSU_W11:
8091 case RISCV::MACCU_H00:
8092 case RISCV::MACCU_H01:
8093 case RISCV::MACCU_H11:
8094 case RISCV::MACCU_W00:
8095 case RISCV::MACCU_W01:
8096 case RISCV::MACCU_W11:
8097 case RISCV::MACC_H00:
8098 case RISCV::MACC_H01:
8099 case RISCV::MACC_H11:
8100 case RISCV::MACC_W00:
8101 case RISCV::MACC_W01:
8102 case RISCV::MACC_W11:
8103 case RISCV::MERGE:
8104 case RISCV::MHACC:
8105 case RISCV::MHACCSU:
8106 case RISCV::MHACCSU_H0:
8107 case RISCV::MHACCSU_H1:
8108 case RISCV::MHACCU:
8109 case RISCV::MHACC_H0:
8110 case RISCV::MHACC_H1:
8111 case RISCV::MHRACC:
8112 case RISCV::MHRACCSU:
8113 case RISCV::MHRACCU:
8114 case RISCV::MQACC_H00:
8115 case RISCV::MQACC_H01:
8116 case RISCV::MQACC_H11:
8117 case RISCV::MQACC_W00:
8118 case RISCV::MQACC_W01:
8119 case RISCV::MQACC_W11:
8120 case RISCV::MQRACC_H00:
8121 case RISCV::MQRACC_H01:
8122 case RISCV::MQRACC_H11:
8123 case RISCV::MQRACC_W00:
8124 case RISCV::MQRACC_W01:
8125 case RISCV::MQRACC_W11:
8126 case RISCV::MVM:
8127 case RISCV::MVMN:
8128 case RISCV::PABDSUMAU_B:
8129 case RISCV::PM2ADDASU_H:
8130 case RISCV::PM2ADDASU_W:
8131 case RISCV::PM2ADDAU_H:
8132 case RISCV::PM2ADDAU_W:
8133 case RISCV::PM2ADDA_H:
8134 case RISCV::PM2ADDA_HX:
8135 case RISCV::PM2ADDA_W:
8136 case RISCV::PM2ADDA_WX:
8137 case RISCV::PM2SUBA_H:
8138 case RISCV::PM2SUBA_HX:
8139 case RISCV::PM2SUBA_W:
8140 case RISCV::PM2SUBA_WX:
8141 case RISCV::PM4ADDASU_B:
8142 case RISCV::PM4ADDASU_H:
8143 case RISCV::PM4ADDAU_B:
8144 case RISCV::PM4ADDAU_H:
8145 case RISCV::PM4ADDA_B:
8146 case RISCV::PM4ADDA_H:
8147 case RISCV::PMACCSU_W_H00:
8148 case RISCV::PMACCSU_W_H11:
8149 case RISCV::PMACCU_W_H00:
8150 case RISCV::PMACCU_W_H01:
8151 case RISCV::PMACCU_W_H11:
8152 case RISCV::PMACC_W_H00:
8153 case RISCV::PMACC_W_H01:
8154 case RISCV::PMACC_W_H11:
8155 case RISCV::PMHACCSU_H:
8156 case RISCV::PMHACCSU_H_B0:
8157 case RISCV::PMHACCSU_H_B1:
8158 case RISCV::PMHACCSU_W:
8159 case RISCV::PMHACCSU_W_H0:
8160 case RISCV::PMHACCSU_W_H1:
8161 case RISCV::PMHACCU_H:
8162 case RISCV::PMHACCU_W:
8163 case RISCV::PMHACC_H:
8164 case RISCV::PMHACC_H_B0:
8165 case RISCV::PMHACC_H_B1:
8166 case RISCV::PMHACC_W:
8167 case RISCV::PMHACC_W_H0:
8168 case RISCV::PMHACC_W_H1:
8169 case RISCV::PMHRACCSU_H:
8170 case RISCV::PMHRACCSU_W:
8171 case RISCV::PMHRACCU_H:
8172 case RISCV::PMHRACCU_W:
8173 case RISCV::PMHRACC_H:
8174 case RISCV::PMHRACC_W:
8175 case RISCV::PMQ2ADDA_H:
8176 case RISCV::PMQ2ADDA_W:
8177 case RISCV::PMQACC_W_H00:
8178 case RISCV::PMQACC_W_H01:
8179 case RISCV::PMQACC_W_H11:
8180 case RISCV::PMQR2ADDA_H:
8181 case RISCV::PMQR2ADDA_W:
8182 case RISCV::PMQRACC_W_H00:
8183 case RISCV::PMQRACC_W_H01:
8184 case RISCV::PMQRACC_W_H11:
8185 case RISCV::QC_INSBHR:
8186 case RISCV::QC_INSBPR:
8187 case RISCV::QC_INSBPRH:
8188 case RISCV::QC_INSBR:
8189 case RISCV::SLX:
8190 case RISCV::SRX:
8191 case RISCV::TH_MULA:
8192 case RISCV::TH_MULAH:
8193 case RISCV::TH_MULAW:
8194 case RISCV::TH_MULS:
8195 case RISCV::TH_MULSH:
8196 case RISCV::TH_MULSW:
8197 case RISCV::TH_MVEQZ:
8198 case RISCV::TH_MVNEZ: {
8199 // op: rs2
8200 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8201 Value |= (op & 0x1f) << 20;
8202 // op: rs1
8203 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8204 Value |= (op & 0x1f) << 15;
8205 // op: rd
8206 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8207 Value |= (op & 0x1f) << 7;
8208 break;
8209 }
8210 case RISCV::CV_MACHHSN:
8211 case RISCV::CV_MACHHSRN:
8212 case RISCV::CV_MACHHUN:
8213 case RISCV::CV_MACHHURN:
8214 case RISCV::CV_MACSN:
8215 case RISCV::CV_MACSRN:
8216 case RISCV::CV_MACUN:
8217 case RISCV::CV_MACURN: {
8218 // op: rs2
8219 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8220 Value |= (op & 0x1f) << 20;
8221 // op: rs1
8222 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8223 Value |= (op & 0x1f) << 15;
8224 // op: rd
8225 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8226 Value |= (op & 0x1f) << 7;
8227 // op: imm5
8228 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8229 Value |= (op & 0x1f) << 25;
8230 break;
8231 }
8232 case RISCV::QC_LIEQ:
8233 case RISCV::QC_LIGE:
8234 case RISCV::QC_LIGEU:
8235 case RISCV::QC_LILT:
8236 case RISCV::QC_LILTU:
8237 case RISCV::QC_LINE: {
8238 // op: rs2
8239 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8240 Value |= (op & 0x1f) << 20;
8241 // op: rs1
8242 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8243 Value |= (op & 0x1f) << 15;
8244 // op: rd
8245 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8246 Value |= (op & 0x1f) << 7;
8247 // op: simm
8248 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8249 Value |= (op & 0x1f) << 27;
8250 break;
8251 }
8252 case RISCV::QC_SELECTIEQ:
8253 case RISCV::QC_SELECTINE: {
8254 // op: rs2
8255 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), 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 // op: rd
8261 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8262 Value |= (op & 0x1f) << 7;
8263 // op: simm2
8264 op = getImmOpValue(MI, OpNo: 4, Fixups, STI);
8265 Value |= (op & 0x1f) << 27;
8266 break;
8267 }
8268 case RISCV::SF_VC_V_FVV:
8269 case RISCV::SF_VC_V_FVW: {
8270 // op: rs2
8271 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8272 Value |= (op & 0x1f) << 20;
8273 // op: rs1
8274 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8275 Value |= (op & 0x1f) << 15;
8276 // op: rd
8277 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8278 Value |= (op & 0x1f) << 7;
8279 // op: funct6_lo1
8280 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
8281 Value |= (op & 0x1) << 26;
8282 break;
8283 }
8284 case RISCV::SF_VC_V_VVV:
8285 case RISCV::SF_VC_V_VVW:
8286 case RISCV::SF_VC_V_XVV:
8287 case RISCV::SF_VC_V_XVW: {
8288 // op: rs2
8289 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8290 Value |= (op & 0x1f) << 20;
8291 // op: rs1
8292 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8293 Value |= (op & 0x1f) << 15;
8294 // op: rd
8295 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8296 Value |= (op & 0x1f) << 7;
8297 // op: funct6_lo2
8298 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
8299 Value |= (op & 0x3) << 26;
8300 break;
8301 }
8302 case RISCV::FMADD_D:
8303 case RISCV::FMADD_D_IN32X:
8304 case RISCV::FMADD_D_INX:
8305 case RISCV::FMADD_H:
8306 case RISCV::FMADD_H_INX:
8307 case RISCV::FMADD_Q:
8308 case RISCV::FMADD_S:
8309 case RISCV::FMADD_S_INX:
8310 case RISCV::FMSUB_D:
8311 case RISCV::FMSUB_D_IN32X:
8312 case RISCV::FMSUB_D_INX:
8313 case RISCV::FMSUB_H:
8314 case RISCV::FMSUB_H_INX:
8315 case RISCV::FMSUB_Q:
8316 case RISCV::FMSUB_S:
8317 case RISCV::FMSUB_S_INX:
8318 case RISCV::FNMADD_D:
8319 case RISCV::FNMADD_D_IN32X:
8320 case RISCV::FNMADD_D_INX:
8321 case RISCV::FNMADD_H:
8322 case RISCV::FNMADD_H_INX:
8323 case RISCV::FNMADD_Q:
8324 case RISCV::FNMADD_S:
8325 case RISCV::FNMADD_S_INX:
8326 case RISCV::FNMSUB_D:
8327 case RISCV::FNMSUB_D_IN32X:
8328 case RISCV::FNMSUB_D_INX:
8329 case RISCV::FNMSUB_H:
8330 case RISCV::FNMSUB_H_INX:
8331 case RISCV::FNMSUB_Q:
8332 case RISCV::FNMSUB_S:
8333 case RISCV::FNMSUB_S_INX: {
8334 // op: rs3
8335 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8336 Value |= (op & 0x1f) << 27;
8337 // op: rs2
8338 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8339 Value |= (op & 0x1f) << 20;
8340 // op: rs1
8341 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8342 Value |= (op & 0x1f) << 15;
8343 // op: frm
8344 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8345 Value |= (op & 0x7) << 12;
8346 // op: rd
8347 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8348 Value |= (op & 0x1f) << 7;
8349 break;
8350 }
8351 case RISCV::MIPS_CCMOV: {
8352 // op: rs3
8353 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8354 Value |= (op & 0x1f) << 27;
8355 // op: rs2
8356 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8357 Value |= (op & 0x1f) << 20;
8358 // op: rs1
8359 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8360 Value |= (op & 0x1f) << 15;
8361 // op: rd
8362 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8363 Value |= (op & 0x1f) << 7;
8364 break;
8365 }
8366 case RISCV::CV_SB_rr_inc:
8367 case RISCV::CV_SH_rr_inc:
8368 case RISCV::CV_SW_rr_inc: {
8369 // op: rs3
8370 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8371 Value |= (op & 0x1f) << 7;
8372 // op: rs2
8373 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8374 Value |= (op & 0x1f) << 20;
8375 // op: rs1
8376 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8377 Value |= (op & 0x1f) << 15;
8378 break;
8379 }
8380 case RISCV::QC_MVEQI:
8381 case RISCV::QC_MVGEI:
8382 case RISCV::QC_MVGEUI:
8383 case RISCV::QC_MVLTI:
8384 case RISCV::QC_MVLTUI:
8385 case RISCV::QC_MVNEI: {
8386 // op: rs3
8387 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8388 Value |= (op & 0x1f) << 27;
8389 // op: rs1
8390 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8391 Value |= (op & 0x1f) << 15;
8392 // op: rd
8393 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8394 Value |= (op & 0x1f) << 7;
8395 // op: imm
8396 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
8397 Value |= (op & 0x1f) << 20;
8398 break;
8399 }
8400 case RISCV::QC_SELECTEQI:
8401 case RISCV::QC_SELECTNEI: {
8402 // op: rs3
8403 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8404 Value |= (op & 0x1f) << 27;
8405 // op: rs2
8406 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8407 Value |= (op & 0x1f) << 20;
8408 // op: rd
8409 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8410 Value |= (op & 0x1f) << 7;
8411 // op: imm
8412 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8413 Value |= (op & 0x1f) << 15;
8414 break;
8415 }
8416 case RISCV::QC_MVEQ:
8417 case RISCV::QC_MVGE:
8418 case RISCV::QC_MVGEU:
8419 case RISCV::QC_MVLT:
8420 case RISCV::QC_MVLTU:
8421 case RISCV::QC_MVNE: {
8422 // op: rs3
8423 op = getMachineOpValue(MI, MO: MI.getOperand(i: 4), Fixups, STI);
8424 Value |= (op & 0x1f) << 27;
8425 // op: rs2
8426 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8427 Value |= (op & 0x1f) << 20;
8428 // op: rs1
8429 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8430 Value |= (op & 0x1f) << 15;
8431 // op: rd
8432 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8433 Value |= (op & 0x1f) << 7;
8434 break;
8435 }
8436 case RISCV::QC_C_SYNC:
8437 case RISCV::QC_C_SYNCR:
8438 case RISCV::QC_C_SYNCWF:
8439 case RISCV::QC_C_SYNCWL: {
8440 // op: slist
8441 op = getImmOpValueSlist(MI, OpNo: 0, Fixups, STI);
8442 Value |= (op & 0x7) << 7;
8443 break;
8444 }
8445 case RISCV::Insn16: {
8446 // op: value
8447 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8448 Value |= (op & 0xffff);
8449 break;
8450 }
8451 case RISCV::Insn32: {
8452 // op: value
8453 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8454 Value |= (op & 0xffffffff);
8455 break;
8456 }
8457 case RISCV::Insn48: {
8458 // op: value
8459 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8460 Value |= (op & 0xffffffffffff);
8461 break;
8462 }
8463 case RISCV::Insn64: {
8464 // op: value
8465 op = getImmOpValue(MI, OpNo: 0, Fixups, STI);
8466 Value |= (op & 0xffffffffffffffff);
8467 break;
8468 }
8469 case RISCV::SMT_VMADOT1:
8470 case RISCV::SMT_VMADOT1SU:
8471 case RISCV::SMT_VMADOT1U:
8472 case RISCV::SMT_VMADOT1US:
8473 case RISCV::SMT_VMADOT2:
8474 case RISCV::SMT_VMADOT2SU:
8475 case RISCV::SMT_VMADOT2U:
8476 case RISCV::SMT_VMADOT2US:
8477 case RISCV::SMT_VMADOT3:
8478 case RISCV::SMT_VMADOT3SU:
8479 case RISCV::SMT_VMADOT3U:
8480 case RISCV::SMT_VMADOT3US: {
8481 // op: vd
8482 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8483 Value |= (op & 0x1e) << 7;
8484 // op: vs1
8485 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8486 Value |= (op & 0x1e) << 15;
8487 // op: vs2
8488 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8489 Value |= (op & 0x1f) << 20;
8490 break;
8491 }
8492 case RISCV::SMT_VMADOT:
8493 case RISCV::SMT_VMADOTSU:
8494 case RISCV::SMT_VMADOTU:
8495 case RISCV::SMT_VMADOTUS: {
8496 // op: vd
8497 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8498 Value |= (op & 0x1e) << 7;
8499 // op: vs1
8500 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8501 Value |= (op & 0x1f) << 15;
8502 // op: vs2
8503 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8504 Value |= (op & 0x1f) << 20;
8505 break;
8506 }
8507 case RISCV::RI_VZERO: {
8508 // op: vd
8509 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8510 Value |= (op & 0x1f) << 7;
8511 break;
8512 }
8513 case RISCV::VMV_V_I: {
8514 // op: vd
8515 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8516 Value |= (op & 0x1f) << 7;
8517 // op: imm
8518 op = getImmOpValue(MI, OpNo: 1, Fixups, STI);
8519 Value |= (op & 0x1f) << 15;
8520 break;
8521 }
8522 case RISCV::VFMV_V_F:
8523 case RISCV::VMV_V_X: {
8524 // op: vd
8525 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8526 Value |= (op & 0x1f) << 7;
8527 // op: rs1
8528 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8529 Value |= (op & 0x1f) << 15;
8530 break;
8531 }
8532 case RISCV::VID_V: {
8533 // op: vd
8534 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8535 Value |= (op & 0x1f) << 7;
8536 // op: vm
8537 op = getVMaskReg(MI, OpNo: 1, Fixups, STI);
8538 Value |= (op & 0x1) << 25;
8539 break;
8540 }
8541 case RISCV::SF_VFEXPA_V:
8542 case RISCV::SF_VFEXP_V:
8543 case RISCV::VBREV8_V:
8544 case RISCV::VBREV_V:
8545 case RISCV::VCLZ_V:
8546 case RISCV::VCPOP_V:
8547 case RISCV::VCTZ_V:
8548 case RISCV::VFCLASS_V:
8549 case RISCV::VFCVT_F_XU_V:
8550 case RISCV::VFCVT_F_X_V:
8551 case RISCV::VFCVT_RTZ_XU_F_V:
8552 case RISCV::VFCVT_RTZ_X_F_V:
8553 case RISCV::VFCVT_XU_F_V:
8554 case RISCV::VFCVT_X_F_V:
8555 case RISCV::VFNCVTBF16_F_F_W:
8556 case RISCV::VFNCVTBF16_SAT_F_F_W:
8557 case RISCV::VFNCVT_F_F_Q:
8558 case RISCV::VFNCVT_F_F_W:
8559 case RISCV::VFNCVT_F_XU_W:
8560 case RISCV::VFNCVT_F_X_W:
8561 case RISCV::VFNCVT_ROD_F_F_W:
8562 case RISCV::VFNCVT_RTZ_XU_F_W:
8563 case RISCV::VFNCVT_RTZ_X_F_W:
8564 case RISCV::VFNCVT_SAT_F_F_Q:
8565 case RISCV::VFNCVT_XU_F_W:
8566 case RISCV::VFNCVT_X_F_W:
8567 case RISCV::VFREC7_V:
8568 case RISCV::VFRSQRT7_V:
8569 case RISCV::VFSQRT_V:
8570 case RISCV::VFWCVTBF16_F_F_V:
8571 case RISCV::VFWCVT_F_F_V:
8572 case RISCV::VFWCVT_F_XU_V:
8573 case RISCV::VFWCVT_F_X_V:
8574 case RISCV::VFWCVT_RTZ_XU_F_V:
8575 case RISCV::VFWCVT_RTZ_X_F_V:
8576 case RISCV::VFWCVT_XU_F_V:
8577 case RISCV::VFWCVT_X_F_V:
8578 case RISCV::VIOTA_M:
8579 case RISCV::VMSBF_M:
8580 case RISCV::VMSIF_M:
8581 case RISCV::VMSOF_M:
8582 case RISCV::VREV8_V:
8583 case RISCV::VSEXT_VF2:
8584 case RISCV::VSEXT_VF4:
8585 case RISCV::VSEXT_VF8:
8586 case RISCV::VZEXT_VF2:
8587 case RISCV::VZEXT_VF4:
8588 case RISCV::VZEXT_VF8: {
8589 // op: vd
8590 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8591 Value |= (op & 0x1f) << 7;
8592 // op: vm
8593 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
8594 Value |= (op & 0x1) << 25;
8595 // op: vs2
8596 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8597 Value |= (op & 0x1f) << 20;
8598 break;
8599 }
8600 case RISCV::VADD_VI:
8601 case RISCV::VAND_VI:
8602 case RISCV::VMSEQ_VI:
8603 case RISCV::VMSGTU_VI:
8604 case RISCV::VMSGT_VI:
8605 case RISCV::VMSLEU_VI:
8606 case RISCV::VMSLE_VI:
8607 case RISCV::VMSNE_VI:
8608 case RISCV::VNCLIPU_WI:
8609 case RISCV::VNCLIP_WI:
8610 case RISCV::VNSRA_WI:
8611 case RISCV::VNSRL_WI:
8612 case RISCV::VOR_VI:
8613 case RISCV::VRGATHER_VI:
8614 case RISCV::VRSUB_VI:
8615 case RISCV::VSADDU_VI:
8616 case RISCV::VSADD_VI:
8617 case RISCV::VSLIDEDOWN_VI:
8618 case RISCV::VSLIDEUP_VI:
8619 case RISCV::VSLL_VI:
8620 case RISCV::VSRA_VI:
8621 case RISCV::VSRL_VI:
8622 case RISCV::VSSRA_VI:
8623 case RISCV::VSSRL_VI:
8624 case RISCV::VWSLL_VI:
8625 case RISCV::VXOR_VI: {
8626 // op: vd
8627 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8628 Value |= (op & 0x1f) << 7;
8629 // op: vm
8630 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8631 Value |= (op & 0x1) << 25;
8632 // op: vs2
8633 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8634 Value |= (op & 0x1f) << 20;
8635 // op: imm
8636 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8637 Value |= (op & 0x1f) << 15;
8638 break;
8639 }
8640 case RISCV::VROR_VI: {
8641 // op: vd
8642 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8643 Value |= (op & 0x1f) << 7;
8644 // op: vm
8645 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8646 Value |= (op & 0x1) << 25;
8647 // op: vs2
8648 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8649 Value |= (op & 0x1f) << 20;
8650 // op: imm
8651 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8652 Value |= (op & 0x20) << 21;
8653 Value |= (op & 0x1f) << 15;
8654 break;
8655 }
8656 case RISCV::SF_VFNRCLIP_XU_F_QF:
8657 case RISCV::SF_VFNRCLIP_X_F_QF:
8658 case RISCV::VAADDU_VX:
8659 case RISCV::VAADD_VX:
8660 case RISCV::VADD_VX:
8661 case RISCV::VANDN_VX:
8662 case RISCV::VAND_VX:
8663 case RISCV::VASUBU_VX:
8664 case RISCV::VASUB_VX:
8665 case RISCV::VCLMULH_VX:
8666 case RISCV::VCLMUL_VX:
8667 case RISCV::VDIVU_VX:
8668 case RISCV::VDIV_VX:
8669 case RISCV::VFADD_VF:
8670 case RISCV::VFDIV_VF:
8671 case RISCV::VFMAX_VF:
8672 case RISCV::VFMIN_VF:
8673 case RISCV::VFMUL_VF:
8674 case RISCV::VFRDIV_VF:
8675 case RISCV::VFRSUB_VF:
8676 case RISCV::VFSGNJN_VF:
8677 case RISCV::VFSGNJX_VF:
8678 case RISCV::VFSGNJ_VF:
8679 case RISCV::VFSLIDE1DOWN_VF:
8680 case RISCV::VFSLIDE1UP_VF:
8681 case RISCV::VFSUB_VF:
8682 case RISCV::VFWADD_VF:
8683 case RISCV::VFWADD_WF:
8684 case RISCV::VFWMUL_VF:
8685 case RISCV::VFWSUB_VF:
8686 case RISCV::VFWSUB_WF:
8687 case RISCV::VMAXU_VX:
8688 case RISCV::VMAX_VX:
8689 case RISCV::VMFEQ_VF:
8690 case RISCV::VMFGE_VF:
8691 case RISCV::VMFGT_VF:
8692 case RISCV::VMFLE_VF:
8693 case RISCV::VMFLT_VF:
8694 case RISCV::VMFNE_VF:
8695 case RISCV::VMINU_VX:
8696 case RISCV::VMIN_VX:
8697 case RISCV::VMSEQ_VX:
8698 case RISCV::VMSGTU_VX:
8699 case RISCV::VMSGT_VX:
8700 case RISCV::VMSLEU_VX:
8701 case RISCV::VMSLE_VX:
8702 case RISCV::VMSLTU_VX:
8703 case RISCV::VMSLT_VX:
8704 case RISCV::VMSNE_VX:
8705 case RISCV::VMULHSU_VX:
8706 case RISCV::VMULHU_VX:
8707 case RISCV::VMULH_VX:
8708 case RISCV::VMUL_VX:
8709 case RISCV::VNCLIPU_WX:
8710 case RISCV::VNCLIP_WX:
8711 case RISCV::VNSRA_WX:
8712 case RISCV::VNSRL_WX:
8713 case RISCV::VOR_VX:
8714 case RISCV::VREMU_VX:
8715 case RISCV::VREM_VX:
8716 case RISCV::VRGATHER_VX:
8717 case RISCV::VROL_VX:
8718 case RISCV::VROR_VX:
8719 case RISCV::VRSUB_VX:
8720 case RISCV::VSADDU_VX:
8721 case RISCV::VSADD_VX:
8722 case RISCV::VSLIDE1DOWN_VX:
8723 case RISCV::VSLIDE1UP_VX:
8724 case RISCV::VSLIDEDOWN_VX:
8725 case RISCV::VSLIDEUP_VX:
8726 case RISCV::VSLL_VX:
8727 case RISCV::VSMUL_VX:
8728 case RISCV::VSRA_VX:
8729 case RISCV::VSRL_VX:
8730 case RISCV::VSSRA_VX:
8731 case RISCV::VSSRL_VX:
8732 case RISCV::VSSUBU_VX:
8733 case RISCV::VSSUB_VX:
8734 case RISCV::VSUB_VX:
8735 case RISCV::VWADDU_VX:
8736 case RISCV::VWADDU_WX:
8737 case RISCV::VWADD_VX:
8738 case RISCV::VWADD_WX:
8739 case RISCV::VWMULSU_VX:
8740 case RISCV::VWMULU_VX:
8741 case RISCV::VWMUL_VX:
8742 case RISCV::VWSLL_VX:
8743 case RISCV::VWSUBU_VX:
8744 case RISCV::VWSUBU_WX:
8745 case RISCV::VWSUB_VX:
8746 case RISCV::VWSUB_WX:
8747 case RISCV::VXOR_VX: {
8748 // op: vd
8749 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8750 Value |= (op & 0x1f) << 7;
8751 // op: vm
8752 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8753 Value |= (op & 0x1) << 25;
8754 // op: vs2
8755 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8756 Value |= (op & 0x1f) << 20;
8757 // op: rs1
8758 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8759 Value |= (op & 0x1f) << 15;
8760 break;
8761 }
8762 case RISCV::RI_VUNZIP2A_VV:
8763 case RISCV::RI_VUNZIP2B_VV:
8764 case RISCV::RI_VZIP2A_VV:
8765 case RISCV::RI_VZIP2B_VV:
8766 case RISCV::RI_VZIPEVEN_VV:
8767 case RISCV::RI_VZIPODD_VV:
8768 case RISCV::VAADDU_VV:
8769 case RISCV::VAADD_VV:
8770 case RISCV::VADD_VV:
8771 case RISCV::VANDN_VV:
8772 case RISCV::VAND_VV:
8773 case RISCV::VASUBU_VV:
8774 case RISCV::VASUB_VV:
8775 case RISCV::VCLMULH_VV:
8776 case RISCV::VCLMUL_VV:
8777 case RISCV::VDIVU_VV:
8778 case RISCV::VDIV_VV:
8779 case RISCV::VFADD_VV:
8780 case RISCV::VFDIV_VV:
8781 case RISCV::VFMAX_VV:
8782 case RISCV::VFMIN_VV:
8783 case RISCV::VFMUL_VV:
8784 case RISCV::VFREDMAX_VS:
8785 case RISCV::VFREDMIN_VS:
8786 case RISCV::VFREDOSUM_VS:
8787 case RISCV::VFREDUSUM_VS:
8788 case RISCV::VFSGNJN_VV:
8789 case RISCV::VFSGNJX_VV:
8790 case RISCV::VFSGNJ_VV:
8791 case RISCV::VFSUB_VV:
8792 case RISCV::VFWADD_VV:
8793 case RISCV::VFWADD_WV:
8794 case RISCV::VFWMUL_VV:
8795 case RISCV::VFWREDOSUM_VS:
8796 case RISCV::VFWREDUSUM_VS:
8797 case RISCV::VFWSUB_VV:
8798 case RISCV::VFWSUB_WV:
8799 case RISCV::VMAXU_VV:
8800 case RISCV::VMAX_VV:
8801 case RISCV::VMFEQ_VV:
8802 case RISCV::VMFLE_VV:
8803 case RISCV::VMFLT_VV:
8804 case RISCV::VMFNE_VV:
8805 case RISCV::VMINU_VV:
8806 case RISCV::VMIN_VV:
8807 case RISCV::VMSEQ_VV:
8808 case RISCV::VMSLEU_VV:
8809 case RISCV::VMSLE_VV:
8810 case RISCV::VMSLTU_VV:
8811 case RISCV::VMSLT_VV:
8812 case RISCV::VMSNE_VV:
8813 case RISCV::VMULHSU_VV:
8814 case RISCV::VMULHU_VV:
8815 case RISCV::VMULH_VV:
8816 case RISCV::VMUL_VV:
8817 case RISCV::VNCLIPU_WV:
8818 case RISCV::VNCLIP_WV:
8819 case RISCV::VNSRA_WV:
8820 case RISCV::VNSRL_WV:
8821 case RISCV::VOR_VV:
8822 case RISCV::VREDAND_VS:
8823 case RISCV::VREDMAXU_VS:
8824 case RISCV::VREDMAX_VS:
8825 case RISCV::VREDMINU_VS:
8826 case RISCV::VREDMIN_VS:
8827 case RISCV::VREDOR_VS:
8828 case RISCV::VREDSUM_VS:
8829 case RISCV::VREDXOR_VS:
8830 case RISCV::VREMU_VV:
8831 case RISCV::VREM_VV:
8832 case RISCV::VRGATHEREI16_VV:
8833 case RISCV::VRGATHER_VV:
8834 case RISCV::VROL_VV:
8835 case RISCV::VROR_VV:
8836 case RISCV::VSADDU_VV:
8837 case RISCV::VSADD_VV:
8838 case RISCV::VSLL_VV:
8839 case RISCV::VSMUL_VV:
8840 case RISCV::VSRA_VV:
8841 case RISCV::VSRL_VV:
8842 case RISCV::VSSRA_VV:
8843 case RISCV::VSSRL_VV:
8844 case RISCV::VSSUBU_VV:
8845 case RISCV::VSSUB_VV:
8846 case RISCV::VSUB_VV:
8847 case RISCV::VWADDU_VV:
8848 case RISCV::VWADDU_WV:
8849 case RISCV::VWADD_VV:
8850 case RISCV::VWADD_WV:
8851 case RISCV::VWMULSU_VV:
8852 case RISCV::VWMULU_VV:
8853 case RISCV::VWMUL_VV:
8854 case RISCV::VWREDSUMU_VS:
8855 case RISCV::VWREDSUM_VS:
8856 case RISCV::VWSLL_VV:
8857 case RISCV::VWSUBU_VV:
8858 case RISCV::VWSUBU_WV:
8859 case RISCV::VWSUB_VV:
8860 case RISCV::VWSUB_WV:
8861 case RISCV::VXOR_VV: {
8862 // op: vd
8863 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8864 Value |= (op & 0x1f) << 7;
8865 // op: vm
8866 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
8867 Value |= (op & 0x1) << 25;
8868 // op: vs2
8869 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8870 Value |= (op & 0x1f) << 20;
8871 // op: vs1
8872 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8873 Value |= (op & 0x1f) << 15;
8874 break;
8875 }
8876 case RISCV::VMV_V_V: {
8877 // op: vd
8878 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8879 Value |= (op & 0x1f) << 7;
8880 // op: vs1
8881 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8882 Value |= (op & 0x1f) << 15;
8883 break;
8884 }
8885 case RISCV::VMV1R_V:
8886 case RISCV::VMV2R_V:
8887 case RISCV::VMV4R_V:
8888 case RISCV::VMV8R_V: {
8889 // op: vd
8890 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8891 Value |= (op & 0x1f) << 7;
8892 // op: vs2
8893 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8894 Value |= (op & 0x1f) << 20;
8895 break;
8896 }
8897 case RISCV::VADC_VIM:
8898 case RISCV::VAESKF1_VI:
8899 case RISCV::VMADC_VI:
8900 case RISCV::VMADC_VIM:
8901 case RISCV::VMERGE_VIM:
8902 case RISCV::VSM4K_VI: {
8903 // op: vd
8904 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8905 Value |= (op & 0x1f) << 7;
8906 // op: vs2
8907 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8908 Value |= (op & 0x1f) << 20;
8909 // op: imm
8910 op = getImmOpValue(MI, OpNo: 2, Fixups, STI);
8911 Value |= (op & 0x1f) << 15;
8912 break;
8913 }
8914 case RISCV::VADC_VXM:
8915 case RISCV::VFMERGE_VFM:
8916 case RISCV::VMADC_VX:
8917 case RISCV::VMADC_VXM:
8918 case RISCV::VMERGE_VXM:
8919 case RISCV::VMSBC_VX:
8920 case RISCV::VMSBC_VXM:
8921 case RISCV::VSBC_VXM: {
8922 // op: vd
8923 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8924 Value |= (op & 0x1f) << 7;
8925 // op: vs2
8926 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8927 Value |= (op & 0x1f) << 20;
8928 // op: rs1
8929 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8930 Value |= (op & 0x1f) << 15;
8931 break;
8932 }
8933 case RISCV::VADC_VVM:
8934 case RISCV::VCOMPRESS_VM:
8935 case RISCV::VMADC_VV:
8936 case RISCV::VMADC_VVM:
8937 case RISCV::VMANDN_MM:
8938 case RISCV::VMAND_MM:
8939 case RISCV::VMERGE_VVM:
8940 case RISCV::VMNAND_MM:
8941 case RISCV::VMNOR_MM:
8942 case RISCV::VMORN_MM:
8943 case RISCV::VMOR_MM:
8944 case RISCV::VMSBC_VV:
8945 case RISCV::VMSBC_VVM:
8946 case RISCV::VMXNOR_MM:
8947 case RISCV::VMXOR_MM:
8948 case RISCV::VSBC_VVM:
8949 case RISCV::VSM3ME_VV: {
8950 // op: vd
8951 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
8952 Value |= (op & 0x1f) << 7;
8953 // op: vs2
8954 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8955 Value |= (op & 0x1f) << 20;
8956 // op: vs1
8957 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8958 Value |= (op & 0x1f) << 15;
8959 break;
8960 }
8961 case RISCV::VFMV_S_F:
8962 case RISCV::VMV_S_X: {
8963 // op: vd
8964 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8965 Value |= (op & 0x1f) << 7;
8966 // op: rs1
8967 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8968 Value |= (op & 0x1f) << 15;
8969 break;
8970 }
8971 case RISCV::VQDOTSU_VX:
8972 case RISCV::VQDOTUS_VX:
8973 case RISCV::VQDOTU_VX:
8974 case RISCV::VQDOT_VX: {
8975 // op: vd
8976 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8977 Value |= (op & 0x1f) << 7;
8978 // op: vm
8979 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8980 Value |= (op & 0x1) << 25;
8981 // op: vs2
8982 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
8983 Value |= (op & 0x1f) << 20;
8984 // op: rs1
8985 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
8986 Value |= (op & 0x1f) << 15;
8987 break;
8988 }
8989 case RISCV::VQDOTSU_VV:
8990 case RISCV::VQDOTU_VV:
8991 case RISCV::VQDOT_VV: {
8992 // op: vd
8993 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
8994 Value |= (op & 0x1f) << 7;
8995 // op: vm
8996 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
8997 Value |= (op & 0x1) << 25;
8998 // op: vs2
8999 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9000 Value |= (op & 0x1f) << 20;
9001 // op: vs1
9002 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9003 Value |= (op & 0x1f) << 15;
9004 break;
9005 }
9006 case RISCV::TH_VMAQASU_VX:
9007 case RISCV::TH_VMAQAUS_VX:
9008 case RISCV::TH_VMAQAU_VX:
9009 case RISCV::TH_VMAQA_VX:
9010 case RISCV::VFMACC_VF:
9011 case RISCV::VFMADD_VF:
9012 case RISCV::VFMSAC_VF:
9013 case RISCV::VFMSUB_VF:
9014 case RISCV::VFNMACC_VF:
9015 case RISCV::VFNMADD_VF:
9016 case RISCV::VFNMSAC_VF:
9017 case RISCV::VFNMSUB_VF:
9018 case RISCV::VFWMACCBF16_VF:
9019 case RISCV::VFWMACC_VF:
9020 case RISCV::VFWMSAC_VF:
9021 case RISCV::VFWNMACC_VF:
9022 case RISCV::VFWNMSAC_VF:
9023 case RISCV::VMACC_VX:
9024 case RISCV::VMADD_VX:
9025 case RISCV::VNMSAC_VX:
9026 case RISCV::VNMSUB_VX:
9027 case RISCV::VWMACCSU_VX:
9028 case RISCV::VWMACCUS_VX:
9029 case RISCV::VWMACCU_VX:
9030 case RISCV::VWMACC_VX: {
9031 // op: vd
9032 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9033 Value |= (op & 0x1f) << 7;
9034 // op: vm
9035 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
9036 Value |= (op & 0x1) << 25;
9037 // op: vs2
9038 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9039 Value |= (op & 0x1f) << 20;
9040 // op: rs1
9041 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9042 Value |= (op & 0x1f) << 15;
9043 break;
9044 }
9045 case RISCV::TH_VMAQASU_VV:
9046 case RISCV::TH_VMAQAU_VV:
9047 case RISCV::TH_VMAQA_VV:
9048 case RISCV::VFMACC_VV:
9049 case RISCV::VFMADD_VV:
9050 case RISCV::VFMSAC_VV:
9051 case RISCV::VFMSUB_VV:
9052 case RISCV::VFNMACC_VV:
9053 case RISCV::VFNMADD_VV:
9054 case RISCV::VFNMSAC_VV:
9055 case RISCV::VFNMSUB_VV:
9056 case RISCV::VFWMACCBF16_VV:
9057 case RISCV::VFWMACC_VV:
9058 case RISCV::VFWMSAC_VV:
9059 case RISCV::VFWNMACC_VV:
9060 case RISCV::VFWNMSAC_VV:
9061 case RISCV::VMACC_VV:
9062 case RISCV::VMADD_VV:
9063 case RISCV::VNMSAC_VV:
9064 case RISCV::VNMSUB_VV:
9065 case RISCV::VWMACCSU_VV:
9066 case RISCV::VWMACCU_VV:
9067 case RISCV::VWMACC_VV: {
9068 // op: vd
9069 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9070 Value |= (op & 0x1f) << 7;
9071 // op: vm
9072 op = getVMaskReg(MI, OpNo: 4, Fixups, STI);
9073 Value |= (op & 0x1) << 25;
9074 // op: vs2
9075 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9076 Value |= (op & 0x1f) << 20;
9077 // op: vs1
9078 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9079 Value |= (op & 0x1f) << 15;
9080 break;
9081 }
9082 case RISCV::VAESDF_VS:
9083 case RISCV::VAESDF_VV:
9084 case RISCV::VAESDM_VS:
9085 case RISCV::VAESDM_VV:
9086 case RISCV::VAESEF_VS:
9087 case RISCV::VAESEF_VV:
9088 case RISCV::VAESEM_VS:
9089 case RISCV::VAESEM_VV:
9090 case RISCV::VAESZ_VS:
9091 case RISCV::VGMUL_VS:
9092 case RISCV::VGMUL_VV:
9093 case RISCV::VSM4R_VS:
9094 case RISCV::VSM4R_VV: {
9095 // op: vd
9096 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9097 Value |= (op & 0x1f) << 7;
9098 // op: vs2
9099 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9100 Value |= (op & 0x1f) << 20;
9101 break;
9102 }
9103 case RISCV::VAESKF2_VI:
9104 case RISCV::VSM3C_VI: {
9105 // op: vd
9106 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9107 Value |= (op & 0x1f) << 7;
9108 // op: vs2
9109 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9110 Value |= (op & 0x1f) << 20;
9111 // op: imm
9112 op = getImmOpValue(MI, OpNo: 3, Fixups, STI);
9113 Value |= (op & 0x1f) << 15;
9114 break;
9115 }
9116 case RISCV::VGHSH_VS:
9117 case RISCV::VGHSH_VV:
9118 case RISCV::VSHA2CH_VV:
9119 case RISCV::VSHA2CL_VV:
9120 case RISCV::VSHA2MS_VV: {
9121 // op: vd
9122 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9123 Value |= (op & 0x1f) << 7;
9124 // op: vs2
9125 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9126 Value |= (op & 0x1f) << 20;
9127 // op: vs1
9128 op = getMachineOpValue(MI, MO: MI.getOperand(i: 3), Fixups, STI);
9129 Value |= (op & 0x1f) << 15;
9130 break;
9131 }
9132 case RISCV::NDS_VFWCVT_F_B:
9133 case RISCV::NDS_VFWCVT_F_BU:
9134 case RISCV::NDS_VFWCVT_F_N:
9135 case RISCV::NDS_VFWCVT_F_NU: {
9136 // op: vs
9137 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9138 Value |= (op & 0x1f) << 20;
9139 // op: vd
9140 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9141 Value |= (op & 0x1f) << 7;
9142 // op: vm
9143 op = getVMaskReg(MI, OpNo: 2, Fixups, STI);
9144 Value |= (op & 0x1) << 25;
9145 break;
9146 }
9147 case RISCV::NDS_VFPMADB_VF:
9148 case RISCV::NDS_VFPMADT_VF: {
9149 // op: vs2
9150 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9151 Value |= (op & 0x1f) << 20;
9152 // op: rs1
9153 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9154 Value |= (op & 0x1f) << 15;
9155 // op: vd
9156 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9157 Value |= (op & 0x1f) << 7;
9158 // op: vm
9159 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
9160 Value |= (op & 0x1) << 25;
9161 break;
9162 }
9163 case RISCV::NDS_VFNCVT_BF16_S:
9164 case RISCV::NDS_VFWCVT_S_BF16: {
9165 // op: vs2
9166 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9167 Value |= (op & 0x1f) << 20;
9168 // op: vd
9169 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9170 Value |= (op & 0x1f) << 7;
9171 break;
9172 }
9173 case RISCV::SF_MM_E4M3_E4M3:
9174 case RISCV::SF_MM_E4M3_E5M2:
9175 case RISCV::SF_MM_E5M2_E4M3:
9176 case RISCV::SF_MM_E5M2_E5M2:
9177 case RISCV::SF_MM_S_S:
9178 case RISCV::SF_MM_S_U:
9179 case RISCV::SF_MM_U_S:
9180 case RISCV::SF_MM_U_U: {
9181 // op: vs2
9182 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9183 Value |= (op & 0x1f) << 20;
9184 // op: vs1
9185 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9186 Value |= (op & 0x1f) << 15;
9187 // op: rd
9188 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9189 Value |= (op & 0xc) << 8;
9190 break;
9191 }
9192 case RISCV::SF_MM_F_F: {
9193 // op: vs2
9194 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9195 Value |= (op & 0x1f) << 20;
9196 // op: vs1
9197 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9198 Value |= (op & 0x1f) << 15;
9199 // op: rd
9200 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9201 Value |= (op & 0xe) << 8;
9202 break;
9203 }
9204 case RISCV::NDS_VD4DOTSU_VV:
9205 case RISCV::NDS_VD4DOTS_VV:
9206 case RISCV::NDS_VD4DOTU_VV: {
9207 // op: vs2
9208 op = getMachineOpValue(MI, MO: MI.getOperand(i: 2), Fixups, STI);
9209 Value |= (op & 0x1f) << 20;
9210 // op: vs1
9211 op = getMachineOpValue(MI, MO: MI.getOperand(i: 1), Fixups, STI);
9212 Value |= (op & 0x1f) << 15;
9213 // op: vd
9214 op = getMachineOpValue(MI, MO: MI.getOperand(i: 0), Fixups, STI);
9215 Value |= (op & 0x1f) << 7;
9216 // op: vm
9217 op = getVMaskReg(MI, OpNo: 3, Fixups, STI);
9218 Value |= (op & 0x1) << 25;
9219 break;
9220 }
9221 default:
9222 reportUnsupportedInst(Inst: MI);
9223 }
9224 return Value;
9225}
9226
9227#ifdef GET_OPERAND_BIT_OFFSET
9228#undef GET_OPERAND_BIT_OFFSET
9229
9230uint32_t RISCVMCCodeEmitter::getOperandBitOffset(const MCInst &MI,
9231 unsigned OpNum,
9232 const MCSubtargetInfo &STI) const {
9233 switch (MI.getOpcode()) {
9234 case RISCV::C_EBREAK:
9235 case RISCV::C_MOP_11:
9236 case RISCV::C_MOP_13:
9237 case RISCV::C_MOP_15:
9238 case RISCV::C_MOP_3:
9239 case RISCV::C_MOP_7:
9240 case RISCV::C_MOP_9:
9241 case RISCV::C_NOP:
9242 case RISCV::C_SSPOPCHK:
9243 case RISCV::C_SSPUSH:
9244 case RISCV::C_UNIMP:
9245 case RISCV::DRET:
9246 case RISCV::EBREAK:
9247 case RISCV::ECALL:
9248 case RISCV::FENCE_I:
9249 case RISCV::FENCE_TSO:
9250 case RISCV::MIPS_EHB:
9251 case RISCV::MIPS_IHB:
9252 case RISCV::MIPS_PAUSE:
9253 case RISCV::MNRET:
9254 case RISCV::MRET:
9255 case RISCV::QC_C_DI:
9256 case RISCV::QC_C_EI:
9257 case RISCV::QC_C_MIENTER:
9258 case RISCV::QC_C_MIENTER_NEST:
9259 case RISCV::QC_C_MILEAVERET:
9260 case RISCV::QC_C_MNRET:
9261 case RISCV::QC_C_MRET:
9262 case RISCV::SCTRCLR:
9263 case RISCV::SFENCE_INVAL_IR:
9264 case RISCV::SFENCE_W_INVAL:
9265 case RISCV::SF_CEASE:
9266 case RISCV::SF_VTDISCARD:
9267 case RISCV::SRET:
9268 case RISCV::TH_DCACHE_CALL:
9269 case RISCV::TH_DCACHE_CIALL:
9270 case RISCV::TH_DCACHE_IALL:
9271 case RISCV::TH_ICACHE_IALL:
9272 case RISCV::TH_ICACHE_IALLS:
9273 case RISCV::TH_L2CACHE_CALL:
9274 case RISCV::TH_L2CACHE_CIALL:
9275 case RISCV::TH_L2CACHE_IALL:
9276 case RISCV::TH_SYNC:
9277 case RISCV::TH_SYNC_I:
9278 case RISCV::TH_SYNC_IS:
9279 case RISCV::TH_SYNC_S:
9280 case RISCV::UNIMP:
9281 case RISCV::WFI:
9282 case RISCV::WRS_NTO:
9283 case RISCV::WRS_STO: {
9284 break;
9285 }
9286 case RISCV::AIF_FSWG_PS:
9287 case RISCV::AIF_FSWL_PS: {
9288 switch (OpNum) {
9289 case 0:
9290 // op: fs3
9291 return 7;
9292 case 1:
9293 // op: rs1
9294 return 15;
9295 }
9296 break;
9297 }
9298 case RISCV::C_NOP_HINT: {
9299 switch (OpNum) {
9300 case 0:
9301 // op: imm
9302 return 2;
9303 }
9304 break;
9305 }
9306 case RISCV::QC_CLRINTI:
9307 case RISCV::QC_SETINTI: {
9308 switch (OpNum) {
9309 case 0:
9310 // op: imm10
9311 return 15;
9312 }
9313 break;
9314 }
9315 case RISCV::QC_E_J:
9316 case RISCV::QC_E_JAL: {
9317 switch (OpNum) {
9318 case 0:
9319 // op: imm31
9320 return 7;
9321 }
9322 break;
9323 }
9324 case RISCV::QC_SYNC:
9325 case RISCV::QC_SYNCR:
9326 case RISCV::QC_SYNCWF:
9327 case RISCV::QC_SYNCWL: {
9328 switch (OpNum) {
9329 case 0:
9330 // op: imm5
9331 return 20;
9332 }
9333 break;
9334 }
9335 case RISCV::QC_PPUTCI: {
9336 switch (OpNum) {
9337 case 0:
9338 // op: imm8
9339 return 20;
9340 }
9341 break;
9342 }
9343 case RISCV::CM_JALT:
9344 case RISCV::CM_JT: {
9345 switch (OpNum) {
9346 case 0:
9347 // op: index
9348 return 2;
9349 }
9350 break;
9351 }
9352 case RISCV::C_J:
9353 case RISCV::C_JAL: {
9354 switch (OpNum) {
9355 case 0:
9356 // op: offset
9357 return 2;
9358 }
9359 break;
9360 }
9361 case RISCV::InsnQC_EJ: {
9362 switch (OpNum) {
9363 case 0:
9364 // op: opcode
9365 return 0;
9366 case 1:
9367 // op: func3
9368 return 12;
9369 case 2:
9370 // op: func2
9371 return 15;
9372 case 3:
9373 // op: func5
9374 return 20;
9375 case 4:
9376 // op: imm31
9377 return 7;
9378 }
9379 break;
9380 }
9381 case RISCV::InsnQC_ES: {
9382 switch (OpNum) {
9383 case 0:
9384 // op: opcode
9385 return 0;
9386 case 1:
9387 // op: func3
9388 return 12;
9389 case 2:
9390 // op: func2
9391 return 30;
9392 case 4:
9393 // op: rs1
9394 return 15;
9395 case 3:
9396 // op: rs2
9397 return 20;
9398 case 5:
9399 // op: imm26
9400 return 7;
9401 }
9402 break;
9403 }
9404 case RISCV::InsnQC_EB: {
9405 switch (OpNum) {
9406 case 0:
9407 // op: opcode
9408 return 0;
9409 case 1:
9410 // op: func3
9411 return 12;
9412 case 2:
9413 // op: func5
9414 return 20;
9415 case 3:
9416 // op: rs1
9417 return 15;
9418 case 5:
9419 // op: imm12
9420 return 7;
9421 case 4:
9422 // op: imm16
9423 return 32;
9424 }
9425 break;
9426 }
9427 case RISCV::InsnS: {
9428 switch (OpNum) {
9429 case 0:
9430 // op: opcode
9431 return 0;
9432 case 1:
9433 // op: funct3
9434 return 12;
9435 case 4:
9436 // op: imm12
9437 return 7;
9438 case 2:
9439 // op: rs2
9440 return 20;
9441 case 3:
9442 // op: rs1
9443 return 15;
9444 }
9445 break;
9446 }
9447 case RISCV::InsnB: {
9448 switch (OpNum) {
9449 case 0:
9450 // op: opcode
9451 return 0;
9452 case 1:
9453 // op: funct3
9454 return 12;
9455 case 4:
9456 // op: imm12
9457 return 7;
9458 case 3:
9459 // op: rs2
9460 return 20;
9461 case 2:
9462 // op: rs1
9463 return 15;
9464 }
9465 break;
9466 }
9467 case RISCV::InsnCJ: {
9468 switch (OpNum) {
9469 case 0:
9470 // op: opcode
9471 return 0;
9472 case 1:
9473 // op: funct3
9474 return 13;
9475 case 2:
9476 // op: imm11
9477 return 2;
9478 }
9479 break;
9480 }
9481 case RISCV::InsnCSS: {
9482 switch (OpNum) {
9483 case 0:
9484 // op: opcode
9485 return 0;
9486 case 1:
9487 // op: funct3
9488 return 13;
9489 case 3:
9490 // op: imm6
9491 return 7;
9492 case 2:
9493 // op: rs2
9494 return 2;
9495 }
9496 break;
9497 }
9498 case RISCV::InsnCB: {
9499 switch (OpNum) {
9500 case 0:
9501 // op: opcode
9502 return 0;
9503 case 1:
9504 // op: funct3
9505 return 13;
9506 case 3:
9507 // op: imm8
9508 return 2;
9509 case 2:
9510 // op: rs1
9511 return 7;
9512 }
9513 break;
9514 }
9515 case RISCV::InsnCS: {
9516 switch (OpNum) {
9517 case 0:
9518 // op: opcode
9519 return 0;
9520 case 1:
9521 // op: funct3
9522 return 13;
9523 case 4:
9524 // op: imm5
9525 return 5;
9526 case 2:
9527 // op: rs2
9528 return 2;
9529 case 3:
9530 // op: rs1
9531 return 7;
9532 }
9533 break;
9534 }
9535 case RISCV::FENCE: {
9536 switch (OpNum) {
9537 case 0:
9538 // op: pred
9539 return 24;
9540 case 1:
9541 // op: succ
9542 return 20;
9543 }
9544 break;
9545 }
9546 case RISCV::C_FLD:
9547 case RISCV::C_FLW:
9548 case RISCV::C_LBU:
9549 case RISCV::C_LD:
9550 case RISCV::C_LD_RV32:
9551 case RISCV::C_LH:
9552 case RISCV::C_LHU:
9553 case RISCV::C_LH_INX:
9554 case RISCV::C_LW:
9555 case RISCV::C_LW_INX:
9556 case RISCV::QK_C_LBU:
9557 case RISCV::QK_C_LHU: {
9558 switch (OpNum) {
9559 case 0:
9560 // op: rd
9561 return 2;
9562 case 1:
9563 // op: rs1
9564 return 7;
9565 case 2:
9566 // op: imm
9567 return 5;
9568 }
9569 break;
9570 }
9571 case RISCV::FLI_D:
9572 case RISCV::FLI_H:
9573 case RISCV::FLI_Q:
9574 case RISCV::FLI_S: {
9575 switch (OpNum) {
9576 case 0:
9577 // op: rd
9578 return 7;
9579 case 1:
9580 // op: imm
9581 return 15;
9582 }
9583 break;
9584 }
9585 case RISCV::QC_E_LI: {
9586 switch (OpNum) {
9587 case 0:
9588 // op: rd
9589 return 7;
9590 case 1:
9591 // op: imm
9592 return 16;
9593 }
9594 break;
9595 }
9596 case RISCV::PLI_H:
9597 case RISCV::PLI_W:
9598 case RISCV::PLUI_H:
9599 case RISCV::PLUI_W: {
9600 switch (OpNum) {
9601 case 0:
9602 // op: rd
9603 return 7;
9604 case 1:
9605 // op: imm10
9606 return 15;
9607 }
9608 break;
9609 }
9610 case RISCV::PLI_B: {
9611 switch (OpNum) {
9612 case 0:
9613 // op: rd
9614 return 7;
9615 case 1:
9616 // op: imm8
9617 return 16;
9618 }
9619 break;
9620 }
9621 case RISCV::AIF_FMVS_X_PS:
9622 case RISCV::AIF_FMVZ_X_PS: {
9623 switch (OpNum) {
9624 case 0:
9625 // op: rd
9626 return 7;
9627 case 1:
9628 // op: rs1
9629 return 15;
9630 case 2:
9631 // op: idx
9632 return 20;
9633 }
9634 break;
9635 }
9636 case RISCV::AIF_FSWIZZ_PS: {
9637 switch (OpNum) {
9638 case 0:
9639 // op: rd
9640 return 7;
9641 case 1:
9642 // op: rs1
9643 return 15;
9644 case 2:
9645 // op: imm
9646 return 12;
9647 }
9648 break;
9649 }
9650 case RISCV::QC_E_ADDI:
9651 case RISCV::QC_E_ANDI:
9652 case RISCV::QC_E_LB:
9653 case RISCV::QC_E_LBU:
9654 case RISCV::QC_E_LH:
9655 case RISCV::QC_E_LHU:
9656 case RISCV::QC_E_LW:
9657 case RISCV::QC_E_ORI:
9658 case RISCV::QC_E_XORI: {
9659 switch (OpNum) {
9660 case 0:
9661 // op: rd
9662 return 7;
9663 case 1:
9664 // op: rs1
9665 return 15;
9666 case 2:
9667 // op: imm
9668 return 20;
9669 }
9670 break;
9671 }
9672 case RISCV::NDS_BFOS:
9673 case RISCV::NDS_BFOZ: {
9674 switch (OpNum) {
9675 case 0:
9676 // op: rd
9677 return 7;
9678 case 1:
9679 // op: rs1
9680 return 15;
9681 case 2:
9682 // op: msb
9683 return 26;
9684 case 3:
9685 // op: lsb
9686 return 20;
9687 }
9688 break;
9689 }
9690 case RISCV::AIF_FCVT_PS_PW:
9691 case RISCV::AIF_FCVT_PS_PWU:
9692 case RISCV::AIF_FCVT_PWU_PS:
9693 case RISCV::AIF_FCVT_PW_PS: {
9694 switch (OpNum) {
9695 case 0:
9696 // op: rd
9697 return 7;
9698 case 1:
9699 // op: rs1
9700 return 15;
9701 case 2:
9702 // op: rm
9703 return 12;
9704 }
9705 break;
9706 }
9707 case RISCV::AIF_FADD_PS:
9708 case RISCV::AIF_FDIV_PS:
9709 case RISCV::AIF_FMUL_PS:
9710 case RISCV::AIF_FSUB_PS: {
9711 switch (OpNum) {
9712 case 0:
9713 // op: rd
9714 return 7;
9715 case 1:
9716 // op: rs1
9717 return 15;
9718 case 2:
9719 // op: rs2
9720 return 20;
9721 case 3:
9722 // op: rm
9723 return 12;
9724 }
9725 break;
9726 }
9727 case RISCV::AIF_FMADD_PS:
9728 case RISCV::AIF_FMSUB_PS:
9729 case RISCV::AIF_FNMADD_PS:
9730 case RISCV::AIF_FNMSUB_PS: {
9731 switch (OpNum) {
9732 case 0:
9733 // op: rd
9734 return 7;
9735 case 1:
9736 // op: rs1
9737 return 15;
9738 case 2:
9739 // op: rs2
9740 return 20;
9741 case 3:
9742 // op: rs3
9743 return 27;
9744 case 4:
9745 // op: rm
9746 return 12;
9747 }
9748 break;
9749 }
9750 case RISCV::AIF_FCMOV_PS: {
9751 switch (OpNum) {
9752 case 0:
9753 // op: rd
9754 return 7;
9755 case 1:
9756 // op: rs1
9757 return 15;
9758 case 2:
9759 // op: rs2
9760 return 20;
9761 case 3:
9762 // op: rs3
9763 return 27;
9764 }
9765 break;
9766 }
9767 case RISCV::VSETIVLI: {
9768 switch (OpNum) {
9769 case 0:
9770 // op: rd
9771 return 7;
9772 case 1:
9773 // op: uimm
9774 return 15;
9775 case 2:
9776 // op: vtypei
9777 return 20;
9778 }
9779 break;
9780 }
9781 case RISCV::VFMV_F_S:
9782 case RISCV::VMV_X_S: {
9783 switch (OpNum) {
9784 case 0:
9785 // op: rd
9786 return 7;
9787 case 1:
9788 // op: vs2
9789 return 20;
9790 }
9791 break;
9792 }
9793 case RISCV::VCPOP_M:
9794 case RISCV::VFIRST_M: {
9795 switch (OpNum) {
9796 case 0:
9797 // op: rd
9798 return 7;
9799 case 2:
9800 // op: vm
9801 return 25;
9802 case 1:
9803 // op: vs2
9804 return 20;
9805 }
9806 break;
9807 }
9808 case RISCV::AIF_MOVA_X_M:
9809 case RISCV::QC_C_DIR:
9810 case RISCV::SSRDP: {
9811 switch (OpNum) {
9812 case 0:
9813 // op: rd
9814 return 7;
9815 }
9816 break;
9817 }
9818 case RISCV::PLI_DH:
9819 case RISCV::PLUI_DH: {
9820 switch (OpNum) {
9821 case 0:
9822 // op: rd
9823 return 8;
9824 case 1:
9825 // op: imm10
9826 return 15;
9827 }
9828 break;
9829 }
9830 case RISCV::PLI_DB: {
9831 switch (OpNum) {
9832 case 0:
9833 // op: rd
9834 return 8;
9835 case 1:
9836 // op: imm8
9837 return 16;
9838 }
9839 break;
9840 }
9841 case RISCV::SF_VTZERO_T: {
9842 switch (OpNum) {
9843 case 0:
9844 // op: rd
9845 return 8;
9846 }
9847 break;
9848 }
9849 case RISCV::QK_C_LBUSP:
9850 case RISCV::QK_C_LHUSP:
9851 case RISCV::QK_C_SBSP:
9852 case RISCV::QK_C_SHSP: {
9853 switch (OpNum) {
9854 case 0:
9855 // op: rd_rs2
9856 return 2;
9857 case 2:
9858 // op: imm
9859 return 7;
9860 }
9861 break;
9862 }
9863 case RISCV::CM_POP:
9864 case RISCV::CM_POPRET:
9865 case RISCV::CM_POPRETZ:
9866 case RISCV::CM_PUSH:
9867 case RISCV::QC_CM_POP:
9868 case RISCV::QC_CM_POPRET:
9869 case RISCV::QC_CM_POPRETZ:
9870 case RISCV::QC_CM_PUSH:
9871 case RISCV::QC_CM_PUSHFP: {
9872 switch (OpNum) {
9873 case 0:
9874 // op: rlist
9875 return 4;
9876 case 1:
9877 // op: stackadj
9878 return 2;
9879 }
9880 break;
9881 }
9882 case RISCV::QC_E_BEQI:
9883 case RISCV::QC_E_BGEI:
9884 case RISCV::QC_E_BGEUI:
9885 case RISCV::QC_E_BLTI:
9886 case RISCV::QC_E_BLTUI:
9887 case RISCV::QC_E_BNEI: {
9888 switch (OpNum) {
9889 case 0:
9890 // op: rs1
9891 return 15;
9892 case 1:
9893 // op: imm16
9894 return 32;
9895 case 2:
9896 // op: imm12
9897 return 7;
9898 }
9899 break;
9900 }
9901 case RISCV::AIF_MOVA_M_X:
9902 case RISCV::CBO_CLEAN:
9903 case RISCV::CBO_FLUSH:
9904 case RISCV::CBO_INVAL:
9905 case RISCV::CBO_ZERO:
9906 case RISCV::SF_CDISCARD_D_L1:
9907 case RISCV::SF_CFLUSH_D_L1:
9908 case RISCV::SSPOPCHK:
9909 case RISCV::TH_DCACHE_CIPA:
9910 case RISCV::TH_DCACHE_CISW:
9911 case RISCV::TH_DCACHE_CIVA:
9912 case RISCV::TH_DCACHE_CPA:
9913 case RISCV::TH_DCACHE_CPAL1:
9914 case RISCV::TH_DCACHE_CSW:
9915 case RISCV::TH_DCACHE_CVA:
9916 case RISCV::TH_DCACHE_CVAL1:
9917 case RISCV::TH_DCACHE_IPA:
9918 case RISCV::TH_DCACHE_ISW:
9919 case RISCV::TH_DCACHE_IVA:
9920 case RISCV::TH_ICACHE_IPA:
9921 case RISCV::TH_ICACHE_IVA: {
9922 switch (OpNum) {
9923 case 0:
9924 // op: rs1
9925 return 15;
9926 }
9927 break;
9928 }
9929 case RISCV::C_MV: {
9930 switch (OpNum) {
9931 case 0:
9932 // op: rs1
9933 return 7;
9934 case 1:
9935 // op: rs2
9936 return 2;
9937 }
9938 break;
9939 }
9940 case RISCV::C_JALR:
9941 case RISCV::C_JR:
9942 case RISCV::QC_C_CLRINT:
9943 case RISCV::QC_C_EIR:
9944 case RISCV::QC_C_SETINT: {
9945 switch (OpNum) {
9946 case 0:
9947 // op: rs1
9948 return 7;
9949 }
9950 break;
9951 }
9952 case RISCV::AIF_SBG:
9953 case RISCV::AIF_SBL:
9954 case RISCV::AIF_SHG:
9955 case RISCV::AIF_SHL:
9956 case RISCV::HSV_B:
9957 case RISCV::HSV_D:
9958 case RISCV::HSV_H:
9959 case RISCV::HSV_W:
9960 case RISCV::SB_AQRL:
9961 case RISCV::SB_RL:
9962 case RISCV::SD_AQRL:
9963 case RISCV::SD_RL:
9964 case RISCV::SF_VLTE16:
9965 case RISCV::SF_VLTE32:
9966 case RISCV::SF_VLTE64:
9967 case RISCV::SF_VLTE8:
9968 case RISCV::SF_VSTE16:
9969 case RISCV::SF_VSTE32:
9970 case RISCV::SF_VSTE64:
9971 case RISCV::SF_VSTE8:
9972 case RISCV::SH_AQRL:
9973 case RISCV::SH_RL:
9974 case RISCV::SW_AQRL:
9975 case RISCV::SW_RL: {
9976 switch (OpNum) {
9977 case 0:
9978 // op: rs2
9979 return 20;
9980 case 1:
9981 // op: rs1
9982 return 15;
9983 }
9984 break;
9985 }
9986 case RISCV::SSPUSH: {
9987 switch (OpNum) {
9988 case 0:
9989 // op: rs2
9990 return 20;
9991 }
9992 break;
9993 }
9994 case RISCV::C_FSD:
9995 case RISCV::C_FSW:
9996 case RISCV::C_SB:
9997 case RISCV::C_SD:
9998 case RISCV::C_SD_RV32:
9999 case RISCV::C_SH:
10000 case RISCV::C_SH_INX:
10001 case RISCV::C_SW:
10002 case RISCV::C_SW_INX:
10003 case RISCV::QK_C_SB:
10004 case RISCV::QK_C_SH: {
10005 switch (OpNum) {
10006 case 0:
10007 // op: rs2
10008 return 2;
10009 case 1:
10010 // op: rs1
10011 return 7;
10012 case 2:
10013 // op: imm
10014 return 5;
10015 }
10016 break;
10017 }
10018 case RISCV::QC_C_SYNC:
10019 case RISCV::QC_C_SYNCR:
10020 case RISCV::QC_C_SYNCWF:
10021 case RISCV::QC_C_SYNCWL: {
10022 switch (OpNum) {
10023 case 0:
10024 // op: slist
10025 return 7;
10026 }
10027 break;
10028 }
10029 case RISCV::Insn16:
10030 case RISCV::Insn32:
10031 case RISCV::Insn48:
10032 case RISCV::Insn64: {
10033 switch (OpNum) {
10034 case 0:
10035 // op: value
10036 return 0;
10037 }
10038 break;
10039 }
10040 case RISCV::VMV_V_I: {
10041 switch (OpNum) {
10042 case 0:
10043 // op: vd
10044 return 7;
10045 case 1:
10046 // op: imm
10047 return 15;
10048 }
10049 break;
10050 }
10051 case RISCV::VFMV_V_F:
10052 case RISCV::VMV_V_X: {
10053 switch (OpNum) {
10054 case 0:
10055 // op: vd
10056 return 7;
10057 case 1:
10058 // op: rs1
10059 return 15;
10060 }
10061 break;
10062 }
10063 case RISCV::VID_V: {
10064 switch (OpNum) {
10065 case 0:
10066 // op: vd
10067 return 7;
10068 case 1:
10069 // op: vm
10070 return 25;
10071 }
10072 break;
10073 }
10074 case RISCV::VMV_V_V: {
10075 switch (OpNum) {
10076 case 0:
10077 // op: vd
10078 return 7;
10079 case 1:
10080 // op: vs1
10081 return 15;
10082 }
10083 break;
10084 }
10085 case RISCV::VADC_VIM:
10086 case RISCV::VAESKF1_VI:
10087 case RISCV::VMADC_VI:
10088 case RISCV::VMADC_VIM:
10089 case RISCV::VMERGE_VIM:
10090 case RISCV::VSM4K_VI: {
10091 switch (OpNum) {
10092 case 0:
10093 // op: vd
10094 return 7;
10095 case 1:
10096 // op: vs2
10097 return 20;
10098 case 2:
10099 // op: imm
10100 return 15;
10101 }
10102 break;
10103 }
10104 case RISCV::VADC_VXM:
10105 case RISCV::VFMERGE_VFM:
10106 case RISCV::VMADC_VX:
10107 case RISCV::VMADC_VXM:
10108 case RISCV::VMERGE_VXM:
10109 case RISCV::VMSBC_VX:
10110 case RISCV::VMSBC_VXM:
10111 case RISCV::VSBC_VXM: {
10112 switch (OpNum) {
10113 case 0:
10114 // op: vd
10115 return 7;
10116 case 1:
10117 // op: vs2
10118 return 20;
10119 case 2:
10120 // op: rs1
10121 return 15;
10122 }
10123 break;
10124 }
10125 case RISCV::VADC_VVM:
10126 case RISCV::VCOMPRESS_VM:
10127 case RISCV::VMADC_VV:
10128 case RISCV::VMADC_VVM:
10129 case RISCV::VMANDN_MM:
10130 case RISCV::VMAND_MM:
10131 case RISCV::VMERGE_VVM:
10132 case RISCV::VMNAND_MM:
10133 case RISCV::VMNOR_MM:
10134 case RISCV::VMORN_MM:
10135 case RISCV::VMOR_MM:
10136 case RISCV::VMSBC_VV:
10137 case RISCV::VMSBC_VVM:
10138 case RISCV::VMXNOR_MM:
10139 case RISCV::VMXOR_MM:
10140 case RISCV::VSBC_VVM:
10141 case RISCV::VSM3ME_VV: {
10142 switch (OpNum) {
10143 case 0:
10144 // op: vd
10145 return 7;
10146 case 1:
10147 // op: vs2
10148 return 20;
10149 case 2:
10150 // op: vs1
10151 return 15;
10152 }
10153 break;
10154 }
10155 case RISCV::VMV1R_V:
10156 case RISCV::VMV2R_V:
10157 case RISCV::VMV4R_V:
10158 case RISCV::VMV8R_V: {
10159 switch (OpNum) {
10160 case 0:
10161 // op: vd
10162 return 7;
10163 case 1:
10164 // op: vs2
10165 return 20;
10166 }
10167 break;
10168 }
10169 case RISCV::SF_VFEXPA_V:
10170 case RISCV::SF_VFEXP_V:
10171 case RISCV::VBREV8_V:
10172 case RISCV::VBREV_V:
10173 case RISCV::VCLZ_V:
10174 case RISCV::VCPOP_V:
10175 case RISCV::VCTZ_V:
10176 case RISCV::VFCLASS_V:
10177 case RISCV::VFCVT_F_XU_V:
10178 case RISCV::VFCVT_F_X_V:
10179 case RISCV::VFCVT_RTZ_XU_F_V:
10180 case RISCV::VFCVT_RTZ_X_F_V:
10181 case RISCV::VFCVT_XU_F_V:
10182 case RISCV::VFCVT_X_F_V:
10183 case RISCV::VFNCVTBF16_F_F_W:
10184 case RISCV::VFNCVTBF16_SAT_F_F_W:
10185 case RISCV::VFNCVT_F_F_Q:
10186 case RISCV::VFNCVT_F_F_W:
10187 case RISCV::VFNCVT_F_XU_W:
10188 case RISCV::VFNCVT_F_X_W:
10189 case RISCV::VFNCVT_ROD_F_F_W:
10190 case RISCV::VFNCVT_RTZ_XU_F_W:
10191 case RISCV::VFNCVT_RTZ_X_F_W:
10192 case RISCV::VFNCVT_SAT_F_F_Q:
10193 case RISCV::VFNCVT_XU_F_W:
10194 case RISCV::VFNCVT_X_F_W:
10195 case RISCV::VFREC7_V:
10196 case RISCV::VFRSQRT7_V:
10197 case RISCV::VFSQRT_V:
10198 case RISCV::VFWCVTBF16_F_F_V:
10199 case RISCV::VFWCVT_F_F_V:
10200 case RISCV::VFWCVT_F_XU_V:
10201 case RISCV::VFWCVT_F_X_V:
10202 case RISCV::VFWCVT_RTZ_XU_F_V:
10203 case RISCV::VFWCVT_RTZ_X_F_V:
10204 case RISCV::VFWCVT_XU_F_V:
10205 case RISCV::VFWCVT_X_F_V:
10206 case RISCV::VIOTA_M:
10207 case RISCV::VMSBF_M:
10208 case RISCV::VMSIF_M:
10209 case RISCV::VMSOF_M:
10210 case RISCV::VREV8_V:
10211 case RISCV::VSEXT_VF2:
10212 case RISCV::VSEXT_VF4:
10213 case RISCV::VSEXT_VF8:
10214 case RISCV::VZEXT_VF2:
10215 case RISCV::VZEXT_VF4:
10216 case RISCV::VZEXT_VF8: {
10217 switch (OpNum) {
10218 case 0:
10219 // op: vd
10220 return 7;
10221 case 2:
10222 // op: vm
10223 return 25;
10224 case 1:
10225 // op: vs2
10226 return 20;
10227 }
10228 break;
10229 }
10230 case RISCV::VADD_VI:
10231 case RISCV::VAND_VI:
10232 case RISCV::VMSEQ_VI:
10233 case RISCV::VMSGTU_VI:
10234 case RISCV::VMSGT_VI:
10235 case RISCV::VMSLEU_VI:
10236 case RISCV::VMSLE_VI:
10237 case RISCV::VMSNE_VI:
10238 case RISCV::VNCLIPU_WI:
10239 case RISCV::VNCLIP_WI:
10240 case RISCV::VNSRA_WI:
10241 case RISCV::VNSRL_WI:
10242 case RISCV::VOR_VI:
10243 case RISCV::VRGATHER_VI:
10244 case RISCV::VROR_VI:
10245 case RISCV::VRSUB_VI:
10246 case RISCV::VSADDU_VI:
10247 case RISCV::VSADD_VI:
10248 case RISCV::VSLIDEDOWN_VI:
10249 case RISCV::VSLIDEUP_VI:
10250 case RISCV::VSLL_VI:
10251 case RISCV::VSRA_VI:
10252 case RISCV::VSRL_VI:
10253 case RISCV::VSSRA_VI:
10254 case RISCV::VSSRL_VI:
10255 case RISCV::VWSLL_VI:
10256 case RISCV::VXOR_VI: {
10257 switch (OpNum) {
10258 case 0:
10259 // op: vd
10260 return 7;
10261 case 3:
10262 // op: vm
10263 return 25;
10264 case 1:
10265 // op: vs2
10266 return 20;
10267 case 2:
10268 // op: imm
10269 return 15;
10270 }
10271 break;
10272 }
10273 case RISCV::SF_VFNRCLIP_XU_F_QF:
10274 case RISCV::SF_VFNRCLIP_X_F_QF:
10275 case RISCV::VAADDU_VX:
10276 case RISCV::VAADD_VX:
10277 case RISCV::VADD_VX:
10278 case RISCV::VANDN_VX:
10279 case RISCV::VAND_VX:
10280 case RISCV::VASUBU_VX:
10281 case RISCV::VASUB_VX:
10282 case RISCV::VCLMULH_VX:
10283 case RISCV::VCLMUL_VX:
10284 case RISCV::VDIVU_VX:
10285 case RISCV::VDIV_VX:
10286 case RISCV::VFADD_VF:
10287 case RISCV::VFDIV_VF:
10288 case RISCV::VFMAX_VF:
10289 case RISCV::VFMIN_VF:
10290 case RISCV::VFMUL_VF:
10291 case RISCV::VFRDIV_VF:
10292 case RISCV::VFRSUB_VF:
10293 case RISCV::VFSGNJN_VF:
10294 case RISCV::VFSGNJX_VF:
10295 case RISCV::VFSGNJ_VF:
10296 case RISCV::VFSLIDE1DOWN_VF:
10297 case RISCV::VFSLIDE1UP_VF:
10298 case RISCV::VFSUB_VF:
10299 case RISCV::VFWADD_VF:
10300 case RISCV::VFWADD_WF:
10301 case RISCV::VFWMUL_VF:
10302 case RISCV::VFWSUB_VF:
10303 case RISCV::VFWSUB_WF:
10304 case RISCV::VMAXU_VX:
10305 case RISCV::VMAX_VX:
10306 case RISCV::VMFEQ_VF:
10307 case RISCV::VMFGE_VF:
10308 case RISCV::VMFGT_VF:
10309 case RISCV::VMFLE_VF:
10310 case RISCV::VMFLT_VF:
10311 case RISCV::VMFNE_VF:
10312 case RISCV::VMINU_VX:
10313 case RISCV::VMIN_VX:
10314 case RISCV::VMSEQ_VX:
10315 case RISCV::VMSGTU_VX:
10316 case RISCV::VMSGT_VX:
10317 case RISCV::VMSLEU_VX:
10318 case RISCV::VMSLE_VX:
10319 case RISCV::VMSLTU_VX:
10320 case RISCV::VMSLT_VX:
10321 case RISCV::VMSNE_VX:
10322 case RISCV::VMULHSU_VX:
10323 case RISCV::VMULHU_VX:
10324 case RISCV::VMULH_VX:
10325 case RISCV::VMUL_VX:
10326 case RISCV::VNCLIPU_WX:
10327 case RISCV::VNCLIP_WX:
10328 case RISCV::VNSRA_WX:
10329 case RISCV::VNSRL_WX:
10330 case RISCV::VOR_VX:
10331 case RISCV::VREMU_VX:
10332 case RISCV::VREM_VX:
10333 case RISCV::VRGATHER_VX:
10334 case RISCV::VROL_VX:
10335 case RISCV::VROR_VX:
10336 case RISCV::VRSUB_VX:
10337 case RISCV::VSADDU_VX:
10338 case RISCV::VSADD_VX:
10339 case RISCV::VSLIDE1DOWN_VX:
10340 case RISCV::VSLIDE1UP_VX:
10341 case RISCV::VSLIDEDOWN_VX:
10342 case RISCV::VSLIDEUP_VX:
10343 case RISCV::VSLL_VX:
10344 case RISCV::VSMUL_VX:
10345 case RISCV::VSRA_VX:
10346 case RISCV::VSRL_VX:
10347 case RISCV::VSSRA_VX:
10348 case RISCV::VSSRL_VX:
10349 case RISCV::VSSUBU_VX:
10350 case RISCV::VSSUB_VX:
10351 case RISCV::VSUB_VX:
10352 case RISCV::VWADDU_VX:
10353 case RISCV::VWADDU_WX:
10354 case RISCV::VWADD_VX:
10355 case RISCV::VWADD_WX:
10356 case RISCV::VWMULSU_VX:
10357 case RISCV::VWMULU_VX:
10358 case RISCV::VWMUL_VX:
10359 case RISCV::VWSLL_VX:
10360 case RISCV::VWSUBU_VX:
10361 case RISCV::VWSUBU_WX:
10362 case RISCV::VWSUB_VX:
10363 case RISCV::VWSUB_WX:
10364 case RISCV::VXOR_VX: {
10365 switch (OpNum) {
10366 case 0:
10367 // op: vd
10368 return 7;
10369 case 3:
10370 // op: vm
10371 return 25;
10372 case 1:
10373 // op: vs2
10374 return 20;
10375 case 2:
10376 // op: rs1
10377 return 15;
10378 }
10379 break;
10380 }
10381 case RISCV::RI_VUNZIP2A_VV:
10382 case RISCV::RI_VUNZIP2B_VV:
10383 case RISCV::RI_VZIP2A_VV:
10384 case RISCV::RI_VZIP2B_VV:
10385 case RISCV::RI_VZIPEVEN_VV:
10386 case RISCV::RI_VZIPODD_VV:
10387 case RISCV::VAADDU_VV:
10388 case RISCV::VAADD_VV:
10389 case RISCV::VADD_VV:
10390 case RISCV::VANDN_VV:
10391 case RISCV::VAND_VV:
10392 case RISCV::VASUBU_VV:
10393 case RISCV::VASUB_VV:
10394 case RISCV::VCLMULH_VV:
10395 case RISCV::VCLMUL_VV:
10396 case RISCV::VDIVU_VV:
10397 case RISCV::VDIV_VV:
10398 case RISCV::VFADD_VV:
10399 case RISCV::VFDIV_VV:
10400 case RISCV::VFMAX_VV:
10401 case RISCV::VFMIN_VV:
10402 case RISCV::VFMUL_VV:
10403 case RISCV::VFREDMAX_VS:
10404 case RISCV::VFREDMIN_VS:
10405 case RISCV::VFREDOSUM_VS:
10406 case RISCV::VFREDUSUM_VS:
10407 case RISCV::VFSGNJN_VV:
10408 case RISCV::VFSGNJX_VV:
10409 case RISCV::VFSGNJ_VV:
10410 case RISCV::VFSUB_VV:
10411 case RISCV::VFWADD_VV:
10412 case RISCV::VFWADD_WV:
10413 case RISCV::VFWMUL_VV:
10414 case RISCV::VFWREDOSUM_VS:
10415 case RISCV::VFWREDUSUM_VS:
10416 case RISCV::VFWSUB_VV:
10417 case RISCV::VFWSUB_WV:
10418 case RISCV::VMAXU_VV:
10419 case RISCV::VMAX_VV:
10420 case RISCV::VMFEQ_VV:
10421 case RISCV::VMFLE_VV:
10422 case RISCV::VMFLT_VV:
10423 case RISCV::VMFNE_VV:
10424 case RISCV::VMINU_VV:
10425 case RISCV::VMIN_VV:
10426 case RISCV::VMSEQ_VV:
10427 case RISCV::VMSLEU_VV:
10428 case RISCV::VMSLE_VV:
10429 case RISCV::VMSLTU_VV:
10430 case RISCV::VMSLT_VV:
10431 case RISCV::VMSNE_VV:
10432 case RISCV::VMULHSU_VV:
10433 case RISCV::VMULHU_VV:
10434 case RISCV::VMULH_VV:
10435 case RISCV::VMUL_VV:
10436 case RISCV::VNCLIPU_WV:
10437 case RISCV::VNCLIP_WV:
10438 case RISCV::VNSRA_WV:
10439 case RISCV::VNSRL_WV:
10440 case RISCV::VOR_VV:
10441 case RISCV::VREDAND_VS:
10442 case RISCV::VREDMAXU_VS:
10443 case RISCV::VREDMAX_VS:
10444 case RISCV::VREDMINU_VS:
10445 case RISCV::VREDMIN_VS:
10446 case RISCV::VREDOR_VS:
10447 case RISCV::VREDSUM_VS:
10448 case RISCV::VREDXOR_VS:
10449 case RISCV::VREMU_VV:
10450 case RISCV::VREM_VV:
10451 case RISCV::VRGATHEREI16_VV:
10452 case RISCV::VRGATHER_VV:
10453 case RISCV::VROL_VV:
10454 case RISCV::VROR_VV:
10455 case RISCV::VSADDU_VV:
10456 case RISCV::VSADD_VV:
10457 case RISCV::VSLL_VV:
10458 case RISCV::VSMUL_VV:
10459 case RISCV::VSRA_VV:
10460 case RISCV::VSRL_VV:
10461 case RISCV::VSSRA_VV:
10462 case RISCV::VSSRL_VV:
10463 case RISCV::VSSUBU_VV:
10464 case RISCV::VSSUB_VV:
10465 case RISCV::VSUB_VV:
10466 case RISCV::VWADDU_VV:
10467 case RISCV::VWADDU_WV:
10468 case RISCV::VWADD_VV:
10469 case RISCV::VWADD_WV:
10470 case RISCV::VWMULSU_VV:
10471 case RISCV::VWMULU_VV:
10472 case RISCV::VWMUL_VV:
10473 case RISCV::VWREDSUMU_VS:
10474 case RISCV::VWREDSUM_VS:
10475 case RISCV::VWSLL_VV:
10476 case RISCV::VWSUBU_VV:
10477 case RISCV::VWSUBU_WV:
10478 case RISCV::VWSUB_VV:
10479 case RISCV::VWSUB_WV:
10480 case RISCV::VXOR_VV: {
10481 switch (OpNum) {
10482 case 0:
10483 // op: vd
10484 return 7;
10485 case 3:
10486 // op: vm
10487 return 25;
10488 case 1:
10489 // op: vs2
10490 return 20;
10491 case 2:
10492 // op: vs1
10493 return 15;
10494 }
10495 break;
10496 }
10497 case RISCV::RI_VZERO: {
10498 switch (OpNum) {
10499 case 0:
10500 // op: vd
10501 return 7;
10502 }
10503 break;
10504 }
10505 case RISCV::SMT_VMADOT:
10506 case RISCV::SMT_VMADOTSU:
10507 case RISCV::SMT_VMADOTU:
10508 case RISCV::SMT_VMADOTUS: {
10509 switch (OpNum) {
10510 case 0:
10511 // op: vd
10512 return 8;
10513 case 1:
10514 // op: vs1
10515 return 15;
10516 case 2:
10517 // op: vs2
10518 return 20;
10519 }
10520 break;
10521 }
10522 case RISCV::SMT_VMADOT1:
10523 case RISCV::SMT_VMADOT1SU:
10524 case RISCV::SMT_VMADOT1U:
10525 case RISCV::SMT_VMADOT1US:
10526 case RISCV::SMT_VMADOT2:
10527 case RISCV::SMT_VMADOT2SU:
10528 case RISCV::SMT_VMADOT2U:
10529 case RISCV::SMT_VMADOT2US:
10530 case RISCV::SMT_VMADOT3:
10531 case RISCV::SMT_VMADOT3SU:
10532 case RISCV::SMT_VMADOT3U:
10533 case RISCV::SMT_VMADOT3US: {
10534 switch (OpNum) {
10535 case 0:
10536 // op: vd
10537 return 8;
10538 case 1:
10539 // op: vs1
10540 return 16;
10541 case 2:
10542 // op: vs2
10543 return 20;
10544 }
10545 break;
10546 }
10547 case RISCV::C_LI:
10548 case RISCV::C_LUI: {
10549 switch (OpNum) {
10550 case 1:
10551 // op: imm
10552 return 2;
10553 case 0:
10554 // op: rd
10555 return 7;
10556 }
10557 break;
10558 }
10559 case RISCV::C_BEQZ:
10560 case RISCV::C_BNEZ: {
10561 switch (OpNum) {
10562 case 1:
10563 // op: imm
10564 return 2;
10565 case 0:
10566 // op: rs1
10567 return 7;
10568 }
10569 break;
10570 }
10571 case RISCV::PREFETCH_I:
10572 case RISCV::PREFETCH_R:
10573 case RISCV::PREFETCH_W: {
10574 switch (OpNum) {
10575 case 1:
10576 // op: imm12
10577 return 25;
10578 case 0:
10579 // op: rs1
10580 return 15;
10581 }
10582 break;
10583 }
10584 case RISCV::AIF_FSQ2:
10585 case RISCV::AIF_FSW_PS: {
10586 switch (OpNum) {
10587 case 1:
10588 // op: imm12
10589 return 7;
10590 case 0:
10591 // op: rs2
10592 return 20;
10593 case 2:
10594 // op: rs1
10595 return 15;
10596 }
10597 break;
10598 }
10599 case RISCV::NDS_LDGP:
10600 case RISCV::NDS_LHGP:
10601 case RISCV::NDS_LHUGP:
10602 case RISCV::NDS_LWGP:
10603 case RISCV::NDS_LWUGP: {
10604 switch (OpNum) {
10605 case 1:
10606 // op: imm17
10607 return 15;
10608 case 0:
10609 // op: rd
10610 return 7;
10611 }
10612 break;
10613 }
10614 case RISCV::NDS_SDGP:
10615 case RISCV::NDS_SHGP:
10616 case RISCV::NDS_SWGP: {
10617 switch (OpNum) {
10618 case 1:
10619 // op: imm17
10620 return 7;
10621 case 0:
10622 // op: rs2
10623 return 20;
10624 }
10625 break;
10626 }
10627 case RISCV::NDS_ADDIGP:
10628 case RISCV::NDS_LBGP:
10629 case RISCV::NDS_LBUGP: {
10630 switch (OpNum) {
10631 case 1:
10632 // op: imm18
10633 return 14;
10634 case 0:
10635 // op: rd
10636 return 7;
10637 }
10638 break;
10639 }
10640 case RISCV::NDS_SBGP: {
10641 switch (OpNum) {
10642 case 1:
10643 // op: imm18
10644 return 7;
10645 case 0:
10646 // op: rs2
10647 return 20;
10648 }
10649 break;
10650 }
10651 case RISCV::AIF_FBCI_PI:
10652 case RISCV::AIF_FBCI_PS:
10653 case RISCV::AUIPC:
10654 case RISCV::JAL:
10655 case RISCV::LUI:
10656 case RISCV::QC_LI: {
10657 switch (OpNum) {
10658 case 1:
10659 // op: imm20
10660 return 12;
10661 case 0:
10662 // op: rd
10663 return 7;
10664 }
10665 break;
10666 }
10667 case RISCV::MIPS_PREF: {
10668 switch (OpNum) {
10669 case 1:
10670 // op: imm9
10671 return 20;
10672 case 0:
10673 // op: rs1
10674 return 15;
10675 case 2:
10676 // op: hint
10677 return 7;
10678 }
10679 break;
10680 }
10681 case RISCV::InsnQC_EAI: {
10682 switch (OpNum) {
10683 case 1:
10684 // op: opcode
10685 return 0;
10686 case 2:
10687 // op: func3
10688 return 12;
10689 case 3:
10690 // op: func1
10691 return 15;
10692 case 0:
10693 // op: rd
10694 return 7;
10695 case 4:
10696 // op: imm32
10697 return 16;
10698 }
10699 break;
10700 }
10701 case RISCV::InsnQC_EI:
10702 case RISCV::InsnQC_EI_Mem: {
10703 switch (OpNum) {
10704 case 1:
10705 // op: opcode
10706 return 0;
10707 case 2:
10708 // op: func3
10709 return 12;
10710 case 3:
10711 // op: func2
10712 return 30;
10713 case 0:
10714 // op: rd
10715 return 7;
10716 case 4:
10717 // op: rs1
10718 return 15;
10719 case 5:
10720 // op: imm26
10721 return 20;
10722 }
10723 break;
10724 }
10725 case RISCV::InsnI:
10726 case RISCV::InsnI_Mem: {
10727 switch (OpNum) {
10728 case 1:
10729 // op: opcode
10730 return 0;
10731 case 2:
10732 // op: funct3
10733 return 12;
10734 case 4:
10735 // op: imm12
10736 return 20;
10737 case 3:
10738 // op: rs1
10739 return 15;
10740 case 0:
10741 // op: rd
10742 return 7;
10743 }
10744 break;
10745 }
10746 case RISCV::InsnCI: {
10747 switch (OpNum) {
10748 case 1:
10749 // op: opcode
10750 return 0;
10751 case 2:
10752 // op: funct3
10753 return 13;
10754 case 3:
10755 // op: imm6
10756 return 2;
10757 case 0:
10758 // op: rd
10759 return 7;
10760 }
10761 break;
10762 }
10763 case RISCV::InsnCIW: {
10764 switch (OpNum) {
10765 case 1:
10766 // op: opcode
10767 return 0;
10768 case 2:
10769 // op: funct3
10770 return 13;
10771 case 3:
10772 // op: imm8
10773 return 5;
10774 case 0:
10775 // op: rd
10776 return 2;
10777 }
10778 break;
10779 }
10780 case RISCV::InsnCL: {
10781 switch (OpNum) {
10782 case 1:
10783 // op: opcode
10784 return 0;
10785 case 2:
10786 // op: funct3
10787 return 13;
10788 case 4:
10789 // op: imm5
10790 return 5;
10791 case 0:
10792 // op: rd
10793 return 2;
10794 case 3:
10795 // op: rs1
10796 return 7;
10797 }
10798 break;
10799 }
10800 case RISCV::InsnCR: {
10801 switch (OpNum) {
10802 case 1:
10803 // op: opcode
10804 return 0;
10805 case 2:
10806 // op: funct4
10807 return 12;
10808 case 3:
10809 // op: rs2
10810 return 2;
10811 case 0:
10812 // op: rd
10813 return 7;
10814 }
10815 break;
10816 }
10817 case RISCV::InsnCA: {
10818 switch (OpNum) {
10819 case 1:
10820 // op: opcode
10821 return 0;
10822 case 2:
10823 // op: funct6
10824 return 10;
10825 case 3:
10826 // op: funct2
10827 return 5;
10828 case 0:
10829 // op: rd
10830 return 7;
10831 case 4:
10832 // op: rs2
10833 return 2;
10834 }
10835 break;
10836 }
10837 case RISCV::InsnJ:
10838 case RISCV::InsnU: {
10839 switch (OpNum) {
10840 case 1:
10841 // op: opcode
10842 return 0;
10843 case 2:
10844 // op: imm20
10845 return 12;
10846 case 0:
10847 // op: rd
10848 return 7;
10849 }
10850 break;
10851 }
10852 case RISCV::InsnR4: {
10853 switch (OpNum) {
10854 case 1:
10855 // op: opcode
10856 return 0;
10857 case 3:
10858 // op: funct2
10859 return 25;
10860 case 2:
10861 // op: funct3
10862 return 12;
10863 case 6:
10864 // op: rs3
10865 return 27;
10866 case 5:
10867 // op: rs2
10868 return 20;
10869 case 4:
10870 // op: rs1
10871 return 15;
10872 case 0:
10873 // op: rd
10874 return 7;
10875 }
10876 break;
10877 }
10878 case RISCV::InsnR: {
10879 switch (OpNum) {
10880 case 1:
10881 // op: opcode
10882 return 0;
10883 case 3:
10884 // op: funct7
10885 return 25;
10886 case 2:
10887 // op: funct3
10888 return 12;
10889 case 5:
10890 // op: rs2
10891 return 20;
10892 case 4:
10893 // op: rs1
10894 return 15;
10895 case 0:
10896 // op: rd
10897 return 7;
10898 }
10899 break;
10900 }
10901 case RISCV::QC_C_MULIADD: {
10902 switch (OpNum) {
10903 case 1:
10904 // op: rd
10905 return 2;
10906 case 2:
10907 // op: rs1
10908 return 7;
10909 case 3:
10910 // op: uimm
10911 return 5;
10912 }
10913 break;
10914 }
10915 case RISCV::QC_C_MVEQZ: {
10916 switch (OpNum) {
10917 case 1:
10918 // op: rd
10919 return 2;
10920 case 2:
10921 // op: rs1
10922 return 7;
10923 }
10924 break;
10925 }
10926 case RISCV::QC_E_ADDAI:
10927 case RISCV::QC_E_ANDAI:
10928 case RISCV::QC_E_ORAI:
10929 case RISCV::QC_E_XORAI: {
10930 switch (OpNum) {
10931 case 1:
10932 // op: rd
10933 return 7;
10934 case 2:
10935 // op: imm
10936 return 16;
10937 }
10938 break;
10939 }
10940 case RISCV::QC_INSBI: {
10941 switch (OpNum) {
10942 case 1:
10943 // op: rd
10944 return 7;
10945 case 2:
10946 // op: imm5
10947 return 15;
10948 case 4:
10949 // op: shamt
10950 return 20;
10951 case 3:
10952 // op: width
10953 return 25;
10954 }
10955 break;
10956 }
10957 case RISCV::QC_C_EXTU: {
10958 switch (OpNum) {
10959 case 1:
10960 // op: rd
10961 return 7;
10962 case 2:
10963 // op: width
10964 return 2;
10965 }
10966 break;
10967 }
10968 case RISCV::C_NOT:
10969 case RISCV::C_SEXT_B:
10970 case RISCV::C_SEXT_H:
10971 case RISCV::C_ZEXT_B:
10972 case RISCV::C_ZEXT_H:
10973 case RISCV::C_ZEXT_W: {
10974 switch (OpNum) {
10975 case 1:
10976 // op: rd
10977 return 7;
10978 }
10979 break;
10980 }
10981 case RISCV::QC_WRAPI: {
10982 switch (OpNum) {
10983 case 1:
10984 // op: rs1
10985 return 15;
10986 case 0:
10987 // op: rd
10988 return 7;
10989 case 2:
10990 // op: imm11
10991 return 20;
10992 }
10993 break;
10994 }
10995 case RISCV::ADDI:
10996 case RISCV::ADDIW:
10997 case RISCV::ANDI:
10998 case RISCV::CV_ELW:
10999 case RISCV::FLD:
11000 case RISCV::FLH:
11001 case RISCV::FLQ:
11002 case RISCV::FLW:
11003 case RISCV::JALR:
11004 case RISCV::LB:
11005 case RISCV::LBU:
11006 case RISCV::LD:
11007 case RISCV::LD_RV32:
11008 case RISCV::LH:
11009 case RISCV::LHU:
11010 case RISCV::LH_INX:
11011 case RISCV::LW:
11012 case RISCV::LWU:
11013 case RISCV::LW_INX:
11014 case RISCV::ORI:
11015 case RISCV::SLTI:
11016 case RISCV::SLTIU:
11017 case RISCV::XORI: {
11018 switch (OpNum) {
11019 case 1:
11020 // op: rs1
11021 return 15;
11022 case 0:
11023 // op: rd
11024 return 7;
11025 case 2:
11026 // op: imm12
11027 return 20;
11028 }
11029 break;
11030 }
11031 case RISCV::QC_INW: {
11032 switch (OpNum) {
11033 case 1:
11034 // op: rs1
11035 return 15;
11036 case 0:
11037 // op: rd
11038 return 7;
11039 case 2:
11040 // op: imm14
11041 return 20;
11042 }
11043 break;
11044 }
11045 case RISCV::CV_CLIP:
11046 case RISCV::CV_CLIPU: {
11047 switch (OpNum) {
11048 case 1:
11049 // op: rs1
11050 return 15;
11051 case 0:
11052 // op: rd
11053 return 7;
11054 case 2:
11055 // op: imm5
11056 return 20;
11057 }
11058 break;
11059 }
11060 case RISCV::CV_ADD_SCI_B:
11061 case RISCV::CV_ADD_SCI_H:
11062 case RISCV::CV_AND_SCI_B:
11063 case RISCV::CV_AND_SCI_H:
11064 case RISCV::CV_AVGU_SCI_B:
11065 case RISCV::CV_AVGU_SCI_H:
11066 case RISCV::CV_AVG_SCI_B:
11067 case RISCV::CV_AVG_SCI_H:
11068 case RISCV::CV_CMPEQ_SCI_B:
11069 case RISCV::CV_CMPEQ_SCI_H:
11070 case RISCV::CV_CMPGEU_SCI_B:
11071 case RISCV::CV_CMPGEU_SCI_H:
11072 case RISCV::CV_CMPGE_SCI_B:
11073 case RISCV::CV_CMPGE_SCI_H:
11074 case RISCV::CV_CMPGTU_SCI_B:
11075 case RISCV::CV_CMPGTU_SCI_H:
11076 case RISCV::CV_CMPGT_SCI_B:
11077 case RISCV::CV_CMPGT_SCI_H:
11078 case RISCV::CV_CMPLEU_SCI_B:
11079 case RISCV::CV_CMPLEU_SCI_H:
11080 case RISCV::CV_CMPLE_SCI_B:
11081 case RISCV::CV_CMPLE_SCI_H:
11082 case RISCV::CV_CMPLTU_SCI_B:
11083 case RISCV::CV_CMPLTU_SCI_H:
11084 case RISCV::CV_CMPLT_SCI_B:
11085 case RISCV::CV_CMPLT_SCI_H:
11086 case RISCV::CV_CMPNE_SCI_B:
11087 case RISCV::CV_CMPNE_SCI_H:
11088 case RISCV::CV_DOTSP_SCI_B:
11089 case RISCV::CV_DOTSP_SCI_H:
11090 case RISCV::CV_DOTUP_SCI_B:
11091 case RISCV::CV_DOTUP_SCI_H:
11092 case RISCV::CV_DOTUSP_SCI_B:
11093 case RISCV::CV_DOTUSP_SCI_H:
11094 case RISCV::CV_EXTRACTU_B:
11095 case RISCV::CV_EXTRACTU_H:
11096 case RISCV::CV_EXTRACT_B:
11097 case RISCV::CV_EXTRACT_H:
11098 case RISCV::CV_MAXU_SCI_B:
11099 case RISCV::CV_MAXU_SCI_H:
11100 case RISCV::CV_MAX_SCI_B:
11101 case RISCV::CV_MAX_SCI_H:
11102 case RISCV::CV_MINU_SCI_B:
11103 case RISCV::CV_MINU_SCI_H:
11104 case RISCV::CV_MIN_SCI_B:
11105 case RISCV::CV_MIN_SCI_H:
11106 case RISCV::CV_OR_SCI_B:
11107 case RISCV::CV_OR_SCI_H:
11108 case RISCV::CV_SHUFFLEI0_SCI_B:
11109 case RISCV::CV_SHUFFLEI1_SCI_B:
11110 case RISCV::CV_SHUFFLEI2_SCI_B:
11111 case RISCV::CV_SHUFFLEI3_SCI_B:
11112 case RISCV::CV_SHUFFLE_SCI_H:
11113 case RISCV::CV_SLL_SCI_B:
11114 case RISCV::CV_SLL_SCI_H:
11115 case RISCV::CV_SRA_SCI_B:
11116 case RISCV::CV_SRA_SCI_H:
11117 case RISCV::CV_SRL_SCI_B:
11118 case RISCV::CV_SRL_SCI_H:
11119 case RISCV::CV_SUB_SCI_B:
11120 case RISCV::CV_SUB_SCI_H:
11121 case RISCV::CV_XOR_SCI_B:
11122 case RISCV::CV_XOR_SCI_H: {
11123 switch (OpNum) {
11124 case 1:
11125 // op: rs1
11126 return 15;
11127 case 0:
11128 // op: rd
11129 return 7;
11130 case 2:
11131 // op: imm6
11132 return 20;
11133 }
11134 break;
11135 }
11136 case RISCV::CV_BCLR:
11137 case RISCV::CV_BITREV:
11138 case RISCV::CV_BSET:
11139 case RISCV::CV_EXTRACT:
11140 case RISCV::CV_EXTRACTU: {
11141 switch (OpNum) {
11142 case 1:
11143 // op: rs1
11144 return 15;
11145 case 0:
11146 // op: rd
11147 return 7;
11148 case 2:
11149 // op: is3
11150 return 25;
11151 case 3:
11152 // op: is2
11153 return 20;
11154 }
11155 break;
11156 }
11157 case RISCV::TH_EXT:
11158 case RISCV::TH_EXTU: {
11159 switch (OpNum) {
11160 case 1:
11161 // op: rs1
11162 return 15;
11163 case 0:
11164 // op: rd
11165 return 7;
11166 case 2:
11167 // op: msb
11168 return 26;
11169 case 3:
11170 // op: lsb
11171 return 20;
11172 }
11173 break;
11174 }
11175 case RISCV::AES64KS1I: {
11176 switch (OpNum) {
11177 case 1:
11178 // op: rs1
11179 return 15;
11180 case 0:
11181 // op: rd
11182 return 7;
11183 case 2:
11184 // op: rnum
11185 return 20;
11186 }
11187 break;
11188 }
11189 case RISCV::BCLRI:
11190 case RISCV::BEXTI:
11191 case RISCV::BINVI:
11192 case RISCV::BSETI:
11193 case RISCV::PSATI_H:
11194 case RISCV::PSATI_W:
11195 case RISCV::PSLLI_B:
11196 case RISCV::PSLLI_H:
11197 case RISCV::PSLLI_W:
11198 case RISCV::PSRAI_B:
11199 case RISCV::PSRAI_H:
11200 case RISCV::PSRAI_W:
11201 case RISCV::PSRARI_H:
11202 case RISCV::PSRARI_W:
11203 case RISCV::PSRLI_B:
11204 case RISCV::PSRLI_H:
11205 case RISCV::PSRLI_W:
11206 case RISCV::PSSLAI_H:
11207 case RISCV::PSSLAI_W:
11208 case RISCV::PUSATI_H:
11209 case RISCV::PUSATI_W:
11210 case RISCV::RORI:
11211 case RISCV::RORIW:
11212 case RISCV::SATI_RV32:
11213 case RISCV::SATI_RV64:
11214 case RISCV::SLLI:
11215 case RISCV::SLLIW:
11216 case RISCV::SLLI_UW:
11217 case RISCV::SRAI:
11218 case RISCV::SRAIW:
11219 case RISCV::SRARI_RV32:
11220 case RISCV::SRARI_RV64:
11221 case RISCV::SRLI:
11222 case RISCV::SRLIW:
11223 case RISCV::SSLAI:
11224 case RISCV::TH_SRRI:
11225 case RISCV::TH_SRRIW:
11226 case RISCV::TH_TST:
11227 case RISCV::USATI_RV32:
11228 case RISCV::USATI_RV64: {
11229 switch (OpNum) {
11230 case 1:
11231 // op: rs1
11232 return 15;
11233 case 0:
11234 // op: rd
11235 return 7;
11236 case 2:
11237 // op: shamt
11238 return 20;
11239 }
11240 break;
11241 }
11242 case RISCV::VSETVLI: {
11243 switch (OpNum) {
11244 case 1:
11245 // op: rs1
11246 return 15;
11247 case 0:
11248 // op: rd
11249 return 7;
11250 case 2:
11251 // op: vtypei
11252 return 20;
11253 }
11254 break;
11255 }
11256 case RISCV::QC_EXT:
11257 case RISCV::QC_EXTD:
11258 case RISCV::QC_EXTDU:
11259 case RISCV::QC_EXTU: {
11260 switch (OpNum) {
11261 case 1:
11262 // op: rs1
11263 return 15;
11264 case 0:
11265 // op: rd
11266 return 7;
11267 case 3:
11268 // op: shamt
11269 return 20;
11270 case 2:
11271 // op: width
11272 return 25;
11273 }
11274 break;
11275 }
11276 case RISCV::ABS:
11277 case RISCV::ABSW:
11278 case RISCV::AES64IM:
11279 case RISCV::AIF_FBCX_PS:
11280 case RISCV::AIF_FCLASS_PS:
11281 case RISCV::AIF_FCVT_F10_PS:
11282 case RISCV::AIF_FCVT_F11_PS:
11283 case RISCV::AIF_FCVT_F16_PS:
11284 case RISCV::AIF_FCVT_PS_F10:
11285 case RISCV::AIF_FCVT_PS_F11:
11286 case RISCV::AIF_FCVT_PS_F16:
11287 case RISCV::AIF_FCVT_PS_RAST:
11288 case RISCV::AIF_FCVT_PS_SN16:
11289 case RISCV::AIF_FCVT_PS_SN8:
11290 case RISCV::AIF_FCVT_PS_UN10:
11291 case RISCV::AIF_FCVT_PS_UN16:
11292 case RISCV::AIF_FCVT_PS_UN2:
11293 case RISCV::AIF_FCVT_PS_UN24:
11294 case RISCV::AIF_FCVT_PS_UN8:
11295 case RISCV::AIF_FCVT_RAST_PS:
11296 case RISCV::AIF_FCVT_SN16_PS:
11297 case RISCV::AIF_FCVT_SN8_PS:
11298 case RISCV::AIF_FCVT_UN10_PS:
11299 case RISCV::AIF_FCVT_UN16_PS:
11300 case RISCV::AIF_FCVT_UN24_PS:
11301 case RISCV::AIF_FCVT_UN2_PS:
11302 case RISCV::AIF_FCVT_UN8_PS:
11303 case RISCV::AIF_FEXP_PS:
11304 case RISCV::AIF_FFRC_PS:
11305 case RISCV::AIF_FLOG_PS:
11306 case RISCV::AIF_FLWG_PS:
11307 case RISCV::AIF_FLWL_PS:
11308 case RISCV::AIF_FNOT_PI:
11309 case RISCV::AIF_FPACKREPB_PI:
11310 case RISCV::AIF_FPACKREPH_PI:
11311 case RISCV::AIF_FRCP_PS:
11312 case RISCV::AIF_FRSQ_PS:
11313 case RISCV::AIF_FSAT8_PI:
11314 case RISCV::AIF_FSATU8_PI:
11315 case RISCV::AIF_FSETM_PI:
11316 case RISCV::AIF_FSIN_PS:
11317 case RISCV::AIF_FSQRT_PS:
11318 case RISCV::AIF_MASKNOT:
11319 case RISCV::AIF_MASKPOPC:
11320 case RISCV::AIF_MASKPOPCZ:
11321 case RISCV::BREV8:
11322 case RISCV::CLS:
11323 case RISCV::CLSW:
11324 case RISCV::CLZ:
11325 case RISCV::CLZW:
11326 case RISCV::CPOP:
11327 case RISCV::CPOPW:
11328 case RISCV::CTZ:
11329 case RISCV::CTZW:
11330 case RISCV::CV_ABS:
11331 case RISCV::CV_ABS_B:
11332 case RISCV::CV_ABS_H:
11333 case RISCV::CV_CLB:
11334 case RISCV::CV_CNT:
11335 case RISCV::CV_CPLXCONJ:
11336 case RISCV::CV_EXTBS:
11337 case RISCV::CV_EXTBZ:
11338 case RISCV::CV_EXTHS:
11339 case RISCV::CV_EXTHZ:
11340 case RISCV::CV_FF1:
11341 case RISCV::CV_FL1:
11342 case RISCV::FCLASS_D:
11343 case RISCV::FCLASS_D_IN32X:
11344 case RISCV::FCLASS_D_INX:
11345 case RISCV::FCLASS_H:
11346 case RISCV::FCLASS_H_INX:
11347 case RISCV::FCLASS_Q:
11348 case RISCV::FCLASS_S:
11349 case RISCV::FCLASS_S_INX:
11350 case RISCV::FCVTMOD_W_D:
11351 case RISCV::FMVH_X_D:
11352 case RISCV::FMVH_X_Q:
11353 case RISCV::FMV_D_X:
11354 case RISCV::FMV_H_X:
11355 case RISCV::FMV_W_X:
11356 case RISCV::FMV_X_D:
11357 case RISCV::FMV_X_H:
11358 case RISCV::FMV_X_W:
11359 case RISCV::FMV_X_W_FPR64:
11360 case RISCV::HLVX_HU:
11361 case RISCV::HLVX_WU:
11362 case RISCV::HLV_B:
11363 case RISCV::HLV_BU:
11364 case RISCV::HLV_D:
11365 case RISCV::HLV_H:
11366 case RISCV::HLV_HU:
11367 case RISCV::HLV_W:
11368 case RISCV::HLV_WU:
11369 case RISCV::LB_AQ:
11370 case RISCV::LB_AQRL:
11371 case RISCV::LD_AQ:
11372 case RISCV::LD_AQRL:
11373 case RISCV::LH_AQ:
11374 case RISCV::LH_AQRL:
11375 case RISCV::LR_D:
11376 case RISCV::LR_D_AQ:
11377 case RISCV::LR_D_AQRL:
11378 case RISCV::LR_D_RL:
11379 case RISCV::LR_W:
11380 case RISCV::LR_W_AQ:
11381 case RISCV::LR_W_AQRL:
11382 case RISCV::LR_W_RL:
11383 case RISCV::LW_AQ:
11384 case RISCV::LW_AQRL:
11385 case RISCV::MOP_R_0:
11386 case RISCV::MOP_R_1:
11387 case RISCV::MOP_R_10:
11388 case RISCV::MOP_R_11:
11389 case RISCV::MOP_R_12:
11390 case RISCV::MOP_R_13:
11391 case RISCV::MOP_R_14:
11392 case RISCV::MOP_R_15:
11393 case RISCV::MOP_R_16:
11394 case RISCV::MOP_R_17:
11395 case RISCV::MOP_R_18:
11396 case RISCV::MOP_R_19:
11397 case RISCV::MOP_R_2:
11398 case RISCV::MOP_R_20:
11399 case RISCV::MOP_R_21:
11400 case RISCV::MOP_R_22:
11401 case RISCV::MOP_R_23:
11402 case RISCV::MOP_R_24:
11403 case RISCV::MOP_R_25:
11404 case RISCV::MOP_R_26:
11405 case RISCV::MOP_R_27:
11406 case RISCV::MOP_R_28:
11407 case RISCV::MOP_R_29:
11408 case RISCV::MOP_R_3:
11409 case RISCV::MOP_R_30:
11410 case RISCV::MOP_R_31:
11411 case RISCV::MOP_R_4:
11412 case RISCV::MOP_R_5:
11413 case RISCV::MOP_R_6:
11414 case RISCV::MOP_R_7:
11415 case RISCV::MOP_R_8:
11416 case RISCV::MOP_R_9:
11417 case RISCV::NDS_FMV_BF16_X:
11418 case RISCV::NDS_FMV_X_BF16:
11419 case RISCV::ORC_B:
11420 case RISCV::PSABS_B:
11421 case RISCV::PSABS_H:
11422 case RISCV::PSEXT_H_B:
11423 case RISCV::PSEXT_W_B:
11424 case RISCV::PSEXT_W_H:
11425 case RISCV::QC_BREV32:
11426 case RISCV::QC_CLO:
11427 case RISCV::QC_COMPRESS2:
11428 case RISCV::QC_COMPRESS3:
11429 case RISCV::QC_CTO:
11430 case RISCV::QC_EXPAND2:
11431 case RISCV::QC_EXPAND3:
11432 case RISCV::QC_NORM:
11433 case RISCV::QC_NORMEU:
11434 case RISCV::QC_NORMU:
11435 case RISCV::REV16:
11436 case RISCV::REV8_RV32:
11437 case RISCV::REV8_RV64:
11438 case RISCV::REV_RV32:
11439 case RISCV::REV_RV64:
11440 case RISCV::SEXT_B:
11441 case RISCV::SEXT_H:
11442 case RISCV::SF_VSETTK:
11443 case RISCV::SF_VSETTM:
11444 case RISCV::SF_VSETTN:
11445 case RISCV::SHA256SIG0:
11446 case RISCV::SHA256SIG1:
11447 case RISCV::SHA256SUM0:
11448 case RISCV::SHA256SUM1:
11449 case RISCV::SHA512SIG0:
11450 case RISCV::SHA512SIG1:
11451 case RISCV::SHA512SUM0:
11452 case RISCV::SHA512SUM1:
11453 case RISCV::SM3P0:
11454 case RISCV::SM3P1:
11455 case RISCV::TH_FF0:
11456 case RISCV::TH_FF1:
11457 case RISCV::TH_REV:
11458 case RISCV::TH_REVW:
11459 case RISCV::TH_TSTNBZ:
11460 case RISCV::UNZIP_RV32:
11461 case RISCV::ZEXT_H_RV32:
11462 case RISCV::ZEXT_H_RV64:
11463 case RISCV::ZIP_RV32: {
11464 switch (OpNum) {
11465 case 1:
11466 // op: rs1
11467 return 15;
11468 case 0:
11469 // op: rd
11470 return 7;
11471 }
11472 break;
11473 }
11474 case RISCV::PWSLAI_B:
11475 case RISCV::PWSLAI_H:
11476 case RISCV::PWSLLI_B:
11477 case RISCV::PWSLLI_H:
11478 case RISCV::WSLAI:
11479 case RISCV::WSLLI: {
11480 switch (OpNum) {
11481 case 1:
11482 // op: rs1
11483 return 15;
11484 case 0:
11485 // op: rd
11486 return 8;
11487 case 2:
11488 // op: shamt
11489 return 20;
11490 }
11491 break;
11492 }
11493 case RISCV::QC_E_SB:
11494 case RISCV::QC_E_SH:
11495 case RISCV::QC_E_SW: {
11496 switch (OpNum) {
11497 case 1:
11498 // op: rs1
11499 return 15;
11500 case 0:
11501 // op: rs2
11502 return 20;
11503 case 2:
11504 // op: imm
11505 return 7;
11506 }
11507 break;
11508 }
11509 case RISCV::CV_SB_rr:
11510 case RISCV::CV_SH_rr:
11511 case RISCV::CV_SW_rr: {
11512 switch (OpNum) {
11513 case 1:
11514 // op: rs1
11515 return 15;
11516 case 0:
11517 // op: rs2
11518 return 20;
11519 case 2:
11520 // op: rs3
11521 return 7;
11522 }
11523 break;
11524 }
11525 case RISCV::QC_OUTW: {
11526 switch (OpNum) {
11527 case 1:
11528 // op: rs1
11529 return 15;
11530 case 0:
11531 // op: rs2
11532 return 7;
11533 case 2:
11534 // op: imm14
11535 return 20;
11536 }
11537 break;
11538 }
11539 case RISCV::NDS_VLN8_V:
11540 case RISCV::NDS_VLNU8_V:
11541 case RISCV::VLE16FF_V:
11542 case RISCV::VLE16_V:
11543 case RISCV::VLE32FF_V:
11544 case RISCV::VLE32_V:
11545 case RISCV::VLE64FF_V:
11546 case RISCV::VLE64_V:
11547 case RISCV::VLE8FF_V:
11548 case RISCV::VLE8_V:
11549 case RISCV::VLSEG2E16FF_V:
11550 case RISCV::VLSEG2E16_V:
11551 case RISCV::VLSEG2E32FF_V:
11552 case RISCV::VLSEG2E32_V:
11553 case RISCV::VLSEG2E64FF_V:
11554 case RISCV::VLSEG2E64_V:
11555 case RISCV::VLSEG2E8FF_V:
11556 case RISCV::VLSEG2E8_V:
11557 case RISCV::VLSEG3E16FF_V:
11558 case RISCV::VLSEG3E16_V:
11559 case RISCV::VLSEG3E32FF_V:
11560 case RISCV::VLSEG3E32_V:
11561 case RISCV::VLSEG3E64FF_V:
11562 case RISCV::VLSEG3E64_V:
11563 case RISCV::VLSEG3E8FF_V:
11564 case RISCV::VLSEG3E8_V:
11565 case RISCV::VLSEG4E16FF_V:
11566 case RISCV::VLSEG4E16_V:
11567 case RISCV::VLSEG4E32FF_V:
11568 case RISCV::VLSEG4E32_V:
11569 case RISCV::VLSEG4E64FF_V:
11570 case RISCV::VLSEG4E64_V:
11571 case RISCV::VLSEG4E8FF_V:
11572 case RISCV::VLSEG4E8_V:
11573 case RISCV::VLSEG5E16FF_V:
11574 case RISCV::VLSEG5E16_V:
11575 case RISCV::VLSEG5E32FF_V:
11576 case RISCV::VLSEG5E32_V:
11577 case RISCV::VLSEG5E64FF_V:
11578 case RISCV::VLSEG5E64_V:
11579 case RISCV::VLSEG5E8FF_V:
11580 case RISCV::VLSEG5E8_V:
11581 case RISCV::VLSEG6E16FF_V:
11582 case RISCV::VLSEG6E16_V:
11583 case RISCV::VLSEG6E32FF_V:
11584 case RISCV::VLSEG6E32_V:
11585 case RISCV::VLSEG6E64FF_V:
11586 case RISCV::VLSEG6E64_V:
11587 case RISCV::VLSEG6E8FF_V:
11588 case RISCV::VLSEG6E8_V:
11589 case RISCV::VLSEG7E16FF_V:
11590 case RISCV::VLSEG7E16_V:
11591 case RISCV::VLSEG7E32FF_V:
11592 case RISCV::VLSEG7E32_V:
11593 case RISCV::VLSEG7E64FF_V:
11594 case RISCV::VLSEG7E64_V:
11595 case RISCV::VLSEG7E8FF_V:
11596 case RISCV::VLSEG7E8_V:
11597 case RISCV::VLSEG8E16FF_V:
11598 case RISCV::VLSEG8E16_V:
11599 case RISCV::VLSEG8E32FF_V:
11600 case RISCV::VLSEG8E32_V:
11601 case RISCV::VLSEG8E64FF_V:
11602 case RISCV::VLSEG8E64_V:
11603 case RISCV::VLSEG8E8FF_V:
11604 case RISCV::VLSEG8E8_V: {
11605 switch (OpNum) {
11606 case 1:
11607 // op: rs1
11608 return 15;
11609 case 0:
11610 // op: vd
11611 return 7;
11612 case 2:
11613 // op: vm
11614 return 25;
11615 }
11616 break;
11617 }
11618 case RISCV::VLSE16_V:
11619 case RISCV::VLSE32_V:
11620 case RISCV::VLSE64_V:
11621 case RISCV::VLSE8_V:
11622 case RISCV::VLSSEG2E16_V:
11623 case RISCV::VLSSEG2E32_V:
11624 case RISCV::VLSSEG2E64_V:
11625 case RISCV::VLSSEG2E8_V:
11626 case RISCV::VLSSEG3E16_V:
11627 case RISCV::VLSSEG3E32_V:
11628 case RISCV::VLSSEG3E64_V:
11629 case RISCV::VLSSEG3E8_V:
11630 case RISCV::VLSSEG4E16_V:
11631 case RISCV::VLSSEG4E32_V:
11632 case RISCV::VLSSEG4E64_V:
11633 case RISCV::VLSSEG4E8_V:
11634 case RISCV::VLSSEG5E16_V:
11635 case RISCV::VLSSEG5E32_V:
11636 case RISCV::VLSSEG5E64_V:
11637 case RISCV::VLSSEG5E8_V:
11638 case RISCV::VLSSEG6E16_V:
11639 case RISCV::VLSSEG6E32_V:
11640 case RISCV::VLSSEG6E64_V:
11641 case RISCV::VLSSEG6E8_V:
11642 case RISCV::VLSSEG7E16_V:
11643 case RISCV::VLSSEG7E32_V:
11644 case RISCV::VLSSEG7E64_V:
11645 case RISCV::VLSSEG7E8_V:
11646 case RISCV::VLSSEG8E16_V:
11647 case RISCV::VLSSEG8E32_V:
11648 case RISCV::VLSSEG8E64_V:
11649 case RISCV::VLSSEG8E8_V: {
11650 switch (OpNum) {
11651 case 1:
11652 // op: rs1
11653 return 15;
11654 case 0:
11655 // op: vd
11656 return 7;
11657 case 3:
11658 // op: vm
11659 return 25;
11660 case 2:
11661 // op: rs2
11662 return 20;
11663 }
11664 break;
11665 }
11666 case RISCV::VLOXEI16_V:
11667 case RISCV::VLOXEI32_V:
11668 case RISCV::VLOXEI64_V:
11669 case RISCV::VLOXEI8_V:
11670 case RISCV::VLOXSEG2EI16_V:
11671 case RISCV::VLOXSEG2EI32_V:
11672 case RISCV::VLOXSEG2EI64_V:
11673 case RISCV::VLOXSEG2EI8_V:
11674 case RISCV::VLOXSEG3EI16_V:
11675 case RISCV::VLOXSEG3EI32_V:
11676 case RISCV::VLOXSEG3EI64_V:
11677 case RISCV::VLOXSEG3EI8_V:
11678 case RISCV::VLOXSEG4EI16_V:
11679 case RISCV::VLOXSEG4EI32_V:
11680 case RISCV::VLOXSEG4EI64_V:
11681 case RISCV::VLOXSEG4EI8_V:
11682 case RISCV::VLOXSEG5EI16_V:
11683 case RISCV::VLOXSEG5EI32_V:
11684 case RISCV::VLOXSEG5EI64_V:
11685 case RISCV::VLOXSEG5EI8_V:
11686 case RISCV::VLOXSEG6EI16_V:
11687 case RISCV::VLOXSEG6EI32_V:
11688 case RISCV::VLOXSEG6EI64_V:
11689 case RISCV::VLOXSEG6EI8_V:
11690 case RISCV::VLOXSEG7EI16_V:
11691 case RISCV::VLOXSEG7EI32_V:
11692 case RISCV::VLOXSEG7EI64_V:
11693 case RISCV::VLOXSEG7EI8_V:
11694 case RISCV::VLOXSEG8EI16_V:
11695 case RISCV::VLOXSEG8EI32_V:
11696 case RISCV::VLOXSEG8EI64_V:
11697 case RISCV::VLOXSEG8EI8_V:
11698 case RISCV::VLUXEI16_V:
11699 case RISCV::VLUXEI32_V:
11700 case RISCV::VLUXEI64_V:
11701 case RISCV::VLUXEI8_V:
11702 case RISCV::VLUXSEG2EI16_V:
11703 case RISCV::VLUXSEG2EI32_V:
11704 case RISCV::VLUXSEG2EI64_V:
11705 case RISCV::VLUXSEG2EI8_V:
11706 case RISCV::VLUXSEG3EI16_V:
11707 case RISCV::VLUXSEG3EI32_V:
11708 case RISCV::VLUXSEG3EI64_V:
11709 case RISCV::VLUXSEG3EI8_V:
11710 case RISCV::VLUXSEG4EI16_V:
11711 case RISCV::VLUXSEG4EI32_V:
11712 case RISCV::VLUXSEG4EI64_V:
11713 case RISCV::VLUXSEG4EI8_V:
11714 case RISCV::VLUXSEG5EI16_V:
11715 case RISCV::VLUXSEG5EI32_V:
11716 case RISCV::VLUXSEG5EI64_V:
11717 case RISCV::VLUXSEG5EI8_V:
11718 case RISCV::VLUXSEG6EI16_V:
11719 case RISCV::VLUXSEG6EI32_V:
11720 case RISCV::VLUXSEG6EI64_V:
11721 case RISCV::VLUXSEG6EI8_V:
11722 case RISCV::VLUXSEG7EI16_V:
11723 case RISCV::VLUXSEG7EI32_V:
11724 case RISCV::VLUXSEG7EI64_V:
11725 case RISCV::VLUXSEG7EI8_V:
11726 case RISCV::VLUXSEG8EI16_V:
11727 case RISCV::VLUXSEG8EI32_V:
11728 case RISCV::VLUXSEG8EI64_V:
11729 case RISCV::VLUXSEG8EI8_V: {
11730 switch (OpNum) {
11731 case 1:
11732 // op: rs1
11733 return 15;
11734 case 0:
11735 // op: vd
11736 return 7;
11737 case 3:
11738 // op: vm
11739 return 25;
11740 case 2:
11741 // op: vs2
11742 return 20;
11743 }
11744 break;
11745 }
11746 case RISCV::NDS_VLE4_V:
11747 case RISCV::SF_VTMV_V_T:
11748 case RISCV::VL1RE16_V:
11749 case RISCV::VL1RE32_V:
11750 case RISCV::VL1RE64_V:
11751 case RISCV::VL1RE8_V:
11752 case RISCV::VL2RE16_V:
11753 case RISCV::VL2RE32_V:
11754 case RISCV::VL2RE64_V:
11755 case RISCV::VL2RE8_V:
11756 case RISCV::VL4RE16_V:
11757 case RISCV::VL4RE32_V:
11758 case RISCV::VL4RE64_V:
11759 case RISCV::VL4RE8_V:
11760 case RISCV::VL8RE16_V:
11761 case RISCV::VL8RE32_V:
11762 case RISCV::VL8RE64_V:
11763 case RISCV::VL8RE8_V:
11764 case RISCV::VLM_V: {
11765 switch (OpNum) {
11766 case 1:
11767 // op: rs1
11768 return 15;
11769 case 0:
11770 // op: vd
11771 return 7;
11772 }
11773 break;
11774 }
11775 case RISCV::VSE16_V:
11776 case RISCV::VSE32_V:
11777 case RISCV::VSE64_V:
11778 case RISCV::VSE8_V:
11779 case RISCV::VSSEG2E16_V:
11780 case RISCV::VSSEG2E32_V:
11781 case RISCV::VSSEG2E64_V:
11782 case RISCV::VSSEG2E8_V:
11783 case RISCV::VSSEG3E16_V:
11784 case RISCV::VSSEG3E32_V:
11785 case RISCV::VSSEG3E64_V:
11786 case RISCV::VSSEG3E8_V:
11787 case RISCV::VSSEG4E16_V:
11788 case RISCV::VSSEG4E32_V:
11789 case RISCV::VSSEG4E64_V:
11790 case RISCV::VSSEG4E8_V:
11791 case RISCV::VSSEG5E16_V:
11792 case RISCV::VSSEG5E32_V:
11793 case RISCV::VSSEG5E64_V:
11794 case RISCV::VSSEG5E8_V:
11795 case RISCV::VSSEG6E16_V:
11796 case RISCV::VSSEG6E32_V:
11797 case RISCV::VSSEG6E64_V:
11798 case RISCV::VSSEG6E8_V:
11799 case RISCV::VSSEG7E16_V:
11800 case RISCV::VSSEG7E32_V:
11801 case RISCV::VSSEG7E64_V:
11802 case RISCV::VSSEG7E8_V:
11803 case RISCV::VSSEG8E16_V:
11804 case RISCV::VSSEG8E32_V:
11805 case RISCV::VSSEG8E64_V:
11806 case RISCV::VSSEG8E8_V: {
11807 switch (OpNum) {
11808 case 1:
11809 // op: rs1
11810 return 15;
11811 case 0:
11812 // op: vs3
11813 return 7;
11814 case 2:
11815 // op: vm
11816 return 25;
11817 }
11818 break;
11819 }
11820 case RISCV::VSSE16_V:
11821 case RISCV::VSSE32_V:
11822 case RISCV::VSSE64_V:
11823 case RISCV::VSSE8_V:
11824 case RISCV::VSSSEG2E16_V:
11825 case RISCV::VSSSEG2E32_V:
11826 case RISCV::VSSSEG2E64_V:
11827 case RISCV::VSSSEG2E8_V:
11828 case RISCV::VSSSEG3E16_V:
11829 case RISCV::VSSSEG3E32_V:
11830 case RISCV::VSSSEG3E64_V:
11831 case RISCV::VSSSEG3E8_V:
11832 case RISCV::VSSSEG4E16_V:
11833 case RISCV::VSSSEG4E32_V:
11834 case RISCV::VSSSEG4E64_V:
11835 case RISCV::VSSSEG4E8_V:
11836 case RISCV::VSSSEG5E16_V:
11837 case RISCV::VSSSEG5E32_V:
11838 case RISCV::VSSSEG5E64_V:
11839 case RISCV::VSSSEG5E8_V:
11840 case RISCV::VSSSEG6E16_V:
11841 case RISCV::VSSSEG6E32_V:
11842 case RISCV::VSSSEG6E64_V:
11843 case RISCV::VSSSEG6E8_V:
11844 case RISCV::VSSSEG7E16_V:
11845 case RISCV::VSSSEG7E32_V:
11846 case RISCV::VSSSEG7E64_V:
11847 case RISCV::VSSSEG7E8_V:
11848 case RISCV::VSSSEG8E16_V:
11849 case RISCV::VSSSEG8E32_V:
11850 case RISCV::VSSSEG8E64_V:
11851 case RISCV::VSSSEG8E8_V: {
11852 switch (OpNum) {
11853 case 1:
11854 // op: rs1
11855 return 15;
11856 case 0:
11857 // op: vs3
11858 return 7;
11859 case 3:
11860 // op: vm
11861 return 25;
11862 case 2:
11863 // op: rs2
11864 return 20;
11865 }
11866 break;
11867 }
11868 case RISCV::VSOXEI16_V:
11869 case RISCV::VSOXEI32_V:
11870 case RISCV::VSOXEI64_V:
11871 case RISCV::VSOXEI8_V:
11872 case RISCV::VSOXSEG2EI16_V:
11873 case RISCV::VSOXSEG2EI32_V:
11874 case RISCV::VSOXSEG2EI64_V:
11875 case RISCV::VSOXSEG2EI8_V:
11876 case RISCV::VSOXSEG3EI16_V:
11877 case RISCV::VSOXSEG3EI32_V:
11878 case RISCV::VSOXSEG3EI64_V:
11879 case RISCV::VSOXSEG3EI8_V:
11880 case RISCV::VSOXSEG4EI16_V:
11881 case RISCV::VSOXSEG4EI32_V:
11882 case RISCV::VSOXSEG4EI64_V:
11883 case RISCV::VSOXSEG4EI8_V:
11884 case RISCV::VSOXSEG5EI16_V:
11885 case RISCV::VSOXSEG5EI32_V:
11886 case RISCV::VSOXSEG5EI64_V:
11887 case RISCV::VSOXSEG5EI8_V:
11888 case RISCV::VSOXSEG6EI16_V:
11889 case RISCV::VSOXSEG6EI32_V:
11890 case RISCV::VSOXSEG6EI64_V:
11891 case RISCV::VSOXSEG6EI8_V:
11892 case RISCV::VSOXSEG7EI16_V:
11893 case RISCV::VSOXSEG7EI32_V:
11894 case RISCV::VSOXSEG7EI64_V:
11895 case RISCV::VSOXSEG7EI8_V:
11896 case RISCV::VSOXSEG8EI16_V:
11897 case RISCV::VSOXSEG8EI32_V:
11898 case RISCV::VSOXSEG8EI64_V:
11899 case RISCV::VSOXSEG8EI8_V:
11900 case RISCV::VSUXEI16_V:
11901 case RISCV::VSUXEI32_V:
11902 case RISCV::VSUXEI64_V:
11903 case RISCV::VSUXEI8_V:
11904 case RISCV::VSUXSEG2EI16_V:
11905 case RISCV::VSUXSEG2EI32_V:
11906 case RISCV::VSUXSEG2EI64_V:
11907 case RISCV::VSUXSEG2EI8_V:
11908 case RISCV::VSUXSEG3EI16_V:
11909 case RISCV::VSUXSEG3EI32_V:
11910 case RISCV::VSUXSEG3EI64_V:
11911 case RISCV::VSUXSEG3EI8_V:
11912 case RISCV::VSUXSEG4EI16_V:
11913 case RISCV::VSUXSEG4EI32_V:
11914 case RISCV::VSUXSEG4EI64_V:
11915 case RISCV::VSUXSEG4EI8_V:
11916 case RISCV::VSUXSEG5EI16_V:
11917 case RISCV::VSUXSEG5EI32_V:
11918 case RISCV::VSUXSEG5EI64_V:
11919 case RISCV::VSUXSEG5EI8_V:
11920 case RISCV::VSUXSEG6EI16_V:
11921 case RISCV::VSUXSEG6EI32_V:
11922 case RISCV::VSUXSEG6EI64_V:
11923 case RISCV::VSUXSEG6EI8_V:
11924 case RISCV::VSUXSEG7EI16_V:
11925 case RISCV::VSUXSEG7EI32_V:
11926 case RISCV::VSUXSEG7EI64_V:
11927 case RISCV::VSUXSEG7EI8_V:
11928 case RISCV::VSUXSEG8EI16_V:
11929 case RISCV::VSUXSEG8EI32_V:
11930 case RISCV::VSUXSEG8EI64_V:
11931 case RISCV::VSUXSEG8EI8_V: {
11932 switch (OpNum) {
11933 case 1:
11934 // op: rs1
11935 return 15;
11936 case 0:
11937 // op: vs3
11938 return 7;
11939 case 3:
11940 // op: vm
11941 return 25;
11942 case 2:
11943 // op: vs2
11944 return 20;
11945 }
11946 break;
11947 }
11948 case RISCV::VS1R_V:
11949 case RISCV::VS2R_V:
11950 case RISCV::VS4R_V:
11951 case RISCV::VS8R_V:
11952 case RISCV::VSM_V: {
11953 switch (OpNum) {
11954 case 1:
11955 // op: rs1
11956 return 15;
11957 case 0:
11958 // op: vs3
11959 return 7;
11960 }
11961 break;
11962 }
11963 case RISCV::FCVT_BF16_S:
11964 case RISCV::FCVT_D_H:
11965 case RISCV::FCVT_D_H_IN32X:
11966 case RISCV::FCVT_D_H_INX:
11967 case RISCV::FCVT_D_L:
11968 case RISCV::FCVT_D_LU:
11969 case RISCV::FCVT_D_LU_INX:
11970 case RISCV::FCVT_D_L_INX:
11971 case RISCV::FCVT_D_Q:
11972 case RISCV::FCVT_D_S:
11973 case RISCV::FCVT_D_S_IN32X:
11974 case RISCV::FCVT_D_S_INX:
11975 case RISCV::FCVT_D_W:
11976 case RISCV::FCVT_D_WU:
11977 case RISCV::FCVT_D_WU_IN32X:
11978 case RISCV::FCVT_D_WU_INX:
11979 case RISCV::FCVT_D_W_IN32X:
11980 case RISCV::FCVT_D_W_INX:
11981 case RISCV::FCVT_H_D:
11982 case RISCV::FCVT_H_D_IN32X:
11983 case RISCV::FCVT_H_D_INX:
11984 case RISCV::FCVT_H_L:
11985 case RISCV::FCVT_H_LU:
11986 case RISCV::FCVT_H_LU_INX:
11987 case RISCV::FCVT_H_L_INX:
11988 case RISCV::FCVT_H_S:
11989 case RISCV::FCVT_H_S_INX:
11990 case RISCV::FCVT_H_W:
11991 case RISCV::FCVT_H_WU:
11992 case RISCV::FCVT_H_WU_INX:
11993 case RISCV::FCVT_H_W_INX:
11994 case RISCV::FCVT_LU_D:
11995 case RISCV::FCVT_LU_D_INX:
11996 case RISCV::FCVT_LU_H:
11997 case RISCV::FCVT_LU_H_INX:
11998 case RISCV::FCVT_LU_Q:
11999 case RISCV::FCVT_LU_S:
12000 case RISCV::FCVT_LU_S_INX:
12001 case RISCV::FCVT_L_D:
12002 case RISCV::FCVT_L_D_INX:
12003 case RISCV::FCVT_L_H:
12004 case RISCV::FCVT_L_H_INX:
12005 case RISCV::FCVT_L_Q:
12006 case RISCV::FCVT_L_S:
12007 case RISCV::FCVT_L_S_INX:
12008 case RISCV::FCVT_Q_D:
12009 case RISCV::FCVT_Q_L:
12010 case RISCV::FCVT_Q_LU:
12011 case RISCV::FCVT_Q_S:
12012 case RISCV::FCVT_Q_W:
12013 case RISCV::FCVT_Q_WU:
12014 case RISCV::FCVT_S_BF16:
12015 case RISCV::FCVT_S_D:
12016 case RISCV::FCVT_S_D_IN32X:
12017 case RISCV::FCVT_S_D_INX:
12018 case RISCV::FCVT_S_H:
12019 case RISCV::FCVT_S_H_INX:
12020 case RISCV::FCVT_S_L:
12021 case RISCV::FCVT_S_LU:
12022 case RISCV::FCVT_S_LU_INX:
12023 case RISCV::FCVT_S_L_INX:
12024 case RISCV::FCVT_S_Q:
12025 case RISCV::FCVT_S_W:
12026 case RISCV::FCVT_S_WU:
12027 case RISCV::FCVT_S_WU_INX:
12028 case RISCV::FCVT_S_W_INX:
12029 case RISCV::FCVT_WU_D:
12030 case RISCV::FCVT_WU_D_IN32X:
12031 case RISCV::FCVT_WU_D_INX:
12032 case RISCV::FCVT_WU_H:
12033 case RISCV::FCVT_WU_H_INX:
12034 case RISCV::FCVT_WU_Q:
12035 case RISCV::FCVT_WU_S:
12036 case RISCV::FCVT_WU_S_INX:
12037 case RISCV::FCVT_W_D:
12038 case RISCV::FCVT_W_D_IN32X:
12039 case RISCV::FCVT_W_D_INX:
12040 case RISCV::FCVT_W_H:
12041 case RISCV::FCVT_W_H_INX:
12042 case RISCV::FCVT_W_Q:
12043 case RISCV::FCVT_W_S:
12044 case RISCV::FCVT_W_S_INX:
12045 case RISCV::FROUNDNX_D:
12046 case RISCV::FROUNDNX_H:
12047 case RISCV::FROUNDNX_Q:
12048 case RISCV::FROUNDNX_S:
12049 case RISCV::FROUND_D:
12050 case RISCV::FROUND_H:
12051 case RISCV::FROUND_Q:
12052 case RISCV::FROUND_S:
12053 case RISCV::FSQRT_D:
12054 case RISCV::FSQRT_D_IN32X:
12055 case RISCV::FSQRT_D_INX:
12056 case RISCV::FSQRT_H:
12057 case RISCV::FSQRT_H_INX:
12058 case RISCV::FSQRT_Q:
12059 case RISCV::FSQRT_S:
12060 case RISCV::FSQRT_S_INX: {
12061 switch (OpNum) {
12062 case 1:
12063 // op: rs1
12064 return 15;
12065 case 2:
12066 // op: frm
12067 return 12;
12068 case 0:
12069 // op: rd
12070 return 7;
12071 }
12072 break;
12073 }
12074 case RISCV::AIF_FROUND_PS: {
12075 switch (OpNum) {
12076 case 1:
12077 // op: rs1
12078 return 15;
12079 case 2:
12080 // op: rm
12081 return 12;
12082 case 0:
12083 // op: rd
12084 return 7;
12085 }
12086 break;
12087 }
12088 case RISCV::AIF_FSC32B_PS:
12089 case RISCV::AIF_FSC32H_PS:
12090 case RISCV::AIF_FSC32W_PS:
12091 case RISCV::AIF_FSCBG_PS:
12092 case RISCV::AIF_FSCBL_PS:
12093 case RISCV::AIF_FSCB_PS:
12094 case RISCV::AIF_FSCHG_PS:
12095 case RISCV::AIF_FSCHL_PS:
12096 case RISCV::AIF_FSCH_PS:
12097 case RISCV::AIF_FSCWG_PS:
12098 case RISCV::AIF_FSCWL_PS:
12099 case RISCV::AIF_FSCW_PS: {
12100 switch (OpNum) {
12101 case 1:
12102 // op: rs1
12103 return 15;
12104 case 2:
12105 // op: rs2
12106 return 20;
12107 case 0:
12108 // op: rs3
12109 return 7;
12110 }
12111 break;
12112 }
12113 case RISCV::NCLIP:
12114 case RISCV::NCLIPR:
12115 case RISCV::NCLIPRU:
12116 case RISCV::NCLIPU:
12117 case RISCV::NSRA:
12118 case RISCV::NSRAR:
12119 case RISCV::NSRL:
12120 case RISCV::PNCLIPRU_BS:
12121 case RISCV::PNCLIPRU_HS:
12122 case RISCV::PNCLIPR_BS:
12123 case RISCV::PNCLIPR_HS:
12124 case RISCV::PNCLIPU_BS:
12125 case RISCV::PNCLIPU_HS:
12126 case RISCV::PNCLIP_BS:
12127 case RISCV::PNCLIP_HS:
12128 case RISCV::PNSRAR_BS:
12129 case RISCV::PNSRAR_HS:
12130 case RISCV::PNSRA_BS:
12131 case RISCV::PNSRA_HS:
12132 case RISCV::PNSRL_BS:
12133 case RISCV::PNSRL_HS:
12134 case RISCV::PREDSUMU_DBS:
12135 case RISCV::PREDSUMU_DHS:
12136 case RISCV::PREDSUM_DBS:
12137 case RISCV::PREDSUM_DHS: {
12138 switch (OpNum) {
12139 case 1:
12140 // op: rs1
12141 return 16;
12142 case 0:
12143 // op: rd
12144 return 7;
12145 case 2:
12146 // op: rs2
12147 return 20;
12148 }
12149 break;
12150 }
12151 case RISCV::NCLIPI:
12152 case RISCV::NCLIPIU:
12153 case RISCV::NCLIPRI:
12154 case RISCV::NCLIPRIU:
12155 case RISCV::NSARI:
12156 case RISCV::NSRAI:
12157 case RISCV::NSRLI:
12158 case RISCV::PNCLIPIU_B:
12159 case RISCV::PNCLIPIU_H:
12160 case RISCV::PNCLIPI_B:
12161 case RISCV::PNCLIPI_H:
12162 case RISCV::PNCLIPRIU_B:
12163 case RISCV::PNCLIPRIU_H:
12164 case RISCV::PNCLIPRI_B:
12165 case RISCV::PNCLIPRI_H:
12166 case RISCV::PNSARI_B:
12167 case RISCV::PNSARI_H:
12168 case RISCV::PNSRAI_B:
12169 case RISCV::PNSRAI_H:
12170 case RISCV::PNSRLI_B:
12171 case RISCV::PNSRLI_H: {
12172 switch (OpNum) {
12173 case 1:
12174 // op: rs1
12175 return 16;
12176 case 0:
12177 // op: rd
12178 return 7;
12179 case 2:
12180 // op: shamt
12181 return 20;
12182 }
12183 break;
12184 }
12185 case RISCV::PADD_DBS:
12186 case RISCV::PADD_DHS:
12187 case RISCV::PADD_DWS:
12188 case RISCV::PSLL_DBS:
12189 case RISCV::PSLL_DHS:
12190 case RISCV::PSLL_DWS:
12191 case RISCV::PSRA_DBS:
12192 case RISCV::PSRA_DHS:
12193 case RISCV::PSRA_DWS:
12194 case RISCV::PSRL_DBS:
12195 case RISCV::PSRL_DHS:
12196 case RISCV::PSRL_DWS:
12197 case RISCV::PSSHAR_DHS:
12198 case RISCV::PSSHAR_DWS:
12199 case RISCV::PSSHA_DHS:
12200 case RISCV::PSSHA_DWS: {
12201 switch (OpNum) {
12202 case 1:
12203 // op: rs1
12204 return 16;
12205 case 0:
12206 // op: rd
12207 return 8;
12208 case 2:
12209 // op: rs2
12210 return 20;
12211 }
12212 break;
12213 }
12214 case RISCV::ADDD:
12215 case RISCV::PAADDU_DB:
12216 case RISCV::PAADDU_DH:
12217 case RISCV::PAADDU_DW:
12218 case RISCV::PAADD_DB:
12219 case RISCV::PAADD_DH:
12220 case RISCV::PAADD_DW:
12221 case RISCV::PAAX_DHX:
12222 case RISCV::PABDU_DB:
12223 case RISCV::PABDU_DH:
12224 case RISCV::PABD_DB:
12225 case RISCV::PABD_DH:
12226 case RISCV::PADD_DB:
12227 case RISCV::PADD_DH:
12228 case RISCV::PADD_DW:
12229 case RISCV::PASA_DHX:
12230 case RISCV::PASUBU_DB:
12231 case RISCV::PASUBU_DH:
12232 case RISCV::PASUBU_DW:
12233 case RISCV::PASUB_DB:
12234 case RISCV::PASUB_DH:
12235 case RISCV::PASUB_DW:
12236 case RISCV::PAS_DHX:
12237 case RISCV::PMAXU_DB:
12238 case RISCV::PMAXU_DH:
12239 case RISCV::PMAXU_DW:
12240 case RISCV::PMAX_DB:
12241 case RISCV::PMAX_DH:
12242 case RISCV::PMAX_DW:
12243 case RISCV::PMINU_DB:
12244 case RISCV::PMINU_DH:
12245 case RISCV::PMINU_DW:
12246 case RISCV::PMIN_DB:
12247 case RISCV::PMIN_DH:
12248 case RISCV::PMIN_DW:
12249 case RISCV::PMSEQ_DB:
12250 case RISCV::PMSEQ_DH:
12251 case RISCV::PMSEQ_DW:
12252 case RISCV::PMSLTU_DB:
12253 case RISCV::PMSLTU_DH:
12254 case RISCV::PMSLTU_DW:
12255 case RISCV::PMSLT_DB:
12256 case RISCV::PMSLT_DH:
12257 case RISCV::PMSLT_DW:
12258 case RISCV::PPAIREO_DB:
12259 case RISCV::PPAIREO_DH:
12260 case RISCV::PPAIRE_DB:
12261 case RISCV::PPAIRE_DH:
12262 case RISCV::PPAIROE_DB:
12263 case RISCV::PPAIROE_DH:
12264 case RISCV::PPAIRO_DB:
12265 case RISCV::PPAIRO_DH:
12266 case RISCV::PSADDU_DB:
12267 case RISCV::PSADDU_DH:
12268 case RISCV::PSADDU_DW:
12269 case RISCV::PSADD_DB:
12270 case RISCV::PSADD_DH:
12271 case RISCV::PSADD_DW:
12272 case RISCV::PSAS_DHX:
12273 case RISCV::PSA_DHX:
12274 case RISCV::PSH1ADD_DH:
12275 case RISCV::PSH1ADD_DW:
12276 case RISCV::PSSA_DHX:
12277 case RISCV::PSSH1SADD_DH:
12278 case RISCV::PSSH1SADD_DW:
12279 case RISCV::PSSUBU_DB:
12280 case RISCV::PSSUBU_DH:
12281 case RISCV::PSSUBU_DW:
12282 case RISCV::PSSUB_DB:
12283 case RISCV::PSSUB_DH:
12284 case RISCV::PSSUB_DW:
12285 case RISCV::PSUB_DB:
12286 case RISCV::PSUB_DH:
12287 case RISCV::PSUB_DW:
12288 case RISCV::SUBD: {
12289 switch (OpNum) {
12290 case 1:
12291 // op: rs1
12292 return 16;
12293 case 0:
12294 // op: rd
12295 return 8;
12296 case 2:
12297 // op: rs2
12298 return 21;
12299 }
12300 break;
12301 }
12302 case RISCV::PSATI_DH:
12303 case RISCV::PSATI_DW:
12304 case RISCV::PSLLI_DB:
12305 case RISCV::PSLLI_DH:
12306 case RISCV::PSLLI_DW:
12307 case RISCV::PSRAI_DB:
12308 case RISCV::PSRAI_DH:
12309 case RISCV::PSRAI_DW:
12310 case RISCV::PSRARI_DH:
12311 case RISCV::PSRARI_DW:
12312 case RISCV::PSRLI_DB:
12313 case RISCV::PSRLI_DH:
12314 case RISCV::PSRLI_DW:
12315 case RISCV::PSSLAI_DH:
12316 case RISCV::PSSLAI_DW:
12317 case RISCV::PUSATI_DH:
12318 case RISCV::PUSATI_DW: {
12319 switch (OpNum) {
12320 case 1:
12321 // op: rs1
12322 return 16;
12323 case 0:
12324 // op: rd
12325 return 8;
12326 case 2:
12327 // op: shamt
12328 return 20;
12329 }
12330 break;
12331 }
12332 case RISCV::PSABS_DB:
12333 case RISCV::PSABS_DH:
12334 case RISCV::PSEXT_DH_B:
12335 case RISCV::PSEXT_DW_B:
12336 case RISCV::PSEXT_DW_H: {
12337 switch (OpNum) {
12338 case 1:
12339 // op: rs1
12340 return 16;
12341 case 0:
12342 // op: rd
12343 return 8;
12344 }
12345 break;
12346 }
12347 case RISCV::C_ADD: {
12348 switch (OpNum) {
12349 case 1:
12350 // op: rs1
12351 return 7;
12352 case 2:
12353 // op: rs2
12354 return 2;
12355 }
12356 break;
12357 }
12358 case RISCV::QC_C_BEXTI:
12359 case RISCV::QC_C_BSETI: {
12360 switch (OpNum) {
12361 case 1:
12362 // op: rs1
12363 return 7;
12364 case 2:
12365 // op: shamt
12366 return 2;
12367 }
12368 break;
12369 }
12370 case RISCV::NDS_FCVT_BF16_S:
12371 case RISCV::NDS_FCVT_S_BF16: {
12372 switch (OpNum) {
12373 case 1:
12374 // op: rs2
12375 return 20;
12376 case 0:
12377 // op: rd
12378 return 7;
12379 }
12380 break;
12381 }
12382 case RISCV::HFENCE_GVMA:
12383 case RISCV::HFENCE_VVMA:
12384 case RISCV::HINVAL_GVMA:
12385 case RISCV::HINVAL_VVMA:
12386 case RISCV::SFENCE_VMA:
12387 case RISCV::SF_VTMV_T_V:
12388 case RISCV::SINVAL_VMA:
12389 case RISCV::TH_SFENCE_VMAS: {
12390 switch (OpNum) {
12391 case 1:
12392 // op: rs2
12393 return 20;
12394 case 0:
12395 // op: rs1
12396 return 15;
12397 }
12398 break;
12399 }
12400 case RISCV::TH_LDD:
12401 case RISCV::TH_LWD:
12402 case RISCV::TH_LWUD:
12403 case RISCV::TH_SDD:
12404 case RISCV::TH_SWD: {
12405 switch (OpNum) {
12406 case 1:
12407 // op: rs2
12408 return 20;
12409 case 2:
12410 // op: rs1
12411 return 15;
12412 case 0:
12413 // op: rd
12414 return 7;
12415 case 3:
12416 // op: uimm2
12417 return 25;
12418 }
12419 break;
12420 }
12421 case RISCV::AIF_AMOADDG_D:
12422 case RISCV::AIF_AMOADDG_W:
12423 case RISCV::AIF_AMOADDL_D:
12424 case RISCV::AIF_AMOADDL_W:
12425 case RISCV::AIF_AMOANDG_D:
12426 case RISCV::AIF_AMOANDG_W:
12427 case RISCV::AIF_AMOANDL_D:
12428 case RISCV::AIF_AMOANDL_W:
12429 case RISCV::AIF_AMOCMPSWAPG_D:
12430 case RISCV::AIF_AMOCMPSWAPG_W:
12431 case RISCV::AIF_AMOCMPSWAPL_D:
12432 case RISCV::AIF_AMOCMPSWAPL_W:
12433 case RISCV::AIF_AMOMAXG_D:
12434 case RISCV::AIF_AMOMAXG_W:
12435 case RISCV::AIF_AMOMAXL_D:
12436 case RISCV::AIF_AMOMAXL_W:
12437 case RISCV::AIF_AMOMAXUG_D:
12438 case RISCV::AIF_AMOMAXUG_W:
12439 case RISCV::AIF_AMOMAXUL_D:
12440 case RISCV::AIF_AMOMAXUL_W:
12441 case RISCV::AIF_AMOMING_D:
12442 case RISCV::AIF_AMOMING_W:
12443 case RISCV::AIF_AMOMINL_D:
12444 case RISCV::AIF_AMOMINL_W:
12445 case RISCV::AIF_AMOMINUG_D:
12446 case RISCV::AIF_AMOMINUG_W:
12447 case RISCV::AIF_AMOMINUL_D:
12448 case RISCV::AIF_AMOMINUL_W:
12449 case RISCV::AIF_AMOORG_D:
12450 case RISCV::AIF_AMOORG_W:
12451 case RISCV::AIF_AMOORL_D:
12452 case RISCV::AIF_AMOORL_W:
12453 case RISCV::AIF_AMOSWAPG_D:
12454 case RISCV::AIF_AMOSWAPG_W:
12455 case RISCV::AIF_AMOSWAPL_D:
12456 case RISCV::AIF_AMOSWAPL_W:
12457 case RISCV::AIF_AMOXORG_D:
12458 case RISCV::AIF_AMOXORG_W:
12459 case RISCV::AIF_AMOXORL_D:
12460 case RISCV::AIF_AMOXORL_W:
12461 case RISCV::AMOADD_B:
12462 case RISCV::AMOADD_B_AQ:
12463 case RISCV::AMOADD_B_AQRL:
12464 case RISCV::AMOADD_B_RL:
12465 case RISCV::AMOADD_D:
12466 case RISCV::AMOADD_D_AQ:
12467 case RISCV::AMOADD_D_AQRL:
12468 case RISCV::AMOADD_D_RL:
12469 case RISCV::AMOADD_H:
12470 case RISCV::AMOADD_H_AQ:
12471 case RISCV::AMOADD_H_AQRL:
12472 case RISCV::AMOADD_H_RL:
12473 case RISCV::AMOADD_W:
12474 case RISCV::AMOADD_W_AQ:
12475 case RISCV::AMOADD_W_AQRL:
12476 case RISCV::AMOADD_W_RL:
12477 case RISCV::AMOAND_B:
12478 case RISCV::AMOAND_B_AQ:
12479 case RISCV::AMOAND_B_AQRL:
12480 case RISCV::AMOAND_B_RL:
12481 case RISCV::AMOAND_D:
12482 case RISCV::AMOAND_D_AQ:
12483 case RISCV::AMOAND_D_AQRL:
12484 case RISCV::AMOAND_D_RL:
12485 case RISCV::AMOAND_H:
12486 case RISCV::AMOAND_H_AQ:
12487 case RISCV::AMOAND_H_AQRL:
12488 case RISCV::AMOAND_H_RL:
12489 case RISCV::AMOAND_W:
12490 case RISCV::AMOAND_W_AQ:
12491 case RISCV::AMOAND_W_AQRL:
12492 case RISCV::AMOAND_W_RL:
12493 case RISCV::AMOMAXU_B:
12494 case RISCV::AMOMAXU_B_AQ:
12495 case RISCV::AMOMAXU_B_AQRL:
12496 case RISCV::AMOMAXU_B_RL:
12497 case RISCV::AMOMAXU_D:
12498 case RISCV::AMOMAXU_D_AQ:
12499 case RISCV::AMOMAXU_D_AQRL:
12500 case RISCV::AMOMAXU_D_RL:
12501 case RISCV::AMOMAXU_H:
12502 case RISCV::AMOMAXU_H_AQ:
12503 case RISCV::AMOMAXU_H_AQRL:
12504 case RISCV::AMOMAXU_H_RL:
12505 case RISCV::AMOMAXU_W:
12506 case RISCV::AMOMAXU_W_AQ:
12507 case RISCV::AMOMAXU_W_AQRL:
12508 case RISCV::AMOMAXU_W_RL:
12509 case RISCV::AMOMAX_B:
12510 case RISCV::AMOMAX_B_AQ:
12511 case RISCV::AMOMAX_B_AQRL:
12512 case RISCV::AMOMAX_B_RL:
12513 case RISCV::AMOMAX_D:
12514 case RISCV::AMOMAX_D_AQ:
12515 case RISCV::AMOMAX_D_AQRL:
12516 case RISCV::AMOMAX_D_RL:
12517 case RISCV::AMOMAX_H:
12518 case RISCV::AMOMAX_H_AQ:
12519 case RISCV::AMOMAX_H_AQRL:
12520 case RISCV::AMOMAX_H_RL:
12521 case RISCV::AMOMAX_W:
12522 case RISCV::AMOMAX_W_AQ:
12523 case RISCV::AMOMAX_W_AQRL:
12524 case RISCV::AMOMAX_W_RL:
12525 case RISCV::AMOMINU_B:
12526 case RISCV::AMOMINU_B_AQ:
12527 case RISCV::AMOMINU_B_AQRL:
12528 case RISCV::AMOMINU_B_RL:
12529 case RISCV::AMOMINU_D:
12530 case RISCV::AMOMINU_D_AQ:
12531 case RISCV::AMOMINU_D_AQRL:
12532 case RISCV::AMOMINU_D_RL:
12533 case RISCV::AMOMINU_H:
12534 case RISCV::AMOMINU_H_AQ:
12535 case RISCV::AMOMINU_H_AQRL:
12536 case RISCV::AMOMINU_H_RL:
12537 case RISCV::AMOMINU_W:
12538 case RISCV::AMOMINU_W_AQ:
12539 case RISCV::AMOMINU_W_AQRL:
12540 case RISCV::AMOMINU_W_RL:
12541 case RISCV::AMOMIN_B:
12542 case RISCV::AMOMIN_B_AQ:
12543 case RISCV::AMOMIN_B_AQRL:
12544 case RISCV::AMOMIN_B_RL:
12545 case RISCV::AMOMIN_D:
12546 case RISCV::AMOMIN_D_AQ:
12547 case RISCV::AMOMIN_D_AQRL:
12548 case RISCV::AMOMIN_D_RL:
12549 case RISCV::AMOMIN_H:
12550 case RISCV::AMOMIN_H_AQ:
12551 case RISCV::AMOMIN_H_AQRL:
12552 case RISCV::AMOMIN_H_RL:
12553 case RISCV::AMOMIN_W:
12554 case RISCV::AMOMIN_W_AQ:
12555 case RISCV::AMOMIN_W_AQRL:
12556 case RISCV::AMOMIN_W_RL:
12557 case RISCV::AMOOR_B:
12558 case RISCV::AMOOR_B_AQ:
12559 case RISCV::AMOOR_B_AQRL:
12560 case RISCV::AMOOR_B_RL:
12561 case RISCV::AMOOR_D:
12562 case RISCV::AMOOR_D_AQ:
12563 case RISCV::AMOOR_D_AQRL:
12564 case RISCV::AMOOR_D_RL:
12565 case RISCV::AMOOR_H:
12566 case RISCV::AMOOR_H_AQ:
12567 case RISCV::AMOOR_H_AQRL:
12568 case RISCV::AMOOR_H_RL:
12569 case RISCV::AMOOR_W:
12570 case RISCV::AMOOR_W_AQ:
12571 case RISCV::AMOOR_W_AQRL:
12572 case RISCV::AMOOR_W_RL:
12573 case RISCV::AMOSWAP_B:
12574 case RISCV::AMOSWAP_B_AQ:
12575 case RISCV::AMOSWAP_B_AQRL:
12576 case RISCV::AMOSWAP_B_RL:
12577 case RISCV::AMOSWAP_D:
12578 case RISCV::AMOSWAP_D_AQ:
12579 case RISCV::AMOSWAP_D_AQRL:
12580 case RISCV::AMOSWAP_D_RL:
12581 case RISCV::AMOSWAP_H:
12582 case RISCV::AMOSWAP_H_AQ:
12583 case RISCV::AMOSWAP_H_AQRL:
12584 case RISCV::AMOSWAP_H_RL:
12585 case RISCV::AMOSWAP_W:
12586 case RISCV::AMOSWAP_W_AQ:
12587 case RISCV::AMOSWAP_W_AQRL:
12588 case RISCV::AMOSWAP_W_RL:
12589 case RISCV::AMOXOR_B:
12590 case RISCV::AMOXOR_B_AQ:
12591 case RISCV::AMOXOR_B_AQRL:
12592 case RISCV::AMOXOR_B_RL:
12593 case RISCV::AMOXOR_D:
12594 case RISCV::AMOXOR_D_AQ:
12595 case RISCV::AMOXOR_D_AQRL:
12596 case RISCV::AMOXOR_D_RL:
12597 case RISCV::AMOXOR_H:
12598 case RISCV::AMOXOR_H_AQ:
12599 case RISCV::AMOXOR_H_AQRL:
12600 case RISCV::AMOXOR_H_RL:
12601 case RISCV::AMOXOR_W:
12602 case RISCV::AMOXOR_W_AQ:
12603 case RISCV::AMOXOR_W_AQRL:
12604 case RISCV::AMOXOR_W_RL:
12605 case RISCV::NDS_LEA_B_ZE:
12606 case RISCV::NDS_LEA_D:
12607 case RISCV::NDS_LEA_D_ZE:
12608 case RISCV::NDS_LEA_H:
12609 case RISCV::NDS_LEA_H_ZE:
12610 case RISCV::NDS_LEA_W:
12611 case RISCV::NDS_LEA_W_ZE:
12612 case RISCV::SC_D:
12613 case RISCV::SC_D_AQ:
12614 case RISCV::SC_D_AQRL:
12615 case RISCV::SC_D_RL:
12616 case RISCV::SC_W:
12617 case RISCV::SC_W_AQ:
12618 case RISCV::SC_W_AQRL:
12619 case RISCV::SC_W_RL:
12620 case RISCV::SSAMOSWAP_D:
12621 case RISCV::SSAMOSWAP_D_AQ:
12622 case RISCV::SSAMOSWAP_D_AQRL:
12623 case RISCV::SSAMOSWAP_D_RL:
12624 case RISCV::SSAMOSWAP_W:
12625 case RISCV::SSAMOSWAP_W_AQ:
12626 case RISCV::SSAMOSWAP_W_AQRL:
12627 case RISCV::SSAMOSWAP_W_RL: {
12628 switch (OpNum) {
12629 case 1:
12630 // op: rs2
12631 return 20;
12632 case 2:
12633 // op: rs1
12634 return 15;
12635 case 0:
12636 // op: rd
12637 return 7;
12638 }
12639 break;
12640 }
12641 case RISCV::SF_VC_I:
12642 case RISCV::SF_VC_X: {
12643 switch (OpNum) {
12644 case 1:
12645 // op: rs2
12646 return 20;
12647 case 3:
12648 // op: rs1
12649 return 15;
12650 case 2:
12651 // op: rd
12652 return 7;
12653 case 0:
12654 // op: funct6_lo2
12655 return 26;
12656 }
12657 break;
12658 }
12659 case RISCV::CM_MVA01S:
12660 case RISCV::CM_MVSA01:
12661 case RISCV::QC_CM_MVA01S:
12662 case RISCV::QC_CM_MVSA01: {
12663 switch (OpNum) {
12664 case 1:
12665 // op: rs2
12666 return 2;
12667 case 0:
12668 // op: rs1
12669 return 7;
12670 }
12671 break;
12672 }
12673 case RISCV::VFMV_S_F:
12674 case RISCV::VMV_S_X: {
12675 switch (OpNum) {
12676 case 1:
12677 // op: vd
12678 return 7;
12679 case 2:
12680 // op: rs1
12681 return 15;
12682 }
12683 break;
12684 }
12685 case RISCV::VAESKF2_VI:
12686 case RISCV::VSM3C_VI: {
12687 switch (OpNum) {
12688 case 1:
12689 // op: vd
12690 return 7;
12691 case 2:
12692 // op: vs2
12693 return 20;
12694 case 3:
12695 // op: imm
12696 return 15;
12697 }
12698 break;
12699 }
12700 case RISCV::VGHSH_VS:
12701 case RISCV::VGHSH_VV:
12702 case RISCV::VSHA2CH_VV:
12703 case RISCV::VSHA2CL_VV:
12704 case RISCV::VSHA2MS_VV: {
12705 switch (OpNum) {
12706 case 1:
12707 // op: vd
12708 return 7;
12709 case 2:
12710 // op: vs2
12711 return 20;
12712 case 3:
12713 // op: vs1
12714 return 15;
12715 }
12716 break;
12717 }
12718 case RISCV::VAESDF_VS:
12719 case RISCV::VAESDF_VV:
12720 case RISCV::VAESDM_VS:
12721 case RISCV::VAESDM_VV:
12722 case RISCV::VAESEF_VS:
12723 case RISCV::VAESEF_VV:
12724 case RISCV::VAESEM_VS:
12725 case RISCV::VAESEM_VV:
12726 case RISCV::VAESZ_VS:
12727 case RISCV::VGMUL_VS:
12728 case RISCV::VGMUL_VV:
12729 case RISCV::VSM4R_VS:
12730 case RISCV::VSM4R_VV: {
12731 switch (OpNum) {
12732 case 1:
12733 // op: vd
12734 return 7;
12735 case 2:
12736 // op: vs2
12737 return 20;
12738 }
12739 break;
12740 }
12741 case RISCV::VQDOTSU_VX:
12742 case RISCV::VQDOTUS_VX:
12743 case RISCV::VQDOTU_VX:
12744 case RISCV::VQDOT_VX: {
12745 switch (OpNum) {
12746 case 1:
12747 // op: vd
12748 return 7;
12749 case 4:
12750 // op: vm
12751 return 25;
12752 case 2:
12753 // op: vs2
12754 return 20;
12755 case 3:
12756 // op: rs1
12757 return 15;
12758 }
12759 break;
12760 }
12761 case RISCV::VQDOTSU_VV:
12762 case RISCV::VQDOTU_VV:
12763 case RISCV::VQDOT_VV: {
12764 switch (OpNum) {
12765 case 1:
12766 // op: vd
12767 return 7;
12768 case 4:
12769 // op: vm
12770 return 25;
12771 case 2:
12772 // op: vs2
12773 return 20;
12774 case 3:
12775 // op: vs1
12776 return 15;
12777 }
12778 break;
12779 }
12780 case RISCV::TH_VMAQASU_VX:
12781 case RISCV::TH_VMAQAUS_VX:
12782 case RISCV::TH_VMAQAU_VX:
12783 case RISCV::TH_VMAQA_VX:
12784 case RISCV::VFMACC_VF:
12785 case RISCV::VFMADD_VF:
12786 case RISCV::VFMSAC_VF:
12787 case RISCV::VFMSUB_VF:
12788 case RISCV::VFNMACC_VF:
12789 case RISCV::VFNMADD_VF:
12790 case RISCV::VFNMSAC_VF:
12791 case RISCV::VFNMSUB_VF:
12792 case RISCV::VFWMACCBF16_VF:
12793 case RISCV::VFWMACC_VF:
12794 case RISCV::VFWMSAC_VF:
12795 case RISCV::VFWNMACC_VF:
12796 case RISCV::VFWNMSAC_VF:
12797 case RISCV::VMACC_VX:
12798 case RISCV::VMADD_VX:
12799 case RISCV::VNMSAC_VX:
12800 case RISCV::VNMSUB_VX:
12801 case RISCV::VWMACCSU_VX:
12802 case RISCV::VWMACCUS_VX:
12803 case RISCV::VWMACCU_VX:
12804 case RISCV::VWMACC_VX: {
12805 switch (OpNum) {
12806 case 1:
12807 // op: vd
12808 return 7;
12809 case 4:
12810 // op: vm
12811 return 25;
12812 case 3:
12813 // op: vs2
12814 return 20;
12815 case 2:
12816 // op: rs1
12817 return 15;
12818 }
12819 break;
12820 }
12821 case RISCV::TH_VMAQASU_VV:
12822 case RISCV::TH_VMAQAU_VV:
12823 case RISCV::TH_VMAQA_VV:
12824 case RISCV::VFMACC_VV:
12825 case RISCV::VFMADD_VV:
12826 case RISCV::VFMSAC_VV:
12827 case RISCV::VFMSUB_VV:
12828 case RISCV::VFNMACC_VV:
12829 case RISCV::VFNMADD_VV:
12830 case RISCV::VFNMSAC_VV:
12831 case RISCV::VFNMSUB_VV:
12832 case RISCV::VFWMACCBF16_VV:
12833 case RISCV::VFWMACC_VV:
12834 case RISCV::VFWMSAC_VV:
12835 case RISCV::VFWNMACC_VV:
12836 case RISCV::VFWNMSAC_VV:
12837 case RISCV::VMACC_VV:
12838 case RISCV::VMADD_VV:
12839 case RISCV::VNMSAC_VV:
12840 case RISCV::VNMSUB_VV:
12841 case RISCV::VWMACCSU_VV:
12842 case RISCV::VWMACCU_VV:
12843 case RISCV::VWMACC_VV: {
12844 switch (OpNum) {
12845 case 1:
12846 // op: vd
12847 return 7;
12848 case 4:
12849 // op: vm
12850 return 25;
12851 case 3:
12852 // op: vs2
12853 return 20;
12854 case 2:
12855 // op: vs1
12856 return 15;
12857 }
12858 break;
12859 }
12860 case RISCV::NDS_VFWCVT_F_B:
12861 case RISCV::NDS_VFWCVT_F_BU:
12862 case RISCV::NDS_VFWCVT_F_N:
12863 case RISCV::NDS_VFWCVT_F_NU: {
12864 switch (OpNum) {
12865 case 1:
12866 // op: vs
12867 return 20;
12868 case 0:
12869 // op: vd
12870 return 7;
12871 case 2:
12872 // op: vm
12873 return 25;
12874 }
12875 break;
12876 }
12877 case RISCV::NDS_VFNCVT_BF16_S:
12878 case RISCV::NDS_VFWCVT_S_BF16: {
12879 switch (OpNum) {
12880 case 1:
12881 // op: vs2
12882 return 20;
12883 case 0:
12884 // op: vd
12885 return 7;
12886 }
12887 break;
12888 }
12889 case RISCV::NDS_VFPMADB_VF:
12890 case RISCV::NDS_VFPMADT_VF: {
12891 switch (OpNum) {
12892 case 1:
12893 // op: vs2
12894 return 20;
12895 case 2:
12896 // op: rs1
12897 return 15;
12898 case 0:
12899 // op: vd
12900 return 7;
12901 case 3:
12902 // op: vm
12903 return 25;
12904 }
12905 break;
12906 }
12907 case RISCV::SF_MM_E4M3_E4M3:
12908 case RISCV::SF_MM_E4M3_E5M2:
12909 case RISCV::SF_MM_E5M2_E4M3:
12910 case RISCV::SF_MM_E5M2_E5M2:
12911 case RISCV::SF_MM_S_S:
12912 case RISCV::SF_MM_S_U:
12913 case RISCV::SF_MM_U_S:
12914 case RISCV::SF_MM_U_U: {
12915 switch (OpNum) {
12916 case 1:
12917 // op: vs2
12918 return 20;
12919 case 2:
12920 // op: vs1
12921 return 15;
12922 case 0:
12923 // op: rd
12924 return 10;
12925 }
12926 break;
12927 }
12928 case RISCV::SF_MM_F_F: {
12929 switch (OpNum) {
12930 case 1:
12931 // op: vs2
12932 return 20;
12933 case 2:
12934 // op: vs1
12935 return 15;
12936 case 0:
12937 // op: rd
12938 return 9;
12939 }
12940 break;
12941 }
12942 case RISCV::AIF_MOV_M_X: {
12943 switch (OpNum) {
12944 case 2:
12945 // op: imm
12946 return 12;
12947 case 1:
12948 // op: rs1
12949 return 15;
12950 case 0:
12951 // op: rd
12952 return 7;
12953 }
12954 break;
12955 }
12956 case RISCV::RI_VEXTRACT: {
12957 switch (OpNum) {
12958 case 2:
12959 // op: imm
12960 return 15;
12961 case 1:
12962 // op: vs2
12963 return 20;
12964 case 0:
12965 // op: rd
12966 return 7;
12967 }
12968 break;
12969 }
12970 case RISCV::AIF_FADDI_PI:
12971 case RISCV::AIF_FANDI_PI:
12972 case RISCV::AIF_FSLLI_PI:
12973 case RISCV::AIF_FSRAI_PI:
12974 case RISCV::AIF_FSRLI_PI: {
12975 switch (OpNum) {
12976 case 2:
12977 // op: imm
12978 return 20;
12979 case 1:
12980 // op: rs1
12981 return 15;
12982 case 0:
12983 // op: rd
12984 return 7;
12985 }
12986 break;
12987 }
12988 case RISCV::C_FLDSP:
12989 case RISCV::C_FLWSP:
12990 case RISCV::C_LDSP:
12991 case RISCV::C_LDSP_RV32:
12992 case RISCV::C_LWSP:
12993 case RISCV::C_LWSP_INX: {
12994 switch (OpNum) {
12995 case 2:
12996 // op: imm
12997 return 2;
12998 case 0:
12999 // op: rd
13000 return 7;
13001 }
13002 break;
13003 }
13004 case RISCV::C_ADDI:
13005 case RISCV::C_ADDIW:
13006 case RISCV::C_SLLI: {
13007 switch (OpNum) {
13008 case 2:
13009 // op: imm
13010 return 2;
13011 case 1:
13012 // op: rd
13013 return 7;
13014 }
13015 break;
13016 }
13017 case RISCV::C_ANDI:
13018 case RISCV::C_SRAI:
13019 case RISCV::C_SRLI: {
13020 switch (OpNum) {
13021 case 2:
13022 // op: imm
13023 return 2;
13024 case 1:
13025 // op: rs1
13026 return 7;
13027 }
13028 break;
13029 }
13030 case RISCV::C_ADDI16SP: {
13031 switch (OpNum) {
13032 case 2:
13033 // op: imm
13034 return 2;
13035 }
13036 break;
13037 }
13038 case RISCV::C_ADDI4SPN: {
13039 switch (OpNum) {
13040 case 2:
13041 // op: imm
13042 return 5;
13043 case 0:
13044 // op: rd
13045 return 2;
13046 }
13047 break;
13048 }
13049 case RISCV::C_FSDSP:
13050 case RISCV::C_FSWSP:
13051 case RISCV::C_SDSP:
13052 case RISCV::C_SDSP_RV32:
13053 case RISCV::C_SWSP:
13054 case RISCV::C_SWSP_INX: {
13055 switch (OpNum) {
13056 case 2:
13057 // op: imm
13058 return 7;
13059 case 0:
13060 // op: rs2
13061 return 2;
13062 }
13063 break;
13064 }
13065 case RISCV::NDS_BBC:
13066 case RISCV::NDS_BBS:
13067 case RISCV::NDS_BEQC:
13068 case RISCV::NDS_BNEC: {
13069 switch (OpNum) {
13070 case 2:
13071 // op: imm10
13072 return 8;
13073 case 0:
13074 // op: rs1
13075 return 15;
13076 case 1:
13077 // op: cimm
13078 return 7;
13079 }
13080 break;
13081 }
13082 case RISCV::CV_BEQIMM:
13083 case RISCV::CV_BNEIMM: {
13084 switch (OpNum) {
13085 case 2:
13086 // op: imm12
13087 return 7;
13088 case 0:
13089 // op: rs1
13090 return 15;
13091 case 1:
13092 // op: imm5
13093 return 20;
13094 }
13095 break;
13096 }
13097 case RISCV::FSD:
13098 case RISCV::FSH:
13099 case RISCV::FSQ:
13100 case RISCV::FSW:
13101 case RISCV::SB:
13102 case RISCV::SD:
13103 case RISCV::SD_RV32:
13104 case RISCV::SH:
13105 case RISCV::SH_INX:
13106 case RISCV::SW:
13107 case RISCV::SW_INX: {
13108 switch (OpNum) {
13109 case 2:
13110 // op: imm12
13111 return 7;
13112 case 0:
13113 // op: rs2
13114 return 20;
13115 case 1:
13116 // op: rs1
13117 return 15;
13118 }
13119 break;
13120 }
13121 case RISCV::BEQI:
13122 case RISCV::BNEI: {
13123 switch (OpNum) {
13124 case 2:
13125 // op: imm12
13126 return 7;
13127 case 1:
13128 // op: cimm
13129 return 20;
13130 case 0:
13131 // op: rs1
13132 return 15;
13133 }
13134 break;
13135 }
13136 case RISCV::BEQ:
13137 case RISCV::BGE:
13138 case RISCV::BGEU:
13139 case RISCV::BLT:
13140 case RISCV::BLTU:
13141 case RISCV::BNE:
13142 case RISCV::QC_BEQI:
13143 case RISCV::QC_BGEI:
13144 case RISCV::QC_BGEUI:
13145 case RISCV::QC_BLTI:
13146 case RISCV::QC_BLTUI:
13147 case RISCV::QC_BNEI: {
13148 switch (OpNum) {
13149 case 2:
13150 // op: imm12
13151 return 7;
13152 case 1:
13153 // op: rs2
13154 return 20;
13155 case 0:
13156 // op: rs1
13157 return 15;
13158 }
13159 break;
13160 }
13161 case RISCV::AIF_FBC_PS:
13162 case RISCV::AIF_FLQ2:
13163 case RISCV::AIF_FLW_PS:
13164 case RISCV::CSRRC:
13165 case RISCV::CSRRCI:
13166 case RISCV::CSRRS:
13167 case RISCV::CSRRSI:
13168 case RISCV::CSRRW:
13169 case RISCV::CSRRWI: {
13170 switch (OpNum) {
13171 case 2:
13172 // op: rs1
13173 return 15;
13174 case 0:
13175 // op: rd
13176 return 7;
13177 case 1:
13178 // op: imm12
13179 return 20;
13180 }
13181 break;
13182 }
13183 case RISCV::CV_LBU_ri_inc:
13184 case RISCV::CV_LB_ri_inc:
13185 case RISCV::CV_LHU_ri_inc:
13186 case RISCV::CV_LH_ri_inc:
13187 case RISCV::CV_LW_ri_inc: {
13188 switch (OpNum) {
13189 case 2:
13190 // op: rs1
13191 return 15;
13192 case 0:
13193 // op: rd
13194 return 7;
13195 case 3:
13196 // op: imm12
13197 return 20;
13198 }
13199 break;
13200 }
13201 case RISCV::TH_LBIA:
13202 case RISCV::TH_LBIB:
13203 case RISCV::TH_LBUIA:
13204 case RISCV::TH_LBUIB:
13205 case RISCV::TH_LDIA:
13206 case RISCV::TH_LDIB:
13207 case RISCV::TH_LHIA:
13208 case RISCV::TH_LHIB:
13209 case RISCV::TH_LHUIA:
13210 case RISCV::TH_LHUIB:
13211 case RISCV::TH_LWIA:
13212 case RISCV::TH_LWIB:
13213 case RISCV::TH_LWUIA:
13214 case RISCV::TH_LWUIB: {
13215 switch (OpNum) {
13216 case 2:
13217 // op: rs1
13218 return 15;
13219 case 0:
13220 // op: rd
13221 return 7;
13222 case 3:
13223 // op: simm5
13224 return 20;
13225 case 4:
13226 // op: uimm2
13227 return 25;
13228 }
13229 break;
13230 }
13231 case RISCV::QC_INSBRI: {
13232 switch (OpNum) {
13233 case 2:
13234 // op: rs1
13235 return 15;
13236 case 1:
13237 // op: rd
13238 return 7;
13239 case 3:
13240 // op: imm11
13241 return 20;
13242 }
13243 break;
13244 }
13245 case RISCV::QC_MULIADD: {
13246 switch (OpNum) {
13247 case 2:
13248 // op: rs1
13249 return 15;
13250 case 1:
13251 // op: rd
13252 return 7;
13253 case 3:
13254 // op: imm12
13255 return 20;
13256 }
13257 break;
13258 }
13259 case RISCV::CV_INSERT_B:
13260 case RISCV::CV_INSERT_H:
13261 case RISCV::CV_SDOTSP_SCI_B:
13262 case RISCV::CV_SDOTSP_SCI_H:
13263 case RISCV::CV_SDOTUP_SCI_B:
13264 case RISCV::CV_SDOTUP_SCI_H:
13265 case RISCV::CV_SDOTUSP_SCI_B:
13266 case RISCV::CV_SDOTUSP_SCI_H: {
13267 switch (OpNum) {
13268 case 2:
13269 // op: rs1
13270 return 15;
13271 case 1:
13272 // op: rd
13273 return 7;
13274 case 3:
13275 // op: imm6
13276 return 20;
13277 }
13278 break;
13279 }
13280 case RISCV::CV_INSERT: {
13281 switch (OpNum) {
13282 case 2:
13283 // op: rs1
13284 return 15;
13285 case 1:
13286 // op: rd
13287 return 7;
13288 case 3:
13289 // op: is3
13290 return 25;
13291 case 4:
13292 // op: is2
13293 return 20;
13294 }
13295 break;
13296 }
13297 case RISCV::QC_SELECTIIEQ:
13298 case RISCV::QC_SELECTIINE: {
13299 switch (OpNum) {
13300 case 2:
13301 // op: rs1
13302 return 15;
13303 case 1:
13304 // op: rd
13305 return 7;
13306 case 3:
13307 // op: simm1
13308 return 20;
13309 case 4:
13310 // op: simm2
13311 return 27;
13312 }
13313 break;
13314 }
13315 case RISCV::TH_SBIA:
13316 case RISCV::TH_SBIB:
13317 case RISCV::TH_SDIA:
13318 case RISCV::TH_SDIB:
13319 case RISCV::TH_SHIA:
13320 case RISCV::TH_SHIB:
13321 case RISCV::TH_SWIA:
13322 case RISCV::TH_SWIB: {
13323 switch (OpNum) {
13324 case 2:
13325 // op: rs1
13326 return 15;
13327 case 1:
13328 // op: rd
13329 return 7;
13330 case 3:
13331 // op: simm5
13332 return 20;
13333 case 4:
13334 // op: uimm2
13335 return 25;
13336 }
13337 break;
13338 }
13339 case RISCV::QC_INSB:
13340 case RISCV::QC_INSBH: {
13341 switch (OpNum) {
13342 case 2:
13343 // op: rs1
13344 return 15;
13345 case 1:
13346 // op: rd
13347 return 7;
13348 case 4:
13349 // op: shamt
13350 return 20;
13351 case 3:
13352 // op: width
13353 return 25;
13354 }
13355 break;
13356 }
13357 case RISCV::AES32DSI:
13358 case RISCV::AES32DSMI:
13359 case RISCV::AES32ESI:
13360 case RISCV::AES32ESMI:
13361 case RISCV::SM4ED:
13362 case RISCV::SM4KS: {
13363 switch (OpNum) {
13364 case 2:
13365 // op: rs2
13366 return 20;
13367 case 1:
13368 // op: rs1
13369 return 15;
13370 case 0:
13371 // op: rd
13372 return 7;
13373 case 3:
13374 // op: bs
13375 return 30;
13376 }
13377 break;
13378 }
13379 case RISCV::QC_LWM:
13380 case RISCV::QC_LWMI:
13381 case RISCV::QC_SETWM:
13382 case RISCV::QC_SETWMI:
13383 case RISCV::QC_SWM:
13384 case RISCV::QC_SWMI: {
13385 switch (OpNum) {
13386 case 2:
13387 // op: rs2
13388 return 20;
13389 case 1:
13390 // op: rs1
13391 return 15;
13392 case 0:
13393 // op: rd
13394 return 7;
13395 case 3:
13396 // op: imm
13397 return 25;
13398 }
13399 break;
13400 }
13401 case RISCV::CV_ADDN:
13402 case RISCV::CV_ADDRN:
13403 case RISCV::CV_ADDUN:
13404 case RISCV::CV_ADDURN:
13405 case RISCV::CV_MULHHSN:
13406 case RISCV::CV_MULHHSRN:
13407 case RISCV::CV_MULHHUN:
13408 case RISCV::CV_MULHHURN:
13409 case RISCV::CV_MULSN:
13410 case RISCV::CV_MULSRN:
13411 case RISCV::CV_MULUN:
13412 case RISCV::CV_MULURN:
13413 case RISCV::CV_SUBN:
13414 case RISCV::CV_SUBRN:
13415 case RISCV::CV_SUBUN:
13416 case RISCV::CV_SUBURN: {
13417 switch (OpNum) {
13418 case 2:
13419 // op: rs2
13420 return 20;
13421 case 1:
13422 // op: rs1
13423 return 15;
13424 case 0:
13425 // op: rd
13426 return 7;
13427 case 3:
13428 // op: imm5
13429 return 25;
13430 }
13431 break;
13432 }
13433 case RISCV::QC_LRB:
13434 case RISCV::QC_LRBU:
13435 case RISCV::QC_LRH:
13436 case RISCV::QC_LRHU:
13437 case RISCV::QC_LRW:
13438 case RISCV::QC_SHLADD:
13439 case RISCV::QC_SRB:
13440 case RISCV::QC_SRH:
13441 case RISCV::QC_SRW: {
13442 switch (OpNum) {
13443 case 2:
13444 // op: rs2
13445 return 20;
13446 case 1:
13447 // op: rs1
13448 return 15;
13449 case 0:
13450 // op: rd
13451 return 7;
13452 case 3:
13453 // op: shamt
13454 return 25;
13455 }
13456 break;
13457 }
13458 case RISCV::TH_ADDSL:
13459 case RISCV::TH_FLRD:
13460 case RISCV::TH_FLRW:
13461 case RISCV::TH_FLURD:
13462 case RISCV::TH_FLURW:
13463 case RISCV::TH_FSRD:
13464 case RISCV::TH_FSRW:
13465 case RISCV::TH_FSURD:
13466 case RISCV::TH_FSURW:
13467 case RISCV::TH_LRB:
13468 case RISCV::TH_LRBU:
13469 case RISCV::TH_LRD:
13470 case RISCV::TH_LRH:
13471 case RISCV::TH_LRHU:
13472 case RISCV::TH_LRW:
13473 case RISCV::TH_LRWU:
13474 case RISCV::TH_LURB:
13475 case RISCV::TH_LURBU:
13476 case RISCV::TH_LURD:
13477 case RISCV::TH_LURH:
13478 case RISCV::TH_LURHU:
13479 case RISCV::TH_LURW:
13480 case RISCV::TH_LURWU:
13481 case RISCV::TH_SRB:
13482 case RISCV::TH_SRD:
13483 case RISCV::TH_SRH:
13484 case RISCV::TH_SRW:
13485 case RISCV::TH_SURB:
13486 case RISCV::TH_SURD:
13487 case RISCV::TH_SURH:
13488 case RISCV::TH_SURW: {
13489 switch (OpNum) {
13490 case 2:
13491 // op: rs2
13492 return 20;
13493 case 1:
13494 // op: rs1
13495 return 15;
13496 case 0:
13497 // op: rd
13498 return 7;
13499 case 3:
13500 // op: uimm2
13501 return 25;
13502 }
13503 break;
13504 }
13505 case RISCV::AADD:
13506 case RISCV::AADDU:
13507 case RISCV::ADD:
13508 case RISCV::ADDW:
13509 case RISCV::ADD_UW:
13510 case RISCV::AES64DS:
13511 case RISCV::AES64DSM:
13512 case RISCV::AES64ES:
13513 case RISCV::AES64ESM:
13514 case RISCV::AES64KS2:
13515 case RISCV::AIF_BITMIXB:
13516 case RISCV::AIF_CUBEFACEIDX_PS:
13517 case RISCV::AIF_CUBEFACE_PS:
13518 case RISCV::AIF_CUBESGNSC_PS:
13519 case RISCV::AIF_CUBESGNTC_PS:
13520 case RISCV::AIF_FADD_PI:
13521 case RISCV::AIF_FAMOADDG_PI:
13522 case RISCV::AIF_FAMOADDL_PI:
13523 case RISCV::AIF_FAMOANDG_PI:
13524 case RISCV::AIF_FAMOANDL_PI:
13525 case RISCV::AIF_FAMOMAXG_PI:
13526 case RISCV::AIF_FAMOMAXG_PS:
13527 case RISCV::AIF_FAMOMAXL_PI:
13528 case RISCV::AIF_FAMOMAXL_PS:
13529 case RISCV::AIF_FAMOMAXUG_PI:
13530 case RISCV::AIF_FAMOMAXUL_PI:
13531 case RISCV::AIF_FAMOMING_PI:
13532 case RISCV::AIF_FAMOMING_PS:
13533 case RISCV::AIF_FAMOMINL_PI:
13534 case RISCV::AIF_FAMOMINL_PS:
13535 case RISCV::AIF_FAMOMINUG_PI:
13536 case RISCV::AIF_FAMOMINUL_PI:
13537 case RISCV::AIF_FAMOORG_PI:
13538 case RISCV::AIF_FAMOORL_PI:
13539 case RISCV::AIF_FAMOSWAPG_PI:
13540 case RISCV::AIF_FAMOSWAPL_PI:
13541 case RISCV::AIF_FAMOXORG_PI:
13542 case RISCV::AIF_FAMOXORL_PI:
13543 case RISCV::AIF_FAND_PI:
13544 case RISCV::AIF_FCMOVM_PS:
13545 case RISCV::AIF_FDIVU_PI:
13546 case RISCV::AIF_FDIV_PI:
13547 case RISCV::AIF_FEQM_PS:
13548 case RISCV::AIF_FEQ_PI:
13549 case RISCV::AIF_FEQ_PS:
13550 case RISCV::AIF_FG32B_PS:
13551 case RISCV::AIF_FG32H_PS:
13552 case RISCV::AIF_FG32W_PS:
13553 case RISCV::AIF_FGBG_PS:
13554 case RISCV::AIF_FGBL_PS:
13555 case RISCV::AIF_FGB_PS:
13556 case RISCV::AIF_FGHG_PS:
13557 case RISCV::AIF_FGHL_PS:
13558 case RISCV::AIF_FGH_PS:
13559 case RISCV::AIF_FGWG_PS:
13560 case RISCV::AIF_FGWL_PS:
13561 case RISCV::AIF_FGW_PS:
13562 case RISCV::AIF_FLEM_PS:
13563 case RISCV::AIF_FLE_PI:
13564 case RISCV::AIF_FLE_PS:
13565 case RISCV::AIF_FLTM_PI:
13566 case RISCV::AIF_FLTM_PS:
13567 case RISCV::AIF_FLTU_PI:
13568 case RISCV::AIF_FLT_PI:
13569 case RISCV::AIF_FLT_PS:
13570 case RISCV::AIF_FMAXU_PI:
13571 case RISCV::AIF_FMAX_PI:
13572 case RISCV::AIF_FMAX_PS:
13573 case RISCV::AIF_FMINU_PI:
13574 case RISCV::AIF_FMIN_PI:
13575 case RISCV::AIF_FMIN_PS:
13576 case RISCV::AIF_FMULHU_PI:
13577 case RISCV::AIF_FMULH_PI:
13578 case RISCV::AIF_FMUL_PI:
13579 case RISCV::AIF_FOR_PI:
13580 case RISCV::AIF_FRCP_FIX_RAST:
13581 case RISCV::AIF_FREMU_PI:
13582 case RISCV::AIF_FREM_PI:
13583 case RISCV::AIF_FSGNJN_PS:
13584 case RISCV::AIF_FSGNJX_PS:
13585 case RISCV::AIF_FSGNJ_PS:
13586 case RISCV::AIF_FSLL_PI:
13587 case RISCV::AIF_FSRA_PI:
13588 case RISCV::AIF_FSRL_PI:
13589 case RISCV::AIF_FSUB_PI:
13590 case RISCV::AIF_FXOR_PI:
13591 case RISCV::AIF_MASKAND:
13592 case RISCV::AIF_MASKOR:
13593 case RISCV::AIF_MASKXOR:
13594 case RISCV::AIF_PACKB:
13595 case RISCV::AND:
13596 case RISCV::ANDN:
13597 case RISCV::ASUB:
13598 case RISCV::ASUBU:
13599 case RISCV::BCLR:
13600 case RISCV::BEXT:
13601 case RISCV::BINV:
13602 case RISCV::BSET:
13603 case RISCV::CLMUL:
13604 case RISCV::CLMULH:
13605 case RISCV::CLMULR:
13606 case RISCV::CV_ADD_B:
13607 case RISCV::CV_ADD_DIV2:
13608 case RISCV::CV_ADD_DIV4:
13609 case RISCV::CV_ADD_DIV8:
13610 case RISCV::CV_ADD_H:
13611 case RISCV::CV_ADD_SC_B:
13612 case RISCV::CV_ADD_SC_H:
13613 case RISCV::CV_AND_B:
13614 case RISCV::CV_AND_H:
13615 case RISCV::CV_AND_SC_B:
13616 case RISCV::CV_AND_SC_H:
13617 case RISCV::CV_AVGU_B:
13618 case RISCV::CV_AVGU_H:
13619 case RISCV::CV_AVGU_SC_B:
13620 case RISCV::CV_AVGU_SC_H:
13621 case RISCV::CV_AVG_B:
13622 case RISCV::CV_AVG_H:
13623 case RISCV::CV_AVG_SC_B:
13624 case RISCV::CV_AVG_SC_H:
13625 case RISCV::CV_BCLRR:
13626 case RISCV::CV_BSETR:
13627 case RISCV::CV_CLIPR:
13628 case RISCV::CV_CLIPUR:
13629 case RISCV::CV_CMPEQ_B:
13630 case RISCV::CV_CMPEQ_H:
13631 case RISCV::CV_CMPEQ_SC_B:
13632 case RISCV::CV_CMPEQ_SC_H:
13633 case RISCV::CV_CMPGEU_B:
13634 case RISCV::CV_CMPGEU_H:
13635 case RISCV::CV_CMPGEU_SC_B:
13636 case RISCV::CV_CMPGEU_SC_H:
13637 case RISCV::CV_CMPGE_B:
13638 case RISCV::CV_CMPGE_H:
13639 case RISCV::CV_CMPGE_SC_B:
13640 case RISCV::CV_CMPGE_SC_H:
13641 case RISCV::CV_CMPGTU_B:
13642 case RISCV::CV_CMPGTU_H:
13643 case RISCV::CV_CMPGTU_SC_B:
13644 case RISCV::CV_CMPGTU_SC_H:
13645 case RISCV::CV_CMPGT_B:
13646 case RISCV::CV_CMPGT_H:
13647 case RISCV::CV_CMPGT_SC_B:
13648 case RISCV::CV_CMPGT_SC_H:
13649 case RISCV::CV_CMPLEU_B:
13650 case RISCV::CV_CMPLEU_H:
13651 case RISCV::CV_CMPLEU_SC_B:
13652 case RISCV::CV_CMPLEU_SC_H:
13653 case RISCV::CV_CMPLE_B:
13654 case RISCV::CV_CMPLE_H:
13655 case RISCV::CV_CMPLE_SC_B:
13656 case RISCV::CV_CMPLE_SC_H:
13657 case RISCV::CV_CMPLTU_B:
13658 case RISCV::CV_CMPLTU_H:
13659 case RISCV::CV_CMPLTU_SC_B:
13660 case RISCV::CV_CMPLTU_SC_H:
13661 case RISCV::CV_CMPLT_B:
13662 case RISCV::CV_CMPLT_H:
13663 case RISCV::CV_CMPLT_SC_B:
13664 case RISCV::CV_CMPLT_SC_H:
13665 case RISCV::CV_CMPNE_B:
13666 case RISCV::CV_CMPNE_H:
13667 case RISCV::CV_CMPNE_SC_B:
13668 case RISCV::CV_CMPNE_SC_H:
13669 case RISCV::CV_DOTSP_B:
13670 case RISCV::CV_DOTSP_H:
13671 case RISCV::CV_DOTSP_SC_B:
13672 case RISCV::CV_DOTSP_SC_H:
13673 case RISCV::CV_DOTUP_B:
13674 case RISCV::CV_DOTUP_H:
13675 case RISCV::CV_DOTUP_SC_B:
13676 case RISCV::CV_DOTUP_SC_H:
13677 case RISCV::CV_DOTUSP_B:
13678 case RISCV::CV_DOTUSP_H:
13679 case RISCV::CV_DOTUSP_SC_B:
13680 case RISCV::CV_DOTUSP_SC_H:
13681 case RISCV::CV_EXTRACTR:
13682 case RISCV::CV_EXTRACTUR:
13683 case RISCV::CV_LBU_rr:
13684 case RISCV::CV_LB_rr:
13685 case RISCV::CV_LHU_rr:
13686 case RISCV::CV_LH_rr:
13687 case RISCV::CV_LW_rr:
13688 case RISCV::CV_MAX:
13689 case RISCV::CV_MAXU:
13690 case RISCV::CV_MAXU_B:
13691 case RISCV::CV_MAXU_H:
13692 case RISCV::CV_MAXU_SC_B:
13693 case RISCV::CV_MAXU_SC_H:
13694 case RISCV::CV_MAX_B:
13695 case RISCV::CV_MAX_H:
13696 case RISCV::CV_MAX_SC_B:
13697 case RISCV::CV_MAX_SC_H:
13698 case RISCV::CV_MIN:
13699 case RISCV::CV_MINU:
13700 case RISCV::CV_MINU_B:
13701 case RISCV::CV_MINU_H:
13702 case RISCV::CV_MINU_SC_B:
13703 case RISCV::CV_MINU_SC_H:
13704 case RISCV::CV_MIN_B:
13705 case RISCV::CV_MIN_H:
13706 case RISCV::CV_MIN_SC_B:
13707 case RISCV::CV_MIN_SC_H:
13708 case RISCV::CV_OR_B:
13709 case RISCV::CV_OR_H:
13710 case RISCV::CV_OR_SC_B:
13711 case RISCV::CV_OR_SC_H:
13712 case RISCV::CV_PACK:
13713 case RISCV::CV_PACK_H:
13714 case RISCV::CV_ROR:
13715 case RISCV::CV_SHUFFLE_B:
13716 case RISCV::CV_SHUFFLE_H:
13717 case RISCV::CV_SLE:
13718 case RISCV::CV_SLEU:
13719 case RISCV::CV_SLL_B:
13720 case RISCV::CV_SLL_H:
13721 case RISCV::CV_SLL_SC_B:
13722 case RISCV::CV_SLL_SC_H:
13723 case RISCV::CV_SRA_B:
13724 case RISCV::CV_SRA_H:
13725 case RISCV::CV_SRA_SC_B:
13726 case RISCV::CV_SRA_SC_H:
13727 case RISCV::CV_SRL_B:
13728 case RISCV::CV_SRL_H:
13729 case RISCV::CV_SRL_SC_B:
13730 case RISCV::CV_SRL_SC_H:
13731 case RISCV::CV_SUBROTMJ:
13732 case RISCV::CV_SUBROTMJ_DIV2:
13733 case RISCV::CV_SUBROTMJ_DIV4:
13734 case RISCV::CV_SUBROTMJ_DIV8:
13735 case RISCV::CV_SUB_B:
13736 case RISCV::CV_SUB_DIV2:
13737 case RISCV::CV_SUB_DIV4:
13738 case RISCV::CV_SUB_DIV8:
13739 case RISCV::CV_SUB_H:
13740 case RISCV::CV_SUB_SC_B:
13741 case RISCV::CV_SUB_SC_H:
13742 case RISCV::CV_XOR_B:
13743 case RISCV::CV_XOR_H:
13744 case RISCV::CV_XOR_SC_B:
13745 case RISCV::CV_XOR_SC_H:
13746 case RISCV::CZERO_EQZ:
13747 case RISCV::CZERO_NEZ:
13748 case RISCV::DIV:
13749 case RISCV::DIVU:
13750 case RISCV::DIVUW:
13751 case RISCV::DIVW:
13752 case RISCV::FEQ_D:
13753 case RISCV::FEQ_D_IN32X:
13754 case RISCV::FEQ_D_INX:
13755 case RISCV::FEQ_H:
13756 case RISCV::FEQ_H_INX:
13757 case RISCV::FEQ_Q:
13758 case RISCV::FEQ_S:
13759 case RISCV::FEQ_S_INX:
13760 case RISCV::FLEQ_D:
13761 case RISCV::FLEQ_H:
13762 case RISCV::FLEQ_Q:
13763 case RISCV::FLEQ_S:
13764 case RISCV::FLE_D:
13765 case RISCV::FLE_D_IN32X:
13766 case RISCV::FLE_D_INX:
13767 case RISCV::FLE_H:
13768 case RISCV::FLE_H_INX:
13769 case RISCV::FLE_Q:
13770 case RISCV::FLE_S:
13771 case RISCV::FLE_S_INX:
13772 case RISCV::FLTQ_D:
13773 case RISCV::FLTQ_H:
13774 case RISCV::FLTQ_Q:
13775 case RISCV::FLTQ_S:
13776 case RISCV::FLT_D:
13777 case RISCV::FLT_D_IN32X:
13778 case RISCV::FLT_D_INX:
13779 case RISCV::FLT_H:
13780 case RISCV::FLT_H_INX:
13781 case RISCV::FLT_Q:
13782 case RISCV::FLT_S:
13783 case RISCV::FLT_S_INX:
13784 case RISCV::FMAXM_D:
13785 case RISCV::FMAXM_H:
13786 case RISCV::FMAXM_Q:
13787 case RISCV::FMAXM_S:
13788 case RISCV::FMAX_D:
13789 case RISCV::FMAX_D_IN32X:
13790 case RISCV::FMAX_D_INX:
13791 case RISCV::FMAX_H:
13792 case RISCV::FMAX_H_INX:
13793 case RISCV::FMAX_Q:
13794 case RISCV::FMAX_S:
13795 case RISCV::FMAX_S_INX:
13796 case RISCV::FMINM_D:
13797 case RISCV::FMINM_H:
13798 case RISCV::FMINM_Q:
13799 case RISCV::FMINM_S:
13800 case RISCV::FMIN_D:
13801 case RISCV::FMIN_D_IN32X:
13802 case RISCV::FMIN_D_INX:
13803 case RISCV::FMIN_H:
13804 case RISCV::FMIN_H_INX:
13805 case RISCV::FMIN_Q:
13806 case RISCV::FMIN_S:
13807 case RISCV::FMIN_S_INX:
13808 case RISCV::FMVP_D_X:
13809 case RISCV::FMVP_Q_X:
13810 case RISCV::FSGNJN_D:
13811 case RISCV::FSGNJN_D_IN32X:
13812 case RISCV::FSGNJN_D_INX:
13813 case RISCV::FSGNJN_H:
13814 case RISCV::FSGNJN_H_INX:
13815 case RISCV::FSGNJN_Q:
13816 case RISCV::FSGNJN_S:
13817 case RISCV::FSGNJN_S_INX:
13818 case RISCV::FSGNJX_D:
13819 case RISCV::FSGNJX_D_IN32X:
13820 case RISCV::FSGNJX_D_INX:
13821 case RISCV::FSGNJX_H:
13822 case RISCV::FSGNJX_H_INX:
13823 case RISCV::FSGNJX_Q:
13824 case RISCV::FSGNJX_S:
13825 case RISCV::FSGNJX_S_INX:
13826 case RISCV::FSGNJ_D:
13827 case RISCV::FSGNJ_D_IN32X:
13828 case RISCV::FSGNJ_D_INX:
13829 case RISCV::FSGNJ_H:
13830 case RISCV::FSGNJ_H_INX:
13831 case RISCV::FSGNJ_Q:
13832 case RISCV::FSGNJ_S:
13833 case RISCV::FSGNJ_S_INX:
13834 case RISCV::MAX:
13835 case RISCV::MAXU:
13836 case RISCV::MIN:
13837 case RISCV::MINU:
13838 case RISCV::MOP_RR_0:
13839 case RISCV::MOP_RR_1:
13840 case RISCV::MOP_RR_2:
13841 case RISCV::MOP_RR_3:
13842 case RISCV::MOP_RR_4:
13843 case RISCV::MOP_RR_5:
13844 case RISCV::MOP_RR_6:
13845 case RISCV::MOP_RR_7:
13846 case RISCV::MSEQ:
13847 case RISCV::MSLT:
13848 case RISCV::MSLTU:
13849 case RISCV::MUL:
13850 case RISCV::MULH:
13851 case RISCV::MULHR:
13852 case RISCV::MULHRSU:
13853 case RISCV::MULHRU:
13854 case RISCV::MULHSU:
13855 case RISCV::MULHSU_H0:
13856 case RISCV::MULHSU_H1:
13857 case RISCV::MULHU:
13858 case RISCV::MULH_H0:
13859 case RISCV::MULH_H1:
13860 case RISCV::MULQ:
13861 case RISCV::MULQR:
13862 case RISCV::MULSU_H00:
13863 case RISCV::MULSU_H11:
13864 case RISCV::MULSU_W00:
13865 case RISCV::MULSU_W11:
13866 case RISCV::MULU_H00:
13867 case RISCV::MULU_H01:
13868 case RISCV::MULU_H11:
13869 case RISCV::MULU_W00:
13870 case RISCV::MULU_W01:
13871 case RISCV::MULU_W11:
13872 case RISCV::MULW:
13873 case RISCV::MUL_H00:
13874 case RISCV::MUL_H01:
13875 case RISCV::MUL_H11:
13876 case RISCV::MUL_W00:
13877 case RISCV::MUL_W01:
13878 case RISCV::MUL_W11:
13879 case RISCV::NDS_FFB:
13880 case RISCV::NDS_FFMISM:
13881 case RISCV::NDS_FFZMISM:
13882 case RISCV::NDS_FLMISM:
13883 case RISCV::OR:
13884 case RISCV::ORN:
13885 case RISCV::PAADDU_B:
13886 case RISCV::PAADDU_H:
13887 case RISCV::PAADDU_W:
13888 case RISCV::PAADD_B:
13889 case RISCV::PAADD_H:
13890 case RISCV::PAADD_W:
13891 case RISCV::PAAS_HX:
13892 case RISCV::PAAS_WX:
13893 case RISCV::PABDSUMU_B:
13894 case RISCV::PABDU_B:
13895 case RISCV::PABDU_H:
13896 case RISCV::PABD_B:
13897 case RISCV::PABD_H:
13898 case RISCV::PACK:
13899 case RISCV::PACKH:
13900 case RISCV::PACKW:
13901 case RISCV::PADD_B:
13902 case RISCV::PADD_BS:
13903 case RISCV::PADD_H:
13904 case RISCV::PADD_HS:
13905 case RISCV::PADD_W:
13906 case RISCV::PADD_WS:
13907 case RISCV::PASA_HX:
13908 case RISCV::PASA_WX:
13909 case RISCV::PASUBU_B:
13910 case RISCV::PASUBU_H:
13911 case RISCV::PASUBU_W:
13912 case RISCV::PASUB_B:
13913 case RISCV::PASUB_H:
13914 case RISCV::PASUB_W:
13915 case RISCV::PAS_HX:
13916 case RISCV::PAS_WX:
13917 case RISCV::PM2ADDSU_H:
13918 case RISCV::PM2ADDSU_W:
13919 case RISCV::PM2ADDU_H:
13920 case RISCV::PM2ADDU_W:
13921 case RISCV::PM2ADD_H:
13922 case RISCV::PM2ADD_HX:
13923 case RISCV::PM2ADD_W:
13924 case RISCV::PM2ADD_WX:
13925 case RISCV::PM2SADD_H:
13926 case RISCV::PM2SADD_HX:
13927 case RISCV::PM2SUB_H:
13928 case RISCV::PM2SUB_HX:
13929 case RISCV::PM2SUB_W:
13930 case RISCV::PM2SUB_WX:
13931 case RISCV::PM4ADDSU_B:
13932 case RISCV::PM4ADDSU_H:
13933 case RISCV::PM4ADDU_B:
13934 case RISCV::PM4ADDU_H:
13935 case RISCV::PM4ADD_B:
13936 case RISCV::PM4ADD_H:
13937 case RISCV::PMAXU_B:
13938 case RISCV::PMAXU_H:
13939 case RISCV::PMAXU_W:
13940 case RISCV::PMAX_B:
13941 case RISCV::PMAX_H:
13942 case RISCV::PMAX_W:
13943 case RISCV::PMINU_B:
13944 case RISCV::PMINU_H:
13945 case RISCV::PMINU_W:
13946 case RISCV::PMIN_B:
13947 case RISCV::PMIN_H:
13948 case RISCV::PMIN_W:
13949 case RISCV::PMQ2ADD_H:
13950 case RISCV::PMQ2ADD_W:
13951 case RISCV::PMQR2ADD_H:
13952 case RISCV::PMQR2ADD_W:
13953 case RISCV::PMSEQ_B:
13954 case RISCV::PMSEQ_H:
13955 case RISCV::PMSEQ_W:
13956 case RISCV::PMSLTU_B:
13957 case RISCV::PMSLTU_H:
13958 case RISCV::PMSLTU_W:
13959 case RISCV::PMSLT_B:
13960 case RISCV::PMSLT_H:
13961 case RISCV::PMSLT_W:
13962 case RISCV::PMULHRSU_H:
13963 case RISCV::PMULHRSU_W:
13964 case RISCV::PMULHRU_H:
13965 case RISCV::PMULHRU_W:
13966 case RISCV::PMULHR_H:
13967 case RISCV::PMULHR_W:
13968 case RISCV::PMULHSU_H:
13969 case RISCV::PMULHSU_H_B0:
13970 case RISCV::PMULHSU_H_B1:
13971 case RISCV::PMULHSU_W:
13972 case RISCV::PMULHSU_W_H0:
13973 case RISCV::PMULHSU_W_H1:
13974 case RISCV::PMULHU_H:
13975 case RISCV::PMULHU_W:
13976 case RISCV::PMULH_H:
13977 case RISCV::PMULH_H_B0:
13978 case RISCV::PMULH_H_B1:
13979 case RISCV::PMULH_W:
13980 case RISCV::PMULH_W_H0:
13981 case RISCV::PMULH_W_H1:
13982 case RISCV::PMULQR_H:
13983 case RISCV::PMULQR_W:
13984 case RISCV::PMULQ_H:
13985 case RISCV::PMULQ_W:
13986 case RISCV::PMULSU_H_B00:
13987 case RISCV::PMULSU_H_B11:
13988 case RISCV::PMULSU_W_H00:
13989 case RISCV::PMULSU_W_H11:
13990 case RISCV::PMULU_H_B00:
13991 case RISCV::PMULU_H_B01:
13992 case RISCV::PMULU_H_B11:
13993 case RISCV::PMULU_W_H00:
13994 case RISCV::PMULU_W_H01:
13995 case RISCV::PMULU_W_H11:
13996 case RISCV::PMUL_H_B00:
13997 case RISCV::PMUL_H_B01:
13998 case RISCV::PMUL_H_B11:
13999 case RISCV::PMUL_W_H00:
14000 case RISCV::PMUL_W_H01:
14001 case RISCV::PMUL_W_H11:
14002 case RISCV::PPAIREO_B:
14003 case RISCV::PPAIREO_H:
14004 case RISCV::PPAIREO_W:
14005 case RISCV::PPAIRE_B:
14006 case RISCV::PPAIRE_H:
14007 case RISCV::PPAIROE_B:
14008 case RISCV::PPAIROE_H:
14009 case RISCV::PPAIROE_W:
14010 case RISCV::PPAIRO_B:
14011 case RISCV::PPAIRO_H:
14012 case RISCV::PPAIRO_W:
14013 case RISCV::PREDSUMU_BS:
14014 case RISCV::PREDSUMU_HS:
14015 case RISCV::PREDSUMU_WS:
14016 case RISCV::PREDSUM_BS:
14017 case RISCV::PREDSUM_HS:
14018 case RISCV::PREDSUM_WS:
14019 case RISCV::PSADDU_B:
14020 case RISCV::PSADDU_H:
14021 case RISCV::PSADDU_W:
14022 case RISCV::PSADD_B:
14023 case RISCV::PSADD_H:
14024 case RISCV::PSADD_W:
14025 case RISCV::PSAS_HX:
14026 case RISCV::PSAS_WX:
14027 case RISCV::PSA_HX:
14028 case RISCV::PSA_WX:
14029 case RISCV::PSH1ADD_H:
14030 case RISCV::PSH1ADD_W:
14031 case RISCV::PSLL_BS:
14032 case RISCV::PSLL_HS:
14033 case RISCV::PSLL_WS:
14034 case RISCV::PSRA_BS:
14035 case RISCV::PSRA_HS:
14036 case RISCV::PSRA_WS:
14037 case RISCV::PSRL_BS:
14038 case RISCV::PSRL_HS:
14039 case RISCV::PSRL_WS:
14040 case RISCV::PSSA_HX:
14041 case RISCV::PSSA_WX:
14042 case RISCV::PSSH1SADD_H:
14043 case RISCV::PSSH1SADD_W:
14044 case RISCV::PSSHAR_HS:
14045 case RISCV::PSSHAR_WS:
14046 case RISCV::PSSHA_HS:
14047 case RISCV::PSSHA_WS:
14048 case RISCV::PSSUBU_B:
14049 case RISCV::PSSUBU_H:
14050 case RISCV::PSSUBU_W:
14051 case RISCV::PSSUB_B:
14052 case RISCV::PSSUB_H:
14053 case RISCV::PSSUB_W:
14054 case RISCV::PSUB_B:
14055 case RISCV::PSUB_H:
14056 case RISCV::PSUB_W:
14057 case RISCV::QC_ADDSAT:
14058 case RISCV::QC_ADDUSAT:
14059 case RISCV::QC_CSRRWR:
14060 case RISCV::QC_CSRRWRI:
14061 case RISCV::QC_EXTDPR:
14062 case RISCV::QC_EXTDPRH:
14063 case RISCV::QC_EXTDR:
14064 case RISCV::QC_EXTDUPR:
14065 case RISCV::QC_EXTDUPRH:
14066 case RISCV::QC_EXTDUR:
14067 case RISCV::QC_SHLSAT:
14068 case RISCV::QC_SHLUSAT:
14069 case RISCV::QC_SUBSAT:
14070 case RISCV::QC_SUBUSAT:
14071 case RISCV::QC_WRAP:
14072 case RISCV::REM:
14073 case RISCV::REMU:
14074 case RISCV::REMUW:
14075 case RISCV::REMW:
14076 case RISCV::ROL:
14077 case RISCV::ROLW:
14078 case RISCV::ROR:
14079 case RISCV::RORW:
14080 case RISCV::SADD:
14081 case RISCV::SADDU:
14082 case RISCV::SF_VFWMACC_4x4x4:
14083 case RISCV::SF_VQMACCSU_2x8x2:
14084 case RISCV::SF_VQMACCSU_4x8x4:
14085 case RISCV::SF_VQMACCUS_2x8x2:
14086 case RISCV::SF_VQMACCUS_4x8x4:
14087 case RISCV::SF_VQMACCU_2x8x2:
14088 case RISCV::SF_VQMACCU_4x8x4:
14089 case RISCV::SF_VQMACC_2x8x2:
14090 case RISCV::SF_VQMACC_4x8x4:
14091 case RISCV::SH1ADD:
14092 case RISCV::SH1ADD_UW:
14093 case RISCV::SH2ADD:
14094 case RISCV::SH2ADD_UW:
14095 case RISCV::SH3ADD:
14096 case RISCV::SH3ADD_UW:
14097 case RISCV::SHA:
14098 case RISCV::SHA512SIG0H:
14099 case RISCV::SHA512SIG0L:
14100 case RISCV::SHA512SIG1H:
14101 case RISCV::SHA512SIG1L:
14102 case RISCV::SHA512SUM0R:
14103 case RISCV::SHA512SUM1R:
14104 case RISCV::SHAR:
14105 case RISCV::SLL:
14106 case RISCV::SLLW:
14107 case RISCV::SLT:
14108 case RISCV::SLTU:
14109 case RISCV::SRA:
14110 case RISCV::SRAW:
14111 case RISCV::SRL:
14112 case RISCV::SRLW:
14113 case RISCV::SSH1SADD:
14114 case RISCV::SSHA:
14115 case RISCV::SSHAR:
14116 case RISCV::SSUB:
14117 case RISCV::SSUBU:
14118 case RISCV::SUB:
14119 case RISCV::SUBW:
14120 case RISCV::UNZIP16HP:
14121 case RISCV::UNZIP16P:
14122 case RISCV::UNZIP8HP:
14123 case RISCV::UNZIP8P:
14124 case RISCV::VSETVL:
14125 case RISCV::VT_MASKC:
14126 case RISCV::VT_MASKCN:
14127 case RISCV::XNOR:
14128 case RISCV::XOR:
14129 case RISCV::XPERM4:
14130 case RISCV::XPERM8:
14131 case RISCV::ZIP16HP:
14132 case RISCV::ZIP16P:
14133 case RISCV::ZIP8HP:
14134 case RISCV::ZIP8P: {
14135 switch (OpNum) {
14136 case 2:
14137 // op: rs2
14138 return 20;
14139 case 1:
14140 // op: rs1
14141 return 15;
14142 case 0:
14143 // op: rd
14144 return 7;
14145 }
14146 break;
14147 }
14148 case RISCV::PM2WADDSU_H:
14149 case RISCV::PM2WADDU_H:
14150 case RISCV::PM2WADD_H:
14151 case RISCV::PM2WADD_HX:
14152 case RISCV::PM2WSUB_H:
14153 case RISCV::PM2WSUB_HX:
14154 case RISCV::PWADDU_B:
14155 case RISCV::PWADDU_H:
14156 case RISCV::PWADD_B:
14157 case RISCV::PWADD_H:
14158 case RISCV::PWMULSU_B:
14159 case RISCV::PWMULSU_H:
14160 case RISCV::PWMULU_B:
14161 case RISCV::PWMULU_H:
14162 case RISCV::PWMUL_B:
14163 case RISCV::PWMUL_H:
14164 case RISCV::PWSLA_BS:
14165 case RISCV::PWSLA_HS:
14166 case RISCV::PWSLL_BS:
14167 case RISCV::PWSLL_HS:
14168 case RISCV::PWSUBU_B:
14169 case RISCV::PWSUBU_H:
14170 case RISCV::PWSUB_B:
14171 case RISCV::PWSUB_H:
14172 case RISCV::WADD:
14173 case RISCV::WADDU:
14174 case RISCV::WMUL:
14175 case RISCV::WMULSU:
14176 case RISCV::WMULU:
14177 case RISCV::WSLA:
14178 case RISCV::WSLL:
14179 case RISCV::WSUB:
14180 case RISCV::WSUBU:
14181 case RISCV::WZIP16P:
14182 case RISCV::WZIP8P: {
14183 switch (OpNum) {
14184 case 2:
14185 // op: rs2
14186 return 20;
14187 case 1:
14188 // op: rs1
14189 return 15;
14190 case 0:
14191 // op: rd
14192 return 8;
14193 }
14194 break;
14195 }
14196 case RISCV::FADD_D:
14197 case RISCV::FADD_D_IN32X:
14198 case RISCV::FADD_D_INX:
14199 case RISCV::FADD_H:
14200 case RISCV::FADD_H_INX:
14201 case RISCV::FADD_Q:
14202 case RISCV::FADD_S:
14203 case RISCV::FADD_S_INX:
14204 case RISCV::FDIV_D:
14205 case RISCV::FDIV_D_IN32X:
14206 case RISCV::FDIV_D_INX:
14207 case RISCV::FDIV_H:
14208 case RISCV::FDIV_H_INX:
14209 case RISCV::FDIV_Q:
14210 case RISCV::FDIV_S:
14211 case RISCV::FDIV_S_INX:
14212 case RISCV::FMUL_D:
14213 case RISCV::FMUL_D_IN32X:
14214 case RISCV::FMUL_D_INX:
14215 case RISCV::FMUL_H:
14216 case RISCV::FMUL_H_INX:
14217 case RISCV::FMUL_Q:
14218 case RISCV::FMUL_S:
14219 case RISCV::FMUL_S_INX:
14220 case RISCV::FSUB_D:
14221 case RISCV::FSUB_D_IN32X:
14222 case RISCV::FSUB_D_INX:
14223 case RISCV::FSUB_H:
14224 case RISCV::FSUB_H_INX:
14225 case RISCV::FSUB_Q:
14226 case RISCV::FSUB_S:
14227 case RISCV::FSUB_S_INX: {
14228 switch (OpNum) {
14229 case 2:
14230 // op: rs2
14231 return 20;
14232 case 1:
14233 // op: rs1
14234 return 15;
14235 case 3:
14236 // op: frm
14237 return 12;
14238 case 0:
14239 // op: rd
14240 return 7;
14241 }
14242 break;
14243 }
14244 case RISCV::SF_VC_V_FV: {
14245 switch (OpNum) {
14246 case 2:
14247 // op: rs2
14248 return 20;
14249 case 3:
14250 // op: rs1
14251 return 15;
14252 case 0:
14253 // op: rd
14254 return 7;
14255 case 1:
14256 // op: funct6_lo1
14257 return 26;
14258 }
14259 break;
14260 }
14261 case RISCV::SF_VC_V_I:
14262 case RISCV::SF_VC_V_IV:
14263 case RISCV::SF_VC_V_VV:
14264 case RISCV::SF_VC_V_X:
14265 case RISCV::SF_VC_V_XV: {
14266 switch (OpNum) {
14267 case 2:
14268 // op: rs2
14269 return 20;
14270 case 3:
14271 // op: rs1
14272 return 15;
14273 case 0:
14274 // op: rd
14275 return 7;
14276 case 1:
14277 // op: funct6_lo2
14278 return 26;
14279 }
14280 break;
14281 }
14282 case RISCV::SF_VC_FV:
14283 case RISCV::SF_VC_FVV:
14284 case RISCV::SF_VC_FVW: {
14285 switch (OpNum) {
14286 case 2:
14287 // op: rs2
14288 return 20;
14289 case 3:
14290 // op: rs1
14291 return 15;
14292 case 1:
14293 // op: rd
14294 return 7;
14295 case 0:
14296 // op: funct6_lo1
14297 return 26;
14298 }
14299 break;
14300 }
14301 case RISCV::SF_VC_IV:
14302 case RISCV::SF_VC_IVV:
14303 case RISCV::SF_VC_IVW:
14304 case RISCV::SF_VC_VV:
14305 case RISCV::SF_VC_VVV:
14306 case RISCV::SF_VC_VVW:
14307 case RISCV::SF_VC_XV:
14308 case RISCV::SF_VC_XVV:
14309 case RISCV::SF_VC_XVW: {
14310 switch (OpNum) {
14311 case 2:
14312 // op: rs2
14313 return 20;
14314 case 3:
14315 // op: rs1
14316 return 15;
14317 case 1:
14318 // op: rd
14319 return 7;
14320 case 0:
14321 // op: funct6_lo2
14322 return 26;
14323 }
14324 break;
14325 }
14326 case RISCV::AMOCAS_B:
14327 case RISCV::AMOCAS_B_AQ:
14328 case RISCV::AMOCAS_B_AQRL:
14329 case RISCV::AMOCAS_B_RL:
14330 case RISCV::AMOCAS_D_RV32:
14331 case RISCV::AMOCAS_D_RV32_AQ:
14332 case RISCV::AMOCAS_D_RV32_AQRL:
14333 case RISCV::AMOCAS_D_RV32_RL:
14334 case RISCV::AMOCAS_D_RV64:
14335 case RISCV::AMOCAS_D_RV64_AQ:
14336 case RISCV::AMOCAS_D_RV64_AQRL:
14337 case RISCV::AMOCAS_D_RV64_RL:
14338 case RISCV::AMOCAS_H:
14339 case RISCV::AMOCAS_H_AQ:
14340 case RISCV::AMOCAS_H_AQRL:
14341 case RISCV::AMOCAS_H_RL:
14342 case RISCV::AMOCAS_Q:
14343 case RISCV::AMOCAS_Q_AQ:
14344 case RISCV::AMOCAS_Q_AQRL:
14345 case RISCV::AMOCAS_Q_RL:
14346 case RISCV::AMOCAS_W:
14347 case RISCV::AMOCAS_W_AQ:
14348 case RISCV::AMOCAS_W_AQRL:
14349 case RISCV::AMOCAS_W_RL: {
14350 switch (OpNum) {
14351 case 2:
14352 // op: rs2
14353 return 20;
14354 case 3:
14355 // op: rs1
14356 return 15;
14357 case 1:
14358 // op: rd
14359 return 7;
14360 }
14361 break;
14362 }
14363 case RISCV::C_ADDW:
14364 case RISCV::C_AND:
14365 case RISCV::C_MUL:
14366 case RISCV::C_OR:
14367 case RISCV::C_SUB:
14368 case RISCV::C_SUBW:
14369 case RISCV::C_XOR: {
14370 switch (OpNum) {
14371 case 2:
14372 // op: rs2
14373 return 2;
14374 case 1:
14375 // op: rd
14376 return 7;
14377 }
14378 break;
14379 }
14380 case RISCV::NDS_VD4DOTSU_VV:
14381 case RISCV::NDS_VD4DOTS_VV:
14382 case RISCV::NDS_VD4DOTU_VV: {
14383 switch (OpNum) {
14384 case 2:
14385 // op: vs2
14386 return 20;
14387 case 1:
14388 // op: vs1
14389 return 15;
14390 case 0:
14391 // op: vd
14392 return 7;
14393 case 3:
14394 // op: vm
14395 return 25;
14396 }
14397 break;
14398 }
14399 case RISCV::AIF_MASKPOPC_ET_RAST: {
14400 switch (OpNum) {
14401 case 3:
14402 // op: imm
14403 return 18;
14404 case 2:
14405 // op: rs2
14406 return 20;
14407 case 1:
14408 // op: rs1
14409 return 15;
14410 case 0:
14411 // op: rd
14412 return 7;
14413 }
14414 break;
14415 }
14416 case RISCV::RI_VINSERT: {
14417 switch (OpNum) {
14418 case 3:
14419 // op: imm
14420 return 20;
14421 case 2:
14422 // op: rs1
14423 return 15;
14424 case 1:
14425 // op: vd
14426 return 7;
14427 }
14428 break;
14429 }
14430 case RISCV::CV_SB_ri_inc:
14431 case RISCV::CV_SH_ri_inc:
14432 case RISCV::CV_SW_ri_inc: {
14433 switch (OpNum) {
14434 case 3:
14435 // op: imm12
14436 return 7;
14437 case 1:
14438 // op: rs2
14439 return 20;
14440 case 2:
14441 // op: rs1
14442 return 15;
14443 }
14444 break;
14445 }
14446 case RISCV::MIPS_SDP: {
14447 switch (OpNum) {
14448 case 3:
14449 // op: imm7
14450 return 10;
14451 case 1:
14452 // op: rs3
14453 return 27;
14454 case 0:
14455 // op: rs2
14456 return 20;
14457 case 2:
14458 // op: rs1
14459 return 15;
14460 }
14461 break;
14462 }
14463 case RISCV::MIPS_LWP: {
14464 switch (OpNum) {
14465 case 3:
14466 // op: imm7
14467 return 22;
14468 case 2:
14469 // op: rs1
14470 return 15;
14471 case 0:
14472 // op: rd1
14473 return 7;
14474 case 1:
14475 // op: rd2
14476 return 27;
14477 }
14478 break;
14479 }
14480 case RISCV::MIPS_LDP: {
14481 switch (OpNum) {
14482 case 3:
14483 // op: imm7
14484 return 23;
14485 case 2:
14486 // op: rs1
14487 return 15;
14488 case 0:
14489 // op: rd1
14490 return 7;
14491 case 1:
14492 // op: rd2
14493 return 27;
14494 }
14495 break;
14496 }
14497 case RISCV::MIPS_SWP: {
14498 switch (OpNum) {
14499 case 3:
14500 // op: imm7
14501 return 9;
14502 case 1:
14503 // op: rs3
14504 return 27;
14505 case 0:
14506 // op: rs2
14507 return 20;
14508 case 2:
14509 // op: rs1
14510 return 15;
14511 }
14512 break;
14513 }
14514 case RISCV::QC_SELECTIEQI:
14515 case RISCV::QC_SELECTINEI: {
14516 switch (OpNum) {
14517 case 3:
14518 // op: rs2
14519 return 20;
14520 case 1:
14521 // op: rd
14522 return 7;
14523 case 2:
14524 // op: imm
14525 return 15;
14526 case 4:
14527 // op: simm2
14528 return 27;
14529 }
14530 break;
14531 }
14532 case RISCV::CV_LBU_rr_inc:
14533 case RISCV::CV_LB_rr_inc:
14534 case RISCV::CV_LHU_rr_inc:
14535 case RISCV::CV_LH_rr_inc:
14536 case RISCV::CV_LW_rr_inc: {
14537 switch (OpNum) {
14538 case 3:
14539 // op: rs2
14540 return 20;
14541 case 2:
14542 // op: rs1
14543 return 15;
14544 case 0:
14545 // op: rd
14546 return 7;
14547 }
14548 break;
14549 }
14550 case RISCV::CV_MACHHSN:
14551 case RISCV::CV_MACHHSRN:
14552 case RISCV::CV_MACHHUN:
14553 case RISCV::CV_MACHHURN:
14554 case RISCV::CV_MACSN:
14555 case RISCV::CV_MACSRN:
14556 case RISCV::CV_MACUN:
14557 case RISCV::CV_MACURN: {
14558 switch (OpNum) {
14559 case 3:
14560 // op: rs2
14561 return 20;
14562 case 2:
14563 // op: rs1
14564 return 15;
14565 case 1:
14566 // op: rd
14567 return 7;
14568 case 4:
14569 // op: imm5
14570 return 25;
14571 }
14572 break;
14573 }
14574 case RISCV::QC_LIEQ:
14575 case RISCV::QC_LIEQI:
14576 case RISCV::QC_LIGE:
14577 case RISCV::QC_LIGEI:
14578 case RISCV::QC_LIGEU:
14579 case RISCV::QC_LIGEUI:
14580 case RISCV::QC_LILT:
14581 case RISCV::QC_LILTI:
14582 case RISCV::QC_LILTU:
14583 case RISCV::QC_LILTUI:
14584 case RISCV::QC_LINE:
14585 case RISCV::QC_LINEI: {
14586 switch (OpNum) {
14587 case 3:
14588 // op: rs2
14589 return 20;
14590 case 2:
14591 // op: rs1
14592 return 15;
14593 case 1:
14594 // op: rd
14595 return 7;
14596 case 4:
14597 // op: simm
14598 return 27;
14599 }
14600 break;
14601 }
14602 case RISCV::QC_SELECTIEQ:
14603 case RISCV::QC_SELECTINE: {
14604 switch (OpNum) {
14605 case 3:
14606 // op: rs2
14607 return 20;
14608 case 2:
14609 // op: rs1
14610 return 15;
14611 case 1:
14612 // op: rd
14613 return 7;
14614 case 4:
14615 // op: simm2
14616 return 27;
14617 }
14618 break;
14619 }
14620 case RISCV::CV_ADDNR:
14621 case RISCV::CV_ADDRNR:
14622 case RISCV::CV_ADDUNR:
14623 case RISCV::CV_ADDURNR:
14624 case RISCV::CV_CPLXMUL_I:
14625 case RISCV::CV_CPLXMUL_I_DIV2:
14626 case RISCV::CV_CPLXMUL_I_DIV4:
14627 case RISCV::CV_CPLXMUL_I_DIV8:
14628 case RISCV::CV_CPLXMUL_R:
14629 case RISCV::CV_CPLXMUL_R_DIV2:
14630 case RISCV::CV_CPLXMUL_R_DIV4:
14631 case RISCV::CV_CPLXMUL_R_DIV8:
14632 case RISCV::CV_INSERTR:
14633 case RISCV::CV_MAC:
14634 case RISCV::CV_MSU:
14635 case RISCV::CV_PACKHI_B:
14636 case RISCV::CV_PACKLO_B:
14637 case RISCV::CV_SDOTSP_B:
14638 case RISCV::CV_SDOTSP_H:
14639 case RISCV::CV_SDOTSP_SC_B:
14640 case RISCV::CV_SDOTSP_SC_H:
14641 case RISCV::CV_SDOTUP_B:
14642 case RISCV::CV_SDOTUP_H:
14643 case RISCV::CV_SDOTUP_SC_B:
14644 case RISCV::CV_SDOTUP_SC_H:
14645 case RISCV::CV_SDOTUSP_B:
14646 case RISCV::CV_SDOTUSP_H:
14647 case RISCV::CV_SDOTUSP_SC_B:
14648 case RISCV::CV_SDOTUSP_SC_H:
14649 case RISCV::CV_SHUFFLE2_B:
14650 case RISCV::CV_SHUFFLE2_H:
14651 case RISCV::CV_SUBNR:
14652 case RISCV::CV_SUBRNR:
14653 case RISCV::CV_SUBUNR:
14654 case RISCV::CV_SUBURNR:
14655 case RISCV::MACCSU_H00:
14656 case RISCV::MACCSU_H11:
14657 case RISCV::MACCSU_W00:
14658 case RISCV::MACCSU_W11:
14659 case RISCV::MACCU_H00:
14660 case RISCV::MACCU_H01:
14661 case RISCV::MACCU_H11:
14662 case RISCV::MACCU_W00:
14663 case RISCV::MACCU_W01:
14664 case RISCV::MACCU_W11:
14665 case RISCV::MACC_H00:
14666 case RISCV::MACC_H01:
14667 case RISCV::MACC_H11:
14668 case RISCV::MACC_W00:
14669 case RISCV::MACC_W01:
14670 case RISCV::MACC_W11:
14671 case RISCV::MERGE:
14672 case RISCV::MHACC:
14673 case RISCV::MHACCSU:
14674 case RISCV::MHACCSU_H0:
14675 case RISCV::MHACCSU_H1:
14676 case RISCV::MHACCU:
14677 case RISCV::MHACC_H0:
14678 case RISCV::MHACC_H1:
14679 case RISCV::MHRACC:
14680 case RISCV::MHRACCSU:
14681 case RISCV::MHRACCU:
14682 case RISCV::MQACC_H00:
14683 case RISCV::MQACC_H01:
14684 case RISCV::MQACC_H11:
14685 case RISCV::MQACC_W00:
14686 case RISCV::MQACC_W01:
14687 case RISCV::MQACC_W11:
14688 case RISCV::MQRACC_H00:
14689 case RISCV::MQRACC_H01:
14690 case RISCV::MQRACC_H11:
14691 case RISCV::MQRACC_W00:
14692 case RISCV::MQRACC_W01:
14693 case RISCV::MQRACC_W11:
14694 case RISCV::MVM:
14695 case RISCV::MVMN:
14696 case RISCV::PABDSUMAU_B:
14697 case RISCV::PM2ADDASU_H:
14698 case RISCV::PM2ADDASU_W:
14699 case RISCV::PM2ADDAU_H:
14700 case RISCV::PM2ADDAU_W:
14701 case RISCV::PM2ADDA_H:
14702 case RISCV::PM2ADDA_HX:
14703 case RISCV::PM2ADDA_W:
14704 case RISCV::PM2ADDA_WX:
14705 case RISCV::PM2SUBA_H:
14706 case RISCV::PM2SUBA_HX:
14707 case RISCV::PM2SUBA_W:
14708 case RISCV::PM2SUBA_WX:
14709 case RISCV::PM4ADDASU_B:
14710 case RISCV::PM4ADDASU_H:
14711 case RISCV::PM4ADDAU_B:
14712 case RISCV::PM4ADDAU_H:
14713 case RISCV::PM4ADDA_B:
14714 case RISCV::PM4ADDA_H:
14715 case RISCV::PMACCSU_W_H00:
14716 case RISCV::PMACCSU_W_H11:
14717 case RISCV::PMACCU_W_H00:
14718 case RISCV::PMACCU_W_H01:
14719 case RISCV::PMACCU_W_H11:
14720 case RISCV::PMACC_W_H00:
14721 case RISCV::PMACC_W_H01:
14722 case RISCV::PMACC_W_H11:
14723 case RISCV::PMHACCSU_H:
14724 case RISCV::PMHACCSU_H_B0:
14725 case RISCV::PMHACCSU_H_B1:
14726 case RISCV::PMHACCSU_W:
14727 case RISCV::PMHACCSU_W_H0:
14728 case RISCV::PMHACCSU_W_H1:
14729 case RISCV::PMHACCU_H:
14730 case RISCV::PMHACCU_W:
14731 case RISCV::PMHACC_H:
14732 case RISCV::PMHACC_H_B0:
14733 case RISCV::PMHACC_H_B1:
14734 case RISCV::PMHACC_W:
14735 case RISCV::PMHACC_W_H0:
14736 case RISCV::PMHACC_W_H1:
14737 case RISCV::PMHRACCSU_H:
14738 case RISCV::PMHRACCSU_W:
14739 case RISCV::PMHRACCU_H:
14740 case RISCV::PMHRACCU_W:
14741 case RISCV::PMHRACC_H:
14742 case RISCV::PMHRACC_W:
14743 case RISCV::PMQ2ADDA_H:
14744 case RISCV::PMQ2ADDA_W:
14745 case RISCV::PMQACC_W_H00:
14746 case RISCV::PMQACC_W_H01:
14747 case RISCV::PMQACC_W_H11:
14748 case RISCV::PMQR2ADDA_H:
14749 case RISCV::PMQR2ADDA_W:
14750 case RISCV::PMQRACC_W_H00:
14751 case RISCV::PMQRACC_W_H01:
14752 case RISCV::PMQRACC_W_H11:
14753 case RISCV::QC_INSBHR:
14754 case RISCV::QC_INSBPR:
14755 case RISCV::QC_INSBPRH:
14756 case RISCV::QC_INSBR:
14757 case RISCV::SLX:
14758 case RISCV::SRX:
14759 case RISCV::TH_MULA:
14760 case RISCV::TH_MULAH:
14761 case RISCV::TH_MULAW:
14762 case RISCV::TH_MULS:
14763 case RISCV::TH_MULSH:
14764 case RISCV::TH_MULSW:
14765 case RISCV::TH_MVEQZ:
14766 case RISCV::TH_MVNEZ: {
14767 switch (OpNum) {
14768 case 3:
14769 // op: rs2
14770 return 20;
14771 case 2:
14772 // op: rs1
14773 return 15;
14774 case 1:
14775 // op: rd
14776 return 7;
14777 }
14778 break;
14779 }
14780 case RISCV::MQRWACC:
14781 case RISCV::MQWACC:
14782 case RISCV::PM2WADDASU_H:
14783 case RISCV::PM2WADDAU_H:
14784 case RISCV::PM2WADDA_H:
14785 case RISCV::PM2WADDA_HX:
14786 case RISCV::PM2WSUBA_H:
14787 case RISCV::PM2WSUBA_HX:
14788 case RISCV::PMQRWACC_H:
14789 case RISCV::PMQWACC_H:
14790 case RISCV::PWADDAU_B:
14791 case RISCV::PWADDAU_H:
14792 case RISCV::PWADDA_B:
14793 case RISCV::PWADDA_H:
14794 case RISCV::PWMACCSU_H:
14795 case RISCV::PWMACCU_H:
14796 case RISCV::PWMACC_H:
14797 case RISCV::PWSUBAU_B:
14798 case RISCV::PWSUBAU_H:
14799 case RISCV::PWSUBA_B:
14800 case RISCV::PWSUBA_H:
14801 case RISCV::WADDA:
14802 case RISCV::WADDAU:
14803 case RISCV::WMACC:
14804 case RISCV::WMACCSU:
14805 case RISCV::WMACCU:
14806 case RISCV::WSUBA:
14807 case RISCV::WSUBAU: {
14808 switch (OpNum) {
14809 case 3:
14810 // op: rs2
14811 return 20;
14812 case 2:
14813 // op: rs1
14814 return 15;
14815 case 1:
14816 // op: rd
14817 return 8;
14818 }
14819 break;
14820 }
14821 case RISCV::SF_VC_V_FVV:
14822 case RISCV::SF_VC_V_FVW: {
14823 switch (OpNum) {
14824 case 3:
14825 // op: rs2
14826 return 20;
14827 case 4:
14828 // op: rs1
14829 return 15;
14830 case 2:
14831 // op: rd
14832 return 7;
14833 case 1:
14834 // op: funct6_lo1
14835 return 26;
14836 }
14837 break;
14838 }
14839 case RISCV::SF_VC_V_IVV:
14840 case RISCV::SF_VC_V_IVW:
14841 case RISCV::SF_VC_V_VVV:
14842 case RISCV::SF_VC_V_VVW:
14843 case RISCV::SF_VC_V_XVV:
14844 case RISCV::SF_VC_V_XVW: {
14845 switch (OpNum) {
14846 case 3:
14847 // op: rs2
14848 return 20;
14849 case 4:
14850 // op: rs1
14851 return 15;
14852 case 2:
14853 // op: rd
14854 return 7;
14855 case 1:
14856 // op: funct6_lo2
14857 return 26;
14858 }
14859 break;
14860 }
14861 case RISCV::MIPS_CCMOV: {
14862 switch (OpNum) {
14863 case 3:
14864 // op: rs3
14865 return 27;
14866 case 2:
14867 // op: rs2
14868 return 20;
14869 case 1:
14870 // op: rs1
14871 return 15;
14872 case 0:
14873 // op: rd
14874 return 7;
14875 }
14876 break;
14877 }
14878 case RISCV::FMADD_D:
14879 case RISCV::FMADD_D_IN32X:
14880 case RISCV::FMADD_D_INX:
14881 case RISCV::FMADD_H:
14882 case RISCV::FMADD_H_INX:
14883 case RISCV::FMADD_Q:
14884 case RISCV::FMADD_S:
14885 case RISCV::FMADD_S_INX:
14886 case RISCV::FMSUB_D:
14887 case RISCV::FMSUB_D_IN32X:
14888 case RISCV::FMSUB_D_INX:
14889 case RISCV::FMSUB_H:
14890 case RISCV::FMSUB_H_INX:
14891 case RISCV::FMSUB_Q:
14892 case RISCV::FMSUB_S:
14893 case RISCV::FMSUB_S_INX:
14894 case RISCV::FNMADD_D:
14895 case RISCV::FNMADD_D_IN32X:
14896 case RISCV::FNMADD_D_INX:
14897 case RISCV::FNMADD_H:
14898 case RISCV::FNMADD_H_INX:
14899 case RISCV::FNMADD_Q:
14900 case RISCV::FNMADD_S:
14901 case RISCV::FNMADD_S_INX:
14902 case RISCV::FNMSUB_D:
14903 case RISCV::FNMSUB_D_IN32X:
14904 case RISCV::FNMSUB_D_INX:
14905 case RISCV::FNMSUB_H:
14906 case RISCV::FNMSUB_H_INX:
14907 case RISCV::FNMSUB_Q:
14908 case RISCV::FNMSUB_S:
14909 case RISCV::FNMSUB_S_INX: {
14910 switch (OpNum) {
14911 case 3:
14912 // op: rs3
14913 return 27;
14914 case 2:
14915 // op: rs2
14916 return 20;
14917 case 1:
14918 // op: rs1
14919 return 15;
14920 case 4:
14921 // op: frm
14922 return 12;
14923 case 0:
14924 // op: rd
14925 return 7;
14926 }
14927 break;
14928 }
14929 case RISCV::CV_SB_rr_inc:
14930 case RISCV::CV_SH_rr_inc:
14931 case RISCV::CV_SW_rr_inc: {
14932 switch (OpNum) {
14933 case 3:
14934 // op: rs3
14935 return 7;
14936 case 1:
14937 // op: rs2
14938 return 20;
14939 case 2:
14940 // op: rs1
14941 return 15;
14942 }
14943 break;
14944 }
14945 case RISCV::QC_MVEQI:
14946 case RISCV::QC_MVGEI:
14947 case RISCV::QC_MVGEUI:
14948 case RISCV::QC_MVLTI:
14949 case RISCV::QC_MVLTUI:
14950 case RISCV::QC_MVNEI: {
14951 switch (OpNum) {
14952 case 4:
14953 // op: rs3
14954 return 27;
14955 case 2:
14956 // op: rs1
14957 return 15;
14958 case 1:
14959 // op: rd
14960 return 7;
14961 case 3:
14962 // op: imm
14963 return 20;
14964 }
14965 break;
14966 }
14967 case RISCV::QC_SELECTEQI:
14968 case RISCV::QC_SELECTNEI: {
14969 switch (OpNum) {
14970 case 4:
14971 // op: rs3
14972 return 27;
14973 case 3:
14974 // op: rs2
14975 return 20;
14976 case 1:
14977 // op: rd
14978 return 7;
14979 case 2:
14980 // op: imm
14981 return 15;
14982 }
14983 break;
14984 }
14985 case RISCV::QC_MVEQ:
14986 case RISCV::QC_MVGE:
14987 case RISCV::QC_MVGEU:
14988 case RISCV::QC_MVLT:
14989 case RISCV::QC_MVLTU:
14990 case RISCV::QC_MVNE: {
14991 switch (OpNum) {
14992 case 4:
14993 // op: rs3
14994 return 27;
14995 case 3:
14996 // op: rs2
14997 return 20;
14998 case 2:
14999 // op: rs1
15000 return 15;
15001 case 1:
15002 // op: rd
15003 return 7;
15004 }
15005 break;
15006 }
15007 default:
15008 reportUnsupportedInst(MI);
15009 }
15010 reportUnsupportedOperand(MI, OpNum);
15011}
15012
15013#endif // GET_OPERAND_BIT_OFFSET
15014
15015