Commit | Line | Data |
---|---|---|
9d70630e DE |
1 | /* Simulator model support for m32r. |
2 | ||
e0bd6e18 DE |
3 | This file is machine generated with CGEN. |
4 | ||
9d70630e DE |
5 | Copyright (C) 1996, 1997, 1998 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 2, or (at your option) | |
12 | 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 along | |
20 | with this program; if not, write to the Free Software Foundation, Inc., | |
21 | 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | |
22 | ||
23 | */ | |
24 | ||
25 | #define WANT_CPU | |
26 | #define WANT_CPU_M32R | |
27 | ||
28 | #include "sim-main.h" | |
29 | #include "cpu-sim.h" | |
30 | #include "cpu-opc.h" | |
31 | ||
32 | /* The profiling data is recorded here, but is accessed via the profiling | |
33 | mechanism. After all, this is information for profiling. */ | |
34 | ||
35 | #if WITH_PROFILE_MODEL_P | |
36 | ||
37 | /* Track function unit usage for an instruction. */ | |
38 | ||
39 | void | |
e0bd6e18 | 40 | m32r_model_profile_insn (SIM_CPU *current_cpu, ARGBUF *abuf) |
9d70630e DE |
41 | { |
42 | const MODEL *model = CPU_MODEL (current_cpu); | |
43 | const INSN_TIMING *timing = MODEL_TIMING (model); | |
44 | const CGEN_INSN *insn = abuf->opcode; | |
45 | const UNIT *unit = &timing[CGEN_INSN_INDEX (insn)].units[0]; | |
46 | const UNIT *unit_end = unit + MAX_UNITS; | |
47 | PROFILE_DATA *profile = CPU_PROFILE_DATA (current_cpu); | |
48 | ||
49 | do | |
50 | { | |
51 | switch (unit->name) | |
52 | { | |
53 | case UNIT_M32R_D_U_STORE : | |
54 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
55 | m32r_model_mark_unbusy_reg (current_cpu, abuf); | |
56 | break; | |
57 | case UNIT_M32R_D_U_LOAD : | |
58 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
59 | m32r_model_mark_busy_reg (current_cpu, abuf); | |
60 | break; | |
61 | case UNIT_M32R_D_U_EXEC : | |
62 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
63 | m32r_model_mark_unbusy_reg (current_cpu, abuf); | |
64 | break; | |
65 | case UNIT_TEST_U_EXEC : | |
66 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
67 | break; | |
68 | } | |
69 | ++unit; | |
70 | } | |
71 | while (unit != unit_end && unit->name != UNIT_NONE); | |
72 | } | |
73 | ||
74 | /* Track function unit usage for an instruction. */ | |
75 | ||
76 | void | |
e0bd6e18 | 77 | m32r_model_profile_cti_insn (SIM_CPU *current_cpu, ARGBUF *abuf, int taken_p) |
9d70630e DE |
78 | { |
79 | const MODEL *model = CPU_MODEL (current_cpu); | |
80 | const INSN_TIMING *timing = MODEL_TIMING (model); | |
81 | const CGEN_INSN *insn = abuf->opcode; | |
82 | const UNIT *unit = &timing[CGEN_INSN_INDEX (insn)].units[0]; | |
83 | const UNIT *unit_end = unit + MAX_UNITS; | |
84 | PROFILE_DATA *profile = CPU_PROFILE_DATA (current_cpu); | |
85 | ||
86 | do | |
87 | { | |
88 | switch (unit->name) | |
89 | { | |
90 | case UNIT_M32R_D_U_STORE : | |
91 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
92 | m32r_model_mark_unbusy_reg (current_cpu, abuf); | |
93 | break; | |
94 | case UNIT_M32R_D_U_LOAD : | |
95 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
96 | m32r_model_mark_busy_reg (current_cpu, abuf); | |
97 | break; | |
98 | case UNIT_M32R_D_U_EXEC : | |
99 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
100 | if (taken_p) PROFILE_MODEL_CTI_STALL_COUNT (profile) += 2; | |
101 | m32r_model_mark_unbusy_reg (current_cpu, abuf); | |
102 | break; | |
103 | case UNIT_TEST_U_EXEC : | |
104 | PROFILE_MODEL_CYCLE_COUNT (profile) += unit->done; | |
105 | break; | |
106 | } | |
107 | if (taken_p) | |
108 | PROFILE_MODEL_TAKEN_COUNT (profile) += 1; | |
109 | else | |
110 | PROFILE_MODEL_UNTAKEN_COUNT (profile) += 1; | |
111 | ++unit; | |
112 | } | |
113 | while (unit != unit_end && unit->name != UNIT_NONE); | |
114 | } | |
115 | ||
116 | /* We assume UNIT_NONE == 0 because the tables don't always terminate | |
117 | entries with it. */ | |
118 | ||
119 | /* Model timing data for `m32r/d'. */ | |
120 | ||
121 | static const INSN_TIMING m32r_d_timing[] = { | |
122 | { { (UQI) UNIT_NONE } }, /* illegal insn */ | |
123 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* add */ | |
124 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* add3 */ | |
e0bd6e18 | 125 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* add3.a */ |
9d70630e DE |
126 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* and */ |
127 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* and3 */ | |
e0bd6e18 | 128 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* and3.a */ |
9d70630e DE |
129 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* or */ |
130 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* or3 */ | |
e0bd6e18 | 131 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* or3.a */ |
9d70630e DE |
132 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* xor */ |
133 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* xor3 */ | |
e0bd6e18 | 134 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* xor3.a */ |
9d70630e | 135 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* addi */ |
e0bd6e18 | 136 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* addi.a */ |
9d70630e DE |
137 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* addv */ |
138 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* addv3 */ | |
e0bd6e18 | 139 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* addv3.a */ |
9d70630e DE |
140 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* addx */ |
141 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bc8 */ | |
142 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bc8.s */ | |
143 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bc24 */ | |
144 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bc24.l */ | |
145 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* beq */ | |
146 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* beqz */ | |
147 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bgez */ | |
148 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bgtz */ | |
149 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* blez */ | |
150 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bltz */ | |
151 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bnez */ | |
152 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bl8 */ | |
153 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bl8.s */ | |
154 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bl24 */ | |
155 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bl24.l */ | |
156 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bnc8 */ | |
157 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bnc8.s */ | |
158 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bnc24 */ | |
159 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bnc24.l */ | |
160 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bne */ | |
161 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bra8 */ | |
162 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bra8.s */ | |
163 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bra24 */ | |
164 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* bra24.l */ | |
165 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* cmp */ | |
166 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* cmpi */ | |
e0bd6e18 | 167 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* cmpi.a */ |
9d70630e DE |
168 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* cmpu */ |
169 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* cmpui */ | |
e0bd6e18 | 170 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* cmpui.a */ |
9d70630e | 171 | { { (UQI) UNIT_M32R_D_U_EXEC, 37, 37 } }, /* div */ |
e0bd6e18 | 172 | { { (UQI) UNIT_M32R_D_U_EXEC, 27, 27 } }, /* divu */ |
9d70630e | 173 | { { (UQI) UNIT_M32R_D_U_EXEC, 37, 37 } }, /* rem */ |
e0bd6e18 DE |
174 | { { (UQI) UNIT_M32R_D_U_EXEC, 27, 27 } }, /* remu */ |
175 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* divh */ | |
9d70630e DE |
176 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* jl */ |
177 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* jmp */ | |
178 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ld */ | |
179 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ld-2 */ | |
e0bd6e18 DE |
180 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ld-d */ |
181 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ld-d2 */ | |
9d70630e DE |
182 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ldb */ |
183 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ldb-2 */ | |
e0bd6e18 DE |
184 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ldb-d */ |
185 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ldb-d2 */ | |
9d70630e DE |
186 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ldh */ |
187 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ldh-2 */ | |
e0bd6e18 DE |
188 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ldh-d */ |
189 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ldh-d2 */ | |
9d70630e DE |
190 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ldub */ |
191 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ldub-2 */ | |
e0bd6e18 DE |
192 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ldub-d */ |
193 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* ldub-d2 */ | |
9d70630e DE |
194 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* lduh */ |
195 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* lduh-2 */ | |
e0bd6e18 DE |
196 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* lduh-d */ |
197 | { { (UQI) UNIT_M32R_D_U_LOAD, 2, 2 } }, /* lduh-d2 */ | |
9d70630e DE |
198 | { { (UQI) UNIT_M32R_D_U_LOAD, 1, 1 } }, /* ld-plus */ |
199 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ld24 */ | |
e0bd6e18 | 200 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ld24.a */ |
9d70630e | 201 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ldi8 */ |
e0bd6e18 | 202 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ldi8.a */ |
9d70630e | 203 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ldi8a */ |
e0bd6e18 | 204 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ldi8a.a */ |
9d70630e DE |
205 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ldi16 */ |
206 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* ldi16a */ | |
207 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* lock */ | |
208 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* machi */ | |
209 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* maclo */ | |
210 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* macwhi */ | |
211 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* macwlo */ | |
e0bd6e18 | 212 | { { (UQI) UNIT_M32R_D_U_EXEC, 4, 4 } }, /* mul */ |
9d70630e DE |
213 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mulhi */ |
214 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mullo */ | |
215 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mulwhi */ | |
216 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mulwlo */ | |
217 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mv */ | |
218 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mvfachi */ | |
219 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mvfaclo */ | |
220 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mvfacmi */ | |
221 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mvfc */ | |
222 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mvtachi */ | |
223 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mvtaclo */ | |
224 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* mvtc */ | |
225 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* neg */ | |
226 | { { (UQI) UNIT_M32R_D_U_EXEC, 0, 0 } }, /* nop */ | |
227 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* not */ | |
228 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* rac */ | |
229 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* rach */ | |
230 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* rte */ | |
231 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* seth */ | |
e0bd6e18 | 232 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* seth.a */ |
9d70630e DE |
233 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* sll */ |
234 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* sll3 */ | |
e0bd6e18 | 235 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* sll3.a */ |
9d70630e | 236 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* slli */ |
e0bd6e18 | 237 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* slli.a */ |
9d70630e DE |
238 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* sra */ |
239 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* sra3 */ | |
e0bd6e18 | 240 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* sra3.a */ |
9d70630e | 241 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* srai */ |
e0bd6e18 | 242 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* srai.a */ |
9d70630e DE |
243 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* srl */ |
244 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* srl3 */ | |
e0bd6e18 | 245 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* srl3.a */ |
9d70630e | 246 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* srli */ |
e0bd6e18 | 247 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* srli.a */ |
9d70630e DE |
248 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* st */ |
249 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* st-2 */ | |
e0bd6e18 DE |
250 | { { (UQI) UNIT_M32R_D_U_STORE, 2, 2 } }, /* st-d */ |
251 | { { (UQI) UNIT_M32R_D_U_STORE, 2, 2 } }, /* st-d2 */ | |
9d70630e DE |
252 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* stb */ |
253 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* stb-2 */ | |
e0bd6e18 DE |
254 | { { (UQI) UNIT_M32R_D_U_STORE, 2, 2 } }, /* stb-d */ |
255 | { { (UQI) UNIT_M32R_D_U_STORE, 2, 2 } }, /* stb-d2 */ | |
9d70630e DE |
256 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* sth */ |
257 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* sth-2 */ | |
e0bd6e18 DE |
258 | { { (UQI) UNIT_M32R_D_U_STORE, 2, 2 } }, /* sth-d */ |
259 | { { (UQI) UNIT_M32R_D_U_STORE, 2, 2 } }, /* sth-d2 */ | |
9d70630e DE |
260 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* st-plus */ |
261 | { { (UQI) UNIT_M32R_D_U_STORE, 1, 1 } }, /* st-minus */ | |
262 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* sub */ | |
263 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* subv */ | |
264 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* subx */ | |
265 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* trap */ | |
e0bd6e18 | 266 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* trap.a */ |
9d70630e DE |
267 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* unlock */ |
268 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* push */ | |
269 | { { (UQI) UNIT_M32R_D_U_EXEC, 1, 1 } }, /* pop */ | |
270 | }; | |
271 | ||
272 | /* Model timing data for `test'. */ | |
273 | ||
274 | static const INSN_TIMING test_timing[] = { | |
275 | { { (UQI) UNIT_NONE } }, /* illegal insn */ | |
276 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* add */ | |
277 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* add3 */ | |
e0bd6e18 | 278 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* add3.a */ |
9d70630e DE |
279 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* and */ |
280 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* and3 */ | |
e0bd6e18 | 281 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* and3.a */ |
9d70630e DE |
282 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* or */ |
283 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* or3 */ | |
e0bd6e18 | 284 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* or3.a */ |
9d70630e DE |
285 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* xor */ |
286 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* xor3 */ | |
e0bd6e18 | 287 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* xor3.a */ |
9d70630e | 288 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* addi */ |
e0bd6e18 | 289 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* addi.a */ |
9d70630e DE |
290 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* addv */ |
291 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* addv3 */ | |
e0bd6e18 | 292 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* addv3.a */ |
9d70630e DE |
293 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* addx */ |
294 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bc8 */ | |
295 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bc8.s */ | |
296 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bc24 */ | |
297 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bc24.l */ | |
298 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* beq */ | |
299 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* beqz */ | |
300 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bgez */ | |
301 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bgtz */ | |
302 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* blez */ | |
303 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bltz */ | |
304 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bnez */ | |
305 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bl8 */ | |
306 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bl8.s */ | |
307 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bl24 */ | |
308 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bl24.l */ | |
309 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bnc8 */ | |
310 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bnc8.s */ | |
311 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bnc24 */ | |
312 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bnc24.l */ | |
313 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bne */ | |
314 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bra8 */ | |
315 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bra8.s */ | |
316 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bra24 */ | |
317 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* bra24.l */ | |
318 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* cmp */ | |
319 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* cmpi */ | |
e0bd6e18 | 320 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* cmpi.a */ |
9d70630e DE |
321 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* cmpu */ |
322 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* cmpui */ | |
e0bd6e18 | 323 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* cmpui.a */ |
9d70630e DE |
324 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* div */ |
325 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* divu */ | |
326 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* rem */ | |
327 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* remu */ | |
e0bd6e18 | 328 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* divh */ |
9d70630e DE |
329 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* jl */ |
330 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* jmp */ | |
331 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ld */ | |
332 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ld-2 */ | |
333 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ld-d */ | |
334 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ld-d2 */ | |
335 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldb */ | |
336 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldb-2 */ | |
337 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldb-d */ | |
338 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldb-d2 */ | |
339 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldh */ | |
340 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldh-2 */ | |
341 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldh-d */ | |
342 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldh-d2 */ | |
343 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldub */ | |
344 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldub-2 */ | |
345 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldub-d */ | |
346 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldub-d2 */ | |
347 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* lduh */ | |
348 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* lduh-2 */ | |
349 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* lduh-d */ | |
350 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* lduh-d2 */ | |
351 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ld-plus */ | |
352 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ld24 */ | |
e0bd6e18 | 353 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ld24.a */ |
9d70630e | 354 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldi8 */ |
e0bd6e18 | 355 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldi8.a */ |
9d70630e | 356 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldi8a */ |
e0bd6e18 | 357 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldi8a.a */ |
9d70630e DE |
358 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldi16 */ |
359 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* ldi16a */ | |
360 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* lock */ | |
361 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* machi */ | |
362 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* maclo */ | |
363 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* macwhi */ | |
364 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* macwlo */ | |
365 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mul */ | |
366 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mulhi */ | |
367 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mullo */ | |
368 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mulwhi */ | |
369 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mulwlo */ | |
370 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mv */ | |
371 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mvfachi */ | |
372 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mvfaclo */ | |
373 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mvfacmi */ | |
374 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mvfc */ | |
375 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mvtachi */ | |
376 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mvtaclo */ | |
377 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* mvtc */ | |
378 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* neg */ | |
379 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* nop */ | |
380 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* not */ | |
381 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* rac */ | |
382 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* rach */ | |
383 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* rte */ | |
384 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* seth */ | |
e0bd6e18 | 385 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* seth.a */ |
9d70630e DE |
386 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sll */ |
387 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sll3 */ | |
e0bd6e18 | 388 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sll3.a */ |
9d70630e | 389 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* slli */ |
e0bd6e18 | 390 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* slli.a */ |
9d70630e DE |
391 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sra */ |
392 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sra3 */ | |
e0bd6e18 | 393 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sra3.a */ |
9d70630e | 394 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* srai */ |
e0bd6e18 | 395 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* srai.a */ |
9d70630e DE |
396 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* srl */ |
397 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* srl3 */ | |
e0bd6e18 | 398 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* srl3.a */ |
9d70630e | 399 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* srli */ |
e0bd6e18 | 400 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* srli.a */ |
9d70630e DE |
401 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* st */ |
402 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* st-2 */ | |
403 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* st-d */ | |
404 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* st-d2 */ | |
405 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* stb */ | |
406 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* stb-2 */ | |
407 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* stb-d */ | |
408 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* stb-d2 */ | |
409 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sth */ | |
410 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sth-2 */ | |
411 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sth-d */ | |
412 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sth-d2 */ | |
413 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* st-plus */ | |
414 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* st-minus */ | |
415 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* sub */ | |
416 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* subv */ | |
417 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* subx */ | |
418 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* trap */ | |
e0bd6e18 | 419 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* trap.a */ |
9d70630e DE |
420 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* unlock */ |
421 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* push */ | |
422 | { { (UQI) UNIT_TEST_U_EXEC, 1, 1 } }, /* pop */ | |
423 | }; | |
424 | ||
425 | #endif /* WITH_PROFILE_MODEL_P */ | |
426 | ||
427 | #if WITH_PROFILE_MODEL_P | |
428 | #define TIMING_DATA(td) td | |
429 | #else | |
430 | #define TIMING_DATA(td) 0 | |
431 | #endif | |
432 | ||
433 | const MODEL m32r_models[] = { | |
434 | { "m32r/d", &machs[MACH_M32R], TIMING_DATA (& m32r_d_timing[0]) }, | |
435 | { "test", &machs[MACH_M32R], TIMING_DATA (& test_timing[0]) }, | |
436 | { 0 } | |
437 | }; | |
438 | ||
439 | /* The properties of this cpu's implementation. */ | |
440 | ||
441 | const IMP_PROPERTIES m32r_imp_properties = { | |
442 | sizeof (SIM_CPU) | |
443 | #if WITH_SCACHE | |
444 | , sizeof (SCACHE) | |
445 | #endif | |
446 | }; | |
447 |