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
33.8k
{
1504
33.8k
  MCRegisterInfo *MRI = (MCRegisterInfo *) info;
1505
33.8k
  const char *AsmString;
1506
33.8k
  unsigned I = 0;
1507
33.8k
#define ASMSTRING_CONTAIN_SIZE 64
1508
33.8k
  unsigned AsmStringLen = 0;
1509
33.8k
  char tmpString_[ASMSTRING_CONTAIN_SIZE];
1510
33.8k
  char *tmpString = tmpString_;
1511
33.8k
  switch (MCInst_getOpcode(MI)) {
1512
5.66k
  default: return false;
1513
195
  case RISCV_ADDI:
1514
195
    if (MCInst_getNumOperands(MI) == 3 &&
1515
195
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1516
169
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1517
119
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1518
119
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
1519
      // (ADDI X0, X0, 0)
1520
107
      AsmString = "nop";
1521
107
      break;
1522
107
    }
1523
88
    if (MCInst_getNumOperands(MI) == 3 &&
1524
88
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1525
88
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1526
88
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1527
88
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1528
88
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1529
88
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
1530
      // (ADDI GPR:$rd, GPR:$rs, 0)
1531
7
      AsmString = "mv $\x01, $\x02";
1532
7
      break;
1533
7
    }
1534
81
    return false;
1535
115
  case RISCV_ADDIW:
1536
115
    if (MCInst_getNumOperands(MI) == 3 &&
1537
115
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1538
115
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1539
115
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1540
115
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1541
115
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1542
115
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
1543
      // (ADDIW GPR:$rd, GPR:$rs, 0)
1544
95
      AsmString = "sext.w $\x01, $\x02";
1545
95
      break;
1546
95
    }
1547
20
    return false;
1548
11
  case RISCV_BEQ:
1549
11
    if (MCInst_getNumOperands(MI) == 3 &&
1550
11
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1551
11
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1552
11
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1553
1
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1554
      // (BEQ GPR:$rs, X0, simm13_lsb0:$offset)
1555
1
      AsmString = "beqz $\x01, $\x03";
1556
1
      break;
1557
1
    }
1558
10
    return false;
1559
60
  case RISCV_BGE:
1560
60
    if (MCInst_getNumOperands(MI) == 3 &&
1561
60
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1562
6
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1563
6
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1564
6
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1565
      // (BGE X0, GPR:$rs, simm13_lsb0:$offset)
1566
6
      AsmString = "blez $\x02, $\x03";
1567
6
      break;
1568
6
    }
1569
54
    if (MCInst_getNumOperands(MI) == 3 &&
1570
54
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1571
54
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1572
54
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1573
6
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1574
      // (BGE GPR:$rs, X0, simm13_lsb0:$offset)
1575
6
      AsmString = "bgez $\x01, $\x03";
1576
6
      break;
1577
6
    }
1578
48
    return false;
1579
55
  case RISCV_BLT:
1580
55
    if (MCInst_getNumOperands(MI) == 3 &&
1581
55
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1582
55
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1583
55
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1584
21
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1585
      // (BLT GPR:$rs, X0, simm13_lsb0:$offset)
1586
21
      AsmString = "bltz $\x01, $\x03";
1587
21
      break;
1588
21
    }
1589
34
    if (MCInst_getNumOperands(MI) == 3 &&
1590
34
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1591
4
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1592
4
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1593
4
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1594
      // (BLT X0, GPR:$rs, simm13_lsb0:$offset)
1595
4
      AsmString = "bgtz $\x02, $\x03";
1596
4
      break;
1597
4
    }
1598
30
    return false;
1599
220
  case RISCV_BNE:
1600
220
    if (MCInst_getNumOperands(MI) == 3 &&
1601
220
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1602
220
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1603
220
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
1604
107
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 2), 1)) {
1605
      // (BNE GPR:$rs, X0, simm13_lsb0:$offset)
1606
107
      AsmString = "bnez $\x01, $\x03";
1607
107
      break;
1608
107
    }
1609
113
    return false;
1610
3.88k
  case RISCV_CSRRC:
1611
3.88k
    if (MCInst_getNumOperands(MI) == 3 &&
1612
3.88k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1613
971
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1614
971
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1615
      // (CSRRC X0, csr_sysreg:$csr, GPR:$rs)
1616
971
      AsmString = "csrc $\xFF\x02\x01, $\x03";
1617
971
      break;
1618
971
    }
1619
2.91k
    return false;
1620
2.35k
  case RISCV_CSRRCI:
1621
2.35k
    if (MCInst_getNumOperands(MI) == 3 &&
1622
2.35k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0) {
1623
      // (CSRRCI X0, csr_sysreg:$csr, uimm5:$imm)
1624
239
      AsmString = "csrci $\xFF\x02\x01, $\x03";
1625
239
      break;
1626
239
    }
1627
2.11k
    return false;
1628
4.76k
  case RISCV_CSRRS:
1629
4.76k
    if (MCInst_getNumOperands(MI) == 3 &&
1630
4.76k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1631
4.76k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1632
4.76k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1633
4.76k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3 &&
1634
50
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1635
      // (CSRRS GPR:$rd, 3, X0)
1636
0
      AsmString = "frcsr $\x01";
1637
0
      break;
1638
0
    }
1639
4.76k
    if (MCInst_getNumOperands(MI) == 3 &&
1640
4.76k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1641
4.76k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1642
4.76k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1643
4.76k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2 &&
1644
159
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1645
      // (CSRRS GPR:$rd, 2, X0)
1646
9
      AsmString = "frrm $\x01";
1647
9
      break;
1648
9
    }
1649
4.75k
    if (MCInst_getNumOperands(MI) == 3 &&
1650
4.75k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1651
4.75k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1652
4.75k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1653
4.75k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1 &&
1654
64
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1655
      // (CSRRS GPR:$rd, 1, X0)
1656
2
      AsmString = "frflags $\x01";
1657
2
      break;
1658
2
    }
1659
4.75k
    if (MCInst_getNumOperands(MI) == 3 &&
1660
4.75k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1661
4.75k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1662
4.75k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1663
4.75k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3074 &&
1664
91
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1665
      // (CSRRS GPR:$rd, 3074, X0)
1666
51
      AsmString = "rdinstret $\x01";
1667
51
      break;
1668
51
    }
1669
4.70k
    if (MCInst_getNumOperands(MI) == 3 &&
1670
4.70k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1671
4.70k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1672
4.70k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1673
4.70k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3072 &&
1674
354
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1675
      // (CSRRS GPR:$rd, 3072, X0)
1676
192
      AsmString = "rdcycle $\x01";
1677
192
      break;
1678
192
    }
1679
4.51k
    if (MCInst_getNumOperands(MI) == 3 &&
1680
4.51k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1681
4.51k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1682
4.51k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1683
4.51k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3073 &&
1684
301
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1685
      // (CSRRS GPR:$rd, 3073, X0)
1686
40
      AsmString = "rdtime $\x01";
1687
40
      break;
1688
40
    }
1689
4.47k
    if (MCInst_getNumOperands(MI) == 3 &&
1690
4.47k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1691
4.47k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1692
4.47k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1693
4.47k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3202 &&
1694
50
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1695
      // (CSRRS GPR:$rd, 3202, X0)
1696
2
      AsmString = "rdinstreth $\x01";
1697
2
      break;
1698
2
    }
1699
4.47k
    if (MCInst_getNumOperands(MI) == 3 &&
1700
4.47k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1701
4.47k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1702
4.47k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1703
4.47k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3200 &&
1704
12
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1705
      // (CSRRS GPR:$rd, 3200, X0)
1706
6
      AsmString = "rdcycleh $\x01";
1707
6
      break;
1708
6
    }
1709
4.46k
    if (MCInst_getNumOperands(MI) == 3 &&
1710
4.46k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1711
4.46k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1712
4.46k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1713
4.46k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3201 &&
1714
47
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1715
      // (CSRRS GPR:$rd, 3201, X0)
1716
47
      AsmString = "rdtimeh $\x01";
1717
47
      break;
1718
47
    }
1719
4.41k
    if (MCInst_getNumOperands(MI) == 3 &&
1720
4.41k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1721
4.41k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1722
4.41k
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
1723
      // (CSRRS GPR:$rd, csr_sysreg:$csr, X0)
1724
935
      AsmString = "csrr $\x01, $\xFF\x02\x01";
1725
935
      break;
1726
935
    }
1727
3.48k
    if (MCInst_getNumOperands(MI) == 3 &&
1728
3.48k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1729
290
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1730
290
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1731
      // (CSRRS X0, csr_sysreg:$csr, GPR:$rs)
1732
290
      AsmString = "csrs $\xFF\x02\x01, $\x03";
1733
290
      break;
1734
290
    }
1735
3.19k
    return false;
1736
2.87k
  case RISCV_CSRRSI:
1737
2.87k
    if (MCInst_getNumOperands(MI) == 3 &&
1738
2.87k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0) {
1739
      // (CSRRSI X0, csr_sysreg:$csr, uimm5:$imm)
1740
77
      AsmString = "csrsi $\xFF\x02\x01, $\x03";
1741
77
      break;
1742
77
    }
1743
2.79k
    return false;
1744
4.36k
  case RISCV_CSRRW:
1745
4.36k
    if (MCInst_getNumOperands(MI) == 3 &&
1746
4.36k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1747
1.09k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1748
1.09k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3 &&
1749
346
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1750
346
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1751
      // (CSRRW X0, 3, GPR:$rs)
1752
346
      AsmString = "fscsr $\x03";
1753
346
      break;
1754
346
    }
1755
4.02k
    if (MCInst_getNumOperands(MI) == 3 &&
1756
4.02k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1757
745
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1758
745
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2 &&
1759
18
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1760
18
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1761
      // (CSRRW X0, 2, GPR:$rs)
1762
18
      AsmString = "fsrm $\x03";
1763
18
      break;
1764
18
    }
1765
4.00k
    if (MCInst_getNumOperands(MI) == 3 &&
1766
4.00k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1767
727
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1768
727
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1 &&
1769
48
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1770
48
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1771
      // (CSRRW X0, 1, GPR:$rs)
1772
48
      AsmString = "fsflags $\x03";
1773
48
      break;
1774
48
    }
1775
3.95k
    if (MCInst_getNumOperands(MI) == 3 &&
1776
3.95k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1777
679
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1778
679
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1779
      // (CSRRW X0, csr_sysreg:$csr, GPR:$rs)
1780
679
      AsmString = "csrw $\xFF\x02\x01, $\x03";
1781
679
      break;
1782
679
    }
1783
3.27k
    if (MCInst_getNumOperands(MI) == 3 &&
1784
3.27k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1785
3.27k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1786
3.27k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1787
3.27k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 3 &&
1788
94
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1789
94
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1790
      // (CSRRW GPR:$rd, 3, GPR:$rs)
1791
94
      AsmString = "fscsr $\x01, $\x03";
1792
94
      break;
1793
94
    }
1794
3.18k
    if (MCInst_getNumOperands(MI) == 3 &&
1795
3.18k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1796
3.18k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1797
3.18k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1798
3.18k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2 &&
1799
407
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1800
407
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1801
      // (CSRRW GPR:$rd, 2, GPR:$rs)
1802
407
      AsmString = "fsrm $\x01, $\x03";
1803
407
      break;
1804
407
    }
1805
2.77k
    if (MCInst_getNumOperands(MI) == 3 &&
1806
2.77k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1807
2.77k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1808
2.77k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1809
2.77k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1 &&
1810
116
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1811
116
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
1812
      // (CSRRW GPR:$rd, 1, GPR:$rs)
1813
116
      AsmString = "fsflags $\x01, $\x03";
1814
116
      break;
1815
116
    }
1816
2.65k
    return false;
1817
1.66k
  case RISCV_CSRRWI:
1818
1.66k
    if (MCInst_getNumOperands(MI) == 3 &&
1819
1.66k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1820
458
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1821
458
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2) {
1822
      // (CSRRWI X0, 2, uimm5:$imm)
1823
28
      AsmString = "fsrmi $\x03";
1824
28
      break;
1825
28
    }
1826
1.64k
    if (MCInst_getNumOperands(MI) == 3 &&
1827
1.64k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
1828
430
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1829
430
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1) {
1830
      // (CSRRWI X0, 1, uimm5:$imm)
1831
6
      AsmString = "fsflagsi $\x03";
1832
6
      break;
1833
6
    }
1834
1.63k
    if (MCInst_getNumOperands(MI) == 3 &&
1835
1.63k
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0) {
1836
      // (CSRRWI X0, csr_sysreg:$csr, uimm5:$imm)
1837
424
      AsmString = "csrwi $\xFF\x02\x01, $\x03";
1838
424
      break;
1839
424
    }
1840
1.21k
    if (MCInst_getNumOperands(MI) == 3 &&
1841
1.21k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1842
1.21k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1843
1.21k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1844
1.21k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 2) {
1845
      // (CSRRWI GPR:$rd, 2, uimm5:$imm)
1846
20
      AsmString = "fsrmi $\x01, $\x03";
1847
20
      break;
1848
20
    }
1849
1.19k
    if (MCInst_getNumOperands(MI) == 3 &&
1850
1.19k
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1851
1.19k
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1852
1.19k
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
1853
1.19k
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 1) {
1854
      // (CSRRWI GPR:$rd, 1, uimm5:$imm)
1855
110
      AsmString = "fsflagsi $\x01, $\x03";
1856
110
      break;
1857
110
    }
1858
1.08k
    return false;
1859
388
  case RISCV_FADD_D:
1860
388
    if (MCInst_getNumOperands(MI) == 4 &&
1861
388
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1862
388
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1863
388
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1864
388
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1865
388
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1866
388
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
1867
388
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
1868
388
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
1869
      // (FADD_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
1870
287
      AsmString = "fadd.d $\x01, $\x02, $\x03";
1871
287
      break;
1872
287
    }
1873
101
    return false;
1874
541
  case RISCV_FADD_S:
1875
541
    if (MCInst_getNumOperands(MI) == 4 &&
1876
541
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1877
541
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1878
541
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1879
541
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1880
541
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
1881
541
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
1882
541
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
1883
541
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
1884
      // (FADD_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
1885
30
      AsmString = "fadd.s $\x01, $\x02, $\x03";
1886
30
      break;
1887
30
    }
1888
511
    return false;
1889
38
  case RISCV_FCVT_D_L:
1890
38
    if (MCInst_getNumOperands(MI) == 3 &&
1891
38
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1892
38
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1893
38
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1894
38
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1895
38
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1896
38
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1897
      // (FCVT_D_L FPR64:$rd, GPR:$rs1, { 1, 1, 1 })
1898
16
      AsmString = "fcvt.d.l $\x01, $\x02";
1899
16
      break;
1900
16
    }
1901
22
    return false;
1902
119
  case RISCV_FCVT_D_LU:
1903
119
    if (MCInst_getNumOperands(MI) == 3 &&
1904
119
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1905
119
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1906
119
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1907
119
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1908
119
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1909
119
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1910
      // (FCVT_D_LU FPR64:$rd, GPR:$rs1, { 1, 1, 1 })
1911
13
      AsmString = "fcvt.d.lu $\x01, $\x02";
1912
13
      break;
1913
13
    }
1914
106
    return false;
1915
45
  case RISCV_FCVT_LU_D:
1916
45
    if (MCInst_getNumOperands(MI) == 3 &&
1917
45
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1918
45
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1919
45
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1920
45
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1921
45
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1922
45
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1923
      // (FCVT_LU_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
1924
15
      AsmString = "fcvt.lu.d $\x01, $\x02";
1925
15
      break;
1926
15
    }
1927
30
    return false;
1928
395
  case RISCV_FCVT_LU_S:
1929
395
    if (MCInst_getNumOperands(MI) == 3 &&
1930
395
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1931
395
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1932
395
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1933
395
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1934
395
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1935
395
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1936
      // (FCVT_LU_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
1937
301
      AsmString = "fcvt.lu.s $\x01, $\x02";
1938
301
      break;
1939
301
    }
1940
94
    return false;
1941
78
  case RISCV_FCVT_L_D:
1942
78
    if (MCInst_getNumOperands(MI) == 3 &&
1943
78
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1944
78
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1945
78
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1946
78
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1947
78
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1948
78
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1949
      // (FCVT_L_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
1950
7
      AsmString = "fcvt.l.d $\x01, $\x02";
1951
7
      break;
1952
7
    }
1953
71
    return false;
1954
360
  case RISCV_FCVT_L_S:
1955
360
    if (MCInst_getNumOperands(MI) == 3 &&
1956
360
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1957
360
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1958
360
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1959
360
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1960
360
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1961
360
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1962
      // (FCVT_L_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
1963
212
      AsmString = "fcvt.l.s $\x01, $\x02";
1964
212
      break;
1965
212
    }
1966
148
    return false;
1967
19
  case RISCV_FCVT_S_D:
1968
19
    if (MCInst_getNumOperands(MI) == 3 &&
1969
19
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1970
19
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1971
19
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1972
19
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1973
19
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1974
19
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1975
      // (FCVT_S_D FPR32:$rd, FPR64:$rs1, { 1, 1, 1 })
1976
2
      AsmString = "fcvt.s.d $\x01, $\x02";
1977
2
      break;
1978
2
    }
1979
17
    return false;
1980
35
  case RISCV_FCVT_S_L:
1981
35
    if (MCInst_getNumOperands(MI) == 3 &&
1982
35
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1983
35
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1984
35
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1985
35
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1986
35
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
1987
35
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
1988
      // (FCVT_S_L FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
1989
26
      AsmString = "fcvt.s.l $\x01, $\x02";
1990
26
      break;
1991
26
    }
1992
9
    return false;
1993
39
  case RISCV_FCVT_S_LU:
1994
39
    if (MCInst_getNumOperands(MI) == 3 &&
1995
39
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
1996
39
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
1997
39
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
1998
39
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
1999
39
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2000
39
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2001
      // (FCVT_S_LU FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
2002
15
      AsmString = "fcvt.s.lu $\x01, $\x02";
2003
15
      break;
2004
15
    }
2005
24
    return false;
2006
305
  case RISCV_FCVT_S_W:
2007
305
    if (MCInst_getNumOperands(MI) == 3 &&
2008
305
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2009
305
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2010
305
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2011
305
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2012
305
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2013
305
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2014
      // (FCVT_S_W FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
2015
209
      AsmString = "fcvt.s.w $\x01, $\x02";
2016
209
      break;
2017
209
    }
2018
96
    return false;
2019
14
  case RISCV_FCVT_S_WU:
2020
14
    if (MCInst_getNumOperands(MI) == 3 &&
2021
14
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2022
14
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2023
14
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2024
14
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2025
14
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2026
14
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2027
      // (FCVT_S_WU FPR32:$rd, GPR:$rs1, { 1, 1, 1 })
2028
9
      AsmString = "fcvt.s.wu $\x01, $\x02";
2029
9
      break;
2030
9
    }
2031
5
    return false;
2032
60
  case RISCV_FCVT_WU_D:
2033
60
    if (MCInst_getNumOperands(MI) == 3 &&
2034
60
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2035
60
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2036
60
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2037
60
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2038
60
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2039
60
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2040
      // (FCVT_WU_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
2041
8
      AsmString = "fcvt.wu.d $\x01, $\x02";
2042
8
      break;
2043
8
    }
2044
52
    return false;
2045
232
  case RISCV_FCVT_WU_S:
2046
232
    if (MCInst_getNumOperands(MI) == 3 &&
2047
232
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2048
232
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2049
232
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2050
232
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2051
232
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2052
232
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2053
      // (FCVT_WU_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
2054
13
      AsmString = "fcvt.wu.s $\x01, $\x02";
2055
13
      break;
2056
13
    }
2057
219
    return false;
2058
75
  case RISCV_FCVT_W_D:
2059
75
    if (MCInst_getNumOperands(MI) == 3 &&
2060
75
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2061
75
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2062
75
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2063
75
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2064
75
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2065
75
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2066
      // (FCVT_W_D GPR:$rd, FPR64:$rs1, { 1, 1, 1 })
2067
61
      AsmString = "fcvt.w.d $\x01, $\x02";
2068
61
      break;
2069
61
    }
2070
14
    return false;
2071
167
  case RISCV_FCVT_W_S:
2072
167
    if (MCInst_getNumOperands(MI) == 3 &&
2073
167
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2074
167
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2075
167
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2076
167
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2077
167
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2078
167
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2079
      // (FCVT_W_S GPR:$rd, FPR32:$rs1, { 1, 1, 1 })
2080
86
      AsmString = "fcvt.w.s $\x01, $\x02";
2081
86
      break;
2082
86
    }
2083
81
    return false;
2084
299
  case RISCV_FDIV_D:
2085
299
    if (MCInst_getNumOperands(MI) == 4 &&
2086
299
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2087
299
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2088
299
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2089
299
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2090
299
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2091
299
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2092
299
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2093
299
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2094
      // (FDIV_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
2095
33
      AsmString = "fdiv.d $\x01, $\x02, $\x03";
2096
33
      break;
2097
33
    }
2098
266
    return false;
2099
80
  case RISCV_FDIV_S:
2100
80
    if (MCInst_getNumOperands(MI) == 4 &&
2101
80
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2102
80
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2103
80
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2104
80
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2105
80
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2106
80
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2107
80
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2108
80
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2109
      // (FDIV_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
2110
60
      AsmString = "fdiv.s $\x01, $\x02, $\x03";
2111
60
      break;
2112
60
    }
2113
20
    return false;
2114
518
  case RISCV_FENCE:
2115
518
    if (MCInst_getNumOperands(MI) == 2 &&
2116
518
        MCOperand_isImm(MCInst_getOperand(MI, 0)) &&
2117
518
        MCOperand_getImm(MCInst_getOperand(MI, 0)) == 15 &&
2118
235
        MCOperand_isImm(MCInst_getOperand(MI, 1)) &&
2119
235
        MCOperand_getImm(MCInst_getOperand(MI, 1)) == 15) {
2120
      // (FENCE 15, 15)
2121
13
      AsmString = "fence";
2122
13
      break;
2123
13
    }
2124
505
    return false;
2125
266
  case RISCV_FMADD_D:
2126
266
    if (MCInst_getNumOperands(MI) == 5 &&
2127
266
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2128
266
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2129
266
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2130
266
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2131
266
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2132
266
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2133
266
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2134
266
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2135
266
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2136
266
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2137
      // (FMADD_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2138
181
      AsmString = "fmadd.d $\x01, $\x02, $\x03, $\x04";
2139
181
      break;
2140
181
    }
2141
85
    return false;
2142
118
  case RISCV_FMADD_S:
2143
118
    if (MCInst_getNumOperands(MI) == 5 &&
2144
118
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2145
118
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2146
118
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2147
118
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2148
118
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2149
118
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2150
118
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2151
118
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2152
118
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2153
118
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2154
      // (FMADD_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2155
47
      AsmString = "fmadd.s $\x01, $\x02, $\x03, $\x04";
2156
47
      break;
2157
47
    }
2158
71
    return false;
2159
92
  case RISCV_FMSUB_D:
2160
92
    if (MCInst_getNumOperands(MI) == 5 &&
2161
92
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2162
92
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2163
92
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2164
92
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2165
92
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2166
92
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2167
92
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2168
92
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2169
92
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2170
92
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2171
      // (FMSUB_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2172
4
      AsmString = "fmsub.d $\x01, $\x02, $\x03, $\x04";
2173
4
      break;
2174
4
    }
2175
88
    return false;
2176
36
  case RISCV_FMSUB_S:
2177
36
    if (MCInst_getNumOperands(MI) == 5 &&
2178
36
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2179
36
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2180
36
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2181
36
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2182
36
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2183
36
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2184
36
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2185
36
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2186
36
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2187
36
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2188
      // (FMSUB_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2189
20
      AsmString = "fmsub.s $\x01, $\x02, $\x03, $\x04";
2190
20
      break;
2191
20
    }
2192
16
    return false;
2193
72
  case RISCV_FMUL_D:
2194
72
    if (MCInst_getNumOperands(MI) == 4 &&
2195
72
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2196
72
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2197
72
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2198
72
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2199
72
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2200
72
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2201
72
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2202
72
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2203
      // (FMUL_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
2204
5
      AsmString = "fmul.d $\x01, $\x02, $\x03";
2205
5
      break;
2206
5
    }
2207
67
    return false;
2208
230
  case RISCV_FMUL_S:
2209
230
    if (MCInst_getNumOperands(MI) == 4 &&
2210
230
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2211
230
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2212
230
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2213
230
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2214
230
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2215
230
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2216
230
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2217
230
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2218
      // (FMUL_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
2219
44
      AsmString = "fmul.s $\x01, $\x02, $\x03";
2220
44
      break;
2221
44
    }
2222
186
    return false;
2223
88
  case RISCV_FNMADD_D:
2224
88
    if (MCInst_getNumOperands(MI) == 5 &&
2225
88
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2226
88
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2227
88
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2228
88
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2229
88
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2230
88
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2231
88
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2232
88
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2233
88
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2234
88
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2235
      // (FNMADD_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2236
62
      AsmString = "fnmadd.d $\x01, $\x02, $\x03, $\x04";
2237
62
      break;
2238
62
    }
2239
26
    return false;
2240
121
  case RISCV_FNMADD_S:
2241
121
    if (MCInst_getNumOperands(MI) == 5 &&
2242
121
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2243
121
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2244
121
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2245
121
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2246
121
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2247
121
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2248
121
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2249
121
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2250
121
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2251
121
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2252
      // (FNMADD_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2253
105
      AsmString = "fnmadd.s $\x01, $\x02, $\x03, $\x04";
2254
105
      break;
2255
105
    }
2256
16
    return false;
2257
9
  case RISCV_FNMSUB_D:
2258
9
    if (MCInst_getNumOperands(MI) == 5 &&
2259
9
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2260
9
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2261
9
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2262
9
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2263
9
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2264
9
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2265
9
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2266
9
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2267
9
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2268
9
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2269
      // (FNMSUB_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, FPR64:$rs3, { 1, 1, 1 })
2270
7
      AsmString = "fnmsub.d $\x01, $\x02, $\x03, $\x04";
2271
7
      break;
2272
7
    }
2273
2
    return false;
2274
148
  case RISCV_FNMSUB_S:
2275
148
    if (MCInst_getNumOperands(MI) == 5 &&
2276
148
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2277
148
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2278
148
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2279
148
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2280
148
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2281
148
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2282
148
        MCOperand_isReg(MCInst_getOperand(MI, 3)) &&
2283
148
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 3))) &&
2284
148
        MCOperand_isImm(MCInst_getOperand(MI, 4)) &&
2285
148
        MCOperand_getImm(MCInst_getOperand(MI, 4)) == 7) {
2286
      // (FNMSUB_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, FPR32:$rs3, { 1, 1, 1 })
2287
25
      AsmString = "fnmsub.s $\x01, $\x02, $\x03, $\x04";
2288
25
      break;
2289
25
    }
2290
123
    return false;
2291
634
  case RISCV_FSGNJN_D:
2292
634
    if (MCInst_getNumOperands(MI) == 3 &&
2293
634
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2294
634
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2295
634
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2296
634
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2297
634
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2298
634
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2299
      // (FSGNJN_D FPR64:$rd, FPR64:$rs, FPR64:$rs)
2300
9
      AsmString = "fneg.d $\x01, $\x02";
2301
9
      break;
2302
9
    }
2303
625
    return false;
2304
92
  case RISCV_FSGNJN_S:
2305
92
    if (MCInst_getNumOperands(MI) == 3 &&
2306
92
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2307
92
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2308
92
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2309
92
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2310
92
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2311
92
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2312
      // (FSGNJN_S FPR32:$rd, FPR32:$rs, FPR32:$rs)
2313
50
      AsmString = "fneg.s $\x01, $\x02";
2314
50
      break;
2315
50
    }
2316
42
    return false;
2317
55
  case RISCV_FSGNJX_D:
2318
55
    if (MCInst_getNumOperands(MI) == 3 &&
2319
55
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2320
55
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2321
55
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2322
55
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2323
55
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2324
55
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2325
      // (FSGNJX_D FPR64:$rd, FPR64:$rs, FPR64:$rs)
2326
23
      AsmString = "fabs.d $\x01, $\x02";
2327
23
      break;
2328
23
    }
2329
32
    return false;
2330
287
  case RISCV_FSGNJX_S:
2331
287
    if (MCInst_getNumOperands(MI) == 3 &&
2332
287
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2333
287
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2334
287
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2335
287
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2336
287
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2337
287
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2338
      // (FSGNJX_S FPR32:$rd, FPR32:$rs, FPR32:$rs)
2339
84
      AsmString = "fabs.s $\x01, $\x02";
2340
84
      break;
2341
84
    }
2342
203
    return false;
2343
28
  case RISCV_FSGNJ_D:
2344
28
    if (MCInst_getNumOperands(MI) == 3 &&
2345
28
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2346
28
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2347
28
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2348
28
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2349
28
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2350
28
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2351
      // (FSGNJ_D FPR64:$rd, FPR64:$rs, FPR64:$rs)
2352
14
      AsmString = "fmv.d $\x01, $\x02";
2353
14
      break;
2354
14
    }
2355
14
    return false;
2356
345
  case RISCV_FSGNJ_S:
2357
345
    if (MCInst_getNumOperands(MI) == 3 &&
2358
345
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2359
345
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2360
345
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2361
345
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2362
345
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2363
345
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == MCOperand_getReg(MCInst_getOperand(MI, 1))) {
2364
      // (FSGNJ_S FPR32:$rd, FPR32:$rs, FPR32:$rs)
2365
305
      AsmString = "fmv.s $\x01, $\x02";
2366
305
      break;
2367
305
    }
2368
40
    return false;
2369
61
  case RISCV_FSQRT_D:
2370
61
    if (MCInst_getNumOperands(MI) == 3 &&
2371
61
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2372
61
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2373
61
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2374
61
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2375
61
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2376
61
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2377
      // (FSQRT_D FPR64:$rd, FPR64:$rs1, { 1, 1, 1 })
2378
15
      AsmString = "fsqrt.d $\x01, $\x02";
2379
15
      break;
2380
15
    }
2381
46
    return false;
2382
16
  case RISCV_FSQRT_S:
2383
16
    if (MCInst_getNumOperands(MI) == 3 &&
2384
16
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2385
16
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2386
16
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2387
16
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2388
16
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2389
16
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 7) {
2390
      // (FSQRT_S FPR32:$rd, FPR32:$rs1, { 1, 1, 1 })
2391
8
      AsmString = "fsqrt.s $\x01, $\x02";
2392
8
      break;
2393
8
    }
2394
8
    return false;
2395
140
  case RISCV_FSUB_D:
2396
140
    if (MCInst_getNumOperands(MI) == 4 &&
2397
140
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2398
140
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2399
140
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2400
140
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2401
140
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2402
140
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR64RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2403
140
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2404
140
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2405
      // (FSUB_D FPR64:$rd, FPR64:$rs1, FPR64:$rs2, { 1, 1, 1 })
2406
33
      AsmString = "fsub.d $\x01, $\x02, $\x03";
2407
33
      break;
2408
33
    }
2409
107
    return false;
2410
4
  case RISCV_FSUB_S:
2411
4
    if (MCInst_getNumOperands(MI) == 4 &&
2412
4
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2413
4
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2414
4
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2415
4
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2416
4
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2417
4
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_FPR32RegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2))) &&
2418
4
        MCOperand_isImm(MCInst_getOperand(MI, 3)) &&
2419
4
        MCOperand_getImm(MCInst_getOperand(MI, 3)) == 7) {
2420
      // (FSUB_S FPR32:$rd, FPR32:$rs1, FPR32:$rs2, { 1, 1, 1 })
2421
1
      AsmString = "fsub.s $\x01, $\x02, $\x03";
2422
1
      break;
2423
1
    }
2424
3
    return false;
2425
145
  case RISCV_JAL:
2426
145
    if (MCInst_getNumOperands(MI) == 2 &&
2427
145
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2428
47
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 1), 2)) {
2429
      // (JAL X0, simm21_lsb0_jal:$offset)
2430
47
      AsmString = "j $\x02";
2431
47
      break;
2432
47
    }
2433
98
    if (MCInst_getNumOperands(MI) == 2 &&
2434
98
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X1 &&
2435
16
        RISCVInstPrinterValidateMCOperand(MCInst_getOperand(MI, 1), 2)) {
2436
      // (JAL X1, simm21_lsb0_jal:$offset)
2437
16
      AsmString = "jal $\x02";
2438
16
      break;
2439
16
    }
2440
82
    return false;
2441
244
  case RISCV_JALR:
2442
244
    if (MCInst_getNumOperands(MI) == 3 &&
2443
244
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2444
98
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X1 &&
2445
57
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2446
57
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
2447
      // (JALR X0, X1, 0)
2448
29
      AsmString = "ret";
2449
29
      break;
2450
29
    }
2451
215
    if (MCInst_getNumOperands(MI) == 3 &&
2452
215
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2453
69
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2454
69
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2455
69
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2456
69
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
2457
      // (JALR X0, GPR:$rs, 0)
2458
4
      AsmString = "jr $\x02";
2459
4
      break;
2460
4
    }
2461
211
    if (MCInst_getNumOperands(MI) == 3 &&
2462
211
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X1 &&
2463
105
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2464
105
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2465
105
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2466
105
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 0) {
2467
      // (JALR X1, GPR:$rs, 0)
2468
61
      AsmString = "jalr $\x02";
2469
61
      break;
2470
61
    }
2471
150
    return false;
2472
207
  case RISCV_SFENCE_VMA:
2473
207
    if (MCInst_getNumOperands(MI) == 2 &&
2474
207
        MCOperand_getReg(MCInst_getOperand(MI, 0)) == RISCV_X0 &&
2475
68
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0) {
2476
      // (SFENCE_VMA X0, X0)
2477
57
      AsmString = "sfence.vma";
2478
57
      break;
2479
57
    }
2480
150
    if (MCInst_getNumOperands(MI) == 2 &&
2481
150
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2482
150
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2483
150
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0) {
2484
      // (SFENCE_VMA GPR:$rs, X0)
2485
54
      AsmString = "sfence.vma $\x01";
2486
54
      break;
2487
54
    }
2488
96
    return false;
2489
190
  case RISCV_SLT:
2490
190
    if (MCInst_getNumOperands(MI) == 3 &&
2491
190
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2492
190
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2493
190
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2494
190
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2495
190
        MCOperand_getReg(MCInst_getOperand(MI, 2)) == RISCV_X0) {
2496
      // (SLT GPR:$rd, GPR:$rs, X0)
2497
52
      AsmString = "sltz $\x01, $\x02";
2498
52
      break;
2499
52
    }
2500
138
    if (MCInst_getNumOperands(MI) == 3 &&
2501
138
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2502
138
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2503
138
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2504
100
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2505
100
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2506
      // (SLT GPR:$rd, X0, GPR:$rs)
2507
100
      AsmString = "sgtz $\x01, $\x03";
2508
100
      break;
2509
100
    }
2510
38
    return false;
2511
34
  case RISCV_SLTIU:
2512
34
    if (MCInst_getNumOperands(MI) == 3 &&
2513
34
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2514
34
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2515
34
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2516
34
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2517
34
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2518
34
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == 1) {
2519
      // (SLTIU GPR:$rd, GPR:$rs, 1)
2520
2
      AsmString = "seqz $\x01, $\x02";
2521
2
      break;
2522
2
    }
2523
32
    return false;
2524
19
  case RISCV_SLTU:
2525
19
    if (MCInst_getNumOperands(MI) == 3 &&
2526
19
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2527
19
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2528
19
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2529
5
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2530
5
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2531
      // (SLTU GPR:$rd, X0, GPR:$rs)
2532
5
      AsmString = "snez $\x01, $\x03";
2533
5
      break;
2534
5
    }
2535
14
    return false;
2536
25
  case RISCV_SUB:
2537
25
    if (MCInst_getNumOperands(MI) == 3 &&
2538
25
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2539
25
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2540
25
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2541
12
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2542
12
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2543
      // (SUB GPR:$rd, X0, GPR:$rs)
2544
12
      AsmString = "neg $\x01, $\x03";
2545
12
      break;
2546
12
    }
2547
13
    return false;
2548
24
  case RISCV_SUBW:
2549
24
    if (MCInst_getNumOperands(MI) == 3 &&
2550
24
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2551
24
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2552
24
        MCOperand_getReg(MCInst_getOperand(MI, 1)) == RISCV_X0 &&
2553
4
        MCOperand_isReg(MCInst_getOperand(MI, 2)) &&
2554
4
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 2)))) {
2555
      // (SUBW GPR:$rd, X0, GPR:$rs)
2556
4
      AsmString = "negw $\x01, $\x03";
2557
4
      break;
2558
4
    }
2559
20
    return false;
2560
41
  case RISCV_XORI:
2561
41
    if (MCInst_getNumOperands(MI) == 3 &&
2562
41
        MCOperand_isReg(MCInst_getOperand(MI, 0)) &&
2563
41
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 0))) &&
2564
41
        MCOperand_isReg(MCInst_getOperand(MI, 1)) &&
2565
41
        MCRegisterClass_contains(MCRegisterInfo_getRegClass(MRI, RISCV_GPRRegClassID), MCOperand_getReg(MCInst_getOperand(MI, 1))) &&
2566
41
        MCOperand_isImm(MCInst_getOperand(MI, 2)) &&
2567
41
        MCOperand_getImm(MCInst_getOperand(MI, 2)) == -1) {
2568
      // (XORI GPR:$rd, GPR:$rs, -1)
2569
34
      AsmString = "not $\x01, $\x02";
2570
34
      break;
2571
34
    }
2572
7
    return false;
2573
33.8k
  }
2574
2575
8.44k
  AsmStringLen = strlen(AsmString);
2576
8.44k
  if (ASMSTRING_CONTAIN_SIZE - 1 < AsmStringLen)
2577
0
    tmpString = cs_strdup(AsmString);
2578
8.44k
  else
2579
8.44k
    tmpString = memcpy(tmpString, AsmString, 1 + AsmStringLen);
2580
2581
53.6k
  while (AsmString[I] != ' ' && AsmString[I] != '\t' &&
2582
45.3k
         AsmString[I] != '$' && AsmString[I] != '\0')
2583
45.1k
    ++I;
2584
8.44k
  tmpString[I] = 0;
2585
8.44k
  SStream_concat0(OS, tmpString);
2586
8.44k
  if (ASMSTRING_CONTAIN_SIZE - 1 < AsmStringLen)
2587
    /* Free the possible cs_strdup() memory. PR#1424. */
2588
0
    cs_mem_free(tmpString);
2589
8.44k
#undef ASMSTRING_CONTAIN_SIZE
2590
2591
8.44k
  if (AsmString[I] != '\0') {
2592
8.24k
    if (AsmString[I] == ' ' || AsmString[I] == '\t') {
2593
8.24k
      SStream_concat0(OS, " ");
2594
8.24k
      ++I;
2595
8.24k
    }
2596
34.2k
    do {
2597
34.2k
      if (AsmString[I] == '$') {
2598
16.8k
        ++I;
2599
16.8k
        if (AsmString[I] == (char)0xff) {
2600
3.61k
          ++I;
2601
3.61k
          int OpIdx = AsmString[I++] - 1;
2602
3.61k
          int PrintMethodIdx = AsmString[I++] - 1;
2603
3.61k
          printCustomAliasOperand(MI, OpIdx, PrintMethodIdx, OS);
2604
3.61k
        } else
2605
13.2k
          printOperand(MI, (unsigned)(AsmString[I++]) - 1, OS);
2606
17.3k
      } else {
2607
17.3k
        SStream_concat1(OS, AsmString[I++]);
2608
17.3k
      }
2609
34.2k
    } while (AsmString[I] != '\0');
2610
8.24k
  }
2611
2612
8.44k
  return true;
2613
33.8k
}
2614
2615
static void printCustomAliasOperand(
2616
         MCInst *MI, unsigned OpIdx,
2617
         unsigned PrintMethodIdx,
2618
3.61k
         SStream *OS) {
2619
3.61k
  switch (PrintMethodIdx) {
2620
0
  default:
2621
0
    CS_ASSERT(0 && "Unknown PrintMethod kind");
2622
0
    break;
2623
3.61k
  case 0:
2624
3.61k
    printCSRSystemRegister(MI, OpIdx, OS);
2625
3.61k
    break;
2626
3.61k
  }
2627
3.61k
}
2628
2629
static bool RISCVInstPrinterValidateMCOperand(MCOperand *MCOp,
2630
208
                  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
208
  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
208
}
2660
2661
#endif // PRINT_ALIAS_INSTR