Coverage Report

Created: 2025-07-04 06:11

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