1 /* Instruction opcode header for cris.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright 1996-2004 Free Software Foundation, Inc.
7 This file is part of the GNU Binutils and/or GDB, the GNU debugger.
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2, or (at your option)
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License along
20 with this program; if not, write to the Free Software Foundation, Inc.,
21 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
28 /* Enum declaration for cris instruction types. */
29 typedef enum cgen_insn_type
{
30 CRIS_INSN_INVALID
, CRIS_INSN_NOP
, CRIS_INSN_MOVE_B_R
, CRIS_INSN_MOVE_W_R
31 , CRIS_INSN_MOVE_D_R
, CRIS_INSN_MOVEPCR
, CRIS_INSN_MOVEQ
, CRIS_INSN_MOVS_B_R
32 , CRIS_INSN_MOVS_W_R
, CRIS_INSN_MOVU_B_R
, CRIS_INSN_MOVU_W_R
, CRIS_INSN_MOVECBR
33 , CRIS_INSN_MOVECWR
, CRIS_INSN_MOVECDR
, CRIS_INSN_MOVSCBR
, CRIS_INSN_MOVSCWR
34 , CRIS_INSN_MOVUCBR
, CRIS_INSN_MOVUCWR
, CRIS_INSN_ADDQ
, CRIS_INSN_SUBQ
35 , CRIS_INSN_CMP_R_B_R
, CRIS_INSN_CMP_R_W_R
, CRIS_INSN_CMP_R_D_R
, CRIS_INSN_CMP_M_B_M
36 , CRIS_INSN_CMP_M_W_M
, CRIS_INSN_CMP_M_D_M
, CRIS_INSN_CMPCBR
, CRIS_INSN_CMPCWR
37 , CRIS_INSN_CMPCDR
, CRIS_INSN_CMPQ
, CRIS_INSN_CMPS_M_B_M
, CRIS_INSN_CMPS_M_W_M
38 , CRIS_INSN_CMPSCBR
, CRIS_INSN_CMPSCWR
, CRIS_INSN_CMPU_M_B_M
, CRIS_INSN_CMPU_M_W_M
39 , CRIS_INSN_CMPUCBR
, CRIS_INSN_CMPUCWR
, CRIS_INSN_MOVE_M_B_M
, CRIS_INSN_MOVE_M_W_M
40 , CRIS_INSN_MOVE_M_D_M
, CRIS_INSN_MOVS_M_B_M
, CRIS_INSN_MOVS_M_W_M
, CRIS_INSN_MOVU_M_B_M
41 , CRIS_INSN_MOVU_M_W_M
, CRIS_INSN_MOVE_R_SPRV0
, CRIS_INSN_MOVE_R_SPRV3
, CRIS_INSN_MOVE_R_SPRV8
42 , CRIS_INSN_MOVE_R_SPRV10
, CRIS_INSN_MOVE_R_SPRV32
, CRIS_INSN_MOVE_SPR_RV0
, CRIS_INSN_MOVE_SPR_RV3
43 , CRIS_INSN_MOVE_SPR_RV8
, CRIS_INSN_MOVE_SPR_RV10
, CRIS_INSN_MOVE_SPR_RV32
, CRIS_INSN_RET_TYPE
44 , CRIS_INSN_MOVE_M_SPRV0
, CRIS_INSN_MOVE_M_SPRV3
, CRIS_INSN_MOVE_M_SPRV8
, CRIS_INSN_MOVE_M_SPRV10
45 , CRIS_INSN_MOVE_M_SPRV32
, CRIS_INSN_MOVE_C_SPRV0_P0
, CRIS_INSN_MOVE_C_SPRV0_P1
, CRIS_INSN_MOVE_C_SPRV0_P4
46 , CRIS_INSN_MOVE_C_SPRV0_P5
, CRIS_INSN_MOVE_C_SPRV0_P8
, CRIS_INSN_MOVE_C_SPRV0_P9
, CRIS_INSN_MOVE_C_SPRV0_P10
47 , CRIS_INSN_MOVE_C_SPRV0_P11
, CRIS_INSN_MOVE_C_SPRV0_P12
, CRIS_INSN_MOVE_C_SPRV0_P13
, CRIS_INSN_MOVE_C_SPRV0_P6
48 , CRIS_INSN_MOVE_C_SPRV0_P7
, CRIS_INSN_MOVE_C_SPRV3_P0
, CRIS_INSN_MOVE_C_SPRV3_P1
, CRIS_INSN_MOVE_C_SPRV3_P4
49 , CRIS_INSN_MOVE_C_SPRV3_P5
, CRIS_INSN_MOVE_C_SPRV3_P8
, CRIS_INSN_MOVE_C_SPRV3_P9
, CRIS_INSN_MOVE_C_SPRV3_P10
50 , CRIS_INSN_MOVE_C_SPRV3_P11
, CRIS_INSN_MOVE_C_SPRV3_P12
, CRIS_INSN_MOVE_C_SPRV3_P13
, CRIS_INSN_MOVE_C_SPRV3_P6
51 , CRIS_INSN_MOVE_C_SPRV3_P7
, CRIS_INSN_MOVE_C_SPRV3_P14
, CRIS_INSN_MOVE_C_SPRV8_P0
, CRIS_INSN_MOVE_C_SPRV8_P1
52 , CRIS_INSN_MOVE_C_SPRV8_P4
, CRIS_INSN_MOVE_C_SPRV8_P5
, CRIS_INSN_MOVE_C_SPRV8_P8
, CRIS_INSN_MOVE_C_SPRV8_P9
53 , CRIS_INSN_MOVE_C_SPRV8_P10
, CRIS_INSN_MOVE_C_SPRV8_P11
, CRIS_INSN_MOVE_C_SPRV8_P12
, CRIS_INSN_MOVE_C_SPRV8_P13
54 , CRIS_INSN_MOVE_C_SPRV8_P14
, CRIS_INSN_MOVE_C_SPRV10_P0
, CRIS_INSN_MOVE_C_SPRV10_P1
, CRIS_INSN_MOVE_C_SPRV10_P4
55 , CRIS_INSN_MOVE_C_SPRV10_P5
, CRIS_INSN_MOVE_C_SPRV10_P8
, CRIS_INSN_MOVE_C_SPRV10_P9
, CRIS_INSN_MOVE_C_SPRV10_P10
56 , CRIS_INSN_MOVE_C_SPRV10_P11
, CRIS_INSN_MOVE_C_SPRV10_P12
, CRIS_INSN_MOVE_C_SPRV10_P13
, CRIS_INSN_MOVE_C_SPRV10_P7
57 , CRIS_INSN_MOVE_C_SPRV10_P14
, CRIS_INSN_MOVE_C_SPRV10_P15
, CRIS_INSN_MOVE_C_SPRV32_P0
, CRIS_INSN_MOVE_C_SPRV32_P1
58 , CRIS_INSN_MOVE_C_SPRV32_P2
, CRIS_INSN_MOVE_C_SPRV32_P3
, CRIS_INSN_MOVE_C_SPRV32_P4
, CRIS_INSN_MOVE_C_SPRV32_P5
59 , CRIS_INSN_MOVE_C_SPRV32_P6
, CRIS_INSN_MOVE_C_SPRV32_P7
, CRIS_INSN_MOVE_C_SPRV32_P8
, CRIS_INSN_MOVE_C_SPRV32_P9
60 , CRIS_INSN_MOVE_C_SPRV32_P10
, CRIS_INSN_MOVE_C_SPRV32_P11
, CRIS_INSN_MOVE_C_SPRV32_P12
, CRIS_INSN_MOVE_C_SPRV32_P13
61 , CRIS_INSN_MOVE_C_SPRV32_P14
, CRIS_INSN_MOVE_C_SPRV32_P15
, CRIS_INSN_MOVE_SPR_MV0
, CRIS_INSN_MOVE_SPR_MV3
62 , CRIS_INSN_MOVE_SPR_MV8
, CRIS_INSN_MOVE_SPR_MV10
, CRIS_INSN_MOVE_SPR_MV32
, CRIS_INSN_SBFS
63 , CRIS_INSN_MOVE_SS_R
, CRIS_INSN_MOVE_R_SS
, CRIS_INSN_MOVEM_R_M
, CRIS_INSN_MOVEM_R_M_V32
64 , CRIS_INSN_MOVEM_M_R
, CRIS_INSN_MOVEM_M_PC
, CRIS_INSN_MOVEM_M_R_V32
, CRIS_INSN_ADD_B_R
65 , CRIS_INSN_ADD_W_R
, CRIS_INSN_ADD_D_R
, CRIS_INSN_ADD_M_B_M
, CRIS_INSN_ADD_M_W_M
66 , CRIS_INSN_ADD_M_D_M
, CRIS_INSN_ADDCBR
, CRIS_INSN_ADDCWR
, CRIS_INSN_ADDCDR
67 , CRIS_INSN_ADDCPC
, CRIS_INSN_ADDS_B_R
, CRIS_INSN_ADDS_W_R
, CRIS_INSN_ADDS_M_B_M
68 , CRIS_INSN_ADDS_M_W_M
, CRIS_INSN_ADDSCBR
, CRIS_INSN_ADDSCWR
, CRIS_INSN_ADDSPCPC
69 , CRIS_INSN_ADDU_B_R
, CRIS_INSN_ADDU_W_R
, CRIS_INSN_ADDU_M_B_M
, CRIS_INSN_ADDU_M_W_M
70 , CRIS_INSN_ADDUCBR
, CRIS_INSN_ADDUCWR
, CRIS_INSN_SUB_B_R
, CRIS_INSN_SUB_W_R
71 , CRIS_INSN_SUB_D_R
, CRIS_INSN_SUB_M_B_M
, CRIS_INSN_SUB_M_W_M
, CRIS_INSN_SUB_M_D_M
72 , CRIS_INSN_SUBCBR
, CRIS_INSN_SUBCWR
, CRIS_INSN_SUBCDR
, CRIS_INSN_SUBS_B_R
73 , CRIS_INSN_SUBS_W_R
, CRIS_INSN_SUBS_M_B_M
, CRIS_INSN_SUBS_M_W_M
, CRIS_INSN_SUBSCBR
74 , CRIS_INSN_SUBSCWR
, CRIS_INSN_SUBU_B_R
, CRIS_INSN_SUBU_W_R
, CRIS_INSN_SUBU_M_B_M
75 , CRIS_INSN_SUBU_M_W_M
, CRIS_INSN_SUBUCBR
, CRIS_INSN_SUBUCWR
, CRIS_INSN_ADDC_R
76 , CRIS_INSN_ADDC_M
, CRIS_INSN_ADDC_C
, CRIS_INSN_LAPC_D
, CRIS_INSN_LAPCQ
77 , CRIS_INSN_ADDI_B_R
, CRIS_INSN_ADDI_W_R
, CRIS_INSN_ADDI_D_R
, CRIS_INSN_NEG_B_R
78 , CRIS_INSN_NEG_W_R
, CRIS_INSN_NEG_D_R
, CRIS_INSN_TEST_M_B_M
, CRIS_INSN_TEST_M_W_M
79 , CRIS_INSN_TEST_M_D_M
, CRIS_INSN_MOVE_R_M_B_M
, CRIS_INSN_MOVE_R_M_W_M
, CRIS_INSN_MOVE_R_M_D_M
80 , CRIS_INSN_MULS_B
, CRIS_INSN_MULS_W
, CRIS_INSN_MULS_D
, CRIS_INSN_MULU_B
81 , CRIS_INSN_MULU_W
, CRIS_INSN_MULU_D
, CRIS_INSN_MCP
, CRIS_INSN_MSTEP
82 , CRIS_INSN_DSTEP
, CRIS_INSN_ABS
, CRIS_INSN_AND_B_R
, CRIS_INSN_AND_W_R
83 , CRIS_INSN_AND_D_R
, CRIS_INSN_AND_M_B_M
, CRIS_INSN_AND_M_W_M
, CRIS_INSN_AND_M_D_M
84 , CRIS_INSN_ANDCBR
, CRIS_INSN_ANDCWR
, CRIS_INSN_ANDCDR
, CRIS_INSN_ANDQ
85 , CRIS_INSN_ORR_B_R
, CRIS_INSN_ORR_W_R
, CRIS_INSN_ORR_D_R
, CRIS_INSN_OR_M_B_M
86 , CRIS_INSN_OR_M_W_M
, CRIS_INSN_OR_M_D_M
, CRIS_INSN_ORCBR
, CRIS_INSN_ORCWR
87 , CRIS_INSN_ORCDR
, CRIS_INSN_ORQ
, CRIS_INSN_XOR
, CRIS_INSN_NOT
88 , CRIS_INSN_SWAP
, CRIS_INSN_ASRR_B_R
, CRIS_INSN_ASRR_W_R
, CRIS_INSN_ASRR_D_R
89 , CRIS_INSN_ASRQ
, CRIS_INSN_LSRR_B_R
, CRIS_INSN_LSRR_W_R
, CRIS_INSN_LSRR_D_R
90 , CRIS_INSN_LSRQ
, CRIS_INSN_LSLR_B_R
, CRIS_INSN_LSLR_W_R
, CRIS_INSN_LSLR_D_R
91 , CRIS_INSN_LSLQ
, CRIS_INSN_BTST
, CRIS_INSN_BTSTQ
, CRIS_INSN_SETF
92 , CRIS_INSN_CLEARF
, CRIS_INSN_RFE
, CRIS_INSN_SFE
, CRIS_INSN_RFG
93 , CRIS_INSN_RFN
, CRIS_INSN_HALT
, CRIS_INSN_BCC_B
, CRIS_INSN_BA_B
94 , CRIS_INSN_BCC_W
, CRIS_INSN_BA_W
, CRIS_INSN_JAS_R
, CRIS_INSN_JUMP_R
95 , CRIS_INSN_JAS_C
, CRIS_INSN_JUMP_M
, CRIS_INSN_JUMP_C
, CRIS_INSN_JUMP_P
96 , CRIS_INSN_BAS_C
, CRIS_INSN_JASC_R
, CRIS_INSN_JASC_C
, CRIS_INSN_BASC_C
97 , CRIS_INSN_BREAK
, CRIS_INSN_BOUND_R_B_R
, CRIS_INSN_BOUND_R_W_R
, CRIS_INSN_BOUND_R_D_R
98 , CRIS_INSN_BOUND_M_B_M
, CRIS_INSN_BOUND_M_W_M
, CRIS_INSN_BOUND_M_D_M
, CRIS_INSN_BOUND_CB
99 , CRIS_INSN_BOUND_CW
, CRIS_INSN_BOUND_CD
, CRIS_INSN_SCC
, CRIS_INSN_LZ
100 , CRIS_INSN_ADDOQ
, CRIS_INSN_BDAPQPC
, CRIS_INSN_ADDO_M_B_M
, CRIS_INSN_ADDO_M_W_M
101 , CRIS_INSN_ADDO_M_D_M
, CRIS_INSN_ADDO_CB
, CRIS_INSN_ADDO_CW
, CRIS_INSN_ADDO_CD
102 , CRIS_INSN_DIP_M
, CRIS_INSN_DIP_C
, CRIS_INSN_ADDI_ACR_B_R
, CRIS_INSN_ADDI_ACR_W_R
103 , CRIS_INSN_ADDI_ACR_D_R
, CRIS_INSN_BIAP_PC_B_R
, CRIS_INSN_BIAP_PC_W_R
, CRIS_INSN_BIAP_PC_D_R
104 , CRIS_INSN_FIDXI
, CRIS_INSN_FTAGI
, CRIS_INSN_FIDXD
, CRIS_INSN_FTAGD
107 /* Index of `invalid' insn place holder. */
108 #define CGEN_INSN_INVALID CRIS_INSN_INVALID
110 /* Total number of insns in table. */
111 #define MAX_INSNS ((int) CRIS_INSN_FTAGD + 1)
113 /* This struct records data prior to insertion or after extraction. */
138 long f_indir_pc__byte
;
139 long f_indir_pc__word
;
140 long f_indir_pc__word_pcrel
;
141 long f_indir_pc__dword
;
142 long f_indir_pc__dword_pcrel
;
145 #define CGEN_INIT_PARSE(od) \
148 #define CGEN_INIT_INSERT(od) \
151 #define CGEN_INIT_EXTRACT(od) \
154 #define CGEN_INIT_PRINT(od) \
159 #endif /* CRIS_OPC_H */