Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ 8ca3f6c3

History | View | Annotate | Download (254.2 kB)

1 3fc6c082 bellard
/*
2 3fc6c082 bellard
 *  PowerPC CPU initialization for qemu.
3 5fafdf24 ths
 *
4 76a66253 j_mayer
 *  Copyright (c) 2003-2007 Jocelyn Mayer
5 3fc6c082 bellard
 *
6 3fc6c082 bellard
 * This library is free software; you can redistribute it and/or
7 3fc6c082 bellard
 * modify it under the terms of the GNU Lesser General Public
8 3fc6c082 bellard
 * License as published by the Free Software Foundation; either
9 3fc6c082 bellard
 * version 2 of the License, or (at your option) any later version.
10 3fc6c082 bellard
 *
11 3fc6c082 bellard
 * This library is distributed in the hope that it will be useful,
12 3fc6c082 bellard
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 3fc6c082 bellard
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 3fc6c082 bellard
 * Lesser General Public License for more details.
15 3fc6c082 bellard
 *
16 3fc6c082 bellard
 * You should have received a copy of the GNU Lesser General Public
17 3fc6c082 bellard
 * License along with this library; if not, write to the Free Software
18 3fc6c082 bellard
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19 3fc6c082 bellard
 */
20 3fc6c082 bellard
21 3fc6c082 bellard
/* A lot of PowerPC definition have been included here.
22 3fc6c082 bellard
 * Most of them are not usable for now but have been kept
23 3fc6c082 bellard
 * inside "#if defined(TODO) ... #endif" statements to make tests easier.
24 3fc6c082 bellard
 */
25 3fc6c082 bellard
26 237c0af0 j_mayer
#include "dis-asm.h"
27 237c0af0 j_mayer
28 3fc6c082 bellard
//#define PPC_DUMP_CPU
29 3fc6c082 bellard
//#define PPC_DEBUG_SPR
30 a496775f j_mayer
//#define PPC_DEBUG_IRQ
31 3fc6c082 bellard
32 3fc6c082 bellard
struct ppc_def_t {
33 3fc6c082 bellard
    const unsigned char *name;
34 3fc6c082 bellard
    uint32_t pvr;
35 3fc6c082 bellard
    uint32_t pvr_mask;
36 0487d6a8 j_mayer
    uint64_t insns_flags;
37 3fc6c082 bellard
    uint64_t msr_mask;
38 a750fc0b j_mayer
    uint8_t mmu_model;
39 a750fc0b j_mayer
    uint8_t excp_model;
40 a750fc0b j_mayer
    uint8_t bus_model;
41 a750fc0b j_mayer
    uint8_t pad;
42 d26bfc9a j_mayer
    uint32_t flags;
43 237c0af0 j_mayer
    int bfd_mach;
44 a750fc0b j_mayer
    void (*init_proc)(CPUPPCState *env);
45 3fc6c082 bellard
};
46 3fc6c082 bellard
47 e9df014c j_mayer
/* For user-mode emulation, we don't emulate any IRQ controller */
48 e9df014c j_mayer
#if defined(CONFIG_USER_ONLY)
49 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
50 a750fc0b j_mayer
static inline void glue(glue(ppc, name),_irq_init) (CPUPPCState *env)         \
51 a750fc0b j_mayer
{                                                                             \
52 e9df014c j_mayer
}
53 e9df014c j_mayer
#else
54 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
55 e9df014c j_mayer
void glue(glue(ppc, name),_irq_init) (CPUPPCState *env);
56 e9df014c j_mayer
#endif
57 a750fc0b j_mayer
58 4e290a0b j_mayer
PPC_IRQ_INIT_FN(40x);
59 e9df014c j_mayer
PPC_IRQ_INIT_FN(6xx);
60 d0dfae6e j_mayer
PPC_IRQ_INIT_FN(970);
61 e9df014c j_mayer
62 3fc6c082 bellard
/* Generic callbacks:
63 3fc6c082 bellard
 * do nothing but store/retrieve spr value
64 3fc6c082 bellard
 */
65 04f20795 j_mayer
#ifdef PPC_DUMP_SPR_ACCESSES
66 3fc6c082 bellard
static void spr_read_generic (void *opaque, int sprn)
67 3fc6c082 bellard
{
68 04f20795 j_mayer
    gen_op_load_dump_spr(sprn);
69 3fc6c082 bellard
}
70 3fc6c082 bellard
71 3fc6c082 bellard
static void spr_write_generic (void *opaque, int sprn)
72 3fc6c082 bellard
{
73 04f20795 j_mayer
    gen_op_store_dump_spr(sprn);
74 3fc6c082 bellard
}
75 04f20795 j_mayer
#else
76 04f20795 j_mayer
static void spr_read_generic (void *opaque, int sprn)
77 a496775f j_mayer
{
78 04f20795 j_mayer
    gen_op_load_spr(sprn);
79 a496775f j_mayer
}
80 a496775f j_mayer
81 04f20795 j_mayer
static void spr_write_generic (void *opaque, int sprn)
82 a496775f j_mayer
{
83 04f20795 j_mayer
    gen_op_store_spr(sprn);
84 a496775f j_mayer
}
85 04f20795 j_mayer
#endif
86 a496775f j_mayer
87 a496775f j_mayer
#if !defined(CONFIG_USER_ONLY)
88 a496775f j_mayer
static void spr_write_clear (void *opaque, int sprn)
89 a496775f j_mayer
{
90 a496775f j_mayer
    gen_op_mask_spr(sprn);
91 a496775f j_mayer
}
92 a496775f j_mayer
#endif
93 a496775f j_mayer
94 76a66253 j_mayer
/* SPR common to all PowerPC */
95 3fc6c082 bellard
/* XER */
96 3fc6c082 bellard
static void spr_read_xer (void *opaque, int sprn)
97 3fc6c082 bellard
{
98 3fc6c082 bellard
    gen_op_load_xer();
99 3fc6c082 bellard
}
100 3fc6c082 bellard
101 3fc6c082 bellard
static void spr_write_xer (void *opaque, int sprn)
102 3fc6c082 bellard
{
103 3fc6c082 bellard
    gen_op_store_xer();
104 3fc6c082 bellard
}
105 3fc6c082 bellard
106 3fc6c082 bellard
/* LR */
107 3fc6c082 bellard
static void spr_read_lr (void *opaque, int sprn)
108 3fc6c082 bellard
{
109 3fc6c082 bellard
    gen_op_load_lr();
110 3fc6c082 bellard
}
111 3fc6c082 bellard
112 3fc6c082 bellard
static void spr_write_lr (void *opaque, int sprn)
113 3fc6c082 bellard
{
114 3fc6c082 bellard
    gen_op_store_lr();
115 3fc6c082 bellard
}
116 3fc6c082 bellard
117 3fc6c082 bellard
/* CTR */
118 3fc6c082 bellard
static void spr_read_ctr (void *opaque, int sprn)
119 3fc6c082 bellard
{
120 3fc6c082 bellard
    gen_op_load_ctr();
121 3fc6c082 bellard
}
122 3fc6c082 bellard
123 3fc6c082 bellard
static void spr_write_ctr (void *opaque, int sprn)
124 3fc6c082 bellard
{
125 3fc6c082 bellard
    gen_op_store_ctr();
126 3fc6c082 bellard
}
127 3fc6c082 bellard
128 3fc6c082 bellard
/* User read access to SPR */
129 3fc6c082 bellard
/* USPRx */
130 3fc6c082 bellard
/* UMMCRx */
131 3fc6c082 bellard
/* UPMCx */
132 3fc6c082 bellard
/* USIA */
133 3fc6c082 bellard
/* UDECR */
134 3fc6c082 bellard
static void spr_read_ureg (void *opaque, int sprn)
135 3fc6c082 bellard
{
136 3fc6c082 bellard
    gen_op_load_spr(sprn + 0x10);
137 3fc6c082 bellard
}
138 3fc6c082 bellard
139 76a66253 j_mayer
/* SPR common to all non-embedded PowerPC */
140 3fc6c082 bellard
/* DECR */
141 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
142 3fc6c082 bellard
static void spr_read_decr (void *opaque, int sprn)
143 3fc6c082 bellard
{
144 3fc6c082 bellard
    gen_op_load_decr();
145 3fc6c082 bellard
}
146 3fc6c082 bellard
147 3fc6c082 bellard
static void spr_write_decr (void *opaque, int sprn)
148 3fc6c082 bellard
{
149 3fc6c082 bellard
    gen_op_store_decr();
150 3fc6c082 bellard
}
151 76a66253 j_mayer
#endif
152 3fc6c082 bellard
153 76a66253 j_mayer
/* SPR common to all non-embedded PowerPC, except 601 */
154 3fc6c082 bellard
/* Time base */
155 3fc6c082 bellard
static void spr_read_tbl (void *opaque, int sprn)
156 3fc6c082 bellard
{
157 3fc6c082 bellard
    gen_op_load_tbl();
158 3fc6c082 bellard
}
159 3fc6c082 bellard
160 76a66253 j_mayer
static void spr_read_tbu (void *opaque, int sprn)
161 3fc6c082 bellard
{
162 76a66253 j_mayer
    gen_op_load_tbu();
163 3fc6c082 bellard
}
164 3fc6c082 bellard
165 a062e36c j_mayer
__attribute__ (( unused ))
166 a062e36c j_mayer
static void spr_read_atbl (void *opaque, int sprn)
167 a062e36c j_mayer
{
168 a062e36c j_mayer
    gen_op_load_atbl();
169 a062e36c j_mayer
}
170 a062e36c j_mayer
171 a062e36c j_mayer
__attribute__ (( unused ))
172 a062e36c j_mayer
static void spr_read_atbu (void *opaque, int sprn)
173 a062e36c j_mayer
{
174 a062e36c j_mayer
    gen_op_load_atbu();
175 a062e36c j_mayer
}
176 a062e36c j_mayer
177 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
178 76a66253 j_mayer
static void spr_write_tbl (void *opaque, int sprn)
179 3fc6c082 bellard
{
180 76a66253 j_mayer
    gen_op_store_tbl();
181 3fc6c082 bellard
}
182 3fc6c082 bellard
183 3fc6c082 bellard
static void spr_write_tbu (void *opaque, int sprn)
184 3fc6c082 bellard
{
185 3fc6c082 bellard
    gen_op_store_tbu();
186 3fc6c082 bellard
}
187 a062e36c j_mayer
188 a062e36c j_mayer
__attribute__ (( unused ))
189 a062e36c j_mayer
static void spr_write_atbl (void *opaque, int sprn)
190 a062e36c j_mayer
{
191 a062e36c j_mayer
    gen_op_store_atbl();
192 a062e36c j_mayer
}
193 a062e36c j_mayer
194 a062e36c j_mayer
__attribute__ (( unused ))
195 a062e36c j_mayer
static void spr_write_atbu (void *opaque, int sprn)
196 a062e36c j_mayer
{
197 a062e36c j_mayer
    gen_op_store_atbu();
198 a062e36c j_mayer
}
199 76a66253 j_mayer
#endif
200 3fc6c082 bellard
201 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
202 3fc6c082 bellard
/* IBAT0U...IBAT0U */
203 3fc6c082 bellard
/* IBAT0L...IBAT7L */
204 3fc6c082 bellard
static void spr_read_ibat (void *opaque, int sprn)
205 3fc6c082 bellard
{
206 3fc6c082 bellard
    gen_op_load_ibat(sprn & 1, (sprn - SPR_IBAT0U) / 2);
207 3fc6c082 bellard
}
208 3fc6c082 bellard
209 3fc6c082 bellard
static void spr_read_ibat_h (void *opaque, int sprn)
210 3fc6c082 bellard
{
211 3fc6c082 bellard
    gen_op_load_ibat(sprn & 1, (sprn - SPR_IBAT4U) / 2);
212 3fc6c082 bellard
}
213 3fc6c082 bellard
214 3fc6c082 bellard
static void spr_write_ibatu (void *opaque, int sprn)
215 3fc6c082 bellard
{
216 3fc6c082 bellard
    gen_op_store_ibatu((sprn - SPR_IBAT0U) / 2);
217 3fc6c082 bellard
}
218 3fc6c082 bellard
219 3fc6c082 bellard
static void spr_write_ibatu_h (void *opaque, int sprn)
220 3fc6c082 bellard
{
221 3fc6c082 bellard
    gen_op_store_ibatu((sprn - SPR_IBAT4U) / 2);
222 3fc6c082 bellard
}
223 3fc6c082 bellard
224 3fc6c082 bellard
static void spr_write_ibatl (void *opaque, int sprn)
225 3fc6c082 bellard
{
226 3fc6c082 bellard
    gen_op_store_ibatl((sprn - SPR_IBAT0L) / 2);
227 3fc6c082 bellard
}
228 3fc6c082 bellard
229 3fc6c082 bellard
static void spr_write_ibatl_h (void *opaque, int sprn)
230 3fc6c082 bellard
{
231 3fc6c082 bellard
    gen_op_store_ibatl((sprn - SPR_IBAT4L) / 2);
232 3fc6c082 bellard
}
233 3fc6c082 bellard
234 3fc6c082 bellard
/* DBAT0U...DBAT7U */
235 3fc6c082 bellard
/* DBAT0L...DBAT7L */
236 3fc6c082 bellard
static void spr_read_dbat (void *opaque, int sprn)
237 3fc6c082 bellard
{
238 3fc6c082 bellard
    gen_op_load_dbat(sprn & 1, (sprn - SPR_DBAT0U) / 2);
239 3fc6c082 bellard
}
240 3fc6c082 bellard
241 3fc6c082 bellard
static void spr_read_dbat_h (void *opaque, int sprn)
242 3fc6c082 bellard
{
243 3fc6c082 bellard
    gen_op_load_dbat(sprn & 1, (sprn - SPR_DBAT4U) / 2);
244 3fc6c082 bellard
}
245 3fc6c082 bellard
246 3fc6c082 bellard
static void spr_write_dbatu (void *opaque, int sprn)
247 3fc6c082 bellard
{
248 3fc6c082 bellard
    gen_op_store_dbatu((sprn - SPR_DBAT0U) / 2);
249 3fc6c082 bellard
}
250 3fc6c082 bellard
251 3fc6c082 bellard
static void spr_write_dbatu_h (void *opaque, int sprn)
252 3fc6c082 bellard
{
253 3fc6c082 bellard
    gen_op_store_dbatu((sprn - SPR_DBAT4U) / 2);
254 3fc6c082 bellard
}
255 3fc6c082 bellard
256 3fc6c082 bellard
static void spr_write_dbatl (void *opaque, int sprn)
257 3fc6c082 bellard
{
258 3fc6c082 bellard
    gen_op_store_dbatl((sprn - SPR_DBAT0L) / 2);
259 3fc6c082 bellard
}
260 3fc6c082 bellard
261 3fc6c082 bellard
static void spr_write_dbatl_h (void *opaque, int sprn)
262 3fc6c082 bellard
{
263 3fc6c082 bellard
    gen_op_store_dbatl((sprn - SPR_DBAT4L) / 2);
264 3fc6c082 bellard
}
265 3fc6c082 bellard
266 3fc6c082 bellard
/* SDR1 */
267 3fc6c082 bellard
static void spr_read_sdr1 (void *opaque, int sprn)
268 3fc6c082 bellard
{
269 3fc6c082 bellard
    gen_op_load_sdr1();
270 3fc6c082 bellard
}
271 3fc6c082 bellard
272 3fc6c082 bellard
static void spr_write_sdr1 (void *opaque, int sprn)
273 3fc6c082 bellard
{
274 3fc6c082 bellard
    gen_op_store_sdr1();
275 3fc6c082 bellard
}
276 3fc6c082 bellard
277 76a66253 j_mayer
/* 64 bits PowerPC specific SPRs */
278 76a66253 j_mayer
/* ASR */
279 578bb252 j_mayer
#if defined(TARGET_PPC64)
280 578bb252 j_mayer
__attribute__ (( unused ))
281 76a66253 j_mayer
static void spr_read_asr (void *opaque, int sprn)
282 76a66253 j_mayer
{
283 76a66253 j_mayer
    gen_op_load_asr();
284 76a66253 j_mayer
}
285 76a66253 j_mayer
286 578bb252 j_mayer
__attribute__ (( unused ))
287 76a66253 j_mayer
static void spr_write_asr (void *opaque, int sprn)
288 76a66253 j_mayer
{
289 76a66253 j_mayer
    gen_op_store_asr();
290 76a66253 j_mayer
}
291 76a66253 j_mayer
#endif
292 a750fc0b j_mayer
#endif
293 76a66253 j_mayer
294 76a66253 j_mayer
/* PowerPC 601 specific registers */
295 76a66253 j_mayer
/* RTC */
296 76a66253 j_mayer
static void spr_read_601_rtcl (void *opaque, int sprn)
297 76a66253 j_mayer
{
298 76a66253 j_mayer
    gen_op_load_601_rtcl();
299 76a66253 j_mayer
}
300 76a66253 j_mayer
301 76a66253 j_mayer
static void spr_read_601_rtcu (void *opaque, int sprn)
302 76a66253 j_mayer
{
303 76a66253 j_mayer
    gen_op_load_601_rtcu();
304 76a66253 j_mayer
}
305 76a66253 j_mayer
306 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
307 76a66253 j_mayer
static void spr_write_601_rtcu (void *opaque, int sprn)
308 76a66253 j_mayer
{
309 76a66253 j_mayer
    gen_op_store_601_rtcu();
310 76a66253 j_mayer
}
311 76a66253 j_mayer
312 76a66253 j_mayer
static void spr_write_601_rtcl (void *opaque, int sprn)
313 76a66253 j_mayer
{
314 76a66253 j_mayer
    gen_op_store_601_rtcl();
315 76a66253 j_mayer
}
316 76a66253 j_mayer
#endif
317 76a66253 j_mayer
318 76a66253 j_mayer
/* Unified bats */
319 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
320 76a66253 j_mayer
static void spr_read_601_ubat (void *opaque, int sprn)
321 76a66253 j_mayer
{
322 76a66253 j_mayer
    gen_op_load_601_bat(sprn & 1, (sprn - SPR_IBAT0U) / 2);
323 76a66253 j_mayer
}
324 76a66253 j_mayer
325 76a66253 j_mayer
static void spr_write_601_ubatu (void *opaque, int sprn)
326 76a66253 j_mayer
{
327 76a66253 j_mayer
    gen_op_store_601_batu((sprn - SPR_IBAT0U) / 2);
328 76a66253 j_mayer
}
329 76a66253 j_mayer
330 76a66253 j_mayer
static void spr_write_601_ubatl (void *opaque, int sprn)
331 76a66253 j_mayer
{
332 76a66253 j_mayer
    gen_op_store_601_batl((sprn - SPR_IBAT0L) / 2);
333 76a66253 j_mayer
}
334 76a66253 j_mayer
#endif
335 76a66253 j_mayer
336 76a66253 j_mayer
/* PowerPC 40x specific registers */
337 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
338 76a66253 j_mayer
static void spr_read_40x_pit (void *opaque, int sprn)
339 76a66253 j_mayer
{
340 76a66253 j_mayer
    gen_op_load_40x_pit();
341 76a66253 j_mayer
}
342 76a66253 j_mayer
343 76a66253 j_mayer
static void spr_write_40x_pit (void *opaque, int sprn)
344 76a66253 j_mayer
{
345 76a66253 j_mayer
    gen_op_store_40x_pit();
346 76a66253 j_mayer
}
347 76a66253 j_mayer
348 8ecc7913 j_mayer
static void spr_write_40x_dbcr0 (void *opaque, int sprn)
349 8ecc7913 j_mayer
{
350 8ecc7913 j_mayer
    DisasContext *ctx = opaque;
351 8ecc7913 j_mayer
352 8ecc7913 j_mayer
    gen_op_store_40x_dbcr0();
353 8ecc7913 j_mayer
    /* We must stop translation as we may have rebooted */
354 e1833e1f j_mayer
    GEN_STOP(ctx);
355 8ecc7913 j_mayer
}
356 8ecc7913 j_mayer
357 c294fc58 j_mayer
static void spr_write_40x_sler (void *opaque, int sprn)
358 c294fc58 j_mayer
{
359 c294fc58 j_mayer
    gen_op_store_40x_sler();
360 c294fc58 j_mayer
}
361 c294fc58 j_mayer
362 76a66253 j_mayer
static void spr_write_booke_tcr (void *opaque, int sprn)
363 76a66253 j_mayer
{
364 76a66253 j_mayer
    gen_op_store_booke_tcr();
365 76a66253 j_mayer
}
366 76a66253 j_mayer
367 76a66253 j_mayer
static void spr_write_booke_tsr (void *opaque, int sprn)
368 76a66253 j_mayer
{
369 76a66253 j_mayer
    gen_op_store_booke_tsr();
370 76a66253 j_mayer
}
371 76a66253 j_mayer
#endif
372 76a66253 j_mayer
373 76a66253 j_mayer
/* PowerPC 403 specific registers */
374 76a66253 j_mayer
/* PBL1 / PBU1 / PBL2 / PBU2 */
375 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
376 76a66253 j_mayer
static void spr_read_403_pbr (void *opaque, int sprn)
377 76a66253 j_mayer
{
378 76a66253 j_mayer
    gen_op_load_403_pb(sprn - SPR_403_PBL1);
379 76a66253 j_mayer
}
380 76a66253 j_mayer
381 76a66253 j_mayer
static void spr_write_403_pbr (void *opaque, int sprn)
382 76a66253 j_mayer
{
383 76a66253 j_mayer
    gen_op_store_403_pb(sprn - SPR_403_PBL1);
384 76a66253 j_mayer
}
385 76a66253 j_mayer
386 3fc6c082 bellard
static void spr_write_pir (void *opaque, int sprn)
387 3fc6c082 bellard
{
388 3fc6c082 bellard
    gen_op_store_pir();
389 3fc6c082 bellard
}
390 76a66253 j_mayer
#endif
391 3fc6c082 bellard
392 6f5d427d j_mayer
#if !defined(CONFIG_USER_ONLY)
393 6f5d427d j_mayer
/* Callback used to write the exception vector base */
394 6f5d427d j_mayer
static void spr_write_excp_prefix (void *opaque, int sprn)
395 6f5d427d j_mayer
{
396 6f5d427d j_mayer
    gen_op_store_excp_prefix();
397 6f5d427d j_mayer
    gen_op_store_spr(sprn);
398 6f5d427d j_mayer
}
399 6f5d427d j_mayer
400 6f5d427d j_mayer
static void spr_write_excp_vector (void *opaque, int sprn)
401 6f5d427d j_mayer
{
402 6f5d427d j_mayer
    DisasContext *ctx = opaque;
403 6f5d427d j_mayer
404 6f5d427d j_mayer
    if (sprn >= SPR_BOOKE_IVOR0 && sprn <= SPR_BOOKE_IVOR15) {
405 6f5d427d j_mayer
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR0);
406 6f5d427d j_mayer
        gen_op_store_spr(sprn);
407 6f5d427d j_mayer
    } else if (sprn >= SPR_BOOKE_IVOR32 && sprn <= SPR_BOOKE_IVOR37) {
408 6f5d427d j_mayer
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR32 + 32);
409 6f5d427d j_mayer
        gen_op_store_spr(sprn);
410 6f5d427d j_mayer
    } else {
411 6f5d427d j_mayer
        printf("Trying to write an unknown exception vector %d %03x\n",
412 6f5d427d j_mayer
               sprn, sprn);
413 6f5d427d j_mayer
        GEN_EXCP_PRIVREG(ctx);
414 6f5d427d j_mayer
    }
415 6f5d427d j_mayer
}
416 6f5d427d j_mayer
#endif
417 6f5d427d j_mayer
418 76a66253 j_mayer
#if defined(CONFIG_USER_ONLY)
419 76a66253 j_mayer
#define spr_register(env, num, name, uea_read, uea_write,                     \
420 76a66253 j_mayer
                     oea_read, oea_write, initial_value)                      \
421 76a66253 j_mayer
do {                                                                          \
422 76a66253 j_mayer
     _spr_register(env, num, name, uea_read, uea_write, initial_value);       \
423 76a66253 j_mayer
} while (0)
424 76a66253 j_mayer
static inline void _spr_register (CPUPPCState *env, int num,
425 76a66253 j_mayer
                                  const unsigned char *name,
426 76a66253 j_mayer
                                  void (*uea_read)(void *opaque, int sprn),
427 76a66253 j_mayer
                                  void (*uea_write)(void *opaque, int sprn),
428 76a66253 j_mayer
                                  target_ulong initial_value)
429 76a66253 j_mayer
#else
430 3fc6c082 bellard
static inline void spr_register (CPUPPCState *env, int num,
431 3fc6c082 bellard
                                 const unsigned char *name,
432 3fc6c082 bellard
                                 void (*uea_read)(void *opaque, int sprn),
433 3fc6c082 bellard
                                 void (*uea_write)(void *opaque, int sprn),
434 3fc6c082 bellard
                                 void (*oea_read)(void *opaque, int sprn),
435 3fc6c082 bellard
                                 void (*oea_write)(void *opaque, int sprn),
436 3fc6c082 bellard
                                 target_ulong initial_value)
437 76a66253 j_mayer
#endif
438 3fc6c082 bellard
{
439 3fc6c082 bellard
    ppc_spr_t *spr;
440 3fc6c082 bellard
441 3fc6c082 bellard
    spr = &env->spr_cb[num];
442 3fc6c082 bellard
    if (spr->name != NULL ||env-> spr[num] != 0x00000000 ||
443 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
444 76a66253 j_mayer
        spr->oea_read != NULL || spr->oea_write != NULL ||
445 76a66253 j_mayer
#endif
446 76a66253 j_mayer
        spr->uea_read != NULL || spr->uea_write != NULL) {
447 3fc6c082 bellard
        printf("Error: Trying to register SPR %d (%03x) twice !\n", num, num);
448 3fc6c082 bellard
        exit(1);
449 3fc6c082 bellard
    }
450 3fc6c082 bellard
#if defined(PPC_DEBUG_SPR)
451 1b9eb036 j_mayer
    printf("*** register spr %d (%03x) %s val " ADDRX "\n", num, num, name,
452 76a66253 j_mayer
           initial_value);
453 3fc6c082 bellard
#endif
454 3fc6c082 bellard
    spr->name = name;
455 3fc6c082 bellard
    spr->uea_read = uea_read;
456 3fc6c082 bellard
    spr->uea_write = uea_write;
457 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
458 3fc6c082 bellard
    spr->oea_read = oea_read;
459 3fc6c082 bellard
    spr->oea_write = oea_write;
460 76a66253 j_mayer
#endif
461 3fc6c082 bellard
    env->spr[num] = initial_value;
462 3fc6c082 bellard
}
463 3fc6c082 bellard
464 3fc6c082 bellard
/* Generic PowerPC SPRs */
465 3fc6c082 bellard
static void gen_spr_generic (CPUPPCState *env)
466 3fc6c082 bellard
{
467 3fc6c082 bellard
    /* Integer processing */
468 3fc6c082 bellard
    spr_register(env, SPR_XER, "XER",
469 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
470 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
471 3fc6c082 bellard
                 0x00000000);
472 3fc6c082 bellard
    /* Branch contol */
473 3fc6c082 bellard
    spr_register(env, SPR_LR, "LR",
474 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
475 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
476 3fc6c082 bellard
                 0x00000000);
477 3fc6c082 bellard
    spr_register(env, SPR_CTR, "CTR",
478 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
479 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
480 3fc6c082 bellard
                 0x00000000);
481 3fc6c082 bellard
    /* Interrupt processing */
482 3fc6c082 bellard
    spr_register(env, SPR_SRR0, "SRR0",
483 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
484 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
485 3fc6c082 bellard
                 0x00000000);
486 3fc6c082 bellard
    spr_register(env, SPR_SRR1, "SRR1",
487 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
488 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
489 3fc6c082 bellard
                 0x00000000);
490 3fc6c082 bellard
    /* Processor control */
491 3fc6c082 bellard
    spr_register(env, SPR_SPRG0, "SPRG0",
492 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
493 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
494 3fc6c082 bellard
                 0x00000000);
495 3fc6c082 bellard
    spr_register(env, SPR_SPRG1, "SPRG1",
496 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
497 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
498 3fc6c082 bellard
                 0x00000000);
499 3fc6c082 bellard
    spr_register(env, SPR_SPRG2, "SPRG2",
500 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
501 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
502 3fc6c082 bellard
                 0x00000000);
503 3fc6c082 bellard
    spr_register(env, SPR_SPRG3, "SPRG3",
504 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
505 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
506 3fc6c082 bellard
                 0x00000000);
507 3fc6c082 bellard
}
508 3fc6c082 bellard
509 3fc6c082 bellard
/* SPR common to all non-embedded PowerPC, including 601 */
510 3fc6c082 bellard
static void gen_spr_ne_601 (CPUPPCState *env)
511 3fc6c082 bellard
{
512 3fc6c082 bellard
    /* Exception processing */
513 3fc6c082 bellard
    spr_register(env, SPR_DSISR, "DSISR",
514 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
515 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
516 3fc6c082 bellard
                 0x00000000);
517 3fc6c082 bellard
    spr_register(env, SPR_DAR, "DAR",
518 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
519 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
520 3fc6c082 bellard
                 0x00000000);
521 3fc6c082 bellard
    /* Timer */
522 3fc6c082 bellard
    spr_register(env, SPR_DECR, "DECR",
523 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
524 3fc6c082 bellard
                 &spr_read_decr, &spr_write_decr,
525 3fc6c082 bellard
                 0x00000000);
526 3fc6c082 bellard
    /* Memory management */
527 3fc6c082 bellard
    spr_register(env, SPR_SDR1, "SDR1",
528 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
529 3fc6c082 bellard
                 &spr_read_sdr1, &spr_write_sdr1,
530 3fc6c082 bellard
                 0x00000000);
531 3fc6c082 bellard
}
532 3fc6c082 bellard
533 3fc6c082 bellard
/* BATs 0-3 */
534 3fc6c082 bellard
static void gen_low_BATs (CPUPPCState *env)
535 3fc6c082 bellard
{
536 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
537 3fc6c082 bellard
    spr_register(env, SPR_IBAT0U, "IBAT0U",
538 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
539 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
540 3fc6c082 bellard
                 0x00000000);
541 3fc6c082 bellard
    spr_register(env, SPR_IBAT0L, "IBAT0L",
542 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
543 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
544 3fc6c082 bellard
                 0x00000000);
545 3fc6c082 bellard
    spr_register(env, SPR_IBAT1U, "IBAT1U",
546 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
547 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
548 3fc6c082 bellard
                 0x00000000);
549 3fc6c082 bellard
    spr_register(env, SPR_IBAT1L, "IBAT1L",
550 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
551 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
552 3fc6c082 bellard
                 0x00000000);
553 3fc6c082 bellard
    spr_register(env, SPR_IBAT2U, "IBAT2U",
554 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
555 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
556 3fc6c082 bellard
                 0x00000000);
557 3fc6c082 bellard
    spr_register(env, SPR_IBAT2L, "IBAT2L",
558 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
559 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
560 3fc6c082 bellard
                 0x00000000);
561 3fc6c082 bellard
    spr_register(env, SPR_IBAT3U, "IBAT3U",
562 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
563 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
564 3fc6c082 bellard
                 0x00000000);
565 3fc6c082 bellard
    spr_register(env, SPR_IBAT3L, "IBAT3L",
566 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
567 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
568 3fc6c082 bellard
                 0x00000000);
569 3fc6c082 bellard
    spr_register(env, SPR_DBAT0U, "DBAT0U",
570 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
571 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
572 3fc6c082 bellard
                 0x00000000);
573 3fc6c082 bellard
    spr_register(env, SPR_DBAT0L, "DBAT0L",
574 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
575 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
576 3fc6c082 bellard
                 0x00000000);
577 3fc6c082 bellard
    spr_register(env, SPR_DBAT1U, "DBAT1U",
578 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
579 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
580 3fc6c082 bellard
                 0x00000000);
581 3fc6c082 bellard
    spr_register(env, SPR_DBAT1L, "DBAT1L",
582 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
583 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
584 3fc6c082 bellard
                 0x00000000);
585 3fc6c082 bellard
    spr_register(env, SPR_DBAT2U, "DBAT2U",
586 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
587 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
588 3fc6c082 bellard
                 0x00000000);
589 3fc6c082 bellard
    spr_register(env, SPR_DBAT2L, "DBAT2L",
590 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
591 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
592 3fc6c082 bellard
                 0x00000000);
593 3fc6c082 bellard
    spr_register(env, SPR_DBAT3U, "DBAT3U",
594 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
595 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
596 3fc6c082 bellard
                 0x00000000);
597 3fc6c082 bellard
    spr_register(env, SPR_DBAT3L, "DBAT3L",
598 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
599 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
600 3fc6c082 bellard
                 0x00000000);
601 a750fc0b j_mayer
    env->nb_BATs += 4;
602 f2e63a42 j_mayer
#endif
603 3fc6c082 bellard
}
604 3fc6c082 bellard
605 3fc6c082 bellard
/* BATs 4-7 */
606 3fc6c082 bellard
static void gen_high_BATs (CPUPPCState *env)
607 3fc6c082 bellard
{
608 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
609 3fc6c082 bellard
    spr_register(env, SPR_IBAT4U, "IBAT4U",
610 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
611 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
612 3fc6c082 bellard
                 0x00000000);
613 3fc6c082 bellard
    spr_register(env, SPR_IBAT4L, "IBAT4L",
614 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
615 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
616 3fc6c082 bellard
                 0x00000000);
617 3fc6c082 bellard
    spr_register(env, SPR_IBAT5U, "IBAT5U",
618 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
619 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
620 3fc6c082 bellard
                 0x00000000);
621 3fc6c082 bellard
    spr_register(env, SPR_IBAT5L, "IBAT5L",
622 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
623 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
624 3fc6c082 bellard
                 0x00000000);
625 3fc6c082 bellard
    spr_register(env, SPR_IBAT6U, "IBAT6U",
626 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
627 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
628 3fc6c082 bellard
                 0x00000000);
629 3fc6c082 bellard
    spr_register(env, SPR_IBAT6L, "IBAT6L",
630 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
631 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
632 3fc6c082 bellard
                 0x00000000);
633 3fc6c082 bellard
    spr_register(env, SPR_IBAT7U, "IBAT7U",
634 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
635 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
636 3fc6c082 bellard
                 0x00000000);
637 3fc6c082 bellard
    spr_register(env, SPR_IBAT7L, "IBAT7L",
638 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
639 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
640 3fc6c082 bellard
                 0x00000000);
641 3fc6c082 bellard
    spr_register(env, SPR_DBAT4U, "DBAT4U",
642 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
643 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
644 3fc6c082 bellard
                 0x00000000);
645 3fc6c082 bellard
    spr_register(env, SPR_DBAT4L, "DBAT4L",
646 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
647 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
648 3fc6c082 bellard
                 0x00000000);
649 3fc6c082 bellard
    spr_register(env, SPR_DBAT5U, "DBAT5U",
650 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
651 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
652 3fc6c082 bellard
                 0x00000000);
653 3fc6c082 bellard
    spr_register(env, SPR_DBAT5L, "DBAT5L",
654 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
655 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
656 3fc6c082 bellard
                 0x00000000);
657 3fc6c082 bellard
    spr_register(env, SPR_DBAT6U, "DBAT6U",
658 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
659 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
660 3fc6c082 bellard
                 0x00000000);
661 3fc6c082 bellard
    spr_register(env, SPR_DBAT6L, "DBAT6L",
662 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
663 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
664 3fc6c082 bellard
                 0x00000000);
665 3fc6c082 bellard
    spr_register(env, SPR_DBAT7U, "DBAT7U",
666 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
667 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
668 3fc6c082 bellard
                 0x00000000);
669 3fc6c082 bellard
    spr_register(env, SPR_DBAT7L, "DBAT7L",
670 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
671 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
672 3fc6c082 bellard
                 0x00000000);
673 a750fc0b j_mayer
    env->nb_BATs += 4;
674 f2e63a42 j_mayer
#endif
675 3fc6c082 bellard
}
676 3fc6c082 bellard
677 3fc6c082 bellard
/* Generic PowerPC time base */
678 3fc6c082 bellard
static void gen_tbl (CPUPPCState *env)
679 3fc6c082 bellard
{
680 3fc6c082 bellard
    spr_register(env, SPR_VTBL,  "TBL",
681 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
682 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
683 3fc6c082 bellard
                 0x00000000);
684 3fc6c082 bellard
    spr_register(env, SPR_TBL,   "TBL",
685 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
686 3fc6c082 bellard
                 SPR_NOACCESS, &spr_write_tbl,
687 3fc6c082 bellard
                 0x00000000);
688 3fc6c082 bellard
    spr_register(env, SPR_VTBU,  "TBU",
689 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
690 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
691 3fc6c082 bellard
                 0x00000000);
692 3fc6c082 bellard
    spr_register(env, SPR_TBU,   "TBU",
693 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
694 3fc6c082 bellard
                 SPR_NOACCESS, &spr_write_tbu,
695 3fc6c082 bellard
                 0x00000000);
696 3fc6c082 bellard
}
697 3fc6c082 bellard
698 76a66253 j_mayer
/* Softare table search registers */
699 76a66253 j_mayer
static void gen_6xx_7xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
700 76a66253 j_mayer
{
701 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
702 76a66253 j_mayer
    env->nb_tlb = nb_tlbs;
703 76a66253 j_mayer
    env->nb_ways = nb_ways;
704 76a66253 j_mayer
    env->id_tlbs = 1;
705 76a66253 j_mayer
    spr_register(env, SPR_DMISS, "DMISS",
706 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
707 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
708 76a66253 j_mayer
                 0x00000000);
709 76a66253 j_mayer
    spr_register(env, SPR_DCMP, "DCMP",
710 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
711 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
712 76a66253 j_mayer
                 0x00000000);
713 76a66253 j_mayer
    spr_register(env, SPR_HASH1, "HASH1",
714 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
715 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
716 76a66253 j_mayer
                 0x00000000);
717 76a66253 j_mayer
    spr_register(env, SPR_HASH2, "HASH2",
718 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
719 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
720 76a66253 j_mayer
                 0x00000000);
721 76a66253 j_mayer
    spr_register(env, SPR_IMISS, "IMISS",
722 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
723 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
724 76a66253 j_mayer
                 0x00000000);
725 76a66253 j_mayer
    spr_register(env, SPR_ICMP, "ICMP",
726 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
727 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
728 76a66253 j_mayer
                 0x00000000);
729 76a66253 j_mayer
    spr_register(env, SPR_RPA, "RPA",
730 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
731 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
732 76a66253 j_mayer
                 0x00000000);
733 f2e63a42 j_mayer
#endif
734 76a66253 j_mayer
}
735 76a66253 j_mayer
736 76a66253 j_mayer
/* SPR common to MPC755 and G2 */
737 76a66253 j_mayer
static void gen_spr_G2_755 (CPUPPCState *env)
738 76a66253 j_mayer
{
739 76a66253 j_mayer
    /* SGPRs */
740 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
741 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
742 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
743 76a66253 j_mayer
                 0x00000000);
744 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
745 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
746 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
747 76a66253 j_mayer
                 0x00000000);
748 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
749 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
750 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
751 76a66253 j_mayer
                 0x00000000);
752 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
753 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
754 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
755 76a66253 j_mayer
                 0x00000000);
756 76a66253 j_mayer
    /* External access control */
757 76a66253 j_mayer
    /* XXX : not implemented */
758 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
759 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
760 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
761 76a66253 j_mayer
                 0x00000000);
762 76a66253 j_mayer
}
763 76a66253 j_mayer
764 3fc6c082 bellard
/* SPR common to all 7xx PowerPC implementations */
765 3fc6c082 bellard
static void gen_spr_7xx (CPUPPCState *env)
766 3fc6c082 bellard
{
767 3fc6c082 bellard
    /* Breakpoints */
768 3fc6c082 bellard
    /* XXX : not implemented */
769 3fc6c082 bellard
    spr_register(env, SPR_DABR, "DABR",
770 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
771 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
772 3fc6c082 bellard
                 0x00000000);
773 3fc6c082 bellard
    /* XXX : not implemented */
774 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
775 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
776 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
777 3fc6c082 bellard
                 0x00000000);
778 3fc6c082 bellard
    /* Cache management */
779 3fc6c082 bellard
    /* XXX : not implemented */
780 3fc6c082 bellard
    spr_register(env, SPR_ICTC, "ICTC",
781 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
782 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
783 3fc6c082 bellard
                 0x00000000);
784 76a66253 j_mayer
    /* XXX : not implemented */
785 76a66253 j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
786 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
787 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
788 76a66253 j_mayer
                 0x00000000);
789 3fc6c082 bellard
    /* Performance monitors */
790 3fc6c082 bellard
    /* XXX : not implemented */
791 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
792 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
793 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
794 3fc6c082 bellard
                 0x00000000);
795 3fc6c082 bellard
    /* XXX : not implemented */
796 3fc6c082 bellard
    spr_register(env, SPR_MMCR1, "MMCR1",
797 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
798 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
799 3fc6c082 bellard
                 0x00000000);
800 3fc6c082 bellard
    /* XXX : not implemented */
801 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
802 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
803 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
804 3fc6c082 bellard
                 0x00000000);
805 3fc6c082 bellard
    /* XXX : not implemented */
806 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
807 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
808 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
809 3fc6c082 bellard
                 0x00000000);
810 3fc6c082 bellard
    /* XXX : not implemented */
811 3fc6c082 bellard
    spr_register(env, SPR_PMC3, "PMC3",
812 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
813 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
814 3fc6c082 bellard
                 0x00000000);
815 3fc6c082 bellard
    /* XXX : not implemented */
816 3fc6c082 bellard
    spr_register(env, SPR_PMC4, "PMC4",
817 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
818 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
819 3fc6c082 bellard
                 0x00000000);
820 3fc6c082 bellard
    /* XXX : not implemented */
821 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
822 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
823 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
824 3fc6c082 bellard
                 0x00000000);
825 578bb252 j_mayer
    /* XXX : not implemented */
826 3fc6c082 bellard
    spr_register(env, SPR_UMMCR0, "UMMCR0",
827 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
828 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
829 3fc6c082 bellard
                 0x00000000);
830 578bb252 j_mayer
    /* XXX : not implemented */
831 3fc6c082 bellard
    spr_register(env, SPR_UMMCR1, "UMMCR1",
832 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
833 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
834 3fc6c082 bellard
                 0x00000000);
835 578bb252 j_mayer
    /* XXX : not implemented */
836 3fc6c082 bellard
    spr_register(env, SPR_UPMC1, "UPMC1",
837 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
838 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
839 3fc6c082 bellard
                 0x00000000);
840 578bb252 j_mayer
    /* XXX : not implemented */
841 3fc6c082 bellard
    spr_register(env, SPR_UPMC2, "UPMC2",
842 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
843 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
844 3fc6c082 bellard
                 0x00000000);
845 578bb252 j_mayer
    /* XXX : not implemented */
846 3fc6c082 bellard
    spr_register(env, SPR_UPMC3, "UPMC3",
847 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
848 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
849 3fc6c082 bellard
                 0x00000000);
850 578bb252 j_mayer
    /* XXX : not implemented */
851 3fc6c082 bellard
    spr_register(env, SPR_UPMC4, "UPMC4",
852 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
853 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
854 3fc6c082 bellard
                 0x00000000);
855 578bb252 j_mayer
    /* XXX : not implemented */
856 a750fc0b j_mayer
    spr_register(env, SPR_USIAR, "USIAR",
857 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
858 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
859 3fc6c082 bellard
                 0x00000000);
860 a750fc0b j_mayer
    /* External access control */
861 3fc6c082 bellard
    /* XXX : not implemented */
862 a750fc0b j_mayer
    spr_register(env, SPR_EAR, "EAR",
863 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
864 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
865 3fc6c082 bellard
                 0x00000000);
866 a750fc0b j_mayer
}
867 a750fc0b j_mayer
868 a750fc0b j_mayer
static void gen_spr_thrm (CPUPPCState *env)
869 a750fc0b j_mayer
{
870 a750fc0b j_mayer
    /* Thermal management */
871 3fc6c082 bellard
    /* XXX : not implemented */
872 a750fc0b j_mayer
    spr_register(env, SPR_THRM1, "THRM1",
873 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
874 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
875 3fc6c082 bellard
                 0x00000000);
876 3fc6c082 bellard
    /* XXX : not implemented */
877 a750fc0b j_mayer
    spr_register(env, SPR_THRM2, "THRM2",
878 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
879 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
880 3fc6c082 bellard
                 0x00000000);
881 3fc6c082 bellard
    /* XXX : not implemented */
882 a750fc0b j_mayer
    spr_register(env, SPR_THRM3, "THRM3",
883 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
884 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
885 3fc6c082 bellard
                 0x00000000);
886 3fc6c082 bellard
}
887 3fc6c082 bellard
888 3fc6c082 bellard
/* SPR specific to PowerPC 604 implementation */
889 3fc6c082 bellard
static void gen_spr_604 (CPUPPCState *env)
890 3fc6c082 bellard
{
891 3fc6c082 bellard
    /* Processor identification */
892 3fc6c082 bellard
    spr_register(env, SPR_PIR, "PIR",
893 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
894 3fc6c082 bellard
                 &spr_read_generic, &spr_write_pir,
895 3fc6c082 bellard
                 0x00000000);
896 3fc6c082 bellard
    /* Breakpoints */
897 3fc6c082 bellard
    /* XXX : not implemented */
898 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
899 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
900 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
901 3fc6c082 bellard
                 0x00000000);
902 3fc6c082 bellard
    /* XXX : not implemented */
903 3fc6c082 bellard
    spr_register(env, SPR_DABR, "DABR",
904 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
905 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
906 3fc6c082 bellard
                 0x00000000);
907 3fc6c082 bellard
    /* Performance counters */
908 3fc6c082 bellard
    /* XXX : not implemented */
909 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
910 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
911 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
912 3fc6c082 bellard
                 0x00000000);
913 3fc6c082 bellard
    /* XXX : not implemented */
914 3fc6c082 bellard
    spr_register(env, SPR_MMCR1, "MMCR1",
915 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
916 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
917 3fc6c082 bellard
                 0x00000000);
918 3fc6c082 bellard
    /* XXX : not implemented */
919 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
920 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
921 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
922 3fc6c082 bellard
                 0x00000000);
923 3fc6c082 bellard
    /* XXX : not implemented */
924 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
925 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
926 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
927 3fc6c082 bellard
                 0x00000000);
928 3fc6c082 bellard
    /* XXX : not implemented */
929 3fc6c082 bellard
    spr_register(env, SPR_PMC3, "PMC3",
930 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
931 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
932 3fc6c082 bellard
                 0x00000000);
933 3fc6c082 bellard
    /* XXX : not implemented */
934 3fc6c082 bellard
    spr_register(env, SPR_PMC4, "PMC4",
935 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
936 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
937 3fc6c082 bellard
                 0x00000000);
938 3fc6c082 bellard
    /* XXX : not implemented */
939 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
940 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
941 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
942 3fc6c082 bellard
                 0x00000000);
943 3fc6c082 bellard
    /* XXX : not implemented */
944 3fc6c082 bellard
    spr_register(env, SPR_SDA, "SDA",
945 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
946 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
947 3fc6c082 bellard
                 0x00000000);
948 3fc6c082 bellard
    /* External access control */
949 3fc6c082 bellard
    /* XXX : not implemented */
950 3fc6c082 bellard
    spr_register(env, SPR_EAR, "EAR",
951 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
952 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
953 3fc6c082 bellard
                 0x00000000);
954 3fc6c082 bellard
}
955 3fc6c082 bellard
956 76a66253 j_mayer
/* SPR specific to PowerPC 603 implementation */
957 76a66253 j_mayer
static void gen_spr_603 (CPUPPCState *env)
958 3fc6c082 bellard
{
959 76a66253 j_mayer
    /* External access control */
960 76a66253 j_mayer
    /* XXX : not implemented */
961 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
962 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
963 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
964 76a66253 j_mayer
                 0x00000000);
965 3fc6c082 bellard
}
966 3fc6c082 bellard
967 76a66253 j_mayer
/* SPR specific to PowerPC G2 implementation */
968 76a66253 j_mayer
static void gen_spr_G2 (CPUPPCState *env)
969 3fc6c082 bellard
{
970 76a66253 j_mayer
    /* Memory base address */
971 76a66253 j_mayer
    /* MBAR */
972 578bb252 j_mayer
    /* XXX : not implemented */
973 76a66253 j_mayer
    spr_register(env, SPR_MBAR, "MBAR",
974 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
975 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
976 76a66253 j_mayer
                 0x00000000);
977 76a66253 j_mayer
    /* System version register */
978 76a66253 j_mayer
    /* SVR */
979 578bb252 j_mayer
    /* XXX : TODO: initialize it to an appropriate value */
980 76a66253 j_mayer
    spr_register(env, SPR_SVR, "SVR",
981 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
982 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
983 76a66253 j_mayer
                 0x00000000);
984 76a66253 j_mayer
    /* Exception processing */
985 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
986 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
987 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
988 76a66253 j_mayer
                 0x00000000);
989 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
990 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
991 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
992 76a66253 j_mayer
                 0x00000000);
993 76a66253 j_mayer
    /* Breakpoints */
994 76a66253 j_mayer
    /* XXX : not implemented */
995 76a66253 j_mayer
    spr_register(env, SPR_DABR, "DABR",
996 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
997 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
998 76a66253 j_mayer
                 0x00000000);
999 76a66253 j_mayer
    /* XXX : not implemented */
1000 76a66253 j_mayer
    spr_register(env, SPR_DABR2, "DABR2",
1001 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1002 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1003 76a66253 j_mayer
                 0x00000000);
1004 76a66253 j_mayer
    /* XXX : not implemented */
1005 76a66253 j_mayer
    spr_register(env, SPR_IABR, "IABR",
1006 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1007 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1008 76a66253 j_mayer
                 0x00000000);
1009 76a66253 j_mayer
    /* XXX : not implemented */
1010 76a66253 j_mayer
    spr_register(env, SPR_IABR2, "IABR2",
1011 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1012 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1013 76a66253 j_mayer
                 0x00000000);
1014 76a66253 j_mayer
    /* XXX : not implemented */
1015 76a66253 j_mayer
    spr_register(env, SPR_IBCR, "IBCR",
1016 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1017 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1018 76a66253 j_mayer
                 0x00000000);
1019 76a66253 j_mayer
    /* XXX : not implemented */
1020 76a66253 j_mayer
    spr_register(env, SPR_DBCR, "DBCR",
1021 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1022 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1023 76a66253 j_mayer
                 0x00000000);
1024 76a66253 j_mayer
}
1025 76a66253 j_mayer
1026 76a66253 j_mayer
/* SPR specific to PowerPC 602 implementation */
1027 76a66253 j_mayer
static void gen_spr_602 (CPUPPCState *env)
1028 76a66253 j_mayer
{
1029 76a66253 j_mayer
    /* ESA registers */
1030 76a66253 j_mayer
    /* XXX : not implemented */
1031 76a66253 j_mayer
    spr_register(env, SPR_SER, "SER",
1032 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1033 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1034 76a66253 j_mayer
                 0x00000000);
1035 76a66253 j_mayer
    /* XXX : not implemented */
1036 76a66253 j_mayer
    spr_register(env, SPR_SEBR, "SEBR",
1037 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1038 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1039 76a66253 j_mayer
                 0x00000000);
1040 76a66253 j_mayer
    /* XXX : not implemented */
1041 a750fc0b j_mayer
    spr_register(env, SPR_ESASRR, "ESASRR",
1042 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1043 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1044 76a66253 j_mayer
                 0x00000000);
1045 76a66253 j_mayer
    /* Floating point status */
1046 76a66253 j_mayer
    /* XXX : not implemented */
1047 76a66253 j_mayer
    spr_register(env, SPR_SP, "SP",
1048 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1049 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1050 76a66253 j_mayer
                 0x00000000);
1051 76a66253 j_mayer
    /* XXX : not implemented */
1052 76a66253 j_mayer
    spr_register(env, SPR_LT, "LT",
1053 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1054 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1055 76a66253 j_mayer
                 0x00000000);
1056 76a66253 j_mayer
    /* Watchdog timer */
1057 76a66253 j_mayer
    /* XXX : not implemented */
1058 76a66253 j_mayer
    spr_register(env, SPR_TCR, "TCR",
1059 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1060 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1061 76a66253 j_mayer
                 0x00000000);
1062 76a66253 j_mayer
    /* Interrupt base */
1063 76a66253 j_mayer
    spr_register(env, SPR_IBR, "IBR",
1064 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1065 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1066 76a66253 j_mayer
                 0x00000000);
1067 a750fc0b j_mayer
    /* XXX : not implemented */
1068 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
1069 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1070 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1071 a750fc0b j_mayer
                 0x00000000);
1072 76a66253 j_mayer
}
1073 76a66253 j_mayer
1074 76a66253 j_mayer
/* SPR specific to PowerPC 601 implementation */
1075 76a66253 j_mayer
static void gen_spr_601 (CPUPPCState *env)
1076 76a66253 j_mayer
{
1077 76a66253 j_mayer
    /* Multiplication/division register */
1078 76a66253 j_mayer
    /* MQ */
1079 76a66253 j_mayer
    spr_register(env, SPR_MQ, "MQ",
1080 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1081 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1082 76a66253 j_mayer
                 0x00000000);
1083 76a66253 j_mayer
    /* RTC registers */
1084 76a66253 j_mayer
    spr_register(env, SPR_601_RTCU, "RTCU",
1085 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1086 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcu,
1087 76a66253 j_mayer
                 0x00000000);
1088 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCU, "RTCU",
1089 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1090 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1091 76a66253 j_mayer
                 0x00000000);
1092 76a66253 j_mayer
    spr_register(env, SPR_601_RTCL, "RTCL",
1093 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1094 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcl,
1095 76a66253 j_mayer
                 0x00000000);
1096 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCL, "RTCL",
1097 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1098 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1099 76a66253 j_mayer
                 0x00000000);
1100 76a66253 j_mayer
    /* Timer */
1101 76a66253 j_mayer
#if 0 /* ? */
1102 76a66253 j_mayer
    spr_register(env, SPR_601_UDECR, "UDECR",
1103 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1104 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1105 76a66253 j_mayer
                 0x00000000);
1106 76a66253 j_mayer
#endif
1107 76a66253 j_mayer
    /* External access control */
1108 76a66253 j_mayer
    /* XXX : not implemented */
1109 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
1110 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1111 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1112 76a66253 j_mayer
                 0x00000000);
1113 76a66253 j_mayer
    /* Memory management */
1114 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1115 76a66253 j_mayer
    spr_register(env, SPR_IBAT0U, "IBAT0U",
1116 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1117 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1118 76a66253 j_mayer
                 0x00000000);
1119 76a66253 j_mayer
    spr_register(env, SPR_IBAT0L, "IBAT0L",
1120 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1121 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1122 76a66253 j_mayer
                 0x00000000);
1123 76a66253 j_mayer
    spr_register(env, SPR_IBAT1U, "IBAT1U",
1124 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1125 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1126 76a66253 j_mayer
                 0x00000000);
1127 76a66253 j_mayer
    spr_register(env, SPR_IBAT1L, "IBAT1L",
1128 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1129 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1130 76a66253 j_mayer
                 0x00000000);
1131 76a66253 j_mayer
    spr_register(env, SPR_IBAT2U, "IBAT2U",
1132 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1133 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1134 76a66253 j_mayer
                 0x00000000);
1135 76a66253 j_mayer
    spr_register(env, SPR_IBAT2L, "IBAT2L",
1136 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1137 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1138 76a66253 j_mayer
                 0x00000000);
1139 76a66253 j_mayer
    spr_register(env, SPR_IBAT3U, "IBAT3U",
1140 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1141 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1142 76a66253 j_mayer
                 0x00000000);
1143 76a66253 j_mayer
    spr_register(env, SPR_IBAT3L, "IBAT3L",
1144 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1145 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1146 76a66253 j_mayer
                 0x00000000);
1147 a750fc0b j_mayer
    env->nb_BATs = 4;
1148 f2e63a42 j_mayer
#endif
1149 a750fc0b j_mayer
}
1150 a750fc0b j_mayer
1151 a750fc0b j_mayer
static void gen_spr_74xx (CPUPPCState *env)
1152 a750fc0b j_mayer
{
1153 a750fc0b j_mayer
    /* Processor identification */
1154 a750fc0b j_mayer
    spr_register(env, SPR_PIR, "PIR",
1155 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1156 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_pir,
1157 a750fc0b j_mayer
                 0x00000000);
1158 a750fc0b j_mayer
    /* XXX : not implemented */
1159 a750fc0b j_mayer
    spr_register(env, SPR_MMCR2, "MMCR2",
1160 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1161 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1162 a750fc0b j_mayer
                 0x00000000);
1163 578bb252 j_mayer
    /* XXX : not implemented */
1164 a750fc0b j_mayer
    spr_register(env, SPR_UMMCR2, "UMMCR2",
1165 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1166 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1167 a750fc0b j_mayer
                 0x00000000);
1168 a750fc0b j_mayer
    /* XXX: not implemented */
1169 a750fc0b j_mayer
    spr_register(env, SPR_BAMR, "BAMR",
1170 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1171 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1172 a750fc0b j_mayer
                 0x00000000);
1173 578bb252 j_mayer
    /* XXX : not implemented */
1174 a750fc0b j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
1175 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1176 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1177 a750fc0b j_mayer
                 0x00000000);
1178 578bb252 j_mayer
    /* XXX : not implemented */
1179 a750fc0b j_mayer
    spr_register(env, SPR_MSSCR0, "MSSCR0",
1180 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1181 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1182 a750fc0b j_mayer
                 0x00000000);
1183 a750fc0b j_mayer
    /* Hardware implementation registers */
1184 a750fc0b j_mayer
    /* XXX : not implemented */
1185 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
1186 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1187 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1188 a750fc0b j_mayer
                 0x00000000);
1189 a750fc0b j_mayer
    /* XXX : not implemented */
1190 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
1191 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1192 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1193 a750fc0b j_mayer
                 0x00000000);
1194 a750fc0b j_mayer
    /* Altivec */
1195 a750fc0b j_mayer
    spr_register(env, SPR_VRSAVE, "VRSAVE",
1196 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1197 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1198 a750fc0b j_mayer
                 0x00000000);
1199 a750fc0b j_mayer
}
1200 a750fc0b j_mayer
1201 a750fc0b j_mayer
static void gen_l3_ctrl (CPUPPCState *env)
1202 a750fc0b j_mayer
{
1203 a750fc0b j_mayer
    /* L3CR */
1204 a750fc0b j_mayer
    /* XXX : not implemented */
1205 a750fc0b j_mayer
    spr_register(env, SPR_L3CR, "L3CR",
1206 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1207 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1208 a750fc0b j_mayer
                 0x00000000);
1209 a750fc0b j_mayer
    /* L3ITCR0 */
1210 578bb252 j_mayer
    /* XXX : not implemented */
1211 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR0, "L3ITCR0",
1212 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1213 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1214 a750fc0b j_mayer
                 0x00000000);
1215 a750fc0b j_mayer
    /* L3ITCR1 */
1216 578bb252 j_mayer
    /* XXX : not implemented */
1217 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
1218 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1219 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1220 a750fc0b j_mayer
                 0x00000000);
1221 a750fc0b j_mayer
    /* L3ITCR2 */
1222 578bb252 j_mayer
    /* XXX : not implemented */
1223 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
1224 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1225 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1226 a750fc0b j_mayer
                 0x00000000);
1227 a750fc0b j_mayer
    /* L3ITCR3 */
1228 578bb252 j_mayer
    /* XXX : not implemented */
1229 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
1230 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1231 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1232 a750fc0b j_mayer
                 0x00000000);
1233 a750fc0b j_mayer
    /* L3OHCR */
1234 578bb252 j_mayer
    /* XXX : not implemented */
1235 a750fc0b j_mayer
    spr_register(env, SPR_L3OHCR, "L3OHCR",
1236 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1237 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1238 a750fc0b j_mayer
                 0x00000000);
1239 a750fc0b j_mayer
    /* L3PM */
1240 578bb252 j_mayer
    /* XXX : not implemented */
1241 a750fc0b j_mayer
    spr_register(env, SPR_L3PM, "L3PM",
1242 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1243 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1244 a750fc0b j_mayer
                 0x00000000);
1245 a750fc0b j_mayer
}
1246 a750fc0b j_mayer
1247 578bb252 j_mayer
static void gen_74xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
1248 a750fc0b j_mayer
{
1249 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1250 578bb252 j_mayer
    env->nb_tlb = nb_tlbs;
1251 578bb252 j_mayer
    env->nb_ways = nb_ways;
1252 578bb252 j_mayer
    env->id_tlbs = 1;
1253 578bb252 j_mayer
    /* XXX : not implemented */
1254 a750fc0b j_mayer
    spr_register(env, SPR_PTEHI, "PTEHI",
1255 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1256 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1257 a750fc0b j_mayer
                 0x00000000);
1258 578bb252 j_mayer
    /* XXX : not implemented */
1259 a750fc0b j_mayer
    spr_register(env, SPR_PTELO, "PTELO",
1260 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1261 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1262 a750fc0b j_mayer
                 0x00000000);
1263 578bb252 j_mayer
    /* XXX : not implemented */
1264 a750fc0b j_mayer
    spr_register(env, SPR_TLBMISS, "TLBMISS",
1265 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1266 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1267 a750fc0b j_mayer
                 0x00000000);
1268 f2e63a42 j_mayer
#endif
1269 76a66253 j_mayer
}
1270 76a66253 j_mayer
1271 76a66253 j_mayer
/* PowerPC BookE SPR */
1272 76a66253 j_mayer
static void gen_spr_BookE (CPUPPCState *env)
1273 76a66253 j_mayer
{
1274 76a66253 j_mayer
    /* Processor identification */
1275 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
1276 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1277 76a66253 j_mayer
                 &spr_read_generic, &spr_write_pir,
1278 76a66253 j_mayer
                 0x00000000);
1279 76a66253 j_mayer
    /* Interrupt processing */
1280 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
1281 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1282 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1283 76a66253 j_mayer
                 0x00000000);
1284 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
1285 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1286 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1287 363be49c j_mayer
                 0x00000000);
1288 2662a059 j_mayer
#if 0
1289 363be49c j_mayer
    spr_register(env, SPR_BOOKE_DSRR0, "DSRR0",
1290 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1291 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1292 363be49c j_mayer
                 0x00000000);
1293 363be49c j_mayer
    spr_register(env, SPR_BOOKE_DSRR1, "DSRR1",
1294 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1295 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1296 363be49c j_mayer
                 0x00000000);
1297 2662a059 j_mayer
#endif
1298 76a66253 j_mayer
    /* Debug */
1299 76a66253 j_mayer
    /* XXX : not implemented */
1300 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC1, "IAC1",
1301 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1302 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1303 76a66253 j_mayer
                 0x00000000);
1304 76a66253 j_mayer
    /* XXX : not implemented */
1305 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC2, "IAC2",
1306 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1307 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1308 76a66253 j_mayer
                 0x00000000);
1309 76a66253 j_mayer
    /* XXX : not implemented */
1310 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
1311 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1312 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1313 76a66253 j_mayer
                 0x00000000);
1314 76a66253 j_mayer
    /* XXX : not implemented */
1315 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
1316 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1317 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1318 76a66253 j_mayer
                 0x00000000);
1319 76a66253 j_mayer
    /* XXX : not implemented */
1320 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC1, "DAC1",
1321 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1322 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1323 76a66253 j_mayer
                 0x00000000);
1324 76a66253 j_mayer
    /* XXX : not implemented */
1325 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC2, "DAC2",
1326 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1327 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1328 76a66253 j_mayer
                 0x00000000);
1329 76a66253 j_mayer
    /* XXX : not implemented */
1330 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
1331 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1332 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1333 76a66253 j_mayer
                 0x00000000);
1334 76a66253 j_mayer
    /* XXX : not implemented */
1335 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
1336 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1337 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1338 76a66253 j_mayer
                 0x00000000);
1339 76a66253 j_mayer
    /* XXX : not implemented */
1340 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR0, "DBCR0",
1341 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1342 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1343 76a66253 j_mayer
                 0x00000000);
1344 76a66253 j_mayer
    /* XXX : not implemented */
1345 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR1, "DBCR1",
1346 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1347 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1348 76a66253 j_mayer
                 0x00000000);
1349 76a66253 j_mayer
    /* XXX : not implemented */
1350 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR2, "DBCR2",
1351 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1352 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1353 76a66253 j_mayer
                 0x00000000);
1354 76a66253 j_mayer
    /* XXX : not implemented */
1355 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBSR, "DBSR",
1356 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1357 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1358 76a66253 j_mayer
                 0x00000000);
1359 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DEAR, "DEAR",
1360 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1361 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1362 76a66253 j_mayer
                 0x00000000);
1363 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_ESR, "ESR",
1364 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1365 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1366 76a66253 j_mayer
                 0x00000000);
1367 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVPR, "IVPR",
1368 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1369 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1370 363be49c j_mayer
                 0x00000000);
1371 363be49c j_mayer
    /* Exception vectors */
1372 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR0, "IVOR0",
1373 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1374 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1375 76a66253 j_mayer
                 0x00000000);
1376 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR1, "IVOR1",
1377 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1378 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1379 76a66253 j_mayer
                 0x00000000);
1380 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR2, "IVOR2",
1381 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1382 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1383 76a66253 j_mayer
                 0x00000000);
1384 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR3, "IVOR3",
1385 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1386 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1387 76a66253 j_mayer
                 0x00000000);
1388 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR4, "IVOR4",
1389 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1390 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1391 76a66253 j_mayer
                 0x00000000);
1392 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR5, "IVOR5",
1393 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1394 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1395 76a66253 j_mayer
                 0x00000000);
1396 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR6, "IVOR6",
1397 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1398 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1399 76a66253 j_mayer
                 0x00000000);
1400 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR7, "IVOR7",
1401 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1402 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1403 76a66253 j_mayer
                 0x00000000);
1404 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR8, "IVOR8",
1405 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1406 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1407 76a66253 j_mayer
                 0x00000000);
1408 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR9, "IVOR9",
1409 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1410 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1411 76a66253 j_mayer
                 0x00000000);
1412 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR10, "IVOR10",
1413 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1414 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1415 76a66253 j_mayer
                 0x00000000);
1416 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR11, "IVOR11",
1417 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1418 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1419 76a66253 j_mayer
                 0x00000000);
1420 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR12, "IVOR12",
1421 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1422 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1423 76a66253 j_mayer
                 0x00000000);
1424 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR13, "IVOR13",
1425 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1426 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1427 76a66253 j_mayer
                 0x00000000);
1428 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR14, "IVOR14",
1429 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1430 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1431 76a66253 j_mayer
                 0x00000000);
1432 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IVOR15, "IVOR15",
1433 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1434 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1435 76a66253 j_mayer
                 0x00000000);
1436 2662a059 j_mayer
#if 0
1437 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVOR32, "IVOR32",
1438 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1439 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1440 363be49c j_mayer
                 0x00000000);
1441 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVOR33, "IVOR33",
1442 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1443 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1444 363be49c j_mayer
                 0x00000000);
1445 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVOR34, "IVOR34",
1446 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1447 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1448 363be49c j_mayer
                 0x00000000);
1449 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVOR35, "IVOR35",
1450 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1451 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1452 363be49c j_mayer
                 0x00000000);
1453 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVOR36, "IVOR36",
1454 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1455 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1456 363be49c j_mayer
                 0x00000000);
1457 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVOR37, "IVOR37",
1458 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1459 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_vector,
1460 363be49c j_mayer
                 0x00000000);
1461 2662a059 j_mayer
#endif
1462 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_PID, "PID",
1463 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1464 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1465 76a66253 j_mayer
                 0x00000000);
1466 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TCR, "TCR",
1467 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1468 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1469 76a66253 j_mayer
                 0x00000000);
1470 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TSR, "TSR",
1471 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1472 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1473 76a66253 j_mayer
                 0x00000000);
1474 76a66253 j_mayer
    /* Timer */
1475 76a66253 j_mayer
    spr_register(env, SPR_DECR, "DECR",
1476 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1477 76a66253 j_mayer
                 &spr_read_decr, &spr_write_decr,
1478 76a66253 j_mayer
                 0x00000000);
1479 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DECAR, "DECAR",
1480 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1481 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_generic,
1482 76a66253 j_mayer
                 0x00000000);
1483 76a66253 j_mayer
    /* SPRGs */
1484 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1485 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1486 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1487 76a66253 j_mayer
                 0x00000000);
1488 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1489 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1490 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1491 76a66253 j_mayer
                 0x00000000);
1492 76a66253 j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
1493 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1494 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1495 76a66253 j_mayer
                 0x00000000);
1496 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1497 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1498 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1499 76a66253 j_mayer
                 0x00000000);
1500 76a66253 j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
1501 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1502 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1503 76a66253 j_mayer
                 0x00000000);
1504 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1505 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1506 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1507 76a66253 j_mayer
                 0x00000000);
1508 76a66253 j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
1509 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1510 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1511 76a66253 j_mayer
                 0x00000000);
1512 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1513 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1514 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1515 76a66253 j_mayer
                 0x00000000);
1516 76a66253 j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
1517 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1518 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1519 76a66253 j_mayer
                 0x00000000);
1520 76a66253 j_mayer
}
1521 76a66253 j_mayer
1522 363be49c j_mayer
/* FSL storage control registers */
1523 363be49c j_mayer
static void gen_spr_BookE_FSL (CPUPPCState *env)
1524 363be49c j_mayer
{
1525 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1526 363be49c j_mayer
    /* TLB assist registers */
1527 578bb252 j_mayer
    /* XXX : not implemented */
1528 363be49c j_mayer
    spr_register(env, SPR_BOOKE_MAS0, "MAS0",
1529 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1530 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1531 363be49c j_mayer
                 0x00000000);
1532 578bb252 j_mayer
    /* XXX : not implemented */
1533 363be49c j_mayer
    spr_register(env, SPR_BOOKE_MAS1, "MAS2",
1534 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1535 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1536 363be49c j_mayer
                 0x00000000);
1537 578bb252 j_mayer
    /* XXX : not implemented */
1538 363be49c j_mayer
    spr_register(env, SPR_BOOKE_MAS2, "MAS3",
1539 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1540 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1541 363be49c j_mayer
                 0x00000000);
1542 578bb252 j_mayer
    /* XXX : not implemented */
1543 363be49c j_mayer
    spr_register(env, SPR_BOOKE_MAS3, "MAS4",
1544 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1545 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1546 363be49c j_mayer
                 0x00000000);
1547 578bb252 j_mayer
    /* XXX : not implemented */
1548 363be49c j_mayer
    spr_register(env, SPR_BOOKE_MAS4, "MAS5",
1549 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1550 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1551 363be49c j_mayer
                 0x00000000);
1552 578bb252 j_mayer
    /* XXX : not implemented */
1553 363be49c j_mayer
    spr_register(env, SPR_BOOKE_MAS6, "MAS6",
1554 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1555 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1556 363be49c j_mayer
                 0x00000000);
1557 578bb252 j_mayer
    /* XXX : not implemented */
1558 363be49c j_mayer
    spr_register(env, SPR_BOOKE_MAS7, "MAS7",
1559 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1560 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1561 363be49c j_mayer
                 0x00000000);
1562 363be49c j_mayer
    if (env->nb_pids > 1) {
1563 578bb252 j_mayer
        /* XXX : not implemented */
1564 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID1, "PID1",
1565 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1566 363be49c j_mayer
                     &spr_read_generic, &spr_write_generic,
1567 363be49c j_mayer
                     0x00000000);
1568 363be49c j_mayer
    }
1569 363be49c j_mayer
    if (env->nb_pids > 2) {
1570 578bb252 j_mayer
        /* XXX : not implemented */
1571 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID2, "PID2",
1572 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1573 363be49c j_mayer
                     &spr_read_generic, &spr_write_generic,
1574 363be49c j_mayer
                     0x00000000);
1575 363be49c j_mayer
    }
1576 578bb252 j_mayer
    /* XXX : not implemented */
1577 65f9ee8d j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
1578 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1579 363be49c j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1580 363be49c j_mayer
                 0x00000000); /* TOFIX */
1581 578bb252 j_mayer
    /* XXX : not implemented */
1582 65f9ee8d j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
1583 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1584 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1585 363be49c j_mayer
                 0x00000000); /* TOFIX */
1586 363be49c j_mayer
    switch (env->nb_ways) {
1587 363be49c j_mayer
    case 4:
1588 578bb252 j_mayer
        /* XXX : not implemented */
1589 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB3CFG, "TLB3CFG",
1590 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1591 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1592 363be49c j_mayer
                     0x00000000); /* TOFIX */
1593 363be49c j_mayer
        /* Fallthru */
1594 363be49c j_mayer
    case 3:
1595 578bb252 j_mayer
        /* XXX : not implemented */
1596 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB2CFG, "TLB2CFG",
1597 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1598 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1599 363be49c j_mayer
                     0x00000000); /* TOFIX */
1600 363be49c j_mayer
        /* Fallthru */
1601 363be49c j_mayer
    case 2:
1602 578bb252 j_mayer
        /* XXX : not implemented */
1603 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
1604 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1605 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1606 363be49c j_mayer
                     0x00000000); /* TOFIX */
1607 363be49c j_mayer
        /* Fallthru */
1608 363be49c j_mayer
    case 1:
1609 578bb252 j_mayer
        /* XXX : not implemented */
1610 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
1611 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1612 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1613 363be49c j_mayer
                     0x00000000); /* TOFIX */
1614 363be49c j_mayer
        /* Fallthru */
1615 363be49c j_mayer
    case 0:
1616 363be49c j_mayer
    default:
1617 363be49c j_mayer
        break;
1618 363be49c j_mayer
    }
1619 f2e63a42 j_mayer
#endif
1620 363be49c j_mayer
}
1621 363be49c j_mayer
1622 76a66253 j_mayer
/* SPR specific to PowerPC 440 implementation */
1623 76a66253 j_mayer
static void gen_spr_440 (CPUPPCState *env)
1624 76a66253 j_mayer
{
1625 76a66253 j_mayer
    /* Cache control */
1626 76a66253 j_mayer
    /* XXX : not implemented */
1627 76a66253 j_mayer
    spr_register(env, SPR_440_DNV0, "DNV0",
1628 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1629 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1630 76a66253 j_mayer
                 0x00000000);
1631 76a66253 j_mayer
    /* XXX : not implemented */
1632 76a66253 j_mayer
    spr_register(env, SPR_440_DNV1, "DNV1",
1633 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1634 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1635 76a66253 j_mayer
                 0x00000000);
1636 76a66253 j_mayer
    /* XXX : not implemented */
1637 76a66253 j_mayer
    spr_register(env, SPR_440_DNV2, "DNV2",
1638 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1639 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1640 76a66253 j_mayer
                 0x00000000);
1641 76a66253 j_mayer
    /* XXX : not implemented */
1642 76a66253 j_mayer
    spr_register(env, SPR_440_DNV3, "DNV3",
1643 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1644 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1645 76a66253 j_mayer
                 0x00000000);
1646 76a66253 j_mayer
    /* XXX : not implemented */
1647 2662a059 j_mayer
    spr_register(env, SPR_440_DTV0, "DTV0",
1648 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1649 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1650 76a66253 j_mayer
                 0x00000000);
1651 76a66253 j_mayer
    /* XXX : not implemented */
1652 2662a059 j_mayer
    spr_register(env, SPR_440_DTV1, "DTV1",
1653 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1654 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1655 76a66253 j_mayer
                 0x00000000);
1656 76a66253 j_mayer
    /* XXX : not implemented */
1657 2662a059 j_mayer
    spr_register(env, SPR_440_DTV2, "DTV2",
1658 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1659 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1660 76a66253 j_mayer
                 0x00000000);
1661 76a66253 j_mayer
    /* XXX : not implemented */
1662 2662a059 j_mayer
    spr_register(env, SPR_440_DTV3, "DTV3",
1663 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1664 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1665 76a66253 j_mayer
                 0x00000000);
1666 76a66253 j_mayer
    /* XXX : not implemented */
1667 76a66253 j_mayer
    spr_register(env, SPR_440_DVLIM, "DVLIM",
1668 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1669 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1670 76a66253 j_mayer
                 0x00000000);
1671 76a66253 j_mayer
    /* XXX : not implemented */
1672 76a66253 j_mayer
    spr_register(env, SPR_440_INV0, "INV0",
1673 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1674 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1675 76a66253 j_mayer
                 0x00000000);
1676 76a66253 j_mayer
    /* XXX : not implemented */
1677 76a66253 j_mayer
    spr_register(env, SPR_440_INV1, "INV1",
1678 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1679 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1680 76a66253 j_mayer
                 0x00000000);
1681 76a66253 j_mayer
    /* XXX : not implemented */
1682 76a66253 j_mayer
    spr_register(env, SPR_440_INV2, "INV2",
1683 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1684 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1685 76a66253 j_mayer
                 0x00000000);
1686 76a66253 j_mayer
    /* XXX : not implemented */
1687 76a66253 j_mayer
    spr_register(env, SPR_440_INV3, "INV3",
1688 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1689 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1690 76a66253 j_mayer
                 0x00000000);
1691 76a66253 j_mayer
    /* XXX : not implemented */
1692 2662a059 j_mayer
    spr_register(env, SPR_440_ITV0, "ITV0",
1693 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1694 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1695 76a66253 j_mayer
                 0x00000000);
1696 76a66253 j_mayer
    /* XXX : not implemented */
1697 2662a059 j_mayer
    spr_register(env, SPR_440_ITV1, "ITV1",
1698 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1699 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1700 76a66253 j_mayer
                 0x00000000);
1701 76a66253 j_mayer
    /* XXX : not implemented */
1702 2662a059 j_mayer
    spr_register(env, SPR_440_ITV2, "ITV2",
1703 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1704 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1705 76a66253 j_mayer
                 0x00000000);
1706 76a66253 j_mayer
    /* XXX : not implemented */
1707 2662a059 j_mayer
    spr_register(env, SPR_440_ITV3, "ITV3",
1708 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1709 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1710 76a66253 j_mayer
                 0x00000000);
1711 76a66253 j_mayer
    /* XXX : not implemented */
1712 76a66253 j_mayer
    spr_register(env, SPR_440_IVLIM, "IVLIM",
1713 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1714 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1715 76a66253 j_mayer
                 0x00000000);
1716 76a66253 j_mayer
    /* Cache debug */
1717 76a66253 j_mayer
    /* XXX : not implemented */
1718 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRH, "DCDBTRH",
1719 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1720 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1721 76a66253 j_mayer
                 0x00000000);
1722 76a66253 j_mayer
    /* XXX : not implemented */
1723 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRL, "DCDBTRL",
1724 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1725 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1726 76a66253 j_mayer
                 0x00000000);
1727 76a66253 j_mayer
    /* XXX : not implemented */
1728 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1729 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1730 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1731 76a66253 j_mayer
                 0x00000000);
1732 76a66253 j_mayer
    /* XXX : not implemented */
1733 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRH, "ICDBTRH",
1734 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1735 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1736 76a66253 j_mayer
                 0x00000000);
1737 76a66253 j_mayer
    /* XXX : not implemented */
1738 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRL, "ICDBTRL",
1739 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1740 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1741 76a66253 j_mayer
                 0x00000000);
1742 76a66253 j_mayer
    /* XXX : not implemented */
1743 76a66253 j_mayer
    spr_register(env, SPR_440_DBDR, "DBDR",
1744 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1745 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1746 76a66253 j_mayer
                 0x00000000);
1747 76a66253 j_mayer
    /* Processor control */
1748 76a66253 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1749 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1750 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1751 76a66253 j_mayer
                 0x00000000);
1752 76a66253 j_mayer
    spr_register(env, SPR_440_RSTCFG, "RSTCFG",
1753 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1754 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1755 76a66253 j_mayer
                 0x00000000);
1756 76a66253 j_mayer
    /* Storage control */
1757 76a66253 j_mayer
    spr_register(env, SPR_440_MMUCR, "MMUCR",
1758 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1759 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1760 76a66253 j_mayer
                 0x00000000);
1761 76a66253 j_mayer
}
1762 76a66253 j_mayer
1763 76a66253 j_mayer
/* SPR shared between PowerPC 40x implementations */
1764 76a66253 j_mayer
static void gen_spr_40x (CPUPPCState *env)
1765 76a66253 j_mayer
{
1766 76a66253 j_mayer
    /* Cache */
1767 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1768 76a66253 j_mayer
    spr_register(env, SPR_40x_DCCR, "DCCR",
1769 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1770 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1771 76a66253 j_mayer
                 0x00000000);
1772 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1773 76a66253 j_mayer
    spr_register(env, SPR_40x_ICCR, "ICCR",
1774 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1775 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1776 76a66253 j_mayer
                 0x00000000);
1777 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1778 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1779 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1780 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1781 76a66253 j_mayer
                 0x00000000);
1782 76a66253 j_mayer
    /* Exception */
1783 76a66253 j_mayer
    spr_register(env, SPR_40x_DEAR, "DEAR",
1784 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1785 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1786 76a66253 j_mayer
                 0x00000000);
1787 76a66253 j_mayer
    spr_register(env, SPR_40x_ESR, "ESR",
1788 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1789 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1790 76a66253 j_mayer
                 0x00000000);
1791 76a66253 j_mayer
    spr_register(env, SPR_40x_EVPR, "EVPR",
1792 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1793 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1794 76a66253 j_mayer
                 0x00000000);
1795 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR2, "SRR2",
1796 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1797 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1798 76a66253 j_mayer
                 0x00000000);
1799 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR3, "SRR3",
1800 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1801 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1802 76a66253 j_mayer
                 0x00000000);
1803 76a66253 j_mayer
    /* Timers */
1804 76a66253 j_mayer
    spr_register(env, SPR_40x_PIT, "PIT",
1805 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1806 76a66253 j_mayer
                 &spr_read_40x_pit, &spr_write_40x_pit,
1807 76a66253 j_mayer
                 0x00000000);
1808 76a66253 j_mayer
    spr_register(env, SPR_40x_TCR, "TCR",
1809 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1810 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1811 76a66253 j_mayer
                 0x00000000);
1812 76a66253 j_mayer
    spr_register(env, SPR_40x_TSR, "TSR",
1813 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1814 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1815 76a66253 j_mayer
                 0x00000000);
1816 2662a059 j_mayer
}
1817 2662a059 j_mayer
1818 2662a059 j_mayer
/* SPR specific to PowerPC 405 implementation */
1819 2662a059 j_mayer
static void gen_spr_405 (CPUPPCState *env)
1820 2662a059 j_mayer
{
1821 2662a059 j_mayer
    /* MMU */
1822 2662a059 j_mayer
    spr_register(env, SPR_40x_PID, "PID",
1823 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1824 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1825 76a66253 j_mayer
                 0x00000000);
1826 2662a059 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1827 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1828 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1829 2662a059 j_mayer
                 0x00700000);
1830 2662a059 j_mayer
    /* Debug interface */
1831 76a66253 j_mayer
    /* XXX : not implemented */
1832 76a66253 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1833 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1834 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1835 76a66253 j_mayer
                 0x00000000);
1836 76a66253 j_mayer
    /* XXX : not implemented */
1837 2662a059 j_mayer
    spr_register(env, SPR_405_DBCR1, "DBCR1",
1838 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1839 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1840 2662a059 j_mayer
                 0x00000000);
1841 2662a059 j_mayer
    /* XXX : not implemented */
1842 76a66253 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1843 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1844 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1845 8ecc7913 j_mayer
                 /* Last reset was system reset */
1846 76a66253 j_mayer
                 0x00000300);
1847 76a66253 j_mayer
    /* XXX : not implemented */
1848 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
1849 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1850 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1851 76a66253 j_mayer
                 0x00000000);
1852 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
1853 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1854 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1855 76a66253 j_mayer
                 0x00000000);
1856 2662a059 j_mayer
    /* XXX : not implemented */
1857 2662a059 j_mayer
    spr_register(env, SPR_405_DVC1, "DVC1",
1858 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1859 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1860 2662a059 j_mayer
                 0x00000000);
1861 76a66253 j_mayer
    /* XXX : not implemented */
1862 2662a059 j_mayer
    spr_register(env, SPR_405_DVC2, "DVC2",
1863 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1864 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1865 76a66253 j_mayer
                 0x00000000);
1866 76a66253 j_mayer
    /* XXX : not implemented */
1867 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
1868 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1869 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1870 76a66253 j_mayer
                 0x00000000);
1871 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
1872 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1873 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1874 76a66253 j_mayer
                 0x00000000);
1875 76a66253 j_mayer
    /* XXX : not implemented */
1876 76a66253 j_mayer
    spr_register(env, SPR_405_IAC3, "IAC3",
1877 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1878 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1879 76a66253 j_mayer
                 0x00000000);
1880 76a66253 j_mayer
    /* XXX : not implemented */
1881 76a66253 j_mayer
    spr_register(env, SPR_405_IAC4, "IAC4",
1882 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1883 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1884 76a66253 j_mayer
                 0x00000000);
1885 76a66253 j_mayer
    /* Storage control */
1886 035feb88 j_mayer
    /* XXX: TODO: not implemented */
1887 76a66253 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
1888 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1889 c294fc58 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
1890 76a66253 j_mayer
                 0x00000000);
1891 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
1892 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1893 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1894 2662a059 j_mayer
                 0x00000000);
1895 76a66253 j_mayer
    /* XXX : not implemented */
1896 76a66253 j_mayer
    spr_register(env, SPR_405_SU0R, "SU0R",
1897 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1898 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1899 76a66253 j_mayer
                 0x00000000);
1900 76a66253 j_mayer
    /* SPRG */
1901 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1902 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1903 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1904 76a66253 j_mayer
                 0x00000000);
1905 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1906 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1907 04f20795 j_mayer
                 &spr_read_generic, &spr_write_generic,
1908 76a66253 j_mayer
                 0x00000000);
1909 76a66253 j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
1910 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1911 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1912 76a66253 j_mayer
                 0x00000000);
1913 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1914 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1915 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1916 76a66253 j_mayer
                 0x00000000);
1917 76a66253 j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
1918 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1919 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1920 76a66253 j_mayer
                 0x00000000);
1921 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1922 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1923 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1924 76a66253 j_mayer
                 0x00000000);
1925 76a66253 j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
1926 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1927 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1928 76a66253 j_mayer
                 0x00000000);
1929 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1930 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1931 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1932 76a66253 j_mayer
                 0x00000000);
1933 76a66253 j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
1934 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1935 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1936 76a66253 j_mayer
                 0x00000000);
1937 76a66253 j_mayer
}
1938 76a66253 j_mayer
1939 76a66253 j_mayer
/* SPR shared between PowerPC 401 & 403 implementations */
1940 76a66253 j_mayer
static void gen_spr_401_403 (CPUPPCState *env)
1941 76a66253 j_mayer
{
1942 76a66253 j_mayer
    /* Time base */
1943 76a66253 j_mayer
    spr_register(env, SPR_403_VTBL,  "TBL",
1944 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1945 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1946 76a66253 j_mayer
                 0x00000000);
1947 76a66253 j_mayer
    spr_register(env, SPR_403_TBL,   "TBL",
1948 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1949 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbl,
1950 76a66253 j_mayer
                 0x00000000);
1951 76a66253 j_mayer
    spr_register(env, SPR_403_VTBU,  "TBU",
1952 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1953 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1954 76a66253 j_mayer
                 0x00000000);
1955 76a66253 j_mayer
    spr_register(env, SPR_403_TBU,   "TBU",
1956 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1957 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbu,
1958 76a66253 j_mayer
                 0x00000000);
1959 76a66253 j_mayer
    /* Debug */
1960 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1961 76a66253 j_mayer
    spr_register(env, SPR_403_CDBCR, "CDBCR",
1962 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1963 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1964 76a66253 j_mayer
                 0x00000000);
1965 76a66253 j_mayer
}
1966 76a66253 j_mayer
1967 2662a059 j_mayer
/* SPR specific to PowerPC 401 implementation */
1968 2662a059 j_mayer
static void gen_spr_401 (CPUPPCState *env)
1969 2662a059 j_mayer
{
1970 2662a059 j_mayer
    /* Debug interface */
1971 2662a059 j_mayer
    /* XXX : not implemented */
1972 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR",
1973 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1974 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1975 2662a059 j_mayer
                 0x00000000);
1976 2662a059 j_mayer
    /* XXX : not implemented */
1977 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1978 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1979 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
1980 2662a059 j_mayer
                 /* Last reset was system reset */
1981 2662a059 j_mayer
                 0x00000300);
1982 2662a059 j_mayer
    /* XXX : not implemented */
1983 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC",
1984 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1985 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1986 2662a059 j_mayer
                 0x00000000);
1987 2662a059 j_mayer
    /* XXX : not implemented */
1988 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC",
1989 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1990 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1991 2662a059 j_mayer
                 0x00000000);
1992 2662a059 j_mayer
    /* Storage control */
1993 035feb88 j_mayer
    /* XXX: TODO: not implemented */
1994 2662a059 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
1995 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1996 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
1997 2662a059 j_mayer
                 0x00000000);
1998 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
1999 035feb88 j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
2000 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2001 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
2002 035feb88 j_mayer
                 0xFFFFFFFF);
2003 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
2004 035feb88 j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
2005 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2006 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
2007 035feb88 j_mayer
                 0x00000000);
2008 2662a059 j_mayer
}
2009 2662a059 j_mayer
2010 a750fc0b j_mayer
static void gen_spr_401x2 (CPUPPCState *env)
2011 a750fc0b j_mayer
{
2012 a750fc0b j_mayer
    gen_spr_401(env);
2013 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
2014 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2015 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2016 a750fc0b j_mayer
                 0x00000000);
2017 a750fc0b j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
2018 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2019 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2020 a750fc0b j_mayer
                 0x00000000);
2021 a750fc0b j_mayer
}
2022 a750fc0b j_mayer
2023 76a66253 j_mayer
/* SPR specific to PowerPC 403 implementation */
2024 76a66253 j_mayer
static void gen_spr_403 (CPUPPCState *env)
2025 76a66253 j_mayer
{
2026 2662a059 j_mayer
    /* Debug interface */
2027 2662a059 j_mayer
    /* XXX : not implemented */
2028 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
2029 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2030 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
2031 2662a059 j_mayer
                 0x00000000);
2032 2662a059 j_mayer
    /* XXX : not implemented */
2033 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
2034 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2035 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
2036 2662a059 j_mayer
                 /* Last reset was system reset */
2037 2662a059 j_mayer
                 0x00000300);
2038 2662a059 j_mayer
    /* XXX : not implemented */
2039 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
2040 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2041 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2042 2662a059 j_mayer
                 0x00000000);
2043 578bb252 j_mayer
    /* XXX : not implemented */
2044 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
2045 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2046 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2047 2662a059 j_mayer
                 0x00000000);
2048 2662a059 j_mayer
    /* XXX : not implemented */
2049 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
2050 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2051 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2052 2662a059 j_mayer
                 0x00000000);
2053 578bb252 j_mayer
    /* XXX : not implemented */
2054 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
2055 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2056 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2057 2662a059 j_mayer
                 0x00000000);
2058 a750fc0b j_mayer
}
2059 a750fc0b j_mayer
2060 a750fc0b j_mayer
static void gen_spr_403_real (CPUPPCState *env)
2061 a750fc0b j_mayer
{
2062 76a66253 j_mayer
    spr_register(env, SPR_403_PBL1,  "PBL1",
2063 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2064 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2065 76a66253 j_mayer
                 0x00000000);
2066 76a66253 j_mayer
    spr_register(env, SPR_403_PBU1,  "PBU1",
2067 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2068 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2069 76a66253 j_mayer
                 0x00000000);
2070 76a66253 j_mayer
    spr_register(env, SPR_403_PBL2,  "PBL2",
2071 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2072 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2073 76a66253 j_mayer
                 0x00000000);
2074 76a66253 j_mayer
    spr_register(env, SPR_403_PBU2,  "PBU2",
2075 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2076 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2077 76a66253 j_mayer
                 0x00000000);
2078 a750fc0b j_mayer
}
2079 a750fc0b j_mayer
2080 a750fc0b j_mayer
static void gen_spr_403_mmu (CPUPPCState *env)
2081 a750fc0b j_mayer
{
2082 a750fc0b j_mayer
    /* MMU */
2083 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
2084 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2085 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2086 a750fc0b j_mayer
                 0x00000000);
2087 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
2088 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2089 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
2090 76a66253 j_mayer
                 0x00000000);
2091 76a66253 j_mayer
}
2092 76a66253 j_mayer
2093 76a66253 j_mayer
/* SPR specific to PowerPC compression coprocessor extension */
2094 76a66253 j_mayer
static void gen_spr_compress (CPUPPCState *env)
2095 76a66253 j_mayer
{
2096 578bb252 j_mayer
    /* XXX : not implemented */
2097 76a66253 j_mayer
    spr_register(env, SPR_401_SKR, "SKR",
2098 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2099 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
2100 76a66253 j_mayer
                 0x00000000);
2101 76a66253 j_mayer
}
2102 a750fc0b j_mayer
2103 a750fc0b j_mayer
#if defined (TARGET_PPC64)
2104 a750fc0b j_mayer
/* SPR specific to PowerPC 620 */
2105 a750fc0b j_mayer
static void gen_spr_620 (CPUPPCState *env)
2106 a750fc0b j_mayer
{
2107 578bb252 j_mayer
    /* XXX : not implemented */
2108 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR0, "PMR0",
2109 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2110 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2111 a750fc0b j_mayer
                 0x00000000);
2112 578bb252 j_mayer
    /* XXX : not implemented */
2113 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR1, "PMR1",
2114 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2115 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2116 a750fc0b j_mayer
                 0x00000000);
2117 578bb252 j_mayer
    /* XXX : not implemented */
2118 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR2, "PMR2",
2119 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2120 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2121 a750fc0b j_mayer
                 0x00000000);
2122 578bb252 j_mayer
    /* XXX : not implemented */
2123 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR3, "PMR3",
2124 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2125 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2126 a750fc0b j_mayer
                 0x00000000);
2127 578bb252 j_mayer
    /* XXX : not implemented */
2128 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR4, "PMR4",
2129 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2130 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2131 a750fc0b j_mayer
                 0x00000000);
2132 578bb252 j_mayer
    /* XXX : not implemented */
2133 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR5, "PMR5",
2134 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2135 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2136 a750fc0b j_mayer
                 0x00000000);
2137 578bb252 j_mayer
    /* XXX : not implemented */
2138 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR6, "PMR6",
2139 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2140 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2141 a750fc0b j_mayer
                 0x00000000);
2142 578bb252 j_mayer
    /* XXX : not implemented */
2143 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR7, "PMR7",
2144 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2145 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2146 a750fc0b j_mayer
                 0x00000000);
2147 578bb252 j_mayer
    /* XXX : not implemented */
2148 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR8, "PMR8",
2149 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2150 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2151 a750fc0b j_mayer
                 0x00000000);
2152 578bb252 j_mayer
    /* XXX : not implemented */
2153 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR9, "PMR9",
2154 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2155 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2156 a750fc0b j_mayer
                 0x00000000);
2157 578bb252 j_mayer
    /* XXX : not implemented */
2158 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRA, "PMR10",
2159 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2160 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2161 a750fc0b j_mayer
                 0x00000000);
2162 578bb252 j_mayer
    /* XXX : not implemented */
2163 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRB, "PMR11",
2164 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2165 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2166 a750fc0b j_mayer
                 0x00000000);
2167 578bb252 j_mayer
    /* XXX : not implemented */
2168 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRC, "PMR12",
2169 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2170 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2171 a750fc0b j_mayer
                 0x00000000);
2172 578bb252 j_mayer
    /* XXX : not implemented */
2173 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRD, "PMR13",
2174 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2175 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2176 a750fc0b j_mayer
                 0x00000000);
2177 578bb252 j_mayer
    /* XXX : not implemented */
2178 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRE, "PMR14",
2179 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2180 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2181 a750fc0b j_mayer
                 0x00000000);
2182 578bb252 j_mayer
    /* XXX : not implemented */
2183 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRF, "PMR15",
2184 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2185 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2186 a750fc0b j_mayer
                 0x00000000);
2187 578bb252 j_mayer
    /* XXX : not implemented */
2188 a750fc0b j_mayer
    spr_register(env, SPR_620_HID8, "HID8",
2189 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2190 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2191 a750fc0b j_mayer
                 0x00000000);
2192 578bb252 j_mayer
    /* XXX : not implemented */
2193 a750fc0b j_mayer
    spr_register(env, SPR_620_HID9, "HID9",
2194 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2195 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2196 a750fc0b j_mayer
                 0x00000000);
2197 a750fc0b j_mayer
}
2198 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
2199 76a66253 j_mayer
2200 2662a059 j_mayer
// XXX: TODO
2201 76a66253 j_mayer
/*
2202 2662a059 j_mayer
 * AMR     => SPR 29 (Power 2.04)
2203 2662a059 j_mayer
 * CTRL    => SPR 136 (Power 2.04)
2204 2662a059 j_mayer
 * CTRL    => SPR 152 (Power 2.04)
2205 2662a059 j_mayer
 * SCOMC   => SPR 276 (64 bits ?)
2206 2662a059 j_mayer
 * SCOMD   => SPR 277 (64 bits ?)
2207 2662a059 j_mayer
 * TBU40   => SPR 286 (Power 2.04 hypv)
2208 2662a059 j_mayer
 * HSPRG0  => SPR 304 (Power 2.04 hypv)
2209 2662a059 j_mayer
 * HSPRG1  => SPR 305 (Power 2.04 hypv)
2210 2662a059 j_mayer
 * HDSISR  => SPR 306 (Power 2.04 hypv)
2211 2662a059 j_mayer
 * HDAR    => SPR 307 (Power 2.04 hypv)
2212 2662a059 j_mayer
 * PURR    => SPR 309 (Power 2.04 hypv)
2213 2662a059 j_mayer
 * HDEC    => SPR 310 (Power 2.04 hypv)
2214 2662a059 j_mayer
 * HIOR    => SPR 311 (hypv)
2215 2662a059 j_mayer
 * RMOR    => SPR 312 (970)
2216 2662a059 j_mayer
 * HRMOR   => SPR 313 (Power 2.04 hypv)
2217 2662a059 j_mayer
 * HSRR0   => SPR 314 (Power 2.04 hypv)
2218 2662a059 j_mayer
 * HSRR1   => SPR 315 (Power 2.04 hypv)
2219 2662a059 j_mayer
 * LPCR    => SPR 316 (970)
2220 2662a059 j_mayer
 * LPIDR   => SPR 317 (970)
2221 2662a059 j_mayer
 * SPEFSCR => SPR 512 (Power 2.04 emb)
2222 2662a059 j_mayer
 * EPR     => SPR 702 (Power 2.04 emb)
2223 2662a059 j_mayer
 * perf    => 768-783 (Power 2.04)
2224 2662a059 j_mayer
 * perf    => 784-799 (Power 2.04)
2225 2662a059 j_mayer
 * PPR     => SPR 896 (Power 2.04)
2226 2662a059 j_mayer
 * EPLC    => SPR 947 (Power 2.04 emb)
2227 2662a059 j_mayer
 * EPSC    => SPR 948 (Power 2.04 emb)
2228 2662a059 j_mayer
 * DABRX   => 1015    (Power 2.04 hypv)
2229 2662a059 j_mayer
 * FPECR   => SPR 1022 (?)
2230 76a66253 j_mayer
 * ... and more (thermal management, performance counters, ...)
2231 76a66253 j_mayer
 */
2232 76a66253 j_mayer
2233 a750fc0b j_mayer
/*****************************************************************************/
2234 e1833e1f j_mayer
/* Exception vectors models                                                  */
2235 e1833e1f j_mayer
static void init_excp_4xx_real (CPUPPCState *env)
2236 e1833e1f j_mayer
{
2237 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2238 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2239 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2240 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2241 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2242 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2243 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2244 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2245 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2246 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2247 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2248 6f5d427d j_mayer
    env->excp_prefix = 0x00000000;
2249 6f5d427d j_mayer
    env->ivor_mask = 0x0000FFF0;
2250 6f5d427d j_mayer
    env->ivpr_mask = 0xFFFF0000;
2251 1c27f8fb j_mayer
    /* Hardware reset vector */
2252 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2253 e1833e1f j_mayer
#endif
2254 e1833e1f j_mayer
}
2255 e1833e1f j_mayer
2256 e1833e1f j_mayer
static void init_excp_4xx_softmmu (CPUPPCState *env)
2257 e1833e1f j_mayer
{
2258 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2259 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2260 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2261 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2262 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2263 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2264 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2265 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2266 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2267 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2268 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2269 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2270 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001100;
2271 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001200;
2272 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2273 6f5d427d j_mayer
    env->excp_prefix = 0x00000000;
2274 6f5d427d j_mayer
    env->ivor_mask = 0x0000FFF0;
2275 6f5d427d j_mayer
    env->ivpr_mask = 0xFFFF0000;
2276 1c27f8fb j_mayer
    /* Hardware reset vector */
2277 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2278 e1833e1f j_mayer
#endif
2279 e1833e1f j_mayer
}
2280 e1833e1f j_mayer
2281 e1833e1f j_mayer
static void init_excp_BookE (CPUPPCState *env)
2282 e1833e1f j_mayer
{
2283 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2284 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2285 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2286 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2287 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2288 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2289 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2290 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2291 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2292 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2293 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2294 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2295 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2296 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2297 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2298 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2299 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2300 e1833e1f j_mayer
    env->excp_prefix = 0x00000000;
2301 e1833e1f j_mayer
    env->ivor_mask = 0x0000FFE0;
2302 e1833e1f j_mayer
    env->ivpr_mask = 0xFFFF0000;
2303 1c27f8fb j_mayer
    /* Hardware reset vector */
2304 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2305 e1833e1f j_mayer
#endif
2306 e1833e1f j_mayer
}
2307 e1833e1f j_mayer
2308 e1833e1f j_mayer
static void init_excp_601 (CPUPPCState *env)
2309 e1833e1f j_mayer
{
2310 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2311 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2312 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2313 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2314 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2315 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2316 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2317 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2318 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2319 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2320 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IO]       = 0x00000A00;
2321 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2322 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RUNM]     = 0x00002000;
2323 e1833e1f j_mayer
    env->excp_prefix = 0xFFF00000;
2324 1c27f8fb j_mayer
    /* Hardware reset vector */
2325 4e80effc j_mayer
    env->hreset_vector = 0x00000100UL;
2326 e1833e1f j_mayer
#endif
2327 e1833e1f j_mayer
}
2328 e1833e1f j_mayer
2329 e1833e1f j_mayer
static void init_excp_602 (CPUPPCState *env)
2330 e1833e1f j_mayer
{
2331 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2332 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2333 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2334 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2335 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2336 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2337 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2338 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2339 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2340 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2341 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2342 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2343 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2344 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2345 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2346 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2347 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2348 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2349 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001500;
2350 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001600;
2351 e1833e1f j_mayer
    env->excp_prefix = 0xFFF00000;
2352 1c27f8fb j_mayer
    /* Hardware reset vector */
2353 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2354 e1833e1f j_mayer
#endif
2355 e1833e1f j_mayer
}
2356 e1833e1f j_mayer
2357 e1833e1f j_mayer
static void init_excp_603 (CPUPPCState *env)
2358 e1833e1f j_mayer
{
2359 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2360 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2361 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2362 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2363 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2364 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2365 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2366 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2367 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2368 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2369 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2370 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2371 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2372 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2373 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2374 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2375 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2376 1c27f8fb j_mayer
    /* Hardware reset vector */
2377 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2378 e1833e1f j_mayer
#endif
2379 e1833e1f j_mayer
}
2380 e1833e1f j_mayer
2381 e1833e1f j_mayer
static void init_excp_G2 (CPUPPCState *env)
2382 e1833e1f j_mayer
{
2383 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2384 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2385 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2386 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2387 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2388 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2389 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2390 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2391 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2392 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2393 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000A00;
2394 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2395 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2396 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2397 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2398 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2399 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2400 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2401 1c27f8fb j_mayer
    /* Hardware reset vector */
2402 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2403 e1833e1f j_mayer
#endif
2404 e1833e1f j_mayer
}
2405 e1833e1f j_mayer
2406 e1833e1f j_mayer
static void init_excp_604 (CPUPPCState *env)
2407 e1833e1f j_mayer
{
2408 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2409 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2410 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2411 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2412 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2413 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2414 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2415 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2416 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2417 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2418 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2419 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2420 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2421 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2422 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2423 1c27f8fb j_mayer
    /* Hardware reset vector */
2424 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2425 e1833e1f j_mayer
#endif
2426 e1833e1f j_mayer
}
2427 e1833e1f j_mayer
2428 578bb252 j_mayer
#if defined(TARGET_PPC64)
2429 e1833e1f j_mayer
static void init_excp_620 (CPUPPCState *env)
2430 e1833e1f j_mayer
{
2431 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2432 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2433 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2434 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2435 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2436 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2437 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2438 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2439 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2440 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2441 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2442 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2443 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2444 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2445 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2446 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2447 1c27f8fb j_mayer
    /* Hardware reset vector */
2448 1c27f8fb j_mayer
    env->hreset_vector = 0x0000000000000100ULL; /* ? */
2449 e1833e1f j_mayer
#endif
2450 e1833e1f j_mayer
}
2451 578bb252 j_mayer
#endif /* defined(TARGET_PPC64) */
2452 e1833e1f j_mayer
2453 e1833e1f j_mayer
static void init_excp_7x0 (CPUPPCState *env)
2454 e1833e1f j_mayer
{
2455 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2456 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2457 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2458 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2459 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2460 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2461 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2462 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2463 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2464 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2465 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2466 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2467 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2468 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2469 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2470 1c27f8fb j_mayer
    /* Hardware reset vector */
2471 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2472 e1833e1f j_mayer
#endif
2473 e1833e1f j_mayer
}
2474 e1833e1f j_mayer
2475 e1833e1f j_mayer
static void init_excp_750FX (CPUPPCState *env)
2476 e1833e1f j_mayer
{
2477 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2478 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2479 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2480 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2481 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2482 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2483 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2484 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2485 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2486 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2487 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2488 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2489 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2490 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2491 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2492 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2493 1c27f8fb j_mayer
    /* Hardware reset vector */
2494 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2495 e1833e1f j_mayer
#endif
2496 e1833e1f j_mayer
}
2497 e1833e1f j_mayer
2498 7a3a6927 j_mayer
/* XXX: Check if this is correct */
2499 7a3a6927 j_mayer
static void init_excp_7x5 (CPUPPCState *env)
2500 7a3a6927 j_mayer
{
2501 7a3a6927 j_mayer
#if !defined(CONFIG_USER_ONLY)
2502 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2503 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2504 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2505 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2506 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2507 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2508 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2509 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2510 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2511 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2512 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2513 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2514 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2515 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2516 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2517 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2518 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2519 7a3a6927 j_mayer
    /* Hardware reset vector */
2520 7a3a6927 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2521 7a3a6927 j_mayer
#endif
2522 7a3a6927 j_mayer
}
2523 7a3a6927 j_mayer
2524 e1833e1f j_mayer
static void init_excp_7400 (CPUPPCState *env)
2525 e1833e1f j_mayer
{
2526 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2527 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2528 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2529 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2530 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2531 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2532 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2533 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2534 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2535 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2536 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2537 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2538 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2539 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2540 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2541 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2542 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2543 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2544 1c27f8fb j_mayer
    /* Hardware reset vector */
2545 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2546 e1833e1f j_mayer
#endif
2547 e1833e1f j_mayer
}
2548 e1833e1f j_mayer
2549 e1833e1f j_mayer
static void init_excp_7450 (CPUPPCState *env)
2550 e1833e1f j_mayer
{
2551 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2552 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2553 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2554 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2555 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2556 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2557 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2558 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2559 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2560 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2561 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2562 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2563 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2564 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2565 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2566 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2567 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2568 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2569 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2570 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2571 1c27f8fb j_mayer
    /* Hardware reset vector */
2572 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2573 e1833e1f j_mayer
#endif
2574 e1833e1f j_mayer
}
2575 e1833e1f j_mayer
2576 e1833e1f j_mayer
#if defined (TARGET_PPC64)
2577 e1833e1f j_mayer
static void init_excp_970 (CPUPPCState *env)
2578 e1833e1f j_mayer
{
2579 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2580 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2581 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2582 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2583 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
2584 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2585 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
2586 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2587 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2588 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2589 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2590 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2591 e1833e1f j_mayer
#if defined(TARGET_PPC64H) /* PowerPC 64 with hypervisor mode support */
2592 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
2593 e1833e1f j_mayer
#endif
2594 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2595 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2596 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2597 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2598 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2599 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
2600 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
2601 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
2602 1c27f8fb j_mayer
    /* Hardware reset vector */
2603 1c27f8fb j_mayer
    env->hreset_vector = 0x0000000000000100ULL;
2604 e1833e1f j_mayer
#endif
2605 e1833e1f j_mayer
}
2606 e1833e1f j_mayer
#endif
2607 e1833e1f j_mayer
2608 e1833e1f j_mayer
/*****************************************************************************/
2609 a750fc0b j_mayer
/* PowerPC implementations definitions                                       */
2610 76a66253 j_mayer
2611 a750fc0b j_mayer
/* PowerPC 40x instruction set                                               */
2612 d63001d1 j_mayer
#define POWERPC_INSNS_EMB    (PPC_INSNS_BASE | PPC_CACHE_DCBZ | PPC_EMB_COMMON)
2613 76a66253 j_mayer
2614 a750fc0b j_mayer
/* PowerPC 401                                                               */
2615 a750fc0b j_mayer
#define POWERPC_INSNS_401    (POWERPC_INSNS_EMB |                             \
2616 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2617 a750fc0b j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2618 a750fc0b j_mayer
#define POWERPC_MSRM_401     (0x00000000000FD201ULL)
2619 a750fc0b j_mayer
#define POWERPC_MMU_401      (POWERPC_MMU_REAL_4xx)
2620 a750fc0b j_mayer
#define POWERPC_EXCP_401     (POWERPC_EXCP_40x)
2621 a750fc0b j_mayer
#define POWERPC_INPUT_401    (PPC_FLAGS_INPUT_401)
2622 237c0af0 j_mayer
#define POWERPC_BFDM_401     (bfd_mach_ppc_403)
2623 25ba3a68 j_mayer
#define POWERPC_FLAG_401     (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2624 76a66253 j_mayer
2625 a750fc0b j_mayer
static void init_proc_401 (CPUPPCState *env)
2626 a750fc0b j_mayer
{
2627 a750fc0b j_mayer
    gen_spr_40x(env);
2628 a750fc0b j_mayer
    gen_spr_401_403(env);
2629 a750fc0b j_mayer
    gen_spr_401(env);
2630 e1833e1f j_mayer
    init_excp_4xx_real(env);
2631 d63001d1 j_mayer
    env->dcache_line_size = 32;
2632 d63001d1 j_mayer
    env->icache_line_size = 32;
2633 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
2634 4e290a0b j_mayer
    ppc40x_irq_init(env);
2635 a750fc0b j_mayer
}
2636 76a66253 j_mayer
2637 a750fc0b j_mayer
/* PowerPC 401x2                                                             */
2638 a750fc0b j_mayer
#define POWERPC_INSNS_401x2  (POWERPC_INSNS_EMB |                             \
2639 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2640 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2641 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MFTB |                     \
2642 a750fc0b j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2643 a750fc0b j_mayer
#define POWERPC_MSRM_401x2   (0x00000000001FD231ULL)
2644 a750fc0b j_mayer
#define POWERPC_MMU_401x2    (POWERPC_MMU_SOFT_4xx_Z)
2645 a750fc0b j_mayer
#define POWERPC_EXCP_401x2   (POWERPC_EXCP_40x)
2646 a750fc0b j_mayer
#define POWERPC_INPUT_401x2  (PPC_FLAGS_INPUT_401)
2647 237c0af0 j_mayer
#define POWERPC_BFDM_401x2   (bfd_mach_ppc_403)
2648 25ba3a68 j_mayer
#define POWERPC_FLAG_401x2   (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2649 a750fc0b j_mayer
2650 a750fc0b j_mayer
static void init_proc_401x2 (CPUPPCState *env)
2651 a750fc0b j_mayer
{
2652 a750fc0b j_mayer
    gen_spr_40x(env);
2653 a750fc0b j_mayer
    gen_spr_401_403(env);
2654 a750fc0b j_mayer
    gen_spr_401x2(env);
2655 a750fc0b j_mayer
    gen_spr_compress(env);
2656 a750fc0b j_mayer
    /* Memory management */
2657 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2658 a750fc0b j_mayer
    env->nb_tlb = 64;
2659 a750fc0b j_mayer
    env->nb_ways = 1;
2660 a750fc0b j_mayer
    env->id_tlbs = 0;
2661 f2e63a42 j_mayer
#endif
2662 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
2663 d63001d1 j_mayer
    env->dcache_line_size = 32;
2664 d63001d1 j_mayer
    env->icache_line_size = 32;
2665 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
2666 4e290a0b j_mayer
    ppc40x_irq_init(env);
2667 76a66253 j_mayer
}
2668 76a66253 j_mayer
2669 a750fc0b j_mayer
/* PowerPC 401x3                                                             */
2670 a750fc0b j_mayer
#define POWERPC_INSNS_401x3  (POWERPC_INSNS_EMB |                             \
2671 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2672 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2673 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MFTB |                     \
2674 a750fc0b j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2675 a750fc0b j_mayer
#define POWERPC_MSRM_401x3   (0x00000000001FD631ULL)
2676 a750fc0b j_mayer
#define POWERPC_MMU_401x3    (POWERPC_MMU_SOFT_4xx_Z)
2677 a750fc0b j_mayer
#define POWERPC_EXCP_401x3   (POWERPC_EXCP_40x)
2678 a750fc0b j_mayer
#define POWERPC_INPUT_401x3  (PPC_FLAGS_INPUT_401)
2679 237c0af0 j_mayer
#define POWERPC_BFDM_401x3   (bfd_mach_ppc_403)
2680 25ba3a68 j_mayer
#define POWERPC_FLAG_401x3   (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2681 a750fc0b j_mayer
2682 578bb252 j_mayer
__attribute__ (( unused ))
2683 e1833e1f j_mayer
static void init_proc_401x3 (CPUPPCState *env)
2684 76a66253 j_mayer
{
2685 4e290a0b j_mayer
    gen_spr_40x(env);
2686 4e290a0b j_mayer
    gen_spr_401_403(env);
2687 4e290a0b j_mayer
    gen_spr_401(env);
2688 4e290a0b j_mayer
    gen_spr_401x2(env);
2689 4e290a0b j_mayer
    gen_spr_compress(env);
2690 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
2691 d63001d1 j_mayer
    env->dcache_line_size = 32;
2692 d63001d1 j_mayer
    env->icache_line_size = 32;
2693 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
2694 4e290a0b j_mayer
    ppc40x_irq_init(env);
2695 3fc6c082 bellard
}
2696 a750fc0b j_mayer
2697 a750fc0b j_mayer
/* IOP480                                                                    */
2698 a750fc0b j_mayer
#define POWERPC_INSNS_IOP480 (POWERPC_INSNS_EMB |                             \
2699 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2700 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2701 a750fc0b j_mayer
                              PPC_CACHE_DCBA |                                \
2702 a750fc0b j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP |  PPC_40x_ICBT)
2703 a750fc0b j_mayer
#define POWERPC_MSRM_IOP480  (0x00000000001FD231ULL)
2704 a750fc0b j_mayer
#define POWERPC_MMU_IOP480   (POWERPC_MMU_SOFT_4xx_Z)
2705 a750fc0b j_mayer
#define POWERPC_EXCP_IOP480  (POWERPC_EXCP_40x)
2706 a750fc0b j_mayer
#define POWERPC_INPUT_IOP480 (PPC_FLAGS_INPUT_401)
2707 237c0af0 j_mayer
#define POWERPC_BFDM_IOP480  (bfd_mach_ppc_403)
2708 25ba3a68 j_mayer
#define POWERPC_FLAG_IOP480  (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2709 a750fc0b j_mayer
2710 a750fc0b j_mayer
static void init_proc_IOP480 (CPUPPCState *env)
2711 3fc6c082 bellard
{
2712 a750fc0b j_mayer
    gen_spr_40x(env);
2713 a750fc0b j_mayer
    gen_spr_401_403(env);
2714 a750fc0b j_mayer
    gen_spr_401x2(env);
2715 a750fc0b j_mayer
    gen_spr_compress(env);
2716 a750fc0b j_mayer
    /* Memory management */
2717 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2718 a750fc0b j_mayer
    env->nb_tlb = 64;
2719 a750fc0b j_mayer
    env->nb_ways = 1;
2720 a750fc0b j_mayer
    env->id_tlbs = 0;
2721 f2e63a42 j_mayer
#endif
2722 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
2723 d63001d1 j_mayer
    env->dcache_line_size = 32;
2724 d63001d1 j_mayer
    env->icache_line_size = 32;
2725 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
2726 4e290a0b j_mayer
    ppc40x_irq_init(env);
2727 3fc6c082 bellard
}
2728 3fc6c082 bellard
2729 a750fc0b j_mayer
/* PowerPC 403                                                               */
2730 a750fc0b j_mayer
#define POWERPC_INSNS_403    (POWERPC_INSNS_EMB |                             \
2731 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2732 a750fc0b j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2733 a750fc0b j_mayer
#define POWERPC_MSRM_403     (0x000000000007D00DULL)
2734 a750fc0b j_mayer
#define POWERPC_MMU_403      (POWERPC_MMU_REAL_4xx)
2735 a750fc0b j_mayer
#define POWERPC_EXCP_403     (POWERPC_EXCP_40x)
2736 a750fc0b j_mayer
#define POWERPC_INPUT_403    (PPC_FLAGS_INPUT_401)
2737 237c0af0 j_mayer
#define POWERPC_BFDM_403     (bfd_mach_ppc_403)
2738 25ba3a68 j_mayer
#define POWERPC_FLAG_403     (POWERPC_FLAG_CE | POWERPC_FLAG_PX)
2739 a750fc0b j_mayer
2740 a750fc0b j_mayer
static void init_proc_403 (CPUPPCState *env)
2741 3fc6c082 bellard
{
2742 a750fc0b j_mayer
    gen_spr_40x(env);
2743 a750fc0b j_mayer
    gen_spr_401_403(env);
2744 a750fc0b j_mayer
    gen_spr_403(env);
2745 a750fc0b j_mayer
    gen_spr_403_real(env);
2746 e1833e1f j_mayer
    init_excp_4xx_real(env);
2747 d63001d1 j_mayer
    env->dcache_line_size = 32;
2748 d63001d1 j_mayer
    env->icache_line_size = 32;
2749 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
2750 4e290a0b j_mayer
    ppc40x_irq_init(env);
2751 d63001d1 j_mayer
#if !defined(CONFIG_USER_ONLY)
2752 d63001d1 j_mayer
    /* Hardware reset vector */
2753 d63001d1 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2754 d63001d1 j_mayer
#endif
2755 3fc6c082 bellard
}
2756 3fc6c082 bellard
2757 a750fc0b j_mayer
/* PowerPC 403 GCX                                                           */
2758 a750fc0b j_mayer
#define POWERPC_INSNS_403GCX (POWERPC_INSNS_EMB |                             \
2759 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2760 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2761 a750fc0b j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2762 a750fc0b j_mayer
#define POWERPC_MSRM_403GCX  (0x000000000007D00DULL)
2763 a750fc0b j_mayer
#define POWERPC_MMU_403GCX   (POWERPC_MMU_SOFT_4xx_Z)
2764 a750fc0b j_mayer
#define POWERPC_EXCP_403GCX  (POWERPC_EXCP_40x)
2765 a750fc0b j_mayer
#define POWERPC_INPUT_403GCX (PPC_FLAGS_INPUT_401)
2766 237c0af0 j_mayer
#define POWERPC_BFDM_403GCX  (bfd_mach_ppc_403)
2767 25ba3a68 j_mayer
#define POWERPC_FLAG_403GCX  (POWERPC_FLAG_CE | POWERPC_FLAG_PX)
2768 a750fc0b j_mayer
2769 a750fc0b j_mayer
static void init_proc_403GCX (CPUPPCState *env)
2770 3fc6c082 bellard
{
2771 a750fc0b j_mayer
    gen_spr_40x(env);
2772 a750fc0b j_mayer
    gen_spr_401_403(env);
2773 a750fc0b j_mayer
    gen_spr_403(env);
2774 a750fc0b j_mayer
    gen_spr_403_real(env);
2775 a750fc0b j_mayer
    gen_spr_403_mmu(env);
2776 a750fc0b j_mayer
    /* Bus access control */
2777 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
2778 a750fc0b j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
2779 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2780 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2781 a750fc0b j_mayer
                 0xFFFFFFFF);
2782 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
2783 a750fc0b j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
2784 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2785 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2786 a750fc0b j_mayer
                 0x00000000);
2787 a750fc0b j_mayer
    /* Memory management */
2788 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2789 a750fc0b j_mayer
    env->nb_tlb = 64;
2790 a750fc0b j_mayer
    env->nb_ways = 1;
2791 a750fc0b j_mayer
    env->id_tlbs = 0;
2792 f2e63a42 j_mayer
#endif
2793 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
2794 d63001d1 j_mayer
    env->dcache_line_size = 32;
2795 d63001d1 j_mayer
    env->icache_line_size = 32;
2796 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
2797 4e290a0b j_mayer
    ppc40x_irq_init(env);
2798 3fc6c082 bellard
}
2799 3fc6c082 bellard
2800 a750fc0b j_mayer
/* PowerPC 405                                                               */
2801 a750fc0b j_mayer
#define POWERPC_INSNS_405    (POWERPC_INSNS_EMB | PPC_MFTB |                  \
2802 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_CACHE_DCBA | \
2803 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2804 a750fc0b j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT |  \
2805 a750fc0b j_mayer
                              PPC_405_MAC)
2806 a750fc0b j_mayer
#define POWERPC_MSRM_405     (0x000000000006E630ULL)
2807 a750fc0b j_mayer
#define POWERPC_MMU_405      (POWERPC_MMU_SOFT_4xx)
2808 a750fc0b j_mayer
#define POWERPC_EXCP_405     (POWERPC_EXCP_40x)
2809 a750fc0b j_mayer
#define POWERPC_INPUT_405    (PPC_FLAGS_INPUT_405)
2810 237c0af0 j_mayer
#define POWERPC_BFDM_405     (bfd_mach_ppc_403)
2811 25ba3a68 j_mayer
#define POWERPC_FLAG_405     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2812 25ba3a68 j_mayer
                              POWERPC_FLAG_DE)
2813 a750fc0b j_mayer
2814 a750fc0b j_mayer
static void init_proc_405 (CPUPPCState *env)
2815 3fc6c082 bellard
{
2816 a750fc0b j_mayer
    /* Time base */
2817 a750fc0b j_mayer
    gen_tbl(env);
2818 a750fc0b j_mayer
    gen_spr_40x(env);
2819 a750fc0b j_mayer
    gen_spr_405(env);
2820 a750fc0b j_mayer
    /* Bus access control */
2821 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
2822 a750fc0b j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
2823 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2824 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2825 a750fc0b j_mayer
                 0xFFFFFFFF);
2826 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
2827 a750fc0b j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
2828 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2829 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2830 a750fc0b j_mayer
                 0x00000000);
2831 a750fc0b j_mayer
    /* Memory management */
2832 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2833 a750fc0b j_mayer
    env->nb_tlb = 64;
2834 a750fc0b j_mayer
    env->nb_ways = 1;
2835 a750fc0b j_mayer
    env->id_tlbs = 0;
2836 f2e63a42 j_mayer
#endif
2837 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
2838 d63001d1 j_mayer
    env->dcache_line_size = 32;
2839 d63001d1 j_mayer
    env->icache_line_size = 32;
2840 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
2841 4e290a0b j_mayer
    ppc40x_irq_init(env);
2842 3fc6c082 bellard
}
2843 3fc6c082 bellard
2844 a750fc0b j_mayer
/* PowerPC 440 EP                                                            */
2845 a750fc0b j_mayer
#define POWERPC_INSNS_440EP  (POWERPC_INSNS_EMB |                             \
2846 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2847 a750fc0b j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2848 a750fc0b j_mayer
                              PPC_440_SPEC | PPC_RFMCI)
2849 a750fc0b j_mayer
#define POWERPC_MSRM_440EP   (0x000000000006D630ULL)
2850 a750fc0b j_mayer
#define POWERPC_MMU_440EP    (POWERPC_MMU_BOOKE)
2851 a750fc0b j_mayer
#define POWERPC_EXCP_440EP   (POWERPC_EXCP_BOOKE)
2852 a750fc0b j_mayer
#define POWERPC_INPUT_440EP  (PPC_FLAGS_INPUT_BookE)
2853 237c0af0 j_mayer
#define POWERPC_BFDM_440EP   (bfd_mach_ppc_403)
2854 25ba3a68 j_mayer
#define POWERPC_FLAG_440EP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2855 25ba3a68 j_mayer
                              POWERPC_FLAG_DE)
2856 a750fc0b j_mayer
2857 a750fc0b j_mayer
static void init_proc_440EP (CPUPPCState *env)
2858 3fc6c082 bellard
{
2859 a750fc0b j_mayer
    /* Time base */
2860 a750fc0b j_mayer
    gen_tbl(env);
2861 a750fc0b j_mayer
    gen_spr_BookE(env);
2862 a750fc0b j_mayer
    gen_spr_440(env);
2863 578bb252 j_mayer
    /* XXX : not implemented */
2864 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
2865 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2866 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2867 a750fc0b j_mayer
                 0x00000000);
2868 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
2869 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2870 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2871 a750fc0b j_mayer
                 0x00000000);
2872 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
2873 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2874 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2875 a750fc0b j_mayer
                 0x00000000);
2876 578bb252 j_mayer
    /* XXX : not implemented */
2877 a750fc0b j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
2878 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2879 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2880 a750fc0b j_mayer
                 0x00000000);
2881 a750fc0b j_mayer
    /* Memory management */
2882 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2883 a750fc0b j_mayer
    env->nb_tlb = 64;
2884 a750fc0b j_mayer
    env->nb_ways = 1;
2885 a750fc0b j_mayer
    env->id_tlbs = 0;
2886 f2e63a42 j_mayer
#endif
2887 e1833e1f j_mayer
    init_excp_BookE(env);
2888 d63001d1 j_mayer
    env->dcache_line_size = 32;
2889 d63001d1 j_mayer
    env->icache_line_size = 32;
2890 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
2891 3fc6c082 bellard
}
2892 3fc6c082 bellard
2893 a750fc0b j_mayer
/* PowerPC 440 GP                                                            */
2894 a750fc0b j_mayer
#define POWERPC_INSNS_440GP  (POWERPC_INSNS_EMB |                             \
2895 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2896 a750fc0b j_mayer
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
2897 a750fc0b j_mayer
                              PPC_405_MAC | PPC_440_SPEC)
2898 a750fc0b j_mayer
#define POWERPC_MSRM_440GP   (0x000000000006FF30ULL)
2899 a750fc0b j_mayer
#define POWERPC_MMU_440GP    (POWERPC_MMU_BOOKE)
2900 a750fc0b j_mayer
#define POWERPC_EXCP_440GP   (POWERPC_EXCP_BOOKE)
2901 a750fc0b j_mayer
#define POWERPC_INPUT_440GP  (PPC_FLAGS_INPUT_BookE)
2902 237c0af0 j_mayer
#define POWERPC_BFDM_440GP   (bfd_mach_ppc_403)
2903 25ba3a68 j_mayer
#define POWERPC_FLAG_440GP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2904 25ba3a68 j_mayer
                              POWERPC_FLAG_DE)
2905 a750fc0b j_mayer
2906 a750fc0b j_mayer
static void init_proc_440GP (CPUPPCState *env)
2907 3fc6c082 bellard
{
2908 a750fc0b j_mayer
    /* Time base */
2909 a750fc0b j_mayer
    gen_tbl(env);
2910 a750fc0b j_mayer
    gen_spr_BookE(env);
2911 a750fc0b j_mayer
    gen_spr_440(env);
2912 a750fc0b j_mayer
    /* Memory management */
2913 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2914 a750fc0b j_mayer
    env->nb_tlb = 64;
2915 a750fc0b j_mayer
    env->nb_ways = 1;
2916 a750fc0b j_mayer
    env->id_tlbs = 0;
2917 f2e63a42 j_mayer
#endif
2918 e1833e1f j_mayer
    init_excp_BookE(env);
2919 d63001d1 j_mayer
    env->dcache_line_size = 32;
2920 d63001d1 j_mayer
    env->icache_line_size = 32;
2921 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
2922 3fc6c082 bellard
}
2923 3fc6c082 bellard
2924 a750fc0b j_mayer
/* PowerPC 440x4                                                             */
2925 a750fc0b j_mayer
#define POWERPC_INSNS_440x4  (POWERPC_INSNS_EMB |                             \
2926 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2927 a750fc0b j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2928 a750fc0b j_mayer
                              PPC_440_SPEC)
2929 a750fc0b j_mayer
#define POWERPC_MSRM_440x4   (0x000000000006FF30ULL)
2930 a750fc0b j_mayer
#define POWERPC_MMU_440x4    (POWERPC_MMU_BOOKE)
2931 a750fc0b j_mayer
#define POWERPC_EXCP_440x4   (POWERPC_EXCP_BOOKE)
2932 a750fc0b j_mayer
#define POWERPC_INPUT_440x4  (PPC_FLAGS_INPUT_BookE)
2933 237c0af0 j_mayer
#define POWERPC_BFDM_440x4   (bfd_mach_ppc_403)
2934 25ba3a68 j_mayer
#define POWERPC_FLAG_440x4   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2935 25ba3a68 j_mayer
                              POWERPC_FLAG_DE)
2936 a750fc0b j_mayer
2937 578bb252 j_mayer
__attribute__ (( unused ))
2938 a750fc0b j_mayer
static void init_proc_440x4 (CPUPPCState *env)
2939 3fc6c082 bellard
{
2940 a750fc0b j_mayer
    /* Time base */
2941 a750fc0b j_mayer
    gen_tbl(env);
2942 a750fc0b j_mayer
    gen_spr_BookE(env);
2943 a750fc0b j_mayer
    gen_spr_440(env);
2944 a750fc0b j_mayer
    /* Memory management */
2945 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2946 a750fc0b j_mayer
    env->nb_tlb = 64;
2947 a750fc0b j_mayer
    env->nb_ways = 1;
2948 a750fc0b j_mayer
    env->id_tlbs = 0;
2949 f2e63a42 j_mayer
#endif
2950 e1833e1f j_mayer
    init_excp_BookE(env);
2951 d63001d1 j_mayer
    env->dcache_line_size = 32;
2952 d63001d1 j_mayer
    env->icache_line_size = 32;
2953 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
2954 3fc6c082 bellard
}
2955 a750fc0b j_mayer
2956 a750fc0b j_mayer
/* PowerPC 440x5                                                             */
2957 a750fc0b j_mayer
#define POWERPC_INSNS_440x5  (POWERPC_INSNS_EMB |                             \
2958 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2959 a750fc0b j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2960 a750fc0b j_mayer
                              PPC_440_SPEC | PPC_RFMCI)
2961 a750fc0b j_mayer
#define POWERPC_MSRM_440x5   (0x000000000006FF30ULL)
2962 a750fc0b j_mayer
#define POWERPC_MMU_440x5    (POWERPC_MMU_BOOKE)
2963 a750fc0b j_mayer
#define POWERPC_EXCP_440x5   (POWERPC_EXCP_BOOKE)
2964 a750fc0b j_mayer
#define POWERPC_INPUT_440x5  (PPC_FLAGS_INPUT_BookE)
2965 237c0af0 j_mayer
#define POWERPC_BFDM_440x5   (bfd_mach_ppc_403)
2966 25ba3a68 j_mayer
#define POWERPC_FLAG_440x5   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |           \
2967 25ba3a68 j_mayer
                              POWERPC_FLAG_DE)
2968 a750fc0b j_mayer
2969 a750fc0b j_mayer
static void init_proc_440x5 (CPUPPCState *env)
2970 3fc6c082 bellard
{
2971 a750fc0b j_mayer
    /* Time base */
2972 a750fc0b j_mayer
    gen_tbl(env);
2973 a750fc0b j_mayer
    gen_spr_BookE(env);
2974 a750fc0b j_mayer
    gen_spr_440(env);
2975 578bb252 j_mayer
    /* XXX : not implemented */
2976 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
2977 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2978 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2979 a750fc0b j_mayer
                 0x00000000);
2980 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
2981 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2982 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2983 a750fc0b j_mayer
                 0x00000000);
2984 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
2985 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2986 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2987 a750fc0b j_mayer
                 0x00000000);
2988 578bb252 j_mayer
    /* XXX : not implemented */
2989 a750fc0b j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
2990 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2991 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2992 a750fc0b j_mayer
                 0x00000000);
2993 a750fc0b j_mayer
    /* Memory management */
2994 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
2995 a750fc0b j_mayer
    env->nb_tlb = 64;
2996 a750fc0b j_mayer
    env->nb_ways = 1;
2997 a750fc0b j_mayer
    env->id_tlbs = 0;
2998 f2e63a42 j_mayer
#endif
2999 e1833e1f j_mayer
    init_excp_BookE(env);
3000 d63001d1 j_mayer
    env->dcache_line_size = 32;
3001 d63001d1 j_mayer
    env->icache_line_size = 32;
3002 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3003 3fc6c082 bellard
}
3004 3fc6c082 bellard
3005 a750fc0b j_mayer
/* PowerPC 460 (guessed)                                                     */
3006 578bb252 j_mayer
#define POWERPC_INSNS_460    (POWERPC_INSNS_EMB |                             \
3007 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
3008 a750fc0b j_mayer
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
3009 a750fc0b j_mayer
                              PPC_405_MAC | PPC_440_SPEC | PPC_DCRUX)
3010 a750fc0b j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3011 a750fc0b j_mayer
#define POWERPC_MMU_460      (POWERPC_MMU_BOOKE)
3012 a750fc0b j_mayer
#define POWERPC_EXCP_460     (POWERPC_EXCP_BOOKE)
3013 a750fc0b j_mayer
#define POWERPC_INPUT_460    (PPC_FLAGS_INPUT_BookE)
3014 237c0af0 j_mayer
#define POWERPC_BFDM_460     (bfd_mach_ppc_403)
3015 25ba3a68 j_mayer
#define POWERPC_FLAG_460     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3016 25ba3a68 j_mayer
                              POWERPC_FLAG_DE)
3017 a750fc0b j_mayer
3018 578bb252 j_mayer
__attribute__ (( unused ))
3019 a750fc0b j_mayer
static void init_proc_460 (CPUPPCState *env)
3020 3fc6c082 bellard
{
3021 e1833e1f j_mayer
    /* Time base */
3022 e1833e1f j_mayer
    gen_tbl(env);
3023 e1833e1f j_mayer
    gen_spr_BookE(env);
3024 e1833e1f j_mayer
    gen_spr_440(env);
3025 578bb252 j_mayer
    /* XXX : not implemented */
3026 e1833e1f j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3027 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3028 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3029 e1833e1f j_mayer
                 0x00000000);
3030 e1833e1f j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3031 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3032 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3033 e1833e1f j_mayer
                 0x00000000);
3034 e1833e1f j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3035 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3036 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3037 e1833e1f j_mayer
                 0x00000000);
3038 578bb252 j_mayer
    /* XXX : not implemented */
3039 e1833e1f j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3040 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3041 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3042 e1833e1f j_mayer
                 0x00000000);
3043 578bb252 j_mayer
    /* XXX : not implemented */
3044 e1833e1f j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3045 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3046 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3047 e1833e1f j_mayer
                 0x00000000);
3048 e1833e1f j_mayer
    /* Memory management */
3049 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3050 e1833e1f j_mayer
    env->nb_tlb = 64;
3051 e1833e1f j_mayer
    env->nb_ways = 1;
3052 e1833e1f j_mayer
    env->id_tlbs = 0;
3053 f2e63a42 j_mayer
#endif
3054 e1833e1f j_mayer
    init_excp_BookE(env);
3055 d63001d1 j_mayer
    env->dcache_line_size = 32;
3056 d63001d1 j_mayer
    env->icache_line_size = 32;
3057 e1833e1f j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3058 3fc6c082 bellard
}
3059 a750fc0b j_mayer
3060 a750fc0b j_mayer
/* PowerPC 460F (guessed)                                                    */
3061 a750fc0b j_mayer
#define POWERPC_INSNS_460F   (POWERPC_INSNS_EMB |                             \
3062 a750fc0b j_mayer
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
3063 a750fc0b j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSQRT | PPC_FLOAT_FRES |  \
3064 a750fc0b j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_FSEL |            \
3065 a750fc0b j_mayer
                              PPC_FLOAT_STFIWX |                              \
3066 a750fc0b j_mayer
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
3067 a750fc0b j_mayer
                              PPC_405_MAC | PPC_440_SPEC | PPC_DCRUX)
3068 a750fc0b j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3069 a750fc0b j_mayer
#define POWERPC_MMU_460F     (POWERPC_MMU_BOOKE)
3070 a750fc0b j_mayer
#define POWERPC_EXCP_460F    (POWERPC_EXCP_BOOKE)
3071 a750fc0b j_mayer
#define POWERPC_INPUT_460F   (PPC_FLAGS_INPUT_BookE)
3072 237c0af0 j_mayer
#define POWERPC_BFDM_460F    (bfd_mach_ppc_403)
3073 25ba3a68 j_mayer
#define POWERPC_FLAG_460F    (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3074 25ba3a68 j_mayer
                              POWERPC_FLAG_DE)
3075 a750fc0b j_mayer
3076 578bb252 j_mayer
__attribute__ (( unused ))
3077 e1833e1f j_mayer
static void init_proc_460F (CPUPPCState *env)
3078 3fc6c082 bellard
{
3079 a750fc0b j_mayer
    /* Time base */
3080 a750fc0b j_mayer
    gen_tbl(env);
3081 a750fc0b j_mayer
    gen_spr_BookE(env);
3082 a750fc0b j_mayer
    gen_spr_440(env);
3083 578bb252 j_mayer
    /* XXX : not implemented */
3084 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3085 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3086 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3087 a750fc0b j_mayer
                 0x00000000);
3088 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3089 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3090 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3091 a750fc0b j_mayer
                 0x00000000);
3092 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3093 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3094 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3095 a750fc0b j_mayer
                 0x00000000);
3096 578bb252 j_mayer
    /* XXX : not implemented */
3097 a750fc0b j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3098 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3099 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3100 a750fc0b j_mayer
                 0x00000000);
3101 578bb252 j_mayer
    /* XXX : not implemented */
3102 a750fc0b j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3103 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3104 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3105 a750fc0b j_mayer
                 0x00000000);
3106 a750fc0b j_mayer
    /* Memory management */
3107 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3108 a750fc0b j_mayer
    env->nb_tlb = 64;
3109 a750fc0b j_mayer
    env->nb_ways = 1;
3110 a750fc0b j_mayer
    env->id_tlbs = 0;
3111 f2e63a42 j_mayer
#endif
3112 e1833e1f j_mayer
    init_excp_BookE(env);
3113 d63001d1 j_mayer
    env->dcache_line_size = 32;
3114 d63001d1 j_mayer
    env->icache_line_size = 32;
3115 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3116 3fc6c082 bellard
}
3117 a750fc0b j_mayer
3118 a750fc0b j_mayer
/* Generic BookE PowerPC                                                     */
3119 a750fc0b j_mayer
#define POWERPC_INSNS_BookE  (POWERPC_INSNS_EMB |                             \
3120 a750fc0b j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_TLBSYNC |               \
3121 a750fc0b j_mayer
                              PPC_CACHE_DCBA |                                \
3122 a750fc0b j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSQRT |                   \
3123 a750fc0b j_mayer
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3124 a750fc0b j_mayer
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIW |              \
3125 a750fc0b j_mayer
                              PPC_BOOKE)
3126 a750fc0b j_mayer
#define POWERPC_MSRM_BookE   (0x000000000006D630ULL)
3127 a750fc0b j_mayer
#define POWERPC_MMU_BookE    (POWERPC_MMU_BOOKE)
3128 a750fc0b j_mayer
#define POWERPC_EXCP_BookE   (POWERPC_EXCP_BOOKE)
3129 a750fc0b j_mayer
#define POWERPC_INPUT_BookE  (PPC_FLAGS_INPUT_BookE)
3130 237c0af0 j_mayer
#define POWERPC_BFDM_BookE   (bfd_mach_ppc_403)
3131 d26bfc9a j_mayer
#define POWERPC_FLAG_BookE   (POWERPC_FLAG_NONE)
3132 a750fc0b j_mayer
3133 578bb252 j_mayer
__attribute__ (( unused ))
3134 a750fc0b j_mayer
static void init_proc_BookE (CPUPPCState *env)
3135 3fc6c082 bellard
{
3136 e1833e1f j_mayer
    init_excp_BookE(env);
3137 d63001d1 j_mayer
    env->dcache_line_size = 32;
3138 d63001d1 j_mayer
    env->icache_line_size = 32;
3139 3fc6c082 bellard
}
3140 a750fc0b j_mayer
3141 a750fc0b j_mayer
/* e200 core                                                                 */
3142 a750fc0b j_mayer
3143 a750fc0b j_mayer
/* e300 core                                                                 */
3144 a750fc0b j_mayer
3145 a750fc0b j_mayer
/* e500 core                                                                 */
3146 a750fc0b j_mayer
#define POWERPC_INSNS_e500   (POWERPC_INSNS_EMB |                             \
3147 a750fc0b j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_TLBSYNC |               \
3148 a750fc0b j_mayer
                              PPC_CACHE_DCBA |                                \
3149 a750fc0b j_mayer
                              PPC_BOOKE | PPC_E500_VECTOR)
3150 a750fc0b j_mayer
#define POWERPC_MMU_e500     (POWERPC_MMU_SOFT_4xx)
3151 a750fc0b j_mayer
#define POWERPC_EXCP_e500    (POWERPC_EXCP_40x)
3152 a750fc0b j_mayer
#define POWERPC_INPUT_e500   (PPC_FLAGS_INPUT_BookE)
3153 237c0af0 j_mayer
#define POWERPC_BFDM_e500    (bfd_mach_ppc_403)
3154 d26bfc9a j_mayer
#define POWERPC_FLAG_e500    (POWERPC_FLAG_SPE)
3155 a750fc0b j_mayer
3156 578bb252 j_mayer
__attribute__ (( unused ))
3157 a750fc0b j_mayer
static void init_proc_e500 (CPUPPCState *env)
3158 3fc6c082 bellard
{
3159 a750fc0b j_mayer
    /* Time base */
3160 a750fc0b j_mayer
    gen_tbl(env);
3161 a750fc0b j_mayer
    gen_spr_BookE(env);
3162 a750fc0b j_mayer
    /* Memory management */
3163 a750fc0b j_mayer
    gen_spr_BookE_FSL(env);
3164 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3165 a750fc0b j_mayer
    env->nb_tlb = 64;
3166 a750fc0b j_mayer
    env->nb_ways = 1;
3167 a750fc0b j_mayer
    env->id_tlbs = 0;
3168 f2e63a42 j_mayer
#endif
3169 e1833e1f j_mayer
    init_excp_BookE(env);
3170 d63001d1 j_mayer
    env->dcache_line_size = 32;
3171 d63001d1 j_mayer
    env->icache_line_size = 32;
3172 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3173 3fc6c082 bellard
}
3174 a750fc0b j_mayer
3175 a750fc0b j_mayer
/* e600 core                                                                 */
3176 a750fc0b j_mayer
3177 a750fc0b j_mayer
/* Non-embedded PowerPC                                                      */
3178 a750fc0b j_mayer
/* Base instructions set for all 6xx/7xx/74xx/970 PowerPC                    */
3179 a750fc0b j_mayer
#define POWERPC_INSNS_6xx    (PPC_INSNS_BASE | PPC_FLOAT | PPC_MEM_SYNC |     \
3180 12de9a39 j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_TLBIE)
3181 a750fc0b j_mayer
/* Instructions common to all 6xx/7xx/74xx/970 PowerPC except 601 & 602      */
3182 a750fc0b j_mayer
#define POWERPC_INSNS_WORKS  (POWERPC_INSNS_6xx | PPC_FLOAT_FSQRT |           \
3183 a750fc0b j_mayer
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3184 a750fc0b j_mayer
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |             \
3185 12de9a39 j_mayer
                              PPC_MEM_TLBSYNC | PPC_CACHE_DCBZ | PPC_MFTB |   \
3186 12de9a39 j_mayer
                              PPC_SEGMENT)
3187 a750fc0b j_mayer
3188 a750fc0b j_mayer
/* POWER : same as 601, without mfmsr, mfsr                                  */
3189 a750fc0b j_mayer
#if defined(TODO)
3190 a750fc0b j_mayer
#define POWERPC_INSNS_POWER  (XXX_TODO)
3191 a750fc0b j_mayer
/* POWER RSC (from RAD6000) */
3192 a750fc0b j_mayer
#define POWERPC_MSRM_POWER   (0x00000000FEF0ULL)
3193 a750fc0b j_mayer
#endif /* TODO */
3194 a750fc0b j_mayer
3195 a750fc0b j_mayer
/* PowerPC 601                                                               */
3196 d63001d1 j_mayer
#define POWERPC_INSNS_601    (POWERPC_INSNS_6xx | PPC_CACHE_DCBZ |            \
3197 12de9a39 j_mayer
                              PPC_SEGMENT | PPC_EXTERN | PPC_POWER_BR)
3198 25ba3a68 j_mayer
#define POWERPC_MSRM_601     (0x000000000000FD70ULL)
3199 a13d7523 j_mayer
#define POWERPC_MMU_601      (POWERPC_MMU_32B)
3200 a750fc0b j_mayer
//#define POWERPC_EXCP_601     (POWERPC_EXCP_601)
3201 a750fc0b j_mayer
#define POWERPC_INPUT_601    (PPC_FLAGS_INPUT_6xx)
3202 237c0af0 j_mayer
#define POWERPC_BFDM_601     (bfd_mach_ppc_601)
3203 25ba3a68 j_mayer
#define POWERPC_FLAG_601     (POWERPC_FLAG_SE)
3204 a750fc0b j_mayer
3205 a750fc0b j_mayer
static void init_proc_601 (CPUPPCState *env)
3206 3fc6c082 bellard
{
3207 a750fc0b j_mayer
    gen_spr_ne_601(env);
3208 a750fc0b j_mayer
    gen_spr_601(env);
3209 a750fc0b j_mayer
    /* Hardware implementation registers */
3210 a750fc0b j_mayer
    /* XXX : not implemented */
3211 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3212 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3213 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3214 a750fc0b j_mayer
                 0x00000000);
3215 a750fc0b j_mayer
    /* XXX : not implemented */
3216 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3217 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3218 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3219 a750fc0b j_mayer
                 0x00000000);
3220 a750fc0b j_mayer
    /* XXX : not implemented */
3221 a750fc0b j_mayer
    spr_register(env, SPR_601_HID2, "HID2",
3222 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3223 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3224 a750fc0b j_mayer
                 0x00000000);
3225 a750fc0b j_mayer
    /* XXX : not implemented */
3226 a750fc0b j_mayer
    spr_register(env, SPR_601_HID5, "HID5",
3227 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3228 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3229 a750fc0b j_mayer
                 0x00000000);
3230 a750fc0b j_mayer
    /* XXX : not implemented */
3231 a750fc0b j_mayer
    spr_register(env, SPR_601_HID15, "HID15",
3232 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3233 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3234 a750fc0b j_mayer
                 0x00000000);
3235 a750fc0b j_mayer
    /* Memory management */
3236 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3237 a750fc0b j_mayer
    env->nb_tlb = 64;
3238 a750fc0b j_mayer
    env->nb_ways = 2;
3239 a750fc0b j_mayer
    env->id_tlbs = 0;
3240 f2e63a42 j_mayer
#endif
3241 e1833e1f j_mayer
    init_excp_601(env);
3242 d63001d1 j_mayer
    env->dcache_line_size = 64;
3243 d63001d1 j_mayer
    env->icache_line_size = 64;
3244 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3245 3fc6c082 bellard
}
3246 3fc6c082 bellard
3247 a750fc0b j_mayer
/* PowerPC 602                                                               */
3248 a750fc0b j_mayer
#define POWERPC_INSNS_602    (POWERPC_INSNS_6xx | PPC_MFTB |                  \
3249 a750fc0b j_mayer
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3250 a750fc0b j_mayer
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |             \
3251 d63001d1 j_mayer
                              PPC_6xx_TLB | PPC_MEM_TLBSYNC | PPC_CACHE_DCBZ |\
3252 12de9a39 j_mayer
                              PPC_SEGMENT | PPC_602_SPEC)
3253 a750fc0b j_mayer
#define POWERPC_MSRM_602     (0x000000000033FF73ULL)
3254 a750fc0b j_mayer
#define POWERPC_MMU_602      (POWERPC_MMU_SOFT_6xx)
3255 a750fc0b j_mayer
//#define POWERPC_EXCP_602     (POWERPC_EXCP_602)
3256 a750fc0b j_mayer
#define POWERPC_INPUT_602    (PPC_FLAGS_INPUT_6xx)
3257 237c0af0 j_mayer
#define POWERPC_BFDM_602     (bfd_mach_ppc_602)
3258 25ba3a68 j_mayer
#define POWERPC_FLAG_602     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3259 25ba3a68 j_mayer
                              POWERPC_FLAG_BE)
3260 a750fc0b j_mayer
3261 a750fc0b j_mayer
static void init_proc_602 (CPUPPCState *env)
3262 3fc6c082 bellard
{
3263 a750fc0b j_mayer
    gen_spr_ne_601(env);
3264 a750fc0b j_mayer
    gen_spr_602(env);
3265 a750fc0b j_mayer
    /* Time base */
3266 a750fc0b j_mayer
    gen_tbl(env);
3267 a750fc0b j_mayer
    /* hardware implementation registers */
3268 a750fc0b j_mayer
    /* XXX : not implemented */
3269 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3270 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3271 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3272 a750fc0b j_mayer
                 0x00000000);
3273 a750fc0b j_mayer
    /* XXX : not implemented */
3274 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3275 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3276 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3277 a750fc0b j_mayer
                 0x00000000);
3278 a750fc0b j_mayer
    /* Memory management */
3279 a750fc0b j_mayer
    gen_low_BATs(env);
3280 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3281 e1833e1f j_mayer
    init_excp_602(env);
3282 d63001d1 j_mayer
    env->dcache_line_size = 32;
3283 d63001d1 j_mayer
    env->icache_line_size = 32;
3284 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3285 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3286 a750fc0b j_mayer
}
3287 3fc6c082 bellard
3288 a750fc0b j_mayer
/* PowerPC 603                                                               */
3289 a750fc0b j_mayer
#define POWERPC_INSNS_603    (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3290 25ba3a68 j_mayer
#define POWERPC_MSRM_603     (0x000000000007FF73ULL)
3291 a750fc0b j_mayer
#define POWERPC_MMU_603      (POWERPC_MMU_SOFT_6xx)
3292 a750fc0b j_mayer
//#define POWERPC_EXCP_603     (POWERPC_EXCP_603)
3293 a750fc0b j_mayer
#define POWERPC_INPUT_603    (PPC_FLAGS_INPUT_6xx)
3294 237c0af0 j_mayer
#define POWERPC_BFDM_603     (bfd_mach_ppc_603)
3295 25ba3a68 j_mayer
#define POWERPC_FLAG_603     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3296 25ba3a68 j_mayer
                              POWERPC_FLAG_BE)
3297 a750fc0b j_mayer
3298 a750fc0b j_mayer
static void init_proc_603 (CPUPPCState *env)
3299 a750fc0b j_mayer
{
3300 a750fc0b j_mayer
    gen_spr_ne_601(env);
3301 a750fc0b j_mayer
    gen_spr_603(env);
3302 a750fc0b j_mayer
    /* Time base */
3303 a750fc0b j_mayer
    gen_tbl(env);
3304 a750fc0b j_mayer
    /* hardware implementation registers */
3305 a750fc0b j_mayer
    /* XXX : not implemented */
3306 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3307 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3308 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3309 a750fc0b j_mayer
                 0x00000000);
3310 a750fc0b j_mayer
    /* XXX : not implemented */
3311 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3312 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3313 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3314 a750fc0b j_mayer
                 0x00000000);
3315 a750fc0b j_mayer
    /* Memory management */
3316 a750fc0b j_mayer
    gen_low_BATs(env);
3317 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3318 e1833e1f j_mayer
    init_excp_603(env);
3319 d63001d1 j_mayer
    env->dcache_line_size = 32;
3320 d63001d1 j_mayer
    env->icache_line_size = 32;
3321 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3322 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3323 3fc6c082 bellard
}
3324 3fc6c082 bellard
3325 a750fc0b j_mayer
/* PowerPC 603e                                                              */
3326 a750fc0b j_mayer
#define POWERPC_INSNS_603E   (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3327 a750fc0b j_mayer
#define POWERPC_MSRM_603E    (0x000000000007FF73ULL)
3328 a750fc0b j_mayer
#define POWERPC_MMU_603E     (POWERPC_MMU_SOFT_6xx)
3329 a750fc0b j_mayer
//#define POWERPC_EXCP_603E    (POWERPC_EXCP_603E)
3330 a750fc0b j_mayer
#define POWERPC_INPUT_603E   (PPC_FLAGS_INPUT_6xx)
3331 237c0af0 j_mayer
#define POWERPC_BFDM_603E    (bfd_mach_ppc_ec603e)
3332 25ba3a68 j_mayer
#define POWERPC_FLAG_603E    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3333 25ba3a68 j_mayer
                              POWERPC_FLAG_BE)
3334 a750fc0b j_mayer
3335 a750fc0b j_mayer
static void init_proc_603E (CPUPPCState *env)
3336 a750fc0b j_mayer
{
3337 a750fc0b j_mayer
    gen_spr_ne_601(env);
3338 a750fc0b j_mayer
    gen_spr_603(env);
3339 a750fc0b j_mayer
    /* Time base */
3340 a750fc0b j_mayer
    gen_tbl(env);
3341 a750fc0b j_mayer
    /* hardware implementation registers */
3342 a750fc0b j_mayer
    /* XXX : not implemented */
3343 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3344 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3345 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3346 a750fc0b j_mayer
                 0x00000000);
3347 a750fc0b j_mayer
    /* XXX : not implemented */
3348 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3349 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3350 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3351 a750fc0b j_mayer
                 0x00000000);
3352 a750fc0b j_mayer
    /* XXX : not implemented */
3353 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
3354 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3355 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3356 a750fc0b j_mayer
                 0x00000000);
3357 a750fc0b j_mayer
    /* Memory management */
3358 a750fc0b j_mayer
    gen_low_BATs(env);
3359 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3360 e1833e1f j_mayer
    init_excp_603(env);
3361 d63001d1 j_mayer
    env->dcache_line_size = 32;
3362 d63001d1 j_mayer
    env->icache_line_size = 32;
3363 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3364 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3365 a750fc0b j_mayer
}
3366 a750fc0b j_mayer
3367 a750fc0b j_mayer
/* PowerPC G2                                                                */
3368 a750fc0b j_mayer
#define POWERPC_INSNS_G2     (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3369 a750fc0b j_mayer
#define POWERPC_MSRM_G2      (0x000000000006FFF2ULL)
3370 a750fc0b j_mayer
#define POWERPC_MMU_G2       (POWERPC_MMU_SOFT_6xx)
3371 a750fc0b j_mayer
//#define POWERPC_EXCP_G2      (POWERPC_EXCP_G2)
3372 a750fc0b j_mayer
#define POWERPC_INPUT_G2     (PPC_FLAGS_INPUT_6xx)
3373 237c0af0 j_mayer
#define POWERPC_BFDM_G2      (bfd_mach_ppc_ec603e)
3374 25ba3a68 j_mayer
#define POWERPC_FLAG_G2      (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3375 25ba3a68 j_mayer
                              POWERPC_FLAG_BE)
3376 a750fc0b j_mayer
3377 a750fc0b j_mayer
static void init_proc_G2 (CPUPPCState *env)
3378 a750fc0b j_mayer
{
3379 a750fc0b j_mayer
    gen_spr_ne_601(env);
3380 a750fc0b j_mayer
    gen_spr_G2_755(env);
3381 a750fc0b j_mayer
    gen_spr_G2(env);
3382 a750fc0b j_mayer
    /* Time base */
3383 a750fc0b j_mayer
    gen_tbl(env);
3384 a750fc0b j_mayer
    /* Hardware implementation register */
3385 a750fc0b j_mayer
    /* XXX : not implemented */
3386 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3387 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3388 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3389 a750fc0b j_mayer
                 0x00000000);
3390 a750fc0b j_mayer
    /* XXX : not implemented */
3391 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3392 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3393 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3394 a750fc0b j_mayer
                 0x00000000);
3395 a750fc0b j_mayer
    /* XXX : not implemented */
3396 a750fc0b j_mayer
    spr_register(env, SPR_HID2, "HID2",
3397 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3398 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3399 a750fc0b j_mayer
                 0x00000000);
3400 a750fc0b j_mayer
    /* Memory management */
3401 a750fc0b j_mayer
    gen_low_BATs(env);
3402 a750fc0b j_mayer
    gen_high_BATs(env);
3403 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3404 e1833e1f j_mayer
    init_excp_G2(env);
3405 d63001d1 j_mayer
    env->dcache_line_size = 32;
3406 d63001d1 j_mayer
    env->icache_line_size = 32;
3407 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3408 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3409 a750fc0b j_mayer
}
3410 a750fc0b j_mayer
3411 a750fc0b j_mayer
/* PowerPC G2LE                                                              */
3412 a750fc0b j_mayer
#define POWERPC_INSNS_G2LE   (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3413 a750fc0b j_mayer
#define POWERPC_MSRM_G2LE    (0x000000000007FFF3ULL)
3414 a750fc0b j_mayer
#define POWERPC_MMU_G2LE     (POWERPC_MMU_SOFT_6xx)
3415 a750fc0b j_mayer
#define POWERPC_EXCP_G2LE    (POWERPC_EXCP_G2)
3416 a750fc0b j_mayer
#define POWERPC_INPUT_G2LE   (PPC_FLAGS_INPUT_6xx)
3417 237c0af0 j_mayer
#define POWERPC_BFDM_G2LE    (bfd_mach_ppc_ec603e)
3418 25ba3a68 j_mayer
#define POWERPC_FLAG_G2LE    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3419 25ba3a68 j_mayer
                              POWERPC_FLAG_BE)
3420 a750fc0b j_mayer
3421 a750fc0b j_mayer
static void init_proc_G2LE (CPUPPCState *env)
3422 a750fc0b j_mayer
{
3423 a750fc0b j_mayer
    gen_spr_ne_601(env);
3424 a750fc0b j_mayer
    gen_spr_G2_755(env);
3425 a750fc0b j_mayer
    gen_spr_G2(env);
3426 a750fc0b j_mayer
    /* Time base */
3427 a750fc0b j_mayer
    gen_tbl(env);
3428 a750fc0b j_mayer
    /* Hardware implementation register */
3429 a750fc0b j_mayer
    /* XXX : not implemented */
3430 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3431 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3432 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3433 a750fc0b j_mayer
                 0x00000000);
3434 a750fc0b j_mayer
    /* XXX : not implemented */
3435 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3436 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3437 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3438 a750fc0b j_mayer
                 0x00000000);
3439 a750fc0b j_mayer
    /* XXX : not implemented */
3440 a750fc0b j_mayer
    spr_register(env, SPR_HID2, "HID2",
3441 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3442 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3443 a750fc0b j_mayer
                 0x00000000);
3444 a750fc0b j_mayer
    /* Memory management */
3445 a750fc0b j_mayer
    gen_low_BATs(env);
3446 a750fc0b j_mayer
    gen_high_BATs(env);
3447 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3448 e1833e1f j_mayer
    init_excp_G2(env);
3449 d63001d1 j_mayer
    env->dcache_line_size = 32;
3450 d63001d1 j_mayer
    env->icache_line_size = 32;
3451 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3452 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3453 a750fc0b j_mayer
}
3454 a750fc0b j_mayer
3455 a750fc0b j_mayer
/* PowerPC 604                                                               */
3456 a750fc0b j_mayer
#define POWERPC_INSNS_604    (POWERPC_INSNS_WORKS | PPC_EXTERN)
3457 a750fc0b j_mayer
#define POWERPC_MSRM_604     (0x000000000005FF77ULL)
3458 a750fc0b j_mayer
#define POWERPC_MMU_604      (POWERPC_MMU_32B)
3459 a750fc0b j_mayer
//#define POWERPC_EXCP_604     (POWERPC_EXCP_604)
3460 a750fc0b j_mayer
#define POWERPC_INPUT_604    (PPC_FLAGS_INPUT_6xx)
3461 237c0af0 j_mayer
#define POWERPC_BFDM_604     (bfd_mach_ppc_604)
3462 25ba3a68 j_mayer
#define POWERPC_FLAG_604     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3463 25ba3a68 j_mayer
                              POWERPC_FLAG_PMM)
3464 a750fc0b j_mayer
3465 a750fc0b j_mayer
static void init_proc_604 (CPUPPCState *env)
3466 a750fc0b j_mayer
{
3467 a750fc0b j_mayer
    gen_spr_ne_601(env);
3468 a750fc0b j_mayer
    gen_spr_604(env);
3469 a750fc0b j_mayer
    /* Time base */
3470 a750fc0b j_mayer
    gen_tbl(env);
3471 a750fc0b j_mayer
    /* Hardware implementation registers */
3472 a750fc0b j_mayer
    /* XXX : not implemented */
3473 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3474 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3475 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3476 a750fc0b j_mayer
                 0x00000000);
3477 a750fc0b j_mayer
    /* XXX : not implemented */
3478 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3479 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3480 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3481 a750fc0b j_mayer
                 0x00000000);
3482 a750fc0b j_mayer
    /* Memory management */
3483 a750fc0b j_mayer
    gen_low_BATs(env);
3484 e1833e1f j_mayer
    init_excp_604(env);
3485 d63001d1 j_mayer
    env->dcache_line_size = 32;
3486 d63001d1 j_mayer
    env->icache_line_size = 32;
3487 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3488 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3489 a750fc0b j_mayer
}
3490 a750fc0b j_mayer
3491 a750fc0b j_mayer
/* PowerPC 740/750 (aka G3)                                                  */
3492 a750fc0b j_mayer
#define POWERPC_INSNS_7x0    (POWERPC_INSNS_WORKS | PPC_EXTERN)
3493 25ba3a68 j_mayer
#define POWERPC_MSRM_7x0     (0x000000000005FF77ULL)
3494 a750fc0b j_mayer
#define POWERPC_MMU_7x0      (POWERPC_MMU_32B)
3495 a750fc0b j_mayer
//#define POWERPC_EXCP_7x0     (POWERPC_EXCP_7x0)
3496 a750fc0b j_mayer
#define POWERPC_INPUT_7x0    (PPC_FLAGS_INPUT_6xx)
3497 237c0af0 j_mayer
#define POWERPC_BFDM_7x0     (bfd_mach_ppc_750)
3498 25ba3a68 j_mayer
#define POWERPC_FLAG_7x0     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3499 25ba3a68 j_mayer
                              POWERPC_FLAG_PMM)
3500 a750fc0b j_mayer
3501 a750fc0b j_mayer
static void init_proc_7x0 (CPUPPCState *env)
3502 a750fc0b j_mayer
{
3503 a750fc0b j_mayer
    gen_spr_ne_601(env);
3504 a750fc0b j_mayer
    gen_spr_7xx(env);
3505 a750fc0b j_mayer
    /* Time base */
3506 a750fc0b j_mayer
    gen_tbl(env);
3507 a750fc0b j_mayer
    /* Thermal management */
3508 a750fc0b j_mayer
    gen_spr_thrm(env);
3509 a750fc0b j_mayer
    /* Hardware implementation registers */
3510 a750fc0b j_mayer
    /* XXX : not implemented */
3511 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3512 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3513 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3514 a750fc0b j_mayer
                 0x00000000);
3515 a750fc0b j_mayer
    /* XXX : not implemented */
3516 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3517 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3518 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3519 a750fc0b j_mayer
                 0x00000000);
3520 a750fc0b j_mayer
    /* Memory management */
3521 a750fc0b j_mayer
    gen_low_BATs(env);
3522 e1833e1f j_mayer
    init_excp_7x0(env);
3523 d63001d1 j_mayer
    env->dcache_line_size = 32;
3524 d63001d1 j_mayer
    env->icache_line_size = 32;
3525 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3526 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3527 a750fc0b j_mayer
}
3528 a750fc0b j_mayer
3529 a750fc0b j_mayer
/* PowerPC 750FX/GX                                                          */
3530 a750fc0b j_mayer
#define POWERPC_INSNS_750fx  (POWERPC_INSNS_WORKS | PPC_EXTERN)
3531 25ba3a68 j_mayer
#define POWERPC_MSRM_750fx   (0x000000000005FF77ULL)
3532 a750fc0b j_mayer
#define POWERPC_MMU_750fx    (POWERPC_MMU_32B)
3533 a750fc0b j_mayer
#define POWERPC_EXCP_750fx   (POWERPC_EXCP_7x0)
3534 a750fc0b j_mayer
#define POWERPC_INPUT_750fx  (PPC_FLAGS_INPUT_6xx)
3535 237c0af0 j_mayer
#define POWERPC_BFDM_750fx   (bfd_mach_ppc_750)
3536 25ba3a68 j_mayer
#define POWERPC_FLAG_750fx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3537 25ba3a68 j_mayer
                              POWERPC_FLAG_PMM)
3538 a750fc0b j_mayer
3539 a750fc0b j_mayer
static void init_proc_750fx (CPUPPCState *env)
3540 a750fc0b j_mayer
{
3541 a750fc0b j_mayer
    gen_spr_ne_601(env);
3542 a750fc0b j_mayer
    gen_spr_7xx(env);
3543 a750fc0b j_mayer
    /* Time base */
3544 a750fc0b j_mayer
    gen_tbl(env);
3545 a750fc0b j_mayer
    /* Thermal management */
3546 a750fc0b j_mayer
    gen_spr_thrm(env);
3547 a750fc0b j_mayer
    /* Hardware implementation registers */
3548 a750fc0b j_mayer
    /* XXX : not implemented */
3549 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3550 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3551 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3552 a750fc0b j_mayer
                 0x00000000);
3553 a750fc0b j_mayer
    /* XXX : not implemented */
3554 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3555 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3556 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3557 a750fc0b j_mayer
                 0x00000000);
3558 a750fc0b j_mayer
    /* XXX : not implemented */
3559 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
3560 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3561 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3562 a750fc0b j_mayer
                 0x00000000);
3563 a750fc0b j_mayer
    /* Memory management */
3564 a750fc0b j_mayer
    gen_low_BATs(env);
3565 a750fc0b j_mayer
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
3566 a750fc0b j_mayer
    gen_high_BATs(env);
3567 e1833e1f j_mayer
    init_excp_750FX(env);
3568 d63001d1 j_mayer
    env->dcache_line_size = 32;
3569 d63001d1 j_mayer
    env->icache_line_size = 32;
3570 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3571 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3572 a750fc0b j_mayer
}
3573 a750fc0b j_mayer
3574 a750fc0b j_mayer
/* PowerPC 745/755                                                           */
3575 a750fc0b j_mayer
#define POWERPC_INSNS_7x5    (POWERPC_INSNS_WORKS | PPC_EXTERN | PPC_6xx_TLB)
3576 25ba3a68 j_mayer
#define POWERPC_MSRM_7x5     (0x000000000005FF77ULL)
3577 a750fc0b j_mayer
#define POWERPC_MMU_7x5      (POWERPC_MMU_SOFT_6xx)
3578 a750fc0b j_mayer
//#define POWERPC_EXCP_7x5     (POWERPC_EXCP_7x5)
3579 a750fc0b j_mayer
#define POWERPC_INPUT_7x5    (PPC_FLAGS_INPUT_6xx)
3580 237c0af0 j_mayer
#define POWERPC_BFDM_7x5     (bfd_mach_ppc_750)
3581 25ba3a68 j_mayer
#define POWERPC_FLAG_7x5     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3582 25ba3a68 j_mayer
                              POWERPC_FLAG_PMM)
3583 a750fc0b j_mayer
3584 a750fc0b j_mayer
static void init_proc_7x5 (CPUPPCState *env)
3585 a750fc0b j_mayer
{
3586 a750fc0b j_mayer
    gen_spr_ne_601(env);
3587 a750fc0b j_mayer
    gen_spr_G2_755(env);
3588 a750fc0b j_mayer
    /* Time base */
3589 a750fc0b j_mayer
    gen_tbl(env);
3590 a750fc0b j_mayer
    /* L2 cache control */
3591 a750fc0b j_mayer
    /* XXX : not implemented */
3592 a750fc0b j_mayer
    spr_register(env, SPR_ICTC, "ICTC",
3593 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3594 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3595 a750fc0b j_mayer
                 0x00000000);
3596 a750fc0b j_mayer
    /* XXX : not implemented */
3597 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
3598 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3599 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3600 a750fc0b j_mayer
                 0x00000000);
3601 a750fc0b j_mayer
    /* Hardware implementation registers */
3602 a750fc0b j_mayer
    /* XXX : not implemented */
3603 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
3604 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3605 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3606 a750fc0b j_mayer
                 0x00000000);
3607 a750fc0b j_mayer
    /* XXX : not implemented */
3608 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
3609 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3610 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3611 a750fc0b j_mayer
                 0x00000000);
3612 a750fc0b j_mayer
    /* XXX : not implemented */
3613 a750fc0b j_mayer
    spr_register(env, SPR_HID2, "HID2",
3614 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3615 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3616 a750fc0b j_mayer
                 0x00000000);
3617 a750fc0b j_mayer
    /* Memory management */
3618 a750fc0b j_mayer
    gen_low_BATs(env);
3619 a750fc0b j_mayer
    gen_high_BATs(env);
3620 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3621 7a3a6927 j_mayer
    init_excp_7x5(env);
3622 d63001d1 j_mayer
    env->dcache_line_size = 32;
3623 d63001d1 j_mayer
    env->icache_line_size = 32;
3624 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3625 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3626 d63001d1 j_mayer
#if !defined(CONFIG_USER_ONLY)
3627 d63001d1 j_mayer
    /* Hardware reset vector */
3628 d63001d1 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3629 d63001d1 j_mayer
#endif
3630 a750fc0b j_mayer
}
3631 a750fc0b j_mayer
3632 a750fc0b j_mayer
/* PowerPC 7400 (aka G4)                                                     */
3633 a750fc0b j_mayer
#define POWERPC_INSNS_7400   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3634 a750fc0b j_mayer
                              PPC_EXTERN | PPC_MEM_TLBIA |                    \
3635 a750fc0b j_mayer
                              PPC_ALTIVEC)
3636 a750fc0b j_mayer
#define POWERPC_MSRM_7400    (0x000000000205FF77ULL)
3637 a750fc0b j_mayer
#define POWERPC_MMU_7400     (POWERPC_MMU_32B)
3638 a750fc0b j_mayer
#define POWERPC_EXCP_7400    (POWERPC_EXCP_74xx)
3639 a750fc0b j_mayer
#define POWERPC_INPUT_7400   (PPC_FLAGS_INPUT_6xx)
3640 237c0af0 j_mayer
#define POWERPC_BFDM_7400    (bfd_mach_ppc_7400)
3641 25ba3a68 j_mayer
#define POWERPC_FLAG_7400    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3642 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3643 a750fc0b j_mayer
3644 a750fc0b j_mayer
static void init_proc_7400 (CPUPPCState *env)
3645 a750fc0b j_mayer
{
3646 a750fc0b j_mayer
    gen_spr_ne_601(env);
3647 a750fc0b j_mayer
    gen_spr_7xx(env);
3648 a750fc0b j_mayer
    /* Time base */
3649 a750fc0b j_mayer
    gen_tbl(env);
3650 a750fc0b j_mayer
    /* 74xx specific SPR */
3651 a750fc0b j_mayer
    gen_spr_74xx(env);
3652 a750fc0b j_mayer
    /* Thermal management */
3653 a750fc0b j_mayer
    gen_spr_thrm(env);
3654 a750fc0b j_mayer
    /* Memory management */
3655 a750fc0b j_mayer
    gen_low_BATs(env);
3656 e1833e1f j_mayer
    init_excp_7400(env);
3657 d63001d1 j_mayer
    env->dcache_line_size = 32;
3658 d63001d1 j_mayer
    env->icache_line_size = 32;
3659 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3660 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3661 a750fc0b j_mayer
}
3662 a750fc0b j_mayer
3663 a750fc0b j_mayer
/* PowerPC 7410 (aka G4)                                                     */
3664 a750fc0b j_mayer
#define POWERPC_INSNS_7410   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3665 a750fc0b j_mayer
                              PPC_EXTERN | PPC_MEM_TLBIA |                    \
3666 a750fc0b j_mayer
                              PPC_ALTIVEC)
3667 a750fc0b j_mayer
#define POWERPC_MSRM_7410    (0x000000000205FF77ULL)
3668 a750fc0b j_mayer
#define POWERPC_MMU_7410     (POWERPC_MMU_32B)
3669 a750fc0b j_mayer
#define POWERPC_EXCP_7410    (POWERPC_EXCP_74xx)
3670 a750fc0b j_mayer
#define POWERPC_INPUT_7410   (PPC_FLAGS_INPUT_6xx)
3671 237c0af0 j_mayer
#define POWERPC_BFDM_7410    (bfd_mach_ppc_7400)
3672 25ba3a68 j_mayer
#define POWERPC_FLAG_7410    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3673 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3674 a750fc0b j_mayer
3675 a750fc0b j_mayer
static void init_proc_7410 (CPUPPCState *env)
3676 a750fc0b j_mayer
{
3677 a750fc0b j_mayer
    gen_spr_ne_601(env);
3678 a750fc0b j_mayer
    gen_spr_7xx(env);
3679 a750fc0b j_mayer
    /* Time base */
3680 a750fc0b j_mayer
    gen_tbl(env);
3681 a750fc0b j_mayer
    /* 74xx specific SPR */
3682 a750fc0b j_mayer
    gen_spr_74xx(env);
3683 a750fc0b j_mayer
    /* Thermal management */
3684 a750fc0b j_mayer
    gen_spr_thrm(env);
3685 a750fc0b j_mayer
    /* L2PMCR */
3686 a750fc0b j_mayer
    /* XXX : not implemented */
3687 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
3688 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3689 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3690 a750fc0b j_mayer
                 0x00000000);
3691 a750fc0b j_mayer
    /* LDSTDB */
3692 a750fc0b j_mayer
    /* XXX : not implemented */
3693 a750fc0b j_mayer
    spr_register(env, SPR_LDSTDB, "LDSTDB",
3694 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3695 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3696 a750fc0b j_mayer
                 0x00000000);
3697 a750fc0b j_mayer
    /* Memory management */
3698 a750fc0b j_mayer
    gen_low_BATs(env);
3699 e1833e1f j_mayer
    init_excp_7400(env);
3700 d63001d1 j_mayer
    env->dcache_line_size = 32;
3701 d63001d1 j_mayer
    env->icache_line_size = 32;
3702 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3703 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3704 a750fc0b j_mayer
}
3705 a750fc0b j_mayer
3706 a750fc0b j_mayer
/* PowerPC 7440 (aka G4)                                                     */
3707 a750fc0b j_mayer
#define POWERPC_INSNS_7440   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3708 a750fc0b j_mayer
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3709 a750fc0b j_mayer
                              PPC_ALTIVEC)
3710 a750fc0b j_mayer
#define POWERPC_MSRM_7440    (0x000000000205FF77ULL)
3711 a750fc0b j_mayer
#define POWERPC_MMU_7440     (POWERPC_MMU_SOFT_74xx)
3712 a750fc0b j_mayer
#define POWERPC_EXCP_7440    (POWERPC_EXCP_74xx)
3713 a750fc0b j_mayer
#define POWERPC_INPUT_7440   (PPC_FLAGS_INPUT_6xx)
3714 237c0af0 j_mayer
#define POWERPC_BFDM_7440    (bfd_mach_ppc_7400)
3715 25ba3a68 j_mayer
#define POWERPC_FLAG_7440    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3716 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3717 a750fc0b j_mayer
3718 578bb252 j_mayer
__attribute__ (( unused ))
3719 a750fc0b j_mayer
static void init_proc_7440 (CPUPPCState *env)
3720 a750fc0b j_mayer
{
3721 a750fc0b j_mayer
    gen_spr_ne_601(env);
3722 a750fc0b j_mayer
    gen_spr_7xx(env);
3723 a750fc0b j_mayer
    /* Time base */
3724 a750fc0b j_mayer
    gen_tbl(env);
3725 a750fc0b j_mayer
    /* 74xx specific SPR */
3726 a750fc0b j_mayer
    gen_spr_74xx(env);
3727 a750fc0b j_mayer
    /* LDSTCR */
3728 a750fc0b j_mayer
    /* XXX : not implemented */
3729 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3730 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3731 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3732 a750fc0b j_mayer
                 0x00000000);
3733 a750fc0b j_mayer
    /* ICTRL */
3734 a750fc0b j_mayer
    /* XXX : not implemented */
3735 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
3736 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3737 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3738 a750fc0b j_mayer
                 0x00000000);
3739 a750fc0b j_mayer
    /* MSSSR0 */
3740 578bb252 j_mayer
    /* XXX : not implemented */
3741 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3742 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3743 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3744 a750fc0b j_mayer
                 0x00000000);
3745 a750fc0b j_mayer
    /* PMC */
3746 a750fc0b j_mayer
    /* XXX : not implemented */
3747 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
3748 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3749 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3750 a750fc0b j_mayer
                 0x00000000);
3751 578bb252 j_mayer
    /* XXX : not implemented */
3752 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
3753 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3754 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3755 a750fc0b j_mayer
                 0x00000000);
3756 578bb252 j_mayer
    /* XXX : not implemented */
3757 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
3758 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3759 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3760 a750fc0b j_mayer
                 0x00000000);
3761 578bb252 j_mayer
    /* XXX : not implemented */
3762 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
3763 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3764 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3765 a750fc0b j_mayer
                 0x00000000);
3766 a750fc0b j_mayer
    /* Memory management */
3767 a750fc0b j_mayer
    gen_low_BATs(env);
3768 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
3769 1c27f8fb j_mayer
    init_excp_7450(env);
3770 d63001d1 j_mayer
    env->dcache_line_size = 32;
3771 d63001d1 j_mayer
    env->icache_line_size = 32;
3772 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3773 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3774 a750fc0b j_mayer
}
3775 a750fc0b j_mayer
3776 a750fc0b j_mayer
/* PowerPC 7450 (aka G4)                                                     */
3777 a750fc0b j_mayer
#define POWERPC_INSNS_7450   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3778 a750fc0b j_mayer
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3779 a750fc0b j_mayer
                              PPC_ALTIVEC)
3780 a750fc0b j_mayer
#define POWERPC_MSRM_7450    (0x000000000205FF77ULL)
3781 a750fc0b j_mayer
#define POWERPC_MMU_7450     (POWERPC_MMU_SOFT_74xx)
3782 a750fc0b j_mayer
#define POWERPC_EXCP_7450    (POWERPC_EXCP_74xx)
3783 a750fc0b j_mayer
#define POWERPC_INPUT_7450   (PPC_FLAGS_INPUT_6xx)
3784 237c0af0 j_mayer
#define POWERPC_BFDM_7450    (bfd_mach_ppc_7400)
3785 25ba3a68 j_mayer
#define POWERPC_FLAG_7450    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3786 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3787 a750fc0b j_mayer
3788 578bb252 j_mayer
__attribute__ (( unused ))
3789 a750fc0b j_mayer
static void init_proc_7450 (CPUPPCState *env)
3790 a750fc0b j_mayer
{
3791 a750fc0b j_mayer
    gen_spr_ne_601(env);
3792 a750fc0b j_mayer
    gen_spr_7xx(env);
3793 a750fc0b j_mayer
    /* Time base */
3794 a750fc0b j_mayer
    gen_tbl(env);
3795 a750fc0b j_mayer
    /* 74xx specific SPR */
3796 a750fc0b j_mayer
    gen_spr_74xx(env);
3797 a750fc0b j_mayer
    /* Level 3 cache control */
3798 a750fc0b j_mayer
    gen_l3_ctrl(env);
3799 a750fc0b j_mayer
    /* LDSTCR */
3800 a750fc0b j_mayer
    /* XXX : not implemented */
3801 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3802 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3803 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3804 a750fc0b j_mayer
                 0x00000000);
3805 a750fc0b j_mayer
    /* ICTRL */
3806 a750fc0b j_mayer
    /* XXX : not implemented */
3807 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
3808 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3809 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3810 a750fc0b j_mayer
                 0x00000000);
3811 a750fc0b j_mayer
    /* MSSSR0 */
3812 578bb252 j_mayer
    /* XXX : not implemented */
3813 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3814 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3815 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3816 a750fc0b j_mayer
                 0x00000000);
3817 a750fc0b j_mayer
    /* PMC */
3818 a750fc0b j_mayer
    /* XXX : not implemented */
3819 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
3820 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3821 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3822 a750fc0b j_mayer
                 0x00000000);
3823 578bb252 j_mayer
    /* XXX : not implemented */
3824 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
3825 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3826 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3827 a750fc0b j_mayer
                 0x00000000);
3828 578bb252 j_mayer
    /* XXX : not implemented */
3829 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
3830 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3831 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3832 a750fc0b j_mayer
                 0x00000000);
3833 578bb252 j_mayer
    /* XXX : not implemented */
3834 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
3835 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3836 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3837 a750fc0b j_mayer
                 0x00000000);
3838 a750fc0b j_mayer
    /* Memory management */
3839 a750fc0b j_mayer
    gen_low_BATs(env);
3840 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
3841 e1833e1f j_mayer
    init_excp_7450(env);
3842 d63001d1 j_mayer
    env->dcache_line_size = 32;
3843 d63001d1 j_mayer
    env->icache_line_size = 32;
3844 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3845 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3846 a750fc0b j_mayer
}
3847 a750fc0b j_mayer
3848 a750fc0b j_mayer
/* PowerPC 7445 (aka G4)                                                     */
3849 a750fc0b j_mayer
#define POWERPC_INSNS_7445   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3850 a750fc0b j_mayer
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3851 a750fc0b j_mayer
                              PPC_ALTIVEC)
3852 a750fc0b j_mayer
#define POWERPC_MSRM_7445    (0x000000000205FF77ULL)
3853 a750fc0b j_mayer
#define POWERPC_MMU_7445     (POWERPC_MMU_SOFT_74xx)
3854 a750fc0b j_mayer
#define POWERPC_EXCP_7445    (POWERPC_EXCP_74xx)
3855 a750fc0b j_mayer
#define POWERPC_INPUT_7445   (PPC_FLAGS_INPUT_6xx)
3856 237c0af0 j_mayer
#define POWERPC_BFDM_7445    (bfd_mach_ppc_7400)
3857 25ba3a68 j_mayer
#define POWERPC_FLAG_7445    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3858 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3859 a750fc0b j_mayer
3860 578bb252 j_mayer
__attribute__ (( unused ))
3861 a750fc0b j_mayer
static void init_proc_7445 (CPUPPCState *env)
3862 a750fc0b j_mayer
{
3863 a750fc0b j_mayer
    gen_spr_ne_601(env);
3864 a750fc0b j_mayer
    gen_spr_7xx(env);
3865 a750fc0b j_mayer
    /* Time base */
3866 a750fc0b j_mayer
    gen_tbl(env);
3867 a750fc0b j_mayer
    /* 74xx specific SPR */
3868 a750fc0b j_mayer
    gen_spr_74xx(env);
3869 a750fc0b j_mayer
    /* LDSTCR */
3870 a750fc0b j_mayer
    /* XXX : not implemented */
3871 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3872 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3873 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3874 a750fc0b j_mayer
                 0x00000000);
3875 a750fc0b j_mayer
    /* ICTRL */
3876 a750fc0b j_mayer
    /* XXX : not implemented */
3877 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
3878 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3879 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3880 a750fc0b j_mayer
                 0x00000000);
3881 a750fc0b j_mayer
    /* MSSSR0 */
3882 578bb252 j_mayer
    /* XXX : not implemented */
3883 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3884 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3885 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3886 a750fc0b j_mayer
                 0x00000000);
3887 a750fc0b j_mayer
    /* PMC */
3888 a750fc0b j_mayer
    /* XXX : not implemented */
3889 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
3890 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3891 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3892 a750fc0b j_mayer
                 0x00000000);
3893 578bb252 j_mayer
    /* XXX : not implemented */
3894 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
3895 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3896 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3897 a750fc0b j_mayer
                 0x00000000);
3898 578bb252 j_mayer
    /* XXX : not implemented */
3899 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
3900 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3901 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3902 a750fc0b j_mayer
                 0x00000000);
3903 578bb252 j_mayer
    /* XXX : not implemented */
3904 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
3905 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3906 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3907 a750fc0b j_mayer
                 0x00000000);
3908 a750fc0b j_mayer
    /* SPRGs */
3909 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
3910 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3911 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3912 a750fc0b j_mayer
                 0x00000000);
3913 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
3914 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3915 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3916 a750fc0b j_mayer
                 0x00000000);
3917 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
3918 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3919 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3920 a750fc0b j_mayer
                 0x00000000);
3921 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
3922 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3923 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3924 a750fc0b j_mayer
                 0x00000000);
3925 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
3926 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3927 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3928 a750fc0b j_mayer
                 0x00000000);
3929 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
3930 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3931 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3932 a750fc0b j_mayer
                 0x00000000);
3933 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
3934 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3935 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3936 a750fc0b j_mayer
                 0x00000000);
3937 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
3938 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3939 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
3940 a750fc0b j_mayer
                 0x00000000);
3941 a750fc0b j_mayer
    /* Memory management */
3942 a750fc0b j_mayer
    gen_low_BATs(env);
3943 a750fc0b j_mayer
    gen_high_BATs(env);
3944 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
3945 e1833e1f j_mayer
    init_excp_7450(env);
3946 d63001d1 j_mayer
    env->dcache_line_size = 32;
3947 d63001d1 j_mayer
    env->icache_line_size = 32;
3948 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
3949 a750fc0b j_mayer
    ppc6xx_irq_init(env);
3950 a750fc0b j_mayer
}
3951 a750fc0b j_mayer
3952 a750fc0b j_mayer
/* PowerPC 7455 (aka G4)                                                     */
3953 a750fc0b j_mayer
#define POWERPC_INSNS_7455   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3954 a750fc0b j_mayer
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3955 a750fc0b j_mayer
                              PPC_ALTIVEC)
3956 a750fc0b j_mayer
#define POWERPC_MSRM_7455    (0x000000000205FF77ULL)
3957 a750fc0b j_mayer
#define POWERPC_MMU_7455     (POWERPC_MMU_SOFT_74xx)
3958 a750fc0b j_mayer
#define POWERPC_EXCP_7455    (POWERPC_EXCP_74xx)
3959 a750fc0b j_mayer
#define POWERPC_INPUT_7455   (PPC_FLAGS_INPUT_6xx)
3960 237c0af0 j_mayer
#define POWERPC_BFDM_7455    (bfd_mach_ppc_7400)
3961 25ba3a68 j_mayer
#define POWERPC_FLAG_7455    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3962 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3963 a750fc0b j_mayer
3964 578bb252 j_mayer
__attribute__ (( unused ))
3965 a750fc0b j_mayer
static void init_proc_7455 (CPUPPCState *env)
3966 a750fc0b j_mayer
{
3967 a750fc0b j_mayer
    gen_spr_ne_601(env);
3968 a750fc0b j_mayer
    gen_spr_7xx(env);
3969 a750fc0b j_mayer
    /* Time base */
3970 a750fc0b j_mayer
    gen_tbl(env);
3971 a750fc0b j_mayer
    /* 74xx specific SPR */
3972 a750fc0b j_mayer
    gen_spr_74xx(env);
3973 a750fc0b j_mayer
    /* Level 3 cache control */
3974 a750fc0b j_mayer
    gen_l3_ctrl(env);
3975 a750fc0b j_mayer
    /* LDSTCR */
3976 a750fc0b j_mayer
    /* XXX : not implemented */
3977 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3978 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3979 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3980 a750fc0b j_mayer
                 0x00000000);
3981 a750fc0b j_mayer
    /* ICTRL */
3982 a750fc0b j_mayer
    /* XXX : not implemented */
3983 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
3984 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3985 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3986 a750fc0b j_mayer
                 0x00000000);
3987 a750fc0b j_mayer
    /* MSSSR0 */
3988 578bb252 j_mayer
    /* XXX : not implemented */
3989 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3990 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3991 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3992 a750fc0b j_mayer
                 0x00000000);
3993 a750fc0b j_mayer
    /* PMC */
3994 a750fc0b j_mayer
    /* XXX : not implemented */
3995 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
3996 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3997 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3998 a750fc0b j_mayer
                 0x00000000);
3999 578bb252 j_mayer
    /* XXX : not implemented */
4000 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
4001 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4002 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4003 a750fc0b j_mayer
                 0x00000000);
4004 578bb252 j_mayer
    /* XXX : not implemented */
4005 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
4006 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4007 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4008 a750fc0b j_mayer
                 0x00000000);
4009 578bb252 j_mayer
    /* XXX : not implemented */
4010 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
4011 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4012 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4013 a750fc0b j_mayer
                 0x00000000);
4014 a750fc0b j_mayer
    /* SPRGs */
4015 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
4016 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4017 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4018 a750fc0b j_mayer
                 0x00000000);
4019 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
4020 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4021 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4022 a750fc0b j_mayer
                 0x00000000);
4023 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
4024 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4025 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4026 a750fc0b j_mayer
                 0x00000000);
4027 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
4028 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4029 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4030 a750fc0b j_mayer
                 0x00000000);
4031 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
4032 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4033 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4034 a750fc0b j_mayer
                 0x00000000);
4035 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
4036 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4037 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4038 a750fc0b j_mayer
                 0x00000000);
4039 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
4040 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4041 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4042 a750fc0b j_mayer
                 0x00000000);
4043 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
4044 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4045 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4046 a750fc0b j_mayer
                 0x00000000);
4047 a750fc0b j_mayer
    /* Memory management */
4048 a750fc0b j_mayer
    gen_low_BATs(env);
4049 a750fc0b j_mayer
    gen_high_BATs(env);
4050 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
4051 e1833e1f j_mayer
    init_excp_7450(env);
4052 d63001d1 j_mayer
    env->dcache_line_size = 32;
4053 d63001d1 j_mayer
    env->icache_line_size = 32;
4054 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4055 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4056 a750fc0b j_mayer
}
4057 a750fc0b j_mayer
4058 a750fc0b j_mayer
#if defined (TARGET_PPC64)
4059 d63001d1 j_mayer
#define POWERPC_INSNS_WORK64  (POWERPC_INSNS_6xx | PPC_FLOAT_FSQRT |          \
4060 12de9a39 j_mayer
                               PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |           \
4061 12de9a39 j_mayer
                               PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |            \
4062 12de9a39 j_mayer
                               PPC_MEM_TLBSYNC | PPC_CACHE_DCBZT | PPC_MFTB)
4063 a750fc0b j_mayer
/* PowerPC 970                                                               */
4064 d63001d1 j_mayer
#define POWERPC_INSNS_970    (POWERPC_INSNS_WORK64 | PPC_FLOAT_FSQRT |        \
4065 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
4066 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
4067 a750fc0b j_mayer
#define POWERPC_MSRM_970     (0x900000000204FF36ULL)
4068 12de9a39 j_mayer
#define POWERPC_MMU_970      (POWERPC_MMU_64B)
4069 a750fc0b j_mayer
//#define POWERPC_EXCP_970     (POWERPC_EXCP_970)
4070 a750fc0b j_mayer
#define POWERPC_INPUT_970    (PPC_FLAGS_INPUT_970)
4071 237c0af0 j_mayer
#define POWERPC_BFDM_970     (bfd_mach_ppc64)
4072 25ba3a68 j_mayer
#define POWERPC_FLAG_970     (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4073 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4074 a750fc0b j_mayer
4075 417bf010 j_mayer
#if defined(CONFIG_USER_ONLY)
4076 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000080
4077 417bf010 j_mayer
#else
4078 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000000
4079 417bf010 j_mayer
#endif
4080 417bf010 j_mayer
4081 a750fc0b j_mayer
static void init_proc_970 (CPUPPCState *env)
4082 a750fc0b j_mayer
{
4083 a750fc0b j_mayer
    gen_spr_ne_601(env);
4084 a750fc0b j_mayer
    gen_spr_7xx(env);
4085 a750fc0b j_mayer
    /* Time base */
4086 a750fc0b j_mayer
    gen_tbl(env);
4087 a750fc0b j_mayer
    /* Hardware implementation registers */
4088 a750fc0b j_mayer
    /* XXX : not implemented */
4089 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4090 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4091 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
4092 d63001d1 j_mayer
                 0x60000000);
4093 a750fc0b j_mayer
    /* XXX : not implemented */
4094 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4095 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4096 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4097 a750fc0b j_mayer
                 0x00000000);
4098 a750fc0b j_mayer
    /* XXX : not implemented */
4099 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
4100 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4101 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4102 a750fc0b j_mayer
                 0x00000000);
4103 e57448f1 j_mayer
    /* XXX : not implemented */
4104 e57448f1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
4105 e57448f1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4106 e57448f1 j_mayer
                 &spr_read_generic, &spr_write_generic,
4107 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
4108 a750fc0b j_mayer
    /* Memory management */
4109 a750fc0b j_mayer
    /* XXX: not correct */
4110 a750fc0b j_mayer
    gen_low_BATs(env);
4111 12de9a39 j_mayer
    /* XXX : not implemented */
4112 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
4113 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4114 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
4115 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
4116 12de9a39 j_mayer
    /* XXX : not implemented */
4117 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4118 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4119 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
4120 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
4121 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
4122 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4123 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
4124 12de9a39 j_mayer
                 0xFFF00000); /* XXX: This is a hack */
4125 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
4126 12de9a39 j_mayer
    env->excp_prefix = 0xFFF00000;
4127 a750fc0b j_mayer
#endif
4128 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4129 12de9a39 j_mayer
    env->slb_nr = 32;
4130 f2e63a42 j_mayer
#endif
4131 e1833e1f j_mayer
    init_excp_970(env);
4132 d63001d1 j_mayer
    env->dcache_line_size = 128;
4133 d63001d1 j_mayer
    env->icache_line_size = 128;
4134 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4135 a750fc0b j_mayer
    ppc970_irq_init(env);
4136 a750fc0b j_mayer
}
4137 a750fc0b j_mayer
4138 a750fc0b j_mayer
/* PowerPC 970FX (aka G5)                                                    */
4139 d63001d1 j_mayer
#define POWERPC_INSNS_970FX  (POWERPC_INSNS_WORK64 | PPC_FLOAT_FSQRT |        \
4140 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
4141 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
4142 a750fc0b j_mayer
#define POWERPC_MSRM_970FX   (0x800000000204FF36ULL)
4143 12de9a39 j_mayer
#define POWERPC_MMU_970FX    (POWERPC_MMU_64B)
4144 a750fc0b j_mayer
#define POWERPC_EXCP_970FX   (POWERPC_EXCP_970)
4145 a750fc0b j_mayer
#define POWERPC_INPUT_970FX  (PPC_FLAGS_INPUT_970)
4146 237c0af0 j_mayer
#define POWERPC_BFDM_970FX   (bfd_mach_ppc64)
4147 25ba3a68 j_mayer
#define POWERPC_FLAG_970FX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4148 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4149 a750fc0b j_mayer
4150 a750fc0b j_mayer
static void init_proc_970FX (CPUPPCState *env)
4151 a750fc0b j_mayer
{
4152 a750fc0b j_mayer
    gen_spr_ne_601(env);
4153 a750fc0b j_mayer
    gen_spr_7xx(env);
4154 a750fc0b j_mayer
    /* Time base */
4155 a750fc0b j_mayer
    gen_tbl(env);
4156 a750fc0b j_mayer
    /* Hardware implementation registers */
4157 a750fc0b j_mayer
    /* XXX : not implemented */
4158 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4159 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4160 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
4161 d63001d1 j_mayer
                 0x60000000);
4162 a750fc0b j_mayer
    /* XXX : not implemented */
4163 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4164 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4165 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4166 a750fc0b j_mayer
                 0x00000000);
4167 a750fc0b j_mayer
    /* XXX : not implemented */
4168 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
4169 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4170 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4171 a750fc0b j_mayer
                 0x00000000);
4172 d63001d1 j_mayer
    /* XXX : not implemented */
4173 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
4174 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4175 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
4176 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
4177 a750fc0b j_mayer
    /* Memory management */
4178 a750fc0b j_mayer
    /* XXX: not correct */
4179 a750fc0b j_mayer
    gen_low_BATs(env);
4180 12de9a39 j_mayer
    /* XXX : not implemented */
4181 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
4182 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4183 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
4184 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
4185 12de9a39 j_mayer
    /* XXX : not implemented */
4186 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4187 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4188 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
4189 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
4190 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
4191 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4192 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
4193 12de9a39 j_mayer
                 0xFFF00000); /* XXX: This is a hack */
4194 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
4195 12de9a39 j_mayer
    env->excp_prefix = 0xFFF00000;
4196 a750fc0b j_mayer
#endif
4197 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4198 12de9a39 j_mayer
    env->slb_nr = 32;
4199 f2e63a42 j_mayer
#endif
4200 e1833e1f j_mayer
    init_excp_970(env);
4201 d63001d1 j_mayer
    env->dcache_line_size = 128;
4202 d63001d1 j_mayer
    env->icache_line_size = 128;
4203 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4204 a750fc0b j_mayer
    ppc970_irq_init(env);
4205 a750fc0b j_mayer
}
4206 a750fc0b j_mayer
4207 a750fc0b j_mayer
/* PowerPC 970 GX                                                            */
4208 d63001d1 j_mayer
#define POWERPC_INSNS_970GX  (POWERPC_INSNS_WORK64 | PPC_FLOAT_FSQRT |        \
4209 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
4210 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
4211 a750fc0b j_mayer
#define POWERPC_MSRM_970GX   (0x800000000204FF36ULL)
4212 12de9a39 j_mayer
#define POWERPC_MMU_970GX    (POWERPC_MMU_64B)
4213 a750fc0b j_mayer
#define POWERPC_EXCP_970GX   (POWERPC_EXCP_970)
4214 a750fc0b j_mayer
#define POWERPC_INPUT_970GX  (PPC_FLAGS_INPUT_970)
4215 237c0af0 j_mayer
#define POWERPC_BFDM_970GX   (bfd_mach_ppc64)
4216 25ba3a68 j_mayer
#define POWERPC_FLAG_970GX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4217 25ba3a68 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4218 a750fc0b j_mayer
4219 a750fc0b j_mayer
static void init_proc_970GX (CPUPPCState *env)
4220 a750fc0b j_mayer
{
4221 a750fc0b j_mayer
    gen_spr_ne_601(env);
4222 a750fc0b j_mayer
    gen_spr_7xx(env);
4223 a750fc0b j_mayer
    /* Time base */
4224 a750fc0b j_mayer
    gen_tbl(env);
4225 a750fc0b j_mayer
    /* Hardware implementation registers */
4226 a750fc0b j_mayer
    /* XXX : not implemented */
4227 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4228 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4229 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
4230 d63001d1 j_mayer
                 0x60000000);
4231 a750fc0b j_mayer
    /* XXX : not implemented */
4232 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4233 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4234 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4235 a750fc0b j_mayer
                 0x00000000);
4236 a750fc0b j_mayer
    /* XXX : not implemented */
4237 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
4238 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4239 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4240 a750fc0b j_mayer
                 0x00000000);
4241 d63001d1 j_mayer
    /* XXX : not implemented */
4242 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
4243 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4244 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
4245 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
4246 a750fc0b j_mayer
    /* Memory management */
4247 a750fc0b j_mayer
    /* XXX: not correct */
4248 a750fc0b j_mayer
    gen_low_BATs(env);
4249 12de9a39 j_mayer
    /* XXX : not implemented */
4250 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
4251 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4252 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
4253 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
4254 12de9a39 j_mayer
    /* XXX : not implemented */
4255 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4256 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4257 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
4258 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
4259 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
4260 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4261 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
4262 12de9a39 j_mayer
                 0xFFF00000); /* XXX: This is a hack */
4263 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
4264 12de9a39 j_mayer
    env->excp_prefix = 0xFFF00000;
4265 a750fc0b j_mayer
#endif
4266 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4267 12de9a39 j_mayer
    env->slb_nr = 32;
4268 f2e63a42 j_mayer
#endif
4269 e1833e1f j_mayer
    init_excp_970(env);
4270 d63001d1 j_mayer
    env->dcache_line_size = 128;
4271 d63001d1 j_mayer
    env->icache_line_size = 128;
4272 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4273 a750fc0b j_mayer
    ppc970_irq_init(env);
4274 a750fc0b j_mayer
}
4275 a750fc0b j_mayer
4276 a750fc0b j_mayer
/* PowerPC 620                                                               */
4277 a750fc0b j_mayer
#define POWERPC_INSNS_620    (POWERPC_INSNS_WORKS | PPC_FLOAT_FSQRT |         \
4278 a750fc0b j_mayer
                              PPC_64B | PPC_SLBI)
4279 a750fc0b j_mayer
#define POWERPC_MSRM_620     (0x800000000005FF73ULL)
4280 a750fc0b j_mayer
#define POWERPC_MMU_620      (POWERPC_MMU_64B)
4281 a750fc0b j_mayer
#define POWERPC_EXCP_620     (POWERPC_EXCP_970)
4282 a750fc0b j_mayer
#define POWERPC_INPUT_620    (PPC_FLAGS_INPUT_970)
4283 237c0af0 j_mayer
#define POWERPC_BFDM_620     (bfd_mach_ppc64)
4284 25ba3a68 j_mayer
#define POWERPC_FLAG_620     (POWERPC_FLAG_SE | POWERPC_FLAG_BE)
4285 a750fc0b j_mayer
4286 578bb252 j_mayer
__attribute__ (( unused ))
4287 a750fc0b j_mayer
static void init_proc_620 (CPUPPCState *env)
4288 a750fc0b j_mayer
{
4289 a750fc0b j_mayer
    gen_spr_ne_601(env);
4290 a750fc0b j_mayer
    gen_spr_620(env);
4291 a750fc0b j_mayer
    /* Time base */
4292 a750fc0b j_mayer
    gen_tbl(env);
4293 a750fc0b j_mayer
    /* Hardware implementation registers */
4294 a750fc0b j_mayer
    /* XXX : not implemented */
4295 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4296 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4297 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4298 a750fc0b j_mayer
                 0x00000000);
4299 a750fc0b j_mayer
    /* Memory management */
4300 a750fc0b j_mayer
    gen_low_BATs(env);
4301 a750fc0b j_mayer
    gen_high_BATs(env);
4302 e1833e1f j_mayer
    init_excp_620(env);
4303 d63001d1 j_mayer
    env->dcache_line_size = 64;
4304 d63001d1 j_mayer
    env->icache_line_size = 64;
4305 a750fc0b j_mayer
    /* XXX: TODO: initialize internal interrupt controller */
4306 a750fc0b j_mayer
}
4307 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
4308 a750fc0b j_mayer
4309 a750fc0b j_mayer
/* Default 32 bits PowerPC target will be 604 */
4310 a750fc0b j_mayer
#define CPU_POWERPC_PPC32     CPU_POWERPC_604
4311 a750fc0b j_mayer
#define POWERPC_INSNS_PPC32   POWERPC_INSNS_604
4312 a750fc0b j_mayer
#define POWERPC_MSRM_PPC32    POWERPC_MSRM_604
4313 a750fc0b j_mayer
#define POWERPC_MMU_PPC32     POWERPC_MMU_604
4314 a750fc0b j_mayer
#define POWERPC_EXCP_PPC32    POWERPC_EXCP_604
4315 a750fc0b j_mayer
#define POWERPC_INPUT_PPC32   POWERPC_INPUT_604
4316 a750fc0b j_mayer
#define init_proc_PPC32       init_proc_604
4317 237c0af0 j_mayer
#define POWERPC_BFDM_PPC32    POWERPC_BFDM_604
4318 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC32    POWERPC_FLAG_604
4319 a750fc0b j_mayer
4320 a750fc0b j_mayer
/* Default 64 bits PowerPC target will be 970 FX */
4321 a750fc0b j_mayer
#define CPU_POWERPC_PPC64     CPU_POWERPC_970FX
4322 a750fc0b j_mayer
#define POWERPC_INSNS_PPC64   POWERPC_INSNS_970FX
4323 a750fc0b j_mayer
#define POWERPC_MSRM_PPC64    POWERPC_MSRM_970FX
4324 a750fc0b j_mayer
#define POWERPC_MMU_PPC64     POWERPC_MMU_970FX
4325 a750fc0b j_mayer
#define POWERPC_EXCP_PPC64    POWERPC_EXCP_970FX
4326 a750fc0b j_mayer
#define POWERPC_INPUT_PPC64   POWERPC_INPUT_970FX
4327 a750fc0b j_mayer
#define init_proc_PPC64       init_proc_970FX
4328 237c0af0 j_mayer
#define POWERPC_BFDM_PPC64    POWERPC_BFDM_970FX
4329 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC64    POWERPC_FLAG_970FX
4330 a750fc0b j_mayer
4331 a750fc0b j_mayer
/* Default PowerPC target will be PowerPC 32 */
4332 a750fc0b j_mayer
#if defined (TARGET_PPC64) && 0 // XXX: TODO
4333 d12f4c38 j_mayer
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC64
4334 d12f4c38 j_mayer
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC64
4335 d12f4c38 j_mayer
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC64
4336 d12f4c38 j_mayer
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC64
4337 d12f4c38 j_mayer
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC64
4338 d12f4c38 j_mayer
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC64
4339 d12f4c38 j_mayer
#define init_proc_DEFAULT     init_proc_PPC64
4340 237c0af0 j_mayer
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC64
4341 d26bfc9a j_mayer
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC64
4342 a750fc0b j_mayer
#else
4343 d12f4c38 j_mayer
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC32
4344 d12f4c38 j_mayer
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC32
4345 d12f4c38 j_mayer
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC32
4346 d12f4c38 j_mayer
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC32
4347 d12f4c38 j_mayer
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC32
4348 d12f4c38 j_mayer
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC32
4349 d12f4c38 j_mayer
#define init_proc_DEFAULT     init_proc_PPC32
4350 237c0af0 j_mayer
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC32
4351 d26bfc9a j_mayer
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC32
4352 a750fc0b j_mayer
#endif
4353 a750fc0b j_mayer
4354 a750fc0b j_mayer
/*****************************************************************************/
4355 a750fc0b j_mayer
/* PVR definitions for most known PowerPC                                    */
4356 a750fc0b j_mayer
enum {
4357 a750fc0b j_mayer
    /* PowerPC 401 family */
4358 a750fc0b j_mayer
    /* Generic PowerPC 401 */
4359 a750fc0b j_mayer
#define CPU_POWERPC_401       CPU_POWERPC_401G2
4360 a750fc0b j_mayer
    /* PowerPC 401 cores */
4361 a750fc0b j_mayer
    CPU_POWERPC_401A1       = 0x00210000,
4362 a750fc0b j_mayer
    CPU_POWERPC_401B2       = 0x00220000,
4363 a750fc0b j_mayer
#if 0
4364 a750fc0b j_mayer
    CPU_POWERPC_401B3       = xxx,
4365 a750fc0b j_mayer
#endif
4366 a750fc0b j_mayer
    CPU_POWERPC_401C2       = 0x00230000,
4367 a750fc0b j_mayer
    CPU_POWERPC_401D2       = 0x00240000,
4368 a750fc0b j_mayer
    CPU_POWERPC_401E2       = 0x00250000,
4369 a750fc0b j_mayer
    CPU_POWERPC_401F2       = 0x00260000,
4370 a750fc0b j_mayer
    CPU_POWERPC_401G2       = 0x00270000,
4371 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers */
4372 a750fc0b j_mayer
#if 0
4373 a750fc0b j_mayer
    CPU_POWERPC_401GF       = xxx,
4374 a750fc0b j_mayer
#endif
4375 a750fc0b j_mayer
#define CPU_POWERPC_IOP480    CPU_POWERPC_401B2
4376 a750fc0b j_mayer
    /* IBM Processor for Network Resources */
4377 a750fc0b j_mayer
    CPU_POWERPC_COBRA       = 0x10100000, /* XXX: 405 ? */
4378 a750fc0b j_mayer
#if 0
4379 a750fc0b j_mayer
    CPU_POWERPC_XIPCHIP     = xxx,
4380 a750fc0b j_mayer
#endif
4381 a750fc0b j_mayer
    /* PowerPC 403 family */
4382 a750fc0b j_mayer
    /* Generic PowerPC 403 */
4383 a750fc0b j_mayer
#define CPU_POWERPC_403       CPU_POWERPC_403GC
4384 a750fc0b j_mayer
    /* PowerPC 403 microcontrollers */
4385 a750fc0b j_mayer
    CPU_POWERPC_403GA       = 0x00200011,
4386 a750fc0b j_mayer
    CPU_POWERPC_403GB       = 0x00200100,
4387 a750fc0b j_mayer
    CPU_POWERPC_403GC       = 0x00200200,
4388 a750fc0b j_mayer
    CPU_POWERPC_403GCX      = 0x00201400,
4389 a750fc0b j_mayer
#if 0
4390 a750fc0b j_mayer
    CPU_POWERPC_403GP       = xxx,
4391 a750fc0b j_mayer
#endif
4392 a750fc0b j_mayer
    /* PowerPC 405 family */
4393 a750fc0b j_mayer
    /* Generic PowerPC 405 */
4394 a750fc0b j_mayer
#define CPU_POWERPC_405       CPU_POWERPC_405D4
4395 a750fc0b j_mayer
    /* PowerPC 405 cores */
4396 a750fc0b j_mayer
#if 0
4397 a750fc0b j_mayer
    CPU_POWERPC_405A3       = xxx,
4398 a750fc0b j_mayer
#endif
4399 a750fc0b j_mayer
#if 0
4400 a750fc0b j_mayer
    CPU_POWERPC_405A4       = xxx,
4401 a750fc0b j_mayer
#endif
4402 a750fc0b j_mayer
#if 0
4403 a750fc0b j_mayer
    CPU_POWERPC_405B3       = xxx,
4404 a750fc0b j_mayer
#endif
4405 a750fc0b j_mayer
#if 0
4406 a750fc0b j_mayer
    CPU_POWERPC_405B4       = xxx,
4407 a750fc0b j_mayer
#endif
4408 a750fc0b j_mayer
#if 0
4409 a750fc0b j_mayer
    CPU_POWERPC_405C3       = xxx,
4410 a750fc0b j_mayer
#endif
4411 a750fc0b j_mayer
#if 0
4412 a750fc0b j_mayer
    CPU_POWERPC_405C4       = xxx,
4413 a750fc0b j_mayer
#endif
4414 a750fc0b j_mayer
    CPU_POWERPC_405D2       = 0x20010000,
4415 a750fc0b j_mayer
#if 0
4416 a750fc0b j_mayer
    CPU_POWERPC_405D3       = xxx,
4417 a750fc0b j_mayer
#endif
4418 a750fc0b j_mayer
    CPU_POWERPC_405D4       = 0x41810000,
4419 a750fc0b j_mayer
#if 0
4420 a750fc0b j_mayer
    CPU_POWERPC_405D5       = xxx,
4421 a750fc0b j_mayer
#endif
4422 a750fc0b j_mayer
#if 0
4423 a750fc0b j_mayer
    CPU_POWERPC_405E4       = xxx,
4424 a750fc0b j_mayer
#endif
4425 a750fc0b j_mayer
#if 0
4426 a750fc0b j_mayer
    CPU_POWERPC_405F4       = xxx,
4427 a750fc0b j_mayer
#endif
4428 a750fc0b j_mayer
#if 0
4429 a750fc0b j_mayer
    CPU_POWERPC_405F5       = xxx,
4430 a750fc0b j_mayer
#endif
4431 a750fc0b j_mayer
#if 0
4432 a750fc0b j_mayer
    CPU_POWERPC_405F6       = xxx,
4433 a750fc0b j_mayer
#endif
4434 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers */
4435 a750fc0b j_mayer
    /* XXX: missing 0x200108a0 */
4436 a750fc0b j_mayer
#define CPU_POWERPC_405CR     CPU_POWERPC_405CRc
4437 a750fc0b j_mayer
    CPU_POWERPC_405CRa      = 0x40110041,
4438 a750fc0b j_mayer
    CPU_POWERPC_405CRb      = 0x401100C5,
4439 a750fc0b j_mayer
    CPU_POWERPC_405CRc      = 0x40110145,
4440 a750fc0b j_mayer
    CPU_POWERPC_405EP       = 0x51210950,
4441 a750fc0b j_mayer
#if 0
4442 a750fc0b j_mayer
    CPU_POWERPC_405EXr      = xxx,
4443 a750fc0b j_mayer
#endif
4444 a750fc0b j_mayer
    CPU_POWERPC_405EZ       = 0x41511460, /* 0x51210950 ? */
4445 a750fc0b j_mayer
#if 0
4446 a750fc0b j_mayer
    CPU_POWERPC_405FX       = xxx,
4447 a750fc0b j_mayer
#endif
4448 a750fc0b j_mayer
#define CPU_POWERPC_405GP     CPU_POWERPC_405GPd
4449 a750fc0b j_mayer
    CPU_POWERPC_405GPa      = 0x40110000,
4450 a750fc0b j_mayer
    CPU_POWERPC_405GPb      = 0x40110040,
4451 a750fc0b j_mayer
    CPU_POWERPC_405GPc      = 0x40110082,
4452 a750fc0b j_mayer
    CPU_POWERPC_405GPd      = 0x401100C4,
4453 a750fc0b j_mayer
#define CPU_POWERPC_405GPe    CPU_POWERPC_405CRc
4454 a750fc0b j_mayer
    CPU_POWERPC_405GPR      = 0x50910951,
4455 a750fc0b j_mayer
#if 0
4456 a750fc0b j_mayer
    CPU_POWERPC_405H        = xxx,
4457 a750fc0b j_mayer
#endif
4458 a750fc0b j_mayer
#if 0
4459 a750fc0b j_mayer
    CPU_POWERPC_405L        = xxx,
4460 a750fc0b j_mayer
#endif
4461 a750fc0b j_mayer
    CPU_POWERPC_405LP       = 0x41F10000,
4462 a750fc0b j_mayer
#if 0
4463 a750fc0b j_mayer
    CPU_POWERPC_405PM       = xxx,
4464 a750fc0b j_mayer
#endif
4465 a750fc0b j_mayer
#if 0
4466 a750fc0b j_mayer
    CPU_POWERPC_405PS       = xxx,
4467 a750fc0b j_mayer
#endif
4468 a750fc0b j_mayer
#if 0
4469 a750fc0b j_mayer
    CPU_POWERPC_405S        = xxx,
4470 a750fc0b j_mayer
#endif
4471 a750fc0b j_mayer
    /* IBM network processors */
4472 a750fc0b j_mayer
    CPU_POWERPC_NPE405H     = 0x414100C0,
4473 a750fc0b j_mayer
    CPU_POWERPC_NPE405H2    = 0x41410140,
4474 a750fc0b j_mayer
    CPU_POWERPC_NPE405L     = 0x416100C0,
4475 a750fc0b j_mayer
    CPU_POWERPC_NPE4GS3     = 0x40B10000,
4476 a750fc0b j_mayer
#if 0
4477 a750fc0b j_mayer
    CPU_POWERPC_NPCxx1      = xxx,
4478 a750fc0b j_mayer
#endif
4479 a750fc0b j_mayer
#if 0
4480 a750fc0b j_mayer
    CPU_POWERPC_NPR161      = xxx,
4481 a750fc0b j_mayer
#endif
4482 a750fc0b j_mayer
#if 0
4483 a750fc0b j_mayer
    CPU_POWERPC_LC77700     = xxx,
4484 a750fc0b j_mayer
#endif
4485 a750fc0b j_mayer
    /* IBM STBxxx (PowerPC 401/403/405 core based microcontrollers) */
4486 a750fc0b j_mayer
#if 0
4487 a750fc0b j_mayer
    CPU_POWERPC_STB01000    = xxx,
4488 a750fc0b j_mayer
#endif
4489 a750fc0b j_mayer
#if 0
4490 a750fc0b j_mayer
    CPU_POWERPC_STB01010    = xxx,
4491 a750fc0b j_mayer
#endif
4492 a750fc0b j_mayer
#if 0
4493 a750fc0b j_mayer
    CPU_POWERPC_STB0210     = xxx, /* 401B3 */
4494 a750fc0b j_mayer
#endif
4495 a750fc0b j_mayer
    CPU_POWERPC_STB03       = 0x40310000, /* 0x40130000 ? */
4496 a750fc0b j_mayer
#if 0
4497 a750fc0b j_mayer
    CPU_POWERPC_STB043      = xxx,
4498 a750fc0b j_mayer
#endif
4499 a750fc0b j_mayer
#if 0
4500 a750fc0b j_mayer
    CPU_POWERPC_STB045      = xxx,
4501 a750fc0b j_mayer
#endif
4502 a750fc0b j_mayer
    CPU_POWERPC_STB04       = 0x41810000,
4503 a750fc0b j_mayer
    CPU_POWERPC_STB25       = 0x51510950,
4504 a750fc0b j_mayer
#if 0
4505 a750fc0b j_mayer
    CPU_POWERPC_STB130      = xxx,
4506 a750fc0b j_mayer
#endif
4507 a750fc0b j_mayer
    /* Xilinx cores */
4508 a750fc0b j_mayer
    CPU_POWERPC_X2VP4       = 0x20010820,
4509 a750fc0b j_mayer
#define CPU_POWERPC_X2VP7     CPU_POWERPC_X2VP4
4510 a750fc0b j_mayer
    CPU_POWERPC_X2VP20      = 0x20010860,
4511 a750fc0b j_mayer
#define CPU_POWERPC_X2VP50    CPU_POWERPC_X2VP20
4512 a750fc0b j_mayer
#if 0
4513 a750fc0b j_mayer
    CPU_POWERPC_ZL10310     = xxx,
4514 a750fc0b j_mayer
#endif
4515 a750fc0b j_mayer
#if 0
4516 a750fc0b j_mayer
    CPU_POWERPC_ZL10311     = xxx,
4517 a750fc0b j_mayer
#endif
4518 a750fc0b j_mayer
#if 0
4519 a750fc0b j_mayer
    CPU_POWERPC_ZL10320     = xxx,
4520 a750fc0b j_mayer
#endif
4521 a750fc0b j_mayer
#if 0
4522 a750fc0b j_mayer
    CPU_POWERPC_ZL10321     = xxx,
4523 a750fc0b j_mayer
#endif
4524 a750fc0b j_mayer
    /* PowerPC 440 family */
4525 a750fc0b j_mayer
    /* Generic PowerPC 440 */
4526 a750fc0b j_mayer
#define CPU_POWERPC_440       CPU_POWERPC_440GXf
4527 a750fc0b j_mayer
    /* PowerPC 440 cores */
4528 a750fc0b j_mayer
#if 0
4529 a750fc0b j_mayer
    CPU_POWERPC_440A4       = xxx,
4530 a750fc0b j_mayer
#endif
4531 a750fc0b j_mayer
#if 0
4532 a750fc0b j_mayer
    CPU_POWERPC_440A5       = xxx,
4533 a750fc0b j_mayer
#endif
4534 a750fc0b j_mayer
#if 0
4535 a750fc0b j_mayer
    CPU_POWERPC_440B4       = xxx,
4536 a750fc0b j_mayer
#endif
4537 a750fc0b j_mayer
#if 0
4538 a750fc0b j_mayer
    CPU_POWERPC_440F5       = xxx,
4539 a750fc0b j_mayer
#endif
4540 a750fc0b j_mayer
#if 0
4541 a750fc0b j_mayer
    CPU_POWERPC_440G5       = xxx,
4542 a750fc0b j_mayer
#endif
4543 a750fc0b j_mayer
#if 0
4544 a750fc0b j_mayer
    CPU_POWERPC_440H4       = xxx,
4545 a750fc0b j_mayer
#endif
4546 a750fc0b j_mayer
#if 0
4547 a750fc0b j_mayer
    CPU_POWERPC_440H6       = xxx,
4548 a750fc0b j_mayer
#endif
4549 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers */
4550 a750fc0b j_mayer
#define CPU_POWERPC_440EP     CPU_POWERPC_440EPb
4551 a750fc0b j_mayer
    CPU_POWERPC_440EPa      = 0x42221850,
4552 a750fc0b j_mayer
    CPU_POWERPC_440EPb      = 0x422218D3,
4553 a750fc0b j_mayer
#define CPU_POWERPC_440GP     CPU_POWERPC_440GPc
4554 a750fc0b j_mayer
    CPU_POWERPC_440GPb      = 0x40120440,
4555 a750fc0b j_mayer
    CPU_POWERPC_440GPc      = 0x40120481,
4556 a750fc0b j_mayer
#define CPU_POWERPC_440GR     CPU_POWERPC_440GRa
4557 a750fc0b j_mayer
#define CPU_POWERPC_440GRa    CPU_POWERPC_440EPb
4558 a750fc0b j_mayer
    CPU_POWERPC_440GRX      = 0x200008D0,
4559 a750fc0b j_mayer
#define CPU_POWERPC_440EPX    CPU_POWERPC_440GRX
4560 a750fc0b j_mayer
#define CPU_POWERPC_440GX     CPU_POWERPC_440GXf
4561 a750fc0b j_mayer
    CPU_POWERPC_440GXa      = 0x51B21850,
4562 a750fc0b j_mayer
    CPU_POWERPC_440GXb      = 0x51B21851,
4563 a750fc0b j_mayer
    CPU_POWERPC_440GXc      = 0x51B21892,
4564 a750fc0b j_mayer
    CPU_POWERPC_440GXf      = 0x51B21894,
4565 a750fc0b j_mayer
#if 0
4566 a750fc0b j_mayer
    CPU_POWERPC_440S        = xxx,
4567 a750fc0b j_mayer
#endif
4568 a750fc0b j_mayer
    CPU_POWERPC_440SP       = 0x53221850,
4569 a750fc0b j_mayer
    CPU_POWERPC_440SP2      = 0x53221891,
4570 a750fc0b j_mayer
    CPU_POWERPC_440SPE      = 0x53421890,
4571 a750fc0b j_mayer
    /* PowerPC 460 family */
4572 a750fc0b j_mayer
#if 0
4573 a750fc0b j_mayer
    /* Generic PowerPC 464 */
4574 a750fc0b j_mayer
#define CPU_POWERPC_464       CPU_POWERPC_464H90
4575 a750fc0b j_mayer
#endif
4576 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers */
4577 a750fc0b j_mayer
#if 0
4578 a750fc0b j_mayer
    CPU_POWERPC_464H90      = xxx,
4579 a750fc0b j_mayer
#endif
4580 a750fc0b j_mayer
#if 0
4581 a750fc0b j_mayer
    CPU_POWERPC_464H90FP    = xxx,
4582 a750fc0b j_mayer
#endif
4583 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores */
4584 a750fc0b j_mayer
    /* e200 family */
4585 a750fc0b j_mayer
#define CPU_POWERPC_e200      CPU_POWERPC_e200z6
4586 a750fc0b j_mayer
#if 0
4587 a750fc0b j_mayer
    CPU_POWERPC_e200z0      = xxx,
4588 a750fc0b j_mayer
#endif
4589 a750fc0b j_mayer
#if 0
4590 a750fc0b j_mayer
    CPU_POWERPC_e200z3      = xxx,
4591 a750fc0b j_mayer
#endif
4592 a750fc0b j_mayer
    CPU_POWERPC_e200z5      = 0x81000000,
4593 a750fc0b j_mayer
    CPU_POWERPC_e200z6      = 0x81120000,
4594 a750fc0b j_mayer
    /* e300 family */
4595 a750fc0b j_mayer
#define CPU_POWERPC_e300      CPU_POWERPC_e300c3
4596 a750fc0b j_mayer
    CPU_POWERPC_e300c1      = 0x00830000,
4597 a750fc0b j_mayer
    CPU_POWERPC_e300c2      = 0x00840000,
4598 a750fc0b j_mayer
    CPU_POWERPC_e300c3      = 0x00850000,
4599 a750fc0b j_mayer
    /* e500 family */
4600 a750fc0b j_mayer
#define CPU_POWERPC_e500      CPU_POWERPC_e500_v22
4601 a750fc0b j_mayer
    CPU_POWERPC_e500_v11    = 0x80200010,
4602 a750fc0b j_mayer
    CPU_POWERPC_e500_v12    = 0x80200020,
4603 a750fc0b j_mayer
    CPU_POWERPC_e500_v21    = 0x80210010,
4604 a750fc0b j_mayer
    CPU_POWERPC_e500_v22    = 0x80210020,
4605 a750fc0b j_mayer
#if 0
4606 a750fc0b j_mayer
    CPU_POWERPC_e500mc      = xxx,
4607 a750fc0b j_mayer
#endif
4608 a750fc0b j_mayer
    /* e600 family */
4609 a750fc0b j_mayer
    CPU_POWERPC_e600        = 0x80040010,
4610 a750fc0b j_mayer
    /* PowerPC MPC 5xx cores */
4611 a750fc0b j_mayer
    CPU_POWERPC_5xx         = 0x00020020,
4612 a750fc0b j_mayer
    /* PowerPC MPC 8xx cores (aka PowerQUICC) */
4613 a750fc0b j_mayer
    CPU_POWERPC_8xx         = 0x00500000,
4614 a750fc0b j_mayer
    /* PowerPC MPC 8xxx cores (aka PowerQUICC-II) */
4615 a750fc0b j_mayer
    CPU_POWERPC_82xx_HIP3   = 0x00810101,
4616 a750fc0b j_mayer
    CPU_POWERPC_82xx_HIP4   = 0x80811014,
4617 a750fc0b j_mayer
    CPU_POWERPC_827x        = 0x80822013,
4618 a750fc0b j_mayer
    /* PowerPC 6xx cores */
4619 a750fc0b j_mayer
    CPU_POWERPC_601         = 0x00010001,
4620 a750fc0b j_mayer
    CPU_POWERPC_601a        = 0x00010002,
4621 a750fc0b j_mayer
    CPU_POWERPC_602         = 0x00050100,
4622 a750fc0b j_mayer
    CPU_POWERPC_603         = 0x00030100,
4623 a750fc0b j_mayer
#define CPU_POWERPC_603E      CPU_POWERPC_603E_v41
4624 a750fc0b j_mayer
    CPU_POWERPC_603E_v11    = 0x00060101,
4625 a750fc0b j_mayer
    CPU_POWERPC_603E_v12    = 0x00060102,
4626 a750fc0b j_mayer
    CPU_POWERPC_603E_v13    = 0x00060103,
4627 a750fc0b j_mayer
    CPU_POWERPC_603E_v14    = 0x00060104,
4628 a750fc0b j_mayer
    CPU_POWERPC_603E_v22    = 0x00060202,
4629 a750fc0b j_mayer
    CPU_POWERPC_603E_v3     = 0x00060300,
4630 a750fc0b j_mayer
    CPU_POWERPC_603E_v4     = 0x00060400,
4631 a750fc0b j_mayer
    CPU_POWERPC_603E_v41    = 0x00060401,
4632 a750fc0b j_mayer
    CPU_POWERPC_603E7t      = 0x00071201,
4633 a750fc0b j_mayer
    CPU_POWERPC_603E7v      = 0x00070100,
4634 a750fc0b j_mayer
    CPU_POWERPC_603E7v1     = 0x00070101,
4635 a750fc0b j_mayer
    CPU_POWERPC_603E7v2     = 0x00070201,
4636 a750fc0b j_mayer
    CPU_POWERPC_603E7       = 0x00070200,
4637 a750fc0b j_mayer
    CPU_POWERPC_603P        = 0x00070000,
4638 a750fc0b j_mayer
#define CPU_POWERPC_603R      CPU_POWERPC_603E7t
4639 a750fc0b j_mayer
    CPU_POWERPC_G2          = 0x00810011,
4640 a750fc0b j_mayer
#if 0 // Linux pretends the MSB is zero...
4641 a750fc0b j_mayer
    CPU_POWERPC_G2H4        = 0x80811010,
4642 a750fc0b j_mayer
    CPU_POWERPC_G2gp        = 0x80821010,
4643 a750fc0b j_mayer
    CPU_POWERPC_G2ls        = 0x90810010,
4644 a750fc0b j_mayer
    CPU_POWERPC_G2LE        = 0x80820010,
4645 a750fc0b j_mayer
    CPU_POWERPC_G2LEgp      = 0x80822010,
4646 a750fc0b j_mayer
    CPU_POWERPC_G2LEls      = 0xA0822010,
4647 a750fc0b j_mayer
#else
4648 a750fc0b j_mayer
    CPU_POWERPC_G2H4        = 0x00811010,
4649 a750fc0b j_mayer
    CPU_POWERPC_G2gp        = 0x00821010,
4650 a750fc0b j_mayer
    CPU_POWERPC_G2ls        = 0x10810010,
4651 a750fc0b j_mayer
    CPU_POWERPC_G2LE        = 0x00820010,
4652 a750fc0b j_mayer
    CPU_POWERPC_G2LEgp      = 0x00822010,
4653 a750fc0b j_mayer
    CPU_POWERPC_G2LEls      = 0x20822010,
4654 a750fc0b j_mayer
#endif
4655 a750fc0b j_mayer
    CPU_POWERPC_604         = 0x00040103,
4656 a750fc0b j_mayer
#define CPU_POWERPC_604E      CPU_POWERPC_604E_v24
4657 a750fc0b j_mayer
    CPU_POWERPC_604E_v10    = 0x00090100, /* Also 2110 & 2120 */
4658 a750fc0b j_mayer
    CPU_POWERPC_604E_v22    = 0x00090202,
4659 a750fc0b j_mayer
    CPU_POWERPC_604E_v24    = 0x00090204,
4660 a750fc0b j_mayer
    CPU_POWERPC_604R        = 0x000a0101, /* Also 0x00093102 */
4661 a750fc0b j_mayer
#if 0
4662 a750fc0b j_mayer
    CPU_POWERPC_604EV       = xxx,
4663 a750fc0b j_mayer
#endif
4664 a750fc0b j_mayer
    /* PowerPC 740/750 cores (aka G3) */
4665 a750fc0b j_mayer
    /* XXX: missing 0x00084202 */
4666 a750fc0b j_mayer
#define CPU_POWERPC_7x0       CPU_POWERPC_7x0_v31
4667 a750fc0b j_mayer
    CPU_POWERPC_7x0_v20     = 0x00080200,
4668 a750fc0b j_mayer
    CPU_POWERPC_7x0_v21     = 0x00080201,
4669 a750fc0b j_mayer
    CPU_POWERPC_7x0_v22     = 0x00080202,
4670 a750fc0b j_mayer
    CPU_POWERPC_7x0_v30     = 0x00080300,
4671 a750fc0b j_mayer
    CPU_POWERPC_7x0_v31     = 0x00080301,
4672 a750fc0b j_mayer
    CPU_POWERPC_740E        = 0x00080100,
4673 a750fc0b j_mayer
    CPU_POWERPC_7x0P        = 0x10080000,
4674 a750fc0b j_mayer
    /* XXX: missing 0x00087010 (CL ?) */
4675 a750fc0b j_mayer
    CPU_POWERPC_750CL       = 0x00087200,
4676 a750fc0b j_mayer
#define CPU_POWERPC_750CX     CPU_POWERPC_750CX_v22
4677 a750fc0b j_mayer
    CPU_POWERPC_750CX_v21   = 0x00082201,
4678 a750fc0b j_mayer
    CPU_POWERPC_750CX_v22   = 0x00082202,
4679 a750fc0b j_mayer
#define CPU_POWERPC_750CXE    CPU_POWERPC_750CXE_v31b
4680 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v21  = 0x00082211,
4681 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v22  = 0x00082212,
4682 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v23  = 0x00082213,
4683 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v24  = 0x00082214,
4684 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v24b = 0x00083214,
4685 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v31  = 0x00083211,
4686 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v31b = 0x00083311,
4687 a750fc0b j_mayer
    CPU_POWERPC_750CXR      = 0x00083410,
4688 a750fc0b j_mayer
    CPU_POWERPC_750E        = 0x00080200,
4689 a750fc0b j_mayer
    CPU_POWERPC_750FL       = 0x700A0203,
4690 a750fc0b j_mayer
#define CPU_POWERPC_750FX     CPU_POWERPC_750FX_v23
4691 a750fc0b j_mayer
    CPU_POWERPC_750FX_v10   = 0x70000100,
4692 a750fc0b j_mayer
    CPU_POWERPC_750FX_v20   = 0x70000200,
4693 a750fc0b j_mayer
    CPU_POWERPC_750FX_v21   = 0x70000201,
4694 a750fc0b j_mayer
    CPU_POWERPC_750FX_v22   = 0x70000202,
4695 a750fc0b j_mayer
    CPU_POWERPC_750FX_v23   = 0x70000203,
4696 a750fc0b j_mayer
    CPU_POWERPC_750GL       = 0x70020102,
4697 a750fc0b j_mayer
#define CPU_POWERPC_750GX     CPU_POWERPC_750GX_v12
4698 a750fc0b j_mayer
    CPU_POWERPC_750GX_v10   = 0x70020100,
4699 a750fc0b j_mayer
    CPU_POWERPC_750GX_v11   = 0x70020101,
4700 a750fc0b j_mayer
    CPU_POWERPC_750GX_v12   = 0x70020102,
4701 a750fc0b j_mayer
#define CPU_POWERPC_750L      CPU_POWERPC_750L_v32 /* Aka LoneStar */
4702 a750fc0b j_mayer
    CPU_POWERPC_750L_v22    = 0x00088202,
4703 a750fc0b j_mayer
    CPU_POWERPC_750L_v30    = 0x00088300,
4704 a750fc0b j_mayer
    CPU_POWERPC_750L_v32    = 0x00088302,
4705 a750fc0b j_mayer
    /* PowerPC 745/755 cores */
4706 a750fc0b j_mayer
#define CPU_POWERPC_7x5       CPU_POWERPC_7x5_v28
4707 a750fc0b j_mayer
    CPU_POWERPC_7x5_v10     = 0x00083100,
4708 a750fc0b j_mayer
    CPU_POWERPC_7x5_v11     = 0x00083101,
4709 a750fc0b j_mayer
    CPU_POWERPC_7x5_v20     = 0x00083200,
4710 a750fc0b j_mayer
    CPU_POWERPC_7x5_v21     = 0x00083201,
4711 a750fc0b j_mayer
    CPU_POWERPC_7x5_v22     = 0x00083202, /* aka D */
4712 a750fc0b j_mayer
    CPU_POWERPC_7x5_v23     = 0x00083203, /* aka E */
4713 a750fc0b j_mayer
    CPU_POWERPC_7x5_v24     = 0x00083204,
4714 a750fc0b j_mayer
    CPU_POWERPC_7x5_v25     = 0x00083205,
4715 a750fc0b j_mayer
    CPU_POWERPC_7x5_v26     = 0x00083206,
4716 a750fc0b j_mayer
    CPU_POWERPC_7x5_v27     = 0x00083207,
4717 a750fc0b j_mayer
    CPU_POWERPC_7x5_v28     = 0x00083208,
4718 a750fc0b j_mayer
#if 0
4719 a750fc0b j_mayer
    CPU_POWERPC_7x5P        = xxx,
4720 a750fc0b j_mayer
#endif
4721 a750fc0b j_mayer
    /* PowerPC 74xx cores (aka G4) */
4722 a750fc0b j_mayer
    /* XXX: missing 0x000C1101 */
4723 a750fc0b j_mayer
#define CPU_POWERPC_7400      CPU_POWERPC_7400_v29
4724 a750fc0b j_mayer
    CPU_POWERPC_7400_v10    = 0x000C0100,
4725 a750fc0b j_mayer
    CPU_POWERPC_7400_v11    = 0x000C0101,
4726 a750fc0b j_mayer
    CPU_POWERPC_7400_v20    = 0x000C0200,
4727 a750fc0b j_mayer
    CPU_POWERPC_7400_v22    = 0x000C0202,
4728 a750fc0b j_mayer
    CPU_POWERPC_7400_v26    = 0x000C0206,
4729 a750fc0b j_mayer
    CPU_POWERPC_7400_v27    = 0x000C0207,
4730 a750fc0b j_mayer
    CPU_POWERPC_7400_v28    = 0x000C0208,
4731 a750fc0b j_mayer
    CPU_POWERPC_7400_v29    = 0x000C0209,
4732 a750fc0b j_mayer
#define CPU_POWERPC_7410      CPU_POWERPC_7410_v14
4733 a750fc0b j_mayer
    CPU_POWERPC_7410_v10    = 0x800C1100,
4734 a750fc0b j_mayer
    CPU_POWERPC_7410_v11    = 0x800C1101,
4735 a750fc0b j_mayer
    CPU_POWERPC_7410_v12    = 0x800C1102, /* aka C */
4736 a750fc0b j_mayer
    CPU_POWERPC_7410_v13    = 0x800C1103, /* aka D */
4737 a750fc0b j_mayer
    CPU_POWERPC_7410_v14    = 0x800C1104, /* aka E */
4738 a750fc0b j_mayer
#define CPU_POWERPC_7448      CPU_POWERPC_7448_v21
4739 a750fc0b j_mayer
    CPU_POWERPC_7448_v10    = 0x80040100,
4740 a750fc0b j_mayer
    CPU_POWERPC_7448_v11    = 0x80040101,
4741 a750fc0b j_mayer
    CPU_POWERPC_7448_v20    = 0x80040200,
4742 a750fc0b j_mayer
    CPU_POWERPC_7448_v21    = 0x80040201,
4743 a750fc0b j_mayer
#define CPU_POWERPC_7450      CPU_POWERPC_7450_v21
4744 a750fc0b j_mayer
    CPU_POWERPC_7450_v10    = 0x80000100,
4745 a750fc0b j_mayer
    CPU_POWERPC_7450_v11    = 0x80000101,
4746 a750fc0b j_mayer
    CPU_POWERPC_7450_v12    = 0x80000102,
4747 a750fc0b j_mayer
    CPU_POWERPC_7450_v20    = 0x80000200, /* aka D: 2.04 */
4748 a750fc0b j_mayer
    CPU_POWERPC_7450_v21    = 0x80000201, /* aka E */
4749 a750fc0b j_mayer
    CPU_POWERPC_74x1        = 0x80000203,
4750 a750fc0b j_mayer
    CPU_POWERPC_74x1G       = 0x80000210, /* aka G: 2.3 */
4751 a750fc0b j_mayer
    /* XXX: missing 0x80010200 */
4752 a750fc0b j_mayer
#define CPU_POWERPC_74x5      CPU_POWERPC_74x5_v32
4753 a750fc0b j_mayer
    CPU_POWERPC_74x5_v10    = 0x80010100,
4754 a750fc0b j_mayer
    CPU_POWERPC_74x5_v21    = 0x80010201, /* aka C: 2.1 */
4755 a750fc0b j_mayer
    CPU_POWERPC_74x5_v32    = 0x80010302,
4756 a750fc0b j_mayer
    CPU_POWERPC_74x5_v33    = 0x80010303, /* aka F: 3.3 */
4757 a750fc0b j_mayer
    CPU_POWERPC_74x5_v34    = 0x80010304, /* aka G: 3.4 */
4758 a750fc0b j_mayer
#define CPU_POWERPC_74x7      CPU_POWERPC_74x7_v12
4759 a750fc0b j_mayer
    CPU_POWERPC_74x7_v10    = 0x80020100, /* aka A: 1.0 */
4760 a750fc0b j_mayer
    CPU_POWERPC_74x7_v11    = 0x80030101, /* aka B: 1.1 */
4761 a750fc0b j_mayer
    CPU_POWERPC_74x7_v12    = 0x80020102, /* aka C: 1.2 */
4762 a750fc0b j_mayer
    /* 64 bits PowerPC */
4763 00af685f j_mayer
#if defined(TARGET_PPC64)
4764 a750fc0b j_mayer
    CPU_POWERPC_620         = 0x00140000,
4765 a750fc0b j_mayer
    CPU_POWERPC_630         = 0x00400000,
4766 a750fc0b j_mayer
    CPU_POWERPC_631         = 0x00410104,
4767 a750fc0b j_mayer
    CPU_POWERPC_POWER4      = 0x00350000,
4768 a750fc0b j_mayer
    CPU_POWERPC_POWER4P     = 0x00380000,
4769 a750fc0b j_mayer
    CPU_POWERPC_POWER5      = 0x003A0203,
4770 a750fc0b j_mayer
#define CPU_POWERPC_POWER5GR  CPU_POWERPC_POWER5
4771 a750fc0b j_mayer
    CPU_POWERPC_POWER5P     = 0x003B0000,
4772 a750fc0b j_mayer
#define CPU_POWERPC_POWER5GS  CPU_POWERPC_POWER5P
4773 a750fc0b j_mayer
    CPU_POWERPC_POWER6      = 0x003E0000,
4774 a750fc0b j_mayer
    CPU_POWERPC_POWER6_5    = 0x0F000001, /* POWER6 running POWER5 mode */
4775 a750fc0b j_mayer
    CPU_POWERPC_POWER6A     = 0x0F000002,
4776 a750fc0b j_mayer
    CPU_POWERPC_970         = 0x00390202,
4777 a750fc0b j_mayer
#define CPU_POWERPC_970FX     CPU_POWERPC_970FX_v31
4778 a750fc0b j_mayer
    CPU_POWERPC_970FX_v10   = 0x00391100,
4779 a750fc0b j_mayer
    CPU_POWERPC_970FX_v20   = 0x003C0200,
4780 a750fc0b j_mayer
    CPU_POWERPC_970FX_v21   = 0x003C0201,
4781 a750fc0b j_mayer
    CPU_POWERPC_970FX_v30   = 0x003C0300,
4782 a750fc0b j_mayer
    CPU_POWERPC_970FX_v31   = 0x003C0301,
4783 a750fc0b j_mayer
    CPU_POWERPC_970GX       = 0x00450000,
4784 a750fc0b j_mayer
#define CPU_POWERPC_970MP     CPU_POWERPC_970MP_v11
4785 a750fc0b j_mayer
    CPU_POWERPC_970MP_v10   = 0x00440100,
4786 a750fc0b j_mayer
    CPU_POWERPC_970MP_v11   = 0x00440101,
4787 a750fc0b j_mayer
#define CPU_POWERPC_CELL      CPU_POWERPC_CELL_v32
4788 a750fc0b j_mayer
    CPU_POWERPC_CELL_v10    = 0x00700100,
4789 a750fc0b j_mayer
    CPU_POWERPC_CELL_v20    = 0x00700400,
4790 a750fc0b j_mayer
    CPU_POWERPC_CELL_v30    = 0x00700500,
4791 a750fc0b j_mayer
    CPU_POWERPC_CELL_v31    = 0x00700501,
4792 a750fc0b j_mayer
#define CPU_POWERPC_CELL_v32  CPU_POWERPC_CELL_v31
4793 a750fc0b j_mayer
    CPU_POWERPC_RS64        = 0x00330000,
4794 a750fc0b j_mayer
    CPU_POWERPC_RS64II      = 0x00340000,
4795 a750fc0b j_mayer
    CPU_POWERPC_RS64III     = 0x00360000,
4796 a750fc0b j_mayer
    CPU_POWERPC_RS64IV      = 0x00370000,
4797 00af685f j_mayer
#endif /* defined(TARGET_PPC64) */
4798 a750fc0b j_mayer
    /* Original POWER */
4799 a750fc0b j_mayer
    /* XXX: should be POWER (RIOS), RSC3308, RSC4608,
4800 a750fc0b j_mayer
     * POWER2 (RIOS2) & RSC2 (P2SC) here
4801 a750fc0b j_mayer
     */
4802 a750fc0b j_mayer
#if 0
4803 a750fc0b j_mayer
    CPU_POWER           = xxx, /* 0x20000 ? 0x30000 for RSC ? */
4804 a750fc0b j_mayer
#endif
4805 a750fc0b j_mayer
#if 0
4806 a750fc0b j_mayer
    CPU_POWER2          = xxx, /* 0x40000 ? */
4807 a750fc0b j_mayer
#endif
4808 a750fc0b j_mayer
    /* PA Semi core */
4809 a750fc0b j_mayer
    CPU_POWERPC_PA6T        = 0x00900000,
4810 a750fc0b j_mayer
};
4811 a750fc0b j_mayer
4812 a750fc0b j_mayer
/* System version register (used on MPC 8xxx)                                */
4813 a750fc0b j_mayer
enum {
4814 a750fc0b j_mayer
    PPC_SVR_8540      = 0x80300000,
4815 a750fc0b j_mayer
    PPC_SVR_8541E     = 0x807A0010,
4816 a750fc0b j_mayer
    PPC_SVR_8543v10   = 0x80320010,
4817 a750fc0b j_mayer
    PPC_SVR_8543v11   = 0x80320011,
4818 a750fc0b j_mayer
    PPC_SVR_8543v20   = 0x80320020,
4819 a750fc0b j_mayer
    PPC_SVR_8543Ev10  = 0x803A0010,
4820 a750fc0b j_mayer
    PPC_SVR_8543Ev11  = 0x803A0011,
4821 a750fc0b j_mayer
    PPC_SVR_8543Ev20  = 0x803A0020,
4822 a750fc0b j_mayer
    PPC_SVR_8545      = 0x80310220,
4823 a750fc0b j_mayer
    PPC_SVR_8545E     = 0x80390220,
4824 a750fc0b j_mayer
    PPC_SVR_8547E     = 0x80390120,
4825 a750fc0b j_mayer
    PPC_SCR_8548v10   = 0x80310010,
4826 a750fc0b j_mayer
    PPC_SCR_8548v11   = 0x80310011,
4827 a750fc0b j_mayer
    PPC_SCR_8548v20   = 0x80310020,
4828 a750fc0b j_mayer
    PPC_SVR_8548Ev10  = 0x80390010,
4829 a750fc0b j_mayer
    PPC_SVR_8548Ev11  = 0x80390011,
4830 a750fc0b j_mayer
    PPC_SVR_8548Ev20  = 0x80390020,
4831 a750fc0b j_mayer
    PPC_SVR_8555E     = 0x80790010,
4832 a750fc0b j_mayer
    PPC_SVR_8560v10   = 0x80700010,
4833 a750fc0b j_mayer
    PPC_SVR_8560v20   = 0x80700020,
4834 a750fc0b j_mayer
};
4835 a750fc0b j_mayer
4836 3fc6c082 bellard
/*****************************************************************************/
4837 a750fc0b j_mayer
/* PowerPC CPU definitions                                                   */
4838 a750fc0b j_mayer
#define POWERPC_DEF(_name, _pvr, _pvr_mask, _type)                            \
4839 a750fc0b j_mayer
    {                                                                         \
4840 a750fc0b j_mayer
        .name        = _name,                                                 \
4841 a750fc0b j_mayer
        .pvr         = _pvr,                                                  \
4842 a750fc0b j_mayer
        .pvr_mask    = _pvr_mask,                                             \
4843 a750fc0b j_mayer
        .insns_flags = glue(POWERPC_INSNS_,_type),                            \
4844 a750fc0b j_mayer
        .msr_mask    = glue(POWERPC_MSRM_,_type),                             \
4845 a750fc0b j_mayer
        .mmu_model   = glue(POWERPC_MMU_,_type),                              \
4846 a750fc0b j_mayer
        .excp_model  = glue(POWERPC_EXCP_,_type),                             \
4847 a750fc0b j_mayer
        .bus_model   = glue(POWERPC_INPUT_,_type),                            \
4848 237c0af0 j_mayer
        .bfd_mach    = glue(POWERPC_BFDM_,_type),                             \
4849 d26bfc9a j_mayer
        .flags       = glue(POWERPC_FLAG_,_type),                             \
4850 a750fc0b j_mayer
        .init_proc   = &glue(init_proc_,_type),                               \
4851 a750fc0b j_mayer
    }
4852 a750fc0b j_mayer
4853 3a607854 j_mayer
static ppc_def_t ppc_defs[] = {
4854 a750fc0b j_mayer
    /* Embedded PowerPC                                                      */
4855 a750fc0b j_mayer
    /* PowerPC 401 family                                                    */
4856 2662a059 j_mayer
    /* Generic PowerPC 401 */
4857 a750fc0b j_mayer
    POWERPC_DEF("401",         CPU_POWERPC_401,         0xFFFF0000, 401),
4858 a750fc0b j_mayer
    /* PowerPC 401 cores                                                     */
4859 2662a059 j_mayer
    /* PowerPC 401A1 */
4860 a750fc0b j_mayer
    POWERPC_DEF("401A1",       CPU_POWERPC_401A1,       0xFFFFFFFF, 401),
4861 a750fc0b j_mayer
    /* PowerPC 401B2                                                         */
4862 a750fc0b j_mayer
    POWERPC_DEF("401B2",       CPU_POWERPC_401B2,       0xFFFFFFFF, 401x2),
4863 2662a059 j_mayer
#if defined (TODO)
4864 a750fc0b j_mayer
    /* PowerPC 401B3                                                         */
4865 a750fc0b j_mayer
    POWERPC_DEF("401B3",       CPU_POWERPC_401B3,       0xFFFFFFFF, 401x3),
4866 a750fc0b j_mayer
#endif
4867 a750fc0b j_mayer
    /* PowerPC 401C2                                                         */
4868 a750fc0b j_mayer
    POWERPC_DEF("401C2",       CPU_POWERPC_401C2,       0xFFFFFFFF, 401x2),
4869 a750fc0b j_mayer
    /* PowerPC 401D2                                                         */
4870 a750fc0b j_mayer
    POWERPC_DEF("401D2",       CPU_POWERPC_401D2,       0xFFFFFFFF, 401x2),
4871 a750fc0b j_mayer
    /* PowerPC 401E2                                                         */
4872 a750fc0b j_mayer
    POWERPC_DEF("401E2",       CPU_POWERPC_401E2,       0xFFFFFFFF, 401x2),
4873 a750fc0b j_mayer
    /* PowerPC 401F2                                                         */
4874 a750fc0b j_mayer
    POWERPC_DEF("401F2",       CPU_POWERPC_401F2,       0xFFFFFFFF, 401x2),
4875 a750fc0b j_mayer
    /* PowerPC 401G2                                                         */
4876 a750fc0b j_mayer
    /* XXX: to be checked */
4877 a750fc0b j_mayer
    POWERPC_DEF("401G2",       CPU_POWERPC_401G2,       0xFFFFFFFF, 401x2),
4878 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers                                           */
4879 2662a059 j_mayer
#if defined (TODO)
4880 a750fc0b j_mayer
    /* PowerPC 401GF                                                         */
4881 a750fc0b j_mayer
    POWERPC_DEF("401GF",       CPU_POWERPC_401GF,       0xFFFFFFFF, 401),
4882 3fc6c082 bellard
#endif
4883 a750fc0b j_mayer
    /* IOP480 (401 microcontroler)                                           */
4884 a750fc0b j_mayer
    POWERPC_DEF("IOP480",      CPU_POWERPC_IOP480,      0xFFFFFFFF, IOP480),
4885 a750fc0b j_mayer
    /* IBM Processor for Network Resources                                   */
4886 a750fc0b j_mayer
    POWERPC_DEF("Cobra",       CPU_POWERPC_COBRA,       0xFFFFFFFF, 401),
4887 3fc6c082 bellard
#if defined (TODO)
4888 a750fc0b j_mayer
    POWERPC_DEF("Xipchip",     CPU_POWERPC_XIPCHIP,     0xFFFFFFFF, 401),
4889 3fc6c082 bellard
#endif
4890 a750fc0b j_mayer
    /* PowerPC 403 family                                                    */
4891 a750fc0b j_mayer
    /* Generic PowerPC 403                                                   */
4892 a750fc0b j_mayer
    POWERPC_DEF("403",         CPU_POWERPC_403,         0xFFFF0000, 403),
4893 a750fc0b j_mayer
    /* PowerPC 403 microcontrolers                                           */
4894 a750fc0b j_mayer
    /* PowerPC 403 GA                                                        */
4895 a750fc0b j_mayer
    POWERPC_DEF("403GA",       CPU_POWERPC_403GA,       0xFFFFFFFF, 403),
4896 a750fc0b j_mayer
    /* PowerPC 403 GB                                                        */
4897 a750fc0b j_mayer
    POWERPC_DEF("403GB",       CPU_POWERPC_403GB,       0xFFFFFFFF, 403),
4898 a750fc0b j_mayer
    /* PowerPC 403 GC                                                        */
4899 a750fc0b j_mayer
    POWERPC_DEF("403GC",       CPU_POWERPC_403GC,       0xFFFFFFFF, 403),
4900 a750fc0b j_mayer
    /* PowerPC 403 GCX                                                       */
4901 a750fc0b j_mayer
    POWERPC_DEF("403GCX",      CPU_POWERPC_403GCX,      0xFFFFFFFF, 403GCX),
4902 3fc6c082 bellard
#if defined (TODO)
4903 a750fc0b j_mayer
    /* PowerPC 403 GP                                                        */
4904 a750fc0b j_mayer
    POWERPC_DEF("403GP",       CPU_POWERPC_403GP,       0xFFFFFFFF, 403),
4905 3fc6c082 bellard
#endif
4906 a750fc0b j_mayer
    /* PowerPC 405 family                                                    */
4907 a750fc0b j_mayer
    /* Generic PowerPC 405                                                   */
4908 a750fc0b j_mayer
    POWERPC_DEF("405",         CPU_POWERPC_405,         0xFFFF0000, 405),
4909 a750fc0b j_mayer
    /* PowerPC 405 cores                                                     */
4910 2662a059 j_mayer
#if defined (TODO)
4911 a750fc0b j_mayer
    /* PowerPC 405 A3                                                        */
4912 a750fc0b j_mayer
    POWERPC_DEF("405A3",       CPU_POWERPC_405A3,       0xFFFFFFFF, 405),
4913 3a607854 j_mayer
#endif
4914 3a607854 j_mayer
#if defined (TODO)
4915 a750fc0b j_mayer
    /* PowerPC 405 A4                                                        */
4916 a750fc0b j_mayer
    POWERPC_DEF("405A4",       CPU_POWERPC_405A4,       0xFFFFFFFF, 405),
4917 3a607854 j_mayer
#endif
4918 3a607854 j_mayer
#if defined (TODO)
4919 a750fc0b j_mayer
    /* PowerPC 405 B3                                                        */
4920 a750fc0b j_mayer
    POWERPC_DEF("405B3",       CPU_POWERPC_405B3,       0xFFFFFFFF, 405),
4921 3fc6c082 bellard
#endif
4922 3fc6c082 bellard
#if defined (TODO)
4923 a750fc0b j_mayer
    /* PowerPC 405 B4                                                        */
4924 a750fc0b j_mayer
    POWERPC_DEF("405B4",       CPU_POWERPC_405B4,       0xFFFFFFFF, 405),
4925 a750fc0b j_mayer
#endif
4926 a750fc0b j_mayer
#if defined (TODO)
4927 a750fc0b j_mayer
    /* PowerPC 405 C3                                                        */
4928 a750fc0b j_mayer
    POWERPC_DEF("405C3",       CPU_POWERPC_405C3,       0xFFFFFFFF, 405),
4929 a750fc0b j_mayer
#endif
4930 a750fc0b j_mayer
#if defined (TODO)
4931 a750fc0b j_mayer
    /* PowerPC 405 C4                                                        */
4932 a750fc0b j_mayer
    POWERPC_DEF("405C4",       CPU_POWERPC_405C4,       0xFFFFFFFF, 405),
4933 a750fc0b j_mayer
#endif
4934 a750fc0b j_mayer
    /* PowerPC 405 D2                                                        */
4935 a750fc0b j_mayer
    POWERPC_DEF("405D2",       CPU_POWERPC_405D2,       0xFFFFFFFF, 405),
4936 a750fc0b j_mayer
#if defined (TODO)
4937 a750fc0b j_mayer
    /* PowerPC 405 D3                                                        */
4938 a750fc0b j_mayer
    POWERPC_DEF("405D3",       CPU_POWERPC_405D3,       0xFFFFFFFF, 405),
4939 a750fc0b j_mayer
#endif
4940 a750fc0b j_mayer
    /* PowerPC 405 D4                                                        */
4941 a750fc0b j_mayer
    POWERPC_DEF("405D4",       CPU_POWERPC_405D4,       0xFFFFFFFF, 405),
4942 a750fc0b j_mayer
#if defined (TODO)
4943 a750fc0b j_mayer
    /* PowerPC 405 D5                                                        */
4944 a750fc0b j_mayer
    POWERPC_DEF("405D5",       CPU_POWERPC_405D5,       0xFFFFFFFF, 405),
4945 a750fc0b j_mayer
#endif
4946 a750fc0b j_mayer
#if defined (TODO)
4947 a750fc0b j_mayer
    /* PowerPC 405 E4                                                        */
4948 a750fc0b j_mayer
    POWERPC_DEF("405E4",       CPU_POWERPC_405E4,       0xFFFFFFFF, 405),
4949 a750fc0b j_mayer
#endif
4950 a750fc0b j_mayer
#if defined (TODO)
4951 a750fc0b j_mayer
    /* PowerPC 405 F4                                                        */
4952 a750fc0b j_mayer
    POWERPC_DEF("405F4",       CPU_POWERPC_405F4,       0xFFFFFFFF, 405),
4953 a750fc0b j_mayer
#endif
4954 a750fc0b j_mayer
#if defined (TODO)
4955 a750fc0b j_mayer
    /* PowerPC 405 F5                                                        */
4956 a750fc0b j_mayer
    POWERPC_DEF("405F5",       CPU_POWERPC_405F5,       0xFFFFFFFF, 405),
4957 a750fc0b j_mayer
#endif
4958 a750fc0b j_mayer
#if defined (TODO)
4959 a750fc0b j_mayer
    /* PowerPC 405 F6                                                        */
4960 a750fc0b j_mayer
    POWERPC_DEF("405F6",       CPU_POWERPC_405F6,       0xFFFFFFFF, 405),
4961 a750fc0b j_mayer
#endif
4962 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers                                           */
4963 a750fc0b j_mayer
    /* PowerPC 405 CR                                                        */
4964 a750fc0b j_mayer
    POWERPC_DEF("405CR",       CPU_POWERPC_405CR,       0xFFFFFFFF, 405),
4965 a750fc0b j_mayer
    /* PowerPC 405 CRa                                                       */
4966 a750fc0b j_mayer
    POWERPC_DEF("405CRa",      CPU_POWERPC_405CRa,      0xFFFFFFFF, 405),
4967 a750fc0b j_mayer
    /* PowerPC 405 CRb                                                       */
4968 a750fc0b j_mayer
    POWERPC_DEF("405CRb",      CPU_POWERPC_405CRb,      0xFFFFFFFF, 405),
4969 a750fc0b j_mayer
    /* PowerPC 405 CRc                                                       */
4970 a750fc0b j_mayer
    POWERPC_DEF("405CRc",      CPU_POWERPC_405CRc,      0xFFFFFFFF, 405),
4971 a750fc0b j_mayer
    /* PowerPC 405 EP                                                        */
4972 a750fc0b j_mayer
    POWERPC_DEF("405EP",       CPU_POWERPC_405EP,       0xFFFFFFFF, 405),
4973 a750fc0b j_mayer
#if defined(TODO)
4974 a750fc0b j_mayer
    /* PowerPC 405 EXr                                                       */
4975 a750fc0b j_mayer
    POWERPC_DEF("405EXr",      CPU_POWERPC_405EXr,      0xFFFFFFFF, 405),
4976 a750fc0b j_mayer
#endif
4977 a750fc0b j_mayer
    /* PowerPC 405 EZ                                                        */
4978 a750fc0b j_mayer
    POWERPC_DEF("405EZ",       CPU_POWERPC_405EZ,       0xFFFFFFFF, 405),
4979 a750fc0b j_mayer
#if defined(TODO)
4980 a750fc0b j_mayer
    /* PowerPC 405 FX                                                        */
4981 a750fc0b j_mayer
    POWERPC_DEF("405FX",       CPU_POWERPC_405FX,       0xFFFFFFFF, 405),
4982 a750fc0b j_mayer
#endif
4983 a750fc0b j_mayer
    /* PowerPC 405 GP                                                        */
4984 a750fc0b j_mayer
    POWERPC_DEF("405GP",       CPU_POWERPC_405GP,       0xFFFFFFFF, 405),
4985 a750fc0b j_mayer
    /* PowerPC 405 GPa                                                       */
4986 a750fc0b j_mayer
    POWERPC_DEF("405GPa",      CPU_POWERPC_405GPa,      0xFFFFFFFF, 405),
4987 a750fc0b j_mayer
    /* PowerPC 405 GPb                                                       */
4988 a750fc0b j_mayer
    POWERPC_DEF("405GPb",      CPU_POWERPC_405GPb,      0xFFFFFFFF, 405),
4989 a750fc0b j_mayer
    /* PowerPC 405 GPc                                                       */
4990 a750fc0b j_mayer
    POWERPC_DEF("405GPc",      CPU_POWERPC_405GPc,      0xFFFFFFFF, 405),
4991 a750fc0b j_mayer
    /* PowerPC 405 GPd                                                       */
4992 a750fc0b j_mayer
    POWERPC_DEF("405GPd",      CPU_POWERPC_405GPd,      0xFFFFFFFF, 405),
4993 a750fc0b j_mayer
    /* PowerPC 405 GPe                                                       */
4994 a750fc0b j_mayer
    POWERPC_DEF("405GPe",      CPU_POWERPC_405GPe,      0xFFFFFFFF, 405),
4995 a750fc0b j_mayer
    /* PowerPC 405 GPR                                                       */
4996 a750fc0b j_mayer
    POWERPC_DEF("405GPR",      CPU_POWERPC_405GPR,      0xFFFFFFFF, 405),
4997 a750fc0b j_mayer
#if defined(TODO)
4998 a750fc0b j_mayer
    /* PowerPC 405 H                                                         */
4999 a750fc0b j_mayer
    POWERPC_DEF("405H",        CPU_POWERPC_405H,        0xFFFFFFFF, 405),
5000 a750fc0b j_mayer
#endif
5001 a750fc0b j_mayer
#if defined(TODO)
5002 a750fc0b j_mayer
    /* PowerPC 405 L                                                         */
5003 a750fc0b j_mayer
    POWERPC_DEF("405L",        CPU_POWERPC_405L,        0xFFFFFFFF, 405),
5004 a750fc0b j_mayer
#endif
5005 a750fc0b j_mayer
    /* PowerPC 405 LP                                                        */
5006 a750fc0b j_mayer
    POWERPC_DEF("405LP",       CPU_POWERPC_405LP,       0xFFFFFFFF, 405),
5007 a750fc0b j_mayer
#if defined(TODO)
5008 a750fc0b j_mayer
    /* PowerPC 405 PM                                                        */
5009 a750fc0b j_mayer
    POWERPC_DEF("405PM",       CPU_POWERPC_405PM,       0xFFFFFFFF, 405),
5010 a750fc0b j_mayer
#endif
5011 a750fc0b j_mayer
#if defined(TODO)
5012 a750fc0b j_mayer
    /* PowerPC 405 PS                                                        */
5013 a750fc0b j_mayer
    POWERPC_DEF("405PS",       CPU_POWERPC_405PS,       0xFFFFFFFF, 405),
5014 a750fc0b j_mayer
#endif
5015 a750fc0b j_mayer
#if defined(TODO)
5016 a750fc0b j_mayer
    /* PowerPC 405 S                                                         */
5017 a750fc0b j_mayer
    POWERPC_DEF("405S",        CPU_POWERPC_405S,        0xFFFFFFFF, 405),
5018 a750fc0b j_mayer
#endif
5019 a750fc0b j_mayer
    /* Npe405 H                                                              */
5020 a750fc0b j_mayer
    POWERPC_DEF("Npe405H",     CPU_POWERPC_NPE405H,     0xFFFFFFFF, 405),
5021 a750fc0b j_mayer
    /* Npe405 H2                                                             */
5022 a750fc0b j_mayer
    POWERPC_DEF("Npe405H2",    CPU_POWERPC_NPE405H2,    0xFFFFFFFF, 405),
5023 a750fc0b j_mayer
    /* Npe405 L                                                              */
5024 a750fc0b j_mayer
    POWERPC_DEF("Npe405L",     CPU_POWERPC_NPE405L,     0xFFFFFFFF, 405),
5025 a750fc0b j_mayer
    /* Npe4GS3                                                               */
5026 a750fc0b j_mayer
    POWERPC_DEF("Npe4GS3",     CPU_POWERPC_NPE4GS3,     0xFFFFFFFF, 405),
5027 a750fc0b j_mayer
#if defined (TODO)
5028 a750fc0b j_mayer
    POWERPC_DEF("Npcxx1",      CPU_POWERPC_NPCxx1,      0xFFFFFFFF, 405),
5029 a750fc0b j_mayer
#endif
5030 a750fc0b j_mayer
#if defined (TODO)
5031 a750fc0b j_mayer
    POWERPC_DEF("Npr161",      CPU_POWERPC_NPR161,      0xFFFFFFFF, 405),
5032 a750fc0b j_mayer
#endif
5033 a750fc0b j_mayer
#if defined (TODO)
5034 a750fc0b j_mayer
    /* PowerPC LC77700 (Sanyo)                                               */
5035 a750fc0b j_mayer
    POWERPC_DEF("LC77700",     CPU_POWERPC_LC77700,     0xFFFFFFFF, 405),
5036 a750fc0b j_mayer
#endif
5037 a750fc0b j_mayer
    /* PowerPC 401/403/405 based set-top-box microcontrolers                 */
5038 a750fc0b j_mayer
#if defined (TODO)
5039 a750fc0b j_mayer
    /* STB010000                                                             */
5040 a750fc0b j_mayer
    POWERPC_DEF("STB01000",    CPU_POWERPC_STB01000,    0xFFFFFFFF, 401x2),
5041 a750fc0b j_mayer
#endif
5042 a750fc0b j_mayer
#if defined (TODO)
5043 a750fc0b j_mayer
    /* STB01010                                                              */
5044 a750fc0b j_mayer
    POWERPC_DEF("STB01010",    CPU_POWERPC_STB01010,    0xFFFFFFFF, 401x2),
5045 a750fc0b j_mayer
#endif
5046 a750fc0b j_mayer
#if defined (TODO)
5047 a750fc0b j_mayer
    /* STB0210                                                               */
5048 a750fc0b j_mayer
    POWERPC_DEF("STB0210",     CPU_POWERPC_STB0210,     0xFFFFFFFF, 401x3),
5049 a750fc0b j_mayer
#endif
5050 a750fc0b j_mayer
    /* STB03xx                                                               */
5051 a750fc0b j_mayer
    POWERPC_DEF("STB03",       CPU_POWERPC_STB03,       0xFFFFFFFF, 405),
5052 a750fc0b j_mayer
#if defined (TODO)
5053 a750fc0b j_mayer
    /* STB043x                                                               */
5054 a750fc0b j_mayer
    POWERPC_DEF("STB043",      CPU_POWERPC_STB043,      0xFFFFFFFF, 405),
5055 a750fc0b j_mayer
#endif
5056 a750fc0b j_mayer
#if defined (TODO)
5057 a750fc0b j_mayer
    /* STB045x                                                               */
5058 a750fc0b j_mayer
    POWERPC_DEF("STB045",      CPU_POWERPC_STB045,      0xFFFFFFFF, 405),
5059 a750fc0b j_mayer
#endif
5060 a750fc0b j_mayer
    /* STB04xx                                                               */
5061 a750fc0b j_mayer
    POWERPC_DEF("STB04",       CPU_POWERPC_STB04,       0xFFFF0000, 405),
5062 a750fc0b j_mayer
    /* STB25xx                                                               */
5063 a750fc0b j_mayer
    POWERPC_DEF("STB25",       CPU_POWERPC_STB25,       0xFFFFFFFF, 405),
5064 a750fc0b j_mayer
#if defined (TODO)
5065 a750fc0b j_mayer
    /* STB130                                                                */
5066 a750fc0b j_mayer
    POWERPC_DEF("STB130",      CPU_POWERPC_STB130,      0xFFFFFFFF, 405),
5067 a750fc0b j_mayer
#endif
5068 a750fc0b j_mayer
    /* Xilinx PowerPC 405 cores                                              */
5069 a750fc0b j_mayer
    POWERPC_DEF("x2vp4",       CPU_POWERPC_X2VP4,       0xFFFFFFFF, 405),
5070 a750fc0b j_mayer
    POWERPC_DEF("x2vp7",       CPU_POWERPC_X2VP7,       0xFFFFFFFF, 405),
5071 a750fc0b j_mayer
    POWERPC_DEF("x2vp20",      CPU_POWERPC_X2VP20,      0xFFFFFFFF, 405),
5072 a750fc0b j_mayer
    POWERPC_DEF("x2vp50",      CPU_POWERPC_X2VP50,      0xFFFFFFFF, 405),
5073 a750fc0b j_mayer
#if defined (TODO)
5074 a750fc0b j_mayer
    /* Zarlink ZL10310                                                       */
5075 a750fc0b j_mayer
    POWERPC_DEF("zl10310",     CPU_POWERPC_ZL10310,     0xFFFFFFFF, 405),
5076 a750fc0b j_mayer
#endif
5077 a750fc0b j_mayer
#if defined (TODO)
5078 a750fc0b j_mayer
    /* Zarlink ZL10311                                                       */
5079 a750fc0b j_mayer
    POWERPC_DEF("zl10311",     CPU_POWERPC_ZL10311,     0xFFFFFFFF, 405),
5080 a750fc0b j_mayer
#endif
5081 a750fc0b j_mayer
#if defined (TODO)
5082 a750fc0b j_mayer
    /* Zarlink ZL10320                                                       */
5083 a750fc0b j_mayer
    POWERPC_DEF("zl10320",     CPU_POWERPC_ZL10320,     0xFFFFFFFF, 405),
5084 a750fc0b j_mayer
#endif
5085 a750fc0b j_mayer
#if defined (TODO)
5086 a750fc0b j_mayer
    /* Zarlink ZL10321                                                       */
5087 a750fc0b j_mayer
    POWERPC_DEF("zl10321",     CPU_POWERPC_ZL10321,     0xFFFFFFFF, 405),
5088 a750fc0b j_mayer
#endif
5089 a750fc0b j_mayer
    /* PowerPC 440 family                                                    */
5090 a750fc0b j_mayer
    /* Generic PowerPC 440                                                   */
5091 a750fc0b j_mayer
    POWERPC_DEF("440",         CPU_POWERPC_440,         0xFFFFFFFF, 440GP),
5092 a750fc0b j_mayer
    /* PowerPC 440 cores                                                     */
5093 a750fc0b j_mayer
#if defined (TODO)
5094 a750fc0b j_mayer
    /* PowerPC 440 A4                                                        */
5095 a750fc0b j_mayer
    POWERPC_DEF("440A4",       CPU_POWERPC_440A4,       0xFFFFFFFF, 440x4),
5096 a750fc0b j_mayer
#endif
5097 a750fc0b j_mayer
#if defined (TODO)
5098 a750fc0b j_mayer
    /* PowerPC 440 A5                                                        */
5099 a750fc0b j_mayer
    POWERPC_DEF("440A5",       CPU_POWERPC_440A5,       0xFFFFFFFF, 440x5),
5100 a750fc0b j_mayer
#endif
5101 a750fc0b j_mayer
#if defined (TODO)
5102 a750fc0b j_mayer
    /* PowerPC 440 B4                                                        */
5103 a750fc0b j_mayer
    POWERPC_DEF("440B4",       CPU_POWERPC_440B4,       0xFFFFFFFF, 440x4),
5104 a750fc0b j_mayer
#endif
5105 a750fc0b j_mayer
#if defined (TODO)
5106 a750fc0b j_mayer
    /* PowerPC 440 G4                                                        */
5107 a750fc0b j_mayer
    POWERPC_DEF("440G4",       CPU_POWERPC_440G4,       0xFFFFFFFF, 440x4),
5108 a750fc0b j_mayer
#endif
5109 a750fc0b j_mayer
#if defined (TODO)
5110 a750fc0b j_mayer
    /* PowerPC 440 F5                                                        */
5111 a750fc0b j_mayer
    POWERPC_DEF("440F5",       CPU_POWERPC_440F5,       0xFFFFFFFF, 440x5),
5112 a750fc0b j_mayer
#endif
5113 a750fc0b j_mayer
#if defined (TODO)
5114 a750fc0b j_mayer
    /* PowerPC 440 G5                                                        */
5115 a750fc0b j_mayer
    POWERPC_DEF("440G5",       CPU_POWERPC_440G5,       0xFFFFFFFF, 440x5),
5116 a750fc0b j_mayer
#endif
5117 a750fc0b j_mayer
#if defined (TODO)
5118 a750fc0b j_mayer
    /* PowerPC 440H4                                                         */
5119 a750fc0b j_mayer
    POWERPC_DEF("440H4",       CPU_POWERPC_440H4,       0xFFFFFFFF, 440x4),
5120 a750fc0b j_mayer
#endif
5121 a750fc0b j_mayer
#if defined (TODO)
5122 a750fc0b j_mayer
    /* PowerPC 440H6                                                         */
5123 a750fc0b j_mayer
    POWERPC_DEF("440H6",       CPU_POWERPC_440H6,       0xFFFFFFFF, 440Gx5),
5124 a750fc0b j_mayer
#endif
5125 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers                                           */
5126 a750fc0b j_mayer
    /* PowerPC 440 EP                                                        */
5127 a750fc0b j_mayer
    POWERPC_DEF("440EP",       CPU_POWERPC_440EP,       0xFFFFFFFF, 440EP),
5128 a750fc0b j_mayer
    /* PowerPC 440 EPa                                                       */
5129 a750fc0b j_mayer
    POWERPC_DEF("440EPa",      CPU_POWERPC_440EPa,      0xFFFFFFFF, 440EP),
5130 a750fc0b j_mayer
    /* PowerPC 440 EPb                                                       */
5131 a750fc0b j_mayer
    POWERPC_DEF("440EPb",      CPU_POWERPC_440EPb,      0xFFFFFFFF, 440EP),
5132 a750fc0b j_mayer
    /* PowerPC 440 EPX                                                       */
5133 a750fc0b j_mayer
    POWERPC_DEF("440EPX",      CPU_POWERPC_440EPX,      0xFFFFFFFF, 440EP),
5134 a750fc0b j_mayer
    /* PowerPC 440 GP                                                        */
5135 a750fc0b j_mayer
    POWERPC_DEF("440GP",       CPU_POWERPC_440GP,       0xFFFFFFFF, 440GP),
5136 a750fc0b j_mayer
    /* PowerPC 440 GPb                                                       */
5137 a750fc0b j_mayer
    POWERPC_DEF("440GPb",      CPU_POWERPC_440GPb,      0xFFFFFFFF, 440GP),
5138 a750fc0b j_mayer
    /* PowerPC 440 GPc                                                       */
5139 a750fc0b j_mayer
    POWERPC_DEF("440GPc",      CPU_POWERPC_440GPc,      0xFFFFFFFF, 440GP),
5140 a750fc0b j_mayer
    /* PowerPC 440 GR                                                        */
5141 a750fc0b j_mayer
    POWERPC_DEF("440GR",       CPU_POWERPC_440GR,       0xFFFFFFFF, 440x5),
5142 a750fc0b j_mayer
    /* PowerPC 440 GRa                                                       */
5143 a750fc0b j_mayer
    POWERPC_DEF("440GRa",      CPU_POWERPC_440GRa,      0xFFFFFFFF, 440x5),
5144 a750fc0b j_mayer
    /* PowerPC 440 GRX                                                       */
5145 a750fc0b j_mayer
    POWERPC_DEF("440GRX",      CPU_POWERPC_440GRX,      0xFFFFFFFF, 440x5),
5146 a750fc0b j_mayer
    /* PowerPC 440 GX                                                        */
5147 a750fc0b j_mayer
    POWERPC_DEF("440GX",       CPU_POWERPC_440GX,       0xFFFFFFFF, 440EP),
5148 a750fc0b j_mayer
    /* PowerPC 440 GXa                                                       */
5149 a750fc0b j_mayer
    POWERPC_DEF("440GXa",      CPU_POWERPC_440GXa,      0xFFFFFFFF, 440EP),
5150 a750fc0b j_mayer
    /* PowerPC 440 GXb                                                       */
5151 a750fc0b j_mayer
    POWERPC_DEF("440GXb",      CPU_POWERPC_440GXb,      0xFFFFFFFF, 440EP),
5152 a750fc0b j_mayer
    /* PowerPC 440 GXc                                                       */
5153 a750fc0b j_mayer
    POWERPC_DEF("440GXc",      CPU_POWERPC_440GXc,      0xFFFFFFFF, 440EP),
5154 a750fc0b j_mayer
    /* PowerPC 440 GXf                                                       */
5155 a750fc0b j_mayer
    POWERPC_DEF("440GXf",      CPU_POWERPC_440GXf,      0xFFFFFFFF, 440EP),
5156 a750fc0b j_mayer
#if defined(TODO)
5157 a750fc0b j_mayer
    /* PowerPC 440 S                                                         */
5158 a750fc0b j_mayer
    POWERPC_DEF("440S",        CPU_POWERPC_440S,        0xFFFFFFFF, 440),
5159 a750fc0b j_mayer
#endif
5160 a750fc0b j_mayer
    /* PowerPC 440 SP                                                        */
5161 a750fc0b j_mayer
    POWERPC_DEF("440SP",       CPU_POWERPC_440SP,       0xFFFFFFFF, 440EP),
5162 a750fc0b j_mayer
    /* PowerPC 440 SP2                                                       */
5163 a750fc0b j_mayer
    POWERPC_DEF("440SP2",      CPU_POWERPC_440SP2,      0xFFFFFFFF, 440EP),
5164 a750fc0b j_mayer
    /* PowerPC 440 SPE                                                       */
5165 a750fc0b j_mayer
    POWERPC_DEF("440SPE",      CPU_POWERPC_440SPE,      0xFFFFFFFF, 440EP),
5166 a750fc0b j_mayer
    /* PowerPC 460 family                                                    */
5167 a750fc0b j_mayer
#if defined (TODO)
5168 a750fc0b j_mayer
    /* Generic PowerPC 464                                                   */
5169 a750fc0b j_mayer
    POWERPC_DEF("464",         CPU_POWERPC_464,         0xFFFFFFFF, 460),
5170 a750fc0b j_mayer
#endif
5171 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers                                           */
5172 a750fc0b j_mayer
#if defined (TODO)
5173 a750fc0b j_mayer
    /* PowerPC 464H90                                                        */
5174 a750fc0b j_mayer
    POWERPC_DEF("464H90",      CPU_POWERPC_464H90,      0xFFFFFFFF, 460),
5175 a750fc0b j_mayer
#endif
5176 a750fc0b j_mayer
#if defined (TODO)
5177 a750fc0b j_mayer
    /* PowerPC 464H90F                                                       */
5178 a750fc0b j_mayer
    POWERPC_DEF("464H90F",     CPU_POWERPC_464H90F,     0xFFFFFFFF, 460F),
5179 a750fc0b j_mayer
#endif
5180 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores                                      */
5181 a750fc0b j_mayer
    /* e200 family                                                           */
5182 a750fc0b j_mayer
#if defined (TODO)
5183 a750fc0b j_mayer
    /* Generic PowerPC e200 core                                             */
5184 a750fc0b j_mayer
    POWERPC_DEF("e200",        CPU_POWERPC_e200,        0xFFFFFFFF, e200),
5185 a750fc0b j_mayer
#endif
5186 a750fc0b j_mayer
#if defined (TODO)
5187 a750fc0b j_mayer
    /* PowerPC e200z5 core                                                   */
5188 a750fc0b j_mayer
    POWERPC_DEF("e200z5",      CPU_POWERPC_e200z5,      0xFFFFFFFF, e200),
5189 a750fc0b j_mayer
#endif
5190 a750fc0b j_mayer
#if defined (TODO)
5191 a750fc0b j_mayer
    /* PowerPC e200z6 core                                                   */
5192 a750fc0b j_mayer
    POWERPC_DEF("e200z6",      CPU_POWERPC_e200z6,      0xFFFFFFFF, e200),
5193 a750fc0b j_mayer
#endif
5194 a750fc0b j_mayer
    /* e300 family                                                           */
5195 a750fc0b j_mayer
#if defined (TODO)
5196 a750fc0b j_mayer
    /* Generic PowerPC e300 core                                             */
5197 a750fc0b j_mayer
    POWERPC_DEF("e300",        CPU_POWERPC_e300,        0xFFFFFFFF, e300),
5198 a750fc0b j_mayer
#endif
5199 a750fc0b j_mayer
#if defined (TODO)
5200 a750fc0b j_mayer
    /* PowerPC e300c1 core                                                   */
5201 a750fc0b j_mayer
    POWERPC_DEF("e300c1",      CPU_POWERPC_e300c1,      0xFFFFFFFF, e300),
5202 a750fc0b j_mayer
#endif
5203 a750fc0b j_mayer
#if defined (TODO)
5204 a750fc0b j_mayer
    /* PowerPC e300c2 core                                                   */
5205 a750fc0b j_mayer
    POWERPC_DEF("e300c2",      CPU_POWERPC_e300c2,      0xFFFFFFFF, e300),
5206 a750fc0b j_mayer
#endif
5207 a750fc0b j_mayer
#if defined (TODO)
5208 a750fc0b j_mayer
    /* PowerPC e300c3 core                                                   */
5209 a750fc0b j_mayer
    POWERPC_DEF("e300c3",      CPU_POWERPC_e300c3,      0xFFFFFFFF, e300),
5210 a750fc0b j_mayer
#endif
5211 a750fc0b j_mayer
    /* e500 family                                                           */
5212 a750fc0b j_mayer
#if defined (TODO)
5213 a750fc0b j_mayer
    /* PowerPC e500 core                                                     */
5214 a750fc0b j_mayer
    POWERPC_DEF("e500",        CPU_POWERPC_e500,        0xFFFFFFFF, e500),
5215 a750fc0b j_mayer
#endif
5216 a750fc0b j_mayer
#if defined (TODO)
5217 a750fc0b j_mayer
    /* PowerPC e500 v1.1 core                                                */
5218 a750fc0b j_mayer
    POWERPC_DEF("e500v1.1",    CPU_POWERPC_e500_v11,    0xFFFFFFFF, e500),
5219 a750fc0b j_mayer
#endif
5220 a750fc0b j_mayer
#if defined (TODO)
5221 a750fc0b j_mayer
    /* PowerPC e500 v1.2 core                                                */
5222 a750fc0b j_mayer
    POWERPC_DEF("e500v1.2",    CPU_POWERPC_e500_v12,    0xFFFFFFFF, e500),
5223 a750fc0b j_mayer
#endif
5224 a750fc0b j_mayer
#if defined (TODO)
5225 a750fc0b j_mayer
    /* PowerPC e500 v2.1 core                                                */
5226 a750fc0b j_mayer
    POWERPC_DEF("e500v2.1",    CPU_POWERPC_e500_v21,    0xFFFFFFFF, e500),
5227 a750fc0b j_mayer
#endif
5228 a750fc0b j_mayer
#if defined (TODO)
5229 a750fc0b j_mayer
    /* PowerPC e500 v2.2 core                                                */
5230 a750fc0b j_mayer
    POWERPC_DEF("e500v2.2",    CPU_POWERPC_e500_v22,    0xFFFFFFFF, e500),
5231 a750fc0b j_mayer
#endif
5232 a750fc0b j_mayer
    /* e600 family                                                           */
5233 a750fc0b j_mayer
#if defined (TODO)
5234 a750fc0b j_mayer
    /* PowerPC e600 core                                                     */
5235 a750fc0b j_mayer
    POWERPC_DEF("e600",        CPU_POWERPC_e600,        0xFFFFFFFF, e600),
5236 a750fc0b j_mayer
#endif
5237 a750fc0b j_mayer
    /* PowerPC MPC 5xx cores                                                 */
5238 a750fc0b j_mayer
#if defined (TODO)
5239 a750fc0b j_mayer
    /* PowerPC MPC 5xx                                                       */
5240 a750fc0b j_mayer
    POWERPC_DEF("mpc5xx",      CPU_POWERPC_5xx,         0xFFFFFFFF, 5xx),
5241 a750fc0b j_mayer
#endif
5242 a750fc0b j_mayer
    /* PowerPC MPC 8xx cores                                                 */
5243 a750fc0b j_mayer
#if defined (TODO)
5244 a750fc0b j_mayer
    /* PowerPC MPC 8xx                                                       */
5245 a750fc0b j_mayer
    POWERPC_DEF("mpc8xx",      CPU_POWERPC_8xx,         0xFFFFFFFF, 8xx),
5246 a750fc0b j_mayer
#endif
5247 a750fc0b j_mayer
    /* PowerPC MPC 8xxx cores                                                */
5248 a750fc0b j_mayer
#if defined (TODO)
5249 a750fc0b j_mayer
    /* PowerPC MPC 82xx HIP3                                                 */
5250 a750fc0b j_mayer
    POWERPC_DEF("mpc82xxhip3", CPU_POWERPC_82xx_HIP3,   0xFFFFFFFF, 82xx),
5251 a750fc0b j_mayer
#endif
5252 a750fc0b j_mayer
#if defined (TODO)
5253 a750fc0b j_mayer
    /* PowerPC MPC 82xx HIP4                                                 */
5254 a750fc0b j_mayer
    POWERPC_DEF("mpc82xxhip4", CPU_POWERPC_82xx_HIP4,   0xFFFFFFFF, 82xx),
5255 a750fc0b j_mayer
#endif
5256 a750fc0b j_mayer
#if defined (TODO)
5257 a750fc0b j_mayer
    /* PowerPC MPC 827x                                                      */
5258 a750fc0b j_mayer
    POWERPC_DEF("mpc827x",     CPU_POWERPC_827x,        0xFFFFFFFF, 827x),
5259 a750fc0b j_mayer
#endif
5260 a750fc0b j_mayer
5261 a750fc0b j_mayer
    /* 32 bits "classic" PowerPC                                             */
5262 a750fc0b j_mayer
    /* PowerPC 6xx family                                                    */
5263 a750fc0b j_mayer
    /* PowerPC 601                                                           */
5264 a750fc0b j_mayer
    POWERPC_DEF("601",         CPU_POWERPC_601,         0xFFFFFFFF, 601),
5265 a750fc0b j_mayer
    /* PowerPC 601v2                                                         */
5266 a750fc0b j_mayer
    POWERPC_DEF("601a",        CPU_POWERPC_601a,        0xFFFFFFFF, 601),
5267 a750fc0b j_mayer
    /* PowerPC 602                                                           */
5268 a750fc0b j_mayer
    POWERPC_DEF("602",         CPU_POWERPC_602,         0xFFFFFFFF, 602),
5269 a750fc0b j_mayer
    /* PowerPC 603                                                           */
5270 a750fc0b j_mayer
    POWERPC_DEF("603",         CPU_POWERPC_603,         0xFFFFFFFF, 603),
5271 a750fc0b j_mayer
    /* Code name for PowerPC 603                                             */
5272 a750fc0b j_mayer
    POWERPC_DEF("Vanilla",     CPU_POWERPC_603,         0xFFFFFFFF, 603),
5273 a750fc0b j_mayer
    /* PowerPC 603e                                                          */
5274 a750fc0b j_mayer
    POWERPC_DEF("603e",        CPU_POWERPC_603E,        0xFFFFFFFF, 603E),
5275 a750fc0b j_mayer
    /* Code name for PowerPC 603e                                            */
5276 a750fc0b j_mayer
    POWERPC_DEF("Stretch",     CPU_POWERPC_603E,        0xFFFFFFFF, 603E),
5277 a750fc0b j_mayer
    /* PowerPC 603e v1.1                                                     */
5278 a750fc0b j_mayer
    POWERPC_DEF("603e1.1",     CPU_POWERPC_603E_v11,    0xFFFFFFFF, 603E),
5279 a750fc0b j_mayer
    /* PowerPC 603e v1.2                                                     */
5280 a750fc0b j_mayer
    POWERPC_DEF("603e1.2",     CPU_POWERPC_603E_v12,    0xFFFFFFFF, 603E),
5281 a750fc0b j_mayer
    /* PowerPC 603e v1.3                                                     */
5282 a750fc0b j_mayer
    POWERPC_DEF("603e1.3",     CPU_POWERPC_603E_v13,    0xFFFFFFFF, 603E),
5283 a750fc0b j_mayer
    /* PowerPC 603e v1.4                                                     */
5284 a750fc0b j_mayer
    POWERPC_DEF("603e1.4",     CPU_POWERPC_603E_v14,    0xFFFFFFFF, 603E),
5285 a750fc0b j_mayer
    /* PowerPC 603e v2.2                                                     */
5286 a750fc0b j_mayer
    POWERPC_DEF("603e2.2",     CPU_POWERPC_603E_v22,    0xFFFFFFFF, 603E),
5287 a750fc0b j_mayer
    /* PowerPC 603e v3                                                       */
5288 a750fc0b j_mayer
    POWERPC_DEF("603e3",       CPU_POWERPC_603E_v3,     0xFFFFFFFF, 603E),
5289 a750fc0b j_mayer
    /* PowerPC 603e v4                                                       */
5290 a750fc0b j_mayer
    POWERPC_DEF("603e4",       CPU_POWERPC_603E_v4,     0xFFFFFFFF, 603E),
5291 a750fc0b j_mayer
    /* PowerPC 603e v4.1                                                     */
5292 a750fc0b j_mayer
    POWERPC_DEF("603e4.1",     CPU_POWERPC_603E_v41,    0xFFFFFFFF, 603E),
5293 a750fc0b j_mayer
    /* PowerPC 603e                                                          */
5294 a750fc0b j_mayer
    POWERPC_DEF("603e7",       CPU_POWERPC_603E7,       0xFFFFFFFF, 603E),
5295 a750fc0b j_mayer
    /* PowerPC 603e7t                                                        */
5296 a750fc0b j_mayer
    POWERPC_DEF("603e7t",      CPU_POWERPC_603E7t,      0xFFFFFFFF, 603E),
5297 a750fc0b j_mayer
    /* PowerPC 603e7v                                                        */
5298 a750fc0b j_mayer
    POWERPC_DEF("603e7v",      CPU_POWERPC_603E7v,      0xFFFFFFFF, 603E),
5299 a750fc0b j_mayer
    /* Code name for PowerPC 603ev                                           */
5300 a750fc0b j_mayer
    POWERPC_DEF("Vaillant",    CPU_POWERPC_603E7v,      0xFFFFFFFF, 603E),
5301 a750fc0b j_mayer
    /* PowerPC 603e7v1                                                       */
5302 a750fc0b j_mayer
    POWERPC_DEF("603e7v1",     CPU_POWERPC_603E7v1,     0xFFFFFFFF, 603E),
5303 a750fc0b j_mayer
    /* PowerPC 603e7v2                                                       */
5304 a750fc0b j_mayer
    POWERPC_DEF("603e7v2",     CPU_POWERPC_603E7v2,     0xFFFFFFFF, 603E),
5305 a750fc0b j_mayer
    /* PowerPC 603p                                                          */
5306 a750fc0b j_mayer
    /* to be checked */
5307 a750fc0b j_mayer
    POWERPC_DEF("603p",        CPU_POWERPC_603P,        0xFFFFFFFF, 603),
5308 a750fc0b j_mayer
    /* PowerPC 603r                                                          */
5309 a750fc0b j_mayer
    POWERPC_DEF("603r",        CPU_POWERPC_603R,        0xFFFFFFFF, 603E),
5310 a750fc0b j_mayer
    /* Code name for PowerPC 603r                                            */
5311 a750fc0b j_mayer
    POWERPC_DEF("Goldeneye",   CPU_POWERPC_603R,        0xFFFFFFFF, 603E),
5312 a750fc0b j_mayer
    /* PowerPC G2 core                                                       */
5313 a750fc0b j_mayer
    POWERPC_DEF("G2",          CPU_POWERPC_G2,          0xFFFFFFFF, G2),
5314 a750fc0b j_mayer
    /* PowerPC G2 H4                                                         */
5315 a750fc0b j_mayer
    POWERPC_DEF("G2H4",        CPU_POWERPC_G2H4,        0xFFFFFFFF, G2),
5316 a750fc0b j_mayer
    /* PowerPC G2 GP                                                         */
5317 a750fc0b j_mayer
    POWERPC_DEF("G2GP",        CPU_POWERPC_G2gp,        0xFFFFFFFF, G2),
5318 a750fc0b j_mayer
    /* PowerPC G2 LS                                                         */
5319 a750fc0b j_mayer
    POWERPC_DEF("G2LS",        CPU_POWERPC_G2ls,        0xFFFFFFFF, G2),
5320 a750fc0b j_mayer
    /* PowerPC G2LE                                                          */
5321 a750fc0b j_mayer
    /* Same as G2, with little-endian mode support                           */
5322 a750fc0b j_mayer
    POWERPC_DEF("G2le",        CPU_POWERPC_G2LE,        0xFFFFFFFF, G2LE),
5323 a750fc0b j_mayer
    /* PowerPC G2LE GP                                                       */
5324 a750fc0b j_mayer
    POWERPC_DEF("G2leGP",      CPU_POWERPC_G2LEgp,      0xFFFFFFFF, G2LE),
5325 a750fc0b j_mayer
    /* PowerPC G2LE LS                                                       */
5326 a750fc0b j_mayer
    POWERPC_DEF("G2leLS",      CPU_POWERPC_G2LEls,      0xFFFFFFFF, G2LE),
5327 a750fc0b j_mayer
    /* PowerPC 604                                                           */
5328 a750fc0b j_mayer
    POWERPC_DEF("604",         CPU_POWERPC_604,         0xFFFFFFFF, 604),
5329 a750fc0b j_mayer
    /* PowerPC 604e                                                          */
5330 a750fc0b j_mayer
    POWERPC_DEF("604e",        CPU_POWERPC_604E,        0xFFFFFFFF, 604),
5331 a750fc0b j_mayer
    /* PowerPC 604e v1.0                                                     */
5332 a750fc0b j_mayer
    POWERPC_DEF("604e1.0",     CPU_POWERPC_604E_v10,    0xFFFFFFFF, 604),
5333 a750fc0b j_mayer
    /* PowerPC 604e v2.2                                                     */
5334 a750fc0b j_mayer
    POWERPC_DEF("604e2.2",     CPU_POWERPC_604E_v22,    0xFFFFFFFF, 604),
5335 a750fc0b j_mayer
    /* PowerPC 604e v2.4                                                     */
5336 a750fc0b j_mayer
    POWERPC_DEF("604e2.4",     CPU_POWERPC_604E_v24,    0xFFFFFFFF, 604),
5337 a750fc0b j_mayer
    /* PowerPC 604r                                                          */
5338 a750fc0b j_mayer
    POWERPC_DEF("604r",        CPU_POWERPC_604R,        0xFFFFFFFF, 604),
5339 a750fc0b j_mayer
#if defined(TODO)
5340 a750fc0b j_mayer
    /* PowerPC 604ev                                                         */
5341 a750fc0b j_mayer
    POWERPC_DEF("604ev",       CPU_POWERPC_604EV,       0xFFFFFFFF, 604),
5342 a750fc0b j_mayer
#endif
5343 a750fc0b j_mayer
    /* PowerPC 7xx family                                                    */
5344 a750fc0b j_mayer
    /* Generic PowerPC 740 (G3)                                              */
5345 a750fc0b j_mayer
    POWERPC_DEF("740",         CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
5346 a750fc0b j_mayer
    /* Generic PowerPC 750 (G3)                                              */
5347 a750fc0b j_mayer
    POWERPC_DEF("750",         CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
5348 a750fc0b j_mayer
    /* Code name for generic PowerPC 740/750 (G3)                            */
5349 a750fc0b j_mayer
    POWERPC_DEF("Arthur",      CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
5350 a750fc0b j_mayer
    /* PowerPC 740/750 is also known as G3                                   */
5351 a750fc0b j_mayer
    POWERPC_DEF("G3",          CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
5352 a750fc0b j_mayer
    /* PowerPC 740 v2.0 (G3)                                                 */
5353 a750fc0b j_mayer
    POWERPC_DEF("740v2.0",     CPU_POWERPC_7x0_v20,     0xFFFFFFFF, 7x0),
5354 a750fc0b j_mayer
    /* PowerPC 750 v2.0 (G3)                                                 */
5355 a750fc0b j_mayer
    POWERPC_DEF("750v2.0",     CPU_POWERPC_7x0_v20,     0xFFFFFFFF, 7x0),
5356 a750fc0b j_mayer
    /* PowerPC 740 v2.1 (G3)                                                 */
5357 a750fc0b j_mayer
    POWERPC_DEF("740v2.1",     CPU_POWERPC_7x0_v21,     0xFFFFFFFF, 7x0),
5358 a750fc0b j_mayer
    /* PowerPC 750 v2.1 (G3)                                                 */
5359 a750fc0b j_mayer
    POWERPC_DEF("750v2.1",     CPU_POWERPC_7x0_v21,     0xFFFFFFFF, 7x0),
5360 a750fc0b j_mayer
    /* PowerPC 740 v2.2 (G3)                                                 */
5361 a750fc0b j_mayer
    POWERPC_DEF("740v2.2",     CPU_POWERPC_7x0_v22,     0xFFFFFFFF, 7x0),
5362 a750fc0b j_mayer
    /* PowerPC 750 v2.2 (G3)                                                 */
5363 a750fc0b j_mayer
    POWERPC_DEF("750v2.2",     CPU_POWERPC_7x0_v22,     0xFFFFFFFF, 7x0),
5364 a750fc0b j_mayer
    /* PowerPC 740 v3.0 (G3)                                                 */
5365 a750fc0b j_mayer
    POWERPC_DEF("740v3.0",     CPU_POWERPC_7x0_v30,     0xFFFFFFFF, 7x0),
5366 a750fc0b j_mayer
    /* PowerPC 750 v3.0 (G3)                                                 */
5367 a750fc0b j_mayer
    POWERPC_DEF("750v3.0",     CPU_POWERPC_7x0_v30,     0xFFFFFFFF, 7x0),
5368 a750fc0b j_mayer
    /* PowerPC 740 v3.1 (G3)                                                 */
5369 a750fc0b j_mayer
    POWERPC_DEF("740v3.1",     CPU_POWERPC_7x0_v31,     0xFFFFFFFF, 7x0),
5370 a750fc0b j_mayer
    /* PowerPC 750 v3.1 (G3)                                                 */
5371 a750fc0b j_mayer
    POWERPC_DEF("750v3.1",     CPU_POWERPC_7x0_v31,     0xFFFFFFFF, 7x0),
5372 a750fc0b j_mayer
    /* PowerPC 740E (G3)                                                     */
5373 a750fc0b j_mayer
    POWERPC_DEF("740e",        CPU_POWERPC_740E,        0xFFFFFFFF, 7x0),
5374 a750fc0b j_mayer
    /* PowerPC 740P (G3)                                                     */
5375 a750fc0b j_mayer
    POWERPC_DEF("740p",        CPU_POWERPC_7x0P,        0xFFFFFFFF, 7x0),
5376 a750fc0b j_mayer
    /* PowerPC 750P (G3)                                                     */
5377 a750fc0b j_mayer
    POWERPC_DEF("750p",        CPU_POWERPC_7x0P,        0xFFFFFFFF, 7x0),
5378 a750fc0b j_mayer
    /* Code name for PowerPC 740P/750P (G3)                                  */
5379 a750fc0b j_mayer
    POWERPC_DEF("Conan/Doyle", CPU_POWERPC_7x0P,        0xFFFFFFFF, 7x0),
5380 a750fc0b j_mayer
    /* PowerPC 750CL (G3 embedded)                                           */
5381 a750fc0b j_mayer
    POWERPC_DEF("750cl",       CPU_POWERPC_750CL,       0xFFFFFFFF, 7x0),
5382 a750fc0b j_mayer
    /* PowerPC 750CX (G3 embedded)                                           */
5383 a750fc0b j_mayer
    POWERPC_DEF("750cx",       CPU_POWERPC_750CX,       0xFFFFFFFF, 7x0),
5384 a750fc0b j_mayer
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
5385 a750fc0b j_mayer
    POWERPC_DEF("750cx2.1",    CPU_POWERPC_750CX_v21,   0xFFFFFFFF, 7x0),
5386 a750fc0b j_mayer
    /* PowerPC 750CX v2.2 (G3 embedded)                                      */
5387 a750fc0b j_mayer
    POWERPC_DEF("750cx2.2",    CPU_POWERPC_750CX_v22,   0xFFFFFFFF, 7x0),
5388 a750fc0b j_mayer
    /* PowerPC 750CXe (G3 embedded)                                          */
5389 a750fc0b j_mayer
    POWERPC_DEF("750cxe",      CPU_POWERPC_750CXE,      0xFFFFFFFF, 7x0),
5390 a750fc0b j_mayer
    /* PowerPC 750CXe v2.1 (G3 embedded)                                     */
5391 a750fc0b j_mayer
    POWERPC_DEF("750cxe21",    CPU_POWERPC_750CXE_v21,  0xFFFFFFFF, 7x0),
5392 a750fc0b j_mayer
    /* PowerPC 750CXe v2.2 (G3 embedded)                                     */
5393 a750fc0b j_mayer
    POWERPC_DEF("750cxe22",    CPU_POWERPC_750CXE_v22,  0xFFFFFFFF, 7x0),
5394 a750fc0b j_mayer
    /* PowerPC 750CXe v2.3 (G3 embedded)                                     */
5395 a750fc0b j_mayer
    POWERPC_DEF("750cxe23",    CPU_POWERPC_750CXE_v23,  0xFFFFFFFF, 7x0),
5396 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4 (G3 embedded)                                     */
5397 a750fc0b j_mayer
    POWERPC_DEF("750cxe24",    CPU_POWERPC_750CXE_v24,  0xFFFFFFFF, 7x0),
5398 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4b (G3 embedded)                                    */
5399 a750fc0b j_mayer
    POWERPC_DEF("750cxe24b",   CPU_POWERPC_750CXE_v24b, 0xFFFFFFFF, 7x0),
5400 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1 (G3 embedded)                                     */
5401 a750fc0b j_mayer
    POWERPC_DEF("750cxe31",    CPU_POWERPC_750CXE_v31,  0xFFFFFFFF, 7x0),
5402 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1b (G3 embedded)                                    */
5403 a750fc0b j_mayer
    POWERPC_DEF("750cxe3.1b",  CPU_POWERPC_750CXE_v31b, 0xFFFFFFFF, 7x0),
5404 a750fc0b j_mayer
    /* PowerPC 750CXr (G3 embedded)                                          */
5405 a750fc0b j_mayer
    POWERPC_DEF("750cxr",      CPU_POWERPC_750CXR,      0xFFFFFFFF, 7x0),
5406 a750fc0b j_mayer
    /* PowerPC 750E (G3)                                                     */
5407 a750fc0b j_mayer
    POWERPC_DEF("750e",        CPU_POWERPC_750E,        0xFFFFFFFF, 7x0),
5408 a750fc0b j_mayer
    /* PowerPC 750FL (G3 embedded)                                           */
5409 d12f4c38 j_mayer
    POWERPC_DEF("750fl",       CPU_POWERPC_750FL,       0xFFFFFFFF, 750fx),
5410 a750fc0b j_mayer
    /* PowerPC 750FX (G3 embedded)                                           */
5411 a750fc0b j_mayer
    POWERPC_DEF("750fx",       CPU_POWERPC_750FX,       0xFFFFFFFF, 750fx),
5412 a750fc0b j_mayer
    /* PowerPC 750FX v1.0 (G3 embedded)                                      */
5413 a750fc0b j_mayer
    POWERPC_DEF("750fx1.0",    CPU_POWERPC_750FX_v10,   0xFFFFFFFF, 750fx),
5414 a750fc0b j_mayer
    /* PowerPC 750FX v2.0 (G3 embedded)                                      */
5415 a750fc0b j_mayer
    POWERPC_DEF("750fx2.0",    CPU_POWERPC_750FX_v20,   0xFFFFFFFF, 750fx),
5416 a750fc0b j_mayer
    /* PowerPC 750FX v2.1 (G3 embedded)                                      */
5417 a750fc0b j_mayer
    POWERPC_DEF("750fx2.1",    CPU_POWERPC_750FX_v21,   0xFFFFFFFF, 750fx),
5418 a750fc0b j_mayer
    /* PowerPC 750FX v2.2 (G3 embedded)                                      */
5419 a750fc0b j_mayer
    POWERPC_DEF("750fx2.2",    CPU_POWERPC_750FX_v22,   0xFFFFFFFF, 750fx),
5420 a750fc0b j_mayer
    /* PowerPC 750FX v2.3 (G3 embedded)                                      */
5421 a750fc0b j_mayer
    POWERPC_DEF("750fx2.3",    CPU_POWERPC_750FX_v23,   0xFFFFFFFF, 750fx),
5422 a750fc0b j_mayer
    /* PowerPC 750GL (G3 embedded)                                           */
5423 d12f4c38 j_mayer
    POWERPC_DEF("750gl",       CPU_POWERPC_750GL,       0xFFFFFFFF, 750fx),
5424 a750fc0b j_mayer
    /* PowerPC 750GX (G3 embedded)                                           */
5425 a750fc0b j_mayer
    POWERPC_DEF("750gx",       CPU_POWERPC_750GX,       0xFFFFFFFF, 750fx),
5426 a750fc0b j_mayer
    /* PowerPC 750GX v1.0 (G3 embedded)                                      */
5427 a750fc0b j_mayer
    POWERPC_DEF("750gx1.0",    CPU_POWERPC_750GX_v10,   0xFFFFFFFF, 750fx),
5428 a750fc0b j_mayer
    /* PowerPC 750GX v1.1 (G3 embedded)                                      */
5429 a750fc0b j_mayer
    POWERPC_DEF("750gx1.1",    CPU_POWERPC_750GX_v11,   0xFFFFFFFF, 750fx),
5430 a750fc0b j_mayer
    /* PowerPC 750GX v1.2 (G3 embedded)                                      */
5431 a750fc0b j_mayer
    POWERPC_DEF("750gx1.2",    CPU_POWERPC_750GX_v12,   0xFFFFFFFF, 750fx),
5432 a750fc0b j_mayer
    /* PowerPC 750L (G3 embedded)                                            */
5433 a750fc0b j_mayer
    POWERPC_DEF("750l",        CPU_POWERPC_750L,        0xFFFFFFFF, 7x0),
5434 a750fc0b j_mayer
    /* Code name for PowerPC 750L (G3 embedded)                              */
5435 a750fc0b j_mayer
    POWERPC_DEF("LoneStar",    CPU_POWERPC_750L,        0xFFFFFFFF, 7x0),
5436 a750fc0b j_mayer
    /* PowerPC 750L v2.2 (G3 embedded)                                       */
5437 a750fc0b j_mayer
    POWERPC_DEF("750l2.2",     CPU_POWERPC_750L_v22,    0xFFFFFFFF, 7x0),
5438 a750fc0b j_mayer
    /* PowerPC 750L v3.0 (G3 embedded)                                       */
5439 a750fc0b j_mayer
    POWERPC_DEF("750l3.0",     CPU_POWERPC_750L_v30,    0xFFFFFFFF, 7x0),
5440 a750fc0b j_mayer
    /* PowerPC 750L v3.2 (G3 embedded)                                       */
5441 a750fc0b j_mayer
    POWERPC_DEF("750l3.2",     CPU_POWERPC_750L_v32,    0xFFFFFFFF, 7x0),
5442 a750fc0b j_mayer
    /* Generic PowerPC 745                                                   */
5443 a750fc0b j_mayer
    POWERPC_DEF("745",         CPU_POWERPC_7x5,         0xFFFFFFFF, 7x5),
5444 a750fc0b j_mayer
    /* Generic PowerPC 755                                                   */
5445 a750fc0b j_mayer
    POWERPC_DEF("755",         CPU_POWERPC_7x5,         0xFFFFFFFF, 7x5),
5446 a750fc0b j_mayer
    /* Code name for PowerPC 745/755                                         */
5447 a750fc0b j_mayer
    POWERPC_DEF("Goldfinger",  CPU_POWERPC_7x5,         0xFFFFFFFF, 7x5),
5448 a750fc0b j_mayer
    /* PowerPC 745 v1.0                                                      */
5449 a750fc0b j_mayer
    POWERPC_DEF("745v1.0",     CPU_POWERPC_7x5_v10,     0xFFFFFFFF, 7x5),
5450 a750fc0b j_mayer
    /* PowerPC 755 v1.0                                                      */
5451 a750fc0b j_mayer
    POWERPC_DEF("755v1.0",     CPU_POWERPC_7x5_v10,     0xFFFFFFFF, 7x5),
5452 a750fc0b j_mayer
    /* PowerPC 745 v1.1                                                      */
5453 a750fc0b j_mayer
    POWERPC_DEF("745v1.1",     CPU_POWERPC_7x5_v11,     0xFFFFFFFF, 7x5),
5454 a750fc0b j_mayer
    /* PowerPC 755 v1.1                                                      */
5455 a750fc0b j_mayer
    POWERPC_DEF("755v1.1",     CPU_POWERPC_7x5_v11,     0xFFFFFFFF, 7x5),
5456 a750fc0b j_mayer
    /* PowerPC 745 v2.0                                                      */
5457 a750fc0b j_mayer
    POWERPC_DEF("745v2.0",     CPU_POWERPC_7x5_v20,     0xFFFFFFFF, 7x5),
5458 a750fc0b j_mayer
    /* PowerPC 755 v2.0                                                      */
5459 a750fc0b j_mayer
    POWERPC_DEF("755v2.0",     CPU_POWERPC_7x5_v20,     0xFFFFFFFF, 7x5),
5460 a750fc0b j_mayer
    /* PowerPC 745 v2.1                                                      */
5461 a750fc0b j_mayer
    POWERPC_DEF("745v2.1",     CPU_POWERPC_7x5_v21,     0xFFFFFFFF, 7x5),
5462 a750fc0b j_mayer
    /* PowerPC 755 v2.1                                                      */
5463 a750fc0b j_mayer
    POWERPC_DEF("755v2.1",     CPU_POWERPC_7x5_v21,     0xFFFFFFFF, 7x5),
5464 a750fc0b j_mayer
    /* PowerPC 745 v2.2                                                      */
5465 a750fc0b j_mayer
    POWERPC_DEF("745v2.2",     CPU_POWERPC_7x5_v22,     0xFFFFFFFF, 7x5),
5466 a750fc0b j_mayer
    /* PowerPC 755 v2.2                                                      */
5467 a750fc0b j_mayer
    POWERPC_DEF("755v2.2",     CPU_POWERPC_7x5_v22,     0xFFFFFFFF, 7x5),
5468 a750fc0b j_mayer
    /* PowerPC 745 v2.3                                                      */
5469 a750fc0b j_mayer
    POWERPC_DEF("745v2.3",     CPU_POWERPC_7x5_v23,     0xFFFFFFFF, 7x5),
5470 a750fc0b j_mayer
    /* PowerPC 755 v2.3                                                      */
5471 a750fc0b j_mayer
    POWERPC_DEF("755v2.3",     CPU_POWERPC_7x5_v23,     0xFFFFFFFF, 7x5),
5472 a750fc0b j_mayer
    /* PowerPC 745 v2.4                                                      */
5473 a750fc0b j_mayer
    POWERPC_DEF("745v2.4",     CPU_POWERPC_7x5_v24,     0xFFFFFFFF, 7x5),
5474 a750fc0b j_mayer
    /* PowerPC 755 v2.4                                                      */
5475 a750fc0b j_mayer
    POWERPC_DEF("755v2.4",     CPU_POWERPC_7x5_v24,     0xFFFFFFFF, 7x5),
5476 a750fc0b j_mayer
    /* PowerPC 745 v2.5                                                      */
5477 a750fc0b j_mayer
    POWERPC_DEF("745v2.5",     CPU_POWERPC_7x5_v25,     0xFFFFFFFF, 7x5),
5478 a750fc0b j_mayer
    /* PowerPC 755 v2.5                                                      */
5479 a750fc0b j_mayer
    POWERPC_DEF("755v2.5",     CPU_POWERPC_7x5_v25,     0xFFFFFFFF, 7x5),
5480 a750fc0b j_mayer
    /* PowerPC 745 v2.6                                                      */
5481 a750fc0b j_mayer
    POWERPC_DEF("745v2.6",     CPU_POWERPC_7x5_v26,     0xFFFFFFFF, 7x5),
5482 a750fc0b j_mayer
    /* PowerPC 755 v2.6                                                      */
5483 a750fc0b j_mayer
    POWERPC_DEF("755v2.6",     CPU_POWERPC_7x5_v26,     0xFFFFFFFF, 7x5),
5484 a750fc0b j_mayer
    /* PowerPC 745 v2.7                                                      */
5485 a750fc0b j_mayer
    POWERPC_DEF("745v2.7",     CPU_POWERPC_7x5_v27,     0xFFFFFFFF, 7x5),
5486 a750fc0b j_mayer
    /* PowerPC 755 v2.7                                                      */
5487 a750fc0b j_mayer
    POWERPC_DEF("755v2.7",     CPU_POWERPC_7x5_v27,     0xFFFFFFFF, 7x5),
5488 a750fc0b j_mayer
    /* PowerPC 745 v2.8                                                      */
5489 a750fc0b j_mayer
    POWERPC_DEF("745v2.8",     CPU_POWERPC_7x5_v28,     0xFFFFFFFF, 7x5),
5490 a750fc0b j_mayer
    /* PowerPC 755 v2.8                                                      */
5491 a750fc0b j_mayer
    POWERPC_DEF("755v2.8",     CPU_POWERPC_7x5_v28,     0xFFFFFFFF, 7x5),
5492 a750fc0b j_mayer
#if defined (TODO)
5493 a750fc0b j_mayer
    /* PowerPC 745P (G3)                                                     */
5494 a750fc0b j_mayer
    POWERPC_DEF("745p",        CPU_POWERPC_7x5P,        0xFFFFFFFF, 7x5),
5495 a750fc0b j_mayer
    /* PowerPC 755P (G3)                                                     */
5496 a750fc0b j_mayer
    POWERPC_DEF("755p",        CPU_POWERPC_7x5P,        0xFFFFFFFF, 7x5),
5497 a750fc0b j_mayer
#endif
5498 a750fc0b j_mayer
    /* PowerPC 74xx family                                                   */
5499 a750fc0b j_mayer
    /* PowerPC 7400 (G4)                                                     */
5500 a750fc0b j_mayer
    POWERPC_DEF("7400",        CPU_POWERPC_7400,        0xFFFFFFFF, 7400),
5501 a750fc0b j_mayer
    /* Code name for PowerPC 7400                                            */
5502 a750fc0b j_mayer
    POWERPC_DEF("Max",         CPU_POWERPC_7400,        0xFFFFFFFF, 7400),
5503 a750fc0b j_mayer
    /* PowerPC 74xx is also well known as G4                                 */
5504 a750fc0b j_mayer
    POWERPC_DEF("G4",          CPU_POWERPC_7400,        0xFFFFFFFF, 7400),
5505 a750fc0b j_mayer
    /* PowerPC 7400 v1.0 (G4)                                                */
5506 a750fc0b j_mayer
    POWERPC_DEF("7400v1.0",    CPU_POWERPC_7400_v10,    0xFFFFFFFF, 7400),
5507 a750fc0b j_mayer
    /* PowerPC 7400 v1.1 (G4)                                                */
5508 a750fc0b j_mayer
    POWERPC_DEF("7400v1.1",    CPU_POWERPC_7400_v11,    0xFFFFFFFF, 7400),
5509 a750fc0b j_mayer
    /* PowerPC 7400 v2.0 (G4)                                                */
5510 a750fc0b j_mayer
    POWERPC_DEF("7400v2.0",    CPU_POWERPC_7400_v20,    0xFFFFFFFF, 7400),
5511 a750fc0b j_mayer
    /* PowerPC 7400 v2.2 (G4)                                                */
5512 a750fc0b j_mayer
    POWERPC_DEF("7400v2.2",    CPU_POWERPC_7400_v22,    0xFFFFFFFF, 7400),
5513 a750fc0b j_mayer
    /* PowerPC 7400 v2.6 (G4)                                                */
5514 a750fc0b j_mayer
    POWERPC_DEF("7400v2.6",    CPU_POWERPC_7400_v26,    0xFFFFFFFF, 7400),
5515 a750fc0b j_mayer
    /* PowerPC 7400 v2.7 (G4)                                                */
5516 a750fc0b j_mayer
    POWERPC_DEF("7400v2.7",    CPU_POWERPC_7400_v27,    0xFFFFFFFF, 7400),
5517 a750fc0b j_mayer
    /* PowerPC 7400 v2.8 (G4)                                                */
5518 a750fc0b j_mayer
    POWERPC_DEF("7400v2.8",    CPU_POWERPC_7400_v28,    0xFFFFFFFF, 7400),
5519 a750fc0b j_mayer
    /* PowerPC 7400 v2.9 (G4)                                                */
5520 a750fc0b j_mayer
    POWERPC_DEF("7400v2.9",    CPU_POWERPC_7400_v29,    0xFFFFFFFF, 7400),
5521 a750fc0b j_mayer
    /* PowerPC 7410 (G4)                                                     */
5522 a750fc0b j_mayer
    POWERPC_DEF("7410",        CPU_POWERPC_7410,        0xFFFFFFFF, 7410),
5523 a750fc0b j_mayer
    /* Code name for PowerPC 7410                                            */
5524 a750fc0b j_mayer
    POWERPC_DEF("Nitro",       CPU_POWERPC_7410,        0xFFFFFFFF, 7410),
5525 a750fc0b j_mayer
    /* PowerPC 7410 v1.0 (G4)                                                */
5526 a750fc0b j_mayer
    POWERPC_DEF("7410v1.0",    CPU_POWERPC_7410_v10,    0xFFFFFFFF, 7410),
5527 a750fc0b j_mayer
    /* PowerPC 7410 v1.1 (G4)                                                */
5528 a750fc0b j_mayer
    POWERPC_DEF("7410v1.1",    CPU_POWERPC_7410_v11,    0xFFFFFFFF, 7410),
5529 a750fc0b j_mayer
    /* PowerPC 7410 v1.2 (G4)                                                */
5530 a750fc0b j_mayer
    POWERPC_DEF("7410v1.2",    CPU_POWERPC_7410_v12,    0xFFFFFFFF, 7410),
5531 a750fc0b j_mayer
    /* PowerPC 7410 v1.3 (G4)                                                */
5532 a750fc0b j_mayer
    POWERPC_DEF("7410v1.3",    CPU_POWERPC_7410_v13,    0xFFFFFFFF, 7410),
5533 a750fc0b j_mayer
    /* PowerPC 7410 v1.4 (G4)                                                */
5534 a750fc0b j_mayer
    POWERPC_DEF("7410v1.4",    CPU_POWERPC_7410_v14,    0xFFFFFFFF, 7410),
5535 a750fc0b j_mayer
    /* PowerPC 7448 (G4)                                                     */
5536 a750fc0b j_mayer
    POWERPC_DEF("7448",        CPU_POWERPC_7448,        0xFFFFFFFF, 7400),
5537 a750fc0b j_mayer
    /* PowerPC 7448 v1.0 (G4)                                                */
5538 a750fc0b j_mayer
    POWERPC_DEF("7448v1.0",    CPU_POWERPC_7448_v10,    0xFFFFFFFF, 7400),
5539 a750fc0b j_mayer
    /* PowerPC 7448 v1.1 (G4)                                                */
5540 a750fc0b j_mayer
    POWERPC_DEF("7448v1.1",    CPU_POWERPC_7448_v11,    0xFFFFFFFF, 7400),
5541 a750fc0b j_mayer
    /* PowerPC 7448 v2.0 (G4)                                                */
5542 a750fc0b j_mayer
    POWERPC_DEF("7448v2.0",    CPU_POWERPC_7448_v20,    0xFFFFFFFF, 7400),
5543 a750fc0b j_mayer
    /* PowerPC 7448 v2.1 (G4)                                                */
5544 a750fc0b j_mayer
    POWERPC_DEF("7448v2.1",    CPU_POWERPC_7448_v21,    0xFFFFFFFF, 7400),
5545 a750fc0b j_mayer
    /* PowerPC 7450 (G4)                                                     */
5546 a750fc0b j_mayer
    POWERPC_DEF("7450",        CPU_POWERPC_7450,        0xFFFFFFFF, 7450),
5547 a750fc0b j_mayer
    /* Code name for PowerPC 7450                                            */
5548 a750fc0b j_mayer
    POWERPC_DEF("Vger",        CPU_POWERPC_7450,        0xFFFFFFFF, 7450),
5549 a750fc0b j_mayer
    /* PowerPC 7450 v1.0 (G4)                                                */
5550 a750fc0b j_mayer
    POWERPC_DEF("7450v1.0",    CPU_POWERPC_7450_v10,    0xFFFFFFFF, 7450),
5551 a750fc0b j_mayer
    /* PowerPC 7450 v1.1 (G4)                                                */
5552 a750fc0b j_mayer
    POWERPC_DEF("7450v1.1",    CPU_POWERPC_7450_v11,    0xFFFFFFFF, 7450),
5553 a750fc0b j_mayer
    /* PowerPC 7450 v1.2 (G4)                                                */
5554 a750fc0b j_mayer
    POWERPC_DEF("7450v1.2",    CPU_POWERPC_7450_v12,    0xFFFFFFFF, 7450),
5555 a750fc0b j_mayer
    /* PowerPC 7450 v2.0 (G4)                                                */
5556 a750fc0b j_mayer
    POWERPC_DEF("7450v2.0",    CPU_POWERPC_7450_v20,    0xFFFFFFFF, 7450),
5557 a750fc0b j_mayer
    /* PowerPC 7450 v2.1 (G4)                                                */
5558 a750fc0b j_mayer
    POWERPC_DEF("7450v2.1",    CPU_POWERPC_7450_v21,    0xFFFFFFFF, 7450),
5559 a750fc0b j_mayer
    /* PowerPC 7441 (G4)                                                     */
5560 a750fc0b j_mayer
    POWERPC_DEF("7441",        CPU_POWERPC_74x1,        0xFFFFFFFF, 7440),
5561 a750fc0b j_mayer
    /* PowerPC 7451 (G4)                                                     */
5562 a750fc0b j_mayer
    POWERPC_DEF("7451",        CPU_POWERPC_74x1,        0xFFFFFFFF, 7450),
5563 a750fc0b j_mayer
    /* PowerPC 7441g (G4)                                                    */
5564 a750fc0b j_mayer
    POWERPC_DEF("7441g",       CPU_POWERPC_74x1G,       0xFFFFFFFF, 7440),
5565 a750fc0b j_mayer
    /* PowerPC 7451g (G4)                                                    */
5566 a750fc0b j_mayer
    POWERPC_DEF("7451g",       CPU_POWERPC_74x1G,       0xFFFFFFFF, 7450),
5567 a750fc0b j_mayer
    /* PowerPC 7445 (G4)                                                     */
5568 a750fc0b j_mayer
    POWERPC_DEF("7445",        CPU_POWERPC_74x5,        0xFFFFFFFF, 7445),
5569 a750fc0b j_mayer
    /* PowerPC 7455 (G4)                                                     */
5570 a750fc0b j_mayer
    POWERPC_DEF("7455",        CPU_POWERPC_74x5,        0xFFFFFFFF, 7455),
5571 a750fc0b j_mayer
    /* Code name for PowerPC 7445/7455                                       */
5572 a750fc0b j_mayer
    POWERPC_DEF("Apollo6",     CPU_POWERPC_74x5,        0xFFFFFFFF, 7455),
5573 a750fc0b j_mayer
    /* PowerPC 7445 v1.0 (G4)                                                */
5574 a750fc0b j_mayer
    POWERPC_DEF("7445v1.0",    CPU_POWERPC_74x5_v10,    0xFFFFFFFF, 7445),
5575 a750fc0b j_mayer
    /* PowerPC 7455 v1.0 (G4)                                                */
5576 a750fc0b j_mayer
    POWERPC_DEF("7455v1.0",    CPU_POWERPC_74x5_v10,    0xFFFFFFFF, 7455),
5577 a750fc0b j_mayer
    /* PowerPC 7445 v2.1 (G4)                                                */
5578 a750fc0b j_mayer
    POWERPC_DEF("7445v2.1",    CPU_POWERPC_74x5_v21,    0xFFFFFFFF, 7445),
5579 a750fc0b j_mayer
    /* PowerPC 7455 v2.1 (G4)                                                */
5580 a750fc0b j_mayer
    POWERPC_DEF("7455v2.1",    CPU_POWERPC_74x5_v21,    0xFFFFFFFF, 7455),
5581 a750fc0b j_mayer
    /* PowerPC 7445 v3.2 (G4)                                                */
5582 a750fc0b j_mayer
    POWERPC_DEF("7445v3.2",    CPU_POWERPC_74x5_v32,    0xFFFFFFFF, 7445),
5583 a750fc0b j_mayer
    /* PowerPC 7455 v3.2 (G4)                                                */
5584 a750fc0b j_mayer
    POWERPC_DEF("7455v3.2",    CPU_POWERPC_74x5_v32,    0xFFFFFFFF, 7455),
5585 a750fc0b j_mayer
    /* PowerPC 7445 v3.3 (G4)                                                */
5586 a750fc0b j_mayer
    POWERPC_DEF("7445v3.3",    CPU_POWERPC_74x5_v33,    0xFFFFFFFF, 7445),
5587 a750fc0b j_mayer
    /* PowerPC 7455 v3.3 (G4)                                                */
5588 a750fc0b j_mayer
    POWERPC_DEF("7455v3.3",    CPU_POWERPC_74x5_v33,    0xFFFFFFFF, 7455),
5589 a750fc0b j_mayer
    /* PowerPC 7445 v3.4 (G4)                                                */
5590 a750fc0b j_mayer
    POWERPC_DEF("7445v3.4",    CPU_POWERPC_74x5_v34,    0xFFFFFFFF, 7445),
5591 a750fc0b j_mayer
    /* PowerPC 7455 v3.4 (G4)                                                */
5592 a750fc0b j_mayer
    POWERPC_DEF("7455v3.4",    CPU_POWERPC_74x5_v34,    0xFFFFFFFF, 7455),
5593 a750fc0b j_mayer
    /* PowerPC 7447 (G4)                                                     */
5594 a750fc0b j_mayer
    POWERPC_DEF("7447",        CPU_POWERPC_74x7,        0xFFFFFFFF, 7445),
5595 a750fc0b j_mayer
    /* PowerPC 7457 (G4)                                                     */
5596 a750fc0b j_mayer
    POWERPC_DEF("7457",        CPU_POWERPC_74x7,        0xFFFFFFFF, 7455),
5597 a750fc0b j_mayer
    /* Code name for PowerPC 7447/7457                                       */
5598 a750fc0b j_mayer
    POWERPC_DEF("Apollo7",     CPU_POWERPC_74x7,        0xFFFFFFFF, 7455),
5599 a750fc0b j_mayer
    /* PowerPC 7447 v1.0 (G4)                                                */
5600 a750fc0b j_mayer
    POWERPC_DEF("7447v1.0",    CPU_POWERPC_74x7_v10,    0xFFFFFFFF, 7445),
5601 a750fc0b j_mayer
    /* PowerPC 7457 v1.0 (G4)                                                */
5602 a750fc0b j_mayer
    POWERPC_DEF("7457v1.0",    CPU_POWERPC_74x7_v10,    0xFFFFFFFF, 7455),
5603 a750fc0b j_mayer
    /* Code name for PowerPC 7447A/7457A                                     */
5604 a750fc0b j_mayer
    POWERPC_DEF("Apollo7PM",   CPU_POWERPC_74x7_v10,    0xFFFFFFFF, 7455),
5605 a750fc0b j_mayer
    /* PowerPC 7447 v1.1 (G4)                                                */
5606 a750fc0b j_mayer
    POWERPC_DEF("7447v1.1",    CPU_POWERPC_74x7_v11,    0xFFFFFFFF, 7445),
5607 a750fc0b j_mayer
    /* PowerPC 7457 v1.1 (G4)                                                */
5608 a750fc0b j_mayer
    POWERPC_DEF("7457v1.1",    CPU_POWERPC_74x7_v11,    0xFFFFFFFF, 7455),
5609 a750fc0b j_mayer
    /* PowerPC 7447 v1.2 (G4)                                                */
5610 a750fc0b j_mayer
    POWERPC_DEF("7447v1.2",    CPU_POWERPC_74x7_v12,    0xFFFFFFFF, 7445),
5611 a750fc0b j_mayer
    /* PowerPC 7457 v1.2 (G4)                                                */
5612 a750fc0b j_mayer
    POWERPC_DEF("7457v1.2",    CPU_POWERPC_74x7_v12,    0xFFFFFFFF, 7455),
5613 a750fc0b j_mayer
    /* 64 bits PowerPC                                                       */
5614 a750fc0b j_mayer
#if defined (TARGET_PPC64)
5615 3fc6c082 bellard
#if defined (TODO)
5616 a750fc0b j_mayer
    /* PowerPC 620                                                           */
5617 a750fc0b j_mayer
    POWERPC_DEF("620",         CPU_POWERPC_620,         0xFFFFFFFF, 620),
5618 a750fc0b j_mayer
#endif
5619 3fc6c082 bellard
#if defined (TODO)
5620 a750fc0b j_mayer
    /* PowerPC 630 (POWER3)                                                  */
5621 a750fc0b j_mayer
    POWERPC_DEF("630",         CPU_POWERPC_630,         0xFFFFFFFF, 630),
5622 a750fc0b j_mayer
    POWERPC_DEF("POWER3",      CPU_POWERPC_630,         0xFFFFFFFF, 630),
5623 a750fc0b j_mayer
#endif
5624 3a607854 j_mayer
#if defined (TODO)
5625 a750fc0b j_mayer
    /* PowerPC 631 (Power 3+)                                                */
5626 a750fc0b j_mayer
    POWERPC_DEF("631",         CPU_POWERPC_631,         0xFFFFFFFF, 631),
5627 a750fc0b j_mayer
    POWERPC_DEF("POWER3+",     CPU_POWERPC_631,         0xFFFFFFFF, 631),
5628 3a607854 j_mayer
#endif
5629 3a607854 j_mayer
#if defined (TODO)
5630 a750fc0b j_mayer
    /* POWER4                                                                */
5631 a750fc0b j_mayer
    POWERPC_DEF("POWER4",      CPU_POWERPC_POWER4,      0xFFFFFFFF, POWER4),
5632 a750fc0b j_mayer
#endif
5633 3a607854 j_mayer
#if defined (TODO)
5634 a750fc0b j_mayer
    /* POWER4p                                                               */
5635 a750fc0b j_mayer
    POWERPC_DEF("POWER4+",     CPU_POWERPC_POWER4P,     0xFFFFFFFF, POWER4P),
5636 a750fc0b j_mayer
#endif
5637 3a607854 j_mayer
#if defined (TODO)
5638 a750fc0b j_mayer
    /* POWER5                                                                */
5639 a750fc0b j_mayer
    POWERPC_DEF("POWER5",      CPU_POWERPC_POWER5,      0xFFFFFFFF, POWER5),
5640 a750fc0b j_mayer
    /* POWER5GR                                                              */
5641 a750fc0b j_mayer
    POWERPC_DEF("POWER5gr",    CPU_POWERPC_POWER5GR,    0xFFFFFFFF, POWER5),
5642 2662a059 j_mayer
#endif
5643 2662a059 j_mayer
#if defined (TODO)
5644 a750fc0b j_mayer
    /* POWER5+                                                               */
5645 a750fc0b j_mayer
    POWERPC_DEF("POWER5+",     CPU_POWERPC_POWER5P,     0xFFFFFFFF, POWER5P),
5646 a750fc0b j_mayer
    /* POWER5GS                                                              */
5647 a750fc0b j_mayer
    POWERPC_DEF("POWER5gs",    CPU_POWERPC_POWER5GS,    0xFFFFFFFF, POWER5P),
5648 a750fc0b j_mayer
#endif
5649 2662a059 j_mayer
#if defined (TODO)
5650 a750fc0b j_mayer
    /* POWER6                                                                */
5651 a750fc0b j_mayer
    POWERPC_DEF("POWER6",      CPU_POWERPC_POWER6,      0xFFFFFFFF, POWER6),
5652 a750fc0b j_mayer
    /* POWER6 running in POWER5 mode                                         */
5653 a750fc0b j_mayer
    POWERPC_DEF("POWER6_5",    CPU_POWERPC_POWER6_5,    0xFFFFFFFF, POWER5),
5654 a750fc0b j_mayer
    /* POWER6A                                                               */
5655 a750fc0b j_mayer
    POWERPC_DEF("POWER6A",     CPU_POWERPC_POWER6A,     0xFFFFFFFF, POWER6),
5656 2662a059 j_mayer
#endif
5657 a750fc0b j_mayer
    /* PowerPC 970                                                           */
5658 a750fc0b j_mayer
    POWERPC_DEF("970",         CPU_POWERPC_970,         0xFFFFFFFF, 970),
5659 a750fc0b j_mayer
    /* PowerPC 970FX (G5)                                                    */
5660 a750fc0b j_mayer
    POWERPC_DEF("970fx",       CPU_POWERPC_970FX,       0xFFFFFFFF, 970FX),
5661 a750fc0b j_mayer
    /* PowerPC 970FX v1.0 (G5)                                               */
5662 a750fc0b j_mayer
    POWERPC_DEF("970fx1.0",    CPU_POWERPC_970FX_v10,   0xFFFFFFFF, 970FX),
5663 a750fc0b j_mayer
    /* PowerPC 970FX v2.0 (G5)                                               */
5664 a750fc0b j_mayer
    POWERPC_DEF("970fx2.0",    CPU_POWERPC_970FX_v20,   0xFFFFFFFF, 970FX),
5665 a750fc0b j_mayer
    /* PowerPC 970FX v2.1 (G5)                                               */
5666 a750fc0b j_mayer
    POWERPC_DEF("970fx2.1",    CPU_POWERPC_970FX_v21,   0xFFFFFFFF, 970FX),
5667 a750fc0b j_mayer
    /* PowerPC 970FX v3.0 (G5)                                               */
5668 a750fc0b j_mayer
    POWERPC_DEF("970fx3.0",    CPU_POWERPC_970FX_v30,   0xFFFFFFFF, 970FX),
5669 a750fc0b j_mayer
    /* PowerPC 970FX v3.1 (G5)                                               */
5670 a750fc0b j_mayer
    POWERPC_DEF("970fx3.1",    CPU_POWERPC_970FX_v31,   0xFFFFFFFF, 970FX),
5671 a750fc0b j_mayer
    /* PowerPC 970GX (G5)                                                    */
5672 a750fc0b j_mayer
    POWERPC_DEF("970gx",       CPU_POWERPC_970GX,       0xFFFFFFFF, 970GX),
5673 a750fc0b j_mayer
    /* PowerPC 970MP                                                         */
5674 a750fc0b j_mayer
    POWERPC_DEF("970mp",       CPU_POWERPC_970MP,       0xFFFFFFFF, 970),
5675 a750fc0b j_mayer
    /* PowerPC 970MP v1.0                                                    */
5676 a750fc0b j_mayer
    POWERPC_DEF("970mp1.0",    CPU_POWERPC_970MP_v10,   0xFFFFFFFF, 970),
5677 a750fc0b j_mayer
    /* PowerPC 970MP v1.1                                                    */
5678 a750fc0b j_mayer
    POWERPC_DEF("970mp1.1",    CPU_POWERPC_970MP_v11,   0xFFFFFFFF, 970),
5679 3a607854 j_mayer
#if defined (TODO)
5680 a750fc0b j_mayer
    /* PowerPC Cell                                                          */
5681 a750fc0b j_mayer
    POWERPC_DEF("Cell",        CPU_POWERPC_CELL,        0xFFFFFFFF, 970),
5682 2662a059 j_mayer
#endif
5683 2662a059 j_mayer
#if defined (TODO)
5684 a750fc0b j_mayer
    /* PowerPC Cell v1.0                                                     */
5685 a750fc0b j_mayer
    POWERPC_DEF("Cell1.0",     CPU_POWERPC_CELL_v10,    0xFFFFFFFF, 970),
5686 2662a059 j_mayer
#endif
5687 2662a059 j_mayer
#if defined (TODO)
5688 a750fc0b j_mayer
    /* PowerPC Cell v2.0                                                     */
5689 a750fc0b j_mayer
    POWERPC_DEF("Cell2.0",     CPU_POWERPC_CELL_v20,    0xFFFFFFFF, 970),
5690 2662a059 j_mayer
#endif
5691 2662a059 j_mayer
#if defined (TODO)
5692 a750fc0b j_mayer
    /* PowerPC Cell v3.0                                                     */
5693 a750fc0b j_mayer
    POWERPC_DEF("Cell3.0",     CPU_POWERPC_CELL_v30,    0xFFFFFFFF, 970),
5694 3a607854 j_mayer
#endif
5695 3a607854 j_mayer
#if defined (TODO)
5696 a750fc0b j_mayer
    /* PowerPC Cell v3.1                                                     */
5697 a750fc0b j_mayer
    POWERPC_DEF("Cell3.1",     CPU_POWERPC_CELL_v31,    0xFFFFFFFF, 970),
5698 2662a059 j_mayer
#endif
5699 2662a059 j_mayer
#if defined (TODO)
5700 a750fc0b j_mayer
    /* PowerPC Cell v3.2                                                     */
5701 a750fc0b j_mayer
    POWERPC_DEF("Cell3.2",     CPU_POWERPC_CELL_v32,    0xFFFFFFFF, 970),
5702 2662a059 j_mayer
#endif
5703 2662a059 j_mayer
#if defined (TODO)
5704 a750fc0b j_mayer
    /* RS64 (Apache/A35)                                                     */
5705 a750fc0b j_mayer
    /* This one seems to support the whole POWER2 instruction set
5706 a750fc0b j_mayer
     * and the PowerPC 64 one.
5707 a750fc0b j_mayer
     */
5708 a750fc0b j_mayer
    /* What about A10 & A30 ? */
5709 a750fc0b j_mayer
    POWERPC_DEF("RS64",        CPU_POWERPC_RS64,        0xFFFFFFFF, RS64),
5710 a750fc0b j_mayer
    POWERPC_DEF("Apache",      CPU_POWERPC_RS64,        0xFFFFFFFF, RS64),
5711 a750fc0b j_mayer
    POWERPC_DEF("A35",         CPU_POWERPC_RS64,        0xFFFFFFFF, RS64),
5712 3a607854 j_mayer
#endif
5713 3a607854 j_mayer
#if defined (TODO)
5714 a750fc0b j_mayer
    /* RS64-II (NorthStar/A50)                                               */
5715 a750fc0b j_mayer
    POWERPC_DEF("RS64-II",     CPU_POWERPC_RS64II,      0xFFFFFFFF, RS64),
5716 a750fc0b j_mayer
    POWERPC_DEF("NorthStar",   CPU_POWERPC_RS64II,      0xFFFFFFFF, RS64),
5717 a750fc0b j_mayer
    POWERPC_DEF("A50",         CPU_POWERPC_RS64II,      0xFFFFFFFF, RS64),
5718 3a607854 j_mayer
#endif
5719 3a607854 j_mayer
#if defined (TODO)
5720 a750fc0b j_mayer
    /* RS64-III (Pulsar)                                                     */
5721 a750fc0b j_mayer
    POWERPC_DEF("RS64-III",    CPU_POWERPC_RS64III,     0xFFFFFFFF, RS64),
5722 a750fc0b j_mayer
    POWERPC_DEF("Pulsar",      CPU_POWERPC_RS64III,     0xFFFFFFFF, RS64),
5723 2662a059 j_mayer
#endif
5724 2662a059 j_mayer
#if defined (TODO)
5725 a750fc0b j_mayer
    /* RS64-IV (IceStar/IStar/SStar)                                         */
5726 a750fc0b j_mayer
    POWERPC_DEF("RS64-IV",     CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5727 a750fc0b j_mayer
    POWERPC_DEF("IceStar",     CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5728 a750fc0b j_mayer
    POWERPC_DEF("IStar",       CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5729 a750fc0b j_mayer
    POWERPC_DEF("SStar",       CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5730 3a607854 j_mayer
#endif
5731 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
5732 a750fc0b j_mayer
    /* POWER                                                                 */
5733 3fc6c082 bellard
#if defined (TODO)
5734 a750fc0b j_mayer
    /* Original POWER                                                        */
5735 a750fc0b j_mayer
    POWERPC_DEF("POWER",       CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5736 a750fc0b j_mayer
    POWERPC_DEF("RIOS",        CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5737 a750fc0b j_mayer
    POWERPC_DEF("RSC",         CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5738 a750fc0b j_mayer
    POWERPC_DEF("RSC3308",     CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5739 a750fc0b j_mayer
    POWERPC_DEF("RSC4608",     CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5740 76a66253 j_mayer
#endif
5741 76a66253 j_mayer
#if defined (TODO)
5742 a750fc0b j_mayer
    /* POWER2                                                                */
5743 a750fc0b j_mayer
    POWERPC_DEF("POWER2",      CPU_POWERPC_POWER2,      0xFFFFFFFF, POWER),
5744 a750fc0b j_mayer
    POWERPC_DEF("RSC2",        CPU_POWERPC_POWER2,      0xFFFFFFFF, POWER),
5745 a750fc0b j_mayer
    POWERPC_DEF("P2SC",        CPU_POWERPC_POWER2,      0xFFFFFFFF, POWER),
5746 a750fc0b j_mayer
#endif
5747 a750fc0b j_mayer
    /* PA semi cores                                                         */
5748 a750fc0b j_mayer
#if defined (TODO)
5749 a750fc0b j_mayer
    /* PA PA6T */
5750 a750fc0b j_mayer
    POWERPC_DEF("PA6T",        CPU_POWERPC_PA6T,        0xFFFFFFFF, PA6T),
5751 a750fc0b j_mayer
#endif
5752 a750fc0b j_mayer
    /* Generic PowerPCs                                                      */
5753 a750fc0b j_mayer
#if defined (TARGET_PPC64)
5754 a750fc0b j_mayer
#if defined (TODO)
5755 a750fc0b j_mayer
    POWERPC_DEF("ppc64",       CPU_POWERPC_PPC64,       0xFFFFFFFF, PPC64),
5756 a750fc0b j_mayer
#endif
5757 a750fc0b j_mayer
#endif
5758 a750fc0b j_mayer
    POWERPC_DEF("ppc32",       CPU_POWERPC_PPC32,       0xFFFFFFFF, PPC32),
5759 d12f4c38 j_mayer
    POWERPC_DEF("ppc",         CPU_POWERPC_DEFAULT,     0xFFFFFFFF, DEFAULT),
5760 a750fc0b j_mayer
    /* Fallback                                                              */
5761 d12f4c38 j_mayer
    POWERPC_DEF("default",     CPU_POWERPC_DEFAULT,     0xFFFFFFFF, DEFAULT),
5762 a750fc0b j_mayer
};
5763 a750fc0b j_mayer
5764 a750fc0b j_mayer
/*****************************************************************************/
5765 a750fc0b j_mayer
/* Generic CPU instanciation routine                                         */
5766 a750fc0b j_mayer
static void init_ppc_proc (CPUPPCState *env, ppc_def_t *def)
5767 a750fc0b j_mayer
{
5768 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
5769 e1833e1f j_mayer
    int i;
5770 e1833e1f j_mayer
5771 a750fc0b j_mayer
    env->irq_inputs = NULL;
5772 e1833e1f j_mayer
    /* Set all exception vectors to an invalid address */
5773 e1833e1f j_mayer
    for (i = 0; i < POWERPC_EXCP_NB; i++)
5774 e1833e1f j_mayer
        env->excp_vectors[i] = (target_ulong)(-1ULL);
5775 e1833e1f j_mayer
    env->excp_prefix = 0x00000000;
5776 e1833e1f j_mayer
    env->ivor_mask = 0x00000000;
5777 e1833e1f j_mayer
    env->ivpr_mask = 0x00000000;
5778 a750fc0b j_mayer
    /* Default MMU definitions */
5779 a750fc0b j_mayer
    env->nb_BATs = 0;
5780 a750fc0b j_mayer
    env->nb_tlb = 0;
5781 a750fc0b j_mayer
    env->nb_ways = 0;
5782 f2e63a42 j_mayer
#endif
5783 a750fc0b j_mayer
    /* Register SPR common to all PowerPC implementations */
5784 a750fc0b j_mayer
    gen_spr_generic(env);
5785 a750fc0b j_mayer
    spr_register(env, SPR_PVR, "PVR",
5786 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5787 a750fc0b j_mayer
                 &spr_read_generic, SPR_NOACCESS,
5788 a750fc0b j_mayer
                 def->pvr);
5789 a750fc0b j_mayer
    /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
5790 a750fc0b j_mayer
    (*def->init_proc)(env);
5791 25ba3a68 j_mayer
    /* MSR bits & flags consistency checks */
5792 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 25)) {
5793 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
5794 25ba3a68 j_mayer
        case POWERPC_FLAG_SPE:
5795 25ba3a68 j_mayer
        case POWERPC_FLAG_VRE:
5796 25ba3a68 j_mayer
            break;
5797 25ba3a68 j_mayer
        default:
5798 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5799 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SPE or POWERPC_FLAG_VRE\n");
5800 25ba3a68 j_mayer
            exit(1);
5801 25ba3a68 j_mayer
        }
5802 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
5803 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5804 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SPE nor POWERPC_FLAG_VRE\n");
5805 25ba3a68 j_mayer
        exit(1);
5806 25ba3a68 j_mayer
    }
5807 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 17)) {
5808 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
5809 25ba3a68 j_mayer
        case POWERPC_FLAG_TGPR:
5810 25ba3a68 j_mayer
        case POWERPC_FLAG_CE:
5811 25ba3a68 j_mayer
            break;
5812 25ba3a68 j_mayer
        default:
5813 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5814 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_TGPR or POWERPC_FLAG_CE\n");
5815 25ba3a68 j_mayer
            exit(1);
5816 25ba3a68 j_mayer
        }
5817 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
5818 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5819 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_TGPR nor POWERPC_FLAG_CE\n");
5820 25ba3a68 j_mayer
        exit(1);
5821 25ba3a68 j_mayer
    }
5822 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 10)) {
5823 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
5824 25ba3a68 j_mayer
                              POWERPC_FLAG_UBLE)) {
5825 25ba3a68 j_mayer
        case POWERPC_FLAG_SE:
5826 25ba3a68 j_mayer
        case POWERPC_FLAG_DWE:
5827 25ba3a68 j_mayer
        case POWERPC_FLAG_UBLE:
5828 25ba3a68 j_mayer
            break;
5829 25ba3a68 j_mayer
        default:
5830 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5831 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SE or POWERPC_FLAG_DWE or "
5832 25ba3a68 j_mayer
                    "POWERPC_FLAG_UBLE\n");
5833 25ba3a68 j_mayer
            exit(1);
5834 25ba3a68 j_mayer
        }
5835 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
5836 25ba3a68 j_mayer
                             POWERPC_FLAG_UBLE)) {
5837 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5838 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SE nor POWERPC_FLAG_DWE nor "
5839 25ba3a68 j_mayer
                "POWERPC_FLAG_UBLE\n");
5840 25ba3a68 j_mayer
            exit(1);
5841 25ba3a68 j_mayer
    }
5842 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 9)) {
5843 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
5844 25ba3a68 j_mayer
        case POWERPC_FLAG_BE:
5845 25ba3a68 j_mayer
        case POWERPC_FLAG_DE:
5846 25ba3a68 j_mayer
            break;
5847 25ba3a68 j_mayer
        default:
5848 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5849 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_BE or POWERPC_FLAG_DE\n");
5850 25ba3a68 j_mayer
            exit(1);
5851 25ba3a68 j_mayer
        }
5852 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
5853 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5854 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_BE nor POWERPC_FLAG_DE\n");
5855 25ba3a68 j_mayer
        exit(1);
5856 25ba3a68 j_mayer
    }
5857 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 2)) {
5858 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
5859 25ba3a68 j_mayer
        case POWERPC_FLAG_PX:
5860 25ba3a68 j_mayer
        case POWERPC_FLAG_PMM:
5861 25ba3a68 j_mayer
            break;
5862 25ba3a68 j_mayer
        default:
5863 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5864 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_PX or POWERPC_FLAG_PMM\n");
5865 25ba3a68 j_mayer
            exit(1);
5866 25ba3a68 j_mayer
        }
5867 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
5868 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5869 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_PX nor POWERPC_FLAG_PMM\n");
5870 25ba3a68 j_mayer
        exit(1);
5871 25ba3a68 j_mayer
    }
5872 a750fc0b j_mayer
    /* Allocate TLBs buffer when needed */
5873 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
5874 a750fc0b j_mayer
    if (env->nb_tlb != 0) {
5875 a750fc0b j_mayer
        int nb_tlb = env->nb_tlb;
5876 a750fc0b j_mayer
        if (env->id_tlbs != 0)
5877 a750fc0b j_mayer
            nb_tlb *= 2;
5878 a750fc0b j_mayer
        env->tlb = qemu_mallocz(nb_tlb * sizeof(ppc_tlb_t));
5879 a750fc0b j_mayer
        /* Pre-compute some useful values */
5880 a750fc0b j_mayer
        env->tlb_per_way = env->nb_tlb / env->nb_ways;
5881 a750fc0b j_mayer
    }
5882 a750fc0b j_mayer
    if (env->irq_inputs == NULL) {
5883 a750fc0b j_mayer
        fprintf(stderr, "WARNING: no internal IRQ controller registered.\n"
5884 a750fc0b j_mayer
                " Attempt Qemu to crash very soon !\n");
5885 a750fc0b j_mayer
    }
5886 a750fc0b j_mayer
#endif
5887 a750fc0b j_mayer
}
5888 a750fc0b j_mayer
5889 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
5890 a750fc0b j_mayer
static void dump_ppc_sprs (CPUPPCState *env)
5891 a750fc0b j_mayer
{
5892 a750fc0b j_mayer
    ppc_spr_t *spr;
5893 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
5894 a750fc0b j_mayer
    uint32_t sr, sw;
5895 a750fc0b j_mayer
#endif
5896 a750fc0b j_mayer
    uint32_t ur, uw;
5897 a750fc0b j_mayer
    int i, j, n;
5898 a750fc0b j_mayer
5899 a750fc0b j_mayer
    printf("Special purpose registers:\n");
5900 a750fc0b j_mayer
    for (i = 0; i < 32; i++) {
5901 a750fc0b j_mayer
        for (j = 0; j < 32; j++) {
5902 a750fc0b j_mayer
            n = (i << 5) | j;
5903 a750fc0b j_mayer
            spr = &env->spr_cb[n];
5904 a750fc0b j_mayer
            uw = spr->uea_write != NULL && spr->uea_write != SPR_NOACCESS;
5905 a750fc0b j_mayer
            ur = spr->uea_read != NULL && spr->uea_read != SPR_NOACCESS;
5906 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
5907 a750fc0b j_mayer
            sw = spr->oea_write != NULL && spr->oea_write != SPR_NOACCESS;
5908 a750fc0b j_mayer
            sr = spr->oea_read != NULL && spr->oea_read != SPR_NOACCESS;
5909 a750fc0b j_mayer
            if (sw || sr || uw || ur) {
5910 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
5911 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
5912 a750fc0b j_mayer
                       sw ? 'w' : '-', sr ? 'r' : '-',
5913 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
5914 a750fc0b j_mayer
            }
5915 a750fc0b j_mayer
#else
5916 a750fc0b j_mayer
            if (uw || ur) {
5917 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s u%c%c\n",
5918 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
5919 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
5920 a750fc0b j_mayer
            }
5921 a750fc0b j_mayer
#endif
5922 a750fc0b j_mayer
        }
5923 a750fc0b j_mayer
    }
5924 a750fc0b j_mayer
    fflush(stdout);
5925 a750fc0b j_mayer
    fflush(stderr);
5926 a750fc0b j_mayer
}
5927 a750fc0b j_mayer
#endif
5928 a750fc0b j_mayer
5929 a750fc0b j_mayer
/*****************************************************************************/
5930 a750fc0b j_mayer
#include <stdlib.h>
5931 a750fc0b j_mayer
#include <string.h>
5932 a750fc0b j_mayer
5933 a750fc0b j_mayer
int fflush (FILE *stream);
5934 a750fc0b j_mayer
5935 a750fc0b j_mayer
/* Opcode types */
5936 a750fc0b j_mayer
enum {
5937 a750fc0b j_mayer
    PPC_DIRECT   = 0, /* Opcode routine        */
5938 a750fc0b j_mayer
    PPC_INDIRECT = 1, /* Indirect opcode table */
5939 a750fc0b j_mayer
};
5940 a750fc0b j_mayer
5941 a750fc0b j_mayer
static inline int is_indirect_opcode (void *handler)
5942 a750fc0b j_mayer
{
5943 a750fc0b j_mayer
    return ((unsigned long)handler & 0x03) == PPC_INDIRECT;
5944 a750fc0b j_mayer
}
5945 a750fc0b j_mayer
5946 a750fc0b j_mayer
static inline opc_handler_t **ind_table(void *handler)
5947 a750fc0b j_mayer
{
5948 a750fc0b j_mayer
    return (opc_handler_t **)((unsigned long)handler & ~3);
5949 a750fc0b j_mayer
}
5950 a750fc0b j_mayer
5951 a750fc0b j_mayer
/* Instruction table creation */
5952 a750fc0b j_mayer
/* Opcodes tables creation */
5953 a750fc0b j_mayer
static void fill_new_table (opc_handler_t **table, int len)
5954 a750fc0b j_mayer
{
5955 a750fc0b j_mayer
    int i;
5956 a750fc0b j_mayer
5957 a750fc0b j_mayer
    for (i = 0; i < len; i++)
5958 a750fc0b j_mayer
        table[i] = &invalid_handler;
5959 a750fc0b j_mayer
}
5960 a750fc0b j_mayer
5961 a750fc0b j_mayer
static int create_new_table (opc_handler_t **table, unsigned char idx)
5962 a750fc0b j_mayer
{
5963 a750fc0b j_mayer
    opc_handler_t **tmp;
5964 a750fc0b j_mayer
5965 a750fc0b j_mayer
    tmp = malloc(0x20 * sizeof(opc_handler_t));
5966 a750fc0b j_mayer
    if (tmp == NULL)
5967 a750fc0b j_mayer
        return -1;
5968 a750fc0b j_mayer
    fill_new_table(tmp, 0x20);
5969 a750fc0b j_mayer
    table[idx] = (opc_handler_t *)((unsigned long)tmp | PPC_INDIRECT);
5970 a750fc0b j_mayer
5971 a750fc0b j_mayer
    return 0;
5972 a750fc0b j_mayer
}
5973 a750fc0b j_mayer
5974 a750fc0b j_mayer
static int insert_in_table (opc_handler_t **table, unsigned char idx,
5975 a750fc0b j_mayer
                            opc_handler_t *handler)
5976 a750fc0b j_mayer
{
5977 a750fc0b j_mayer
    if (table[idx] != &invalid_handler)
5978 a750fc0b j_mayer
        return -1;
5979 a750fc0b j_mayer
    table[idx] = handler;
5980 a750fc0b j_mayer
5981 a750fc0b j_mayer
    return 0;
5982 a750fc0b j_mayer
}
5983 a750fc0b j_mayer
5984 a750fc0b j_mayer
static int register_direct_insn (opc_handler_t **ppc_opcodes,
5985 a750fc0b j_mayer
                                 unsigned char idx, opc_handler_t *handler)
5986 a750fc0b j_mayer
{
5987 a750fc0b j_mayer
    if (insert_in_table(ppc_opcodes, idx, handler) < 0) {
5988 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in main "
5989 a750fc0b j_mayer
               "opcode table\n", idx);
5990 a750fc0b j_mayer
        return -1;
5991 a750fc0b j_mayer
    }
5992 a750fc0b j_mayer
5993 a750fc0b j_mayer
    return 0;
5994 a750fc0b j_mayer
}
5995 a750fc0b j_mayer
5996 a750fc0b j_mayer
static int register_ind_in_table (opc_handler_t **table,
5997 a750fc0b j_mayer
                                  unsigned char idx1, unsigned char idx2,
5998 a750fc0b j_mayer
                                  opc_handler_t *handler)
5999 a750fc0b j_mayer
{
6000 a750fc0b j_mayer
    if (table[idx1] == &invalid_handler) {
6001 a750fc0b j_mayer
        if (create_new_table(table, idx1) < 0) {
6002 a750fc0b j_mayer
            printf("*** ERROR: unable to create indirect table "
6003 a750fc0b j_mayer
                   "idx=%02x\n", idx1);
6004 a750fc0b j_mayer
            return -1;
6005 a750fc0b j_mayer
        }
6006 a750fc0b j_mayer
    } else {
6007 a750fc0b j_mayer
        if (!is_indirect_opcode(table[idx1])) {
6008 a750fc0b j_mayer
            printf("*** ERROR: idx %02x already assigned to a direct "
6009 a750fc0b j_mayer
                   "opcode\n", idx1);
6010 a750fc0b j_mayer
            return -1;
6011 a750fc0b j_mayer
        }
6012 3a607854 j_mayer
    }
6013 a750fc0b j_mayer
    if (handler != NULL &&
6014 a750fc0b j_mayer
        insert_in_table(ind_table(table[idx1]), idx2, handler) < 0) {
6015 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in "
6016 a750fc0b j_mayer
               "opcode table %02x\n", idx2, idx1);
6017 a750fc0b j_mayer
        return -1;
6018 3a607854 j_mayer
    }
6019 a750fc0b j_mayer
6020 a750fc0b j_mayer
    return 0;
6021 a750fc0b j_mayer
}
6022 a750fc0b j_mayer
6023 a750fc0b j_mayer
static int register_ind_insn (opc_handler_t **ppc_opcodes,
6024 a750fc0b j_mayer
                              unsigned char idx1, unsigned char idx2,
6025 a750fc0b j_mayer
                              opc_handler_t *handler)
6026 a750fc0b j_mayer
{
6027 a750fc0b j_mayer
    int ret;
6028 a750fc0b j_mayer
6029 a750fc0b j_mayer
    ret = register_ind_in_table(ppc_opcodes, idx1, idx2, handler);
6030 a750fc0b j_mayer
6031 a750fc0b j_mayer
    return ret;
6032 a750fc0b j_mayer
}
6033 a750fc0b j_mayer
6034 a750fc0b j_mayer
static int register_dblind_insn (opc_handler_t **ppc_opcodes,
6035 a750fc0b j_mayer
                                 unsigned char idx1, unsigned char idx2,
6036 a750fc0b j_mayer
                                 unsigned char idx3, opc_handler_t *handler)
6037 a750fc0b j_mayer
{
6038 a750fc0b j_mayer
    if (register_ind_in_table(ppc_opcodes, idx1, idx2, NULL) < 0) {
6039 a750fc0b j_mayer
        printf("*** ERROR: unable to join indirect table idx "
6040 a750fc0b j_mayer
               "[%02x-%02x]\n", idx1, idx2);
6041 a750fc0b j_mayer
        return -1;
6042 a750fc0b j_mayer
    }
6043 a750fc0b j_mayer
    if (register_ind_in_table(ind_table(ppc_opcodes[idx1]), idx2, idx3,
6044 a750fc0b j_mayer
                              handler) < 0) {
6045 a750fc0b j_mayer
        printf("*** ERROR: unable to insert opcode "
6046 a750fc0b j_mayer
               "[%02x-%02x-%02x]\n", idx1, idx2, idx3);
6047 a750fc0b j_mayer
        return -1;
6048 a750fc0b j_mayer
    }
6049 a750fc0b j_mayer
6050 a750fc0b j_mayer
    return 0;
6051 a750fc0b j_mayer
}
6052 a750fc0b j_mayer
6053 a750fc0b j_mayer
static int register_insn (opc_handler_t **ppc_opcodes, opcode_t *insn)
6054 a750fc0b j_mayer
{
6055 a750fc0b j_mayer
    if (insn->opc2 != 0xFF) {
6056 a750fc0b j_mayer
        if (insn->opc3 != 0xFF) {
6057 a750fc0b j_mayer
            if (register_dblind_insn(ppc_opcodes, insn->opc1, insn->opc2,
6058 a750fc0b j_mayer
                                     insn->opc3, &insn->handler) < 0)
6059 a750fc0b j_mayer
                return -1;
6060 a750fc0b j_mayer
        } else {
6061 a750fc0b j_mayer
            if (register_ind_insn(ppc_opcodes, insn->opc1,
6062 a750fc0b j_mayer
                                  insn->opc2, &insn->handler) < 0)
6063 a750fc0b j_mayer
                return -1;
6064 a750fc0b j_mayer
        }
6065 a750fc0b j_mayer
    } else {
6066 a750fc0b j_mayer
        if (register_direct_insn(ppc_opcodes, insn->opc1, &insn->handler) < 0)
6067 a750fc0b j_mayer
            return -1;
6068 a750fc0b j_mayer
    }
6069 a750fc0b j_mayer
6070 a750fc0b j_mayer
    return 0;
6071 a750fc0b j_mayer
}
6072 a750fc0b j_mayer
6073 a750fc0b j_mayer
static int test_opcode_table (opc_handler_t **table, int len)
6074 a750fc0b j_mayer
{
6075 a750fc0b j_mayer
    int i, count, tmp;
6076 a750fc0b j_mayer
6077 a750fc0b j_mayer
    for (i = 0, count = 0; i < len; i++) {
6078 a750fc0b j_mayer
        /* Consistency fixup */
6079 a750fc0b j_mayer
        if (table[i] == NULL)
6080 a750fc0b j_mayer
            table[i] = &invalid_handler;
6081 a750fc0b j_mayer
        if (table[i] != &invalid_handler) {
6082 a750fc0b j_mayer
            if (is_indirect_opcode(table[i])) {
6083 a750fc0b j_mayer
                tmp = test_opcode_table(ind_table(table[i]), 0x20);
6084 a750fc0b j_mayer
                if (tmp == 0) {
6085 a750fc0b j_mayer
                    free(table[i]);
6086 a750fc0b j_mayer
                    table[i] = &invalid_handler;
6087 a750fc0b j_mayer
                } else {
6088 a750fc0b j_mayer
                    count++;
6089 a750fc0b j_mayer
                }
6090 a750fc0b j_mayer
            } else {
6091 a750fc0b j_mayer
                count++;
6092 a750fc0b j_mayer
            }
6093 a750fc0b j_mayer
        }
6094 a750fc0b j_mayer
    }
6095 a750fc0b j_mayer
6096 a750fc0b j_mayer
    return count;
6097 a750fc0b j_mayer
}
6098 a750fc0b j_mayer
6099 a750fc0b j_mayer
static void fix_opcode_tables (opc_handler_t **ppc_opcodes)
6100 a750fc0b j_mayer
{
6101 a750fc0b j_mayer
    if (test_opcode_table(ppc_opcodes, 0x40) == 0)
6102 a750fc0b j_mayer
        printf("*** WARNING: no opcode defined !\n");
6103 a750fc0b j_mayer
}
6104 a750fc0b j_mayer
6105 a750fc0b j_mayer
/*****************************************************************************/
6106 a750fc0b j_mayer
static int create_ppc_opcodes (CPUPPCState *env, ppc_def_t *def)
6107 a750fc0b j_mayer
{
6108 a750fc0b j_mayer
    opcode_t *opc, *start, *end;
6109 a750fc0b j_mayer
6110 a750fc0b j_mayer
    fill_new_table(env->opcodes, 0x40);
6111 a750fc0b j_mayer
    if (&opc_start < &opc_end) {
6112 a750fc0b j_mayer
        start = &opc_start;
6113 a750fc0b j_mayer
        end = &opc_end;
6114 a750fc0b j_mayer
    } else {
6115 a750fc0b j_mayer
        start = &opc_end;
6116 a750fc0b j_mayer
        end = &opc_start;
6117 a750fc0b j_mayer
    }
6118 a750fc0b j_mayer
    for (opc = start + 1; opc != end; opc++) {
6119 a750fc0b j_mayer
        if ((opc->handler.type & def->insns_flags) != 0) {
6120 a750fc0b j_mayer
            if (register_insn(env->opcodes, opc) < 0) {
6121 a750fc0b j_mayer
                printf("*** ERROR initializing PowerPC instruction "
6122 a750fc0b j_mayer
                       "0x%02x 0x%02x 0x%02x\n", opc->opc1, opc->opc2,
6123 a750fc0b j_mayer
                       opc->opc3);
6124 a750fc0b j_mayer
                return -1;
6125 a750fc0b j_mayer
            }
6126 a750fc0b j_mayer
        }
6127 a750fc0b j_mayer
    }
6128 a750fc0b j_mayer
    fix_opcode_tables(env->opcodes);
6129 a750fc0b j_mayer
    fflush(stdout);
6130 a750fc0b j_mayer
    fflush(stderr);
6131 a750fc0b j_mayer
6132 a750fc0b j_mayer
    return 0;
6133 a750fc0b j_mayer
}
6134 a750fc0b j_mayer
6135 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
6136 25ba3a68 j_mayer
static void dump_ppc_insns (CPUPPCState *env)
6137 a750fc0b j_mayer
{
6138 a750fc0b j_mayer
    opc_handler_t **table, *handler;
6139 a750fc0b j_mayer
    uint8_t opc1, opc2, opc3;
6140 a750fc0b j_mayer
6141 a750fc0b j_mayer
    printf("Instructions set:\n");
6142 a750fc0b j_mayer
    /* opc1 is 6 bits long */
6143 a750fc0b j_mayer
    for (opc1 = 0x00; opc1 < 0x40; opc1++) {
6144 a750fc0b j_mayer
        table = env->opcodes;
6145 a750fc0b j_mayer
        handler = table[opc1];
6146 a750fc0b j_mayer
        if (is_indirect_opcode(handler)) {
6147 a750fc0b j_mayer
            /* opc2 is 5 bits long */
6148 a750fc0b j_mayer
            for (opc2 = 0; opc2 < 0x20; opc2++) {
6149 a750fc0b j_mayer
                table = env->opcodes;
6150 a750fc0b j_mayer
                handler = env->opcodes[opc1];
6151 a750fc0b j_mayer
                table = ind_table(handler);
6152 a750fc0b j_mayer
                handler = table[opc2];
6153 a750fc0b j_mayer
                if (is_indirect_opcode(handler)) {
6154 a750fc0b j_mayer
                    table = ind_table(handler);
6155 a750fc0b j_mayer
                    /* opc3 is 5 bits long */
6156 a750fc0b j_mayer
                    for (opc3 = 0; opc3 < 0x20; opc3++) {
6157 a750fc0b j_mayer
                        handler = table[opc3];
6158 a750fc0b j_mayer
                        if (handler->handler != &gen_invalid) {
6159 a750fc0b j_mayer
                            printf("INSN: %02x %02x %02x (%02d %04d) : %s\n",
6160 a750fc0b j_mayer
                                   opc1, opc2, opc3, opc1, (opc3 << 5) | opc2,
6161 a750fc0b j_mayer
                                   handler->oname);
6162 a750fc0b j_mayer
                        }
6163 a750fc0b j_mayer
                    }
6164 a750fc0b j_mayer
                } else {
6165 a750fc0b j_mayer
                    if (handler->handler != &gen_invalid) {
6166 a750fc0b j_mayer
                        printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
6167 a750fc0b j_mayer
                               opc1, opc2, opc1, opc2, handler->oname);
6168 a750fc0b j_mayer
                    }
6169 a750fc0b j_mayer
                }
6170 a750fc0b j_mayer
            }
6171 a750fc0b j_mayer
        } else {
6172 a750fc0b j_mayer
            if (handler->handler != &gen_invalid) {
6173 a750fc0b j_mayer
                printf("INSN: %02x -- -- (%02d ----) : %s\n",
6174 a750fc0b j_mayer
                       opc1, opc1, handler->oname);
6175 a750fc0b j_mayer
            }
6176 a750fc0b j_mayer
        }
6177 a750fc0b j_mayer
    }
6178 a750fc0b j_mayer
}
6179 3a607854 j_mayer
#endif
6180 a750fc0b j_mayer
6181 a750fc0b j_mayer
int cpu_ppc_register (CPUPPCState *env, ppc_def_t *def)
6182 a750fc0b j_mayer
{
6183 a750fc0b j_mayer
    env->msr_mask = def->msr_mask;
6184 a750fc0b j_mayer
    env->mmu_model = def->mmu_model;
6185 a750fc0b j_mayer
    env->excp_model = def->excp_model;
6186 a750fc0b j_mayer
    env->bus_model = def->bus_model;
6187 d26bfc9a j_mayer
    env->flags = def->flags;
6188 237c0af0 j_mayer
    env->bfd_mach = def->bfd_mach;
6189 a750fc0b j_mayer
    if (create_ppc_opcodes(env, def) < 0)
6190 a750fc0b j_mayer
        return -1;
6191 a750fc0b j_mayer
    init_ppc_proc(env, def);
6192 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
6193 3a607854 j_mayer
    {
6194 a750fc0b j_mayer
        const unsigned char *mmu_model, *excp_model, *bus_model;
6195 a750fc0b j_mayer
        switch (env->mmu_model) {
6196 a750fc0b j_mayer
        case POWERPC_MMU_32B:
6197 a750fc0b j_mayer
            mmu_model = "PowerPC 32";
6198 a750fc0b j_mayer
            break;
6199 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_6xx:
6200 a750fc0b j_mayer
            mmu_model = "PowerPC 6xx/7xx with software driven TLBs";
6201 a750fc0b j_mayer
            break;
6202 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_74xx:
6203 a750fc0b j_mayer
            mmu_model = "PowerPC 74xx with software driven TLBs";
6204 a750fc0b j_mayer
            break;
6205 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx:
6206 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs";
6207 a750fc0b j_mayer
            break;
6208 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx_Z:
6209 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs "
6210 a750fc0b j_mayer
                "and zones protections";
6211 a750fc0b j_mayer
            break;
6212 a750fc0b j_mayer
        case POWERPC_MMU_REAL_4xx:
6213 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx real mode only";
6214 a750fc0b j_mayer
            break;
6215 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE:
6216 a750fc0b j_mayer
            mmu_model = "PowerPC BookE";
6217 a750fc0b j_mayer
            break;
6218 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE_FSL:
6219 a750fc0b j_mayer
            mmu_model = "PowerPC BookE FSL";
6220 a750fc0b j_mayer
            break;
6221 00af685f j_mayer
#if defined (TARGET_PPC64)
6222 00af685f j_mayer
        case POWERPC_MMU_64B:
6223 00af685f j_mayer
            mmu_model = "PowerPC 64";
6224 00af685f j_mayer
            break;
6225 00af685f j_mayer
#endif
6226 a750fc0b j_mayer
        default:
6227 a750fc0b j_mayer
            mmu_model = "Unknown or invalid";
6228 a750fc0b j_mayer
            break;
6229 a750fc0b j_mayer
        }
6230 a750fc0b j_mayer
        switch (env->excp_model) {
6231 a750fc0b j_mayer
        case POWERPC_EXCP_STD:
6232 a750fc0b j_mayer
            excp_model = "PowerPC";
6233 a750fc0b j_mayer
            break;
6234 a750fc0b j_mayer
        case POWERPC_EXCP_40x:
6235 a750fc0b j_mayer
            excp_model = "PowerPC 40x";
6236 a750fc0b j_mayer
            break;
6237 a750fc0b j_mayer
        case POWERPC_EXCP_601:
6238 a750fc0b j_mayer
            excp_model = "PowerPC 601";
6239 a750fc0b j_mayer
            break;
6240 a750fc0b j_mayer
        case POWERPC_EXCP_602:
6241 a750fc0b j_mayer
            excp_model = "PowerPC 602";
6242 a750fc0b j_mayer
            break;
6243 a750fc0b j_mayer
        case POWERPC_EXCP_603:
6244 a750fc0b j_mayer
            excp_model = "PowerPC 603";
6245 a750fc0b j_mayer
            break;
6246 a750fc0b j_mayer
        case POWERPC_EXCP_603E:
6247 a750fc0b j_mayer
            excp_model = "PowerPC 603e";
6248 a750fc0b j_mayer
            break;
6249 a750fc0b j_mayer
        case POWERPC_EXCP_604:
6250 a750fc0b j_mayer
            excp_model = "PowerPC 604";
6251 a750fc0b j_mayer
            break;
6252 a750fc0b j_mayer
        case POWERPC_EXCP_7x0:
6253 a750fc0b j_mayer
            excp_model = "PowerPC 740/750";
6254 a750fc0b j_mayer
            break;
6255 a750fc0b j_mayer
        case POWERPC_EXCP_7x5:
6256 a750fc0b j_mayer
            excp_model = "PowerPC 745/755";
6257 a750fc0b j_mayer
            break;
6258 a750fc0b j_mayer
        case POWERPC_EXCP_74xx:
6259 a750fc0b j_mayer
            excp_model = "PowerPC 74xx";
6260 a750fc0b j_mayer
            break;
6261 a750fc0b j_mayer
        case POWERPC_EXCP_BOOKE:
6262 a750fc0b j_mayer
            excp_model = "PowerPC BookE";
6263 a750fc0b j_mayer
            break;
6264 00af685f j_mayer
#if defined (TARGET_PPC64)
6265 00af685f j_mayer
        case POWERPC_EXCP_970:
6266 00af685f j_mayer
            excp_model = "PowerPC 970";
6267 00af685f j_mayer
            break;
6268 00af685f j_mayer
#endif
6269 a750fc0b j_mayer
        default:
6270 a750fc0b j_mayer
            excp_model = "Unknown or invalid";
6271 a750fc0b j_mayer
            break;
6272 a750fc0b j_mayer
        }
6273 a750fc0b j_mayer
        switch (env->bus_model) {
6274 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_6xx:
6275 a750fc0b j_mayer
            bus_model = "PowerPC 6xx";
6276 a750fc0b j_mayer
            break;
6277 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_BookE:
6278 a750fc0b j_mayer
            bus_model = "PowerPC BookE";
6279 a750fc0b j_mayer
            break;
6280 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_405:
6281 a750fc0b j_mayer
            bus_model = "PowerPC 405";
6282 a750fc0b j_mayer
            break;
6283 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_401:
6284 a750fc0b j_mayer
            bus_model = "PowerPC 401/403";
6285 a750fc0b j_mayer
            break;
6286 00af685f j_mayer
#if defined (TARGET_PPC64)
6287 00af685f j_mayer
        case PPC_FLAGS_INPUT_970:
6288 00af685f j_mayer
            bus_model = "PowerPC 970";
6289 00af685f j_mayer
            break;
6290 00af685f j_mayer
#endif
6291 a750fc0b j_mayer
        default:
6292 a750fc0b j_mayer
            bus_model = "Unknown or invalid";
6293 a750fc0b j_mayer
            break;
6294 a750fc0b j_mayer
        }
6295 a750fc0b j_mayer
        printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64 "\n"
6296 a750fc0b j_mayer
               "    MMU model        : %s\n",
6297 a750fc0b j_mayer
               def->name, def->pvr, def->msr_mask, mmu_model);
6298 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
6299 a750fc0b j_mayer
        if (env->tlb != NULL) {
6300 a750fc0b j_mayer
            printf("                       %d %s TLB in %d ways\n",
6301 a750fc0b j_mayer
                   env->nb_tlb, env->id_tlbs ? "splitted" : "merged",
6302 a750fc0b j_mayer
                   env->nb_ways);
6303 a750fc0b j_mayer
        }
6304 f2e63a42 j_mayer
#endif
6305 a750fc0b j_mayer
        printf("    Exceptions model : %s\n"
6306 a750fc0b j_mayer
               "    Bus model        : %s\n",
6307 a750fc0b j_mayer
               excp_model, bus_model);
6308 25ba3a68 j_mayer
        printf("    MSR features     :\n");
6309 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SPE)
6310 25ba3a68 j_mayer
            printf("                        signal processing engine enable"
6311 25ba3a68 j_mayer
                   "\n");
6312 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_VRE)
6313 25ba3a68 j_mayer
            printf("                        vector processor enable\n");
6314 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_TGPR)
6315 25ba3a68 j_mayer
            printf("                        temporary GPRs\n");
6316 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_CE)
6317 25ba3a68 j_mayer
            printf("                        critical input enable\n");
6318 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SE)
6319 25ba3a68 j_mayer
            printf("                        single-step trace mode\n");
6320 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DWE)
6321 25ba3a68 j_mayer
            printf("                        debug wait enable\n");
6322 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_UBLE)
6323 25ba3a68 j_mayer
            printf("                        user BTB lock enable\n");
6324 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_BE)
6325 25ba3a68 j_mayer
            printf("                        branch-step trace mode\n");
6326 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DE)
6327 25ba3a68 j_mayer
            printf("                        debug interrupt enable\n");
6328 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_PX)
6329 25ba3a68 j_mayer
            printf("                        inclusive protection\n");
6330 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_PMM)
6331 25ba3a68 j_mayer
            printf("                        performance monitor mark\n");
6332 25ba3a68 j_mayer
        if (env->flags == POWERPC_FLAG_NONE)
6333 25ba3a68 j_mayer
            printf("                        none\n");
6334 a750fc0b j_mayer
    }
6335 a750fc0b j_mayer
    dump_ppc_insns(env);
6336 a750fc0b j_mayer
    dump_ppc_sprs(env);
6337 a750fc0b j_mayer
    fflush(stdout);
6338 3a607854 j_mayer
#endif
6339 a750fc0b j_mayer
6340 a750fc0b j_mayer
    return 0;
6341 a750fc0b j_mayer
}
6342 3fc6c082 bellard
6343 3fc6c082 bellard
int ppc_find_by_name (const unsigned char *name, ppc_def_t **def)
6344 3fc6c082 bellard
{
6345 068abdc8 j_mayer
    int i, max, ret;
6346 3fc6c082 bellard
6347 3fc6c082 bellard
    ret = -1;
6348 3fc6c082 bellard
    *def = NULL;
6349 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6350 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
6351 3fc6c082 bellard
        if (strcasecmp(name, ppc_defs[i].name) == 0) {
6352 3fc6c082 bellard
            *def = &ppc_defs[i];
6353 3fc6c082 bellard
            ret = 0;
6354 3fc6c082 bellard
            break;
6355 3fc6c082 bellard
        }
6356 3fc6c082 bellard
    }
6357 3fc6c082 bellard
6358 3fc6c082 bellard
    return ret;
6359 3fc6c082 bellard
}
6360 3fc6c082 bellard
6361 3fc6c082 bellard
int ppc_find_by_pvr (uint32_t pvr, ppc_def_t **def)
6362 3fc6c082 bellard
{
6363 068abdc8 j_mayer
    int i, max, ret;
6364 3fc6c082 bellard
6365 3fc6c082 bellard
    ret = -1;
6366 3fc6c082 bellard
    *def = NULL;
6367 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6368 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
6369 3fc6c082 bellard
        if ((pvr & ppc_defs[i].pvr_mask) ==
6370 3fc6c082 bellard
            (ppc_defs[i].pvr & ppc_defs[i].pvr_mask)) {
6371 3fc6c082 bellard
            *def = &ppc_defs[i];
6372 3fc6c082 bellard
            ret = 0;
6373 3fc6c082 bellard
            break;
6374 3fc6c082 bellard
        }
6375 3fc6c082 bellard
    }
6376 3fc6c082 bellard
6377 3fc6c082 bellard
    return ret;
6378 3fc6c082 bellard
}
6379 3fc6c082 bellard
6380 3fc6c082 bellard
void ppc_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...))
6381 3fc6c082 bellard
{
6382 068abdc8 j_mayer
    int i, max;
6383 3fc6c082 bellard
6384 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6385 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
6386 a750fc0b j_mayer
        (*cpu_fprintf)(f, "PowerPC %-16s PVR %08x\n",
6387 a750fc0b j_mayer
                       ppc_defs[i].name, ppc_defs[i].pvr);
6388 3fc6c082 bellard
    }
6389 3fc6c082 bellard
}