Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ 082c6681

History | View | Annotate | Download (376.7 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 ee4e83ed j_mayer
#include "host-utils.h"
28 237c0af0 j_mayer
29 3fc6c082 bellard
//#define PPC_DUMP_CPU
30 3fc6c082 bellard
//#define PPC_DEBUG_SPR
31 80d11f44 j_mayer
//#define PPC_DUMP_SPR_ACCESSES
32 80d11f44 j_mayer
#if defined(CONFIG_USER_ONLY)
33 80d11f44 j_mayer
#define TODO_USER_ONLY 1
34 80d11f44 j_mayer
#endif
35 3fc6c082 bellard
36 3fc6c082 bellard
struct ppc_def_t {
37 3fc6c082 bellard
    const unsigned char *name;
38 3fc6c082 bellard
    uint32_t pvr;
39 80d11f44 j_mayer
    uint32_t svr;
40 0487d6a8 j_mayer
    uint64_t insns_flags;
41 3fc6c082 bellard
    uint64_t msr_mask;
42 7820dbf3 j_mayer
    powerpc_mmu_t   mmu_model;
43 7820dbf3 j_mayer
    powerpc_excp_t  excp_model;
44 7820dbf3 j_mayer
    powerpc_input_t bus_model;
45 d26bfc9a j_mayer
    uint32_t flags;
46 237c0af0 j_mayer
    int bfd_mach;
47 a750fc0b j_mayer
    void (*init_proc)(CPUPPCState *env);
48 4c1b1bfe j_mayer
    int  (*check_pow)(CPUPPCState *env);
49 3fc6c082 bellard
};
50 3fc6c082 bellard
51 e9df014c j_mayer
/* For user-mode emulation, we don't emulate any IRQ controller */
52 e9df014c j_mayer
#if defined(CONFIG_USER_ONLY)
53 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
54 a750fc0b j_mayer
static inline void glue(glue(ppc, name),_irq_init) (CPUPPCState *env)         \
55 a750fc0b j_mayer
{                                                                             \
56 e9df014c j_mayer
}
57 e9df014c j_mayer
#else
58 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
59 e9df014c j_mayer
void glue(glue(ppc, name),_irq_init) (CPUPPCState *env);
60 e9df014c j_mayer
#endif
61 a750fc0b j_mayer
62 4e290a0b j_mayer
PPC_IRQ_INIT_FN(40x);
63 e9df014c j_mayer
PPC_IRQ_INIT_FN(6xx);
64 d0dfae6e j_mayer
PPC_IRQ_INIT_FN(970);
65 e9df014c j_mayer
66 3fc6c082 bellard
/* Generic callbacks:
67 3fc6c082 bellard
 * do nothing but store/retrieve spr value
68 3fc6c082 bellard
 */
69 04f20795 j_mayer
#ifdef PPC_DUMP_SPR_ACCESSES
70 3fc6c082 bellard
static void spr_read_generic (void *opaque, int sprn)
71 3fc6c082 bellard
{
72 04f20795 j_mayer
    gen_op_load_dump_spr(sprn);
73 3fc6c082 bellard
}
74 3fc6c082 bellard
75 3fc6c082 bellard
static void spr_write_generic (void *opaque, int sprn)
76 3fc6c082 bellard
{
77 04f20795 j_mayer
    gen_op_store_dump_spr(sprn);
78 3fc6c082 bellard
}
79 04f20795 j_mayer
#else
80 04f20795 j_mayer
static void spr_read_generic (void *opaque, int sprn)
81 a496775f j_mayer
{
82 04f20795 j_mayer
    gen_op_load_spr(sprn);
83 a496775f j_mayer
}
84 a496775f j_mayer
85 04f20795 j_mayer
static void spr_write_generic (void *opaque, int sprn)
86 a496775f j_mayer
{
87 04f20795 j_mayer
    gen_op_store_spr(sprn);
88 a496775f j_mayer
}
89 04f20795 j_mayer
#endif
90 a496775f j_mayer
91 a496775f j_mayer
#if !defined(CONFIG_USER_ONLY)
92 a496775f j_mayer
static void spr_write_clear (void *opaque, int sprn)
93 a496775f j_mayer
{
94 a496775f j_mayer
    gen_op_mask_spr(sprn);
95 a496775f j_mayer
}
96 a496775f j_mayer
#endif
97 a496775f j_mayer
98 76a66253 j_mayer
/* SPR common to all PowerPC */
99 3fc6c082 bellard
/* XER */
100 3fc6c082 bellard
static void spr_read_xer (void *opaque, int sprn)
101 3fc6c082 bellard
{
102 3fc6c082 bellard
    gen_op_load_xer();
103 3fc6c082 bellard
}
104 3fc6c082 bellard
105 3fc6c082 bellard
static void spr_write_xer (void *opaque, int sprn)
106 3fc6c082 bellard
{
107 3fc6c082 bellard
    gen_op_store_xer();
108 3fc6c082 bellard
}
109 3fc6c082 bellard
110 3fc6c082 bellard
/* LR */
111 3fc6c082 bellard
static void spr_read_lr (void *opaque, int sprn)
112 3fc6c082 bellard
{
113 3fc6c082 bellard
    gen_op_load_lr();
114 3fc6c082 bellard
}
115 3fc6c082 bellard
116 3fc6c082 bellard
static void spr_write_lr (void *opaque, int sprn)
117 3fc6c082 bellard
{
118 3fc6c082 bellard
    gen_op_store_lr();
119 3fc6c082 bellard
}
120 3fc6c082 bellard
121 3fc6c082 bellard
/* CTR */
122 3fc6c082 bellard
static void spr_read_ctr (void *opaque, int sprn)
123 3fc6c082 bellard
{
124 3fc6c082 bellard
    gen_op_load_ctr();
125 3fc6c082 bellard
}
126 3fc6c082 bellard
127 3fc6c082 bellard
static void spr_write_ctr (void *opaque, int sprn)
128 3fc6c082 bellard
{
129 3fc6c082 bellard
    gen_op_store_ctr();
130 3fc6c082 bellard
}
131 3fc6c082 bellard
132 3fc6c082 bellard
/* User read access to SPR */
133 3fc6c082 bellard
/* USPRx */
134 3fc6c082 bellard
/* UMMCRx */
135 3fc6c082 bellard
/* UPMCx */
136 3fc6c082 bellard
/* USIA */
137 3fc6c082 bellard
/* UDECR */
138 3fc6c082 bellard
static void spr_read_ureg (void *opaque, int sprn)
139 3fc6c082 bellard
{
140 3fc6c082 bellard
    gen_op_load_spr(sprn + 0x10);
141 3fc6c082 bellard
}
142 3fc6c082 bellard
143 76a66253 j_mayer
/* SPR common to all non-embedded PowerPC */
144 3fc6c082 bellard
/* DECR */
145 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
146 3fc6c082 bellard
static void spr_read_decr (void *opaque, int sprn)
147 3fc6c082 bellard
{
148 3fc6c082 bellard
    gen_op_load_decr();
149 3fc6c082 bellard
}
150 3fc6c082 bellard
151 3fc6c082 bellard
static void spr_write_decr (void *opaque, int sprn)
152 3fc6c082 bellard
{
153 3fc6c082 bellard
    gen_op_store_decr();
154 3fc6c082 bellard
}
155 76a66253 j_mayer
#endif
156 3fc6c082 bellard
157 76a66253 j_mayer
/* SPR common to all non-embedded PowerPC, except 601 */
158 3fc6c082 bellard
/* Time base */
159 3fc6c082 bellard
static void spr_read_tbl (void *opaque, int sprn)
160 3fc6c082 bellard
{
161 3fc6c082 bellard
    gen_op_load_tbl();
162 3fc6c082 bellard
}
163 3fc6c082 bellard
164 76a66253 j_mayer
static void spr_read_tbu (void *opaque, int sprn)
165 3fc6c082 bellard
{
166 76a66253 j_mayer
    gen_op_load_tbu();
167 3fc6c082 bellard
}
168 3fc6c082 bellard
169 a062e36c j_mayer
__attribute__ (( unused ))
170 a062e36c j_mayer
static void spr_read_atbl (void *opaque, int sprn)
171 a062e36c j_mayer
{
172 a062e36c j_mayer
    gen_op_load_atbl();
173 a062e36c j_mayer
}
174 a062e36c j_mayer
175 a062e36c j_mayer
__attribute__ (( unused ))
176 a062e36c j_mayer
static void spr_read_atbu (void *opaque, int sprn)
177 a062e36c j_mayer
{
178 a062e36c j_mayer
    gen_op_load_atbu();
179 a062e36c j_mayer
}
180 a062e36c j_mayer
181 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
182 76a66253 j_mayer
static void spr_write_tbl (void *opaque, int sprn)
183 3fc6c082 bellard
{
184 76a66253 j_mayer
    gen_op_store_tbl();
185 3fc6c082 bellard
}
186 3fc6c082 bellard
187 3fc6c082 bellard
static void spr_write_tbu (void *opaque, int sprn)
188 3fc6c082 bellard
{
189 3fc6c082 bellard
    gen_op_store_tbu();
190 3fc6c082 bellard
}
191 a062e36c j_mayer
192 a062e36c j_mayer
__attribute__ (( unused ))
193 a062e36c j_mayer
static void spr_write_atbl (void *opaque, int sprn)
194 a062e36c j_mayer
{
195 a062e36c j_mayer
    gen_op_store_atbl();
196 a062e36c j_mayer
}
197 a062e36c j_mayer
198 a062e36c j_mayer
__attribute__ (( unused ))
199 a062e36c j_mayer
static void spr_write_atbu (void *opaque, int sprn)
200 a062e36c j_mayer
{
201 a062e36c j_mayer
    gen_op_store_atbu();
202 a062e36c j_mayer
}
203 76a66253 j_mayer
#endif
204 3fc6c082 bellard
205 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
206 3fc6c082 bellard
/* IBAT0U...IBAT0U */
207 3fc6c082 bellard
/* IBAT0L...IBAT7L */
208 3fc6c082 bellard
static void spr_read_ibat (void *opaque, int sprn)
209 3fc6c082 bellard
{
210 3fc6c082 bellard
    gen_op_load_ibat(sprn & 1, (sprn - SPR_IBAT0U) / 2);
211 3fc6c082 bellard
}
212 3fc6c082 bellard
213 3fc6c082 bellard
static void spr_read_ibat_h (void *opaque, int sprn)
214 3fc6c082 bellard
{
215 3fc6c082 bellard
    gen_op_load_ibat(sprn & 1, (sprn - SPR_IBAT4U) / 2);
216 3fc6c082 bellard
}
217 3fc6c082 bellard
218 3fc6c082 bellard
static void spr_write_ibatu (void *opaque, int sprn)
219 3fc6c082 bellard
{
220 3fc6c082 bellard
    gen_op_store_ibatu((sprn - SPR_IBAT0U) / 2);
221 3fc6c082 bellard
}
222 3fc6c082 bellard
223 3fc6c082 bellard
static void spr_write_ibatu_h (void *opaque, int sprn)
224 3fc6c082 bellard
{
225 3fc6c082 bellard
    gen_op_store_ibatu((sprn - SPR_IBAT4U) / 2);
226 3fc6c082 bellard
}
227 3fc6c082 bellard
228 3fc6c082 bellard
static void spr_write_ibatl (void *opaque, int sprn)
229 3fc6c082 bellard
{
230 3fc6c082 bellard
    gen_op_store_ibatl((sprn - SPR_IBAT0L) / 2);
231 3fc6c082 bellard
}
232 3fc6c082 bellard
233 3fc6c082 bellard
static void spr_write_ibatl_h (void *opaque, int sprn)
234 3fc6c082 bellard
{
235 3fc6c082 bellard
    gen_op_store_ibatl((sprn - SPR_IBAT4L) / 2);
236 3fc6c082 bellard
}
237 3fc6c082 bellard
238 3fc6c082 bellard
/* DBAT0U...DBAT7U */
239 3fc6c082 bellard
/* DBAT0L...DBAT7L */
240 3fc6c082 bellard
static void spr_read_dbat (void *opaque, int sprn)
241 3fc6c082 bellard
{
242 3fc6c082 bellard
    gen_op_load_dbat(sprn & 1, (sprn - SPR_DBAT0U) / 2);
243 3fc6c082 bellard
}
244 3fc6c082 bellard
245 3fc6c082 bellard
static void spr_read_dbat_h (void *opaque, int sprn)
246 3fc6c082 bellard
{
247 2e13d23a j_mayer
    gen_op_load_dbat(sprn & 1, ((sprn - SPR_DBAT4U) / 2) + 4);
248 3fc6c082 bellard
}
249 3fc6c082 bellard
250 3fc6c082 bellard
static void spr_write_dbatu (void *opaque, int sprn)
251 3fc6c082 bellard
{
252 3fc6c082 bellard
    gen_op_store_dbatu((sprn - SPR_DBAT0U) / 2);
253 3fc6c082 bellard
}
254 3fc6c082 bellard
255 3fc6c082 bellard
static void spr_write_dbatu_h (void *opaque, int sprn)
256 3fc6c082 bellard
{
257 2e13d23a j_mayer
    gen_op_store_dbatu(((sprn - SPR_DBAT4U) / 2) + 4);
258 3fc6c082 bellard
}
259 3fc6c082 bellard
260 3fc6c082 bellard
static void spr_write_dbatl (void *opaque, int sprn)
261 3fc6c082 bellard
{
262 3fc6c082 bellard
    gen_op_store_dbatl((sprn - SPR_DBAT0L) / 2);
263 3fc6c082 bellard
}
264 3fc6c082 bellard
265 3fc6c082 bellard
static void spr_write_dbatl_h (void *opaque, int sprn)
266 3fc6c082 bellard
{
267 2e13d23a j_mayer
    gen_op_store_dbatl(((sprn - SPR_DBAT4L) / 2) + 4);
268 3fc6c082 bellard
}
269 3fc6c082 bellard
270 3fc6c082 bellard
/* SDR1 */
271 3fc6c082 bellard
static void spr_read_sdr1 (void *opaque, int sprn)
272 3fc6c082 bellard
{
273 3fc6c082 bellard
    gen_op_load_sdr1();
274 3fc6c082 bellard
}
275 3fc6c082 bellard
276 3fc6c082 bellard
static void spr_write_sdr1 (void *opaque, int sprn)
277 3fc6c082 bellard
{
278 3fc6c082 bellard
    gen_op_store_sdr1();
279 3fc6c082 bellard
}
280 3fc6c082 bellard
281 76a66253 j_mayer
/* 64 bits PowerPC specific SPRs */
282 76a66253 j_mayer
/* ASR */
283 578bb252 j_mayer
#if defined(TARGET_PPC64)
284 76a66253 j_mayer
static void spr_read_asr (void *opaque, int sprn)
285 76a66253 j_mayer
{
286 76a66253 j_mayer
    gen_op_load_asr();
287 76a66253 j_mayer
}
288 76a66253 j_mayer
289 76a66253 j_mayer
static void spr_write_asr (void *opaque, int sprn)
290 76a66253 j_mayer
{
291 76a66253 j_mayer
    gen_op_store_asr();
292 76a66253 j_mayer
}
293 76a66253 j_mayer
#endif
294 a750fc0b j_mayer
#endif
295 76a66253 j_mayer
296 76a66253 j_mayer
/* PowerPC 601 specific registers */
297 76a66253 j_mayer
/* RTC */
298 76a66253 j_mayer
static void spr_read_601_rtcl (void *opaque, int sprn)
299 76a66253 j_mayer
{
300 76a66253 j_mayer
    gen_op_load_601_rtcl();
301 76a66253 j_mayer
}
302 76a66253 j_mayer
303 76a66253 j_mayer
static void spr_read_601_rtcu (void *opaque, int sprn)
304 76a66253 j_mayer
{
305 76a66253 j_mayer
    gen_op_load_601_rtcu();
306 76a66253 j_mayer
}
307 76a66253 j_mayer
308 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
309 76a66253 j_mayer
static void spr_write_601_rtcu (void *opaque, int sprn)
310 76a66253 j_mayer
{
311 76a66253 j_mayer
    gen_op_store_601_rtcu();
312 76a66253 j_mayer
}
313 76a66253 j_mayer
314 76a66253 j_mayer
static void spr_write_601_rtcl (void *opaque, int sprn)
315 76a66253 j_mayer
{
316 76a66253 j_mayer
    gen_op_store_601_rtcl();
317 76a66253 j_mayer
}
318 056401ea j_mayer
319 056401ea j_mayer
static void spr_write_hid0_601 (void *opaque, int sprn)
320 056401ea j_mayer
{
321 056401ea j_mayer
    DisasContext *ctx = opaque;
322 056401ea j_mayer
323 056401ea j_mayer
    gen_op_store_hid0_601();
324 056401ea j_mayer
    /* Must stop the translation as endianness may have changed */
325 056401ea j_mayer
    GEN_STOP(ctx);
326 056401ea j_mayer
}
327 76a66253 j_mayer
#endif
328 76a66253 j_mayer
329 76a66253 j_mayer
/* Unified bats */
330 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
331 76a66253 j_mayer
static void spr_read_601_ubat (void *opaque, int sprn)
332 76a66253 j_mayer
{
333 76a66253 j_mayer
    gen_op_load_601_bat(sprn & 1, (sprn - SPR_IBAT0U) / 2);
334 76a66253 j_mayer
}
335 76a66253 j_mayer
336 76a66253 j_mayer
static void spr_write_601_ubatu (void *opaque, int sprn)
337 76a66253 j_mayer
{
338 76a66253 j_mayer
    gen_op_store_601_batu((sprn - SPR_IBAT0U) / 2);
339 76a66253 j_mayer
}
340 76a66253 j_mayer
341 76a66253 j_mayer
static void spr_write_601_ubatl (void *opaque, int sprn)
342 76a66253 j_mayer
{
343 76a66253 j_mayer
    gen_op_store_601_batl((sprn - SPR_IBAT0L) / 2);
344 76a66253 j_mayer
}
345 76a66253 j_mayer
#endif
346 76a66253 j_mayer
347 76a66253 j_mayer
/* PowerPC 40x specific registers */
348 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
349 76a66253 j_mayer
static void spr_read_40x_pit (void *opaque, int sprn)
350 76a66253 j_mayer
{
351 76a66253 j_mayer
    gen_op_load_40x_pit();
352 76a66253 j_mayer
}
353 76a66253 j_mayer
354 76a66253 j_mayer
static void spr_write_40x_pit (void *opaque, int sprn)
355 76a66253 j_mayer
{
356 76a66253 j_mayer
    gen_op_store_40x_pit();
357 76a66253 j_mayer
}
358 76a66253 j_mayer
359 8ecc7913 j_mayer
static void spr_write_40x_dbcr0 (void *opaque, int sprn)
360 8ecc7913 j_mayer
{
361 8ecc7913 j_mayer
    DisasContext *ctx = opaque;
362 8ecc7913 j_mayer
363 8ecc7913 j_mayer
    gen_op_store_40x_dbcr0();
364 8ecc7913 j_mayer
    /* We must stop translation as we may have rebooted */
365 e1833e1f j_mayer
    GEN_STOP(ctx);
366 8ecc7913 j_mayer
}
367 8ecc7913 j_mayer
368 c294fc58 j_mayer
static void spr_write_40x_sler (void *opaque, int sprn)
369 c294fc58 j_mayer
{
370 c294fc58 j_mayer
    gen_op_store_40x_sler();
371 c294fc58 j_mayer
}
372 c294fc58 j_mayer
373 76a66253 j_mayer
static void spr_write_booke_tcr (void *opaque, int sprn)
374 76a66253 j_mayer
{
375 76a66253 j_mayer
    gen_op_store_booke_tcr();
376 76a66253 j_mayer
}
377 76a66253 j_mayer
378 76a66253 j_mayer
static void spr_write_booke_tsr (void *opaque, int sprn)
379 76a66253 j_mayer
{
380 76a66253 j_mayer
    gen_op_store_booke_tsr();
381 76a66253 j_mayer
}
382 76a66253 j_mayer
#endif
383 76a66253 j_mayer
384 76a66253 j_mayer
/* PowerPC 403 specific registers */
385 76a66253 j_mayer
/* PBL1 / PBU1 / PBL2 / PBU2 */
386 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
387 76a66253 j_mayer
static void spr_read_403_pbr (void *opaque, int sprn)
388 76a66253 j_mayer
{
389 76a66253 j_mayer
    gen_op_load_403_pb(sprn - SPR_403_PBL1);
390 76a66253 j_mayer
}
391 76a66253 j_mayer
392 76a66253 j_mayer
static void spr_write_403_pbr (void *opaque, int sprn)
393 76a66253 j_mayer
{
394 76a66253 j_mayer
    gen_op_store_403_pb(sprn - SPR_403_PBL1);
395 76a66253 j_mayer
}
396 76a66253 j_mayer
397 3fc6c082 bellard
static void spr_write_pir (void *opaque, int sprn)
398 3fc6c082 bellard
{
399 3fc6c082 bellard
    gen_op_store_pir();
400 3fc6c082 bellard
}
401 76a66253 j_mayer
#endif
402 3fc6c082 bellard
403 6f5d427d j_mayer
#if !defined(CONFIG_USER_ONLY)
404 6f5d427d j_mayer
/* Callback used to write the exception vector base */
405 6f5d427d j_mayer
static void spr_write_excp_prefix (void *opaque, int sprn)
406 6f5d427d j_mayer
{
407 6f5d427d j_mayer
    gen_op_store_excp_prefix();
408 6f5d427d j_mayer
    gen_op_store_spr(sprn);
409 6f5d427d j_mayer
}
410 6f5d427d j_mayer
411 6f5d427d j_mayer
static void spr_write_excp_vector (void *opaque, int sprn)
412 6f5d427d j_mayer
{
413 6f5d427d j_mayer
    DisasContext *ctx = opaque;
414 6f5d427d j_mayer
415 6f5d427d j_mayer
    if (sprn >= SPR_BOOKE_IVOR0 && sprn <= SPR_BOOKE_IVOR15) {
416 6f5d427d j_mayer
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR0);
417 6f5d427d j_mayer
        gen_op_store_spr(sprn);
418 6f5d427d j_mayer
    } else if (sprn >= SPR_BOOKE_IVOR32 && sprn <= SPR_BOOKE_IVOR37) {
419 6f5d427d j_mayer
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR32 + 32);
420 6f5d427d j_mayer
        gen_op_store_spr(sprn);
421 6f5d427d j_mayer
    } else {
422 6f5d427d j_mayer
        printf("Trying to write an unknown exception vector %d %03x\n",
423 6f5d427d j_mayer
               sprn, sprn);
424 6f5d427d j_mayer
        GEN_EXCP_PRIVREG(ctx);
425 6f5d427d j_mayer
    }
426 6f5d427d j_mayer
}
427 6f5d427d j_mayer
#endif
428 6f5d427d j_mayer
429 76a66253 j_mayer
#if defined(CONFIG_USER_ONLY)
430 76a66253 j_mayer
#define spr_register(env, num, name, uea_read, uea_write,                     \
431 76a66253 j_mayer
                     oea_read, oea_write, initial_value)                      \
432 76a66253 j_mayer
do {                                                                          \
433 76a66253 j_mayer
     _spr_register(env, num, name, uea_read, uea_write, initial_value);       \
434 76a66253 j_mayer
} while (0)
435 76a66253 j_mayer
static inline void _spr_register (CPUPPCState *env, int num,
436 76a66253 j_mayer
                                  const unsigned char *name,
437 76a66253 j_mayer
                                  void (*uea_read)(void *opaque, int sprn),
438 76a66253 j_mayer
                                  void (*uea_write)(void *opaque, int sprn),
439 76a66253 j_mayer
                                  target_ulong initial_value)
440 76a66253 j_mayer
#else
441 3fc6c082 bellard
static inline void spr_register (CPUPPCState *env, int num,
442 3fc6c082 bellard
                                 const unsigned char *name,
443 3fc6c082 bellard
                                 void (*uea_read)(void *opaque, int sprn),
444 3fc6c082 bellard
                                 void (*uea_write)(void *opaque, int sprn),
445 3fc6c082 bellard
                                 void (*oea_read)(void *opaque, int sprn),
446 3fc6c082 bellard
                                 void (*oea_write)(void *opaque, int sprn),
447 3fc6c082 bellard
                                 target_ulong initial_value)
448 76a66253 j_mayer
#endif
449 3fc6c082 bellard
{
450 3fc6c082 bellard
    ppc_spr_t *spr;
451 3fc6c082 bellard
452 3fc6c082 bellard
    spr = &env->spr_cb[num];
453 3fc6c082 bellard
    if (spr->name != NULL ||env-> spr[num] != 0x00000000 ||
454 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
455 76a66253 j_mayer
        spr->oea_read != NULL || spr->oea_write != NULL ||
456 76a66253 j_mayer
#endif
457 76a66253 j_mayer
        spr->uea_read != NULL || spr->uea_write != NULL) {
458 3fc6c082 bellard
        printf("Error: Trying to register SPR %d (%03x) twice !\n", num, num);
459 3fc6c082 bellard
        exit(1);
460 3fc6c082 bellard
    }
461 3fc6c082 bellard
#if defined(PPC_DEBUG_SPR)
462 1b9eb036 j_mayer
    printf("*** register spr %d (%03x) %s val " ADDRX "\n", num, num, name,
463 76a66253 j_mayer
           initial_value);
464 3fc6c082 bellard
#endif
465 3fc6c082 bellard
    spr->name = name;
466 3fc6c082 bellard
    spr->uea_read = uea_read;
467 3fc6c082 bellard
    spr->uea_write = uea_write;
468 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
469 3fc6c082 bellard
    spr->oea_read = oea_read;
470 3fc6c082 bellard
    spr->oea_write = oea_write;
471 76a66253 j_mayer
#endif
472 3fc6c082 bellard
    env->spr[num] = initial_value;
473 3fc6c082 bellard
}
474 3fc6c082 bellard
475 3fc6c082 bellard
/* Generic PowerPC SPRs */
476 3fc6c082 bellard
static void gen_spr_generic (CPUPPCState *env)
477 3fc6c082 bellard
{
478 3fc6c082 bellard
    /* Integer processing */
479 3fc6c082 bellard
    spr_register(env, SPR_XER, "XER",
480 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
481 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
482 3fc6c082 bellard
                 0x00000000);
483 3fc6c082 bellard
    /* Branch contol */
484 3fc6c082 bellard
    spr_register(env, SPR_LR, "LR",
485 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
486 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
487 3fc6c082 bellard
                 0x00000000);
488 3fc6c082 bellard
    spr_register(env, SPR_CTR, "CTR",
489 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
490 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
491 3fc6c082 bellard
                 0x00000000);
492 3fc6c082 bellard
    /* Interrupt processing */
493 3fc6c082 bellard
    spr_register(env, SPR_SRR0, "SRR0",
494 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
495 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
496 3fc6c082 bellard
                 0x00000000);
497 3fc6c082 bellard
    spr_register(env, SPR_SRR1, "SRR1",
498 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
499 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
500 3fc6c082 bellard
                 0x00000000);
501 3fc6c082 bellard
    /* Processor control */
502 3fc6c082 bellard
    spr_register(env, SPR_SPRG0, "SPRG0",
503 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
504 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
505 3fc6c082 bellard
                 0x00000000);
506 3fc6c082 bellard
    spr_register(env, SPR_SPRG1, "SPRG1",
507 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
508 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
509 3fc6c082 bellard
                 0x00000000);
510 3fc6c082 bellard
    spr_register(env, SPR_SPRG2, "SPRG2",
511 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
512 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
513 3fc6c082 bellard
                 0x00000000);
514 3fc6c082 bellard
    spr_register(env, SPR_SPRG3, "SPRG3",
515 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
516 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
517 3fc6c082 bellard
                 0x00000000);
518 3fc6c082 bellard
}
519 3fc6c082 bellard
520 3fc6c082 bellard
/* SPR common to all non-embedded PowerPC, including 601 */
521 3fc6c082 bellard
static void gen_spr_ne_601 (CPUPPCState *env)
522 3fc6c082 bellard
{
523 3fc6c082 bellard
    /* Exception processing */
524 3fc6c082 bellard
    spr_register(env, SPR_DSISR, "DSISR",
525 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
526 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
527 3fc6c082 bellard
                 0x00000000);
528 3fc6c082 bellard
    spr_register(env, SPR_DAR, "DAR",
529 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
530 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
531 3fc6c082 bellard
                 0x00000000);
532 3fc6c082 bellard
    /* Timer */
533 3fc6c082 bellard
    spr_register(env, SPR_DECR, "DECR",
534 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
535 3fc6c082 bellard
                 &spr_read_decr, &spr_write_decr,
536 3fc6c082 bellard
                 0x00000000);
537 3fc6c082 bellard
    /* Memory management */
538 3fc6c082 bellard
    spr_register(env, SPR_SDR1, "SDR1",
539 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
540 3fc6c082 bellard
                 &spr_read_sdr1, &spr_write_sdr1,
541 3fc6c082 bellard
                 0x00000000);
542 3fc6c082 bellard
}
543 3fc6c082 bellard
544 3fc6c082 bellard
/* BATs 0-3 */
545 3fc6c082 bellard
static void gen_low_BATs (CPUPPCState *env)
546 3fc6c082 bellard
{
547 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
548 3fc6c082 bellard
    spr_register(env, SPR_IBAT0U, "IBAT0U",
549 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
550 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
551 3fc6c082 bellard
                 0x00000000);
552 3fc6c082 bellard
    spr_register(env, SPR_IBAT0L, "IBAT0L",
553 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
554 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
555 3fc6c082 bellard
                 0x00000000);
556 3fc6c082 bellard
    spr_register(env, SPR_IBAT1U, "IBAT1U",
557 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
558 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
559 3fc6c082 bellard
                 0x00000000);
560 3fc6c082 bellard
    spr_register(env, SPR_IBAT1L, "IBAT1L",
561 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
562 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
563 3fc6c082 bellard
                 0x00000000);
564 3fc6c082 bellard
    spr_register(env, SPR_IBAT2U, "IBAT2U",
565 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
566 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
567 3fc6c082 bellard
                 0x00000000);
568 3fc6c082 bellard
    spr_register(env, SPR_IBAT2L, "IBAT2L",
569 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
570 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
571 3fc6c082 bellard
                 0x00000000);
572 3fc6c082 bellard
    spr_register(env, SPR_IBAT3U, "IBAT3U",
573 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
574 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
575 3fc6c082 bellard
                 0x00000000);
576 3fc6c082 bellard
    spr_register(env, SPR_IBAT3L, "IBAT3L",
577 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
578 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
579 3fc6c082 bellard
                 0x00000000);
580 3fc6c082 bellard
    spr_register(env, SPR_DBAT0U, "DBAT0U",
581 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
582 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
583 3fc6c082 bellard
                 0x00000000);
584 3fc6c082 bellard
    spr_register(env, SPR_DBAT0L, "DBAT0L",
585 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
586 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
587 3fc6c082 bellard
                 0x00000000);
588 3fc6c082 bellard
    spr_register(env, SPR_DBAT1U, "DBAT1U",
589 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
590 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
591 3fc6c082 bellard
                 0x00000000);
592 3fc6c082 bellard
    spr_register(env, SPR_DBAT1L, "DBAT1L",
593 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
594 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
595 3fc6c082 bellard
                 0x00000000);
596 3fc6c082 bellard
    spr_register(env, SPR_DBAT2U, "DBAT2U",
597 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
598 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
599 3fc6c082 bellard
                 0x00000000);
600 3fc6c082 bellard
    spr_register(env, SPR_DBAT2L, "DBAT2L",
601 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
602 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
603 3fc6c082 bellard
                 0x00000000);
604 3fc6c082 bellard
    spr_register(env, SPR_DBAT3U, "DBAT3U",
605 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
606 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
607 3fc6c082 bellard
                 0x00000000);
608 3fc6c082 bellard
    spr_register(env, SPR_DBAT3L, "DBAT3L",
609 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
610 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
611 3fc6c082 bellard
                 0x00000000);
612 a750fc0b j_mayer
    env->nb_BATs += 4;
613 f2e63a42 j_mayer
#endif
614 3fc6c082 bellard
}
615 3fc6c082 bellard
616 3fc6c082 bellard
/* BATs 4-7 */
617 3fc6c082 bellard
static void gen_high_BATs (CPUPPCState *env)
618 3fc6c082 bellard
{
619 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
620 3fc6c082 bellard
    spr_register(env, SPR_IBAT4U, "IBAT4U",
621 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
622 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
623 3fc6c082 bellard
                 0x00000000);
624 3fc6c082 bellard
    spr_register(env, SPR_IBAT4L, "IBAT4L",
625 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
626 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
627 3fc6c082 bellard
                 0x00000000);
628 3fc6c082 bellard
    spr_register(env, SPR_IBAT5U, "IBAT5U",
629 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
630 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
631 3fc6c082 bellard
                 0x00000000);
632 3fc6c082 bellard
    spr_register(env, SPR_IBAT5L, "IBAT5L",
633 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
634 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
635 3fc6c082 bellard
                 0x00000000);
636 3fc6c082 bellard
    spr_register(env, SPR_IBAT6U, "IBAT6U",
637 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
638 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
639 3fc6c082 bellard
                 0x00000000);
640 3fc6c082 bellard
    spr_register(env, SPR_IBAT6L, "IBAT6L",
641 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
642 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
643 3fc6c082 bellard
                 0x00000000);
644 3fc6c082 bellard
    spr_register(env, SPR_IBAT7U, "IBAT7U",
645 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
646 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
647 3fc6c082 bellard
                 0x00000000);
648 3fc6c082 bellard
    spr_register(env, SPR_IBAT7L, "IBAT7L",
649 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
650 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
651 3fc6c082 bellard
                 0x00000000);
652 3fc6c082 bellard
    spr_register(env, SPR_DBAT4U, "DBAT4U",
653 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
654 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
655 3fc6c082 bellard
                 0x00000000);
656 3fc6c082 bellard
    spr_register(env, SPR_DBAT4L, "DBAT4L",
657 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
658 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
659 3fc6c082 bellard
                 0x00000000);
660 3fc6c082 bellard
    spr_register(env, SPR_DBAT5U, "DBAT5U",
661 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
662 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
663 3fc6c082 bellard
                 0x00000000);
664 3fc6c082 bellard
    spr_register(env, SPR_DBAT5L, "DBAT5L",
665 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
666 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
667 3fc6c082 bellard
                 0x00000000);
668 3fc6c082 bellard
    spr_register(env, SPR_DBAT6U, "DBAT6U",
669 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
670 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
671 3fc6c082 bellard
                 0x00000000);
672 3fc6c082 bellard
    spr_register(env, SPR_DBAT6L, "DBAT6L",
673 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
674 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
675 3fc6c082 bellard
                 0x00000000);
676 3fc6c082 bellard
    spr_register(env, SPR_DBAT7U, "DBAT7U",
677 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
678 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
679 3fc6c082 bellard
                 0x00000000);
680 3fc6c082 bellard
    spr_register(env, SPR_DBAT7L, "DBAT7L",
681 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
682 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
683 3fc6c082 bellard
                 0x00000000);
684 a750fc0b j_mayer
    env->nb_BATs += 4;
685 f2e63a42 j_mayer
#endif
686 3fc6c082 bellard
}
687 3fc6c082 bellard
688 3fc6c082 bellard
/* Generic PowerPC time base */
689 3fc6c082 bellard
static void gen_tbl (CPUPPCState *env)
690 3fc6c082 bellard
{
691 3fc6c082 bellard
    spr_register(env, SPR_VTBL,  "TBL",
692 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
693 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
694 3fc6c082 bellard
                 0x00000000);
695 3fc6c082 bellard
    spr_register(env, SPR_TBL,   "TBL",
696 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
697 3fc6c082 bellard
                 SPR_NOACCESS, &spr_write_tbl,
698 3fc6c082 bellard
                 0x00000000);
699 3fc6c082 bellard
    spr_register(env, SPR_VTBU,  "TBU",
700 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
701 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
702 3fc6c082 bellard
                 0x00000000);
703 3fc6c082 bellard
    spr_register(env, SPR_TBU,   "TBU",
704 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
705 3fc6c082 bellard
                 SPR_NOACCESS, &spr_write_tbu,
706 3fc6c082 bellard
                 0x00000000);
707 3fc6c082 bellard
}
708 3fc6c082 bellard
709 76a66253 j_mayer
/* Softare table search registers */
710 76a66253 j_mayer
static void gen_6xx_7xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
711 76a66253 j_mayer
{
712 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
713 76a66253 j_mayer
    env->nb_tlb = nb_tlbs;
714 76a66253 j_mayer
    env->nb_ways = nb_ways;
715 76a66253 j_mayer
    env->id_tlbs = 1;
716 76a66253 j_mayer
    spr_register(env, SPR_DMISS, "DMISS",
717 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
718 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
719 76a66253 j_mayer
                 0x00000000);
720 76a66253 j_mayer
    spr_register(env, SPR_DCMP, "DCMP",
721 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
722 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
723 76a66253 j_mayer
                 0x00000000);
724 76a66253 j_mayer
    spr_register(env, SPR_HASH1, "HASH1",
725 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
726 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
727 76a66253 j_mayer
                 0x00000000);
728 76a66253 j_mayer
    spr_register(env, SPR_HASH2, "HASH2",
729 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
730 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
731 76a66253 j_mayer
                 0x00000000);
732 76a66253 j_mayer
    spr_register(env, SPR_IMISS, "IMISS",
733 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
734 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
735 76a66253 j_mayer
                 0x00000000);
736 76a66253 j_mayer
    spr_register(env, SPR_ICMP, "ICMP",
737 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
738 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
739 76a66253 j_mayer
                 0x00000000);
740 76a66253 j_mayer
    spr_register(env, SPR_RPA, "RPA",
741 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
742 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
743 76a66253 j_mayer
                 0x00000000);
744 f2e63a42 j_mayer
#endif
745 76a66253 j_mayer
}
746 76a66253 j_mayer
747 76a66253 j_mayer
/* SPR common to MPC755 and G2 */
748 76a66253 j_mayer
static void gen_spr_G2_755 (CPUPPCState *env)
749 76a66253 j_mayer
{
750 76a66253 j_mayer
    /* SGPRs */
751 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
752 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
753 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
754 76a66253 j_mayer
                 0x00000000);
755 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
756 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
757 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
758 76a66253 j_mayer
                 0x00000000);
759 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
760 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
761 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
762 76a66253 j_mayer
                 0x00000000);
763 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
764 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
765 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
766 76a66253 j_mayer
                 0x00000000);
767 76a66253 j_mayer
    /* External access control */
768 76a66253 j_mayer
    /* XXX : not implemented */
769 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
770 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
771 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
772 76a66253 j_mayer
                 0x00000000);
773 76a66253 j_mayer
}
774 76a66253 j_mayer
775 3fc6c082 bellard
/* SPR common to all 7xx PowerPC implementations */
776 3fc6c082 bellard
static void gen_spr_7xx (CPUPPCState *env)
777 3fc6c082 bellard
{
778 3fc6c082 bellard
    /* Breakpoints */
779 3fc6c082 bellard
    /* XXX : not implemented */
780 3fc6c082 bellard
    spr_register(env, SPR_DABR, "DABR",
781 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
782 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
783 3fc6c082 bellard
                 0x00000000);
784 3fc6c082 bellard
    /* XXX : not implemented */
785 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
786 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
787 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
788 3fc6c082 bellard
                 0x00000000);
789 3fc6c082 bellard
    /* Cache management */
790 3fc6c082 bellard
    /* XXX : not implemented */
791 3fc6c082 bellard
    spr_register(env, SPR_ICTC, "ICTC",
792 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
793 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
794 3fc6c082 bellard
                 0x00000000);
795 76a66253 j_mayer
    /* XXX : not implemented */
796 76a66253 j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
797 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
798 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
799 76a66253 j_mayer
                 0x00000000);
800 3fc6c082 bellard
    /* Performance monitors */
801 3fc6c082 bellard
    /* XXX : not implemented */
802 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
803 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
804 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
805 3fc6c082 bellard
                 0x00000000);
806 3fc6c082 bellard
    /* XXX : not implemented */
807 3fc6c082 bellard
    spr_register(env, SPR_MMCR1, "MMCR1",
808 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
809 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
810 3fc6c082 bellard
                 0x00000000);
811 3fc6c082 bellard
    /* XXX : not implemented */
812 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
813 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
814 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
815 3fc6c082 bellard
                 0x00000000);
816 3fc6c082 bellard
    /* XXX : not implemented */
817 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
818 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
819 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
820 3fc6c082 bellard
                 0x00000000);
821 3fc6c082 bellard
    /* XXX : not implemented */
822 3fc6c082 bellard
    spr_register(env, SPR_PMC3, "PMC3",
823 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
824 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
825 3fc6c082 bellard
                 0x00000000);
826 3fc6c082 bellard
    /* XXX : not implemented */
827 3fc6c082 bellard
    spr_register(env, SPR_PMC4, "PMC4",
828 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
829 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
830 3fc6c082 bellard
                 0x00000000);
831 3fc6c082 bellard
    /* XXX : not implemented */
832 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
833 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
834 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
835 3fc6c082 bellard
                 0x00000000);
836 578bb252 j_mayer
    /* XXX : not implemented */
837 3fc6c082 bellard
    spr_register(env, SPR_UMMCR0, "UMMCR0",
838 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
839 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
840 3fc6c082 bellard
                 0x00000000);
841 578bb252 j_mayer
    /* XXX : not implemented */
842 3fc6c082 bellard
    spr_register(env, SPR_UMMCR1, "UMMCR1",
843 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
844 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
845 3fc6c082 bellard
                 0x00000000);
846 578bb252 j_mayer
    /* XXX : not implemented */
847 3fc6c082 bellard
    spr_register(env, SPR_UPMC1, "UPMC1",
848 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
849 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
850 3fc6c082 bellard
                 0x00000000);
851 578bb252 j_mayer
    /* XXX : not implemented */
852 3fc6c082 bellard
    spr_register(env, SPR_UPMC2, "UPMC2",
853 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
854 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
855 3fc6c082 bellard
                 0x00000000);
856 578bb252 j_mayer
    /* XXX : not implemented */
857 3fc6c082 bellard
    spr_register(env, SPR_UPMC3, "UPMC3",
858 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
859 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
860 3fc6c082 bellard
                 0x00000000);
861 578bb252 j_mayer
    /* XXX : not implemented */
862 3fc6c082 bellard
    spr_register(env, SPR_UPMC4, "UPMC4",
863 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
864 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
865 3fc6c082 bellard
                 0x00000000);
866 578bb252 j_mayer
    /* XXX : not implemented */
867 a750fc0b j_mayer
    spr_register(env, SPR_USIAR, "USIAR",
868 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
869 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
870 3fc6c082 bellard
                 0x00000000);
871 a750fc0b j_mayer
    /* External access control */
872 3fc6c082 bellard
    /* XXX : not implemented */
873 a750fc0b j_mayer
    spr_register(env, SPR_EAR, "EAR",
874 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
875 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
876 3fc6c082 bellard
                 0x00000000);
877 a750fc0b j_mayer
}
878 a750fc0b j_mayer
879 a750fc0b j_mayer
static void gen_spr_thrm (CPUPPCState *env)
880 a750fc0b j_mayer
{
881 a750fc0b j_mayer
    /* Thermal management */
882 3fc6c082 bellard
    /* XXX : not implemented */
883 a750fc0b j_mayer
    spr_register(env, SPR_THRM1, "THRM1",
884 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
885 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
886 3fc6c082 bellard
                 0x00000000);
887 3fc6c082 bellard
    /* XXX : not implemented */
888 a750fc0b j_mayer
    spr_register(env, SPR_THRM2, "THRM2",
889 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
890 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
891 3fc6c082 bellard
                 0x00000000);
892 3fc6c082 bellard
    /* XXX : not implemented */
893 a750fc0b j_mayer
    spr_register(env, SPR_THRM3, "THRM3",
894 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
895 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
896 3fc6c082 bellard
                 0x00000000);
897 3fc6c082 bellard
}
898 3fc6c082 bellard
899 3fc6c082 bellard
/* SPR specific to PowerPC 604 implementation */
900 3fc6c082 bellard
static void gen_spr_604 (CPUPPCState *env)
901 3fc6c082 bellard
{
902 3fc6c082 bellard
    /* Processor identification */
903 3fc6c082 bellard
    spr_register(env, SPR_PIR, "PIR",
904 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
905 3fc6c082 bellard
                 &spr_read_generic, &spr_write_pir,
906 3fc6c082 bellard
                 0x00000000);
907 3fc6c082 bellard
    /* Breakpoints */
908 3fc6c082 bellard
    /* XXX : not implemented */
909 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
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_DABR, "DABR",
915 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
916 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
917 3fc6c082 bellard
                 0x00000000);
918 3fc6c082 bellard
    /* Performance counters */
919 3fc6c082 bellard
    /* XXX : not implemented */
920 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
921 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
922 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
923 3fc6c082 bellard
                 0x00000000);
924 3fc6c082 bellard
    /* XXX : not implemented */
925 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
926 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
927 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
928 3fc6c082 bellard
                 0x00000000);
929 3fc6c082 bellard
    /* XXX : not implemented */
930 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
931 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
932 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
933 3fc6c082 bellard
                 0x00000000);
934 3fc6c082 bellard
    /* XXX : not implemented */
935 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
936 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
937 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
938 3fc6c082 bellard
                 0x00000000);
939 3fc6c082 bellard
    /* XXX : not implemented */
940 3fc6c082 bellard
    spr_register(env, SPR_SDA, "SDA",
941 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
942 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
943 3fc6c082 bellard
                 0x00000000);
944 3fc6c082 bellard
    /* External access control */
945 3fc6c082 bellard
    /* XXX : not implemented */
946 3fc6c082 bellard
    spr_register(env, SPR_EAR, "EAR",
947 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
948 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
949 3fc6c082 bellard
                 0x00000000);
950 3fc6c082 bellard
}
951 3fc6c082 bellard
952 76a66253 j_mayer
/* SPR specific to PowerPC 603 implementation */
953 76a66253 j_mayer
static void gen_spr_603 (CPUPPCState *env)
954 3fc6c082 bellard
{
955 76a66253 j_mayer
    /* External access control */
956 76a66253 j_mayer
    /* XXX : not implemented */
957 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
958 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
959 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
960 76a66253 j_mayer
                 0x00000000);
961 3fc6c082 bellard
}
962 3fc6c082 bellard
963 76a66253 j_mayer
/* SPR specific to PowerPC G2 implementation */
964 76a66253 j_mayer
static void gen_spr_G2 (CPUPPCState *env)
965 3fc6c082 bellard
{
966 76a66253 j_mayer
    /* Memory base address */
967 76a66253 j_mayer
    /* MBAR */
968 578bb252 j_mayer
    /* XXX : not implemented */
969 76a66253 j_mayer
    spr_register(env, SPR_MBAR, "MBAR",
970 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
971 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
972 76a66253 j_mayer
                 0x00000000);
973 76a66253 j_mayer
    /* Exception processing */
974 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
975 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
976 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
977 76a66253 j_mayer
                 0x00000000);
978 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
979 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
980 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
981 76a66253 j_mayer
                 0x00000000);
982 76a66253 j_mayer
    /* Breakpoints */
983 76a66253 j_mayer
    /* XXX : not implemented */
984 76a66253 j_mayer
    spr_register(env, SPR_DABR, "DABR",
985 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
986 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
987 76a66253 j_mayer
                 0x00000000);
988 76a66253 j_mayer
    /* XXX : not implemented */
989 76a66253 j_mayer
    spr_register(env, SPR_DABR2, "DABR2",
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
    /* XXX : not implemented */
994 76a66253 j_mayer
    spr_register(env, SPR_IABR, "IABR",
995 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
996 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
997 76a66253 j_mayer
                 0x00000000);
998 76a66253 j_mayer
    /* XXX : not implemented */
999 76a66253 j_mayer
    spr_register(env, SPR_IABR2, "IABR2",
1000 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1001 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1002 76a66253 j_mayer
                 0x00000000);
1003 76a66253 j_mayer
    /* XXX : not implemented */
1004 76a66253 j_mayer
    spr_register(env, SPR_IBCR, "IBCR",
1005 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1006 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1007 76a66253 j_mayer
                 0x00000000);
1008 76a66253 j_mayer
    /* XXX : not implemented */
1009 76a66253 j_mayer
    spr_register(env, SPR_DBCR, "DBCR",
1010 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1011 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1012 76a66253 j_mayer
                 0x00000000);
1013 76a66253 j_mayer
}
1014 76a66253 j_mayer
1015 76a66253 j_mayer
/* SPR specific to PowerPC 602 implementation */
1016 76a66253 j_mayer
static void gen_spr_602 (CPUPPCState *env)
1017 76a66253 j_mayer
{
1018 76a66253 j_mayer
    /* ESA registers */
1019 76a66253 j_mayer
    /* XXX : not implemented */
1020 76a66253 j_mayer
    spr_register(env, SPR_SER, "SER",
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
    /* XXX : not implemented */
1025 76a66253 j_mayer
    spr_register(env, SPR_SEBR, "SEBR",
1026 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1027 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1028 76a66253 j_mayer
                 0x00000000);
1029 76a66253 j_mayer
    /* XXX : not implemented */
1030 a750fc0b j_mayer
    spr_register(env, SPR_ESASRR, "ESASRR",
1031 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1032 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1033 76a66253 j_mayer
                 0x00000000);
1034 76a66253 j_mayer
    /* Floating point status */
1035 76a66253 j_mayer
    /* XXX : not implemented */
1036 76a66253 j_mayer
    spr_register(env, SPR_SP, "SP",
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 76a66253 j_mayer
    spr_register(env, SPR_LT, "LT",
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
    /* Watchdog timer */
1046 76a66253 j_mayer
    /* XXX : not implemented */
1047 76a66253 j_mayer
    spr_register(env, SPR_TCR, "TCR",
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
    /* Interrupt base */
1052 76a66253 j_mayer
    spr_register(env, SPR_IBR, "IBR",
1053 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1054 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1055 76a66253 j_mayer
                 0x00000000);
1056 a750fc0b j_mayer
    /* XXX : not implemented */
1057 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
1058 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1059 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1060 a750fc0b j_mayer
                 0x00000000);
1061 76a66253 j_mayer
}
1062 76a66253 j_mayer
1063 76a66253 j_mayer
/* SPR specific to PowerPC 601 implementation */
1064 76a66253 j_mayer
static void gen_spr_601 (CPUPPCState *env)
1065 76a66253 j_mayer
{
1066 76a66253 j_mayer
    /* Multiplication/division register */
1067 76a66253 j_mayer
    /* MQ */
1068 76a66253 j_mayer
    spr_register(env, SPR_MQ, "MQ",
1069 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1070 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1071 76a66253 j_mayer
                 0x00000000);
1072 76a66253 j_mayer
    /* RTC registers */
1073 76a66253 j_mayer
    spr_register(env, SPR_601_RTCU, "RTCU",
1074 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1075 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcu,
1076 76a66253 j_mayer
                 0x00000000);
1077 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCU, "RTCU",
1078 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1079 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1080 76a66253 j_mayer
                 0x00000000);
1081 76a66253 j_mayer
    spr_register(env, SPR_601_RTCL, "RTCL",
1082 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1083 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcl,
1084 76a66253 j_mayer
                 0x00000000);
1085 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCL, "RTCL",
1086 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1087 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1088 76a66253 j_mayer
                 0x00000000);
1089 76a66253 j_mayer
    /* Timer */
1090 76a66253 j_mayer
#if 0 /* ? */
1091 76a66253 j_mayer
    spr_register(env, SPR_601_UDECR, "UDECR",
1092 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1093 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1094 76a66253 j_mayer
                 0x00000000);
1095 76a66253 j_mayer
#endif
1096 76a66253 j_mayer
    /* External access control */
1097 76a66253 j_mayer
    /* XXX : not implemented */
1098 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
1099 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1100 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1101 76a66253 j_mayer
                 0x00000000);
1102 76a66253 j_mayer
    /* Memory management */
1103 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1104 76a66253 j_mayer
    spr_register(env, SPR_IBAT0U, "IBAT0U",
1105 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1106 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1107 76a66253 j_mayer
                 0x00000000);
1108 76a66253 j_mayer
    spr_register(env, SPR_IBAT0L, "IBAT0L",
1109 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1110 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1111 76a66253 j_mayer
                 0x00000000);
1112 76a66253 j_mayer
    spr_register(env, SPR_IBAT1U, "IBAT1U",
1113 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1114 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1115 76a66253 j_mayer
                 0x00000000);
1116 76a66253 j_mayer
    spr_register(env, SPR_IBAT1L, "IBAT1L",
1117 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1118 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1119 76a66253 j_mayer
                 0x00000000);
1120 76a66253 j_mayer
    spr_register(env, SPR_IBAT2U, "IBAT2U",
1121 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1122 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1123 76a66253 j_mayer
                 0x00000000);
1124 76a66253 j_mayer
    spr_register(env, SPR_IBAT2L, "IBAT2L",
1125 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1126 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1127 76a66253 j_mayer
                 0x00000000);
1128 76a66253 j_mayer
    spr_register(env, SPR_IBAT3U, "IBAT3U",
1129 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1130 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1131 76a66253 j_mayer
                 0x00000000);
1132 76a66253 j_mayer
    spr_register(env, SPR_IBAT3L, "IBAT3L",
1133 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1134 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1135 76a66253 j_mayer
                 0x00000000);
1136 a750fc0b j_mayer
    env->nb_BATs = 4;
1137 f2e63a42 j_mayer
#endif
1138 a750fc0b j_mayer
}
1139 a750fc0b j_mayer
1140 a750fc0b j_mayer
static void gen_spr_74xx (CPUPPCState *env)
1141 a750fc0b j_mayer
{
1142 a750fc0b j_mayer
    /* Processor identification */
1143 a750fc0b j_mayer
    spr_register(env, SPR_PIR, "PIR",
1144 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1145 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_pir,
1146 a750fc0b j_mayer
                 0x00000000);
1147 a750fc0b j_mayer
    /* XXX : not implemented */
1148 a750fc0b j_mayer
    spr_register(env, SPR_MMCR2, "MMCR2",
1149 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1150 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1151 a750fc0b j_mayer
                 0x00000000);
1152 578bb252 j_mayer
    /* XXX : not implemented */
1153 a750fc0b j_mayer
    spr_register(env, SPR_UMMCR2, "UMMCR2",
1154 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1155 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1156 a750fc0b j_mayer
                 0x00000000);
1157 a750fc0b j_mayer
    /* XXX: not implemented */
1158 a750fc0b j_mayer
    spr_register(env, SPR_BAMR, "BAMR",
1159 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1160 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1161 a750fc0b j_mayer
                 0x00000000);
1162 578bb252 j_mayer
    /* XXX : not implemented */
1163 a750fc0b j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
1164 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1165 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1166 a750fc0b j_mayer
                 0x00000000);
1167 578bb252 j_mayer
    /* XXX : not implemented */
1168 a750fc0b j_mayer
    spr_register(env, SPR_MSSCR0, "MSSCR0",
1169 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1170 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1171 a750fc0b j_mayer
                 0x00000000);
1172 a750fc0b j_mayer
    /* Hardware implementation registers */
1173 a750fc0b j_mayer
    /* XXX : not implemented */
1174 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
1175 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1176 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1177 a750fc0b j_mayer
                 0x00000000);
1178 a750fc0b j_mayer
    /* XXX : not implemented */
1179 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
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
    /* Altivec */
1184 a750fc0b j_mayer
    spr_register(env, SPR_VRSAVE, "VRSAVE",
1185 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1186 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1187 a750fc0b j_mayer
                 0x00000000);
1188 a750fc0b j_mayer
}
1189 a750fc0b j_mayer
1190 a750fc0b j_mayer
static void gen_l3_ctrl (CPUPPCState *env)
1191 a750fc0b j_mayer
{
1192 a750fc0b j_mayer
    /* L3CR */
1193 a750fc0b j_mayer
    /* XXX : not implemented */
1194 a750fc0b j_mayer
    spr_register(env, SPR_L3CR, "L3CR",
1195 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1196 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1197 a750fc0b j_mayer
                 0x00000000);
1198 a750fc0b j_mayer
    /* L3ITCR0 */
1199 578bb252 j_mayer
    /* XXX : not implemented */
1200 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR0, "L3ITCR0",
1201 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1202 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1203 a750fc0b j_mayer
                 0x00000000);
1204 a750fc0b j_mayer
    /* L3ITCR1 */
1205 578bb252 j_mayer
    /* XXX : not implemented */
1206 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
1207 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1208 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1209 a750fc0b j_mayer
                 0x00000000);
1210 a750fc0b j_mayer
    /* L3ITCR2 */
1211 578bb252 j_mayer
    /* XXX : not implemented */
1212 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
1213 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1214 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1215 a750fc0b j_mayer
                 0x00000000);
1216 a750fc0b j_mayer
    /* L3ITCR3 */
1217 578bb252 j_mayer
    /* XXX : not implemented */
1218 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
1219 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1220 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1221 a750fc0b j_mayer
                 0x00000000);
1222 a750fc0b j_mayer
    /* L3OHCR */
1223 578bb252 j_mayer
    /* XXX : not implemented */
1224 a750fc0b j_mayer
    spr_register(env, SPR_L3OHCR, "L3OHCR",
1225 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1226 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1227 a750fc0b j_mayer
                 0x00000000);
1228 a750fc0b j_mayer
    /* L3PM */
1229 578bb252 j_mayer
    /* XXX : not implemented */
1230 a750fc0b j_mayer
    spr_register(env, SPR_L3PM, "L3PM",
1231 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1232 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1233 a750fc0b j_mayer
                 0x00000000);
1234 a750fc0b j_mayer
}
1235 a750fc0b j_mayer
1236 578bb252 j_mayer
static void gen_74xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
1237 a750fc0b j_mayer
{
1238 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1239 578bb252 j_mayer
    env->nb_tlb = nb_tlbs;
1240 578bb252 j_mayer
    env->nb_ways = nb_ways;
1241 578bb252 j_mayer
    env->id_tlbs = 1;
1242 578bb252 j_mayer
    /* XXX : not implemented */
1243 a750fc0b j_mayer
    spr_register(env, SPR_PTEHI, "PTEHI",
1244 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1245 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1246 a750fc0b j_mayer
                 0x00000000);
1247 578bb252 j_mayer
    /* XXX : not implemented */
1248 a750fc0b j_mayer
    spr_register(env, SPR_PTELO, "PTELO",
1249 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1250 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1251 a750fc0b j_mayer
                 0x00000000);
1252 578bb252 j_mayer
    /* XXX : not implemented */
1253 a750fc0b j_mayer
    spr_register(env, SPR_TLBMISS, "TLBMISS",
1254 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1255 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1256 a750fc0b j_mayer
                 0x00000000);
1257 f2e63a42 j_mayer
#endif
1258 76a66253 j_mayer
}
1259 76a66253 j_mayer
1260 80d11f44 j_mayer
static void gen_spr_usprgh (CPUPPCState *env)
1261 76a66253 j_mayer
{
1262 80d11f44 j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
1263 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1264 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1265 80d11f44 j_mayer
                 0x00000000);
1266 80d11f44 j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
1267 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1268 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1269 80d11f44 j_mayer
                 0x00000000);
1270 80d11f44 j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
1271 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1272 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1273 80d11f44 j_mayer
                 0x00000000);
1274 80d11f44 j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
1275 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1276 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1277 76a66253 j_mayer
                 0x00000000);
1278 80d11f44 j_mayer
}
1279 80d11f44 j_mayer
1280 80d11f44 j_mayer
/* PowerPC BookE SPR */
1281 80d11f44 j_mayer
static void gen_spr_BookE (CPUPPCState *env, uint64_t ivor_mask)
1282 80d11f44 j_mayer
{
1283 80d11f44 j_mayer
    const unsigned char *ivor_names[64] = {
1284 80d11f44 j_mayer
        "IVOR0",  "IVOR1",  "IVOR2",  "IVOR3",
1285 80d11f44 j_mayer
        "IVOR4",  "IVOR5",  "IVOR6",  "IVOR7",
1286 80d11f44 j_mayer
        "IVOR8",  "IVOR9",  "IVOR10", "IVOR11",
1287 80d11f44 j_mayer
        "IVOR12", "IVOR13", "IVOR14", "IVOR15",
1288 80d11f44 j_mayer
        "IVOR16", "IVOR17", "IVOR18", "IVOR19",
1289 80d11f44 j_mayer
        "IVOR20", "IVOR21", "IVOR22", "IVOR23",
1290 80d11f44 j_mayer
        "IVOR24", "IVOR25", "IVOR26", "IVOR27",
1291 80d11f44 j_mayer
        "IVOR28", "IVOR29", "IVOR30", "IVOR31",
1292 80d11f44 j_mayer
        "IVOR32", "IVOR33", "IVOR34", "IVOR35",
1293 80d11f44 j_mayer
        "IVOR36", "IVOR37", "IVOR38", "IVOR39",
1294 80d11f44 j_mayer
        "IVOR40", "IVOR41", "IVOR42", "IVOR43",
1295 80d11f44 j_mayer
        "IVOR44", "IVOR45", "IVOR46", "IVOR47",
1296 80d11f44 j_mayer
        "IVOR48", "IVOR49", "IVOR50", "IVOR51",
1297 80d11f44 j_mayer
        "IVOR52", "IVOR53", "IVOR54", "IVOR55",
1298 80d11f44 j_mayer
        "IVOR56", "IVOR57", "IVOR58", "IVOR59",
1299 80d11f44 j_mayer
        "IVOR60", "IVOR61", "IVOR62", "IVOR63",
1300 80d11f44 j_mayer
    };
1301 80d11f44 j_mayer
#define SPR_BOOKE_IVORxx (-1)
1302 80d11f44 j_mayer
    int ivor_sprn[64] = {
1303 80d11f44 j_mayer
        SPR_BOOKE_IVOR0,  SPR_BOOKE_IVOR1,  SPR_BOOKE_IVOR2,  SPR_BOOKE_IVOR3,
1304 80d11f44 j_mayer
        SPR_BOOKE_IVOR4,  SPR_BOOKE_IVOR5,  SPR_BOOKE_IVOR6,  SPR_BOOKE_IVOR7,
1305 80d11f44 j_mayer
        SPR_BOOKE_IVOR8,  SPR_BOOKE_IVOR9,  SPR_BOOKE_IVOR10, SPR_BOOKE_IVOR11,
1306 80d11f44 j_mayer
        SPR_BOOKE_IVOR12, SPR_BOOKE_IVOR13, SPR_BOOKE_IVOR14, SPR_BOOKE_IVOR15,
1307 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1308 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1309 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1310 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1311 80d11f44 j_mayer
        SPR_BOOKE_IVOR32, SPR_BOOKE_IVOR33, SPR_BOOKE_IVOR34, SPR_BOOKE_IVOR35,
1312 80d11f44 j_mayer
        SPR_BOOKE_IVOR36, SPR_BOOKE_IVOR37, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1313 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1314 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1315 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1316 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1317 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1318 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1319 80d11f44 j_mayer
    };
1320 80d11f44 j_mayer
    int i;
1321 80d11f44 j_mayer
1322 76a66253 j_mayer
    /* Interrupt processing */
1323 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
1324 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1325 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1326 76a66253 j_mayer
                 0x00000000);
1327 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
1328 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1329 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1330 363be49c j_mayer
                 0x00000000);
1331 76a66253 j_mayer
    /* Debug */
1332 76a66253 j_mayer
    /* XXX : not implemented */
1333 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC1, "IAC1",
1334 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1335 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1336 76a66253 j_mayer
                 0x00000000);
1337 76a66253 j_mayer
    /* XXX : not implemented */
1338 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC2, "IAC2",
1339 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1340 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1341 76a66253 j_mayer
                 0x00000000);
1342 76a66253 j_mayer
    /* XXX : not implemented */
1343 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC1, "DAC1",
1344 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1345 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1346 76a66253 j_mayer
                 0x00000000);
1347 76a66253 j_mayer
    /* XXX : not implemented */
1348 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC2, "DAC2",
1349 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1350 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1351 76a66253 j_mayer
                 0x00000000);
1352 76a66253 j_mayer
    /* XXX : not implemented */
1353 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR0, "DBCR0",
1354 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1355 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1356 76a66253 j_mayer
                 0x00000000);
1357 76a66253 j_mayer
    /* XXX : not implemented */
1358 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR1, "DBCR1",
1359 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1360 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1361 76a66253 j_mayer
                 0x00000000);
1362 76a66253 j_mayer
    /* XXX : not implemented */
1363 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR2, "DBCR2",
1364 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1365 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1366 76a66253 j_mayer
                 0x00000000);
1367 76a66253 j_mayer
    /* XXX : not implemented */
1368 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBSR, "DBSR",
1369 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1370 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1371 76a66253 j_mayer
                 0x00000000);
1372 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DEAR, "DEAR",
1373 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1374 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1375 76a66253 j_mayer
                 0x00000000);
1376 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_ESR, "ESR",
1377 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1378 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1379 76a66253 j_mayer
                 0x00000000);
1380 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVPR, "IVPR",
1381 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1382 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1383 363be49c j_mayer
                 0x00000000);
1384 363be49c j_mayer
    /* Exception vectors */
1385 80d11f44 j_mayer
    for (i = 0; i < 64; i++) {
1386 80d11f44 j_mayer
        if (ivor_mask & (1ULL << i)) {
1387 80d11f44 j_mayer
            if (ivor_sprn[i] == SPR_BOOKE_IVORxx) {
1388 80d11f44 j_mayer
                fprintf(stderr, "ERROR: IVOR %d SPR is not defined\n", i);
1389 80d11f44 j_mayer
                exit(1);
1390 80d11f44 j_mayer
            }
1391 80d11f44 j_mayer
            spr_register(env, ivor_sprn[i], ivor_names[i],
1392 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
1393 80d11f44 j_mayer
                         &spr_read_generic, &spr_write_excp_vector,
1394 80d11f44 j_mayer
                         0x00000000);
1395 80d11f44 j_mayer
        }
1396 80d11f44 j_mayer
    }
1397 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_PID, "PID",
1398 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1399 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1400 76a66253 j_mayer
                 0x00000000);
1401 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TCR, "TCR",
1402 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1403 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1404 76a66253 j_mayer
                 0x00000000);
1405 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TSR, "TSR",
1406 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1407 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1408 76a66253 j_mayer
                 0x00000000);
1409 76a66253 j_mayer
    /* Timer */
1410 76a66253 j_mayer
    spr_register(env, SPR_DECR, "DECR",
1411 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1412 76a66253 j_mayer
                 &spr_read_decr, &spr_write_decr,
1413 76a66253 j_mayer
                 0x00000000);
1414 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DECAR, "DECAR",
1415 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1416 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_generic,
1417 76a66253 j_mayer
                 0x00000000);
1418 76a66253 j_mayer
    /* SPRGs */
1419 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1420 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1421 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1422 76a66253 j_mayer
                 0x00000000);
1423 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1424 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1425 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1426 76a66253 j_mayer
                 0x00000000);
1427 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1428 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1429 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1430 76a66253 j_mayer
                 0x00000000);
1431 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1432 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1433 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1434 76a66253 j_mayer
                 0x00000000);
1435 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1436 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1437 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1438 76a66253 j_mayer
                 0x00000000);
1439 76a66253 j_mayer
}
1440 76a66253 j_mayer
1441 363be49c j_mayer
/* FSL storage control registers */
1442 80d11f44 j_mayer
static void gen_spr_BookE_FSL (CPUPPCState *env, uint32_t mas_mask)
1443 363be49c j_mayer
{
1444 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1445 80d11f44 j_mayer
    const unsigned char *mas_names[8] = {
1446 80d11f44 j_mayer
        "MAS0", "MAS1", "MAS2", "MAS3", "MAS4", "MAS5", "MAS6", "MAS7",
1447 80d11f44 j_mayer
    };
1448 80d11f44 j_mayer
    int mas_sprn[8] = {
1449 80d11f44 j_mayer
        SPR_BOOKE_MAS0, SPR_BOOKE_MAS1, SPR_BOOKE_MAS2, SPR_BOOKE_MAS3,
1450 80d11f44 j_mayer
        SPR_BOOKE_MAS4, SPR_BOOKE_MAS5, SPR_BOOKE_MAS6, SPR_BOOKE_MAS7,
1451 80d11f44 j_mayer
    };
1452 80d11f44 j_mayer
    int i;
1453 80d11f44 j_mayer
1454 363be49c j_mayer
    /* TLB assist registers */
1455 578bb252 j_mayer
    /* XXX : not implemented */
1456 80d11f44 j_mayer
    for (i = 0; i < 8; i++) {
1457 80d11f44 j_mayer
        if (mas_mask & (1 << i)) {
1458 80d11f44 j_mayer
            spr_register(env, mas_sprn[i], mas_names[i],
1459 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
1460 80d11f44 j_mayer
                         &spr_read_generic, &spr_write_generic,
1461 80d11f44 j_mayer
                         0x00000000);
1462 80d11f44 j_mayer
        }
1463 80d11f44 j_mayer
    }
1464 363be49c j_mayer
    if (env->nb_pids > 1) {
1465 578bb252 j_mayer
        /* XXX : not implemented */
1466 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID1, "PID1",
1467 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1468 363be49c j_mayer
                     &spr_read_generic, &spr_write_generic,
1469 363be49c j_mayer
                     0x00000000);
1470 363be49c j_mayer
    }
1471 363be49c j_mayer
    if (env->nb_pids > 2) {
1472 578bb252 j_mayer
        /* XXX : not implemented */
1473 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID2, "PID2",
1474 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1475 363be49c j_mayer
                     &spr_read_generic, &spr_write_generic,
1476 363be49c j_mayer
                     0x00000000);
1477 363be49c j_mayer
    }
1478 578bb252 j_mayer
    /* XXX : not implemented */
1479 65f9ee8d j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
1480 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1481 363be49c j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1482 363be49c j_mayer
                 0x00000000); /* TOFIX */
1483 578bb252 j_mayer
    /* XXX : not implemented */
1484 65f9ee8d j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
1485 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1486 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1487 363be49c j_mayer
                 0x00000000); /* TOFIX */
1488 363be49c j_mayer
    switch (env->nb_ways) {
1489 363be49c j_mayer
    case 4:
1490 578bb252 j_mayer
        /* XXX : not implemented */
1491 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB3CFG, "TLB3CFG",
1492 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1493 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1494 363be49c j_mayer
                     0x00000000); /* TOFIX */
1495 363be49c j_mayer
        /* Fallthru */
1496 363be49c j_mayer
    case 3:
1497 578bb252 j_mayer
        /* XXX : not implemented */
1498 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB2CFG, "TLB2CFG",
1499 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1500 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1501 363be49c j_mayer
                     0x00000000); /* TOFIX */
1502 363be49c j_mayer
        /* Fallthru */
1503 363be49c j_mayer
    case 2:
1504 578bb252 j_mayer
        /* XXX : not implemented */
1505 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
1506 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1507 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1508 363be49c j_mayer
                     0x00000000); /* TOFIX */
1509 363be49c j_mayer
        /* Fallthru */
1510 363be49c j_mayer
    case 1:
1511 578bb252 j_mayer
        /* XXX : not implemented */
1512 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
1513 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1514 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1515 363be49c j_mayer
                     0x00000000); /* TOFIX */
1516 363be49c j_mayer
        /* Fallthru */
1517 363be49c j_mayer
    case 0:
1518 363be49c j_mayer
    default:
1519 363be49c j_mayer
        break;
1520 363be49c j_mayer
    }
1521 f2e63a42 j_mayer
#endif
1522 363be49c j_mayer
}
1523 363be49c j_mayer
1524 76a66253 j_mayer
/* SPR specific to PowerPC 440 implementation */
1525 76a66253 j_mayer
static void gen_spr_440 (CPUPPCState *env)
1526 76a66253 j_mayer
{
1527 76a66253 j_mayer
    /* Cache control */
1528 76a66253 j_mayer
    /* XXX : not implemented */
1529 76a66253 j_mayer
    spr_register(env, SPR_440_DNV0, "DNV0",
1530 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1531 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1532 76a66253 j_mayer
                 0x00000000);
1533 76a66253 j_mayer
    /* XXX : not implemented */
1534 76a66253 j_mayer
    spr_register(env, SPR_440_DNV1, "DNV1",
1535 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1536 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1537 76a66253 j_mayer
                 0x00000000);
1538 76a66253 j_mayer
    /* XXX : not implemented */
1539 76a66253 j_mayer
    spr_register(env, SPR_440_DNV2, "DNV2",
1540 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1541 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1542 76a66253 j_mayer
                 0x00000000);
1543 76a66253 j_mayer
    /* XXX : not implemented */
1544 76a66253 j_mayer
    spr_register(env, SPR_440_DNV3, "DNV3",
1545 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1546 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1547 76a66253 j_mayer
                 0x00000000);
1548 76a66253 j_mayer
    /* XXX : not implemented */
1549 2662a059 j_mayer
    spr_register(env, SPR_440_DTV0, "DTV0",
1550 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1551 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1552 76a66253 j_mayer
                 0x00000000);
1553 76a66253 j_mayer
    /* XXX : not implemented */
1554 2662a059 j_mayer
    spr_register(env, SPR_440_DTV1, "DTV1",
1555 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1556 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1557 76a66253 j_mayer
                 0x00000000);
1558 76a66253 j_mayer
    /* XXX : not implemented */
1559 2662a059 j_mayer
    spr_register(env, SPR_440_DTV2, "DTV2",
1560 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1561 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1562 76a66253 j_mayer
                 0x00000000);
1563 76a66253 j_mayer
    /* XXX : not implemented */
1564 2662a059 j_mayer
    spr_register(env, SPR_440_DTV3, "DTV3",
1565 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1566 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1567 76a66253 j_mayer
                 0x00000000);
1568 76a66253 j_mayer
    /* XXX : not implemented */
1569 76a66253 j_mayer
    spr_register(env, SPR_440_DVLIM, "DVLIM",
1570 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1571 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1572 76a66253 j_mayer
                 0x00000000);
1573 76a66253 j_mayer
    /* XXX : not implemented */
1574 76a66253 j_mayer
    spr_register(env, SPR_440_INV0, "INV0",
1575 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1576 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1577 76a66253 j_mayer
                 0x00000000);
1578 76a66253 j_mayer
    /* XXX : not implemented */
1579 76a66253 j_mayer
    spr_register(env, SPR_440_INV1, "INV1",
1580 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1581 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1582 76a66253 j_mayer
                 0x00000000);
1583 76a66253 j_mayer
    /* XXX : not implemented */
1584 76a66253 j_mayer
    spr_register(env, SPR_440_INV2, "INV2",
1585 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1586 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1587 76a66253 j_mayer
                 0x00000000);
1588 76a66253 j_mayer
    /* XXX : not implemented */
1589 76a66253 j_mayer
    spr_register(env, SPR_440_INV3, "INV3",
1590 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1591 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1592 76a66253 j_mayer
                 0x00000000);
1593 76a66253 j_mayer
    /* XXX : not implemented */
1594 2662a059 j_mayer
    spr_register(env, SPR_440_ITV0, "ITV0",
1595 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1596 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1597 76a66253 j_mayer
                 0x00000000);
1598 76a66253 j_mayer
    /* XXX : not implemented */
1599 2662a059 j_mayer
    spr_register(env, SPR_440_ITV1, "ITV1",
1600 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1601 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1602 76a66253 j_mayer
                 0x00000000);
1603 76a66253 j_mayer
    /* XXX : not implemented */
1604 2662a059 j_mayer
    spr_register(env, SPR_440_ITV2, "ITV2",
1605 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1606 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1607 76a66253 j_mayer
                 0x00000000);
1608 76a66253 j_mayer
    /* XXX : not implemented */
1609 2662a059 j_mayer
    spr_register(env, SPR_440_ITV3, "ITV3",
1610 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1611 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1612 76a66253 j_mayer
                 0x00000000);
1613 76a66253 j_mayer
    /* XXX : not implemented */
1614 76a66253 j_mayer
    spr_register(env, SPR_440_IVLIM, "IVLIM",
1615 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1616 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1617 76a66253 j_mayer
                 0x00000000);
1618 76a66253 j_mayer
    /* Cache debug */
1619 76a66253 j_mayer
    /* XXX : not implemented */
1620 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRH, "DCDBTRH",
1621 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1622 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1623 76a66253 j_mayer
                 0x00000000);
1624 76a66253 j_mayer
    /* XXX : not implemented */
1625 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRL, "DCDBTRL",
1626 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1627 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1628 76a66253 j_mayer
                 0x00000000);
1629 76a66253 j_mayer
    /* XXX : not implemented */
1630 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1631 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1632 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1633 76a66253 j_mayer
                 0x00000000);
1634 76a66253 j_mayer
    /* XXX : not implemented */
1635 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRH, "ICDBTRH",
1636 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1637 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1638 76a66253 j_mayer
                 0x00000000);
1639 76a66253 j_mayer
    /* XXX : not implemented */
1640 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRL, "ICDBTRL",
1641 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1642 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1643 76a66253 j_mayer
                 0x00000000);
1644 76a66253 j_mayer
    /* XXX : not implemented */
1645 76a66253 j_mayer
    spr_register(env, SPR_440_DBDR, "DBDR",
1646 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1647 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1648 76a66253 j_mayer
                 0x00000000);
1649 76a66253 j_mayer
    /* Processor control */
1650 76a66253 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1651 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1652 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1653 76a66253 j_mayer
                 0x00000000);
1654 76a66253 j_mayer
    spr_register(env, SPR_440_RSTCFG, "RSTCFG",
1655 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1656 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1657 76a66253 j_mayer
                 0x00000000);
1658 76a66253 j_mayer
    /* Storage control */
1659 76a66253 j_mayer
    spr_register(env, SPR_440_MMUCR, "MMUCR",
1660 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1661 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1662 76a66253 j_mayer
                 0x00000000);
1663 76a66253 j_mayer
}
1664 76a66253 j_mayer
1665 76a66253 j_mayer
/* SPR shared between PowerPC 40x implementations */
1666 76a66253 j_mayer
static void gen_spr_40x (CPUPPCState *env)
1667 76a66253 j_mayer
{
1668 76a66253 j_mayer
    /* Cache */
1669 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1670 76a66253 j_mayer
    spr_register(env, SPR_40x_DCCR, "DCCR",
1671 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1672 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1673 76a66253 j_mayer
                 0x00000000);
1674 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1675 76a66253 j_mayer
    spr_register(env, SPR_40x_ICCR, "ICCR",
1676 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1677 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1678 76a66253 j_mayer
                 0x00000000);
1679 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1680 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1681 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1682 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1683 76a66253 j_mayer
                 0x00000000);
1684 76a66253 j_mayer
    /* Exception */
1685 76a66253 j_mayer
    spr_register(env, SPR_40x_DEAR, "DEAR",
1686 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1687 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1688 76a66253 j_mayer
                 0x00000000);
1689 76a66253 j_mayer
    spr_register(env, SPR_40x_ESR, "ESR",
1690 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1691 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1692 76a66253 j_mayer
                 0x00000000);
1693 76a66253 j_mayer
    spr_register(env, SPR_40x_EVPR, "EVPR",
1694 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1695 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1696 76a66253 j_mayer
                 0x00000000);
1697 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR2, "SRR2",
1698 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1699 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1700 76a66253 j_mayer
                 0x00000000);
1701 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR3, "SRR3",
1702 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1703 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1704 76a66253 j_mayer
                 0x00000000);
1705 76a66253 j_mayer
    /* Timers */
1706 76a66253 j_mayer
    spr_register(env, SPR_40x_PIT, "PIT",
1707 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1708 76a66253 j_mayer
                 &spr_read_40x_pit, &spr_write_40x_pit,
1709 76a66253 j_mayer
                 0x00000000);
1710 76a66253 j_mayer
    spr_register(env, SPR_40x_TCR, "TCR",
1711 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1712 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1713 76a66253 j_mayer
                 0x00000000);
1714 76a66253 j_mayer
    spr_register(env, SPR_40x_TSR, "TSR",
1715 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1716 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1717 76a66253 j_mayer
                 0x00000000);
1718 2662a059 j_mayer
}
1719 2662a059 j_mayer
1720 2662a059 j_mayer
/* SPR specific to PowerPC 405 implementation */
1721 2662a059 j_mayer
static void gen_spr_405 (CPUPPCState *env)
1722 2662a059 j_mayer
{
1723 2662a059 j_mayer
    /* MMU */
1724 2662a059 j_mayer
    spr_register(env, SPR_40x_PID, "PID",
1725 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1726 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1727 76a66253 j_mayer
                 0x00000000);
1728 2662a059 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1729 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1730 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1731 2662a059 j_mayer
                 0x00700000);
1732 2662a059 j_mayer
    /* Debug interface */
1733 76a66253 j_mayer
    /* XXX : not implemented */
1734 76a66253 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1735 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1736 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1737 76a66253 j_mayer
                 0x00000000);
1738 76a66253 j_mayer
    /* XXX : not implemented */
1739 2662a059 j_mayer
    spr_register(env, SPR_405_DBCR1, "DBCR1",
1740 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1741 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1742 2662a059 j_mayer
                 0x00000000);
1743 2662a059 j_mayer
    /* XXX : not implemented */
1744 76a66253 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1745 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1746 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1747 8ecc7913 j_mayer
                 /* Last reset was system reset */
1748 76a66253 j_mayer
                 0x00000300);
1749 76a66253 j_mayer
    /* XXX : not implemented */
1750 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
1751 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1752 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1753 76a66253 j_mayer
                 0x00000000);
1754 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
1755 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1756 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1757 76a66253 j_mayer
                 0x00000000);
1758 2662a059 j_mayer
    /* XXX : not implemented */
1759 2662a059 j_mayer
    spr_register(env, SPR_405_DVC1, "DVC1",
1760 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1761 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1762 2662a059 j_mayer
                 0x00000000);
1763 76a66253 j_mayer
    /* XXX : not implemented */
1764 2662a059 j_mayer
    spr_register(env, SPR_405_DVC2, "DVC2",
1765 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1766 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1767 76a66253 j_mayer
                 0x00000000);
1768 76a66253 j_mayer
    /* XXX : not implemented */
1769 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
1770 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1771 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1772 76a66253 j_mayer
                 0x00000000);
1773 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
1774 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1775 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1776 76a66253 j_mayer
                 0x00000000);
1777 76a66253 j_mayer
    /* XXX : not implemented */
1778 76a66253 j_mayer
    spr_register(env, SPR_405_IAC3, "IAC3",
1779 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1780 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1781 76a66253 j_mayer
                 0x00000000);
1782 76a66253 j_mayer
    /* XXX : not implemented */
1783 76a66253 j_mayer
    spr_register(env, SPR_405_IAC4, "IAC4",
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
    /* Storage control */
1788 035feb88 j_mayer
    /* XXX: TODO: not implemented */
1789 76a66253 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
1790 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1791 c294fc58 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
1792 76a66253 j_mayer
                 0x00000000);
1793 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
1794 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1795 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1796 2662a059 j_mayer
                 0x00000000);
1797 76a66253 j_mayer
    /* XXX : not implemented */
1798 76a66253 j_mayer
    spr_register(env, SPR_405_SU0R, "SU0R",
1799 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1800 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1801 76a66253 j_mayer
                 0x00000000);
1802 76a66253 j_mayer
    /* SPRG */
1803 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1804 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1805 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1806 76a66253 j_mayer
                 0x00000000);
1807 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1808 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1809 04f20795 j_mayer
                 &spr_read_generic, &spr_write_generic,
1810 76a66253 j_mayer
                 0x00000000);
1811 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1812 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1813 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1814 76a66253 j_mayer
                 0x00000000);
1815 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1816 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1817 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1818 76a66253 j_mayer
                 0x00000000);
1819 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1820 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1821 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1822 76a66253 j_mayer
                 0x00000000);
1823 80d11f44 j_mayer
    gen_spr_usprgh(env);
1824 76a66253 j_mayer
}
1825 76a66253 j_mayer
1826 76a66253 j_mayer
/* SPR shared between PowerPC 401 & 403 implementations */
1827 76a66253 j_mayer
static void gen_spr_401_403 (CPUPPCState *env)
1828 76a66253 j_mayer
{
1829 76a66253 j_mayer
    /* Time base */
1830 76a66253 j_mayer
    spr_register(env, SPR_403_VTBL,  "TBL",
1831 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1832 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1833 76a66253 j_mayer
                 0x00000000);
1834 76a66253 j_mayer
    spr_register(env, SPR_403_TBL,   "TBL",
1835 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1836 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbl,
1837 76a66253 j_mayer
                 0x00000000);
1838 76a66253 j_mayer
    spr_register(env, SPR_403_VTBU,  "TBU",
1839 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1840 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1841 76a66253 j_mayer
                 0x00000000);
1842 76a66253 j_mayer
    spr_register(env, SPR_403_TBU,   "TBU",
1843 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1844 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbu,
1845 76a66253 j_mayer
                 0x00000000);
1846 76a66253 j_mayer
    /* Debug */
1847 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1848 76a66253 j_mayer
    spr_register(env, SPR_403_CDBCR, "CDBCR",
1849 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1850 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1851 76a66253 j_mayer
                 0x00000000);
1852 76a66253 j_mayer
}
1853 76a66253 j_mayer
1854 2662a059 j_mayer
/* SPR specific to PowerPC 401 implementation */
1855 2662a059 j_mayer
static void gen_spr_401 (CPUPPCState *env)
1856 2662a059 j_mayer
{
1857 2662a059 j_mayer
    /* Debug interface */
1858 2662a059 j_mayer
    /* XXX : not implemented */
1859 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR",
1860 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1861 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1862 2662a059 j_mayer
                 0x00000000);
1863 2662a059 j_mayer
    /* XXX : not implemented */
1864 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1865 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1866 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
1867 2662a059 j_mayer
                 /* Last reset was system reset */
1868 2662a059 j_mayer
                 0x00000300);
1869 2662a059 j_mayer
    /* XXX : not implemented */
1870 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC",
1871 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1872 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1873 2662a059 j_mayer
                 0x00000000);
1874 2662a059 j_mayer
    /* XXX : not implemented */
1875 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC",
1876 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1877 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1878 2662a059 j_mayer
                 0x00000000);
1879 2662a059 j_mayer
    /* Storage control */
1880 035feb88 j_mayer
    /* XXX: TODO: not implemented */
1881 2662a059 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
1882 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1883 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
1884 2662a059 j_mayer
                 0x00000000);
1885 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
1886 035feb88 j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
1887 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1888 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
1889 035feb88 j_mayer
                 0xFFFFFFFF);
1890 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1891 035feb88 j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
1892 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1893 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
1894 035feb88 j_mayer
                 0x00000000);
1895 2662a059 j_mayer
}
1896 2662a059 j_mayer
1897 a750fc0b j_mayer
static void gen_spr_401x2 (CPUPPCState *env)
1898 a750fc0b j_mayer
{
1899 a750fc0b j_mayer
    gen_spr_401(env);
1900 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
1901 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1902 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1903 a750fc0b j_mayer
                 0x00000000);
1904 a750fc0b j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
1905 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1906 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1907 a750fc0b j_mayer
                 0x00000000);
1908 a750fc0b j_mayer
}
1909 a750fc0b j_mayer
1910 76a66253 j_mayer
/* SPR specific to PowerPC 403 implementation */
1911 76a66253 j_mayer
static void gen_spr_403 (CPUPPCState *env)
1912 76a66253 j_mayer
{
1913 2662a059 j_mayer
    /* Debug interface */
1914 2662a059 j_mayer
    /* XXX : not implemented */
1915 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1916 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1917 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1918 2662a059 j_mayer
                 0x00000000);
1919 2662a059 j_mayer
    /* XXX : not implemented */
1920 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1921 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1922 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
1923 2662a059 j_mayer
                 /* Last reset was system reset */
1924 2662a059 j_mayer
                 0x00000300);
1925 2662a059 j_mayer
    /* XXX : not implemented */
1926 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
1927 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1928 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1929 2662a059 j_mayer
                 0x00000000);
1930 578bb252 j_mayer
    /* XXX : not implemented */
1931 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
1932 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1933 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1934 2662a059 j_mayer
                 0x00000000);
1935 2662a059 j_mayer
    /* XXX : not implemented */
1936 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
1937 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1938 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1939 2662a059 j_mayer
                 0x00000000);
1940 578bb252 j_mayer
    /* XXX : not implemented */
1941 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
1942 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1943 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1944 2662a059 j_mayer
                 0x00000000);
1945 a750fc0b j_mayer
}
1946 a750fc0b j_mayer
1947 a750fc0b j_mayer
static void gen_spr_403_real (CPUPPCState *env)
1948 a750fc0b j_mayer
{
1949 76a66253 j_mayer
    spr_register(env, SPR_403_PBL1,  "PBL1",
1950 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1951 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
1952 76a66253 j_mayer
                 0x00000000);
1953 76a66253 j_mayer
    spr_register(env, SPR_403_PBU1,  "PBU1",
1954 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1955 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
1956 76a66253 j_mayer
                 0x00000000);
1957 76a66253 j_mayer
    spr_register(env, SPR_403_PBL2,  "PBL2",
1958 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1959 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
1960 76a66253 j_mayer
                 0x00000000);
1961 76a66253 j_mayer
    spr_register(env, SPR_403_PBU2,  "PBU2",
1962 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1963 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
1964 76a66253 j_mayer
                 0x00000000);
1965 a750fc0b j_mayer
}
1966 a750fc0b j_mayer
1967 a750fc0b j_mayer
static void gen_spr_403_mmu (CPUPPCState *env)
1968 a750fc0b j_mayer
{
1969 a750fc0b j_mayer
    /* MMU */
1970 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
1971 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1972 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1973 a750fc0b j_mayer
                 0x00000000);
1974 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
1975 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1976 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1977 76a66253 j_mayer
                 0x00000000);
1978 76a66253 j_mayer
}
1979 76a66253 j_mayer
1980 76a66253 j_mayer
/* SPR specific to PowerPC compression coprocessor extension */
1981 76a66253 j_mayer
static void gen_spr_compress (CPUPPCState *env)
1982 76a66253 j_mayer
{
1983 578bb252 j_mayer
    /* XXX : not implemented */
1984 76a66253 j_mayer
    spr_register(env, SPR_401_SKR, "SKR",
1985 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1986 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1987 76a66253 j_mayer
                 0x00000000);
1988 76a66253 j_mayer
}
1989 a750fc0b j_mayer
1990 a750fc0b j_mayer
#if defined (TARGET_PPC64)
1991 a750fc0b j_mayer
/* SPR specific to PowerPC 620 */
1992 a750fc0b j_mayer
static void gen_spr_620 (CPUPPCState *env)
1993 a750fc0b j_mayer
{
1994 082c6681 j_mayer
    /* Processor identification */
1995 082c6681 j_mayer
    spr_register(env, SPR_PIR, "PIR",
1996 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1997 082c6681 j_mayer
                 &spr_read_generic, &spr_write_pir,
1998 082c6681 j_mayer
                 0x00000000);
1999 082c6681 j_mayer
    spr_register(env, SPR_ASR, "ASR",
2000 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2001 082c6681 j_mayer
                 &spr_read_asr, &spr_write_asr,
2002 082c6681 j_mayer
                 0x00000000);
2003 082c6681 j_mayer
    /* Breakpoints */
2004 082c6681 j_mayer
    /* XXX : not implemented */
2005 082c6681 j_mayer
    spr_register(env, SPR_IABR, "IABR",
2006 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2007 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2008 082c6681 j_mayer
                 0x00000000);
2009 082c6681 j_mayer
    /* XXX : not implemented */
2010 082c6681 j_mayer
    spr_register(env, SPR_DABR, "DABR",
2011 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2012 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2013 082c6681 j_mayer
                 0x00000000);
2014 082c6681 j_mayer
    /* XXX : not implemented */
2015 082c6681 j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
2016 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2017 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2018 082c6681 j_mayer
                 0x00000000);
2019 082c6681 j_mayer
    /* XXX : not implemented */
2020 082c6681 j_mayer
    spr_register(env, SPR_SDA, "SDA",
2021 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2022 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2023 082c6681 j_mayer
                 0x00000000);
2024 082c6681 j_mayer
    /* XXX : not implemented */
2025 082c6681 j_mayer
    spr_register(env, SPR_620_PMC1R, "PMC1",
2026 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2027 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2028 082c6681 j_mayer
                 0x00000000);
2029 082c6681 j_mayer
    spr_register(env, SPR_620_PMC1W, "PMC1",
2030 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2031 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2032 082c6681 j_mayer
                 0x00000000);
2033 082c6681 j_mayer
    /* XXX : not implemented */
2034 082c6681 j_mayer
    spr_register(env, SPR_620_PMC2R, "PMC2",
2035 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2036 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2037 082c6681 j_mayer
                 0x00000000);
2038 082c6681 j_mayer
    spr_register(env, SPR_620_PMC2W, "PMC2",
2039 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2040 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2041 082c6681 j_mayer
                 0x00000000);
2042 082c6681 j_mayer
    /* XXX : not implemented */
2043 082c6681 j_mayer
    spr_register(env, SPR_620_MMCR0R, "MMCR0",
2044 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2045 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2046 082c6681 j_mayer
                 0x00000000);
2047 082c6681 j_mayer
    spr_register(env, SPR_620_MMCR0W, "MMCR0",
2048 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2049 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2050 082c6681 j_mayer
                 0x00000000);
2051 082c6681 j_mayer
    /* External access control */
2052 082c6681 j_mayer
    /* XXX : not implemented */
2053 082c6681 j_mayer
    spr_register(env, SPR_EAR, "EAR",
2054 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2055 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2056 082c6681 j_mayer
                 0x00000000);
2057 082c6681 j_mayer
#if 0 // XXX: check this
2058 578bb252 j_mayer
    /* XXX : not implemented */
2059 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR0, "PMR0",
2060 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2061 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2062 a750fc0b j_mayer
                 0x00000000);
2063 578bb252 j_mayer
    /* XXX : not implemented */
2064 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR1, "PMR1",
2065 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2066 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2067 a750fc0b j_mayer
                 0x00000000);
2068 578bb252 j_mayer
    /* XXX : not implemented */
2069 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR2, "PMR2",
2070 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2071 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2072 a750fc0b j_mayer
                 0x00000000);
2073 578bb252 j_mayer
    /* XXX : not implemented */
2074 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR3, "PMR3",
2075 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2076 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2077 a750fc0b j_mayer
                 0x00000000);
2078 578bb252 j_mayer
    /* XXX : not implemented */
2079 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR4, "PMR4",
2080 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2081 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2082 a750fc0b j_mayer
                 0x00000000);
2083 578bb252 j_mayer
    /* XXX : not implemented */
2084 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR5, "PMR5",
2085 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2086 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2087 a750fc0b j_mayer
                 0x00000000);
2088 578bb252 j_mayer
    /* XXX : not implemented */
2089 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR6, "PMR6",
2090 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2091 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2092 a750fc0b j_mayer
                 0x00000000);
2093 578bb252 j_mayer
    /* XXX : not implemented */
2094 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR7, "PMR7",
2095 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2096 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2097 a750fc0b j_mayer
                 0x00000000);
2098 578bb252 j_mayer
    /* XXX : not implemented */
2099 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR8, "PMR8",
2100 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2101 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2102 a750fc0b j_mayer
                 0x00000000);
2103 578bb252 j_mayer
    /* XXX : not implemented */
2104 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR9, "PMR9",
2105 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2106 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2107 a750fc0b j_mayer
                 0x00000000);
2108 578bb252 j_mayer
    /* XXX : not implemented */
2109 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRA, "PMR10",
2110 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2111 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2112 a750fc0b j_mayer
                 0x00000000);
2113 578bb252 j_mayer
    /* XXX : not implemented */
2114 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRB, "PMR11",
2115 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2116 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2117 a750fc0b j_mayer
                 0x00000000);
2118 578bb252 j_mayer
    /* XXX : not implemented */
2119 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRC, "PMR12",
2120 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2121 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2122 a750fc0b j_mayer
                 0x00000000);
2123 578bb252 j_mayer
    /* XXX : not implemented */
2124 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRD, "PMR13",
2125 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2126 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2127 a750fc0b j_mayer
                 0x00000000);
2128 578bb252 j_mayer
    /* XXX : not implemented */
2129 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRE, "PMR14",
2130 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2131 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2132 a750fc0b j_mayer
                 0x00000000);
2133 578bb252 j_mayer
    /* XXX : not implemented */
2134 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRF, "PMR15",
2135 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2136 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2137 a750fc0b j_mayer
                 0x00000000);
2138 082c6681 j_mayer
#endif
2139 578bb252 j_mayer
    /* XXX : not implemented */
2140 082c6681 j_mayer
    spr_register(env, SPR_620_BUSCSR, "BUSCSR",
2141 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2142 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2143 a750fc0b j_mayer
                 0x00000000);
2144 578bb252 j_mayer
    /* XXX : not implemented */
2145 082c6681 j_mayer
    spr_register(env, SPR_620_L2CR, "L2CR",
2146 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2147 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2148 082c6681 j_mayer
                 0x00000000);
2149 082c6681 j_mayer
    /* XXX : not implemented */
2150 082c6681 j_mayer
    spr_register(env, SPR_620_L2SR, "L2SR",
2151 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2152 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2153 a750fc0b j_mayer
                 0x00000000);
2154 a750fc0b j_mayer
}
2155 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
2156 76a66253 j_mayer
2157 80d11f44 j_mayer
static void gen_spr_5xx_8xx (CPUPPCState *env)
2158 e1833e1f j_mayer
{
2159 80d11f44 j_mayer
    /* Exception processing */
2160 80d11f44 j_mayer
    spr_register(env, SPR_DSISR, "DSISR",
2161 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2162 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2163 80d11f44 j_mayer
                 0x00000000);
2164 80d11f44 j_mayer
    spr_register(env, SPR_DAR, "DAR",
2165 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2166 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2167 80d11f44 j_mayer
                 0x00000000);
2168 80d11f44 j_mayer
    /* Timer */
2169 80d11f44 j_mayer
    spr_register(env, SPR_DECR, "DECR",
2170 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2171 80d11f44 j_mayer
                 &spr_read_decr, &spr_write_decr,
2172 80d11f44 j_mayer
                 0x00000000);
2173 80d11f44 j_mayer
    /* XXX : not implemented */
2174 80d11f44 j_mayer
    spr_register(env, SPR_MPC_EIE, "EIE",
2175 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2176 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2177 80d11f44 j_mayer
                 0x00000000);
2178 80d11f44 j_mayer
    /* XXX : not implemented */
2179 80d11f44 j_mayer
    spr_register(env, SPR_MPC_EID, "EID",
2180 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2181 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2182 80d11f44 j_mayer
                 0x00000000);
2183 80d11f44 j_mayer
    /* XXX : not implemented */
2184 80d11f44 j_mayer
    spr_register(env, SPR_MPC_NRI, "NRI",
2185 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2186 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2187 80d11f44 j_mayer
                 0x00000000);
2188 80d11f44 j_mayer
    /* XXX : not implemented */
2189 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPA, "CMPA",
2190 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2191 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2192 80d11f44 j_mayer
                 0x00000000);
2193 80d11f44 j_mayer
    /* XXX : not implemented */
2194 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPB, "CMPB",
2195 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2196 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2197 80d11f44 j_mayer
                 0x00000000);
2198 80d11f44 j_mayer
    /* XXX : not implemented */
2199 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPC, "CMPC",
2200 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2201 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2202 80d11f44 j_mayer
                 0x00000000);
2203 80d11f44 j_mayer
    /* XXX : not implemented */
2204 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPD, "CMPD",
2205 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2206 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2207 80d11f44 j_mayer
                 0x00000000);
2208 80d11f44 j_mayer
    /* XXX : not implemented */
2209 80d11f44 j_mayer
    spr_register(env, SPR_MPC_ECR, "ECR",
2210 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2211 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2212 80d11f44 j_mayer
                 0x00000000);
2213 80d11f44 j_mayer
    /* XXX : not implemented */
2214 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DER, "DER",
2215 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2216 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2217 80d11f44 j_mayer
                 0x00000000);
2218 80d11f44 j_mayer
    /* XXX : not implemented */
2219 80d11f44 j_mayer
    spr_register(env, SPR_MPC_COUNTA, "COUNTA",
2220 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2221 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2222 80d11f44 j_mayer
                 0x00000000);
2223 80d11f44 j_mayer
    /* XXX : not implemented */
2224 80d11f44 j_mayer
    spr_register(env, SPR_MPC_COUNTB, "COUNTB",
2225 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2226 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2227 80d11f44 j_mayer
                 0x00000000);
2228 80d11f44 j_mayer
    /* XXX : not implemented */
2229 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPE, "CMPE",
2230 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2231 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2232 80d11f44 j_mayer
                 0x00000000);
2233 80d11f44 j_mayer
    /* XXX : not implemented */
2234 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPF, "CMPF",
2235 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2236 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2237 80d11f44 j_mayer
                 0x00000000);
2238 80d11f44 j_mayer
    /* XXX : not implemented */
2239 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPG, "CMPG",
2240 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2241 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2242 80d11f44 j_mayer
                 0x00000000);
2243 80d11f44 j_mayer
    /* XXX : not implemented */
2244 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPH, "CMPH",
2245 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2246 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2247 80d11f44 j_mayer
                 0x00000000);
2248 80d11f44 j_mayer
    /* XXX : not implemented */
2249 80d11f44 j_mayer
    spr_register(env, SPR_MPC_LCTRL1, "LCTRL1",
2250 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2251 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2252 80d11f44 j_mayer
                 0x00000000);
2253 80d11f44 j_mayer
    /* XXX : not implemented */
2254 80d11f44 j_mayer
    spr_register(env, SPR_MPC_LCTRL2, "LCTRL2",
2255 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2256 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2257 80d11f44 j_mayer
                 0x00000000);
2258 80d11f44 j_mayer
    /* XXX : not implemented */
2259 80d11f44 j_mayer
    spr_register(env, SPR_MPC_BAR, "BAR",
2260 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2261 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2262 80d11f44 j_mayer
                 0x00000000);
2263 80d11f44 j_mayer
    /* XXX : not implemented */
2264 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DPDR, "DPDR",
2265 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2266 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2267 80d11f44 j_mayer
                 0x00000000);
2268 80d11f44 j_mayer
    /* XXX : not implemented */
2269 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IMMR, "IMMR",
2270 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2271 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2272 80d11f44 j_mayer
                 0x00000000);
2273 80d11f44 j_mayer
}
2274 80d11f44 j_mayer
2275 80d11f44 j_mayer
static void gen_spr_5xx (CPUPPCState *env)
2276 80d11f44 j_mayer
{
2277 80d11f44 j_mayer
    /* XXX : not implemented */
2278 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_GRA, "MI_GRA",
2279 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2280 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2281 80d11f44 j_mayer
                 0x00000000);
2282 80d11f44 j_mayer
    /* XXX : not implemented */
2283 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_GRA, "L2U_GRA",
2284 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2285 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2286 80d11f44 j_mayer
                 0x00000000);
2287 80d11f44 j_mayer
    /* XXX : not implemented */
2288 80d11f44 j_mayer
    spr_register(env, SPR_RPCU_BBCMCR, "L2U_BBCMCR",
2289 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2290 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2291 80d11f44 j_mayer
                 0x00000000);
2292 80d11f44 j_mayer
    /* XXX : not implemented */
2293 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_MCR, "L2U_MCR",
2294 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2295 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2296 80d11f44 j_mayer
                 0x00000000);
2297 80d11f44 j_mayer
    /* XXX : not implemented */
2298 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA0, "MI_RBA0",
2299 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2300 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2301 80d11f44 j_mayer
                 0x00000000);
2302 80d11f44 j_mayer
    /* XXX : not implemented */
2303 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA1, "MI_RBA1",
2304 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2305 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2306 80d11f44 j_mayer
                 0x00000000);
2307 80d11f44 j_mayer
    /* XXX : not implemented */
2308 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA2, "MI_RBA2",
2309 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2310 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2311 80d11f44 j_mayer
                 0x00000000);
2312 80d11f44 j_mayer
    /* XXX : not implemented */
2313 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA3, "MI_RBA3",
2314 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2315 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2316 80d11f44 j_mayer
                 0x00000000);
2317 80d11f44 j_mayer
    /* XXX : not implemented */
2318 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA0, "L2U_RBA0",
2319 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2320 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2321 80d11f44 j_mayer
                 0x00000000);
2322 80d11f44 j_mayer
    /* XXX : not implemented */
2323 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA1, "L2U_RBA1",
2324 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2325 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2326 80d11f44 j_mayer
                 0x00000000);
2327 80d11f44 j_mayer
    /* XXX : not implemented */
2328 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA2, "L2U_RBA2",
2329 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2330 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2331 80d11f44 j_mayer
                 0x00000000);
2332 80d11f44 j_mayer
    /* XXX : not implemented */
2333 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA3, "L2U_RBA3",
2334 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2335 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2336 80d11f44 j_mayer
                 0x00000000);
2337 80d11f44 j_mayer
    /* XXX : not implemented */
2338 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA0, "MI_RA0",
2339 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2340 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2341 80d11f44 j_mayer
                 0x00000000);
2342 80d11f44 j_mayer
    /* XXX : not implemented */
2343 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA1, "MI_RA1",
2344 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2345 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2346 80d11f44 j_mayer
                 0x00000000);
2347 80d11f44 j_mayer
    /* XXX : not implemented */
2348 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA2, "MI_RA2",
2349 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2350 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2351 80d11f44 j_mayer
                 0x00000000);
2352 80d11f44 j_mayer
    /* XXX : not implemented */
2353 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA3, "MI_RA3",
2354 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2355 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2356 80d11f44 j_mayer
                 0x00000000);
2357 80d11f44 j_mayer
    /* XXX : not implemented */
2358 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA0, "L2U_RA0",
2359 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2360 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2361 80d11f44 j_mayer
                 0x00000000);
2362 80d11f44 j_mayer
    /* XXX : not implemented */
2363 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA1, "L2U_RA1",
2364 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2365 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2366 80d11f44 j_mayer
                 0x00000000);
2367 80d11f44 j_mayer
    /* XXX : not implemented */
2368 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA2, "L2U_RA2",
2369 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2370 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2371 80d11f44 j_mayer
                 0x00000000);
2372 80d11f44 j_mayer
    /* XXX : not implemented */
2373 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA3, "L2U_RA3",
2374 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2375 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2376 80d11f44 j_mayer
                 0x00000000);
2377 80d11f44 j_mayer
    /* XXX : not implemented */
2378 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_FPECR, "FPECR",
2379 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2380 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2381 80d11f44 j_mayer
                 0x00000000);
2382 80d11f44 j_mayer
}
2383 80d11f44 j_mayer
2384 80d11f44 j_mayer
static void gen_spr_8xx (CPUPPCState *env)
2385 80d11f44 j_mayer
{
2386 80d11f44 j_mayer
    /* XXX : not implemented */
2387 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_CST, "IC_CST",
2388 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2389 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2390 80d11f44 j_mayer
                 0x00000000);
2391 80d11f44 j_mayer
    /* XXX : not implemented */
2392 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_ADR, "IC_ADR",
2393 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2394 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2395 80d11f44 j_mayer
                 0x00000000);
2396 80d11f44 j_mayer
    /* XXX : not implemented */
2397 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_DAT, "IC_DAT",
2398 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2399 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2400 80d11f44 j_mayer
                 0x00000000);
2401 80d11f44 j_mayer
    /* XXX : not implemented */
2402 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_CST, "DC_CST",
2403 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2404 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2405 80d11f44 j_mayer
                 0x00000000);
2406 80d11f44 j_mayer
    /* XXX : not implemented */
2407 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_ADR, "DC_ADR",
2408 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2409 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2410 80d11f44 j_mayer
                 0x00000000);
2411 80d11f44 j_mayer
    /* XXX : not implemented */
2412 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_DAT, "DC_DAT",
2413 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2414 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2415 80d11f44 j_mayer
                 0x00000000);
2416 80d11f44 j_mayer
    /* XXX : not implemented */
2417 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_CTR, "MI_CTR",
2418 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2419 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2420 80d11f44 j_mayer
                 0x00000000);
2421 80d11f44 j_mayer
    /* XXX : not implemented */
2422 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_AP, "MI_AP",
2423 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2424 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2425 80d11f44 j_mayer
                 0x00000000);
2426 80d11f44 j_mayer
    /* XXX : not implemented */
2427 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_EPN, "MI_EPN",
2428 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2429 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2430 80d11f44 j_mayer
                 0x00000000);
2431 80d11f44 j_mayer
    /* XXX : not implemented */
2432 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_TWC, "MI_TWC",
2433 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2434 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2435 80d11f44 j_mayer
                 0x00000000);
2436 80d11f44 j_mayer
    /* XXX : not implemented */
2437 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_RPN, "MI_RPN",
2438 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2439 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2440 80d11f44 j_mayer
                 0x00000000);
2441 80d11f44 j_mayer
    /* XXX : not implemented */
2442 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBCAM, "MI_DBCAM",
2443 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2444 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2445 80d11f44 j_mayer
                 0x00000000);
2446 80d11f44 j_mayer
    /* XXX : not implemented */
2447 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBRAM0, "MI_DBRAM0",
2448 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2449 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2450 80d11f44 j_mayer
                 0x00000000);
2451 80d11f44 j_mayer
    /* XXX : not implemented */
2452 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBRAM1, "MI_DBRAM1",
2453 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2454 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2455 80d11f44 j_mayer
                 0x00000000);
2456 80d11f44 j_mayer
    /* XXX : not implemented */
2457 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_CTR, "MD_CTR",
2458 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2459 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2460 80d11f44 j_mayer
                 0x00000000);
2461 80d11f44 j_mayer
    /* XXX : not implemented */
2462 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_CASID, "MD_CASID",
2463 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2464 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2465 80d11f44 j_mayer
                 0x00000000);
2466 80d11f44 j_mayer
    /* XXX : not implemented */
2467 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_AP, "MD_AP",
2468 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2469 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2470 80d11f44 j_mayer
                 0x00000000);
2471 80d11f44 j_mayer
    /* XXX : not implemented */
2472 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_EPN, "MD_EPN",
2473 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2474 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2475 80d11f44 j_mayer
                 0x00000000);
2476 80d11f44 j_mayer
    /* XXX : not implemented */
2477 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TWB, "MD_TWB",
2478 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2479 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2480 80d11f44 j_mayer
                 0x00000000);
2481 80d11f44 j_mayer
    /* XXX : not implemented */
2482 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TWC, "MD_TWC",
2483 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2484 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2485 80d11f44 j_mayer
                 0x00000000);
2486 80d11f44 j_mayer
    /* XXX : not implemented */
2487 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_RPN, "MD_RPN",
2488 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2489 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2490 80d11f44 j_mayer
                 0x00000000);
2491 80d11f44 j_mayer
    /* XXX : not implemented */
2492 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TW, "MD_TW",
2493 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2494 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2495 80d11f44 j_mayer
                 0x00000000);
2496 80d11f44 j_mayer
    /* XXX : not implemented */
2497 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBCAM, "MD_DBCAM",
2498 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2499 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2500 80d11f44 j_mayer
                 0x00000000);
2501 80d11f44 j_mayer
    /* XXX : not implemented */
2502 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBRAM0, "MD_DBRAM0",
2503 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2504 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2505 80d11f44 j_mayer
                 0x00000000);
2506 80d11f44 j_mayer
    /* XXX : not implemented */
2507 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBRAM1, "MD_DBRAM1",
2508 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2509 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2510 80d11f44 j_mayer
                 0x00000000);
2511 80d11f44 j_mayer
}
2512 80d11f44 j_mayer
2513 80d11f44 j_mayer
// XXX: TODO
2514 80d11f44 j_mayer
/*
2515 80d11f44 j_mayer
 * AMR     => SPR 29 (Power 2.04)
2516 80d11f44 j_mayer
 * CTRL    => SPR 136 (Power 2.04)
2517 80d11f44 j_mayer
 * CTRL    => SPR 152 (Power 2.04)
2518 80d11f44 j_mayer
 * SCOMC   => SPR 276 (64 bits ?)
2519 80d11f44 j_mayer
 * SCOMD   => SPR 277 (64 bits ?)
2520 80d11f44 j_mayer
 * TBU40   => SPR 286 (Power 2.04 hypv)
2521 80d11f44 j_mayer
 * HSPRG0  => SPR 304 (Power 2.04 hypv)
2522 80d11f44 j_mayer
 * HSPRG1  => SPR 305 (Power 2.04 hypv)
2523 80d11f44 j_mayer
 * HDSISR  => SPR 306 (Power 2.04 hypv)
2524 80d11f44 j_mayer
 * HDAR    => SPR 307 (Power 2.04 hypv)
2525 80d11f44 j_mayer
 * PURR    => SPR 309 (Power 2.04 hypv)
2526 80d11f44 j_mayer
 * HDEC    => SPR 310 (Power 2.04 hypv)
2527 80d11f44 j_mayer
 * HIOR    => SPR 311 (hypv)
2528 80d11f44 j_mayer
 * RMOR    => SPR 312 (970)
2529 80d11f44 j_mayer
 * HRMOR   => SPR 313 (Power 2.04 hypv)
2530 80d11f44 j_mayer
 * HSRR0   => SPR 314 (Power 2.04 hypv)
2531 80d11f44 j_mayer
 * HSRR1   => SPR 315 (Power 2.04 hypv)
2532 80d11f44 j_mayer
 * LPCR    => SPR 316 (970)
2533 80d11f44 j_mayer
 * LPIDR   => SPR 317 (970)
2534 80d11f44 j_mayer
 * SPEFSCR => SPR 512 (Power 2.04 emb)
2535 80d11f44 j_mayer
 * EPR     => SPR 702 (Power 2.04 emb)
2536 80d11f44 j_mayer
 * perf    => 768-783 (Power 2.04)
2537 80d11f44 j_mayer
 * perf    => 784-799 (Power 2.04)
2538 80d11f44 j_mayer
 * PPR     => SPR 896 (Power 2.04)
2539 80d11f44 j_mayer
 * EPLC    => SPR 947 (Power 2.04 emb)
2540 80d11f44 j_mayer
 * EPSC    => SPR 948 (Power 2.04 emb)
2541 80d11f44 j_mayer
 * DABRX   => 1015    (Power 2.04 hypv)
2542 80d11f44 j_mayer
 * FPECR   => SPR 1022 (?)
2543 80d11f44 j_mayer
 * ... and more (thermal management, performance counters, ...)
2544 80d11f44 j_mayer
 */
2545 80d11f44 j_mayer
2546 80d11f44 j_mayer
/*****************************************************************************/
2547 80d11f44 j_mayer
/* Exception vectors models                                                  */
2548 80d11f44 j_mayer
static void init_excp_4xx_real (CPUPPCState *env)
2549 80d11f44 j_mayer
{
2550 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2551 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2552 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2553 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2554 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2555 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2556 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2557 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2558 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2559 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2560 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2561 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2562 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2563 faadf50e j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2564 1c27f8fb j_mayer
    /* Hardware reset vector */
2565 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2566 e1833e1f j_mayer
#endif
2567 e1833e1f j_mayer
}
2568 e1833e1f j_mayer
2569 80d11f44 j_mayer
static void init_excp_4xx_softmmu (CPUPPCState *env)
2570 80d11f44 j_mayer
{
2571 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2572 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2573 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2574 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2575 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2576 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2577 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2578 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2579 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2580 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2581 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2582 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2583 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001100;
2584 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001200;
2585 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2586 80d11f44 j_mayer
    env->excp_prefix = 0x00000000UL;
2587 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2588 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2589 80d11f44 j_mayer
    /* Hardware reset vector */
2590 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2591 80d11f44 j_mayer
#endif
2592 80d11f44 j_mayer
}
2593 80d11f44 j_mayer
2594 80d11f44 j_mayer
static void init_excp_MPC5xx (CPUPPCState *env)
2595 80d11f44 j_mayer
{
2596 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2597 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2598 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2599 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2600 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2601 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2602 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000900;
2603 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2604 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2605 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2606 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2607 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001000;
2608 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DABR]     = 0x00001C00;
2609 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001C00;
2610 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MEXTBR]   = 0x00001E00;
2611 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_NMEXTBR]  = 0x00001F00;
2612 80d11f44 j_mayer
    env->excp_prefix = 0x00000000UL;
2613 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2614 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2615 80d11f44 j_mayer
    /* Hardware reset vector */
2616 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2617 80d11f44 j_mayer
#endif
2618 80d11f44 j_mayer
}
2619 80d11f44 j_mayer
2620 80d11f44 j_mayer
static void init_excp_MPC8xx (CPUPPCState *env)
2621 e1833e1f j_mayer
{
2622 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2623 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2624 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2625 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2626 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2627 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2628 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2629 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2630 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000900;
2631 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2632 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2633 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2634 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2635 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001000;
2636 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001100;
2637 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001200;
2638 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLBE]    = 0x00001300;
2639 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLBE]    = 0x00001400;
2640 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DABR]     = 0x00001C00;
2641 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001C00;
2642 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MEXTBR]   = 0x00001E00;
2643 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_NMEXTBR]  = 0x00001F00;
2644 80d11f44 j_mayer
    env->excp_prefix = 0x00000000UL;
2645 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2646 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2647 1c27f8fb j_mayer
    /* Hardware reset vector */
2648 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2649 e1833e1f j_mayer
#endif
2650 e1833e1f j_mayer
}
2651 e1833e1f j_mayer
2652 80d11f44 j_mayer
static void init_excp_G2 (CPUPPCState *env)
2653 e1833e1f j_mayer
{
2654 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2655 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2656 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2657 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2658 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2659 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2660 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2661 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2662 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2663 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2664 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000A00;
2665 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2666 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2667 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2668 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2669 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2670 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2671 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2672 80d11f44 j_mayer
    env->excp_prefix = 0x00000000UL;
2673 80d11f44 j_mayer
    /* Hardware reset vector */
2674 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2675 80d11f44 j_mayer
#endif
2676 80d11f44 j_mayer
}
2677 80d11f44 j_mayer
2678 80d11f44 j_mayer
static void init_excp_e200 (CPUPPCState *env)
2679 80d11f44 j_mayer
{
2680 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2681 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000FFC;
2682 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2683 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2684 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2685 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2686 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2687 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2688 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2689 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2690 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2691 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2692 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2693 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2694 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2695 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2696 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2697 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2698 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SPEU]     = 0x00000000;
2699 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EFPDI]    = 0x00000000;
2700 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EFPRI]    = 0x00000000;
2701 80d11f44 j_mayer
    env->excp_prefix = 0x00000000UL;
2702 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF7UL;
2703 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2704 80d11f44 j_mayer
    /* Hardware reset vector */
2705 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2706 80d11f44 j_mayer
#endif
2707 80d11f44 j_mayer
}
2708 80d11f44 j_mayer
2709 80d11f44 j_mayer
static void init_excp_BookE (CPUPPCState *env)
2710 80d11f44 j_mayer
{
2711 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2712 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2713 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2714 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2715 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2716 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2717 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2718 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2719 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2720 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2721 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2722 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2723 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2724 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2725 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2726 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2727 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2728 80d11f44 j_mayer
    env->excp_prefix = 0x00000000UL;
2729 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFE0UL;
2730 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2731 80d11f44 j_mayer
    /* Hardware reset vector */
2732 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2733 80d11f44 j_mayer
#endif
2734 80d11f44 j_mayer
}
2735 80d11f44 j_mayer
2736 80d11f44 j_mayer
static void init_excp_601 (CPUPPCState *env)
2737 80d11f44 j_mayer
{
2738 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2739 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2740 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2741 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2742 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2743 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2744 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2745 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2746 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2747 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2748 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IO]       = 0x00000A00;
2749 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2750 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RUNM]     = 0x00002000;
2751 faadf50e j_mayer
    env->excp_prefix = 0xFFF00000UL;
2752 1c27f8fb j_mayer
    /* Hardware reset vector */
2753 80d11f44 j_mayer
    env->hreset_vector = 0x00000100UL;
2754 e1833e1f j_mayer
#endif
2755 e1833e1f j_mayer
}
2756 e1833e1f j_mayer
2757 80d11f44 j_mayer
static void init_excp_602 (CPUPPCState *env)
2758 e1833e1f j_mayer
{
2759 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2760 082c6681 j_mayer
    /* XXX: exception prefix has a special behavior on 602 */
2761 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2762 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2763 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2764 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2765 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2766 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2767 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2768 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2769 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2770 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2771 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2772 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2773 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2774 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2775 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2776 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2777 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001500;
2778 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001600;
2779 80d11f44 j_mayer
    env->excp_prefix = 0xFFF00000UL;
2780 1c27f8fb j_mayer
    /* Hardware reset vector */
2781 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2782 e1833e1f j_mayer
#endif
2783 e1833e1f j_mayer
}
2784 e1833e1f j_mayer
2785 80d11f44 j_mayer
static void init_excp_603 (CPUPPCState *env)
2786 e1833e1f j_mayer
{
2787 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2788 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2789 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2790 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2791 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2792 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2793 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2794 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2795 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2796 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2797 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2798 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2799 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2800 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2801 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2802 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2803 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2804 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2805 1c27f8fb j_mayer
    /* Hardware reset vector */
2806 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2807 e1833e1f j_mayer
#endif
2808 e1833e1f j_mayer
}
2809 e1833e1f j_mayer
2810 e1833e1f j_mayer
static void init_excp_604 (CPUPPCState *env)
2811 e1833e1f j_mayer
{
2812 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2813 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2814 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2815 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2816 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2817 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2818 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2819 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2820 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2821 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2822 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2823 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2824 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2825 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2826 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2827 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2828 1c27f8fb j_mayer
    /* Hardware reset vector */
2829 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2830 e1833e1f j_mayer
#endif
2831 e1833e1f j_mayer
}
2832 e1833e1f j_mayer
2833 578bb252 j_mayer
#if defined(TARGET_PPC64)
2834 e1833e1f j_mayer
static void init_excp_620 (CPUPPCState *env)
2835 e1833e1f j_mayer
{
2836 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2837 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2838 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2839 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2840 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2841 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2842 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2843 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2844 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2845 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2846 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2847 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2848 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2849 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2850 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2851 faadf50e j_mayer
    env->excp_prefix = 0xFFF00000UL;
2852 1c27f8fb j_mayer
    /* Hardware reset vector */
2853 faadf50e j_mayer
    env->hreset_vector = 0x0000000000000100ULL;
2854 e1833e1f j_mayer
#endif
2855 e1833e1f j_mayer
}
2856 578bb252 j_mayer
#endif /* defined(TARGET_PPC64) */
2857 e1833e1f j_mayer
2858 e1833e1f j_mayer
static void init_excp_7x0 (CPUPPCState *env)
2859 e1833e1f j_mayer
{
2860 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2861 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2862 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2863 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2864 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2865 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2866 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2867 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2868 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2869 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2870 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2871 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2872 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2873 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2874 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2875 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2876 1c27f8fb j_mayer
    /* Hardware reset vector */
2877 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2878 e1833e1f j_mayer
#endif
2879 e1833e1f j_mayer
}
2880 e1833e1f j_mayer
2881 e1833e1f j_mayer
static void init_excp_750FX (CPUPPCState *env)
2882 e1833e1f j_mayer
{
2883 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2884 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2885 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2886 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2887 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2888 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2889 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2890 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2891 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2892 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2893 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2894 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2895 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2896 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2897 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2898 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2899 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2900 1c27f8fb j_mayer
    /* Hardware reset vector */
2901 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2902 e1833e1f j_mayer
#endif
2903 e1833e1f j_mayer
}
2904 e1833e1f j_mayer
2905 7a3a6927 j_mayer
/* XXX: Check if this is correct */
2906 7a3a6927 j_mayer
static void init_excp_7x5 (CPUPPCState *env)
2907 7a3a6927 j_mayer
{
2908 7a3a6927 j_mayer
#if !defined(CONFIG_USER_ONLY)
2909 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2910 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2911 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2912 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2913 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2914 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2915 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2916 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2917 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2918 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2919 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2920 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2921 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2922 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2923 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2924 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2925 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2926 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2927 7a3a6927 j_mayer
    /* Hardware reset vector */
2928 7a3a6927 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2929 7a3a6927 j_mayer
#endif
2930 7a3a6927 j_mayer
}
2931 7a3a6927 j_mayer
2932 e1833e1f j_mayer
static void init_excp_7400 (CPUPPCState *env)
2933 e1833e1f j_mayer
{
2934 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2935 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2936 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2937 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2938 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2939 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2940 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2941 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2942 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2943 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2944 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2945 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2946 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2947 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2948 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2949 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2950 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2951 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2952 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2953 1c27f8fb j_mayer
    /* Hardware reset vector */
2954 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2955 e1833e1f j_mayer
#endif
2956 e1833e1f j_mayer
}
2957 e1833e1f j_mayer
2958 e1833e1f j_mayer
static void init_excp_7450 (CPUPPCState *env)
2959 e1833e1f j_mayer
{
2960 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2961 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2962 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2963 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2964 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2965 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2966 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2967 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2968 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2969 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2970 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2971 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2972 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2973 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2974 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2975 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2976 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2977 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2978 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2979 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2980 faadf50e j_mayer
    env->excp_prefix = 0x00000000UL;
2981 1c27f8fb j_mayer
    /* Hardware reset vector */
2982 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2983 e1833e1f j_mayer
#endif
2984 e1833e1f j_mayer
}
2985 e1833e1f j_mayer
2986 e1833e1f j_mayer
#if defined (TARGET_PPC64)
2987 e1833e1f j_mayer
static void init_excp_970 (CPUPPCState *env)
2988 e1833e1f j_mayer
{
2989 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2990 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2991 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2992 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2993 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
2994 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2995 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
2996 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2997 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2998 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2999 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3000 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3001 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
3002 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3003 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3004 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3005 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3006 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3007 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
3008 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
3009 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
3010 faadf50e j_mayer
    env->excp_prefix   = 0x00000000FFF00000ULL;
3011 1c27f8fb j_mayer
    /* Hardware reset vector */
3012 1c27f8fb j_mayer
    env->hreset_vector = 0x0000000000000100ULL;
3013 e1833e1f j_mayer
#endif
3014 e1833e1f j_mayer
}
3015 e1833e1f j_mayer
#endif
3016 e1833e1f j_mayer
3017 e1833e1f j_mayer
/*****************************************************************************/
3018 2f462816 j_mayer
/* Power management enable checks                                            */
3019 2f462816 j_mayer
static int check_pow_none (CPUPPCState *env)
3020 2f462816 j_mayer
{
3021 2f462816 j_mayer
    return 0;
3022 2f462816 j_mayer
}
3023 2f462816 j_mayer
3024 2f462816 j_mayer
static int check_pow_nocheck (CPUPPCState *env)
3025 2f462816 j_mayer
{
3026 2f462816 j_mayer
    return 1;
3027 2f462816 j_mayer
}
3028 2f462816 j_mayer
3029 2f462816 j_mayer
static int check_pow_hid0 (CPUPPCState *env)
3030 2f462816 j_mayer
{
3031 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00E00000)
3032 2f462816 j_mayer
        return 1;
3033 2f462816 j_mayer
3034 2f462816 j_mayer
    return 0;
3035 2f462816 j_mayer
}
3036 2f462816 j_mayer
3037 2f462816 j_mayer
/*****************************************************************************/
3038 a750fc0b j_mayer
/* PowerPC implementations definitions                                       */
3039 76a66253 j_mayer
3040 a750fc0b j_mayer
/* PowerPC 401                                                               */
3041 082c6681 j_mayer
#define POWERPC_INSNS_401    (PPC_INSNS_BASE | PPC_STRING |                   \
3042 082c6681 j_mayer
                              PPC_WRTEE | PPC_DCR |                           \
3043 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3044 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3045 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3046 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3047 a750fc0b j_mayer
#define POWERPC_MSRM_401     (0x00000000000FD201ULL)
3048 b4095fed j_mayer
#define POWERPC_MMU_401      (POWERPC_MMU_REAL)
3049 a750fc0b j_mayer
#define POWERPC_EXCP_401     (POWERPC_EXCP_40x)
3050 a750fc0b j_mayer
#define POWERPC_INPUT_401    (PPC_FLAGS_INPUT_401)
3051 237c0af0 j_mayer
#define POWERPC_BFDM_401     (bfd_mach_ppc_403)
3052 4018bae9 j_mayer
#define POWERPC_FLAG_401     (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3053 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3054 2f462816 j_mayer
#define check_pow_401        check_pow_nocheck
3055 76a66253 j_mayer
3056 a750fc0b j_mayer
static void init_proc_401 (CPUPPCState *env)
3057 a750fc0b j_mayer
{
3058 a750fc0b j_mayer
    gen_spr_40x(env);
3059 a750fc0b j_mayer
    gen_spr_401_403(env);
3060 a750fc0b j_mayer
    gen_spr_401(env);
3061 e1833e1f j_mayer
    init_excp_4xx_real(env);
3062 d63001d1 j_mayer
    env->dcache_line_size = 32;
3063 d63001d1 j_mayer
    env->icache_line_size = 32;
3064 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3065 4e290a0b j_mayer
    ppc40x_irq_init(env);
3066 a750fc0b j_mayer
}
3067 76a66253 j_mayer
3068 a750fc0b j_mayer
/* PowerPC 401x2                                                             */
3069 082c6681 j_mayer
#define POWERPC_INSNS_401x2  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3070 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3071 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3072 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3073 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3074 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3075 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3076 a750fc0b j_mayer
#define POWERPC_MSRM_401x2   (0x00000000001FD231ULL)
3077 a750fc0b j_mayer
#define POWERPC_MMU_401x2    (POWERPC_MMU_SOFT_4xx_Z)
3078 a750fc0b j_mayer
#define POWERPC_EXCP_401x2   (POWERPC_EXCP_40x)
3079 a750fc0b j_mayer
#define POWERPC_INPUT_401x2  (PPC_FLAGS_INPUT_401)
3080 237c0af0 j_mayer
#define POWERPC_BFDM_401x2   (bfd_mach_ppc_403)
3081 4018bae9 j_mayer
#define POWERPC_FLAG_401x2   (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3082 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3083 2f462816 j_mayer
#define check_pow_401x2      check_pow_nocheck
3084 a750fc0b j_mayer
3085 a750fc0b j_mayer
static void init_proc_401x2 (CPUPPCState *env)
3086 a750fc0b j_mayer
{
3087 a750fc0b j_mayer
    gen_spr_40x(env);
3088 a750fc0b j_mayer
    gen_spr_401_403(env);
3089 a750fc0b j_mayer
    gen_spr_401x2(env);
3090 a750fc0b j_mayer
    gen_spr_compress(env);
3091 a750fc0b j_mayer
    /* Memory management */
3092 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3093 a750fc0b j_mayer
    env->nb_tlb = 64;
3094 a750fc0b j_mayer
    env->nb_ways = 1;
3095 a750fc0b j_mayer
    env->id_tlbs = 0;
3096 f2e63a42 j_mayer
#endif
3097 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3098 d63001d1 j_mayer
    env->dcache_line_size = 32;
3099 d63001d1 j_mayer
    env->icache_line_size = 32;
3100 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3101 4e290a0b j_mayer
    ppc40x_irq_init(env);
3102 76a66253 j_mayer
}
3103 76a66253 j_mayer
3104 a750fc0b j_mayer
/* PowerPC 401x3                                                             */
3105 082c6681 j_mayer
#define POWERPC_INSNS_401x3  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3106 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3107 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3108 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3109 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3110 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3111 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3112 a750fc0b j_mayer
#define POWERPC_MSRM_401x3   (0x00000000001FD631ULL)
3113 a750fc0b j_mayer
#define POWERPC_MMU_401x3    (POWERPC_MMU_SOFT_4xx_Z)
3114 a750fc0b j_mayer
#define POWERPC_EXCP_401x3   (POWERPC_EXCP_40x)
3115 a750fc0b j_mayer
#define POWERPC_INPUT_401x3  (PPC_FLAGS_INPUT_401)
3116 237c0af0 j_mayer
#define POWERPC_BFDM_401x3   (bfd_mach_ppc_403)
3117 4018bae9 j_mayer
#define POWERPC_FLAG_401x3   (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3118 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3119 2f462816 j_mayer
#define check_pow_401x3      check_pow_nocheck
3120 a750fc0b j_mayer
3121 578bb252 j_mayer
__attribute__ (( unused ))
3122 e1833e1f j_mayer
static void init_proc_401x3 (CPUPPCState *env)
3123 76a66253 j_mayer
{
3124 4e290a0b j_mayer
    gen_spr_40x(env);
3125 4e290a0b j_mayer
    gen_spr_401_403(env);
3126 4e290a0b j_mayer
    gen_spr_401(env);
3127 4e290a0b j_mayer
    gen_spr_401x2(env);
3128 4e290a0b j_mayer
    gen_spr_compress(env);
3129 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3130 d63001d1 j_mayer
    env->dcache_line_size = 32;
3131 d63001d1 j_mayer
    env->icache_line_size = 32;
3132 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3133 4e290a0b j_mayer
    ppc40x_irq_init(env);
3134 3fc6c082 bellard
}
3135 a750fc0b j_mayer
3136 a750fc0b j_mayer
/* IOP480                                                                    */
3137 082c6681 j_mayer
#define POWERPC_INSNS_IOP480 (PPC_INSNS_BASE | PPC_STRING |                   \
3138 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3139 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |  PPC_40x_ICBT |    \
3140 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3141 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3142 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3143 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3144 a750fc0b j_mayer
#define POWERPC_MSRM_IOP480  (0x00000000001FD231ULL)
3145 a750fc0b j_mayer
#define POWERPC_MMU_IOP480   (POWERPC_MMU_SOFT_4xx_Z)
3146 a750fc0b j_mayer
#define POWERPC_EXCP_IOP480  (POWERPC_EXCP_40x)
3147 a750fc0b j_mayer
#define POWERPC_INPUT_IOP480 (PPC_FLAGS_INPUT_401)
3148 237c0af0 j_mayer
#define POWERPC_BFDM_IOP480  (bfd_mach_ppc_403)
3149 4018bae9 j_mayer
#define POWERPC_FLAG_IOP480  (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3150 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3151 2f462816 j_mayer
#define check_pow_IOP480     check_pow_nocheck
3152 a750fc0b j_mayer
3153 a750fc0b j_mayer
static void init_proc_IOP480 (CPUPPCState *env)
3154 3fc6c082 bellard
{
3155 a750fc0b j_mayer
    gen_spr_40x(env);
3156 a750fc0b j_mayer
    gen_spr_401_403(env);
3157 a750fc0b j_mayer
    gen_spr_401x2(env);
3158 a750fc0b j_mayer
    gen_spr_compress(env);
3159 a750fc0b j_mayer
    /* Memory management */
3160 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3161 a750fc0b j_mayer
    env->nb_tlb = 64;
3162 a750fc0b j_mayer
    env->nb_ways = 1;
3163 a750fc0b j_mayer
    env->id_tlbs = 0;
3164 f2e63a42 j_mayer
#endif
3165 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3166 d63001d1 j_mayer
    env->dcache_line_size = 32;
3167 d63001d1 j_mayer
    env->icache_line_size = 32;
3168 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3169 4e290a0b j_mayer
    ppc40x_irq_init(env);
3170 3fc6c082 bellard
}
3171 3fc6c082 bellard
3172 a750fc0b j_mayer
/* PowerPC 403                                                               */
3173 082c6681 j_mayer
#define POWERPC_INSNS_403    (PPC_INSNS_BASE | PPC_STRING |                   \
3174 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3175 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3176 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3177 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3178 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3179 a750fc0b j_mayer
#define POWERPC_MSRM_403     (0x000000000007D00DULL)
3180 b4095fed j_mayer
#define POWERPC_MMU_403      (POWERPC_MMU_REAL)
3181 a750fc0b j_mayer
#define POWERPC_EXCP_403     (POWERPC_EXCP_40x)
3182 a750fc0b j_mayer
#define POWERPC_INPUT_403    (PPC_FLAGS_INPUT_401)
3183 237c0af0 j_mayer
#define POWERPC_BFDM_403     (bfd_mach_ppc_403)
3184 4018bae9 j_mayer
#define POWERPC_FLAG_403     (POWERPC_FLAG_CE | POWERPC_FLAG_PX |             \
3185 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3186 2f462816 j_mayer
#define check_pow_403        check_pow_nocheck
3187 a750fc0b j_mayer
3188 a750fc0b j_mayer
static void init_proc_403 (CPUPPCState *env)
3189 3fc6c082 bellard
{
3190 a750fc0b j_mayer
    gen_spr_40x(env);
3191 a750fc0b j_mayer
    gen_spr_401_403(env);
3192 a750fc0b j_mayer
    gen_spr_403(env);
3193 a750fc0b j_mayer
    gen_spr_403_real(env);
3194 e1833e1f j_mayer
    init_excp_4xx_real(env);
3195 d63001d1 j_mayer
    env->dcache_line_size = 32;
3196 d63001d1 j_mayer
    env->icache_line_size = 32;
3197 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3198 4e290a0b j_mayer
    ppc40x_irq_init(env);
3199 d63001d1 j_mayer
#if !defined(CONFIG_USER_ONLY)
3200 d63001d1 j_mayer
    /* Hardware reset vector */
3201 d63001d1 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3202 d63001d1 j_mayer
#endif
3203 3fc6c082 bellard
}
3204 3fc6c082 bellard
3205 a750fc0b j_mayer
/* PowerPC 403 GCX                                                           */
3206 082c6681 j_mayer
#define POWERPC_INSNS_403GCX (PPC_INSNS_BASE | PPC_STRING |                   \
3207 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3208 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3209 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3210 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3211 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3212 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3213 a750fc0b j_mayer
#define POWERPC_MSRM_403GCX  (0x000000000007D00DULL)
3214 a750fc0b j_mayer
#define POWERPC_MMU_403GCX   (POWERPC_MMU_SOFT_4xx_Z)
3215 a750fc0b j_mayer
#define POWERPC_EXCP_403GCX  (POWERPC_EXCP_40x)
3216 a750fc0b j_mayer
#define POWERPC_INPUT_403GCX (PPC_FLAGS_INPUT_401)
3217 237c0af0 j_mayer
#define POWERPC_BFDM_403GCX  (bfd_mach_ppc_403)
3218 4018bae9 j_mayer
#define POWERPC_FLAG_403GCX  (POWERPC_FLAG_CE | POWERPC_FLAG_PX |             \
3219 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3220 2f462816 j_mayer
#define check_pow_403GCX     check_pow_nocheck
3221 a750fc0b j_mayer
3222 a750fc0b j_mayer
static void init_proc_403GCX (CPUPPCState *env)
3223 3fc6c082 bellard
{
3224 a750fc0b j_mayer
    gen_spr_40x(env);
3225 a750fc0b j_mayer
    gen_spr_401_403(env);
3226 a750fc0b j_mayer
    gen_spr_403(env);
3227 a750fc0b j_mayer
    gen_spr_403_real(env);
3228 a750fc0b j_mayer
    gen_spr_403_mmu(env);
3229 a750fc0b j_mayer
    /* Bus access control */
3230 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
3231 a750fc0b j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
3232 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3233 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3234 a750fc0b j_mayer
                 0xFFFFFFFF);
3235 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
3236 a750fc0b j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
3237 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3238 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3239 a750fc0b j_mayer
                 0x00000000);
3240 a750fc0b j_mayer
    /* Memory management */
3241 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3242 a750fc0b j_mayer
    env->nb_tlb = 64;
3243 a750fc0b j_mayer
    env->nb_ways = 1;
3244 a750fc0b j_mayer
    env->id_tlbs = 0;
3245 f2e63a42 j_mayer
#endif
3246 80d11f44 j_mayer
    init_excp_4xx_softmmu(env);
3247 80d11f44 j_mayer
    env->dcache_line_size = 32;
3248 80d11f44 j_mayer
    env->icache_line_size = 32;
3249 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3250 80d11f44 j_mayer
    ppc40x_irq_init(env);
3251 80d11f44 j_mayer
}
3252 80d11f44 j_mayer
3253 80d11f44 j_mayer
/* PowerPC 405                                                               */
3254 082c6681 j_mayer
#define POWERPC_INSNS_405    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3255 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3256 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3257 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3258 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3259 80d11f44 j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3260 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_405_MAC | PPC_40x_EXCP)
3261 80d11f44 j_mayer
#define POWERPC_MSRM_405     (0x000000000006E630ULL)
3262 80d11f44 j_mayer
#define POWERPC_MMU_405      (POWERPC_MMU_SOFT_4xx)
3263 80d11f44 j_mayer
#define POWERPC_EXCP_405     (POWERPC_EXCP_40x)
3264 80d11f44 j_mayer
#define POWERPC_INPUT_405    (PPC_FLAGS_INPUT_405)
3265 80d11f44 j_mayer
#define POWERPC_BFDM_405     (bfd_mach_ppc_403)
3266 80d11f44 j_mayer
#define POWERPC_FLAG_405     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3267 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3268 80d11f44 j_mayer
#define check_pow_405        check_pow_nocheck
3269 80d11f44 j_mayer
3270 80d11f44 j_mayer
static void init_proc_405 (CPUPPCState *env)
3271 80d11f44 j_mayer
{
3272 80d11f44 j_mayer
    /* Time base */
3273 80d11f44 j_mayer
    gen_tbl(env);
3274 80d11f44 j_mayer
    gen_spr_40x(env);
3275 80d11f44 j_mayer
    gen_spr_405(env);
3276 80d11f44 j_mayer
    /* Bus access control */
3277 80d11f44 j_mayer
    /* not emulated, as Qemu never does speculative access */
3278 80d11f44 j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
3279 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3280 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3281 80d11f44 j_mayer
                 0xFFFFFFFF);
3282 80d11f44 j_mayer
    /* not emulated, as Qemu do not emulate caches */
3283 80d11f44 j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
3284 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3285 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3286 80d11f44 j_mayer
                 0x00000000);
3287 80d11f44 j_mayer
    /* Memory management */
3288 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3289 80d11f44 j_mayer
    env->nb_tlb = 64;
3290 80d11f44 j_mayer
    env->nb_ways = 1;
3291 80d11f44 j_mayer
    env->id_tlbs = 0;
3292 80d11f44 j_mayer
#endif
3293 80d11f44 j_mayer
    init_excp_4xx_softmmu(env);
3294 80d11f44 j_mayer
    env->dcache_line_size = 32;
3295 80d11f44 j_mayer
    env->icache_line_size = 32;
3296 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3297 80d11f44 j_mayer
    ppc40x_irq_init(env);
3298 80d11f44 j_mayer
}
3299 80d11f44 j_mayer
3300 80d11f44 j_mayer
/* PowerPC 440 EP                                                            */
3301 082c6681 j_mayer
#define POWERPC_INSNS_440EP  (PPC_INSNS_BASE | PPC_STRING |                   \
3302 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE | PPC_RFMCI |               \
3303 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3304 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3305 082c6681 j_mayer
                              PPC_MEM_TLBSYNC |                               \
3306 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3307 082c6681 j_mayer
                              PPC_440_SPEC)
3308 80d11f44 j_mayer
#define POWERPC_MSRM_440EP   (0x000000000006D630ULL)
3309 80d11f44 j_mayer
#define POWERPC_MMU_440EP    (POWERPC_MMU_BOOKE)
3310 80d11f44 j_mayer
#define POWERPC_EXCP_440EP   (POWERPC_EXCP_BOOKE)
3311 80d11f44 j_mayer
#define POWERPC_INPUT_440EP  (PPC_FLAGS_INPUT_BookE)
3312 80d11f44 j_mayer
#define POWERPC_BFDM_440EP   (bfd_mach_ppc_403)
3313 80d11f44 j_mayer
#define POWERPC_FLAG_440EP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3314 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3315 80d11f44 j_mayer
#define check_pow_440EP      check_pow_nocheck
3316 80d11f44 j_mayer
3317 80d11f44 j_mayer
__attribute__ (( unused ))
3318 80d11f44 j_mayer
static void init_proc_440EP (CPUPPCState *env)
3319 80d11f44 j_mayer
{
3320 80d11f44 j_mayer
    /* Time base */
3321 80d11f44 j_mayer
    gen_tbl(env);
3322 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3323 80d11f44 j_mayer
    gen_spr_440(env);
3324 80d11f44 j_mayer
    gen_spr_usprgh(env);
3325 80d11f44 j_mayer
    /* Processor identification */
3326 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3327 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3328 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3329 80d11f44 j_mayer
                 0x00000000);
3330 80d11f44 j_mayer
    /* XXX : not implemented */
3331 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3332 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3333 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3334 80d11f44 j_mayer
                 0x00000000);
3335 80d11f44 j_mayer
    /* XXX : not implemented */
3336 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3337 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3338 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3339 80d11f44 j_mayer
                 0x00000000);
3340 80d11f44 j_mayer
    /* XXX : not implemented */
3341 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3342 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3343 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3344 80d11f44 j_mayer
                 0x00000000);
3345 80d11f44 j_mayer
    /* XXX : not implemented */
3346 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3347 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3348 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3349 80d11f44 j_mayer
                 0x00000000);
3350 80d11f44 j_mayer
    /* XXX : not implemented */
3351 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3352 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3353 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3354 80d11f44 j_mayer
                 0x00000000);
3355 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3356 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3357 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3358 80d11f44 j_mayer
                 0x00000000);
3359 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3360 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3361 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3362 80d11f44 j_mayer
                 0x00000000);
3363 80d11f44 j_mayer
    /* XXX : not implemented */
3364 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3365 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3366 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3367 80d11f44 j_mayer
                 0x00000000);
3368 80d11f44 j_mayer
    /* Memory management */
3369 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3370 80d11f44 j_mayer
    env->nb_tlb = 64;
3371 80d11f44 j_mayer
    env->nb_ways = 1;
3372 80d11f44 j_mayer
    env->id_tlbs = 0;
3373 80d11f44 j_mayer
#endif
3374 80d11f44 j_mayer
    init_excp_BookE(env);
3375 80d11f44 j_mayer
    env->dcache_line_size = 32;
3376 80d11f44 j_mayer
    env->icache_line_size = 32;
3377 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3378 80d11f44 j_mayer
}
3379 80d11f44 j_mayer
3380 80d11f44 j_mayer
/* PowerPC 440 GP                                                            */
3381 082c6681 j_mayer
#define POWERPC_INSNS_440GP  (PPC_INSNS_BASE | PPC_STRING |                   \
3382 082c6681 j_mayer
                              PPC_DCR | PPC_DCRX | PPC_WRTEE | PPC_MFAPIDI |  \
3383 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3384 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3385 082c6681 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVA |                  \
3386 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3387 082c6681 j_mayer
                              PPC_440_SPEC)
3388 80d11f44 j_mayer
#define POWERPC_MSRM_440GP   (0x000000000006FF30ULL)
3389 80d11f44 j_mayer
#define POWERPC_MMU_440GP    (POWERPC_MMU_BOOKE)
3390 80d11f44 j_mayer
#define POWERPC_EXCP_440GP   (POWERPC_EXCP_BOOKE)
3391 80d11f44 j_mayer
#define POWERPC_INPUT_440GP  (PPC_FLAGS_INPUT_BookE)
3392 80d11f44 j_mayer
#define POWERPC_BFDM_440GP   (bfd_mach_ppc_403)
3393 80d11f44 j_mayer
#define POWERPC_FLAG_440GP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3394 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3395 80d11f44 j_mayer
#define check_pow_440GP      check_pow_nocheck
3396 80d11f44 j_mayer
3397 80d11f44 j_mayer
__attribute__ (( unused ))
3398 80d11f44 j_mayer
static void init_proc_440GP (CPUPPCState *env)
3399 80d11f44 j_mayer
{
3400 80d11f44 j_mayer
    /* Time base */
3401 80d11f44 j_mayer
    gen_tbl(env);
3402 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3403 80d11f44 j_mayer
    gen_spr_440(env);
3404 80d11f44 j_mayer
    gen_spr_usprgh(env);
3405 80d11f44 j_mayer
    /* Processor identification */
3406 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3407 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3408 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3409 80d11f44 j_mayer
                 0x00000000);
3410 80d11f44 j_mayer
    /* XXX : not implemented */
3411 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3412 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3413 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3414 80d11f44 j_mayer
                 0x00000000);
3415 80d11f44 j_mayer
    /* XXX : not implemented */
3416 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3417 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3418 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3419 80d11f44 j_mayer
                 0x00000000);
3420 80d11f44 j_mayer
    /* XXX : not implemented */
3421 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3422 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3423 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3424 80d11f44 j_mayer
                 0x00000000);
3425 80d11f44 j_mayer
    /* XXX : not implemented */
3426 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3427 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3428 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3429 80d11f44 j_mayer
                 0x00000000);
3430 80d11f44 j_mayer
    /* Memory management */
3431 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3432 80d11f44 j_mayer
    env->nb_tlb = 64;
3433 80d11f44 j_mayer
    env->nb_ways = 1;
3434 80d11f44 j_mayer
    env->id_tlbs = 0;
3435 80d11f44 j_mayer
#endif
3436 80d11f44 j_mayer
    init_excp_BookE(env);
3437 80d11f44 j_mayer
    env->dcache_line_size = 32;
3438 80d11f44 j_mayer
    env->icache_line_size = 32;
3439 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3440 80d11f44 j_mayer
}
3441 80d11f44 j_mayer
3442 80d11f44 j_mayer
/* PowerPC 440x4                                                             */
3443 082c6681 j_mayer
#define POWERPC_INSNS_440x4  (PPC_INSNS_BASE | PPC_STRING |                   \
3444 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3445 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3446 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3447 082c6681 j_mayer
                              PPC_MEM_TLBSYNC |                               \
3448 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3449 80d11f44 j_mayer
                              PPC_440_SPEC)
3450 80d11f44 j_mayer
#define POWERPC_MSRM_440x4   (0x000000000006FF30ULL)
3451 80d11f44 j_mayer
#define POWERPC_MMU_440x4    (POWERPC_MMU_BOOKE)
3452 80d11f44 j_mayer
#define POWERPC_EXCP_440x4   (POWERPC_EXCP_BOOKE)
3453 80d11f44 j_mayer
#define POWERPC_INPUT_440x4  (PPC_FLAGS_INPUT_BookE)
3454 80d11f44 j_mayer
#define POWERPC_BFDM_440x4   (bfd_mach_ppc_403)
3455 80d11f44 j_mayer
#define POWERPC_FLAG_440x4   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3456 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3457 80d11f44 j_mayer
#define check_pow_440x4      check_pow_nocheck
3458 80d11f44 j_mayer
3459 80d11f44 j_mayer
__attribute__ (( unused ))
3460 80d11f44 j_mayer
static void init_proc_440x4 (CPUPPCState *env)
3461 80d11f44 j_mayer
{
3462 80d11f44 j_mayer
    /* Time base */
3463 80d11f44 j_mayer
    gen_tbl(env);
3464 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3465 80d11f44 j_mayer
    gen_spr_440(env);
3466 80d11f44 j_mayer
    gen_spr_usprgh(env);
3467 80d11f44 j_mayer
    /* Processor identification */
3468 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3469 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3470 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3471 80d11f44 j_mayer
                 0x00000000);
3472 80d11f44 j_mayer
    /* XXX : not implemented */
3473 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3474 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3475 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3476 80d11f44 j_mayer
                 0x00000000);
3477 80d11f44 j_mayer
    /* XXX : not implemented */
3478 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3479 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3480 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3481 80d11f44 j_mayer
                 0x00000000);
3482 80d11f44 j_mayer
    /* XXX : not implemented */
3483 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3484 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3485 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3486 80d11f44 j_mayer
                 0x00000000);
3487 80d11f44 j_mayer
    /* XXX : not implemented */
3488 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3489 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3490 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3491 80d11f44 j_mayer
                 0x00000000);
3492 80d11f44 j_mayer
    /* Memory management */
3493 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3494 80d11f44 j_mayer
    env->nb_tlb = 64;
3495 80d11f44 j_mayer
    env->nb_ways = 1;
3496 80d11f44 j_mayer
    env->id_tlbs = 0;
3497 80d11f44 j_mayer
#endif
3498 80d11f44 j_mayer
    init_excp_BookE(env);
3499 d63001d1 j_mayer
    env->dcache_line_size = 32;
3500 d63001d1 j_mayer
    env->icache_line_size = 32;
3501 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3502 3fc6c082 bellard
}
3503 3fc6c082 bellard
3504 80d11f44 j_mayer
/* PowerPC 440x5                                                             */
3505 082c6681 j_mayer
#define POWERPC_INSNS_440x5  (PPC_INSNS_BASE | PPC_STRING |                   \
3506 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE | PPC_RFMCI |               \
3507 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3508 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3509 082c6681 j_mayer
                              PPC_MEM_TLBSYNC |                               \
3510 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3511 082c6681 j_mayer
                              PPC_440_SPEC)
3512 80d11f44 j_mayer
#define POWERPC_MSRM_440x5   (0x000000000006FF30ULL)
3513 80d11f44 j_mayer
#define POWERPC_MMU_440x5    (POWERPC_MMU_BOOKE)
3514 80d11f44 j_mayer
#define POWERPC_EXCP_440x5   (POWERPC_EXCP_BOOKE)
3515 80d11f44 j_mayer
#define POWERPC_INPUT_440x5  (PPC_FLAGS_INPUT_BookE)
3516 80d11f44 j_mayer
#define POWERPC_BFDM_440x5   (bfd_mach_ppc_403)
3517 80d11f44 j_mayer
#define POWERPC_FLAG_440x5   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |           \
3518 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3519 80d11f44 j_mayer
#define check_pow_440x5      check_pow_nocheck
3520 a750fc0b j_mayer
3521 80d11f44 j_mayer
__attribute__ (( unused ))
3522 80d11f44 j_mayer
static void init_proc_440x5 (CPUPPCState *env)
3523 3fc6c082 bellard
{
3524 a750fc0b j_mayer
    /* Time base */
3525 a750fc0b j_mayer
    gen_tbl(env);
3526 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3527 80d11f44 j_mayer
    gen_spr_440(env);
3528 80d11f44 j_mayer
    gen_spr_usprgh(env);
3529 80d11f44 j_mayer
    /* Processor identification */
3530 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3531 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3532 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3533 80d11f44 j_mayer
                 0x00000000);
3534 80d11f44 j_mayer
    /* XXX : not implemented */
3535 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3536 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3537 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3538 80d11f44 j_mayer
                 0x00000000);
3539 80d11f44 j_mayer
    /* XXX : not implemented */
3540 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3541 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3542 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3543 80d11f44 j_mayer
                 0x00000000);
3544 80d11f44 j_mayer
    /* XXX : not implemented */
3545 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3546 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3547 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3548 80d11f44 j_mayer
                 0x00000000);
3549 80d11f44 j_mayer
    /* XXX : not implemented */
3550 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3551 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3552 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3553 80d11f44 j_mayer
                 0x00000000);
3554 80d11f44 j_mayer
    /* XXX : not implemented */
3555 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3556 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3557 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3558 80d11f44 j_mayer
                 0x00000000);
3559 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3560 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3561 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3562 80d11f44 j_mayer
                 0x00000000);
3563 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3564 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3565 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3566 80d11f44 j_mayer
                 0x00000000);
3567 80d11f44 j_mayer
    /* XXX : not implemented */
3568 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3569 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3570 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3571 a750fc0b j_mayer
                 0x00000000);
3572 a750fc0b j_mayer
    /* Memory management */
3573 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3574 a750fc0b j_mayer
    env->nb_tlb = 64;
3575 a750fc0b j_mayer
    env->nb_ways = 1;
3576 a750fc0b j_mayer
    env->id_tlbs = 0;
3577 f2e63a42 j_mayer
#endif
3578 80d11f44 j_mayer
    init_excp_BookE(env);
3579 d63001d1 j_mayer
    env->dcache_line_size = 32;
3580 d63001d1 j_mayer
    env->icache_line_size = 32;
3581 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3582 3fc6c082 bellard
}
3583 3fc6c082 bellard
3584 80d11f44 j_mayer
/* PowerPC 460 (guessed)                                                     */
3585 082c6681 j_mayer
#define POWERPC_INSNS_460    (PPC_INSNS_BASE | PPC_STRING |                   \
3586 80d11f44 j_mayer
                              PPC_DCR | PPC_DCRX  | PPC_DCRUX |               \
3587 082c6681 j_mayer
                              PPC_WRTEE | PPC_MFAPIDI |                       \
3588 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3589 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3590 082c6681 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVA |                  \
3591 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3592 082c6681 j_mayer
                              PPC_440_SPEC)
3593 80d11f44 j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3594 80d11f44 j_mayer
#define POWERPC_MMU_460      (POWERPC_MMU_BOOKE)
3595 80d11f44 j_mayer
#define POWERPC_EXCP_460     (POWERPC_EXCP_BOOKE)
3596 80d11f44 j_mayer
#define POWERPC_INPUT_460    (PPC_FLAGS_INPUT_BookE)
3597 80d11f44 j_mayer
#define POWERPC_BFDM_460     (bfd_mach_ppc_403)
3598 80d11f44 j_mayer
#define POWERPC_FLAG_460     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3599 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3600 80d11f44 j_mayer
#define check_pow_460        check_pow_nocheck
3601 a750fc0b j_mayer
3602 80d11f44 j_mayer
__attribute__ (( unused ))
3603 80d11f44 j_mayer
static void init_proc_460 (CPUPPCState *env)
3604 3fc6c082 bellard
{
3605 a750fc0b j_mayer
    /* Time base */
3606 a750fc0b j_mayer
    gen_tbl(env);
3607 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3608 a750fc0b j_mayer
    gen_spr_440(env);
3609 80d11f44 j_mayer
    gen_spr_usprgh(env);
3610 80d11f44 j_mayer
    /* Processor identification */
3611 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3612 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3613 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3614 80d11f44 j_mayer
                 0x00000000);
3615 80d11f44 j_mayer
    /* XXX : not implemented */
3616 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3617 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3618 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3619 80d11f44 j_mayer
                 0x00000000);
3620 80d11f44 j_mayer
    /* XXX : not implemented */
3621 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3622 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3623 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3624 80d11f44 j_mayer
                 0x00000000);
3625 80d11f44 j_mayer
    /* XXX : not implemented */
3626 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3627 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3628 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3629 80d11f44 j_mayer
                 0x00000000);
3630 80d11f44 j_mayer
    /* XXX : not implemented */
3631 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3632 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3633 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3634 80d11f44 j_mayer
                 0x00000000);
3635 578bb252 j_mayer
    /* XXX : not implemented */
3636 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3637 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3638 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3639 a750fc0b j_mayer
                 0x00000000);
3640 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3641 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3642 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3643 a750fc0b j_mayer
                 0x00000000);
3644 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3645 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3646 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3647 a750fc0b j_mayer
                 0x00000000);
3648 578bb252 j_mayer
    /* XXX : not implemented */
3649 a750fc0b j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3650 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3651 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3652 a750fc0b j_mayer
                 0x00000000);
3653 80d11f44 j_mayer
    /* XXX : not implemented */
3654 80d11f44 j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3655 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3656 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3657 80d11f44 j_mayer
                 0x00000000);
3658 a750fc0b j_mayer
    /* Memory management */
3659 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3660 a750fc0b j_mayer
    env->nb_tlb = 64;
3661 a750fc0b j_mayer
    env->nb_ways = 1;
3662 a750fc0b j_mayer
    env->id_tlbs = 0;
3663 f2e63a42 j_mayer
#endif
3664 e1833e1f j_mayer
    init_excp_BookE(env);
3665 d63001d1 j_mayer
    env->dcache_line_size = 32;
3666 d63001d1 j_mayer
    env->icache_line_size = 32;
3667 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3668 3fc6c082 bellard
}
3669 3fc6c082 bellard
3670 80d11f44 j_mayer
/* PowerPC 460F (guessed)                                                    */
3671 082c6681 j_mayer
#define POWERPC_INSNS_460F   (PPC_INSNS_BASE | PPC_STRING |                   \
3672 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FRES | PPC_FLOAT_FSEL |   \
3673 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
3674 80d11f44 j_mayer
                              PPC_FLOAT_STFIWX |                              \
3675 082c6681 j_mayer
                              PPC_DCR | PPC_DCRX | PPC_DCRUX |                \
3676 082c6681 j_mayer
                              PPC_WRTEE | PPC_MFAPIDI |                       \
3677 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3678 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3679 082c6681 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVA |                  \
3680 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3681 082c6681 j_mayer
                              PPC_440_SPEC)
3682 80d11f44 j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3683 80d11f44 j_mayer
#define POWERPC_MMU_460F     (POWERPC_MMU_BOOKE)
3684 80d11f44 j_mayer
#define POWERPC_EXCP_460F    (POWERPC_EXCP_BOOKE)
3685 80d11f44 j_mayer
#define POWERPC_INPUT_460F   (PPC_FLAGS_INPUT_BookE)
3686 80d11f44 j_mayer
#define POWERPC_BFDM_460F    (bfd_mach_ppc_403)
3687 80d11f44 j_mayer
#define POWERPC_FLAG_460F    (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3688 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3689 80d11f44 j_mayer
#define check_pow_460F       check_pow_nocheck
3690 a750fc0b j_mayer
3691 80d11f44 j_mayer
__attribute__ (( unused ))
3692 80d11f44 j_mayer
static void init_proc_460F (CPUPPCState *env)
3693 3fc6c082 bellard
{
3694 a750fc0b j_mayer
    /* Time base */
3695 a750fc0b j_mayer
    gen_tbl(env);
3696 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3697 a750fc0b j_mayer
    gen_spr_440(env);
3698 80d11f44 j_mayer
    gen_spr_usprgh(env);
3699 80d11f44 j_mayer
    /* Processor identification */
3700 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3701 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3702 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3703 80d11f44 j_mayer
                 0x00000000);
3704 80d11f44 j_mayer
    /* XXX : not implemented */
3705 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3706 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3707 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3708 80d11f44 j_mayer
                 0x00000000);
3709 80d11f44 j_mayer
    /* XXX : not implemented */
3710 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3711 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3712 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3713 80d11f44 j_mayer
                 0x00000000);
3714 80d11f44 j_mayer
    /* XXX : not implemented */
3715 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3716 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3717 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3718 80d11f44 j_mayer
                 0x00000000);
3719 80d11f44 j_mayer
    /* XXX : not implemented */
3720 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3721 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3722 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3723 80d11f44 j_mayer
                 0x00000000);
3724 80d11f44 j_mayer
    /* XXX : not implemented */
3725 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3726 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3727 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3728 80d11f44 j_mayer
                 0x00000000);
3729 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3730 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3731 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3732 80d11f44 j_mayer
                 0x00000000);
3733 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3734 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3735 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3736 80d11f44 j_mayer
                 0x00000000);
3737 80d11f44 j_mayer
    /* XXX : not implemented */
3738 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3739 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3740 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3741 80d11f44 j_mayer
                 0x00000000);
3742 80d11f44 j_mayer
    /* XXX : not implemented */
3743 80d11f44 j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3744 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3745 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3746 80d11f44 j_mayer
                 0x00000000);
3747 a750fc0b j_mayer
    /* Memory management */
3748 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3749 a750fc0b j_mayer
    env->nb_tlb = 64;
3750 a750fc0b j_mayer
    env->nb_ways = 1;
3751 a750fc0b j_mayer
    env->id_tlbs = 0;
3752 f2e63a42 j_mayer
#endif
3753 e1833e1f j_mayer
    init_excp_BookE(env);
3754 d63001d1 j_mayer
    env->dcache_line_size = 32;
3755 d63001d1 j_mayer
    env->icache_line_size = 32;
3756 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3757 3fc6c082 bellard
}
3758 3fc6c082 bellard
3759 80d11f44 j_mayer
/* Freescale 5xx cores (aka RCPU) */
3760 80d11f44 j_mayer
#define POWERPC_INSNS_MPC5xx (PPC_INSNS_BASE | PPC_STRING |                   \
3761 80d11f44 j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_SYNC |                  \
3762 80d11f44 j_mayer
                              PPC_CACHE_ICBI | PPC_FLOAT | PPC_FLOAT_STFIWX | \
3763 80d11f44 j_mayer
                              PPC_MFTB)
3764 80d11f44 j_mayer
#define POWERPC_MSRM_MPC5xx  (0x000000000001FF43ULL)
3765 80d11f44 j_mayer
#define POWERPC_MMU_MPC5xx   (POWERPC_MMU_REAL)
3766 80d11f44 j_mayer
#define POWERPC_EXCP_MPC5xx  (POWERPC_EXCP_603)
3767 80d11f44 j_mayer
#define POWERPC_INPUT_MPC5xx (PPC_FLAGS_INPUT_RCPU)
3768 80d11f44 j_mayer
#define POWERPC_BFDM_MPC5xx  (bfd_mach_ppc_505)
3769 4018bae9 j_mayer
#define POWERPC_FLAG_MPC5xx  (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3770 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3771 80d11f44 j_mayer
#define check_pow_MPC5xx     check_pow_none
3772 80d11f44 j_mayer
3773 80d11f44 j_mayer
__attribute__ (( unused ))
3774 80d11f44 j_mayer
static void init_proc_MPC5xx (CPUPPCState *env)
3775 80d11f44 j_mayer
{
3776 80d11f44 j_mayer
    /* Time base */
3777 80d11f44 j_mayer
    gen_tbl(env);
3778 80d11f44 j_mayer
    gen_spr_5xx_8xx(env);
3779 80d11f44 j_mayer
    gen_spr_5xx(env);
3780 80d11f44 j_mayer
    init_excp_MPC5xx(env);
3781 80d11f44 j_mayer
    env->dcache_line_size = 32;
3782 80d11f44 j_mayer
    env->icache_line_size = 32;
3783 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3784 80d11f44 j_mayer
}
3785 80d11f44 j_mayer
3786 80d11f44 j_mayer
/* Freescale 8xx cores (aka PowerQUICC) */
3787 80d11f44 j_mayer
#define POWERPC_INSNS_MPC8xx (PPC_INSNS_BASE | PPC_STRING  |                  \
3788 80d11f44 j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_SYNC |                  \
3789 80d11f44 j_mayer
                              PPC_CACHE_ICBI | PPC_MFTB)
3790 80d11f44 j_mayer
#define POWERPC_MSRM_MPC8xx  (0x000000000001F673ULL)
3791 80d11f44 j_mayer
#define POWERPC_MMU_MPC8xx   (POWERPC_MMU_MPC8xx)
3792 80d11f44 j_mayer
#define POWERPC_EXCP_MPC8xx  (POWERPC_EXCP_603)
3793 80d11f44 j_mayer
#define POWERPC_INPUT_MPC8xx (PPC_FLAGS_INPUT_RCPU)
3794 80d11f44 j_mayer
#define POWERPC_BFDM_MPC8xx  (bfd_mach_ppc_860)
3795 4018bae9 j_mayer
#define POWERPC_FLAG_MPC8xx  (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3796 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3797 80d11f44 j_mayer
#define check_pow_MPC8xx     check_pow_none
3798 80d11f44 j_mayer
3799 80d11f44 j_mayer
__attribute__ (( unused ))
3800 80d11f44 j_mayer
static void init_proc_MPC8xx (CPUPPCState *env)
3801 80d11f44 j_mayer
{
3802 80d11f44 j_mayer
    /* Time base */
3803 80d11f44 j_mayer
    gen_tbl(env);
3804 80d11f44 j_mayer
    gen_spr_5xx_8xx(env);
3805 80d11f44 j_mayer
    gen_spr_8xx(env);
3806 80d11f44 j_mayer
    init_excp_MPC8xx(env);
3807 80d11f44 j_mayer
    env->dcache_line_size = 32;
3808 80d11f44 j_mayer
    env->icache_line_size = 32;
3809 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3810 80d11f44 j_mayer
}
3811 80d11f44 j_mayer
3812 80d11f44 j_mayer
/* Freescale 82xx cores (aka PowerQUICC-II)                                  */
3813 80d11f44 j_mayer
/* PowerPC G2                                                                */
3814 082c6681 j_mayer
#define POWERPC_INSNS_G2     (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3815 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
3816 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
3817 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
3818 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3819 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
3820 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
3821 80d11f44 j_mayer
#define POWERPC_MSRM_G2      (0x000000000006FFF2ULL)
3822 80d11f44 j_mayer
#define POWERPC_MMU_G2       (POWERPC_MMU_SOFT_6xx)
3823 80d11f44 j_mayer
//#define POWERPC_EXCP_G2      (POWERPC_EXCP_G2)
3824 80d11f44 j_mayer
#define POWERPC_INPUT_G2     (PPC_FLAGS_INPUT_6xx)
3825 80d11f44 j_mayer
#define POWERPC_BFDM_G2      (bfd_mach_ppc_ec603e)
3826 80d11f44 j_mayer
#define POWERPC_FLAG_G2      (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3827 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
3828 80d11f44 j_mayer
#define check_pow_G2         check_pow_hid0
3829 a750fc0b j_mayer
3830 80d11f44 j_mayer
static void init_proc_G2 (CPUPPCState *env)
3831 3fc6c082 bellard
{
3832 80d11f44 j_mayer
    gen_spr_ne_601(env);
3833 80d11f44 j_mayer
    gen_spr_G2_755(env);
3834 80d11f44 j_mayer
    gen_spr_G2(env);
3835 a750fc0b j_mayer
    /* Time base */
3836 a750fc0b j_mayer
    gen_tbl(env);
3837 80d11f44 j_mayer
    /* Hardware implementation register */
3838 80d11f44 j_mayer
    /* XXX : not implemented */
3839 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
3840 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3841 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3842 80d11f44 j_mayer
                 0x00000000);
3843 80d11f44 j_mayer
    /* XXX : not implemented */
3844 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
3845 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3846 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3847 80d11f44 j_mayer
                 0x00000000);
3848 80d11f44 j_mayer
    /* XXX : not implemented */
3849 80d11f44 j_mayer
    spr_register(env, SPR_HID2, "HID2",
3850 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3851 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3852 80d11f44 j_mayer
                 0x00000000);
3853 a750fc0b j_mayer
    /* Memory management */
3854 80d11f44 j_mayer
    gen_low_BATs(env);
3855 80d11f44 j_mayer
    gen_high_BATs(env);
3856 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3857 80d11f44 j_mayer
    init_excp_G2(env);
3858 d63001d1 j_mayer
    env->dcache_line_size = 32;
3859 d63001d1 j_mayer
    env->icache_line_size = 32;
3860 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3861 80d11f44 j_mayer
    ppc6xx_irq_init(env);
3862 3fc6c082 bellard
}
3863 a750fc0b j_mayer
3864 80d11f44 j_mayer
/* PowerPC G2LE                                                              */
3865 082c6681 j_mayer
#define POWERPC_INSNS_G2LE   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3866 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
3867 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
3868 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
3869 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3870 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
3871 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
3872 80d11f44 j_mayer
#define POWERPC_MSRM_G2LE    (0x000000000007FFF3ULL)
3873 80d11f44 j_mayer
#define POWERPC_MMU_G2LE     (POWERPC_MMU_SOFT_6xx)
3874 80d11f44 j_mayer
#define POWERPC_EXCP_G2LE    (POWERPC_EXCP_G2)
3875 80d11f44 j_mayer
#define POWERPC_INPUT_G2LE   (PPC_FLAGS_INPUT_6xx)
3876 80d11f44 j_mayer
#define POWERPC_BFDM_G2LE    (bfd_mach_ppc_ec603e)
3877 80d11f44 j_mayer
#define POWERPC_FLAG_G2LE    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3878 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
3879 80d11f44 j_mayer
#define check_pow_G2LE       check_pow_hid0
3880 a750fc0b j_mayer
3881 80d11f44 j_mayer
static void init_proc_G2LE (CPUPPCState *env)
3882 3fc6c082 bellard
{
3883 80d11f44 j_mayer
    gen_spr_ne_601(env);
3884 80d11f44 j_mayer
    gen_spr_G2_755(env);
3885 80d11f44 j_mayer
    gen_spr_G2(env);
3886 a750fc0b j_mayer
    /* Time base */
3887 a750fc0b j_mayer
    gen_tbl(env);
3888 80d11f44 j_mayer
    /* Hardware implementation register */
3889 578bb252 j_mayer
    /* XXX : not implemented */
3890 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
3891 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3892 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3893 a750fc0b j_mayer
                 0x00000000);
3894 80d11f44 j_mayer
    /* XXX : not implemented */
3895 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
3896 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3897 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3898 a750fc0b j_mayer
                 0x00000000);
3899 578bb252 j_mayer
    /* XXX : not implemented */
3900 80d11f44 j_mayer
    spr_register(env, SPR_HID2, "HID2",
3901 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3902 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3903 a750fc0b j_mayer
                 0x00000000);
3904 a750fc0b j_mayer
    /* Memory management */
3905 80d11f44 j_mayer
    gen_low_BATs(env);
3906 80d11f44 j_mayer
    gen_high_BATs(env);
3907 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3908 80d11f44 j_mayer
    init_excp_G2(env);
3909 d63001d1 j_mayer
    env->dcache_line_size = 32;
3910 d63001d1 j_mayer
    env->icache_line_size = 32;
3911 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3912 80d11f44 j_mayer
    ppc6xx_irq_init(env);
3913 3fc6c082 bellard
}
3914 3fc6c082 bellard
3915 80d11f44 j_mayer
/* e200 core                                                                 */
3916 80d11f44 j_mayer
/* XXX: unimplemented instructions:
3917 80d11f44 j_mayer
 * dcblc
3918 80d11f44 j_mayer
 * dcbtlst
3919 80d11f44 j_mayer
 * dcbtstls
3920 80d11f44 j_mayer
 * icblc
3921 80d11f44 j_mayer
 * icbtls
3922 80d11f44 j_mayer
 * tlbivax
3923 80d11f44 j_mayer
 * all SPE multiply-accumulate instructions
3924 80d11f44 j_mayer
 */
3925 082c6681 j_mayer
#define POWERPC_INSNS_e200   (PPC_INSNS_BASE | PPC_ISEL |                     \
3926 80d11f44 j_mayer
                              PPC_SPE | PPC_SPEFPU |                          \
3927 082c6681 j_mayer
                              PPC_WRTEE | PPC_RFDI |                          \
3928 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI |   \
3929 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3930 80d11f44 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVAX |                 \
3931 082c6681 j_mayer
                              PPC_BOOKE)
3932 80d11f44 j_mayer
#define POWERPC_MSRM_e200    (0x000000000606FF30ULL)
3933 80d11f44 j_mayer
#define POWERPC_MMU_e200     (POWERPC_MMU_BOOKE_FSL)
3934 80d11f44 j_mayer
#define POWERPC_EXCP_e200    (POWERPC_EXCP_BOOKE)
3935 80d11f44 j_mayer
#define POWERPC_INPUT_e200   (PPC_FLAGS_INPUT_BookE)
3936 80d11f44 j_mayer
#define POWERPC_BFDM_e200    (bfd_mach_ppc_860)
3937 80d11f44 j_mayer
#define POWERPC_FLAG_e200    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |            \
3938 4018bae9 j_mayer
                              POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |           \
3939 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3940 80d11f44 j_mayer
#define check_pow_e200       check_pow_hid0
3941 80d11f44 j_mayer
3942 578bb252 j_mayer
__attribute__ (( unused ))
3943 80d11f44 j_mayer
static void init_proc_e200 (CPUPPCState *env)
3944 3fc6c082 bellard
{
3945 e1833e1f j_mayer
    /* Time base */
3946 e1833e1f j_mayer
    gen_tbl(env);
3947 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000070000FFFFULL);
3948 578bb252 j_mayer
    /* XXX : not implemented */
3949 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_SPEFSCR, "SPEFSCR",
3950 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3951 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3952 e1833e1f j_mayer
                 0x00000000);
3953 80d11f44 j_mayer
    /* Memory management */
3954 80d11f44 j_mayer
    gen_spr_BookE_FSL(env, 0x0000005D);
3955 80d11f44 j_mayer
    /* XXX : not implemented */
3956 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
3957 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3958 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3959 e1833e1f j_mayer
                 0x00000000);
3960 80d11f44 j_mayer
    /* XXX : not implemented */
3961 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
3962 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3963 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3964 e1833e1f j_mayer
                 0x00000000);
3965 578bb252 j_mayer
    /* XXX : not implemented */
3966 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_ALTCTXCR, "ALTCTXCR",
3967 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3968 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3969 e1833e1f j_mayer
                 0x00000000);
3970 578bb252 j_mayer
    /* XXX : not implemented */
3971 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BUCSR, "BUCSR",
3972 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3973 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
3974 80d11f44 j_mayer
                 0x00000000);
3975 80d11f44 j_mayer
    /* XXX : not implemented */
3976 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_CTXCR, "CTXCR",
3977 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3978 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3979 80d11f44 j_mayer
                 0x00000000);
3980 80d11f44 j_mayer
    /* XXX : not implemented */
3981 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_DBCNT, "DBCNT",
3982 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3983 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3984 80d11f44 j_mayer
                 0x00000000);
3985 80d11f44 j_mayer
    /* XXX : not implemented */
3986 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_DBCR3, "DBCR3",
3987 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3988 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3989 80d11f44 j_mayer
                 0x00000000);
3990 80d11f44 j_mayer
    /* XXX : not implemented */
3991 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CFG0, "L1CFG0",
3992 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3993 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3994 80d11f44 j_mayer
                 0x00000000);
3995 80d11f44 j_mayer
    /* XXX : not implemented */
3996 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR0, "L1CSR0",
3997 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3998 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3999 80d11f44 j_mayer
                 0x00000000);
4000 80d11f44 j_mayer
    /* XXX : not implemented */
4001 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1FINV0, "L1FINV0",
4002 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4003 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4004 80d11f44 j_mayer
                 0x00000000);
4005 80d11f44 j_mayer
    /* XXX : not implemented */
4006 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
4007 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4008 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4009 80d11f44 j_mayer
                 0x00000000);
4010 80d11f44 j_mayer
    /* XXX : not implemented */
4011 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
4012 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4013 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4014 80d11f44 j_mayer
                 0x00000000);
4015 80d11f44 j_mayer
    /* XXX : not implemented */
4016 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
4017 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4018 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4019 80d11f44 j_mayer
                 0x00000000);
4020 80d11f44 j_mayer
    /* XXX : not implemented */
4021 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
4022 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4023 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4024 80d11f44 j_mayer
                 0x00000000);
4025 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DSRR0, "DSRR0",
4026 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4027 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4028 80d11f44 j_mayer
                 0x00000000);
4029 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DSRR1, "DSRR1",
4030 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4031 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4032 e1833e1f j_mayer
                 0x00000000);
4033 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4034 e1833e1f j_mayer
    env->nb_tlb = 64;
4035 e1833e1f j_mayer
    env->nb_ways = 1;
4036 e1833e1f j_mayer
    env->id_tlbs = 0;
4037 f2e63a42 j_mayer
#endif
4038 80d11f44 j_mayer
    init_excp_e200(env);
4039 d63001d1 j_mayer
    env->dcache_line_size = 32;
4040 d63001d1 j_mayer
    env->icache_line_size = 32;
4041 e1833e1f j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
4042 3fc6c082 bellard
}
4043 a750fc0b j_mayer
4044 80d11f44 j_mayer
/* e300 core                                                                 */
4045 082c6681 j_mayer
#define POWERPC_INSNS_e300   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4046 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4047 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4048 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4049 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4050 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4051 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4052 80d11f44 j_mayer
#define POWERPC_MSRM_e300    (0x000000000007FFF3ULL)
4053 80d11f44 j_mayer
#define POWERPC_MMU_e300     (POWERPC_MMU_SOFT_6xx)
4054 80d11f44 j_mayer
#define POWERPC_EXCP_e300    (POWERPC_EXCP_603)
4055 80d11f44 j_mayer
#define POWERPC_INPUT_e300   (PPC_FLAGS_INPUT_6xx)
4056 80d11f44 j_mayer
#define POWERPC_BFDM_e300    (bfd_mach_ppc_603)
4057 80d11f44 j_mayer
#define POWERPC_FLAG_e300    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4058 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4059 80d11f44 j_mayer
#define check_pow_e300       check_pow_hid0
4060 a750fc0b j_mayer
4061 578bb252 j_mayer
__attribute__ (( unused ))
4062 80d11f44 j_mayer
static void init_proc_e300 (CPUPPCState *env)
4063 3fc6c082 bellard
{
4064 80d11f44 j_mayer
    gen_spr_ne_601(env);
4065 80d11f44 j_mayer
    gen_spr_603(env);
4066 a750fc0b j_mayer
    /* Time base */
4067 a750fc0b j_mayer
    gen_tbl(env);
4068 80d11f44 j_mayer
    /* hardware implementation registers */
4069 80d11f44 j_mayer
    /* XXX : not implemented */
4070 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4071 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4072 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4073 80d11f44 j_mayer
                 0x00000000);
4074 80d11f44 j_mayer
    /* XXX : not implemented */
4075 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4076 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4077 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4078 80d11f44 j_mayer
                 0x00000000);
4079 80d11f44 j_mayer
    /* Memory management */
4080 80d11f44 j_mayer
    gen_low_BATs(env);
4081 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4082 80d11f44 j_mayer
    init_excp_603(env);
4083 80d11f44 j_mayer
    env->dcache_line_size = 32;
4084 80d11f44 j_mayer
    env->icache_line_size = 32;
4085 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
4086 80d11f44 j_mayer
    ppc6xx_irq_init(env);
4087 80d11f44 j_mayer
}
4088 80d11f44 j_mayer
4089 80d11f44 j_mayer
/* e500 core                                                                 */
4090 082c6681 j_mayer
#define POWERPC_INSNS_e500   (PPC_INSNS_BASE | PPC_ISEL |                     \
4091 80d11f44 j_mayer
                              PPC_SPE | PPC_SPEFPU |                          \
4092 082c6681 j_mayer
                              PPC_WRTEE | PPC_RFDI |                          \
4093 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI |   \
4094 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
4095 80d11f44 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVAX |                 \
4096 082c6681 j_mayer
                              PPC_BOOKE)
4097 80d11f44 j_mayer
#define POWERPC_MSRM_e500    (0x000000000606FF30ULL)
4098 80d11f44 j_mayer
#define POWERPC_MMU_e500     (POWERPC_MMU_BOOKE_FSL)
4099 80d11f44 j_mayer
#define POWERPC_EXCP_e500    (POWERPC_EXCP_BOOKE)
4100 80d11f44 j_mayer
#define POWERPC_INPUT_e500   (PPC_FLAGS_INPUT_BookE)
4101 80d11f44 j_mayer
#define POWERPC_BFDM_e500    (bfd_mach_ppc_860)
4102 80d11f44 j_mayer
#define POWERPC_FLAG_e500    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |            \
4103 4018bae9 j_mayer
                              POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |           \
4104 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4105 80d11f44 j_mayer
#define check_pow_e500       check_pow_hid0
4106 80d11f44 j_mayer
4107 80d11f44 j_mayer
__attribute__ (( unused ))
4108 80d11f44 j_mayer
static void init_proc_e500 (CPUPPCState *env)
4109 80d11f44 j_mayer
{
4110 80d11f44 j_mayer
    /* Time base */
4111 80d11f44 j_mayer
    gen_tbl(env);
4112 80d11f44 j_mayer
    gen_spr_BookE(env, 0x0000000F0000FD7FULL);
4113 80d11f44 j_mayer
    /* Processor identification */
4114 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
4115 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4116 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
4117 80d11f44 j_mayer
                 0x00000000);
4118 80d11f44 j_mayer
    /* XXX : not implemented */
4119 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_SPEFSCR, "SPEFSCR",
4120 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4121 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4122 80d11f44 j_mayer
                 0x00000000);
4123 80d11f44 j_mayer
    /* Memory management */
4124 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
4125 80d11f44 j_mayer
    env->nb_pids = 3;
4126 80d11f44 j_mayer
#endif
4127 80d11f44 j_mayer
    gen_spr_BookE_FSL(env, 0x0000005F);
4128 80d11f44 j_mayer
    /* XXX : not implemented */
4129 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4130 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4131 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4132 80d11f44 j_mayer
                 0x00000000);
4133 80d11f44 j_mayer
    /* XXX : not implemented */
4134 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4135 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4136 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4137 80d11f44 j_mayer
                 0x00000000);
4138 80d11f44 j_mayer
    /* XXX : not implemented */
4139 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BBEAR, "BBEAR",
4140 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4141 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4142 80d11f44 j_mayer
                 0x00000000);
4143 80d11f44 j_mayer
    /* XXX : not implemented */
4144 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BBTAR, "BBTAR",
4145 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4146 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4147 80d11f44 j_mayer
                 0x00000000);
4148 80d11f44 j_mayer
    /* XXX : not implemented */
4149 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_MCAR, "MCAR",
4150 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4151 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4152 80d11f44 j_mayer
                 0x00000000);
4153 578bb252 j_mayer
    /* XXX : not implemented */
4154 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
4155 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4156 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4157 a750fc0b j_mayer
                 0x00000000);
4158 80d11f44 j_mayer
    /* XXX : not implemented */
4159 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_NPIDR, "NPIDR",
4160 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4161 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4162 a750fc0b j_mayer
                 0x00000000);
4163 80d11f44 j_mayer
    /* XXX : not implemented */
4164 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BUCSR, "BUCSR",
4165 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4166 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4167 a750fc0b j_mayer
                 0x00000000);
4168 578bb252 j_mayer
    /* XXX : not implemented */
4169 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CFG0, "L1CFG0",
4170 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4171 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4172 a750fc0b j_mayer
                 0x00000000);
4173 578bb252 j_mayer
    /* XXX : not implemented */
4174 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR0, "L1CSR0",
4175 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4176 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4177 80d11f44 j_mayer
                 0x00000000);
4178 80d11f44 j_mayer
    /* XXX : not implemented */
4179 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR1, "L1CSR1",
4180 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4181 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4182 80d11f44 j_mayer
                 0x00000000);
4183 80d11f44 j_mayer
    /* XXX : not implemented */
4184 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
4185 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4186 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4187 80d11f44 j_mayer
                 0x00000000);
4188 80d11f44 j_mayer
    /* XXX : not implemented */
4189 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
4190 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4191 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4192 80d11f44 j_mayer
                 0x00000000);
4193 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
4194 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4195 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4196 80d11f44 j_mayer
                 0x00000000);
4197 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
4198 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4199 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4200 a750fc0b j_mayer
                 0x00000000);
4201 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4202 a750fc0b j_mayer
    env->nb_tlb = 64;
4203 a750fc0b j_mayer
    env->nb_ways = 1;
4204 a750fc0b j_mayer
    env->id_tlbs = 0;
4205 f2e63a42 j_mayer
#endif
4206 80d11f44 j_mayer
    init_excp_e200(env);
4207 d63001d1 j_mayer
    env->dcache_line_size = 32;
4208 d63001d1 j_mayer
    env->icache_line_size = 32;
4209 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
4210 3fc6c082 bellard
}
4211 a750fc0b j_mayer
4212 a750fc0b j_mayer
/* Non-embedded PowerPC                                                      */
4213 a750fc0b j_mayer
4214 a750fc0b j_mayer
/* POWER : same as 601, without mfmsr, mfsr                                  */
4215 a750fc0b j_mayer
#if defined(TODO)
4216 a750fc0b j_mayer
#define POWERPC_INSNS_POWER  (XXX_TODO)
4217 a750fc0b j_mayer
/* POWER RSC (from RAD6000) */
4218 a750fc0b j_mayer
#define POWERPC_MSRM_POWER   (0x00000000FEF0ULL)
4219 a750fc0b j_mayer
#endif /* TODO */
4220 a750fc0b j_mayer
4221 a750fc0b j_mayer
/* PowerPC 601                                                               */
4222 082c6681 j_mayer
#define POWERPC_INSNS_601    (PPC_INSNS_BASE | PPC_STRING | PPC_POWER_BR |    \
4223 082c6681 j_mayer
                              PPC_FLOAT |                                     \
4224 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4225 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_MEM_TLBIE |  \
4226 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4227 25ba3a68 j_mayer
#define POWERPC_MSRM_601     (0x000000000000FD70ULL)
4228 082c6681 j_mayer
#define POWERPC_MSRR_601     (0x0000000000001040ULL)
4229 faadf50e j_mayer
//#define POWERPC_MMU_601      (POWERPC_MMU_601)
4230 a750fc0b j_mayer
//#define POWERPC_EXCP_601     (POWERPC_EXCP_601)
4231 a750fc0b j_mayer
#define POWERPC_INPUT_601    (PPC_FLAGS_INPUT_6xx)
4232 237c0af0 j_mayer
#define POWERPC_BFDM_601     (bfd_mach_ppc_601)
4233 4018bae9 j_mayer
#define POWERPC_FLAG_601     (POWERPC_FLAG_SE | POWERPC_FLAG_RTC_CLK)
4234 2f462816 j_mayer
#define check_pow_601        check_pow_none
4235 a750fc0b j_mayer
4236 a750fc0b j_mayer
static void init_proc_601 (CPUPPCState *env)
4237 3fc6c082 bellard
{
4238 a750fc0b j_mayer
    gen_spr_ne_601(env);
4239 a750fc0b j_mayer
    gen_spr_601(env);
4240 a750fc0b j_mayer
    /* Hardware implementation registers */
4241 a750fc0b j_mayer
    /* XXX : not implemented */
4242 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4243 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4244 056401ea j_mayer
                 &spr_read_generic, &spr_write_hid0_601,
4245 faadf50e j_mayer
                 0x80010080);
4246 a750fc0b j_mayer
    /* XXX : not implemented */
4247 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4248 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4249 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4250 a750fc0b j_mayer
                 0x00000000);
4251 a750fc0b j_mayer
    /* XXX : not implemented */
4252 a750fc0b j_mayer
    spr_register(env, SPR_601_HID2, "HID2",
4253 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4254 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4255 a750fc0b j_mayer
                 0x00000000);
4256 a750fc0b j_mayer
    /* XXX : not implemented */
4257 a750fc0b j_mayer
    spr_register(env, SPR_601_HID5, "HID5",
4258 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4259 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4260 a750fc0b j_mayer
                 0x00000000);
4261 a750fc0b j_mayer
    /* Memory management */
4262 e1833e1f j_mayer
    init_excp_601(env);
4263 082c6681 j_mayer
    /* XXX: beware that dcache line size is 64 
4264 082c6681 j_mayer
     *      but dcbz uses 32 bytes "sectors"
4265 082c6681 j_mayer
     * XXX: this breaks clcs instruction !
4266 082c6681 j_mayer
     */
4267 082c6681 j_mayer
    env->dcache_line_size = 32;
4268 d63001d1 j_mayer
    env->icache_line_size = 64;
4269 faadf50e j_mayer
    /* Allocate hardware IRQ controller */
4270 faadf50e j_mayer
    ppc6xx_irq_init(env);
4271 3fc6c082 bellard
}
4272 3fc6c082 bellard
4273 082c6681 j_mayer
/* PowerPC 601v                                                              */
4274 082c6681 j_mayer
#define POWERPC_INSNS_601v   (PPC_INSNS_BASE | PPC_STRING | PPC_POWER_BR |    \
4275 082c6681 j_mayer
                              PPC_FLOAT |                                     \
4276 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4277 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_MEM_TLBIE |  \
4278 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4279 082c6681 j_mayer
#define POWERPC_MSRM_601v    (0x000000000000FD70ULL)
4280 082c6681 j_mayer
#define POWERPC_MSRR_601v    (0x0000000000001040ULL)
4281 082c6681 j_mayer
#define POWERPC_MMU_601v     (POWERPC_MMU_601)
4282 082c6681 j_mayer
#define POWERPC_EXCP_601v    (POWERPC_EXCP_601)
4283 082c6681 j_mayer
#define POWERPC_INPUT_601v   (PPC_FLAGS_INPUT_6xx)
4284 082c6681 j_mayer
#define POWERPC_BFDM_601v    (bfd_mach_ppc_601)
4285 082c6681 j_mayer
#define POWERPC_FLAG_601v    (POWERPC_FLAG_SE | POWERPC_FLAG_RTC_CLK)
4286 082c6681 j_mayer
#define check_pow_601v       check_pow_none
4287 082c6681 j_mayer
4288 082c6681 j_mayer
static void init_proc_601v (CPUPPCState *env)
4289 082c6681 j_mayer
{
4290 082c6681 j_mayer
    init_proc_601(env);
4291 082c6681 j_mayer
    /* XXX : not implemented */
4292 082c6681 j_mayer
    spr_register(env, SPR_601_HID15, "HID15",
4293 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4294 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4295 082c6681 j_mayer
                 0x00000000);
4296 082c6681 j_mayer
}
4297 082c6681 j_mayer
4298 a750fc0b j_mayer
/* PowerPC 602                                                               */
4299 082c6681 j_mayer
#define POWERPC_INSNS_602    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4300 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4301 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4302 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4303 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4304 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_6xx_TLB | PPC_MEM_TLBSYNC | \
4305 12de9a39 j_mayer
                              PPC_SEGMENT | PPC_602_SPEC)
4306 082c6681 j_mayer
#define POWERPC_MSRM_602     (0x0000000000C7FF73ULL)
4307 082c6681 j_mayer
/* XXX: 602 MMU is quite specific. Should add a special case */
4308 a750fc0b j_mayer
#define POWERPC_MMU_602      (POWERPC_MMU_SOFT_6xx)
4309 a750fc0b j_mayer
//#define POWERPC_EXCP_602     (POWERPC_EXCP_602)
4310 a750fc0b j_mayer
#define POWERPC_INPUT_602    (PPC_FLAGS_INPUT_6xx)
4311 237c0af0 j_mayer
#define POWERPC_BFDM_602     (bfd_mach_ppc_602)
4312 25ba3a68 j_mayer
#define POWERPC_FLAG_602     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4313 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4314 2f462816 j_mayer
#define check_pow_602        check_pow_hid0
4315 a750fc0b j_mayer
4316 a750fc0b j_mayer
static void init_proc_602 (CPUPPCState *env)
4317 3fc6c082 bellard
{
4318 a750fc0b j_mayer
    gen_spr_ne_601(env);
4319 a750fc0b j_mayer
    gen_spr_602(env);
4320 a750fc0b j_mayer
    /* Time base */
4321 a750fc0b j_mayer
    gen_tbl(env);
4322 a750fc0b j_mayer
    /* hardware implementation registers */
4323 a750fc0b j_mayer
    /* XXX : not implemented */
4324 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4325 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4326 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4327 a750fc0b j_mayer
                 0x00000000);
4328 a750fc0b j_mayer
    /* XXX : not implemented */
4329 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4330 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4331 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4332 a750fc0b j_mayer
                 0x00000000);
4333 a750fc0b j_mayer
    /* Memory management */
4334 a750fc0b j_mayer
    gen_low_BATs(env);
4335 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4336 e1833e1f j_mayer
    init_excp_602(env);
4337 d63001d1 j_mayer
    env->dcache_line_size = 32;
4338 d63001d1 j_mayer
    env->icache_line_size = 32;
4339 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4340 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4341 a750fc0b j_mayer
}
4342 3fc6c082 bellard
4343 a750fc0b j_mayer
/* PowerPC 603                                                               */
4344 082c6681 j_mayer
#define POWERPC_INSNS_603    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4345 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4346 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4347 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4348 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4349 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4350 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4351 25ba3a68 j_mayer
#define POWERPC_MSRM_603     (0x000000000007FF73ULL)
4352 a750fc0b j_mayer
#define POWERPC_MMU_603      (POWERPC_MMU_SOFT_6xx)
4353 a750fc0b j_mayer
//#define POWERPC_EXCP_603     (POWERPC_EXCP_603)
4354 a750fc0b j_mayer
#define POWERPC_INPUT_603    (PPC_FLAGS_INPUT_6xx)
4355 237c0af0 j_mayer
#define POWERPC_BFDM_603     (bfd_mach_ppc_603)
4356 25ba3a68 j_mayer
#define POWERPC_FLAG_603     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4357 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4358 2f462816 j_mayer
#define check_pow_603        check_pow_hid0
4359 a750fc0b j_mayer
4360 a750fc0b j_mayer
static void init_proc_603 (CPUPPCState *env)
4361 a750fc0b j_mayer
{
4362 a750fc0b j_mayer
    gen_spr_ne_601(env);
4363 a750fc0b j_mayer
    gen_spr_603(env);
4364 a750fc0b j_mayer
    /* Time base */
4365 a750fc0b j_mayer
    gen_tbl(env);
4366 a750fc0b j_mayer
    /* hardware implementation registers */
4367 a750fc0b j_mayer
    /* XXX : not implemented */
4368 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4369 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4370 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4371 a750fc0b j_mayer
                 0x00000000);
4372 a750fc0b j_mayer
    /* XXX : not implemented */
4373 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4374 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4375 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4376 a750fc0b j_mayer
                 0x00000000);
4377 a750fc0b j_mayer
    /* Memory management */
4378 a750fc0b j_mayer
    gen_low_BATs(env);
4379 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4380 e1833e1f j_mayer
    init_excp_603(env);
4381 d63001d1 j_mayer
    env->dcache_line_size = 32;
4382 d63001d1 j_mayer
    env->icache_line_size = 32;
4383 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4384 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4385 3fc6c082 bellard
}
4386 3fc6c082 bellard
4387 a750fc0b j_mayer
/* PowerPC 603e                                                              */
4388 082c6681 j_mayer
#define POWERPC_INSNS_603E   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4389 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4390 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4391 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4392 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4393 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4394 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4395 a750fc0b j_mayer
#define POWERPC_MSRM_603E    (0x000000000007FF73ULL)
4396 a750fc0b j_mayer
#define POWERPC_MMU_603E     (POWERPC_MMU_SOFT_6xx)
4397 a750fc0b j_mayer
//#define POWERPC_EXCP_603E    (POWERPC_EXCP_603E)
4398 a750fc0b j_mayer
#define POWERPC_INPUT_603E   (PPC_FLAGS_INPUT_6xx)
4399 237c0af0 j_mayer
#define POWERPC_BFDM_603E    (bfd_mach_ppc_ec603e)
4400 25ba3a68 j_mayer
#define POWERPC_FLAG_603E    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4401 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4402 2f462816 j_mayer
#define check_pow_603E       check_pow_hid0
4403 a750fc0b j_mayer
4404 a750fc0b j_mayer
static void init_proc_603E (CPUPPCState *env)
4405 a750fc0b j_mayer
{
4406 a750fc0b j_mayer
    gen_spr_ne_601(env);
4407 a750fc0b j_mayer
    gen_spr_603(env);
4408 a750fc0b j_mayer
    /* Time base */
4409 a750fc0b j_mayer
    gen_tbl(env);
4410 a750fc0b j_mayer
    /* hardware implementation registers */
4411 a750fc0b j_mayer
    /* XXX : not implemented */
4412 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4413 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4414 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4415 a750fc0b j_mayer
                 0x00000000);
4416 a750fc0b j_mayer
    /* XXX : not implemented */
4417 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4418 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4419 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4420 a750fc0b j_mayer
                 0x00000000);
4421 a750fc0b j_mayer
    /* XXX : not implemented */
4422 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
4423 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4424 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4425 a750fc0b j_mayer
                 0x00000000);
4426 a750fc0b j_mayer
    /* Memory management */
4427 a750fc0b j_mayer
    gen_low_BATs(env);
4428 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4429 e1833e1f j_mayer
    init_excp_603(env);
4430 d63001d1 j_mayer
    env->dcache_line_size = 32;
4431 d63001d1 j_mayer
    env->icache_line_size = 32;
4432 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4433 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4434 a750fc0b j_mayer
}
4435 a750fc0b j_mayer
4436 a750fc0b j_mayer
/* PowerPC 604                                                               */
4437 082c6681 j_mayer
#define POWERPC_INSNS_604    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4438 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4439 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4440 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4441 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4442 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4443 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4444 a750fc0b j_mayer
#define POWERPC_MSRM_604     (0x000000000005FF77ULL)
4445 a750fc0b j_mayer
#define POWERPC_MMU_604      (POWERPC_MMU_32B)
4446 a750fc0b j_mayer
//#define POWERPC_EXCP_604     (POWERPC_EXCP_604)
4447 a750fc0b j_mayer
#define POWERPC_INPUT_604    (PPC_FLAGS_INPUT_6xx)
4448 237c0af0 j_mayer
#define POWERPC_BFDM_604     (bfd_mach_ppc_604)
4449 25ba3a68 j_mayer
#define POWERPC_FLAG_604     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4450 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4451 2f462816 j_mayer
#define check_pow_604        check_pow_nocheck
4452 a750fc0b j_mayer
4453 a750fc0b j_mayer
static void init_proc_604 (CPUPPCState *env)
4454 a750fc0b j_mayer
{
4455 a750fc0b j_mayer
    gen_spr_ne_601(env);
4456 a750fc0b j_mayer
    gen_spr_604(env);
4457 a750fc0b j_mayer
    /* Time base */
4458 a750fc0b j_mayer
    gen_tbl(env);
4459 a750fc0b j_mayer
    /* Hardware implementation registers */
4460 a750fc0b j_mayer
    /* XXX : not implemented */
4461 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4462 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4463 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4464 a750fc0b j_mayer
                 0x00000000);
4465 082c6681 j_mayer
    /* Memory management */
4466 082c6681 j_mayer
    gen_low_BATs(env);
4467 082c6681 j_mayer
    init_excp_604(env);
4468 082c6681 j_mayer
    env->dcache_line_size = 32;
4469 082c6681 j_mayer
    env->icache_line_size = 32;
4470 082c6681 j_mayer
    /* Allocate hardware IRQ controller */
4471 082c6681 j_mayer
    ppc6xx_irq_init(env);
4472 082c6681 j_mayer
}
4473 082c6681 j_mayer
4474 082c6681 j_mayer
/* PowerPC 604E                                                              */
4475 082c6681 j_mayer
#define POWERPC_INSNS_604E   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4476 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4477 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4478 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4479 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4480 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4481 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4482 082c6681 j_mayer
#define POWERPC_MSRM_604E    (0x000000000005FF77ULL)
4483 082c6681 j_mayer
#define POWERPC_MMU_604E     (POWERPC_MMU_32B)
4484 082c6681 j_mayer
#define POWERPC_EXCP_604E    (POWERPC_EXCP_604)
4485 082c6681 j_mayer
#define POWERPC_INPUT_604E   (PPC_FLAGS_INPUT_6xx)
4486 082c6681 j_mayer
#define POWERPC_BFDM_604E    (bfd_mach_ppc_604)
4487 082c6681 j_mayer
#define POWERPC_FLAG_604E    (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4488 082c6681 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4489 082c6681 j_mayer
#define check_pow_604E       check_pow_nocheck
4490 082c6681 j_mayer
4491 082c6681 j_mayer
static void init_proc_604E (CPUPPCState *env)
4492 082c6681 j_mayer
{
4493 082c6681 j_mayer
    gen_spr_ne_601(env);
4494 082c6681 j_mayer
    gen_spr_604(env);
4495 082c6681 j_mayer
    /* XXX : not implemented */
4496 082c6681 j_mayer
    spr_register(env, SPR_MMCR1, "MMCR1",
4497 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4498 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4499 082c6681 j_mayer
                 0x00000000);
4500 082c6681 j_mayer
    /* XXX : not implemented */
4501 082c6681 j_mayer
    spr_register(env, SPR_PMC3, "PMC3",
4502 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4503 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4504 082c6681 j_mayer
                 0x00000000);
4505 082c6681 j_mayer
    /* XXX : not implemented */
4506 082c6681 j_mayer
    spr_register(env, SPR_PMC4, "PMC4",
4507 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4508 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4509 082c6681 j_mayer
                 0x00000000);
4510 082c6681 j_mayer
    /* Time base */
4511 082c6681 j_mayer
    gen_tbl(env);
4512 082c6681 j_mayer
    /* Hardware implementation registers */
4513 082c6681 j_mayer
    /* XXX : not implemented */
4514 082c6681 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4515 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4516 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4517 082c6681 j_mayer
                 0x00000000);
4518 a750fc0b j_mayer
    /* XXX : not implemented */
4519 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4520 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4521 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4522 a750fc0b j_mayer
                 0x00000000);
4523 a750fc0b j_mayer
    /* Memory management */
4524 a750fc0b j_mayer
    gen_low_BATs(env);
4525 e1833e1f j_mayer
    init_excp_604(env);
4526 d63001d1 j_mayer
    env->dcache_line_size = 32;
4527 d63001d1 j_mayer
    env->icache_line_size = 32;
4528 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4529 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4530 a750fc0b j_mayer
}
4531 a750fc0b j_mayer
4532 a750fc0b j_mayer
/* PowerPC 740/750 (aka G3)                                                  */
4533 082c6681 j_mayer
#define POWERPC_INSNS_7x0    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4534 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4535 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4536 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4537 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4538 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4539 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4540 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4541 25ba3a68 j_mayer
#define POWERPC_MSRM_7x0     (0x000000000005FF77ULL)
4542 a750fc0b j_mayer
#define POWERPC_MMU_7x0      (POWERPC_MMU_32B)
4543 a750fc0b j_mayer
//#define POWERPC_EXCP_7x0     (POWERPC_EXCP_7x0)
4544 a750fc0b j_mayer
#define POWERPC_INPUT_7x0    (PPC_FLAGS_INPUT_6xx)
4545 237c0af0 j_mayer
#define POWERPC_BFDM_7x0     (bfd_mach_ppc_750)
4546 25ba3a68 j_mayer
#define POWERPC_FLAG_7x0     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4547 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4548 2f462816 j_mayer
#define check_pow_7x0        check_pow_hid0
4549 a750fc0b j_mayer
4550 a750fc0b j_mayer
static void init_proc_7x0 (CPUPPCState *env)
4551 a750fc0b j_mayer
{
4552 a750fc0b j_mayer
    gen_spr_ne_601(env);
4553 a750fc0b j_mayer
    gen_spr_7xx(env);
4554 a750fc0b j_mayer
    /* Time base */
4555 a750fc0b j_mayer
    gen_tbl(env);
4556 a750fc0b j_mayer
    /* Thermal management */
4557 a750fc0b j_mayer
    gen_spr_thrm(env);
4558 a750fc0b j_mayer
    /* Hardware implementation registers */
4559 a750fc0b j_mayer
    /* XXX : not implemented */
4560 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4561 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4562 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4563 a750fc0b j_mayer
                 0x00000000);
4564 a750fc0b j_mayer
    /* XXX : not implemented */
4565 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4566 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4567 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4568 a750fc0b j_mayer
                 0x00000000);
4569 a750fc0b j_mayer
    /* Memory management */
4570 a750fc0b j_mayer
    gen_low_BATs(env);
4571 e1833e1f j_mayer
    init_excp_7x0(env);
4572 d63001d1 j_mayer
    env->dcache_line_size = 32;
4573 d63001d1 j_mayer
    env->icache_line_size = 32;
4574 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4575 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4576 a750fc0b j_mayer
}
4577 a750fc0b j_mayer
4578 a750fc0b j_mayer
/* PowerPC 750FX/GX                                                          */
4579 082c6681 j_mayer
#define POWERPC_INSNS_750fx  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4580 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4581 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4582 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4583 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4584 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4585 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4586 082c6681 j_mayer
                              PPC_SEGMENT  | PPC_EXTERN)
4587 25ba3a68 j_mayer
#define POWERPC_MSRM_750fx   (0x000000000005FF77ULL)
4588 a750fc0b j_mayer
#define POWERPC_MMU_750fx    (POWERPC_MMU_32B)
4589 a750fc0b j_mayer
#define POWERPC_EXCP_750fx   (POWERPC_EXCP_7x0)
4590 a750fc0b j_mayer
#define POWERPC_INPUT_750fx  (PPC_FLAGS_INPUT_6xx)
4591 237c0af0 j_mayer
#define POWERPC_BFDM_750fx   (bfd_mach_ppc_750)
4592 25ba3a68 j_mayer
#define POWERPC_FLAG_750fx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4593 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4594 2f462816 j_mayer
#define check_pow_750fx      check_pow_hid0
4595 a750fc0b j_mayer
4596 a750fc0b j_mayer
static void init_proc_750fx (CPUPPCState *env)
4597 a750fc0b j_mayer
{
4598 a750fc0b j_mayer
    gen_spr_ne_601(env);
4599 a750fc0b j_mayer
    gen_spr_7xx(env);
4600 a750fc0b j_mayer
    /* Time base */
4601 a750fc0b j_mayer
    gen_tbl(env);
4602 a750fc0b j_mayer
    /* Thermal management */
4603 a750fc0b j_mayer
    gen_spr_thrm(env);
4604 a750fc0b j_mayer
    /* Hardware implementation registers */
4605 a750fc0b j_mayer
    /* XXX : not implemented */
4606 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4607 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4608 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4609 a750fc0b j_mayer
                 0x00000000);
4610 a750fc0b j_mayer
    /* XXX : not implemented */
4611 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4612 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4613 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4614 a750fc0b j_mayer
                 0x00000000);
4615 a750fc0b j_mayer
    /* XXX : not implemented */
4616 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
4617 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4618 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4619 a750fc0b j_mayer
                 0x00000000);
4620 a750fc0b j_mayer
    /* Memory management */
4621 a750fc0b j_mayer
    gen_low_BATs(env);
4622 a750fc0b j_mayer
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
4623 a750fc0b j_mayer
    gen_high_BATs(env);
4624 e1833e1f j_mayer
    init_excp_750FX(env);
4625 d63001d1 j_mayer
    env->dcache_line_size = 32;
4626 d63001d1 j_mayer
    env->icache_line_size = 32;
4627 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4628 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4629 a750fc0b j_mayer
}
4630 a750fc0b j_mayer
4631 a750fc0b j_mayer
/* PowerPC 745/755                                                           */
4632 082c6681 j_mayer
#define POWERPC_INSNS_7x5    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4633 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4634 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4635 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4636 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4637 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4638 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4639 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4640 25ba3a68 j_mayer
#define POWERPC_MSRM_7x5     (0x000000000005FF77ULL)
4641 a750fc0b j_mayer
#define POWERPC_MMU_7x5      (POWERPC_MMU_SOFT_6xx)
4642 a750fc0b j_mayer
//#define POWERPC_EXCP_7x5     (POWERPC_EXCP_7x5)
4643 a750fc0b j_mayer
#define POWERPC_INPUT_7x5    (PPC_FLAGS_INPUT_6xx)
4644 237c0af0 j_mayer
#define POWERPC_BFDM_7x5     (bfd_mach_ppc_750)
4645 25ba3a68 j_mayer
#define POWERPC_FLAG_7x5     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4646 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4647 2f462816 j_mayer
#define check_pow_7x5        check_pow_hid0
4648 a750fc0b j_mayer
4649 a750fc0b j_mayer
static void init_proc_7x5 (CPUPPCState *env)
4650 a750fc0b j_mayer
{
4651 a750fc0b j_mayer
    gen_spr_ne_601(env);
4652 a750fc0b j_mayer
    gen_spr_G2_755(env);
4653 a750fc0b j_mayer
    /* Time base */
4654 a750fc0b j_mayer
    gen_tbl(env);
4655 a750fc0b j_mayer
    /* L2 cache control */
4656 a750fc0b j_mayer
    /* XXX : not implemented */
4657 a750fc0b j_mayer
    spr_register(env, SPR_ICTC, "ICTC",
4658 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4659 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4660 a750fc0b j_mayer
                 0x00000000);
4661 a750fc0b j_mayer
    /* XXX : not implemented */
4662 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
4663 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4664 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4665 a750fc0b j_mayer
                 0x00000000);
4666 a750fc0b j_mayer
    /* Hardware implementation registers */
4667 a750fc0b j_mayer
    /* XXX : not implemented */
4668 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4669 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4670 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4671 a750fc0b j_mayer
                 0x00000000);
4672 a750fc0b j_mayer
    /* XXX : not implemented */
4673 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4674 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4675 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4676 a750fc0b j_mayer
                 0x00000000);
4677 a750fc0b j_mayer
    /* XXX : not implemented */
4678 a750fc0b j_mayer
    spr_register(env, SPR_HID2, "HID2",
4679 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4680 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4681 a750fc0b j_mayer
                 0x00000000);
4682 a750fc0b j_mayer
    /* Memory management */
4683 a750fc0b j_mayer
    gen_low_BATs(env);
4684 a750fc0b j_mayer
    gen_high_BATs(env);
4685 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4686 7a3a6927 j_mayer
    init_excp_7x5(env);
4687 d63001d1 j_mayer
    env->dcache_line_size = 32;
4688 d63001d1 j_mayer
    env->icache_line_size = 32;
4689 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4690 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4691 d63001d1 j_mayer
#if !defined(CONFIG_USER_ONLY)
4692 d63001d1 j_mayer
    /* Hardware reset vector */
4693 d63001d1 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
4694 d63001d1 j_mayer
#endif
4695 a750fc0b j_mayer
}
4696 a750fc0b j_mayer
4697 a750fc0b j_mayer
/* PowerPC 7400 (aka G4)                                                     */
4698 082c6681 j_mayer
#define POWERPC_INSNS_7400   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4699 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4700 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4701 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4702 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
4703 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
4704 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4705 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4706 082c6681 j_mayer
                              PPC_MEM_TLBIA |                                 \
4707 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
4708 a750fc0b j_mayer
                              PPC_ALTIVEC)
4709 a750fc0b j_mayer
#define POWERPC_MSRM_7400    (0x000000000205FF77ULL)
4710 a750fc0b j_mayer
#define POWERPC_MMU_7400     (POWERPC_MMU_32B)
4711 a750fc0b j_mayer
#define POWERPC_EXCP_7400    (POWERPC_EXCP_74xx)
4712 a750fc0b j_mayer
#define POWERPC_INPUT_7400   (PPC_FLAGS_INPUT_6xx)
4713 237c0af0 j_mayer
#define POWERPC_BFDM_7400    (bfd_mach_ppc_7400)
4714 25ba3a68 j_mayer
#define POWERPC_FLAG_7400    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4715 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
4716 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4717 2f462816 j_mayer
#define check_pow_7400       check_pow_hid0
4718 a750fc0b j_mayer
4719 a750fc0b j_mayer
static void init_proc_7400 (CPUPPCState *env)
4720 a750fc0b j_mayer
{
4721 a750fc0b j_mayer
    gen_spr_ne_601(env);
4722 a750fc0b j_mayer
    gen_spr_7xx(env);
4723 a750fc0b j_mayer
    /* Time base */
4724 a750fc0b j_mayer
    gen_tbl(env);
4725 a750fc0b j_mayer
    /* 74xx specific SPR */
4726 a750fc0b j_mayer
    gen_spr_74xx(env);
4727 a750fc0b j_mayer
    /* Thermal management */
4728 a750fc0b j_mayer
    gen_spr_thrm(env);
4729 a750fc0b j_mayer
    /* Memory management */
4730 a750fc0b j_mayer
    gen_low_BATs(env);
4731 e1833e1f j_mayer
    init_excp_7400(env);
4732 d63001d1 j_mayer
    env->dcache_line_size = 32;
4733 d63001d1 j_mayer
    env->icache_line_size = 32;
4734 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4735 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4736 a750fc0b j_mayer
}
4737 a750fc0b j_mayer
4738 a750fc0b j_mayer
/* PowerPC 7410 (aka G4)                                                     */
4739 082c6681 j_mayer
#define POWERPC_INSNS_7410   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4740 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4741 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4742 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4743 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
4744 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
4745 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4746 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4747 082c6681 j_mayer
                              PPC_MEM_TLBIA |                                 \
4748 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
4749 a750fc0b j_mayer
                              PPC_ALTIVEC)
4750 a750fc0b j_mayer
#define POWERPC_MSRM_7410    (0x000000000205FF77ULL)
4751 a750fc0b j_mayer
#define POWERPC_MMU_7410     (POWERPC_MMU_32B)
4752 a750fc0b j_mayer
#define POWERPC_EXCP_7410    (POWERPC_EXCP_74xx)
4753 a750fc0b j_mayer
#define POWERPC_INPUT_7410   (PPC_FLAGS_INPUT_6xx)
4754 237c0af0 j_mayer
#define POWERPC_BFDM_7410    (bfd_mach_ppc_7400)
4755 25ba3a68 j_mayer
#define POWERPC_FLAG_7410    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4756 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
4757 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4758 2f462816 j_mayer
#define check_pow_7410       check_pow_hid0
4759 a750fc0b j_mayer
4760 a750fc0b j_mayer
static void init_proc_7410 (CPUPPCState *env)
4761 a750fc0b j_mayer
{
4762 a750fc0b j_mayer
    gen_spr_ne_601(env);
4763 a750fc0b j_mayer
    gen_spr_7xx(env);
4764 a750fc0b j_mayer
    /* Time base */
4765 a750fc0b j_mayer
    gen_tbl(env);
4766 a750fc0b j_mayer
    /* 74xx specific SPR */
4767 a750fc0b j_mayer
    gen_spr_74xx(env);
4768 a750fc0b j_mayer
    /* Thermal management */
4769 a750fc0b j_mayer
    gen_spr_thrm(env);
4770 a750fc0b j_mayer
    /* L2PMCR */
4771 a750fc0b j_mayer
    /* XXX : not implemented */
4772 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
4773 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4774 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4775 a750fc0b j_mayer
                 0x00000000);
4776 a750fc0b j_mayer
    /* LDSTDB */
4777 a750fc0b j_mayer
    /* XXX : not implemented */
4778 a750fc0b j_mayer
    spr_register(env, SPR_LDSTDB, "LDSTDB",
4779 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4780 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4781 a750fc0b j_mayer
                 0x00000000);
4782 a750fc0b j_mayer
    /* Memory management */
4783 a750fc0b j_mayer
    gen_low_BATs(env);
4784 e1833e1f j_mayer
    init_excp_7400(env);
4785 d63001d1 j_mayer
    env->dcache_line_size = 32;
4786 d63001d1 j_mayer
    env->icache_line_size = 32;
4787 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4788 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4789 a750fc0b j_mayer
}
4790 a750fc0b j_mayer
4791 a750fc0b j_mayer
/* PowerPC 7440 (aka G4)                                                     */
4792 082c6681 j_mayer
#define POWERPC_INSNS_7440   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4793 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4794 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4795 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4796 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
4797 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
4798 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4799 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4800 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
4801 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
4802 a750fc0b j_mayer
                              PPC_ALTIVEC)
4803 a750fc0b j_mayer
#define POWERPC_MSRM_7440    (0x000000000205FF77ULL)
4804 a750fc0b j_mayer
#define POWERPC_MMU_7440     (POWERPC_MMU_SOFT_74xx)
4805 a750fc0b j_mayer
#define POWERPC_EXCP_7440    (POWERPC_EXCP_74xx)
4806 a750fc0b j_mayer
#define POWERPC_INPUT_7440   (PPC_FLAGS_INPUT_6xx)
4807 237c0af0 j_mayer
#define POWERPC_BFDM_7440    (bfd_mach_ppc_7400)
4808 25ba3a68 j_mayer
#define POWERPC_FLAG_7440    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4809 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
4810 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4811 2f462816 j_mayer
#define check_pow_7440       check_pow_hid0
4812 a750fc0b j_mayer
4813 578bb252 j_mayer
__attribute__ (( unused ))
4814 a750fc0b j_mayer
static void init_proc_7440 (CPUPPCState *env)
4815 a750fc0b j_mayer
{
4816 a750fc0b j_mayer
    gen_spr_ne_601(env);
4817 a750fc0b j_mayer
    gen_spr_7xx(env);
4818 a750fc0b j_mayer
    /* Time base */
4819 a750fc0b j_mayer
    gen_tbl(env);
4820 a750fc0b j_mayer
    /* 74xx specific SPR */
4821 a750fc0b j_mayer
    gen_spr_74xx(env);
4822 a750fc0b j_mayer
    /* LDSTCR */
4823 a750fc0b j_mayer
    /* XXX : not implemented */
4824 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
4825 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4826 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4827 a750fc0b j_mayer
                 0x00000000);
4828 a750fc0b j_mayer
    /* ICTRL */
4829 a750fc0b j_mayer
    /* XXX : not implemented */
4830 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
4831 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4832 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4833 a750fc0b j_mayer
                 0x00000000);
4834 a750fc0b j_mayer
    /* MSSSR0 */
4835 578bb252 j_mayer
    /* XXX : not implemented */
4836 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
4837 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4838 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4839 a750fc0b j_mayer
                 0x00000000);
4840 a750fc0b j_mayer
    /* PMC */
4841 a750fc0b j_mayer
    /* XXX : not implemented */
4842 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
4843 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4844 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4845 a750fc0b j_mayer
                 0x00000000);
4846 578bb252 j_mayer
    /* XXX : not implemented */
4847 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
4848 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4849 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4850 a750fc0b j_mayer
                 0x00000000);
4851 578bb252 j_mayer
    /* XXX : not implemented */
4852 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
4853 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4854 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4855 a750fc0b j_mayer
                 0x00000000);
4856 578bb252 j_mayer
    /* XXX : not implemented */
4857 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
4858 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4859 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4860 a750fc0b j_mayer
                 0x00000000);
4861 a750fc0b j_mayer
    /* Memory management */
4862 a750fc0b j_mayer
    gen_low_BATs(env);
4863 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
4864 1c27f8fb j_mayer
    init_excp_7450(env);
4865 d63001d1 j_mayer
    env->dcache_line_size = 32;
4866 d63001d1 j_mayer
    env->icache_line_size = 32;
4867 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4868 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4869 a750fc0b j_mayer
}
4870 a750fc0b j_mayer
4871 a750fc0b j_mayer
/* PowerPC 7450 (aka G4)                                                     */
4872 082c6681 j_mayer
#define POWERPC_INSNS_7450   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4873 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4874 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4875 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4876 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
4877 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
4878 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4879 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4880 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
4881 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
4882 a750fc0b j_mayer
                              PPC_ALTIVEC)
4883 a750fc0b j_mayer
#define POWERPC_MSRM_7450    (0x000000000205FF77ULL)
4884 a750fc0b j_mayer
#define POWERPC_MMU_7450     (POWERPC_MMU_SOFT_74xx)
4885 a750fc0b j_mayer
#define POWERPC_EXCP_7450    (POWERPC_EXCP_74xx)
4886 a750fc0b j_mayer
#define POWERPC_INPUT_7450   (PPC_FLAGS_INPUT_6xx)
4887 237c0af0 j_mayer
#define POWERPC_BFDM_7450    (bfd_mach_ppc_7400)
4888 25ba3a68 j_mayer
#define POWERPC_FLAG_7450    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4889 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
4890 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4891 2f462816 j_mayer
#define check_pow_7450       check_pow_hid0
4892 a750fc0b j_mayer
4893 578bb252 j_mayer
__attribute__ (( unused ))
4894 a750fc0b j_mayer
static void init_proc_7450 (CPUPPCState *env)
4895 a750fc0b j_mayer
{
4896 a750fc0b j_mayer
    gen_spr_ne_601(env);
4897 a750fc0b j_mayer
    gen_spr_7xx(env);
4898 a750fc0b j_mayer
    /* Time base */
4899 a750fc0b j_mayer
    gen_tbl(env);
4900 a750fc0b j_mayer
    /* 74xx specific SPR */
4901 a750fc0b j_mayer
    gen_spr_74xx(env);
4902 a750fc0b j_mayer
    /* Level 3 cache control */
4903 a750fc0b j_mayer
    gen_l3_ctrl(env);
4904 a750fc0b j_mayer
    /* LDSTCR */
4905 a750fc0b j_mayer
    /* XXX : not implemented */
4906 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
4907 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4908 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4909 a750fc0b j_mayer
                 0x00000000);
4910 a750fc0b j_mayer
    /* ICTRL */
4911 a750fc0b j_mayer
    /* XXX : not implemented */
4912 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
4913 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4914 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4915 a750fc0b j_mayer
                 0x00000000);
4916 a750fc0b j_mayer
    /* MSSSR0 */
4917 578bb252 j_mayer
    /* XXX : not implemented */
4918 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
4919 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4920 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4921 a750fc0b j_mayer
                 0x00000000);
4922 a750fc0b j_mayer
    /* PMC */
4923 a750fc0b j_mayer
    /* XXX : not implemented */
4924 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
4925 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4926 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4927 a750fc0b j_mayer
                 0x00000000);
4928 578bb252 j_mayer
    /* XXX : not implemented */
4929 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
4930 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4931 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4932 a750fc0b j_mayer
                 0x00000000);
4933 578bb252 j_mayer
    /* XXX : not implemented */
4934 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
4935 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4936 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4937 a750fc0b j_mayer
                 0x00000000);
4938 578bb252 j_mayer
    /* XXX : not implemented */
4939 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
4940 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4941 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
4942 a750fc0b j_mayer
                 0x00000000);
4943 a750fc0b j_mayer
    /* Memory management */
4944 a750fc0b j_mayer
    gen_low_BATs(env);
4945 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
4946 e1833e1f j_mayer
    init_excp_7450(env);
4947 d63001d1 j_mayer
    env->dcache_line_size = 32;
4948 d63001d1 j_mayer
    env->icache_line_size = 32;
4949 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4950 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4951 a750fc0b j_mayer
}
4952 a750fc0b j_mayer
4953 a750fc0b j_mayer
/* PowerPC 7445 (aka G4)                                                     */
4954 082c6681 j_mayer
#define POWERPC_INSNS_7445   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4955 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4956 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
4957 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4958 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
4959 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
4960 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4961 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4962 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
4963 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
4964 a750fc0b j_mayer
                              PPC_ALTIVEC)
4965 a750fc0b j_mayer
#define POWERPC_MSRM_7445    (0x000000000205FF77ULL)
4966 a750fc0b j_mayer
#define POWERPC_MMU_7445     (POWERPC_MMU_SOFT_74xx)
4967 a750fc0b j_mayer
#define POWERPC_EXCP_7445    (POWERPC_EXCP_74xx)
4968 a750fc0b j_mayer
#define POWERPC_INPUT_7445   (PPC_FLAGS_INPUT_6xx)
4969 237c0af0 j_mayer
#define POWERPC_BFDM_7445    (bfd_mach_ppc_7400)
4970 25ba3a68 j_mayer
#define POWERPC_FLAG_7445    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4971 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
4972 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4973 2f462816 j_mayer
#define check_pow_7445       check_pow_hid0
4974 a750fc0b j_mayer
4975 578bb252 j_mayer
__attribute__ (( unused ))
4976 a750fc0b j_mayer
static void init_proc_7445 (CPUPPCState *env)
4977 a750fc0b j_mayer
{
4978 a750fc0b j_mayer
    gen_spr_ne_601(env);
4979 a750fc0b j_mayer
    gen_spr_7xx(env);
4980 a750fc0b j_mayer
    /* Time base */
4981 a750fc0b j_mayer
    gen_tbl(env);
4982 a750fc0b j_mayer
    /* 74xx specific SPR */
4983 a750fc0b j_mayer
    gen_spr_74xx(env);
4984 a750fc0b j_mayer
    /* LDSTCR */
4985 a750fc0b j_mayer
    /* XXX : not implemented */
4986 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
4987 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4988 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4989 a750fc0b j_mayer
                 0x00000000);
4990 a750fc0b j_mayer
    /* ICTRL */
4991 a750fc0b j_mayer
    /* XXX : not implemented */
4992 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
4993 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4994 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4995 a750fc0b j_mayer
                 0x00000000);
4996 a750fc0b j_mayer
    /* MSSSR0 */
4997 578bb252 j_mayer
    /* XXX : not implemented */
4998 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
4999 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5000 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5001 a750fc0b j_mayer
                 0x00000000);
5002 a750fc0b j_mayer
    /* PMC */
5003 a750fc0b j_mayer
    /* XXX : not implemented */
5004 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5005 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5006 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5007 a750fc0b j_mayer
                 0x00000000);
5008 578bb252 j_mayer
    /* XXX : not implemented */
5009 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5010 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5011 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5012 a750fc0b j_mayer
                 0x00000000);
5013 578bb252 j_mayer
    /* XXX : not implemented */
5014 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5015 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5016 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5017 a750fc0b j_mayer
                 0x00000000);
5018 578bb252 j_mayer
    /* XXX : not implemented */
5019 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5020 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5021 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5022 a750fc0b j_mayer
                 0x00000000);
5023 a750fc0b j_mayer
    /* SPRGs */
5024 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
5025 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5026 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5027 a750fc0b j_mayer
                 0x00000000);
5028 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
5029 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5030 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5031 a750fc0b j_mayer
                 0x00000000);
5032 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
5033 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5034 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5035 a750fc0b j_mayer
                 0x00000000);
5036 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
5037 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5038 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5039 a750fc0b j_mayer
                 0x00000000);
5040 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
5041 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5042 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5043 a750fc0b j_mayer
                 0x00000000);
5044 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
5045 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5046 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5047 a750fc0b j_mayer
                 0x00000000);
5048 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
5049 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5050 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5051 a750fc0b j_mayer
                 0x00000000);
5052 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
5053 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5054 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5055 a750fc0b j_mayer
                 0x00000000);
5056 a750fc0b j_mayer
    /* Memory management */
5057 a750fc0b j_mayer
    gen_low_BATs(env);
5058 a750fc0b j_mayer
    gen_high_BATs(env);
5059 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5060 e1833e1f j_mayer
    init_excp_7450(env);
5061 d63001d1 j_mayer
    env->dcache_line_size = 32;
5062 d63001d1 j_mayer
    env->icache_line_size = 32;
5063 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5064 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5065 a750fc0b j_mayer
}
5066 a750fc0b j_mayer
5067 a750fc0b j_mayer
/* PowerPC 7455 (aka G4)                                                     */
5068 082c6681 j_mayer
#define POWERPC_INSNS_7455   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5069 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5070 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5071 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5072 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5073 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5074 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5075 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5076 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5077 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5078 a750fc0b j_mayer
                              PPC_ALTIVEC)
5079 a750fc0b j_mayer
#define POWERPC_MSRM_7455    (0x000000000205FF77ULL)
5080 a750fc0b j_mayer
#define POWERPC_MMU_7455     (POWERPC_MMU_SOFT_74xx)
5081 a750fc0b j_mayer
#define POWERPC_EXCP_7455    (POWERPC_EXCP_74xx)
5082 a750fc0b j_mayer
#define POWERPC_INPUT_7455   (PPC_FLAGS_INPUT_6xx)
5083 237c0af0 j_mayer
#define POWERPC_BFDM_7455    (bfd_mach_ppc_7400)
5084 25ba3a68 j_mayer
#define POWERPC_FLAG_7455    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5085 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5086 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5087 2f462816 j_mayer
#define check_pow_7455       check_pow_hid0
5088 a750fc0b j_mayer
5089 578bb252 j_mayer
__attribute__ (( unused ))
5090 a750fc0b j_mayer
static void init_proc_7455 (CPUPPCState *env)
5091 a750fc0b j_mayer
{
5092 a750fc0b j_mayer
    gen_spr_ne_601(env);
5093 a750fc0b j_mayer
    gen_spr_7xx(env);
5094 a750fc0b j_mayer
    /* Time base */
5095 a750fc0b j_mayer
    gen_tbl(env);
5096 a750fc0b j_mayer
    /* 74xx specific SPR */
5097 a750fc0b j_mayer
    gen_spr_74xx(env);
5098 a750fc0b j_mayer
    /* Level 3 cache control */
5099 a750fc0b j_mayer
    gen_l3_ctrl(env);
5100 a750fc0b j_mayer
    /* LDSTCR */
5101 a750fc0b j_mayer
    /* XXX : not implemented */
5102 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5103 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5104 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5105 a750fc0b j_mayer
                 0x00000000);
5106 a750fc0b j_mayer
    /* ICTRL */
5107 a750fc0b j_mayer
    /* XXX : not implemented */
5108 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5109 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5110 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5111 a750fc0b j_mayer
                 0x00000000);
5112 a750fc0b j_mayer
    /* MSSSR0 */
5113 578bb252 j_mayer
    /* XXX : not implemented */
5114 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5115 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5116 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5117 a750fc0b j_mayer
                 0x00000000);
5118 a750fc0b j_mayer
    /* PMC */
5119 a750fc0b j_mayer
    /* XXX : not implemented */
5120 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5121 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5122 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5123 a750fc0b j_mayer
                 0x00000000);
5124 578bb252 j_mayer
    /* XXX : not implemented */
5125 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5126 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5127 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5128 a750fc0b j_mayer
                 0x00000000);
5129 578bb252 j_mayer
    /* XXX : not implemented */
5130 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5131 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5132 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5133 a750fc0b j_mayer
                 0x00000000);
5134 578bb252 j_mayer
    /* XXX : not implemented */
5135 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5136 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5137 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5138 a750fc0b j_mayer
                 0x00000000);
5139 a750fc0b j_mayer
    /* SPRGs */
5140 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
5141 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5142 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5143 a750fc0b j_mayer
                 0x00000000);
5144 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
5145 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5146 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5147 a750fc0b j_mayer
                 0x00000000);
5148 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
5149 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5150 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5151 a750fc0b j_mayer
                 0x00000000);
5152 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
5153 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5154 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5155 a750fc0b j_mayer
                 0x00000000);
5156 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
5157 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5158 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5159 a750fc0b j_mayer
                 0x00000000);
5160 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
5161 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5162 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5163 a750fc0b j_mayer
                 0x00000000);
5164 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
5165 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5166 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5167 a750fc0b j_mayer
                 0x00000000);
5168 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
5169 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5170 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5171 a750fc0b j_mayer
                 0x00000000);
5172 a750fc0b j_mayer
    /* Memory management */
5173 a750fc0b j_mayer
    gen_low_BATs(env);
5174 a750fc0b j_mayer
    gen_high_BATs(env);
5175 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5176 e1833e1f j_mayer
    init_excp_7450(env);
5177 d63001d1 j_mayer
    env->dcache_line_size = 32;
5178 d63001d1 j_mayer
    env->icache_line_size = 32;
5179 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5180 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5181 a750fc0b j_mayer
}
5182 a750fc0b j_mayer
5183 a750fc0b j_mayer
#if defined (TARGET_PPC64)
5184 a750fc0b j_mayer
/* PowerPC 970                                                               */
5185 082c6681 j_mayer
#define POWERPC_INSNS_970    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5186 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5187 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5188 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5189 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
5190 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5191 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5192 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
5193 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
5194 a750fc0b j_mayer
#define POWERPC_MSRM_970     (0x900000000204FF36ULL)
5195 12de9a39 j_mayer
#define POWERPC_MMU_970      (POWERPC_MMU_64B)
5196 a750fc0b j_mayer
//#define POWERPC_EXCP_970     (POWERPC_EXCP_970)
5197 a750fc0b j_mayer
#define POWERPC_INPUT_970    (PPC_FLAGS_INPUT_970)
5198 237c0af0 j_mayer
#define POWERPC_BFDM_970     (bfd_mach_ppc64)
5199 25ba3a68 j_mayer
#define POWERPC_FLAG_970     (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5200 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5201 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5202 a750fc0b j_mayer
5203 417bf010 j_mayer
#if defined(CONFIG_USER_ONLY)
5204 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000080
5205 417bf010 j_mayer
#else
5206 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000000
5207 417bf010 j_mayer
#endif
5208 417bf010 j_mayer
5209 2f462816 j_mayer
static int check_pow_970 (CPUPPCState *env)
5210 2f462816 j_mayer
{
5211 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
5212 2f462816 j_mayer
        return 1;
5213 2f462816 j_mayer
5214 2f462816 j_mayer
    return 0;
5215 2f462816 j_mayer
}
5216 2f462816 j_mayer
5217 a750fc0b j_mayer
static void init_proc_970 (CPUPPCState *env)
5218 a750fc0b j_mayer
{
5219 a750fc0b j_mayer
    gen_spr_ne_601(env);
5220 a750fc0b j_mayer
    gen_spr_7xx(env);
5221 a750fc0b j_mayer
    /* Time base */
5222 a750fc0b j_mayer
    gen_tbl(env);
5223 a750fc0b j_mayer
    /* Hardware implementation registers */
5224 a750fc0b j_mayer
    /* XXX : not implemented */
5225 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5226 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5227 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
5228 d63001d1 j_mayer
                 0x60000000);
5229 a750fc0b j_mayer
    /* XXX : not implemented */
5230 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
5231 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5232 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5233 a750fc0b j_mayer
                 0x00000000);
5234 a750fc0b j_mayer
    /* XXX : not implemented */
5235 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
5236 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5237 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5238 a750fc0b j_mayer
                 0x00000000);
5239 e57448f1 j_mayer
    /* XXX : not implemented */
5240 e57448f1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
5241 e57448f1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5242 e57448f1 j_mayer
                 &spr_read_generic, &spr_write_generic,
5243 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
5244 a750fc0b j_mayer
    /* Memory management */
5245 a750fc0b j_mayer
    /* XXX: not correct */
5246 a750fc0b j_mayer
    gen_low_BATs(env);
5247 12de9a39 j_mayer
    /* XXX : not implemented */
5248 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
5249 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5250 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
5251 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
5252 12de9a39 j_mayer
    /* XXX : not implemented */
5253 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
5254 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5255 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
5256 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
5257 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
5258 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5259 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
5260 12de9a39 j_mayer
                 0xFFF00000); /* XXX: This is a hack */
5261 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
5262 12de9a39 j_mayer
    env->slb_nr = 32;
5263 f2e63a42 j_mayer
#endif
5264 e1833e1f j_mayer
    init_excp_970(env);
5265 d63001d1 j_mayer
    env->dcache_line_size = 128;
5266 d63001d1 j_mayer
    env->icache_line_size = 128;
5267 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5268 a750fc0b j_mayer
    ppc970_irq_init(env);
5269 a750fc0b j_mayer
}
5270 a750fc0b j_mayer
5271 a750fc0b j_mayer
/* PowerPC 970FX (aka G5)                                                    */
5272 082c6681 j_mayer
#define POWERPC_INSNS_970FX  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5273 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5274 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5275 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5276 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
5277 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5278 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5279 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
5280 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
5281 a750fc0b j_mayer
#define POWERPC_MSRM_970FX   (0x800000000204FF36ULL)
5282 12de9a39 j_mayer
#define POWERPC_MMU_970FX    (POWERPC_MMU_64B)
5283 a750fc0b j_mayer
#define POWERPC_EXCP_970FX   (POWERPC_EXCP_970)
5284 a750fc0b j_mayer
#define POWERPC_INPUT_970FX  (PPC_FLAGS_INPUT_970)
5285 237c0af0 j_mayer
#define POWERPC_BFDM_970FX   (bfd_mach_ppc64)
5286 25ba3a68 j_mayer
#define POWERPC_FLAG_970FX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5287 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5288 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5289 a750fc0b j_mayer
5290 2f462816 j_mayer
static int check_pow_970FX (CPUPPCState *env)
5291 2f462816 j_mayer
{
5292 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
5293 2f462816 j_mayer
        return 1;
5294 2f462816 j_mayer
5295 2f462816 j_mayer
    return 0;
5296 2f462816 j_mayer
}
5297 2f462816 j_mayer
5298 a750fc0b j_mayer
static void init_proc_970FX (CPUPPCState *env)
5299 a750fc0b j_mayer
{
5300 a750fc0b j_mayer
    gen_spr_ne_601(env);
5301 a750fc0b j_mayer
    gen_spr_7xx(env);
5302 a750fc0b j_mayer
    /* Time base */
5303 a750fc0b j_mayer
    gen_tbl(env);
5304 a750fc0b j_mayer
    /* Hardware implementation registers */
5305 a750fc0b j_mayer
    /* XXX : not implemented */
5306 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5307 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5308 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
5309 d63001d1 j_mayer
                 0x60000000);
5310 a750fc0b j_mayer
    /* XXX : not implemented */
5311 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
5312 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5313 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5314 a750fc0b j_mayer
                 0x00000000);
5315 a750fc0b j_mayer
    /* XXX : not implemented */
5316 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
5317 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5318 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5319 a750fc0b j_mayer
                 0x00000000);
5320 d63001d1 j_mayer
    /* XXX : not implemented */
5321 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
5322 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5323 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
5324 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
5325 a750fc0b j_mayer
    /* Memory management */
5326 a750fc0b j_mayer
    /* XXX: not correct */
5327 a750fc0b j_mayer
    gen_low_BATs(env);
5328 12de9a39 j_mayer
    /* XXX : not implemented */
5329 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
5330 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5331 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
5332 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
5333 12de9a39 j_mayer
    /* XXX : not implemented */
5334 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
5335 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5336 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
5337 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
5338 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
5339 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5340 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
5341 12de9a39 j_mayer
                 0xFFF00000); /* XXX: This is a hack */
5342 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
5343 12de9a39 j_mayer
    env->slb_nr = 32;
5344 f2e63a42 j_mayer
#endif
5345 e1833e1f j_mayer
    init_excp_970(env);
5346 d63001d1 j_mayer
    env->dcache_line_size = 128;
5347 d63001d1 j_mayer
    env->icache_line_size = 128;
5348 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5349 a750fc0b j_mayer
    ppc970_irq_init(env);
5350 a750fc0b j_mayer
}
5351 a750fc0b j_mayer
5352 a750fc0b j_mayer
/* PowerPC 970 GX                                                            */
5353 082c6681 j_mayer
#define POWERPC_INSNS_970GX  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5354 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5355 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5356 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5357 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
5358 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5359 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5360 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
5361 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
5362 a750fc0b j_mayer
#define POWERPC_MSRM_970GX   (0x800000000204FF36ULL)
5363 12de9a39 j_mayer
#define POWERPC_MMU_970GX    (POWERPC_MMU_64B)
5364 a750fc0b j_mayer
#define POWERPC_EXCP_970GX   (POWERPC_EXCP_970)
5365 a750fc0b j_mayer
#define POWERPC_INPUT_970GX  (PPC_FLAGS_INPUT_970)
5366 237c0af0 j_mayer
#define POWERPC_BFDM_970GX   (bfd_mach_ppc64)
5367 25ba3a68 j_mayer
#define POWERPC_FLAG_970GX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5368 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5369 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5370 a750fc0b j_mayer
5371 2f462816 j_mayer
static int check_pow_970GX (CPUPPCState *env)
5372 2f462816 j_mayer
{
5373 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
5374 2f462816 j_mayer
        return 1;
5375 2f462816 j_mayer
5376 2f462816 j_mayer
    return 0;
5377 2f462816 j_mayer
}
5378 2f462816 j_mayer
5379 a750fc0b j_mayer
static void init_proc_970GX (CPUPPCState *env)
5380 a750fc0b j_mayer
{
5381 a750fc0b j_mayer
    gen_spr_ne_601(env);
5382 a750fc0b j_mayer
    gen_spr_7xx(env);
5383 a750fc0b j_mayer
    /* Time base */
5384 a750fc0b j_mayer
    gen_tbl(env);
5385 a750fc0b j_mayer
    /* Hardware implementation registers */
5386 a750fc0b j_mayer
    /* XXX : not implemented */
5387 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5388 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5389 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
5390 d63001d1 j_mayer
                 0x60000000);
5391 a750fc0b j_mayer
    /* XXX : not implemented */
5392 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
5393 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5394 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5395 a750fc0b j_mayer
                 0x00000000);
5396 a750fc0b j_mayer
    /* XXX : not implemented */
5397 a750fc0b j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
5398 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5399 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5400 a750fc0b j_mayer
                 0x00000000);
5401 d63001d1 j_mayer
    /* XXX : not implemented */
5402 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
5403 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5404 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
5405 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
5406 a750fc0b j_mayer
    /* Memory management */
5407 a750fc0b j_mayer
    /* XXX: not correct */
5408 a750fc0b j_mayer
    gen_low_BATs(env);
5409 12de9a39 j_mayer
    /* XXX : not implemented */
5410 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
5411 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5412 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
5413 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
5414 12de9a39 j_mayer
    /* XXX : not implemented */
5415 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
5416 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5417 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
5418 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
5419 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
5420 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5421 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
5422 12de9a39 j_mayer
                 0xFFF00000); /* XXX: This is a hack */
5423 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
5424 12de9a39 j_mayer
    env->slb_nr = 32;
5425 f2e63a42 j_mayer
#endif
5426 e1833e1f j_mayer
    init_excp_970(env);
5427 d63001d1 j_mayer
    env->dcache_line_size = 128;
5428 d63001d1 j_mayer
    env->icache_line_size = 128;
5429 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5430 a750fc0b j_mayer
    ppc970_irq_init(env);
5431 a750fc0b j_mayer
}
5432 a750fc0b j_mayer
5433 2f462816 j_mayer
/* PowerPC 970 MP                                                            */
5434 082c6681 j_mayer
#define POWERPC_INSNS_970MP  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5435 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5436 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5437 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5438 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
5439 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5440 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5441 2f462816 j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
5442 2f462816 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
5443 2f462816 j_mayer
#define POWERPC_MSRM_970MP   (0x900000000204FF36ULL)
5444 2f462816 j_mayer
#define POWERPC_MMU_970MP    (POWERPC_MMU_64B)
5445 2f462816 j_mayer
#define POWERPC_EXCP_970MP   (POWERPC_EXCP_970)
5446 2f462816 j_mayer
#define POWERPC_INPUT_970MP  (PPC_FLAGS_INPUT_970)
5447 2f462816 j_mayer
#define POWERPC_BFDM_970MP   (bfd_mach_ppc64)
5448 2f462816 j_mayer
#define POWERPC_FLAG_970MP   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5449 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5450 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5451 2f462816 j_mayer
5452 2f462816 j_mayer
static int check_pow_970MP (CPUPPCState *env)
5453 2f462816 j_mayer
{
5454 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x01C00000)
5455 2f462816 j_mayer
        return 1;
5456 2f462816 j_mayer
5457 2f462816 j_mayer
    return 0;
5458 2f462816 j_mayer
}
5459 2f462816 j_mayer
5460 2f462816 j_mayer
static void init_proc_970MP (CPUPPCState *env)
5461 2f462816 j_mayer
{
5462 2f462816 j_mayer
    gen_spr_ne_601(env);
5463 2f462816 j_mayer
    gen_spr_7xx(env);
5464 2f462816 j_mayer
    /* Time base */
5465 2f462816 j_mayer
    gen_tbl(env);
5466 2f462816 j_mayer
    /* Hardware implementation registers */
5467 2f462816 j_mayer
    /* XXX : not implemented */
5468 2f462816 j_mayer
    spr_register(env, SPR_HID0, "HID0",
5469 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5470 2f462816 j_mayer
                 &spr_read_generic, &spr_write_clear,
5471 2f462816 j_mayer
                 0x60000000);
5472 2f462816 j_mayer
    /* XXX : not implemented */
5473 2f462816 j_mayer
    spr_register(env, SPR_HID1, "HID1",
5474 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5475 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
5476 2f462816 j_mayer
                 0x00000000);
5477 2f462816 j_mayer
    /* XXX : not implemented */
5478 2f462816 j_mayer
    spr_register(env, SPR_750_HID2, "HID2",
5479 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5480 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
5481 2f462816 j_mayer
                 0x00000000);
5482 2f462816 j_mayer
    /* XXX : not implemented */
5483 2f462816 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
5484 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5485 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
5486 2f462816 j_mayer
                 POWERPC970_HID5_INIT);
5487 2f462816 j_mayer
    /* Memory management */
5488 2f462816 j_mayer
    /* XXX: not correct */
5489 2f462816 j_mayer
    gen_low_BATs(env);
5490 2f462816 j_mayer
    /* XXX : not implemented */
5491 2f462816 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
5492 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5493 2f462816 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
5494 2f462816 j_mayer
                 0x00000000); /* TOFIX */
5495 2f462816 j_mayer
    /* XXX : not implemented */
5496 2f462816 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
5497 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5498 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
5499 2f462816 j_mayer
                 0x00000000); /* TOFIX */
5500 2f462816 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
5501 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5502 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
5503 2f462816 j_mayer
                 0xFFF00000); /* XXX: This is a hack */
5504 2f462816 j_mayer
#if !defined(CONFIG_USER_ONLY)
5505 2f462816 j_mayer
    env->slb_nr = 32;
5506 2f462816 j_mayer
#endif
5507 2f462816 j_mayer
    init_excp_970(env);
5508 2f462816 j_mayer
    env->dcache_line_size = 128;
5509 2f462816 j_mayer
    env->icache_line_size = 128;
5510 2f462816 j_mayer
    /* Allocate hardware IRQ controller */
5511 2f462816 j_mayer
    ppc970_irq_init(env);
5512 2f462816 j_mayer
}
5513 2f462816 j_mayer
5514 a750fc0b j_mayer
/* PowerPC 620                                                               */
5515 082c6681 j_mayer
#define POWERPC_INSNS_620    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5516 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5517 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5518 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5519 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5520 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5521 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5522 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5523 a750fc0b j_mayer
                              PPC_64B | PPC_SLBI)
5524 add78955 j_mayer
#define POWERPC_MSRM_620     (0x800000000005FF77ULL)
5525 add78955 j_mayer
//#define POWERPC_MMU_620      (POWERPC_MMU_620)
5526 a750fc0b j_mayer
#define POWERPC_EXCP_620     (POWERPC_EXCP_970)
5527 faadf50e j_mayer
#define POWERPC_INPUT_620    (PPC_FLAGS_INPUT_6xx)
5528 237c0af0 j_mayer
#define POWERPC_BFDM_620     (bfd_mach_ppc64)
5529 4018bae9 j_mayer
#define POWERPC_FLAG_620     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |            \
5530 add78955 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5531 2f462816 j_mayer
#define check_pow_620        check_pow_nocheck /* Check this */
5532 a750fc0b j_mayer
5533 578bb252 j_mayer
__attribute__ (( unused ))
5534 a750fc0b j_mayer
static void init_proc_620 (CPUPPCState *env)
5535 a750fc0b j_mayer
{
5536 a750fc0b j_mayer
    gen_spr_ne_601(env);
5537 a750fc0b j_mayer
    gen_spr_620(env);
5538 a750fc0b j_mayer
    /* Time base */
5539 a750fc0b j_mayer
    gen_tbl(env);
5540 a750fc0b j_mayer
    /* Hardware implementation registers */
5541 a750fc0b j_mayer
    /* XXX : not implemented */
5542 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5543 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5544 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5545 a750fc0b j_mayer
                 0x00000000);
5546 a750fc0b j_mayer
    /* Memory management */
5547 a750fc0b j_mayer
    gen_low_BATs(env);
5548 e1833e1f j_mayer
    init_excp_620(env);
5549 d63001d1 j_mayer
    env->dcache_line_size = 64;
5550 d63001d1 j_mayer
    env->icache_line_size = 64;
5551 faadf50e j_mayer
    /* Allocate hardware IRQ controller */
5552 faadf50e j_mayer
    ppc6xx_irq_init(env);
5553 a750fc0b j_mayer
}
5554 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
5555 a750fc0b j_mayer
5556 a750fc0b j_mayer
/* Default 32 bits PowerPC target will be 604 */
5557 a750fc0b j_mayer
#define CPU_POWERPC_PPC32     CPU_POWERPC_604
5558 a750fc0b j_mayer
#define POWERPC_INSNS_PPC32   POWERPC_INSNS_604
5559 a750fc0b j_mayer
#define POWERPC_MSRM_PPC32    POWERPC_MSRM_604
5560 a750fc0b j_mayer
#define POWERPC_MMU_PPC32     POWERPC_MMU_604
5561 a750fc0b j_mayer
#define POWERPC_EXCP_PPC32    POWERPC_EXCP_604
5562 a750fc0b j_mayer
#define POWERPC_INPUT_PPC32   POWERPC_INPUT_604
5563 237c0af0 j_mayer
#define POWERPC_BFDM_PPC32    POWERPC_BFDM_604
5564 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC32    POWERPC_FLAG_604
5565 2f462816 j_mayer
#define check_pow_PPC32       check_pow_604
5566 2f462816 j_mayer
#define init_proc_PPC32       init_proc_604
5567 a750fc0b j_mayer
5568 a750fc0b j_mayer
/* Default 64 bits PowerPC target will be 970 FX */
5569 a750fc0b j_mayer
#define CPU_POWERPC_PPC64     CPU_POWERPC_970FX
5570 a750fc0b j_mayer
#define POWERPC_INSNS_PPC64   POWERPC_INSNS_970FX
5571 a750fc0b j_mayer
#define POWERPC_MSRM_PPC64    POWERPC_MSRM_970FX
5572 a750fc0b j_mayer
#define POWERPC_MMU_PPC64     POWERPC_MMU_970FX
5573 a750fc0b j_mayer
#define POWERPC_EXCP_PPC64    POWERPC_EXCP_970FX
5574 a750fc0b j_mayer
#define POWERPC_INPUT_PPC64   POWERPC_INPUT_970FX
5575 237c0af0 j_mayer
#define POWERPC_BFDM_PPC64    POWERPC_BFDM_970FX
5576 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC64    POWERPC_FLAG_970FX
5577 2f462816 j_mayer
#define check_pow_PPC64       check_pow_970FX
5578 2f462816 j_mayer
#define init_proc_PPC64       init_proc_970FX
5579 a750fc0b j_mayer
5580 a750fc0b j_mayer
/* Default PowerPC target will be PowerPC 32 */
5581 a750fc0b j_mayer
#if defined (TARGET_PPC64) && 0 // XXX: TODO
5582 d12f4c38 j_mayer
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC64
5583 d12f4c38 j_mayer
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC64
5584 d12f4c38 j_mayer
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC64
5585 d12f4c38 j_mayer
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC64
5586 d12f4c38 j_mayer
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC64
5587 d12f4c38 j_mayer
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC64
5588 237c0af0 j_mayer
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC64
5589 d26bfc9a j_mayer
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC64
5590 2f462816 j_mayer
#define check_pow_DEFAULT     check_pow_PPC64
5591 2f462816 j_mayer
#define init_proc_DEFAULT     init_proc_PPC64
5592 a750fc0b j_mayer
#else
5593 d12f4c38 j_mayer
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC32
5594 d12f4c38 j_mayer
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC32
5595 d12f4c38 j_mayer
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC32
5596 d12f4c38 j_mayer
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC32
5597 d12f4c38 j_mayer
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC32
5598 d12f4c38 j_mayer
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC32
5599 237c0af0 j_mayer
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC32
5600 d26bfc9a j_mayer
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC32
5601 2f462816 j_mayer
#define check_pow_DEFAULT     check_pow_PPC32
5602 2f462816 j_mayer
#define init_proc_DEFAULT     init_proc_PPC32
5603 a750fc0b j_mayer
#endif
5604 a750fc0b j_mayer
5605 a750fc0b j_mayer
/*****************************************************************************/
5606 a750fc0b j_mayer
/* PVR definitions for most known PowerPC                                    */
5607 a750fc0b j_mayer
enum {
5608 a750fc0b j_mayer
    /* PowerPC 401 family */
5609 a750fc0b j_mayer
    /* Generic PowerPC 401 */
5610 80d11f44 j_mayer
#define CPU_POWERPC_401              CPU_POWERPC_401G2
5611 a750fc0b j_mayer
    /* PowerPC 401 cores */
5612 80d11f44 j_mayer
    CPU_POWERPC_401A1              = 0x00210000,
5613 80d11f44 j_mayer
    CPU_POWERPC_401B2              = 0x00220000,
5614 a750fc0b j_mayer
#if 0
5615 80d11f44 j_mayer
    CPU_POWERPC_401B3              = xxx,
5616 a750fc0b j_mayer
#endif
5617 80d11f44 j_mayer
    CPU_POWERPC_401C2              = 0x00230000,
5618 80d11f44 j_mayer
    CPU_POWERPC_401D2              = 0x00240000,
5619 80d11f44 j_mayer
    CPU_POWERPC_401E2              = 0x00250000,
5620 80d11f44 j_mayer
    CPU_POWERPC_401F2              = 0x00260000,
5621 80d11f44 j_mayer
    CPU_POWERPC_401G2              = 0x00270000,
5622 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers */
5623 a750fc0b j_mayer
#if 0
5624 80d11f44 j_mayer
    CPU_POWERPC_401GF              = xxx,
5625 a750fc0b j_mayer
#endif
5626 80d11f44 j_mayer
#define CPU_POWERPC_IOP480           CPU_POWERPC_401B2
5627 a750fc0b j_mayer
    /* IBM Processor for Network Resources */
5628 80d11f44 j_mayer
    CPU_POWERPC_COBRA              = 0x10100000, /* XXX: 405 ? */
5629 a750fc0b j_mayer
#if 0
5630 80d11f44 j_mayer
    CPU_POWERPC_XIPCHIP            = xxx,
5631 a750fc0b j_mayer
#endif
5632 a750fc0b j_mayer
    /* PowerPC 403 family */
5633 a750fc0b j_mayer
    /* Generic PowerPC 403 */
5634 80d11f44 j_mayer
#define CPU_POWERPC_403              CPU_POWERPC_403GC
5635 a750fc0b j_mayer
    /* PowerPC 403 microcontrollers */
5636 80d11f44 j_mayer
    CPU_POWERPC_403GA              = 0x00200011,
5637 80d11f44 j_mayer
    CPU_POWERPC_403GB              = 0x00200100,
5638 80d11f44 j_mayer
    CPU_POWERPC_403GC              = 0x00200200,
5639 80d11f44 j_mayer
    CPU_POWERPC_403GCX             = 0x00201400,
5640 a750fc0b j_mayer
#if 0
5641 80d11f44 j_mayer
    CPU_POWERPC_403GP              = xxx,
5642 a750fc0b j_mayer
#endif
5643 a750fc0b j_mayer
    /* PowerPC 405 family */
5644 a750fc0b j_mayer
    /* Generic PowerPC 405 */
5645 80d11f44 j_mayer
#define CPU_POWERPC_405              CPU_POWERPC_405D4
5646 a750fc0b j_mayer
    /* PowerPC 405 cores */
5647 a750fc0b j_mayer
#if 0
5648 80d11f44 j_mayer
    CPU_POWERPC_405A3              = xxx,
5649 a750fc0b j_mayer
#endif
5650 a750fc0b j_mayer
#if 0
5651 80d11f44 j_mayer
    CPU_POWERPC_405A4              = xxx,
5652 a750fc0b j_mayer
#endif
5653 a750fc0b j_mayer
#if 0
5654 80d11f44 j_mayer
    CPU_POWERPC_405B3              = xxx,
5655 a750fc0b j_mayer
#endif
5656 a750fc0b j_mayer
#if 0
5657 80d11f44 j_mayer
    CPU_POWERPC_405B4              = xxx,
5658 a750fc0b j_mayer
#endif
5659 a750fc0b j_mayer
#if 0
5660 80d11f44 j_mayer
    CPU_POWERPC_405C3              = xxx,
5661 a750fc0b j_mayer
#endif
5662 a750fc0b j_mayer
#if 0
5663 80d11f44 j_mayer
    CPU_POWERPC_405C4              = xxx,
5664 a750fc0b j_mayer
#endif
5665 80d11f44 j_mayer
    CPU_POWERPC_405D2              = 0x20010000,
5666 a750fc0b j_mayer
#if 0
5667 80d11f44 j_mayer
    CPU_POWERPC_405D3              = xxx,
5668 a750fc0b j_mayer
#endif
5669 80d11f44 j_mayer
    CPU_POWERPC_405D4              = 0x41810000,
5670 a750fc0b j_mayer
#if 0
5671 80d11f44 j_mayer
    CPU_POWERPC_405D5              = xxx,
5672 a750fc0b j_mayer
#endif
5673 a750fc0b j_mayer
#if 0
5674 80d11f44 j_mayer
    CPU_POWERPC_405E4              = xxx,
5675 a750fc0b j_mayer
#endif
5676 a750fc0b j_mayer
#if 0
5677 80d11f44 j_mayer
    CPU_POWERPC_405F4              = xxx,
5678 a750fc0b j_mayer
#endif
5679 a750fc0b j_mayer
#if 0
5680 80d11f44 j_mayer
    CPU_POWERPC_405F5              = xxx,
5681 a750fc0b j_mayer
#endif
5682 a750fc0b j_mayer
#if 0
5683 80d11f44 j_mayer
    CPU_POWERPC_405F6              = xxx,
5684 a750fc0b j_mayer
#endif
5685 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers */
5686 a750fc0b j_mayer
    /* XXX: missing 0x200108a0 */
5687 80d11f44 j_mayer
#define CPU_POWERPC_405CR            CPU_POWERPC_405CRc
5688 80d11f44 j_mayer
    CPU_POWERPC_405CRa             = 0x40110041,
5689 80d11f44 j_mayer
    CPU_POWERPC_405CRb             = 0x401100C5,
5690 80d11f44 j_mayer
    CPU_POWERPC_405CRc             = 0x40110145,
5691 80d11f44 j_mayer
    CPU_POWERPC_405EP              = 0x51210950,
5692 a750fc0b j_mayer
#if 0
5693 80d11f44 j_mayer
    CPU_POWERPC_405EXr             = xxx,
5694 a750fc0b j_mayer
#endif
5695 80d11f44 j_mayer
    CPU_POWERPC_405EZ              = 0x41511460, /* 0x51210950 ? */
5696 a750fc0b j_mayer
#if 0
5697 80d11f44 j_mayer
    CPU_POWERPC_405FX              = xxx,
5698 80d11f44 j_mayer
#endif
5699 80d11f44 j_mayer
#define CPU_POWERPC_405GP            CPU_POWERPC_405GPd
5700 80d11f44 j_mayer
    CPU_POWERPC_405GPa             = 0x40110000,
5701 80d11f44 j_mayer
    CPU_POWERPC_405GPb             = 0x40110040,
5702 80d11f44 j_mayer
    CPU_POWERPC_405GPc             = 0x40110082,
5703 80d11f44 j_mayer
    CPU_POWERPC_405GPd             = 0x401100C4,
5704 80d11f44 j_mayer
#define CPU_POWERPC_405GPe           CPU_POWERPC_405CRc
5705 80d11f44 j_mayer
    CPU_POWERPC_405GPR             = 0x50910951,
5706 a750fc0b j_mayer
#if 0
5707 80d11f44 j_mayer
    CPU_POWERPC_405H               = xxx,
5708 a750fc0b j_mayer
#endif
5709 a750fc0b j_mayer
#if 0
5710 80d11f44 j_mayer
    CPU_POWERPC_405L               = xxx,
5711 a750fc0b j_mayer
#endif
5712 80d11f44 j_mayer
    CPU_POWERPC_405LP              = 0x41F10000,
5713 a750fc0b j_mayer
#if 0
5714 80d11f44 j_mayer
    CPU_POWERPC_405PM              = xxx,
5715 a750fc0b j_mayer
#endif
5716 a750fc0b j_mayer
#if 0
5717 80d11f44 j_mayer
    CPU_POWERPC_405PS              = xxx,
5718 a750fc0b j_mayer
#endif
5719 a750fc0b j_mayer
#if 0
5720 80d11f44 j_mayer
    CPU_POWERPC_405S               = xxx,
5721 a750fc0b j_mayer
#endif
5722 a750fc0b j_mayer
    /* IBM network processors */
5723 80d11f44 j_mayer
    CPU_POWERPC_NPE405H            = 0x414100C0,
5724 80d11f44 j_mayer
    CPU_POWERPC_NPE405H2           = 0x41410140,
5725 80d11f44 j_mayer
    CPU_POWERPC_NPE405L            = 0x416100C0,
5726 80d11f44 j_mayer
    CPU_POWERPC_NPE4GS3            = 0x40B10000,
5727 a750fc0b j_mayer
#if 0
5728 80d11f44 j_mayer
    CPU_POWERPC_NPCxx1             = xxx,
5729 a750fc0b j_mayer
#endif
5730 a750fc0b j_mayer
#if 0
5731 80d11f44 j_mayer
    CPU_POWERPC_NPR161             = xxx,
5732 a750fc0b j_mayer
#endif
5733 a750fc0b j_mayer
#if 0
5734 80d11f44 j_mayer
    CPU_POWERPC_LC77700            = xxx,
5735 a750fc0b j_mayer
#endif
5736 a750fc0b j_mayer
    /* IBM STBxxx (PowerPC 401/403/405 core based microcontrollers) */
5737 a750fc0b j_mayer
#if 0
5738 80d11f44 j_mayer
    CPU_POWERPC_STB01000           = xxx,
5739 a750fc0b j_mayer
#endif
5740 a750fc0b j_mayer
#if 0
5741 80d11f44 j_mayer
    CPU_POWERPC_STB01010           = xxx,
5742 a750fc0b j_mayer
#endif
5743 a750fc0b j_mayer
#if 0
5744 80d11f44 j_mayer
    CPU_POWERPC_STB0210            = xxx, /* 401B3 */
5745 a750fc0b j_mayer
#endif
5746 80d11f44 j_mayer
    CPU_POWERPC_STB03              = 0x40310000, /* 0x40130000 ? */
5747 a750fc0b j_mayer
#if 0
5748 80d11f44 j_mayer
    CPU_POWERPC_STB043             = xxx,
5749 a750fc0b j_mayer
#endif
5750 a750fc0b j_mayer
#if 0
5751 80d11f44 j_mayer
    CPU_POWERPC_STB045             = xxx,
5752 a750fc0b j_mayer
#endif
5753 80d11f44 j_mayer
    CPU_POWERPC_STB04              = 0x41810000,
5754 80d11f44 j_mayer
    CPU_POWERPC_STB25              = 0x51510950,
5755 a750fc0b j_mayer
#if 0
5756 80d11f44 j_mayer
    CPU_POWERPC_STB130             = xxx,
5757 a750fc0b j_mayer
#endif
5758 a750fc0b j_mayer
    /* Xilinx cores */
5759 80d11f44 j_mayer
    CPU_POWERPC_X2VP4              = 0x20010820,
5760 80d11f44 j_mayer
#define CPU_POWERPC_X2VP7            CPU_POWERPC_X2VP4
5761 80d11f44 j_mayer
    CPU_POWERPC_X2VP20             = 0x20010860,
5762 80d11f44 j_mayer
#define CPU_POWERPC_X2VP50           CPU_POWERPC_X2VP20
5763 a750fc0b j_mayer
#if 0
5764 80d11f44 j_mayer
    CPU_POWERPC_ZL10310            = xxx,
5765 a750fc0b j_mayer
#endif
5766 a750fc0b j_mayer
#if 0
5767 80d11f44 j_mayer
    CPU_POWERPC_ZL10311            = xxx,
5768 a750fc0b j_mayer
#endif
5769 a750fc0b j_mayer
#if 0
5770 80d11f44 j_mayer
    CPU_POWERPC_ZL10320            = xxx,
5771 a750fc0b j_mayer
#endif
5772 a750fc0b j_mayer
#if 0
5773 80d11f44 j_mayer
    CPU_POWERPC_ZL10321            = xxx,
5774 a750fc0b j_mayer
#endif
5775 a750fc0b j_mayer
    /* PowerPC 440 family */
5776 a750fc0b j_mayer
    /* Generic PowerPC 440 */
5777 80d11f44 j_mayer
#define CPU_POWERPC_440              CPU_POWERPC_440GXf
5778 a750fc0b j_mayer
    /* PowerPC 440 cores */
5779 a750fc0b j_mayer
#if 0
5780 80d11f44 j_mayer
    CPU_POWERPC_440A4              = xxx,
5781 a750fc0b j_mayer
#endif
5782 a750fc0b j_mayer
#if 0
5783 80d11f44 j_mayer
    CPU_POWERPC_440A5              = xxx,
5784 a750fc0b j_mayer
#endif
5785 a750fc0b j_mayer
#if 0
5786 80d11f44 j_mayer
    CPU_POWERPC_440B4              = xxx,
5787 a750fc0b j_mayer
#endif
5788 a750fc0b j_mayer
#if 0
5789 80d11f44 j_mayer
    CPU_POWERPC_440F5              = xxx,
5790 a750fc0b j_mayer
#endif
5791 a750fc0b j_mayer
#if 0
5792 80d11f44 j_mayer
    CPU_POWERPC_440G5              = xxx,
5793 a750fc0b j_mayer
#endif
5794 a750fc0b j_mayer
#if 0
5795 80d11f44 j_mayer
    CPU_POWERPC_440H4              = xxx,
5796 a750fc0b j_mayer
#endif
5797 a750fc0b j_mayer
#if 0
5798 80d11f44 j_mayer
    CPU_POWERPC_440H6              = xxx,
5799 a750fc0b j_mayer
#endif
5800 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers */
5801 80d11f44 j_mayer
#define CPU_POWERPC_440EP            CPU_POWERPC_440EPb
5802 80d11f44 j_mayer
    CPU_POWERPC_440EPa             = 0x42221850,
5803 80d11f44 j_mayer
    CPU_POWERPC_440EPb             = 0x422218D3,
5804 80d11f44 j_mayer
#define CPU_POWERPC_440GP            CPU_POWERPC_440GPc
5805 80d11f44 j_mayer
    CPU_POWERPC_440GPb             = 0x40120440,
5806 80d11f44 j_mayer
    CPU_POWERPC_440GPc             = 0x40120481,
5807 80d11f44 j_mayer
#define CPU_POWERPC_440GR            CPU_POWERPC_440GRa
5808 80d11f44 j_mayer
#define CPU_POWERPC_440GRa           CPU_POWERPC_440EPb
5809 80d11f44 j_mayer
    CPU_POWERPC_440GRX             = 0x200008D0,
5810 80d11f44 j_mayer
#define CPU_POWERPC_440EPX           CPU_POWERPC_440GRX
5811 80d11f44 j_mayer
#define CPU_POWERPC_440GX            CPU_POWERPC_440GXf
5812 80d11f44 j_mayer
    CPU_POWERPC_440GXa             = 0x51B21850,
5813 80d11f44 j_mayer
    CPU_POWERPC_440GXb             = 0x51B21851,
5814 80d11f44 j_mayer
    CPU_POWERPC_440GXc             = 0x51B21892,
5815 80d11f44 j_mayer
    CPU_POWERPC_440GXf             = 0x51B21894,
5816 a750fc0b j_mayer
#if 0
5817 80d11f44 j_mayer
    CPU_POWERPC_440S               = xxx,
5818 a750fc0b j_mayer
#endif
5819 80d11f44 j_mayer
    CPU_POWERPC_440SP              = 0x53221850,
5820 80d11f44 j_mayer
    CPU_POWERPC_440SP2             = 0x53221891,
5821 80d11f44 j_mayer
    CPU_POWERPC_440SPE             = 0x53421890,
5822 a750fc0b j_mayer
    /* PowerPC 460 family */
5823 a750fc0b j_mayer
#if 0
5824 a750fc0b j_mayer
    /* Generic PowerPC 464 */
5825 80d11f44 j_mayer
#define CPU_POWERPC_464              CPU_POWERPC_464H90
5826 a750fc0b j_mayer
#endif
5827 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers */
5828 a750fc0b j_mayer
#if 0
5829 80d11f44 j_mayer
    CPU_POWERPC_464H90             = xxx,
5830 a750fc0b j_mayer
#endif
5831 a750fc0b j_mayer
#if 0
5832 80d11f44 j_mayer
    CPU_POWERPC_464H90FP           = xxx,
5833 a750fc0b j_mayer
#endif
5834 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores */
5835 c3e36823 j_mayer
    /* PowerPC MPC 5xx cores (aka RCPU) */
5836 80d11f44 j_mayer
    CPU_POWERPC_MPC5xx             = 0x00020020,
5837 80d11f44 j_mayer
#define CPU_POWERPC_MGT560           CPU_POWERPC_MPC5xx
5838 80d11f44 j_mayer
#define CPU_POWERPC_MPC509           CPU_POWERPC_MPC5xx
5839 80d11f44 j_mayer
#define CPU_POWERPC_MPC533           CPU_POWERPC_MPC5xx
5840 80d11f44 j_mayer
#define CPU_POWERPC_MPC534           CPU_POWERPC_MPC5xx
5841 80d11f44 j_mayer
#define CPU_POWERPC_MPC555           CPU_POWERPC_MPC5xx
5842 80d11f44 j_mayer
#define CPU_POWERPC_MPC556           CPU_POWERPC_MPC5xx
5843 80d11f44 j_mayer
#define CPU_POWERPC_MPC560           CPU_POWERPC_MPC5xx
5844 80d11f44 j_mayer
#define CPU_POWERPC_MPC561           CPU_POWERPC_MPC5xx
5845 80d11f44 j_mayer
#define CPU_POWERPC_MPC562           CPU_POWERPC_MPC5xx
5846 80d11f44 j_mayer
#define CPU_POWERPC_MPC563           CPU_POWERPC_MPC5xx
5847 80d11f44 j_mayer
#define CPU_POWERPC_MPC564           CPU_POWERPC_MPC5xx
5848 80d11f44 j_mayer
#define CPU_POWERPC_MPC565           CPU_POWERPC_MPC5xx
5849 80d11f44 j_mayer
#define CPU_POWERPC_MPC566           CPU_POWERPC_MPC5xx
5850 c3e36823 j_mayer
    /* PowerPC MPC 8xx cores (aka PowerQUICC) */
5851 80d11f44 j_mayer
    CPU_POWERPC_MPC8xx             = 0x00500000,
5852 80d11f44 j_mayer
#define CPU_POWERPC_MGT823           CPU_POWERPC_MPC8xx
5853 80d11f44 j_mayer
#define CPU_POWERPC_MPC821           CPU_POWERPC_MPC8xx
5854 80d11f44 j_mayer
#define CPU_POWERPC_MPC823           CPU_POWERPC_MPC8xx
5855 80d11f44 j_mayer
#define CPU_POWERPC_MPC850           CPU_POWERPC_MPC8xx
5856 80d11f44 j_mayer
#define CPU_POWERPC_MPC852T          CPU_POWERPC_MPC8xx
5857 80d11f44 j_mayer
#define CPU_POWERPC_MPC855T          CPU_POWERPC_MPC8xx
5858 80d11f44 j_mayer
#define CPU_POWERPC_MPC857           CPU_POWERPC_MPC8xx
5859 80d11f44 j_mayer
#define CPU_POWERPC_MPC859           CPU_POWERPC_MPC8xx
5860 80d11f44 j_mayer
#define CPU_POWERPC_MPC860           CPU_POWERPC_MPC8xx
5861 80d11f44 j_mayer
#define CPU_POWERPC_MPC862           CPU_POWERPC_MPC8xx
5862 80d11f44 j_mayer
#define CPU_POWERPC_MPC866           CPU_POWERPC_MPC8xx
5863 80d11f44 j_mayer
#define CPU_POWERPC_MPC870           CPU_POWERPC_MPC8xx
5864 80d11f44 j_mayer
#define CPU_POWERPC_MPC875           CPU_POWERPC_MPC8xx
5865 80d11f44 j_mayer
#define CPU_POWERPC_MPC880           CPU_POWERPC_MPC8xx
5866 80d11f44 j_mayer
#define CPU_POWERPC_MPC885           CPU_POWERPC_MPC8xx
5867 c3e36823 j_mayer
    /* G2 cores (aka PowerQUICC-II) */
5868 80d11f44 j_mayer
    CPU_POWERPC_G2                 = 0x00810011,
5869 80d11f44 j_mayer
    CPU_POWERPC_G2H4               = 0x80811010,
5870 80d11f44 j_mayer
    CPU_POWERPC_G2gp               = 0x80821010,
5871 80d11f44 j_mayer
    CPU_POWERPC_G2ls               = 0x90810010,
5872 80d11f44 j_mayer
    CPU_POWERPC_MPC603             = 0x00810100,
5873 80d11f44 j_mayer
    CPU_POWERPC_G2_HIP3            = 0x00810101,
5874 80d11f44 j_mayer
    CPU_POWERPC_G2_HIP4            = 0x80811014,
5875 c3e36823 j_mayer
    /*   G2_LE core (aka PowerQUICC-II) */
5876 80d11f44 j_mayer
    CPU_POWERPC_G2LE               = 0x80820010,
5877 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp             = 0x80822010,
5878 80d11f44 j_mayer
    CPU_POWERPC_G2LEls             = 0xA0822010,
5879 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp1            = 0x80822011,
5880 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp3            = 0x80822013,
5881 80d11f44 j_mayer
    /* MPC52xx microcontrollers  */
5882 c3e36823 j_mayer
    /* XXX: MPC 5121 ? */
5883 80d11f44 j_mayer
#define CPU_POWERPC_MPC52xx          CPU_POWERPC_MPC5200
5884 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200          CPU_POWERPC_MPC5200_v12
5885 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v10      CPU_POWERPC_G2LEgp1
5886 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v11      CPU_POWERPC_G2LEgp1
5887 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v12      CPU_POWERPC_G2LEgp1
5888 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B         CPU_POWERPC_MPC5200B_v21
5889 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B_v20     CPU_POWERPC_G2LEgp1
5890 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B_v21     CPU_POWERPC_G2LEgp1
5891 80d11f44 j_mayer
    /* MPC82xx microcontrollers */
5892 80d11f44 j_mayer
#define CPU_POWERPC_MPC82xx          CPU_POWERPC_MPC8280
5893 80d11f44 j_mayer
#define CPU_POWERPC_MPC8240          CPU_POWERPC_MPC603
5894 80d11f44 j_mayer
#define CPU_POWERPC_MPC8241          CPU_POWERPC_G2_HIP4
5895 80d11f44 j_mayer
#define CPU_POWERPC_MPC8245          CPU_POWERPC_G2_HIP4
5896 80d11f44 j_mayer
#define CPU_POWERPC_MPC8247          CPU_POWERPC_G2LEgp3
5897 80d11f44 j_mayer
#define CPU_POWERPC_MPC8248          CPU_POWERPC_G2LEgp3
5898 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250          CPU_POWERPC_MPC8250_HiP4
5899 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250_HiP3     CPU_POWERPC_G2_HIP3
5900 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250_HiP4     CPU_POWERPC_G2_HIP4
5901 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255          CPU_POWERPC_MPC8255_HiP4
5902 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255_HiP3     CPU_POWERPC_G2_HIP3
5903 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255_HiP4     CPU_POWERPC_G2_HIP4
5904 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260          CPU_POWERPC_MPC8260_HiP4
5905 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260_HiP3     CPU_POWERPC_G2_HIP3
5906 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260_HiP4     CPU_POWERPC_G2_HIP4
5907 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264          CPU_POWERPC_MPC8264_HiP4
5908 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264_HiP3     CPU_POWERPC_G2_HIP3
5909 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264_HiP4     CPU_POWERPC_G2_HIP4
5910 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265          CPU_POWERPC_MPC8265_HiP4
5911 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265_HiP3     CPU_POWERPC_G2_HIP3
5912 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265_HiP4     CPU_POWERPC_G2_HIP4
5913 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266          CPU_POWERPC_MPC8266_HiP4
5914 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266_HiP3     CPU_POWERPC_G2_HIP3
5915 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266_HiP4     CPU_POWERPC_G2_HIP4
5916 80d11f44 j_mayer
#define CPU_POWERPC_MPC8270          CPU_POWERPC_G2LEgp3
5917 80d11f44 j_mayer
#define CPU_POWERPC_MPC8271          CPU_POWERPC_G2LEgp3
5918 80d11f44 j_mayer
#define CPU_POWERPC_MPC8272          CPU_POWERPC_G2LEgp3
5919 80d11f44 j_mayer
#define CPU_POWERPC_MPC8275          CPU_POWERPC_G2LEgp3
5920 80d11f44 j_mayer
#define CPU_POWERPC_MPC8280          CPU_POWERPC_G2LEgp3
5921 a750fc0b j_mayer
    /* e200 family */
5922 80d11f44 j_mayer
    /* e200 cores */
5923 80d11f44 j_mayer
#define CPU_POWERPC_e200             CPU_POWERPC_e200z6
5924 a750fc0b j_mayer
#if 0
5925 80d11f44 j_mayer
    CPU_POWERPC_e200z0             = xxx,
5926 a750fc0b j_mayer
#endif
5927 a750fc0b j_mayer
#if 0
5928 80d11f44 j_mayer
    CPU_POWERPC_e200z1             = xxx,
5929 c3e36823 j_mayer
#endif
5930 c3e36823 j_mayer
#if 0 /* ? */
5931 80d11f44 j_mayer
    CPU_POWERPC_e200z3             = 0x81120000,
5932 80d11f44 j_mayer
#endif
5933 80d11f44 j_mayer
    CPU_POWERPC_e200z5             = 0x81000000,
5934 80d11f44 j_mayer
    CPU_POWERPC_e200z6             = 0x81120000,
5935 80d11f44 j_mayer
    /* MPC55xx microcontrollers */
5936 80d11f44 j_mayer
#define CPU_POWERPC_MPC55xx          CPU_POWERPC_MPC5567
5937 80d11f44 j_mayer
#if 0
5938 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E         CPU_POWERPC_MPC5514E_v1
5939 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E_v0      CPU_POWERPC_e200z0
5940 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E_v1      CPU_POWERPC_e200z1
5941 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G         CPU_POWERPC_MPC5514G_v1
5942 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G_v0      CPU_POWERPC_e200z0
5943 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G_v1      CPU_POWERPC_e200z1
5944 80d11f44 j_mayer
#define CPU_POWERPC_MPC5515S         CPU_POWERPC_e200z1
5945 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E         CPU_POWERPC_MPC5516E_v1
5946 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E_v0      CPU_POWERPC_e200z0
5947 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E_v1      CPU_POWERPC_e200z1
5948 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G         CPU_POWERPC_MPC5516G_v1
5949 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G_v0      CPU_POWERPC_e200z0
5950 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G_v1      CPU_POWERPC_e200z1
5951 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516S         CPU_POWERPC_e200z1
5952 80d11f44 j_mayer
#endif
5953 80d11f44 j_mayer
#if 0
5954 80d11f44 j_mayer
#define CPU_POWERPC_MPC5533          CPU_POWERPC_e200z3
5955 80d11f44 j_mayer
#define CPU_POWERPC_MPC5534          CPU_POWERPC_e200z3
5956 80d11f44 j_mayer
#endif
5957 80d11f44 j_mayer
#define CPU_POWERPC_MPC5553          CPU_POWERPC_e200z6
5958 80d11f44 j_mayer
#define CPU_POWERPC_MPC5554          CPU_POWERPC_e200z6
5959 80d11f44 j_mayer
#define CPU_POWERPC_MPC5561          CPU_POWERPC_e200z6
5960 80d11f44 j_mayer
#define CPU_POWERPC_MPC5565          CPU_POWERPC_e200z6
5961 80d11f44 j_mayer
#define CPU_POWERPC_MPC5566          CPU_POWERPC_e200z6
5962 80d11f44 j_mayer
#define CPU_POWERPC_MPC5567          CPU_POWERPC_e200z6
5963 a750fc0b j_mayer
    /* e300 family */
5964 80d11f44 j_mayer
    /* e300 cores */
5965 80d11f44 j_mayer
#define CPU_POWERPC_e300             CPU_POWERPC_e300c3
5966 80d11f44 j_mayer
    CPU_POWERPC_e300c1             = 0x00830010,
5967 80d11f44 j_mayer
    CPU_POWERPC_e300c2             = 0x00840010,
5968 80d11f44 j_mayer
    CPU_POWERPC_e300c3             = 0x00850010,
5969 80d11f44 j_mayer
    CPU_POWERPC_e300c4             = 0x00860010,
5970 80d11f44 j_mayer
    /* MPC83xx microcontrollers */
5971 80d11f44 j_mayer
#define CPU_POWERPC_MPC8313          CPU_POWERPC_e300c3
5972 80d11f44 j_mayer
#define CPU_POWERPC_MPC8313E         CPU_POWERPC_e300c3
5973 80d11f44 j_mayer
#define CPU_POWERPC_MPC8314          CPU_POWERPC_e300c3
5974 80d11f44 j_mayer
#define CPU_POWERPC_MPC8314E         CPU_POWERPC_e300c3
5975 80d11f44 j_mayer
#define CPU_POWERPC_MPC8315          CPU_POWERPC_e300c3
5976 80d11f44 j_mayer
#define CPU_POWERPC_MPC8315E         CPU_POWERPC_e300c3
5977 80d11f44 j_mayer
#define CPU_POWERPC_MPC8321          CPU_POWERPC_e300c2
5978 80d11f44 j_mayer
#define CPU_POWERPC_MPC8321E         CPU_POWERPC_e300c2
5979 80d11f44 j_mayer
#define CPU_POWERPC_MPC8323          CPU_POWERPC_e300c2
5980 80d11f44 j_mayer
#define CPU_POWERPC_MPC8323E         CPU_POWERPC_e300c2
5981 80d11f44 j_mayer
#define CPU_POWERPC_MPC8343A         CPU_POWERPC_e300c1
5982 80d11f44 j_mayer
#define CPU_POWERPC_MPC8343EA        CPU_POWERPC_e300c1
5983 80d11f44 j_mayer
#define CPU_POWERPC_MPC8347A         CPU_POWERPC_e300c1
5984 80d11f44 j_mayer
#define CPU_POWERPC_MPC8347AT        CPU_POWERPC_e300c1
5985 80d11f44 j_mayer
#define CPU_POWERPC_MPC8347AP        CPU_POWERPC_e300c1
5986 80d11f44 j_mayer
#define CPU_POWERPC_MPC8347EA        CPU_POWERPC_e300c1
5987 80d11f44 j_mayer
#define CPU_POWERPC_MPC8347EAT       CPU_POWERPC_e300c1
5988 80d11f44 j_mayer
#define CPU_POWERPC_MPC8347EAP       CPU_POWERPC_e300c1
5989 80d11f44 j_mayer
#define CPU_POWERPC_MPC8349          CPU_POWERPC_e300c1
5990 80d11f44 j_mayer
#define CPU_POWERPC_MPC8349A         CPU_POWERPC_e300c1
5991 80d11f44 j_mayer
#define CPU_POWERPC_MPC8349E         CPU_POWERPC_e300c1
5992 80d11f44 j_mayer
#define CPU_POWERPC_MPC8349EA        CPU_POWERPC_e300c1
5993 80d11f44 j_mayer
#define CPU_POWERPC_MPC8358E         CPU_POWERPC_e300c1
5994 80d11f44 j_mayer
#define CPU_POWERPC_MPC8360E         CPU_POWERPC_e300c1
5995 80d11f44 j_mayer
#define CPU_POWERPC_MPC8377          CPU_POWERPC_e300c4
5996 80d11f44 j_mayer
#define CPU_POWERPC_MPC8377E         CPU_POWERPC_e300c4
5997 80d11f44 j_mayer
#define CPU_POWERPC_MPC8378          CPU_POWERPC_e300c4
5998 80d11f44 j_mayer
#define CPU_POWERPC_MPC8378E         CPU_POWERPC_e300c4
5999 80d11f44 j_mayer
#define CPU_POWERPC_MPC8379          CPU_POWERPC_e300c4
6000 80d11f44 j_mayer
#define CPU_POWERPC_MPC8379E         CPU_POWERPC_e300c4
6001 a750fc0b j_mayer
    /* e500 family */
6002 80d11f44 j_mayer
    /* e500 cores  */
6003 80d11f44 j_mayer
#define CPU_POWERPC_e500             CPU_POWERPC_e500v2_v22
6004 80d11f44 j_mayer
#define CPU_POWERPC_e500v2           CPU_POWERPC_e500v2_v22
6005 80d11f44 j_mayer
    CPU_POWERPC_e500_v10           = 0x80200010,
6006 80d11f44 j_mayer
    CPU_POWERPC_e500_v20           = 0x80200020,
6007 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v10         = 0x80210010,
6008 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v11         = 0x80210011,
6009 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v20         = 0x80210020,
6010 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v21         = 0x80210021,
6011 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v22         = 0x80210022,
6012 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v30         = 0x80210030,
6013 80d11f44 j_mayer
    /* MPC85xx microcontrollers */
6014 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533          CPU_POWERPC_MPC8533_v11
6015 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533_v10      CPU_POWERPC_e500v2_v21
6016 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533_v11      CPU_POWERPC_e500v2_v22
6017 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E         CPU_POWERPC_MPC8533E_v11
6018 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E_v10     CPU_POWERPC_e500v2_v21
6019 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E_v11     CPU_POWERPC_e500v2_v22
6020 80d11f44 j_mayer
#define CPU_POWERPC_MPC8540          CPU_POWERPC_MPC8540_v21
6021 80d11f44 j_mayer
#define CPU_POWERPC_MPC8540_v10      CPU_POWERPC_e500_v10
6022 80d11f44 j_mayer
#define CPU_POWERPC_MPC8540_v20      CPU_POWERPC_e500_v20
6023 80d11f44 j_mayer
#define CPU_POWERPC_MPC8540_v21      CPU_POWERPC_e500_v20
6024 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541          CPU_POWERPC_MPC8541_v11
6025 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541_v10      CPU_POWERPC_e500_v20
6026 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541_v11      CPU_POWERPC_e500_v20
6027 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541E         CPU_POWERPC_MPC8541E_v11
6028 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541E_v10     CPU_POWERPC_e500_v20
6029 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541E_v11     CPU_POWERPC_e500_v20
6030 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543          CPU_POWERPC_MPC8543_v21
6031 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v10      CPU_POWERPC_e500v2_v10
6032 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v11      CPU_POWERPC_e500v2_v11
6033 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v20      CPU_POWERPC_e500v2_v20
6034 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v21      CPU_POWERPC_e500v2_v21
6035 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E         CPU_POWERPC_MPC8543E_v21
6036 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v10     CPU_POWERPC_e500v2_v10
6037 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v11     CPU_POWERPC_e500v2_v11
6038 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v20     CPU_POWERPC_e500v2_v20
6039 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v21     CPU_POWERPC_e500v2_v21
6040 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544          CPU_POWERPC_MPC8544_v11
6041 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544_v10      CPU_POWERPC_e500v2_v21
6042 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544_v11      CPU_POWERPC_e500v2_v22
6043 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E_v11     CPU_POWERPC_e500v2_v22
6044 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E         CPU_POWERPC_MPC8544E_v11
6045 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E_v10     CPU_POWERPC_e500v2_v21
6046 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545          CPU_POWERPC_MPC8545_v21
6047 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v10      CPU_POWERPC_e500v2_v10
6048 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v20      CPU_POWERPC_e500v2_v20
6049 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v21      CPU_POWERPC_e500v2_v21
6050 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E         CPU_POWERPC_MPC8545E_v21
6051 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v10     CPU_POWERPC_e500v2_v10
6052 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v20     CPU_POWERPC_e500v2_v20
6053 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v21     CPU_POWERPC_e500v2_v21
6054 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E         CPU_POWERPC_MPC8545E_v21
6055 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v10     CPU_POWERPC_e500v2_v10
6056 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v20     CPU_POWERPC_e500v2_v20
6057 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v21     CPU_POWERPC_e500v2_v21
6058 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548          CPU_POWERPC_MPC8548_v21
6059 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v10      CPU_POWERPC_e500v2_v10
6060 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v11      CPU_POWERPC_e500v2_v11
6061 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v20      CPU_POWERPC_e500v2_v20
6062 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v21      CPU_POWERPC_e500v2_v21
6063 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E         CPU_POWERPC_MPC8548E_v21
6064 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v10     CPU_POWERPC_e500v2_v10
6065 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v11     CPU_POWERPC_e500v2_v11
6066 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v20     CPU_POWERPC_e500v2_v20
6067 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v21     CPU_POWERPC_e500v2_v21
6068 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555          CPU_POWERPC_MPC8555_v11
6069 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555_v10      CPU_POWERPC_e500v2_v10
6070 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555_v11      CPU_POWERPC_e500v2_v11
6071 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E         CPU_POWERPC_MPC8555E_v11
6072 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E_v10     CPU_POWERPC_e500v2_v10
6073 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E_v11     CPU_POWERPC_e500v2_v11
6074 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560          CPU_POWERPC_MPC8560_v21
6075 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v10      CPU_POWERPC_e500v2_v10
6076 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v20      CPU_POWERPC_e500v2_v20
6077 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v21      CPU_POWERPC_e500v2_v21
6078 80d11f44 j_mayer
#define CPU_POWERPC_MPC8567          CPU_POWERPC_e500v2_v22
6079 80d11f44 j_mayer
#define CPU_POWERPC_MPC8567E         CPU_POWERPC_e500v2_v22
6080 80d11f44 j_mayer
#define CPU_POWERPC_MPC8568          CPU_POWERPC_e500v2_v22
6081 80d11f44 j_mayer
#define CPU_POWERPC_MPC8568E         CPU_POWERPC_e500v2_v22
6082 80d11f44 j_mayer
#define CPU_POWERPC_MPC8572          CPU_POWERPC_e500v2_v30
6083 80d11f44 j_mayer
#define CPU_POWERPC_MPC8572E         CPU_POWERPC_e500v2_v30
6084 a750fc0b j_mayer
    /* e600 family */
6085 80d11f44 j_mayer
    /* e600 cores */
6086 80d11f44 j_mayer
    CPU_POWERPC_e600               = 0x80040010,
6087 80d11f44 j_mayer
    /* MPC86xx microcontrollers */
6088 80d11f44 j_mayer
#define CPU_POWERPC_MPC8610          CPU_POWERPC_e600
6089 80d11f44 j_mayer
#define CPU_POWERPC_MPC8641          CPU_POWERPC_e600
6090 80d11f44 j_mayer
#define CPU_POWERPC_MPC8641D         CPU_POWERPC_e600
6091 a750fc0b j_mayer
    /* PowerPC 6xx cores */
6092 80d11f44 j_mayer
#define CPU_POWERPC_601              CPU_POWERPC_601_v2
6093 80d11f44 j_mayer
    CPU_POWERPC_601_v0             = 0x00010001,
6094 80d11f44 j_mayer
    CPU_POWERPC_601_v1             = 0x00010001,
6095 80d11f44 j_mayer
    CPU_POWERPC_601_v2             = 0x00010002,
6096 80d11f44 j_mayer
    CPU_POWERPC_602                = 0x00050100,
6097 80d11f44 j_mayer
    CPU_POWERPC_603                = 0x00030100,
6098 80d11f44 j_mayer
#define CPU_POWERPC_603E             CPU_POWERPC_603E_v41
6099 80d11f44 j_mayer
    CPU_POWERPC_603E_v11           = 0x00060101,
6100 80d11f44 j_mayer
    CPU_POWERPC_603E_v12           = 0x00060102,
6101 80d11f44 j_mayer
    CPU_POWERPC_603E_v13           = 0x00060103,
6102 80d11f44 j_mayer
    CPU_POWERPC_603E_v14           = 0x00060104,
6103 80d11f44 j_mayer
    CPU_POWERPC_603E_v22           = 0x00060202,
6104 80d11f44 j_mayer
    CPU_POWERPC_603E_v3            = 0x00060300,
6105 80d11f44 j_mayer
    CPU_POWERPC_603E_v4            = 0x00060400,
6106 80d11f44 j_mayer
    CPU_POWERPC_603E_v41           = 0x00060401,
6107 80d11f44 j_mayer
    CPU_POWERPC_603E7t             = 0x00071201,
6108 80d11f44 j_mayer
    CPU_POWERPC_603E7v             = 0x00070100,
6109 80d11f44 j_mayer
    CPU_POWERPC_603E7v1            = 0x00070101,
6110 80d11f44 j_mayer
    CPU_POWERPC_603E7v2            = 0x00070201,
6111 80d11f44 j_mayer
    CPU_POWERPC_603E7              = 0x00070200,
6112 80d11f44 j_mayer
    CPU_POWERPC_603P               = 0x00070000,
6113 80d11f44 j_mayer
#define CPU_POWERPC_603R             CPU_POWERPC_603E7t
6114 c3e36823 j_mayer
    /* XXX: missing 0x00040303 (604) */
6115 80d11f44 j_mayer
    CPU_POWERPC_604                = 0x00040103,
6116 80d11f44 j_mayer
#define CPU_POWERPC_604E             CPU_POWERPC_604E_v24
6117 c3e36823 j_mayer
    /* XXX: missing 0x00091203 */
6118 c3e36823 j_mayer
    /* XXX: missing 0x00092110 */
6119 c3e36823 j_mayer
    /* XXX: missing 0x00092120 */
6120 80d11f44 j_mayer
    CPU_POWERPC_604E_v10           = 0x00090100,
6121 80d11f44 j_mayer
    CPU_POWERPC_604E_v22           = 0x00090202,
6122 80d11f44 j_mayer
    CPU_POWERPC_604E_v24           = 0x00090204,
6123 c3e36823 j_mayer
    /* XXX: missing 0x000a0100 */
6124 c3e36823 j_mayer
    /* XXX: missing 0x00093102 */
6125 80d11f44 j_mayer
    CPU_POWERPC_604R               = 0x000a0101,
6126 a750fc0b j_mayer
#if 0
6127 80d11f44 j_mayer
    CPU_POWERPC_604EV              = xxx, /* XXX: same as 604R ? */
6128 a750fc0b j_mayer
#endif
6129 a750fc0b j_mayer
    /* PowerPC 740/750 cores (aka G3) */
6130 a750fc0b j_mayer
    /* XXX: missing 0x00084202 */
6131 80d11f44 j_mayer
#define CPU_POWERPC_7x0              CPU_POWERPC_7x0_v31
6132 80d11f44 j_mayer
    CPU_POWERPC_7x0_v20            = 0x00080200,
6133 80d11f44 j_mayer
    CPU_POWERPC_7x0_v21            = 0x00080201,
6134 80d11f44 j_mayer
    CPU_POWERPC_7x0_v22            = 0x00080202,
6135 80d11f44 j_mayer
    CPU_POWERPC_7x0_v30            = 0x00080300,
6136 80d11f44 j_mayer
    CPU_POWERPC_7x0_v31            = 0x00080301,
6137 80d11f44 j_mayer
    CPU_POWERPC_740E               = 0x00080100,
6138 80d11f44 j_mayer
    CPU_POWERPC_7x0P               = 0x10080000,
6139 a750fc0b j_mayer
    /* XXX: missing 0x00087010 (CL ?) */
6140 80d11f44 j_mayer
    CPU_POWERPC_750CL              = 0x00087200,
6141 80d11f44 j_mayer
#define CPU_POWERPC_750CX            CPU_POWERPC_750CX_v22
6142 80d11f44 j_mayer
    CPU_POWERPC_750CX_v21          = 0x00082201,
6143 80d11f44 j_mayer
    CPU_POWERPC_750CX_v22          = 0x00082202,
6144 80d11f44 j_mayer
#define CPU_POWERPC_750CXE           CPU_POWERPC_750CXE_v31b
6145 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v21         = 0x00082211,
6146 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v22         = 0x00082212,
6147 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v23         = 0x00082213,
6148 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v24         = 0x00082214,
6149 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v24b        = 0x00083214,
6150 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v31         = 0x00083211,
6151 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v31b        = 0x00083311,
6152 80d11f44 j_mayer
    CPU_POWERPC_750CXR             = 0x00083410,
6153 80d11f44 j_mayer
    CPU_POWERPC_750E               = 0x00080200,
6154 80d11f44 j_mayer
    CPU_POWERPC_750FL              = 0x700A0203,
6155 80d11f44 j_mayer
#define CPU_POWERPC_750FX            CPU_POWERPC_750FX_v23
6156 80d11f44 j_mayer
    CPU_POWERPC_750FX_v10          = 0x70000100,
6157 80d11f44 j_mayer
    CPU_POWERPC_750FX_v20          = 0x70000200,
6158 80d11f44 j_mayer
    CPU_POWERPC_750FX_v21          = 0x70000201,
6159 80d11f44 j_mayer
    CPU_POWERPC_750FX_v22          = 0x70000202,
6160 80d11f44 j_mayer
    CPU_POWERPC_750FX_v23          = 0x70000203,
6161 80d11f44 j_mayer
    CPU_POWERPC_750GL              = 0x70020102,
6162 80d11f44 j_mayer
#define CPU_POWERPC_750GX            CPU_POWERPC_750GX_v12
6163 80d11f44 j_mayer
    CPU_POWERPC_750GX_v10          = 0x70020100,
6164 80d11f44 j_mayer
    CPU_POWERPC_750GX_v11          = 0x70020101,
6165 80d11f44 j_mayer
    CPU_POWERPC_750GX_v12          = 0x70020102,
6166 80d11f44 j_mayer
#define CPU_POWERPC_750L             CPU_POWERPC_750L_v32 /* Aka LoneStar */
6167 80d11f44 j_mayer
    CPU_POWERPC_750L_v22           = 0x00088202,
6168 80d11f44 j_mayer
    CPU_POWERPC_750L_v30           = 0x00088300,
6169 80d11f44 j_mayer
    CPU_POWERPC_750L_v32           = 0x00088302,
6170 a750fc0b j_mayer
    /* PowerPC 745/755 cores */
6171 80d11f44 j_mayer
#define CPU_POWERPC_7x5              CPU_POWERPC_7x5_v28
6172 80d11f44 j_mayer
    CPU_POWERPC_7x5_v10            = 0x00083100,
6173 80d11f44 j_mayer
    CPU_POWERPC_7x5_v11            = 0x00083101,
6174 80d11f44 j_mayer
    CPU_POWERPC_7x5_v20            = 0x00083200,
6175 80d11f44 j_mayer
    CPU_POWERPC_7x5_v21            = 0x00083201,
6176 80d11f44 j_mayer
    CPU_POWERPC_7x5_v22            = 0x00083202, /* aka D */
6177 80d11f44 j_mayer
    CPU_POWERPC_7x5_v23            = 0x00083203, /* aka E */
6178 80d11f44 j_mayer
    CPU_POWERPC_7x5_v24            = 0x00083204,
6179 80d11f44 j_mayer
    CPU_POWERPC_7x5_v25            = 0x00083205,
6180 80d11f44 j_mayer
    CPU_POWERPC_7x5_v26            = 0x00083206,
6181 80d11f44 j_mayer
    CPU_POWERPC_7x5_v27            = 0x00083207,
6182 80d11f44 j_mayer
    CPU_POWERPC_7x5_v28            = 0x00083208,
6183 a750fc0b j_mayer
#if 0
6184 80d11f44 j_mayer
    CPU_POWERPC_7x5P               = xxx,
6185 a750fc0b j_mayer
#endif
6186 a750fc0b j_mayer
    /* PowerPC 74xx cores (aka G4) */
6187 a750fc0b j_mayer
    /* XXX: missing 0x000C1101 */
6188 80d11f44 j_mayer
#define CPU_POWERPC_7400             CPU_POWERPC_7400_v29
6189 80d11f44 j_mayer
    CPU_POWERPC_7400_v10           = 0x000C0100,
6190 80d11f44 j_mayer
    CPU_POWERPC_7400_v11           = 0x000C0101,
6191 80d11f44 j_mayer
    CPU_POWERPC_7400_v20           = 0x000C0200,
6192 80d11f44 j_mayer
    CPU_POWERPC_7400_v22           = 0x000C0202,
6193 80d11f44 j_mayer
    CPU_POWERPC_7400_v26           = 0x000C0206,
6194 80d11f44 j_mayer
    CPU_POWERPC_7400_v27           = 0x000C0207,
6195 80d11f44 j_mayer
    CPU_POWERPC_7400_v28           = 0x000C0208,
6196 80d11f44 j_mayer
    CPU_POWERPC_7400_v29           = 0x000C0209,
6197 80d11f44 j_mayer
#define CPU_POWERPC_7410             CPU_POWERPC_7410_v14
6198 80d11f44 j_mayer
    CPU_POWERPC_7410_v10           = 0x800C1100,
6199 80d11f44 j_mayer
    CPU_POWERPC_7410_v11           = 0x800C1101,
6200 80d11f44 j_mayer
    CPU_POWERPC_7410_v12           = 0x800C1102, /* aka C */
6201 80d11f44 j_mayer
    CPU_POWERPC_7410_v13           = 0x800C1103, /* aka D */
6202 80d11f44 j_mayer
    CPU_POWERPC_7410_v14           = 0x800C1104, /* aka E */
6203 80d11f44 j_mayer
#define CPU_POWERPC_7448             CPU_POWERPC_7448_v21
6204 80d11f44 j_mayer
    CPU_POWERPC_7448_v10           = 0x80040100,
6205 80d11f44 j_mayer
    CPU_POWERPC_7448_v11           = 0x80040101,
6206 80d11f44 j_mayer
    CPU_POWERPC_7448_v20           = 0x80040200,
6207 80d11f44 j_mayer
    CPU_POWERPC_7448_v21           = 0x80040201,
6208 80d11f44 j_mayer
#define CPU_POWERPC_7450             CPU_POWERPC_7450_v21
6209 80d11f44 j_mayer
    CPU_POWERPC_7450_v10           = 0x80000100,
6210 80d11f44 j_mayer
    CPU_POWERPC_7450_v11           = 0x80000101,
6211 80d11f44 j_mayer
    CPU_POWERPC_7450_v12           = 0x80000102,
6212 80d11f44 j_mayer
    CPU_POWERPC_7450_v20           = 0x80000200, /* aka D: 2.04 */
6213 80d11f44 j_mayer
    CPU_POWERPC_7450_v21           = 0x80000201, /* aka E */
6214 80d11f44 j_mayer
    CPU_POWERPC_74x1               = 0x80000203,
6215 80d11f44 j_mayer
    CPU_POWERPC_74x1G              = 0x80000210, /* aka G: 2.3 */
6216 80d11f44 j_mayer
#define CPU_POWERPC_74x5             CPU_POWERPC_74x5_v32
6217 80d11f44 j_mayer
    CPU_POWERPC_74x5_v10           = 0x80010100,
6218 c3e36823 j_mayer
    /* XXX: missing 0x80010200 */
6219 80d11f44 j_mayer
    CPU_POWERPC_74x5_v21           = 0x80010201, /* aka C: 2.1 */
6220 80d11f44 j_mayer
    CPU_POWERPC_74x5_v32           = 0x80010302,
6221 80d11f44 j_mayer
    CPU_POWERPC_74x5_v33           = 0x80010303, /* aka F: 3.3 */
6222 80d11f44 j_mayer
    CPU_POWERPC_74x5_v34           = 0x80010304, /* aka G: 3.4 */
6223 80d11f44 j_mayer
#define CPU_POWERPC_74x7             CPU_POWERPC_74x7_v12
6224 80d11f44 j_mayer
    CPU_POWERPC_74x7_v10           = 0x80020100, /* aka A: 1.0 */
6225 082c6681 j_mayer
    CPU_POWERPC_74x7_v11           = 0x80020101, /* aka B: 1.1 */
6226 80d11f44 j_mayer
    CPU_POWERPC_74x7_v12           = 0x80020102, /* aka C: 1.2 */
6227 082c6681 j_mayer
#define CPU_POWERPC_74x7A            CPU_POWERPC_74x7A_v12
6228 082c6681 j_mayer
    CPU_POWERPC_74x7A_v10          = 0x80030100, /* aka A: 1.0 */
6229 082c6681 j_mayer
    CPU_POWERPC_74x7A_v11          = 0x80030101, /* aka B: 1.1 */
6230 082c6681 j_mayer
    CPU_POWERPC_74x7A_v12          = 0x80030102, /* aka C: 1.2 */
6231 a750fc0b j_mayer
    /* 64 bits PowerPC */
6232 00af685f j_mayer
#if defined(TARGET_PPC64)
6233 80d11f44 j_mayer
    CPU_POWERPC_620                = 0x00140000,
6234 80d11f44 j_mayer
    CPU_POWERPC_630                = 0x00400000,
6235 80d11f44 j_mayer
    CPU_POWERPC_631                = 0x00410104,
6236 80d11f44 j_mayer
    CPU_POWERPC_POWER4             = 0x00350000,
6237 80d11f44 j_mayer
    CPU_POWERPC_POWER4P            = 0x00380000,
6238 c3e36823 j_mayer
     /* XXX: missing 0x003A0201 */
6239 80d11f44 j_mayer
    CPU_POWERPC_POWER5             = 0x003A0203,
6240 80d11f44 j_mayer
#define CPU_POWERPC_POWER5GR         CPU_POWERPC_POWER5
6241 80d11f44 j_mayer
    CPU_POWERPC_POWER5P            = 0x003B0000,
6242 80d11f44 j_mayer
#define CPU_POWERPC_POWER5GS         CPU_POWERPC_POWER5P
6243 80d11f44 j_mayer
    CPU_POWERPC_POWER6             = 0x003E0000,
6244 80d11f44 j_mayer
    CPU_POWERPC_POWER6_5           = 0x0F000001, /* POWER6 in POWER5 mode */
6245 80d11f44 j_mayer
    CPU_POWERPC_POWER6A            = 0x0F000002,
6246 80d11f44 j_mayer
    CPU_POWERPC_970                = 0x00390202,
6247 80d11f44 j_mayer
#define CPU_POWERPC_970FX            CPU_POWERPC_970FX_v31
6248 80d11f44 j_mayer
    CPU_POWERPC_970FX_v10          = 0x00391100,
6249 80d11f44 j_mayer
    CPU_POWERPC_970FX_v20          = 0x003C0200,
6250 80d11f44 j_mayer
    CPU_POWERPC_970FX_v21          = 0x003C0201,
6251 80d11f44 j_mayer
    CPU_POWERPC_970FX_v30          = 0x003C0300,
6252 80d11f44 j_mayer
    CPU_POWERPC_970FX_v31          = 0x003C0301,
6253 80d11f44 j_mayer
    CPU_POWERPC_970GX              = 0x00450000,
6254 80d11f44 j_mayer
#define CPU_POWERPC_970MP            CPU_POWERPC_970MP_v11
6255 80d11f44 j_mayer
    CPU_POWERPC_970MP_v10          = 0x00440100,
6256 80d11f44 j_mayer
    CPU_POWERPC_970MP_v11          = 0x00440101,
6257 80d11f44 j_mayer
#define CPU_POWERPC_CELL             CPU_POWERPC_CELL_v32
6258 80d11f44 j_mayer
    CPU_POWERPC_CELL_v10           = 0x00700100,
6259 80d11f44 j_mayer
    CPU_POWERPC_CELL_v20           = 0x00700400,
6260 80d11f44 j_mayer
    CPU_POWERPC_CELL_v30           = 0x00700500,
6261 80d11f44 j_mayer
    CPU_POWERPC_CELL_v31           = 0x00700501,
6262 80d11f44 j_mayer
#define CPU_POWERPC_CELL_v32         CPU_POWERPC_CELL_v31
6263 80d11f44 j_mayer
    CPU_POWERPC_RS64               = 0x00330000,
6264 80d11f44 j_mayer
    CPU_POWERPC_RS64II             = 0x00340000,
6265 80d11f44 j_mayer
    CPU_POWERPC_RS64III            = 0x00360000,
6266 80d11f44 j_mayer
    CPU_POWERPC_RS64IV             = 0x00370000,
6267 00af685f j_mayer
#endif /* defined(TARGET_PPC64) */
6268 a750fc0b j_mayer
    /* Original POWER */
6269 a750fc0b j_mayer
    /* XXX: should be POWER (RIOS), RSC3308, RSC4608,
6270 a750fc0b j_mayer
     * POWER2 (RIOS2) & RSC2 (P2SC) here
6271 a750fc0b j_mayer
     */
6272 a750fc0b j_mayer
#if 0
6273 80d11f44 j_mayer
    CPU_POWER                      = xxx, /* 0x20000 ? 0x30000 for RSC ? */
6274 a750fc0b j_mayer
#endif
6275 a750fc0b j_mayer
#if 0
6276 80d11f44 j_mayer
    CPU_POWER2                     = xxx, /* 0x40000 ? */
6277 a750fc0b j_mayer
#endif
6278 a750fc0b j_mayer
    /* PA Semi core */
6279 80d11f44 j_mayer
    CPU_POWERPC_PA6T               = 0x00900000,
6280 a750fc0b j_mayer
};
6281 a750fc0b j_mayer
6282 a750fc0b j_mayer
/* System version register (used on MPC 8xxx)                                */
6283 a750fc0b j_mayer
enum {
6284 80d11f44 j_mayer
    POWERPC_SVR_NONE               = 0x00000000,
6285 80d11f44 j_mayer
#define POWERPC_SVR_52xx             POWERPC_SVR_5200
6286 80d11f44 j_mayer
#define POWERPC_SVR_5200             POWERPC_SVR_5200_v12
6287 80d11f44 j_mayer
    POWERPC_SVR_5200_v10           = 0x80110010,
6288 80d11f44 j_mayer
    POWERPC_SVR_5200_v11           = 0x80110011,
6289 80d11f44 j_mayer
    POWERPC_SVR_5200_v12           = 0x80110012,
6290 80d11f44 j_mayer
#define POWERPC_SVR_5200B            POWERPC_SVR_5200B_v21
6291 80d11f44 j_mayer
    POWERPC_SVR_5200B_v20          = 0x80110020,
6292 80d11f44 j_mayer
    POWERPC_SVR_5200B_v21          = 0x80110021,
6293 80d11f44 j_mayer
#define POWERPC_SVR_55xx             POWERPC_SVR_5567
6294 c3e36823 j_mayer
#if 0
6295 80d11f44 j_mayer
    POWERPC_SVR_5533               = xxx,
6296 c3e36823 j_mayer
#endif
6297 c3e36823 j_mayer
#if 0
6298 80d11f44 j_mayer
    POWERPC_SVR_5534               = xxx,
6299 c3e36823 j_mayer
#endif
6300 c3e36823 j_mayer
#if 0
6301 80d11f44 j_mayer
    POWERPC_SVR_5553               = xxx,
6302 c3e36823 j_mayer
#endif
6303 c3e36823 j_mayer
#if 0
6304 80d11f44 j_mayer
    POWERPC_SVR_5554               = xxx,
6305 c3e36823 j_mayer
#endif
6306 c3e36823 j_mayer
#if 0
6307 80d11f44 j_mayer
    POWERPC_SVR_5561               = xxx,
6308 c3e36823 j_mayer
#endif
6309 c3e36823 j_mayer
#if 0
6310 80d11f44 j_mayer
    POWERPC_SVR_5565               = xxx,
6311 c3e36823 j_mayer
#endif
6312 c3e36823 j_mayer
#if 0
6313 80d11f44 j_mayer
    POWERPC_SVR_5566               = xxx,
6314 c3e36823 j_mayer
#endif
6315 c3e36823 j_mayer
#if 0
6316 80d11f44 j_mayer
    POWERPC_SVR_5567               = xxx,
6317 c3e36823 j_mayer
#endif
6318 c3e36823 j_mayer
#if 0
6319 80d11f44 j_mayer
    POWERPC_SVR_8313               = xxx,
6320 c3e36823 j_mayer
#endif
6321 c3e36823 j_mayer
#if 0
6322 80d11f44 j_mayer
    POWERPC_SVR_8313E              = xxx,
6323 c3e36823 j_mayer
#endif
6324 c3e36823 j_mayer
#if 0
6325 80d11f44 j_mayer
    POWERPC_SVR_8314               = xxx,
6326 c3e36823 j_mayer
#endif
6327 c3e36823 j_mayer
#if 0
6328 80d11f44 j_mayer
    POWERPC_SVR_8314E              = xxx,
6329 c3e36823 j_mayer
#endif
6330 c3e36823 j_mayer
#if 0
6331 80d11f44 j_mayer
    POWERPC_SVR_8315               = xxx,
6332 c3e36823 j_mayer
#endif
6333 c3e36823 j_mayer
#if 0
6334 80d11f44 j_mayer
    POWERPC_SVR_8315E              = xxx,
6335 c3e36823 j_mayer
#endif
6336 c3e36823 j_mayer
#if 0
6337 80d11f44 j_mayer
    POWERPC_SVR_8321               = xxx,
6338 c3e36823 j_mayer
#endif
6339 c3e36823 j_mayer
#if 0
6340 80d11f44 j_mayer
    POWERPC_SVR_8321E              = xxx,
6341 c3e36823 j_mayer
#endif
6342 c3e36823 j_mayer
#if 0
6343 80d11f44 j_mayer
    POWERPC_SVR_8323               = xxx,
6344 c3e36823 j_mayer
#endif
6345 c3e36823 j_mayer
#if 0
6346 80d11f44 j_mayer
    POWERPC_SVR_8323E              = xxx,
6347 80d11f44 j_mayer
#endif
6348 80d11f44 j_mayer
    POWERPC_SVR_8343A              = 0x80570030,
6349 80d11f44 j_mayer
    POWERPC_SVR_8343EA             = 0x80560030,
6350 80d11f44 j_mayer
#define POWERPC_SVR_8347A            POWERPC_SVR_8347AT
6351 80d11f44 j_mayer
    POWERPC_SVR_8347AP             = 0x80550030, /* PBGA package */
6352 80d11f44 j_mayer
    POWERPC_SVR_8347AT             = 0x80530030, /* TBGA package */
6353 80d11f44 j_mayer
#define POWERPC_SVR_8347EA            POWERPC_SVR_8347EAT
6354 80d11f44 j_mayer
    POWERPC_SVR_8347EAP            = 0x80540030, /* PBGA package */
6355 80d11f44 j_mayer
    POWERPC_SVR_8347EAT            = 0x80520030, /* TBGA package */
6356 80d11f44 j_mayer
    POWERPC_SVR_8349               = 0x80510010,
6357 80d11f44 j_mayer
    POWERPC_SVR_8349A              = 0x80510030,
6358 80d11f44 j_mayer
    POWERPC_SVR_8349E              = 0x80500010,
6359 80d11f44 j_mayer
    POWERPC_SVR_8349EA             = 0x80500030,
6360 c3e36823 j_mayer
#if 0
6361 80d11f44 j_mayer
    POWERPC_SVR_8358E              = xxx,
6362 c3e36823 j_mayer
#endif
6363 c3e36823 j_mayer
#if 0
6364 80d11f44 j_mayer
    POWERPC_SVR_8360E              = xxx,
6365 80d11f44 j_mayer
#endif
6366 80d11f44 j_mayer
#define POWERPC_SVR_E500             0x40000000
6367 80d11f44 j_mayer
    POWERPC_SVR_8377               = 0x80C70010 | POWERPC_SVR_E500,
6368 80d11f44 j_mayer
    POWERPC_SVR_8377E              = 0x80C60010 | POWERPC_SVR_E500,
6369 80d11f44 j_mayer
    POWERPC_SVR_8378               = 0x80C50010 | POWERPC_SVR_E500,
6370 80d11f44 j_mayer
    POWERPC_SVR_8378E              = 0x80C40010 | POWERPC_SVR_E500,
6371 80d11f44 j_mayer
    POWERPC_SVR_8379               = 0x80C30010 | POWERPC_SVR_E500,
6372 80d11f44 j_mayer
    POWERPC_SVR_8379E              = 0x80C00010 | POWERPC_SVR_E500,
6373 80d11f44 j_mayer
#define POWERPC_SVR_8533             POWERPC_SVR_8533_v11
6374 80d11f44 j_mayer
    POWERPC_SVR_8533_v10           = 0x80340010 | POWERPC_SVR_E500,
6375 80d11f44 j_mayer
    POWERPC_SVR_8533_v11           = 0x80340011 | POWERPC_SVR_E500,
6376 80d11f44 j_mayer
#define POWERPC_SVR_8533E            POWERPC_SVR_8533E_v11
6377 80d11f44 j_mayer
    POWERPC_SVR_8533E_v10          = 0x803C0010 | POWERPC_SVR_E500,
6378 80d11f44 j_mayer
    POWERPC_SVR_8533E_v11          = 0x803C0011 | POWERPC_SVR_E500,
6379 80d11f44 j_mayer
#define POWERPC_SVR_8540             POWERPC_SVR_8540_v21
6380 80d11f44 j_mayer
    POWERPC_SVR_8540_v10           = 0x80300010 | POWERPC_SVR_E500,
6381 80d11f44 j_mayer
    POWERPC_SVR_8540_v20           = 0x80300020 | POWERPC_SVR_E500,
6382 80d11f44 j_mayer
    POWERPC_SVR_8540_v21           = 0x80300021 | POWERPC_SVR_E500,
6383 80d11f44 j_mayer
#define POWERPC_SVR_8541             POWERPC_SVR_8541_v11
6384 80d11f44 j_mayer
    POWERPC_SVR_8541_v10           = 0x80720010 | POWERPC_SVR_E500,
6385 80d11f44 j_mayer
    POWERPC_SVR_8541_v11           = 0x80720011 | POWERPC_SVR_E500,
6386 80d11f44 j_mayer
#define POWERPC_SVR_8541E            POWERPC_SVR_8541E_v11
6387 80d11f44 j_mayer
    POWERPC_SVR_8541E_v10          = 0x807A0010 | POWERPC_SVR_E500,
6388 80d11f44 j_mayer
    POWERPC_SVR_8541E_v11          = 0x807A0011 | POWERPC_SVR_E500,
6389 80d11f44 j_mayer
#define POWERPC_SVR_8543             POWERPC_SVR_8543_v21
6390 80d11f44 j_mayer
    POWERPC_SVR_8543_v10           = 0x80320010 | POWERPC_SVR_E500,
6391 80d11f44 j_mayer
    POWERPC_SVR_8543_v11           = 0x80320011 | POWERPC_SVR_E500,
6392 80d11f44 j_mayer
    POWERPC_SVR_8543_v20           = 0x80320020 | POWERPC_SVR_E500,
6393 80d11f44 j_mayer
    POWERPC_SVR_8543_v21           = 0x80320021 | POWERPC_SVR_E500,
6394 80d11f44 j_mayer
#define POWERPC_SVR_8543E            POWERPC_SVR_8543E_v21
6395 80d11f44 j_mayer
    POWERPC_SVR_8543E_v10          = 0x803A0010 | POWERPC_SVR_E500,
6396 80d11f44 j_mayer
    POWERPC_SVR_8543E_v11          = 0x803A0011 | POWERPC_SVR_E500,
6397 80d11f44 j_mayer
    POWERPC_SVR_8543E_v20          = 0x803A0020 | POWERPC_SVR_E500,
6398 80d11f44 j_mayer
    POWERPC_SVR_8543E_v21          = 0x803A0021 | POWERPC_SVR_E500,
6399 80d11f44 j_mayer
#define POWERPC_SVR_8544             POWERPC_SVR_8544_v11
6400 80d11f44 j_mayer
    POWERPC_SVR_8544_v10           = 0x80340110 | POWERPC_SVR_E500,
6401 80d11f44 j_mayer
    POWERPC_SVR_8544_v11           = 0x80340111 | POWERPC_SVR_E500,
6402 80d11f44 j_mayer
#define POWERPC_SVR_8544E            POWERPC_SVR_8544E_v11
6403 80d11f44 j_mayer
    POWERPC_SVR_8544E_v10          = 0x803C0110 | POWERPC_SVR_E500,
6404 80d11f44 j_mayer
    POWERPC_SVR_8544E_v11          = 0x803C0111 | POWERPC_SVR_E500,
6405 80d11f44 j_mayer
#define POWERPC_SVR_8545             POWERPC_SVR_8545_v21
6406 80d11f44 j_mayer
    POWERPC_SVR_8545_v20           = 0x80310220 | POWERPC_SVR_E500,
6407 80d11f44 j_mayer
    POWERPC_SVR_8545_v21           = 0x80310221 | POWERPC_SVR_E500,
6408 80d11f44 j_mayer
#define POWERPC_SVR_8545E            POWERPC_SVR_8545E_v21
6409 80d11f44 j_mayer
    POWERPC_SVR_8545E_v20          = 0x80390220 | POWERPC_SVR_E500,
6410 80d11f44 j_mayer
    POWERPC_SVR_8545E_v21          = 0x80390221 | POWERPC_SVR_E500,
6411 80d11f44 j_mayer
#define POWERPC_SVR_8547E            POWERPC_SVR_8547E_v21
6412 80d11f44 j_mayer
    POWERPC_SVR_8547E_v20          = 0x80390120 | POWERPC_SVR_E500,
6413 80d11f44 j_mayer
    POWERPC_SVR_8547E_v21          = 0x80390121 | POWERPC_SVR_E500,
6414 80d11f44 j_mayer
#define POWERPC_SVR_8548             POWERPC_SVR_8548_v21
6415 80d11f44 j_mayer
    POWERPC_SVR_8548_v10           = 0x80310010 | POWERPC_SVR_E500,
6416 80d11f44 j_mayer
    POWERPC_SVR_8548_v11           = 0x80310011 | POWERPC_SVR_E500,
6417 80d11f44 j_mayer
    POWERPC_SVR_8548_v20           = 0x80310020 | POWERPC_SVR_E500,
6418 80d11f44 j_mayer
    POWERPC_SVR_8548_v21           = 0x80310021 | POWERPC_SVR_E500,
6419 80d11f44 j_mayer
#define POWERPC_SVR_8548E            POWERPC_SVR_8548E_v21
6420 80d11f44 j_mayer
    POWERPC_SVR_8548E_v10          = 0x80390010 | POWERPC_SVR_E500,
6421 80d11f44 j_mayer
    POWERPC_SVR_8548E_v11          = 0x80390011 | POWERPC_SVR_E500,
6422 80d11f44 j_mayer
    POWERPC_SVR_8548E_v20          = 0x80390020 | POWERPC_SVR_E500,
6423 80d11f44 j_mayer
    POWERPC_SVR_8548E_v21          = 0x80390021 | POWERPC_SVR_E500,
6424 80d11f44 j_mayer
#define POWERPC_SVR_8555             POWERPC_SVR_8555_v11
6425 80d11f44 j_mayer
    POWERPC_SVR_8555_v10           = 0x80710010 | POWERPC_SVR_E500,
6426 80d11f44 j_mayer
    POWERPC_SVR_8555_v11           = 0x80710011 | POWERPC_SVR_E500,
6427 80d11f44 j_mayer
#define POWERPC_SVR_8555E            POWERPC_SVR_8555_v11
6428 80d11f44 j_mayer
    POWERPC_SVR_8555E_v10          = 0x80790010 | POWERPC_SVR_E500,
6429 80d11f44 j_mayer
    POWERPC_SVR_8555E_v11          = 0x80790011 | POWERPC_SVR_E500,
6430 80d11f44 j_mayer
#define POWERPC_SVR_8560             POWERPC_SVR_8560_v21
6431 80d11f44 j_mayer
    POWERPC_SVR_8560_v10           = 0x80700010 | POWERPC_SVR_E500,
6432 80d11f44 j_mayer
    POWERPC_SVR_8560_v20           = 0x80700020 | POWERPC_SVR_E500,
6433 80d11f44 j_mayer
    POWERPC_SVR_8560_v21           = 0x80700021 | POWERPC_SVR_E500,
6434 80d11f44 j_mayer
    POWERPC_SVR_8567               = 0x80750111 | POWERPC_SVR_E500,
6435 80d11f44 j_mayer
    POWERPC_SVR_8567E              = 0x807D0111 | POWERPC_SVR_E500,
6436 80d11f44 j_mayer
    POWERPC_SVR_8568               = 0x80750011 | POWERPC_SVR_E500,
6437 80d11f44 j_mayer
    POWERPC_SVR_8568E              = 0x807D0011 | POWERPC_SVR_E500,
6438 80d11f44 j_mayer
    POWERPC_SVR_8572               = 0x80E00010 | POWERPC_SVR_E500,
6439 80d11f44 j_mayer
    POWERPC_SVR_8572E              = 0x80E80010 | POWERPC_SVR_E500,
6440 c3e36823 j_mayer
#if 0
6441 80d11f44 j_mayer
    POWERPC_SVR_8610               = xxx,
6442 c3e36823 j_mayer
#endif
6443 80d11f44 j_mayer
    POWERPC_SVR_8641               = 0x80900021,
6444 80d11f44 j_mayer
    POWERPC_SVR_8641D              = 0x80900121,
6445 a750fc0b j_mayer
};
6446 a750fc0b j_mayer
6447 3fc6c082 bellard
/*****************************************************************************/
6448 a750fc0b j_mayer
/* PowerPC CPU definitions                                                   */
6449 80d11f44 j_mayer
#define POWERPC_DEF_SVR(_name, _pvr, _svr, _type)                             \
6450 a750fc0b j_mayer
    {                                                                         \
6451 a750fc0b j_mayer
        .name        = _name,                                                 \
6452 a750fc0b j_mayer
        .pvr         = _pvr,                                                  \
6453 80d11f44 j_mayer
        .svr         = _svr,                                                  \
6454 a750fc0b j_mayer
        .insns_flags = glue(POWERPC_INSNS_,_type),                            \
6455 a750fc0b j_mayer
        .msr_mask    = glue(POWERPC_MSRM_,_type),                             \
6456 a750fc0b j_mayer
        .mmu_model   = glue(POWERPC_MMU_,_type),                              \
6457 a750fc0b j_mayer
        .excp_model  = glue(POWERPC_EXCP_,_type),                             \
6458 a750fc0b j_mayer
        .bus_model   = glue(POWERPC_INPUT_,_type),                            \
6459 237c0af0 j_mayer
        .bfd_mach    = glue(POWERPC_BFDM_,_type),                             \
6460 d26bfc9a j_mayer
        .flags       = glue(POWERPC_FLAG_,_type),                             \
6461 a750fc0b j_mayer
        .init_proc   = &glue(init_proc_,_type),                               \
6462 2f462816 j_mayer
        .check_pow   = &glue(check_pow_,_type),                               \
6463 a750fc0b j_mayer
    }
6464 80d11f44 j_mayer
#define POWERPC_DEF(_name, _pvr, _type)                                       \
6465 80d11f44 j_mayer
POWERPC_DEF_SVR(_name, _pvr, POWERPC_SVR_NONE, _type)
6466 a750fc0b j_mayer
6467 ee4e83ed j_mayer
static const ppc_def_t ppc_defs[] = {
6468 a750fc0b j_mayer
    /* Embedded PowerPC                                                      */
6469 a750fc0b j_mayer
    /* PowerPC 401 family                                                    */
6470 2662a059 j_mayer
    /* Generic PowerPC 401 */
6471 80d11f44 j_mayer
    POWERPC_DEF("401",           CPU_POWERPC_401,                    401),
6472 a750fc0b j_mayer
    /* PowerPC 401 cores                                                     */
6473 2662a059 j_mayer
    /* PowerPC 401A1 */
6474 80d11f44 j_mayer
    POWERPC_DEF("401A1",         CPU_POWERPC_401A1,                  401),
6475 a750fc0b j_mayer
    /* PowerPC 401B2                                                         */
6476 80d11f44 j_mayer
    POWERPC_DEF("401B2",         CPU_POWERPC_401B2,                  401x2),
6477 2662a059 j_mayer
#if defined (TODO)
6478 a750fc0b j_mayer
    /* PowerPC 401B3                                                         */
6479 80d11f44 j_mayer
    POWERPC_DEF("401B3",         CPU_POWERPC_401B3,                  401x3),
6480 a750fc0b j_mayer
#endif
6481 a750fc0b j_mayer
    /* PowerPC 401C2                                                         */
6482 80d11f44 j_mayer
    POWERPC_DEF("401C2",         CPU_POWERPC_401C2,                  401x2),
6483 a750fc0b j_mayer
    /* PowerPC 401D2                                                         */
6484 80d11f44 j_mayer
    POWERPC_DEF("401D2",         CPU_POWERPC_401D2,                  401x2),
6485 a750fc0b j_mayer
    /* PowerPC 401E2                                                         */
6486 80d11f44 j_mayer
    POWERPC_DEF("401E2",         CPU_POWERPC_401E2,                  401x2),
6487 a750fc0b j_mayer
    /* PowerPC 401F2                                                         */
6488 80d11f44 j_mayer
    POWERPC_DEF("401F2",         CPU_POWERPC_401F2,                  401x2),
6489 a750fc0b j_mayer
    /* PowerPC 401G2                                                         */
6490 a750fc0b j_mayer
    /* XXX: to be checked */
6491 80d11f44 j_mayer
    POWERPC_DEF("401G2",         CPU_POWERPC_401G2,                  401x2),
6492 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers                                           */
6493 2662a059 j_mayer
#if defined (TODO)
6494 a750fc0b j_mayer
    /* PowerPC 401GF                                                         */
6495 80d11f44 j_mayer
    POWERPC_DEF("401GF",         CPU_POWERPC_401GF,                  401),
6496 3fc6c082 bellard
#endif
6497 a750fc0b j_mayer
    /* IOP480 (401 microcontroler)                                           */
6498 80d11f44 j_mayer
    POWERPC_DEF("IOP480",        CPU_POWERPC_IOP480,                 IOP480),
6499 a750fc0b j_mayer
    /* IBM Processor for Network Resources                                   */
6500 80d11f44 j_mayer
    POWERPC_DEF("Cobra",         CPU_POWERPC_COBRA,                  401),
6501 3fc6c082 bellard
#if defined (TODO)
6502 80d11f44 j_mayer
    POWERPC_DEF("Xipchip",       CPU_POWERPC_XIPCHIP,                401),
6503 3fc6c082 bellard
#endif
6504 a750fc0b j_mayer
    /* PowerPC 403 family                                                    */
6505 a750fc0b j_mayer
    /* Generic PowerPC 403                                                   */
6506 80d11f44 j_mayer
    POWERPC_DEF("403",           CPU_POWERPC_403,                    403),
6507 a750fc0b j_mayer
    /* PowerPC 403 microcontrolers                                           */
6508 a750fc0b j_mayer
    /* PowerPC 403 GA                                                        */
6509 80d11f44 j_mayer
    POWERPC_DEF("403GA",         CPU_POWERPC_403GA,                  403),
6510 a750fc0b j_mayer
    /* PowerPC 403 GB                                                        */
6511 80d11f44 j_mayer
    POWERPC_DEF("403GB",         CPU_POWERPC_403GB,                  403),
6512 a750fc0b j_mayer
    /* PowerPC 403 GC                                                        */
6513 80d11f44 j_mayer
    POWERPC_DEF("403GC",         CPU_POWERPC_403GC,                  403),
6514 a750fc0b j_mayer
    /* PowerPC 403 GCX                                                       */
6515 80d11f44 j_mayer
    POWERPC_DEF("403GCX",        CPU_POWERPC_403GCX,                 403GCX),
6516 3fc6c082 bellard
#if defined (TODO)
6517 a750fc0b j_mayer
    /* PowerPC 403 GP                                                        */
6518 80d11f44 j_mayer
    POWERPC_DEF("403GP",         CPU_POWERPC_403GP,                  403),
6519 3fc6c082 bellard
#endif
6520 a750fc0b j_mayer
    /* PowerPC 405 family                                                    */
6521 a750fc0b j_mayer
    /* Generic PowerPC 405                                                   */
6522 80d11f44 j_mayer
    POWERPC_DEF("405",           CPU_POWERPC_405,                    405),
6523 a750fc0b j_mayer
    /* PowerPC 405 cores                                                     */
6524 2662a059 j_mayer
#if defined (TODO)
6525 a750fc0b j_mayer
    /* PowerPC 405 A3                                                        */
6526 80d11f44 j_mayer
    POWERPC_DEF("405A3",         CPU_POWERPC_405A3,                  405),
6527 3a607854 j_mayer
#endif
6528 3a607854 j_mayer
#if defined (TODO)
6529 a750fc0b j_mayer
    /* PowerPC 405 A4                                                        */
6530 80d11f44 j_mayer
    POWERPC_DEF("405A4",         CPU_POWERPC_405A4,                  405),
6531 3a607854 j_mayer
#endif
6532 3a607854 j_mayer
#if defined (TODO)
6533 a750fc0b j_mayer
    /* PowerPC 405 B3                                                        */
6534 80d11f44 j_mayer
    POWERPC_DEF("405B3",         CPU_POWERPC_405B3,                  405),
6535 3fc6c082 bellard
#endif
6536 3fc6c082 bellard
#if defined (TODO)
6537 a750fc0b j_mayer
    /* PowerPC 405 B4                                                        */
6538 80d11f44 j_mayer
    POWERPC_DEF("405B4",         CPU_POWERPC_405B4,                  405),
6539 a750fc0b j_mayer
#endif
6540 a750fc0b j_mayer
#if defined (TODO)
6541 a750fc0b j_mayer
    /* PowerPC 405 C3                                                        */
6542 80d11f44 j_mayer
    POWERPC_DEF("405C3",         CPU_POWERPC_405C3,                  405),
6543 a750fc0b j_mayer
#endif
6544 a750fc0b j_mayer
#if defined (TODO)
6545 a750fc0b j_mayer
    /* PowerPC 405 C4                                                        */
6546 80d11f44 j_mayer
    POWERPC_DEF("405C4",         CPU_POWERPC_405C4,                  405),
6547 a750fc0b j_mayer
#endif
6548 a750fc0b j_mayer
    /* PowerPC 405 D2                                                        */
6549 80d11f44 j_mayer
    POWERPC_DEF("405D2",         CPU_POWERPC_405D2,                  405),
6550 a750fc0b j_mayer
#if defined (TODO)
6551 a750fc0b j_mayer
    /* PowerPC 405 D3                                                        */
6552 80d11f44 j_mayer
    POWERPC_DEF("405D3",         CPU_POWERPC_405D3,                  405),
6553 a750fc0b j_mayer
#endif
6554 a750fc0b j_mayer
    /* PowerPC 405 D4                                                        */
6555 80d11f44 j_mayer
    POWERPC_DEF("405D4",         CPU_POWERPC_405D4,                  405),
6556 a750fc0b j_mayer
#if defined (TODO)
6557 a750fc0b j_mayer
    /* PowerPC 405 D5                                                        */
6558 80d11f44 j_mayer
    POWERPC_DEF("405D5",         CPU_POWERPC_405D5,                  405),
6559 a750fc0b j_mayer
#endif
6560 a750fc0b j_mayer
#if defined (TODO)
6561 a750fc0b j_mayer
    /* PowerPC 405 E4                                                        */
6562 80d11f44 j_mayer
    POWERPC_DEF("405E4",         CPU_POWERPC_405E4,                  405),
6563 a750fc0b j_mayer
#endif
6564 a750fc0b j_mayer
#if defined (TODO)
6565 a750fc0b j_mayer
    /* PowerPC 405 F4                                                        */
6566 80d11f44 j_mayer
    POWERPC_DEF("405F4",         CPU_POWERPC_405F4,                  405),
6567 a750fc0b j_mayer
#endif
6568 a750fc0b j_mayer
#if defined (TODO)
6569 a750fc0b j_mayer
    /* PowerPC 405 F5                                                        */
6570 80d11f44 j_mayer
    POWERPC_DEF("405F5",         CPU_POWERPC_405F5,                  405),
6571 a750fc0b j_mayer
#endif
6572 a750fc0b j_mayer
#if defined (TODO)
6573 a750fc0b j_mayer
    /* PowerPC 405 F6                                                        */
6574 80d11f44 j_mayer
    POWERPC_DEF("405F6",         CPU_POWERPC_405F6,                  405),
6575 a750fc0b j_mayer
#endif
6576 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers                                           */
6577 a750fc0b j_mayer
    /* PowerPC 405 CR                                                        */
6578 80d11f44 j_mayer
    POWERPC_DEF("405CR",         CPU_POWERPC_405CR,                  405),
6579 a750fc0b j_mayer
    /* PowerPC 405 CRa                                                       */
6580 80d11f44 j_mayer
    POWERPC_DEF("405CRa",        CPU_POWERPC_405CRa,                 405),
6581 a750fc0b j_mayer
    /* PowerPC 405 CRb                                                       */
6582 80d11f44 j_mayer
    POWERPC_DEF("405CRb",        CPU_POWERPC_405CRb,                 405),
6583 a750fc0b j_mayer
    /* PowerPC 405 CRc                                                       */
6584 80d11f44 j_mayer
    POWERPC_DEF("405CRc",        CPU_POWERPC_405CRc,                 405),
6585 a750fc0b j_mayer
    /* PowerPC 405 EP                                                        */
6586 80d11f44 j_mayer
    POWERPC_DEF("405EP",         CPU_POWERPC_405EP,                  405),
6587 a750fc0b j_mayer
#if defined(TODO)
6588 a750fc0b j_mayer
    /* PowerPC 405 EXr                                                       */
6589 80d11f44 j_mayer
    POWERPC_DEF("405EXr",        CPU_POWERPC_405EXr,                 405),
6590 a750fc0b j_mayer
#endif
6591 a750fc0b j_mayer
    /* PowerPC 405 EZ                                                        */
6592 80d11f44 j_mayer
    POWERPC_DEF("405EZ",         CPU_POWERPC_405EZ,                  405),
6593 a750fc0b j_mayer
#if defined(TODO)
6594 a750fc0b j_mayer
    /* PowerPC 405 FX                                                        */
6595 80d11f44 j_mayer
    POWERPC_DEF("405FX",         CPU_POWERPC_405FX,                  405),
6596 a750fc0b j_mayer
#endif
6597 a750fc0b j_mayer
    /* PowerPC 405 GP                                                        */
6598 80d11f44 j_mayer
    POWERPC_DEF("405GP",         CPU_POWERPC_405GP,                  405),
6599 a750fc0b j_mayer
    /* PowerPC 405 GPa                                                       */
6600 80d11f44 j_mayer
    POWERPC_DEF("405GPa",        CPU_POWERPC_405GPa,                 405),
6601 a750fc0b j_mayer
    /* PowerPC 405 GPb                                                       */
6602 80d11f44 j_mayer
    POWERPC_DEF("405GPb",        CPU_POWERPC_405GPb,                 405),
6603 a750fc0b j_mayer
    /* PowerPC 405 GPc                                                       */
6604 80d11f44 j_mayer
    POWERPC_DEF("405GPc",        CPU_POWERPC_405GPc,                 405),
6605 a750fc0b j_mayer
    /* PowerPC 405 GPd                                                       */
6606 80d11f44 j_mayer
    POWERPC_DEF("405GPd",        CPU_POWERPC_405GPd,                 405),
6607 a750fc0b j_mayer
    /* PowerPC 405 GPe                                                       */
6608 80d11f44 j_mayer
    POWERPC_DEF("405GPe",        CPU_POWERPC_405GPe,                 405),
6609 a750fc0b j_mayer
    /* PowerPC 405 GPR                                                       */
6610 80d11f44 j_mayer
    POWERPC_DEF("405GPR",        CPU_POWERPC_405GPR,                 405),
6611 a750fc0b j_mayer
#if defined(TODO)
6612 a750fc0b j_mayer
    /* PowerPC 405 H                                                         */
6613 80d11f44 j_mayer
    POWERPC_DEF("405H",          CPU_POWERPC_405H,                   405),
6614 a750fc0b j_mayer
#endif
6615 a750fc0b j_mayer
#if defined(TODO)
6616 a750fc0b j_mayer
    /* PowerPC 405 L                                                         */
6617 80d11f44 j_mayer
    POWERPC_DEF("405L",          CPU_POWERPC_405L,                   405),
6618 a750fc0b j_mayer
#endif
6619 a750fc0b j_mayer
    /* PowerPC 405 LP                                                        */
6620 80d11f44 j_mayer
    POWERPC_DEF("405LP",         CPU_POWERPC_405LP,                  405),
6621 a750fc0b j_mayer
#if defined(TODO)
6622 a750fc0b j_mayer
    /* PowerPC 405 PM                                                        */
6623 80d11f44 j_mayer
    POWERPC_DEF("405PM",         CPU_POWERPC_405PM,                  405),
6624 a750fc0b j_mayer
#endif
6625 a750fc0b j_mayer
#if defined(TODO)
6626 a750fc0b j_mayer
    /* PowerPC 405 PS                                                        */
6627 80d11f44 j_mayer
    POWERPC_DEF("405PS",         CPU_POWERPC_405PS,                  405),
6628 a750fc0b j_mayer
#endif
6629 a750fc0b j_mayer
#if defined(TODO)
6630 a750fc0b j_mayer
    /* PowerPC 405 S                                                         */
6631 80d11f44 j_mayer
    POWERPC_DEF("405S",          CPU_POWERPC_405S,                   405),
6632 a750fc0b j_mayer
#endif
6633 a750fc0b j_mayer
    /* Npe405 H                                                              */
6634 80d11f44 j_mayer
    POWERPC_DEF("Npe405H",       CPU_POWERPC_NPE405H,                405),
6635 a750fc0b j_mayer
    /* Npe405 H2                                                             */
6636 80d11f44 j_mayer
    POWERPC_DEF("Npe405H2",      CPU_POWERPC_NPE405H2,               405),
6637 a750fc0b j_mayer
    /* Npe405 L                                                              */
6638 80d11f44 j_mayer
    POWERPC_DEF("Npe405L",       CPU_POWERPC_NPE405L,                405),
6639 a750fc0b j_mayer
    /* Npe4GS3                                                               */
6640 80d11f44 j_mayer
    POWERPC_DEF("Npe4GS3",       CPU_POWERPC_NPE4GS3,                405),
6641 a750fc0b j_mayer
#if defined (TODO)
6642 80d11f44 j_mayer
    POWERPC_DEF("Npcxx1",        CPU_POWERPC_NPCxx1,                 405),
6643 a750fc0b j_mayer
#endif
6644 a750fc0b j_mayer
#if defined (TODO)
6645 80d11f44 j_mayer
    POWERPC_DEF("Npr161",        CPU_POWERPC_NPR161,                 405),
6646 a750fc0b j_mayer
#endif
6647 a750fc0b j_mayer
#if defined (TODO)
6648 a750fc0b j_mayer
    /* PowerPC LC77700 (Sanyo)                                               */
6649 80d11f44 j_mayer
    POWERPC_DEF("LC77700",       CPU_POWERPC_LC77700,                405),
6650 a750fc0b j_mayer
#endif
6651 a750fc0b j_mayer
    /* PowerPC 401/403/405 based set-top-box microcontrolers                 */
6652 a750fc0b j_mayer
#if defined (TODO)
6653 a750fc0b j_mayer
    /* STB010000                                                             */
6654 80d11f44 j_mayer
    POWERPC_DEF("STB01000",      CPU_POWERPC_STB01000,               401x2),
6655 a750fc0b j_mayer
#endif
6656 a750fc0b j_mayer
#if defined (TODO)
6657 a750fc0b j_mayer
    /* STB01010                                                              */
6658 80d11f44 j_mayer
    POWERPC_DEF("STB01010",      CPU_POWERPC_STB01010,               401x2),
6659 a750fc0b j_mayer
#endif
6660 a750fc0b j_mayer
#if defined (TODO)
6661 a750fc0b j_mayer
    /* STB0210                                                               */
6662 80d11f44 j_mayer
    POWERPC_DEF("STB0210",       CPU_POWERPC_STB0210,                401x3),
6663 a750fc0b j_mayer
#endif
6664 a750fc0b j_mayer
    /* STB03xx                                                               */
6665 80d11f44 j_mayer
    POWERPC_DEF("STB03",         CPU_POWERPC_STB03,                  405),
6666 a750fc0b j_mayer
#if defined (TODO)
6667 a750fc0b j_mayer
    /* STB043x                                                               */
6668 80d11f44 j_mayer
    POWERPC_DEF("STB043",        CPU_POWERPC_STB043,                 405),
6669 a750fc0b j_mayer
#endif
6670 a750fc0b j_mayer
#if defined (TODO)
6671 a750fc0b j_mayer
    /* STB045x                                                               */
6672 80d11f44 j_mayer
    POWERPC_DEF("STB045",        CPU_POWERPC_STB045,                 405),
6673 a750fc0b j_mayer
#endif
6674 a750fc0b j_mayer
    /* STB04xx                                                               */
6675 80d11f44 j_mayer
    POWERPC_DEF("STB04",         CPU_POWERPC_STB04,                  405),
6676 a750fc0b j_mayer
    /* STB25xx                                                               */
6677 80d11f44 j_mayer
    POWERPC_DEF("STB25",         CPU_POWERPC_STB25,                  405),
6678 a750fc0b j_mayer
#if defined (TODO)
6679 a750fc0b j_mayer
    /* STB130                                                                */
6680 80d11f44 j_mayer
    POWERPC_DEF("STB130",        CPU_POWERPC_STB130,                 405),
6681 a750fc0b j_mayer
#endif
6682 a750fc0b j_mayer
    /* Xilinx PowerPC 405 cores                                              */
6683 80d11f44 j_mayer
    POWERPC_DEF("x2vp4",         CPU_POWERPC_X2VP4,                  405),
6684 80d11f44 j_mayer
    POWERPC_DEF("x2vp7",         CPU_POWERPC_X2VP7,                  405),
6685 80d11f44 j_mayer
    POWERPC_DEF("x2vp20",        CPU_POWERPC_X2VP20,                 405),
6686 80d11f44 j_mayer
    POWERPC_DEF("x2vp50",        CPU_POWERPC_X2VP50,                 405),
6687 a750fc0b j_mayer
#if defined (TODO)
6688 a750fc0b j_mayer
    /* Zarlink ZL10310                                                       */
6689 80d11f44 j_mayer
    POWERPC_DEF("zl10310",       CPU_POWERPC_ZL10310,                405),
6690 a750fc0b j_mayer
#endif
6691 a750fc0b j_mayer
#if defined (TODO)
6692 a750fc0b j_mayer
    /* Zarlink ZL10311                                                       */
6693 80d11f44 j_mayer
    POWERPC_DEF("zl10311",       CPU_POWERPC_ZL10311,                405),
6694 a750fc0b j_mayer
#endif
6695 a750fc0b j_mayer
#if defined (TODO)
6696 a750fc0b j_mayer
    /* Zarlink ZL10320                                                       */
6697 80d11f44 j_mayer
    POWERPC_DEF("zl10320",       CPU_POWERPC_ZL10320,                405),
6698 a750fc0b j_mayer
#endif
6699 a750fc0b j_mayer
#if defined (TODO)
6700 a750fc0b j_mayer
    /* Zarlink ZL10321                                                       */
6701 80d11f44 j_mayer
    POWERPC_DEF("zl10321",       CPU_POWERPC_ZL10321,                405),
6702 a750fc0b j_mayer
#endif
6703 a750fc0b j_mayer
    /* PowerPC 440 family                                                    */
6704 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6705 a750fc0b j_mayer
    /* Generic PowerPC 440                                                   */
6706 80d11f44 j_mayer
    POWERPC_DEF("440",           CPU_POWERPC_440,                    440GP),
6707 80d11f44 j_mayer
#endif
6708 a750fc0b j_mayer
    /* PowerPC 440 cores                                                     */
6709 a750fc0b j_mayer
#if defined (TODO)
6710 a750fc0b j_mayer
    /* PowerPC 440 A4                                                        */
6711 80d11f44 j_mayer
    POWERPC_DEF("440A4",         CPU_POWERPC_440A4,                  440x4),
6712 a750fc0b j_mayer
#endif
6713 a750fc0b j_mayer
#if defined (TODO)
6714 a750fc0b j_mayer
    /* PowerPC 440 A5                                                        */
6715 80d11f44 j_mayer
    POWERPC_DEF("440A5",         CPU_POWERPC_440A5,                  440x5),
6716 a750fc0b j_mayer
#endif
6717 a750fc0b j_mayer
#if defined (TODO)
6718 a750fc0b j_mayer
    /* PowerPC 440 B4                                                        */
6719 80d11f44 j_mayer
    POWERPC_DEF("440B4",         CPU_POWERPC_440B4,                  440x4),
6720 a750fc0b j_mayer
#endif
6721 a750fc0b j_mayer
#if defined (TODO)
6722 a750fc0b j_mayer
    /* PowerPC 440 G4                                                        */
6723 80d11f44 j_mayer
    POWERPC_DEF("440G4",         CPU_POWERPC_440G4,                  440x4),
6724 a750fc0b j_mayer
#endif
6725 a750fc0b j_mayer
#if defined (TODO)
6726 a750fc0b j_mayer
    /* PowerPC 440 F5                                                        */
6727 80d11f44 j_mayer
    POWERPC_DEF("440F5",         CPU_POWERPC_440F5,                  440x5),
6728 a750fc0b j_mayer
#endif
6729 a750fc0b j_mayer
#if defined (TODO)
6730 a750fc0b j_mayer
    /* PowerPC 440 G5                                                        */
6731 80d11f44 j_mayer
    POWERPC_DEF("440G5",         CPU_POWERPC_440G5,                  440x5),
6732 a750fc0b j_mayer
#endif
6733 a750fc0b j_mayer
#if defined (TODO)
6734 a750fc0b j_mayer
    /* PowerPC 440H4                                                         */
6735 80d11f44 j_mayer
    POWERPC_DEF("440H4",         CPU_POWERPC_440H4,                  440x4),
6736 a750fc0b j_mayer
#endif
6737 a750fc0b j_mayer
#if defined (TODO)
6738 a750fc0b j_mayer
    /* PowerPC 440H6                                                         */
6739 80d11f44 j_mayer
    POWERPC_DEF("440H6",         CPU_POWERPC_440H6,                  440Gx5),
6740 a750fc0b j_mayer
#endif
6741 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers                                           */
6742 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6743 a750fc0b j_mayer
    /* PowerPC 440 EP                                                        */
6744 80d11f44 j_mayer
    POWERPC_DEF("440EP",         CPU_POWERPC_440EP,                  440EP),
6745 80d11f44 j_mayer
#endif
6746 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6747 a750fc0b j_mayer
    /* PowerPC 440 EPa                                                       */
6748 80d11f44 j_mayer
    POWERPC_DEF("440EPa",        CPU_POWERPC_440EPa,                 440EP),
6749 80d11f44 j_mayer
#endif
6750 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6751 a750fc0b j_mayer
    /* PowerPC 440 EPb                                                       */
6752 80d11f44 j_mayer
    POWERPC_DEF("440EPb",        CPU_POWERPC_440EPb,                 440EP),
6753 80d11f44 j_mayer
#endif
6754 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6755 a750fc0b j_mayer
    /* PowerPC 440 EPX                                                       */
6756 80d11f44 j_mayer
    POWERPC_DEF("440EPX",        CPU_POWERPC_440EPX,                 440EP),
6757 80d11f44 j_mayer
#endif
6758 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6759 a750fc0b j_mayer
    /* PowerPC 440 GP                                                        */
6760 80d11f44 j_mayer
    POWERPC_DEF("440GP",         CPU_POWERPC_440GP,                  440GP),
6761 80d11f44 j_mayer
#endif
6762 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6763 a750fc0b j_mayer
    /* PowerPC 440 GPb                                                       */
6764 80d11f44 j_mayer
    POWERPC_DEF("440GPb",        CPU_POWERPC_440GPb,                 440GP),
6765 80d11f44 j_mayer
#endif
6766 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6767 a750fc0b j_mayer
    /* PowerPC 440 GPc                                                       */
6768 80d11f44 j_mayer
    POWERPC_DEF("440GPc",        CPU_POWERPC_440GPc,                 440GP),
6769 80d11f44 j_mayer
#endif
6770 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6771 a750fc0b j_mayer
    /* PowerPC 440 GR                                                        */
6772 80d11f44 j_mayer
    POWERPC_DEF("440GR",         CPU_POWERPC_440GR,                  440x5),
6773 80d11f44 j_mayer
#endif
6774 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6775 a750fc0b j_mayer
    /* PowerPC 440 GRa                                                       */
6776 80d11f44 j_mayer
    POWERPC_DEF("440GRa",        CPU_POWERPC_440GRa,                 440x5),
6777 80d11f44 j_mayer
#endif
6778 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6779 a750fc0b j_mayer
    /* PowerPC 440 GRX                                                       */
6780 80d11f44 j_mayer
    POWERPC_DEF("440GRX",        CPU_POWERPC_440GRX,                 440x5),
6781 80d11f44 j_mayer
#endif
6782 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6783 a750fc0b j_mayer
    /* PowerPC 440 GX                                                        */
6784 80d11f44 j_mayer
    POWERPC_DEF("440GX",         CPU_POWERPC_440GX,                  440EP),
6785 80d11f44 j_mayer
#endif
6786 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6787 a750fc0b j_mayer
    /* PowerPC 440 GXa                                                       */
6788 80d11f44 j_mayer
    POWERPC_DEF("440GXa",        CPU_POWERPC_440GXa,                 440EP),
6789 80d11f44 j_mayer
#endif
6790 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6791 a750fc0b j_mayer
    /* PowerPC 440 GXb                                                       */
6792 80d11f44 j_mayer
    POWERPC_DEF("440GXb",        CPU_POWERPC_440GXb,                 440EP),
6793 80d11f44 j_mayer
#endif
6794 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6795 a750fc0b j_mayer
    /* PowerPC 440 GXc                                                       */
6796 80d11f44 j_mayer
    POWERPC_DEF("440GXc",        CPU_POWERPC_440GXc,                 440EP),
6797 80d11f44 j_mayer
#endif
6798 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6799 a750fc0b j_mayer
    /* PowerPC 440 GXf                                                       */
6800 80d11f44 j_mayer
    POWERPC_DEF("440GXf",        CPU_POWERPC_440GXf,                 440EP),
6801 80d11f44 j_mayer
#endif
6802 a750fc0b j_mayer
#if defined(TODO)
6803 a750fc0b j_mayer
    /* PowerPC 440 S                                                         */
6804 80d11f44 j_mayer
    POWERPC_DEF("440S",          CPU_POWERPC_440S,                   440),
6805 a750fc0b j_mayer
#endif
6806 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6807 a750fc0b j_mayer
    /* PowerPC 440 SP                                                        */
6808 80d11f44 j_mayer
    POWERPC_DEF("440SP",         CPU_POWERPC_440SP,                  440EP),
6809 80d11f44 j_mayer
#endif
6810 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6811 a750fc0b j_mayer
    /* PowerPC 440 SP2                                                       */
6812 80d11f44 j_mayer
    POWERPC_DEF("440SP2",        CPU_POWERPC_440SP2,                 440EP),
6813 80d11f44 j_mayer
#endif
6814 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6815 a750fc0b j_mayer
    /* PowerPC 440 SPE                                                       */
6816 80d11f44 j_mayer
    POWERPC_DEF("440SPE",        CPU_POWERPC_440SPE,                 440EP),
6817 80d11f44 j_mayer
#endif
6818 a750fc0b j_mayer
    /* PowerPC 460 family                                                    */
6819 a750fc0b j_mayer
#if defined (TODO)
6820 a750fc0b j_mayer
    /* Generic PowerPC 464                                                   */
6821 80d11f44 j_mayer
    POWERPC_DEF("464",           CPU_POWERPC_464,                    460),
6822 a750fc0b j_mayer
#endif
6823 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers                                           */
6824 a750fc0b j_mayer
#if defined (TODO)
6825 a750fc0b j_mayer
    /* PowerPC 464H90                                                        */
6826 80d11f44 j_mayer
    POWERPC_DEF("464H90",        CPU_POWERPC_464H90,                 460),
6827 a750fc0b j_mayer
#endif
6828 a750fc0b j_mayer
#if defined (TODO)
6829 a750fc0b j_mayer
    /* PowerPC 464H90F                                                       */
6830 80d11f44 j_mayer
    POWERPC_DEF("464H90F",       CPU_POWERPC_464H90F,                460F),
6831 a750fc0b j_mayer
#endif
6832 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores                                      */
6833 80d11f44 j_mayer
    /* MPC5xx family (aka RCPU)                                              */
6834 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6835 80d11f44 j_mayer
    /* Generic MPC5xx core                                                   */
6836 80d11f44 j_mayer
    POWERPC_DEF("MPC5xx",        CPU_POWERPC_MPC5xx,                 MPC5xx),
6837 80d11f44 j_mayer
#endif
6838 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6839 80d11f44 j_mayer
    /* Codename for MPC5xx core                                              */
6840 80d11f44 j_mayer
    POWERPC_DEF("RCPU",          CPU_POWERPC_MPC5xx,                 MPC5xx),
6841 80d11f44 j_mayer
#endif
6842 80d11f44 j_mayer
    /* MPC5xx microcontrollers                                               */
6843 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6844 80d11f44 j_mayer
    /* MGT560                                                                */
6845 80d11f44 j_mayer
    POWERPC_DEF("MGT560",        CPU_POWERPC_MGT560,                 MPC5xx),
6846 80d11f44 j_mayer
#endif
6847 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6848 80d11f44 j_mayer
    /* MPC509                                                                */
6849 80d11f44 j_mayer
    POWERPC_DEF("MPC509",        CPU_POWERPC_MPC509,                 MPC5xx),
6850 80d11f44 j_mayer
#endif
6851 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6852 80d11f44 j_mayer
    /* MPC533                                                                */
6853 80d11f44 j_mayer
    POWERPC_DEF("MPC533",        CPU_POWERPC_MPC533,                 MPC5xx),
6854 80d11f44 j_mayer
#endif
6855 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6856 80d11f44 j_mayer
    /* MPC534                                                                */
6857 80d11f44 j_mayer
    POWERPC_DEF("MPC534",        CPU_POWERPC_MPC534,                 MPC5xx),
6858 80d11f44 j_mayer
#endif
6859 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6860 80d11f44 j_mayer
    /* MPC555                                                                */
6861 80d11f44 j_mayer
    POWERPC_DEF("MPC555",        CPU_POWERPC_MPC555,                 MPC5xx),
6862 80d11f44 j_mayer
#endif
6863 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6864 80d11f44 j_mayer
    /* MPC556                                                                */
6865 80d11f44 j_mayer
    POWERPC_DEF("MPC556",        CPU_POWERPC_MPC556,                 MPC5xx),
6866 80d11f44 j_mayer
#endif
6867 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6868 80d11f44 j_mayer
    /* MPC560                                                                */
6869 80d11f44 j_mayer
    POWERPC_DEF("MPC560",        CPU_POWERPC_MPC560,                 MPC5xx),
6870 80d11f44 j_mayer
#endif
6871 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6872 80d11f44 j_mayer
    /* MPC561                                                                */
6873 80d11f44 j_mayer
    POWERPC_DEF("MPC561",        CPU_POWERPC_MPC561,                 MPC5xx),
6874 80d11f44 j_mayer
#endif
6875 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6876 80d11f44 j_mayer
    /* MPC562                                                                */
6877 80d11f44 j_mayer
    POWERPC_DEF("MPC562",        CPU_POWERPC_MPC562,                 MPC5xx),
6878 80d11f44 j_mayer
#endif
6879 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6880 80d11f44 j_mayer
    /* MPC563                                                                */
6881 80d11f44 j_mayer
    POWERPC_DEF("MPC563",        CPU_POWERPC_MPC563,                 MPC5xx),
6882 80d11f44 j_mayer
#endif
6883 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6884 80d11f44 j_mayer
    /* MPC564                                                                */
6885 80d11f44 j_mayer
    POWERPC_DEF("MPC564",        CPU_POWERPC_MPC564,                 MPC5xx),
6886 80d11f44 j_mayer
#endif
6887 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6888 80d11f44 j_mayer
    /* MPC565                                                                */
6889 80d11f44 j_mayer
    POWERPC_DEF("MPC565",        CPU_POWERPC_MPC565,                 MPC5xx),
6890 80d11f44 j_mayer
#endif
6891 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6892 80d11f44 j_mayer
    /* MPC566                                                                */
6893 80d11f44 j_mayer
    POWERPC_DEF("MPC566",        CPU_POWERPC_MPC566,                 MPC5xx),
6894 80d11f44 j_mayer
#endif
6895 80d11f44 j_mayer
    /* MPC8xx family (aka PowerQUICC)                                        */
6896 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6897 80d11f44 j_mayer
    /* Generic MPC8xx core                                                   */
6898 80d11f44 j_mayer
    POWERPC_DEF("MPC8xx",        CPU_POWERPC_MPC8xx,                 MPC8xx),
6899 80d11f44 j_mayer
#endif
6900 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6901 80d11f44 j_mayer
    /* Codename for MPC8xx core                                              */
6902 80d11f44 j_mayer
    POWERPC_DEF("PowerQUICC",    CPU_POWERPC_MPC8xx,                 MPC8xx),
6903 80d11f44 j_mayer
#endif
6904 80d11f44 j_mayer
    /* MPC8xx microcontrollers                                               */
6905 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6906 80d11f44 j_mayer
    /* MGT823                                                                */
6907 80d11f44 j_mayer
    POWERPC_DEF("MGT823",        CPU_POWERPC_MGT823,                 MPC8xx),
6908 80d11f44 j_mayer
#endif
6909 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6910 80d11f44 j_mayer
    /* MPC821                                                                */
6911 80d11f44 j_mayer
    POWERPC_DEF("MPC821",        CPU_POWERPC_MPC821,                 MPC8xx),
6912 80d11f44 j_mayer
#endif
6913 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6914 80d11f44 j_mayer
    /* MPC823                                                                */
6915 80d11f44 j_mayer
    POWERPC_DEF("MPC823",        CPU_POWERPC_MPC823,                 MPC8xx),
6916 80d11f44 j_mayer
#endif
6917 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6918 80d11f44 j_mayer
    /* MPC850                                                                */
6919 80d11f44 j_mayer
    POWERPC_DEF("MPC850",        CPU_POWERPC_MPC850,                 MPC8xx),
6920 80d11f44 j_mayer
#endif
6921 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6922 80d11f44 j_mayer
    /* MPC852T                                                               */
6923 80d11f44 j_mayer
    POWERPC_DEF("MPC852T",       CPU_POWERPC_MPC852T,                MPC8xx),
6924 80d11f44 j_mayer
#endif
6925 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6926 80d11f44 j_mayer
    /* MPC855T                                                               */
6927 80d11f44 j_mayer
    POWERPC_DEF("MPC855T",       CPU_POWERPC_MPC855T,                MPC8xx),
6928 80d11f44 j_mayer
#endif
6929 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6930 80d11f44 j_mayer
    /* MPC857                                                                */
6931 80d11f44 j_mayer
    POWERPC_DEF("MPC857",        CPU_POWERPC_MPC857,                 MPC8xx),
6932 80d11f44 j_mayer
#endif
6933 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6934 80d11f44 j_mayer
    /* MPC859                                                                */
6935 80d11f44 j_mayer
    POWERPC_DEF("MPC859",        CPU_POWERPC_MPC859,                 MPC8xx),
6936 80d11f44 j_mayer
#endif
6937 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6938 80d11f44 j_mayer
    /* MPC860                                                                */
6939 80d11f44 j_mayer
    POWERPC_DEF("MPC860",        CPU_POWERPC_MPC860,                 MPC8xx),
6940 80d11f44 j_mayer
#endif
6941 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6942 80d11f44 j_mayer
    /* MPC862                                                                */
6943 80d11f44 j_mayer
    POWERPC_DEF("MPC862",        CPU_POWERPC_MPC862,                 MPC8xx),
6944 80d11f44 j_mayer
#endif
6945 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6946 80d11f44 j_mayer
    /* MPC866                                                                */
6947 80d11f44 j_mayer
    POWERPC_DEF("MPC866",        CPU_POWERPC_MPC866,                 MPC8xx),
6948 80d11f44 j_mayer
#endif
6949 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6950 80d11f44 j_mayer
    /* MPC870                                                                */
6951 80d11f44 j_mayer
    POWERPC_DEF("MPC870",        CPU_POWERPC_MPC870,                 MPC8xx),
6952 80d11f44 j_mayer
#endif
6953 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6954 80d11f44 j_mayer
    /* MPC875                                                                */
6955 80d11f44 j_mayer
    POWERPC_DEF("MPC875",        CPU_POWERPC_MPC875,                 MPC8xx),
6956 80d11f44 j_mayer
#endif
6957 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6958 80d11f44 j_mayer
    /* MPC880                                                                */
6959 80d11f44 j_mayer
    POWERPC_DEF("MPC880",        CPU_POWERPC_MPC880,                 MPC8xx),
6960 80d11f44 j_mayer
#endif
6961 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
6962 80d11f44 j_mayer
    /* MPC885                                                                */
6963 80d11f44 j_mayer
    POWERPC_DEF("MPC885",        CPU_POWERPC_MPC885,                 MPC8xx),
6964 80d11f44 j_mayer
#endif
6965 80d11f44 j_mayer
    /* MPC82xx family (aka PowerQUICC-II)                                    */
6966 80d11f44 j_mayer
    /* Generic MPC52xx core                                                  */
6967 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC52xx",
6968 80d11f44 j_mayer
                    CPU_POWERPC_MPC52xx,      POWERPC_SVR_52xx,      G2LE),
6969 80d11f44 j_mayer
    /* Generic MPC82xx core                                                  */
6970 80d11f44 j_mayer
    POWERPC_DEF("MPC82xx",       CPU_POWERPC_MPC82xx,                G2),
6971 80d11f44 j_mayer
    /* Codename for MPC82xx                                                  */
6972 80d11f44 j_mayer
    POWERPC_DEF("PowerQUICC-II", CPU_POWERPC_MPC82xx,                G2),
6973 80d11f44 j_mayer
    /* PowerPC G2 core                                                       */
6974 80d11f44 j_mayer
    POWERPC_DEF("G2",            CPU_POWERPC_G2,                     G2),
6975 80d11f44 j_mayer
    /* PowerPC G2 H4 core                                                    */
6976 80d11f44 j_mayer
    POWERPC_DEF("G2H4",          CPU_POWERPC_G2H4,                   G2),
6977 80d11f44 j_mayer
    /* PowerPC G2 GP core                                                    */
6978 80d11f44 j_mayer
    POWERPC_DEF("G2GP",          CPU_POWERPC_G2gp,                   G2),
6979 80d11f44 j_mayer
    /* PowerPC G2 LS core                                                    */
6980 80d11f44 j_mayer
    POWERPC_DEF("G2LS",          CPU_POWERPC_G2ls,                   G2),
6981 80d11f44 j_mayer
    /* PowerPC G2 HiP3 core                                                  */
6982 80d11f44 j_mayer
    POWERPC_DEF("G2HiP3",        CPU_POWERPC_G2_HIP3,                G2),
6983 80d11f44 j_mayer
    /* PowerPC G2 HiP4 core                                                  */
6984 80d11f44 j_mayer
    POWERPC_DEF("G2HiP4",        CPU_POWERPC_G2_HIP4,                G2),
6985 80d11f44 j_mayer
    /* PowerPC MPC603 core                                                   */
6986 80d11f44 j_mayer
    POWERPC_DEF("MPC603",        CPU_POWERPC_MPC603,                 603E),
6987 80d11f44 j_mayer
    /* PowerPC G2le core (same as G2 plus little-endian mode support)        */
6988 80d11f44 j_mayer
    POWERPC_DEF("G2le",          CPU_POWERPC_G2LE,                   G2LE),
6989 80d11f44 j_mayer
    /* PowerPC G2LE GP core                                                  */
6990 80d11f44 j_mayer
    POWERPC_DEF("G2leGP",        CPU_POWERPC_G2LEgp,                 G2LE),
6991 80d11f44 j_mayer
    /* PowerPC G2LE LS core                                                  */
6992 80d11f44 j_mayer
    POWERPC_DEF("G2leLS",        CPU_POWERPC_G2LEls,                 G2LE),
6993 80d11f44 j_mayer
    /* PowerPC G2LE GP1 core                                                 */
6994 80d11f44 j_mayer
    POWERPC_DEF("G2leGP1",       CPU_POWERPC_G2LEgp1,                G2LE),
6995 80d11f44 j_mayer
    /* PowerPC G2LE GP3 core                                                 */
6996 80d11f44 j_mayer
    POWERPC_DEF("G2leGP3",       CPU_POWERPC_G2LEgp1,                G2LE),
6997 80d11f44 j_mayer
    /* PowerPC MPC603 microcontrollers                                       */
6998 80d11f44 j_mayer
    /* MPC8240                                                               */
6999 80d11f44 j_mayer
    POWERPC_DEF("MPC8240",       CPU_POWERPC_MPC8240,                603E),
7000 80d11f44 j_mayer
    /* PowerPC G2 microcontrollers                                           */
7001 082c6681 j_mayer
#if defined(TODO)
7002 80d11f44 j_mayer
    /* MPC5121                                                               */
7003 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5121",
7004 80d11f44 j_mayer
                    CPU_POWERPC_MPC5121,      POWERPC_SVR_5121,      G2LE),
7005 80d11f44 j_mayer
#endif
7006 80d11f44 j_mayer
    /* MPC5200                                                               */
7007 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200",
7008 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200,      POWERPC_SVR_5200,      G2LE),
7009 80d11f44 j_mayer
    /* MPC5200 v1.0                                                          */
7010 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v10",
7011 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v10,  POWERPC_SVR_5200_v10,  G2LE),
7012 80d11f44 j_mayer
    /* MPC5200 v1.1                                                          */
7013 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v11",
7014 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v11,  POWERPC_SVR_5200_v11,  G2LE),
7015 80d11f44 j_mayer
    /* MPC5200 v1.2                                                          */
7016 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v12",
7017 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v12,  POWERPC_SVR_5200_v12,  G2LE),
7018 80d11f44 j_mayer
    /* MPC5200B                                                              */
7019 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B",
7020 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B,     POWERPC_SVR_5200B,     G2LE),
7021 80d11f44 j_mayer
    /* MPC5200B v2.0                                                         */
7022 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B_v20",
7023 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B_v20, POWERPC_SVR_5200B_v20, G2LE),
7024 80d11f44 j_mayer
    /* MPC5200B v2.1                                                         */
7025 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B_v21",
7026 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B_v21, POWERPC_SVR_5200B_v21, G2LE),
7027 80d11f44 j_mayer
    /* MPC8241                                                               */
7028 80d11f44 j_mayer
    POWERPC_DEF("MPC8241",       CPU_POWERPC_MPC8241,                G2),
7029 80d11f44 j_mayer
    /* MPC8245                                                               */
7030 80d11f44 j_mayer
    POWERPC_DEF("MPC8245",       CPU_POWERPC_MPC8245,                G2),
7031 80d11f44 j_mayer
    /* MPC8247                                                               */
7032 80d11f44 j_mayer
    POWERPC_DEF("MPC8247",       CPU_POWERPC_MPC8247,                G2LE),
7033 80d11f44 j_mayer
    /* MPC8248                                                               */
7034 80d11f44 j_mayer
    POWERPC_DEF("MPC8248",       CPU_POWERPC_MPC8248,                G2LE),
7035 80d11f44 j_mayer
    /* MPC8250                                                               */
7036 80d11f44 j_mayer
    POWERPC_DEF("MPC8250",       CPU_POWERPC_MPC8250,                G2),
7037 80d11f44 j_mayer
    /* MPC8250 HiP3                                                          */
7038 80d11f44 j_mayer
    POWERPC_DEF("MPC8250_HiP3",  CPU_POWERPC_MPC8250_HiP3,           G2),
7039 80d11f44 j_mayer
    /* MPC8250 HiP4                                                          */
7040 80d11f44 j_mayer
    POWERPC_DEF("MPC8250_HiP4",  CPU_POWERPC_MPC8250_HiP4,           G2),
7041 80d11f44 j_mayer
    /* MPC8255                                                               */
7042 80d11f44 j_mayer
    POWERPC_DEF("MPC8255",       CPU_POWERPC_MPC8255,                G2),
7043 80d11f44 j_mayer
    /* MPC8255 HiP3                                                          */
7044 80d11f44 j_mayer
    POWERPC_DEF("MPC8255_HiP3",  CPU_POWERPC_MPC8255_HiP3,           G2),
7045 80d11f44 j_mayer
    /* MPC8255 HiP4                                                          */
7046 80d11f44 j_mayer
    POWERPC_DEF("MPC8255_HiP4",  CPU_POWERPC_MPC8255_HiP4,           G2),
7047 80d11f44 j_mayer
    /* MPC8260                                                               */
7048 80d11f44 j_mayer
    POWERPC_DEF("MPC8260",       CPU_POWERPC_MPC8260,                G2),
7049 80d11f44 j_mayer
    /* MPC8260 HiP3                                                          */
7050 80d11f44 j_mayer
    POWERPC_DEF("MPC8260_HiP3",  CPU_POWERPC_MPC8260_HiP3,           G2),
7051 80d11f44 j_mayer
    /* MPC8260 HiP4                                                          */
7052 80d11f44 j_mayer
    POWERPC_DEF("MPC8260_HiP4",  CPU_POWERPC_MPC8260_HiP4,           G2),
7053 80d11f44 j_mayer
    /* MPC8264                                                               */
7054 80d11f44 j_mayer
    POWERPC_DEF("MPC8264",       CPU_POWERPC_MPC8264,                G2),
7055 80d11f44 j_mayer
    /* MPC8264 HiP3                                                          */
7056 80d11f44 j_mayer
    POWERPC_DEF("MPC8264_HiP3",  CPU_POWERPC_MPC8264_HiP3,           G2),
7057 80d11f44 j_mayer
    /* MPC8264 HiP4                                                          */
7058 80d11f44 j_mayer
    POWERPC_DEF("MPC8264_HiP4",  CPU_POWERPC_MPC8264_HiP4,           G2),
7059 80d11f44 j_mayer
    /* MPC8265                                                               */
7060 80d11f44 j_mayer
    POWERPC_DEF("MPC8265",       CPU_POWERPC_MPC8265,                G2),
7061 80d11f44 j_mayer
    /* MPC8265 HiP3                                                          */
7062 80d11f44 j_mayer
    POWERPC_DEF("MPC8265_HiP3",  CPU_POWERPC_MPC8265_HiP3,           G2),
7063 80d11f44 j_mayer
    /* MPC8265 HiP4                                                          */
7064 80d11f44 j_mayer
    POWERPC_DEF("MPC8265_HiP4",  CPU_POWERPC_MPC8265_HiP4,           G2),
7065 80d11f44 j_mayer
    /* MPC8266                                                               */
7066 80d11f44 j_mayer
    POWERPC_DEF("MPC8266",       CPU_POWERPC_MPC8266,                G2),
7067 80d11f44 j_mayer
    /* MPC8266 HiP3                                                          */
7068 80d11f44 j_mayer
    POWERPC_DEF("MPC8266_HiP3",  CPU_POWERPC_MPC8266_HiP3,           G2),
7069 80d11f44 j_mayer
    /* MPC8266 HiP4                                                          */
7070 80d11f44 j_mayer
    POWERPC_DEF("MPC8266_HiP4",  CPU_POWERPC_MPC8266_HiP4,           G2),
7071 80d11f44 j_mayer
    /* MPC8270                                                               */
7072 80d11f44 j_mayer
    POWERPC_DEF("MPC8270",       CPU_POWERPC_MPC8270,                G2LE),
7073 80d11f44 j_mayer
    /* MPC8271                                                               */
7074 80d11f44 j_mayer
    POWERPC_DEF("MPC8271",       CPU_POWERPC_MPC8271,                G2LE),
7075 80d11f44 j_mayer
    /* MPC8272                                                               */
7076 80d11f44 j_mayer
    POWERPC_DEF("MPC8272",       CPU_POWERPC_MPC8272,                G2LE),
7077 80d11f44 j_mayer
    /* MPC8275                                                               */
7078 80d11f44 j_mayer
    POWERPC_DEF("MPC8275",       CPU_POWERPC_MPC8275,                G2LE),
7079 80d11f44 j_mayer
    /* MPC8280                                                               */
7080 80d11f44 j_mayer
    POWERPC_DEF("MPC8280",       CPU_POWERPC_MPC8280,                G2LE),
7081 a750fc0b j_mayer
    /* e200 family                                                           */
7082 a750fc0b j_mayer
    /* Generic PowerPC e200 core                                             */
7083 80d11f44 j_mayer
    POWERPC_DEF("e200",          CPU_POWERPC_e200,                   e200),
7084 80d11f44 j_mayer
    /* Generic MPC55xx core                                                  */
7085 80d11f44 j_mayer
#if defined (TODO)
7086 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC55xx",
7087 80d11f44 j_mayer
                    CPU_POWERPC_MPC55xx,      POWERPC_SVR_55xx,      e200),
7088 a750fc0b j_mayer
#endif
7089 a750fc0b j_mayer
#if defined (TODO)
7090 80d11f44 j_mayer
    /* PowerPC e200z0 core                                                   */
7091 80d11f44 j_mayer
    POWERPC_DEF("e200z0",        CPU_POWERPC_e200z0,                 e200),
7092 a750fc0b j_mayer
#endif
7093 a750fc0b j_mayer
#if defined (TODO)
7094 80d11f44 j_mayer
    /* PowerPC e200z1 core                                                   */
7095 80d11f44 j_mayer
    POWERPC_DEF("e200z1",        CPU_POWERPC_e200z1,                 e200),
7096 80d11f44 j_mayer
#endif
7097 80d11f44 j_mayer
#if defined (TODO)
7098 80d11f44 j_mayer
    /* PowerPC e200z3 core                                                   */
7099 80d11f44 j_mayer
    POWERPC_DEF("e200z3",        CPU_POWERPC_e200z3,                 e200),
7100 80d11f44 j_mayer
#endif
7101 80d11f44 j_mayer
    /* PowerPC e200z5 core                                                   */
7102 80d11f44 j_mayer
    POWERPC_DEF("e200z5",        CPU_POWERPC_e200z5,                 e200),
7103 a750fc0b j_mayer
    /* PowerPC e200z6 core                                                   */
7104 80d11f44 j_mayer
    POWERPC_DEF("e200z6",        CPU_POWERPC_e200z6,                 e200),
7105 80d11f44 j_mayer
    /* PowerPC e200 microcontrollers                                         */
7106 80d11f44 j_mayer
#if defined (TODO)
7107 80d11f44 j_mayer
    /* MPC5514E                                                              */
7108 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E",
7109 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E,     POWERPC_SVR_5514E,     e200),
7110 a750fc0b j_mayer
#endif
7111 a750fc0b j_mayer
#if defined (TODO)
7112 80d11f44 j_mayer
    /* MPC5514E v0                                                           */
7113 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E_v0",
7114 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E_v0,  POWERPC_SVR_5514E_v0,  e200),
7115 a750fc0b j_mayer
#endif
7116 a750fc0b j_mayer
#if defined (TODO)
7117 80d11f44 j_mayer
    /* MPC5514E v1                                                           */
7118 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E_v1",
7119 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E_v1,  POWERPC_SVR_5514E_v1,  e200),
7120 a750fc0b j_mayer
#endif
7121 a750fc0b j_mayer
#if defined (TODO)
7122 80d11f44 j_mayer
    /* MPC5514G                                                              */
7123 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G",
7124 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G,     POWERPC_SVR_5514G,     e200),
7125 a750fc0b j_mayer
#endif
7126 a750fc0b j_mayer
#if defined (TODO)
7127 80d11f44 j_mayer
    /* MPC5514G v0                                                           */
7128 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G_v0",
7129 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G_v0,  POWERPC_SVR_5514G_v0,  e200),
7130 a750fc0b j_mayer
#endif
7131 a750fc0b j_mayer
#if defined (TODO)
7132 80d11f44 j_mayer
    /* MPC5514G v1                                                           */
7133 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G_v1",
7134 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G_v1,  POWERPC_SVR_5514G_v1,  e200),
7135 a750fc0b j_mayer
#endif
7136 a750fc0b j_mayer
#if defined (TODO)
7137 80d11f44 j_mayer
    /* MPC5515S                                                              */
7138 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5515S",
7139 80d11f44 j_mayer
                    CPU_POWERPC_MPC5515S,     POWERPC_SVR_5515S,     e200),
7140 a750fc0b j_mayer
#endif
7141 a750fc0b j_mayer
#if defined (TODO)
7142 80d11f44 j_mayer
    /* MPC5516E                                                              */
7143 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E",
7144 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E,     POWERPC_SVR_5516E,     e200),
7145 a750fc0b j_mayer
#endif
7146 a750fc0b j_mayer
#if defined (TODO)
7147 80d11f44 j_mayer
    /* MPC5516E v0                                                           */
7148 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E_v0",
7149 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E_v0,  POWERPC_SVR_5516E_v0,  e200),
7150 a750fc0b j_mayer
#endif
7151 a750fc0b j_mayer
#if defined (TODO)
7152 80d11f44 j_mayer
    /* MPC5516E v1                                                           */
7153 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E_v1",
7154 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E_v1,  POWERPC_SVR_5516E_v1,  e200),
7155 a750fc0b j_mayer
#endif
7156 a750fc0b j_mayer
#if defined (TODO)
7157 80d11f44 j_mayer
    /* MPC5516G                                                              */
7158 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G",
7159 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G,     POWERPC_SVR_5516G,     e200),
7160 a750fc0b j_mayer
#endif
7161 a750fc0b j_mayer
#if defined (TODO)
7162 80d11f44 j_mayer
    /* MPC5516G v0                                                           */
7163 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G_v0",
7164 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G_v0,  POWERPC_SVR_5516G_v0,  e200),
7165 a750fc0b j_mayer
#endif
7166 a750fc0b j_mayer
#if defined (TODO)
7167 80d11f44 j_mayer
    /* MPC5516G v1                                                           */
7168 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G_v1",
7169 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G_v1,  POWERPC_SVR_5516G_v1,  e200),
7170 a750fc0b j_mayer
#endif
7171 a750fc0b j_mayer
#if defined (TODO)
7172 80d11f44 j_mayer
    /* MPC5516S                                                              */
7173 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516S",
7174 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516S,     POWERPC_SVR_5516S,     e200),
7175 a750fc0b j_mayer
#endif
7176 a750fc0b j_mayer
#if defined (TODO)
7177 80d11f44 j_mayer
    /* MPC5533                                                               */
7178 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5533",
7179 80d11f44 j_mayer
                    CPU_POWERPC_MPC5533,      POWERPC_SVR_5533,      e200),
7180 a750fc0b j_mayer
#endif
7181 a750fc0b j_mayer
#if defined (TODO)
7182 80d11f44 j_mayer
    /* MPC5534                                                               */
7183 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5534",
7184 80d11f44 j_mayer
                    CPU_POWERPC_MPC5534,      POWERPC_SVR_5534,      e200),
7185 a750fc0b j_mayer
#endif
7186 80d11f44 j_mayer
#if defined (TODO)
7187 80d11f44 j_mayer
    /* MPC5553                                                               */
7188 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5553",
7189 80d11f44 j_mayer
                    CPU_POWERPC_MPC5553,      POWERPC_SVR_5553,      e200),
7190 80d11f44 j_mayer
#endif
7191 80d11f44 j_mayer
#if defined (TODO)
7192 80d11f44 j_mayer
    /* MPC5554                                                               */
7193 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5554",
7194 80d11f44 j_mayer
                    CPU_POWERPC_MPC5554,      POWERPC_SVR_5554,      e200),
7195 80d11f44 j_mayer
#endif
7196 80d11f44 j_mayer
#if defined (TODO)
7197 80d11f44 j_mayer
    /* MPC5561                                                               */
7198 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5561",
7199 80d11f44 j_mayer
                    CPU_POWERPC_MPC5561,      POWERPC_SVR_5561,      e200),
7200 80d11f44 j_mayer
#endif
7201 80d11f44 j_mayer
#if defined (TODO)
7202 80d11f44 j_mayer
    /* MPC5565                                                               */
7203 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5565",
7204 80d11f44 j_mayer
                    CPU_POWERPC_MPC5565,      POWERPC_SVR_5565,      e200),
7205 80d11f44 j_mayer
#endif
7206 80d11f44 j_mayer
#if defined (TODO)
7207 80d11f44 j_mayer
    /* MPC5566                                                               */
7208 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5566",
7209 80d11f44 j_mayer
                    CPU_POWERPC_MPC5566,      POWERPC_SVR_5566,      e200),
7210 80d11f44 j_mayer
#endif
7211 80d11f44 j_mayer
#if defined (TODO)
7212 80d11f44 j_mayer
    /* MPC5567                                                               */
7213 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5567",
7214 80d11f44 j_mayer
                    CPU_POWERPC_MPC5567,      POWERPC_SVR_5567,      e200),
7215 80d11f44 j_mayer
#endif
7216 80d11f44 j_mayer
    /* e300 family                                                           */
7217 80d11f44 j_mayer
    /* Generic PowerPC e300 core                                             */
7218 80d11f44 j_mayer
    POWERPC_DEF("e300",          CPU_POWERPC_e300,                   e300),
7219 80d11f44 j_mayer
    /* PowerPC e300c1 core                                                   */
7220 80d11f44 j_mayer
    POWERPC_DEF("e300c1",        CPU_POWERPC_e300c1,                 e300),
7221 80d11f44 j_mayer
    /* PowerPC e300c2 core                                                   */
7222 80d11f44 j_mayer
    POWERPC_DEF("e300c2",        CPU_POWERPC_e300c2,                 e300),
7223 80d11f44 j_mayer
    /* PowerPC e300c3 core                                                   */
7224 80d11f44 j_mayer
    POWERPC_DEF("e300c3",        CPU_POWERPC_e300c3,                 e300),
7225 80d11f44 j_mayer
    /* PowerPC e300c4 core                                                   */
7226 80d11f44 j_mayer
    POWERPC_DEF("e300c4",        CPU_POWERPC_e300c4,                 e300),
7227 80d11f44 j_mayer
    /* PowerPC e300 microcontrollers                                         */
7228 80d11f44 j_mayer
#if defined (TODO)
7229 80d11f44 j_mayer
    /* MPC8313                                                               */
7230 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8313",
7231 80d11f44 j_mayer
                    CPU_POWERPC_MPC8313,      POWERPC_SVR_8313,      e300),
7232 80d11f44 j_mayer
#endif
7233 80d11f44 j_mayer
#if defined (TODO)
7234 80d11f44 j_mayer
    /* MPC8313E                                                              */
7235 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8313E",
7236 80d11f44 j_mayer
                    CPU_POWERPC_MPC8313E,     POWERPC_SVR_8313E,     e300),
7237 80d11f44 j_mayer
#endif
7238 80d11f44 j_mayer
#if defined (TODO)
7239 80d11f44 j_mayer
    /* MPC8314                                                               */
7240 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8314",
7241 80d11f44 j_mayer
                    CPU_POWERPC_MPC8314,      POWERPC_SVR_8314,      e300),
7242 80d11f44 j_mayer
#endif
7243 80d11f44 j_mayer
#if defined (TODO)
7244 80d11f44 j_mayer
    /* MPC8314E                                                              */
7245 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8314E",
7246 80d11f44 j_mayer
                    CPU_POWERPC_MPC8314E,     POWERPC_SVR_8314E,     e300),
7247 80d11f44 j_mayer
#endif
7248 80d11f44 j_mayer
#if defined (TODO)
7249 80d11f44 j_mayer
    /* MPC8315                                                               */
7250 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8315",
7251 80d11f44 j_mayer
                    CPU_POWERPC_MPC8315,      POWERPC_SVR_8315,      e300),
7252 80d11f44 j_mayer
#endif
7253 80d11f44 j_mayer
#if defined (TODO)
7254 80d11f44 j_mayer
    /* MPC8315E                                                              */
7255 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8315E",
7256 80d11f44 j_mayer
                    CPU_POWERPC_MPC8315E,     POWERPC_SVR_8315E,     e300),
7257 80d11f44 j_mayer
#endif
7258 80d11f44 j_mayer
#if defined (TODO)
7259 80d11f44 j_mayer
    /* MPC8321                                                               */
7260 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8321",
7261 80d11f44 j_mayer
                    CPU_POWERPC_MPC8321,      POWERPC_SVR_8321,      e300),
7262 80d11f44 j_mayer
#endif
7263 80d11f44 j_mayer
#if defined (TODO)
7264 80d11f44 j_mayer
    /* MPC8321E                                                              */
7265 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8321E",
7266 80d11f44 j_mayer
                    CPU_POWERPC_MPC8321E,     POWERPC_SVR_8321E,     e300),
7267 80d11f44 j_mayer
#endif
7268 80d11f44 j_mayer
#if defined (TODO)
7269 80d11f44 j_mayer
    /* MPC8323                                                               */
7270 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8323",
7271 80d11f44 j_mayer
                    CPU_POWERPC_MPC8323,      POWERPC_SVR_8323,      e300),
7272 80d11f44 j_mayer
#endif
7273 80d11f44 j_mayer
#if defined (TODO)
7274 80d11f44 j_mayer
    /* MPC8323E                                                              */
7275 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8323E",
7276 80d11f44 j_mayer
                    CPU_POWERPC_MPC8323E,     POWERPC_SVR_8323E,     e300),
7277 80d11f44 j_mayer
#endif
7278 80d11f44 j_mayer
    /* MPC8343A                                                              */
7279 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8343A",
7280 80d11f44 j_mayer
                    CPU_POWERPC_MPC8343A,     POWERPC_SVR_8343A,     e300),
7281 80d11f44 j_mayer
    /* MPC8343EA                                                             */
7282 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8343EA",
7283 80d11f44 j_mayer
                    CPU_POWERPC_MPC8343EA,    POWERPC_SVR_8343EA,    e300),
7284 80d11f44 j_mayer
    /* MPC8347A                                                              */
7285 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347A",
7286 80d11f44 j_mayer
                    CPU_POWERPC_MPC8347A,     POWERPC_SVR_8347A,     e300),
7287 80d11f44 j_mayer
    /* MPC8347AT                                                             */
7288 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347AT",
7289 80d11f44 j_mayer
                    CPU_POWERPC_MPC8347AT,    POWERPC_SVR_8347AT,    e300),
7290 80d11f44 j_mayer
    /* MPC8347AP                                                             */
7291 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347AP",
7292 80d11f44 j_mayer
                    CPU_POWERPC_MPC8347AP,    POWERPC_SVR_8347AP,    e300),
7293 80d11f44 j_mayer
    /* MPC8347EA                                                             */
7294 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EA",
7295 80d11f44 j_mayer
                    CPU_POWERPC_MPC8347EA,    POWERPC_SVR_8347EA,    e300),
7296 80d11f44 j_mayer
    /* MPC8347EAT                                                            */
7297 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EAT",
7298 80d11f44 j_mayer
                    CPU_POWERPC_MPC8347EAT,   POWERPC_SVR_8347EAT,   e300),
7299 80d11f44 j_mayer
    /* MPC8343EAP                                                            */
7300 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EAP",
7301 80d11f44 j_mayer
                    CPU_POWERPC_MPC8347EAP,   POWERPC_SVR_8347EAP,   e300),
7302 80d11f44 j_mayer
    /* MPC8349                                                               */
7303 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349",
7304 80d11f44 j_mayer
                    CPU_POWERPC_MPC8349,      POWERPC_SVR_8349,      e300),
7305 80d11f44 j_mayer
    /* MPC8349A                                                              */
7306 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349A",
7307 80d11f44 j_mayer
                    CPU_POWERPC_MPC8349A,     POWERPC_SVR_8349A,     e300),
7308 80d11f44 j_mayer
    /* MPC8349E                                                              */
7309 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349E",
7310 80d11f44 j_mayer
                    CPU_POWERPC_MPC8349E,     POWERPC_SVR_8349E,     e300),
7311 80d11f44 j_mayer
    /* MPC8349EA                                                             */
7312 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349EA",
7313 80d11f44 j_mayer
                    CPU_POWERPC_MPC8349EA,    POWERPC_SVR_8349EA,    e300),
7314 80d11f44 j_mayer
#if defined (TODO)
7315 80d11f44 j_mayer
    /* MPC8358E                                                              */
7316 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8358E",
7317 80d11f44 j_mayer
                    CPU_POWERPC_MPC8358E,     POWERPC_SVR_8358E,     e300),
7318 80d11f44 j_mayer
#endif
7319 80d11f44 j_mayer
#if defined (TODO)
7320 80d11f44 j_mayer
    /* MPC8360E                                                              */
7321 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8360E",
7322 80d11f44 j_mayer
                    CPU_POWERPC_MPC8360E,     POWERPC_SVR_8360E,     e300),
7323 80d11f44 j_mayer
#endif
7324 80d11f44 j_mayer
    /* MPC8377                                                               */
7325 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8377",
7326 80d11f44 j_mayer
                    CPU_POWERPC_MPC8377,      POWERPC_SVR_8377,      e300),
7327 80d11f44 j_mayer
    /* MPC8377E                                                              */
7328 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8377E",
7329 80d11f44 j_mayer
                    CPU_POWERPC_MPC8377E,     POWERPC_SVR_8377E,     e300),
7330 80d11f44 j_mayer
    /* MPC8378                                                               */
7331 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8378",
7332 80d11f44 j_mayer
                    CPU_POWERPC_MPC8378,      POWERPC_SVR_8378,      e300),
7333 80d11f44 j_mayer
    /* MPC8378E                                                              */
7334 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8378E",
7335 80d11f44 j_mayer
                    CPU_POWERPC_MPC8378E,     POWERPC_SVR_8378E,     e300),
7336 80d11f44 j_mayer
    /* MPC8379                                                               */
7337 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8379",
7338 80d11f44 j_mayer
                    CPU_POWERPC_MPC8379,      POWERPC_SVR_8379,      e300),
7339 80d11f44 j_mayer
    /* MPC8379E                                                              */
7340 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8379E",
7341 80d11f44 j_mayer
                    CPU_POWERPC_MPC8379E,     POWERPC_SVR_8379E,     e300),
7342 80d11f44 j_mayer
    /* e500 family                                                           */
7343 80d11f44 j_mayer
    /* PowerPC e500 core                                                     */
7344 80d11f44 j_mayer
    POWERPC_DEF("e500",          CPU_POWERPC_e500,                   e500),
7345 80d11f44 j_mayer
    /* PowerPC e500 v1.0 core                                                */
7346 80d11f44 j_mayer
    POWERPC_DEF("e500_v10",      CPU_POWERPC_e500_v10,               e500),
7347 80d11f44 j_mayer
    /* PowerPC e500 v2.0 core                                                */
7348 80d11f44 j_mayer
    POWERPC_DEF("e500_v20",      CPU_POWERPC_e500_v20,               e500),
7349 80d11f44 j_mayer
    /* PowerPC e500v2 core                                                   */
7350 80d11f44 j_mayer
    POWERPC_DEF("e500v2",        CPU_POWERPC_e500v2,                 e500),
7351 80d11f44 j_mayer
    /* PowerPC e500v2 v1.0 core                                              */
7352 80d11f44 j_mayer
    POWERPC_DEF("e500v2_v10",    CPU_POWERPC_e500v2_v10,             e500),
7353 80d11f44 j_mayer
    /* PowerPC e500v2 v2.0 core                                              */
7354 80d11f44 j_mayer
    POWERPC_DEF("e500v2_v20",    CPU_POWERPC_e500v2_v20,             e500),
7355 80d11f44 j_mayer
    /* PowerPC e500v2 v2.1 core                                              */
7356 80d11f44 j_mayer
    POWERPC_DEF("e500v2_v21",    CPU_POWERPC_e500v2_v21,             e500),
7357 80d11f44 j_mayer
    /* PowerPC e500v2 v2.2 core                                              */
7358 80d11f44 j_mayer
    POWERPC_DEF("e500v2_v22",    CPU_POWERPC_e500v2_v22,             e500),
7359 80d11f44 j_mayer
    /* PowerPC e500v2 v3.0 core                                              */
7360 80d11f44 j_mayer
    POWERPC_DEF("e500v2_v30",    CPU_POWERPC_e500v2_v30,             e500),
7361 80d11f44 j_mayer
    /* PowerPC e500 microcontrollers                                         */
7362 80d11f44 j_mayer
    /* MPC8533                                                               */
7363 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533",
7364 80d11f44 j_mayer
                    CPU_POWERPC_MPC8533,      POWERPC_SVR_8533,      e500),
7365 80d11f44 j_mayer
    /* MPC8533 v1.0                                                          */
7366 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533_v10",
7367 80d11f44 j_mayer
                    CPU_POWERPC_MPC8533_v10,  POWERPC_SVR_8533_v10,  e500),
7368 80d11f44 j_mayer
    /* MPC8533 v1.1                                                          */
7369 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533_v11",
7370 80d11f44 j_mayer
                    CPU_POWERPC_MPC8533_v11,  POWERPC_SVR_8533_v11,  e500),
7371 80d11f44 j_mayer
    /* MPC8533E                                                              */
7372 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E",
7373 80d11f44 j_mayer
                    CPU_POWERPC_MPC8533E,     POWERPC_SVR_8533E,     e500),
7374 80d11f44 j_mayer
    /* MPC8533E v1.0                                                         */
7375 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E_v10",
7376 80d11f44 j_mayer
                    CPU_POWERPC_MPC8533E_v10, POWERPC_SVR_8533E_v10, e500),
7377 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E_v11",
7378 80d11f44 j_mayer
                    CPU_POWERPC_MPC8533E_v11, POWERPC_SVR_8533E_v11, e500),
7379 80d11f44 j_mayer
    /* MPC8540                                                               */
7380 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540",
7381 80d11f44 j_mayer
                    CPU_POWERPC_MPC8540,      POWERPC_SVR_8540,      e500),
7382 80d11f44 j_mayer
    /* MPC8540 v1.0                                                          */
7383 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v10",
7384 80d11f44 j_mayer
                    CPU_POWERPC_MPC8540_v10,  POWERPC_SVR_8540_v10,  e500),
7385 80d11f44 j_mayer
    /* MPC8540 v2.0                                                          */
7386 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v20",
7387 80d11f44 j_mayer
                    CPU_POWERPC_MPC8540_v20,  POWERPC_SVR_8540_v20,  e500),
7388 80d11f44 j_mayer
    /* MPC8540 v2.1                                                          */
7389 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v21",
7390 80d11f44 j_mayer
                    CPU_POWERPC_MPC8540_v21,  POWERPC_SVR_8540_v21,  e500),
7391 80d11f44 j_mayer
    /* MPC8541                                                               */
7392 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541",
7393 80d11f44 j_mayer
                    CPU_POWERPC_MPC8541,      POWERPC_SVR_8541,      e500),
7394 80d11f44 j_mayer
    /* MPC8541 v1.0                                                          */
7395 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541_v10",
7396 80d11f44 j_mayer
                    CPU_POWERPC_MPC8541_v10,  POWERPC_SVR_8541_v10,  e500),
7397 80d11f44 j_mayer
    /* MPC8541 v1.1                                                          */
7398 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541_v11",
7399 80d11f44 j_mayer
                    CPU_POWERPC_MPC8541_v11,  POWERPC_SVR_8541_v11,  e500),
7400 80d11f44 j_mayer
    /* MPC8541E                                                              */
7401 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E",
7402 80d11f44 j_mayer
                    CPU_POWERPC_MPC8541E,     POWERPC_SVR_8541E,     e500),
7403 80d11f44 j_mayer
    /* MPC8541E v1.0                                                         */
7404 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E_v10",
7405 80d11f44 j_mayer
                    CPU_POWERPC_MPC8541E_v10, POWERPC_SVR_8541E_v10, e500),
7406 80d11f44 j_mayer
    /* MPC8541E v1.1                                                         */
7407 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E_v11",
7408 80d11f44 j_mayer
                    CPU_POWERPC_MPC8541E_v11, POWERPC_SVR_8541E_v11, e500),
7409 80d11f44 j_mayer
    /* MPC8543                                                               */
7410 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543",
7411 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543,      POWERPC_SVR_8543,      e500),
7412 80d11f44 j_mayer
    /* MPC8543 v1.0                                                          */
7413 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v10",
7414 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543_v10,  POWERPC_SVR_8543_v10,  e500),
7415 80d11f44 j_mayer
    /* MPC8543 v1.1                                                          */
7416 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v11",
7417 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543_v11,  POWERPC_SVR_8543_v11,  e500),
7418 80d11f44 j_mayer
    /* MPC8543 v2.0                                                          */
7419 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v20",
7420 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543_v20,  POWERPC_SVR_8543_v20,  e500),
7421 80d11f44 j_mayer
    /* MPC8543 v2.1                                                          */
7422 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v21",
7423 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543_v21,  POWERPC_SVR_8543_v21,  e500),
7424 80d11f44 j_mayer
    /* MPC8543E                                                              */
7425 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E",
7426 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543E,     POWERPC_SVR_8543E,     e500),
7427 80d11f44 j_mayer
    /* MPC8543E v1.0                                                         */
7428 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v10",
7429 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543E_v10, POWERPC_SVR_8543E_v10, e500),
7430 80d11f44 j_mayer
    /* MPC8543E v1.1                                                         */
7431 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v11",
7432 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543E_v11, POWERPC_SVR_8543E_v11, e500),
7433 80d11f44 j_mayer
    /* MPC8543E v2.0                                                         */
7434 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v20",
7435 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543E_v20, POWERPC_SVR_8543E_v20, e500),
7436 80d11f44 j_mayer
    /* MPC8543E v2.1                                                         */
7437 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v21",
7438 80d11f44 j_mayer
                    CPU_POWERPC_MPC8543E_v21, POWERPC_SVR_8543E_v21, e500),
7439 80d11f44 j_mayer
    /* MPC8544                                                               */
7440 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544",
7441 80d11f44 j_mayer
                    CPU_POWERPC_MPC8544,      POWERPC_SVR_8544,      e500),
7442 80d11f44 j_mayer
    /* MPC8544 v1.0                                                          */
7443 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544_v10",
7444 80d11f44 j_mayer
                    CPU_POWERPC_MPC8544_v10,  POWERPC_SVR_8544_v10,  e500),
7445 80d11f44 j_mayer
    /* MPC8544 v1.1                                                          */
7446 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544_v11",
7447 80d11f44 j_mayer
                    CPU_POWERPC_MPC8544_v11,  POWERPC_SVR_8544_v11,  e500),
7448 80d11f44 j_mayer
    /* MPC8544E                                                              */
7449 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E",
7450 80d11f44 j_mayer
                    CPU_POWERPC_MPC8544E,     POWERPC_SVR_8544E,     e500),
7451 80d11f44 j_mayer
    /* MPC8544E v1.0                                                         */
7452 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E_v10",
7453 80d11f44 j_mayer
                    CPU_POWERPC_MPC8544E_v10, POWERPC_SVR_8544E_v10, e500),
7454 80d11f44 j_mayer
    /* MPC8544E v1.1                                                         */
7455 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E_v11",
7456 80d11f44 j_mayer
                    CPU_POWERPC_MPC8544E_v11, POWERPC_SVR_8544E_v11, e500),
7457 80d11f44 j_mayer
    /* MPC8545                                                               */
7458 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545",
7459 80d11f44 j_mayer
                    CPU_POWERPC_MPC8545,      POWERPC_SVR_8545,      e500),
7460 80d11f44 j_mayer
    /* MPC8545 v2.0                                                          */
7461 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545_v20",
7462 80d11f44 j_mayer
                    CPU_POWERPC_MPC8545_v20,  POWERPC_SVR_8545_v20,  e500),
7463 80d11f44 j_mayer
    /* MPC8545 v2.1                                                          */
7464 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545_v21",
7465 80d11f44 j_mayer
                    CPU_POWERPC_MPC8545_v21,  POWERPC_SVR_8545_v21,  e500),
7466 80d11f44 j_mayer
    /* MPC8545E                                                              */
7467 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E",
7468 80d11f44 j_mayer
                    CPU_POWERPC_MPC8545E,     POWERPC_SVR_8545E,     e500),
7469 80d11f44 j_mayer
    /* MPC8545E v2.0                                                         */
7470 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E_v20",
7471 80d11f44 j_mayer
                    CPU_POWERPC_MPC8545E_v20, POWERPC_SVR_8545E_v20, e500),
7472 80d11f44 j_mayer
    /* MPC8545E v2.1                                                         */
7473 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E_v21",
7474 80d11f44 j_mayer
                    CPU_POWERPC_MPC8545E_v21, POWERPC_SVR_8545E_v21, e500),
7475 80d11f44 j_mayer
    /* MPC8547E                                                              */
7476 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E",
7477 80d11f44 j_mayer
                    CPU_POWERPC_MPC8547E,     POWERPC_SVR_8547E,     e500),
7478 80d11f44 j_mayer
    /* MPC8547E v2.0                                                         */
7479 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E_v20",
7480 80d11f44 j_mayer
                    CPU_POWERPC_MPC8547E_v20, POWERPC_SVR_8547E_v20, e500),
7481 80d11f44 j_mayer
    /* MPC8547E v2.1                                                         */
7482 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E_v21",
7483 80d11f44 j_mayer
                    CPU_POWERPC_MPC8547E_v21, POWERPC_SVR_8547E_v21, e500),
7484 80d11f44 j_mayer
    /* MPC8548                                                               */
7485 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548",
7486 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548,      POWERPC_SVR_8548,      e500),
7487 80d11f44 j_mayer
    /* MPC8548 v1.0                                                          */
7488 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v10",
7489 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548_v10,  POWERPC_SVR_8548_v10,  e500),
7490 80d11f44 j_mayer
    /* MPC8548 v1.1                                                          */
7491 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v11",
7492 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548_v11,  POWERPC_SVR_8548_v11,  e500),
7493 80d11f44 j_mayer
    /* MPC8548 v2.0                                                          */
7494 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v20",
7495 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548_v20,  POWERPC_SVR_8548_v20,  e500),
7496 80d11f44 j_mayer
    /* MPC8548 v2.1                                                          */
7497 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v21",
7498 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548_v21,  POWERPC_SVR_8548_v21,  e500),
7499 80d11f44 j_mayer
    /* MPC8548E                                                              */
7500 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E",
7501 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548E,     POWERPC_SVR_8548E,     e500),
7502 80d11f44 j_mayer
    /* MPC8548E v1.0                                                         */
7503 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v10",
7504 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548E_v10, POWERPC_SVR_8548E_v10, e500),
7505 80d11f44 j_mayer
    /* MPC8548E v1.1                                                         */
7506 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v11",
7507 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548E_v11, POWERPC_SVR_8548E_v11, e500),
7508 80d11f44 j_mayer
    /* MPC8548E v2.0                                                         */
7509 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v20",
7510 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548E_v20, POWERPC_SVR_8548E_v20, e500),
7511 80d11f44 j_mayer
    /* MPC8548E v2.1                                                         */
7512 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v21",
7513 80d11f44 j_mayer
                    CPU_POWERPC_MPC8548E_v21, POWERPC_SVR_8548E_v21, e500),
7514 80d11f44 j_mayer
    /* MPC8555                                                               */
7515 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555",
7516 80d11f44 j_mayer
                    CPU_POWERPC_MPC8555,      POWERPC_SVR_8555,      e500),
7517 80d11f44 j_mayer
    /* MPC8555 v1.0                                                          */
7518 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555_v10",
7519 80d11f44 j_mayer
                    CPU_POWERPC_MPC8555_v10,  POWERPC_SVR_8555_v10,  e500),
7520 80d11f44 j_mayer
    /* MPC8555 v1.1                                                          */
7521 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555_v11",
7522 80d11f44 j_mayer
                    CPU_POWERPC_MPC8555_v11,  POWERPC_SVR_8555_v11,  e500),
7523 80d11f44 j_mayer
    /* MPC8555E                                                              */
7524 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E",
7525 80d11f44 j_mayer
                    CPU_POWERPC_MPC8555E,     POWERPC_SVR_8555E,     e500),
7526 80d11f44 j_mayer
    /* MPC8555E v1.0                                                         */
7527 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E_v10",
7528 80d11f44 j_mayer
                    CPU_POWERPC_MPC8555E_v10, POWERPC_SVR_8555E_v10, e500),
7529 80d11f44 j_mayer
    /* MPC8555E v1.1                                                         */
7530 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E_v11",
7531 80d11f44 j_mayer
                    CPU_POWERPC_MPC8555E_v11, POWERPC_SVR_8555E_v11, e500),
7532 80d11f44 j_mayer
    /* MPC8560                                                               */
7533 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560",
7534 80d11f44 j_mayer
                    CPU_POWERPC_MPC8560,      POWERPC_SVR_8560,      e500),
7535 80d11f44 j_mayer
    /* MPC8560 v1.0                                                          */
7536 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v10",
7537 80d11f44 j_mayer
                    CPU_POWERPC_MPC8560_v10,  POWERPC_SVR_8560_v10,  e500),
7538 80d11f44 j_mayer
    /* MPC8560 v2.0                                                          */
7539 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v20",
7540 80d11f44 j_mayer
                    CPU_POWERPC_MPC8560_v20,  POWERPC_SVR_8560_v20,  e500),
7541 80d11f44 j_mayer
    /* MPC8560 v2.1                                                          */
7542 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v21",
7543 80d11f44 j_mayer
                    CPU_POWERPC_MPC8560_v21,  POWERPC_SVR_8560_v21,  e500),
7544 80d11f44 j_mayer
    /* MPC8567                                                               */
7545 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8567",
7546 80d11f44 j_mayer
                    CPU_POWERPC_MPC8567,      POWERPC_SVR_8567,      e500),
7547 80d11f44 j_mayer
    /* MPC8567E                                                              */
7548 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8567E",
7549 80d11f44 j_mayer
                    CPU_POWERPC_MPC8567E,     POWERPC_SVR_8567E,     e500),
7550 80d11f44 j_mayer
    /* MPC8568                                                               */
7551 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8568",
7552 80d11f44 j_mayer
                    CPU_POWERPC_MPC8568,      POWERPC_SVR_8568,      e500),
7553 80d11f44 j_mayer
    /* MPC8568E                                                              */
7554 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8568E",
7555 80d11f44 j_mayer
                    CPU_POWERPC_MPC8568E,     POWERPC_SVR_8568E,     e500),
7556 80d11f44 j_mayer
    /* MPC8572                                                               */
7557 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8572",
7558 80d11f44 j_mayer
                    CPU_POWERPC_MPC8572,      POWERPC_SVR_8572,      e500),
7559 80d11f44 j_mayer
    /* MPC8572E                                                              */
7560 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8572E",
7561 80d11f44 j_mayer
                    CPU_POWERPC_MPC8572E,     POWERPC_SVR_8572E,     e500),
7562 80d11f44 j_mayer
    /* e600 family                                                           */
7563 80d11f44 j_mayer
    /* PowerPC e600 core                                                     */
7564 80d11f44 j_mayer
    POWERPC_DEF("e600",          CPU_POWERPC_e600,                   7400),
7565 80d11f44 j_mayer
    /* PowerPC e600 microcontrollers                                         */
7566 80d11f44 j_mayer
#if defined (TODO)
7567 80d11f44 j_mayer
    /* MPC8610                                                               */
7568 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8610",
7569 80d11f44 j_mayer
                    CPU_POWERPC_MPC8610,      POWERPC_SVR_8610,      7400),
7570 80d11f44 j_mayer
#endif
7571 80d11f44 j_mayer
    /* MPC8641                                                               */
7572 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8641",
7573 80d11f44 j_mayer
                    CPU_POWERPC_MPC8641,      POWERPC_SVR_8641,      7400),
7574 80d11f44 j_mayer
    /* MPC8641D                                                              */
7575 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8641D",
7576 80d11f44 j_mayer
                    CPU_POWERPC_MPC8641D,     POWERPC_SVR_8641D,     7400),
7577 a750fc0b j_mayer
    /* 32 bits "classic" PowerPC                                             */
7578 a750fc0b j_mayer
    /* PowerPC 6xx family                                                    */
7579 a750fc0b j_mayer
    /* PowerPC 601                                                           */
7580 80d11f44 j_mayer
    POWERPC_DEF("601",           CPU_POWERPC_601,                    601),
7581 c3e36823 j_mayer
    /* PowerPC 601v0                                                         */
7582 082c6681 j_mayer
    POWERPC_DEF("601_v0",        CPU_POWERPC_601_v0,                 601),
7583 c3e36823 j_mayer
    /* PowerPC 601v1                                                         */
7584 082c6681 j_mayer
    POWERPC_DEF("601_v1",        CPU_POWERPC_601_v1,                 601),
7585 082c6681 j_mayer
    /* PowerPC 601v                                                          */
7586 082c6681 j_mayer
    POWERPC_DEF("601v",          CPU_POWERPC_601,                    601v),
7587 a750fc0b j_mayer
    /* PowerPC 601v2                                                         */
7588 082c6681 j_mayer
    POWERPC_DEF("601_v2",        CPU_POWERPC_601_v2,                 601v),
7589 a750fc0b j_mayer
    /* PowerPC 602                                                           */
7590 80d11f44 j_mayer
    POWERPC_DEF("602",           CPU_POWERPC_602,                    602),
7591 a750fc0b j_mayer
    /* PowerPC 603                                                           */
7592 80d11f44 j_mayer
    POWERPC_DEF("603",           CPU_POWERPC_603,                    603),
7593 a750fc0b j_mayer
    /* Code name for PowerPC 603                                             */
7594 80d11f44 j_mayer
    POWERPC_DEF("Vanilla",       CPU_POWERPC_603,                    603),
7595 082c6681 j_mayer
    /* PowerPC 603e (aka PID6)                                               */
7596 80d11f44 j_mayer
    POWERPC_DEF("603e",          CPU_POWERPC_603E,                   603E),
7597 a750fc0b j_mayer
    /* Code name for PowerPC 603e                                            */
7598 80d11f44 j_mayer
    POWERPC_DEF("Stretch",       CPU_POWERPC_603E,                   603E),
7599 a750fc0b j_mayer
    /* PowerPC 603e v1.1                                                     */
7600 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.1",     CPU_POWERPC_603E_v11,               603E),
7601 a750fc0b j_mayer
    /* PowerPC 603e v1.2                                                     */
7602 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.2",     CPU_POWERPC_603E_v12,               603E),
7603 a750fc0b j_mayer
    /* PowerPC 603e v1.3                                                     */
7604 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.3",     CPU_POWERPC_603E_v13,               603E),
7605 a750fc0b j_mayer
    /* PowerPC 603e v1.4                                                     */
7606 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.4",     CPU_POWERPC_603E_v14,               603E),
7607 a750fc0b j_mayer
    /* PowerPC 603e v2.2                                                     */
7608 80d11f44 j_mayer
    POWERPC_DEF("603e_v2.2",     CPU_POWERPC_603E_v22,               603E),
7609 a750fc0b j_mayer
    /* PowerPC 603e v3                                                       */
7610 80d11f44 j_mayer
    POWERPC_DEF("603e_v3",       CPU_POWERPC_603E_v3,                603E),
7611 a750fc0b j_mayer
    /* PowerPC 603e v4                                                       */
7612 80d11f44 j_mayer
    POWERPC_DEF("603e_v4",       CPU_POWERPC_603E_v4,                603E),
7613 a750fc0b j_mayer
    /* PowerPC 603e v4.1                                                     */
7614 80d11f44 j_mayer
    POWERPC_DEF("603e_v4.1",     CPU_POWERPC_603E_v41,               603E),
7615 082c6681 j_mayer
    /* PowerPC 603e (aka PID7)                                               */
7616 80d11f44 j_mayer
    POWERPC_DEF("603e7",         CPU_POWERPC_603E7,                  603E),
7617 a750fc0b j_mayer
    /* PowerPC 603e7t                                                        */
7618 80d11f44 j_mayer
    POWERPC_DEF("603e7t",        CPU_POWERPC_603E7t,                 603E),
7619 a750fc0b j_mayer
    /* PowerPC 603e7v                                                        */
7620 80d11f44 j_mayer
    POWERPC_DEF("603e7v",        CPU_POWERPC_603E7v,                 603E),
7621 a750fc0b j_mayer
    /* Code name for PowerPC 603ev                                           */
7622 80d11f44 j_mayer
    POWERPC_DEF("Vaillant",      CPU_POWERPC_603E7v,                 603E),
7623 a750fc0b j_mayer
    /* PowerPC 603e7v1                                                       */
7624 80d11f44 j_mayer
    POWERPC_DEF("603e7v1",       CPU_POWERPC_603E7v1,                603E),
7625 a750fc0b j_mayer
    /* PowerPC 603e7v2                                                       */
7626 80d11f44 j_mayer
    POWERPC_DEF("603e7v2",       CPU_POWERPC_603E7v2,                603E),
7627 082c6681 j_mayer
    /* PowerPC 603p (aka PID7v)                                              */
7628 082c6681 j_mayer
    POWERPC_DEF("603p",          CPU_POWERPC_603P,                   603E),
7629 082c6681 j_mayer
    /* PowerPC 603r (aka PID7t)                                              */
7630 80d11f44 j_mayer
    POWERPC_DEF("603r",          CPU_POWERPC_603R,                   603E),
7631 a750fc0b j_mayer
    /* Code name for PowerPC 603r                                            */
7632 80d11f44 j_mayer
    POWERPC_DEF("Goldeneye",     CPU_POWERPC_603R,                   603E),
7633 a750fc0b j_mayer
    /* PowerPC 604                                                           */
7634 80d11f44 j_mayer
    POWERPC_DEF("604",           CPU_POWERPC_604,                    604),
7635 082c6681 j_mayer
    /* PowerPC 604e (aka PID9)                                               */
7636 082c6681 j_mayer
    POWERPC_DEF("604e",          CPU_POWERPC_604E,                   604E),
7637 082c6681 j_mayer
    /* Code name for PowerPC 604e                                            */
7638 082c6681 j_mayer
    POWERPC_DEF("Sirocco",       CPU_POWERPC_604E,                   604E),
7639 a750fc0b j_mayer
    /* PowerPC 604e v1.0                                                     */
7640 082c6681 j_mayer
    POWERPC_DEF("604e_v1.0",     CPU_POWERPC_604E_v10,               604E),
7641 a750fc0b j_mayer
    /* PowerPC 604e v2.2                                                     */
7642 082c6681 j_mayer
    POWERPC_DEF("604e_v2.2",     CPU_POWERPC_604E_v22,               604E),
7643 a750fc0b j_mayer
    /* PowerPC 604e v2.4                                                     */
7644 082c6681 j_mayer
    POWERPC_DEF("604e_v2.4",     CPU_POWERPC_604E_v24,               604E),
7645 082c6681 j_mayer
    /* PowerPC 604r (aka PIDA)                                               */
7646 082c6681 j_mayer
    POWERPC_DEF("604r",          CPU_POWERPC_604R,                   604E),
7647 082c6681 j_mayer
    /* Code name for PowerPC 604r                                            */
7648 082c6681 j_mayer
    POWERPC_DEF("Mach5",         CPU_POWERPC_604R,                   604E),
7649 a750fc0b j_mayer
#if defined(TODO)
7650 a750fc0b j_mayer
    /* PowerPC 604ev                                                         */
7651 082c6681 j_mayer
    POWERPC_DEF("604ev",         CPU_POWERPC_604EV,                  604E),
7652 a750fc0b j_mayer
#endif
7653 a750fc0b j_mayer
    /* PowerPC 7xx family                                                    */
7654 a750fc0b j_mayer
    /* Generic PowerPC 740 (G3)                                              */
7655 80d11f44 j_mayer
    POWERPC_DEF("740",           CPU_POWERPC_7x0,                    7x0),
7656 082c6681 j_mayer
    /* Code name for PowerPC 740                                             */
7657 082c6681 j_mayer
    POWERPC_DEF("Arthur",        CPU_POWERPC_7x0,                    7x0),
7658 a750fc0b j_mayer
    /* Generic PowerPC 750 (G3)                                              */
7659 80d11f44 j_mayer
    POWERPC_DEF("750",           CPU_POWERPC_7x0,                    7x0),
7660 082c6681 j_mayer
    /* Code name for PowerPC 750                                             */
7661 082c6681 j_mayer
    POWERPC_DEF("Typhoon",       CPU_POWERPC_7x0,                    7x0),
7662 a750fc0b j_mayer
    /* PowerPC 740/750 is also known as G3                                   */
7663 80d11f44 j_mayer
    POWERPC_DEF("G3",            CPU_POWERPC_7x0,                    7x0),
7664 a750fc0b j_mayer
    /* PowerPC 740 v2.0 (G3)                                                 */
7665 80d11f44 j_mayer
    POWERPC_DEF("740_v2.0",      CPU_POWERPC_7x0_v20,                7x0),
7666 a750fc0b j_mayer
    /* PowerPC 750 v2.0 (G3)                                                 */
7667 80d11f44 j_mayer
    POWERPC_DEF("750_v2.0",      CPU_POWERPC_7x0_v20,                7x0),
7668 a750fc0b j_mayer
    /* PowerPC 740 v2.1 (G3)                                                 */
7669 80d11f44 j_mayer
    POWERPC_DEF("740_v2.1",      CPU_POWERPC_7x0_v21,                7x0),
7670 a750fc0b j_mayer
    /* PowerPC 750 v2.1 (G3)                                                 */
7671 80d11f44 j_mayer
    POWERPC_DEF("750_v2.1",      CPU_POWERPC_7x0_v21,                7x0),
7672 a750fc0b j_mayer
    /* PowerPC 740 v2.2 (G3)                                                 */
7673 80d11f44 j_mayer
    POWERPC_DEF("740_v2.2",      CPU_POWERPC_7x0_v22,                7x0),
7674 a750fc0b j_mayer
    /* PowerPC 750 v2.2 (G3)                                                 */
7675 80d11f44 j_mayer
    POWERPC_DEF("750_v2.2",      CPU_POWERPC_7x0_v22,                7x0),
7676 a750fc0b j_mayer
    /* PowerPC 740 v3.0 (G3)                                                 */
7677 80d11f44 j_mayer
    POWERPC_DEF("740_v3.0",      CPU_POWERPC_7x0_v30,                7x0),
7678 a750fc0b j_mayer
    /* PowerPC 750 v3.0 (G3)                                                 */
7679 80d11f44 j_mayer
    POWERPC_DEF("750_v3.0",      CPU_POWERPC_7x0_v30,                7x0),
7680 a750fc0b j_mayer
    /* PowerPC 740 v3.1 (G3)                                                 */
7681 80d11f44 j_mayer
    POWERPC_DEF("740_v3.1",      CPU_POWERPC_7x0_v31,                7x0),
7682 a750fc0b j_mayer
    /* PowerPC 750 v3.1 (G3)                                                 */
7683 80d11f44 j_mayer
    POWERPC_DEF("750_v3.1",      CPU_POWERPC_7x0_v31,                7x0),
7684 a750fc0b j_mayer
    /* PowerPC 740E (G3)                                                     */
7685 80d11f44 j_mayer
    POWERPC_DEF("740e",          CPU_POWERPC_740E,                   7x0),
7686 a750fc0b j_mayer
    /* PowerPC 740P (G3)                                                     */
7687 80d11f44 j_mayer
    POWERPC_DEF("740p",          CPU_POWERPC_7x0P,                   7x0),
7688 a750fc0b j_mayer
    /* PowerPC 750P (G3)                                                     */
7689 80d11f44 j_mayer
    POWERPC_DEF("750p",          CPU_POWERPC_7x0P,                   7x0),
7690 a750fc0b j_mayer
    /* Code name for PowerPC 740P/750P (G3)                                  */
7691 80d11f44 j_mayer
    POWERPC_DEF("Conan/Doyle",   CPU_POWERPC_7x0P,                   7x0),
7692 a750fc0b j_mayer
    /* PowerPC 750CL (G3 embedded)                                           */
7693 80d11f44 j_mayer
    POWERPC_DEF("750cl",         CPU_POWERPC_750CL,                  7x0),
7694 a750fc0b j_mayer
    /* PowerPC 750CX (G3 embedded)                                           */
7695 80d11f44 j_mayer
    POWERPC_DEF("750cx",         CPU_POWERPC_750CX,                  7x0),
7696 a750fc0b j_mayer
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
7697 80d11f44 j_mayer
    POWERPC_DEF("750cx_v2.1",    CPU_POWERPC_750CX_v21,              7x0),
7698 a750fc0b j_mayer
    /* PowerPC 750CX v2.2 (G3 embedded)                                      */
7699 80d11f44 j_mayer
    POWERPC_DEF("750cx_v2.2",    CPU_POWERPC_750CX_v22,              7x0),
7700 a750fc0b j_mayer
    /* PowerPC 750CXe (G3 embedded)                                          */
7701 80d11f44 j_mayer
    POWERPC_DEF("750cxe",        CPU_POWERPC_750CXE,                 7x0),
7702 a750fc0b j_mayer
    /* PowerPC 750CXe v2.1 (G3 embedded)                                     */
7703 082c6681 j_mayer
    POWERPC_DEF("750cxe_v2.1",   CPU_POWERPC_750CXE_v21,             7x0),
7704 a750fc0b j_mayer
    /* PowerPC 750CXe v2.2 (G3 embedded)                                     */
7705 082c6681 j_mayer
    POWERPC_DEF("750cxe_v2.2",   CPU_POWERPC_750CXE_v22,             7x0),
7706 a750fc0b j_mayer
    /* PowerPC 750CXe v2.3 (G3 embedded)                                     */
7707 082c6681 j_mayer
    POWERPC_DEF("750cxe_v2.3",   CPU_POWERPC_750CXE_v23,             7x0),
7708 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4 (G3 embedded)                                     */
7709 082c6681 j_mayer
    POWERPC_DEF("750cxe_v2.4",   CPU_POWERPC_750CXE_v24,             7x0),
7710 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4b (G3 embedded)                                    */
7711 082c6681 j_mayer
    POWERPC_DEF("750cxe_v2.4b",  CPU_POWERPC_750CXE_v24b,            7x0),
7712 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1 (G3 embedded)                                     */
7713 082c6681 j_mayer
    POWERPC_DEF("750cxe_v3.1",   CPU_POWERPC_750CXE_v31,             7x0),
7714 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1b (G3 embedded)                                    */
7715 80d11f44 j_mayer
    POWERPC_DEF("750cxe_v3.1b",  CPU_POWERPC_750CXE_v31b,            7x0),
7716 a750fc0b j_mayer
    /* PowerPC 750CXr (G3 embedded)                                          */
7717 80d11f44 j_mayer
    POWERPC_DEF("750cxr",        CPU_POWERPC_750CXR,                 7x0),
7718 a750fc0b j_mayer
    /* PowerPC 750E (G3)                                                     */
7719 80d11f44 j_mayer
    POWERPC_DEF("750e",          CPU_POWERPC_750E,                   7x0),
7720 a750fc0b j_mayer
    /* PowerPC 750FL (G3 embedded)                                           */
7721 80d11f44 j_mayer
    POWERPC_DEF("750fl",         CPU_POWERPC_750FL,                  750fx),
7722 a750fc0b j_mayer
    /* PowerPC 750FX (G3 embedded)                                           */
7723 80d11f44 j_mayer
    POWERPC_DEF("750fx",         CPU_POWERPC_750FX,                  750fx),
7724 a750fc0b j_mayer
    /* PowerPC 750FX v1.0 (G3 embedded)                                      */
7725 80d11f44 j_mayer
    POWERPC_DEF("750fx_v1.0",    CPU_POWERPC_750FX_v10,              750fx),
7726 a750fc0b j_mayer
    /* PowerPC 750FX v2.0 (G3 embedded)                                      */
7727 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.0",    CPU_POWERPC_750FX_v20,              750fx),
7728 a750fc0b j_mayer
    /* PowerPC 750FX v2.1 (G3 embedded)                                      */
7729 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.1",    CPU_POWERPC_750FX_v21,              750fx),
7730 a750fc0b j_mayer
    /* PowerPC 750FX v2.2 (G3 embedded)                                      */
7731 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.2",    CPU_POWERPC_750FX_v22,              750fx),
7732 a750fc0b j_mayer
    /* PowerPC 750FX v2.3 (G3 embedded)                                      */
7733 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.3",    CPU_POWERPC_750FX_v23,              750fx),
7734 a750fc0b j_mayer
    /* PowerPC 750GL (G3 embedded)                                           */
7735 80d11f44 j_mayer
    POWERPC_DEF("750gl",         CPU_POWERPC_750GL,                  750fx),
7736 a750fc0b j_mayer
    /* PowerPC 750GX (G3 embedded)                                           */
7737 80d11f44 j_mayer
    POWERPC_DEF("750gx",         CPU_POWERPC_750GX,                  750fx),
7738 a750fc0b j_mayer
    /* PowerPC 750GX v1.0 (G3 embedded)                                      */
7739 80d11f44 j_mayer
    POWERPC_DEF("750gx_v1.0",    CPU_POWERPC_750GX_v10,              750fx),
7740 a750fc0b j_mayer
    /* PowerPC 750GX v1.1 (G3 embedded)                                      */
7741 80d11f44 j_mayer
    POWERPC_DEF("750gx_v1.1",    CPU_POWERPC_750GX_v11,              750fx),
7742 a750fc0b j_mayer
    /* PowerPC 750GX v1.2 (G3 embedded)                                      */
7743 80d11f44 j_mayer
    POWERPC_DEF("750gx_v1.2",    CPU_POWERPC_750GX_v12,              750fx),
7744 a750fc0b j_mayer
    /* PowerPC 750L (G3 embedded)                                            */
7745 80d11f44 j_mayer
    POWERPC_DEF("750l",          CPU_POWERPC_750L,                   7x0),
7746 a750fc0b j_mayer
    /* Code name for PowerPC 750L (G3 embedded)                              */
7747 80d11f44 j_mayer
    POWERPC_DEF("LoneStar",      CPU_POWERPC_750L,                   7x0),
7748 a750fc0b j_mayer
    /* PowerPC 750L v2.2 (G3 embedded)                                       */
7749 80d11f44 j_mayer
    POWERPC_DEF("750l_v2.2",     CPU_POWERPC_750L_v22,               7x0),
7750 a750fc0b j_mayer
    /* PowerPC 750L v3.0 (G3 embedded)                                       */
7751 80d11f44 j_mayer
    POWERPC_DEF("750l_v3.0",     CPU_POWERPC_750L_v30,               7x0),
7752 a750fc0b j_mayer
    /* PowerPC 750L v3.2 (G3 embedded)                                       */
7753 80d11f44 j_mayer
    POWERPC_DEF("750l_v3.2",     CPU_POWERPC_750L_v32,               7x0),
7754 a750fc0b j_mayer
    /* Generic PowerPC 745                                                   */
7755 80d11f44 j_mayer
    POWERPC_DEF("745",           CPU_POWERPC_7x5,                    7x5),
7756 a750fc0b j_mayer
    /* Generic PowerPC 755                                                   */
7757 80d11f44 j_mayer
    POWERPC_DEF("755",           CPU_POWERPC_7x5,                    7x5),
7758 a750fc0b j_mayer
    /* Code name for PowerPC 745/755                                         */
7759 80d11f44 j_mayer
    POWERPC_DEF("Goldfinger",    CPU_POWERPC_7x5,                    7x5),
7760 a750fc0b j_mayer
    /* PowerPC 745 v1.0                                                      */
7761 80d11f44 j_mayer
    POWERPC_DEF("745_v1.0",      CPU_POWERPC_7x5_v10,                7x5),
7762 a750fc0b j_mayer
    /* PowerPC 755 v1.0                                                      */
7763 80d11f44 j_mayer
    POWERPC_DEF("755_v1.0",      CPU_POWERPC_7x5_v10,                7x5),
7764 a750fc0b j_mayer
    /* PowerPC 745 v1.1                                                      */
7765 80d11f44 j_mayer
    POWERPC_DEF("745_v1.1",      CPU_POWERPC_7x5_v11,                7x5),
7766 a750fc0b j_mayer
    /* PowerPC 755 v1.1                                                      */
7767 80d11f44 j_mayer
    POWERPC_DEF("755_v1.1",      CPU_POWERPC_7x5_v11,                7x5),
7768 a750fc0b j_mayer
    /* PowerPC 745 v2.0                                                      */
7769 80d11f44 j_mayer
    POWERPC_DEF("745_v2.0",      CPU_POWERPC_7x5_v20,                7x5),
7770 a750fc0b j_mayer
    /* PowerPC 755 v2.0                                                      */
7771 80d11f44 j_mayer
    POWERPC_DEF("755_v2.0",      CPU_POWERPC_7x5_v20,                7x5),
7772 a750fc0b j_mayer
    /* PowerPC 745 v2.1                                                      */
7773 80d11f44 j_mayer
    POWERPC_DEF("745_v2.1",      CPU_POWERPC_7x5_v21,                7x5),
7774 a750fc0b j_mayer
    /* PowerPC 755 v2.1                                                      */
7775 80d11f44 j_mayer
    POWERPC_DEF("755_v2.1",      CPU_POWERPC_7x5_v21,                7x5),
7776 a750fc0b j_mayer
    /* PowerPC 745 v2.2                                                      */
7777 80d11f44 j_mayer
    POWERPC_DEF("745_v2.2",      CPU_POWERPC_7x5_v22,                7x5),
7778 a750fc0b j_mayer
    /* PowerPC 755 v2.2                                                      */
7779 80d11f44 j_mayer
    POWERPC_DEF("755_v2.2",      CPU_POWERPC_7x5_v22,                7x5),
7780 a750fc0b j_mayer
    /* PowerPC 745 v2.3                                                      */
7781 80d11f44 j_mayer
    POWERPC_DEF("745_v2.3",      CPU_POWERPC_7x5_v23,                7x5),
7782 a750fc0b j_mayer
    /* PowerPC 755 v2.3                                                      */
7783 80d11f44 j_mayer
    POWERPC_DEF("755_v2.3",      CPU_POWERPC_7x5_v23,                7x5),
7784 a750fc0b j_mayer
    /* PowerPC 745 v2.4                                                      */
7785 80d11f44 j_mayer
    POWERPC_DEF("745_v2.4",      CPU_POWERPC_7x5_v24,                7x5),
7786 a750fc0b j_mayer
    /* PowerPC 755 v2.4                                                      */
7787 80d11f44 j_mayer
    POWERPC_DEF("755_v2.4",      CPU_POWERPC_7x5_v24,                7x5),
7788 a750fc0b j_mayer
    /* PowerPC 745 v2.5                                                      */
7789 80d11f44 j_mayer
    POWERPC_DEF("745_v2.5",      CPU_POWERPC_7x5_v25,                7x5),
7790 a750fc0b j_mayer
    /* PowerPC 755 v2.5                                                      */
7791 80d11f44 j_mayer
    POWERPC_DEF("755_v2.5",      CPU_POWERPC_7x5_v25,                7x5),
7792 a750fc0b j_mayer
    /* PowerPC 745 v2.6                                                      */
7793 80d11f44 j_mayer
    POWERPC_DEF("745_v2.6",      CPU_POWERPC_7x5_v26,                7x5),
7794 a750fc0b j_mayer
    /* PowerPC 755 v2.6                                                      */
7795 80d11f44 j_mayer
    POWERPC_DEF("755_v2.6",      CPU_POWERPC_7x5_v26,                7x5),
7796 a750fc0b j_mayer
    /* PowerPC 745 v2.7                                                      */
7797 80d11f44 j_mayer
    POWERPC_DEF("745_v2.7",      CPU_POWERPC_7x5_v27,                7x5),
7798 a750fc0b j_mayer
    /* PowerPC 755 v2.7                                                      */
7799 80d11f44 j_mayer
    POWERPC_DEF("755_v2.7",      CPU_POWERPC_7x5_v27,                7x5),
7800 a750fc0b j_mayer
    /* PowerPC 745 v2.8                                                      */
7801 80d11f44 j_mayer
    POWERPC_DEF("745_v2.8",      CPU_POWERPC_7x5_v28,                7x5),
7802 a750fc0b j_mayer
    /* PowerPC 755 v2.8                                                      */
7803 80d11f44 j_mayer
    POWERPC_DEF("755_v2.8",      CPU_POWERPC_7x5_v28,                7x5),
7804 a750fc0b j_mayer
#if defined (TODO)
7805 a750fc0b j_mayer
    /* PowerPC 745P (G3)                                                     */
7806 80d11f44 j_mayer
    POWERPC_DEF("745p",          CPU_POWERPC_7x5P,                   7x5),
7807 a750fc0b j_mayer
    /* PowerPC 755P (G3)                                                     */
7808 80d11f44 j_mayer
    POWERPC_DEF("755p",          CPU_POWERPC_7x5P,                   7x5),
7809 a750fc0b j_mayer
#endif
7810 a750fc0b j_mayer
    /* PowerPC 74xx family                                                   */
7811 a750fc0b j_mayer
    /* PowerPC 7400 (G4)                                                     */
7812 80d11f44 j_mayer
    POWERPC_DEF("7400",          CPU_POWERPC_7400,                   7400),
7813 a750fc0b j_mayer
    /* Code name for PowerPC 7400                                            */
7814 80d11f44 j_mayer
    POWERPC_DEF("Max",           CPU_POWERPC_7400,                   7400),
7815 a750fc0b j_mayer
    /* PowerPC 74xx is also well known as G4                                 */
7816 80d11f44 j_mayer
    POWERPC_DEF("G4",            CPU_POWERPC_7400,                   7400),
7817 a750fc0b j_mayer
    /* PowerPC 7400 v1.0 (G4)                                                */
7818 80d11f44 j_mayer
    POWERPC_DEF("7400_v1.0",     CPU_POWERPC_7400_v10,               7400),
7819 a750fc0b j_mayer
    /* PowerPC 7400 v1.1 (G4)                                                */
7820 80d11f44 j_mayer
    POWERPC_DEF("7400_v1.1",     CPU_POWERPC_7400_v11,               7400),
7821 a750fc0b j_mayer
    /* PowerPC 7400 v2.0 (G4)                                                */
7822 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.0",     CPU_POWERPC_7400_v20,               7400),
7823 a750fc0b j_mayer
    /* PowerPC 7400 v2.2 (G4)                                                */
7824 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.2",     CPU_POWERPC_7400_v22,               7400),
7825 a750fc0b j_mayer
    /* PowerPC 7400 v2.6 (G4)                                                */
7826 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.6",     CPU_POWERPC_7400_v26,               7400),
7827 a750fc0b j_mayer
    /* PowerPC 7400 v2.7 (G4)                                                */
7828 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.7",     CPU_POWERPC_7400_v27,               7400),
7829 a750fc0b j_mayer
    /* PowerPC 7400 v2.8 (G4)                                                */
7830 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.8",     CPU_POWERPC_7400_v28,               7400),
7831 a750fc0b j_mayer
    /* PowerPC 7400 v2.9 (G4)                                                */
7832 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.9",     CPU_POWERPC_7400_v29,               7400),
7833 a750fc0b j_mayer
    /* PowerPC 7410 (G4)                                                     */
7834 80d11f44 j_mayer
    POWERPC_DEF("7410",          CPU_POWERPC_7410,                   7410),
7835 a750fc0b j_mayer
    /* Code name for PowerPC 7410                                            */
7836 80d11f44 j_mayer
    POWERPC_DEF("Nitro",         CPU_POWERPC_7410,                   7410),
7837 a750fc0b j_mayer
    /* PowerPC 7410 v1.0 (G4)                                                */
7838 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.0",     CPU_POWERPC_7410_v10,               7410),
7839 a750fc0b j_mayer
    /* PowerPC 7410 v1.1 (G4)                                                */
7840 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.1",     CPU_POWERPC_7410_v11,               7410),
7841 a750fc0b j_mayer
    /* PowerPC 7410 v1.2 (G4)                                                */
7842 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.2",     CPU_POWERPC_7410_v12,               7410),
7843 a750fc0b j_mayer
    /* PowerPC 7410 v1.3 (G4)                                                */
7844 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.3",     CPU_POWERPC_7410_v13,               7410),
7845 a750fc0b j_mayer
    /* PowerPC 7410 v1.4 (G4)                                                */
7846 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.4",     CPU_POWERPC_7410_v14,               7410),
7847 a750fc0b j_mayer
    /* PowerPC 7448 (G4)                                                     */
7848 80d11f44 j_mayer
    POWERPC_DEF("7448",          CPU_POWERPC_7448,                   7400),
7849 a750fc0b j_mayer
    /* PowerPC 7448 v1.0 (G4)                                                */
7850 80d11f44 j_mayer
    POWERPC_DEF("7448_v1.0",     CPU_POWERPC_7448_v10,               7400),
7851 a750fc0b j_mayer
    /* PowerPC 7448 v1.1 (G4)                                                */
7852 80d11f44 j_mayer
    POWERPC_DEF("7448_v1.1",     CPU_POWERPC_7448_v11,               7400),
7853 a750fc0b j_mayer
    /* PowerPC 7448 v2.0 (G4)                                                */
7854 80d11f44 j_mayer
    POWERPC_DEF("7448_v2.0",     CPU_POWERPC_7448_v20,               7400),
7855 a750fc0b j_mayer
    /* PowerPC 7448 v2.1 (G4)                                                */
7856 80d11f44 j_mayer
    POWERPC_DEF("7448_v2.1",     CPU_POWERPC_7448_v21,               7400),
7857 a750fc0b j_mayer
    /* PowerPC 7450 (G4)                                                     */
7858 80d11f44 j_mayer
    POWERPC_DEF("7450",          CPU_POWERPC_7450,                   7450),
7859 a750fc0b j_mayer
    /* Code name for PowerPC 7450                                            */
7860 80d11f44 j_mayer
    POWERPC_DEF("Vger",          CPU_POWERPC_7450,                   7450),
7861 a750fc0b j_mayer
    /* PowerPC 7450 v1.0 (G4)                                                */
7862 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.0",     CPU_POWERPC_7450_v10,               7450),
7863 a750fc0b j_mayer
    /* PowerPC 7450 v1.1 (G4)                                                */
7864 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.1",     CPU_POWERPC_7450_v11,               7450),
7865 a750fc0b j_mayer
    /* PowerPC 7450 v1.2 (G4)                                                */
7866 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.2",     CPU_POWERPC_7450_v12,               7450),
7867 a750fc0b j_mayer
    /* PowerPC 7450 v2.0 (G4)                                                */
7868 80d11f44 j_mayer
    POWERPC_DEF("7450_v2.0",     CPU_POWERPC_7450_v20,               7450),
7869 a750fc0b j_mayer
    /* PowerPC 7450 v2.1 (G4)                                                */
7870 80d11f44 j_mayer
    POWERPC_DEF("7450_v2.1",     CPU_POWERPC_7450_v21,               7450),
7871 a750fc0b j_mayer
    /* PowerPC 7441 (G4)                                                     */
7872 80d11f44 j_mayer
    POWERPC_DEF("7441",          CPU_POWERPC_74x1,                   7440),
7873 a750fc0b j_mayer
    /* PowerPC 7451 (G4)                                                     */
7874 80d11f44 j_mayer
    POWERPC_DEF("7451",          CPU_POWERPC_74x1,                   7450),
7875 a750fc0b j_mayer
    /* PowerPC 7441g (G4)                                                    */
7876 80d11f44 j_mayer
    POWERPC_DEF("7441g",         CPU_POWERPC_74x1G,                  7440),
7877 a750fc0b j_mayer
    /* PowerPC 7451g (G4)                                                    */
7878 80d11f44 j_mayer
    POWERPC_DEF("7451g",         CPU_POWERPC_74x1G,                  7450),
7879 a750fc0b j_mayer
    /* PowerPC 7445 (G4)                                                     */
7880 80d11f44 j_mayer
    POWERPC_DEF("7445",          CPU_POWERPC_74x5,                   7445),
7881 a750fc0b j_mayer
    /* PowerPC 7455 (G4)                                                     */
7882 80d11f44 j_mayer
    POWERPC_DEF("7455",          CPU_POWERPC_74x5,                   7455),
7883 a750fc0b j_mayer
    /* Code name for PowerPC 7445/7455                                       */
7884 80d11f44 j_mayer
    POWERPC_DEF("Apollo6",       CPU_POWERPC_74x5,                   7455),
7885 a750fc0b j_mayer
    /* PowerPC 7445 v1.0 (G4)                                                */
7886 80d11f44 j_mayer
    POWERPC_DEF("7445_v1.0",     CPU_POWERPC_74x5_v10,               7445),
7887 a750fc0b j_mayer
    /* PowerPC 7455 v1.0 (G4)                                                */
7888 80d11f44 j_mayer
    POWERPC_DEF("7455_v1.0",     CPU_POWERPC_74x5_v10,               7455),
7889 a750fc0b j_mayer
    /* PowerPC 7445 v2.1 (G4)                                                */
7890 80d11f44 j_mayer
    POWERPC_DEF("7445_v2.1",     CPU_POWERPC_74x5_v21,               7445),
7891 a750fc0b j_mayer
    /* PowerPC 7455 v2.1 (G4)                                                */
7892 80d11f44 j_mayer
    POWERPC_DEF("7455_v2.1",     CPU_POWERPC_74x5_v21,               7455),
7893 a750fc0b j_mayer
    /* PowerPC 7445 v3.2 (G4)                                                */
7894 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.2",     CPU_POWERPC_74x5_v32,               7445),
7895 a750fc0b j_mayer
    /* PowerPC 7455 v3.2 (G4)                                                */
7896 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.2",     CPU_POWERPC_74x5_v32,               7455),
7897 a750fc0b j_mayer
    /* PowerPC 7445 v3.3 (G4)                                                */
7898 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.3",     CPU_POWERPC_74x5_v33,               7445),
7899 a750fc0b j_mayer
    /* PowerPC 7455 v3.3 (G4)                                                */
7900 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.3",     CPU_POWERPC_74x5_v33,               7455),
7901 a750fc0b j_mayer
    /* PowerPC 7445 v3.4 (G4)                                                */
7902 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.4",     CPU_POWERPC_74x5_v34,               7445),
7903 a750fc0b j_mayer
    /* PowerPC 7455 v3.4 (G4)                                                */
7904 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.4",     CPU_POWERPC_74x5_v34,               7455),
7905 a750fc0b j_mayer
    /* PowerPC 7447 (G4)                                                     */
7906 80d11f44 j_mayer
    POWERPC_DEF("7447",          CPU_POWERPC_74x7,                   7445),
7907 a750fc0b j_mayer
    /* PowerPC 7457 (G4)                                                     */
7908 80d11f44 j_mayer
    POWERPC_DEF("7457",          CPU_POWERPC_74x7,                   7455),
7909 a750fc0b j_mayer
    /* Code name for PowerPC 7447/7457                                       */
7910 80d11f44 j_mayer
    POWERPC_DEF("Apollo7",       CPU_POWERPC_74x7,                   7455),
7911 a750fc0b j_mayer
    /* PowerPC 7447 v1.0 (G4)                                                */
7912 80d11f44 j_mayer
    POWERPC_DEF("7447_v1.0",     CPU_POWERPC_74x7_v10,               7445),
7913 a750fc0b j_mayer
    /* PowerPC 7457 v1.0 (G4)                                                */
7914 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.0",     CPU_POWERPC_74x7_v10,               7455),
7915 a750fc0b j_mayer
    /* PowerPC 7447 v1.1 (G4)                                                */
7916 80d11f44 j_mayer
    POWERPC_DEF("7447_v1.1",     CPU_POWERPC_74x7_v11,               7445),
7917 a750fc0b j_mayer
    /* PowerPC 7457 v1.1 (G4)                                                */
7918 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.1",     CPU_POWERPC_74x7_v11,               7455),
7919 a750fc0b j_mayer
    /* PowerPC 7447 v1.2 (G4)                                                */
7920 80d11f44 j_mayer
    POWERPC_DEF("7447_v1.2",     CPU_POWERPC_74x7_v12,               7445),
7921 a750fc0b j_mayer
    /* PowerPC 7457 v1.2 (G4)                                                */
7922 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.2",     CPU_POWERPC_74x7_v12,               7455),
7923 082c6681 j_mayer
    /* PowerPC 7447A (G4)                                                    */
7924 082c6681 j_mayer
    POWERPC_DEF("7447A",         CPU_POWERPC_74x7A,                  7445),
7925 082c6681 j_mayer
    /* PowerPC 7457A (G4)                                                    */
7926 082c6681 j_mayer
    POWERPC_DEF("7457A",         CPU_POWERPC_74x7A,                  7455),
7927 082c6681 j_mayer
    /* PowerPC 7447A v1.0 (G4)                                               */
7928 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.0",    CPU_POWERPC_74x7A_v10,              7445),
7929 082c6681 j_mayer
    /* PowerPC 7457A v1.0 (G4)                                               */
7930 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.0",    CPU_POWERPC_74x7A_v10,              7455),
7931 082c6681 j_mayer
    /* Code name for PowerPC 7447A/7457A                                     */
7932 082c6681 j_mayer
    POWERPC_DEF("Apollo7PM",     CPU_POWERPC_74x7A_v10,              7455),
7933 082c6681 j_mayer
    /* PowerPC 7447A v1.1 (G4)                                               */
7934 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.1",    CPU_POWERPC_74x7A_v11,              7445),
7935 082c6681 j_mayer
    /* PowerPC 7457A v1.1 (G4)                                               */
7936 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.1",    CPU_POWERPC_74x7A_v11,              7455),
7937 082c6681 j_mayer
    /* PowerPC 7447A v1.2 (G4)                                               */
7938 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.2",    CPU_POWERPC_74x7A_v12,              7445),
7939 082c6681 j_mayer
    /* PowerPC 7457A v1.2 (G4)                                               */
7940 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.2",    CPU_POWERPC_74x7A_v12,              7455),
7941 a750fc0b j_mayer
    /* 64 bits PowerPC                                                       */
7942 a750fc0b j_mayer
#if defined (TARGET_PPC64)
7943 a750fc0b j_mayer
    /* PowerPC 620                                                           */
7944 80d11f44 j_mayer
    POWERPC_DEF("620",           CPU_POWERPC_620,                    620),
7945 082c6681 j_mayer
    /* Code name for PowerPC 620                                             */
7946 082c6681 j_mayer
    POWERPC_DEF("Trident",       CPU_POWERPC_620,                    620),
7947 3fc6c082 bellard
#if defined (TODO)
7948 a750fc0b j_mayer
    /* PowerPC 630 (POWER3)                                                  */
7949 80d11f44 j_mayer
    POWERPC_DEF("630",           CPU_POWERPC_630,                    630),
7950 80d11f44 j_mayer
    POWERPC_DEF("POWER3",        CPU_POWERPC_630,                    630),
7951 082c6681 j_mayer
    /* Code names for POWER3                                                 */
7952 082c6681 j_mayer
    POWERPC_DEF("Boxer",         CPU_POWERPC_630,                    630),
7953 082c6681 j_mayer
    POWERPC_DEF("Dino",          CPU_POWERPC_630,                    630),
7954 a750fc0b j_mayer
#endif
7955 3a607854 j_mayer
#if defined (TODO)
7956 a750fc0b j_mayer
    /* PowerPC 631 (Power 3+)                                                */
7957 80d11f44 j_mayer
    POWERPC_DEF("631",           CPU_POWERPC_631,                    631),
7958 80d11f44 j_mayer
    POWERPC_DEF("POWER3+",       CPU_POWERPC_631,                    631),
7959 3a607854 j_mayer
#endif
7960 3a607854 j_mayer
#if defined (TODO)
7961 a750fc0b j_mayer
    /* POWER4                                                                */
7962 80d11f44 j_mayer
    POWERPC_DEF("POWER4",        CPU_POWERPC_POWER4,                 POWER4),
7963 a750fc0b j_mayer
#endif
7964 3a607854 j_mayer
#if defined (TODO)
7965 a750fc0b j_mayer
    /* POWER4p                                                               */
7966 80d11f44 j_mayer
    POWERPC_DEF("POWER4+",       CPU_POWERPC_POWER4P,                POWER4P),
7967 a750fc0b j_mayer
#endif
7968 3a607854 j_mayer
#if defined (TODO)
7969 a750fc0b j_mayer
    /* POWER5                                                                */
7970 80d11f44 j_mayer
    POWERPC_DEF("POWER5",        CPU_POWERPC_POWER5,                 POWER5),
7971 a750fc0b j_mayer
    /* POWER5GR                                                              */
7972 80d11f44 j_mayer
    POWERPC_DEF("POWER5gr",      CPU_POWERPC_POWER5GR,               POWER5),
7973 2662a059 j_mayer
#endif
7974 2662a059 j_mayer
#if defined (TODO)
7975 a750fc0b j_mayer
    /* POWER5+                                                               */
7976 80d11f44 j_mayer
    POWERPC_DEF("POWER5+",       CPU_POWERPC_POWER5P,                POWER5P),
7977 a750fc0b j_mayer
    /* POWER5GS                                                              */
7978 80d11f44 j_mayer
    POWERPC_DEF("POWER5gs",      CPU_POWERPC_POWER5GS,               POWER5P),
7979 a750fc0b j_mayer
#endif
7980 2662a059 j_mayer
#if defined (TODO)
7981 a750fc0b j_mayer
    /* POWER6                                                                */
7982 80d11f44 j_mayer
    POWERPC_DEF("POWER6",        CPU_POWERPC_POWER6,                 POWER6),
7983 a750fc0b j_mayer
    /* POWER6 running in POWER5 mode                                         */
7984 80d11f44 j_mayer
    POWERPC_DEF("POWER6_5",      CPU_POWERPC_POWER6_5,               POWER5),
7985 a750fc0b j_mayer
    /* POWER6A                                                               */
7986 80d11f44 j_mayer
    POWERPC_DEF("POWER6A",       CPU_POWERPC_POWER6A,                POWER6),
7987 2662a059 j_mayer
#endif
7988 a750fc0b j_mayer
    /* PowerPC 970                                                           */
7989 80d11f44 j_mayer
    POWERPC_DEF("970",           CPU_POWERPC_970,                    970),
7990 a750fc0b j_mayer
    /* PowerPC 970FX (G5)                                                    */
7991 80d11f44 j_mayer
    POWERPC_DEF("970fx",         CPU_POWERPC_970FX,                  970FX),
7992 a750fc0b j_mayer
    /* PowerPC 970FX v1.0 (G5)                                               */
7993 80d11f44 j_mayer
    POWERPC_DEF("970fx_v1.0",    CPU_POWERPC_970FX_v10,              970FX),
7994 a750fc0b j_mayer
    /* PowerPC 970FX v2.0 (G5)                                               */
7995 80d11f44 j_mayer
    POWERPC_DEF("970fx_v2.0",    CPU_POWERPC_970FX_v20,              970FX),
7996 a750fc0b j_mayer
    /* PowerPC 970FX v2.1 (G5)                                               */
7997 80d11f44 j_mayer
    POWERPC_DEF("970fx_v2.1",    CPU_POWERPC_970FX_v21,              970FX),
7998 a750fc0b j_mayer
    /* PowerPC 970FX v3.0 (G5)                                               */
7999 80d11f44 j_mayer
    POWERPC_DEF("970fx_v3.0",    CPU_POWERPC_970FX_v30,              970FX),
8000 a750fc0b j_mayer
    /* PowerPC 970FX v3.1 (G5)                                               */
8001 80d11f44 j_mayer
    POWERPC_DEF("970fx_v3.1",    CPU_POWERPC_970FX_v31,              970FX),
8002 a750fc0b j_mayer
    /* PowerPC 970GX (G5)                                                    */
8003 80d11f44 j_mayer
    POWERPC_DEF("970gx",         CPU_POWERPC_970GX,                  970GX),
8004 a750fc0b j_mayer
    /* PowerPC 970MP                                                         */
8005 80d11f44 j_mayer
    POWERPC_DEF("970mp",         CPU_POWERPC_970MP,                  970MP),
8006 a750fc0b j_mayer
    /* PowerPC 970MP v1.0                                                    */
8007 80d11f44 j_mayer
    POWERPC_DEF("970mp_v1.0",    CPU_POWERPC_970MP_v10,              970MP),
8008 a750fc0b j_mayer
    /* PowerPC 970MP v1.1                                                    */
8009 80d11f44 j_mayer
    POWERPC_DEF("970mp_v1.1",    CPU_POWERPC_970MP_v11,              970MP),
8010 3a607854 j_mayer
#if defined (TODO)
8011 a750fc0b j_mayer
    /* PowerPC Cell                                                          */
8012 80d11f44 j_mayer
    POWERPC_DEF("Cell",          CPU_POWERPC_CELL,                   970),
8013 2662a059 j_mayer
#endif
8014 2662a059 j_mayer
#if defined (TODO)
8015 a750fc0b j_mayer
    /* PowerPC Cell v1.0                                                     */
8016 80d11f44 j_mayer
    POWERPC_DEF("Cell_v1.0",     CPU_POWERPC_CELL_v10,               970),
8017 2662a059 j_mayer
#endif
8018 2662a059 j_mayer
#if defined (TODO)
8019 a750fc0b j_mayer
    /* PowerPC Cell v2.0                                                     */
8020 80d11f44 j_mayer
    POWERPC_DEF("Cell_v2.0",     CPU_POWERPC_CELL_v20,               970),
8021 2662a059 j_mayer
#endif
8022 2662a059 j_mayer
#if defined (TODO)
8023 a750fc0b j_mayer
    /* PowerPC Cell v3.0                                                     */
8024 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.0",     CPU_POWERPC_CELL_v30,               970),
8025 3a607854 j_mayer
#endif
8026 3a607854 j_mayer
#if defined (TODO)
8027 a750fc0b j_mayer
    /* PowerPC Cell v3.1                                                     */
8028 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.1",     CPU_POWERPC_CELL_v31,               970),
8029 2662a059 j_mayer
#endif
8030 2662a059 j_mayer
#if defined (TODO)
8031 a750fc0b j_mayer
    /* PowerPC Cell v3.2                                                     */
8032 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.2",     CPU_POWERPC_CELL_v32,               970),
8033 2662a059 j_mayer
#endif
8034 2662a059 j_mayer
#if defined (TODO)
8035 a750fc0b j_mayer
    /* RS64 (Apache/A35)                                                     */
8036 a750fc0b j_mayer
    /* This one seems to support the whole POWER2 instruction set
8037 a750fc0b j_mayer
     * and the PowerPC 64 one.
8038 a750fc0b j_mayer
     */
8039 a750fc0b j_mayer
    /* What about A10 & A30 ? */
8040 80d11f44 j_mayer
    POWERPC_DEF("RS64",          CPU_POWERPC_RS64,                   RS64),
8041 80d11f44 j_mayer
    POWERPC_DEF("Apache",        CPU_POWERPC_RS64,                   RS64),
8042 80d11f44 j_mayer
    POWERPC_DEF("A35",           CPU_POWERPC_RS64,                   RS64),
8043 3a607854 j_mayer
#endif
8044 3a607854 j_mayer
#if defined (TODO)
8045 a750fc0b j_mayer
    /* RS64-II (NorthStar/A50)                                               */
8046 80d11f44 j_mayer
    POWERPC_DEF("RS64-II",       CPU_POWERPC_RS64II,                 RS64),
8047 80d11f44 j_mayer
    POWERPC_DEF("NorthStar",     CPU_POWERPC_RS64II,                 RS64),
8048 80d11f44 j_mayer
    POWERPC_DEF("A50",           CPU_POWERPC_RS64II,                 RS64),
8049 3a607854 j_mayer
#endif
8050 3a607854 j_mayer
#if defined (TODO)
8051 a750fc0b j_mayer
    /* RS64-III (Pulsar)                                                     */
8052 80d11f44 j_mayer
    POWERPC_DEF("RS64-III",      CPU_POWERPC_RS64III,                RS64),
8053 80d11f44 j_mayer
    POWERPC_DEF("Pulsar",        CPU_POWERPC_RS64III,                RS64),
8054 2662a059 j_mayer
#endif
8055 2662a059 j_mayer
#if defined (TODO)
8056 a750fc0b j_mayer
    /* RS64-IV (IceStar/IStar/SStar)                                         */
8057 80d11f44 j_mayer
    POWERPC_DEF("RS64-IV",       CPU_POWERPC_RS64IV,                 RS64),
8058 80d11f44 j_mayer
    POWERPC_DEF("IceStar",       CPU_POWERPC_RS64IV,                 RS64),
8059 80d11f44 j_mayer
    POWERPC_DEF("IStar",         CPU_POWERPC_RS64IV,                 RS64),
8060 80d11f44 j_mayer
    POWERPC_DEF("SStar",         CPU_POWERPC_RS64IV,                 RS64),
8061 3a607854 j_mayer
#endif
8062 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
8063 a750fc0b j_mayer
    /* POWER                                                                 */
8064 3fc6c082 bellard
#if defined (TODO)
8065 a750fc0b j_mayer
    /* Original POWER                                                        */
8066 80d11f44 j_mayer
    POWERPC_DEF("POWER",         CPU_POWERPC_POWER,                  POWER),
8067 80d11f44 j_mayer
    POWERPC_DEF("RIOS",          CPU_POWERPC_POWER,                  POWER),
8068 80d11f44 j_mayer
    POWERPC_DEF("RSC",           CPU_POWERPC_POWER,                  POWER),
8069 80d11f44 j_mayer
    POWERPC_DEF("RSC3308",       CPU_POWERPC_POWER,                  POWER),
8070 80d11f44 j_mayer
    POWERPC_DEF("RSC4608",       CPU_POWERPC_POWER,                  POWER),
8071 76a66253 j_mayer
#endif
8072 76a66253 j_mayer
#if defined (TODO)
8073 a750fc0b j_mayer
    /* POWER2                                                                */
8074 80d11f44 j_mayer
    POWERPC_DEF("POWER2",        CPU_POWERPC_POWER2,                 POWER),
8075 80d11f44 j_mayer
    POWERPC_DEF("RSC2",          CPU_POWERPC_POWER2,                 POWER),
8076 80d11f44 j_mayer
    POWERPC_DEF("P2SC",          CPU_POWERPC_POWER2,                 POWER),
8077 a750fc0b j_mayer
#endif
8078 a750fc0b j_mayer
    /* PA semi cores                                                         */
8079 a750fc0b j_mayer
#if defined (TODO)
8080 a750fc0b j_mayer
    /* PA PA6T */
8081 80d11f44 j_mayer
    POWERPC_DEF("PA6T",          CPU_POWERPC_PA6T,                   PA6T),
8082 a750fc0b j_mayer
#endif
8083 a750fc0b j_mayer
    /* Generic PowerPCs                                                      */
8084 a750fc0b j_mayer
#if defined (TARGET_PPC64)
8085 80d11f44 j_mayer
    POWERPC_DEF("ppc64",         CPU_POWERPC_PPC64,                  PPC64),
8086 a750fc0b j_mayer
#endif
8087 80d11f44 j_mayer
    POWERPC_DEF("ppc32",         CPU_POWERPC_PPC32,                  PPC32),
8088 80d11f44 j_mayer
    POWERPC_DEF("ppc",           CPU_POWERPC_DEFAULT,                DEFAULT),
8089 a750fc0b j_mayer
    /* Fallback                                                              */
8090 80d11f44 j_mayer
    POWERPC_DEF("default",       CPU_POWERPC_DEFAULT,                DEFAULT),
8091 a750fc0b j_mayer
};
8092 a750fc0b j_mayer
8093 a750fc0b j_mayer
/*****************************************************************************/
8094 a750fc0b j_mayer
/* Generic CPU instanciation routine                                         */
8095 aaed909a bellard
static void init_ppc_proc (CPUPPCState *env, const ppc_def_t *def)
8096 a750fc0b j_mayer
{
8097 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
8098 e1833e1f j_mayer
    int i;
8099 e1833e1f j_mayer
8100 a750fc0b j_mayer
    env->irq_inputs = NULL;
8101 e1833e1f j_mayer
    /* Set all exception vectors to an invalid address */
8102 e1833e1f j_mayer
    for (i = 0; i < POWERPC_EXCP_NB; i++)
8103 e1833e1f j_mayer
        env->excp_vectors[i] = (target_ulong)(-1ULL);
8104 e1833e1f j_mayer
    env->excp_prefix = 0x00000000;
8105 e1833e1f j_mayer
    env->ivor_mask = 0x00000000;
8106 e1833e1f j_mayer
    env->ivpr_mask = 0x00000000;
8107 a750fc0b j_mayer
    /* Default MMU definitions */
8108 a750fc0b j_mayer
    env->nb_BATs = 0;
8109 a750fc0b j_mayer
    env->nb_tlb = 0;
8110 a750fc0b j_mayer
    env->nb_ways = 0;
8111 f2e63a42 j_mayer
#endif
8112 a750fc0b j_mayer
    /* Register SPR common to all PowerPC implementations */
8113 a750fc0b j_mayer
    gen_spr_generic(env);
8114 a750fc0b j_mayer
    spr_register(env, SPR_PVR, "PVR",
8115 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
8116 a750fc0b j_mayer
                 &spr_read_generic, SPR_NOACCESS,
8117 a750fc0b j_mayer
                 def->pvr);
8118 80d11f44 j_mayer
    /* Register SVR if it's defined to anything else than POWERPC_SVR_NONE */
8119 80d11f44 j_mayer
    if (def->svr != POWERPC_SVR_NONE) {
8120 80d11f44 j_mayer
        if (def->svr & POWERPC_SVR_E500) {
8121 80d11f44 j_mayer
            spr_register(env, SPR_E500_SVR, "SVR",
8122 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
8123 80d11f44 j_mayer
                         &spr_read_generic, SPR_NOACCESS,
8124 80d11f44 j_mayer
                         def->svr & ~POWERPC_SVR_E500);
8125 80d11f44 j_mayer
        } else {
8126 80d11f44 j_mayer
            spr_register(env, SPR_SVR, "SVR",
8127 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
8128 80d11f44 j_mayer
                         &spr_read_generic, SPR_NOACCESS,
8129 80d11f44 j_mayer
                         def->svr);
8130 80d11f44 j_mayer
        }
8131 80d11f44 j_mayer
    }
8132 a750fc0b j_mayer
    /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
8133 a750fc0b j_mayer
    (*def->init_proc)(env);
8134 25ba3a68 j_mayer
    /* MSR bits & flags consistency checks */
8135 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 25)) {
8136 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
8137 25ba3a68 j_mayer
        case POWERPC_FLAG_SPE:
8138 25ba3a68 j_mayer
        case POWERPC_FLAG_VRE:
8139 25ba3a68 j_mayer
            break;
8140 25ba3a68 j_mayer
        default:
8141 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8142 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SPE or POWERPC_FLAG_VRE\n");
8143 25ba3a68 j_mayer
            exit(1);
8144 25ba3a68 j_mayer
        }
8145 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
8146 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8147 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SPE nor POWERPC_FLAG_VRE\n");
8148 25ba3a68 j_mayer
        exit(1);
8149 25ba3a68 j_mayer
    }
8150 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 17)) {
8151 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
8152 25ba3a68 j_mayer
        case POWERPC_FLAG_TGPR:
8153 25ba3a68 j_mayer
        case POWERPC_FLAG_CE:
8154 25ba3a68 j_mayer
            break;
8155 25ba3a68 j_mayer
        default:
8156 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8157 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_TGPR or POWERPC_FLAG_CE\n");
8158 25ba3a68 j_mayer
            exit(1);
8159 25ba3a68 j_mayer
        }
8160 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
8161 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8162 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_TGPR nor POWERPC_FLAG_CE\n");
8163 25ba3a68 j_mayer
        exit(1);
8164 25ba3a68 j_mayer
    }
8165 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 10)) {
8166 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
8167 25ba3a68 j_mayer
                              POWERPC_FLAG_UBLE)) {
8168 25ba3a68 j_mayer
        case POWERPC_FLAG_SE:
8169 25ba3a68 j_mayer
        case POWERPC_FLAG_DWE:
8170 25ba3a68 j_mayer
        case POWERPC_FLAG_UBLE:
8171 25ba3a68 j_mayer
            break;
8172 25ba3a68 j_mayer
        default:
8173 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8174 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SE or POWERPC_FLAG_DWE or "
8175 25ba3a68 j_mayer
                    "POWERPC_FLAG_UBLE\n");
8176 25ba3a68 j_mayer
            exit(1);
8177 25ba3a68 j_mayer
        }
8178 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
8179 25ba3a68 j_mayer
                             POWERPC_FLAG_UBLE)) {
8180 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8181 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SE nor POWERPC_FLAG_DWE nor "
8182 25ba3a68 j_mayer
                "POWERPC_FLAG_UBLE\n");
8183 25ba3a68 j_mayer
            exit(1);
8184 25ba3a68 j_mayer
    }
8185 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 9)) {
8186 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
8187 25ba3a68 j_mayer
        case POWERPC_FLAG_BE:
8188 25ba3a68 j_mayer
        case POWERPC_FLAG_DE:
8189 25ba3a68 j_mayer
            break;
8190 25ba3a68 j_mayer
        default:
8191 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8192 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_BE or POWERPC_FLAG_DE\n");
8193 25ba3a68 j_mayer
            exit(1);
8194 25ba3a68 j_mayer
        }
8195 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
8196 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8197 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_BE nor POWERPC_FLAG_DE\n");
8198 25ba3a68 j_mayer
        exit(1);
8199 25ba3a68 j_mayer
    }
8200 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 2)) {
8201 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
8202 25ba3a68 j_mayer
        case POWERPC_FLAG_PX:
8203 25ba3a68 j_mayer
        case POWERPC_FLAG_PMM:
8204 25ba3a68 j_mayer
            break;
8205 25ba3a68 j_mayer
        default:
8206 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8207 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_PX or POWERPC_FLAG_PMM\n");
8208 25ba3a68 j_mayer
            exit(1);
8209 25ba3a68 j_mayer
        }
8210 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
8211 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
8212 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_PX nor POWERPC_FLAG_PMM\n");
8213 25ba3a68 j_mayer
        exit(1);
8214 25ba3a68 j_mayer
    }
8215 4018bae9 j_mayer
    if ((env->flags & (POWERPC_FLAG_RTC_CLK | POWERPC_FLAG_BUS_CLK)) == 0) {
8216 4018bae9 j_mayer
        fprintf(stderr, "PowerPC flags inconsistency\n"
8217 4018bae9 j_mayer
                "Should define the time-base and decrementer clock source\n");
8218 4018bae9 j_mayer
        exit(1);
8219 4018bae9 j_mayer
    }
8220 a750fc0b j_mayer
    /* Allocate TLBs buffer when needed */
8221 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
8222 a750fc0b j_mayer
    if (env->nb_tlb != 0) {
8223 a750fc0b j_mayer
        int nb_tlb = env->nb_tlb;
8224 a750fc0b j_mayer
        if (env->id_tlbs != 0)
8225 a750fc0b j_mayer
            nb_tlb *= 2;
8226 a750fc0b j_mayer
        env->tlb = qemu_mallocz(nb_tlb * sizeof(ppc_tlb_t));
8227 a750fc0b j_mayer
        /* Pre-compute some useful values */
8228 a750fc0b j_mayer
        env->tlb_per_way = env->nb_tlb / env->nb_ways;
8229 a750fc0b j_mayer
    }
8230 a750fc0b j_mayer
    if (env->irq_inputs == NULL) {
8231 a750fc0b j_mayer
        fprintf(stderr, "WARNING: no internal IRQ controller registered.\n"
8232 a750fc0b j_mayer
                " Attempt Qemu to crash very soon !\n");
8233 a750fc0b j_mayer
    }
8234 a750fc0b j_mayer
#endif
8235 2f462816 j_mayer
    if (env->check_pow == NULL) {
8236 2f462816 j_mayer
        fprintf(stderr, "WARNING: no power management check handler "
8237 2f462816 j_mayer
                "registered.\n"
8238 2f462816 j_mayer
                " Attempt Qemu to crash very soon !\n");
8239 2f462816 j_mayer
    }
8240 a750fc0b j_mayer
}
8241 a750fc0b j_mayer
8242 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
8243 a750fc0b j_mayer
static void dump_ppc_sprs (CPUPPCState *env)
8244 a750fc0b j_mayer
{
8245 a750fc0b j_mayer
    ppc_spr_t *spr;
8246 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
8247 a750fc0b j_mayer
    uint32_t sr, sw;
8248 a750fc0b j_mayer
#endif
8249 a750fc0b j_mayer
    uint32_t ur, uw;
8250 a750fc0b j_mayer
    int i, j, n;
8251 a750fc0b j_mayer
8252 a750fc0b j_mayer
    printf("Special purpose registers:\n");
8253 a750fc0b j_mayer
    for (i = 0; i < 32; i++) {
8254 a750fc0b j_mayer
        for (j = 0; j < 32; j++) {
8255 a750fc0b j_mayer
            n = (i << 5) | j;
8256 a750fc0b j_mayer
            spr = &env->spr_cb[n];
8257 a750fc0b j_mayer
            uw = spr->uea_write != NULL && spr->uea_write != SPR_NOACCESS;
8258 a750fc0b j_mayer
            ur = spr->uea_read != NULL && spr->uea_read != SPR_NOACCESS;
8259 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
8260 a750fc0b j_mayer
            sw = spr->oea_write != NULL && spr->oea_write != SPR_NOACCESS;
8261 a750fc0b j_mayer
            sr = spr->oea_read != NULL && spr->oea_read != SPR_NOACCESS;
8262 a750fc0b j_mayer
            if (sw || sr || uw || ur) {
8263 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
8264 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
8265 a750fc0b j_mayer
                       sw ? 'w' : '-', sr ? 'r' : '-',
8266 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
8267 a750fc0b j_mayer
            }
8268 a750fc0b j_mayer
#else
8269 a750fc0b j_mayer
            if (uw || ur) {
8270 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s u%c%c\n",
8271 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
8272 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
8273 a750fc0b j_mayer
            }
8274 a750fc0b j_mayer
#endif
8275 a750fc0b j_mayer
        }
8276 a750fc0b j_mayer
    }
8277 a750fc0b j_mayer
    fflush(stdout);
8278 a750fc0b j_mayer
    fflush(stderr);
8279 a750fc0b j_mayer
}
8280 a750fc0b j_mayer
#endif
8281 a750fc0b j_mayer
8282 a750fc0b j_mayer
/*****************************************************************************/
8283 a750fc0b j_mayer
#include <stdlib.h>
8284 a750fc0b j_mayer
#include <string.h>
8285 a750fc0b j_mayer
8286 a750fc0b j_mayer
int fflush (FILE *stream);
8287 a750fc0b j_mayer
8288 a750fc0b j_mayer
/* Opcode types */
8289 a750fc0b j_mayer
enum {
8290 a750fc0b j_mayer
    PPC_DIRECT   = 0, /* Opcode routine        */
8291 a750fc0b j_mayer
    PPC_INDIRECT = 1, /* Indirect opcode table */
8292 a750fc0b j_mayer
};
8293 a750fc0b j_mayer
8294 a750fc0b j_mayer
static inline int is_indirect_opcode (void *handler)
8295 a750fc0b j_mayer
{
8296 a750fc0b j_mayer
    return ((unsigned long)handler & 0x03) == PPC_INDIRECT;
8297 a750fc0b j_mayer
}
8298 a750fc0b j_mayer
8299 a750fc0b j_mayer
static inline opc_handler_t **ind_table(void *handler)
8300 a750fc0b j_mayer
{
8301 a750fc0b j_mayer
    return (opc_handler_t **)((unsigned long)handler & ~3);
8302 a750fc0b j_mayer
}
8303 a750fc0b j_mayer
8304 a750fc0b j_mayer
/* Instruction table creation */
8305 a750fc0b j_mayer
/* Opcodes tables creation */
8306 a750fc0b j_mayer
static void fill_new_table (opc_handler_t **table, int len)
8307 a750fc0b j_mayer
{
8308 a750fc0b j_mayer
    int i;
8309 a750fc0b j_mayer
8310 a750fc0b j_mayer
    for (i = 0; i < len; i++)
8311 a750fc0b j_mayer
        table[i] = &invalid_handler;
8312 a750fc0b j_mayer
}
8313 a750fc0b j_mayer
8314 a750fc0b j_mayer
static int create_new_table (opc_handler_t **table, unsigned char idx)
8315 a750fc0b j_mayer
{
8316 a750fc0b j_mayer
    opc_handler_t **tmp;
8317 a750fc0b j_mayer
8318 a750fc0b j_mayer
    tmp = malloc(0x20 * sizeof(opc_handler_t));
8319 a750fc0b j_mayer
    if (tmp == NULL)
8320 a750fc0b j_mayer
        return -1;
8321 a750fc0b j_mayer
    fill_new_table(tmp, 0x20);
8322 a750fc0b j_mayer
    table[idx] = (opc_handler_t *)((unsigned long)tmp | PPC_INDIRECT);
8323 a750fc0b j_mayer
8324 a750fc0b j_mayer
    return 0;
8325 a750fc0b j_mayer
}
8326 a750fc0b j_mayer
8327 a750fc0b j_mayer
static int insert_in_table (opc_handler_t **table, unsigned char idx,
8328 a750fc0b j_mayer
                            opc_handler_t *handler)
8329 a750fc0b j_mayer
{
8330 a750fc0b j_mayer
    if (table[idx] != &invalid_handler)
8331 a750fc0b j_mayer
        return -1;
8332 a750fc0b j_mayer
    table[idx] = handler;
8333 a750fc0b j_mayer
8334 a750fc0b j_mayer
    return 0;
8335 a750fc0b j_mayer
}
8336 a750fc0b j_mayer
8337 a750fc0b j_mayer
static int register_direct_insn (opc_handler_t **ppc_opcodes,
8338 a750fc0b j_mayer
                                 unsigned char idx, opc_handler_t *handler)
8339 a750fc0b j_mayer
{
8340 a750fc0b j_mayer
    if (insert_in_table(ppc_opcodes, idx, handler) < 0) {
8341 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in main "
8342 a750fc0b j_mayer
               "opcode table\n", idx);
8343 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
8344 4c1b1bfe j_mayer
        printf("           Registered handler '%s' - new handler '%s'\n",
8345 4c1b1bfe j_mayer
               ppc_opcodes[idx]->oname, handler->oname);
8346 4c1b1bfe j_mayer
#endif
8347 a750fc0b j_mayer
        return -1;
8348 a750fc0b j_mayer
    }
8349 a750fc0b j_mayer
8350 a750fc0b j_mayer
    return 0;
8351 a750fc0b j_mayer
}
8352 a750fc0b j_mayer
8353 a750fc0b j_mayer
static int register_ind_in_table (opc_handler_t **table,
8354 a750fc0b j_mayer
                                  unsigned char idx1, unsigned char idx2,
8355 a750fc0b j_mayer
                                  opc_handler_t *handler)
8356 a750fc0b j_mayer
{
8357 a750fc0b j_mayer
    if (table[idx1] == &invalid_handler) {
8358 a750fc0b j_mayer
        if (create_new_table(table, idx1) < 0) {
8359 a750fc0b j_mayer
            printf("*** ERROR: unable to create indirect table "
8360 a750fc0b j_mayer
                   "idx=%02x\n", idx1);
8361 a750fc0b j_mayer
            return -1;
8362 a750fc0b j_mayer
        }
8363 a750fc0b j_mayer
    } else {
8364 a750fc0b j_mayer
        if (!is_indirect_opcode(table[idx1])) {
8365 a750fc0b j_mayer
            printf("*** ERROR: idx %02x already assigned to a direct "
8366 a750fc0b j_mayer
                   "opcode\n", idx1);
8367 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
8368 4c1b1bfe j_mayer
            printf("           Registered handler '%s' - new handler '%s'\n",
8369 4c1b1bfe j_mayer
                   ind_table(table[idx1])[idx2]->oname, handler->oname);
8370 4c1b1bfe j_mayer
#endif
8371 a750fc0b j_mayer
            return -1;
8372 a750fc0b j_mayer
        }
8373 3a607854 j_mayer
    }
8374 a750fc0b j_mayer
    if (handler != NULL &&
8375 a750fc0b j_mayer
        insert_in_table(ind_table(table[idx1]), idx2, handler) < 0) {
8376 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in "
8377 a750fc0b j_mayer
               "opcode table %02x\n", idx2, idx1);
8378 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
8379 4c1b1bfe j_mayer
        printf("           Registered handler '%s' - new handler '%s'\n",
8380 4c1b1bfe j_mayer
               ind_table(table[idx1])[idx2]->oname, handler->oname);
8381 4c1b1bfe j_mayer
#endif
8382 a750fc0b j_mayer
        return -1;
8383 3a607854 j_mayer
    }
8384 a750fc0b j_mayer
8385 a750fc0b j_mayer
    return 0;
8386 a750fc0b j_mayer
}
8387 a750fc0b j_mayer
8388 a750fc0b j_mayer
static int register_ind_insn (opc_handler_t **ppc_opcodes,
8389 a750fc0b j_mayer
                              unsigned char idx1, unsigned char idx2,
8390 a750fc0b j_mayer
                              opc_handler_t *handler)
8391 a750fc0b j_mayer
{
8392 a750fc0b j_mayer
    int ret;
8393 a750fc0b j_mayer
8394 a750fc0b j_mayer
    ret = register_ind_in_table(ppc_opcodes, idx1, idx2, handler);
8395 a750fc0b j_mayer
8396 a750fc0b j_mayer
    return ret;
8397 a750fc0b j_mayer
}
8398 a750fc0b j_mayer
8399 a750fc0b j_mayer
static int register_dblind_insn (opc_handler_t **ppc_opcodes,
8400 a750fc0b j_mayer
                                 unsigned char idx1, unsigned char idx2,
8401 a750fc0b j_mayer
                                 unsigned char idx3, opc_handler_t *handler)
8402 a750fc0b j_mayer
{
8403 a750fc0b j_mayer
    if (register_ind_in_table(ppc_opcodes, idx1, idx2, NULL) < 0) {
8404 a750fc0b j_mayer
        printf("*** ERROR: unable to join indirect table idx "
8405 a750fc0b j_mayer
               "[%02x-%02x]\n", idx1, idx2);
8406 a750fc0b j_mayer
        return -1;
8407 a750fc0b j_mayer
    }
8408 a750fc0b j_mayer
    if (register_ind_in_table(ind_table(ppc_opcodes[idx1]), idx2, idx3,
8409 a750fc0b j_mayer
                              handler) < 0) {
8410 a750fc0b j_mayer
        printf("*** ERROR: unable to insert opcode "
8411 a750fc0b j_mayer
               "[%02x-%02x-%02x]\n", idx1, idx2, idx3);
8412 a750fc0b j_mayer
        return -1;
8413 a750fc0b j_mayer
    }
8414 a750fc0b j_mayer
8415 a750fc0b j_mayer
    return 0;
8416 a750fc0b j_mayer
}
8417 a750fc0b j_mayer
8418 a750fc0b j_mayer
static int register_insn (opc_handler_t **ppc_opcodes, opcode_t *insn)
8419 a750fc0b j_mayer
{
8420 a750fc0b j_mayer
    if (insn->opc2 != 0xFF) {
8421 a750fc0b j_mayer
        if (insn->opc3 != 0xFF) {
8422 a750fc0b j_mayer
            if (register_dblind_insn(ppc_opcodes, insn->opc1, insn->opc2,
8423 a750fc0b j_mayer
                                     insn->opc3, &insn->handler) < 0)
8424 a750fc0b j_mayer
                return -1;
8425 a750fc0b j_mayer
        } else {
8426 a750fc0b j_mayer
            if (register_ind_insn(ppc_opcodes, insn->opc1,
8427 a750fc0b j_mayer
                                  insn->opc2, &insn->handler) < 0)
8428 a750fc0b j_mayer
                return -1;
8429 a750fc0b j_mayer
        }
8430 a750fc0b j_mayer
    } else {
8431 a750fc0b j_mayer
        if (register_direct_insn(ppc_opcodes, insn->opc1, &insn->handler) < 0)
8432 a750fc0b j_mayer
            return -1;
8433 a750fc0b j_mayer
    }
8434 a750fc0b j_mayer
8435 a750fc0b j_mayer
    return 0;
8436 a750fc0b j_mayer
}
8437 a750fc0b j_mayer
8438 a750fc0b j_mayer
static int test_opcode_table (opc_handler_t **table, int len)
8439 a750fc0b j_mayer
{
8440 a750fc0b j_mayer
    int i, count, tmp;
8441 a750fc0b j_mayer
8442 a750fc0b j_mayer
    for (i = 0, count = 0; i < len; i++) {
8443 a750fc0b j_mayer
        /* Consistency fixup */
8444 a750fc0b j_mayer
        if (table[i] == NULL)
8445 a750fc0b j_mayer
            table[i] = &invalid_handler;
8446 a750fc0b j_mayer
        if (table[i] != &invalid_handler) {
8447 a750fc0b j_mayer
            if (is_indirect_opcode(table[i])) {
8448 a750fc0b j_mayer
                tmp = test_opcode_table(ind_table(table[i]), 0x20);
8449 a750fc0b j_mayer
                if (tmp == 0) {
8450 a750fc0b j_mayer
                    free(table[i]);
8451 a750fc0b j_mayer
                    table[i] = &invalid_handler;
8452 a750fc0b j_mayer
                } else {
8453 a750fc0b j_mayer
                    count++;
8454 a750fc0b j_mayer
                }
8455 a750fc0b j_mayer
            } else {
8456 a750fc0b j_mayer
                count++;
8457 a750fc0b j_mayer
            }
8458 a750fc0b j_mayer
        }
8459 a750fc0b j_mayer
    }
8460 a750fc0b j_mayer
8461 a750fc0b j_mayer
    return count;
8462 a750fc0b j_mayer
}
8463 a750fc0b j_mayer
8464 a750fc0b j_mayer
static void fix_opcode_tables (opc_handler_t **ppc_opcodes)
8465 a750fc0b j_mayer
{
8466 a750fc0b j_mayer
    if (test_opcode_table(ppc_opcodes, 0x40) == 0)
8467 a750fc0b j_mayer
        printf("*** WARNING: no opcode defined !\n");
8468 a750fc0b j_mayer
}
8469 a750fc0b j_mayer
8470 a750fc0b j_mayer
/*****************************************************************************/
8471 aaed909a bellard
static int create_ppc_opcodes (CPUPPCState *env, const ppc_def_t *def)
8472 a750fc0b j_mayer
{
8473 a750fc0b j_mayer
    opcode_t *opc, *start, *end;
8474 a750fc0b j_mayer
8475 a750fc0b j_mayer
    fill_new_table(env->opcodes, 0x40);
8476 a750fc0b j_mayer
    if (&opc_start < &opc_end) {
8477 a750fc0b j_mayer
        start = &opc_start;
8478 a750fc0b j_mayer
        end = &opc_end;
8479 a750fc0b j_mayer
    } else {
8480 a750fc0b j_mayer
        start = &opc_end;
8481 a750fc0b j_mayer
        end = &opc_start;
8482 a750fc0b j_mayer
    }
8483 a750fc0b j_mayer
    for (opc = start + 1; opc != end; opc++) {
8484 a750fc0b j_mayer
        if ((opc->handler.type & def->insns_flags) != 0) {
8485 a750fc0b j_mayer
            if (register_insn(env->opcodes, opc) < 0) {
8486 a750fc0b j_mayer
                printf("*** ERROR initializing PowerPC instruction "
8487 a750fc0b j_mayer
                       "0x%02x 0x%02x 0x%02x\n", opc->opc1, opc->opc2,
8488 a750fc0b j_mayer
                       opc->opc3);
8489 a750fc0b j_mayer
                return -1;
8490 a750fc0b j_mayer
            }
8491 a750fc0b j_mayer
        }
8492 a750fc0b j_mayer
    }
8493 a750fc0b j_mayer
    fix_opcode_tables(env->opcodes);
8494 a750fc0b j_mayer
    fflush(stdout);
8495 a750fc0b j_mayer
    fflush(stderr);
8496 a750fc0b j_mayer
8497 a750fc0b j_mayer
    return 0;
8498 a750fc0b j_mayer
}
8499 a750fc0b j_mayer
8500 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
8501 25ba3a68 j_mayer
static void dump_ppc_insns (CPUPPCState *env)
8502 a750fc0b j_mayer
{
8503 a750fc0b j_mayer
    opc_handler_t **table, *handler;
8504 4c1b1bfe j_mayer
    const unsigned char *p, *q;
8505 a750fc0b j_mayer
    uint8_t opc1, opc2, opc3;
8506 a750fc0b j_mayer
8507 a750fc0b j_mayer
    printf("Instructions set:\n");
8508 a750fc0b j_mayer
    /* opc1 is 6 bits long */
8509 a750fc0b j_mayer
    for (opc1 = 0x00; opc1 < 0x40; opc1++) {
8510 a750fc0b j_mayer
        table = env->opcodes;
8511 a750fc0b j_mayer
        handler = table[opc1];
8512 a750fc0b j_mayer
        if (is_indirect_opcode(handler)) {
8513 a750fc0b j_mayer
            /* opc2 is 5 bits long */
8514 a750fc0b j_mayer
            for (opc2 = 0; opc2 < 0x20; opc2++) {
8515 a750fc0b j_mayer
                table = env->opcodes;
8516 a750fc0b j_mayer
                handler = env->opcodes[opc1];
8517 a750fc0b j_mayer
                table = ind_table(handler);
8518 a750fc0b j_mayer
                handler = table[opc2];
8519 a750fc0b j_mayer
                if (is_indirect_opcode(handler)) {
8520 a750fc0b j_mayer
                    table = ind_table(handler);
8521 a750fc0b j_mayer
                    /* opc3 is 5 bits long */
8522 a750fc0b j_mayer
                    for (opc3 = 0; opc3 < 0x20; opc3++) {
8523 a750fc0b j_mayer
                        handler = table[opc3];
8524 a750fc0b j_mayer
                        if (handler->handler != &gen_invalid) {
8525 4c1b1bfe j_mayer
                            /* Special hack to properly dump SPE insns */
8526 4c1b1bfe j_mayer
                            p = strchr(handler->oname, '_');
8527 4c1b1bfe j_mayer
                            if (p == NULL) {
8528 4c1b1bfe j_mayer
                                printf("INSN: %02x %02x %02x (%02d %04d) : "
8529 4c1b1bfe j_mayer
                                       "%s\n",
8530 4c1b1bfe j_mayer
                                       opc1, opc2, opc3, opc1,
8531 4c1b1bfe j_mayer
                                       (opc3 << 5) | opc2,
8532 4c1b1bfe j_mayer
                                       handler->oname);
8533 4c1b1bfe j_mayer
                            } else {
8534 4c1b1bfe j_mayer
                                q = "speundef";
8535 4c1b1bfe j_mayer
                                if ((p - handler->oname) != strlen(q) ||
8536 4c1b1bfe j_mayer
                                    memcmp(handler->oname, q, strlen(q)) != 0) {
8537 4c1b1bfe j_mayer
                                    /* First instruction */
8538 4c1b1bfe j_mayer
                                    printf("INSN: %02x %02x %02x (%02d %04d) : "
8539 4c1b1bfe j_mayer
                                           "%.*s\n",
8540 4c1b1bfe j_mayer
                                           opc1, opc2 << 1, opc3, opc1,
8541 4c1b1bfe j_mayer
                                           (opc3 << 6) | (opc2 << 1),
8542 4c1b1bfe j_mayer
                                           (int)(p - handler->oname),
8543 4c1b1bfe j_mayer
                                           handler->oname);
8544 4c1b1bfe j_mayer
                                }
8545 4c1b1bfe j_mayer
                                if (strcmp(p + 1, q) != 0) {
8546 4c1b1bfe j_mayer
                                    /* Second instruction */
8547 4c1b1bfe j_mayer
                                    printf("INSN: %02x %02x %02x (%02d %04d) : "
8548 4c1b1bfe j_mayer
                                           "%s\n",
8549 4c1b1bfe j_mayer
                                           opc1, (opc2 << 1) | 1, opc3, opc1,
8550 4c1b1bfe j_mayer
                                           (opc3 << 6) | (opc2 << 1) | 1,
8551 4c1b1bfe j_mayer
                                           p + 1);
8552 4c1b1bfe j_mayer
                                }
8553 4c1b1bfe j_mayer
                            }
8554 a750fc0b j_mayer
                        }
8555 a750fc0b j_mayer
                    }
8556 a750fc0b j_mayer
                } else {
8557 a750fc0b j_mayer
                    if (handler->handler != &gen_invalid) {
8558 a750fc0b j_mayer
                        printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
8559 a750fc0b j_mayer
                               opc1, opc2, opc1, opc2, handler->oname);
8560 a750fc0b j_mayer
                    }
8561 a750fc0b j_mayer
                }
8562 a750fc0b j_mayer
            }
8563 a750fc0b j_mayer
        } else {
8564 a750fc0b j_mayer
            if (handler->handler != &gen_invalid) {
8565 a750fc0b j_mayer
                printf("INSN: %02x -- -- (%02d ----) : %s\n",
8566 a750fc0b j_mayer
                       opc1, opc1, handler->oname);
8567 a750fc0b j_mayer
            }
8568 a750fc0b j_mayer
        }
8569 a750fc0b j_mayer
    }
8570 a750fc0b j_mayer
}
8571 3a607854 j_mayer
#endif
8572 a750fc0b j_mayer
8573 aaed909a bellard
int cpu_ppc_register_internal (CPUPPCState *env, const ppc_def_t *def)
8574 a750fc0b j_mayer
{
8575 a750fc0b j_mayer
    env->msr_mask = def->msr_mask;
8576 a750fc0b j_mayer
    env->mmu_model = def->mmu_model;
8577 a750fc0b j_mayer
    env->excp_model = def->excp_model;
8578 a750fc0b j_mayer
    env->bus_model = def->bus_model;
8579 d26bfc9a j_mayer
    env->flags = def->flags;
8580 237c0af0 j_mayer
    env->bfd_mach = def->bfd_mach;
8581 2f462816 j_mayer
    env->check_pow = def->check_pow;
8582 a750fc0b j_mayer
    if (create_ppc_opcodes(env, def) < 0)
8583 a750fc0b j_mayer
        return -1;
8584 a750fc0b j_mayer
    init_ppc_proc(env, def);
8585 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
8586 3a607854 j_mayer
    {
8587 a750fc0b j_mayer
        const unsigned char *mmu_model, *excp_model, *bus_model;
8588 a750fc0b j_mayer
        switch (env->mmu_model) {
8589 a750fc0b j_mayer
        case POWERPC_MMU_32B:
8590 a750fc0b j_mayer
            mmu_model = "PowerPC 32";
8591 a750fc0b j_mayer
            break;
8592 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_6xx:
8593 a750fc0b j_mayer
            mmu_model = "PowerPC 6xx/7xx with software driven TLBs";
8594 a750fc0b j_mayer
            break;
8595 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_74xx:
8596 a750fc0b j_mayer
            mmu_model = "PowerPC 74xx with software driven TLBs";
8597 a750fc0b j_mayer
            break;
8598 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx:
8599 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs";
8600 a750fc0b j_mayer
            break;
8601 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx_Z:
8602 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs "
8603 a750fc0b j_mayer
                "and zones protections";
8604 a750fc0b j_mayer
            break;
8605 b4095fed j_mayer
        case POWERPC_MMU_REAL:
8606 b4095fed j_mayer
            mmu_model = "PowerPC real mode only";
8607 b4095fed j_mayer
            break;
8608 b4095fed j_mayer
        case POWERPC_MMU_MPC8xx:
8609 b4095fed j_mayer
            mmu_model = "PowerPC MPC8xx";
8610 a750fc0b j_mayer
            break;
8611 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE:
8612 a750fc0b j_mayer
            mmu_model = "PowerPC BookE";
8613 a750fc0b j_mayer
            break;
8614 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE_FSL:
8615 a750fc0b j_mayer
            mmu_model = "PowerPC BookE FSL";
8616 a750fc0b j_mayer
            break;
8617 b4095fed j_mayer
        case POWERPC_MMU_601:
8618 b4095fed j_mayer
            mmu_model = "PowerPC 601";
8619 b4095fed j_mayer
            break;
8620 00af685f j_mayer
#if defined (TARGET_PPC64)
8621 00af685f j_mayer
        case POWERPC_MMU_64B:
8622 00af685f j_mayer
            mmu_model = "PowerPC 64";
8623 00af685f j_mayer
            break;
8624 add78955 j_mayer
        case POWERPC_MMU_620:
8625 add78955 j_mayer
            mmu_model = "PowerPC 620";
8626 add78955 j_mayer
            break;
8627 00af685f j_mayer
#endif
8628 a750fc0b j_mayer
        default:
8629 a750fc0b j_mayer
            mmu_model = "Unknown or invalid";
8630 a750fc0b j_mayer
            break;
8631 a750fc0b j_mayer
        }
8632 a750fc0b j_mayer
        switch (env->excp_model) {
8633 a750fc0b j_mayer
        case POWERPC_EXCP_STD:
8634 a750fc0b j_mayer
            excp_model = "PowerPC";
8635 a750fc0b j_mayer
            break;
8636 a750fc0b j_mayer
        case POWERPC_EXCP_40x:
8637 a750fc0b j_mayer
            excp_model = "PowerPC 40x";
8638 a750fc0b j_mayer
            break;
8639 a750fc0b j_mayer
        case POWERPC_EXCP_601:
8640 a750fc0b j_mayer
            excp_model = "PowerPC 601";
8641 a750fc0b j_mayer
            break;
8642 a750fc0b j_mayer
        case POWERPC_EXCP_602:
8643 a750fc0b j_mayer
            excp_model = "PowerPC 602";
8644 a750fc0b j_mayer
            break;
8645 a750fc0b j_mayer
        case POWERPC_EXCP_603:
8646 a750fc0b j_mayer
            excp_model = "PowerPC 603";
8647 a750fc0b j_mayer
            break;
8648 a750fc0b j_mayer
        case POWERPC_EXCP_603E:
8649 a750fc0b j_mayer
            excp_model = "PowerPC 603e";
8650 a750fc0b j_mayer
            break;
8651 a750fc0b j_mayer
        case POWERPC_EXCP_604:
8652 a750fc0b j_mayer
            excp_model = "PowerPC 604";
8653 a750fc0b j_mayer
            break;
8654 a750fc0b j_mayer
        case POWERPC_EXCP_7x0:
8655 a750fc0b j_mayer
            excp_model = "PowerPC 740/750";
8656 a750fc0b j_mayer
            break;
8657 a750fc0b j_mayer
        case POWERPC_EXCP_7x5:
8658 a750fc0b j_mayer
            excp_model = "PowerPC 745/755";
8659 a750fc0b j_mayer
            break;
8660 a750fc0b j_mayer
        case POWERPC_EXCP_74xx:
8661 a750fc0b j_mayer
            excp_model = "PowerPC 74xx";
8662 a750fc0b j_mayer
            break;
8663 a750fc0b j_mayer
        case POWERPC_EXCP_BOOKE:
8664 a750fc0b j_mayer
            excp_model = "PowerPC BookE";
8665 a750fc0b j_mayer
            break;
8666 00af685f j_mayer
#if defined (TARGET_PPC64)
8667 00af685f j_mayer
        case POWERPC_EXCP_970:
8668 00af685f j_mayer
            excp_model = "PowerPC 970";
8669 00af685f j_mayer
            break;
8670 00af685f j_mayer
#endif
8671 a750fc0b j_mayer
        default:
8672 a750fc0b j_mayer
            excp_model = "Unknown or invalid";
8673 a750fc0b j_mayer
            break;
8674 a750fc0b j_mayer
        }
8675 a750fc0b j_mayer
        switch (env->bus_model) {
8676 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_6xx:
8677 a750fc0b j_mayer
            bus_model = "PowerPC 6xx";
8678 a750fc0b j_mayer
            break;
8679 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_BookE:
8680 a750fc0b j_mayer
            bus_model = "PowerPC BookE";
8681 a750fc0b j_mayer
            break;
8682 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_405:
8683 a750fc0b j_mayer
            bus_model = "PowerPC 405";
8684 a750fc0b j_mayer
            break;
8685 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_401:
8686 a750fc0b j_mayer
            bus_model = "PowerPC 401/403";
8687 a750fc0b j_mayer
            break;
8688 b4095fed j_mayer
        case PPC_FLAGS_INPUT_RCPU:
8689 b4095fed j_mayer
            bus_model = "RCPU / MPC8xx";
8690 b4095fed j_mayer
            break;
8691 00af685f j_mayer
#if defined (TARGET_PPC64)
8692 00af685f j_mayer
        case PPC_FLAGS_INPUT_970:
8693 00af685f j_mayer
            bus_model = "PowerPC 970";
8694 00af685f j_mayer
            break;
8695 00af685f j_mayer
#endif
8696 a750fc0b j_mayer
        default:
8697 a750fc0b j_mayer
            bus_model = "Unknown or invalid";
8698 a750fc0b j_mayer
            break;
8699 a750fc0b j_mayer
        }
8700 a750fc0b j_mayer
        printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64 "\n"
8701 a750fc0b j_mayer
               "    MMU model        : %s\n",
8702 a750fc0b j_mayer
               def->name, def->pvr, def->msr_mask, mmu_model);
8703 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
8704 a750fc0b j_mayer
        if (env->tlb != NULL) {
8705 a750fc0b j_mayer
            printf("                       %d %s TLB in %d ways\n",
8706 a750fc0b j_mayer
                   env->nb_tlb, env->id_tlbs ? "splitted" : "merged",
8707 a750fc0b j_mayer
                   env->nb_ways);
8708 a750fc0b j_mayer
        }
8709 f2e63a42 j_mayer
#endif
8710 a750fc0b j_mayer
        printf("    Exceptions model : %s\n"
8711 a750fc0b j_mayer
               "    Bus model        : %s\n",
8712 a750fc0b j_mayer
               excp_model, bus_model);
8713 25ba3a68 j_mayer
        printf("    MSR features     :\n");
8714 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SPE)
8715 25ba3a68 j_mayer
            printf("                        signal processing engine enable"
8716 25ba3a68 j_mayer
                   "\n");
8717 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_VRE)
8718 25ba3a68 j_mayer
            printf("                        vector processor enable\n");
8719 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_TGPR)
8720 25ba3a68 j_mayer
            printf("                        temporary GPRs\n");
8721 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_CE)
8722 25ba3a68 j_mayer
            printf("                        critical input enable\n");
8723 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SE)
8724 25ba3a68 j_mayer
            printf("                        single-step trace mode\n");
8725 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DWE)
8726 25ba3a68 j_mayer
            printf("                        debug wait enable\n");
8727 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_UBLE)
8728 25ba3a68 j_mayer
            printf("                        user BTB lock enable\n");
8729 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_BE)
8730 25ba3a68 j_mayer
            printf("                        branch-step trace mode\n");
8731 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DE)
8732 25ba3a68 j_mayer
            printf("                        debug interrupt enable\n");
8733 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_PX)
8734 25ba3a68 j_mayer
            printf("                        inclusive protection\n");
8735 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_PMM)
8736 25ba3a68 j_mayer
            printf("                        performance monitor mark\n");
8737 25ba3a68 j_mayer
        if (env->flags == POWERPC_FLAG_NONE)
8738 25ba3a68 j_mayer
            printf("                        none\n");
8739 4018bae9 j_mayer
        printf("    Time-base/decrementer clock source: %s\n",
8740 4018bae9 j_mayer
               env->flags & POWERPC_FLAG_RTC_CLK ? "RTC clock" : "bus clock");
8741 a750fc0b j_mayer
    }
8742 a750fc0b j_mayer
    dump_ppc_insns(env);
8743 a750fc0b j_mayer
    dump_ppc_sprs(env);
8744 a750fc0b j_mayer
    fflush(stdout);
8745 3a607854 j_mayer
#endif
8746 a750fc0b j_mayer
8747 a750fc0b j_mayer
    return 0;
8748 a750fc0b j_mayer
}
8749 3fc6c082 bellard
8750 ee4e83ed j_mayer
static const ppc_def_t *ppc_find_by_pvr (uint32_t pvr)
8751 3fc6c082 bellard
{
8752 ee4e83ed j_mayer
    const ppc_def_t *ret;
8753 ee4e83ed j_mayer
    uint32_t pvr_rev;
8754 ee4e83ed j_mayer
    int i, best, match, best_match, max;
8755 3fc6c082 bellard
8756 ee4e83ed j_mayer
    ret = NULL;
8757 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
8758 ee4e83ed j_mayer
    best = -1;
8759 ee4e83ed j_mayer
    pvr_rev = pvr & 0xFFFF;
8760 ee4e83ed j_mayer
    /* We want all specified bits to match */
8761 ee4e83ed j_mayer
    best_match = 32 - ctz32(pvr_rev);
8762 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
8763 ee4e83ed j_mayer
        /* We check that the 16 higher bits are the same to ensure the CPU
8764 ee4e83ed j_mayer
         * model will be the choosen one.
8765 ee4e83ed j_mayer
         */
8766 ee4e83ed j_mayer
        if (((pvr ^ ppc_defs[i].pvr) >> 16) == 0) {
8767 ee4e83ed j_mayer
            /* We want as much as possible of the low-level 16 bits
8768 ee4e83ed j_mayer
             * to be the same but we allow inexact matches.
8769 ee4e83ed j_mayer
             */
8770 ee4e83ed j_mayer
            match = clz32(pvr_rev ^ (ppc_defs[i].pvr & 0xFFFF));
8771 ee4e83ed j_mayer
            /* We check '>=' instead of '>' because the PPC_defs table
8772 ee4e83ed j_mayer
             * is ordered by increasing revision.
8773 4c1b1bfe j_mayer
             * Then, we will match the higher revision compatible
8774 ee4e83ed j_mayer
             * with the requested PVR
8775 ee4e83ed j_mayer
             */
8776 ee4e83ed j_mayer
            if (match >= best_match) {
8777 ee4e83ed j_mayer
                best = i;
8778 ee4e83ed j_mayer
                best_match = match;
8779 ee4e83ed j_mayer
            }
8780 3fc6c082 bellard
        }
8781 3fc6c082 bellard
    }
8782 ee4e83ed j_mayer
    if (best != -1)
8783 ee4e83ed j_mayer
        ret = &ppc_defs[best];
8784 ee4e83ed j_mayer
8785 ee4e83ed j_mayer
    return ret;
8786 3fc6c082 bellard
}
8787 3fc6c082 bellard
8788 ee4e83ed j_mayer
#include <ctype.h>
8789 3fc6c082 bellard
8790 ee4e83ed j_mayer
const ppc_def_t *cpu_ppc_find_by_name (const unsigned char *name)
8791 ee4e83ed j_mayer
{
8792 ee4e83ed j_mayer
    const ppc_def_t *ret;
8793 ee4e83ed j_mayer
    const unsigned char *p;
8794 ee4e83ed j_mayer
    int i, max, len;
8795 ee4e83ed j_mayer
8796 ee4e83ed j_mayer
    /* Check if the given name is a PVR */
8797 ee4e83ed j_mayer
    len = strlen(name);
8798 ee4e83ed j_mayer
    if (len == 10 && name[0] == '0' && name[1] == 'x') {
8799 ee4e83ed j_mayer
        p = name + 2;
8800 ee4e83ed j_mayer
        goto check_pvr;
8801 ee4e83ed j_mayer
    } else if (len == 8) {
8802 ee4e83ed j_mayer
        p = name;
8803 ee4e83ed j_mayer
    check_pvr:
8804 ee4e83ed j_mayer
        for (i = 0; i < 8; i++) {
8805 ee4e83ed j_mayer
            if (!isxdigit(*p++))
8806 ee4e83ed j_mayer
                break;
8807 ee4e83ed j_mayer
        }
8808 ee4e83ed j_mayer
        if (i == 8)
8809 ee4e83ed j_mayer
            return ppc_find_by_pvr(strtoul(name, NULL, 16));
8810 ee4e83ed j_mayer
    }
8811 ee4e83ed j_mayer
    ret = NULL;
8812 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
8813 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
8814 ee4e83ed j_mayer
        if (strcasecmp(name, ppc_defs[i].name) == 0) {
8815 ee4e83ed j_mayer
            ret = &ppc_defs[i];
8816 ee4e83ed j_mayer
            break;
8817 3fc6c082 bellard
        }
8818 3fc6c082 bellard
    }
8819 ee4e83ed j_mayer
8820 ee4e83ed j_mayer
    return ret;
8821 3fc6c082 bellard
}
8822 3fc6c082 bellard
8823 3fc6c082 bellard
void ppc_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...))
8824 3fc6c082 bellard
{
8825 068abdc8 j_mayer
    int i, max;
8826 3fc6c082 bellard
8827 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
8828 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
8829 a750fc0b j_mayer
        (*cpu_fprintf)(f, "PowerPC %-16s PVR %08x\n",
8830 a750fc0b j_mayer
                       ppc_defs[i].name, ppc_defs[i].pvr);
8831 3fc6c082 bellard
    }
8832 3fc6c082 bellard
}