Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ c3e36823

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