Coverage Report

Created: 2026-01-12 07:13

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/capstonev5/arch/RISCV/RISCVGenAsmWriter.inc
Line
Count
Source
1
/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
2
|*                                                                            *|
3
|* Assembly Writer Source Fragment                                            *|
4
|*                                                                            *|
5
|* Automatically generated file, do not edit!                                 *|
6
|*                                                                            *|
7
\*===----------------------------------------------------------------------===*/
8
9
/* Capstone Disassembly Engine */
10
/* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2015 */
11
12
#include <stdio.h>  // debug
13
#include <capstone/platform.h>
14
#include <assert.h>
15
16
17
/// printInstruction - This method is automatically generated by tablegen
18
/// from the instruction set description.
19
static void printInstruction(MCInst *MI, SStream *O, MCRegisterInfo *MRI)
20
84.2k
{
21
84.2k
#ifndef CAPSTONE_DIET
22
84.2k
  static const char AsmStrs[] = {
23
84.2k
  /* 0 */ 'l', 'l', 'a', 9, 0,
24
84.2k
  /* 5 */ 's', 'f', 'e', 'n', 'c', 'e', '.', 'v', 'm', 'a', 9, 0,
25
84.2k
  /* 17 */ 's', 'r', 'a', 9, 0,
26
84.2k
  /* 22 */ 'l', 'b', 9, 0,
27
84.2k
  /* 26 */ 's', 'b', 9, 0,
28
84.2k
  /* 30 */ 'c', '.', 's', 'u', 'b', 9, 0,
29
84.2k
  /* 37 */ 'a', 'u', 'i', 'p', 'c', 9, 0,
30
84.2k
  /* 44 */ 'c', 's', 'r', 'r', 'c', 9, 0,
31
84.2k
  /* 51 */ 'f', 's', 'u', 'b', '.', 'd', 9, 0,
32
84.2k
  /* 59 */ 'f', 'm', 's', 'u', 'b', '.', 'd', 9, 0,
33
84.2k
  /* 68 */ 'f', 'n', 'm', 's', 'u', 'b', '.', 'd', 9, 0,
34
84.2k
  /* 78 */ 's', 'c', '.', 'd', 9, 0,
35
84.2k
  /* 84 */ 'f', 'a', 'd', 'd', '.', 'd', 9, 0,
36
84.2k
  /* 92 */ 'f', 'm', 'a', 'd', 'd', '.', 'd', 9, 0,
37
84.2k
  /* 101 */ 'f', 'n', 'm', 'a', 'd', 'd', '.', 'd', 9, 0,
38
84.2k
  /* 111 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'd', 9, 0,
39
84.2k
  /* 121 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'd', 9, 0,
40
84.2k
  /* 131 */ 'f', 'l', 'e', '.', 'd', 9, 0,
41
84.2k
  /* 138 */ 'f', 's', 'g', 'n', 'j', '.', 'd', 9, 0,
42
84.2k
  /* 147 */ 'f', 'c', 'v', 't', '.', 'l', '.', 'd', 9, 0,
43
84.2k
  /* 157 */ 'f', 'm', 'u', 'l', '.', 'd', 9, 0,
44
84.2k
  /* 165 */ 'f', 'm', 'i', 'n', '.', 'd', 9, 0,
45
84.2k
  /* 173 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'd', 9, 0,
46
84.2k
  /* 183 */ 'f', 's', 'g', 'n', 'j', 'n', '.', 'd', 9, 0,
47
84.2k
  /* 193 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'd', 9, 0,
48
84.2k
  /* 204 */ 'f', 'e', 'q', '.', 'd', 9, 0,
49
84.2k
  /* 211 */ 'l', 'r', '.', 'd', 9, 0,
50
84.2k
  /* 217 */ 'a', 'm', 'o', 'o', 'r', '.', 'd', 9, 0,
51
84.2k
  /* 226 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'd', 9, 0,
52
84.2k
  /* 236 */ 'f', 'c', 'v', 't', '.', 's', '.', 'd', 9, 0,
53
84.2k
  /* 246 */ 'f', 'c', 'l', 'a', 's', 's', '.', 'd', 9, 0,
54
84.2k
  /* 256 */ 'f', 'l', 't', '.', 'd', 9, 0,
55
84.2k
  /* 263 */ 'f', 's', 'q', 'r', 't', '.', 'd', 9, 0,
56
84.2k
  /* 272 */ 'f', 'c', 'v', 't', '.', 'l', 'u', '.', 'd', 9, 0,
57
84.2k
  /* 283 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'd', 9, 0,
58
84.2k
  /* 294 */ 'f', 'c', 'v', 't', '.', 'w', 'u', '.', 'd', 9, 0,
59
84.2k
  /* 305 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'd', 9, 0,
60
84.2k
  /* 316 */ 'f', 'd', 'i', 'v', '.', 'd', 9, 0,
61
84.2k
  /* 324 */ 'f', 'c', 'v', 't', '.', 'w', '.', 'd', 9, 0,
62
84.2k
  /* 334 */ 'f', 'm', 'v', '.', 'x', '.', 'd', 9, 0,
63
84.2k
  /* 343 */ 'f', 'm', 'a', 'x', '.', 'd', 9, 0,
64
84.2k
  /* 351 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'd', 9, 0,
65
84.2k
  /* 361 */ 'f', 's', 'g', 'n', 'j', 'x', '.', 'd', 9, 0,
66
84.2k
  /* 371 */ 'c', '.', 'a', 'd', 'd', 9, 0,
67
84.2k
  /* 378 */ 'c', '.', 'l', 'd', 9, 0,
68
84.2k
  /* 384 */ 'c', '.', 'f', 'l', 'd', 9, 0,
69
84.2k
  /* 391 */ 'c', '.', 'a', 'n', 'd', 9, 0,
70
84.2k
  /* 398 */ 'c', '.', 's', 'd', 9, 0,
71
84.2k
  /* 404 */ 'c', '.', 'f', 's', 'd', 9, 0,
72
84.2k
  /* 411 */ 'f', 'e', 'n', 'c', 'e', 9, 0,
73
84.2k
  /* 418 */ 'b', 'g', 'e', 9, 0,
74
84.2k
  /* 423 */ 'b', 'n', 'e', 9, 0,
75
84.2k
  /* 428 */ 'm', 'u', 'l', 'h', 9, 0,
76
84.2k
  /* 434 */ 's', 'h', 9, 0,
77
84.2k
  /* 438 */ 'f', 'e', 'n', 'c', 'e', '.', 'i', 9, 0,
78
84.2k
  /* 447 */ 'c', '.', 's', 'r', 'a', 'i', 9, 0,
79
84.2k
  /* 455 */ 'c', 's', 'r', 'r', 'c', 'i', 9, 0,
80
84.2k
  /* 463 */ 'c', '.', 'a', 'd', 'd', 'i', 9, 0,
81
84.2k
  /* 471 */ 'c', '.', 'a', 'n', 'd', 'i', 9, 0,
82
84.2k
  /* 479 */ 'w', 'f', 'i', 9, 0,
83
84.2k
  /* 484 */ 'c', '.', 'l', 'i', 9, 0,
84
84.2k
  /* 490 */ 'c', '.', 's', 'l', 'l', 'i', 9, 0,
85
84.2k
  /* 498 */ 'c', '.', 's', 'r', 'l', 'i', 9, 0,
86
84.2k
  /* 506 */ 'x', 'o', 'r', 'i', 9, 0,
87
84.2k
  /* 512 */ 'c', 's', 'r', 'r', 's', 'i', 9, 0,
88
84.2k
  /* 520 */ 's', 'l', 't', 'i', 9, 0,
89
84.2k
  /* 526 */ 'c', '.', 'l', 'u', 'i', 9, 0,
90
84.2k
  /* 533 */ 'c', 's', 'r', 'r', 'w', 'i', 9, 0,
91
84.2k
  /* 541 */ 'c', '.', 'j', 9, 0,
92
84.2k
  /* 546 */ 'c', '.', 'e', 'b', 'r', 'e', 'a', 'k', 9, 0,
93
84.2k
  /* 556 */ 'f', 'c', 'v', 't', '.', 'd', '.', 'l', 9, 0,
94
84.2k
  /* 566 */ 'f', 'c', 'v', 't', '.', 's', '.', 'l', 9, 0,
95
84.2k
  /* 576 */ 'c', '.', 'j', 'a', 'l', 9, 0,
96
84.2k
  /* 583 */ 't', 'a', 'i', 'l', 9, 0,
97
84.2k
  /* 589 */ 'e', 'c', 'a', 'l', 'l', 9, 0,
98
84.2k
  /* 596 */ 's', 'l', 'l', 9, 0,
99
84.2k
  /* 601 */ 's', 'c', '.', 'd', '.', 'r', 'l', 9, 0,
100
84.2k
  /* 610 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'd', '.', 'r', 'l', 9, 0,
101
84.2k
  /* 623 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'd', '.', 'r', 'l', 9, 0,
102
84.2k
  /* 636 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'd', '.', 'r', 'l', 9, 0,
103
84.2k
  /* 649 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'd', '.', 'r', 'l', 9, 0,
104
84.2k
  /* 663 */ 'l', 'r', '.', 'd', '.', 'r', 'l', 9, 0,
105
84.2k
  /* 672 */ 'a', 'm', 'o', 'o', 'r', '.', 'd', '.', 'r', 'l', 9, 0,
106
84.2k
  /* 684 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'd', '.', 'r', 'l', 9, 0,
107
84.2k
  /* 697 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'd', '.', 'r', 'l', 9, 0,
108
84.2k
  /* 711 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'd', '.', 'r', 'l', 9, 0,
109
84.2k
  /* 725 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'd', '.', 'r', 'l', 9, 0,
110
84.2k
  /* 738 */ 's', 'c', '.', 'w', '.', 'r', 'l', 9, 0,
111
84.2k
  /* 747 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'w', '.', 'r', 'l', 9, 0,
112
84.2k
  /* 760 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'w', '.', 'r', 'l', 9, 0,
113
84.2k
  /* 773 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'w', '.', 'r', 'l', 9, 0,
114
84.2k
  /* 786 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'w', '.', 'r', 'l', 9, 0,
115
84.2k
  /* 800 */ 'l', 'r', '.', 'w', '.', 'r', 'l', 9, 0,
116
84.2k
  /* 809 */ 'a', 'm', 'o', 'o', 'r', '.', 'w', '.', 'r', 'l', 9, 0,
117
84.2k
  /* 821 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'w', '.', 'r', 'l', 9, 0,
118
84.2k
  /* 834 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'w', '.', 'r', 'l', 9, 0,
119
84.2k
  /* 848 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'w', '.', 'r', 'l', 9, 0,
120
84.2k
  /* 862 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'w', '.', 'r', 'l', 9, 0,
121
84.2k
  /* 875 */ 's', 'c', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
122
84.2k
  /* 886 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
123
84.2k
  /* 901 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
124
84.2k
  /* 916 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
125
84.2k
  /* 931 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
126
84.2k
  /* 947 */ 'l', 'r', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
127
84.2k
  /* 958 */ 'a', 'm', 'o', 'o', 'r', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
128
84.2k
  /* 972 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
129
84.2k
  /* 987 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
130
84.2k
  /* 1003 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
131
84.2k
  /* 1019 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'd', '.', 'a', 'q', 'r', 'l', 9, 0,
132
84.2k
  /* 1034 */ 's', 'c', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
133
84.2k
  /* 1045 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
134
84.2k
  /* 1060 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
135
84.2k
  /* 1075 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
136
84.2k
  /* 1090 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
137
84.2k
  /* 1106 */ 'l', 'r', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
138
84.2k
  /* 1117 */ 'a', 'm', 'o', 'o', 'r', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
139
84.2k
  /* 1131 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
140
84.2k
  /* 1146 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
141
84.2k
  /* 1162 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
142
84.2k
  /* 1178 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'w', '.', 'a', 'q', 'r', 'l', 9, 0,
143
84.2k
  /* 1193 */ 's', 'r', 'l', 9, 0,
144
84.2k
  /* 1198 */ 'm', 'u', 'l', 9, 0,
145
84.2k
  /* 1203 */ 'r', 'e', 'm', 9, 0,
146
84.2k
  /* 1208 */ 'c', '.', 'a', 'd', 'd', 'i', '4', 's', 'p', 'n', 9, 0,
147
84.2k
  /* 1220 */ 'f', 'e', 'n', 'c', 'e', '.', 't', 's', 'o', 9, 0,
148
84.2k
  /* 1231 */ 'c', '.', 'u', 'n', 'i', 'm', 'p', 9, 0,
149
84.2k
  /* 1240 */ 'c', '.', 'n', 'o', 'p', 9, 0,
150
84.2k
  /* 1247 */ 'c', '.', 'a', 'd', 'd', 'i', '1', '6', 's', 'p', 9, 0,
151
84.2k
  /* 1259 */ 'c', '.', 'l', 'd', 's', 'p', 9, 0,
152
84.2k
  /* 1267 */ 'c', '.', 'f', 'l', 'd', 's', 'p', 9, 0,
153
84.2k
  /* 1276 */ 'c', '.', 's', 'd', 's', 'p', 9, 0,
154
84.2k
  /* 1284 */ 'c', '.', 'f', 's', 'd', 's', 'p', 9, 0,
155
84.2k
  /* 1293 */ 'c', '.', 'l', 'w', 's', 'p', 9, 0,
156
84.2k
  /* 1301 */ 'c', '.', 'f', 'l', 'w', 's', 'p', 9, 0,
157
84.2k
  /* 1310 */ 'c', '.', 's', 'w', 's', 'p', 9, 0,
158
84.2k
  /* 1318 */ 'c', '.', 'f', 's', 'w', 's', 'p', 9, 0,
159
84.2k
  /* 1327 */ 's', 'c', '.', 'd', '.', 'a', 'q', 9, 0,
160
84.2k
  /* 1336 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'd', '.', 'a', 'q', 9, 0,
161
84.2k
  /* 1349 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'd', '.', 'a', 'q', 9, 0,
162
84.2k
  /* 1362 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'd', '.', 'a', 'q', 9, 0,
163
84.2k
  /* 1375 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'd', '.', 'a', 'q', 9, 0,
164
84.2k
  /* 1389 */ 'l', 'r', '.', 'd', '.', 'a', 'q', 9, 0,
165
84.2k
  /* 1398 */ 'a', 'm', 'o', 'o', 'r', '.', 'd', '.', 'a', 'q', 9, 0,
166
84.2k
  /* 1410 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'd', '.', 'a', 'q', 9, 0,
167
84.2k
  /* 1423 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'd', '.', 'a', 'q', 9, 0,
168
84.2k
  /* 1437 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'd', '.', 'a', 'q', 9, 0,
169
84.2k
  /* 1451 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'd', '.', 'a', 'q', 9, 0,
170
84.2k
  /* 1464 */ 's', 'c', '.', 'w', '.', 'a', 'q', 9, 0,
171
84.2k
  /* 1473 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'w', '.', 'a', 'q', 9, 0,
172
84.2k
  /* 1486 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'w', '.', 'a', 'q', 9, 0,
173
84.2k
  /* 1499 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'w', '.', 'a', 'q', 9, 0,
174
84.2k
  /* 1512 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'w', '.', 'a', 'q', 9, 0,
175
84.2k
  /* 1526 */ 'l', 'r', '.', 'w', '.', 'a', 'q', 9, 0,
176
84.2k
  /* 1535 */ 'a', 'm', 'o', 'o', 'r', '.', 'w', '.', 'a', 'q', 9, 0,
177
84.2k
  /* 1547 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'w', '.', 'a', 'q', 9, 0,
178
84.2k
  /* 1560 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'w', '.', 'a', 'q', 9, 0,
179
84.2k
  /* 1574 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'w', '.', 'a', 'q', 9, 0,
180
84.2k
  /* 1588 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'w', '.', 'a', 'q', 9, 0,
181
84.2k
  /* 1601 */ 'b', 'e', 'q', 9, 0,
182
84.2k
  /* 1606 */ 'c', '.', 'j', 'r', 9, 0,
183
84.2k
  /* 1612 */ 'c', '.', 'j', 'a', 'l', 'r', 9, 0,
184
84.2k
  /* 1620 */ 'c', '.', 'o', 'r', 9, 0,
185
84.2k
  /* 1626 */ 'c', '.', 'x', 'o', 'r', 9, 0,
186
84.2k
  /* 1633 */ 'f', 's', 'u', 'b', '.', 's', 9, 0,
187
84.2k
  /* 1641 */ 'f', 'm', 's', 'u', 'b', '.', 's', 9, 0,
188
84.2k
  /* 1650 */ 'f', 'n', 'm', 's', 'u', 'b', '.', 's', 9, 0,
189
84.2k
  /* 1660 */ 'f', 'c', 'v', 't', '.', 'd', '.', 's', 9, 0,
190
84.2k
  /* 1670 */ 'f', 'a', 'd', 'd', '.', 's', 9, 0,
191
84.2k
  /* 1678 */ 'f', 'm', 'a', 'd', 'd', '.', 's', 9, 0,
192
84.2k
  /* 1687 */ 'f', 'n', 'm', 'a', 'd', 'd', '.', 's', 9, 0,
193
84.2k
  /* 1697 */ 'f', 'l', 'e', '.', 's', 9, 0,
194
84.2k
  /* 1704 */ 'f', 's', 'g', 'n', 'j', '.', 's', 9, 0,
195
84.2k
  /* 1713 */ 'f', 'c', 'v', 't', '.', 'l', '.', 's', 9, 0,
196
84.2k
  /* 1723 */ 'f', 'm', 'u', 'l', '.', 's', 9, 0,
197
84.2k
  /* 1731 */ 'f', 'm', 'i', 'n', '.', 's', 9, 0,
198
84.2k
  /* 1739 */ 'f', 's', 'g', 'n', 'j', 'n', '.', 's', 9, 0,
199
84.2k
  /* 1749 */ 'f', 'e', 'q', '.', 's', 9, 0,
200
84.2k
  /* 1756 */ 'f', 'c', 'l', 'a', 's', 's', '.', 's', 9, 0,
201
84.2k
  /* 1766 */ 'f', 'l', 't', '.', 's', 9, 0,
202
84.2k
  /* 1773 */ 'f', 's', 'q', 'r', 't', '.', 's', 9, 0,
203
84.2k
  /* 1782 */ 'f', 'c', 'v', 't', '.', 'l', 'u', '.', 's', 9, 0,
204
84.2k
  /* 1793 */ 'f', 'c', 'v', 't', '.', 'w', 'u', '.', 's', 9, 0,
205
84.2k
  /* 1804 */ 'f', 'd', 'i', 'v', '.', 's', 9, 0,
206
84.2k
  /* 1812 */ 'f', 'c', 'v', 't', '.', 'w', '.', 's', 9, 0,
207
84.2k
  /* 1822 */ 'f', 'm', 'a', 'x', '.', 's', 9, 0,
208
84.2k
  /* 1830 */ 'f', 's', 'g', 'n', 'j', 'x', '.', 's', 9, 0,
209
84.2k
  /* 1840 */ 'c', 's', 'r', 'r', 's', 9, 0,
210
84.2k
  /* 1847 */ 'm', 'r', 'e', 't', 9, 0,
211
84.2k
  /* 1853 */ 's', 'r', 'e', 't', 9, 0,
212
84.2k
  /* 1859 */ 'u', 'r', 'e', 't', 9, 0,
213
84.2k
  /* 1865 */ 'b', 'l', 't', 9, 0,
214
84.2k
  /* 1870 */ 's', 'l', 't', 9, 0,
215
84.2k
  /* 1875 */ 'l', 'b', 'u', 9, 0,
216
84.2k
  /* 1880 */ 'b', 'g', 'e', 'u', 9, 0,
217
84.2k
  /* 1886 */ 'm', 'u', 'l', 'h', 'u', 9, 0,
218
84.2k
  /* 1893 */ 's', 'l', 't', 'i', 'u', 9, 0,
219
84.2k
  /* 1900 */ 'f', 'c', 'v', 't', '.', 'd', '.', 'l', 'u', 9, 0,
220
84.2k
  /* 1911 */ 'f', 'c', 'v', 't', '.', 's', '.', 'l', 'u', 9, 0,
221
84.2k
  /* 1922 */ 'r', 'e', 'm', 'u', 9, 0,
222
84.2k
  /* 1928 */ 'm', 'u', 'l', 'h', 's', 'u', 9, 0,
223
84.2k
  /* 1936 */ 'b', 'l', 't', 'u', 9, 0,
224
84.2k
  /* 1942 */ 's', 'l', 't', 'u', 9, 0,
225
84.2k
  /* 1948 */ 'd', 'i', 'v', 'u', 9, 0,
226
84.2k
  /* 1954 */ 'f', 'c', 'v', 't', '.', 'd', '.', 'w', 'u', 9, 0,
227
84.2k
  /* 1965 */ 'f', 'c', 'v', 't', '.', 's', '.', 'w', 'u', 9, 0,
228
84.2k
  /* 1976 */ 'l', 'w', 'u', 9, 0,
229
84.2k
  /* 1981 */ 'd', 'i', 'v', 9, 0,
230
84.2k
  /* 1986 */ 'c', '.', 'm', 'v', 9, 0,
231
84.2k
  /* 1992 */ 's', 'c', '.', 'w', 9, 0,
232
84.2k
  /* 1998 */ 'f', 'c', 'v', 't', '.', 'd', '.', 'w', 9, 0,
233
84.2k
  /* 2008 */ 'a', 'm', 'o', 'a', 'd', 'd', '.', 'w', 9, 0,
234
84.2k
  /* 2018 */ 'a', 'm', 'o', 'a', 'n', 'd', '.', 'w', 9, 0,
235
84.2k
  /* 2028 */ 'a', 'm', 'o', 'm', 'i', 'n', '.', 'w', 9, 0,
236
84.2k
  /* 2038 */ 'a', 'm', 'o', 's', 'w', 'a', 'p', '.', 'w', 9, 0,
237
84.2k
  /* 2049 */ 'l', 'r', '.', 'w', 9, 0,
238
84.2k
  /* 2055 */ 'a', 'm', 'o', 'o', 'r', '.', 'w', 9, 0,
239
84.2k
  /* 2064 */ 'a', 'm', 'o', 'x', 'o', 'r', '.', 'w', 9, 0,
240
84.2k
  /* 2074 */ 'f', 'c', 'v', 't', '.', 's', '.', 'w', 9, 0,
241
84.2k
  /* 2084 */ 'a', 'm', 'o', 'm', 'i', 'n', 'u', '.', 'w', 9, 0,
242
84.2k
  /* 2095 */ 'a', 'm', 'o', 'm', 'a', 'x', 'u', '.', 'w', 9, 0,
243
84.2k
  /* 2106 */ 'f', 'm', 'v', '.', 'x', '.', 'w', 9, 0,
244
84.2k
  /* 2115 */ 'a', 'm', 'o', 'm', 'a', 'x', '.', 'w', 9, 0,
245
84.2k
  /* 2125 */ 's', 'r', 'a', 'w', 9, 0,
246
84.2k
  /* 2131 */ 'c', '.', 's', 'u', 'b', 'w', 9, 0,
247
84.2k
  /* 2139 */ 'c', '.', 'a', 'd', 'd', 'w', 9, 0,
248
84.2k
  /* 2147 */ 's', 'r', 'a', 'i', 'w', 9, 0,
249
84.2k
  /* 2154 */ 'c', '.', 'a', 'd', 'd', 'i', 'w', 9, 0,
250
84.2k
  /* 2163 */ 's', 'l', 'l', 'i', 'w', 9, 0,
251
84.2k
  /* 2170 */ 's', 'r', 'l', 'i', 'w', 9, 0,
252
84.2k
  /* 2177 */ 'c', '.', 'l', 'w', 9, 0,
253
84.2k
  /* 2183 */ 'c', '.', 'f', 'l', 'w', 9, 0,
254
84.2k
  /* 2190 */ 's', 'l', 'l', 'w', 9, 0,
255
84.2k
  /* 2196 */ 's', 'r', 'l', 'w', 9, 0,
256
84.2k
  /* 2202 */ 'm', 'u', 'l', 'w', 9, 0,
257
84.2k
  /* 2208 */ 'r', 'e', 'm', 'w', 9, 0,
258
84.2k
  /* 2214 */ 'c', 's', 'r', 'r', 'w', 9, 0,
259
84.2k
  /* 2221 */ 'c', '.', 's', 'w', 9, 0,
260
84.2k
  /* 2227 */ 'c', '.', 'f', 's', 'w', 9, 0,
261
84.2k
  /* 2234 */ 'r', 'e', 'm', 'u', 'w', 9, 0,
262
84.2k
  /* 2241 */ 'd', 'i', 'v', 'u', 'w', 9, 0,
263
84.2k
  /* 2248 */ 'd', 'i', 'v', 'w', 9, 0,
264
84.2k
  /* 2254 */ 'f', 'm', 'v', '.', 'd', '.', 'x', 9, 0,
265
84.2k
  /* 2263 */ 'f', 'm', 'v', '.', 'w', '.', 'x', 9, 0,
266
84.2k
  /* 2272 */ 'c', '.', 'b', 'n', 'e', 'z', 9, 0,
267
84.2k
  /* 2280 */ 'c', '.', 'b', 'e', 'q', 'z', 9, 0,
268
84.2k
  /* 2288 */ '#', 32, 'X', 'R', 'a', 'y', 32, 'F', 'u', 'n', 'c', 't', 'i', 'o', 'n', 32, 'P', 'a', 't', 'c', 'h', 'a', 'b', 'l', 'e', 32, 'R', 'E', 'T', '.', 0,
269
84.2k
  /* 2319 */ '#', 32, 'X', 'R', 'a', 'y', 32, 'T', 'y', 'p', 'e', 'd', 32, 'E', 'v', 'e', 'n', 't', 32, 'L', 'o', 'g', '.', 0,
270
84.2k
  /* 2343 */ '#', 32, 'X', 'R', 'a', 'y', 32, 'C', 'u', 's', 't', 'o', 'm', 32, 'E', 'v', 'e', 'n', 't', 32, 'L', 'o', 'g', '.', 0,
271
84.2k
  /* 2368 */ '#', 32, 'X', 'R', 'a', 'y', 32, 'F', 'u', 'n', 'c', 't', 'i', 'o', 'n', 32, 'E', 'n', 't', 'e', 'r', '.', 0,
272
84.2k
  /* 2391 */ '#', 32, 'X', 'R', 'a', 'y', 32, 'T', 'a', 'i', 'l', 32, 'C', 'a', 'l', 'l', 32, 'E', 'x', 'i', 't', '.', 0,
273
84.2k
  /* 2414 */ '#', 32, 'X', 'R', 'a', 'y', 32, 'F', 'u', 'n', 'c', 't', 'i', 'o', 'n', 32, 'E', 'x', 'i', 't', '.', 0,
274
84.2k
  /* 2436 */ 'L', 'I', 'F', 'E', 'T', 'I', 'M', 'E', '_', 'E', 'N', 'D', 0,
275
84.2k
  /* 2449 */ 'B', 'U', 'N', 'D', 'L', 'E', 0,
276
84.2k
  /* 2456 */ 'D', 'B', 'G', '_', 'V', 'A', 'L', 'U', 'E', 0,
277
84.2k
  /* 2466 */ 'D', 'B', 'G', '_', 'L', 'A', 'B', 'E', 'L', 0,
278
84.2k
  /* 2476 */ 'L', 'I', 'F', 'E', 'T', 'I', 'M', 'E', '_', 'S', 'T', 'A', 'R', 'T', 0,
279
84.2k
  /* 2491 */ '#', 32, 'F', 'E', 'n', 't', 'r', 'y', 32, 'c', 'a', 'l', 'l', 0,
280
84.2k
  };
281
84.2k
#endif
282
283
84.2k
  static const uint16_t OpInfo0[] = {
284
84.2k
    0U, // PHI
285
84.2k
    0U, // INLINEASM
286
84.2k
    0U, // INLINEASM_BR
287
84.2k
    0U, // CFI_INSTRUCTION
288
84.2k
    0U, // EH_LABEL
289
84.2k
    0U, // GC_LABEL
290
84.2k
    0U, // ANNOTATION_LABEL
291
84.2k
    0U, // KILL
292
84.2k
    0U, // EXTRACT_SUBREG
293
84.2k
    0U, // INSERT_SUBREG
294
84.2k
    0U, // IMPLICIT_DEF
295
84.2k
    0U, // SUBREG_TO_REG
296
84.2k
    0U, // COPY_TO_REGCLASS
297
84.2k
    2457U,  // DBG_VALUE
298
84.2k
    2467U,  // DBG_LABEL
299
84.2k
    0U, // REG_SEQUENCE
300
84.2k
    0U, // COPY
301
84.2k
    2450U,  // BUNDLE
302
84.2k
    2477U,  // LIFETIME_START
303
84.2k
    2437U,  // LIFETIME_END
304
84.2k
    0U, // STACKMAP
305
84.2k
    2492U,  // FENTRY_CALL
306
84.2k
    0U, // PATCHPOINT
307
84.2k
    0U, // LOAD_STACK_GUARD
308
84.2k
    0U, // STATEPOINT
309
84.2k
    0U, // LOCAL_ESCAPE
310
84.2k
    0U, // FAULTING_OP
311
84.2k
    0U, // PATCHABLE_OP
312
84.2k
    2369U,  // PATCHABLE_FUNCTION_ENTER
313
84.2k
    2289U,  // PATCHABLE_RET
314
84.2k
    2415U,  // PATCHABLE_FUNCTION_EXIT
315
84.2k
    2392U,  // PATCHABLE_TAIL_CALL
316
84.2k
    2344U,  // PATCHABLE_EVENT_CALL
317
84.2k
    2320U,  // PATCHABLE_TYPED_EVENT_CALL
318
84.2k
    0U, // ICALL_BRANCH_FUNNEL
319
84.2k
    0U, // G_ADD
320
84.2k
    0U, // G_SUB
321
84.2k
    0U, // G_MUL
322
84.2k
    0U, // G_SDIV
323
84.2k
    0U, // G_UDIV
324
84.2k
    0U, // G_SREM
325
84.2k
    0U, // G_UREM
326
84.2k
    0U, // G_AND
327
84.2k
    0U, // G_OR
328
84.2k
    0U, // G_XOR
329
84.2k
    0U, // G_IMPLICIT_DEF
330
84.2k
    0U, // G_PHI
331
84.2k
    0U, // G_FRAME_INDEX
332
84.2k
    0U, // G_GLOBAL_VALUE
333
84.2k
    0U, // G_EXTRACT
334
84.2k
    0U, // G_UNMERGE_VALUES
335
84.2k
    0U, // G_INSERT
336
84.2k
    0U, // G_MERGE_VALUES
337
84.2k
    0U, // G_BUILD_VECTOR
338
84.2k
    0U, // G_BUILD_VECTOR_TRUNC
339
84.2k
    0U, // G_CONCAT_VECTORS
340
84.2k
    0U, // G_PTRTOINT
341
84.2k
    0U, // G_INTTOPTR
342
84.2k
    0U, // G_BITCAST
343
84.2k
    0U, // G_INTRINSIC_TRUNC
344
84.2k
    0U, // G_INTRINSIC_ROUND
345
84.2k
    0U, // G_LOAD
346
84.2k
    0U, // G_SEXTLOAD
347
84.2k
    0U, // G_ZEXTLOAD
348
84.2k
    0U, // G_STORE
349
84.2k
    0U, // G_ATOMIC_CMPXCHG_WITH_SUCCESS
350
84.2k
    0U, // G_ATOMIC_CMPXCHG
351
84.2k
    0U, // G_ATOMICRMW_XCHG
352
84.2k
    0U, // G_ATOMICRMW_ADD
353
84.2k
    0U, // G_ATOMICRMW_SUB
354
84.2k
    0U, // G_ATOMICRMW_AND
355
84.2k
    0U, // G_ATOMICRMW_NAND
356
84.2k
    0U, // G_ATOMICRMW_OR
357
84.2k
    0U, // G_ATOMICRMW_XOR
358
84.2k
    0U, // G_ATOMICRMW_MAX
359
84.2k
    0U, // G_ATOMICRMW_MIN
360
84.2k
    0U, // G_ATOMICRMW_UMAX
361
84.2k
    0U, // G_ATOMICRMW_UMIN
362
84.2k
    0U, // G_BRCOND
363
84.2k
    0U, // G_BRINDIRECT
364
84.2k
    0U, // G_INTRINSIC
365
84.2k
    0U, // G_INTRINSIC_W_SIDE_EFFECTS
366
84.2k
    0U, // G_ANYEXT
367
84.2k
    0U, // G_TRUNC
368
84.2k
    0U, // G_CONSTANT
369
84.2k
    0U, // G_FCONSTANT
370
84.2k
    0U, // G_VASTART
371
84.2k
    0U, // G_VAARG
372
84.2k
    0U, // G_SEXT
373
84.2k
    0U, // G_ZEXT
374
84.2k
    0U, // G_SHL
375
84.2k
    0U, // G_LSHR
376
84.2k
    0U, // G_ASHR
377
84.2k
    0U, // G_ICMP
378
84.2k
    0U, // G_FCMP
379
84.2k
    0U, // G_SELECT
380
84.2k
    0U, // G_UADDO
381
84.2k
    0U, // G_UADDE
382
84.2k
    0U, // G_USUBO
383
84.2k
    0U, // G_USUBE
384
84.2k
    0U, // G_SADDO
385
84.2k
    0U, // G_SADDE
386
84.2k
    0U, // G_SSUBO
387
84.2k
    0U, // G_SSUBE
388
84.2k
    0U, // G_UMULO
389
84.2k
    0U, // G_SMULO
390
84.2k
    0U, // G_UMULH
391
84.2k
    0U, // G_SMULH
392
84.2k
    0U, // G_FADD
393
84.2k
    0U, // G_FSUB
394
84.2k
    0U, // G_FMUL
395
84.2k
    0U, // G_FMA
396
84.2k
    0U, // G_FDIV
397
84.2k
    0U, // G_FREM
398
84.2k
    0U, // G_FPOW
399
84.2k
    0U, // G_FEXP
400
84.2k
    0U, // G_FEXP2
401
84.2k
    0U, // G_FLOG
402
84.2k
    0U, // G_FLOG2
403
84.2k
    0U, // G_FLOG10
404
84.2k
    0U, // G_FNEG
405
84.2k
    0U, // G_FPEXT
406
84.2k
    0U, // G_FPTRUNC
407
84.2k
    0U, // G_FPTOSI
408
84.2k
    0U, // G_FPTOUI
409
84.2k
    0U, // G_SITOFP
410
84.2k
    0U, // G_UITOFP
411
84.2k
    0U, // G_FABS
412
84.2k
    0U, // G_FCANONICALIZE
413
84.2k
    0U, // G_GEP
414
84.2k
    0U, // G_PTR_MASK
415
84.2k
    0U, // G_BR
416
84.2k
    0U, // G_INSERT_VECTOR_ELT
417
84.2k
    0U, // G_EXTRACT_VECTOR_ELT
418
84.2k
    0U, // G_SHUFFLE_VECTOR
419
84.2k
    0U, // G_CTTZ
420
84.2k
    0U, // G_CTTZ_ZERO_UNDEF
421
84.2k
    0U, // G_CTLZ
422
84.2k
    0U, // G_CTLZ_ZERO_UNDEF
423
84.2k
    0U, // G_CTPOP
424
84.2k
    0U, // G_BSWAP
425
84.2k
    0U, // G_FCEIL
426
84.2k
    0U, // G_FCOS
427
84.2k
    0U, // G_FSIN
428
84.2k
    0U, // G_FSQRT
429
84.2k
    0U, // G_FFLOOR
430
84.2k
    0U, // G_ADDRSPACE_CAST
431
84.2k
    0U, // G_BLOCK_ADDR
432
84.2k
    4U, // ADJCALLSTACKDOWN
433
84.2k
    4U, // ADJCALLSTACKUP
434
84.2k
    4U, // BuildPairF64Pseudo
435
84.2k
    4U, // PseudoAtomicLoadNand32
436
84.2k
    4U, // PseudoAtomicLoadNand64
437
84.2k
    4U, // PseudoBR
438
84.2k
    4U, // PseudoBRIND
439
84.2k
    4687U,  // PseudoCALL
440
84.2k
    4U, // PseudoCALLIndirect
441
84.2k
    4U, // PseudoCmpXchg32
442
84.2k
    4U, // PseudoCmpXchg64
443
84.2k
    20482U, // PseudoLA
444
84.2k
    20967U, // PseudoLI
445
84.2k
    20481U, // PseudoLLA
446
84.2k
    4U, // PseudoMaskedAtomicLoadAdd32
447
84.2k
    4U, // PseudoMaskedAtomicLoadMax32
448
84.2k
    4U, // PseudoMaskedAtomicLoadMin32
449
84.2k
    4U, // PseudoMaskedAtomicLoadNand32
450
84.2k
    4U, // PseudoMaskedAtomicLoadSub32
451
84.2k
    4U, // PseudoMaskedAtomicLoadUMax32
452
84.2k
    4U, // PseudoMaskedAtomicLoadUMin32
453
84.2k
    4U, // PseudoMaskedAtomicSwap32
454
84.2k
    4U, // PseudoMaskedCmpXchg32
455
84.2k
    4U, // PseudoRET
456
84.2k
    4680U,  // PseudoTAIL
457
84.2k
    4U, // PseudoTAILIndirect
458
84.2k
    4U, // Select_FPR32_Using_CC_GPR
459
84.2k
    4U, // Select_FPR64_Using_CC_GPR
460
84.2k
    4U, // Select_GPR_Using_CC_GPR
461
84.2k
    4U, // SplitF64Pseudo
462
84.2k
    20854U, // ADD
463
84.2k
    20946U, // ADDI
464
84.2k
    22637U, // ADDIW
465
84.2k
    22622U, // ADDW
466
84.2k
    20592U, // AMOADD_D
467
84.2k
    21817U, // AMOADD_D_AQ
468
84.2k
    21367U, // AMOADD_D_AQ_RL
469
84.2k
    21091U, // AMOADD_D_RL
470
84.2k
    22489U, // AMOADD_W
471
84.2k
    21954U, // AMOADD_W_AQ
472
84.2k
    21526U, // AMOADD_W_AQ_RL
473
84.2k
    21228U, // AMOADD_W_RL
474
84.2k
    20602U, // AMOAND_D
475
84.2k
    21830U, // AMOAND_D_AQ
476
84.2k
    21382U, // AMOAND_D_AQ_RL
477
84.2k
    21104U, // AMOAND_D_RL
478
84.2k
    22499U, // AMOAND_W
479
84.2k
    21967U, // AMOAND_W_AQ
480
84.2k
    21541U, // AMOAND_W_AQ_RL
481
84.2k
    21241U, // AMOAND_W_RL
482
84.2k
    20786U, // AMOMAXU_D
483
84.2k
    21918U, // AMOMAXU_D_AQ
484
84.2k
    21484U, // AMOMAXU_D_AQ_RL
485
84.2k
    21192U, // AMOMAXU_D_RL
486
84.2k
    22576U, // AMOMAXU_W
487
84.2k
    22055U, // AMOMAXU_W_AQ
488
84.2k
    21643U, // AMOMAXU_W_AQ_RL
489
84.2k
    21329U, // AMOMAXU_W_RL
490
84.2k
    20832U, // AMOMAX_D
491
84.2k
    21932U, // AMOMAX_D_AQ
492
84.2k
    21500U, // AMOMAX_D_AQ_RL
493
84.2k
    21206U, // AMOMAX_D_RL
494
84.2k
    22596U, // AMOMAX_W
495
84.2k
    22069U, // AMOMAX_W_AQ
496
84.2k
    21659U, // AMOMAX_W_AQ_RL
497
84.2k
    21343U, // AMOMAX_W_RL
498
84.2k
    20764U, // AMOMINU_D
499
84.2k
    21904U, // AMOMINU_D_AQ
500
84.2k
    21468U, // AMOMINU_D_AQ_RL
501
84.2k
    21178U, // AMOMINU_D_RL
502
84.2k
    22565U, // AMOMINU_W
503
84.2k
    22041U, // AMOMINU_W_AQ
504
84.2k
    21627U, // AMOMINU_W_AQ_RL
505
84.2k
    21315U, // AMOMINU_W_RL
506
84.2k
    20654U, // AMOMIN_D
507
84.2k
    21843U, // AMOMIN_D_AQ
508
84.2k
    21397U, // AMOMIN_D_AQ_RL
509
84.2k
    21117U, // AMOMIN_D_RL
510
84.2k
    22509U, // AMOMIN_W
511
84.2k
    21980U, // AMOMIN_W_AQ
512
84.2k
    21556U, // AMOMIN_W_AQ_RL
513
84.2k
    21254U, // AMOMIN_W_RL
514
84.2k
    20698U, // AMOOR_D
515
84.2k
    21879U, // AMOOR_D_AQ
516
84.2k
    21439U, // AMOOR_D_AQ_RL
517
84.2k
    21153U, // AMOOR_D_RL
518
84.2k
    22536U, // AMOOR_W
519
84.2k
    22016U, // AMOOR_W_AQ
520
84.2k
    21598U, // AMOOR_W_AQ_RL
521
84.2k
    21290U, // AMOOR_W_RL
522
84.2k
    20674U, // AMOSWAP_D
523
84.2k
    21856U, // AMOSWAP_D_AQ
524
84.2k
    21412U, // AMOSWAP_D_AQ_RL
525
84.2k
    21130U, // AMOSWAP_D_RL
526
84.2k
    22519U, // AMOSWAP_W
527
84.2k
    21993U, // AMOSWAP_W_AQ
528
84.2k
    21571U, // AMOSWAP_W_AQ_RL
529
84.2k
    21267U, // AMOSWAP_W_RL
530
84.2k
    20707U, // AMOXOR_D
531
84.2k
    21891U, // AMOXOR_D_AQ
532
84.2k
    21453U, // AMOXOR_D_AQ_RL
533
84.2k
    21165U, // AMOXOR_D_RL
534
84.2k
    22545U, // AMOXOR_W
535
84.2k
    22028U, // AMOXOR_W_AQ
536
84.2k
    21612U, // AMOXOR_W_AQ_RL
537
84.2k
    21302U, // AMOXOR_W_RL
538
84.2k
    20874U, // AND
539
84.2k
    20954U, // ANDI
540
84.2k
    20518U, // AUIPC
541
84.2k
    22082U, // BEQ
542
84.2k
    20899U, // BGE
543
84.2k
    22361U, // BGEU
544
84.2k
    22346U, // BLT
545
84.2k
    22417U, // BLTU
546
84.2k
    20904U, // BNE
547
84.2k
    20525U, // CSRRC
548
84.2k
    20936U, // CSRRCI
549
84.2k
    22321U, // CSRRS
550
84.2k
    20993U, // CSRRSI
551
84.2k
    22695U, // CSRRW
552
84.2k
    21014U, // CSRRWI
553
84.2k
    8564U,  // C_ADD
554
84.2k
    8656U,  // C_ADDI
555
84.2k
    9440U,  // C_ADDI16SP
556
84.2k
    21689U, // C_ADDI4SPN
557
84.2k
    10347U, // C_ADDIW
558
84.2k
    10332U, // C_ADDW
559
84.2k
    8584U,  // C_AND
560
84.2k
    8664U,  // C_ANDI
561
84.2k
    22761U, // C_BEQZ
562
84.2k
    22753U, // C_BNEZ
563
84.2k
    547U, // C_EBREAK
564
84.2k
    20865U, // C_FLD
565
84.2k
    21748U, // C_FLDSP
566
84.2k
    22664U, // C_FLW
567
84.2k
    21782U, // C_FLWSP
568
84.2k
    20885U, // C_FSD
569
84.2k
    21765U, // C_FSDSP
570
84.2k
    22708U, // C_FSW
571
84.2k
    21799U, // C_FSWSP
572
84.2k
    4638U,  // C_J
573
84.2k
    4673U,  // C_JAL
574
84.2k
    5709U,  // C_JALR
575
84.2k
    5703U,  // C_JR
576
84.2k
    20859U, // C_LD
577
84.2k
    21740U, // C_LDSP
578
84.2k
    20965U, // C_LI
579
84.2k
    21007U, // C_LUI
580
84.2k
    22658U, // C_LW
581
84.2k
    21774U, // C_LWSP
582
84.2k
    22467U, // C_MV
583
84.2k
    1241U,  // C_NOP
584
84.2k
    9813U,  // C_OR
585
84.2k
    20879U, // C_SD
586
84.2k
    21757U, // C_SDSP
587
84.2k
    8683U,  // C_SLLI
588
84.2k
    8640U,  // C_SRAI
589
84.2k
    8691U,  // C_SRLI
590
84.2k
    8223U,  // C_SUB
591
84.2k
    10324U, // C_SUBW
592
84.2k
    22702U, // C_SW
593
84.2k
    21791U, // C_SWSP
594
84.2k
    1232U,  // C_UNIMP
595
84.2k
    9819U,  // C_XOR
596
84.2k
    22462U, // DIV
597
84.2k
    22429U, // DIVU
598
84.2k
    22722U, // DIVUW
599
84.2k
    22729U, // DIVW
600
84.2k
    549U, // EBREAK
601
84.2k
    590U, // ECALL
602
84.2k
    20565U, // FADD_D
603
84.2k
    22151U, // FADD_S
604
84.2k
    20727U, // FCLASS_D
605
84.2k
    22237U, // FCLASS_S
606
84.2k
    21037U, // FCVT_D_L
607
84.2k
    22381U, // FCVT_D_LU
608
84.2k
    22141U, // FCVT_D_S
609
84.2k
    22479U, // FCVT_D_W
610
84.2k
    22435U, // FCVT_D_WU
611
84.2k
    20753U, // FCVT_LU_D
612
84.2k
    22263U, // FCVT_LU_S
613
84.2k
    20628U, // FCVT_L_D
614
84.2k
    22194U, // FCVT_L_S
615
84.2k
    20717U, // FCVT_S_D
616
84.2k
    21047U, // FCVT_S_L
617
84.2k
    22392U, // FCVT_S_LU
618
84.2k
    22555U, // FCVT_S_W
619
84.2k
    22446U, // FCVT_S_WU
620
84.2k
    20775U, // FCVT_WU_D
621
84.2k
    22274U, // FCVT_WU_S
622
84.2k
    20805U, // FCVT_W_D
623
84.2k
    22293U, // FCVT_W_S
624
84.2k
    20797U, // FDIV_D
625
84.2k
    22285U, // FDIV_S
626
84.2k
    12700U, // FENCE
627
84.2k
    439U, // FENCE_I
628
84.2k
    1221U,  // FENCE_TSO
629
84.2k
    20685U, // FEQ_D
630
84.2k
    22230U, // FEQ_S
631
84.2k
    20867U, // FLD
632
84.2k
    20612U, // FLE_D
633
84.2k
    22178U, // FLE_S
634
84.2k
    20737U, // FLT_D
635
84.2k
    22247U, // FLT_S
636
84.2k
    22666U, // FLW
637
84.2k
    20573U, // FMADD_D
638
84.2k
    22159U, // FMADD_S
639
84.2k
    20824U, // FMAX_D
640
84.2k
    22303U, // FMAX_S
641
84.2k
    20646U, // FMIN_D
642
84.2k
    22212U, // FMIN_S
643
84.2k
    20540U, // FMSUB_D
644
84.2k
    22122U, // FMSUB_S
645
84.2k
    20638U, // FMUL_D
646
84.2k
    22204U, // FMUL_S
647
84.2k
    22735U, // FMV_D_X
648
84.2k
    22744U, // FMV_W_X
649
84.2k
    20815U, // FMV_X_D
650
84.2k
    22587U, // FMV_X_W
651
84.2k
    20582U, // FNMADD_D
652
84.2k
    22168U, // FNMADD_S
653
84.2k
    20549U, // FNMSUB_D
654
84.2k
    22131U, // FNMSUB_S
655
84.2k
    20887U, // FSD
656
84.2k
    20664U, // FSGNJN_D
657
84.2k
    22220U, // FSGNJN_S
658
84.2k
    20842U, // FSGNJX_D
659
84.2k
    22311U, // FSGNJX_S
660
84.2k
    20619U, // FSGNJ_D
661
84.2k
    22185U, // FSGNJ_S
662
84.2k
    20744U, // FSQRT_D
663
84.2k
    22254U, // FSQRT_S
664
84.2k
    20532U, // FSUB_D
665
84.2k
    22114U, // FSUB_S
666
84.2k
    22710U, // FSW
667
84.2k
    21059U, // JAL
668
84.2k
    22095U, // JALR
669
84.2k
    20503U, // LB
670
84.2k
    22356U, // LBU
671
84.2k
    20861U, // LD
672
84.2k
    20911U, // LH
673
84.2k
    22369U, // LHU
674
84.2k
    37076U, // LR_D
675
84.2k
    38254U, // LR_D_AQ
676
84.2k
    37812U, // LR_D_AQ_RL
677
84.2k
    37528U, // LR_D_RL
678
84.2k
    38914U, // LR_W
679
84.2k
    38391U, // LR_W_AQ
680
84.2k
    37971U, // LR_W_AQ_RL
681
84.2k
    37665U, // LR_W_RL
682
84.2k
    21009U, // LUI
683
84.2k
    22660U, // LW
684
84.2k
    22457U, // LWU
685
84.2k
    1848U,  // MRET
686
84.2k
    21679U, // MUL
687
84.2k
    20909U, // MULH
688
84.2k
    22409U, // MULHSU
689
84.2k
    22367U, // MULHU
690
84.2k
    22683U, // MULW
691
84.2k
    22103U, // OR
692
84.2k
    20988U, // ORI
693
84.2k
    21684U, // REM
694
84.2k
    22403U, // REMU
695
84.2k
    22715U, // REMUW
696
84.2k
    22689U, // REMW
697
84.2k
    20507U, // SB
698
84.2k
    20559U, // SC_D
699
84.2k
    21808U, // SC_D_AQ
700
84.2k
    21356U, // SC_D_AQ_RL
701
84.2k
    21082U, // SC_D_RL
702
84.2k
    22473U, // SC_W
703
84.2k
    21945U, // SC_W_AQ
704
84.2k
    21515U, // SC_W_AQ_RL
705
84.2k
    21219U, // SC_W_RL
706
84.2k
    20881U, // SD
707
84.2k
    20486U, // SFENCE_VMA
708
84.2k
    20915U, // SH
709
84.2k
    21077U, // SLL
710
84.2k
    20973U, // SLLI
711
84.2k
    22644U, // SLLIW
712
84.2k
    22671U, // SLLW
713
84.2k
    22351U, // SLT
714
84.2k
    21001U, // SLTI
715
84.2k
    22374U, // SLTIU
716
84.2k
    22423U, // SLTU
717
84.2k
    20498U, // SRA
718
84.2k
    20930U, // SRAI
719
84.2k
    22628U, // SRAIW
720
84.2k
    22606U, // SRAW
721
84.2k
    1854U,  // SRET
722
84.2k
    21674U, // SRL
723
84.2k
    20981U, // SRLI
724
84.2k
    22651U, // SRLIW
725
84.2k
    22677U, // SRLW
726
84.2k
    20513U, // SUB
727
84.2k
    22614U, // SUBW
728
84.2k
    22704U, // SW
729
84.2k
    1234U,  // UNIMP
730
84.2k
    1860U,  // URET
731
84.2k
    480U, // WFI
732
84.2k
    22109U, // XOR
733
84.2k
    20987U, // XORI
734
84.2k
  };
735
736
84.2k
  static const uint8_t OpInfo1[] = {
737
84.2k
    0U, // PHI
738
84.2k
    0U, // INLINEASM
739
84.2k
    0U, // INLINEASM_BR
740
84.2k
    0U, // CFI_INSTRUCTION
741
84.2k
    0U, // EH_LABEL
742
84.2k
    0U, // GC_LABEL
743
84.2k
    0U, // ANNOTATION_LABEL
744
84.2k
    0U, // KILL
745
84.2k
    0U, // EXTRACT_SUBREG
746
84.2k
    0U, // INSERT_SUBREG
747
84.2k
    0U, // IMPLICIT_DEF
748
84.2k
    0U, // SUBREG_TO_REG
749
84.2k
    0U, // COPY_TO_REGCLASS
750
84.2k
    0U, // DBG_VALUE
751
84.2k
    0U, // DBG_LABEL
752
84.2k
    0U, // REG_SEQUENCE
753
84.2k
    0U, // COPY
754
84.2k
    0U, // BUNDLE
755
84.2k
    0U, // LIFETIME_START
756
84.2k
    0U, // LIFETIME_END
757
84.2k
    0U, // STACKMAP
758
84.2k
    0U, // FENTRY_CALL
759
84.2k
    0U, // PATCHPOINT
760
84.2k
    0U, // LOAD_STACK_GUARD
761
84.2k
    0U, // STATEPOINT
762
84.2k
    0U, // LOCAL_ESCAPE
763
84.2k
    0U, // FAULTING_OP
764
84.2k
    0U, // PATCHABLE_OP
765
84.2k
    0U, // PATCHABLE_FUNCTION_ENTER
766
84.2k
    0U, // PATCHABLE_RET
767
84.2k
    0U, // PATCHABLE_FUNCTION_EXIT
768
84.2k
    0U, // PATCHABLE_TAIL_CALL
769
84.2k
    0U, // PATCHABLE_EVENT_CALL
770
84.2k
    0U, // PATCHABLE_TYPED_EVENT_CALL
771
84.2k
    0U, // ICALL_BRANCH_FUNNEL
772
84.2k
    0U, // G_ADD
773
84.2k
    0U, // G_SUB
774
84.2k
    0U, // G_MUL
775
84.2k
    0U, // G_SDIV
776
84.2k
    0U, // G_UDIV
777
84.2k
    0U, // G_SREM
778
84.2k
    0U, // G_UREM
779
84.2k
    0U, // G_AND
780
84.2k
    0U, // G_OR
781
84.2k
    0U, // G_XOR
782
84.2k
    0U, // G_IMPLICIT_DEF
783
84.2k
    0U, // G_PHI
784
84.2k
    0U, // G_FRAME_INDEX
785
84.2k
    0U, // G_GLOBAL_VALUE
786
84.2k
    0U, // G_EXTRACT
787
84.2k
    0U, // G_UNMERGE_VALUES
788
84.2k
    0U, // G_INSERT
789
84.2k
    0U, // G_MERGE_VALUES
790
84.2k
    0U, // G_BUILD_VECTOR
791
84.2k
    0U, // G_BUILD_VECTOR_TRUNC
792
84.2k
    0U, // G_CONCAT_VECTORS
793
84.2k
    0U, // G_PTRTOINT
794
84.2k
    0U, // G_INTTOPTR
795
84.2k
    0U, // G_BITCAST
796
84.2k
    0U, // G_INTRINSIC_TRUNC
797
84.2k
    0U, // G_INTRINSIC_ROUND
798
84.2k
    0U, // G_LOAD
799
84.2k
    0U, // G_SEXTLOAD
800
84.2k
    0U, // G_ZEXTLOAD
801
84.2k
    0U, // G_STORE
802
84.2k
    0U, // G_ATOMIC_CMPXCHG_WITH_SUCCESS
803
84.2k
    0U, // G_ATOMIC_CMPXCHG
804
84.2k
    0U, // G_ATOMICRMW_XCHG
805
84.2k
    0U, // G_ATOMICRMW_ADD
806
84.2k
    0U, // G_ATOMICRMW_SUB
807
84.2k
    0U, // G_ATOMICRMW_AND
808
84.2k
    0U, // G_ATOMICRMW_NAND
809
84.2k
    0U, // G_ATOMICRMW_OR
810
84.2k
    0U, // G_ATOMICRMW_XOR
811
84.2k
    0U, // G_ATOMICRMW_MAX
812
84.2k
    0U, // G_ATOMICRMW_MIN
813
84.2k
    0U, // G_ATOMICRMW_UMAX
814
84.2k
    0U, // G_ATOMICRMW_UMIN
815
84.2k
    0U, // G_BRCOND
816
84.2k
    0U, // G_BRINDIRECT
817
84.2k
    0U, // G_INTRINSIC
818
84.2k
    0U, // G_INTRINSIC_W_SIDE_EFFECTS
819
84.2k
    0U, // G_ANYEXT
820
84.2k
    0U, // G_TRUNC
821
84.2k
    0U, // G_CONSTANT
822
84.2k
    0U, // G_FCONSTANT
823
84.2k
    0U, // G_VASTART
824
84.2k
    0U, // G_VAARG
825
84.2k
    0U, // G_SEXT
826
84.2k
    0U, // G_ZEXT
827
84.2k
    0U, // G_SHL
828
84.2k
    0U, // G_LSHR
829
84.2k
    0U, // G_ASHR
830
84.2k
    0U, // G_ICMP
831
84.2k
    0U, // G_FCMP
832
84.2k
    0U, // G_SELECT
833
84.2k
    0U, // G_UADDO
834
84.2k
    0U, // G_UADDE
835
84.2k
    0U, // G_USUBO
836
84.2k
    0U, // G_USUBE
837
84.2k
    0U, // G_SADDO
838
84.2k
    0U, // G_SADDE
839
84.2k
    0U, // G_SSUBO
840
84.2k
    0U, // G_SSUBE
841
84.2k
    0U, // G_UMULO
842
84.2k
    0U, // G_SMULO
843
84.2k
    0U, // G_UMULH
844
84.2k
    0U, // G_SMULH
845
84.2k
    0U, // G_FADD
846
84.2k
    0U, // G_FSUB
847
84.2k
    0U, // G_FMUL
848
84.2k
    0U, // G_FMA
849
84.2k
    0U, // G_FDIV
850
84.2k
    0U, // G_FREM
851
84.2k
    0U, // G_FPOW
852
84.2k
    0U, // G_FEXP
853
84.2k
    0U, // G_FEXP2
854
84.2k
    0U, // G_FLOG
855
84.2k
    0U, // G_FLOG2
856
84.2k
    0U, // G_FLOG10
857
84.2k
    0U, // G_FNEG
858
84.2k
    0U, // G_FPEXT
859
84.2k
    0U, // G_FPTRUNC
860
84.2k
    0U, // G_FPTOSI
861
84.2k
    0U, // G_FPTOUI
862
84.2k
    0U, // G_SITOFP
863
84.2k
    0U, // G_UITOFP
864
84.2k
    0U, // G_FABS
865
84.2k
    0U, // G_FCANONICALIZE
866
84.2k
    0U, // G_GEP
867
84.2k
    0U, // G_PTR_MASK
868
84.2k
    0U, // G_BR
869
84.2k
    0U, // G_INSERT_VECTOR_ELT
870
84.2k
    0U, // G_EXTRACT_VECTOR_ELT
871
84.2k
    0U, // G_SHUFFLE_VECTOR
872
84.2k
    0U, // G_CTTZ
873
84.2k
    0U, // G_CTTZ_ZERO_UNDEF
874
84.2k
    0U, // G_CTLZ
875
84.2k
    0U, // G_CTLZ_ZERO_UNDEF
876
84.2k
    0U, // G_CTPOP
877
84.2k
    0U, // G_BSWAP
878
84.2k
    0U, // G_FCEIL
879
84.2k
    0U, // G_FCOS
880
84.2k
    0U, // G_FSIN
881
84.2k
    0U, // G_FSQRT
882
84.2k
    0U, // G_FFLOOR
883
84.2k
    0U, // G_ADDRSPACE_CAST
884
84.2k
    0U, // G_BLOCK_ADDR
885
84.2k
    0U, // ADJCALLSTACKDOWN
886
84.2k
    0U, // ADJCALLSTACKUP
887
84.2k
    0U, // BuildPairF64Pseudo
888
84.2k
    0U, // PseudoAtomicLoadNand32
889
84.2k
    0U, // PseudoAtomicLoadNand64
890
84.2k
    0U, // PseudoBR
891
84.2k
    0U, // PseudoBRIND
892
84.2k
    0U, // PseudoCALL
893
84.2k
    0U, // PseudoCALLIndirect
894
84.2k
    0U, // PseudoCmpXchg32
895
84.2k
    0U, // PseudoCmpXchg64
896
84.2k
    0U, // PseudoLA
897
84.2k
    0U, // PseudoLI
898
84.2k
    0U, // PseudoLLA
899
84.2k
    0U, // PseudoMaskedAtomicLoadAdd32
900
84.2k
    0U, // PseudoMaskedAtomicLoadMax32
901
84.2k
    0U, // PseudoMaskedAtomicLoadMin32
902
84.2k
    0U, // PseudoMaskedAtomicLoadNand32
903
84.2k
    0U, // PseudoMaskedAtomicLoadSub32
904
84.2k
    0U, // PseudoMaskedAtomicLoadUMax32
905
84.2k
    0U, // PseudoMaskedAtomicLoadUMin32
906
84.2k
    0U, // PseudoMaskedAtomicSwap32
907
84.2k
    0U, // PseudoMaskedCmpXchg32
908
84.2k
    0U, // PseudoRET
909
84.2k
    0U, // PseudoTAIL
910
84.2k
    0U, // PseudoTAILIndirect
911
84.2k
    0U, // Select_FPR32_Using_CC_GPR
912
84.2k
    0U, // Select_FPR64_Using_CC_GPR
913
84.2k
    0U, // Select_GPR_Using_CC_GPR
914
84.2k
    0U, // SplitF64Pseudo
915
84.2k
    4U, // ADD
916
84.2k
    4U, // ADDI
917
84.2k
    4U, // ADDIW
918
84.2k
    4U, // ADDW
919
84.2k
    9U, // AMOADD_D
920
84.2k
    9U, // AMOADD_D_AQ
921
84.2k
    9U, // AMOADD_D_AQ_RL
922
84.2k
    9U, // AMOADD_D_RL
923
84.2k
    9U, // AMOADD_W
924
84.2k
    9U, // AMOADD_W_AQ
925
84.2k
    9U, // AMOADD_W_AQ_RL
926
84.2k
    9U, // AMOADD_W_RL
927
84.2k
    9U, // AMOAND_D
928
84.2k
    9U, // AMOAND_D_AQ
929
84.2k
    9U, // AMOAND_D_AQ_RL
930
84.2k
    9U, // AMOAND_D_RL
931
84.2k
    9U, // AMOAND_W
932
84.2k
    9U, // AMOAND_W_AQ
933
84.2k
    9U, // AMOAND_W_AQ_RL
934
84.2k
    9U, // AMOAND_W_RL
935
84.2k
    9U, // AMOMAXU_D
936
84.2k
    9U, // AMOMAXU_D_AQ
937
84.2k
    9U, // AMOMAXU_D_AQ_RL
938
84.2k
    9U, // AMOMAXU_D_RL
939
84.2k
    9U, // AMOMAXU_W
940
84.2k
    9U, // AMOMAXU_W_AQ
941
84.2k
    9U, // AMOMAXU_W_AQ_RL
942
84.2k
    9U, // AMOMAXU_W_RL
943
84.2k
    9U, // AMOMAX_D
944
84.2k
    9U, // AMOMAX_D_AQ
945
84.2k
    9U, // AMOMAX_D_AQ_RL
946
84.2k
    9U, // AMOMAX_D_RL
947
84.2k
    9U, // AMOMAX_W
948
84.2k
    9U, // AMOMAX_W_AQ
949
84.2k
    9U, // AMOMAX_W_AQ_RL
950
84.2k
    9U, // AMOMAX_W_RL
951
84.2k
    9U, // AMOMINU_D
952
84.2k
    9U, // AMOMINU_D_AQ
953
84.2k
    9U, // AMOMINU_D_AQ_RL
954
84.2k
    9U, // AMOMINU_D_RL
955
84.2k
    9U, // AMOMINU_W
956
84.2k
    9U, // AMOMINU_W_AQ
957
84.2k
    9U, // AMOMINU_W_AQ_RL
958
84.2k
    9U, // AMOMINU_W_RL
959
84.2k
    9U, // AMOMIN_D
960
84.2k
    9U, // AMOMIN_D_AQ
961
84.2k
    9U, // AMOMIN_D_AQ_RL
962
84.2k
    9U, // AMOMIN_D_RL
963
84.2k
    9U, // AMOMIN_W
964
84.2k
    9U, // AMOMIN_W_AQ
965
84.2k
    9U, // AMOMIN_W_AQ_RL
966
84.2k
    9U, // AMOMIN_W_RL
967
84.2k
    9U, // AMOOR_D
968
84.2k
    9U, // AMOOR_D_AQ
969
84.2k
    9U, // AMOOR_D_AQ_RL
970
84.2k
    9U, // AMOOR_D_RL
971
84.2k
    9U, // AMOOR_W
972
84.2k
    9U, // AMOOR_W_AQ
973
84.2k
    9U, // AMOOR_W_AQ_RL
974
84.2k
    9U, // AMOOR_W_RL
975
84.2k
    9U, // AMOSWAP_D
976
84.2k
    9U, // AMOSWAP_D_AQ
977
84.2k
    9U, // AMOSWAP_D_AQ_RL
978
84.2k
    9U, // AMOSWAP_D_RL
979
84.2k
    9U, // AMOSWAP_W
980
84.2k
    9U, // AMOSWAP_W_AQ
981
84.2k
    9U, // AMOSWAP_W_AQ_RL
982
84.2k
    9U, // AMOSWAP_W_RL
983
84.2k
    9U, // AMOXOR_D
984
84.2k
    9U, // AMOXOR_D_AQ
985
84.2k
    9U, // AMOXOR_D_AQ_RL
986
84.2k
    9U, // AMOXOR_D_RL
987
84.2k
    9U, // AMOXOR_W
988
84.2k
    9U, // AMOXOR_W_AQ
989
84.2k
    9U, // AMOXOR_W_AQ_RL
990
84.2k
    9U, // AMOXOR_W_RL
991
84.2k
    4U, // AND
992
84.2k
    4U, // ANDI
993
84.2k
    0U, // AUIPC
994
84.2k
    4U, // BEQ
995
84.2k
    4U, // BGE
996
84.2k
    4U, // BGEU
997
84.2k
    4U, // BLT
998
84.2k
    4U, // BLTU
999
84.2k
    4U, // BNE
1000
84.2k
    2U, // CSRRC
1001
84.2k
    2U, // CSRRCI
1002
84.2k
    2U, // CSRRS
1003
84.2k
    2U, // CSRRSI
1004
84.2k
    2U, // CSRRW
1005
84.2k
    2U, // CSRRWI
1006
84.2k
    0U, // C_ADD
1007
84.2k
    0U, // C_ADDI
1008
84.2k
    0U, // C_ADDI16SP
1009
84.2k
    4U, // C_ADDI4SPN
1010
84.2k
    0U, // C_ADDIW
1011
84.2k
    0U, // C_ADDW
1012
84.2k
    0U, // C_AND
1013
84.2k
    0U, // C_ANDI
1014
84.2k
    0U, // C_BEQZ
1015
84.2k
    0U, // C_BNEZ
1016
84.2k
    0U, // C_EBREAK
1017
84.2k
    13U,  // C_FLD
1018
84.2k
    13U,  // C_FLDSP
1019
84.2k
    13U,  // C_FLW
1020
84.2k
    13U,  // C_FLWSP
1021
84.2k
    13U,  // C_FSD
1022
84.2k
    13U,  // C_FSDSP
1023
84.2k
    13U,  // C_FSW
1024
84.2k
    13U,  // C_FSWSP
1025
84.2k
    0U, // C_J
1026
84.2k
    0U, // C_JAL
1027
84.2k
    0U, // C_JALR
1028
84.2k
    0U, // C_JR
1029
84.2k
    13U,  // C_LD
1030
84.2k
    13U,  // C_LDSP
1031
84.2k
    0U, // C_LI
1032
84.2k
    0U, // C_LUI
1033
84.2k
    13U,  // C_LW
1034
84.2k
    13U,  // C_LWSP
1035
84.2k
    0U, // C_MV
1036
84.2k
    0U, // C_NOP
1037
84.2k
    0U, // C_OR
1038
84.2k
    13U,  // C_SD
1039
84.2k
    13U,  // C_SDSP
1040
84.2k
    0U, // C_SLLI
1041
84.2k
    0U, // C_SRAI
1042
84.2k
    0U, // C_SRLI
1043
84.2k
    0U, // C_SUB
1044
84.2k
    0U, // C_SUBW
1045
84.2k
    13U,  // C_SW
1046
84.2k
    13U,  // C_SWSP
1047
84.2k
    0U, // C_UNIMP
1048
84.2k
    0U, // C_XOR
1049
84.2k
    4U, // DIV
1050
84.2k
    4U, // DIVU
1051
84.2k
    4U, // DIVUW
1052
84.2k
    4U, // DIVW
1053
84.2k
    0U, // EBREAK
1054
84.2k
    0U, // ECALL
1055
84.2k
    36U,  // FADD_D
1056
84.2k
    36U,  // FADD_S
1057
84.2k
    0U, // FCLASS_D
1058
84.2k
    0U, // FCLASS_S
1059
84.2k
    20U,  // FCVT_D_L
1060
84.2k
    20U,  // FCVT_D_LU
1061
84.2k
    0U, // FCVT_D_S
1062
84.2k
    0U, // FCVT_D_W
1063
84.2k
    0U, // FCVT_D_WU
1064
84.2k
    20U,  // FCVT_LU_D
1065
84.2k
    20U,  // FCVT_LU_S
1066
84.2k
    20U,  // FCVT_L_D
1067
84.2k
    20U,  // FCVT_L_S
1068
84.2k
    20U,  // FCVT_S_D
1069
84.2k
    20U,  // FCVT_S_L
1070
84.2k
    20U,  // FCVT_S_LU
1071
84.2k
    20U,  // FCVT_S_W
1072
84.2k
    20U,  // FCVT_S_WU
1073
84.2k
    20U,  // FCVT_WU_D
1074
84.2k
    20U,  // FCVT_WU_S
1075
84.2k
    20U,  // FCVT_W_D
1076
84.2k
    20U,  // FCVT_W_S
1077
84.2k
    36U,  // FDIV_D
1078
84.2k
    36U,  // FDIV_S
1079
84.2k
    0U, // FENCE
1080
84.2k
    0U, // FENCE_I
1081
84.2k
    0U, // FENCE_TSO
1082
84.2k
    4U, // FEQ_D
1083
84.2k
    4U, // FEQ_S
1084
84.2k
    13U,  // FLD
1085
84.2k
    4U, // FLE_D
1086
84.2k
    4U, // FLE_S
1087
84.2k
    4U, // FLT_D
1088
84.2k
    4U, // FLT_S
1089
84.2k
    13U,  // FLW
1090
84.2k
    100U, // FMADD_D
1091
84.2k
    100U, // FMADD_S
1092
84.2k
    4U, // FMAX_D
1093
84.2k
    4U, // FMAX_S
1094
84.2k
    4U, // FMIN_D
1095
84.2k
    4U, // FMIN_S
1096
84.2k
    100U, // FMSUB_D
1097
84.2k
    100U, // FMSUB_S
1098
84.2k
    36U,  // FMUL_D
1099
84.2k
    36U,  // FMUL_S
1100
84.2k
    0U, // FMV_D_X
1101
84.2k
    0U, // FMV_W_X
1102
84.2k
    0U, // FMV_X_D
1103
84.2k
    0U, // FMV_X_W
1104
84.2k
    100U, // FNMADD_D
1105
84.2k
    100U, // FNMADD_S
1106
84.2k
    100U, // FNMSUB_D
1107
84.2k
    100U, // FNMSUB_S
1108
84.2k
    13U,  // FSD
1109
84.2k
    4U, // FSGNJN_D
1110
84.2k
    4U, // FSGNJN_S
1111
84.2k
    4U, // FSGNJX_D
1112
84.2k
    4U, // FSGNJX_S
1113
84.2k
    4U, // FSGNJ_D
1114
84.2k
    4U, // FSGNJ_S
1115
84.2k
    20U,  // FSQRT_D
1116
84.2k
    20U,  // FSQRT_S
1117
84.2k
    36U,  // FSUB_D
1118
84.2k
    36U,  // FSUB_S
1119
84.2k
    13U,  // FSW
1120
84.2k
    0U, // JAL
1121
84.2k
    4U, // JALR
1122
84.2k
    13U,  // LB
1123
84.2k
    13U,  // LBU
1124
84.2k
    13U,  // LD
1125
84.2k
    13U,  // LH
1126
84.2k
    13U,  // LHU
1127
84.2k
    0U, // LR_D
1128
84.2k
    0U, // LR_D_AQ
1129
84.2k
    0U, // LR_D_AQ_RL
1130
84.2k
    0U, // LR_D_RL
1131
84.2k
    0U, // LR_W
1132
84.2k
    0U, // LR_W_AQ
1133
84.2k
    0U, // LR_W_AQ_RL
1134
84.2k
    0U, // LR_W_RL
1135
84.2k
    0U, // LUI
1136
84.2k
    13U,  // LW
1137
84.2k
    13U,  // LWU
1138
84.2k
    0U, // MRET
1139
84.2k
    4U, // MUL
1140
84.2k
    4U, // MULH
1141
84.2k
    4U, // MULHSU
1142
84.2k
    4U, // MULHU
1143
84.2k
    4U, // MULW
1144
84.2k
    4U, // OR
1145
84.2k
    4U, // ORI
1146
84.2k
    4U, // REM
1147
84.2k
    4U, // REMU
1148
84.2k
    4U, // REMUW
1149
84.2k
    4U, // REMW
1150
84.2k
    13U,  // SB
1151
84.2k
    9U, // SC_D
1152
84.2k
    9U, // SC_D_AQ
1153
84.2k
    9U, // SC_D_AQ_RL
1154
84.2k
    9U, // SC_D_RL
1155
84.2k
    9U, // SC_W
1156
84.2k
    9U, // SC_W_AQ
1157
84.2k
    9U, // SC_W_AQ_RL
1158
84.2k
    9U, // SC_W_RL
1159
84.2k
    13U,  // SD
1160
84.2k
    0U, // SFENCE_VMA
1161
84.2k
    13U,  // SH
1162
84.2k
    4U, // SLL
1163
84.2k
    4U, // SLLI
1164
84.2k
    4U, // SLLIW
1165
84.2k
    4U, // SLLW
1166
84.2k
    4U, // SLT
1167
84.2k
    4U, // SLTI
1168
84.2k
    4U, // SLTIU
1169
84.2k
    4U, // SLTU
1170
84.2k
    4U, // SRA
1171
84.2k
    4U, // SRAI
1172
84.2k
    4U, // SRAIW
1173
84.2k
    4U, // SRAW
1174
84.2k
    0U, // SRET
1175
84.2k
    4U, // SRL
1176
84.2k
    4U, // SRLI
1177
84.2k
    4U, // SRLIW
1178
84.2k
    4U, // SRLW
1179
84.2k
    4U, // SUB
1180
84.2k
    4U, // SUBW
1181
84.2k
    13U,  // SW
1182
84.2k
    0U, // UNIMP
1183
84.2k
    0U, // URET
1184
84.2k
    0U, // WFI
1185
84.2k
    4U, // XOR
1186
84.2k
    4U, // XORI
1187
84.2k
  };
1188
1189
  // Emit the opcode for the instruction.
1190
84.2k
  uint32_t Bits = 0;
1191
84.2k
  Bits |= OpInfo0[MCInst_getOpcode(MI)] << 0;
1192
84.2k
  Bits |= OpInfo1[MCInst_getOpcode(MI)] << 16;
1193
84.2k
  CS_ASSERT(Bits != 0 && "Cannot print this instruction.");
1194
84.2k
#ifndef CAPSTONE_DIET
1195
84.2k
  SStream_concat0(O, AsmStrs+(Bits & 4095)-1);
1196
84.2k
#endif
1197
1198
1199
  // Fragment 0 encoded into 2 bits for 4 unique commands.
1200
84.2k
  switch ((Bits >> 12) & 3) {
1201
0
  default: CS_ASSERT(0 && "Invalid command number.");
1202
373
  case 0:
1203
    // DBG_VALUE, DBG_LABEL, BUNDLE, LIFETIME_START, LIFETIME_END, FENTRY_CAL...
1204
373
    return;
1205
0
    break;
1206
82.3k
  case 1:
1207
    // PseudoCALL, PseudoLA, PseudoLI, PseudoLLA, PseudoTAIL, ADD, ADDI, ADDI...
1208
82.3k
    printOperand(MI, 0, O);
1209
82.3k
    break;
1210
0
  case 2:
1211
    // C_ADD, C_ADDI, C_ADDI16SP, C_ADDIW, C_ADDW, C_AND, C_ANDI, C_OR, C_SLL...
1212
0
    printOperand(MI, 1, O);
1213
0
    SStream_concat0(O, ", ");
1214
0
    printOperand(MI, 2, O);
1215
0
    return;
1216
0
    break;
1217
1.51k
  case 3:
1218
    // FENCE
1219
1.51k
    printFenceArg(MI, 0, O);
1220
1.51k
    SStream_concat0(O, ", ");
1221
1.51k
    printFenceArg(MI, 1, O);
1222
1.51k
    return;
1223
0
    break;
1224
84.2k
  }
1225
1226
1227
  // Fragment 1 encoded into 2 bits for 3 unique commands.
1228
82.3k
  switch ((Bits >> 14) & 3) {
1229
0
  default: CS_ASSERT(0 && "Invalid command number.");
1230
0
  case 0:
1231
    // PseudoCALL, PseudoTAIL, C_J, C_JAL, C_JALR, C_JR
1232
0
    return;
1233
0
    break;
1234
81.9k
  case 1:
1235
    // PseudoLA, PseudoLI, PseudoLLA, ADD, ADDI, ADDIW, ADDW, AMOADD_D, AMOAD...
1236
81.9k
    SStream_concat0(O, ", ");
1237
81.9k
    break;
1238
354
  case 2:
1239
    // LR_D, LR_D_AQ, LR_D_AQ_RL, LR_D_RL, LR_W, LR_W_AQ, LR_W_AQ_RL, LR_W_RL
1240
354
    SStream_concat0(O, ", (");
1241
354
    printOperand(MI, 1, O);
1242
354
    SStream_concat0(O, ")");
1243
354
    return;
1244
0
    break;
1245
82.3k
  }
1246
1247
1248
  // Fragment 2 encoded into 2 bits for 3 unique commands.
1249
81.9k
  switch ((Bits >> 16) & 3) {
1250
0
  default: CS_ASSERT(0 && "Invalid command number.");
1251
19.9k
  case 0:
1252
    // PseudoLA, PseudoLI, PseudoLLA, ADD, ADDI, ADDIW, ADDW, AND, ANDI, AUIP...
1253
19.9k
    printOperand(MI, 1, O);
1254
19.9k
    break;
1255
2.01k
  case 1:
1256
    // AMOADD_D, AMOADD_D_AQ, AMOADD_D_AQ_RL, AMOADD_D_RL, AMOADD_W, AMOADD_W...
1257
2.01k
    printOperand(MI, 2, O);
1258
2.01k
    break;
1259
59.9k
  case 2:
1260
    // CSRRC, CSRRCI, CSRRS, CSRRSI, CSRRW, CSRRWI
1261
59.9k
    printCSRSystemRegister(MI, 1, O);
1262
59.9k
    SStream_concat0(O, ", ");
1263
59.9k
    printOperand(MI, 2, O);
1264
59.9k
    return;
1265
0
    break;
1266
81.9k
  }
1267
1268
1269
  // Fragment 3 encoded into 2 bits for 4 unique commands.
1270
21.9k
  switch ((Bits >> 18) & 3) {
1271
0
  default: CS_ASSERT(0 && "Invalid command number.");
1272
1.90k
  case 0:
1273
    // PseudoLA, PseudoLI, PseudoLLA, AUIPC, C_BEQZ, C_BNEZ, C_LI, C_LUI, C_M...
1274
1.90k
    return;
1275
0
    break;
1276
18.0k
  case 1:
1277
    // ADD, ADDI, ADDIW, ADDW, AND, ANDI, BEQ, BGE, BGEU, BLT, BLTU, BNE, C_A...
1278
18.0k
    SStream_concat0(O, ", ");
1279
18.0k
    break;
1280
584
  case 2:
1281
    // AMOADD_D, AMOADD_D_AQ, AMOADD_D_AQ_RL, AMOADD_D_RL, AMOADD_W, AMOADD_W...
1282
584
    SStream_concat0(O, ", (");
1283
584
    printOperand(MI, 1, O);
1284
584
    SStream_concat0(O, ")");
1285
584
    return;
1286
0
    break;
1287
1.43k
  case 3:
1288
    // C_FLD, C_FLDSP, C_FLW, C_FLWSP, C_FSD, C_FSDSP, C_FSW, C_FSWSP, C_LD, ...
1289
1.43k
    SStream_concat0(O, "(");
1290
1.43k
    printOperand(MI, 1, O);
1291
1.43k
    SStream_concat0(O, ")");
1292
1.43k
    return;
1293
0
    break;
1294
21.9k
  }
1295
1296
1297
  // Fragment 4 encoded into 1 bits for 2 unique commands.
1298
18.0k
  if ((Bits >> 20) & 1) {
1299
    // FCVT_D_L, FCVT_D_LU, FCVT_LU_D, FCVT_LU_S, FCVT_L_D, FCVT_L_S, FCVT_S_...
1300
6.75k
    printFRMArg(MI, 2, O);
1301
6.75k
    return;
1302
11.2k
  } else {
1303
    // ADD, ADDI, ADDIW, ADDW, AND, ANDI, BEQ, BGE, BGEU, BLT, BLTU, BNE, C_A...
1304
11.2k
    printOperand(MI, 2, O);
1305
11.2k
  }
1306
1307
1308
  // Fragment 5 encoded into 1 bits for 2 unique commands.
1309
11.2k
  if ((Bits >> 21) & 1) {
1310
    // FADD_D, FADD_S, FDIV_D, FDIV_S, FMADD_D, FMADD_S, FMSUB_D, FMSUB_S, FM...
1311
3.95k
    SStream_concat0(O, ", ");
1312
7.34k
  } else {
1313
    // ADD, ADDI, ADDIW, ADDW, AND, ANDI, BEQ, BGE, BGEU, BLT, BLTU, BNE, C_A...
1314
7.34k
    return;
1315
7.34k
  }
1316
1317
1318
  // Fragment 6 encoded into 1 bits for 2 unique commands.
1319
3.95k
  if ((Bits >> 22) & 1) {
1320
    // FMADD_D, FMADD_S, FMSUB_D, FMSUB_S, FNMADD_D, FNMADD_S, FNMSUB_D, FNMS...
1321
2.15k
    printOperand(MI, 3, O);
1322
2.15k
    SStream_concat0(O, ", ");
1323
2.15k
    printFRMArg(MI, 4, O);
1324
2.15k
    return;
1325
2.15k
  } else {
1326
    // FADD_D, FADD_S, FDIV_D, FDIV_S, FMUL_D, FMUL_S, FSUB_D, FSUB_S
1327
1.80k
    printFRMArg(MI, 3, O);
1328
1.80k
    return;
1329
1.80k
  }
1330
1331
3.95k
}
1332
1333
1334
/// getRegisterName - This method is automatically generated by tblgen
1335
/// from the register set description.  This returns the assembler name
1336
/// for the specified register.
1337
static const char *
1338
getRegisterName(unsigned RegNo, unsigned AltIdx)
1339
193k
{
1340
193k
  CS_ASSERT(RegNo && RegNo < 97 && "Invalid register number!");
1341
1342
193k
#ifndef CAPSTONE_DIET
1343
193k
  static const char AsmStrsABIRegAltName[] = {
1344
193k
  /* 0 */ 'f', 's', '1', '0', 0,
1345
193k
  /* 5 */ 'f', 't', '1', '0', 0,
1346
193k
  /* 10 */ 'f', 'a', '0', 0,
1347
193k
  /* 14 */ 'f', 's', '0', 0,
1348
193k
  /* 18 */ 'f', 't', '0', 0,
1349
193k
  /* 22 */ 'f', 's', '1', '1', 0,
1350
193k
  /* 27 */ 'f', 't', '1', '1', 0,
1351
193k
  /* 32 */ 'f', 'a', '1', 0,
1352
193k
  /* 36 */ 'f', 's', '1', 0,
1353
193k
  /* 40 */ 'f', 't', '1', 0,
1354
193k
  /* 44 */ 'f', 'a', '2', 0,
1355
193k
  /* 48 */ 'f', 's', '2', 0,
1356
193k
  /* 52 */ 'f', 't', '2', 0,
1357
193k
  /* 56 */ 'f', 'a', '3', 0,
1358
193k
  /* 60 */ 'f', 's', '3', 0,
1359
193k
  /* 64 */ 'f', 't', '3', 0,
1360
193k
  /* 68 */ 'f', 'a', '4', 0,
1361
193k
  /* 72 */ 'f', 's', '4', 0,
1362
193k
  /* 76 */ 'f', 't', '4', 0,
1363
193k
  /* 80 */ 'f', 'a', '5', 0,
1364
193k
  /* 84 */ 'f', 's', '5', 0,
1365
193k
  /* 88 */ 'f', 't', '5', 0,
1366
193k
  /* 92 */ 'f', 'a', '6', 0,
1367
193k
  /* 96 */ 'f', 's', '6', 0,
1368
193k
  /* 100 */ 'f', 't', '6', 0,
1369
193k
  /* 104 */ 'f', 'a', '7', 0,
1370
193k
  /* 108 */ 'f', 's', '7', 0,
1371
193k
  /* 112 */ 'f', 't', '7', 0,
1372
193k
  /* 116 */ 'f', 's', '8', 0,
1373
193k
  /* 120 */ 'f', 't', '8', 0,
1374
193k
  /* 124 */ 'f', 's', '9', 0,
1375
193k
  /* 128 */ 'f', 't', '9', 0,
1376
193k
  /* 132 */ 'r', 'a', 0,
1377
193k
  /* 135 */ 'z', 'e', 'r', 'o', 0,
1378
193k
  /* 140 */ 'g', 'p', 0,
1379
193k
  /* 143 */ 's', 'p', 0,
1380
193k
  /* 146 */ 't', 'p', 0,
1381
193k
  };
1382
1383
193k
  static const uint8_t RegAsmOffsetABIRegAltName[] = {
1384
193k
    135, 132, 143, 140, 146, 19, 41, 53, 15, 37, 11, 33, 45, 57, 
1385
193k
    69, 81, 93, 105, 49, 61, 73, 85, 97, 109, 117, 125, 1, 23, 
1386
193k
    65, 77, 89, 101, 18, 18, 40, 40, 52, 52, 64, 64, 76, 76, 
1387
193k
    88, 88, 100, 100, 112, 112, 14, 14, 36, 36, 10, 10, 32, 32, 
1388
193k
    44, 44, 56, 56, 68, 68, 80, 80, 92, 92, 104, 104, 48, 48, 
1389
193k
    60, 60, 72, 72, 84, 84, 96, 96, 108, 108, 116, 116, 124, 124, 
1390
193k
    0, 0, 22, 22, 120, 120, 128, 128, 5, 5, 27, 27, 
1391
193k
  };
1392
1393
193k
  static const char AsmStrsNoRegAltName[] = {
1394
193k
  /* 0 */ 'f', '1', '0', 0,
1395
193k
  /* 4 */ 'x', '1', '0', 0,
1396
193k
  /* 8 */ 'f', '2', '0', 0,
1397
193k
  /* 12 */ 'x', '2', '0', 0,
1398
193k
  /* 16 */ 'f', '3', '0', 0,
1399
193k
  /* 20 */ 'x', '3', '0', 0,
1400
193k
  /* 24 */ 'f', '0', 0,
1401
193k
  /* 27 */ 'x', '0', 0,
1402
193k
  /* 30 */ 'f', '1', '1', 0,
1403
193k
  /* 34 */ 'x', '1', '1', 0,
1404
193k
  /* 38 */ 'f', '2', '1', 0,
1405
193k
  /* 42 */ 'x', '2', '1', 0,
1406
193k
  /* 46 */ 'f', '3', '1', 0,
1407
193k
  /* 50 */ 'x', '3', '1', 0,
1408
193k
  /* 54 */ 'f', '1', 0,
1409
193k
  /* 57 */ 'x', '1', 0,
1410
193k
  /* 60 */ 'f', '1', '2', 0,
1411
193k
  /* 64 */ 'x', '1', '2', 0,
1412
193k
  /* 68 */ 'f', '2', '2', 0,
1413
193k
  /* 72 */ 'x', '2', '2', 0,
1414
193k
  /* 76 */ 'f', '2', 0,
1415
193k
  /* 79 */ 'x', '2', 0,
1416
193k
  /* 82 */ 'f', '1', '3', 0,
1417
193k
  /* 86 */ 'x', '1', '3', 0,
1418
193k
  /* 90 */ 'f', '2', '3', 0,
1419
193k
  /* 94 */ 'x', '2', '3', 0,
1420
193k
  /* 98 */ 'f', '3', 0,
1421
193k
  /* 101 */ 'x', '3', 0,
1422
193k
  /* 104 */ 'f', '1', '4', 0,
1423
193k
  /* 108 */ 'x', '1', '4', 0,
1424
193k
  /* 112 */ 'f', '2', '4', 0,
1425
193k
  /* 116 */ 'x', '2', '4', 0,
1426
193k
  /* 120 */ 'f', '4', 0,
1427
193k
  /* 123 */ 'x', '4', 0,
1428
193k
  /* 126 */ 'f', '1', '5', 0,
1429
193k
  /* 130 */ 'x', '1', '5', 0,
1430
193k
  /* 134 */ 'f', '2', '5', 0,
1431
193k
  /* 138 */ 'x', '2', '5', 0,
1432
193k
  /* 142 */ 'f', '5', 0,
1433
193k
  /* 145 */ 'x', '5', 0,
1434
193k
  /* 148 */ 'f', '1', '6', 0,
1435
193k
  /* 152 */ 'x', '1', '6', 0,
1436
193k
  /* 156 */ 'f', '2', '6', 0,
1437
193k
  /* 160 */ 'x', '2', '6', 0,
1438
193k
  /* 164 */ 'f', '6', 0,
1439
193k
  /* 167 */ 'x', '6', 0,
1440
193k
  /* 170 */ 'f', '1', '7', 0,
1441
193k
  /* 174 */ 'x', '1', '7', 0,
1442
193k
  /* 178 */ 'f', '2', '7', 0,
1443
193k
  /* 182 */ 'x', '2', '7', 0,
1444
193k
  /* 186 */ 'f', '7', 0,
1445
193k
  /* 189 */ 'x', '7', 0,
1446
193k
  /* 192 */ 'f', '1', '8', 0,
1447
193k
  /* 196 */ 'x', '1', '8', 0,
1448
193k
  /* 200 */ 'f', '2', '8', 0,
1449
193k
  /* 204 */ 'x', '2', '8', 0,
1450
193k
  /* 208 */ 'f', '8', 0,
1451
193k
  /* 211 */ 'x', '8', 0,
1452
193k
  /* 214 */ 'f', '1', '9', 0,
1453
193k
  /* 218 */ 'x', '1', '9', 0,
1454
193k
  /* 222 */ 'f', '2', '9', 0,
1455
193k
  /* 226 */ 'x', '2', '9', 0,
1456
193k
  /* 230 */ 'f', '9', 0,
1457
193k
  /* 233 */ 'x', '9', 0,
1458
193k
  };
1459
1460
193k
  static const uint8_t RegAsmOffsetNoRegAltName[] = {
1461
193k
    27, 57, 79, 101, 123, 145, 167, 189, 211, 233, 4, 34, 64, 86, 
1462
193k
    108, 130, 152, 174, 196, 218, 12, 42, 72, 94, 116, 138, 160, 182, 
1463
193k
    204, 226, 20, 50, 24, 24, 54, 54, 76, 76, 98, 98, 120, 120, 
1464
193k
    142, 142, 164, 164, 186, 186, 208, 208, 230, 230, 0, 0, 30, 30, 
1465
193k
    60, 60, 82, 82, 104, 104, 126, 126, 148, 148, 170, 170, 192, 192, 
1466
193k
    214, 214, 8, 8, 38, 38, 68, 68, 90, 90, 112, 112, 134, 134, 
1467
193k
    156, 156, 178, 178, 200, 200, 222, 222, 16, 16, 46, 46, 
1468
193k
  };
1469
1470
193k
  switch(AltIdx) {
1471
0
  default: CS_ASSERT(0 && "Invalid register alt name index!");
1472
193k
  case RISCV_ABIRegAltName:
1473
193k
    CS_ASSERT(*(AsmStrsABIRegAltName+RegAsmOffsetABIRegAltName[RegNo-1]) &&
1474
193k
           "Invalid alt name index for register!");
1475
193k
    return AsmStrsABIRegAltName+RegAsmOffsetABIRegAltName[RegNo-1];
1476
0
  case RISCV_NoRegAltName:
1477
0
    CS_ASSERT(*(AsmStrsNoRegAltName+RegAsmOffsetNoRegAltName[RegNo-1]) &&
1478
0
           "Invalid alt name index for register!");
1479
0
    return AsmStrsNoRegAltName+RegAsmOffsetNoRegAltName[RegNo-1];
1480
193k
  }
1481
#else
1482
  return NULL;
1483
#endif
1484
193k
}
1485
1486
#ifdef PRINT_ALIAS_INSTR
1487
#undef PRINT_ALIAS_INSTR
1488
1489
static bool RISCVInstPrinterValidateMCOperand(MCOperand *MCOp,
1490
                  unsigned PredicateIndex);
1491
1492
static bool printAliasInstr(MCInst *MI, SStream * OS, void *info)
1493
215k
{
1494
215k
  MCRegisterInfo *MRI = (MCRegisterInfo *) info;
1495
215k
  const char *AsmString;
1496
215k
  unsigned I = 0;
1497
215k
#define ASMSTRING_CONTAIN_SIZE 64
1498
215k
  unsigned AsmStringLen = 0;
1499
215k
  char tmpString_[ASMSTRING_CONTAIN_SIZE];
1500
215k
  char *tmpString = tmpString_;
1501
215k
  switch (MCInst_getOpcode(MI)) {
1502
18.3k
  default: return false;
1503
1.88k
  case RISCV_ADDI:
1504
1.88k
    if (MCInst_getNumOperands(MI) == 3 &&
1505
1.88k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1506
1.49k
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1507
1.29k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1508
1.29k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
1509
      // (ADDI X0, X0, 0)
1510
593
      AsmString = "nop";
1511
593
      break;
1512
593
    }
1513
1.29k
    if (MCInst_getNumOperands(MI) == 3 &&
1514
1.29k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1515
1.29k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1516
1.29k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1517
1.29k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1518
1.29k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1519
1.29k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
1520
      // (ADDI GPR:$rd, GPR:$rs, 0)
1521
152
      AsmString = "mv $\x01, $\x02";
1522
152
      break;
1523
152
    }
1524
1.13k
    return false;
1525
578
  case RISCV_ADDIW:
1526
578
    if (MCInst_getNumOperands(MI) == 3 &&
1527
578
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1528
578
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1529
578
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1530
578
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1531
578
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1532
578
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
1533
      // (ADDIW GPR:$rd, GPR:$rs, 0)
1534
143
      AsmString = "sext.w $\x01, $\x02";
1535
143
      break;
1536
143
    }
1537
435
    return false;
1538
475
  case RISCV_BEQ:
1539
475
    if (MCInst_getNumOperands(MI) == 3 &&
1540
475
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1541
475
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1542
475
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1543
192
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1544
      // (BEQ GPR:$rs, X0, simm13_lsb0:$offset)
1545
192
      AsmString = "beqz $\x01, $\x03";
1546
192
      break;
1547
192
    }
1548
283
    return false;
1549
1.18k
  case RISCV_BGE:
1550
1.18k
    if (MCInst_getNumOperands(MI) == 3 &&
1551
1.18k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1552
329
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1553
329
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1554
329
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1555
      // (BGE X0, GPR:$rs, simm13_lsb0:$offset)
1556
329
      AsmString = "blez $\x02, $\x03";
1557
329
      break;
1558
329
    }
1559
853
    if (MCInst_getNumOperands(MI) == 3 &&
1560
853
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1561
853
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1562
853
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1563
363
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1564
      // (BGE GPR:$rs, X0, simm13_lsb0:$offset)
1565
363
      AsmString = "bgez $\x01, $\x03";
1566
363
      break;
1567
363
    }
1568
490
    return false;
1569
746
  case RISCV_BLT:
1570
746
    if (MCInst_getNumOperands(MI) == 3 &&
1571
746
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1572
746
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1573
746
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1574
265
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1575
      // (BLT GPR:$rs, X0, simm13_lsb0:$offset)
1576
265
      AsmString = "bltz $\x01, $\x03";
1577
265
      break;
1578
265
    }
1579
481
    if (MCInst_getNumOperands(MI) == 3 &&
1580
481
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1581
132
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1582
132
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1583
132
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1584
      // (BLT X0, GPR:$rs, simm13_lsb0:$offset)
1585
132
      AsmString = "bgtz $\x02, $\x03";
1586
132
      break;
1587
132
    }
1588
349
    return false;
1589
486
  case RISCV_BNE:
1590
486
    if (MCInst_getNumOperands(MI) == 3 &&
1591
486
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1592
486
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1593
486
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1594
119
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1595
      // (BNE GPR:$rs, X0, simm13_lsb0:$offset)
1596
119
      AsmString = "bnez $\x01, $\x03";
1597
119
      break;
1598
119
    }
1599
367
    return false;
1600
17.6k
  case RISCV_CSRRC:
1601
17.6k
    if (MCInst_getNumOperands(MI) == 3 &&
1602
17.6k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1603
2.50k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1604
2.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1605
      // (CSRRC X0, csr_sysreg:$csr, GPR:$rs)
1606
2.50k
      AsmString = "csrc $\xFF\x02\x01, $\x03";
1607
2.50k
      break;
1608
2.50k
    }
1609
15.1k
    return false;
1610
20.4k
  case RISCV_CSRRCI:
1611
20.4k
    if (MCInst_getNumOperands(MI) == 3 &&
1612
20.4k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0) {
1613
      // (CSRRCI X0, csr_sysreg:$csr, uimm5:$imm)
1614
2.08k
      AsmString = "csrci $\xFF\x02\x01, $\x03";
1615
2.08k
      break;
1616
2.08k
    }
1617
18.3k
    return false;
1618
36.6k
  case RISCV_CSRRS:
1619
36.6k
    if (MCInst_getNumOperands(MI) == 3 &&
1620
36.6k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1621
36.6k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1622
36.6k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1623
36.6k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3 &&
1624
750
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1625
      // (CSRRS GPR:$rd, 3, X0)
1626
179
      AsmString = "frcsr $\x01";
1627
179
      break;
1628
179
    }
1629
36.4k
    if (MCInst_getNumOperands(MI) == 3 &&
1630
36.4k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1631
36.4k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1632
36.4k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1633
36.4k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2 &&
1634
833
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1635
      // (CSRRS GPR:$rd, 2, X0)
1636
273
      AsmString = "frrm $\x01";
1637
273
      break;
1638
273
    }
1639
36.2k
    if (MCInst_getNumOperands(MI) == 3 &&
1640
36.2k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1641
36.2k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1642
36.2k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1643
36.2k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1 &&
1644
368
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1645
      // (CSRRS GPR:$rd, 1, X0)
1646
88
      AsmString = "frflags $\x01";
1647
88
      break;
1648
88
    }
1649
36.1k
    if (MCInst_getNumOperands(MI) == 3 &&
1650
36.1k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1651
36.1k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1652
36.1k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1653
36.1k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3074 &&
1654
521
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1655
      // (CSRRS GPR:$rd, 3074, X0)
1656
286
      AsmString = "rdinstret $\x01";
1657
286
      break;
1658
286
    }
1659
35.8k
    if (MCInst_getNumOperands(MI) == 3 &&
1660
35.8k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1661
35.8k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1662
35.8k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1663
35.8k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3072 &&
1664
2.43k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1665
      // (CSRRS GPR:$rd, 3072, X0)
1666
1.40k
      AsmString = "rdcycle $\x01";
1667
1.40k
      break;
1668
1.40k
    }
1669
34.4k
    if (MCInst_getNumOperands(MI) == 3 &&
1670
34.4k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1671
34.4k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1672
34.4k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1673
34.4k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3073 &&
1674
1.06k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1675
      // (CSRRS GPR:$rd, 3073, X0)
1676
282
      AsmString = "rdtime $\x01";
1677
282
      break;
1678
282
    }
1679
34.1k
    if (MCInst_getNumOperands(MI) == 3 &&
1680
34.1k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1681
34.1k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1682
34.1k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1683
34.1k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3202 &&
1684
1.54k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1685
      // (CSRRS GPR:$rd, 3202, X0)
1686
490
      AsmString = "rdinstreth $\x01";
1687
490
      break;
1688
490
    }
1689
33.6k
    if (MCInst_getNumOperands(MI) == 3 &&
1690
33.6k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1691
33.6k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1692
33.6k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1693
33.6k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3200 &&
1694
471
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1695
      // (CSRRS GPR:$rd, 3200, X0)
1696
180
      AsmString = "rdcycleh $\x01";
1697
180
      break;
1698
180
    }
1699
33.4k
    if (MCInst_getNumOperands(MI) == 3 &&
1700
33.4k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1701
33.4k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1702
33.4k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1703
33.4k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3201 &&
1704
525
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1705
      // (CSRRS GPR:$rd, 3201, X0)
1706
273
      AsmString = "rdtimeh $\x01";
1707
273
      break;
1708
273
    }
1709
33.2k
    if (MCInst_getNumOperands(MI) == 3 &&
1710
33.2k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1711
33.2k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1712
33.2k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1713
      // (CSRRS GPR:$rd, csr_sysreg:$csr, X0)
1714
5.44k
      AsmString = "csrr $\x01, $\xFF\x02\x01";
1715
5.44k
      break;
1716
5.44k
    }
1717
27.7k
    if (MCInst_getNumOperands(MI) == 3 &&
1718
27.7k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1719
4.41k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1720
4.41k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1721
      // (CSRRS X0, csr_sysreg:$csr, GPR:$rs)
1722
4.41k
      AsmString = "csrs $\xFF\x02\x01, $\x03";
1723
4.41k
      break;
1724
4.41k
    }
1725
23.3k
    return false;
1726
16.0k
  case RISCV_CSRRSI:
1727
16.0k
    if (MCInst_getNumOperands(MI) == 3 &&
1728
16.0k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0) {
1729
      // (CSRRSI X0, csr_sysreg:$csr, uimm5:$imm)
1730
1.05k
      AsmString = "csrsi $\xFF\x02\x01, $\x03";
1731
1.05k
      break;
1732
1.05k
    }
1733
14.9k
    return false;
1734
26.1k
  case RISCV_CSRRW:
1735
26.1k
    if (MCInst_getNumOperands(MI) == 3 &&
1736
26.1k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1737
4.40k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1738
4.40k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3 &&
1739
1.23k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1740
1.23k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1741
      // (CSRRW X0, 3, GPR:$rs)
1742
1.23k
      AsmString = "fscsr $\x03";
1743
1.23k
      break;
1744
1.23k
    }
1745
24.9k
    if (MCInst_getNumOperands(MI) == 3 &&
1746
24.9k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1747
3.16k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1748
3.16k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2 &&
1749
358
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1750
358
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1751
      // (CSRRW X0, 2, GPR:$rs)
1752
358
      AsmString = "fsrm $\x03";
1753
358
      break;
1754
358
    }
1755
24.5k
    if (MCInst_getNumOperands(MI) == 3 &&
1756
24.5k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1757
2.80k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1758
2.80k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1 &&
1759
196
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1760
196
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1761
      // (CSRRW X0, 1, GPR:$rs)
1762
196
      AsmString = "fsflags $\x03";
1763
196
      break;
1764
196
    }
1765
24.3k
    if (MCInst_getNumOperands(MI) == 3 &&
1766
24.3k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1767
2.61k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1768
2.61k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1769
      // (CSRRW X0, csr_sysreg:$csr, GPR:$rs)
1770
2.61k
      AsmString = "csrw $\xFF\x02\x01, $\x03";
1771
2.61k
      break;
1772
2.61k
    }
1773
21.7k
    if (MCInst_getNumOperands(MI) == 3 &&
1774
21.7k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1775
21.7k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1776
21.7k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1777
21.7k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3 &&
1778
183
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1779
183
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1780
      // (CSRRW GPR:$rd, 3, GPR:$rs)
1781
183
      AsmString = "fscsr $\x01, $\x03";
1782
183
      break;
1783
183
    }
1784
21.5k
    if (MCInst_getNumOperands(MI) == 3 &&
1785
21.5k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1786
21.5k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1787
21.5k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1788
21.5k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2 &&
1789
589
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1790
589
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1791
      // (CSRRW GPR:$rd, 2, GPR:$rs)
1792
589
      AsmString = "fsrm $\x01, $\x03";
1793
589
      break;
1794
589
    }
1795
20.9k
    if (MCInst_getNumOperands(MI) == 3 &&
1796
20.9k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1797
20.9k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1798
20.9k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1799
20.9k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1 &&
1800
987
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1801
987
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1802
      // (CSRRW GPR:$rd, 1, GPR:$rs)
1803
987
      AsmString = "fsflags $\x01, $\x03";
1804
987
      break;
1805
987
    }
1806
19.9k
    return false;
1807
16.2k
  case RISCV_CSRRWI:
1808
16.2k
    if (MCInst_getNumOperands(MI) == 3 &&
1809
16.2k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1810
3.90k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1811
3.90k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2) {
1812
      // (CSRRWI X0, 2, uimm5:$imm)
1813
340
      AsmString = "fsrmi $\x03";
1814
340
      break;
1815
340
    }
1816
15.9k
    if (MCInst_getNumOperands(MI) == 3 &&
1817
15.9k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1818
3.56k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1819
3.56k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1) {
1820
      // (CSRRWI X0, 1, uimm5:$imm)
1821
646
      AsmString = "fsflagsi $\x03";
1822
646
      break;
1823
646
    }
1824
15.2k
    if (MCInst_getNumOperands(MI) == 3 &&
1825
15.2k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0) {
1826
      // (CSRRWI X0, csr_sysreg:$csr, uimm5:$imm)
1827
2.92k
      AsmString = "csrwi $\xFF\x02\x01, $\x03";
1828
2.92k
      break;
1829
2.92k
    }
1830
12.3k
    if (MCInst_getNumOperands(MI) == 3 &&
1831
12.3k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1832
12.3k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1833
12.3k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1834
12.3k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2) {
1835
      // (CSRRWI GPR:$rd, 2, uimm5:$imm)
1836
427
      AsmString = "fsrmi $\x01, $\x03";
1837
427
      break;
1838
427
    }
1839
11.9k
    if (MCInst_getNumOperands(MI) == 3 &&
1840
11.9k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1841
11.9k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1842
11.9k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1843
11.9k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1) {
1844
      // (CSRRWI GPR:$rd, 1, uimm5:$imm)
1845
548
      AsmString = "fsflagsi $\x01, $\x03";
1846
548
      break;
1847
548
    }
1848
11.3k
    return false;
1849
2.34k
  case RISCV_FADD_D:
1850
2.34k
    if (MCInst_getNumOperands(MI) == 4 &&
1851
2.34k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1852
2.34k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1853
2.34k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1854
2.34k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1855
2.34k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1856
2.34k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
1857
2.34k
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
1858
2.34k
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
1859
      // (FADD_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
1860
1.61k
      AsmString = "fadd.d $\x01, $\x02, $\x03";
1861
1.61k
      break;
1862
1.61k
    }
1863
730
    return false;
1864
1.50k
  case RISCV_FADD_S:
1865
1.50k
    if (MCInst_getNumOperands(MI) == 4 &&
1866
1.50k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1867
1.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1868
1.50k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1869
1.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1870
1.50k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1871
1.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
1872
1.50k
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
1873
1.50k
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
1874
      // (FADD_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
1875
228
      AsmString = "fadd.s $\x01, $\x02, $\x03";
1876
228
      break;
1877
228
    }
1878
1.27k
    return false;
1879
1.99k
  case RISCV_FCVT_D_L:
1880
1.99k
    if (MCInst_getNumOperands(MI) == 3 &&
1881
1.99k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1882
1.99k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1883
1.99k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1884
1.99k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1885
1.99k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1886
1.99k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1887
      // (FCVT_D_L FPR64:$rd, GPR:$rs1, { 1, 1, 1 })
1888
965
      AsmString = "fcvt.d.l $\x01, $\x02";
1889
965
      break;
1890
965
    }
1891
1.03k
    return false;
1892
1.32k
  case RISCV_FCVT_D_LU:
1893
1.32k
    if (MCInst_getNumOperands(MI) == 3 &&
1894
1.32k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1895
1.32k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1896
1.32k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1897
1.32k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1898
1.32k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1899
1.32k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1900
      // (FCVT_D_LU FPR64:$rd, GPR:$rs1, { 1, 1, 1 })
1901
859
      AsmString = "fcvt.d.lu $\x01, $\x02";
1902
859
      break;
1903
859
    }
1904
463
    return false;
1905
1.41k
  case RISCV_FCVT_LU_D:
1906
1.41k
    if (MCInst_getNumOperands(MI) == 3 &&
1907
1.41k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1908
1.41k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1909
1.41k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1910
1.41k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1911
1.41k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1912
1.41k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1913
      // (FCVT_LU_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
1914
767
      AsmString = "fcvt.lu.d $\x01, $\x02";
1915
767
      break;
1916
767
    }
1917
647
    return false;
1918
2.86k
  case RISCV_FCVT_LU_S:
1919
2.86k
    if (MCInst_getNumOperands(MI) == 3 &&
1920
2.86k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1921
2.86k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1922
2.86k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1923
2.86k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1924
2.86k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1925
2.86k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1926
      // (FCVT_LU_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
1927
1.28k
      AsmString = "fcvt.lu.s $\x01, $\x02";
1928
1.28k
      break;
1929
1.28k
    }
1930
1.57k
    return false;
1931
1.47k
  case RISCV_FCVT_L_D:
1932
1.47k
    if (MCInst_getNumOperands(MI) == 3 &&
1933
1.47k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1934
1.47k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1935
1.47k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1936
1.47k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1937
1.47k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1938
1.47k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1939
      // (FCVT_L_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
1940
526
      AsmString = "fcvt.l.d $\x01, $\x02";
1941
526
      break;
1942
526
    }
1943
945
    return false;
1944
1.50k
  case RISCV_FCVT_L_S:
1945
1.50k
    if (MCInst_getNumOperands(MI) == 3 &&
1946
1.50k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1947
1.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1948
1.50k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1949
1.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1950
1.50k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1951
1.50k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1952
      // (FCVT_L_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
1953
374
      AsmString = "fcvt.l.s $\x01, $\x02";
1954
374
      break;
1955
374
    }
1956
1.13k
    return false;
1957
1.09k
  case RISCV_FCVT_S_D:
1958
1.09k
    if (MCInst_getNumOperands(MI) == 3 &&
1959
1.09k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1960
1.09k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1961
1.09k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1962
1.09k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1963
1.09k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1964
1.09k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1965
      // (FCVT_S_D FPR32:$rd, FPR64:$rs1, { 1, 1, 1 })
1966
350
      AsmString = "fcvt.s.d $\x01, $\x02";
1967
350
      break;
1968
350
    }
1969
742
    return false;
1970
1.72k
  case RISCV_FCVT_S_L:
1971
1.72k
    if (MCInst_getNumOperands(MI) == 3 &&
1972
1.72k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1973
1.72k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1974
1.72k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1975
1.72k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1976
1.72k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1977
1.72k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1978
      // (FCVT_S_L FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
1979
920
      AsmString = "fcvt.s.l $\x01, $\x02";
1980
920
      break;
1981
920
    }
1982
800
    return false;
1983
998
  case RISCV_FCVT_S_LU:
1984
998
    if (MCInst_getNumOperands(MI) == 3 &&
1985
998
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1986
998
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1987
998
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1988
998
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1989
998
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1990
998
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1991
      // (FCVT_S_LU FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
1992
575
      AsmString = "fcvt.s.lu $\x01, $\x02";
1993
575
      break;
1994
575
    }
1995
423
    return false;
1996
796
  case RISCV_FCVT_S_W:
1997
796
    if (MCInst_getNumOperands(MI) == 3 &&
1998
796
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1999
796
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2000
796
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2001
796
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2002
796
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2003
796
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2004
      // (FCVT_S_W FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
2005
569
      AsmString = "fcvt.s.w $\x01, $\x02";
2006
569
      break;
2007
569
    }
2008
227
    return false;
2009
788
  case RISCV_FCVT_S_WU:
2010
788
    if (MCInst_getNumOperands(MI) == 3 &&
2011
788
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2012
788
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2013
788
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2014
788
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2015
788
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2016
788
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2017
      // (FCVT_S_WU FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
2018
390
      AsmString = "fcvt.s.wu $\x01, $\x02";
2019
390
      break;
2020
390
    }
2021
398
    return false;
2022
739
  case RISCV_FCVT_WU_D:
2023
739
    if (MCInst_getNumOperands(MI) == 3 &&
2024
739
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2025
739
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2026
739
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2027
739
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2028
739
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2029
739
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2030
      // (FCVT_WU_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
2031
71
      AsmString = "fcvt.wu.d $\x01, $\x02";
2032
71
      break;
2033
71
    }
2034
668
    return false;
2035
1.97k
  case RISCV_FCVT_WU_S:
2036
1.97k
    if (MCInst_getNumOperands(MI) == 3 &&
2037
1.97k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2038
1.97k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2039
1.97k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2040
1.97k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2041
1.97k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2042
1.97k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2043
      // (FCVT_WU_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
2044
1.09k
      AsmString = "fcvt.wu.s $\x01, $\x02";
2045
1.09k
      break;
2046
1.09k
    }
2047
882
    return false;
2048
979
  case RISCV_FCVT_W_D:
2049
979
    if (MCInst_getNumOperands(MI) == 3 &&
2050
979
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2051
979
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2052
979
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2053
979
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2054
979
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2055
979
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2056
      // (FCVT_W_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
2057
866
      AsmString = "fcvt.w.d $\x01, $\x02";
2058
866
      break;
2059
866
    }
2060
113
    return false;
2061
1.02k
  case RISCV_FCVT_W_S:
2062
1.02k
    if (MCInst_getNumOperands(MI) == 3 &&
2063
1.02k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2064
1.02k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2065
1.02k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2066
1.02k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2067
1.02k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2068
1.02k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2069
      // (FCVT_W_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
2070
472
      AsmString = "fcvt.w.s $\x01, $\x02";
2071
472
      break;
2072
472
    }
2073
548
    return false;
2074
364
  case RISCV_FDIV_D:
2075
364
    if (MCInst_getNumOperands(MI) == 4 &&
2076
364
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2077
364
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2078
364
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2079
364
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2080
364
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2081
364
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2082
364
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2083
364
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2084
      // (FDIV_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
2085
112
      AsmString = "fdiv.d $\x01, $\x02, $\x03";
2086
112
      break;
2087
112
    }
2088
252
    return false;
2089
1.32k
  case RISCV_FDIV_S:
2090
1.32k
    if (MCInst_getNumOperands(MI) == 4 &&
2091
1.32k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2092
1.32k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2093
1.32k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2094
1.32k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2095
1.32k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2096
1.32k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2097
1.32k
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2098
1.32k
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2099
      // (FDIV_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
2100
876
      AsmString = "fdiv.s $\x01, $\x02, $\x03";
2101
876
      break;
2102
876
    }
2103
446
    return false;
2104
2.18k
  case RISCV_FENCE:
2105
2.18k
    if (MCInst_getNumOperands(MI) == 2 &&
2106
2.18k
        MCOperand_isImm(MCInst_getOperand(MI, 0)) &&
2107
2.18k
        MCOperand_getImm(MCInst_getOperand(MI, 0)) == 15 &&
2108
1.07k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
2109
1.07k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 15) {
2110
      // (FENCE 15, 15)
2111
122
      AsmString = "fence";
2112
122
      break;
2113
122
    }
2114
2.06k
    return false;
2115
967
  case RISCV_FMADD_D:
2116
967
    if (MCInst_getNumOperands(MI) == 5 &&
2117
967
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2118
967
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2119
967
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2120
967
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2121
967
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2122
967
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2123
967
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2124
967
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2125
967
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2126
967
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2127
      // (FMADD_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2128
229
      AsmString = "fmadd.d $\x01, $\x02, $\x03, $\x04";
2129
229
      break;
2130
229
    }
2131
738
    return false;
2132
785
  case RISCV_FMADD_S:
2133
785
    if (MCInst_getNumOperands(MI) == 5 &&
2134
785
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2135
785
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2136
785
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2137
785
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2138
785
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2139
785
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2140
785
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2141
785
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2142
785
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2143
785
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2144
      // (FMADD_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2145
386
      AsmString = "fmadd.s $\x01, $\x02, $\x03, $\x04";
2146
386
      break;
2147
386
    }
2148
399
    return false;
2149
1.74k
  case RISCV_FMSUB_D:
2150
1.74k
    if (MCInst_getNumOperands(MI) == 5 &&
2151
1.74k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2152
1.74k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2153
1.74k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2154
1.74k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2155
1.74k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2156
1.74k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2157
1.74k
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2158
1.74k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2159
1.74k
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2160
1.74k
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2161
      // (FMSUB_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2162
413
      AsmString = "fmsub.d $\x01, $\x02, $\x03, $\x04";
2163
413
      break;
2164
413
    }
2165
1.33k
    return false;
2166
538
  case RISCV_FMSUB_S:
2167
538
    if (MCInst_getNumOperands(MI) == 5 &&
2168
538
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2169
538
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2170
538
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2171
538
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2172
538
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2173
538
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2174
538
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2175
538
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2176
538
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2177
538
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2178
      // (FMSUB_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2179
136
      AsmString = "fmsub.s $\x01, $\x02, $\x03, $\x04";
2180
136
      break;
2181
136
    }
2182
402
    return false;
2183
277
  case RISCV_FMUL_D:
2184
277
    if (MCInst_getNumOperands(MI) == 4 &&
2185
277
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2186
277
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2187
277
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2188
277
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2189
277
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2190
277
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2191
277
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2192
277
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2193
      // (FMUL_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
2194
104
      AsmString = "fmul.d $\x01, $\x02, $\x03";
2195
104
      break;
2196
104
    }
2197
173
    return false;
2198
950
  case RISCV_FMUL_S:
2199
950
    if (MCInst_getNumOperands(MI) == 4 &&
2200
950
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2201
950
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2202
950
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2203
950
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2204
950
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2205
950
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2206
950
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2207
950
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2208
      // (FMUL_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
2209
538
      AsmString = "fmul.s $\x01, $\x02, $\x03";
2210
538
      break;
2211
538
    }
2212
412
    return false;
2213
429
  case RISCV_FNMADD_D:
2214
429
    if (MCInst_getNumOperands(MI) == 5 &&
2215
429
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2216
429
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2217
429
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2218
429
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2219
429
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2220
429
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2221
429
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2222
429
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2223
429
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2224
429
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2225
      // (FNMADD_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2226
139
      AsmString = "fnmadd.d $\x01, $\x02, $\x03, $\x04";
2227
139
      break;
2228
139
    }
2229
290
    return false;
2230
1.12k
  case RISCV_FNMADD_S:
2231
1.12k
    if (MCInst_getNumOperands(MI) == 5 &&
2232
1.12k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2233
1.12k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2234
1.12k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2235
1.12k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2236
1.12k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2237
1.12k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2238
1.12k
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2239
1.12k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2240
1.12k
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2241
1.12k
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2242
      // (FNMADD_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2243
543
      AsmString = "fnmadd.s $\x01, $\x02, $\x03, $\x04";
2244
543
      break;
2245
543
    }
2246
585
    return false;
2247
670
  case RISCV_FNMSUB_D:
2248
670
    if (MCInst_getNumOperands(MI) == 5 &&
2249
670
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2250
670
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2251
670
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2252
670
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2253
670
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2254
670
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2255
670
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2256
670
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2257
670
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2258
670
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2259
      // (FNMSUB_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2260
269
      AsmString = "fnmsub.d $\x01, $\x02, $\x03, $\x04";
2261
269
      break;
2262
269
    }
2263
401
    return false;
2264
799
  case RISCV_FNMSUB_S:
2265
799
    if (MCInst_getNumOperands(MI) == 5 &&
2266
799
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2267
799
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2268
799
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2269
799
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2270
799
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2271
799
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2272
799
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2273
799
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2274
799
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2275
799
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2276
      // (FNMSUB_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2277
317
      AsmString = "fnmsub.s $\x01, $\x02, $\x03, $\x04";
2278
317
      break;
2279
317
    }
2280
482
    return false;
2281
579
  case RISCV_FSGNJN_D:
2282
579
    if (MCInst_getNumOperands(MI) == 3 &&
2283
579
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2284
579
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2285
579
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2286
579
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2287
579
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2288
579
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2289
      // (FSGNJN_D FPR64:$rd, FPR64:$rs, FPR64:$rs)
2290
135
      AsmString = "fneg.d $\x01, $\x02";
2291
135
      break;
2292
135
    }
2293
444
    return false;
2294
1.22k
  case RISCV_FSGNJN_S:
2295
1.22k
    if (MCInst_getNumOperands(MI) == 3 &&
2296
1.22k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2297
1.22k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2298
1.22k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2299
1.22k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2300
1.22k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2301
1.22k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2302
      // (FSGNJN_S FPR32:$rd, FPR32:$rs, FPR32:$rs)
2303
834
      AsmString = "fneg.s $\x01, $\x02";
2304
834
      break;
2305
834
    }
2306
386
    return false;
2307
235
  case RISCV_FSGNJX_D:
2308
235
    if (MCInst_getNumOperands(MI) == 3 &&
2309
235
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2310
235
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2311
235
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2312
235
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2313
235
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2314
235
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2315
      // (FSGNJX_D FPR64:$rd, FPR64:$rs, FPR64:$rs)
2316
105
      AsmString = "fabs.d $\x01, $\x02";
2317
105
      break;
2318
105
    }
2319
130
    return false;
2320
2.22k
  case RISCV_FSGNJX_S:
2321
2.22k
    if (MCInst_getNumOperands(MI) == 3 &&
2322
2.22k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2323
2.22k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2324
2.22k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2325
2.22k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2326
2.22k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2327
2.22k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2328
      // (FSGNJX_S FPR32:$rd, FPR32:$rs, FPR32:$rs)
2329
582
      AsmString = "fabs.s $\x01, $\x02";
2330
582
      break;
2331
582
    }
2332
1.63k
    return false;
2333
1.22k
  case RISCV_FSGNJ_D:
2334
1.22k
    if (MCInst_getNumOperands(MI) == 3 &&
2335
1.22k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2336
1.22k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2337
1.22k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2338
1.22k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2339
1.22k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2340
1.22k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2341
      // (FSGNJ_D FPR64:$rd, FPR64:$rs, FPR64:$rs)
2342
214
      AsmString = "fmv.d $\x01, $\x02";
2343
214
      break;
2344
214
    }
2345
1.00k
    return false;
2346
2.50k
  case RISCV_FSGNJ_S:
2347
2.50k
    if (MCInst_getNumOperands(MI) == 3 &&
2348
2.50k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2349
2.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2350
2.50k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2351
2.50k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2352
2.50k
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2353
2.50k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2354
      // (FSGNJ_S FPR32:$rd, FPR32:$rs, FPR32:$rs)
2355
1.96k
      AsmString = "fmv.s $\x01, $\x02";
2356
1.96k
      break;
2357
1.96k
    }
2358
534
    return false;
2359
2.04k
  case RISCV_FSQRT_D:
2360
2.04k
    if (MCInst_getNumOperands(MI) == 3 &&
2361
2.04k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2362
2.04k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2363
2.04k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2364
2.04k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2365
2.04k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2366
2.04k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2367
      // (FSQRT_D FPR64:$rd, FPR64:$rs1, { 1, 1, 1 })
2368
1.13k
      AsmString = "fsqrt.d $\x01, $\x02";
2369
1.13k
      break;
2370
1.13k
    }
2371
904
    return false;
2372
1.53k
  case RISCV_FSQRT_S:
2373
1.53k
    if (MCInst_getNumOperands(MI) == 3 &&
2374
1.53k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2375
1.53k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2376
1.53k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2377
1.53k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2378
1.53k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2379
1.53k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2380
      // (FSQRT_S FPR32:$rd, FPR32:$rs1, { 1, 1, 1 })
2381
586
      AsmString = "fsqrt.s $\x01, $\x02";
2382
586
      break;
2383
586
    }
2384
949
    return false;
2385
741
  case RISCV_FSUB_D:
2386
741
    if (MCInst_getNumOperands(MI) == 4 &&
2387
741
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2388
741
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2389
741
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2390
741
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2391
741
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2392
741
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2393
741
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2394
741
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2395
      // (FSUB_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
2396
392
      AsmString = "fsub.d $\x01, $\x02, $\x03";
2397
392
      break;
2398
392
    }
2399
349
    return false;
2400
484
  case RISCV_FSUB_S:
2401
484
    if (MCInst_getNumOperands(MI) == 4 &&
2402
484
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2403
484
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2404
484
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2405
484
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2406
484
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2407
484
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2408
484
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2409
484
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2410
      // (FSUB_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
2411
376
      AsmString = "fsub.s $\x01, $\x02, $\x03";
2412
376
      break;
2413
376
    }
2414
108
    return false;
2415
1.43k
  case RISCV_JAL:
2416
1.43k
    if (MCInst_getNumOperands(MI) == 2 &&
2417
1.43k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2418
322
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 1), 2)) {
2419
      // (JAL X0, simm21_lsb0_jal:$offset)
2420
322
      AsmString = "j $\x02";
2421
322
      break;
2422
322
    }
2423
1.10k
    if (MCInst_getNumOperands(MI) == 2 &&
2424
1.10k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X1 &&
2425
141
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 1), 2)) {
2426
      // (JAL X1, simm21_lsb0_jal:$offset)
2427
141
      AsmString = "jal $\x02";
2428
141
      break;
2429
141
    }
2430
967
    return false;
2431
1.80k
  case RISCV_JALR:
2432
1.80k
    if (MCInst_getNumOperands(MI) == 3 &&
2433
1.80k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2434
1.51k
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X1 &&
2435
681
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2436
681
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
2437
      // (JALR X0, X1, 0)
2438
368
      AsmString = "ret";
2439
368
      break;
2440
368
    }
2441
1.43k
    if (MCInst_getNumOperands(MI) == 3 &&
2442
1.43k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2443
1.14k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2444
1.14k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2445
1.14k
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2446
1.14k
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
2447
      // (JALR X0, GPR:$rs, 0)
2448
170
      AsmString = "jr $\x02";
2449
170
      break;
2450
170
    }
2451
1.26k
    if (MCInst_getNumOperands(MI) == 3 &&
2452
1.26k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X1 &&
2453
215
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2454
215
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2455
215
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2456
215
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
2457
      // (JALR X1, GPR:$rs, 0)
2458
54
      AsmString = "jalr $\x02";
2459
54
      break;
2460
54
    }
2461
1.21k
    return false;
2462
2.14k
  case RISCV_SFENCE_VMA:
2463
2.14k
    if (MCInst_getNumOperands(MI) == 2 &&
2464
2.14k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2465
1.36k
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0) {
2466
      // (SFENCE_VMA X0, X0)
2467
945
      AsmString = "sfence.vma";
2468
945
      break;
2469
945
    }
2470
1.19k
    if (MCInst_getNumOperands(MI) == 2 &&
2471
1.19k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2472
1.19k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2473
1.19k
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0) {
2474
      // (SFENCE_VMA GPR:$rs, X0)
2475
405
      AsmString = "sfence.vma $\x01";
2476
405
      break;
2477
405
    }
2478
793
    return false;
2479
2.11k
  case RISCV_SLT:
2480
2.11k
    if (MCInst_getNumOperands(MI) == 3 &&
2481
2.11k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2482
2.11k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2483
2.11k
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2484
2.11k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2485
2.11k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
2486
      // (SLT GPR:$rd, GPR:$rs, X0)
2487
707
      AsmString = "sltz $\x01, $\x02";
2488
707
      break;
2489
707
    }
2490
1.40k
    if (MCInst_getNumOperands(MI) == 3 &&
2491
1.40k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2492
1.40k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2493
1.40k
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2494
922
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2495
922
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2496
      // (SLT GPR:$rd, X0, GPR:$rs)
2497
922
      AsmString = "sgtz $\x01, $\x03";
2498
922
      break;
2499
922
    }
2500
481
    return false;
2501
451
  case RISCV_SLTIU:
2502
451
    if (MCInst_getNumOperands(MI) == 3 &&
2503
451
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2504
451
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2505
451
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2506
451
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2507
451
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2508
451
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 1) {
2509
      // (SLTIU GPR:$rd, GPR:$rs, 1)
2510
136
      AsmString = "seqz $\x01, $\x02";
2511
136
      break;
2512
136
    }
2513
315
    return false;
2514
482
  case RISCV_SLTU:
2515
482
    if (MCInst_getNumOperands(MI) == 3 &&
2516
482
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2517
482
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2518
482
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2519
392
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2520
392
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2521
      // (SLTU GPR:$rd, X0, GPR:$rs)
2522
392
      AsmString = "snez $\x01, $\x03";
2523
392
      break;
2524
392
    }
2525
90
    return false;
2526
197
  case RISCV_SUB:
2527
197
    if (MCInst_getNumOperands(MI) == 3 &&
2528
197
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2529
197
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2530
197
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2531
101
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2532
101
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2533
      // (SUB GPR:$rd, X0, GPR:$rs)
2534
101
      AsmString = "neg $\x01, $\x03";
2535
101
      break;
2536
101
    }
2537
96
    return false;
2538
170
  case RISCV_SUBW:
2539
170
    if (MCInst_getNumOperands(MI) == 3 &&
2540
170
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2541
170
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2542
170
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2543
102
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2544
102
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2545
      // (SUBW GPR:$rd, X0, GPR:$rs)
2546
102
      AsmString = "negw $\x01, $\x03";
2547
102
      break;
2548
102
    }
2549
68
    return false;
2550
680
  case RISCV_XORI:
2551
680
    if (MCInst_getNumOperands(MI) == 3 &&
2552
680
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2553
680
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2554
680
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2555
680
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2556
680
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2557
680
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == -1) {
2558
      // (XORI GPR:$rd, GPR:$rs, -1)
2559
273
      AsmString = "not $\x01, $\x02";
2560
273
      break;
2561
273
    }
2562
407
    return false;
2563
215k
  }
2564
2565
59.7k
  AsmStringLen = strlen(AsmString);
2566
59.7k
  if (ASMSTRING_CONTAIN_SIZE - 1 < AsmStringLen)
2567
0
    tmpString = cs_strdup(AsmString);
2568
59.7k
  else
2569
59.7k
    tmpString = memcpy(tmpString, AsmString, 1 + AsmStringLen);
2570
2571
405k
  while (AsmString[I] != ' ' && AsmString[I] != '\t' &&
2572
347k
         AsmString[I] != '$' && AsmString[I] != '\0')
2573
345k
    ++I;
2574
59.7k
  tmpString[I] = 0;
2575
59.7k
  SStream_concat0(OS, tmpString);
2576
59.7k
  if (ASMSTRING_CONTAIN_SIZE - 1 < AsmStringLen)
2577
    /* Free the possible cs_strdup() memory. PR#1424. */
2578
0
    cs_mem_free(tmpString);
2579
59.7k
#undef ASMSTRING_CONTAIN_SIZE
2580
2581
59.7k
  if (AsmString[I] != '\0') {
2582
57.7k
    if (AsmString[I] == ' ' || AsmString[I] == '\t') {
2583
57.7k
      SStream_concat0(OS, " ");
2584
57.7k
      ++I;
2585
57.7k
    }
2586
236k
    do {
2587
236k
      if (AsmString[I] == '$') {
2588
117k
        ++I;
2589
117k
        if (AsmString[I] == (char)0xff) {
2590
21.0k
          ++I;
2591
21.0k
          int OpIdx = AsmString[I++] - 1;
2592
21.0k
          int PrintMethodIdx = AsmString[I++] - 1;
2593
21.0k
          printCustomAliasOperand(MI, OpIdx, PrintMethodIdx, OS);
2594
21.0k
        } else
2595
96.2k
          printOperand(MI, (unsigned)(AsmString[I++]) - 1, OS);
2596
119k
      } else {
2597
119k
        SStream_concat1(OS, AsmString[I++]);
2598
119k
      }
2599
236k
    } while (AsmString[I] != '\0');
2600
57.7k
  }
2601
2602
59.7k
  return true;
2603
215k
}
2604
2605
static void printCustomAliasOperand(
2606
         MCInst *MI, unsigned OpIdx,
2607
         unsigned PrintMethodIdx,
2608
21.0k
         SStream *OS) {
2609
21.0k
  switch (PrintMethodIdx) {
2610
0
  default:
2611
0
    CS_ASSERT(0 && "Unknown PrintMethod kind");
2612
0
    break;
2613
21.0k
  case 0:
2614
21.0k
    printCSRSystemRegister(MI, OpIdx, OS);
2615
21.0k
    break;
2616
21.0k
  }
2617
21.0k
}
2618
2619
static bool RISCVInstPrinterValidateMCOperand(MCOperand *MCOp,
2620
1.86k
                  unsigned PredicateIndex) {
2621
  // TODO: need some constant untils operate the MCOperand,
2622
  // but current CAPSTONE does't have.
2623
  // So, We just return true
2624
1.86k
  return true;
2625
2626
#if 0
2627
  switch (PredicateIndex) {
2628
  default:
2629
    llvm_unreachable("Unknown MCOperandPredicate kind");
2630
    break;
2631
  case 1: {
2632
2633
    int64_t Imm;
2634
    if (MCOp.evaluateAsConstantImm(Imm))
2635
      return isShiftedInt<12, 1>(Imm);
2636
    return MCOp.isBareSymbolRef();
2637
  
2638
    }
2639
  case 2: {
2640
2641
    int64_t Imm;
2642
    if (MCOp.evaluateAsConstantImm(Imm))
2643
      return isShiftedInt<20, 1>(Imm);
2644
    return MCOp.isBareSymbolRef();
2645
  
2646
    }
2647
  }
2648
#endif
2649
1.86k
}
2650
2651
#endif // PRINT_ALIAS_INSTR