Release 2.33.1
[external/binutils.git] / opcodes / epiphany-desc.c
1 /* DO NOT EDIT!  -*- buffer-read-only: t -*- vi:set ro:  */
2 /* CPU data for epiphany.
3
4 THIS FILE IS MACHINE GENERATED WITH CGEN.
5
6 Copyright (C) 1996-2019 Free Software Foundation, Inc.
7
8 This file is part of the GNU Binutils and/or GDB, the GNU debugger.
9
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.
14
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.
19
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.
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 "epiphany-desc.h"
33 #include "epiphany-opc.h"
34 #include "opintl.h"
35 #include "libiberty.h"
36 #include "xregex.h"
37
38 /* Attributes.  */
39
40 static const CGEN_ATTR_ENTRY bool_attr[] =
41 {
42   { "#f", 0 },
43   { "#t", 1 },
44   { 0, 0 }
45 };
46
47 static const CGEN_ATTR_ENTRY MACH_attr[] ATTRIBUTE_UNUSED =
48 {
49   { "base", MACH_BASE },
50   { "epiphany32", MACH_EPIPHANY32 },
51   { "max", MACH_MAX },
52   { 0, 0 }
53 };
54
55 static const CGEN_ATTR_ENTRY ISA_attr[] ATTRIBUTE_UNUSED =
56 {
57   { "epiphany", ISA_EPIPHANY },
58   { "max", ISA_MAX },
59   { 0, 0 }
60 };
61
62 const CGEN_ATTR_TABLE epiphany_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   { "RELOC", &bool_attr[0], &bool_attr[0] },
72   { 0, 0, 0 }
73 };
74
75 const CGEN_ATTR_TABLE epiphany_cgen_hardware_attr_table[] =
76 {
77   { "MACH", & MACH_attr[0], & MACH_attr[0] },
78   { "VIRTUAL", &bool_attr[0], &bool_attr[0] },
79   { "CACHE-ADDR", &bool_attr[0], &bool_attr[0] },
80   { "PC", &bool_attr[0], &bool_attr[0] },
81   { "PROFILE", &bool_attr[0], &bool_attr[0] },
82   { 0, 0, 0 }
83 };
84
85 const CGEN_ATTR_TABLE epiphany_cgen_operand_attr_table[] =
86 {
87   { "MACH", & MACH_attr[0], & MACH_attr[0] },
88   { "VIRTUAL", &bool_attr[0], &bool_attr[0] },
89   { "PCREL-ADDR", &bool_attr[0], &bool_attr[0] },
90   { "ABS-ADDR", &bool_attr[0], &bool_attr[0] },
91   { "SIGN-OPT", &bool_attr[0], &bool_attr[0] },
92   { "SIGNED", &bool_attr[0], &bool_attr[0] },
93   { "NEGATIVE", &bool_attr[0], &bool_attr[0] },
94   { "RELAX", &bool_attr[0], &bool_attr[0] },
95   { "SEM-ONLY", &bool_attr[0], &bool_attr[0] },
96   { "RELOC", &bool_attr[0], &bool_attr[0] },
97   { 0, 0, 0 }
98 };
99
100 const CGEN_ATTR_TABLE epiphany_cgen_insn_attr_table[] =
101 {
102   { "MACH", & MACH_attr[0], & MACH_attr[0] },
103   { "ALIAS", &bool_attr[0], &bool_attr[0] },
104   { "VIRTUAL", &bool_attr[0], &bool_attr[0] },
105   { "UNCOND-CTI", &bool_attr[0], &bool_attr[0] },
106   { "COND-CTI", &bool_attr[0], &bool_attr[0] },
107   { "SKIP-CTI", &bool_attr[0], &bool_attr[0] },
108   { "DELAY-SLOT", &bool_attr[0], &bool_attr[0] },
109   { "RELAXABLE", &bool_attr[0], &bool_attr[0] },
110   { "RELAXED", &bool_attr[0], &bool_attr[0] },
111   { "NO-DIS", &bool_attr[0], &bool_attr[0] },
112   { "PBB", &bool_attr[0], &bool_attr[0] },
113   { "SHORT-INSN", &bool_attr[0], &bool_attr[0] },
114   { "IMM3", &bool_attr[0], &bool_attr[0] },
115   { "IMM8", &bool_attr[0], &bool_attr[0] },
116   { 0, 0, 0 }
117 };
118
119 /* Instruction set variants.  */
120
121 static const CGEN_ISA epiphany_cgen_isa_table[] = {
122   { "epiphany", 32, 32, 16, 32 },
123   { 0, 0, 0, 0, 0 }
124 };
125
126 /* Machine variants.  */
127
128 static const CGEN_MACH epiphany_cgen_mach_table[] = {
129   { "epiphany32", "epiphany32", MACH_EPIPHANY32, 0 },
130   { 0, 0, 0, 0 }
131 };
132
133 static CGEN_KEYWORD_ENTRY epiphany_cgen_opval_gr_names_entries[] =
134 {
135   { "fp", 11, {0, {{{0, 0}}}}, 0, 0 },
136   { "sp", 13, {0, {{{0, 0}}}}, 0, 0 },
137   { "lr", 14, {0, {{{0, 0}}}}, 0, 0 },
138   { "r0", 0, {0, {{{0, 0}}}}, 0, 0 },
139   { "r1", 1, {0, {{{0, 0}}}}, 0, 0 },
140   { "r2", 2, {0, {{{0, 0}}}}, 0, 0 },
141   { "r3", 3, {0, {{{0, 0}}}}, 0, 0 },
142   { "r4", 4, {0, {{{0, 0}}}}, 0, 0 },
143   { "r5", 5, {0, {{{0, 0}}}}, 0, 0 },
144   { "r6", 6, {0, {{{0, 0}}}}, 0, 0 },
145   { "r7", 7, {0, {{{0, 0}}}}, 0, 0 },
146   { "r8", 8, {0, {{{0, 0}}}}, 0, 0 },
147   { "r9", 9, {0, {{{0, 0}}}}, 0, 0 },
148   { "r10", 10, {0, {{{0, 0}}}}, 0, 0 },
149   { "r11", 11, {0, {{{0, 0}}}}, 0, 0 },
150   { "r12", 12, {0, {{{0, 0}}}}, 0, 0 },
151   { "r13", 13, {0, {{{0, 0}}}}, 0, 0 },
152   { "r14", 14, {0, {{{0, 0}}}}, 0, 0 },
153   { "r15", 15, {0, {{{0, 0}}}}, 0, 0 },
154   { "r16", 16, {0, {{{0, 0}}}}, 0, 0 },
155   { "r17", 17, {0, {{{0, 0}}}}, 0, 0 },
156   { "r18", 18, {0, {{{0, 0}}}}, 0, 0 },
157   { "r19", 19, {0, {{{0, 0}}}}, 0, 0 },
158   { "r20", 20, {0, {{{0, 0}}}}, 0, 0 },
159   { "r21", 21, {0, {{{0, 0}}}}, 0, 0 },
160   { "r22", 22, {0, {{{0, 0}}}}, 0, 0 },
161   { "r23", 23, {0, {{{0, 0}}}}, 0, 0 },
162   { "r24", 24, {0, {{{0, 0}}}}, 0, 0 },
163   { "r25", 25, {0, {{{0, 0}}}}, 0, 0 },
164   { "r26", 26, {0, {{{0, 0}}}}, 0, 0 },
165   { "r27", 27, {0, {{{0, 0}}}}, 0, 0 },
166   { "r28", 28, {0, {{{0, 0}}}}, 0, 0 },
167   { "r29", 29, {0, {{{0, 0}}}}, 0, 0 },
168   { "r30", 30, {0, {{{0, 0}}}}, 0, 0 },
169   { "r31", 31, {0, {{{0, 0}}}}, 0, 0 },
170   { "r32", 32, {0, {{{0, 0}}}}, 0, 0 },
171   { "r33", 33, {0, {{{0, 0}}}}, 0, 0 },
172   { "r34", 34, {0, {{{0, 0}}}}, 0, 0 },
173   { "r35", 35, {0, {{{0, 0}}}}, 0, 0 },
174   { "r36", 36, {0, {{{0, 0}}}}, 0, 0 },
175   { "r37", 37, {0, {{{0, 0}}}}, 0, 0 },
176   { "r38", 38, {0, {{{0, 0}}}}, 0, 0 },
177   { "r39", 39, {0, {{{0, 0}}}}, 0, 0 },
178   { "r40", 40, {0, {{{0, 0}}}}, 0, 0 },
179   { "r41", 41, {0, {{{0, 0}}}}, 0, 0 },
180   { "r42", 42, {0, {{{0, 0}}}}, 0, 0 },
181   { "r43", 43, {0, {{{0, 0}}}}, 0, 0 },
182   { "r44", 44, {0, {{{0, 0}}}}, 0, 0 },
183   { "r45", 45, {0, {{{0, 0}}}}, 0, 0 },
184   { "r46", 46, {0, {{{0, 0}}}}, 0, 0 },
185   { "r47", 47, {0, {{{0, 0}}}}, 0, 0 },
186   { "r48", 48, {0, {{{0, 0}}}}, 0, 0 },
187   { "r49", 49, {0, {{{0, 0}}}}, 0, 0 },
188   { "r50", 50, {0, {{{0, 0}}}}, 0, 0 },
189   { "r51", 51, {0, {{{0, 0}}}}, 0, 0 },
190   { "r52", 52, {0, {{{0, 0}}}}, 0, 0 },
191   { "r53", 53, {0, {{{0, 0}}}}, 0, 0 },
192   { "r54", 54, {0, {{{0, 0}}}}, 0, 0 },
193   { "r55", 55, {0, {{{0, 0}}}}, 0, 0 },
194   { "r56", 56, {0, {{{0, 0}}}}, 0, 0 },
195   { "r57", 57, {0, {{{0, 0}}}}, 0, 0 },
196   { "r58", 58, {0, {{{0, 0}}}}, 0, 0 },
197   { "r59", 59, {0, {{{0, 0}}}}, 0, 0 },
198   { "r60", 60, {0, {{{0, 0}}}}, 0, 0 },
199   { "r61", 61, {0, {{{0, 0}}}}, 0, 0 },
200   { "r62", 62, {0, {{{0, 0}}}}, 0, 0 },
201   { "r63", 63, {0, {{{0, 0}}}}, 0, 0 },
202   { "a1", 0, {0, {{{0, 0}}}}, 0, 0 },
203   { "a2", 1, {0, {{{0, 0}}}}, 0, 0 },
204   { "a3", 2, {0, {{{0, 0}}}}, 0, 0 },
205   { "a4", 3, {0, {{{0, 0}}}}, 0, 0 },
206   { "v1", 4, {0, {{{0, 0}}}}, 0, 0 },
207   { "v2", 5, {0, {{{0, 0}}}}, 0, 0 },
208   { "v3", 6, {0, {{{0, 0}}}}, 0, 0 },
209   { "v4", 7, {0, {{{0, 0}}}}, 0, 0 },
210   { "v5", 8, {0, {{{0, 0}}}}, 0, 0 },
211   { "v6", 9, {0, {{{0, 0}}}}, 0, 0 },
212   { "v7", 10, {0, {{{0, 0}}}}, 0, 0 },
213   { "v8", 11, {0, {{{0, 0}}}}, 0, 0 },
214   { "sb", 9, {0, {{{0, 0}}}}, 0, 0 },
215   { "sl", 10, {0, {{{0, 0}}}}, 0, 0 },
216   { "ip", 12, {0, {{{0, 0}}}}, 0, 0 }
217 };
218
219 CGEN_KEYWORD epiphany_cgen_opval_gr_names =
220 {
221   & epiphany_cgen_opval_gr_names_entries[0],
222   82,
223   0, 0, 0, 0, ""
224 };
225
226 static CGEN_KEYWORD_ENTRY epiphany_cgen_opval_cr_names_entries[] =
227 {
228   { "config", 0, {0, {{{0, 0}}}}, 0, 0 },
229   { "status", 1, {0, {{{0, 0}}}}, 0, 0 },
230   { "pc", 2, {0, {{{0, 0}}}}, 0, 0 },
231   { "debug", 3, {0, {{{0, 0}}}}, 0, 0 },
232   { "iab", 4, {0, {{{0, 0}}}}, 0, 0 },
233   { "lc", 5, {0, {{{0, 0}}}}, 0, 0 },
234   { "ls", 6, {0, {{{0, 0}}}}, 0, 0 },
235   { "le", 7, {0, {{{0, 0}}}}, 0, 0 },
236   { "iret", 8, {0, {{{0, 0}}}}, 0, 0 },
237   { "imask", 9, {0, {{{0, 0}}}}, 0, 0 },
238   { "ilat", 10, {0, {{{0, 0}}}}, 0, 0 },
239   { "ilatst", 11, {0, {{{0, 0}}}}, 0, 0 },
240   { "ilatcl", 12, {0, {{{0, 0}}}}, 0, 0 },
241   { "ipend", 13, {0, {{{0, 0}}}}, 0, 0 },
242   { "ctimer0", 14, {0, {{{0, 0}}}}, 0, 0 },
243   { "ctimer1", 15, {0, {{{0, 0}}}}, 0, 0 },
244   { "hstatus", 16, {0, {{{0, 0}}}}, 0, 0 }
245 };
246
247 CGEN_KEYWORD epiphany_cgen_opval_cr_names =
248 {
249   & epiphany_cgen_opval_cr_names_entries[0],
250   17,
251   0, 0, 0, 0, ""
252 };
253
254 static CGEN_KEYWORD_ENTRY epiphany_cgen_opval_crdma_names_entries[] =
255 {
256   { "dma0config", 0, {0, {{{0, 0}}}}, 0, 0 },
257   { "dma0stride", 1, {0, {{{0, 0}}}}, 0, 0 },
258   { "dma0count", 2, {0, {{{0, 0}}}}, 0, 0 },
259   { "dma0srcaddr", 3, {0, {{{0, 0}}}}, 0, 0 },
260   { "dma0dstaddr", 4, {0, {{{0, 0}}}}, 0, 0 },
261   { "dma0auto0", 5, {0, {{{0, 0}}}}, 0, 0 },
262   { "dma0auto1", 6, {0, {{{0, 0}}}}, 0, 0 },
263   { "dma0status", 7, {0, {{{0, 0}}}}, 0, 0 },
264   { "dma1config", 8, {0, {{{0, 0}}}}, 0, 0 },
265   { "dma1stride", 9, {0, {{{0, 0}}}}, 0, 0 },
266   { "dma1count", 10, {0, {{{0, 0}}}}, 0, 0 },
267   { "dma1srcaddr", 11, {0, {{{0, 0}}}}, 0, 0 },
268   { "dma1dstaddr", 12, {0, {{{0, 0}}}}, 0, 0 },
269   { "dma1auto0", 13, {0, {{{0, 0}}}}, 0, 0 },
270   { "dma1auto1", 14, {0, {{{0, 0}}}}, 0, 0 },
271   { "dma1status", 15, {0, {{{0, 0}}}}, 0, 0 }
272 };
273
274 CGEN_KEYWORD epiphany_cgen_opval_crdma_names =
275 {
276   & epiphany_cgen_opval_crdma_names_entries[0],
277   16,
278   0, 0, 0, 0, ""
279 };
280
281 static CGEN_KEYWORD_ENTRY epiphany_cgen_opval_crmem_names_entries[] =
282 {
283   { "memconfig", 0, {0, {{{0, 0}}}}, 0, 0 },
284   { "memstatus", 1, {0, {{{0, 0}}}}, 0, 0 },
285   { "memprotect", 2, {0, {{{0, 0}}}}, 0, 0 },
286   { "memreserve", 3, {0, {{{0, 0}}}}, 0, 0 }
287 };
288
289 CGEN_KEYWORD epiphany_cgen_opval_crmem_names =
290 {
291   & epiphany_cgen_opval_crmem_names_entries[0],
292   4,
293   0, 0, 0, 0, ""
294 };
295
296 static CGEN_KEYWORD_ENTRY epiphany_cgen_opval_crmesh_names_entries[] =
297 {
298   { "meshconfig", 0, {0, {{{0, 0}}}}, 0, 0 },
299   { "coreid", 1, {0, {{{0, 0}}}}, 0, 0 },
300   { "meshmulticast", 2, {0, {{{0, 0}}}}, 0, 0 },
301   { "swreset", 3, {0, {{{0, 0}}}}, 0, 0 }
302 };
303
304 CGEN_KEYWORD epiphany_cgen_opval_crmesh_names =
305 {
306   & epiphany_cgen_opval_crmesh_names_entries[0],
307   4,
308   0, 0, 0, 0, ""
309 };
310
311
312 /* The hardware table.  */
313
314 #define A(a) (1 << CGEN_HW_##a)
315
316 const CGEN_HW_ENTRY epiphany_cgen_hw_table[] =
317 {
318   { "h-memory", HW_H_MEMORY, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
319   { "h-sint", HW_H_SINT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
320   { "h-uint", HW_H_UINT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
321   { "h-addr", HW_H_ADDR, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
322   { "h-iaddr", HW_H_IADDR, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
323   { "h-registers", HW_H_REGISTERS, CGEN_ASM_KEYWORD, (PTR) & epiphany_cgen_opval_gr_names, { 0|A(CACHE_ADDR)|A(PROFILE), { { { (1<<MACH_BASE), 0 } } } } },
324   { "h-fpregisters", HW_H_FPREGISTERS, CGEN_ASM_KEYWORD, (PTR) & epiphany_cgen_opval_gr_names, { 0|A(VIRTUAL)|A(PROFILE), { { { (1<<MACH_BASE), 0 } } } } },
325   { "h-zbit", HW_H_ZBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
326   { "h-nbit", HW_H_NBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
327   { "h-cbit", HW_H_CBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
328   { "h-vbit", HW_H_VBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
329   { "h-vsbit", HW_H_VSBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
330   { "h-bzbit", HW_H_BZBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
331   { "h-bnbit", HW_H_BNBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
332   { "h-bvbit", HW_H_BVBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
333   { "h-bubit", HW_H_BUBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
334   { "h-bibit", HW_H_BIBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
335   { "h-bcbit", HW_H_BCBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
336   { "h-bvsbit", HW_H_BVSBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
337   { "h-bisbit", HW_H_BISBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
338   { "h-busbit", HW_H_BUSBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
339   { "h-expcause0bit", HW_H_EXPCAUSE0BIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
340   { "h-expcause1bit", HW_H_EXPCAUSE1BIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
341   { "h-expcause2bit", HW_H_EXPCAUSE2BIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
342   { "h-extFstallbit", HW_H_EXTFSTALLBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
343   { "h-trmbit", HW_H_TRMBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
344   { "h-invExcEnbit", HW_H_INVEXCENBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
345   { "h-ovfExcEnbit", HW_H_OVFEXCENBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
346   { "h-unExcEnbit", HW_H_UNEXCENBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
347   { "h-timer0bit0", HW_H_TIMER0BIT0, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
348   { "h-timer0bit1", HW_H_TIMER0BIT1, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
349   { "h-timer0bit2", HW_H_TIMER0BIT2, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
350   { "h-timer0bit3", HW_H_TIMER0BIT3, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
351   { "h-timer1bit0", HW_H_TIMER1BIT0, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
352   { "h-timer1bit1", HW_H_TIMER1BIT1, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
353   { "h-timer1bit2", HW_H_TIMER1BIT2, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
354   { "h-timer1bit3", HW_H_TIMER1BIT3, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
355   { "h-mbkptEnbit", HW_H_MBKPTENBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
356   { "h-clockGateEnbit", HW_H_CLOCKGATEENBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
357   { "h-coreCfgResBit12", HW_H_CORECFGRESBIT12, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
358   { "h-coreCfgResBit13", HW_H_CORECFGRESBIT13, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
359   { "h-coreCfgResBit14", HW_H_CORECFGRESBIT14, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
360   { "h-coreCfgResBit15", HW_H_CORECFGRESBIT15, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
361   { "h-coreCfgResBit16", HW_H_CORECFGRESBIT16, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
362   { "h-coreCfgResBit20", HW_H_CORECFGRESBIT20, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
363   { "h-coreCfgResBit21", HW_H_CORECFGRESBIT21, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
364   { "h-coreCfgResBit24", HW_H_CORECFGRESBIT24, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
365   { "h-coreCfgResBit25", HW_H_CORECFGRESBIT25, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
366   { "h-coreCfgResBit26", HW_H_CORECFGRESBIT26, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
367   { "h-coreCfgResBit27", HW_H_CORECFGRESBIT27, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
368   { "h-coreCfgResBit28", HW_H_CORECFGRESBIT28, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
369   { "h-coreCfgResBit29", HW_H_CORECFGRESBIT29, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
370   { "h-coreCfgResBit30", HW_H_CORECFGRESBIT30, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
371   { "h-coreCfgResBit31", HW_H_CORECFGRESBIT31, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
372   { "h-arithmetic-modebit0", HW_H_ARITHMETIC_MODEBIT0, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
373   { "h-arithmetic-modebit1", HW_H_ARITHMETIC_MODEBIT1, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
374   { "h-arithmetic-modebit2", HW_H_ARITHMETIC_MODEBIT2, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
375   { "h-gidisablebit", HW_H_GIDISABLEBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
376   { "h-kmbit", HW_H_KMBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
377   { "h-caibit", HW_H_CAIBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
378   { "h-sflagbit", HW_H_SFLAGBIT, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
379   { "h-pc", HW_H_PC, CGEN_ASM_NONE, 0, { 0|A(PROFILE)|A(PC), { { { (1<<MACH_BASE), 0 } } } } },
380   { "h-memaddr", HW_H_MEMADDR, CGEN_ASM_NONE, 0, { 0|A(PROFILE), { { { (1<<MACH_BASE), 0 } } } } },
381   { "h-core-registers", HW_H_CORE_REGISTERS, CGEN_ASM_KEYWORD, (PTR) & epiphany_cgen_opval_cr_names, { 0, { { { (1<<MACH_BASE), 0 } } } } },
382   { "h-coredma-registers", HW_H_COREDMA_REGISTERS, CGEN_ASM_KEYWORD, (PTR) & epiphany_cgen_opval_crdma_names, { 0, { { { (1<<MACH_BASE), 0 } } } } },
383   { "h-coremem-registers", HW_H_COREMEM_REGISTERS, CGEN_ASM_KEYWORD, (PTR) & epiphany_cgen_opval_crmem_names, { 0, { { { (1<<MACH_BASE), 0 } } } } },
384   { "h-coremesh-registers", HW_H_COREMESH_REGISTERS, CGEN_ASM_KEYWORD, (PTR) & epiphany_cgen_opval_crmesh_names, { 0, { { { (1<<MACH_BASE), 0 } } } } },
385   { 0, 0, CGEN_ASM_NONE, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } }
386 };
387
388 #undef A
389
390
391 /* The instruction field table.  */
392
393 #define A(a) (1 << CGEN_IFLD_##a)
394
395 const CGEN_IFLD epiphany_cgen_ifld_table[] =
396 {
397   { EPIPHANY_F_NIL, "f-nil", 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
398   { EPIPHANY_F_ANYOF, "f-anyof", 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
399   { EPIPHANY_F_OPC, "f-opc", 0, 32, 3, 4, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
400   { EPIPHANY_F_OPC_4_1, "f-opc-4-1", 0, 32, 4, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
401   { EPIPHANY_F_OPC_6_3, "f-opc-6-3", 0, 32, 6, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
402   { EPIPHANY_F_OPC_8_5, "f-opc-8-5", 0, 32, 8, 5, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
403   { EPIPHANY_F_OPC_19_4, "f-opc-19-4", 0, 32, 19, 4, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
404   { EPIPHANY_F_CONDCODE, "f-condcode", 0, 32, 7, 4, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
405   { EPIPHANY_F_SECONDARY_CCS, "f-secondary-ccs", 0, 32, 7, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
406   { EPIPHANY_F_SHIFT, "f-shift", 0, 32, 9, 5, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
407   { EPIPHANY_F_WORDSIZE, "f-wordsize", 0, 32, 6, 2, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
408   { EPIPHANY_F_STORE, "f-store", 0, 32, 4, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
409   { EPIPHANY_F_OPC_8_1, "f-opc-8-1", 0, 32, 8, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
410   { EPIPHANY_F_OPC_31_32, "f-opc-31-32", 0, 32, 31, 32, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
411   { EPIPHANY_F_SIMM8, "f-simm8", 0, 32, 15, 8, { 0|A(RELOC)|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } }  },
412   { EPIPHANY_F_SIMM24, "f-simm24", 0, 32, 31, 24, { 0|A(RELOC)|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } }  },
413   { EPIPHANY_F_SDISP3, "f-sdisp3", 0, 32, 9, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
414   { EPIPHANY_F_DISP3, "f-disp3", 0, 32, 9, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
415   { EPIPHANY_F_DISP8, "f-disp8", 0, 32, 23, 8, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
416   { EPIPHANY_F_IMM8, "f-imm8", 0, 32, 12, 8, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
417   { EPIPHANY_F_IMM_27_8, "f-imm-27-8", 0, 32, 27, 8, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
418   { EPIPHANY_F_ADDSUBX, "f-addsubx", 0, 32, 20, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
419   { EPIPHANY_F_SUBD, "f-subd", 0, 32, 24, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
420   { EPIPHANY_F_PM, "f-pm", 0, 32, 25, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
421   { EPIPHANY_F_RM, "f-rm", 0, 32, 9, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
422   { EPIPHANY_F_RN, "f-rn", 0, 32, 12, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
423   { EPIPHANY_F_RD, "f-rd", 0, 32, 15, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
424   { EPIPHANY_F_RM_X, "f-rm-x", 0, 32, 25, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
425   { EPIPHANY_F_RN_X, "f-rn-x", 0, 32, 28, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
426   { EPIPHANY_F_RD_X, "f-rd-x", 0, 32, 31, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
427   { EPIPHANY_F_DC_9_1, "f-dc-9-1", 0, 32, 9, 1, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
428   { EPIPHANY_F_SN, "f-sn", 0, 32, 12, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
429   { EPIPHANY_F_SD, "f-sd", 0, 32, 15, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
430   { EPIPHANY_F_SN_X, "f-sn-x", 0, 32, 28, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
431   { EPIPHANY_F_SD_X, "f-sd-x", 0, 32, 31, 3, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
432   { EPIPHANY_F_DC_7_4, "f-dc-7-4", 0, 32, 7, 4, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
433   { EPIPHANY_F_TRAP_SWI_9_1, "f-trap-swi-9-1", 0, 32, 9, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
434   { EPIPHANY_F_GIEN_GIDIS_9_1, "f-gien-gidis-9-1", 0, 32, 9, 1, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
435   { EPIPHANY_F_DC_15_3, "f-dc-15-3", 0, 32, 15, 3, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
436   { EPIPHANY_F_DC_15_7, "f-dc-15-7", 0, 32, 15, 7, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
437   { EPIPHANY_F_DC_15_6, "f-dc-15-6", 0, 32, 15, 6, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
438   { EPIPHANY_F_TRAP_NUM, "f-trap-num", 0, 32, 15, 6, { 0, { { { (1<<MACH_BASE), 0 } } } }  },
439   { EPIPHANY_F_DC_20_1, "f-dc-20-1", 0, 32, 20, 1, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
440   { EPIPHANY_F_DC_21_1, "f-dc-21-1", 0, 32, 21, 1, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
441   { EPIPHANY_F_DC_21_2, "f-dc-21-2", 0, 32, 21, 2, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
442   { EPIPHANY_F_DC_22_3, "f-dc-22-3", 0, 32, 22, 3, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
443   { EPIPHANY_F_DC_22_2, "f-dc-22-2", 0, 32, 22, 2, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
444   { EPIPHANY_F_DC_22_1, "f-dc-22-1", 0, 32, 22, 1, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
445   { EPIPHANY_F_DC_25_6, "f-dc-25-6", 0, 32, 25, 6, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
446   { EPIPHANY_F_DC_25_4, "f-dc-25-4", 0, 32, 25, 4, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
447   { EPIPHANY_F_DC_25_2, "f-dc-25-2", 0, 32, 25, 2, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
448   { EPIPHANY_F_DC_25_1, "f-dc-25-1", 0, 32, 25, 1, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
449   { EPIPHANY_F_DC_28_1, "f-dc-28-1", 0, 32, 28, 1, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
450   { EPIPHANY_F_DC_31_3, "f-dc-31-3", 0, 32, 31, 3, { 0|A(RESERVED), { { { (1<<MACH_BASE), 0 } } } }  },
451   { EPIPHANY_F_DISP11, "f-disp11", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
452   { EPIPHANY_F_SDISP11, "f-sdisp11", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
453   { EPIPHANY_F_IMM16, "f-imm16", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
454   { EPIPHANY_F_RD6, "f-rd6", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
455   { EPIPHANY_F_RN6, "f-rn6", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
456   { EPIPHANY_F_RM6, "f-rm6", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
457   { EPIPHANY_F_SD6, "f-sd6", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
458   { EPIPHANY_F_SN6, "f-sn6", 0, 0, 0, 0,{ 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
459   { 0, 0, 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } }
460 };
461
462 #undef A
463
464
465
466 /* multi ifield declarations */
467
468 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_DISP11_MULTI_IFIELD [];
469 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_SDISP11_MULTI_IFIELD [];
470 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_IMM16_MULTI_IFIELD [];
471 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_RD6_MULTI_IFIELD [];
472 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_RN6_MULTI_IFIELD [];
473 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_RM6_MULTI_IFIELD [];
474 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_SD6_MULTI_IFIELD [];
475 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_SN6_MULTI_IFIELD [];
476
477
478 /* multi ifield definitions */
479
480 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_DISP11_MULTI_IFIELD [] =
481 {
482     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_DISP3] } },
483     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_DISP8] } },
484     { 0, { (const PTR) 0 } }
485 };
486 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_SDISP11_MULTI_IFIELD [] =
487 {
488     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_DISP3] } },
489     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_DISP8] } },
490     { 0, { (const PTR) 0 } }
491 };
492 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_IMM16_MULTI_IFIELD [] =
493 {
494     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_IMM8] } },
495     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_IMM_27_8] } },
496     { 0, { (const PTR) 0 } }
497 };
498 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_RD6_MULTI_IFIELD [] =
499 {
500     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RD_X] } },
501     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RD] } },
502     { 0, { (const PTR) 0 } }
503 };
504 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_RN6_MULTI_IFIELD [] =
505 {
506     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RN_X] } },
507     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RN] } },
508     { 0, { (const PTR) 0 } }
509 };
510 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_RM6_MULTI_IFIELD [] =
511 {
512     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RM_X] } },
513     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RM] } },
514     { 0, { (const PTR) 0 } }
515 };
516 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_SD6_MULTI_IFIELD [] =
517 {
518     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SD_X] } },
519     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SD] } },
520     { 0, { (const PTR) 0 } }
521 };
522 const CGEN_MAYBE_MULTI_IFLD EPIPHANY_F_SN6_MULTI_IFIELD [] =
523 {
524     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SN_X] } },
525     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SN] } },
526     { 0, { (const PTR) 0 } }
527 };
528
529 /* The operand table.  */
530
531 #define A(a) (1 << CGEN_OPERAND_##a)
532 #define OPERAND(op) EPIPHANY_OPERAND_##op
533
534 const CGEN_OPERAND epiphany_cgen_operand_table[] =
535 {
536 /* pc: program counter */
537   { "pc", EPIPHANY_OPERAND_PC, HW_H_PC, 0, 0,
538     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_NIL] } },
539     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
540 /* zbit: integer zero bit */
541   { "zbit", EPIPHANY_OPERAND_ZBIT, HW_H_ZBIT, 0, 0,
542     { 0, { (const PTR) 0 } },
543     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
544 /* nbit: integer neg bit */
545   { "nbit", EPIPHANY_OPERAND_NBIT, HW_H_NBIT, 0, 0,
546     { 0, { (const PTR) 0 } },
547     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
548 /* cbit: integer carry bit */
549   { "cbit", EPIPHANY_OPERAND_CBIT, HW_H_CBIT, 0, 0,
550     { 0, { (const PTR) 0 } },
551     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
552 /* vbit: integer overflow bit */
553   { "vbit", EPIPHANY_OPERAND_VBIT, HW_H_VBIT, 0, 0,
554     { 0, { (const PTR) 0 } },
555     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
556 /* bzbit: floating point zero bit */
557   { "bzbit", EPIPHANY_OPERAND_BZBIT, HW_H_BZBIT, 0, 0,
558     { 0, { (const PTR) 0 } },
559     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
560 /* bnbit: floating point neg bit */
561   { "bnbit", EPIPHANY_OPERAND_BNBIT, HW_H_BNBIT, 0, 0,
562     { 0, { (const PTR) 0 } },
563     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
564 /* bvbit: floating point ovfl bit */
565   { "bvbit", EPIPHANY_OPERAND_BVBIT, HW_H_BVBIT, 0, 0,
566     { 0, { (const PTR) 0 } },
567     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
568 /* bcbit: floating point carry bit */
569   { "bcbit", EPIPHANY_OPERAND_BCBIT, HW_H_BCBIT, 0, 0,
570     { 0, { (const PTR) 0 } },
571     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
572 /* bubit: floating point underfl bit */
573   { "bubit", EPIPHANY_OPERAND_BUBIT, HW_H_BUBIT, 0, 0,
574     { 0, { (const PTR) 0 } },
575     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
576 /* bibit: floating point invalid bit */
577   { "bibit", EPIPHANY_OPERAND_BIBIT, HW_H_BIBIT, 0, 0,
578     { 0, { (const PTR) 0 } },
579     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
580 /* vsbit: integer overflow sticky */
581   { "vsbit", EPIPHANY_OPERAND_VSBIT, HW_H_VSBIT, 0, 0,
582     { 0, { (const PTR) 0 } },
583     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
584 /* bvsbit: floating point overflow sticky */
585   { "bvsbit", EPIPHANY_OPERAND_BVSBIT, HW_H_BVSBIT, 0, 0,
586     { 0, { (const PTR) 0 } },
587     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
588 /* bisbit: floating point invalid sticky */
589   { "bisbit", EPIPHANY_OPERAND_BISBIT, HW_H_BISBIT, 0, 0,
590     { 0, { (const PTR) 0 } },
591     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
592 /* busbit: floating point underflow sticky */
593   { "busbit", EPIPHANY_OPERAND_BUSBIT, HW_H_BUSBIT, 0, 0,
594     { 0, { (const PTR) 0 } },
595     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
596 /* expcause0bit: exceprion cause bit0 */
597   { "expcause0bit", EPIPHANY_OPERAND_EXPCAUSE0BIT, HW_H_EXPCAUSE0BIT, 0, 0,
598     { 0, { (const PTR) 0 } },
599     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
600 /* expcause1bit: exceprion cause bit1 */
601   { "expcause1bit", EPIPHANY_OPERAND_EXPCAUSE1BIT, HW_H_EXPCAUSE1BIT, 0, 0,
602     { 0, { (const PTR) 0 } },
603     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
604 /* expcause2bit: external load stalled bit */
605   { "expcause2bit", EPIPHANY_OPERAND_EXPCAUSE2BIT, HW_H_EXPCAUSE2BIT, 0, 0,
606     { 0, { (const PTR) 0 } },
607     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
608 /* extFstallbit: external fetch stalled bit */
609   { "extFstallbit", EPIPHANY_OPERAND_EXTFSTALLBIT, HW_H_EXTFSTALLBIT, 0, 0,
610     { 0, { (const PTR) 0 } },
611     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
612 /* trmbit: 0=round to nearest, 1=trunacte selct bit */
613   { "trmbit", EPIPHANY_OPERAND_TRMBIT, HW_H_TRMBIT, 0, 0,
614     { 0, { (const PTR) 0 } },
615     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
616 /* invExcEnbit: invalid exception enable bit */
617   { "invExcEnbit", EPIPHANY_OPERAND_INVEXCENBIT, HW_H_INVEXCENBIT, 0, 0,
618     { 0, { (const PTR) 0 } },
619     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
620 /* ovfExcEnbit: overflow exception enable bit */
621   { "ovfExcEnbit", EPIPHANY_OPERAND_OVFEXCENBIT, HW_H_OVFEXCENBIT, 0, 0,
622     { 0, { (const PTR) 0 } },
623     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
624 /* unExcEnbit: underflow exception enable bit */
625   { "unExcEnbit", EPIPHANY_OPERAND_UNEXCENBIT, HW_H_UNEXCENBIT, 0, 0,
626     { 0, { (const PTR) 0 } },
627     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
628 /* timer0bit0: timer 0 mode selection 0 */
629   { "timer0bit0", EPIPHANY_OPERAND_TIMER0BIT0, HW_H_TIMER0BIT0, 0, 0,
630     { 0, { (const PTR) 0 } },
631     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
632 /* timer0bit1: timer 0 mode selection 1 */
633   { "timer0bit1", EPIPHANY_OPERAND_TIMER0BIT1, HW_H_TIMER0BIT1, 0, 0,
634     { 0, { (const PTR) 0 } },
635     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
636 /* timer0bit2: timer 0 mode selection 2 */
637   { "timer0bit2", EPIPHANY_OPERAND_TIMER0BIT2, HW_H_TIMER0BIT2, 0, 0,
638     { 0, { (const PTR) 0 } },
639     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
640 /* timer0bit3: timer 0 mode selection 3 */
641   { "timer0bit3", EPIPHANY_OPERAND_TIMER0BIT3, HW_H_TIMER0BIT3, 0, 0,
642     { 0, { (const PTR) 0 } },
643     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
644 /* timer1bit0: timer 1 mode selection 0 */
645   { "timer1bit0", EPIPHANY_OPERAND_TIMER1BIT0, HW_H_TIMER1BIT0, 0, 0,
646     { 0, { (const PTR) 0 } },
647     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
648 /* timer1bit1: timer 1 mode selection 1 */
649   { "timer1bit1", EPIPHANY_OPERAND_TIMER1BIT1, HW_H_TIMER1BIT1, 0, 0,
650     { 0, { (const PTR) 0 } },
651     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
652 /* timer1bit2: timer 1 mode selection 2 */
653   { "timer1bit2", EPIPHANY_OPERAND_TIMER1BIT2, HW_H_TIMER1BIT2, 0, 0,
654     { 0, { (const PTR) 0 } },
655     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
656 /* timer1bit3: timer 1 mode selection 3 */
657   { "timer1bit3", EPIPHANY_OPERAND_TIMER1BIT3, HW_H_TIMER1BIT3, 0, 0,
658     { 0, { (const PTR) 0 } },
659     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
660 /* mbkptEnbit: multicore bkpt enable */
661   { "mbkptEnbit", EPIPHANY_OPERAND_MBKPTENBIT, HW_H_MBKPTENBIT, 0, 0,
662     { 0, { (const PTR) 0 } },
663     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
664 /* clockGateEnbit: clock gate enable enable */
665   { "clockGateEnbit", EPIPHANY_OPERAND_CLOCKGATEENBIT, HW_H_CLOCKGATEENBIT, 0, 0,
666     { 0, { (const PTR) 0 } },
667     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
668 /* arithmetic-modebit0: arithmetic mode bit0 */
669   { "arithmetic-modebit0", EPIPHANY_OPERAND_ARITHMETIC_MODEBIT0, HW_H_ARITHMETIC_MODEBIT0, 0, 0,
670     { 0, { (const PTR) 0 } },
671     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
672 /* arithmetic-modebit1: arithmetic mode bit1 */
673   { "arithmetic-modebit1", EPIPHANY_OPERAND_ARITHMETIC_MODEBIT1, HW_H_ARITHMETIC_MODEBIT1, 0, 0,
674     { 0, { (const PTR) 0 } },
675     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
676 /* arithmetic-modebit2: arithmetic mode bit2 */
677   { "arithmetic-modebit2", EPIPHANY_OPERAND_ARITHMETIC_MODEBIT2, HW_H_ARITHMETIC_MODEBIT2, 0, 0,
678     { 0, { (const PTR) 0 } },
679     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
680 /* coreCfgResBit12: core config bit 12 */
681   { "coreCfgResBit12", EPIPHANY_OPERAND_CORECFGRESBIT12, HW_H_CORECFGRESBIT12, 0, 0,
682     { 0, { (const PTR) 0 } },
683     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
684 /* coreCfgResBit13: core config bit 13 */
685   { "coreCfgResBit13", EPIPHANY_OPERAND_CORECFGRESBIT13, HW_H_CORECFGRESBIT13, 0, 0,
686     { 0, { (const PTR) 0 } },
687     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
688 /* coreCfgResBit14: core config bit 14 */
689   { "coreCfgResBit14", EPIPHANY_OPERAND_CORECFGRESBIT14, HW_H_CORECFGRESBIT14, 0, 0,
690     { 0, { (const PTR) 0 } },
691     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
692 /* coreCfgResBit15: core config bit 15 */
693   { "coreCfgResBit15", EPIPHANY_OPERAND_CORECFGRESBIT15, HW_H_CORECFGRESBIT15, 0, 0,
694     { 0, { (const PTR) 0 } },
695     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
696 /* coreCfgResBit16: core config bit 16 */
697   { "coreCfgResBit16", EPIPHANY_OPERAND_CORECFGRESBIT16, HW_H_CORECFGRESBIT16, 0, 0,
698     { 0, { (const PTR) 0 } },
699     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
700 /* coreCfgResBit20: core config bit 20 */
701   { "coreCfgResBit20", EPIPHANY_OPERAND_CORECFGRESBIT20, HW_H_CORECFGRESBIT20, 0, 0,
702     { 0, { (const PTR) 0 } },
703     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
704 /* coreCfgResBit21: core config bit 21 */
705   { "coreCfgResBit21", EPIPHANY_OPERAND_CORECFGRESBIT21, HW_H_CORECFGRESBIT21, 0, 0,
706     { 0, { (const PTR) 0 } },
707     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
708 /* coreCfgResBit24: core config bit 24 */
709   { "coreCfgResBit24", EPIPHANY_OPERAND_CORECFGRESBIT24, HW_H_CORECFGRESBIT24, 0, 0,
710     { 0, { (const PTR) 0 } },
711     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
712 /* coreCfgResBit25: core config bit 25 */
713   { "coreCfgResBit25", EPIPHANY_OPERAND_CORECFGRESBIT25, HW_H_CORECFGRESBIT25, 0, 0,
714     { 0, { (const PTR) 0 } },
715     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
716 /* coreCfgResBit26: core config bit 26 */
717   { "coreCfgResBit26", EPIPHANY_OPERAND_CORECFGRESBIT26, HW_H_CORECFGRESBIT26, 0, 0,
718     { 0, { (const PTR) 0 } },
719     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
720 /* coreCfgResBit27: core config bit 27 */
721   { "coreCfgResBit27", EPIPHANY_OPERAND_CORECFGRESBIT27, HW_H_CORECFGRESBIT27, 0, 0,
722     { 0, { (const PTR) 0 } },
723     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
724 /* coreCfgResBit28: core config bit 28 */
725   { "coreCfgResBit28", EPIPHANY_OPERAND_CORECFGRESBIT28, HW_H_CORECFGRESBIT28, 0, 0,
726     { 0, { (const PTR) 0 } },
727     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
728 /* coreCfgResBit29: core config bit 29 */
729   { "coreCfgResBit29", EPIPHANY_OPERAND_CORECFGRESBIT29, HW_H_CORECFGRESBIT29, 0, 0,
730     { 0, { (const PTR) 0 } },
731     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
732 /* coreCfgResBit30: core config bit 30 */
733   { "coreCfgResBit30", EPIPHANY_OPERAND_CORECFGRESBIT30, HW_H_CORECFGRESBIT30, 0, 0,
734     { 0, { (const PTR) 0 } },
735     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
736 /* coreCfgResBit31: core config bit 31 */
737   { "coreCfgResBit31", EPIPHANY_OPERAND_CORECFGRESBIT31, HW_H_CORECFGRESBIT31, 0, 0,
738     { 0, { (const PTR) 0 } },
739     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
740 /* gidisablebit: global interrupt disable bit */
741   { "gidisablebit", EPIPHANY_OPERAND_GIDISABLEBIT, HW_H_GIDISABLEBIT, 0, 0,
742     { 0, { (const PTR) 0 } },
743     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
744 /* kmbit: kernel mode bit */
745   { "kmbit", EPIPHANY_OPERAND_KMBIT, HW_H_KMBIT, 0, 0,
746     { 0, { (const PTR) 0 } },
747     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
748 /* caibit: core actibe indicator bit */
749   { "caibit", EPIPHANY_OPERAND_CAIBIT, HW_H_CAIBIT, 0, 0,
750     { 0, { (const PTR) 0 } },
751     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
752 /* sflagbit: sflag bit */
753   { "sflagbit", EPIPHANY_OPERAND_SFLAGBIT, HW_H_SFLAGBIT, 0, 0,
754     { 0, { (const PTR) 0 } },
755     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
756 /* memaddr: memory effective address */
757   { "memaddr", EPIPHANY_OPERAND_MEMADDR, HW_H_MEMADDR, 0, 0,
758     { 0, { (const PTR) 0 } },
759     { 0|A(SEM_ONLY), { { { (1<<MACH_BASE), 0 } } } }  },
760 /* simm24: branch address pc-relative */
761   { "simm24", EPIPHANY_OPERAND_SIMM24, HW_H_IADDR, 31, 24,
762     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SIMM24] } },
763     { 0|A(RELAX)|A(RELOC)|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } }  },
764 /* simm8: branch address pc-relative */
765   { "simm8", EPIPHANY_OPERAND_SIMM8, HW_H_IADDR, 15, 8,
766     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SIMM8] } },
767     { 0|A(RELAX)|A(RELOC)|A(PCREL_ADDR), { { { (1<<MACH_BASE), 0 } } } }  },
768 /* rd: destination register */
769   { "rd", EPIPHANY_OPERAND_RD, HW_H_REGISTERS, 15, 3,
770     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RD] } },
771     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
772 /* rn: source register */
773   { "rn", EPIPHANY_OPERAND_RN, HW_H_REGISTERS, 12, 3,
774     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RN] } },
775     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
776 /* rm: source register */
777   { "rm", EPIPHANY_OPERAND_RM, HW_H_REGISTERS, 9, 3,
778     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RM] } },
779     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
780 /* frd: fp destination register */
781   { "frd", EPIPHANY_OPERAND_FRD, HW_H_FPREGISTERS, 15, 3,
782     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RD] } },
783     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
784 /* frn: fp source register */
785   { "frn", EPIPHANY_OPERAND_FRN, HW_H_FPREGISTERS, 12, 3,
786     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RN] } },
787     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
788 /* frm: fp source register */
789   { "frm", EPIPHANY_OPERAND_FRM, HW_H_FPREGISTERS, 9, 3,
790     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_RM] } },
791     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
792 /* rd6: destination register */
793   { "rd6", EPIPHANY_OPERAND_RD6, HW_H_REGISTERS, 15, 6,
794     { 2, { (const PTR) &EPIPHANY_F_RD6_MULTI_IFIELD[0] } },
795     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
796 /* rn6: source register */
797   { "rn6", EPIPHANY_OPERAND_RN6, HW_H_REGISTERS, 12, 6,
798     { 2, { (const PTR) &EPIPHANY_F_RN6_MULTI_IFIELD[0] } },
799     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
800 /* rm6: source register */
801   { "rm6", EPIPHANY_OPERAND_RM6, HW_H_REGISTERS, 9, 6,
802     { 2, { (const PTR) &EPIPHANY_F_RM6_MULTI_IFIELD[0] } },
803     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
804 /* frd6: fp destination register */
805   { "frd6", EPIPHANY_OPERAND_FRD6, HW_H_FPREGISTERS, 15, 6,
806     { 2, { (const PTR) &EPIPHANY_F_RD6_MULTI_IFIELD[0] } },
807     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
808 /* frn6: fp source register */
809   { "frn6", EPIPHANY_OPERAND_FRN6, HW_H_FPREGISTERS, 12, 6,
810     { 2, { (const PTR) &EPIPHANY_F_RN6_MULTI_IFIELD[0] } },
811     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
812 /* frm6: fp source register */
813   { "frm6", EPIPHANY_OPERAND_FRM6, HW_H_FPREGISTERS, 9, 6,
814     { 2, { (const PTR) &EPIPHANY_F_RM6_MULTI_IFIELD[0] } },
815     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
816 /* sd: special destination */
817   { "sd", EPIPHANY_OPERAND_SD, HW_H_CORE_REGISTERS, 15, 3,
818     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SD] } },
819     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
820 /* sn: special source */
821   { "sn", EPIPHANY_OPERAND_SN, HW_H_CORE_REGISTERS, 12, 3,
822     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SN] } },
823     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
824 /* sd6: special destination register */
825   { "sd6", EPIPHANY_OPERAND_SD6, HW_H_CORE_REGISTERS, 15, 6,
826     { 2, { (const PTR) &EPIPHANY_F_SD6_MULTI_IFIELD[0] } },
827     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
828 /* sn6: special source register */
829   { "sn6", EPIPHANY_OPERAND_SN6, HW_H_CORE_REGISTERS, 12, 6,
830     { 2, { (const PTR) &EPIPHANY_F_SN6_MULTI_IFIELD[0] } },
831     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
832 /* sddma: dma register */
833   { "sddma", EPIPHANY_OPERAND_SDDMA, HW_H_COREDMA_REGISTERS, 15, 6,
834     { 2, { (const PTR) &EPIPHANY_F_SD6_MULTI_IFIELD[0] } },
835     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
836 /* sndma: dma register */
837   { "sndma", EPIPHANY_OPERAND_SNDMA, HW_H_COREDMA_REGISTERS, 12, 6,
838     { 2, { (const PTR) &EPIPHANY_F_SN6_MULTI_IFIELD[0] } },
839     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
840 /* sdmem: mem register */
841   { "sdmem", EPIPHANY_OPERAND_SDMEM, HW_H_COREMEM_REGISTERS, 15, 6,
842     { 2, { (const PTR) &EPIPHANY_F_SD6_MULTI_IFIELD[0] } },
843     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
844 /* snmem: mem register */
845   { "snmem", EPIPHANY_OPERAND_SNMEM, HW_H_COREMEM_REGISTERS, 12, 6,
846     { 2, { (const PTR) &EPIPHANY_F_SN6_MULTI_IFIELD[0] } },
847     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
848 /* sdmesh: mesh register */
849   { "sdmesh", EPIPHANY_OPERAND_SDMESH, HW_H_COREMESH_REGISTERS, 15, 6,
850     { 2, { (const PTR) &EPIPHANY_F_SD6_MULTI_IFIELD[0] } },
851     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
852 /* snmesh: mesh register */
853   { "snmesh", EPIPHANY_OPERAND_SNMESH, HW_H_COREMESH_REGISTERS, 12, 6,
854     { 2, { (const PTR) &EPIPHANY_F_SN6_MULTI_IFIELD[0] } },
855     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
856 /* simm3: signed 3-bit literal */
857   { "simm3", EPIPHANY_OPERAND_SIMM3, HW_H_SINT, 9, 3,
858     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SDISP3] } },
859     { 0|A(RELAX), { { { (1<<MACH_BASE), 0 } } } }  },
860 /* simm11: signed 11-bit literal */
861   { "simm11", EPIPHANY_OPERAND_SIMM11, HW_H_SINT, 9, 11,
862     { 2, { (const PTR) &EPIPHANY_F_SDISP11_MULTI_IFIELD[0] } },
863     { 0|A(RELAX)|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
864 /* disp3: short data displacement */
865   { "disp3", EPIPHANY_OPERAND_DISP3, HW_H_UINT, 9, 3,
866     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_DISP3] } },
867     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
868 /* trapnum6: parameter for swi or trap */
869   { "trapnum6", EPIPHANY_OPERAND_TRAPNUM6, HW_H_UINT, 15, 6,
870     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_TRAP_NUM] } },
871     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
872 /* swi_num: unsigned 6-bit swi# */
873   { "swi_num", EPIPHANY_OPERAND_SWI_NUM, HW_H_UINT, 15, 6,
874     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_TRAP_NUM] } },
875     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
876 /* disp11: sign-magnitude data displacement */
877   { "disp11", EPIPHANY_OPERAND_DISP11, HW_H_UINT, 9, 11,
878     { 2, { (const PTR) &EPIPHANY_F_DISP11_MULTI_IFIELD[0] } },
879     { 0|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
880 /* shift: immediate shift amount */
881   { "shift", EPIPHANY_OPERAND_SHIFT, HW_H_UINT, 9, 5,
882     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SHIFT] } },
883     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
884 /* imm16: 16-bit unsigned literal */
885   { "imm16", EPIPHANY_OPERAND_IMM16, HW_H_ADDR, 12, 16,
886     { 2, { (const PTR) &EPIPHANY_F_IMM16_MULTI_IFIELD[0] } },
887     { 0|A(RELAX)|A(VIRTUAL), { { { (1<<MACH_BASE), 0 } } } }  },
888 /* imm8: 8-bit unsigned literal */
889   { "imm8", EPIPHANY_OPERAND_IMM8, HW_H_ADDR, 12, 8,
890     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_IMM8] } },
891     { 0|A(RELAX), { { { (1<<MACH_BASE), 0 } } } }  },
892 /* direction: +/- indexing */
893   { "direction", EPIPHANY_OPERAND_DIRECTION, HW_H_UINT, 20, 1,
894     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_ADDSUBX] } },
895     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
896 /* dpmi: +/- magnitude immediate displacement */
897   { "dpmi", EPIPHANY_OPERAND_DPMI, HW_H_UINT, 24, 1,
898     { 0, { (const PTR) &epiphany_cgen_ifld_table[EPIPHANY_F_SUBD] } },
899     { 0, { { { (1<<MACH_BASE), 0 } } } }  },
900 /* sentinel */
901   { 0, 0, 0, 0, 0,
902     { 0, { (const PTR) 0 } },
903     { 0, { { { (1<<MACH_BASE), 0 } } } } }
904 };
905
906 #undef A
907
908
909 /* The instruction table.  */
910
911 #define OP(field) CGEN_SYNTAX_MAKE_FIELD (OPERAND (field))
912 #define A(a) (1 << CGEN_INSN_##a)
913
914 static const CGEN_IBASE epiphany_cgen_insn_table[MAX_INSNS] =
915 {
916   /* Special null first entry.
917      A `num' value of zero is thus invalid.
918      Also, the special `invalid' insn resides here.  */
919   { 0, 0, 0, 0, { 0, { { { (1<<MACH_BASE), 0 } } } } },
920 /* beq.s $simm8 */
921   {
922     EPIPHANY_INSN_BEQ16, "beq16", "beq.s", 16,
923     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
924   },
925 /* beq.l $simm24 */
926   {
927     EPIPHANY_INSN_BEQ, "beq", "beq.l", 32,
928     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
929   },
930 /* bne.s $simm8 */
931   {
932     EPIPHANY_INSN_BNE16, "bne16", "bne.s", 16,
933     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
934   },
935 /* bne.l $simm24 */
936   {
937     EPIPHANY_INSN_BNE, "bne", "bne.l", 32,
938     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
939   },
940 /* bgtu.s $simm8 */
941   {
942     EPIPHANY_INSN_BGTU16, "bgtu16", "bgtu.s", 16,
943     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
944   },
945 /* bgtu.l $simm24 */
946   {
947     EPIPHANY_INSN_BGTU, "bgtu", "bgtu.l", 32,
948     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
949   },
950 /* bgteu.s $simm8 */
951   {
952     EPIPHANY_INSN_BGTEU16, "bgteu16", "bgteu.s", 16,
953     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
954   },
955 /* bgteu.l $simm24 */
956   {
957     EPIPHANY_INSN_BGTEU, "bgteu", "bgteu.l", 32,
958     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
959   },
960 /* blteu.s $simm8 */
961   {
962     EPIPHANY_INSN_BLTEU16, "blteu16", "blteu.s", 16,
963     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
964   },
965 /* blteu.l $simm24 */
966   {
967     EPIPHANY_INSN_BLTEU, "blteu", "blteu.l", 32,
968     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
969   },
970 /* bltu.s $simm8 */
971   {
972     EPIPHANY_INSN_BLTU16, "bltu16", "bltu.s", 16,
973     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
974   },
975 /* bltu.l $simm24 */
976   {
977     EPIPHANY_INSN_BLTU, "bltu", "bltu.l", 32,
978     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
979   },
980 /* bgt.s $simm8 */
981   {
982     EPIPHANY_INSN_BGT16, "bgt16", "bgt.s", 16,
983     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
984   },
985 /* bgt.l $simm24 */
986   {
987     EPIPHANY_INSN_BGT, "bgt", "bgt.l", 32,
988     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
989   },
990 /* bgte.s $simm8 */
991   {
992     EPIPHANY_INSN_BGTE16, "bgte16", "bgte.s", 16,
993     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
994   },
995 /* bgte.l $simm24 */
996   {
997     EPIPHANY_INSN_BGTE, "bgte", "bgte.l", 32,
998     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
999   },
1000 /* blt.s $simm8 */
1001   {
1002     EPIPHANY_INSN_BLT16, "blt16", "blt.s", 16,
1003     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1004   },
1005 /* blt.l $simm24 */
1006   {
1007     EPIPHANY_INSN_BLT, "blt", "blt.l", 32,
1008     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1009   },
1010 /* blte.s $simm8 */
1011   {
1012     EPIPHANY_INSN_BLTE16, "blte16", "blte.s", 16,
1013     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1014   },
1015 /* blte.l $simm24 */
1016   {
1017     EPIPHANY_INSN_BLTE, "blte", "blte.l", 32,
1018     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1019   },
1020 /* bbeq.s $simm8 */
1021   {
1022     EPIPHANY_INSN_BBEQ16, "bbeq16", "bbeq.s", 16,
1023     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1024   },
1025 /* bbeq.l $simm24 */
1026   {
1027     EPIPHANY_INSN_BBEQ, "bbeq", "bbeq.l", 32,
1028     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1029   },
1030 /* bbne.s $simm8 */
1031   {
1032     EPIPHANY_INSN_BBNE16, "bbne16", "bbne.s", 16,
1033     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1034   },
1035 /* bbne.l $simm24 */
1036   {
1037     EPIPHANY_INSN_BBNE, "bbne", "bbne.l", 32,
1038     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1039   },
1040 /* bblt.s $simm8 */
1041   {
1042     EPIPHANY_INSN_BBLT16, "bblt16", "bblt.s", 16,
1043     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1044   },
1045 /* bblt.l $simm24 */
1046   {
1047     EPIPHANY_INSN_BBLT, "bblt", "bblt.l", 32,
1048     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1049   },
1050 /* bblte.s $simm8 */
1051   {
1052     EPIPHANY_INSN_BBLTE16, "bblte16", "bblte.s", 16,
1053     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1054   },
1055 /* bblte.l $simm24 */
1056   {
1057     EPIPHANY_INSN_BBLTE, "bblte", "bblte.l", 32,
1058     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1059   },
1060 /* b.s $simm8 */
1061   {
1062     EPIPHANY_INSN_B16, "b16", "b.s", 16,
1063     { 0|A(SHORT_INSN)|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1064   },
1065 /* b.l $simm24 */
1066   {
1067     EPIPHANY_INSN_B, "b", "b.l", 32,
1068     { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1069   },
1070 /* bl.s $simm8 */
1071   {
1072     EPIPHANY_INSN_BL16, "bl16", "bl.s", 16,
1073     { 0|A(SHORT_INSN)|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1074   },
1075 /* bl.l $simm24 */
1076   {
1077     EPIPHANY_INSN_BL, "bl", "bl.l", 32,
1078     { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1079   },
1080 /* jr $rn */
1081   {
1082     EPIPHANY_INSN_JR16, "jr16", "jr", 16,
1083     { 0|A(SHORT_INSN)|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1084   },
1085 /* rts */
1086   {
1087     -1, "rts", "rts", 32,
1088     { 0|A(UNCOND_CTI)|A(ALIAS), { { { (1<<MACH_BASE), 0 } } } }
1089   },
1090 /* jr $rn6 */
1091   {
1092     EPIPHANY_INSN_JR, "jr", "jr", 32,
1093     { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1094   },
1095 /* jalr $rn */
1096   {
1097     EPIPHANY_INSN_JALR16, "jalr16", "jalr", 16,
1098     { 0|A(SHORT_INSN)|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1099   },
1100 /* jalr $rn6 */
1101   {
1102     EPIPHANY_INSN_JALR, "jalr", "jalr", 32,
1103     { 0|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1104   },
1105 /* ldrb $rd,[$rn,$rm] */
1106   {
1107     EPIPHANY_INSN_LDRBX16_S, "ldrbx16.s", "ldrb", 16,
1108     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1109   },
1110 /* ldrb $rd,[$rn],$rm */
1111   {
1112     EPIPHANY_INSN_LDRBP16_S, "ldrbp16.s", "ldrb", 16,
1113     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1114   },
1115 /* ldrb $rd6,[$rn6,$direction$rm6] */
1116   {
1117     EPIPHANY_INSN_LDRBX_L, "ldrbx.l", "ldrb", 32,
1118     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1119   },
1120 /* ldrb $rd6,[$rn6],$direction$rm6 */
1121   {
1122     EPIPHANY_INSN_LDRBP_L, "ldrbp.l", "ldrb", 32,
1123     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1124   },
1125 /* ldrb $rd,[$rn,$disp3] */
1126   {
1127     EPIPHANY_INSN_LDRBD16_S, "ldrbd16.s", "ldrb", 16,
1128     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1129   },
1130 /* ldrb $rd6,[$rn6,$dpmi$disp11] */
1131   {
1132     EPIPHANY_INSN_LDRBD_L, "ldrbd.l", "ldrb", 32,
1133     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1134   },
1135 /* ldrb $rd6,[$rn6],$dpmi$disp11 */
1136   {
1137     EPIPHANY_INSN_LDRBDPM_L, "ldrbdpm.l", "ldrb", 32,
1138     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1139   },
1140 /* ldrh $rd,[$rn,$rm] */
1141   {
1142     EPIPHANY_INSN_LDRHX16_S, "ldrhx16.s", "ldrh", 16,
1143     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1144   },
1145 /* ldrh $rd,[$rn],$rm */
1146   {
1147     EPIPHANY_INSN_LDRHP16_S, "ldrhp16.s", "ldrh", 16,
1148     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1149   },
1150 /* ldrh $rd6,[$rn6,$direction$rm6] */
1151   {
1152     EPIPHANY_INSN_LDRHX_L, "ldrhx.l", "ldrh", 32,
1153     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1154   },
1155 /* ldrh $rd6,[$rn6],$direction$rm6 */
1156   {
1157     EPIPHANY_INSN_LDRHP_L, "ldrhp.l", "ldrh", 32,
1158     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1159   },
1160 /* ldrh $rd,[$rn,$disp3] */
1161   {
1162     EPIPHANY_INSN_LDRHD16_S, "ldrhd16.s", "ldrh", 16,
1163     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1164   },
1165 /* ldrh $rd6,[$rn6,$dpmi$disp11] */
1166   {
1167     EPIPHANY_INSN_LDRHD_L, "ldrhd.l", "ldrh", 32,
1168     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1169   },
1170 /* ldrh $rd6,[$rn6],$dpmi$disp11 */
1171   {
1172     EPIPHANY_INSN_LDRHDPM_L, "ldrhdpm.l", "ldrh", 32,
1173     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1174   },
1175 /* ldr $rd,[$rn,$rm] */
1176   {
1177     EPIPHANY_INSN_LDRX16_S, "ldrx16.s", "ldr", 16,
1178     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1179   },
1180 /* ldr $rd,[$rn],$rm */
1181   {
1182     EPIPHANY_INSN_LDRP16_S, "ldrp16.s", "ldr", 16,
1183     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1184   },
1185 /* ldr $rd6,[$rn6,$direction$rm6] */
1186   {
1187     EPIPHANY_INSN_LDRX_L, "ldrx.l", "ldr", 32,
1188     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1189   },
1190 /* ldr $rd6,[$rn6],$direction$rm6 */
1191   {
1192     EPIPHANY_INSN_LDRP_L, "ldrp.l", "ldr", 32,
1193     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1194   },
1195 /* ldr $rd,[$rn,$disp3] */
1196   {
1197     EPIPHANY_INSN_LDRD16_S, "ldrd16.s", "ldr", 16,
1198     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1199   },
1200 /* ldr $rd6,[$rn6,$dpmi$disp11] */
1201   {
1202     EPIPHANY_INSN_LDRD_L, "ldrd.l", "ldr", 32,
1203     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1204   },
1205 /* ldr $rd6,[$rn6],$dpmi$disp11 */
1206   {
1207     EPIPHANY_INSN_LDRDPM_L, "ldrdpm.l", "ldr", 32,
1208     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1209   },
1210 /* ldrd $rd,[$rn,$rm] */
1211   {
1212     EPIPHANY_INSN_LDRDX16_S, "ldrdx16.s", "ldrd", 16,
1213     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1214   },
1215 /* ldrd $rd,[$rn],$rm */
1216   {
1217     EPIPHANY_INSN_LDRDP16_S, "ldrdp16.s", "ldrd", 16,
1218     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1219   },
1220 /* ldrd $rd6,[$rn6,$direction$rm6] */
1221   {
1222     EPIPHANY_INSN_LDRDX_L, "ldrdx.l", "ldrd", 32,
1223     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1224   },
1225 /* ldrd $rd6,[$rn6],$direction$rm6 */
1226   {
1227     EPIPHANY_INSN_LDRDP_L, "ldrdp.l", "ldrd", 32,
1228     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1229   },
1230 /* ldrd $rd,[$rn,$disp3] */
1231   {
1232     EPIPHANY_INSN_LDRDD16_S, "ldrdd16.s", "ldrd", 16,
1233     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1234   },
1235 /* ldrd $rd6,[$rn6,$dpmi$disp11] */
1236   {
1237     EPIPHANY_INSN_LDRDD_L, "ldrdd.l", "ldrd", 32,
1238     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1239   },
1240 /* ldrd $rd6,[$rn6],$dpmi$disp11 */
1241   {
1242     EPIPHANY_INSN_LDRDDPM_L, "ldrddpm.l", "ldrd", 32,
1243     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1244   },
1245 /* testsetb $rd6,[$rn6,$direction$rm6] */
1246   {
1247     EPIPHANY_INSN_TESTSETBT, "testsetbt", "testsetb", 32,
1248     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1249   },
1250 /* testseth $rd6,[$rn6,$direction$rm6] */
1251   {
1252     EPIPHANY_INSN_TESTSETHT, "testsetht", "testseth", 32,
1253     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1254   },
1255 /* testset $rd6,[$rn6,$direction$rm6] */
1256   {
1257     EPIPHANY_INSN_TESTSETT, "testsett", "testset", 32,
1258     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1259   },
1260 /* strb $rd,[$rn,$rm] */
1261   {
1262     EPIPHANY_INSN_STRBX16, "strbx16", "strb", 16,
1263     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1264   },
1265 /* strb $rd6,[$rn6,$direction$rm6] */
1266   {
1267     EPIPHANY_INSN_STRBX, "strbx", "strb", 32,
1268     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1269   },
1270 /* strb $rd,[$rn],$rm */
1271   {
1272     EPIPHANY_INSN_STRBP16, "strbp16", "strb", 16,
1273     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1274   },
1275 /* strb $rd6,[$rn6],$direction$rm6 */
1276   {
1277     EPIPHANY_INSN_STRBP, "strbp", "strb", 32,
1278     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1279   },
1280 /* strb $rd,[$rn,$disp3] */
1281   {
1282     EPIPHANY_INSN_STRBD16, "strbd16", "strb", 16,
1283     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1284   },
1285 /* strb $rd6,[$rn6,$dpmi$disp11] */
1286   {
1287     EPIPHANY_INSN_STRBD, "strbd", "strb", 32,
1288     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1289   },
1290 /* strb $rd6,[$rn6],$dpmi$disp11 */
1291   {
1292     EPIPHANY_INSN_STRBDPM, "strbdpm", "strb", 32,
1293     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1294   },
1295 /* strh $rd,[$rn,$rm] */
1296   {
1297     EPIPHANY_INSN_STRHX16, "strhx16", "strh", 16,
1298     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1299   },
1300 /* strh $rd6,[$rn6,$direction$rm6] */
1301   {
1302     EPIPHANY_INSN_STRHX, "strhx", "strh", 32,
1303     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1304   },
1305 /* strh $rd,[$rn],$rm */
1306   {
1307     EPIPHANY_INSN_STRHP16, "strhp16", "strh", 16,
1308     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1309   },
1310 /* strh $rd6,[$rn6],$direction$rm6 */
1311   {
1312     EPIPHANY_INSN_STRHP, "strhp", "strh", 32,
1313     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1314   },
1315 /* strh $rd,[$rn,$disp3] */
1316   {
1317     EPIPHANY_INSN_STRHD16, "strhd16", "strh", 16,
1318     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1319   },
1320 /* strh $rd6,[$rn6,$dpmi$disp11] */
1321   {
1322     EPIPHANY_INSN_STRHD, "strhd", "strh", 32,
1323     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1324   },
1325 /* strh $rd6,[$rn6],$dpmi$disp11 */
1326   {
1327     EPIPHANY_INSN_STRHDPM, "strhdpm", "strh", 32,
1328     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1329   },
1330 /* str $rd,[$rn,$rm] */
1331   {
1332     EPIPHANY_INSN_STRX16, "strx16", "str", 16,
1333     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1334   },
1335 /* str $rd6,[$rn6,$direction$rm6] */
1336   {
1337     EPIPHANY_INSN_STRX, "strx", "str", 32,
1338     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1339   },
1340 /* str $rd,[$rn],$rm */
1341   {
1342     EPIPHANY_INSN_STRP16, "strp16", "str", 16,
1343     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1344   },
1345 /* str $rd6,[$rn6],$direction$rm6 */
1346   {
1347     EPIPHANY_INSN_STRP, "strp", "str", 32,
1348     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1349   },
1350 /* str $rd,[$rn,$disp3] */
1351   {
1352     EPIPHANY_INSN_STRD16, "strd16", "str", 16,
1353     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1354   },
1355 /* str $rd6,[$rn6,$dpmi$disp11] */
1356   {
1357     EPIPHANY_INSN_STRD, "strd", "str", 32,
1358     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1359   },
1360 /* str $rd6,[$rn6],$dpmi$disp11 */
1361   {
1362     EPIPHANY_INSN_STRDPM, "strdpm", "str", 32,
1363     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1364   },
1365 /* strd $rd,[$rn,$rm] */
1366   {
1367     EPIPHANY_INSN_STRDX16, "strdx16", "strd", 16,
1368     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1369   },
1370 /* strd $rd6,[$rn6,$direction$rm6] */
1371   {
1372     EPIPHANY_INSN_STRDX, "strdx", "strd", 32,
1373     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1374   },
1375 /* strd $rd,[$rn],$rm */
1376   {
1377     EPIPHANY_INSN_STRDP16, "strdp16", "strd", 16,
1378     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1379   },
1380 /* strd $rd6,[$rn6],$direction$rm6 */
1381   {
1382     EPIPHANY_INSN_STRDP, "strdp", "strd", 32,
1383     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1384   },
1385 /* strd $rd,[$rn,$disp3] */
1386   {
1387     EPIPHANY_INSN_STRDD16, "strdd16", "strd", 16,
1388     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1389   },
1390 /* strd $rd6,[$rn6,$dpmi$disp11] */
1391   {
1392     EPIPHANY_INSN_STRDD, "strdd", "strd", 32,
1393     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1394   },
1395 /* strd $rd6,[$rn6],$dpmi$disp11 */
1396   {
1397     EPIPHANY_INSN_STRDDPM, "strddpm", "strd", 32,
1398     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1399   },
1400 /* moveq $rd,$rn */
1401   {
1402     EPIPHANY_INSN_CMOV16EQ, "cmov16EQ", "moveq", 16,
1403     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1404   },
1405 /* moveq $rd6,$rn6 */
1406   {
1407     EPIPHANY_INSN_CMOVEQ, "cmovEQ", "moveq", 32,
1408     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1409   },
1410 /* movne $rd,$rn */
1411   {
1412     EPIPHANY_INSN_CMOV16NE, "cmov16NE", "movne", 16,
1413     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1414   },
1415 /* movne $rd6,$rn6 */
1416   {
1417     EPIPHANY_INSN_CMOVNE, "cmovNE", "movne", 32,
1418     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1419   },
1420 /* movgtu $rd,$rn */
1421   {
1422     EPIPHANY_INSN_CMOV16GTU, "cmov16GTU", "movgtu", 16,
1423     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1424   },
1425 /* movgtu $rd6,$rn6 */
1426   {
1427     EPIPHANY_INSN_CMOVGTU, "cmovGTU", "movgtu", 32,
1428     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1429   },
1430 /* movgteu $rd,$rn */
1431   {
1432     EPIPHANY_INSN_CMOV16GTEU, "cmov16GTEU", "movgteu", 16,
1433     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1434   },
1435 /* movgteu $rd6,$rn6 */
1436   {
1437     EPIPHANY_INSN_CMOVGTEU, "cmovGTEU", "movgteu", 32,
1438     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1439   },
1440 /* movlteu $rd,$rn */
1441   {
1442     EPIPHANY_INSN_CMOV16LTEU, "cmov16LTEU", "movlteu", 16,
1443     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1444   },
1445 /* movlteu $rd6,$rn6 */
1446   {
1447     EPIPHANY_INSN_CMOVLTEU, "cmovLTEU", "movlteu", 32,
1448     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1449   },
1450 /* movltu $rd,$rn */
1451   {
1452     EPIPHANY_INSN_CMOV16LTU, "cmov16LTU", "movltu", 16,
1453     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1454   },
1455 /* movltu $rd6,$rn6 */
1456   {
1457     EPIPHANY_INSN_CMOVLTU, "cmovLTU", "movltu", 32,
1458     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1459   },
1460 /* movgt $rd,$rn */
1461   {
1462     EPIPHANY_INSN_CMOV16GT, "cmov16GT", "movgt", 16,
1463     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1464   },
1465 /* movgt $rd6,$rn6 */
1466   {
1467     EPIPHANY_INSN_CMOVGT, "cmovGT", "movgt", 32,
1468     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1469   },
1470 /* movgte $rd,$rn */
1471   {
1472     EPIPHANY_INSN_CMOV16GTE, "cmov16GTE", "movgte", 16,
1473     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1474   },
1475 /* movgte $rd6,$rn6 */
1476   {
1477     EPIPHANY_INSN_CMOVGTE, "cmovGTE", "movgte", 32,
1478     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1479   },
1480 /* movlt $rd,$rn */
1481   {
1482     EPIPHANY_INSN_CMOV16LT, "cmov16LT", "movlt", 16,
1483     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1484   },
1485 /* movlt $rd6,$rn6 */
1486   {
1487     EPIPHANY_INSN_CMOVLT, "cmovLT", "movlt", 32,
1488     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1489   },
1490 /* movlte $rd,$rn */
1491   {
1492     EPIPHANY_INSN_CMOV16LTE, "cmov16LTE", "movlte", 16,
1493     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1494   },
1495 /* movlte $rd6,$rn6 */
1496   {
1497     EPIPHANY_INSN_CMOVLTE, "cmovLTE", "movlte", 32,
1498     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1499   },
1500 /* mov $rd,$rn */
1501   {
1502     EPIPHANY_INSN_CMOV16B, "cmov16B", "mov", 16,
1503     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1504   },
1505 /* mov $rd6,$rn6 */
1506   {
1507     EPIPHANY_INSN_CMOVB, "cmovB", "mov", 32,
1508     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1509   },
1510 /* movbeq $rd,$rn */
1511   {
1512     EPIPHANY_INSN_CMOV16BEQ, "cmov16BEQ", "movbeq", 16,
1513     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1514   },
1515 /* movbeq $rd6,$rn6 */
1516   {
1517     EPIPHANY_INSN_CMOVBEQ, "cmovBEQ", "movbeq", 32,
1518     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1519   },
1520 /* movbne $rd,$rn */
1521   {
1522     EPIPHANY_INSN_CMOV16BNE, "cmov16BNE", "movbne", 16,
1523     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1524   },
1525 /* movbne $rd6,$rn6 */
1526   {
1527     EPIPHANY_INSN_CMOVBNE, "cmovBNE", "movbne", 32,
1528     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1529   },
1530 /* movblt $rd,$rn */
1531   {
1532     EPIPHANY_INSN_CMOV16BLT, "cmov16BLT", "movblt", 16,
1533     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1534   },
1535 /* movblt $rd6,$rn6 */
1536   {
1537     EPIPHANY_INSN_CMOVBLT, "cmovBLT", "movblt", 32,
1538     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1539   },
1540 /* movblte $rd,$rn */
1541   {
1542     EPIPHANY_INSN_CMOV16BLTE, "cmov16BLTE", "movblte", 16,
1543     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1544   },
1545 /* movblte $rd6,$rn6 */
1546   {
1547     EPIPHANY_INSN_CMOVBLTE, "cmovBLTE", "movblte", 32,
1548     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1549   },
1550 /* movts $sn,$rd */
1551   {
1552     EPIPHANY_INSN_MOVTS16, "movts16", "movts", 16,
1553     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1554   },
1555 /* movts $sn6,$rd6 */
1556   {
1557     EPIPHANY_INSN_MOVTS6, "movts6", "movts", 32,
1558     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1559   },
1560 /* movts $sndma,$rd6 */
1561   {
1562     EPIPHANY_INSN_MOVTSDMA, "movtsdma", "movts", 32,
1563     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1564   },
1565 /* movts $snmem,$rd6 */
1566   {
1567     EPIPHANY_INSN_MOVTSMEM, "movtsmem", "movts", 32,
1568     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1569   },
1570 /* movts $snmesh,$rd6 */
1571   {
1572     EPIPHANY_INSN_MOVTSMESH, "movtsmesh", "movts", 32,
1573     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1574   },
1575 /* movfs $rd,$sn */
1576   {
1577     EPIPHANY_INSN_MOVFS16, "movfs16", "movfs", 16,
1578     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1579   },
1580 /* movfs $rd6,$sn6 */
1581   {
1582     EPIPHANY_INSN_MOVFS6, "movfs6", "movfs", 32,
1583     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1584   },
1585 /* movfs $rd6,$sndma */
1586   {
1587     EPIPHANY_INSN_MOVFSDMA, "movfsdma", "movfs", 32,
1588     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1589   },
1590 /* movfs $rd6,$snmem */
1591   {
1592     EPIPHANY_INSN_MOVFSMEM, "movfsmem", "movfs", 32,
1593     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1594   },
1595 /* movfs $rd6,$snmesh */
1596   {
1597     EPIPHANY_INSN_MOVFSMESH, "movfsmesh", "movfs", 32,
1598     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1599   },
1600 /* nop */
1601   {
1602     EPIPHANY_INSN_NOP, "nop", "nop", 16,
1603     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1604   },
1605 /* snop */
1606   {
1607     EPIPHANY_INSN_SNOP, "snop", "snop", 16,
1608     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1609   },
1610 /* unimpl */
1611   {
1612     EPIPHANY_INSN_UNIMPL, "unimpl", "unimpl", 32,
1613     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1614   },
1615 /* idle */
1616   {
1617     EPIPHANY_INSN_IDLE, "idle", "idle", 16,
1618     { 0, { { { (1<<MACH_BASE), 0 } } } }
1619   },
1620 /* bkpt */
1621   {
1622     EPIPHANY_INSN_BKPT, "bkpt", "bkpt", 16,
1623     { 0|A(SHORT_INSN)|A(UNCOND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1624   },
1625 /* mbkpt */
1626   {
1627     EPIPHANY_INSN_MBKPT, "mbkpt", "mbkpt", 16,
1628     { 0|A(SHORT_INSN), { { { (1<<MACH_BASE), 0 } } } }
1629   },
1630 /* rti */
1631   {
1632     EPIPHANY_INSN_RTI, "rti", "rti", 16,
1633     { 0|A(UNCOND_CTI)|A(SHORT_INSN), { { { (1<<MACH_BASE), 0 } } } }
1634   },
1635 /* wand */
1636   {
1637     EPIPHANY_INSN_WAND, "wand", "wand", 16,
1638     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1639   },
1640 /* sync */
1641   {
1642     EPIPHANY_INSN_SYNC, "sync", "sync", 16,
1643     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1644   },
1645 /* gie */
1646   {
1647     EPIPHANY_INSN_GIEN, "gien", "gie", 16,
1648     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1649   },
1650 /* gid */
1651   {
1652     EPIPHANY_INSN_GIDIS, "gidis", "gid", 16,
1653     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1654   },
1655 /* swi $swi_num */
1656   {
1657     EPIPHANY_INSN_SWI_NUM, "swi_num", "swi", 16,
1658     { 0|A(UNCOND_CTI)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1659   },
1660 /* swi */
1661   {
1662     -1, "swi", "swi", 16,
1663     { 0|A(UNCOND_CTI)|A(SHORT_INSN)|A(ALIAS)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1664   },
1665 /* trap $trapnum6 */
1666   {
1667     EPIPHANY_INSN_TRAP16, "trap16", "trap", 16,
1668     { 0|A(UNCOND_CTI)|A(SHORT_INSN), { { { (1<<MACH_BASE), 0 } } } }
1669   },
1670 /* add $rd,$rn,$rm */
1671   {
1672     EPIPHANY_INSN_ADD16, "add16", "add", 16,
1673     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1674   },
1675 /* add $rd6,$rn6,$rm6 */
1676   {
1677     EPIPHANY_INSN_ADD, "add", "add", 32,
1678     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1679   },
1680 /* sub $rd,$rn,$rm */
1681   {
1682     EPIPHANY_INSN_SUB16, "sub16", "sub", 16,
1683     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1684   },
1685 /* sub $rd6,$rn6,$rm6 */
1686   {
1687     EPIPHANY_INSN_SUB, "sub", "sub", 32,
1688     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1689   },
1690 /* and $rd,$rn,$rm */
1691   {
1692     EPIPHANY_INSN_AND16, "and16", "and", 16,
1693     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1694   },
1695 /* and $rd6,$rn6,$rm6 */
1696   {
1697     EPIPHANY_INSN_AND, "and", "and", 32,
1698     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1699   },
1700 /* orr $rd,$rn,$rm */
1701   {
1702     EPIPHANY_INSN_ORR16, "orr16", "orr", 16,
1703     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1704   },
1705 /* orr $rd6,$rn6,$rm6 */
1706   {
1707     EPIPHANY_INSN_ORR, "orr", "orr", 32,
1708     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1709   },
1710 /* eor $rd,$rn,$rm */
1711   {
1712     EPIPHANY_INSN_EOR16, "eor16", "eor", 16,
1713     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1714   },
1715 /* eor $rd6,$rn6,$rm6 */
1716   {
1717     EPIPHANY_INSN_EOR, "eor", "eor", 32,
1718     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1719   },
1720 /* add.s $rd,$rn,$simm3 */
1721   {
1722     EPIPHANY_INSN_ADDI16, "addi16", "add.s", 16,
1723     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1724   },
1725 /* add.l $rd6,$rn6,$simm11 */
1726   {
1727     EPIPHANY_INSN_ADDI, "addi", "add.l", 32,
1728     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1729   },
1730 /* sub.s $rd,$rn,$simm3 */
1731   {
1732     EPIPHANY_INSN_SUBI16, "subi16", "sub.s", 16,
1733     { 0|A(IMM3)|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1734   },
1735 /* sub.l $rd6,$rn6,$simm11 */
1736   {
1737     EPIPHANY_INSN_SUBI, "subi", "sub.l", 32,
1738     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1739   },
1740 /* asr $rd,$rn,$rm */
1741   {
1742     EPIPHANY_INSN_ASR16, "asr16", "asr", 16,
1743     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1744   },
1745 /* asr $rd6,$rn6,$rm6 */
1746   {
1747     EPIPHANY_INSN_ASR, "asr", "asr", 32,
1748     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1749   },
1750 /* lsr $rd,$rn,$rm */
1751   {
1752     EPIPHANY_INSN_LSR16, "lsr16", "lsr", 16,
1753     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1754   },
1755 /* lsr $rd6,$rn6,$rm6 */
1756   {
1757     EPIPHANY_INSN_LSR, "lsr", "lsr", 32,
1758     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1759   },
1760 /* lsl $rd,$rn,$rm */
1761   {
1762     EPIPHANY_INSN_LSL16, "lsl16", "lsl", 16,
1763     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1764   },
1765 /* lsl $rd6,$rn6,$rm6 */
1766   {
1767     EPIPHANY_INSN_LSL, "lsl", "lsl", 32,
1768     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1769   },
1770 /* lsr $rd,$rn,$shift */
1771   {
1772     EPIPHANY_INSN_LSRI16, "lsri16", "lsr", 16,
1773     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1774   },
1775 /* lsr $rd6,$rn6,$shift */
1776   {
1777     EPIPHANY_INSN_LSRI32, "lsri32", "lsr", 32,
1778     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1779   },
1780 /* lsl $rd,$rn,$shift */
1781   {
1782     EPIPHANY_INSN_LSLI16, "lsli16", "lsl", 16,
1783     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1784   },
1785 /* lsl $rd6,$rn6,$shift */
1786   {
1787     EPIPHANY_INSN_LSLI32, "lsli32", "lsl", 32,
1788     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1789   },
1790 /* asr $rd,$rn,$shift */
1791   {
1792     EPIPHANY_INSN_ASRI16, "asri16", "asr", 16,
1793     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1794   },
1795 /* asr $rd6,$rn6,$shift */
1796   {
1797     EPIPHANY_INSN_ASRI32, "asri32", "asr", 32,
1798     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1799   },
1800 /* bitr $rd,$rn */
1801   {
1802     EPIPHANY_INSN_BITR16, "bitr16", "bitr", 16,
1803     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1804   },
1805 /* bitr $rd6,$rn6 */
1806   {
1807     EPIPHANY_INSN_BITR, "bitr", "bitr", 32,
1808     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1809   },
1810 /* fext $rd6,$rn6,$rm6 */
1811   {
1812     EPIPHANY_INSN_FEXT, "fext", "fext", 32,
1813     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1814   },
1815 /* fdep $rd6,$rn6,$rm6 */
1816   {
1817     EPIPHANY_INSN_FDEP, "fdep", "fdep", 32,
1818     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1819   },
1820 /* lfsr $rd6,$rn6,$rm6 */
1821   {
1822     EPIPHANY_INSN_LFSR, "lfsr", "lfsr", 32,
1823     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1824   },
1825 /* mov.b $rd,$imm8 */
1826   {
1827     EPIPHANY_INSN_MOV8, "mov8", "mov.b", 16,
1828     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1829   },
1830 /* mov.l $rd6,$imm16 */
1831   {
1832     EPIPHANY_INSN_MOV16, "mov16", "mov.l", 32,
1833     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1834   },
1835 /* movt $rd6,$imm16 */
1836   {
1837     EPIPHANY_INSN_MOVT, "movt", "movt", 32,
1838     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1839   },
1840 /* fadd $rd,$rn,$rm */
1841   {
1842     EPIPHANY_INSN_F_ADDF16, "f_addf16", "fadd", 16,
1843     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1844   },
1845 /* fadd $rd6,$rn6,$rm6 */
1846   {
1847     EPIPHANY_INSN_F_ADDF32, "f_addf32", "fadd", 32,
1848     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1849   },
1850 /* fsub $rd,$rn,$rm */
1851   {
1852     EPIPHANY_INSN_F_SUBF16, "f_subf16", "fsub", 16,
1853     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1854   },
1855 /* fsub $rd6,$rn6,$rm6 */
1856   {
1857     EPIPHANY_INSN_F_SUBF32, "f_subf32", "fsub", 32,
1858     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1859   },
1860 /* fmul $rd,$rn,$rm */
1861   {
1862     EPIPHANY_INSN_F_MULF16, "f_mulf16", "fmul", 16,
1863     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1864   },
1865 /* fmul $rd6,$rn6,$rm6 */
1866   {
1867     EPIPHANY_INSN_F_MULF32, "f_mulf32", "fmul", 32,
1868     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1869   },
1870 /* fmadd $rd,$rn,$rm */
1871   {
1872     EPIPHANY_INSN_F_MADDF16, "f_maddf16", "fmadd", 16,
1873     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1874   },
1875 /* fmadd $rd6,$rn6,$rm6 */
1876   {
1877     EPIPHANY_INSN_F_MADDF32, "f_maddf32", "fmadd", 32,
1878     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1879   },
1880 /* fmsub $rd,$rn,$rm */
1881   {
1882     EPIPHANY_INSN_F_MSUBF16, "f_msubf16", "fmsub", 16,
1883     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1884   },
1885 /* fmsub $rd6,$rn6,$rm6 */
1886   {
1887     EPIPHANY_INSN_F_MSUBF32, "f_msubf32", "fmsub", 32,
1888     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1889   },
1890 /* fabs rd,rn */
1891   {
1892     EPIPHANY_INSN_F_ABSF16, "f_absf16", "fabs", 16,
1893     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1894   },
1895 /* fabs $rd6,$rn6 */
1896   {
1897     EPIPHANY_INSN_F_ABSF32, "f_absf32", "fabs", 32,
1898     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1899   },
1900 /* float $rd,$rn */
1901   {
1902     EPIPHANY_INSN_F_LOATF16, "f_loatf16", "float", 16,
1903     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1904   },
1905 /* float $rd6,$rn6 */
1906   {
1907     EPIPHANY_INSN_F_LOATF32, "f_loatf32", "float", 32,
1908     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1909   },
1910 /* fix $rd,$rn */
1911   {
1912     EPIPHANY_INSN_F_IXF16, "f_ixf16", "fix", 16,
1913     { 0|A(SHORT_INSN)|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1914   },
1915 /* fix $rd6,$rn6 */
1916   {
1917     EPIPHANY_INSN_F_IXF32, "f_ixf32", "fix", 32,
1918     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1919   },
1920 /* frecip $frd6,$frn6 */
1921   {
1922     EPIPHANY_INSN_F_RECIPF32, "f_recipf32", "frecip", 32,
1923     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1924   },
1925 /* fsqrt $frd6,$frn6 */
1926   {
1927     EPIPHANY_INSN_F_SQRTF32, "f_sqrtf32", "fsqrt", 32,
1928     { 0|A(COND_CTI), { { { (1<<MACH_BASE), 0 } } } }
1929   },
1930 };
1931
1932 #undef OP
1933 #undef A
1934
1935 /* Initialize anything needed to be done once, before any cpu_open call.  */
1936
1937 static void
1938 init_tables (void)
1939 {
1940 }
1941
1942 #ifndef opcodes_error_handler
1943 #define opcodes_error_handler(...) \
1944   fprintf (stderr, __VA_ARGS__); fputc ('\n', stderr)
1945 #endif
1946
1947 static const CGEN_MACH * lookup_mach_via_bfd_name (const CGEN_MACH *, const char *);
1948 static void build_hw_table      (CGEN_CPU_TABLE *);
1949 static void build_ifield_table  (CGEN_CPU_TABLE *);
1950 static void build_operand_table (CGEN_CPU_TABLE *);
1951 static void build_insn_table    (CGEN_CPU_TABLE *);
1952 static void epiphany_cgen_rebuild_tables (CGEN_CPU_TABLE *);
1953
1954 /* Subroutine of epiphany_cgen_cpu_open to look up a mach via its bfd name.  */
1955
1956 static const CGEN_MACH *
1957 lookup_mach_via_bfd_name (const CGEN_MACH *table, const char *name)
1958 {
1959   while (table->name)
1960     {
1961       if (strcmp (name, table->bfd_name) == 0)
1962         return table;
1963       ++table;
1964     }
1965   return NULL;
1966 }
1967
1968 /* Subroutine of epiphany_cgen_cpu_open to build the hardware table.  */
1969
1970 static void
1971 build_hw_table (CGEN_CPU_TABLE *cd)
1972 {
1973   int i;
1974   int machs = cd->machs;
1975   const CGEN_HW_ENTRY *init = & epiphany_cgen_hw_table[0];
1976   /* MAX_HW is only an upper bound on the number of selected entries.
1977      However each entry is indexed by it's enum so there can be holes in
1978      the table.  */
1979   const CGEN_HW_ENTRY **selected =
1980     (const CGEN_HW_ENTRY **) xmalloc (MAX_HW * sizeof (CGEN_HW_ENTRY *));
1981
1982   cd->hw_table.init_entries = init;
1983   cd->hw_table.entry_size = sizeof (CGEN_HW_ENTRY);
1984   memset (selected, 0, MAX_HW * sizeof (CGEN_HW_ENTRY *));
1985   /* ??? For now we just use machs to determine which ones we want.  */
1986   for (i = 0; init[i].name != NULL; ++i)
1987     if (CGEN_HW_ATTR_VALUE (&init[i], CGEN_HW_MACH)
1988         & machs)
1989       selected[init[i].type] = &init[i];
1990   cd->hw_table.entries = selected;
1991   cd->hw_table.num_entries = MAX_HW;
1992 }
1993
1994 /* Subroutine of epiphany_cgen_cpu_open to build the hardware table.  */
1995
1996 static void
1997 build_ifield_table (CGEN_CPU_TABLE *cd)
1998 {
1999   cd->ifld_table = & epiphany_cgen_ifld_table[0];
2000 }
2001
2002 /* Subroutine of epiphany_cgen_cpu_open to build the hardware table.  */
2003
2004 static void
2005 build_operand_table (CGEN_CPU_TABLE *cd)
2006 {
2007   int i;
2008   int machs = cd->machs;
2009   const CGEN_OPERAND *init = & epiphany_cgen_operand_table[0];
2010   /* MAX_OPERANDS is only an upper bound on the number of selected entries.
2011      However each entry is indexed by it's enum so there can be holes in
2012      the table.  */
2013   const CGEN_OPERAND **selected = xmalloc (MAX_OPERANDS * sizeof (* selected));
2014
2015   cd->operand_table.init_entries = init;
2016   cd->operand_table.entry_size = sizeof (CGEN_OPERAND);
2017   memset (selected, 0, MAX_OPERANDS * sizeof (CGEN_OPERAND *));
2018   /* ??? For now we just use mach to determine which ones we want.  */
2019   for (i = 0; init[i].name != NULL; ++i)
2020     if (CGEN_OPERAND_ATTR_VALUE (&init[i], CGEN_OPERAND_MACH)
2021         & machs)
2022       selected[init[i].type] = &init[i];
2023   cd->operand_table.entries = selected;
2024   cd->operand_table.num_entries = MAX_OPERANDS;
2025 }
2026
2027 /* Subroutine of epiphany_cgen_cpu_open to build the hardware table.
2028    ??? This could leave out insns not supported by the specified mach/isa,
2029    but that would cause errors like "foo only supported by bar" to become
2030    "unknown insn", so for now we include all insns and require the app to
2031    do the checking later.
2032    ??? On the other hand, parsing of such insns may require their hardware or
2033    operand elements to be in the table [which they mightn't be].  */
2034
2035 static void
2036 build_insn_table (CGEN_CPU_TABLE *cd)
2037 {
2038   int i;
2039   const CGEN_IBASE *ib = & epiphany_cgen_insn_table[0];
2040   CGEN_INSN *insns = xmalloc (MAX_INSNS * sizeof (CGEN_INSN));
2041
2042   memset (insns, 0, MAX_INSNS * sizeof (CGEN_INSN));
2043   for (i = 0; i < MAX_INSNS; ++i)
2044     insns[i].base = &ib[i];
2045   cd->insn_table.init_entries = insns;
2046   cd->insn_table.entry_size = sizeof (CGEN_IBASE);
2047   cd->insn_table.num_init_entries = MAX_INSNS;
2048 }
2049
2050 /* Subroutine of epiphany_cgen_cpu_open to rebuild the tables.  */
2051
2052 static void
2053 epiphany_cgen_rebuild_tables (CGEN_CPU_TABLE *cd)
2054 {
2055   int i;
2056   CGEN_BITSET *isas = cd->isas;
2057   unsigned int machs = cd->machs;
2058
2059   cd->int_insn_p = CGEN_INT_INSN_P;
2060
2061   /* Data derived from the isa spec.  */
2062 #define UNSET (CGEN_SIZE_UNKNOWN + 1)
2063   cd->default_insn_bitsize = UNSET;
2064   cd->base_insn_bitsize = UNSET;
2065   cd->min_insn_bitsize = 65535; /* Some ridiculously big number.  */
2066   cd->max_insn_bitsize = 0;
2067   for (i = 0; i < MAX_ISAS; ++i)
2068     if (cgen_bitset_contains (isas, i))
2069       {
2070         const CGEN_ISA *isa = & epiphany_cgen_isa_table[i];
2071
2072         /* Default insn sizes of all selected isas must be
2073            equal or we set the result to 0, meaning "unknown".  */
2074         if (cd->default_insn_bitsize == UNSET)
2075           cd->default_insn_bitsize = isa->default_insn_bitsize;
2076         else if (isa->default_insn_bitsize == cd->default_insn_bitsize)
2077           ; /* This is ok.  */
2078         else
2079           cd->default_insn_bitsize = CGEN_SIZE_UNKNOWN;
2080
2081         /* Base insn sizes of all selected isas must be equal
2082            or we set the result to 0, meaning "unknown".  */
2083         if (cd->base_insn_bitsize == UNSET)
2084           cd->base_insn_bitsize = isa->base_insn_bitsize;
2085         else if (isa->base_insn_bitsize == cd->base_insn_bitsize)
2086           ; /* This is ok.  */
2087         else
2088           cd->base_insn_bitsize = CGEN_SIZE_UNKNOWN;
2089
2090         /* Set min,max insn sizes.  */
2091         if (isa->min_insn_bitsize < cd->min_insn_bitsize)
2092           cd->min_insn_bitsize = isa->min_insn_bitsize;
2093         if (isa->max_insn_bitsize > cd->max_insn_bitsize)
2094           cd->max_insn_bitsize = isa->max_insn_bitsize;
2095       }
2096
2097   /* Data derived from the mach spec.  */
2098   for (i = 0; i < MAX_MACHS; ++i)
2099     if (((1 << i) & machs) != 0)
2100       {
2101         const CGEN_MACH *mach = & epiphany_cgen_mach_table[i];
2102
2103         if (mach->insn_chunk_bitsize != 0)
2104         {
2105           if (cd->insn_chunk_bitsize != 0 && cd->insn_chunk_bitsize != mach->insn_chunk_bitsize)
2106             {
2107               opcodes_error_handler
2108                 (/* xgettext:c-format */
2109                  _("internal error: epiphany_cgen_rebuild_tables: "
2110                    "conflicting insn-chunk-bitsize values: `%d' vs. `%d'"),
2111                  cd->insn_chunk_bitsize, mach->insn_chunk_bitsize);
2112               abort ();
2113             }
2114
2115           cd->insn_chunk_bitsize = mach->insn_chunk_bitsize;
2116         }
2117       }
2118
2119   /* Determine which hw elements are used by MACH.  */
2120   build_hw_table (cd);
2121
2122   /* Build the ifield table.  */
2123   build_ifield_table (cd);
2124
2125   /* Determine which operands are used by MACH/ISA.  */
2126   build_operand_table (cd);
2127
2128   /* Build the instruction table.  */
2129   build_insn_table (cd);
2130 }
2131
2132 /* Initialize a cpu table and return a descriptor.
2133    It's much like opening a file, and must be the first function called.
2134    The arguments are a set of (type/value) pairs, terminated with
2135    CGEN_CPU_OPEN_END.
2136
2137    Currently supported values:
2138    CGEN_CPU_OPEN_ISAS:    bitmap of values in enum isa_attr
2139    CGEN_CPU_OPEN_MACHS:   bitmap of values in enum mach_attr
2140    CGEN_CPU_OPEN_BFDMACH: specify 1 mach using bfd name
2141    CGEN_CPU_OPEN_ENDIAN:  specify endian choice
2142    CGEN_CPU_OPEN_END:     terminates arguments
2143
2144    ??? Simultaneous multiple isas might not make sense, but it's not (yet)
2145    precluded.  */
2146
2147 CGEN_CPU_DESC
2148 epiphany_cgen_cpu_open (enum cgen_cpu_open_arg arg_type, ...)
2149 {
2150   CGEN_CPU_TABLE *cd = (CGEN_CPU_TABLE *) xmalloc (sizeof (CGEN_CPU_TABLE));
2151   static int init_p;
2152   CGEN_BITSET *isas = 0;  /* 0 = "unspecified" */
2153   unsigned int machs = 0; /* 0 = "unspecified" */
2154   enum cgen_endian endian = CGEN_ENDIAN_UNKNOWN;
2155   va_list ap;
2156
2157   if (! init_p)
2158     {
2159       init_tables ();
2160       init_p = 1;
2161     }
2162
2163   memset (cd, 0, sizeof (*cd));
2164
2165   va_start (ap, arg_type);
2166   while (arg_type != CGEN_CPU_OPEN_END)
2167     {
2168       switch (arg_type)
2169         {
2170         case CGEN_CPU_OPEN_ISAS :
2171           isas = va_arg (ap, CGEN_BITSET *);
2172           break;
2173         case CGEN_CPU_OPEN_MACHS :
2174           machs = va_arg (ap, unsigned int);
2175           break;
2176         case CGEN_CPU_OPEN_BFDMACH :
2177           {
2178             const char *name = va_arg (ap, const char *);
2179             const CGEN_MACH *mach =
2180               lookup_mach_via_bfd_name (epiphany_cgen_mach_table, name);
2181
2182             if (mach != NULL)
2183               machs |= 1 << mach->num;
2184             break;
2185           }
2186         case CGEN_CPU_OPEN_ENDIAN :
2187           endian = va_arg (ap, enum cgen_endian);
2188           break;
2189         default :
2190           opcodes_error_handler
2191             (/* xgettext:c-format */
2192              _("internal error: epiphany_cgen_cpu_open: "
2193                "unsupported argument `%d'"),
2194              arg_type);
2195           abort (); /* ??? return NULL? */
2196         }
2197       arg_type = va_arg (ap, enum cgen_cpu_open_arg);
2198     }
2199   va_end (ap);
2200
2201   /* Mach unspecified means "all".  */
2202   if (machs == 0)
2203     machs = (1 << MAX_MACHS) - 1;
2204   /* Base mach is always selected.  */
2205   machs |= 1;
2206   if (endian == CGEN_ENDIAN_UNKNOWN)
2207     {
2208       /* ??? If target has only one, could have a default.  */
2209       opcodes_error_handler
2210         (/* xgettext:c-format */
2211          _("internal error: epiphany_cgen_cpu_open: no endianness specified"));
2212       abort ();
2213     }
2214
2215   cd->isas = cgen_bitset_copy (isas);
2216   cd->machs = machs;
2217   cd->endian = endian;
2218   /* FIXME: for the sparc case we can determine insn-endianness statically.
2219      The worry here is where both data and insn endian can be independently
2220      chosen, in which case this function will need another argument.
2221      Actually, will want to allow for more arguments in the future anyway.  */
2222   cd->insn_endian = endian;
2223
2224   /* Table (re)builder.  */
2225   cd->rebuild_tables = epiphany_cgen_rebuild_tables;
2226   epiphany_cgen_rebuild_tables (cd);
2227
2228   /* Default to not allowing signed overflow.  */
2229   cd->signed_overflow_ok_p = 0;
2230
2231   return (CGEN_CPU_DESC) cd;
2232 }
2233
2234 /* Cover fn to epiphany_cgen_cpu_open to handle the simple case of 1 isa, 1 mach.
2235    MACH_NAME is the bfd name of the mach.  */
2236
2237 CGEN_CPU_DESC
2238 epiphany_cgen_cpu_open_1 (const char *mach_name, enum cgen_endian endian)
2239 {
2240   return epiphany_cgen_cpu_open (CGEN_CPU_OPEN_BFDMACH, mach_name,
2241                                CGEN_CPU_OPEN_ENDIAN, endian,
2242                                CGEN_CPU_OPEN_END);
2243 }
2244
2245 /* Close a cpu table.
2246    ??? This can live in a machine independent file, but there's currently
2247    no place to put this file (there's no libcgen).  libopcodes is the wrong
2248    place as some simulator ports use this but they don't use libopcodes.  */
2249
2250 void
2251 epiphany_cgen_cpu_close (CGEN_CPU_DESC cd)
2252 {
2253   unsigned int i;
2254   const CGEN_INSN *insns;
2255
2256   if (cd->macro_insn_table.init_entries)
2257     {
2258       insns = cd->macro_insn_table.init_entries;
2259       for (i = 0; i < cd->macro_insn_table.num_init_entries; ++i, ++insns)
2260         if (CGEN_INSN_RX ((insns)))
2261           regfree (CGEN_INSN_RX (insns));
2262     }
2263
2264   if (cd->insn_table.init_entries)
2265     {
2266       insns = cd->insn_table.init_entries;
2267       for (i = 0; i < cd->insn_table.num_init_entries; ++i, ++insns)
2268         if (CGEN_INSN_RX (insns))
2269           regfree (CGEN_INSN_RX (insns));
2270     }
2271
2272   if (cd->macro_insn_table.init_entries)
2273     free ((CGEN_INSN *) cd->macro_insn_table.init_entries);
2274
2275   if (cd->insn_table.init_entries)
2276     free ((CGEN_INSN *) cd->insn_table.init_entries);
2277
2278   if (cd->hw_table.entries)
2279     free ((CGEN_HW_ENTRY *) cd->hw_table.entries);
2280
2281   if (cd->operand_table.entries)
2282     free ((CGEN_HW_ENTRY *) cd->operand_table.entries);
2283
2284   free (cd);
2285 }
2286