Coverage Report

Created: 2025-07-18 06:43

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