OSDN Git Service

28a6153c629e2878f742c31150760d7c4281f944
[pf3gnuchains/pf3gnuchains3x.git] / sid / component / cgen-cpu / sh / sh3e-decode.h
1 /* Decode header for sh3e.
2
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
4
5 Copyright (C) 2000-2009 Red Hat, Inc.
6
7 This file is part of the Red Hat simulators.
8
9
10 */
11
12 #ifndef SH3E_DECODE_H
13 #define SH3E_DECODE_H
14
15 namespace sh3e {
16 // forward declaration of struct in -defs.h
17 struct write_stacks;
18 }
19
20 namespace sh3e {
21
22 using namespace cgen;
23 using namespace sh;
24
25 typedef UINT sh3e_insn_word;
26
27 /* Enum declaration for instructions in cpu family sh3e.  */
28 typedef enum sh3e_insn_type {
29   SH3E_INSN_X_INVALID, SH3E_INSN_ADD_COMPACT, SH3E_INSN_ADDI_COMPACT, SH3E_INSN_ADDC_COMPACT
30  , SH3E_INSN_ADDV_COMPACT, SH3E_INSN_AND_COMPACT, SH3E_INSN_ANDI_COMPACT, SH3E_INSN_ANDB_COMPACT
31  , SH3E_INSN_BF_COMPACT, SH3E_INSN_BFS_COMPACT, SH3E_INSN_BRA_COMPACT, SH3E_INSN_BRAF_COMPACT
32  , SH3E_INSN_BSR_COMPACT, SH3E_INSN_BSRF_COMPACT, SH3E_INSN_BT_COMPACT, SH3E_INSN_BTS_COMPACT
33  , SH3E_INSN_CLRMAC_COMPACT, SH3E_INSN_CLRS_COMPACT, SH3E_INSN_CLRT_COMPACT, SH3E_INSN_CMPEQ_COMPACT
34  , SH3E_INSN_CMPEQI_COMPACT, SH3E_INSN_CMPGE_COMPACT, SH3E_INSN_CMPGT_COMPACT, SH3E_INSN_CMPHI_COMPACT
35  , SH3E_INSN_CMPHS_COMPACT, SH3E_INSN_CMPPL_COMPACT, SH3E_INSN_CMPPZ_COMPACT, SH3E_INSN_CMPSTR_COMPACT
36  , SH3E_INSN_DIV0S_COMPACT, SH3E_INSN_DIV0U_COMPACT, SH3E_INSN_DIV1_COMPACT, SH3E_INSN_DMULSL_COMPACT
37  , SH3E_INSN_DMULUL_COMPACT, SH3E_INSN_DT_COMPACT, SH3E_INSN_EXTSB_COMPACT, SH3E_INSN_EXTSW_COMPACT
38  , SH3E_INSN_EXTUB_COMPACT, SH3E_INSN_EXTUW_COMPACT, SH3E_INSN_FABS_COMPACT, SH3E_INSN_FADD_COMPACT
39  , SH3E_INSN_FCMPEQ_COMPACT, SH3E_INSN_FCMPGT_COMPACT, SH3E_INSN_FDIV_COMPACT, SH3E_INSN_FLDS_COMPACT
40  , SH3E_INSN_FLDI0_COMPACT, SH3E_INSN_FLDI1_COMPACT, SH3E_INSN_FLOAT_COMPACT, SH3E_INSN_FMAC_COMPACT
41  , SH3E_INSN_FMOV1_COMPACT, SH3E_INSN_FMOV2_COMPACT, SH3E_INSN_FMOV3_COMPACT, SH3E_INSN_FMOV4_COMPACT
42  , SH3E_INSN_FMOV5_COMPACT, SH3E_INSN_FMOV6_COMPACT, SH3E_INSN_FMOV7_COMPACT, SH3E_INSN_FMUL_COMPACT
43  , SH3E_INSN_FNEG_COMPACT, SH3E_INSN_FRCHG_COMPACT, SH3E_INSN_FSCHG_COMPACT, SH3E_INSN_FSQRT_COMPACT
44  , SH3E_INSN_FSTS_COMPACT, SH3E_INSN_FSUB_COMPACT, SH3E_INSN_FTRC_COMPACT, SH3E_INSN_JMP_COMPACT
45  , SH3E_INSN_JSR_COMPACT, SH3E_INSN_LDC_GBR_COMPACT, SH3E_INSN_LDC_VBR_COMPACT, SH3E_INSN_LDC_SR_COMPACT
46  , SH3E_INSN_LDCL_GBR_COMPACT, SH3E_INSN_LDCL_VBR_COMPACT, SH3E_INSN_LDS_FPSCR_COMPACT, SH3E_INSN_LDSL_FPSCR_COMPACT
47  , SH3E_INSN_LDS_FPUL_COMPACT, SH3E_INSN_LDSL_FPUL_COMPACT, SH3E_INSN_LDS_MACH_COMPACT, SH3E_INSN_LDSL_MACH_COMPACT
48  , SH3E_INSN_LDS_MACL_COMPACT, SH3E_INSN_LDSL_MACL_COMPACT, SH3E_INSN_LDS_PR_COMPACT, SH3E_INSN_LDSL_PR_COMPACT
49  , SH3E_INSN_MACL_COMPACT, SH3E_INSN_MACW_COMPACT, SH3E_INSN_MOV_COMPACT, SH3E_INSN_MOVI_COMPACT
50  , SH3E_INSN_MOVB1_COMPACT, SH3E_INSN_MOVB2_COMPACT, SH3E_INSN_MOVB3_COMPACT, SH3E_INSN_MOVB4_COMPACT
51  , SH3E_INSN_MOVB5_COMPACT, SH3E_INSN_MOVB6_COMPACT, SH3E_INSN_MOVB7_COMPACT, SH3E_INSN_MOVB8_COMPACT
52  , SH3E_INSN_MOVB9_COMPACT, SH3E_INSN_MOVB10_COMPACT, SH3E_INSN_MOVL1_COMPACT, SH3E_INSN_MOVL2_COMPACT
53  , SH3E_INSN_MOVL3_COMPACT, SH3E_INSN_MOVL4_COMPACT, SH3E_INSN_MOVL5_COMPACT, SH3E_INSN_MOVL6_COMPACT
54  , SH3E_INSN_MOVL7_COMPACT, SH3E_INSN_MOVL8_COMPACT, SH3E_INSN_MOVL9_COMPACT, SH3E_INSN_MOVL10_COMPACT
55  , SH3E_INSN_MOVL11_COMPACT, SH3E_INSN_MOVW1_COMPACT, SH3E_INSN_MOVW2_COMPACT, SH3E_INSN_MOVW3_COMPACT
56  , SH3E_INSN_MOVW4_COMPACT, SH3E_INSN_MOVW5_COMPACT, SH3E_INSN_MOVW6_COMPACT, SH3E_INSN_MOVW7_COMPACT
57  , SH3E_INSN_MOVW8_COMPACT, SH3E_INSN_MOVW9_COMPACT, SH3E_INSN_MOVW10_COMPACT, SH3E_INSN_MOVW11_COMPACT
58  , SH3E_INSN_MOVA_COMPACT, SH3E_INSN_MOVT_COMPACT, SH3E_INSN_MULL_COMPACT, SH3E_INSN_MULSW_COMPACT
59  , SH3E_INSN_MULUW_COMPACT, SH3E_INSN_NEG_COMPACT, SH3E_INSN_NEGC_COMPACT, SH3E_INSN_NOP_COMPACT
60  , SH3E_INSN_NOT_COMPACT, SH3E_INSN_OR_COMPACT, SH3E_INSN_ORI_COMPACT, SH3E_INSN_ORB_COMPACT
61  , SH3E_INSN_PREF_COMPACT, SH3E_INSN_ROTCL_COMPACT, SH3E_INSN_ROTCR_COMPACT, SH3E_INSN_ROTL_COMPACT
62  , SH3E_INSN_ROTR_COMPACT, SH3E_INSN_RTS_COMPACT, SH3E_INSN_SETS_COMPACT, SH3E_INSN_SETT_COMPACT
63  , SH3E_INSN_SHAD_COMPACT, SH3E_INSN_SHAL_COMPACT, SH3E_INSN_SHAR_COMPACT, SH3E_INSN_SHLD_COMPACT
64  , SH3E_INSN_SHLL_COMPACT, SH3E_INSN_SHLL2_COMPACT, SH3E_INSN_SHLL8_COMPACT, SH3E_INSN_SHLL16_COMPACT
65  , SH3E_INSN_SHLR_COMPACT, SH3E_INSN_SHLR2_COMPACT, SH3E_INSN_SHLR8_COMPACT, SH3E_INSN_SHLR16_COMPACT
66  , SH3E_INSN_STC_GBR_COMPACT, SH3E_INSN_STC_VBR_COMPACT, SH3E_INSN_STCL_GBR_COMPACT, SH3E_INSN_STCL_VBR_COMPACT
67  , SH3E_INSN_STS_FPSCR_COMPACT, SH3E_INSN_STSL_FPSCR_COMPACT, SH3E_INSN_STS_FPUL_COMPACT, SH3E_INSN_STSL_FPUL_COMPACT
68  , SH3E_INSN_STS_MACH_COMPACT, SH3E_INSN_STSL_MACH_COMPACT, SH3E_INSN_STS_MACL_COMPACT, SH3E_INSN_STSL_MACL_COMPACT
69  , SH3E_INSN_STS_PR_COMPACT, SH3E_INSN_STSL_PR_COMPACT, SH3E_INSN_SUB_COMPACT, SH3E_INSN_SUBC_COMPACT
70  , SH3E_INSN_SUBV_COMPACT, SH3E_INSN_SWAPB_COMPACT, SH3E_INSN_SWAPW_COMPACT, SH3E_INSN_TASB_COMPACT
71  , SH3E_INSN_TRAPA_COMPACT, SH3E_INSN_TST_COMPACT, SH3E_INSN_TSTI_COMPACT, SH3E_INSN_TSTB_COMPACT
72  , SH3E_INSN_XOR_COMPACT, SH3E_INSN_XORI_COMPACT, SH3E_INSN_XORB_COMPACT, SH3E_INSN_XTRCT_COMPACT
73 } SH3E_INSN_TYPE;
74
75
76 // Forward decls.
77 struct sh3e_cpu;
78 struct sh3e_scache;
79 typedef void (sh3e_sem_fn) (sh3e_cpu* cpu, sh3e_scache* sem, int tick, sh3e::write_stacks &buf);
80
81
82 // Instruction descriptor.
83
84 struct sh3e_idesc {
85
86   // scache engine executor for this insn
87   sh3e_sem_fn* execute;
88
89   const char* insn_name;
90   enum sh3e_insn_type sem_index;
91   sh_insn_attr attrs;
92
93   // idesc table: indexed by sem_index
94   static sh3e_idesc idesc_table[];
95
96   static sh3e_insn_type lookup_virtual (virtual_insn_type vit);
97 };
98
99 // Instruction argument buffer.
100
101 union sh3e_sem_fields {
102   struct { /* no operands */
103     int empty;
104   } fmt_empty;
105   struct { /*  */
106     IADDR i_disp12;
107   } sfmt_bra_compact;
108   struct { /*  */
109     IADDR i_disp8;
110   } sfmt_bf_compact;
111   struct { /*  */
112     SI f_imm8x2;
113     unsigned char out_r0;
114   } sfmt_movw9_compact;
115   struct { /*  */
116     SI f_imm8x2;
117     unsigned char in_r0;
118   } sfmt_movw4_compact;
119   struct { /*  */
120     SI f_imm8x4;
121     unsigned char out_r0;
122   } sfmt_movl9_compact;
123   struct { /*  */
124     SI f_imm8x4;
125     unsigned char in_r0;
126   } sfmt_movl4_compact;
127   struct { /*  */
128     SI f_imm8x2;
129     UINT f_rn;
130     unsigned char out_rn;
131   } sfmt_movw10_compact;
132   struct { /*  */
133     SI f_imm8x4;
134     UINT f_rn;
135     unsigned char out_rn;
136   } sfmt_movl10_compact;
137   struct { /*  */
138     UINT f_rn;
139     unsigned char in_fsdn;
140     unsigned char out_fpul;
141   } sfmt_ftrc_compact;
142   struct { /*  */
143     UINT f_rn;
144     unsigned char in_fpul;
145     unsigned char out_frn;
146   } sfmt_fsts_compact;
147   struct { /*  */
148     UINT f_rn;
149     unsigned char in_fpul;
150     unsigned char out_fsdn;
151   } sfmt_float_compact;
152   struct { /*  */
153     UINT f_rn;
154     unsigned char in_frn;
155     unsigned char out_fpul;
156   } sfmt_flds_compact;
157   struct { /*  */
158     UINT f_imm8;
159     unsigned char in_r0;
160     unsigned char out_r0;
161   } sfmt_andi_compact;
162   struct { /*  */
163     UINT f_rn;
164     unsigned char in_fpul;
165     unsigned char in_rn;
166     unsigned char out_rn;
167   } sfmt_stsl_fpul_compact;
168   struct { /*  */
169     SI f_imm4x2;
170     UINT f_rm;
171     unsigned char in_rm;
172     unsigned char out_r0;
173   } sfmt_movw11_compact;
174   struct { /*  */
175     SI f_imm4x2;
176     UINT f_rm;
177     unsigned char in_r0;
178     unsigned char in_rm;
179   } sfmt_movw5_compact;
180   struct { /*  */
181     UINT f_imm4;
182     UINT f_rm;
183     unsigned char in_rm;
184     unsigned char out_r0;
185   } sfmt_movb10_compact;
186   struct { /*  */
187     UINT f_imm4;
188     UINT f_rm;
189     unsigned char in_r0;
190     unsigned char in_rm;
191   } sfmt_movb5_compact;
192   struct { /*  */
193     UINT f_rn;
194     unsigned char in_rn;
195     unsigned char out_fpul;
196     unsigned char out_rn;
197   } sfmt_ldsl_fpul_compact;
198   struct { /*  */
199     UINT f_rm;
200     UINT f_rn;
201     unsigned char in_fmovm;
202     unsigned char out_fmovn;
203   } sfmt_fmov1_compact;
204   struct { /*  */
205     UINT f_imm8;
206     UINT f_rn;
207     unsigned char in_rn;
208     unsigned char out_rn;
209   } sfmt_addi_compact;
210   struct { /*  */
211     SI f_imm4x4;
212     UINT f_rm;
213     UINT f_rn;
214     unsigned char in_rm;
215     unsigned char out_rn;
216   } sfmt_movl11_compact;
217   struct { /*  */
218     SI f_imm4x4;
219     UINT f_rm;
220     UINT f_rn;
221     unsigned char in_rm;
222     unsigned char in_rn;
223   } sfmt_movl5_compact;
224   struct { /*  */
225     UINT f_rm;
226     UINT f_rn;
227     unsigned char in_r0;
228     unsigned char in_rm;
229     unsigned char out_rn;
230   } sfmt_movb8_compact;
231   struct { /*  */
232     UINT f_rm;
233     UINT f_rn;
234     unsigned char in_r0;
235     unsigned char in_rm;
236     unsigned char in_rn;
237   } sfmt_movb3_compact;
238   struct { /*  */
239     UINT f_rm;
240     UINT f_rn;
241     unsigned char in_fmovm;
242     unsigned char in_r0;
243     unsigned char in_rn;
244   } sfmt_fmov7_compact;
245   struct { /*  */
246     UINT f_rm;
247     UINT f_rn;
248     unsigned char in_fmovm;
249     unsigned char in_rn;
250     unsigned char out_rn;
251   } sfmt_fmov6_compact;
252   struct { /*  */
253     UINT f_rm;
254     UINT f_rn;
255     unsigned char in_r0;
256     unsigned char in_rm;
257     unsigned char out_fmovn;
258   } sfmt_fmov4_compact;
259   struct { /*  */
260     UINT f_rm;
261     UINT f_rn;
262     unsigned char in_rm;
263     unsigned char out_fmovn;
264     unsigned char out_rm;
265   } sfmt_fmov3_compact;
266   struct { /*  */
267     UINT f_rm;
268     UINT f_rn;
269     unsigned char in_fsdm;
270     unsigned char in_fsdn;
271     unsigned char out_fsdn;
272   } sfmt_fadd_compact;
273   struct { /*  */
274     UINT f_rm;
275     UINT f_rn;
276     unsigned char in_rm64;
277     unsigned char in_rn64;
278     unsigned char out_rn64;
279   } sfmt_and_compact;
280   struct { /*  */
281     UINT f_rm;
282     UINT f_rn;
283     unsigned char in_rm;
284     unsigned char in_rn;
285     unsigned char out_rm;
286     unsigned char out_rn;
287   } sfmt_macl_compact;
288   struct { /*  */
289     UINT f_rm;
290     UINT f_rn;
291     unsigned char in_fr0;
292     unsigned char in_frm;
293     unsigned char in_frn;
294     unsigned char out_frn;
295   } sfmt_fmac_compact;
296   // This one is for chain/cti-chain virtual insns.
297   struct {
298     // Number of insns in pbb.
299     unsigned insn_count;
300     // This is used by chain insns and by untaken conditional branches.
301     sh3e_scache* next;
302     sh3e_scache* branch_target;
303   } chain;
304   // This one is for `before' virtual insns.
305   struct {
306     // The cache entry of the real insn.
307     sh3e_scache* insn;
308   } before;
309 };
310
311 // Simulator instruction cache.
312
313 struct sh3e_scache {
314   // executor
315   union {
316     cgoto_label cgoto;
317     sh3e_sem_fn* fn;
318   } execute;
319
320   // PC of this instruction.
321   PCADDR addr;
322
323   // instruction class
324   sh3e_idesc* idesc;
325
326   // argument buffer
327   sh3e_sem_fields fields;
328
329
330   // writeback flags
331   // Only used if profiling or parallel execution support enabled during
332   // file generation.
333   unsigned long long written;
334
335
336   // decode given instruction
337   void decode (sh3e_cpu* current_cpu, PCADDR pc, sh3e_insn_word base_insn, sh3e_insn_word entire_insn);
338 };
339
340 } // end sh3e namespace
341
342 // Decls of each semantic fn.
343
344 using sh3e::sh3e_sem_fn;
345 extern sh3e_sem_fn sh3e_sem_x_invalid;
346 extern sh3e_sem_fn sh3e_sem_add_compact;
347 extern sh3e_sem_fn sh3e_sem_addi_compact;
348 extern sh3e_sem_fn sh3e_sem_addc_compact;
349 extern sh3e_sem_fn sh3e_sem_addv_compact;
350 extern sh3e_sem_fn sh3e_sem_and_compact;
351 extern sh3e_sem_fn sh3e_sem_andi_compact;
352 extern sh3e_sem_fn sh3e_sem_andb_compact;
353 extern sh3e_sem_fn sh3e_sem_bf_compact;
354 extern sh3e_sem_fn sh3e_sem_bfs_compact;
355 extern sh3e_sem_fn sh3e_sem_bra_compact;
356 extern sh3e_sem_fn sh3e_sem_braf_compact;
357 extern sh3e_sem_fn sh3e_sem_bsr_compact;
358 extern sh3e_sem_fn sh3e_sem_bsrf_compact;
359 extern sh3e_sem_fn sh3e_sem_bt_compact;
360 extern sh3e_sem_fn sh3e_sem_bts_compact;
361 extern sh3e_sem_fn sh3e_sem_clrmac_compact;
362 extern sh3e_sem_fn sh3e_sem_clrs_compact;
363 extern sh3e_sem_fn sh3e_sem_clrt_compact;
364 extern sh3e_sem_fn sh3e_sem_cmpeq_compact;
365 extern sh3e_sem_fn sh3e_sem_cmpeqi_compact;
366 extern sh3e_sem_fn sh3e_sem_cmpge_compact;
367 extern sh3e_sem_fn sh3e_sem_cmpgt_compact;
368 extern sh3e_sem_fn sh3e_sem_cmphi_compact;
369 extern sh3e_sem_fn sh3e_sem_cmphs_compact;
370 extern sh3e_sem_fn sh3e_sem_cmppl_compact;
371 extern sh3e_sem_fn sh3e_sem_cmppz_compact;
372 extern sh3e_sem_fn sh3e_sem_cmpstr_compact;
373 extern sh3e_sem_fn sh3e_sem_div0s_compact;
374 extern sh3e_sem_fn sh3e_sem_div0u_compact;
375 extern sh3e_sem_fn sh3e_sem_div1_compact;
376 extern sh3e_sem_fn sh3e_sem_dmulsl_compact;
377 extern sh3e_sem_fn sh3e_sem_dmulul_compact;
378 extern sh3e_sem_fn sh3e_sem_dt_compact;
379 extern sh3e_sem_fn sh3e_sem_extsb_compact;
380 extern sh3e_sem_fn sh3e_sem_extsw_compact;
381 extern sh3e_sem_fn sh3e_sem_extub_compact;
382 extern sh3e_sem_fn sh3e_sem_extuw_compact;
383 extern sh3e_sem_fn sh3e_sem_fabs_compact;
384 extern sh3e_sem_fn sh3e_sem_fadd_compact;
385 extern sh3e_sem_fn sh3e_sem_fcmpeq_compact;
386 extern sh3e_sem_fn sh3e_sem_fcmpgt_compact;
387 extern sh3e_sem_fn sh3e_sem_fdiv_compact;
388 extern sh3e_sem_fn sh3e_sem_flds_compact;
389 extern sh3e_sem_fn sh3e_sem_fldi0_compact;
390 extern sh3e_sem_fn sh3e_sem_fldi1_compact;
391 extern sh3e_sem_fn sh3e_sem_float_compact;
392 extern sh3e_sem_fn sh3e_sem_fmac_compact;
393 extern sh3e_sem_fn sh3e_sem_fmov1_compact;
394 extern sh3e_sem_fn sh3e_sem_fmov2_compact;
395 extern sh3e_sem_fn sh3e_sem_fmov3_compact;
396 extern sh3e_sem_fn sh3e_sem_fmov4_compact;
397 extern sh3e_sem_fn sh3e_sem_fmov5_compact;
398 extern sh3e_sem_fn sh3e_sem_fmov6_compact;
399 extern sh3e_sem_fn sh3e_sem_fmov7_compact;
400 extern sh3e_sem_fn sh3e_sem_fmul_compact;
401 extern sh3e_sem_fn sh3e_sem_fneg_compact;
402 extern sh3e_sem_fn sh3e_sem_frchg_compact;
403 extern sh3e_sem_fn sh3e_sem_fschg_compact;
404 extern sh3e_sem_fn sh3e_sem_fsqrt_compact;
405 extern sh3e_sem_fn sh3e_sem_fsts_compact;
406 extern sh3e_sem_fn sh3e_sem_fsub_compact;
407 extern sh3e_sem_fn sh3e_sem_ftrc_compact;
408 extern sh3e_sem_fn sh3e_sem_jmp_compact;
409 extern sh3e_sem_fn sh3e_sem_jsr_compact;
410 extern sh3e_sem_fn sh3e_sem_ldc_gbr_compact;
411 extern sh3e_sem_fn sh3e_sem_ldc_vbr_compact;
412 extern sh3e_sem_fn sh3e_sem_ldc_sr_compact;
413 extern sh3e_sem_fn sh3e_sem_ldcl_gbr_compact;
414 extern sh3e_sem_fn sh3e_sem_ldcl_vbr_compact;
415 extern sh3e_sem_fn sh3e_sem_lds_fpscr_compact;
416 extern sh3e_sem_fn sh3e_sem_ldsl_fpscr_compact;
417 extern sh3e_sem_fn sh3e_sem_lds_fpul_compact;
418 extern sh3e_sem_fn sh3e_sem_ldsl_fpul_compact;
419 extern sh3e_sem_fn sh3e_sem_lds_mach_compact;
420 extern sh3e_sem_fn sh3e_sem_ldsl_mach_compact;
421 extern sh3e_sem_fn sh3e_sem_lds_macl_compact;
422 extern sh3e_sem_fn sh3e_sem_ldsl_macl_compact;
423 extern sh3e_sem_fn sh3e_sem_lds_pr_compact;
424 extern sh3e_sem_fn sh3e_sem_ldsl_pr_compact;
425 extern sh3e_sem_fn sh3e_sem_macl_compact;
426 extern sh3e_sem_fn sh3e_sem_macw_compact;
427 extern sh3e_sem_fn sh3e_sem_mov_compact;
428 extern sh3e_sem_fn sh3e_sem_movi_compact;
429 extern sh3e_sem_fn sh3e_sem_movb1_compact;
430 extern sh3e_sem_fn sh3e_sem_movb2_compact;
431 extern sh3e_sem_fn sh3e_sem_movb3_compact;
432 extern sh3e_sem_fn sh3e_sem_movb4_compact;
433 extern sh3e_sem_fn sh3e_sem_movb5_compact;
434 extern sh3e_sem_fn sh3e_sem_movb6_compact;
435 extern sh3e_sem_fn sh3e_sem_movb7_compact;
436 extern sh3e_sem_fn sh3e_sem_movb8_compact;
437 extern sh3e_sem_fn sh3e_sem_movb9_compact;
438 extern sh3e_sem_fn sh3e_sem_movb10_compact;
439 extern sh3e_sem_fn sh3e_sem_movl1_compact;
440 extern sh3e_sem_fn sh3e_sem_movl2_compact;
441 extern sh3e_sem_fn sh3e_sem_movl3_compact;
442 extern sh3e_sem_fn sh3e_sem_movl4_compact;
443 extern sh3e_sem_fn sh3e_sem_movl5_compact;
444 extern sh3e_sem_fn sh3e_sem_movl6_compact;
445 extern sh3e_sem_fn sh3e_sem_movl7_compact;
446 extern sh3e_sem_fn sh3e_sem_movl8_compact;
447 extern sh3e_sem_fn sh3e_sem_movl9_compact;
448 extern sh3e_sem_fn sh3e_sem_movl10_compact;
449 extern sh3e_sem_fn sh3e_sem_movl11_compact;
450 extern sh3e_sem_fn sh3e_sem_movw1_compact;
451 extern sh3e_sem_fn sh3e_sem_movw2_compact;
452 extern sh3e_sem_fn sh3e_sem_movw3_compact;
453 extern sh3e_sem_fn sh3e_sem_movw4_compact;
454 extern sh3e_sem_fn sh3e_sem_movw5_compact;
455 extern sh3e_sem_fn sh3e_sem_movw6_compact;
456 extern sh3e_sem_fn sh3e_sem_movw7_compact;
457 extern sh3e_sem_fn sh3e_sem_movw8_compact;
458 extern sh3e_sem_fn sh3e_sem_movw9_compact;
459 extern sh3e_sem_fn sh3e_sem_movw10_compact;
460 extern sh3e_sem_fn sh3e_sem_movw11_compact;
461 extern sh3e_sem_fn sh3e_sem_mova_compact;
462 extern sh3e_sem_fn sh3e_sem_movt_compact;
463 extern sh3e_sem_fn sh3e_sem_mull_compact;
464 extern sh3e_sem_fn sh3e_sem_mulsw_compact;
465 extern sh3e_sem_fn sh3e_sem_muluw_compact;
466 extern sh3e_sem_fn sh3e_sem_neg_compact;
467 extern sh3e_sem_fn sh3e_sem_negc_compact;
468 extern sh3e_sem_fn sh3e_sem_nop_compact;
469 extern sh3e_sem_fn sh3e_sem_not_compact;
470 extern sh3e_sem_fn sh3e_sem_or_compact;
471 extern sh3e_sem_fn sh3e_sem_ori_compact;
472 extern sh3e_sem_fn sh3e_sem_orb_compact;
473 extern sh3e_sem_fn sh3e_sem_pref_compact;
474 extern sh3e_sem_fn sh3e_sem_rotcl_compact;
475 extern sh3e_sem_fn sh3e_sem_rotcr_compact;
476 extern sh3e_sem_fn sh3e_sem_rotl_compact;
477 extern sh3e_sem_fn sh3e_sem_rotr_compact;
478 extern sh3e_sem_fn sh3e_sem_rts_compact;
479 extern sh3e_sem_fn sh3e_sem_sets_compact;
480 extern sh3e_sem_fn sh3e_sem_sett_compact;
481 extern sh3e_sem_fn sh3e_sem_shad_compact;
482 extern sh3e_sem_fn sh3e_sem_shal_compact;
483 extern sh3e_sem_fn sh3e_sem_shar_compact;
484 extern sh3e_sem_fn sh3e_sem_shld_compact;
485 extern sh3e_sem_fn sh3e_sem_shll_compact;
486 extern sh3e_sem_fn sh3e_sem_shll2_compact;
487 extern sh3e_sem_fn sh3e_sem_shll8_compact;
488 extern sh3e_sem_fn sh3e_sem_shll16_compact;
489 extern sh3e_sem_fn sh3e_sem_shlr_compact;
490 extern sh3e_sem_fn sh3e_sem_shlr2_compact;
491 extern sh3e_sem_fn sh3e_sem_shlr8_compact;
492 extern sh3e_sem_fn sh3e_sem_shlr16_compact;
493 extern sh3e_sem_fn sh3e_sem_stc_gbr_compact;
494 extern sh3e_sem_fn sh3e_sem_stc_vbr_compact;
495 extern sh3e_sem_fn sh3e_sem_stcl_gbr_compact;
496 extern sh3e_sem_fn sh3e_sem_stcl_vbr_compact;
497 extern sh3e_sem_fn sh3e_sem_sts_fpscr_compact;
498 extern sh3e_sem_fn sh3e_sem_stsl_fpscr_compact;
499 extern sh3e_sem_fn sh3e_sem_sts_fpul_compact;
500 extern sh3e_sem_fn sh3e_sem_stsl_fpul_compact;
501 extern sh3e_sem_fn sh3e_sem_sts_mach_compact;
502 extern sh3e_sem_fn sh3e_sem_stsl_mach_compact;
503 extern sh3e_sem_fn sh3e_sem_sts_macl_compact;
504 extern sh3e_sem_fn sh3e_sem_stsl_macl_compact;
505 extern sh3e_sem_fn sh3e_sem_sts_pr_compact;
506 extern sh3e_sem_fn sh3e_sem_stsl_pr_compact;
507 extern sh3e_sem_fn sh3e_sem_sub_compact;
508 extern sh3e_sem_fn sh3e_sem_subc_compact;
509 extern sh3e_sem_fn sh3e_sem_subv_compact;
510 extern sh3e_sem_fn sh3e_sem_swapb_compact;
511 extern sh3e_sem_fn sh3e_sem_swapw_compact;
512 extern sh3e_sem_fn sh3e_sem_tasb_compact;
513 extern sh3e_sem_fn sh3e_sem_trapa_compact;
514 extern sh3e_sem_fn sh3e_sem_tst_compact;
515 extern sh3e_sem_fn sh3e_sem_tsti_compact;
516 extern sh3e_sem_fn sh3e_sem_tstb_compact;
517 extern sh3e_sem_fn sh3e_sem_xor_compact;
518 extern sh3e_sem_fn sh3e_sem_xori_compact;
519 extern sh3e_sem_fn sh3e_sem_xorb_compact;
520 extern sh3e_sem_fn sh3e_sem_xtrct_compact;
521
522 #endif /* SH3E_DECODE_H */