1 /* Simulator instruction decoder for m32rxf.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright 1996-2019 Free Software Foundation, Inc.
7 This file is part of the GNU simulators.
9 This file 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, or (at your option)
14 It is distributed in the hope that it will be useful, but WITHOUT
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
16 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
17 License for more details.
19 You should have received a copy of the GNU General Public License along
20 with this program; if not, see <http://www.gnu.org/licenses/>.
24 #define WANT_CPU m32rxf
25 #define WANT_CPU_M32RXF
28 #include "sim-assert.h"
30 /* Insn can't be executed in parallel.
31 Or is that "do NOt Pass to Air defense Radar"? :-) */
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 m32rxf_insn_data
[M32RXF_INSN__MAX
];
41 /* Commas between elements are contained in the macros.
42 Some of these are conditionally compiled out. */
44 static const struct insn_sem m32rxf_insn_sem
[] =
46 { VIRTUAL_INSN_X_INVALID
, M32RXF_INSN_X_INVALID
, M32RXF_SFMT_EMPTY
, NOPAR
, NOPAR
},
47 { VIRTUAL_INSN_X_AFTER
, M32RXF_INSN_X_AFTER
, M32RXF_SFMT_EMPTY
, NOPAR
, NOPAR
},
48 { VIRTUAL_INSN_X_BEFORE
, M32RXF_INSN_X_BEFORE
, M32RXF_SFMT_EMPTY
, NOPAR
, NOPAR
},
49 { VIRTUAL_INSN_X_CTI_CHAIN
, M32RXF_INSN_X_CTI_CHAIN
, M32RXF_SFMT_EMPTY
, NOPAR
, NOPAR
},
50 { VIRTUAL_INSN_X_CHAIN
, M32RXF_INSN_X_CHAIN
, M32RXF_SFMT_EMPTY
, NOPAR
, NOPAR
},
51 { VIRTUAL_INSN_X_BEGIN
, M32RXF_INSN_X_BEGIN
, M32RXF_SFMT_EMPTY
, NOPAR
, NOPAR
},
52 { M32R_INSN_ADD
, M32RXF_INSN_ADD
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_ADD
, M32RXF_INSN_WRITE_ADD
},
53 { M32R_INSN_ADD3
, M32RXF_INSN_ADD3
, M32RXF_SFMT_ADD3
, NOPAR
, NOPAR
},
54 { M32R_INSN_AND
, M32RXF_INSN_AND
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_AND
, M32RXF_INSN_WRITE_AND
},
55 { M32R_INSN_AND3
, M32RXF_INSN_AND3
, M32RXF_SFMT_AND3
, NOPAR
, NOPAR
},
56 { M32R_INSN_OR
, M32RXF_INSN_OR
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_OR
, M32RXF_INSN_WRITE_OR
},
57 { M32R_INSN_OR3
, M32RXF_INSN_OR3
, M32RXF_SFMT_OR3
, NOPAR
, NOPAR
},
58 { M32R_INSN_XOR
, M32RXF_INSN_XOR
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_XOR
, M32RXF_INSN_WRITE_XOR
},
59 { M32R_INSN_XOR3
, M32RXF_INSN_XOR3
, M32RXF_SFMT_AND3
, NOPAR
, NOPAR
},
60 { M32R_INSN_ADDI
, M32RXF_INSN_ADDI
, M32RXF_SFMT_ADDI
, M32RXF_INSN_PAR_ADDI
, M32RXF_INSN_WRITE_ADDI
},
61 { M32R_INSN_ADDV
, M32RXF_INSN_ADDV
, M32RXF_SFMT_ADDV
, M32RXF_INSN_PAR_ADDV
, M32RXF_INSN_WRITE_ADDV
},
62 { M32R_INSN_ADDV3
, M32RXF_INSN_ADDV3
, M32RXF_SFMT_ADDV3
, NOPAR
, NOPAR
},
63 { M32R_INSN_ADDX
, M32RXF_INSN_ADDX
, M32RXF_SFMT_ADDX
, M32RXF_INSN_PAR_ADDX
, M32RXF_INSN_WRITE_ADDX
},
64 { M32R_INSN_BC8
, M32RXF_INSN_BC8
, M32RXF_SFMT_BC8
, M32RXF_INSN_PAR_BC8
, M32RXF_INSN_WRITE_BC8
},
65 { M32R_INSN_BC24
, M32RXF_INSN_BC24
, M32RXF_SFMT_BC24
, NOPAR
, NOPAR
},
66 { M32R_INSN_BEQ
, M32RXF_INSN_BEQ
, M32RXF_SFMT_BEQ
, NOPAR
, NOPAR
},
67 { M32R_INSN_BEQZ
, M32RXF_INSN_BEQZ
, M32RXF_SFMT_BEQZ
, NOPAR
, NOPAR
},
68 { M32R_INSN_BGEZ
, M32RXF_INSN_BGEZ
, M32RXF_SFMT_BEQZ
, NOPAR
, NOPAR
},
69 { M32R_INSN_BGTZ
, M32RXF_INSN_BGTZ
, M32RXF_SFMT_BEQZ
, NOPAR
, NOPAR
},
70 { M32R_INSN_BLEZ
, M32RXF_INSN_BLEZ
, M32RXF_SFMT_BEQZ
, NOPAR
, NOPAR
},
71 { M32R_INSN_BLTZ
, M32RXF_INSN_BLTZ
, M32RXF_SFMT_BEQZ
, NOPAR
, NOPAR
},
72 { M32R_INSN_BNEZ
, M32RXF_INSN_BNEZ
, M32RXF_SFMT_BEQZ
, NOPAR
, NOPAR
},
73 { M32R_INSN_BL8
, M32RXF_INSN_BL8
, M32RXF_SFMT_BL8
, M32RXF_INSN_PAR_BL8
, M32RXF_INSN_WRITE_BL8
},
74 { M32R_INSN_BL24
, M32RXF_INSN_BL24
, M32RXF_SFMT_BL24
, NOPAR
, NOPAR
},
75 { M32R_INSN_BCL8
, M32RXF_INSN_BCL8
, M32RXF_SFMT_BCL8
, M32RXF_INSN_PAR_BCL8
, M32RXF_INSN_WRITE_BCL8
},
76 { M32R_INSN_BCL24
, M32RXF_INSN_BCL24
, M32RXF_SFMT_BCL24
, NOPAR
, NOPAR
},
77 { M32R_INSN_BNC8
, M32RXF_INSN_BNC8
, M32RXF_SFMT_BC8
, M32RXF_INSN_PAR_BNC8
, M32RXF_INSN_WRITE_BNC8
},
78 { M32R_INSN_BNC24
, M32RXF_INSN_BNC24
, M32RXF_SFMT_BC24
, NOPAR
, NOPAR
},
79 { M32R_INSN_BNE
, M32RXF_INSN_BNE
, M32RXF_SFMT_BEQ
, NOPAR
, NOPAR
},
80 { M32R_INSN_BRA8
, M32RXF_INSN_BRA8
, M32RXF_SFMT_BRA8
, M32RXF_INSN_PAR_BRA8
, M32RXF_INSN_WRITE_BRA8
},
81 { M32R_INSN_BRA24
, M32RXF_INSN_BRA24
, M32RXF_SFMT_BRA24
, NOPAR
, NOPAR
},
82 { M32R_INSN_BNCL8
, M32RXF_INSN_BNCL8
, M32RXF_SFMT_BCL8
, M32RXF_INSN_PAR_BNCL8
, M32RXF_INSN_WRITE_BNCL8
},
83 { M32R_INSN_BNCL24
, M32RXF_INSN_BNCL24
, M32RXF_SFMT_BCL24
, NOPAR
, NOPAR
},
84 { M32R_INSN_CMP
, M32RXF_INSN_CMP
, M32RXF_SFMT_CMP
, M32RXF_INSN_PAR_CMP
, M32RXF_INSN_WRITE_CMP
},
85 { M32R_INSN_CMPI
, M32RXF_INSN_CMPI
, M32RXF_SFMT_CMPI
, NOPAR
, NOPAR
},
86 { M32R_INSN_CMPU
, M32RXF_INSN_CMPU
, M32RXF_SFMT_CMP
, M32RXF_INSN_PAR_CMPU
, M32RXF_INSN_WRITE_CMPU
},
87 { M32R_INSN_CMPUI
, M32RXF_INSN_CMPUI
, M32RXF_SFMT_CMPI
, NOPAR
, NOPAR
},
88 { M32R_INSN_CMPEQ
, M32RXF_INSN_CMPEQ
, M32RXF_SFMT_CMP
, M32RXF_INSN_PAR_CMPEQ
, M32RXF_INSN_WRITE_CMPEQ
},
89 { M32R_INSN_CMPZ
, M32RXF_INSN_CMPZ
, M32RXF_SFMT_CMPZ
, M32RXF_INSN_PAR_CMPZ
, M32RXF_INSN_WRITE_CMPZ
},
90 { M32R_INSN_DIV
, M32RXF_INSN_DIV
, M32RXF_SFMT_DIV
, NOPAR
, NOPAR
},
91 { M32R_INSN_DIVU
, M32RXF_INSN_DIVU
, M32RXF_SFMT_DIV
, NOPAR
, NOPAR
},
92 { M32R_INSN_REM
, M32RXF_INSN_REM
, M32RXF_SFMT_DIV
, NOPAR
, NOPAR
},
93 { M32R_INSN_REMU
, M32RXF_INSN_REMU
, M32RXF_SFMT_DIV
, NOPAR
, NOPAR
},
94 { M32R_INSN_DIVH
, M32RXF_INSN_DIVH
, M32RXF_SFMT_DIV
, NOPAR
, NOPAR
},
95 { M32R_INSN_JC
, M32RXF_INSN_JC
, M32RXF_SFMT_JC
, M32RXF_INSN_PAR_JC
, M32RXF_INSN_WRITE_JC
},
96 { M32R_INSN_JNC
, M32RXF_INSN_JNC
, M32RXF_SFMT_JC
, M32RXF_INSN_PAR_JNC
, M32RXF_INSN_WRITE_JNC
},
97 { M32R_INSN_JL
, M32RXF_INSN_JL
, M32RXF_SFMT_JL
, M32RXF_INSN_PAR_JL
, M32RXF_INSN_WRITE_JL
},
98 { M32R_INSN_JMP
, M32RXF_INSN_JMP
, M32RXF_SFMT_JMP
, M32RXF_INSN_PAR_JMP
, M32RXF_INSN_WRITE_JMP
},
99 { M32R_INSN_LD
, M32RXF_INSN_LD
, M32RXF_SFMT_LD
, M32RXF_INSN_PAR_LD
, M32RXF_INSN_WRITE_LD
},
100 { M32R_INSN_LD_D
, M32RXF_INSN_LD_D
, M32RXF_SFMT_LD_D
, NOPAR
, NOPAR
},
101 { M32R_INSN_LDB
, M32RXF_INSN_LDB
, M32RXF_SFMT_LDB
, M32RXF_INSN_PAR_LDB
, M32RXF_INSN_WRITE_LDB
},
102 { M32R_INSN_LDB_D
, M32RXF_INSN_LDB_D
, M32RXF_SFMT_LDB_D
, NOPAR
, NOPAR
},
103 { M32R_INSN_LDH
, M32RXF_INSN_LDH
, M32RXF_SFMT_LDH
, M32RXF_INSN_PAR_LDH
, M32RXF_INSN_WRITE_LDH
},
104 { M32R_INSN_LDH_D
, M32RXF_INSN_LDH_D
, M32RXF_SFMT_LDH_D
, NOPAR
, NOPAR
},
105 { M32R_INSN_LDUB
, M32RXF_INSN_LDUB
, M32RXF_SFMT_LDB
, M32RXF_INSN_PAR_LDUB
, M32RXF_INSN_WRITE_LDUB
},
106 { M32R_INSN_LDUB_D
, M32RXF_INSN_LDUB_D
, M32RXF_SFMT_LDB_D
, NOPAR
, NOPAR
},
107 { M32R_INSN_LDUH
, M32RXF_INSN_LDUH
, M32RXF_SFMT_LDH
, M32RXF_INSN_PAR_LDUH
, M32RXF_INSN_WRITE_LDUH
},
108 { M32R_INSN_LDUH_D
, M32RXF_INSN_LDUH_D
, M32RXF_SFMT_LDH_D
, NOPAR
, NOPAR
},
109 { M32R_INSN_LD_PLUS
, M32RXF_INSN_LD_PLUS
, M32RXF_SFMT_LD_PLUS
, M32RXF_INSN_PAR_LD_PLUS
, M32RXF_INSN_WRITE_LD_PLUS
},
110 { M32R_INSN_LD24
, M32RXF_INSN_LD24
, M32RXF_SFMT_LD24
, NOPAR
, NOPAR
},
111 { M32R_INSN_LDI8
, M32RXF_INSN_LDI8
, M32RXF_SFMT_LDI8
, M32RXF_INSN_PAR_LDI8
, M32RXF_INSN_WRITE_LDI8
},
112 { M32R_INSN_LDI16
, M32RXF_INSN_LDI16
, M32RXF_SFMT_LDI16
, NOPAR
, NOPAR
},
113 { M32R_INSN_LOCK
, M32RXF_INSN_LOCK
, M32RXF_SFMT_LOCK
, M32RXF_INSN_PAR_LOCK
, M32RXF_INSN_WRITE_LOCK
},
114 { M32R_INSN_MACHI_A
, M32RXF_INSN_MACHI_A
, M32RXF_SFMT_MACHI_A
, M32RXF_INSN_PAR_MACHI_A
, M32RXF_INSN_WRITE_MACHI_A
},
115 { M32R_INSN_MACLO_A
, M32RXF_INSN_MACLO_A
, M32RXF_SFMT_MACHI_A
, M32RXF_INSN_PAR_MACLO_A
, M32RXF_INSN_WRITE_MACLO_A
},
116 { M32R_INSN_MACWHI_A
, M32RXF_INSN_MACWHI_A
, M32RXF_SFMT_MACHI_A
, M32RXF_INSN_PAR_MACWHI_A
, M32RXF_INSN_WRITE_MACWHI_A
},
117 { M32R_INSN_MACWLO_A
, M32RXF_INSN_MACWLO_A
, M32RXF_SFMT_MACHI_A
, M32RXF_INSN_PAR_MACWLO_A
, M32RXF_INSN_WRITE_MACWLO_A
},
118 { M32R_INSN_MUL
, M32RXF_INSN_MUL
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_MUL
, M32RXF_INSN_WRITE_MUL
},
119 { M32R_INSN_MULHI_A
, M32RXF_INSN_MULHI_A
, M32RXF_SFMT_MULHI_A
, M32RXF_INSN_PAR_MULHI_A
, M32RXF_INSN_WRITE_MULHI_A
},
120 { M32R_INSN_MULLO_A
, M32RXF_INSN_MULLO_A
, M32RXF_SFMT_MULHI_A
, M32RXF_INSN_PAR_MULLO_A
, M32RXF_INSN_WRITE_MULLO_A
},
121 { M32R_INSN_MULWHI_A
, M32RXF_INSN_MULWHI_A
, M32RXF_SFMT_MULHI_A
, M32RXF_INSN_PAR_MULWHI_A
, M32RXF_INSN_WRITE_MULWHI_A
},
122 { M32R_INSN_MULWLO_A
, M32RXF_INSN_MULWLO_A
, M32RXF_SFMT_MULHI_A
, M32RXF_INSN_PAR_MULWLO_A
, M32RXF_INSN_WRITE_MULWLO_A
},
123 { M32R_INSN_MV
, M32RXF_INSN_MV
, M32RXF_SFMT_MV
, M32RXF_INSN_PAR_MV
, M32RXF_INSN_WRITE_MV
},
124 { M32R_INSN_MVFACHI_A
, M32RXF_INSN_MVFACHI_A
, M32RXF_SFMT_MVFACHI_A
, M32RXF_INSN_PAR_MVFACHI_A
, M32RXF_INSN_WRITE_MVFACHI_A
},
125 { M32R_INSN_MVFACLO_A
, M32RXF_INSN_MVFACLO_A
, M32RXF_SFMT_MVFACHI_A
, M32RXF_INSN_PAR_MVFACLO_A
, M32RXF_INSN_WRITE_MVFACLO_A
},
126 { M32R_INSN_MVFACMI_A
, M32RXF_INSN_MVFACMI_A
, M32RXF_SFMT_MVFACHI_A
, M32RXF_INSN_PAR_MVFACMI_A
, M32RXF_INSN_WRITE_MVFACMI_A
},
127 { M32R_INSN_MVFC
, M32RXF_INSN_MVFC
, M32RXF_SFMT_MVFC
, M32RXF_INSN_PAR_MVFC
, M32RXF_INSN_WRITE_MVFC
},
128 { M32R_INSN_MVTACHI_A
, M32RXF_INSN_MVTACHI_A
, M32RXF_SFMT_MVTACHI_A
, M32RXF_INSN_PAR_MVTACHI_A
, M32RXF_INSN_WRITE_MVTACHI_A
},
129 { M32R_INSN_MVTACLO_A
, M32RXF_INSN_MVTACLO_A
, M32RXF_SFMT_MVTACHI_A
, M32RXF_INSN_PAR_MVTACLO_A
, M32RXF_INSN_WRITE_MVTACLO_A
},
130 { M32R_INSN_MVTC
, M32RXF_INSN_MVTC
, M32RXF_SFMT_MVTC
, M32RXF_INSN_PAR_MVTC
, M32RXF_INSN_WRITE_MVTC
},
131 { M32R_INSN_NEG
, M32RXF_INSN_NEG
, M32RXF_SFMT_MV
, M32RXF_INSN_PAR_NEG
, M32RXF_INSN_WRITE_NEG
},
132 { M32R_INSN_NOP
, M32RXF_INSN_NOP
, M32RXF_SFMT_NOP
, M32RXF_INSN_PAR_NOP
, M32RXF_INSN_WRITE_NOP
},
133 { M32R_INSN_NOT
, M32RXF_INSN_NOT
, M32RXF_SFMT_MV
, M32RXF_INSN_PAR_NOT
, M32RXF_INSN_WRITE_NOT
},
134 { M32R_INSN_RAC_DSI
, M32RXF_INSN_RAC_DSI
, M32RXF_SFMT_RAC_DSI
, M32RXF_INSN_PAR_RAC_DSI
, M32RXF_INSN_WRITE_RAC_DSI
},
135 { M32R_INSN_RACH_DSI
, M32RXF_INSN_RACH_DSI
, M32RXF_SFMT_RAC_DSI
, M32RXF_INSN_PAR_RACH_DSI
, M32RXF_INSN_WRITE_RACH_DSI
},
136 { M32R_INSN_RTE
, M32RXF_INSN_RTE
, M32RXF_SFMT_RTE
, M32RXF_INSN_PAR_RTE
, M32RXF_INSN_WRITE_RTE
},
137 { M32R_INSN_SETH
, M32RXF_INSN_SETH
, M32RXF_SFMT_SETH
, NOPAR
, NOPAR
},
138 { M32R_INSN_SLL
, M32RXF_INSN_SLL
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_SLL
, M32RXF_INSN_WRITE_SLL
},
139 { M32R_INSN_SLL3
, M32RXF_INSN_SLL3
, M32RXF_SFMT_SLL3
, NOPAR
, NOPAR
},
140 { M32R_INSN_SLLI
, M32RXF_INSN_SLLI
, M32RXF_SFMT_SLLI
, M32RXF_INSN_PAR_SLLI
, M32RXF_INSN_WRITE_SLLI
},
141 { M32R_INSN_SRA
, M32RXF_INSN_SRA
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_SRA
, M32RXF_INSN_WRITE_SRA
},
142 { M32R_INSN_SRA3
, M32RXF_INSN_SRA3
, M32RXF_SFMT_SLL3
, NOPAR
, NOPAR
},
143 { M32R_INSN_SRAI
, M32RXF_INSN_SRAI
, M32RXF_SFMT_SLLI
, M32RXF_INSN_PAR_SRAI
, M32RXF_INSN_WRITE_SRAI
},
144 { M32R_INSN_SRL
, M32RXF_INSN_SRL
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_SRL
, M32RXF_INSN_WRITE_SRL
},
145 { M32R_INSN_SRL3
, M32RXF_INSN_SRL3
, M32RXF_SFMT_SLL3
, NOPAR
, NOPAR
},
146 { M32R_INSN_SRLI
, M32RXF_INSN_SRLI
, M32RXF_SFMT_SLLI
, M32RXF_INSN_PAR_SRLI
, M32RXF_INSN_WRITE_SRLI
},
147 { M32R_INSN_ST
, M32RXF_INSN_ST
, M32RXF_SFMT_ST
, M32RXF_INSN_PAR_ST
, M32RXF_INSN_WRITE_ST
},
148 { M32R_INSN_ST_D
, M32RXF_INSN_ST_D
, M32RXF_SFMT_ST_D
, NOPAR
, NOPAR
},
149 { M32R_INSN_STB
, M32RXF_INSN_STB
, M32RXF_SFMT_STB
, M32RXF_INSN_PAR_STB
, M32RXF_INSN_WRITE_STB
},
150 { M32R_INSN_STB_D
, M32RXF_INSN_STB_D
, M32RXF_SFMT_STB_D
, NOPAR
, NOPAR
},
151 { M32R_INSN_STH
, M32RXF_INSN_STH
, M32RXF_SFMT_STH
, M32RXF_INSN_PAR_STH
, M32RXF_INSN_WRITE_STH
},
152 { M32R_INSN_STH_D
, M32RXF_INSN_STH_D
, M32RXF_SFMT_STH_D
, NOPAR
, NOPAR
},
153 { M32R_INSN_ST_PLUS
, M32RXF_INSN_ST_PLUS
, M32RXF_SFMT_ST_PLUS
, M32RXF_INSN_PAR_ST_PLUS
, M32RXF_INSN_WRITE_ST_PLUS
},
154 { M32R_INSN_STH_PLUS
, M32RXF_INSN_STH_PLUS
, M32RXF_SFMT_STH_PLUS
, M32RXF_INSN_PAR_STH_PLUS
, M32RXF_INSN_WRITE_STH_PLUS
},
155 { M32R_INSN_STB_PLUS
, M32RXF_INSN_STB_PLUS
, M32RXF_SFMT_STB_PLUS
, M32RXF_INSN_PAR_STB_PLUS
, M32RXF_INSN_WRITE_STB_PLUS
},
156 { M32R_INSN_ST_MINUS
, M32RXF_INSN_ST_MINUS
, M32RXF_SFMT_ST_PLUS
, M32RXF_INSN_PAR_ST_MINUS
, M32RXF_INSN_WRITE_ST_MINUS
},
157 { M32R_INSN_SUB
, M32RXF_INSN_SUB
, M32RXF_SFMT_ADD
, M32RXF_INSN_PAR_SUB
, M32RXF_INSN_WRITE_SUB
},
158 { M32R_INSN_SUBV
, M32RXF_INSN_SUBV
, M32RXF_SFMT_ADDV
, M32RXF_INSN_PAR_SUBV
, M32RXF_INSN_WRITE_SUBV
},
159 { M32R_INSN_SUBX
, M32RXF_INSN_SUBX
, M32RXF_SFMT_ADDX
, M32RXF_INSN_PAR_SUBX
, M32RXF_INSN_WRITE_SUBX
},
160 { M32R_INSN_TRAP
, M32RXF_INSN_TRAP
, M32RXF_SFMT_TRAP
, M32RXF_INSN_PAR_TRAP
, M32RXF_INSN_WRITE_TRAP
},
161 { M32R_INSN_UNLOCK
, M32RXF_INSN_UNLOCK
, M32RXF_SFMT_UNLOCK
, M32RXF_INSN_PAR_UNLOCK
, M32RXF_INSN_WRITE_UNLOCK
},
162 { M32R_INSN_SATB
, M32RXF_INSN_SATB
, M32RXF_SFMT_SATB
, NOPAR
, NOPAR
},
163 { M32R_INSN_SATH
, M32RXF_INSN_SATH
, M32RXF_SFMT_SATB
, NOPAR
, NOPAR
},
164 { M32R_INSN_SAT
, M32RXF_INSN_SAT
, M32RXF_SFMT_SAT
, NOPAR
, NOPAR
},
165 { M32R_INSN_PCMPBZ
, M32RXF_INSN_PCMPBZ
, M32RXF_SFMT_CMPZ
, M32RXF_INSN_PAR_PCMPBZ
, M32RXF_INSN_WRITE_PCMPBZ
},
166 { M32R_INSN_SADD
, M32RXF_INSN_SADD
, M32RXF_SFMT_SADD
, M32RXF_INSN_PAR_SADD
, M32RXF_INSN_WRITE_SADD
},
167 { M32R_INSN_MACWU1
, M32RXF_INSN_MACWU1
, M32RXF_SFMT_MACWU1
, M32RXF_INSN_PAR_MACWU1
, M32RXF_INSN_WRITE_MACWU1
},
168 { M32R_INSN_MSBLO
, M32RXF_INSN_MSBLO
, M32RXF_SFMT_MSBLO
, M32RXF_INSN_PAR_MSBLO
, M32RXF_INSN_WRITE_MSBLO
},
169 { M32R_INSN_MULWU1
, M32RXF_INSN_MULWU1
, M32RXF_SFMT_MULWU1
, M32RXF_INSN_PAR_MULWU1
, M32RXF_INSN_WRITE_MULWU1
},
170 { M32R_INSN_MACLH1
, M32RXF_INSN_MACLH1
, M32RXF_SFMT_MACWU1
, M32RXF_INSN_PAR_MACLH1
, M32RXF_INSN_WRITE_MACLH1
},
171 { M32R_INSN_SC
, M32RXF_INSN_SC
, M32RXF_SFMT_SC
, M32RXF_INSN_PAR_SC
, M32RXF_INSN_WRITE_SC
},
172 { M32R_INSN_SNC
, M32RXF_INSN_SNC
, M32RXF_SFMT_SC
, M32RXF_INSN_PAR_SNC
, M32RXF_INSN_WRITE_SNC
},
173 { M32R_INSN_CLRPSW
, M32RXF_INSN_CLRPSW
, M32RXF_SFMT_CLRPSW
, M32RXF_INSN_PAR_CLRPSW
, M32RXF_INSN_WRITE_CLRPSW
},
174 { M32R_INSN_SETPSW
, M32RXF_INSN_SETPSW
, M32RXF_SFMT_SETPSW
, M32RXF_INSN_PAR_SETPSW
, M32RXF_INSN_WRITE_SETPSW
},
175 { M32R_INSN_BSET
, M32RXF_INSN_BSET
, M32RXF_SFMT_BSET
, NOPAR
, NOPAR
},
176 { M32R_INSN_BCLR
, M32RXF_INSN_BCLR
, M32RXF_SFMT_BSET
, NOPAR
, NOPAR
},
177 { M32R_INSN_BTST
, M32RXF_INSN_BTST
, M32RXF_SFMT_BTST
, M32RXF_INSN_PAR_BTST
, M32RXF_INSN_WRITE_BTST
},
180 static const struct insn_sem m32rxf_insn_sem_invalid
=
182 VIRTUAL_INSN_X_INVALID
, M32RXF_INSN_X_INVALID
, M32RXF_SFMT_EMPTY
, NOPAR
, NOPAR
185 /* Initialize an IDESC from the compile-time computable parts. */
188 init_idesc (SIM_CPU
*cpu
, IDESC
*id
, const struct insn_sem
*t
)
190 const CGEN_INSN
*insn_table
= CGEN_CPU_INSN_TABLE (CPU_CPU_DESC (cpu
))->init_entries
;
194 if ((int) t
->type
<= 0)
195 id
->idata
= & cgen_virtual_insn_table
[- (int) t
->type
];
197 id
->idata
= & insn_table
[t
->type
];
198 id
->attrs
= CGEN_INSN_ATTRS (id
->idata
);
199 /* Oh my god, a magic number. */
200 id
->length
= CGEN_INSN_BITSIZE (id
->idata
) / 8;
202 #if WITH_PROFILE_MODEL_P
203 id
->timing
= & MODEL_TIMING (CPU_MODEL (cpu
)) [t
->index
];
205 SIM_DESC sd
= CPU_STATE (cpu
);
206 SIM_ASSERT (t
->index
== id
->timing
->num
);
210 /* Semantic pointers are initialized elsewhere. */
213 /* Initialize the instruction descriptor table. */
216 m32rxf_init_idesc_table (SIM_CPU
*cpu
)
219 const struct insn_sem
*t
,*tend
;
220 int tabsize
= M32RXF_INSN__MAX
;
221 IDESC
*table
= m32rxf_insn_data
;
223 memset (table
, 0, tabsize
* sizeof (IDESC
));
225 /* First set all entries to the `invalid insn'. */
226 t
= & m32rxf_insn_sem_invalid
;
227 for (id
= table
, tabend
= table
+ tabsize
; id
< tabend
; ++id
)
228 init_idesc (cpu
, id
, t
);
230 /* Now fill in the values for the chosen cpu. */
231 for (t
= m32rxf_insn_sem
, tend
= t
+ ARRAY_SIZE (m32rxf_insn_sem
);
234 init_idesc (cpu
, & table
[t
->index
], t
);
235 if (t
->par_index
!= NOPAR
)
237 init_idesc (cpu
, &table
[t
->par_index
], t
);
238 table
[t
->index
].par_idesc
= &table
[t
->par_index
];
240 if (t
->par_index
!= NOPAR
)
242 init_idesc (cpu
, &table
[t
->write_index
], t
);
243 table
[t
->par_index
].par_idesc
= &table
[t
->write_index
];
247 /* Link the IDESC table into the cpu. */
248 CPU_IDESC (cpu
) = table
;
251 /* Given an instruction, return a pointer to its IDESC entry. */
254 m32rxf_decode (SIM_CPU
*current_cpu
, IADDR pc
,
255 CGEN_INSN_WORD base_insn
, CGEN_INSN_WORD entire_insn
,
258 /* Result of decoder. */
259 M32RXF_INSN_TYPE itype
;
262 CGEN_INSN_WORD insn
= base_insn
;
265 unsigned int val
= (((insn
>> 8) & (15 << 4)) | ((insn
>> 4) & (15 << 0)));
268 case 0 : itype
= M32RXF_INSN_SUBV
; goto extract_sfmt_addv
;
269 case 1 : itype
= M32RXF_INSN_SUBX
; goto extract_sfmt_addx
;
270 case 2 : itype
= M32RXF_INSN_SUB
; goto extract_sfmt_add
;
271 case 3 : itype
= M32RXF_INSN_NEG
; goto extract_sfmt_mv
;
272 case 4 : itype
= M32RXF_INSN_CMP
; goto extract_sfmt_cmp
;
273 case 5 : itype
= M32RXF_INSN_CMPU
; goto extract_sfmt_cmp
;
274 case 6 : itype
= M32RXF_INSN_CMPEQ
; goto extract_sfmt_cmp
;
277 unsigned int val
= (((insn
>> 8) & (3 << 0)));
281 if ((entire_insn
& 0xfff0) == 0x70)
282 { itype
= M32RXF_INSN_CMPZ
; goto extract_sfmt_cmpz
; }
283 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
285 if ((entire_insn
& 0xfff0) == 0x370)
286 { itype
= M32RXF_INSN_PCMPBZ
; goto extract_sfmt_cmpz
; }
287 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
288 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
291 case 8 : itype
= M32RXF_INSN_ADDV
; goto extract_sfmt_addv
;
292 case 9 : itype
= M32RXF_INSN_ADDX
; goto extract_sfmt_addx
;
293 case 10 : itype
= M32RXF_INSN_ADD
; goto extract_sfmt_add
;
294 case 11 : itype
= M32RXF_INSN_NOT
; goto extract_sfmt_mv
;
295 case 12 : itype
= M32RXF_INSN_AND
; goto extract_sfmt_add
;
296 case 13 : itype
= M32RXF_INSN_XOR
; goto extract_sfmt_add
;
297 case 14 : itype
= M32RXF_INSN_OR
; goto extract_sfmt_add
;
299 if ((entire_insn
& 0xf8f0) == 0xf0)
300 { itype
= M32RXF_INSN_BTST
; goto extract_sfmt_btst
; }
301 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
302 case 16 : itype
= M32RXF_INSN_SRL
; goto extract_sfmt_add
;
303 case 18 : itype
= M32RXF_INSN_SRA
; goto extract_sfmt_add
;
304 case 20 : itype
= M32RXF_INSN_SLL
; goto extract_sfmt_add
;
305 case 22 : itype
= M32RXF_INSN_MUL
; goto extract_sfmt_add
;
306 case 24 : itype
= M32RXF_INSN_MV
; goto extract_sfmt_mv
;
307 case 25 : itype
= M32RXF_INSN_MVFC
; goto extract_sfmt_mvfc
;
308 case 26 : itype
= M32RXF_INSN_MVTC
; goto extract_sfmt_mvtc
;
311 unsigned int val
= (((insn
>> 8) & (3 << 0)));
315 if ((entire_insn
& 0xfff0) == 0x1cc0)
316 { itype
= M32RXF_INSN_JC
; goto extract_sfmt_jc
; }
317 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
319 if ((entire_insn
& 0xfff0) == 0x1dc0)
320 { itype
= M32RXF_INSN_JNC
; goto extract_sfmt_jc
; }
321 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
323 if ((entire_insn
& 0xfff0) == 0x1ec0)
324 { itype
= M32RXF_INSN_JL
; goto extract_sfmt_jl
; }
325 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
327 if ((entire_insn
& 0xfff0) == 0x1fc0)
328 { itype
= M32RXF_INSN_JMP
; goto extract_sfmt_jmp
; }
329 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
330 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
334 if ((entire_insn
& 0xffff) == 0x10d6)
335 { itype
= M32RXF_INSN_RTE
; goto extract_sfmt_rte
; }
336 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
338 if ((entire_insn
& 0xfff0) == 0x10f0)
339 { itype
= M32RXF_INSN_TRAP
; goto extract_sfmt_trap
; }
340 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
341 case 32 : itype
= M32RXF_INSN_STB
; goto extract_sfmt_stb
;
342 case 33 : itype
= M32RXF_INSN_STB_PLUS
; goto extract_sfmt_stb_plus
;
343 case 34 : itype
= M32RXF_INSN_STH
; goto extract_sfmt_sth
;
344 case 35 : itype
= M32RXF_INSN_STH_PLUS
; goto extract_sfmt_sth_plus
;
345 case 36 : itype
= M32RXF_INSN_ST
; goto extract_sfmt_st
;
346 case 37 : itype
= M32RXF_INSN_UNLOCK
; goto extract_sfmt_unlock
;
347 case 38 : itype
= M32RXF_INSN_ST_PLUS
; goto extract_sfmt_st_plus
;
348 case 39 : itype
= M32RXF_INSN_ST_MINUS
; goto extract_sfmt_st_plus
;
349 case 40 : itype
= M32RXF_INSN_LDB
; goto extract_sfmt_ldb
;
350 case 41 : itype
= M32RXF_INSN_LDUB
; goto extract_sfmt_ldb
;
351 case 42 : itype
= M32RXF_INSN_LDH
; goto extract_sfmt_ldh
;
352 case 43 : itype
= M32RXF_INSN_LDUH
; goto extract_sfmt_ldh
;
353 case 44 : itype
= M32RXF_INSN_LD
; goto extract_sfmt_ld
;
354 case 45 : itype
= M32RXF_INSN_LOCK
; goto extract_sfmt_lock
;
355 case 46 : itype
= M32RXF_INSN_LD_PLUS
; goto extract_sfmt_ld_plus
;
356 case 48 : /* fall through */
357 case 56 : itype
= M32RXF_INSN_MULHI_A
; goto extract_sfmt_mulhi_a
;
358 case 49 : /* fall through */
359 case 57 : itype
= M32RXF_INSN_MULLO_A
; goto extract_sfmt_mulhi_a
;
360 case 50 : /* fall through */
361 case 58 : itype
= M32RXF_INSN_MULWHI_A
; goto extract_sfmt_mulhi_a
;
362 case 51 : /* fall through */
363 case 59 : itype
= M32RXF_INSN_MULWLO_A
; goto extract_sfmt_mulhi_a
;
364 case 52 : /* fall through */
365 case 60 : itype
= M32RXF_INSN_MACHI_A
; goto extract_sfmt_machi_a
;
366 case 53 : /* fall through */
367 case 61 : itype
= M32RXF_INSN_MACLO_A
; goto extract_sfmt_machi_a
;
368 case 54 : /* fall through */
369 case 62 : itype
= M32RXF_INSN_MACWHI_A
; goto extract_sfmt_machi_a
;
370 case 55 : /* fall through */
371 case 63 : itype
= M32RXF_INSN_MACWLO_A
; goto extract_sfmt_machi_a
;
372 case 64 : /* fall through */
373 case 65 : /* fall through */
374 case 66 : /* fall through */
375 case 67 : /* fall through */
376 case 68 : /* fall through */
377 case 69 : /* fall through */
378 case 70 : /* fall through */
379 case 71 : /* fall through */
380 case 72 : /* fall through */
381 case 73 : /* fall through */
382 case 74 : /* fall through */
383 case 75 : /* fall through */
384 case 76 : /* fall through */
385 case 77 : /* fall through */
386 case 78 : /* fall through */
387 case 79 : itype
= M32RXF_INSN_ADDI
; goto extract_sfmt_addi
;
388 case 80 : /* fall through */
389 case 81 : itype
= M32RXF_INSN_SRLI
; goto extract_sfmt_slli
;
390 case 82 : /* fall through */
391 case 83 : itype
= M32RXF_INSN_SRAI
; goto extract_sfmt_slli
;
392 case 84 : /* fall through */
393 case 85 : itype
= M32RXF_INSN_SLLI
; goto extract_sfmt_slli
;
396 unsigned int val
= (((insn
>> 0) & (1 << 0)));
400 if ((entire_insn
& 0xf0f3) == 0x5070)
401 { itype
= M32RXF_INSN_MVTACHI_A
; goto extract_sfmt_mvtachi_a
; }
402 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
404 if ((entire_insn
& 0xf0f3) == 0x5071)
405 { itype
= M32RXF_INSN_MVTACLO_A
; goto extract_sfmt_mvtachi_a
; }
406 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
407 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
411 if ((entire_insn
& 0xf3f2) == 0x5080)
412 { itype
= M32RXF_INSN_RACH_DSI
; goto extract_sfmt_rac_dsi
; }
413 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
415 if ((entire_insn
& 0xf3f2) == 0x5090)
416 { itype
= M32RXF_INSN_RAC_DSI
; goto extract_sfmt_rac_dsi
; }
417 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
418 case 90 : itype
= M32RXF_INSN_MULWU1
; goto extract_sfmt_mulwu1
;
419 case 91 : itype
= M32RXF_INSN_MACWU1
; goto extract_sfmt_macwu1
;
420 case 92 : itype
= M32RXF_INSN_MACLH1
; goto extract_sfmt_macwu1
;
421 case 93 : itype
= M32RXF_INSN_MSBLO
; goto extract_sfmt_msblo
;
423 if ((entire_insn
& 0xffff) == 0x50e4)
424 { itype
= M32RXF_INSN_SADD
; goto extract_sfmt_sadd
; }
425 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
428 unsigned int val
= (((insn
>> 0) & (3 << 0)));
431 case 0 : itype
= M32RXF_INSN_MVFACHI_A
; goto extract_sfmt_mvfachi_a
;
432 case 1 : itype
= M32RXF_INSN_MVFACLO_A
; goto extract_sfmt_mvfachi_a
;
433 case 2 : itype
= M32RXF_INSN_MVFACMI_A
; goto extract_sfmt_mvfachi_a
;
434 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
437 case 96 : /* fall through */
438 case 97 : /* fall through */
439 case 98 : /* fall through */
440 case 99 : /* fall through */
441 case 100 : /* fall through */
442 case 101 : /* fall through */
443 case 102 : /* fall through */
444 case 103 : /* fall through */
445 case 104 : /* fall through */
446 case 105 : /* fall through */
447 case 106 : /* fall through */
448 case 107 : /* fall through */
449 case 108 : /* fall through */
450 case 109 : /* fall through */
451 case 110 : /* fall through */
452 case 111 : itype
= M32RXF_INSN_LDI8
; goto extract_sfmt_ldi8
;
455 unsigned int val
= (((insn
>> 7) & (15 << 1)) | ((insn
>> 0) & (1 << 0)));
459 if ((entire_insn
& 0xffff) == 0x7000)
460 { itype
= M32RXF_INSN_NOP
; goto extract_sfmt_nop
; }
461 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
462 case 2 : /* fall through */
463 case 3 : itype
= M32RXF_INSN_SETPSW
; goto extract_sfmt_setpsw
;
464 case 4 : /* fall through */
465 case 5 : itype
= M32RXF_INSN_CLRPSW
; goto extract_sfmt_clrpsw
;
467 if ((entire_insn
& 0xffff) == 0x7401)
468 { itype
= M32RXF_INSN_SC
; goto extract_sfmt_sc
; }
469 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
471 if ((entire_insn
& 0xffff) == 0x7501)
472 { itype
= M32RXF_INSN_SNC
; goto extract_sfmt_sc
; }
473 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
474 case 16 : /* fall through */
475 case 17 : itype
= M32RXF_INSN_BCL8
; goto extract_sfmt_bcl8
;
476 case 18 : /* fall through */
477 case 19 : itype
= M32RXF_INSN_BNCL8
; goto extract_sfmt_bcl8
;
478 case 24 : /* fall through */
479 case 25 : itype
= M32RXF_INSN_BC8
; goto extract_sfmt_bc8
;
480 case 26 : /* fall through */
481 case 27 : itype
= M32RXF_INSN_BNC8
; goto extract_sfmt_bc8
;
482 case 28 : /* fall through */
483 case 29 : itype
= M32RXF_INSN_BL8
; goto extract_sfmt_bl8
;
484 case 30 : /* fall through */
485 case 31 : itype
= M32RXF_INSN_BRA8
; goto extract_sfmt_bra8
;
486 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
489 case 113 : /* fall through */
490 case 114 : /* fall through */
491 case 115 : /* fall through */
492 case 116 : /* fall through */
493 case 117 : /* fall through */
494 case 118 : /* fall through */
495 case 119 : /* fall through */
496 case 120 : /* fall through */
497 case 121 : /* fall through */
498 case 122 : /* fall through */
499 case 123 : /* fall through */
500 case 124 : /* fall through */
501 case 125 : /* fall through */
502 case 126 : /* fall through */
505 unsigned int val
= (((insn
>> 8) & (15 << 0)));
508 case 1 : itype
= M32RXF_INSN_SETPSW
; goto extract_sfmt_setpsw
;
509 case 2 : itype
= M32RXF_INSN_CLRPSW
; goto extract_sfmt_clrpsw
;
510 case 8 : itype
= M32RXF_INSN_BCL8
; goto extract_sfmt_bcl8
;
511 case 9 : itype
= M32RXF_INSN_BNCL8
; goto extract_sfmt_bcl8
;
512 case 12 : itype
= M32RXF_INSN_BC8
; goto extract_sfmt_bc8
;
513 case 13 : itype
= M32RXF_INSN_BNC8
; goto extract_sfmt_bc8
;
514 case 14 : itype
= M32RXF_INSN_BL8
; goto extract_sfmt_bl8
;
515 case 15 : itype
= M32RXF_INSN_BRA8
; goto extract_sfmt_bra8
;
516 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
520 if ((entire_insn
& 0xfff00000) == 0x80400000)
521 { itype
= M32RXF_INSN_CMPI
; goto extract_sfmt_cmpi
; }
522 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
524 if ((entire_insn
& 0xfff00000) == 0x80500000)
525 { itype
= M32RXF_INSN_CMPUI
; goto extract_sfmt_cmpi
; }
526 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
529 unsigned int val
= (((entire_insn
>> 8) & (3 << 0)));
533 if ((entire_insn
& 0xf0f0ffff) == 0x80600000)
534 { itype
= M32RXF_INSN_SAT
; goto extract_sfmt_sat
; }
535 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
537 if ((entire_insn
& 0xf0f0ffff) == 0x80600200)
538 { itype
= M32RXF_INSN_SATH
; goto extract_sfmt_satb
; }
539 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
541 if ((entire_insn
& 0xf0f0ffff) == 0x80600300)
542 { itype
= M32RXF_INSN_SATB
; goto extract_sfmt_satb
; }
543 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
544 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
547 case 136 : itype
= M32RXF_INSN_ADDV3
; goto extract_sfmt_addv3
;
548 case 138 : itype
= M32RXF_INSN_ADD3
; goto extract_sfmt_add3
;
549 case 140 : itype
= M32RXF_INSN_AND3
; goto extract_sfmt_and3
;
550 case 141 : itype
= M32RXF_INSN_XOR3
; goto extract_sfmt_and3
;
551 case 142 : itype
= M32RXF_INSN_OR3
; goto extract_sfmt_or3
;
554 unsigned int val
= (((entire_insn
>> 4) & (1 << 0)));
558 if ((entire_insn
& 0xf0f0ffff) == 0x90000000)
559 { itype
= M32RXF_INSN_DIV
; goto extract_sfmt_div
; }
560 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
562 if ((entire_insn
& 0xf0f0ffff) == 0x90000010)
563 { itype
= M32RXF_INSN_DIVH
; goto extract_sfmt_div
; }
564 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
565 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
569 if ((entire_insn
& 0xf0f0ffff) == 0x90100000)
570 { itype
= M32RXF_INSN_DIVU
; goto extract_sfmt_div
; }
571 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
573 if ((entire_insn
& 0xf0f0ffff) == 0x90200000)
574 { itype
= M32RXF_INSN_REM
; goto extract_sfmt_div
; }
575 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
577 if ((entire_insn
& 0xf0f0ffff) == 0x90300000)
578 { itype
= M32RXF_INSN_REMU
; goto extract_sfmt_div
; }
579 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
580 case 152 : itype
= M32RXF_INSN_SRL3
; goto extract_sfmt_sll3
;
581 case 154 : itype
= M32RXF_INSN_SRA3
; goto extract_sfmt_sll3
;
582 case 156 : itype
= M32RXF_INSN_SLL3
; goto extract_sfmt_sll3
;
584 if ((entire_insn
& 0xf0ff0000) == 0x90f00000)
585 { itype
= M32RXF_INSN_LDI16
; goto extract_sfmt_ldi16
; }
586 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
587 case 160 : itype
= M32RXF_INSN_STB_D
; goto extract_sfmt_stb_d
;
588 case 162 : itype
= M32RXF_INSN_STH_D
; goto extract_sfmt_sth_d
;
589 case 164 : itype
= M32RXF_INSN_ST_D
; goto extract_sfmt_st_d
;
591 if ((entire_insn
& 0xf8f00000) == 0xa0600000)
592 { itype
= M32RXF_INSN_BSET
; goto extract_sfmt_bset
; }
593 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
595 if ((entire_insn
& 0xf8f00000) == 0xa0700000)
596 { itype
= M32RXF_INSN_BCLR
; goto extract_sfmt_bset
; }
597 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
598 case 168 : itype
= M32RXF_INSN_LDB_D
; goto extract_sfmt_ldb_d
;
599 case 169 : itype
= M32RXF_INSN_LDUB_D
; goto extract_sfmt_ldb_d
;
600 case 170 : itype
= M32RXF_INSN_LDH_D
; goto extract_sfmt_ldh_d
;
601 case 171 : itype
= M32RXF_INSN_LDUH_D
; goto extract_sfmt_ldh_d
;
602 case 172 : itype
= M32RXF_INSN_LD_D
; goto extract_sfmt_ld_d
;
603 case 176 : itype
= M32RXF_INSN_BEQ
; goto extract_sfmt_beq
;
604 case 177 : itype
= M32RXF_INSN_BNE
; goto extract_sfmt_beq
;
606 if ((entire_insn
& 0xfff00000) == 0xb0800000)
607 { itype
= M32RXF_INSN_BEQZ
; goto extract_sfmt_beqz
; }
608 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
610 if ((entire_insn
& 0xfff00000) == 0xb0900000)
611 { itype
= M32RXF_INSN_BNEZ
; goto extract_sfmt_beqz
; }
612 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
614 if ((entire_insn
& 0xfff00000) == 0xb0a00000)
615 { itype
= M32RXF_INSN_BLTZ
; goto extract_sfmt_beqz
; }
616 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
618 if ((entire_insn
& 0xfff00000) == 0xb0b00000)
619 { itype
= M32RXF_INSN_BGEZ
; goto extract_sfmt_beqz
; }
620 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
622 if ((entire_insn
& 0xfff00000) == 0xb0c00000)
623 { itype
= M32RXF_INSN_BLEZ
; goto extract_sfmt_beqz
; }
624 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
626 if ((entire_insn
& 0xfff00000) == 0xb0d00000)
627 { itype
= M32RXF_INSN_BGTZ
; goto extract_sfmt_beqz
; }
628 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
630 if ((entire_insn
& 0xf0ff0000) == 0xd0c00000)
631 { itype
= M32RXF_INSN_SETH
; goto extract_sfmt_seth
; }
632 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
633 case 224 : /* fall through */
634 case 225 : /* fall through */
635 case 226 : /* fall through */
636 case 227 : /* fall through */
637 case 228 : /* fall through */
638 case 229 : /* fall through */
639 case 230 : /* fall through */
640 case 231 : /* fall through */
641 case 232 : /* fall through */
642 case 233 : /* fall through */
643 case 234 : /* fall through */
644 case 235 : /* fall through */
645 case 236 : /* fall through */
646 case 237 : /* fall through */
647 case 238 : /* fall through */
648 case 239 : itype
= M32RXF_INSN_LD24
; goto extract_sfmt_ld24
;
649 case 240 : /* fall through */
650 case 241 : /* fall through */
651 case 242 : /* fall through */
652 case 243 : /* fall through */
653 case 244 : /* fall through */
654 case 245 : /* fall through */
655 case 246 : /* fall through */
656 case 247 : /* fall through */
657 case 248 : /* fall through */
658 case 249 : /* fall through */
659 case 250 : /* fall through */
660 case 251 : /* fall through */
661 case 252 : /* fall through */
662 case 253 : /* fall through */
663 case 254 : /* fall through */
666 unsigned int val
= (((insn
>> 8) & (7 << 0)));
670 if ((entire_insn
& 0xff000000) == 0xf8000000)
671 { itype
= M32RXF_INSN_BCL24
; goto extract_sfmt_bcl24
; }
672 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
674 if ((entire_insn
& 0xff000000) == 0xf9000000)
675 { itype
= M32RXF_INSN_BNCL24
; goto extract_sfmt_bcl24
; }
676 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
678 if ((entire_insn
& 0xff000000) == 0xfc000000)
679 { itype
= M32RXF_INSN_BC24
; goto extract_sfmt_bc24
; }
680 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
682 if ((entire_insn
& 0xff000000) == 0xfd000000)
683 { itype
= M32RXF_INSN_BNC24
; goto extract_sfmt_bc24
; }
684 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
686 if ((entire_insn
& 0xff000000) == 0xfe000000)
687 { itype
= M32RXF_INSN_BL24
; goto extract_sfmt_bl24
; }
688 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
690 if ((entire_insn
& 0xff000000) == 0xff000000)
691 { itype
= M32RXF_INSN_BRA24
; goto extract_sfmt_bra24
; }
692 itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
693 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
696 default : itype
= M32RXF_INSN_X_INVALID
; goto extract_sfmt_empty
;
701 /* The instruction has been decoded, now extract the fields. */
705 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
706 #define FLD(f) abuf->fields.sfmt_empty.f
709 /* Record the fields for the semantic handler. */
710 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_empty", (char *) 0));
718 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
719 CGEN_INSN_WORD insn
= entire_insn
;
720 #define FLD(f) abuf->fields.sfmt_add.f
724 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
725 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
727 /* Record the fields for the semantic handler. */
730 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
731 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
732 CGEN_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));
734 #if WITH_PROFILE_MODEL_P
735 /* Record the fields for profiling. */
736 if (PROFILE_MODEL_P (current_cpu
))
749 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
750 CGEN_INSN_WORD insn
= entire_insn
;
751 #define FLD(f) abuf->fields.sfmt_add3.f
756 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
757 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
758 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
760 /* Record the fields for the semantic handler. */
761 FLD (f_simm16
) = f_simm16
;
764 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
765 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
766 CGEN_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));
768 #if WITH_PROFILE_MODEL_P
769 /* Record the fields for profiling. */
770 if (PROFILE_MODEL_P (current_cpu
))
782 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
783 CGEN_INSN_WORD insn
= entire_insn
;
784 #define FLD(f) abuf->fields.sfmt_and3.f
789 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
790 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
791 f_uimm16
= EXTRACT_MSB0_UINT (insn
, 32, 16, 16);
793 /* Record the fields for the semantic handler. */
795 FLD (f_uimm16
) = f_uimm16
;
797 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
798 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
799 CGEN_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));
801 #if WITH_PROFILE_MODEL_P
802 /* Record the fields for profiling. */
803 if (PROFILE_MODEL_P (current_cpu
))
815 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
816 CGEN_INSN_WORD insn
= entire_insn
;
817 #define FLD(f) abuf->fields.sfmt_and3.f
822 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
823 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
824 f_uimm16
= EXTRACT_MSB0_UINT (insn
, 32, 16, 16);
826 /* Record the fields for the semantic handler. */
828 FLD (f_uimm16
) = f_uimm16
;
830 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
831 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
832 CGEN_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));
834 #if WITH_PROFILE_MODEL_P
835 /* Record the fields for profiling. */
836 if (PROFILE_MODEL_P (current_cpu
))
848 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
849 CGEN_INSN_WORD insn
= entire_insn
;
850 #define FLD(f) abuf->fields.sfmt_addi.f
854 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
855 f_simm8
= EXTRACT_MSB0_SINT (insn
, 16, 8, 8);
857 /* Record the fields for the semantic handler. */
859 FLD (f_simm8
) = f_simm8
;
860 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
861 CGEN_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));
863 #if WITH_PROFILE_MODEL_P
864 /* Record the fields for profiling. */
865 if (PROFILE_MODEL_P (current_cpu
))
877 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
878 CGEN_INSN_WORD insn
= entire_insn
;
879 #define FLD(f) abuf->fields.sfmt_add.f
883 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
884 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
886 /* Record the fields for the semantic handler. */
889 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
890 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
891 CGEN_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));
893 #if WITH_PROFILE_MODEL_P
894 /* Record the fields for profiling. */
895 if (PROFILE_MODEL_P (current_cpu
))
908 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
909 CGEN_INSN_WORD insn
= entire_insn
;
910 #define FLD(f) abuf->fields.sfmt_add3.f
915 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
916 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
917 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
919 /* Record the fields for the semantic handler. */
920 FLD (f_simm16
) = f_simm16
;
923 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
924 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
925 CGEN_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));
927 #if WITH_PROFILE_MODEL_P
928 /* Record the fields for profiling. */
929 if (PROFILE_MODEL_P (current_cpu
))
941 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
942 CGEN_INSN_WORD insn
= entire_insn
;
943 #define FLD(f) abuf->fields.sfmt_add.f
947 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
948 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
950 /* Record the fields for the semantic handler. */
953 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
954 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
955 CGEN_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));
957 #if WITH_PROFILE_MODEL_P
958 /* Record the fields for profiling. */
959 if (PROFILE_MODEL_P (current_cpu
))
972 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
973 CGEN_INSN_WORD insn
= entire_insn
;
974 #define FLD(f) abuf->fields.sfmt_bl8.f
977 f_disp8
= ((((EXTRACT_MSB0_SINT (insn
, 16, 8, 8)) << (2))) + (((pc
) & (-4))));
979 /* Record the fields for the semantic handler. */
980 FLD (i_disp8
) = f_disp8
;
981 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bc8", "disp8 0x%x", 'x', f_disp8
, (char *) 0));
983 #if WITH_PROFILE_MODEL_P
984 /* Record the fields for profiling. */
985 if (PROFILE_MODEL_P (current_cpu
))
995 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
996 CGEN_INSN_WORD insn
= entire_insn
;
997 #define FLD(f) abuf->fields.sfmt_bl24.f
1000 f_disp24
= ((((EXTRACT_MSB0_SINT (insn
, 32, 8, 24)) << (2))) + (pc
));
1002 /* Record the fields for the semantic handler. */
1003 FLD (i_disp24
) = f_disp24
;
1004 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bc24", "disp24 0x%x", 'x', f_disp24
, (char *) 0));
1006 #if WITH_PROFILE_MODEL_P
1007 /* Record the fields for profiling. */
1008 if (PROFILE_MODEL_P (current_cpu
))
1018 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1019 CGEN_INSN_WORD insn
= entire_insn
;
1020 #define FLD(f) abuf->fields.sfmt_beq.f
1025 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
1026 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
1027 f_disp16
= ((((EXTRACT_MSB0_SINT (insn
, 32, 16, 16)) << (2))) + (pc
));
1029 /* Record the fields for the semantic handler. */
1032 FLD (i_disp16
) = f_disp16
;
1033 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
1034 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
1035 CGEN_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));
1037 #if WITH_PROFILE_MODEL_P
1038 /* Record the fields for profiling. */
1039 if (PROFILE_MODEL_P (current_cpu
))
1041 FLD (in_src1
) = f_r1
;
1042 FLD (in_src2
) = f_r2
;
1051 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1052 CGEN_INSN_WORD insn
= entire_insn
;
1053 #define FLD(f) abuf->fields.sfmt_beq.f
1057 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
1058 f_disp16
= ((((EXTRACT_MSB0_SINT (insn
, 32, 16, 16)) << (2))) + (pc
));
1060 /* Record the fields for the semantic handler. */
1062 FLD (i_disp16
) = f_disp16
;
1063 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
1064 CGEN_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));
1066 #if WITH_PROFILE_MODEL_P
1067 /* Record the fields for profiling. */
1068 if (PROFILE_MODEL_P (current_cpu
))
1070 FLD (in_src2
) = f_r2
;
1079 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1080 CGEN_INSN_WORD insn
= entire_insn
;
1081 #define FLD(f) abuf->fields.sfmt_bl8.f
1084 f_disp8
= ((((EXTRACT_MSB0_SINT (insn
, 16, 8, 8)) << (2))) + (((pc
) & (-4))));
1086 /* Record the fields for the semantic handler. */
1087 FLD (i_disp8
) = f_disp8
;
1088 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bl8", "disp8 0x%x", 'x', f_disp8
, (char *) 0));
1090 #if WITH_PROFILE_MODEL_P
1091 /* Record the fields for profiling. */
1092 if (PROFILE_MODEL_P (current_cpu
))
1094 FLD (out_h_gr_SI_14
) = 14;
1103 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1104 CGEN_INSN_WORD insn
= entire_insn
;
1105 #define FLD(f) abuf->fields.sfmt_bl24.f
1108 f_disp24
= ((((EXTRACT_MSB0_SINT (insn
, 32, 8, 24)) << (2))) + (pc
));
1110 /* Record the fields for the semantic handler. */
1111 FLD (i_disp24
) = f_disp24
;
1112 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bl24", "disp24 0x%x", 'x', f_disp24
, (char *) 0));
1114 #if WITH_PROFILE_MODEL_P
1115 /* Record the fields for profiling. */
1116 if (PROFILE_MODEL_P (current_cpu
))
1118 FLD (out_h_gr_SI_14
) = 14;
1127 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1128 CGEN_INSN_WORD insn
= entire_insn
;
1129 #define FLD(f) abuf->fields.sfmt_bl8.f
1132 f_disp8
= ((((EXTRACT_MSB0_SINT (insn
, 16, 8, 8)) << (2))) + (((pc
) & (-4))));
1134 /* Record the fields for the semantic handler. */
1135 FLD (i_disp8
) = f_disp8
;
1136 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bcl8", "disp8 0x%x", 'x', f_disp8
, (char *) 0));
1138 #if WITH_PROFILE_MODEL_P
1139 /* Record the fields for profiling. */
1140 if (PROFILE_MODEL_P (current_cpu
))
1142 FLD (out_h_gr_SI_14
) = 14;
1151 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1152 CGEN_INSN_WORD insn
= entire_insn
;
1153 #define FLD(f) abuf->fields.sfmt_bl24.f
1156 f_disp24
= ((((EXTRACT_MSB0_SINT (insn
, 32, 8, 24)) << (2))) + (pc
));
1158 /* Record the fields for the semantic handler. */
1159 FLD (i_disp24
) = f_disp24
;
1160 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bcl24", "disp24 0x%x", 'x', f_disp24
, (char *) 0));
1162 #if WITH_PROFILE_MODEL_P
1163 /* Record the fields for profiling. */
1164 if (PROFILE_MODEL_P (current_cpu
))
1166 FLD (out_h_gr_SI_14
) = 14;
1175 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1176 CGEN_INSN_WORD insn
= entire_insn
;
1177 #define FLD(f) abuf->fields.sfmt_bl8.f
1180 f_disp8
= ((((EXTRACT_MSB0_SINT (insn
, 16, 8, 8)) << (2))) + (((pc
) & (-4))));
1182 /* Record the fields for the semantic handler. */
1183 FLD (i_disp8
) = f_disp8
;
1184 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bra8", "disp8 0x%x", 'x', f_disp8
, (char *) 0));
1186 #if WITH_PROFILE_MODEL_P
1187 /* Record the fields for profiling. */
1188 if (PROFILE_MODEL_P (current_cpu
))
1198 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1199 CGEN_INSN_WORD insn
= entire_insn
;
1200 #define FLD(f) abuf->fields.sfmt_bl24.f
1203 f_disp24
= ((((EXTRACT_MSB0_SINT (insn
, 32, 8, 24)) << (2))) + (pc
));
1205 /* Record the fields for the semantic handler. */
1206 FLD (i_disp24
) = f_disp24
;
1207 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_bra24", "disp24 0x%x", 'x', f_disp24
, (char *) 0));
1209 #if WITH_PROFILE_MODEL_P
1210 /* Record the fields for profiling. */
1211 if (PROFILE_MODEL_P (current_cpu
))
1221 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1222 CGEN_INSN_WORD insn
= entire_insn
;
1223 #define FLD(f) abuf->fields.sfmt_st_plus.f
1227 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1228 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1230 /* Record the fields for the semantic handler. */
1233 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
1234 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
1235 CGEN_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));
1237 #if WITH_PROFILE_MODEL_P
1238 /* Record the fields for profiling. */
1239 if (PROFILE_MODEL_P (current_cpu
))
1241 FLD (in_src1
) = f_r1
;
1242 FLD (in_src2
) = f_r2
;
1251 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1252 CGEN_INSN_WORD insn
= entire_insn
;
1253 #define FLD(f) abuf->fields.sfmt_st_d.f
1257 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
1258 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
1260 /* Record the fields for the semantic handler. */
1261 FLD (f_simm16
) = f_simm16
;
1263 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
1264 CGEN_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));
1266 #if WITH_PROFILE_MODEL_P
1267 /* Record the fields for profiling. */
1268 if (PROFILE_MODEL_P (current_cpu
))
1270 FLD (in_src2
) = f_r2
;
1279 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1280 CGEN_INSN_WORD insn
= entire_insn
;
1281 #define FLD(f) abuf->fields.sfmt_st_plus.f
1284 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1286 /* Record the fields for the semantic handler. */
1288 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
1289 CGEN_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));
1291 #if WITH_PROFILE_MODEL_P
1292 /* Record the fields for profiling. */
1293 if (PROFILE_MODEL_P (current_cpu
))
1295 FLD (in_src2
) = f_r2
;
1304 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1305 CGEN_INSN_WORD insn
= entire_insn
;
1306 #define FLD(f) abuf->fields.sfmt_add.f
1310 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
1311 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
1313 /* Record the fields for the semantic handler. */
1316 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1317 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1318 CGEN_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));
1320 #if WITH_PROFILE_MODEL_P
1321 /* Record the fields for profiling. */
1322 if (PROFILE_MODEL_P (current_cpu
))
1326 FLD (out_dr
) = f_r1
;
1335 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1336 CGEN_INSN_WORD insn
= entire_insn
;
1337 #define FLD(f) abuf->fields.sfmt_jl.f
1340 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1342 /* Record the fields for the semantic handler. */
1344 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1345 CGEN_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));
1347 #if WITH_PROFILE_MODEL_P
1348 /* Record the fields for profiling. */
1349 if (PROFILE_MODEL_P (current_cpu
))
1360 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1361 CGEN_INSN_WORD insn
= entire_insn
;
1362 #define FLD(f) abuf->fields.sfmt_jl.f
1365 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1367 /* Record the fields for the semantic handler. */
1369 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1370 CGEN_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));
1372 #if WITH_PROFILE_MODEL_P
1373 /* Record the fields for profiling. */
1374 if (PROFILE_MODEL_P (current_cpu
))
1377 FLD (out_h_gr_SI_14
) = 14;
1386 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1387 CGEN_INSN_WORD insn
= entire_insn
;
1388 #define FLD(f) abuf->fields.sfmt_jl.f
1391 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1393 /* Record the fields for the semantic handler. */
1395 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1396 CGEN_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));
1398 #if WITH_PROFILE_MODEL_P
1399 /* Record the fields for profiling. */
1400 if (PROFILE_MODEL_P (current_cpu
))
1411 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1412 CGEN_INSN_WORD insn
= entire_insn
;
1413 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1417 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1418 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1420 /* Record the fields for the semantic handler. */
1423 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1424 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1425 CGEN_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));
1427 #if WITH_PROFILE_MODEL_P
1428 /* Record the fields for profiling. */
1429 if (PROFILE_MODEL_P (current_cpu
))
1432 FLD (out_dr
) = f_r1
;
1441 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1442 CGEN_INSN_WORD insn
= entire_insn
;
1443 #define FLD(f) abuf->fields.sfmt_add3.f
1448 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
1449 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
1450 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
1452 /* Record the fields for the semantic handler. */
1453 FLD (f_simm16
) = f_simm16
;
1456 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1457 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1458 CGEN_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));
1460 #if WITH_PROFILE_MODEL_P
1461 /* Record the fields for profiling. */
1462 if (PROFILE_MODEL_P (current_cpu
))
1465 FLD (out_dr
) = f_r1
;
1474 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1475 CGEN_INSN_WORD insn
= entire_insn
;
1476 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1480 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1481 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1483 /* Record the fields for the semantic handler. */
1486 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1487 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1488 CGEN_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));
1490 #if WITH_PROFILE_MODEL_P
1491 /* Record the fields for profiling. */
1492 if (PROFILE_MODEL_P (current_cpu
))
1495 FLD (out_dr
) = f_r1
;
1504 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1505 CGEN_INSN_WORD insn
= entire_insn
;
1506 #define FLD(f) abuf->fields.sfmt_add3.f
1511 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
1512 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
1513 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
1515 /* Record the fields for the semantic handler. */
1516 FLD (f_simm16
) = f_simm16
;
1519 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1520 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1521 CGEN_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));
1523 #if WITH_PROFILE_MODEL_P
1524 /* Record the fields for profiling. */
1525 if (PROFILE_MODEL_P (current_cpu
))
1528 FLD (out_dr
) = f_r1
;
1537 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1538 CGEN_INSN_WORD insn
= entire_insn
;
1539 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1543 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1544 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1546 /* Record the fields for the semantic handler. */
1549 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1550 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1551 CGEN_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));
1553 #if WITH_PROFILE_MODEL_P
1554 /* Record the fields for profiling. */
1555 if (PROFILE_MODEL_P (current_cpu
))
1558 FLD (out_dr
) = f_r1
;
1567 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1568 CGEN_INSN_WORD insn
= entire_insn
;
1569 #define FLD(f) abuf->fields.sfmt_add3.f
1574 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
1575 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
1576 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
1578 /* Record the fields for the semantic handler. */
1579 FLD (f_simm16
) = f_simm16
;
1582 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1583 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1584 CGEN_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));
1586 #if WITH_PROFILE_MODEL_P
1587 /* Record the fields for profiling. */
1588 if (PROFILE_MODEL_P (current_cpu
))
1591 FLD (out_dr
) = f_r1
;
1598 extract_sfmt_ld_plus
:
1600 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1601 CGEN_INSN_WORD insn
= entire_insn
;
1602 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1606 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1607 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1609 /* Record the fields for the semantic handler. */
1612 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1613 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1614 CGEN_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));
1616 #if WITH_PROFILE_MODEL_P
1617 /* Record the fields for profiling. */
1618 if (PROFILE_MODEL_P (current_cpu
))
1621 FLD (out_dr
) = f_r1
;
1622 FLD (out_sr
) = f_r2
;
1631 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1632 CGEN_INSN_WORD insn
= entire_insn
;
1633 #define FLD(f) abuf->fields.sfmt_ld24.f
1637 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
1638 f_uimm24
= EXTRACT_MSB0_UINT (insn
, 32, 8, 24);
1640 /* Record the fields for the semantic handler. */
1642 FLD (i_uimm24
) = f_uimm24
;
1643 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1644 CGEN_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));
1646 #if WITH_PROFILE_MODEL_P
1647 /* Record the fields for profiling. */
1648 if (PROFILE_MODEL_P (current_cpu
))
1650 FLD (out_dr
) = f_r1
;
1659 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1660 CGEN_INSN_WORD insn
= entire_insn
;
1661 #define FLD(f) abuf->fields.sfmt_addi.f
1665 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1666 f_simm8
= EXTRACT_MSB0_SINT (insn
, 16, 8, 8);
1668 /* Record the fields for the semantic handler. */
1669 FLD (f_simm8
) = f_simm8
;
1671 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1672 CGEN_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));
1674 #if WITH_PROFILE_MODEL_P
1675 /* Record the fields for profiling. */
1676 if (PROFILE_MODEL_P (current_cpu
))
1678 FLD (out_dr
) = f_r1
;
1687 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1688 CGEN_INSN_WORD insn
= entire_insn
;
1689 #define FLD(f) abuf->fields.sfmt_add3.f
1693 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
1694 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
1696 /* Record the fields for the semantic handler. */
1697 FLD (f_simm16
) = f_simm16
;
1699 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1700 CGEN_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));
1702 #if WITH_PROFILE_MODEL_P
1703 /* Record the fields for profiling. */
1704 if (PROFILE_MODEL_P (current_cpu
))
1706 FLD (out_dr
) = f_r1
;
1715 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1716 CGEN_INSN_WORD insn
= entire_insn
;
1717 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1721 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1722 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1724 /* Record the fields for the semantic handler. */
1727 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1728 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1729 CGEN_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));
1731 #if WITH_PROFILE_MODEL_P
1732 /* Record the fields for profiling. */
1733 if (PROFILE_MODEL_P (current_cpu
))
1736 FLD (out_dr
) = f_r1
;
1743 extract_sfmt_machi_a
:
1745 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1746 CGEN_INSN_WORD insn
= entire_insn
;
1747 #define FLD(f) abuf->fields.sfmt_machi_a.f
1752 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1753 f_acc
= EXTRACT_MSB0_UINT (insn
, 16, 8, 1);
1754 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1756 /* Record the fields for the semantic handler. */
1757 FLD (f_acc
) = f_acc
;
1760 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
1761 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
1762 CGEN_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));
1764 #if WITH_PROFILE_MODEL_P
1765 /* Record the fields for profiling. */
1766 if (PROFILE_MODEL_P (current_cpu
))
1768 FLD (in_src1
) = f_r1
;
1769 FLD (in_src2
) = f_r2
;
1776 extract_sfmt_mulhi_a
:
1778 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1779 CGEN_INSN_WORD insn
= entire_insn
;
1780 #define FLD(f) abuf->fields.sfmt_machi_a.f
1785 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1786 f_acc
= EXTRACT_MSB0_UINT (insn
, 16, 8, 1);
1787 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1789 /* Record the fields for the semantic handler. */
1792 FLD (f_acc
) = f_acc
;
1793 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
1794 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
1795 CGEN_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));
1797 #if WITH_PROFILE_MODEL_P
1798 /* Record the fields for profiling. */
1799 if (PROFILE_MODEL_P (current_cpu
))
1801 FLD (in_src1
) = f_r1
;
1802 FLD (in_src2
) = f_r2
;
1811 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1812 CGEN_INSN_WORD insn
= entire_insn
;
1813 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1817 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1818 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1820 /* Record the fields for the semantic handler. */
1823 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1824 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1825 CGEN_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));
1827 #if WITH_PROFILE_MODEL_P
1828 /* Record the fields for profiling. */
1829 if (PROFILE_MODEL_P (current_cpu
))
1832 FLD (out_dr
) = f_r1
;
1839 extract_sfmt_mvfachi_a
:
1841 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1842 CGEN_INSN_WORD insn
= entire_insn
;
1843 #define FLD(f) abuf->fields.sfmt_mvfachi_a.f
1847 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1848 f_accs
= EXTRACT_MSB0_UINT (insn
, 16, 12, 2);
1850 /* Record the fields for the semantic handler. */
1851 FLD (f_accs
) = f_accs
;
1853 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1854 CGEN_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));
1856 #if WITH_PROFILE_MODEL_P
1857 /* Record the fields for profiling. */
1858 if (PROFILE_MODEL_P (current_cpu
))
1860 FLD (out_dr
) = f_r1
;
1869 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1870 CGEN_INSN_WORD insn
= entire_insn
;
1871 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1875 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1876 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1878 /* Record the fields for the semantic handler. */
1881 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
1882 CGEN_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));
1884 #if WITH_PROFILE_MODEL_P
1885 /* Record the fields for profiling. */
1886 if (PROFILE_MODEL_P (current_cpu
))
1888 FLD (out_dr
) = f_r1
;
1895 extract_sfmt_mvtachi_a
:
1897 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1898 CGEN_INSN_WORD insn
= entire_insn
;
1899 #define FLD(f) abuf->fields.sfmt_mvtachi_a.f
1903 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1904 f_accs
= EXTRACT_MSB0_UINT (insn
, 16, 12, 2);
1906 /* Record the fields for the semantic handler. */
1907 FLD (f_accs
) = f_accs
;
1909 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
1910 CGEN_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));
1912 #if WITH_PROFILE_MODEL_P
1913 /* Record the fields for profiling. */
1914 if (PROFILE_MODEL_P (current_cpu
))
1916 FLD (in_src1
) = f_r1
;
1925 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1926 CGEN_INSN_WORD insn
= entire_insn
;
1927 #define FLD(f) abuf->fields.sfmt_ld_plus.f
1931 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
1932 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
1934 /* Record the fields for the semantic handler. */
1937 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
1938 CGEN_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));
1940 #if WITH_PROFILE_MODEL_P
1941 /* Record the fields for profiling. */
1942 if (PROFILE_MODEL_P (current_cpu
))
1953 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1954 #define FLD(f) abuf->fields.sfmt_empty.f
1957 /* Record the fields for the semantic handler. */
1958 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_nop", (char *) 0));
1964 extract_sfmt_rac_dsi
:
1966 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1967 CGEN_INSN_WORD insn
= entire_insn
;
1968 #define FLD(f) abuf->fields.sfmt_rac_dsi.f
1973 f_accd
= EXTRACT_MSB0_UINT (insn
, 16, 4, 2);
1974 f_accs
= EXTRACT_MSB0_UINT (insn
, 16, 12, 2);
1975 f_imm1
= ((EXTRACT_MSB0_UINT (insn
, 16, 15, 1)) + (1));
1977 /* Record the fields for the semantic handler. */
1978 FLD (f_accs
) = f_accs
;
1979 FLD (f_imm1
) = f_imm1
;
1980 FLD (f_accd
) = f_accd
;
1981 CGEN_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));
1989 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
1990 #define FLD(f) abuf->fields.sfmt_empty.f
1993 /* Record the fields for the semantic handler. */
1994 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_rte", (char *) 0));
1996 #if WITH_PROFILE_MODEL_P
1997 /* Record the fields for profiling. */
1998 if (PROFILE_MODEL_P (current_cpu
))
2008 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2009 CGEN_INSN_WORD insn
= entire_insn
;
2010 #define FLD(f) abuf->fields.sfmt_seth.f
2014 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
2015 f_hi16
= EXTRACT_MSB0_UINT (insn
, 32, 16, 16);
2017 /* Record the fields for the semantic handler. */
2018 FLD (f_hi16
) = f_hi16
;
2020 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
2021 CGEN_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));
2023 #if WITH_PROFILE_MODEL_P
2024 /* Record the fields for profiling. */
2025 if (PROFILE_MODEL_P (current_cpu
))
2027 FLD (out_dr
) = f_r1
;
2036 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2037 CGEN_INSN_WORD insn
= entire_insn
;
2038 #define FLD(f) abuf->fields.sfmt_add3.f
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_SINT (insn
, 32, 16, 16);
2047 /* Record the fields for the semantic handler. */
2048 FLD (f_simm16
) = f_simm16
;
2051 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
2052 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
2053 CGEN_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));
2055 #if WITH_PROFILE_MODEL_P
2056 /* Record the fields for profiling. */
2057 if (PROFILE_MODEL_P (current_cpu
))
2060 FLD (out_dr
) = f_r1
;
2069 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2070 CGEN_INSN_WORD insn
= entire_insn
;
2071 #define FLD(f) abuf->fields.sfmt_slli.f
2075 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2076 f_uimm5
= EXTRACT_MSB0_UINT (insn
, 16, 11, 5);
2078 /* Record the fields for the semantic handler. */
2080 FLD (f_uimm5
) = f_uimm5
;
2081 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
2082 CGEN_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));
2084 #if WITH_PROFILE_MODEL_P
2085 /* Record the fields for profiling. */
2086 if (PROFILE_MODEL_P (current_cpu
))
2089 FLD (out_dr
) = f_r1
;
2098 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2099 CGEN_INSN_WORD insn
= entire_insn
;
2100 #define FLD(f) abuf->fields.sfmt_st_plus.f
2104 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2105 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2107 /* Record the fields for the semantic handler. */
2110 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2111 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2112 CGEN_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));
2114 #if WITH_PROFILE_MODEL_P
2115 /* Record the fields for profiling. */
2116 if (PROFILE_MODEL_P (current_cpu
))
2118 FLD (in_src1
) = f_r1
;
2119 FLD (in_src2
) = f_r2
;
2128 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2129 CGEN_INSN_WORD insn
= entire_insn
;
2130 #define FLD(f) abuf->fields.sfmt_st_d.f
2135 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
2136 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
2137 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
2139 /* Record the fields for the semantic handler. */
2140 FLD (f_simm16
) = f_simm16
;
2143 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2144 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2145 CGEN_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));
2147 #if WITH_PROFILE_MODEL_P
2148 /* Record the fields for profiling. */
2149 if (PROFILE_MODEL_P (current_cpu
))
2151 FLD (in_src1
) = f_r1
;
2152 FLD (in_src2
) = f_r2
;
2161 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2162 CGEN_INSN_WORD insn
= entire_insn
;
2163 #define FLD(f) abuf->fields.sfmt_st_plus.f
2167 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2168 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2170 /* Record the fields for the semantic handler. */
2173 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2174 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2175 CGEN_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));
2177 #if WITH_PROFILE_MODEL_P
2178 /* Record the fields for profiling. */
2179 if (PROFILE_MODEL_P (current_cpu
))
2181 FLD (in_src1
) = f_r1
;
2182 FLD (in_src2
) = f_r2
;
2191 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2192 CGEN_INSN_WORD insn
= entire_insn
;
2193 #define FLD(f) abuf->fields.sfmt_st_d.f
2198 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
2199 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
2200 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
2202 /* Record the fields for the semantic handler. */
2203 FLD (f_simm16
) = f_simm16
;
2206 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2207 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2208 CGEN_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));
2210 #if WITH_PROFILE_MODEL_P
2211 /* Record the fields for profiling. */
2212 if (PROFILE_MODEL_P (current_cpu
))
2214 FLD (in_src1
) = f_r1
;
2215 FLD (in_src2
) = f_r2
;
2224 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2225 CGEN_INSN_WORD insn
= entire_insn
;
2226 #define FLD(f) abuf->fields.sfmt_st_plus.f
2230 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2231 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2233 /* Record the fields for the semantic handler. */
2236 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2237 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2238 CGEN_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));
2240 #if WITH_PROFILE_MODEL_P
2241 /* Record the fields for profiling. */
2242 if (PROFILE_MODEL_P (current_cpu
))
2244 FLD (in_src1
) = f_r1
;
2245 FLD (in_src2
) = f_r2
;
2254 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2255 CGEN_INSN_WORD insn
= entire_insn
;
2256 #define FLD(f) abuf->fields.sfmt_st_d.f
2261 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
2262 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
2263 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
2265 /* Record the fields for the semantic handler. */
2266 FLD (f_simm16
) = f_simm16
;
2269 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2270 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2271 CGEN_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));
2273 #if WITH_PROFILE_MODEL_P
2274 /* Record the fields for profiling. */
2275 if (PROFILE_MODEL_P (current_cpu
))
2277 FLD (in_src1
) = f_r1
;
2278 FLD (in_src2
) = f_r2
;
2285 extract_sfmt_st_plus
:
2287 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2288 CGEN_INSN_WORD insn
= entire_insn
;
2289 #define FLD(f) abuf->fields.sfmt_st_plus.f
2293 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2294 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2296 /* Record the fields for the semantic handler. */
2299 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2300 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2301 CGEN_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));
2303 #if WITH_PROFILE_MODEL_P
2304 /* Record the fields for profiling. */
2305 if (PROFILE_MODEL_P (current_cpu
))
2307 FLD (in_src1
) = f_r1
;
2308 FLD (in_src2
) = f_r2
;
2309 FLD (out_src2
) = f_r2
;
2316 extract_sfmt_sth_plus
:
2318 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2319 CGEN_INSN_WORD insn
= entire_insn
;
2320 #define FLD(f) abuf->fields.sfmt_st_plus.f
2324 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2325 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2327 /* Record the fields for the semantic handler. */
2330 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2331 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2332 CGEN_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));
2334 #if WITH_PROFILE_MODEL_P
2335 /* Record the fields for profiling. */
2336 if (PROFILE_MODEL_P (current_cpu
))
2338 FLD (in_src1
) = f_r1
;
2339 FLD (in_src2
) = f_r2
;
2340 FLD (out_src2
) = f_r2
;
2347 extract_sfmt_stb_plus
:
2349 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2350 CGEN_INSN_WORD insn
= entire_insn
;
2351 #define FLD(f) abuf->fields.sfmt_st_plus.f
2355 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2356 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2358 /* Record the fields for the semantic handler. */
2361 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2362 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2363 CGEN_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));
2365 #if WITH_PROFILE_MODEL_P
2366 /* Record the fields for profiling. */
2367 if (PROFILE_MODEL_P (current_cpu
))
2369 FLD (in_src1
) = f_r1
;
2370 FLD (in_src2
) = f_r2
;
2371 FLD (out_src2
) = f_r2
;
2380 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2381 CGEN_INSN_WORD insn
= entire_insn
;
2382 #define FLD(f) abuf->fields.sfmt_trap.f
2385 f_uimm4
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2387 /* Record the fields for the semantic handler. */
2388 FLD (f_uimm4
) = f_uimm4
;
2389 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_trap", "f_uimm4 0x%x", 'x', f_uimm4
, (char *) 0));
2391 #if WITH_PROFILE_MODEL_P
2392 /* Record the fields for profiling. */
2393 if (PROFILE_MODEL_P (current_cpu
))
2401 extract_sfmt_unlock
:
2403 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2404 CGEN_INSN_WORD insn
= entire_insn
;
2405 #define FLD(f) abuf->fields.sfmt_st_plus.f
2409 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2410 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2412 /* Record the fields for the semantic handler. */
2415 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2416 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2417 CGEN_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));
2419 #if WITH_PROFILE_MODEL_P
2420 /* Record the fields for profiling. */
2421 if (PROFILE_MODEL_P (current_cpu
))
2423 FLD (in_src1
) = f_r1
;
2424 FLD (in_src2
) = f_r2
;
2433 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2434 CGEN_INSN_WORD insn
= entire_insn
;
2435 #define FLD(f) abuf->fields.sfmt_ld_plus.f
2439 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
2440 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
2442 /* Record the fields for the semantic handler. */
2445 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
2446 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
2447 CGEN_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));
2449 #if WITH_PROFILE_MODEL_P
2450 /* Record the fields for profiling. */
2451 if (PROFILE_MODEL_P (current_cpu
))
2454 FLD (out_dr
) = f_r1
;
2463 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2464 CGEN_INSN_WORD insn
= entire_insn
;
2465 #define FLD(f) abuf->fields.sfmt_ld_plus.f
2469 f_r1
= EXTRACT_MSB0_UINT (insn
, 32, 4, 4);
2470 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
2472 /* Record the fields for the semantic handler. */
2475 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
2476 FLD (i_dr
) = & CPU (h_gr
)[f_r1
];
2477 CGEN_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));
2479 #if WITH_PROFILE_MODEL_P
2480 /* Record the fields for profiling. */
2481 if (PROFILE_MODEL_P (current_cpu
))
2484 FLD (out_dr
) = f_r1
;
2493 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2494 #define FLD(f) abuf->fields.sfmt_empty.f
2497 /* Record the fields for the semantic handler. */
2498 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_sadd", (char *) 0));
2504 extract_sfmt_macwu1
:
2506 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2507 CGEN_INSN_WORD insn
= entire_insn
;
2508 #define FLD(f) abuf->fields.sfmt_st_plus.f
2512 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2513 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2515 /* Record the fields for the semantic handler. */
2518 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2519 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2520 CGEN_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));
2522 #if WITH_PROFILE_MODEL_P
2523 /* Record the fields for profiling. */
2524 if (PROFILE_MODEL_P (current_cpu
))
2526 FLD (in_src1
) = f_r1
;
2527 FLD (in_src2
) = f_r2
;
2536 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2537 CGEN_INSN_WORD insn
= entire_insn
;
2538 #define FLD(f) abuf->fields.sfmt_st_plus.f
2542 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2543 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2545 /* Record the fields for the semantic handler. */
2548 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2549 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2550 CGEN_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));
2552 #if WITH_PROFILE_MODEL_P
2553 /* Record the fields for profiling. */
2554 if (PROFILE_MODEL_P (current_cpu
))
2556 FLD (in_src1
) = f_r1
;
2557 FLD (in_src2
) = f_r2
;
2564 extract_sfmt_mulwu1
:
2566 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2567 CGEN_INSN_WORD insn
= entire_insn
;
2568 #define FLD(f) abuf->fields.sfmt_st_plus.f
2572 f_r1
= EXTRACT_MSB0_UINT (insn
, 16, 4, 4);
2573 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2575 /* Record the fields for the semantic handler. */
2578 FLD (i_src1
) = & CPU (h_gr
)[f_r1
];
2579 FLD (i_src2
) = & CPU (h_gr
)[f_r2
];
2580 CGEN_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));
2582 #if WITH_PROFILE_MODEL_P
2583 /* Record the fields for profiling. */
2584 if (PROFILE_MODEL_P (current_cpu
))
2586 FLD (in_src1
) = f_r1
;
2587 FLD (in_src2
) = f_r2
;
2596 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2597 #define FLD(f) abuf->fields.sfmt_empty.f
2600 /* Record the fields for the semantic handler. */
2601 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_sc", (char *) 0));
2607 extract_sfmt_clrpsw
:
2609 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2610 CGEN_INSN_WORD insn
= entire_insn
;
2611 #define FLD(f) abuf->fields.sfmt_clrpsw.f
2614 f_uimm8
= EXTRACT_MSB0_UINT (insn
, 16, 8, 8);
2616 /* Record the fields for the semantic handler. */
2617 FLD (f_uimm8
) = f_uimm8
;
2618 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_clrpsw", "f_uimm8 0x%x", 'x', f_uimm8
, (char *) 0));
2624 extract_sfmt_setpsw
:
2626 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2627 CGEN_INSN_WORD insn
= entire_insn
;
2628 #define FLD(f) abuf->fields.sfmt_clrpsw.f
2631 f_uimm8
= EXTRACT_MSB0_UINT (insn
, 16, 8, 8);
2633 /* Record the fields for the semantic handler. */
2634 FLD (f_uimm8
) = f_uimm8
;
2635 CGEN_TRACE_EXTRACT (current_cpu
, abuf
, (current_cpu
, pc
, "sfmt_setpsw", "f_uimm8 0x%x", 'x', f_uimm8
, (char *) 0));
2643 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2644 CGEN_INSN_WORD insn
= entire_insn
;
2645 #define FLD(f) abuf->fields.sfmt_bset.f
2650 f_uimm3
= EXTRACT_MSB0_UINT (insn
, 32, 5, 3);
2651 f_r2
= EXTRACT_MSB0_UINT (insn
, 32, 12, 4);
2652 f_simm16
= EXTRACT_MSB0_SINT (insn
, 32, 16, 16);
2654 /* Record the fields for the semantic handler. */
2655 FLD (f_simm16
) = f_simm16
;
2657 FLD (f_uimm3
) = f_uimm3
;
2658 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
2659 CGEN_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));
2661 #if WITH_PROFILE_MODEL_P
2662 /* Record the fields for profiling. */
2663 if (PROFILE_MODEL_P (current_cpu
))
2674 const IDESC
*idesc
= &m32rxf_insn_data
[itype
];
2675 CGEN_INSN_WORD insn
= entire_insn
;
2676 #define FLD(f) abuf->fields.sfmt_bset.f
2680 f_uimm3
= EXTRACT_MSB0_UINT (insn
, 16, 5, 3);
2681 f_r2
= EXTRACT_MSB0_UINT (insn
, 16, 12, 4);
2683 /* Record the fields for the semantic handler. */
2685 FLD (f_uimm3
) = f_uimm3
;
2686 FLD (i_sr
) = & CPU (h_gr
)[f_r2
];
2687 CGEN_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));
2689 #if WITH_PROFILE_MODEL_P
2690 /* Record the fields for profiling. */
2691 if (PROFILE_MODEL_P (current_cpu
))