Coverage Report

Created: 2025-10-12 06:32

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