Coverage Report

Created: 2025-07-04 06:11

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