diff options
Diffstat (limited to 'sim/fr30/decode.c')
-rw-r--r-- | sim/fr30/decode.c | 743 |
1 files changed, 620 insertions, 123 deletions
diff --git a/sim/fr30/decode.c b/sim/fr30/decode.c index ff01ce5..445c3ab 100644 --- a/sim/fr30/decode.c +++ b/sim/fr30/decode.c @@ -2,9 +2,9 @@ THIS FILE IS MACHINE GENERATED WITH CGEN. -Copyright (C) 1996, 1997, 1998, 1999, 2000 Free Software Foundation, Inc. +Copyright 1996, 1997, 1998, 1999, 2000, 2001 Free Software Foundation, Inc. -This file is part of the GNU Simulators. +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 @@ -33,7 +33,7 @@ with this program; if not, write to the Free Software Foundation, Inc., teensy bit of cpu in the decoder. Moving it to malloc space is trivial but won't be done until necessary (we don't currently support the runtime addition of instructions nor an SMP machine with different cpus). */ -static IDESC fr30bf_insn_data[FR30BF_INSN_MAX]; +static IDESC fr30bf_insn_data[FR30BF_INSN_XCHB + 1]; /* Commas between elements are contained in the macros. Some of these are conditionally compiled out. */ @@ -102,11 +102,11 @@ static const struct insn_sem fr30bf_insn_sem[] = { FR30_INSN_LDI20, FR30BF_INSN_LDI20, FR30BF_SFMT_LDI20 }, { FR30_INSN_LDI32, FR30BF_INSN_LDI32, FR30BF_SFMT_LDI32 }, { FR30_INSN_LD, FR30BF_INSN_LD, FR30BF_SFMT_LD }, - { FR30_INSN_LDUH, FR30BF_INSN_LDUH, FR30BF_SFMT_LD }, - { FR30_INSN_LDUB, FR30BF_INSN_LDUB, FR30BF_SFMT_LD }, + { FR30_INSN_LDUH, FR30BF_INSN_LDUH, FR30BF_SFMT_LDUH }, + { FR30_INSN_LDUB, FR30BF_INSN_LDUB, FR30BF_SFMT_LDUB }, { FR30_INSN_LDR13, FR30BF_INSN_LDR13, FR30BF_SFMT_LDR13 }, - { FR30_INSN_LDR13UH, FR30BF_INSN_LDR13UH, FR30BF_SFMT_LDR13 }, - { FR30_INSN_LDR13UB, FR30BF_INSN_LDR13UB, FR30BF_SFMT_LDR13 }, + { FR30_INSN_LDR13UH, FR30BF_INSN_LDR13UH, FR30BF_SFMT_LDR13UH }, + { FR30_INSN_LDR13UB, FR30BF_INSN_LDR13UB, FR30BF_SFMT_LDR13UB }, { FR30_INSN_LDR14, FR30BF_INSN_LDR14, FR30BF_SFMT_LDR14 }, { FR30_INSN_LDR14UH, FR30BF_INSN_LDR14UH, FR30BF_SFMT_LDR14UH }, { FR30_INSN_LDR14UB, FR30BF_INSN_LDR14UB, FR30BF_SFMT_LDR14UB }, @@ -115,11 +115,11 @@ static const struct insn_sem fr30bf_insn_sem[] = { FR30_INSN_LDR15DR, FR30BF_INSN_LDR15DR, FR30BF_SFMT_LDR15DR }, { FR30_INSN_LDR15PS, FR30BF_INSN_LDR15PS, FR30BF_SFMT_LDR15PS }, { FR30_INSN_ST, FR30BF_INSN_ST, FR30BF_SFMT_ST }, - { FR30_INSN_STH, FR30BF_INSN_STH, FR30BF_SFMT_ST }, - { FR30_INSN_STB, FR30BF_INSN_STB, FR30BF_SFMT_ST }, + { FR30_INSN_STH, FR30BF_INSN_STH, FR30BF_SFMT_STH }, + { FR30_INSN_STB, FR30BF_INSN_STB, FR30BF_SFMT_STB }, { FR30_INSN_STR13, FR30BF_INSN_STR13, FR30BF_SFMT_STR13 }, - { FR30_INSN_STR13H, FR30BF_INSN_STR13H, FR30BF_SFMT_STR13 }, - { FR30_INSN_STR13B, FR30BF_INSN_STR13B, FR30BF_SFMT_STR13 }, + { FR30_INSN_STR13H, FR30BF_INSN_STR13H, FR30BF_SFMT_STR13H }, + { FR30_INSN_STR13B, FR30BF_INSN_STR13B, FR30BF_SFMT_STR13B }, { FR30_INSN_STR14, FR30BF_INSN_STR14, FR30BF_SFMT_STR14 }, { FR30_INSN_STR14H, FR30BF_INSN_STR14H, FR30BF_SFMT_STR14H }, { FR30_INSN_STR14B, FR30BF_INSN_STR14B, FR30BF_SFMT_STR14B }, @@ -252,7 +252,7 @@ fr30bf_init_idesc_table (SIM_CPU *cpu) { IDESC *id,*tabend; const struct insn_sem *t,*tend; - int tabsize = FR30BF_INSN_MAX; + int tabsize = sizeof (fr30bf_insn_data) / sizeof (IDESC); IDESC *table = fr30bf_insn_data; memset (table, 0, tabsize * sizeof (IDESC)); @@ -282,31 +282,69 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, { /* Result of decoder. */ FR30BF_INSN_TYPE itype; - CGEN_INSN_INT insn = base_insn; { + CGEN_INSN_INT insn = base_insn; { unsigned int val = (((insn >> 8) & (255 << 0))); switch (val) { - case 0 : itype = FR30BF_INSN_LDR13; goto extract_sfmt_ldr13; case 1 : itype = FR30BF_INSN_LDR13UH; goto extract_sfmt_ldr13; case 2 : itype = FR30BF_INSN_LDR13UB; goto extract_sfmt_ldr13; case 3 : itype = FR30BF_INSN_LDR15; goto extract_sfmt_ldr15; case 4 : itype = FR30BF_INSN_LD; goto extract_sfmt_ld; case 5 : itype = FR30BF_INSN_LDUH; goto extract_sfmt_ld; case 6 : itype = FR30BF_INSN_LDUB; goto extract_sfmt_ld; case 7 : + case 0 : itype = FR30BF_INSN_LDR13;goto extract_sfmt_ldr13; + case 1 : itype = FR30BF_INSN_LDR13UH;goto extract_sfmt_ldr13uh; + case 2 : itype = FR30BF_INSN_LDR13UB;goto extract_sfmt_ldr13ub; + case 3 : itype = FR30BF_INSN_LDR15;goto extract_sfmt_ldr15; + case 4 : itype = FR30BF_INSN_LD;goto extract_sfmt_ld; + case 5 : itype = FR30BF_INSN_LDUH;goto extract_sfmt_lduh; + case 6 : itype = FR30BF_INSN_LDUB;goto extract_sfmt_ldub; + case 7 : { unsigned int val = (((insn >> 6) & (1 << 1)) | ((insn >> 4) & (1 << 0))); switch (val) { - case 0 : itype = FR30BF_INSN_LDR15GR; goto extract_sfmt_ldr15gr; case 1 : itype = FR30BF_INSN_MOV2PS; goto extract_sfmt_mov2ps; case 2 : itype = FR30BF_INSN_LDR15DR; goto extract_sfmt_ldr15dr; case 3 : itype = FR30BF_INSN_LDR15PS; goto extract_sfmt_ldr15ps; default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; + case 0 : itype = FR30BF_INSN_LDR15GR;goto extract_sfmt_ldr15gr; + case 1 : itype = FR30BF_INSN_MOV2PS;goto extract_sfmt_mov2ps; + case 2 : itype = FR30BF_INSN_LDR15DR;goto extract_sfmt_ldr15dr; + case 3 : itype = FR30BF_INSN_LDR15PS;goto extract_sfmt_ldr15ps; + default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; } } - case 8 : itype = FR30BF_INSN_DMOV2R13; goto extract_sfmt_dmov2r13; case 9 : itype = FR30BF_INSN_DMOV2R13H; goto extract_sfmt_dmov2r13h; case 10 : itype = FR30BF_INSN_DMOV2R13B; goto extract_sfmt_dmov2r13b; case 11 : itype = FR30BF_INSN_DMOV2R15PD; goto extract_sfmt_dmov2r15pd; case 12 : itype = FR30BF_INSN_DMOV2R13PI; goto extract_sfmt_dmov2r13pi; case 13 : itype = FR30BF_INSN_DMOV2R13PIH; goto extract_sfmt_dmov2r13pih; case 14 : itype = FR30BF_INSN_DMOV2R13PIB; goto extract_sfmt_dmov2r13pib; case 15 : itype = FR30BF_INSN_ENTER; goto extract_sfmt_enter; case 16 : itype = FR30BF_INSN_STR13; goto extract_sfmt_str13; case 17 : itype = FR30BF_INSN_STR13H; goto extract_sfmt_str13; case 18 : itype = FR30BF_INSN_STR13B; goto extract_sfmt_str13; case 19 : itype = FR30BF_INSN_STR15; goto extract_sfmt_str15; case 20 : itype = FR30BF_INSN_ST; goto extract_sfmt_st; case 21 : itype = FR30BF_INSN_STH; goto extract_sfmt_st; case 22 : itype = FR30BF_INSN_STB; goto extract_sfmt_st; case 23 : + case 8 : itype = FR30BF_INSN_DMOV2R13;goto extract_sfmt_dmov2r13; + case 9 : itype = FR30BF_INSN_DMOV2R13H;goto extract_sfmt_dmov2r13h; + case 10 : itype = FR30BF_INSN_DMOV2R13B;goto extract_sfmt_dmov2r13b; + case 11 : itype = FR30BF_INSN_DMOV2R15PD;goto extract_sfmt_dmov2r15pd; + case 12 : itype = FR30BF_INSN_DMOV2R13PI;goto extract_sfmt_dmov2r13pi; + case 13 : itype = FR30BF_INSN_DMOV2R13PIH;goto extract_sfmt_dmov2r13pih; + case 14 : itype = FR30BF_INSN_DMOV2R13PIB;goto extract_sfmt_dmov2r13pib; + case 15 : itype = FR30BF_INSN_ENTER;goto extract_sfmt_enter; + case 16 : itype = FR30BF_INSN_STR13;goto extract_sfmt_str13; + case 17 : itype = FR30BF_INSN_STR13H;goto extract_sfmt_str13h; + case 18 : itype = FR30BF_INSN_STR13B;goto extract_sfmt_str13b; + case 19 : itype = FR30BF_INSN_STR15;goto extract_sfmt_str15; + case 20 : itype = FR30BF_INSN_ST;goto extract_sfmt_st; + case 21 : itype = FR30BF_INSN_STH;goto extract_sfmt_sth; + case 22 : itype = FR30BF_INSN_STB;goto extract_sfmt_stb; + case 23 : { unsigned int val = (((insn >> 6) & (1 << 1)) | ((insn >> 4) & (1 << 0))); switch (val) { - case 0 : itype = FR30BF_INSN_STR15GR; goto extract_sfmt_str15gr; case 1 : itype = FR30BF_INSN_MOVPS; goto extract_sfmt_movps; case 2 : itype = FR30BF_INSN_STR15DR; goto extract_sfmt_str15dr; case 3 : itype = FR30BF_INSN_STR15PS; goto extract_sfmt_str15ps; default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; + case 0 : itype = FR30BF_INSN_STR15GR;goto extract_sfmt_str15gr; + case 1 : itype = FR30BF_INSN_MOVPS;goto extract_sfmt_movps; + case 2 : itype = FR30BF_INSN_STR15DR;goto extract_sfmt_str15dr; + case 3 : itype = FR30BF_INSN_STR15PS;goto extract_sfmt_str15ps; + default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; } } - case 24 : itype = FR30BF_INSN_DMOVR13; goto extract_sfmt_dmovr13; case 25 : itype = FR30BF_INSN_DMOVR13H; goto extract_sfmt_dmovr13h; case 26 : itype = FR30BF_INSN_DMOVR13B; goto extract_sfmt_dmovr13b; case 27 : itype = FR30BF_INSN_DMOVR15PI; goto extract_sfmt_dmovr15pi; case 28 : itype = FR30BF_INSN_DMOVR13PI; goto extract_sfmt_dmovr13pi; case 29 : itype = FR30BF_INSN_DMOVR13PIH; goto extract_sfmt_dmovr13pih; case 30 : itype = FR30BF_INSN_DMOVR13PIB; goto extract_sfmt_dmovr13pib; case 31 : itype = FR30BF_INSN_INT; goto extract_sfmt_int; case 32 : /* fall through */ + case 24 : itype = FR30BF_INSN_DMOVR13;goto extract_sfmt_dmovr13; + case 25 : itype = FR30BF_INSN_DMOVR13H;goto extract_sfmt_dmovr13h; + case 26 : itype = FR30BF_INSN_DMOVR13B;goto extract_sfmt_dmovr13b; + case 27 : itype = FR30BF_INSN_DMOVR15PI;goto extract_sfmt_dmovr15pi; + case 28 : itype = FR30BF_INSN_DMOVR13PI;goto extract_sfmt_dmovr13pi; + case 29 : itype = FR30BF_INSN_DMOVR13PIH;goto extract_sfmt_dmovr13pih; + case 30 : itype = FR30BF_INSN_DMOVR13PIB;goto extract_sfmt_dmovr13pib; + case 31 : itype = FR30BF_INSN_INT;goto extract_sfmt_int; + case 32 : /* fall through */ case 33 : /* fall through */ case 34 : /* fall through */ case 35 : /* fall through */ @@ -321,7 +359,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, case 44 : /* fall through */ case 45 : /* fall through */ case 46 : /* fall through */ - case 47 : itype = FR30BF_INSN_LDR14; goto extract_sfmt_ldr14; case 48 : /* fall through */ + case 47 : itype = FR30BF_INSN_LDR14;goto extract_sfmt_ldr14; + case 48 : /* fall through */ case 49 : /* fall through */ case 50 : /* fall through */ case 51 : /* fall through */ @@ -336,7 +375,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, case 60 : /* fall through */ case 61 : /* fall through */ case 62 : /* fall through */ - case 63 : itype = FR30BF_INSN_STR14; goto extract_sfmt_str14; case 64 : /* fall through */ + case 63 : itype = FR30BF_INSN_STR14;goto extract_sfmt_str14; + case 64 : /* fall through */ case 65 : /* fall through */ case 66 : /* fall through */ case 67 : /* fall through */ @@ -351,7 +391,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, case 76 : /* fall through */ case 77 : /* fall through */ case 78 : /* fall through */ - case 79 : itype = FR30BF_INSN_LDR14UH; goto extract_sfmt_ldr14uh; case 80 : /* fall through */ + case 79 : itype = FR30BF_INSN_LDR14UH;goto extract_sfmt_ldr14uh; + case 80 : /* fall through */ case 81 : /* fall through */ case 82 : /* fall through */ case 83 : /* fall through */ @@ -366,7 +407,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, case 92 : /* fall through */ case 93 : /* fall through */ case 94 : /* fall through */ - case 95 : itype = FR30BF_INSN_STR14H; goto extract_sfmt_str14h; case 96 : /* fall through */ + case 95 : itype = FR30BF_INSN_STR14H;goto extract_sfmt_str14h; + case 96 : /* fall through */ case 97 : /* fall through */ case 98 : /* fall through */ case 99 : /* fall through */ @@ -381,7 +423,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, case 108 : /* fall through */ case 109 : /* fall through */ case 110 : /* fall through */ - case 111 : itype = FR30BF_INSN_LDR14UB; goto extract_sfmt_ldr14ub; case 112 : /* fall through */ + case 111 : itype = FR30BF_INSN_LDR14UB;goto extract_sfmt_ldr14ub; + case 112 : /* fall through */ case 113 : /* fall through */ case 114 : /* fall through */ case 115 : /* fall through */ @@ -396,23 +439,110 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, case 124 : /* fall through */ case 125 : /* fall through */ case 126 : /* fall through */ - case 127 : itype = FR30BF_INSN_STR14B; goto extract_sfmt_str14b; case 128 : itype = FR30BF_INSN_BANDL; goto extract_sfmt_bandl; case 129 : itype = FR30BF_INSN_BANDH; goto extract_sfmt_bandl; case 130 : itype = FR30BF_INSN_AND; goto extract_sfmt_and; case 131 : itype = FR30BF_INSN_ANDCCR; goto extract_sfmt_andccr; case 132 : itype = FR30BF_INSN_ANDM; goto extract_sfmt_andm; case 133 : itype = FR30BF_INSN_ANDH; goto extract_sfmt_andh; case 134 : itype = FR30BF_INSN_ANDB; goto extract_sfmt_andb; case 135 : itype = FR30BF_INSN_STILM; goto extract_sfmt_stilm; case 136 : itype = FR30BF_INSN_BTSTL; goto extract_sfmt_btstl; case 137 : itype = FR30BF_INSN_BTSTH; goto extract_sfmt_btstl; case 138 : itype = FR30BF_INSN_XCHB; goto extract_sfmt_xchb; case 139 : itype = FR30BF_INSN_MOV; goto extract_sfmt_mov; case 140 : itype = FR30BF_INSN_LDM0; goto extract_sfmt_ldm0; case 141 : itype = FR30BF_INSN_LDM1; goto extract_sfmt_ldm1; case 142 : itype = FR30BF_INSN_STM0; goto extract_sfmt_stm0; case 143 : itype = FR30BF_INSN_STM1; goto extract_sfmt_stm1; case 144 : itype = FR30BF_INSN_BORL; goto extract_sfmt_bandl; case 145 : itype = FR30BF_INSN_BORH; goto extract_sfmt_bandl; case 146 : itype = FR30BF_INSN_OR; goto extract_sfmt_and; case 147 : itype = FR30BF_INSN_ORCCR; goto extract_sfmt_andccr; case 148 : itype = FR30BF_INSN_ORM; goto extract_sfmt_andm; case 149 : itype = FR30BF_INSN_ORH; goto extract_sfmt_andh; case 150 : itype = FR30BF_INSN_ORB; goto extract_sfmt_andb; case 151 : + case 127 : itype = FR30BF_INSN_STR14B;goto extract_sfmt_str14b; + case 128 : itype = FR30BF_INSN_BANDL;goto extract_sfmt_bandl; + case 129 : itype = FR30BF_INSN_BANDH;goto extract_sfmt_bandl; + case 130 : itype = FR30BF_INSN_AND;goto extract_sfmt_and; + case 131 : itype = FR30BF_INSN_ANDCCR;goto extract_sfmt_andccr; + case 132 : itype = FR30BF_INSN_ANDM;goto extract_sfmt_andm; + case 133 : itype = FR30BF_INSN_ANDH;goto extract_sfmt_andh; + case 134 : itype = FR30BF_INSN_ANDB;goto extract_sfmt_andb; + case 135 : itype = FR30BF_INSN_STILM;goto extract_sfmt_stilm; + case 136 : itype = FR30BF_INSN_BTSTL;goto extract_sfmt_btstl; + case 137 : itype = FR30BF_INSN_BTSTH;goto extract_sfmt_btstl; + case 138 : itype = FR30BF_INSN_XCHB;goto extract_sfmt_xchb; + case 139 : itype = FR30BF_INSN_MOV;goto extract_sfmt_mov; + case 140 : itype = FR30BF_INSN_LDM0;goto extract_sfmt_ldm0; + case 141 : itype = FR30BF_INSN_LDM1;goto extract_sfmt_ldm1; + case 142 : itype = FR30BF_INSN_STM0;goto extract_sfmt_stm0; + case 143 : itype = FR30BF_INSN_STM1;goto extract_sfmt_stm1; + case 144 : itype = FR30BF_INSN_BORL;goto extract_sfmt_bandl; + case 145 : itype = FR30BF_INSN_BORH;goto extract_sfmt_bandl; + case 146 : itype = FR30BF_INSN_OR;goto extract_sfmt_and; + case 147 : itype = FR30BF_INSN_ORCCR;goto extract_sfmt_andccr; + case 148 : itype = FR30BF_INSN_ORM;goto extract_sfmt_andm; + case 149 : itype = FR30BF_INSN_ORH;goto extract_sfmt_andh; + case 150 : itype = FR30BF_INSN_ORB;goto extract_sfmt_andb; + case 151 : { unsigned int val = (((insn >> 4) & (15 << 0))); switch (val) { - case 0 : itype = FR30BF_INSN_JMP; goto extract_sfmt_jmp; case 1 : itype = FR30BF_INSN_CALLR; goto extract_sfmt_callr; case 2 : itype = FR30BF_INSN_RET; goto extract_sfmt_ret; case 3 : itype = FR30BF_INSN_RETI; goto extract_sfmt_reti; case 4 : itype = FR30BF_INSN_DIV0S; goto extract_sfmt_div0s; case 5 : itype = FR30BF_INSN_DIV0U; goto extract_sfmt_div0u; case 6 : itype = FR30BF_INSN_DIV1; goto extract_sfmt_div1; case 7 : itype = FR30BF_INSN_DIV2; goto extract_sfmt_div2; case 8 : itype = FR30BF_INSN_EXTSB; goto extract_sfmt_extsb; case 9 : itype = FR30BF_INSN_EXTUB; goto extract_sfmt_extub; case 10 : itype = FR30BF_INSN_EXTSH; goto extract_sfmt_extsh; case 11 : itype = FR30BF_INSN_EXTUH; goto extract_sfmt_extuh; default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; + case 0 : itype = FR30BF_INSN_JMP;goto extract_sfmt_jmp; + case 1 : itype = FR30BF_INSN_CALLR;goto extract_sfmt_callr; + case 2 : itype = FR30BF_INSN_RET;goto extract_sfmt_ret; + case 3 : itype = FR30BF_INSN_RETI;goto extract_sfmt_reti; + case 4 : itype = FR30BF_INSN_DIV0S;goto extract_sfmt_div0s; + case 5 : itype = FR30BF_INSN_DIV0U;goto extract_sfmt_div0u; + case 6 : itype = FR30BF_INSN_DIV1;goto extract_sfmt_div1; + case 7 : itype = FR30BF_INSN_DIV2;goto extract_sfmt_div2; + case 8 : itype = FR30BF_INSN_EXTSB;goto extract_sfmt_extsb; + case 9 : itype = FR30BF_INSN_EXTUB;goto extract_sfmt_extub; + case 10 : itype = FR30BF_INSN_EXTSH;goto extract_sfmt_extsh; + case 11 : itype = FR30BF_INSN_EXTUH;goto extract_sfmt_extuh; + default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; } } - case 152 : itype = FR30BF_INSN_BEORL; goto extract_sfmt_bandl; case 153 : itype = FR30BF_INSN_BEORH; goto extract_sfmt_bandl; case 154 : itype = FR30BF_INSN_EOR; goto extract_sfmt_and; case 155 : itype = FR30BF_INSN_LDI20; goto extract_sfmt_ldi20; case 156 : itype = FR30BF_INSN_EORM; goto extract_sfmt_andm; case 157 : itype = FR30BF_INSN_EORH; goto extract_sfmt_andh; case 158 : itype = FR30BF_INSN_EORB; goto extract_sfmt_andb; case 159 : + case 152 : itype = FR30BF_INSN_BEORL;goto extract_sfmt_bandl; + case 153 : itype = FR30BF_INSN_BEORH;goto extract_sfmt_bandl; + case 154 : itype = FR30BF_INSN_EOR;goto extract_sfmt_and; + case 155 : itype = FR30BF_INSN_LDI20;goto extract_sfmt_ldi20; + case 156 : itype = FR30BF_INSN_EORM;goto extract_sfmt_andm; + case 157 : itype = FR30BF_INSN_EORH;goto extract_sfmt_andh; + case 158 : itype = FR30BF_INSN_EORB;goto extract_sfmt_andb; + case 159 : { unsigned int val = (((insn >> 4) & (15 << 0))); switch (val) { - case 0 : itype = FR30BF_INSN_JMPD; goto extract_sfmt_jmp; case 1 : itype = FR30BF_INSN_CALLRD; goto extract_sfmt_callr; case 2 : itype = FR30BF_INSN_RET_D; goto extract_sfmt_ret; case 3 : itype = FR30BF_INSN_INTE; goto extract_sfmt_inte; case 6 : itype = FR30BF_INSN_DIV3; goto extract_sfmt_div3; case 7 : itype = FR30BF_INSN_DIV4S; goto extract_sfmt_div4s; case 8 : itype = FR30BF_INSN_LDI32; goto extract_sfmt_ldi32; case 9 : itype = FR30BF_INSN_LEAVE; goto extract_sfmt_leave; case 10 : itype = FR30BF_INSN_NOP; goto extract_sfmt_bnod; case 12 : itype = FR30BF_INSN_COPOP; goto extract_sfmt_copop; case 13 : itype = FR30BF_INSN_COPLD; goto extract_sfmt_copop; case 14 : itype = FR30BF_INSN_COPST; goto extract_sfmt_copop; case 15 : itype = FR30BF_INSN_COPSV; goto extract_sfmt_copop; default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; + case 0 : itype = FR30BF_INSN_JMPD;goto extract_sfmt_jmp; + case 1 : itype = FR30BF_INSN_CALLRD;goto extract_sfmt_callr; + case 2 : itype = FR30BF_INSN_RET_D;goto extract_sfmt_ret; + case 3 : itype = FR30BF_INSN_INTE;goto extract_sfmt_inte; + case 6 : itype = FR30BF_INSN_DIV3;goto extract_sfmt_div3; + case 7 : itype = FR30BF_INSN_DIV4S;goto extract_sfmt_div4s; + case 8 : itype = FR30BF_INSN_LDI32;goto extract_sfmt_ldi32; + case 9 : itype = FR30BF_INSN_LEAVE;goto extract_sfmt_leave; + case 10 : itype = FR30BF_INSN_NOP;goto extract_sfmt_bnod; + case 12 : itype = FR30BF_INSN_COPOP;goto extract_sfmt_copop; + case 13 : itype = FR30BF_INSN_COPLD;goto extract_sfmt_copop; + case 14 : itype = FR30BF_INSN_COPST;goto extract_sfmt_copop; + case 15 : itype = FR30BF_INSN_COPSV;goto extract_sfmt_copop; + default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; } } - case 160 : itype = FR30BF_INSN_ADDNI; goto extract_sfmt_addni; case 161 : itype = FR30BF_INSN_ADDN2; goto extract_sfmt_addn2; case 162 : itype = FR30BF_INSN_ADDN; goto extract_sfmt_addn; case 163 : itype = FR30BF_INSN_ADDSP; goto extract_sfmt_addsp; case 164 : itype = FR30BF_INSN_ADDI; goto extract_sfmt_addi; case 165 : itype = FR30BF_INSN_ADD2; goto extract_sfmt_add2; case 166 : itype = FR30BF_INSN_ADD; goto extract_sfmt_add; case 167 : itype = FR30BF_INSN_ADDC; goto extract_sfmt_addc; case 168 : itype = FR30BF_INSN_CMPI; goto extract_sfmt_cmpi; case 169 : itype = FR30BF_INSN_CMP2; goto extract_sfmt_cmp2; case 170 : itype = FR30BF_INSN_CMP; goto extract_sfmt_cmp; case 171 : itype = FR30BF_INSN_MULU; goto extract_sfmt_mulu; case 172 : itype = FR30BF_INSN_SUB; goto extract_sfmt_add; case 173 : itype = FR30BF_INSN_SUBC; goto extract_sfmt_addc; case 174 : itype = FR30BF_INSN_SUBN; goto extract_sfmt_addn; case 175 : itype = FR30BF_INSN_MUL; goto extract_sfmt_mul; case 176 : itype = FR30BF_INSN_LSRI; goto extract_sfmt_lsli; case 177 : itype = FR30BF_INSN_LSR2; goto extract_sfmt_lsli; case 178 : itype = FR30BF_INSN_LSR; goto extract_sfmt_lsl; case 179 : itype = FR30BF_INSN_MOV2DR; goto extract_sfmt_mov2dr; case 180 : itype = FR30BF_INSN_LSLI; goto extract_sfmt_lsli; case 181 : itype = FR30BF_INSN_LSL2; goto extract_sfmt_lsli; case 182 : itype = FR30BF_INSN_LSL; goto extract_sfmt_lsl; case 183 : itype = FR30BF_INSN_MOVDR; goto extract_sfmt_movdr; case 184 : itype = FR30BF_INSN_ASRI; goto extract_sfmt_lsli; case 185 : itype = FR30BF_INSN_ASR2; goto extract_sfmt_lsli; case 186 : itype = FR30BF_INSN_ASR; goto extract_sfmt_lsl; case 187 : itype = FR30BF_INSN_MULUH; goto extract_sfmt_mulh; case 188 : itype = FR30BF_INSN_LDRES; goto extract_sfmt_ldres; case 189 : itype = FR30BF_INSN_STRES; goto extract_sfmt_ldres; case 191 : itype = FR30BF_INSN_MULH; goto extract_sfmt_mulh; case 192 : /* fall through */ + case 160 : itype = FR30BF_INSN_ADDNI;goto extract_sfmt_addni; + case 161 : itype = FR30BF_INSN_ADDN2;goto extract_sfmt_addn2; + case 162 : itype = FR30BF_INSN_ADDN;goto extract_sfmt_addn; + case 163 : itype = FR30BF_INSN_ADDSP;goto extract_sfmt_addsp; + case 164 : itype = FR30BF_INSN_ADDI;goto extract_sfmt_addi; + case 165 : itype = FR30BF_INSN_ADD2;goto extract_sfmt_add2; + case 166 : itype = FR30BF_INSN_ADD;goto extract_sfmt_add; + case 167 : itype = FR30BF_INSN_ADDC;goto extract_sfmt_addc; + case 168 : itype = FR30BF_INSN_CMPI;goto extract_sfmt_cmpi; + case 169 : itype = FR30BF_INSN_CMP2;goto extract_sfmt_cmp2; + case 170 : itype = FR30BF_INSN_CMP;goto extract_sfmt_cmp; + case 171 : itype = FR30BF_INSN_MULU;goto extract_sfmt_mulu; + case 172 : itype = FR30BF_INSN_SUB;goto extract_sfmt_add; + case 173 : itype = FR30BF_INSN_SUBC;goto extract_sfmt_addc; + case 174 : itype = FR30BF_INSN_SUBN;goto extract_sfmt_addn; + case 175 : itype = FR30BF_INSN_MUL;goto extract_sfmt_mul; + case 176 : itype = FR30BF_INSN_LSRI;goto extract_sfmt_lsli; + case 177 : itype = FR30BF_INSN_LSR2;goto extract_sfmt_lsli; + case 178 : itype = FR30BF_INSN_LSR;goto extract_sfmt_lsl; + case 179 : itype = FR30BF_INSN_MOV2DR;goto extract_sfmt_mov2dr; + case 180 : itype = FR30BF_INSN_LSLI;goto extract_sfmt_lsli; + case 181 : itype = FR30BF_INSN_LSL2;goto extract_sfmt_lsli; + case 182 : itype = FR30BF_INSN_LSL;goto extract_sfmt_lsl; + case 183 : itype = FR30BF_INSN_MOVDR;goto extract_sfmt_movdr; + case 184 : itype = FR30BF_INSN_ASRI;goto extract_sfmt_lsli; + case 185 : itype = FR30BF_INSN_ASR2;goto extract_sfmt_lsli; + case 186 : itype = FR30BF_INSN_ASR;goto extract_sfmt_lsl; + case 187 : itype = FR30BF_INSN_MULUH;goto extract_sfmt_mulh; + case 188 : itype = FR30BF_INSN_LDRES;goto extract_sfmt_ldres; + case 189 : itype = FR30BF_INSN_STRES;goto extract_sfmt_ldres; + case 191 : itype = FR30BF_INSN_MULH;goto extract_sfmt_mulh; + case 192 : /* fall through */ case 193 : /* fall through */ case 194 : /* fall through */ case 195 : /* fall through */ @@ -427,21 +557,56 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, case 204 : /* fall through */ case 205 : /* fall through */ case 206 : /* fall through */ - case 207 : itype = FR30BF_INSN_LDI8; goto extract_sfmt_ldi8; case 208 : /* fall through */ + case 207 : itype = FR30BF_INSN_LDI8;goto extract_sfmt_ldi8; + case 208 : /* fall through */ case 209 : /* fall through */ case 210 : /* fall through */ case 211 : /* fall through */ case 212 : /* fall through */ case 213 : /* fall through */ case 214 : /* fall through */ - case 215 : itype = FR30BF_INSN_CALL; goto extract_sfmt_call; case 216 : /* fall through */ + case 215 : itype = FR30BF_INSN_CALL;goto extract_sfmt_call; + case 216 : /* fall through */ case 217 : /* fall through */ case 218 : /* fall through */ case 219 : /* fall through */ case 220 : /* fall through */ case 221 : /* fall through */ case 222 : /* fall through */ - case 223 : itype = FR30BF_INSN_CALLD; goto extract_sfmt_call; case 224 : itype = FR30BF_INSN_BRA; goto extract_sfmt_brad; case 225 : itype = FR30BF_INSN_BNO; goto extract_sfmt_bnod; case 226 : itype = FR30BF_INSN_BEQ; goto extract_sfmt_beqd; case 227 : itype = FR30BF_INSN_BNE; goto extract_sfmt_beqd; case 228 : itype = FR30BF_INSN_BC; goto extract_sfmt_bcd; case 229 : itype = FR30BF_INSN_BNC; goto extract_sfmt_bcd; case 230 : itype = FR30BF_INSN_BN; goto extract_sfmt_bnd; case 231 : itype = FR30BF_INSN_BP; goto extract_sfmt_bnd; case 232 : itype = FR30BF_INSN_BV; goto extract_sfmt_bvd; case 233 : itype = FR30BF_INSN_BNV; goto extract_sfmt_bvd; case 234 : itype = FR30BF_INSN_BLT; goto extract_sfmt_bltd; case 235 : itype = FR30BF_INSN_BGE; goto extract_sfmt_bltd; case 236 : itype = FR30BF_INSN_BLE; goto extract_sfmt_bled; case 237 : itype = FR30BF_INSN_BGT; goto extract_sfmt_bled; case 238 : itype = FR30BF_INSN_BLS; goto extract_sfmt_blsd; case 239 : itype = FR30BF_INSN_BHI; goto extract_sfmt_blsd; case 240 : itype = FR30BF_INSN_BRAD; goto extract_sfmt_brad; case 241 : itype = FR30BF_INSN_BNOD; goto extract_sfmt_bnod; case 242 : itype = FR30BF_INSN_BEQD; goto extract_sfmt_beqd; case 243 : itype = FR30BF_INSN_BNED; goto extract_sfmt_beqd; case 244 : itype = FR30BF_INSN_BCD; goto extract_sfmt_bcd; case 245 : itype = FR30BF_INSN_BNCD; goto extract_sfmt_bcd; case 246 : itype = FR30BF_INSN_BND; goto extract_sfmt_bnd; case 247 : itype = FR30BF_INSN_BPD; goto extract_sfmt_bnd; case 248 : itype = FR30BF_INSN_BVD; goto extract_sfmt_bvd; case 249 : itype = FR30BF_INSN_BNVD; goto extract_sfmt_bvd; case 250 : itype = FR30BF_INSN_BLTD; goto extract_sfmt_bltd; case 251 : itype = FR30BF_INSN_BGED; goto extract_sfmt_bltd; case 252 : itype = FR30BF_INSN_BLED; goto extract_sfmt_bled; case 253 : itype = FR30BF_INSN_BGTD; goto extract_sfmt_bled; case 254 : itype = FR30BF_INSN_BLSD; goto extract_sfmt_blsd; case 255 : itype = FR30BF_INSN_BHID; goto extract_sfmt_blsd; default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; + case 223 : itype = FR30BF_INSN_CALLD;goto extract_sfmt_call; + case 224 : itype = FR30BF_INSN_BRA;goto extract_sfmt_brad; + case 225 : itype = FR30BF_INSN_BNO;goto extract_sfmt_bnod; + case 226 : itype = FR30BF_INSN_BEQ;goto extract_sfmt_beqd; + case 227 : itype = FR30BF_INSN_BNE;goto extract_sfmt_beqd; + case 228 : itype = FR30BF_INSN_BC;goto extract_sfmt_bcd; + case 229 : itype = FR30BF_INSN_BNC;goto extract_sfmt_bcd; + case 230 : itype = FR30BF_INSN_BN;goto extract_sfmt_bnd; + case 231 : itype = FR30BF_INSN_BP;goto extract_sfmt_bnd; + case 232 : itype = FR30BF_INSN_BV;goto extract_sfmt_bvd; + case 233 : itype = FR30BF_INSN_BNV;goto extract_sfmt_bvd; + case 234 : itype = FR30BF_INSN_BLT;goto extract_sfmt_bltd; + case 235 : itype = FR30BF_INSN_BGE;goto extract_sfmt_bltd; + case 236 : itype = FR30BF_INSN_BLE;goto extract_sfmt_bled; + case 237 : itype = FR30BF_INSN_BGT;goto extract_sfmt_bled; + case 238 : itype = FR30BF_INSN_BLS;goto extract_sfmt_blsd; + case 239 : itype = FR30BF_INSN_BHI;goto extract_sfmt_blsd; + case 240 : itype = FR30BF_INSN_BRAD;goto extract_sfmt_brad; + case 241 : itype = FR30BF_INSN_BNOD;goto extract_sfmt_bnod; + case 242 : itype = FR30BF_INSN_BEQD;goto extract_sfmt_beqd; + case 243 : itype = FR30BF_INSN_BNED;goto extract_sfmt_beqd; + case 244 : itype = FR30BF_INSN_BCD;goto extract_sfmt_bcd; + case 245 : itype = FR30BF_INSN_BNCD;goto extract_sfmt_bcd; + case 246 : itype = FR30BF_INSN_BND;goto extract_sfmt_bnd; + case 247 : itype = FR30BF_INSN_BPD;goto extract_sfmt_bnd; + case 248 : itype = FR30BF_INSN_BVD;goto extract_sfmt_bvd; + case 249 : itype = FR30BF_INSN_BNVD;goto extract_sfmt_bvd; + case 250 : itype = FR30BF_INSN_BLTD;goto extract_sfmt_bltd; + case 251 : itype = FR30BF_INSN_BGED;goto extract_sfmt_bltd; + case 252 : itype = FR30BF_INSN_BLED;goto extract_sfmt_bled; + case 253 : itype = FR30BF_INSN_BGTD;goto extract_sfmt_bled; + case 254 : itype = FR30BF_INSN_BLSD;goto extract_sfmt_blsd; + case 255 : itype = FR30BF_INSN_BHID;goto extract_sfmt_blsd; + default : itype = FR30BF_INSN_X_INVALID; goto extract_sfmt_empty; } } } @@ -464,6 +629,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_add: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add.f UINT f_Rj; UINT f_Ri; @@ -494,6 +660,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_addi: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_addi.f UINT f_u4; UINT f_Ri; @@ -522,6 +689,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_add2: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f SI f_m4; UINT f_Ri; @@ -550,6 +718,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_addc: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add.f UINT f_Rj; UINT f_Ri; @@ -580,6 +749,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_addn: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add.f UINT f_Rj; UINT f_Ri; @@ -610,6 +780,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_addni: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_addi.f UINT f_u4; UINT f_Ri; @@ -638,6 +809,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_addn2: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f SI f_m4; UINT f_Ri; @@ -666,6 +838,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_cmp: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -695,6 +868,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_cmpi: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_addi.f UINT f_u4; UINT f_Ri; @@ -722,6 +896,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_cmp2: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f SI f_m4; UINT f_Ri; @@ -749,6 +924,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_and: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add.f UINT f_Rj; UINT f_Ri; @@ -779,6 +955,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_andm: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -808,6 +985,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_andh: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -837,6 +1015,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_andb: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -866,6 +1045,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_bandl: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_addi.f UINT f_u4; UINT f_Ri; @@ -893,6 +1073,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_btstl: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_addi.f UINT f_u4; UINT f_Ri; @@ -920,6 +1101,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_mul: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -949,6 +1131,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_mulu: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -978,6 +1161,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_mulh: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -1007,6 +1191,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_div0s: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_mov2dr.f UINT f_Ri; @@ -1044,6 +1229,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_div1: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_mov2dr.f UINT f_Ri; @@ -1068,6 +1254,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_div2: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_mov2dr.f UINT f_Ri; @@ -1118,6 +1305,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_lsl: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add.f UINT f_Rj; UINT f_Ri; @@ -1148,6 +1336,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_lsli: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_addi.f UINT f_u4; UINT f_Ri; @@ -1176,6 +1365,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldi8: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldi8.f UINT f_i8; UINT f_Ri; @@ -1203,6 +1393,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldi20: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldi20.f UINT f_i20_16; UINT f_i20_4; @@ -1239,6 +1430,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldi32: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldi32.f UINT f_i32; UINT f_Ri; @@ -1271,6 +1463,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ld: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr13.f UINT f_Rj; UINT f_Ri; @@ -1297,9 +1490,70 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, return idesc; } + extract_sfmt_lduh: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_ldr13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Rj) = f_Rj; + FLD (f_Ri) = f_Ri; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_lduh", "f_Rj 0x%x", 'x', f_Rj, "f_Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Rj) = f_Rj; + FLD (out_Ri) = f_Ri; + } +#endif +#undef FLD + return idesc; + } + + extract_sfmt_ldub: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_ldr13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Rj) = f_Rj; + FLD (f_Ri) = f_Ri; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldub", "f_Rj 0x%x", 'x', f_Rj, "f_Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Rj) = f_Rj; + FLD (out_Ri) = f_Ri; + } +#endif +#undef FLD + return idesc; + } + extract_sfmt_ldr13: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr13.f UINT f_Rj; UINT f_Ri; @@ -1319,7 +1573,69 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, if (PROFILE_MODEL_P (current_cpu)) { FLD (in_Rj) = f_Rj; - FLD (in_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + FLD (out_Ri) = f_Ri; + } +#endif +#undef FLD + return idesc; + } + + extract_sfmt_ldr13uh: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_ldr13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Rj) = f_Rj; + FLD (f_Ri) = f_Ri; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldr13uh", "f_Rj 0x%x", 'x', f_Rj, "f_Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Rj) = f_Rj; + FLD (in_h_gr_SI_13) = 13; + FLD (out_Ri) = f_Ri; + } +#endif +#undef FLD + return idesc; + } + + extract_sfmt_ldr13ub: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_ldr13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Rj) = f_Rj; + FLD (f_Ri) = f_Ri; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldr13ub", "f_Rj 0x%x", 'x', f_Rj, "f_Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Rj) = f_Rj; + FLD (in_h_gr_SI_13) = 13; FLD (out_Ri) = f_Ri; } #endif @@ -1330,6 +1646,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldr14: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr14.f SI f_disp10; UINT f_Ri; @@ -1347,7 +1664,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_14) = 14; + FLD (in_h_gr_SI_14) = 14; FLD (out_Ri) = f_Ri; } #endif @@ -1358,6 +1675,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldr14uh: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr14uh.f SI f_disp9; UINT f_Ri; @@ -1375,7 +1693,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_14) = 14; + FLD (in_h_gr_SI_14) = 14; FLD (out_Ri) = f_Ri; } #endif @@ -1386,6 +1704,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldr14ub: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr14ub.f INT f_disp8; UINT f_Ri; @@ -1403,7 +1722,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_14) = 14; + FLD (in_h_gr_SI_14) = 14; FLD (out_Ri) = f_Ri; } #endif @@ -1414,6 +1733,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldr15: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr15.f USI f_udisp6; UINT f_Ri; @@ -1431,7 +1751,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; FLD (out_Ri) = f_Ri; } #endif @@ -1442,6 +1762,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldr15gr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr15gr.f UINT f_Ri; @@ -1456,9 +1777,9 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; FLD (out_Ri) = f_Ri; - FLD (out_h_gr_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -1468,6 +1789,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldr15dr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr15dr.f UINT f_Rs2; @@ -1481,8 +1803,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -1502,8 +1824,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -1513,6 +1835,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_st: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -1539,9 +1862,70 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, return idesc; } + extract_sfmt_sth: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_str13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Ri) = f_Ri; + FLD (f_Rj) = f_Rj; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sth", "f_Ri 0x%x", 'x', f_Ri, "f_Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Ri) = f_Ri; + FLD (in_Rj) = f_Rj; + } +#endif +#undef FLD + return idesc; + } + + extract_sfmt_stb: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_str13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Ri) = f_Ri; + FLD (f_Rj) = f_Rj; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_stb", "f_Ri 0x%x", 'x', f_Ri, "f_Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Ri) = f_Ri; + FLD (in_Rj) = f_Rj; + } +#endif +#undef FLD + return idesc; + } + extract_sfmt_str13: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str13.f UINT f_Rj; UINT f_Ri; @@ -1562,7 +1946,69 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, { FLD (in_Ri) = f_Ri; FLD (in_Rj) = f_Rj; - FLD (in_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + } +#endif +#undef FLD + return idesc; + } + + extract_sfmt_str13h: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_str13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Ri) = f_Ri; + FLD (f_Rj) = f_Rj; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_str13h", "f_Ri 0x%x", 'x', f_Ri, "f_Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Ri) = f_Ri; + FLD (in_Rj) = f_Rj; + FLD (in_h_gr_SI_13) = 13; + } +#endif +#undef FLD + return idesc; + } + + extract_sfmt_str13b: + { + const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; +#define FLD(f) abuf->fields.sfmt_str13.f + UINT f_Rj; + UINT f_Ri; + + f_Rj = EXTRACT_MSB0_UINT (insn, 16, 8, 4); + f_Ri = EXTRACT_MSB0_UINT (insn, 16, 12, 4); + + /* Record the fields for the semantic handler. */ + FLD (f_Ri) = f_Ri; + FLD (f_Rj) = f_Rj; + FLD (i_Ri) = & CPU (h_gr)[f_Ri]; + FLD (i_Rj) = & CPU (h_gr)[f_Rj]; + TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_str13b", "f_Ri 0x%x", 'x', f_Ri, "f_Rj 0x%x", 'x', f_Rj, "Ri 0x%x", 'x', f_Ri, "Rj 0x%x", 'x', f_Rj, (char *) 0)); + +#if WITH_PROFILE_MODEL_P + /* Record the fields for profiling. */ + if (PROFILE_MODEL_P (current_cpu)) + { + FLD (in_Ri) = f_Ri; + FLD (in_Rj) = f_Rj; + FLD (in_h_gr_SI_13) = 13; } #endif #undef FLD @@ -1572,6 +2018,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_str14: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str14.f SI f_disp10; UINT f_Ri; @@ -1590,7 +2037,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, if (PROFILE_MODEL_P (current_cpu)) { FLD (in_Ri) = f_Ri; - FLD (in_h_gr_14) = 14; + FLD (in_h_gr_SI_14) = 14; } #endif #undef FLD @@ -1600,6 +2047,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_str14h: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str14h.f SI f_disp9; UINT f_Ri; @@ -1618,7 +2066,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, if (PROFILE_MODEL_P (current_cpu)) { FLD (in_Ri) = f_Ri; - FLD (in_h_gr_14) = 14; + FLD (in_h_gr_SI_14) = 14; } #endif #undef FLD @@ -1628,6 +2076,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_str14b: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str14b.f INT f_disp8; UINT f_Ri; @@ -1646,7 +2095,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, if (PROFILE_MODEL_P (current_cpu)) { FLD (in_Ri) = f_Ri; - FLD (in_h_gr_14) = 14; + FLD (in_h_gr_SI_14) = 14; } #endif #undef FLD @@ -1656,6 +2105,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_str15: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str15.f USI f_udisp6; UINT f_Ri; @@ -1674,7 +2124,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, if (PROFILE_MODEL_P (current_cpu)) { FLD (in_Ri) = f_Ri; - FLD (in_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; } #endif #undef FLD @@ -1684,6 +2134,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_str15gr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_str15gr.f UINT f_Ri; @@ -1699,8 +2150,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, if (PROFILE_MODEL_P (current_cpu)) { FLD (in_Ri) = f_Ri; - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -1710,6 +2161,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_str15dr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr15dr.f UINT f_Rs2; @@ -1723,8 +2175,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -1744,8 +2196,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -1755,6 +2207,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_mov: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldr13.f UINT f_Rj; UINT f_Ri; @@ -1784,6 +2237,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_movdr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_movdr.f UINT f_Rs1; UINT f_Ri; @@ -1811,6 +2265,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_movps: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_movdr.f UINT f_Ri; @@ -1835,6 +2290,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_mov2dr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_mov2dr.f UINT f_Rs1; UINT f_Ri; @@ -1862,6 +2318,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_mov2ps: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_mov2dr.f UINT f_Ri; @@ -1886,6 +2343,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_jmp: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_mov2dr.f UINT f_Ri; @@ -1910,6 +2368,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_callr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_mov2dr.f UINT f_Ri; @@ -1934,6 +2393,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_call: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_call.f SI f_rel12; @@ -1975,6 +2435,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_int: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_int.f UINT f_u8; @@ -2035,6 +2496,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_brad: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2070,6 +2532,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_beqd: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2092,6 +2555,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_bcd: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2114,6 +2578,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_bnd: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2136,6 +2601,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_bvd: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2158,6 +2624,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_bltd: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2180,6 +2647,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_bled: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2202,6 +2670,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_blsd: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_brad.f SI f_rel9; @@ -2224,6 +2693,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmovr13: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pi.f USI f_dir10; @@ -2237,7 +2707,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2247,6 +2717,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmovr13h: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pih.f USI f_dir9; @@ -2260,7 +2731,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2270,6 +2741,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmovr13b: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pib.f UINT f_dir8; @@ -2283,7 +2755,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2293,6 +2765,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmovr13pi: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pi.f USI f_dir10; @@ -2306,8 +2779,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; - FLD (out_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2317,6 +2790,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmovr13pih: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pih.f USI f_dir9; @@ -2330,8 +2804,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; - FLD (out_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2341,6 +2815,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmovr13pib: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pib.f UINT f_dir8; @@ -2354,8 +2829,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; - FLD (out_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2365,6 +2840,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmovr15pi: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr15pi.f USI f_dir10; @@ -2378,8 +2854,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -2389,6 +2865,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmov2r13: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pi.f USI f_dir10; @@ -2402,7 +2879,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (out_h_gr_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2412,6 +2889,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmov2r13h: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pih.f USI f_dir9; @@ -2425,7 +2903,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (out_h_gr_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2435,6 +2913,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmov2r13b: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pib.f UINT f_dir8; @@ -2448,7 +2927,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (out_h_gr_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2458,6 +2937,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmov2r13pi: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pi.f USI f_dir10; @@ -2471,8 +2951,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; - FLD (out_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2482,6 +2962,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmov2r13pih: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pih.f USI f_dir9; @@ -2495,8 +2976,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; - FLD (out_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2506,6 +2987,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmov2r13pib: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr13pib.f UINT f_dir8; @@ -2519,8 +3001,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_13) = 13; - FLD (out_h_gr_13) = 13; + FLD (in_h_gr_SI_13) = 13; + FLD (out_h_gr_SI_13) = 13; } #endif #undef FLD @@ -2530,6 +3012,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_dmov2r15pd: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_dmovr15pi.f USI f_dir10; @@ -2543,8 +3026,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -2554,6 +3037,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldres: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f UINT f_Ri; @@ -2595,6 +3079,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_andccr: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_int.f UINT f_u8; @@ -2611,6 +3096,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_stilm: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_int.f UINT f_u8; @@ -2627,6 +3113,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_addsp: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_addsp.f SI f_s10; @@ -2640,8 +3127,8 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -2651,6 +3138,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_extsb: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f UINT f_Ri; @@ -2676,6 +3164,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_extub: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f UINT f_Ri; @@ -2701,6 +3190,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_extsh: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f UINT f_Ri; @@ -2726,6 +3216,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_extuh: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add2.f UINT f_Ri; @@ -2751,6 +3242,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldm0: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldm0.f UINT f_reglist_low_ld; @@ -2764,16 +3256,16 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_0) = 0; - FLD (out_h_gr_1) = 1; - FLD (out_h_gr_15) = 15; - FLD (out_h_gr_2) = 2; - FLD (out_h_gr_3) = 3; - FLD (out_h_gr_4) = 4; - FLD (out_h_gr_5) = 5; - FLD (out_h_gr_6) = 6; - FLD (out_h_gr_7) = 7; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_0) = 0; + FLD (out_h_gr_SI_1) = 1; + 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; } #endif #undef FLD @@ -2783,6 +3275,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_ldm1: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_ldm1.f UINT f_reglist_hi_ld; @@ -2796,15 +3289,15 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_10) = 10; - FLD (out_h_gr_11) = 11; - FLD (out_h_gr_12) = 12; - FLD (out_h_gr_13) = 13; - FLD (out_h_gr_14) = 14; - FLD (out_h_gr_15) = 15; - FLD (out_h_gr_8) = 8; - FLD (out_h_gr_9) = 9; + FLD (in_h_gr_SI_15) = 15; + 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_8) = 8; + FLD (out_h_gr_SI_9) = 9; } #endif #undef FLD @@ -2814,6 +3307,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_stm0: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_stm0.f UINT f_reglist_low_st; @@ -2827,16 +3321,16 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_0) = 0; - FLD (in_h_gr_1) = 1; - FLD (in_h_gr_15) = 15; - FLD (in_h_gr_2) = 2; - FLD (in_h_gr_3) = 3; - FLD (in_h_gr_4) = 4; - FLD (in_h_gr_5) = 5; - FLD (in_h_gr_6) = 6; - FLD (in_h_gr_7) = 7; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_0) = 0; + FLD (in_h_gr_SI_1) = 1; + 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 (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -2846,6 +3340,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_stm1: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_stm1.f UINT f_reglist_hi_st; @@ -2859,15 +3354,15 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_10) = 10; - FLD (in_h_gr_11) = 11; - FLD (in_h_gr_12) = 12; - FLD (in_h_gr_13) = 13; - FLD (in_h_gr_14) = 14; - FLD (in_h_gr_15) = 15; - FLD (in_h_gr_8) = 8; - FLD (in_h_gr_9) = 9; - FLD (out_h_gr_15) = 15; + 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_8) = 8; + FLD (in_h_gr_SI_9) = 9; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -2877,6 +3372,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_enter: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_enter.f USI f_u10; @@ -2890,10 +3386,10 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_14) = 14; - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_14) = 14; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_14) = 14; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_14) = 14; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -2913,10 +3409,10 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, /* Record the fields for profiling. */ if (PROFILE_MODEL_P (current_cpu)) { - FLD (in_h_gr_14) = 14; - FLD (in_h_gr_15) = 15; - FLD (out_h_gr_14) = 14; - FLD (out_h_gr_15) = 15; + FLD (in_h_gr_SI_14) = 14; + FLD (in_h_gr_SI_15) = 15; + FLD (out_h_gr_SI_14) = 14; + FLD (out_h_gr_SI_15) = 15; } #endif #undef FLD @@ -2926,6 +3422,7 @@ fr30bf_decode (SIM_CPU *current_cpu, IADDR pc, extract_sfmt_xchb: { const IDESC *idesc = &fr30bf_insn_data[itype]; + CGEN_INSN_INT insn = base_insn; #define FLD(f) abuf->fields.sfmt_add.f UINT f_Rj; UINT f_Ri; |