Coverage Report

Created: 2025-07-11 06:32

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