* ldemul.h: Forward declare struct option.
[binutils.git] / opcodes / iq2000-desc.c
blob56974aebeb3def755e270c33cf4c01e42af4aa8b
1 /* CPU data for iq2000.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright 1996-2004 Free Software Foundation, Inc.
7 This file is part of the GNU Binutils and/or GDB, the GNU debugger.
9 This program 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 2, or (at your option)
12 any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
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 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
25 #include "sysdep.h"
26 #include <stdio.h>
27 #include <stdarg.h>
28 #include "ansidecl.h"
29 #include "bfd.h"
30 #include "symcat.h"
31 #include "iq2000-desc.h"
32 #include "iq2000-opc.h"
33 #include "opintl.h"
34 #include "libiberty.h"
35 #include "xregex.h"
37 /* Attributes. */
39 static const CGEN_ATTR_ENTRY bool_attr[] =
41 { "#f", 0 },
42 { "#t", 1 },
43 { 0, 0 }
46 static const CGEN_ATTR_ENTRY MACH_attr[] =
48 { "base", MACH_BASE },
49 { "iq2000", MACH_IQ2000 },
50 { "iq10", MACH_IQ10 },
51 { "max", MACH_MAX },
52 { 0, 0 }
55 static const CGEN_ATTR_ENTRY ISA_attr[] =
57 { "iq2000", ISA_IQ2000 },
58 { "max", ISA_MAX },
59 { 0, 0 }
62 const CGEN_ATTR_TABLE iq2000_cgen_ifield_attr_table[] =
64 { "MACH", & MACH_attr[0], & MACH_attr[0] },
65 { "VIRTUAL", &bool_attr[0], &bool_attr[0] },
66 { "PCREL-ADDR", &bool_attr[0], &bool_attr[0] },
67 { "ABS-ADDR", &bool_attr[0], &bool_attr[0] },
68 { "RESERVED", &bool_attr[0], &bool_attr[0] },
69 { "SIGN-OPT", &bool_attr[0], &bool_attr[0] },
70 { "SIGNED", &bool_attr[0], &bool_attr[0] },
71 { 0, 0, 0 }
74 const CGEN_ATTR_TABLE iq2000_cgen_hardware_attr_table[] =
76 { "MACH", & MACH_attr[0], & MACH_attr[0] },
77 { "VIRTUAL", &bool_attr[0], &bool_attr[0] },
78 { "CACHE-ADDR", &bool_attr[0], &bool_attr[0] },
79 { "PC", &bool_attr[0], &bool_attr[0] },
80 { "PROFILE", &bool_attr[0], &bool_attr[0] },
81 { 0, 0, 0 }
84 const CGEN_ATTR_TABLE iq2000_cgen_operand_attr_table[] =
86 { "MACH", & MACH_attr[0], & MACH_attr[0] },
87 { "VIRTUAL", &bool_attr[0], &bool_attr[0] },
88 { "PCREL-ADDR", &bool_attr[0], &bool_attr[0] },
89 { "ABS-ADDR", &bool_attr[0], &bool_attr[0] },
90 { "SIGN-OPT", &bool_attr[0], &bool_attr[0] },
91 { "SIGNED", &bool_attr[0], &bool_attr[0] },
92 { "NEGATIVE", &bool_attr[0], &bool_attr[0] },
93 { "RELAX", &bool_attr[0], &bool_attr[0] },
94 { "SEM-ONLY", &bool_attr[0], &bool_attr[0] },
95 { 0, 0, 0 }
98 const CGEN_ATTR_TABLE iq2000_cgen_insn_attr_table[] =
100 { "MACH", & MACH_attr[0], & MACH_attr[0] },
101 { "ALIAS", &bool_attr[0], &bool_attr[0] },
102 { "VIRTUAL", &bool_attr[0], &bool_attr[0] },
103 { "UNCOND-CTI", &bool_attr[0], &bool_attr[0] },
104 { "COND-CTI", &bool_attr[0], &bool_attr[0] },
105 { "SKIP-CTI", &bool_attr[0], &bool_attr[0] },
106 { "DELAY-SLOT", &bool_attr[0], &bool_attr[0] },
107 { "RELAXABLE", &bool_attr[0], &bool_attr[0] },
108 { "RELAXED", &bool_attr[0], &bool_attr[0] },
109 { "NO-DIS", &bool_attr[0], &bool_attr[0] },
110 { "PBB", &bool_attr[0], &bool_attr[0] },
111 { "YIELD-INSN", &bool_attr[0], &bool_attr[0] },
112 { "LOAD-DELAY", &bool_attr[0], &bool_attr[0] },
113 { "EVEN-REG-NUM", &bool_attr[0], &bool_attr[0] },
114 { "UNSUPPORTED", &bool_attr[0], &bool_attr[0] },
115 { "USES-RD", &bool_attr[0], &bool_attr[0] },
116 { "USES-RS", &bool_attr[0], &bool_attr[0] },
117 { "USES-RT", &bool_attr[0], &bool_attr[0] },
118 { "USES-R31", &bool_attr[0], &bool_attr[0] },
119 { 0, 0, 0 }
122 /* Instruction set variants. */
124 static const CGEN_ISA iq2000_cgen_isa_table[] = {
125 { "iq2000", 32, 32, 32, 32 },
126 { 0, 0, 0, 0, 0 }
129 /* Machine variants. */
131 static const CGEN_MACH iq2000_cgen_mach_table[] = {
132 { "iq2000", "iq2000", MACH_IQ2000, 0 },
133 { "iq10", "iq10", MACH_IQ10, 0 },
134 { 0, 0, 0, 0 }
137 static CGEN_KEYWORD_ENTRY iq2000_cgen_opval_gr_names_entries[] =
139 { "r0", 0, {0, {0}}, 0, 0 },
140 { "%0", 0, {0, {0}}, 0, 0 },
141 { "r1", 1, {0, {0}}, 0, 0 },
142 { "%1", 1, {0, {0}}, 0, 0 },
143 { "r2", 2, {0, {0}}, 0, 0 },
144 { "%2", 2, {0, {0}}, 0, 0 },
145 { "r3", 3, {0, {0}}, 0, 0 },
146 { "%3", 3, {0, {0}}, 0, 0 },
147 { "r4", 4, {0, {0}}, 0, 0 },
148 { "%4", 4, {0, {0}}, 0, 0 },
149 { "r5", 5, {0, {0}}, 0, 0 },
150 { "%5", 5, {0, {0}}, 0, 0 },
151 { "r6", 6, {0, {0}}, 0, 0 },
152 { "%6", 6, {0, {0}}, 0, 0 },
153 { "r7", 7, {0, {0}}, 0, 0 },
154 { "%7", 7, {0, {0}}, 0, 0 },
155 { "r8", 8, {0, {0}}, 0, 0 },
156 { "%8", 8, {0, {0}}, 0, 0 },
157 { "r9", 9, {0, {0}}, 0, 0 },
158 { "%9", 9, {0, {0}}, 0, 0 },
159 { "r10", 10, {0, {0}}, 0, 0 },
160 { "%10", 10, {0, {0}}, 0, 0 },
161 { "r11", 11, {0, {0}}, 0, 0 },
162 { "%11", 11, {0, {0}}, 0, 0 },
163 { "r12", 12, {0, {0}}, 0, 0 },
164 { "%12", 12, {0, {0}}, 0, 0 },
165 { "r13", 13, {0, {0}}, 0, 0 },
166 { "%13", 13, {0, {0}}, 0, 0 },
167 { "r14", 14, {0, {0}}, 0, 0 },
168 { "%14", 14, {0, {0}}, 0, 0 },
169 { "r15", 15, {0, {0}}, 0, 0 },
170 { "%15", 15, {0, {0}}, 0, 0 },
171 { "r16", 16, {0, {0}}, 0, 0 },
172 { "%16", 16, {0, {0}}, 0, 0 },
173 { "r17", 17, {0, {0}}, 0, 0 },
174 { "%17", 17, {0, {0}}, 0, 0 },
175 { "r18", 18, {0, {0}}, 0, 0 },
176 { "%18", 18, {0, {0}}, 0, 0 },
177 { "r19", 19, {0, {0}}, 0, 0 },
178 { "%19", 19, {0, {0}}, 0, 0 },
179 { "r20", 20, {0, {0}}, 0, 0 },
180 { "%20", 20, {0, {0}}, 0, 0 },
181 { "r21", 21, {0, {0}}, 0, 0 },
182 { "%21", 21, {0, {0}}, 0, 0 },
183 { "r22", 22, {0, {0}}, 0, 0 },
184 { "%22", 22, {0, {0}}, 0, 0 },
185 { "r23", 23, {0, {0}}, 0, 0 },
186 { "%23", 23, {0, {0}}, 0, 0 },
187 { "r24", 24, {0, {0}}, 0, 0 },
188 { "%24", 24, {0, {0}}, 0, 0 },
189 { "r25", 25, {0, {0}}, 0, 0 },
190 { "%25", 25, {0, {0}}, 0, 0 },
191 { "r26", 26, {0, {0}}, 0, 0 },
192 { "%26", 26, {0, {0}}, 0, 0 },
193 { "r27", 27, {0, {0}}, 0, 0 },
194 { "%27", 27, {0, {0}}, 0, 0 },
195 { "r28", 28, {0, {0}}, 0, 0 },
196 { "%28", 28, {0, {0}}, 0, 0 },
197 { "r29", 29, {0, {0}}, 0, 0 },
198 { "%29", 29, {0, {0}}, 0, 0 },
199 { "r30", 30, {0, {0}}, 0, 0 },
200 { "%30", 30, {0, {0}}, 0, 0 },
201 { "r31", 31, {0, {0}}, 0, 0 },
202 { "%31", 31, {0, {0}}, 0, 0 }
205 CGEN_KEYWORD iq2000_cgen_opval_gr_names =
207 & iq2000_cgen_opval_gr_names_entries[0],
209 0, 0, 0, 0, ""
213 /* The hardware table. */
215 #if defined (__STDC__) || defined (ALMOST_STDC) || defined (HAVE_STRINGIZE)
216 #define A(a) (1 << CGEN_HW_##a)
217 #else
218 #define A(a) (1 << CGEN_HW_/**/a)
219 #endif
221 const CGEN_HW_ENTRY iq2000_cgen_hw_table[] =
223 { "h-memory", HW_H_MEMORY, CGEN_ASM_NONE, 0, { 0, { (1<<MACH_BASE) } } },
224 { "h-sint", HW_H_SINT, CGEN_ASM_NONE, 0, { 0, { (1<<MACH_BASE) } } },
225 { "h-uint", HW_H_UINT, CGEN_ASM_NONE, 0, { 0, { (1<<MACH_BASE) } } },
226 { "h-addr", HW_H_ADDR, CGEN_ASM_NONE, 0, { 0, { (1<<MACH_BASE) } } },
227 { "h-iaddr", HW_H_IADDR, CGEN_ASM_NONE, 0, { 0, { (1<<MACH_BASE) } } },
228 { "h-pc", HW_H_PC, CGEN_ASM_NONE, 0, { 0|A(PROFILE)|A(PC), { (1<<MACH_BASE) } } },
229 { "h-gr", HW_H_GR, CGEN_ASM_KEYWORD, (PTR) & iq2000_cgen_opval_gr_names, { 0, { (1<<MACH_BASE) } } },
230 { 0, 0, CGEN_ASM_NONE, 0, {0, {0}} }
233 #undef A
236 /* The instruction field table. */
238 #if defined (__STDC__) || defined (ALMOST_STDC) || defined (HAVE_STRINGIZE)
239 #define A(a) (1 << CGEN_IFLD_##a)
240 #else
241 #define A(a) (1 << CGEN_IFLD_/**/a)
242 #endif
244 const CGEN_IFLD iq2000_cgen_ifld_table[] =
246 { IQ2000_F_NIL, "f-nil", 0, 0, 0, 0, { 0, { (1<<MACH_BASE) } } },
247 { IQ2000_F_ANYOF, "f-anyof", 0, 0, 0, 0, { 0, { (1<<MACH_BASE) } } },
248 { IQ2000_F_OPCODE, "f-opcode", 0, 32, 31, 6, { 0, { (1<<MACH_BASE) } } },
249 { IQ2000_F_RS, "f-rs", 0, 32, 25, 5, { 0, { (1<<MACH_BASE) } } },
250 { IQ2000_F_RT, "f-rt", 0, 32, 20, 5, { 0, { (1<<MACH_BASE) } } },
251 { IQ2000_F_RD, "f-rd", 0, 32, 15, 5, { 0, { (1<<MACH_BASE) } } },
252 { IQ2000_F_SHAMT, "f-shamt", 0, 32, 10, 5, { 0, { (1<<MACH_BASE) } } },
253 { IQ2000_F_CP_OP, "f-cp-op", 0, 32, 10, 3, { 0, { (1<<MACH_BASE) } } },
254 { IQ2000_F_CP_OP_10, "f-cp-op-10", 0, 32, 10, 5, { 0, { (1<<MACH_BASE) } } },
255 { IQ2000_F_CP_GRP, "f-cp-grp", 0, 32, 7, 2, { 0, { (1<<MACH_BASE) } } },
256 { IQ2000_F_FUNC, "f-func", 0, 32, 5, 6, { 0, { (1<<MACH_BASE) } } },
257 { IQ2000_F_IMM, "f-imm", 0, 32, 15, 16, { 0, { (1<<MACH_BASE) } } },
258 { IQ2000_F_RD_RS, "f-rd-rs", 0, 0, 0, 0,{ 0|A(VIRTUAL), { (1<<MACH_BASE) } } },
259 { IQ2000_F_RD_RT, "f-rd-rt", 0, 0, 0, 0,{ 0|A(VIRTUAL), { (1<<MACH_BASE) } } },
260 { IQ2000_F_RT_RS, "f-rt-rs", 0, 0, 0, 0,{ 0|A(VIRTUAL), { (1<<MACH_BASE) } } },
261 { IQ2000_F_JTARG, "f-jtarg", 0, 32, 15, 16, { 0|A(ABS_ADDR), { (1<<MACH_BASE) } } },
262 { IQ2000_F_JTARGQ10, "f-jtargq10", 0, 32, 20, 21, { 0|A(ABS_ADDR), { (1<<MACH_BASE) } } },
263 { IQ2000_F_OFFSET, "f-offset", 0, 32, 15, 16, { 0|A(PCREL_ADDR), { (1<<MACH_BASE) } } },
264 { IQ2000_F_COUNT, "f-count", 0, 32, 15, 7, { 0, { (1<<MACH_BASE) } } },
265 { IQ2000_F_BYTECOUNT, "f-bytecount", 0, 32, 7, 8, { 0, { (1<<MACH_BASE) } } },
266 { IQ2000_F_INDEX, "f-index", 0, 32, 8, 9, { 0, { (1<<MACH_BASE) } } },
267 { IQ2000_F_MASK, "f-mask", 0, 32, 9, 4, { 0, { (1<<MACH_BASE) } } },
268 { IQ2000_F_MASKQ10, "f-maskq10", 0, 32, 10, 5, { 0, { (1<<MACH_BASE) } } },
269 { IQ2000_F_MASKL, "f-maskl", 0, 32, 4, 5, { 0, { (1<<MACH_BASE) } } },
270 { IQ2000_F_EXCODE, "f-excode", 0, 32, 25, 20, { 0, { (1<<MACH_BASE) } } },
271 { IQ2000_F_RSRVD, "f-rsrvd", 0, 32, 25, 10, { 0, { (1<<MACH_BASE) } } },
272 { IQ2000_F_10_11, "f-10-11", 0, 32, 10, 11, { 0, { (1<<MACH_BASE) } } },
273 { IQ2000_F_24_19, "f-24-19", 0, 32, 24, 19, { 0, { (1<<MACH_BASE) } } },
274 { IQ2000_F_5, "f-5", 0, 32, 5, 1, { 0, { (1<<MACH_BASE) } } },
275 { IQ2000_F_10, "f-10", 0, 32, 10, 1, { 0, { (1<<MACH_BASE) } } },
276 { IQ2000_F_25, "f-25", 0, 32, 25, 1, { 0, { (1<<MACH_BASE) } } },
277 { IQ2000_F_CAM_Z, "f-cam-z", 0, 32, 5, 3, { 0, { (1<<MACH_BASE) } } },
278 { IQ2000_F_CAM_Y, "f-cam-y", 0, 32, 2, 3, { 0, { (1<<MACH_BASE) } } },
279 { IQ2000_F_CM_3FUNC, "f-cm-3func", 0, 32, 5, 3, { 0, { (1<<MACH_BASE) } } },
280 { IQ2000_F_CM_4FUNC, "f-cm-4func", 0, 32, 5, 4, { 0, { (1<<MACH_BASE) } } },
281 { IQ2000_F_CM_3Z, "f-cm-3z", 0, 32, 1, 2, { 0, { (1<<MACH_BASE) } } },
282 { IQ2000_F_CM_4Z, "f-cm-4z", 0, 32, 2, 3, { 0, { (1<<MACH_BASE) } } },
283 { 0, 0, 0, 0, 0, 0, {0, {0}} }
286 #undef A
290 /* multi ifield declarations */
292 const CGEN_MAYBE_MULTI_IFLD IQ2000_F_RD_RS_MULTI_IFIELD [];
293 const CGEN_MAYBE_MULTI_IFLD IQ2000_F_RD_RT_MULTI_IFIELD [];
294 const CGEN_MAYBE_MULTI_IFLD IQ2000_F_RT_RS_MULTI_IFIELD [];
297 /* multi ifield definitions */
299 const CGEN_MAYBE_MULTI_IFLD IQ2000_F_RD_RS_MULTI_IFIELD [] =
301 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RD] } },
302 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RS] } },
303 { 0, { (const PTR) 0 } }
305 const CGEN_MAYBE_MULTI_IFLD IQ2000_F_RD_RT_MULTI_IFIELD [] =
307 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RD] } },
308 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RT] } },
309 { 0, { (const PTR) 0 } }
311 const CGEN_MAYBE_MULTI_IFLD IQ2000_F_RT_RS_MULTI_IFIELD [] =
313 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RT] } },
314 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RS] } },
315 { 0, { (const PTR) 0 } }
318 /* The operand table. */
320 #if defined (__STDC__) || defined (ALMOST_STDC) || defined (HAVE_STRINGIZE)
321 #define A(a) (1 << CGEN_OPERAND_##a)
322 #else
323 #define A(a) (1 << CGEN_OPERAND_/**/a)
324 #endif
325 #if defined (__STDC__) || defined (ALMOST_STDC) || defined (HAVE_STRINGIZE)
326 #define OPERAND(op) IQ2000_OPERAND_##op
327 #else
328 #define OPERAND(op) IQ2000_OPERAND_/**/op
329 #endif
331 const CGEN_OPERAND iq2000_cgen_operand_table[] =
333 /* pc: program counter */
334 { "pc", IQ2000_OPERAND_PC, HW_H_PC, 0, 0,
335 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_NIL] } },
336 { 0|A(SEM_ONLY), { (1<<MACH_BASE) } } },
337 /* rs: register Rs */
338 { "rs", IQ2000_OPERAND_RS, HW_H_GR, 25, 5,
339 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RS] } },
340 { 0, { (1<<MACH_BASE) } } },
341 /* rt: register Rt */
342 { "rt", IQ2000_OPERAND_RT, HW_H_GR, 20, 5,
343 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RT] } },
344 { 0, { (1<<MACH_BASE) } } },
345 /* rd: register Rd */
346 { "rd", IQ2000_OPERAND_RD, HW_H_GR, 15, 5,
347 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RD] } },
348 { 0, { (1<<MACH_BASE) } } },
349 /* rd-rs: register Rd from Rs */
350 { "rd-rs", IQ2000_OPERAND_RD_RS, HW_H_GR, 15, 10,
351 { 2, { (const PTR) &IQ2000_F_RD_RS_MULTI_IFIELD[0] } },
352 { 0|A(VIRTUAL), { (1<<MACH_BASE) } } },
353 /* rd-rt: register Rd from Rt */
354 { "rd-rt", IQ2000_OPERAND_RD_RT, HW_H_GR, 15, 10,
355 { 2, { (const PTR) &IQ2000_F_RD_RT_MULTI_IFIELD[0] } },
356 { 0|A(VIRTUAL), { (1<<MACH_BASE) } } },
357 /* rt-rs: register Rt from Rs */
358 { "rt-rs", IQ2000_OPERAND_RT_RS, HW_H_GR, 20, 10,
359 { 2, { (const PTR) &IQ2000_F_RT_RS_MULTI_IFIELD[0] } },
360 { 0|A(VIRTUAL), { (1<<MACH_BASE) } } },
361 /* shamt: shift amount */
362 { "shamt", IQ2000_OPERAND_SHAMT, HW_H_UINT, 10, 5,
363 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_SHAMT] } },
364 { 0, { (1<<MACH_BASE) } } },
365 /* imm: immediate */
366 { "imm", IQ2000_OPERAND_IMM, HW_H_UINT, 15, 16,
367 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_IMM] } },
368 { 0, { (1<<MACH_BASE) } } },
369 /* offset: pc-relative offset */
370 { "offset", IQ2000_OPERAND_OFFSET, HW_H_IADDR, 15, 16,
371 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_OFFSET] } },
372 { 0|A(PCREL_ADDR), { (1<<MACH_BASE) } } },
373 /* baseoff: base register offset */
374 { "baseoff", IQ2000_OPERAND_BASEOFF, HW_H_IADDR, 15, 16,
375 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_IMM] } },
376 { 0, { (1<<MACH_BASE) } } },
377 /* jmptarg: jump target */
378 { "jmptarg", IQ2000_OPERAND_JMPTARG, HW_H_IADDR, 15, 16,
379 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_JTARG] } },
380 { 0|A(ABS_ADDR), { (1<<MACH_BASE) } } },
381 /* mask: mask */
382 { "mask", IQ2000_OPERAND_MASK, HW_H_UINT, 9, 4,
383 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_MASK] } },
384 { 0, { (1<<MACH_BASE) } } },
385 /* maskq10: iq10 mask */
386 { "maskq10", IQ2000_OPERAND_MASKQ10, HW_H_UINT, 10, 5,
387 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_MASKQ10] } },
388 { 0, { (1<<MACH_BASE) } } },
389 /* maskl: mask left */
390 { "maskl", IQ2000_OPERAND_MASKL, HW_H_UINT, 4, 5,
391 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_MASKL] } },
392 { 0, { (1<<MACH_BASE) } } },
393 /* count: count */
394 { "count", IQ2000_OPERAND_COUNT, HW_H_UINT, 15, 7,
395 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_COUNT] } },
396 { 0, { (1<<MACH_BASE) } } },
397 /* _index: index */
398 { "_index", IQ2000_OPERAND__INDEX, HW_H_UINT, 8, 9,
399 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_INDEX] } },
400 { 0, { (1<<MACH_BASE) } } },
401 /* execode: execcode */
402 { "execode", IQ2000_OPERAND_EXECODE, HW_H_UINT, 25, 20,
403 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_EXCODE] } },
404 { 0, { (1<<MACH_BASE) } } },
405 /* bytecount: byte count */
406 { "bytecount", IQ2000_OPERAND_BYTECOUNT, HW_H_UINT, 7, 8,
407 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_BYTECOUNT] } },
408 { 0, { (1<<MACH_BASE) } } },
409 /* cam-y: cam global opn y */
410 { "cam-y", IQ2000_OPERAND_CAM_Y, HW_H_UINT, 2, 3,
411 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_CAM_Y] } },
412 { 0, { (1<<MACH_BASE) } } },
413 /* cam-z: cam global mask z */
414 { "cam-z", IQ2000_OPERAND_CAM_Z, HW_H_UINT, 5, 3,
415 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_CAM_Z] } },
416 { 0, { (1<<MACH_BASE) } } },
417 /* cm-3func: CM 3 bit fn field */
418 { "cm-3func", IQ2000_OPERAND_CM_3FUNC, HW_H_UINT, 5, 3,
419 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_CM_3FUNC] } },
420 { 0, { (1<<MACH_BASE) } } },
421 /* cm-4func: CM 4 bit fn field */
422 { "cm-4func", IQ2000_OPERAND_CM_4FUNC, HW_H_UINT, 5, 4,
423 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_CM_4FUNC] } },
424 { 0, { (1<<MACH_BASE) } } },
425 /* cm-3z: CM 3 bit Z field */
426 { "cm-3z", IQ2000_OPERAND_CM_3Z, HW_H_UINT, 1, 2,
427 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_CM_3Z] } },
428 { 0, { (1<<MACH_BASE) } } },
429 /* cm-4z: CM 4 bit Z field */
430 { "cm-4z", IQ2000_OPERAND_CM_4Z, HW_H_UINT, 2, 3,
431 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_CM_4Z] } },
432 { 0, { (1<<MACH_BASE) } } },
433 /* base: base register */
434 { "base", IQ2000_OPERAND_BASE, HW_H_GR, 25, 5,
435 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RS] } },
436 { 0, { (1<<MACH_BASE) } } },
437 /* maskr: mask right */
438 { "maskr", IQ2000_OPERAND_MASKR, HW_H_UINT, 25, 5,
439 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RS] } },
440 { 0, { (1<<MACH_BASE) } } },
441 /* bitnum: bit number */
442 { "bitnum", IQ2000_OPERAND_BITNUM, HW_H_UINT, 20, 5,
443 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_RT] } },
444 { 0, { (1<<MACH_BASE) } } },
445 /* hi16: high 16 bit immediate */
446 { "hi16", IQ2000_OPERAND_HI16, HW_H_UINT, 15, 16,
447 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_IMM] } },
448 { 0, { (1<<MACH_BASE) } } },
449 /* lo16: 16 bit signed immediate, for low */
450 { "lo16", IQ2000_OPERAND_LO16, HW_H_UINT, 15, 16,
451 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_IMM] } },
452 { 0, { (1<<MACH_BASE) } } },
453 /* mlo16: negated 16 bit signed immediate */
454 { "mlo16", IQ2000_OPERAND_MLO16, HW_H_UINT, 15, 16,
455 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_IMM] } },
456 { 0, { (1<<MACH_BASE) } } },
457 /* jmptargq10: iq10 21-bit jump offset */
458 { "jmptargq10", IQ2000_OPERAND_JMPTARGQ10, HW_H_IADDR, 20, 21,
459 { 0, { (const PTR) &iq2000_cgen_ifld_table[IQ2000_F_JTARGQ10] } },
460 { 0|A(ABS_ADDR), { (1<<MACH_BASE) } } },
461 /* sentinel */
462 { 0, 0, 0, 0, 0,
463 { 0, { (const PTR) 0 } },
464 { 0, { 0 } } }
467 #undef A
470 /* The instruction table. */
472 #define OP(field) CGEN_SYNTAX_MAKE_FIELD (OPERAND (field))
473 #if defined (__STDC__) || defined (ALMOST_STDC) || defined (HAVE_STRINGIZE)
474 #define A(a) (1 << CGEN_INSN_##a)
475 #else
476 #define A(a) (1 << CGEN_INSN_/**/a)
477 #endif
479 static const CGEN_IBASE iq2000_cgen_insn_table[MAX_INSNS] =
481 /* Special null first entry.
482 A `num' value of zero is thus invalid.
483 Also, the special `invalid' insn resides here. */
484 { 0, 0, 0, 0, {0, {0}} },
485 /* add ${rd-rs},$rt */
487 -1, "add2", "add", 32,
488 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
490 /* add $rd,$rs,$rt */
492 IQ2000_INSN_ADD, "add", "add", 32,
493 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
495 /* addi ${rt-rs},$lo16 */
497 -1, "addi2", "addi", 32,
498 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
500 /* addi $rt,$rs,$lo16 */
502 IQ2000_INSN_ADDI, "addi", "addi", 32,
503 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
505 /* addiu ${rt-rs},$lo16 */
507 -1, "addiu2", "addiu", 32,
508 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
510 /* addiu $rt,$rs,$lo16 */
512 IQ2000_INSN_ADDIU, "addiu", "addiu", 32,
513 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
515 /* addu ${rd-rs},$rt */
517 -1, "addu2", "addu", 32,
518 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
520 /* addu $rd,$rs,$rt */
522 IQ2000_INSN_ADDU, "addu", "addu", 32,
523 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
525 /* ado16 ${rd-rs},$rt */
527 -1, "ado162", "ado16", 32,
528 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
530 /* ado16 $rd,$rs,$rt */
532 IQ2000_INSN_ADO16, "ado16", "ado16", 32,
533 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
535 /* and ${rd-rs},$rt */
537 -1, "and2", "and", 32,
538 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
540 /* and $rd,$rs,$rt */
542 IQ2000_INSN_AND, "and", "and", 32,
543 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
545 /* andi ${rt-rs},$lo16 */
547 -1, "andi2", "andi", 32,
548 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
550 /* andi $rt,$rs,$lo16 */
552 IQ2000_INSN_ANDI, "andi", "andi", 32,
553 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
555 /* andoi ${rt-rs},$lo16 */
557 -1, "andoi2", "andoi", 32,
558 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
560 /* andoi $rt,$rs,$lo16 */
562 IQ2000_INSN_ANDOI, "andoi", "andoi", 32,
563 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
565 /* nor ${rd-rs},$rt */
567 -1, "nor2", "nor", 32,
568 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
570 /* nor $rd,$rs,$rt */
572 IQ2000_INSN_NOR, "nor", "nor", 32,
573 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
575 /* or ${rd-rs},$rt */
577 -1, "or2", "or", 32,
578 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
580 /* or $rd,$rs,$rt */
582 IQ2000_INSN_OR, "or", "or", 32,
583 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
585 /* ori ${rt-rs},$lo16 */
587 -1, "ori2", "ori", 32,
588 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
590 /* ori $rt,$rs,$lo16 */
592 IQ2000_INSN_ORI, "ori", "ori", 32,
593 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
595 /* ram $rd,$rt,$shamt,$maskl,$maskr */
597 IQ2000_INSN_RAM, "ram", "ram", 32,
598 { 0|A(USES_RT)|A(USES_RD), { (1<<MACH_BASE) } }
600 /* sll $rd,$rt,$shamt */
602 IQ2000_INSN_SLL, "sll", "sll", 32,
603 { 0|A(USES_RT)|A(USES_RD), { (1<<MACH_BASE) } }
605 /* sllv ${rd-rt},$rs */
607 -1, "sllv2", "sllv", 32,
608 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
610 /* sllv $rd,$rt,$rs */
612 IQ2000_INSN_SLLV, "sllv", "sllv", 32,
613 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
615 /* slmv ${rd-rt},$rs,$shamt */
617 -1, "slmv2", "slmv", 32,
618 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
620 /* slmv $rd,$rt,$rs,$shamt */
622 IQ2000_INSN_SLMV, "slmv", "slmv", 32,
623 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
625 /* slt ${rd-rs},$rt */
627 -1, "slt2", "slt", 32,
628 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
630 /* slt $rd,$rs,$rt */
632 IQ2000_INSN_SLT, "slt", "slt", 32,
633 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
635 /* slti ${rt-rs},$imm */
637 -1, "slti2", "slti", 32,
638 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
640 /* slti $rt,$rs,$imm */
642 IQ2000_INSN_SLTI, "slti", "slti", 32,
643 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
645 /* sltiu ${rt-rs},$imm */
647 -1, "sltiu2", "sltiu", 32,
648 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
650 /* sltiu $rt,$rs,$imm */
652 IQ2000_INSN_SLTIU, "sltiu", "sltiu", 32,
653 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
655 /* sltu ${rd-rs},$rt */
657 -1, "sltu2", "sltu", 32,
658 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
660 /* sltu $rd,$rs,$rt */
662 IQ2000_INSN_SLTU, "sltu", "sltu", 32,
663 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
665 /* sra ${rd-rt},$shamt */
667 -1, "sra2", "sra", 32,
668 { 0|A(USES_RT)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
670 /* sra $rd,$rt,$shamt */
672 IQ2000_INSN_SRA, "sra", "sra", 32,
673 { 0|A(USES_RT)|A(USES_RD), { (1<<MACH_BASE) } }
675 /* srav ${rd-rt},$rs */
677 -1, "srav2", "srav", 32,
678 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
680 /* srav $rd,$rt,$rs */
682 IQ2000_INSN_SRAV, "srav", "srav", 32,
683 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
685 /* srl $rd,$rt,$shamt */
687 IQ2000_INSN_SRL, "srl", "srl", 32,
688 { 0|A(USES_RT)|A(USES_RD), { (1<<MACH_BASE) } }
690 /* srlv ${rd-rt},$rs */
692 -1, "srlv2", "srlv", 32,
693 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
695 /* srlv $rd,$rt,$rs */
697 IQ2000_INSN_SRLV, "srlv", "srlv", 32,
698 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
700 /* srmv ${rd-rt},$rs,$shamt */
702 -1, "srmv2", "srmv", 32,
703 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
705 /* srmv $rd,$rt,$rs,$shamt */
707 IQ2000_INSN_SRMV, "srmv", "srmv", 32,
708 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
710 /* sub ${rd-rs},$rt */
712 -1, "sub2", "sub", 32,
713 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
715 /* sub $rd,$rs,$rt */
717 IQ2000_INSN_SUB, "sub", "sub", 32,
718 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
720 /* subu ${rd-rs},$rt */
722 -1, "subu2", "subu", 32,
723 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
725 /* subu $rd,$rs,$rt */
727 IQ2000_INSN_SUBU, "subu", "subu", 32,
728 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
730 /* xor ${rd-rs},$rt */
732 -1, "xor2", "xor", 32,
733 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
735 /* xor $rd,$rs,$rt */
737 IQ2000_INSN_XOR, "xor", "xor", 32,
738 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_BASE) } }
740 /* xori ${rt-rs},$lo16 */
742 -1, "xori2", "xori", 32,
743 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_BASE) } }
745 /* xori $rt,$rs,$lo16 */
747 IQ2000_INSN_XORI, "xori", "xori", 32,
748 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
750 /* bbi $rs($bitnum),$offset */
752 IQ2000_INSN_BBI, "bbi", "bbi", 32,
753 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
755 /* bbin $rs($bitnum),$offset */
757 IQ2000_INSN_BBIN, "bbin", "bbin", 32,
758 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
760 /* bbv $rs,$rt,$offset */
762 IQ2000_INSN_BBV, "bbv", "bbv", 32,
763 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
765 /* bbvn $rs,$rt,$offset */
767 IQ2000_INSN_BBVN, "bbvn", "bbvn", 32,
768 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
770 /* beq $rs,$rt,$offset */
772 IQ2000_INSN_BEQ, "beq", "beq", 32,
773 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
775 /* beql $rs,$rt,$offset */
777 IQ2000_INSN_BEQL, "beql", "beql", 32,
778 { 0|A(USES_RT)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
780 /* bgez $rs,$offset */
782 IQ2000_INSN_BGEZ, "bgez", "bgez", 32,
783 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
785 /* bgezal $rs,$offset */
787 IQ2000_INSN_BGEZAL, "bgezal", "bgezal", 32,
788 { 0|A(USES_R31)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
790 /* bgezall $rs,$offset */
792 IQ2000_INSN_BGEZALL, "bgezall", "bgezall", 32,
793 { 0|A(USES_R31)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
795 /* bgezl $rs,$offset */
797 IQ2000_INSN_BGEZL, "bgezl", "bgezl", 32,
798 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
800 /* bltz $rs,$offset */
802 IQ2000_INSN_BLTZ, "bltz", "bltz", 32,
803 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
805 /* bltzl $rs,$offset */
807 IQ2000_INSN_BLTZL, "bltzl", "bltzl", 32,
808 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
810 /* bltzal $rs,$offset */
812 IQ2000_INSN_BLTZAL, "bltzal", "bltzal", 32,
813 { 0|A(USES_R31)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
815 /* bltzall $rs,$offset */
817 IQ2000_INSN_BLTZALL, "bltzall", "bltzall", 32,
818 { 0|A(USES_R31)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
820 /* bmb0 $rs,$rt,$offset */
822 IQ2000_INSN_BMB0, "bmb0", "bmb0", 32,
823 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
825 /* bmb1 $rs,$rt,$offset */
827 IQ2000_INSN_BMB1, "bmb1", "bmb1", 32,
828 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
830 /* bmb2 $rs,$rt,$offset */
832 IQ2000_INSN_BMB2, "bmb2", "bmb2", 32,
833 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
835 /* bmb3 $rs,$rt,$offset */
837 IQ2000_INSN_BMB3, "bmb3", "bmb3", 32,
838 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
840 /* bne $rs,$rt,$offset */
842 IQ2000_INSN_BNE, "bne", "bne", 32,
843 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
845 /* bnel $rs,$rt,$offset */
847 IQ2000_INSN_BNEL, "bnel", "bnel", 32,
848 { 0|A(USES_RT)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
850 /* jalr $rd,$rs */
852 IQ2000_INSN_JALR, "jalr", "jalr", 32,
853 { 0|A(USES_RS)|A(USES_RD)|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
855 /* jr $rs */
857 IQ2000_INSN_JR, "jr", "jr", 32,
858 { 0|A(USES_RS)|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_BASE) } }
860 /* lb $rt,$lo16($base) */
862 IQ2000_INSN_LB, "lb", "lb", 32,
863 { 0|A(USES_RT)|A(USES_RS)|A(LOAD_DELAY), { (1<<MACH_BASE) } }
865 /* lbu $rt,$lo16($base) */
867 IQ2000_INSN_LBU, "lbu", "lbu", 32,
868 { 0|A(USES_RT)|A(USES_RS)|A(LOAD_DELAY), { (1<<MACH_BASE) } }
870 /* lh $rt,$lo16($base) */
872 IQ2000_INSN_LH, "lh", "lh", 32,
873 { 0|A(USES_RT)|A(USES_RS)|A(LOAD_DELAY), { (1<<MACH_BASE) } }
875 /* lhu $rt,$lo16($base) */
877 IQ2000_INSN_LHU, "lhu", "lhu", 32,
878 { 0|A(USES_RT)|A(USES_RS)|A(LOAD_DELAY), { (1<<MACH_BASE) } }
880 /* lui $rt,$hi16 */
882 IQ2000_INSN_LUI, "lui", "lui", 32,
883 { 0|A(USES_RT), { (1<<MACH_BASE) } }
885 /* lw $rt,$lo16($base) */
887 IQ2000_INSN_LW, "lw", "lw", 32,
888 { 0|A(USES_RT)|A(USES_RS)|A(LOAD_DELAY), { (1<<MACH_BASE) } }
890 /* sb $rt,$lo16($base) */
892 IQ2000_INSN_SB, "sb", "sb", 32,
893 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
895 /* sh $rt,$lo16($base) */
897 IQ2000_INSN_SH, "sh", "sh", 32,
898 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
900 /* sw $rt,$lo16($base) */
902 IQ2000_INSN_SW, "sw", "sw", 32,
903 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_BASE) } }
905 /* break */
907 IQ2000_INSN_BREAK, "break", "break", 32,
908 { 0, { (1<<MACH_BASE) } }
910 /* syscall */
912 IQ2000_INSN_SYSCALL, "syscall", "syscall", 32,
913 { 0|A(YIELD_INSN), { (1<<MACH_BASE) } }
915 /* andoui $rt,$rs,$hi16 */
917 IQ2000_INSN_ANDOUI, "andoui", "andoui", 32,
918 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ2000) } }
920 /* andoui ${rt-rs},$hi16 */
922 -1, "andoui2", "andoui", 32,
923 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_IQ2000) } }
925 /* orui ${rt-rs},$hi16 */
927 -1, "orui2", "orui", 32,
928 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_IQ2000) } }
930 /* orui $rt,$rs,$hi16 */
932 IQ2000_INSN_ORUI, "orui", "orui", 32,
933 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ2000) } }
935 /* bgtz $rs,$offset */
937 IQ2000_INSN_BGTZ, "bgtz", "bgtz", 32,
938 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
940 /* bgtzl $rs,$offset */
942 IQ2000_INSN_BGTZL, "bgtzl", "bgtzl", 32,
943 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
945 /* blez $rs,$offset */
947 IQ2000_INSN_BLEZ, "blez", "blez", 32,
948 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
950 /* blezl $rs,$offset */
952 IQ2000_INSN_BLEZL, "blezl", "blezl", 32,
953 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
955 /* mrgb $rd,$rs,$rt,$mask */
957 IQ2000_INSN_MRGB, "mrgb", "mrgb", 32,
958 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ2000) } }
960 /* mrgb ${rd-rs},$rt,$mask */
962 -1, "mrgb2", "mrgb", 32,
963 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_IQ2000) } }
965 /* bctxt $rs,$offset */
967 IQ2000_INSN_BCTXT, "bctxt", "bctxt", 32,
968 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
970 /* bc0f $offset */
972 IQ2000_INSN_BC0F, "bc0f", "bc0f", 32,
973 { 0|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
975 /* bc0fl $offset */
977 IQ2000_INSN_BC0FL, "bc0fl", "bc0fl", 32,
978 { 0|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
980 /* bc3f $offset */
982 IQ2000_INSN_BC3F, "bc3f", "bc3f", 32,
983 { 0|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
985 /* bc3fl $offset */
987 IQ2000_INSN_BC3FL, "bc3fl", "bc3fl", 32,
988 { 0|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
990 /* bc0t $offset */
992 IQ2000_INSN_BC0T, "bc0t", "bc0t", 32,
993 { 0|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
995 /* bc0tl $offset */
997 IQ2000_INSN_BC0TL, "bc0tl", "bc0tl", 32,
998 { 0|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
1000 /* bc3t $offset */
1002 IQ2000_INSN_BC3T, "bc3t", "bc3t", 32,
1003 { 0|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
1005 /* bc3tl $offset */
1007 IQ2000_INSN_BC3TL, "bc3tl", "bc3tl", 32,
1008 { 0|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
1010 /* cfc0 $rt,$rd */
1012 IQ2000_INSN_CFC0, "cfc0", "cfc0", 32,
1013 { 0|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1015 /* cfc1 $rt,$rd */
1017 IQ2000_INSN_CFC1, "cfc1", "cfc1", 32,
1018 { 0|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1020 /* cfc2 $rt,$rd */
1022 IQ2000_INSN_CFC2, "cfc2", "cfc2", 32,
1023 { 0|A(YIELD_INSN)|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1025 /* cfc3 $rt,$rd */
1027 IQ2000_INSN_CFC3, "cfc3", "cfc3", 32,
1028 { 0|A(YIELD_INSN)|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1030 /* chkhdr $rd,$rt */
1032 IQ2000_INSN_CHKHDR, "chkhdr", "chkhdr", 32,
1033 { 0|A(YIELD_INSN)|A(USES_RD)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1035 /* ctc0 $rt,$rd */
1037 IQ2000_INSN_CTC0, "ctc0", "ctc0", 32,
1038 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1040 /* ctc1 $rt,$rd */
1042 IQ2000_INSN_CTC1, "ctc1", "ctc1", 32,
1043 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1045 /* ctc2 $rt,$rd */
1047 IQ2000_INSN_CTC2, "ctc2", "ctc2", 32,
1048 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1050 /* ctc3 $rt,$rd */
1052 IQ2000_INSN_CTC3, "ctc3", "ctc3", 32,
1053 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1055 /* jcr $rs */
1057 IQ2000_INSN_JCR, "jcr", "jcr", 32,
1058 { 0|A(USES_RS)|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
1060 /* luc32 $rt,$rd */
1062 IQ2000_INSN_LUC32, "luc32", "luc32", 32,
1063 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1065 /* luc32l $rt,$rd */
1067 IQ2000_INSN_LUC32L, "luc32l", "luc32l", 32,
1068 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1070 /* luc64 $rt,$rd */
1072 IQ2000_INSN_LUC64, "luc64", "luc64", 32,
1073 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1075 /* luc64l $rt,$rd */
1077 IQ2000_INSN_LUC64L, "luc64l", "luc64l", 32,
1078 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1080 /* luk $rt,$rd */
1082 IQ2000_INSN_LUK, "luk", "luk", 32,
1083 { 0|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1085 /* lulck $rt */
1087 IQ2000_INSN_LULCK, "lulck", "lulck", 32,
1088 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1090 /* lum32 $rt,$rd */
1092 IQ2000_INSN_LUM32, "lum32", "lum32", 32,
1093 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1095 /* lum32l $rt,$rd */
1097 IQ2000_INSN_LUM32L, "lum32l", "lum32l", 32,
1098 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1100 /* lum64 $rt,$rd */
1102 IQ2000_INSN_LUM64, "lum64", "lum64", 32,
1103 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1105 /* lum64l $rt,$rd */
1107 IQ2000_INSN_LUM64L, "lum64l", "lum64l", 32,
1108 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1110 /* lur $rt,$rd */
1112 IQ2000_INSN_LUR, "lur", "lur", 32,
1113 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1115 /* lurl $rt,$rd */
1117 IQ2000_INSN_LURL, "lurl", "lurl", 32,
1118 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1120 /* luulck $rt */
1122 IQ2000_INSN_LUULCK, "luulck", "luulck", 32,
1123 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1125 /* mfc0 $rt,$rd */
1127 IQ2000_INSN_MFC0, "mfc0", "mfc0", 32,
1128 { 0|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1130 /* mfc1 $rt,$rd */
1132 IQ2000_INSN_MFC1, "mfc1", "mfc1", 32,
1133 { 0|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1135 /* mfc2 $rt,$rd */
1137 IQ2000_INSN_MFC2, "mfc2", "mfc2", 32,
1138 { 0|A(YIELD_INSN)|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1140 /* mfc3 $rt,$rd */
1142 IQ2000_INSN_MFC3, "mfc3", "mfc3", 32,
1143 { 0|A(YIELD_INSN)|A(USES_RT)|A(LOAD_DELAY), { (1<<MACH_IQ2000) } }
1145 /* mtc0 $rt,$rd */
1147 IQ2000_INSN_MTC0, "mtc0", "mtc0", 32,
1148 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1150 /* mtc1 $rt,$rd */
1152 IQ2000_INSN_MTC1, "mtc1", "mtc1", 32,
1153 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1155 /* mtc2 $rt,$rd */
1157 IQ2000_INSN_MTC2, "mtc2", "mtc2", 32,
1158 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1160 /* mtc3 $rt,$rd */
1162 IQ2000_INSN_MTC3, "mtc3", "mtc3", 32,
1163 { 0|A(USES_RT), { (1<<MACH_IQ2000) } }
1165 /* pkrl $rd,$rt */
1167 IQ2000_INSN_PKRL, "pkrl", "pkrl", 32,
1168 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1170 /* pkrlr1 $rt,$_index,$count */
1172 IQ2000_INSN_PKRLR1, "pkrlr1", "pkrlr1", 32,
1173 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1175 /* pkrlr30 $rt,$_index,$count */
1177 IQ2000_INSN_PKRLR30, "pkrlr30", "pkrlr30", 32,
1178 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1180 /* rb $rd,$rt */
1182 IQ2000_INSN_RB, "rb", "rb", 32,
1183 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1185 /* rbr1 $rt,$_index,$count */
1187 IQ2000_INSN_RBR1, "rbr1", "rbr1", 32,
1188 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1190 /* rbr30 $rt,$_index,$count */
1192 IQ2000_INSN_RBR30, "rbr30", "rbr30", 32,
1193 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1195 /* rfe */
1197 IQ2000_INSN_RFE, "rfe", "rfe", 32,
1198 { 0, { (1<<MACH_IQ2000) } }
1200 /* rx $rd,$rt */
1202 IQ2000_INSN_RX, "rx", "rx", 32,
1203 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1205 /* rxr1 $rt,$_index,$count */
1207 IQ2000_INSN_RXR1, "rxr1", "rxr1", 32,
1208 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1210 /* rxr30 $rt,$_index,$count */
1212 IQ2000_INSN_RXR30, "rxr30", "rxr30", 32,
1213 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1215 /* sleep */
1217 IQ2000_INSN_SLEEP, "sleep", "sleep", 32,
1218 { 0|A(YIELD_INSN), { (1<<MACH_IQ2000) } }
1220 /* srrd $rt */
1222 IQ2000_INSN_SRRD, "srrd", "srrd", 32,
1223 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1225 /* srrdl $rt */
1227 IQ2000_INSN_SRRDL, "srrdl", "srrdl", 32,
1228 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1230 /* srulck $rt */
1232 IQ2000_INSN_SRULCK, "srulck", "srulck", 32,
1233 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1235 /* srwr $rt,$rd */
1237 IQ2000_INSN_SRWR, "srwr", "srwr", 32,
1238 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1240 /* srwru $rt,$rd */
1242 IQ2000_INSN_SRWRU, "srwru", "srwru", 32,
1243 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1245 /* trapqfl */
1247 IQ2000_INSN_TRAPQFL, "trapqfl", "trapqfl", 32,
1248 { 0|A(YIELD_INSN), { (1<<MACH_IQ2000) } }
1250 /* trapqne */
1252 IQ2000_INSN_TRAPQNE, "trapqne", "trapqne", 32,
1253 { 0|A(YIELD_INSN), { (1<<MACH_IQ2000) } }
1255 /* traprel $rt */
1257 IQ2000_INSN_TRAPREL, "traprel", "traprel", 32,
1258 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1260 /* wb $rd,$rt */
1262 IQ2000_INSN_WB, "wb", "wb", 32,
1263 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1265 /* wbu $rd,$rt */
1267 IQ2000_INSN_WBU, "wbu", "wbu", 32,
1268 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1270 /* wbr1 $rt,$_index,$count */
1272 IQ2000_INSN_WBR1, "wbr1", "wbr1", 32,
1273 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1275 /* wbr1u $rt,$_index,$count */
1277 IQ2000_INSN_WBR1U, "wbr1u", "wbr1u", 32,
1278 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1280 /* wbr30 $rt,$_index,$count */
1282 IQ2000_INSN_WBR30, "wbr30", "wbr30", 32,
1283 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1285 /* wbr30u $rt,$_index,$count */
1287 IQ2000_INSN_WBR30U, "wbr30u", "wbr30u", 32,
1288 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1290 /* wx $rd,$rt */
1292 IQ2000_INSN_WX, "wx", "wx", 32,
1293 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1295 /* wxu $rd,$rt */
1297 IQ2000_INSN_WXU, "wxu", "wxu", 32,
1298 { 0|A(YIELD_INSN)|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ2000) } }
1300 /* wxr1 $rt,$_index,$count */
1302 IQ2000_INSN_WXR1, "wxr1", "wxr1", 32,
1303 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1305 /* wxr1u $rt,$_index,$count */
1307 IQ2000_INSN_WXR1U, "wxr1u", "wxr1u", 32,
1308 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1310 /* wxr30 $rt,$_index,$count */
1312 IQ2000_INSN_WXR30, "wxr30", "wxr30", 32,
1313 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1315 /* wxr30u $rt,$_index,$count */
1317 IQ2000_INSN_WXR30U, "wxr30u", "wxr30u", 32,
1318 { 0|A(YIELD_INSN)|A(USES_RT), { (1<<MACH_IQ2000) } }
1320 /* ldw $rt,$lo16($base) */
1322 IQ2000_INSN_LDW, "ldw", "ldw", 32,
1323 { 0|A(USES_RT)|A(LOAD_DELAY)|A(EVEN_REG_NUM), { (1<<MACH_IQ2000) } }
1325 /* sdw $rt,$lo16($base) */
1327 IQ2000_INSN_SDW, "sdw", "sdw", 32,
1328 { 0|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ2000) } }
1330 /* j $jmptarg */
1332 IQ2000_INSN_J, "j", "j", 32,
1333 { 0|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
1335 /* jal $jmptarg */
1337 IQ2000_INSN_JAL, "jal", "jal", 32,
1338 { 0|A(USES_R31)|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
1340 /* bmb $rs,$rt,$offset */
1342 IQ2000_INSN_BMB, "bmb", "bmb", 32,
1343 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ2000) } }
1345 /* andoui $rt,$rs,$hi16 */
1347 IQ2000_INSN_ANDOUI_Q10, "andoui-q10", "andoui", 32,
1348 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1350 /* andoui ${rt-rs},$hi16 */
1352 -1, "andoui2-q10", "andoui", 32,
1353 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_IQ10) } }
1355 /* orui $rt,$rs,$hi16 */
1357 IQ2000_INSN_ORUI_Q10, "orui-q10", "orui", 32,
1358 { 0|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1360 /* orui ${rt-rs},$hi16 */
1362 -1, "orui2-q10", "orui", 32,
1363 { 0|A(USES_RT)|A(USES_RS)|A(NO_DIS)|A(ALIAS), { (1<<MACH_IQ10) } }
1365 /* mrgb $rd,$rs,$rt,$maskq10 */
1367 IQ2000_INSN_MRGBQ10, "mrgbq10", "mrgb", 32,
1368 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1370 /* mrgb ${rd-rs},$rt,$maskq10 */
1372 -1, "mrgbq102", "mrgb", 32,
1373 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD)|A(NO_DIS)|A(ALIAS), { (1<<MACH_IQ10) } }
1375 /* j $jmptarg */
1377 IQ2000_INSN_JQ10, "jq10", "j", 32,
1378 { 0|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1380 /* jal $rt,$jmptarg */
1382 IQ2000_INSN_JALQ10, "jalq10", "jal", 32,
1383 { 0|A(USES_RT)|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1385 /* jal $jmptarg */
1387 IQ2000_INSN_JALQ10_2, "jalq10-2", "jal", 32,
1388 { 0|A(USES_RT)|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1390 /* bbil $rs($bitnum),$offset */
1392 IQ2000_INSN_BBIL, "bbil", "bbil", 32,
1393 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1395 /* bbinl $rs($bitnum),$offset */
1397 IQ2000_INSN_BBINL, "bbinl", "bbinl", 32,
1398 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1400 /* bbvl $rs,$rt,$offset */
1402 IQ2000_INSN_BBVL, "bbvl", "bbvl", 32,
1403 { 0|A(USES_RT)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1405 /* bbvnl $rs,$rt,$offset */
1407 IQ2000_INSN_BBVNL, "bbvnl", "bbvnl", 32,
1408 { 0|A(USES_RT)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1410 /* bgtzal $rs,$offset */
1412 IQ2000_INSN_BGTZAL, "bgtzal", "bgtzal", 32,
1413 { 0|A(USES_R31)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1415 /* bgtzall $rs,$offset */
1417 IQ2000_INSN_BGTZALL, "bgtzall", "bgtzall", 32,
1418 { 0|A(USES_R31)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1420 /* blezal $rs,$offset */
1422 IQ2000_INSN_BLEZAL, "blezal", "blezal", 32,
1423 { 0|A(USES_R31)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1425 /* blezall $rs,$offset */
1427 IQ2000_INSN_BLEZALL, "blezall", "blezall", 32,
1428 { 0|A(USES_R31)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1430 /* bgtz $rs,$offset */
1432 IQ2000_INSN_BGTZ_Q10, "bgtz-q10", "bgtz", 32,
1433 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1435 /* bgtzl $rs,$offset */
1437 IQ2000_INSN_BGTZL_Q10, "bgtzl-q10", "bgtzl", 32,
1438 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1440 /* blez $rs,$offset */
1442 IQ2000_INSN_BLEZ_Q10, "blez-q10", "blez", 32,
1443 { 0|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1445 /* blezl $rs,$offset */
1447 IQ2000_INSN_BLEZL_Q10, "blezl-q10", "blezl", 32,
1448 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1450 /* bmb $rs,$rt,$offset */
1452 IQ2000_INSN_BMB_Q10, "bmb-q10", "bmb", 32,
1453 { 0|A(USES_RT)|A(USES_RS)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1455 /* bmbl $rs,$rt,$offset */
1457 IQ2000_INSN_BMBL, "bmbl", "bmbl", 32,
1458 { 0|A(USES_RT)|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1460 /* bri $rs,$offset */
1462 IQ2000_INSN_BRI, "bri", "bri", 32,
1463 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1465 /* brv $rs,$offset */
1467 IQ2000_INSN_BRV, "brv", "brv", 32,
1468 { 0|A(USES_RS)|A(SKIP_CTI)|A(COND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1470 /* bctx $rs,$offset */
1472 IQ2000_INSN_BCTX, "bctx", "bctx", 32,
1473 { 0|A(USES_RS)|A(UNCOND_CTI)|A(DELAY_SLOT), { (1<<MACH_IQ10) } }
1475 /* yield */
1477 IQ2000_INSN_YIELD, "yield", "yield", 32,
1478 { 0, { (1<<MACH_IQ10) } }
1480 /* crc32 $rd,$rs,$rt */
1482 IQ2000_INSN_CRC32, "crc32", "crc32", 32,
1483 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1485 /* crc32b $rd,$rs,$rt */
1487 IQ2000_INSN_CRC32B, "crc32b", "crc32b", 32,
1488 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1490 /* cnt1s $rd,$rs */
1492 IQ2000_INSN_CNT1S, "cnt1s", "cnt1s", 32,
1493 { 0|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1495 /* avail $rd */
1497 IQ2000_INSN_AVAIL, "avail", "avail", 32,
1498 { 0|A(USES_RD), { (1<<MACH_IQ10) } }
1500 /* free $rd,$rs */
1502 IQ2000_INSN_FREE, "free", "free", 32,
1503 { 0|A(USES_RD)|A(USES_RS), { (1<<MACH_IQ10) } }
1505 /* tstod $rd,$rs */
1507 IQ2000_INSN_TSTOD, "tstod", "tstod", 32,
1508 { 0|A(USES_RD)|A(USES_RS), { (1<<MACH_IQ10) } }
1510 /* cmphdr $rd */
1512 IQ2000_INSN_CMPHDR, "cmphdr", "cmphdr", 32,
1513 { 0|A(USES_RD), { (1<<MACH_IQ10) } }
1515 /* mcid $rd,$rt */
1517 IQ2000_INSN_MCID, "mcid", "mcid", 32,
1518 { 0|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ10) } }
1520 /* dba $rd */
1522 IQ2000_INSN_DBA, "dba", "dba", 32,
1523 { 0|A(USES_RD), { (1<<MACH_IQ10) } }
1525 /* dbd $rd,$rs,$rt */
1527 IQ2000_INSN_DBD, "dbd", "dbd", 32,
1528 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1530 /* dpwt $rd,$rs */
1532 IQ2000_INSN_DPWT, "dpwt", "dpwt", 32,
1533 { 0|A(USES_RD)|A(USES_RS), { (1<<MACH_IQ10) } }
1535 /* chkhdr $rd,$rs */
1537 IQ2000_INSN_CHKHDRQ10, "chkhdrq10", "chkhdr", 32,
1538 { 0|A(USES_RD)|A(USES_RS), { (1<<MACH_IQ10) } }
1540 /* rba $rd,$rs,$rt */
1542 IQ2000_INSN_RBA, "rba", "rba", 32,
1543 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1545 /* rbal $rd,$rs,$rt */
1547 IQ2000_INSN_RBAL, "rbal", "rbal", 32,
1548 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1550 /* rbar $rd,$rs,$rt */
1552 IQ2000_INSN_RBAR, "rbar", "rbar", 32,
1553 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1555 /* wba $rd,$rs,$rt */
1557 IQ2000_INSN_WBA, "wba", "wba", 32,
1558 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1560 /* wbau $rd,$rs,$rt */
1562 IQ2000_INSN_WBAU, "wbau", "wbau", 32,
1563 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1565 /* wbac $rd,$rs,$rt */
1567 IQ2000_INSN_WBAC, "wbac", "wbac", 32,
1568 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1570 /* rbi $rd,$rs,$rt,$bytecount */
1572 IQ2000_INSN_RBI, "rbi", "rbi", 32,
1573 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1575 /* rbil $rd,$rs,$rt,$bytecount */
1577 IQ2000_INSN_RBIL, "rbil", "rbil", 32,
1578 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1580 /* rbir $rd,$rs,$rt,$bytecount */
1582 IQ2000_INSN_RBIR, "rbir", "rbir", 32,
1583 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1585 /* wbi $rd,$rs,$rt,$bytecount */
1587 IQ2000_INSN_WBI, "wbi", "wbi", 32,
1588 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1590 /* wbic $rd,$rs,$rt,$bytecount */
1592 IQ2000_INSN_WBIC, "wbic", "wbic", 32,
1593 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1595 /* wbiu $rd,$rs,$rt,$bytecount */
1597 IQ2000_INSN_WBIU, "wbiu", "wbiu", 32,
1598 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1600 /* pkrli $rd,$rs,$rt,$bytecount */
1602 IQ2000_INSN_PKRLI, "pkrli", "pkrli", 32,
1603 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1605 /* pkrlih $rd,$rs,$rt,$bytecount */
1607 IQ2000_INSN_PKRLIH, "pkrlih", "pkrlih", 32,
1608 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1610 /* pkrliu $rd,$rs,$rt,$bytecount */
1612 IQ2000_INSN_PKRLIU, "pkrliu", "pkrliu", 32,
1613 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1615 /* pkrlic $rd,$rs,$rt,$bytecount */
1617 IQ2000_INSN_PKRLIC, "pkrlic", "pkrlic", 32,
1618 { 0|A(USES_RT)|A(USES_RS)|A(USES_RD), { (1<<MACH_IQ10) } }
1620 /* pkrla $rd,$rs,$rt */
1622 IQ2000_INSN_PKRLA, "pkrla", "pkrla", 32,
1623 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1625 /* pkrlau $rd,$rs,$rt */
1627 IQ2000_INSN_PKRLAU, "pkrlau", "pkrlau", 32,
1628 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1630 /* pkrlah $rd,$rs,$rt */
1632 IQ2000_INSN_PKRLAH, "pkrlah", "pkrlah", 32,
1633 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1635 /* pkrlac $rd,$rs,$rt */
1637 IQ2000_INSN_PKRLAC, "pkrlac", "pkrlac", 32,
1638 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1640 /* lock $rd,$rt */
1642 IQ2000_INSN_LOCK, "lock", "lock", 32,
1643 { 0|A(USES_RT)|A(USES_RD), { (1<<MACH_IQ10) } }
1645 /* unlk $rd,$rt */
1647 IQ2000_INSN_UNLK, "unlk", "unlk", 32,
1648 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1650 /* swrd $rd,$rt */
1652 IQ2000_INSN_SWRD, "swrd", "swrd", 32,
1653 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1655 /* swrdl $rd,$rt */
1657 IQ2000_INSN_SWRDL, "swrdl", "swrdl", 32,
1658 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1660 /* swwr $rd,$rs,$rt */
1662 IQ2000_INSN_SWWR, "swwr", "swwr", 32,
1663 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1665 /* swwru $rd,$rs,$rt */
1667 IQ2000_INSN_SWWRU, "swwru", "swwru", 32,
1668 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1670 /* dwrd $rd,$rt */
1672 IQ2000_INSN_DWRD, "dwrd", "dwrd", 32,
1673 { 0|A(USES_RD)|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1675 /* dwrdl $rd,$rt */
1677 IQ2000_INSN_DWRDL, "dwrdl", "dwrdl", 32,
1678 { 0|A(USES_RD)|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1680 /* cam36 $rd,$rt,${cam-z},${cam-y} */
1682 IQ2000_INSN_CAM36, "cam36", "cam36", 32,
1683 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1685 /* cam72 $rd,$rt,${cam-y},${cam-z} */
1687 IQ2000_INSN_CAM72, "cam72", "cam72", 32,
1688 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1690 /* cam144 $rd,$rt,${cam-y},${cam-z} */
1692 IQ2000_INSN_CAM144, "cam144", "cam144", 32,
1693 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1695 /* cam288 $rd,$rt,${cam-y},${cam-z} */
1697 IQ2000_INSN_CAM288, "cam288", "cam288", 32,
1698 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1700 /* cm32and $rd,$rs,$rt */
1702 IQ2000_INSN_CM32AND, "cm32and", "cm32and", 32,
1703 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1705 /* cm32andn $rd,$rs,$rt */
1707 IQ2000_INSN_CM32ANDN, "cm32andn", "cm32andn", 32,
1708 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1710 /* cm32or $rd,$rs,$rt */
1712 IQ2000_INSN_CM32OR, "cm32or", "cm32or", 32,
1713 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1715 /* cm32ra $rd,$rs,$rt */
1717 IQ2000_INSN_CM32RA, "cm32ra", "cm32ra", 32,
1718 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1720 /* cm32rd $rd,$rt */
1722 IQ2000_INSN_CM32RD, "cm32rd", "cm32rd", 32,
1723 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1725 /* cm32ri $rd,$rt */
1727 IQ2000_INSN_CM32RI, "cm32ri", "cm32ri", 32,
1728 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1730 /* cm32rs $rd,$rs,$rt */
1732 IQ2000_INSN_CM32RS, "cm32rs", "cm32rs", 32,
1733 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1735 /* cm32sa $rd,$rs,$rt */
1737 IQ2000_INSN_CM32SA, "cm32sa", "cm32sa", 32,
1738 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1740 /* cm32sd $rd,$rt */
1742 IQ2000_INSN_CM32SD, "cm32sd", "cm32sd", 32,
1743 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1745 /* cm32si $rd,$rt */
1747 IQ2000_INSN_CM32SI, "cm32si", "cm32si", 32,
1748 { 0|A(USES_RD)|A(USES_RT), { (1<<MACH_IQ10) } }
1750 /* cm32ss $rd,$rs,$rt */
1752 IQ2000_INSN_CM32SS, "cm32ss", "cm32ss", 32,
1753 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1755 /* cm32xor $rd,$rs,$rt */
1757 IQ2000_INSN_CM32XOR, "cm32xor", "cm32xor", 32,
1758 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1760 /* cm64clr $rd,$rt */
1762 IQ2000_INSN_CM64CLR, "cm64clr", "cm64clr", 32,
1763 { 0|A(USES_RD)|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1765 /* cm64ra $rd,$rs,$rt */
1767 IQ2000_INSN_CM64RA, "cm64ra", "cm64ra", 32,
1768 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1770 /* cm64rd $rd,$rt */
1772 IQ2000_INSN_CM64RD, "cm64rd", "cm64rd", 32,
1773 { 0|A(USES_RD)|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1775 /* cm64ri $rd,$rt */
1777 IQ2000_INSN_CM64RI, "cm64ri", "cm64ri", 32,
1778 { 0|A(USES_RD)|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1780 /* cm64ria2 $rd,$rs,$rt */
1782 IQ2000_INSN_CM64RIA2, "cm64ria2", "cm64ria2", 32,
1783 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1785 /* cm64rs $rd,$rs,$rt */
1787 IQ2000_INSN_CM64RS, "cm64rs", "cm64rs", 32,
1788 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1790 /* cm64sa $rd,$rs,$rt */
1792 IQ2000_INSN_CM64SA, "cm64sa", "cm64sa", 32,
1793 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1795 /* cm64sd $rd,$rt */
1797 IQ2000_INSN_CM64SD, "cm64sd", "cm64sd", 32,
1798 { 0|A(USES_RD)|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1800 /* cm64si $rd,$rt */
1802 IQ2000_INSN_CM64SI, "cm64si", "cm64si", 32,
1803 { 0|A(USES_RD)|A(USES_RT)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1805 /* cm64sia2 $rd,$rs,$rt */
1807 IQ2000_INSN_CM64SIA2, "cm64sia2", "cm64sia2", 32,
1808 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1810 /* cm64ss $rd,$rs,$rt */
1812 IQ2000_INSN_CM64SS, "cm64ss", "cm64ss", 32,
1813 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1815 /* cm128ria2 $rd,$rs,$rt */
1817 IQ2000_INSN_CM128RIA2, "cm128ria2", "cm128ria2", 32,
1818 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1820 /* cm128ria3 $rd,$rs,$rt,${cm-3z} */
1822 IQ2000_INSN_CM128RIA3, "cm128ria3", "cm128ria3", 32,
1823 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1825 /* cm128ria4 $rd,$rs,$rt,${cm-4z} */
1827 IQ2000_INSN_CM128RIA4, "cm128ria4", "cm128ria4", 32,
1828 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1830 /* cm128sia2 $rd,$rs,$rt */
1832 IQ2000_INSN_CM128SIA2, "cm128sia2", "cm128sia2", 32,
1833 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1835 /* cm128sia3 $rd,$rs,$rt,${cm-3z} */
1837 IQ2000_INSN_CM128SIA3, "cm128sia3", "cm128sia3", 32,
1838 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS)|A(EVEN_REG_NUM), { (1<<MACH_IQ10) } }
1840 /* cm128sia4 $rd,$rs,$rt,${cm-4z} */
1842 IQ2000_INSN_CM128SIA4, "cm128sia4", "cm128sia4", 32,
1843 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1845 /* cm128vsa $rd,$rs,$rt */
1847 IQ2000_INSN_CM128VSA, "cm128vsa", "cm128vsa", 32,
1848 { 0|A(USES_RD)|A(USES_RT)|A(USES_RS), { (1<<MACH_IQ10) } }
1850 /* cfc $rd,$rt */
1852 IQ2000_INSN_CFC, "cfc", "cfc", 32,
1853 { 0|A(YIELD_INSN)|A(USES_RD)|A(LOAD_DELAY), { (1<<MACH_IQ10) } }
1855 /* ctc $rs,$rt */
1857 IQ2000_INSN_CTC, "ctc", "ctc", 32,
1858 { 0|A(USES_RS), { (1<<MACH_IQ10) } }
1862 #undef OP
1863 #undef A
1865 /* Initialize anything needed to be done once, before any cpu_open call. */
1866 static void init_tables PARAMS ((void));
1868 static void
1869 init_tables ()
1873 static const CGEN_MACH * lookup_mach_via_bfd_name
1874 PARAMS ((const CGEN_MACH *, const char *));
1875 static void build_hw_table PARAMS ((CGEN_CPU_TABLE *));
1876 static void build_ifield_table PARAMS ((CGEN_CPU_TABLE *));
1877 static void build_operand_table PARAMS ((CGEN_CPU_TABLE *));
1878 static void build_insn_table PARAMS ((CGEN_CPU_TABLE *));
1879 static void iq2000_cgen_rebuild_tables PARAMS ((CGEN_CPU_TABLE *));
1881 /* Subroutine of iq2000_cgen_cpu_open to look up a mach via its bfd name. */
1883 static const CGEN_MACH *
1884 lookup_mach_via_bfd_name (table, name)
1885 const CGEN_MACH *table;
1886 const char *name;
1888 while (table->name)
1890 if (strcmp (name, table->bfd_name) == 0)
1891 return table;
1892 ++table;
1894 abort ();
1897 /* Subroutine of iq2000_cgen_cpu_open to build the hardware table. */
1899 static void
1900 build_hw_table (cd)
1901 CGEN_CPU_TABLE *cd;
1903 int i;
1904 int machs = cd->machs;
1905 const CGEN_HW_ENTRY *init = & iq2000_cgen_hw_table[0];
1906 /* MAX_HW is only an upper bound on the number of selected entries.
1907 However each entry is indexed by it's enum so there can be holes in
1908 the table. */
1909 const CGEN_HW_ENTRY **selected =
1910 (const CGEN_HW_ENTRY **) xmalloc (MAX_HW * sizeof (CGEN_HW_ENTRY *));
1912 cd->hw_table.init_entries = init;
1913 cd->hw_table.entry_size = sizeof (CGEN_HW_ENTRY);
1914 memset (selected, 0, MAX_HW * sizeof (CGEN_HW_ENTRY *));
1915 /* ??? For now we just use machs to determine which ones we want. */
1916 for (i = 0; init[i].name != NULL; ++i)
1917 if (CGEN_HW_ATTR_VALUE (&init[i], CGEN_HW_MACH)
1918 & machs)
1919 selected[init[i].type] = &init[i];
1920 cd->hw_table.entries = selected;
1921 cd->hw_table.num_entries = MAX_HW;
1924 /* Subroutine of iq2000_cgen_cpu_open to build the hardware table. */
1926 static void
1927 build_ifield_table (cd)
1928 CGEN_CPU_TABLE *cd;
1930 cd->ifld_table = & iq2000_cgen_ifld_table[0];
1933 /* Subroutine of iq2000_cgen_cpu_open to build the hardware table. */
1935 static void
1936 build_operand_table (cd)
1937 CGEN_CPU_TABLE *cd;
1939 int i;
1940 int machs = cd->machs;
1941 const CGEN_OPERAND *init = & iq2000_cgen_operand_table[0];
1942 /* MAX_OPERANDS is only an upper bound on the number of selected entries.
1943 However each entry is indexed by it's enum so there can be holes in
1944 the table. */
1945 const CGEN_OPERAND **selected =
1946 (const CGEN_OPERAND **) xmalloc (MAX_OPERANDS * sizeof (CGEN_OPERAND *));
1948 cd->operand_table.init_entries = init;
1949 cd->operand_table.entry_size = sizeof (CGEN_OPERAND);
1950 memset (selected, 0, MAX_OPERANDS * sizeof (CGEN_OPERAND *));
1951 /* ??? For now we just use mach to determine which ones we want. */
1952 for (i = 0; init[i].name != NULL; ++i)
1953 if (CGEN_OPERAND_ATTR_VALUE (&init[i], CGEN_OPERAND_MACH)
1954 & machs)
1955 selected[init[i].type] = &init[i];
1956 cd->operand_table.entries = selected;
1957 cd->operand_table.num_entries = MAX_OPERANDS;
1960 /* Subroutine of iq2000_cgen_cpu_open to build the hardware table.
1961 ??? This could leave out insns not supported by the specified mach/isa,
1962 but that would cause errors like "foo only supported by bar" to become
1963 "unknown insn", so for now we include all insns and require the app to
1964 do the checking later.
1965 ??? On the other hand, parsing of such insns may require their hardware or
1966 operand elements to be in the table [which they mightn't be]. */
1968 static void
1969 build_insn_table (cd)
1970 CGEN_CPU_TABLE *cd;
1972 int i;
1973 const CGEN_IBASE *ib = & iq2000_cgen_insn_table[0];
1974 CGEN_INSN *insns = (CGEN_INSN *) xmalloc (MAX_INSNS * sizeof (CGEN_INSN));
1976 memset (insns, 0, MAX_INSNS * sizeof (CGEN_INSN));
1977 for (i = 0; i < MAX_INSNS; ++i)
1978 insns[i].base = &ib[i];
1979 cd->insn_table.init_entries = insns;
1980 cd->insn_table.entry_size = sizeof (CGEN_IBASE);
1981 cd->insn_table.num_init_entries = MAX_INSNS;
1984 /* Subroutine of iq2000_cgen_cpu_open to rebuild the tables. */
1986 static void
1987 iq2000_cgen_rebuild_tables (cd)
1988 CGEN_CPU_TABLE *cd;
1990 int i;
1991 unsigned int isas = cd->isas;
1992 unsigned int machs = cd->machs;
1994 cd->int_insn_p = CGEN_INT_INSN_P;
1996 /* Data derived from the isa spec. */
1997 #define UNSET (CGEN_SIZE_UNKNOWN + 1)
1998 cd->default_insn_bitsize = UNSET;
1999 cd->base_insn_bitsize = UNSET;
2000 cd->min_insn_bitsize = 65535; /* some ridiculously big number */
2001 cd->max_insn_bitsize = 0;
2002 for (i = 0; i < MAX_ISAS; ++i)
2003 if (((1 << i) & isas) != 0)
2005 const CGEN_ISA *isa = & iq2000_cgen_isa_table[i];
2007 /* Default insn sizes of all selected isas must be
2008 equal or we set the result to 0, meaning "unknown". */
2009 if (cd->default_insn_bitsize == UNSET)
2010 cd->default_insn_bitsize = isa->default_insn_bitsize;
2011 else if (isa->default_insn_bitsize == cd->default_insn_bitsize)
2012 ; /* this is ok */
2013 else
2014 cd->default_insn_bitsize = CGEN_SIZE_UNKNOWN;
2016 /* Base insn sizes of all selected isas must be equal
2017 or we set the result to 0, meaning "unknown". */
2018 if (cd->base_insn_bitsize == UNSET)
2019 cd->base_insn_bitsize = isa->base_insn_bitsize;
2020 else if (isa->base_insn_bitsize == cd->base_insn_bitsize)
2021 ; /* this is ok */
2022 else
2023 cd->base_insn_bitsize = CGEN_SIZE_UNKNOWN;
2025 /* Set min,max insn sizes. */
2026 if (isa->min_insn_bitsize < cd->min_insn_bitsize)
2027 cd->min_insn_bitsize = isa->min_insn_bitsize;
2028 if (isa->max_insn_bitsize > cd->max_insn_bitsize)
2029 cd->max_insn_bitsize = isa->max_insn_bitsize;
2032 /* Data derived from the mach spec. */
2033 for (i = 0; i < MAX_MACHS; ++i)
2034 if (((1 << i) & machs) != 0)
2036 const CGEN_MACH *mach = & iq2000_cgen_mach_table[i];
2038 if (mach->insn_chunk_bitsize != 0)
2040 if (cd->insn_chunk_bitsize != 0 && cd->insn_chunk_bitsize != mach->insn_chunk_bitsize)
2042 fprintf (stderr, "iq2000_cgen_rebuild_tables: conflicting insn-chunk-bitsize values: `%d' vs. `%d'\n",
2043 cd->insn_chunk_bitsize, mach->insn_chunk_bitsize);
2044 abort ();
2047 cd->insn_chunk_bitsize = mach->insn_chunk_bitsize;
2051 /* Determine which hw elements are used by MACH. */
2052 build_hw_table (cd);
2054 /* Build the ifield table. */
2055 build_ifield_table (cd);
2057 /* Determine which operands are used by MACH/ISA. */
2058 build_operand_table (cd);
2060 /* Build the instruction table. */
2061 build_insn_table (cd);
2064 /* Initialize a cpu table and return a descriptor.
2065 It's much like opening a file, and must be the first function called.
2066 The arguments are a set of (type/value) pairs, terminated with
2067 CGEN_CPU_OPEN_END.
2069 Currently supported values:
2070 CGEN_CPU_OPEN_ISAS: bitmap of values in enum isa_attr
2071 CGEN_CPU_OPEN_MACHS: bitmap of values in enum mach_attr
2072 CGEN_CPU_OPEN_BFDMACH: specify 1 mach using bfd name
2073 CGEN_CPU_OPEN_ENDIAN: specify endian choice
2074 CGEN_CPU_OPEN_END: terminates arguments
2076 ??? Simultaneous multiple isas might not make sense, but it's not (yet)
2077 precluded.
2079 ??? We only support ISO C stdargs here, not K&R.
2080 Laziness, plus experiment to see if anything requires K&R - eventually
2081 K&R will no longer be supported - e.g. GDB is currently trying this. */
2083 CGEN_CPU_DESC
2084 iq2000_cgen_cpu_open (enum cgen_cpu_open_arg arg_type, ...)
2086 CGEN_CPU_TABLE *cd = (CGEN_CPU_TABLE *) xmalloc (sizeof (CGEN_CPU_TABLE));
2087 static int init_p;
2088 unsigned int isas = 0; /* 0 = "unspecified" */
2089 unsigned int machs = 0; /* 0 = "unspecified" */
2090 enum cgen_endian endian = CGEN_ENDIAN_UNKNOWN;
2091 va_list ap;
2093 if (! init_p)
2095 init_tables ();
2096 init_p = 1;
2099 memset (cd, 0, sizeof (*cd));
2101 va_start (ap, arg_type);
2102 while (arg_type != CGEN_CPU_OPEN_END)
2104 switch (arg_type)
2106 case CGEN_CPU_OPEN_ISAS :
2107 isas = va_arg (ap, unsigned int);
2108 break;
2109 case CGEN_CPU_OPEN_MACHS :
2110 machs = va_arg (ap, unsigned int);
2111 break;
2112 case CGEN_CPU_OPEN_BFDMACH :
2114 const char *name = va_arg (ap, const char *);
2115 const CGEN_MACH *mach =
2116 lookup_mach_via_bfd_name (iq2000_cgen_mach_table, name);
2118 machs |= 1 << mach->num;
2119 break;
2121 case CGEN_CPU_OPEN_ENDIAN :
2122 endian = va_arg (ap, enum cgen_endian);
2123 break;
2124 default :
2125 fprintf (stderr, "iq2000_cgen_cpu_open: unsupported argument `%d'\n",
2126 arg_type);
2127 abort (); /* ??? return NULL? */
2129 arg_type = va_arg (ap, enum cgen_cpu_open_arg);
2131 va_end (ap);
2133 /* mach unspecified means "all" */
2134 if (machs == 0)
2135 machs = (1 << MAX_MACHS) - 1;
2136 /* base mach is always selected */
2137 machs |= 1;
2138 /* isa unspecified means "all" */
2139 if (isas == 0)
2140 isas = (1 << MAX_ISAS) - 1;
2141 if (endian == CGEN_ENDIAN_UNKNOWN)
2143 /* ??? If target has only one, could have a default. */
2144 fprintf (stderr, "iq2000_cgen_cpu_open: no endianness specified\n");
2145 abort ();
2148 cd->isas = isas;
2149 cd->machs = machs;
2150 cd->endian = endian;
2151 /* FIXME: for the sparc case we can determine insn-endianness statically.
2152 The worry here is where both data and insn endian can be independently
2153 chosen, in which case this function will need another argument.
2154 Actually, will want to allow for more arguments in the future anyway. */
2155 cd->insn_endian = endian;
2157 /* Table (re)builder. */
2158 cd->rebuild_tables = iq2000_cgen_rebuild_tables;
2159 iq2000_cgen_rebuild_tables (cd);
2161 /* Default to not allowing signed overflow. */
2162 cd->signed_overflow_ok_p = 0;
2164 return (CGEN_CPU_DESC) cd;
2167 /* Cover fn to iq2000_cgen_cpu_open to handle the simple case of 1 isa, 1 mach.
2168 MACH_NAME is the bfd name of the mach. */
2170 CGEN_CPU_DESC
2171 iq2000_cgen_cpu_open_1 (mach_name, endian)
2172 const char *mach_name;
2173 enum cgen_endian endian;
2175 return iq2000_cgen_cpu_open (CGEN_CPU_OPEN_BFDMACH, mach_name,
2176 CGEN_CPU_OPEN_ENDIAN, endian,
2177 CGEN_CPU_OPEN_END);
2180 /* Close a cpu table.
2181 ??? This can live in a machine independent file, but there's currently
2182 no place to put this file (there's no libcgen). libopcodes is the wrong
2183 place as some simulator ports use this but they don't use libopcodes. */
2185 void
2186 iq2000_cgen_cpu_close (cd)
2187 CGEN_CPU_DESC cd;
2189 unsigned int i;
2190 const CGEN_INSN *insns;
2192 if (cd->macro_insn_table.init_entries)
2194 insns = cd->macro_insn_table.init_entries;
2195 for (i = 0; i < cd->macro_insn_table.num_init_entries; ++i, ++insns)
2197 if (CGEN_INSN_RX ((insns)))
2198 regfree (CGEN_INSN_RX (insns));
2202 if (cd->insn_table.init_entries)
2204 insns = cd->insn_table.init_entries;
2205 for (i = 0; i < cd->insn_table.num_init_entries; ++i, ++insns)
2207 if (CGEN_INSN_RX (insns))
2208 regfree (CGEN_INSN_RX (insns));
2214 if (cd->macro_insn_table.init_entries)
2215 free ((CGEN_INSN *) cd->macro_insn_table.init_entries);
2217 if (cd->insn_table.init_entries)
2218 free ((CGEN_INSN *) cd->insn_table.init_entries);
2220 if (cd->hw_table.entries)
2221 free ((CGEN_HW_ENTRY *) cd->hw_table.entries);
2223 if (cd->operand_table.entries)
2224 free ((CGEN_HW_ENTRY *) cd->operand_table.entries);
2226 free (cd);