OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [gdb-6.8/] [sim/] [m32r/] [decode2.c] - Blame information for rev 301

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 24 jeremybenn
/* Simulator instruction decoder for m32r2f.
2
 
3
THIS FILE IS MACHINE GENERATED WITH CGEN.
4
 
5
Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
6
 
7
This file is part of the GNU simulators.
8
 
9
This program is free software; you can redistribute it and/or modify
10
it under the terms of the GNU General Public License as published by
11
the Free Software Foundation; either version 3 of the License, or
12
(at your option) any later version.
13
 
14
This program is distributed in the hope that it will be useful,
15
but WITHOUT ANY WARRANTY; without even the implied warranty of
16
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
GNU General Public License for more details.
18
 
19
You should have received a copy of the GNU General Public License
20
along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 
22
*/
23
 
24
#define WANT_CPU m32r2f
25
#define WANT_CPU_M32R2F
26
 
27
#include "sim-main.h"
28
#include "sim-assert.h"
29
 
30
/* Insn can't be executed in parallel.
31
   Or is that "do NOt Pass to Air defense Radar"? :-) */
32
#define NOPAR (-1)
33
 
34
/* The instruction descriptor array.
35
   This is computed at runtime.  Space for it is not malloc'd to save a
36
   teensy bit of cpu in the decoder.  Moving it to malloc space is trivial
37
   but won't be done until necessary (we don't currently support the runtime
38
   addition of instructions nor an SMP machine with different cpus).  */
39
static IDESC m32r2f_insn_data[M32R2F_INSN__MAX];
40
 
41
/* Commas between elements are contained in the macros.
42
   Some of these are conditionally compiled out.  */
43
 
44
static const struct insn_sem m32r2f_insn_sem[] =
45
{
46
  { VIRTUAL_INSN_X_INVALID, M32R2F_INSN_X_INVALID, M32R2F_SFMT_EMPTY, NOPAR, NOPAR  },
47
  { VIRTUAL_INSN_X_AFTER, M32R2F_INSN_X_AFTER, M32R2F_SFMT_EMPTY, NOPAR, NOPAR  },
48
  { VIRTUAL_INSN_X_BEFORE, M32R2F_INSN_X_BEFORE, M32R2F_SFMT_EMPTY, NOPAR, NOPAR  },
49
  { VIRTUAL_INSN_X_CTI_CHAIN, M32R2F_INSN_X_CTI_CHAIN, M32R2F_SFMT_EMPTY, NOPAR, NOPAR  },
50
  { VIRTUAL_INSN_X_CHAIN, M32R2F_INSN_X_CHAIN, M32R2F_SFMT_EMPTY, NOPAR, NOPAR  },
51
  { VIRTUAL_INSN_X_BEGIN, M32R2F_INSN_X_BEGIN, M32R2F_SFMT_EMPTY, NOPAR, NOPAR  },
52
  { M32R_INSN_ADD, M32R2F_INSN_ADD, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_ADD, M32R2F_INSN_WRITE_ADD },
53
  { M32R_INSN_ADD3, M32R2F_INSN_ADD3, M32R2F_SFMT_ADD3, NOPAR, NOPAR  },
54
  { M32R_INSN_AND, M32R2F_INSN_AND, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_AND, M32R2F_INSN_WRITE_AND },
55
  { M32R_INSN_AND3, M32R2F_INSN_AND3, M32R2F_SFMT_AND3, NOPAR, NOPAR  },
56
  { M32R_INSN_OR, M32R2F_INSN_OR, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_OR, M32R2F_INSN_WRITE_OR },
57
  { M32R_INSN_OR3, M32R2F_INSN_OR3, M32R2F_SFMT_OR3, NOPAR, NOPAR  },
58
  { M32R_INSN_XOR, M32R2F_INSN_XOR, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_XOR, M32R2F_INSN_WRITE_XOR },
59
  { M32R_INSN_XOR3, M32R2F_INSN_XOR3, M32R2F_SFMT_AND3, NOPAR, NOPAR  },
60
  { M32R_INSN_ADDI, M32R2F_INSN_ADDI, M32R2F_SFMT_ADDI, M32R2F_INSN_PAR_ADDI, M32R2F_INSN_WRITE_ADDI },
61
  { M32R_INSN_ADDV, M32R2F_INSN_ADDV, M32R2F_SFMT_ADDV, M32R2F_INSN_PAR_ADDV, M32R2F_INSN_WRITE_ADDV },
62
  { M32R_INSN_ADDV3, M32R2F_INSN_ADDV3, M32R2F_SFMT_ADDV3, NOPAR, NOPAR  },
63
  { M32R_INSN_ADDX, M32R2F_INSN_ADDX, M32R2F_SFMT_ADDX, M32R2F_INSN_PAR_ADDX, M32R2F_INSN_WRITE_ADDX },
64
  { M32R_INSN_BC8, M32R2F_INSN_BC8, M32R2F_SFMT_BC8, M32R2F_INSN_PAR_BC8, M32R2F_INSN_WRITE_BC8 },
65
  { M32R_INSN_BC24, M32R2F_INSN_BC24, M32R2F_SFMT_BC24, NOPAR, NOPAR  },
66
  { M32R_INSN_BEQ, M32R2F_INSN_BEQ, M32R2F_SFMT_BEQ, NOPAR, NOPAR  },
67
  { M32R_INSN_BEQZ, M32R2F_INSN_BEQZ, M32R2F_SFMT_BEQZ, NOPAR, NOPAR  },
68
  { M32R_INSN_BGEZ, M32R2F_INSN_BGEZ, M32R2F_SFMT_BEQZ, NOPAR, NOPAR  },
69
  { M32R_INSN_BGTZ, M32R2F_INSN_BGTZ, M32R2F_SFMT_BEQZ, NOPAR, NOPAR  },
70
  { M32R_INSN_BLEZ, M32R2F_INSN_BLEZ, M32R2F_SFMT_BEQZ, NOPAR, NOPAR  },
71
  { M32R_INSN_BLTZ, M32R2F_INSN_BLTZ, M32R2F_SFMT_BEQZ, NOPAR, NOPAR  },
72
  { M32R_INSN_BNEZ, M32R2F_INSN_BNEZ, M32R2F_SFMT_BEQZ, NOPAR, NOPAR  },
73
  { M32R_INSN_BL8, M32R2F_INSN_BL8, M32R2F_SFMT_BL8, M32R2F_INSN_PAR_BL8, M32R2F_INSN_WRITE_BL8 },
74
  { M32R_INSN_BL24, M32R2F_INSN_BL24, M32R2F_SFMT_BL24, NOPAR, NOPAR  },
75
  { M32R_INSN_BCL8, M32R2F_INSN_BCL8, M32R2F_SFMT_BCL8, M32R2F_INSN_PAR_BCL8, M32R2F_INSN_WRITE_BCL8 },
76
  { M32R_INSN_BCL24, M32R2F_INSN_BCL24, M32R2F_SFMT_BCL24, NOPAR, NOPAR  },
77
  { M32R_INSN_BNC8, M32R2F_INSN_BNC8, M32R2F_SFMT_BC8, M32R2F_INSN_PAR_BNC8, M32R2F_INSN_WRITE_BNC8 },
78
  { M32R_INSN_BNC24, M32R2F_INSN_BNC24, M32R2F_SFMT_BC24, NOPAR, NOPAR  },
79
  { M32R_INSN_BNE, M32R2F_INSN_BNE, M32R2F_SFMT_BEQ, NOPAR, NOPAR  },
80
  { M32R_INSN_BRA8, M32R2F_INSN_BRA8, M32R2F_SFMT_BRA8, M32R2F_INSN_PAR_BRA8, M32R2F_INSN_WRITE_BRA8 },
81
  { M32R_INSN_BRA24, M32R2F_INSN_BRA24, M32R2F_SFMT_BRA24, NOPAR, NOPAR  },
82
  { M32R_INSN_BNCL8, M32R2F_INSN_BNCL8, M32R2F_SFMT_BCL8, M32R2F_INSN_PAR_BNCL8, M32R2F_INSN_WRITE_BNCL8 },
83
  { M32R_INSN_BNCL24, M32R2F_INSN_BNCL24, M32R2F_SFMT_BCL24, NOPAR, NOPAR  },
84
  { M32R_INSN_CMP, M32R2F_INSN_CMP, M32R2F_SFMT_CMP, M32R2F_INSN_PAR_CMP, M32R2F_INSN_WRITE_CMP },
85
  { M32R_INSN_CMPI, M32R2F_INSN_CMPI, M32R2F_SFMT_CMPI, NOPAR, NOPAR  },
86
  { M32R_INSN_CMPU, M32R2F_INSN_CMPU, M32R2F_SFMT_CMP, M32R2F_INSN_PAR_CMPU, M32R2F_INSN_WRITE_CMPU },
87
  { M32R_INSN_CMPUI, M32R2F_INSN_CMPUI, M32R2F_SFMT_CMPI, NOPAR, NOPAR  },
88
  { M32R_INSN_CMPEQ, M32R2F_INSN_CMPEQ, M32R2F_SFMT_CMP, M32R2F_INSN_PAR_CMPEQ, M32R2F_INSN_WRITE_CMPEQ },
89
  { M32R_INSN_CMPZ, M32R2F_INSN_CMPZ, M32R2F_SFMT_CMPZ, M32R2F_INSN_PAR_CMPZ, M32R2F_INSN_WRITE_CMPZ },
90
  { M32R_INSN_DIV, M32R2F_INSN_DIV, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
91
  { M32R_INSN_DIVU, M32R2F_INSN_DIVU, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
92
  { M32R_INSN_REM, M32R2F_INSN_REM, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
93
  { M32R_INSN_REMU, M32R2F_INSN_REMU, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
94
  { M32R_INSN_REMH, M32R2F_INSN_REMH, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
95
  { M32R_INSN_REMUH, M32R2F_INSN_REMUH, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
96
  { M32R_INSN_REMB, M32R2F_INSN_REMB, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
97
  { M32R_INSN_REMUB, M32R2F_INSN_REMUB, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
98
  { M32R_INSN_DIVUH, M32R2F_INSN_DIVUH, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
99
  { M32R_INSN_DIVB, M32R2F_INSN_DIVB, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
100
  { M32R_INSN_DIVUB, M32R2F_INSN_DIVUB, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
101
  { M32R_INSN_DIVH, M32R2F_INSN_DIVH, M32R2F_SFMT_DIV, NOPAR, NOPAR  },
102
  { M32R_INSN_JC, M32R2F_INSN_JC, M32R2F_SFMT_JC, M32R2F_INSN_PAR_JC, M32R2F_INSN_WRITE_JC },
103
  { M32R_INSN_JNC, M32R2F_INSN_JNC, M32R2F_SFMT_JC, M32R2F_INSN_PAR_JNC, M32R2F_INSN_WRITE_JNC },
104
  { M32R_INSN_JL, M32R2F_INSN_JL, M32R2F_SFMT_JL, M32R2F_INSN_PAR_JL, M32R2F_INSN_WRITE_JL },
105
  { M32R_INSN_JMP, M32R2F_INSN_JMP, M32R2F_SFMT_JMP, M32R2F_INSN_PAR_JMP, M32R2F_INSN_WRITE_JMP },
106
  { M32R_INSN_LD, M32R2F_INSN_LD, M32R2F_SFMT_LD, M32R2F_INSN_PAR_LD, M32R2F_INSN_WRITE_LD },
107
  { M32R_INSN_LD_D, M32R2F_INSN_LD_D, M32R2F_SFMT_LD_D, NOPAR, NOPAR  },
108
  { M32R_INSN_LDB, M32R2F_INSN_LDB, M32R2F_SFMT_LDB, M32R2F_INSN_PAR_LDB, M32R2F_INSN_WRITE_LDB },
109
  { M32R_INSN_LDB_D, M32R2F_INSN_LDB_D, M32R2F_SFMT_LDB_D, NOPAR, NOPAR  },
110
  { M32R_INSN_LDH, M32R2F_INSN_LDH, M32R2F_SFMT_LDH, M32R2F_INSN_PAR_LDH, M32R2F_INSN_WRITE_LDH },
111
  { M32R_INSN_LDH_D, M32R2F_INSN_LDH_D, M32R2F_SFMT_LDH_D, NOPAR, NOPAR  },
112
  { M32R_INSN_LDUB, M32R2F_INSN_LDUB, M32R2F_SFMT_LDB, M32R2F_INSN_PAR_LDUB, M32R2F_INSN_WRITE_LDUB },
113
  { M32R_INSN_LDUB_D, M32R2F_INSN_LDUB_D, M32R2F_SFMT_LDB_D, NOPAR, NOPAR  },
114
  { M32R_INSN_LDUH, M32R2F_INSN_LDUH, M32R2F_SFMT_LDH, M32R2F_INSN_PAR_LDUH, M32R2F_INSN_WRITE_LDUH },
115
  { M32R_INSN_LDUH_D, M32R2F_INSN_LDUH_D, M32R2F_SFMT_LDH_D, NOPAR, NOPAR  },
116
  { M32R_INSN_LD_PLUS, M32R2F_INSN_LD_PLUS, M32R2F_SFMT_LD_PLUS, M32R2F_INSN_PAR_LD_PLUS, M32R2F_INSN_WRITE_LD_PLUS },
117
  { M32R_INSN_LD24, M32R2F_INSN_LD24, M32R2F_SFMT_LD24, NOPAR, NOPAR  },
118
  { M32R_INSN_LDI8, M32R2F_INSN_LDI8, M32R2F_SFMT_LDI8, M32R2F_INSN_PAR_LDI8, M32R2F_INSN_WRITE_LDI8 },
119
  { M32R_INSN_LDI16, M32R2F_INSN_LDI16, M32R2F_SFMT_LDI16, NOPAR, NOPAR  },
120
  { M32R_INSN_LOCK, M32R2F_INSN_LOCK, M32R2F_SFMT_LOCK, M32R2F_INSN_PAR_LOCK, M32R2F_INSN_WRITE_LOCK },
121
  { M32R_INSN_MACHI_A, M32R2F_INSN_MACHI_A, M32R2F_SFMT_MACHI_A, M32R2F_INSN_PAR_MACHI_A, M32R2F_INSN_WRITE_MACHI_A },
122
  { M32R_INSN_MACLO_A, M32R2F_INSN_MACLO_A, M32R2F_SFMT_MACHI_A, M32R2F_INSN_PAR_MACLO_A, M32R2F_INSN_WRITE_MACLO_A },
123
  { M32R_INSN_MACWHI_A, M32R2F_INSN_MACWHI_A, M32R2F_SFMT_MACHI_A, M32R2F_INSN_PAR_MACWHI_A, M32R2F_INSN_WRITE_MACWHI_A },
124
  { M32R_INSN_MACWLO_A, M32R2F_INSN_MACWLO_A, M32R2F_SFMT_MACHI_A, M32R2F_INSN_PAR_MACWLO_A, M32R2F_INSN_WRITE_MACWLO_A },
125
  { M32R_INSN_MUL, M32R2F_INSN_MUL, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_MUL, M32R2F_INSN_WRITE_MUL },
126
  { M32R_INSN_MULHI_A, M32R2F_INSN_MULHI_A, M32R2F_SFMT_MULHI_A, M32R2F_INSN_PAR_MULHI_A, M32R2F_INSN_WRITE_MULHI_A },
127
  { M32R_INSN_MULLO_A, M32R2F_INSN_MULLO_A, M32R2F_SFMT_MULHI_A, M32R2F_INSN_PAR_MULLO_A, M32R2F_INSN_WRITE_MULLO_A },
128
  { M32R_INSN_MULWHI_A, M32R2F_INSN_MULWHI_A, M32R2F_SFMT_MULHI_A, M32R2F_INSN_PAR_MULWHI_A, M32R2F_INSN_WRITE_MULWHI_A },
129
  { M32R_INSN_MULWLO_A, M32R2F_INSN_MULWLO_A, M32R2F_SFMT_MULHI_A, M32R2F_INSN_PAR_MULWLO_A, M32R2F_INSN_WRITE_MULWLO_A },
130
  { M32R_INSN_MV, M32R2F_INSN_MV, M32R2F_SFMT_MV, M32R2F_INSN_PAR_MV, M32R2F_INSN_WRITE_MV },
131
  { M32R_INSN_MVFACHI_A, M32R2F_INSN_MVFACHI_A, M32R2F_SFMT_MVFACHI_A, M32R2F_INSN_PAR_MVFACHI_A, M32R2F_INSN_WRITE_MVFACHI_A },
132
  { M32R_INSN_MVFACLO_A, M32R2F_INSN_MVFACLO_A, M32R2F_SFMT_MVFACHI_A, M32R2F_INSN_PAR_MVFACLO_A, M32R2F_INSN_WRITE_MVFACLO_A },
133
  { M32R_INSN_MVFACMI_A, M32R2F_INSN_MVFACMI_A, M32R2F_SFMT_MVFACHI_A, M32R2F_INSN_PAR_MVFACMI_A, M32R2F_INSN_WRITE_MVFACMI_A },
134
  { M32R_INSN_MVFC, M32R2F_INSN_MVFC, M32R2F_SFMT_MVFC, M32R2F_INSN_PAR_MVFC, M32R2F_INSN_WRITE_MVFC },
135
  { M32R_INSN_MVTACHI_A, M32R2F_INSN_MVTACHI_A, M32R2F_SFMT_MVTACHI_A, M32R2F_INSN_PAR_MVTACHI_A, M32R2F_INSN_WRITE_MVTACHI_A },
136
  { M32R_INSN_MVTACLO_A, M32R2F_INSN_MVTACLO_A, M32R2F_SFMT_MVTACHI_A, M32R2F_INSN_PAR_MVTACLO_A, M32R2F_INSN_WRITE_MVTACLO_A },
137
  { M32R_INSN_MVTC, M32R2F_INSN_MVTC, M32R2F_SFMT_MVTC, M32R2F_INSN_PAR_MVTC, M32R2F_INSN_WRITE_MVTC },
138
  { M32R_INSN_NEG, M32R2F_INSN_NEG, M32R2F_SFMT_MV, M32R2F_INSN_PAR_NEG, M32R2F_INSN_WRITE_NEG },
139
  { M32R_INSN_NOP, M32R2F_INSN_NOP, M32R2F_SFMT_NOP, M32R2F_INSN_PAR_NOP, M32R2F_INSN_WRITE_NOP },
140
  { M32R_INSN_NOT, M32R2F_INSN_NOT, M32R2F_SFMT_MV, M32R2F_INSN_PAR_NOT, M32R2F_INSN_WRITE_NOT },
141
  { M32R_INSN_RAC_DSI, M32R2F_INSN_RAC_DSI, M32R2F_SFMT_RAC_DSI, M32R2F_INSN_PAR_RAC_DSI, M32R2F_INSN_WRITE_RAC_DSI },
142
  { M32R_INSN_RACH_DSI, M32R2F_INSN_RACH_DSI, M32R2F_SFMT_RAC_DSI, M32R2F_INSN_PAR_RACH_DSI, M32R2F_INSN_WRITE_RACH_DSI },
143
  { M32R_INSN_RTE, M32R2F_INSN_RTE, M32R2F_SFMT_RTE, M32R2F_INSN_PAR_RTE, M32R2F_INSN_WRITE_RTE },
144
  { M32R_INSN_SETH, M32R2F_INSN_SETH, M32R2F_SFMT_SETH, NOPAR, NOPAR  },
145
  { M32R_INSN_SLL, M32R2F_INSN_SLL, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_SLL, M32R2F_INSN_WRITE_SLL },
146
  { M32R_INSN_SLL3, M32R2F_INSN_SLL3, M32R2F_SFMT_SLL3, NOPAR, NOPAR  },
147
  { M32R_INSN_SLLI, M32R2F_INSN_SLLI, M32R2F_SFMT_SLLI, M32R2F_INSN_PAR_SLLI, M32R2F_INSN_WRITE_SLLI },
148
  { M32R_INSN_SRA, M32R2F_INSN_SRA, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_SRA, M32R2F_INSN_WRITE_SRA },
149
  { M32R_INSN_SRA3, M32R2F_INSN_SRA3, M32R2F_SFMT_SLL3, NOPAR, NOPAR  },
150
  { M32R_INSN_SRAI, M32R2F_INSN_SRAI, M32R2F_SFMT_SLLI, M32R2F_INSN_PAR_SRAI, M32R2F_INSN_WRITE_SRAI },
151
  { M32R_INSN_SRL, M32R2F_INSN_SRL, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_SRL, M32R2F_INSN_WRITE_SRL },
152
  { M32R_INSN_SRL3, M32R2F_INSN_SRL3, M32R2F_SFMT_SLL3, NOPAR, NOPAR  },
153
  { M32R_INSN_SRLI, M32R2F_INSN_SRLI, M32R2F_SFMT_SLLI, M32R2F_INSN_PAR_SRLI, M32R2F_INSN_WRITE_SRLI },
154
  { M32R_INSN_ST, M32R2F_INSN_ST, M32R2F_SFMT_ST, M32R2F_INSN_PAR_ST, M32R2F_INSN_WRITE_ST },
155
  { M32R_INSN_ST_D, M32R2F_INSN_ST_D, M32R2F_SFMT_ST_D, NOPAR, NOPAR  },
156
  { M32R_INSN_STB, M32R2F_INSN_STB, M32R2F_SFMT_STB, M32R2F_INSN_PAR_STB, M32R2F_INSN_WRITE_STB },
157
  { M32R_INSN_STB_D, M32R2F_INSN_STB_D, M32R2F_SFMT_STB_D, NOPAR, NOPAR  },
158
  { M32R_INSN_STH, M32R2F_INSN_STH, M32R2F_SFMT_STH, M32R2F_INSN_PAR_STH, M32R2F_INSN_WRITE_STH },
159
  { M32R_INSN_STH_D, M32R2F_INSN_STH_D, M32R2F_SFMT_STH_D, NOPAR, NOPAR  },
160
  { M32R_INSN_ST_PLUS, M32R2F_INSN_ST_PLUS, M32R2F_SFMT_ST_PLUS, M32R2F_INSN_PAR_ST_PLUS, M32R2F_INSN_WRITE_ST_PLUS },
161
  { M32R_INSN_STH_PLUS, M32R2F_INSN_STH_PLUS, M32R2F_SFMT_STH_PLUS, M32R2F_INSN_PAR_STH_PLUS, M32R2F_INSN_WRITE_STH_PLUS },
162
  { M32R_INSN_STB_PLUS, M32R2F_INSN_STB_PLUS, M32R2F_SFMT_STB_PLUS, M32R2F_INSN_PAR_STB_PLUS, M32R2F_INSN_WRITE_STB_PLUS },
163
  { M32R_INSN_ST_MINUS, M32R2F_INSN_ST_MINUS, M32R2F_SFMT_ST_PLUS, M32R2F_INSN_PAR_ST_MINUS, M32R2F_INSN_WRITE_ST_MINUS },
164
  { M32R_INSN_SUB, M32R2F_INSN_SUB, M32R2F_SFMT_ADD, M32R2F_INSN_PAR_SUB, M32R2F_INSN_WRITE_SUB },
165
  { M32R_INSN_SUBV, M32R2F_INSN_SUBV, M32R2F_SFMT_ADDV, M32R2F_INSN_PAR_SUBV, M32R2F_INSN_WRITE_SUBV },
166
  { M32R_INSN_SUBX, M32R2F_INSN_SUBX, M32R2F_SFMT_ADDX, M32R2F_INSN_PAR_SUBX, M32R2F_INSN_WRITE_SUBX },
167
  { M32R_INSN_TRAP, M32R2F_INSN_TRAP, M32R2F_SFMT_TRAP, M32R2F_INSN_PAR_TRAP, M32R2F_INSN_WRITE_TRAP },
168
  { M32R_INSN_UNLOCK, M32R2F_INSN_UNLOCK, M32R2F_SFMT_UNLOCK, M32R2F_INSN_PAR_UNLOCK, M32R2F_INSN_WRITE_UNLOCK },
169
  { M32R_INSN_SATB, M32R2F_INSN_SATB, M32R2F_SFMT_SATB, NOPAR, NOPAR  },
170
  { M32R_INSN_SATH, M32R2F_INSN_SATH, M32R2F_SFMT_SATB, NOPAR, NOPAR  },
171
  { M32R_INSN_SAT, M32R2F_INSN_SAT, M32R2F_SFMT_SAT, NOPAR, NOPAR  },
172
  { M32R_INSN_PCMPBZ, M32R2F_INSN_PCMPBZ, M32R2F_SFMT_CMPZ, M32R2F_INSN_PAR_PCMPBZ, M32R2F_INSN_WRITE_PCMPBZ },
173
  { M32R_INSN_SADD, M32R2F_INSN_SADD, M32R2F_SFMT_SADD, M32R2F_INSN_PAR_SADD, M32R2F_INSN_WRITE_SADD },
174
  { M32R_INSN_MACWU1, M32R2F_INSN_MACWU1, M32R2F_SFMT_MACWU1, M32R2F_INSN_PAR_MACWU1, M32R2F_INSN_WRITE_MACWU1 },
175
  { M32R_INSN_MSBLO, M32R2F_INSN_MSBLO, M32R2F_SFMT_MSBLO, M32R2F_INSN_PAR_MSBLO, M32R2F_INSN_WRITE_MSBLO },
176
  { M32R_INSN_MULWU1, M32R2F_INSN_MULWU1, M32R2F_SFMT_MULWU1, M32R2F_INSN_PAR_MULWU1, M32R2F_INSN_WRITE_MULWU1 },
177
  { M32R_INSN_MACLH1, M32R2F_INSN_MACLH1, M32R2F_SFMT_MACWU1, M32R2F_INSN_PAR_MACLH1, M32R2F_INSN_WRITE_MACLH1 },
178
  { M32R_INSN_SC, M32R2F_INSN_SC, M32R2F_SFMT_SC, M32R2F_INSN_PAR_SC, M32R2F_INSN_WRITE_SC },
179
  { M32R_INSN_SNC, M32R2F_INSN_SNC, M32R2F_SFMT_SC, M32R2F_INSN_PAR_SNC, M32R2F_INSN_WRITE_SNC },
180
  { M32R_INSN_CLRPSW, M32R2F_INSN_CLRPSW, M32R2F_SFMT_CLRPSW, M32R2F_INSN_PAR_CLRPSW, M32R2F_INSN_WRITE_CLRPSW },
181
  { M32R_INSN_SETPSW, M32R2F_INSN_SETPSW, M32R2F_SFMT_SETPSW, M32R2F_INSN_PAR_SETPSW, M32R2F_INSN_WRITE_SETPSW },
182
  { M32R_INSN_BSET, M32R2F_INSN_BSET, M32R2F_SFMT_BSET, NOPAR, NOPAR  },
183
  { M32R_INSN_BCLR, M32R2F_INSN_BCLR, M32R2F_SFMT_BSET, NOPAR, NOPAR  },
184
  { M32R_INSN_BTST, M32R2F_INSN_BTST, M32R2F_SFMT_BTST, M32R2F_INSN_PAR_BTST, M32R2F_INSN_WRITE_BTST },
185
};
186
 
187
static const struct insn_sem m32r2f_insn_sem_invalid = {
188
  VIRTUAL_INSN_X_INVALID, M32R2F_INSN_X_INVALID, M32R2F_SFMT_EMPTY, NOPAR, NOPAR
189
};
190
 
191
/* Initialize an IDESC from the compile-time computable parts.  */
192
 
193
static INLINE void
194
init_idesc (SIM_CPU *cpu, IDESC *id, const struct insn_sem *t)
195
{
196
  const CGEN_INSN *insn_table = CGEN_CPU_INSN_TABLE (CPU_CPU_DESC (cpu))->init_entries;
197
 
198
  id->num = t->index;
199
  id->sfmt = t->sfmt;
200
  if ((int) t->type <= 0)
201
    id->idata = & cgen_virtual_insn_table[- (int) t->type];
202
  else
203
    id->idata = & insn_table[t->type];
204
  id->attrs = CGEN_INSN_ATTRS (id->idata);
205
  /* Oh my god, a magic number.  */
206
  id->length = CGEN_INSN_BITSIZE (id->idata) / 8;
207
 
208
#if WITH_PROFILE_MODEL_P
209
  id->timing = & MODEL_TIMING (CPU_MODEL (cpu)) [t->index];
210
  {
211
    SIM_DESC sd = CPU_STATE (cpu);
212
    SIM_ASSERT (t->index == id->timing->num);
213
  }
214
#endif
215
 
216
  /* Semantic pointers are initialized elsewhere.  */
217
}
218
 
219
/* Initialize the instruction descriptor table.  */
220
 
221
void
222
m32r2f_init_idesc_table (SIM_CPU *cpu)
223
{
224
  IDESC *id,*tabend;
225
  const struct insn_sem *t,*tend;
226
  int tabsize = M32R2F_INSN__MAX;
227
  IDESC *table = m32r2f_insn_data;
228
 
229
  memset (table, 0, tabsize * sizeof (IDESC));
230
 
231
  /* First set all entries to the `invalid insn'.  */
232
  t = & m32r2f_insn_sem_invalid;
233
  for (id = table, tabend = table + tabsize; id < tabend; ++id)
234
    init_idesc (cpu, id, t);
235
 
236
  /* Now fill in the values for the chosen cpu.  */
237
  for (t = m32r2f_insn_sem, tend = t + sizeof (m32r2f_insn_sem) / sizeof (*t);
238
       t != tend; ++t)
239
    {
240
      init_idesc (cpu, & table[t->index], t);
241
      if (t->par_index != NOPAR)
242
        {
243
          init_idesc (cpu, &table[t->par_index], t);
244
          table[t->index].par_idesc = &table[t->par_index];
245
        }
246
      if (t->par_index != NOPAR)
247
        {
248
          init_idesc (cpu, &table[t->write_index], t);
249
          table[t->par_index].par_idesc = &table[t->write_index];
250
        }
251
    }
252
 
253
  /* Link the IDESC table into the cpu.  */
254
  CPU_IDESC (cpu) = table;
255
}
256
 
257
/* Given an instruction, return a pointer to its IDESC entry.  */
258
 
259
const IDESC *
260
m32r2f_decode (SIM_CPU *current_cpu, IADDR pc,
261
              CGEN_INSN_INT base_insn, CGEN_INSN_INT entire_insn,
262
              ARGBUF *abuf)
263
{
264
  /* Result of decoder.  */
265
  M32R2F_INSN_TYPE itype;
266
 
267
  {
268
    CGEN_INSN_INT insn = base_insn;
269
 
270
    {
271
      unsigned int val = (((insn >> 8) & (15 << 4)) | ((insn >> 4) & (15 << 0)));
272
      switch (val)
273
      {
274
      case 0 : itype = M32R2F_INSN_SUBV; goto extract_sfmt_addv;
275
      case 1 : itype = M32R2F_INSN_SUBX; goto extract_sfmt_addx;
276
      case 2 : itype = M32R2F_INSN_SUB; goto extract_sfmt_add;
277
      case 3 : itype = M32R2F_INSN_NEG; goto extract_sfmt_mv;
278
      case 4 : itype = M32R2F_INSN_CMP; goto extract_sfmt_cmp;
279
      case 5 : itype = M32R2F_INSN_CMPU; goto extract_sfmt_cmp;
280
      case 6 : itype = M32R2F_INSN_CMPEQ; goto extract_sfmt_cmp;
281
      case 7 :
282
        {
283
          unsigned int val = (((insn >> 8) & (3 << 0)));
284
          switch (val)
285
          {
286
          case 0 : itype = M32R2F_INSN_CMPZ; goto extract_sfmt_cmpz;
287
          case 3 : itype = M32R2F_INSN_PCMPBZ; goto extract_sfmt_cmpz;
288
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
289
          }
290
        }
291
      case 8 : itype = M32R2F_INSN_ADDV; goto extract_sfmt_addv;
292
      case 9 : itype = M32R2F_INSN_ADDX; goto extract_sfmt_addx;
293
      case 10 : itype = M32R2F_INSN_ADD; goto extract_sfmt_add;
294
      case 11 : itype = M32R2F_INSN_NOT; goto extract_sfmt_mv;
295
      case 12 : itype = M32R2F_INSN_AND; goto extract_sfmt_add;
296
      case 13 : itype = M32R2F_INSN_XOR; goto extract_sfmt_add;
297
      case 14 : itype = M32R2F_INSN_OR; goto extract_sfmt_add;
298
      case 15 : itype = M32R2F_INSN_BTST; goto extract_sfmt_btst;
299
      case 16 : itype = M32R2F_INSN_SRL; goto extract_sfmt_add;
300
      case 18 : itype = M32R2F_INSN_SRA; goto extract_sfmt_add;
301
      case 20 : itype = M32R2F_INSN_SLL; goto extract_sfmt_add;
302
      case 22 : itype = M32R2F_INSN_MUL; goto extract_sfmt_add;
303
      case 24 : itype = M32R2F_INSN_MV; goto extract_sfmt_mv;
304
      case 25 : itype = M32R2F_INSN_MVFC; goto extract_sfmt_mvfc;
305
      case 26 : itype = M32R2F_INSN_MVTC; goto extract_sfmt_mvtc;
306
      case 28 :
307
        {
308
          unsigned int val = (((insn >> 8) & (3 << 0)));
309
          switch (val)
310
          {
311
          case 0 : itype = M32R2F_INSN_JC; goto extract_sfmt_jc;
312
          case 1 : itype = M32R2F_INSN_JNC; goto extract_sfmt_jc;
313
          case 2 : itype = M32R2F_INSN_JL; goto extract_sfmt_jl;
314
          case 3 : itype = M32R2F_INSN_JMP; goto extract_sfmt_jmp;
315
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
316
          }
317
        }
318
      case 29 : itype = M32R2F_INSN_RTE; goto extract_sfmt_rte;
319
      case 31 : itype = M32R2F_INSN_TRAP; goto extract_sfmt_trap;
320
      case 32 : itype = M32R2F_INSN_STB; goto extract_sfmt_stb;
321
      case 33 : itype = M32R2F_INSN_STB_PLUS; goto extract_sfmt_stb_plus;
322
      case 34 : itype = M32R2F_INSN_STH; goto extract_sfmt_sth;
323
      case 35 : itype = M32R2F_INSN_STH_PLUS; goto extract_sfmt_sth_plus;
324
      case 36 : itype = M32R2F_INSN_ST; goto extract_sfmt_st;
325
      case 37 : itype = M32R2F_INSN_UNLOCK; goto extract_sfmt_unlock;
326
      case 38 : itype = M32R2F_INSN_ST_PLUS; goto extract_sfmt_st_plus;
327
      case 39 : itype = M32R2F_INSN_ST_MINUS; goto extract_sfmt_st_plus;
328
      case 40 : itype = M32R2F_INSN_LDB; goto extract_sfmt_ldb;
329
      case 41 : itype = M32R2F_INSN_LDUB; goto extract_sfmt_ldb;
330
      case 42 : itype = M32R2F_INSN_LDH; goto extract_sfmt_ldh;
331
      case 43 : itype = M32R2F_INSN_LDUH; goto extract_sfmt_ldh;
332
      case 44 : itype = M32R2F_INSN_LD; goto extract_sfmt_ld;
333
      case 45 : itype = M32R2F_INSN_LOCK; goto extract_sfmt_lock;
334
      case 46 : itype = M32R2F_INSN_LD_PLUS; goto extract_sfmt_ld_plus;
335
      case 48 : /* fall through */
336
      case 56 : itype = M32R2F_INSN_MULHI_A; goto extract_sfmt_mulhi_a;
337
      case 49 : /* fall through */
338
      case 57 : itype = M32R2F_INSN_MULLO_A; goto extract_sfmt_mulhi_a;
339
      case 50 : /* fall through */
340
      case 58 : itype = M32R2F_INSN_MULWHI_A; goto extract_sfmt_mulhi_a;
341
      case 51 : /* fall through */
342
      case 59 : itype = M32R2F_INSN_MULWLO_A; goto extract_sfmt_mulhi_a;
343
      case 52 : /* fall through */
344
      case 60 : itype = M32R2F_INSN_MACHI_A; goto extract_sfmt_machi_a;
345
      case 53 : /* fall through */
346
      case 61 : itype = M32R2F_INSN_MACLO_A; goto extract_sfmt_machi_a;
347
      case 54 : /* fall through */
348
      case 62 : itype = M32R2F_INSN_MACWHI_A; goto extract_sfmt_machi_a;
349
      case 55 : /* fall through */
350
      case 63 : itype = M32R2F_INSN_MACWLO_A; goto extract_sfmt_machi_a;
351
      case 64 : /* fall through */
352
      case 65 : /* fall through */
353
      case 66 : /* fall through */
354
      case 67 : /* fall through */
355
      case 68 : /* fall through */
356
      case 69 : /* fall through */
357
      case 70 : /* fall through */
358
      case 71 : /* fall through */
359
      case 72 : /* fall through */
360
      case 73 : /* fall through */
361
      case 74 : /* fall through */
362
      case 75 : /* fall through */
363
      case 76 : /* fall through */
364
      case 77 : /* fall through */
365
      case 78 : /* fall through */
366
      case 79 : itype = M32R2F_INSN_ADDI; goto extract_sfmt_addi;
367
      case 80 : /* fall through */
368
      case 81 : itype = M32R2F_INSN_SRLI; goto extract_sfmt_slli;
369
      case 82 : /* fall through */
370
      case 83 : itype = M32R2F_INSN_SRAI; goto extract_sfmt_slli;
371
      case 84 : /* fall through */
372
      case 85 : itype = M32R2F_INSN_SLLI; goto extract_sfmt_slli;
373
      case 87 :
374
        {
375
          unsigned int val = (((insn >> 0) & (1 << 0)));
376
          switch (val)
377
          {
378
          case 0 : itype = M32R2F_INSN_MVTACHI_A; goto extract_sfmt_mvtachi_a;
379
          case 1 : itype = M32R2F_INSN_MVTACLO_A; goto extract_sfmt_mvtachi_a;
380
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
381
          }
382
        }
383
      case 88 : itype = M32R2F_INSN_RACH_DSI; goto extract_sfmt_rac_dsi;
384
      case 89 : itype = M32R2F_INSN_RAC_DSI; goto extract_sfmt_rac_dsi;
385
      case 90 : itype = M32R2F_INSN_MULWU1; goto extract_sfmt_mulwu1;
386
      case 91 : itype = M32R2F_INSN_MACWU1; goto extract_sfmt_macwu1;
387
      case 92 : itype = M32R2F_INSN_MACLH1; goto extract_sfmt_macwu1;
388
      case 93 : itype = M32R2F_INSN_MSBLO; goto extract_sfmt_msblo;
389
      case 94 : itype = M32R2F_INSN_SADD; goto extract_sfmt_sadd;
390
      case 95 :
391
        {
392
          unsigned int val = (((insn >> 0) & (3 << 0)));
393
          switch (val)
394
          {
395
          case 0 : itype = M32R2F_INSN_MVFACHI_A; goto extract_sfmt_mvfachi_a;
396
          case 1 : itype = M32R2F_INSN_MVFACLO_A; goto extract_sfmt_mvfachi_a;
397
          case 2 : itype = M32R2F_INSN_MVFACMI_A; goto extract_sfmt_mvfachi_a;
398
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
399
          }
400
        }
401
      case 96 : /* fall through */
402
      case 97 : /* fall through */
403
      case 98 : /* fall through */
404
      case 99 : /* fall through */
405
      case 100 : /* fall through */
406
      case 101 : /* fall through */
407
      case 102 : /* fall through */
408
      case 103 : /* fall through */
409
      case 104 : /* fall through */
410
      case 105 : /* fall through */
411
      case 106 : /* fall through */
412
      case 107 : /* fall through */
413
      case 108 : /* fall through */
414
      case 109 : /* fall through */
415
      case 110 : /* fall through */
416
      case 111 : itype = M32R2F_INSN_LDI8; goto extract_sfmt_ldi8;
417
      case 112 :
418
        {
419
          unsigned int val = (((insn >> 7) & (15 << 1)) | ((insn >> 0) & (1 << 0)));
420
          switch (val)
421
          {
422
          case 0 : itype = M32R2F_INSN_NOP; goto extract_sfmt_nop;
423
          case 2 : /* fall through */
424
          case 3 : itype = M32R2F_INSN_SETPSW; goto extract_sfmt_setpsw;
425
          case 4 : /* fall through */
426
          case 5 : itype = M32R2F_INSN_CLRPSW; goto extract_sfmt_clrpsw;
427
          case 9 : itype = M32R2F_INSN_SC; goto extract_sfmt_sc;
428
          case 11 : itype = M32R2F_INSN_SNC; goto extract_sfmt_sc;
429
          case 16 : /* fall through */
430
          case 17 : itype = M32R2F_INSN_BCL8; goto extract_sfmt_bcl8;
431
          case 18 : /* fall through */
432
          case 19 : itype = M32R2F_INSN_BNCL8; goto extract_sfmt_bcl8;
433
          case 24 : /* fall through */
434
          case 25 : itype = M32R2F_INSN_BC8; goto extract_sfmt_bc8;
435
          case 26 : /* fall through */
436
          case 27 : itype = M32R2F_INSN_BNC8; goto extract_sfmt_bc8;
437
          case 28 : /* fall through */
438
          case 29 : itype = M32R2F_INSN_BL8; goto extract_sfmt_bl8;
439
          case 30 : /* fall through */
440
          case 31 : itype = M32R2F_INSN_BRA8; goto extract_sfmt_bra8;
441
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
442
          }
443
        }
444
      case 113 : /* fall through */
445
      case 114 : /* fall through */
446
      case 115 : /* fall through */
447
      case 116 : /* fall through */
448
      case 117 : /* fall through */
449
      case 118 : /* fall through */
450
      case 119 : /* fall through */
451
      case 120 : /* fall through */
452
      case 121 : /* fall through */
453
      case 122 : /* fall through */
454
      case 123 : /* fall through */
455
      case 124 : /* fall through */
456
      case 125 : /* fall through */
457
      case 126 : /* fall through */
458
      case 127 :
459
        {
460
          unsigned int val = (((insn >> 8) & (15 << 0)));
461
          switch (val)
462
          {
463
          case 1 : itype = M32R2F_INSN_SETPSW; goto extract_sfmt_setpsw;
464
          case 2 : itype = M32R2F_INSN_CLRPSW; goto extract_sfmt_clrpsw;
465
          case 8 : itype = M32R2F_INSN_BCL8; goto extract_sfmt_bcl8;
466
          case 9 : itype = M32R2F_INSN_BNCL8; goto extract_sfmt_bcl8;
467
          case 12 : itype = M32R2F_INSN_BC8; goto extract_sfmt_bc8;
468
          case 13 : itype = M32R2F_INSN_BNC8; goto extract_sfmt_bc8;
469
          case 14 : itype = M32R2F_INSN_BL8; goto extract_sfmt_bl8;
470
          case 15 : itype = M32R2F_INSN_BRA8; goto extract_sfmt_bra8;
471
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
472
          }
473
        }
474
      case 132 : itype = M32R2F_INSN_CMPI; goto extract_sfmt_cmpi;
475
      case 133 : itype = M32R2F_INSN_CMPUI; goto extract_sfmt_cmpi;
476
      case 134 :
477
        {
478
          unsigned int val = (((insn >> -8) & (3 << 0)));
479
          switch (val)
480
          {
481
          case 0 : itype = M32R2F_INSN_SAT; goto extract_sfmt_sat;
482
          case 2 : itype = M32R2F_INSN_SATH; goto extract_sfmt_satb;
483
          case 3 : itype = M32R2F_INSN_SATB; goto extract_sfmt_satb;
484
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
485
          }
486
        }
487
      case 136 : itype = M32R2F_INSN_ADDV3; goto extract_sfmt_addv3;
488
      case 138 : itype = M32R2F_INSN_ADD3; goto extract_sfmt_add3;
489
      case 140 : itype = M32R2F_INSN_AND3; goto extract_sfmt_and3;
490
      case 141 : itype = M32R2F_INSN_XOR3; goto extract_sfmt_and3;
491
      case 142 : itype = M32R2F_INSN_OR3; goto extract_sfmt_or3;
492
      case 144 :
493
        {
494
          unsigned int val = (((insn >> -13) & (3 << 0)));
495
          switch (val)
496
          {
497
          case 0 : itype = M32R2F_INSN_DIV; goto extract_sfmt_div;
498
          case 2 : itype = M32R2F_INSN_DIVH; goto extract_sfmt_div;
499
          case 3 : itype = M32R2F_INSN_DIVB; goto extract_sfmt_div;
500
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
501
          }
502
        }
503
      case 145 :
504
        {
505
          unsigned int val = (((insn >> -13) & (3 << 0)));
506
          switch (val)
507
          {
508
          case 0 : itype = M32R2F_INSN_DIVU; goto extract_sfmt_div;
509
          case 2 : itype = M32R2F_INSN_DIVUH; goto extract_sfmt_div;
510
          case 3 : itype = M32R2F_INSN_DIVUB; goto extract_sfmt_div;
511
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
512
          }
513
        }
514
      case 146 :
515
        {
516
          unsigned int val = (((insn >> -13) & (3 << 0)));
517
          switch (val)
518
          {
519
          case 0 : itype = M32R2F_INSN_REM; goto extract_sfmt_div;
520
          case 2 : itype = M32R2F_INSN_REMH; goto extract_sfmt_div;
521
          case 3 : itype = M32R2F_INSN_REMB; goto extract_sfmt_div;
522
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
523
          }
524
        }
525
      case 147 :
526
        {
527
          unsigned int val = (((insn >> -13) & (3 << 0)));
528
          switch (val)
529
          {
530
          case 0 : itype = M32R2F_INSN_REMU; goto extract_sfmt_div;
531
          case 2 : itype = M32R2F_INSN_REMUH; goto extract_sfmt_div;
532
          case 3 : itype = M32R2F_INSN_REMUB; goto extract_sfmt_div;
533
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
534
          }
535
        }
536
      case 152 : itype = M32R2F_INSN_SRL3; goto extract_sfmt_sll3;
537
      case 154 : itype = M32R2F_INSN_SRA3; goto extract_sfmt_sll3;
538
      case 156 : itype = M32R2F_INSN_SLL3; goto extract_sfmt_sll3;
539
      case 159 : itype = M32R2F_INSN_LDI16; goto extract_sfmt_ldi16;
540
      case 160 : itype = M32R2F_INSN_STB_D; goto extract_sfmt_stb_d;
541
      case 162 : itype = M32R2F_INSN_STH_D; goto extract_sfmt_sth_d;
542
      case 164 : itype = M32R2F_INSN_ST_D; goto extract_sfmt_st_d;
543
      case 166 : itype = M32R2F_INSN_BSET; goto extract_sfmt_bset;
544
      case 167 : itype = M32R2F_INSN_BCLR; goto extract_sfmt_bset;
545
      case 168 : itype = M32R2F_INSN_LDB_D; goto extract_sfmt_ldb_d;
546
      case 169 : itype = M32R2F_INSN_LDUB_D; goto extract_sfmt_ldb_d;
547
      case 170 : itype = M32R2F_INSN_LDH_D; goto extract_sfmt_ldh_d;
548
      case 171 : itype = M32R2F_INSN_LDUH_D; goto extract_sfmt_ldh_d;
549
      case 172 : itype = M32R2F_INSN_LD_D; goto extract_sfmt_ld_d;
550
      case 176 : itype = M32R2F_INSN_BEQ; goto extract_sfmt_beq;
551
      case 177 : itype = M32R2F_INSN_BNE; goto extract_sfmt_beq;
552
      case 184 : itype = M32R2F_INSN_BEQZ; goto extract_sfmt_beqz;
553
      case 185 : itype = M32R2F_INSN_BNEZ; goto extract_sfmt_beqz;
554
      case 186 : itype = M32R2F_INSN_BLTZ; goto extract_sfmt_beqz;
555
      case 187 : itype = M32R2F_INSN_BGEZ; goto extract_sfmt_beqz;
556
      case 188 : itype = M32R2F_INSN_BLEZ; goto extract_sfmt_beqz;
557
      case 189 : itype = M32R2F_INSN_BGTZ; goto extract_sfmt_beqz;
558
      case 220 : itype = M32R2F_INSN_SETH; goto extract_sfmt_seth;
559
      case 224 : /* fall through */
560
      case 225 : /* fall through */
561
      case 226 : /* fall through */
562
      case 227 : /* fall through */
563
      case 228 : /* fall through */
564
      case 229 : /* fall through */
565
      case 230 : /* fall through */
566
      case 231 : /* fall through */
567
      case 232 : /* fall through */
568
      case 233 : /* fall through */
569
      case 234 : /* fall through */
570
      case 235 : /* fall through */
571
      case 236 : /* fall through */
572
      case 237 : /* fall through */
573
      case 238 : /* fall through */
574
      case 239 : itype = M32R2F_INSN_LD24; goto extract_sfmt_ld24;
575
      case 240 : /* fall through */
576
      case 241 : /* fall through */
577
      case 242 : /* fall through */
578
      case 243 : /* fall through */
579
      case 244 : /* fall through */
580
      case 245 : /* fall through */
581
      case 246 : /* fall through */
582
      case 247 : /* fall through */
583
      case 248 : /* fall through */
584
      case 249 : /* fall through */
585
      case 250 : /* fall through */
586
      case 251 : /* fall through */
587
      case 252 : /* fall through */
588
      case 253 : /* fall through */
589
      case 254 : /* fall through */
590
      case 255 :
591
        {
592
          unsigned int val = (((insn >> 8) & (7 << 0)));
593
          switch (val)
594
          {
595
          case 0 : itype = M32R2F_INSN_BCL24; goto extract_sfmt_bcl24;
596
          case 1 : itype = M32R2F_INSN_BNCL24; goto extract_sfmt_bcl24;
597
          case 4 : itype = M32R2F_INSN_BC24; goto extract_sfmt_bc24;
598
          case 5 : itype = M32R2F_INSN_BNC24; goto extract_sfmt_bc24;
599
          case 6 : itype = M32R2F_INSN_BL24; goto extract_sfmt_bl24;
600
          case 7 : itype = M32R2F_INSN_BRA24; goto extract_sfmt_bra24;
601
          default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
602
          }
603
        }
604
      default : itype = M32R2F_INSN_X_INVALID; goto extract_sfmt_empty;
605
      }
606
    }
607
  }
608
 
609
  /* The instruction has been decoded, now extract the fields.  */
610
 
611
 extract_sfmt_empty:
612
  {
613
    const IDESC *idesc = &m32r2f_insn_data[itype];
614
#define FLD(f) abuf->fields.fmt_empty.f
615
 
616
 
617
  /* Record the fields for the semantic handler.  */
618
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_empty", (char *) 0));
619
 
620
#undef FLD
621
    return idesc;
622
  }
623
 
624
 extract_sfmt_add:
625
  {
626
    const IDESC *idesc = &m32r2f_insn_data[itype];
627
    CGEN_INSN_INT insn = entire_insn;
628
#define FLD(f) abuf->fields.sfmt_add.f
629
    UINT f_r1;
630
    UINT f_r2;
631
 
632
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
633
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
634
 
635
  /* Record the fields for the semantic handler.  */
636
  FLD (f_r1) = f_r1;
637
  FLD (f_r2) = f_r2;
638
  FLD (i_dr) = & CPU (h_gr)[f_r1];
639
  FLD (i_sr) = & CPU (h_gr)[f_r2];
640
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_add", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, (char *) 0));
641
 
642
#if WITH_PROFILE_MODEL_P
643
  /* Record the fields for profiling.  */
644
  if (PROFILE_MODEL_P (current_cpu))
645
    {
646
      FLD (in_dr) = f_r1;
647
      FLD (in_sr) = f_r2;
648
      FLD (out_dr) = f_r1;
649
    }
650
#endif
651
#undef FLD
652
    return idesc;
653
  }
654
 
655
 extract_sfmt_add3:
656
  {
657
    const IDESC *idesc = &m32r2f_insn_data[itype];
658
    CGEN_INSN_INT insn = entire_insn;
659
#define FLD(f) abuf->fields.sfmt_add3.f
660
    UINT f_r1;
661
    UINT f_r2;
662
    INT f_simm16;
663
 
664
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
665
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
666
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
667
 
668
  /* Record the fields for the semantic handler.  */
669
  FLD (f_simm16) = f_simm16;
670
  FLD (f_r2) = f_r2;
671
  FLD (f_r1) = f_r1;
672
  FLD (i_sr) = & CPU (h_gr)[f_r2];
673
  FLD (i_dr) = & CPU (h_gr)[f_r1];
674
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_add3", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
675
 
676
#if WITH_PROFILE_MODEL_P
677
  /* Record the fields for profiling.  */
678
  if (PROFILE_MODEL_P (current_cpu))
679
    {
680
      FLD (in_sr) = f_r2;
681
      FLD (out_dr) = f_r1;
682
    }
683
#endif
684
#undef FLD
685
    return idesc;
686
  }
687
 
688
 extract_sfmt_and3:
689
  {
690
    const IDESC *idesc = &m32r2f_insn_data[itype];
691
    CGEN_INSN_INT insn = entire_insn;
692
#define FLD(f) abuf->fields.sfmt_and3.f
693
    UINT f_r1;
694
    UINT f_r2;
695
    UINT f_uimm16;
696
 
697
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
698
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
699
    f_uimm16 = EXTRACT_MSB0_UINT (insn, 32, 16, 16);
700
 
701
  /* Record the fields for the semantic handler.  */
702
  FLD (f_r2) = f_r2;
703
  FLD (f_uimm16) = f_uimm16;
704
  FLD (f_r1) = f_r1;
705
  FLD (i_sr) = & CPU (h_gr)[f_r2];
706
  FLD (i_dr) = & CPU (h_gr)[f_r1];
707
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_and3", "f_r2 0x%x", 'x', f_r2, "f_uimm16 0x%x", 'x', f_uimm16, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
708
 
709
#if WITH_PROFILE_MODEL_P
710
  /* Record the fields for profiling.  */
711
  if (PROFILE_MODEL_P (current_cpu))
712
    {
713
      FLD (in_sr) = f_r2;
714
      FLD (out_dr) = f_r1;
715
    }
716
#endif
717
#undef FLD
718
    return idesc;
719
  }
720
 
721
 extract_sfmt_or3:
722
  {
723
    const IDESC *idesc = &m32r2f_insn_data[itype];
724
    CGEN_INSN_INT insn = entire_insn;
725
#define FLD(f) abuf->fields.sfmt_and3.f
726
    UINT f_r1;
727
    UINT f_r2;
728
    UINT f_uimm16;
729
 
730
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
731
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
732
    f_uimm16 = EXTRACT_MSB0_UINT (insn, 32, 16, 16);
733
 
734
  /* Record the fields for the semantic handler.  */
735
  FLD (f_r2) = f_r2;
736
  FLD (f_uimm16) = f_uimm16;
737
  FLD (f_r1) = f_r1;
738
  FLD (i_sr) = & CPU (h_gr)[f_r2];
739
  FLD (i_dr) = & CPU (h_gr)[f_r1];
740
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_or3", "f_r2 0x%x", 'x', f_r2, "f_uimm16 0x%x", 'x', f_uimm16, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
741
 
742
#if WITH_PROFILE_MODEL_P
743
  /* Record the fields for profiling.  */
744
  if (PROFILE_MODEL_P (current_cpu))
745
    {
746
      FLD (in_sr) = f_r2;
747
      FLD (out_dr) = f_r1;
748
    }
749
#endif
750
#undef FLD
751
    return idesc;
752
  }
753
 
754
 extract_sfmt_addi:
755
  {
756
    const IDESC *idesc = &m32r2f_insn_data[itype];
757
    CGEN_INSN_INT insn = entire_insn;
758
#define FLD(f) abuf->fields.sfmt_addi.f
759
    UINT f_r1;
760
    INT f_simm8;
761
 
762
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
763
    f_simm8 = EXTRACT_MSB0_INT (insn, 16, 8, 8);
764
 
765
  /* Record the fields for the semantic handler.  */
766
  FLD (f_r1) = f_r1;
767
  FLD (f_simm8) = f_simm8;
768
  FLD (i_dr) = & CPU (h_gr)[f_r1];
769
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addi", "f_r1 0x%x", 'x', f_r1, "f_simm8 0x%x", 'x', f_simm8, "dr 0x%x", 'x', f_r1, (char *) 0));
770
 
771
#if WITH_PROFILE_MODEL_P
772
  /* Record the fields for profiling.  */
773
  if (PROFILE_MODEL_P (current_cpu))
774
    {
775
      FLD (in_dr) = f_r1;
776
      FLD (out_dr) = f_r1;
777
    }
778
#endif
779
#undef FLD
780
    return idesc;
781
  }
782
 
783
 extract_sfmt_addv:
784
  {
785
    const IDESC *idesc = &m32r2f_insn_data[itype];
786
    CGEN_INSN_INT insn = entire_insn;
787
#define FLD(f) abuf->fields.sfmt_add.f
788
    UINT f_r1;
789
    UINT f_r2;
790
 
791
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
792
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
793
 
794
  /* Record the fields for the semantic handler.  */
795
  FLD (f_r1) = f_r1;
796
  FLD (f_r2) = f_r2;
797
  FLD (i_dr) = & CPU (h_gr)[f_r1];
798
  FLD (i_sr) = & CPU (h_gr)[f_r2];
799
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addv", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, (char *) 0));
800
 
801
#if WITH_PROFILE_MODEL_P
802
  /* Record the fields for profiling.  */
803
  if (PROFILE_MODEL_P (current_cpu))
804
    {
805
      FLD (in_dr) = f_r1;
806
      FLD (in_sr) = f_r2;
807
      FLD (out_dr) = f_r1;
808
    }
809
#endif
810
#undef FLD
811
    return idesc;
812
  }
813
 
814
 extract_sfmt_addv3:
815
  {
816
    const IDESC *idesc = &m32r2f_insn_data[itype];
817
    CGEN_INSN_INT insn = entire_insn;
818
#define FLD(f) abuf->fields.sfmt_add3.f
819
    UINT f_r1;
820
    UINT f_r2;
821
    INT f_simm16;
822
 
823
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
824
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
825
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
826
 
827
  /* Record the fields for the semantic handler.  */
828
  FLD (f_simm16) = f_simm16;
829
  FLD (f_r2) = f_r2;
830
  FLD (f_r1) = f_r1;
831
  FLD (i_sr) = & CPU (h_gr)[f_r2];
832
  FLD (i_dr) = & CPU (h_gr)[f_r1];
833
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addv3", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
834
 
835
#if WITH_PROFILE_MODEL_P
836
  /* Record the fields for profiling.  */
837
  if (PROFILE_MODEL_P (current_cpu))
838
    {
839
      FLD (in_sr) = f_r2;
840
      FLD (out_dr) = f_r1;
841
    }
842
#endif
843
#undef FLD
844
    return idesc;
845
  }
846
 
847
 extract_sfmt_addx:
848
  {
849
    const IDESC *idesc = &m32r2f_insn_data[itype];
850
    CGEN_INSN_INT insn = entire_insn;
851
#define FLD(f) abuf->fields.sfmt_add.f
852
    UINT f_r1;
853
    UINT f_r2;
854
 
855
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
856
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
857
 
858
  /* Record the fields for the semantic handler.  */
859
  FLD (f_r1) = f_r1;
860
  FLD (f_r2) = f_r2;
861
  FLD (i_dr) = & CPU (h_gr)[f_r1];
862
  FLD (i_sr) = & CPU (h_gr)[f_r2];
863
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_addx", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, (char *) 0));
864
 
865
#if WITH_PROFILE_MODEL_P
866
  /* Record the fields for profiling.  */
867
  if (PROFILE_MODEL_P (current_cpu))
868
    {
869
      FLD (in_dr) = f_r1;
870
      FLD (in_sr) = f_r2;
871
      FLD (out_dr) = f_r1;
872
    }
873
#endif
874
#undef FLD
875
    return idesc;
876
  }
877
 
878
 extract_sfmt_bc8:
879
  {
880
    const IDESC *idesc = &m32r2f_insn_data[itype];
881
    CGEN_INSN_INT insn = entire_insn;
882
#define FLD(f) abuf->fields.sfmt_bl8.f
883
    SI f_disp8;
884
 
885
    f_disp8 = ((((EXTRACT_MSB0_INT (insn, 16, 8, 8)) << (2))) + (((pc) & (-4))));
886
 
887
  /* Record the fields for the semantic handler.  */
888
  FLD (i_disp8) = f_disp8;
889
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bc8", "disp8 0x%x", 'x', f_disp8, (char *) 0));
890
 
891
#if WITH_PROFILE_MODEL_P
892
  /* Record the fields for profiling.  */
893
  if (PROFILE_MODEL_P (current_cpu))
894
    {
895
    }
896
#endif
897
#undef FLD
898
    return idesc;
899
  }
900
 
901
 extract_sfmt_bc24:
902
  {
903
    const IDESC *idesc = &m32r2f_insn_data[itype];
904
    CGEN_INSN_INT insn = entire_insn;
905
#define FLD(f) abuf->fields.sfmt_bl24.f
906
    SI f_disp24;
907
 
908
    f_disp24 = ((((EXTRACT_MSB0_INT (insn, 32, 8, 24)) << (2))) + (pc));
909
 
910
  /* Record the fields for the semantic handler.  */
911
  FLD (i_disp24) = f_disp24;
912
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bc24", "disp24 0x%x", 'x', f_disp24, (char *) 0));
913
 
914
#if WITH_PROFILE_MODEL_P
915
  /* Record the fields for profiling.  */
916
  if (PROFILE_MODEL_P (current_cpu))
917
    {
918
    }
919
#endif
920
#undef FLD
921
    return idesc;
922
  }
923
 
924
 extract_sfmt_beq:
925
  {
926
    const IDESC *idesc = &m32r2f_insn_data[itype];
927
    CGEN_INSN_INT insn = entire_insn;
928
#define FLD(f) abuf->fields.sfmt_beq.f
929
    UINT f_r1;
930
    UINT f_r2;
931
    SI f_disp16;
932
 
933
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
934
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
935
    f_disp16 = ((((EXTRACT_MSB0_INT (insn, 32, 16, 16)) << (2))) + (pc));
936
 
937
  /* Record the fields for the semantic handler.  */
938
  FLD (f_r1) = f_r1;
939
  FLD (f_r2) = f_r2;
940
  FLD (i_disp16) = f_disp16;
941
  FLD (i_src1) = & CPU (h_gr)[f_r1];
942
  FLD (i_src2) = & CPU (h_gr)[f_r2];
943
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_beq", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "disp16 0x%x", 'x', f_disp16, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
944
 
945
#if WITH_PROFILE_MODEL_P
946
  /* Record the fields for profiling.  */
947
  if (PROFILE_MODEL_P (current_cpu))
948
    {
949
      FLD (in_src1) = f_r1;
950
      FLD (in_src2) = f_r2;
951
    }
952
#endif
953
#undef FLD
954
    return idesc;
955
  }
956
 
957
 extract_sfmt_beqz:
958
  {
959
    const IDESC *idesc = &m32r2f_insn_data[itype];
960
    CGEN_INSN_INT insn = entire_insn;
961
#define FLD(f) abuf->fields.sfmt_beq.f
962
    UINT f_r2;
963
    SI f_disp16;
964
 
965
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
966
    f_disp16 = ((((EXTRACT_MSB0_INT (insn, 32, 16, 16)) << (2))) + (pc));
967
 
968
  /* Record the fields for the semantic handler.  */
969
  FLD (f_r2) = f_r2;
970
  FLD (i_disp16) = f_disp16;
971
  FLD (i_src2) = & CPU (h_gr)[f_r2];
972
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_beqz", "f_r2 0x%x", 'x', f_r2, "disp16 0x%x", 'x', f_disp16, "src2 0x%x", 'x', f_r2, (char *) 0));
973
 
974
#if WITH_PROFILE_MODEL_P
975
  /* Record the fields for profiling.  */
976
  if (PROFILE_MODEL_P (current_cpu))
977
    {
978
      FLD (in_src2) = f_r2;
979
    }
980
#endif
981
#undef FLD
982
    return idesc;
983
  }
984
 
985
 extract_sfmt_bl8:
986
  {
987
    const IDESC *idesc = &m32r2f_insn_data[itype];
988
    CGEN_INSN_INT insn = entire_insn;
989
#define FLD(f) abuf->fields.sfmt_bl8.f
990
    SI f_disp8;
991
 
992
    f_disp8 = ((((EXTRACT_MSB0_INT (insn, 16, 8, 8)) << (2))) + (((pc) & (-4))));
993
 
994
  /* Record the fields for the semantic handler.  */
995
  FLD (i_disp8) = f_disp8;
996
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bl8", "disp8 0x%x", 'x', f_disp8, (char *) 0));
997
 
998
#if WITH_PROFILE_MODEL_P
999
  /* Record the fields for profiling.  */
1000
  if (PROFILE_MODEL_P (current_cpu))
1001
    {
1002
      FLD (out_h_gr_SI_14) = 14;
1003
    }
1004
#endif
1005
#undef FLD
1006
    return idesc;
1007
  }
1008
 
1009
 extract_sfmt_bl24:
1010
  {
1011
    const IDESC *idesc = &m32r2f_insn_data[itype];
1012
    CGEN_INSN_INT insn = entire_insn;
1013
#define FLD(f) abuf->fields.sfmt_bl24.f
1014
    SI f_disp24;
1015
 
1016
    f_disp24 = ((((EXTRACT_MSB0_INT (insn, 32, 8, 24)) << (2))) + (pc));
1017
 
1018
  /* Record the fields for the semantic handler.  */
1019
  FLD (i_disp24) = f_disp24;
1020
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bl24", "disp24 0x%x", 'x', f_disp24, (char *) 0));
1021
 
1022
#if WITH_PROFILE_MODEL_P
1023
  /* Record the fields for profiling.  */
1024
  if (PROFILE_MODEL_P (current_cpu))
1025
    {
1026
      FLD (out_h_gr_SI_14) = 14;
1027
    }
1028
#endif
1029
#undef FLD
1030
    return idesc;
1031
  }
1032
 
1033
 extract_sfmt_bcl8:
1034
  {
1035
    const IDESC *idesc = &m32r2f_insn_data[itype];
1036
    CGEN_INSN_INT insn = entire_insn;
1037
#define FLD(f) abuf->fields.sfmt_bl8.f
1038
    SI f_disp8;
1039
 
1040
    f_disp8 = ((((EXTRACT_MSB0_INT (insn, 16, 8, 8)) << (2))) + (((pc) & (-4))));
1041
 
1042
  /* Record the fields for the semantic handler.  */
1043
  FLD (i_disp8) = f_disp8;
1044
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bcl8", "disp8 0x%x", 'x', f_disp8, (char *) 0));
1045
 
1046
#if WITH_PROFILE_MODEL_P
1047
  /* Record the fields for profiling.  */
1048
  if (PROFILE_MODEL_P (current_cpu))
1049
    {
1050
      FLD (out_h_gr_SI_14) = 14;
1051
    }
1052
#endif
1053
#undef FLD
1054
    return idesc;
1055
  }
1056
 
1057
 extract_sfmt_bcl24:
1058
  {
1059
    const IDESC *idesc = &m32r2f_insn_data[itype];
1060
    CGEN_INSN_INT insn = entire_insn;
1061
#define FLD(f) abuf->fields.sfmt_bl24.f
1062
    SI f_disp24;
1063
 
1064
    f_disp24 = ((((EXTRACT_MSB0_INT (insn, 32, 8, 24)) << (2))) + (pc));
1065
 
1066
  /* Record the fields for the semantic handler.  */
1067
  FLD (i_disp24) = f_disp24;
1068
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bcl24", "disp24 0x%x", 'x', f_disp24, (char *) 0));
1069
 
1070
#if WITH_PROFILE_MODEL_P
1071
  /* Record the fields for profiling.  */
1072
  if (PROFILE_MODEL_P (current_cpu))
1073
    {
1074
      FLD (out_h_gr_SI_14) = 14;
1075
    }
1076
#endif
1077
#undef FLD
1078
    return idesc;
1079
  }
1080
 
1081
 extract_sfmt_bra8:
1082
  {
1083
    const IDESC *idesc = &m32r2f_insn_data[itype];
1084
    CGEN_INSN_INT insn = entire_insn;
1085
#define FLD(f) abuf->fields.sfmt_bl8.f
1086
    SI f_disp8;
1087
 
1088
    f_disp8 = ((((EXTRACT_MSB0_INT (insn, 16, 8, 8)) << (2))) + (((pc) & (-4))));
1089
 
1090
  /* Record the fields for the semantic handler.  */
1091
  FLD (i_disp8) = f_disp8;
1092
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bra8", "disp8 0x%x", 'x', f_disp8, (char *) 0));
1093
 
1094
#if WITH_PROFILE_MODEL_P
1095
  /* Record the fields for profiling.  */
1096
  if (PROFILE_MODEL_P (current_cpu))
1097
    {
1098
    }
1099
#endif
1100
#undef FLD
1101
    return idesc;
1102
  }
1103
 
1104
 extract_sfmt_bra24:
1105
  {
1106
    const IDESC *idesc = &m32r2f_insn_data[itype];
1107
    CGEN_INSN_INT insn = entire_insn;
1108
#define FLD(f) abuf->fields.sfmt_bl24.f
1109
    SI f_disp24;
1110
 
1111
    f_disp24 = ((((EXTRACT_MSB0_INT (insn, 32, 8, 24)) << (2))) + (pc));
1112
 
1113
  /* Record the fields for the semantic handler.  */
1114
  FLD (i_disp24) = f_disp24;
1115
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bra24", "disp24 0x%x", 'x', f_disp24, (char *) 0));
1116
 
1117
#if WITH_PROFILE_MODEL_P
1118
  /* Record the fields for profiling.  */
1119
  if (PROFILE_MODEL_P (current_cpu))
1120
    {
1121
    }
1122
#endif
1123
#undef FLD
1124
    return idesc;
1125
  }
1126
 
1127
 extract_sfmt_cmp:
1128
  {
1129
    const IDESC *idesc = &m32r2f_insn_data[itype];
1130
    CGEN_INSN_INT insn = entire_insn;
1131
#define FLD(f) abuf->fields.sfmt_st_plus.f
1132
    UINT f_r1;
1133
    UINT f_r2;
1134
 
1135
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1136
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1137
 
1138
  /* Record the fields for the semantic handler.  */
1139
  FLD (f_r1) = f_r1;
1140
  FLD (f_r2) = f_r2;
1141
  FLD (i_src1) = & CPU (h_gr)[f_r1];
1142
  FLD (i_src2) = & CPU (h_gr)[f_r2];
1143
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmp", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
1144
 
1145
#if WITH_PROFILE_MODEL_P
1146
  /* Record the fields for profiling.  */
1147
  if (PROFILE_MODEL_P (current_cpu))
1148
    {
1149
      FLD (in_src1) = f_r1;
1150
      FLD (in_src2) = f_r2;
1151
    }
1152
#endif
1153
#undef FLD
1154
    return idesc;
1155
  }
1156
 
1157
 extract_sfmt_cmpi:
1158
  {
1159
    const IDESC *idesc = &m32r2f_insn_data[itype];
1160
    CGEN_INSN_INT insn = entire_insn;
1161
#define FLD(f) abuf->fields.sfmt_st_d.f
1162
    UINT f_r2;
1163
    INT f_simm16;
1164
 
1165
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
1166
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
1167
 
1168
  /* Record the fields for the semantic handler.  */
1169
  FLD (f_simm16) = f_simm16;
1170
  FLD (f_r2) = f_r2;
1171
  FLD (i_src2) = & CPU (h_gr)[f_r2];
1172
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpi", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "src2 0x%x", 'x', f_r2, (char *) 0));
1173
 
1174
#if WITH_PROFILE_MODEL_P
1175
  /* Record the fields for profiling.  */
1176
  if (PROFILE_MODEL_P (current_cpu))
1177
    {
1178
      FLD (in_src2) = f_r2;
1179
    }
1180
#endif
1181
#undef FLD
1182
    return idesc;
1183
  }
1184
 
1185
 extract_sfmt_cmpz:
1186
  {
1187
    const IDESC *idesc = &m32r2f_insn_data[itype];
1188
    CGEN_INSN_INT insn = entire_insn;
1189
#define FLD(f) abuf->fields.sfmt_st_plus.f
1190
    UINT f_r2;
1191
 
1192
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1193
 
1194
  /* Record the fields for the semantic handler.  */
1195
  FLD (f_r2) = f_r2;
1196
  FLD (i_src2) = & CPU (h_gr)[f_r2];
1197
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_cmpz", "f_r2 0x%x", 'x', f_r2, "src2 0x%x", 'x', f_r2, (char *) 0));
1198
 
1199
#if WITH_PROFILE_MODEL_P
1200
  /* Record the fields for profiling.  */
1201
  if (PROFILE_MODEL_P (current_cpu))
1202
    {
1203
      FLD (in_src2) = f_r2;
1204
    }
1205
#endif
1206
#undef FLD
1207
    return idesc;
1208
  }
1209
 
1210
 extract_sfmt_div:
1211
  {
1212
    const IDESC *idesc = &m32r2f_insn_data[itype];
1213
    CGEN_INSN_INT insn = entire_insn;
1214
#define FLD(f) abuf->fields.sfmt_add.f
1215
    UINT f_r1;
1216
    UINT f_r2;
1217
 
1218
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1219
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
1220
 
1221
  /* Record the fields for the semantic handler.  */
1222
  FLD (f_r1) = f_r1;
1223
  FLD (f_r2) = f_r2;
1224
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1225
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1226
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_div", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, (char *) 0));
1227
 
1228
#if WITH_PROFILE_MODEL_P
1229
  /* Record the fields for profiling.  */
1230
  if (PROFILE_MODEL_P (current_cpu))
1231
    {
1232
      FLD (in_dr) = f_r1;
1233
      FLD (in_sr) = f_r2;
1234
      FLD (out_dr) = f_r1;
1235
    }
1236
#endif
1237
#undef FLD
1238
    return idesc;
1239
  }
1240
 
1241
 extract_sfmt_jc:
1242
  {
1243
    const IDESC *idesc = &m32r2f_insn_data[itype];
1244
    CGEN_INSN_INT insn = entire_insn;
1245
#define FLD(f) abuf->fields.sfmt_jl.f
1246
    UINT f_r2;
1247
 
1248
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1249
 
1250
  /* Record the fields for the semantic handler.  */
1251
  FLD (f_r2) = f_r2;
1252
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1253
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jc", "f_r2 0x%x", 'x', f_r2, "sr 0x%x", 'x', f_r2, (char *) 0));
1254
 
1255
#if WITH_PROFILE_MODEL_P
1256
  /* Record the fields for profiling.  */
1257
  if (PROFILE_MODEL_P (current_cpu))
1258
    {
1259
      FLD (in_sr) = f_r2;
1260
    }
1261
#endif
1262
#undef FLD
1263
    return idesc;
1264
  }
1265
 
1266
 extract_sfmt_jl:
1267
  {
1268
    const IDESC *idesc = &m32r2f_insn_data[itype];
1269
    CGEN_INSN_INT insn = entire_insn;
1270
#define FLD(f) abuf->fields.sfmt_jl.f
1271
    UINT f_r2;
1272
 
1273
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1274
 
1275
  /* Record the fields for the semantic handler.  */
1276
  FLD (f_r2) = f_r2;
1277
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1278
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jl", "f_r2 0x%x", 'x', f_r2, "sr 0x%x", 'x', f_r2, (char *) 0));
1279
 
1280
#if WITH_PROFILE_MODEL_P
1281
  /* Record the fields for profiling.  */
1282
  if (PROFILE_MODEL_P (current_cpu))
1283
    {
1284
      FLD (in_sr) = f_r2;
1285
      FLD (out_h_gr_SI_14) = 14;
1286
    }
1287
#endif
1288
#undef FLD
1289
    return idesc;
1290
  }
1291
 
1292
 extract_sfmt_jmp:
1293
  {
1294
    const IDESC *idesc = &m32r2f_insn_data[itype];
1295
    CGEN_INSN_INT insn = entire_insn;
1296
#define FLD(f) abuf->fields.sfmt_jl.f
1297
    UINT f_r2;
1298
 
1299
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1300
 
1301
  /* Record the fields for the semantic handler.  */
1302
  FLD (f_r2) = f_r2;
1303
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1304
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_jmp", "f_r2 0x%x", 'x', f_r2, "sr 0x%x", 'x', f_r2, (char *) 0));
1305
 
1306
#if WITH_PROFILE_MODEL_P
1307
  /* Record the fields for profiling.  */
1308
  if (PROFILE_MODEL_P (current_cpu))
1309
    {
1310
      FLD (in_sr) = f_r2;
1311
    }
1312
#endif
1313
#undef FLD
1314
    return idesc;
1315
  }
1316
 
1317
 extract_sfmt_ld:
1318
  {
1319
    const IDESC *idesc = &m32r2f_insn_data[itype];
1320
    CGEN_INSN_INT insn = entire_insn;
1321
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1322
    UINT f_r1;
1323
    UINT f_r2;
1324
 
1325
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1326
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1327
 
1328
  /* Record the fields for the semantic handler.  */
1329
  FLD (f_r2) = f_r2;
1330
  FLD (f_r1) = f_r1;
1331
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1332
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1333
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ld", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1334
 
1335
#if WITH_PROFILE_MODEL_P
1336
  /* Record the fields for profiling.  */
1337
  if (PROFILE_MODEL_P (current_cpu))
1338
    {
1339
      FLD (in_sr) = f_r2;
1340
      FLD (out_dr) = f_r1;
1341
    }
1342
#endif
1343
#undef FLD
1344
    return idesc;
1345
  }
1346
 
1347
 extract_sfmt_ld_d:
1348
  {
1349
    const IDESC *idesc = &m32r2f_insn_data[itype];
1350
    CGEN_INSN_INT insn = entire_insn;
1351
#define FLD(f) abuf->fields.sfmt_add3.f
1352
    UINT f_r1;
1353
    UINT f_r2;
1354
    INT f_simm16;
1355
 
1356
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1357
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
1358
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
1359
 
1360
  /* Record the fields for the semantic handler.  */
1361
  FLD (f_simm16) = f_simm16;
1362
  FLD (f_r2) = f_r2;
1363
  FLD (f_r1) = f_r1;
1364
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1365
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1366
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ld_d", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1367
 
1368
#if WITH_PROFILE_MODEL_P
1369
  /* Record the fields for profiling.  */
1370
  if (PROFILE_MODEL_P (current_cpu))
1371
    {
1372
      FLD (in_sr) = f_r2;
1373
      FLD (out_dr) = f_r1;
1374
    }
1375
#endif
1376
#undef FLD
1377
    return idesc;
1378
  }
1379
 
1380
 extract_sfmt_ldb:
1381
  {
1382
    const IDESC *idesc = &m32r2f_insn_data[itype];
1383
    CGEN_INSN_INT insn = entire_insn;
1384
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1385
    UINT f_r1;
1386
    UINT f_r2;
1387
 
1388
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1389
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1390
 
1391
  /* Record the fields for the semantic handler.  */
1392
  FLD (f_r2) = f_r2;
1393
  FLD (f_r1) = f_r1;
1394
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1395
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1396
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldb", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1397
 
1398
#if WITH_PROFILE_MODEL_P
1399
  /* Record the fields for profiling.  */
1400
  if (PROFILE_MODEL_P (current_cpu))
1401
    {
1402
      FLD (in_sr) = f_r2;
1403
      FLD (out_dr) = f_r1;
1404
    }
1405
#endif
1406
#undef FLD
1407
    return idesc;
1408
  }
1409
 
1410
 extract_sfmt_ldb_d:
1411
  {
1412
    const IDESC *idesc = &m32r2f_insn_data[itype];
1413
    CGEN_INSN_INT insn = entire_insn;
1414
#define FLD(f) abuf->fields.sfmt_add3.f
1415
    UINT f_r1;
1416
    UINT f_r2;
1417
    INT f_simm16;
1418
 
1419
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1420
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
1421
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
1422
 
1423
  /* Record the fields for the semantic handler.  */
1424
  FLD (f_simm16) = f_simm16;
1425
  FLD (f_r2) = f_r2;
1426
  FLD (f_r1) = f_r1;
1427
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1428
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1429
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldb_d", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1430
 
1431
#if WITH_PROFILE_MODEL_P
1432
  /* Record the fields for profiling.  */
1433
  if (PROFILE_MODEL_P (current_cpu))
1434
    {
1435
      FLD (in_sr) = f_r2;
1436
      FLD (out_dr) = f_r1;
1437
    }
1438
#endif
1439
#undef FLD
1440
    return idesc;
1441
  }
1442
 
1443
 extract_sfmt_ldh:
1444
  {
1445
    const IDESC *idesc = &m32r2f_insn_data[itype];
1446
    CGEN_INSN_INT insn = entire_insn;
1447
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1448
    UINT f_r1;
1449
    UINT f_r2;
1450
 
1451
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1452
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1453
 
1454
  /* Record the fields for the semantic handler.  */
1455
  FLD (f_r2) = f_r2;
1456
  FLD (f_r1) = f_r1;
1457
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1458
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1459
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldh", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1460
 
1461
#if WITH_PROFILE_MODEL_P
1462
  /* Record the fields for profiling.  */
1463
  if (PROFILE_MODEL_P (current_cpu))
1464
    {
1465
      FLD (in_sr) = f_r2;
1466
      FLD (out_dr) = f_r1;
1467
    }
1468
#endif
1469
#undef FLD
1470
    return idesc;
1471
  }
1472
 
1473
 extract_sfmt_ldh_d:
1474
  {
1475
    const IDESC *idesc = &m32r2f_insn_data[itype];
1476
    CGEN_INSN_INT insn = entire_insn;
1477
#define FLD(f) abuf->fields.sfmt_add3.f
1478
    UINT f_r1;
1479
    UINT f_r2;
1480
    INT f_simm16;
1481
 
1482
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1483
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
1484
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
1485
 
1486
  /* Record the fields for the semantic handler.  */
1487
  FLD (f_simm16) = f_simm16;
1488
  FLD (f_r2) = f_r2;
1489
  FLD (f_r1) = f_r1;
1490
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1491
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1492
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldh_d", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1493
 
1494
#if WITH_PROFILE_MODEL_P
1495
  /* Record the fields for profiling.  */
1496
  if (PROFILE_MODEL_P (current_cpu))
1497
    {
1498
      FLD (in_sr) = f_r2;
1499
      FLD (out_dr) = f_r1;
1500
    }
1501
#endif
1502
#undef FLD
1503
    return idesc;
1504
  }
1505
 
1506
 extract_sfmt_ld_plus:
1507
  {
1508
    const IDESC *idesc = &m32r2f_insn_data[itype];
1509
    CGEN_INSN_INT insn = entire_insn;
1510
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1511
    UINT f_r1;
1512
    UINT f_r2;
1513
 
1514
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1515
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1516
 
1517
  /* Record the fields for the semantic handler.  */
1518
  FLD (f_r2) = f_r2;
1519
  FLD (f_r1) = f_r1;
1520
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1521
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1522
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ld_plus", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1523
 
1524
#if WITH_PROFILE_MODEL_P
1525
  /* Record the fields for profiling.  */
1526
  if (PROFILE_MODEL_P (current_cpu))
1527
    {
1528
      FLD (in_sr) = f_r2;
1529
      FLD (out_dr) = f_r1;
1530
      FLD (out_sr) = f_r2;
1531
    }
1532
#endif
1533
#undef FLD
1534
    return idesc;
1535
  }
1536
 
1537
 extract_sfmt_ld24:
1538
  {
1539
    const IDESC *idesc = &m32r2f_insn_data[itype];
1540
    CGEN_INSN_INT insn = entire_insn;
1541
#define FLD(f) abuf->fields.sfmt_ld24.f
1542
    UINT f_r1;
1543
    UINT f_uimm24;
1544
 
1545
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1546
    f_uimm24 = EXTRACT_MSB0_UINT (insn, 32, 8, 24);
1547
 
1548
  /* Record the fields for the semantic handler.  */
1549
  FLD (f_r1) = f_r1;
1550
  FLD (i_uimm24) = f_uimm24;
1551
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1552
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ld24", "f_r1 0x%x", 'x', f_r1, "uimm24 0x%x", 'x', f_uimm24, "dr 0x%x", 'x', f_r1, (char *) 0));
1553
 
1554
#if WITH_PROFILE_MODEL_P
1555
  /* Record the fields for profiling.  */
1556
  if (PROFILE_MODEL_P (current_cpu))
1557
    {
1558
      FLD (out_dr) = f_r1;
1559
    }
1560
#endif
1561
#undef FLD
1562
    return idesc;
1563
  }
1564
 
1565
 extract_sfmt_ldi8:
1566
  {
1567
    const IDESC *idesc = &m32r2f_insn_data[itype];
1568
    CGEN_INSN_INT insn = entire_insn;
1569
#define FLD(f) abuf->fields.sfmt_addi.f
1570
    UINT f_r1;
1571
    INT f_simm8;
1572
 
1573
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1574
    f_simm8 = EXTRACT_MSB0_INT (insn, 16, 8, 8);
1575
 
1576
  /* Record the fields for the semantic handler.  */
1577
  FLD (f_simm8) = f_simm8;
1578
  FLD (f_r1) = f_r1;
1579
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1580
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldi8", "f_simm8 0x%x", 'x', f_simm8, "f_r1 0x%x", 'x', f_r1, "dr 0x%x", 'x', f_r1, (char *) 0));
1581
 
1582
#if WITH_PROFILE_MODEL_P
1583
  /* Record the fields for profiling.  */
1584
  if (PROFILE_MODEL_P (current_cpu))
1585
    {
1586
      FLD (out_dr) = f_r1;
1587
    }
1588
#endif
1589
#undef FLD
1590
    return idesc;
1591
  }
1592
 
1593
 extract_sfmt_ldi16:
1594
  {
1595
    const IDESC *idesc = &m32r2f_insn_data[itype];
1596
    CGEN_INSN_INT insn = entire_insn;
1597
#define FLD(f) abuf->fields.sfmt_add3.f
1598
    UINT f_r1;
1599
    INT f_simm16;
1600
 
1601
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1602
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
1603
 
1604
  /* Record the fields for the semantic handler.  */
1605
  FLD (f_simm16) = f_simm16;
1606
  FLD (f_r1) = f_r1;
1607
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1608
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_ldi16", "f_simm16 0x%x", 'x', f_simm16, "f_r1 0x%x", 'x', f_r1, "dr 0x%x", 'x', f_r1, (char *) 0));
1609
 
1610
#if WITH_PROFILE_MODEL_P
1611
  /* Record the fields for profiling.  */
1612
  if (PROFILE_MODEL_P (current_cpu))
1613
    {
1614
      FLD (out_dr) = f_r1;
1615
    }
1616
#endif
1617
#undef FLD
1618
    return idesc;
1619
  }
1620
 
1621
 extract_sfmt_lock:
1622
  {
1623
    const IDESC *idesc = &m32r2f_insn_data[itype];
1624
    CGEN_INSN_INT insn = entire_insn;
1625
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1626
    UINT f_r1;
1627
    UINT f_r2;
1628
 
1629
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1630
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1631
 
1632
  /* Record the fields for the semantic handler.  */
1633
  FLD (f_r2) = f_r2;
1634
  FLD (f_r1) = f_r1;
1635
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1636
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1637
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_lock", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1638
 
1639
#if WITH_PROFILE_MODEL_P
1640
  /* Record the fields for profiling.  */
1641
  if (PROFILE_MODEL_P (current_cpu))
1642
    {
1643
      FLD (in_sr) = f_r2;
1644
      FLD (out_dr) = f_r1;
1645
    }
1646
#endif
1647
#undef FLD
1648
    return idesc;
1649
  }
1650
 
1651
 extract_sfmt_machi_a:
1652
  {
1653
    const IDESC *idesc = &m32r2f_insn_data[itype];
1654
    CGEN_INSN_INT insn = entire_insn;
1655
#define FLD(f) abuf->fields.sfmt_machi_a.f
1656
    UINT f_r1;
1657
    UINT f_acc;
1658
    UINT f_r2;
1659
 
1660
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1661
    f_acc = EXTRACT_MSB0_UINT (insn, 16, 8, 1);
1662
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1663
 
1664
  /* Record the fields for the semantic handler.  */
1665
  FLD (f_acc) = f_acc;
1666
  FLD (f_r1) = f_r1;
1667
  FLD (f_r2) = f_r2;
1668
  FLD (i_src1) = & CPU (h_gr)[f_r1];
1669
  FLD (i_src2) = & CPU (h_gr)[f_r2];
1670
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_machi_a", "f_acc 0x%x", 'x', f_acc, "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
1671
 
1672
#if WITH_PROFILE_MODEL_P
1673
  /* Record the fields for profiling.  */
1674
  if (PROFILE_MODEL_P (current_cpu))
1675
    {
1676
      FLD (in_src1) = f_r1;
1677
      FLD (in_src2) = f_r2;
1678
    }
1679
#endif
1680
#undef FLD
1681
    return idesc;
1682
  }
1683
 
1684
 extract_sfmt_mulhi_a:
1685
  {
1686
    const IDESC *idesc = &m32r2f_insn_data[itype];
1687
    CGEN_INSN_INT insn = entire_insn;
1688
#define FLD(f) abuf->fields.sfmt_machi_a.f
1689
    UINT f_r1;
1690
    UINT f_acc;
1691
    UINT f_r2;
1692
 
1693
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1694
    f_acc = EXTRACT_MSB0_UINT (insn, 16, 8, 1);
1695
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1696
 
1697
  /* Record the fields for the semantic handler.  */
1698
  FLD (f_r1) = f_r1;
1699
  FLD (f_r2) = f_r2;
1700
  FLD (f_acc) = f_acc;
1701
  FLD (i_src1) = & CPU (h_gr)[f_r1];
1702
  FLD (i_src2) = & CPU (h_gr)[f_r2];
1703
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mulhi_a", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "f_acc 0x%x", 'x', f_acc, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
1704
 
1705
#if WITH_PROFILE_MODEL_P
1706
  /* Record the fields for profiling.  */
1707
  if (PROFILE_MODEL_P (current_cpu))
1708
    {
1709
      FLD (in_src1) = f_r1;
1710
      FLD (in_src2) = f_r2;
1711
    }
1712
#endif
1713
#undef FLD
1714
    return idesc;
1715
  }
1716
 
1717
 extract_sfmt_mv:
1718
  {
1719
    const IDESC *idesc = &m32r2f_insn_data[itype];
1720
    CGEN_INSN_INT insn = entire_insn;
1721
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1722
    UINT f_r1;
1723
    UINT f_r2;
1724
 
1725
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1726
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1727
 
1728
  /* Record the fields for the semantic handler.  */
1729
  FLD (f_r2) = f_r2;
1730
  FLD (f_r1) = f_r1;
1731
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1732
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1733
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mv", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1734
 
1735
#if WITH_PROFILE_MODEL_P
1736
  /* Record the fields for profiling.  */
1737
  if (PROFILE_MODEL_P (current_cpu))
1738
    {
1739
      FLD (in_sr) = f_r2;
1740
      FLD (out_dr) = f_r1;
1741
    }
1742
#endif
1743
#undef FLD
1744
    return idesc;
1745
  }
1746
 
1747
 extract_sfmt_mvfachi_a:
1748
  {
1749
    const IDESC *idesc = &m32r2f_insn_data[itype];
1750
    CGEN_INSN_INT insn = entire_insn;
1751
#define FLD(f) abuf->fields.sfmt_mvfachi_a.f
1752
    UINT f_r1;
1753
    UINT f_accs;
1754
 
1755
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1756
    f_accs = EXTRACT_MSB0_UINT (insn, 16, 12, 2);
1757
 
1758
  /* Record the fields for the semantic handler.  */
1759
  FLD (f_accs) = f_accs;
1760
  FLD (f_r1) = f_r1;
1761
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1762
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mvfachi_a", "f_accs 0x%x", 'x', f_accs, "f_r1 0x%x", 'x', f_r1, "dr 0x%x", 'x', f_r1, (char *) 0));
1763
 
1764
#if WITH_PROFILE_MODEL_P
1765
  /* Record the fields for profiling.  */
1766
  if (PROFILE_MODEL_P (current_cpu))
1767
    {
1768
      FLD (out_dr) = f_r1;
1769
    }
1770
#endif
1771
#undef FLD
1772
    return idesc;
1773
  }
1774
 
1775
 extract_sfmt_mvfc:
1776
  {
1777
    const IDESC *idesc = &m32r2f_insn_data[itype];
1778
    CGEN_INSN_INT insn = entire_insn;
1779
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1780
    UINT f_r1;
1781
    UINT f_r2;
1782
 
1783
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1784
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1785
 
1786
  /* Record the fields for the semantic handler.  */
1787
  FLD (f_r2) = f_r2;
1788
  FLD (f_r1) = f_r1;
1789
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1790
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mvfc", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "dr 0x%x", 'x', f_r1, (char *) 0));
1791
 
1792
#if WITH_PROFILE_MODEL_P
1793
  /* Record the fields for profiling.  */
1794
  if (PROFILE_MODEL_P (current_cpu))
1795
    {
1796
      FLD (out_dr) = f_r1;
1797
    }
1798
#endif
1799
#undef FLD
1800
    return idesc;
1801
  }
1802
 
1803
 extract_sfmt_mvtachi_a:
1804
  {
1805
    const IDESC *idesc = &m32r2f_insn_data[itype];
1806
    CGEN_INSN_INT insn = entire_insn;
1807
#define FLD(f) abuf->fields.sfmt_mvtachi_a.f
1808
    UINT f_r1;
1809
    UINT f_accs;
1810
 
1811
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1812
    f_accs = EXTRACT_MSB0_UINT (insn, 16, 12, 2);
1813
 
1814
  /* Record the fields for the semantic handler.  */
1815
  FLD (f_accs) = f_accs;
1816
  FLD (f_r1) = f_r1;
1817
  FLD (i_src1) = & CPU (h_gr)[f_r1];
1818
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mvtachi_a", "f_accs 0x%x", 'x', f_accs, "f_r1 0x%x", 'x', f_r1, "src1 0x%x", 'x', f_r1, (char *) 0));
1819
 
1820
#if WITH_PROFILE_MODEL_P
1821
  /* Record the fields for profiling.  */
1822
  if (PROFILE_MODEL_P (current_cpu))
1823
    {
1824
      FLD (in_src1) = f_r1;
1825
    }
1826
#endif
1827
#undef FLD
1828
    return idesc;
1829
  }
1830
 
1831
 extract_sfmt_mvtc:
1832
  {
1833
    const IDESC *idesc = &m32r2f_insn_data[itype];
1834
    CGEN_INSN_INT insn = entire_insn;
1835
#define FLD(f) abuf->fields.sfmt_ld_plus.f
1836
    UINT f_r1;
1837
    UINT f_r2;
1838
 
1839
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1840
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
1841
 
1842
  /* Record the fields for the semantic handler.  */
1843
  FLD (f_r2) = f_r2;
1844
  FLD (f_r1) = f_r1;
1845
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1846
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mvtc", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, (char *) 0));
1847
 
1848
#if WITH_PROFILE_MODEL_P
1849
  /* Record the fields for profiling.  */
1850
  if (PROFILE_MODEL_P (current_cpu))
1851
    {
1852
      FLD (in_sr) = f_r2;
1853
    }
1854
#endif
1855
#undef FLD
1856
    return idesc;
1857
  }
1858
 
1859
 extract_sfmt_nop:
1860
  {
1861
    const IDESC *idesc = &m32r2f_insn_data[itype];
1862
#define FLD(f) abuf->fields.fmt_empty.f
1863
 
1864
 
1865
  /* Record the fields for the semantic handler.  */
1866
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_nop", (char *) 0));
1867
 
1868
#undef FLD
1869
    return idesc;
1870
  }
1871
 
1872
 extract_sfmt_rac_dsi:
1873
  {
1874
    const IDESC *idesc = &m32r2f_insn_data[itype];
1875
    CGEN_INSN_INT insn = entire_insn;
1876
#define FLD(f) abuf->fields.sfmt_rac_dsi.f
1877
    UINT f_accd;
1878
    UINT f_accs;
1879
    SI f_imm1;
1880
 
1881
    f_accd = EXTRACT_MSB0_UINT (insn, 16, 4, 2);
1882
    f_accs = EXTRACT_MSB0_UINT (insn, 16, 12, 2);
1883
    f_imm1 = ((EXTRACT_MSB0_UINT (insn, 16, 15, 1)) + (1));
1884
 
1885
  /* Record the fields for the semantic handler.  */
1886
  FLD (f_accs) = f_accs;
1887
  FLD (f_imm1) = f_imm1;
1888
  FLD (f_accd) = f_accd;
1889
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_rac_dsi", "f_accs 0x%x", 'x', f_accs, "f_imm1 0x%x", 'x', f_imm1, "f_accd 0x%x", 'x', f_accd, (char *) 0));
1890
 
1891
#undef FLD
1892
    return idesc;
1893
  }
1894
 
1895
 extract_sfmt_rte:
1896
  {
1897
    const IDESC *idesc = &m32r2f_insn_data[itype];
1898
#define FLD(f) abuf->fields.fmt_empty.f
1899
 
1900
 
1901
  /* Record the fields for the semantic handler.  */
1902
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_rte", (char *) 0));
1903
 
1904
#if WITH_PROFILE_MODEL_P
1905
  /* Record the fields for profiling.  */
1906
  if (PROFILE_MODEL_P (current_cpu))
1907
    {
1908
    }
1909
#endif
1910
#undef FLD
1911
    return idesc;
1912
  }
1913
 
1914
 extract_sfmt_seth:
1915
  {
1916
    const IDESC *idesc = &m32r2f_insn_data[itype];
1917
    CGEN_INSN_INT insn = entire_insn;
1918
#define FLD(f) abuf->fields.sfmt_seth.f
1919
    UINT f_r1;
1920
    UINT f_hi16;
1921
 
1922
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1923
    f_hi16 = EXTRACT_MSB0_UINT (insn, 32, 16, 16);
1924
 
1925
  /* Record the fields for the semantic handler.  */
1926
  FLD (f_hi16) = f_hi16;
1927
  FLD (f_r1) = f_r1;
1928
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1929
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_seth", "f_hi16 0x%x", 'x', f_hi16, "f_r1 0x%x", 'x', f_r1, "dr 0x%x", 'x', f_r1, (char *) 0));
1930
 
1931
#if WITH_PROFILE_MODEL_P
1932
  /* Record the fields for profiling.  */
1933
  if (PROFILE_MODEL_P (current_cpu))
1934
    {
1935
      FLD (out_dr) = f_r1;
1936
    }
1937
#endif
1938
#undef FLD
1939
    return idesc;
1940
  }
1941
 
1942
 extract_sfmt_sll3:
1943
  {
1944
    const IDESC *idesc = &m32r2f_insn_data[itype];
1945
    CGEN_INSN_INT insn = entire_insn;
1946
#define FLD(f) abuf->fields.sfmt_add3.f
1947
    UINT f_r1;
1948
    UINT f_r2;
1949
    INT f_simm16;
1950
 
1951
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
1952
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
1953
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
1954
 
1955
  /* Record the fields for the semantic handler.  */
1956
  FLD (f_simm16) = f_simm16;
1957
  FLD (f_r2) = f_r2;
1958
  FLD (f_r1) = f_r1;
1959
  FLD (i_sr) = & CPU (h_gr)[f_r2];
1960
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1961
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sll3", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
1962
 
1963
#if WITH_PROFILE_MODEL_P
1964
  /* Record the fields for profiling.  */
1965
  if (PROFILE_MODEL_P (current_cpu))
1966
    {
1967
      FLD (in_sr) = f_r2;
1968
      FLD (out_dr) = f_r1;
1969
    }
1970
#endif
1971
#undef FLD
1972
    return idesc;
1973
  }
1974
 
1975
 extract_sfmt_slli:
1976
  {
1977
    const IDESC *idesc = &m32r2f_insn_data[itype];
1978
    CGEN_INSN_INT insn = entire_insn;
1979
#define FLD(f) abuf->fields.sfmt_slli.f
1980
    UINT f_r1;
1981
    UINT f_uimm5;
1982
 
1983
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
1984
    f_uimm5 = EXTRACT_MSB0_UINT (insn, 16, 11, 5);
1985
 
1986
  /* Record the fields for the semantic handler.  */
1987
  FLD (f_r1) = f_r1;
1988
  FLD (f_uimm5) = f_uimm5;
1989
  FLD (i_dr) = & CPU (h_gr)[f_r1];
1990
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_slli", "f_r1 0x%x", 'x', f_r1, "f_uimm5 0x%x", 'x', f_uimm5, "dr 0x%x", 'x', f_r1, (char *) 0));
1991
 
1992
#if WITH_PROFILE_MODEL_P
1993
  /* Record the fields for profiling.  */
1994
  if (PROFILE_MODEL_P (current_cpu))
1995
    {
1996
      FLD (in_dr) = f_r1;
1997
      FLD (out_dr) = f_r1;
1998
    }
1999
#endif
2000
#undef FLD
2001
    return idesc;
2002
  }
2003
 
2004
 extract_sfmt_st:
2005
  {
2006
    const IDESC *idesc = &m32r2f_insn_data[itype];
2007
    CGEN_INSN_INT insn = entire_insn;
2008
#define FLD(f) abuf->fields.sfmt_st_plus.f
2009
    UINT f_r1;
2010
    UINT f_r2;
2011
 
2012
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2013
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2014
 
2015
  /* Record the fields for the semantic handler.  */
2016
  FLD (f_r1) = f_r1;
2017
  FLD (f_r2) = f_r2;
2018
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2019
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2020
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_st", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2021
 
2022
#if WITH_PROFILE_MODEL_P
2023
  /* Record the fields for profiling.  */
2024
  if (PROFILE_MODEL_P (current_cpu))
2025
    {
2026
      FLD (in_src1) = f_r1;
2027
      FLD (in_src2) = f_r2;
2028
    }
2029
#endif
2030
#undef FLD
2031
    return idesc;
2032
  }
2033
 
2034
 extract_sfmt_st_d:
2035
  {
2036
    const IDESC *idesc = &m32r2f_insn_data[itype];
2037
    CGEN_INSN_INT insn = entire_insn;
2038
#define FLD(f) abuf->fields.sfmt_st_d.f
2039
    UINT f_r1;
2040
    UINT f_r2;
2041
    INT f_simm16;
2042
 
2043
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
2044
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
2045
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
2046
 
2047
  /* Record the fields for the semantic handler.  */
2048
  FLD (f_simm16) = f_simm16;
2049
  FLD (f_r1) = f_r1;
2050
  FLD (f_r2) = f_r2;
2051
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2052
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2053
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_st_d", "f_simm16 0x%x", 'x', f_simm16, "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2054
 
2055
#if WITH_PROFILE_MODEL_P
2056
  /* Record the fields for profiling.  */
2057
  if (PROFILE_MODEL_P (current_cpu))
2058
    {
2059
      FLD (in_src1) = f_r1;
2060
      FLD (in_src2) = f_r2;
2061
    }
2062
#endif
2063
#undef FLD
2064
    return idesc;
2065
  }
2066
 
2067
 extract_sfmt_stb:
2068
  {
2069
    const IDESC *idesc = &m32r2f_insn_data[itype];
2070
    CGEN_INSN_INT insn = entire_insn;
2071
#define FLD(f) abuf->fields.sfmt_st_plus.f
2072
    UINT f_r1;
2073
    UINT f_r2;
2074
 
2075
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2076
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2077
 
2078
  /* Record the fields for the semantic handler.  */
2079
  FLD (f_r1) = f_r1;
2080
  FLD (f_r2) = f_r2;
2081
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2082
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2083
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_stb", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2084
 
2085
#if WITH_PROFILE_MODEL_P
2086
  /* Record the fields for profiling.  */
2087
  if (PROFILE_MODEL_P (current_cpu))
2088
    {
2089
      FLD (in_src1) = f_r1;
2090
      FLD (in_src2) = f_r2;
2091
    }
2092
#endif
2093
#undef FLD
2094
    return idesc;
2095
  }
2096
 
2097
 extract_sfmt_stb_d:
2098
  {
2099
    const IDESC *idesc = &m32r2f_insn_data[itype];
2100
    CGEN_INSN_INT insn = entire_insn;
2101
#define FLD(f) abuf->fields.sfmt_st_d.f
2102
    UINT f_r1;
2103
    UINT f_r2;
2104
    INT f_simm16;
2105
 
2106
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
2107
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
2108
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
2109
 
2110
  /* Record the fields for the semantic handler.  */
2111
  FLD (f_simm16) = f_simm16;
2112
  FLD (f_r1) = f_r1;
2113
  FLD (f_r2) = f_r2;
2114
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2115
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2116
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_stb_d", "f_simm16 0x%x", 'x', f_simm16, "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2117
 
2118
#if WITH_PROFILE_MODEL_P
2119
  /* Record the fields for profiling.  */
2120
  if (PROFILE_MODEL_P (current_cpu))
2121
    {
2122
      FLD (in_src1) = f_r1;
2123
      FLD (in_src2) = f_r2;
2124
    }
2125
#endif
2126
#undef FLD
2127
    return idesc;
2128
  }
2129
 
2130
 extract_sfmt_sth:
2131
  {
2132
    const IDESC *idesc = &m32r2f_insn_data[itype];
2133
    CGEN_INSN_INT insn = entire_insn;
2134
#define FLD(f) abuf->fields.sfmt_st_plus.f
2135
    UINT f_r1;
2136
    UINT f_r2;
2137
 
2138
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2139
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2140
 
2141
  /* Record the fields for the semantic handler.  */
2142
  FLD (f_r1) = f_r1;
2143
  FLD (f_r2) = f_r2;
2144
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2145
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2146
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sth", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2147
 
2148
#if WITH_PROFILE_MODEL_P
2149
  /* Record the fields for profiling.  */
2150
  if (PROFILE_MODEL_P (current_cpu))
2151
    {
2152
      FLD (in_src1) = f_r1;
2153
      FLD (in_src2) = f_r2;
2154
    }
2155
#endif
2156
#undef FLD
2157
    return idesc;
2158
  }
2159
 
2160
 extract_sfmt_sth_d:
2161
  {
2162
    const IDESC *idesc = &m32r2f_insn_data[itype];
2163
    CGEN_INSN_INT insn = entire_insn;
2164
#define FLD(f) abuf->fields.sfmt_st_d.f
2165
    UINT f_r1;
2166
    UINT f_r2;
2167
    INT f_simm16;
2168
 
2169
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
2170
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
2171
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
2172
 
2173
  /* Record the fields for the semantic handler.  */
2174
  FLD (f_simm16) = f_simm16;
2175
  FLD (f_r1) = f_r1;
2176
  FLD (f_r2) = f_r2;
2177
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2178
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2179
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sth_d", "f_simm16 0x%x", 'x', f_simm16, "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2180
 
2181
#if WITH_PROFILE_MODEL_P
2182
  /* Record the fields for profiling.  */
2183
  if (PROFILE_MODEL_P (current_cpu))
2184
    {
2185
      FLD (in_src1) = f_r1;
2186
      FLD (in_src2) = f_r2;
2187
    }
2188
#endif
2189
#undef FLD
2190
    return idesc;
2191
  }
2192
 
2193
 extract_sfmt_st_plus:
2194
  {
2195
    const IDESC *idesc = &m32r2f_insn_data[itype];
2196
    CGEN_INSN_INT insn = entire_insn;
2197
#define FLD(f) abuf->fields.sfmt_st_plus.f
2198
    UINT f_r1;
2199
    UINT f_r2;
2200
 
2201
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2202
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2203
 
2204
  /* Record the fields for the semantic handler.  */
2205
  FLD (f_r1) = f_r1;
2206
  FLD (f_r2) = f_r2;
2207
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2208
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2209
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_st_plus", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2210
 
2211
#if WITH_PROFILE_MODEL_P
2212
  /* Record the fields for profiling.  */
2213
  if (PROFILE_MODEL_P (current_cpu))
2214
    {
2215
      FLD (in_src1) = f_r1;
2216
      FLD (in_src2) = f_r2;
2217
      FLD (out_src2) = f_r2;
2218
    }
2219
#endif
2220
#undef FLD
2221
    return idesc;
2222
  }
2223
 
2224
 extract_sfmt_sth_plus:
2225
  {
2226
    const IDESC *idesc = &m32r2f_insn_data[itype];
2227
    CGEN_INSN_INT insn = entire_insn;
2228
#define FLD(f) abuf->fields.sfmt_st_plus.f
2229
    UINT f_r1;
2230
    UINT f_r2;
2231
 
2232
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2233
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2234
 
2235
  /* Record the fields for the semantic handler.  */
2236
  FLD (f_r1) = f_r1;
2237
  FLD (f_r2) = f_r2;
2238
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2239
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2240
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sth_plus", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2241
 
2242
#if WITH_PROFILE_MODEL_P
2243
  /* Record the fields for profiling.  */
2244
  if (PROFILE_MODEL_P (current_cpu))
2245
    {
2246
      FLD (in_src1) = f_r1;
2247
      FLD (in_src2) = f_r2;
2248
      FLD (out_src2) = f_r2;
2249
    }
2250
#endif
2251
#undef FLD
2252
    return idesc;
2253
  }
2254
 
2255
 extract_sfmt_stb_plus:
2256
  {
2257
    const IDESC *idesc = &m32r2f_insn_data[itype];
2258
    CGEN_INSN_INT insn = entire_insn;
2259
#define FLD(f) abuf->fields.sfmt_st_plus.f
2260
    UINT f_r1;
2261
    UINT f_r2;
2262
 
2263
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2264
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2265
 
2266
  /* Record the fields for the semantic handler.  */
2267
  FLD (f_r1) = f_r1;
2268
  FLD (f_r2) = f_r2;
2269
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2270
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2271
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_stb_plus", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2272
 
2273
#if WITH_PROFILE_MODEL_P
2274
  /* Record the fields for profiling.  */
2275
  if (PROFILE_MODEL_P (current_cpu))
2276
    {
2277
      FLD (in_src1) = f_r1;
2278
      FLD (in_src2) = f_r2;
2279
      FLD (out_src2) = f_r2;
2280
    }
2281
#endif
2282
#undef FLD
2283
    return idesc;
2284
  }
2285
 
2286
 extract_sfmt_trap:
2287
  {
2288
    const IDESC *idesc = &m32r2f_insn_data[itype];
2289
    CGEN_INSN_INT insn = entire_insn;
2290
#define FLD(f) abuf->fields.sfmt_trap.f
2291
    UINT f_uimm4;
2292
 
2293
    f_uimm4 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2294
 
2295
  /* Record the fields for the semantic handler.  */
2296
  FLD (f_uimm4) = f_uimm4;
2297
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_trap", "f_uimm4 0x%x", 'x', f_uimm4, (char *) 0));
2298
 
2299
#if WITH_PROFILE_MODEL_P
2300
  /* Record the fields for profiling.  */
2301
  if (PROFILE_MODEL_P (current_cpu))
2302
    {
2303
    }
2304
#endif
2305
#undef FLD
2306
    return idesc;
2307
  }
2308
 
2309
 extract_sfmt_unlock:
2310
  {
2311
    const IDESC *idesc = &m32r2f_insn_data[itype];
2312
    CGEN_INSN_INT insn = entire_insn;
2313
#define FLD(f) abuf->fields.sfmt_st_plus.f
2314
    UINT f_r1;
2315
    UINT f_r2;
2316
 
2317
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2318
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2319
 
2320
  /* Record the fields for the semantic handler.  */
2321
  FLD (f_r1) = f_r1;
2322
  FLD (f_r2) = f_r2;
2323
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2324
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2325
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_unlock", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2326
 
2327
#if WITH_PROFILE_MODEL_P
2328
  /* Record the fields for profiling.  */
2329
  if (PROFILE_MODEL_P (current_cpu))
2330
    {
2331
      FLD (in_src1) = f_r1;
2332
      FLD (in_src2) = f_r2;
2333
    }
2334
#endif
2335
#undef FLD
2336
    return idesc;
2337
  }
2338
 
2339
 extract_sfmt_satb:
2340
  {
2341
    const IDESC *idesc = &m32r2f_insn_data[itype];
2342
    CGEN_INSN_INT insn = entire_insn;
2343
#define FLD(f) abuf->fields.sfmt_ld_plus.f
2344
    UINT f_r1;
2345
    UINT f_r2;
2346
 
2347
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
2348
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
2349
 
2350
  /* Record the fields for the semantic handler.  */
2351
  FLD (f_r2) = f_r2;
2352
  FLD (f_r1) = f_r1;
2353
  FLD (i_sr) = & CPU (h_gr)[f_r2];
2354
  FLD (i_dr) = & CPU (h_gr)[f_r1];
2355
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_satb", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
2356
 
2357
#if WITH_PROFILE_MODEL_P
2358
  /* Record the fields for profiling.  */
2359
  if (PROFILE_MODEL_P (current_cpu))
2360
    {
2361
      FLD (in_sr) = f_r2;
2362
      FLD (out_dr) = f_r1;
2363
    }
2364
#endif
2365
#undef FLD
2366
    return idesc;
2367
  }
2368
 
2369
 extract_sfmt_sat:
2370
  {
2371
    const IDESC *idesc = &m32r2f_insn_data[itype];
2372
    CGEN_INSN_INT insn = entire_insn;
2373
#define FLD(f) abuf->fields.sfmt_ld_plus.f
2374
    UINT f_r1;
2375
    UINT f_r2;
2376
 
2377
    f_r1 = EXTRACT_MSB0_UINT (insn, 32, 4, 4);
2378
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
2379
 
2380
  /* Record the fields for the semantic handler.  */
2381
  FLD (f_r2) = f_r2;
2382
  FLD (f_r1) = f_r1;
2383
  FLD (i_sr) = & CPU (h_gr)[f_r2];
2384
  FLD (i_dr) = & CPU (h_gr)[f_r1];
2385
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sat", "f_r2 0x%x", 'x', f_r2, "f_r1 0x%x", 'x', f_r1, "sr 0x%x", 'x', f_r2, "dr 0x%x", 'x', f_r1, (char *) 0));
2386
 
2387
#if WITH_PROFILE_MODEL_P
2388
  /* Record the fields for profiling.  */
2389
  if (PROFILE_MODEL_P (current_cpu))
2390
    {
2391
      FLD (in_sr) = f_r2;
2392
      FLD (out_dr) = f_r1;
2393
    }
2394
#endif
2395
#undef FLD
2396
    return idesc;
2397
  }
2398
 
2399
 extract_sfmt_sadd:
2400
  {
2401
    const IDESC *idesc = &m32r2f_insn_data[itype];
2402
#define FLD(f) abuf->fields.fmt_empty.f
2403
 
2404
 
2405
  /* Record the fields for the semantic handler.  */
2406
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sadd", (char *) 0));
2407
 
2408
#undef FLD
2409
    return idesc;
2410
  }
2411
 
2412
 extract_sfmt_macwu1:
2413
  {
2414
    const IDESC *idesc = &m32r2f_insn_data[itype];
2415
    CGEN_INSN_INT insn = entire_insn;
2416
#define FLD(f) abuf->fields.sfmt_st_plus.f
2417
    UINT f_r1;
2418
    UINT f_r2;
2419
 
2420
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2421
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2422
 
2423
  /* Record the fields for the semantic handler.  */
2424
  FLD (f_r1) = f_r1;
2425
  FLD (f_r2) = f_r2;
2426
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2427
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2428
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_macwu1", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2429
 
2430
#if WITH_PROFILE_MODEL_P
2431
  /* Record the fields for profiling.  */
2432
  if (PROFILE_MODEL_P (current_cpu))
2433
    {
2434
      FLD (in_src1) = f_r1;
2435
      FLD (in_src2) = f_r2;
2436
    }
2437
#endif
2438
#undef FLD
2439
    return idesc;
2440
  }
2441
 
2442
 extract_sfmt_msblo:
2443
  {
2444
    const IDESC *idesc = &m32r2f_insn_data[itype];
2445
    CGEN_INSN_INT insn = entire_insn;
2446
#define FLD(f) abuf->fields.sfmt_st_plus.f
2447
    UINT f_r1;
2448
    UINT f_r2;
2449
 
2450
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2451
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2452
 
2453
  /* Record the fields for the semantic handler.  */
2454
  FLD (f_r1) = f_r1;
2455
  FLD (f_r2) = f_r2;
2456
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2457
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2458
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_msblo", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2459
 
2460
#if WITH_PROFILE_MODEL_P
2461
  /* Record the fields for profiling.  */
2462
  if (PROFILE_MODEL_P (current_cpu))
2463
    {
2464
      FLD (in_src1) = f_r1;
2465
      FLD (in_src2) = f_r2;
2466
    }
2467
#endif
2468
#undef FLD
2469
    return idesc;
2470
  }
2471
 
2472
 extract_sfmt_mulwu1:
2473
  {
2474
    const IDESC *idesc = &m32r2f_insn_data[itype];
2475
    CGEN_INSN_INT insn = entire_insn;
2476
#define FLD(f) abuf->fields.sfmt_st_plus.f
2477
    UINT f_r1;
2478
    UINT f_r2;
2479
 
2480
    f_r1 = EXTRACT_MSB0_UINT (insn, 16, 4, 4);
2481
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2482
 
2483
  /* Record the fields for the semantic handler.  */
2484
  FLD (f_r1) = f_r1;
2485
  FLD (f_r2) = f_r2;
2486
  FLD (i_src1) = & CPU (h_gr)[f_r1];
2487
  FLD (i_src2) = & CPU (h_gr)[f_r2];
2488
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_mulwu1", "f_r1 0x%x", 'x', f_r1, "f_r2 0x%x", 'x', f_r2, "src1 0x%x", 'x', f_r1, "src2 0x%x", 'x', f_r2, (char *) 0));
2489
 
2490
#if WITH_PROFILE_MODEL_P
2491
  /* Record the fields for profiling.  */
2492
  if (PROFILE_MODEL_P (current_cpu))
2493
    {
2494
      FLD (in_src1) = f_r1;
2495
      FLD (in_src2) = f_r2;
2496
    }
2497
#endif
2498
#undef FLD
2499
    return idesc;
2500
  }
2501
 
2502
 extract_sfmt_sc:
2503
  {
2504
    const IDESC *idesc = &m32r2f_insn_data[itype];
2505
#define FLD(f) abuf->fields.fmt_empty.f
2506
 
2507
 
2508
  /* Record the fields for the semantic handler.  */
2509
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_sc", (char *) 0));
2510
 
2511
#undef FLD
2512
    return idesc;
2513
  }
2514
 
2515
 extract_sfmt_clrpsw:
2516
  {
2517
    const IDESC *idesc = &m32r2f_insn_data[itype];
2518
    CGEN_INSN_INT insn = entire_insn;
2519
#define FLD(f) abuf->fields.sfmt_clrpsw.f
2520
    UINT f_uimm8;
2521
 
2522
    f_uimm8 = EXTRACT_MSB0_UINT (insn, 16, 8, 8);
2523
 
2524
  /* Record the fields for the semantic handler.  */
2525
  FLD (f_uimm8) = f_uimm8;
2526
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_clrpsw", "f_uimm8 0x%x", 'x', f_uimm8, (char *) 0));
2527
 
2528
#undef FLD
2529
    return idesc;
2530
  }
2531
 
2532
 extract_sfmt_setpsw:
2533
  {
2534
    const IDESC *idesc = &m32r2f_insn_data[itype];
2535
    CGEN_INSN_INT insn = entire_insn;
2536
#define FLD(f) abuf->fields.sfmt_clrpsw.f
2537
    UINT f_uimm8;
2538
 
2539
    f_uimm8 = EXTRACT_MSB0_UINT (insn, 16, 8, 8);
2540
 
2541
  /* Record the fields for the semantic handler.  */
2542
  FLD (f_uimm8) = f_uimm8;
2543
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_setpsw", "f_uimm8 0x%x", 'x', f_uimm8, (char *) 0));
2544
 
2545
#undef FLD
2546
    return idesc;
2547
  }
2548
 
2549
 extract_sfmt_bset:
2550
  {
2551
    const IDESC *idesc = &m32r2f_insn_data[itype];
2552
    CGEN_INSN_INT insn = entire_insn;
2553
#define FLD(f) abuf->fields.sfmt_bset.f
2554
    UINT f_uimm3;
2555
    UINT f_r2;
2556
    INT f_simm16;
2557
 
2558
    f_uimm3 = EXTRACT_MSB0_UINT (insn, 32, 5, 3);
2559
    f_r2 = EXTRACT_MSB0_UINT (insn, 32, 12, 4);
2560
    f_simm16 = EXTRACT_MSB0_INT (insn, 32, 16, 16);
2561
 
2562
  /* Record the fields for the semantic handler.  */
2563
  FLD (f_simm16) = f_simm16;
2564
  FLD (f_r2) = f_r2;
2565
  FLD (f_uimm3) = f_uimm3;
2566
  FLD (i_sr) = & CPU (h_gr)[f_r2];
2567
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_bset", "f_simm16 0x%x", 'x', f_simm16, "f_r2 0x%x", 'x', f_r2, "f_uimm3 0x%x", 'x', f_uimm3, "sr 0x%x", 'x', f_r2, (char *) 0));
2568
 
2569
#if WITH_PROFILE_MODEL_P
2570
  /* Record the fields for profiling.  */
2571
  if (PROFILE_MODEL_P (current_cpu))
2572
    {
2573
      FLD (in_sr) = f_r2;
2574
    }
2575
#endif
2576
#undef FLD
2577
    return idesc;
2578
  }
2579
 
2580
 extract_sfmt_btst:
2581
  {
2582
    const IDESC *idesc = &m32r2f_insn_data[itype];
2583
    CGEN_INSN_INT insn = entire_insn;
2584
#define FLD(f) abuf->fields.sfmt_bset.f
2585
    UINT f_uimm3;
2586
    UINT f_r2;
2587
 
2588
    f_uimm3 = EXTRACT_MSB0_UINT (insn, 16, 5, 3);
2589
    f_r2 = EXTRACT_MSB0_UINT (insn, 16, 12, 4);
2590
 
2591
  /* Record the fields for the semantic handler.  */
2592
  FLD (f_r2) = f_r2;
2593
  FLD (f_uimm3) = f_uimm3;
2594
  FLD (i_sr) = & CPU (h_gr)[f_r2];
2595
  TRACE_EXTRACT (current_cpu, abuf, (current_cpu, pc, "sfmt_btst", "f_r2 0x%x", 'x', f_r2, "f_uimm3 0x%x", 'x', f_uimm3, "sr 0x%x", 'x', f_r2, (char *) 0));
2596
 
2597
#if WITH_PROFILE_MODEL_P
2598
  /* Record the fields for profiling.  */
2599
  if (PROFILE_MODEL_P (current_cpu))
2600
    {
2601
      FLD (in_sr) = f_r2;
2602
    }
2603
#endif
2604
#undef FLD
2605
    return idesc;
2606
  }
2607
 
2608
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.