Coverage Report

Created: 2025-07-04 06:11

/src/capstonenext/arch/RISCV/RISCVGenDisassemblerTables.inc
Line
Count
Source (jump to first uncovered line)
1
/*===- TableGen'erated file -------------------------------------*- C++ -*-===*\
2
|*                                                                            *|
3
|*  * RISCV Disassembler                                                      *|
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 "../../MCInst.h"
13
#include "../../LEB128.h"
14
#include "../../cs_priv.h"
15
16
// Helper functions for extracting fields from encoded instructions.
17
// InsnType must either be integral or an APInt-like object that must:
18
// * Have a static const max_size_in_bits equal to the number of bits in the
19
//   encoding.
20
// * be default-constructible and copy-constructible
21
// * be constructible from a uint64_t
22
// * be constructible from an APInt (this can be private)
23
// * Support getBitsSet(loBit, hiBit)
24
// * be convertible to uint64_t
25
// * Support the ~, &, ==, !=, and |= operators with other objects of the same type
26
// * Support shift (<<, >>) with signed and unsigned integers on the RHS
27
// * Support put (<<) to raw_ostream&
28
#define FieldFromInstruction(fname, InsnType) \
29
783k
static InsnType fname(InsnType insn, unsigned startBit, unsigned numBits) \
30
783k
{ \
31
783k
  InsnType fieldMask; \
32
783k
  if (numBits == sizeof(InsnType)*8) \
33
783k
    fieldMask = (InsnType)(-1LL); \
34
783k
  else \
35
783k
    fieldMask = (((InsnType)1 << numBits) - 1) << startBit; \
36
783k
  return (insn & fieldMask) >> startBit; \
37
783k
}
38
39
static const uint8_t DecoderTable16[] = {
40
/* 0 */       MCD_OPC_ExtractField, 13, 3,  // Inst{15-13} ...
41
/* 3 */       MCD_OPC_FilterValue, 0, 77, 0, 0, // Skip to: 85
42
/* 8 */       MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
43
/* 11 */      MCD_OPC_FilterValue, 0, 25, 0, 0, // Skip to: 41
44
/* 16 */      MCD_OPC_CheckPredicate, 0, 11, 0, 0, // Skip to: 32
45
/* 21 */      MCD_OPC_CheckField, 2, 11, 0, 4, 0, 0, // Skip to: 32
46
/* 28 */      MCD_OPC_Decode, 182, 2, 0, // Opcode: C_UNIMP
47
/* 32 */      MCD_OPC_CheckPredicate, 0, 124, 2, 0, // Skip to: 673
48
/* 37 */      MCD_OPC_Decode, 144, 2, 1, // Opcode: C_ADDI4SPN
49
/* 41 */      MCD_OPC_FilterValue, 1, 25, 0, 0, // Skip to: 71
50
/* 46 */      MCD_OPC_CheckPredicate, 0, 11, 0, 0, // Skip to: 62
51
/* 51 */      MCD_OPC_CheckField, 7, 6, 0, 4, 0, 0, // Skip to: 62
52
/* 58 */      MCD_OPC_Decode, 171, 2, 0, // Opcode: C_NOP
53
/* 62 */      MCD_OPC_CheckPredicate, 0, 94, 2, 0, // Skip to: 673
54
/* 67 */      MCD_OPC_Decode, 142, 2, 2, // Opcode: C_ADDI
55
/* 71 */      MCD_OPC_FilterValue, 2, 85, 2, 0, // Skip to: 673
56
/* 76 */      MCD_OPC_CheckPredicate, 0, 80, 2, 0, // Skip to: 673
57
/* 81 */      MCD_OPC_Decode, 175, 2, 3, // Opcode: C_SLLI
58
/* 85 */      MCD_OPC_FilterValue, 1, 45, 0, 0, // Skip to: 135
59
/* 90 */      MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
60
/* 93 */      MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 107
61
/* 98 */      MCD_OPC_CheckPredicate, 1, 58, 2, 0, // Skip to: 673
62
/* 103 */     MCD_OPC_Decode, 152, 2, 4, // Opcode: C_FLD
63
/* 107 */     MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 121
64
/* 112 */     MCD_OPC_CheckPredicate, 2, 44, 2, 0, // Skip to: 673
65
/* 117 */     MCD_OPC_Decode, 145, 2, 2, // Opcode: C_ADDIW
66
/* 121 */     MCD_OPC_FilterValue, 2, 35, 2, 0, // Skip to: 673
67
/* 126 */     MCD_OPC_CheckPredicate, 1, 30, 2, 0, // Skip to: 673
68
/* 131 */     MCD_OPC_Decode, 153, 2, 5, // Opcode: C_FLDSP
69
/* 135 */     MCD_OPC_FilterValue, 2, 45, 0, 0, // Skip to: 185
70
/* 140 */     MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
71
/* 143 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 157
72
/* 148 */     MCD_OPC_CheckPredicate, 0, 8, 2, 0, // Skip to: 673
73
/* 153 */     MCD_OPC_Decode, 168, 2, 6, // Opcode: C_LW
74
/* 157 */     MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 171
75
/* 162 */     MCD_OPC_CheckPredicate, 0, 250, 1, 0, // Skip to: 673
76
/* 167 */     MCD_OPC_Decode, 166, 2, 7, // Opcode: C_LI
77
/* 171 */     MCD_OPC_FilterValue, 2, 241, 1, 0, // Skip to: 673
78
/* 176 */     MCD_OPC_CheckPredicate, 0, 236, 1, 0, // Skip to: 673
79
/* 181 */     MCD_OPC_Decode, 169, 2, 8, // Opcode: C_LWSP
80
/* 185 */     MCD_OPC_FilterValue, 3, 61, 0, 0, // Skip to: 251
81
/* 190 */     MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
82
/* 193 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 207
83
/* 198 */     MCD_OPC_CheckPredicate, 2, 214, 1, 0, // Skip to: 673
84
/* 203 */     MCD_OPC_Decode, 164, 2, 9, // Opcode: C_LD
85
/* 207 */     MCD_OPC_FilterValue, 1, 25, 0, 0, // Skip to: 237
86
/* 212 */     MCD_OPC_CheckPredicate, 0, 11, 0, 0, // Skip to: 228
87
/* 217 */     MCD_OPC_CheckField, 7, 5, 2, 4, 0, 0, // Skip to: 228
88
/* 224 */     MCD_OPC_Decode, 143, 2, 10, // Opcode: C_ADDI16SP
89
/* 228 */     MCD_OPC_CheckPredicate, 0, 184, 1, 0, // Skip to: 673
90
/* 233 */     MCD_OPC_Decode, 167, 2, 11, // Opcode: C_LUI
91
/* 237 */     MCD_OPC_FilterValue, 2, 175, 1, 0, // Skip to: 673
92
/* 242 */     MCD_OPC_CheckPredicate, 2, 170, 1, 0, // Skip to: 673
93
/* 247 */     MCD_OPC_Decode, 165, 2, 12, // Opcode: C_LDSP
94
/* 251 */     MCD_OPC_FilterValue, 4, 11, 1, 0, // Skip to: 523
95
/* 256 */     MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
96
/* 259 */     MCD_OPC_FilterValue, 1, 175, 0, 0, // Skip to: 439
97
/* 264 */     MCD_OPC_ExtractField, 10, 2,  // Inst{11-10} ...
98
/* 267 */     MCD_OPC_FilterValue, 0, 17, 0, 0, // Skip to: 289
99
/* 272 */     MCD_OPC_CheckPredicate, 0, 140, 1, 0, // Skip to: 673
100
/* 277 */     MCD_OPC_ExtractField, 12, 1,   // Inst{12} ...
101
/* 280 */     MCD_OPC_FilterValue, 0, 132, 1, 0, // Skip to: 673
102
/* 285 */     MCD_OPC_Decode, 177, 2, 13, // Opcode: C_SRLI
103
/* 289 */     MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 303
104
/* 294 */     MCD_OPC_CheckPredicate, 0, 118, 1, 0, // Skip to: 673
105
/* 299 */     MCD_OPC_Decode, 176, 2, 13, // Opcode: C_SRAI
106
/* 303 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 317
107
/* 308 */     MCD_OPC_CheckPredicate, 0, 104, 1, 0, // Skip to: 673
108
/* 313 */     MCD_OPC_Decode, 148, 2, 14, // Opcode: C_ANDI
109
/* 317 */     MCD_OPC_FilterValue, 3, 95, 1, 0, // Skip to: 673
110
/* 322 */     MCD_OPC_ExtractField, 5, 2,  // Inst{6-5} ...
111
/* 325 */     MCD_OPC_FilterValue, 0, 31, 0, 0, // Skip to: 361
112
/* 330 */     MCD_OPC_ExtractField, 12, 1,  // Inst{12} ...
113
/* 333 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 347
114
/* 338 */     MCD_OPC_CheckPredicate, 0, 74, 1, 0, // Skip to: 673
115
/* 343 */     MCD_OPC_Decode, 178, 2, 15, // Opcode: C_SUB
116
/* 347 */     MCD_OPC_FilterValue, 1, 65, 1, 0, // Skip to: 673
117
/* 352 */     MCD_OPC_CheckPredicate, 2, 60, 1, 0, // Skip to: 673
118
/* 357 */     MCD_OPC_Decode, 179, 2, 15, // Opcode: C_SUBW
119
/* 361 */     MCD_OPC_FilterValue, 1, 31, 0, 0, // Skip to: 397
120
/* 366 */     MCD_OPC_ExtractField, 12, 1,  // Inst{12} ...
121
/* 369 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 383
122
/* 374 */     MCD_OPC_CheckPredicate, 0, 38, 1, 0, // Skip to: 673
123
/* 379 */     MCD_OPC_Decode, 183, 2, 15, // Opcode: C_XOR
124
/* 383 */     MCD_OPC_FilterValue, 1, 29, 1, 0, // Skip to: 673
125
/* 388 */     MCD_OPC_CheckPredicate, 2, 24, 1, 0, // Skip to: 673
126
/* 393 */     MCD_OPC_Decode, 146, 2, 15, // Opcode: C_ADDW
127
/* 397 */     MCD_OPC_FilterValue, 2, 16, 0, 0, // Skip to: 418
128
/* 402 */     MCD_OPC_CheckPredicate, 0, 10, 1, 0, // Skip to: 673
129
/* 407 */     MCD_OPC_CheckField, 12, 1, 0, 3, 1, 0, // Skip to: 673
130
/* 414 */     MCD_OPC_Decode, 172, 2, 15, // Opcode: C_OR
131
/* 418 */     MCD_OPC_FilterValue, 3, 250, 0, 0, // Skip to: 673
132
/* 423 */     MCD_OPC_CheckPredicate, 0, 245, 0, 0, // Skip to: 673
133
/* 428 */     MCD_OPC_CheckField, 12, 1, 0, 238, 0, 0, // Skip to: 673
134
/* 435 */     MCD_OPC_Decode, 147, 2, 15, // Opcode: C_AND
135
/* 439 */     MCD_OPC_FilterValue, 2, 229, 0, 0, // Skip to: 673
136
/* 444 */     MCD_OPC_ExtractField, 12, 1,  // Inst{12} ...
137
/* 447 */     MCD_OPC_FilterValue, 0, 25, 0, 0, // Skip to: 477
138
/* 452 */     MCD_OPC_CheckPredicate, 0, 11, 0, 0, // Skip to: 468
139
/* 457 */     MCD_OPC_CheckField, 2, 5, 0, 4, 0, 0, // Skip to: 468
140
/* 464 */     MCD_OPC_Decode, 163, 2, 16, // Opcode: C_JR
141
/* 468 */     MCD_OPC_CheckPredicate, 0, 200, 0, 0, // Skip to: 673
142
/* 473 */     MCD_OPC_Decode, 170, 2, 17, // Opcode: C_MV
143
/* 477 */     MCD_OPC_FilterValue, 1, 191, 0, 0, // Skip to: 673
144
/* 482 */     MCD_OPC_CheckPredicate, 0, 11, 0, 0, // Skip to: 498
145
/* 487 */     MCD_OPC_CheckField, 2, 10, 0, 4, 0, 0, // Skip to: 498
146
/* 494 */     MCD_OPC_Decode, 151, 2, 0, // Opcode: C_EBREAK
147
/* 498 */     MCD_OPC_CheckPredicate, 0, 11, 0, 0, // Skip to: 514
148
/* 503 */     MCD_OPC_CheckField, 2, 5, 0, 4, 0, 0, // Skip to: 514
149
/* 510 */     MCD_OPC_Decode, 162, 2, 16, // Opcode: C_JALR
150
/* 514 */     MCD_OPC_CheckPredicate, 0, 154, 0, 0, // Skip to: 673
151
/* 519 */     MCD_OPC_Decode, 141, 2, 18, // Opcode: C_ADD
152
/* 523 */     MCD_OPC_FilterValue, 5, 45, 0, 0, // Skip to: 573
153
/* 528 */     MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
154
/* 531 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 545
155
/* 536 */     MCD_OPC_CheckPredicate, 1, 132, 0, 0, // Skip to: 673
156
/* 541 */     MCD_OPC_Decode, 156, 2, 4, // Opcode: C_FSD
157
/* 545 */     MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 559
158
/* 550 */     MCD_OPC_CheckPredicate, 0, 118, 0, 0, // Skip to: 673
159
/* 555 */     MCD_OPC_Decode, 160, 2, 19, // Opcode: C_J
160
/* 559 */     MCD_OPC_FilterValue, 2, 109, 0, 0, // Skip to: 673
161
/* 564 */     MCD_OPC_CheckPredicate, 1, 104, 0, 0, // Skip to: 673
162
/* 569 */     MCD_OPC_Decode, 157, 2, 20, // Opcode: C_FSDSP
163
/* 573 */     MCD_OPC_FilterValue, 6, 45, 0, 0, // Skip to: 623
164
/* 578 */     MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
165
/* 581 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 595
166
/* 586 */     MCD_OPC_CheckPredicate, 0, 82, 0, 0, // Skip to: 673
167
/* 591 */     MCD_OPC_Decode, 180, 2, 6, // Opcode: C_SW
168
/* 595 */     MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 609
169
/* 600 */     MCD_OPC_CheckPredicate, 0, 68, 0, 0, // Skip to: 673
170
/* 605 */     MCD_OPC_Decode, 149, 2, 21, // Opcode: C_BEQZ
171
/* 609 */     MCD_OPC_FilterValue, 2, 59, 0, 0, // Skip to: 673
172
/* 614 */     MCD_OPC_CheckPredicate, 0, 54, 0, 0, // Skip to: 673
173
/* 619 */     MCD_OPC_Decode, 181, 2, 22, // Opcode: C_SWSP
174
/* 623 */     MCD_OPC_FilterValue, 7, 45, 0, 0, // Skip to: 673
175
/* 628 */     MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
176
/* 631 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 645
177
/* 636 */     MCD_OPC_CheckPredicate, 2, 32, 0, 0, // Skip to: 673
178
/* 641 */     MCD_OPC_Decode, 173, 2, 9, // Opcode: C_SD
179
/* 645 */     MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 659
180
/* 650 */     MCD_OPC_CheckPredicate, 0, 18, 0, 0, // Skip to: 673
181
/* 655 */     MCD_OPC_Decode, 150, 2, 21, // Opcode: C_BNEZ
182
/* 659 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 673
183
/* 664 */     MCD_OPC_CheckPredicate, 2, 4, 0, 0, // Skip to: 673
184
/* 669 */     MCD_OPC_Decode, 174, 2, 23, // Opcode: C_SDSP
185
/* 673 */     MCD_OPC_Fail, 
186
  0
187
};
188
189
static const uint8_t DecoderTable32[] = {
190
/* 0 */       MCD_OPC_ExtractField, 0, 7,  // Inst{6-0} ...
191
/* 3 */       MCD_OPC_FilterValue, 3, 76, 0, 0, // Skip to: 84
192
/* 8 */       MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
193
/* 11 */      MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 20
194
/* 16 */      MCD_OPC_Decode, 129, 3, 24, // Opcode: LB
195
/* 20 */      MCD_OPC_FilterValue, 1, 4, 0, 0, // Skip to: 29
196
/* 25 */      MCD_OPC_Decode, 132, 3, 24, // Opcode: LH
197
/* 29 */      MCD_OPC_FilterValue, 2, 4, 0, 0, // Skip to: 38
198
/* 34 */      MCD_OPC_Decode, 143, 3, 24, // Opcode: LW
199
/* 38 */      MCD_OPC_FilterValue, 3, 9, 0, 0, // Skip to: 52
200
/* 43 */      MCD_OPC_CheckPredicate, 3, 55, 15, 0, // Skip to: 3943
201
/* 48 */      MCD_OPC_Decode, 131, 3, 24, // Opcode: LD
202
/* 52 */      MCD_OPC_FilterValue, 4, 4, 0, 0, // Skip to: 61
203
/* 57 */      MCD_OPC_Decode, 130, 3, 24, // Opcode: LBU
204
/* 61 */      MCD_OPC_FilterValue, 5, 4, 0, 0, // Skip to: 70
205
/* 66 */      MCD_OPC_Decode, 133, 3, 24, // Opcode: LHU
206
/* 70 */      MCD_OPC_FilterValue, 6, 28, 15, 0, // Skip to: 3943
207
/* 75 */      MCD_OPC_CheckPredicate, 3, 23, 15, 0, // Skip to: 3943
208
/* 80 */      MCD_OPC_Decode, 144, 3, 24, // Opcode: LWU
209
/* 84 */      MCD_OPC_FilterValue, 7, 31, 0, 0, // Skip to: 120
210
/* 89 */      MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
211
/* 92 */      MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 106
212
/* 97 */      MCD_OPC_CheckPredicate, 4, 1, 15, 0, // Skip to: 3943
213
/* 102 */     MCD_OPC_Decode, 224, 2, 25, // Opcode: FLW
214
/* 106 */     MCD_OPC_FilterValue, 3, 248, 14, 0, // Skip to: 3943
215
/* 111 */     MCD_OPC_CheckPredicate, 5, 243, 14, 0, // Skip to: 3943
216
/* 116 */     MCD_OPC_Decode, 219, 2, 26, // Opcode: FLD
217
/* 120 */     MCD_OPC_FilterValue, 15, 52, 0, 0, // Skip to: 177
218
/* 125 */     MCD_OPC_ExtractField, 7, 13,  // Inst{19-7} ...
219
/* 128 */     MCD_OPC_FilterValue, 0, 28, 0, 0, // Skip to: 161
220
/* 133 */     MCD_OPC_ExtractField, 28, 4,  // Inst{31-28} ...
221
/* 136 */     MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 145
222
/* 141 */     MCD_OPC_Decode, 214, 2, 27, // Opcode: FENCE
223
/* 145 */     MCD_OPC_FilterValue, 8, 209, 14, 0, // Skip to: 3943
224
/* 150 */     MCD_OPC_CheckField, 20, 8, 51, 202, 14, 0, // Skip to: 3943
225
/* 157 */     MCD_OPC_Decode, 216, 2, 0, // Opcode: FENCE_TSO
226
/* 161 */     MCD_OPC_FilterValue, 32, 193, 14, 0, // Skip to: 3943
227
/* 166 */     MCD_OPC_CheckField, 20, 12, 0, 186, 14, 0, // Skip to: 3943
228
/* 173 */     MCD_OPC_Decode, 215, 2, 0, // Opcode: FENCE_I
229
/* 177 */     MCD_OPC_FilterValue, 19, 99, 0, 0, // Skip to: 281
230
/* 182 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
231
/* 185 */     MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 194
232
/* 190 */     MCD_OPC_Decode, 179, 1, 24, // Opcode: ADDI
233
/* 194 */     MCD_OPC_FilterValue, 1, 11, 0, 0, // Skip to: 210
234
/* 199 */     MCD_OPC_CheckField, 26, 6, 0, 153, 14, 0, // Skip to: 3943
235
/* 206 */     MCD_OPC_Decode, 170, 3, 28, // Opcode: SLLI
236
/* 210 */     MCD_OPC_FilterValue, 2, 4, 0, 0, // Skip to: 219
237
/* 215 */     MCD_OPC_Decode, 174, 3, 24, // Opcode: SLTI
238
/* 219 */     MCD_OPC_FilterValue, 3, 4, 0, 0, // Skip to: 228
239
/* 224 */     MCD_OPC_Decode, 175, 3, 24, // Opcode: SLTIU
240
/* 228 */     MCD_OPC_FilterValue, 4, 4, 0, 0, // Skip to: 237
241
/* 233 */     MCD_OPC_Decode, 193, 3, 24, // Opcode: XORI
242
/* 237 */     MCD_OPC_FilterValue, 5, 21, 0, 0, // Skip to: 263
243
/* 242 */     MCD_OPC_ExtractField, 26, 6,  // Inst{31-26} ...
244
/* 245 */     MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 254
245
/* 250 */     MCD_OPC_Decode, 183, 3, 28, // Opcode: SRLI
246
/* 254 */     MCD_OPC_FilterValue, 16, 100, 14, 0, // Skip to: 3943
247
/* 259 */     MCD_OPC_Decode, 178, 3, 28, // Opcode: SRAI
248
/* 263 */     MCD_OPC_FilterValue, 6, 4, 0, 0, // Skip to: 272
249
/* 268 */     MCD_OPC_Decode, 152, 3, 24, // Opcode: ORI
250
/* 272 */     MCD_OPC_FilterValue, 7, 82, 14, 0, // Skip to: 3943
251
/* 277 */     MCD_OPC_Decode, 255, 1, 24, // Opcode: ANDI
252
/* 281 */     MCD_OPC_FilterValue, 23, 4, 0, 0, // Skip to: 290
253
/* 286 */     MCD_OPC_Decode, 128, 2, 29, // Opcode: AUIPC
254
/* 290 */     MCD_OPC_FilterValue, 27, 74, 0, 0, // Skip to: 369
255
/* 295 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
256
/* 298 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 312
257
/* 303 */     MCD_OPC_CheckPredicate, 3, 51, 14, 0, // Skip to: 3943
258
/* 308 */     MCD_OPC_Decode, 180, 1, 24, // Opcode: ADDIW
259
/* 312 */     MCD_OPC_FilterValue, 1, 16, 0, 0, // Skip to: 333
260
/* 317 */     MCD_OPC_CheckPredicate, 3, 37, 14, 0, // Skip to: 3943
261
/* 322 */     MCD_OPC_CheckField, 25, 7, 0, 30, 14, 0, // Skip to: 3943
262
/* 329 */     MCD_OPC_Decode, 171, 3, 30, // Opcode: SLLIW
263
/* 333 */     MCD_OPC_FilterValue, 5, 21, 14, 0, // Skip to: 3943
264
/* 338 */     MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
265
/* 341 */     MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 355
266
/* 346 */     MCD_OPC_CheckPredicate, 3, 8, 14, 0, // Skip to: 3943
267
/* 351 */     MCD_OPC_Decode, 184, 3, 30, // Opcode: SRLIW
268
/* 355 */     MCD_OPC_FilterValue, 32, 255, 13, 0, // Skip to: 3943
269
/* 360 */     MCD_OPC_CheckPredicate, 3, 250, 13, 0, // Skip to: 3943
270
/* 365 */     MCD_OPC_Decode, 179, 3, 30, // Opcode: SRAIW
271
/* 369 */     MCD_OPC_FilterValue, 35, 44, 0, 0, // Skip to: 418
272
/* 374 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
273
/* 377 */     MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 386
274
/* 382 */     MCD_OPC_Decode, 157, 3, 31, // Opcode: SB
275
/* 386 */     MCD_OPC_FilterValue, 1, 4, 0, 0, // Skip to: 395
276
/* 391 */     MCD_OPC_Decode, 168, 3, 31, // Opcode: SH
277
/* 395 */     MCD_OPC_FilterValue, 2, 4, 0, 0, // Skip to: 404
278
/* 400 */     MCD_OPC_Decode, 188, 3, 31, // Opcode: SW
279
/* 404 */     MCD_OPC_FilterValue, 3, 206, 13, 0, // Skip to: 3943
280
/* 409 */     MCD_OPC_CheckPredicate, 3, 201, 13, 0, // Skip to: 3943
281
/* 414 */     MCD_OPC_Decode, 166, 3, 31, // Opcode: SD
282
/* 418 */     MCD_OPC_FilterValue, 39, 31, 0, 0, // Skip to: 454
283
/* 423 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
284
/* 426 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 440
285
/* 431 */     MCD_OPC_CheckPredicate, 4, 179, 13, 0, // Skip to: 3943
286
/* 436 */     MCD_OPC_Decode, 254, 2, 32, // Opcode: FSW
287
/* 440 */     MCD_OPC_FilterValue, 3, 170, 13, 0, // Skip to: 3943
288
/* 445 */     MCD_OPC_CheckPredicate, 5, 165, 13, 0, // Skip to: 3943
289
/* 450 */     MCD_OPC_Decode, 243, 2, 33, // Opcode: FSD
290
/* 454 */     MCD_OPC_FilterValue, 47, 107, 6, 0, // Skip to: 2102
291
/* 459 */     MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
292
/* 462 */     MCD_OPC_FilterValue, 0, 31, 0, 0, // Skip to: 498
293
/* 467 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
294
/* 470 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 484
295
/* 475 */     MCD_OPC_CheckPredicate, 6, 135, 13, 0, // Skip to: 3943
296
/* 480 */     MCD_OPC_Decode, 186, 1, 34, // Opcode: AMOADD_W
297
/* 484 */     MCD_OPC_FilterValue, 3, 126, 13, 0, // Skip to: 3943
298
/* 489 */     MCD_OPC_CheckPredicate, 7, 121, 13, 0, // Skip to: 3943
299
/* 494 */     MCD_OPC_Decode, 182, 1, 34, // Opcode: AMOADD_D
300
/* 498 */     MCD_OPC_FilterValue, 1, 31, 0, 0, // Skip to: 534
301
/* 503 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
302
/* 506 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 520
303
/* 511 */     MCD_OPC_CheckPredicate, 6, 99, 13, 0, // Skip to: 3943
304
/* 516 */     MCD_OPC_Decode, 189, 1, 34, // Opcode: AMOADD_W_RL
305
/* 520 */     MCD_OPC_FilterValue, 3, 90, 13, 0, // Skip to: 3943
306
/* 525 */     MCD_OPC_CheckPredicate, 7, 85, 13, 0, // Skip to: 3943
307
/* 530 */     MCD_OPC_Decode, 185, 1, 34, // Opcode: AMOADD_D_RL
308
/* 534 */     MCD_OPC_FilterValue, 2, 31, 0, 0, // Skip to: 570
309
/* 539 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
310
/* 542 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 556
311
/* 547 */     MCD_OPC_CheckPredicate, 6, 63, 13, 0, // Skip to: 3943
312
/* 552 */     MCD_OPC_Decode, 187, 1, 34, // Opcode: AMOADD_W_AQ
313
/* 556 */     MCD_OPC_FilterValue, 3, 54, 13, 0, // Skip to: 3943
314
/* 561 */     MCD_OPC_CheckPredicate, 7, 49, 13, 0, // Skip to: 3943
315
/* 566 */     MCD_OPC_Decode, 183, 1, 34, // Opcode: AMOADD_D_AQ
316
/* 570 */     MCD_OPC_FilterValue, 3, 31, 0, 0, // Skip to: 606
317
/* 575 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
318
/* 578 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 592
319
/* 583 */     MCD_OPC_CheckPredicate, 6, 27, 13, 0, // Skip to: 3943
320
/* 588 */     MCD_OPC_Decode, 188, 1, 34, // Opcode: AMOADD_W_AQ_RL
321
/* 592 */     MCD_OPC_FilterValue, 3, 18, 13, 0, // Skip to: 3943
322
/* 597 */     MCD_OPC_CheckPredicate, 7, 13, 13, 0, // Skip to: 3943
323
/* 602 */     MCD_OPC_Decode, 184, 1, 34, // Opcode: AMOADD_D_AQ_RL
324
/* 606 */     MCD_OPC_FilterValue, 4, 31, 0, 0, // Skip to: 642
325
/* 611 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
326
/* 614 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 628
327
/* 619 */     MCD_OPC_CheckPredicate, 6, 247, 12, 0, // Skip to: 3943
328
/* 624 */     MCD_OPC_Decode, 242, 1, 34, // Opcode: AMOSWAP_W
329
/* 628 */     MCD_OPC_FilterValue, 3, 238, 12, 0, // Skip to: 3943
330
/* 633 */     MCD_OPC_CheckPredicate, 7, 233, 12, 0, // Skip to: 3943
331
/* 638 */     MCD_OPC_Decode, 238, 1, 34, // Opcode: AMOSWAP_D
332
/* 642 */     MCD_OPC_FilterValue, 5, 31, 0, 0, // Skip to: 678
333
/* 647 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
334
/* 650 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 664
335
/* 655 */     MCD_OPC_CheckPredicate, 6, 211, 12, 0, // Skip to: 3943
336
/* 660 */     MCD_OPC_Decode, 245, 1, 34, // Opcode: AMOSWAP_W_RL
337
/* 664 */     MCD_OPC_FilterValue, 3, 202, 12, 0, // Skip to: 3943
338
/* 669 */     MCD_OPC_CheckPredicate, 7, 197, 12, 0, // Skip to: 3943
339
/* 674 */     MCD_OPC_Decode, 241, 1, 34, // Opcode: AMOSWAP_D_RL
340
/* 678 */     MCD_OPC_FilterValue, 6, 31, 0, 0, // Skip to: 714
341
/* 683 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
342
/* 686 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 700
343
/* 691 */     MCD_OPC_CheckPredicate, 6, 175, 12, 0, // Skip to: 3943
344
/* 696 */     MCD_OPC_Decode, 243, 1, 34, // Opcode: AMOSWAP_W_AQ
345
/* 700 */     MCD_OPC_FilterValue, 3, 166, 12, 0, // Skip to: 3943
346
/* 705 */     MCD_OPC_CheckPredicate, 7, 161, 12, 0, // Skip to: 3943
347
/* 710 */     MCD_OPC_Decode, 239, 1, 34, // Opcode: AMOSWAP_D_AQ
348
/* 714 */     MCD_OPC_FilterValue, 7, 31, 0, 0, // Skip to: 750
349
/* 719 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
350
/* 722 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 736
351
/* 727 */     MCD_OPC_CheckPredicate, 6, 139, 12, 0, // Skip to: 3943
352
/* 732 */     MCD_OPC_Decode, 244, 1, 34, // Opcode: AMOSWAP_W_AQ_RL
353
/* 736 */     MCD_OPC_FilterValue, 3, 130, 12, 0, // Skip to: 3943
354
/* 741 */     MCD_OPC_CheckPredicate, 7, 125, 12, 0, // Skip to: 3943
355
/* 746 */     MCD_OPC_Decode, 240, 1, 34, // Opcode: AMOSWAP_D_AQ_RL
356
/* 750 */     MCD_OPC_FilterValue, 8, 45, 0, 0, // Skip to: 800
357
/* 755 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
358
/* 758 */     MCD_OPC_FilterValue, 2, 16, 0, 0, // Skip to: 779
359
/* 763 */     MCD_OPC_CheckPredicate, 6, 103, 12, 0, // Skip to: 3943
360
/* 768 */     MCD_OPC_CheckField, 20, 5, 0, 96, 12, 0, // Skip to: 3943
361
/* 775 */     MCD_OPC_Decode, 138, 3, 35, // Opcode: LR_W
362
/* 779 */     MCD_OPC_FilterValue, 3, 87, 12, 0, // Skip to: 3943
363
/* 784 */     MCD_OPC_CheckPredicate, 7, 82, 12, 0, // Skip to: 3943
364
/* 789 */     MCD_OPC_CheckField, 20, 5, 0, 75, 12, 0, // Skip to: 3943
365
/* 796 */     MCD_OPC_Decode, 134, 3, 35, // Opcode: LR_D
366
/* 800 */     MCD_OPC_FilterValue, 9, 45, 0, 0, // Skip to: 850
367
/* 805 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
368
/* 808 */     MCD_OPC_FilterValue, 2, 16, 0, 0, // Skip to: 829
369
/* 813 */     MCD_OPC_CheckPredicate, 6, 53, 12, 0, // Skip to: 3943
370
/* 818 */     MCD_OPC_CheckField, 20, 5, 0, 46, 12, 0, // Skip to: 3943
371
/* 825 */     MCD_OPC_Decode, 141, 3, 35, // Opcode: LR_W_RL
372
/* 829 */     MCD_OPC_FilterValue, 3, 37, 12, 0, // Skip to: 3943
373
/* 834 */     MCD_OPC_CheckPredicate, 7, 32, 12, 0, // Skip to: 3943
374
/* 839 */     MCD_OPC_CheckField, 20, 5, 0, 25, 12, 0, // Skip to: 3943
375
/* 846 */     MCD_OPC_Decode, 137, 3, 35, // Opcode: LR_D_RL
376
/* 850 */     MCD_OPC_FilterValue, 10, 45, 0, 0, // Skip to: 900
377
/* 855 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
378
/* 858 */     MCD_OPC_FilterValue, 2, 16, 0, 0, // Skip to: 879
379
/* 863 */     MCD_OPC_CheckPredicate, 6, 3, 12, 0, // Skip to: 3943
380
/* 868 */     MCD_OPC_CheckField, 20, 5, 0, 252, 11, 0, // Skip to: 3943
381
/* 875 */     MCD_OPC_Decode, 139, 3, 35, // Opcode: LR_W_AQ
382
/* 879 */     MCD_OPC_FilterValue, 3, 243, 11, 0, // Skip to: 3943
383
/* 884 */     MCD_OPC_CheckPredicate, 7, 238, 11, 0, // Skip to: 3943
384
/* 889 */     MCD_OPC_CheckField, 20, 5, 0, 231, 11, 0, // Skip to: 3943
385
/* 896 */     MCD_OPC_Decode, 135, 3, 35, // Opcode: LR_D_AQ
386
/* 900 */     MCD_OPC_FilterValue, 11, 45, 0, 0, // Skip to: 950
387
/* 905 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
388
/* 908 */     MCD_OPC_FilterValue, 2, 16, 0, 0, // Skip to: 929
389
/* 913 */     MCD_OPC_CheckPredicate, 6, 209, 11, 0, // Skip to: 3943
390
/* 918 */     MCD_OPC_CheckField, 20, 5, 0, 202, 11, 0, // Skip to: 3943
391
/* 925 */     MCD_OPC_Decode, 140, 3, 35, // Opcode: LR_W_AQ_RL
392
/* 929 */     MCD_OPC_FilterValue, 3, 193, 11, 0, // Skip to: 3943
393
/* 934 */     MCD_OPC_CheckPredicate, 7, 188, 11, 0, // Skip to: 3943
394
/* 939 */     MCD_OPC_CheckField, 20, 5, 0, 181, 11, 0, // Skip to: 3943
395
/* 946 */     MCD_OPC_Decode, 136, 3, 35, // Opcode: LR_D_AQ_RL
396
/* 950 */     MCD_OPC_FilterValue, 12, 31, 0, 0, // Skip to: 986
397
/* 955 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
398
/* 958 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 972
399
/* 963 */     MCD_OPC_CheckPredicate, 6, 159, 11, 0, // Skip to: 3943
400
/* 968 */     MCD_OPC_Decode, 162, 3, 34, // Opcode: SC_W
401
/* 972 */     MCD_OPC_FilterValue, 3, 150, 11, 0, // Skip to: 3943
402
/* 977 */     MCD_OPC_CheckPredicate, 7, 145, 11, 0, // Skip to: 3943
403
/* 982 */     MCD_OPC_Decode, 158, 3, 34, // Opcode: SC_D
404
/* 986 */     MCD_OPC_FilterValue, 13, 31, 0, 0, // Skip to: 1022
405
/* 991 */     MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
406
/* 994 */     MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1008
407
/* 999 */     MCD_OPC_CheckPredicate, 6, 123, 11, 0, // Skip to: 3943
408
/* 1004 */    MCD_OPC_Decode, 165, 3, 34, // Opcode: SC_W_RL
409
/* 1008 */    MCD_OPC_FilterValue, 3, 114, 11, 0, // Skip to: 3943
410
/* 1013 */    MCD_OPC_CheckPredicate, 7, 109, 11, 0, // Skip to: 3943
411
/* 1018 */    MCD_OPC_Decode, 161, 3, 34, // Opcode: SC_D_RL
412
/* 1022 */    MCD_OPC_FilterValue, 14, 31, 0, 0, // Skip to: 1058
413
/* 1027 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
414
/* 1030 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1044
415
/* 1035 */    MCD_OPC_CheckPredicate, 6, 87, 11, 0, // Skip to: 3943
416
/* 1040 */    MCD_OPC_Decode, 163, 3, 34, // Opcode: SC_W_AQ
417
/* 1044 */    MCD_OPC_FilterValue, 3, 78, 11, 0, // Skip to: 3943
418
/* 1049 */    MCD_OPC_CheckPredicate, 7, 73, 11, 0, // Skip to: 3943
419
/* 1054 */    MCD_OPC_Decode, 159, 3, 34, // Opcode: SC_D_AQ
420
/* 1058 */    MCD_OPC_FilterValue, 15, 31, 0, 0, // Skip to: 1094
421
/* 1063 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
422
/* 1066 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1080
423
/* 1071 */    MCD_OPC_CheckPredicate, 6, 51, 11, 0, // Skip to: 3943
424
/* 1076 */    MCD_OPC_Decode, 164, 3, 34, // Opcode: SC_W_AQ_RL
425
/* 1080 */    MCD_OPC_FilterValue, 3, 42, 11, 0, // Skip to: 3943
426
/* 1085 */    MCD_OPC_CheckPredicate, 7, 37, 11, 0, // Skip to: 3943
427
/* 1090 */    MCD_OPC_Decode, 160, 3, 34, // Opcode: SC_D_AQ_RL
428
/* 1094 */    MCD_OPC_FilterValue, 16, 31, 0, 0, // Skip to: 1130
429
/* 1099 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
430
/* 1102 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1116
431
/* 1107 */    MCD_OPC_CheckPredicate, 6, 15, 11, 0, // Skip to: 3943
432
/* 1112 */    MCD_OPC_Decode, 250, 1, 34, // Opcode: AMOXOR_W
433
/* 1116 */    MCD_OPC_FilterValue, 3, 6, 11, 0, // Skip to: 3943
434
/* 1121 */    MCD_OPC_CheckPredicate, 7, 1, 11, 0, // Skip to: 3943
435
/* 1126 */    MCD_OPC_Decode, 246, 1, 34, // Opcode: AMOXOR_D
436
/* 1130 */    MCD_OPC_FilterValue, 17, 31, 0, 0, // Skip to: 1166
437
/* 1135 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
438
/* 1138 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1152
439
/* 1143 */    MCD_OPC_CheckPredicate, 6, 235, 10, 0, // Skip to: 3943
440
/* 1148 */    MCD_OPC_Decode, 253, 1, 34, // Opcode: AMOXOR_W_RL
441
/* 1152 */    MCD_OPC_FilterValue, 3, 226, 10, 0, // Skip to: 3943
442
/* 1157 */    MCD_OPC_CheckPredicate, 7, 221, 10, 0, // Skip to: 3943
443
/* 1162 */    MCD_OPC_Decode, 249, 1, 34, // Opcode: AMOXOR_D_RL
444
/* 1166 */    MCD_OPC_FilterValue, 18, 31, 0, 0, // Skip to: 1202
445
/* 1171 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
446
/* 1174 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1188
447
/* 1179 */    MCD_OPC_CheckPredicate, 6, 199, 10, 0, // Skip to: 3943
448
/* 1184 */    MCD_OPC_Decode, 251, 1, 34, // Opcode: AMOXOR_W_AQ
449
/* 1188 */    MCD_OPC_FilterValue, 3, 190, 10, 0, // Skip to: 3943
450
/* 1193 */    MCD_OPC_CheckPredicate, 7, 185, 10, 0, // Skip to: 3943
451
/* 1198 */    MCD_OPC_Decode, 247, 1, 34, // Opcode: AMOXOR_D_AQ
452
/* 1202 */    MCD_OPC_FilterValue, 19, 31, 0, 0, // Skip to: 1238
453
/* 1207 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
454
/* 1210 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1224
455
/* 1215 */    MCD_OPC_CheckPredicate, 6, 163, 10, 0, // Skip to: 3943
456
/* 1220 */    MCD_OPC_Decode, 252, 1, 34, // Opcode: AMOXOR_W_AQ_RL
457
/* 1224 */    MCD_OPC_FilterValue, 3, 154, 10, 0, // Skip to: 3943
458
/* 1229 */    MCD_OPC_CheckPredicate, 7, 149, 10, 0, // Skip to: 3943
459
/* 1234 */    MCD_OPC_Decode, 248, 1, 34, // Opcode: AMOXOR_D_AQ_RL
460
/* 1238 */    MCD_OPC_FilterValue, 32, 31, 0, 0, // Skip to: 1274
461
/* 1243 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
462
/* 1246 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1260
463
/* 1251 */    MCD_OPC_CheckPredicate, 6, 127, 10, 0, // Skip to: 3943
464
/* 1256 */    MCD_OPC_Decode, 234, 1, 34, // Opcode: AMOOR_W
465
/* 1260 */    MCD_OPC_FilterValue, 3, 118, 10, 0, // Skip to: 3943
466
/* 1265 */    MCD_OPC_CheckPredicate, 7, 113, 10, 0, // Skip to: 3943
467
/* 1270 */    MCD_OPC_Decode, 230, 1, 34, // Opcode: AMOOR_D
468
/* 1274 */    MCD_OPC_FilterValue, 33, 31, 0, 0, // Skip to: 1310
469
/* 1279 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
470
/* 1282 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1296
471
/* 1287 */    MCD_OPC_CheckPredicate, 6, 91, 10, 0, // Skip to: 3943
472
/* 1292 */    MCD_OPC_Decode, 237, 1, 34, // Opcode: AMOOR_W_RL
473
/* 1296 */    MCD_OPC_FilterValue, 3, 82, 10, 0, // Skip to: 3943
474
/* 1301 */    MCD_OPC_CheckPredicate, 7, 77, 10, 0, // Skip to: 3943
475
/* 1306 */    MCD_OPC_Decode, 233, 1, 34, // Opcode: AMOOR_D_RL
476
/* 1310 */    MCD_OPC_FilterValue, 34, 31, 0, 0, // Skip to: 1346
477
/* 1315 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
478
/* 1318 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1332
479
/* 1323 */    MCD_OPC_CheckPredicate, 6, 55, 10, 0, // Skip to: 3943
480
/* 1328 */    MCD_OPC_Decode, 235, 1, 34, // Opcode: AMOOR_W_AQ
481
/* 1332 */    MCD_OPC_FilterValue, 3, 46, 10, 0, // Skip to: 3943
482
/* 1337 */    MCD_OPC_CheckPredicate, 7, 41, 10, 0, // Skip to: 3943
483
/* 1342 */    MCD_OPC_Decode, 231, 1, 34, // Opcode: AMOOR_D_AQ
484
/* 1346 */    MCD_OPC_FilterValue, 35, 31, 0, 0, // Skip to: 1382
485
/* 1351 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
486
/* 1354 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1368
487
/* 1359 */    MCD_OPC_CheckPredicate, 6, 19, 10, 0, // Skip to: 3943
488
/* 1364 */    MCD_OPC_Decode, 236, 1, 34, // Opcode: AMOOR_W_AQ_RL
489
/* 1368 */    MCD_OPC_FilterValue, 3, 10, 10, 0, // Skip to: 3943
490
/* 1373 */    MCD_OPC_CheckPredicate, 7, 5, 10, 0, // Skip to: 3943
491
/* 1378 */    MCD_OPC_Decode, 232, 1, 34, // Opcode: AMOOR_D_AQ_RL
492
/* 1382 */    MCD_OPC_FilterValue, 48, 31, 0, 0, // Skip to: 1418
493
/* 1387 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
494
/* 1390 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1404
495
/* 1395 */    MCD_OPC_CheckPredicate, 6, 239, 9, 0, // Skip to: 3943
496
/* 1400 */    MCD_OPC_Decode, 194, 1, 34, // Opcode: AMOAND_W
497
/* 1404 */    MCD_OPC_FilterValue, 3, 230, 9, 0, // Skip to: 3943
498
/* 1409 */    MCD_OPC_CheckPredicate, 7, 225, 9, 0, // Skip to: 3943
499
/* 1414 */    MCD_OPC_Decode, 190, 1, 34, // Opcode: AMOAND_D
500
/* 1418 */    MCD_OPC_FilterValue, 49, 31, 0, 0, // Skip to: 1454
501
/* 1423 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
502
/* 1426 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1440
503
/* 1431 */    MCD_OPC_CheckPredicate, 6, 203, 9, 0, // Skip to: 3943
504
/* 1436 */    MCD_OPC_Decode, 197, 1, 34, // Opcode: AMOAND_W_RL
505
/* 1440 */    MCD_OPC_FilterValue, 3, 194, 9, 0, // Skip to: 3943
506
/* 1445 */    MCD_OPC_CheckPredicate, 7, 189, 9, 0, // Skip to: 3943
507
/* 1450 */    MCD_OPC_Decode, 193, 1, 34, // Opcode: AMOAND_D_RL
508
/* 1454 */    MCD_OPC_FilterValue, 50, 31, 0, 0, // Skip to: 1490
509
/* 1459 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
510
/* 1462 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1476
511
/* 1467 */    MCD_OPC_CheckPredicate, 6, 167, 9, 0, // Skip to: 3943
512
/* 1472 */    MCD_OPC_Decode, 195, 1, 34, // Opcode: AMOAND_W_AQ
513
/* 1476 */    MCD_OPC_FilterValue, 3, 158, 9, 0, // Skip to: 3943
514
/* 1481 */    MCD_OPC_CheckPredicate, 7, 153, 9, 0, // Skip to: 3943
515
/* 1486 */    MCD_OPC_Decode, 191, 1, 34, // Opcode: AMOAND_D_AQ
516
/* 1490 */    MCD_OPC_FilterValue, 51, 31, 0, 0, // Skip to: 1526
517
/* 1495 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
518
/* 1498 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1512
519
/* 1503 */    MCD_OPC_CheckPredicate, 6, 131, 9, 0, // Skip to: 3943
520
/* 1508 */    MCD_OPC_Decode, 196, 1, 34, // Opcode: AMOAND_W_AQ_RL
521
/* 1512 */    MCD_OPC_FilterValue, 3, 122, 9, 0, // Skip to: 3943
522
/* 1517 */    MCD_OPC_CheckPredicate, 7, 117, 9, 0, // Skip to: 3943
523
/* 1522 */    MCD_OPC_Decode, 192, 1, 34, // Opcode: AMOAND_D_AQ_RL
524
/* 1526 */    MCD_OPC_FilterValue, 64, 31, 0, 0, // Skip to: 1562
525
/* 1531 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
526
/* 1534 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1548
527
/* 1539 */    MCD_OPC_CheckPredicate, 6, 95, 9, 0, // Skip to: 3943
528
/* 1544 */    MCD_OPC_Decode, 226, 1, 34, // Opcode: AMOMIN_W
529
/* 1548 */    MCD_OPC_FilterValue, 3, 86, 9, 0, // Skip to: 3943
530
/* 1553 */    MCD_OPC_CheckPredicate, 7, 81, 9, 0, // Skip to: 3943
531
/* 1558 */    MCD_OPC_Decode, 222, 1, 34, // Opcode: AMOMIN_D
532
/* 1562 */    MCD_OPC_FilterValue, 65, 31, 0, 0, // Skip to: 1598
533
/* 1567 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
534
/* 1570 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1584
535
/* 1575 */    MCD_OPC_CheckPredicate, 6, 59, 9, 0, // Skip to: 3943
536
/* 1580 */    MCD_OPC_Decode, 229, 1, 34, // Opcode: AMOMIN_W_RL
537
/* 1584 */    MCD_OPC_FilterValue, 3, 50, 9, 0, // Skip to: 3943
538
/* 1589 */    MCD_OPC_CheckPredicate, 7, 45, 9, 0, // Skip to: 3943
539
/* 1594 */    MCD_OPC_Decode, 225, 1, 34, // Opcode: AMOMIN_D_RL
540
/* 1598 */    MCD_OPC_FilterValue, 66, 31, 0, 0, // Skip to: 1634
541
/* 1603 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
542
/* 1606 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1620
543
/* 1611 */    MCD_OPC_CheckPredicate, 6, 23, 9, 0, // Skip to: 3943
544
/* 1616 */    MCD_OPC_Decode, 227, 1, 34, // Opcode: AMOMIN_W_AQ
545
/* 1620 */    MCD_OPC_FilterValue, 3, 14, 9, 0, // Skip to: 3943
546
/* 1625 */    MCD_OPC_CheckPredicate, 7, 9, 9, 0, // Skip to: 3943
547
/* 1630 */    MCD_OPC_Decode, 223, 1, 34, // Opcode: AMOMIN_D_AQ
548
/* 1634 */    MCD_OPC_FilterValue, 67, 31, 0, 0, // Skip to: 1670
549
/* 1639 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
550
/* 1642 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1656
551
/* 1647 */    MCD_OPC_CheckPredicate, 6, 243, 8, 0, // Skip to: 3943
552
/* 1652 */    MCD_OPC_Decode, 228, 1, 34, // Opcode: AMOMIN_W_AQ_RL
553
/* 1656 */    MCD_OPC_FilterValue, 3, 234, 8, 0, // Skip to: 3943
554
/* 1661 */    MCD_OPC_CheckPredicate, 7, 229, 8, 0, // Skip to: 3943
555
/* 1666 */    MCD_OPC_Decode, 224, 1, 34, // Opcode: AMOMIN_D_AQ_RL
556
/* 1670 */    MCD_OPC_FilterValue, 80, 31, 0, 0, // Skip to: 1706
557
/* 1675 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
558
/* 1678 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1692
559
/* 1683 */    MCD_OPC_CheckPredicate, 6, 207, 8, 0, // Skip to: 3943
560
/* 1688 */    MCD_OPC_Decode, 210, 1, 34, // Opcode: AMOMAX_W
561
/* 1692 */    MCD_OPC_FilterValue, 3, 198, 8, 0, // Skip to: 3943
562
/* 1697 */    MCD_OPC_CheckPredicate, 7, 193, 8, 0, // Skip to: 3943
563
/* 1702 */    MCD_OPC_Decode, 206, 1, 34, // Opcode: AMOMAX_D
564
/* 1706 */    MCD_OPC_FilterValue, 81, 31, 0, 0, // Skip to: 1742
565
/* 1711 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
566
/* 1714 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1728
567
/* 1719 */    MCD_OPC_CheckPredicate, 6, 171, 8, 0, // Skip to: 3943
568
/* 1724 */    MCD_OPC_Decode, 213, 1, 34, // Opcode: AMOMAX_W_RL
569
/* 1728 */    MCD_OPC_FilterValue, 3, 162, 8, 0, // Skip to: 3943
570
/* 1733 */    MCD_OPC_CheckPredicate, 7, 157, 8, 0, // Skip to: 3943
571
/* 1738 */    MCD_OPC_Decode, 209, 1, 34, // Opcode: AMOMAX_D_RL
572
/* 1742 */    MCD_OPC_FilterValue, 82, 31, 0, 0, // Skip to: 1778
573
/* 1747 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
574
/* 1750 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1764
575
/* 1755 */    MCD_OPC_CheckPredicate, 6, 135, 8, 0, // Skip to: 3943
576
/* 1760 */    MCD_OPC_Decode, 211, 1, 34, // Opcode: AMOMAX_W_AQ
577
/* 1764 */    MCD_OPC_FilterValue, 3, 126, 8, 0, // Skip to: 3943
578
/* 1769 */    MCD_OPC_CheckPredicate, 7, 121, 8, 0, // Skip to: 3943
579
/* 1774 */    MCD_OPC_Decode, 207, 1, 34, // Opcode: AMOMAX_D_AQ
580
/* 1778 */    MCD_OPC_FilterValue, 83, 31, 0, 0, // Skip to: 1814
581
/* 1783 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
582
/* 1786 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1800
583
/* 1791 */    MCD_OPC_CheckPredicate, 6, 99, 8, 0, // Skip to: 3943
584
/* 1796 */    MCD_OPC_Decode, 212, 1, 34, // Opcode: AMOMAX_W_AQ_RL
585
/* 1800 */    MCD_OPC_FilterValue, 3, 90, 8, 0, // Skip to: 3943
586
/* 1805 */    MCD_OPC_CheckPredicate, 7, 85, 8, 0, // Skip to: 3943
587
/* 1810 */    MCD_OPC_Decode, 208, 1, 34, // Opcode: AMOMAX_D_AQ_RL
588
/* 1814 */    MCD_OPC_FilterValue, 96, 31, 0, 0, // Skip to: 1850
589
/* 1819 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
590
/* 1822 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1836
591
/* 1827 */    MCD_OPC_CheckPredicate, 6, 63, 8, 0, // Skip to: 3943
592
/* 1832 */    MCD_OPC_Decode, 218, 1, 34, // Opcode: AMOMINU_W
593
/* 1836 */    MCD_OPC_FilterValue, 3, 54, 8, 0, // Skip to: 3943
594
/* 1841 */    MCD_OPC_CheckPredicate, 7, 49, 8, 0, // Skip to: 3943
595
/* 1846 */    MCD_OPC_Decode, 214, 1, 34, // Opcode: AMOMINU_D
596
/* 1850 */    MCD_OPC_FilterValue, 97, 31, 0, 0, // Skip to: 1886
597
/* 1855 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
598
/* 1858 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1872
599
/* 1863 */    MCD_OPC_CheckPredicate, 6, 27, 8, 0, // Skip to: 3943
600
/* 1868 */    MCD_OPC_Decode, 221, 1, 34, // Opcode: AMOMINU_W_RL
601
/* 1872 */    MCD_OPC_FilterValue, 3, 18, 8, 0, // Skip to: 3943
602
/* 1877 */    MCD_OPC_CheckPredicate, 7, 13, 8, 0, // Skip to: 3943
603
/* 1882 */    MCD_OPC_Decode, 217, 1, 34, // Opcode: AMOMINU_D_RL
604
/* 1886 */    MCD_OPC_FilterValue, 98, 31, 0, 0, // Skip to: 1922
605
/* 1891 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
606
/* 1894 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1908
607
/* 1899 */    MCD_OPC_CheckPredicate, 6, 247, 7, 0, // Skip to: 3943
608
/* 1904 */    MCD_OPC_Decode, 219, 1, 34, // Opcode: AMOMINU_W_AQ
609
/* 1908 */    MCD_OPC_FilterValue, 3, 238, 7, 0, // Skip to: 3943
610
/* 1913 */    MCD_OPC_CheckPredicate, 7, 233, 7, 0, // Skip to: 3943
611
/* 1918 */    MCD_OPC_Decode, 215, 1, 34, // Opcode: AMOMINU_D_AQ
612
/* 1922 */    MCD_OPC_FilterValue, 99, 31, 0, 0, // Skip to: 1958
613
/* 1927 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
614
/* 1930 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1944
615
/* 1935 */    MCD_OPC_CheckPredicate, 6, 211, 7, 0, // Skip to: 3943
616
/* 1940 */    MCD_OPC_Decode, 220, 1, 34, // Opcode: AMOMINU_W_AQ_RL
617
/* 1944 */    MCD_OPC_FilterValue, 3, 202, 7, 0, // Skip to: 3943
618
/* 1949 */    MCD_OPC_CheckPredicate, 7, 197, 7, 0, // Skip to: 3943
619
/* 1954 */    MCD_OPC_Decode, 216, 1, 34, // Opcode: AMOMINU_D_AQ_RL
620
/* 1958 */    MCD_OPC_FilterValue, 112, 31, 0, 0, // Skip to: 1994
621
/* 1963 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
622
/* 1966 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 1980
623
/* 1971 */    MCD_OPC_CheckPredicate, 6, 175, 7, 0, // Skip to: 3943
624
/* 1976 */    MCD_OPC_Decode, 202, 1, 34, // Opcode: AMOMAXU_W
625
/* 1980 */    MCD_OPC_FilterValue, 3, 166, 7, 0, // Skip to: 3943
626
/* 1985 */    MCD_OPC_CheckPredicate, 7, 161, 7, 0, // Skip to: 3943
627
/* 1990 */    MCD_OPC_Decode, 198, 1, 34, // Opcode: AMOMAXU_D
628
/* 1994 */    MCD_OPC_FilterValue, 113, 31, 0, 0, // Skip to: 2030
629
/* 1999 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
630
/* 2002 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 2016
631
/* 2007 */    MCD_OPC_CheckPredicate, 6, 139, 7, 0, // Skip to: 3943
632
/* 2012 */    MCD_OPC_Decode, 205, 1, 34, // Opcode: AMOMAXU_W_RL
633
/* 2016 */    MCD_OPC_FilterValue, 3, 130, 7, 0, // Skip to: 3943
634
/* 2021 */    MCD_OPC_CheckPredicate, 7, 125, 7, 0, // Skip to: 3943
635
/* 2026 */    MCD_OPC_Decode, 201, 1, 34, // Opcode: AMOMAXU_D_RL
636
/* 2030 */    MCD_OPC_FilterValue, 114, 31, 0, 0, // Skip to: 2066
637
/* 2035 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
638
/* 2038 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 2052
639
/* 2043 */    MCD_OPC_CheckPredicate, 6, 103, 7, 0, // Skip to: 3943
640
/* 2048 */    MCD_OPC_Decode, 203, 1, 34, // Opcode: AMOMAXU_W_AQ
641
/* 2052 */    MCD_OPC_FilterValue, 3, 94, 7, 0, // Skip to: 3943
642
/* 2057 */    MCD_OPC_CheckPredicate, 7, 89, 7, 0, // Skip to: 3943
643
/* 2062 */    MCD_OPC_Decode, 199, 1, 34, // Opcode: AMOMAXU_D_AQ
644
/* 2066 */    MCD_OPC_FilterValue, 115, 80, 7, 0, // Skip to: 3943
645
/* 2071 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
646
/* 2074 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 2088
647
/* 2079 */    MCD_OPC_CheckPredicate, 6, 67, 7, 0, // Skip to: 3943
648
/* 2084 */    MCD_OPC_Decode, 204, 1, 34, // Opcode: AMOMAXU_W_AQ_RL
649
/* 2088 */    MCD_OPC_FilterValue, 3, 58, 7, 0, // Skip to: 3943
650
/* 2093 */    MCD_OPC_CheckPredicate, 7, 53, 7, 0, // Skip to: 3943
651
/* 2098 */    MCD_OPC_Decode, 200, 1, 34, // Opcode: AMOMAXU_D_AQ_RL
652
/* 2102 */    MCD_OPC_FilterValue, 51, 13, 1, 0, // Skip to: 2376
653
/* 2107 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
654
/* 2110 */    MCD_OPC_FilterValue, 0, 35, 0, 0, // Skip to: 2150
655
/* 2115 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
656
/* 2118 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2127
657
/* 2123 */    MCD_OPC_Decode, 178, 1, 34, // Opcode: ADD
658
/* 2127 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 2141
659
/* 2132 */    MCD_OPC_CheckPredicate, 8, 14, 7, 0, // Skip to: 3943
660
/* 2137 */    MCD_OPC_Decode, 146, 3, 34, // Opcode: MUL
661
/* 2141 */    MCD_OPC_FilterValue, 32, 5, 7, 0, // Skip to: 3943
662
/* 2146 */    MCD_OPC_Decode, 186, 3, 34, // Opcode: SUB
663
/* 2150 */    MCD_OPC_FilterValue, 1, 26, 0, 0, // Skip to: 2181
664
/* 2155 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
665
/* 2158 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2167
666
/* 2163 */    MCD_OPC_Decode, 169, 3, 34, // Opcode: SLL
667
/* 2167 */    MCD_OPC_FilterValue, 1, 235, 6, 0, // Skip to: 3943
668
/* 2172 */    MCD_OPC_CheckPredicate, 8, 230, 6, 0, // Skip to: 3943
669
/* 2177 */    MCD_OPC_Decode, 147, 3, 34, // Opcode: MULH
670
/* 2181 */    MCD_OPC_FilterValue, 2, 26, 0, 0, // Skip to: 2212
671
/* 2186 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
672
/* 2189 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2198
673
/* 2194 */    MCD_OPC_Decode, 173, 3, 34, // Opcode: SLT
674
/* 2198 */    MCD_OPC_FilterValue, 1, 204, 6, 0, // Skip to: 3943
675
/* 2203 */    MCD_OPC_CheckPredicate, 8, 199, 6, 0, // Skip to: 3943
676
/* 2208 */    MCD_OPC_Decode, 148, 3, 34, // Opcode: MULHSU
677
/* 2212 */    MCD_OPC_FilterValue, 3, 26, 0, 0, // Skip to: 2243
678
/* 2217 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
679
/* 2220 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2229
680
/* 2225 */    MCD_OPC_Decode, 176, 3, 34, // Opcode: SLTU
681
/* 2229 */    MCD_OPC_FilterValue, 1, 173, 6, 0, // Skip to: 3943
682
/* 2234 */    MCD_OPC_CheckPredicate, 8, 168, 6, 0, // Skip to: 3943
683
/* 2239 */    MCD_OPC_Decode, 149, 3, 34, // Opcode: MULHU
684
/* 2243 */    MCD_OPC_FilterValue, 4, 26, 0, 0, // Skip to: 2274
685
/* 2248 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
686
/* 2251 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2260
687
/* 2256 */    MCD_OPC_Decode, 192, 3, 34, // Opcode: XOR
688
/* 2260 */    MCD_OPC_FilterValue, 1, 142, 6, 0, // Skip to: 3943
689
/* 2265 */    MCD_OPC_CheckPredicate, 8, 137, 6, 0, // Skip to: 3943
690
/* 2270 */    MCD_OPC_Decode, 184, 2, 34, // Opcode: DIV
691
/* 2274 */    MCD_OPC_FilterValue, 5, 35, 0, 0, // Skip to: 2314
692
/* 2279 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
693
/* 2282 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2291
694
/* 2287 */    MCD_OPC_Decode, 182, 3, 34, // Opcode: SRL
695
/* 2291 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 2305
696
/* 2296 */    MCD_OPC_CheckPredicate, 8, 106, 6, 0, // Skip to: 3943
697
/* 2301 */    MCD_OPC_Decode, 185, 2, 34, // Opcode: DIVU
698
/* 2305 */    MCD_OPC_FilterValue, 32, 97, 6, 0, // Skip to: 3943
699
/* 2310 */    MCD_OPC_Decode, 177, 3, 34, // Opcode: SRA
700
/* 2314 */    MCD_OPC_FilterValue, 6, 26, 0, 0, // Skip to: 2345
701
/* 2319 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
702
/* 2322 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2331
703
/* 2327 */    MCD_OPC_Decode, 151, 3, 34, // Opcode: OR
704
/* 2331 */    MCD_OPC_FilterValue, 1, 71, 6, 0, // Skip to: 3943
705
/* 2336 */    MCD_OPC_CheckPredicate, 8, 66, 6, 0, // Skip to: 3943
706
/* 2341 */    MCD_OPC_Decode, 153, 3, 34, // Opcode: REM
707
/* 2345 */    MCD_OPC_FilterValue, 7, 57, 6, 0, // Skip to: 3943
708
/* 2350 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
709
/* 2353 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 2362
710
/* 2358 */    MCD_OPC_Decode, 254, 1, 34, // Opcode: AND
711
/* 2362 */    MCD_OPC_FilterValue, 1, 40, 6, 0, // Skip to: 3943
712
/* 2367 */    MCD_OPC_CheckPredicate, 8, 35, 6, 0, // Skip to: 3943
713
/* 2372 */    MCD_OPC_Decode, 154, 3, 34, // Opcode: REMU
714
/* 2376 */    MCD_OPC_FilterValue, 55, 4, 0, 0, // Skip to: 2385
715
/* 2381 */    MCD_OPC_Decode, 142, 3, 29, // Opcode: LUI
716
/* 2385 */    MCD_OPC_FilterValue, 59, 187, 0, 0, // Skip to: 2577
717
/* 2390 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
718
/* 2393 */    MCD_OPC_FilterValue, 0, 45, 0, 0, // Skip to: 2443
719
/* 2398 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
720
/* 2401 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2415
721
/* 2406 */    MCD_OPC_CheckPredicate, 3, 252, 5, 0, // Skip to: 3943
722
/* 2411 */    MCD_OPC_Decode, 181, 1, 34, // Opcode: ADDW
723
/* 2415 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 2429
724
/* 2420 */    MCD_OPC_CheckPredicate, 9, 238, 5, 0, // Skip to: 3943
725
/* 2425 */    MCD_OPC_Decode, 150, 3, 34, // Opcode: MULW
726
/* 2429 */    MCD_OPC_FilterValue, 32, 229, 5, 0, // Skip to: 3943
727
/* 2434 */    MCD_OPC_CheckPredicate, 3, 224, 5, 0, // Skip to: 3943
728
/* 2439 */    MCD_OPC_Decode, 187, 3, 34, // Opcode: SUBW
729
/* 2443 */    MCD_OPC_FilterValue, 1, 16, 0, 0, // Skip to: 2464
730
/* 2448 */    MCD_OPC_CheckPredicate, 3, 210, 5, 0, // Skip to: 3943
731
/* 2453 */    MCD_OPC_CheckField, 25, 7, 0, 203, 5, 0, // Skip to: 3943
732
/* 2460 */    MCD_OPC_Decode, 172, 3, 34, // Opcode: SLLW
733
/* 2464 */    MCD_OPC_FilterValue, 4, 16, 0, 0, // Skip to: 2485
734
/* 2469 */    MCD_OPC_CheckPredicate, 9, 189, 5, 0, // Skip to: 3943
735
/* 2474 */    MCD_OPC_CheckField, 25, 7, 1, 182, 5, 0, // Skip to: 3943
736
/* 2481 */    MCD_OPC_Decode, 187, 2, 34, // Opcode: DIVW
737
/* 2485 */    MCD_OPC_FilterValue, 5, 45, 0, 0, // Skip to: 2535
738
/* 2490 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
739
/* 2493 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2507
740
/* 2498 */    MCD_OPC_CheckPredicate, 3, 160, 5, 0, // Skip to: 3943
741
/* 2503 */    MCD_OPC_Decode, 185, 3, 34, // Opcode: SRLW
742
/* 2507 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 2521
743
/* 2512 */    MCD_OPC_CheckPredicate, 9, 146, 5, 0, // Skip to: 3943
744
/* 2517 */    MCD_OPC_Decode, 186, 2, 34, // Opcode: DIVUW
745
/* 2521 */    MCD_OPC_FilterValue, 32, 137, 5, 0, // Skip to: 3943
746
/* 2526 */    MCD_OPC_CheckPredicate, 3, 132, 5, 0, // Skip to: 3943
747
/* 2531 */    MCD_OPC_Decode, 180, 3, 34, // Opcode: SRAW
748
/* 2535 */    MCD_OPC_FilterValue, 6, 16, 0, 0, // Skip to: 2556
749
/* 2540 */    MCD_OPC_CheckPredicate, 9, 118, 5, 0, // Skip to: 3943
750
/* 2545 */    MCD_OPC_CheckField, 25, 7, 1, 111, 5, 0, // Skip to: 3943
751
/* 2552 */    MCD_OPC_Decode, 156, 3, 34, // Opcode: REMW
752
/* 2556 */    MCD_OPC_FilterValue, 7, 102, 5, 0, // Skip to: 3943
753
/* 2561 */    MCD_OPC_CheckPredicate, 9, 97, 5, 0, // Skip to: 3943
754
/* 2566 */    MCD_OPC_CheckField, 25, 7, 1, 90, 5, 0, // Skip to: 3943
755
/* 2573 */    MCD_OPC_Decode, 155, 3, 34, // Opcode: REMUW
756
/* 2577 */    MCD_OPC_FilterValue, 67, 31, 0, 0, // Skip to: 2613
757
/* 2582 */    MCD_OPC_ExtractField, 25, 2,  // Inst{26-25} ...
758
/* 2585 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2599
759
/* 2590 */    MCD_OPC_CheckPredicate, 4, 68, 5, 0, // Skip to: 3943
760
/* 2595 */    MCD_OPC_Decode, 226, 2, 36, // Opcode: FMADD_S
761
/* 2599 */    MCD_OPC_FilterValue, 1, 59, 5, 0, // Skip to: 3943
762
/* 2604 */    MCD_OPC_CheckPredicate, 5, 54, 5, 0, // Skip to: 3943
763
/* 2609 */    MCD_OPC_Decode, 225, 2, 37, // Opcode: FMADD_D
764
/* 2613 */    MCD_OPC_FilterValue, 71, 31, 0, 0, // Skip to: 2649
765
/* 2618 */    MCD_OPC_ExtractField, 25, 2,  // Inst{26-25} ...
766
/* 2621 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2635
767
/* 2626 */    MCD_OPC_CheckPredicate, 4, 32, 5, 0, // Skip to: 3943
768
/* 2631 */    MCD_OPC_Decode, 232, 2, 36, // Opcode: FMSUB_S
769
/* 2635 */    MCD_OPC_FilterValue, 1, 23, 5, 0, // Skip to: 3943
770
/* 2640 */    MCD_OPC_CheckPredicate, 5, 18, 5, 0, // Skip to: 3943
771
/* 2645 */    MCD_OPC_Decode, 231, 2, 37, // Opcode: FMSUB_D
772
/* 2649 */    MCD_OPC_FilterValue, 75, 31, 0, 0, // Skip to: 2685
773
/* 2654 */    MCD_OPC_ExtractField, 25, 2,  // Inst{26-25} ...
774
/* 2657 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2671
775
/* 2662 */    MCD_OPC_CheckPredicate, 4, 252, 4, 0, // Skip to: 3943
776
/* 2667 */    MCD_OPC_Decode, 242, 2, 36, // Opcode: FNMSUB_S
777
/* 2671 */    MCD_OPC_FilterValue, 1, 243, 4, 0, // Skip to: 3943
778
/* 2676 */    MCD_OPC_CheckPredicate, 5, 238, 4, 0, // Skip to: 3943
779
/* 2681 */    MCD_OPC_Decode, 241, 2, 37, // Opcode: FNMSUB_D
780
/* 2685 */    MCD_OPC_FilterValue, 79, 31, 0, 0, // Skip to: 2721
781
/* 2690 */    MCD_OPC_ExtractField, 25, 2,  // Inst{26-25} ...
782
/* 2693 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2707
783
/* 2698 */    MCD_OPC_CheckPredicate, 4, 216, 4, 0, // Skip to: 3943
784
/* 2703 */    MCD_OPC_Decode, 240, 2, 36, // Opcode: FNMADD_S
785
/* 2707 */    MCD_OPC_FilterValue, 1, 207, 4, 0, // Skip to: 3943
786
/* 2712 */    MCD_OPC_CheckPredicate, 5, 202, 4, 0, // Skip to: 3943
787
/* 2717 */    MCD_OPC_Decode, 239, 2, 37, // Opcode: FNMADD_D
788
/* 2721 */    MCD_OPC_FilterValue, 83, 136, 3, 0, // Skip to: 3630
789
/* 2726 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
790
/* 2729 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2743
791
/* 2734 */    MCD_OPC_CheckPredicate, 4, 180, 4, 0, // Skip to: 3943
792
/* 2739 */    MCD_OPC_Decode, 191, 2, 38, // Opcode: FADD_S
793
/* 2743 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 2757
794
/* 2748 */    MCD_OPC_CheckPredicate, 5, 166, 4, 0, // Skip to: 3943
795
/* 2753 */    MCD_OPC_Decode, 190, 2, 39, // Opcode: FADD_D
796
/* 2757 */    MCD_OPC_FilterValue, 4, 9, 0, 0, // Skip to: 2771
797
/* 2762 */    MCD_OPC_CheckPredicate, 4, 152, 4, 0, // Skip to: 3943
798
/* 2767 */    MCD_OPC_Decode, 253, 2, 38, // Opcode: FSUB_S
799
/* 2771 */    MCD_OPC_FilterValue, 5, 9, 0, 0, // Skip to: 2785
800
/* 2776 */    MCD_OPC_CheckPredicate, 5, 138, 4, 0, // Skip to: 3943
801
/* 2781 */    MCD_OPC_Decode, 252, 2, 39, // Opcode: FSUB_D
802
/* 2785 */    MCD_OPC_FilterValue, 8, 9, 0, 0, // Skip to: 2799
803
/* 2790 */    MCD_OPC_CheckPredicate, 4, 124, 4, 0, // Skip to: 3943
804
/* 2795 */    MCD_OPC_Decode, 234, 2, 38, // Opcode: FMUL_S
805
/* 2799 */    MCD_OPC_FilterValue, 9, 9, 0, 0, // Skip to: 2813
806
/* 2804 */    MCD_OPC_CheckPredicate, 5, 110, 4, 0, // Skip to: 3943
807
/* 2809 */    MCD_OPC_Decode, 233, 2, 39, // Opcode: FMUL_D
808
/* 2813 */    MCD_OPC_FilterValue, 12, 9, 0, 0, // Skip to: 2827
809
/* 2818 */    MCD_OPC_CheckPredicate, 4, 96, 4, 0, // Skip to: 3943
810
/* 2823 */    MCD_OPC_Decode, 213, 2, 38, // Opcode: FDIV_S
811
/* 2827 */    MCD_OPC_FilterValue, 13, 9, 0, 0, // Skip to: 2841
812
/* 2832 */    MCD_OPC_CheckPredicate, 5, 82, 4, 0, // Skip to: 3943
813
/* 2837 */    MCD_OPC_Decode, 212, 2, 39, // Opcode: FDIV_D
814
/* 2841 */    MCD_OPC_FilterValue, 16, 45, 0, 0, // Skip to: 2891
815
/* 2846 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
816
/* 2849 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2863
817
/* 2854 */    MCD_OPC_CheckPredicate, 4, 60, 4, 0, // Skip to: 3943
818
/* 2859 */    MCD_OPC_Decode, 249, 2, 40, // Opcode: FSGNJ_S
819
/* 2863 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 2877
820
/* 2868 */    MCD_OPC_CheckPredicate, 4, 46, 4, 0, // Skip to: 3943
821
/* 2873 */    MCD_OPC_Decode, 245, 2, 40, // Opcode: FSGNJN_S
822
/* 2877 */    MCD_OPC_FilterValue, 2, 37, 4, 0, // Skip to: 3943
823
/* 2882 */    MCD_OPC_CheckPredicate, 4, 32, 4, 0, // Skip to: 3943
824
/* 2887 */    MCD_OPC_Decode, 247, 2, 40, // Opcode: FSGNJX_S
825
/* 2891 */    MCD_OPC_FilterValue, 17, 45, 0, 0, // Skip to: 2941
826
/* 2896 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
827
/* 2899 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2913
828
/* 2904 */    MCD_OPC_CheckPredicate, 5, 10, 4, 0, // Skip to: 3943
829
/* 2909 */    MCD_OPC_Decode, 248, 2, 41, // Opcode: FSGNJ_D
830
/* 2913 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 2927
831
/* 2918 */    MCD_OPC_CheckPredicate, 5, 252, 3, 0, // Skip to: 3943
832
/* 2923 */    MCD_OPC_Decode, 244, 2, 41, // Opcode: FSGNJN_D
833
/* 2927 */    MCD_OPC_FilterValue, 2, 243, 3, 0, // Skip to: 3943
834
/* 2932 */    MCD_OPC_CheckPredicate, 5, 238, 3, 0, // Skip to: 3943
835
/* 2937 */    MCD_OPC_Decode, 246, 2, 41, // Opcode: FSGNJX_D
836
/* 2941 */    MCD_OPC_FilterValue, 20, 31, 0, 0, // Skip to: 2977
837
/* 2946 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
838
/* 2949 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2963
839
/* 2954 */    MCD_OPC_CheckPredicate, 4, 216, 3, 0, // Skip to: 3943
840
/* 2959 */    MCD_OPC_Decode, 230, 2, 40, // Opcode: FMIN_S
841
/* 2963 */    MCD_OPC_FilterValue, 1, 207, 3, 0, // Skip to: 3943
842
/* 2968 */    MCD_OPC_CheckPredicate, 4, 202, 3, 0, // Skip to: 3943
843
/* 2973 */    MCD_OPC_Decode, 228, 2, 40, // Opcode: FMAX_S
844
/* 2977 */    MCD_OPC_FilterValue, 21, 31, 0, 0, // Skip to: 3013
845
/* 2982 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
846
/* 2985 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 2999
847
/* 2990 */    MCD_OPC_CheckPredicate, 5, 180, 3, 0, // Skip to: 3943
848
/* 2995 */    MCD_OPC_Decode, 229, 2, 41, // Opcode: FMIN_D
849
/* 2999 */    MCD_OPC_FilterValue, 1, 171, 3, 0, // Skip to: 3943
850
/* 3004 */    MCD_OPC_CheckPredicate, 5, 166, 3, 0, // Skip to: 3943
851
/* 3009 */    MCD_OPC_Decode, 227, 2, 41, // Opcode: FMAX_D
852
/* 3013 */    MCD_OPC_FilterValue, 32, 16, 0, 0, // Skip to: 3034
853
/* 3018 */    MCD_OPC_CheckPredicate, 5, 152, 3, 0, // Skip to: 3943
854
/* 3023 */    MCD_OPC_CheckField, 20, 5, 1, 145, 3, 0, // Skip to: 3943
855
/* 3030 */    MCD_OPC_Decode, 203, 2, 42, // Opcode: FCVT_S_D
856
/* 3034 */    MCD_OPC_FilterValue, 33, 23, 0, 0, // Skip to: 3062
857
/* 3039 */    MCD_OPC_CheckPredicate, 5, 131, 3, 0, // Skip to: 3943
858
/* 3044 */    MCD_OPC_CheckField, 20, 5, 0, 124, 3, 0, // Skip to: 3943
859
/* 3051 */    MCD_OPC_CheckField, 12, 3, 0, 117, 3, 0, // Skip to: 3943
860
/* 3058 */    MCD_OPC_Decode, 196, 2, 43, // Opcode: FCVT_D_S
861
/* 3062 */    MCD_OPC_FilterValue, 44, 16, 0, 0, // Skip to: 3083
862
/* 3067 */    MCD_OPC_CheckPredicate, 4, 103, 3, 0, // Skip to: 3943
863
/* 3072 */    MCD_OPC_CheckField, 20, 5, 0, 96, 3, 0, // Skip to: 3943
864
/* 3079 */    MCD_OPC_Decode, 251, 2, 44, // Opcode: FSQRT_S
865
/* 3083 */    MCD_OPC_FilterValue, 45, 16, 0, 0, // Skip to: 3104
866
/* 3088 */    MCD_OPC_CheckPredicate, 5, 82, 3, 0, // Skip to: 3943
867
/* 3093 */    MCD_OPC_CheckField, 20, 5, 0, 75, 3, 0, // Skip to: 3943
868
/* 3100 */    MCD_OPC_Decode, 250, 2, 45, // Opcode: FSQRT_D
869
/* 3104 */    MCD_OPC_FilterValue, 80, 45, 0, 0, // Skip to: 3154
870
/* 3109 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
871
/* 3112 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 3126
872
/* 3117 */    MCD_OPC_CheckPredicate, 4, 53, 3, 0, // Skip to: 3943
873
/* 3122 */    MCD_OPC_Decode, 221, 2, 46, // Opcode: FLE_S
874
/* 3126 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 3140
875
/* 3131 */    MCD_OPC_CheckPredicate, 4, 39, 3, 0, // Skip to: 3943
876
/* 3136 */    MCD_OPC_Decode, 223, 2, 46, // Opcode: FLT_S
877
/* 3140 */    MCD_OPC_FilterValue, 2, 30, 3, 0, // Skip to: 3943
878
/* 3145 */    MCD_OPC_CheckPredicate, 4, 25, 3, 0, // Skip to: 3943
879
/* 3150 */    MCD_OPC_Decode, 218, 2, 46, // Opcode: FEQ_S
880
/* 3154 */    MCD_OPC_FilterValue, 81, 45, 0, 0, // Skip to: 3204
881
/* 3159 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
882
/* 3162 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 3176
883
/* 3167 */    MCD_OPC_CheckPredicate, 5, 3, 3, 0, // Skip to: 3943
884
/* 3172 */    MCD_OPC_Decode, 220, 2, 47, // Opcode: FLE_D
885
/* 3176 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 3190
886
/* 3181 */    MCD_OPC_CheckPredicate, 5, 245, 2, 0, // Skip to: 3943
887
/* 3186 */    MCD_OPC_Decode, 222, 2, 47, // Opcode: FLT_D
888
/* 3190 */    MCD_OPC_FilterValue, 2, 236, 2, 0, // Skip to: 3943
889
/* 3195 */    MCD_OPC_CheckPredicate, 5, 231, 2, 0, // Skip to: 3943
890
/* 3200 */    MCD_OPC_Decode, 217, 2, 47, // Opcode: FEQ_D
891
/* 3204 */    MCD_OPC_FilterValue, 96, 59, 0, 0, // Skip to: 3268
892
/* 3209 */    MCD_OPC_ExtractField, 20, 5,  // Inst{24-20} ...
893
/* 3212 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 3226
894
/* 3217 */    MCD_OPC_CheckPredicate, 4, 209, 2, 0, // Skip to: 3943
895
/* 3222 */    MCD_OPC_Decode, 211, 2, 48, // Opcode: FCVT_W_S
896
/* 3226 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 3240
897
/* 3231 */    MCD_OPC_CheckPredicate, 4, 195, 2, 0, // Skip to: 3943
898
/* 3236 */    MCD_OPC_Decode, 209, 2, 48, // Opcode: FCVT_WU_S
899
/* 3240 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 3254
900
/* 3245 */    MCD_OPC_CheckPredicate, 10, 181, 2, 0, // Skip to: 3943
901
/* 3250 */    MCD_OPC_Decode, 202, 2, 48, // Opcode: FCVT_L_S
902
/* 3254 */    MCD_OPC_FilterValue, 3, 172, 2, 0, // Skip to: 3943
903
/* 3259 */    MCD_OPC_CheckPredicate, 10, 167, 2, 0, // Skip to: 3943
904
/* 3264 */    MCD_OPC_Decode, 200, 2, 48, // Opcode: FCVT_LU_S
905
/* 3268 */    MCD_OPC_FilterValue, 97, 59, 0, 0, // Skip to: 3332
906
/* 3273 */    MCD_OPC_ExtractField, 20, 5,  // Inst{24-20} ...
907
/* 3276 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 3290
908
/* 3281 */    MCD_OPC_CheckPredicate, 5, 145, 2, 0, // Skip to: 3943
909
/* 3286 */    MCD_OPC_Decode, 210, 2, 49, // Opcode: FCVT_W_D
910
/* 3290 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 3304
911
/* 3295 */    MCD_OPC_CheckPredicate, 5, 131, 2, 0, // Skip to: 3943
912
/* 3300 */    MCD_OPC_Decode, 208, 2, 49, // Opcode: FCVT_WU_D
913
/* 3304 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 3318
914
/* 3309 */    MCD_OPC_CheckPredicate, 11, 117, 2, 0, // Skip to: 3943
915
/* 3314 */    MCD_OPC_Decode, 201, 2, 49, // Opcode: FCVT_L_D
916
/* 3318 */    MCD_OPC_FilterValue, 3, 108, 2, 0, // Skip to: 3943
917
/* 3323 */    MCD_OPC_CheckPredicate, 11, 103, 2, 0, // Skip to: 3943
918
/* 3328 */    MCD_OPC_Decode, 199, 2, 49, // Opcode: FCVT_LU_D
919
/* 3332 */    MCD_OPC_FilterValue, 104, 59, 0, 0, // Skip to: 3396
920
/* 3337 */    MCD_OPC_ExtractField, 20, 5,  // Inst{24-20} ...
921
/* 3340 */    MCD_OPC_FilterValue, 0, 9, 0, 0, // Skip to: 3354
922
/* 3345 */    MCD_OPC_CheckPredicate, 4, 81, 2, 0, // Skip to: 3943
923
/* 3350 */    MCD_OPC_Decode, 206, 2, 50, // Opcode: FCVT_S_W
924
/* 3354 */    MCD_OPC_FilterValue, 1, 9, 0, 0, // Skip to: 3368
925
/* 3359 */    MCD_OPC_CheckPredicate, 4, 67, 2, 0, // Skip to: 3943
926
/* 3364 */    MCD_OPC_Decode, 207, 2, 50, // Opcode: FCVT_S_WU
927
/* 3368 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 3382
928
/* 3373 */    MCD_OPC_CheckPredicate, 10, 53, 2, 0, // Skip to: 3943
929
/* 3378 */    MCD_OPC_Decode, 204, 2, 50, // Opcode: FCVT_S_L
930
/* 3382 */    MCD_OPC_FilterValue, 3, 44, 2, 0, // Skip to: 3943
931
/* 3387 */    MCD_OPC_CheckPredicate, 10, 39, 2, 0, // Skip to: 3943
932
/* 3392 */    MCD_OPC_Decode, 205, 2, 50, // Opcode: FCVT_S_LU
933
/* 3396 */    MCD_OPC_FilterValue, 105, 73, 0, 0, // Skip to: 3474
934
/* 3401 */    MCD_OPC_ExtractField, 20, 5,  // Inst{24-20} ...
935
/* 3404 */    MCD_OPC_FilterValue, 0, 16, 0, 0, // Skip to: 3425
936
/* 3409 */    MCD_OPC_CheckPredicate, 5, 17, 2, 0, // Skip to: 3943
937
/* 3414 */    MCD_OPC_CheckField, 12, 3, 0, 10, 2, 0, // Skip to: 3943
938
/* 3421 */    MCD_OPC_Decode, 197, 2, 51, // Opcode: FCVT_D_W
939
/* 3425 */    MCD_OPC_FilterValue, 1, 16, 0, 0, // Skip to: 3446
940
/* 3430 */    MCD_OPC_CheckPredicate, 5, 252, 1, 0, // Skip to: 3943
941
/* 3435 */    MCD_OPC_CheckField, 12, 3, 0, 245, 1, 0, // Skip to: 3943
942
/* 3442 */    MCD_OPC_Decode, 198, 2, 51, // Opcode: FCVT_D_WU
943
/* 3446 */    MCD_OPC_FilterValue, 2, 9, 0, 0, // Skip to: 3460
944
/* 3451 */    MCD_OPC_CheckPredicate, 11, 231, 1, 0, // Skip to: 3943
945
/* 3456 */    MCD_OPC_Decode, 194, 2, 52, // Opcode: FCVT_D_L
946
/* 3460 */    MCD_OPC_FilterValue, 3, 222, 1, 0, // Skip to: 3943
947
/* 3465 */    MCD_OPC_CheckPredicate, 11, 217, 1, 0, // Skip to: 3943
948
/* 3470 */    MCD_OPC_Decode, 195, 2, 52, // Opcode: FCVT_D_LU
949
/* 3474 */    MCD_OPC_FilterValue, 112, 45, 0, 0, // Skip to: 3524
950
/* 3479 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
951
/* 3482 */    MCD_OPC_FilterValue, 0, 16, 0, 0, // Skip to: 3503
952
/* 3487 */    MCD_OPC_CheckPredicate, 4, 195, 1, 0, // Skip to: 3943
953
/* 3492 */    MCD_OPC_CheckField, 20, 5, 0, 188, 1, 0, // Skip to: 3943
954
/* 3499 */    MCD_OPC_Decode, 238, 2, 53, // Opcode: FMV_X_W
955
/* 3503 */    MCD_OPC_FilterValue, 1, 179, 1, 0, // Skip to: 3943
956
/* 3508 */    MCD_OPC_CheckPredicate, 4, 174, 1, 0, // Skip to: 3943
957
/* 3513 */    MCD_OPC_CheckField, 20, 5, 0, 167, 1, 0, // Skip to: 3943
958
/* 3520 */    MCD_OPC_Decode, 193, 2, 53, // Opcode: FCLASS_S
959
/* 3524 */    MCD_OPC_FilterValue, 113, 45, 0, 0, // Skip to: 3574
960
/* 3529 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
961
/* 3532 */    MCD_OPC_FilterValue, 0, 16, 0, 0, // Skip to: 3553
962
/* 3537 */    MCD_OPC_CheckPredicate, 11, 145, 1, 0, // Skip to: 3943
963
/* 3542 */    MCD_OPC_CheckField, 20, 5, 0, 138, 1, 0, // Skip to: 3943
964
/* 3549 */    MCD_OPC_Decode, 237, 2, 54, // Opcode: FMV_X_D
965
/* 3553 */    MCD_OPC_FilterValue, 1, 129, 1, 0, // Skip to: 3943
966
/* 3558 */    MCD_OPC_CheckPredicate, 5, 124, 1, 0, // Skip to: 3943
967
/* 3563 */    MCD_OPC_CheckField, 20, 5, 0, 117, 1, 0, // Skip to: 3943
968
/* 3570 */    MCD_OPC_Decode, 192, 2, 54, // Opcode: FCLASS_D
969
/* 3574 */    MCD_OPC_FilterValue, 120, 23, 0, 0, // Skip to: 3602
970
/* 3579 */    MCD_OPC_CheckPredicate, 4, 103, 1, 0, // Skip to: 3943
971
/* 3584 */    MCD_OPC_CheckField, 20, 5, 0, 96, 1, 0, // Skip to: 3943
972
/* 3591 */    MCD_OPC_CheckField, 12, 3, 0, 89, 1, 0, // Skip to: 3943
973
/* 3598 */    MCD_OPC_Decode, 236, 2, 55, // Opcode: FMV_W_X
974
/* 3602 */    MCD_OPC_FilterValue, 121, 80, 1, 0, // Skip to: 3943
975
/* 3607 */    MCD_OPC_CheckPredicate, 11, 75, 1, 0, // Skip to: 3943
976
/* 3612 */    MCD_OPC_CheckField, 20, 5, 0, 68, 1, 0, // Skip to: 3943
977
/* 3619 */    MCD_OPC_CheckField, 12, 3, 0, 61, 1, 0, // Skip to: 3943
978
/* 3626 */    MCD_OPC_Decode, 235, 2, 51, // Opcode: FMV_D_X
979
/* 3630 */    MCD_OPC_FilterValue, 99, 57, 0, 0, // Skip to: 3692
980
/* 3635 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
981
/* 3638 */    MCD_OPC_FilterValue, 0, 4, 0, 0, // Skip to: 3647
982
/* 3643 */    MCD_OPC_Decode, 129, 2, 56, // Opcode: BEQ
983
/* 3647 */    MCD_OPC_FilterValue, 1, 4, 0, 0, // Skip to: 3656
984
/* 3652 */    MCD_OPC_Decode, 134, 2, 56, // Opcode: BNE
985
/* 3656 */    MCD_OPC_FilterValue, 4, 4, 0, 0, // Skip to: 3665
986
/* 3661 */    MCD_OPC_Decode, 132, 2, 56, // Opcode: BLT
987
/* 3665 */    MCD_OPC_FilterValue, 5, 4, 0, 0, // Skip to: 3674
988
/* 3670 */    MCD_OPC_Decode, 130, 2, 56, // Opcode: BGE
989
/* 3674 */    MCD_OPC_FilterValue, 6, 4, 0, 0, // Skip to: 3683
990
/* 3679 */    MCD_OPC_Decode, 133, 2, 56, // Opcode: BLTU
991
/* 3683 */    MCD_OPC_FilterValue, 7, 255, 0, 0, // Skip to: 3943
992
/* 3688 */    MCD_OPC_Decode, 131, 2, 56, // Opcode: BGEU
993
/* 3692 */    MCD_OPC_FilterValue, 103, 11, 0, 0, // Skip to: 3708
994
/* 3697 */    MCD_OPC_CheckField, 12, 3, 0, 239, 0, 0, // Skip to: 3943
995
/* 3704 */    MCD_OPC_Decode, 128, 3, 24, // Opcode: JALR
996
/* 3708 */    MCD_OPC_FilterValue, 111, 4, 0, 0, // Skip to: 3717
997
/* 3713 */    MCD_OPC_Decode, 255, 2, 57, // Opcode: JAL
998
/* 3717 */    MCD_OPC_FilterValue, 115, 221, 0, 0, // Skip to: 3943
999
/* 3722 */    MCD_OPC_ExtractField, 12, 3,  // Inst{14-12} ...
1000
/* 3725 */    MCD_OPC_FilterValue, 0, 139, 0, 0, // Skip to: 3869
1001
/* 3730 */    MCD_OPC_ExtractField, 25, 7,  // Inst{31-25} ...
1002
/* 3733 */    MCD_OPC_FilterValue, 0, 51, 0, 0, // Skip to: 3789
1003
/* 3738 */    MCD_OPC_ExtractField, 15, 10,  // Inst{24-15} ...
1004
/* 3741 */    MCD_OPC_FilterValue, 0, 11, 0, 0, // Skip to: 3757
1005
/* 3746 */    MCD_OPC_CheckField, 7, 5, 0, 190, 0, 0, // Skip to: 3943
1006
/* 3753 */    MCD_OPC_Decode, 189, 2, 0, // Opcode: ECALL
1007
/* 3757 */    MCD_OPC_FilterValue, 32, 11, 0, 0, // Skip to: 3773
1008
/* 3762 */    MCD_OPC_CheckField, 7, 5, 0, 174, 0, 0, // Skip to: 3943
1009
/* 3769 */    MCD_OPC_Decode, 188, 2, 0, // Opcode: EBREAK
1010
/* 3773 */    MCD_OPC_FilterValue, 64, 165, 0, 0, // Skip to: 3943
1011
/* 3778 */    MCD_OPC_CheckField, 7, 5, 0, 158, 0, 0, // Skip to: 3943
1012
/* 3785 */    MCD_OPC_Decode, 190, 3, 0, // Opcode: URET
1013
/* 3789 */    MCD_OPC_FilterValue, 8, 36, 0, 0, // Skip to: 3830
1014
/* 3794 */    MCD_OPC_ExtractField, 15, 10,  // Inst{24-15} ...
1015
/* 3797 */    MCD_OPC_FilterValue, 64, 11, 0, 0, // Skip to: 3813
1016
/* 3802 */    MCD_OPC_CheckField, 7, 5, 0, 134, 0, 0, // Skip to: 3943
1017
/* 3809 */    MCD_OPC_Decode, 181, 3, 0, // Opcode: SRET
1018
/* 3813 */    MCD_OPC_FilterValue, 160, 1, 124, 0, 0, // Skip to: 3943
1019
/* 3819 */    MCD_OPC_CheckField, 7, 5, 0, 117, 0, 0, // Skip to: 3943
1020
/* 3826 */    MCD_OPC_Decode, 191, 3, 0, // Opcode: WFI
1021
/* 3830 */    MCD_OPC_FilterValue, 9, 11, 0, 0, // Skip to: 3846
1022
/* 3835 */    MCD_OPC_CheckField, 7, 5, 0, 101, 0, 0, // Skip to: 3943
1023
/* 3842 */    MCD_OPC_Decode, 167, 3, 58, // Opcode: SFENCE_VMA
1024
/* 3846 */    MCD_OPC_FilterValue, 24, 92, 0, 0, // Skip to: 3943
1025
/* 3851 */    MCD_OPC_CheckField, 15, 10, 64, 85, 0, 0, // Skip to: 3943
1026
/* 3858 */    MCD_OPC_CheckField, 7, 5, 0, 78, 0, 0, // Skip to: 3943
1027
/* 3865 */    MCD_OPC_Decode, 145, 3, 0, // Opcode: MRET
1028
/* 3869 */    MCD_OPC_FilterValue, 1, 24, 0, 0, // Skip to: 3898
1029
/* 3874 */    MCD_OPC_CheckField, 15, 17, 128, 128, 6, 11, 0, 0, // Skip to: 3894
1030
/* 3883 */    MCD_OPC_CheckField, 7, 5, 0, 4, 0, 0, // Skip to: 3894
1031
/* 3890 */    MCD_OPC_Decode, 189, 3, 0, // Opcode: UNIMP
1032
/* 3894 */    MCD_OPC_Decode, 139, 2, 59, // Opcode: CSRRW
1033
/* 3898 */    MCD_OPC_FilterValue, 2, 4, 0, 0, // Skip to: 3907
1034
/* 3903 */    MCD_OPC_Decode, 137, 2, 59, // Opcode: CSRRS
1035
/* 3907 */    MCD_OPC_FilterValue, 3, 4, 0, 0, // Skip to: 3916
1036
/* 3912 */    MCD_OPC_Decode, 135, 2, 59, // Opcode: CSRRC
1037
/* 3916 */    MCD_OPC_FilterValue, 5, 4, 0, 0, // Skip to: 3925
1038
/* 3921 */    MCD_OPC_Decode, 140, 2, 60, // Opcode: CSRRWI
1039
/* 3925 */    MCD_OPC_FilterValue, 6, 4, 0, 0, // Skip to: 3934
1040
/* 3930 */    MCD_OPC_Decode, 138, 2, 60, // Opcode: CSRRSI
1041
/* 3934 */    MCD_OPC_FilterValue, 7, 4, 0, 0, // Skip to: 3943
1042
/* 3939 */    MCD_OPC_Decode, 136, 2, 60, // Opcode: CSRRCI
1043
/* 3943 */    MCD_OPC_Fail,
1044
  0
1045
};
1046
1047
static const uint8_t DecoderTableRISCV32Only_16[] = {
1048
/* 0 */       MCD_OPC_ExtractField, 0, 2,  // Inst{1-0} ...
1049
/* 3 */       MCD_OPC_FilterValue, 0, 31, 0, 0, // Skip to: 39
1050
/* 8 */       MCD_OPC_ExtractField, 13, 3,  // Inst{15-13} ...
1051
/* 11 */      MCD_OPC_FilterValue, 3, 9, 0, 0, // Skip to: 25
1052
/* 16 */      MCD_OPC_CheckPredicate, 12, 75, 0, 0, // Skip to: 96
1053
/* 21 */      MCD_OPC_Decode, 154, 2, 61, // Opcode: C_FLW
1054
/* 25 */      MCD_OPC_FilterValue, 7, 66, 0, 0, // Skip to: 96
1055
/* 30 */      MCD_OPC_CheckPredicate, 12, 61, 0, 0, // Skip to: 96
1056
/* 35 */      MCD_OPC_Decode, 158, 2, 61, // Opcode: C_FSW
1057
/* 39 */      MCD_OPC_FilterValue, 1, 16, 0, 0, // Skip to: 60
1058
/* 44 */      MCD_OPC_CheckPredicate, 13, 47, 0, 0, // Skip to: 96
1059
/* 49 */      MCD_OPC_CheckField, 13, 3, 1, 40, 0, 0, // Skip to: 96
1060
/* 56 */      MCD_OPC_Decode, 161, 2, 19, // Opcode: C_JAL
1061
/* 60 */      MCD_OPC_FilterValue, 2, 31, 0, 0, // Skip to: 96
1062
/* 65 */      MCD_OPC_ExtractField, 13, 3,  // Inst{15-13} ...
1063
/* 68 */      MCD_OPC_FilterValue, 3, 9, 0, 0, // Skip to: 82
1064
/* 73 */      MCD_OPC_CheckPredicate, 12, 18, 0, 0, // Skip to: 96
1065
/* 78 */      MCD_OPC_Decode, 155, 2, 62, // Opcode: C_FLWSP
1066
/* 82 */      MCD_OPC_FilterValue, 7, 9, 0, 0, // Skip to: 96
1067
/* 87 */      MCD_OPC_CheckPredicate, 12, 4, 0, 0, // Skip to: 96
1068
/* 92 */      MCD_OPC_Decode, 159, 2, 63, // Opcode: C_FSWSP
1069
/* 96 */      MCD_OPC_Fail,
1070
  0
1071
};
1072
1073
static bool checkDecoderPredicate(unsigned Idx, uint64_t Bits)
1074
40.9k
{
1075
40.9k
  switch (Idx) {
1076
0
  default: CS_ASSERT(0 && "Invalid index!");
1077
1.10k
  case 0:
1078
1.10k
    return (Bits & RISCV_FeatureStdExtC);
1079
226
  case 1:
1080
226
    return (Bits & RISCV_FeatureStdExtC) && (Bits & RISCV_FeatureStdExtD);
1081
335
  case 2:
1082
335
    return (Bits & RISCV_FeatureStdExtC) && (Bits & RISCV_Feature64Bit);
1083
1.74k
  case 3:
1084
1.74k
    return (Bits & RISCV_Feature64Bit);
1085
14.8k
  case 4:
1086
14.8k
    return (Bits & RISCV_FeatureStdExtF);
1087
9.62k
  case 5:
1088
9.62k
    return (Bits & RISCV_FeatureStdExtD);
1089
2.53k
  case 6:
1090
2.53k
    return (Bits & RISCV_FeatureStdExtA);
1091
3.17k
  case 7:
1092
3.17k
    return (Bits & RISCV_FeatureStdExtA) && (Bits & RISCV_Feature64Bit);
1093
40
  case 8:
1094
40
    return (Bits & RISCV_FeatureStdExtM);
1095
147
  case 9:
1096
147
    return (Bits & RISCV_FeatureStdExtM) && (Bits & RISCV_Feature64Bit);
1097
2.45k
  case 10:
1098
2.45k
    return (Bits & RISCV_FeatureStdExtF) && (Bits & RISCV_Feature64Bit);
1099
4.43k
  case 11:
1100
4.43k
    return (Bits & RISCV_FeatureStdExtD) && (Bits & RISCV_Feature64Bit);
1101
131
  case 12:
1102
131
    return (Bits & RISCV_FeatureStdExtC) && (Bits & RISCV_FeatureStdExtF) && !(Bits & RISCV_Feature64Bit);
1103
160
  case 13:
1104
160
    return (Bits & RISCV_FeatureStdExtC) && !(Bits & RISCV_Feature64Bit);
1105
40.9k
  }
1106
40.9k
}
1107
1108
#define DecodeToMCInst(fname, fieldname, InsnType) \
1109
static DecodeStatus fname(DecodeStatus S, unsigned Idx, InsnType insn, MCInst *MI, \
1110
                          uint64_t Address, const void *Decoder,\
1111
141k
                          bool *DecodeComplete) {\
1112
141k
  *DecodeComplete = true;\
1113
141k
  InsnType tmp; \
1114
141k
  switch (Idx) { \
1115
0
  default: CS_ASSERT(0 && "Invalid index!");\
1116
265
  case 0: \
1117
265
    return S; \
1118
0
  case 1: \
1119
0
    tmp = fieldname(insn, 2, 3); \
1120
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1121
0
    tmp = 0; \
1122
0
    tmp |= fieldname(insn, 5, 1) << 3; \
1123
0
    tmp |= fieldname(insn, 6, 1) << 2; \
1124
0
    tmp |= fieldname(insn, 7, 4) << 6; \
1125
0
    tmp |= fieldname(insn, 11, 2) << 4; \
1126
0
    if (decodeUImmNonZeroOperand(MI, tmp, Address, Decoder, 10) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1127
0
    return S; \
1128
0
  case 2: \
1129
0
    tmp = fieldname(insn, 7, 5); \
1130
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1131
0
    tmp = fieldname(insn, 7, 5); \
1132
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1133
0
    tmp = 0; \
1134
0
    tmp |= fieldname(insn, 2, 5) << 0; \
1135
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1136
0
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 6) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1137
0
    return S; \
1138
0
  case 3: \
1139
0
    tmp = fieldname(insn, 7, 5); \
1140
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1141
0
    tmp = fieldname(insn, 7, 5); \
1142
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1143
0
    tmp = 0; \
1144
0
    tmp |= fieldname(insn, 2, 5) << 0; \
1145
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1146
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 6) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1147
0
    return S; \
1148
0
  case 4: \
1149
0
    tmp = fieldname(insn, 2, 3); \
1150
0
    if (DecodeFPR64CRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1151
0
    tmp = fieldname(insn, 7, 3); \
1152
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1153
0
    tmp = 0; \
1154
0
    tmp |= fieldname(insn, 5, 2) << 6; \
1155
0
    tmp |= fieldname(insn, 10, 3) << 3; \
1156
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 8) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1157
0
    return S; \
1158
0
  case 5: \
1159
0
    tmp = fieldname(insn, 7, 5); \
1160
0
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1161
0
    tmp = 0; \
1162
0
    tmp |= fieldname(insn, 2, 3) << 6; \
1163
0
    tmp |= fieldname(insn, 5, 2) << 3; \
1164
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1165
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 9) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1166
0
    return S; \
1167
0
  case 6: \
1168
0
    tmp = fieldname(insn, 2, 3); \
1169
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1170
0
    tmp = fieldname(insn, 7, 3); \
1171
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1172
0
    tmp = 0; \
1173
0
    tmp |= fieldname(insn, 5, 1) << 6; \
1174
0
    tmp |= fieldname(insn, 6, 1) << 2; \
1175
0
    tmp |= fieldname(insn, 10, 3) << 3; \
1176
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 7) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1177
0
    return S; \
1178
0
  case 7: \
1179
0
    tmp = fieldname(insn, 7, 5); \
1180
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1181
0
    tmp = 0; \
1182
0
    tmp |= fieldname(insn, 2, 5) << 0; \
1183
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1184
0
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 6) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1185
0
    return S; \
1186
0
  case 8: \
1187
0
    tmp = fieldname(insn, 7, 5); \
1188
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1189
0
    tmp = 0; \
1190
0
    tmp |= fieldname(insn, 2, 2) << 6; \
1191
0
    tmp |= fieldname(insn, 4, 3) << 2; \
1192
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1193
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 8) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1194
0
    return S; \
1195
0
  case 9: \
1196
0
    tmp = fieldname(insn, 2, 3); \
1197
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1198
0
    tmp = fieldname(insn, 7, 3); \
1199
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1200
0
    tmp = 0; \
1201
0
    tmp |= fieldname(insn, 5, 2) << 6; \
1202
0
    tmp |= fieldname(insn, 10, 3) << 3; \
1203
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 8) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1204
0
    return S; \
1205
0
  case 10: \
1206
0
    tmp = 0; \
1207
0
    tmp |= fieldname(insn, 2, 1) << 5; \
1208
0
    tmp |= fieldname(insn, 3, 2) << 7; \
1209
0
    tmp |= fieldname(insn, 5, 1) << 6; \
1210
0
    tmp |= fieldname(insn, 6, 1) << 4; \
1211
0
    tmp |= fieldname(insn, 12, 1) << 9; \
1212
0
    if (decodeSImmNonZeroOperand(MI, tmp, Address, Decoder, 10) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1213
0
    return S; \
1214
0
  case 11: \
1215
0
    tmp = fieldname(insn, 7, 5); \
1216
0
    if (DecodeGPRNoX0X2RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1217
0
    tmp = 0; \
1218
0
    tmp |= fieldname(insn, 2, 5) << 0; \
1219
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1220
0
    if (decodeCLUIImmOperand(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1221
0
    return S; \
1222
0
  case 12: \
1223
0
    tmp = fieldname(insn, 7, 5); \
1224
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1225
0
    tmp = 0; \
1226
0
    tmp |= fieldname(insn, 2, 3) << 6; \
1227
0
    tmp |= fieldname(insn, 5, 2) << 3; \
1228
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1229
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 9) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1230
0
    return S; \
1231
0
  case 13: \
1232
0
    tmp = fieldname(insn, 7, 3); \
1233
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1234
0
    tmp = fieldname(insn, 7, 3); \
1235
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1236
0
    tmp = 0; \
1237
0
    tmp |= fieldname(insn, 2, 5) << 0; \
1238
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1239
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 6) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1240
0
    return S; \
1241
0
  case 14: \
1242
0
    tmp = fieldname(insn, 7, 3); \
1243
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1244
0
    tmp = fieldname(insn, 7, 3); \
1245
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1246
0
    tmp = 0; \
1247
0
    tmp |= fieldname(insn, 2, 5) << 0; \
1248
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1249
0
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 6) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1250
0
    return S; \
1251
0
  case 15: \
1252
0
    tmp = fieldname(insn, 7, 3); \
1253
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1254
0
    tmp = fieldname(insn, 7, 3); \
1255
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1256
0
    tmp = fieldname(insn, 2, 3); \
1257
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1258
0
    return S; \
1259
0
  case 16: \
1260
0
    tmp = fieldname(insn, 7, 5); \
1261
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1262
0
    return S; \
1263
0
  case 17: \
1264
0
    tmp = fieldname(insn, 7, 5); \
1265
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1266
0
    tmp = fieldname(insn, 2, 5); \
1267
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1268
0
    return S; \
1269
0
  case 18: \
1270
0
    tmp = fieldname(insn, 7, 5); \
1271
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1272
0
    tmp = fieldname(insn, 7, 5); \
1273
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1274
0
    tmp = fieldname(insn, 2, 5); \
1275
0
    if (DecodeGPRNoX0RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1276
0
    return S; \
1277
0
  case 19: \
1278
0
    tmp = 0; \
1279
0
    tmp |= fieldname(insn, 2, 1) << 4; \
1280
0
    tmp |= fieldname(insn, 3, 3) << 0; \
1281
0
    tmp |= fieldname(insn, 6, 1) << 6; \
1282
0
    tmp |= fieldname(insn, 7, 1) << 5; \
1283
0
    tmp |= fieldname(insn, 8, 1) << 9; \
1284
0
    tmp |= fieldname(insn, 9, 2) << 7; \
1285
0
    tmp |= fieldname(insn, 11, 1) << 3; \
1286
0
    tmp |= fieldname(insn, 12, 1) << 10; \
1287
0
    if (decodeSImmOperandAndLsl1(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1288
0
    return S; \
1289
0
  case 20: \
1290
0
    tmp = fieldname(insn, 2, 5); \
1291
0
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1292
0
    tmp = 0; \
1293
0
    tmp |= fieldname(insn, 7, 3) << 6; \
1294
0
    tmp |= fieldname(insn, 10, 3) << 3; \
1295
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 9) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1296
0
    return S; \
1297
0
  case 21: \
1298
0
    tmp = fieldname(insn, 7, 3); \
1299
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1300
0
    tmp = 0; \
1301
0
    tmp |= fieldname(insn, 2, 1) << 4; \
1302
0
    tmp |= fieldname(insn, 3, 2) << 0; \
1303
0
    tmp |= fieldname(insn, 5, 2) << 5; \
1304
0
    tmp |= fieldname(insn, 10, 2) << 2; \
1305
0
    tmp |= fieldname(insn, 12, 1) << 7; \
1306
0
    if (decodeSImmOperandAndLsl1(MI, tmp, Address, Decoder, 9) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1307
0
    return S; \
1308
0
  case 22: \
1309
0
    tmp = fieldname(insn, 2, 5); \
1310
0
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1311
0
    tmp = 0; \
1312
0
    tmp |= fieldname(insn, 7, 2) << 6; \
1313
0
    tmp |= fieldname(insn, 9, 4) << 2; \
1314
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 8) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1315
0
    return S; \
1316
0
  case 23: \
1317
0
    tmp = fieldname(insn, 2, 5); \
1318
0
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1319
0
    tmp = 0; \
1320
0
    tmp |= fieldname(insn, 7, 3) << 6; \
1321
0
    tmp |= fieldname(insn, 10, 3) << 3; \
1322
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 9) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1323
0
    return S; \
1324
5.93k
  case 24: \
1325
5.93k
    tmp = fieldname(insn, 7, 5); \
1326
5.93k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1327
5.93k
    tmp = fieldname(insn, 15, 5); \
1328
5.93k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1329
5.93k
    tmp = fieldname(insn, 20, 12); \
1330
5.93k
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1331
5.93k
    return S; \
1332
5.93k
  case 25: \
1333
216
    tmp = fieldname(insn, 7, 5); \
1334
216
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1335
216
    tmp = fieldname(insn, 15, 5); \
1336
216
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1337
216
    tmp = fieldname(insn, 20, 12); \
1338
216
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1339
216
    return S; \
1340
216
  case 26: \
1341
146
    tmp = fieldname(insn, 7, 5); \
1342
146
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1343
146
    tmp = fieldname(insn, 15, 5); \
1344
146
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1345
146
    tmp = fieldname(insn, 20, 12); \
1346
146
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1347
146
    return S; \
1348
2.13k
  case 27: \
1349
2.13k
    tmp = fieldname(insn, 24, 4); \
1350
2.13k
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 4) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1351
2.13k
    tmp = fieldname(insn, 20, 4); \
1352
2.13k
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 4) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1353
2.13k
    return S; \
1354
2.13k
  case 28: \
1355
118
    tmp = fieldname(insn, 7, 5); \
1356
118
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1357
118
    tmp = fieldname(insn, 15, 5); \
1358
118
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1359
118
    tmp = fieldname(insn, 20, 6); \
1360
118
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 6) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1361
118
    return S; \
1362
742
  case 29: \
1363
742
    tmp = fieldname(insn, 7, 5); \
1364
742
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1365
742
    tmp = fieldname(insn, 12, 20); \
1366
742
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 20) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1367
742
    return S; \
1368
742
  case 30: \
1369
245
    tmp = fieldname(insn, 7, 5); \
1370
245
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1371
245
    tmp = fieldname(insn, 15, 5); \
1372
245
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1373
245
    tmp = fieldname(insn, 20, 5); \
1374
245
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 5) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1375
245
    return S; \
1376
1.48k
  case 31: \
1377
1.48k
    tmp = fieldname(insn, 20, 5); \
1378
1.48k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1379
1.48k
    tmp = fieldname(insn, 15, 5); \
1380
1.48k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1381
1.48k
    tmp = 0; \
1382
1.48k
    tmp |= fieldname(insn, 7, 5) << 0; \
1383
1.48k
    tmp |= fieldname(insn, 25, 7) << 5; \
1384
1.48k
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1385
1.48k
    return S; \
1386
1.48k
  case 32: \
1387
570
    tmp = fieldname(insn, 20, 5); \
1388
570
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1389
570
    tmp = fieldname(insn, 15, 5); \
1390
570
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1391
570
    tmp = 0; \
1392
570
    tmp |= fieldname(insn, 7, 5) << 0; \
1393
570
    tmp |= fieldname(insn, 25, 7) << 5; \
1394
570
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1395
570
    return S; \
1396
570
  case 33: \
1397
58
    tmp = fieldname(insn, 20, 5); \
1398
58
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1399
58
    tmp = fieldname(insn, 15, 5); \
1400
58
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1401
58
    tmp = 0; \
1402
58
    tmp |= fieldname(insn, 7, 5) << 0; \
1403
58
    tmp |= fieldname(insn, 25, 7) << 5; \
1404
58
    if (decodeSImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1405
58
    return S; \
1406
6.53k
  case 34: \
1407
6.53k
    tmp = fieldname(insn, 7, 5); \
1408
6.53k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1409
6.53k
    tmp = fieldname(insn, 15, 5); \
1410
6.53k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1411
6.53k
    tmp = fieldname(insn, 20, 5); \
1412
6.53k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1413
6.53k
    return S; \
1414
6.53k
  case 35: \
1415
393
    tmp = fieldname(insn, 7, 5); \
1416
393
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1417
393
    tmp = fieldname(insn, 15, 5); \
1418
393
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1419
393
    return S; \
1420
2.26k
  case 36: \
1421
2.26k
    tmp = fieldname(insn, 7, 5); \
1422
2.26k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1423
2.26k
    tmp = fieldname(insn, 15, 5); \
1424
2.26k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1425
2.26k
    tmp = fieldname(insn, 20, 5); \
1426
2.26k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1427
2.26k
    tmp = fieldname(insn, 27, 5); \
1428
2.26k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1429
2.26k
    tmp = fieldname(insn, 12, 3); \
1430
2.26k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1431
2.26k
    return S; \
1432
2.26k
  case 37: \
1433
2.14k
    tmp = fieldname(insn, 7, 5); \
1434
2.14k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1435
2.14k
    tmp = fieldname(insn, 15, 5); \
1436
2.14k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1437
2.14k
    tmp = fieldname(insn, 20, 5); \
1438
2.14k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1439
2.14k
    tmp = fieldname(insn, 27, 5); \
1440
2.14k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1441
2.14k
    tmp = fieldname(insn, 12, 3); \
1442
2.14k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1443
2.14k
    return S; \
1444
3.74k
  case 38: \
1445
3.74k
    tmp = fieldname(insn, 7, 5); \
1446
3.74k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1447
3.74k
    tmp = fieldname(insn, 15, 5); \
1448
3.74k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1449
3.74k
    tmp = fieldname(insn, 20, 5); \
1450
3.74k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1451
3.74k
    tmp = fieldname(insn, 12, 3); \
1452
3.74k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1453
3.74k
    return S; \
1454
3.74k
  case 39: \
1455
1.24k
    tmp = fieldname(insn, 7, 5); \
1456
1.24k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1457
1.24k
    tmp = fieldname(insn, 15, 5); \
1458
1.24k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1459
1.24k
    tmp = fieldname(insn, 20, 5); \
1460
1.24k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1461
1.24k
    tmp = fieldname(insn, 12, 3); \
1462
1.24k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1463
1.24k
    return S; \
1464
3.47k
  case 40: \
1465
3.47k
    tmp = fieldname(insn, 7, 5); \
1466
3.47k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1467
3.47k
    tmp = fieldname(insn, 15, 5); \
1468
3.47k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1469
3.47k
    tmp = fieldname(insn, 20, 5); \
1470
3.47k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1471
3.47k
    return S; \
1472
3.47k
  case 41: \
1473
2.94k
    tmp = fieldname(insn, 7, 5); \
1474
2.94k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1475
2.94k
    tmp = fieldname(insn, 15, 5); \
1476
2.94k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1477
2.94k
    tmp = fieldname(insn, 20, 5); \
1478
2.94k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1479
2.94k
    return S; \
1480
2.94k
  case 42: \
1481
810
    tmp = fieldname(insn, 7, 5); \
1482
810
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1483
810
    tmp = fieldname(insn, 15, 5); \
1484
810
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1485
810
    tmp = fieldname(insn, 12, 3); \
1486
810
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1487
810
    return S; \
1488
810
  case 43: \
1489
79
    tmp = fieldname(insn, 7, 5); \
1490
79
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1491
79
    tmp = fieldname(insn, 15, 5); \
1492
79
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1493
79
    return S; \
1494
926
  case 44: \
1495
926
    tmp = fieldname(insn, 7, 5); \
1496
926
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1497
926
    tmp = fieldname(insn, 15, 5); \
1498
926
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1499
926
    tmp = fieldname(insn, 12, 3); \
1500
926
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1501
926
    return S; \
1502
926
  case 45: \
1503
340
    tmp = fieldname(insn, 7, 5); \
1504
340
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1505
340
    tmp = fieldname(insn, 15, 5); \
1506
340
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1507
340
    tmp = fieldname(insn, 12, 3); \
1508
340
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1509
340
    return S; \
1510
340
  case 46: \
1511
323
    tmp = fieldname(insn, 7, 5); \
1512
323
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1513
323
    tmp = fieldname(insn, 15, 5); \
1514
323
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1515
323
    tmp = fieldname(insn, 20, 5); \
1516
323
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1517
323
    return S; \
1518
323
  case 47: \
1519
84
    tmp = fieldname(insn, 7, 5); \
1520
84
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1521
84
    tmp = fieldname(insn, 15, 5); \
1522
84
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1523
84
    tmp = fieldname(insn, 20, 5); \
1524
84
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1525
84
    return S; \
1526
2.83k
  case 48: \
1527
2.83k
    tmp = fieldname(insn, 7, 5); \
1528
2.83k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1529
2.83k
    tmp = fieldname(insn, 15, 5); \
1530
2.83k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1531
2.83k
    tmp = fieldname(insn, 12, 3); \
1532
2.83k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1533
2.83k
    return S; \
1534
3.47k
  case 49: \
1535
3.47k
    tmp = fieldname(insn, 7, 5); \
1536
3.47k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1537
3.47k
    tmp = fieldname(insn, 15, 5); \
1538
3.47k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1539
3.47k
    tmp = fieldname(insn, 12, 3); \
1540
3.47k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1541
3.47k
    return S; \
1542
3.47k
  case 50: \
1543
2.82k
    tmp = fieldname(insn, 7, 5); \
1544
2.82k
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1545
2.82k
    tmp = fieldname(insn, 15, 5); \
1546
2.82k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1547
2.82k
    tmp = fieldname(insn, 12, 3); \
1548
2.82k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1549
2.82k
    return S; \
1550
2.82k
  case 51: \
1551
136
    tmp = fieldname(insn, 7, 5); \
1552
136
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1553
136
    tmp = fieldname(insn, 15, 5); \
1554
136
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1555
136
    return S; \
1556
2.48k
  case 52: \
1557
2.48k
    tmp = fieldname(insn, 7, 5); \
1558
2.48k
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1559
2.48k
    tmp = fieldname(insn, 15, 5); \
1560
2.48k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1561
2.48k
    tmp = fieldname(insn, 12, 3); \
1562
2.48k
    if (decodeFRMArg(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1563
2.48k
    return S; \
1564
2.48k
  case 53: \
1565
42
    tmp = fieldname(insn, 7, 5); \
1566
42
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1567
42
    tmp = fieldname(insn, 15, 5); \
1568
42
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1569
42
    return S; \
1570
114
  case 54: \
1571
114
    tmp = fieldname(insn, 7, 5); \
1572
114
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1573
114
    tmp = fieldname(insn, 15, 5); \
1574
114
    if (DecodeFPR64RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1575
114
    return S; \
1576
114
  case 55: \
1577
40
    tmp = fieldname(insn, 7, 5); \
1578
40
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1579
40
    tmp = fieldname(insn, 15, 5); \
1580
40
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1581
40
    return S; \
1582
3.67k
  case 56: \
1583
3.67k
    tmp = fieldname(insn, 15, 5); \
1584
3.67k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1585
3.67k
    tmp = fieldname(insn, 20, 5); \
1586
3.67k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1587
3.67k
    tmp = 0; \
1588
3.67k
    tmp |= fieldname(insn, 7, 1) << 10; \
1589
3.67k
    tmp |= fieldname(insn, 8, 4) << 0; \
1590
3.67k
    tmp |= fieldname(insn, 25, 6) << 4; \
1591
3.67k
    tmp |= fieldname(insn, 31, 1) << 11; \
1592
3.67k
    if (decodeSImmOperandAndLsl1(MI, tmp, Address, Decoder, 13) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1593
3.67k
    return S; \
1594
3.67k
  case 57: \
1595
1.36k
    tmp = fieldname(insn, 7, 5); \
1596
1.36k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1597
1.36k
    tmp = 0; \
1598
1.36k
    tmp |= fieldname(insn, 12, 8) << 11; \
1599
1.36k
    tmp |= fieldname(insn, 20, 1) << 10; \
1600
1.36k
    tmp |= fieldname(insn, 21, 10) << 0; \
1601
1.36k
    tmp |= fieldname(insn, 31, 1) << 19; \
1602
1.36k
    if (decodeSImmOperandAndLsl1(MI, tmp, Address, Decoder, 21) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1603
1.36k
    return S; \
1604
1.36k
  case 58: \
1605
581
    tmp = fieldname(insn, 15, 5); \
1606
581
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1607
581
    tmp = fieldname(insn, 20, 5); \
1608
581
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1609
581
    return S; \
1610
51.1k
  case 59: \
1611
51.1k
    tmp = fieldname(insn, 7, 5); \
1612
51.1k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1613
51.1k
    tmp = fieldname(insn, 20, 12); \
1614
51.1k
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1615
51.1k
    tmp = fieldname(insn, 15, 5); \
1616
51.1k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1617
51.1k
    return S; \
1618
51.1k
  case 60: \
1619
35.9k
    tmp = fieldname(insn, 7, 5); \
1620
35.9k
    if (DecodeGPRRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1621
35.9k
    tmp = fieldname(insn, 20, 12); \
1622
35.9k
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 12) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1623
35.9k
    tmp = fieldname(insn, 15, 5); \
1624
35.9k
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 5) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1625
35.9k
    return S; \
1626
35.9k
  case 61: \
1627
0
    tmp = fieldname(insn, 2, 3); \
1628
0
    if (DecodeFPR32CRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1629
0
    tmp = fieldname(insn, 7, 3); \
1630
0
    if (DecodeGPRCRegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1631
0
    tmp = 0; \
1632
0
    tmp |= fieldname(insn, 5, 1) << 6; \
1633
0
    tmp |= fieldname(insn, 6, 1) << 2; \
1634
0
    tmp |= fieldname(insn, 10, 3) << 3; \
1635
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 7) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1636
0
    return S; \
1637
0
  case 62: \
1638
0
    tmp = fieldname(insn, 7, 5); \
1639
0
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1640
0
    tmp = 0; \
1641
0
    tmp |= fieldname(insn, 2, 2) << 6; \
1642
0
    tmp |= fieldname(insn, 4, 3) << 2; \
1643
0
    tmp |= fieldname(insn, 12, 1) << 5; \
1644
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 8) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1645
0
    return S; \
1646
0
  case 63: \
1647
0
    tmp = fieldname(insn, 2, 5); \
1648
0
    if (DecodeFPR32RegisterClass(MI, tmp, Address, Decoder) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1649
0
    tmp = 0; \
1650
0
    tmp |= fieldname(insn, 7, 2) << 6; \
1651
0
    tmp |= fieldname(insn, 9, 4) << 2; \
1652
0
    if (decodeUImmOperand(MI, tmp, Address, Decoder, 8) == MCDisassembler_Fail) return MCDisassembler_Fail; \
1653
0
    return S; \
1654
141k
  } \
1655
141k
}
1656
1657
#define DecodeInstruction(fname, fieldname, decoder, InsnType) \
1658
static DecodeStatus fname(const uint8_t DecodeTable[], MCInst *MI,\
1659
                          InsnType insn, uint64_t Address,\
1660
144k
                          const void *DisAsm, int feature) {\
1661
144k
  uint64_t Bits = getFeatureBits(feature);\
1662
144k
\
1663
144k
  const uint8_t *Ptr = DecodeTable;\
1664
144k
  uint32_t CurFieldValue = 0;\
1665
144k
  DecodeStatus S = MCDisassembler_Success;\
1666
4.07M
  while (true) {\
1667
4.07M
    switch (*Ptr) {\
1668
0
    default:\
1669
0
      return MCDisassembler_Fail;\
1670
314k
    case MCD_OPC_ExtractField: {\
1671
314k
      unsigned Start = *++Ptr;\
1672
314k
      unsigned Len = *++Ptr;\
1673
314k
      ++Ptr;\
1674
314k
      CurFieldValue = fieldname(insn, Start, Len);\
1675
314k
      break;\
1676
0
    }\
1677
3.55M
    case MCD_OPC_FilterValue: {\
1678
3.55M
      unsigned Len;\
1679
3.55M
      InsnType Val = decodeULEB128(++Ptr, &Len);\
1680
3.55M
      Ptr += Len;\
1681
3.55M
      unsigned NumToSkip = *Ptr++;\
1682
3.55M
      NumToSkip |= (*Ptr++) << 8;\
1683
3.55M
      NumToSkip |= (*Ptr++) << 16;\
1684
3.55M
\
1685
3.55M
      if (Val != CurFieldValue)\
1686
3.55M
        Ptr += NumToSkip;\
1687
3.55M
      break;\
1688
0
    }\
1689
18.4k
    case MCD_OPC_CheckField: {\
1690
18.4k
      unsigned Start = *++Ptr;\
1691
18.4k
      unsigned Len = *++Ptr;\
1692
18.4k
      InsnType FieldValue = fieldname(insn, Start, Len);\
1693
18.4k
      uint32_t ExpectedValue = decodeULEB128(++Ptr, &Len);\
1694
18.4k
      Ptr += Len;\
1695
18.4k
      unsigned NumToSkip = *Ptr++;\
1696
18.4k
      NumToSkip |= (*Ptr++) << 8;\
1697
18.4k
      NumToSkip |= (*Ptr++) << 16;\
1698
18.4k
\
1699
18.4k
      if (ExpectedValue != FieldValue)\
1700
18.4k
        Ptr += NumToSkip;\
1701
18.4k
      break;\
1702
0
    }\
1703
40.9k
    case MCD_OPC_CheckPredicate: {\
1704
40.9k
      unsigned Len;\
1705
40.9k
      unsigned PIdx = decodeULEB128(++Ptr, &Len);\
1706
40.9k
      Ptr += Len;\
1707
40.9k
      unsigned NumToSkip = *Ptr++;\
1708
40.9k
      NumToSkip |= (*Ptr++) << 8;\
1709
40.9k
      NumToSkip |= (*Ptr++) << 16;\
1710
40.9k
      bool Pred;\
1711
40.9k
      if (!(Pred = checkDecoderPredicate(PIdx, Bits)))\
1712
40.9k
        Ptr += NumToSkip;\
1713
40.9k
      (void)Pred;\
1714
40.9k
      break;\
1715
0
    }\
1716
141k
    case MCD_OPC_Decode: {\
1717
141k
      unsigned Len;\
1718
141k
      unsigned Opc = decodeULEB128(++Ptr, &Len);\
1719
141k
      Ptr += Len;\
1720
141k
      unsigned DecodeIdx = decodeULEB128(Ptr, &Len);\
1721
141k
      Ptr += Len;\
1722
141k
\
1723
141k
      MCInst_clear(MI);\
1724
141k
      MCInst_setOpcode(MI, Opc);\
1725
141k
      bool DecodeComplete = false;\
1726
141k
      S = decoder(S, DecodeIdx, insn, MI, Address, DisAsm, &DecodeComplete);\
1727
141k
      CS_ASSERT(DecodeComplete);\
1728
141k
\
1729
141k
      return S;\
1730
0
    }\
1731
0
    case MCD_OPC_TryDecode: {\
1732
0
      unsigned Len;\
1733
0
      unsigned Opc = decodeULEB128(++Ptr, &Len);\
1734
0
      Ptr += Len;\
1735
0
      unsigned DecodeIdx = decodeULEB128(Ptr, &Len);\
1736
0
      Ptr += Len;\
1737
0
      unsigned NumToSkip = *Ptr++;\
1738
0
      NumToSkip |= (*Ptr++) << 8;\
1739
0
      NumToSkip |= (*Ptr++) << 16;\
1740
0
\
1741
0
      MCInst TmpMI = { 0 }; \
1742
0
      MCInst_Init(&TmpMI, CS_ARCH_RISCV); \
1743
0
      MCInst_setOpcode(&TmpMI, Opc);\
1744
0
      bool DecodeComplete = false;\
1745
0
      S = decoder(S, DecodeIdx, insn, &TmpMI, Address, DisAsm, &DecodeComplete);\
1746
0
\
1747
0
      if (DecodeComplete) {\
1748
0
        *MI = TmpMI;\
1749
0
        return S;\
1750
0
      } else {\
1751
0
        CS_ASSERT(S == MCDisassembler_Fail);\
1752
0
        Ptr += NumToSkip;\
1753
0
        S = MCDisassembler_Success;\
1754
0
      }\
1755
0
      break;\
1756
0
    }\
1757
0
    case MCD_OPC_SoftFail: {\
1758
0
      unsigned Len;\
1759
0
      InsnType PositiveMask = decodeULEB128(++Ptr, &Len);\
1760
0
      Ptr += Len;\
1761
0
      InsnType NegativeMask = decodeULEB128(Ptr, &Len);\
1762
0
      Ptr += Len;\
1763
0
      bool Fail = (insn & PositiveMask) || (~insn & NegativeMask);\
1764
0
      if (Fail)\
1765
0
        S = MCDisassembler_SoftFail;\
1766
0
      break;\
1767
0
    }\
1768
2.38k
    case MCD_OPC_Fail: {\
1769
2.38k
      return MCDisassembler_Fail;\
1770
0
    }\
1771
4.07M
    }\
1772
4.07M
  }\
1773
144k
  CS_ASSERT(0 && "bogosity detected in disassembler state machine!");\
1774
0
}
1775
1776
// For RISCV instruction is 32 bits.
1777
FieldFromInstruction(fieldFromInstruction, uint32_t)
1778
DecodeToMCInst(decodeToMCInst, fieldFromInstruction, uint32_t)
1779
DecodeInstruction(decodeInstruction, fieldFromInstruction, decodeToMCInst, uint32_t)