Coverage Report

Created: 2025-12-05 06:11

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