Coverage Report

Created: 2025-07-01 07:03

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