Coverage Report

Created: 2025-10-12 06:32

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