Coverage Report

Created: 2025-07-09 06:32

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