Coverage Report

Created: 2026-03-13 06:50

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