1 /* Decode header for crisv10f.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright 1996-2005 Free Software Foundation, Inc.
7 This file is part of the GNU simulators.
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2, or (at your option)
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License along
20 with this program; if not, write to the Free Software Foundation, Inc.,
21 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
25 #ifndef CRISV10F_DECODE_H
26 #define CRISV10F_DECODE_H
28 extern const IDESC
*crisv10f_decode (SIM_CPU
*, IADDR
,
31 extern void crisv10f_init_idesc_table (SIM_CPU
*);
32 extern void crisv10f_sem_init_idesc_table (SIM_CPU
*);
33 extern void crisv10f_semf_init_idesc_table (SIM_CPU
*);
35 /* Enum declaration for instructions in cpu family crisv10f. */
36 typedef enum crisv10f_insn_type
{
37 CRISV10F_INSN_X_INVALID
, CRISV10F_INSN_X_AFTER
, CRISV10F_INSN_X_BEFORE
, CRISV10F_INSN_X_CTI_CHAIN
38 , CRISV10F_INSN_X_CHAIN
, CRISV10F_INSN_X_BEGIN
, CRISV10F_INSN_NOP
, CRISV10F_INSN_MOVE_B_R
39 , CRISV10F_INSN_MOVE_W_R
, CRISV10F_INSN_MOVE_D_R
, CRISV10F_INSN_MOVEPCR
, CRISV10F_INSN_MOVEQ
40 , CRISV10F_INSN_MOVS_B_R
, CRISV10F_INSN_MOVS_W_R
, CRISV10F_INSN_MOVU_B_R
, CRISV10F_INSN_MOVU_W_R
41 , CRISV10F_INSN_MOVECBR
, CRISV10F_INSN_MOVECWR
, CRISV10F_INSN_MOVECDR
, CRISV10F_INSN_MOVSCBR
42 , CRISV10F_INSN_MOVSCWR
, CRISV10F_INSN_MOVUCBR
, CRISV10F_INSN_MOVUCWR
, CRISV10F_INSN_ADDQ
43 , CRISV10F_INSN_SUBQ
, CRISV10F_INSN_CMP_R_B_R
, CRISV10F_INSN_CMP_R_W_R
, CRISV10F_INSN_CMP_R_D_R
44 , CRISV10F_INSN_CMP_M_B_M
, CRISV10F_INSN_CMP_M_W_M
, CRISV10F_INSN_CMP_M_D_M
, CRISV10F_INSN_CMPCBR
45 , CRISV10F_INSN_CMPCWR
, CRISV10F_INSN_CMPCDR
, CRISV10F_INSN_CMPQ
, CRISV10F_INSN_CMPS_M_B_M
46 , CRISV10F_INSN_CMPS_M_W_M
, CRISV10F_INSN_CMPSCBR
, CRISV10F_INSN_CMPSCWR
, CRISV10F_INSN_CMPU_M_B_M
47 , CRISV10F_INSN_CMPU_M_W_M
, CRISV10F_INSN_CMPUCBR
, CRISV10F_INSN_CMPUCWR
, CRISV10F_INSN_MOVE_M_B_M
48 , CRISV10F_INSN_MOVE_M_W_M
, CRISV10F_INSN_MOVE_M_D_M
, CRISV10F_INSN_MOVS_M_B_M
, CRISV10F_INSN_MOVS_M_W_M
49 , CRISV10F_INSN_MOVU_M_B_M
, CRISV10F_INSN_MOVU_M_W_M
, CRISV10F_INSN_MOVE_R_SPRV10
, CRISV10F_INSN_MOVE_SPR_RV10
50 , CRISV10F_INSN_RET_TYPE
, CRISV10F_INSN_MOVE_M_SPRV10
, CRISV10F_INSN_MOVE_C_SPRV10_P5
, CRISV10F_INSN_MOVE_C_SPRV10_P9
51 , CRISV10F_INSN_MOVE_C_SPRV10_P10
, CRISV10F_INSN_MOVE_C_SPRV10_P11
, CRISV10F_INSN_MOVE_C_SPRV10_P12
, CRISV10F_INSN_MOVE_C_SPRV10_P13
52 , CRISV10F_INSN_MOVE_C_SPRV10_P7
, CRISV10F_INSN_MOVE_C_SPRV10_P14
, CRISV10F_INSN_MOVE_C_SPRV10_P15
, CRISV10F_INSN_MOVE_SPR_MV10
53 , CRISV10F_INSN_SBFS
, CRISV10F_INSN_MOVEM_R_M
, CRISV10F_INSN_MOVEM_M_R
, CRISV10F_INSN_MOVEM_M_PC
54 , CRISV10F_INSN_ADD_B_R
, CRISV10F_INSN_ADD_W_R
, CRISV10F_INSN_ADD_D_R
, CRISV10F_INSN_ADD_M_B_M
55 , CRISV10F_INSN_ADD_M_W_M
, CRISV10F_INSN_ADD_M_D_M
, CRISV10F_INSN_ADDCBR
, CRISV10F_INSN_ADDCWR
56 , CRISV10F_INSN_ADDCDR
, CRISV10F_INSN_ADDCPC
, CRISV10F_INSN_ADDS_B_R
, CRISV10F_INSN_ADDS_W_R
57 , CRISV10F_INSN_ADDS_M_B_M
, CRISV10F_INSN_ADDS_M_W_M
, CRISV10F_INSN_ADDSCBR
, CRISV10F_INSN_ADDSCWR
58 , CRISV10F_INSN_ADDSPCPC
, CRISV10F_INSN_ADDU_B_R
, CRISV10F_INSN_ADDU_W_R
, CRISV10F_INSN_ADDU_M_B_M
59 , CRISV10F_INSN_ADDU_M_W_M
, CRISV10F_INSN_ADDUCBR
, CRISV10F_INSN_ADDUCWR
, CRISV10F_INSN_SUB_B_R
60 , CRISV10F_INSN_SUB_W_R
, CRISV10F_INSN_SUB_D_R
, CRISV10F_INSN_SUB_M_B_M
, CRISV10F_INSN_SUB_M_W_M
61 , CRISV10F_INSN_SUB_M_D_M
, CRISV10F_INSN_SUBCBR
, CRISV10F_INSN_SUBCWR
, CRISV10F_INSN_SUBCDR
62 , CRISV10F_INSN_SUBS_B_R
, CRISV10F_INSN_SUBS_W_R
, CRISV10F_INSN_SUBS_M_B_M
, CRISV10F_INSN_SUBS_M_W_M
63 , CRISV10F_INSN_SUBSCBR
, CRISV10F_INSN_SUBSCWR
, CRISV10F_INSN_SUBU_B_R
, CRISV10F_INSN_SUBU_W_R
64 , CRISV10F_INSN_SUBU_M_B_M
, CRISV10F_INSN_SUBU_M_W_M
, CRISV10F_INSN_SUBUCBR
, CRISV10F_INSN_SUBUCWR
65 , CRISV10F_INSN_ADDI_B_R
, CRISV10F_INSN_ADDI_W_R
, CRISV10F_INSN_ADDI_D_R
, CRISV10F_INSN_NEG_B_R
66 , CRISV10F_INSN_NEG_W_R
, CRISV10F_INSN_NEG_D_R
, CRISV10F_INSN_TEST_M_B_M
, CRISV10F_INSN_TEST_M_W_M
67 , CRISV10F_INSN_TEST_M_D_M
, CRISV10F_INSN_MOVE_R_M_B_M
, CRISV10F_INSN_MOVE_R_M_W_M
, CRISV10F_INSN_MOVE_R_M_D_M
68 , CRISV10F_INSN_MULS_B
, CRISV10F_INSN_MULS_W
, CRISV10F_INSN_MULS_D
, CRISV10F_INSN_MULU_B
69 , CRISV10F_INSN_MULU_W
, CRISV10F_INSN_MULU_D
, CRISV10F_INSN_MSTEP
, CRISV10F_INSN_DSTEP
70 , CRISV10F_INSN_ABS
, CRISV10F_INSN_AND_B_R
, CRISV10F_INSN_AND_W_R
, CRISV10F_INSN_AND_D_R
71 , CRISV10F_INSN_AND_M_B_M
, CRISV10F_INSN_AND_M_W_M
, CRISV10F_INSN_AND_M_D_M
, CRISV10F_INSN_ANDCBR
72 , CRISV10F_INSN_ANDCWR
, CRISV10F_INSN_ANDCDR
, CRISV10F_INSN_ANDQ
, CRISV10F_INSN_ORR_B_R
73 , CRISV10F_INSN_ORR_W_R
, CRISV10F_INSN_ORR_D_R
, CRISV10F_INSN_OR_M_B_M
, CRISV10F_INSN_OR_M_W_M
74 , CRISV10F_INSN_OR_M_D_M
, CRISV10F_INSN_ORCBR
, CRISV10F_INSN_ORCWR
, CRISV10F_INSN_ORCDR
75 , CRISV10F_INSN_ORQ
, CRISV10F_INSN_XOR
, CRISV10F_INSN_SWAP
, CRISV10F_INSN_ASRR_B_R
76 , CRISV10F_INSN_ASRR_W_R
, CRISV10F_INSN_ASRR_D_R
, CRISV10F_INSN_ASRQ
, CRISV10F_INSN_LSRR_B_R
77 , CRISV10F_INSN_LSRR_W_R
, CRISV10F_INSN_LSRR_D_R
, CRISV10F_INSN_LSRQ
, CRISV10F_INSN_LSLR_B_R
78 , CRISV10F_INSN_LSLR_W_R
, CRISV10F_INSN_LSLR_D_R
, CRISV10F_INSN_LSLQ
, CRISV10F_INSN_BTST
79 , CRISV10F_INSN_BTSTQ
, CRISV10F_INSN_SETF
, CRISV10F_INSN_CLEARF
, CRISV10F_INSN_BCC_B
80 , CRISV10F_INSN_BA_B
, CRISV10F_INSN_BCC_W
, CRISV10F_INSN_BA_W
, CRISV10F_INSN_JUMP_R
81 , CRISV10F_INSN_JUMP_M
, CRISV10F_INSN_JUMP_C
, CRISV10F_INSN_BREAK
, CRISV10F_INSN_BOUND_R_B_R
82 , CRISV10F_INSN_BOUND_R_W_R
, CRISV10F_INSN_BOUND_R_D_R
, CRISV10F_INSN_BOUND_M_B_M
, CRISV10F_INSN_BOUND_M_W_M
83 , CRISV10F_INSN_BOUND_M_D_M
, CRISV10F_INSN_BOUND_CB
, CRISV10F_INSN_BOUND_CW
, CRISV10F_INSN_BOUND_CD
84 , CRISV10F_INSN_SCC
, CRISV10F_INSN_LZ
, CRISV10F_INSN_ADDOQ
, CRISV10F_INSN_BDAPQPC
85 , CRISV10F_INSN_BDAP_32_PC
, CRISV10F_INSN_MOVE_M_PCPLUS_P0
, CRISV10F_INSN_MOVE_M_SPPLUS_P8
, CRISV10F_INSN_ADDO_M_B_M
86 , CRISV10F_INSN_ADDO_M_W_M
, CRISV10F_INSN_ADDO_M_D_M
, CRISV10F_INSN_ADDO_CB
, CRISV10F_INSN_ADDO_CW
87 , CRISV10F_INSN_ADDO_CD
, CRISV10F_INSN_DIP_M
, CRISV10F_INSN_DIP_C
, CRISV10F_INSN_ADDI_ACR_B_R
88 , CRISV10F_INSN_ADDI_ACR_W_R
, CRISV10F_INSN_ADDI_ACR_D_R
, CRISV10F_INSN_BIAP_PC_B_R
, CRISV10F_INSN_BIAP_PC_W_R
89 , CRISV10F_INSN_BIAP_PC_D_R
, CRISV10F_INSN__MAX
92 /* Enum declaration for semantic formats in cpu family crisv10f. */
93 typedef enum crisv10f_sfmt_type
{
94 CRISV10F_SFMT_EMPTY
, CRISV10F_SFMT_NOP
, CRISV10F_SFMT_MOVE_B_R
, CRISV10F_SFMT_MOVE_D_R
95 , CRISV10F_SFMT_MOVEPCR
, CRISV10F_SFMT_MOVEQ
, CRISV10F_SFMT_MOVS_B_R
, CRISV10F_SFMT_MOVECBR
96 , CRISV10F_SFMT_MOVECWR
, CRISV10F_SFMT_MOVECDR
, CRISV10F_SFMT_MOVSCBR
, CRISV10F_SFMT_MOVSCWR
97 , CRISV10F_SFMT_MOVUCBR
, CRISV10F_SFMT_MOVUCWR
, CRISV10F_SFMT_ADDQ
, CRISV10F_SFMT_CMP_R_B_R
98 , CRISV10F_SFMT_CMP_M_B_M
, CRISV10F_SFMT_CMP_M_W_M
, CRISV10F_SFMT_CMP_M_D_M
, CRISV10F_SFMT_CMPCBR
99 , CRISV10F_SFMT_CMPCWR
, CRISV10F_SFMT_CMPCDR
, CRISV10F_SFMT_CMPQ
, CRISV10F_SFMT_CMPUCBR
100 , CRISV10F_SFMT_CMPUCWR
, CRISV10F_SFMT_MOVE_M_B_M
, CRISV10F_SFMT_MOVE_M_W_M
, CRISV10F_SFMT_MOVE_M_D_M
101 , CRISV10F_SFMT_MOVS_M_B_M
, CRISV10F_SFMT_MOVS_M_W_M
, CRISV10F_SFMT_MOVE_R_SPRV10
, CRISV10F_SFMT_MOVE_SPR_RV10
102 , CRISV10F_SFMT_RET_TYPE
, CRISV10F_SFMT_MOVE_M_SPRV10
, CRISV10F_SFMT_MOVE_C_SPRV10_P5
, CRISV10F_SFMT_MOVE_C_SPRV10_P9
103 , CRISV10F_SFMT_MOVE_SPR_MV10
, CRISV10F_SFMT_SBFS
, CRISV10F_SFMT_MOVEM_R_M
, CRISV10F_SFMT_MOVEM_M_R
104 , CRISV10F_SFMT_MOVEM_M_PC
, CRISV10F_SFMT_ADD_B_R
, CRISV10F_SFMT_ADD_D_R
, CRISV10F_SFMT_ADD_M_B_M
105 , CRISV10F_SFMT_ADD_M_W_M
, CRISV10F_SFMT_ADD_M_D_M
, CRISV10F_SFMT_ADDCBR
, CRISV10F_SFMT_ADDCWR
106 , CRISV10F_SFMT_ADDCDR
, CRISV10F_SFMT_ADDCPC
, CRISV10F_SFMT_ADDS_M_B_M
, CRISV10F_SFMT_ADDS_M_W_M
107 , CRISV10F_SFMT_ADDSCBR
, CRISV10F_SFMT_ADDSCWR
, CRISV10F_SFMT_ADDSPCPC
, CRISV10F_SFMT_ADDI_B_R
108 , CRISV10F_SFMT_NEG_B_R
, CRISV10F_SFMT_NEG_D_R
, CRISV10F_SFMT_TEST_M_B_M
, CRISV10F_SFMT_TEST_M_W_M
109 , CRISV10F_SFMT_TEST_M_D_M
, CRISV10F_SFMT_MOVE_R_M_B_M
, CRISV10F_SFMT_MOVE_R_M_W_M
, CRISV10F_SFMT_MOVE_R_M_D_M
110 , CRISV10F_SFMT_MULS_B
, CRISV10F_SFMT_MSTEP
, CRISV10F_SFMT_DSTEP
, CRISV10F_SFMT_AND_B_R
111 , CRISV10F_SFMT_AND_W_R
, CRISV10F_SFMT_AND_D_R
, CRISV10F_SFMT_AND_M_B_M
, CRISV10F_SFMT_AND_M_W_M
112 , CRISV10F_SFMT_AND_M_D_M
, CRISV10F_SFMT_ANDCBR
, CRISV10F_SFMT_ANDCWR
, CRISV10F_SFMT_ANDCDR
113 , CRISV10F_SFMT_ANDQ
, CRISV10F_SFMT_SWAP
, CRISV10F_SFMT_ASRR_B_R
, CRISV10F_SFMT_ASRQ
114 , CRISV10F_SFMT_LSRR_B_R
, CRISV10F_SFMT_LSRR_D_R
, CRISV10F_SFMT_BTST
, CRISV10F_SFMT_BTSTQ
115 , CRISV10F_SFMT_SETF
, CRISV10F_SFMT_BCC_B
, CRISV10F_SFMT_BA_B
, CRISV10F_SFMT_BCC_W
116 , CRISV10F_SFMT_BA_W
, CRISV10F_SFMT_JUMP_R
, CRISV10F_SFMT_JUMP_M
, CRISV10F_SFMT_JUMP_C
117 , CRISV10F_SFMT_BREAK
, CRISV10F_SFMT_BOUND_M_B_M
, CRISV10F_SFMT_BOUND_M_W_M
, CRISV10F_SFMT_BOUND_M_D_M
118 , CRISV10F_SFMT_BOUND_CB
, CRISV10F_SFMT_BOUND_CW
, CRISV10F_SFMT_BOUND_CD
, CRISV10F_SFMT_SCC
119 , CRISV10F_SFMT_ADDOQ
, CRISV10F_SFMT_BDAPQPC
, CRISV10F_SFMT_BDAP_32_PC
, CRISV10F_SFMT_MOVE_M_PCPLUS_P0
120 , CRISV10F_SFMT_MOVE_M_SPPLUS_P8
, CRISV10F_SFMT_ADDO_M_B_M
, CRISV10F_SFMT_ADDO_M_W_M
, CRISV10F_SFMT_ADDO_M_D_M
121 , CRISV10F_SFMT_ADDO_CB
, CRISV10F_SFMT_ADDO_CW
, CRISV10F_SFMT_ADDO_CD
, CRISV10F_SFMT_DIP_M
122 , CRISV10F_SFMT_DIP_C
, CRISV10F_SFMT_ADDI_ACR_B_R
, CRISV10F_SFMT_BIAP_PC_B_R
123 } CRISV10F_SFMT_TYPE
;
125 /* Function unit handlers (user written). */
127 extern int crisv10f_model_crisv10_u_movem (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/, INT
/*Rd*/);
128 extern int crisv10f_model_crisv10_u_multiply (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/);
129 extern int crisv10f_model_crisv10_u_skip4 (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/);
130 extern int crisv10f_model_crisv10_u_stall (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/);
131 extern int crisv10f_model_crisv10_u_const32 (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/);
132 extern int crisv10f_model_crisv10_u_const16 (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/);
133 extern int crisv10f_model_crisv10_u_mem (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/);
134 extern int crisv10f_model_crisv10_u_exec (SIM_CPU
*, const IDESC
*, int /*unit_num*/, int /*referenced*/);
136 /* Profiling before/after handlers (user written) */
138 extern void crisv10f_model_insn_before (SIM_CPU
*, int /*first_p*/);
139 extern void crisv10f_model_insn_after (SIM_CPU
*, int /*last_p*/, int /*cycles*/);
141 #endif /* CRISV10F_DECODE_H */