OpenCores
URL https://opencores.org/ocsvn/open8_urisc/open8_urisc/trunk

Subversion Repositories open8_urisc

[/] [open8_urisc/] [trunk/] [gnu/] [binutils/] [opcodes/] [iq2000-opc.c] - Blame information for rev 279

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 18 khays
/* Instruction opcode table for iq2000.
2
 
3
THIS FILE IS MACHINE GENERATED WITH CGEN.
4
 
5
Copyright 1996-2010 Free Software Foundation, Inc.
6
 
7
This file is part of the GNU Binutils and/or GDB, the GNU debugger.
8
 
9
   This file is free software; you can redistribute it and/or modify
10
   it under the terms of the GNU General Public License as published by
11
   the Free Software Foundation; either version 3, or (at your option)
12
   any later version.
13
 
14
   It is distributed in the hope that it will be useful, but WITHOUT
15
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
16
   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
17
   License for more details.
18
 
19
   You should have received a copy of the GNU General Public License along
20
   with this program; if not, write to the Free Software Foundation, Inc.,
21
   51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
22
 
23
*/
24
 
25
#include "sysdep.h"
26
#include "ansidecl.h"
27
#include "bfd.h"
28
#include "symcat.h"
29
#include "iq2000-desc.h"
30
#include "iq2000-opc.h"
31
#include "libiberty.h"
32
 
33
/* The hash functions are recorded here to help keep assembler code out of
34
   the disassembler and vice versa.  */
35
 
36
static int asm_hash_insn_p        (const CGEN_INSN *);
37
static unsigned int asm_hash_insn (const char *);
38
static int dis_hash_insn_p        (const CGEN_INSN *);
39
static unsigned int dis_hash_insn (const char *, CGEN_INSN_INT);
40
 
41
/* Instruction formats.  */
42
 
43
#define F(f) & iq2000_cgen_ifld_table[IQ2000_##f]
44
static const CGEN_IFMT ifmt_empty ATTRIBUTE_UNUSED = {
45
  0, 0, 0x0, { { 0 } }
46
};
47
 
48
static const CGEN_IFMT ifmt_add2 ATTRIBUTE_UNUSED = {
49
  32, 32, 0xfc0007ff, { { F (F_OPCODE) }, { F (F_RT) }, { F (F_RD_RS) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
50
};
51
 
52
static const CGEN_IFMT ifmt_add ATTRIBUTE_UNUSED = {
53
  32, 32, 0xfc0007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
54
};
55
 
56
static const CGEN_IFMT ifmt_addi2 ATTRIBUTE_UNUSED = {
57
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RT_RS) }, { F (F_IMM) }, { 0 } }
58
};
59
 
60
static const CGEN_IFMT ifmt_addi ATTRIBUTE_UNUSED = {
61
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
62
};
63
 
64
static const CGEN_IFMT ifmt_ram ATTRIBUTE_UNUSED = {
65
  32, 32, 0xfc000020, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_5) }, { F (F_MASKL) }, { 0 } }
66
};
67
 
68
static const CGEN_IFMT ifmt_sll ATTRIBUTE_UNUSED = {
69
  32, 32, 0xffe0003f, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
70
};
71
 
72
static const CGEN_IFMT ifmt_sllv2 ATTRIBUTE_UNUSED = {
73
  32, 32, 0xfc0007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RD_RT) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
74
};
75
 
76
static const CGEN_IFMT ifmt_slmv2 ATTRIBUTE_UNUSED = {
77
  32, 32, 0xfc00003f, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RD_RT) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
78
};
79
 
80
static const CGEN_IFMT ifmt_slmv ATTRIBUTE_UNUSED = {
81
  32, 32, 0xfc00003f, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
82
};
83
 
84
static const CGEN_IFMT ifmt_slti2 ATTRIBUTE_UNUSED = {
85
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RT_RS) }, { F (F_IMM) }, { 0 } }
86
};
87
 
88
static const CGEN_IFMT ifmt_slti ATTRIBUTE_UNUSED = {
89
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
90
};
91
 
92
static const CGEN_IFMT ifmt_sra2 ATTRIBUTE_UNUSED = {
93
  32, 32, 0xffe0003f, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RD_RT) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
94
};
95
 
96
static const CGEN_IFMT ifmt_bbi ATTRIBUTE_UNUSED = {
97
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_OFFSET) }, { 0 } }
98
};
99
 
100
static const CGEN_IFMT ifmt_bbv ATTRIBUTE_UNUSED = {
101
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_OFFSET) }, { 0 } }
102
};
103
 
104
static const CGEN_IFMT ifmt_bgez ATTRIBUTE_UNUSED = {
105
  32, 32, 0xfc1f0000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_OFFSET) }, { 0 } }
106
};
107
 
108
static const CGEN_IFMT ifmt_jalr ATTRIBUTE_UNUSED = {
109
  32, 32, 0xfc1f07ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
110
};
111
 
112
static const CGEN_IFMT ifmt_jr ATTRIBUTE_UNUSED = {
113
  32, 32, 0xfc1fffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
114
};
115
 
116
static const CGEN_IFMT ifmt_lb ATTRIBUTE_UNUSED = {
117
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
118
};
119
 
120
static const CGEN_IFMT ifmt_lui ATTRIBUTE_UNUSED = {
121
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
122
};
123
 
124
static const CGEN_IFMT ifmt_break ATTRIBUTE_UNUSED = {
125
  32, 32, 0xffffffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
126
};
127
 
128
static const CGEN_IFMT ifmt_syscall ATTRIBUTE_UNUSED = {
129
  32, 32, 0xfc00003f, { { F (F_OPCODE) }, { F (F_EXCODE) }, { F (F_FUNC) }, { 0 } }
130
};
131
 
132
static const CGEN_IFMT ifmt_andoui ATTRIBUTE_UNUSED = {
133
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
134
};
135
 
136
static const CGEN_IFMT ifmt_andoui2 ATTRIBUTE_UNUSED = {
137
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RT_RS) }, { F (F_IMM) }, { 0 } }
138
};
139
 
140
static const CGEN_IFMT ifmt_mrgb ATTRIBUTE_UNUSED = {
141
  32, 32, 0xfc00043f, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_10) }, { F (F_MASK) }, { F (F_FUNC) }, { 0 } }
142
};
143
 
144
static const CGEN_IFMT ifmt_mrgb2 ATTRIBUTE_UNUSED = {
145
  32, 32, 0xfc00043f, { { F (F_OPCODE) }, { F (F_RT) }, { F (F_RD_RS) }, { F (F_10) }, { F (F_MASK) }, { F (F_FUNC) }, { 0 } }
146
};
147
 
148
static const CGEN_IFMT ifmt_bc0f ATTRIBUTE_UNUSED = {
149
  32, 32, 0xffff0000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_OFFSET) }, { 0 } }
150
};
151
 
152
static const CGEN_IFMT ifmt_cfc0 ATTRIBUTE_UNUSED = {
153
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_10_11) }, { 0 } }
154
};
155
 
156
static const CGEN_IFMT ifmt_chkhdr ATTRIBUTE_UNUSED = {
157
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
158
};
159
 
160
static const CGEN_IFMT ifmt_lulck ATTRIBUTE_UNUSED = {
161
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
162
};
163
 
164
static const CGEN_IFMT ifmt_pkrlr1 ATTRIBUTE_UNUSED = {
165
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_COUNT) }, { F (F_INDEX) }, { 0 } }
166
};
167
 
168
static const CGEN_IFMT ifmt_rfe ATTRIBUTE_UNUSED = {
169
  32, 32, 0xffffffff, { { F (F_OPCODE) }, { F (F_25) }, { F (F_24_19) }, { F (F_FUNC) }, { 0 } }
170
};
171
 
172
static const CGEN_IFMT ifmt_j ATTRIBUTE_UNUSED = {
173
  32, 32, 0xffff0000, { { F (F_OPCODE) }, { F (F_RSRVD) }, { F (F_JTARG) }, { 0 } }
174
};
175
 
176
static const CGEN_IFMT ifmt_mrgbq10 ATTRIBUTE_UNUSED = {
177
  32, 32, 0xfc00003f, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_MASKQ10) }, { F (F_FUNC) }, { 0 } }
178
};
179
 
180
static const CGEN_IFMT ifmt_mrgbq102 ATTRIBUTE_UNUSED = {
181
  32, 32, 0xfc00003f, { { F (F_OPCODE) }, { F (F_RT) }, { F (F_RD_RS) }, { F (F_MASKQ10) }, { F (F_FUNC) }, { 0 } }
182
};
183
 
184
static const CGEN_IFMT ifmt_jq10 ATTRIBUTE_UNUSED = {
185
  32, 32, 0xffff0000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_JTARG) }, { 0 } }
186
};
187
 
188
static const CGEN_IFMT ifmt_jalq10 ATTRIBUTE_UNUSED = {
189
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_JTARG) }, { 0 } }
190
};
191
 
192
static const CGEN_IFMT ifmt_avail ATTRIBUTE_UNUSED = {
193
  32, 32, 0xffff07ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
194
};
195
 
196
static const CGEN_IFMT ifmt_rbi ATTRIBUTE_UNUSED = {
197
  32, 32, 0xfc000700, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
198
};
199
 
200
static const CGEN_IFMT ifmt_cam36 ATTRIBUTE_UNUSED = {
201
  32, 32, 0xffe007c0, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP_10) }, { F (F_CAM_Z) }, { F (F_CAM_Y) }, { 0 } }
202
};
203
 
204
static const CGEN_IFMT ifmt_cm32and ATTRIBUTE_UNUSED = {
205
  32, 32, 0xfc0007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
206
};
207
 
208
static const CGEN_IFMT ifmt_cm32rd ATTRIBUTE_UNUSED = {
209
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
210
};
211
 
212
static const CGEN_IFMT ifmt_cm128ria3 ATTRIBUTE_UNUSED = {
213
  32, 32, 0xfc0007fc, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_CM_4FUNC) }, { F (F_CM_3Z) }, { 0 } }
214
};
215
 
216
static const CGEN_IFMT ifmt_cm128ria4 ATTRIBUTE_UNUSED = {
217
  32, 32, 0xfc0007f8, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_CM_3FUNC) }, { F (F_CM_4Z) }, { 0 } }
218
};
219
 
220
static const CGEN_IFMT ifmt_ctc ATTRIBUTE_UNUSED = {
221
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
222
};
223
 
224
#undef F
225
 
226
#define A(a) (1 << CGEN_INSN_##a)
227
#define OPERAND(op) IQ2000_OPERAND_##op
228
#define MNEM CGEN_SYNTAX_MNEMONIC /* syntax value for mnemonic */
229
#define OP(field) CGEN_SYNTAX_MAKE_FIELD (OPERAND (field))
230
 
231
/* The instruction table.  */
232
 
233
static const CGEN_OPCODE iq2000_cgen_insn_opcode_table[MAX_INSNS] =
234
{
235
  /* Special null first entry.
236
     A `num' value of zero is thus invalid.
237
     Also, the special `invalid' insn resides here.  */
238
  { { 0, 0, 0, 0 }, {{0}}, 0, {0}},
239
/* add ${rd-rs},$rt */
240
  {
241
    { 0, 0, 0, 0 },
242
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
243
    & ifmt_add2, { 0x20 }
244
  },
245
/* add $rd,$rs,$rt */
246
  {
247
    { 0, 0, 0, 0 },
248
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
249
    & ifmt_add, { 0x20 }
250
  },
251
/* addi ${rt-rs},$lo16 */
252
  {
253
    { 0, 0, 0, 0 },
254
    { { MNEM, ' ', OP (RT_RS), ',', OP (LO16), 0 } },
255
    & ifmt_addi2, { 0x20000000 }
256
  },
257
/* addi $rt,$rs,$lo16 */
258
  {
259
    { 0, 0, 0, 0 },
260
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
261
    & ifmt_addi, { 0x20000000 }
262
  },
263
/* addiu ${rt-rs},$lo16 */
264
  {
265
    { 0, 0, 0, 0 },
266
    { { MNEM, ' ', OP (RT_RS), ',', OP (LO16), 0 } },
267
    & ifmt_addi2, { 0x24000000 }
268
  },
269
/* addiu $rt,$rs,$lo16 */
270
  {
271
    { 0, 0, 0, 0 },
272
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
273
    & ifmt_addi, { 0x24000000 }
274
  },
275
/* addu ${rd-rs},$rt */
276
  {
277
    { 0, 0, 0, 0 },
278
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
279
    & ifmt_add2, { 0x21 }
280
  },
281
/* addu $rd,$rs,$rt */
282
  {
283
    { 0, 0, 0, 0 },
284
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
285
    & ifmt_add, { 0x21 }
286
  },
287
/* ado16 ${rd-rs},$rt */
288
  {
289
    { 0, 0, 0, 0 },
290
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
291
    & ifmt_add2, { 0x29 }
292
  },
293
/* ado16 $rd,$rs,$rt */
294
  {
295
    { 0, 0, 0, 0 },
296
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
297
    & ifmt_add, { 0x29 }
298
  },
299
/* and ${rd-rs},$rt */
300
  {
301
    { 0, 0, 0, 0 },
302
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
303
    & ifmt_add2, { 0x24 }
304
  },
305
/* and $rd,$rs,$rt */
306
  {
307
    { 0, 0, 0, 0 },
308
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
309
    & ifmt_add, { 0x24 }
310
  },
311
/* andi ${rt-rs},$lo16 */
312
  {
313
    { 0, 0, 0, 0 },
314
    { { MNEM, ' ', OP (RT_RS), ',', OP (LO16), 0 } },
315
    & ifmt_addi2, { 0x30000000 }
316
  },
317
/* andi $rt,$rs,$lo16 */
318
  {
319
    { 0, 0, 0, 0 },
320
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
321
    & ifmt_addi, { 0x30000000 }
322
  },
323
/* andoi ${rt-rs},$lo16 */
324
  {
325
    { 0, 0, 0, 0 },
326
    { { MNEM, ' ', OP (RT_RS), ',', OP (LO16), 0 } },
327
    & ifmt_addi2, { 0xb0000000 }
328
  },
329
/* andoi $rt,$rs,$lo16 */
330
  {
331
    { 0, 0, 0, 0 },
332
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
333
    & ifmt_addi, { 0xb0000000 }
334
  },
335
/* nor ${rd-rs},$rt */
336
  {
337
    { 0, 0, 0, 0 },
338
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
339
    & ifmt_add2, { 0x27 }
340
  },
341
/* nor $rd,$rs,$rt */
342
  {
343
    { 0, 0, 0, 0 },
344
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
345
    & ifmt_add, { 0x27 }
346
  },
347
/* or ${rd-rs},$rt */
348
  {
349
    { 0, 0, 0, 0 },
350
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
351
    & ifmt_add2, { 0x25 }
352
  },
353
/* or $rd,$rs,$rt */
354
  {
355
    { 0, 0, 0, 0 },
356
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
357
    & ifmt_add, { 0x25 }
358
  },
359
/* ori ${rt-rs},$lo16 */
360
  {
361
    { 0, 0, 0, 0 },
362
    { { MNEM, ' ', OP (RT_RS), ',', OP (LO16), 0 } },
363
    & ifmt_addi2, { 0x34000000 }
364
  },
365
/* ori $rt,$rs,$lo16 */
366
  {
367
    { 0, 0, 0, 0 },
368
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
369
    & ifmt_addi, { 0x34000000 }
370
  },
371
/* ram $rd,$rt,$shamt,$maskl,$maskr */
372
  {
373
    { 0, 0, 0, 0 },
374
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (SHAMT), ',', OP (MASKL), ',', OP (MASKR), 0 } },
375
    & ifmt_ram, { 0x9c000000 }
376
  },
377
/* sll $rd,$rt,$shamt */
378
  {
379
    { 0, 0, 0, 0 },
380
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (SHAMT), 0 } },
381
    & ifmt_sll, { 0x0 }
382
  },
383
/* sllv ${rd-rt},$rs */
384
  {
385
    { 0, 0, 0, 0 },
386
    { { MNEM, ' ', OP (RD_RT), ',', OP (RS), 0 } },
387
    & ifmt_sllv2, { 0x4 }
388
  },
389
/* sllv $rd,$rt,$rs */
390
  {
391
    { 0, 0, 0, 0 },
392
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), 0 } },
393
    & ifmt_add, { 0x4 }
394
  },
395
/* slmv ${rd-rt},$rs,$shamt */
396
  {
397
    { 0, 0, 0, 0 },
398
    { { MNEM, ' ', OP (RD_RT), ',', OP (RS), ',', OP (SHAMT), 0 } },
399
    & ifmt_slmv2, { 0x1 }
400
  },
401
/* slmv $rd,$rt,$rs,$shamt */
402
  {
403
    { 0, 0, 0, 0 },
404
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), ',', OP (SHAMT), 0 } },
405
    & ifmt_slmv, { 0x1 }
406
  },
407
/* slt ${rd-rs},$rt */
408
  {
409
    { 0, 0, 0, 0 },
410
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
411
    & ifmt_add2, { 0x2a }
412
  },
413
/* slt $rd,$rs,$rt */
414
  {
415
    { 0, 0, 0, 0 },
416
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
417
    & ifmt_add, { 0x2a }
418
  },
419
/* slti ${rt-rs},$imm */
420
  {
421
    { 0, 0, 0, 0 },
422
    { { MNEM, ' ', OP (RT_RS), ',', OP (IMM), 0 } },
423
    & ifmt_slti2, { 0x28000000 }
424
  },
425
/* slti $rt,$rs,$imm */
426
  {
427
    { 0, 0, 0, 0 },
428
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (IMM), 0 } },
429
    & ifmt_slti, { 0x28000000 }
430
  },
431
/* sltiu ${rt-rs},$imm */
432
  {
433
    { 0, 0, 0, 0 },
434
    { { MNEM, ' ', OP (RT_RS), ',', OP (IMM), 0 } },
435
    & ifmt_slti2, { 0x2c000000 }
436
  },
437
/* sltiu $rt,$rs,$imm */
438
  {
439
    { 0, 0, 0, 0 },
440
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (IMM), 0 } },
441
    & ifmt_slti, { 0x2c000000 }
442
  },
443
/* sltu ${rd-rs},$rt */
444
  {
445
    { 0, 0, 0, 0 },
446
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
447
    & ifmt_add2, { 0x2b }
448
  },
449
/* sltu $rd,$rs,$rt */
450
  {
451
    { 0, 0, 0, 0 },
452
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
453
    & ifmt_add, { 0x2b }
454
  },
455
/* sra ${rd-rt},$shamt */
456
  {
457
    { 0, 0, 0, 0 },
458
    { { MNEM, ' ', OP (RD_RT), ',', OP (SHAMT), 0 } },
459
    & ifmt_sra2, { 0x3 }
460
  },
461
/* sra $rd,$rt,$shamt */
462
  {
463
    { 0, 0, 0, 0 },
464
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (SHAMT), 0 } },
465
    & ifmt_sll, { 0x3 }
466
  },
467
/* srav ${rd-rt},$rs */
468
  {
469
    { 0, 0, 0, 0 },
470
    { { MNEM, ' ', OP (RD_RT), ',', OP (RS), 0 } },
471
    & ifmt_sllv2, { 0x7 }
472
  },
473
/* srav $rd,$rt,$rs */
474
  {
475
    { 0, 0, 0, 0 },
476
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), 0 } },
477
    & ifmt_add, { 0x7 }
478
  },
479
/* srl $rd,$rt,$shamt */
480
  {
481
    { 0, 0, 0, 0 },
482
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (SHAMT), 0 } },
483
    & ifmt_sll, { 0x2 }
484
  },
485
/* srlv ${rd-rt},$rs */
486
  {
487
    { 0, 0, 0, 0 },
488
    { { MNEM, ' ', OP (RD_RT), ',', OP (RS), 0 } },
489
    & ifmt_sllv2, { 0x6 }
490
  },
491
/* srlv $rd,$rt,$rs */
492
  {
493
    { 0, 0, 0, 0 },
494
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), 0 } },
495
    & ifmt_add, { 0x6 }
496
  },
497
/* srmv ${rd-rt},$rs,$shamt */
498
  {
499
    { 0, 0, 0, 0 },
500
    { { MNEM, ' ', OP (RD_RT), ',', OP (RS), ',', OP (SHAMT), 0 } },
501
    & ifmt_slmv2, { 0x5 }
502
  },
503
/* srmv $rd,$rt,$rs,$shamt */
504
  {
505
    { 0, 0, 0, 0 },
506
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), ',', OP (SHAMT), 0 } },
507
    & ifmt_slmv, { 0x5 }
508
  },
509
/* sub ${rd-rs},$rt */
510
  {
511
    { 0, 0, 0, 0 },
512
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
513
    & ifmt_add2, { 0x22 }
514
  },
515
/* sub $rd,$rs,$rt */
516
  {
517
    { 0, 0, 0, 0 },
518
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
519
    & ifmt_add, { 0x22 }
520
  },
521
/* subu ${rd-rs},$rt */
522
  {
523
    { 0, 0, 0, 0 },
524
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
525
    & ifmt_add2, { 0x23 }
526
  },
527
/* subu $rd,$rs,$rt */
528
  {
529
    { 0, 0, 0, 0 },
530
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
531
    & ifmt_add, { 0x23 }
532
  },
533
/* xor ${rd-rs},$rt */
534
  {
535
    { 0, 0, 0, 0 },
536
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), 0 } },
537
    & ifmt_add2, { 0x26 }
538
  },
539
/* xor $rd,$rs,$rt */
540
  {
541
    { 0, 0, 0, 0 },
542
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
543
    & ifmt_add, { 0x26 }
544
  },
545
/* xori ${rt-rs},$lo16 */
546
  {
547
    { 0, 0, 0, 0 },
548
    { { MNEM, ' ', OP (RT_RS), ',', OP (LO16), 0 } },
549
    & ifmt_addi2, { 0x38000000 }
550
  },
551
/* xori $rt,$rs,$lo16 */
552
  {
553
    { 0, 0, 0, 0 },
554
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
555
    & ifmt_addi, { 0x38000000 }
556
  },
557
/* bbi $rs($bitnum),$offset */
558
  {
559
    { 0, 0, 0, 0 },
560
    { { MNEM, ' ', OP (RS), '(', OP (BITNUM), ')', ',', OP (OFFSET), 0 } },
561
    & ifmt_bbi, { 0x70000000 }
562
  },
563
/* bbin $rs($bitnum),$offset */
564
  {
565
    { 0, 0, 0, 0 },
566
    { { MNEM, ' ', OP (RS), '(', OP (BITNUM), ')', ',', OP (OFFSET), 0 } },
567
    & ifmt_bbi, { 0x78000000 }
568
  },
569
/* bbv $rs,$rt,$offset */
570
  {
571
    { 0, 0, 0, 0 },
572
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
573
    & ifmt_bbv, { 0x74000000 }
574
  },
575
/* bbvn $rs,$rt,$offset */
576
  {
577
    { 0, 0, 0, 0 },
578
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
579
    & ifmt_bbv, { 0x7c000000 }
580
  },
581
/* beq $rs,$rt,$offset */
582
  {
583
    { 0, 0, 0, 0 },
584
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
585
    & ifmt_bbv, { 0x10000000 }
586
  },
587
/* beql $rs,$rt,$offset */
588
  {
589
    { 0, 0, 0, 0 },
590
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
591
    & ifmt_bbv, { 0x50000000 }
592
  },
593
/* bgez $rs,$offset */
594
  {
595
    { 0, 0, 0, 0 },
596
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
597
    & ifmt_bgez, { 0x4010000 }
598
  },
599
/* bgezal $rs,$offset */
600
  {
601
    { 0, 0, 0, 0 },
602
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
603
    & ifmt_bgez, { 0x4110000 }
604
  },
605
/* bgezall $rs,$offset */
606
  {
607
    { 0, 0, 0, 0 },
608
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
609
    & ifmt_bgez, { 0x4130000 }
610
  },
611
/* bgezl $rs,$offset */
612
  {
613
    { 0, 0, 0, 0 },
614
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
615
    & ifmt_bgez, { 0x4030000 }
616
  },
617
/* bltz $rs,$offset */
618
  {
619
    { 0, 0, 0, 0 },
620
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
621
    & ifmt_bgez, { 0x4000000 }
622
  },
623
/* bltzl $rs,$offset */
624
  {
625
    { 0, 0, 0, 0 },
626
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
627
    & ifmt_bgez, { 0x4020000 }
628
  },
629
/* bltzal $rs,$offset */
630
  {
631
    { 0, 0, 0, 0 },
632
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
633
    & ifmt_bgez, { 0x4100000 }
634
  },
635
/* bltzall $rs,$offset */
636
  {
637
    { 0, 0, 0, 0 },
638
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
639
    & ifmt_bgez, { 0x4120000 }
640
  },
641
/* bmb0 $rs,$rt,$offset */
642
  {
643
    { 0, 0, 0, 0 },
644
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
645
    & ifmt_bbv, { 0x60000000 }
646
  },
647
/* bmb1 $rs,$rt,$offset */
648
  {
649
    { 0, 0, 0, 0 },
650
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
651
    & ifmt_bbv, { 0x64000000 }
652
  },
653
/* bmb2 $rs,$rt,$offset */
654
  {
655
    { 0, 0, 0, 0 },
656
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
657
    & ifmt_bbv, { 0x68000000 }
658
  },
659
/* bmb3 $rs,$rt,$offset */
660
  {
661
    { 0, 0, 0, 0 },
662
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
663
    & ifmt_bbv, { 0x6c000000 }
664
  },
665
/* bne $rs,$rt,$offset */
666
  {
667
    { 0, 0, 0, 0 },
668
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
669
    & ifmt_bbv, { 0x14000000 }
670
  },
671
/* bnel $rs,$rt,$offset */
672
  {
673
    { 0, 0, 0, 0 },
674
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
675
    & ifmt_bbv, { 0x54000000 }
676
  },
677
/* jalr $rd,$rs */
678
  {
679
    { 0, 0, 0, 0 },
680
    { { MNEM, ' ', OP (RD), ',', OP (RS), 0 } },
681
    & ifmt_jalr, { 0x9 }
682
  },
683
/* jr $rs */
684
  {
685
    { 0, 0, 0, 0 },
686
    { { MNEM, ' ', OP (RS), 0 } },
687
    & ifmt_jr, { 0x8 }
688
  },
689
/* lb $rt,$lo16($base) */
690
  {
691
    { 0, 0, 0, 0 },
692
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
693
    & ifmt_lb, { 0x80000000 }
694
  },
695
/* lbu $rt,$lo16($base) */
696
  {
697
    { 0, 0, 0, 0 },
698
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
699
    & ifmt_lb, { 0x90000000 }
700
  },
701
/* lh $rt,$lo16($base) */
702
  {
703
    { 0, 0, 0, 0 },
704
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
705
    & ifmt_lb, { 0x84000000 }
706
  },
707
/* lhu $rt,$lo16($base) */
708
  {
709
    { 0, 0, 0, 0 },
710
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
711
    & ifmt_lb, { 0x94000000 }
712
  },
713
/* lui $rt,$hi16 */
714
  {
715
    { 0, 0, 0, 0 },
716
    { { MNEM, ' ', OP (RT), ',', OP (HI16), 0 } },
717
    & ifmt_lui, { 0x3c000000 }
718
  },
719
/* lw $rt,$lo16($base) */
720
  {
721
    { 0, 0, 0, 0 },
722
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
723
    & ifmt_lb, { 0x8c000000 }
724
  },
725
/* sb $rt,$lo16($base) */
726
  {
727
    { 0, 0, 0, 0 },
728
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
729
    & ifmt_lb, { 0xa0000000 }
730
  },
731
/* sh $rt,$lo16($base) */
732
  {
733
    { 0, 0, 0, 0 },
734
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
735
    & ifmt_lb, { 0xa4000000 }
736
  },
737
/* sw $rt,$lo16($base) */
738
  {
739
    { 0, 0, 0, 0 },
740
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
741
    & ifmt_lb, { 0xac000000 }
742
  },
743
/* break */
744
  {
745
    { 0, 0, 0, 0 },
746
    { { MNEM, 0 } },
747
    & ifmt_break, { 0xd }
748
  },
749
/* syscall */
750
  {
751
    { 0, 0, 0, 0 },
752
    { { MNEM, 0 } },
753
    & ifmt_syscall, { 0xc }
754
  },
755
/* andoui $rt,$rs,$hi16 */
756
  {
757
    { 0, 0, 0, 0 },
758
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (HI16), 0 } },
759
    & ifmt_andoui, { 0xfc000000 }
760
  },
761
/* andoui ${rt-rs},$hi16 */
762
  {
763
    { 0, 0, 0, 0 },
764
    { { MNEM, ' ', OP (RT_RS), ',', OP (HI16), 0 } },
765
    & ifmt_andoui2, { 0xfc000000 }
766
  },
767
/* orui ${rt-rs},$hi16 */
768
  {
769
    { 0, 0, 0, 0 },
770
    { { MNEM, ' ', OP (RT_RS), ',', OP (HI16), 0 } },
771
    & ifmt_andoui2, { 0xbc000000 }
772
  },
773
/* orui $rt,$rs,$hi16 */
774
  {
775
    { 0, 0, 0, 0 },
776
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (HI16), 0 } },
777
    & ifmt_andoui, { 0xbc000000 }
778
  },
779
/* bgtz $rs,$offset */
780
  {
781
    { 0, 0, 0, 0 },
782
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
783
    & ifmt_bgez, { 0x1c000000 }
784
  },
785
/* bgtzl $rs,$offset */
786
  {
787
    { 0, 0, 0, 0 },
788
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
789
    & ifmt_bgez, { 0x5c000000 }
790
  },
791
/* blez $rs,$offset */
792
  {
793
    { 0, 0, 0, 0 },
794
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
795
    & ifmt_bgez, { 0x18000000 }
796
  },
797
/* blezl $rs,$offset */
798
  {
799
    { 0, 0, 0, 0 },
800
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
801
    & ifmt_bgez, { 0x58000000 }
802
  },
803
/* mrgb $rd,$rs,$rt,$mask */
804
  {
805
    { 0, 0, 0, 0 },
806
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (MASK), 0 } },
807
    & ifmt_mrgb, { 0x2d }
808
  },
809
/* mrgb ${rd-rs},$rt,$mask */
810
  {
811
    { 0, 0, 0, 0 },
812
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), ',', OP (MASK), 0 } },
813
    & ifmt_mrgb2, { 0x2d }
814
  },
815
/* bctxt $rs,$offset */
816
  {
817
    { 0, 0, 0, 0 },
818
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
819
    & ifmt_bgez, { 0x4060000 }
820
  },
821
/* bc0f $offset */
822
  {
823
    { 0, 0, 0, 0 },
824
    { { MNEM, ' ', OP (OFFSET), 0 } },
825
    & ifmt_bc0f, { 0x41000000 }
826
  },
827
/* bc0fl $offset */
828
  {
829
    { 0, 0, 0, 0 },
830
    { { MNEM, ' ', OP (OFFSET), 0 } },
831
    & ifmt_bc0f, { 0x41020000 }
832
  },
833
/* bc3f $offset */
834
  {
835
    { 0, 0, 0, 0 },
836
    { { MNEM, ' ', OP (OFFSET), 0 } },
837
    & ifmt_bc0f, { 0x4d000000 }
838
  },
839
/* bc3fl $offset */
840
  {
841
    { 0, 0, 0, 0 },
842
    { { MNEM, ' ', OP (OFFSET), 0 } },
843
    & ifmt_bc0f, { 0x4d020000 }
844
  },
845
/* bc0t $offset */
846
  {
847
    { 0, 0, 0, 0 },
848
    { { MNEM, ' ', OP (OFFSET), 0 } },
849
    & ifmt_bc0f, { 0x41010000 }
850
  },
851
/* bc0tl $offset */
852
  {
853
    { 0, 0, 0, 0 },
854
    { { MNEM, ' ', OP (OFFSET), 0 } },
855
    & ifmt_bc0f, { 0x41030000 }
856
  },
857
/* bc3t $offset */
858
  {
859
    { 0, 0, 0, 0 },
860
    { { MNEM, ' ', OP (OFFSET), 0 } },
861
    & ifmt_bc0f, { 0x4d010000 }
862
  },
863
/* bc3tl $offset */
864
  {
865
    { 0, 0, 0, 0 },
866
    { { MNEM, ' ', OP (OFFSET), 0 } },
867
    & ifmt_bc0f, { 0x4d030000 }
868
  },
869
/* cfc0 $rt,$rd */
870
  {
871
    { 0, 0, 0, 0 },
872
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
873
    & ifmt_cfc0, { 0x40400000 }
874
  },
875
/* cfc1 $rt,$rd */
876
  {
877
    { 0, 0, 0, 0 },
878
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
879
    & ifmt_cfc0, { 0x44400000 }
880
  },
881
/* cfc2 $rt,$rd */
882
  {
883
    { 0, 0, 0, 0 },
884
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
885
    & ifmt_cfc0, { 0x48400000 }
886
  },
887
/* cfc3 $rt,$rd */
888
  {
889
    { 0, 0, 0, 0 },
890
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
891
    & ifmt_cfc0, { 0x4c400000 }
892
  },
893
/* chkhdr $rd,$rt */
894
  {
895
    { 0, 0, 0, 0 },
896
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
897
    & ifmt_chkhdr, { 0x4d200000 }
898
  },
899
/* ctc0 $rt,$rd */
900
  {
901
    { 0, 0, 0, 0 },
902
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
903
    & ifmt_cfc0, { 0x40c00000 }
904
  },
905
/* ctc1 $rt,$rd */
906
  {
907
    { 0, 0, 0, 0 },
908
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
909
    & ifmt_cfc0, { 0x44c00000 }
910
  },
911
/* ctc2 $rt,$rd */
912
  {
913
    { 0, 0, 0, 0 },
914
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
915
    & ifmt_cfc0, { 0x48c00000 }
916
  },
917
/* ctc3 $rt,$rd */
918
  {
919
    { 0, 0, 0, 0 },
920
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
921
    & ifmt_cfc0, { 0x4cc00000 }
922
  },
923
/* jcr $rs */
924
  {
925
    { 0, 0, 0, 0 },
926
    { { MNEM, ' ', OP (RS), 0 } },
927
    & ifmt_jr, { 0xa }
928
  },
929
/* luc32 $rt,$rd */
930
  {
931
    { 0, 0, 0, 0 },
932
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
933
    & ifmt_chkhdr, { 0x48200003 }
934
  },
935
/* luc32l $rt,$rd */
936
  {
937
    { 0, 0, 0, 0 },
938
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
939
    & ifmt_chkhdr, { 0x48200007 }
940
  },
941
/* luc64 $rt,$rd */
942
  {
943
    { 0, 0, 0, 0 },
944
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
945
    & ifmt_chkhdr, { 0x4820000b }
946
  },
947
/* luc64l $rt,$rd */
948
  {
949
    { 0, 0, 0, 0 },
950
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
951
    & ifmt_chkhdr, { 0x4820000f }
952
  },
953
/* luk $rt,$rd */
954
  {
955
    { 0, 0, 0, 0 },
956
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
957
    & ifmt_chkhdr, { 0x48200008 }
958
  },
959
/* lulck $rt */
960
  {
961
    { 0, 0, 0, 0 },
962
    { { MNEM, ' ', OP (RT), 0 } },
963
    & ifmt_lulck, { 0x48200004 }
964
  },
965
/* lum32 $rt,$rd */
966
  {
967
    { 0, 0, 0, 0 },
968
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
969
    & ifmt_chkhdr, { 0x48200002 }
970
  },
971
/* lum32l $rt,$rd */
972
  {
973
    { 0, 0, 0, 0 },
974
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
975
    & ifmt_chkhdr, { 0x48200006 }
976
  },
977
/* lum64 $rt,$rd */
978
  {
979
    { 0, 0, 0, 0 },
980
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
981
    & ifmt_chkhdr, { 0x4820000a }
982
  },
983
/* lum64l $rt,$rd */
984
  {
985
    { 0, 0, 0, 0 },
986
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
987
    & ifmt_chkhdr, { 0x4820000e }
988
  },
989
/* lur $rt,$rd */
990
  {
991
    { 0, 0, 0, 0 },
992
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
993
    & ifmt_chkhdr, { 0x48200001 }
994
  },
995
/* lurl $rt,$rd */
996
  {
997
    { 0, 0, 0, 0 },
998
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
999
    & ifmt_chkhdr, { 0x48200005 }
1000
  },
1001
/* luulck $rt */
1002
  {
1003
    { 0, 0, 0, 0 },
1004
    { { MNEM, ' ', OP (RT), 0 } },
1005
    & ifmt_lulck, { 0x48200000 }
1006
  },
1007
/* mfc0 $rt,$rd */
1008
  {
1009
    { 0, 0, 0, 0 },
1010
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1011
    & ifmt_cfc0, { 0x40000000 }
1012
  },
1013
/* mfc1 $rt,$rd */
1014
  {
1015
    { 0, 0, 0, 0 },
1016
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1017
    & ifmt_cfc0, { 0x44000000 }
1018
  },
1019
/* mfc2 $rt,$rd */
1020
  {
1021
    { 0, 0, 0, 0 },
1022
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1023
    & ifmt_cfc0, { 0x48000000 }
1024
  },
1025
/* mfc3 $rt,$rd */
1026
  {
1027
    { 0, 0, 0, 0 },
1028
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1029
    & ifmt_cfc0, { 0x4c000000 }
1030
  },
1031
/* mtc0 $rt,$rd */
1032
  {
1033
    { 0, 0, 0, 0 },
1034
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1035
    & ifmt_cfc0, { 0x40800000 }
1036
  },
1037
/* mtc1 $rt,$rd */
1038
  {
1039
    { 0, 0, 0, 0 },
1040
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1041
    & ifmt_cfc0, { 0x44800000 }
1042
  },
1043
/* mtc2 $rt,$rd */
1044
  {
1045
    { 0, 0, 0, 0 },
1046
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1047
    & ifmt_cfc0, { 0x48800000 }
1048
  },
1049
/* mtc3 $rt,$rd */
1050
  {
1051
    { 0, 0, 0, 0 },
1052
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1053
    & ifmt_cfc0, { 0x4c800000 }
1054
  },
1055
/* pkrl $rd,$rt */
1056
  {
1057
    { 0, 0, 0, 0 },
1058
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1059
    & ifmt_chkhdr, { 0x4c200007 }
1060
  },
1061
/* pkrlr1 $rt,$_index,$count */
1062
  {
1063
    { 0, 0, 0, 0 },
1064
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1065
    & ifmt_pkrlr1, { 0x4fa00000 }
1066
  },
1067
/* pkrlr30 $rt,$_index,$count */
1068
  {
1069
    { 0, 0, 0, 0 },
1070
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1071
    & ifmt_pkrlr1, { 0x4fe00000 }
1072
  },
1073
/* rb $rd,$rt */
1074
  {
1075
    { 0, 0, 0, 0 },
1076
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1077
    & ifmt_chkhdr, { 0x4c200004 }
1078
  },
1079
/* rbr1 $rt,$_index,$count */
1080
  {
1081
    { 0, 0, 0, 0 },
1082
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1083
    & ifmt_pkrlr1, { 0x4f000000 }
1084
  },
1085
/* rbr30 $rt,$_index,$count */
1086
  {
1087
    { 0, 0, 0, 0 },
1088
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1089
    & ifmt_pkrlr1, { 0x4f400000 }
1090
  },
1091
/* rfe */
1092
  {
1093
    { 0, 0, 0, 0 },
1094
    { { MNEM, 0 } },
1095
    & ifmt_rfe, { 0x42000010 }
1096
  },
1097
/* rx $rd,$rt */
1098
  {
1099
    { 0, 0, 0, 0 },
1100
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1101
    & ifmt_chkhdr, { 0x4c200006 }
1102
  },
1103
/* rxr1 $rt,$_index,$count */
1104
  {
1105
    { 0, 0, 0, 0 },
1106
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1107
    & ifmt_pkrlr1, { 0x4f800000 }
1108
  },
1109
/* rxr30 $rt,$_index,$count */
1110
  {
1111
    { 0, 0, 0, 0 },
1112
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1113
    & ifmt_pkrlr1, { 0x4fc00000 }
1114
  },
1115
/* sleep */
1116
  {
1117
    { 0, 0, 0, 0 },
1118
    { { MNEM, 0 } },
1119
    & ifmt_syscall, { 0xe }
1120
  },
1121
/* srrd $rt */
1122
  {
1123
    { 0, 0, 0, 0 },
1124
    { { MNEM, ' ', OP (RT), 0 } },
1125
    & ifmt_lulck, { 0x48200010 }
1126
  },
1127
/* srrdl $rt */
1128
  {
1129
    { 0, 0, 0, 0 },
1130
    { { MNEM, ' ', OP (RT), 0 } },
1131
    & ifmt_lulck, { 0x48200014 }
1132
  },
1133
/* srulck $rt */
1134
  {
1135
    { 0, 0, 0, 0 },
1136
    { { MNEM, ' ', OP (RT), 0 } },
1137
    & ifmt_lulck, { 0x48200016 }
1138
  },
1139
/* srwr $rt,$rd */
1140
  {
1141
    { 0, 0, 0, 0 },
1142
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1143
    & ifmt_chkhdr, { 0x48200011 }
1144
  },
1145
/* srwru $rt,$rd */
1146
  {
1147
    { 0, 0, 0, 0 },
1148
    { { MNEM, ' ', OP (RT), ',', OP (RD), 0 } },
1149
    & ifmt_chkhdr, { 0x48200015 }
1150
  },
1151
/* trapqfl */
1152
  {
1153
    { 0, 0, 0, 0 },
1154
    { { MNEM, 0 } },
1155
    & ifmt_break, { 0x4c200008 }
1156
  },
1157
/* trapqne */
1158
  {
1159
    { 0, 0, 0, 0 },
1160
    { { MNEM, 0 } },
1161
    & ifmt_break, { 0x4c200009 }
1162
  },
1163
/* traprel $rt */
1164
  {
1165
    { 0, 0, 0, 0 },
1166
    { { MNEM, ' ', OP (RT), 0 } },
1167
    & ifmt_lulck, { 0x4c20000a }
1168
  },
1169
/* wb $rd,$rt */
1170
  {
1171
    { 0, 0, 0, 0 },
1172
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1173
    & ifmt_chkhdr, { 0x4c200000 }
1174
  },
1175
/* wbu $rd,$rt */
1176
  {
1177
    { 0, 0, 0, 0 },
1178
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1179
    & ifmt_chkhdr, { 0x4c200001 }
1180
  },
1181
/* wbr1 $rt,$_index,$count */
1182
  {
1183
    { 0, 0, 0, 0 },
1184
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1185
    & ifmt_pkrlr1, { 0x4e000000 }
1186
  },
1187
/* wbr1u $rt,$_index,$count */
1188
  {
1189
    { 0, 0, 0, 0 },
1190
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1191
    & ifmt_pkrlr1, { 0x4e200000 }
1192
  },
1193
/* wbr30 $rt,$_index,$count */
1194
  {
1195
    { 0, 0, 0, 0 },
1196
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1197
    & ifmt_pkrlr1, { 0x4e400000 }
1198
  },
1199
/* wbr30u $rt,$_index,$count */
1200
  {
1201
    { 0, 0, 0, 0 },
1202
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1203
    & ifmt_pkrlr1, { 0x4e600000 }
1204
  },
1205
/* wx $rd,$rt */
1206
  {
1207
    { 0, 0, 0, 0 },
1208
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1209
    & ifmt_chkhdr, { 0x4c200002 }
1210
  },
1211
/* wxu $rd,$rt */
1212
  {
1213
    { 0, 0, 0, 0 },
1214
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1215
    & ifmt_chkhdr, { 0x4c200003 }
1216
  },
1217
/* wxr1 $rt,$_index,$count */
1218
  {
1219
    { 0, 0, 0, 0 },
1220
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1221
    & ifmt_pkrlr1, { 0x4e800000 }
1222
  },
1223
/* wxr1u $rt,$_index,$count */
1224
  {
1225
    { 0, 0, 0, 0 },
1226
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1227
    & ifmt_pkrlr1, { 0x4ea00000 }
1228
  },
1229
/* wxr30 $rt,$_index,$count */
1230
  {
1231
    { 0, 0, 0, 0 },
1232
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1233
    & ifmt_pkrlr1, { 0x4ec00000 }
1234
  },
1235
/* wxr30u $rt,$_index,$count */
1236
  {
1237
    { 0, 0, 0, 0 },
1238
    { { MNEM, ' ', OP (RT), ',', OP (_INDEX), ',', OP (COUNT), 0 } },
1239
    & ifmt_pkrlr1, { 0x4ee00000 }
1240
  },
1241
/* ldw $rt,$lo16($base) */
1242
  {
1243
    { 0, 0, 0, 0 },
1244
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
1245
    & ifmt_lb, { 0xc0000000 }
1246
  },
1247
/* sdw $rt,$lo16($base) */
1248
  {
1249
    { 0, 0, 0, 0 },
1250
    { { MNEM, ' ', OP (RT), ',', OP (LO16), '(', OP (BASE), ')', 0 } },
1251
    & ifmt_lb, { 0xe0000000 }
1252
  },
1253
/* j $jmptarg */
1254
  {
1255
    { 0, 0, 0, 0 },
1256
    { { MNEM, ' ', OP (JMPTARG), 0 } },
1257
    & ifmt_j, { 0x8000000 }
1258
  },
1259
/* jal $jmptarg */
1260
  {
1261
    { 0, 0, 0, 0 },
1262
    { { MNEM, ' ', OP (JMPTARG), 0 } },
1263
    & ifmt_j, { 0xc000000 }
1264
  },
1265
/* bmb $rs,$rt,$offset */
1266
  {
1267
    { 0, 0, 0, 0 },
1268
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
1269
    & ifmt_bbv, { 0xb4000000 }
1270
  },
1271
/* andoui $rt,$rs,$hi16 */
1272
  {
1273
    { 0, 0, 0, 0 },
1274
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (HI16), 0 } },
1275
    & ifmt_andoui, { 0xbc000000 }
1276
  },
1277
/* andoui ${rt-rs},$hi16 */
1278
  {
1279
    { 0, 0, 0, 0 },
1280
    { { MNEM, ' ', OP (RT_RS), ',', OP (HI16), 0 } },
1281
    & ifmt_andoui2, { 0xbc000000 }
1282
  },
1283
/* orui $rt,$rs,$hi16 */
1284
  {
1285
    { 0, 0, 0, 0 },
1286
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (HI16), 0 } },
1287
    & ifmt_andoui, { 0x3c000000 }
1288
  },
1289
/* orui ${rt-rs},$hi16 */
1290
  {
1291
    { 0, 0, 0, 0 },
1292
    { { MNEM, ' ', OP (RT_RS), ',', OP (HI16), 0 } },
1293
    & ifmt_andoui2, { 0x3c000000 }
1294
  },
1295
/* mrgb $rd,$rs,$rt,$maskq10 */
1296
  {
1297
    { 0, 0, 0, 0 },
1298
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (MASKQ10), 0 } },
1299
    & ifmt_mrgbq10, { 0x2d }
1300
  },
1301
/* mrgb ${rd-rs},$rt,$maskq10 */
1302
  {
1303
    { 0, 0, 0, 0 },
1304
    { { MNEM, ' ', OP (RD_RS), ',', OP (RT), ',', OP (MASKQ10), 0 } },
1305
    & ifmt_mrgbq102, { 0x2d }
1306
  },
1307
/* j $jmptarg */
1308
  {
1309
    { 0, 0, 0, 0 },
1310
    { { MNEM, ' ', OP (JMPTARG), 0 } },
1311
    & ifmt_jq10, { 0x8000000 }
1312
  },
1313
/* jal $rt,$jmptarg */
1314
  {
1315
    { 0, 0, 0, 0 },
1316
    { { MNEM, ' ', OP (RT), ',', OP (JMPTARG), 0 } },
1317
    & ifmt_jalq10, { 0xc000000 }
1318
  },
1319
/* jal $jmptarg */
1320
  {
1321
    { 0, 0, 0, 0 },
1322
    { { MNEM, ' ', OP (JMPTARG), 0 } },
1323
    & ifmt_jq10, { 0xc1f0000 }
1324
  },
1325
/* bbil $rs($bitnum),$offset */
1326
  {
1327
    { 0, 0, 0, 0 },
1328
    { { MNEM, ' ', OP (RS), '(', OP (BITNUM), ')', ',', OP (OFFSET), 0 } },
1329
    & ifmt_bbi, { 0xf0000000 }
1330
  },
1331
/* bbinl $rs($bitnum),$offset */
1332
  {
1333
    { 0, 0, 0, 0 },
1334
    { { MNEM, ' ', OP (RS), '(', OP (BITNUM), ')', ',', OP (OFFSET), 0 } },
1335
    & ifmt_bbi, { 0xf8000000 }
1336
  },
1337
/* bbvl $rs,$rt,$offset */
1338
  {
1339
    { 0, 0, 0, 0 },
1340
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
1341
    & ifmt_bbv, { 0xf4000000 }
1342
  },
1343
/* bbvnl $rs,$rt,$offset */
1344
  {
1345
    { 0, 0, 0, 0 },
1346
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
1347
    & ifmt_bbv, { 0xfc000000 }
1348
  },
1349
/* bgtzal $rs,$offset */
1350
  {
1351
    { 0, 0, 0, 0 },
1352
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1353
    & ifmt_bgez, { 0x4150000 }
1354
  },
1355
/* bgtzall $rs,$offset */
1356
  {
1357
    { 0, 0, 0, 0 },
1358
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1359
    & ifmt_bgez, { 0x4170000 }
1360
  },
1361
/* blezal $rs,$offset */
1362
  {
1363
    { 0, 0, 0, 0 },
1364
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1365
    & ifmt_bgez, { 0x4140000 }
1366
  },
1367
/* blezall $rs,$offset */
1368
  {
1369
    { 0, 0, 0, 0 },
1370
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1371
    & ifmt_bgez, { 0x4160000 }
1372
  },
1373
/* bgtz $rs,$offset */
1374
  {
1375
    { 0, 0, 0, 0 },
1376
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1377
    & ifmt_bgez, { 0x4050000 }
1378
  },
1379
/* bgtzl $rs,$offset */
1380
  {
1381
    { 0, 0, 0, 0 },
1382
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1383
    & ifmt_bgez, { 0x4070000 }
1384
  },
1385
/* blez $rs,$offset */
1386
  {
1387
    { 0, 0, 0, 0 },
1388
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1389
    & ifmt_bgez, { 0x4040000 }
1390
  },
1391
/* blezl $rs,$offset */
1392
  {
1393
    { 0, 0, 0, 0 },
1394
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1395
    & ifmt_bgez, { 0x4060000 }
1396
  },
1397
/* bmb $rs,$rt,$offset */
1398
  {
1399
    { 0, 0, 0, 0 },
1400
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
1401
    & ifmt_bbv, { 0x18000000 }
1402
  },
1403
/* bmbl $rs,$rt,$offset */
1404
  {
1405
    { 0, 0, 0, 0 },
1406
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (OFFSET), 0 } },
1407
    & ifmt_bbv, { 0x58000000 }
1408
  },
1409
/* bri $rs,$offset */
1410
  {
1411
    { 0, 0, 0, 0 },
1412
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1413
    & ifmt_bgez, { 0x4080000 }
1414
  },
1415
/* brv $rs,$offset */
1416
  {
1417
    { 0, 0, 0, 0 },
1418
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1419
    & ifmt_bgez, { 0x4090000 }
1420
  },
1421
/* bctx $rs,$offset */
1422
  {
1423
    { 0, 0, 0, 0 },
1424
    { { MNEM, ' ', OP (RS), ',', OP (OFFSET), 0 } },
1425
    & ifmt_bgez, { 0x40c0000 }
1426
  },
1427
/* yield */
1428
  {
1429
    { 0, 0, 0, 0 },
1430
    { { MNEM, 0 } },
1431
    & ifmt_break, { 0xe }
1432
  },
1433
/* crc32 $rd,$rs,$rt */
1434
  {
1435
    { 0, 0, 0, 0 },
1436
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1437
    & ifmt_add, { 0x4c000014 }
1438
  },
1439
/* crc32b $rd,$rs,$rt */
1440
  {
1441
    { 0, 0, 0, 0 },
1442
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1443
    & ifmt_add, { 0x4c000015 }
1444
  },
1445
/* cnt1s $rd,$rs */
1446
  {
1447
    { 0, 0, 0, 0 },
1448
    { { MNEM, ' ', OP (RD), ',', OP (RS), 0 } },
1449
    & ifmt_add, { 0x2e }
1450
  },
1451
/* avail $rd */
1452
  {
1453
    { 0, 0, 0, 0 },
1454
    { { MNEM, ' ', OP (RD), 0 } },
1455
    & ifmt_avail, { 0x4c000024 }
1456
  },
1457
/* free $rd,$rs */
1458
  {
1459
    { 0, 0, 0, 0 },
1460
    { { MNEM, ' ', OP (RD), ',', OP (RS), 0 } },
1461
    & ifmt_jalr, { 0x4c000025 }
1462
  },
1463
/* tstod $rd,$rs */
1464
  {
1465
    { 0, 0, 0, 0 },
1466
    { { MNEM, ' ', OP (RD), ',', OP (RS), 0 } },
1467
    & ifmt_jalr, { 0x4c000027 }
1468
  },
1469
/* cmphdr $rd */
1470
  {
1471
    { 0, 0, 0, 0 },
1472
    { { MNEM, ' ', OP (RD), 0 } },
1473
    & ifmt_avail, { 0x4c00002c }
1474
  },
1475
/* mcid $rd,$rt */
1476
  {
1477
    { 0, 0, 0, 0 },
1478
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1479
    & ifmt_chkhdr, { 0x4c000020 }
1480
  },
1481
/* dba $rd */
1482
  {
1483
    { 0, 0, 0, 0 },
1484
    { { MNEM, ' ', OP (RD), 0 } },
1485
    & ifmt_avail, { 0x4c000022 }
1486
  },
1487
/* dbd $rd,$rs,$rt */
1488
  {
1489
    { 0, 0, 0, 0 },
1490
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1491
    & ifmt_add, { 0x4c000021 }
1492
  },
1493
/* dpwt $rd,$rs */
1494
  {
1495
    { 0, 0, 0, 0 },
1496
    { { MNEM, ' ', OP (RD), ',', OP (RS), 0 } },
1497
    & ifmt_jalr, { 0x4c000023 }
1498
  },
1499
/* chkhdr $rd,$rs */
1500
  {
1501
    { 0, 0, 0, 0 },
1502
    { { MNEM, ' ', OP (RD), ',', OP (RS), 0 } },
1503
    & ifmt_jalr, { 0x4c000026 }
1504
  },
1505
/* rba $rd,$rs,$rt */
1506
  {
1507
    { 0, 0, 0, 0 },
1508
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1509
    & ifmt_add, { 0x4c000008 }
1510
  },
1511
/* rbal $rd,$rs,$rt */
1512
  {
1513
    { 0, 0, 0, 0 },
1514
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1515
    & ifmt_add, { 0x4c000009 }
1516
  },
1517
/* rbar $rd,$rs,$rt */
1518
  {
1519
    { 0, 0, 0, 0 },
1520
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1521
    & ifmt_add, { 0x4c00000a }
1522
  },
1523
/* wba $rd,$rs,$rt */
1524
  {
1525
    { 0, 0, 0, 0 },
1526
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1527
    & ifmt_add, { 0x4c000010 }
1528
  },
1529
/* wbau $rd,$rs,$rt */
1530
  {
1531
    { 0, 0, 0, 0 },
1532
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1533
    & ifmt_add, { 0x4c000011 }
1534
  },
1535
/* wbac $rd,$rs,$rt */
1536
  {
1537
    { 0, 0, 0, 0 },
1538
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1539
    & ifmt_add, { 0x4c000012 }
1540
  },
1541
/* rbi $rd,$rs,$rt,$bytecount */
1542
  {
1543
    { 0, 0, 0, 0 },
1544
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1545
    & ifmt_rbi, { 0x4c000200 }
1546
  },
1547
/* rbil $rd,$rs,$rt,$bytecount */
1548
  {
1549
    { 0, 0, 0, 0 },
1550
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1551
    & ifmt_rbi, { 0x4c000300 }
1552
  },
1553
/* rbir $rd,$rs,$rt,$bytecount */
1554
  {
1555
    { 0, 0, 0, 0 },
1556
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1557
    & ifmt_rbi, { 0x4c000100 }
1558
  },
1559
/* wbi $rd,$rs,$rt,$bytecount */
1560
  {
1561
    { 0, 0, 0, 0 },
1562
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1563
    & ifmt_rbi, { 0x4c000600 }
1564
  },
1565
/* wbic $rd,$rs,$rt,$bytecount */
1566
  {
1567
    { 0, 0, 0, 0 },
1568
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1569
    & ifmt_rbi, { 0x4c000500 }
1570
  },
1571
/* wbiu $rd,$rs,$rt,$bytecount */
1572
  {
1573
    { 0, 0, 0, 0 },
1574
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1575
    & ifmt_rbi, { 0x4c000700 }
1576
  },
1577
/* pkrli $rd,$rs,$rt,$bytecount */
1578
  {
1579
    { 0, 0, 0, 0 },
1580
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1581
    & ifmt_rbi, { 0x48000000 }
1582
  },
1583
/* pkrlih $rd,$rs,$rt,$bytecount */
1584
  {
1585
    { 0, 0, 0, 0 },
1586
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1587
    & ifmt_rbi, { 0x48000200 }
1588
  },
1589
/* pkrliu $rd,$rs,$rt,$bytecount */
1590
  {
1591
    { 0, 0, 0, 0 },
1592
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1593
    & ifmt_rbi, { 0x48000100 }
1594
  },
1595
/* pkrlic $rd,$rs,$rt,$bytecount */
1596
  {
1597
    { 0, 0, 0, 0 },
1598
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
1599
    & ifmt_rbi, { 0x48000300 }
1600
  },
1601
/* pkrla $rd,$rs,$rt */
1602
  {
1603
    { 0, 0, 0, 0 },
1604
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1605
    & ifmt_add, { 0x4c000028 }
1606
  },
1607
/* pkrlau $rd,$rs,$rt */
1608
  {
1609
    { 0, 0, 0, 0 },
1610
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1611
    & ifmt_add, { 0x4c000029 }
1612
  },
1613
/* pkrlah $rd,$rs,$rt */
1614
  {
1615
    { 0, 0, 0, 0 },
1616
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1617
    & ifmt_add, { 0x4c00002a }
1618
  },
1619
/* pkrlac $rd,$rs,$rt */
1620
  {
1621
    { 0, 0, 0, 0 },
1622
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1623
    & ifmt_add, { 0x4c00002b }
1624
  },
1625
/* lock $rd,$rt */
1626
  {
1627
    { 0, 0, 0, 0 },
1628
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1629
    & ifmt_chkhdr, { 0x4c000001 }
1630
  },
1631
/* unlk $rd,$rt */
1632
  {
1633
    { 0, 0, 0, 0 },
1634
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1635
    & ifmt_chkhdr, { 0x4c000003 }
1636
  },
1637
/* swrd $rd,$rt */
1638
  {
1639
    { 0, 0, 0, 0 },
1640
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1641
    & ifmt_chkhdr, { 0x4c000004 }
1642
  },
1643
/* swrdl $rd,$rt */
1644
  {
1645
    { 0, 0, 0, 0 },
1646
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1647
    & ifmt_chkhdr, { 0x4c000005 }
1648
  },
1649
/* swwr $rd,$rs,$rt */
1650
  {
1651
    { 0, 0, 0, 0 },
1652
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1653
    & ifmt_add, { 0x4c000006 }
1654
  },
1655
/* swwru $rd,$rs,$rt */
1656
  {
1657
    { 0, 0, 0, 0 },
1658
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1659
    & ifmt_add, { 0x4c000007 }
1660
  },
1661
/* dwrd $rd,$rt */
1662
  {
1663
    { 0, 0, 0, 0 },
1664
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1665
    & ifmt_chkhdr, { 0x4c00000c }
1666
  },
1667
/* dwrdl $rd,$rt */
1668
  {
1669
    { 0, 0, 0, 0 },
1670
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1671
    & ifmt_chkhdr, { 0x4c00000d }
1672
  },
1673
/* cam36 $rd,$rt,${cam-z},${cam-y} */
1674
  {
1675
    { 0, 0, 0, 0 },
1676
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Z), ',', OP (CAM_Y), 0 } },
1677
    & ifmt_cam36, { 0x4c000400 }
1678
  },
1679
/* cam72 $rd,$rt,${cam-y},${cam-z} */
1680
  {
1681
    { 0, 0, 0, 0 },
1682
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Y), ',', OP (CAM_Z), 0 } },
1683
    & ifmt_cam36, { 0x4c000440 }
1684
  },
1685
/* cam144 $rd,$rt,${cam-y},${cam-z} */
1686
  {
1687
    { 0, 0, 0, 0 },
1688
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Y), ',', OP (CAM_Z), 0 } },
1689
    & ifmt_cam36, { 0x4c000480 }
1690
  },
1691
/* cam288 $rd,$rt,${cam-y},${cam-z} */
1692
  {
1693
    { 0, 0, 0, 0 },
1694
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Y), ',', OP (CAM_Z), 0 } },
1695
    & ifmt_cam36, { 0x4c0004c0 }
1696
  },
1697
/* cm32and $rd,$rs,$rt */
1698
  {
1699
    { 0, 0, 0, 0 },
1700
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1701
    & ifmt_cm32and, { 0x4c0000ab }
1702
  },
1703
/* cm32andn $rd,$rs,$rt */
1704
  {
1705
    { 0, 0, 0, 0 },
1706
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1707
    & ifmt_cm32and, { 0x4c0000a3 }
1708
  },
1709
/* cm32or $rd,$rs,$rt */
1710
  {
1711
    { 0, 0, 0, 0 },
1712
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1713
    & ifmt_cm32and, { 0x4c0000aa }
1714
  },
1715
/* cm32ra $rd,$rs,$rt */
1716
  {
1717
    { 0, 0, 0, 0 },
1718
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1719
    & ifmt_add, { 0x4c0000b0 }
1720
  },
1721
/* cm32rd $rd,$rt */
1722
  {
1723
    { 0, 0, 0, 0 },
1724
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1725
    & ifmt_cm32rd, { 0x4c0000a1 }
1726
  },
1727
/* cm32ri $rd,$rt */
1728
  {
1729
    { 0, 0, 0, 0 },
1730
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1731
    & ifmt_cm32rd, { 0x4c0000a4 }
1732
  },
1733
/* cm32rs $rd,$rs,$rt */
1734
  {
1735
    { 0, 0, 0, 0 },
1736
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1737
    & ifmt_add, { 0x4c0000a0 }
1738
  },
1739
/* cm32sa $rd,$rs,$rt */
1740
  {
1741
    { 0, 0, 0, 0 },
1742
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1743
    & ifmt_cm32and, { 0x4c0000b8 }
1744
  },
1745
/* cm32sd $rd,$rt */
1746
  {
1747
    { 0, 0, 0, 0 },
1748
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1749
    & ifmt_cm32rd, { 0x4c0000a9 }
1750
  },
1751
/* cm32si $rd,$rt */
1752
  {
1753
    { 0, 0, 0, 0 },
1754
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1755
    & ifmt_cm32rd, { 0x4c0000ac }
1756
  },
1757
/* cm32ss $rd,$rs,$rt */
1758
  {
1759
    { 0, 0, 0, 0 },
1760
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1761
    & ifmt_cm32and, { 0x4c0000a8 }
1762
  },
1763
/* cm32xor $rd,$rs,$rt */
1764
  {
1765
    { 0, 0, 0, 0 },
1766
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1767
    & ifmt_cm32and, { 0x4c0000a2 }
1768
  },
1769
/* cm64clr $rd,$rt */
1770
  {
1771
    { 0, 0, 0, 0 },
1772
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1773
    & ifmt_cm32rd, { 0x4c000085 }
1774
  },
1775
/* cm64ra $rd,$rs,$rt */
1776
  {
1777
    { 0, 0, 0, 0 },
1778
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1779
    & ifmt_cm32and, { 0x4c000090 }
1780
  },
1781
/* cm64rd $rd,$rt */
1782
  {
1783
    { 0, 0, 0, 0 },
1784
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1785
    & ifmt_cm32rd, { 0x4c000081 }
1786
  },
1787
/* cm64ri $rd,$rt */
1788
  {
1789
    { 0, 0, 0, 0 },
1790
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1791
    & ifmt_cm32rd, { 0x4c000084 }
1792
  },
1793
/* cm64ria2 $rd,$rs,$rt */
1794
  {
1795
    { 0, 0, 0, 0 },
1796
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1797
    & ifmt_cm32and, { 0x4c000094 }
1798
  },
1799
/* cm64rs $rd,$rs,$rt */
1800
  {
1801
    { 0, 0, 0, 0 },
1802
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1803
    & ifmt_cm32and, { 0x4c000080 }
1804
  },
1805
/* cm64sa $rd,$rs,$rt */
1806
  {
1807
    { 0, 0, 0, 0 },
1808
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1809
    & ifmt_cm32and, { 0x4c000098 }
1810
  },
1811
/* cm64sd $rd,$rt */
1812
  {
1813
    { 0, 0, 0, 0 },
1814
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1815
    & ifmt_cm32rd, { 0x4c000089 }
1816
  },
1817
/* cm64si $rd,$rt */
1818
  {
1819
    { 0, 0, 0, 0 },
1820
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1821
    & ifmt_cm32rd, { 0x4c00008c }
1822
  },
1823
/* cm64sia2 $rd,$rs,$rt */
1824
  {
1825
    { 0, 0, 0, 0 },
1826
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1827
    & ifmt_cm32and, { 0x4c00009c }
1828
  },
1829
/* cm64ss $rd,$rs,$rt */
1830
  {
1831
    { 0, 0, 0, 0 },
1832
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1833
    & ifmt_cm32and, { 0x4c000088 }
1834
  },
1835
/* cm128ria2 $rd,$rs,$rt */
1836
  {
1837
    { 0, 0, 0, 0 },
1838
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1839
    & ifmt_cm32and, { 0x4c000095 }
1840
  },
1841
/* cm128ria3 $rd,$rs,$rt,${cm-3z} */
1842
  {
1843
    { 0, 0, 0, 0 },
1844
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (CM_3Z), 0 } },
1845
    & ifmt_cm128ria3, { 0x4c000090 }
1846
  },
1847
/* cm128ria4 $rd,$rs,$rt,${cm-4z} */
1848
  {
1849
    { 0, 0, 0, 0 },
1850
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (CM_4Z), 0 } },
1851
    & ifmt_cm128ria4, { 0x4c0000b0 }
1852
  },
1853
/* cm128sia2 $rd,$rs,$rt */
1854
  {
1855
    { 0, 0, 0, 0 },
1856
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1857
    & ifmt_cm32and, { 0x4c00009d }
1858
  },
1859
/* cm128sia3 $rd,$rs,$rt,${cm-3z} */
1860
  {
1861
    { 0, 0, 0, 0 },
1862
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (CM_3Z), 0 } },
1863
    & ifmt_cm128ria3, { 0x4c000098 }
1864
  },
1865
/* cm128sia4 $rd,$rs,$rt,${cm-4z} */
1866
  {
1867
    { 0, 0, 0, 0 },
1868
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), ',', OP (CM_4Z), 0 } },
1869
    & ifmt_cm128ria4, { 0x4c0000b8 }
1870
  },
1871
/* cm128vsa $rd,$rs,$rt */
1872
  {
1873
    { 0, 0, 0, 0 },
1874
    { { MNEM, ' ', OP (RD), ',', OP (RS), ',', OP (RT), 0 } },
1875
    & ifmt_cm32and, { 0x4c0000a6 }
1876
  },
1877
/* cfc $rd,$rt */
1878
  {
1879
    { 0, 0, 0, 0 },
1880
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
1881
    & ifmt_chkhdr, { 0x4c000000 }
1882
  },
1883
/* ctc $rs,$rt */
1884
  {
1885
    { 0, 0, 0, 0 },
1886
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
1887
    & ifmt_ctc, { 0x4c000002 }
1888
  },
1889
};
1890
 
1891
#undef A
1892
#undef OPERAND
1893
#undef MNEM
1894
#undef OP
1895
 
1896
/* Formats for ALIAS macro-insns.  */
1897
 
1898
#define F(f) & iq2000_cgen_ifld_table[IQ2000_##f]
1899
static const CGEN_IFMT ifmt_nop ATTRIBUTE_UNUSED = {
1900
  32, 32, 0xffffffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
1901
};
1902
 
1903
static const CGEN_IFMT ifmt_li ATTRIBUTE_UNUSED = {
1904
  32, 32, 0xfc1f0000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1905
};
1906
 
1907
static const CGEN_IFMT ifmt_move ATTRIBUTE_UNUSED = {
1908
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
1909
};
1910
 
1911
static const CGEN_IFMT ifmt_lb_base_0 ATTRIBUTE_UNUSED = {
1912
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1913
};
1914
 
1915
static const CGEN_IFMT ifmt_lbu_base_0 ATTRIBUTE_UNUSED = {
1916
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1917
};
1918
 
1919
static const CGEN_IFMT ifmt_lh_base_0 ATTRIBUTE_UNUSED = {
1920
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1921
};
1922
 
1923
static const CGEN_IFMT ifmt_lw_base_0 ATTRIBUTE_UNUSED = {
1924
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1925
};
1926
 
1927
static const CGEN_IFMT ifmt_m_add ATTRIBUTE_UNUSED = {
1928
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1929
};
1930
 
1931
static const CGEN_IFMT ifmt_m_addu ATTRIBUTE_UNUSED = {
1932
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1933
};
1934
 
1935
static const CGEN_IFMT ifmt_m_and ATTRIBUTE_UNUSED = {
1936
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1937
};
1938
 
1939
static const CGEN_IFMT ifmt_m_j ATTRIBUTE_UNUSED = {
1940
  32, 32, 0xfc1fffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
1941
};
1942
 
1943
static const CGEN_IFMT ifmt_m_or ATTRIBUTE_UNUSED = {
1944
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1945
};
1946
 
1947
static const CGEN_IFMT ifmt_m_sll ATTRIBUTE_UNUSED = {
1948
  32, 32, 0xfc0007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
1949
};
1950
 
1951
static const CGEN_IFMT ifmt_m_slt ATTRIBUTE_UNUSED = {
1952
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1953
};
1954
 
1955
static const CGEN_IFMT ifmt_m_sltu ATTRIBUTE_UNUSED = {
1956
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1957
};
1958
 
1959
static const CGEN_IFMT ifmt_m_sra ATTRIBUTE_UNUSED = {
1960
  32, 32, 0xfc0007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
1961
};
1962
 
1963
static const CGEN_IFMT ifmt_m_srl ATTRIBUTE_UNUSED = {
1964
  32, 32, 0xfc0007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
1965
};
1966
 
1967
static const CGEN_IFMT ifmt_not ATTRIBUTE_UNUSED = {
1968
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
1969
};
1970
 
1971
static const CGEN_IFMT ifmt_subi ATTRIBUTE_UNUSED = {
1972
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1973
};
1974
 
1975
static const CGEN_IFMT ifmt_m_sub ATTRIBUTE_UNUSED = {
1976
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1977
};
1978
 
1979
static const CGEN_IFMT ifmt_m_subu ATTRIBUTE_UNUSED = {
1980
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1981
};
1982
 
1983
static const CGEN_IFMT ifmt_sb_base_0 ATTRIBUTE_UNUSED = {
1984
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1985
};
1986
 
1987
static const CGEN_IFMT ifmt_sh_base_0 ATTRIBUTE_UNUSED = {
1988
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1989
};
1990
 
1991
static const CGEN_IFMT ifmt_sw_base_0 ATTRIBUTE_UNUSED = {
1992
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1993
};
1994
 
1995
static const CGEN_IFMT ifmt_m_xor ATTRIBUTE_UNUSED = {
1996
  32, 32, 0xfc000000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
1997
};
1998
 
1999
static const CGEN_IFMT ifmt_ldw_base_0 ATTRIBUTE_UNUSED = {
2000
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
2001
};
2002
 
2003
static const CGEN_IFMT ifmt_sdw_base_0 ATTRIBUTE_UNUSED = {
2004
  32, 32, 0xffe00000, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_IMM) }, { 0 } }
2005
};
2006
 
2007
static const CGEN_IFMT ifmt_m_avail ATTRIBUTE_UNUSED = {
2008
  32, 32, 0xffffffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2009
};
2010
 
2011
static const CGEN_IFMT ifmt_m_cam36 ATTRIBUTE_UNUSED = {
2012
  32, 32, 0xffe007c7, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP_10) }, { F (F_CAM_Z) }, { F (F_CAM_Y) }, { 0 } }
2013
};
2014
 
2015
static const CGEN_IFMT ifmt_m_cam72 ATTRIBUTE_UNUSED = {
2016
  32, 32, 0xffe007c7, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP_10) }, { F (F_CAM_Z) }, { F (F_CAM_Y) }, { 0 } }
2017
};
2018
 
2019
static const CGEN_IFMT ifmt_m_cam144 ATTRIBUTE_UNUSED = {
2020
  32, 32, 0xffe007c7, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP_10) }, { F (F_CAM_Z) }, { F (F_CAM_Y) }, { 0 } }
2021
};
2022
 
2023
static const CGEN_IFMT ifmt_m_cam288 ATTRIBUTE_UNUSED = {
2024
  32, 32, 0xffe007c7, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP_10) }, { F (F_CAM_Z) }, { F (F_CAM_Y) }, { 0 } }
2025
};
2026
 
2027
static const CGEN_IFMT ifmt_m_cm32read ATTRIBUTE_UNUSED = {
2028
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2029
};
2030
 
2031
static const CGEN_IFMT ifmt_m_cm64read ATTRIBUTE_UNUSED = {
2032
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2033
};
2034
 
2035
static const CGEN_IFMT ifmt_m_cm32mlog ATTRIBUTE_UNUSED = {
2036
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2037
};
2038
 
2039
static const CGEN_IFMT ifmt_m_cm32and ATTRIBUTE_UNUSED = {
2040
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2041
};
2042
 
2043
static const CGEN_IFMT ifmt_m_cm32andn ATTRIBUTE_UNUSED = {
2044
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2045
};
2046
 
2047
static const CGEN_IFMT ifmt_m_cm32or ATTRIBUTE_UNUSED = {
2048
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2049
};
2050
 
2051
static const CGEN_IFMT ifmt_m_cm32ra ATTRIBUTE_UNUSED = {
2052
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2053
};
2054
 
2055
static const CGEN_IFMT ifmt_m_cm32rd ATTRIBUTE_UNUSED = {
2056
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2057
};
2058
 
2059
static const CGEN_IFMT ifmt_m_cm32ri ATTRIBUTE_UNUSED = {
2060
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2061
};
2062
 
2063
static const CGEN_IFMT ifmt_m_cm32rs ATTRIBUTE_UNUSED = {
2064
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2065
};
2066
 
2067
static const CGEN_IFMT ifmt_m_cm32sa ATTRIBUTE_UNUSED = {
2068
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2069
};
2070
 
2071
static const CGEN_IFMT ifmt_m_cm32sd ATTRIBUTE_UNUSED = {
2072
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2073
};
2074
 
2075
static const CGEN_IFMT ifmt_m_cm32si ATTRIBUTE_UNUSED = {
2076
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2077
};
2078
 
2079
static const CGEN_IFMT ifmt_m_cm32ss ATTRIBUTE_UNUSED = {
2080
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2081
};
2082
 
2083
static const CGEN_IFMT ifmt_m_cm32xor ATTRIBUTE_UNUSED = {
2084
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2085
};
2086
 
2087
static const CGEN_IFMT ifmt_m_cm64clr ATTRIBUTE_UNUSED = {
2088
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2089
};
2090
 
2091
static const CGEN_IFMT ifmt_m_cm64ra ATTRIBUTE_UNUSED = {
2092
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2093
};
2094
 
2095
static const CGEN_IFMT ifmt_m_cm64rd ATTRIBUTE_UNUSED = {
2096
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2097
};
2098
 
2099
static const CGEN_IFMT ifmt_m_cm64ri ATTRIBUTE_UNUSED = {
2100
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2101
};
2102
 
2103
static const CGEN_IFMT ifmt_m_cm64ria2 ATTRIBUTE_UNUSED = {
2104
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2105
};
2106
 
2107
static const CGEN_IFMT ifmt_m_cm64rs ATTRIBUTE_UNUSED = {
2108
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2109
};
2110
 
2111
static const CGEN_IFMT ifmt_m_cm64sa ATTRIBUTE_UNUSED = {
2112
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2113
};
2114
 
2115
static const CGEN_IFMT ifmt_m_cm64sd ATTRIBUTE_UNUSED = {
2116
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2117
};
2118
 
2119
static const CGEN_IFMT ifmt_m_cm64si ATTRIBUTE_UNUSED = {
2120
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2121
};
2122
 
2123
static const CGEN_IFMT ifmt_m_cm64sia2 ATTRIBUTE_UNUSED = {
2124
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2125
};
2126
 
2127
static const CGEN_IFMT ifmt_m_cm64ss ATTRIBUTE_UNUSED = {
2128
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2129
};
2130
 
2131
static const CGEN_IFMT ifmt_m_cm128ria2 ATTRIBUTE_UNUSED = {
2132
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2133
};
2134
 
2135
static const CGEN_IFMT ifmt_m_cm128ria3 ATTRIBUTE_UNUSED = {
2136
  32, 32, 0xfc00fffc, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_CM_4FUNC) }, { F (F_CM_3Z) }, { 0 } }
2137
};
2138
 
2139
static const CGEN_IFMT ifmt_m_cm128ria4 ATTRIBUTE_UNUSED = {
2140
  32, 32, 0xfc00fff8, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_CM_3FUNC) }, { F (F_CM_4Z) }, { 0 } }
2141
};
2142
 
2143
static const CGEN_IFMT ifmt_m_cm128sia2 ATTRIBUTE_UNUSED = {
2144
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_FUNC) }, { 0 } }
2145
};
2146
 
2147
static const CGEN_IFMT ifmt_m_cm128sia3 ATTRIBUTE_UNUSED = {
2148
  32, 32, 0xfc00fffc, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_CM_4FUNC) }, { F (F_CM_3Z) }, { 0 } }
2149
};
2150
 
2151
static const CGEN_IFMT ifmt_m_cm128sia4 ATTRIBUTE_UNUSED = {
2152
  32, 32, 0xfc00fff8, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_CP_GRP) }, { F (F_CM_3FUNC) }, { F (F_CM_4Z) }, { 0 } }
2153
};
2154
 
2155
static const CGEN_IFMT ifmt_m_cmphdr ATTRIBUTE_UNUSED = {
2156
  32, 32, 0xffffffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2157
};
2158
 
2159
static const CGEN_IFMT ifmt_m_dbd ATTRIBUTE_UNUSED = {
2160
  32, 32, 0xffe007ff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2161
};
2162
 
2163
static const CGEN_IFMT ifmt_m2_dbd ATTRIBUTE_UNUSED = {
2164
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2165
};
2166
 
2167
static const CGEN_IFMT ifmt_m_dpwt ATTRIBUTE_UNUSED = {
2168
  32, 32, 0xfc1fffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2169
};
2170
 
2171
static const CGEN_IFMT ifmt_m_free ATTRIBUTE_UNUSED = {
2172
  32, 32, 0xfc1fffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2173
};
2174
 
2175
static const CGEN_IFMT ifmt_m_lock ATTRIBUTE_UNUSED = {
2176
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2177
};
2178
 
2179
static const CGEN_IFMT ifmt_m_pkrla ATTRIBUTE_UNUSED = {
2180
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2181
};
2182
 
2183
static const CGEN_IFMT ifmt_m_pkrlac ATTRIBUTE_UNUSED = {
2184
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2185
};
2186
 
2187
static const CGEN_IFMT ifmt_m_pkrlah ATTRIBUTE_UNUSED = {
2188
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2189
};
2190
 
2191
static const CGEN_IFMT ifmt_m_pkrlau ATTRIBUTE_UNUSED = {
2192
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2193
};
2194
 
2195
static const CGEN_IFMT ifmt_m_pkrli ATTRIBUTE_UNUSED = {
2196
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2197
};
2198
 
2199
static const CGEN_IFMT ifmt_m_pkrlic ATTRIBUTE_UNUSED = {
2200
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2201
};
2202
 
2203
static const CGEN_IFMT ifmt_m_pkrlih ATTRIBUTE_UNUSED = {
2204
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2205
};
2206
 
2207
static const CGEN_IFMT ifmt_m_pkrliu ATTRIBUTE_UNUSED = {
2208
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2209
};
2210
 
2211
static const CGEN_IFMT ifmt_m_rba ATTRIBUTE_UNUSED = {
2212
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2213
};
2214
 
2215
static const CGEN_IFMT ifmt_m_rbal ATTRIBUTE_UNUSED = {
2216
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2217
};
2218
 
2219
static const CGEN_IFMT ifmt_m_rbar ATTRIBUTE_UNUSED = {
2220
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2221
};
2222
 
2223
static const CGEN_IFMT ifmt_m_rbi ATTRIBUTE_UNUSED = {
2224
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2225
};
2226
 
2227
static const CGEN_IFMT ifmt_m_rbil ATTRIBUTE_UNUSED = {
2228
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2229
};
2230
 
2231
static const CGEN_IFMT ifmt_m_rbir ATTRIBUTE_UNUSED = {
2232
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2233
};
2234
 
2235
static const CGEN_IFMT ifmt_m_swwr ATTRIBUTE_UNUSED = {
2236
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2237
};
2238
 
2239
static const CGEN_IFMT ifmt_m_swwru ATTRIBUTE_UNUSED = {
2240
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2241
};
2242
 
2243
static const CGEN_IFMT ifmt_m_tstod ATTRIBUTE_UNUSED = {
2244
  32, 32, 0xfc1fffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2245
};
2246
 
2247
static const CGEN_IFMT ifmt_m_unlk ATTRIBUTE_UNUSED = {
2248
  32, 32, 0xffe0ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2249
};
2250
 
2251
static const CGEN_IFMT ifmt_m_wba ATTRIBUTE_UNUSED = {
2252
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2253
};
2254
 
2255
static const CGEN_IFMT ifmt_m_wbac ATTRIBUTE_UNUSED = {
2256
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2257
};
2258
 
2259
static const CGEN_IFMT ifmt_m_wbau ATTRIBUTE_UNUSED = {
2260
  32, 32, 0xfc00ffff, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_SHAMT) }, { F (F_FUNC) }, { 0 } }
2261
};
2262
 
2263
static const CGEN_IFMT ifmt_m_wbi ATTRIBUTE_UNUSED = {
2264
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2265
};
2266
 
2267
static const CGEN_IFMT ifmt_m_wbic ATTRIBUTE_UNUSED = {
2268
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2269
};
2270
 
2271
static const CGEN_IFMT ifmt_m_wbiu ATTRIBUTE_UNUSED = {
2272
  32, 32, 0xfc00ff00, { { F (F_OPCODE) }, { F (F_RS) }, { F (F_RT) }, { F (F_RD) }, { F (F_CP_OP) }, { F (F_BYTECOUNT) }, { 0 } }
2273
};
2274
 
2275
#undef F
2276
 
2277
/* Each non-simple macro entry points to an array of expansion possibilities.  */
2278
 
2279
#define A(a) (1 << CGEN_INSN_##a)
2280
#define OPERAND(op) IQ2000_OPERAND_##op
2281
#define MNEM CGEN_SYNTAX_MNEMONIC /* syntax value for mnemonic */
2282
#define OP(field) CGEN_SYNTAX_MAKE_FIELD (OPERAND (field))
2283
 
2284
/* The macro instruction table.  */
2285
 
2286
static const CGEN_IBASE iq2000_cgen_macro_insn_table[] =
2287
{
2288
/* nop */
2289
  {
2290
    -1, "nop", "nop", 32,
2291
    { 0|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2292
  },
2293
/* li $rs,$imm */
2294
  {
2295
    -1, "li", "li", 32,
2296
    { 0|A(NO_DIS)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2297
  },
2298
/* move $rd,$rt */
2299
  {
2300
    -1, "move", "move", 32,
2301
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2302
  },
2303
/* lb $rt,$lo16 */
2304
  {
2305
    -1, "lb-base-0", "lb", 32,
2306
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2307
  },
2308
/* lbu $rt,$lo16 */
2309
  {
2310
    -1, "lbu-base-0", "lbu", 32,
2311
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2312
  },
2313
/* lh $rt,$lo16 */
2314
  {
2315
    -1, "lh-base-0", "lh", 32,
2316
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2317
  },
2318
/* lw $rt,$lo16 */
2319
  {
2320
    -1, "lw-base-0", "lw", 32,
2321
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2322
  },
2323
/* add $rt,$rs,$lo16 */
2324
  {
2325
    -1, "m-add", "add", 32,
2326
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2327
  },
2328
/* addu $rt,$rs,$lo16 */
2329
  {
2330
    -1, "m-addu", "addu", 32,
2331
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2332
  },
2333
/* and $rt,$rs,$lo16 */
2334
  {
2335
    -1, "m-and", "and", 32,
2336
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2337
  },
2338
/* j $rs */
2339
  {
2340
    -1, "m-j", "j", 32,
2341
    { 0|A(NO_DIS)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2342
  },
2343
/* or $rt,$rs,$lo16 */
2344
  {
2345
    -1, "m-or", "or", 32,
2346
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2347
  },
2348
/* sll $rd,$rt,$rs */
2349
  {
2350
    -1, "m-sll", "sll", 32,
2351
    { 0|A(NO_DIS)|A(USES_RS)|A(USES_RT)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2352
  },
2353
/* slt $rt,$rs,$imm */
2354
  {
2355
    -1, "m-slt", "slt", 32,
2356
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2357
  },
2358
/* sltu $rt,$rs,$imm */
2359
  {
2360
    -1, "m-sltu", "sltu", 32,
2361
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2362
  },
2363
/* sra $rd,$rt,$rs */
2364
  {
2365
    -1, "m-sra", "sra", 32,
2366
    { 0|A(NO_DIS)|A(USES_RS)|A(USES_RT)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2367
  },
2368
/* srl $rd,$rt,$rs */
2369
  {
2370
    -1, "m-srl", "srl", 32,
2371
    { 0|A(NO_DIS)|A(USES_RS)|A(USES_RT)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2372
  },
2373
/* not $rd,$rt */
2374
  {
2375
    -1, "not", "not", 32,
2376
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2377
  },
2378
/* subi $rt,$rs,$mlo16 */
2379
  {
2380
    -1, "subi", "subi", 32,
2381
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2382
  },
2383
/* sub $rt,$rs,$mlo16 */
2384
  {
2385
    -1, "m-sub", "sub", 32,
2386
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2387
  },
2388
/* subu $rt,$rs,$mlo16 */
2389
  {
2390
    -1, "m-subu", "subu", 32,
2391
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2392
  },
2393
/* sb $rt,$lo16 */
2394
  {
2395
    -1, "sb-base-0", "sb", 32,
2396
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2397
  },
2398
/* sh $rt,$lo16 */
2399
  {
2400
    -1, "sh-base-0", "sh", 32,
2401
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2402
  },
2403
/* sw $rt,$lo16 */
2404
  {
2405
    -1, "sw-base-0", "sw", 32,
2406
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2407
  },
2408
/* xor $rt,$rs,$lo16 */
2409
  {
2410
    -1, "m-xor", "xor", 32,
2411
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
2412
  },
2413
/* ldw $rt,$lo16 */
2414
  {
2415
    -1, "ldw-base-0", "ldw", 32,
2416
    { 0|A(NO_DIS)|A(USES_RS)|A(USES_RT)|A(LOAD_DELAY)|A(EVEN_REG_NUM)|A(ALIAS), { { { (1<<MACH_IQ2000), 0 } } } }
2417
  },
2418
/* sdw $rt,$lo16 */
2419
  {
2420
    -1, "sdw-base-0", "sdw", 32,
2421
    { 0|A(NO_DIS)|A(USES_RT)|A(EVEN_REG_NUM)|A(ALIAS), { { { (1<<MACH_IQ2000), 0 } } } }
2422
  },
2423
/* avail */
2424
  {
2425
    -1, "m-avail", "avail", 32,
2426
    { 0|A(NO_DIS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2427
  },
2428
/* cam36 $rd,$rt,${cam-z} */
2429
  {
2430
    -1, "m-cam36", "cam36", 32,
2431
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2432
  },
2433
/* cam72 $rd,$rt,${cam-z} */
2434
  {
2435
    -1, "m-cam72", "cam72", 32,
2436
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2437
  },
2438
/* cam144 $rd,$rt,${cam-z} */
2439
  {
2440
    -1, "m-cam144", "cam144", 32,
2441
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2442
  },
2443
/* cam288 $rd,$rt,${cam-z} */
2444
  {
2445
    -1, "m-cam288", "cam288", 32,
2446
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2447
  },
2448
/* cm32read $rd,$rt */
2449
  {
2450
    -1, "m-cm32read", "cm32read", 32,
2451
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2452
  },
2453
/* cm64read $rd,$rt */
2454
  {
2455
    -1, "m-cm64read", "cm64read", 32,
2456
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2457
  },
2458
/* cm32mlog $rs,$rt */
2459
  {
2460
    -1, "m-cm32mlog", "cm32mlog", 32,
2461
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2462
  },
2463
/* cm32and $rs,$rt */
2464
  {
2465
    -1, "m-cm32and", "cm32and", 32,
2466
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2467
  },
2468
/* cm32andn $rs,$rt */
2469
  {
2470
    -1, "m-cm32andn", "cm32andn", 32,
2471
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2472
  },
2473
/* cm32or $rs,$rt */
2474
  {
2475
    -1, "m-cm32or", "cm32or", 32,
2476
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2477
  },
2478
/* cm32ra $rs,$rt */
2479
  {
2480
    -1, "m-cm32ra", "cm32ra", 32,
2481
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2482
  },
2483
/* cm32rd $rt */
2484
  {
2485
    -1, "m-cm32rd", "cm32rd", 32,
2486
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2487
  },
2488
/* cm32ri $rt */
2489
  {
2490
    -1, "m-cm32ri", "cm32ri", 32,
2491
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2492
  },
2493
/* cm32rs $rs,$rt */
2494
  {
2495
    -1, "m-cm32rs", "cm32rs", 32,
2496
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2497
  },
2498
/* cm32sa $rs,$rt */
2499
  {
2500
    -1, "m-cm32sa", "cm32sa", 32,
2501
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2502
  },
2503
/* cm32sd $rt */
2504
  {
2505
    -1, "m-cm32sd", "cm32sd", 32,
2506
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2507
  },
2508
/* cm32si $rt */
2509
  {
2510
    -1, "m-cm32si", "cm32si", 32,
2511
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2512
  },
2513
/* cm32ss $rs,$rt */
2514
  {
2515
    -1, "m-cm32ss", "cm32ss", 32,
2516
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2517
  },
2518
/* cm32xor $rs,$rt */
2519
  {
2520
    -1, "m-cm32xor", "cm32xor", 32,
2521
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2522
  },
2523
/* cm64clr $rt */
2524
  {
2525
    -1, "m-cm64clr", "cm64clr", 32,
2526
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2527
  },
2528
/* cm64ra $rs,$rt */
2529
  {
2530
    -1, "m-cm64ra", "cm64ra", 32,
2531
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2532
  },
2533
/* cm64rd $rt */
2534
  {
2535
    -1, "m-cm64rd", "cm64rd", 32,
2536
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2537
  },
2538
/* cm64ri $rt */
2539
  {
2540
    -1, "m-cm64ri", "cm64ri", 32,
2541
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2542
  },
2543
/* cm64ria2 $rs,$rt */
2544
  {
2545
    -1, "m-cm64ria2", "cm64ria2", 32,
2546
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2547
  },
2548
/* cm64rs $rs,$rt */
2549
  {
2550
    -1, "m-cm64rs", "cm64rs", 32,
2551
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2552
  },
2553
/* cm64sa $rs,$rt */
2554
  {
2555
    -1, "m-cm64sa", "cm64sa", 32,
2556
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2557
  },
2558
/* cm64sd $rt */
2559
  {
2560
    -1, "m-cm64sd", "cm64sd", 32,
2561
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2562
  },
2563
/* cm64si $rt */
2564
  {
2565
    -1, "m-cm64si", "cm64si", 32,
2566
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2567
  },
2568
/* cm64sia2 $rs,$rt */
2569
  {
2570
    -1, "m-cm64sia2", "cm64sia2", 32,
2571
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2572
  },
2573
/* cm64ss $rs,$rt */
2574
  {
2575
    -1, "m-cm64ss", "cm64ss", 32,
2576
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2577
  },
2578
/* cm128ria2 $rs,$rt */
2579
  {
2580
    -1, "m-cm128ria2", "cm128ria2", 32,
2581
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2582
  },
2583
/* cm128ria3 $rs,$rt,${cm-3z} */
2584
  {
2585
    -1, "m-cm128ria3", "cm128ria3", 32,
2586
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2587
  },
2588
/* cm128ria4 $rs,$rt,${cm-4z} */
2589
  {
2590
    -1, "m-cm128ria4", "cm128ria4", 32,
2591
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2592
  },
2593
/* cm128sia2 $rs,$rt */
2594
  {
2595
    -1, "m-cm128sia2", "cm128sia2", 32,
2596
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2597
  },
2598
/* cm128sia3 $rs,$rt,${cm-3z} */
2599
  {
2600
    -1, "m-cm128sia3", "cm128sia3", 32,
2601
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2602
  },
2603
/* cm128sia4 $rs,$rt,${cm-4z} */
2604
  {
2605
    -1, "m-cm128sia4", "cm128sia4", 32,
2606
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2607
  },
2608
/* cmphdr */
2609
  {
2610
    -1, "m-cmphdr", "cmphdr", 32,
2611
    { 0|A(NO_DIS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2612
  },
2613
/* dbd $rd,$rt */
2614
  {
2615
    -1, "m-dbd", "dbd", 32,
2616
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2617
  },
2618
/* dbd $rt */
2619
  {
2620
    -1, "m2-dbd", "dbd", 32,
2621
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2622
  },
2623
/* dpwt $rs */
2624
  {
2625
    -1, "m-dpwt", "dpwt", 32,
2626
    { 0|A(NO_DIS)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2627
  },
2628
/* free $rs */
2629
  {
2630
    -1, "m-free", "free", 32,
2631
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2632
  },
2633
/* lock $rt */
2634
  {
2635
    -1, "m-lock", "lock", 32,
2636
    { 0|A(NO_DIS)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2637
  },
2638
/* pkrla $rs,$rt */
2639
  {
2640
    -1, "m-pkrla", "pkrla", 32,
2641
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2642
  },
2643
/* pkrlac $rs,$rt */
2644
  {
2645
    -1, "m-pkrlac", "pkrlac", 32,
2646
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2647
  },
2648
/* pkrlah $rs,$rt */
2649
  {
2650
    -1, "m-pkrlah", "pkrlah", 32,
2651
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2652
  },
2653
/* pkrlau $rs,$rt */
2654
  {
2655
    -1, "m-pkrlau", "pkrlau", 32,
2656
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2657
  },
2658
/* pkrli $rs,$rt,$bytecount */
2659
  {
2660
    -1, "m-pkrli", "pkrli", 32,
2661
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2662
  },
2663
/* pkrlic $rs,$rt,$bytecount */
2664
  {
2665
    -1, "m-pkrlic", "pkrlic", 32,
2666
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2667
  },
2668
/* pkrlih $rs,$rt,$bytecount */
2669
  {
2670
    -1, "m-pkrlih", "pkrlih", 32,
2671
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2672
  },
2673
/* pkrliu $rs,$rt,$bytecount */
2674
  {
2675
    -1, "m-pkrliu", "pkrliu", 32,
2676
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2677
  },
2678
/* rba $rs,$rt */
2679
  {
2680
    -1, "m-rba", "rba", 32,
2681
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2682
  },
2683
/* rbal $rs,$rt */
2684
  {
2685
    -1, "m-rbal", "rbal", 32,
2686
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2687
  },
2688
/* rbar $rs,$rt */
2689
  {
2690
    -1, "m-rbar", "rbar", 32,
2691
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2692
  },
2693
/* rbi $rs,$rt,$bytecount */
2694
  {
2695
    -1, "m-rbi", "rbi", 32,
2696
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2697
  },
2698
/* rbil $rs,$rt,$bytecount */
2699
  {
2700
    -1, "m-rbil", "rbil", 32,
2701
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2702
  },
2703
/* rbir $rs,$rt,$bytecount */
2704
  {
2705
    -1, "m-rbir", "rbir", 32,
2706
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2707
  },
2708
/* swwr $rs,$rt */
2709
  {
2710
    -1, "m-swwr", "swwr", 32,
2711
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2712
  },
2713
/* swwru $rs,$rt */
2714
  {
2715
    -1, "m-swwru", "swwru", 32,
2716
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2717
  },
2718
/* tstod $rs */
2719
  {
2720
    -1, "m-tstod", "tstod", 32,
2721
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2722
  },
2723
/* unlk $rt */
2724
  {
2725
    -1, "m-unlk", "unlk", 32,
2726
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2727
  },
2728
/* wba $rs,$rt */
2729
  {
2730
    -1, "m-wba", "wba", 32,
2731
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2732
  },
2733
/* wbac $rs,$rt */
2734
  {
2735
    -1, "m-wbac", "wbac", 32,
2736
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2737
  },
2738
/* wbau $rs,$rt */
2739
  {
2740
    -1, "m-wbau", "wbau", 32,
2741
    { 0|A(NO_DIS)|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2742
  },
2743
/* wbi $rs,$rt,$bytecount */
2744
  {
2745
    -1, "m-wbi", "wbi", 32,
2746
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2747
  },
2748
/* wbic $rs,$rt,$bytecount */
2749
  {
2750
    -1, "m-wbic", "wbic", 32,
2751
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2752
  },
2753
/* wbiu $rs,$rt,$bytecount */
2754
  {
2755
    -1, "m-wbiu", "wbiu", 32,
2756
    { 0|A(NO_DIS)|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(ALIAS), { { { (1<<MACH_IQ10), 0 } } } }
2757
  },
2758
};
2759
 
2760
/* The macro instruction opcode table.  */
2761
 
2762
static const CGEN_OPCODE iq2000_cgen_macro_insn_opcode_table[] =
2763
{
2764
/* nop */
2765
  {
2766
    { 0, 0, 0, 0 },
2767
    { { MNEM, 0 } },
2768
    & ifmt_nop, { 0x0 }
2769
  },
2770
/* li $rs,$imm */
2771
  {
2772
    { 0, 0, 0, 0 },
2773
    { { MNEM, ' ', OP (RS), ',', OP (IMM), 0 } },
2774
    & ifmt_li, { 0x34000000 }
2775
  },
2776
/* move $rd,$rt */
2777
  {
2778
    { 0, 0, 0, 0 },
2779
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
2780
    & ifmt_move, { 0x25 }
2781
  },
2782
/* lb $rt,$lo16 */
2783
  {
2784
    { 0, 0, 0, 0 },
2785
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2786
    & ifmt_lb_base_0, { 0x80000000 }
2787
  },
2788
/* lbu $rt,$lo16 */
2789
  {
2790
    { 0, 0, 0, 0 },
2791
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2792
    & ifmt_lbu_base_0, { 0x90000000 }
2793
  },
2794
/* lh $rt,$lo16 */
2795
  {
2796
    { 0, 0, 0, 0 },
2797
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2798
    & ifmt_lh_base_0, { 0x84000000 }
2799
  },
2800
/* lw $rt,$lo16 */
2801
  {
2802
    { 0, 0, 0, 0 },
2803
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2804
    & ifmt_lw_base_0, { 0x8c000000 }
2805
  },
2806
/* add $rt,$rs,$lo16 */
2807
  {
2808
    { 0, 0, 0, 0 },
2809
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
2810
    & ifmt_m_add, { 0x20000000 }
2811
  },
2812
/* addu $rt,$rs,$lo16 */
2813
  {
2814
    { 0, 0, 0, 0 },
2815
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
2816
    & ifmt_m_addu, { 0x24000000 }
2817
  },
2818
/* and $rt,$rs,$lo16 */
2819
  {
2820
    { 0, 0, 0, 0 },
2821
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
2822
    & ifmt_m_and, { 0x30000000 }
2823
  },
2824
/* j $rs */
2825
  {
2826
    { 0, 0, 0, 0 },
2827
    { { MNEM, ' ', OP (RS), 0 } },
2828
    & ifmt_m_j, { 0x8 }
2829
  },
2830
/* or $rt,$rs,$lo16 */
2831
  {
2832
    { 0, 0, 0, 0 },
2833
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
2834
    & ifmt_m_or, { 0x34000000 }
2835
  },
2836
/* sll $rd,$rt,$rs */
2837
  {
2838
    { 0, 0, 0, 0 },
2839
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), 0 } },
2840
    & ifmt_m_sll, { 0x4 }
2841
  },
2842
/* slt $rt,$rs,$imm */
2843
  {
2844
    { 0, 0, 0, 0 },
2845
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (IMM), 0 } },
2846
    & ifmt_m_slt, { 0x28000000 }
2847
  },
2848
/* sltu $rt,$rs,$imm */
2849
  {
2850
    { 0, 0, 0, 0 },
2851
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (IMM), 0 } },
2852
    & ifmt_m_sltu, { 0x2c000000 }
2853
  },
2854
/* sra $rd,$rt,$rs */
2855
  {
2856
    { 0, 0, 0, 0 },
2857
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), 0 } },
2858
    & ifmt_m_sra, { 0x7 }
2859
  },
2860
/* srl $rd,$rt,$rs */
2861
  {
2862
    { 0, 0, 0, 0 },
2863
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (RS), 0 } },
2864
    & ifmt_m_srl, { 0x6 }
2865
  },
2866
/* not $rd,$rt */
2867
  {
2868
    { 0, 0, 0, 0 },
2869
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
2870
    & ifmt_not, { 0x27 }
2871
  },
2872
/* subi $rt,$rs,$mlo16 */
2873
  {
2874
    { 0, 0, 0, 0 },
2875
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (MLO16), 0 } },
2876
    & ifmt_subi, { 0x24000000 }
2877
  },
2878
/* sub $rt,$rs,$mlo16 */
2879
  {
2880
    { 0, 0, 0, 0 },
2881
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (MLO16), 0 } },
2882
    & ifmt_m_sub, { 0x24000000 }
2883
  },
2884
/* subu $rt,$rs,$mlo16 */
2885
  {
2886
    { 0, 0, 0, 0 },
2887
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (MLO16), 0 } },
2888
    & ifmt_m_subu, { 0x24000000 }
2889
  },
2890
/* sb $rt,$lo16 */
2891
  {
2892
    { 0, 0, 0, 0 },
2893
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2894
    & ifmt_sb_base_0, { 0xa0000000 }
2895
  },
2896
/* sh $rt,$lo16 */
2897
  {
2898
    { 0, 0, 0, 0 },
2899
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2900
    & ifmt_sh_base_0, { 0xa4000000 }
2901
  },
2902
/* sw $rt,$lo16 */
2903
  {
2904
    { 0, 0, 0, 0 },
2905
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2906
    & ifmt_sw_base_0, { 0xac000000 }
2907
  },
2908
/* xor $rt,$rs,$lo16 */
2909
  {
2910
    { 0, 0, 0, 0 },
2911
    { { MNEM, ' ', OP (RT), ',', OP (RS), ',', OP (LO16), 0 } },
2912
    & ifmt_m_xor, { 0x38000000 }
2913
  },
2914
/* ldw $rt,$lo16 */
2915
  {
2916
    { 0, 0, 0, 0 },
2917
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2918
    & ifmt_ldw_base_0, { 0xc0000000 }
2919
  },
2920
/* sdw $rt,$lo16 */
2921
  {
2922
    { 0, 0, 0, 0 },
2923
    { { MNEM, ' ', OP (RT), ',', OP (LO16), 0 } },
2924
    & ifmt_sdw_base_0, { 0xe0000000 }
2925
  },
2926
/* avail */
2927
  {
2928
    { 0, 0, 0, 0 },
2929
    { { MNEM, 0 } },
2930
    & ifmt_m_avail, { 0x4c000024 }
2931
  },
2932
/* cam36 $rd,$rt,${cam-z} */
2933
  {
2934
    { 0, 0, 0, 0 },
2935
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Z), 0 } },
2936
    & ifmt_m_cam36, { 0x4c000400 }
2937
  },
2938
/* cam72 $rd,$rt,${cam-z} */
2939
  {
2940
    { 0, 0, 0, 0 },
2941
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Z), 0 } },
2942
    & ifmt_m_cam72, { 0x4c000440 }
2943
  },
2944
/* cam144 $rd,$rt,${cam-z} */
2945
  {
2946
    { 0, 0, 0, 0 },
2947
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Z), 0 } },
2948
    & ifmt_m_cam144, { 0x4c000480 }
2949
  },
2950
/* cam288 $rd,$rt,${cam-z} */
2951
  {
2952
    { 0, 0, 0, 0 },
2953
    { { MNEM, ' ', OP (RD), ',', OP (RT), ',', OP (CAM_Z), 0 } },
2954
    & ifmt_m_cam288, { 0x4c0004c0 }
2955
  },
2956
/* cm32read $rd,$rt */
2957
  {
2958
    { 0, 0, 0, 0 },
2959
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
2960
    & ifmt_m_cm32read, { 0x4c0000b0 }
2961
  },
2962
/* cm64read $rd,$rt */
2963
  {
2964
    { 0, 0, 0, 0 },
2965
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
2966
    & ifmt_m_cm64read, { 0x4c000090 }
2967
  },
2968
/* cm32mlog $rs,$rt */
2969
  {
2970
    { 0, 0, 0, 0 },
2971
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
2972
    & ifmt_m_cm32mlog, { 0x4c0000aa }
2973
  },
2974
/* cm32and $rs,$rt */
2975
  {
2976
    { 0, 0, 0, 0 },
2977
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
2978
    & ifmt_m_cm32and, { 0x4c0000ab }
2979
  },
2980
/* cm32andn $rs,$rt */
2981
  {
2982
    { 0, 0, 0, 0 },
2983
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
2984
    & ifmt_m_cm32andn, { 0x4c0000a3 }
2985
  },
2986
/* cm32or $rs,$rt */
2987
  {
2988
    { 0, 0, 0, 0 },
2989
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
2990
    & ifmt_m_cm32or, { 0x4c0000aa }
2991
  },
2992
/* cm32ra $rs,$rt */
2993
  {
2994
    { 0, 0, 0, 0 },
2995
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
2996
    & ifmt_m_cm32ra, { 0x4c0000b0 }
2997
  },
2998
/* cm32rd $rt */
2999
  {
3000
    { 0, 0, 0, 0 },
3001
    { { MNEM, ' ', OP (RT), 0 } },
3002
    & ifmt_m_cm32rd, { 0x4c0000a1 }
3003
  },
3004
/* cm32ri $rt */
3005
  {
3006
    { 0, 0, 0, 0 },
3007
    { { MNEM, ' ', OP (RT), 0 } },
3008
    & ifmt_m_cm32ri, { 0x4c0000a4 }
3009
  },
3010
/* cm32rs $rs,$rt */
3011
  {
3012
    { 0, 0, 0, 0 },
3013
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3014
    & ifmt_m_cm32rs, { 0x4c0000a0 }
3015
  },
3016
/* cm32sa $rs,$rt */
3017
  {
3018
    { 0, 0, 0, 0 },
3019
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3020
    & ifmt_m_cm32sa, { 0x4c0000b8 }
3021
  },
3022
/* cm32sd $rt */
3023
  {
3024
    { 0, 0, 0, 0 },
3025
    { { MNEM, ' ', OP (RT), 0 } },
3026
    & ifmt_m_cm32sd, { 0x4c0000a9 }
3027
  },
3028
/* cm32si $rt */
3029
  {
3030
    { 0, 0, 0, 0 },
3031
    { { MNEM, ' ', OP (RT), 0 } },
3032
    & ifmt_m_cm32si, { 0x4c0000ac }
3033
  },
3034
/* cm32ss $rs,$rt */
3035
  {
3036
    { 0, 0, 0, 0 },
3037
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3038
    & ifmt_m_cm32ss, { 0x4c0000a8 }
3039
  },
3040
/* cm32xor $rs,$rt */
3041
  {
3042
    { 0, 0, 0, 0 },
3043
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3044
    & ifmt_m_cm32xor, { 0x4c0000a2 }
3045
  },
3046
/* cm64clr $rt */
3047
  {
3048
    { 0, 0, 0, 0 },
3049
    { { MNEM, ' ', OP (RT), 0 } },
3050
    & ifmt_m_cm64clr, { 0x4c000085 }
3051
  },
3052
/* cm64ra $rs,$rt */
3053
  {
3054
    { 0, 0, 0, 0 },
3055
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3056
    & ifmt_m_cm64ra, { 0x4c000090 }
3057
  },
3058
/* cm64rd $rt */
3059
  {
3060
    { 0, 0, 0, 0 },
3061
    { { MNEM, ' ', OP (RT), 0 } },
3062
    & ifmt_m_cm64rd, { 0x4c000081 }
3063
  },
3064
/* cm64ri $rt */
3065
  {
3066
    { 0, 0, 0, 0 },
3067
    { { MNEM, ' ', OP (RT), 0 } },
3068
    & ifmt_m_cm64ri, { 0x4c000084 }
3069
  },
3070
/* cm64ria2 $rs,$rt */
3071
  {
3072
    { 0, 0, 0, 0 },
3073
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3074
    & ifmt_m_cm64ria2, { 0x4c000094 }
3075
  },
3076
/* cm64rs $rs,$rt */
3077
  {
3078
    { 0, 0, 0, 0 },
3079
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3080
    & ifmt_m_cm64rs, { 0x4c000080 }
3081
  },
3082
/* cm64sa $rs,$rt */
3083
  {
3084
    { 0, 0, 0, 0 },
3085
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3086
    & ifmt_m_cm64sa, { 0x4c000098 }
3087
  },
3088
/* cm64sd $rt */
3089
  {
3090
    { 0, 0, 0, 0 },
3091
    { { MNEM, ' ', OP (RT), 0 } },
3092
    & ifmt_m_cm64sd, { 0x4c000089 }
3093
  },
3094
/* cm64si $rt */
3095
  {
3096
    { 0, 0, 0, 0 },
3097
    { { MNEM, ' ', OP (RT), 0 } },
3098
    & ifmt_m_cm64si, { 0x4c00008c }
3099
  },
3100
/* cm64sia2 $rs,$rt */
3101
  {
3102
    { 0, 0, 0, 0 },
3103
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3104
    & ifmt_m_cm64sia2, { 0x4c00009c }
3105
  },
3106
/* cm64ss $rs,$rt */
3107
  {
3108
    { 0, 0, 0, 0 },
3109
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3110
    & ifmt_m_cm64ss, { 0x4c000088 }
3111
  },
3112
/* cm128ria2 $rs,$rt */
3113
  {
3114
    { 0, 0, 0, 0 },
3115
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3116
    & ifmt_m_cm128ria2, { 0x4c000095 }
3117
  },
3118
/* cm128ria3 $rs,$rt,${cm-3z} */
3119
  {
3120
    { 0, 0, 0, 0 },
3121
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (CM_3Z), 0 } },
3122
    & ifmt_m_cm128ria3, { 0x4c000090 }
3123
  },
3124
/* cm128ria4 $rs,$rt,${cm-4z} */
3125
  {
3126
    { 0, 0, 0, 0 },
3127
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (CM_4Z), 0 } },
3128
    & ifmt_m_cm128ria4, { 0x4c0000b0 }
3129
  },
3130
/* cm128sia2 $rs,$rt */
3131
  {
3132
    { 0, 0, 0, 0 },
3133
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3134
    & ifmt_m_cm128sia2, { 0x4c00009d }
3135
  },
3136
/* cm128sia3 $rs,$rt,${cm-3z} */
3137
  {
3138
    { 0, 0, 0, 0 },
3139
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (CM_3Z), 0 } },
3140
    & ifmt_m_cm128sia3, { 0x4c000098 }
3141
  },
3142
/* cm128sia4 $rs,$rt,${cm-4z} */
3143
  {
3144
    { 0, 0, 0, 0 },
3145
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (CM_4Z), 0 } },
3146
    & ifmt_m_cm128sia4, { 0x4c0000b8 }
3147
  },
3148
/* cmphdr */
3149
  {
3150
    { 0, 0, 0, 0 },
3151
    { { MNEM, 0 } },
3152
    & ifmt_m_cmphdr, { 0x4c00002c }
3153
  },
3154
/* dbd $rd,$rt */
3155
  {
3156
    { 0, 0, 0, 0 },
3157
    { { MNEM, ' ', OP (RD), ',', OP (RT), 0 } },
3158
    & ifmt_m_dbd, { 0x4c000021 }
3159
  },
3160
/* dbd $rt */
3161
  {
3162
    { 0, 0, 0, 0 },
3163
    { { MNEM, ' ', OP (RT), 0 } },
3164
    & ifmt_m2_dbd, { 0x4c000021 }
3165
  },
3166
/* dpwt $rs */
3167
  {
3168
    { 0, 0, 0, 0 },
3169
    { { MNEM, ' ', OP (RS), 0 } },
3170
    & ifmt_m_dpwt, { 0x4c000023 }
3171
  },
3172
/* free $rs */
3173
  {
3174
    { 0, 0, 0, 0 },
3175
    { { MNEM, ' ', OP (RS), 0 } },
3176
    & ifmt_m_free, { 0x4c000025 }
3177
  },
3178
/* lock $rt */
3179
  {
3180
    { 0, 0, 0, 0 },
3181
    { { MNEM, ' ', OP (RT), 0 } },
3182
    & ifmt_m_lock, { 0x4c000001 }
3183
  },
3184
/* pkrla $rs,$rt */
3185
  {
3186
    { 0, 0, 0, 0 },
3187
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3188
    & ifmt_m_pkrla, { 0x4c000028 }
3189
  },
3190
/* pkrlac $rs,$rt */
3191
  {
3192
    { 0, 0, 0, 0 },
3193
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3194
    & ifmt_m_pkrlac, { 0x4c00002b }
3195
  },
3196
/* pkrlah $rs,$rt */
3197
  {
3198
    { 0, 0, 0, 0 },
3199
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3200
    & ifmt_m_pkrlah, { 0x4c00002a }
3201
  },
3202
/* pkrlau $rs,$rt */
3203
  {
3204
    { 0, 0, 0, 0 },
3205
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3206
    & ifmt_m_pkrlau, { 0x4c000029 }
3207
  },
3208
/* pkrli $rs,$rt,$bytecount */
3209
  {
3210
    { 0, 0, 0, 0 },
3211
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3212
    & ifmt_m_pkrli, { 0x48000000 }
3213
  },
3214
/* pkrlic $rs,$rt,$bytecount */
3215
  {
3216
    { 0, 0, 0, 0 },
3217
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3218
    & ifmt_m_pkrlic, { 0x48000300 }
3219
  },
3220
/* pkrlih $rs,$rt,$bytecount */
3221
  {
3222
    { 0, 0, 0, 0 },
3223
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3224
    & ifmt_m_pkrlih, { 0x48000200 }
3225
  },
3226
/* pkrliu $rs,$rt,$bytecount */
3227
  {
3228
    { 0, 0, 0, 0 },
3229
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3230
    & ifmt_m_pkrliu, { 0x48000100 }
3231
  },
3232
/* rba $rs,$rt */
3233
  {
3234
    { 0, 0, 0, 0 },
3235
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3236
    & ifmt_m_rba, { 0x4c000008 }
3237
  },
3238
/* rbal $rs,$rt */
3239
  {
3240
    { 0, 0, 0, 0 },
3241
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3242
    & ifmt_m_rbal, { 0x4c000009 }
3243
  },
3244
/* rbar $rs,$rt */
3245
  {
3246
    { 0, 0, 0, 0 },
3247
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3248
    & ifmt_m_rbar, { 0x4c00000a }
3249
  },
3250
/* rbi $rs,$rt,$bytecount */
3251
  {
3252
    { 0, 0, 0, 0 },
3253
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3254
    & ifmt_m_rbi, { 0x4c000200 }
3255
  },
3256
/* rbil $rs,$rt,$bytecount */
3257
  {
3258
    { 0, 0, 0, 0 },
3259
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3260
    & ifmt_m_rbil, { 0x4c000300 }
3261
  },
3262
/* rbir $rs,$rt,$bytecount */
3263
  {
3264
    { 0, 0, 0, 0 },
3265
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3266
    & ifmt_m_rbir, { 0x4c000100 }
3267
  },
3268
/* swwr $rs,$rt */
3269
  {
3270
    { 0, 0, 0, 0 },
3271
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3272
    & ifmt_m_swwr, { 0x4c000006 }
3273
  },
3274
/* swwru $rs,$rt */
3275
  {
3276
    { 0, 0, 0, 0 },
3277
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3278
    & ifmt_m_swwru, { 0x4c000007 }
3279
  },
3280
/* tstod $rs */
3281
  {
3282
    { 0, 0, 0, 0 },
3283
    { { MNEM, ' ', OP (RS), 0 } },
3284
    & ifmt_m_tstod, { 0x4c000027 }
3285
  },
3286
/* unlk $rt */
3287
  {
3288
    { 0, 0, 0, 0 },
3289
    { { MNEM, ' ', OP (RT), 0 } },
3290
    & ifmt_m_unlk, { 0x4c000003 }
3291
  },
3292
/* wba $rs,$rt */
3293
  {
3294
    { 0, 0, 0, 0 },
3295
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3296
    & ifmt_m_wba, { 0x4c000010 }
3297
  },
3298
/* wbac $rs,$rt */
3299
  {
3300
    { 0, 0, 0, 0 },
3301
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3302
    & ifmt_m_wbac, { 0x4c000012 }
3303
  },
3304
/* wbau $rs,$rt */
3305
  {
3306
    { 0, 0, 0, 0 },
3307
    { { MNEM, ' ', OP (RS), ',', OP (RT), 0 } },
3308
    & ifmt_m_wbau, { 0x4c000011 }
3309
  },
3310
/* wbi $rs,$rt,$bytecount */
3311
  {
3312
    { 0, 0, 0, 0 },
3313
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3314
    & ifmt_m_wbi, { 0x4c000600 }
3315
  },
3316
/* wbic $rs,$rt,$bytecount */
3317
  {
3318
    { 0, 0, 0, 0 },
3319
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3320
    & ifmt_m_wbic, { 0x4c000500 }
3321
  },
3322
/* wbiu $rs,$rt,$bytecount */
3323
  {
3324
    { 0, 0, 0, 0 },
3325
    { { MNEM, ' ', OP (RS), ',', OP (RT), ',', OP (BYTECOUNT), 0 } },
3326
    & ifmt_m_wbiu, { 0x4c000700 }
3327
  },
3328
};
3329
 
3330
#undef A
3331
#undef OPERAND
3332
#undef MNEM
3333
#undef OP
3334
 
3335
#ifndef CGEN_ASM_HASH_P
3336
#define CGEN_ASM_HASH_P(insn) 1
3337
#endif
3338
 
3339
#ifndef CGEN_DIS_HASH_P
3340
#define CGEN_DIS_HASH_P(insn) 1
3341
#endif
3342
 
3343
/* Return non-zero if INSN is to be added to the hash table.
3344
   Targets are free to override CGEN_{ASM,DIS}_HASH_P in the .opc file.  */
3345
 
3346
static int
3347
asm_hash_insn_p (insn)
3348
     const CGEN_INSN *insn ATTRIBUTE_UNUSED;
3349
{
3350
  return CGEN_ASM_HASH_P (insn);
3351
}
3352
 
3353
static int
3354
dis_hash_insn_p (insn)
3355
     const CGEN_INSN *insn;
3356
{
3357
  /* If building the hash table and the NO-DIS attribute is present,
3358
     ignore.  */
3359
  if (CGEN_INSN_ATTR_VALUE (insn, CGEN_INSN_NO_DIS))
3360
    return 0;
3361
  return CGEN_DIS_HASH_P (insn);
3362
}
3363
 
3364
#ifndef CGEN_ASM_HASH
3365
#define CGEN_ASM_HASH_SIZE 127
3366
#ifdef CGEN_MNEMONIC_OPERANDS
3367
#define CGEN_ASM_HASH(mnem) (*(unsigned char *) (mnem) % CGEN_ASM_HASH_SIZE)
3368
#else
3369
#define CGEN_ASM_HASH(mnem) (*(unsigned char *) (mnem) % CGEN_ASM_HASH_SIZE) /*FIXME*/
3370
#endif
3371
#endif
3372
 
3373
/* It doesn't make much sense to provide a default here,
3374
   but while this is under development we do.
3375
   BUFFER is a pointer to the bytes of the insn, target order.
3376
   VALUE is the first base_insn_bitsize bits as an int in host order.  */
3377
 
3378
#ifndef CGEN_DIS_HASH
3379
#define CGEN_DIS_HASH_SIZE 256
3380
#define CGEN_DIS_HASH(buf, value) (*(unsigned char *) (buf))
3381
#endif
3382
 
3383
/* The result is the hash value of the insn.
3384
   Targets are free to override CGEN_{ASM,DIS}_HASH in the .opc file.  */
3385
 
3386
static unsigned int
3387
asm_hash_insn (mnem)
3388
     const char * mnem;
3389
{
3390
  return CGEN_ASM_HASH (mnem);
3391
}
3392
 
3393
/* BUF is a pointer to the bytes of the insn, target order.
3394
   VALUE is the first base_insn_bitsize bits as an int in host order.  */
3395
 
3396
static unsigned int
3397
dis_hash_insn (buf, value)
3398
     const char * buf ATTRIBUTE_UNUSED;
3399
     CGEN_INSN_INT value ATTRIBUTE_UNUSED;
3400
{
3401
  return CGEN_DIS_HASH (buf, value);
3402
}
3403
 
3404
/* Set the recorded length of the insn in the CGEN_FIELDS struct.  */
3405
 
3406
static void
3407
set_fields_bitsize (CGEN_FIELDS *fields, int size)
3408
{
3409
  CGEN_FIELDS_BITSIZE (fields) = size;
3410
}
3411
 
3412
/* Function to call before using the operand instance table.
3413
   This plugs the opcode entries and macro instructions into the cpu table.  */
3414
 
3415
void
3416
iq2000_cgen_init_opcode_table (CGEN_CPU_DESC cd)
3417
{
3418
  int i;
3419
  int num_macros = (sizeof (iq2000_cgen_macro_insn_table) /
3420
                    sizeof (iq2000_cgen_macro_insn_table[0]));
3421
  const CGEN_IBASE *ib = & iq2000_cgen_macro_insn_table[0];
3422
  const CGEN_OPCODE *oc = & iq2000_cgen_macro_insn_opcode_table[0];
3423
  CGEN_INSN *insns = xmalloc (num_macros * sizeof (CGEN_INSN));
3424
 
3425
  /* This test has been added to avoid a warning generated
3426
     if memset is called with a third argument of value zero.  */
3427
  if (num_macros >= 1)
3428
    memset (insns, 0, num_macros * sizeof (CGEN_INSN));
3429
  for (i = 0; i < num_macros; ++i)
3430
    {
3431
      insns[i].base = &ib[i];
3432
      insns[i].opcode = &oc[i];
3433
      iq2000_cgen_build_insn_regex (& insns[i]);
3434
    }
3435
  cd->macro_insn_table.init_entries = insns;
3436
  cd->macro_insn_table.entry_size = sizeof (CGEN_IBASE);
3437
  cd->macro_insn_table.num_init_entries = num_macros;
3438
 
3439
  oc = & iq2000_cgen_insn_opcode_table[0];
3440
  insns = (CGEN_INSN *) cd->insn_table.init_entries;
3441
  for (i = 0; i < MAX_INSNS; ++i)
3442
    {
3443
      insns[i].opcode = &oc[i];
3444
      iq2000_cgen_build_insn_regex (& insns[i]);
3445
    }
3446
 
3447
  cd->sizeof_fields = sizeof (CGEN_FIELDS);
3448
  cd->set_fields_bitsize = set_fields_bitsize;
3449
 
3450
  cd->asm_hash_p = asm_hash_insn_p;
3451
  cd->asm_hash = asm_hash_insn;
3452
  cd->asm_hash_size = CGEN_ASM_HASH_SIZE;
3453
 
3454
  cd->dis_hash_p = dis_hash_insn_p;
3455
  cd->dis_hash = dis_hash_insn;
3456
  cd->dis_hash_size = CGEN_DIS_HASH_SIZE;
3457
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.