Coverage Report

Created: 2026-01-09 06:55

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