Coverage Report

Created: 2025-08-29 06:29

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