diff options
Diffstat (limited to 'sim/cris/decodev32.c')
-rw-r--r-- | sim/cris/decodev32.c | 5858 |
1 files changed, 0 insertions, 5858 deletions
diff --git a/sim/cris/decodev32.c b/sim/cris/decodev32.c deleted file mode 100644 index f118915..0000000 --- a/sim/cris/decodev32.c +++ /dev/null @@ -1,5858 +0,0 @@ -/* Simulator instruction decoder for crisv32f. - -THIS FILE IS MACHINE GENERATED WITH CGEN. - -Copyright 1996-2005 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., -51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. - -*/ - -#define WANT_CPU crisv32f -#define WANT_CPU_CRISV32F - -#include "sim-main.h" -#include "sim-assert.h" -#include "cgen-ops.h" - -/* 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 crisv32f_insn_data[CRISV32F_INSN__MAX]; - -/* Commas between elements are contained in the macros. - Some of these are conditionally compiled out. */ - -static const struct insn_sem crisv32f_insn_sem[] = -{ - { VIRTUAL_INSN_X_INVALID, CRISV32F_INSN_X_INVALID, CRISV32F_SFMT_EMPTY }, - { VIRTUAL_INSN_X_AFTER, CRISV32F_INSN_X_AFTER, CRISV32F_SFMT_EMPTY }, - { VIRTUAL_INSN_X_BEFORE, CRISV32F_INSN_X_BEFORE, CRISV32F_SFMT_EMPTY }, - { VIRTUAL_INSN_X_CTI_CHAIN, CRISV32F_INSN_X_CTI_CHAIN, CRISV32F_SFMT_EMPTY }, - { VIRTUAL_INSN_X_CHAIN, CRISV32F_INSN_X_CHAIN, CRISV32F_SFMT_EMPTY }, - { VIRTUAL_INSN_X_BEGIN, CRISV32F_INSN_X_BEGIN, CRISV32F_SFMT_EMPTY }, - { CRIS_INSN_MOVE_B_R, CRISV32F_INSN_MOVE_B_R, CRISV32F_SFMT_MOVE_B_R }, - { CRIS_INSN_MOVE_W_R, CRISV32F_INSN_MOVE_W_R, CRISV32F_SFMT_MOVE_B_R }, - { CRIS_INSN_MOVE_D_R, CRISV32F_INSN_MOVE_D_R, CRISV32F_SFMT_MOVE_D_R }, - { CRIS_INSN_MOVEQ, CRISV32F_INSN_MOVEQ, CRISV32F_SFMT_MOVEQ }, - { CRIS_INSN_MOVS_B_R, CRISV32F_INSN_MOVS_B_R, CRISV32F_SFMT_MOVS_B_R }, - { CRIS_INSN_MOVS_W_R, CRISV32F_INSN_MOVS_W_R, CRISV32F_SFMT_MOVS_B_R }, - { CRIS_INSN_MOVU_B_R, CRISV32F_INSN_MOVU_B_R, CRISV32F_SFMT_MOVS_B_R }, - { CRIS_INSN_MOVU_W_R, CRISV32F_INSN_MOVU_W_R, CRISV32F_SFMT_MOVS_B_R }, - { CRIS_INSN_MOVECBR, CRISV32F_INSN_MOVECBR, CRISV32F_SFMT_MOVECBR }, - { CRIS_INSN_MOVECWR, CRISV32F_INSN_MOVECWR, CRISV32F_SFMT_MOVECWR }, - { CRIS_INSN_MOVECDR, CRISV32F_INSN_MOVECDR, CRISV32F_SFMT_MOVECDR }, - { CRIS_INSN_MOVSCBR, CRISV32F_INSN_MOVSCBR, CRISV32F_SFMT_MOVSCBR }, - { CRIS_INSN_MOVSCWR, CRISV32F_INSN_MOVSCWR, CRISV32F_SFMT_MOVSCWR }, - { CRIS_INSN_MOVUCBR, CRISV32F_INSN_MOVUCBR, CRISV32F_SFMT_MOVUCBR }, - { CRIS_INSN_MOVUCWR, CRISV32F_INSN_MOVUCWR, CRISV32F_SFMT_MOVUCWR }, - { CRIS_INSN_ADDQ, CRISV32F_INSN_ADDQ, CRISV32F_SFMT_ADDQ }, - { CRIS_INSN_SUBQ, CRISV32F_INSN_SUBQ, CRISV32F_SFMT_ADDQ }, - { CRIS_INSN_CMP_R_B_R, CRISV32F_INSN_CMP_R_B_R, CRISV32F_SFMT_CMP_R_B_R }, - { CRIS_INSN_CMP_R_W_R, CRISV32F_INSN_CMP_R_W_R, CRISV32F_SFMT_CMP_R_B_R }, - { CRIS_INSN_CMP_R_D_R, CRISV32F_INSN_CMP_R_D_R, CRISV32F_SFMT_CMP_R_B_R }, - { CRIS_INSN_CMP_M_B_M, CRISV32F_INSN_CMP_M_B_M, CRISV32F_SFMT_CMP_M_B_M }, - { CRIS_INSN_CMP_M_W_M, CRISV32F_INSN_CMP_M_W_M, CRISV32F_SFMT_CMP_M_W_M }, - { CRIS_INSN_CMP_M_D_M, CRISV32F_INSN_CMP_M_D_M, CRISV32F_SFMT_CMP_M_D_M }, - { CRIS_INSN_CMPCBR, CRISV32F_INSN_CMPCBR, CRISV32F_SFMT_CMPCBR }, - { CRIS_INSN_CMPCWR, CRISV32F_INSN_CMPCWR, CRISV32F_SFMT_CMPCWR }, - { CRIS_INSN_CMPCDR, CRISV32F_INSN_CMPCDR, CRISV32F_SFMT_CMPCDR }, - { CRIS_INSN_CMPQ, CRISV32F_INSN_CMPQ, CRISV32F_SFMT_CMPQ }, - { CRIS_INSN_CMPS_M_B_M, CRISV32F_INSN_CMPS_M_B_M, CRISV32F_SFMT_CMP_M_B_M }, - { CRIS_INSN_CMPS_M_W_M, CRISV32F_INSN_CMPS_M_W_M, CRISV32F_SFMT_CMP_M_W_M }, - { CRIS_INSN_CMPSCBR, CRISV32F_INSN_CMPSCBR, CRISV32F_SFMT_CMPCBR }, - { CRIS_INSN_CMPSCWR, CRISV32F_INSN_CMPSCWR, CRISV32F_SFMT_CMPCWR }, - { CRIS_INSN_CMPU_M_B_M, CRISV32F_INSN_CMPU_M_B_M, CRISV32F_SFMT_CMP_M_B_M }, - { CRIS_INSN_CMPU_M_W_M, CRISV32F_INSN_CMPU_M_W_M, CRISV32F_SFMT_CMP_M_W_M }, - { CRIS_INSN_CMPUCBR, CRISV32F_INSN_CMPUCBR, CRISV32F_SFMT_CMPUCBR }, - { CRIS_INSN_CMPUCWR, CRISV32F_INSN_CMPUCWR, CRISV32F_SFMT_CMPUCWR }, - { CRIS_INSN_MOVE_M_B_M, CRISV32F_INSN_MOVE_M_B_M, CRISV32F_SFMT_MOVE_M_B_M }, - { CRIS_INSN_MOVE_M_W_M, CRISV32F_INSN_MOVE_M_W_M, CRISV32F_SFMT_MOVE_M_W_M }, - { CRIS_INSN_MOVE_M_D_M, CRISV32F_INSN_MOVE_M_D_M, CRISV32F_SFMT_MOVE_M_D_M }, - { CRIS_INSN_MOVS_M_B_M, CRISV32F_INSN_MOVS_M_B_M, CRISV32F_SFMT_MOVS_M_B_M }, - { CRIS_INSN_MOVS_M_W_M, CRISV32F_INSN_MOVS_M_W_M, CRISV32F_SFMT_MOVS_M_W_M }, - { CRIS_INSN_MOVU_M_B_M, CRISV32F_INSN_MOVU_M_B_M, CRISV32F_SFMT_MOVS_M_B_M }, - { CRIS_INSN_MOVU_M_W_M, CRISV32F_INSN_MOVU_M_W_M, CRISV32F_SFMT_MOVS_M_W_M }, - { CRIS_INSN_MOVE_R_SPRV32, CRISV32F_INSN_MOVE_R_SPRV32, CRISV32F_SFMT_MOVE_R_SPRV32 }, - { CRIS_INSN_MOVE_SPR_RV32, CRISV32F_INSN_MOVE_SPR_RV32, CRISV32F_SFMT_MOVE_SPR_RV32 }, - { CRIS_INSN_MOVE_M_SPRV32, CRISV32F_INSN_MOVE_M_SPRV32, CRISV32F_SFMT_MOVE_M_SPRV32 }, - { CRIS_INSN_MOVE_C_SPRV32_P2, CRISV32F_INSN_MOVE_C_SPRV32_P2, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P3, CRISV32F_INSN_MOVE_C_SPRV32_P3, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P5, CRISV32F_INSN_MOVE_C_SPRV32_P5, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P6, CRISV32F_INSN_MOVE_C_SPRV32_P6, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P7, CRISV32F_INSN_MOVE_C_SPRV32_P7, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P9, CRISV32F_INSN_MOVE_C_SPRV32_P9, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P10, CRISV32F_INSN_MOVE_C_SPRV32_P10, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P11, CRISV32F_INSN_MOVE_C_SPRV32_P11, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P12, CRISV32F_INSN_MOVE_C_SPRV32_P12, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P13, CRISV32F_INSN_MOVE_C_SPRV32_P13, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P14, CRISV32F_INSN_MOVE_C_SPRV32_P14, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_C_SPRV32_P15, CRISV32F_INSN_MOVE_C_SPRV32_P15, CRISV32F_SFMT_MOVE_C_SPRV32_P2 }, - { CRIS_INSN_MOVE_SPR_MV32, CRISV32F_INSN_MOVE_SPR_MV32, CRISV32F_SFMT_MOVE_SPR_MV32 }, - { CRIS_INSN_MOVE_SS_R, CRISV32F_INSN_MOVE_SS_R, CRISV32F_SFMT_MOVE_SS_R }, - { CRIS_INSN_MOVE_R_SS, CRISV32F_INSN_MOVE_R_SS, CRISV32F_SFMT_MOVE_R_SS }, - { CRIS_INSN_MOVEM_R_M_V32, CRISV32F_INSN_MOVEM_R_M_V32, CRISV32F_SFMT_MOVEM_R_M_V32 }, - { CRIS_INSN_MOVEM_M_R_V32, CRISV32F_INSN_MOVEM_M_R_V32, CRISV32F_SFMT_MOVEM_M_R_V32 }, - { CRIS_INSN_ADD_B_R, CRISV32F_INSN_ADD_B_R, CRISV32F_SFMT_ADD_B_R }, - { CRIS_INSN_ADD_W_R, CRISV32F_INSN_ADD_W_R, CRISV32F_SFMT_ADD_B_R }, - { CRIS_INSN_ADD_D_R, CRISV32F_INSN_ADD_D_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_ADD_M_B_M, CRISV32F_INSN_ADD_M_B_M, CRISV32F_SFMT_ADD_M_B_M }, - { CRIS_INSN_ADD_M_W_M, CRISV32F_INSN_ADD_M_W_M, CRISV32F_SFMT_ADD_M_W_M }, - { CRIS_INSN_ADD_M_D_M, CRISV32F_INSN_ADD_M_D_M, CRISV32F_SFMT_ADD_M_D_M }, - { CRIS_INSN_ADDCBR, CRISV32F_INSN_ADDCBR, CRISV32F_SFMT_ADDCBR }, - { CRIS_INSN_ADDCWR, CRISV32F_INSN_ADDCWR, CRISV32F_SFMT_ADDCWR }, - { CRIS_INSN_ADDCDR, CRISV32F_INSN_ADDCDR, CRISV32F_SFMT_ADDCDR }, - { CRIS_INSN_ADDS_B_R, CRISV32F_INSN_ADDS_B_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_ADDS_W_R, CRISV32F_INSN_ADDS_W_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_ADDS_M_B_M, CRISV32F_INSN_ADDS_M_B_M, CRISV32F_SFMT_ADDS_M_B_M }, - { CRIS_INSN_ADDS_M_W_M, CRISV32F_INSN_ADDS_M_W_M, CRISV32F_SFMT_ADDS_M_W_M }, - { CRIS_INSN_ADDSCBR, CRISV32F_INSN_ADDSCBR, CRISV32F_SFMT_ADDSCBR }, - { CRIS_INSN_ADDSCWR, CRISV32F_INSN_ADDSCWR, CRISV32F_SFMT_ADDSCWR }, - { CRIS_INSN_ADDU_B_R, CRISV32F_INSN_ADDU_B_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_ADDU_W_R, CRISV32F_INSN_ADDU_W_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_ADDU_M_B_M, CRISV32F_INSN_ADDU_M_B_M, CRISV32F_SFMT_ADDS_M_B_M }, - { CRIS_INSN_ADDU_M_W_M, CRISV32F_INSN_ADDU_M_W_M, CRISV32F_SFMT_ADDS_M_W_M }, - { CRIS_INSN_ADDUCBR, CRISV32F_INSN_ADDUCBR, CRISV32F_SFMT_ADDSCBR }, - { CRIS_INSN_ADDUCWR, CRISV32F_INSN_ADDUCWR, CRISV32F_SFMT_ADDSCWR }, - { CRIS_INSN_SUB_B_R, CRISV32F_INSN_SUB_B_R, CRISV32F_SFMT_ADD_B_R }, - { CRIS_INSN_SUB_W_R, CRISV32F_INSN_SUB_W_R, CRISV32F_SFMT_ADD_B_R }, - { CRIS_INSN_SUB_D_R, CRISV32F_INSN_SUB_D_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_SUB_M_B_M, CRISV32F_INSN_SUB_M_B_M, CRISV32F_SFMT_ADD_M_B_M }, - { CRIS_INSN_SUB_M_W_M, CRISV32F_INSN_SUB_M_W_M, CRISV32F_SFMT_ADD_M_W_M }, - { CRIS_INSN_SUB_M_D_M, CRISV32F_INSN_SUB_M_D_M, CRISV32F_SFMT_ADD_M_D_M }, - { CRIS_INSN_SUBCBR, CRISV32F_INSN_SUBCBR, CRISV32F_SFMT_ADDCBR }, - { CRIS_INSN_SUBCWR, CRISV32F_INSN_SUBCWR, CRISV32F_SFMT_ADDCWR }, - { CRIS_INSN_SUBCDR, CRISV32F_INSN_SUBCDR, CRISV32F_SFMT_ADDCDR }, - { CRIS_INSN_SUBS_B_R, CRISV32F_INSN_SUBS_B_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_SUBS_W_R, CRISV32F_INSN_SUBS_W_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_SUBS_M_B_M, CRISV32F_INSN_SUBS_M_B_M, CRISV32F_SFMT_ADDS_M_B_M }, - { CRIS_INSN_SUBS_M_W_M, CRISV32F_INSN_SUBS_M_W_M, CRISV32F_SFMT_ADDS_M_W_M }, - { CRIS_INSN_SUBSCBR, CRISV32F_INSN_SUBSCBR, CRISV32F_SFMT_ADDSCBR }, - { CRIS_INSN_SUBSCWR, CRISV32F_INSN_SUBSCWR, CRISV32F_SFMT_ADDSCWR }, - { CRIS_INSN_SUBU_B_R, CRISV32F_INSN_SUBU_B_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_SUBU_W_R, CRISV32F_INSN_SUBU_W_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_SUBU_M_B_M, CRISV32F_INSN_SUBU_M_B_M, CRISV32F_SFMT_ADDS_M_B_M }, - { CRIS_INSN_SUBU_M_W_M, CRISV32F_INSN_SUBU_M_W_M, CRISV32F_SFMT_ADDS_M_W_M }, - { CRIS_INSN_SUBUCBR, CRISV32F_INSN_SUBUCBR, CRISV32F_SFMT_ADDSCBR }, - { CRIS_INSN_SUBUCWR, CRISV32F_INSN_SUBUCWR, CRISV32F_SFMT_ADDSCWR }, - { CRIS_INSN_ADDC_R, CRISV32F_INSN_ADDC_R, CRISV32F_SFMT_ADD_D_R }, - { CRIS_INSN_ADDC_M, CRISV32F_INSN_ADDC_M, CRISV32F_SFMT_ADDC_M }, - { CRIS_INSN_ADDC_C, CRISV32F_INSN_ADDC_C, CRISV32F_SFMT_ADDCDR }, - { CRIS_INSN_LAPC_D, CRISV32F_INSN_LAPC_D, CRISV32F_SFMT_LAPC_D }, - { CRIS_INSN_LAPCQ, CRISV32F_INSN_LAPCQ, CRISV32F_SFMT_LAPCQ }, - { CRIS_INSN_ADDI_B_R, CRISV32F_INSN_ADDI_B_R, CRISV32F_SFMT_ADDI_B_R }, - { CRIS_INSN_ADDI_W_R, CRISV32F_INSN_ADDI_W_R, CRISV32F_SFMT_ADDI_B_R }, - { CRIS_INSN_ADDI_D_R, CRISV32F_INSN_ADDI_D_R, CRISV32F_SFMT_ADDI_B_R }, - { CRIS_INSN_NEG_B_R, CRISV32F_INSN_NEG_B_R, CRISV32F_SFMT_NEG_B_R }, - { CRIS_INSN_NEG_W_R, CRISV32F_INSN_NEG_W_R, CRISV32F_SFMT_NEG_B_R }, - { CRIS_INSN_NEG_D_R, CRISV32F_INSN_NEG_D_R, CRISV32F_SFMT_NEG_D_R }, - { CRIS_INSN_TEST_M_B_M, CRISV32F_INSN_TEST_M_B_M, CRISV32F_SFMT_TEST_M_B_M }, - { CRIS_INSN_TEST_M_W_M, CRISV32F_INSN_TEST_M_W_M, CRISV32F_SFMT_TEST_M_W_M }, - { CRIS_INSN_TEST_M_D_M, CRISV32F_INSN_TEST_M_D_M, CRISV32F_SFMT_TEST_M_D_M }, - { CRIS_INSN_MOVE_R_M_B_M, CRISV32F_INSN_MOVE_R_M_B_M, CRISV32F_SFMT_MOVE_R_M_B_M }, - { CRIS_INSN_MOVE_R_M_W_M, CRISV32F_INSN_MOVE_R_M_W_M, CRISV32F_SFMT_MOVE_R_M_W_M }, - { CRIS_INSN_MOVE_R_M_D_M, CRISV32F_INSN_MOVE_R_M_D_M, CRISV32F_SFMT_MOVE_R_M_D_M }, - { CRIS_INSN_MULS_B, CRISV32F_INSN_MULS_B, CRISV32F_SFMT_MULS_B }, - { CRIS_INSN_MULS_W, CRISV32F_INSN_MULS_W, CRISV32F_SFMT_MULS_B }, - { CRIS_INSN_MULS_D, CRISV32F_INSN_MULS_D, CRISV32F_SFMT_MULS_B }, - { CRIS_INSN_MULU_B, CRISV32F_INSN_MULU_B, CRISV32F_SFMT_MULS_B }, - { CRIS_INSN_MULU_W, CRISV32F_INSN_MULU_W, CRISV32F_SFMT_MULS_B }, - { CRIS_INSN_MULU_D, CRISV32F_INSN_MULU_D, CRISV32F_SFMT_MULS_B }, - { CRIS_INSN_MCP, CRISV32F_INSN_MCP, CRISV32F_SFMT_MCP }, - { CRIS_INSN_DSTEP, CRISV32F_INSN_DSTEP, CRISV32F_SFMT_DSTEP }, - { CRIS_INSN_ABS, CRISV32F_INSN_ABS, CRISV32F_SFMT_MOVS_B_R }, - { CRIS_INSN_AND_B_R, CRISV32F_INSN_AND_B_R, CRISV32F_SFMT_AND_B_R }, - { CRIS_INSN_AND_W_R, CRISV32F_INSN_AND_W_R, CRISV32F_SFMT_AND_W_R }, - { CRIS_INSN_AND_D_R, CRISV32F_INSN_AND_D_R, CRISV32F_SFMT_AND_D_R }, - { CRIS_INSN_AND_M_B_M, CRISV32F_INSN_AND_M_B_M, CRISV32F_SFMT_AND_M_B_M }, - { CRIS_INSN_AND_M_W_M, CRISV32F_INSN_AND_M_W_M, CRISV32F_SFMT_AND_M_W_M }, - { CRIS_INSN_AND_M_D_M, CRISV32F_INSN_AND_M_D_M, CRISV32F_SFMT_AND_M_D_M }, - { CRIS_INSN_ANDCBR, CRISV32F_INSN_ANDCBR, CRISV32F_SFMT_ANDCBR }, - { CRIS_INSN_ANDCWR, CRISV32F_INSN_ANDCWR, CRISV32F_SFMT_ANDCWR }, - { CRIS_INSN_ANDCDR, CRISV32F_INSN_ANDCDR, CRISV32F_SFMT_ANDCDR }, - { CRIS_INSN_ANDQ, CRISV32F_INSN_ANDQ, CRISV32F_SFMT_ANDQ }, - { CRIS_INSN_ORR_B_R, CRISV32F_INSN_ORR_B_R, CRISV32F_SFMT_AND_B_R }, - { CRIS_INSN_ORR_W_R, CRISV32F_INSN_ORR_W_R, CRISV32F_SFMT_AND_W_R }, - { CRIS_INSN_ORR_D_R, CRISV32F_INSN_ORR_D_R, CRISV32F_SFMT_AND_D_R }, - { CRIS_INSN_OR_M_B_M, CRISV32F_INSN_OR_M_B_M, CRISV32F_SFMT_AND_M_B_M }, - { CRIS_INSN_OR_M_W_M, CRISV32F_INSN_OR_M_W_M, CRISV32F_SFMT_AND_M_W_M }, - { CRIS_INSN_OR_M_D_M, CRISV32F_INSN_OR_M_D_M, CRISV32F_SFMT_AND_M_D_M }, - { CRIS_INSN_ORCBR, CRISV32F_INSN_ORCBR, CRISV32F_SFMT_ANDCBR }, - { CRIS_INSN_ORCWR, CRISV32F_INSN_ORCWR, CRISV32F_SFMT_ANDCWR }, - { CRIS_INSN_ORCDR, CRISV32F_INSN_ORCDR, CRISV32F_SFMT_ANDCDR }, - { CRIS_INSN_ORQ, CRISV32F_INSN_ORQ, CRISV32F_SFMT_ANDQ }, - { CRIS_INSN_XOR, CRISV32F_INSN_XOR, CRISV32F_SFMT_DSTEP }, - { CRIS_INSN_SWAP, CRISV32F_INSN_SWAP, CRISV32F_SFMT_SWAP }, - { CRIS_INSN_ASRR_B_R, CRISV32F_INSN_ASRR_B_R, CRISV32F_SFMT_ASRR_B_R }, - { CRIS_INSN_ASRR_W_R, CRISV32F_INSN_ASRR_W_R, CRISV32F_SFMT_ASRR_B_R }, - { CRIS_INSN_ASRR_D_R, CRISV32F_INSN_ASRR_D_R, CRISV32F_SFMT_AND_D_R }, - { CRIS_INSN_ASRQ, CRISV32F_INSN_ASRQ, CRISV32F_SFMT_ASRQ }, - { CRIS_INSN_LSRR_B_R, CRISV32F_INSN_LSRR_B_R, CRISV32F_SFMT_LSRR_B_R }, - { CRIS_INSN_LSRR_W_R, CRISV32F_INSN_LSRR_W_R, CRISV32F_SFMT_LSRR_B_R }, - { CRIS_INSN_LSRR_D_R, CRISV32F_INSN_LSRR_D_R, CRISV32F_SFMT_LSRR_D_R }, - { CRIS_INSN_LSRQ, CRISV32F_INSN_LSRQ, CRISV32F_SFMT_ASRQ }, - { CRIS_INSN_LSLR_B_R, CRISV32F_INSN_LSLR_B_R, CRISV32F_SFMT_LSRR_B_R }, - { CRIS_INSN_LSLR_W_R, CRISV32F_INSN_LSLR_W_R, CRISV32F_SFMT_LSRR_B_R }, - { CRIS_INSN_LSLR_D_R, CRISV32F_INSN_LSLR_D_R, CRISV32F_SFMT_LSRR_D_R }, - { CRIS_INSN_LSLQ, CRISV32F_INSN_LSLQ, CRISV32F_SFMT_ASRQ }, - { CRIS_INSN_BTST, CRISV32F_INSN_BTST, CRISV32F_SFMT_BTST }, - { CRIS_INSN_BTSTQ, CRISV32F_INSN_BTSTQ, CRISV32F_SFMT_BTSTQ }, - { CRIS_INSN_SETF, CRISV32F_INSN_SETF, CRISV32F_SFMT_SETF }, - { CRIS_INSN_CLEARF, CRISV32F_INSN_CLEARF, CRISV32F_SFMT_SETF }, - { CRIS_INSN_RFE, CRISV32F_INSN_RFE, CRISV32F_SFMT_RFE }, - { CRIS_INSN_SFE, CRISV32F_INSN_SFE, CRISV32F_SFMT_SFE }, - { CRIS_INSN_RFG, CRISV32F_INSN_RFG, CRISV32F_SFMT_RFG }, - { CRIS_INSN_RFN, CRISV32F_INSN_RFN, CRISV32F_SFMT_RFN }, - { CRIS_INSN_HALT, CRISV32F_INSN_HALT, CRISV32F_SFMT_HALT }, - { CRIS_INSN_BCC_B, CRISV32F_INSN_BCC_B, CRISV32F_SFMT_BCC_B }, - { CRIS_INSN_BA_B, CRISV32F_INSN_BA_B, CRISV32F_SFMT_BA_B }, - { CRIS_INSN_BCC_W, CRISV32F_INSN_BCC_W, CRISV32F_SFMT_BCC_W }, - { CRIS_INSN_BA_W, CRISV32F_INSN_BA_W, CRISV32F_SFMT_BA_W }, - { CRIS_INSN_JAS_R, CRISV32F_INSN_JAS_R, CRISV32F_SFMT_JAS_R }, - { CRIS_INSN_JAS_C, CRISV32F_INSN_JAS_C, CRISV32F_SFMT_JAS_C }, - { CRIS_INSN_JUMP_P, CRISV32F_INSN_JUMP_P, CRISV32F_SFMT_JUMP_P }, - { CRIS_INSN_BAS_C, CRISV32F_INSN_BAS_C, CRISV32F_SFMT_BAS_C }, - { CRIS_INSN_JASC_R, CRISV32F_INSN_JASC_R, CRISV32F_SFMT_JASC_R }, - { CRIS_INSN_JASC_C, CRISV32F_INSN_JASC_C, CRISV32F_SFMT_JAS_C }, - { CRIS_INSN_BASC_C, CRISV32F_INSN_BASC_C, CRISV32F_SFMT_BAS_C }, - { CRIS_INSN_BREAK, CRISV32F_INSN_BREAK, CRISV32F_SFMT_BREAK }, - { CRIS_INSN_BOUND_R_B_R, CRISV32F_INSN_BOUND_R_B_R, CRISV32F_SFMT_DSTEP }, - { CRIS_INSN_BOUND_R_W_R, CRISV32F_INSN_BOUND_R_W_R, CRISV32F_SFMT_DSTEP }, - { CRIS_INSN_BOUND_R_D_R, CRISV32F_INSN_BOUND_R_D_R, CRISV32F_SFMT_DSTEP }, - { CRIS_INSN_BOUND_CB, CRISV32F_INSN_BOUND_CB, CRISV32F_SFMT_BOUND_CB }, - { CRIS_INSN_BOUND_CW, CRISV32F_INSN_BOUND_CW, CRISV32F_SFMT_BOUND_CW }, - { CRIS_INSN_BOUND_CD, CRISV32F_INSN_BOUND_CD, CRISV32F_SFMT_BOUND_CD }, - { CRIS_INSN_SCC, CRISV32F_INSN_SCC, CRISV32F_SFMT_SCC }, - { CRIS_INSN_LZ, CRISV32F_INSN_LZ, CRISV32F_SFMT_MOVS_B_R }, - { CRIS_INSN_ADDOQ, CRISV32F_INSN_ADDOQ, CRISV32F_SFMT_ADDOQ }, - { CRIS_INSN_ADDO_M_B_M, CRISV32F_INSN_ADDO_M_B_M, CRISV32F_SFMT_ADDO_M_B_M }, - { CRIS_INSN_ADDO_M_W_M, CRISV32F_INSN_ADDO_M_W_M, CRISV32F_SFMT_ADDO_M_W_M }, - { CRIS_INSN_ADDO_M_D_M, CRISV32F_INSN_ADDO_M_D_M, CRISV32F_SFMT_ADDO_M_D_M }, - { CRIS_INSN_ADDO_CB, CRISV32F_INSN_ADDO_CB, CRISV32F_SFMT_ADDO_CB }, - { CRIS_INSN_ADDO_CW, CRISV32F_INSN_ADDO_CW, CRISV32F_SFMT_ADDO_CW }, - { CRIS_INSN_ADDO_CD, CRISV32F_INSN_ADDO_CD, CRISV32F_SFMT_ADDO_CD }, - { CRIS_INSN_ADDI_ACR_B_R, CRISV32F_INSN_ADDI_ACR_B_R, CRISV32F_SFMT_ADDI_ACR_B_R }, - { CRIS_INSN_ADDI_ACR_W_R, CRISV32F_INSN_ADDI_ACR_W_R, CRISV32F_SFMT_ADDI_ACR_B_R }, - { CRIS_INSN_ADDI_ACR_D_R, CRISV32F_INSN_ADDI_ACR_D_R, CRISV32F_SFMT_ADDI_ACR_B_R }, - { CRIS_INSN_FIDXI, CRISV32F_INSN_FIDXI, CRISV32F_SFMT_FIDXI }, - { CRIS_INSN_FTAGI, CRISV32F_INSN_FTAGI, CRISV32F_SFMT_FIDXI }, - { CRIS_INSN_FIDXD, CRISV32F_INSN_FIDXD, CRISV32F_SFMT_FIDXI }, - { CRIS_INSN_FTAGD, CRISV32F_INSN_FTAGD, CRISV32F_SFMT_FIDXI }, -}; - -static const struct insn_sem crisv32f_insn_sem_invalid = { - VIRTUAL_INSN_X_INVALID, CRISV32F_INSN_X_INVALID, CRISV32F_SFMT_EMPTY -}; - -/* 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; - id->sfmt = t->sfmt; - 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_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 - - /* Semantic pointers are initialized elsewhere. */ -} - -/* Initialize the instruction descriptor table. */ - -void -crisv32f_init_idesc_table (SIM_CPU *cpu) -{ - IDESC *id,*tabend; - const struct insn_sem *t,*tend; - int tabsize = CRISV32F_INSN__MAX; - IDESC *table = crisv32f_insn_data; - - memset (table, 0, tabsize * sizeof (IDESC)); - - /* First set all entries to the `invalid insn'. */ - t = & crisv32f_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 = crisv32f_insn_sem, tend = t + sizeof (crisv32f_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 * -crisv32f_decode (SIM_CPU *current_cpu, IADDR pc, - CGEN_INSN_INT base_insn, - ARGBUF *abuf) -{ - /* Result of decoder. */ - CRISV32F_INSN_TYPE itype; - - { - CGEN_INSN_INT insn = base_insn; - - { - unsigned int val = (((insn >> 4) & (255 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : /* fall through */ - case 15 : - { - unsigned int val = (((insn >> 12) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 15 : - if ((base_insn & 0xf00) == 0x0) - { itype = CRISV32F_INSN_BCC_B; goto extract_sfmt_bcc_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 14 : - if ((base_insn & 0xff00) == 0xe000) - { itype = CRISV32F_INSN_BA_B; goto extract_sfmt_ba_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 16 : /* fall through */ - case 17 : /* fall through */ - case 18 : /* fall through */ - case 19 : /* fall through */ - case 20 : /* fall through */ - case 21 : /* fall through */ - case 22 : /* fall through */ - case 23 : /* fall through */ - case 24 : /* fall through */ - case 25 : /* fall through */ - case 26 : /* fall through */ - case 27 : /* fall through */ - case 28 : /* fall through */ - case 29 : /* fall through */ - case 30 : /* fall through */ - case 31 : - if ((base_insn & 0xf00) == 0x100) - { itype = CRISV32F_INSN_ADDOQ; goto extract_sfmt_addoq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 32 : /* fall through */ - case 33 : /* fall through */ - case 34 : /* fall through */ - case 35 : - if ((base_insn & 0xfc0) == 0x200) - { itype = CRISV32F_INSN_ADDQ; goto extract_sfmt_addq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 36 : /* fall through */ - case 37 : /* fall through */ - case 38 : /* fall through */ - case 39 : - if ((base_insn & 0xfc0) == 0x240) - { itype = CRISV32F_INSN_MOVEQ; goto extract_sfmt_moveq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 40 : /* fall through */ - case 41 : /* fall through */ - case 42 : /* fall through */ - case 43 : - if ((base_insn & 0xfc0) == 0x280) - { itype = CRISV32F_INSN_SUBQ; goto extract_sfmt_addq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 44 : /* fall through */ - case 45 : /* fall through */ - case 46 : /* fall through */ - case 47 : - if ((base_insn & 0xfc0) == 0x2c0) - { itype = CRISV32F_INSN_CMPQ; goto extract_sfmt_cmpq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 48 : /* fall through */ - case 49 : /* fall through */ - case 50 : /* fall through */ - case 51 : - if ((base_insn & 0xfc0) == 0x300) - { itype = CRISV32F_INSN_ANDQ; goto extract_sfmt_andq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 52 : /* fall through */ - case 53 : /* fall through */ - case 54 : /* fall through */ - case 55 : - if ((base_insn & 0xfc0) == 0x340) - { itype = CRISV32F_INSN_ORQ; goto extract_sfmt_andq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 56 : /* fall through */ - case 57 : - if ((base_insn & 0xfe0) == 0x380) - { itype = CRISV32F_INSN_BTSTQ; goto extract_sfmt_btstq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 58 : /* fall through */ - case 59 : - if ((base_insn & 0xfe0) == 0x3a0) - { itype = CRISV32F_INSN_ASRQ; goto extract_sfmt_asrq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 60 : /* fall through */ - case 61 : - if ((base_insn & 0xfe0) == 0x3c0) - { itype = CRISV32F_INSN_LSLQ; goto extract_sfmt_asrq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 62 : /* fall through */ - case 63 : - if ((base_insn & 0xfe0) == 0x3e0) - { itype = CRISV32F_INSN_LSRQ; goto extract_sfmt_asrq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 64 : - if ((base_insn & 0xff0) == 0x400) - { itype = CRISV32F_INSN_ADDU_B_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 65 : - if ((base_insn & 0xff0) == 0x410) - { itype = CRISV32F_INSN_ADDU_W_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 66 : - if ((base_insn & 0xff0) == 0x420) - { itype = CRISV32F_INSN_ADDS_B_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 67 : - if ((base_insn & 0xff0) == 0x430) - { itype = CRISV32F_INSN_ADDS_W_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 68 : - if ((base_insn & 0xff0) == 0x440) - { itype = CRISV32F_INSN_MOVU_B_R; goto extract_sfmt_movs_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 69 : - if ((base_insn & 0xff0) == 0x450) - { itype = CRISV32F_INSN_MOVU_W_R; goto extract_sfmt_movs_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 70 : - if ((base_insn & 0xff0) == 0x460) - { itype = CRISV32F_INSN_MOVS_B_R; goto extract_sfmt_movs_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 71 : - if ((base_insn & 0xff0) == 0x470) - { itype = CRISV32F_INSN_MOVS_W_R; goto extract_sfmt_movs_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 72 : - if ((base_insn & 0xff0) == 0x480) - { itype = CRISV32F_INSN_SUBU_B_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 73 : - if ((base_insn & 0xff0) == 0x490) - { itype = CRISV32F_INSN_SUBU_W_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 74 : - if ((base_insn & 0xff0) == 0x4a0) - { itype = CRISV32F_INSN_SUBS_B_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 75 : - if ((base_insn & 0xff0) == 0x4b0) - { itype = CRISV32F_INSN_SUBS_W_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 76 : - if ((base_insn & 0xff0) == 0x4c0) - { itype = CRISV32F_INSN_LSLR_B_R; goto extract_sfmt_lsrr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 77 : - if ((base_insn & 0xff0) == 0x4d0) - { itype = CRISV32F_INSN_LSLR_W_R; goto extract_sfmt_lsrr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 78 : - if ((base_insn & 0xff0) == 0x4e0) - { itype = CRISV32F_INSN_LSLR_D_R; goto extract_sfmt_lsrr_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 79 : - if ((base_insn & 0xff0) == 0x4f0) - { itype = CRISV32F_INSN_BTST; goto extract_sfmt_btst; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 80 : - if ((base_insn & 0xff0) == 0x500) - { itype = CRISV32F_INSN_ADDI_B_R; goto extract_sfmt_addi_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 81 : - if ((base_insn & 0xff0) == 0x510) - { itype = CRISV32F_INSN_ADDI_W_R; goto extract_sfmt_addi_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 82 : - if ((base_insn & 0xff0) == 0x520) - { itype = CRISV32F_INSN_ADDI_D_R; goto extract_sfmt_addi_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 83 : - if ((base_insn & 0xff0) == 0x530) - { itype = CRISV32F_INSN_SCC; goto extract_sfmt_scc; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 84 : - if ((base_insn & 0xff0) == 0x540) - { itype = CRISV32F_INSN_ADDI_ACR_B_R; goto extract_sfmt_addi_acr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 85 : - if ((base_insn & 0xff0) == 0x550) - { itype = CRISV32F_INSN_ADDI_ACR_W_R; goto extract_sfmt_addi_acr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 86 : - if ((base_insn & 0xff0) == 0x560) - { itype = CRISV32F_INSN_ADDI_ACR_D_R; goto extract_sfmt_addi_acr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 87 : - if ((base_insn & 0xff0) == 0x570) - { itype = CRISV32F_INSN_ADDC_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 88 : - if ((base_insn & 0xff0) == 0x580) - { itype = CRISV32F_INSN_NEG_B_R; goto extract_sfmt_neg_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 89 : - if ((base_insn & 0xff0) == 0x590) - { itype = CRISV32F_INSN_NEG_W_R; goto extract_sfmt_neg_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 90 : - if ((base_insn & 0xff0) == 0x5a0) - { itype = CRISV32F_INSN_NEG_D_R; goto extract_sfmt_neg_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 91 : - if ((base_insn & 0xff0) == 0x5b0) - { itype = CRISV32F_INSN_SETF; goto extract_sfmt_setf; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 92 : - if ((base_insn & 0xff0) == 0x5c0) - { itype = CRISV32F_INSN_BOUND_R_B_R; goto extract_sfmt_dstep; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 93 : - if ((base_insn & 0xff0) == 0x5d0) - { itype = CRISV32F_INSN_BOUND_R_W_R; goto extract_sfmt_dstep; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 94 : - if ((base_insn & 0xff0) == 0x5e0) - { itype = CRISV32F_INSN_BOUND_R_D_R; goto extract_sfmt_dstep; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 95 : - if ((base_insn & 0xff0) == 0x5f0) - { itype = CRISV32F_INSN_CLEARF; goto extract_sfmt_setf; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 96 : - if ((base_insn & 0xff0) == 0x600) - { itype = CRISV32F_INSN_ADD_B_R; goto extract_sfmt_add_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 97 : - if ((base_insn & 0xff0) == 0x610) - { itype = CRISV32F_INSN_ADD_W_R; goto extract_sfmt_add_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 98 : - if ((base_insn & 0xff0) == 0x620) - { itype = CRISV32F_INSN_ADD_D_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 99 : - if ((base_insn & 0xff0) == 0x630) - { itype = CRISV32F_INSN_MOVE_R_SPRV32; goto extract_sfmt_move_r_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 100 : - if ((base_insn & 0xff0) == 0x640) - { itype = CRISV32F_INSN_MOVE_B_R; goto extract_sfmt_move_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 101 : - if ((base_insn & 0xff0) == 0x650) - { itype = CRISV32F_INSN_MOVE_W_R; goto extract_sfmt_move_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 102 : - if ((base_insn & 0xff0) == 0x660) - { itype = CRISV32F_INSN_MOVE_D_R; goto extract_sfmt_move_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 103 : - if ((base_insn & 0xff0) == 0x670) - { itype = CRISV32F_INSN_MOVE_SPR_RV32; goto extract_sfmt_move_spr_rv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 104 : - if ((base_insn & 0xff0) == 0x680) - { itype = CRISV32F_INSN_SUB_B_R; goto extract_sfmt_add_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 105 : - if ((base_insn & 0xff0) == 0x690) - { itype = CRISV32F_INSN_SUB_W_R; goto extract_sfmt_add_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 106 : - if ((base_insn & 0xff0) == 0x6a0) - { itype = CRISV32F_INSN_SUB_D_R; goto extract_sfmt_add_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 107 : - if ((base_insn & 0xff0) == 0x6b0) - { itype = CRISV32F_INSN_ABS; goto extract_sfmt_movs_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 108 : - if ((base_insn & 0xff0) == 0x6c0) - { itype = CRISV32F_INSN_CMP_R_B_R; goto extract_sfmt_cmp_r_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 109 : - if ((base_insn & 0xff0) == 0x6d0) - { itype = CRISV32F_INSN_CMP_R_W_R; goto extract_sfmt_cmp_r_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 110 : - if ((base_insn & 0xff0) == 0x6e0) - { itype = CRISV32F_INSN_CMP_R_D_R; goto extract_sfmt_cmp_r_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 111 : - if ((base_insn & 0xff0) == 0x6f0) - { itype = CRISV32F_INSN_DSTEP; goto extract_sfmt_dstep; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 112 : - if ((base_insn & 0xff0) == 0x700) - { itype = CRISV32F_INSN_AND_B_R; goto extract_sfmt_and_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 113 : - if ((base_insn & 0xff0) == 0x710) - { itype = CRISV32F_INSN_AND_W_R; goto extract_sfmt_and_w_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 114 : - if ((base_insn & 0xff0) == 0x720) - { itype = CRISV32F_INSN_AND_D_R; goto extract_sfmt_and_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 115 : - if ((base_insn & 0xff0) == 0x730) - { itype = CRISV32F_INSN_LZ; goto extract_sfmt_movs_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 116 : - if ((base_insn & 0xff0) == 0x740) - { itype = CRISV32F_INSN_ORR_B_R; goto extract_sfmt_and_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 117 : - if ((base_insn & 0xff0) == 0x750) - { itype = CRISV32F_INSN_ORR_W_R; goto extract_sfmt_and_w_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 118 : - if ((base_insn & 0xff0) == 0x760) - { itype = CRISV32F_INSN_ORR_D_R; goto extract_sfmt_and_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 119 : - if ((base_insn & 0xff0) == 0x770) - { itype = CRISV32F_INSN_SWAP; goto extract_sfmt_swap; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 120 : - if ((base_insn & 0xff0) == 0x780) - { itype = CRISV32F_INSN_ASRR_B_R; goto extract_sfmt_asrr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 121 : - if ((base_insn & 0xff0) == 0x790) - { itype = CRISV32F_INSN_ASRR_W_R; goto extract_sfmt_asrr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 122 : - if ((base_insn & 0xff0) == 0x7a0) - { itype = CRISV32F_INSN_ASRR_D_R; goto extract_sfmt_and_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 123 : - if ((base_insn & 0xff0) == 0x7b0) - { itype = CRISV32F_INSN_XOR; goto extract_sfmt_dstep; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 124 : - if ((base_insn & 0xff0) == 0x7c0) - { itype = CRISV32F_INSN_LSRR_B_R; goto extract_sfmt_lsrr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 125 : - if ((base_insn & 0xff0) == 0x7d0) - { itype = CRISV32F_INSN_LSRR_W_R; goto extract_sfmt_lsrr_b_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 126 : - if ((base_insn & 0xff0) == 0x7e0) - { itype = CRISV32F_INSN_LSRR_D_R; goto extract_sfmt_lsrr_d_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 127 : - if ((base_insn & 0xff0) == 0x7f0) - { itype = CRISV32F_INSN_MCP; goto extract_sfmt_mcp; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 128 : - if ((base_insn & 0xbf0) == 0x800) - { itype = CRISV32F_INSN_ADDU_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 129 : - if ((base_insn & 0xbf0) == 0x810) - { itype = CRISV32F_INSN_ADDU_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 130 : - if ((base_insn & 0xbf0) == 0x820) - { itype = CRISV32F_INSN_ADDS_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 131 : - if ((base_insn & 0xbf0) == 0x830) - { itype = CRISV32F_INSN_ADDS_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 132 : - if ((base_insn & 0xbf0) == 0x840) - { itype = CRISV32F_INSN_MOVU_M_B_M; goto extract_sfmt_movs_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 133 : - if ((base_insn & 0xbf0) == 0x850) - { itype = CRISV32F_INSN_MOVU_M_W_M; goto extract_sfmt_movs_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 134 : - if ((base_insn & 0xbf0) == 0x860) - { itype = CRISV32F_INSN_MOVS_M_B_M; goto extract_sfmt_movs_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 135 : - if ((base_insn & 0xbf0) == 0x870) - { itype = CRISV32F_INSN_MOVS_M_W_M; goto extract_sfmt_movs_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 136 : - if ((base_insn & 0xbf0) == 0x880) - { itype = CRISV32F_INSN_SUBU_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 137 : - if ((base_insn & 0xbf0) == 0x890) - { itype = CRISV32F_INSN_SUBU_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 138 : - if ((base_insn & 0xbf0) == 0x8a0) - { itype = CRISV32F_INSN_SUBS_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 139 : - if ((base_insn & 0xbf0) == 0x8b0) - { itype = CRISV32F_INSN_SUBS_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 140 : - if ((base_insn & 0xbf0) == 0x8c0) - { itype = CRISV32F_INSN_CMPU_M_B_M; goto extract_sfmt_cmp_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 141 : - if ((base_insn & 0xbf0) == 0x8d0) - { itype = CRISV32F_INSN_CMPU_M_W_M; goto extract_sfmt_cmp_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 142 : - if ((base_insn & 0xbf0) == 0x8e0) - { itype = CRISV32F_INSN_CMPS_M_B_M; goto extract_sfmt_cmp_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 143 : - if ((base_insn & 0xbf0) == 0x8f0) - { itype = CRISV32F_INSN_CMPS_M_W_M; goto extract_sfmt_cmp_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 144 : - if ((base_insn & 0xff0) == 0x900) - { itype = CRISV32F_INSN_MULU_B; goto extract_sfmt_muls_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 145 : - if ((base_insn & 0xff0) == 0x910) - { itype = CRISV32F_INSN_MULU_W; goto extract_sfmt_muls_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 146 : - if ((base_insn & 0xff0) == 0x920) - { itype = CRISV32F_INSN_MULU_D; goto extract_sfmt_muls_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 147 : - { - unsigned int val = (((insn >> 12) & (15 << 0))); - switch (val) - { - case 2 : - if ((base_insn & 0xffff) == 0x2930) - { itype = CRISV32F_INSN_RFE; goto extract_sfmt_rfe; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 3 : - if ((base_insn & 0xffff) == 0x3930) - { itype = CRISV32F_INSN_SFE; goto extract_sfmt_sfe; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 4 : - if ((base_insn & 0xffff) == 0x4930) - { itype = CRISV32F_INSN_RFG; goto extract_sfmt_rfg; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 5 : - if ((base_insn & 0xffff) == 0x5930) - { itype = CRISV32F_INSN_RFN; goto extract_sfmt_rfn; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 14 : - if ((base_insn & 0xfff0) == 0xe930) - { itype = CRISV32F_INSN_BREAK; goto extract_sfmt_break; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0xf930) - { itype = CRISV32F_INSN_HALT; goto extract_sfmt_halt; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 148 : - if ((base_insn & 0xbf0) == 0x940) - { itype = CRISV32F_INSN_ADDO_M_B_M; goto extract_sfmt_addo_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 149 : - if ((base_insn & 0xbf0) == 0x950) - { itype = CRISV32F_INSN_ADDO_M_W_M; goto extract_sfmt_addo_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 150 : - if ((base_insn & 0xbf0) == 0x960) - { itype = CRISV32F_INSN_ADDO_M_D_M; goto extract_sfmt_addo_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 151 : - if ((base_insn & 0xff0) == 0x970) - { itype = CRISV32F_INSN_LAPCQ; goto extract_sfmt_lapcq; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 154 : - if ((base_insn & 0xbf0) == 0x9a0) - { itype = CRISV32F_INSN_ADDC_M; goto extract_sfmt_addc_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 155 : - if ((base_insn & 0xff0) == 0x9b0) - { itype = CRISV32F_INSN_JAS_R; goto extract_sfmt_jas_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 159 : - if ((base_insn & 0xfff) == 0x9f0) - { itype = CRISV32F_INSN_JUMP_P; goto extract_sfmt_jump_p; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 160 : - if ((base_insn & 0xbf0) == 0xa00) - { itype = CRISV32F_INSN_ADD_M_B_M; goto extract_sfmt_add_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 161 : - if ((base_insn & 0xbf0) == 0xa10) - { itype = CRISV32F_INSN_ADD_M_W_M; goto extract_sfmt_add_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 162 : - if ((base_insn & 0xbf0) == 0xa20) - { itype = CRISV32F_INSN_ADD_M_D_M; goto extract_sfmt_add_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 163 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 164 : - if ((base_insn & 0xbf0) == 0xa40) - { itype = CRISV32F_INSN_MOVE_M_B_M; goto extract_sfmt_move_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 165 : - if ((base_insn & 0xbf0) == 0xa50) - { itype = CRISV32F_INSN_MOVE_M_W_M; goto extract_sfmt_move_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 166 : - if ((base_insn & 0xbf0) == 0xa60) - { itype = CRISV32F_INSN_MOVE_M_D_M; goto extract_sfmt_move_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 167 : /* fall through */ - case 231 : - if ((base_insn & 0xbf0) == 0xa70) - { itype = CRISV32F_INSN_MOVE_SPR_MV32; goto extract_sfmt_move_spr_mv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 168 : - if ((base_insn & 0xbf0) == 0xa80) - { itype = CRISV32F_INSN_SUB_M_B_M; goto extract_sfmt_add_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 169 : - if ((base_insn & 0xbf0) == 0xa90) - { itype = CRISV32F_INSN_SUB_M_W_M; goto extract_sfmt_add_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 170 : - if ((base_insn & 0xbf0) == 0xaa0) - { itype = CRISV32F_INSN_SUB_M_D_M; goto extract_sfmt_add_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 171 : - { - unsigned int val = (((insn >> 12) & (1 << 0))); - switch (val) - { - case 0 : - if ((base_insn & 0xfff0) == 0xab0) - { itype = CRISV32F_INSN_FIDXD; goto extract_sfmt_fidxi; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 1 : - if ((base_insn & 0xfff0) == 0x1ab0) - { itype = CRISV32F_INSN_FTAGD; goto extract_sfmt_fidxi; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 172 : - if ((base_insn & 0xbf0) == 0xac0) - { itype = CRISV32F_INSN_CMP_M_B_M; goto extract_sfmt_cmp_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 173 : - if ((base_insn & 0xbf0) == 0xad0) - { itype = CRISV32F_INSN_CMP_M_W_M; goto extract_sfmt_cmp_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 174 : - if ((base_insn & 0xbf0) == 0xae0) - { itype = CRISV32F_INSN_CMP_M_D_M; goto extract_sfmt_cmp_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 176 : - if ((base_insn & 0xbf0) == 0xb00) - { itype = CRISV32F_INSN_AND_M_B_M; goto extract_sfmt_and_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 177 : - if ((base_insn & 0xbf0) == 0xb10) - { itype = CRISV32F_INSN_AND_M_W_M; goto extract_sfmt_and_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 178 : - if ((base_insn & 0xbf0) == 0xb20) - { itype = CRISV32F_INSN_AND_M_D_M; goto extract_sfmt_and_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 179 : - if ((base_insn & 0xff0) == 0xb30) - { itype = CRISV32F_INSN_JASC_R; goto extract_sfmt_jasc_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 180 : - if ((base_insn & 0xbf0) == 0xb40) - { itype = CRISV32F_INSN_OR_M_B_M; goto extract_sfmt_and_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 181 : - if ((base_insn & 0xbf0) == 0xb50) - { itype = CRISV32F_INSN_OR_M_W_M; goto extract_sfmt_and_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 182 : - if ((base_insn & 0xbf0) == 0xb60) - { itype = CRISV32F_INSN_OR_M_D_M; goto extract_sfmt_and_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 183 : - if ((base_insn & 0xff0) == 0xb70) - { itype = CRISV32F_INSN_MOVE_R_SS; goto extract_sfmt_move_r_ss; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 184 : /* fall through */ - case 248 : - if ((base_insn & 0xfbf0) == 0xb80) - { itype = CRISV32F_INSN_TEST_M_B_M; goto extract_sfmt_test_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 185 : /* fall through */ - case 249 : - if ((base_insn & 0xfbf0) == 0xb90) - { itype = CRISV32F_INSN_TEST_M_W_M; goto extract_sfmt_test_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 186 : /* fall through */ - case 250 : - if ((base_insn & 0xfbf0) == 0xba0) - { itype = CRISV32F_INSN_TEST_M_D_M; goto extract_sfmt_test_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 187 : /* fall through */ - case 251 : - if ((base_insn & 0xbf0) == 0xbb0) - { itype = CRISV32F_INSN_MOVEM_M_R_V32; goto extract_sfmt_movem_m_r_v32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 188 : /* fall through */ - case 252 : - if ((base_insn & 0xbf0) == 0xbc0) - { itype = CRISV32F_INSN_MOVE_R_M_B_M; goto extract_sfmt_move_r_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 189 : /* fall through */ - case 253 : - if ((base_insn & 0xbf0) == 0xbd0) - { itype = CRISV32F_INSN_MOVE_R_M_W_M; goto extract_sfmt_move_r_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 190 : /* fall through */ - case 254 : - if ((base_insn & 0xbf0) == 0xbe0) - { itype = CRISV32F_INSN_MOVE_R_M_D_M; goto extract_sfmt_move_r_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 191 : /* fall through */ - case 255 : - if ((base_insn & 0xbf0) == 0xbf0) - { itype = CRISV32F_INSN_MOVEM_R_M_V32; goto extract_sfmt_movem_r_m_v32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 192 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x800) - { itype = CRISV32F_INSN_ADDU_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc0f) - { itype = CRISV32F_INSN_ADDUCBR; goto extract_sfmt_addscbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 193 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x810) - { itype = CRISV32F_INSN_ADDU_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc1f) - { itype = CRISV32F_INSN_ADDUCWR; goto extract_sfmt_addscwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 194 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x820) - { itype = CRISV32F_INSN_ADDS_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc2f) - { itype = CRISV32F_INSN_ADDSCBR; goto extract_sfmt_addscbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 195 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x830) - { itype = CRISV32F_INSN_ADDS_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc3f) - { itype = CRISV32F_INSN_ADDSCWR; goto extract_sfmt_addscwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 196 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x840) - { itype = CRISV32F_INSN_MOVU_M_B_M; goto extract_sfmt_movs_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc4f) - { itype = CRISV32F_INSN_MOVUCBR; goto extract_sfmt_movucbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 197 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x850) - { itype = CRISV32F_INSN_MOVU_M_W_M; goto extract_sfmt_movs_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc5f) - { itype = CRISV32F_INSN_MOVUCWR; goto extract_sfmt_movucwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 198 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x860) - { itype = CRISV32F_INSN_MOVS_M_B_M; goto extract_sfmt_movs_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc6f) - { itype = CRISV32F_INSN_MOVSCBR; goto extract_sfmt_movscbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 199 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x870) - { itype = CRISV32F_INSN_MOVS_M_W_M; goto extract_sfmt_movs_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc7f) - { itype = CRISV32F_INSN_MOVSCWR; goto extract_sfmt_movscwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 200 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x880) - { itype = CRISV32F_INSN_SUBU_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc8f) - { itype = CRISV32F_INSN_SUBUCBR; goto extract_sfmt_addscbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 201 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x890) - { itype = CRISV32F_INSN_SUBU_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xc9f) - { itype = CRISV32F_INSN_SUBUCWR; goto extract_sfmt_addscwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 202 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x8a0) - { itype = CRISV32F_INSN_SUBS_M_B_M; goto extract_sfmt_adds_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xcaf) - { itype = CRISV32F_INSN_SUBSCBR; goto extract_sfmt_addscbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 203 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x8b0) - { itype = CRISV32F_INSN_SUBS_M_W_M; goto extract_sfmt_adds_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xcbf) - { itype = CRISV32F_INSN_SUBSCWR; goto extract_sfmt_addscwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 204 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x8c0) - { itype = CRISV32F_INSN_CMPU_M_B_M; goto extract_sfmt_cmp_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xccf) - { itype = CRISV32F_INSN_CMPUCBR; goto extract_sfmt_cmpucbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 205 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x8d0) - { itype = CRISV32F_INSN_CMPU_M_W_M; goto extract_sfmt_cmp_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xcdf) - { itype = CRISV32F_INSN_CMPUCWR; goto extract_sfmt_cmpucwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 206 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x8e0) - { itype = CRISV32F_INSN_CMPS_M_B_M; goto extract_sfmt_cmp_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xcef) - { itype = CRISV32F_INSN_CMPSCBR; goto extract_sfmt_cmpcbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 207 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x8f0) - { itype = CRISV32F_INSN_CMPS_M_W_M; goto extract_sfmt_cmp_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xcff) - { itype = CRISV32F_INSN_CMPSCWR; goto extract_sfmt_cmpcwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 208 : - if ((base_insn & 0xff0) == 0xd00) - { itype = CRISV32F_INSN_MULS_B; goto extract_sfmt_muls_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 209 : - if ((base_insn & 0xff0) == 0xd10) - { itype = CRISV32F_INSN_MULS_W; goto extract_sfmt_muls_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 210 : - if ((base_insn & 0xff0) == 0xd20) - { itype = CRISV32F_INSN_MULS_D; goto extract_sfmt_muls_b; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 211 : - { - unsigned int val = (((insn >> 12) & (1 << 0))); - switch (val) - { - case 0 : - if ((base_insn & 0xfff0) == 0xd30) - { itype = CRISV32F_INSN_FIDXI; goto extract_sfmt_fidxi; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 1 : - if ((base_insn & 0xfff0) == 0x1d30) - { itype = CRISV32F_INSN_FTAGI; goto extract_sfmt_fidxi; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 212 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x940) - { itype = CRISV32F_INSN_ADDO_M_B_M; goto extract_sfmt_addo_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xd4f) - { itype = CRISV32F_INSN_ADDO_CB; goto extract_sfmt_addo_cb; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 213 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x950) - { itype = CRISV32F_INSN_ADDO_M_W_M; goto extract_sfmt_addo_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xd5f) - { itype = CRISV32F_INSN_ADDO_CW; goto extract_sfmt_addo_cw; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 214 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x960) - { itype = CRISV32F_INSN_ADDO_M_D_M; goto extract_sfmt_addo_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xd6f) - { itype = CRISV32F_INSN_ADDO_CD; goto extract_sfmt_addo_cd; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 215 : - if ((base_insn & 0xfff) == 0xd7f) - { itype = CRISV32F_INSN_LAPC_D; goto extract_sfmt_lapc_d; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 218 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0x9a0) - { itype = CRISV32F_INSN_ADDC_M; goto extract_sfmt_addc_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xdaf) - { itype = CRISV32F_INSN_ADDC_C; goto extract_sfmt_addcdr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 219 : - if ((base_insn & 0xfff) == 0xdbf) - { itype = CRISV32F_INSN_JAS_C; goto extract_sfmt_jas_c; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 220 : - if ((base_insn & 0xfff) == 0xdcf) - { itype = CRISV32F_INSN_BOUND_CB; goto extract_sfmt_bound_cb; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 221 : - if ((base_insn & 0xfff) == 0xddf) - { itype = CRISV32F_INSN_BOUND_CW; goto extract_sfmt_bound_cw; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 222 : - if ((base_insn & 0xfff) == 0xdef) - { itype = CRISV32F_INSN_BOUND_CD; goto extract_sfmt_bound_cd; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 223 : - { - unsigned int val = (((insn >> 12) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 15 : - if ((base_insn & 0xfff) == 0xdff) - { itype = CRISV32F_INSN_BCC_W; goto extract_sfmt_bcc_w; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 14 : - if ((base_insn & 0xffff) == 0xedff) - { itype = CRISV32F_INSN_BA_W; goto extract_sfmt_ba_w; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 224 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa00) - { itype = CRISV32F_INSN_ADD_M_B_M; goto extract_sfmt_add_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe0f) - { itype = CRISV32F_INSN_ADDCBR; goto extract_sfmt_addcbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 225 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa10) - { itype = CRISV32F_INSN_ADD_M_W_M; goto extract_sfmt_add_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe1f) - { itype = CRISV32F_INSN_ADDCWR; goto extract_sfmt_addcwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 226 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa20) - { itype = CRISV32F_INSN_ADD_M_D_M; goto extract_sfmt_add_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe2f) - { itype = CRISV32F_INSN_ADDCDR; goto extract_sfmt_addcdr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 227 : - { - unsigned int val = (((insn >> 12) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 4 : /* fall through */ - case 8 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 2 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0x2e3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P2; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 3 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0x3e3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P3; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 5 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0x5e3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P5; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 6 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0x6e3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P6; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 7 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0x7e3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P7; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 9 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0x9e3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P9; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 10 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0xae3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P10; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 11 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0xbe3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P11; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 12 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0xce3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P12; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 13 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0xde3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P13; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 14 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0xee3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P14; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 15 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa30) - { itype = CRISV32F_INSN_MOVE_M_SPRV32; goto extract_sfmt_move_m_sprv32; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xffff) == 0xfe3f) - { itype = CRISV32F_INSN_MOVE_C_SPRV32_P15; goto extract_sfmt_move_c_sprv32_p2; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 228 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa40) - { itype = CRISV32F_INSN_MOVE_M_B_M; goto extract_sfmt_move_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe4f) - { itype = CRISV32F_INSN_MOVECBR; goto extract_sfmt_movecbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 229 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa50) - { itype = CRISV32F_INSN_MOVE_M_W_M; goto extract_sfmt_move_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe5f) - { itype = CRISV32F_INSN_MOVECWR; goto extract_sfmt_movecwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 230 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa60) - { itype = CRISV32F_INSN_MOVE_M_D_M; goto extract_sfmt_move_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe6f) - { itype = CRISV32F_INSN_MOVECDR; goto extract_sfmt_movecdr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 232 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa80) - { itype = CRISV32F_INSN_SUB_M_B_M; goto extract_sfmt_add_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe8f) - { itype = CRISV32F_INSN_SUBCBR; goto extract_sfmt_addcbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 233 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xa90) - { itype = CRISV32F_INSN_SUB_M_W_M; goto extract_sfmt_add_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xe9f) - { itype = CRISV32F_INSN_SUBCWR; goto extract_sfmt_addcwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 234 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xaa0) - { itype = CRISV32F_INSN_SUB_M_D_M; goto extract_sfmt_add_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xeaf) - { itype = CRISV32F_INSN_SUBCDR; goto extract_sfmt_addcdr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 235 : - if ((base_insn & 0xfff) == 0xebf) - { itype = CRISV32F_INSN_BAS_C; goto extract_sfmt_bas_c; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 236 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xac0) - { itype = CRISV32F_INSN_CMP_M_B_M; goto extract_sfmt_cmp_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xecf) - { itype = CRISV32F_INSN_CMPCBR; goto extract_sfmt_cmpcbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 237 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xad0) - { itype = CRISV32F_INSN_CMP_M_W_M; goto extract_sfmt_cmp_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xedf) - { itype = CRISV32F_INSN_CMPCWR; goto extract_sfmt_cmpcwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 238 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xae0) - { itype = CRISV32F_INSN_CMP_M_D_M; goto extract_sfmt_cmp_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xeef) - { itype = CRISV32F_INSN_CMPCDR; goto extract_sfmt_cmpcdr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 239 : - if ((base_insn & 0xfff) == 0xeff) - { itype = CRISV32F_INSN_BASC_C; goto extract_sfmt_bas_c; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 240 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xb00) - { itype = CRISV32F_INSN_AND_M_B_M; goto extract_sfmt_and_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xf0f) - { itype = CRISV32F_INSN_ANDCBR; goto extract_sfmt_andcbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 241 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xb10) - { itype = CRISV32F_INSN_AND_M_W_M; goto extract_sfmt_and_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xf1f) - { itype = CRISV32F_INSN_ANDCWR; goto extract_sfmt_andcwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 242 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xb20) - { itype = CRISV32F_INSN_AND_M_D_M; goto extract_sfmt_and_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xf2f) - { itype = CRISV32F_INSN_ANDCDR; goto extract_sfmt_andcdr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 243 : - if ((base_insn & 0xfff) == 0xf3f) - { itype = CRISV32F_INSN_JASC_C; goto extract_sfmt_jas_c; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 244 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xb40) - { itype = CRISV32F_INSN_OR_M_B_M; goto extract_sfmt_and_m_b_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xf4f) - { itype = CRISV32F_INSN_ORCBR; goto extract_sfmt_andcbr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 245 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xb50) - { itype = CRISV32F_INSN_OR_M_W_M; goto extract_sfmt_and_m_w_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xf5f) - { itype = CRISV32F_INSN_ORCWR; goto extract_sfmt_andcwr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 246 : - { - unsigned int val = (((insn >> 0) & (15 << 0))); - switch (val) - { - case 0 : /* fall through */ - case 1 : /* fall through */ - case 2 : /* fall through */ - case 3 : /* fall through */ - case 4 : /* fall through */ - case 5 : /* fall through */ - case 6 : /* fall through */ - case 7 : /* fall through */ - case 8 : /* fall through */ - case 9 : /* fall through */ - case 10 : /* fall through */ - case 11 : /* fall through */ - case 12 : /* fall through */ - case 13 : /* fall through */ - case 14 : - if ((base_insn & 0xbf0) == 0xb60) - { itype = CRISV32F_INSN_OR_M_D_M; goto extract_sfmt_and_m_d_m; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - case 15 : - if ((base_insn & 0xfff) == 0xf6f) - { itype = CRISV32F_INSN_ORCDR; goto extract_sfmt_andcdr; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - case 247 : - if ((base_insn & 0xff0) == 0xf70) - { itype = CRISV32F_INSN_MOVE_SS_R; goto extract_sfmt_move_ss_r; } - itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - default : itype = CRISV32F_INSN_X_INVALID; goto extract_sfmt_empty; - } - } - } - - /* The instruction has been decoded, now extract the fields. */ - - extract_sfmt_empty: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; -#define FLD(f) abuf->fields.fmt_empty.f - - - /* Record the fields for the semantic handler. */ - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_empty", (char *) 0)); - -#undef FLD - return idesc; - } - - extract_sfmt_move_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_b_r", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_d_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_d_r", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_moveq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_moveq.f - UINT f_operand2; - INT f_s6; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_s6 = EXTRACT_LSB0_INT (insn, 16, 5, 6); - - /* Record the fields for the semantic handler. */ - FLD (f_s6) = f_s6; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_moveq", "f_s6 0x%x", 'x', f_s6, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movs_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_muls_b.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movs_b_r", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movecbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcbr.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movecbr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movecwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcwr.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movecwr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movecdr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cd.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_indir_pc__dword) = f_indir_pc__dword; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movecdr", "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movscbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cb.f - UINT f_operand2; - INT f_indir_pc__byte; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - - /* Record the fields for the semantic handler. */ - FLD (f_indir_pc__byte) = f_indir_pc__byte; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movscbr", "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movscwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cw.f - UINT f_operand2; - INT f_indir_pc__word; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - - /* Record the fields for the semantic handler. */ - FLD (f_indir_pc__word) = f_indir_pc__word; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movscwr", "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movucbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cb.f - UINT f_operand2; - INT f_indir_pc__byte; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - - /* Record the fields for the semantic handler. */ - FLD (f_indir_pc__byte) = f_indir_pc__byte; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movucbr", "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movucwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cw.f - UINT f_operand2; - INT f_indir_pc__word; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - - /* Record the fields for the semantic handler. */ - FLD (f_indir_pc__word) = f_indir_pc__word; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movucwr", "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addq.f - UINT f_operand2; - UINT f_u6; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_u6 = EXTRACT_LSB0_UINT (insn, 16, 5, 6); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_u6) = f_u6; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addq", "f_operand2 0x%x", 'x', f_operand2, "f_u6 0x%x", 'x', f_u6, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmp_r_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_muls_b.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmp_r_b_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmp_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmp_m_b_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmp_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmp_m_w_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmp_m_d_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmp_m_d_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmpcbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cb.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpcbr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmpcwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cw.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpcwr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmpcdr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cd.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__dword) = f_indir_pc__dword; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpcdr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmpq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_andq.f - UINT f_operand2; - INT f_s6; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_s6 = EXTRACT_LSB0_INT (insn, 16, 5, 6); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_s6) = f_s6; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpq", "f_operand2 0x%x", 'x', f_operand2, "f_s6 0x%x", 'x', f_s6, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmpucbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cb.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpucbr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_cmpucwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cw.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpucwr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_m_b_m", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_m_w_m", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_m_d_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_m_d_m", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movs_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_movs_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movs_m_b_m", "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rd) = f_operand2; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movs_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_movs_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movs_m_w_m", "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rd) = f_operand2; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_r_sprv32: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_m_sprv32.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_r_sprv32", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Pd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_spr_rv32: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_mcp.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_spr_rv32", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Ps) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rs) = FLD (f_operand1); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_m_sprv32: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_m_sprv32.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_m_sprv32", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Pd) = f_operand2; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_c_sprv32_p2: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_indir_pc__dword) = f_indir_pc__dword; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_c_sprv32_p2", "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Pd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_spr_mv32: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_spr_mv32.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_spr_mv32", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Ps) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_ss_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_spr_mv32.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_ss_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_r_ss: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_mcp.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_r_ss", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movem_r_m_v32: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_movem_r_m_v32.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movem_r_m_v32", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (in_h_gr_SI_0) = 0; - FLD (in_h_gr_SI_1) = 1; - FLD (in_h_gr_SI_10) = 10; - FLD (in_h_gr_SI_11) = 11; - FLD (in_h_gr_SI_12) = 12; - FLD (in_h_gr_SI_13) = 13; - FLD (in_h_gr_SI_14) = 14; - FLD (in_h_gr_SI_15) = 15; - FLD (in_h_gr_SI_2) = 2; - FLD (in_h_gr_SI_3) = 3; - FLD (in_h_gr_SI_4) = 4; - FLD (in_h_gr_SI_5) = 5; - FLD (in_h_gr_SI_6) = 6; - FLD (in_h_gr_SI_7) = 7; - FLD (in_h_gr_SI_8) = 8; - FLD (in_h_gr_SI_9) = 9; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_movem_m_r_v32: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_movem_m_r_v32.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_movem_m_r_v32", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_0) = 0; - FLD (out_h_gr_SI_1) = 1; - FLD (out_h_gr_SI_10) = 10; - FLD (out_h_gr_SI_11) = 11; - FLD (out_h_gr_SI_12) = 12; - FLD (out_h_gr_SI_13) = 13; - FLD (out_h_gr_SI_14) = 14; - FLD (out_h_gr_SI_15) = 15; - FLD (out_h_gr_SI_2) = 2; - FLD (out_h_gr_SI_3) = 3; - FLD (out_h_gr_SI_4) = 4; - FLD (out_h_gr_SI_5) = 5; - FLD (out_h_gr_SI_6) = 6; - FLD (out_h_gr_SI_7) = 7; - FLD (out_h_gr_SI_8) = 8; - FLD (out_h_gr_SI_9) = 9; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_add_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_add_b_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_add_d_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_add_d_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_add_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_add_m_b_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_add_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_add_m_w_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_add_m_d_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_add_m_d_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addcbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcbr.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addcbr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addcwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcwr.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addcwr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addcdr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcdr.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__dword) = f_indir_pc__dword; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addcdr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_adds_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_adds_m_b_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_adds_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_adds_m_w_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addscbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcbr.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addscbr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addscwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcwr.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addscwr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addc_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addc_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_lapc_d: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_lapc_d.f - SI f_indir_pc__dword_pcrel; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword_pcrel = ((pc) + ((0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)))); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (i_const32_pcrel) = f_indir_pc__dword_pcrel; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_lapc_d", "f_operand2 0x%x", 'x', f_operand2, "const32_pcrel 0x%x", 'x', f_indir_pc__dword_pcrel, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_lapcq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_lapcq.f - UINT f_operand2; - SI f_qo; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_qo = ((pc) + (((EXTRACT_LSB0_UINT (insn, 16, 3, 4)) << (1)))); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (i_qo) = f_qo; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_lapcq", "f_operand2 0x%x", 'x', f_operand2, "qo 0x%x", 'x', f_qo, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addi_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addi_b_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_neg_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_neg_b_r", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_neg_d_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_neg_d_r", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_test_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_spr_mv32.f - UINT f_memmode; - UINT f_operand1; - - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_test_m_b_m", "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_test_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_spr_mv32.f - UINT f_memmode; - UINT f_operand1; - - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_test_m_w_m", "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_test_m_d_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_spr_mv32.f - UINT f_memmode; - UINT f_operand1; - - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_test_m_d_m", "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_r_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_r_m_b_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_r_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_r_m_w_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_move_r_m_d_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_move_r_m_d_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_muls_b: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_muls_b.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_muls_b", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rd) = f_operand2; - FLD (out_h_sr_SI_7) = 7; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_mcp: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_mcp.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mcp", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Ps) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rs) = FLD (f_operand1); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_dstep: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_muls_b.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_dstep", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_and_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_and_b_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_and_w_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_and_w_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_and_d_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_and_d_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_and_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_and_m_b_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_and_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_and_m_w_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_and_m_d_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_add_m_b_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_and_m_d_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - FLD (out_h_gr_SI_if__SI_andif__DFLT_prefix_set_not__DFLT_inc_index_of__DFLT_Rs_index_of__DFLT_Rd) = ((ANDIF (GET_H_INSN_PREFIXED_P (), (! (FLD (f_memmode))))) ? (FLD (f_operand1)) : (FLD (f_operand2))); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_andcbr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcbr.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_andcbr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_andcwr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcwr.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_andcwr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_andcdr: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addcdr.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__dword) = f_indir_pc__dword; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_andcdr", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_andq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_andq.f - UINT f_operand2; - INT f_s6; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_s6 = EXTRACT_LSB0_INT (insn, 16, 5, 6); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_s6) = f_s6; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_andq", "f_operand2 0x%x", 'x', f_operand2, "f_s6 0x%x", 'x', f_s6, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_swap: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_spr_mv32.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_swap", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_asrr_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_asrr_b_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_asrq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_asrq.f - UINT f_operand2; - UINT f_u5; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_u5 = EXTRACT_LSB0_UINT (insn, 16, 4, 5); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_u5) = f_u5; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_asrq", "f_operand2 0x%x", 'x', f_operand2, "f_u5 0x%x", 'x', f_u5, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_lsrr_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_lsrr_b_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_lsrr_d_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_lsrr_d_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_h_gr_SI_index_of__DFLT_Rd) = FLD (f_operand2); - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_btst: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_muls_b.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_btst", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_btstq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_asrq.f - UINT f_operand2; - UINT f_u5; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_u5 = EXTRACT_LSB0_UINT (insn, 16, 4, 5); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_u5) = f_u5; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_btstq", "f_operand2 0x%x", 'x', f_operand2, "f_u5 0x%x", 'x', f_u5, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_setf: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_setf.f - UINT f_operand2; - UINT f_operand1; - UINT f_dstsrc; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - f_dstsrc = ((((f_operand1) | (((f_operand2) << (4))))) & (255)); - - /* Record the fields for the semantic handler. */ - FLD (f_dstsrc) = f_dstsrc; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_setf", "f_dstsrc 0x%x", 'x', f_dstsrc, (char *) 0)); - -#undef FLD - return idesc; - } - - extract_sfmt_rfe: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; -#define FLD(f) abuf->fields.sfmt_rfe.f - - - /* Record the fields for the semantic handler. */ - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_rfe", (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_h_sr_SI_13) = 13; - FLD (out_h_sr_SI_13) = 13; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_sfe: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; -#define FLD(f) abuf->fields.sfmt_rfe.f - - - /* Record the fields for the semantic handler. */ - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sfe", (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_h_sr_SI_13) = 13; - FLD (out_h_sr_SI_13) = 13; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_rfg: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; -#define FLD(f) abuf->fields.fmt_empty.f - - - /* Record the fields for the semantic handler. */ - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_rfg", (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_rfn: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; -#define FLD(f) abuf->fields.sfmt_rfe.f - - - /* Record the fields for the semantic handler. */ - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_rfn", (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_h_sr_SI_13) = 13; - FLD (out_h_sr_SI_13) = 13; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_halt: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; -#define FLD(f) abuf->fields.fmt_empty.f - - - /* Record the fields for the semantic handler. */ - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_halt", (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_bcc_b: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bcc_b.f - UINT f_operand2; - UINT f_disp9_lo; - INT f_disp9_hi; - INT f_disp9; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_disp9_lo = EXTRACT_LSB0_UINT (insn, 16, 7, 7); - f_disp9_hi = EXTRACT_LSB0_INT (insn, 16, 0, 1); -{ - SI tmp_abslo; - SI tmp_absval; - tmp_abslo = ((f_disp9_lo) << (1)); - tmp_absval = ((((((f_disp9_hi) != (0))) ? ((~ (255))) : (0))) | (tmp_abslo)); - f_disp9 = ((((pc) + (tmp_absval))) + (((GET_H_V32_V32 ()) ? (0) : (2)))); -} - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (i_o_pcrel) = f_disp9; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bcc_b", "f_operand2 0x%x", 'x', f_operand2, "o_pcrel 0x%x", 'x', f_disp9, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_ba_b: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bcc_b.f - UINT f_disp9_lo; - INT f_disp9_hi; - INT f_disp9; - - f_disp9_lo = EXTRACT_LSB0_UINT (insn, 16, 7, 7); - f_disp9_hi = EXTRACT_LSB0_INT (insn, 16, 0, 1); -{ - SI tmp_abslo; - SI tmp_absval; - tmp_abslo = ((f_disp9_lo) << (1)); - tmp_absval = ((((((f_disp9_hi) != (0))) ? ((~ (255))) : (0))) | (tmp_abslo)); - f_disp9 = ((((pc) + (tmp_absval))) + (((GET_H_V32_V32 ()) ? (0) : (2)))); -} - - /* Record the fields for the semantic handler. */ - FLD (i_o_pcrel) = f_disp9; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ba_b", "o_pcrel 0x%x", 'x', f_disp9, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_bcc_w: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bcc_w.f - SI f_indir_pc__word_pcrel; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word_pcrel = ((EXTHISI (((HI) (UINT) ((0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)))))) + (((pc) + (((GET_H_V32_V32 ()) ? (0) : (4)))))); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (i_o_word_pcrel) = f_indir_pc__word_pcrel; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bcc_w", "f_operand2 0x%x", 'x', f_operand2, "o_word_pcrel 0x%x", 'x', f_indir_pc__word_pcrel, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_ba_w: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bcc_w.f - SI f_indir_pc__word_pcrel; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word_pcrel = ((EXTHISI (((HI) (UINT) ((0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)))))) + (((pc) + (((GET_H_V32_V32 ()) ? (0) : (4)))))); - - /* Record the fields for the semantic handler. */ - FLD (i_o_word_pcrel) = f_indir_pc__word_pcrel; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ba_w", "o_word_pcrel 0x%x", 'x', f_indir_pc__word_pcrel, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_jas_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_m_sprv32.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jas_r", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Pd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_jas_c: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_c_sprv32_p2.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_indir_pc__dword) = f_indir_pc__dword; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jas_c", "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Pd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_jump_p: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_mcp.f - UINT f_operand2; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jump_p", "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Ps) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_bas_c: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bas_c.f - SI f_indir_pc__dword_pcrel; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword_pcrel = ((pc) + ((0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)))); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (i_const32_pcrel) = f_indir_pc__dword_pcrel; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bas_c", "f_operand2 0x%x", 'x', f_operand2, "const32_pcrel 0x%x", 'x', f_indir_pc__dword_pcrel, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Pd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_jasc_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_m_sprv32.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - FLD (f_operand2) = f_operand2; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jasc_r", "f_operand1 0x%x", 'x', f_operand1, "f_operand2 0x%x", 'x', f_operand2, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - FLD (out_Pd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_break: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_break.f - UINT f_u4; - - f_u4 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_u4) = f_u4; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_break", "f_u4 0x%x", 'x', f_u4, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_bound_cb: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cb.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bound_cb", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_bound_cw: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cw.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bound_cw", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_bound_cd: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cd.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__dword) = f_indir_pc__dword; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bound_cd", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (out_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_scc: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_move_spr_mv32.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_scc", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addoq: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addoq.f - UINT f_operand2; - INT f_s8; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_s8 = EXTRACT_LSB0_INT (insn, 16, 7, 8); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_s8) = f_s8; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addoq", "f_operand2 0x%x", 'x', f_operand2, "f_s8 0x%x", 'x', f_s8, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addo_m_b_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addo_m_b_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addo_m_w_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addo_m_w_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addo_m_d_m: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_addc_m.f - UINT f_operand2; - UINT f_memmode; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_memmode = EXTRACT_LSB0_UINT (insn, 16, 10, 1); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - FLD (f_memmode) = f_memmode; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addo_m_d_m", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, "f_memmode 0x%x", 'x', f_memmode, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - FLD (out_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addo_cb: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cb.f - INT f_indir_pc__byte; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__byte = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__byte) = f_indir_pc__byte; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addo_cb", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__byte 0x%x", 'x', f_indir_pc__byte, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addo_cw: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cw.f - INT f_indir_pc__word; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__word = (0|(EXTRACT_LSB0_UINT (word_1, 32, 15, 16) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__word) = f_indir_pc__word; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addo_cw", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__word 0x%x", 'x', f_indir_pc__word, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addo_cd: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_bound_cd.f - INT f_indir_pc__dword; - UINT f_operand2; - /* Contents of trailing part of insn. */ - UINT word_1; - - word_1 = GETIMEMUSI (current_cpu, pc + 2); - f_indir_pc__dword = (0|(EXTRACT_LSB0_UINT (word_1, 32, 31, 32) << 0)); - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_indir_pc__dword) = f_indir_pc__dword; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addo_cd", "f_operand2 0x%x", 'x', f_operand2, "f_indir_pc__dword 0x%x", 'x', f_indir_pc__dword, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_addi_acr_b_r: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_muls_b.f - UINT f_operand2; - UINT f_operand1; - - f_operand2 = EXTRACT_LSB0_UINT (insn, 16, 15, 4); - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand2) = f_operand2; - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addi_acr_b_r", "f_operand2 0x%x", 'x', f_operand2, "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rd) = f_operand2; - FLD (in_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - - extract_sfmt_fidxi: - { - const IDESC *idesc = &crisv32f_insn_data[itype]; - CGEN_INSN_INT insn = base_insn; -#define FLD(f) abuf->fields.sfmt_mcp.f - UINT f_operand1; - - f_operand1 = EXTRACT_LSB0_UINT (insn, 16, 3, 4); - - /* Record the fields for the semantic handler. */ - FLD (f_operand1) = f_operand1; - TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_fidxi", "f_operand1 0x%x", 'x', f_operand1, (char *) 0)); - -#if WITH_PROFILE_MODEL_P - /* Record the fields for profiling. */ - if (PROFILE_MODEL_P (current_cpu)) - { - FLD (in_Rs) = f_operand1; - } -#endif -#undef FLD - return idesc; - } - -} |