]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - opcodes/xstormy16-desc.c
Fix testing gdb.rust/modules.exp against gdbserver
[thirdparty/binutils-gdb.git] / opcodes / xstormy16-desc.c
CommitLineData
4162bb66 1/* DO NOT EDIT! -*- buffer-read-only: t -*- vi:set ro: */
93fbbb04
GK
2/* CPU data for xstormy16.
3
4THIS FILE IS MACHINE GENERATED WITH CGEN.
5
2571583a 6Copyright (C) 1996-2017 Free Software Foundation, Inc.
93fbbb04
GK
7
8This file is part of the GNU Binutils and/or GDB, the GNU debugger.
9
9b201bb5
NC
10 This file is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 3, or (at your option)
13 any later version.
93fbbb04 14
9b201bb5
NC
15 It is distributed in the hope that it will be useful, but WITHOUT
16 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
17 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
18 License for more details.
93fbbb04 19
9b201bb5
NC
20 You should have received a copy of the GNU General Public License along
21 with this program; if not, write to the Free Software Foundation, Inc.,
22 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
93fbbb04
GK
23
24*/
25
26#include "sysdep.h"
27#include <stdio.h>
28#include <stdarg.h>
29#include "ansidecl.h"
30#include "bfd.h"
31#include "symcat.h"
32#include "xstormy16-desc.h"
33#include "xstormy16-opc.h"
34#include "opintl.h"
35#include "libiberty.h"
98f70fc4 36#include "xregex.h"
93fbbb04
GK
37
38/* Attributes. */
39
40static const CGEN_ATTR_ENTRY bool_attr[] =
41{
42 { "#f", 0 },
43 { "#t", 1 },
44 { 0, 0 }
45};
46
bf143b25 47static const CGEN_ATTR_ENTRY MACH_attr[] ATTRIBUTE_UNUSED =
93fbbb04
GK
48{
49 { "base", MACH_BASE },
50 { "xstormy16", MACH_XSTORMY16 },
51 { "max", MACH_MAX },
52 { 0, 0 }
53};
54
bf143b25 55static const CGEN_ATTR_ENTRY ISA_attr[] ATTRIBUTE_UNUSED =
93fbbb04
GK
56{
57 { "xstormy16", ISA_XSTORMY16 },
58 { "max", ISA_MAX },
59 { 0, 0 }
60};
61
62const CGEN_ATTR_TABLE xstormy16_cgen_ifield_attr_table[] =
63{
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 }
72};
73
74const CGEN_ATTR_TABLE xstormy16_cgen_hardware_attr_table[] =
75{
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 }
82};
83
84const CGEN_ATTR_TABLE xstormy16_cgen_operand_attr_table[] =
85{
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 }
96};
97
98const CGEN_ATTR_TABLE xstormy16_cgen_insn_attr_table[] =
99{
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] },
b11dcf4e 108 { "RELAXED", &bool_attr[0], &bool_attr[0] },
93fbbb04
GK
109 { "NO-DIS", &bool_attr[0], &bool_attr[0] },
110 { "PBB", &bool_attr[0], &bool_attr[0] },
111 { 0, 0, 0 }
112};
113
114/* Instruction set variants. */
115
116static const CGEN_ISA xstormy16_cgen_isa_table[] = {
117 { "xstormy16", 32, 32, 16, 32 },
118 { 0, 0, 0, 0, 0 }
119};
120
121/* Machine variants. */
122
123static const CGEN_MACH xstormy16_cgen_mach_table[] = {
124 { "xstormy16", "xstormy16", MACH_XSTORMY16, 16 },
125 { 0, 0, 0, 0 }
126};
127
128static CGEN_KEYWORD_ENTRY xstormy16_cgen_opval_gr_names_entries[] =
129{
fb53f5a8
DB
130 { "r0", 0, {0, {{{0, 0}}}}, 0, 0 },
131 { "r1", 1, {0, {{{0, 0}}}}, 0, 0 },
132 { "r2", 2, {0, {{{0, 0}}}}, 0, 0 },
133 { "r3", 3, {0, {{{0, 0}}}}, 0, 0 },
134 { "r4", 4, {0, {{{0, 0}}}}, 0, 0 },
135 { "r5", 5, {0, {{{0, 0}}}}, 0, 0 },
136 { "r6", 6, {0, {{{0, 0}}}}, 0, 0 },
137 { "r7", 7, {0, {{{0, 0}}}}, 0, 0 },
138 { "r8", 8, {0, {{{0, 0}}}}, 0, 0 },
139 { "r9", 9, {0, {{{0, 0}}}}, 0, 0 },
140 { "r10", 10, {0, {{{0, 0}}}}, 0, 0 },
141 { "r11", 11, {0, {{{0, 0}}}}, 0, 0 },
142 { "r12", 12, {0, {{{0, 0}}}}, 0, 0 },
143 { "r13", 13, {0, {{{0, 0}}}}, 0, 0 },
144 { "r14", 14, {0, {{{0, 0}}}}, 0, 0 },
145 { "r15", 15, {0, {{{0, 0}}}}, 0, 0 },
146 { "psw", 14, {0, {{{0, 0}}}}, 0, 0 },
147 { "sp", 15, {0, {{{0, 0}}}}, 0, 0 }
93fbbb04
GK
148};
149
150CGEN_KEYWORD xstormy16_cgen_opval_gr_names =
151{
152 & xstormy16_cgen_opval_gr_names_entries[0],
153 18,
154 0, 0, 0, 0, ""
155};
156
1951c6f7 157static CGEN_KEYWORD_ENTRY xstormy16_cgen_opval_gr_Rb_names_entries[] =
93fbbb04 158{
fb53f5a8
DB
159 { "r8", 0, {0, {{{0, 0}}}}, 0, 0 },
160 { "r9", 1, {0, {{{0, 0}}}}, 0, 0 },
161 { "r10", 2, {0, {{{0, 0}}}}, 0, 0 },
162 { "r11", 3, {0, {{{0, 0}}}}, 0, 0 },
163 { "r12", 4, {0, {{{0, 0}}}}, 0, 0 },
164 { "r13", 5, {0, {{{0, 0}}}}, 0, 0 },
165 { "r14", 6, {0, {{{0, 0}}}}, 0, 0 },
166 { "r15", 7, {0, {{{0, 0}}}}, 0, 0 },
167 { "psw", 6, {0, {{{0, 0}}}}, 0, 0 },
168 { "sp", 7, {0, {{{0, 0}}}}, 0, 0 }
93fbbb04
GK
169};
170
1951c6f7 171CGEN_KEYWORD xstormy16_cgen_opval_gr_Rb_names =
93fbbb04 172{
1951c6f7
MG
173 & xstormy16_cgen_opval_gr_Rb_names_entries[0],
174 10,
93fbbb04
GK
175 0, 0, 0, 0, ""
176};
177
178static CGEN_KEYWORD_ENTRY xstormy16_cgen_opval_h_branchcond_entries[] =
179{
fb53f5a8
DB
180 { "ge", 0, {0, {{{0, 0}}}}, 0, 0 },
181 { "nc", 1, {0, {{{0, 0}}}}, 0, 0 },
182 { "lt", 2, {0, {{{0, 0}}}}, 0, 0 },
183 { "c", 3, {0, {{{0, 0}}}}, 0, 0 },
184 { "gt", 4, {0, {{{0, 0}}}}, 0, 0 },
185 { "hi", 5, {0, {{{0, 0}}}}, 0, 0 },
186 { "le", 6, {0, {{{0, 0}}}}, 0, 0 },
187 { "ls", 7, {0, {{{0, 0}}}}, 0, 0 },
188 { "pl", 8, {0, {{{0, 0}}}}, 0, 0 },
189 { "nv", 9, {0, {{{0, 0}}}}, 0, 0 },
190 { "mi", 10, {0, {{{0, 0}}}}, 0, 0 },
191 { "v", 11, {0, {{{0, 0}}}}, 0, 0 },
192 { "nz.b", 12, {0, {{{0, 0}}}}, 0, 0 },
193 { "nz", 13, {0, {{{0, 0}}}}, 0, 0 },
194 { "z.b", 14, {0, {{{0, 0}}}}, 0, 0 },
195 { "z", 15, {0, {{{0, 0}}}}, 0, 0 }
93fbbb04
GK
196};
197
198CGEN_KEYWORD xstormy16_cgen_opval_h_branchcond =
199{
200 & xstormy16_cgen_opval_h_branchcond_entries[0],
201 16,
202 0, 0, 0, 0, ""
203};
204
205static CGEN_KEYWORD_ENTRY xstormy16_cgen_opval_h_wordsize_entries[] =
206{
fb53f5a8
DB
207 { ".b", 0, {0, {{{0, 0}}}}, 0, 0 },
208 { ".w", 1, {0, {{{0, 0}}}}, 0, 0 },
209 { "", 1, {0, {{{0, 0}}}}, 0, 0 }
93fbbb04
GK
210};
211
212CGEN_KEYWORD xstormy16_cgen_opval_h_wordsize =
213{
214 & xstormy16_cgen_opval_h_wordsize_entries[0],
215 3,
216 0, 0, 0, 0, ""
217};
218
219
220/* The hardware table. */
221
93fbbb04 222#define A(a) (1 << CGEN_HW_##a)
93fbbb04
GK
223
224const CGEN_HW_ENTRY xstormy16_cgen_hw_table[] =
225{
fb53f5a8
DB
226 { "h-memory", HW_H_MEMORY, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
227 { "h-sint", HW_H_SINT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
228 { "h-uint", HW_H_UINT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
229 { "h-addr", HW_H_ADDR, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
230 { "h-iaddr", HW_H_IADDR, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
231 { "h-pc", HW_H_PC, CGEN_ASM_NONE, 0, { 0|A(PC), { { { (1<<MACH_BASE), 0 } } } } },
232 { "h-gr", HW_H_GR, CGEN_ASM_KEYWORD, (PTR) & xstormy16_cgen_opval_gr_names, { 0, { { { (1<<MACH_BASE), 0 } } } } },
233 { "h-Rb", HW_H_RB, CGEN_ASM_KEYWORD, (PTR) & xstormy16_cgen_opval_gr_Rb_names, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
234 { "h-Rbj", HW_H_RBJ, CGEN_ASM_KEYWORD, (PTR) & xstormy16_cgen_opval_gr_Rb_names, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
235 { "h-Rpsw", HW_H_RPSW, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
236 { "h-z8", HW_H_Z8, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
237 { "h-z16", HW_H_Z16, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
238 { "h-cy", HW_H_CY, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
239 { "h-hc", HW_H_HC, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
240 { "h-ov", HW_H_OV, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
241 { "h-pt", HW_H_PT, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
242 { "h-s", HW_H_S, CGEN_ASM_NONE, 0, { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
243 { "h-branchcond", HW_H_BRANCHCOND, CGEN_ASM_KEYWORD, (PTR) & xstormy16_cgen_opval_h_branchcond, { 0, { { { (1<<MACH_BASE), 0 } } } } },
244 { "h-wordsize", HW_H_WORDSIZE, CGEN_ASM_KEYWORD, (PTR) & xstormy16_cgen_opval_h_wordsize, { 0, { { { (1<<MACH_BASE), 0 } } } } },
245 { 0, 0, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } }
93fbbb04
GK
246};
247
248#undef A
249
250
251/* The instruction field table. */
252
93fbbb04 253#define A(a) (1 << CGEN_IFLD_##a)
93fbbb04
GK
254
255const CGEN_IFLD xstormy16_cgen_ifld_table[] =
256{
fb53f5a8
DB
257 { XSTORMY16_F_NIL, "f-nil", 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
258 { XSTORMY16_F_ANYOF, "f-anyof", 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
259 { XSTORMY16_F_RD, "f-Rd", 0, 32, 12, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
260 { XSTORMY16_F_RDM, "f-Rdm", 0, 32, 13, 3, { 0, { { { (1<<MACH_BASE), 0 } } } } },
261 { XSTORMY16_F_RM, "f-Rm", 0, 32, 4, 3, { 0, { { { (1<<MACH_BASE), 0 } } } } },
262 { XSTORMY16_F_RS, "f-Rs", 0, 32, 8, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
263 { XSTORMY16_F_RB, "f-Rb", 0, 32, 17, 3, { 0, { { { (1<<MACH_BASE), 0 } } } } },
264 { XSTORMY16_F_RBJ, "f-Rbj", 0, 32, 11, 1, { 0, { { { (1<<MACH_BASE), 0 } } } } },
265 { XSTORMY16_F_OP1, "f-op1", 0, 32, 0, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
266 { XSTORMY16_F_OP2, "f-op2", 0, 32, 4, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
267 { XSTORMY16_F_OP2A, "f-op2a", 0, 32, 4, 3, { 0, { { { (1<<MACH_BASE), 0 } } } } },
268 { XSTORMY16_F_OP2M, "f-op2m", 0, 32, 7, 1, { 0, { { { (1<<MACH_BASE), 0 } } } } },
269 { XSTORMY16_F_OP3, "f-op3", 0, 32, 8, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
270 { XSTORMY16_F_OP3A, "f-op3a", 0, 32, 8, 2, { 0, { { { (1<<MACH_BASE), 0 } } } } },
271 { XSTORMY16_F_OP3B, "f-op3b", 0, 32, 8, 3, { 0, { { { (1<<MACH_BASE), 0 } } } } },
272 { XSTORMY16_F_OP4, "f-op4", 0, 32, 12, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
273 { XSTORMY16_F_OP4M, "f-op4m", 0, 32, 12, 1, { 0, { { { (1<<MACH_BASE), 0 } } } } },
274 { XSTORMY16_F_OP4B, "f-op4b", 0, 32, 15, 1, { 0, { { { (1<<MACH_BASE), 0 } } } } },
275 { XSTORMY16_F_OP5, "f-op5", 0, 32, 16, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
276 { XSTORMY16_F_OP5A, "f-op5a", 0, 32, 16, 1, { 0, { { { (1<<MACH_BASE), 0 } } } } },
277 { XSTORMY16_F_OP, "f-op", 0, 32, 0, 16, { 0, { { { (1<<MACH_BASE), 0 } } } } },
278 { XSTORMY16_F_IMM2, "f-imm2", 0, 32, 10, 2, { 0, { { { (1<<MACH_BASE), 0 } } } } },
279 { XSTORMY16_F_IMM3, "f-imm3", 0, 32, 4, 3, { 0, { { { (1<<MACH_BASE), 0 } } } } },
280 { XSTORMY16_F_IMM3B, "f-imm3b", 0, 32, 17, 3, { 0, { { { (1<<MACH_BASE), 0 } } } } },
281 { XSTORMY16_F_IMM4, "f-imm4", 0, 32, 8, 4, { 0, { { { (1<<MACH_BASE), 0 } } } } },
282 { XSTORMY16_F_IMM8, "f-imm8", 0, 32, 8, 8, { 0, { { { (1<<MACH_BASE), 0 } } } } },
283 { XSTORMY16_F_IMM12, "f-imm12", 0, 32, 20, 12, { 0, { { { (1<<MACH_BASE), 0 } } } } },
284 { XSTORMY16_F_IMM16, "f-imm16", 0, 32, 16, 16, { 0|A(SIGN_OPT), { { { (1<<MACH_BASE), 0 } } } } },
285 { XSTORMY16_F_LMEM8, "f-lmem8", 0, 32, 8, 8, { 0|A(ABS_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
286 { XSTORMY16_F_HMEM8, "f-hmem8", 0, 32, 8, 8, { 0|A(ABS_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
287 { XSTORMY16_F_REL8_2, "f-rel8-2", 0, 32, 8, 8, { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
288 { XSTORMY16_F_REL8_4, "f-rel8-4", 0, 32, 8, 8, { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
289 { XSTORMY16_F_REL12, "f-rel12", 0, 32, 20, 12, { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
290 { XSTORMY16_F_REL12A, "f-rel12a", 0, 32, 4, 11, { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
291 { XSTORMY16_F_ABS24_1, "f-abs24-1", 0, 32, 8, 8, { 0, { { { (1<<MACH_BASE), 0 } } } } },
292 { XSTORMY16_F_ABS24_2, "f-abs24-2", 0, 32, 16, 16, { 0, { { { (1<<MACH_BASE), 0 } } } } },
293 { XSTORMY16_F_ABS24, "f-abs24", 0, 0, 0, 0,{ 0|A(ABS_ADDR)|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
294 { 0, 0, 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } }
93fbbb04
GK
295};
296
297#undef A
298
299
9a2e995d
GH
300
301/* multi ifield declarations */
302
303const CGEN_MAYBE_MULTI_IFLD XSTORMY16_F_ABS24_MULTI_IFIELD [];
304
305
306/* multi ifield definitions */
307
308const CGEN_MAYBE_MULTI_IFLD XSTORMY16_F_ABS24_MULTI_IFIELD [] =
309{
390ff83f
DE
310 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_ABS24_1] } },
311 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_ABS24_2] } },
98f70fc4 312 { 0, { (const PTR) 0 } }
9a2e995d
GH
313};
314
93fbbb04
GK
315/* The operand table. */
316
93fbbb04 317#define A(a) (1 << CGEN_OPERAND_##a)
93fbbb04 318#define OPERAND(op) XSTORMY16_OPERAND_##op
93fbbb04
GK
319
320const CGEN_OPERAND xstormy16_cgen_operand_table[] =
321{
322/* pc: program counter */
323 { "pc", XSTORMY16_OPERAND_PC, HW_H_PC, 0, 0,
43e65147 324 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_NIL] } },
fb53f5a8 325 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
326/* psw-z8: */
327 { "psw-z8", XSTORMY16_OPERAND_PSW_Z8, HW_H_Z8, 0, 0,
43e65147 328 { 0, { (const PTR) 0 } },
fb53f5a8 329 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
330/* psw-z16: */
331 { "psw-z16", XSTORMY16_OPERAND_PSW_Z16, HW_H_Z16, 0, 0,
43e65147 332 { 0, { (const PTR) 0 } },
fb53f5a8 333 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
334/* psw-cy: */
335 { "psw-cy", XSTORMY16_OPERAND_PSW_CY, HW_H_CY, 0, 0,
43e65147 336 { 0, { (const PTR) 0 } },
fb53f5a8 337 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
338/* psw-hc: */
339 { "psw-hc", XSTORMY16_OPERAND_PSW_HC, HW_H_HC, 0, 0,
43e65147 340 { 0, { (const PTR) 0 } },
fb53f5a8 341 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
342/* psw-ov: */
343 { "psw-ov", XSTORMY16_OPERAND_PSW_OV, HW_H_OV, 0, 0,
43e65147 344 { 0, { (const PTR) 0 } },
fb53f5a8 345 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
346/* psw-pt: */
347 { "psw-pt", XSTORMY16_OPERAND_PSW_PT, HW_H_PT, 0, 0,
43e65147 348 { 0, { (const PTR) 0 } },
fb53f5a8 349 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
350/* psw-s: */
351 { "psw-s", XSTORMY16_OPERAND_PSW_S, HW_H_S, 0, 0,
43e65147 352 { 0, { (const PTR) 0 } },
fb53f5a8 353 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
354/* Rd: general register destination */
355 { "Rd", XSTORMY16_OPERAND_RD, HW_H_GR, 12, 4,
43e65147 356 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_RD] } },
fb53f5a8 357 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
358/* Rdm: general register destination */
359 { "Rdm", XSTORMY16_OPERAND_RDM, HW_H_GR, 13, 3,
43e65147 360 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_RDM] } },
fb53f5a8 361 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
362/* Rm: general register for memory */
363 { "Rm", XSTORMY16_OPERAND_RM, HW_H_GR, 4, 3,
43e65147 364 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_RM] } },
fb53f5a8 365 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
366/* Rs: general register source */
367 { "Rs", XSTORMY16_OPERAND_RS, HW_H_GR, 8, 4,
43e65147 368 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_RS] } },
fb53f5a8 369 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04 370/* Rb: base register */
1951c6f7 371 { "Rb", XSTORMY16_OPERAND_RB, HW_H_RB, 17, 3,
43e65147 372 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_RB] } },
fb53f5a8 373 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
374/* Rbj: base register for jump */
375 { "Rbj", XSTORMY16_OPERAND_RBJ, HW_H_RBJ, 11, 1,
43e65147 376 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_RBJ] } },
fb53f5a8 377 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
378/* bcond2: branch condition opcode */
379 { "bcond2", XSTORMY16_OPERAND_BCOND2, HW_H_BRANCHCOND, 4, 4,
43e65147 380 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_OP2] } },
fb53f5a8 381 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
382/* ws2: word size opcode */
383 { "ws2", XSTORMY16_OPERAND_WS2, HW_H_WORDSIZE, 7, 1,
43e65147 384 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_OP2M] } },
fb53f5a8 385 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
386/* bcond5: branch condition opcode */
387 { "bcond5", XSTORMY16_OPERAND_BCOND5, HW_H_BRANCHCOND, 16, 4,
43e65147 388 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_OP5] } },
fb53f5a8 389 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
390/* imm2: 2 bit unsigned immediate */
391 { "imm2", XSTORMY16_OPERAND_IMM2, HW_H_UINT, 10, 2,
43e65147 392 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM2] } },
fb53f5a8 393 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
394/* imm3: 3 bit unsigned immediate */
395 { "imm3", XSTORMY16_OPERAND_IMM3, HW_H_UINT, 4, 3,
43e65147 396 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM3] } },
fb53f5a8 397 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
398/* imm3b: 3 bit unsigned immediate for bit tests */
399 { "imm3b", XSTORMY16_OPERAND_IMM3B, HW_H_UINT, 17, 3,
43e65147 400 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM3B] } },
fb53f5a8 401 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
402/* imm4: 4 bit unsigned immediate */
403 { "imm4", XSTORMY16_OPERAND_IMM4, HW_H_UINT, 8, 4,
43e65147 404 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM4] } },
fb53f5a8 405 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
406/* imm8: 8 bit unsigned immediate */
407 { "imm8", XSTORMY16_OPERAND_IMM8, HW_H_UINT, 8, 8,
43e65147 408 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM8] } },
fb53f5a8 409 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
410/* imm8small: 8 bit unsigned immediate */
411 { "imm8small", XSTORMY16_OPERAND_IMM8SMALL, HW_H_UINT, 8, 8,
43e65147 412 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM8] } },
fb53f5a8 413 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
414/* imm12: 12 bit signed immediate */
415 { "imm12", XSTORMY16_OPERAND_IMM12, HW_H_SINT, 20, 12,
43e65147 416 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM12] } },
fb53f5a8 417 { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
418/* imm16: 16 bit immediate */
419 { "imm16", XSTORMY16_OPERAND_IMM16, HW_H_UINT, 16, 16,
43e65147 420 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_IMM16] } },
fb53f5a8 421 { 0|A(SIGN_OPT), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
422/* lmem8: 8 bit unsigned immediate low memory */
423 { "lmem8", XSTORMY16_OPERAND_LMEM8, HW_H_UINT, 8, 8,
43e65147 424 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_LMEM8] } },
fb53f5a8 425 { 0|A(ABS_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
426/* hmem8: 8 bit unsigned immediate high memory */
427 { "hmem8", XSTORMY16_OPERAND_HMEM8, HW_H_UINT, 8, 8,
43e65147 428 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_HMEM8] } },
fb53f5a8 429 { 0|A(ABS_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
430/* rel8-2: 8 bit relative address */
431 { "rel8-2", XSTORMY16_OPERAND_REL8_2, HW_H_UINT, 8, 8,
43e65147 432 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_REL8_2] } },
fb53f5a8 433 { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
434/* rel8-4: 8 bit relative address */
435 { "rel8-4", XSTORMY16_OPERAND_REL8_4, HW_H_UINT, 8, 8,
43e65147 436 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_REL8_4] } },
fb53f5a8 437 { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
438/* rel12: 12 bit relative address */
439 { "rel12", XSTORMY16_OPERAND_REL12, HW_H_UINT, 20, 12,
43e65147 440 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_REL12] } },
fb53f5a8 441 { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
442/* rel12a: 12 bit relative address */
443 { "rel12a", XSTORMY16_OPERAND_REL12A, HW_H_UINT, 4, 11,
43e65147 444 { 0, { (const PTR) &xstormy16_cgen_ifld_table[XSTORMY16_F_REL12A] } },
fb53f5a8 445 { 0|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
446/* abs24: 24 bit absolute address */
447 { "abs24", XSTORMY16_OPERAND_ABS24, HW_H_UINT, 8, 24,
43e65147 448 { 2, { (const PTR) &XSTORMY16_F_ABS24_MULTI_IFIELD[0] } },
fb53f5a8 449 { 0|A(ABS_ADDR)|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
450/* psw: program status word */
451 { "psw", XSTORMY16_OPERAND_PSW, HW_H_GR, 0, 0,
43e65147 452 { 0, { (const PTR) 0 } },
fb53f5a8 453 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
454/* Rpsw: N0-N3 of the program status word */
455 { "Rpsw", XSTORMY16_OPERAND_RPSW, HW_H_RPSW, 0, 0,
43e65147 456 { 0, { (const PTR) 0 } },
fb53f5a8 457 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
458/* sp: stack pointer */
459 { "sp", XSTORMY16_OPERAND_SP, HW_H_GR, 0, 0,
43e65147 460 { 0, { (const PTR) 0 } },
fb53f5a8 461 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
462/* R0: R0 */
463 { "R0", XSTORMY16_OPERAND_R0, HW_H_GR, 0, 0,
43e65147 464 { 0, { (const PTR) 0 } },
fb53f5a8 465 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
466/* R1: R1 */
467 { "R1", XSTORMY16_OPERAND_R1, HW_H_GR, 0, 0,
43e65147 468 { 0, { (const PTR) 0 } },
fb53f5a8 469 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
470/* R2: R2 */
471 { "R2", XSTORMY16_OPERAND_R2, HW_H_GR, 0, 0,
43e65147 472 { 0, { (const PTR) 0 } },
fb53f5a8 473 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
474/* R8: R8 */
475 { "R8", XSTORMY16_OPERAND_R8, HW_H_GR, 0, 0,
43e65147 476 { 0, { (const PTR) 0 } },
fb53f5a8 477 { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } } },
98f70fc4
AM
478/* sentinel */
479 { 0, 0, 0, 0, 0,
480 { 0, { (const PTR) 0 } },
fb53f5a8 481 { 0, { { { (1<<MACH_BASE), 0 } } } } }
93fbbb04
GK
482};
483
484#undef A
485
486
487/* The instruction table. */
488
489#define OP(field) CGEN_SYNTAX_MAKE_FIELD (OPERAND (field))
93fbbb04 490#define A(a) (1 << CGEN_INSN_##a)
93fbbb04
GK
491
492static const CGEN_IBASE xstormy16_cgen_insn_table[MAX_INSNS] =
493{
494 /* Special null first entry.
495 A `num' value of zero is thus invalid.
496 Also, the special `invalid' insn resides here. */
fb53f5a8 497 { 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
93fbbb04
GK
498/* mov$ws2 $lmem8,#$imm16 */
499 {
500 XSTORMY16_INSN_MOVLMEMIMM, "movlmemimm", "mov", 32,
fb53f5a8 501 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
502 },
503/* mov$ws2 $hmem8,#$imm16 */
504 {
505 XSTORMY16_INSN_MOVHMEMIMM, "movhmemimm", "mov", 32,
fb53f5a8 506 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
507 },
508/* mov$ws2 $Rm,$lmem8 */
509 {
510 XSTORMY16_INSN_MOVLGRMEM, "movlgrmem", "mov", 16,
fb53f5a8 511 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
512 },
513/* mov$ws2 $Rm,$hmem8 */
514 {
515 XSTORMY16_INSN_MOVHGRMEM, "movhgrmem", "mov", 16,
fb53f5a8 516 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
517 },
518/* mov$ws2 $lmem8,$Rm */
519 {
520 XSTORMY16_INSN_MOVLMEMGR, "movlmemgr", "mov", 16,
fb53f5a8 521 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
522 },
523/* mov$ws2 $hmem8,$Rm */
524 {
525 XSTORMY16_INSN_MOVHMEMGR, "movhmemgr", "mov", 16,
fb53f5a8 526 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
527 },
528/* mov$ws2 $Rdm,($Rs) */
529 {
530 XSTORMY16_INSN_MOVGRGRI, "movgrgri", "mov", 16,
fb53f5a8 531 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
532 },
533/* mov$ws2 $Rdm,($Rs++) */
534 {
535 XSTORMY16_INSN_MOVGRGRIPOSTINC, "movgrgripostinc", "mov", 16,
fb53f5a8 536 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
537 },
538/* mov$ws2 $Rdm,(--$Rs) */
539 {
540 XSTORMY16_INSN_MOVGRGRIPREDEC, "movgrgripredec", "mov", 16,
fb53f5a8 541 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
542 },
543/* mov$ws2 ($Rs),$Rdm */
544 {
545 XSTORMY16_INSN_MOVGRIGR, "movgrigr", "mov", 16,
fb53f5a8 546 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
547 },
548/* mov$ws2 ($Rs++),$Rdm */
549 {
550 XSTORMY16_INSN_MOVGRIPOSTINCGR, "movgripostincgr", "mov", 16,
fb53f5a8 551 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
552 },
553/* mov$ws2 (--$Rs),$Rdm */
554 {
555 XSTORMY16_INSN_MOVGRIPREDECGR, "movgripredecgr", "mov", 16,
fb53f5a8 556 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
557 },
558/* mov$ws2 $Rdm,($Rs,$imm12) */
559 {
560 XSTORMY16_INSN_MOVGRGRII, "movgrgrii", "mov", 32,
fb53f5a8 561 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
562 },
563/* mov$ws2 $Rdm,($Rs++,$imm12) */
564 {
565 XSTORMY16_INSN_MOVGRGRIIPOSTINC, "movgrgriipostinc", "mov", 32,
fb53f5a8 566 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
567 },
568/* mov$ws2 $Rdm,(--$Rs,$imm12) */
569 {
570 XSTORMY16_INSN_MOVGRGRIIPREDEC, "movgrgriipredec", "mov", 32,
fb53f5a8 571 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
572 },
573/* mov$ws2 ($Rs,$imm12),$Rdm */
574 {
575 XSTORMY16_INSN_MOVGRIIGR, "movgriigr", "mov", 32,
fb53f5a8 576 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
577 },
578/* mov$ws2 ($Rs++,$imm12),$Rdm */
579 {
580 XSTORMY16_INSN_MOVGRIIPOSTINCGR, "movgriipostincgr", "mov", 32,
fb53f5a8 581 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
582 },
583/* mov$ws2 (--$Rs,$imm12),$Rdm */
584 {
585 XSTORMY16_INSN_MOVGRIIPREDECGR, "movgriipredecgr", "mov", 32,
fb53f5a8 586 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
587 },
588/* mov $Rd,$Rs */
589 {
590 XSTORMY16_INSN_MOVGRGR, "movgrgr", "mov", 16,
fb53f5a8 591 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
592 },
593/* mov.w Rx,#$imm8 */
594 {
595 XSTORMY16_INSN_MOVWIMM8, "movwimm8", "mov.w", 16,
fb53f5a8 596 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
597 },
598/* mov.w $Rm,#$imm8small */
599 {
600 XSTORMY16_INSN_MOVWGRIMM8, "movwgrimm8", "mov.w", 16,
fb53f5a8 601 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
602 },
603/* mov.w $Rd,#$imm16 */
604 {
605 XSTORMY16_INSN_MOVWGRIMM16, "movwgrimm16", "mov.w", 32,
fb53f5a8 606 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
607 },
608/* mov.b $Rd,RxL */
609 {
610 XSTORMY16_INSN_MOVLOWGR, "movlowgr", "mov.b", 16,
fb53f5a8 611 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
612 },
613/* mov.b $Rd,RxH */
614 {
615 XSTORMY16_INSN_MOVHIGHGR, "movhighgr", "mov.b", 16,
fb53f5a8 616 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
617 },
618/* movf$ws2 $Rdm,($Rs) */
619 {
620 XSTORMY16_INSN_MOVFGRGRI, "movfgrgri", "movf", 16,
fb53f5a8 621 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
622 },
623/* movf$ws2 $Rdm,($Rs++) */
624 {
625 XSTORMY16_INSN_MOVFGRGRIPOSTINC, "movfgrgripostinc", "movf", 16,
fb53f5a8 626 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
627 },
628/* movf$ws2 $Rdm,(--$Rs) */
629 {
630 XSTORMY16_INSN_MOVFGRGRIPREDEC, "movfgrgripredec", "movf", 16,
fb53f5a8 631 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
632 },
633/* movf$ws2 ($Rs),$Rdm */
634 {
635 XSTORMY16_INSN_MOVFGRIGR, "movfgrigr", "movf", 16,
fb53f5a8 636 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
637 },
638/* movf$ws2 ($Rs++),$Rdm */
639 {
640 XSTORMY16_INSN_MOVFGRIPOSTINCGR, "movfgripostincgr", "movf", 16,
fb53f5a8 641 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
642 },
643/* movf$ws2 (--$Rs),$Rdm */
644 {
645 XSTORMY16_INSN_MOVFGRIPREDECGR, "movfgripredecgr", "movf", 16,
fb53f5a8 646 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
647 },
648/* movf$ws2 $Rdm,($Rb,$Rs,$imm12) */
649 {
650 XSTORMY16_INSN_MOVFGRGRII, "movfgrgrii", "movf", 32,
fb53f5a8 651 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
652 },
653/* movf$ws2 $Rdm,($Rb,$Rs++,$imm12) */
654 {
655 XSTORMY16_INSN_MOVFGRGRIIPOSTINC, "movfgrgriipostinc", "movf", 32,
fb53f5a8 656 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
657 },
658/* movf$ws2 $Rdm,($Rb,--$Rs,$imm12) */
659 {
660 XSTORMY16_INSN_MOVFGRGRIIPREDEC, "movfgrgriipredec", "movf", 32,
fb53f5a8 661 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
662 },
663/* movf$ws2 ($Rb,$Rs,$imm12),$Rdm */
664 {
665 XSTORMY16_INSN_MOVFGRIIGR, "movfgriigr", "movf", 32,
fb53f5a8 666 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
667 },
668/* movf$ws2 ($Rb,$Rs++,$imm12),$Rdm */
669 {
670 XSTORMY16_INSN_MOVFGRIIPOSTINCGR, "movfgriipostincgr", "movf", 32,
fb53f5a8 671 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
672 },
673/* movf$ws2 ($Rb,--$Rs,$imm12),$Rdm */
674 {
675 XSTORMY16_INSN_MOVFGRIIPREDECGR, "movfgriipredecgr", "movf", 32,
fb53f5a8 676 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
677 },
678/* mask $Rd,$Rs */
679 {
680 XSTORMY16_INSN_MASKGRGR, "maskgrgr", "mask", 16,
fb53f5a8 681 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
682 },
683/* mask $Rd,#$imm16 */
684 {
685 XSTORMY16_INSN_MASKGRIMM16, "maskgrimm16", "mask", 32,
fb53f5a8 686 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
687 },
688/* push $Rd */
689 {
690 XSTORMY16_INSN_PUSHGR, "pushgr", "push", 16,
fb53f5a8 691 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
692 },
693/* pop $Rd */
694 {
695 XSTORMY16_INSN_POPGR, "popgr", "pop", 16,
fb53f5a8 696 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
697 },
698/* swpn $Rd */
699 {
700 XSTORMY16_INSN_SWPN, "swpn", "swpn", 16,
fb53f5a8 701 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
702 },
703/* swpb $Rd */
704 {
705 XSTORMY16_INSN_SWPB, "swpb", "swpb", 16,
fb53f5a8 706 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
707 },
708/* swpw $Rd,$Rs */
709 {
710 XSTORMY16_INSN_SWPW, "swpw", "swpw", 16,
fb53f5a8 711 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
712 },
713/* and $Rd,$Rs */
714 {
715 XSTORMY16_INSN_ANDGRGR, "andgrgr", "and", 16,
fb53f5a8 716 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
717 },
718/* and Rx,#$imm8 */
719 {
720 XSTORMY16_INSN_ANDIMM8, "andimm8", "and", 16,
fb53f5a8 721 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
722 },
723/* and $Rd,#$imm16 */
724 {
725 XSTORMY16_INSN_ANDGRIMM16, "andgrimm16", "and", 32,
fb53f5a8 726 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
727 },
728/* or $Rd,$Rs */
729 {
730 XSTORMY16_INSN_ORGRGR, "orgrgr", "or", 16,
fb53f5a8 731 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
732 },
733/* or Rx,#$imm8 */
734 {
735 XSTORMY16_INSN_ORIMM8, "orimm8", "or", 16,
fb53f5a8 736 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
737 },
738/* or $Rd,#$imm16 */
739 {
740 XSTORMY16_INSN_ORGRIMM16, "orgrimm16", "or", 32,
fb53f5a8 741 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
742 },
743/* xor $Rd,$Rs */
744 {
745 XSTORMY16_INSN_XORGRGR, "xorgrgr", "xor", 16,
fb53f5a8 746 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
747 },
748/* xor Rx,#$imm8 */
749 {
750 XSTORMY16_INSN_XORIMM8, "xorimm8", "xor", 16,
fb53f5a8 751 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
752 },
753/* xor $Rd,#$imm16 */
754 {
755 XSTORMY16_INSN_XORGRIMM16, "xorgrimm16", "xor", 32,
fb53f5a8 756 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
757 },
758/* not $Rd */
759 {
760 XSTORMY16_INSN_NOTGR, "notgr", "not", 16,
fb53f5a8 761 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
762 },
763/* add $Rd,$Rs */
764 {
765 XSTORMY16_INSN_ADDGRGR, "addgrgr", "add", 16,
fb53f5a8 766 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
767 },
768/* add $Rd,#$imm4 */
769 {
770 XSTORMY16_INSN_ADDGRIMM4, "addgrimm4", "add", 16,
fb53f5a8 771 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
772 },
773/* add Rx,#$imm8 */
774 {
775 XSTORMY16_INSN_ADDIMM8, "addimm8", "add", 16,
fb53f5a8 776 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
777 },
778/* add $Rd,#$imm16 */
779 {
780 XSTORMY16_INSN_ADDGRIMM16, "addgrimm16", "add", 32,
fb53f5a8 781 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
782 },
783/* adc $Rd,$Rs */
784 {
785 XSTORMY16_INSN_ADCGRGR, "adcgrgr", "adc", 16,
fb53f5a8 786 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
787 },
788/* adc $Rd,#$imm4 */
789 {
790 XSTORMY16_INSN_ADCGRIMM4, "adcgrimm4", "adc", 16,
fb53f5a8 791 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
792 },
793/* adc Rx,#$imm8 */
794 {
795 XSTORMY16_INSN_ADCIMM8, "adcimm8", "adc", 16,
fb53f5a8 796 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
797 },
798/* adc $Rd,#$imm16 */
799 {
800 XSTORMY16_INSN_ADCGRIMM16, "adcgrimm16", "adc", 32,
fb53f5a8 801 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
802 },
803/* sub $Rd,$Rs */
804 {
805 XSTORMY16_INSN_SUBGRGR, "subgrgr", "sub", 16,
fb53f5a8 806 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
807 },
808/* sub $Rd,#$imm4 */
809 {
810 XSTORMY16_INSN_SUBGRIMM4, "subgrimm4", "sub", 16,
fb53f5a8 811 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
812 },
813/* sub Rx,#$imm8 */
814 {
815 XSTORMY16_INSN_SUBIMM8, "subimm8", "sub", 16,
fb53f5a8 816 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
817 },
818/* sub $Rd,#$imm16 */
819 {
820 XSTORMY16_INSN_SUBGRIMM16, "subgrimm16", "sub", 32,
fb53f5a8 821 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
822 },
823/* sbc $Rd,$Rs */
824 {
825 XSTORMY16_INSN_SBCGRGR, "sbcgrgr", "sbc", 16,
fb53f5a8 826 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
827 },
828/* sbc $Rd,#$imm4 */
829 {
830 XSTORMY16_INSN_SBCGRIMM4, "sbcgrimm4", "sbc", 16,
fb53f5a8 831 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
832 },
833/* sbc Rx,#$imm8 */
834 {
835 XSTORMY16_INSN_SBCGRIMM8, "sbcgrimm8", "sbc", 16,
fb53f5a8 836 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
837 },
838/* sbc $Rd,#$imm16 */
839 {
840 XSTORMY16_INSN_SBCGRIMM16, "sbcgrimm16", "sbc", 32,
fb53f5a8 841 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
842 },
843/* inc $Rd,#$imm2 */
844 {
845 XSTORMY16_INSN_INCGRIMM2, "incgrimm2", "inc", 16,
fb53f5a8 846 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
847 },
848/* dec $Rd,#$imm2 */
849 {
850 XSTORMY16_INSN_DECGRIMM2, "decgrimm2", "dec", 16,
fb53f5a8 851 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
852 },
853/* rrc $Rd,$Rs */
854 {
855 XSTORMY16_INSN_RRCGRGR, "rrcgrgr", "rrc", 16,
fb53f5a8 856 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
857 },
858/* rrc $Rd,#$imm4 */
859 {
860 XSTORMY16_INSN_RRCGRIMM4, "rrcgrimm4", "rrc", 16,
fb53f5a8 861 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
862 },
863/* rlc $Rd,$Rs */
864 {
865 XSTORMY16_INSN_RLCGRGR, "rlcgrgr", "rlc", 16,
fb53f5a8 866 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
867 },
868/* rlc $Rd,#$imm4 */
869 {
870 XSTORMY16_INSN_RLCGRIMM4, "rlcgrimm4", "rlc", 16,
fb53f5a8 871 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
872 },
873/* shr $Rd,$Rs */
874 {
875 XSTORMY16_INSN_SHRGRGR, "shrgrgr", "shr", 16,
fb53f5a8 876 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
877 },
878/* shr $Rd,#$imm4 */
879 {
880 XSTORMY16_INSN_SHRGRIMM, "shrgrimm", "shr", 16,
fb53f5a8 881 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
882 },
883/* shl $Rd,$Rs */
884 {
885 XSTORMY16_INSN_SHLGRGR, "shlgrgr", "shl", 16,
fb53f5a8 886 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
887 },
888/* shl $Rd,#$imm4 */
889 {
890 XSTORMY16_INSN_SHLGRIMM, "shlgrimm", "shl", 16,
fb53f5a8 891 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
892 },
893/* asr $Rd,$Rs */
894 {
895 XSTORMY16_INSN_ASRGRGR, "asrgrgr", "asr", 16,
fb53f5a8 896 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
897 },
898/* asr $Rd,#$imm4 */
899 {
900 XSTORMY16_INSN_ASRGRIMM, "asrgrimm", "asr", 16,
fb53f5a8 901 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
902 },
903/* set1 $Rd,#$imm4 */
904 {
905 XSTORMY16_INSN_SET1GRIMM, "set1grimm", "set1", 16,
fb53f5a8 906 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
907 },
908/* set1 $Rd,$Rs */
909 {
910 XSTORMY16_INSN_SET1GRGR, "set1grgr", "set1", 16,
fb53f5a8 911 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
912 },
913/* set1 $lmem8,#$imm3 */
914 {
915 XSTORMY16_INSN_SET1LMEMIMM, "set1lmemimm", "set1", 16,
fb53f5a8 916 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
917 },
918/* set1 $hmem8,#$imm3 */
919 {
920 XSTORMY16_INSN_SET1HMEMIMM, "set1hmemimm", "set1", 16,
fb53f5a8 921 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
922 },
923/* clr1 $Rd,#$imm4 */
924 {
925 XSTORMY16_INSN_CLR1GRIMM, "clr1grimm", "clr1", 16,
fb53f5a8 926 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
927 },
928/* clr1 $Rd,$Rs */
929 {
930 XSTORMY16_INSN_CLR1GRGR, "clr1grgr", "clr1", 16,
fb53f5a8 931 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
932 },
933/* clr1 $lmem8,#$imm3 */
934 {
935 XSTORMY16_INSN_CLR1LMEMIMM, "clr1lmemimm", "clr1", 16,
fb53f5a8 936 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
937 },
938/* clr1 $hmem8,#$imm3 */
939 {
940 XSTORMY16_INSN_CLR1HMEMIMM, "clr1hmemimm", "clr1", 16,
fb53f5a8 941 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
942 },
943/* cbw $Rd */
944 {
945 XSTORMY16_INSN_CBWGR, "cbwgr", "cbw", 16,
fb53f5a8 946 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
947 },
948/* rev $Rd */
949 {
950 XSTORMY16_INSN_REVGR, "revgr", "rev", 16,
fb53f5a8 951 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
952 },
953/* b$bcond5 $Rd,$Rs,$rel12 */
954 {
955 XSTORMY16_INSN_BCCGRGR, "bccgrgr", "b", 32,
fb53f5a8 956 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
957 },
958/* b$bcond5 $Rm,#$imm8,$rel12 */
959 {
960 XSTORMY16_INSN_BCCGRIMM8, "bccgrimm8", "b", 32,
fb53f5a8 961 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
962 },
963/* b$bcond2 Rx,#$imm16,${rel8-4} */
964 {
965 XSTORMY16_INSN_BCCIMM16, "bccimm16", "b", 32,
fb53f5a8 966 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
967 },
968/* bn $Rd,#$imm4,$rel12 */
969 {
970 XSTORMY16_INSN_BNGRIMM4, "bngrimm4", "bn", 32,
fb53f5a8 971 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
972 },
973/* bn $Rd,$Rs,$rel12 */
974 {
975 XSTORMY16_INSN_BNGRGR, "bngrgr", "bn", 32,
fb53f5a8 976 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
977 },
978/* bn $lmem8,#$imm3b,$rel12 */
979 {
980 XSTORMY16_INSN_BNLMEMIMM, "bnlmemimm", "bn", 32,
fb53f5a8 981 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
982 },
983/* bn $hmem8,#$imm3b,$rel12 */
984 {
985 XSTORMY16_INSN_BNHMEMIMM, "bnhmemimm", "bn", 32,
fb53f5a8 986 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
987 },
988/* bp $Rd,#$imm4,$rel12 */
989 {
990 XSTORMY16_INSN_BPGRIMM4, "bpgrimm4", "bp", 32,
fb53f5a8 991 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
992 },
993/* bp $Rd,$Rs,$rel12 */
994 {
995 XSTORMY16_INSN_BPGRGR, "bpgrgr", "bp", 32,
fb53f5a8 996 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
997 },
998/* bp $lmem8,#$imm3b,$rel12 */
999 {
1000 XSTORMY16_INSN_BPLMEMIMM, "bplmemimm", "bp", 32,
fb53f5a8 1001 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1002 },
1003/* bp $hmem8,#$imm3b,$rel12 */
1004 {
1005 XSTORMY16_INSN_BPHMEMIMM, "bphmemimm", "bp", 32,
fb53f5a8 1006 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1007 },
1008/* b$bcond2 ${rel8-2} */
1009 {
1010 XSTORMY16_INSN_BCC, "bcc", "b", 16,
fb53f5a8 1011 { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1012 },
1013/* br $Rd */
1014 {
1015 XSTORMY16_INSN_BGR, "bgr", "br", 16,
fb53f5a8 1016 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1017 },
1018/* br $rel12a */
1019 {
1020 XSTORMY16_INSN_BR, "br", "br", 16,
fb53f5a8 1021 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1022 },
1023/* jmp $Rbj,$Rd */
1024 {
1025 XSTORMY16_INSN_JMP, "jmp", "jmp", 16,
fb53f5a8 1026 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1027 },
1028/* jmpf $abs24 */
1029 {
1030 XSTORMY16_INSN_JMPF, "jmpf", "jmpf", 32,
fb53f5a8 1031 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1032 },
1033/* callr $Rd */
1034 {
1035 XSTORMY16_INSN_CALLRGR, "callrgr", "callr", 16,
fb53f5a8 1036 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1037 },
1038/* callr $rel12a */
1039 {
1040 XSTORMY16_INSN_CALLRIMM, "callrimm", "callr", 16,
fb53f5a8 1041 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1042 },
1043/* call $Rbj,$Rd */
1044 {
1045 XSTORMY16_INSN_CALLGR, "callgr", "call", 16,
fb53f5a8 1046 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1047 },
1048/* callf $abs24 */
1049 {
1050 XSTORMY16_INSN_CALLFIMM, "callfimm", "callf", 32,
fb53f5a8 1051 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1052 },
1053/* icallr $Rd */
1054 {
1055 XSTORMY16_INSN_ICALLRGR, "icallrgr", "icallr", 16,
fb53f5a8 1056 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1057 },
1058/* icall $Rbj,$Rd */
1059 {
1060 XSTORMY16_INSN_ICALLGR, "icallgr", "icall", 16,
fb53f5a8 1061 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1062 },
1063/* icallf $abs24 */
1064 {
1065 XSTORMY16_INSN_ICALLFIMM, "icallfimm", "icallf", 32,
fb53f5a8 1066 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1067 },
1068/* iret */
1069 {
1070 XSTORMY16_INSN_IRET, "iret", "iret", 16,
fb53f5a8 1071 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1072 },
1073/* ret */
1074 {
1075 XSTORMY16_INSN_RET, "ret", "ret", 16,
fb53f5a8 1076 { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1077 },
1078/* mul */
1079 {
1080 XSTORMY16_INSN_MUL, "mul", "mul", 16,
fb53f5a8 1081 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1082 },
1083/* div */
1084 {
1085 XSTORMY16_INSN_DIV, "div", "div", 16,
fb53f5a8 1086 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04 1087 },
193eb15d
DD
1088/* sdiv */
1089 {
1090 XSTORMY16_INSN_SDIV, "sdiv", "sdiv", 16,
fb53f5a8 1091 { 0, { { { (1<<MACH_BASE), 0 } } } }
193eb15d
DD
1092 },
1093/* sdivlh */
1094 {
1095 XSTORMY16_INSN_SDIVLH, "sdivlh", "sdivlh", 16,
fb53f5a8 1096 { 0, { { { (1<<MACH_BASE), 0 } } } }
193eb15d
DD
1097 },
1098/* divlh */
1099 {
1100 XSTORMY16_INSN_DIVLH, "divlh", "divlh", 16,
fb53f5a8 1101 { 0, { { { (1<<MACH_BASE), 0 } } } }
193eb15d 1102 },
390ff83f
DE
1103/* reset */
1104 {
1105 XSTORMY16_INSN_RESET, "reset", "reset", 16,
fb53f5a8 1106 { 0, { { { (1<<MACH_BASE), 0 } } } }
390ff83f 1107 },
93fbbb04
GK
1108/* nop */
1109 {
1110 XSTORMY16_INSN_NOP, "nop", "nop", 16,
fb53f5a8 1111 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1112 },
1113/* halt */
1114 {
1115 XSTORMY16_INSN_HALT, "halt", "halt", 16,
fb53f5a8 1116 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1117 },
1118/* hold */
1119 {
1120 XSTORMY16_INSN_HOLD, "hold", "hold", 16,
fb53f5a8 1121 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04 1122 },
1951c6f7
MG
1123/* holdx */
1124 {
1125 XSTORMY16_INSN_HOLDX, "holdx", "holdx", 16,
fb53f5a8 1126 { 0, { { { (1<<MACH_BASE), 0 } } } }
1951c6f7 1127 },
93fbbb04
GK
1128/* brk */
1129 {
1130 XSTORMY16_INSN_BRK, "brk", "brk", 16,
fb53f5a8 1131 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1132 },
1133/* --unused-- */
1134 {
1135 XSTORMY16_INSN_SYSCALL, "syscall", "--unused--", 16,
fb53f5a8 1136 { 0, { { { (1<<MACH_BASE), 0 } } } }
93fbbb04
GK
1137 },
1138};
1139
1140#undef OP
1141#undef A
1142
1143/* Initialize anything needed to be done once, before any cpu_open call. */
93fbbb04
GK
1144
1145static void
47b0e7ad 1146init_tables (void)
93fbbb04
GK
1147{
1148}
1149
47b0e7ad
NC
1150static const CGEN_MACH * lookup_mach_via_bfd_name (const CGEN_MACH *, const char *);
1151static void build_hw_table (CGEN_CPU_TABLE *);
1152static void build_ifield_table (CGEN_CPU_TABLE *);
1153static void build_operand_table (CGEN_CPU_TABLE *);
1154static void build_insn_table (CGEN_CPU_TABLE *);
1155static void xstormy16_cgen_rebuild_tables (CGEN_CPU_TABLE *);
93fbbb04
GK
1156
1157/* Subroutine of xstormy16_cgen_cpu_open to look up a mach via its bfd name. */
1158
1159static const CGEN_MACH *
47b0e7ad 1160lookup_mach_via_bfd_name (const CGEN_MACH *table, const char *name)
93fbbb04
GK
1161{
1162 while (table->name)
1163 {
1164 if (strcmp (name, table->bfd_name) == 0)
1165 return table;
1166 ++table;
1167 }
42742084 1168 return NULL;
93fbbb04
GK
1169}
1170
1171/* Subroutine of xstormy16_cgen_cpu_open to build the hardware table. */
1172
1173static void
47b0e7ad 1174build_hw_table (CGEN_CPU_TABLE *cd)
93fbbb04
GK
1175{
1176 int i;
1177 int machs = cd->machs;
1178 const CGEN_HW_ENTRY *init = & xstormy16_cgen_hw_table[0];
1179 /* MAX_HW is only an upper bound on the number of selected entries.
1180 However each entry is indexed by it's enum so there can be holes in
1181 the table. */
1182 const CGEN_HW_ENTRY **selected =
1183 (const CGEN_HW_ENTRY **) xmalloc (MAX_HW * sizeof (CGEN_HW_ENTRY *));
1184
1185 cd->hw_table.init_entries = init;
1186 cd->hw_table.entry_size = sizeof (CGEN_HW_ENTRY);
1187 memset (selected, 0, MAX_HW * sizeof (CGEN_HW_ENTRY *));
1188 /* ??? For now we just use machs to determine which ones we want. */
1189 for (i = 0; init[i].name != NULL; ++i)
1190 if (CGEN_HW_ATTR_VALUE (&init[i], CGEN_HW_MACH)
1191 & machs)
1192 selected[init[i].type] = &init[i];
1193 cd->hw_table.entries = selected;
1194 cd->hw_table.num_entries = MAX_HW;
1195}
1196
1197/* Subroutine of xstormy16_cgen_cpu_open to build the hardware table. */
1198
1199static void
47b0e7ad 1200build_ifield_table (CGEN_CPU_TABLE *cd)
93fbbb04
GK
1201{
1202 cd->ifld_table = & xstormy16_cgen_ifld_table[0];
1203}
1204
1205/* Subroutine of xstormy16_cgen_cpu_open to build the hardware table. */
1206
1207static void
47b0e7ad 1208build_operand_table (CGEN_CPU_TABLE *cd)
93fbbb04
GK
1209{
1210 int i;
1211 int machs = cd->machs;
1212 const CGEN_OPERAND *init = & xstormy16_cgen_operand_table[0];
1213 /* MAX_OPERANDS is only an upper bound on the number of selected entries.
1214 However each entry is indexed by it's enum so there can be holes in
1215 the table. */
47b0e7ad 1216 const CGEN_OPERAND **selected = xmalloc (MAX_OPERANDS * sizeof (* selected));
93fbbb04
GK
1217
1218 cd->operand_table.init_entries = init;
1219 cd->operand_table.entry_size = sizeof (CGEN_OPERAND);
1220 memset (selected, 0, MAX_OPERANDS * sizeof (CGEN_OPERAND *));
1221 /* ??? For now we just use mach to determine which ones we want. */
1222 for (i = 0; init[i].name != NULL; ++i)
1223 if (CGEN_OPERAND_ATTR_VALUE (&init[i], CGEN_OPERAND_MACH)
1224 & machs)
1225 selected[init[i].type] = &init[i];
1226 cd->operand_table.entries = selected;
1227 cd->operand_table.num_entries = MAX_OPERANDS;
1228}
1229
1230/* Subroutine of xstormy16_cgen_cpu_open to build the hardware table.
1231 ??? This could leave out insns not supported by the specified mach/isa,
1232 but that would cause errors like "foo only supported by bar" to become
1233 "unknown insn", so for now we include all insns and require the app to
1234 do the checking later.
1235 ??? On the other hand, parsing of such insns may require their hardware or
1236 operand elements to be in the table [which they mightn't be]. */
1237
1238static void
47b0e7ad 1239build_insn_table (CGEN_CPU_TABLE *cd)
93fbbb04
GK
1240{
1241 int i;
1242 const CGEN_IBASE *ib = & xstormy16_cgen_insn_table[0];
47b0e7ad 1243 CGEN_INSN *insns = xmalloc (MAX_INSNS * sizeof (CGEN_INSN));
93fbbb04
GK
1244
1245 memset (insns, 0, MAX_INSNS * sizeof (CGEN_INSN));
1246 for (i = 0; i < MAX_INSNS; ++i)
1247 insns[i].base = &ib[i];
1248 cd->insn_table.init_entries = insns;
1249 cd->insn_table.entry_size = sizeof (CGEN_IBASE);
1250 cd->insn_table.num_init_entries = MAX_INSNS;
1251}
1252
1253/* Subroutine of xstormy16_cgen_cpu_open to rebuild the tables. */
1254
1255static void
47b0e7ad 1256xstormy16_cgen_rebuild_tables (CGEN_CPU_TABLE *cd)
93fbbb04
GK
1257{
1258 int i;
fb53f5a8 1259 CGEN_BITSET *isas = cd->isas;
93fbbb04
GK
1260 unsigned int machs = cd->machs;
1261
1262 cd->int_insn_p = CGEN_INT_INSN_P;
1263
1264 /* Data derived from the isa spec. */
1265#define UNSET (CGEN_SIZE_UNKNOWN + 1)
1266 cd->default_insn_bitsize = UNSET;
1267 cd->base_insn_bitsize = UNSET;
47b0e7ad 1268 cd->min_insn_bitsize = 65535; /* Some ridiculously big number. */
93fbbb04
GK
1269 cd->max_insn_bitsize = 0;
1270 for (i = 0; i < MAX_ISAS; ++i)
fb53f5a8 1271 if (cgen_bitset_contains (isas, i))
93fbbb04
GK
1272 {
1273 const CGEN_ISA *isa = & xstormy16_cgen_isa_table[i];
1274
9a2e995d
GH
1275 /* Default insn sizes of all selected isas must be
1276 equal or we set the result to 0, meaning "unknown". */
93fbbb04
GK
1277 if (cd->default_insn_bitsize == UNSET)
1278 cd->default_insn_bitsize = isa->default_insn_bitsize;
1279 else if (isa->default_insn_bitsize == cd->default_insn_bitsize)
47b0e7ad 1280 ; /* This is ok. */
93fbbb04
GK
1281 else
1282 cd->default_insn_bitsize = CGEN_SIZE_UNKNOWN;
1283
9a2e995d
GH
1284 /* Base insn sizes of all selected isas must be equal
1285 or we set the result to 0, meaning "unknown". */
93fbbb04
GK
1286 if (cd->base_insn_bitsize == UNSET)
1287 cd->base_insn_bitsize = isa->base_insn_bitsize;
1288 else if (isa->base_insn_bitsize == cd->base_insn_bitsize)
47b0e7ad 1289 ; /* This is ok. */
93fbbb04
GK
1290 else
1291 cd->base_insn_bitsize = CGEN_SIZE_UNKNOWN;
1292
1293 /* Set min,max insn sizes. */
1294 if (isa->min_insn_bitsize < cd->min_insn_bitsize)
1295 cd->min_insn_bitsize = isa->min_insn_bitsize;
1296 if (isa->max_insn_bitsize > cd->max_insn_bitsize)
1297 cd->max_insn_bitsize = isa->max_insn_bitsize;
1298 }
1299
1300 /* Data derived from the mach spec. */
1301 for (i = 0; i < MAX_MACHS; ++i)
1302 if (((1 << i) & machs) != 0)
1303 {
1304 const CGEN_MACH *mach = & xstormy16_cgen_mach_table[i];
1305
1306 if (mach->insn_chunk_bitsize != 0)
1307 {
1308 if (cd->insn_chunk_bitsize != 0 && cd->insn_chunk_bitsize != mach->insn_chunk_bitsize)
1309 {
1310 fprintf (stderr, "xstormy16_cgen_rebuild_tables: conflicting insn-chunk-bitsize values: `%d' vs. `%d'\n",
1311 cd->insn_chunk_bitsize, mach->insn_chunk_bitsize);
1312 abort ();
1313 }
1314
1315 cd->insn_chunk_bitsize = mach->insn_chunk_bitsize;
1316 }
1317 }
1318
1319 /* Determine which hw elements are used by MACH. */
1320 build_hw_table (cd);
1321
1322 /* Build the ifield table. */
1323 build_ifield_table (cd);
1324
1325 /* Determine which operands are used by MACH/ISA. */
1326 build_operand_table (cd);
1327
1328 /* Build the instruction table. */
1329 build_insn_table (cd);
1330}
1331
1332/* Initialize a cpu table and return a descriptor.
1333 It's much like opening a file, and must be the first function called.
1334 The arguments are a set of (type/value) pairs, terminated with
1335 CGEN_CPU_OPEN_END.
1336
1337 Currently supported values:
1338 CGEN_CPU_OPEN_ISAS: bitmap of values in enum isa_attr
1339 CGEN_CPU_OPEN_MACHS: bitmap of values in enum mach_attr
1340 CGEN_CPU_OPEN_BFDMACH: specify 1 mach using bfd name
1341 CGEN_CPU_OPEN_ENDIAN: specify endian choice
1342 CGEN_CPU_OPEN_END: terminates arguments
1343
1344 ??? Simultaneous multiple isas might not make sense, but it's not (yet)
37ec9240 1345 precluded. */
93fbbb04
GK
1346
1347CGEN_CPU_DESC
1348xstormy16_cgen_cpu_open (enum cgen_cpu_open_arg arg_type, ...)
1349{
1350 CGEN_CPU_TABLE *cd = (CGEN_CPU_TABLE *) xmalloc (sizeof (CGEN_CPU_TABLE));
1351 static int init_p;
fb53f5a8 1352 CGEN_BITSET *isas = 0; /* 0 = "unspecified" */
93fbbb04
GK
1353 unsigned int machs = 0; /* 0 = "unspecified" */
1354 enum cgen_endian endian = CGEN_ENDIAN_UNKNOWN;
1355 va_list ap;
1356
1357 if (! init_p)
1358 {
1359 init_tables ();
1360 init_p = 1;
1361 }
1362
1363 memset (cd, 0, sizeof (*cd));
1364
1365 va_start (ap, arg_type);
1366 while (arg_type != CGEN_CPU_OPEN_END)
1367 {
1368 switch (arg_type)
1369 {
1370 case CGEN_CPU_OPEN_ISAS :
fb53f5a8 1371 isas = va_arg (ap, CGEN_BITSET *);
93fbbb04
GK
1372 break;
1373 case CGEN_CPU_OPEN_MACHS :
1374 machs = va_arg (ap, unsigned int);
1375 break;
1376 case CGEN_CPU_OPEN_BFDMACH :
1377 {
1378 const char *name = va_arg (ap, const char *);
1379 const CGEN_MACH *mach =
1380 lookup_mach_via_bfd_name (xstormy16_cgen_mach_table, name);
1381
42742084
AM
1382 if (mach != NULL)
1383 machs |= 1 << mach->num;
93fbbb04
GK
1384 break;
1385 }
1386 case CGEN_CPU_OPEN_ENDIAN :
1387 endian = va_arg (ap, enum cgen_endian);
1388 break;
1389 default :
1390 fprintf (stderr, "xstormy16_cgen_cpu_open: unsupported argument `%d'\n",
1391 arg_type);
1392 abort (); /* ??? return NULL? */
1393 }
1394 arg_type = va_arg (ap, enum cgen_cpu_open_arg);
1395 }
1396 va_end (ap);
1397
47b0e7ad 1398 /* Mach unspecified means "all". */
93fbbb04
GK
1399 if (machs == 0)
1400 machs = (1 << MAX_MACHS) - 1;
47b0e7ad 1401 /* Base mach is always selected. */
93fbbb04 1402 machs |= 1;
93fbbb04
GK
1403 if (endian == CGEN_ENDIAN_UNKNOWN)
1404 {
1405 /* ??? If target has only one, could have a default. */
1406 fprintf (stderr, "xstormy16_cgen_cpu_open: no endianness specified\n");
1407 abort ();
1408 }
1409
fb53f5a8 1410 cd->isas = cgen_bitset_copy (isas);
93fbbb04
GK
1411 cd->machs = machs;
1412 cd->endian = endian;
1413 /* FIXME: for the sparc case we can determine insn-endianness statically.
1414 The worry here is where both data and insn endian can be independently
1415 chosen, in which case this function will need another argument.
1416 Actually, will want to allow for more arguments in the future anyway. */
1417 cd->insn_endian = endian;
1418
1419 /* Table (re)builder. */
1420 cd->rebuild_tables = xstormy16_cgen_rebuild_tables;
1421 xstormy16_cgen_rebuild_tables (cd);
1422
1423 /* Default to not allowing signed overflow. */
1424 cd->signed_overflow_ok_p = 0;
43e65147 1425
93fbbb04
GK
1426 return (CGEN_CPU_DESC) cd;
1427}
1428
1429/* Cover fn to xstormy16_cgen_cpu_open to handle the simple case of 1 isa, 1 mach.
1430 MACH_NAME is the bfd name of the mach. */
1431
1432CGEN_CPU_DESC
47b0e7ad 1433xstormy16_cgen_cpu_open_1 (const char *mach_name, enum cgen_endian endian)
93fbbb04
GK
1434{
1435 return xstormy16_cgen_cpu_open (CGEN_CPU_OPEN_BFDMACH, mach_name,
1436 CGEN_CPU_OPEN_ENDIAN, endian,
1437 CGEN_CPU_OPEN_END);
1438}
1439
1440/* Close a cpu table.
1441 ??? This can live in a machine independent file, but there's currently
1442 no place to put this file (there's no libcgen). libopcodes is the wrong
1443 place as some simulator ports use this but they don't use libopcodes. */
1444
1445void
47b0e7ad 1446xstormy16_cgen_cpu_close (CGEN_CPU_DESC cd)
93fbbb04 1447{
a978a3e5 1448 unsigned int i;
98f70fc4 1449 const CGEN_INSN *insns;
a978a3e5
NC
1450
1451 if (cd->macro_insn_table.init_entries)
1452 {
1453 insns = cd->macro_insn_table.init_entries;
1454 for (i = 0; i < cd->macro_insn_table.num_init_entries; ++i, ++insns)
47b0e7ad
NC
1455 if (CGEN_INSN_RX ((insns)))
1456 regfree (CGEN_INSN_RX (insns));
a978a3e5
NC
1457 }
1458
1459 if (cd->insn_table.init_entries)
1460 {
1461 insns = cd->insn_table.init_entries;
1462 for (i = 0; i < cd->insn_table.num_init_entries; ++i, ++insns)
47b0e7ad
NC
1463 if (CGEN_INSN_RX (insns))
1464 regfree (CGEN_INSN_RX (insns));
43e65147 1465 }
a978a3e5
NC
1466
1467 if (cd->macro_insn_table.init_entries)
1468 free ((CGEN_INSN *) cd->macro_insn_table.init_entries);
1469
93fbbb04
GK
1470 if (cd->insn_table.init_entries)
1471 free ((CGEN_INSN *) cd->insn_table.init_entries);
a978a3e5 1472
93fbbb04
GK
1473 if (cd->hw_table.entries)
1474 free ((CGEN_HW_ENTRY *) cd->hw_table.entries);
a978a3e5
NC
1475
1476 if (cd->operand_table.entries)
1477 free ((CGEN_HW_ENTRY *) cd->operand_table.entries);
1478
93fbbb04
GK
1479 free (cd);
1480}
1481