Coverage Report

Created: 2026-06-15 06:41

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