Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ 9c7e37e7

History | View | Annotate | Download (257.3 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 a750fc0b j_mayer
    /* e200 family */
4754 a750fc0b j_mayer
#define CPU_POWERPC_e200      CPU_POWERPC_e200z6
4755 a750fc0b j_mayer
#if 0
4756 a750fc0b j_mayer
    CPU_POWERPC_e200z0      = xxx,
4757 a750fc0b j_mayer
#endif
4758 a750fc0b j_mayer
#if 0
4759 a750fc0b j_mayer
    CPU_POWERPC_e200z3      = xxx,
4760 a750fc0b j_mayer
#endif
4761 a750fc0b j_mayer
    CPU_POWERPC_e200z5      = 0x81000000,
4762 a750fc0b j_mayer
    CPU_POWERPC_e200z6      = 0x81120000,
4763 a750fc0b j_mayer
    /* e300 family */
4764 a750fc0b j_mayer
#define CPU_POWERPC_e300      CPU_POWERPC_e300c3
4765 a750fc0b j_mayer
    CPU_POWERPC_e300c1      = 0x00830000,
4766 a750fc0b j_mayer
    CPU_POWERPC_e300c2      = 0x00840000,
4767 a750fc0b j_mayer
    CPU_POWERPC_e300c3      = 0x00850000,
4768 a750fc0b j_mayer
    /* e500 family */
4769 a750fc0b j_mayer
#define CPU_POWERPC_e500      CPU_POWERPC_e500_v22
4770 a750fc0b j_mayer
    CPU_POWERPC_e500_v11    = 0x80200010,
4771 a750fc0b j_mayer
    CPU_POWERPC_e500_v12    = 0x80200020,
4772 a750fc0b j_mayer
    CPU_POWERPC_e500_v21    = 0x80210010,
4773 a750fc0b j_mayer
    CPU_POWERPC_e500_v22    = 0x80210020,
4774 a750fc0b j_mayer
#if 0
4775 a750fc0b j_mayer
    CPU_POWERPC_e500mc      = xxx,
4776 a750fc0b j_mayer
#endif
4777 a750fc0b j_mayer
    /* e600 family */
4778 a750fc0b j_mayer
    CPU_POWERPC_e600        = 0x80040010,
4779 a750fc0b j_mayer
    /* PowerPC MPC 5xx cores */
4780 a750fc0b j_mayer
    CPU_POWERPC_5xx         = 0x00020020,
4781 a750fc0b j_mayer
    /* PowerPC MPC 8xx cores (aka PowerQUICC) */
4782 a750fc0b j_mayer
    CPU_POWERPC_8xx         = 0x00500000,
4783 a750fc0b j_mayer
    /* PowerPC MPC 8xxx cores (aka PowerQUICC-II) */
4784 a750fc0b j_mayer
    CPU_POWERPC_82xx_HIP3   = 0x00810101,
4785 a750fc0b j_mayer
    CPU_POWERPC_82xx_HIP4   = 0x80811014,
4786 a750fc0b j_mayer
    CPU_POWERPC_827x        = 0x80822013,
4787 a750fc0b j_mayer
    /* PowerPC 6xx cores */
4788 a750fc0b j_mayer
    CPU_POWERPC_601         = 0x00010001,
4789 a750fc0b j_mayer
    CPU_POWERPC_601a        = 0x00010002,
4790 a750fc0b j_mayer
    CPU_POWERPC_602         = 0x00050100,
4791 a750fc0b j_mayer
    CPU_POWERPC_603         = 0x00030100,
4792 a750fc0b j_mayer
#define CPU_POWERPC_603E      CPU_POWERPC_603E_v41
4793 a750fc0b j_mayer
    CPU_POWERPC_603E_v11    = 0x00060101,
4794 a750fc0b j_mayer
    CPU_POWERPC_603E_v12    = 0x00060102,
4795 a750fc0b j_mayer
    CPU_POWERPC_603E_v13    = 0x00060103,
4796 a750fc0b j_mayer
    CPU_POWERPC_603E_v14    = 0x00060104,
4797 a750fc0b j_mayer
    CPU_POWERPC_603E_v22    = 0x00060202,
4798 a750fc0b j_mayer
    CPU_POWERPC_603E_v3     = 0x00060300,
4799 a750fc0b j_mayer
    CPU_POWERPC_603E_v4     = 0x00060400,
4800 a750fc0b j_mayer
    CPU_POWERPC_603E_v41    = 0x00060401,
4801 a750fc0b j_mayer
    CPU_POWERPC_603E7t      = 0x00071201,
4802 a750fc0b j_mayer
    CPU_POWERPC_603E7v      = 0x00070100,
4803 a750fc0b j_mayer
    CPU_POWERPC_603E7v1     = 0x00070101,
4804 a750fc0b j_mayer
    CPU_POWERPC_603E7v2     = 0x00070201,
4805 a750fc0b j_mayer
    CPU_POWERPC_603E7       = 0x00070200,
4806 a750fc0b j_mayer
    CPU_POWERPC_603P        = 0x00070000,
4807 a750fc0b j_mayer
#define CPU_POWERPC_603R      CPU_POWERPC_603E7t
4808 a750fc0b j_mayer
    CPU_POWERPC_G2          = 0x00810011,
4809 a750fc0b j_mayer
#if 0 // Linux pretends the MSB is zero...
4810 a750fc0b j_mayer
    CPU_POWERPC_G2H4        = 0x80811010,
4811 a750fc0b j_mayer
    CPU_POWERPC_G2gp        = 0x80821010,
4812 a750fc0b j_mayer
    CPU_POWERPC_G2ls        = 0x90810010,
4813 a750fc0b j_mayer
    CPU_POWERPC_G2LE        = 0x80820010,
4814 a750fc0b j_mayer
    CPU_POWERPC_G2LEgp      = 0x80822010,
4815 a750fc0b j_mayer
    CPU_POWERPC_G2LEls      = 0xA0822010,
4816 a750fc0b j_mayer
#else
4817 a750fc0b j_mayer
    CPU_POWERPC_G2H4        = 0x00811010,
4818 a750fc0b j_mayer
    CPU_POWERPC_G2gp        = 0x00821010,
4819 a750fc0b j_mayer
    CPU_POWERPC_G2ls        = 0x10810010,
4820 a750fc0b j_mayer
    CPU_POWERPC_G2LE        = 0x00820010,
4821 a750fc0b j_mayer
    CPU_POWERPC_G2LEgp      = 0x00822010,
4822 a750fc0b j_mayer
    CPU_POWERPC_G2LEls      = 0x20822010,
4823 a750fc0b j_mayer
#endif
4824 a750fc0b j_mayer
    CPU_POWERPC_604         = 0x00040103,
4825 a750fc0b j_mayer
#define CPU_POWERPC_604E      CPU_POWERPC_604E_v24
4826 a750fc0b j_mayer
    CPU_POWERPC_604E_v10    = 0x00090100, /* Also 2110 & 2120 */
4827 a750fc0b j_mayer
    CPU_POWERPC_604E_v22    = 0x00090202,
4828 a750fc0b j_mayer
    CPU_POWERPC_604E_v24    = 0x00090204,
4829 a750fc0b j_mayer
    CPU_POWERPC_604R        = 0x000a0101, /* Also 0x00093102 */
4830 a750fc0b j_mayer
#if 0
4831 a750fc0b j_mayer
    CPU_POWERPC_604EV       = xxx,
4832 a750fc0b j_mayer
#endif
4833 a750fc0b j_mayer
    /* PowerPC 740/750 cores (aka G3) */
4834 a750fc0b j_mayer
    /* XXX: missing 0x00084202 */
4835 a750fc0b j_mayer
#define CPU_POWERPC_7x0       CPU_POWERPC_7x0_v31
4836 a750fc0b j_mayer
    CPU_POWERPC_7x0_v20     = 0x00080200,
4837 a750fc0b j_mayer
    CPU_POWERPC_7x0_v21     = 0x00080201,
4838 a750fc0b j_mayer
    CPU_POWERPC_7x0_v22     = 0x00080202,
4839 a750fc0b j_mayer
    CPU_POWERPC_7x0_v30     = 0x00080300,
4840 a750fc0b j_mayer
    CPU_POWERPC_7x0_v31     = 0x00080301,
4841 a750fc0b j_mayer
    CPU_POWERPC_740E        = 0x00080100,
4842 a750fc0b j_mayer
    CPU_POWERPC_7x0P        = 0x10080000,
4843 a750fc0b j_mayer
    /* XXX: missing 0x00087010 (CL ?) */
4844 a750fc0b j_mayer
    CPU_POWERPC_750CL       = 0x00087200,
4845 a750fc0b j_mayer
#define CPU_POWERPC_750CX     CPU_POWERPC_750CX_v22
4846 a750fc0b j_mayer
    CPU_POWERPC_750CX_v21   = 0x00082201,
4847 a750fc0b j_mayer
    CPU_POWERPC_750CX_v22   = 0x00082202,
4848 a750fc0b j_mayer
#define CPU_POWERPC_750CXE    CPU_POWERPC_750CXE_v31b
4849 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v21  = 0x00082211,
4850 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v22  = 0x00082212,
4851 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v23  = 0x00082213,
4852 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v24  = 0x00082214,
4853 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v24b = 0x00083214,
4854 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v31  = 0x00083211,
4855 a750fc0b j_mayer
    CPU_POWERPC_750CXE_v31b = 0x00083311,
4856 a750fc0b j_mayer
    CPU_POWERPC_750CXR      = 0x00083410,
4857 a750fc0b j_mayer
    CPU_POWERPC_750E        = 0x00080200,
4858 a750fc0b j_mayer
    CPU_POWERPC_750FL       = 0x700A0203,
4859 a750fc0b j_mayer
#define CPU_POWERPC_750FX     CPU_POWERPC_750FX_v23
4860 a750fc0b j_mayer
    CPU_POWERPC_750FX_v10   = 0x70000100,
4861 a750fc0b j_mayer
    CPU_POWERPC_750FX_v20   = 0x70000200,
4862 a750fc0b j_mayer
    CPU_POWERPC_750FX_v21   = 0x70000201,
4863 a750fc0b j_mayer
    CPU_POWERPC_750FX_v22   = 0x70000202,
4864 a750fc0b j_mayer
    CPU_POWERPC_750FX_v23   = 0x70000203,
4865 a750fc0b j_mayer
    CPU_POWERPC_750GL       = 0x70020102,
4866 a750fc0b j_mayer
#define CPU_POWERPC_750GX     CPU_POWERPC_750GX_v12
4867 a750fc0b j_mayer
    CPU_POWERPC_750GX_v10   = 0x70020100,
4868 a750fc0b j_mayer
    CPU_POWERPC_750GX_v11   = 0x70020101,
4869 a750fc0b j_mayer
    CPU_POWERPC_750GX_v12   = 0x70020102,
4870 a750fc0b j_mayer
#define CPU_POWERPC_750L      CPU_POWERPC_750L_v32 /* Aka LoneStar */
4871 a750fc0b j_mayer
    CPU_POWERPC_750L_v22    = 0x00088202,
4872 a750fc0b j_mayer
    CPU_POWERPC_750L_v30    = 0x00088300,
4873 a750fc0b j_mayer
    CPU_POWERPC_750L_v32    = 0x00088302,
4874 a750fc0b j_mayer
    /* PowerPC 745/755 cores */
4875 a750fc0b j_mayer
#define CPU_POWERPC_7x5       CPU_POWERPC_7x5_v28
4876 a750fc0b j_mayer
    CPU_POWERPC_7x5_v10     = 0x00083100,
4877 a750fc0b j_mayer
    CPU_POWERPC_7x5_v11     = 0x00083101,
4878 a750fc0b j_mayer
    CPU_POWERPC_7x5_v20     = 0x00083200,
4879 a750fc0b j_mayer
    CPU_POWERPC_7x5_v21     = 0x00083201,
4880 a750fc0b j_mayer
    CPU_POWERPC_7x5_v22     = 0x00083202, /* aka D */
4881 a750fc0b j_mayer
    CPU_POWERPC_7x5_v23     = 0x00083203, /* aka E */
4882 a750fc0b j_mayer
    CPU_POWERPC_7x5_v24     = 0x00083204,
4883 a750fc0b j_mayer
    CPU_POWERPC_7x5_v25     = 0x00083205,
4884 a750fc0b j_mayer
    CPU_POWERPC_7x5_v26     = 0x00083206,
4885 a750fc0b j_mayer
    CPU_POWERPC_7x5_v27     = 0x00083207,
4886 a750fc0b j_mayer
    CPU_POWERPC_7x5_v28     = 0x00083208,
4887 a750fc0b j_mayer
#if 0
4888 a750fc0b j_mayer
    CPU_POWERPC_7x5P        = xxx,
4889 a750fc0b j_mayer
#endif
4890 a750fc0b j_mayer
    /* PowerPC 74xx cores (aka G4) */
4891 a750fc0b j_mayer
    /* XXX: missing 0x000C1101 */
4892 a750fc0b j_mayer
#define CPU_POWERPC_7400      CPU_POWERPC_7400_v29
4893 a750fc0b j_mayer
    CPU_POWERPC_7400_v10    = 0x000C0100,
4894 a750fc0b j_mayer
    CPU_POWERPC_7400_v11    = 0x000C0101,
4895 a750fc0b j_mayer
    CPU_POWERPC_7400_v20    = 0x000C0200,
4896 a750fc0b j_mayer
    CPU_POWERPC_7400_v22    = 0x000C0202,
4897 a750fc0b j_mayer
    CPU_POWERPC_7400_v26    = 0x000C0206,
4898 a750fc0b j_mayer
    CPU_POWERPC_7400_v27    = 0x000C0207,
4899 a750fc0b j_mayer
    CPU_POWERPC_7400_v28    = 0x000C0208,
4900 a750fc0b j_mayer
    CPU_POWERPC_7400_v29    = 0x000C0209,
4901 a750fc0b j_mayer
#define CPU_POWERPC_7410      CPU_POWERPC_7410_v14
4902 a750fc0b j_mayer
    CPU_POWERPC_7410_v10    = 0x800C1100,
4903 a750fc0b j_mayer
    CPU_POWERPC_7410_v11    = 0x800C1101,
4904 a750fc0b j_mayer
    CPU_POWERPC_7410_v12    = 0x800C1102, /* aka C */
4905 a750fc0b j_mayer
    CPU_POWERPC_7410_v13    = 0x800C1103, /* aka D */
4906 a750fc0b j_mayer
    CPU_POWERPC_7410_v14    = 0x800C1104, /* aka E */
4907 a750fc0b j_mayer
#define CPU_POWERPC_7448      CPU_POWERPC_7448_v21
4908 a750fc0b j_mayer
    CPU_POWERPC_7448_v10    = 0x80040100,
4909 a750fc0b j_mayer
    CPU_POWERPC_7448_v11    = 0x80040101,
4910 a750fc0b j_mayer
    CPU_POWERPC_7448_v20    = 0x80040200,
4911 a750fc0b j_mayer
    CPU_POWERPC_7448_v21    = 0x80040201,
4912 a750fc0b j_mayer
#define CPU_POWERPC_7450      CPU_POWERPC_7450_v21
4913 a750fc0b j_mayer
    CPU_POWERPC_7450_v10    = 0x80000100,
4914 a750fc0b j_mayer
    CPU_POWERPC_7450_v11    = 0x80000101,
4915 a750fc0b j_mayer
    CPU_POWERPC_7450_v12    = 0x80000102,
4916 a750fc0b j_mayer
    CPU_POWERPC_7450_v20    = 0x80000200, /* aka D: 2.04 */
4917 a750fc0b j_mayer
    CPU_POWERPC_7450_v21    = 0x80000201, /* aka E */
4918 a750fc0b j_mayer
    CPU_POWERPC_74x1        = 0x80000203,
4919 a750fc0b j_mayer
    CPU_POWERPC_74x1G       = 0x80000210, /* aka G: 2.3 */
4920 a750fc0b j_mayer
    /* XXX: missing 0x80010200 */
4921 a750fc0b j_mayer
#define CPU_POWERPC_74x5      CPU_POWERPC_74x5_v32
4922 a750fc0b j_mayer
    CPU_POWERPC_74x5_v10    = 0x80010100,
4923 a750fc0b j_mayer
    CPU_POWERPC_74x5_v21    = 0x80010201, /* aka C: 2.1 */
4924 a750fc0b j_mayer
    CPU_POWERPC_74x5_v32    = 0x80010302,
4925 a750fc0b j_mayer
    CPU_POWERPC_74x5_v33    = 0x80010303, /* aka F: 3.3 */
4926 a750fc0b j_mayer
    CPU_POWERPC_74x5_v34    = 0x80010304, /* aka G: 3.4 */
4927 a750fc0b j_mayer
#define CPU_POWERPC_74x7      CPU_POWERPC_74x7_v12
4928 a750fc0b j_mayer
    CPU_POWERPC_74x7_v10    = 0x80020100, /* aka A: 1.0 */
4929 a750fc0b j_mayer
    CPU_POWERPC_74x7_v11    = 0x80030101, /* aka B: 1.1 */
4930 a750fc0b j_mayer
    CPU_POWERPC_74x7_v12    = 0x80020102, /* aka C: 1.2 */
4931 a750fc0b j_mayer
    /* 64 bits PowerPC */
4932 00af685f j_mayer
#if defined(TARGET_PPC64)
4933 a750fc0b j_mayer
    CPU_POWERPC_620         = 0x00140000,
4934 a750fc0b j_mayer
    CPU_POWERPC_630         = 0x00400000,
4935 a750fc0b j_mayer
    CPU_POWERPC_631         = 0x00410104,
4936 a750fc0b j_mayer
    CPU_POWERPC_POWER4      = 0x00350000,
4937 a750fc0b j_mayer
    CPU_POWERPC_POWER4P     = 0x00380000,
4938 a750fc0b j_mayer
    CPU_POWERPC_POWER5      = 0x003A0203,
4939 a750fc0b j_mayer
#define CPU_POWERPC_POWER5GR  CPU_POWERPC_POWER5
4940 a750fc0b j_mayer
    CPU_POWERPC_POWER5P     = 0x003B0000,
4941 a750fc0b j_mayer
#define CPU_POWERPC_POWER5GS  CPU_POWERPC_POWER5P
4942 a750fc0b j_mayer
    CPU_POWERPC_POWER6      = 0x003E0000,
4943 a750fc0b j_mayer
    CPU_POWERPC_POWER6_5    = 0x0F000001, /* POWER6 running POWER5 mode */
4944 a750fc0b j_mayer
    CPU_POWERPC_POWER6A     = 0x0F000002,
4945 a750fc0b j_mayer
    CPU_POWERPC_970         = 0x00390202,
4946 a750fc0b j_mayer
#define CPU_POWERPC_970FX     CPU_POWERPC_970FX_v31
4947 a750fc0b j_mayer
    CPU_POWERPC_970FX_v10   = 0x00391100,
4948 a750fc0b j_mayer
    CPU_POWERPC_970FX_v20   = 0x003C0200,
4949 a750fc0b j_mayer
    CPU_POWERPC_970FX_v21   = 0x003C0201,
4950 a750fc0b j_mayer
    CPU_POWERPC_970FX_v30   = 0x003C0300,
4951 a750fc0b j_mayer
    CPU_POWERPC_970FX_v31   = 0x003C0301,
4952 a750fc0b j_mayer
    CPU_POWERPC_970GX       = 0x00450000,
4953 a750fc0b j_mayer
#define CPU_POWERPC_970MP     CPU_POWERPC_970MP_v11
4954 a750fc0b j_mayer
    CPU_POWERPC_970MP_v10   = 0x00440100,
4955 a750fc0b j_mayer
    CPU_POWERPC_970MP_v11   = 0x00440101,
4956 a750fc0b j_mayer
#define CPU_POWERPC_CELL      CPU_POWERPC_CELL_v32
4957 a750fc0b j_mayer
    CPU_POWERPC_CELL_v10    = 0x00700100,
4958 a750fc0b j_mayer
    CPU_POWERPC_CELL_v20    = 0x00700400,
4959 a750fc0b j_mayer
    CPU_POWERPC_CELL_v30    = 0x00700500,
4960 a750fc0b j_mayer
    CPU_POWERPC_CELL_v31    = 0x00700501,
4961 a750fc0b j_mayer
#define CPU_POWERPC_CELL_v32  CPU_POWERPC_CELL_v31
4962 a750fc0b j_mayer
    CPU_POWERPC_RS64        = 0x00330000,
4963 a750fc0b j_mayer
    CPU_POWERPC_RS64II      = 0x00340000,
4964 a750fc0b j_mayer
    CPU_POWERPC_RS64III     = 0x00360000,
4965 a750fc0b j_mayer
    CPU_POWERPC_RS64IV      = 0x00370000,
4966 00af685f j_mayer
#endif /* defined(TARGET_PPC64) */
4967 a750fc0b j_mayer
    /* Original POWER */
4968 a750fc0b j_mayer
    /* XXX: should be POWER (RIOS), RSC3308, RSC4608,
4969 a750fc0b j_mayer
     * POWER2 (RIOS2) & RSC2 (P2SC) here
4970 a750fc0b j_mayer
     */
4971 a750fc0b j_mayer
#if 0
4972 a750fc0b j_mayer
    CPU_POWER           = xxx, /* 0x20000 ? 0x30000 for RSC ? */
4973 a750fc0b j_mayer
#endif
4974 a750fc0b j_mayer
#if 0
4975 a750fc0b j_mayer
    CPU_POWER2          = xxx, /* 0x40000 ? */
4976 a750fc0b j_mayer
#endif
4977 a750fc0b j_mayer
    /* PA Semi core */
4978 a750fc0b j_mayer
    CPU_POWERPC_PA6T        = 0x00900000,
4979 a750fc0b j_mayer
};
4980 a750fc0b j_mayer
4981 a750fc0b j_mayer
/* System version register (used on MPC 8xxx)                                */
4982 a750fc0b j_mayer
enum {
4983 a750fc0b j_mayer
    PPC_SVR_8540      = 0x80300000,
4984 a750fc0b j_mayer
    PPC_SVR_8541E     = 0x807A0010,
4985 a750fc0b j_mayer
    PPC_SVR_8543v10   = 0x80320010,
4986 a750fc0b j_mayer
    PPC_SVR_8543v11   = 0x80320011,
4987 a750fc0b j_mayer
    PPC_SVR_8543v20   = 0x80320020,
4988 a750fc0b j_mayer
    PPC_SVR_8543Ev10  = 0x803A0010,
4989 a750fc0b j_mayer
    PPC_SVR_8543Ev11  = 0x803A0011,
4990 a750fc0b j_mayer
    PPC_SVR_8543Ev20  = 0x803A0020,
4991 a750fc0b j_mayer
    PPC_SVR_8545      = 0x80310220,
4992 a750fc0b j_mayer
    PPC_SVR_8545E     = 0x80390220,
4993 a750fc0b j_mayer
    PPC_SVR_8547E     = 0x80390120,
4994 a750fc0b j_mayer
    PPC_SCR_8548v10   = 0x80310010,
4995 a750fc0b j_mayer
    PPC_SCR_8548v11   = 0x80310011,
4996 a750fc0b j_mayer
    PPC_SCR_8548v20   = 0x80310020,
4997 a750fc0b j_mayer
    PPC_SVR_8548Ev10  = 0x80390010,
4998 a750fc0b j_mayer
    PPC_SVR_8548Ev11  = 0x80390011,
4999 a750fc0b j_mayer
    PPC_SVR_8548Ev20  = 0x80390020,
5000 a750fc0b j_mayer
    PPC_SVR_8555E     = 0x80790010,
5001 a750fc0b j_mayer
    PPC_SVR_8560v10   = 0x80700010,
5002 a750fc0b j_mayer
    PPC_SVR_8560v20   = 0x80700020,
5003 a750fc0b j_mayer
};
5004 a750fc0b j_mayer
5005 3fc6c082 bellard
/*****************************************************************************/
5006 a750fc0b j_mayer
/* PowerPC CPU definitions                                                   */
5007 ee4e83ed j_mayer
#define POWERPC_DEF(_name, _pvr, _type)                                       \
5008 a750fc0b j_mayer
    {                                                                         \
5009 a750fc0b j_mayer
        .name        = _name,                                                 \
5010 a750fc0b j_mayer
        .pvr         = _pvr,                                                  \
5011 a750fc0b j_mayer
        .insns_flags = glue(POWERPC_INSNS_,_type),                            \
5012 a750fc0b j_mayer
        .msr_mask    = glue(POWERPC_MSRM_,_type),                             \
5013 a750fc0b j_mayer
        .mmu_model   = glue(POWERPC_MMU_,_type),                              \
5014 a750fc0b j_mayer
        .excp_model  = glue(POWERPC_EXCP_,_type),                             \
5015 a750fc0b j_mayer
        .bus_model   = glue(POWERPC_INPUT_,_type),                            \
5016 237c0af0 j_mayer
        .bfd_mach    = glue(POWERPC_BFDM_,_type),                             \
5017 d26bfc9a j_mayer
        .flags       = glue(POWERPC_FLAG_,_type),                             \
5018 a750fc0b j_mayer
        .init_proc   = &glue(init_proc_,_type),                               \
5019 2f462816 j_mayer
        .check_pow   = &glue(check_pow_,_type),                               \
5020 a750fc0b j_mayer
    }
5021 a750fc0b j_mayer
5022 ee4e83ed j_mayer
static const ppc_def_t ppc_defs[] = {
5023 a750fc0b j_mayer
    /* Embedded PowerPC                                                      */
5024 a750fc0b j_mayer
    /* PowerPC 401 family                                                    */
5025 2662a059 j_mayer
    /* Generic PowerPC 401 */
5026 ee4e83ed j_mayer
    POWERPC_DEF("401",         CPU_POWERPC_401,         401),
5027 a750fc0b j_mayer
    /* PowerPC 401 cores                                                     */
5028 2662a059 j_mayer
    /* PowerPC 401A1 */
5029 ee4e83ed j_mayer
    POWERPC_DEF("401A1",       CPU_POWERPC_401A1,       401),
5030 a750fc0b j_mayer
    /* PowerPC 401B2                                                         */
5031 ee4e83ed j_mayer
    POWERPC_DEF("401B2",       CPU_POWERPC_401B2,       401x2),
5032 2662a059 j_mayer
#if defined (TODO)
5033 a750fc0b j_mayer
    /* PowerPC 401B3                                                         */
5034 ee4e83ed j_mayer
    POWERPC_DEF("401B3",       CPU_POWERPC_401B3,       401x3),
5035 a750fc0b j_mayer
#endif
5036 a750fc0b j_mayer
    /* PowerPC 401C2                                                         */
5037 ee4e83ed j_mayer
    POWERPC_DEF("401C2",       CPU_POWERPC_401C2,       401x2),
5038 a750fc0b j_mayer
    /* PowerPC 401D2                                                         */
5039 ee4e83ed j_mayer
    POWERPC_DEF("401D2",       CPU_POWERPC_401D2,       401x2),
5040 a750fc0b j_mayer
    /* PowerPC 401E2                                                         */
5041 ee4e83ed j_mayer
    POWERPC_DEF("401E2",       CPU_POWERPC_401E2,       401x2),
5042 a750fc0b j_mayer
    /* PowerPC 401F2                                                         */
5043 ee4e83ed j_mayer
    POWERPC_DEF("401F2",       CPU_POWERPC_401F2,       401x2),
5044 a750fc0b j_mayer
    /* PowerPC 401G2                                                         */
5045 a750fc0b j_mayer
    /* XXX: to be checked */
5046 ee4e83ed j_mayer
    POWERPC_DEF("401G2",       CPU_POWERPC_401G2,       401x2),
5047 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers                                           */
5048 2662a059 j_mayer
#if defined (TODO)
5049 a750fc0b j_mayer
    /* PowerPC 401GF                                                         */
5050 ee4e83ed j_mayer
    POWERPC_DEF("401GF",       CPU_POWERPC_401GF,       401),
5051 3fc6c082 bellard
#endif
5052 a750fc0b j_mayer
    /* IOP480 (401 microcontroler)                                           */
5053 ee4e83ed j_mayer
    POWERPC_DEF("IOP480",      CPU_POWERPC_IOP480,      IOP480),
5054 a750fc0b j_mayer
    /* IBM Processor for Network Resources                                   */
5055 ee4e83ed j_mayer
    POWERPC_DEF("Cobra",       CPU_POWERPC_COBRA,       401),
5056 3fc6c082 bellard
#if defined (TODO)
5057 ee4e83ed j_mayer
    POWERPC_DEF("Xipchip",     CPU_POWERPC_XIPCHIP,     401),
5058 3fc6c082 bellard
#endif
5059 a750fc0b j_mayer
    /* PowerPC 403 family                                                    */
5060 a750fc0b j_mayer
    /* Generic PowerPC 403                                                   */
5061 ee4e83ed j_mayer
    POWERPC_DEF("403",         CPU_POWERPC_403,         403),
5062 a750fc0b j_mayer
    /* PowerPC 403 microcontrolers                                           */
5063 a750fc0b j_mayer
    /* PowerPC 403 GA                                                        */
5064 ee4e83ed j_mayer
    POWERPC_DEF("403GA",       CPU_POWERPC_403GA,       403),
5065 a750fc0b j_mayer
    /* PowerPC 403 GB                                                        */
5066 ee4e83ed j_mayer
    POWERPC_DEF("403GB",       CPU_POWERPC_403GB,       403),
5067 a750fc0b j_mayer
    /* PowerPC 403 GC                                                        */
5068 ee4e83ed j_mayer
    POWERPC_DEF("403GC",       CPU_POWERPC_403GC,       403),
5069 a750fc0b j_mayer
    /* PowerPC 403 GCX                                                       */
5070 ee4e83ed j_mayer
    POWERPC_DEF("403GCX",      CPU_POWERPC_403GCX,      403GCX),
5071 3fc6c082 bellard
#if defined (TODO)
5072 a750fc0b j_mayer
    /* PowerPC 403 GP                                                        */
5073 ee4e83ed j_mayer
    POWERPC_DEF("403GP",       CPU_POWERPC_403GP,       403),
5074 3fc6c082 bellard
#endif
5075 a750fc0b j_mayer
    /* PowerPC 405 family                                                    */
5076 a750fc0b j_mayer
    /* Generic PowerPC 405                                                   */
5077 ee4e83ed j_mayer
    POWERPC_DEF("405",         CPU_POWERPC_405,         405),
5078 a750fc0b j_mayer
    /* PowerPC 405 cores                                                     */
5079 2662a059 j_mayer
#if defined (TODO)
5080 a750fc0b j_mayer
    /* PowerPC 405 A3                                                        */
5081 ee4e83ed j_mayer
    POWERPC_DEF("405A3",       CPU_POWERPC_405A3,       405),
5082 3a607854 j_mayer
#endif
5083 3a607854 j_mayer
#if defined (TODO)
5084 a750fc0b j_mayer
    /* PowerPC 405 A4                                                        */
5085 ee4e83ed j_mayer
    POWERPC_DEF("405A4",       CPU_POWERPC_405A4,       405),
5086 3a607854 j_mayer
#endif
5087 3a607854 j_mayer
#if defined (TODO)
5088 a750fc0b j_mayer
    /* PowerPC 405 B3                                                        */
5089 ee4e83ed j_mayer
    POWERPC_DEF("405B3",       CPU_POWERPC_405B3,       405),
5090 3fc6c082 bellard
#endif
5091 3fc6c082 bellard
#if defined (TODO)
5092 a750fc0b j_mayer
    /* PowerPC 405 B4                                                        */
5093 ee4e83ed j_mayer
    POWERPC_DEF("405B4",       CPU_POWERPC_405B4,       405),
5094 a750fc0b j_mayer
#endif
5095 a750fc0b j_mayer
#if defined (TODO)
5096 a750fc0b j_mayer
    /* PowerPC 405 C3                                                        */
5097 ee4e83ed j_mayer
    POWERPC_DEF("405C3",       CPU_POWERPC_405C3,       405),
5098 a750fc0b j_mayer
#endif
5099 a750fc0b j_mayer
#if defined (TODO)
5100 a750fc0b j_mayer
    /* PowerPC 405 C4                                                        */
5101 ee4e83ed j_mayer
    POWERPC_DEF("405C4",       CPU_POWERPC_405C4,       405),
5102 a750fc0b j_mayer
#endif
5103 a750fc0b j_mayer
    /* PowerPC 405 D2                                                        */
5104 ee4e83ed j_mayer
    POWERPC_DEF("405D2",       CPU_POWERPC_405D2,       405),
5105 a750fc0b j_mayer
#if defined (TODO)
5106 a750fc0b j_mayer
    /* PowerPC 405 D3                                                        */
5107 ee4e83ed j_mayer
    POWERPC_DEF("405D3",       CPU_POWERPC_405D3,       405),
5108 a750fc0b j_mayer
#endif
5109 a750fc0b j_mayer
    /* PowerPC 405 D4                                                        */
5110 ee4e83ed j_mayer
    POWERPC_DEF("405D4",       CPU_POWERPC_405D4,       405),
5111 a750fc0b j_mayer
#if defined (TODO)
5112 a750fc0b j_mayer
    /* PowerPC 405 D5                                                        */
5113 ee4e83ed j_mayer
    POWERPC_DEF("405D5",       CPU_POWERPC_405D5,       405),
5114 a750fc0b j_mayer
#endif
5115 a750fc0b j_mayer
#if defined (TODO)
5116 a750fc0b j_mayer
    /* PowerPC 405 E4                                                        */
5117 ee4e83ed j_mayer
    POWERPC_DEF("405E4",       CPU_POWERPC_405E4,       405),
5118 a750fc0b j_mayer
#endif
5119 a750fc0b j_mayer
#if defined (TODO)
5120 a750fc0b j_mayer
    /* PowerPC 405 F4                                                        */
5121 ee4e83ed j_mayer
    POWERPC_DEF("405F4",       CPU_POWERPC_405F4,       405),
5122 a750fc0b j_mayer
#endif
5123 a750fc0b j_mayer
#if defined (TODO)
5124 a750fc0b j_mayer
    /* PowerPC 405 F5                                                        */
5125 ee4e83ed j_mayer
    POWERPC_DEF("405F5",       CPU_POWERPC_405F5,       405),
5126 a750fc0b j_mayer
#endif
5127 a750fc0b j_mayer
#if defined (TODO)
5128 a750fc0b j_mayer
    /* PowerPC 405 F6                                                        */
5129 ee4e83ed j_mayer
    POWERPC_DEF("405F6",       CPU_POWERPC_405F6,       405),
5130 a750fc0b j_mayer
#endif
5131 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers                                           */
5132 a750fc0b j_mayer
    /* PowerPC 405 CR                                                        */
5133 ee4e83ed j_mayer
    POWERPC_DEF("405CR",       CPU_POWERPC_405CR,       405),
5134 a750fc0b j_mayer
    /* PowerPC 405 CRa                                                       */
5135 ee4e83ed j_mayer
    POWERPC_DEF("405CRa",      CPU_POWERPC_405CRa,      405),
5136 a750fc0b j_mayer
    /* PowerPC 405 CRb                                                       */
5137 ee4e83ed j_mayer
    POWERPC_DEF("405CRb",      CPU_POWERPC_405CRb,      405),
5138 a750fc0b j_mayer
    /* PowerPC 405 CRc                                                       */
5139 ee4e83ed j_mayer
    POWERPC_DEF("405CRc",      CPU_POWERPC_405CRc,      405),
5140 a750fc0b j_mayer
    /* PowerPC 405 EP                                                        */
5141 ee4e83ed j_mayer
    POWERPC_DEF("405EP",       CPU_POWERPC_405EP,       405),
5142 a750fc0b j_mayer
#if defined(TODO)
5143 a750fc0b j_mayer
    /* PowerPC 405 EXr                                                       */
5144 ee4e83ed j_mayer
    POWERPC_DEF("405EXr",      CPU_POWERPC_405EXr,      405),
5145 a750fc0b j_mayer
#endif
5146 a750fc0b j_mayer
    /* PowerPC 405 EZ                                                        */
5147 ee4e83ed j_mayer
    POWERPC_DEF("405EZ",       CPU_POWERPC_405EZ,       405),
5148 a750fc0b j_mayer
#if defined(TODO)
5149 a750fc0b j_mayer
    /* PowerPC 405 FX                                                        */
5150 ee4e83ed j_mayer
    POWERPC_DEF("405FX",       CPU_POWERPC_405FX,       405),
5151 a750fc0b j_mayer
#endif
5152 a750fc0b j_mayer
    /* PowerPC 405 GP                                                        */
5153 ee4e83ed j_mayer
    POWERPC_DEF("405GP",       CPU_POWERPC_405GP,       405),
5154 a750fc0b j_mayer
    /* PowerPC 405 GPa                                                       */
5155 ee4e83ed j_mayer
    POWERPC_DEF("405GPa",      CPU_POWERPC_405GPa,      405),
5156 a750fc0b j_mayer
    /* PowerPC 405 GPb                                                       */
5157 ee4e83ed j_mayer
    POWERPC_DEF("405GPb",      CPU_POWERPC_405GPb,      405),
5158 a750fc0b j_mayer
    /* PowerPC 405 GPc                                                       */
5159 ee4e83ed j_mayer
    POWERPC_DEF("405GPc",      CPU_POWERPC_405GPc,      405),
5160 a750fc0b j_mayer
    /* PowerPC 405 GPd                                                       */
5161 ee4e83ed j_mayer
    POWERPC_DEF("405GPd",      CPU_POWERPC_405GPd,      405),
5162 a750fc0b j_mayer
    /* PowerPC 405 GPe                                                       */
5163 ee4e83ed j_mayer
    POWERPC_DEF("405GPe",      CPU_POWERPC_405GPe,      405),
5164 a750fc0b j_mayer
    /* PowerPC 405 GPR                                                       */
5165 ee4e83ed j_mayer
    POWERPC_DEF("405GPR",      CPU_POWERPC_405GPR,      405),
5166 a750fc0b j_mayer
#if defined(TODO)
5167 a750fc0b j_mayer
    /* PowerPC 405 H                                                         */
5168 ee4e83ed j_mayer
    POWERPC_DEF("405H",        CPU_POWERPC_405H,        405),
5169 a750fc0b j_mayer
#endif
5170 a750fc0b j_mayer
#if defined(TODO)
5171 a750fc0b j_mayer
    /* PowerPC 405 L                                                         */
5172 ee4e83ed j_mayer
    POWERPC_DEF("405L",        CPU_POWERPC_405L,        405),
5173 a750fc0b j_mayer
#endif
5174 a750fc0b j_mayer
    /* PowerPC 405 LP                                                        */
5175 ee4e83ed j_mayer
    POWERPC_DEF("405LP",       CPU_POWERPC_405LP,       405),
5176 a750fc0b j_mayer
#if defined(TODO)
5177 a750fc0b j_mayer
    /* PowerPC 405 PM                                                        */
5178 ee4e83ed j_mayer
    POWERPC_DEF("405PM",       CPU_POWERPC_405PM,       405),
5179 a750fc0b j_mayer
#endif
5180 a750fc0b j_mayer
#if defined(TODO)
5181 a750fc0b j_mayer
    /* PowerPC 405 PS                                                        */
5182 ee4e83ed j_mayer
    POWERPC_DEF("405PS",       CPU_POWERPC_405PS,       405),
5183 a750fc0b j_mayer
#endif
5184 a750fc0b j_mayer
#if defined(TODO)
5185 a750fc0b j_mayer
    /* PowerPC 405 S                                                         */
5186 ee4e83ed j_mayer
    POWERPC_DEF("405S",        CPU_POWERPC_405S,        405),
5187 a750fc0b j_mayer
#endif
5188 a750fc0b j_mayer
    /* Npe405 H                                                              */
5189 ee4e83ed j_mayer
    POWERPC_DEF("Npe405H",     CPU_POWERPC_NPE405H,     405),
5190 a750fc0b j_mayer
    /* Npe405 H2                                                             */
5191 ee4e83ed j_mayer
    POWERPC_DEF("Npe405H2",    CPU_POWERPC_NPE405H2,    405),
5192 a750fc0b j_mayer
    /* Npe405 L                                                              */
5193 ee4e83ed j_mayer
    POWERPC_DEF("Npe405L",     CPU_POWERPC_NPE405L,     405),
5194 a750fc0b j_mayer
    /* Npe4GS3                                                               */
5195 ee4e83ed j_mayer
    POWERPC_DEF("Npe4GS3",     CPU_POWERPC_NPE4GS3,     405),
5196 a750fc0b j_mayer
#if defined (TODO)
5197 ee4e83ed j_mayer
    POWERPC_DEF("Npcxx1",      CPU_POWERPC_NPCxx1,      405),
5198 a750fc0b j_mayer
#endif
5199 a750fc0b j_mayer
#if defined (TODO)
5200 ee4e83ed j_mayer
    POWERPC_DEF("Npr161",      CPU_POWERPC_NPR161,      405),
5201 a750fc0b j_mayer
#endif
5202 a750fc0b j_mayer
#if defined (TODO)
5203 a750fc0b j_mayer
    /* PowerPC LC77700 (Sanyo)                                               */
5204 ee4e83ed j_mayer
    POWERPC_DEF("LC77700",     CPU_POWERPC_LC77700,     405),
5205 a750fc0b j_mayer
#endif
5206 a750fc0b j_mayer
    /* PowerPC 401/403/405 based set-top-box microcontrolers                 */
5207 a750fc0b j_mayer
#if defined (TODO)
5208 a750fc0b j_mayer
    /* STB010000                                                             */
5209 ee4e83ed j_mayer
    POWERPC_DEF("STB01000",    CPU_POWERPC_STB01000,    401x2),
5210 a750fc0b j_mayer
#endif
5211 a750fc0b j_mayer
#if defined (TODO)
5212 a750fc0b j_mayer
    /* STB01010                                                              */
5213 ee4e83ed j_mayer
    POWERPC_DEF("STB01010",    CPU_POWERPC_STB01010,    401x2),
5214 a750fc0b j_mayer
#endif
5215 a750fc0b j_mayer
#if defined (TODO)
5216 a750fc0b j_mayer
    /* STB0210                                                               */
5217 ee4e83ed j_mayer
    POWERPC_DEF("STB0210",     CPU_POWERPC_STB0210,     401x3),
5218 a750fc0b j_mayer
#endif
5219 a750fc0b j_mayer
    /* STB03xx                                                               */
5220 ee4e83ed j_mayer
    POWERPC_DEF("STB03",       CPU_POWERPC_STB03,       405),
5221 a750fc0b j_mayer
#if defined (TODO)
5222 a750fc0b j_mayer
    /* STB043x                                                               */
5223 ee4e83ed j_mayer
    POWERPC_DEF("STB043",      CPU_POWERPC_STB043,      405),
5224 a750fc0b j_mayer
#endif
5225 a750fc0b j_mayer
#if defined (TODO)
5226 a750fc0b j_mayer
    /* STB045x                                                               */
5227 ee4e83ed j_mayer
    POWERPC_DEF("STB045",      CPU_POWERPC_STB045,      405),
5228 a750fc0b j_mayer
#endif
5229 a750fc0b j_mayer
    /* STB04xx                                                               */
5230 ee4e83ed j_mayer
    POWERPC_DEF("STB04",       CPU_POWERPC_STB04,       405),
5231 a750fc0b j_mayer
    /* STB25xx                                                               */
5232 ee4e83ed j_mayer
    POWERPC_DEF("STB25",       CPU_POWERPC_STB25,       405),
5233 a750fc0b j_mayer
#if defined (TODO)
5234 a750fc0b j_mayer
    /* STB130                                                                */
5235 ee4e83ed j_mayer
    POWERPC_DEF("STB130",      CPU_POWERPC_STB130,      405),
5236 a750fc0b j_mayer
#endif
5237 a750fc0b j_mayer
    /* Xilinx PowerPC 405 cores                                              */
5238 ee4e83ed j_mayer
    POWERPC_DEF("x2vp4",       CPU_POWERPC_X2VP4,       405),
5239 ee4e83ed j_mayer
    POWERPC_DEF("x2vp7",       CPU_POWERPC_X2VP7,       405),
5240 ee4e83ed j_mayer
    POWERPC_DEF("x2vp20",      CPU_POWERPC_X2VP20,      405),
5241 ee4e83ed j_mayer
    POWERPC_DEF("x2vp50",      CPU_POWERPC_X2VP50,      405),
5242 a750fc0b j_mayer
#if defined (TODO)
5243 a750fc0b j_mayer
    /* Zarlink ZL10310                                                       */
5244 ee4e83ed j_mayer
    POWERPC_DEF("zl10310",     CPU_POWERPC_ZL10310,     405),
5245 a750fc0b j_mayer
#endif
5246 a750fc0b j_mayer
#if defined (TODO)
5247 a750fc0b j_mayer
    /* Zarlink ZL10311                                                       */
5248 ee4e83ed j_mayer
    POWERPC_DEF("zl10311",     CPU_POWERPC_ZL10311,     405),
5249 a750fc0b j_mayer
#endif
5250 a750fc0b j_mayer
#if defined (TODO)
5251 a750fc0b j_mayer
    /* Zarlink ZL10320                                                       */
5252 ee4e83ed j_mayer
    POWERPC_DEF("zl10320",     CPU_POWERPC_ZL10320,     405),
5253 a750fc0b j_mayer
#endif
5254 a750fc0b j_mayer
#if defined (TODO)
5255 a750fc0b j_mayer
    /* Zarlink ZL10321                                                       */
5256 ee4e83ed j_mayer
    POWERPC_DEF("zl10321",     CPU_POWERPC_ZL10321,     405),
5257 a750fc0b j_mayer
#endif
5258 a750fc0b j_mayer
    /* PowerPC 440 family                                                    */
5259 a750fc0b j_mayer
    /* Generic PowerPC 440                                                   */
5260 ee4e83ed j_mayer
    POWERPC_DEF("440",         CPU_POWERPC_440,         440GP),
5261 a750fc0b j_mayer
    /* PowerPC 440 cores                                                     */
5262 a750fc0b j_mayer
#if defined (TODO)
5263 a750fc0b j_mayer
    /* PowerPC 440 A4                                                        */
5264 ee4e83ed j_mayer
    POWERPC_DEF("440A4",       CPU_POWERPC_440A4,       440x4),
5265 a750fc0b j_mayer
#endif
5266 a750fc0b j_mayer
#if defined (TODO)
5267 a750fc0b j_mayer
    /* PowerPC 440 A5                                                        */
5268 ee4e83ed j_mayer
    POWERPC_DEF("440A5",       CPU_POWERPC_440A5,       440x5),
5269 a750fc0b j_mayer
#endif
5270 a750fc0b j_mayer
#if defined (TODO)
5271 a750fc0b j_mayer
    /* PowerPC 440 B4                                                        */
5272 ee4e83ed j_mayer
    POWERPC_DEF("440B4",       CPU_POWERPC_440B4,       440x4),
5273 a750fc0b j_mayer
#endif
5274 a750fc0b j_mayer
#if defined (TODO)
5275 a750fc0b j_mayer
    /* PowerPC 440 G4                                                        */
5276 ee4e83ed j_mayer
    POWERPC_DEF("440G4",       CPU_POWERPC_440G4,       440x4),
5277 a750fc0b j_mayer
#endif
5278 a750fc0b j_mayer
#if defined (TODO)
5279 a750fc0b j_mayer
    /* PowerPC 440 F5                                                        */
5280 ee4e83ed j_mayer
    POWERPC_DEF("440F5",       CPU_POWERPC_440F5,       440x5),
5281 a750fc0b j_mayer
#endif
5282 a750fc0b j_mayer
#if defined (TODO)
5283 a750fc0b j_mayer
    /* PowerPC 440 G5                                                        */
5284 ee4e83ed j_mayer
    POWERPC_DEF("440G5",       CPU_POWERPC_440G5,       440x5),
5285 a750fc0b j_mayer
#endif
5286 a750fc0b j_mayer
#if defined (TODO)
5287 a750fc0b j_mayer
    /* PowerPC 440H4                                                         */
5288 ee4e83ed j_mayer
    POWERPC_DEF("440H4",       CPU_POWERPC_440H4,       440x4),
5289 a750fc0b j_mayer
#endif
5290 a750fc0b j_mayer
#if defined (TODO)
5291 a750fc0b j_mayer
    /* PowerPC 440H6                                                         */
5292 ee4e83ed j_mayer
    POWERPC_DEF("440H6",       CPU_POWERPC_440H6,       440Gx5),
5293 a750fc0b j_mayer
#endif
5294 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers                                           */
5295 a750fc0b j_mayer
    /* PowerPC 440 EP                                                        */
5296 ee4e83ed j_mayer
    POWERPC_DEF("440EP",       CPU_POWERPC_440EP,       440EP),
5297 a750fc0b j_mayer
    /* PowerPC 440 EPa                                                       */
5298 ee4e83ed j_mayer
    POWERPC_DEF("440EPa",      CPU_POWERPC_440EPa,      440EP),
5299 a750fc0b j_mayer
    /* PowerPC 440 EPb                                                       */
5300 ee4e83ed j_mayer
    POWERPC_DEF("440EPb",      CPU_POWERPC_440EPb,      440EP),
5301 a750fc0b j_mayer
    /* PowerPC 440 EPX                                                       */
5302 ee4e83ed j_mayer
    POWERPC_DEF("440EPX",      CPU_POWERPC_440EPX,      440EP),
5303 a750fc0b j_mayer
    /* PowerPC 440 GP                                                        */
5304 ee4e83ed j_mayer
    POWERPC_DEF("440GP",       CPU_POWERPC_440GP,       440GP),
5305 a750fc0b j_mayer
    /* PowerPC 440 GPb                                                       */
5306 ee4e83ed j_mayer
    POWERPC_DEF("440GPb",      CPU_POWERPC_440GPb,      440GP),
5307 a750fc0b j_mayer
    /* PowerPC 440 GPc                                                       */
5308 ee4e83ed j_mayer
    POWERPC_DEF("440GPc",      CPU_POWERPC_440GPc,      440GP),
5309 a750fc0b j_mayer
    /* PowerPC 440 GR                                                        */
5310 ee4e83ed j_mayer
    POWERPC_DEF("440GR",       CPU_POWERPC_440GR,       440x5),
5311 a750fc0b j_mayer
    /* PowerPC 440 GRa                                                       */
5312 ee4e83ed j_mayer
    POWERPC_DEF("440GRa",      CPU_POWERPC_440GRa,      440x5),
5313 a750fc0b j_mayer
    /* PowerPC 440 GRX                                                       */
5314 ee4e83ed j_mayer
    POWERPC_DEF("440GRX",      CPU_POWERPC_440GRX,      440x5),
5315 a750fc0b j_mayer
    /* PowerPC 440 GX                                                        */
5316 ee4e83ed j_mayer
    POWERPC_DEF("440GX",       CPU_POWERPC_440GX,       440EP),
5317 a750fc0b j_mayer
    /* PowerPC 440 GXa                                                       */
5318 ee4e83ed j_mayer
    POWERPC_DEF("440GXa",      CPU_POWERPC_440GXa,      440EP),
5319 a750fc0b j_mayer
    /* PowerPC 440 GXb                                                       */
5320 ee4e83ed j_mayer
    POWERPC_DEF("440GXb",      CPU_POWERPC_440GXb,      440EP),
5321 a750fc0b j_mayer
    /* PowerPC 440 GXc                                                       */
5322 ee4e83ed j_mayer
    POWERPC_DEF("440GXc",      CPU_POWERPC_440GXc,      440EP),
5323 a750fc0b j_mayer
    /* PowerPC 440 GXf                                                       */
5324 ee4e83ed j_mayer
    POWERPC_DEF("440GXf",      CPU_POWERPC_440GXf,      440EP),
5325 a750fc0b j_mayer
#if defined(TODO)
5326 a750fc0b j_mayer
    /* PowerPC 440 S                                                         */
5327 ee4e83ed j_mayer
    POWERPC_DEF("440S",        CPU_POWERPC_440S,        440),
5328 a750fc0b j_mayer
#endif
5329 a750fc0b j_mayer
    /* PowerPC 440 SP                                                        */
5330 ee4e83ed j_mayer
    POWERPC_DEF("440SP",       CPU_POWERPC_440SP,       440EP),
5331 a750fc0b j_mayer
    /* PowerPC 440 SP2                                                       */
5332 ee4e83ed j_mayer
    POWERPC_DEF("440SP2",      CPU_POWERPC_440SP2,      440EP),
5333 a750fc0b j_mayer
    /* PowerPC 440 SPE                                                       */
5334 ee4e83ed j_mayer
    POWERPC_DEF("440SPE",      CPU_POWERPC_440SPE,      440EP),
5335 a750fc0b j_mayer
    /* PowerPC 460 family                                                    */
5336 a750fc0b j_mayer
#if defined (TODO)
5337 a750fc0b j_mayer
    /* Generic PowerPC 464                                                   */
5338 ee4e83ed j_mayer
    POWERPC_DEF("464",         CPU_POWERPC_464,         460),
5339 a750fc0b j_mayer
#endif
5340 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers                                           */
5341 a750fc0b j_mayer
#if defined (TODO)
5342 a750fc0b j_mayer
    /* PowerPC 464H90                                                        */
5343 ee4e83ed j_mayer
    POWERPC_DEF("464H90",      CPU_POWERPC_464H90,      460),
5344 a750fc0b j_mayer
#endif
5345 a750fc0b j_mayer
#if defined (TODO)
5346 a750fc0b j_mayer
    /* PowerPC 464H90F                                                       */
5347 ee4e83ed j_mayer
    POWERPC_DEF("464H90F",     CPU_POWERPC_464H90F,     460F),
5348 a750fc0b j_mayer
#endif
5349 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores                                      */
5350 a750fc0b j_mayer
    /* e200 family                                                           */
5351 a750fc0b j_mayer
#if defined (TODO)
5352 a750fc0b j_mayer
    /* Generic PowerPC e200 core                                             */
5353 ee4e83ed j_mayer
    POWERPC_DEF("e200",        CPU_POWERPC_e200,        e200),
5354 a750fc0b j_mayer
#endif
5355 a750fc0b j_mayer
#if defined (TODO)
5356 a750fc0b j_mayer
    /* PowerPC e200z5 core                                                   */
5357 ee4e83ed j_mayer
    POWERPC_DEF("e200z5",      CPU_POWERPC_e200z5,      e200),
5358 a750fc0b j_mayer
#endif
5359 a750fc0b j_mayer
#if defined (TODO)
5360 a750fc0b j_mayer
    /* PowerPC e200z6 core                                                   */
5361 ee4e83ed j_mayer
    POWERPC_DEF("e200z6",      CPU_POWERPC_e200z6,      e200),
5362 a750fc0b j_mayer
#endif
5363 a750fc0b j_mayer
    /* e300 family                                                           */
5364 a750fc0b j_mayer
#if defined (TODO)
5365 a750fc0b j_mayer
    /* Generic PowerPC e300 core                                             */
5366 ee4e83ed j_mayer
    POWERPC_DEF("e300",        CPU_POWERPC_e300,        e300),
5367 a750fc0b j_mayer
#endif
5368 a750fc0b j_mayer
#if defined (TODO)
5369 a750fc0b j_mayer
    /* PowerPC e300c1 core                                                   */
5370 ee4e83ed j_mayer
    POWERPC_DEF("e300c1",      CPU_POWERPC_e300c1,      e300),
5371 a750fc0b j_mayer
#endif
5372 a750fc0b j_mayer
#if defined (TODO)
5373 a750fc0b j_mayer
    /* PowerPC e300c2 core                                                   */
5374 ee4e83ed j_mayer
    POWERPC_DEF("e300c2",      CPU_POWERPC_e300c2,      e300),
5375 a750fc0b j_mayer
#endif
5376 a750fc0b j_mayer
#if defined (TODO)
5377 a750fc0b j_mayer
    /* PowerPC e300c3 core                                                   */
5378 ee4e83ed j_mayer
    POWERPC_DEF("e300c3",      CPU_POWERPC_e300c3,      e300),
5379 a750fc0b j_mayer
#endif
5380 a750fc0b j_mayer
    /* e500 family                                                           */
5381 a750fc0b j_mayer
#if defined (TODO)
5382 a750fc0b j_mayer
    /* PowerPC e500 core                                                     */
5383 ee4e83ed j_mayer
    POWERPC_DEF("e500",        CPU_POWERPC_e500,        e500),
5384 a750fc0b j_mayer
#endif
5385 a750fc0b j_mayer
#if defined (TODO)
5386 a750fc0b j_mayer
    /* PowerPC e500 v1.1 core                                                */
5387 ee4e83ed j_mayer
    POWERPC_DEF("e500v1.1",    CPU_POWERPC_e500_v11,    e500),
5388 a750fc0b j_mayer
#endif
5389 a750fc0b j_mayer
#if defined (TODO)
5390 a750fc0b j_mayer
    /* PowerPC e500 v1.2 core                                                */
5391 ee4e83ed j_mayer
    POWERPC_DEF("e500v1.2",    CPU_POWERPC_e500_v12,    e500),
5392 a750fc0b j_mayer
#endif
5393 a750fc0b j_mayer
#if defined (TODO)
5394 a750fc0b j_mayer
    /* PowerPC e500 v2.1 core                                                */
5395 ee4e83ed j_mayer
    POWERPC_DEF("e500v2.1",    CPU_POWERPC_e500_v21,    e500),
5396 a750fc0b j_mayer
#endif
5397 a750fc0b j_mayer
#if defined (TODO)
5398 a750fc0b j_mayer
    /* PowerPC e500 v2.2 core                                                */
5399 ee4e83ed j_mayer
    POWERPC_DEF("e500v2.2",    CPU_POWERPC_e500_v22,    e500),
5400 a750fc0b j_mayer
#endif
5401 a750fc0b j_mayer
    /* e600 family                                                           */
5402 a750fc0b j_mayer
#if defined (TODO)
5403 a750fc0b j_mayer
    /* PowerPC e600 core                                                     */
5404 ee4e83ed j_mayer
    POWERPC_DEF("e600",        CPU_POWERPC_e600,        e600),
5405 a750fc0b j_mayer
#endif
5406 a750fc0b j_mayer
    /* PowerPC MPC 5xx cores                                                 */
5407 a750fc0b j_mayer
#if defined (TODO)
5408 a750fc0b j_mayer
    /* PowerPC MPC 5xx                                                       */
5409 ee4e83ed j_mayer
    POWERPC_DEF("mpc5xx",      CPU_POWERPC_5xx,         5xx),
5410 a750fc0b j_mayer
#endif
5411 a750fc0b j_mayer
    /* PowerPC MPC 8xx cores                                                 */
5412 a750fc0b j_mayer
#if defined (TODO)
5413 a750fc0b j_mayer
    /* PowerPC MPC 8xx                                                       */
5414 ee4e83ed j_mayer
    POWERPC_DEF("mpc8xx",      CPU_POWERPC_8xx,         8xx),
5415 a750fc0b j_mayer
#endif
5416 a750fc0b j_mayer
    /* PowerPC MPC 8xxx cores                                                */
5417 a750fc0b j_mayer
#if defined (TODO)
5418 a750fc0b j_mayer
    /* PowerPC MPC 82xx HIP3                                                 */
5419 ee4e83ed j_mayer
    POWERPC_DEF("mpc82xxhip3", CPU_POWERPC_82xx_HIP3,   82xx),
5420 a750fc0b j_mayer
#endif
5421 a750fc0b j_mayer
#if defined (TODO)
5422 a750fc0b j_mayer
    /* PowerPC MPC 82xx HIP4                                                 */
5423 ee4e83ed j_mayer
    POWERPC_DEF("mpc82xxhip4", CPU_POWERPC_82xx_HIP4,   82xx),
5424 a750fc0b j_mayer
#endif
5425 a750fc0b j_mayer
#if defined (TODO)
5426 a750fc0b j_mayer
    /* PowerPC MPC 827x                                                      */
5427 ee4e83ed j_mayer
    POWERPC_DEF("mpc827x",     CPU_POWERPC_827x,        827x),
5428 a750fc0b j_mayer
#endif
5429 a750fc0b j_mayer
5430 a750fc0b j_mayer
    /* 32 bits "classic" PowerPC                                             */
5431 a750fc0b j_mayer
    /* PowerPC 6xx family                                                    */
5432 a750fc0b j_mayer
    /* PowerPC 601                                                           */
5433 ee4e83ed j_mayer
    POWERPC_DEF("601",         CPU_POWERPC_601,         601),
5434 a750fc0b j_mayer
    /* PowerPC 601v2                                                         */
5435 ee4e83ed j_mayer
    POWERPC_DEF("601a",        CPU_POWERPC_601a,        601),
5436 a750fc0b j_mayer
    /* PowerPC 602                                                           */
5437 ee4e83ed j_mayer
    POWERPC_DEF("602",         CPU_POWERPC_602,         602),
5438 a750fc0b j_mayer
    /* PowerPC 603                                                           */
5439 ee4e83ed j_mayer
    POWERPC_DEF("603",         CPU_POWERPC_603,         603),
5440 a750fc0b j_mayer
    /* Code name for PowerPC 603                                             */
5441 ee4e83ed j_mayer
    POWERPC_DEF("Vanilla",     CPU_POWERPC_603,         603),
5442 a750fc0b j_mayer
    /* PowerPC 603e                                                          */
5443 ee4e83ed j_mayer
    POWERPC_DEF("603e",        CPU_POWERPC_603E,        603E),
5444 a750fc0b j_mayer
    /* Code name for PowerPC 603e                                            */
5445 ee4e83ed j_mayer
    POWERPC_DEF("Stretch",     CPU_POWERPC_603E,        603E),
5446 a750fc0b j_mayer
    /* PowerPC 603e v1.1                                                     */
5447 ee4e83ed j_mayer
    POWERPC_DEF("603e1.1",     CPU_POWERPC_603E_v11,    603E),
5448 a750fc0b j_mayer
    /* PowerPC 603e v1.2                                                     */
5449 ee4e83ed j_mayer
    POWERPC_DEF("603e1.2",     CPU_POWERPC_603E_v12,    603E),
5450 a750fc0b j_mayer
    /* PowerPC 603e v1.3                                                     */
5451 ee4e83ed j_mayer
    POWERPC_DEF("603e1.3",     CPU_POWERPC_603E_v13,    603E),
5452 a750fc0b j_mayer
    /* PowerPC 603e v1.4                                                     */
5453 ee4e83ed j_mayer
    POWERPC_DEF("603e1.4",     CPU_POWERPC_603E_v14,    603E),
5454 a750fc0b j_mayer
    /* PowerPC 603e v2.2                                                     */
5455 ee4e83ed j_mayer
    POWERPC_DEF("603e2.2",     CPU_POWERPC_603E_v22,    603E),
5456 a750fc0b j_mayer
    /* PowerPC 603e v3                                                       */
5457 ee4e83ed j_mayer
    POWERPC_DEF("603e3",       CPU_POWERPC_603E_v3,     603E),
5458 a750fc0b j_mayer
    /* PowerPC 603e v4                                                       */
5459 ee4e83ed j_mayer
    POWERPC_DEF("603e4",       CPU_POWERPC_603E_v4,     603E),
5460 a750fc0b j_mayer
    /* PowerPC 603e v4.1                                                     */
5461 ee4e83ed j_mayer
    POWERPC_DEF("603e4.1",     CPU_POWERPC_603E_v41,    603E),
5462 a750fc0b j_mayer
    /* PowerPC 603e                                                          */
5463 ee4e83ed j_mayer
    POWERPC_DEF("603e7",       CPU_POWERPC_603E7,       603E),
5464 a750fc0b j_mayer
    /* PowerPC 603e7t                                                        */
5465 ee4e83ed j_mayer
    POWERPC_DEF("603e7t",      CPU_POWERPC_603E7t,      603E),
5466 a750fc0b j_mayer
    /* PowerPC 603e7v                                                        */
5467 ee4e83ed j_mayer
    POWERPC_DEF("603e7v",      CPU_POWERPC_603E7v,      603E),
5468 a750fc0b j_mayer
    /* Code name for PowerPC 603ev                                           */
5469 ee4e83ed j_mayer
    POWERPC_DEF("Vaillant",    CPU_POWERPC_603E7v,      603E),
5470 a750fc0b j_mayer
    /* PowerPC 603e7v1                                                       */
5471 ee4e83ed j_mayer
    POWERPC_DEF("603e7v1",     CPU_POWERPC_603E7v1,     603E),
5472 a750fc0b j_mayer
    /* PowerPC 603e7v2                                                       */
5473 ee4e83ed j_mayer
    POWERPC_DEF("603e7v2",     CPU_POWERPC_603E7v2,     603E),
5474 a750fc0b j_mayer
    /* PowerPC 603p                                                          */
5475 a750fc0b j_mayer
    /* to be checked */
5476 ee4e83ed j_mayer
    POWERPC_DEF("603p",        CPU_POWERPC_603P,        603),
5477 a750fc0b j_mayer
    /* PowerPC 603r                                                          */
5478 ee4e83ed j_mayer
    POWERPC_DEF("603r",        CPU_POWERPC_603R,        603E),
5479 a750fc0b j_mayer
    /* Code name for PowerPC 603r                                            */
5480 ee4e83ed j_mayer
    POWERPC_DEF("Goldeneye",   CPU_POWERPC_603R,        603E),
5481 a750fc0b j_mayer
    /* PowerPC G2 core                                                       */
5482 ee4e83ed j_mayer
    POWERPC_DEF("G2",          CPU_POWERPC_G2,          G2),
5483 a750fc0b j_mayer
    /* PowerPC G2 H4                                                         */
5484 ee4e83ed j_mayer
    POWERPC_DEF("G2H4",        CPU_POWERPC_G2H4,        G2),
5485 a750fc0b j_mayer
    /* PowerPC G2 GP                                                         */
5486 ee4e83ed j_mayer
    POWERPC_DEF("G2GP",        CPU_POWERPC_G2gp,        G2),
5487 a750fc0b j_mayer
    /* PowerPC G2 LS                                                         */
5488 ee4e83ed j_mayer
    POWERPC_DEF("G2LS",        CPU_POWERPC_G2ls,        G2),
5489 a750fc0b j_mayer
    /* PowerPC G2LE                                                          */
5490 a750fc0b j_mayer
    /* Same as G2, with little-endian mode support                           */
5491 ee4e83ed j_mayer
    POWERPC_DEF("G2le",        CPU_POWERPC_G2LE,        G2LE),
5492 a750fc0b j_mayer
    /* PowerPC G2LE GP                                                       */
5493 ee4e83ed j_mayer
    POWERPC_DEF("G2leGP",      CPU_POWERPC_G2LEgp,      G2LE),
5494 a750fc0b j_mayer
    /* PowerPC G2LE LS                                                       */
5495 ee4e83ed j_mayer
    POWERPC_DEF("G2leLS",      CPU_POWERPC_G2LEls,      G2LE),
5496 a750fc0b j_mayer
    /* PowerPC 604                                                           */
5497 ee4e83ed j_mayer
    POWERPC_DEF("604",         CPU_POWERPC_604,         604),
5498 a750fc0b j_mayer
    /* PowerPC 604e                                                          */
5499 ee4e83ed j_mayer
    /* XXX: code names "Sirocco" "Mach 5" */
5500 ee4e83ed j_mayer
    POWERPC_DEF("604e",        CPU_POWERPC_604E,        604),
5501 a750fc0b j_mayer
    /* PowerPC 604e v1.0                                                     */
5502 ee4e83ed j_mayer
    POWERPC_DEF("604e1.0",     CPU_POWERPC_604E_v10,    604),
5503 a750fc0b j_mayer
    /* PowerPC 604e v2.2                                                     */
5504 ee4e83ed j_mayer
    POWERPC_DEF("604e2.2",     CPU_POWERPC_604E_v22,    604),
5505 a750fc0b j_mayer
    /* PowerPC 604e v2.4                                                     */
5506 ee4e83ed j_mayer
    POWERPC_DEF("604e2.4",     CPU_POWERPC_604E_v24,    604),
5507 a750fc0b j_mayer
    /* PowerPC 604r                                                          */
5508 ee4e83ed j_mayer
    POWERPC_DEF("604r",        CPU_POWERPC_604R,        604),
5509 a750fc0b j_mayer
#if defined(TODO)
5510 a750fc0b j_mayer
    /* PowerPC 604ev                                                         */
5511 ee4e83ed j_mayer
    POWERPC_DEF("604ev",       CPU_POWERPC_604EV,       604),
5512 a750fc0b j_mayer
#endif
5513 a750fc0b j_mayer
    /* PowerPC 7xx family                                                    */
5514 a750fc0b j_mayer
    /* Generic PowerPC 740 (G3)                                              */
5515 ee4e83ed j_mayer
    POWERPC_DEF("740",         CPU_POWERPC_7x0,         7x0),
5516 a750fc0b j_mayer
    /* Generic PowerPC 750 (G3)                                              */
5517 ee4e83ed j_mayer
    POWERPC_DEF("750",         CPU_POWERPC_7x0,         7x0),
5518 a750fc0b j_mayer
    /* Code name for generic PowerPC 740/750 (G3)                            */
5519 ee4e83ed j_mayer
    POWERPC_DEF("Arthur",      CPU_POWERPC_7x0,         7x0),
5520 ee4e83ed j_mayer
    /* XXX: 750 codename "Typhoon" */
5521 a750fc0b j_mayer
    /* PowerPC 740/750 is also known as G3                                   */
5522 ee4e83ed j_mayer
    POWERPC_DEF("G3",          CPU_POWERPC_7x0,         7x0),
5523 a750fc0b j_mayer
    /* PowerPC 740 v2.0 (G3)                                                 */
5524 ee4e83ed j_mayer
    POWERPC_DEF("740v2.0",     CPU_POWERPC_7x0_v20,     7x0),
5525 a750fc0b j_mayer
    /* PowerPC 750 v2.0 (G3)                                                 */
5526 ee4e83ed j_mayer
    POWERPC_DEF("750v2.0",     CPU_POWERPC_7x0_v20,     7x0),
5527 a750fc0b j_mayer
    /* PowerPC 740 v2.1 (G3)                                                 */
5528 ee4e83ed j_mayer
    POWERPC_DEF("740v2.1",     CPU_POWERPC_7x0_v21,     7x0),
5529 a750fc0b j_mayer
    /* PowerPC 750 v2.1 (G3)                                                 */
5530 ee4e83ed j_mayer
    POWERPC_DEF("750v2.1",     CPU_POWERPC_7x0_v21,     7x0),
5531 a750fc0b j_mayer
    /* PowerPC 740 v2.2 (G3)                                                 */
5532 ee4e83ed j_mayer
    POWERPC_DEF("740v2.2",     CPU_POWERPC_7x0_v22,     7x0),
5533 a750fc0b j_mayer
    /* PowerPC 750 v2.2 (G3)                                                 */
5534 ee4e83ed j_mayer
    POWERPC_DEF("750v2.2",     CPU_POWERPC_7x0_v22,     7x0),
5535 a750fc0b j_mayer
    /* PowerPC 740 v3.0 (G3)                                                 */
5536 ee4e83ed j_mayer
    POWERPC_DEF("740v3.0",     CPU_POWERPC_7x0_v30,     7x0),
5537 a750fc0b j_mayer
    /* PowerPC 750 v3.0 (G3)                                                 */
5538 ee4e83ed j_mayer
    POWERPC_DEF("750v3.0",     CPU_POWERPC_7x0_v30,     7x0),
5539 a750fc0b j_mayer
    /* PowerPC 740 v3.1 (G3)                                                 */
5540 ee4e83ed j_mayer
    POWERPC_DEF("740v3.1",     CPU_POWERPC_7x0_v31,     7x0),
5541 a750fc0b j_mayer
    /* PowerPC 750 v3.1 (G3)                                                 */
5542 ee4e83ed j_mayer
    POWERPC_DEF("750v3.1",     CPU_POWERPC_7x0_v31,     7x0),
5543 a750fc0b j_mayer
    /* PowerPC 740E (G3)                                                     */
5544 ee4e83ed j_mayer
    POWERPC_DEF("740e",        CPU_POWERPC_740E,        7x0),
5545 a750fc0b j_mayer
    /* PowerPC 740P (G3)                                                     */
5546 ee4e83ed j_mayer
    POWERPC_DEF("740p",        CPU_POWERPC_7x0P,        7x0),
5547 a750fc0b j_mayer
    /* PowerPC 750P (G3)                                                     */
5548 ee4e83ed j_mayer
    POWERPC_DEF("750p",        CPU_POWERPC_7x0P,        7x0),
5549 a750fc0b j_mayer
    /* Code name for PowerPC 740P/750P (G3)                                  */
5550 ee4e83ed j_mayer
    POWERPC_DEF("Conan/Doyle", CPU_POWERPC_7x0P,        7x0),
5551 a750fc0b j_mayer
    /* PowerPC 750CL (G3 embedded)                                           */
5552 ee4e83ed j_mayer
    POWERPC_DEF("750cl",       CPU_POWERPC_750CL,       7x0),
5553 a750fc0b j_mayer
    /* PowerPC 750CX (G3 embedded)                                           */
5554 ee4e83ed j_mayer
    POWERPC_DEF("750cx",       CPU_POWERPC_750CX,       7x0),
5555 a750fc0b j_mayer
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
5556 ee4e83ed j_mayer
    POWERPC_DEF("750cx2.1",    CPU_POWERPC_750CX_v21,   7x0),
5557 a750fc0b j_mayer
    /* PowerPC 750CX v2.2 (G3 embedded)                                      */
5558 ee4e83ed j_mayer
    POWERPC_DEF("750cx2.2",    CPU_POWERPC_750CX_v22,   7x0),
5559 a750fc0b j_mayer
    /* PowerPC 750CXe (G3 embedded)                                          */
5560 ee4e83ed j_mayer
    POWERPC_DEF("750cxe",      CPU_POWERPC_750CXE,      7x0),
5561 a750fc0b j_mayer
    /* PowerPC 750CXe v2.1 (G3 embedded)                                     */
5562 ee4e83ed j_mayer
    POWERPC_DEF("750cxe21",    CPU_POWERPC_750CXE_v21,  7x0),
5563 a750fc0b j_mayer
    /* PowerPC 750CXe v2.2 (G3 embedded)                                     */
5564 ee4e83ed j_mayer
    POWERPC_DEF("750cxe22",    CPU_POWERPC_750CXE_v22,  7x0),
5565 a750fc0b j_mayer
    /* PowerPC 750CXe v2.3 (G3 embedded)                                     */
5566 ee4e83ed j_mayer
    POWERPC_DEF("750cxe23",    CPU_POWERPC_750CXE_v23,  7x0),
5567 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4 (G3 embedded)                                     */
5568 ee4e83ed j_mayer
    POWERPC_DEF("750cxe24",    CPU_POWERPC_750CXE_v24,  7x0),
5569 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4b (G3 embedded)                                    */
5570 ee4e83ed j_mayer
    POWERPC_DEF("750cxe24b",   CPU_POWERPC_750CXE_v24b, 7x0),
5571 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1 (G3 embedded)                                     */
5572 ee4e83ed j_mayer
    POWERPC_DEF("750cxe31",    CPU_POWERPC_750CXE_v31,  7x0),
5573 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1b (G3 embedded)                                    */
5574 ee4e83ed j_mayer
    POWERPC_DEF("750cxe3.1b",  CPU_POWERPC_750CXE_v31b, 7x0),
5575 a750fc0b j_mayer
    /* PowerPC 750CXr (G3 embedded)                                          */
5576 ee4e83ed j_mayer
    POWERPC_DEF("750cxr",      CPU_POWERPC_750CXR,      7x0),
5577 a750fc0b j_mayer
    /* PowerPC 750E (G3)                                                     */
5578 ee4e83ed j_mayer
    POWERPC_DEF("750e",        CPU_POWERPC_750E,        7x0),
5579 a750fc0b j_mayer
    /* PowerPC 750FL (G3 embedded)                                           */
5580 ee4e83ed j_mayer
    POWERPC_DEF("750fl",       CPU_POWERPC_750FL,       750fx),
5581 a750fc0b j_mayer
    /* PowerPC 750FX (G3 embedded)                                           */
5582 ee4e83ed j_mayer
    POWERPC_DEF("750fx",       CPU_POWERPC_750FX,       750fx),
5583 a750fc0b j_mayer
    /* PowerPC 750FX v1.0 (G3 embedded)                                      */
5584 ee4e83ed j_mayer
    POWERPC_DEF("750fx1.0",    CPU_POWERPC_750FX_v10,   750fx),
5585 a750fc0b j_mayer
    /* PowerPC 750FX v2.0 (G3 embedded)                                      */
5586 ee4e83ed j_mayer
    POWERPC_DEF("750fx2.0",    CPU_POWERPC_750FX_v20,   750fx),
5587 a750fc0b j_mayer
    /* PowerPC 750FX v2.1 (G3 embedded)                                      */
5588 ee4e83ed j_mayer
    POWERPC_DEF("750fx2.1",    CPU_POWERPC_750FX_v21,   750fx),
5589 a750fc0b j_mayer
    /* PowerPC 750FX v2.2 (G3 embedded)                                      */
5590 ee4e83ed j_mayer
    POWERPC_DEF("750fx2.2",    CPU_POWERPC_750FX_v22,   750fx),
5591 a750fc0b j_mayer
    /* PowerPC 750FX v2.3 (G3 embedded)                                      */
5592 ee4e83ed j_mayer
    POWERPC_DEF("750fx2.3",    CPU_POWERPC_750FX_v23,   750fx),
5593 a750fc0b j_mayer
    /* PowerPC 750GL (G3 embedded)                                           */
5594 ee4e83ed j_mayer
    POWERPC_DEF("750gl",       CPU_POWERPC_750GL,       750fx),
5595 a750fc0b j_mayer
    /* PowerPC 750GX (G3 embedded)                                           */
5596 ee4e83ed j_mayer
    POWERPC_DEF("750gx",       CPU_POWERPC_750GX,       750fx),
5597 a750fc0b j_mayer
    /* PowerPC 750GX v1.0 (G3 embedded)                                      */
5598 ee4e83ed j_mayer
    POWERPC_DEF("750gx1.0",    CPU_POWERPC_750GX_v10,   750fx),
5599 a750fc0b j_mayer
    /* PowerPC 750GX v1.1 (G3 embedded)                                      */
5600 ee4e83ed j_mayer
    POWERPC_DEF("750gx1.1",    CPU_POWERPC_750GX_v11,   750fx),
5601 a750fc0b j_mayer
    /* PowerPC 750GX v1.2 (G3 embedded)                                      */
5602 ee4e83ed j_mayer
    POWERPC_DEF("750gx1.2",    CPU_POWERPC_750GX_v12,   750fx),
5603 a750fc0b j_mayer
    /* PowerPC 750L (G3 embedded)                                            */
5604 ee4e83ed j_mayer
    POWERPC_DEF("750l",        CPU_POWERPC_750L,        7x0),
5605 a750fc0b j_mayer
    /* Code name for PowerPC 750L (G3 embedded)                              */
5606 ee4e83ed j_mayer
    POWERPC_DEF("LoneStar",    CPU_POWERPC_750L,        7x0),
5607 a750fc0b j_mayer
    /* PowerPC 750L v2.2 (G3 embedded)                                       */
5608 ee4e83ed j_mayer
    POWERPC_DEF("750l2.2",     CPU_POWERPC_750L_v22,    7x0),
5609 a750fc0b j_mayer
    /* PowerPC 750L v3.0 (G3 embedded)                                       */
5610 ee4e83ed j_mayer
    POWERPC_DEF("750l3.0",     CPU_POWERPC_750L_v30,    7x0),
5611 a750fc0b j_mayer
    /* PowerPC 750L v3.2 (G3 embedded)                                       */
5612 ee4e83ed j_mayer
    POWERPC_DEF("750l3.2",     CPU_POWERPC_750L_v32,    7x0),
5613 a750fc0b j_mayer
    /* Generic PowerPC 745                                                   */
5614 ee4e83ed j_mayer
    POWERPC_DEF("745",         CPU_POWERPC_7x5,         7x5),
5615 a750fc0b j_mayer
    /* Generic PowerPC 755                                                   */
5616 ee4e83ed j_mayer
    POWERPC_DEF("755",         CPU_POWERPC_7x5,         7x5),
5617 a750fc0b j_mayer
    /* Code name for PowerPC 745/755                                         */
5618 ee4e83ed j_mayer
    POWERPC_DEF("Goldfinger",  CPU_POWERPC_7x5,         7x5),
5619 a750fc0b j_mayer
    /* PowerPC 745 v1.0                                                      */
5620 ee4e83ed j_mayer
    POWERPC_DEF("745v1.0",     CPU_POWERPC_7x5_v10,     7x5),
5621 a750fc0b j_mayer
    /* PowerPC 755 v1.0                                                      */
5622 ee4e83ed j_mayer
    POWERPC_DEF("755v1.0",     CPU_POWERPC_7x5_v10,     7x5),
5623 a750fc0b j_mayer
    /* PowerPC 745 v1.1                                                      */
5624 ee4e83ed j_mayer
    POWERPC_DEF("745v1.1",     CPU_POWERPC_7x5_v11,     7x5),
5625 a750fc0b j_mayer
    /* PowerPC 755 v1.1                                                      */
5626 ee4e83ed j_mayer
    POWERPC_DEF("755v1.1",     CPU_POWERPC_7x5_v11,     7x5),
5627 a750fc0b j_mayer
    /* PowerPC 745 v2.0                                                      */
5628 ee4e83ed j_mayer
    POWERPC_DEF("745v2.0",     CPU_POWERPC_7x5_v20,     7x5),
5629 a750fc0b j_mayer
    /* PowerPC 755 v2.0                                                      */
5630 ee4e83ed j_mayer
    POWERPC_DEF("755v2.0",     CPU_POWERPC_7x5_v20,     7x5),
5631 a750fc0b j_mayer
    /* PowerPC 745 v2.1                                                      */
5632 ee4e83ed j_mayer
    POWERPC_DEF("745v2.1",     CPU_POWERPC_7x5_v21,     7x5),
5633 a750fc0b j_mayer
    /* PowerPC 755 v2.1                                                      */
5634 ee4e83ed j_mayer
    POWERPC_DEF("755v2.1",     CPU_POWERPC_7x5_v21,     7x5),
5635 a750fc0b j_mayer
    /* PowerPC 745 v2.2                                                      */
5636 ee4e83ed j_mayer
    POWERPC_DEF("745v2.2",     CPU_POWERPC_7x5_v22,     7x5),
5637 a750fc0b j_mayer
    /* PowerPC 755 v2.2                                                      */
5638 ee4e83ed j_mayer
    POWERPC_DEF("755v2.2",     CPU_POWERPC_7x5_v22,     7x5),
5639 a750fc0b j_mayer
    /* PowerPC 745 v2.3                                                      */
5640 ee4e83ed j_mayer
    POWERPC_DEF("745v2.3",     CPU_POWERPC_7x5_v23,     7x5),
5641 a750fc0b j_mayer
    /* PowerPC 755 v2.3                                                      */
5642 ee4e83ed j_mayer
    POWERPC_DEF("755v2.3",     CPU_POWERPC_7x5_v23,     7x5),
5643 a750fc0b j_mayer
    /* PowerPC 745 v2.4                                                      */
5644 ee4e83ed j_mayer
    POWERPC_DEF("745v2.4",     CPU_POWERPC_7x5_v24,     7x5),
5645 a750fc0b j_mayer
    /* PowerPC 755 v2.4                                                      */
5646 ee4e83ed j_mayer
    POWERPC_DEF("755v2.4",     CPU_POWERPC_7x5_v24,     7x5),
5647 a750fc0b j_mayer
    /* PowerPC 745 v2.5                                                      */
5648 ee4e83ed j_mayer
    POWERPC_DEF("745v2.5",     CPU_POWERPC_7x5_v25,     7x5),
5649 a750fc0b j_mayer
    /* PowerPC 755 v2.5                                                      */
5650 ee4e83ed j_mayer
    POWERPC_DEF("755v2.5",     CPU_POWERPC_7x5_v25,     7x5),
5651 a750fc0b j_mayer
    /* PowerPC 745 v2.6                                                      */
5652 ee4e83ed j_mayer
    POWERPC_DEF("745v2.6",     CPU_POWERPC_7x5_v26,     7x5),
5653 a750fc0b j_mayer
    /* PowerPC 755 v2.6                                                      */
5654 ee4e83ed j_mayer
    POWERPC_DEF("755v2.6",     CPU_POWERPC_7x5_v26,     7x5),
5655 a750fc0b j_mayer
    /* PowerPC 745 v2.7                                                      */
5656 ee4e83ed j_mayer
    POWERPC_DEF("745v2.7",     CPU_POWERPC_7x5_v27,     7x5),
5657 a750fc0b j_mayer
    /* PowerPC 755 v2.7                                                      */
5658 ee4e83ed j_mayer
    POWERPC_DEF("755v2.7",     CPU_POWERPC_7x5_v27,     7x5),
5659 a750fc0b j_mayer
    /* PowerPC 745 v2.8                                                      */
5660 ee4e83ed j_mayer
    POWERPC_DEF("745v2.8",     CPU_POWERPC_7x5_v28,     7x5),
5661 a750fc0b j_mayer
    /* PowerPC 755 v2.8                                                      */
5662 ee4e83ed j_mayer
    POWERPC_DEF("755v2.8",     CPU_POWERPC_7x5_v28,     7x5),
5663 a750fc0b j_mayer
#if defined (TODO)
5664 a750fc0b j_mayer
    /* PowerPC 745P (G3)                                                     */
5665 ee4e83ed j_mayer
    POWERPC_DEF("745p",        CPU_POWERPC_7x5P,        7x5),
5666 a750fc0b j_mayer
    /* PowerPC 755P (G3)                                                     */
5667 ee4e83ed j_mayer
    POWERPC_DEF("755p",        CPU_POWERPC_7x5P,        7x5),
5668 a750fc0b j_mayer
#endif
5669 a750fc0b j_mayer
    /* PowerPC 74xx family                                                   */
5670 a750fc0b j_mayer
    /* PowerPC 7400 (G4)                                                     */
5671 ee4e83ed j_mayer
    POWERPC_DEF("7400",        CPU_POWERPC_7400,        7400),
5672 a750fc0b j_mayer
    /* Code name for PowerPC 7400                                            */
5673 ee4e83ed j_mayer
    POWERPC_DEF("Max",         CPU_POWERPC_7400,        7400),
5674 a750fc0b j_mayer
    /* PowerPC 74xx is also well known as G4                                 */
5675 ee4e83ed j_mayer
    POWERPC_DEF("G4",          CPU_POWERPC_7400,        7400),
5676 a750fc0b j_mayer
    /* PowerPC 7400 v1.0 (G4)                                                */
5677 ee4e83ed j_mayer
    POWERPC_DEF("7400v1.0",    CPU_POWERPC_7400_v10,    7400),
5678 a750fc0b j_mayer
    /* PowerPC 7400 v1.1 (G4)                                                */
5679 ee4e83ed j_mayer
    POWERPC_DEF("7400v1.1",    CPU_POWERPC_7400_v11,    7400),
5680 a750fc0b j_mayer
    /* PowerPC 7400 v2.0 (G4)                                                */
5681 ee4e83ed j_mayer
    POWERPC_DEF("7400v2.0",    CPU_POWERPC_7400_v20,    7400),
5682 a750fc0b j_mayer
    /* PowerPC 7400 v2.2 (G4)                                                */
5683 ee4e83ed j_mayer
    POWERPC_DEF("7400v2.2",    CPU_POWERPC_7400_v22,    7400),
5684 a750fc0b j_mayer
    /* PowerPC 7400 v2.6 (G4)                                                */
5685 ee4e83ed j_mayer
    POWERPC_DEF("7400v2.6",    CPU_POWERPC_7400_v26,    7400),
5686 a750fc0b j_mayer
    /* PowerPC 7400 v2.7 (G4)                                                */
5687 ee4e83ed j_mayer
    POWERPC_DEF("7400v2.7",    CPU_POWERPC_7400_v27,    7400),
5688 a750fc0b j_mayer
    /* PowerPC 7400 v2.8 (G4)                                                */
5689 ee4e83ed j_mayer
    POWERPC_DEF("7400v2.8",    CPU_POWERPC_7400_v28,    7400),
5690 a750fc0b j_mayer
    /* PowerPC 7400 v2.9 (G4)                                                */
5691 ee4e83ed j_mayer
    POWERPC_DEF("7400v2.9",    CPU_POWERPC_7400_v29,    7400),
5692 a750fc0b j_mayer
    /* PowerPC 7410 (G4)                                                     */
5693 ee4e83ed j_mayer
    POWERPC_DEF("7410",        CPU_POWERPC_7410,        7410),
5694 a750fc0b j_mayer
    /* Code name for PowerPC 7410                                            */
5695 ee4e83ed j_mayer
    POWERPC_DEF("Nitro",       CPU_POWERPC_7410,        7410),
5696 a750fc0b j_mayer
    /* PowerPC 7410 v1.0 (G4)                                                */
5697 ee4e83ed j_mayer
    POWERPC_DEF("7410v1.0",    CPU_POWERPC_7410_v10,    7410),
5698 a750fc0b j_mayer
    /* PowerPC 7410 v1.1 (G4)                                                */
5699 ee4e83ed j_mayer
    POWERPC_DEF("7410v1.1",    CPU_POWERPC_7410_v11,    7410),
5700 a750fc0b j_mayer
    /* PowerPC 7410 v1.2 (G4)                                                */
5701 ee4e83ed j_mayer
    POWERPC_DEF("7410v1.2",    CPU_POWERPC_7410_v12,    7410),
5702 a750fc0b j_mayer
    /* PowerPC 7410 v1.3 (G4)                                                */
5703 ee4e83ed j_mayer
    POWERPC_DEF("7410v1.3",    CPU_POWERPC_7410_v13,    7410),
5704 a750fc0b j_mayer
    /* PowerPC 7410 v1.4 (G4)                                                */
5705 ee4e83ed j_mayer
    POWERPC_DEF("7410v1.4",    CPU_POWERPC_7410_v14,    7410),
5706 a750fc0b j_mayer
    /* PowerPC 7448 (G4)                                                     */
5707 ee4e83ed j_mayer
    POWERPC_DEF("7448",        CPU_POWERPC_7448,        7400),
5708 a750fc0b j_mayer
    /* PowerPC 7448 v1.0 (G4)                                                */
5709 ee4e83ed j_mayer
    POWERPC_DEF("7448v1.0",    CPU_POWERPC_7448_v10,    7400),
5710 a750fc0b j_mayer
    /* PowerPC 7448 v1.1 (G4)                                                */
5711 ee4e83ed j_mayer
    POWERPC_DEF("7448v1.1",    CPU_POWERPC_7448_v11,    7400),
5712 a750fc0b j_mayer
    /* PowerPC 7448 v2.0 (G4)                                                */
5713 ee4e83ed j_mayer
    POWERPC_DEF("7448v2.0",    CPU_POWERPC_7448_v20,    7400),
5714 a750fc0b j_mayer
    /* PowerPC 7448 v2.1 (G4)                                                */
5715 ee4e83ed j_mayer
    POWERPC_DEF("7448v2.1",    CPU_POWERPC_7448_v21,    7400),
5716 a750fc0b j_mayer
    /* PowerPC 7450 (G4)                                                     */
5717 ee4e83ed j_mayer
    POWERPC_DEF("7450",        CPU_POWERPC_7450,        7450),
5718 a750fc0b j_mayer
    /* Code name for PowerPC 7450                                            */
5719 ee4e83ed j_mayer
    POWERPC_DEF("Vger",        CPU_POWERPC_7450,        7450),
5720 a750fc0b j_mayer
    /* PowerPC 7450 v1.0 (G4)                                                */
5721 ee4e83ed j_mayer
    POWERPC_DEF("7450v1.0",    CPU_POWERPC_7450_v10,    7450),
5722 a750fc0b j_mayer
    /* PowerPC 7450 v1.1 (G4)                                                */
5723 ee4e83ed j_mayer
    POWERPC_DEF("7450v1.1",    CPU_POWERPC_7450_v11,    7450),
5724 a750fc0b j_mayer
    /* PowerPC 7450 v1.2 (G4)                                                */
5725 ee4e83ed j_mayer
    POWERPC_DEF("7450v1.2",    CPU_POWERPC_7450_v12,    7450),
5726 a750fc0b j_mayer
    /* PowerPC 7450 v2.0 (G4)                                                */
5727 ee4e83ed j_mayer
    POWERPC_DEF("7450v2.0",    CPU_POWERPC_7450_v20,    7450),
5728 a750fc0b j_mayer
    /* PowerPC 7450 v2.1 (G4)                                                */
5729 ee4e83ed j_mayer
    POWERPC_DEF("7450v2.1",    CPU_POWERPC_7450_v21,    7450),
5730 a750fc0b j_mayer
    /* PowerPC 7441 (G4)                                                     */
5731 ee4e83ed j_mayer
    POWERPC_DEF("7441",        CPU_POWERPC_74x1,        7440),
5732 a750fc0b j_mayer
    /* PowerPC 7451 (G4)                                                     */
5733 ee4e83ed j_mayer
    POWERPC_DEF("7451",        CPU_POWERPC_74x1,        7450),
5734 a750fc0b j_mayer
    /* PowerPC 7441g (G4)                                                    */
5735 ee4e83ed j_mayer
    POWERPC_DEF("7441g",       CPU_POWERPC_74x1G,       7440),
5736 a750fc0b j_mayer
    /* PowerPC 7451g (G4)                                                    */
5737 ee4e83ed j_mayer
    POWERPC_DEF("7451g",       CPU_POWERPC_74x1G,       7450),
5738 a750fc0b j_mayer
    /* PowerPC 7445 (G4)                                                     */
5739 ee4e83ed j_mayer
    POWERPC_DEF("7445",        CPU_POWERPC_74x5,        7445),
5740 a750fc0b j_mayer
    /* PowerPC 7455 (G4)                                                     */
5741 ee4e83ed j_mayer
    POWERPC_DEF("7455",        CPU_POWERPC_74x5,        7455),
5742 a750fc0b j_mayer
    /* Code name for PowerPC 7445/7455                                       */
5743 ee4e83ed j_mayer
    POWERPC_DEF("Apollo6",     CPU_POWERPC_74x5,        7455),
5744 a750fc0b j_mayer
    /* PowerPC 7445 v1.0 (G4)                                                */
5745 ee4e83ed j_mayer
    POWERPC_DEF("7445v1.0",    CPU_POWERPC_74x5_v10,    7445),
5746 a750fc0b j_mayer
    /* PowerPC 7455 v1.0 (G4)                                                */
5747 ee4e83ed j_mayer
    POWERPC_DEF("7455v1.0",    CPU_POWERPC_74x5_v10,    7455),
5748 a750fc0b j_mayer
    /* PowerPC 7445 v2.1 (G4)                                                */
5749 ee4e83ed j_mayer
    POWERPC_DEF("7445v2.1",    CPU_POWERPC_74x5_v21,    7445),
5750 a750fc0b j_mayer
    /* PowerPC 7455 v2.1 (G4)                                                */
5751 ee4e83ed j_mayer
    POWERPC_DEF("7455v2.1",    CPU_POWERPC_74x5_v21,    7455),
5752 a750fc0b j_mayer
    /* PowerPC 7445 v3.2 (G4)                                                */
5753 ee4e83ed j_mayer
    POWERPC_DEF("7445v3.2",    CPU_POWERPC_74x5_v32,    7445),
5754 a750fc0b j_mayer
    /* PowerPC 7455 v3.2 (G4)                                                */
5755 ee4e83ed j_mayer
    POWERPC_DEF("7455v3.2",    CPU_POWERPC_74x5_v32,    7455),
5756 a750fc0b j_mayer
    /* PowerPC 7445 v3.3 (G4)                                                */
5757 ee4e83ed j_mayer
    POWERPC_DEF("7445v3.3",    CPU_POWERPC_74x5_v33,    7445),
5758 a750fc0b j_mayer
    /* PowerPC 7455 v3.3 (G4)                                                */
5759 ee4e83ed j_mayer
    POWERPC_DEF("7455v3.3",    CPU_POWERPC_74x5_v33,    7455),
5760 a750fc0b j_mayer
    /* PowerPC 7445 v3.4 (G4)                                                */
5761 ee4e83ed j_mayer
    POWERPC_DEF("7445v3.4",    CPU_POWERPC_74x5_v34,    7445),
5762 a750fc0b j_mayer
    /* PowerPC 7455 v3.4 (G4)                                                */
5763 ee4e83ed j_mayer
    POWERPC_DEF("7455v3.4",    CPU_POWERPC_74x5_v34,    7455),
5764 a750fc0b j_mayer
    /* PowerPC 7447 (G4)                                                     */
5765 ee4e83ed j_mayer
    POWERPC_DEF("7447",        CPU_POWERPC_74x7,        7445),
5766 a750fc0b j_mayer
    /* PowerPC 7457 (G4)                                                     */
5767 ee4e83ed j_mayer
    POWERPC_DEF("7457",        CPU_POWERPC_74x7,        7455),
5768 a750fc0b j_mayer
    /* Code name for PowerPC 7447/7457                                       */
5769 ee4e83ed j_mayer
    POWERPC_DEF("Apollo7",     CPU_POWERPC_74x7,        7455),
5770 a750fc0b j_mayer
    /* PowerPC 7447 v1.0 (G4)                                                */
5771 ee4e83ed j_mayer
    POWERPC_DEF("7447v1.0",    CPU_POWERPC_74x7_v10,    7445),
5772 a750fc0b j_mayer
    /* PowerPC 7457 v1.0 (G4)                                                */
5773 ee4e83ed j_mayer
    POWERPC_DEF("7457v1.0",    CPU_POWERPC_74x7_v10,    7455),
5774 a750fc0b j_mayer
    /* Code name for PowerPC 7447A/7457A                                     */
5775 ee4e83ed j_mayer
    POWERPC_DEF("Apollo7PM",   CPU_POWERPC_74x7_v10,    7455),
5776 a750fc0b j_mayer
    /* PowerPC 7447 v1.1 (G4)                                                */
5777 ee4e83ed j_mayer
    POWERPC_DEF("7447v1.1",    CPU_POWERPC_74x7_v11,    7445),
5778 a750fc0b j_mayer
    /* PowerPC 7457 v1.1 (G4)                                                */
5779 ee4e83ed j_mayer
    POWERPC_DEF("7457v1.1",    CPU_POWERPC_74x7_v11,    7455),
5780 a750fc0b j_mayer
    /* PowerPC 7447 v1.2 (G4)                                                */
5781 ee4e83ed j_mayer
    POWERPC_DEF("7447v1.2",    CPU_POWERPC_74x7_v12,    7445),
5782 a750fc0b j_mayer
    /* PowerPC 7457 v1.2 (G4)                                                */
5783 ee4e83ed j_mayer
    POWERPC_DEF("7457v1.2",    CPU_POWERPC_74x7_v12,    7455),
5784 a750fc0b j_mayer
    /* 64 bits PowerPC                                                       */
5785 a750fc0b j_mayer
#if defined (TARGET_PPC64)
5786 a750fc0b j_mayer
    /* PowerPC 620                                                           */
5787 ee4e83ed j_mayer
    /* XXX: code name "Trident" */
5788 ee4e83ed j_mayer
    POWERPC_DEF("620",         CPU_POWERPC_620,         620),
5789 3fc6c082 bellard
#if defined (TODO)
5790 a750fc0b j_mayer
    /* PowerPC 630 (POWER3)                                                  */
5791 ee4e83ed j_mayer
    /* XXX: code names: "Boxer" "Dino" */
5792 ee4e83ed j_mayer
    POWERPC_DEF("630",         CPU_POWERPC_630,         630),
5793 ee4e83ed j_mayer
    POWERPC_DEF("POWER3",      CPU_POWERPC_630,         630),
5794 a750fc0b j_mayer
#endif
5795 3a607854 j_mayer
#if defined (TODO)
5796 a750fc0b j_mayer
    /* PowerPC 631 (Power 3+)                                                */
5797 ee4e83ed j_mayer
    POWERPC_DEF("631",         CPU_POWERPC_631,         631),
5798 ee4e83ed j_mayer
    POWERPC_DEF("POWER3+",     CPU_POWERPC_631,         631),
5799 3a607854 j_mayer
#endif
5800 3a607854 j_mayer
#if defined (TODO)
5801 a750fc0b j_mayer
    /* POWER4                                                                */
5802 ee4e83ed j_mayer
    POWERPC_DEF("POWER4",      CPU_POWERPC_POWER4,      POWER4),
5803 a750fc0b j_mayer
#endif
5804 3a607854 j_mayer
#if defined (TODO)
5805 a750fc0b j_mayer
    /* POWER4p                                                               */
5806 ee4e83ed j_mayer
    POWERPC_DEF("POWER4+",     CPU_POWERPC_POWER4P,     POWER4P),
5807 a750fc0b j_mayer
#endif
5808 3a607854 j_mayer
#if defined (TODO)
5809 a750fc0b j_mayer
    /* POWER5                                                                */
5810 ee4e83ed j_mayer
    POWERPC_DEF("POWER5",      CPU_POWERPC_POWER5,      POWER5),
5811 a750fc0b j_mayer
    /* POWER5GR                                                              */
5812 ee4e83ed j_mayer
    POWERPC_DEF("POWER5gr",    CPU_POWERPC_POWER5GR,    POWER5),
5813 2662a059 j_mayer
#endif
5814 2662a059 j_mayer
#if defined (TODO)
5815 a750fc0b j_mayer
    /* POWER5+                                                               */
5816 ee4e83ed j_mayer
    POWERPC_DEF("POWER5+",     CPU_POWERPC_POWER5P,     POWER5P),
5817 a750fc0b j_mayer
    /* POWER5GS                                                              */
5818 ee4e83ed j_mayer
    POWERPC_DEF("POWER5gs",    CPU_POWERPC_POWER5GS,    POWER5P),
5819 a750fc0b j_mayer
#endif
5820 2662a059 j_mayer
#if defined (TODO)
5821 a750fc0b j_mayer
    /* POWER6                                                                */
5822 ee4e83ed j_mayer
    POWERPC_DEF("POWER6",      CPU_POWERPC_POWER6,      POWER6),
5823 a750fc0b j_mayer
    /* POWER6 running in POWER5 mode                                         */
5824 ee4e83ed j_mayer
    POWERPC_DEF("POWER6_5",    CPU_POWERPC_POWER6_5,    POWER5),
5825 a750fc0b j_mayer
    /* POWER6A                                                               */
5826 ee4e83ed j_mayer
    POWERPC_DEF("POWER6A",     CPU_POWERPC_POWER6A,     POWER6),
5827 2662a059 j_mayer
#endif
5828 a750fc0b j_mayer
    /* PowerPC 970                                                           */
5829 ee4e83ed j_mayer
    POWERPC_DEF("970",         CPU_POWERPC_970,         970),
5830 a750fc0b j_mayer
    /* PowerPC 970FX (G5)                                                    */
5831 ee4e83ed j_mayer
    POWERPC_DEF("970fx",       CPU_POWERPC_970FX,       970FX),
5832 a750fc0b j_mayer
    /* PowerPC 970FX v1.0 (G5)                                               */
5833 ee4e83ed j_mayer
    POWERPC_DEF("970fx1.0",    CPU_POWERPC_970FX_v10,   970FX),
5834 a750fc0b j_mayer
    /* PowerPC 970FX v2.0 (G5)                                               */
5835 ee4e83ed j_mayer
    POWERPC_DEF("970fx2.0",    CPU_POWERPC_970FX_v20,   970FX),
5836 a750fc0b j_mayer
    /* PowerPC 970FX v2.1 (G5)                                               */
5837 ee4e83ed j_mayer
    POWERPC_DEF("970fx2.1",    CPU_POWERPC_970FX_v21,   970FX),
5838 a750fc0b j_mayer
    /* PowerPC 970FX v3.0 (G5)                                               */
5839 ee4e83ed j_mayer
    POWERPC_DEF("970fx3.0",    CPU_POWERPC_970FX_v30,   970FX),
5840 a750fc0b j_mayer
    /* PowerPC 970FX v3.1 (G5)                                               */
5841 ee4e83ed j_mayer
    POWERPC_DEF("970fx3.1",    CPU_POWERPC_970FX_v31,   970FX),
5842 a750fc0b j_mayer
    /* PowerPC 970GX (G5)                                                    */
5843 ee4e83ed j_mayer
    POWERPC_DEF("970gx",       CPU_POWERPC_970GX,       970GX),
5844 a750fc0b j_mayer
    /* PowerPC 970MP                                                         */
5845 ee4e83ed j_mayer
    POWERPC_DEF("970mp",       CPU_POWERPC_970MP,       970MP),
5846 a750fc0b j_mayer
    /* PowerPC 970MP v1.0                                                    */
5847 ee4e83ed j_mayer
    POWERPC_DEF("970mp1.0",    CPU_POWERPC_970MP_v10,   970MP),
5848 a750fc0b j_mayer
    /* PowerPC 970MP v1.1                                                    */
5849 ee4e83ed j_mayer
    POWERPC_DEF("970mp1.1",    CPU_POWERPC_970MP_v11,   970MP),
5850 3a607854 j_mayer
#if defined (TODO)
5851 a750fc0b j_mayer
    /* PowerPC Cell                                                          */
5852 ee4e83ed j_mayer
    POWERPC_DEF("Cell",        CPU_POWERPC_CELL,        970),
5853 2662a059 j_mayer
#endif
5854 2662a059 j_mayer
#if defined (TODO)
5855 a750fc0b j_mayer
    /* PowerPC Cell v1.0                                                     */
5856 ee4e83ed j_mayer
    POWERPC_DEF("Cell1.0",     CPU_POWERPC_CELL_v10,    970),
5857 2662a059 j_mayer
#endif
5858 2662a059 j_mayer
#if defined (TODO)
5859 a750fc0b j_mayer
    /* PowerPC Cell v2.0                                                     */
5860 ee4e83ed j_mayer
    POWERPC_DEF("Cell2.0",     CPU_POWERPC_CELL_v20,    970),
5861 2662a059 j_mayer
#endif
5862 2662a059 j_mayer
#if defined (TODO)
5863 a750fc0b j_mayer
    /* PowerPC Cell v3.0                                                     */
5864 ee4e83ed j_mayer
    POWERPC_DEF("Cell3.0",     CPU_POWERPC_CELL_v30,    970),
5865 3a607854 j_mayer
#endif
5866 3a607854 j_mayer
#if defined (TODO)
5867 a750fc0b j_mayer
    /* PowerPC Cell v3.1                                                     */
5868 ee4e83ed j_mayer
    POWERPC_DEF("Cell3.1",     CPU_POWERPC_CELL_v31,    970),
5869 2662a059 j_mayer
#endif
5870 2662a059 j_mayer
#if defined (TODO)
5871 a750fc0b j_mayer
    /* PowerPC Cell v3.2                                                     */
5872 ee4e83ed j_mayer
    POWERPC_DEF("Cell3.2",     CPU_POWERPC_CELL_v32,    970),
5873 2662a059 j_mayer
#endif
5874 2662a059 j_mayer
#if defined (TODO)
5875 a750fc0b j_mayer
    /* RS64 (Apache/A35)                                                     */
5876 a750fc0b j_mayer
    /* This one seems to support the whole POWER2 instruction set
5877 a750fc0b j_mayer
     * and the PowerPC 64 one.
5878 a750fc0b j_mayer
     */
5879 a750fc0b j_mayer
    /* What about A10 & A30 ? */
5880 ee4e83ed j_mayer
    POWERPC_DEF("RS64",        CPU_POWERPC_RS64,        RS64),
5881 ee4e83ed j_mayer
    POWERPC_DEF("Apache",      CPU_POWERPC_RS64,        RS64),
5882 ee4e83ed j_mayer
    POWERPC_DEF("A35",         CPU_POWERPC_RS64,        RS64),
5883 3a607854 j_mayer
#endif
5884 3a607854 j_mayer
#if defined (TODO)
5885 a750fc0b j_mayer
    /* RS64-II (NorthStar/A50)                                               */
5886 ee4e83ed j_mayer
    POWERPC_DEF("RS64-II",     CPU_POWERPC_RS64II,      RS64),
5887 ee4e83ed j_mayer
    POWERPC_DEF("NorthStar",   CPU_POWERPC_RS64II,      RS64),
5888 ee4e83ed j_mayer
    POWERPC_DEF("A50",         CPU_POWERPC_RS64II,      RS64),
5889 3a607854 j_mayer
#endif
5890 3a607854 j_mayer
#if defined (TODO)
5891 a750fc0b j_mayer
    /* RS64-III (Pulsar)                                                     */
5892 ee4e83ed j_mayer
    POWERPC_DEF("RS64-III",    CPU_POWERPC_RS64III,     RS64),
5893 ee4e83ed j_mayer
    POWERPC_DEF("Pulsar",      CPU_POWERPC_RS64III,     RS64),
5894 2662a059 j_mayer
#endif
5895 2662a059 j_mayer
#if defined (TODO)
5896 a750fc0b j_mayer
    /* RS64-IV (IceStar/IStar/SStar)                                         */
5897 ee4e83ed j_mayer
    POWERPC_DEF("RS64-IV",     CPU_POWERPC_RS64IV,      RS64),
5898 ee4e83ed j_mayer
    POWERPC_DEF("IceStar",     CPU_POWERPC_RS64IV,      RS64),
5899 ee4e83ed j_mayer
    POWERPC_DEF("IStar",       CPU_POWERPC_RS64IV,      RS64),
5900 ee4e83ed j_mayer
    POWERPC_DEF("SStar",       CPU_POWERPC_RS64IV,      RS64),
5901 3a607854 j_mayer
#endif
5902 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
5903 a750fc0b j_mayer
    /* POWER                                                                 */
5904 3fc6c082 bellard
#if defined (TODO)
5905 a750fc0b j_mayer
    /* Original POWER                                                        */
5906 ee4e83ed j_mayer
    POWERPC_DEF("POWER",       CPU_POWERPC_POWER,       POWER),
5907 ee4e83ed j_mayer
    POWERPC_DEF("RIOS",        CPU_POWERPC_POWER,       POWER),
5908 ee4e83ed j_mayer
    POWERPC_DEF("RSC",         CPU_POWERPC_POWER,       POWER),
5909 ee4e83ed j_mayer
    POWERPC_DEF("RSC3308",     CPU_POWERPC_POWER,       POWER),
5910 ee4e83ed j_mayer
    POWERPC_DEF("RSC4608",     CPU_POWERPC_POWER,       POWER),
5911 76a66253 j_mayer
#endif
5912 76a66253 j_mayer
#if defined (TODO)
5913 a750fc0b j_mayer
    /* POWER2                                                                */
5914 ee4e83ed j_mayer
    POWERPC_DEF("POWER2",      CPU_POWERPC_POWER2,      POWER),
5915 ee4e83ed j_mayer
    POWERPC_DEF("RSC2",        CPU_POWERPC_POWER2,      POWER),
5916 ee4e83ed j_mayer
    POWERPC_DEF("P2SC",        CPU_POWERPC_POWER2,      POWER),
5917 a750fc0b j_mayer
#endif
5918 a750fc0b j_mayer
    /* PA semi cores                                                         */
5919 a750fc0b j_mayer
#if defined (TODO)
5920 a750fc0b j_mayer
    /* PA PA6T */
5921 ee4e83ed j_mayer
    POWERPC_DEF("PA6T",        CPU_POWERPC_PA6T,        PA6T),
5922 a750fc0b j_mayer
#endif
5923 a750fc0b j_mayer
    /* Generic PowerPCs                                                      */
5924 a750fc0b j_mayer
#if defined (TARGET_PPC64)
5925 a750fc0b j_mayer
#if defined (TODO)
5926 ee4e83ed j_mayer
    POWERPC_DEF("ppc64",       CPU_POWERPC_PPC64,       PPC64),
5927 a750fc0b j_mayer
#endif
5928 a750fc0b j_mayer
#endif
5929 ee4e83ed j_mayer
    POWERPC_DEF("ppc32",       CPU_POWERPC_PPC32,       PPC32),
5930 ee4e83ed j_mayer
    POWERPC_DEF("ppc",         CPU_POWERPC_DEFAULT,     DEFAULT),
5931 a750fc0b j_mayer
    /* Fallback                                                              */
5932 ee4e83ed j_mayer
    POWERPC_DEF("default",     CPU_POWERPC_DEFAULT,     DEFAULT),
5933 a750fc0b j_mayer
};
5934 a750fc0b j_mayer
5935 a750fc0b j_mayer
/*****************************************************************************/
5936 a750fc0b j_mayer
/* Generic CPU instanciation routine                                         */
5937 aaed909a bellard
static void init_ppc_proc (CPUPPCState *env, const ppc_def_t *def)
5938 a750fc0b j_mayer
{
5939 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
5940 e1833e1f j_mayer
    int i;
5941 e1833e1f j_mayer
5942 a750fc0b j_mayer
    env->irq_inputs = NULL;
5943 e1833e1f j_mayer
    /* Set all exception vectors to an invalid address */
5944 e1833e1f j_mayer
    for (i = 0; i < POWERPC_EXCP_NB; i++)
5945 e1833e1f j_mayer
        env->excp_vectors[i] = (target_ulong)(-1ULL);
5946 e1833e1f j_mayer
    env->excp_prefix = 0x00000000;
5947 e1833e1f j_mayer
    env->ivor_mask = 0x00000000;
5948 e1833e1f j_mayer
    env->ivpr_mask = 0x00000000;
5949 a750fc0b j_mayer
    /* Default MMU definitions */
5950 a750fc0b j_mayer
    env->nb_BATs = 0;
5951 a750fc0b j_mayer
    env->nb_tlb = 0;
5952 a750fc0b j_mayer
    env->nb_ways = 0;
5953 f2e63a42 j_mayer
#endif
5954 a750fc0b j_mayer
    /* Register SPR common to all PowerPC implementations */
5955 a750fc0b j_mayer
    gen_spr_generic(env);
5956 a750fc0b j_mayer
    spr_register(env, SPR_PVR, "PVR",
5957 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5958 a750fc0b j_mayer
                 &spr_read_generic, SPR_NOACCESS,
5959 a750fc0b j_mayer
                 def->pvr);
5960 a750fc0b j_mayer
    /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
5961 a750fc0b j_mayer
    (*def->init_proc)(env);
5962 25ba3a68 j_mayer
    /* MSR bits & flags consistency checks */
5963 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 25)) {
5964 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
5965 25ba3a68 j_mayer
        case POWERPC_FLAG_SPE:
5966 25ba3a68 j_mayer
        case POWERPC_FLAG_VRE:
5967 25ba3a68 j_mayer
            break;
5968 25ba3a68 j_mayer
        default:
5969 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5970 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SPE or POWERPC_FLAG_VRE\n");
5971 25ba3a68 j_mayer
            exit(1);
5972 25ba3a68 j_mayer
        }
5973 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
5974 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5975 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SPE nor POWERPC_FLAG_VRE\n");
5976 25ba3a68 j_mayer
        exit(1);
5977 25ba3a68 j_mayer
    }
5978 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 17)) {
5979 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
5980 25ba3a68 j_mayer
        case POWERPC_FLAG_TGPR:
5981 25ba3a68 j_mayer
        case POWERPC_FLAG_CE:
5982 25ba3a68 j_mayer
            break;
5983 25ba3a68 j_mayer
        default:
5984 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5985 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_TGPR or POWERPC_FLAG_CE\n");
5986 25ba3a68 j_mayer
            exit(1);
5987 25ba3a68 j_mayer
        }
5988 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
5989 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
5990 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_TGPR nor POWERPC_FLAG_CE\n");
5991 25ba3a68 j_mayer
        exit(1);
5992 25ba3a68 j_mayer
    }
5993 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 10)) {
5994 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
5995 25ba3a68 j_mayer
                              POWERPC_FLAG_UBLE)) {
5996 25ba3a68 j_mayer
        case POWERPC_FLAG_SE:
5997 25ba3a68 j_mayer
        case POWERPC_FLAG_DWE:
5998 25ba3a68 j_mayer
        case POWERPC_FLAG_UBLE:
5999 25ba3a68 j_mayer
            break;
6000 25ba3a68 j_mayer
        default:
6001 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6002 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SE or POWERPC_FLAG_DWE or "
6003 25ba3a68 j_mayer
                    "POWERPC_FLAG_UBLE\n");
6004 25ba3a68 j_mayer
            exit(1);
6005 25ba3a68 j_mayer
        }
6006 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
6007 25ba3a68 j_mayer
                             POWERPC_FLAG_UBLE)) {
6008 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6009 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SE nor POWERPC_FLAG_DWE nor "
6010 25ba3a68 j_mayer
                "POWERPC_FLAG_UBLE\n");
6011 25ba3a68 j_mayer
            exit(1);
6012 25ba3a68 j_mayer
    }
6013 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 9)) {
6014 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
6015 25ba3a68 j_mayer
        case POWERPC_FLAG_BE:
6016 25ba3a68 j_mayer
        case POWERPC_FLAG_DE:
6017 25ba3a68 j_mayer
            break;
6018 25ba3a68 j_mayer
        default:
6019 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6020 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_BE or POWERPC_FLAG_DE\n");
6021 25ba3a68 j_mayer
            exit(1);
6022 25ba3a68 j_mayer
        }
6023 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
6024 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6025 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_BE nor POWERPC_FLAG_DE\n");
6026 25ba3a68 j_mayer
        exit(1);
6027 25ba3a68 j_mayer
    }
6028 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 2)) {
6029 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
6030 25ba3a68 j_mayer
        case POWERPC_FLAG_PX:
6031 25ba3a68 j_mayer
        case POWERPC_FLAG_PMM:
6032 25ba3a68 j_mayer
            break;
6033 25ba3a68 j_mayer
        default:
6034 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6035 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_PX or POWERPC_FLAG_PMM\n");
6036 25ba3a68 j_mayer
            exit(1);
6037 25ba3a68 j_mayer
        }
6038 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
6039 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6040 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_PX nor POWERPC_FLAG_PMM\n");
6041 25ba3a68 j_mayer
        exit(1);
6042 25ba3a68 j_mayer
    }
6043 a750fc0b j_mayer
    /* Allocate TLBs buffer when needed */
6044 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
6045 a750fc0b j_mayer
    if (env->nb_tlb != 0) {
6046 a750fc0b j_mayer
        int nb_tlb = env->nb_tlb;
6047 a750fc0b j_mayer
        if (env->id_tlbs != 0)
6048 a750fc0b j_mayer
            nb_tlb *= 2;
6049 a750fc0b j_mayer
        env->tlb = qemu_mallocz(nb_tlb * sizeof(ppc_tlb_t));
6050 a750fc0b j_mayer
        /* Pre-compute some useful values */
6051 a750fc0b j_mayer
        env->tlb_per_way = env->nb_tlb / env->nb_ways;
6052 a750fc0b j_mayer
    }
6053 a750fc0b j_mayer
    if (env->irq_inputs == NULL) {
6054 a750fc0b j_mayer
        fprintf(stderr, "WARNING: no internal IRQ controller registered.\n"
6055 a750fc0b j_mayer
                " Attempt Qemu to crash very soon !\n");
6056 a750fc0b j_mayer
    }
6057 a750fc0b j_mayer
#endif
6058 2f462816 j_mayer
    if (env->check_pow == NULL) {
6059 2f462816 j_mayer
        fprintf(stderr, "WARNING: no power management check handler "
6060 2f462816 j_mayer
                "registered.\n"
6061 2f462816 j_mayer
                " Attempt Qemu to crash very soon !\n");
6062 2f462816 j_mayer
    }
6063 a750fc0b j_mayer
}
6064 a750fc0b j_mayer
6065 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
6066 a750fc0b j_mayer
static void dump_ppc_sprs (CPUPPCState *env)
6067 a750fc0b j_mayer
{
6068 a750fc0b j_mayer
    ppc_spr_t *spr;
6069 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
6070 a750fc0b j_mayer
    uint32_t sr, sw;
6071 a750fc0b j_mayer
#endif
6072 a750fc0b j_mayer
    uint32_t ur, uw;
6073 a750fc0b j_mayer
    int i, j, n;
6074 a750fc0b j_mayer
6075 a750fc0b j_mayer
    printf("Special purpose registers:\n");
6076 a750fc0b j_mayer
    for (i = 0; i < 32; i++) {
6077 a750fc0b j_mayer
        for (j = 0; j < 32; j++) {
6078 a750fc0b j_mayer
            n = (i << 5) | j;
6079 a750fc0b j_mayer
            spr = &env->spr_cb[n];
6080 a750fc0b j_mayer
            uw = spr->uea_write != NULL && spr->uea_write != SPR_NOACCESS;
6081 a750fc0b j_mayer
            ur = spr->uea_read != NULL && spr->uea_read != SPR_NOACCESS;
6082 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
6083 a750fc0b j_mayer
            sw = spr->oea_write != NULL && spr->oea_write != SPR_NOACCESS;
6084 a750fc0b j_mayer
            sr = spr->oea_read != NULL && spr->oea_read != SPR_NOACCESS;
6085 a750fc0b j_mayer
            if (sw || sr || uw || ur) {
6086 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
6087 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
6088 a750fc0b j_mayer
                       sw ? 'w' : '-', sr ? 'r' : '-',
6089 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
6090 a750fc0b j_mayer
            }
6091 a750fc0b j_mayer
#else
6092 a750fc0b j_mayer
            if (uw || ur) {
6093 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s u%c%c\n",
6094 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
6095 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
6096 a750fc0b j_mayer
            }
6097 a750fc0b j_mayer
#endif
6098 a750fc0b j_mayer
        }
6099 a750fc0b j_mayer
    }
6100 a750fc0b j_mayer
    fflush(stdout);
6101 a750fc0b j_mayer
    fflush(stderr);
6102 a750fc0b j_mayer
}
6103 a750fc0b j_mayer
#endif
6104 a750fc0b j_mayer
6105 a750fc0b j_mayer
/*****************************************************************************/
6106 a750fc0b j_mayer
#include <stdlib.h>
6107 a750fc0b j_mayer
#include <string.h>
6108 a750fc0b j_mayer
6109 a750fc0b j_mayer
int fflush (FILE *stream);
6110 a750fc0b j_mayer
6111 a750fc0b j_mayer
/* Opcode types */
6112 a750fc0b j_mayer
enum {
6113 a750fc0b j_mayer
    PPC_DIRECT   = 0, /* Opcode routine        */
6114 a750fc0b j_mayer
    PPC_INDIRECT = 1, /* Indirect opcode table */
6115 a750fc0b j_mayer
};
6116 a750fc0b j_mayer
6117 a750fc0b j_mayer
static inline int is_indirect_opcode (void *handler)
6118 a750fc0b j_mayer
{
6119 a750fc0b j_mayer
    return ((unsigned long)handler & 0x03) == PPC_INDIRECT;
6120 a750fc0b j_mayer
}
6121 a750fc0b j_mayer
6122 a750fc0b j_mayer
static inline opc_handler_t **ind_table(void *handler)
6123 a750fc0b j_mayer
{
6124 a750fc0b j_mayer
    return (opc_handler_t **)((unsigned long)handler & ~3);
6125 a750fc0b j_mayer
}
6126 a750fc0b j_mayer
6127 a750fc0b j_mayer
/* Instruction table creation */
6128 a750fc0b j_mayer
/* Opcodes tables creation */
6129 a750fc0b j_mayer
static void fill_new_table (opc_handler_t **table, int len)
6130 a750fc0b j_mayer
{
6131 a750fc0b j_mayer
    int i;
6132 a750fc0b j_mayer
6133 a750fc0b j_mayer
    for (i = 0; i < len; i++)
6134 a750fc0b j_mayer
        table[i] = &invalid_handler;
6135 a750fc0b j_mayer
}
6136 a750fc0b j_mayer
6137 a750fc0b j_mayer
static int create_new_table (opc_handler_t **table, unsigned char idx)
6138 a750fc0b j_mayer
{
6139 a750fc0b j_mayer
    opc_handler_t **tmp;
6140 a750fc0b j_mayer
6141 a750fc0b j_mayer
    tmp = malloc(0x20 * sizeof(opc_handler_t));
6142 a750fc0b j_mayer
    if (tmp == NULL)
6143 a750fc0b j_mayer
        return -1;
6144 a750fc0b j_mayer
    fill_new_table(tmp, 0x20);
6145 a750fc0b j_mayer
    table[idx] = (opc_handler_t *)((unsigned long)tmp | PPC_INDIRECT);
6146 a750fc0b j_mayer
6147 a750fc0b j_mayer
    return 0;
6148 a750fc0b j_mayer
}
6149 a750fc0b j_mayer
6150 a750fc0b j_mayer
static int insert_in_table (opc_handler_t **table, unsigned char idx,
6151 a750fc0b j_mayer
                            opc_handler_t *handler)
6152 a750fc0b j_mayer
{
6153 a750fc0b j_mayer
    if (table[idx] != &invalid_handler)
6154 a750fc0b j_mayer
        return -1;
6155 a750fc0b j_mayer
    table[idx] = handler;
6156 a750fc0b j_mayer
6157 a750fc0b j_mayer
    return 0;
6158 a750fc0b j_mayer
}
6159 a750fc0b j_mayer
6160 a750fc0b j_mayer
static int register_direct_insn (opc_handler_t **ppc_opcodes,
6161 a750fc0b j_mayer
                                 unsigned char idx, opc_handler_t *handler)
6162 a750fc0b j_mayer
{
6163 a750fc0b j_mayer
    if (insert_in_table(ppc_opcodes, idx, handler) < 0) {
6164 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in main "
6165 a750fc0b j_mayer
               "opcode table\n", idx);
6166 a750fc0b j_mayer
        return -1;
6167 a750fc0b j_mayer
    }
6168 a750fc0b j_mayer
6169 a750fc0b j_mayer
    return 0;
6170 a750fc0b j_mayer
}
6171 a750fc0b j_mayer
6172 a750fc0b j_mayer
static int register_ind_in_table (opc_handler_t **table,
6173 a750fc0b j_mayer
                                  unsigned char idx1, unsigned char idx2,
6174 a750fc0b j_mayer
                                  opc_handler_t *handler)
6175 a750fc0b j_mayer
{
6176 a750fc0b j_mayer
    if (table[idx1] == &invalid_handler) {
6177 a750fc0b j_mayer
        if (create_new_table(table, idx1) < 0) {
6178 a750fc0b j_mayer
            printf("*** ERROR: unable to create indirect table "
6179 a750fc0b j_mayer
                   "idx=%02x\n", idx1);
6180 a750fc0b j_mayer
            return -1;
6181 a750fc0b j_mayer
        }
6182 a750fc0b j_mayer
    } else {
6183 a750fc0b j_mayer
        if (!is_indirect_opcode(table[idx1])) {
6184 a750fc0b j_mayer
            printf("*** ERROR: idx %02x already assigned to a direct "
6185 a750fc0b j_mayer
                   "opcode\n", idx1);
6186 a750fc0b j_mayer
            return -1;
6187 a750fc0b j_mayer
        }
6188 3a607854 j_mayer
    }
6189 a750fc0b j_mayer
    if (handler != NULL &&
6190 a750fc0b j_mayer
        insert_in_table(ind_table(table[idx1]), idx2, handler) < 0) {
6191 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in "
6192 a750fc0b j_mayer
               "opcode table %02x\n", idx2, idx1);
6193 a750fc0b j_mayer
        return -1;
6194 3a607854 j_mayer
    }
6195 a750fc0b j_mayer
6196 a750fc0b j_mayer
    return 0;
6197 a750fc0b j_mayer
}
6198 a750fc0b j_mayer
6199 a750fc0b j_mayer
static int register_ind_insn (opc_handler_t **ppc_opcodes,
6200 a750fc0b j_mayer
                              unsigned char idx1, unsigned char idx2,
6201 a750fc0b j_mayer
                              opc_handler_t *handler)
6202 a750fc0b j_mayer
{
6203 a750fc0b j_mayer
    int ret;
6204 a750fc0b j_mayer
6205 a750fc0b j_mayer
    ret = register_ind_in_table(ppc_opcodes, idx1, idx2, handler);
6206 a750fc0b j_mayer
6207 a750fc0b j_mayer
    return ret;
6208 a750fc0b j_mayer
}
6209 a750fc0b j_mayer
6210 a750fc0b j_mayer
static int register_dblind_insn (opc_handler_t **ppc_opcodes,
6211 a750fc0b j_mayer
                                 unsigned char idx1, unsigned char idx2,
6212 a750fc0b j_mayer
                                 unsigned char idx3, opc_handler_t *handler)
6213 a750fc0b j_mayer
{
6214 a750fc0b j_mayer
    if (register_ind_in_table(ppc_opcodes, idx1, idx2, NULL) < 0) {
6215 a750fc0b j_mayer
        printf("*** ERROR: unable to join indirect table idx "
6216 a750fc0b j_mayer
               "[%02x-%02x]\n", idx1, idx2);
6217 a750fc0b j_mayer
        return -1;
6218 a750fc0b j_mayer
    }
6219 a750fc0b j_mayer
    if (register_ind_in_table(ind_table(ppc_opcodes[idx1]), idx2, idx3,
6220 a750fc0b j_mayer
                              handler) < 0) {
6221 a750fc0b j_mayer
        printf("*** ERROR: unable to insert opcode "
6222 a750fc0b j_mayer
               "[%02x-%02x-%02x]\n", idx1, idx2, idx3);
6223 a750fc0b j_mayer
        return -1;
6224 a750fc0b j_mayer
    }
6225 a750fc0b j_mayer
6226 a750fc0b j_mayer
    return 0;
6227 a750fc0b j_mayer
}
6228 a750fc0b j_mayer
6229 a750fc0b j_mayer
static int register_insn (opc_handler_t **ppc_opcodes, opcode_t *insn)
6230 a750fc0b j_mayer
{
6231 a750fc0b j_mayer
    if (insn->opc2 != 0xFF) {
6232 a750fc0b j_mayer
        if (insn->opc3 != 0xFF) {
6233 a750fc0b j_mayer
            if (register_dblind_insn(ppc_opcodes, insn->opc1, insn->opc2,
6234 a750fc0b j_mayer
                                     insn->opc3, &insn->handler) < 0)
6235 a750fc0b j_mayer
                return -1;
6236 a750fc0b j_mayer
        } else {
6237 a750fc0b j_mayer
            if (register_ind_insn(ppc_opcodes, insn->opc1,
6238 a750fc0b j_mayer
                                  insn->opc2, &insn->handler) < 0)
6239 a750fc0b j_mayer
                return -1;
6240 a750fc0b j_mayer
        }
6241 a750fc0b j_mayer
    } else {
6242 a750fc0b j_mayer
        if (register_direct_insn(ppc_opcodes, insn->opc1, &insn->handler) < 0)
6243 a750fc0b j_mayer
            return -1;
6244 a750fc0b j_mayer
    }
6245 a750fc0b j_mayer
6246 a750fc0b j_mayer
    return 0;
6247 a750fc0b j_mayer
}
6248 a750fc0b j_mayer
6249 a750fc0b j_mayer
static int test_opcode_table (opc_handler_t **table, int len)
6250 a750fc0b j_mayer
{
6251 a750fc0b j_mayer
    int i, count, tmp;
6252 a750fc0b j_mayer
6253 a750fc0b j_mayer
    for (i = 0, count = 0; i < len; i++) {
6254 a750fc0b j_mayer
        /* Consistency fixup */
6255 a750fc0b j_mayer
        if (table[i] == NULL)
6256 a750fc0b j_mayer
            table[i] = &invalid_handler;
6257 a750fc0b j_mayer
        if (table[i] != &invalid_handler) {
6258 a750fc0b j_mayer
            if (is_indirect_opcode(table[i])) {
6259 a750fc0b j_mayer
                tmp = test_opcode_table(ind_table(table[i]), 0x20);
6260 a750fc0b j_mayer
                if (tmp == 0) {
6261 a750fc0b j_mayer
                    free(table[i]);
6262 a750fc0b j_mayer
                    table[i] = &invalid_handler;
6263 a750fc0b j_mayer
                } else {
6264 a750fc0b j_mayer
                    count++;
6265 a750fc0b j_mayer
                }
6266 a750fc0b j_mayer
            } else {
6267 a750fc0b j_mayer
                count++;
6268 a750fc0b j_mayer
            }
6269 a750fc0b j_mayer
        }
6270 a750fc0b j_mayer
    }
6271 a750fc0b j_mayer
6272 a750fc0b j_mayer
    return count;
6273 a750fc0b j_mayer
}
6274 a750fc0b j_mayer
6275 a750fc0b j_mayer
static void fix_opcode_tables (opc_handler_t **ppc_opcodes)
6276 a750fc0b j_mayer
{
6277 a750fc0b j_mayer
    if (test_opcode_table(ppc_opcodes, 0x40) == 0)
6278 a750fc0b j_mayer
        printf("*** WARNING: no opcode defined !\n");
6279 a750fc0b j_mayer
}
6280 a750fc0b j_mayer
6281 a750fc0b j_mayer
/*****************************************************************************/
6282 aaed909a bellard
static int create_ppc_opcodes (CPUPPCState *env, const ppc_def_t *def)
6283 a750fc0b j_mayer
{
6284 a750fc0b j_mayer
    opcode_t *opc, *start, *end;
6285 a750fc0b j_mayer
6286 a750fc0b j_mayer
    fill_new_table(env->opcodes, 0x40);
6287 a750fc0b j_mayer
    if (&opc_start < &opc_end) {
6288 a750fc0b j_mayer
        start = &opc_start;
6289 a750fc0b j_mayer
        end = &opc_end;
6290 a750fc0b j_mayer
    } else {
6291 a750fc0b j_mayer
        start = &opc_end;
6292 a750fc0b j_mayer
        end = &opc_start;
6293 a750fc0b j_mayer
    }
6294 a750fc0b j_mayer
    for (opc = start + 1; opc != end; opc++) {
6295 a750fc0b j_mayer
        if ((opc->handler.type & def->insns_flags) != 0) {
6296 a750fc0b j_mayer
            if (register_insn(env->opcodes, opc) < 0) {
6297 a750fc0b j_mayer
                printf("*** ERROR initializing PowerPC instruction "
6298 a750fc0b j_mayer
                       "0x%02x 0x%02x 0x%02x\n", opc->opc1, opc->opc2,
6299 a750fc0b j_mayer
                       opc->opc3);
6300 a750fc0b j_mayer
                return -1;
6301 a750fc0b j_mayer
            }
6302 a750fc0b j_mayer
        }
6303 a750fc0b j_mayer
    }
6304 a750fc0b j_mayer
    fix_opcode_tables(env->opcodes);
6305 a750fc0b j_mayer
    fflush(stdout);
6306 a750fc0b j_mayer
    fflush(stderr);
6307 a750fc0b j_mayer
6308 a750fc0b j_mayer
    return 0;
6309 a750fc0b j_mayer
}
6310 a750fc0b j_mayer
6311 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
6312 25ba3a68 j_mayer
static void dump_ppc_insns (CPUPPCState *env)
6313 a750fc0b j_mayer
{
6314 a750fc0b j_mayer
    opc_handler_t **table, *handler;
6315 a750fc0b j_mayer
    uint8_t opc1, opc2, opc3;
6316 a750fc0b j_mayer
6317 a750fc0b j_mayer
    printf("Instructions set:\n");
6318 a750fc0b j_mayer
    /* opc1 is 6 bits long */
6319 a750fc0b j_mayer
    for (opc1 = 0x00; opc1 < 0x40; opc1++) {
6320 a750fc0b j_mayer
        table = env->opcodes;
6321 a750fc0b j_mayer
        handler = table[opc1];
6322 a750fc0b j_mayer
        if (is_indirect_opcode(handler)) {
6323 a750fc0b j_mayer
            /* opc2 is 5 bits long */
6324 a750fc0b j_mayer
            for (opc2 = 0; opc2 < 0x20; opc2++) {
6325 a750fc0b j_mayer
                table = env->opcodes;
6326 a750fc0b j_mayer
                handler = env->opcodes[opc1];
6327 a750fc0b j_mayer
                table = ind_table(handler);
6328 a750fc0b j_mayer
                handler = table[opc2];
6329 a750fc0b j_mayer
                if (is_indirect_opcode(handler)) {
6330 a750fc0b j_mayer
                    table = ind_table(handler);
6331 a750fc0b j_mayer
                    /* opc3 is 5 bits long */
6332 a750fc0b j_mayer
                    for (opc3 = 0; opc3 < 0x20; opc3++) {
6333 a750fc0b j_mayer
                        handler = table[opc3];
6334 a750fc0b j_mayer
                        if (handler->handler != &gen_invalid) {
6335 a750fc0b j_mayer
                            printf("INSN: %02x %02x %02x (%02d %04d) : %s\n",
6336 a750fc0b j_mayer
                                   opc1, opc2, opc3, opc1, (opc3 << 5) | opc2,
6337 a750fc0b j_mayer
                                   handler->oname);
6338 a750fc0b j_mayer
                        }
6339 a750fc0b j_mayer
                    }
6340 a750fc0b j_mayer
                } else {
6341 a750fc0b j_mayer
                    if (handler->handler != &gen_invalid) {
6342 a750fc0b j_mayer
                        printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
6343 a750fc0b j_mayer
                               opc1, opc2, opc1, opc2, handler->oname);
6344 a750fc0b j_mayer
                    }
6345 a750fc0b j_mayer
                }
6346 a750fc0b j_mayer
            }
6347 a750fc0b j_mayer
        } else {
6348 a750fc0b j_mayer
            if (handler->handler != &gen_invalid) {
6349 a750fc0b j_mayer
                printf("INSN: %02x -- -- (%02d ----) : %s\n",
6350 a750fc0b j_mayer
                       opc1, opc1, handler->oname);
6351 a750fc0b j_mayer
            }
6352 a750fc0b j_mayer
        }
6353 a750fc0b j_mayer
    }
6354 a750fc0b j_mayer
}
6355 3a607854 j_mayer
#endif
6356 a750fc0b j_mayer
6357 aaed909a bellard
int cpu_ppc_register_internal (CPUPPCState *env, const ppc_def_t *def)
6358 a750fc0b j_mayer
{
6359 a750fc0b j_mayer
    env->msr_mask = def->msr_mask;
6360 a750fc0b j_mayer
    env->mmu_model = def->mmu_model;
6361 a750fc0b j_mayer
    env->excp_model = def->excp_model;
6362 a750fc0b j_mayer
    env->bus_model = def->bus_model;
6363 d26bfc9a j_mayer
    env->flags = def->flags;
6364 237c0af0 j_mayer
    env->bfd_mach = def->bfd_mach;
6365 2f462816 j_mayer
    env->check_pow = def->check_pow;
6366 a750fc0b j_mayer
    if (create_ppc_opcodes(env, def) < 0)
6367 a750fc0b j_mayer
        return -1;
6368 a750fc0b j_mayer
    init_ppc_proc(env, def);
6369 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
6370 3a607854 j_mayer
    {
6371 a750fc0b j_mayer
        const unsigned char *mmu_model, *excp_model, *bus_model;
6372 a750fc0b j_mayer
        switch (env->mmu_model) {
6373 a750fc0b j_mayer
        case POWERPC_MMU_32B:
6374 a750fc0b j_mayer
            mmu_model = "PowerPC 32";
6375 a750fc0b j_mayer
            break;
6376 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_6xx:
6377 a750fc0b j_mayer
            mmu_model = "PowerPC 6xx/7xx with software driven TLBs";
6378 a750fc0b j_mayer
            break;
6379 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_74xx:
6380 a750fc0b j_mayer
            mmu_model = "PowerPC 74xx with software driven TLBs";
6381 a750fc0b j_mayer
            break;
6382 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx:
6383 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs";
6384 a750fc0b j_mayer
            break;
6385 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx_Z:
6386 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs "
6387 a750fc0b j_mayer
                "and zones protections";
6388 a750fc0b j_mayer
            break;
6389 a750fc0b j_mayer
        case POWERPC_MMU_REAL_4xx:
6390 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx real mode only";
6391 a750fc0b j_mayer
            break;
6392 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE:
6393 a750fc0b j_mayer
            mmu_model = "PowerPC BookE";
6394 a750fc0b j_mayer
            break;
6395 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE_FSL:
6396 a750fc0b j_mayer
            mmu_model = "PowerPC BookE FSL";
6397 a750fc0b j_mayer
            break;
6398 00af685f j_mayer
#if defined (TARGET_PPC64)
6399 00af685f j_mayer
        case POWERPC_MMU_64B:
6400 00af685f j_mayer
            mmu_model = "PowerPC 64";
6401 00af685f j_mayer
            break;
6402 00af685f j_mayer
#endif
6403 a750fc0b j_mayer
        default:
6404 a750fc0b j_mayer
            mmu_model = "Unknown or invalid";
6405 a750fc0b j_mayer
            break;
6406 a750fc0b j_mayer
        }
6407 a750fc0b j_mayer
        switch (env->excp_model) {
6408 a750fc0b j_mayer
        case POWERPC_EXCP_STD:
6409 a750fc0b j_mayer
            excp_model = "PowerPC";
6410 a750fc0b j_mayer
            break;
6411 a750fc0b j_mayer
        case POWERPC_EXCP_40x:
6412 a750fc0b j_mayer
            excp_model = "PowerPC 40x";
6413 a750fc0b j_mayer
            break;
6414 a750fc0b j_mayer
        case POWERPC_EXCP_601:
6415 a750fc0b j_mayer
            excp_model = "PowerPC 601";
6416 a750fc0b j_mayer
            break;
6417 a750fc0b j_mayer
        case POWERPC_EXCP_602:
6418 a750fc0b j_mayer
            excp_model = "PowerPC 602";
6419 a750fc0b j_mayer
            break;
6420 a750fc0b j_mayer
        case POWERPC_EXCP_603:
6421 a750fc0b j_mayer
            excp_model = "PowerPC 603";
6422 a750fc0b j_mayer
            break;
6423 a750fc0b j_mayer
        case POWERPC_EXCP_603E:
6424 a750fc0b j_mayer
            excp_model = "PowerPC 603e";
6425 a750fc0b j_mayer
            break;
6426 a750fc0b j_mayer
        case POWERPC_EXCP_604:
6427 a750fc0b j_mayer
            excp_model = "PowerPC 604";
6428 a750fc0b j_mayer
            break;
6429 a750fc0b j_mayer
        case POWERPC_EXCP_7x0:
6430 a750fc0b j_mayer
            excp_model = "PowerPC 740/750";
6431 a750fc0b j_mayer
            break;
6432 a750fc0b j_mayer
        case POWERPC_EXCP_7x5:
6433 a750fc0b j_mayer
            excp_model = "PowerPC 745/755";
6434 a750fc0b j_mayer
            break;
6435 a750fc0b j_mayer
        case POWERPC_EXCP_74xx:
6436 a750fc0b j_mayer
            excp_model = "PowerPC 74xx";
6437 a750fc0b j_mayer
            break;
6438 a750fc0b j_mayer
        case POWERPC_EXCP_BOOKE:
6439 a750fc0b j_mayer
            excp_model = "PowerPC BookE";
6440 a750fc0b j_mayer
            break;
6441 00af685f j_mayer
#if defined (TARGET_PPC64)
6442 00af685f j_mayer
        case POWERPC_EXCP_970:
6443 00af685f j_mayer
            excp_model = "PowerPC 970";
6444 00af685f j_mayer
            break;
6445 00af685f j_mayer
#endif
6446 a750fc0b j_mayer
        default:
6447 a750fc0b j_mayer
            excp_model = "Unknown or invalid";
6448 a750fc0b j_mayer
            break;
6449 a750fc0b j_mayer
        }
6450 a750fc0b j_mayer
        switch (env->bus_model) {
6451 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_6xx:
6452 a750fc0b j_mayer
            bus_model = "PowerPC 6xx";
6453 a750fc0b j_mayer
            break;
6454 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_BookE:
6455 a750fc0b j_mayer
            bus_model = "PowerPC BookE";
6456 a750fc0b j_mayer
            break;
6457 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_405:
6458 a750fc0b j_mayer
            bus_model = "PowerPC 405";
6459 a750fc0b j_mayer
            break;
6460 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_401:
6461 a750fc0b j_mayer
            bus_model = "PowerPC 401/403";
6462 a750fc0b j_mayer
            break;
6463 00af685f j_mayer
#if defined (TARGET_PPC64)
6464 00af685f j_mayer
        case PPC_FLAGS_INPUT_970:
6465 00af685f j_mayer
            bus_model = "PowerPC 970";
6466 00af685f j_mayer
            break;
6467 00af685f j_mayer
#endif
6468 a750fc0b j_mayer
        default:
6469 a750fc0b j_mayer
            bus_model = "Unknown or invalid";
6470 a750fc0b j_mayer
            break;
6471 a750fc0b j_mayer
        }
6472 a750fc0b j_mayer
        printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64 "\n"
6473 a750fc0b j_mayer
               "    MMU model        : %s\n",
6474 a750fc0b j_mayer
               def->name, def->pvr, def->msr_mask, mmu_model);
6475 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
6476 a750fc0b j_mayer
        if (env->tlb != NULL) {
6477 a750fc0b j_mayer
            printf("                       %d %s TLB in %d ways\n",
6478 a750fc0b j_mayer
                   env->nb_tlb, env->id_tlbs ? "splitted" : "merged",
6479 a750fc0b j_mayer
                   env->nb_ways);
6480 a750fc0b j_mayer
        }
6481 f2e63a42 j_mayer
#endif
6482 a750fc0b j_mayer
        printf("    Exceptions model : %s\n"
6483 a750fc0b j_mayer
               "    Bus model        : %s\n",
6484 a750fc0b j_mayer
               excp_model, bus_model);
6485 25ba3a68 j_mayer
        printf("    MSR features     :\n");
6486 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SPE)
6487 25ba3a68 j_mayer
            printf("                        signal processing engine enable"
6488 25ba3a68 j_mayer
                   "\n");
6489 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_VRE)
6490 25ba3a68 j_mayer
            printf("                        vector processor enable\n");
6491 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_TGPR)
6492 25ba3a68 j_mayer
            printf("                        temporary GPRs\n");
6493 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_CE)
6494 25ba3a68 j_mayer
            printf("                        critical input enable\n");
6495 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SE)
6496 25ba3a68 j_mayer
            printf("                        single-step trace mode\n");
6497 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DWE)
6498 25ba3a68 j_mayer
            printf("                        debug wait enable\n");
6499 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_UBLE)
6500 25ba3a68 j_mayer
            printf("                        user BTB lock enable\n");
6501 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_BE)
6502 25ba3a68 j_mayer
            printf("                        branch-step trace mode\n");
6503 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DE)
6504 25ba3a68 j_mayer
            printf("                        debug interrupt enable\n");
6505 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_PX)
6506 25ba3a68 j_mayer
            printf("                        inclusive protection\n");
6507 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_PMM)
6508 25ba3a68 j_mayer
            printf("                        performance monitor mark\n");
6509 25ba3a68 j_mayer
        if (env->flags == POWERPC_FLAG_NONE)
6510 25ba3a68 j_mayer
            printf("                        none\n");
6511 a750fc0b j_mayer
    }
6512 a750fc0b j_mayer
    dump_ppc_insns(env);
6513 a750fc0b j_mayer
    dump_ppc_sprs(env);
6514 a750fc0b j_mayer
    fflush(stdout);
6515 3a607854 j_mayer
#endif
6516 a750fc0b j_mayer
6517 a750fc0b j_mayer
    return 0;
6518 a750fc0b j_mayer
}
6519 3fc6c082 bellard
6520 ee4e83ed j_mayer
static const ppc_def_t *ppc_find_by_pvr (uint32_t pvr)
6521 3fc6c082 bellard
{
6522 ee4e83ed j_mayer
    const ppc_def_t *ret;
6523 ee4e83ed j_mayer
    uint32_t pvr_rev;
6524 ee4e83ed j_mayer
    int i, best, match, best_match, max;
6525 3fc6c082 bellard
6526 ee4e83ed j_mayer
    ret = NULL;
6527 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6528 ee4e83ed j_mayer
    best = -1;
6529 ee4e83ed j_mayer
    pvr_rev = pvr & 0xFFFF;
6530 ee4e83ed j_mayer
    /* We want all specified bits to match */
6531 ee4e83ed j_mayer
    best_match = 32 - ctz32(pvr_rev);
6532 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
6533 ee4e83ed j_mayer
        /* We check that the 16 higher bits are the same to ensure the CPU
6534 ee4e83ed j_mayer
         * model will be the choosen one.
6535 ee4e83ed j_mayer
         */
6536 ee4e83ed j_mayer
        if (((pvr ^ ppc_defs[i].pvr) >> 16) == 0) {
6537 ee4e83ed j_mayer
            /* We want as much as possible of the low-level 16 bits
6538 ee4e83ed j_mayer
             * to be the same but we allow inexact matches.
6539 ee4e83ed j_mayer
             */
6540 ee4e83ed j_mayer
            match = clz32(pvr_rev ^ (ppc_defs[i].pvr & 0xFFFF));
6541 ee4e83ed j_mayer
            /* We check '>=' instead of '>' because the PPC_defs table
6542 ee4e83ed j_mayer
             * is ordered by increasing revision.
6543 ee4e83ed j_mayer
             * Then, we will match the higher revision compatible 
6544 ee4e83ed j_mayer
             * with the requested PVR
6545 ee4e83ed j_mayer
             */
6546 ee4e83ed j_mayer
            if (match >= best_match) {
6547 ee4e83ed j_mayer
                best = i;
6548 ee4e83ed j_mayer
                best_match = match;
6549 ee4e83ed j_mayer
            }
6550 3fc6c082 bellard
        }
6551 3fc6c082 bellard
    }
6552 ee4e83ed j_mayer
    if (best != -1)
6553 ee4e83ed j_mayer
        ret = &ppc_defs[best];
6554 ee4e83ed j_mayer
6555 ee4e83ed j_mayer
    return ret;
6556 3fc6c082 bellard
}
6557 3fc6c082 bellard
6558 ee4e83ed j_mayer
#include <ctype.h>
6559 3fc6c082 bellard
6560 ee4e83ed j_mayer
const ppc_def_t *cpu_ppc_find_by_name (const unsigned char *name)
6561 ee4e83ed j_mayer
{
6562 ee4e83ed j_mayer
    const ppc_def_t *ret;
6563 ee4e83ed j_mayer
    const unsigned char *p;
6564 ee4e83ed j_mayer
    int i, max, len;
6565 ee4e83ed j_mayer
6566 ee4e83ed j_mayer
    /* Check if the given name is a PVR */
6567 ee4e83ed j_mayer
    len = strlen(name);
6568 ee4e83ed j_mayer
    if (len == 10 && name[0] == '0' && name[1] == 'x') {
6569 ee4e83ed j_mayer
        p = name + 2;
6570 ee4e83ed j_mayer
        goto check_pvr;
6571 ee4e83ed j_mayer
    } else if (len == 8) {
6572 ee4e83ed j_mayer
        p = name;
6573 ee4e83ed j_mayer
    check_pvr:
6574 ee4e83ed j_mayer
        for (i = 0; i < 8; i++) {
6575 ee4e83ed j_mayer
            if (!isxdigit(*p++))
6576 ee4e83ed j_mayer
                break;
6577 ee4e83ed j_mayer
        }
6578 ee4e83ed j_mayer
        if (i == 8)
6579 ee4e83ed j_mayer
            return ppc_find_by_pvr(strtoul(name, NULL, 16));
6580 ee4e83ed j_mayer
    }
6581 ee4e83ed j_mayer
    ret = NULL;
6582 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6583 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
6584 ee4e83ed j_mayer
        if (strcasecmp(name, ppc_defs[i].name) == 0) {
6585 ee4e83ed j_mayer
            ret = &ppc_defs[i];
6586 ee4e83ed j_mayer
            break;
6587 3fc6c082 bellard
        }
6588 3fc6c082 bellard
    }
6589 ee4e83ed j_mayer
6590 ee4e83ed j_mayer
    return ret;
6591 3fc6c082 bellard
}
6592 3fc6c082 bellard
6593 3fc6c082 bellard
void ppc_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...))
6594 3fc6c082 bellard
{
6595 068abdc8 j_mayer
    int i, max;
6596 3fc6c082 bellard
6597 068abdc8 j_mayer
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6598 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
6599 a750fc0b j_mayer
        (*cpu_fprintf)(f, "PowerPC %-16s PVR %08x\n",
6600 a750fc0b j_mayer
                       ppc_defs[i].name, ppc_defs[i].pvr);
6601 3fc6c082 bellard
    }
6602 3fc6c082 bellard
}