| /* Simulator instruction decoder for fr30bf. |
| |
| THIS FILE IS MACHINE GENERATED WITH CGEN. |
| |
| Copyright (C) 1996, 1997, 1998, 1999 Free Software Foundation, Inc. |
| |
| This file is part of the GNU Simulators. |
| |
| This program is free software; you can redistribute it and/or modify |
| it under the terms of the GNU General Public License as published by |
| the Free Software Foundation; either version 2, or (at your option) |
| any later version. |
| |
| This program is distributed in the hope that it will be useful, |
| but WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| GNU General Public License for more details. |
| |
| You should have received a copy of the GNU General Public License along |
| with this program; if not, write to the Free Software Foundation, Inc., |
| 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
| |
| */ |
| |
| #define WANT_CPU fr30bf |
| #define WANT_CPU_FR30BF |
| |
| #include "sim-main.h" |
| #include "sim-assert.h" |
| |
| /* FIXME: Need to review choices for the following. */ |
| |
| #if WITH_SEM_SWITCH_FULL |
| #define FULL(fn) |
| #else |
| #define FULL(fn) CONCAT3 (fr30bf,_sem_,fn) , |
| #endif |
| |
| #if WITH_FAST |
| #if WITH_SEM_SWITCH_FAST |
| #define FAST(fn) |
| #else |
| #define FAST(fn) CONCAT3 (fr30bf,_semf_,fn) , /* f for fast */ |
| #endif |
| #else |
| #define FAST(fn) |
| #endif |
| |
| /* The INSN_ prefix is not here and is instead part of the `insn' argument |
| to avoid collisions with header files (e.g. `AND' in ansidecl.h). */ |
| #define IDX(insn) CONCAT2 (FR30BF_,insn) |
| #define TYPE(insn) CONCAT2 (FR30_,insn) |
| |
| /* The instruction descriptor array. |
| This is computed at runtime. Space for it is not malloc'd to save a |
| teensy bit of cpu in the decoder. Moving it to malloc space is trivial |
| but won't be done until necessary (we don't currently support the runtime |
| addition of instructions nor an SMP machine with different cpus). */ |
| static IDESC fr30bf_insn_data[FR30BF_INSN_MAX]; |
| |
| /* Commas between elements are contained in the macros. |
| Some of these are conditionally compiled out. */ |
| |
| static const struct insn_sem fr30bf_insn_sem[] = |
| { |
| { VIRTUAL_INSN_X_INVALID, IDX (INSN_X_INVALID), FULL (x_invalid) FAST (x_invalid) }, |
| { VIRTUAL_INSN_X_AFTER, IDX (INSN_X_AFTER), FULL (x_after) FAST (x_after) }, |
| { VIRTUAL_INSN_X_BEFORE, IDX (INSN_X_BEFORE), FULL (x_before) FAST (x_before) }, |
| { VIRTUAL_INSN_X_CTI_CHAIN, IDX (INSN_X_CTI_CHAIN), FULL (x_cti_chain) FAST (x_cti_chain) }, |
| { VIRTUAL_INSN_X_CHAIN, IDX (INSN_X_CHAIN), FULL (x_chain) FAST (x_chain) }, |
| { VIRTUAL_INSN_X_BEGIN, IDX (INSN_X_BEGIN), FULL (x_begin) FAST (x_begin) }, |
| { TYPE (INSN_ADD), IDX (INSN_ADD), FULL (add) FAST (add) }, |
| { TYPE (INSN_ADDI), IDX (INSN_ADDI), FULL (addi) FAST (addi) }, |
| { TYPE (INSN_ADD2), IDX (INSN_ADD2), FULL (add2) FAST (add2) }, |
| { TYPE (INSN_ADDC), IDX (INSN_ADDC), FULL (addc) FAST (addc) }, |
| { TYPE (INSN_ADDN), IDX (INSN_ADDN), FULL (addn) FAST (addn) }, |
| { TYPE (INSN_ADDNI), IDX (INSN_ADDNI), FULL (addni) FAST (addni) }, |
| { TYPE (INSN_ADDN2), IDX (INSN_ADDN2), FULL (addn2) FAST (addn2) }, |
| { TYPE (INSN_SUB), IDX (INSN_SUB), FULL (sub) FAST (sub) }, |
| { TYPE (INSN_SUBC), IDX (INSN_SUBC), FULL (subc) FAST (subc) }, |
| { TYPE (INSN_SUBN), IDX (INSN_SUBN), FULL (subn) FAST (subn) }, |
| { TYPE (INSN_CMP), IDX (INSN_CMP), FULL (cmp) FAST (cmp) }, |
| { TYPE (INSN_CMPI), IDX (INSN_CMPI), FULL (cmpi) FAST (cmpi) }, |
| { TYPE (INSN_CMP2), IDX (INSN_CMP2), FULL (cmp2) FAST (cmp2) }, |
| { TYPE (INSN_AND), IDX (INSN_AND), FULL (and) FAST (and) }, |
| { TYPE (INSN_OR), IDX (INSN_OR), FULL (or) FAST (or) }, |
| { TYPE (INSN_EOR), IDX (INSN_EOR), FULL (eor) FAST (eor) }, |
| { TYPE (INSN_ANDM), IDX (INSN_ANDM), FULL (andm) FAST (andm) }, |
| { TYPE (INSN_ANDH), IDX (INSN_ANDH), FULL (andh) FAST (andh) }, |
| { TYPE (INSN_ANDB), IDX (INSN_ANDB), FULL (andb) FAST (andb) }, |
| { TYPE (INSN_ORM), IDX (INSN_ORM), FULL (orm) FAST (orm) }, |
| { TYPE (INSN_ORH), IDX (INSN_ORH), FULL (orh) FAST (orh) }, |
| { TYPE (INSN_ORB), IDX (INSN_ORB), FULL (orb) FAST (orb) }, |
| { TYPE (INSN_EORM), IDX (INSN_EORM), FULL (eorm) FAST (eorm) }, |
| { TYPE (INSN_EORH), IDX (INSN_EORH), FULL (eorh) FAST (eorh) }, |
| { TYPE (INSN_EORB), IDX (INSN_EORB), FULL (eorb) FAST (eorb) }, |
| { TYPE (INSN_BANDL), IDX (INSN_BANDL), FULL (bandl) FAST (bandl) }, |
| { TYPE (INSN_BORL), IDX (INSN_BORL), FULL (borl) FAST (borl) }, |
| { TYPE (INSN_BEORL), IDX (INSN_BEORL), FULL (beorl) FAST (beorl) }, |
| { TYPE (INSN_BANDH), IDX (INSN_BANDH), FULL (bandh) FAST (bandh) }, |
| { TYPE (INSN_BORH), IDX (INSN_BORH), FULL (borh) FAST (borh) }, |
| { TYPE (INSN_BEORH), IDX (INSN_BEORH), FULL (beorh) FAST (beorh) }, |
| { TYPE (INSN_BTSTL), IDX (INSN_BTSTL), FULL (btstl) FAST (btstl) }, |
| { TYPE (INSN_BTSTH), IDX (INSN_BTSTH), FULL (btsth) FAST (btsth) }, |
| { TYPE (INSN_MUL), IDX (INSN_MUL), FULL (mul) FAST (mul) }, |
| { TYPE (INSN_MULU), IDX (INSN_MULU), FULL (mulu) FAST (mulu) }, |
| { TYPE (INSN_MULH), IDX (INSN_MULH), FULL (mulh) FAST (mulh) }, |
| { TYPE (INSN_MULUH), IDX (INSN_MULUH), FULL (muluh) FAST (muluh) }, |
| { TYPE (INSN_DIV0S), IDX (INSN_DIV0S), FULL (div0s) FAST (div0s) }, |
| { TYPE (INSN_DIV0U), IDX (INSN_DIV0U), FULL (div0u) FAST (div0u) }, |
| { TYPE (INSN_DIV1), IDX (INSN_DIV1), FULL (div1) FAST (div1) }, |
| { TYPE (INSN_DIV2), IDX (INSN_DIV2), FULL (div2) FAST (div2) }, |
| { TYPE (INSN_DIV3), IDX (INSN_DIV3), FULL (div3) FAST (div3) }, |
| { TYPE (INSN_DIV4S), IDX (INSN_DIV4S), FULL (div4s) FAST (div4s) }, |
| { TYPE (INSN_LSL), IDX (INSN_LSL), FULL (lsl) FAST (lsl) }, |
| { TYPE (INSN_LSLI), IDX (INSN_LSLI), FULL (lsli) FAST (lsli) }, |
| { TYPE (INSN_LSL2), IDX (INSN_LSL2), FULL (lsl2) FAST (lsl2) }, |
| { TYPE (INSN_LSR), IDX (INSN_LSR), FULL (lsr) FAST (lsr) }, |
| { TYPE (INSN_LSRI), IDX (INSN_LSRI), FULL (lsri) FAST (lsri) }, |
| { TYPE (INSN_LSR2), IDX (INSN_LSR2), FULL (lsr2) FAST (lsr2) }, |
| { TYPE (INSN_ASR), IDX (INSN_ASR), FULL (asr) FAST (asr) }, |
| { TYPE (INSN_ASRI), IDX (INSN_ASRI), FULL (asri) FAST (asri) }, |
| { TYPE (INSN_ASR2), IDX (INSN_ASR2), FULL (asr2) FAST (asr2) }, |
| { TYPE (INSN_LDI8), IDX (INSN_LDI8), FULL (ldi8) FAST (ldi8) }, |
| { TYPE (INSN_LDI20), IDX (INSN_LDI20), FULL (ldi20) FAST (ldi20) }, |
| { TYPE (INSN_LDI32), IDX (INSN_LDI32), FULL (ldi32) FAST (ldi32) }, |
| { TYPE (INSN_LD), IDX (INSN_LD), FULL (ld) FAST (ld) }, |
| { TYPE (INSN_LDUH), IDX (INSN_LDUH), FULL (lduh) FAST (lduh) }, |
| { TYPE (INSN_LDUB), IDX (INSN_LDUB), FULL (ldub) FAST (ldub) }, |
| { TYPE (INSN_LDR13), IDX (INSN_LDR13), FULL (ldr13) FAST (ldr13) }, |
| { TYPE (INSN_LDR13UH), IDX (INSN_LDR13UH), FULL (ldr13uh) FAST (ldr13uh) }, |
| { TYPE (INSN_LDR13UB), IDX (INSN_LDR13UB), FULL (ldr13ub) FAST (ldr13ub) }, |
| { TYPE (INSN_LDR14), IDX (INSN_LDR14), FULL (ldr14) FAST (ldr14) }, |
| { TYPE (INSN_LDR14UH), IDX (INSN_LDR14UH), FULL (ldr14uh) FAST (ldr14uh) }, |
| { TYPE (INSN_LDR14UB), IDX (INSN_LDR14UB), FULL (ldr14ub) FAST (ldr14ub) }, |
| { TYPE (INSN_LDR15), IDX (INSN_LDR15), FULL (ldr15) FAST (ldr15) }, |
| { TYPE (INSN_LDR15GR), IDX (INSN_LDR15GR), FULL (ldr15gr) FAST (ldr15gr) }, |
| { TYPE (INSN_LDR15DR), IDX (INSN_LDR15DR), FULL (ldr15dr) FAST (ldr15dr) }, |
| { TYPE (INSN_LDR15PS), IDX (INSN_LDR15PS), FULL (ldr15ps) FAST (ldr15ps) }, |
| { TYPE (INSN_ST), IDX (INSN_ST), FULL (st) FAST (st) }, |
| { TYPE (INSN_STH), IDX (INSN_STH), FULL (sth) FAST (sth) }, |
| { TYPE (INSN_STB), IDX (INSN_STB), FULL (stb) FAST (stb) }, |
| { TYPE (INSN_STR13), IDX (INSN_STR13), FULL (str13) FAST (str13) }, |
| { TYPE (INSN_STR13H), IDX (INSN_STR13H), FULL (str13h) FAST (str13h) }, |
| { TYPE (INSN_STR13B), IDX (INSN_STR13B), FULL (str13b) FAST (str13b) }, |
| { TYPE (INSN_STR14), IDX (INSN_STR14), FULL (str14) FAST (str14) }, |
| { TYPE (INSN_STR14H), IDX (INSN_STR14H), FULL (str14h) FAST (str14h) }, |
| { TYPE (INSN_STR14B), IDX (INSN_STR14B), FULL (str14b) FAST (str14b) }, |
| { TYPE (INSN_STR15), IDX (INSN_STR15), FULL (str15) FAST (str15) }, |
| { TYPE (INSN_STR15GR), IDX (INSN_STR15GR), FULL (str15gr) FAST (str15gr) }, |
| { TYPE (INSN_STR15DR), IDX (INSN_STR15DR), FULL (str15dr) FAST (str15dr) }, |
| { TYPE (INSN_STR15PS), IDX (INSN_STR15PS), FULL (str15ps) FAST (str15ps) }, |
| { TYPE (INSN_MOV), IDX (INSN_MOV), FULL (mov) FAST (mov) }, |
| { TYPE (INSN_MOVDR), IDX (INSN_MOVDR), FULL (movdr) FAST (movdr) }, |
| { TYPE (INSN_MOVPS), IDX (INSN_MOVPS), FULL (movps) FAST (movps) }, |
| { TYPE (INSN_MOV2DR), IDX (INSN_MOV2DR), FULL (mov2dr) FAST (mov2dr) }, |
| { TYPE (INSN_MOV2PS), IDX (INSN_MOV2PS), FULL (mov2ps) FAST (mov2ps) }, |
| { TYPE (INSN_JMP), IDX (INSN_JMP), FULL (jmp) FAST (jmp) }, |
| { TYPE (INSN_JMPD), IDX (INSN_JMPD), FULL (jmpd) FAST (jmpd) }, |
| { TYPE (INSN_CALLR), IDX (INSN_CALLR), FULL (callr) FAST (callr) }, |
| { TYPE (INSN_CALLRD), IDX (INSN_CALLRD), FULL (callrd) FAST (callrd) }, |
| { TYPE (INSN_CALL), IDX (INSN_CALL), FULL (call) FAST (call) }, |
| { TYPE (INSN_CALLD), IDX (INSN_CALLD), FULL (calld) FAST (calld) }, |
| { TYPE (INSN_RET), IDX (INSN_RET), FULL (ret) FAST (ret) }, |
| { TYPE (INSN_RET_D), IDX (INSN_RET_D), FULL (ret_d) FAST (ret_d) }, |
| { TYPE (INSN_INT), IDX (INSN_INT), FULL (int) FAST (int) }, |
| { TYPE (INSN_INTE), IDX (INSN_INTE), FULL (inte) FAST (inte) }, |
| { TYPE (INSN_RETI), IDX (INSN_RETI), FULL (reti) FAST (reti) }, |
| { TYPE (INSN_BRAD), IDX (INSN_BRAD), FULL (brad) FAST (brad) }, |
| { TYPE (INSN_BRA), IDX (INSN_BRA), FULL (bra) FAST (bra) }, |
| { TYPE (INSN_BNOD), IDX (INSN_BNOD), FULL (bnod) FAST (bnod) }, |
| { TYPE (INSN_BNO), IDX (INSN_BNO), FULL (bno) FAST (bno) }, |
| { TYPE (INSN_BEQD), IDX (INSN_BEQD), FULL (beqd) FAST (beqd) }, |
| { TYPE (INSN_BEQ), IDX (INSN_BEQ), FULL (beq) FAST (beq) }, |
| { TYPE (INSN_BNED), IDX (INSN_BNED), FULL (bned) FAST (bned) }, |
| { TYPE (INSN_BNE), IDX (INSN_BNE), FULL (bne) FAST (bne) }, |
| { TYPE (INSN_BCD), IDX (INSN_BCD), FULL (bcd) FAST (bcd) }, |
| { TYPE (INSN_BC), IDX (INSN_BC), FULL (bc) FAST (bc) }, |
| { TYPE (INSN_BNCD), IDX (INSN_BNCD), FULL (bncd) FAST (bncd) }, |
| { TYPE (INSN_BNC), IDX (INSN_BNC), FULL (bnc) FAST (bnc) }, |
| { TYPE (INSN_BND), IDX (INSN_BND), FULL (bnd) FAST (bnd) }, |
| { TYPE (INSN_BN), IDX (INSN_BN), FULL (bn) FAST (bn) }, |
| { TYPE (INSN_BPD), IDX (INSN_BPD), FULL (bpd) FAST (bpd) }, |
| { TYPE (INSN_BP), IDX (INSN_BP), FULL (bp) FAST (bp) }, |
| { TYPE (INSN_BVD), IDX (INSN_BVD), FULL (bvd) FAST (bvd) }, |
| { TYPE (INSN_BV), IDX (INSN_BV), FULL (bv) FAST (bv) }, |
| { TYPE (INSN_BNVD), IDX (INSN_BNVD), FULL (bnvd) FAST (bnvd) }, |
| { TYPE (INSN_BNV), IDX (INSN_BNV), FULL (bnv) FAST (bnv) }, |
| { TYPE (INSN_BLTD), IDX (INSN_BLTD), FULL (bltd) FAST (bltd) }, |
| { TYPE (INSN_BLT), IDX (INSN_BLT), FULL (blt) FAST (blt) }, |
| { TYPE (INSN_BGED), IDX (INSN_BGED), FULL (bged) FAST (bged) }, |
| { TYPE (INSN_BGE), IDX (INSN_BGE), FULL (bge) FAST (bge) }, |
| { TYPE (INSN_BLED), IDX (INSN_BLED), FULL (bled) FAST (bled) }, |
| { TYPE (INSN_BLE), IDX (INSN_BLE), FULL (ble) FAST (ble) }, |
| { TYPE (INSN_BGTD), IDX (INSN_BGTD), FULL (bgtd) FAST (bgtd) }, |
| { TYPE (INSN_BGT), IDX (INSN_BGT), FULL (bgt) FAST (bgt) }, |
| { TYPE (INSN_BLSD), IDX (INSN_BLSD), FULL (blsd) FAST (blsd) }, |
| { TYPE (INSN_BLS), IDX (INSN_BLS), FULL (bls) FAST (bls) }, |
| { TYPE (INSN_BHID), IDX (INSN_BHID), FULL (bhid) FAST (bhid) }, |
| { TYPE (INSN_BHI), IDX (INSN_BHI), FULL (bhi) FAST (bhi) }, |
| { TYPE (INSN_DMOVR13), IDX (INSN_DMOVR13), FULL (dmovr13) FAST (dmovr13) }, |
| { TYPE (INSN_DMOVR13H), IDX (INSN_DMOVR13H), FULL (dmovr13h) FAST (dmovr13h) }, |
| { TYPE (INSN_DMOVR13B), IDX (INSN_DMOVR13B), FULL (dmovr13b) FAST (dmovr13b) }, |
| { TYPE (INSN_DMOVR13PI), IDX (INSN_DMOVR13PI), FULL (dmovr13pi) FAST (dmovr13pi) }, |
| { TYPE (INSN_DMOVR13PIH), IDX (INSN_DMOVR13PIH), FULL (dmovr13pih) FAST (dmovr13pih) }, |
| { TYPE (INSN_DMOVR13PIB), IDX (INSN_DMOVR13PIB), FULL (dmovr13pib) FAST (dmovr13pib) }, |
| { TYPE (INSN_DMOVR15PI), IDX (INSN_DMOVR15PI), FULL (dmovr15pi) FAST (dmovr15pi) }, |
| { TYPE (INSN_DMOV2R13), IDX (INSN_DMOV2R13), FULL (dmov2r13) FAST (dmov2r13) }, |
| { TYPE (INSN_DMOV2R13H), IDX (INSN_DMOV2R13H), FULL (dmov2r13h) FAST (dmov2r13h) }, |
| { TYPE (INSN_DMOV2R13B), IDX (INSN_DMOV2R13B), FULL (dmov2r13b) FAST (dmov2r13b) }, |
| { TYPE (INSN_DMOV2R13PI), IDX (INSN_DMOV2R13PI), FULL (dmov2r13pi) FAST (dmov2r13pi) }, |
| { TYPE (INSN_DMOV2R13PIH), IDX (INSN_DMOV2R13PIH), FULL (dmov2r13pih) FAST (dmov2r13pih) }, |
| { TYPE (INSN_DMOV2R13PIB), IDX (INSN_DMOV2R13PIB), FULL (dmov2r13pib) FAST (dmov2r13pib) }, |
| { TYPE (INSN_DMOV2R15PD), IDX (INSN_DMOV2R15PD), FULL (dmov2r15pd) FAST (dmov2r15pd) }, |
| { TYPE (INSN_LDRES), IDX (INSN_LDRES), FULL (ldres) FAST (ldres) }, |
| { TYPE (INSN_STRES), IDX (INSN_STRES), FULL (stres) FAST (stres) }, |
| { TYPE (INSN_COPOP), IDX (INSN_COPOP), FULL (copop) FAST (copop) }, |
| { TYPE (INSN_COPLD), IDX (INSN_COPLD), FULL (copld) FAST (copld) }, |
| { TYPE (INSN_COPST), IDX (INSN_COPST), FULL (copst) FAST (copst) }, |
| { TYPE (INSN_COPSV), IDX (INSN_COPSV), FULL (copsv) FAST (copsv) }, |
| { TYPE (INSN_NOP), IDX (INSN_NOP), FULL (nop) FAST (nop) }, |
| { TYPE (INSN_ANDCCR), IDX (INSN_ANDCCR), FULL (andccr) FAST (andccr) }, |
| { TYPE (INSN_ORCCR), IDX (INSN_ORCCR), FULL (orccr) FAST (orccr) }, |
| { TYPE (INSN_STILM), IDX (INSN_STILM), FULL (stilm) FAST (stilm) }, |
| { TYPE (INSN_ADDSP), IDX (INSN_ADDSP), FULL (addsp) FAST (addsp) }, |
| { TYPE (INSN_EXTSB), IDX (INSN_EXTSB), FULL (extsb) FAST (extsb) }, |
| { TYPE (INSN_EXTUB), IDX (INSN_EXTUB), FULL (extub) FAST (extub) }, |
| { TYPE (INSN_EXTSH), IDX (INSN_EXTSH), FULL (extsh) FAST (extsh) }, |
| { TYPE (INSN_EXTUH), IDX (INSN_EXTUH), FULL (extuh) FAST (extuh) }, |
| { TYPE (INSN_LDM0), IDX (INSN_LDM0), FULL (ldm0) FAST (ldm0) }, |
| { TYPE (INSN_LDM1), IDX (INSN_LDM1), FULL (ldm1) FAST (ldm1) }, |
| { TYPE (INSN_STM0), IDX (INSN_STM0), FULL (stm0) FAST (stm0) }, |
| { TYPE (INSN_STM1), IDX (INSN_STM1), FULL (stm1) FAST (stm1) }, |
| { TYPE (INSN_ENTER), IDX (INSN_ENTER), FULL (enter) FAST (enter) }, |
| { TYPE (INSN_LEAVE), IDX (INSN_LEAVE), FULL (leave) FAST (leave) }, |
| { TYPE (INSN_XCHB), IDX (INSN_XCHB), FULL (xchb) FAST (xchb) }, |
| }; |
| |
| static const struct insn_sem fr30bf_insn_sem_invalid = |
| { |
| VIRTUAL_INSN_X_INVALID, IDX (INSN_X_INVALID), FULL (x_invalid) FAST (x_invalid) |
| }; |
| |
| #undef FMT |
| #undef FULL |
| #undef FAST |
| #undef IDX |
| #undef TYPE |
| |
| /* Initialize an IDESC from the compile-time computable parts. */ |
| |
| static INLINE void |
| init_idesc (SIM_CPU *cpu, IDESC *id, const struct insn_sem *t) |
| { |
| const CGEN_INSN *insn_table = CGEN_CPU_INSN_TABLE (CPU_CPU_DESC (cpu))->init_entries; |
| |
| id->num = t->index; |
| if ((int) t->type <= 0) |
| id->idata = & cgen_virtual_insn_table[- (int) t->type]; |
| else |
| id->idata = & insn_table[t->type]; |
| id->attrs = CGEN_INSN_ATTRS (id->idata); |
| /* Oh my god, a magic number. */ |
| id->length = CGEN_INSN_BITSIZE (id->idata) / 8; |
| #if ! WITH_SEM_SWITCH_FULL |
| id->sem_full = t->sem_full; |
| #endif |
| #if WITH_FAST && ! WITH_SEM_SWITCH_FAST |
| id->sem_fast = t->sem_fast; |
| #endif |
| #if WITH_PROFILE_MODEL_P |
| id->timing = & MODEL_TIMING (CPU_MODEL (cpu)) [t->index]; |
| { |
| SIM_DESC sd = CPU_STATE (cpu); |
| SIM_ASSERT (t->index == id->timing->num); |
| } |
| #endif |
| } |
| |
| /* Initialize the instruction descriptor table. */ |
| |
| void |
| fr30bf_init_idesc_table (SIM_CPU *cpu) |
| { |
| IDESC *id,*tabend; |
| const struct insn_sem *t,*tend; |
| int tabsize = FR30BF_INSN_MAX; |
| IDESC *table = fr30bf_insn_data; |
| |
| memset (table, 0, tabsize * sizeof (IDESC)); |
| |
| /* First set all entries to the `invalid insn'. */ |
| t = & fr30bf_insn_sem_invalid; |
| for (id = table, tabend = table + tabsize; id < tabend; ++id) |
| init_idesc (cpu, id, t); |
| |
| /* Now fill in the values for the chosen cpu. */ |
| for (t = fr30bf_insn_sem, tend = t + sizeof (fr30bf_insn_sem) / sizeof (*t); |
| t != tend; ++t) |
| { |
| init_idesc (cpu, & table[t->index], t); |
| } |
| |
| /* Link the IDESC table into the cpu. */ |
| CPU_IDESC (cpu) = table; |
| } |
| |
| /* Given an instruction, return a pointer to its IDESC entry. */ |
| |
| const IDESC * |
| fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, |
| CGEN_INSN_INT base_insn, |
| ARGBUF *abuf) |
| { |
| /* Result of decoder. */ |
| FR30BF_INSN_TYPE itype; |
| |
| { |
| CGEN_INSN_INT insn = base_insn; |
| |
| { |
| unsigned int val = (((insn >> 8) & (255 << 0))); |
| switch (val) |
| { |
| case 0 : itype = FR30BF_INSN_LDR13; goto extract_fmt_ldr13; |
| case 1 : itype = FR30BF_INSN_LDR13UH; goto extract_fmt_ldr13uh; |
| case 2 : itype = FR30BF_INSN_LDR13UB; goto extract_fmt_ldr13ub; |
| case 3 : itype = FR30BF_INSN_LDR15; goto extract_fmt_ldr15; |
| case 4 : itype = FR30BF_INSN_LD; goto extract_fmt_ld; |
| case 5 : itype = FR30BF_INSN_LDUH; goto extract_fmt_lduh; |
| case 6 : itype = FR30BF_INSN_LDUB; goto extract_fmt_ldub; |
| case 7 : |
| { |
| unsigned int val = (((insn >> 4) & (15 << 0))); |
| switch (val) |
| { |
| case 0 : itype = FR30BF_INSN_LDR15GR; goto extract_fmt_ldr15gr; |
| case 1 : itype = FR30BF_INSN_MOV2PS; goto extract_fmt_mov2ps; |
| case 8 : itype = FR30BF_INSN_LDR15DR; goto extract_fmt_ldr15dr; |
| case 9 : itype = FR30BF_INSN_LDR15PS; goto extract_fmt_ldr15ps; |
| default : itype = FR30BF_INSN_X_INVALID; goto extract_fmt_empty; |
| } |
| } |
| case 8 : itype = FR30BF_INSN_DMOV2R13; goto extract_fmt_dmov2r13; |
| case 9 : itype = FR30BF_INSN_DMOV2R13H; goto extract_fmt_dmov2r13h; |
| case 10 : itype = FR30BF_INSN_DMOV2R13B; goto extract_fmt_dmov2r13b; |
| case 11 : itype = FR30BF_INSN_DMOV2R15PD; goto extract_fmt_dmov2r15pd; |
| case 12 : itype = FR30BF_INSN_DMOV2R13PI; goto extract_fmt_dmov2r13pi; |
| case 13 : itype = FR30BF_INSN_DMOV2R13PIH; goto extract_fmt_dmov2r13pih; |
| case 14 : itype = FR30BF_INSN_DMOV2R13PIB; goto extract_fmt_dmov2r13pib; |
| case 15 : itype = FR30BF_INSN_ENTER; goto extract_fmt_enter; |
| case 16 : itype = FR30BF_INSN_STR13; goto extract_fmt_str13; |
| case 17 : itype = FR30BF_INSN_STR13H; goto extract_fmt_str13h; |
| case 18 : itype = FR30BF_INSN_STR13B; goto extract_fmt_str13b; |
| case 19 : itype = FR30BF_INSN_STR15; goto extract_fmt_str15; |
| case 20 : itype = FR30BF_INSN_ST; goto extract_fmt_st; |
| case 21 : itype = FR30BF_INSN_STH; goto extract_fmt_sth; |
| case 22 : itype = FR30BF_INSN_STB; goto extract_fmt_stb; |
| case 23 : |
| { |
| unsigned int val = (((insn >> 4) & (15 << 0))); |
| switch (val) |
| { |
| case 0 : itype = FR30BF_INSN_STR15GR; goto extract_fmt_str15gr; |
| case 1 : itype = FR30BF_INSN_MOVPS; goto extract_fmt_movps; |
| case 8 : itype = FR30BF_INSN_STR15DR; goto extract_fmt_str15dr; |
| case 9 : itype = FR30BF_INSN_STR15PS; goto extract_fmt_str15ps; |
| default : itype = FR30BF_INSN_X_INVALID; goto extract_fmt_empty; |
| } |
| } |
| case 24 : itype = FR30BF_INSN_DMOVR13; goto extract_fmt_dmovr13; |
| case 25 : itype = FR30BF_INSN_DMOVR13H; goto extract_fmt_dmovr13h; |
| case 26 : itype = FR30BF_INSN_DMOVR13B; goto extract_fmt_dmovr13b; |
| case 27 : itype = FR30BF_INSN_DMOVR15PI; goto extract_fmt_dmovr15pi; |
| case 28 : itype = FR30BF_INSN_DMOVR13PI; goto extract_fmt_dmovr13pi; |
| case 29 : itype = FR30BF_INSN_DMOVR13PIH; goto extract_fmt_dmovr13pih; |
| case 30 : itype = FR30BF_INSN_DMOVR13PIB; goto extract_fmt_dmovr13pib; |
| case 31 : itype = FR30BF_INSN_INT; goto extract_fmt_int; |
| case 32 : /* fall through */ |
| case 33 : /* fall through */ |
| case 34 : /* fall through */ |
| case 35 : /* fall through */ |
| case 36 : /* fall through */ |
| case 37 : /* fall through */ |
| case 38 : /* fall through */ |
| case 39 : /* fall through */ |
| case 40 : /* fall through */ |
| case 41 : /* fall through */ |
| case 42 : /* fall through */ |
| case 43 : /* fall through */ |
| case 44 : /* fall through */ |
| case 45 : /* fall through */ |
| case 46 : /* fall through */ |
| case 47 : itype = FR30BF_INSN_LDR14; goto extract_fmt_ldr14; |
| case 48 : /* fall through */ |
| case 49 : /* fall through */ |
| case 50 : /* fall through */ |
| case 51 : /* fall through */ |
| case 52 : /* fall through */ |
| case 53 : /* fall through */ |
| case 54 : /* fall through */ |
| case 55 : /* fall through */ |
| case 56 : /* fall through */ |
| case 57 : /* fall through */ |
| case 58 : /* fall through */ |
| case 59 : /* fall through */ |
| case 60 : /* fall through */ |
| case 61 : /* fall through */ |
| case 62 : /* fall through */ |
| case 63 : itype = FR30BF_INSN_STR14; goto extract_fmt_str14; |
| case 64 : /* fall through */ |
| case 65 : /* fall through */ |
| case 66 : /* fall through */ |
| case 67 : /* fall through */ |
| case 68 : /* fall through */ |
| case 69 : /* fall through */ |
| case 70 : /* fall through */ |
| case 71 : /* fall through */ |
| case 72 : /* fall through */ |
| case 73 : /* fall through */ |
| case 74 : /* fall through */ |
| case 75 : /* fall through */ |
| case 76 : /* fall through */ |
| case 77 : /* fall through */ |
| case 78 : /* fall through */ |
| case 79 : itype = FR30BF_INSN_LDR14UH; goto extract_fmt_ldr14uh; |
| case 80 : /* fall through */ |
| case 81 : /* fall through */ |
| case 82 : /* fall through */ |
| case 83 : /* fall through */ |
| case 84 : /* fall through */ |
| case 85 : /* fall through */ |
| case 86 : /* fall through */ |
| case 87 : /* fall through */ |
| case 88 : /* fall through */ |
| case 89 : /* fall through */ |
| case 90 : /* fall through */ |
| case 91 : /* fall through */ |
| case 92 : /* fall through */ |
| case 93 : /* fall through */ |
| case 94 : /* fall through */ |
| case 95 : itype = FR30BF_INSN_STR14H; goto extract_fmt_str14h; |
| case 96 : /* fall through */ |
| case 97 : /* fall through */ |
| case 98 : /* fall through */ |
| case 99 : /* fall through */ |
| case 100 : /* fall through */ |
| case 101 : /* fall through */ |
| case 102 : /* fall through */ |
| case 103 : /* fall through */ |
| case 104 : /* fall through */ |
| case 105 : /* fall through */ |
| case 106 : /* fall through */ |
| case 107 : /* fall through */ |
| case 108 : /* fall through */ |
| case 109 : /* fall through */ |
| case 110 : /* fall through */ |
| case 111 : itype = FR30BF_INSN_LDR14UB; goto extract_fmt_ldr14ub; |
| case 112 : /* fall through */ |
| case 113 : /* fall through */ |
| case 114 : /* fall through */ |
| case 115 : /* fall through */ |
| case 116 : /* fall through */ |
| case 117 : /* fall through */ |
| case 118 : /* fall through */ |
| case 119 : /* fall through */ |
| case 120 : /* fall through */ |
| case 121 : /* fall through */ |
| case 122 : /* fall through */ |
| case 123 : /* fall through */ |
| case 124 : /* fall through */ |
| case 125 : /* fall through */ |
| case 126 : /* fall through */ |
| case 127 : itype = FR30BF_INSN_STR14B; goto extract_fmt_str14b; |
| case 128 : itype = FR30BF_INSN_BANDL; goto extract_fmt_bandl; |
| case 129 : itype = FR30BF_INSN_BANDH; goto extract_fmt_bandl; |
| case 130 : itype = FR30BF_INSN_AND; goto extract_fmt_and; |
| case 131 : itype = FR30BF_INSN_ANDCCR; goto extract_fmt_andccr; |
| case 132 : itype = FR30BF_INSN_ANDM; goto extract_fmt_andm; |
| case 133 : itype = FR30BF_INSN_ANDH; goto extract_fmt_andh; |
| case 134 : itype = FR30BF_INSN_ANDB; goto extract_fmt_andb; |
| case 135 : itype = FR30BF_INSN_STILM; goto extract_fmt_stilm; |
| case 136 : itype = FR30BF_INSN_BTSTL; goto extract_fmt_btstl; |
| case 137 : itype = FR30BF_INSN_BTSTH; goto extract_fmt_btstl; |
| case 138 : itype = FR30BF_INSN_XCHB; goto extract_fmt_xchb; |
| case 139 : itype = FR30BF_INSN_MOV; goto extract_fmt_mov; |
| case 140 : itype = FR30BF_INSN_LDM0; goto extract_fmt_ldm0; |
| case 141 : itype = FR30BF_INSN_LDM1; goto extract_fmt_ldm1; |
| case 142 : itype = FR30BF_INSN_STM0; goto extract_fmt_stm0; |
| case 143 : itype = FR30BF_INSN_STM1; goto extract_fmt_stm1; |
| case 144 : itype = FR30BF_INSN_BORL; goto extract_fmt_bandl; |
| case 145 : itype = FR30BF_INSN_BORH; goto extract_fmt_bandl; |
| case 146 : itype = FR30BF_INSN_OR; goto extract_fmt_and; |
| case 147 : itype = FR30BF_INSN_ORCCR; goto extract_fmt_andccr; |
| case 148 : itype = FR30BF_INSN_ORM; goto extract_fmt_andm; |
| case 149 : itype = FR30BF_INSN_ORH; goto extract_fmt_andh; |
| case 150 : itype = FR30BF_INSN_ORB; goto extract_fmt_andb; |
| case 151 : |
| { |
| unsigned int val = (((insn >> 4) & (15 << 0))); |
| switch (val) |
| { |
| case 0 : itype = FR30BF_INSN_JMP; goto extract_fmt_jmp; |
| case 1 : itype = FR30BF_INSN_CALLR; goto extract_fmt_callr; |
| case 2 : itype = FR30BF_INSN_RET; goto extract_fmt_ret; |
| case 3 : itype = FR30BF_INSN_RETI; goto extract_fmt_reti; |
| case 4 : itype = FR30BF_INSN_DIV0S; goto extract_fmt_div0s; |
| case 5 : itype = FR30BF_INSN_DIV0U; goto extract_fmt_div0u; |
| case 6 : itype = FR30BF_INSN_DIV1; goto extract_fmt_div1; |
| case 7 : itype = FR30BF_INSN_DIV2; goto extract_fmt_div2; |
| case 8 : itype = FR30BF_INSN_EXTSB; goto extract_fmt_extsb; |
| case 9 : itype = FR30BF_INSN_EXTUB; goto extract_fmt_extub; |
| case 10 : itype = FR30BF_INSN_EXTSH; goto extract_fmt_extsh; |
| case 11 : itype = FR30BF_INSN_EXTUH; goto extract_fmt_extuh; |
| default : itype = FR30BF_INSN_X_INVALID; goto extract_fmt_empty; |
| } |
| } |
| case 152 : itype = FR30BF_INSN_BEORL; goto extract_fmt_bandl; |
| case 153 : itype = FR30BF_INSN_BEORH; goto extract_fmt_bandl; |
| case 154 : itype = FR30BF_INSN_EOR; goto extract_fmt_and; |
| case 155 : itype = FR30BF_INSN_LDI20; goto extract_fmt_ldi20; |
| case 156 : itype = FR30BF_INSN_EORM; goto extract_fmt_andm; |
| case 157 : itype = FR30BF_INSN_EORH; goto extract_fmt_andh; |
| case 158 : itype = FR30BF_INSN_EORB; goto extract_fmt_andb; |
| case 159 : |
| { |
| unsigned int val = (((insn >> 4) & (15 << 0))); |
| switch (val) |
| { |
| case 0 : itype = FR30BF_INSN_JMPD; goto extract_fmt_jmp; |
| case 1 : itype = FR30BF_INSN_CALLRD; goto extract_fmt_callr; |
| case 2 : itype = FR30BF_INSN_RET_D; goto extract_fmt_ret; |
| case 3 : itype = FR30BF_INSN_INTE; goto extract_fmt_inte; |
| case 6 : itype = FR30BF_INSN_DIV3; goto extract_fmt_div3; |
| case 7 : itype = FR30BF_INSN_DIV4S; goto extract_fmt_div4s; |
| case 8 : itype = FR30BF_INSN_LDI32; goto extract_fmt_ldi32; |
| case 9 : itype = FR30BF_INSN_LEAVE; goto extract_fmt_leave; |
| case 10 : itype = FR30BF_INSN_NOP; goto extract_fmt_nop; |
| case 12 : itype = FR30BF_INSN_COPOP; goto extract_fmt_copop; |
| case 13 : itype = FR30BF_INSN_COPLD; goto extract_fmt_copld; |
| case 14 : itype = FR30BF_INSN_COPST; goto extract_fmt_copst; |
| case 15 : itype = FR30BF_INSN_COPSV; goto extract_fmt_copst; |
| default : itype = FR30BF_INSN_X_INVALID; goto extract_fmt_empty; |
| } |
| } |
| case 160 : itype = FR30BF_INSN_ADDNI; goto extract_fmt_addni; |
| case 161 : itype = FR30BF_INSN_ADDN2; goto extract_fmt_addn2; |
| case 162 : itype = FR30BF_INSN_ADDN; goto extract_fmt_addn; |
| case 163 : itype = FR30BF_INSN_ADDSP; goto extract_fmt_addsp; |
| case 164 : itype = FR30BF_INSN_ADDI; goto extract_fmt_addi; |
| case 165 : itype = FR30BF_INSN_ADD2; goto extract_fmt_add2; |
| case 166 : itype = FR30BF_INSN_ADD; goto extract_fmt_add; |
| case 167 : itype = FR30BF_INSN_ADDC; goto extract_fmt_addc; |
| case 168 : itype = FR30BF_INSN_CMPI; goto extract_fmt_cmpi; |
| case 169 : itype = FR30BF_INSN_CMP2; goto extract_fmt_cmp2; |
| case 170 : itype = FR30BF_INSN_CMP; goto extract_fmt_cmp; |
| case 171 : itype = FR30BF_INSN_MULU; goto extract_fmt_mulu; |
| case 172 : itype = FR30BF_INSN_SUB; goto extract_fmt_add; |
| case 173 : itype = FR30BF_INSN_SUBC; goto extract_fmt_addc; |
| case 174 : itype = FR30BF_INSN_SUBN; goto extract_fmt_addn; |
| case 175 : itype = FR30BF_INSN_MUL; goto extract_fmt_mul; |
| case 176 : itype = FR30BF_INSN_LSRI; goto extract_fmt_lsli; |
| case 177 : itype = FR30BF_INSN_LSR2; goto extract_fmt_lsli; |
| case 178 : itype = FR30BF_INSN_LSR; goto extract_fmt_lsl; |
| case 179 : itype = FR30BF_INSN_MOV2DR; goto extract_fmt_mov2dr; |
| case 180 : itype = FR30BF_INSN_LSLI; goto extract_fmt_lsli; |
| case 181 : itype = FR30BF_INSN_LSL2; goto extract_fmt_lsli; |
| case 182 : itype = FR30BF_INSN_LSL; goto extract_fmt_lsl; |
| case 183 : itype = FR30BF_INSN_MOVDR; goto extract_fmt_movdr; |
| case 184 : itype = FR30BF_INSN_ASRI; goto extract_fmt_lsli; |
| case 185 : itype = FR30BF_INSN_ASR2; goto extract_fmt_lsli; |
| case 186 : itype = FR30BF_INSN_ASR; goto extract_fmt_lsl; |
| case 187 : itype = FR30BF_INSN_MULUH; goto extract_fmt_mulh; |
| case 188 : itype = FR30BF_INSN_LDRES; goto extract_fmt_ldres; |
| case 189 : itype = FR30BF_INSN_STRES; goto extract_fmt_ldres; |
| case 191 : itype = FR30BF_INSN_MULH; goto extract_fmt_mulh; |
| case 192 : /* fall through */ |
| case 193 : /* fall through */ |
| case 194 : /* fall through */ |
| case 195 : /* fall through */ |
| case 196 : /* fall through */ |
| case 197 : /* fall through */ |
| case 198 : /* fall through */ |
| case 199 : /* fall through */ |
| case 200 : /* fall through */ |
| case 201 : /* fall through */ |
| case 202 : /* fall through */ |
| case 203 : /* fall through */ |
| case 204 : /* fall through */ |
| case 205 : /* fall through */ |
| case 206 : /* fall through */ |
| case 207 : itype = FR30BF_INSN_LDI8; goto extract_fmt_ldi8; |
| case 208 : /* fall through */ |
| case 209 : /* fall through */ |
| case 210 : /* fall through */ |
| case 211 : /* fall through */ |
| case 212 : /* fall through */ |
| case 213 : /* fall through */ |
| case 214 : /* fall through */ |
| case 215 : itype = FR30BF_INSN_CALL; goto extract_fmt_call; |
| case 216 : /* fall through */ |
| case 217 : /* fall through */ |
| case 218 : /* fall through */ |
| case 219 : /* fall through */ |
| case 220 : /* fall through */ |
| case 221 : /* fall through */ |
| case 222 : /* fall through */ |
| case 223 : itype = FR30BF_INSN_CALLD; goto extract_fmt_call; |
| case 224 : itype = FR30BF_INSN_BRA; goto extract_fmt_brad; |
| case 225 : itype = FR30BF_INSN_BNO; goto extract_fmt_bnod; |
| case 226 : itype = FR30BF_INSN_BEQ; goto extract_fmt_beqd; |
| case 227 : itype = FR30BF_INSN_BNE; goto extract_fmt_beqd; |
| case 228 : itype = FR30BF_INSN_BC; goto extract_fmt_bcd; |
| case 229 : itype = FR30BF_INSN_BNC; goto extract_fmt_bcd; |
| case 230 : itype = FR30BF_INSN_BN; goto extract_fmt_bnd; |
| case 231 : itype = FR30BF_INSN_BP; goto extract_fmt_bnd; |
| case 232 : itype = FR30BF_INSN_BV; goto extract_fmt_bvd; |
| case 233 : itype = FR30BF_INSN_BNV; goto extract_fmt_bvd; |
| case 234 : itype = FR30BF_INSN_BLT; goto extract_fmt_bltd; |
| case 235 : itype = FR30BF_INSN_BGE; goto extract_fmt_bltd; |
| case 236 : itype = FR30BF_INSN_BLE; goto extract_fmt_bled; |
| case 237 : itype = FR30BF_INSN_BGT; goto extract_fmt_bled; |
| case 238 : itype = FR30BF_INSN_BLS; goto extract_fmt_blsd; |
| case 239 : itype = FR30BF_INSN_BHI; goto extract_fmt_blsd; |
| case 240 : itype = FR30BF_INSN_BRAD; goto extract_fmt_brad; |
| case 241 : itype = FR30BF_INSN_BNOD; goto extract_fmt_bnod; |
| case 242 : itype = FR30BF_INSN_BEQD; goto extract_fmt_beqd; |
| case 243 : itype = FR30BF_INSN_BNED; goto extract_fmt_beqd; |
| case 244 : itype = FR30BF_INSN_BCD; goto extract_fmt_bcd; |
| case 245 : itype = FR30BF_INSN_BNCD; goto extract_fmt_bcd; |
| case 246 : itype = FR30BF_INSN_BND; goto extract_fmt_bnd; |
| case 247 : itype = FR30BF_INSN_BPD; goto extract_fmt_bnd; |
| case 248 : itype = FR30BF_INSN_BVD; goto extract_fmt_bvd; |
| case 249 : itype = FR30BF_INSN_BNVD; goto extract_fmt_bvd; |
| case 250 : itype = FR30BF_INSN_BLTD; goto extract_fmt_bltd; |
| case 251 : itype = FR30BF_INSN_BGED; goto extract_fmt_bltd; |
| case 252 : itype = FR30BF_INSN_BLED; goto extract_fmt_bled; |
| case 253 : itype = FR30BF_INSN_BGTD; goto extract_fmt_bled; |
| case 254 : itype = FR30BF_INSN_BLSD; goto extract_fmt_blsd; |
| case 255 : itype = FR30BF_INSN_BHID; goto extract_fmt_blsd; |
| default : itype = FR30BF_INSN_X_INVALID; goto extract_fmt_empty; |
| } |
| } |
| } |
| |
| /* The instruction has been decoded, now extract the fields. */ |
| |
| extract_fmt_empty: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_empty.f |
| EXTRACT_IFMT_EMPTY_VARS /* */ |
| |
| EXTRACT_IFMT_EMPTY_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_empty", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_add: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_add.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_add", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_addi: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_addi.f |
| EXTRACT_IFMT_ADDI_VARS /* f-op1 f-op2 f-u4 f-Ri */ |
| |
| EXTRACT_IFMT_ADDI_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u4) = f_u4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_addi", "f_u4 0x%x", 'x', f_u4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_add2: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_add2.f |
| EXTRACT_IFMT_ADD2_VARS /* f-op1 f-op2 f-m4 f-Ri */ |
| |
| EXTRACT_IFMT_ADD2_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_m4) = f_m4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_add2", "f_m4 0x%x", 'x', f_m4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_addc: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_addc.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_addc", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_addn: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_addn.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_addn", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_addni: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_addni.f |
| EXTRACT_IFMT_ADDI_VARS /* f-op1 f-op2 f-u4 f-Ri */ |
| |
| EXTRACT_IFMT_ADDI_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u4) = f_u4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_addni", "f_u4 0x%x", 'x', f_u4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_addn2: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_addn2.f |
| EXTRACT_IFMT_ADD2_VARS /* f-op1 f-op2 f-m4 f-Ri */ |
| |
| EXTRACT_IFMT_ADD2_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_m4) = f_m4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_addn2", "f_m4 0x%x", 'x', f_m4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_cmp: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_cmp.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_cmp", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_cmpi: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_cmpi.f |
| EXTRACT_IFMT_ADDI_VARS /* f-op1 f-op2 f-u4 f-Ri */ |
| |
| EXTRACT_IFMT_ADDI_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u4) = f_u4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_cmpi", "f_u4 0x%x", 'x', f_u4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_cmp2: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_cmp2.f |
| EXTRACT_IFMT_ADD2_VARS /* f-op1 f-op2 f-m4 f-Ri */ |
| |
| EXTRACT_IFMT_ADD2_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_m4) = f_m4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_cmp2", "f_m4 0x%x", 'x', f_m4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_and: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_and.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_and", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_andm: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_andm.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_andm", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_andh: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_andh.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_andh", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_andb: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_andb.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_andb", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_bandl: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_bandl.f |
| EXTRACT_IFMT_ADDI_VARS /* f-op1 f-op2 f-u4 f-Ri */ |
| |
| EXTRACT_IFMT_ADDI_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u4) = f_u4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_bandl", "f_u4 0x%x", 'x', f_u4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_btstl: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_btstl.f |
| EXTRACT_IFMT_ADDI_VARS /* f-op1 f-op2 f-u4 f-Ri */ |
| |
| EXTRACT_IFMT_ADDI_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u4) = f_u4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_btstl", "f_u4 0x%x", 'x', f_u4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_mul: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_mul.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_mul", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_mulu: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_mulu.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_mulu", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_mulh: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_mulh.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_mulh", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_div0s: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_div0s.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_div0s", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_div0u: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_div0u.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_div0u", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_div1: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_div1.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_div1", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_div2: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_div2.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_div2", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_div3: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_div3.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_div3", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_div4s: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_div4s.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_div4s", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_lsl: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_lsl.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_lsl", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_lsli: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_lsli.f |
| EXTRACT_IFMT_ADDI_VARS /* f-op1 f-op2 f-u4 f-Ri */ |
| |
| EXTRACT_IFMT_ADDI_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u4) = f_u4; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_lsli", "f_u4 0x%x", 'x', f_u4, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldi8: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldi8.f |
| EXTRACT_IFMT_LDI8_VARS /* f-op1 f-i8 f-Ri */ |
| |
| EXTRACT_IFMT_LDI8_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_i8) = f_i8; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldi8", "f_i8 0x%x", 'x', f_i8, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldi20: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldi20.f |
| EXTRACT_IFMT_LDI20_VARS /* f-op1 f-i20 f-op2 f-Ri */ |
| |
| EXTRACT_IFMT_LDI20_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_i20) = f_i20; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldi20", "f_i20 0x%x", 'x', f_i20, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldi32: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldi32.f |
| EXTRACT_IFMT_LDI32_VARS /* f-op1 f-i32 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_LDI32_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_i32) = f_i32; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldi32", "f_i32 0x%x", 'x', f_i32, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ld: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ld.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ld", "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_lduh: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_lduh.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_lduh", "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldub: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldub.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldub", "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr13: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr13.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr13", "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Rj) = f_Rj; |
| FLD (in_h_gr_13) = 13; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr13uh: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr13uh.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr13uh", "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Rj) = f_Rj; |
| FLD (in_h_gr_13) = 13; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr13ub: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr13ub.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr13ub", "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Rj) = f_Rj; |
| FLD (in_h_gr_13) = 13; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr14: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr14.f |
| EXTRACT_IFMT_LDR14_VARS /* f-op1 f-disp10 f-Ri */ |
| |
| EXTRACT_IFMT_LDR14_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_disp10) = f_disp10; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr14", "f_disp10 0x%x", 'x', f_disp10, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_14) = 14; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr14uh: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr14uh.f |
| EXTRACT_IFMT_LDR14UH_VARS /* f-op1 f-disp9 f-Ri */ |
| |
| EXTRACT_IFMT_LDR14UH_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_disp9) = f_disp9; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr14uh", "f_disp9 0x%x", 'x', f_disp9, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_14) = 14; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr14ub: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr14ub.f |
| EXTRACT_IFMT_LDR14UB_VARS /* f-op1 f-disp8 f-Ri */ |
| |
| EXTRACT_IFMT_LDR14UB_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_disp8) = f_disp8; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr14ub", "f_disp8 0x%x", 'x', f_disp8, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_14) = 14; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr15: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr15.f |
| EXTRACT_IFMT_LDR15_VARS /* f-op1 f-op2 f-udisp6 f-Ri */ |
| |
| EXTRACT_IFMT_LDR15_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_udisp6) = f_udisp6; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr15", "f_udisp6 0x%x", 'x', f_udisp6, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr15gr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr15gr.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_Ri) = f_Ri; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr15gr", "f_Ri 0x%x", 'x', f_Ri, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_Ri) = f_Ri; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr15dr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr15dr.f |
| EXTRACT_IFMT_LDR15DR_VARS /* f-op1 f-op2 f-op3 f-Rs2 */ |
| |
| EXTRACT_IFMT_LDR15DR_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_Rs2) = f_Rs2; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr15dr", "f_Rs2 0x%x", 'x', f_Rs2, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldr15ps: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldr15ps.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldr15ps", (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_st: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_st.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_st", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_sth: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_sth.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_sth", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_stb: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_stb.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_stb", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str13: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str13.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str13", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (in_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str13h: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str13h.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str13h", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (in_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str13b: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str13b.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str13b", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (in_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str14: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str14.f |
| EXTRACT_IFMT_LDR14_VARS /* f-op1 f-disp10 f-Ri */ |
| |
| EXTRACT_IFMT_LDR14_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_disp10) = f_disp10; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str14", "f_disp10 0x%x", 'x', f_disp10, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_h_gr_14) = 14; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str14h: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str14h.f |
| EXTRACT_IFMT_LDR14UH_VARS /* f-op1 f-disp9 f-Ri */ |
| |
| EXTRACT_IFMT_LDR14UH_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_disp9) = f_disp9; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str14h", "f_disp9 0x%x", 'x', f_disp9, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_h_gr_14) = 14; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str14b: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str14b.f |
| EXTRACT_IFMT_LDR14UB_VARS /* f-op1 f-disp8 f-Ri */ |
| |
| EXTRACT_IFMT_LDR14UB_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_disp8) = f_disp8; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str14b", "f_disp8 0x%x", 'x', f_disp8, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_h_gr_14) = 14; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str15: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str15.f |
| EXTRACT_IFMT_LDR15_VARS /* f-op1 f-op2 f-udisp6 f-Ri */ |
| |
| EXTRACT_IFMT_LDR15_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_udisp6) = f_udisp6; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str15", "f_udisp6 0x%x", 'x', f_udisp6, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str15gr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str15gr.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str15gr", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str15dr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str15dr.f |
| EXTRACT_IFMT_LDR15DR_VARS /* f-op1 f-op2 f-op3 f-Rs2 */ |
| |
| EXTRACT_IFMT_LDR15DR_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_Rs2) = f_Rs2; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str15dr", "f_Rs2 0x%x", 'x', f_Rs2, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_str15ps: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_str15ps.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_str15ps", (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_mov: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_mov.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_mov", "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_movdr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_movdr.f |
| EXTRACT_IFMT_MOVDR_VARS /* f-op1 f-op2 f-Rs1 f-Ri */ |
| |
| EXTRACT_IFMT_MOVDR_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_Rs1) = f_Rs1; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_movdr", "f_Rs1 0x%x", 'x', f_Rs1, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_movps: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_movps.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_movps", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_mov2dr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_mov2dr.f |
| EXTRACT_IFMT_MOVDR_VARS /* f-op1 f-op2 f-Rs1 f-Ri */ |
| |
| EXTRACT_IFMT_MOVDR_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_Rs1) = f_Rs1; |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_mov2dr", "f_Rs1 0x%x", 'x', f_Rs1, "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_mov2ps: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_mov2ps.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_mov2ps", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_jmp: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_jmp.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_jmp", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_callr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_callr.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_callr", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_call: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_call.f |
| EXTRACT_IFMT_CALL_VARS /* f-op1 f-op5 f-rel12 */ |
| |
| EXTRACT_IFMT_CALL_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label12) = f_rel12; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_call", "label12 0x%x", 'x', f_rel12, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ret: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_ret.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ret", (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_int: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_int.f |
| EXTRACT_IFMT_INT_VARS /* f-op1 f-op2 f-u8 */ |
| |
| EXTRACT_IFMT_INT_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u8) = f_u8; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_int", "f_u8 0x%x", 'x', f_u8, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_inte: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_inte.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_inte", (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_reti: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_reti.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_reti", (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_brad: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_brad.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_brad", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_bnod: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_bnod.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_bnod", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_beqd: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_beqd.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_beqd", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_bcd: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_bcd.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_bcd", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_bnd: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_bnd.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_bnd", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_bvd: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_bvd.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_bvd", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_bltd: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_bltd.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_bltd", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_bled: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_bled.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_bled", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_blsd: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.cti.fields.fmt_blsd.f |
| EXTRACT_IFMT_BRAD_VARS /* f-op1 f-cc f-rel9 */ |
| |
| EXTRACT_IFMT_BRAD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_label9) = f_rel9; |
| SEM_BRANCH_INIT_EXTRACT (abuf); |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_blsd", "label9 0x%x", 'x', f_rel9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmovr13: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmovr13.f |
| EXTRACT_IFMT_DMOVR13_VARS /* f-op1 f-op2 f-dir10 */ |
| |
| EXTRACT_IFMT_DMOVR13_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir10) = f_dir10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmovr13", "f_dir10 0x%x", 'x', f_dir10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmovr13h: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmovr13h.f |
| EXTRACT_IFMT_DMOVR13H_VARS /* f-op1 f-op2 f-dir9 */ |
| |
| EXTRACT_IFMT_DMOVR13H_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir9) = f_dir9; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmovr13h", "f_dir9 0x%x", 'x', f_dir9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmovr13b: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmovr13b.f |
| EXTRACT_IFMT_DMOVR13B_VARS /* f-op1 f-op2 f-dir8 */ |
| |
| EXTRACT_IFMT_DMOVR13B_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir8) = f_dir8; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmovr13b", "f_dir8 0x%x", 'x', f_dir8, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmovr13pi: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmovr13pi.f |
| EXTRACT_IFMT_DMOVR13_VARS /* f-op1 f-op2 f-dir10 */ |
| |
| EXTRACT_IFMT_DMOVR13_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir10) = f_dir10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmovr13pi", "f_dir10 0x%x", 'x', f_dir10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmovr13pih: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmovr13pih.f |
| EXTRACT_IFMT_DMOVR13H_VARS /* f-op1 f-op2 f-dir9 */ |
| |
| EXTRACT_IFMT_DMOVR13H_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir9) = f_dir9; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmovr13pih", "f_dir9 0x%x", 'x', f_dir9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmovr13pib: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmovr13pib.f |
| EXTRACT_IFMT_DMOVR13B_VARS /* f-op1 f-op2 f-dir8 */ |
| |
| EXTRACT_IFMT_DMOVR13B_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir8) = f_dir8; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmovr13pib", "f_dir8 0x%x", 'x', f_dir8, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmovr15pi: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmovr15pi.f |
| EXTRACT_IFMT_DMOVR13_VARS /* f-op1 f-op2 f-dir10 */ |
| |
| EXTRACT_IFMT_DMOVR13_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir10) = f_dir10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmovr15pi", "f_dir10 0x%x", 'x', f_dir10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmov2r13: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmov2r13.f |
| EXTRACT_IFMT_DMOVR13_VARS /* f-op1 f-op2 f-dir10 */ |
| |
| EXTRACT_IFMT_DMOVR13_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir10) = f_dir10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmov2r13", "f_dir10 0x%x", 'x', f_dir10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmov2r13h: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmov2r13h.f |
| EXTRACT_IFMT_DMOVR13H_VARS /* f-op1 f-op2 f-dir9 */ |
| |
| EXTRACT_IFMT_DMOVR13H_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir9) = f_dir9; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmov2r13h", "f_dir9 0x%x", 'x', f_dir9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmov2r13b: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmov2r13b.f |
| EXTRACT_IFMT_DMOVR13B_VARS /* f-op1 f-op2 f-dir8 */ |
| |
| EXTRACT_IFMT_DMOVR13B_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir8) = f_dir8; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmov2r13b", "f_dir8 0x%x", 'x', f_dir8, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmov2r13pi: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmov2r13pi.f |
| EXTRACT_IFMT_DMOVR13_VARS /* f-op1 f-op2 f-dir10 */ |
| |
| EXTRACT_IFMT_DMOVR13_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir10) = f_dir10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmov2r13pi", "f_dir10 0x%x", 'x', f_dir10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmov2r13pih: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmov2r13pih.f |
| EXTRACT_IFMT_DMOVR13H_VARS /* f-op1 f-op2 f-dir9 */ |
| |
| EXTRACT_IFMT_DMOVR13H_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir9) = f_dir9; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmov2r13pih", "f_dir9 0x%x", 'x', f_dir9, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmov2r13pib: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmov2r13pib.f |
| EXTRACT_IFMT_DMOVR13B_VARS /* f-op1 f-op2 f-dir8 */ |
| |
| EXTRACT_IFMT_DMOVR13B_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir8) = f_dir8; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmov2r13pib", "f_dir8 0x%x", 'x', f_dir8, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_13) = 13; |
| FLD (out_h_gr_13) = 13; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_dmov2r15pd: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_dmov2r15pd.f |
| EXTRACT_IFMT_DMOVR13_VARS /* f-op1 f-op2 f-dir10 */ |
| |
| EXTRACT_IFMT_DMOVR13_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_dir10) = f_dir10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_dmov2r15pd", "f_dir10 0x%x", 'x', f_dir10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldres: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldres.f |
| EXTRACT_IFMT_ADDI_VARS /* f-op1 f-op2 f-u4 f-Ri */ |
| |
| EXTRACT_IFMT_ADDI_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldres", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_copop: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_copop.f |
| EXTRACT_IFMT_COPOP_VARS /* f-op1 f-ccc f-op2 f-op3 f-CRj f-u4c f-CRi */ |
| |
| EXTRACT_IFMT_COPOP_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_copop", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_copld: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_copld.f |
| EXTRACT_IFMT_COPLD_VARS /* f-op1 f-ccc f-op2 f-op3 f-Rjc f-u4c f-CRi */ |
| |
| EXTRACT_IFMT_COPLD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_copld", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_copst: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_copst.f |
| EXTRACT_IFMT_COPST_VARS /* f-op1 f-ccc f-op2 f-op3 f-CRj f-u4c f-Ric */ |
| |
| EXTRACT_IFMT_COPST_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_copst", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_nop: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_nop.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_nop", (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_andccr: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_andccr.f |
| EXTRACT_IFMT_INT_VARS /* f-op1 f-op2 f-u8 */ |
| |
| EXTRACT_IFMT_INT_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u8) = f_u8; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_andccr", "f_u8 0x%x", 'x', f_u8, (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_stilm: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_stilm.f |
| EXTRACT_IFMT_INT_VARS /* f-op1 f-op2 f-u8 */ |
| |
| EXTRACT_IFMT_INT_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u8) = f_u8; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_stilm", "f_u8 0x%x", 'x', f_u8, (char *) 0)); |
| |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_addsp: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_addsp.f |
| EXTRACT_IFMT_ADDSP_VARS /* f-op1 f-op2 f-s10 */ |
| |
| EXTRACT_IFMT_ADDSP_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_s10) = f_s10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_addsp", "f_s10 0x%x", 'x', f_s10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_extsb: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_extsb.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_extsb", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_extub: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_extub.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_extub", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_extsh: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_extsh.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_extsh", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_extuh: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_extuh.f |
| EXTRACT_IFMT_DIV0S_VARS /* f-op1 f-op2 f-op3 f-Ri */ |
| |
| EXTRACT_IFMT_DIV0S_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_extuh", "Ri 0x%x", 'x', f_Ri, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldm0: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldm0.f |
| EXTRACT_IFMT_LDM0_VARS /* f-op1 f-op2 f-reglist_low_ld */ |
| |
| EXTRACT_IFMT_LDM0_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_reglist_low_ld) = f_reglist_low_ld; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldm0", "f_reglist_low_ld 0x%x", 'x', f_reglist_low_ld, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_0) = 0; |
| FLD (out_h_gr_1) = 1; |
| FLD (out_h_gr_15) = 15; |
| FLD (out_h_gr_2) = 2; |
| FLD (out_h_gr_3) = 3; |
| FLD (out_h_gr_4) = 4; |
| FLD (out_h_gr_5) = 5; |
| FLD (out_h_gr_6) = 6; |
| FLD (out_h_gr_7) = 7; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_ldm1: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_ldm1.f |
| EXTRACT_IFMT_LDM1_VARS /* f-op1 f-op2 f-reglist_hi_ld */ |
| |
| EXTRACT_IFMT_LDM1_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_reglist_hi_ld) = f_reglist_hi_ld; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_ldm1", "f_reglist_hi_ld 0x%x", 'x', f_reglist_hi_ld, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_10) = 10; |
| FLD (out_h_gr_11) = 11; |
| FLD (out_h_gr_12) = 12; |
| FLD (out_h_gr_13) = 13; |
| FLD (out_h_gr_14) = 14; |
| FLD (out_h_gr_15) = 15; |
| FLD (out_h_gr_8) = 8; |
| FLD (out_h_gr_9) = 9; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_stm0: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_stm0.f |
| EXTRACT_IFMT_STM0_VARS /* f-op1 f-op2 f-reglist_low_st */ |
| |
| EXTRACT_IFMT_STM0_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_reglist_low_st) = f_reglist_low_st; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_stm0", "f_reglist_low_st 0x%x", 'x', f_reglist_low_st, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_0) = 0; |
| FLD (in_h_gr_1) = 1; |
| FLD (in_h_gr_15) = 15; |
| FLD (in_h_gr_2) = 2; |
| FLD (in_h_gr_3) = 3; |
| FLD (in_h_gr_4) = 4; |
| FLD (in_h_gr_5) = 5; |
| FLD (in_h_gr_6) = 6; |
| FLD (in_h_gr_7) = 7; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_stm1: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_stm1.f |
| EXTRACT_IFMT_STM1_VARS /* f-op1 f-op2 f-reglist_hi_st */ |
| |
| EXTRACT_IFMT_STM1_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_reglist_hi_st) = f_reglist_hi_st; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_stm1", "f_reglist_hi_st 0x%x", 'x', f_reglist_hi_st, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_10) = 10; |
| FLD (in_h_gr_11) = 11; |
| FLD (in_h_gr_12) = 12; |
| FLD (in_h_gr_13) = 13; |
| FLD (in_h_gr_14) = 14; |
| FLD (in_h_gr_15) = 15; |
| FLD (in_h_gr_8) = 8; |
| FLD (in_h_gr_9) = 9; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_enter: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_enter.f |
| EXTRACT_IFMT_ENTER_VARS /* f-op1 f-op2 f-u10 */ |
| |
| EXTRACT_IFMT_ENTER_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (f_u10) = f_u10; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_enter", "f_u10 0x%x", 'x', f_u10, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_14) = 14; |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_14) = 14; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_leave: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_leave.f |
| EXTRACT_IFMT_DIV3_VARS /* f-op1 f-op2 f-op3 f-op4 */ |
| |
| EXTRACT_IFMT_DIV3_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_leave", (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_h_gr_14) = 14; |
| FLD (in_h_gr_15) = 15; |
| FLD (out_h_gr_14) = 14; |
| FLD (out_h_gr_15) = 15; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| extract_fmt_xchb: |
| { |
| const IDESC *idesc = &fr30bf_insn_data[itype]; |
| CGEN_INSN_INT insn = base_insn; |
| #define FLD(f) abuf->fields.fmt_xchb.f |
| EXTRACT_IFMT_ADD_VARS /* f-op1 f-op2 f-Rj f-Ri */ |
| |
| EXTRACT_IFMT_ADD_CODE |
| |
| /* Record the fields for the semantic handler. */ |
| FLD (i_Ri) = & CPU (h_gr)[f_Ri]; |
| FLD (i_Rj) = & CPU (h_gr)[f_Rj]; |
| TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "fmt_xchb", "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); |
| |
| #if WITH_PROFILE_MODEL_P |
| /* Record the fields for profiling. */ |
| if (PROFILE_MODEL_P (current_cpu)) |
| { |
| FLD (in_Ri) = f_Ri; |
| FLD (in_Rj) = f_Rj; |
| FLD (out_Ri) = f_Ri; |
| } |
| #endif |
| #undef FLD |
| return idesc; |
| } |
| |
| } |