Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ b881c2c6

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