Coverage Report

Created: 2023-12-08 06:05

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