Coverage Report

Created: 2025-11-09 07:00

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