Coverage Report

Created: 2025-07-01 07:03

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