Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ 0497d2f4

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