Coverage Report

Created: 2025-10-28 07:02

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