1 1.1.1.5 christos /* DO NOT EDIT! -*- buffer-read-only: t -*- vi:set ro: */ 2 1.1 skrll /* CPU data header for m32r. 3 1.1 skrll 4 1.1 skrll THIS FILE IS MACHINE GENERATED WITH CGEN. 5 1.1 skrll 6 1.1.1.10 christos Copyright (C) 1996-2026 Free Software Foundation, Inc. 7 1.1 skrll 8 1.1 skrll This file is part of the GNU Binutils and/or GDB, the GNU debugger. 9 1.1 skrll 10 1.1 skrll This file is free software; you can redistribute it and/or modify 11 1.1 skrll it under the terms of the GNU General Public License as published by 12 1.1 skrll the Free Software Foundation; either version 3, or (at your option) 13 1.1 skrll any later version. 14 1.1 skrll 15 1.1 skrll It is distributed in the hope that it will be useful, but WITHOUT 16 1.1 skrll ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 17 1.1 skrll or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public 18 1.1 skrll License for more details. 19 1.1 skrll 20 1.1 skrll You should have received a copy of the GNU General Public License along 21 1.1 skrll with this program; if not, write to the Free Software Foundation, Inc., 22 1.1 skrll 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. 23 1.1 skrll 24 1.1 skrll */ 25 1.1 skrll 26 1.1 skrll #ifndef M32R_CPU_H 27 1.1 skrll #define M32R_CPU_H 28 1.1 skrll 29 1.1.1.5 christos #ifdef __cplusplus 30 1.1.1.5 christos extern "C" { 31 1.1.1.5 christos #endif 32 1.1.1.5 christos 33 1.1 skrll #define CGEN_ARCH m32r 34 1.1 skrll 35 1.1 skrll /* Given symbol S, return m32r_cgen_<S>. */ 36 1.1 skrll #define CGEN_SYM(s) m32r##_cgen_##s 37 1.1 skrll 38 1.1 skrll 39 1.1 skrll /* Selected cpu families. */ 40 1.1 skrll #define HAVE_CPU_M32RBF 41 1.1 skrll #define HAVE_CPU_M32RXF 42 1.1 skrll #define HAVE_CPU_M32R2F 43 1.1 skrll 44 1.1 skrll #define CGEN_INSN_LSB0_P 0 45 1.1 skrll 46 1.1 skrll /* Minimum size of any insn (in bytes). */ 47 1.1 skrll #define CGEN_MIN_INSN_SIZE 2 48 1.1 skrll 49 1.1 skrll /* Maximum size of any insn (in bytes). */ 50 1.1 skrll #define CGEN_MAX_INSN_SIZE 4 51 1.1 skrll 52 1.1 skrll #define CGEN_INT_INSN_P 1 53 1.1 skrll 54 1.1 skrll /* Maximum number of syntax elements in an instruction. */ 55 1.1 skrll #define CGEN_ACTUAL_MAX_SYNTAX_ELEMENTS 15 56 1.1 skrll 57 1.1 skrll /* CGEN_MNEMONIC_OPERANDS is defined if mnemonics have operands. 58 1.1 skrll e.g. In "b,a foo" the ",a" is an operand. If mnemonics have operands 59 1.1 skrll we can't hash on everything up to the space. */ 60 1.1 skrll #define CGEN_MNEMONIC_OPERANDS 61 1.1 skrll 62 1.1 skrll /* Maximum number of fields in an instruction. */ 63 1.1 skrll #define CGEN_ACTUAL_MAX_IFMT_OPERANDS 7 64 1.1 skrll 65 1.1 skrll /* Enums. */ 66 1.1 skrll 67 1.1 skrll /* Enum declaration for insn format enums. */ 68 1.1 skrll typedef enum insn_op1 { 69 1.1 skrll OP1_0, OP1_1, OP1_2, OP1_3 70 1.1 skrll , OP1_4, OP1_5, OP1_6, OP1_7 71 1.1 skrll , OP1_8, OP1_9, OP1_10, OP1_11 72 1.1 skrll , OP1_12, OP1_13, OP1_14, OP1_15 73 1.1 skrll } INSN_OP1; 74 1.1 skrll 75 1.1 skrll /* Enum declaration for op2 enums. */ 76 1.1 skrll typedef enum insn_op2 { 77 1.1 skrll OP2_0, OP2_1, OP2_2, OP2_3 78 1.1 skrll , OP2_4, OP2_5, OP2_6, OP2_7 79 1.1 skrll , OP2_8, OP2_9, OP2_10, OP2_11 80 1.1 skrll , OP2_12, OP2_13, OP2_14, OP2_15 81 1.1 skrll } INSN_OP2; 82 1.1 skrll 83 1.1 skrll /* Enum declaration for . */ 84 1.1 skrll typedef enum gr_names { 85 1.1 skrll H_GR_FP = 13, H_GR_LR = 14, H_GR_SP = 15, H_GR_R0 = 0 86 1.1 skrll , H_GR_R1 = 1, H_GR_R2 = 2, H_GR_R3 = 3, H_GR_R4 = 4 87 1.1 skrll , H_GR_R5 = 5, H_GR_R6 = 6, H_GR_R7 = 7, H_GR_R8 = 8 88 1.1 skrll , H_GR_R9 = 9, H_GR_R10 = 10, H_GR_R11 = 11, H_GR_R12 = 12 89 1.1 skrll , H_GR_R13 = 13, H_GR_R14 = 14, H_GR_R15 = 15 90 1.1 skrll } GR_NAMES; 91 1.1 skrll 92 1.1 skrll /* Enum declaration for . */ 93 1.1 skrll typedef enum cr_names { 94 1.1 skrll H_CR_PSW = 0, H_CR_CBR = 1, H_CR_SPI = 2, H_CR_SPU = 3 95 1.1 skrll , H_CR_BPC = 6, H_CR_BBPSW = 8, H_CR_BBPC = 14, H_CR_EVB = 5 96 1.1 skrll , H_CR_CR0 = 0, H_CR_CR1 = 1, H_CR_CR2 = 2, H_CR_CR3 = 3 97 1.1 skrll , H_CR_CR4 = 4, H_CR_CR5 = 5, H_CR_CR6 = 6, H_CR_CR7 = 7 98 1.1 skrll , H_CR_CR8 = 8, H_CR_CR9 = 9, H_CR_CR10 = 10, H_CR_CR11 = 11 99 1.1 skrll , H_CR_CR12 = 12, H_CR_CR13 = 13, H_CR_CR14 = 14, H_CR_CR15 = 15 100 1.1 skrll } CR_NAMES; 101 1.1 skrll 102 1.1 skrll /* Attributes. */ 103 1.1 skrll 104 1.1 skrll /* Enum declaration for machine type selection. */ 105 1.1 skrll typedef enum mach_attr { 106 1.1 skrll MACH_BASE, MACH_M32R, MACH_M32RX, MACH_M32R2 107 1.1 skrll , MACH_MAX 108 1.1 skrll } MACH_ATTR; 109 1.1 skrll 110 1.1 skrll /* Enum declaration for instruction set selection. */ 111 1.1 skrll typedef enum isa_attr { 112 1.1 skrll ISA_M32R, ISA_MAX 113 1.1 skrll } ISA_ATTR; 114 1.1 skrll 115 1.1 skrll /* Enum declaration for parallel execution pipeline selection. */ 116 1.1 skrll typedef enum pipe_attr { 117 1.1 skrll PIPE_NONE, PIPE_O, PIPE_S, PIPE_OS 118 1.1 skrll , PIPE_O_OS 119 1.1 skrll } PIPE_ATTR; 120 1.1 skrll 121 1.1 skrll /* Number of architecture variants. */ 122 1.1 skrll #define MAX_ISAS 1 123 1.1 skrll #define MAX_MACHS ((int) MACH_MAX) 124 1.1 skrll 125 1.1 skrll /* Ifield support. */ 126 1.1 skrll 127 1.1 skrll /* Ifield attribute indices. */ 128 1.1 skrll 129 1.1 skrll /* Enum declaration for cgen_ifld attrs. */ 130 1.1 skrll typedef enum cgen_ifld_attr { 131 1.1 skrll CGEN_IFLD_VIRTUAL, CGEN_IFLD_PCREL_ADDR, CGEN_IFLD_ABS_ADDR, CGEN_IFLD_RESERVED 132 1.1 skrll , CGEN_IFLD_SIGN_OPT, CGEN_IFLD_SIGNED, CGEN_IFLD_RELOC, CGEN_IFLD_END_BOOLS 133 1.1 skrll , CGEN_IFLD_START_NBOOLS = 31, CGEN_IFLD_MACH, CGEN_IFLD_END_NBOOLS 134 1.1 skrll } CGEN_IFLD_ATTR; 135 1.1 skrll 136 1.1 skrll /* Number of non-boolean elements in cgen_ifld_attr. */ 137 1.1 skrll #define CGEN_IFLD_NBOOL_ATTRS (CGEN_IFLD_END_NBOOLS - CGEN_IFLD_START_NBOOLS - 1) 138 1.1 skrll 139 1.1 skrll /* cgen_ifld attribute accessor macros. */ 140 1.1 skrll #define CGEN_ATTR_CGEN_IFLD_MACH_VALUE(attrs) ((attrs)->nonbool[CGEN_IFLD_MACH-CGEN_IFLD_START_NBOOLS-1].nonbitset) 141 1.1.1.2 christos #define CGEN_ATTR_CGEN_IFLD_VIRTUAL_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_IFLD_VIRTUAL)) != 0) 142 1.1.1.2 christos #define CGEN_ATTR_CGEN_IFLD_PCREL_ADDR_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_IFLD_PCREL_ADDR)) != 0) 143 1.1.1.2 christos #define CGEN_ATTR_CGEN_IFLD_ABS_ADDR_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_IFLD_ABS_ADDR)) != 0) 144 1.1.1.2 christos #define CGEN_ATTR_CGEN_IFLD_RESERVED_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_IFLD_RESERVED)) != 0) 145 1.1.1.2 christos #define CGEN_ATTR_CGEN_IFLD_SIGN_OPT_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_IFLD_SIGN_OPT)) != 0) 146 1.1.1.2 christos #define CGEN_ATTR_CGEN_IFLD_SIGNED_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_IFLD_SIGNED)) != 0) 147 1.1.1.2 christos #define CGEN_ATTR_CGEN_IFLD_RELOC_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_IFLD_RELOC)) != 0) 148 1.1 skrll 149 1.1 skrll /* Enum declaration for m32r ifield types. */ 150 1.1 skrll typedef enum ifield_type { 151 1.1 skrll M32R_F_NIL, M32R_F_ANYOF, M32R_F_OP1, M32R_F_OP2 152 1.1 skrll , M32R_F_COND, M32R_F_R1, M32R_F_R2, M32R_F_SIMM8 153 1.1 skrll , M32R_F_SIMM16, M32R_F_SHIFT_OP2, M32R_F_UIMM3, M32R_F_UIMM4 154 1.1 skrll , M32R_F_UIMM5, M32R_F_UIMM8, M32R_F_UIMM16, M32R_F_UIMM24 155 1.1 skrll , M32R_F_HI16, M32R_F_DISP8, M32R_F_DISP16, M32R_F_DISP24 156 1.1 skrll , M32R_F_OP23, M32R_F_OP3, M32R_F_ACC, M32R_F_ACCS 157 1.1 skrll , M32R_F_ACCD, M32R_F_BITS67, M32R_F_BIT4, M32R_F_BIT14 158 1.1 skrll , M32R_F_IMM1, M32R_F_MAX 159 1.1 skrll } IFIELD_TYPE; 160 1.1 skrll 161 1.1 skrll #define MAX_IFLD ((int) M32R_F_MAX) 162 1.1 skrll 163 1.1 skrll /* Hardware attribute indices. */ 164 1.1 skrll 165 1.1 skrll /* Enum declaration for cgen_hw attrs. */ 166 1.1 skrll typedef enum cgen_hw_attr { 167 1.1 skrll CGEN_HW_VIRTUAL, CGEN_HW_CACHE_ADDR, CGEN_HW_PC, CGEN_HW_PROFILE 168 1.1 skrll , CGEN_HW_END_BOOLS, CGEN_HW_START_NBOOLS = 31, CGEN_HW_MACH, CGEN_HW_END_NBOOLS 169 1.1 skrll } CGEN_HW_ATTR; 170 1.1 skrll 171 1.1 skrll /* Number of non-boolean elements in cgen_hw_attr. */ 172 1.1 skrll #define CGEN_HW_NBOOL_ATTRS (CGEN_HW_END_NBOOLS - CGEN_HW_START_NBOOLS - 1) 173 1.1 skrll 174 1.1 skrll /* cgen_hw attribute accessor macros. */ 175 1.1 skrll #define CGEN_ATTR_CGEN_HW_MACH_VALUE(attrs) ((attrs)->nonbool[CGEN_HW_MACH-CGEN_HW_START_NBOOLS-1].nonbitset) 176 1.1.1.2 christos #define CGEN_ATTR_CGEN_HW_VIRTUAL_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_HW_VIRTUAL)) != 0) 177 1.1.1.2 christos #define CGEN_ATTR_CGEN_HW_CACHE_ADDR_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_HW_CACHE_ADDR)) != 0) 178 1.1.1.2 christos #define CGEN_ATTR_CGEN_HW_PC_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_HW_PC)) != 0) 179 1.1.1.2 christos #define CGEN_ATTR_CGEN_HW_PROFILE_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_HW_PROFILE)) != 0) 180 1.1 skrll 181 1.1 skrll /* Enum declaration for m32r hardware types. */ 182 1.1 skrll typedef enum cgen_hw_type { 183 1.1 skrll HW_H_MEMORY, HW_H_SINT, HW_H_UINT, HW_H_ADDR 184 1.1 skrll , HW_H_IADDR, HW_H_PC, HW_H_HI16, HW_H_SLO16 185 1.1 skrll , HW_H_ULO16, HW_H_GR, HW_H_CR, HW_H_ACCUM 186 1.1 skrll , HW_H_ACCUMS, HW_H_COND, HW_H_PSW, HW_H_BPSW 187 1.1 skrll , HW_H_BBPSW, HW_H_LOCK, HW_MAX 188 1.1 skrll } CGEN_HW_TYPE; 189 1.1 skrll 190 1.1 skrll #define MAX_HW ((int) HW_MAX) 191 1.1 skrll 192 1.1 skrll /* Operand attribute indices. */ 193 1.1 skrll 194 1.1 skrll /* Enum declaration for cgen_operand attrs. */ 195 1.1 skrll typedef enum cgen_operand_attr { 196 1.1 skrll CGEN_OPERAND_VIRTUAL, CGEN_OPERAND_PCREL_ADDR, CGEN_OPERAND_ABS_ADDR, CGEN_OPERAND_SIGN_OPT 197 1.1 skrll , CGEN_OPERAND_SIGNED, CGEN_OPERAND_NEGATIVE, CGEN_OPERAND_RELAX, CGEN_OPERAND_SEM_ONLY 198 1.1.1.2 christos , CGEN_OPERAND_RELOC, CGEN_OPERAND_END_BOOLS, CGEN_OPERAND_START_NBOOLS = 31, CGEN_OPERAND_MACH 199 1.1.1.2 christos , CGEN_OPERAND_END_NBOOLS 200 1.1 skrll } CGEN_OPERAND_ATTR; 201 1.1 skrll 202 1.1 skrll /* Number of non-boolean elements in cgen_operand_attr. */ 203 1.1 skrll #define CGEN_OPERAND_NBOOL_ATTRS (CGEN_OPERAND_END_NBOOLS - CGEN_OPERAND_START_NBOOLS - 1) 204 1.1 skrll 205 1.1 skrll /* cgen_operand attribute accessor macros. */ 206 1.1 skrll #define CGEN_ATTR_CGEN_OPERAND_MACH_VALUE(attrs) ((attrs)->nonbool[CGEN_OPERAND_MACH-CGEN_OPERAND_START_NBOOLS-1].nonbitset) 207 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_VIRTUAL_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_VIRTUAL)) != 0) 208 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_PCREL_ADDR_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_PCREL_ADDR)) != 0) 209 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_ABS_ADDR_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_ABS_ADDR)) != 0) 210 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_SIGN_OPT_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_SIGN_OPT)) != 0) 211 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_SIGNED_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_SIGNED)) != 0) 212 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_NEGATIVE_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_NEGATIVE)) != 0) 213 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_RELAX_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_RELAX)) != 0) 214 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_SEM_ONLY_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_SEM_ONLY)) != 0) 215 1.1.1.2 christos #define CGEN_ATTR_CGEN_OPERAND_RELOC_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_OPERAND_RELOC)) != 0) 216 1.1 skrll 217 1.1 skrll /* Enum declaration for m32r operand types. */ 218 1.1 skrll typedef enum cgen_operand_type { 219 1.1 skrll M32R_OPERAND_PC, M32R_OPERAND_SR, M32R_OPERAND_DR, M32R_OPERAND_SRC1 220 1.1 skrll , M32R_OPERAND_SRC2, M32R_OPERAND_SCR, M32R_OPERAND_DCR, M32R_OPERAND_SIMM8 221 1.1 skrll , M32R_OPERAND_SIMM16, M32R_OPERAND_UIMM3, M32R_OPERAND_UIMM4, M32R_OPERAND_UIMM5 222 1.1 skrll , M32R_OPERAND_UIMM8, M32R_OPERAND_UIMM16, M32R_OPERAND_IMM1, M32R_OPERAND_ACCD 223 1.1 skrll , M32R_OPERAND_ACCS, M32R_OPERAND_ACC, M32R_OPERAND_HASH, M32R_OPERAND_HI16 224 1.1 skrll , M32R_OPERAND_SLO16, M32R_OPERAND_ULO16, M32R_OPERAND_UIMM24, M32R_OPERAND_DISP8 225 1.1 skrll , M32R_OPERAND_DISP16, M32R_OPERAND_DISP24, M32R_OPERAND_CONDBIT, M32R_OPERAND_ACCUM 226 1.1 skrll , M32R_OPERAND_MAX 227 1.1 skrll } CGEN_OPERAND_TYPE; 228 1.1 skrll 229 1.1 skrll /* Number of operands types. */ 230 1.1 skrll #define MAX_OPERANDS 28 231 1.1 skrll 232 1.1 skrll /* Maximum number of operands referenced by any insn. */ 233 1.1 skrll #define MAX_OPERAND_INSTANCES 11 234 1.1 skrll 235 1.1 skrll /* Insn attribute indices. */ 236 1.1 skrll 237 1.1 skrll /* Enum declaration for cgen_insn attrs. */ 238 1.1 skrll typedef enum cgen_insn_attr { 239 1.1 skrll CGEN_INSN_ALIAS, CGEN_INSN_VIRTUAL, CGEN_INSN_UNCOND_CTI, CGEN_INSN_COND_CTI 240 1.1 skrll , CGEN_INSN_SKIP_CTI, CGEN_INSN_DELAY_SLOT, CGEN_INSN_RELAXABLE, CGEN_INSN_RELAXED 241 1.1 skrll , CGEN_INSN_NO_DIS, CGEN_INSN_PBB, CGEN_INSN_FILL_SLOT, CGEN_INSN_SPECIAL 242 1.1 skrll , CGEN_INSN_SPECIAL_M32R, CGEN_INSN_SPECIAL_FLOAT, CGEN_INSN_END_BOOLS, CGEN_INSN_START_NBOOLS = 31 243 1.1 skrll , CGEN_INSN_MACH, CGEN_INSN_PIPE, CGEN_INSN_END_NBOOLS 244 1.1 skrll } CGEN_INSN_ATTR; 245 1.1 skrll 246 1.1 skrll /* Number of non-boolean elements in cgen_insn_attr. */ 247 1.1 skrll #define CGEN_INSN_NBOOL_ATTRS (CGEN_INSN_END_NBOOLS - CGEN_INSN_START_NBOOLS - 1) 248 1.1 skrll 249 1.1 skrll /* cgen_insn attribute accessor macros. */ 250 1.1 skrll #define CGEN_ATTR_CGEN_INSN_MACH_VALUE(attrs) ((attrs)->nonbool[CGEN_INSN_MACH-CGEN_INSN_START_NBOOLS-1].nonbitset) 251 1.1 skrll #define CGEN_ATTR_CGEN_INSN_PIPE_VALUE(attrs) ((attrs)->nonbool[CGEN_INSN_PIPE-CGEN_INSN_START_NBOOLS-1].nonbitset) 252 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_ALIAS_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_ALIAS)) != 0) 253 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_VIRTUAL_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_VIRTUAL)) != 0) 254 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_UNCOND_CTI_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_UNCOND_CTI)) != 0) 255 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_COND_CTI_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_COND_CTI)) != 0) 256 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_SKIP_CTI_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_SKIP_CTI)) != 0) 257 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_DELAY_SLOT_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_DELAY_SLOT)) != 0) 258 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_RELAXABLE_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_RELAXABLE)) != 0) 259 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_RELAXED_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_RELAXED)) != 0) 260 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_NO_DIS_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_NO_DIS)) != 0) 261 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_PBB_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_PBB)) != 0) 262 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_FILL_SLOT_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_FILL_SLOT)) != 0) 263 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_SPECIAL_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_SPECIAL)) != 0) 264 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_SPECIAL_M32R_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_SPECIAL_M32R)) != 0) 265 1.1.1.2 christos #define CGEN_ATTR_CGEN_INSN_SPECIAL_FLOAT_VALUE(attrs) (((attrs)->bool_ & (1 << CGEN_INSN_SPECIAL_FLOAT)) != 0) 266 1.1 skrll 267 1.1 skrll /* cgen.h uses things we just defined. */ 268 1.1 skrll #include "opcode/cgen.h" 269 1.1 skrll 270 1.1 skrll extern const struct cgen_ifld m32r_cgen_ifld_table[]; 271 1.1 skrll 272 1.1 skrll /* Attributes. */ 273 1.1 skrll extern const CGEN_ATTR_TABLE m32r_cgen_hardware_attr_table[]; 274 1.1 skrll extern const CGEN_ATTR_TABLE m32r_cgen_ifield_attr_table[]; 275 1.1 skrll extern const CGEN_ATTR_TABLE m32r_cgen_operand_attr_table[]; 276 1.1 skrll extern const CGEN_ATTR_TABLE m32r_cgen_insn_attr_table[]; 277 1.1 skrll 278 1.1 skrll /* Hardware decls. */ 279 1.1 skrll 280 1.1 skrll extern CGEN_KEYWORD m32r_cgen_opval_gr_names; 281 1.1 skrll extern CGEN_KEYWORD m32r_cgen_opval_cr_names; 282 1.1 skrll extern CGEN_KEYWORD m32r_cgen_opval_h_accums; 283 1.1 skrll 284 1.1 skrll extern const CGEN_HW_ENTRY m32r_cgen_hw_table[]; 285 1.1 skrll 286 1.1 skrll 287 1.1 skrll 288 1.1.1.5 christos #ifdef __cplusplus 289 1.1.1.5 christos } 290 1.1.1.5 christos #endif 291 1.1.1.5 christos 292 1.1 skrll #endif /* M32R_CPU_H */ 293