Coverage Report

Created: 2026-01-17 06:58

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