Coverage Report

Created: 2026-01-09 06:55

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