Coverage Report

Created: 2025-08-28 06:43

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