Coverage Report

Created: 2025-12-14 06:36

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