Coverage Report

Created: 2025-10-10 06:20

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