Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ 0e326109

History | View | Annotate | Download (420.1 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 8167ee88 Blue Swirl
 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
18 3fc6c082 bellard
 */
19 3fc6c082 bellard
20 3fc6c082 bellard
/* A lot of PowerPC definition have been included here.
21 3fc6c082 bellard
 * Most of them are not usable for now but have been kept
22 3fc6c082 bellard
 * inside "#if defined(TODO) ... #endif" statements to make tests easier.
23 3fc6c082 bellard
 */
24 3fc6c082 bellard
25 237c0af0 j_mayer
#include "dis-asm.h"
26 4e47ea67 aurel32
#include "gdbstub.h"
27 237c0af0 j_mayer
28 3fc6c082 bellard
//#define PPC_DUMP_CPU
29 3fc6c082 bellard
//#define PPC_DEBUG_SPR
30 80d11f44 j_mayer
//#define PPC_DUMP_SPR_ACCESSES
31 80d11f44 j_mayer
#if defined(CONFIG_USER_ONLY)
32 80d11f44 j_mayer
#define TODO_USER_ONLY 1
33 80d11f44 j_mayer
#endif
34 3fc6c082 bellard
35 c227f099 Anthony Liguori
struct ppc_def_t {
36 b55266b5 blueswir1
    const char *name;
37 3fc6c082 bellard
    uint32_t pvr;
38 80d11f44 j_mayer
    uint32_t svr;
39 0487d6a8 j_mayer
    uint64_t insns_flags;
40 3fc6c082 bellard
    uint64_t msr_mask;
41 c227f099 Anthony Liguori
    powerpc_mmu_t   mmu_model;
42 c227f099 Anthony Liguori
    powerpc_excp_t  excp_model;
43 c227f099 Anthony Liguori
    powerpc_input_t bus_model;
44 d26bfc9a j_mayer
    uint32_t flags;
45 237c0af0 j_mayer
    int bfd_mach;
46 a750fc0b j_mayer
    void (*init_proc)(CPUPPCState *env);
47 4c1b1bfe j_mayer
    int  (*check_pow)(CPUPPCState *env);
48 3fc6c082 bellard
};
49 3fc6c082 bellard
50 e9df014c j_mayer
/* For user-mode emulation, we don't emulate any IRQ controller */
51 e9df014c j_mayer
#if defined(CONFIG_USER_ONLY)
52 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
53 a750fc0b j_mayer
static inline void glue(glue(ppc, name),_irq_init) (CPUPPCState *env)         \
54 a750fc0b j_mayer
{                                                                             \
55 e9df014c j_mayer
}
56 e9df014c j_mayer
#else
57 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
58 e9df014c j_mayer
void glue(glue(ppc, name),_irq_init) (CPUPPCState *env);
59 e9df014c j_mayer
#endif
60 a750fc0b j_mayer
61 4e290a0b j_mayer
PPC_IRQ_INIT_FN(40x);
62 e9df014c j_mayer
PPC_IRQ_INIT_FN(6xx);
63 d0dfae6e j_mayer
PPC_IRQ_INIT_FN(970);
64 9d52e907 David Gibson
PPC_IRQ_INIT_FN(POWER7);
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 630ecca0 Tristan Gingold
    if (use_icount) {
159 630ecca0 Tristan Gingold
        gen_io_start();
160 630ecca0 Tristan Gingold
    }
161 45d827d2 aurel32
    gen_helper_load_decr(cpu_gpr[gprn]);
162 630ecca0 Tristan Gingold
    if (use_icount) {
163 630ecca0 Tristan Gingold
        gen_io_end();
164 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
165 630ecca0 Tristan Gingold
    }
166 3fc6c082 bellard
}
167 3fc6c082 bellard
168 45d827d2 aurel32
static void spr_write_decr (void *opaque, int sprn, int gprn)
169 3fc6c082 bellard
{
170 630ecca0 Tristan Gingold
    if (use_icount) {
171 630ecca0 Tristan Gingold
        gen_io_start();
172 630ecca0 Tristan Gingold
    }
173 45d827d2 aurel32
    gen_helper_store_decr(cpu_gpr[gprn]);
174 630ecca0 Tristan Gingold
    if (use_icount) {
175 630ecca0 Tristan Gingold
        gen_io_end();
176 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
177 630ecca0 Tristan Gingold
    }
178 3fc6c082 bellard
}
179 76a66253 j_mayer
#endif
180 3fc6c082 bellard
181 76a66253 j_mayer
/* SPR common to all non-embedded PowerPC, except 601 */
182 3fc6c082 bellard
/* Time base */
183 45d827d2 aurel32
static void spr_read_tbl (void *opaque, int gprn, int sprn)
184 3fc6c082 bellard
{
185 630ecca0 Tristan Gingold
    if (use_icount) {
186 630ecca0 Tristan Gingold
        gen_io_start();
187 630ecca0 Tristan Gingold
    }
188 45d827d2 aurel32
    gen_helper_load_tbl(cpu_gpr[gprn]);
189 630ecca0 Tristan Gingold
    if (use_icount) {
190 630ecca0 Tristan Gingold
        gen_io_end();
191 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
192 630ecca0 Tristan Gingold
    }
193 3fc6c082 bellard
}
194 3fc6c082 bellard
195 45d827d2 aurel32
static void spr_read_tbu (void *opaque, int gprn, int sprn)
196 3fc6c082 bellard
{
197 630ecca0 Tristan Gingold
    if (use_icount) {
198 630ecca0 Tristan Gingold
        gen_io_start();
199 630ecca0 Tristan Gingold
    }
200 45d827d2 aurel32
    gen_helper_load_tbu(cpu_gpr[gprn]);
201 630ecca0 Tristan Gingold
    if (use_icount) {
202 630ecca0 Tristan Gingold
        gen_io_end();
203 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
204 630ecca0 Tristan Gingold
    }
205 3fc6c082 bellard
}
206 3fc6c082 bellard
207 a062e36c j_mayer
__attribute__ (( unused ))
208 45d827d2 aurel32
static void spr_read_atbl (void *opaque, int gprn, int sprn)
209 a062e36c j_mayer
{
210 45d827d2 aurel32
    gen_helper_load_atbl(cpu_gpr[gprn]);
211 a062e36c j_mayer
}
212 a062e36c j_mayer
213 a062e36c j_mayer
__attribute__ (( unused ))
214 45d827d2 aurel32
static void spr_read_atbu (void *opaque, int gprn, int sprn)
215 a062e36c j_mayer
{
216 45d827d2 aurel32
    gen_helper_load_atbu(cpu_gpr[gprn]);
217 a062e36c j_mayer
}
218 a062e36c j_mayer
219 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
220 45d827d2 aurel32
static void spr_write_tbl (void *opaque, int sprn, int gprn)
221 3fc6c082 bellard
{
222 630ecca0 Tristan Gingold
    if (use_icount) {
223 630ecca0 Tristan Gingold
        gen_io_start();
224 630ecca0 Tristan Gingold
    }
225 45d827d2 aurel32
    gen_helper_store_tbl(cpu_gpr[gprn]);
226 630ecca0 Tristan Gingold
    if (use_icount) {
227 630ecca0 Tristan Gingold
        gen_io_end();
228 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
229 630ecca0 Tristan Gingold
    }
230 3fc6c082 bellard
}
231 3fc6c082 bellard
232 45d827d2 aurel32
static void spr_write_tbu (void *opaque, int sprn, int gprn)
233 3fc6c082 bellard
{
234 630ecca0 Tristan Gingold
    if (use_icount) {
235 630ecca0 Tristan Gingold
        gen_io_start();
236 630ecca0 Tristan Gingold
    }
237 45d827d2 aurel32
    gen_helper_store_tbu(cpu_gpr[gprn]);
238 630ecca0 Tristan Gingold
    if (use_icount) {
239 630ecca0 Tristan Gingold
        gen_io_end();
240 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
241 630ecca0 Tristan Gingold
    }
242 3fc6c082 bellard
}
243 a062e36c j_mayer
244 a062e36c j_mayer
__attribute__ (( unused ))
245 45d827d2 aurel32
static void spr_write_atbl (void *opaque, int sprn, int gprn)
246 a062e36c j_mayer
{
247 45d827d2 aurel32
    gen_helper_store_atbl(cpu_gpr[gprn]);
248 a062e36c j_mayer
}
249 a062e36c j_mayer
250 a062e36c j_mayer
__attribute__ (( unused ))
251 45d827d2 aurel32
static void spr_write_atbu (void *opaque, int sprn, int gprn)
252 a062e36c j_mayer
{
253 45d827d2 aurel32
    gen_helper_store_atbu(cpu_gpr[gprn]);
254 a062e36c j_mayer
}
255 3a7f009a David Gibson
256 3a7f009a David Gibson
#if defined(TARGET_PPC64)
257 3a7f009a David Gibson
__attribute__ (( unused ))
258 3a7f009a David Gibson
static void spr_read_purr (void *opaque, int gprn, int sprn)
259 3a7f009a David Gibson
{
260 3a7f009a David Gibson
    gen_helper_load_purr(cpu_gpr[gprn]);
261 3a7f009a David Gibson
}
262 3a7f009a David Gibson
#endif
263 76a66253 j_mayer
#endif
264 3fc6c082 bellard
265 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
266 3fc6c082 bellard
/* IBAT0U...IBAT0U */
267 3fc6c082 bellard
/* IBAT0L...IBAT7L */
268 45d827d2 aurel32
static void spr_read_ibat (void *opaque, int gprn, int sprn)
269 3fc6c082 bellard
{
270 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, IBAT[sprn & 1][(sprn - SPR_IBAT0U) / 2]));
271 3fc6c082 bellard
}
272 3fc6c082 bellard
273 45d827d2 aurel32
static void spr_read_ibat_h (void *opaque, int gprn, int sprn)
274 3fc6c082 bellard
{
275 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, IBAT[sprn & 1][(sprn - SPR_IBAT4U) / 2]));
276 3fc6c082 bellard
}
277 3fc6c082 bellard
278 45d827d2 aurel32
static void spr_write_ibatu (void *opaque, int sprn, int gprn)
279 3fc6c082 bellard
{
280 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
281 45d827d2 aurel32
    gen_helper_store_ibatu(t0, cpu_gpr[gprn]);
282 45d827d2 aurel32
    tcg_temp_free_i32(t0);
283 3fc6c082 bellard
}
284 3fc6c082 bellard
285 45d827d2 aurel32
static void spr_write_ibatu_h (void *opaque, int sprn, int gprn)
286 3fc6c082 bellard
{
287 8daf1781 Thomas Monjalon
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_IBAT4U) / 2) + 4);
288 45d827d2 aurel32
    gen_helper_store_ibatu(t0, cpu_gpr[gprn]);
289 45d827d2 aurel32
    tcg_temp_free_i32(t0);
290 3fc6c082 bellard
}
291 3fc6c082 bellard
292 45d827d2 aurel32
static void spr_write_ibatl (void *opaque, int sprn, int gprn)
293 3fc6c082 bellard
{
294 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0L) / 2);
295 45d827d2 aurel32
    gen_helper_store_ibatl(t0, cpu_gpr[gprn]);
296 45d827d2 aurel32
    tcg_temp_free_i32(t0);
297 3fc6c082 bellard
}
298 3fc6c082 bellard
299 45d827d2 aurel32
static void spr_write_ibatl_h (void *opaque, int sprn, int gprn)
300 3fc6c082 bellard
{
301 8daf1781 Thomas Monjalon
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_IBAT4L) / 2) + 4);
302 45d827d2 aurel32
    gen_helper_store_ibatl(t0, cpu_gpr[gprn]);
303 45d827d2 aurel32
    tcg_temp_free_i32(t0);
304 3fc6c082 bellard
}
305 3fc6c082 bellard
306 3fc6c082 bellard
/* DBAT0U...DBAT7U */
307 3fc6c082 bellard
/* DBAT0L...DBAT7L */
308 45d827d2 aurel32
static void spr_read_dbat (void *opaque, int gprn, int sprn)
309 3fc6c082 bellard
{
310 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, DBAT[sprn & 1][(sprn - SPR_DBAT0U) / 2]));
311 3fc6c082 bellard
}
312 3fc6c082 bellard
313 45d827d2 aurel32
static void spr_read_dbat_h (void *opaque, int gprn, int sprn)
314 3fc6c082 bellard
{
315 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, DBAT[sprn & 1][((sprn - SPR_DBAT4U) / 2) + 4]));
316 3fc6c082 bellard
}
317 3fc6c082 bellard
318 45d827d2 aurel32
static void spr_write_dbatu (void *opaque, int sprn, int gprn)
319 3fc6c082 bellard
{
320 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_DBAT0U) / 2);
321 45d827d2 aurel32
    gen_helper_store_dbatu(t0, cpu_gpr[gprn]);
322 45d827d2 aurel32
    tcg_temp_free_i32(t0);
323 3fc6c082 bellard
}
324 3fc6c082 bellard
325 45d827d2 aurel32
static void spr_write_dbatu_h (void *opaque, int sprn, int gprn)
326 3fc6c082 bellard
{
327 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_DBAT4U) / 2) + 4);
328 45d827d2 aurel32
    gen_helper_store_dbatu(t0, cpu_gpr[gprn]);
329 45d827d2 aurel32
    tcg_temp_free_i32(t0);
330 3fc6c082 bellard
}
331 3fc6c082 bellard
332 45d827d2 aurel32
static void spr_write_dbatl (void *opaque, int sprn, int gprn)
333 3fc6c082 bellard
{
334 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_DBAT0L) / 2);
335 45d827d2 aurel32
    gen_helper_store_dbatl(t0, cpu_gpr[gprn]);
336 45d827d2 aurel32
    tcg_temp_free_i32(t0);
337 3fc6c082 bellard
}
338 3fc6c082 bellard
339 45d827d2 aurel32
static void spr_write_dbatl_h (void *opaque, int sprn, int gprn)
340 3fc6c082 bellard
{
341 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_DBAT4L) / 2) + 4);
342 45d827d2 aurel32
    gen_helper_store_dbatl(t0, cpu_gpr[gprn]);
343 45d827d2 aurel32
    tcg_temp_free_i32(t0);
344 3fc6c082 bellard
}
345 3fc6c082 bellard
346 3fc6c082 bellard
/* SDR1 */
347 45d827d2 aurel32
static void spr_write_sdr1 (void *opaque, int sprn, int gprn)
348 3fc6c082 bellard
{
349 45d827d2 aurel32
    gen_helper_store_sdr1(cpu_gpr[gprn]);
350 3fc6c082 bellard
}
351 3fc6c082 bellard
352 76a66253 j_mayer
/* 64 bits PowerPC specific SPRs */
353 76a66253 j_mayer
/* ASR */
354 578bb252 j_mayer
#if defined(TARGET_PPC64)
355 2adab7d6 blueswir1
static void spr_read_hior (void *opaque, int gprn, int sprn)
356 2adab7d6 blueswir1
{
357 2adab7d6 blueswir1
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, excp_prefix));
358 2adab7d6 blueswir1
}
359 2adab7d6 blueswir1
360 2adab7d6 blueswir1
static void spr_write_hior (void *opaque, int sprn, int gprn)
361 2adab7d6 blueswir1
{
362 2adab7d6 blueswir1
    TCGv t0 = tcg_temp_new();
363 2adab7d6 blueswir1
    tcg_gen_andi_tl(t0, cpu_gpr[gprn], 0x3FFFFF00000ULL);
364 2adab7d6 blueswir1
    tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, excp_prefix));
365 2adab7d6 blueswir1
    tcg_temp_free(t0);
366 2adab7d6 blueswir1
}
367 2adab7d6 blueswir1
368 45d827d2 aurel32
static void spr_read_asr (void *opaque, int gprn, int sprn)
369 76a66253 j_mayer
{
370 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, asr));
371 76a66253 j_mayer
}
372 76a66253 j_mayer
373 45d827d2 aurel32
static void spr_write_asr (void *opaque, int sprn, int gprn)
374 76a66253 j_mayer
{
375 45d827d2 aurel32
    gen_helper_store_asr(cpu_gpr[gprn]);
376 76a66253 j_mayer
}
377 76a66253 j_mayer
#endif
378 a750fc0b j_mayer
#endif
379 76a66253 j_mayer
380 76a66253 j_mayer
/* PowerPC 601 specific registers */
381 76a66253 j_mayer
/* RTC */
382 45d827d2 aurel32
static void spr_read_601_rtcl (void *opaque, int gprn, int sprn)
383 76a66253 j_mayer
{
384 45d827d2 aurel32
    gen_helper_load_601_rtcl(cpu_gpr[gprn]);
385 76a66253 j_mayer
}
386 76a66253 j_mayer
387 45d827d2 aurel32
static void spr_read_601_rtcu (void *opaque, int gprn, int sprn)
388 76a66253 j_mayer
{
389 45d827d2 aurel32
    gen_helper_load_601_rtcu(cpu_gpr[gprn]);
390 76a66253 j_mayer
}
391 76a66253 j_mayer
392 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
393 45d827d2 aurel32
static void spr_write_601_rtcu (void *opaque, int sprn, int gprn)
394 76a66253 j_mayer
{
395 45d827d2 aurel32
    gen_helper_store_601_rtcu(cpu_gpr[gprn]);
396 76a66253 j_mayer
}
397 76a66253 j_mayer
398 45d827d2 aurel32
static void spr_write_601_rtcl (void *opaque, int sprn, int gprn)
399 76a66253 j_mayer
{
400 45d827d2 aurel32
    gen_helper_store_601_rtcl(cpu_gpr[gprn]);
401 76a66253 j_mayer
}
402 056401ea j_mayer
403 45d827d2 aurel32
static void spr_write_hid0_601 (void *opaque, int sprn, int gprn)
404 056401ea j_mayer
{
405 056401ea j_mayer
    DisasContext *ctx = opaque;
406 056401ea j_mayer
407 45d827d2 aurel32
    gen_helper_store_hid0_601(cpu_gpr[gprn]);
408 056401ea j_mayer
    /* Must stop the translation as endianness may have changed */
409 e06fcd75 aurel32
    gen_stop_exception(ctx);
410 056401ea j_mayer
}
411 76a66253 j_mayer
#endif
412 76a66253 j_mayer
413 76a66253 j_mayer
/* Unified bats */
414 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
415 45d827d2 aurel32
static void spr_read_601_ubat (void *opaque, int gprn, int sprn)
416 76a66253 j_mayer
{
417 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, IBAT[sprn & 1][(sprn - SPR_IBAT0U) / 2]));
418 76a66253 j_mayer
}
419 76a66253 j_mayer
420 45d827d2 aurel32
static void spr_write_601_ubatu (void *opaque, int sprn, int gprn)
421 76a66253 j_mayer
{
422 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
423 45d827d2 aurel32
    gen_helper_store_601_batl(t0, cpu_gpr[gprn]);
424 45d827d2 aurel32
    tcg_temp_free_i32(t0);
425 76a66253 j_mayer
}
426 76a66253 j_mayer
427 45d827d2 aurel32
static void spr_write_601_ubatl (void *opaque, int sprn, int gprn)
428 76a66253 j_mayer
{
429 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
430 45d827d2 aurel32
    gen_helper_store_601_batu(t0, cpu_gpr[gprn]);
431 45d827d2 aurel32
    tcg_temp_free_i32(t0);
432 76a66253 j_mayer
}
433 76a66253 j_mayer
#endif
434 76a66253 j_mayer
435 76a66253 j_mayer
/* PowerPC 40x specific registers */
436 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
437 45d827d2 aurel32
static void spr_read_40x_pit (void *opaque, int gprn, int sprn)
438 76a66253 j_mayer
{
439 45d827d2 aurel32
    gen_helper_load_40x_pit(cpu_gpr[gprn]);
440 76a66253 j_mayer
}
441 76a66253 j_mayer
442 45d827d2 aurel32
static void spr_write_40x_pit (void *opaque, int sprn, int gprn)
443 76a66253 j_mayer
{
444 45d827d2 aurel32
    gen_helper_store_40x_pit(cpu_gpr[gprn]);
445 76a66253 j_mayer
}
446 76a66253 j_mayer
447 45d827d2 aurel32
static void spr_write_40x_dbcr0 (void *opaque, int sprn, int gprn)
448 8ecc7913 j_mayer
{
449 8ecc7913 j_mayer
    DisasContext *ctx = opaque;
450 8ecc7913 j_mayer
451 45d827d2 aurel32
    gen_helper_store_40x_dbcr0(cpu_gpr[gprn]);
452 8ecc7913 j_mayer
    /* We must stop translation as we may have rebooted */
453 e06fcd75 aurel32
    gen_stop_exception(ctx);
454 8ecc7913 j_mayer
}
455 8ecc7913 j_mayer
456 45d827d2 aurel32
static void spr_write_40x_sler (void *opaque, int sprn, int gprn)
457 c294fc58 j_mayer
{
458 45d827d2 aurel32
    gen_helper_store_40x_sler(cpu_gpr[gprn]);
459 c294fc58 j_mayer
}
460 c294fc58 j_mayer
461 45d827d2 aurel32
static void spr_write_booke_tcr (void *opaque, int sprn, int gprn)
462 76a66253 j_mayer
{
463 45d827d2 aurel32
    gen_helper_store_booke_tcr(cpu_gpr[gprn]);
464 76a66253 j_mayer
}
465 76a66253 j_mayer
466 45d827d2 aurel32
static void spr_write_booke_tsr (void *opaque, int sprn, int gprn)
467 76a66253 j_mayer
{
468 45d827d2 aurel32
    gen_helper_store_booke_tsr(cpu_gpr[gprn]);
469 76a66253 j_mayer
}
470 76a66253 j_mayer
#endif
471 76a66253 j_mayer
472 76a66253 j_mayer
/* PowerPC 403 specific registers */
473 76a66253 j_mayer
/* PBL1 / PBU1 / PBL2 / PBU2 */
474 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
475 45d827d2 aurel32
static void spr_read_403_pbr (void *opaque, int gprn, int sprn)
476 76a66253 j_mayer
{
477 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, pb[sprn - SPR_403_PBL1]));
478 76a66253 j_mayer
}
479 76a66253 j_mayer
480 45d827d2 aurel32
static void spr_write_403_pbr (void *opaque, int sprn, int gprn)
481 76a66253 j_mayer
{
482 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32(sprn - SPR_403_PBL1);
483 45d827d2 aurel32
    gen_helper_store_403_pbr(t0, cpu_gpr[gprn]);
484 45d827d2 aurel32
    tcg_temp_free_i32(t0);
485 76a66253 j_mayer
}
486 76a66253 j_mayer
487 45d827d2 aurel32
static void spr_write_pir (void *opaque, int sprn, int gprn)
488 3fc6c082 bellard
{
489 45d827d2 aurel32
    TCGv t0 = tcg_temp_new();
490 45d827d2 aurel32
    tcg_gen_andi_tl(t0, cpu_gpr[gprn], 0xF);
491 45d827d2 aurel32
    gen_store_spr(SPR_PIR, t0);
492 45d827d2 aurel32
    tcg_temp_free(t0);
493 3fc6c082 bellard
}
494 76a66253 j_mayer
#endif
495 3fc6c082 bellard
496 d34defbc aurel32
/* SPE specific registers */
497 d34defbc aurel32
static void spr_read_spefscr (void *opaque, int gprn, int sprn)
498 d34defbc aurel32
{
499 d34defbc aurel32
    TCGv_i32 t0 = tcg_temp_new_i32();
500 515e2f7e aurel32
    tcg_gen_ld_i32(t0, cpu_env, offsetof(CPUState, spe_fscr));
501 d34defbc aurel32
    tcg_gen_extu_i32_tl(cpu_gpr[gprn], t0);
502 d34defbc aurel32
    tcg_temp_free_i32(t0);
503 d34defbc aurel32
}
504 d34defbc aurel32
505 d34defbc aurel32
static void spr_write_spefscr (void *opaque, int sprn, int gprn)
506 d34defbc aurel32
{
507 d34defbc aurel32
    TCGv_i32 t0 = tcg_temp_new_i32();
508 d34defbc aurel32
    tcg_gen_trunc_tl_i32(t0, cpu_gpr[gprn]);
509 515e2f7e aurel32
    tcg_gen_st_i32(t0, cpu_env, offsetof(CPUState, spe_fscr));
510 d34defbc aurel32
    tcg_temp_free_i32(t0);
511 d34defbc aurel32
}
512 d34defbc aurel32
513 6f5d427d j_mayer
#if !defined(CONFIG_USER_ONLY)
514 6f5d427d j_mayer
/* Callback used to write the exception vector base */
515 45d827d2 aurel32
static void spr_write_excp_prefix (void *opaque, int sprn, int gprn)
516 6f5d427d j_mayer
{
517 45d827d2 aurel32
    TCGv t0 = tcg_temp_new();
518 45d827d2 aurel32
    tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, ivpr_mask));
519 45d827d2 aurel32
    tcg_gen_and_tl(t0, t0, cpu_gpr[gprn]);
520 45d827d2 aurel32
    tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, excp_prefix));
521 45d827d2 aurel32
    gen_store_spr(sprn, t0);
522 69bd5820 aurel32
    tcg_temp_free(t0);
523 6f5d427d j_mayer
}
524 6f5d427d j_mayer
525 45d827d2 aurel32
static void spr_write_excp_vector (void *opaque, int sprn, int gprn)
526 6f5d427d j_mayer
{
527 6f5d427d j_mayer
    DisasContext *ctx = opaque;
528 6f5d427d j_mayer
529 6f5d427d j_mayer
    if (sprn >= SPR_BOOKE_IVOR0 && sprn <= SPR_BOOKE_IVOR15) {
530 45d827d2 aurel32
        TCGv t0 = tcg_temp_new();
531 45d827d2 aurel32
        tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, ivor_mask));
532 45d827d2 aurel32
        tcg_gen_and_tl(t0, t0, cpu_gpr[gprn]);
533 45d827d2 aurel32
        tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, excp_vectors[sprn - SPR_BOOKE_IVOR0]));
534 45d827d2 aurel32
        gen_store_spr(sprn, t0);
535 45d827d2 aurel32
        tcg_temp_free(t0);
536 6f5d427d j_mayer
    } else if (sprn >= SPR_BOOKE_IVOR32 && sprn <= SPR_BOOKE_IVOR37) {
537 45d827d2 aurel32
        TCGv t0 = tcg_temp_new();
538 45d827d2 aurel32
        tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, ivor_mask));
539 45d827d2 aurel32
        tcg_gen_and_tl(t0, t0, cpu_gpr[gprn]);
540 45d827d2 aurel32
        tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, excp_vectors[sprn - SPR_BOOKE_IVOR32 + 32]));
541 45d827d2 aurel32
        gen_store_spr(sprn, t0);
542 45d827d2 aurel32
        tcg_temp_free(t0);
543 6f5d427d j_mayer
    } else {
544 6f5d427d j_mayer
        printf("Trying to write an unknown exception vector %d %03x\n",
545 6f5d427d j_mayer
               sprn, sprn);
546 e06fcd75 aurel32
        gen_inval_exception(ctx, POWERPC_EXCP_PRIV_REG);
547 6f5d427d j_mayer
    }
548 6f5d427d j_mayer
}
549 6f5d427d j_mayer
#endif
550 6f5d427d j_mayer
551 cf8358c8 aurel32
static inline void vscr_init (CPUPPCState *env, uint32_t val)
552 cf8358c8 aurel32
{
553 cf8358c8 aurel32
    env->vscr = val;
554 cf8358c8 aurel32
    /* Altivec always uses round-to-nearest */
555 cf8358c8 aurel32
    set_float_rounding_mode(float_round_nearest_even, &env->vec_status);
556 cf8358c8 aurel32
    set_flush_to_zero(vscr_nj, &env->vec_status);
557 cf8358c8 aurel32
}
558 cf8358c8 aurel32
559 76a66253 j_mayer
#if defined(CONFIG_USER_ONLY)
560 76a66253 j_mayer
#define spr_register(env, num, name, uea_read, uea_write,                     \
561 76a66253 j_mayer
                     oea_read, oea_write, initial_value)                      \
562 76a66253 j_mayer
do {                                                                          \
563 76a66253 j_mayer
     _spr_register(env, num, name, uea_read, uea_write, initial_value);       \
564 76a66253 j_mayer
} while (0)
565 76a66253 j_mayer
static inline void _spr_register (CPUPPCState *env, int num,
566 b55266b5 blueswir1
                                  const char *name,
567 45d827d2 aurel32
                                  void (*uea_read)(void *opaque, int gprn, int sprn),
568 45d827d2 aurel32
                                  void (*uea_write)(void *opaque, int sprn, int gprn),
569 76a66253 j_mayer
                                  target_ulong initial_value)
570 76a66253 j_mayer
#else
571 3fc6c082 bellard
static inline void spr_register (CPUPPCState *env, int num,
572 b55266b5 blueswir1
                                 const char *name,
573 45d827d2 aurel32
                                 void (*uea_read)(void *opaque, int gprn, int sprn),
574 45d827d2 aurel32
                                 void (*uea_write)(void *opaque, int sprn, int gprn),
575 45d827d2 aurel32
                                 void (*oea_read)(void *opaque, int gprn, int sprn),
576 45d827d2 aurel32
                                 void (*oea_write)(void *opaque, int sprn, int gprn),
577 3fc6c082 bellard
                                 target_ulong initial_value)
578 76a66253 j_mayer
#endif
579 3fc6c082 bellard
{
580 c227f099 Anthony Liguori
    ppc_spr_t *spr;
581 3fc6c082 bellard
582 3fc6c082 bellard
    spr = &env->spr_cb[num];
583 3fc6c082 bellard
    if (spr->name != NULL ||env-> spr[num] != 0x00000000 ||
584 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
585 76a66253 j_mayer
        spr->oea_read != NULL || spr->oea_write != NULL ||
586 76a66253 j_mayer
#endif
587 76a66253 j_mayer
        spr->uea_read != NULL || spr->uea_write != NULL) {
588 3fc6c082 bellard
        printf("Error: Trying to register SPR %d (%03x) twice !\n", num, num);
589 3fc6c082 bellard
        exit(1);
590 3fc6c082 bellard
    }
591 3fc6c082 bellard
#if defined(PPC_DEBUG_SPR)
592 90e189ec Blue Swirl
    printf("*** register spr %d (%03x) %s val " TARGET_FMT_lx "\n", num, num,
593 90e189ec Blue Swirl
           name, initial_value);
594 3fc6c082 bellard
#endif
595 3fc6c082 bellard
    spr->name = name;
596 3fc6c082 bellard
    spr->uea_read = uea_read;
597 3fc6c082 bellard
    spr->uea_write = uea_write;
598 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
599 3fc6c082 bellard
    spr->oea_read = oea_read;
600 3fc6c082 bellard
    spr->oea_write = oea_write;
601 76a66253 j_mayer
#endif
602 3fc6c082 bellard
    env->spr[num] = initial_value;
603 3fc6c082 bellard
}
604 3fc6c082 bellard
605 3fc6c082 bellard
/* Generic PowerPC SPRs */
606 3fc6c082 bellard
static void gen_spr_generic (CPUPPCState *env)
607 3fc6c082 bellard
{
608 3fc6c082 bellard
    /* Integer processing */
609 3fc6c082 bellard
    spr_register(env, SPR_XER, "XER",
610 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
611 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
612 3fc6c082 bellard
                 0x00000000);
613 3fc6c082 bellard
    /* Branch contol */
614 3fc6c082 bellard
    spr_register(env, SPR_LR, "LR",
615 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
616 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
617 3fc6c082 bellard
                 0x00000000);
618 3fc6c082 bellard
    spr_register(env, SPR_CTR, "CTR",
619 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
620 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
621 3fc6c082 bellard
                 0x00000000);
622 3fc6c082 bellard
    /* Interrupt processing */
623 3fc6c082 bellard
    spr_register(env, SPR_SRR0, "SRR0",
624 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
625 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
626 3fc6c082 bellard
                 0x00000000);
627 3fc6c082 bellard
    spr_register(env, SPR_SRR1, "SRR1",
628 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
629 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
630 3fc6c082 bellard
                 0x00000000);
631 3fc6c082 bellard
    /* Processor control */
632 3fc6c082 bellard
    spr_register(env, SPR_SPRG0, "SPRG0",
633 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
634 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
635 3fc6c082 bellard
                 0x00000000);
636 3fc6c082 bellard
    spr_register(env, SPR_SPRG1, "SPRG1",
637 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
638 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
639 3fc6c082 bellard
                 0x00000000);
640 3fc6c082 bellard
    spr_register(env, SPR_SPRG2, "SPRG2",
641 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
642 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
643 3fc6c082 bellard
                 0x00000000);
644 3fc6c082 bellard
    spr_register(env, SPR_SPRG3, "SPRG3",
645 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
646 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
647 3fc6c082 bellard
                 0x00000000);
648 3fc6c082 bellard
}
649 3fc6c082 bellard
650 3fc6c082 bellard
/* SPR common to all non-embedded PowerPC, including 601 */
651 3fc6c082 bellard
static void gen_spr_ne_601 (CPUPPCState *env)
652 3fc6c082 bellard
{
653 3fc6c082 bellard
    /* Exception processing */
654 3fc6c082 bellard
    spr_register(env, SPR_DSISR, "DSISR",
655 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
656 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
657 3fc6c082 bellard
                 0x00000000);
658 3fc6c082 bellard
    spr_register(env, SPR_DAR, "DAR",
659 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
660 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
661 3fc6c082 bellard
                 0x00000000);
662 3fc6c082 bellard
    /* Timer */
663 3fc6c082 bellard
    spr_register(env, SPR_DECR, "DECR",
664 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
665 3fc6c082 bellard
                 &spr_read_decr, &spr_write_decr,
666 3fc6c082 bellard
                 0x00000000);
667 3fc6c082 bellard
    /* Memory management */
668 3fc6c082 bellard
    spr_register(env, SPR_SDR1, "SDR1",
669 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
670 bb593904 David Gibson
                 &spr_read_generic, &spr_write_sdr1,
671 3fc6c082 bellard
                 0x00000000);
672 3fc6c082 bellard
}
673 3fc6c082 bellard
674 3fc6c082 bellard
/* BATs 0-3 */
675 3fc6c082 bellard
static void gen_low_BATs (CPUPPCState *env)
676 3fc6c082 bellard
{
677 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
678 3fc6c082 bellard
    spr_register(env, SPR_IBAT0U, "IBAT0U",
679 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
680 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
681 3fc6c082 bellard
                 0x00000000);
682 3fc6c082 bellard
    spr_register(env, SPR_IBAT0L, "IBAT0L",
683 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
684 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
685 3fc6c082 bellard
                 0x00000000);
686 3fc6c082 bellard
    spr_register(env, SPR_IBAT1U, "IBAT1U",
687 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
688 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
689 3fc6c082 bellard
                 0x00000000);
690 3fc6c082 bellard
    spr_register(env, SPR_IBAT1L, "IBAT1L",
691 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
692 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
693 3fc6c082 bellard
                 0x00000000);
694 3fc6c082 bellard
    spr_register(env, SPR_IBAT2U, "IBAT2U",
695 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
696 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
697 3fc6c082 bellard
                 0x00000000);
698 3fc6c082 bellard
    spr_register(env, SPR_IBAT2L, "IBAT2L",
699 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
700 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
701 3fc6c082 bellard
                 0x00000000);
702 3fc6c082 bellard
    spr_register(env, SPR_IBAT3U, "IBAT3U",
703 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
704 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
705 3fc6c082 bellard
                 0x00000000);
706 3fc6c082 bellard
    spr_register(env, SPR_IBAT3L, "IBAT3L",
707 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
708 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
709 3fc6c082 bellard
                 0x00000000);
710 3fc6c082 bellard
    spr_register(env, SPR_DBAT0U, "DBAT0U",
711 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
712 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
713 3fc6c082 bellard
                 0x00000000);
714 3fc6c082 bellard
    spr_register(env, SPR_DBAT0L, "DBAT0L",
715 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
716 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
717 3fc6c082 bellard
                 0x00000000);
718 3fc6c082 bellard
    spr_register(env, SPR_DBAT1U, "DBAT1U",
719 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
720 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
721 3fc6c082 bellard
                 0x00000000);
722 3fc6c082 bellard
    spr_register(env, SPR_DBAT1L, "DBAT1L",
723 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
724 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
725 3fc6c082 bellard
                 0x00000000);
726 3fc6c082 bellard
    spr_register(env, SPR_DBAT2U, "DBAT2U",
727 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
728 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
729 3fc6c082 bellard
                 0x00000000);
730 3fc6c082 bellard
    spr_register(env, SPR_DBAT2L, "DBAT2L",
731 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
732 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
733 3fc6c082 bellard
                 0x00000000);
734 3fc6c082 bellard
    spr_register(env, SPR_DBAT3U, "DBAT3U",
735 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
736 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
737 3fc6c082 bellard
                 0x00000000);
738 3fc6c082 bellard
    spr_register(env, SPR_DBAT3L, "DBAT3L",
739 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
740 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
741 3fc6c082 bellard
                 0x00000000);
742 a750fc0b j_mayer
    env->nb_BATs += 4;
743 f2e63a42 j_mayer
#endif
744 3fc6c082 bellard
}
745 3fc6c082 bellard
746 3fc6c082 bellard
/* BATs 4-7 */
747 3fc6c082 bellard
static void gen_high_BATs (CPUPPCState *env)
748 3fc6c082 bellard
{
749 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
750 3fc6c082 bellard
    spr_register(env, SPR_IBAT4U, "IBAT4U",
751 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
752 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
753 3fc6c082 bellard
                 0x00000000);
754 3fc6c082 bellard
    spr_register(env, SPR_IBAT4L, "IBAT4L",
755 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
756 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
757 3fc6c082 bellard
                 0x00000000);
758 3fc6c082 bellard
    spr_register(env, SPR_IBAT5U, "IBAT5U",
759 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
760 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
761 3fc6c082 bellard
                 0x00000000);
762 3fc6c082 bellard
    spr_register(env, SPR_IBAT5L, "IBAT5L",
763 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
764 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
765 3fc6c082 bellard
                 0x00000000);
766 3fc6c082 bellard
    spr_register(env, SPR_IBAT6U, "IBAT6U",
767 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
768 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
769 3fc6c082 bellard
                 0x00000000);
770 3fc6c082 bellard
    spr_register(env, SPR_IBAT6L, "IBAT6L",
771 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
772 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
773 3fc6c082 bellard
                 0x00000000);
774 3fc6c082 bellard
    spr_register(env, SPR_IBAT7U, "IBAT7U",
775 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
776 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
777 3fc6c082 bellard
                 0x00000000);
778 3fc6c082 bellard
    spr_register(env, SPR_IBAT7L, "IBAT7L",
779 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
780 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
781 3fc6c082 bellard
                 0x00000000);
782 3fc6c082 bellard
    spr_register(env, SPR_DBAT4U, "DBAT4U",
783 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
784 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
785 3fc6c082 bellard
                 0x00000000);
786 3fc6c082 bellard
    spr_register(env, SPR_DBAT4L, "DBAT4L",
787 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
788 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
789 3fc6c082 bellard
                 0x00000000);
790 3fc6c082 bellard
    spr_register(env, SPR_DBAT5U, "DBAT5U",
791 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
792 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
793 3fc6c082 bellard
                 0x00000000);
794 3fc6c082 bellard
    spr_register(env, SPR_DBAT5L, "DBAT5L",
795 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
796 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
797 3fc6c082 bellard
                 0x00000000);
798 3fc6c082 bellard
    spr_register(env, SPR_DBAT6U, "DBAT6U",
799 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
800 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
801 3fc6c082 bellard
                 0x00000000);
802 3fc6c082 bellard
    spr_register(env, SPR_DBAT6L, "DBAT6L",
803 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
804 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
805 3fc6c082 bellard
                 0x00000000);
806 3fc6c082 bellard
    spr_register(env, SPR_DBAT7U, "DBAT7U",
807 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
808 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
809 3fc6c082 bellard
                 0x00000000);
810 3fc6c082 bellard
    spr_register(env, SPR_DBAT7L, "DBAT7L",
811 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
812 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
813 3fc6c082 bellard
                 0x00000000);
814 a750fc0b j_mayer
    env->nb_BATs += 4;
815 f2e63a42 j_mayer
#endif
816 3fc6c082 bellard
}
817 3fc6c082 bellard
818 3fc6c082 bellard
/* Generic PowerPC time base */
819 3fc6c082 bellard
static void gen_tbl (CPUPPCState *env)
820 3fc6c082 bellard
{
821 3fc6c082 bellard
    spr_register(env, SPR_VTBL,  "TBL",
822 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
823 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
824 3fc6c082 bellard
                 0x00000000);
825 3fc6c082 bellard
    spr_register(env, SPR_TBL,   "TBL",
826 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbl, SPR_NOACCESS,
827 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbl, &spr_write_tbl,
828 3fc6c082 bellard
                 0x00000000);
829 3fc6c082 bellard
    spr_register(env, SPR_VTBU,  "TBU",
830 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
831 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
832 3fc6c082 bellard
                 0x00000000);
833 3fc6c082 bellard
    spr_register(env, SPR_TBU,   "TBU",
834 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbu, SPR_NOACCESS,
835 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbu, &spr_write_tbu,
836 3fc6c082 bellard
                 0x00000000);
837 3fc6c082 bellard
}
838 3fc6c082 bellard
839 76a66253 j_mayer
/* Softare table search registers */
840 76a66253 j_mayer
static void gen_6xx_7xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
841 76a66253 j_mayer
{
842 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
843 76a66253 j_mayer
    env->nb_tlb = nb_tlbs;
844 76a66253 j_mayer
    env->nb_ways = nb_ways;
845 76a66253 j_mayer
    env->id_tlbs = 1;
846 76a66253 j_mayer
    spr_register(env, SPR_DMISS, "DMISS",
847 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
848 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
849 76a66253 j_mayer
                 0x00000000);
850 76a66253 j_mayer
    spr_register(env, SPR_DCMP, "DCMP",
851 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
852 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
853 76a66253 j_mayer
                 0x00000000);
854 76a66253 j_mayer
    spr_register(env, SPR_HASH1, "HASH1",
855 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
856 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
857 76a66253 j_mayer
                 0x00000000);
858 76a66253 j_mayer
    spr_register(env, SPR_HASH2, "HASH2",
859 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
860 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
861 76a66253 j_mayer
                 0x00000000);
862 76a66253 j_mayer
    spr_register(env, SPR_IMISS, "IMISS",
863 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
864 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
865 76a66253 j_mayer
                 0x00000000);
866 76a66253 j_mayer
    spr_register(env, SPR_ICMP, "ICMP",
867 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
868 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
869 76a66253 j_mayer
                 0x00000000);
870 76a66253 j_mayer
    spr_register(env, SPR_RPA, "RPA",
871 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
872 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
873 76a66253 j_mayer
                 0x00000000);
874 f2e63a42 j_mayer
#endif
875 76a66253 j_mayer
}
876 76a66253 j_mayer
877 76a66253 j_mayer
/* SPR common to MPC755 and G2 */
878 76a66253 j_mayer
static void gen_spr_G2_755 (CPUPPCState *env)
879 76a66253 j_mayer
{
880 76a66253 j_mayer
    /* SGPRs */
881 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
882 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
883 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
884 76a66253 j_mayer
                 0x00000000);
885 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
886 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
887 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
888 76a66253 j_mayer
                 0x00000000);
889 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
890 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
891 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
892 76a66253 j_mayer
                 0x00000000);
893 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
894 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
895 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
896 76a66253 j_mayer
                 0x00000000);
897 76a66253 j_mayer
}
898 76a66253 j_mayer
899 3fc6c082 bellard
/* SPR common to all 7xx PowerPC implementations */
900 3fc6c082 bellard
static void gen_spr_7xx (CPUPPCState *env)
901 3fc6c082 bellard
{
902 3fc6c082 bellard
    /* Breakpoints */
903 3fc6c082 bellard
    /* XXX : not implemented */
904 3fc6c082 bellard
    spr_register(env, SPR_DABR, "DABR",
905 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
906 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
907 3fc6c082 bellard
                 0x00000000);
908 3fc6c082 bellard
    /* XXX : not implemented */
909 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
910 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
911 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
912 3fc6c082 bellard
                 0x00000000);
913 3fc6c082 bellard
    /* Cache management */
914 3fc6c082 bellard
    /* XXX : not implemented */
915 3fc6c082 bellard
    spr_register(env, SPR_ICTC, "ICTC",
916 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
917 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
918 3fc6c082 bellard
                 0x00000000);
919 3fc6c082 bellard
    /* Performance monitors */
920 3fc6c082 bellard
    /* XXX : not implemented */
921 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
922 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
923 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
924 3fc6c082 bellard
                 0x00000000);
925 3fc6c082 bellard
    /* XXX : not implemented */
926 3fc6c082 bellard
    spr_register(env, SPR_MMCR1, "MMCR1",
927 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
928 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
929 3fc6c082 bellard
                 0x00000000);
930 3fc6c082 bellard
    /* XXX : not implemented */
931 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
932 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
933 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
934 3fc6c082 bellard
                 0x00000000);
935 3fc6c082 bellard
    /* XXX : not implemented */
936 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
937 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
938 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
939 3fc6c082 bellard
                 0x00000000);
940 3fc6c082 bellard
    /* XXX : not implemented */
941 3fc6c082 bellard
    spr_register(env, SPR_PMC3, "PMC3",
942 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
943 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
944 3fc6c082 bellard
                 0x00000000);
945 3fc6c082 bellard
    /* XXX : not implemented */
946 3fc6c082 bellard
    spr_register(env, SPR_PMC4, "PMC4",
947 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
948 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
949 3fc6c082 bellard
                 0x00000000);
950 3fc6c082 bellard
    /* XXX : not implemented */
951 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
952 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
953 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
954 3fc6c082 bellard
                 0x00000000);
955 578bb252 j_mayer
    /* XXX : not implemented */
956 3fc6c082 bellard
    spr_register(env, SPR_UMMCR0, "UMMCR0",
957 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
958 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
959 3fc6c082 bellard
                 0x00000000);
960 578bb252 j_mayer
    /* XXX : not implemented */
961 3fc6c082 bellard
    spr_register(env, SPR_UMMCR1, "UMMCR1",
962 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
963 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
964 3fc6c082 bellard
                 0x00000000);
965 578bb252 j_mayer
    /* XXX : not implemented */
966 3fc6c082 bellard
    spr_register(env, SPR_UPMC1, "UPMC1",
967 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
968 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
969 3fc6c082 bellard
                 0x00000000);
970 578bb252 j_mayer
    /* XXX : not implemented */
971 3fc6c082 bellard
    spr_register(env, SPR_UPMC2, "UPMC2",
972 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
973 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
974 3fc6c082 bellard
                 0x00000000);
975 578bb252 j_mayer
    /* XXX : not implemented */
976 3fc6c082 bellard
    spr_register(env, SPR_UPMC3, "UPMC3",
977 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
978 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
979 3fc6c082 bellard
                 0x00000000);
980 578bb252 j_mayer
    /* XXX : not implemented */
981 3fc6c082 bellard
    spr_register(env, SPR_UPMC4, "UPMC4",
982 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
983 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
984 3fc6c082 bellard
                 0x00000000);
985 578bb252 j_mayer
    /* XXX : not implemented */
986 a750fc0b j_mayer
    spr_register(env, SPR_USIAR, "USIAR",
987 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
988 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
989 3fc6c082 bellard
                 0x00000000);
990 a750fc0b j_mayer
    /* External access control */
991 3fc6c082 bellard
    /* XXX : not implemented */
992 a750fc0b j_mayer
    spr_register(env, SPR_EAR, "EAR",
993 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
994 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
995 3fc6c082 bellard
                 0x00000000);
996 a750fc0b j_mayer
}
997 a750fc0b j_mayer
998 a750fc0b j_mayer
static void gen_spr_thrm (CPUPPCState *env)
999 a750fc0b j_mayer
{
1000 a750fc0b j_mayer
    /* Thermal management */
1001 3fc6c082 bellard
    /* XXX : not implemented */
1002 a750fc0b j_mayer
    spr_register(env, SPR_THRM1, "THRM1",
1003 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1004 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1005 3fc6c082 bellard
                 0x00000000);
1006 3fc6c082 bellard
    /* XXX : not implemented */
1007 a750fc0b j_mayer
    spr_register(env, SPR_THRM2, "THRM2",
1008 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1009 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1010 3fc6c082 bellard
                 0x00000000);
1011 3fc6c082 bellard
    /* XXX : not implemented */
1012 a750fc0b j_mayer
    spr_register(env, SPR_THRM3, "THRM3",
1013 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1014 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1015 3fc6c082 bellard
                 0x00000000);
1016 3fc6c082 bellard
}
1017 3fc6c082 bellard
1018 3fc6c082 bellard
/* SPR specific to PowerPC 604 implementation */
1019 3fc6c082 bellard
static void gen_spr_604 (CPUPPCState *env)
1020 3fc6c082 bellard
{
1021 3fc6c082 bellard
    /* Processor identification */
1022 3fc6c082 bellard
    spr_register(env, SPR_PIR, "PIR",
1023 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1024 3fc6c082 bellard
                 &spr_read_generic, &spr_write_pir,
1025 3fc6c082 bellard
                 0x00000000);
1026 3fc6c082 bellard
    /* Breakpoints */
1027 3fc6c082 bellard
    /* XXX : not implemented */
1028 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
1029 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1030 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1031 3fc6c082 bellard
                 0x00000000);
1032 3fc6c082 bellard
    /* XXX : not implemented */
1033 3fc6c082 bellard
    spr_register(env, SPR_DABR, "DABR",
1034 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1035 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1036 3fc6c082 bellard
                 0x00000000);
1037 3fc6c082 bellard
    /* Performance counters */
1038 3fc6c082 bellard
    /* XXX : not implemented */
1039 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
1040 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1041 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1042 3fc6c082 bellard
                 0x00000000);
1043 3fc6c082 bellard
    /* XXX : not implemented */
1044 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
1045 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1046 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1047 3fc6c082 bellard
                 0x00000000);
1048 3fc6c082 bellard
    /* XXX : not implemented */
1049 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
1050 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1051 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1052 3fc6c082 bellard
                 0x00000000);
1053 3fc6c082 bellard
    /* XXX : not implemented */
1054 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
1055 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1056 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
1057 3fc6c082 bellard
                 0x00000000);
1058 3fc6c082 bellard
    /* XXX : not implemented */
1059 3fc6c082 bellard
    spr_register(env, SPR_SDA, "SDA",
1060 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1061 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
1062 3fc6c082 bellard
                 0x00000000);
1063 3fc6c082 bellard
    /* External access control */
1064 3fc6c082 bellard
    /* XXX : not implemented */
1065 3fc6c082 bellard
    spr_register(env, SPR_EAR, "EAR",
1066 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1067 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1068 3fc6c082 bellard
                 0x00000000);
1069 3fc6c082 bellard
}
1070 3fc6c082 bellard
1071 76a66253 j_mayer
/* SPR specific to PowerPC 603 implementation */
1072 76a66253 j_mayer
static void gen_spr_603 (CPUPPCState *env)
1073 3fc6c082 bellard
{
1074 76a66253 j_mayer
    /* External access control */
1075 76a66253 j_mayer
    /* XXX : not implemented */
1076 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
1077 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1078 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1079 76a66253 j_mayer
                 0x00000000);
1080 3fc6c082 bellard
}
1081 3fc6c082 bellard
1082 76a66253 j_mayer
/* SPR specific to PowerPC G2 implementation */
1083 76a66253 j_mayer
static void gen_spr_G2 (CPUPPCState *env)
1084 3fc6c082 bellard
{
1085 76a66253 j_mayer
    /* Memory base address */
1086 76a66253 j_mayer
    /* MBAR */
1087 578bb252 j_mayer
    /* XXX : not implemented */
1088 76a66253 j_mayer
    spr_register(env, SPR_MBAR, "MBAR",
1089 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1090 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1091 76a66253 j_mayer
                 0x00000000);
1092 76a66253 j_mayer
    /* Exception processing */
1093 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
1094 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1095 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1096 76a66253 j_mayer
                 0x00000000);
1097 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
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
    /* Breakpoints */
1102 76a66253 j_mayer
    /* XXX : not implemented */
1103 76a66253 j_mayer
    spr_register(env, SPR_DABR, "DABR",
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
    /* XXX : not implemented */
1108 76a66253 j_mayer
    spr_register(env, SPR_DABR2, "DABR2",
1109 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1110 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1111 76a66253 j_mayer
                 0x00000000);
1112 76a66253 j_mayer
    /* XXX : not implemented */
1113 76a66253 j_mayer
    spr_register(env, SPR_IABR, "IABR",
1114 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1115 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1116 76a66253 j_mayer
                 0x00000000);
1117 76a66253 j_mayer
    /* XXX : not implemented */
1118 76a66253 j_mayer
    spr_register(env, SPR_IABR2, "IABR2",
1119 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1120 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1121 76a66253 j_mayer
                 0x00000000);
1122 76a66253 j_mayer
    /* XXX : not implemented */
1123 76a66253 j_mayer
    spr_register(env, SPR_IBCR, "IBCR",
1124 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1125 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1126 76a66253 j_mayer
                 0x00000000);
1127 76a66253 j_mayer
    /* XXX : not implemented */
1128 76a66253 j_mayer
    spr_register(env, SPR_DBCR, "DBCR",
1129 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1130 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1131 76a66253 j_mayer
                 0x00000000);
1132 76a66253 j_mayer
}
1133 76a66253 j_mayer
1134 76a66253 j_mayer
/* SPR specific to PowerPC 602 implementation */
1135 76a66253 j_mayer
static void gen_spr_602 (CPUPPCState *env)
1136 76a66253 j_mayer
{
1137 76a66253 j_mayer
    /* ESA registers */
1138 76a66253 j_mayer
    /* XXX : not implemented */
1139 76a66253 j_mayer
    spr_register(env, SPR_SER, "SER",
1140 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1141 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1142 76a66253 j_mayer
                 0x00000000);
1143 76a66253 j_mayer
    /* XXX : not implemented */
1144 76a66253 j_mayer
    spr_register(env, SPR_SEBR, "SEBR",
1145 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1146 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1147 76a66253 j_mayer
                 0x00000000);
1148 76a66253 j_mayer
    /* XXX : not implemented */
1149 a750fc0b j_mayer
    spr_register(env, SPR_ESASRR, "ESASRR",
1150 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1151 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1152 76a66253 j_mayer
                 0x00000000);
1153 76a66253 j_mayer
    /* Floating point status */
1154 76a66253 j_mayer
    /* XXX : not implemented */
1155 76a66253 j_mayer
    spr_register(env, SPR_SP, "SP",
1156 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1157 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1158 76a66253 j_mayer
                 0x00000000);
1159 76a66253 j_mayer
    /* XXX : not implemented */
1160 76a66253 j_mayer
    spr_register(env, SPR_LT, "LT",
1161 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1162 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1163 76a66253 j_mayer
                 0x00000000);
1164 76a66253 j_mayer
    /* Watchdog timer */
1165 76a66253 j_mayer
    /* XXX : not implemented */
1166 76a66253 j_mayer
    spr_register(env, SPR_TCR, "TCR",
1167 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1168 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1169 76a66253 j_mayer
                 0x00000000);
1170 76a66253 j_mayer
    /* Interrupt base */
1171 76a66253 j_mayer
    spr_register(env, SPR_IBR, "IBR",
1172 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1173 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1174 76a66253 j_mayer
                 0x00000000);
1175 a750fc0b j_mayer
    /* XXX : not implemented */
1176 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
1177 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1178 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1179 a750fc0b j_mayer
                 0x00000000);
1180 76a66253 j_mayer
}
1181 76a66253 j_mayer
1182 76a66253 j_mayer
/* SPR specific to PowerPC 601 implementation */
1183 76a66253 j_mayer
static void gen_spr_601 (CPUPPCState *env)
1184 76a66253 j_mayer
{
1185 76a66253 j_mayer
    /* Multiplication/division register */
1186 76a66253 j_mayer
    /* MQ */
1187 76a66253 j_mayer
    spr_register(env, SPR_MQ, "MQ",
1188 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1189 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1190 76a66253 j_mayer
                 0x00000000);
1191 76a66253 j_mayer
    /* RTC registers */
1192 76a66253 j_mayer
    spr_register(env, SPR_601_RTCU, "RTCU",
1193 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1194 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcu,
1195 76a66253 j_mayer
                 0x00000000);
1196 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCU, "RTCU",
1197 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1198 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1199 76a66253 j_mayer
                 0x00000000);
1200 76a66253 j_mayer
    spr_register(env, SPR_601_RTCL, "RTCL",
1201 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1202 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcl,
1203 76a66253 j_mayer
                 0x00000000);
1204 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCL, "RTCL",
1205 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1206 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1207 76a66253 j_mayer
                 0x00000000);
1208 76a66253 j_mayer
    /* Timer */
1209 76a66253 j_mayer
#if 0 /* ? */
1210 76a66253 j_mayer
    spr_register(env, SPR_601_UDECR, "UDECR",
1211 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1212 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1213 76a66253 j_mayer
                 0x00000000);
1214 76a66253 j_mayer
#endif
1215 76a66253 j_mayer
    /* External access control */
1216 76a66253 j_mayer
    /* XXX : not implemented */
1217 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
1218 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1219 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1220 76a66253 j_mayer
                 0x00000000);
1221 76a66253 j_mayer
    /* Memory management */
1222 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1223 76a66253 j_mayer
    spr_register(env, SPR_IBAT0U, "IBAT0U",
1224 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1225 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1226 76a66253 j_mayer
                 0x00000000);
1227 76a66253 j_mayer
    spr_register(env, SPR_IBAT0L, "IBAT0L",
1228 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1229 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1230 76a66253 j_mayer
                 0x00000000);
1231 76a66253 j_mayer
    spr_register(env, SPR_IBAT1U, "IBAT1U",
1232 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1233 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1234 76a66253 j_mayer
                 0x00000000);
1235 76a66253 j_mayer
    spr_register(env, SPR_IBAT1L, "IBAT1L",
1236 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1237 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1238 76a66253 j_mayer
                 0x00000000);
1239 76a66253 j_mayer
    spr_register(env, SPR_IBAT2U, "IBAT2U",
1240 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1241 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1242 76a66253 j_mayer
                 0x00000000);
1243 76a66253 j_mayer
    spr_register(env, SPR_IBAT2L, "IBAT2L",
1244 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1245 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1246 76a66253 j_mayer
                 0x00000000);
1247 76a66253 j_mayer
    spr_register(env, SPR_IBAT3U, "IBAT3U",
1248 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1249 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1250 76a66253 j_mayer
                 0x00000000);
1251 76a66253 j_mayer
    spr_register(env, SPR_IBAT3L, "IBAT3L",
1252 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1253 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1254 76a66253 j_mayer
                 0x00000000);
1255 a750fc0b j_mayer
    env->nb_BATs = 4;
1256 f2e63a42 j_mayer
#endif
1257 a750fc0b j_mayer
}
1258 a750fc0b j_mayer
1259 a750fc0b j_mayer
static void gen_spr_74xx (CPUPPCState *env)
1260 a750fc0b j_mayer
{
1261 a750fc0b j_mayer
    /* Processor identification */
1262 a750fc0b j_mayer
    spr_register(env, SPR_PIR, "PIR",
1263 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1264 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_pir,
1265 a750fc0b j_mayer
                 0x00000000);
1266 a750fc0b j_mayer
    /* XXX : not implemented */
1267 a750fc0b j_mayer
    spr_register(env, SPR_MMCR2, "MMCR2",
1268 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1269 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1270 a750fc0b j_mayer
                 0x00000000);
1271 578bb252 j_mayer
    /* XXX : not implemented */
1272 a750fc0b j_mayer
    spr_register(env, SPR_UMMCR2, "UMMCR2",
1273 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1274 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1275 a750fc0b j_mayer
                 0x00000000);
1276 a750fc0b j_mayer
    /* XXX: not implemented */
1277 a750fc0b j_mayer
    spr_register(env, SPR_BAMR, "BAMR",
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_MSSCR0, "MSSCR0",
1283 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1284 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1285 a750fc0b j_mayer
                 0x00000000);
1286 a750fc0b j_mayer
    /* Hardware implementation registers */
1287 a750fc0b j_mayer
    /* XXX : not implemented */
1288 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
1289 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1290 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1291 a750fc0b j_mayer
                 0x00000000);
1292 a750fc0b j_mayer
    /* XXX : not implemented */
1293 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
1294 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1295 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1296 a750fc0b j_mayer
                 0x00000000);
1297 a750fc0b j_mayer
    /* Altivec */
1298 a750fc0b j_mayer
    spr_register(env, SPR_VRSAVE, "VRSAVE",
1299 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1300 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1301 a750fc0b j_mayer
                 0x00000000);
1302 bd928eba j_mayer
    /* XXX : not implemented */
1303 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
1304 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1305 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
1306 bd928eba j_mayer
                 0x00000000);
1307 cf8358c8 aurel32
    /* Not strictly an SPR */
1308 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
1309 a750fc0b j_mayer
}
1310 a750fc0b j_mayer
1311 a750fc0b j_mayer
static void gen_l3_ctrl (CPUPPCState *env)
1312 a750fc0b j_mayer
{
1313 a750fc0b j_mayer
    /* L3CR */
1314 a750fc0b j_mayer
    /* XXX : not implemented */
1315 a750fc0b j_mayer
    spr_register(env, SPR_L3CR, "L3CR",
1316 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1317 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1318 a750fc0b j_mayer
                 0x00000000);
1319 a750fc0b j_mayer
    /* L3ITCR0 */
1320 578bb252 j_mayer
    /* XXX : not implemented */
1321 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR0, "L3ITCR0",
1322 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1323 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1324 a750fc0b j_mayer
                 0x00000000);
1325 a750fc0b j_mayer
    /* L3PM */
1326 578bb252 j_mayer
    /* XXX : not implemented */
1327 a750fc0b j_mayer
    spr_register(env, SPR_L3PM, "L3PM",
1328 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1329 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1330 a750fc0b j_mayer
                 0x00000000);
1331 a750fc0b j_mayer
}
1332 a750fc0b j_mayer
1333 578bb252 j_mayer
static void gen_74xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
1334 a750fc0b j_mayer
{
1335 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1336 578bb252 j_mayer
    env->nb_tlb = nb_tlbs;
1337 578bb252 j_mayer
    env->nb_ways = nb_ways;
1338 578bb252 j_mayer
    env->id_tlbs = 1;
1339 578bb252 j_mayer
    /* XXX : not implemented */
1340 a750fc0b j_mayer
    spr_register(env, SPR_PTEHI, "PTEHI",
1341 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1342 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1343 a750fc0b j_mayer
                 0x00000000);
1344 578bb252 j_mayer
    /* XXX : not implemented */
1345 a750fc0b j_mayer
    spr_register(env, SPR_PTELO, "PTELO",
1346 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1347 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1348 a750fc0b j_mayer
                 0x00000000);
1349 578bb252 j_mayer
    /* XXX : not implemented */
1350 a750fc0b j_mayer
    spr_register(env, SPR_TLBMISS, "TLBMISS",
1351 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1352 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1353 a750fc0b j_mayer
                 0x00000000);
1354 f2e63a42 j_mayer
#endif
1355 76a66253 j_mayer
}
1356 76a66253 j_mayer
1357 80d11f44 j_mayer
static void gen_spr_usprgh (CPUPPCState *env)
1358 76a66253 j_mayer
{
1359 80d11f44 j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
1360 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1361 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1362 80d11f44 j_mayer
                 0x00000000);
1363 80d11f44 j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
1364 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1365 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1366 80d11f44 j_mayer
                 0x00000000);
1367 80d11f44 j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
1368 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1369 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1370 80d11f44 j_mayer
                 0x00000000);
1371 80d11f44 j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
1372 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1373 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1374 76a66253 j_mayer
                 0x00000000);
1375 80d11f44 j_mayer
}
1376 80d11f44 j_mayer
1377 80d11f44 j_mayer
/* PowerPC BookE SPR */
1378 80d11f44 j_mayer
static void gen_spr_BookE (CPUPPCState *env, uint64_t ivor_mask)
1379 80d11f44 j_mayer
{
1380 b55266b5 blueswir1
    const char *ivor_names[64] = {
1381 80d11f44 j_mayer
        "IVOR0",  "IVOR1",  "IVOR2",  "IVOR3",
1382 80d11f44 j_mayer
        "IVOR4",  "IVOR5",  "IVOR6",  "IVOR7",
1383 80d11f44 j_mayer
        "IVOR8",  "IVOR9",  "IVOR10", "IVOR11",
1384 80d11f44 j_mayer
        "IVOR12", "IVOR13", "IVOR14", "IVOR15",
1385 80d11f44 j_mayer
        "IVOR16", "IVOR17", "IVOR18", "IVOR19",
1386 80d11f44 j_mayer
        "IVOR20", "IVOR21", "IVOR22", "IVOR23",
1387 80d11f44 j_mayer
        "IVOR24", "IVOR25", "IVOR26", "IVOR27",
1388 80d11f44 j_mayer
        "IVOR28", "IVOR29", "IVOR30", "IVOR31",
1389 80d11f44 j_mayer
        "IVOR32", "IVOR33", "IVOR34", "IVOR35",
1390 80d11f44 j_mayer
        "IVOR36", "IVOR37", "IVOR38", "IVOR39",
1391 80d11f44 j_mayer
        "IVOR40", "IVOR41", "IVOR42", "IVOR43",
1392 80d11f44 j_mayer
        "IVOR44", "IVOR45", "IVOR46", "IVOR47",
1393 80d11f44 j_mayer
        "IVOR48", "IVOR49", "IVOR50", "IVOR51",
1394 80d11f44 j_mayer
        "IVOR52", "IVOR53", "IVOR54", "IVOR55",
1395 80d11f44 j_mayer
        "IVOR56", "IVOR57", "IVOR58", "IVOR59",
1396 80d11f44 j_mayer
        "IVOR60", "IVOR61", "IVOR62", "IVOR63",
1397 80d11f44 j_mayer
    };
1398 80d11f44 j_mayer
#define SPR_BOOKE_IVORxx (-1)
1399 80d11f44 j_mayer
    int ivor_sprn[64] = {
1400 80d11f44 j_mayer
        SPR_BOOKE_IVOR0,  SPR_BOOKE_IVOR1,  SPR_BOOKE_IVOR2,  SPR_BOOKE_IVOR3,
1401 80d11f44 j_mayer
        SPR_BOOKE_IVOR4,  SPR_BOOKE_IVOR5,  SPR_BOOKE_IVOR6,  SPR_BOOKE_IVOR7,
1402 80d11f44 j_mayer
        SPR_BOOKE_IVOR8,  SPR_BOOKE_IVOR9,  SPR_BOOKE_IVOR10, SPR_BOOKE_IVOR11,
1403 80d11f44 j_mayer
        SPR_BOOKE_IVOR12, SPR_BOOKE_IVOR13, SPR_BOOKE_IVOR14, SPR_BOOKE_IVOR15,
1404 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1405 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1406 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1407 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1408 80d11f44 j_mayer
        SPR_BOOKE_IVOR32, SPR_BOOKE_IVOR33, SPR_BOOKE_IVOR34, SPR_BOOKE_IVOR35,
1409 80d11f44 j_mayer
        SPR_BOOKE_IVOR36, SPR_BOOKE_IVOR37, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1410 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1411 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1412 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1413 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1414 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1415 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1416 80d11f44 j_mayer
    };
1417 80d11f44 j_mayer
    int i;
1418 80d11f44 j_mayer
1419 76a66253 j_mayer
    /* Interrupt processing */
1420 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
1421 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1422 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1423 76a66253 j_mayer
                 0x00000000);
1424 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
1425 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1426 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1427 363be49c j_mayer
                 0x00000000);
1428 76a66253 j_mayer
    /* Debug */
1429 76a66253 j_mayer
    /* XXX : not implemented */
1430 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC1, "IAC1",
1431 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1432 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1433 76a66253 j_mayer
                 0x00000000);
1434 76a66253 j_mayer
    /* XXX : not implemented */
1435 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC2, "IAC2",
1436 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1437 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1438 76a66253 j_mayer
                 0x00000000);
1439 76a66253 j_mayer
    /* XXX : not implemented */
1440 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC1, "DAC1",
1441 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1442 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1443 76a66253 j_mayer
                 0x00000000);
1444 76a66253 j_mayer
    /* XXX : not implemented */
1445 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC2, "DAC2",
1446 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1447 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1448 76a66253 j_mayer
                 0x00000000);
1449 76a66253 j_mayer
    /* XXX : not implemented */
1450 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR0, "DBCR0",
1451 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1452 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1453 76a66253 j_mayer
                 0x00000000);
1454 76a66253 j_mayer
    /* XXX : not implemented */
1455 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR1, "DBCR1",
1456 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1457 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1458 76a66253 j_mayer
                 0x00000000);
1459 76a66253 j_mayer
    /* XXX : not implemented */
1460 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR2, "DBCR2",
1461 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1462 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1463 76a66253 j_mayer
                 0x00000000);
1464 76a66253 j_mayer
    /* XXX : not implemented */
1465 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBSR, "DBSR",
1466 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1467 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1468 76a66253 j_mayer
                 0x00000000);
1469 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DEAR, "DEAR",
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
    spr_register(env, SPR_BOOKE_ESR, "ESR",
1474 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1475 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1476 76a66253 j_mayer
                 0x00000000);
1477 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVPR, "IVPR",
1478 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1479 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1480 363be49c j_mayer
                 0x00000000);
1481 363be49c j_mayer
    /* Exception vectors */
1482 80d11f44 j_mayer
    for (i = 0; i < 64; i++) {
1483 80d11f44 j_mayer
        if (ivor_mask & (1ULL << i)) {
1484 80d11f44 j_mayer
            if (ivor_sprn[i] == SPR_BOOKE_IVORxx) {
1485 80d11f44 j_mayer
                fprintf(stderr, "ERROR: IVOR %d SPR is not defined\n", i);
1486 80d11f44 j_mayer
                exit(1);
1487 80d11f44 j_mayer
            }
1488 80d11f44 j_mayer
            spr_register(env, ivor_sprn[i], ivor_names[i],
1489 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
1490 80d11f44 j_mayer
                         &spr_read_generic, &spr_write_excp_vector,
1491 80d11f44 j_mayer
                         0x00000000);
1492 80d11f44 j_mayer
        }
1493 80d11f44 j_mayer
    }
1494 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_PID, "PID",
1495 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1496 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1497 76a66253 j_mayer
                 0x00000000);
1498 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TCR, "TCR",
1499 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1500 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1501 76a66253 j_mayer
                 0x00000000);
1502 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TSR, "TSR",
1503 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1504 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1505 76a66253 j_mayer
                 0x00000000);
1506 76a66253 j_mayer
    /* Timer */
1507 76a66253 j_mayer
    spr_register(env, SPR_DECR, "DECR",
1508 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1509 76a66253 j_mayer
                 &spr_read_decr, &spr_write_decr,
1510 76a66253 j_mayer
                 0x00000000);
1511 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DECAR, "DECAR",
1512 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1513 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_generic,
1514 76a66253 j_mayer
                 0x00000000);
1515 76a66253 j_mayer
    /* SPRGs */
1516 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1517 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1518 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1519 76a66253 j_mayer
                 0x00000000);
1520 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1521 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1522 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1523 76a66253 j_mayer
                 0x00000000);
1524 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1525 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1526 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1527 76a66253 j_mayer
                 0x00000000);
1528 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1529 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1530 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1531 76a66253 j_mayer
                 0x00000000);
1532 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1533 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1534 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1535 76a66253 j_mayer
                 0x00000000);
1536 76a66253 j_mayer
}
1537 76a66253 j_mayer
1538 363be49c j_mayer
/* FSL storage control registers */
1539 80d11f44 j_mayer
static void gen_spr_BookE_FSL (CPUPPCState *env, uint32_t mas_mask)
1540 363be49c j_mayer
{
1541 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1542 b55266b5 blueswir1
    const char *mas_names[8] = {
1543 80d11f44 j_mayer
        "MAS0", "MAS1", "MAS2", "MAS3", "MAS4", "MAS5", "MAS6", "MAS7",
1544 80d11f44 j_mayer
    };
1545 80d11f44 j_mayer
    int mas_sprn[8] = {
1546 80d11f44 j_mayer
        SPR_BOOKE_MAS0, SPR_BOOKE_MAS1, SPR_BOOKE_MAS2, SPR_BOOKE_MAS3,
1547 80d11f44 j_mayer
        SPR_BOOKE_MAS4, SPR_BOOKE_MAS5, SPR_BOOKE_MAS6, SPR_BOOKE_MAS7,
1548 80d11f44 j_mayer
    };
1549 80d11f44 j_mayer
    int i;
1550 80d11f44 j_mayer
1551 363be49c j_mayer
    /* TLB assist registers */
1552 578bb252 j_mayer
    /* XXX : not implemented */
1553 80d11f44 j_mayer
    for (i = 0; i < 8; i++) {
1554 80d11f44 j_mayer
        if (mas_mask & (1 << i)) {
1555 80d11f44 j_mayer
            spr_register(env, mas_sprn[i], mas_names[i],
1556 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
1557 80d11f44 j_mayer
                         &spr_read_generic, &spr_write_generic,
1558 80d11f44 j_mayer
                         0x00000000);
1559 80d11f44 j_mayer
        }
1560 80d11f44 j_mayer
    }
1561 363be49c j_mayer
    if (env->nb_pids > 1) {
1562 578bb252 j_mayer
        /* XXX : not implemented */
1563 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID1, "PID1",
1564 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1565 363be49c j_mayer
                     &spr_read_generic, &spr_write_generic,
1566 363be49c j_mayer
                     0x00000000);
1567 363be49c j_mayer
    }
1568 363be49c j_mayer
    if (env->nb_pids > 2) {
1569 578bb252 j_mayer
        /* XXX : not implemented */
1570 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID2, "PID2",
1571 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1572 363be49c j_mayer
                     &spr_read_generic, &spr_write_generic,
1573 363be49c j_mayer
                     0x00000000);
1574 363be49c j_mayer
    }
1575 578bb252 j_mayer
    /* XXX : not implemented */
1576 65f9ee8d j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
1577 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1578 363be49c j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1579 363be49c j_mayer
                 0x00000000); /* TOFIX */
1580 578bb252 j_mayer
    /* XXX : not implemented */
1581 65f9ee8d j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
1582 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1583 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1584 363be49c j_mayer
                 0x00000000); /* TOFIX */
1585 363be49c j_mayer
    switch (env->nb_ways) {
1586 363be49c j_mayer
    case 4:
1587 578bb252 j_mayer
        /* XXX : not implemented */
1588 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB3CFG, "TLB3CFG",
1589 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1590 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1591 363be49c j_mayer
                     0x00000000); /* TOFIX */
1592 363be49c j_mayer
        /* Fallthru */
1593 363be49c j_mayer
    case 3:
1594 578bb252 j_mayer
        /* XXX : not implemented */
1595 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB2CFG, "TLB2CFG",
1596 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1597 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1598 363be49c j_mayer
                     0x00000000); /* TOFIX */
1599 363be49c j_mayer
        /* Fallthru */
1600 363be49c j_mayer
    case 2:
1601 578bb252 j_mayer
        /* XXX : not implemented */
1602 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
1603 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1604 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1605 363be49c j_mayer
                     0x00000000); /* TOFIX */
1606 363be49c j_mayer
        /* Fallthru */
1607 363be49c j_mayer
    case 1:
1608 578bb252 j_mayer
        /* XXX : not implemented */
1609 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
1610 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1611 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1612 363be49c j_mayer
                     0x00000000); /* TOFIX */
1613 363be49c j_mayer
        /* Fallthru */
1614 363be49c j_mayer
    case 0:
1615 363be49c j_mayer
    default:
1616 363be49c j_mayer
        break;
1617 363be49c j_mayer
    }
1618 f2e63a42 j_mayer
#endif
1619 363be49c j_mayer
}
1620 363be49c j_mayer
1621 76a66253 j_mayer
/* SPR specific to PowerPC 440 implementation */
1622 76a66253 j_mayer
static void gen_spr_440 (CPUPPCState *env)
1623 76a66253 j_mayer
{
1624 76a66253 j_mayer
    /* Cache control */
1625 76a66253 j_mayer
    /* XXX : not implemented */
1626 76a66253 j_mayer
    spr_register(env, SPR_440_DNV0, "DNV0",
1627 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1628 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1629 76a66253 j_mayer
                 0x00000000);
1630 76a66253 j_mayer
    /* XXX : not implemented */
1631 76a66253 j_mayer
    spr_register(env, SPR_440_DNV1, "DNV1",
1632 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1633 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1634 76a66253 j_mayer
                 0x00000000);
1635 76a66253 j_mayer
    /* XXX : not implemented */
1636 76a66253 j_mayer
    spr_register(env, SPR_440_DNV2, "DNV2",
1637 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1638 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1639 76a66253 j_mayer
                 0x00000000);
1640 76a66253 j_mayer
    /* XXX : not implemented */
1641 76a66253 j_mayer
    spr_register(env, SPR_440_DNV3, "DNV3",
1642 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1643 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1644 76a66253 j_mayer
                 0x00000000);
1645 76a66253 j_mayer
    /* XXX : not implemented */
1646 2662a059 j_mayer
    spr_register(env, SPR_440_DTV0, "DTV0",
1647 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1648 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1649 76a66253 j_mayer
                 0x00000000);
1650 76a66253 j_mayer
    /* XXX : not implemented */
1651 2662a059 j_mayer
    spr_register(env, SPR_440_DTV1, "DTV1",
1652 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1653 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1654 76a66253 j_mayer
                 0x00000000);
1655 76a66253 j_mayer
    /* XXX : not implemented */
1656 2662a059 j_mayer
    spr_register(env, SPR_440_DTV2, "DTV2",
1657 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1658 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1659 76a66253 j_mayer
                 0x00000000);
1660 76a66253 j_mayer
    /* XXX : not implemented */
1661 2662a059 j_mayer
    spr_register(env, SPR_440_DTV3, "DTV3",
1662 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1663 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1664 76a66253 j_mayer
                 0x00000000);
1665 76a66253 j_mayer
    /* XXX : not implemented */
1666 76a66253 j_mayer
    spr_register(env, SPR_440_DVLIM, "DVLIM",
1667 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1668 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1669 76a66253 j_mayer
                 0x00000000);
1670 76a66253 j_mayer
    /* XXX : not implemented */
1671 76a66253 j_mayer
    spr_register(env, SPR_440_INV0, "INV0",
1672 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1673 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1674 76a66253 j_mayer
                 0x00000000);
1675 76a66253 j_mayer
    /* XXX : not implemented */
1676 76a66253 j_mayer
    spr_register(env, SPR_440_INV1, "INV1",
1677 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1678 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1679 76a66253 j_mayer
                 0x00000000);
1680 76a66253 j_mayer
    /* XXX : not implemented */
1681 76a66253 j_mayer
    spr_register(env, SPR_440_INV2, "INV2",
1682 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1683 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1684 76a66253 j_mayer
                 0x00000000);
1685 76a66253 j_mayer
    /* XXX : not implemented */
1686 76a66253 j_mayer
    spr_register(env, SPR_440_INV3, "INV3",
1687 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1688 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1689 76a66253 j_mayer
                 0x00000000);
1690 76a66253 j_mayer
    /* XXX : not implemented */
1691 2662a059 j_mayer
    spr_register(env, SPR_440_ITV0, "ITV0",
1692 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1693 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1694 76a66253 j_mayer
                 0x00000000);
1695 76a66253 j_mayer
    /* XXX : not implemented */
1696 2662a059 j_mayer
    spr_register(env, SPR_440_ITV1, "ITV1",
1697 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1698 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1699 76a66253 j_mayer
                 0x00000000);
1700 76a66253 j_mayer
    /* XXX : not implemented */
1701 2662a059 j_mayer
    spr_register(env, SPR_440_ITV2, "ITV2",
1702 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1703 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1704 76a66253 j_mayer
                 0x00000000);
1705 76a66253 j_mayer
    /* XXX : not implemented */
1706 2662a059 j_mayer
    spr_register(env, SPR_440_ITV3, "ITV3",
1707 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1708 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1709 76a66253 j_mayer
                 0x00000000);
1710 76a66253 j_mayer
    /* XXX : not implemented */
1711 76a66253 j_mayer
    spr_register(env, SPR_440_IVLIM, "IVLIM",
1712 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1713 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1714 76a66253 j_mayer
                 0x00000000);
1715 76a66253 j_mayer
    /* Cache debug */
1716 76a66253 j_mayer
    /* XXX : not implemented */
1717 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRH, "DCDBTRH",
1718 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1719 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1720 76a66253 j_mayer
                 0x00000000);
1721 76a66253 j_mayer
    /* XXX : not implemented */
1722 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRL, "DCDBTRL",
1723 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1724 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1725 76a66253 j_mayer
                 0x00000000);
1726 76a66253 j_mayer
    /* XXX : not implemented */
1727 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1728 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1729 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1730 76a66253 j_mayer
                 0x00000000);
1731 76a66253 j_mayer
    /* XXX : not implemented */
1732 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRH, "ICDBTRH",
1733 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1734 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1735 76a66253 j_mayer
                 0x00000000);
1736 76a66253 j_mayer
    /* XXX : not implemented */
1737 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRL, "ICDBTRL",
1738 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1739 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1740 76a66253 j_mayer
                 0x00000000);
1741 76a66253 j_mayer
    /* XXX : not implemented */
1742 76a66253 j_mayer
    spr_register(env, SPR_440_DBDR, "DBDR",
1743 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1744 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1745 76a66253 j_mayer
                 0x00000000);
1746 76a66253 j_mayer
    /* Processor control */
1747 76a66253 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1748 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1749 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1750 76a66253 j_mayer
                 0x00000000);
1751 76a66253 j_mayer
    spr_register(env, SPR_440_RSTCFG, "RSTCFG",
1752 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1753 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1754 76a66253 j_mayer
                 0x00000000);
1755 76a66253 j_mayer
    /* Storage control */
1756 76a66253 j_mayer
    spr_register(env, SPR_440_MMUCR, "MMUCR",
1757 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1758 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1759 76a66253 j_mayer
                 0x00000000);
1760 76a66253 j_mayer
}
1761 76a66253 j_mayer
1762 76a66253 j_mayer
/* SPR shared between PowerPC 40x implementations */
1763 76a66253 j_mayer
static void gen_spr_40x (CPUPPCState *env)
1764 76a66253 j_mayer
{
1765 76a66253 j_mayer
    /* Cache */
1766 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1767 76a66253 j_mayer
    spr_register(env, SPR_40x_DCCR, "DCCR",
1768 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1769 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1770 76a66253 j_mayer
                 0x00000000);
1771 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1772 76a66253 j_mayer
    spr_register(env, SPR_40x_ICCR, "ICCR",
1773 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1774 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1775 76a66253 j_mayer
                 0x00000000);
1776 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1777 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1778 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1779 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1780 76a66253 j_mayer
                 0x00000000);
1781 76a66253 j_mayer
    /* Exception */
1782 76a66253 j_mayer
    spr_register(env, SPR_40x_DEAR, "DEAR",
1783 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1784 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1785 76a66253 j_mayer
                 0x00000000);
1786 76a66253 j_mayer
    spr_register(env, SPR_40x_ESR, "ESR",
1787 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1788 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1789 76a66253 j_mayer
                 0x00000000);
1790 76a66253 j_mayer
    spr_register(env, SPR_40x_EVPR, "EVPR",
1791 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1792 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1793 76a66253 j_mayer
                 0x00000000);
1794 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR2, "SRR2",
1795 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1796 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1797 76a66253 j_mayer
                 0x00000000);
1798 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR3, "SRR3",
1799 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1800 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1801 76a66253 j_mayer
                 0x00000000);
1802 76a66253 j_mayer
    /* Timers */
1803 76a66253 j_mayer
    spr_register(env, SPR_40x_PIT, "PIT",
1804 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1805 76a66253 j_mayer
                 &spr_read_40x_pit, &spr_write_40x_pit,
1806 76a66253 j_mayer
                 0x00000000);
1807 76a66253 j_mayer
    spr_register(env, SPR_40x_TCR, "TCR",
1808 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1809 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1810 76a66253 j_mayer
                 0x00000000);
1811 76a66253 j_mayer
    spr_register(env, SPR_40x_TSR, "TSR",
1812 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1813 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1814 76a66253 j_mayer
                 0x00000000);
1815 2662a059 j_mayer
}
1816 2662a059 j_mayer
1817 2662a059 j_mayer
/* SPR specific to PowerPC 405 implementation */
1818 2662a059 j_mayer
static void gen_spr_405 (CPUPPCState *env)
1819 2662a059 j_mayer
{
1820 2662a059 j_mayer
    /* MMU */
1821 2662a059 j_mayer
    spr_register(env, SPR_40x_PID, "PID",
1822 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1823 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1824 76a66253 j_mayer
                 0x00000000);
1825 2662a059 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1826 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1827 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1828 2662a059 j_mayer
                 0x00700000);
1829 2662a059 j_mayer
    /* Debug interface */
1830 76a66253 j_mayer
    /* XXX : not implemented */
1831 76a66253 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1832 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1833 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1834 76a66253 j_mayer
                 0x00000000);
1835 76a66253 j_mayer
    /* XXX : not implemented */
1836 2662a059 j_mayer
    spr_register(env, SPR_405_DBCR1, "DBCR1",
1837 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1838 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1839 2662a059 j_mayer
                 0x00000000);
1840 2662a059 j_mayer
    /* XXX : not implemented */
1841 76a66253 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1842 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1843 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1844 8ecc7913 j_mayer
                 /* Last reset was system reset */
1845 76a66253 j_mayer
                 0x00000300);
1846 76a66253 j_mayer
    /* XXX : not implemented */
1847 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
1848 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1849 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1850 76a66253 j_mayer
                 0x00000000);
1851 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
1852 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1853 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1854 76a66253 j_mayer
                 0x00000000);
1855 2662a059 j_mayer
    /* XXX : not implemented */
1856 2662a059 j_mayer
    spr_register(env, SPR_405_DVC1, "DVC1",
1857 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1858 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1859 2662a059 j_mayer
                 0x00000000);
1860 76a66253 j_mayer
    /* XXX : not implemented */
1861 2662a059 j_mayer
    spr_register(env, SPR_405_DVC2, "DVC2",
1862 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1863 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1864 76a66253 j_mayer
                 0x00000000);
1865 76a66253 j_mayer
    /* XXX : not implemented */
1866 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
1867 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1868 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1869 76a66253 j_mayer
                 0x00000000);
1870 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
1871 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1872 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1873 76a66253 j_mayer
                 0x00000000);
1874 76a66253 j_mayer
    /* XXX : not implemented */
1875 76a66253 j_mayer
    spr_register(env, SPR_405_IAC3, "IAC3",
1876 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1877 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1878 76a66253 j_mayer
                 0x00000000);
1879 76a66253 j_mayer
    /* XXX : not implemented */
1880 76a66253 j_mayer
    spr_register(env, SPR_405_IAC4, "IAC4",
1881 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1882 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1883 76a66253 j_mayer
                 0x00000000);
1884 76a66253 j_mayer
    /* Storage control */
1885 035feb88 j_mayer
    /* XXX: TODO: not implemented */
1886 76a66253 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
1887 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1888 c294fc58 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
1889 76a66253 j_mayer
                 0x00000000);
1890 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
1891 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1892 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1893 2662a059 j_mayer
                 0x00000000);
1894 76a66253 j_mayer
    /* XXX : not implemented */
1895 76a66253 j_mayer
    spr_register(env, SPR_405_SU0R, "SU0R",
1896 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1897 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1898 76a66253 j_mayer
                 0x00000000);
1899 76a66253 j_mayer
    /* SPRG */
1900 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1901 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1902 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1903 76a66253 j_mayer
                 0x00000000);
1904 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1905 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1906 04f20795 j_mayer
                 &spr_read_generic, &spr_write_generic,
1907 76a66253 j_mayer
                 0x00000000);
1908 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1909 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1910 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1911 76a66253 j_mayer
                 0x00000000);
1912 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1913 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1914 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1915 76a66253 j_mayer
                 0x00000000);
1916 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1917 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1918 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1919 76a66253 j_mayer
                 0x00000000);
1920 80d11f44 j_mayer
    gen_spr_usprgh(env);
1921 76a66253 j_mayer
}
1922 76a66253 j_mayer
1923 76a66253 j_mayer
/* SPR shared between PowerPC 401 & 403 implementations */
1924 76a66253 j_mayer
static void gen_spr_401_403 (CPUPPCState *env)
1925 76a66253 j_mayer
{
1926 76a66253 j_mayer
    /* Time base */
1927 76a66253 j_mayer
    spr_register(env, SPR_403_VTBL,  "TBL",
1928 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1929 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1930 76a66253 j_mayer
                 0x00000000);
1931 76a66253 j_mayer
    spr_register(env, SPR_403_TBL,   "TBL",
1932 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1933 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbl,
1934 76a66253 j_mayer
                 0x00000000);
1935 76a66253 j_mayer
    spr_register(env, SPR_403_VTBU,  "TBU",
1936 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1937 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1938 76a66253 j_mayer
                 0x00000000);
1939 76a66253 j_mayer
    spr_register(env, SPR_403_TBU,   "TBU",
1940 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1941 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbu,
1942 76a66253 j_mayer
                 0x00000000);
1943 76a66253 j_mayer
    /* Debug */
1944 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1945 76a66253 j_mayer
    spr_register(env, SPR_403_CDBCR, "CDBCR",
1946 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1947 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1948 76a66253 j_mayer
                 0x00000000);
1949 76a66253 j_mayer
}
1950 76a66253 j_mayer
1951 2662a059 j_mayer
/* SPR specific to PowerPC 401 implementation */
1952 2662a059 j_mayer
static void gen_spr_401 (CPUPPCState *env)
1953 2662a059 j_mayer
{
1954 2662a059 j_mayer
    /* Debug interface */
1955 2662a059 j_mayer
    /* XXX : not implemented */
1956 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR",
1957 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1958 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1959 2662a059 j_mayer
                 0x00000000);
1960 2662a059 j_mayer
    /* XXX : not implemented */
1961 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1962 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1963 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
1964 2662a059 j_mayer
                 /* Last reset was system reset */
1965 2662a059 j_mayer
                 0x00000300);
1966 2662a059 j_mayer
    /* XXX : not implemented */
1967 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC",
1968 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1969 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1970 2662a059 j_mayer
                 0x00000000);
1971 2662a059 j_mayer
    /* XXX : not implemented */
1972 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC",
1973 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1974 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1975 2662a059 j_mayer
                 0x00000000);
1976 2662a059 j_mayer
    /* Storage control */
1977 035feb88 j_mayer
    /* XXX: TODO: not implemented */
1978 2662a059 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
1979 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1980 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
1981 2662a059 j_mayer
                 0x00000000);
1982 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
1983 035feb88 j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
1984 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1985 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
1986 035feb88 j_mayer
                 0xFFFFFFFF);
1987 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1988 035feb88 j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
1989 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1990 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
1991 035feb88 j_mayer
                 0x00000000);
1992 2662a059 j_mayer
}
1993 2662a059 j_mayer
1994 a750fc0b j_mayer
static void gen_spr_401x2 (CPUPPCState *env)
1995 a750fc0b j_mayer
{
1996 a750fc0b j_mayer
    gen_spr_401(env);
1997 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
1998 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1999 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2000 a750fc0b j_mayer
                 0x00000000);
2001 a750fc0b j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
2002 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2003 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2004 a750fc0b j_mayer
                 0x00000000);
2005 a750fc0b j_mayer
}
2006 a750fc0b j_mayer
2007 76a66253 j_mayer
/* SPR specific to PowerPC 403 implementation */
2008 76a66253 j_mayer
static void gen_spr_403 (CPUPPCState *env)
2009 76a66253 j_mayer
{
2010 2662a059 j_mayer
    /* Debug interface */
2011 2662a059 j_mayer
    /* XXX : not implemented */
2012 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
2013 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2014 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
2015 2662a059 j_mayer
                 0x00000000);
2016 2662a059 j_mayer
    /* XXX : not implemented */
2017 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
2018 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2019 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
2020 2662a059 j_mayer
                 /* Last reset was system reset */
2021 2662a059 j_mayer
                 0x00000300);
2022 2662a059 j_mayer
    /* XXX : not implemented */
2023 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
2024 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2025 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2026 2662a059 j_mayer
                 0x00000000);
2027 578bb252 j_mayer
    /* XXX : not implemented */
2028 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
2029 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2030 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2031 2662a059 j_mayer
                 0x00000000);
2032 2662a059 j_mayer
    /* XXX : not implemented */
2033 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
2034 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2035 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2036 2662a059 j_mayer
                 0x00000000);
2037 578bb252 j_mayer
    /* XXX : not implemented */
2038 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
2039 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2040 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2041 2662a059 j_mayer
                 0x00000000);
2042 a750fc0b j_mayer
}
2043 a750fc0b j_mayer
2044 a750fc0b j_mayer
static void gen_spr_403_real (CPUPPCState *env)
2045 a750fc0b j_mayer
{
2046 76a66253 j_mayer
    spr_register(env, SPR_403_PBL1,  "PBL1",
2047 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2048 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2049 76a66253 j_mayer
                 0x00000000);
2050 76a66253 j_mayer
    spr_register(env, SPR_403_PBU1,  "PBU1",
2051 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2052 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2053 76a66253 j_mayer
                 0x00000000);
2054 76a66253 j_mayer
    spr_register(env, SPR_403_PBL2,  "PBL2",
2055 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2056 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2057 76a66253 j_mayer
                 0x00000000);
2058 76a66253 j_mayer
    spr_register(env, SPR_403_PBU2,  "PBU2",
2059 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2060 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2061 76a66253 j_mayer
                 0x00000000);
2062 a750fc0b j_mayer
}
2063 a750fc0b j_mayer
2064 a750fc0b j_mayer
static void gen_spr_403_mmu (CPUPPCState *env)
2065 a750fc0b j_mayer
{
2066 a750fc0b j_mayer
    /* MMU */
2067 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
2068 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2069 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2070 a750fc0b j_mayer
                 0x00000000);
2071 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
2072 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2073 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
2074 76a66253 j_mayer
                 0x00000000);
2075 76a66253 j_mayer
}
2076 76a66253 j_mayer
2077 76a66253 j_mayer
/* SPR specific to PowerPC compression coprocessor extension */
2078 76a66253 j_mayer
static void gen_spr_compress (CPUPPCState *env)
2079 76a66253 j_mayer
{
2080 578bb252 j_mayer
    /* XXX : not implemented */
2081 76a66253 j_mayer
    spr_register(env, SPR_401_SKR, "SKR",
2082 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2083 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
2084 76a66253 j_mayer
                 0x00000000);
2085 76a66253 j_mayer
}
2086 a750fc0b j_mayer
2087 a750fc0b j_mayer
#if defined (TARGET_PPC64)
2088 a750fc0b j_mayer
/* SPR specific to PowerPC 620 */
2089 a750fc0b j_mayer
static void gen_spr_620 (CPUPPCState *env)
2090 a750fc0b j_mayer
{
2091 082c6681 j_mayer
    /* Processor identification */
2092 082c6681 j_mayer
    spr_register(env, SPR_PIR, "PIR",
2093 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2094 082c6681 j_mayer
                 &spr_read_generic, &spr_write_pir,
2095 082c6681 j_mayer
                 0x00000000);
2096 082c6681 j_mayer
    spr_register(env, SPR_ASR, "ASR",
2097 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2098 082c6681 j_mayer
                 &spr_read_asr, &spr_write_asr,
2099 082c6681 j_mayer
                 0x00000000);
2100 082c6681 j_mayer
    /* Breakpoints */
2101 082c6681 j_mayer
    /* XXX : not implemented */
2102 082c6681 j_mayer
    spr_register(env, SPR_IABR, "IABR",
2103 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2104 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2105 082c6681 j_mayer
                 0x00000000);
2106 082c6681 j_mayer
    /* XXX : not implemented */
2107 082c6681 j_mayer
    spr_register(env, SPR_DABR, "DABR",
2108 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2109 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2110 082c6681 j_mayer
                 0x00000000);
2111 082c6681 j_mayer
    /* XXX : not implemented */
2112 082c6681 j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
2113 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2114 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2115 082c6681 j_mayer
                 0x00000000);
2116 082c6681 j_mayer
    /* XXX : not implemented */
2117 082c6681 j_mayer
    spr_register(env, SPR_SDA, "SDA",
2118 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2119 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2120 082c6681 j_mayer
                 0x00000000);
2121 082c6681 j_mayer
    /* XXX : not implemented */
2122 082c6681 j_mayer
    spr_register(env, SPR_620_PMC1R, "PMC1",
2123 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2124 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2125 082c6681 j_mayer
                 0x00000000);
2126 082c6681 j_mayer
    spr_register(env, SPR_620_PMC1W, "PMC1",
2127 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2128 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2129 082c6681 j_mayer
                 0x00000000);
2130 082c6681 j_mayer
    /* XXX : not implemented */
2131 082c6681 j_mayer
    spr_register(env, SPR_620_PMC2R, "PMC2",
2132 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2133 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2134 082c6681 j_mayer
                 0x00000000);
2135 082c6681 j_mayer
    spr_register(env, SPR_620_PMC2W, "PMC2",
2136 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2137 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2138 082c6681 j_mayer
                 0x00000000);
2139 082c6681 j_mayer
    /* XXX : not implemented */
2140 082c6681 j_mayer
    spr_register(env, SPR_620_MMCR0R, "MMCR0",
2141 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2142 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2143 082c6681 j_mayer
                 0x00000000);
2144 082c6681 j_mayer
    spr_register(env, SPR_620_MMCR0W, "MMCR0",
2145 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2146 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2147 082c6681 j_mayer
                 0x00000000);
2148 082c6681 j_mayer
    /* External access control */
2149 082c6681 j_mayer
    /* XXX : not implemented */
2150 082c6681 j_mayer
    spr_register(env, SPR_EAR, "EAR",
2151 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2152 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2153 082c6681 j_mayer
                 0x00000000);
2154 082c6681 j_mayer
#if 0 // XXX: check this
2155 578bb252 j_mayer
    /* XXX : not implemented */
2156 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR0, "PMR0",
2157 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2158 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2159 a750fc0b j_mayer
                 0x00000000);
2160 578bb252 j_mayer
    /* XXX : not implemented */
2161 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR1, "PMR1",
2162 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2163 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2164 a750fc0b j_mayer
                 0x00000000);
2165 578bb252 j_mayer
    /* XXX : not implemented */
2166 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR2, "PMR2",
2167 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2168 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2169 a750fc0b j_mayer
                 0x00000000);
2170 578bb252 j_mayer
    /* XXX : not implemented */
2171 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR3, "PMR3",
2172 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2173 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2174 a750fc0b j_mayer
                 0x00000000);
2175 578bb252 j_mayer
    /* XXX : not implemented */
2176 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR4, "PMR4",
2177 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2178 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2179 a750fc0b j_mayer
                 0x00000000);
2180 578bb252 j_mayer
    /* XXX : not implemented */
2181 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR5, "PMR5",
2182 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2183 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2184 a750fc0b j_mayer
                 0x00000000);
2185 578bb252 j_mayer
    /* XXX : not implemented */
2186 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR6, "PMR6",
2187 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2188 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2189 a750fc0b j_mayer
                 0x00000000);
2190 578bb252 j_mayer
    /* XXX : not implemented */
2191 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR7, "PMR7",
2192 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2193 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2194 a750fc0b j_mayer
                 0x00000000);
2195 578bb252 j_mayer
    /* XXX : not implemented */
2196 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR8, "PMR8",
2197 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2198 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2199 a750fc0b j_mayer
                 0x00000000);
2200 578bb252 j_mayer
    /* XXX : not implemented */
2201 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR9, "PMR9",
2202 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2203 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2204 a750fc0b j_mayer
                 0x00000000);
2205 578bb252 j_mayer
    /* XXX : not implemented */
2206 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRA, "PMR10",
2207 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2208 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2209 a750fc0b j_mayer
                 0x00000000);
2210 578bb252 j_mayer
    /* XXX : not implemented */
2211 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRB, "PMR11",
2212 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2213 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2214 a750fc0b j_mayer
                 0x00000000);
2215 578bb252 j_mayer
    /* XXX : not implemented */
2216 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRC, "PMR12",
2217 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2218 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2219 a750fc0b j_mayer
                 0x00000000);
2220 578bb252 j_mayer
    /* XXX : not implemented */
2221 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRD, "PMR13",
2222 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2223 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2224 a750fc0b j_mayer
                 0x00000000);
2225 578bb252 j_mayer
    /* XXX : not implemented */
2226 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRE, "PMR14",
2227 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2228 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2229 a750fc0b j_mayer
                 0x00000000);
2230 578bb252 j_mayer
    /* XXX : not implemented */
2231 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRF, "PMR15",
2232 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2233 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2234 a750fc0b j_mayer
                 0x00000000);
2235 082c6681 j_mayer
#endif
2236 578bb252 j_mayer
    /* XXX : not implemented */
2237 082c6681 j_mayer
    spr_register(env, SPR_620_BUSCSR, "BUSCSR",
2238 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2239 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2240 a750fc0b j_mayer
                 0x00000000);
2241 578bb252 j_mayer
    /* XXX : not implemented */
2242 082c6681 j_mayer
    spr_register(env, SPR_620_L2CR, "L2CR",
2243 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2244 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2245 082c6681 j_mayer
                 0x00000000);
2246 082c6681 j_mayer
    /* XXX : not implemented */
2247 082c6681 j_mayer
    spr_register(env, SPR_620_L2SR, "L2SR",
2248 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2249 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2250 a750fc0b j_mayer
                 0x00000000);
2251 a750fc0b j_mayer
}
2252 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
2253 76a66253 j_mayer
2254 80d11f44 j_mayer
static void gen_spr_5xx_8xx (CPUPPCState *env)
2255 e1833e1f j_mayer
{
2256 80d11f44 j_mayer
    /* Exception processing */
2257 80d11f44 j_mayer
    spr_register(env, SPR_DSISR, "DSISR",
2258 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2259 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2260 80d11f44 j_mayer
                 0x00000000);
2261 80d11f44 j_mayer
    spr_register(env, SPR_DAR, "DAR",
2262 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2263 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2264 80d11f44 j_mayer
                 0x00000000);
2265 80d11f44 j_mayer
    /* Timer */
2266 80d11f44 j_mayer
    spr_register(env, SPR_DECR, "DECR",
2267 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2268 80d11f44 j_mayer
                 &spr_read_decr, &spr_write_decr,
2269 80d11f44 j_mayer
                 0x00000000);
2270 80d11f44 j_mayer
    /* XXX : not implemented */
2271 80d11f44 j_mayer
    spr_register(env, SPR_MPC_EIE, "EIE",
2272 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2273 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2274 80d11f44 j_mayer
                 0x00000000);
2275 80d11f44 j_mayer
    /* XXX : not implemented */
2276 80d11f44 j_mayer
    spr_register(env, SPR_MPC_EID, "EID",
2277 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2278 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2279 80d11f44 j_mayer
                 0x00000000);
2280 80d11f44 j_mayer
    /* XXX : not implemented */
2281 80d11f44 j_mayer
    spr_register(env, SPR_MPC_NRI, "NRI",
2282 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2283 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2284 80d11f44 j_mayer
                 0x00000000);
2285 80d11f44 j_mayer
    /* XXX : not implemented */
2286 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPA, "CMPA",
2287 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2288 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2289 80d11f44 j_mayer
                 0x00000000);
2290 80d11f44 j_mayer
    /* XXX : not implemented */
2291 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPB, "CMPB",
2292 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2293 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2294 80d11f44 j_mayer
                 0x00000000);
2295 80d11f44 j_mayer
    /* XXX : not implemented */
2296 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPC, "CMPC",
2297 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2298 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2299 80d11f44 j_mayer
                 0x00000000);
2300 80d11f44 j_mayer
    /* XXX : not implemented */
2301 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPD, "CMPD",
2302 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2303 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2304 80d11f44 j_mayer
                 0x00000000);
2305 80d11f44 j_mayer
    /* XXX : not implemented */
2306 80d11f44 j_mayer
    spr_register(env, SPR_MPC_ECR, "ECR",
2307 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2308 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2309 80d11f44 j_mayer
                 0x00000000);
2310 80d11f44 j_mayer
    /* XXX : not implemented */
2311 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DER, "DER",
2312 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2313 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2314 80d11f44 j_mayer
                 0x00000000);
2315 80d11f44 j_mayer
    /* XXX : not implemented */
2316 80d11f44 j_mayer
    spr_register(env, SPR_MPC_COUNTA, "COUNTA",
2317 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2318 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2319 80d11f44 j_mayer
                 0x00000000);
2320 80d11f44 j_mayer
    /* XXX : not implemented */
2321 80d11f44 j_mayer
    spr_register(env, SPR_MPC_COUNTB, "COUNTB",
2322 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2323 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2324 80d11f44 j_mayer
                 0x00000000);
2325 80d11f44 j_mayer
    /* XXX : not implemented */
2326 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPE, "CMPE",
2327 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2328 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2329 80d11f44 j_mayer
                 0x00000000);
2330 80d11f44 j_mayer
    /* XXX : not implemented */
2331 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPF, "CMPF",
2332 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2333 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2334 80d11f44 j_mayer
                 0x00000000);
2335 80d11f44 j_mayer
    /* XXX : not implemented */
2336 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPG, "CMPG",
2337 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2338 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2339 80d11f44 j_mayer
                 0x00000000);
2340 80d11f44 j_mayer
    /* XXX : not implemented */
2341 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPH, "CMPH",
2342 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2343 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2344 80d11f44 j_mayer
                 0x00000000);
2345 80d11f44 j_mayer
    /* XXX : not implemented */
2346 80d11f44 j_mayer
    spr_register(env, SPR_MPC_LCTRL1, "LCTRL1",
2347 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2348 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2349 80d11f44 j_mayer
                 0x00000000);
2350 80d11f44 j_mayer
    /* XXX : not implemented */
2351 80d11f44 j_mayer
    spr_register(env, SPR_MPC_LCTRL2, "LCTRL2",
2352 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2353 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2354 80d11f44 j_mayer
                 0x00000000);
2355 80d11f44 j_mayer
    /* XXX : not implemented */
2356 80d11f44 j_mayer
    spr_register(env, SPR_MPC_BAR, "BAR",
2357 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2358 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2359 80d11f44 j_mayer
                 0x00000000);
2360 80d11f44 j_mayer
    /* XXX : not implemented */
2361 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DPDR, "DPDR",
2362 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2363 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2364 80d11f44 j_mayer
                 0x00000000);
2365 80d11f44 j_mayer
    /* XXX : not implemented */
2366 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IMMR, "IMMR",
2367 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2368 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2369 80d11f44 j_mayer
                 0x00000000);
2370 80d11f44 j_mayer
}
2371 80d11f44 j_mayer
2372 80d11f44 j_mayer
static void gen_spr_5xx (CPUPPCState *env)
2373 80d11f44 j_mayer
{
2374 80d11f44 j_mayer
    /* XXX : not implemented */
2375 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_GRA, "MI_GRA",
2376 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2377 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2378 80d11f44 j_mayer
                 0x00000000);
2379 80d11f44 j_mayer
    /* XXX : not implemented */
2380 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_GRA, "L2U_GRA",
2381 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2382 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2383 80d11f44 j_mayer
                 0x00000000);
2384 80d11f44 j_mayer
    /* XXX : not implemented */
2385 80d11f44 j_mayer
    spr_register(env, SPR_RPCU_BBCMCR, "L2U_BBCMCR",
2386 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2387 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2388 80d11f44 j_mayer
                 0x00000000);
2389 80d11f44 j_mayer
    /* XXX : not implemented */
2390 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_MCR, "L2U_MCR",
2391 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2392 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2393 80d11f44 j_mayer
                 0x00000000);
2394 80d11f44 j_mayer
    /* XXX : not implemented */
2395 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA0, "MI_RBA0",
2396 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2397 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2398 80d11f44 j_mayer
                 0x00000000);
2399 80d11f44 j_mayer
    /* XXX : not implemented */
2400 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA1, "MI_RBA1",
2401 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2402 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2403 80d11f44 j_mayer
                 0x00000000);
2404 80d11f44 j_mayer
    /* XXX : not implemented */
2405 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA2, "MI_RBA2",
2406 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2407 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2408 80d11f44 j_mayer
                 0x00000000);
2409 80d11f44 j_mayer
    /* XXX : not implemented */
2410 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA3, "MI_RBA3",
2411 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2412 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2413 80d11f44 j_mayer
                 0x00000000);
2414 80d11f44 j_mayer
    /* XXX : not implemented */
2415 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA0, "L2U_RBA0",
2416 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2417 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2418 80d11f44 j_mayer
                 0x00000000);
2419 80d11f44 j_mayer
    /* XXX : not implemented */
2420 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA1, "L2U_RBA1",
2421 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2422 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2423 80d11f44 j_mayer
                 0x00000000);
2424 80d11f44 j_mayer
    /* XXX : not implemented */
2425 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA2, "L2U_RBA2",
2426 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2427 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2428 80d11f44 j_mayer
                 0x00000000);
2429 80d11f44 j_mayer
    /* XXX : not implemented */
2430 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA3, "L2U_RBA3",
2431 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2432 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2433 80d11f44 j_mayer
                 0x00000000);
2434 80d11f44 j_mayer
    /* XXX : not implemented */
2435 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA0, "MI_RA0",
2436 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2437 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2438 80d11f44 j_mayer
                 0x00000000);
2439 80d11f44 j_mayer
    /* XXX : not implemented */
2440 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA1, "MI_RA1",
2441 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2442 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2443 80d11f44 j_mayer
                 0x00000000);
2444 80d11f44 j_mayer
    /* XXX : not implemented */
2445 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA2, "MI_RA2",
2446 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2447 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2448 80d11f44 j_mayer
                 0x00000000);
2449 80d11f44 j_mayer
    /* XXX : not implemented */
2450 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA3, "MI_RA3",
2451 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2452 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2453 80d11f44 j_mayer
                 0x00000000);
2454 80d11f44 j_mayer
    /* XXX : not implemented */
2455 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA0, "L2U_RA0",
2456 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2457 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2458 80d11f44 j_mayer
                 0x00000000);
2459 80d11f44 j_mayer
    /* XXX : not implemented */
2460 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA1, "L2U_RA1",
2461 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2462 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2463 80d11f44 j_mayer
                 0x00000000);
2464 80d11f44 j_mayer
    /* XXX : not implemented */
2465 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA2, "L2U_RA2",
2466 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2467 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2468 80d11f44 j_mayer
                 0x00000000);
2469 80d11f44 j_mayer
    /* XXX : not implemented */
2470 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA3, "L2U_RA3",
2471 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2472 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2473 80d11f44 j_mayer
                 0x00000000);
2474 80d11f44 j_mayer
    /* XXX : not implemented */
2475 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_FPECR, "FPECR",
2476 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2477 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2478 80d11f44 j_mayer
                 0x00000000);
2479 80d11f44 j_mayer
}
2480 80d11f44 j_mayer
2481 80d11f44 j_mayer
static void gen_spr_8xx (CPUPPCState *env)
2482 80d11f44 j_mayer
{
2483 80d11f44 j_mayer
    /* XXX : not implemented */
2484 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_CST, "IC_CST",
2485 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2486 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2487 80d11f44 j_mayer
                 0x00000000);
2488 80d11f44 j_mayer
    /* XXX : not implemented */
2489 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_ADR, "IC_ADR",
2490 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2491 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2492 80d11f44 j_mayer
                 0x00000000);
2493 80d11f44 j_mayer
    /* XXX : not implemented */
2494 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_DAT, "IC_DAT",
2495 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2496 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2497 80d11f44 j_mayer
                 0x00000000);
2498 80d11f44 j_mayer
    /* XXX : not implemented */
2499 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_CST, "DC_CST",
2500 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2501 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2502 80d11f44 j_mayer
                 0x00000000);
2503 80d11f44 j_mayer
    /* XXX : not implemented */
2504 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_ADR, "DC_ADR",
2505 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2506 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2507 80d11f44 j_mayer
                 0x00000000);
2508 80d11f44 j_mayer
    /* XXX : not implemented */
2509 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_DAT, "DC_DAT",
2510 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2511 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2512 80d11f44 j_mayer
                 0x00000000);
2513 80d11f44 j_mayer
    /* XXX : not implemented */
2514 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_CTR, "MI_CTR",
2515 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2516 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2517 80d11f44 j_mayer
                 0x00000000);
2518 80d11f44 j_mayer
    /* XXX : not implemented */
2519 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_AP, "MI_AP",
2520 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2521 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2522 80d11f44 j_mayer
                 0x00000000);
2523 80d11f44 j_mayer
    /* XXX : not implemented */
2524 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_EPN, "MI_EPN",
2525 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2526 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2527 80d11f44 j_mayer
                 0x00000000);
2528 80d11f44 j_mayer
    /* XXX : not implemented */
2529 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_TWC, "MI_TWC",
2530 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2531 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2532 80d11f44 j_mayer
                 0x00000000);
2533 80d11f44 j_mayer
    /* XXX : not implemented */
2534 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_RPN, "MI_RPN",
2535 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2536 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2537 80d11f44 j_mayer
                 0x00000000);
2538 80d11f44 j_mayer
    /* XXX : not implemented */
2539 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBCAM, "MI_DBCAM",
2540 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2541 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2542 80d11f44 j_mayer
                 0x00000000);
2543 80d11f44 j_mayer
    /* XXX : not implemented */
2544 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBRAM0, "MI_DBRAM0",
2545 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2546 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2547 80d11f44 j_mayer
                 0x00000000);
2548 80d11f44 j_mayer
    /* XXX : not implemented */
2549 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBRAM1, "MI_DBRAM1",
2550 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2551 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2552 80d11f44 j_mayer
                 0x00000000);
2553 80d11f44 j_mayer
    /* XXX : not implemented */
2554 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_CTR, "MD_CTR",
2555 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2556 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2557 80d11f44 j_mayer
                 0x00000000);
2558 80d11f44 j_mayer
    /* XXX : not implemented */
2559 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_CASID, "MD_CASID",
2560 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2561 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2562 80d11f44 j_mayer
                 0x00000000);
2563 80d11f44 j_mayer
    /* XXX : not implemented */
2564 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_AP, "MD_AP",
2565 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2566 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2567 80d11f44 j_mayer
                 0x00000000);
2568 80d11f44 j_mayer
    /* XXX : not implemented */
2569 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_EPN, "MD_EPN",
2570 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2571 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2572 80d11f44 j_mayer
                 0x00000000);
2573 80d11f44 j_mayer
    /* XXX : not implemented */
2574 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TWB, "MD_TWB",
2575 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2576 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2577 80d11f44 j_mayer
                 0x00000000);
2578 80d11f44 j_mayer
    /* XXX : not implemented */
2579 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TWC, "MD_TWC",
2580 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2581 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2582 80d11f44 j_mayer
                 0x00000000);
2583 80d11f44 j_mayer
    /* XXX : not implemented */
2584 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_RPN, "MD_RPN",
2585 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2586 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2587 80d11f44 j_mayer
                 0x00000000);
2588 80d11f44 j_mayer
    /* XXX : not implemented */
2589 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TW, "MD_TW",
2590 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2591 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2592 80d11f44 j_mayer
                 0x00000000);
2593 80d11f44 j_mayer
    /* XXX : not implemented */
2594 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBCAM, "MD_DBCAM",
2595 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2596 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2597 80d11f44 j_mayer
                 0x00000000);
2598 80d11f44 j_mayer
    /* XXX : not implemented */
2599 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBRAM0, "MD_DBRAM0",
2600 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2601 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2602 80d11f44 j_mayer
                 0x00000000);
2603 80d11f44 j_mayer
    /* XXX : not implemented */
2604 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBRAM1, "MD_DBRAM1",
2605 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2606 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2607 80d11f44 j_mayer
                 0x00000000);
2608 80d11f44 j_mayer
}
2609 80d11f44 j_mayer
2610 80d11f44 j_mayer
// XXX: TODO
2611 80d11f44 j_mayer
/*
2612 80d11f44 j_mayer
 * AMR     => SPR 29 (Power 2.04)
2613 80d11f44 j_mayer
 * CTRL    => SPR 136 (Power 2.04)
2614 80d11f44 j_mayer
 * CTRL    => SPR 152 (Power 2.04)
2615 80d11f44 j_mayer
 * SCOMC   => SPR 276 (64 bits ?)
2616 80d11f44 j_mayer
 * SCOMD   => SPR 277 (64 bits ?)
2617 80d11f44 j_mayer
 * TBU40   => SPR 286 (Power 2.04 hypv)
2618 80d11f44 j_mayer
 * HSPRG0  => SPR 304 (Power 2.04 hypv)
2619 80d11f44 j_mayer
 * HSPRG1  => SPR 305 (Power 2.04 hypv)
2620 80d11f44 j_mayer
 * HDSISR  => SPR 306 (Power 2.04 hypv)
2621 80d11f44 j_mayer
 * HDAR    => SPR 307 (Power 2.04 hypv)
2622 80d11f44 j_mayer
 * PURR    => SPR 309 (Power 2.04 hypv)
2623 80d11f44 j_mayer
 * HDEC    => SPR 310 (Power 2.04 hypv)
2624 80d11f44 j_mayer
 * HIOR    => SPR 311 (hypv)
2625 80d11f44 j_mayer
 * RMOR    => SPR 312 (970)
2626 80d11f44 j_mayer
 * HRMOR   => SPR 313 (Power 2.04 hypv)
2627 80d11f44 j_mayer
 * HSRR0   => SPR 314 (Power 2.04 hypv)
2628 80d11f44 j_mayer
 * HSRR1   => SPR 315 (Power 2.04 hypv)
2629 80d11f44 j_mayer
 * LPCR    => SPR 316 (970)
2630 80d11f44 j_mayer
 * LPIDR   => SPR 317 (970)
2631 80d11f44 j_mayer
 * EPR     => SPR 702 (Power 2.04 emb)
2632 80d11f44 j_mayer
 * perf    => 768-783 (Power 2.04)
2633 80d11f44 j_mayer
 * perf    => 784-799 (Power 2.04)
2634 80d11f44 j_mayer
 * PPR     => SPR 896 (Power 2.04)
2635 80d11f44 j_mayer
 * EPLC    => SPR 947 (Power 2.04 emb)
2636 80d11f44 j_mayer
 * EPSC    => SPR 948 (Power 2.04 emb)
2637 80d11f44 j_mayer
 * DABRX   => 1015    (Power 2.04 hypv)
2638 80d11f44 j_mayer
 * FPECR   => SPR 1022 (?)
2639 80d11f44 j_mayer
 * ... and more (thermal management, performance counters, ...)
2640 80d11f44 j_mayer
 */
2641 80d11f44 j_mayer
2642 80d11f44 j_mayer
/*****************************************************************************/
2643 80d11f44 j_mayer
/* Exception vectors models                                                  */
2644 80d11f44 j_mayer
static void init_excp_4xx_real (CPUPPCState *env)
2645 80d11f44 j_mayer
{
2646 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2647 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2648 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2649 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2650 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2651 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2652 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2653 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2654 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2655 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2656 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2657 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2658 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2659 faadf50e j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2660 1c27f8fb j_mayer
    /* Hardware reset vector */
2661 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2662 e1833e1f j_mayer
#endif
2663 e1833e1f j_mayer
}
2664 e1833e1f j_mayer
2665 80d11f44 j_mayer
static void init_excp_4xx_softmmu (CPUPPCState *env)
2666 80d11f44 j_mayer
{
2667 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2668 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2669 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2670 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2671 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2672 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2673 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2674 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2675 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2676 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2677 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2678 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2679 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001100;
2680 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001200;
2681 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2682 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2683 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2684 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2685 80d11f44 j_mayer
    /* Hardware reset vector */
2686 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2687 80d11f44 j_mayer
#endif
2688 80d11f44 j_mayer
}
2689 80d11f44 j_mayer
2690 80d11f44 j_mayer
static void init_excp_MPC5xx (CPUPPCState *env)
2691 80d11f44 j_mayer
{
2692 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2693 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2694 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2695 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2696 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2697 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2698 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000900;
2699 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2700 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2701 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2702 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2703 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001000;
2704 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DABR]     = 0x00001C00;
2705 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001C00;
2706 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MEXTBR]   = 0x00001E00;
2707 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_NMEXTBR]  = 0x00001F00;
2708 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2709 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2710 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2711 80d11f44 j_mayer
    /* Hardware reset vector */
2712 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2713 80d11f44 j_mayer
#endif
2714 80d11f44 j_mayer
}
2715 80d11f44 j_mayer
2716 80d11f44 j_mayer
static void init_excp_MPC8xx (CPUPPCState *env)
2717 e1833e1f j_mayer
{
2718 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2719 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2720 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2721 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2722 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2723 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2724 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2725 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2726 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000900;
2727 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2728 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2729 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2730 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2731 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001000;
2732 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001100;
2733 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001200;
2734 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLBE]    = 0x00001300;
2735 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLBE]    = 0x00001400;
2736 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DABR]     = 0x00001C00;
2737 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001C00;
2738 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MEXTBR]   = 0x00001E00;
2739 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_NMEXTBR]  = 0x00001F00;
2740 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2741 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2742 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2743 1c27f8fb j_mayer
    /* Hardware reset vector */
2744 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2745 e1833e1f j_mayer
#endif
2746 e1833e1f j_mayer
}
2747 e1833e1f j_mayer
2748 80d11f44 j_mayer
static void init_excp_G2 (CPUPPCState *env)
2749 e1833e1f j_mayer
{
2750 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2751 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2752 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2753 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2754 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2755 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2756 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2757 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2758 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2759 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2760 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000A00;
2761 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2762 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2763 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2764 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2765 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2766 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2767 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2768 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2769 80d11f44 j_mayer
    /* Hardware reset vector */
2770 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2771 80d11f44 j_mayer
#endif
2772 80d11f44 j_mayer
}
2773 80d11f44 j_mayer
2774 80d11f44 j_mayer
static void init_excp_e200 (CPUPPCState *env)
2775 80d11f44 j_mayer
{
2776 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2777 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000FFC;
2778 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2779 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2780 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2781 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2782 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2783 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2784 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2785 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2786 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2787 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2788 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2789 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2790 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2791 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2792 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2793 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2794 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SPEU]     = 0x00000000;
2795 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EFPDI]    = 0x00000000;
2796 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EFPRI]    = 0x00000000;
2797 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2798 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF7UL;
2799 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2800 80d11f44 j_mayer
    /* Hardware reset vector */
2801 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2802 80d11f44 j_mayer
#endif
2803 80d11f44 j_mayer
}
2804 80d11f44 j_mayer
2805 80d11f44 j_mayer
static void init_excp_BookE (CPUPPCState *env)
2806 80d11f44 j_mayer
{
2807 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2808 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2809 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2810 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2811 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2812 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2813 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2814 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2815 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2816 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2817 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2818 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2819 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2820 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2821 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2822 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2823 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2824 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2825 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFE0UL;
2826 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2827 80d11f44 j_mayer
    /* Hardware reset vector */
2828 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2829 80d11f44 j_mayer
#endif
2830 80d11f44 j_mayer
}
2831 80d11f44 j_mayer
2832 80d11f44 j_mayer
static void init_excp_601 (CPUPPCState *env)
2833 80d11f44 j_mayer
{
2834 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2835 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2836 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2837 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2838 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2839 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2840 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2841 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2842 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2843 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2844 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IO]       = 0x00000A00;
2845 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2846 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RUNM]     = 0x00002000;
2847 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0xFFF00000UL;
2848 1c27f8fb j_mayer
    /* Hardware reset vector */
2849 80d11f44 j_mayer
    env->hreset_vector = 0x00000100UL;
2850 e1833e1f j_mayer
#endif
2851 e1833e1f j_mayer
}
2852 e1833e1f j_mayer
2853 80d11f44 j_mayer
static void init_excp_602 (CPUPPCState *env)
2854 e1833e1f j_mayer
{
2855 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2856 082c6681 j_mayer
    /* XXX: exception prefix has a special behavior on 602 */
2857 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2858 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2859 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2860 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2861 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2862 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2863 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2864 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2865 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2866 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2867 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2868 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2869 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2870 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2871 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2872 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2873 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001500;
2874 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001600;
2875 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0xFFF00000UL;
2876 1c27f8fb j_mayer
    /* Hardware reset vector */
2877 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2878 e1833e1f j_mayer
#endif
2879 e1833e1f j_mayer
}
2880 e1833e1f j_mayer
2881 80d11f44 j_mayer
static void init_excp_603 (CPUPPCState *env)
2882 e1833e1f j_mayer
{
2883 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2884 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2885 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2886 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2887 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2888 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2889 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2890 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2891 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2892 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2893 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2894 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2895 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2896 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2897 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2898 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2899 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2900 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2901 1c27f8fb j_mayer
    /* Hardware reset vector */
2902 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2903 e1833e1f j_mayer
#endif
2904 e1833e1f j_mayer
}
2905 e1833e1f j_mayer
2906 e1833e1f j_mayer
static void init_excp_604 (CPUPPCState *env)
2907 e1833e1f j_mayer
{
2908 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2909 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2910 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2911 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2912 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2913 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2914 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2915 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2916 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2917 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2918 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2919 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2920 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2921 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2922 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2923 2d3eb7bf Tristan Gingold
    env->hreset_excp_prefix = 0xFFF00000UL;
2924 1c27f8fb j_mayer
    /* Hardware reset vector */
2925 2d3eb7bf Tristan Gingold
    env->hreset_vector = 0x00000100UL;
2926 e1833e1f j_mayer
#endif
2927 e1833e1f j_mayer
}
2928 e1833e1f j_mayer
2929 578bb252 j_mayer
#if defined(TARGET_PPC64)
2930 e1833e1f j_mayer
static void init_excp_620 (CPUPPCState *env)
2931 e1833e1f j_mayer
{
2932 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2933 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2934 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2935 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2936 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2937 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2938 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2939 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2940 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2941 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2942 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2943 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2944 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2945 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2946 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2947 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0xFFF00000UL;
2948 1c27f8fb j_mayer
    /* Hardware reset vector */
2949 faadf50e j_mayer
    env->hreset_vector = 0x0000000000000100ULL;
2950 e1833e1f j_mayer
#endif
2951 e1833e1f j_mayer
}
2952 578bb252 j_mayer
#endif /* defined(TARGET_PPC64) */
2953 e1833e1f j_mayer
2954 e1833e1f j_mayer
static void init_excp_7x0 (CPUPPCState *env)
2955 e1833e1f j_mayer
{
2956 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2957 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2958 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2959 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2960 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2961 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2962 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2963 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2964 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2965 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2966 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2967 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2968 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2969 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2970 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2971 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2972 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2973 1c27f8fb j_mayer
    /* Hardware reset vector */
2974 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2975 e1833e1f j_mayer
#endif
2976 e1833e1f j_mayer
}
2977 e1833e1f j_mayer
2978 bd928eba j_mayer
static void init_excp_750cl (CPUPPCState *env)
2979 e1833e1f j_mayer
{
2980 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2981 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2982 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2983 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2984 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2985 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2986 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2987 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2988 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2989 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2990 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2991 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2992 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2993 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2994 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2995 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2996 bd928eba j_mayer
    /* Hardware reset vector */
2997 bd928eba j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2998 bd928eba j_mayer
#endif
2999 bd928eba j_mayer
}
3000 bd928eba j_mayer
3001 bd928eba j_mayer
static void init_excp_750cx (CPUPPCState *env)
3002 bd928eba j_mayer
{
3003 bd928eba j_mayer
#if !defined(CONFIG_USER_ONLY)
3004 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3005 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3006 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3007 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3008 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3009 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3010 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3011 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3012 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3013 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3014 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3015 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3016 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3017 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
3018 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3019 1c27f8fb j_mayer
    /* Hardware reset vector */
3020 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3021 e1833e1f j_mayer
#endif
3022 e1833e1f j_mayer
}
3023 e1833e1f j_mayer
3024 7a3a6927 j_mayer
/* XXX: Check if this is correct */
3025 7a3a6927 j_mayer
static void init_excp_7x5 (CPUPPCState *env)
3026 7a3a6927 j_mayer
{
3027 7a3a6927 j_mayer
#if !defined(CONFIG_USER_ONLY)
3028 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3029 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3030 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3031 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3032 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3033 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3034 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3035 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3036 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3037 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3038 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3039 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3040 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
3041 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
3042 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
3043 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3044 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3045 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
3046 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3047 7a3a6927 j_mayer
    /* Hardware reset vector */
3048 7a3a6927 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3049 7a3a6927 j_mayer
#endif
3050 7a3a6927 j_mayer
}
3051 7a3a6927 j_mayer
3052 e1833e1f j_mayer
static void init_excp_7400 (CPUPPCState *env)
3053 e1833e1f j_mayer
{
3054 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
3055 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3056 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3057 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3058 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3059 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3060 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3061 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3062 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3063 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3064 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3065 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3066 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3067 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3068 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3069 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3070 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
3071 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
3072 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3073 1c27f8fb j_mayer
    /* Hardware reset vector */
3074 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3075 e1833e1f j_mayer
#endif
3076 e1833e1f j_mayer
}
3077 e1833e1f j_mayer
3078 e1833e1f j_mayer
static void init_excp_7450 (CPUPPCState *env)
3079 e1833e1f j_mayer
{
3080 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
3081 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3082 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3083 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3084 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3085 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3086 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3087 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3088 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3089 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3090 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3091 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3092 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3093 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3094 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
3095 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
3096 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
3097 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3098 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3099 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
3100 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3101 1c27f8fb j_mayer
    /* Hardware reset vector */
3102 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3103 e1833e1f j_mayer
#endif
3104 e1833e1f j_mayer
}
3105 e1833e1f j_mayer
3106 e1833e1f j_mayer
#if defined (TARGET_PPC64)
3107 e1833e1f j_mayer
static void init_excp_970 (CPUPPCState *env)
3108 e1833e1f j_mayer
{
3109 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
3110 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3111 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3112 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3113 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
3114 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3115 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
3116 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3117 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3118 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3119 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3120 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3121 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
3122 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3123 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3124 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3125 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3126 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3127 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
3128 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
3129 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
3130 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000FFF00000ULL;
3131 1c27f8fb j_mayer
    /* Hardware reset vector */
3132 1c27f8fb j_mayer
    env->hreset_vector = 0x0000000000000100ULL;
3133 e1833e1f j_mayer
#endif
3134 e1833e1f j_mayer
}
3135 9d52e907 David Gibson
3136 9d52e907 David Gibson
static void init_excp_POWER7 (CPUPPCState *env)
3137 9d52e907 David Gibson
{
3138 9d52e907 David Gibson
#if !defined(CONFIG_USER_ONLY)
3139 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3140 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3141 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3142 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
3143 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3144 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
3145 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3146 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3147 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3148 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3149 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3150 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
3151 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3152 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3153 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3154 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3155 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3156 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
3157 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
3158 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
3159 9d52e907 David Gibson
    env->hreset_excp_prefix = 0;
3160 9d52e907 David Gibson
    /* Hardware reset vector */
3161 9d52e907 David Gibson
    env->hreset_vector = 0x0000000000000100ULL;
3162 9d52e907 David Gibson
#endif
3163 9d52e907 David Gibson
}
3164 e1833e1f j_mayer
#endif
3165 e1833e1f j_mayer
3166 e1833e1f j_mayer
/*****************************************************************************/
3167 2f462816 j_mayer
/* Power management enable checks                                            */
3168 2f462816 j_mayer
static int check_pow_none (CPUPPCState *env)
3169 2f462816 j_mayer
{
3170 2f462816 j_mayer
    return 0;
3171 2f462816 j_mayer
}
3172 2f462816 j_mayer
3173 2f462816 j_mayer
static int check_pow_nocheck (CPUPPCState *env)
3174 2f462816 j_mayer
{
3175 2f462816 j_mayer
    return 1;
3176 2f462816 j_mayer
}
3177 2f462816 j_mayer
3178 2f462816 j_mayer
static int check_pow_hid0 (CPUPPCState *env)
3179 2f462816 j_mayer
{
3180 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00E00000)
3181 2f462816 j_mayer
        return 1;
3182 2f462816 j_mayer
3183 2f462816 j_mayer
    return 0;
3184 2f462816 j_mayer
}
3185 2f462816 j_mayer
3186 4e777442 j_mayer
static int check_pow_hid0_74xx (CPUPPCState *env)
3187 4e777442 j_mayer
{
3188 4e777442 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
3189 4e777442 j_mayer
        return 1;
3190 4e777442 j_mayer
3191 4e777442 j_mayer
    return 0;
3192 4e777442 j_mayer
}
3193 4e777442 j_mayer
3194 2f462816 j_mayer
/*****************************************************************************/
3195 a750fc0b j_mayer
/* PowerPC implementations definitions                                       */
3196 76a66253 j_mayer
3197 a750fc0b j_mayer
/* PowerPC 401                                                               */
3198 082c6681 j_mayer
#define POWERPC_INSNS_401    (PPC_INSNS_BASE | PPC_STRING |                   \
3199 082c6681 j_mayer
                              PPC_WRTEE | PPC_DCR |                           \
3200 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3201 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3202 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3203 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3204 a750fc0b j_mayer
#define POWERPC_MSRM_401     (0x00000000000FD201ULL)
3205 b4095fed j_mayer
#define POWERPC_MMU_401      (POWERPC_MMU_REAL)
3206 a750fc0b j_mayer
#define POWERPC_EXCP_401     (POWERPC_EXCP_40x)
3207 a750fc0b j_mayer
#define POWERPC_INPUT_401    (PPC_FLAGS_INPUT_401)
3208 237c0af0 j_mayer
#define POWERPC_BFDM_401     (bfd_mach_ppc_403)
3209 4018bae9 j_mayer
#define POWERPC_FLAG_401     (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3210 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3211 2f462816 j_mayer
#define check_pow_401        check_pow_nocheck
3212 76a66253 j_mayer
3213 a750fc0b j_mayer
static void init_proc_401 (CPUPPCState *env)
3214 a750fc0b j_mayer
{
3215 a750fc0b j_mayer
    gen_spr_40x(env);
3216 a750fc0b j_mayer
    gen_spr_401_403(env);
3217 a750fc0b j_mayer
    gen_spr_401(env);
3218 e1833e1f j_mayer
    init_excp_4xx_real(env);
3219 d63001d1 j_mayer
    env->dcache_line_size = 32;
3220 d63001d1 j_mayer
    env->icache_line_size = 32;
3221 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3222 4e290a0b j_mayer
    ppc40x_irq_init(env);
3223 a750fc0b j_mayer
}
3224 76a66253 j_mayer
3225 a750fc0b j_mayer
/* PowerPC 401x2                                                             */
3226 082c6681 j_mayer
#define POWERPC_INSNS_401x2  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3227 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3228 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3229 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3230 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3231 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3232 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3233 a750fc0b j_mayer
#define POWERPC_MSRM_401x2   (0x00000000001FD231ULL)
3234 a750fc0b j_mayer
#define POWERPC_MMU_401x2    (POWERPC_MMU_SOFT_4xx_Z)
3235 a750fc0b j_mayer
#define POWERPC_EXCP_401x2   (POWERPC_EXCP_40x)
3236 a750fc0b j_mayer
#define POWERPC_INPUT_401x2  (PPC_FLAGS_INPUT_401)
3237 237c0af0 j_mayer
#define POWERPC_BFDM_401x2   (bfd_mach_ppc_403)
3238 4018bae9 j_mayer
#define POWERPC_FLAG_401x2   (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3239 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3240 2f462816 j_mayer
#define check_pow_401x2      check_pow_nocheck
3241 a750fc0b j_mayer
3242 a750fc0b j_mayer
static void init_proc_401x2 (CPUPPCState *env)
3243 a750fc0b j_mayer
{
3244 a750fc0b j_mayer
    gen_spr_40x(env);
3245 a750fc0b j_mayer
    gen_spr_401_403(env);
3246 a750fc0b j_mayer
    gen_spr_401x2(env);
3247 a750fc0b j_mayer
    gen_spr_compress(env);
3248 a750fc0b j_mayer
    /* Memory management */
3249 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3250 a750fc0b j_mayer
    env->nb_tlb = 64;
3251 a750fc0b j_mayer
    env->nb_ways = 1;
3252 a750fc0b j_mayer
    env->id_tlbs = 0;
3253 f2e63a42 j_mayer
#endif
3254 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3255 d63001d1 j_mayer
    env->dcache_line_size = 32;
3256 d63001d1 j_mayer
    env->icache_line_size = 32;
3257 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3258 4e290a0b j_mayer
    ppc40x_irq_init(env);
3259 76a66253 j_mayer
}
3260 76a66253 j_mayer
3261 a750fc0b j_mayer
/* PowerPC 401x3                                                             */
3262 082c6681 j_mayer
#define POWERPC_INSNS_401x3  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3263 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3264 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3265 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3266 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3267 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3268 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3269 a750fc0b j_mayer
#define POWERPC_MSRM_401x3   (0x00000000001FD631ULL)
3270 a750fc0b j_mayer
#define POWERPC_MMU_401x3    (POWERPC_MMU_SOFT_4xx_Z)
3271 a750fc0b j_mayer
#define POWERPC_EXCP_401x3   (POWERPC_EXCP_40x)
3272 a750fc0b j_mayer
#define POWERPC_INPUT_401x3  (PPC_FLAGS_INPUT_401)
3273 237c0af0 j_mayer
#define POWERPC_BFDM_401x3   (bfd_mach_ppc_403)
3274 4018bae9 j_mayer
#define POWERPC_FLAG_401x3   (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3275 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3276 2f462816 j_mayer
#define check_pow_401x3      check_pow_nocheck
3277 a750fc0b j_mayer
3278 578bb252 j_mayer
__attribute__ (( unused ))
3279 e1833e1f j_mayer
static void init_proc_401x3 (CPUPPCState *env)
3280 76a66253 j_mayer
{
3281 4e290a0b j_mayer
    gen_spr_40x(env);
3282 4e290a0b j_mayer
    gen_spr_401_403(env);
3283 4e290a0b j_mayer
    gen_spr_401(env);
3284 4e290a0b j_mayer
    gen_spr_401x2(env);
3285 4e290a0b j_mayer
    gen_spr_compress(env);
3286 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3287 d63001d1 j_mayer
    env->dcache_line_size = 32;
3288 d63001d1 j_mayer
    env->icache_line_size = 32;
3289 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3290 4e290a0b j_mayer
    ppc40x_irq_init(env);
3291 3fc6c082 bellard
}
3292 a750fc0b j_mayer
3293 a750fc0b j_mayer
/* IOP480                                                                    */
3294 082c6681 j_mayer
#define POWERPC_INSNS_IOP480 (PPC_INSNS_BASE | PPC_STRING |                   \
3295 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3296 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |  PPC_40x_ICBT |    \
3297 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3298 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3299 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3300 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3301 a750fc0b j_mayer
#define POWERPC_MSRM_IOP480  (0x00000000001FD231ULL)
3302 a750fc0b j_mayer
#define POWERPC_MMU_IOP480   (POWERPC_MMU_SOFT_4xx_Z)
3303 a750fc0b j_mayer
#define POWERPC_EXCP_IOP480  (POWERPC_EXCP_40x)
3304 a750fc0b j_mayer
#define POWERPC_INPUT_IOP480 (PPC_FLAGS_INPUT_401)
3305 237c0af0 j_mayer
#define POWERPC_BFDM_IOP480  (bfd_mach_ppc_403)
3306 4018bae9 j_mayer
#define POWERPC_FLAG_IOP480  (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3307 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3308 2f462816 j_mayer
#define check_pow_IOP480     check_pow_nocheck
3309 a750fc0b j_mayer
3310 a750fc0b j_mayer
static void init_proc_IOP480 (CPUPPCState *env)
3311 3fc6c082 bellard
{
3312 a750fc0b j_mayer
    gen_spr_40x(env);
3313 a750fc0b j_mayer
    gen_spr_401_403(env);
3314 a750fc0b j_mayer
    gen_spr_401x2(env);
3315 a750fc0b j_mayer
    gen_spr_compress(env);
3316 a750fc0b j_mayer
    /* Memory management */
3317 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3318 a750fc0b j_mayer
    env->nb_tlb = 64;
3319 a750fc0b j_mayer
    env->nb_ways = 1;
3320 a750fc0b j_mayer
    env->id_tlbs = 0;
3321 f2e63a42 j_mayer
#endif
3322 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3323 d63001d1 j_mayer
    env->dcache_line_size = 32;
3324 d63001d1 j_mayer
    env->icache_line_size = 32;
3325 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3326 4e290a0b j_mayer
    ppc40x_irq_init(env);
3327 3fc6c082 bellard
}
3328 3fc6c082 bellard
3329 a750fc0b j_mayer
/* PowerPC 403                                                               */
3330 082c6681 j_mayer
#define POWERPC_INSNS_403    (PPC_INSNS_BASE | PPC_STRING |                   \
3331 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3332 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3333 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3334 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3335 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3336 a750fc0b j_mayer
#define POWERPC_MSRM_403     (0x000000000007D00DULL)
3337 b4095fed j_mayer
#define POWERPC_MMU_403      (POWERPC_MMU_REAL)
3338 a750fc0b j_mayer
#define POWERPC_EXCP_403     (POWERPC_EXCP_40x)
3339 a750fc0b j_mayer
#define POWERPC_INPUT_403    (PPC_FLAGS_INPUT_401)
3340 237c0af0 j_mayer
#define POWERPC_BFDM_403     (bfd_mach_ppc_403)
3341 4018bae9 j_mayer
#define POWERPC_FLAG_403     (POWERPC_FLAG_CE | POWERPC_FLAG_PX |             \
3342 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3343 2f462816 j_mayer
#define check_pow_403        check_pow_nocheck
3344 a750fc0b j_mayer
3345 a750fc0b j_mayer
static void init_proc_403 (CPUPPCState *env)
3346 3fc6c082 bellard
{
3347 a750fc0b j_mayer
    gen_spr_40x(env);
3348 a750fc0b j_mayer
    gen_spr_401_403(env);
3349 a750fc0b j_mayer
    gen_spr_403(env);
3350 a750fc0b j_mayer
    gen_spr_403_real(env);
3351 e1833e1f j_mayer
    init_excp_4xx_real(env);
3352 d63001d1 j_mayer
    env->dcache_line_size = 32;
3353 d63001d1 j_mayer
    env->icache_line_size = 32;
3354 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3355 4e290a0b j_mayer
    ppc40x_irq_init(env);
3356 3fc6c082 bellard
}
3357 3fc6c082 bellard
3358 a750fc0b j_mayer
/* PowerPC 403 GCX                                                           */
3359 082c6681 j_mayer
#define POWERPC_INSNS_403GCX (PPC_INSNS_BASE | PPC_STRING |                   \
3360 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3361 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3362 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3363 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3364 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3365 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3366 a750fc0b j_mayer
#define POWERPC_MSRM_403GCX  (0x000000000007D00DULL)
3367 a750fc0b j_mayer
#define POWERPC_MMU_403GCX   (POWERPC_MMU_SOFT_4xx_Z)
3368 a750fc0b j_mayer
#define POWERPC_EXCP_403GCX  (POWERPC_EXCP_40x)
3369 a750fc0b j_mayer
#define POWERPC_INPUT_403GCX (PPC_FLAGS_INPUT_401)
3370 237c0af0 j_mayer
#define POWERPC_BFDM_403GCX  (bfd_mach_ppc_403)
3371 4018bae9 j_mayer
#define POWERPC_FLAG_403GCX  (POWERPC_FLAG_CE | POWERPC_FLAG_PX |             \
3372 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3373 2f462816 j_mayer
#define check_pow_403GCX     check_pow_nocheck
3374 a750fc0b j_mayer
3375 a750fc0b j_mayer
static void init_proc_403GCX (CPUPPCState *env)
3376 3fc6c082 bellard
{
3377 a750fc0b j_mayer
    gen_spr_40x(env);
3378 a750fc0b j_mayer
    gen_spr_401_403(env);
3379 a750fc0b j_mayer
    gen_spr_403(env);
3380 a750fc0b j_mayer
    gen_spr_403_real(env);
3381 a750fc0b j_mayer
    gen_spr_403_mmu(env);
3382 a750fc0b j_mayer
    /* Bus access control */
3383 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
3384 a750fc0b j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
3385 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3386 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3387 a750fc0b j_mayer
                 0xFFFFFFFF);
3388 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
3389 a750fc0b j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
3390 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3391 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3392 a750fc0b j_mayer
                 0x00000000);
3393 a750fc0b j_mayer
    /* Memory management */
3394 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3395 a750fc0b j_mayer
    env->nb_tlb = 64;
3396 a750fc0b j_mayer
    env->nb_ways = 1;
3397 a750fc0b j_mayer
    env->id_tlbs = 0;
3398 f2e63a42 j_mayer
#endif
3399 80d11f44 j_mayer
    init_excp_4xx_softmmu(env);
3400 80d11f44 j_mayer
    env->dcache_line_size = 32;
3401 80d11f44 j_mayer
    env->icache_line_size = 32;
3402 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3403 80d11f44 j_mayer
    ppc40x_irq_init(env);
3404 80d11f44 j_mayer
}
3405 80d11f44 j_mayer
3406 80d11f44 j_mayer
/* PowerPC 405                                                               */
3407 082c6681 j_mayer
#define POWERPC_INSNS_405    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3408 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3409 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3410 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3411 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3412 80d11f44 j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3413 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_405_MAC | PPC_40x_EXCP)
3414 80d11f44 j_mayer
#define POWERPC_MSRM_405     (0x000000000006E630ULL)
3415 80d11f44 j_mayer
#define POWERPC_MMU_405      (POWERPC_MMU_SOFT_4xx)
3416 80d11f44 j_mayer
#define POWERPC_EXCP_405     (POWERPC_EXCP_40x)
3417 80d11f44 j_mayer
#define POWERPC_INPUT_405    (PPC_FLAGS_INPUT_405)
3418 80d11f44 j_mayer
#define POWERPC_BFDM_405     (bfd_mach_ppc_403)
3419 80d11f44 j_mayer
#define POWERPC_FLAG_405     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3420 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3421 80d11f44 j_mayer
#define check_pow_405        check_pow_nocheck
3422 80d11f44 j_mayer
3423 80d11f44 j_mayer
static void init_proc_405 (CPUPPCState *env)
3424 80d11f44 j_mayer
{
3425 80d11f44 j_mayer
    /* Time base */
3426 80d11f44 j_mayer
    gen_tbl(env);
3427 80d11f44 j_mayer
    gen_spr_40x(env);
3428 80d11f44 j_mayer
    gen_spr_405(env);
3429 80d11f44 j_mayer
    /* Bus access control */
3430 80d11f44 j_mayer
    /* not emulated, as Qemu never does speculative access */
3431 80d11f44 j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
3432 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3433 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3434 80d11f44 j_mayer
                 0xFFFFFFFF);
3435 80d11f44 j_mayer
    /* not emulated, as Qemu do not emulate caches */
3436 80d11f44 j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
3437 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3438 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3439 80d11f44 j_mayer
                 0x00000000);
3440 80d11f44 j_mayer
    /* Memory management */
3441 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3442 80d11f44 j_mayer
    env->nb_tlb = 64;
3443 80d11f44 j_mayer
    env->nb_ways = 1;
3444 80d11f44 j_mayer
    env->id_tlbs = 0;
3445 80d11f44 j_mayer
#endif
3446 80d11f44 j_mayer
    init_excp_4xx_softmmu(env);
3447 80d11f44 j_mayer
    env->dcache_line_size = 32;
3448 80d11f44 j_mayer
    env->icache_line_size = 32;
3449 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3450 80d11f44 j_mayer
    ppc40x_irq_init(env);
3451 80d11f44 j_mayer
}
3452 80d11f44 j_mayer
3453 80d11f44 j_mayer
/* PowerPC 440 EP                                                            */
3454 082c6681 j_mayer
#define POWERPC_INSNS_440EP  (PPC_INSNS_BASE | PPC_STRING |                   \
3455 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE | PPC_RFMCI |               \
3456 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3457 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3458 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_MFTB |                    \
3459 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3460 082c6681 j_mayer
                              PPC_440_SPEC)
3461 80d11f44 j_mayer
#define POWERPC_MSRM_440EP   (0x000000000006D630ULL)
3462 80d11f44 j_mayer
#define POWERPC_MMU_440EP    (POWERPC_MMU_BOOKE)
3463 80d11f44 j_mayer
#define POWERPC_EXCP_440EP   (POWERPC_EXCP_BOOKE)
3464 80d11f44 j_mayer
#define POWERPC_INPUT_440EP  (PPC_FLAGS_INPUT_BookE)
3465 80d11f44 j_mayer
#define POWERPC_BFDM_440EP   (bfd_mach_ppc_403)
3466 80d11f44 j_mayer
#define POWERPC_FLAG_440EP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3467 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3468 80d11f44 j_mayer
#define check_pow_440EP      check_pow_nocheck
3469 80d11f44 j_mayer
3470 80d11f44 j_mayer
__attribute__ (( unused ))
3471 80d11f44 j_mayer
static void init_proc_440EP (CPUPPCState *env)
3472 80d11f44 j_mayer
{
3473 80d11f44 j_mayer
    /* Time base */
3474 80d11f44 j_mayer
    gen_tbl(env);
3475 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3476 80d11f44 j_mayer
    gen_spr_440(env);
3477 80d11f44 j_mayer
    gen_spr_usprgh(env);
3478 80d11f44 j_mayer
    /* Processor identification */
3479 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3480 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3481 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3482 80d11f44 j_mayer
                 0x00000000);
3483 80d11f44 j_mayer
    /* XXX : not implemented */
3484 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3485 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3486 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3487 80d11f44 j_mayer
                 0x00000000);
3488 80d11f44 j_mayer
    /* XXX : not implemented */
3489 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3490 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3491 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3492 80d11f44 j_mayer
                 0x00000000);
3493 80d11f44 j_mayer
    /* XXX : not implemented */
3494 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3495 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3496 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3497 80d11f44 j_mayer
                 0x00000000);
3498 80d11f44 j_mayer
    /* XXX : not implemented */
3499 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3500 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3501 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3502 80d11f44 j_mayer
                 0x00000000);
3503 80d11f44 j_mayer
    /* XXX : not implemented */
3504 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3505 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3506 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3507 80d11f44 j_mayer
                 0x00000000);
3508 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3509 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3510 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3511 80d11f44 j_mayer
                 0x00000000);
3512 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3513 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3514 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3515 80d11f44 j_mayer
                 0x00000000);
3516 80d11f44 j_mayer
    /* XXX : not implemented */
3517 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3518 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3519 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3520 80d11f44 j_mayer
                 0x00000000);
3521 80d11f44 j_mayer
    /* Memory management */
3522 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3523 80d11f44 j_mayer
    env->nb_tlb = 64;
3524 80d11f44 j_mayer
    env->nb_ways = 1;
3525 80d11f44 j_mayer
    env->id_tlbs = 0;
3526 80d11f44 j_mayer
#endif
3527 80d11f44 j_mayer
    init_excp_BookE(env);
3528 80d11f44 j_mayer
    env->dcache_line_size = 32;
3529 80d11f44 j_mayer
    env->icache_line_size = 32;
3530 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3531 80d11f44 j_mayer
}
3532 80d11f44 j_mayer
3533 80d11f44 j_mayer
/* PowerPC 440 GP                                                            */
3534 082c6681 j_mayer
#define POWERPC_INSNS_440GP  (PPC_INSNS_BASE | PPC_STRING |                   \
3535 082c6681 j_mayer
                              PPC_DCR | PPC_DCRX | PPC_WRTEE | PPC_MFAPIDI |  \
3536 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3537 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3538 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_TLBIVA | PPC_MFTB |       \
3539 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3540 082c6681 j_mayer
                              PPC_440_SPEC)
3541 80d11f44 j_mayer
#define POWERPC_MSRM_440GP   (0x000000000006FF30ULL)
3542 80d11f44 j_mayer
#define POWERPC_MMU_440GP    (POWERPC_MMU_BOOKE)
3543 80d11f44 j_mayer
#define POWERPC_EXCP_440GP   (POWERPC_EXCP_BOOKE)
3544 80d11f44 j_mayer
#define POWERPC_INPUT_440GP  (PPC_FLAGS_INPUT_BookE)
3545 80d11f44 j_mayer
#define POWERPC_BFDM_440GP   (bfd_mach_ppc_403)
3546 80d11f44 j_mayer
#define POWERPC_FLAG_440GP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3547 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3548 80d11f44 j_mayer
#define check_pow_440GP      check_pow_nocheck
3549 80d11f44 j_mayer
3550 80d11f44 j_mayer
__attribute__ (( unused ))
3551 80d11f44 j_mayer
static void init_proc_440GP (CPUPPCState *env)
3552 80d11f44 j_mayer
{
3553 80d11f44 j_mayer
    /* Time base */
3554 80d11f44 j_mayer
    gen_tbl(env);
3555 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3556 80d11f44 j_mayer
    gen_spr_440(env);
3557 80d11f44 j_mayer
    gen_spr_usprgh(env);
3558 80d11f44 j_mayer
    /* Processor identification */
3559 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3560 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3561 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3562 80d11f44 j_mayer
                 0x00000000);
3563 80d11f44 j_mayer
    /* XXX : not implemented */
3564 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3565 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3566 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3567 80d11f44 j_mayer
                 0x00000000);
3568 80d11f44 j_mayer
    /* XXX : not implemented */
3569 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3570 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3571 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3572 80d11f44 j_mayer
                 0x00000000);
3573 80d11f44 j_mayer
    /* XXX : not implemented */
3574 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3575 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3576 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3577 80d11f44 j_mayer
                 0x00000000);
3578 80d11f44 j_mayer
    /* XXX : not implemented */
3579 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3580 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3581 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3582 80d11f44 j_mayer
                 0x00000000);
3583 80d11f44 j_mayer
    /* Memory management */
3584 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3585 80d11f44 j_mayer
    env->nb_tlb = 64;
3586 80d11f44 j_mayer
    env->nb_ways = 1;
3587 80d11f44 j_mayer
    env->id_tlbs = 0;
3588 80d11f44 j_mayer
#endif
3589 80d11f44 j_mayer
    init_excp_BookE(env);
3590 80d11f44 j_mayer
    env->dcache_line_size = 32;
3591 80d11f44 j_mayer
    env->icache_line_size = 32;
3592 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3593 80d11f44 j_mayer
}
3594 80d11f44 j_mayer
3595 80d11f44 j_mayer
/* PowerPC 440x4                                                             */
3596 082c6681 j_mayer
#define POWERPC_INSNS_440x4  (PPC_INSNS_BASE | PPC_STRING |                   \
3597 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3598 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3599 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3600 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_MFTB |                    \
3601 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3602 80d11f44 j_mayer
                              PPC_440_SPEC)
3603 80d11f44 j_mayer
#define POWERPC_MSRM_440x4   (0x000000000006FF30ULL)
3604 80d11f44 j_mayer
#define POWERPC_MMU_440x4    (POWERPC_MMU_BOOKE)
3605 80d11f44 j_mayer
#define POWERPC_EXCP_440x4   (POWERPC_EXCP_BOOKE)
3606 80d11f44 j_mayer
#define POWERPC_INPUT_440x4  (PPC_FLAGS_INPUT_BookE)
3607 80d11f44 j_mayer
#define POWERPC_BFDM_440x4   (bfd_mach_ppc_403)
3608 80d11f44 j_mayer
#define POWERPC_FLAG_440x4   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3609 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3610 80d11f44 j_mayer
#define check_pow_440x4      check_pow_nocheck
3611 80d11f44 j_mayer
3612 80d11f44 j_mayer
__attribute__ (( unused ))
3613 80d11f44 j_mayer
static void init_proc_440x4 (CPUPPCState *env)
3614 80d11f44 j_mayer
{
3615 80d11f44 j_mayer
    /* Time base */
3616 80d11f44 j_mayer
    gen_tbl(env);
3617 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3618 80d11f44 j_mayer
    gen_spr_440(env);
3619 80d11f44 j_mayer
    gen_spr_usprgh(env);
3620 80d11f44 j_mayer
    /* Processor identification */
3621 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3622 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3623 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3624 80d11f44 j_mayer
                 0x00000000);
3625 80d11f44 j_mayer
    /* XXX : not implemented */
3626 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3627 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3628 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3629 80d11f44 j_mayer
                 0x00000000);
3630 80d11f44 j_mayer
    /* XXX : not implemented */
3631 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3632 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3633 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3634 80d11f44 j_mayer
                 0x00000000);
3635 80d11f44 j_mayer
    /* XXX : not implemented */
3636 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3637 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3638 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3639 80d11f44 j_mayer
                 0x00000000);
3640 80d11f44 j_mayer
    /* XXX : not implemented */
3641 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3642 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3643 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3644 80d11f44 j_mayer
                 0x00000000);
3645 80d11f44 j_mayer
    /* Memory management */
3646 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3647 80d11f44 j_mayer
    env->nb_tlb = 64;
3648 80d11f44 j_mayer
    env->nb_ways = 1;
3649 80d11f44 j_mayer
    env->id_tlbs = 0;
3650 80d11f44 j_mayer
#endif
3651 80d11f44 j_mayer
    init_excp_BookE(env);
3652 d63001d1 j_mayer
    env->dcache_line_size = 32;
3653 d63001d1 j_mayer
    env->icache_line_size = 32;
3654 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3655 3fc6c082 bellard
}
3656 3fc6c082 bellard
3657 80d11f44 j_mayer
/* PowerPC 440x5                                                             */
3658 082c6681 j_mayer
#define POWERPC_INSNS_440x5  (PPC_INSNS_BASE | PPC_STRING |                   \
3659 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE | PPC_RFMCI |               \
3660 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3661 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3662 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_MFTB |                    \
3663 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3664 082c6681 j_mayer
                              PPC_440_SPEC)
3665 80d11f44 j_mayer
#define POWERPC_MSRM_440x5   (0x000000000006FF30ULL)
3666 80d11f44 j_mayer
#define POWERPC_MMU_440x5    (POWERPC_MMU_BOOKE)
3667 80d11f44 j_mayer
#define POWERPC_EXCP_440x5   (POWERPC_EXCP_BOOKE)
3668 80d11f44 j_mayer
#define POWERPC_INPUT_440x5  (PPC_FLAGS_INPUT_BookE)
3669 80d11f44 j_mayer
#define POWERPC_BFDM_440x5   (bfd_mach_ppc_403)
3670 80d11f44 j_mayer
#define POWERPC_FLAG_440x5   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |           \
3671 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3672 80d11f44 j_mayer
#define check_pow_440x5      check_pow_nocheck
3673 a750fc0b j_mayer
3674 80d11f44 j_mayer
static void init_proc_440x5 (CPUPPCState *env)
3675 3fc6c082 bellard
{
3676 a750fc0b j_mayer
    /* Time base */
3677 a750fc0b j_mayer
    gen_tbl(env);
3678 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3679 80d11f44 j_mayer
    gen_spr_440(env);
3680 80d11f44 j_mayer
    gen_spr_usprgh(env);
3681 80d11f44 j_mayer
    /* Processor identification */
3682 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3683 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3684 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3685 80d11f44 j_mayer
                 0x00000000);
3686 80d11f44 j_mayer
    /* XXX : not implemented */
3687 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3688 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3689 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3690 80d11f44 j_mayer
                 0x00000000);
3691 80d11f44 j_mayer
    /* XXX : not implemented */
3692 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3693 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3694 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3695 80d11f44 j_mayer
                 0x00000000);
3696 80d11f44 j_mayer
    /* XXX : not implemented */
3697 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3698 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3699 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3700 80d11f44 j_mayer
                 0x00000000);
3701 80d11f44 j_mayer
    /* XXX : not implemented */
3702 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3703 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3704 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3705 80d11f44 j_mayer
                 0x00000000);
3706 80d11f44 j_mayer
    /* XXX : not implemented */
3707 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3708 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3709 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3710 80d11f44 j_mayer
                 0x00000000);
3711 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3712 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3713 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3714 80d11f44 j_mayer
                 0x00000000);
3715 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3716 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3717 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3718 80d11f44 j_mayer
                 0x00000000);
3719 80d11f44 j_mayer
    /* XXX : not implemented */
3720 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3721 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3722 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3723 a750fc0b j_mayer
                 0x00000000);
3724 a750fc0b j_mayer
    /* Memory management */
3725 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3726 a750fc0b j_mayer
    env->nb_tlb = 64;
3727 a750fc0b j_mayer
    env->nb_ways = 1;
3728 a750fc0b j_mayer
    env->id_tlbs = 0;
3729 f2e63a42 j_mayer
#endif
3730 80d11f44 j_mayer
    init_excp_BookE(env);
3731 d63001d1 j_mayer
    env->dcache_line_size = 32;
3732 d63001d1 j_mayer
    env->icache_line_size = 32;
3733 95070372 Edgar E. Iglesias
    ppc40x_irq_init(env);
3734 3fc6c082 bellard
}
3735 3fc6c082 bellard
3736 80d11f44 j_mayer
/* PowerPC 460 (guessed)                                                     */
3737 082c6681 j_mayer
#define POWERPC_INSNS_460    (PPC_INSNS_BASE | PPC_STRING |                   \
3738 80d11f44 j_mayer
                              PPC_DCR | PPC_DCRX  | PPC_DCRUX |               \
3739 f4078236 Baojun Wang
                              PPC_WRTEE | PPC_MFAPIDI | PPC_MFTB |            \
3740 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3741 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3742 082c6681 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVA |                  \
3743 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3744 082c6681 j_mayer
                              PPC_440_SPEC)
3745 80d11f44 j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3746 80d11f44 j_mayer
#define POWERPC_MMU_460      (POWERPC_MMU_BOOKE)
3747 80d11f44 j_mayer
#define POWERPC_EXCP_460     (POWERPC_EXCP_BOOKE)
3748 80d11f44 j_mayer
#define POWERPC_INPUT_460    (PPC_FLAGS_INPUT_BookE)
3749 80d11f44 j_mayer
#define POWERPC_BFDM_460     (bfd_mach_ppc_403)
3750 80d11f44 j_mayer
#define POWERPC_FLAG_460     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3751 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3752 80d11f44 j_mayer
#define check_pow_460        check_pow_nocheck
3753 a750fc0b j_mayer
3754 80d11f44 j_mayer
__attribute__ (( unused ))
3755 80d11f44 j_mayer
static void init_proc_460 (CPUPPCState *env)
3756 3fc6c082 bellard
{
3757 a750fc0b j_mayer
    /* Time base */
3758 a750fc0b j_mayer
    gen_tbl(env);
3759 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3760 a750fc0b j_mayer
    gen_spr_440(env);
3761 80d11f44 j_mayer
    gen_spr_usprgh(env);
3762 80d11f44 j_mayer
    /* Processor identification */
3763 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3764 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3765 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3766 80d11f44 j_mayer
                 0x00000000);
3767 80d11f44 j_mayer
    /* XXX : not implemented */
3768 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3769 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3770 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3771 80d11f44 j_mayer
                 0x00000000);
3772 80d11f44 j_mayer
    /* XXX : not implemented */
3773 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3774 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3775 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3776 80d11f44 j_mayer
                 0x00000000);
3777 80d11f44 j_mayer
    /* XXX : not implemented */
3778 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3779 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3780 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3781 80d11f44 j_mayer
                 0x00000000);
3782 80d11f44 j_mayer
    /* XXX : not implemented */
3783 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3784 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3785 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3786 80d11f44 j_mayer
                 0x00000000);
3787 578bb252 j_mayer
    /* XXX : not implemented */
3788 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3789 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3790 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3791 a750fc0b j_mayer
                 0x00000000);
3792 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3793 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3794 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3795 a750fc0b j_mayer
                 0x00000000);
3796 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3797 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3798 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3799 a750fc0b j_mayer
                 0x00000000);
3800 578bb252 j_mayer
    /* XXX : not implemented */
3801 a750fc0b j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3802 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3803 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3804 a750fc0b j_mayer
                 0x00000000);
3805 80d11f44 j_mayer
    /* XXX : not implemented */
3806 80d11f44 j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3807 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3808 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3809 80d11f44 j_mayer
                 0x00000000);
3810 a750fc0b j_mayer
    /* Memory management */
3811 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3812 a750fc0b j_mayer
    env->nb_tlb = 64;
3813 a750fc0b j_mayer
    env->nb_ways = 1;
3814 a750fc0b j_mayer
    env->id_tlbs = 0;
3815 f2e63a42 j_mayer
#endif
3816 e1833e1f j_mayer
    init_excp_BookE(env);
3817 d63001d1 j_mayer
    env->dcache_line_size = 32;
3818 d63001d1 j_mayer
    env->icache_line_size = 32;
3819 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3820 3fc6c082 bellard
}
3821 3fc6c082 bellard
3822 80d11f44 j_mayer
/* PowerPC 460F (guessed)                                                    */
3823 082c6681 j_mayer
#define POWERPC_INSNS_460F   (PPC_INSNS_BASE | PPC_STRING |                   \
3824 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FRES | PPC_FLOAT_FSEL |   \
3825 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
3826 f4078236 Baojun Wang
                              PPC_FLOAT_STFIWX | PPC_MFTB |                   \
3827 082c6681 j_mayer
                              PPC_DCR | PPC_DCRX | PPC_DCRUX |                \
3828 082c6681 j_mayer
                              PPC_WRTEE | PPC_MFAPIDI |                       \
3829 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3830 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3831 082c6681 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVA |                  \
3832 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3833 082c6681 j_mayer
                              PPC_440_SPEC)
3834 80d11f44 j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3835 80d11f44 j_mayer
#define POWERPC_MMU_460F     (POWERPC_MMU_BOOKE)
3836 80d11f44 j_mayer
#define POWERPC_EXCP_460F    (POWERPC_EXCP_BOOKE)
3837 80d11f44 j_mayer
#define POWERPC_INPUT_460F   (PPC_FLAGS_INPUT_BookE)
3838 80d11f44 j_mayer
#define POWERPC_BFDM_460F    (bfd_mach_ppc_403)
3839 80d11f44 j_mayer
#define POWERPC_FLAG_460F    (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3840 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3841 80d11f44 j_mayer
#define check_pow_460F       check_pow_nocheck
3842 a750fc0b j_mayer
3843 80d11f44 j_mayer
__attribute__ (( unused ))
3844 80d11f44 j_mayer
static void init_proc_460F (CPUPPCState *env)
3845 3fc6c082 bellard
{
3846 a750fc0b j_mayer
    /* Time base */
3847 a750fc0b j_mayer
    gen_tbl(env);
3848 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3849 a750fc0b j_mayer
    gen_spr_440(env);
3850 80d11f44 j_mayer
    gen_spr_usprgh(env);
3851 80d11f44 j_mayer
    /* Processor identification */
3852 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3853 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3854 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3855 80d11f44 j_mayer
                 0x00000000);
3856 80d11f44 j_mayer
    /* XXX : not implemented */
3857 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3858 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3859 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3860 80d11f44 j_mayer
                 0x00000000);
3861 80d11f44 j_mayer
    /* XXX : not implemented */
3862 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3863 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3864 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3865 80d11f44 j_mayer
                 0x00000000);
3866 80d11f44 j_mayer
    /* XXX : not implemented */
3867 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3868 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3869 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3870 80d11f44 j_mayer
                 0x00000000);
3871 80d11f44 j_mayer
    /* XXX : not implemented */
3872 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3873 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3874 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3875 80d11f44 j_mayer
                 0x00000000);
3876 80d11f44 j_mayer
    /* XXX : not implemented */
3877 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3878 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3879 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3880 80d11f44 j_mayer
                 0x00000000);
3881 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3882 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3883 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3884 80d11f44 j_mayer
                 0x00000000);
3885 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3886 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3887 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3888 80d11f44 j_mayer
                 0x00000000);
3889 80d11f44 j_mayer
    /* XXX : not implemented */
3890 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3891 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3892 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3893 80d11f44 j_mayer
                 0x00000000);
3894 80d11f44 j_mayer
    /* XXX : not implemented */
3895 80d11f44 j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3896 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3897 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3898 80d11f44 j_mayer
                 0x00000000);
3899 a750fc0b j_mayer
    /* Memory management */
3900 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3901 a750fc0b j_mayer
    env->nb_tlb = 64;
3902 a750fc0b j_mayer
    env->nb_ways = 1;
3903 a750fc0b j_mayer
    env->id_tlbs = 0;
3904 f2e63a42 j_mayer
#endif
3905 e1833e1f j_mayer
    init_excp_BookE(env);
3906 d63001d1 j_mayer
    env->dcache_line_size = 32;
3907 d63001d1 j_mayer
    env->icache_line_size = 32;
3908 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3909 3fc6c082 bellard
}
3910 3fc6c082 bellard
3911 80d11f44 j_mayer
/* Freescale 5xx cores (aka RCPU) */
3912 80d11f44 j_mayer
#define POWERPC_INSNS_MPC5xx (PPC_INSNS_BASE | PPC_STRING |                   \
3913 80d11f44 j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_SYNC |                  \
3914 80d11f44 j_mayer
                              PPC_CACHE_ICBI | PPC_FLOAT | PPC_FLOAT_STFIWX | \
3915 80d11f44 j_mayer
                              PPC_MFTB)
3916 80d11f44 j_mayer
#define POWERPC_MSRM_MPC5xx  (0x000000000001FF43ULL)
3917 80d11f44 j_mayer
#define POWERPC_MMU_MPC5xx   (POWERPC_MMU_REAL)
3918 80d11f44 j_mayer
#define POWERPC_EXCP_MPC5xx  (POWERPC_EXCP_603)
3919 80d11f44 j_mayer
#define POWERPC_INPUT_MPC5xx (PPC_FLAGS_INPUT_RCPU)
3920 80d11f44 j_mayer
#define POWERPC_BFDM_MPC5xx  (bfd_mach_ppc_505)
3921 4018bae9 j_mayer
#define POWERPC_FLAG_MPC5xx  (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3922 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3923 80d11f44 j_mayer
#define check_pow_MPC5xx     check_pow_none
3924 80d11f44 j_mayer
3925 80d11f44 j_mayer
__attribute__ (( unused ))
3926 80d11f44 j_mayer
static void init_proc_MPC5xx (CPUPPCState *env)
3927 80d11f44 j_mayer
{
3928 80d11f44 j_mayer
    /* Time base */
3929 80d11f44 j_mayer
    gen_tbl(env);
3930 80d11f44 j_mayer
    gen_spr_5xx_8xx(env);
3931 80d11f44 j_mayer
    gen_spr_5xx(env);
3932 80d11f44 j_mayer
    init_excp_MPC5xx(env);
3933 80d11f44 j_mayer
    env->dcache_line_size = 32;
3934 80d11f44 j_mayer
    env->icache_line_size = 32;
3935 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3936 80d11f44 j_mayer
}
3937 80d11f44 j_mayer
3938 80d11f44 j_mayer
/* Freescale 8xx cores (aka PowerQUICC) */
3939 80d11f44 j_mayer
#define POWERPC_INSNS_MPC8xx (PPC_INSNS_BASE | PPC_STRING  |                  \
3940 80d11f44 j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_SYNC |                  \
3941 80d11f44 j_mayer
                              PPC_CACHE_ICBI | PPC_MFTB)
3942 80d11f44 j_mayer
#define POWERPC_MSRM_MPC8xx  (0x000000000001F673ULL)
3943 80d11f44 j_mayer
#define POWERPC_MMU_MPC8xx   (POWERPC_MMU_MPC8xx)
3944 80d11f44 j_mayer
#define POWERPC_EXCP_MPC8xx  (POWERPC_EXCP_603)
3945 80d11f44 j_mayer
#define POWERPC_INPUT_MPC8xx (PPC_FLAGS_INPUT_RCPU)
3946 80d11f44 j_mayer
#define POWERPC_BFDM_MPC8xx  (bfd_mach_ppc_860)
3947 4018bae9 j_mayer
#define POWERPC_FLAG_MPC8xx  (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3948 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3949 80d11f44 j_mayer
#define check_pow_MPC8xx     check_pow_none
3950 80d11f44 j_mayer
3951 80d11f44 j_mayer
__attribute__ (( unused ))
3952 80d11f44 j_mayer
static void init_proc_MPC8xx (CPUPPCState *env)
3953 80d11f44 j_mayer
{
3954 80d11f44 j_mayer
    /* Time base */
3955 80d11f44 j_mayer
    gen_tbl(env);
3956 80d11f44 j_mayer
    gen_spr_5xx_8xx(env);
3957 80d11f44 j_mayer
    gen_spr_8xx(env);
3958 80d11f44 j_mayer
    init_excp_MPC8xx(env);
3959 80d11f44 j_mayer
    env->dcache_line_size = 32;
3960 80d11f44 j_mayer
    env->icache_line_size = 32;
3961 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3962 80d11f44 j_mayer
}
3963 80d11f44 j_mayer
3964 80d11f44 j_mayer
/* Freescale 82xx cores (aka PowerQUICC-II)                                  */
3965 80d11f44 j_mayer
/* PowerPC G2                                                                */
3966 082c6681 j_mayer
#define POWERPC_INSNS_G2     (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3967 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
3968 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
3969 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
3970 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3971 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
3972 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
3973 80d11f44 j_mayer
#define POWERPC_MSRM_G2      (0x000000000006FFF2ULL)
3974 80d11f44 j_mayer
#define POWERPC_MMU_G2       (POWERPC_MMU_SOFT_6xx)
3975 80d11f44 j_mayer
//#define POWERPC_EXCP_G2      (POWERPC_EXCP_G2)
3976 80d11f44 j_mayer
#define POWERPC_INPUT_G2     (PPC_FLAGS_INPUT_6xx)
3977 80d11f44 j_mayer
#define POWERPC_BFDM_G2      (bfd_mach_ppc_ec603e)
3978 80d11f44 j_mayer
#define POWERPC_FLAG_G2      (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3979 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
3980 80d11f44 j_mayer
#define check_pow_G2         check_pow_hid0
3981 a750fc0b j_mayer
3982 80d11f44 j_mayer
static void init_proc_G2 (CPUPPCState *env)
3983 3fc6c082 bellard
{
3984 80d11f44 j_mayer
    gen_spr_ne_601(env);
3985 80d11f44 j_mayer
    gen_spr_G2_755(env);
3986 80d11f44 j_mayer
    gen_spr_G2(env);
3987 a750fc0b j_mayer
    /* Time base */
3988 a750fc0b j_mayer
    gen_tbl(env);
3989 bd928eba j_mayer
    /* External access control */
3990 bd928eba j_mayer
    /* XXX : not implemented */
3991 bd928eba j_mayer
    spr_register(env, SPR_EAR, "EAR",
3992 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3993 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
3994 bd928eba j_mayer
                 0x00000000);
3995 80d11f44 j_mayer
    /* Hardware implementation register */
3996 80d11f44 j_mayer
    /* XXX : not implemented */
3997 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
3998 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3999 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4000 80d11f44 j_mayer
                 0x00000000);
4001 80d11f44 j_mayer
    /* XXX : not implemented */
4002 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4003 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4004 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4005 80d11f44 j_mayer
                 0x00000000);
4006 80d11f44 j_mayer
    /* XXX : not implemented */
4007 80d11f44 j_mayer
    spr_register(env, SPR_HID2, "HID2",
4008 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4009 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4010 80d11f44 j_mayer
                 0x00000000);
4011 a750fc0b j_mayer
    /* Memory management */
4012 80d11f44 j_mayer
    gen_low_BATs(env);
4013 80d11f44 j_mayer
    gen_high_BATs(env);
4014 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4015 80d11f44 j_mayer
    init_excp_G2(env);
4016 d63001d1 j_mayer
    env->dcache_line_size = 32;
4017 d63001d1 j_mayer
    env->icache_line_size = 32;
4018 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
4019 80d11f44 j_mayer
    ppc6xx_irq_init(env);
4020 3fc6c082 bellard
}
4021 a750fc0b j_mayer
4022 80d11f44 j_mayer
/* PowerPC G2LE                                                              */
4023 082c6681 j_mayer
#define POWERPC_INSNS_G2LE   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4024 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4025 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4026 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4027 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4028 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4029 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4030 80d11f44 j_mayer
#define POWERPC_MSRM_G2LE    (0x000000000007FFF3ULL)
4031 80d11f44 j_mayer
#define POWERPC_MMU_G2LE     (POWERPC_MMU_SOFT_6xx)
4032 80d11f44 j_mayer
#define POWERPC_EXCP_G2LE    (POWERPC_EXCP_G2)
4033 80d11f44 j_mayer
#define POWERPC_INPUT_G2LE   (PPC_FLAGS_INPUT_6xx)
4034 80d11f44 j_mayer
#define POWERPC_BFDM_G2LE    (bfd_mach_ppc_ec603e)
4035 80d11f44 j_mayer
#define POWERPC_FLAG_G2LE    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4036 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4037 80d11f44 j_mayer
#define check_pow_G2LE       check_pow_hid0
4038 a750fc0b j_mayer
4039 80d11f44 j_mayer
static void init_proc_G2LE (CPUPPCState *env)
4040 3fc6c082 bellard
{
4041 80d11f44 j_mayer
    gen_spr_ne_601(env);
4042 80d11f44 j_mayer
    gen_spr_G2_755(env);
4043 80d11f44 j_mayer
    gen_spr_G2(env);
4044 a750fc0b j_mayer
    /* Time base */
4045 a750fc0b j_mayer
    gen_tbl(env);
4046 bd928eba j_mayer
    /* External access control */
4047 bd928eba j_mayer
    /* XXX : not implemented */
4048 bd928eba j_mayer
    spr_register(env, SPR_EAR, "EAR",
4049 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4050 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4051 bd928eba j_mayer
                 0x00000000);
4052 80d11f44 j_mayer
    /* Hardware implementation register */
4053 578bb252 j_mayer
    /* XXX : not implemented */
4054 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4055 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4056 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4057 a750fc0b j_mayer
                 0x00000000);
4058 80d11f44 j_mayer
    /* XXX : not implemented */
4059 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4060 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4061 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4062 a750fc0b j_mayer
                 0x00000000);
4063 578bb252 j_mayer
    /* XXX : not implemented */
4064 80d11f44 j_mayer
    spr_register(env, SPR_HID2, "HID2",
4065 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4066 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4067 a750fc0b j_mayer
                 0x00000000);
4068 a750fc0b j_mayer
    /* Memory management */
4069 80d11f44 j_mayer
    gen_low_BATs(env);
4070 80d11f44 j_mayer
    gen_high_BATs(env);
4071 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4072 80d11f44 j_mayer
    init_excp_G2(env);
4073 d63001d1 j_mayer
    env->dcache_line_size = 32;
4074 d63001d1 j_mayer
    env->icache_line_size = 32;
4075 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
4076 80d11f44 j_mayer
    ppc6xx_irq_init(env);
4077 3fc6c082 bellard
}
4078 3fc6c082 bellard
4079 80d11f44 j_mayer
/* e200 core                                                                 */
4080 80d11f44 j_mayer
/* XXX: unimplemented instructions:
4081 80d11f44 j_mayer
 * dcblc
4082 80d11f44 j_mayer
 * dcbtlst
4083 80d11f44 j_mayer
 * dcbtstls
4084 80d11f44 j_mayer
 * icblc
4085 80d11f44 j_mayer
 * icbtls
4086 80d11f44 j_mayer
 * tlbivax
4087 80d11f44 j_mayer
 * all SPE multiply-accumulate instructions
4088 80d11f44 j_mayer
 */
4089 082c6681 j_mayer
#define POWERPC_INSNS_e200   (PPC_INSNS_BASE | PPC_ISEL |                     \
4090 40569b7e aurel32
                              PPC_SPE | PPC_SPE_SINGLE |                      \
4091 082c6681 j_mayer
                              PPC_WRTEE | PPC_RFDI |                          \
4092 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI |   \
4093 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
4094 80d11f44 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVAX |                 \
4095 082c6681 j_mayer
                              PPC_BOOKE)
4096 80d11f44 j_mayer
#define POWERPC_MSRM_e200    (0x000000000606FF30ULL)
4097 80d11f44 j_mayer
#define POWERPC_MMU_e200     (POWERPC_MMU_BOOKE_FSL)
4098 80d11f44 j_mayer
#define POWERPC_EXCP_e200    (POWERPC_EXCP_BOOKE)
4099 80d11f44 j_mayer
#define POWERPC_INPUT_e200   (PPC_FLAGS_INPUT_BookE)
4100 80d11f44 j_mayer
#define POWERPC_BFDM_e200    (bfd_mach_ppc_860)
4101 80d11f44 j_mayer
#define POWERPC_FLAG_e200    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |            \
4102 4018bae9 j_mayer
                              POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |           \
4103 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4104 80d11f44 j_mayer
#define check_pow_e200       check_pow_hid0
4105 80d11f44 j_mayer
4106 578bb252 j_mayer
__attribute__ (( unused ))
4107 80d11f44 j_mayer
static void init_proc_e200 (CPUPPCState *env)
4108 3fc6c082 bellard
{
4109 e1833e1f j_mayer
    /* Time base */
4110 e1833e1f j_mayer
    gen_tbl(env);
4111 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000070000FFFFULL);
4112 578bb252 j_mayer
    /* XXX : not implemented */
4113 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_SPEFSCR, "SPEFSCR",
4114 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4115 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4116 e1833e1f j_mayer
                 0x00000000);
4117 80d11f44 j_mayer
    /* Memory management */
4118 80d11f44 j_mayer
    gen_spr_BookE_FSL(env, 0x0000005D);
4119 80d11f44 j_mayer
    /* XXX : not implemented */
4120 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4121 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4122 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4123 e1833e1f j_mayer
                 0x00000000);
4124 80d11f44 j_mayer
    /* XXX : not implemented */
4125 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4126 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4127 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4128 e1833e1f j_mayer
                 0x00000000);
4129 578bb252 j_mayer
    /* XXX : not implemented */
4130 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_ALTCTXCR, "ALTCTXCR",
4131 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4132 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4133 e1833e1f j_mayer
                 0x00000000);
4134 578bb252 j_mayer
    /* XXX : not implemented */
4135 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BUCSR, "BUCSR",
4136 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4137 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4138 80d11f44 j_mayer
                 0x00000000);
4139 80d11f44 j_mayer
    /* XXX : not implemented */
4140 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_CTXCR, "CTXCR",
4141 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4142 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4143 80d11f44 j_mayer
                 0x00000000);
4144 80d11f44 j_mayer
    /* XXX : not implemented */
4145 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_DBCNT, "DBCNT",
4146 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4147 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4148 80d11f44 j_mayer
                 0x00000000);
4149 80d11f44 j_mayer
    /* XXX : not implemented */
4150 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_DBCR3, "DBCR3",
4151 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4152 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4153 80d11f44 j_mayer
                 0x00000000);
4154 80d11f44 j_mayer
    /* XXX : not implemented */
4155 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CFG0, "L1CFG0",
4156 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4157 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4158 80d11f44 j_mayer
                 0x00000000);
4159 80d11f44 j_mayer
    /* XXX : not implemented */
4160 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR0, "L1CSR0",
4161 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4162 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4163 80d11f44 j_mayer
                 0x00000000);
4164 80d11f44 j_mayer
    /* XXX : not implemented */
4165 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1FINV0, "L1FINV0",
4166 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4167 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4168 80d11f44 j_mayer
                 0x00000000);
4169 80d11f44 j_mayer
    /* XXX : not implemented */
4170 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
4171 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4172 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4173 80d11f44 j_mayer
                 0x00000000);
4174 80d11f44 j_mayer
    /* XXX : not implemented */
4175 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
4176 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4177 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4178 80d11f44 j_mayer
                 0x00000000);
4179 80d11f44 j_mayer
    /* XXX : not implemented */
4180 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
4181 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4182 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4183 80d11f44 j_mayer
                 0x00000000);
4184 80d11f44 j_mayer
    /* XXX : not implemented */
4185 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
4186 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4187 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4188 80d11f44 j_mayer
                 0x00000000);
4189 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DSRR0, "DSRR0",
4190 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4191 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4192 80d11f44 j_mayer
                 0x00000000);
4193 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DSRR1, "DSRR1",
4194 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4195 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4196 e1833e1f j_mayer
                 0x00000000);
4197 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4198 e1833e1f j_mayer
    env->nb_tlb = 64;
4199 e1833e1f j_mayer
    env->nb_ways = 1;
4200 e1833e1f j_mayer
    env->id_tlbs = 0;
4201 f2e63a42 j_mayer
#endif
4202 80d11f44 j_mayer
    init_excp_e200(env);
4203 d63001d1 j_mayer
    env->dcache_line_size = 32;
4204 d63001d1 j_mayer
    env->icache_line_size = 32;
4205 e1833e1f j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
4206 3fc6c082 bellard
}
4207 a750fc0b j_mayer
4208 80d11f44 j_mayer
/* e300 core                                                                 */
4209 082c6681 j_mayer
#define POWERPC_INSNS_e300   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4210 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4211 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4212 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4213 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4214 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4215 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4216 80d11f44 j_mayer
#define POWERPC_MSRM_e300    (0x000000000007FFF3ULL)
4217 80d11f44 j_mayer
#define POWERPC_MMU_e300     (POWERPC_MMU_SOFT_6xx)
4218 80d11f44 j_mayer
#define POWERPC_EXCP_e300    (POWERPC_EXCP_603)
4219 80d11f44 j_mayer
#define POWERPC_INPUT_e300   (PPC_FLAGS_INPUT_6xx)
4220 80d11f44 j_mayer
#define POWERPC_BFDM_e300    (bfd_mach_ppc_603)
4221 80d11f44 j_mayer
#define POWERPC_FLAG_e300    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4222 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4223 80d11f44 j_mayer
#define check_pow_e300       check_pow_hid0
4224 a750fc0b j_mayer
4225 578bb252 j_mayer
__attribute__ (( unused ))
4226 80d11f44 j_mayer
static void init_proc_e300 (CPUPPCState *env)
4227 3fc6c082 bellard
{
4228 80d11f44 j_mayer
    gen_spr_ne_601(env);
4229 80d11f44 j_mayer
    gen_spr_603(env);
4230 a750fc0b j_mayer
    /* Time base */
4231 a750fc0b j_mayer
    gen_tbl(env);
4232 80d11f44 j_mayer
    /* hardware implementation registers */
4233 80d11f44 j_mayer
    /* XXX : not implemented */
4234 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4235 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4236 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4237 80d11f44 j_mayer
                 0x00000000);
4238 80d11f44 j_mayer
    /* XXX : not implemented */
4239 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4240 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4241 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4242 80d11f44 j_mayer
                 0x00000000);
4243 8daf1781 Thomas Monjalon
    /* XXX : not implemented */
4244 8daf1781 Thomas Monjalon
    spr_register(env, SPR_HID2, "HID2",
4245 8daf1781 Thomas Monjalon
                 SPR_NOACCESS, SPR_NOACCESS,
4246 8daf1781 Thomas Monjalon
                 &spr_read_generic, &spr_write_generic,
4247 8daf1781 Thomas Monjalon
                 0x00000000);
4248 80d11f44 j_mayer
    /* Memory management */
4249 80d11f44 j_mayer
    gen_low_BATs(env);
4250 8daf1781 Thomas Monjalon
    gen_high_BATs(env);
4251 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4252 80d11f44 j_mayer
    init_excp_603(env);
4253 80d11f44 j_mayer
    env->dcache_line_size = 32;
4254 80d11f44 j_mayer
    env->icache_line_size = 32;
4255 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
4256 80d11f44 j_mayer
    ppc6xx_irq_init(env);
4257 80d11f44 j_mayer
}
4258 80d11f44 j_mayer
4259 bd5ea513 aurel32
/* e500v1 core                                                               */
4260 bd5ea513 aurel32
#define POWERPC_INSNS_e500v1   (PPC_INSNS_BASE | PPC_ISEL |             \
4261 bd5ea513 aurel32
                                PPC_SPE | PPC_SPE_SINGLE |              \
4262 bd5ea513 aurel32
                                PPC_WRTEE | PPC_RFDI |                  \
4263 bd5ea513 aurel32
                                PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI | \
4264 bd5ea513 aurel32
                                PPC_CACHE_DCBZ | PPC_CACHE_DCBA |       \
4265 bd5ea513 aurel32
                                PPC_MEM_TLBSYNC | PPC_TLBIVAX |         \
4266 bd5ea513 aurel32
                                PPC_BOOKE)
4267 bd5ea513 aurel32
#define POWERPC_MSRM_e500v1    (0x000000000606FF30ULL)
4268 bd5ea513 aurel32
#define POWERPC_MMU_e500v1     (POWERPC_MMU_BOOKE_FSL)
4269 bd5ea513 aurel32
#define POWERPC_EXCP_e500v1    (POWERPC_EXCP_BOOKE)
4270 bd5ea513 aurel32
#define POWERPC_INPUT_e500v1   (PPC_FLAGS_INPUT_BookE)
4271 bd5ea513 aurel32
#define POWERPC_BFDM_e500v1    (bfd_mach_ppc_860)
4272 bd5ea513 aurel32
#define POWERPC_FLAG_e500v1    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |    \
4273 bd5ea513 aurel32
                                POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |   \
4274 bd5ea513 aurel32
                                POWERPC_FLAG_BUS_CLK)
4275 bd5ea513 aurel32
#define check_pow_e500v1       check_pow_hid0
4276 bd5ea513 aurel32
#define init_proc_e500v1       init_proc_e500
4277 bd5ea513 aurel32
4278 bd5ea513 aurel32
/* e500v2 core                                                               */
4279 bd5ea513 aurel32
#define POWERPC_INSNS_e500v2   (PPC_INSNS_BASE | PPC_ISEL |             \
4280 bd5ea513 aurel32
                                PPC_SPE | PPC_SPE_SINGLE | PPC_SPE_DOUBLE |   \
4281 bd5ea513 aurel32
                                PPC_WRTEE | PPC_RFDI |                  \
4282 bd5ea513 aurel32
                                PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI | \
4283 bd5ea513 aurel32
                                PPC_CACHE_DCBZ | PPC_CACHE_DCBA |       \
4284 bd5ea513 aurel32
                                PPC_MEM_TLBSYNC | PPC_TLBIVAX |         \
4285 bd5ea513 aurel32
                                PPC_BOOKE)
4286 bd5ea513 aurel32
#define POWERPC_MSRM_e500v2    (0x000000000606FF30ULL)
4287 bd5ea513 aurel32
#define POWERPC_MMU_e500v2     (POWERPC_MMU_BOOKE_FSL)
4288 bd5ea513 aurel32
#define POWERPC_EXCP_e500v2    (POWERPC_EXCP_BOOKE)
4289 bd5ea513 aurel32
#define POWERPC_INPUT_e500v2   (PPC_FLAGS_INPUT_BookE)
4290 bd5ea513 aurel32
#define POWERPC_BFDM_e500v2    (bfd_mach_ppc_860)
4291 bd5ea513 aurel32
#define POWERPC_FLAG_e500v2    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |    \
4292 bd5ea513 aurel32
                                POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |   \
4293 bd5ea513 aurel32
                                POWERPC_FLAG_BUS_CLK)
4294 bd5ea513 aurel32
#define check_pow_e500v2       check_pow_hid0
4295 bd5ea513 aurel32
#define init_proc_e500v2       init_proc_e500
4296 80d11f44 j_mayer
4297 80d11f44 j_mayer
static void init_proc_e500 (CPUPPCState *env)
4298 80d11f44 j_mayer
{
4299 80d11f44 j_mayer
    /* Time base */
4300 80d11f44 j_mayer
    gen_tbl(env);
4301 80d11f44 j_mayer
    gen_spr_BookE(env, 0x0000000F0000FD7FULL);
4302 80d11f44 j_mayer
    /* Processor identification */
4303 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
4304 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4305 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
4306 80d11f44 j_mayer
                 0x00000000);
4307 80d11f44 j_mayer
    /* XXX : not implemented */
4308 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_SPEFSCR, "SPEFSCR",
4309 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4310 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4311 80d11f44 j_mayer
                 0x00000000);
4312 80d11f44 j_mayer
    /* Memory management */
4313 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
4314 80d11f44 j_mayer
    env->nb_pids = 3;
4315 80d11f44 j_mayer
#endif
4316 80d11f44 j_mayer
    gen_spr_BookE_FSL(env, 0x0000005F);
4317 80d11f44 j_mayer
    /* XXX : not implemented */
4318 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4319 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4320 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4321 80d11f44 j_mayer
                 0x00000000);
4322 80d11f44 j_mayer
    /* XXX : not implemented */
4323 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4324 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4325 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4326 80d11f44 j_mayer
                 0x00000000);
4327 80d11f44 j_mayer
    /* XXX : not implemented */
4328 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BBEAR, "BBEAR",
4329 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4330 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4331 80d11f44 j_mayer
                 0x00000000);
4332 80d11f44 j_mayer
    /* XXX : not implemented */
4333 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BBTAR, "BBTAR",
4334 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4335 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4336 80d11f44 j_mayer
                 0x00000000);
4337 80d11f44 j_mayer
    /* XXX : not implemented */
4338 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_MCAR, "MCAR",
4339 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4340 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4341 80d11f44 j_mayer
                 0x00000000);
4342 578bb252 j_mayer
    /* XXX : not implemented */
4343 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
4344 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4345 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4346 a750fc0b j_mayer
                 0x00000000);
4347 80d11f44 j_mayer
    /* XXX : not implemented */
4348 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_NPIDR, "NPIDR",
4349 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4350 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4351 a750fc0b j_mayer
                 0x00000000);
4352 80d11f44 j_mayer
    /* XXX : not implemented */
4353 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BUCSR, "BUCSR",
4354 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4355 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4356 a750fc0b j_mayer
                 0x00000000);
4357 578bb252 j_mayer
    /* XXX : not implemented */
4358 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CFG0, "L1CFG0",
4359 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4360 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4361 a750fc0b j_mayer
                 0x00000000);
4362 578bb252 j_mayer
    /* XXX : not implemented */
4363 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR0, "L1CSR0",
4364 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4365 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4366 80d11f44 j_mayer
                 0x00000000);
4367 80d11f44 j_mayer
    /* XXX : not implemented */
4368 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR1, "L1CSR1",
4369 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4370 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4371 80d11f44 j_mayer
                 0x00000000);
4372 80d11f44 j_mayer
    /* XXX : not implemented */
4373 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
4374 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4375 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4376 80d11f44 j_mayer
                 0x00000000);
4377 80d11f44 j_mayer
    /* XXX : not implemented */
4378 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
4379 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4380 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4381 80d11f44 j_mayer
                 0x00000000);
4382 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
4383 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4384 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4385 80d11f44 j_mayer
                 0x00000000);
4386 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
4387 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4388 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4389 a750fc0b j_mayer
                 0x00000000);
4390 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4391 a750fc0b j_mayer
    env->nb_tlb = 64;
4392 a750fc0b j_mayer
    env->nb_ways = 1;
4393 a750fc0b j_mayer
    env->id_tlbs = 0;
4394 f2e63a42 j_mayer
#endif
4395 80d11f44 j_mayer
    init_excp_e200(env);
4396 d63001d1 j_mayer
    env->dcache_line_size = 32;
4397 d63001d1 j_mayer
    env->icache_line_size = 32;
4398 9fdc60bf aurel32
    /* Allocate hardware IRQ controller */
4399 9fdc60bf aurel32
    ppce500_irq_init(env);
4400 3fc6c082 bellard
}
4401 a750fc0b j_mayer
4402 a750fc0b j_mayer
/* Non-embedded PowerPC                                                      */
4403 a750fc0b j_mayer
4404 a750fc0b j_mayer
/* POWER : same as 601, without mfmsr, mfsr                                  */
4405 a750fc0b j_mayer
#if defined(TODO)
4406 a750fc0b j_mayer
#define POWERPC_INSNS_POWER  (XXX_TODO)
4407 a750fc0b j_mayer
/* POWER RSC (from RAD6000) */
4408 a750fc0b j_mayer
#define POWERPC_MSRM_POWER   (0x00000000FEF0ULL)
4409 a750fc0b j_mayer
#endif /* TODO */
4410 a750fc0b j_mayer
4411 a750fc0b j_mayer
/* PowerPC 601                                                               */
4412 082c6681 j_mayer
#define POWERPC_INSNS_601    (PPC_INSNS_BASE | PPC_STRING | PPC_POWER_BR |    \
4413 082c6681 j_mayer
                              PPC_FLOAT |                                     \
4414 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4415 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_MEM_TLBIE |  \
4416 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4417 25ba3a68 j_mayer
#define POWERPC_MSRM_601     (0x000000000000FD70ULL)
4418 082c6681 j_mayer
#define POWERPC_MSRR_601     (0x0000000000001040ULL)
4419 faadf50e j_mayer
//#define POWERPC_MMU_601      (POWERPC_MMU_601)
4420 a750fc0b j_mayer
//#define POWERPC_EXCP_601     (POWERPC_EXCP_601)
4421 a750fc0b j_mayer
#define POWERPC_INPUT_601    (PPC_FLAGS_INPUT_6xx)
4422 237c0af0 j_mayer
#define POWERPC_BFDM_601     (bfd_mach_ppc_601)
4423 4018bae9 j_mayer
#define POWERPC_FLAG_601     (POWERPC_FLAG_SE | POWERPC_FLAG_RTC_CLK)
4424 2f462816 j_mayer
#define check_pow_601        check_pow_none
4425 a750fc0b j_mayer
4426 a750fc0b j_mayer
static void init_proc_601 (CPUPPCState *env)
4427 3fc6c082 bellard
{
4428 a750fc0b j_mayer
    gen_spr_ne_601(env);
4429 a750fc0b j_mayer
    gen_spr_601(env);
4430 a750fc0b j_mayer
    /* Hardware implementation registers */
4431 a750fc0b j_mayer
    /* XXX : not implemented */
4432 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4433 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4434 056401ea j_mayer
                 &spr_read_generic, &spr_write_hid0_601,
4435 faadf50e j_mayer
                 0x80010080);
4436 a750fc0b j_mayer
    /* XXX : not implemented */
4437 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4438 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4439 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4440 a750fc0b j_mayer
                 0x00000000);
4441 a750fc0b j_mayer
    /* XXX : not implemented */
4442 a750fc0b j_mayer
    spr_register(env, SPR_601_HID2, "HID2",
4443 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4444 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4445 a750fc0b j_mayer
                 0x00000000);
4446 a750fc0b j_mayer
    /* XXX : not implemented */
4447 a750fc0b j_mayer
    spr_register(env, SPR_601_HID5, "HID5",
4448 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4449 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4450 a750fc0b j_mayer
                 0x00000000);
4451 a750fc0b j_mayer
    /* Memory management */
4452 e1833e1f j_mayer
    init_excp_601(env);
4453 082c6681 j_mayer
    /* XXX: beware that dcache line size is 64 
4454 082c6681 j_mayer
     *      but dcbz uses 32 bytes "sectors"
4455 082c6681 j_mayer
     * XXX: this breaks clcs instruction !
4456 082c6681 j_mayer
     */
4457 082c6681 j_mayer
    env->dcache_line_size = 32;
4458 d63001d1 j_mayer
    env->icache_line_size = 64;
4459 faadf50e j_mayer
    /* Allocate hardware IRQ controller */
4460 faadf50e j_mayer
    ppc6xx_irq_init(env);
4461 3fc6c082 bellard
}
4462 3fc6c082 bellard
4463 082c6681 j_mayer
/* PowerPC 601v                                                              */
4464 082c6681 j_mayer
#define POWERPC_INSNS_601v   (PPC_INSNS_BASE | PPC_STRING | PPC_POWER_BR |    \
4465 082c6681 j_mayer
                              PPC_FLOAT |                                     \
4466 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4467 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_MEM_TLBIE |  \
4468 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4469 082c6681 j_mayer
#define POWERPC_MSRM_601v    (0x000000000000FD70ULL)
4470 082c6681 j_mayer
#define POWERPC_MSRR_601v    (0x0000000000001040ULL)
4471 082c6681 j_mayer
#define POWERPC_MMU_601v     (POWERPC_MMU_601)
4472 082c6681 j_mayer
#define POWERPC_EXCP_601v    (POWERPC_EXCP_601)
4473 082c6681 j_mayer
#define POWERPC_INPUT_601v   (PPC_FLAGS_INPUT_6xx)
4474 082c6681 j_mayer
#define POWERPC_BFDM_601v    (bfd_mach_ppc_601)
4475 082c6681 j_mayer
#define POWERPC_FLAG_601v    (POWERPC_FLAG_SE | POWERPC_FLAG_RTC_CLK)
4476 082c6681 j_mayer
#define check_pow_601v       check_pow_none
4477 082c6681 j_mayer
4478 082c6681 j_mayer
static void init_proc_601v (CPUPPCState *env)
4479 082c6681 j_mayer
{
4480 082c6681 j_mayer
    init_proc_601(env);
4481 082c6681 j_mayer
    /* XXX : not implemented */
4482 082c6681 j_mayer
    spr_register(env, SPR_601_HID15, "HID15",
4483 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4484 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4485 082c6681 j_mayer
                 0x00000000);
4486 082c6681 j_mayer
}
4487 082c6681 j_mayer
4488 a750fc0b j_mayer
/* PowerPC 602                                                               */
4489 082c6681 j_mayer
#define POWERPC_INSNS_602    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4490 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4491 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4492 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4493 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4494 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_6xx_TLB | PPC_MEM_TLBSYNC | \
4495 12de9a39 j_mayer
                              PPC_SEGMENT | PPC_602_SPEC)
4496 082c6681 j_mayer
#define POWERPC_MSRM_602     (0x0000000000C7FF73ULL)
4497 082c6681 j_mayer
/* XXX: 602 MMU is quite specific. Should add a special case */
4498 a750fc0b j_mayer
#define POWERPC_MMU_602      (POWERPC_MMU_SOFT_6xx)
4499 a750fc0b j_mayer
//#define POWERPC_EXCP_602     (POWERPC_EXCP_602)
4500 a750fc0b j_mayer
#define POWERPC_INPUT_602    (PPC_FLAGS_INPUT_6xx)
4501 237c0af0 j_mayer
#define POWERPC_BFDM_602     (bfd_mach_ppc_602)
4502 25ba3a68 j_mayer
#define POWERPC_FLAG_602     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4503 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4504 2f462816 j_mayer
#define check_pow_602        check_pow_hid0
4505 a750fc0b j_mayer
4506 a750fc0b j_mayer
static void init_proc_602 (CPUPPCState *env)
4507 3fc6c082 bellard
{
4508 a750fc0b j_mayer
    gen_spr_ne_601(env);
4509 a750fc0b j_mayer
    gen_spr_602(env);
4510 a750fc0b j_mayer
    /* Time base */
4511 a750fc0b j_mayer
    gen_tbl(env);
4512 a750fc0b j_mayer
    /* hardware implementation registers */
4513 a750fc0b j_mayer
    /* XXX : not implemented */
4514 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4515 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4516 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4517 a750fc0b j_mayer
                 0x00000000);
4518 a750fc0b j_mayer
    /* XXX : not implemented */
4519 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4520 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4521 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4522 a750fc0b j_mayer
                 0x00000000);
4523 a750fc0b j_mayer
    /* Memory management */
4524 a750fc0b j_mayer
    gen_low_BATs(env);
4525 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4526 e1833e1f j_mayer
    init_excp_602(env);
4527 d63001d1 j_mayer
    env->dcache_line_size = 32;
4528 d63001d1 j_mayer
    env->icache_line_size = 32;
4529 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4530 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4531 a750fc0b j_mayer
}
4532 3fc6c082 bellard
4533 a750fc0b j_mayer
/* PowerPC 603                                                               */
4534 082c6681 j_mayer
#define POWERPC_INSNS_603    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4535 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4536 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4537 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4538 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4539 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4540 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4541 25ba3a68 j_mayer
#define POWERPC_MSRM_603     (0x000000000007FF73ULL)
4542 a750fc0b j_mayer
#define POWERPC_MMU_603      (POWERPC_MMU_SOFT_6xx)
4543 a750fc0b j_mayer
//#define POWERPC_EXCP_603     (POWERPC_EXCP_603)
4544 a750fc0b j_mayer
#define POWERPC_INPUT_603    (PPC_FLAGS_INPUT_6xx)
4545 237c0af0 j_mayer
#define POWERPC_BFDM_603     (bfd_mach_ppc_603)
4546 25ba3a68 j_mayer
#define POWERPC_FLAG_603     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4547 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4548 2f462816 j_mayer
#define check_pow_603        check_pow_hid0
4549 a750fc0b j_mayer
4550 a750fc0b j_mayer
static void init_proc_603 (CPUPPCState *env)
4551 a750fc0b j_mayer
{
4552 a750fc0b j_mayer
    gen_spr_ne_601(env);
4553 a750fc0b j_mayer
    gen_spr_603(env);
4554 a750fc0b j_mayer
    /* Time base */
4555 a750fc0b j_mayer
    gen_tbl(env);
4556 a750fc0b j_mayer
    /* hardware implementation registers */
4557 a750fc0b j_mayer
    /* XXX : not implemented */
4558 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4559 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4560 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4561 a750fc0b j_mayer
                 0x00000000);
4562 a750fc0b j_mayer
    /* XXX : not implemented */
4563 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4564 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4565 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4566 a750fc0b j_mayer
                 0x00000000);
4567 a750fc0b j_mayer
    /* Memory management */
4568 a750fc0b j_mayer
    gen_low_BATs(env);
4569 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4570 e1833e1f j_mayer
    init_excp_603(env);
4571 d63001d1 j_mayer
    env->dcache_line_size = 32;
4572 d63001d1 j_mayer
    env->icache_line_size = 32;
4573 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4574 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4575 3fc6c082 bellard
}
4576 3fc6c082 bellard
4577 a750fc0b j_mayer
/* PowerPC 603e                                                              */
4578 082c6681 j_mayer
#define POWERPC_INSNS_603E   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4579 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4580 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4581 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4582 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4583 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4584 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4585 a750fc0b j_mayer
#define POWERPC_MSRM_603E    (0x000000000007FF73ULL)
4586 a750fc0b j_mayer
#define POWERPC_MMU_603E     (POWERPC_MMU_SOFT_6xx)
4587 a750fc0b j_mayer
//#define POWERPC_EXCP_603E    (POWERPC_EXCP_603E)
4588 a750fc0b j_mayer
#define POWERPC_INPUT_603E   (PPC_FLAGS_INPUT_6xx)
4589 237c0af0 j_mayer
#define POWERPC_BFDM_603E    (bfd_mach_ppc_ec603e)
4590 25ba3a68 j_mayer
#define POWERPC_FLAG_603E    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4591 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4592 2f462816 j_mayer
#define check_pow_603E       check_pow_hid0
4593 a750fc0b j_mayer
4594 a750fc0b j_mayer
static void init_proc_603E (CPUPPCState *env)
4595 a750fc0b j_mayer
{
4596 a750fc0b j_mayer
    gen_spr_ne_601(env);
4597 a750fc0b j_mayer
    gen_spr_603(env);
4598 a750fc0b j_mayer
    /* Time base */
4599 a750fc0b j_mayer
    gen_tbl(env);
4600 a750fc0b j_mayer
    /* hardware implementation registers */
4601 a750fc0b j_mayer
    /* XXX : not implemented */
4602 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4603 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4604 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4605 a750fc0b j_mayer
                 0x00000000);
4606 a750fc0b j_mayer
    /* XXX : not implemented */
4607 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4608 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4609 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4610 a750fc0b j_mayer
                 0x00000000);
4611 a750fc0b j_mayer
    /* XXX : not implemented */
4612 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
4613 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4614 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4615 a750fc0b j_mayer
                 0x00000000);
4616 a750fc0b j_mayer
    /* Memory management */
4617 a750fc0b j_mayer
    gen_low_BATs(env);
4618 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4619 e1833e1f j_mayer
    init_excp_603(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 a750fc0b j_mayer
/* PowerPC 604                                                               */
4627 082c6681 j_mayer
#define POWERPC_INSNS_604    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4628 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4629 082c6681 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 a750fc0b j_mayer
#define POWERPC_MSRM_604     (0x000000000005FF77ULL)
4635 a750fc0b j_mayer
#define POWERPC_MMU_604      (POWERPC_MMU_32B)
4636 a750fc0b j_mayer
//#define POWERPC_EXCP_604     (POWERPC_EXCP_604)
4637 a750fc0b j_mayer
#define POWERPC_INPUT_604    (PPC_FLAGS_INPUT_6xx)
4638 237c0af0 j_mayer
#define POWERPC_BFDM_604     (bfd_mach_ppc_604)
4639 25ba3a68 j_mayer
#define POWERPC_FLAG_604     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4640 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4641 2f462816 j_mayer
#define check_pow_604        check_pow_nocheck
4642 a750fc0b j_mayer
4643 a750fc0b j_mayer
static void init_proc_604 (CPUPPCState *env)
4644 a750fc0b j_mayer
{
4645 a750fc0b j_mayer
    gen_spr_ne_601(env);
4646 a750fc0b j_mayer
    gen_spr_604(env);
4647 a750fc0b j_mayer
    /* Time base */
4648 a750fc0b j_mayer
    gen_tbl(env);
4649 a750fc0b j_mayer
    /* Hardware implementation registers */
4650 a750fc0b j_mayer
    /* XXX : not implemented */
4651 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4652 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4653 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4654 a750fc0b j_mayer
                 0x00000000);
4655 082c6681 j_mayer
    /* Memory management */
4656 082c6681 j_mayer
    gen_low_BATs(env);
4657 082c6681 j_mayer
    init_excp_604(env);
4658 082c6681 j_mayer
    env->dcache_line_size = 32;
4659 082c6681 j_mayer
    env->icache_line_size = 32;
4660 082c6681 j_mayer
    /* Allocate hardware IRQ controller */
4661 082c6681 j_mayer
    ppc6xx_irq_init(env);
4662 082c6681 j_mayer
}
4663 082c6681 j_mayer
4664 082c6681 j_mayer
/* PowerPC 604E                                                              */
4665 082c6681 j_mayer
#define POWERPC_INSNS_604E   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4666 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4667 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4668 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4669 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4670 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4671 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4672 082c6681 j_mayer
#define POWERPC_MSRM_604E    (0x000000000005FF77ULL)
4673 082c6681 j_mayer
#define POWERPC_MMU_604E     (POWERPC_MMU_32B)
4674 082c6681 j_mayer
#define POWERPC_EXCP_604E    (POWERPC_EXCP_604)
4675 082c6681 j_mayer
#define POWERPC_INPUT_604E   (PPC_FLAGS_INPUT_6xx)
4676 082c6681 j_mayer
#define POWERPC_BFDM_604E    (bfd_mach_ppc_604)
4677 082c6681 j_mayer
#define POWERPC_FLAG_604E    (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4678 082c6681 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4679 082c6681 j_mayer
#define check_pow_604E       check_pow_nocheck
4680 082c6681 j_mayer
4681 082c6681 j_mayer
static void init_proc_604E (CPUPPCState *env)
4682 082c6681 j_mayer
{
4683 082c6681 j_mayer
    gen_spr_ne_601(env);
4684 082c6681 j_mayer
    gen_spr_604(env);
4685 082c6681 j_mayer
    /* XXX : not implemented */
4686 082c6681 j_mayer
    spr_register(env, SPR_MMCR1, "MMCR1",
4687 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4688 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4689 082c6681 j_mayer
                 0x00000000);
4690 082c6681 j_mayer
    /* XXX : not implemented */
4691 082c6681 j_mayer
    spr_register(env, SPR_PMC3, "PMC3",
4692 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4693 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4694 082c6681 j_mayer
                 0x00000000);
4695 082c6681 j_mayer
    /* XXX : not implemented */
4696 082c6681 j_mayer
    spr_register(env, SPR_PMC4, "PMC4",
4697 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4698 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4699 082c6681 j_mayer
                 0x00000000);
4700 082c6681 j_mayer
    /* Time base */
4701 082c6681 j_mayer
    gen_tbl(env);
4702 082c6681 j_mayer
    /* Hardware implementation registers */
4703 082c6681 j_mayer
    /* XXX : not implemented */
4704 082c6681 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4705 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4706 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4707 082c6681 j_mayer
                 0x00000000);
4708 a750fc0b j_mayer
    /* XXX : not implemented */
4709 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4710 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4711 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4712 a750fc0b j_mayer
                 0x00000000);
4713 a750fc0b j_mayer
    /* Memory management */
4714 a750fc0b j_mayer
    gen_low_BATs(env);
4715 e1833e1f j_mayer
    init_excp_604(env);
4716 d63001d1 j_mayer
    env->dcache_line_size = 32;
4717 d63001d1 j_mayer
    env->icache_line_size = 32;
4718 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4719 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4720 a750fc0b j_mayer
}
4721 a750fc0b j_mayer
4722 bd928eba j_mayer
/* PowerPC 740                                                               */
4723 bd928eba j_mayer
#define POWERPC_INSNS_740    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4724 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4725 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4726 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4727 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4728 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4729 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4730 bd928eba j_mayer
#define POWERPC_MSRM_740     (0x000000000005FF77ULL)
4731 bd928eba j_mayer
#define POWERPC_MMU_740      (POWERPC_MMU_32B)
4732 bd928eba j_mayer
#define POWERPC_EXCP_740     (POWERPC_EXCP_7x0)
4733 bd928eba j_mayer
#define POWERPC_INPUT_740    (PPC_FLAGS_INPUT_6xx)
4734 bd928eba j_mayer
#define POWERPC_BFDM_740     (bfd_mach_ppc_750)
4735 bd928eba j_mayer
#define POWERPC_FLAG_740     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4736 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4737 bd928eba j_mayer
#define check_pow_740        check_pow_hid0
4738 a750fc0b j_mayer
4739 bd928eba j_mayer
static void init_proc_740 (CPUPPCState *env)
4740 a750fc0b j_mayer
{
4741 a750fc0b j_mayer
    gen_spr_ne_601(env);
4742 a750fc0b j_mayer
    gen_spr_7xx(env);
4743 a750fc0b j_mayer
    /* Time base */
4744 a750fc0b j_mayer
    gen_tbl(env);
4745 a750fc0b j_mayer
    /* Thermal management */
4746 a750fc0b j_mayer
    gen_spr_thrm(env);
4747 a750fc0b j_mayer
    /* Hardware implementation registers */
4748 a750fc0b j_mayer
    /* XXX : not implemented */
4749 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4750 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4751 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4752 a750fc0b j_mayer
                 0x00000000);
4753 a750fc0b j_mayer
    /* XXX : not implemented */
4754 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4755 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4756 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4757 a750fc0b j_mayer
                 0x00000000);
4758 a750fc0b j_mayer
    /* Memory management */
4759 a750fc0b j_mayer
    gen_low_BATs(env);
4760 e1833e1f j_mayer
    init_excp_7x0(env);
4761 d63001d1 j_mayer
    env->dcache_line_size = 32;
4762 d63001d1 j_mayer
    env->icache_line_size = 32;
4763 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4764 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4765 a750fc0b j_mayer
}
4766 a750fc0b j_mayer
4767 bd928eba j_mayer
/* PowerPC 750                                                               */
4768 bd928eba j_mayer
#define POWERPC_INSNS_750    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4769 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4770 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4771 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4772 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4773 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4774 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4775 bd928eba j_mayer
#define POWERPC_MSRM_750     (0x000000000005FF77ULL)
4776 bd928eba j_mayer
#define POWERPC_MMU_750      (POWERPC_MMU_32B)
4777 bd928eba j_mayer
#define POWERPC_EXCP_750     (POWERPC_EXCP_7x0)
4778 bd928eba j_mayer
#define POWERPC_INPUT_750    (PPC_FLAGS_INPUT_6xx)
4779 bd928eba j_mayer
#define POWERPC_BFDM_750     (bfd_mach_ppc_750)
4780 bd928eba j_mayer
#define POWERPC_FLAG_750     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4781 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4782 bd928eba j_mayer
#define check_pow_750        check_pow_hid0
4783 bd928eba j_mayer
4784 bd928eba j_mayer
static void init_proc_750 (CPUPPCState *env)
4785 bd928eba j_mayer
{
4786 bd928eba j_mayer
    gen_spr_ne_601(env);
4787 bd928eba j_mayer
    gen_spr_7xx(env);
4788 bd928eba j_mayer
    /* XXX : not implemented */
4789 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
4790 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4791 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4792 bd928eba j_mayer
                 0x00000000);
4793 bd928eba j_mayer
    /* Time base */
4794 bd928eba j_mayer
    gen_tbl(env);
4795 bd928eba j_mayer
    /* Thermal management */
4796 bd928eba j_mayer
    gen_spr_thrm(env);
4797 bd928eba j_mayer
    /* Hardware implementation registers */
4798 bd928eba j_mayer
    /* XXX : not implemented */
4799 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
4800 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4801 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4802 bd928eba j_mayer
                 0x00000000);
4803 bd928eba j_mayer
    /* XXX : not implemented */
4804 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
4805 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4806 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4807 bd928eba j_mayer
                 0x00000000);
4808 bd928eba j_mayer
    /* Memory management */
4809 bd928eba j_mayer
    gen_low_BATs(env);
4810 bd928eba j_mayer
    /* XXX: high BATs are also present but are known to be bugged on
4811 bd928eba j_mayer
     *      die version 1.x
4812 bd928eba j_mayer
     */
4813 bd928eba j_mayer
    init_excp_7x0(env);
4814 bd928eba j_mayer
    env->dcache_line_size = 32;
4815 bd928eba j_mayer
    env->icache_line_size = 32;
4816 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
4817 bd928eba j_mayer
    ppc6xx_irq_init(env);
4818 bd928eba j_mayer
}
4819 bd928eba j_mayer
4820 bd928eba j_mayer
/* PowerPC 750 CL                                                            */
4821 bd928eba j_mayer
/* XXX: not implemented:
4822 bd928eba j_mayer
 * cache lock instructions:
4823 bd928eba j_mayer
 * dcbz_l
4824 bd928eba j_mayer
 * floating point paired instructions
4825 bd928eba j_mayer
 * psq_lux
4826 bd928eba j_mayer
 * psq_lx
4827 bd928eba j_mayer
 * psq_stux
4828 bd928eba j_mayer
 * psq_stx
4829 bd928eba j_mayer
 * ps_abs
4830 bd928eba j_mayer
 * ps_add
4831 bd928eba j_mayer
 * ps_cmpo0
4832 bd928eba j_mayer
 * ps_cmpo1
4833 bd928eba j_mayer
 * ps_cmpu0
4834 bd928eba j_mayer
 * ps_cmpu1
4835 bd928eba j_mayer
 * ps_div
4836 bd928eba j_mayer
 * ps_madd
4837 bd928eba j_mayer
 * ps_madds0
4838 bd928eba j_mayer
 * ps_madds1
4839 bd928eba j_mayer
 * ps_merge00
4840 bd928eba j_mayer
 * ps_merge01
4841 bd928eba j_mayer
 * ps_merge10
4842 bd928eba j_mayer
 * ps_merge11
4843 bd928eba j_mayer
 * ps_mr
4844 bd928eba j_mayer
 * ps_msub
4845 bd928eba j_mayer
 * ps_mul
4846 bd928eba j_mayer
 * ps_muls0
4847 bd928eba j_mayer
 * ps_muls1
4848 bd928eba j_mayer
 * ps_nabs
4849 bd928eba j_mayer
 * ps_neg
4850 bd928eba j_mayer
 * ps_nmadd
4851 bd928eba j_mayer
 * ps_nmsub
4852 bd928eba j_mayer
 * ps_res
4853 bd928eba j_mayer
 * ps_rsqrte
4854 bd928eba j_mayer
 * ps_sel
4855 bd928eba j_mayer
 * ps_sub
4856 bd928eba j_mayer
 * ps_sum0
4857 bd928eba j_mayer
 * ps_sum1
4858 bd928eba j_mayer
 */
4859 bd928eba j_mayer
#define POWERPC_INSNS_750cl  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4860 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4861 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4862 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4863 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4864 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4865 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4866 bd928eba j_mayer
#define POWERPC_MSRM_750cl   (0x000000000005FF77ULL)
4867 bd928eba j_mayer
#define POWERPC_MMU_750cl    (POWERPC_MMU_32B)
4868 bd928eba j_mayer
#define POWERPC_EXCP_750cl   (POWERPC_EXCP_7x0)
4869 bd928eba j_mayer
#define POWERPC_INPUT_750cl  (PPC_FLAGS_INPUT_6xx)
4870 bd928eba j_mayer
#define POWERPC_BFDM_750cl   (bfd_mach_ppc_750)
4871 bd928eba j_mayer
#define POWERPC_FLAG_750cl   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4872 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4873 bd928eba j_mayer
#define check_pow_750cl      check_pow_hid0
4874 bd928eba j_mayer
4875 bd928eba j_mayer
static void init_proc_750cl (CPUPPCState *env)
4876 bd928eba j_mayer
{
4877 bd928eba j_mayer
    gen_spr_ne_601(env);
4878 bd928eba j_mayer
    gen_spr_7xx(env);
4879 bd928eba j_mayer
    /* XXX : not implemented */
4880 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
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
    /* Time base */
4885 bd928eba j_mayer
    gen_tbl(env);
4886 bd928eba j_mayer
    /* Thermal management */
4887 bd928eba j_mayer
    /* Those registers are fake on 750CL */
4888 bd928eba j_mayer
    spr_register(env, SPR_THRM1, "THRM1",
4889 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4890 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4891 bd928eba j_mayer
                 0x00000000);
4892 bd928eba j_mayer
    spr_register(env, SPR_THRM2, "THRM2",
4893 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4894 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4895 bd928eba j_mayer
                 0x00000000);
4896 bd928eba j_mayer
    spr_register(env, SPR_THRM3, "THRM3",
4897 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4898 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4899 bd928eba j_mayer
                 0x00000000);
4900 bd928eba j_mayer
    /* XXX: not implemented */
4901 bd928eba j_mayer
    spr_register(env, SPR_750_TDCL, "TDCL",
4902 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4903 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4904 bd928eba j_mayer
                 0x00000000);
4905 bd928eba j_mayer
    spr_register(env, SPR_750_TDCH, "TDCH",
4906 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4907 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4908 bd928eba j_mayer
                 0x00000000);
4909 bd928eba j_mayer
    /* DMA */
4910 bd928eba j_mayer
    /* XXX : not implemented */
4911 bd928eba j_mayer
    spr_register(env, SPR_750_WPAR, "WPAR",
4912 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4913 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4914 bd928eba j_mayer
                 0x00000000);
4915 bd928eba j_mayer
    spr_register(env, SPR_750_DMAL, "DMAL",
4916 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4917 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4918 bd928eba j_mayer
                 0x00000000);
4919 bd928eba j_mayer
    spr_register(env, SPR_750_DMAU, "DMAU",
4920 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4921 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4922 bd928eba j_mayer
                 0x00000000);
4923 bd928eba j_mayer
    /* Hardware implementation registers */
4924 bd928eba j_mayer
    /* XXX : not implemented */
4925 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
4926 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4927 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4928 bd928eba j_mayer
                 0x00000000);
4929 bd928eba j_mayer
    /* XXX : not implemented */
4930 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
4931 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4932 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4933 bd928eba j_mayer
                 0x00000000);
4934 bd928eba j_mayer
    /* XXX : not implemented */
4935 bd928eba j_mayer
    spr_register(env, SPR_750CL_HID2, "HID2",
4936 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4937 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4938 bd928eba j_mayer
                 0x00000000);
4939 bd928eba j_mayer
    /* XXX : not implemented */
4940 bd928eba j_mayer
    spr_register(env, SPR_750CL_HID4, "HID4",
4941 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4942 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4943 bd928eba j_mayer
                 0x00000000);
4944 bd928eba j_mayer
    /* Quantization registers */
4945 bd928eba j_mayer
    /* XXX : not implemented */
4946 bd928eba j_mayer
    spr_register(env, SPR_750_GQR0, "GQR0",
4947 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4948 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4949 bd928eba j_mayer
                 0x00000000);
4950 bd928eba j_mayer
    /* XXX : not implemented */
4951 bd928eba j_mayer
    spr_register(env, SPR_750_GQR1, "GQR1",
4952 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4953 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4954 bd928eba j_mayer
                 0x00000000);
4955 bd928eba j_mayer
    /* XXX : not implemented */
4956 bd928eba j_mayer
    spr_register(env, SPR_750_GQR2, "GQR2",
4957 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4958 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4959 bd928eba j_mayer
                 0x00000000);
4960 bd928eba j_mayer
    /* XXX : not implemented */
4961 bd928eba j_mayer
    spr_register(env, SPR_750_GQR3, "GQR3",
4962 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4963 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4964 bd928eba j_mayer
                 0x00000000);
4965 bd928eba j_mayer
    /* XXX : not implemented */
4966 bd928eba j_mayer
    spr_register(env, SPR_750_GQR4, "GQR4",
4967 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4968 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4969 bd928eba j_mayer
                 0x00000000);
4970 bd928eba j_mayer
    /* XXX : not implemented */
4971 bd928eba j_mayer
    spr_register(env, SPR_750_GQR5, "GQR5",
4972 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4973 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4974 bd928eba j_mayer
                 0x00000000);
4975 bd928eba j_mayer
    /* XXX : not implemented */
4976 bd928eba j_mayer
    spr_register(env, SPR_750_GQR6, "GQR6",
4977 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4978 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4979 bd928eba j_mayer
                 0x00000000);
4980 bd928eba j_mayer
    /* XXX : not implemented */
4981 bd928eba j_mayer
    spr_register(env, SPR_750_GQR7, "GQR7",
4982 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4983 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4984 bd928eba j_mayer
                 0x00000000);
4985 bd928eba j_mayer
    /* Memory management */
4986 bd928eba j_mayer
    gen_low_BATs(env);
4987 bd928eba j_mayer
    /* PowerPC 750cl has 8 DBATs and 8 IBATs */
4988 bd928eba j_mayer
    gen_high_BATs(env);
4989 bd928eba j_mayer
    init_excp_750cl(env);
4990 bd928eba j_mayer
    env->dcache_line_size = 32;
4991 bd928eba j_mayer
    env->icache_line_size = 32;
4992 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
4993 bd928eba j_mayer
    ppc6xx_irq_init(env);
4994 bd928eba j_mayer
}
4995 bd928eba j_mayer
4996 4e777442 j_mayer
/* PowerPC 750CX                                                             */
4997 bd928eba j_mayer
#define POWERPC_INSNS_750cx  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4998 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4999 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5000 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5001 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5002 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5003 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
5004 bd928eba j_mayer
#define POWERPC_MSRM_750cx   (0x000000000005FF77ULL)
5005 bd928eba j_mayer
#define POWERPC_MMU_750cx    (POWERPC_MMU_32B)
5006 bd928eba j_mayer
#define POWERPC_EXCP_750cx   (POWERPC_EXCP_7x0)
5007 bd928eba j_mayer
#define POWERPC_INPUT_750cx  (PPC_FLAGS_INPUT_6xx)
5008 bd928eba j_mayer
#define POWERPC_BFDM_750cx   (bfd_mach_ppc_750)
5009 bd928eba j_mayer
#define POWERPC_FLAG_750cx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5010 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5011 bd928eba j_mayer
#define check_pow_750cx      check_pow_hid0
5012 bd928eba j_mayer
5013 bd928eba j_mayer
static void init_proc_750cx (CPUPPCState *env)
5014 bd928eba j_mayer
{
5015 bd928eba j_mayer
    gen_spr_ne_601(env);
5016 bd928eba j_mayer
    gen_spr_7xx(env);
5017 bd928eba j_mayer
    /* XXX : not implemented */
5018 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5019 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5020 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5021 bd928eba j_mayer
                 0x00000000);
5022 bd928eba j_mayer
    /* Time base */
5023 bd928eba j_mayer
    gen_tbl(env);
5024 bd928eba j_mayer
    /* Thermal management */
5025 bd928eba j_mayer
    gen_spr_thrm(env);
5026 bd928eba j_mayer
    /* This register is not implemented but is present for compatibility */
5027 bd928eba j_mayer
    spr_register(env, SPR_SDA, "SDA",
5028 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5029 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5030 bd928eba j_mayer
                 0x00000000);
5031 bd928eba j_mayer
    /* Hardware implementation registers */
5032 bd928eba j_mayer
    /* XXX : not implemented */
5033 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
5034 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5035 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5036 bd928eba j_mayer
                 0x00000000);
5037 bd928eba j_mayer
    /* XXX : not implemented */
5038 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5039 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5040 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5041 bd928eba j_mayer
                 0x00000000);
5042 bd928eba j_mayer
    /* Memory management */
5043 bd928eba j_mayer
    gen_low_BATs(env);
5044 4e777442 j_mayer
    /* PowerPC 750cx has 8 DBATs and 8 IBATs */
5045 4e777442 j_mayer
    gen_high_BATs(env);
5046 bd928eba j_mayer
    init_excp_750cx(env);
5047 bd928eba j_mayer
    env->dcache_line_size = 32;
5048 bd928eba j_mayer
    env->icache_line_size = 32;
5049 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5050 bd928eba j_mayer
    ppc6xx_irq_init(env);
5051 bd928eba j_mayer
}
5052 bd928eba j_mayer
5053 bd928eba j_mayer
/* PowerPC 750FX                                                             */
5054 082c6681 j_mayer
#define POWERPC_INSNS_750fx  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5055 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5056 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5057 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5058 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5059 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5060 082c6681 j_mayer
                              PPC_SEGMENT  | PPC_EXTERN)
5061 25ba3a68 j_mayer
#define POWERPC_MSRM_750fx   (0x000000000005FF77ULL)
5062 a750fc0b j_mayer
#define POWERPC_MMU_750fx    (POWERPC_MMU_32B)
5063 a750fc0b j_mayer
#define POWERPC_EXCP_750fx   (POWERPC_EXCP_7x0)
5064 a750fc0b j_mayer
#define POWERPC_INPUT_750fx  (PPC_FLAGS_INPUT_6xx)
5065 237c0af0 j_mayer
#define POWERPC_BFDM_750fx   (bfd_mach_ppc_750)
5066 25ba3a68 j_mayer
#define POWERPC_FLAG_750fx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5067 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5068 2f462816 j_mayer
#define check_pow_750fx      check_pow_hid0
5069 a750fc0b j_mayer
5070 a750fc0b j_mayer
static void init_proc_750fx (CPUPPCState *env)
5071 a750fc0b j_mayer
{
5072 a750fc0b j_mayer
    gen_spr_ne_601(env);
5073 a750fc0b j_mayer
    gen_spr_7xx(env);
5074 bd928eba j_mayer
    /* XXX : not implemented */
5075 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5076 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5077 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5078 bd928eba j_mayer
                 0x00000000);
5079 a750fc0b j_mayer
    /* Time base */
5080 a750fc0b j_mayer
    gen_tbl(env);
5081 a750fc0b j_mayer
    /* Thermal management */
5082 a750fc0b j_mayer
    gen_spr_thrm(env);
5083 bd928eba j_mayer
    /* XXX : not implemented */
5084 bd928eba j_mayer
    spr_register(env, SPR_750_THRM4, "THRM4",
5085 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5086 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5087 bd928eba j_mayer
                 0x00000000);
5088 a750fc0b j_mayer
    /* Hardware implementation registers */
5089 a750fc0b j_mayer
    /* XXX : not implemented */
5090 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5091 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5092 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5093 a750fc0b j_mayer
                 0x00000000);
5094 a750fc0b j_mayer
    /* XXX : not implemented */
5095 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
5096 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5097 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5098 a750fc0b j_mayer
                 0x00000000);
5099 a750fc0b j_mayer
    /* XXX : not implemented */
5100 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
5101 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5102 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5103 a750fc0b j_mayer
                 0x00000000);
5104 a750fc0b j_mayer
    /* Memory management */
5105 a750fc0b j_mayer
    gen_low_BATs(env);
5106 a750fc0b j_mayer
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
5107 a750fc0b j_mayer
    gen_high_BATs(env);
5108 bd928eba j_mayer
    init_excp_7x0(env);
5109 d63001d1 j_mayer
    env->dcache_line_size = 32;
5110 d63001d1 j_mayer
    env->icache_line_size = 32;
5111 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5112 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5113 a750fc0b j_mayer
}
5114 a750fc0b j_mayer
5115 bd928eba j_mayer
/* PowerPC 750GX                                                             */
5116 bd928eba j_mayer
#define POWERPC_INSNS_750gx  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5117 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5118 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5119 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5120 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5121 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5122 bd928eba j_mayer
                              PPC_SEGMENT  | PPC_EXTERN)
5123 bd928eba j_mayer
#define POWERPC_MSRM_750gx   (0x000000000005FF77ULL)
5124 bd928eba j_mayer
#define POWERPC_MMU_750gx    (POWERPC_MMU_32B)
5125 bd928eba j_mayer
#define POWERPC_EXCP_750gx   (POWERPC_EXCP_7x0)
5126 bd928eba j_mayer
#define POWERPC_INPUT_750gx  (PPC_FLAGS_INPUT_6xx)
5127 bd928eba j_mayer
#define POWERPC_BFDM_750gx   (bfd_mach_ppc_750)
5128 bd928eba j_mayer
#define POWERPC_FLAG_750gx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5129 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5130 bd928eba j_mayer
#define check_pow_750gx      check_pow_hid0
5131 bd928eba j_mayer
5132 bd928eba j_mayer
static void init_proc_750gx (CPUPPCState *env)
5133 bd928eba j_mayer
{
5134 bd928eba j_mayer
    gen_spr_ne_601(env);
5135 bd928eba j_mayer
    gen_spr_7xx(env);
5136 bd928eba j_mayer
    /* XXX : not implemented (XXX: different from 750fx) */
5137 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5138 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5139 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5140 bd928eba j_mayer
                 0x00000000);
5141 bd928eba j_mayer
    /* Time base */
5142 bd928eba j_mayer
    gen_tbl(env);
5143 bd928eba j_mayer
    /* Thermal management */
5144 bd928eba j_mayer
    gen_spr_thrm(env);
5145 bd928eba j_mayer
    /* XXX : not implemented */
5146 bd928eba j_mayer
    spr_register(env, SPR_750_THRM4, "THRM4",
5147 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5148 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5149 bd928eba j_mayer
                 0x00000000);
5150 bd928eba j_mayer
    /* Hardware implementation registers */
5151 bd928eba j_mayer
    /* XXX : not implemented (XXX: different from 750fx) */
5152 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
5153 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5154 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5155 bd928eba j_mayer
                 0x00000000);
5156 bd928eba j_mayer
    /* XXX : not implemented */
5157 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5158 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5159 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5160 bd928eba j_mayer
                 0x00000000);
5161 bd928eba j_mayer
    /* XXX : not implemented (XXX: different from 750fx) */
5162 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
5163 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5164 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5165 bd928eba j_mayer
                 0x00000000);
5166 bd928eba j_mayer
    /* Memory management */
5167 bd928eba j_mayer
    gen_low_BATs(env);
5168 bd928eba j_mayer
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
5169 bd928eba j_mayer
    gen_high_BATs(env);
5170 bd928eba j_mayer
    init_excp_7x0(env);
5171 bd928eba j_mayer
    env->dcache_line_size = 32;
5172 bd928eba j_mayer
    env->icache_line_size = 32;
5173 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5174 bd928eba j_mayer
    ppc6xx_irq_init(env);
5175 bd928eba j_mayer
}
5176 bd928eba j_mayer
5177 bd928eba j_mayer
/* PowerPC 745                                                               */
5178 bd928eba j_mayer
#define POWERPC_INSNS_745    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5179 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5180 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5181 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5182 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5183 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
5184 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
5185 bd928eba j_mayer
#define POWERPC_MSRM_745     (0x000000000005FF77ULL)
5186 bd928eba j_mayer
#define POWERPC_MMU_745      (POWERPC_MMU_SOFT_6xx)
5187 bd928eba j_mayer
#define POWERPC_EXCP_745     (POWERPC_EXCP_7x5)
5188 bd928eba j_mayer
#define POWERPC_INPUT_745    (PPC_FLAGS_INPUT_6xx)
5189 bd928eba j_mayer
#define POWERPC_BFDM_745     (bfd_mach_ppc_750)
5190 bd928eba j_mayer
#define POWERPC_FLAG_745     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5191 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5192 bd928eba j_mayer
#define check_pow_745        check_pow_hid0
5193 bd928eba j_mayer
5194 bd928eba j_mayer
static void init_proc_745 (CPUPPCState *env)
5195 bd928eba j_mayer
{
5196 bd928eba j_mayer
    gen_spr_ne_601(env);
5197 bd928eba j_mayer
    gen_spr_7xx(env);
5198 bd928eba j_mayer
    gen_spr_G2_755(env);
5199 bd928eba j_mayer
    /* Time base */
5200 bd928eba j_mayer
    gen_tbl(env);
5201 bd928eba j_mayer
    /* Thermal management */
5202 bd928eba j_mayer
    gen_spr_thrm(env);
5203 bd928eba j_mayer
    /* Hardware implementation registers */
5204 bd928eba j_mayer
    /* XXX : not implemented */
5205 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
5206 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5207 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5208 bd928eba j_mayer
                 0x00000000);
5209 bd928eba j_mayer
    /* XXX : not implemented */
5210 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5211 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5212 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5213 bd928eba j_mayer
                 0x00000000);
5214 bd928eba j_mayer
    /* XXX : not implemented */
5215 bd928eba j_mayer
    spr_register(env, SPR_HID2, "HID2",
5216 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5217 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5218 bd928eba j_mayer
                 0x00000000);
5219 bd928eba j_mayer
    /* Memory management */
5220 bd928eba j_mayer
    gen_low_BATs(env);
5221 bd928eba j_mayer
    gen_high_BATs(env);
5222 bd928eba j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
5223 bd928eba j_mayer
    init_excp_7x5(env);
5224 bd928eba j_mayer
    env->dcache_line_size = 32;
5225 bd928eba j_mayer
    env->icache_line_size = 32;
5226 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5227 bd928eba j_mayer
    ppc6xx_irq_init(env);
5228 bd928eba j_mayer
}
5229 bd928eba j_mayer
5230 bd928eba j_mayer
/* PowerPC 755                                                               */
5231 bd928eba j_mayer
#define POWERPC_INSNS_755    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5232 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5233 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5234 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5235 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5236 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
5237 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
5238 bd928eba j_mayer
#define POWERPC_MSRM_755     (0x000000000005FF77ULL)
5239 bd928eba j_mayer
#define POWERPC_MMU_755      (POWERPC_MMU_SOFT_6xx)
5240 bd928eba j_mayer
#define POWERPC_EXCP_755     (POWERPC_EXCP_7x5)
5241 bd928eba j_mayer
#define POWERPC_INPUT_755    (PPC_FLAGS_INPUT_6xx)
5242 bd928eba j_mayer
#define POWERPC_BFDM_755     (bfd_mach_ppc_750)
5243 bd928eba j_mayer
#define POWERPC_FLAG_755     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5244 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5245 bd928eba j_mayer
#define check_pow_755        check_pow_hid0
5246 a750fc0b j_mayer
5247 bd928eba j_mayer
static void init_proc_755 (CPUPPCState *env)
5248 a750fc0b j_mayer
{
5249 a750fc0b j_mayer
    gen_spr_ne_601(env);
5250 bd928eba j_mayer
    gen_spr_7xx(env);
5251 a750fc0b j_mayer
    gen_spr_G2_755(env);
5252 a750fc0b j_mayer
    /* Time base */
5253 a750fc0b j_mayer
    gen_tbl(env);
5254 a750fc0b j_mayer
    /* L2 cache control */
5255 a750fc0b j_mayer
    /* XXX : not implemented */
5256 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5257 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5258 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5259 a750fc0b j_mayer
                 0x00000000);
5260 a750fc0b j_mayer
    /* XXX : not implemented */
5261 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
5262 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5263 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5264 a750fc0b j_mayer
                 0x00000000);
5265 bd928eba j_mayer
    /* Thermal management */
5266 bd928eba j_mayer
    gen_spr_thrm(env);
5267 a750fc0b j_mayer
    /* Hardware implementation registers */
5268 a750fc0b j_mayer
    /* XXX : not implemented */
5269 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5270 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5271 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5272 a750fc0b j_mayer
                 0x00000000);
5273 a750fc0b j_mayer
    /* XXX : not implemented */
5274 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
5275 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5276 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5277 a750fc0b j_mayer
                 0x00000000);
5278 a750fc0b j_mayer
    /* XXX : not implemented */
5279 a750fc0b j_mayer
    spr_register(env, SPR_HID2, "HID2",
5280 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5281 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5282 a750fc0b j_mayer
                 0x00000000);
5283 a750fc0b j_mayer
    /* Memory management */
5284 a750fc0b j_mayer
    gen_low_BATs(env);
5285 a750fc0b j_mayer
    gen_high_BATs(env);
5286 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
5287 7a3a6927 j_mayer
    init_excp_7x5(env);
5288 d63001d1 j_mayer
    env->dcache_line_size = 32;
5289 d63001d1 j_mayer
    env->icache_line_size = 32;
5290 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5291 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5292 a750fc0b j_mayer
}
5293 a750fc0b j_mayer
5294 a750fc0b j_mayer
/* PowerPC 7400 (aka G4)                                                     */
5295 082c6681 j_mayer
#define POWERPC_INSNS_7400   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5296 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5297 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5298 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5299 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5300 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5301 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5302 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5303 082c6681 j_mayer
                              PPC_MEM_TLBIA |                                 \
5304 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5305 a750fc0b j_mayer
                              PPC_ALTIVEC)
5306 a750fc0b j_mayer
#define POWERPC_MSRM_7400    (0x000000000205FF77ULL)
5307 a750fc0b j_mayer
#define POWERPC_MMU_7400     (POWERPC_MMU_32B)
5308 a750fc0b j_mayer
#define POWERPC_EXCP_7400    (POWERPC_EXCP_74xx)
5309 a750fc0b j_mayer
#define POWERPC_INPUT_7400   (PPC_FLAGS_INPUT_6xx)
5310 237c0af0 j_mayer
#define POWERPC_BFDM_7400    (bfd_mach_ppc_7400)
5311 25ba3a68 j_mayer
#define POWERPC_FLAG_7400    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5312 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5313 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5314 488243b0 Aurelien Jarno
#define check_pow_7400       check_pow_hid0
5315 a750fc0b j_mayer
5316 a750fc0b j_mayer
static void init_proc_7400 (CPUPPCState *env)
5317 a750fc0b j_mayer
{
5318 a750fc0b j_mayer
    gen_spr_ne_601(env);
5319 a750fc0b j_mayer
    gen_spr_7xx(env);
5320 a750fc0b j_mayer
    /* Time base */
5321 a750fc0b j_mayer
    gen_tbl(env);
5322 a750fc0b j_mayer
    /* 74xx specific SPR */
5323 a750fc0b j_mayer
    gen_spr_74xx(env);
5324 4e777442 j_mayer
    /* XXX : not implemented */
5325 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5326 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5327 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5328 4e777442 j_mayer
                 0x00000000);
5329 4e777442 j_mayer
    /* XXX: this seems not implemented on all revisions. */
5330 4e777442 j_mayer
    /* XXX : not implemented */
5331 4e777442 j_mayer
    spr_register(env, SPR_MSSCR1, "MSSCR1",
5332 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5333 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5334 4e777442 j_mayer
                 0x00000000);
5335 a750fc0b j_mayer
    /* Thermal management */
5336 a750fc0b j_mayer
    gen_spr_thrm(env);
5337 a750fc0b j_mayer
    /* Memory management */
5338 a750fc0b j_mayer
    gen_low_BATs(env);
5339 e1833e1f j_mayer
    init_excp_7400(env);
5340 d63001d1 j_mayer
    env->dcache_line_size = 32;
5341 d63001d1 j_mayer
    env->icache_line_size = 32;
5342 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5343 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5344 a750fc0b j_mayer
}
5345 a750fc0b j_mayer
5346 a750fc0b j_mayer
/* PowerPC 7410 (aka G4)                                                     */
5347 082c6681 j_mayer
#define POWERPC_INSNS_7410   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5348 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5349 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5350 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5351 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5352 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5353 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5354 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5355 082c6681 j_mayer
                              PPC_MEM_TLBIA |                                 \
5356 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5357 a750fc0b j_mayer
                              PPC_ALTIVEC)
5358 a750fc0b j_mayer
#define POWERPC_MSRM_7410    (0x000000000205FF77ULL)
5359 a750fc0b j_mayer
#define POWERPC_MMU_7410     (POWERPC_MMU_32B)
5360 a750fc0b j_mayer
#define POWERPC_EXCP_7410    (POWERPC_EXCP_74xx)
5361 a750fc0b j_mayer
#define POWERPC_INPUT_7410   (PPC_FLAGS_INPUT_6xx)
5362 237c0af0 j_mayer
#define POWERPC_BFDM_7410    (bfd_mach_ppc_7400)
5363 25ba3a68 j_mayer
#define POWERPC_FLAG_7410    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5364 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5365 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5366 488243b0 Aurelien Jarno
#define check_pow_7410       check_pow_hid0
5367 a750fc0b j_mayer
5368 a750fc0b j_mayer
static void init_proc_7410 (CPUPPCState *env)
5369 a750fc0b j_mayer
{
5370 a750fc0b j_mayer
    gen_spr_ne_601(env);
5371 a750fc0b j_mayer
    gen_spr_7xx(env);
5372 a750fc0b j_mayer
    /* Time base */
5373 a750fc0b j_mayer
    gen_tbl(env);
5374 a750fc0b j_mayer
    /* 74xx specific SPR */
5375 a750fc0b j_mayer
    gen_spr_74xx(env);
5376 4e777442 j_mayer
    /* XXX : not implemented */
5377 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5378 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5379 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5380 4e777442 j_mayer
                 0x00000000);
5381 a750fc0b j_mayer
    /* Thermal management */
5382 a750fc0b j_mayer
    gen_spr_thrm(env);
5383 a750fc0b j_mayer
    /* L2PMCR */
5384 a750fc0b j_mayer
    /* XXX : not implemented */
5385 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
5386 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5387 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5388 a750fc0b j_mayer
                 0x00000000);
5389 a750fc0b j_mayer
    /* LDSTDB */
5390 a750fc0b j_mayer
    /* XXX : not implemented */
5391 a750fc0b j_mayer
    spr_register(env, SPR_LDSTDB, "LDSTDB",
5392 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5393 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5394 a750fc0b j_mayer
                 0x00000000);
5395 a750fc0b j_mayer
    /* Memory management */
5396 a750fc0b j_mayer
    gen_low_BATs(env);
5397 e1833e1f j_mayer
    init_excp_7400(env);
5398 d63001d1 j_mayer
    env->dcache_line_size = 32;
5399 d63001d1 j_mayer
    env->icache_line_size = 32;
5400 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5401 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5402 a750fc0b j_mayer
}
5403 a750fc0b j_mayer
5404 a750fc0b j_mayer
/* PowerPC 7440 (aka G4)                                                     */
5405 082c6681 j_mayer
#define POWERPC_INSNS_7440   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5406 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5407 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5408 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5409 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5410 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5411 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5412 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5413 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5414 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5415 a750fc0b j_mayer
                              PPC_ALTIVEC)
5416 a750fc0b j_mayer
#define POWERPC_MSRM_7440    (0x000000000205FF77ULL)
5417 a750fc0b j_mayer
#define POWERPC_MMU_7440     (POWERPC_MMU_SOFT_74xx)
5418 a750fc0b j_mayer
#define POWERPC_EXCP_7440    (POWERPC_EXCP_74xx)
5419 a750fc0b j_mayer
#define POWERPC_INPUT_7440   (PPC_FLAGS_INPUT_6xx)
5420 237c0af0 j_mayer
#define POWERPC_BFDM_7440    (bfd_mach_ppc_7400)
5421 25ba3a68 j_mayer
#define POWERPC_FLAG_7440    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5422 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5423 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5424 4e777442 j_mayer
#define check_pow_7440       check_pow_hid0_74xx
5425 a750fc0b j_mayer
5426 578bb252 j_mayer
__attribute__ (( unused ))
5427 a750fc0b j_mayer
static void init_proc_7440 (CPUPPCState *env)
5428 a750fc0b j_mayer
{
5429 a750fc0b j_mayer
    gen_spr_ne_601(env);
5430 a750fc0b j_mayer
    gen_spr_7xx(env);
5431 a750fc0b j_mayer
    /* Time base */
5432 a750fc0b j_mayer
    gen_tbl(env);
5433 a750fc0b j_mayer
    /* 74xx specific SPR */
5434 a750fc0b j_mayer
    gen_spr_74xx(env);
5435 4e777442 j_mayer
    /* XXX : not implemented */
5436 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5437 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5438 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5439 4e777442 j_mayer
                 0x00000000);
5440 a750fc0b j_mayer
    /* LDSTCR */
5441 a750fc0b j_mayer
    /* XXX : not implemented */
5442 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5443 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5444 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5445 a750fc0b j_mayer
                 0x00000000);
5446 a750fc0b j_mayer
    /* ICTRL */
5447 a750fc0b j_mayer
    /* XXX : not implemented */
5448 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5449 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5450 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5451 a750fc0b j_mayer
                 0x00000000);
5452 a750fc0b j_mayer
    /* MSSSR0 */
5453 578bb252 j_mayer
    /* XXX : not implemented */
5454 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5455 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5456 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5457 a750fc0b j_mayer
                 0x00000000);
5458 a750fc0b j_mayer
    /* PMC */
5459 a750fc0b j_mayer
    /* XXX : not implemented */
5460 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5461 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5462 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5463 a750fc0b j_mayer
                 0x00000000);
5464 578bb252 j_mayer
    /* XXX : not implemented */
5465 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5466 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5467 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5468 a750fc0b j_mayer
                 0x00000000);
5469 578bb252 j_mayer
    /* XXX : not implemented */
5470 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5471 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5472 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5473 a750fc0b j_mayer
                 0x00000000);
5474 578bb252 j_mayer
    /* XXX : not implemented */
5475 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5476 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5477 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5478 a750fc0b j_mayer
                 0x00000000);
5479 a750fc0b j_mayer
    /* Memory management */
5480 a750fc0b j_mayer
    gen_low_BATs(env);
5481 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5482 1c27f8fb j_mayer
    init_excp_7450(env);
5483 d63001d1 j_mayer
    env->dcache_line_size = 32;
5484 d63001d1 j_mayer
    env->icache_line_size = 32;
5485 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5486 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5487 a750fc0b j_mayer
}
5488 a750fc0b j_mayer
5489 a750fc0b j_mayer
/* PowerPC 7450 (aka G4)                                                     */
5490 082c6681 j_mayer
#define POWERPC_INSNS_7450   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5491 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5492 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5493 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5494 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5495 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5496 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5497 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5498 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5499 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5500 a750fc0b j_mayer
                              PPC_ALTIVEC)
5501 a750fc0b j_mayer
#define POWERPC_MSRM_7450    (0x000000000205FF77ULL)
5502 a750fc0b j_mayer
#define POWERPC_MMU_7450     (POWERPC_MMU_SOFT_74xx)
5503 a750fc0b j_mayer
#define POWERPC_EXCP_7450    (POWERPC_EXCP_74xx)
5504 a750fc0b j_mayer
#define POWERPC_INPUT_7450   (PPC_FLAGS_INPUT_6xx)
5505 237c0af0 j_mayer
#define POWERPC_BFDM_7450    (bfd_mach_ppc_7400)
5506 25ba3a68 j_mayer
#define POWERPC_FLAG_7450    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5507 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5508 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5509 4e777442 j_mayer
#define check_pow_7450       check_pow_hid0_74xx
5510 a750fc0b j_mayer
5511 578bb252 j_mayer
__attribute__ (( unused ))
5512 a750fc0b j_mayer
static void init_proc_7450 (CPUPPCState *env)
5513 a750fc0b j_mayer
{
5514 a750fc0b j_mayer
    gen_spr_ne_601(env);
5515 a750fc0b j_mayer
    gen_spr_7xx(env);
5516 a750fc0b j_mayer
    /* Time base */
5517 a750fc0b j_mayer
    gen_tbl(env);
5518 a750fc0b j_mayer
    /* 74xx specific SPR */
5519 a750fc0b j_mayer
    gen_spr_74xx(env);
5520 a750fc0b j_mayer
    /* Level 3 cache control */
5521 a750fc0b j_mayer
    gen_l3_ctrl(env);
5522 4e777442 j_mayer
    /* L3ITCR1 */
5523 4e777442 j_mayer
    /* XXX : not implemented */
5524 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
5525 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5526 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5527 4e777442 j_mayer
                 0x00000000);
5528 4e777442 j_mayer
    /* L3ITCR2 */
5529 4e777442 j_mayer
    /* XXX : not implemented */
5530 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
5531 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5532 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5533 4e777442 j_mayer
                 0x00000000);
5534 4e777442 j_mayer
    /* L3ITCR3 */
5535 4e777442 j_mayer
    /* XXX : not implemented */
5536 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
5537 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5538 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5539 4e777442 j_mayer
                 0x00000000);
5540 4e777442 j_mayer
    /* L3OHCR */
5541 4e777442 j_mayer
    /* XXX : not implemented */
5542 4e777442 j_mayer
    spr_register(env, SPR_L3OHCR, "L3OHCR",
5543 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5544 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5545 4e777442 j_mayer
                 0x00000000);
5546 4e777442 j_mayer
    /* XXX : not implemented */
5547 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5548 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5549 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5550 4e777442 j_mayer
                 0x00000000);
5551 a750fc0b j_mayer
    /* LDSTCR */
5552 a750fc0b j_mayer
    /* XXX : not implemented */
5553 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5554 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5555 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5556 a750fc0b j_mayer
                 0x00000000);
5557 a750fc0b j_mayer
    /* ICTRL */
5558 a750fc0b j_mayer
    /* XXX : not implemented */
5559 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5560 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5561 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5562 a750fc0b j_mayer
                 0x00000000);
5563 a750fc0b j_mayer
    /* MSSSR0 */
5564 578bb252 j_mayer
    /* XXX : not implemented */
5565 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5566 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5567 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5568 a750fc0b j_mayer
                 0x00000000);
5569 a750fc0b j_mayer
    /* PMC */
5570 a750fc0b j_mayer
    /* XXX : not implemented */
5571 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5572 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5573 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5574 a750fc0b j_mayer
                 0x00000000);
5575 578bb252 j_mayer
    /* XXX : not implemented */
5576 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5577 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5578 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5579 a750fc0b j_mayer
                 0x00000000);
5580 578bb252 j_mayer
    /* XXX : not implemented */
5581 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5582 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5583 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5584 a750fc0b j_mayer
                 0x00000000);
5585 578bb252 j_mayer
    /* XXX : not implemented */
5586 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5587 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5588 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5589 a750fc0b j_mayer
                 0x00000000);
5590 a750fc0b j_mayer
    /* Memory management */
5591 a750fc0b j_mayer
    gen_low_BATs(env);
5592 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5593 e1833e1f j_mayer
    init_excp_7450(env);
5594 d63001d1 j_mayer
    env->dcache_line_size = 32;
5595 d63001d1 j_mayer
    env->icache_line_size = 32;
5596 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5597 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5598 a750fc0b j_mayer
}
5599 a750fc0b j_mayer
5600 a750fc0b j_mayer
/* PowerPC 7445 (aka G4)                                                     */
5601 082c6681 j_mayer
#define POWERPC_INSNS_7445   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5602 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5603 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5604 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5605 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5606 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5607 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5608 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5609 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5610 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5611 a750fc0b j_mayer
                              PPC_ALTIVEC)
5612 a750fc0b j_mayer
#define POWERPC_MSRM_7445    (0x000000000205FF77ULL)
5613 a750fc0b j_mayer
#define POWERPC_MMU_7445     (POWERPC_MMU_SOFT_74xx)
5614 a750fc0b j_mayer
#define POWERPC_EXCP_7445    (POWERPC_EXCP_74xx)
5615 a750fc0b j_mayer
#define POWERPC_INPUT_7445   (PPC_FLAGS_INPUT_6xx)
5616 237c0af0 j_mayer
#define POWERPC_BFDM_7445    (bfd_mach_ppc_7400)
5617 25ba3a68 j_mayer
#define POWERPC_FLAG_7445    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5618 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5619 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5620 4e777442 j_mayer
#define check_pow_7445       check_pow_hid0_74xx
5621 a750fc0b j_mayer
5622 578bb252 j_mayer
__attribute__ (( unused ))
5623 a750fc0b j_mayer
static void init_proc_7445 (CPUPPCState *env)
5624 a750fc0b j_mayer
{
5625 a750fc0b j_mayer
    gen_spr_ne_601(env);
5626 a750fc0b j_mayer
    gen_spr_7xx(env);
5627 a750fc0b j_mayer
    /* Time base */
5628 a750fc0b j_mayer
    gen_tbl(env);
5629 a750fc0b j_mayer
    /* 74xx specific SPR */
5630 a750fc0b j_mayer
    gen_spr_74xx(env);
5631 a750fc0b j_mayer
    /* LDSTCR */
5632 a750fc0b j_mayer
    /* XXX : not implemented */
5633 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5634 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5635 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5636 a750fc0b j_mayer
                 0x00000000);
5637 a750fc0b j_mayer
    /* ICTRL */
5638 a750fc0b j_mayer
    /* XXX : not implemented */
5639 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5640 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5641 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5642 a750fc0b j_mayer
                 0x00000000);
5643 a750fc0b j_mayer
    /* MSSSR0 */
5644 578bb252 j_mayer
    /* XXX : not implemented */
5645 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5646 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5647 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5648 a750fc0b j_mayer
                 0x00000000);
5649 a750fc0b j_mayer
    /* PMC */
5650 a750fc0b j_mayer
    /* XXX : not implemented */
5651 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5652 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5653 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5654 a750fc0b j_mayer
                 0x00000000);
5655 578bb252 j_mayer
    /* XXX : not implemented */
5656 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5657 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5658 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5659 a750fc0b j_mayer
                 0x00000000);
5660 578bb252 j_mayer
    /* XXX : not implemented */
5661 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5662 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5663 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5664 a750fc0b j_mayer
                 0x00000000);
5665 578bb252 j_mayer
    /* XXX : not implemented */
5666 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5667 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5668 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5669 a750fc0b j_mayer
                 0x00000000);
5670 a750fc0b j_mayer
    /* SPRGs */
5671 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
5672 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5673 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5674 a750fc0b j_mayer
                 0x00000000);
5675 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
5676 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5677 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5678 a750fc0b j_mayer
                 0x00000000);
5679 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
5680 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5681 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5682 a750fc0b j_mayer
                 0x00000000);
5683 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
5684 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5685 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5686 a750fc0b j_mayer
                 0x00000000);
5687 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
5688 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5689 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5690 a750fc0b j_mayer
                 0x00000000);
5691 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
5692 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5693 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5694 a750fc0b j_mayer
                 0x00000000);
5695 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
5696 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5697 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5698 a750fc0b j_mayer
                 0x00000000);
5699 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
5700 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5701 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5702 a750fc0b j_mayer
                 0x00000000);
5703 a750fc0b j_mayer
    /* Memory management */
5704 a750fc0b j_mayer
    gen_low_BATs(env);
5705 a750fc0b j_mayer
    gen_high_BATs(env);
5706 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5707 e1833e1f j_mayer
    init_excp_7450(env);
5708 d63001d1 j_mayer
    env->dcache_line_size = 32;
5709 d63001d1 j_mayer
    env->icache_line_size = 32;
5710 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5711 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5712 a750fc0b j_mayer
}
5713 a750fc0b j_mayer
5714 a750fc0b j_mayer
/* PowerPC 7455 (aka G4)                                                     */
5715 082c6681 j_mayer
#define POWERPC_INSNS_7455   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5716 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5717 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5718 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5719 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5720 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5721 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5722 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5723 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5724 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5725 a750fc0b j_mayer
                              PPC_ALTIVEC)
5726 a750fc0b j_mayer
#define POWERPC_MSRM_7455    (0x000000000205FF77ULL)
5727 a750fc0b j_mayer
#define POWERPC_MMU_7455     (POWERPC_MMU_SOFT_74xx)
5728 a750fc0b j_mayer
#define POWERPC_EXCP_7455    (POWERPC_EXCP_74xx)
5729 a750fc0b j_mayer
#define POWERPC_INPUT_7455   (PPC_FLAGS_INPUT_6xx)
5730 237c0af0 j_mayer
#define POWERPC_BFDM_7455    (bfd_mach_ppc_7400)
5731 25ba3a68 j_mayer
#define POWERPC_FLAG_7455    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5732 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5733 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5734 4e777442 j_mayer
#define check_pow_7455       check_pow_hid0_74xx
5735 a750fc0b j_mayer
5736 578bb252 j_mayer
__attribute__ (( unused ))
5737 a750fc0b j_mayer
static void init_proc_7455 (CPUPPCState *env)
5738 a750fc0b j_mayer
{
5739 a750fc0b j_mayer
    gen_spr_ne_601(env);
5740 a750fc0b j_mayer
    gen_spr_7xx(env);
5741 a750fc0b j_mayer
    /* Time base */
5742 a750fc0b j_mayer
    gen_tbl(env);
5743 a750fc0b j_mayer
    /* 74xx specific SPR */
5744 a750fc0b j_mayer
    gen_spr_74xx(env);
5745 a750fc0b j_mayer
    /* Level 3 cache control */
5746 a750fc0b j_mayer
    gen_l3_ctrl(env);
5747 a750fc0b j_mayer
    /* LDSTCR */
5748 a750fc0b j_mayer
    /* XXX : not implemented */
5749 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5750 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5751 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5752 a750fc0b j_mayer
                 0x00000000);
5753 a750fc0b j_mayer
    /* ICTRL */
5754 a750fc0b j_mayer
    /* XXX : not implemented */
5755 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5756 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5757 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5758 a750fc0b j_mayer
                 0x00000000);
5759 a750fc0b j_mayer
    /* MSSSR0 */
5760 578bb252 j_mayer
    /* XXX : not implemented */
5761 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5762 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5763 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5764 a750fc0b j_mayer
                 0x00000000);
5765 a750fc0b j_mayer
    /* PMC */
5766 a750fc0b j_mayer
    /* XXX : not implemented */
5767 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5768 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5769 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5770 a750fc0b j_mayer
                 0x00000000);
5771 578bb252 j_mayer
    /* XXX : not implemented */
5772 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5773 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5774 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5775 a750fc0b j_mayer
                 0x00000000);
5776 578bb252 j_mayer
    /* XXX : not implemented */
5777 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5778 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5779 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5780 a750fc0b j_mayer
                 0x00000000);
5781 578bb252 j_mayer
    /* XXX : not implemented */
5782 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5783 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5784 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5785 a750fc0b j_mayer
                 0x00000000);
5786 a750fc0b j_mayer
    /* SPRGs */
5787 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
5788 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5789 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5790 a750fc0b j_mayer
                 0x00000000);
5791 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
5792 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5793 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5794 a750fc0b j_mayer
                 0x00000000);
5795 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
5796 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5797 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5798 a750fc0b j_mayer
                 0x00000000);
5799 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
5800 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5801 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5802 a750fc0b j_mayer
                 0x00000000);
5803 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
5804 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5805 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5806 a750fc0b j_mayer
                 0x00000000);
5807 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
5808 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5809 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5810 a750fc0b j_mayer
                 0x00000000);
5811 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
5812 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5813 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5814 a750fc0b j_mayer
                 0x00000000);
5815 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
5816 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5817 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5818 a750fc0b j_mayer
                 0x00000000);
5819 a750fc0b j_mayer
    /* Memory management */
5820 a750fc0b j_mayer
    gen_low_BATs(env);
5821 a750fc0b j_mayer
    gen_high_BATs(env);
5822 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5823 e1833e1f j_mayer
    init_excp_7450(env);
5824 d63001d1 j_mayer
    env->dcache_line_size = 32;
5825 d63001d1 j_mayer
    env->icache_line_size = 32;
5826 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5827 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5828 a750fc0b j_mayer
}
5829 a750fc0b j_mayer
5830 4e777442 j_mayer
/* PowerPC 7457 (aka G4)                                                     */
5831 4e777442 j_mayer
#define POWERPC_INSNS_7457   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5832 4e777442 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5833 4e777442 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5834 4e777442 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5835 4e777442 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5836 4e777442 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5837 4e777442 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5838 4e777442 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5839 4e777442 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5840 4e777442 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5841 4e777442 j_mayer
                              PPC_ALTIVEC)
5842 4e777442 j_mayer
#define POWERPC_MSRM_7457    (0x000000000205FF77ULL)
5843 4e777442 j_mayer
#define POWERPC_MMU_7457     (POWERPC_MMU_SOFT_74xx)
5844 4e777442 j_mayer
#define POWERPC_EXCP_7457    (POWERPC_EXCP_74xx)
5845 4e777442 j_mayer
#define POWERPC_INPUT_7457   (PPC_FLAGS_INPUT_6xx)
5846 4e777442 j_mayer
#define POWERPC_BFDM_7457    (bfd_mach_ppc_7400)
5847 4e777442 j_mayer
#define POWERPC_FLAG_7457    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5848 4e777442 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5849 4e777442 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5850 4e777442 j_mayer
#define check_pow_7457       check_pow_hid0_74xx
5851 4e777442 j_mayer
5852 4e777442 j_mayer
__attribute__ (( unused ))
5853 4e777442 j_mayer
static void init_proc_7457 (CPUPPCState *env)
5854 4e777442 j_mayer
{
5855 4e777442 j_mayer
    gen_spr_ne_601(env);
5856 4e777442 j_mayer
    gen_spr_7xx(env);
5857 4e777442 j_mayer
    /* Time base */
5858 4e777442 j_mayer
    gen_tbl(env);
5859 4e777442 j_mayer
    /* 74xx specific SPR */
5860 4e777442 j_mayer
    gen_spr_74xx(env);
5861 4e777442 j_mayer
    /* Level 3 cache control */
5862 4e777442 j_mayer
    gen_l3_ctrl(env);
5863 4e777442 j_mayer
    /* L3ITCR1 */
5864 4e777442 j_mayer
    /* XXX : not implemented */
5865 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
5866 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5867 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5868 4e777442 j_mayer
                 0x00000000);
5869 4e777442 j_mayer
    /* L3ITCR2 */
5870 4e777442 j_mayer
    /* XXX : not implemented */
5871 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
5872 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5873 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5874 4e777442 j_mayer
                 0x00000000);
5875 4e777442 j_mayer
    /* L3ITCR3 */
5876 4e777442 j_mayer
    /* XXX : not implemented */
5877 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
5878 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5879 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5880 4e777442 j_mayer
                 0x00000000);
5881 4e777442 j_mayer
    /* L3OHCR */
5882 4e777442 j_mayer
    /* XXX : not implemented */
5883 4e777442 j_mayer
    spr_register(env, SPR_L3OHCR, "L3OHCR",
5884 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5885 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5886 4e777442 j_mayer
                 0x00000000);
5887 4e777442 j_mayer
    /* LDSTCR */
5888 4e777442 j_mayer
    /* XXX : not implemented */
5889 4e777442 j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5890 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5891 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5892 4e777442 j_mayer
                 0x00000000);
5893 4e777442 j_mayer
    /* ICTRL */
5894 4e777442 j_mayer
    /* XXX : not implemented */
5895 4e777442 j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5896 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5897 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5898 4e777442 j_mayer
                 0x00000000);
5899 4e777442 j_mayer
    /* MSSSR0 */
5900 4e777442 j_mayer
    /* XXX : not implemented */
5901 4e777442 j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5902 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5903 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5904 4e777442 j_mayer
                 0x00000000);
5905 4e777442 j_mayer
    /* PMC */
5906 4e777442 j_mayer
    /* XXX : not implemented */
5907 4e777442 j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5908 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5909 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5910 4e777442 j_mayer
                 0x00000000);
5911 4e777442 j_mayer
    /* XXX : not implemented */
5912 4e777442 j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5913 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5914 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5915 4e777442 j_mayer
                 0x00000000);
5916 4e777442 j_mayer
    /* XXX : not implemented */
5917 4e777442 j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5918 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5919 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5920 4e777442 j_mayer
                 0x00000000);
5921 4e777442 j_mayer
    /* XXX : not implemented */
5922 4e777442 j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5923 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5924 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5925 4e777442 j_mayer
                 0x00000000);
5926 4e777442 j_mayer
    /* SPRGs */
5927 4e777442 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
5928 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5929 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5930 4e777442 j_mayer
                 0x00000000);
5931 4e777442 j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
5932 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5933 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5934 4e777442 j_mayer
                 0x00000000);
5935 4e777442 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
5936 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5937 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5938 4e777442 j_mayer
                 0x00000000);
5939 4e777442 j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
5940 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5941 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5942 4e777442 j_mayer
                 0x00000000);
5943 4e777442 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
5944 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5945 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5946 4e777442 j_mayer
                 0x00000000);
5947 4e777442 j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
5948 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5949 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5950 4e777442 j_mayer
                 0x00000000);
5951 4e777442 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
5952 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5953 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5954 4e777442 j_mayer
                 0x00000000);
5955 4e777442 j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
5956 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5957 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5958 4e777442 j_mayer
                 0x00000000);
5959 4e777442 j_mayer
    /* Memory management */
5960 4e777442 j_mayer
    gen_low_BATs(env);
5961 4e777442 j_mayer
    gen_high_BATs(env);
5962 4e777442 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5963 4e777442 j_mayer
    init_excp_7450(env);
5964 4e777442 j_mayer
    env->dcache_line_size = 32;
5965 4e777442 j_mayer
    env->icache_line_size = 32;
5966 4e777442 j_mayer
    /* Allocate hardware IRQ controller */
5967 4e777442 j_mayer
    ppc6xx_irq_init(env);
5968 4e777442 j_mayer
}
5969 4e777442 j_mayer
5970 a750fc0b j_mayer
#if defined (TARGET_PPC64)
5971 a750fc0b j_mayer
/* PowerPC 970                                                               */
5972 082c6681 j_mayer
#define POWERPC_INSNS_970    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5973 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5974 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5975 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5976 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
5977 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5978 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5979 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
5980 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
5981 a750fc0b j_mayer
#define POWERPC_MSRM_970     (0x900000000204FF36ULL)
5982 12de9a39 j_mayer
#define POWERPC_MMU_970      (POWERPC_MMU_64B)
5983 a750fc0b j_mayer
//#define POWERPC_EXCP_970     (POWERPC_EXCP_970)
5984 a750fc0b j_mayer
#define POWERPC_INPUT_970    (PPC_FLAGS_INPUT_970)
5985 237c0af0 j_mayer
#define POWERPC_BFDM_970     (bfd_mach_ppc64)
5986 25ba3a68 j_mayer
#define POWERPC_FLAG_970     (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5987 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5988 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5989 a750fc0b j_mayer
5990 417bf010 j_mayer
#if defined(CONFIG_USER_ONLY)
5991 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000080
5992 417bf010 j_mayer
#else
5993 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000000
5994 417bf010 j_mayer
#endif
5995 417bf010 j_mayer
5996 2f462816 j_mayer
static int check_pow_970 (CPUPPCState *env)
5997 2f462816 j_mayer
{
5998 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
5999 2f462816 j_mayer
        return 1;
6000 2f462816 j_mayer
6001 2f462816 j_mayer
    return 0;
6002 2f462816 j_mayer
}
6003 2f462816 j_mayer
6004 a750fc0b j_mayer
static void init_proc_970 (CPUPPCState *env)
6005 a750fc0b j_mayer
{
6006 a750fc0b j_mayer
    gen_spr_ne_601(env);
6007 a750fc0b j_mayer
    gen_spr_7xx(env);
6008 a750fc0b j_mayer
    /* Time base */
6009 a750fc0b j_mayer
    gen_tbl(env);
6010 a750fc0b j_mayer
    /* Hardware implementation registers */
6011 a750fc0b j_mayer
    /* XXX : not implemented */
6012 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6013 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6014 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
6015 d63001d1 j_mayer
                 0x60000000);
6016 a750fc0b j_mayer
    /* XXX : not implemented */
6017 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
6018 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6019 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6020 a750fc0b j_mayer
                 0x00000000);
6021 a750fc0b j_mayer
    /* XXX : not implemented */
6022 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6023 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6024 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6025 a750fc0b j_mayer
                 0x00000000);
6026 e57448f1 j_mayer
    /* XXX : not implemented */
6027 e57448f1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6028 e57448f1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6029 e57448f1 j_mayer
                 &spr_read_generic, &spr_write_generic,
6030 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
6031 bd928eba j_mayer
    /* XXX : not implemented */
6032 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6033 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6034 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6035 bd928eba j_mayer
                 0x00000000);
6036 a750fc0b j_mayer
    /* Memory management */
6037 a750fc0b j_mayer
    /* XXX: not correct */
6038 a750fc0b j_mayer
    gen_low_BATs(env);
6039 12de9a39 j_mayer
    /* XXX : not implemented */
6040 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6041 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6042 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6043 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6044 12de9a39 j_mayer
    /* XXX : not implemented */
6045 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6046 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6047 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
6048 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6049 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6050 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6051 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6052 2adab7d6 blueswir1
                 0x00000000);
6053 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
6054 12de9a39 j_mayer
    env->slb_nr = 32;
6055 f2e63a42 j_mayer
#endif
6056 e1833e1f j_mayer
    init_excp_970(env);
6057 d63001d1 j_mayer
    env->dcache_line_size = 128;
6058 d63001d1 j_mayer
    env->icache_line_size = 128;
6059 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
6060 a750fc0b j_mayer
    ppc970_irq_init(env);
6061 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6062 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6063 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6064 a750fc0b j_mayer
}
6065 a750fc0b j_mayer
6066 a750fc0b j_mayer
/* PowerPC 970FX (aka G5)                                                    */
6067 082c6681 j_mayer
#define POWERPC_INSNS_970FX  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6068 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6069 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6070 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6071 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6072 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6073 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6074 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
6075 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
6076 a750fc0b j_mayer
#define POWERPC_MSRM_970FX   (0x800000000204FF36ULL)
6077 12de9a39 j_mayer
#define POWERPC_MMU_970FX    (POWERPC_MMU_64B)
6078 a750fc0b j_mayer
#define POWERPC_EXCP_970FX   (POWERPC_EXCP_970)
6079 a750fc0b j_mayer
#define POWERPC_INPUT_970FX  (PPC_FLAGS_INPUT_970)
6080 237c0af0 j_mayer
#define POWERPC_BFDM_970FX   (bfd_mach_ppc64)
6081 25ba3a68 j_mayer
#define POWERPC_FLAG_970FX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6082 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6083 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6084 a750fc0b j_mayer
6085 2f462816 j_mayer
static int check_pow_970FX (CPUPPCState *env)
6086 2f462816 j_mayer
{
6087 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
6088 2f462816 j_mayer
        return 1;
6089 2f462816 j_mayer
6090 2f462816 j_mayer
    return 0;
6091 2f462816 j_mayer
}
6092 2f462816 j_mayer
6093 a750fc0b j_mayer
static void init_proc_970FX (CPUPPCState *env)
6094 a750fc0b j_mayer
{
6095 a750fc0b j_mayer
    gen_spr_ne_601(env);
6096 a750fc0b j_mayer
    gen_spr_7xx(env);
6097 a750fc0b j_mayer
    /* Time base */
6098 a750fc0b j_mayer
    gen_tbl(env);
6099 a750fc0b j_mayer
    /* Hardware implementation registers */
6100 a750fc0b j_mayer
    /* XXX : not implemented */
6101 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6102 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6103 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
6104 d63001d1 j_mayer
                 0x60000000);
6105 a750fc0b j_mayer
    /* XXX : not implemented */
6106 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
6107 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6108 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6109 a750fc0b j_mayer
                 0x00000000);
6110 a750fc0b j_mayer
    /* XXX : not implemented */
6111 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6112 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6113 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6114 a750fc0b j_mayer
                 0x00000000);
6115 d63001d1 j_mayer
    /* XXX : not implemented */
6116 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6117 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6118 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
6119 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
6120 bd928eba j_mayer
    /* XXX : not implemented */
6121 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6122 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6123 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6124 bd928eba j_mayer
                 0x00000000);
6125 a750fc0b j_mayer
    /* Memory management */
6126 a750fc0b j_mayer
    /* XXX: not correct */
6127 a750fc0b j_mayer
    gen_low_BATs(env);
6128 12de9a39 j_mayer
    /* XXX : not implemented */
6129 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6130 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6131 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6132 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6133 12de9a39 j_mayer
    /* XXX : not implemented */
6134 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6135 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6136 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
6137 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6138 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6139 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6140 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6141 2adab7d6 blueswir1
                 0x00000000);
6142 4e98d8cf blueswir1
    spr_register(env, SPR_CTRL, "SPR_CTRL",
6143 4e98d8cf blueswir1
                 SPR_NOACCESS, SPR_NOACCESS,
6144 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6145 4e98d8cf blueswir1
                 0x00000000);
6146 4e98d8cf blueswir1
    spr_register(env, SPR_UCTRL, "SPR_UCTRL",
6147 4e98d8cf blueswir1
                 SPR_NOACCESS, SPR_NOACCESS,
6148 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6149 4e98d8cf blueswir1
                 0x00000000);
6150 4e98d8cf blueswir1
    spr_register(env, SPR_VRSAVE, "SPR_VRSAVE",
6151 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6152 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6153 4e98d8cf blueswir1
                 0x00000000);
6154 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
6155 8eee0af9 blueswir1
    env->slb_nr = 64;
6156 f2e63a42 j_mayer
#endif
6157 e1833e1f j_mayer
    init_excp_970(env);
6158 d63001d1 j_mayer
    env->dcache_line_size = 128;
6159 d63001d1 j_mayer
    env->icache_line_size = 128;
6160 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
6161 a750fc0b j_mayer
    ppc970_irq_init(env);
6162 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6163 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6164 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6165 a750fc0b j_mayer
}
6166 a750fc0b j_mayer
6167 a750fc0b j_mayer
/* PowerPC 970 GX                                                            */
6168 082c6681 j_mayer
#define POWERPC_INSNS_970GX  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6169 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6170 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6171 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6172 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6173 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6174 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6175 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
6176 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
6177 a750fc0b j_mayer
#define POWERPC_MSRM_970GX   (0x800000000204FF36ULL)
6178 12de9a39 j_mayer
#define POWERPC_MMU_970GX    (POWERPC_MMU_64B)
6179 a750fc0b j_mayer
#define POWERPC_EXCP_970GX   (POWERPC_EXCP_970)
6180 a750fc0b j_mayer
#define POWERPC_INPUT_970GX  (PPC_FLAGS_INPUT_970)
6181 237c0af0 j_mayer
#define POWERPC_BFDM_970GX   (bfd_mach_ppc64)
6182 25ba3a68 j_mayer
#define POWERPC_FLAG_970GX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6183 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6184 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6185 a750fc0b j_mayer
6186 2f462816 j_mayer
static int check_pow_970GX (CPUPPCState *env)
6187 2f462816 j_mayer
{
6188 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
6189 2f462816 j_mayer
        return 1;
6190 2f462816 j_mayer
6191 2f462816 j_mayer
    return 0;
6192 2f462816 j_mayer
}
6193 2f462816 j_mayer
6194 a750fc0b j_mayer
static void init_proc_970GX (CPUPPCState *env)
6195 a750fc0b j_mayer
{
6196 a750fc0b j_mayer
    gen_spr_ne_601(env);
6197 a750fc0b j_mayer
    gen_spr_7xx(env);
6198 a750fc0b j_mayer
    /* Time base */
6199 a750fc0b j_mayer
    gen_tbl(env);
6200 a750fc0b j_mayer
    /* Hardware implementation registers */
6201 a750fc0b j_mayer
    /* XXX : not implemented */
6202 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6203 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6204 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
6205 d63001d1 j_mayer
                 0x60000000);
6206 a750fc0b j_mayer
    /* XXX : not implemented */
6207 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
6208 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6209 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6210 a750fc0b j_mayer
                 0x00000000);
6211 a750fc0b j_mayer
    /* XXX : not implemented */
6212 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6213 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6214 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6215 a750fc0b j_mayer
                 0x00000000);
6216 d63001d1 j_mayer
    /* XXX : not implemented */
6217 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6218 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6219 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
6220 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
6221 bd928eba j_mayer
    /* XXX : not implemented */
6222 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6223 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6224 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6225 bd928eba j_mayer
                 0x00000000);
6226 a750fc0b j_mayer
    /* Memory management */
6227 a750fc0b j_mayer
    /* XXX: not correct */
6228 a750fc0b j_mayer
    gen_low_BATs(env);
6229 12de9a39 j_mayer
    /* XXX : not implemented */
6230 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6231 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6232 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6233 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6234 12de9a39 j_mayer
    /* XXX : not implemented */
6235 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6236 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6237 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
6238 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6239 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6240 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6241 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6242 2adab7d6 blueswir1
                 0x00000000);
6243 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
6244 12de9a39 j_mayer
    env->slb_nr = 32;
6245 f2e63a42 j_mayer
#endif
6246 e1833e1f j_mayer
    init_excp_970(env);
6247 d63001d1 j_mayer
    env->dcache_line_size = 128;
6248 d63001d1 j_mayer
    env->icache_line_size = 128;
6249 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
6250 a750fc0b j_mayer
    ppc970_irq_init(env);
6251 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6252 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6253 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6254 a750fc0b j_mayer
}
6255 a750fc0b j_mayer
6256 2f462816 j_mayer
/* PowerPC 970 MP                                                            */
6257 082c6681 j_mayer
#define POWERPC_INSNS_970MP  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6258 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6259 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6260 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6261 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6262 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6263 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6264 2f462816 j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
6265 2f462816 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
6266 2f462816 j_mayer
#define POWERPC_MSRM_970MP   (0x900000000204FF36ULL)
6267 2f462816 j_mayer
#define POWERPC_MMU_970MP    (POWERPC_MMU_64B)
6268 2f462816 j_mayer
#define POWERPC_EXCP_970MP   (POWERPC_EXCP_970)
6269 2f462816 j_mayer
#define POWERPC_INPUT_970MP  (PPC_FLAGS_INPUT_970)
6270 2f462816 j_mayer
#define POWERPC_BFDM_970MP   (bfd_mach_ppc64)
6271 2f462816 j_mayer
#define POWERPC_FLAG_970MP   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6272 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6273 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6274 2f462816 j_mayer
6275 2f462816 j_mayer
static int check_pow_970MP (CPUPPCState *env)
6276 2f462816 j_mayer
{
6277 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x01C00000)
6278 2f462816 j_mayer
        return 1;
6279 2f462816 j_mayer
6280 2f462816 j_mayer
    return 0;
6281 2f462816 j_mayer
}
6282 2f462816 j_mayer
6283 2f462816 j_mayer
static void init_proc_970MP (CPUPPCState *env)
6284 2f462816 j_mayer
{
6285 2f462816 j_mayer
    gen_spr_ne_601(env);
6286 2f462816 j_mayer
    gen_spr_7xx(env);
6287 2f462816 j_mayer
    /* Time base */
6288 2f462816 j_mayer
    gen_tbl(env);
6289 2f462816 j_mayer
    /* Hardware implementation registers */
6290 2f462816 j_mayer
    /* XXX : not implemented */
6291 2f462816 j_mayer
    spr_register(env, SPR_HID0, "HID0",
6292 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6293 2f462816 j_mayer
                 &spr_read_generic, &spr_write_clear,
6294 2f462816 j_mayer
                 0x60000000);
6295 2f462816 j_mayer
    /* XXX : not implemented */
6296 2f462816 j_mayer
    spr_register(env, SPR_HID1, "HID1",
6297 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6298 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6299 2f462816 j_mayer
                 0x00000000);
6300 2f462816 j_mayer
    /* XXX : not implemented */
6301 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6302 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6303 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6304 2f462816 j_mayer
                 0x00000000);
6305 2f462816 j_mayer
    /* XXX : not implemented */
6306 2f462816 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6307 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6308 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6309 2f462816 j_mayer
                 POWERPC970_HID5_INIT);
6310 bd928eba j_mayer
    /* XXX : not implemented */
6311 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6312 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6313 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6314 bd928eba j_mayer
                 0x00000000);
6315 2f462816 j_mayer
    /* Memory management */
6316 2f462816 j_mayer
    /* XXX: not correct */
6317 2f462816 j_mayer
    gen_low_BATs(env);
6318 2f462816 j_mayer
    /* XXX : not implemented */
6319 2f462816 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6320 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6321 2f462816 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6322 2f462816 j_mayer
                 0x00000000); /* TOFIX */
6323 2f462816 j_mayer
    /* XXX : not implemented */
6324 2f462816 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6325 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6326 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6327 2f462816 j_mayer
                 0x00000000); /* TOFIX */
6328 2f462816 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6329 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6330 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6331 2adab7d6 blueswir1
                 0x00000000);
6332 2f462816 j_mayer
#if !defined(CONFIG_USER_ONLY)
6333 2f462816 j_mayer
    env->slb_nr = 32;
6334 2f462816 j_mayer
#endif
6335 2f462816 j_mayer
    init_excp_970(env);
6336 2f462816 j_mayer
    env->dcache_line_size = 128;
6337 2f462816 j_mayer
    env->icache_line_size = 128;
6338 2f462816 j_mayer
    /* Allocate hardware IRQ controller */
6339 2f462816 j_mayer
    ppc970_irq_init(env);
6340 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6341 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6342 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6343 2f462816 j_mayer
}
6344 2f462816 j_mayer
6345 9d52e907 David Gibson
#if defined(TARGET_PPC64)
6346 9d52e907 David Gibson
/* POWER7 */
6347 9d52e907 David Gibson
#define POWERPC_INSNS_POWER7  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6348 9d52e907 David Gibson
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6349 9d52e907 David Gibson
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6350 9d52e907 David Gibson
                              PPC_FLOAT_STFIWX |                              \
6351 9d52e907 David Gibson
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6352 9d52e907 David Gibson
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6353 9d52e907 David Gibson
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6354 9d52e907 David Gibson
                              PPC_64B | PPC_ALTIVEC |                         \
6355 9d52e907 David Gibson
                              PPC_SEGMENT_64B | PPC_SLBI |                    \
6356 9d52e907 David Gibson
                              PPC_POPCNTB | PPC_POPCNTWD)
6357 9d52e907 David Gibson
#define POWERPC_MSRM_POWER7   (0x800000000204FF36ULL)
6358 9d52e907 David Gibson
#define POWERPC_MMU_POWER7    (POWERPC_MMU_2_06)
6359 9d52e907 David Gibson
#define POWERPC_EXCP_POWER7   (POWERPC_EXCP_POWER7)
6360 9d52e907 David Gibson
#define POWERPC_INPUT_POWER7  (PPC_FLAGS_INPUT_POWER7)
6361 9d52e907 David Gibson
#define POWERPC_BFDM_POWER7   (bfd_mach_ppc64)
6362 9d52e907 David Gibson
#define POWERPC_FLAG_POWER7   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6363 9d52e907 David Gibson
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6364 9d52e907 David Gibson
                              POWERPC_FLAG_BUS_CLK)
6365 9d52e907 David Gibson
#define check_pow_POWER7    check_pow_nocheck
6366 9d52e907 David Gibson
6367 9d52e907 David Gibson
static void init_proc_POWER7 (CPUPPCState *env)
6368 9d52e907 David Gibson
{
6369 9d52e907 David Gibson
    gen_spr_ne_601(env);
6370 9d52e907 David Gibson
    gen_spr_7xx(env);
6371 9d52e907 David Gibson
    /* Time base */
6372 9d52e907 David Gibson
    gen_tbl(env);
6373 9d52e907 David Gibson
#if !defined(CONFIG_USER_ONLY)
6374 9d52e907 David Gibson
    /* PURR & SPURR: Hack - treat these as aliases for the TB for now */
6375 9d52e907 David Gibson
    spr_register(env, SPR_PURR,   "PURR",
6376 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6377 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6378 9d52e907 David Gibson
                 0x00000000);
6379 9d52e907 David Gibson
    spr_register(env, SPR_SPURR,   "SPURR",
6380 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6381 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6382 9d52e907 David Gibson
                 0x00000000);
6383 9d52e907 David Gibson
#endif /* !CONFIG_USER_ONLY */
6384 9d52e907 David Gibson
    /* Memory management */
6385 9d52e907 David Gibson
    /* XXX : not implemented */
6386 9d52e907 David Gibson
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6387 9d52e907 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6388 9d52e907 David Gibson
                 &spr_read_generic, SPR_NOACCESS,
6389 9d52e907 David Gibson
                 0x00000000); /* TOFIX */
6390 9d52e907 David Gibson
    /* XXX : not implemented */
6391 9d52e907 David Gibson
    spr_register(env, SPR_CTRL, "SPR_CTRLT",
6392 9d52e907 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6393 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6394 9d52e907 David Gibson
                 0x80800000);
6395 9d52e907 David Gibson
    spr_register(env, SPR_UCTRL, "SPR_CTRLF",
6396 9d52e907 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6397 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6398 9d52e907 David Gibson
                 0x80800000);
6399 9d52e907 David Gibson
    spr_register(env, SPR_VRSAVE, "SPR_VRSAVE",
6400 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6401 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6402 9d52e907 David Gibson
                 0x00000000);
6403 9d52e907 David Gibson
#if !defined(CONFIG_USER_ONLY)
6404 9d52e907 David Gibson
    env->slb_nr = 32;
6405 9d52e907 David Gibson
#endif
6406 9d52e907 David Gibson
    init_excp_POWER7(env);
6407 9d52e907 David Gibson
    env->dcache_line_size = 128;
6408 9d52e907 David Gibson
    env->icache_line_size = 128;
6409 9d52e907 David Gibson
    /* Allocate hardware IRQ controller */
6410 9d52e907 David Gibson
    ppcPOWER7_irq_init(env);
6411 9d52e907 David Gibson
    /* Can't find information on what this should be on reset.  This
6412 9d52e907 David Gibson
     * value is the one used by 74xx processors. */
6413 9d52e907 David Gibson
    vscr_init(env, 0x00010000);
6414 9d52e907 David Gibson
}
6415 9d52e907 David Gibson
#endif /* TARGET_PPC64 */
6416 9d52e907 David Gibson
6417 a750fc0b j_mayer
/* PowerPC 620                                                               */
6418 082c6681 j_mayer
#define POWERPC_INSNS_620    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6419 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6420 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6421 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6422 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
6423 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6424 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6425 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
6426 a750fc0b j_mayer
                              PPC_64B | PPC_SLBI)
6427 add78955 j_mayer
#define POWERPC_MSRM_620     (0x800000000005FF77ULL)
6428 add78955 j_mayer
//#define POWERPC_MMU_620      (POWERPC_MMU_620)
6429 a750fc0b j_mayer
#define POWERPC_EXCP_620     (POWERPC_EXCP_970)
6430 faadf50e j_mayer
#define POWERPC_INPUT_620    (PPC_FLAGS_INPUT_6xx)
6431 237c0af0 j_mayer
#define POWERPC_BFDM_620     (bfd_mach_ppc64)
6432 4018bae9 j_mayer
#define POWERPC_FLAG_620     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |            \
6433 add78955 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
6434 2f462816 j_mayer
#define check_pow_620        check_pow_nocheck /* Check this */
6435 a750fc0b j_mayer
6436 578bb252 j_mayer
__attribute__ (( unused ))
6437 a750fc0b j_mayer
static void init_proc_620 (CPUPPCState *env)
6438 a750fc0b j_mayer
{
6439 a750fc0b j_mayer
    gen_spr_ne_601(env);
6440 a750fc0b j_mayer
    gen_spr_620(env);
6441 a750fc0b j_mayer
    /* Time base */
6442 a750fc0b j_mayer
    gen_tbl(env);
6443 a750fc0b j_mayer
    /* Hardware implementation registers */
6444 a750fc0b j_mayer
    /* XXX : not implemented */
6445 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6446 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6447 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6448 a750fc0b j_mayer
                 0x00000000);
6449 a750fc0b j_mayer
    /* Memory management */
6450 a750fc0b j_mayer
    gen_low_BATs(env);
6451 e1833e1f j_mayer
    init_excp_620(env);
6452 d63001d1 j_mayer
    env->dcache_line_size = 64;
6453 d63001d1 j_mayer
    env->icache_line_size = 64;
6454 faadf50e j_mayer
    /* Allocate hardware IRQ controller */
6455 faadf50e j_mayer
    ppc6xx_irq_init(env);
6456 a750fc0b j_mayer
}
6457 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
6458 a750fc0b j_mayer
6459 a750fc0b j_mayer
/* Default 32 bits PowerPC target will be 604 */
6460 a750fc0b j_mayer
#define CPU_POWERPC_PPC32     CPU_POWERPC_604
6461 a750fc0b j_mayer
#define POWERPC_INSNS_PPC32   POWERPC_INSNS_604
6462 a750fc0b j_mayer
#define POWERPC_MSRM_PPC32    POWERPC_MSRM_604
6463 a750fc0b j_mayer
#define POWERPC_MMU_PPC32     POWERPC_MMU_604
6464 a750fc0b j_mayer
#define POWERPC_EXCP_PPC32    POWERPC_EXCP_604
6465 a750fc0b j_mayer
#define POWERPC_INPUT_PPC32   POWERPC_INPUT_604
6466 237c0af0 j_mayer
#define POWERPC_BFDM_PPC32    POWERPC_BFDM_604
6467 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC32    POWERPC_FLAG_604
6468 2f462816 j_mayer
#define check_pow_PPC32       check_pow_604
6469 2f462816 j_mayer
#define init_proc_PPC32       init_proc_604
6470 a750fc0b j_mayer
6471 a750fc0b j_mayer
/* Default 64 bits PowerPC target will be 970 FX */
6472 a750fc0b j_mayer
#define CPU_POWERPC_PPC64     CPU_POWERPC_970FX
6473 a750fc0b j_mayer
#define POWERPC_INSNS_PPC64   POWERPC_INSNS_970FX
6474 a750fc0b j_mayer
#define POWERPC_MSRM_PPC64    POWERPC_MSRM_970FX
6475 a750fc0b j_mayer
#define POWERPC_MMU_PPC64     POWERPC_MMU_970FX
6476 a750fc0b j_mayer
#define POWERPC_EXCP_PPC64    POWERPC_EXCP_970FX
6477 a750fc0b j_mayer
#define POWERPC_INPUT_PPC64   POWERPC_INPUT_970FX
6478 237c0af0 j_mayer
#define POWERPC_BFDM_PPC64    POWERPC_BFDM_970FX
6479 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC64    POWERPC_FLAG_970FX
6480 2f462816 j_mayer
#define check_pow_PPC64       check_pow_970FX
6481 2f462816 j_mayer
#define init_proc_PPC64       init_proc_970FX
6482 a750fc0b j_mayer
6483 a750fc0b j_mayer
/* Default PowerPC target will be PowerPC 32 */
6484 a750fc0b j_mayer
#if defined (TARGET_PPC64) && 0 // XXX: TODO
6485 d12f4c38 j_mayer
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC64
6486 d12f4c38 j_mayer
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC64
6487 d12f4c38 j_mayer
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC64
6488 d12f4c38 j_mayer
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC64
6489 d12f4c38 j_mayer
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC64
6490 d12f4c38 j_mayer
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC64
6491 237c0af0 j_mayer
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC64
6492 d26bfc9a j_mayer
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC64
6493 2f462816 j_mayer
#define check_pow_DEFAULT     check_pow_PPC64
6494 2f462816 j_mayer
#define init_proc_DEFAULT     init_proc_PPC64
6495 a750fc0b j_mayer
#else
6496 d12f4c38 j_mayer
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC32
6497 d12f4c38 j_mayer
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC32
6498 d12f4c38 j_mayer
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC32
6499 d12f4c38 j_mayer
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC32
6500 d12f4c38 j_mayer
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC32
6501 d12f4c38 j_mayer
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC32
6502 237c0af0 j_mayer
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC32
6503 d26bfc9a j_mayer
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC32
6504 2f462816 j_mayer
#define check_pow_DEFAULT     check_pow_PPC32
6505 2f462816 j_mayer
#define init_proc_DEFAULT     init_proc_PPC32
6506 a750fc0b j_mayer
#endif
6507 a750fc0b j_mayer
6508 a750fc0b j_mayer
/*****************************************************************************/
6509 a750fc0b j_mayer
/* PVR definitions for most known PowerPC                                    */
6510 a750fc0b j_mayer
enum {
6511 a750fc0b j_mayer
    /* PowerPC 401 family */
6512 a750fc0b j_mayer
    /* Generic PowerPC 401 */
6513 80d11f44 j_mayer
#define CPU_POWERPC_401              CPU_POWERPC_401G2
6514 a750fc0b j_mayer
    /* PowerPC 401 cores */
6515 80d11f44 j_mayer
    CPU_POWERPC_401A1              = 0x00210000,
6516 80d11f44 j_mayer
    CPU_POWERPC_401B2              = 0x00220000,
6517 a750fc0b j_mayer
#if 0
6518 80d11f44 j_mayer
    CPU_POWERPC_401B3              = xxx,
6519 a750fc0b j_mayer
#endif
6520 80d11f44 j_mayer
    CPU_POWERPC_401C2              = 0x00230000,
6521 80d11f44 j_mayer
    CPU_POWERPC_401D2              = 0x00240000,
6522 80d11f44 j_mayer
    CPU_POWERPC_401E2              = 0x00250000,
6523 80d11f44 j_mayer
    CPU_POWERPC_401F2              = 0x00260000,
6524 80d11f44 j_mayer
    CPU_POWERPC_401G2              = 0x00270000,
6525 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers */
6526 a750fc0b j_mayer
#if 0
6527 80d11f44 j_mayer
    CPU_POWERPC_401GF              = xxx,
6528 a750fc0b j_mayer
#endif
6529 80d11f44 j_mayer
#define CPU_POWERPC_IOP480           CPU_POWERPC_401B2
6530 a750fc0b j_mayer
    /* IBM Processor for Network Resources */
6531 80d11f44 j_mayer
    CPU_POWERPC_COBRA              = 0x10100000, /* XXX: 405 ? */
6532 a750fc0b j_mayer
#if 0
6533 80d11f44 j_mayer
    CPU_POWERPC_XIPCHIP            = xxx,
6534 a750fc0b j_mayer
#endif
6535 a750fc0b j_mayer
    /* PowerPC 403 family */
6536 a750fc0b j_mayer
    /* Generic PowerPC 403 */
6537 80d11f44 j_mayer
#define CPU_POWERPC_403              CPU_POWERPC_403GC
6538 a750fc0b j_mayer
    /* PowerPC 403 microcontrollers */
6539 80d11f44 j_mayer
    CPU_POWERPC_403GA              = 0x00200011,
6540 80d11f44 j_mayer
    CPU_POWERPC_403GB              = 0x00200100,
6541 80d11f44 j_mayer
    CPU_POWERPC_403GC              = 0x00200200,
6542 80d11f44 j_mayer
    CPU_POWERPC_403GCX             = 0x00201400,
6543 a750fc0b j_mayer
#if 0
6544 80d11f44 j_mayer
    CPU_POWERPC_403GP              = xxx,
6545 a750fc0b j_mayer
#endif
6546 a750fc0b j_mayer
    /* PowerPC 405 family */
6547 a750fc0b j_mayer
    /* Generic PowerPC 405 */
6548 80d11f44 j_mayer
#define CPU_POWERPC_405              CPU_POWERPC_405D4
6549 a750fc0b j_mayer
    /* PowerPC 405 cores */
6550 a750fc0b j_mayer
#if 0
6551 80d11f44 j_mayer
    CPU_POWERPC_405A3              = xxx,
6552 a750fc0b j_mayer
#endif
6553 a750fc0b j_mayer
#if 0
6554 80d11f44 j_mayer
    CPU_POWERPC_405A4              = xxx,
6555 a750fc0b j_mayer
#endif
6556 a750fc0b j_mayer
#if 0
6557 80d11f44 j_mayer
    CPU_POWERPC_405B3              = xxx,
6558 a750fc0b j_mayer
#endif
6559 a750fc0b j_mayer
#if 0
6560 80d11f44 j_mayer
    CPU_POWERPC_405B4              = xxx,
6561 a750fc0b j_mayer
#endif
6562 a750fc0b j_mayer
#if 0
6563 80d11f44 j_mayer
    CPU_POWERPC_405C3              = xxx,
6564 a750fc0b j_mayer
#endif
6565 a750fc0b j_mayer
#if 0
6566 80d11f44 j_mayer
    CPU_POWERPC_405C4              = xxx,
6567 a750fc0b j_mayer
#endif
6568 80d11f44 j_mayer
    CPU_POWERPC_405D2              = 0x20010000,
6569 a750fc0b j_mayer
#if 0
6570 80d11f44 j_mayer
    CPU_POWERPC_405D3              = xxx,
6571 a750fc0b j_mayer
#endif
6572 80d11f44 j_mayer
    CPU_POWERPC_405D4              = 0x41810000,
6573 a750fc0b j_mayer
#if 0
6574 80d11f44 j_mayer
    CPU_POWERPC_405D5              = xxx,
6575 a750fc0b j_mayer
#endif
6576 a750fc0b j_mayer
#if 0
6577 80d11f44 j_mayer
    CPU_POWERPC_405E4              = xxx,
6578 a750fc0b j_mayer
#endif
6579 a750fc0b j_mayer
#if 0
6580 80d11f44 j_mayer
    CPU_POWERPC_405F4              = xxx,
6581 a750fc0b j_mayer
#endif
6582 a750fc0b j_mayer
#if 0
6583 80d11f44 j_mayer
    CPU_POWERPC_405F5              = xxx,
6584 a750fc0b j_mayer
#endif
6585 a750fc0b j_mayer
#if 0
6586 80d11f44 j_mayer
    CPU_POWERPC_405F6              = xxx,
6587 a750fc0b j_mayer
#endif
6588 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers */
6589 a750fc0b j_mayer
    /* XXX: missing 0x200108a0 */
6590 80d11f44 j_mayer
#define CPU_POWERPC_405CR            CPU_POWERPC_405CRc
6591 80d11f44 j_mayer
    CPU_POWERPC_405CRa             = 0x40110041,
6592 80d11f44 j_mayer
    CPU_POWERPC_405CRb             = 0x401100C5,
6593 80d11f44 j_mayer
    CPU_POWERPC_405CRc             = 0x40110145,
6594 80d11f44 j_mayer
    CPU_POWERPC_405EP              = 0x51210950,
6595 a750fc0b j_mayer
#if 0
6596 80d11f44 j_mayer
    CPU_POWERPC_405EXr             = xxx,
6597 a750fc0b j_mayer
#endif
6598 80d11f44 j_mayer
    CPU_POWERPC_405EZ              = 0x41511460, /* 0x51210950 ? */
6599 a750fc0b j_mayer
#if 0
6600 80d11f44 j_mayer
    CPU_POWERPC_405FX              = xxx,
6601 80d11f44 j_mayer
#endif
6602 80d11f44 j_mayer
#define CPU_POWERPC_405GP            CPU_POWERPC_405GPd
6603 80d11f44 j_mayer
    CPU_POWERPC_405GPa             = 0x40110000,
6604 80d11f44 j_mayer
    CPU_POWERPC_405GPb             = 0x40110040,
6605 80d11f44 j_mayer
    CPU_POWERPC_405GPc             = 0x40110082,
6606 80d11f44 j_mayer
    CPU_POWERPC_405GPd             = 0x401100C4,
6607 80d11f44 j_mayer
#define CPU_POWERPC_405GPe           CPU_POWERPC_405CRc
6608 80d11f44 j_mayer
    CPU_POWERPC_405GPR             = 0x50910951,
6609 a750fc0b j_mayer
#if 0
6610 80d11f44 j_mayer
    CPU_POWERPC_405H               = xxx,
6611 a750fc0b j_mayer
#endif
6612 a750fc0b j_mayer
#if 0
6613 80d11f44 j_mayer
    CPU_POWERPC_405L               = xxx,
6614 a750fc0b j_mayer
#endif
6615 80d11f44 j_mayer
    CPU_POWERPC_405LP              = 0x41F10000,
6616 a750fc0b j_mayer
#if 0
6617 80d11f44 j_mayer
    CPU_POWERPC_405PM              = xxx,
6618 a750fc0b j_mayer
#endif
6619 a750fc0b j_mayer
#if 0
6620 80d11f44 j_mayer
    CPU_POWERPC_405PS              = xxx,
6621 a750fc0b j_mayer
#endif
6622 a750fc0b j_mayer
#if 0
6623 80d11f44 j_mayer
    CPU_POWERPC_405S               = xxx,
6624 a750fc0b j_mayer
#endif
6625 a750fc0b j_mayer
    /* IBM network processors */
6626 80d11f44 j_mayer
    CPU_POWERPC_NPE405H            = 0x414100C0,
6627 80d11f44 j_mayer
    CPU_POWERPC_NPE405H2           = 0x41410140,
6628 80d11f44 j_mayer
    CPU_POWERPC_NPE405L            = 0x416100C0,
6629 80d11f44 j_mayer
    CPU_POWERPC_NPE4GS3            = 0x40B10000,
6630 a750fc0b j_mayer
#if 0
6631 80d11f44 j_mayer
    CPU_POWERPC_NPCxx1             = xxx,
6632 a750fc0b j_mayer
#endif
6633 a750fc0b j_mayer
#if 0
6634 80d11f44 j_mayer
    CPU_POWERPC_NPR161             = xxx,
6635 a750fc0b j_mayer
#endif
6636 a750fc0b j_mayer
#if 0
6637 80d11f44 j_mayer
    CPU_POWERPC_LC77700            = xxx,
6638 a750fc0b j_mayer
#endif
6639 a750fc0b j_mayer
    /* IBM STBxxx (PowerPC 401/403/405 core based microcontrollers) */
6640 a750fc0b j_mayer
#if 0
6641 80d11f44 j_mayer
    CPU_POWERPC_STB01000           = xxx,
6642 a750fc0b j_mayer
#endif
6643 a750fc0b j_mayer
#if 0
6644 80d11f44 j_mayer
    CPU_POWERPC_STB01010           = xxx,
6645 a750fc0b j_mayer
#endif
6646 a750fc0b j_mayer
#if 0
6647 80d11f44 j_mayer
    CPU_POWERPC_STB0210            = xxx, /* 401B3 */
6648 a750fc0b j_mayer
#endif
6649 80d11f44 j_mayer
    CPU_POWERPC_STB03              = 0x40310000, /* 0x40130000 ? */
6650 a750fc0b j_mayer
#if 0
6651 80d11f44 j_mayer
    CPU_POWERPC_STB043             = xxx,
6652 a750fc0b j_mayer
#endif
6653 a750fc0b j_mayer
#if 0
6654 80d11f44 j_mayer
    CPU_POWERPC_STB045             = xxx,
6655 a750fc0b j_mayer
#endif
6656 80d11f44 j_mayer
    CPU_POWERPC_STB04              = 0x41810000,
6657 80d11f44 j_mayer
    CPU_POWERPC_STB25              = 0x51510950,
6658 a750fc0b j_mayer
#if 0
6659 80d11f44 j_mayer
    CPU_POWERPC_STB130             = xxx,
6660 a750fc0b j_mayer
#endif
6661 a750fc0b j_mayer
    /* Xilinx cores */
6662 80d11f44 j_mayer
    CPU_POWERPC_X2VP4              = 0x20010820,
6663 80d11f44 j_mayer
#define CPU_POWERPC_X2VP7            CPU_POWERPC_X2VP4
6664 80d11f44 j_mayer
    CPU_POWERPC_X2VP20             = 0x20010860,
6665 80d11f44 j_mayer
#define CPU_POWERPC_X2VP50           CPU_POWERPC_X2VP20
6666 a750fc0b j_mayer
#if 0
6667 80d11f44 j_mayer
    CPU_POWERPC_ZL10310            = xxx,
6668 a750fc0b j_mayer
#endif
6669 a750fc0b j_mayer
#if 0
6670 80d11f44 j_mayer
    CPU_POWERPC_ZL10311            = xxx,
6671 a750fc0b j_mayer
#endif
6672 a750fc0b j_mayer
#if 0
6673 80d11f44 j_mayer
    CPU_POWERPC_ZL10320            = xxx,
6674 a750fc0b j_mayer
#endif
6675 a750fc0b j_mayer
#if 0
6676 80d11f44 j_mayer
    CPU_POWERPC_ZL10321            = xxx,
6677 a750fc0b j_mayer
#endif
6678 a750fc0b j_mayer
    /* PowerPC 440 family */
6679 a750fc0b j_mayer
    /* Generic PowerPC 440 */
6680 80d11f44 j_mayer
#define CPU_POWERPC_440              CPU_POWERPC_440GXf
6681 a750fc0b j_mayer
    /* PowerPC 440 cores */
6682 a750fc0b j_mayer
#if 0
6683 80d11f44 j_mayer
    CPU_POWERPC_440A4              = xxx,
6684 a750fc0b j_mayer
#endif
6685 95070372 Edgar E. Iglesias
    CPU_POWERPC_440_XILINX         = 0x7ff21910,
6686 a750fc0b j_mayer
#if 0
6687 80d11f44 j_mayer
    CPU_POWERPC_440A5              = xxx,
6688 a750fc0b j_mayer
#endif
6689 a750fc0b j_mayer
#if 0
6690 80d11f44 j_mayer
    CPU_POWERPC_440B4              = xxx,
6691 a750fc0b j_mayer
#endif
6692 a750fc0b j_mayer
#if 0
6693 80d11f44 j_mayer
    CPU_POWERPC_440F5              = xxx,
6694 a750fc0b j_mayer
#endif
6695 a750fc0b j_mayer
#if 0
6696 80d11f44 j_mayer
    CPU_POWERPC_440G5              = xxx,
6697 a750fc0b j_mayer
#endif
6698 a750fc0b j_mayer
#if 0
6699 80d11f44 j_mayer
    CPU_POWERPC_440H4              = xxx,
6700 a750fc0b j_mayer
#endif
6701 a750fc0b j_mayer
#if 0
6702 80d11f44 j_mayer
    CPU_POWERPC_440H6              = xxx,
6703 a750fc0b j_mayer
#endif
6704 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers */
6705 80d11f44 j_mayer
#define CPU_POWERPC_440EP            CPU_POWERPC_440EPb
6706 80d11f44 j_mayer
    CPU_POWERPC_440EPa             = 0x42221850,
6707 80d11f44 j_mayer
    CPU_POWERPC_440EPb             = 0x422218D3,
6708 80d11f44 j_mayer
#define CPU_POWERPC_440GP            CPU_POWERPC_440GPc
6709 80d11f44 j_mayer
    CPU_POWERPC_440GPb             = 0x40120440,
6710 80d11f44 j_mayer
    CPU_POWERPC_440GPc             = 0x40120481,
6711 80d11f44 j_mayer
#define CPU_POWERPC_440GR            CPU_POWERPC_440GRa
6712 80d11f44 j_mayer
#define CPU_POWERPC_440GRa           CPU_POWERPC_440EPb
6713 80d11f44 j_mayer
    CPU_POWERPC_440GRX             = 0x200008D0,
6714 80d11f44 j_mayer
#define CPU_POWERPC_440EPX           CPU_POWERPC_440GRX
6715 80d11f44 j_mayer
#define CPU_POWERPC_440GX            CPU_POWERPC_440GXf
6716 80d11f44 j_mayer
    CPU_POWERPC_440GXa             = 0x51B21850,
6717 80d11f44 j_mayer
    CPU_POWERPC_440GXb             = 0x51B21851,
6718 80d11f44 j_mayer
    CPU_POWERPC_440GXc             = 0x51B21892,
6719 80d11f44 j_mayer
    CPU_POWERPC_440GXf             = 0x51B21894,
6720 a750fc0b j_mayer
#if 0
6721 80d11f44 j_mayer
    CPU_POWERPC_440S               = xxx,
6722 a750fc0b j_mayer
#endif
6723 80d11f44 j_mayer
    CPU_POWERPC_440SP              = 0x53221850,
6724 80d11f44 j_mayer
    CPU_POWERPC_440SP2             = 0x53221891,
6725 80d11f44 j_mayer
    CPU_POWERPC_440SPE             = 0x53421890,
6726 a750fc0b j_mayer
    /* PowerPC 460 family */
6727 a750fc0b j_mayer
#if 0
6728 a750fc0b j_mayer
    /* Generic PowerPC 464 */
6729 80d11f44 j_mayer
#define CPU_POWERPC_464              CPU_POWERPC_464H90
6730 a750fc0b j_mayer
#endif
6731 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers */
6732 a750fc0b j_mayer
#if 0
6733 80d11f44 j_mayer
    CPU_POWERPC_464H90             = xxx,
6734 a750fc0b j_mayer
#endif
6735 a750fc0b j_mayer
#if 0
6736 80d11f44 j_mayer
    CPU_POWERPC_464H90FP           = xxx,
6737 a750fc0b j_mayer
#endif
6738 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores */
6739 c3e36823 j_mayer
    /* PowerPC MPC 5xx cores (aka RCPU) */
6740 80d11f44 j_mayer
    CPU_POWERPC_MPC5xx             = 0x00020020,
6741 80d11f44 j_mayer
#define CPU_POWERPC_MGT560           CPU_POWERPC_MPC5xx
6742 80d11f44 j_mayer
#define CPU_POWERPC_MPC509           CPU_POWERPC_MPC5xx
6743 80d11f44 j_mayer
#define CPU_POWERPC_MPC533           CPU_POWERPC_MPC5xx
6744 80d11f44 j_mayer
#define CPU_POWERPC_MPC534           CPU_POWERPC_MPC5xx
6745 80d11f44 j_mayer
#define CPU_POWERPC_MPC555           CPU_POWERPC_MPC5xx
6746 80d11f44 j_mayer
#define CPU_POWERPC_MPC556           CPU_POWERPC_MPC5xx
6747 80d11f44 j_mayer
#define CPU_POWERPC_MPC560           CPU_POWERPC_MPC5xx
6748 80d11f44 j_mayer
#define CPU_POWERPC_MPC561           CPU_POWERPC_MPC5xx
6749 80d11f44 j_mayer
#define CPU_POWERPC_MPC562           CPU_POWERPC_MPC5xx
6750 80d11f44 j_mayer
#define CPU_POWERPC_MPC563           CPU_POWERPC_MPC5xx
6751 80d11f44 j_mayer
#define CPU_POWERPC_MPC564           CPU_POWERPC_MPC5xx
6752 80d11f44 j_mayer
#define CPU_POWERPC_MPC565           CPU_POWERPC_MPC5xx
6753 80d11f44 j_mayer
#define CPU_POWERPC_MPC566           CPU_POWERPC_MPC5xx
6754 c3e36823 j_mayer
    /* PowerPC MPC 8xx cores (aka PowerQUICC) */
6755 80d11f44 j_mayer
    CPU_POWERPC_MPC8xx             = 0x00500000,
6756 80d11f44 j_mayer
#define CPU_POWERPC_MGT823           CPU_POWERPC_MPC8xx
6757 80d11f44 j_mayer
#define CPU_POWERPC_MPC821           CPU_POWERPC_MPC8xx
6758 80d11f44 j_mayer
#define CPU_POWERPC_MPC823           CPU_POWERPC_MPC8xx
6759 80d11f44 j_mayer
#define CPU_POWERPC_MPC850           CPU_POWERPC_MPC8xx
6760 80d11f44 j_mayer
#define CPU_POWERPC_MPC852T          CPU_POWERPC_MPC8xx
6761 80d11f44 j_mayer
#define CPU_POWERPC_MPC855T          CPU_POWERPC_MPC8xx
6762 80d11f44 j_mayer
#define CPU_POWERPC_MPC857           CPU_POWERPC_MPC8xx
6763 80d11f44 j_mayer
#define CPU_POWERPC_MPC859           CPU_POWERPC_MPC8xx
6764 80d11f44 j_mayer
#define CPU_POWERPC_MPC860           CPU_POWERPC_MPC8xx
6765 80d11f44 j_mayer
#define CPU_POWERPC_MPC862           CPU_POWERPC_MPC8xx
6766 80d11f44 j_mayer
#define CPU_POWERPC_MPC866           CPU_POWERPC_MPC8xx
6767 80d11f44 j_mayer
#define CPU_POWERPC_MPC870           CPU_POWERPC_MPC8xx
6768 80d11f44 j_mayer
#define CPU_POWERPC_MPC875           CPU_POWERPC_MPC8xx
6769 80d11f44 j_mayer
#define CPU_POWERPC_MPC880           CPU_POWERPC_MPC8xx
6770 80d11f44 j_mayer
#define CPU_POWERPC_MPC885           CPU_POWERPC_MPC8xx
6771 c3e36823 j_mayer
    /* G2 cores (aka PowerQUICC-II) */
6772 80d11f44 j_mayer
    CPU_POWERPC_G2                 = 0x00810011,
6773 80d11f44 j_mayer
    CPU_POWERPC_G2H4               = 0x80811010,
6774 80d11f44 j_mayer
    CPU_POWERPC_G2gp               = 0x80821010,
6775 80d11f44 j_mayer
    CPU_POWERPC_G2ls               = 0x90810010,
6776 80d11f44 j_mayer
    CPU_POWERPC_MPC603             = 0x00810100,
6777 80d11f44 j_mayer
    CPU_POWERPC_G2_HIP3            = 0x00810101,
6778 80d11f44 j_mayer
    CPU_POWERPC_G2_HIP4            = 0x80811014,
6779 c3e36823 j_mayer
    /*   G2_LE core (aka PowerQUICC-II) */
6780 80d11f44 j_mayer
    CPU_POWERPC_G2LE               = 0x80820010,
6781 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp             = 0x80822010,
6782 80d11f44 j_mayer
    CPU_POWERPC_G2LEls             = 0xA0822010,
6783 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp1            = 0x80822011,
6784 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp3            = 0x80822013,
6785 80d11f44 j_mayer
    /* MPC52xx microcontrollers  */
6786 c3e36823 j_mayer
    /* XXX: MPC 5121 ? */
6787 80d11f44 j_mayer
#define CPU_POWERPC_MPC52xx          CPU_POWERPC_MPC5200
6788 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200          CPU_POWERPC_MPC5200_v12
6789 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v10      CPU_POWERPC_G2LEgp1
6790 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v11      CPU_POWERPC_G2LEgp1
6791 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v12      CPU_POWERPC_G2LEgp1
6792 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B         CPU_POWERPC_MPC5200B_v21
6793 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B_v20     CPU_POWERPC_G2LEgp1
6794 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B_v21     CPU_POWERPC_G2LEgp1
6795 80d11f44 j_mayer
    /* MPC82xx microcontrollers */
6796 80d11f44 j_mayer
#define CPU_POWERPC_MPC82xx          CPU_POWERPC_MPC8280
6797 80d11f44 j_mayer
#define CPU_POWERPC_MPC8240          CPU_POWERPC_MPC603
6798 80d11f44 j_mayer
#define CPU_POWERPC_MPC8241          CPU_POWERPC_G2_HIP4
6799 80d11f44 j_mayer
#define CPU_POWERPC_MPC8245          CPU_POWERPC_G2_HIP4
6800 80d11f44 j_mayer
#define CPU_POWERPC_MPC8247          CPU_POWERPC_G2LEgp3
6801 80d11f44 j_mayer
#define CPU_POWERPC_MPC8248          CPU_POWERPC_G2LEgp3
6802 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250          CPU_POWERPC_MPC8250_HiP4
6803 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250_HiP3     CPU_POWERPC_G2_HIP3
6804 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250_HiP4     CPU_POWERPC_G2_HIP4
6805 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255          CPU_POWERPC_MPC8255_HiP4
6806 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255_HiP3     CPU_POWERPC_G2_HIP3
6807 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255_HiP4     CPU_POWERPC_G2_HIP4
6808 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260          CPU_POWERPC_MPC8260_HiP4
6809 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260_HiP3     CPU_POWERPC_G2_HIP3
6810 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260_HiP4     CPU_POWERPC_G2_HIP4
6811 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264          CPU_POWERPC_MPC8264_HiP4
6812 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264_HiP3     CPU_POWERPC_G2_HIP3
6813 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264_HiP4     CPU_POWERPC_G2_HIP4
6814 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265          CPU_POWERPC_MPC8265_HiP4
6815 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265_HiP3     CPU_POWERPC_G2_HIP3
6816 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265_HiP4     CPU_POWERPC_G2_HIP4
6817 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266          CPU_POWERPC_MPC8266_HiP4
6818 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266_HiP3     CPU_POWERPC_G2_HIP3
6819 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266_HiP4     CPU_POWERPC_G2_HIP4
6820 80d11f44 j_mayer
#define CPU_POWERPC_MPC8270          CPU_POWERPC_G2LEgp3
6821 80d11f44 j_mayer
#define CPU_POWERPC_MPC8271          CPU_POWERPC_G2LEgp3
6822 80d11f44 j_mayer
#define CPU_POWERPC_MPC8272          CPU_POWERPC_G2LEgp3
6823 80d11f44 j_mayer
#define CPU_POWERPC_MPC8275          CPU_POWERPC_G2LEgp3
6824 80d11f44 j_mayer
#define CPU_POWERPC_MPC8280          CPU_POWERPC_G2LEgp3
6825 a750fc0b j_mayer
    /* e200 family */
6826 80d11f44 j_mayer
    /* e200 cores */
6827 80d11f44 j_mayer
#define CPU_POWERPC_e200             CPU_POWERPC_e200z6
6828 a750fc0b j_mayer
#if 0
6829 80d11f44 j_mayer
    CPU_POWERPC_e200z0             = xxx,
6830 a750fc0b j_mayer
#endif
6831 a750fc0b j_mayer
#if 0
6832 80d11f44 j_mayer
    CPU_POWERPC_e200z1             = xxx,
6833 c3e36823 j_mayer
#endif
6834 c3e36823 j_mayer
#if 0 /* ? */
6835 80d11f44 j_mayer
    CPU_POWERPC_e200z3             = 0x81120000,
6836 80d11f44 j_mayer
#endif
6837 80d11f44 j_mayer
    CPU_POWERPC_e200z5             = 0x81000000,
6838 80d11f44 j_mayer
    CPU_POWERPC_e200z6             = 0x81120000,
6839 80d11f44 j_mayer
    /* MPC55xx microcontrollers */
6840 80d11f44 j_mayer
#define CPU_POWERPC_MPC55xx          CPU_POWERPC_MPC5567
6841 80d11f44 j_mayer
#if 0
6842 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E         CPU_POWERPC_MPC5514E_v1
6843 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E_v0      CPU_POWERPC_e200z0
6844 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E_v1      CPU_POWERPC_e200z1
6845 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G         CPU_POWERPC_MPC5514G_v1
6846 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G_v0      CPU_POWERPC_e200z0
6847 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G_v1      CPU_POWERPC_e200z1
6848 80d11f44 j_mayer
#define CPU_POWERPC_MPC5515S         CPU_POWERPC_e200z1
6849 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E         CPU_POWERPC_MPC5516E_v1
6850 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E_v0      CPU_POWERPC_e200z0
6851 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E_v1      CPU_POWERPC_e200z1
6852 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G         CPU_POWERPC_MPC5516G_v1
6853 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G_v0      CPU_POWERPC_e200z0
6854 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G_v1      CPU_POWERPC_e200z1
6855 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516S         CPU_POWERPC_e200z1
6856 80d11f44 j_mayer
#endif
6857 80d11f44 j_mayer
#if 0
6858 80d11f44 j_mayer
#define CPU_POWERPC_MPC5533          CPU_POWERPC_e200z3
6859 80d11f44 j_mayer
#define CPU_POWERPC_MPC5534          CPU_POWERPC_e200z3
6860 80d11f44 j_mayer
#endif
6861 80d11f44 j_mayer
#define CPU_POWERPC_MPC5553          CPU_POWERPC_e200z6
6862 80d11f44 j_mayer
#define CPU_POWERPC_MPC5554          CPU_POWERPC_e200z6
6863 80d11f44 j_mayer
#define CPU_POWERPC_MPC5561          CPU_POWERPC_e200z6
6864 80d11f44 j_mayer
#define CPU_POWERPC_MPC5565          CPU_POWERPC_e200z6
6865 80d11f44 j_mayer
#define CPU_POWERPC_MPC5566          CPU_POWERPC_e200z6
6866 80d11f44 j_mayer
#define CPU_POWERPC_MPC5567          CPU_POWERPC_e200z6
6867 a750fc0b j_mayer
    /* e300 family */
6868 80d11f44 j_mayer
    /* e300 cores */
6869 80d11f44 j_mayer
#define CPU_POWERPC_e300             CPU_POWERPC_e300c3
6870 80d11f44 j_mayer
    CPU_POWERPC_e300c1             = 0x00830010,
6871 80d11f44 j_mayer
    CPU_POWERPC_e300c2             = 0x00840010,
6872 80d11f44 j_mayer
    CPU_POWERPC_e300c3             = 0x00850010,
6873 80d11f44 j_mayer
    CPU_POWERPC_e300c4             = 0x00860010,
6874 80d11f44 j_mayer
    /* MPC83xx microcontrollers */
6875 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC831x          CPU_POWERPC_e300c3
6876 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC832x          CPU_POWERPC_e300c2
6877 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC834x          CPU_POWERPC_e300c1
6878 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC835x          CPU_POWERPC_e300c1
6879 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC836x          CPU_POWERPC_e300c1
6880 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC837x          CPU_POWERPC_e300c4
6881 a750fc0b j_mayer
    /* e500 family */
6882 80d11f44 j_mayer
    /* e500 cores  */
6883 80d11f44 j_mayer
#define CPU_POWERPC_e500             CPU_POWERPC_e500v2_v22
6884 bd5ea513 aurel32
#define CPU_POWERPC_e500v1           CPU_POWERPC_e500v1_v20
6885 80d11f44 j_mayer
#define CPU_POWERPC_e500v2           CPU_POWERPC_e500v2_v22
6886 bd5ea513 aurel32
    CPU_POWERPC_e500v1_v10         = 0x80200010,
6887 bd5ea513 aurel32
    CPU_POWERPC_e500v1_v20         = 0x80200020,
6888 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v10         = 0x80210010,
6889 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v11         = 0x80210011,
6890 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v20         = 0x80210020,
6891 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v21         = 0x80210021,
6892 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v22         = 0x80210022,
6893 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v30         = 0x80210030,
6894 80d11f44 j_mayer
    /* MPC85xx microcontrollers */
6895 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533          CPU_POWERPC_MPC8533_v11
6896 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533_v10      CPU_POWERPC_e500v2_v21
6897 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533_v11      CPU_POWERPC_e500v2_v22
6898 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E         CPU_POWERPC_MPC8533E_v11
6899 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E_v10     CPU_POWERPC_e500v2_v21
6900 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E_v11     CPU_POWERPC_e500v2_v22
6901 80d11f44 j_mayer
#define CPU_POWERPC_MPC8540          CPU_POWERPC_MPC8540_v21
6902 bd5ea513 aurel32
#define CPU_POWERPC_MPC8540_v10      CPU_POWERPC_e500v1_v10
6903 bd5ea513 aurel32
#define CPU_POWERPC_MPC8540_v20      CPU_POWERPC_e500v1_v20
6904 bd5ea513 aurel32
#define CPU_POWERPC_MPC8540_v21      CPU_POWERPC_e500v1_v20
6905 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541          CPU_POWERPC_MPC8541_v11
6906 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541_v10      CPU_POWERPC_e500v1_v20
6907 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541_v11      CPU_POWERPC_e500v1_v20
6908 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541E         CPU_POWERPC_MPC8541E_v11
6909 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541E_v10     CPU_POWERPC_e500v1_v20
6910 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541E_v11     CPU_POWERPC_e500v1_v20
6911 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543          CPU_POWERPC_MPC8543_v21
6912 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v10      CPU_POWERPC_e500v2_v10
6913 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v11      CPU_POWERPC_e500v2_v11
6914 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v20      CPU_POWERPC_e500v2_v20
6915 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v21      CPU_POWERPC_e500v2_v21
6916 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E         CPU_POWERPC_MPC8543E_v21
6917 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v10     CPU_POWERPC_e500v2_v10
6918 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v11     CPU_POWERPC_e500v2_v11
6919 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v20     CPU_POWERPC_e500v2_v20
6920 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v21     CPU_POWERPC_e500v2_v21
6921 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544          CPU_POWERPC_MPC8544_v11
6922 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544_v10      CPU_POWERPC_e500v2_v21
6923 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544_v11      CPU_POWERPC_e500v2_v22
6924 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E_v11     CPU_POWERPC_e500v2_v22
6925 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E         CPU_POWERPC_MPC8544E_v11
6926 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E_v10     CPU_POWERPC_e500v2_v21
6927 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545          CPU_POWERPC_MPC8545_v21
6928 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v10      CPU_POWERPC_e500v2_v10
6929 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v20      CPU_POWERPC_e500v2_v20
6930 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v21      CPU_POWERPC_e500v2_v21
6931 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E         CPU_POWERPC_MPC8545E_v21
6932 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v10     CPU_POWERPC_e500v2_v10
6933 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v20     CPU_POWERPC_e500v2_v20
6934 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v21     CPU_POWERPC_e500v2_v21
6935 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E         CPU_POWERPC_MPC8545E_v21
6936 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v10     CPU_POWERPC_e500v2_v10
6937 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v20     CPU_POWERPC_e500v2_v20
6938 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v21     CPU_POWERPC_e500v2_v21
6939 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548          CPU_POWERPC_MPC8548_v21
6940 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v10      CPU_POWERPC_e500v2_v10
6941 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v11      CPU_POWERPC_e500v2_v11
6942 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v20      CPU_POWERPC_e500v2_v20
6943 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v21      CPU_POWERPC_e500v2_v21
6944 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E         CPU_POWERPC_MPC8548E_v21
6945 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v10     CPU_POWERPC_e500v2_v10
6946 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v11     CPU_POWERPC_e500v2_v11
6947 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v20     CPU_POWERPC_e500v2_v20
6948 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v21     CPU_POWERPC_e500v2_v21
6949 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555          CPU_POWERPC_MPC8555_v11
6950 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555_v10      CPU_POWERPC_e500v2_v10
6951 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555_v11      CPU_POWERPC_e500v2_v11
6952 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E         CPU_POWERPC_MPC8555E_v11
6953 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E_v10     CPU_POWERPC_e500v2_v10
6954 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E_v11     CPU_POWERPC_e500v2_v11
6955 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560          CPU_POWERPC_MPC8560_v21
6956 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v10      CPU_POWERPC_e500v2_v10
6957 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v20      CPU_POWERPC_e500v2_v20
6958 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v21      CPU_POWERPC_e500v2_v21
6959 80d11f44 j_mayer
#define CPU_POWERPC_MPC8567          CPU_POWERPC_e500v2_v22
6960 80d11f44 j_mayer
#define CPU_POWERPC_MPC8567E         CPU_POWERPC_e500v2_v22
6961 80d11f44 j_mayer
#define CPU_POWERPC_MPC8568          CPU_POWERPC_e500v2_v22
6962 80d11f44 j_mayer
#define CPU_POWERPC_MPC8568E         CPU_POWERPC_e500v2_v22
6963 80d11f44 j_mayer
#define CPU_POWERPC_MPC8572          CPU_POWERPC_e500v2_v30
6964 80d11f44 j_mayer
#define CPU_POWERPC_MPC8572E         CPU_POWERPC_e500v2_v30
6965 a750fc0b j_mayer
    /* e600 family */
6966 80d11f44 j_mayer
    /* e600 cores */
6967 80d11f44 j_mayer
    CPU_POWERPC_e600               = 0x80040010,
6968 80d11f44 j_mayer
    /* MPC86xx microcontrollers */
6969 80d11f44 j_mayer
#define CPU_POWERPC_MPC8610          CPU_POWERPC_e600
6970 80d11f44 j_mayer
#define CPU_POWERPC_MPC8641          CPU_POWERPC_e600
6971 80d11f44 j_mayer
#define CPU_POWERPC_MPC8641D         CPU_POWERPC_e600
6972 a750fc0b j_mayer
    /* PowerPC 6xx cores */
6973 80d11f44 j_mayer
#define CPU_POWERPC_601              CPU_POWERPC_601_v2
6974 80d11f44 j_mayer
    CPU_POWERPC_601_v0             = 0x00010001,
6975 80d11f44 j_mayer
    CPU_POWERPC_601_v1             = 0x00010001,
6976 bd928eba j_mayer
#define CPU_POWERPC_601v             CPU_POWERPC_601_v2
6977 80d11f44 j_mayer
    CPU_POWERPC_601_v2             = 0x00010002,
6978 80d11f44 j_mayer
    CPU_POWERPC_602                = 0x00050100,
6979 80d11f44 j_mayer
    CPU_POWERPC_603                = 0x00030100,
6980 80d11f44 j_mayer
#define CPU_POWERPC_603E             CPU_POWERPC_603E_v41
6981 80d11f44 j_mayer
    CPU_POWERPC_603E_v11           = 0x00060101,
6982 80d11f44 j_mayer
    CPU_POWERPC_603E_v12           = 0x00060102,
6983 80d11f44 j_mayer
    CPU_POWERPC_603E_v13           = 0x00060103,
6984 80d11f44 j_mayer
    CPU_POWERPC_603E_v14           = 0x00060104,
6985 80d11f44 j_mayer
    CPU_POWERPC_603E_v22           = 0x00060202,
6986 80d11f44 j_mayer
    CPU_POWERPC_603E_v3            = 0x00060300,
6987 80d11f44 j_mayer
    CPU_POWERPC_603E_v4            = 0x00060400,
6988 80d11f44 j_mayer
    CPU_POWERPC_603E_v41           = 0x00060401,
6989 80d11f44 j_mayer
    CPU_POWERPC_603E7t             = 0x00071201,
6990 80d11f44 j_mayer
    CPU_POWERPC_603E7v             = 0x00070100,
6991 80d11f44 j_mayer
    CPU_POWERPC_603E7v1            = 0x00070101,
6992 80d11f44 j_mayer
    CPU_POWERPC_603E7v2            = 0x00070201,
6993 80d11f44 j_mayer
    CPU_POWERPC_603E7              = 0x00070200,
6994 80d11f44 j_mayer
    CPU_POWERPC_603P               = 0x00070000,
6995 80d11f44 j_mayer
#define CPU_POWERPC_603R             CPU_POWERPC_603E7t
6996 c3e36823 j_mayer
    /* XXX: missing 0x00040303 (604) */
6997 80d11f44 j_mayer
    CPU_POWERPC_604                = 0x00040103,
6998 80d11f44 j_mayer
#define CPU_POWERPC_604E             CPU_POWERPC_604E_v24
6999 c3e36823 j_mayer
    /* XXX: missing 0x00091203 */
7000 c3e36823 j_mayer
    /* XXX: missing 0x00092110 */
7001 c3e36823 j_mayer
    /* XXX: missing 0x00092120 */
7002 80d11f44 j_mayer
    CPU_POWERPC_604E_v10           = 0x00090100,
7003 80d11f44 j_mayer
    CPU_POWERPC_604E_v22           = 0x00090202,
7004 80d11f44 j_mayer
    CPU_POWERPC_604E_v24           = 0x00090204,
7005 c3e36823 j_mayer
    /* XXX: missing 0x000a0100 */
7006 c3e36823 j_mayer
    /* XXX: missing 0x00093102 */
7007 80d11f44 j_mayer
    CPU_POWERPC_604R               = 0x000a0101,
7008 a750fc0b j_mayer
#if 0
7009 80d11f44 j_mayer
    CPU_POWERPC_604EV              = xxx, /* XXX: same as 604R ? */
7010 a750fc0b j_mayer
#endif
7011 a750fc0b j_mayer
    /* PowerPC 740/750 cores (aka G3) */
7012 a750fc0b j_mayer
    /* XXX: missing 0x00084202 */
7013 80d11f44 j_mayer
#define CPU_POWERPC_7x0              CPU_POWERPC_7x0_v31
7014 bd928eba j_mayer
    CPU_POWERPC_7x0_v10            = 0x00080100,
7015 80d11f44 j_mayer
    CPU_POWERPC_7x0_v20            = 0x00080200,
7016 80d11f44 j_mayer
    CPU_POWERPC_7x0_v21            = 0x00080201,
7017 80d11f44 j_mayer
    CPU_POWERPC_7x0_v22            = 0x00080202,
7018 80d11f44 j_mayer
    CPU_POWERPC_7x0_v30            = 0x00080300,
7019 80d11f44 j_mayer
    CPU_POWERPC_7x0_v31            = 0x00080301,
7020 80d11f44 j_mayer
    CPU_POWERPC_740E               = 0x00080100,
7021 bd928eba j_mayer
    CPU_POWERPC_750E               = 0x00080200,
7022 80d11f44 j_mayer
    CPU_POWERPC_7x0P               = 0x10080000,
7023 a750fc0b j_mayer
    /* XXX: missing 0x00087010 (CL ?) */
7024 bd928eba j_mayer
#define CPU_POWERPC_750CL            CPU_POWERPC_750CL_v20
7025 bd928eba j_mayer
    CPU_POWERPC_750CL_v10          = 0x00087200,
7026 bd928eba j_mayer
    CPU_POWERPC_750CL_v20          = 0x00087210, /* aka rev E */
7027 80d11f44 j_mayer
#define CPU_POWERPC_750CX            CPU_POWERPC_750CX_v22
7028 bd928eba j_mayer
    CPU_POWERPC_750CX_v10          = 0x00082100,
7029 bd928eba j_mayer
    CPU_POWERPC_750CX_v20          = 0x00082200,
7030 80d11f44 j_mayer
    CPU_POWERPC_750CX_v21          = 0x00082201,
7031 80d11f44 j_mayer
    CPU_POWERPC_750CX_v22          = 0x00082202,
7032 80d11f44 j_mayer
#define CPU_POWERPC_750CXE           CPU_POWERPC_750CXE_v31b
7033 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v21         = 0x00082211,
7034 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v22         = 0x00082212,
7035 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v23         = 0x00082213,
7036 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v24         = 0x00082214,
7037 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v24b        = 0x00083214,
7038 bd928eba j_mayer
    CPU_POWERPC_750CXE_v30         = 0x00082310,
7039 bd928eba j_mayer
    CPU_POWERPC_750CXE_v31         = 0x00082311,
7040 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v31b        = 0x00083311,
7041 80d11f44 j_mayer
    CPU_POWERPC_750CXR             = 0x00083410,
7042 bd928eba j_mayer
    CPU_POWERPC_750FL              = 0x70000203,
7043 80d11f44 j_mayer
#define CPU_POWERPC_750FX            CPU_POWERPC_750FX_v23
7044 80d11f44 j_mayer
    CPU_POWERPC_750FX_v10          = 0x70000100,
7045 80d11f44 j_mayer
    CPU_POWERPC_750FX_v20          = 0x70000200,
7046 80d11f44 j_mayer
    CPU_POWERPC_750FX_v21          = 0x70000201,
7047 80d11f44 j_mayer
    CPU_POWERPC_750FX_v22          = 0x70000202,
7048 80d11f44 j_mayer
    CPU_POWERPC_750FX_v23          = 0x70000203,
7049 80d11f44 j_mayer
    CPU_POWERPC_750GL              = 0x70020102,
7050 80d11f44 j_mayer
#define CPU_POWERPC_750GX            CPU_POWERPC_750GX_v12
7051 80d11f44 j_mayer
    CPU_POWERPC_750GX_v10          = 0x70020100,
7052 80d11f44 j_mayer
    CPU_POWERPC_750GX_v11          = 0x70020101,
7053 80d11f44 j_mayer
    CPU_POWERPC_750GX_v12          = 0x70020102,
7054 80d11f44 j_mayer
#define CPU_POWERPC_750L             CPU_POWERPC_750L_v32 /* Aka LoneStar */
7055 bd928eba j_mayer
    CPU_POWERPC_750L_v20           = 0x00088200,
7056 bd928eba j_mayer
    CPU_POWERPC_750L_v21           = 0x00088201,
7057 80d11f44 j_mayer
    CPU_POWERPC_750L_v22           = 0x00088202,
7058 80d11f44 j_mayer
    CPU_POWERPC_750L_v30           = 0x00088300,
7059 80d11f44 j_mayer
    CPU_POWERPC_750L_v32           = 0x00088302,
7060 a750fc0b j_mayer
    /* PowerPC 745/755 cores */
7061 80d11f44 j_mayer
#define CPU_POWERPC_7x5              CPU_POWERPC_7x5_v28
7062 80d11f44 j_mayer
    CPU_POWERPC_7x5_v10            = 0x00083100,
7063 80d11f44 j_mayer
    CPU_POWERPC_7x5_v11            = 0x00083101,
7064 80d11f44 j_mayer
    CPU_POWERPC_7x5_v20            = 0x00083200,
7065 80d11f44 j_mayer
    CPU_POWERPC_7x5_v21            = 0x00083201,
7066 80d11f44 j_mayer
    CPU_POWERPC_7x5_v22            = 0x00083202, /* aka D */
7067 80d11f44 j_mayer
    CPU_POWERPC_7x5_v23            = 0x00083203, /* aka E */
7068 80d11f44 j_mayer
    CPU_POWERPC_7x5_v24            = 0x00083204,
7069 80d11f44 j_mayer
    CPU_POWERPC_7x5_v25            = 0x00083205,
7070 80d11f44 j_mayer
    CPU_POWERPC_7x5_v26            = 0x00083206,
7071 80d11f44 j_mayer
    CPU_POWERPC_7x5_v27            = 0x00083207,
7072 80d11f44 j_mayer
    CPU_POWERPC_7x5_v28            = 0x00083208,
7073 a750fc0b j_mayer
#if 0
7074 80d11f44 j_mayer
    CPU_POWERPC_7x5P               = xxx,
7075 a750fc0b j_mayer
#endif
7076 a750fc0b j_mayer
    /* PowerPC 74xx cores (aka G4) */
7077 a750fc0b j_mayer
    /* XXX: missing 0x000C1101 */
7078 80d11f44 j_mayer
#define CPU_POWERPC_7400             CPU_POWERPC_7400_v29
7079 80d11f44 j_mayer
    CPU_POWERPC_7400_v10           = 0x000C0100,
7080 80d11f44 j_mayer
    CPU_POWERPC_7400_v11           = 0x000C0101,
7081 80d11f44 j_mayer
    CPU_POWERPC_7400_v20           = 0x000C0200,
7082 4e777442 j_mayer
    CPU_POWERPC_7400_v21           = 0x000C0201,
7083 80d11f44 j_mayer
    CPU_POWERPC_7400_v22           = 0x000C0202,
7084 80d11f44 j_mayer
    CPU_POWERPC_7400_v26           = 0x000C0206,
7085 80d11f44 j_mayer
    CPU_POWERPC_7400_v27           = 0x000C0207,
7086 80d11f44 j_mayer
    CPU_POWERPC_7400_v28           = 0x000C0208,
7087 80d11f44 j_mayer
    CPU_POWERPC_7400_v29           = 0x000C0209,
7088 80d11f44 j_mayer
#define CPU_POWERPC_7410             CPU_POWERPC_7410_v14
7089 80d11f44 j_mayer
    CPU_POWERPC_7410_v10           = 0x800C1100,
7090 80d11f44 j_mayer
    CPU_POWERPC_7410_v11           = 0x800C1101,
7091 80d11f44 j_mayer
    CPU_POWERPC_7410_v12           = 0x800C1102, /* aka C */
7092 80d11f44 j_mayer
    CPU_POWERPC_7410_v13           = 0x800C1103, /* aka D */
7093 80d11f44 j_mayer
    CPU_POWERPC_7410_v14           = 0x800C1104, /* aka E */
7094 80d11f44 j_mayer
#define CPU_POWERPC_7448             CPU_POWERPC_7448_v21
7095 80d11f44 j_mayer
    CPU_POWERPC_7448_v10           = 0x80040100,
7096 80d11f44 j_mayer
    CPU_POWERPC_7448_v11           = 0x80040101,
7097 80d11f44 j_mayer
    CPU_POWERPC_7448_v20           = 0x80040200,
7098 80d11f44 j_mayer
    CPU_POWERPC_7448_v21           = 0x80040201,
7099 80d11f44 j_mayer
#define CPU_POWERPC_7450             CPU_POWERPC_7450_v21
7100 80d11f44 j_mayer
    CPU_POWERPC_7450_v10           = 0x80000100,
7101 80d11f44 j_mayer
    CPU_POWERPC_7450_v11           = 0x80000101,
7102 80d11f44 j_mayer
    CPU_POWERPC_7450_v12           = 0x80000102,
7103 4e777442 j_mayer
    CPU_POWERPC_7450_v20           = 0x80000200, /* aka A, B, C, D: 2.04 */
7104 80d11f44 j_mayer
    CPU_POWERPC_7450_v21           = 0x80000201, /* aka E */
7105 4e777442 j_mayer
#define CPU_POWERPC_74x1             CPU_POWERPC_74x1_v23
7106 4e777442 j_mayer
    CPU_POWERPC_74x1_v23           = 0x80000203, /* aka G: 2.3 */
7107 4e777442 j_mayer
    /* XXX: this entry might be a bug in some documentation */
7108 4e777442 j_mayer
    CPU_POWERPC_74x1_v210          = 0x80000210, /* aka G: 2.3 ? */
7109 80d11f44 j_mayer
#define CPU_POWERPC_74x5             CPU_POWERPC_74x5_v32
7110 80d11f44 j_mayer
    CPU_POWERPC_74x5_v10           = 0x80010100,
7111 c3e36823 j_mayer
    /* XXX: missing 0x80010200 */
7112 80d11f44 j_mayer
    CPU_POWERPC_74x5_v21           = 0x80010201, /* aka C: 2.1 */
7113 80d11f44 j_mayer
    CPU_POWERPC_74x5_v32           = 0x80010302,
7114 80d11f44 j_mayer
    CPU_POWERPC_74x5_v33           = 0x80010303, /* aka F: 3.3 */
7115 80d11f44 j_mayer
    CPU_POWERPC_74x5_v34           = 0x80010304, /* aka G: 3.4 */
7116 80d11f44 j_mayer
#define CPU_POWERPC_74x7             CPU_POWERPC_74x7_v12
7117 80d11f44 j_mayer
    CPU_POWERPC_74x7_v10           = 0x80020100, /* aka A: 1.0 */
7118 082c6681 j_mayer
    CPU_POWERPC_74x7_v11           = 0x80020101, /* aka B: 1.1 */
7119 80d11f44 j_mayer
    CPU_POWERPC_74x7_v12           = 0x80020102, /* aka C: 1.2 */
7120 082c6681 j_mayer
#define CPU_POWERPC_74x7A            CPU_POWERPC_74x7A_v12
7121 082c6681 j_mayer
    CPU_POWERPC_74x7A_v10          = 0x80030100, /* aka A: 1.0 */
7122 082c6681 j_mayer
    CPU_POWERPC_74x7A_v11          = 0x80030101, /* aka B: 1.1 */
7123 082c6681 j_mayer
    CPU_POWERPC_74x7A_v12          = 0x80030102, /* aka C: 1.2 */
7124 a750fc0b j_mayer
    /* 64 bits PowerPC */
7125 00af685f j_mayer
#if defined(TARGET_PPC64)
7126 80d11f44 j_mayer
    CPU_POWERPC_620                = 0x00140000,
7127 80d11f44 j_mayer
    CPU_POWERPC_630                = 0x00400000,
7128 80d11f44 j_mayer
    CPU_POWERPC_631                = 0x00410104,
7129 80d11f44 j_mayer
    CPU_POWERPC_POWER4             = 0x00350000,
7130 80d11f44 j_mayer
    CPU_POWERPC_POWER4P            = 0x00380000,
7131 c3e36823 j_mayer
     /* XXX: missing 0x003A0201 */
7132 80d11f44 j_mayer
    CPU_POWERPC_POWER5             = 0x003A0203,
7133 80d11f44 j_mayer
#define CPU_POWERPC_POWER5GR         CPU_POWERPC_POWER5
7134 80d11f44 j_mayer
    CPU_POWERPC_POWER5P            = 0x003B0000,
7135 80d11f44 j_mayer
#define CPU_POWERPC_POWER5GS         CPU_POWERPC_POWER5P
7136 80d11f44 j_mayer
    CPU_POWERPC_POWER6             = 0x003E0000,
7137 80d11f44 j_mayer
    CPU_POWERPC_POWER6_5           = 0x0F000001, /* POWER6 in POWER5 mode */
7138 80d11f44 j_mayer
    CPU_POWERPC_POWER6A            = 0x0F000002,
7139 9d52e907 David Gibson
#define CPU_POWERPC_POWER7           CPU_POWERPC_POWER7_v20
7140 9d52e907 David Gibson
    CPU_POWERPC_POWER7_v20         = 0x003F0200,
7141 80d11f44 j_mayer
    CPU_POWERPC_970                = 0x00390202,
7142 80d11f44 j_mayer
#define CPU_POWERPC_970FX            CPU_POWERPC_970FX_v31
7143 80d11f44 j_mayer
    CPU_POWERPC_970FX_v10          = 0x00391100,
7144 80d11f44 j_mayer
    CPU_POWERPC_970FX_v20          = 0x003C0200,
7145 80d11f44 j_mayer
    CPU_POWERPC_970FX_v21          = 0x003C0201,
7146 80d11f44 j_mayer
    CPU_POWERPC_970FX_v30          = 0x003C0300,
7147 80d11f44 j_mayer
    CPU_POWERPC_970FX_v31          = 0x003C0301,
7148 80d11f44 j_mayer
    CPU_POWERPC_970GX              = 0x00450000,
7149 80d11f44 j_mayer
#define CPU_POWERPC_970MP            CPU_POWERPC_970MP_v11
7150 80d11f44 j_mayer
    CPU_POWERPC_970MP_v10          = 0x00440100,
7151 80d11f44 j_mayer
    CPU_POWERPC_970MP_v11          = 0x00440101,
7152 80d11f44 j_mayer
#define CPU_POWERPC_CELL             CPU_POWERPC_CELL_v32
7153 80d11f44 j_mayer
    CPU_POWERPC_CELL_v10           = 0x00700100,
7154 80d11f44 j_mayer
    CPU_POWERPC_CELL_v20           = 0x00700400,
7155 80d11f44 j_mayer
    CPU_POWERPC_CELL_v30           = 0x00700500,
7156 80d11f44 j_mayer
    CPU_POWERPC_CELL_v31           = 0x00700501,
7157 80d11f44 j_mayer
#define CPU_POWERPC_CELL_v32         CPU_POWERPC_CELL_v31
7158 80d11f44 j_mayer
    CPU_POWERPC_RS64               = 0x00330000,
7159 80d11f44 j_mayer
    CPU_POWERPC_RS64II             = 0x00340000,
7160 80d11f44 j_mayer
    CPU_POWERPC_RS64III            = 0x00360000,
7161 80d11f44 j_mayer
    CPU_POWERPC_RS64IV             = 0x00370000,
7162 00af685f j_mayer
#endif /* defined(TARGET_PPC64) */
7163 a750fc0b j_mayer
    /* Original POWER */
7164 a750fc0b j_mayer
    /* XXX: should be POWER (RIOS), RSC3308, RSC4608,
7165 a750fc0b j_mayer
     * POWER2 (RIOS2) & RSC2 (P2SC) here
7166 a750fc0b j_mayer
     */
7167 a750fc0b j_mayer
#if 0
7168 80d11f44 j_mayer
    CPU_POWER                      = xxx, /* 0x20000 ? 0x30000 for RSC ? */
7169 a750fc0b j_mayer
#endif
7170 a750fc0b j_mayer
#if 0
7171 80d11f44 j_mayer
    CPU_POWER2                     = xxx, /* 0x40000 ? */
7172 a750fc0b j_mayer
#endif
7173 a750fc0b j_mayer
    /* PA Semi core */
7174 80d11f44 j_mayer
    CPU_POWERPC_PA6T               = 0x00900000,
7175 a750fc0b j_mayer
};
7176 a750fc0b j_mayer
7177 a750fc0b j_mayer
/* System version register (used on MPC 8xxx)                                */
7178 a750fc0b j_mayer
enum {
7179 80d11f44 j_mayer
    POWERPC_SVR_NONE               = 0x00000000,
7180 80d11f44 j_mayer
#define POWERPC_SVR_52xx             POWERPC_SVR_5200
7181 80d11f44 j_mayer
#define POWERPC_SVR_5200             POWERPC_SVR_5200_v12
7182 80d11f44 j_mayer
    POWERPC_SVR_5200_v10           = 0x80110010,
7183 80d11f44 j_mayer
    POWERPC_SVR_5200_v11           = 0x80110011,
7184 80d11f44 j_mayer
    POWERPC_SVR_5200_v12           = 0x80110012,
7185 80d11f44 j_mayer
#define POWERPC_SVR_5200B            POWERPC_SVR_5200B_v21
7186 80d11f44 j_mayer
    POWERPC_SVR_5200B_v20          = 0x80110020,
7187 80d11f44 j_mayer
    POWERPC_SVR_5200B_v21          = 0x80110021,
7188 80d11f44 j_mayer
#define POWERPC_SVR_55xx             POWERPC_SVR_5567
7189 c3e36823 j_mayer
#if 0
7190 80d11f44 j_mayer
    POWERPC_SVR_5533               = xxx,
7191 c3e36823 j_mayer
#endif
7192 c3e36823 j_mayer
#if 0
7193 80d11f44 j_mayer
    POWERPC_SVR_5534               = xxx,
7194 c3e36823 j_mayer
#endif
7195 c3e36823 j_mayer
#if 0
7196 80d11f44 j_mayer
    POWERPC_SVR_5553               = xxx,
7197 c3e36823 j_mayer
#endif
7198 c3e36823 j_mayer
#if 0
7199 80d11f44 j_mayer
    POWERPC_SVR_5554               = xxx,
7200 c3e36823 j_mayer
#endif
7201 c3e36823 j_mayer
#if 0
7202 80d11f44 j_mayer
    POWERPC_SVR_5561               = xxx,
7203 c3e36823 j_mayer
#endif
7204 c3e36823 j_mayer
#if 0
7205 80d11f44 j_mayer
    POWERPC_SVR_5565               = xxx,
7206 c3e36823 j_mayer
#endif
7207 c3e36823 j_mayer
#if 0
7208 80d11f44 j_mayer
    POWERPC_SVR_5566               = xxx,
7209 c3e36823 j_mayer
#endif
7210 c3e36823 j_mayer
#if 0
7211 80d11f44 j_mayer
    POWERPC_SVR_5567               = xxx,
7212 c3e36823 j_mayer
#endif
7213 c3e36823 j_mayer
#if 0
7214 80d11f44 j_mayer
    POWERPC_SVR_8313               = xxx,
7215 c3e36823 j_mayer
#endif
7216 c3e36823 j_mayer
#if 0
7217 80d11f44 j_mayer
    POWERPC_SVR_8313E              = xxx,
7218 c3e36823 j_mayer
#endif
7219 c3e36823 j_mayer
#if 0
7220 80d11f44 j_mayer
    POWERPC_SVR_8314               = xxx,
7221 c3e36823 j_mayer
#endif
7222 c3e36823 j_mayer
#if 0
7223 80d11f44 j_mayer
    POWERPC_SVR_8314E              = xxx,
7224 c3e36823 j_mayer
#endif
7225 c3e36823 j_mayer
#if 0
7226 80d11f44 j_mayer
    POWERPC_SVR_8315               = xxx,
7227 c3e36823 j_mayer
#endif
7228 c3e36823 j_mayer
#if 0
7229 80d11f44 j_mayer
    POWERPC_SVR_8315E              = xxx,
7230 c3e36823 j_mayer
#endif
7231 c3e36823 j_mayer
#if 0
7232 80d11f44 j_mayer
    POWERPC_SVR_8321               = xxx,
7233 c3e36823 j_mayer
#endif
7234 c3e36823 j_mayer
#if 0
7235 80d11f44 j_mayer
    POWERPC_SVR_8321E              = xxx,
7236 c3e36823 j_mayer
#endif
7237 c3e36823 j_mayer
#if 0
7238 80d11f44 j_mayer
    POWERPC_SVR_8323               = xxx,
7239 c3e36823 j_mayer
#endif
7240 c3e36823 j_mayer
#if 0
7241 80d11f44 j_mayer
    POWERPC_SVR_8323E              = xxx,
7242 80d11f44 j_mayer
#endif
7243 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8343               = 0x80570010,
7244 80d11f44 j_mayer
    POWERPC_SVR_8343A              = 0x80570030,
7245 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8343E              = 0x80560010,
7246 80d11f44 j_mayer
    POWERPC_SVR_8343EA             = 0x80560030,
7247 492d7bf5 Thomas Monjalon
#define POWERPC_SVR_8347             POWERPC_SVR_8347T
7248 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347P              = 0x80550010, /* PBGA package */
7249 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347T              = 0x80530010, /* TBGA package */
7250 80d11f44 j_mayer
#define POWERPC_SVR_8347A            POWERPC_SVR_8347AT
7251 80d11f44 j_mayer
    POWERPC_SVR_8347AP             = 0x80550030, /* PBGA package */
7252 80d11f44 j_mayer
    POWERPC_SVR_8347AT             = 0x80530030, /* TBGA package */
7253 492d7bf5 Thomas Monjalon
#define POWERPC_SVR_8347E            POWERPC_SVR_8347ET
7254 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347EP             = 0x80540010, /* PBGA package */
7255 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347ET             = 0x80520010, /* TBGA package */
7256 80d11f44 j_mayer
#define POWERPC_SVR_8347EA            POWERPC_SVR_8347EAT
7257 80d11f44 j_mayer
    POWERPC_SVR_8347EAP            = 0x80540030, /* PBGA package */
7258 80d11f44 j_mayer
    POWERPC_SVR_8347EAT            = 0x80520030, /* TBGA package */
7259 80d11f44 j_mayer
    POWERPC_SVR_8349               = 0x80510010,
7260 80d11f44 j_mayer
    POWERPC_SVR_8349A              = 0x80510030,
7261 80d11f44 j_mayer
    POWERPC_SVR_8349E              = 0x80500010,
7262 80d11f44 j_mayer
    POWERPC_SVR_8349EA             = 0x80500030,
7263 c3e36823 j_mayer
#if 0
7264 80d11f44 j_mayer
    POWERPC_SVR_8358E              = xxx,
7265 c3e36823 j_mayer
#endif
7266 c3e36823 j_mayer
#if 0
7267 80d11f44 j_mayer
    POWERPC_SVR_8360E              = xxx,
7268 80d11f44 j_mayer
#endif
7269 80d11f44 j_mayer
#define POWERPC_SVR_E500             0x40000000
7270 80d11f44 j_mayer
    POWERPC_SVR_8377               = 0x80C70010 | POWERPC_SVR_E500,
7271 80d11f44 j_mayer
    POWERPC_SVR_8377E              = 0x80C60010 | POWERPC_SVR_E500,
7272 80d11f44 j_mayer
    POWERPC_SVR_8378               = 0x80C50010 | POWERPC_SVR_E500,
7273 80d11f44 j_mayer
    POWERPC_SVR_8378E              = 0x80C40010 | POWERPC_SVR_E500,
7274 80d11f44 j_mayer
    POWERPC_SVR_8379               = 0x80C30010 | POWERPC_SVR_E500,
7275 80d11f44 j_mayer
    POWERPC_SVR_8379E              = 0x80C00010 | POWERPC_SVR_E500,
7276 80d11f44 j_mayer
#define POWERPC_SVR_8533             POWERPC_SVR_8533_v11
7277 80d11f44 j_mayer
    POWERPC_SVR_8533_v10           = 0x80340010 | POWERPC_SVR_E500,
7278 80d11f44 j_mayer
    POWERPC_SVR_8533_v11           = 0x80340011 | POWERPC_SVR_E500,
7279 80d11f44 j_mayer
#define POWERPC_SVR_8533E            POWERPC_SVR_8533E_v11
7280 80d11f44 j_mayer
    POWERPC_SVR_8533E_v10          = 0x803C0010 | POWERPC_SVR_E500,
7281 80d11f44 j_mayer
    POWERPC_SVR_8533E_v11          = 0x803C0011 | POWERPC_SVR_E500,
7282 80d11f44 j_mayer
#define POWERPC_SVR_8540             POWERPC_SVR_8540_v21
7283 80d11f44 j_mayer
    POWERPC_SVR_8540_v10           = 0x80300010 | POWERPC_SVR_E500,
7284 80d11f44 j_mayer
    POWERPC_SVR_8540_v20           = 0x80300020 | POWERPC_SVR_E500,
7285 80d11f44 j_mayer
    POWERPC_SVR_8540_v21           = 0x80300021 | POWERPC_SVR_E500,
7286 80d11f44 j_mayer
#define POWERPC_SVR_8541             POWERPC_SVR_8541_v11
7287 80d11f44 j_mayer
    POWERPC_SVR_8541_v10           = 0x80720010 | POWERPC_SVR_E500,
7288 80d11f44 j_mayer
    POWERPC_SVR_8541_v11           = 0x80720011 | POWERPC_SVR_E500,
7289 80d11f44 j_mayer
#define POWERPC_SVR_8541E            POWERPC_SVR_8541E_v11
7290 80d11f44 j_mayer
    POWERPC_SVR_8541E_v10          = 0x807A0010 | POWERPC_SVR_E500,
7291 80d11f44 j_mayer
    POWERPC_SVR_8541E_v11          = 0x807A0011 | POWERPC_SVR_E500,
7292 80d11f44 j_mayer
#define POWERPC_SVR_8543             POWERPC_SVR_8543_v21
7293 80d11f44 j_mayer
    POWERPC_SVR_8543_v10           = 0x80320010 | POWERPC_SVR_E500,
7294 80d11f44 j_mayer
    POWERPC_SVR_8543_v11           = 0x80320011 | POWERPC_SVR_E500,
7295 80d11f44 j_mayer
    POWERPC_SVR_8543_v20           = 0x80320020 | POWERPC_SVR_E500,
7296 80d11f44 j_mayer
    POWERPC_SVR_8543_v21           = 0x80320021 | POWERPC_SVR_E500,
7297 80d11f44 j_mayer
#define POWERPC_SVR_8543E            POWERPC_SVR_8543E_v21
7298 80d11f44 j_mayer
    POWERPC_SVR_8543E_v10          = 0x803A0010 | POWERPC_SVR_E500,
7299 80d11f44 j_mayer
    POWERPC_SVR_8543E_v11          = 0x803A0011 | POWERPC_SVR_E500,
7300 80d11f44 j_mayer
    POWERPC_SVR_8543E_v20          = 0x803A0020 | POWERPC_SVR_E500,
7301 80d11f44 j_mayer
    POWERPC_SVR_8543E_v21          = 0x803A0021 | POWERPC_SVR_E500,
7302 80d11f44 j_mayer
#define POWERPC_SVR_8544             POWERPC_SVR_8544_v11
7303 80d11f44 j_mayer
    POWERPC_SVR_8544_v10           = 0x80340110 | POWERPC_SVR_E500,
7304 80d11f44 j_mayer
    POWERPC_SVR_8544_v11           = 0x80340111 | POWERPC_SVR_E500,
7305 80d11f44 j_mayer
#define POWERPC_SVR_8544E            POWERPC_SVR_8544E_v11
7306 80d11f44 j_mayer
    POWERPC_SVR_8544E_v10          = 0x803C0110 | POWERPC_SVR_E500,
7307 80d11f44 j_mayer
    POWERPC_SVR_8544E_v11          = 0x803C0111 | POWERPC_SVR_E500,
7308 80d11f44 j_mayer
#define POWERPC_SVR_8545             POWERPC_SVR_8545_v21
7309 80d11f44 j_mayer
    POWERPC_SVR_8545_v20           = 0x80310220 | POWERPC_SVR_E500,
7310 80d11f44 j_mayer
    POWERPC_SVR_8545_v21           = 0x80310221 | POWERPC_SVR_E500,
7311 80d11f44 j_mayer
#define POWERPC_SVR_8545E            POWERPC_SVR_8545E_v21
7312 80d11f44 j_mayer
    POWERPC_SVR_8545E_v20          = 0x80390220 | POWERPC_SVR_E500,
7313 80d11f44 j_mayer
    POWERPC_SVR_8545E_v21          = 0x80390221 | POWERPC_SVR_E500,
7314 80d11f44 j_mayer
#define POWERPC_SVR_8547E            POWERPC_SVR_8547E_v21
7315 80d11f44 j_mayer
    POWERPC_SVR_8547E_v20          = 0x80390120 | POWERPC_SVR_E500,
7316 80d11f44 j_mayer
    POWERPC_SVR_8547E_v21          = 0x80390121 | POWERPC_SVR_E500,
7317 80d11f44 j_mayer
#define POWERPC_SVR_8548             POWERPC_SVR_8548_v21
7318 80d11f44 j_mayer
    POWERPC_SVR_8548_v10           = 0x80310010 | POWERPC_SVR_E500,
7319 80d11f44 j_mayer
    POWERPC_SVR_8548_v11           = 0x80310011 | POWERPC_SVR_E500,
7320 80d11f44 j_mayer
    POWERPC_SVR_8548_v20           = 0x80310020 | POWERPC_SVR_E500,
7321 80d11f44 j_mayer
    POWERPC_SVR_8548_v21           = 0x80310021 | POWERPC_SVR_E500,
7322 80d11f44 j_mayer
#define POWERPC_SVR_8548E            POWERPC_SVR_8548E_v21
7323 80d11f44 j_mayer
    POWERPC_SVR_8548E_v10          = 0x80390010 | POWERPC_SVR_E500,
7324 80d11f44 j_mayer
    POWERPC_SVR_8548E_v11          = 0x80390011 | POWERPC_SVR_E500,
7325 80d11f44 j_mayer
    POWERPC_SVR_8548E_v20          = 0x80390020 | POWERPC_SVR_E500,
7326 80d11f44 j_mayer
    POWERPC_SVR_8548E_v21          = 0x80390021 | POWERPC_SVR_E500,
7327 80d11f44 j_mayer
#define POWERPC_SVR_8555             POWERPC_SVR_8555_v11
7328 80d11f44 j_mayer
    POWERPC_SVR_8555_v10           = 0x80710010 | POWERPC_SVR_E500,
7329 80d11f44 j_mayer
    POWERPC_SVR_8555_v11           = 0x80710011 | POWERPC_SVR_E500,
7330 80d11f44 j_mayer
#define POWERPC_SVR_8555E            POWERPC_SVR_8555_v11
7331 80d11f44 j_mayer
    POWERPC_SVR_8555E_v10          = 0x80790010 | POWERPC_SVR_E500,
7332 80d11f44 j_mayer
    POWERPC_SVR_8555E_v11          = 0x80790011 | POWERPC_SVR_E500,
7333 80d11f44 j_mayer
#define POWERPC_SVR_8560             POWERPC_SVR_8560_v21
7334 80d11f44 j_mayer
    POWERPC_SVR_8560_v10           = 0x80700010 | POWERPC_SVR_E500,
7335 80d11f44 j_mayer
    POWERPC_SVR_8560_v20           = 0x80700020 | POWERPC_SVR_E500,
7336 80d11f44 j_mayer
    POWERPC_SVR_8560_v21           = 0x80700021 | POWERPC_SVR_E500,
7337 80d11f44 j_mayer
    POWERPC_SVR_8567               = 0x80750111 | POWERPC_SVR_E500,
7338 80d11f44 j_mayer
    POWERPC_SVR_8567E              = 0x807D0111 | POWERPC_SVR_E500,
7339 80d11f44 j_mayer
    POWERPC_SVR_8568               = 0x80750011 | POWERPC_SVR_E500,
7340 80d11f44 j_mayer
    POWERPC_SVR_8568E              = 0x807D0011 | POWERPC_SVR_E500,
7341 80d11f44 j_mayer
    POWERPC_SVR_8572               = 0x80E00010 | POWERPC_SVR_E500,
7342 80d11f44 j_mayer
    POWERPC_SVR_8572E              = 0x80E80010 | POWERPC_SVR_E500,
7343 c3e36823 j_mayer
#if 0
7344 80d11f44 j_mayer
    POWERPC_SVR_8610               = xxx,
7345 c3e36823 j_mayer
#endif
7346 80d11f44 j_mayer
    POWERPC_SVR_8641               = 0x80900021,
7347 80d11f44 j_mayer
    POWERPC_SVR_8641D              = 0x80900121,
7348 a750fc0b j_mayer
};
7349 a750fc0b j_mayer
7350 3fc6c082 bellard
/*****************************************************************************/
7351 a750fc0b j_mayer
/* PowerPC CPU definitions                                                   */
7352 80d11f44 j_mayer
#define POWERPC_DEF_SVR(_name, _pvr, _svr, _type)                             \
7353 a750fc0b j_mayer
    {                                                                         \
7354 a750fc0b j_mayer
        .name        = _name,                                                 \
7355 a750fc0b j_mayer
        .pvr         = _pvr,                                                  \
7356 80d11f44 j_mayer
        .svr         = _svr,                                                  \
7357 a750fc0b j_mayer
        .insns_flags = glue(POWERPC_INSNS_,_type),                            \
7358 a750fc0b j_mayer
        .msr_mask    = glue(POWERPC_MSRM_,_type),                             \
7359 a750fc0b j_mayer
        .mmu_model   = glue(POWERPC_MMU_,_type),                              \
7360 a750fc0b j_mayer
        .excp_model  = glue(POWERPC_EXCP_,_type),                             \
7361 a750fc0b j_mayer
        .bus_model   = glue(POWERPC_INPUT_,_type),                            \
7362 237c0af0 j_mayer
        .bfd_mach    = glue(POWERPC_BFDM_,_type),                             \
7363 d26bfc9a j_mayer
        .flags       = glue(POWERPC_FLAG_,_type),                             \
7364 a750fc0b j_mayer
        .init_proc   = &glue(init_proc_,_type),                               \
7365 2f462816 j_mayer
        .check_pow   = &glue(check_pow_,_type),                               \
7366 a750fc0b j_mayer
    }
7367 80d11f44 j_mayer
#define POWERPC_DEF(_name, _pvr, _type)                                       \
7368 80d11f44 j_mayer
POWERPC_DEF_SVR(_name, _pvr, POWERPC_SVR_NONE, _type)
7369 a750fc0b j_mayer
7370 c227f099 Anthony Liguori
static const ppc_def_t ppc_defs[] = {
7371 a750fc0b j_mayer
    /* Embedded PowerPC                                                      */
7372 a750fc0b j_mayer
    /* PowerPC 401 family                                                    */
7373 2662a059 j_mayer
    /* Generic PowerPC 401 */
7374 80d11f44 j_mayer
    POWERPC_DEF("401",           CPU_POWERPC_401,                    401),
7375 a750fc0b j_mayer
    /* PowerPC 401 cores                                                     */
7376 2662a059 j_mayer
    /* PowerPC 401A1 */
7377 80d11f44 j_mayer
    POWERPC_DEF("401A1",         CPU_POWERPC_401A1,                  401),
7378 a750fc0b j_mayer
    /* PowerPC 401B2                                                         */
7379 80d11f44 j_mayer
    POWERPC_DEF("401B2",         CPU_POWERPC_401B2,                  401x2),
7380 2662a059 j_mayer
#if defined (TODO)
7381 a750fc0b j_mayer
    /* PowerPC 401B3                                                         */
7382 80d11f44 j_mayer
    POWERPC_DEF("401B3",         CPU_POWERPC_401B3,                  401x3),
7383 a750fc0b j_mayer
#endif
7384 a750fc0b j_mayer
    /* PowerPC 401C2                                                         */
7385 80d11f44 j_mayer
    POWERPC_DEF("401C2",         CPU_POWERPC_401C2,                  401x2),
7386 a750fc0b j_mayer
    /* PowerPC 401D2                                                         */
7387 80d11f44 j_mayer
    POWERPC_DEF("401D2",         CPU_POWERPC_401D2,                  401x2),
7388 a750fc0b j_mayer
    /* PowerPC 401E2                                                         */
7389 80d11f44 j_mayer
    POWERPC_DEF("401E2",         CPU_POWERPC_401E2,                  401x2),
7390 a750fc0b j_mayer
    /* PowerPC 401F2                                                         */
7391 80d11f44 j_mayer
    POWERPC_DEF("401F2",         CPU_POWERPC_401F2,                  401x2),
7392 a750fc0b j_mayer
    /* PowerPC 401G2                                                         */
7393 a750fc0b j_mayer
    /* XXX: to be checked */
7394 80d11f44 j_mayer
    POWERPC_DEF("401G2",         CPU_POWERPC_401G2,                  401x2),
7395 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers                                           */
7396 2662a059 j_mayer
#if defined (TODO)
7397 a750fc0b j_mayer
    /* PowerPC 401GF                                                         */
7398 80d11f44 j_mayer
    POWERPC_DEF("401GF",         CPU_POWERPC_401GF,                  401),
7399 3fc6c082 bellard
#endif
7400 a750fc0b j_mayer
    /* IOP480 (401 microcontroler)                                           */
7401 80d11f44 j_mayer
    POWERPC_DEF("IOP480",        CPU_POWERPC_IOP480,                 IOP480),
7402 a750fc0b j_mayer
    /* IBM Processor for Network Resources                                   */
7403 80d11f44 j_mayer
    POWERPC_DEF("Cobra",         CPU_POWERPC_COBRA,                  401),
7404 3fc6c082 bellard
#if defined (TODO)
7405 80d11f44 j_mayer
    POWERPC_DEF("Xipchip",       CPU_POWERPC_XIPCHIP,                401),
7406 3fc6c082 bellard
#endif
7407 a750fc0b j_mayer
    /* PowerPC 403 family                                                    */
7408 a750fc0b j_mayer
    /* Generic PowerPC 403                                                   */
7409 80d11f44 j_mayer
    POWERPC_DEF("403",           CPU_POWERPC_403,                    403),
7410 a750fc0b j_mayer
    /* PowerPC 403 microcontrolers                                           */
7411 a750fc0b j_mayer
    /* PowerPC 403 GA                                                        */
7412 80d11f44 j_mayer
    POWERPC_DEF("403GA",         CPU_POWERPC_403GA,                  403),
7413 a750fc0b j_mayer
    /* PowerPC 403 GB                                                        */
7414 80d11f44 j_mayer
    POWERPC_DEF("403GB",         CPU_POWERPC_403GB,                  403),
7415 a750fc0b j_mayer
    /* PowerPC 403 GC                                                        */
7416 80d11f44 j_mayer
    POWERPC_DEF("403GC",         CPU_POWERPC_403GC,                  403),
7417 a750fc0b j_mayer
    /* PowerPC 403 GCX                                                       */
7418 80d11f44 j_mayer
    POWERPC_DEF("403GCX",        CPU_POWERPC_403GCX,                 403GCX),
7419 3fc6c082 bellard
#if defined (TODO)
7420 a750fc0b j_mayer
    /* PowerPC 403 GP                                                        */
7421 80d11f44 j_mayer
    POWERPC_DEF("403GP",         CPU_POWERPC_403GP,                  403),
7422 3fc6c082 bellard
#endif
7423 a750fc0b j_mayer
    /* PowerPC 405 family                                                    */
7424 a750fc0b j_mayer
    /* Generic PowerPC 405                                                   */
7425 80d11f44 j_mayer
    POWERPC_DEF("405",           CPU_POWERPC_405,                    405),
7426 a750fc0b j_mayer
    /* PowerPC 405 cores                                                     */
7427 2662a059 j_mayer
#if defined (TODO)
7428 a750fc0b j_mayer
    /* PowerPC 405 A3                                                        */
7429 80d11f44 j_mayer
    POWERPC_DEF("405A3",         CPU_POWERPC_405A3,                  405),
7430 3a607854 j_mayer
#endif
7431 3a607854 j_mayer
#if defined (TODO)
7432 a750fc0b j_mayer
    /* PowerPC 405 A4                                                        */
7433 80d11f44 j_mayer
    POWERPC_DEF("405A4",         CPU_POWERPC_405A4,                  405),
7434 3a607854 j_mayer
#endif
7435 3a607854 j_mayer
#if defined (TODO)
7436 a750fc0b j_mayer
    /* PowerPC 405 B3                                                        */
7437 80d11f44 j_mayer
    POWERPC_DEF("405B3",         CPU_POWERPC_405B3,                  405),
7438 3fc6c082 bellard
#endif
7439 3fc6c082 bellard
#if defined (TODO)
7440 a750fc0b j_mayer
    /* PowerPC 405 B4                                                        */
7441 80d11f44 j_mayer
    POWERPC_DEF("405B4",         CPU_POWERPC_405B4,                  405),
7442 a750fc0b j_mayer
#endif
7443 a750fc0b j_mayer
#if defined (TODO)
7444 a750fc0b j_mayer
    /* PowerPC 405 C3                                                        */
7445 80d11f44 j_mayer
    POWERPC_DEF("405C3",         CPU_POWERPC_405C3,                  405),
7446 a750fc0b j_mayer
#endif
7447 a750fc0b j_mayer
#if defined (TODO)
7448 a750fc0b j_mayer
    /* PowerPC 405 C4                                                        */
7449 80d11f44 j_mayer
    POWERPC_DEF("405C4",         CPU_POWERPC_405C4,                  405),
7450 a750fc0b j_mayer
#endif
7451 a750fc0b j_mayer
    /* PowerPC 405 D2                                                        */
7452 80d11f44 j_mayer
    POWERPC_DEF("405D2",         CPU_POWERPC_405D2,                  405),
7453 a750fc0b j_mayer
#if defined (TODO)
7454 a750fc0b j_mayer
    /* PowerPC 405 D3                                                        */
7455 80d11f44 j_mayer
    POWERPC_DEF("405D3",         CPU_POWERPC_405D3,                  405),
7456 a750fc0b j_mayer
#endif
7457 a750fc0b j_mayer
    /* PowerPC 405 D4                                                        */
7458 80d11f44 j_mayer
    POWERPC_DEF("405D4",         CPU_POWERPC_405D4,                  405),
7459 a750fc0b j_mayer
#if defined (TODO)
7460 a750fc0b j_mayer
    /* PowerPC 405 D5                                                        */
7461 80d11f44 j_mayer
    POWERPC_DEF("405D5",         CPU_POWERPC_405D5,                  405),
7462 a750fc0b j_mayer
#endif
7463 a750fc0b j_mayer
#if defined (TODO)
7464 a750fc0b j_mayer
    /* PowerPC 405 E4                                                        */
7465 80d11f44 j_mayer
    POWERPC_DEF("405E4",         CPU_POWERPC_405E4,                  405),
7466 a750fc0b j_mayer
#endif
7467 a750fc0b j_mayer
#if defined (TODO)
7468 a750fc0b j_mayer
    /* PowerPC 405 F4                                                        */
7469 80d11f44 j_mayer
    POWERPC_DEF("405F4",         CPU_POWERPC_405F4,                  405),
7470 a750fc0b j_mayer
#endif
7471 a750fc0b j_mayer
#if defined (TODO)
7472 a750fc0b j_mayer
    /* PowerPC 405 F5                                                        */
7473 80d11f44 j_mayer
    POWERPC_DEF("405F5",         CPU_POWERPC_405F5,                  405),
7474 a750fc0b j_mayer
#endif
7475 a750fc0b j_mayer
#if defined (TODO)
7476 a750fc0b j_mayer
    /* PowerPC 405 F6                                                        */
7477 80d11f44 j_mayer
    POWERPC_DEF("405F6",         CPU_POWERPC_405F6,                  405),
7478 a750fc0b j_mayer
#endif
7479 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers                                           */
7480 a750fc0b j_mayer
    /* PowerPC 405 CR                                                        */
7481 80d11f44 j_mayer
    POWERPC_DEF("405CR",         CPU_POWERPC_405CR,                  405),
7482 a750fc0b j_mayer
    /* PowerPC 405 CRa                                                       */
7483 80d11f44 j_mayer
    POWERPC_DEF("405CRa",        CPU_POWERPC_405CRa,                 405),
7484 a750fc0b j_mayer
    /* PowerPC 405 CRb                                                       */
7485 80d11f44 j_mayer
    POWERPC_DEF("405CRb",        CPU_POWERPC_405CRb,                 405),
7486 a750fc0b j_mayer
    /* PowerPC 405 CRc                                                       */
7487 80d11f44 j_mayer
    POWERPC_DEF("405CRc",        CPU_POWERPC_405CRc,                 405),
7488 a750fc0b j_mayer
    /* PowerPC 405 EP                                                        */
7489 80d11f44 j_mayer
    POWERPC_DEF("405EP",         CPU_POWERPC_405EP,                  405),
7490 a750fc0b j_mayer
#if defined(TODO)
7491 a750fc0b j_mayer
    /* PowerPC 405 EXr                                                       */
7492 80d11f44 j_mayer
    POWERPC_DEF("405EXr",        CPU_POWERPC_405EXr,                 405),
7493 a750fc0b j_mayer
#endif
7494 a750fc0b j_mayer
    /* PowerPC 405 EZ                                                        */
7495 80d11f44 j_mayer
    POWERPC_DEF("405EZ",         CPU_POWERPC_405EZ,                  405),
7496 a750fc0b j_mayer
#if defined(TODO)
7497 a750fc0b j_mayer
    /* PowerPC 405 FX                                                        */
7498 80d11f44 j_mayer
    POWERPC_DEF("405FX",         CPU_POWERPC_405FX,                  405),
7499 a750fc0b j_mayer
#endif
7500 a750fc0b j_mayer
    /* PowerPC 405 GP                                                        */
7501 80d11f44 j_mayer
    POWERPC_DEF("405GP",         CPU_POWERPC_405GP,                  405),
7502 a750fc0b j_mayer
    /* PowerPC 405 GPa                                                       */
7503 80d11f44 j_mayer
    POWERPC_DEF("405GPa",        CPU_POWERPC_405GPa,                 405),
7504 a750fc0b j_mayer
    /* PowerPC 405 GPb                                                       */
7505 80d11f44 j_mayer
    POWERPC_DEF("405GPb",        CPU_POWERPC_405GPb,                 405),
7506 a750fc0b j_mayer
    /* PowerPC 405 GPc                                                       */
7507 80d11f44 j_mayer
    POWERPC_DEF("405GPc",        CPU_POWERPC_405GPc,                 405),
7508 a750fc0b j_mayer
    /* PowerPC 405 GPd                                                       */
7509 80d11f44 j_mayer
    POWERPC_DEF("405GPd",        CPU_POWERPC_405GPd,                 405),
7510 a750fc0b j_mayer
    /* PowerPC 405 GPe                                                       */
7511 80d11f44 j_mayer
    POWERPC_DEF("405GPe",        CPU_POWERPC_405GPe,                 405),
7512 a750fc0b j_mayer
    /* PowerPC 405 GPR                                                       */
7513 80d11f44 j_mayer
    POWERPC_DEF("405GPR",        CPU_POWERPC_405GPR,                 405),
7514 a750fc0b j_mayer
#if defined(TODO)
7515 a750fc0b j_mayer
    /* PowerPC 405 H                                                         */
7516 80d11f44 j_mayer
    POWERPC_DEF("405H",          CPU_POWERPC_405H,                   405),
7517 a750fc0b j_mayer
#endif
7518 a750fc0b j_mayer
#if defined(TODO)
7519 a750fc0b j_mayer
    /* PowerPC 405 L                                                         */
7520 80d11f44 j_mayer
    POWERPC_DEF("405L",          CPU_POWERPC_405L,                   405),
7521 a750fc0b j_mayer
#endif
7522 a750fc0b j_mayer
    /* PowerPC 405 LP                                                        */
7523 80d11f44 j_mayer
    POWERPC_DEF("405LP",         CPU_POWERPC_405LP,                  405),
7524 a750fc0b j_mayer
#if defined(TODO)
7525 a750fc0b j_mayer
    /* PowerPC 405 PM                                                        */
7526 80d11f44 j_mayer
    POWERPC_DEF("405PM",         CPU_POWERPC_405PM,                  405),
7527 a750fc0b j_mayer
#endif
7528 a750fc0b j_mayer
#if defined(TODO)
7529 a750fc0b j_mayer
    /* PowerPC 405 PS                                                        */
7530 80d11f44 j_mayer
    POWERPC_DEF("405PS",         CPU_POWERPC_405PS,                  405),
7531 a750fc0b j_mayer
#endif
7532 a750fc0b j_mayer
#if defined(TODO)
7533 a750fc0b j_mayer
    /* PowerPC 405 S                                                         */
7534 80d11f44 j_mayer
    POWERPC_DEF("405S",          CPU_POWERPC_405S,                   405),
7535 a750fc0b j_mayer
#endif
7536 a750fc0b j_mayer
    /* Npe405 H                                                              */
7537 80d11f44 j_mayer
    POWERPC_DEF("Npe405H",       CPU_POWERPC_NPE405H,                405),
7538 a750fc0b j_mayer
    /* Npe405 H2                                                             */
7539 80d11f44 j_mayer
    POWERPC_DEF("Npe405H2",      CPU_POWERPC_NPE405H2,               405),
7540 a750fc0b j_mayer
    /* Npe405 L                                                              */
7541 80d11f44 j_mayer
    POWERPC_DEF("Npe405L",       CPU_POWERPC_NPE405L,                405),
7542 a750fc0b j_mayer
    /* Npe4GS3                                                               */
7543 80d11f44 j_mayer
    POWERPC_DEF("Npe4GS3",       CPU_POWERPC_NPE4GS3,                405),
7544 a750fc0b j_mayer
#if defined (TODO)
7545 80d11f44 j_mayer
    POWERPC_DEF("Npcxx1",        CPU_POWERPC_NPCxx1,                 405),
7546 a750fc0b j_mayer
#endif
7547 a750fc0b j_mayer
#if defined (TODO)
7548 80d11f44 j_mayer
    POWERPC_DEF("Npr161",        CPU_POWERPC_NPR161,                 405),
7549 a750fc0b j_mayer
#endif
7550 a750fc0b j_mayer
#if defined (TODO)
7551 a750fc0b j_mayer
    /* PowerPC LC77700 (Sanyo)                                               */
7552 80d11f44 j_mayer
    POWERPC_DEF("LC77700",       CPU_POWERPC_LC77700,                405),
7553 a750fc0b j_mayer
#endif
7554 a750fc0b j_mayer
    /* PowerPC 401/403/405 based set-top-box microcontrolers                 */
7555 a750fc0b j_mayer
#if defined (TODO)
7556 a750fc0b j_mayer
    /* STB010000                                                             */
7557 80d11f44 j_mayer
    POWERPC_DEF("STB01000",      CPU_POWERPC_STB01000,               401x2),
7558 a750fc0b j_mayer
#endif
7559 a750fc0b j_mayer
#if defined (TODO)
7560 a750fc0b j_mayer
    /* STB01010                                                              */
7561 80d11f44 j_mayer
    POWERPC_DEF("STB01010",      CPU_POWERPC_STB01010,               401x2),
7562 a750fc0b j_mayer
#endif
7563 a750fc0b j_mayer
#if defined (TODO)
7564 a750fc0b j_mayer
    /* STB0210                                                               */
7565 80d11f44 j_mayer
    POWERPC_DEF("STB0210",       CPU_POWERPC_STB0210,                401x3),
7566 a750fc0b j_mayer
#endif
7567 a750fc0b j_mayer
    /* STB03xx                                                               */
7568 80d11f44 j_mayer
    POWERPC_DEF("STB03",         CPU_POWERPC_STB03,                  405),
7569 a750fc0b j_mayer
#if defined (TODO)
7570 a750fc0b j_mayer
    /* STB043x                                                               */
7571 80d11f44 j_mayer
    POWERPC_DEF("STB043",        CPU_POWERPC_STB043,                 405),
7572 a750fc0b j_mayer
#endif
7573 a750fc0b j_mayer
#if defined (TODO)
7574 a750fc0b j_mayer
    /* STB045x                                                               */
7575 80d11f44 j_mayer
    POWERPC_DEF("STB045",        CPU_POWERPC_STB045,                 405),
7576 a750fc0b j_mayer
#endif
7577 a750fc0b j_mayer
    /* STB04xx                                                               */
7578 80d11f44 j_mayer
    POWERPC_DEF("STB04",         CPU_POWERPC_STB04,                  405),
7579 a750fc0b j_mayer
    /* STB25xx                                                               */
7580 80d11f44 j_mayer
    POWERPC_DEF("STB25",         CPU_POWERPC_STB25,                  405),
7581 a750fc0b j_mayer
#if defined (TODO)
7582 a750fc0b j_mayer
    /* STB130                                                                */
7583 80d11f44 j_mayer
    POWERPC_DEF("STB130",        CPU_POWERPC_STB130,                 405),
7584 a750fc0b j_mayer
#endif
7585 a750fc0b j_mayer
    /* Xilinx PowerPC 405 cores                                              */
7586 80d11f44 j_mayer
    POWERPC_DEF("x2vp4",         CPU_POWERPC_X2VP4,                  405),
7587 80d11f44 j_mayer
    POWERPC_DEF("x2vp7",         CPU_POWERPC_X2VP7,                  405),
7588 80d11f44 j_mayer
    POWERPC_DEF("x2vp20",        CPU_POWERPC_X2VP20,                 405),
7589 80d11f44 j_mayer
    POWERPC_DEF("x2vp50",        CPU_POWERPC_X2VP50,                 405),
7590 a750fc0b j_mayer
#if defined (TODO)
7591 a750fc0b j_mayer
    /* Zarlink ZL10310                                                       */
7592 80d11f44 j_mayer
    POWERPC_DEF("zl10310",       CPU_POWERPC_ZL10310,                405),
7593 a750fc0b j_mayer
#endif
7594 a750fc0b j_mayer
#if defined (TODO)
7595 a750fc0b j_mayer
    /* Zarlink ZL10311                                                       */
7596 80d11f44 j_mayer
    POWERPC_DEF("zl10311",       CPU_POWERPC_ZL10311,                405),
7597 a750fc0b j_mayer
#endif
7598 a750fc0b j_mayer
#if defined (TODO)
7599 a750fc0b j_mayer
    /* Zarlink ZL10320                                                       */
7600 80d11f44 j_mayer
    POWERPC_DEF("zl10320",       CPU_POWERPC_ZL10320,                405),
7601 a750fc0b j_mayer
#endif
7602 a750fc0b j_mayer
#if defined (TODO)
7603 a750fc0b j_mayer
    /* Zarlink ZL10321                                                       */
7604 80d11f44 j_mayer
    POWERPC_DEF("zl10321",       CPU_POWERPC_ZL10321,                405),
7605 a750fc0b j_mayer
#endif
7606 a750fc0b j_mayer
    /* PowerPC 440 family                                                    */
7607 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7608 a750fc0b j_mayer
    /* Generic PowerPC 440                                                   */
7609 80d11f44 j_mayer
    POWERPC_DEF("440",           CPU_POWERPC_440,                    440GP),
7610 80d11f44 j_mayer
#endif
7611 a750fc0b j_mayer
    /* PowerPC 440 cores                                                     */
7612 a750fc0b j_mayer
#if defined (TODO)
7613 a750fc0b j_mayer
    /* PowerPC 440 A4                                                        */
7614 80d11f44 j_mayer
    POWERPC_DEF("440A4",         CPU_POWERPC_440A4,                  440x4),
7615 a750fc0b j_mayer
#endif
7616 95070372 Edgar E. Iglesias
    /* PowerPC 440 Xilinx 5                                                  */
7617 95070372 Edgar E. Iglesias
    POWERPC_DEF("440-Xilinx",    CPU_POWERPC_440_XILINX,             440x5),
7618 a750fc0b j_mayer
#if defined (TODO)
7619 a750fc0b j_mayer
    /* PowerPC 440 A5                                                        */
7620 80d11f44 j_mayer
    POWERPC_DEF("440A5",         CPU_POWERPC_440A5,                  440x5),
7621 a750fc0b j_mayer
#endif
7622 a750fc0b j_mayer
#if defined (TODO)
7623 a750fc0b j_mayer
    /* PowerPC 440 B4                                                        */
7624 80d11f44 j_mayer
    POWERPC_DEF("440B4",         CPU_POWERPC_440B4,                  440x4),
7625 a750fc0b j_mayer
#endif
7626 a750fc0b j_mayer
#if defined (TODO)
7627 a750fc0b j_mayer
    /* PowerPC 440 G4                                                        */
7628 80d11f44 j_mayer
    POWERPC_DEF("440G4",         CPU_POWERPC_440G4,                  440x4),
7629 a750fc0b j_mayer
#endif
7630 a750fc0b j_mayer
#if defined (TODO)
7631 a750fc0b j_mayer
    /* PowerPC 440 F5                                                        */
7632 80d11f44 j_mayer
    POWERPC_DEF("440F5",         CPU_POWERPC_440F5,                  440x5),
7633 a750fc0b j_mayer
#endif
7634 a750fc0b j_mayer
#if defined (TODO)
7635 a750fc0b j_mayer
    /* PowerPC 440 G5                                                        */
7636 80d11f44 j_mayer
    POWERPC_DEF("440G5",         CPU_POWERPC_440G5,                  440x5),
7637 a750fc0b j_mayer
#endif
7638 a750fc0b j_mayer
#if defined (TODO)
7639 a750fc0b j_mayer
    /* PowerPC 440H4                                                         */
7640 80d11f44 j_mayer
    POWERPC_DEF("440H4",         CPU_POWERPC_440H4,                  440x4),
7641 a750fc0b j_mayer
#endif
7642 a750fc0b j_mayer
#if defined (TODO)
7643 a750fc0b j_mayer
    /* PowerPC 440H6                                                         */
7644 80d11f44 j_mayer
    POWERPC_DEF("440H6",         CPU_POWERPC_440H6,                  440Gx5),
7645 a750fc0b j_mayer
#endif
7646 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers                                           */
7647 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7648 a750fc0b j_mayer
    /* PowerPC 440 EP                                                        */
7649 80d11f44 j_mayer
    POWERPC_DEF("440EP",         CPU_POWERPC_440EP,                  440EP),
7650 80d11f44 j_mayer
#endif
7651 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7652 a750fc0b j_mayer
    /* PowerPC 440 EPa                                                       */
7653 80d11f44 j_mayer
    POWERPC_DEF("440EPa",        CPU_POWERPC_440EPa,                 440EP),
7654 80d11f44 j_mayer
#endif
7655 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7656 a750fc0b j_mayer
    /* PowerPC 440 EPb                                                       */
7657 80d11f44 j_mayer
    POWERPC_DEF("440EPb",        CPU_POWERPC_440EPb,                 440EP),
7658 80d11f44 j_mayer
#endif
7659 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7660 a750fc0b j_mayer
    /* PowerPC 440 EPX                                                       */
7661 80d11f44 j_mayer
    POWERPC_DEF("440EPX",        CPU_POWERPC_440EPX,                 440EP),
7662 80d11f44 j_mayer
#endif
7663 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7664 a750fc0b j_mayer
    /* PowerPC 440 GP                                                        */
7665 80d11f44 j_mayer
    POWERPC_DEF("440GP",         CPU_POWERPC_440GP,                  440GP),
7666 80d11f44 j_mayer
#endif
7667 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7668 a750fc0b j_mayer
    /* PowerPC 440 GPb                                                       */
7669 80d11f44 j_mayer
    POWERPC_DEF("440GPb",        CPU_POWERPC_440GPb,                 440GP),
7670 80d11f44 j_mayer
#endif
7671 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7672 a750fc0b j_mayer
    /* PowerPC 440 GPc                                                       */
7673 80d11f44 j_mayer
    POWERPC_DEF("440GPc",        CPU_POWERPC_440GPc,                 440GP),
7674 80d11f44 j_mayer
#endif
7675 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7676 a750fc0b j_mayer
    /* PowerPC 440 GR                                                        */
7677 80d11f44 j_mayer
    POWERPC_DEF("440GR",         CPU_POWERPC_440GR,                  440x5),
7678 80d11f44 j_mayer
#endif
7679 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7680 a750fc0b j_mayer
    /* PowerPC 440 GRa                                                       */
7681 80d11f44 j_mayer
    POWERPC_DEF("440GRa",        CPU_POWERPC_440GRa,                 440x5),
7682 80d11f44 j_mayer
#endif
7683 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7684 a750fc0b j_mayer
    /* PowerPC 440 GRX                                                       */
7685 80d11f44 j_mayer
    POWERPC_DEF("440GRX",        CPU_POWERPC_440GRX,                 440x5),
7686 80d11f44 j_mayer
#endif
7687 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7688 a750fc0b j_mayer
    /* PowerPC 440 GX                                                        */
7689 80d11f44 j_mayer
    POWERPC_DEF("440GX",         CPU_POWERPC_440GX,                  440EP),
7690 80d11f44 j_mayer
#endif
7691 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7692 a750fc0b j_mayer
    /* PowerPC 440 GXa                                                       */
7693 80d11f44 j_mayer
    POWERPC_DEF("440GXa",        CPU_POWERPC_440GXa,                 440EP),
7694 80d11f44 j_mayer
#endif
7695 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7696 a750fc0b j_mayer
    /* PowerPC 440 GXb                                                       */
7697 80d11f44 j_mayer
    POWERPC_DEF("440GXb",        CPU_POWERPC_440GXb,                 440EP),
7698 80d11f44 j_mayer
#endif
7699 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7700 a750fc0b j_mayer
    /* PowerPC 440 GXc                                                       */
7701 80d11f44 j_mayer
    POWERPC_DEF("440GXc",        CPU_POWERPC_440GXc,                 440EP),
7702 80d11f44 j_mayer
#endif
7703 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7704 a750fc0b j_mayer
    /* PowerPC 440 GXf                                                       */
7705 80d11f44 j_mayer
    POWERPC_DEF("440GXf",        CPU_POWERPC_440GXf,                 440EP),
7706 80d11f44 j_mayer
#endif
7707 a750fc0b j_mayer
#if defined(TODO)
7708 a750fc0b j_mayer
    /* PowerPC 440 S                                                         */
7709 80d11f44 j_mayer
    POWERPC_DEF("440S",          CPU_POWERPC_440S,                   440),
7710 a750fc0b j_mayer
#endif
7711 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7712 a750fc0b j_mayer
    /* PowerPC 440 SP                                                        */
7713 80d11f44 j_mayer
    POWERPC_DEF("440SP",         CPU_POWERPC_440SP,                  440EP),
7714 80d11f44 j_mayer
#endif
7715 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7716 a750fc0b j_mayer
    /* PowerPC 440 SP2                                                       */
7717 80d11f44 j_mayer
    POWERPC_DEF("440SP2",        CPU_POWERPC_440SP2,                 440EP),
7718 80d11f44 j_mayer
#endif
7719 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7720 a750fc0b j_mayer
    /* PowerPC 440 SPE                                                       */
7721 80d11f44 j_mayer
    POWERPC_DEF("440SPE",        CPU_POWERPC_440SPE,                 440EP),
7722 80d11f44 j_mayer
#endif
7723 a750fc0b j_mayer
    /* PowerPC 460 family                                                    */
7724 a750fc0b j_mayer
#if defined (TODO)
7725 a750fc0b j_mayer
    /* Generic PowerPC 464                                                   */
7726 80d11f44 j_mayer
    POWERPC_DEF("464",           CPU_POWERPC_464,                    460),
7727 a750fc0b j_mayer
#endif
7728 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers                                           */
7729 a750fc0b j_mayer
#if defined (TODO)
7730 a750fc0b j_mayer
    /* PowerPC 464H90                                                        */
7731 80d11f44 j_mayer
    POWERPC_DEF("464H90",        CPU_POWERPC_464H90,                 460),
7732 a750fc0b j_mayer
#endif
7733 a750fc0b j_mayer
#if defined (TODO)
7734 a750fc0b j_mayer
    /* PowerPC 464H90F                                                       */
7735 80d11f44 j_mayer
    POWERPC_DEF("464H90F",       CPU_POWERPC_464H90F,                460F),
7736 a750fc0b j_mayer
#endif
7737 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores                                      */
7738 80d11f44 j_mayer
    /* MPC5xx family (aka RCPU)                                              */
7739 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7740 80d11f44 j_mayer
    /* Generic MPC5xx core                                                   */
7741 80d11f44 j_mayer
    POWERPC_DEF("MPC5xx",        CPU_POWERPC_MPC5xx,                 MPC5xx),
7742 80d11f44 j_mayer
#endif
7743 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7744 80d11f44 j_mayer
    /* Codename for MPC5xx core                                              */
7745 80d11f44 j_mayer
    POWERPC_DEF("RCPU",          CPU_POWERPC_MPC5xx,                 MPC5xx),
7746 80d11f44 j_mayer
#endif
7747 80d11f44 j_mayer
    /* MPC5xx microcontrollers                                               */
7748 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7749 80d11f44 j_mayer
    /* MGT560                                                                */
7750 80d11f44 j_mayer
    POWERPC_DEF("MGT560",        CPU_POWERPC_MGT560,                 MPC5xx),
7751 80d11f44 j_mayer
#endif
7752 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7753 80d11f44 j_mayer
    /* MPC509                                                                */
7754 80d11f44 j_mayer
    POWERPC_DEF("MPC509",        CPU_POWERPC_MPC509,                 MPC5xx),
7755 80d11f44 j_mayer
#endif
7756 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7757 80d11f44 j_mayer
    /* MPC533                                                                */
7758 80d11f44 j_mayer
    POWERPC_DEF("MPC533",        CPU_POWERPC_MPC533,                 MPC5xx),
7759 80d11f44 j_mayer
#endif
7760 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7761 80d11f44 j_mayer
    /* MPC534                                                                */
7762 80d11f44 j_mayer
    POWERPC_DEF("MPC534",        CPU_POWERPC_MPC534,                 MPC5xx),
7763 80d11f44 j_mayer
#endif
7764 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7765 80d11f44 j_mayer
    /* MPC555                                                                */
7766 80d11f44 j_mayer
    POWERPC_DEF("MPC555",        CPU_POWERPC_MPC555,                 MPC5xx),
7767 80d11f44 j_mayer
#endif
7768 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7769 80d11f44 j_mayer
    /* MPC556                                                                */
7770 80d11f44 j_mayer
    POWERPC_DEF("MPC556",        CPU_POWERPC_MPC556,                 MPC5xx),
7771 80d11f44 j_mayer
#endif
7772 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7773 80d11f44 j_mayer
    /* MPC560                                                                */
7774 80d11f44 j_mayer
    POWERPC_DEF("MPC560",        CPU_POWERPC_MPC560,                 MPC5xx),
7775 80d11f44 j_mayer
#endif
7776 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7777 80d11f44 j_mayer
    /* MPC561                                                                */
7778 80d11f44 j_mayer
    POWERPC_DEF("MPC561",        CPU_POWERPC_MPC561,                 MPC5xx),
7779 80d11f44 j_mayer
#endif
7780 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7781 80d11f44 j_mayer
    /* MPC562                                                                */
7782 80d11f44 j_mayer
    POWERPC_DEF("MPC562",        CPU_POWERPC_MPC562,                 MPC5xx),
7783 80d11f44 j_mayer
#endif
7784 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7785 80d11f44 j_mayer
    /* MPC563                                                                */
7786 80d11f44 j_mayer
    POWERPC_DEF("MPC563",        CPU_POWERPC_MPC563,                 MPC5xx),
7787 80d11f44 j_mayer
#endif
7788 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7789 80d11f44 j_mayer
    /* MPC564                                                                */
7790 80d11f44 j_mayer
    POWERPC_DEF("MPC564",        CPU_POWERPC_MPC564,                 MPC5xx),
7791 80d11f44 j_mayer
#endif
7792 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7793 80d11f44 j_mayer
    /* MPC565                                                                */
7794 80d11f44 j_mayer
    POWERPC_DEF("MPC565",        CPU_POWERPC_MPC565,                 MPC5xx),
7795 80d11f44 j_mayer
#endif
7796 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7797 80d11f44 j_mayer
    /* MPC566                                                                */
7798 80d11f44 j_mayer
    POWERPC_DEF("MPC566",        CPU_POWERPC_MPC566,                 MPC5xx),
7799 80d11f44 j_mayer
#endif
7800 80d11f44 j_mayer
    /* MPC8xx family (aka PowerQUICC)                                        */
7801 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7802 80d11f44 j_mayer
    /* Generic MPC8xx core                                                   */
7803 80d11f44 j_mayer
    POWERPC_DEF("MPC8xx",        CPU_POWERPC_MPC8xx,                 MPC8xx),
7804 80d11f44 j_mayer
#endif
7805 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7806 80d11f44 j_mayer
    /* Codename for MPC8xx core                                              */
7807 80d11f44 j_mayer
    POWERPC_DEF("PowerQUICC",    CPU_POWERPC_MPC8xx,                 MPC8xx),
7808 80d11f44 j_mayer
#endif
7809 80d11f44 j_mayer
    /* MPC8xx microcontrollers                                               */
7810 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7811 80d11f44 j_mayer
    /* MGT823                                                                */
7812 80d11f44 j_mayer
    POWERPC_DEF("MGT823",        CPU_POWERPC_MGT823,                 MPC8xx),
7813 80d11f44 j_mayer
#endif
7814 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7815 80d11f44 j_mayer
    /* MPC821                                                                */
7816 80d11f44 j_mayer
    POWERPC_DEF("MPC821",        CPU_POWERPC_MPC821,                 MPC8xx),
7817 80d11f44 j_mayer
#endif
7818 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7819 80d11f44 j_mayer
    /* MPC823                                                                */
7820 80d11f44 j_mayer
    POWERPC_DEF("MPC823",        CPU_POWERPC_MPC823,                 MPC8xx),
7821 80d11f44 j_mayer
#endif
7822 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7823 80d11f44 j_mayer
    /* MPC850                                                                */
7824 80d11f44 j_mayer
    POWERPC_DEF("MPC850",        CPU_POWERPC_MPC850,                 MPC8xx),
7825 80d11f44 j_mayer
#endif
7826 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7827 80d11f44 j_mayer
    /* MPC852T                                                               */
7828 80d11f44 j_mayer
    POWERPC_DEF("MPC852T",       CPU_POWERPC_MPC852T,                MPC8xx),
7829 80d11f44 j_mayer
#endif
7830 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7831 80d11f44 j_mayer
    /* MPC855T                                                               */
7832 80d11f44 j_mayer
    POWERPC_DEF("MPC855T",       CPU_POWERPC_MPC855T,                MPC8xx),
7833 80d11f44 j_mayer
#endif
7834 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7835 80d11f44 j_mayer
    /* MPC857                                                                */
7836 80d11f44 j_mayer
    POWERPC_DEF("MPC857",        CPU_POWERPC_MPC857,                 MPC8xx),
7837 80d11f44 j_mayer
#endif
7838 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7839 80d11f44 j_mayer
    /* MPC859                                                                */
7840 80d11f44 j_mayer
    POWERPC_DEF("MPC859",        CPU_POWERPC_MPC859,                 MPC8xx),
7841 80d11f44 j_mayer
#endif
7842 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7843 80d11f44 j_mayer
    /* MPC860                                                                */
7844 80d11f44 j_mayer
    POWERPC_DEF("MPC860",        CPU_POWERPC_MPC860,                 MPC8xx),
7845 80d11f44 j_mayer
#endif
7846 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7847 80d11f44 j_mayer
    /* MPC862                                                                */
7848 80d11f44 j_mayer
    POWERPC_DEF("MPC862",        CPU_POWERPC_MPC862,                 MPC8xx),
7849 80d11f44 j_mayer
#endif
7850 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7851 80d11f44 j_mayer
    /* MPC866                                                                */
7852 80d11f44 j_mayer
    POWERPC_DEF("MPC866",        CPU_POWERPC_MPC866,                 MPC8xx),
7853 80d11f44 j_mayer
#endif
7854 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7855 80d11f44 j_mayer
    /* MPC870                                                                */
7856 80d11f44 j_mayer
    POWERPC_DEF("MPC870",        CPU_POWERPC_MPC870,                 MPC8xx),
7857 80d11f44 j_mayer
#endif
7858 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7859 80d11f44 j_mayer
    /* MPC875                                                                */
7860 80d11f44 j_mayer
    POWERPC_DEF("MPC875",        CPU_POWERPC_MPC875,                 MPC8xx),
7861 80d11f44 j_mayer
#endif
7862 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7863 80d11f44 j_mayer
    /* MPC880                                                                */
7864 80d11f44 j_mayer
    POWERPC_DEF("MPC880",        CPU_POWERPC_MPC880,                 MPC8xx),
7865 80d11f44 j_mayer
#endif
7866 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7867 80d11f44 j_mayer
    /* MPC885                                                                */
7868 80d11f44 j_mayer
    POWERPC_DEF("MPC885",        CPU_POWERPC_MPC885,                 MPC8xx),
7869 80d11f44 j_mayer
#endif
7870 80d11f44 j_mayer
    /* MPC82xx family (aka PowerQUICC-II)                                    */
7871 80d11f44 j_mayer
    /* Generic MPC52xx core                                                  */
7872 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC52xx",
7873 80d11f44 j_mayer
                    CPU_POWERPC_MPC52xx,      POWERPC_SVR_52xx,      G2LE),
7874 80d11f44 j_mayer
    /* Generic MPC82xx core                                                  */
7875 80d11f44 j_mayer
    POWERPC_DEF("MPC82xx",       CPU_POWERPC_MPC82xx,                G2),
7876 80d11f44 j_mayer
    /* Codename for MPC82xx                                                  */
7877 80d11f44 j_mayer
    POWERPC_DEF("PowerQUICC-II", CPU_POWERPC_MPC82xx,                G2),
7878 80d11f44 j_mayer
    /* PowerPC G2 core                                                       */
7879 80d11f44 j_mayer
    POWERPC_DEF("G2",            CPU_POWERPC_G2,                     G2),
7880 80d11f44 j_mayer
    /* PowerPC G2 H4 core                                                    */
7881 80d11f44 j_mayer
    POWERPC_DEF("G2H4",          CPU_POWERPC_G2H4,                   G2),
7882 80d11f44 j_mayer
    /* PowerPC G2 GP core                                                    */
7883 80d11f44 j_mayer
    POWERPC_DEF("G2GP",          CPU_POWERPC_G2gp,                   G2),
7884 80d11f44 j_mayer
    /* PowerPC G2 LS core                                                    */
7885 80d11f44 j_mayer
    POWERPC_DEF("G2LS",          CPU_POWERPC_G2ls,                   G2),
7886 80d11f44 j_mayer
    /* PowerPC G2 HiP3 core                                                  */
7887 80d11f44 j_mayer
    POWERPC_DEF("G2HiP3",        CPU_POWERPC_G2_HIP3,                G2),
7888 80d11f44 j_mayer
    /* PowerPC G2 HiP4 core                                                  */
7889 80d11f44 j_mayer
    POWERPC_DEF("G2HiP4",        CPU_POWERPC_G2_HIP4,                G2),
7890 80d11f44 j_mayer
    /* PowerPC MPC603 core                                                   */
7891 80d11f44 j_mayer
    POWERPC_DEF("MPC603",        CPU_POWERPC_MPC603,                 603E),
7892 80d11f44 j_mayer
    /* PowerPC G2le core (same as G2 plus little-endian mode support)        */
7893 80d11f44 j_mayer
    POWERPC_DEF("G2le",          CPU_POWERPC_G2LE,                   G2LE),
7894 80d11f44 j_mayer
    /* PowerPC G2LE GP core                                                  */
7895 80d11f44 j_mayer
    POWERPC_DEF("G2leGP",        CPU_POWERPC_G2LEgp,                 G2LE),
7896 80d11f44 j_mayer
    /* PowerPC G2LE LS core                                                  */
7897 80d11f44 j_mayer
    POWERPC_DEF("G2leLS",        CPU_POWERPC_G2LEls,                 G2LE),
7898 80d11f44 j_mayer
    /* PowerPC G2LE GP1 core                                                 */
7899 80d11f44 j_mayer
    POWERPC_DEF("G2leGP1",       CPU_POWERPC_G2LEgp1,                G2LE),
7900 80d11f44 j_mayer
    /* PowerPC G2LE GP3 core                                                 */
7901 80d11f44 j_mayer
    POWERPC_DEF("G2leGP3",       CPU_POWERPC_G2LEgp1,                G2LE),
7902 80d11f44 j_mayer
    /* PowerPC MPC603 microcontrollers                                       */
7903 80d11f44 j_mayer
    /* MPC8240                                                               */
7904 80d11f44 j_mayer
    POWERPC_DEF("MPC8240",       CPU_POWERPC_MPC8240,                603E),
7905 80d11f44 j_mayer
    /* PowerPC G2 microcontrollers                                           */
7906 082c6681 j_mayer
#if defined(TODO)
7907 80d11f44 j_mayer
    /* MPC5121                                                               */
7908 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5121",
7909 80d11f44 j_mayer
                    CPU_POWERPC_MPC5121,      POWERPC_SVR_5121,      G2LE),
7910 80d11f44 j_mayer
#endif
7911 80d11f44 j_mayer
    /* MPC5200                                                               */
7912 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200",
7913 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200,      POWERPC_SVR_5200,      G2LE),
7914 80d11f44 j_mayer
    /* MPC5200 v1.0                                                          */
7915 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v10",
7916 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v10,  POWERPC_SVR_5200_v10,  G2LE),
7917 80d11f44 j_mayer
    /* MPC5200 v1.1                                                          */
7918 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v11",
7919 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v11,  POWERPC_SVR_5200_v11,  G2LE),
7920 80d11f44 j_mayer
    /* MPC5200 v1.2                                                          */
7921 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v12",
7922 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v12,  POWERPC_SVR_5200_v12,  G2LE),
7923 80d11f44 j_mayer
    /* MPC5200B                                                              */
7924 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B",
7925 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B,     POWERPC_SVR_5200B,     G2LE),
7926 80d11f44 j_mayer
    /* MPC5200B v2.0                                                         */
7927 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B_v20",
7928 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B_v20, POWERPC_SVR_5200B_v20, G2LE),
7929 80d11f44 j_mayer
    /* MPC5200B v2.1                                                         */
7930 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B_v21",
7931 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B_v21, POWERPC_SVR_5200B_v21, G2LE),
7932 80d11f44 j_mayer
    /* MPC8241                                                               */
7933 80d11f44 j_mayer
    POWERPC_DEF("MPC8241",       CPU_POWERPC_MPC8241,                G2),
7934 80d11f44 j_mayer
    /* MPC8245                                                               */
7935 80d11f44 j_mayer
    POWERPC_DEF("MPC8245",       CPU_POWERPC_MPC8245,                G2),
7936 80d11f44 j_mayer
    /* MPC8247                                                               */
7937 80d11f44 j_mayer
    POWERPC_DEF("MPC8247",       CPU_POWERPC_MPC8247,                G2LE),
7938 80d11f44 j_mayer
    /* MPC8248                                                               */
7939 80d11f44 j_mayer
    POWERPC_DEF("MPC8248",       CPU_POWERPC_MPC8248,                G2LE),
7940 80d11f44 j_mayer
    /* MPC8250                                                               */
7941 80d11f44 j_mayer
    POWERPC_DEF("MPC8250",       CPU_POWERPC_MPC8250,                G2),
7942 80d11f44 j_mayer
    /* MPC8250 HiP3                                                          */
7943 80d11f44 j_mayer
    POWERPC_DEF("MPC8250_HiP3",  CPU_POWERPC_MPC8250_HiP3,           G2),
7944 80d11f44 j_mayer
    /* MPC8250 HiP4                                                          */
7945 80d11f44 j_mayer
    POWERPC_DEF("MPC8250_HiP4",  CPU_POWERPC_MPC8250_HiP4,           G2),
7946 80d11f44 j_mayer
    /* MPC8255                                                               */
7947 80d11f44 j_mayer
    POWERPC_DEF("MPC8255",       CPU_POWERPC_MPC8255,                G2),
7948 80d11f44 j_mayer
    /* MPC8255 HiP3                                                          */
7949 80d11f44 j_mayer
    POWERPC_DEF("MPC8255_HiP3",  CPU_POWERPC_MPC8255_HiP3,           G2),
7950 80d11f44 j_mayer
    /* MPC8255 HiP4                                                          */
7951 80d11f44 j_mayer
    POWERPC_DEF("MPC8255_HiP4",  CPU_POWERPC_MPC8255_HiP4,           G2),
7952 80d11f44 j_mayer
    /* MPC8260                                                               */
7953 80d11f44 j_mayer
    POWERPC_DEF("MPC8260",       CPU_POWERPC_MPC8260,                G2),
7954 80d11f44 j_mayer
    /* MPC8260 HiP3                                                          */
7955 80d11f44 j_mayer
    POWERPC_DEF("MPC8260_HiP3",  CPU_POWERPC_MPC8260_HiP3,           G2),
7956 80d11f44 j_mayer
    /* MPC8260 HiP4                                                          */
7957 80d11f44 j_mayer
    POWERPC_DEF("MPC8260_HiP4",  CPU_POWERPC_MPC8260_HiP4,           G2),
7958 80d11f44 j_mayer
    /* MPC8264                                                               */
7959 80d11f44 j_mayer
    POWERPC_DEF("MPC8264",       CPU_POWERPC_MPC8264,                G2),
7960 80d11f44 j_mayer
    /* MPC8264 HiP3                                                          */
7961 80d11f44 j_mayer
    POWERPC_DEF("MPC8264_HiP3",  CPU_POWERPC_MPC8264_HiP3,           G2),
7962 80d11f44 j_mayer
    /* MPC8264 HiP4                                                          */
7963 80d11f44 j_mayer
    POWERPC_DEF("MPC8264_HiP4",  CPU_POWERPC_MPC8264_HiP4,           G2),
7964 80d11f44 j_mayer
    /* MPC8265                                                               */
7965 80d11f44 j_mayer
    POWERPC_DEF("MPC8265",       CPU_POWERPC_MPC8265,                G2),
7966 80d11f44 j_mayer
    /* MPC8265 HiP3                                                          */
7967 80d11f44 j_mayer
    POWERPC_DEF("MPC8265_HiP3",  CPU_POWERPC_MPC8265_HiP3,           G2),
7968 80d11f44 j_mayer
    /* MPC8265 HiP4                                                          */
7969 80d11f44 j_mayer
    POWERPC_DEF("MPC8265_HiP4",  CPU_POWERPC_MPC8265_HiP4,           G2),
7970 80d11f44 j_mayer
    /* MPC8266                                                               */
7971 80d11f44 j_mayer
    POWERPC_DEF("MPC8266",       CPU_POWERPC_MPC8266,                G2),
7972 80d11f44 j_mayer
    /* MPC8266 HiP3                                                          */
7973 80d11f44 j_mayer
    POWERPC_DEF("MPC8266_HiP3",  CPU_POWERPC_MPC8266_HiP3,           G2),
7974 80d11f44 j_mayer
    /* MPC8266 HiP4                                                          */
7975 80d11f44 j_mayer
    POWERPC_DEF("MPC8266_HiP4",  CPU_POWERPC_MPC8266_HiP4,           G2),
7976 80d11f44 j_mayer
    /* MPC8270                                                               */
7977 80d11f44 j_mayer
    POWERPC_DEF("MPC8270",       CPU_POWERPC_MPC8270,                G2LE),
7978 80d11f44 j_mayer
    /* MPC8271                                                               */
7979 80d11f44 j_mayer
    POWERPC_DEF("MPC8271",       CPU_POWERPC_MPC8271,                G2LE),
7980 80d11f44 j_mayer
    /* MPC8272                                                               */
7981 80d11f44 j_mayer
    POWERPC_DEF("MPC8272",       CPU_POWERPC_MPC8272,                G2LE),
7982 80d11f44 j_mayer
    /* MPC8275                                                               */
7983 80d11f44 j_mayer
    POWERPC_DEF("MPC8275",       CPU_POWERPC_MPC8275,                G2LE),
7984 80d11f44 j_mayer
    /* MPC8280                                                               */
7985 80d11f44 j_mayer
    POWERPC_DEF("MPC8280",       CPU_POWERPC_MPC8280,                G2LE),
7986 a750fc0b j_mayer
    /* e200 family                                                           */
7987 a750fc0b j_mayer
    /* Generic PowerPC e200 core                                             */
7988 80d11f44 j_mayer
    POWERPC_DEF("e200",          CPU_POWERPC_e200,                   e200),
7989 80d11f44 j_mayer
    /* Generic MPC55xx core                                                  */
7990 80d11f44 j_mayer
#if defined (TODO)
7991 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC55xx",
7992 80d11f44 j_mayer
                    CPU_POWERPC_MPC55xx,      POWERPC_SVR_55xx,      e200),
7993 a750fc0b j_mayer
#endif
7994 a750fc0b j_mayer
#if defined (TODO)
7995 80d11f44 j_mayer
    /* PowerPC e200z0 core                                                   */
7996 80d11f44 j_mayer
    POWERPC_DEF("e200z0",        CPU_POWERPC_e200z0,                 e200),
7997 a750fc0b j_mayer
#endif
7998 a750fc0b j_mayer
#if defined (TODO)
7999 80d11f44 j_mayer
    /* PowerPC e200z1 core                                                   */
8000 80d11f44 j_mayer
    POWERPC_DEF("e200z1",        CPU_POWERPC_e200z1,                 e200),
8001 80d11f44 j_mayer
#endif
8002 80d11f44 j_mayer
#if defined (TODO)
8003 80d11f44 j_mayer
    /* PowerPC e200z3 core                                                   */
8004 80d11f44 j_mayer
    POWERPC_DEF("e200z3",        CPU_POWERPC_e200z3,                 e200),
8005 80d11f44 j_mayer
#endif
8006 80d11f44 j_mayer
    /* PowerPC e200z5 core                                                   */
8007 80d11f44 j_mayer
    POWERPC_DEF("e200z5",        CPU_POWERPC_e200z5,                 e200),
8008 a750fc0b j_mayer
    /* PowerPC e200z6 core                                                   */
8009 80d11f44 j_mayer
    POWERPC_DEF("e200z6",        CPU_POWERPC_e200z6,                 e200),
8010 80d11f44 j_mayer
    /* PowerPC e200 microcontrollers                                         */
8011 80d11f44 j_mayer
#if defined (TODO)
8012 80d11f44 j_mayer
    /* MPC5514E                                                              */
8013 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E",
8014 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E,     POWERPC_SVR_5514E,     e200),
8015 a750fc0b j_mayer
#endif
8016 a750fc0b j_mayer
#if defined (TODO)
8017 80d11f44 j_mayer
    /* MPC5514E v0                                                           */
8018 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E_v0",
8019 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E_v0,  POWERPC_SVR_5514E_v0,  e200),
8020 a750fc0b j_mayer
#endif
8021 a750fc0b j_mayer
#if defined (TODO)
8022 80d11f44 j_mayer
    /* MPC5514E v1                                                           */
8023 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E_v1",
8024 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E_v1,  POWERPC_SVR_5514E_v1,  e200),
8025 a750fc0b j_mayer
#endif
8026 a750fc0b j_mayer
#if defined (TODO)
8027 80d11f44 j_mayer
    /* MPC5514G                                                              */
8028 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G",
8029 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G,     POWERPC_SVR_5514G,     e200),
8030 a750fc0b j_mayer
#endif
8031 a750fc0b j_mayer
#if defined (TODO)
8032 80d11f44 j_mayer
    /* MPC5514G v0                                                           */
8033 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G_v0",
8034 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G_v0,  POWERPC_SVR_5514G_v0,  e200),
8035 a750fc0b j_mayer
#endif
8036 a750fc0b j_mayer
#if defined (TODO)
8037 80d11f44 j_mayer
    /* MPC5514G v1                                                           */
8038 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G_v1",
8039 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G_v1,  POWERPC_SVR_5514G_v1,  e200),
8040 a750fc0b j_mayer
#endif
8041 a750fc0b j_mayer
#if defined (TODO)
8042 80d11f44 j_mayer
    /* MPC5515S                                                              */
8043 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5515S",
8044 80d11f44 j_mayer
                    CPU_POWERPC_MPC5515S,     POWERPC_SVR_5515S,     e200),
8045 a750fc0b j_mayer
#endif
8046 a750fc0b j_mayer
#if defined (TODO)
8047 80d11f44 j_mayer
    /* MPC5516E                                                              */
8048 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E",
8049 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E,     POWERPC_SVR_5516E,     e200),
8050 a750fc0b j_mayer
#endif
8051 a750fc0b j_mayer
#if defined (TODO)
8052 80d11f44 j_mayer
    /* MPC5516E v0                                                           */
8053 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E_v0",
8054 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E_v0,  POWERPC_SVR_5516E_v0,  e200),
8055 a750fc0b j_mayer
#endif
8056 a750fc0b j_mayer
#if defined (TODO)
8057 80d11f44 j_mayer
    /* MPC5516E v1                                                           */
8058 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E_v1",
8059 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E_v1,  POWERPC_SVR_5516E_v1,  e200),
8060 a750fc0b j_mayer
#endif
8061 a750fc0b j_mayer
#if defined (TODO)
8062 80d11f44 j_mayer
    /* MPC5516G                                                              */
8063 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G",
8064 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G,     POWERPC_SVR_5516G,     e200),
8065 a750fc0b j_mayer
#endif
8066 a750fc0b j_mayer
#if defined (TODO)
8067 80d11f44 j_mayer
    /* MPC5516G v0                                                           */
8068 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G_v0",
8069 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G_v0,  POWERPC_SVR_5516G_v0,  e200),
8070 a750fc0b j_mayer
#endif
8071 a750fc0b j_mayer
#if defined (TODO)
8072 80d11f44 j_mayer
    /* MPC5516G v1                                                           */
8073 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G_v1",
8074 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G_v1,  POWERPC_SVR_5516G_v1,  e200),
8075 a750fc0b j_mayer
#endif
8076 a750fc0b j_mayer
#if defined (TODO)
8077 80d11f44 j_mayer
    /* MPC5516S                                                              */
8078 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516S",
8079 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516S,     POWERPC_SVR_5516S,     e200),
8080 a750fc0b j_mayer
#endif
8081 a750fc0b j_mayer
#if defined (TODO)
8082 80d11f44 j_mayer
    /* MPC5533                                                               */
8083 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5533",
8084 80d11f44 j_mayer
                    CPU_POWERPC_MPC5533,      POWERPC_SVR_5533,      e200),
8085 a750fc0b j_mayer
#endif
8086 a750fc0b j_mayer
#if defined (TODO)
8087 80d11f44 j_mayer
    /* MPC5534                                                               */
8088 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5534",
8089 80d11f44 j_mayer
                    CPU_POWERPC_MPC5534,      POWERPC_SVR_5534,      e200),
8090 a750fc0b j_mayer
#endif
8091 80d11f44 j_mayer
#if defined (TODO)
8092 80d11f44 j_mayer
    /* MPC5553                                                               */
8093 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5553",
8094 80d11f44 j_mayer
                    CPU_POWERPC_MPC5553,      POWERPC_SVR_5553,      e200),
8095 80d11f44 j_mayer
#endif
8096 80d11f44 j_mayer
#if defined (TODO)
8097 80d11f44 j_mayer
    /* MPC5554                                                               */
8098 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5554",
8099 80d11f44 j_mayer
                    CPU_POWERPC_MPC5554,      POWERPC_SVR_5554,      e200),
8100 80d11f44 j_mayer
#endif
8101 80d11f44 j_mayer
#if defined (TODO)
8102 80d11f44 j_mayer
    /* MPC5561                                                               */
8103 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5561",
8104 80d11f44 j_mayer
                    CPU_POWERPC_MPC5561,      POWERPC_SVR_5561,      e200),
8105 80d11f44 j_mayer
#endif
8106 80d11f44 j_mayer
#if defined (TODO)
8107 80d11f44 j_mayer
    /* MPC5565                                                               */
8108 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5565",
8109 80d11f44 j_mayer
                    CPU_POWERPC_MPC5565,      POWERPC_SVR_5565,      e200),
8110 80d11f44 j_mayer
#endif
8111 80d11f44 j_mayer
#if defined (TODO)
8112 80d11f44 j_mayer
    /* MPC5566                                                               */
8113 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5566",
8114 80d11f44 j_mayer
                    CPU_POWERPC_MPC5566,      POWERPC_SVR_5566,      e200),
8115 80d11f44 j_mayer
#endif
8116 80d11f44 j_mayer
#if defined (TODO)
8117 80d11f44 j_mayer
    /* MPC5567                                                               */
8118 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5567",
8119 80d11f44 j_mayer
                    CPU_POWERPC_MPC5567,      POWERPC_SVR_5567,      e200),
8120 80d11f44 j_mayer
#endif
8121 80d11f44 j_mayer
    /* e300 family                                                           */
8122 80d11f44 j_mayer
    /* Generic PowerPC e300 core                                             */
8123 80d11f44 j_mayer
    POWERPC_DEF("e300",          CPU_POWERPC_e300,                   e300),
8124 80d11f44 j_mayer
    /* PowerPC e300c1 core                                                   */
8125 80d11f44 j_mayer
    POWERPC_DEF("e300c1",        CPU_POWERPC_e300c1,                 e300),
8126 80d11f44 j_mayer
    /* PowerPC e300c2 core                                                   */
8127 80d11f44 j_mayer
    POWERPC_DEF("e300c2",        CPU_POWERPC_e300c2,                 e300),
8128 80d11f44 j_mayer
    /* PowerPC e300c3 core                                                   */
8129 80d11f44 j_mayer
    POWERPC_DEF("e300c3",        CPU_POWERPC_e300c3,                 e300),
8130 80d11f44 j_mayer
    /* PowerPC e300c4 core                                                   */
8131 80d11f44 j_mayer
    POWERPC_DEF("e300c4",        CPU_POWERPC_e300c4,                 e300),
8132 80d11f44 j_mayer
    /* PowerPC e300 microcontrollers                                         */
8133 80d11f44 j_mayer
#if defined (TODO)
8134 80d11f44 j_mayer
    /* MPC8313                                                               */
8135 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8313",
8136 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8313,      e300),
8137 80d11f44 j_mayer
#endif
8138 80d11f44 j_mayer
#if defined (TODO)
8139 80d11f44 j_mayer
    /* MPC8313E                                                              */
8140 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8313E",
8141 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8313E,     e300),
8142 80d11f44 j_mayer
#endif
8143 80d11f44 j_mayer
#if defined (TODO)
8144 80d11f44 j_mayer
    /* MPC8314                                                               */
8145 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8314",
8146 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8314,      e300),
8147 80d11f44 j_mayer
#endif
8148 80d11f44 j_mayer
#if defined (TODO)
8149 80d11f44 j_mayer
    /* MPC8314E                                                              */
8150 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8314E",
8151 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8314E,     e300),
8152 80d11f44 j_mayer
#endif
8153 80d11f44 j_mayer
#if defined (TODO)
8154 80d11f44 j_mayer
    /* MPC8315                                                               */
8155 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8315",
8156 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8315,      e300),
8157 80d11f44 j_mayer
#endif
8158 80d11f44 j_mayer
#if defined (TODO)
8159 80d11f44 j_mayer
    /* MPC8315E                                                              */
8160 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8315E",
8161 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8315E,     e300),
8162 80d11f44 j_mayer
#endif
8163 80d11f44 j_mayer
#if defined (TODO)
8164 80d11f44 j_mayer
    /* MPC8321                                                               */
8165 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8321",
8166 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8321,      e300),
8167 80d11f44 j_mayer
#endif
8168 80d11f44 j_mayer
#if defined (TODO)
8169 80d11f44 j_mayer
    /* MPC8321E                                                              */
8170 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8321E",
8171 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8321E,     e300),
8172 80d11f44 j_mayer
#endif
8173 80d11f44 j_mayer
#if defined (TODO)
8174 80d11f44 j_mayer
    /* MPC8323                                                               */
8175 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8323",
8176 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8323,      e300),
8177 80d11f44 j_mayer
#endif
8178 80d11f44 j_mayer
#if defined (TODO)
8179 80d11f44 j_mayer
    /* MPC8323E                                                              */
8180 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8323E",
8181 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8323E,     e300),
8182 80d11f44 j_mayer
#endif
8183 492d7bf5 Thomas Monjalon
    /* MPC8343                                                               */
8184 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8343",
8185 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343,      e300),
8186 80d11f44 j_mayer
    /* MPC8343A                                                              */
8187 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8343A",
8188 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343A,     e300),
8189 492d7bf5 Thomas Monjalon
    /* MPC8343E                                                              */
8190 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8343E",
8191 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343E,     e300),
8192 80d11f44 j_mayer
    /* MPC8343EA                                                             */
8193 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8343EA",
8194 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343EA,    e300),
8195 492d7bf5 Thomas Monjalon
    /* MPC8347                                                               */
8196 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347",
8197 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347,      e300),
8198 492d7bf5 Thomas Monjalon
    /* MPC8347T                                                              */
8199 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347T",
8200 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347T,     e300),
8201 492d7bf5 Thomas Monjalon
    /* MPC8347P                                                              */
8202 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347P",
8203 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347P,     e300),
8204 80d11f44 j_mayer
    /* MPC8347A                                                              */
8205 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347A",
8206 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347A,     e300),
8207 80d11f44 j_mayer
    /* MPC8347AT                                                             */
8208 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347AT",
8209 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347AT,    e300),
8210 80d11f44 j_mayer
    /* MPC8347AP                                                             */
8211 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347AP",
8212 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347AP,    e300),
8213 492d7bf5 Thomas Monjalon
    /* MPC8347E                                                              */
8214 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347E",
8215 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347E,     e300),
8216 492d7bf5 Thomas Monjalon
    /* MPC8347ET                                                             */
8217 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347ET",
8218 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347ET,    e300),
8219 492d7bf5 Thomas Monjalon
    /* MPC8343EP                                                             */
8220 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347EP",
8221 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EP,    e300),
8222 80d11f44 j_mayer
    /* MPC8347EA                                                             */
8223 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EA",
8224 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EA,    e300),
8225 80d11f44 j_mayer
    /* MPC8347EAT                                                            */
8226 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EAT",
8227 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EAT,   e300),
8228 80d11f44 j_mayer
    /* MPC8343EAP                                                            */
8229 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EAP",
8230 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EAP,   e300),
8231 80d11f44 j_mayer
    /* MPC8349                                                               */
8232 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349",
8233 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349,      e300),
8234 80d11f44 j_mayer
    /* MPC8349A                                                              */
8235 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349A",
8236 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349A,     e300),
8237 80d11f44 j_mayer
    /* MPC8349E                                                              */
8238 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349E",
8239 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349E,     e300),
8240 80d11f44 j_mayer
    /* MPC8349EA                                                             */
8241 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349EA",
8242 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349EA,    e300),
8243 80d11f44 j_mayer
#if defined (TODO)
8244 80d11f44 j_mayer
    /* MPC8358E                                                              */
8245 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8358E",
8246 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC835x,      POWERPC_SVR_8358E,     e300),
8247 80d11f44 j_mayer
#endif
8248 80d11f44 j_mayer
#if defined (TODO)
8249 80d11f44 j_mayer
    /* MPC8360E                                                              */
8250 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8360E",
8251 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC836x,      POWERPC_SVR_8360E,     e300),
8252 80d11f44 j_mayer
#endif
8253 80d11f44 j_mayer
    /* MPC8377                                                               */
8254 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8377",
8255 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8377,      e300),
8256 80d11f44 j_mayer
    /* MPC8377E                                                              */
8257 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8377E",
8258 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8377E,     e300),
8259 80d11f44 j_mayer
    /* MPC8378                                                               */
8260 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8378",
8261 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8378,      e300),
8262 80d11f44 j_mayer
    /* MPC8378E                                                              */
8263 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8378E",
8264 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8378E,     e300),
8265 80d11f44 j_mayer
    /* MPC8379                                                               */
8266 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8379",
8267 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8379,      e300),
8268 80d11f44 j_mayer
    /* MPC8379E                                                              */
8269 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8379E",
8270 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8379E,     e300),
8271 80d11f44 j_mayer
    /* e500 family                                                           */
8272 80d11f44 j_mayer
    /* PowerPC e500 core                                                     */
8273 bd5ea513 aurel32
    POWERPC_DEF("e500",          CPU_POWERPC_e500v2_v22,             e500v2),
8274 bd5ea513 aurel32
    /* PowerPC e500v1 core                                                   */
8275 bd5ea513 aurel32
    POWERPC_DEF("e500v1",        CPU_POWERPC_e500v1,                 e500v1),
8276 80d11f44 j_mayer
    /* PowerPC e500 v1.0 core                                                */
8277 bd5ea513 aurel32
    POWERPC_DEF("e500_v10",      CPU_POWERPC_e500v1_v10,             e500v1),
8278 80d11f44 j_mayer
    /* PowerPC e500 v2.0 core                                                */
8279 bd5ea513 aurel32
    POWERPC_DEF("e500_v20",      CPU_POWERPC_e500v1_v20,             e500v1),
8280 80d11f44 j_mayer
    /* PowerPC e500v2 core                                                   */
8281 bd5ea513 aurel32
    POWERPC_DEF("e500v2",        CPU_POWERPC_e500v2,                 e500v2),
8282 80d11f44 j_mayer
    /* PowerPC e500v2 v1.0 core                                              */
8283 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v10",    CPU_POWERPC_e500v2_v10,             e500v2),
8284 80d11f44 j_mayer
    /* PowerPC e500v2 v2.0 core                                              */
8285 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v20",    CPU_POWERPC_e500v2_v20,             e500v2),
8286 80d11f44 j_mayer
    /* PowerPC e500v2 v2.1 core                                              */
8287 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v21",    CPU_POWERPC_e500v2_v21,             e500v2),
8288 80d11f44 j_mayer
    /* PowerPC e500v2 v2.2 core                                              */
8289 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v22",    CPU_POWERPC_e500v2_v22,             e500v2),
8290 80d11f44 j_mayer
    /* PowerPC e500v2 v3.0 core                                              */
8291 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v30",    CPU_POWERPC_e500v2_v30,             e500v2),
8292 80d11f44 j_mayer
    /* PowerPC e500 microcontrollers                                         */
8293 80d11f44 j_mayer
    /* MPC8533                                                               */
8294 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533",
8295 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533,      POWERPC_SVR_8533,      e500v2),
8296 80d11f44 j_mayer
    /* MPC8533 v1.0                                                          */
8297 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533_v10",
8298 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533_v10,  POWERPC_SVR_8533_v10,  e500v2),
8299 80d11f44 j_mayer
    /* MPC8533 v1.1                                                          */
8300 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533_v11",
8301 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533_v11,  POWERPC_SVR_8533_v11,  e500v2),
8302 80d11f44 j_mayer
    /* MPC8533E                                                              */
8303 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E",
8304 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533E,     POWERPC_SVR_8533E,     e500v2),
8305 80d11f44 j_mayer
    /* MPC8533E v1.0                                                         */
8306 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E_v10",
8307 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533E_v10, POWERPC_SVR_8533E_v10, e500v2),
8308 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E_v11",
8309 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533E_v11, POWERPC_SVR_8533E_v11, e500v2),
8310 80d11f44 j_mayer
    /* MPC8540                                                               */
8311 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540",
8312 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540,      POWERPC_SVR_8540,      e500v1),
8313 80d11f44 j_mayer
    /* MPC8540 v1.0                                                          */
8314 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v10",
8315 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540_v10,  POWERPC_SVR_8540_v10,  e500v1),
8316 80d11f44 j_mayer
    /* MPC8540 v2.0                                                          */
8317 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v20",
8318 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540_v20,  POWERPC_SVR_8540_v20,  e500v1),
8319 80d11f44 j_mayer
    /* MPC8540 v2.1                                                          */
8320 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v21",
8321 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540_v21,  POWERPC_SVR_8540_v21,  e500v1),
8322 80d11f44 j_mayer
    /* MPC8541                                                               */
8323 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541",
8324 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541,      POWERPC_SVR_8541,      e500v1),
8325 80d11f44 j_mayer
    /* MPC8541 v1.0                                                          */
8326 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541_v10",
8327 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541_v10,  POWERPC_SVR_8541_v10,  e500v1),
8328 80d11f44 j_mayer
    /* MPC8541 v1.1                                                          */
8329 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541_v11",
8330 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541_v11,  POWERPC_SVR_8541_v11,  e500v1),
8331 80d11f44 j_mayer
    /* MPC8541E                                                              */
8332 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E",
8333 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541E,     POWERPC_SVR_8541E,     e500v1),
8334 80d11f44 j_mayer
    /* MPC8541E v1.0                                                         */
8335 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E_v10",
8336 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541E_v10, POWERPC_SVR_8541E_v10, e500v1),
8337 80d11f44 j_mayer
    /* MPC8541E v1.1                                                         */
8338 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E_v11",
8339 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541E_v11, POWERPC_SVR_8541E_v11, e500v1),
8340 80d11f44 j_mayer
    /* MPC8543                                                               */
8341 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543",
8342 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543,      POWERPC_SVR_8543,      e500v2),
8343 80d11f44 j_mayer
    /* MPC8543 v1.0                                                          */
8344 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v10",
8345 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v10,  POWERPC_SVR_8543_v10,  e500v2),
8346 80d11f44 j_mayer
    /* MPC8543 v1.1                                                          */
8347 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v11",
8348 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v11,  POWERPC_SVR_8543_v11,  e500v2),
8349 80d11f44 j_mayer
    /* MPC8543 v2.0                                                          */
8350 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v20",
8351 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v20,  POWERPC_SVR_8543_v20,  e500v2),
8352 80d11f44 j_mayer
    /* MPC8543 v2.1                                                          */
8353 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v21",
8354 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v21,  POWERPC_SVR_8543_v21,  e500v2),
8355 80d11f44 j_mayer
    /* MPC8543E                                                              */
8356 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E",
8357 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E,     POWERPC_SVR_8543E,     e500v2),
8358 80d11f44 j_mayer
    /* MPC8543E v1.0                                                         */
8359 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v10",
8360 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v10, POWERPC_SVR_8543E_v10, e500v2),
8361 80d11f44 j_mayer
    /* MPC8543E v1.1                                                         */
8362 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v11",
8363 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v11, POWERPC_SVR_8543E_v11, e500v2),
8364 80d11f44 j_mayer
    /* MPC8543E v2.0                                                         */
8365 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v20",
8366 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v20, POWERPC_SVR_8543E_v20, e500v2),
8367 80d11f44 j_mayer
    /* MPC8543E v2.1                                                         */
8368 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v21",
8369 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v21, POWERPC_SVR_8543E_v21, e500v2),
8370 80d11f44 j_mayer
    /* MPC8544                                                               */
8371 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544",
8372 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544,      POWERPC_SVR_8544,      e500v2),
8373 80d11f44 j_mayer
    /* MPC8544 v1.0                                                          */
8374 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544_v10",
8375 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544_v10,  POWERPC_SVR_8544_v10,  e500v2),
8376 80d11f44 j_mayer
    /* MPC8544 v1.1                                                          */
8377 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544_v11",
8378 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544_v11,  POWERPC_SVR_8544_v11,  e500v2),
8379 80d11f44 j_mayer
    /* MPC8544E                                                              */
8380 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E",
8381 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544E,     POWERPC_SVR_8544E,     e500v2),
8382 80d11f44 j_mayer
    /* MPC8544E v1.0                                                         */
8383 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E_v10",
8384 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544E_v10, POWERPC_SVR_8544E_v10, e500v2),
8385 80d11f44 j_mayer
    /* MPC8544E v1.1                                                         */
8386 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E_v11",
8387 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544E_v11, POWERPC_SVR_8544E_v11, e500v2),
8388 80d11f44 j_mayer
    /* MPC8545                                                               */
8389 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545",
8390 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545,      POWERPC_SVR_8545,      e500v2),
8391 80d11f44 j_mayer
    /* MPC8545 v2.0                                                          */
8392 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545_v20",
8393 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545_v20,  POWERPC_SVR_8545_v20,  e500v2),
8394 80d11f44 j_mayer
    /* MPC8545 v2.1                                                          */
8395 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545_v21",
8396 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545_v21,  POWERPC_SVR_8545_v21,  e500v2),
8397 80d11f44 j_mayer
    /* MPC8545E                                                              */
8398 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E",
8399 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545E,     POWERPC_SVR_8545E,     e500v2),
8400 80d11f44 j_mayer
    /* MPC8545E v2.0                                                         */
8401 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E_v20",
8402 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545E_v20, POWERPC_SVR_8545E_v20, e500v2),
8403 80d11f44 j_mayer
    /* MPC8545E v2.1                                                         */
8404 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E_v21",
8405 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545E_v21, POWERPC_SVR_8545E_v21, e500v2),
8406 80d11f44 j_mayer
    /* MPC8547E                                                              */
8407 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E",
8408 bd5ea513 aurel32
                    CPU_POWERPC_MPC8547E,     POWERPC_SVR_8547E,     e500v2),
8409 80d11f44 j_mayer
    /* MPC8547E v2.0                                                         */
8410 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E_v20",
8411 bd5ea513 aurel32
                    CPU_POWERPC_MPC8547E_v20, POWERPC_SVR_8547E_v20, e500v2),
8412 80d11f44 j_mayer
    /* MPC8547E v2.1                                                         */
8413 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E_v21",
8414 bd5ea513 aurel32
                    CPU_POWERPC_MPC8547E_v21, POWERPC_SVR_8547E_v21, e500v2),
8415 80d11f44 j_mayer
    /* MPC8548                                                               */
8416 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548",
8417 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548,      POWERPC_SVR_8548,      e500v2),
8418 80d11f44 j_mayer
    /* MPC8548 v1.0                                                          */
8419 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v10",
8420 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v10,  POWERPC_SVR_8548_v10,  e500v2),
8421 80d11f44 j_mayer
    /* MPC8548 v1.1                                                          */
8422 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v11",
8423 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v11,  POWERPC_SVR_8548_v11,  e500v2),
8424 80d11f44 j_mayer
    /* MPC8548 v2.0                                                          */
8425 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v20",
8426 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v20,  POWERPC_SVR_8548_v20,  e500v2),
8427 80d11f44 j_mayer
    /* MPC8548 v2.1                                                          */
8428 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v21",
8429 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v21,  POWERPC_SVR_8548_v21,  e500v2),
8430 80d11f44 j_mayer
    /* MPC8548E                                                              */
8431 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E",
8432 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E,     POWERPC_SVR_8548E,     e500v2),
8433 80d11f44 j_mayer
    /* MPC8548E v1.0                                                         */
8434 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v10",
8435 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v10, POWERPC_SVR_8548E_v10, e500v2),
8436 80d11f44 j_mayer
    /* MPC8548E v1.1                                                         */
8437 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v11",
8438 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v11, POWERPC_SVR_8548E_v11, e500v2),
8439 80d11f44 j_mayer
    /* MPC8548E v2.0                                                         */
8440 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v20",
8441 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v20, POWERPC_SVR_8548E_v20, e500v2),
8442 80d11f44 j_mayer
    /* MPC8548E v2.1                                                         */
8443 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v21",
8444 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v21, POWERPC_SVR_8548E_v21, e500v2),
8445 80d11f44 j_mayer
    /* MPC8555                                                               */
8446 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555",
8447 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555,      POWERPC_SVR_8555,      e500v2),
8448 80d11f44 j_mayer
    /* MPC8555 v1.0                                                          */
8449 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555_v10",
8450 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555_v10,  POWERPC_SVR_8555_v10,  e500v2),
8451 80d11f44 j_mayer
    /* MPC8555 v1.1                                                          */
8452 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555_v11",
8453 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555_v11,  POWERPC_SVR_8555_v11,  e500v2),
8454 80d11f44 j_mayer
    /* MPC8555E                                                              */
8455 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E",
8456 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555E,     POWERPC_SVR_8555E,     e500v2),
8457 80d11f44 j_mayer
    /* MPC8555E v1.0                                                         */
8458 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E_v10",
8459 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555E_v10, POWERPC_SVR_8555E_v10, e500v2),
8460 80d11f44 j_mayer
    /* MPC8555E v1.1                                                         */
8461 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E_v11",
8462 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555E_v11, POWERPC_SVR_8555E_v11, e500v2),
8463 80d11f44 j_mayer
    /* MPC8560                                                               */
8464 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560",
8465 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560,      POWERPC_SVR_8560,      e500v2),
8466 80d11f44 j_mayer
    /* MPC8560 v1.0                                                          */
8467 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v10",
8468 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560_v10,  POWERPC_SVR_8560_v10,  e500v2),
8469 80d11f44 j_mayer
    /* MPC8560 v2.0                                                          */
8470 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v20",
8471 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560_v20,  POWERPC_SVR_8560_v20,  e500v2),
8472 80d11f44 j_mayer
    /* MPC8560 v2.1                                                          */
8473 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v21",
8474 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560_v21,  POWERPC_SVR_8560_v21,  e500v2),
8475 80d11f44 j_mayer
    /* MPC8567                                                               */
8476 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8567",
8477 bd5ea513 aurel32
                    CPU_POWERPC_MPC8567,      POWERPC_SVR_8567,      e500v2),
8478 80d11f44 j_mayer
    /* MPC8567E                                                              */
8479 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8567E",
8480 bd5ea513 aurel32
                    CPU_POWERPC_MPC8567E,     POWERPC_SVR_8567E,     e500v2),
8481 80d11f44 j_mayer
    /* MPC8568                                                               */
8482 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8568",
8483 bd5ea513 aurel32
                    CPU_POWERPC_MPC8568,      POWERPC_SVR_8568,      e500v2),
8484 80d11f44 j_mayer
    /* MPC8568E                                                              */
8485 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8568E",
8486 bd5ea513 aurel32
                    CPU_POWERPC_MPC8568E,     POWERPC_SVR_8568E,     e500v2),
8487 80d11f44 j_mayer
    /* MPC8572                                                               */
8488 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8572",
8489 bd5ea513 aurel32
                    CPU_POWERPC_MPC8572,      POWERPC_SVR_8572,      e500v2),
8490 80d11f44 j_mayer
    /* MPC8572E                                                              */
8491 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8572E",
8492 bd5ea513 aurel32
                    CPU_POWERPC_MPC8572E,     POWERPC_SVR_8572E,     e500v2),
8493 80d11f44 j_mayer
    /* e600 family                                                           */
8494 80d11f44 j_mayer
    /* PowerPC e600 core                                                     */
8495 80d11f44 j_mayer
    POWERPC_DEF("e600",          CPU_POWERPC_e600,                   7400),
8496 80d11f44 j_mayer
    /* PowerPC e600 microcontrollers                                         */
8497 80d11f44 j_mayer
#if defined (TODO)
8498 80d11f44 j_mayer
    /* MPC8610                                                               */
8499 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8610",
8500 80d11f44 j_mayer
                    CPU_POWERPC_MPC8610,      POWERPC_SVR_8610,      7400),
8501 80d11f44 j_mayer
#endif
8502 80d11f44 j_mayer
    /* MPC8641                                                               */
8503 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8641",
8504 80d11f44 j_mayer
                    CPU_POWERPC_MPC8641,      POWERPC_SVR_8641,      7400),
8505 80d11f44 j_mayer
    /* MPC8641D                                                              */
8506 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8641D",
8507 80d11f44 j_mayer
                    CPU_POWERPC_MPC8641D,     POWERPC_SVR_8641D,     7400),
8508 a750fc0b j_mayer
    /* 32 bits "classic" PowerPC                                             */
8509 a750fc0b j_mayer
    /* PowerPC 6xx family                                                    */
8510 a750fc0b j_mayer
    /* PowerPC 601                                                           */
8511 bd928eba j_mayer
    POWERPC_DEF("601",           CPU_POWERPC_601,                    601v),
8512 c3e36823 j_mayer
    /* PowerPC 601v0                                                         */
8513 082c6681 j_mayer
    POWERPC_DEF("601_v0",        CPU_POWERPC_601_v0,                 601),
8514 c3e36823 j_mayer
    /* PowerPC 601v1                                                         */
8515 082c6681 j_mayer
    POWERPC_DEF("601_v1",        CPU_POWERPC_601_v1,                 601),
8516 082c6681 j_mayer
    /* PowerPC 601v                                                          */
8517 bd928eba j_mayer
    POWERPC_DEF("601v",          CPU_POWERPC_601v,                   601v),
8518 a750fc0b j_mayer
    /* PowerPC 601v2                                                         */
8519 082c6681 j_mayer
    POWERPC_DEF("601_v2",        CPU_POWERPC_601_v2,                 601v),
8520 a750fc0b j_mayer
    /* PowerPC 602                                                           */
8521 80d11f44 j_mayer
    POWERPC_DEF("602",           CPU_POWERPC_602,                    602),
8522 a750fc0b j_mayer
    /* PowerPC 603                                                           */
8523 80d11f44 j_mayer
    POWERPC_DEF("603",           CPU_POWERPC_603,                    603),
8524 a750fc0b j_mayer
    /* Code name for PowerPC 603                                             */
8525 80d11f44 j_mayer
    POWERPC_DEF("Vanilla",       CPU_POWERPC_603,                    603),
8526 082c6681 j_mayer
    /* PowerPC 603e (aka PID6)                                               */
8527 80d11f44 j_mayer
    POWERPC_DEF("603e",          CPU_POWERPC_603E,                   603E),
8528 a750fc0b j_mayer
    /* Code name for PowerPC 603e                                            */
8529 80d11f44 j_mayer
    POWERPC_DEF("Stretch",       CPU_POWERPC_603E,                   603E),
8530 a750fc0b j_mayer
    /* PowerPC 603e v1.1                                                     */
8531 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.1",     CPU_POWERPC_603E_v11,               603E),
8532 a750fc0b j_mayer
    /* PowerPC 603e v1.2                                                     */
8533 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.2",     CPU_POWERPC_603E_v12,               603E),
8534 a750fc0b j_mayer
    /* PowerPC 603e v1.3                                                     */
8535 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.3",     CPU_POWERPC_603E_v13,               603E),
8536 a750fc0b j_mayer
    /* PowerPC 603e v1.4                                                     */
8537 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.4",     CPU_POWERPC_603E_v14,               603E),
8538 a750fc0b j_mayer
    /* PowerPC 603e v2.2                                                     */
8539 80d11f44 j_mayer
    POWERPC_DEF("603e_v2.2",     CPU_POWERPC_603E_v22,               603E),
8540 a750fc0b j_mayer
    /* PowerPC 603e v3                                                       */
8541 80d11f44 j_mayer
    POWERPC_DEF("603e_v3",       CPU_POWERPC_603E_v3,                603E),
8542 a750fc0b j_mayer
    /* PowerPC 603e v4                                                       */
8543 80d11f44 j_mayer
    POWERPC_DEF("603e_v4",       CPU_POWERPC_603E_v4,                603E),
8544 a750fc0b j_mayer
    /* PowerPC 603e v4.1                                                     */
8545 80d11f44 j_mayer
    POWERPC_DEF("603e_v4.1",     CPU_POWERPC_603E_v41,               603E),
8546 082c6681 j_mayer
    /* PowerPC 603e (aka PID7)                                               */
8547 80d11f44 j_mayer
    POWERPC_DEF("603e7",         CPU_POWERPC_603E7,                  603E),
8548 a750fc0b j_mayer
    /* PowerPC 603e7t                                                        */
8549 80d11f44 j_mayer
    POWERPC_DEF("603e7t",        CPU_POWERPC_603E7t,                 603E),
8550 a750fc0b j_mayer
    /* PowerPC 603e7v                                                        */
8551 80d11f44 j_mayer
    POWERPC_DEF("603e7v",        CPU_POWERPC_603E7v,                 603E),
8552 a750fc0b j_mayer
    /* Code name for PowerPC 603ev                                           */
8553 80d11f44 j_mayer
    POWERPC_DEF("Vaillant",      CPU_POWERPC_603E7v,                 603E),
8554 a750fc0b j_mayer
    /* PowerPC 603e7v1                                                       */
8555 80d11f44 j_mayer
    POWERPC_DEF("603e7v1",       CPU_POWERPC_603E7v1,                603E),
8556 a750fc0b j_mayer
    /* PowerPC 603e7v2                                                       */
8557 80d11f44 j_mayer
    POWERPC_DEF("603e7v2",       CPU_POWERPC_603E7v2,                603E),
8558 082c6681 j_mayer
    /* PowerPC 603p (aka PID7v)                                              */
8559 082c6681 j_mayer
    POWERPC_DEF("603p",          CPU_POWERPC_603P,                   603E),
8560 082c6681 j_mayer
    /* PowerPC 603r (aka PID7t)                                              */
8561 80d11f44 j_mayer
    POWERPC_DEF("603r",          CPU_POWERPC_603R,                   603E),
8562 a750fc0b j_mayer
    /* Code name for PowerPC 603r                                            */
8563 80d11f44 j_mayer
    POWERPC_DEF("Goldeneye",     CPU_POWERPC_603R,                   603E),
8564 a750fc0b j_mayer
    /* PowerPC 604                                                           */
8565 80d11f44 j_mayer
    POWERPC_DEF("604",           CPU_POWERPC_604,                    604),
8566 082c6681 j_mayer
    /* PowerPC 604e (aka PID9)                                               */
8567 082c6681 j_mayer
    POWERPC_DEF("604e",          CPU_POWERPC_604E,                   604E),
8568 082c6681 j_mayer
    /* Code name for PowerPC 604e                                            */
8569 082c6681 j_mayer
    POWERPC_DEF("Sirocco",       CPU_POWERPC_604E,                   604E),
8570 a750fc0b j_mayer
    /* PowerPC 604e v1.0                                                     */
8571 082c6681 j_mayer
    POWERPC_DEF("604e_v1.0",     CPU_POWERPC_604E_v10,               604E),
8572 a750fc0b j_mayer
    /* PowerPC 604e v2.2                                                     */
8573 082c6681 j_mayer
    POWERPC_DEF("604e_v2.2",     CPU_POWERPC_604E_v22,               604E),
8574 a750fc0b j_mayer
    /* PowerPC 604e v2.4                                                     */
8575 082c6681 j_mayer
    POWERPC_DEF("604e_v2.4",     CPU_POWERPC_604E_v24,               604E),
8576 082c6681 j_mayer
    /* PowerPC 604r (aka PIDA)                                               */
8577 082c6681 j_mayer
    POWERPC_DEF("604r",          CPU_POWERPC_604R,                   604E),
8578 082c6681 j_mayer
    /* Code name for PowerPC 604r                                            */
8579 082c6681 j_mayer
    POWERPC_DEF("Mach5",         CPU_POWERPC_604R,                   604E),
8580 a750fc0b j_mayer
#if defined(TODO)
8581 a750fc0b j_mayer
    /* PowerPC 604ev                                                         */
8582 082c6681 j_mayer
    POWERPC_DEF("604ev",         CPU_POWERPC_604EV,                  604E),
8583 a750fc0b j_mayer
#endif
8584 a750fc0b j_mayer
    /* PowerPC 7xx family                                                    */
8585 a750fc0b j_mayer
    /* Generic PowerPC 740 (G3)                                              */
8586 bd928eba j_mayer
    POWERPC_DEF("740",           CPU_POWERPC_7x0,                    740),
8587 082c6681 j_mayer
    /* Code name for PowerPC 740                                             */
8588 bd928eba j_mayer
    POWERPC_DEF("Arthur",        CPU_POWERPC_7x0,                    740),
8589 a750fc0b j_mayer
    /* Generic PowerPC 750 (G3)                                              */
8590 bd928eba j_mayer
    POWERPC_DEF("750",           CPU_POWERPC_7x0,                    750),
8591 082c6681 j_mayer
    /* Code name for PowerPC 750                                             */
8592 bd928eba j_mayer
    POWERPC_DEF("Typhoon",       CPU_POWERPC_7x0,                    750),
8593 a750fc0b j_mayer
    /* PowerPC 740/750 is also known as G3                                   */
8594 bd928eba j_mayer
    POWERPC_DEF("G3",            CPU_POWERPC_7x0,                    750),
8595 bd928eba j_mayer
    /* PowerPC 740 v1.0 (G3)                                                 */
8596 bd928eba j_mayer
    POWERPC_DEF("740_v1.0",      CPU_POWERPC_7x0_v10,                740),
8597 bd928eba j_mayer
    /* PowerPC 750 v1.0 (G3)                                                 */
8598 bd928eba j_mayer
    POWERPC_DEF("750_v1.0",      CPU_POWERPC_7x0_v10,                750),
8599 a750fc0b j_mayer
    /* PowerPC 740 v2.0 (G3)                                                 */
8600 bd928eba j_mayer
    POWERPC_DEF("740_v2.0",      CPU_POWERPC_7x0_v20,                740),
8601 a750fc0b j_mayer
    /* PowerPC 750 v2.0 (G3)                                                 */
8602 bd928eba j_mayer
    POWERPC_DEF("750_v2.0",      CPU_POWERPC_7x0_v20,                750),
8603 a750fc0b j_mayer
    /* PowerPC 740 v2.1 (G3)                                                 */
8604 bd928eba j_mayer
    POWERPC_DEF("740_v2.1",      CPU_POWERPC_7x0_v21,                740),
8605 a750fc0b j_mayer
    /* PowerPC 750 v2.1 (G3)                                                 */
8606 bd928eba j_mayer
    POWERPC_DEF("750_v2.1",      CPU_POWERPC_7x0_v21,                750),
8607 a750fc0b j_mayer
    /* PowerPC 740 v2.2 (G3)                                                 */
8608 bd928eba j_mayer
    POWERPC_DEF("740_v2.2",      CPU_POWERPC_7x0_v22,                740),
8609 a750fc0b j_mayer
    /* PowerPC 750 v2.2 (G3)                                                 */
8610 bd928eba j_mayer
    POWERPC_DEF("750_v2.2",      CPU_POWERPC_7x0_v22,                750),
8611 a750fc0b j_mayer
    /* PowerPC 740 v3.0 (G3)                                                 */
8612 bd928eba j_mayer
    POWERPC_DEF("740_v3.0",      CPU_POWERPC_7x0_v30,                740),
8613 a750fc0b j_mayer
    /* PowerPC 750 v3.0 (G3)                                                 */
8614 bd928eba j_mayer
    POWERPC_DEF("750_v3.0",      CPU_POWERPC_7x0_v30,                750),
8615 a750fc0b j_mayer
    /* PowerPC 740 v3.1 (G3)                                                 */
8616 bd928eba j_mayer
    POWERPC_DEF("740_v3.1",      CPU_POWERPC_7x0_v31,                740),
8617 a750fc0b j_mayer
    /* PowerPC 750 v3.1 (G3)                                                 */
8618 bd928eba j_mayer
    POWERPC_DEF("750_v3.1",      CPU_POWERPC_7x0_v31,                750),
8619 a750fc0b j_mayer
    /* PowerPC 740E (G3)                                                     */
8620 bd928eba j_mayer
    POWERPC_DEF("740e",          CPU_POWERPC_740E,                   740),
8621 bd928eba j_mayer
    /* PowerPC 750E (G3)                                                     */
8622 bd928eba j_mayer
    POWERPC_DEF("750e",          CPU_POWERPC_750E,                   750),
8623 a750fc0b j_mayer
    /* PowerPC 740P (G3)                                                     */
8624 bd928eba j_mayer
    POWERPC_DEF("740p",          CPU_POWERPC_7x0P,                   740),
8625 a750fc0b j_mayer
    /* PowerPC 750P (G3)                                                     */
8626 bd928eba j_mayer
    POWERPC_DEF("750p",          CPU_POWERPC_7x0P,                   750),
8627 a750fc0b j_mayer
    /* Code name for PowerPC 740P/750P (G3)                                  */
8628 bd928eba j_mayer
    POWERPC_DEF("Conan/Doyle",   CPU_POWERPC_7x0P,                   750),
8629 a750fc0b j_mayer
    /* PowerPC 750CL (G3 embedded)                                           */
8630 bd928eba j_mayer
    POWERPC_DEF("750cl",         CPU_POWERPC_750CL,                  750cl),
8631 bd928eba j_mayer
    /* PowerPC 750CL v1.0                                                    */
8632 bd928eba j_mayer
    POWERPC_DEF("750cl_v1.0",    CPU_POWERPC_750CL_v10,              750cl),
8633 bd928eba j_mayer
    /* PowerPC 750CL v2.0                                                    */
8634 bd928eba j_mayer
    POWERPC_DEF("750cl_v2.0",    CPU_POWERPC_750CL_v20,              750cl),
8635 a750fc0b j_mayer
    /* PowerPC 750CX (G3 embedded)                                           */
8636 bd928eba j_mayer
    POWERPC_DEF("750cx",         CPU_POWERPC_750CX,                  750cx),
8637 bd928eba j_mayer
    /* PowerPC 750CX v1.0 (G3 embedded)                                      */
8638 bd928eba j_mayer
    POWERPC_DEF("750cx_v1.0",    CPU_POWERPC_750CX_v10,              750cx),
8639 bd928eba j_mayer
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
8640 bd928eba j_mayer
    POWERPC_DEF("750cx_v2.0",    CPU_POWERPC_750CX_v20,              750cx),
8641 a750fc0b j_mayer
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
8642 bd928eba j_mayer
    POWERPC_DEF("750cx_v2.1",    CPU_POWERPC_750CX_v21,              750cx),
8643 a750fc0b j_mayer
    /* PowerPC 750CX v2.2 (G3 embedded)                                      */
8644 bd928eba j_mayer
    POWERPC_DEF("750cx_v2.2",    CPU_POWERPC_750CX_v22,              750cx),
8645 a750fc0b j_mayer
    /* PowerPC 750CXe (G3 embedded)                                          */
8646 bd928eba j_mayer
    POWERPC_DEF("750cxe",        CPU_POWERPC_750CXE,                 750cx),
8647 a750fc0b j_mayer
    /* PowerPC 750CXe v2.1 (G3 embedded)                                     */
8648 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.1",   CPU_POWERPC_750CXE_v21,             750cx),
8649 a750fc0b j_mayer
    /* PowerPC 750CXe v2.2 (G3 embedded)                                     */
8650 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.2",   CPU_POWERPC_750CXE_v22,             750cx),
8651 a750fc0b j_mayer
    /* PowerPC 750CXe v2.3 (G3 embedded)                                     */
8652 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.3",   CPU_POWERPC_750CXE_v23,             750cx),
8653 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4 (G3 embedded)                                     */
8654 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.4",   CPU_POWERPC_750CXE_v24,             750cx),
8655 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4b (G3 embedded)                                    */
8656 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.4b",  CPU_POWERPC_750CXE_v24b,            750cx),
8657 bd928eba j_mayer
    /* PowerPC 750CXe v3.0 (G3 embedded)                                     */
8658 bd928eba j_mayer
    POWERPC_DEF("750cxe_v3.0",   CPU_POWERPC_750CXE_v30,             750cx),
8659 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1 (G3 embedded)                                     */
8660 bd928eba j_mayer
    POWERPC_DEF("750cxe_v3.1",   CPU_POWERPC_750CXE_v31,             750cx),
8661 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1b (G3 embedded)                                    */
8662 bd928eba j_mayer
    POWERPC_DEF("750cxe_v3.1b",  CPU_POWERPC_750CXE_v31b,            750cx),
8663 a750fc0b j_mayer
    /* PowerPC 750CXr (G3 embedded)                                          */
8664 bd928eba j_mayer
    POWERPC_DEF("750cxr",        CPU_POWERPC_750CXR,                 750cx),
8665 a750fc0b j_mayer
    /* PowerPC 750FL (G3 embedded)                                           */
8666 80d11f44 j_mayer
    POWERPC_DEF("750fl",         CPU_POWERPC_750FL,                  750fx),
8667 a750fc0b j_mayer
    /* PowerPC 750FX (G3 embedded)                                           */
8668 80d11f44 j_mayer
    POWERPC_DEF("750fx",         CPU_POWERPC_750FX,                  750fx),
8669 a750fc0b j_mayer
    /* PowerPC 750FX v1.0 (G3 embedded)                                      */
8670 80d11f44 j_mayer
    POWERPC_DEF("750fx_v1.0",    CPU_POWERPC_750FX_v10,              750fx),
8671 a750fc0b j_mayer
    /* PowerPC 750FX v2.0 (G3 embedded)                                      */
8672 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.0",    CPU_POWERPC_750FX_v20,              750fx),
8673 a750fc0b j_mayer
    /* PowerPC 750FX v2.1 (G3 embedded)                                      */
8674 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.1",    CPU_POWERPC_750FX_v21,              750fx),
8675 a750fc0b j_mayer
    /* PowerPC 750FX v2.2 (G3 embedded)                                      */
8676 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.2",    CPU_POWERPC_750FX_v22,              750fx),
8677 a750fc0b j_mayer
    /* PowerPC 750FX v2.3 (G3 embedded)                                      */
8678 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.3",    CPU_POWERPC_750FX_v23,              750fx),
8679 a750fc0b j_mayer
    /* PowerPC 750GL (G3 embedded)                                           */
8680 bd928eba j_mayer
    POWERPC_DEF("750gl",         CPU_POWERPC_750GL,                  750gx),
8681 a750fc0b j_mayer
    /* PowerPC 750GX (G3 embedded)                                           */
8682 bd928eba j_mayer
    POWERPC_DEF("750gx",         CPU_POWERPC_750GX,                  750gx),
8683 a750fc0b j_mayer
    /* PowerPC 750GX v1.0 (G3 embedded)                                      */
8684 bd928eba j_mayer
    POWERPC_DEF("750gx_v1.0",    CPU_POWERPC_750GX_v10,              750gx),
8685 a750fc0b j_mayer
    /* PowerPC 750GX v1.1 (G3 embedded)                                      */
8686 bd928eba j_mayer
    POWERPC_DEF("750gx_v1.1",    CPU_POWERPC_750GX_v11,              750gx),
8687 a750fc0b j_mayer
    /* PowerPC 750GX v1.2 (G3 embedded)                                      */
8688 bd928eba j_mayer
    POWERPC_DEF("750gx_v1.2",    CPU_POWERPC_750GX_v12,              750gx),
8689 a750fc0b j_mayer
    /* PowerPC 750L (G3 embedded)                                            */
8690 bd928eba j_mayer
    POWERPC_DEF("750l",          CPU_POWERPC_750L,                   750),
8691 a750fc0b j_mayer
    /* Code name for PowerPC 750L (G3 embedded)                              */
8692 bd928eba j_mayer
    POWERPC_DEF("LoneStar",      CPU_POWERPC_750L,                   750),
8693 bd928eba j_mayer
    /* PowerPC 750L v2.0 (G3 embedded)                                       */
8694 bd928eba j_mayer
    POWERPC_DEF("750l_v2.0",     CPU_POWERPC_750L_v20,               750),
8695 bd928eba j_mayer
    /* PowerPC 750L v2.1 (G3 embedded)                                       */
8696 bd928eba j_mayer
    POWERPC_DEF("750l_v2.1",     CPU_POWERPC_750L_v21,               750),
8697 a750fc0b j_mayer
    /* PowerPC 750L v2.2 (G3 embedded)                                       */
8698 bd928eba j_mayer
    POWERPC_DEF("750l_v2.2",     CPU_POWERPC_750L_v22,               750),
8699 a750fc0b j_mayer
    /* PowerPC 750L v3.0 (G3 embedded)                                       */
8700 bd928eba j_mayer
    POWERPC_DEF("750l_v3.0",     CPU_POWERPC_750L_v30,               750),
8701 a750fc0b j_mayer
    /* PowerPC 750L v3.2 (G3 embedded)                                       */
8702 bd928eba j_mayer
    POWERPC_DEF("750l_v3.2",     CPU_POWERPC_750L_v32,               750),
8703 a750fc0b j_mayer
    /* Generic PowerPC 745                                                   */
8704 bd928eba j_mayer
    POWERPC_DEF("745",           CPU_POWERPC_7x5,                    745),
8705 a750fc0b j_mayer
    /* Generic PowerPC 755                                                   */
8706 bd928eba j_mayer
    POWERPC_DEF("755",           CPU_POWERPC_7x5,                    755),
8707 a750fc0b j_mayer
    /* Code name for PowerPC 745/755                                         */
8708 bd928eba j_mayer
    POWERPC_DEF("Goldfinger",    CPU_POWERPC_7x5,                    755),
8709 a750fc0b j_mayer
    /* PowerPC 745 v1.0                                                      */
8710 bd928eba j_mayer
    POWERPC_DEF("745_v1.0",      CPU_POWERPC_7x5_v10,                745),
8711 a750fc0b j_mayer
    /* PowerPC 755 v1.0                                                      */
8712 bd928eba j_mayer
    POWERPC_DEF("755_v1.0",      CPU_POWERPC_7x5_v10,                755),
8713 a750fc0b j_mayer
    /* PowerPC 745 v1.1                                                      */
8714 bd928eba j_mayer
    POWERPC_DEF("745_v1.1",      CPU_POWERPC_7x5_v11,                745),
8715 a750fc0b j_mayer
    /* PowerPC 755 v1.1                                                      */
8716 bd928eba j_mayer
    POWERPC_DEF("755_v1.1",      CPU_POWERPC_7x5_v11,                755),
8717 a750fc0b j_mayer
    /* PowerPC 745 v2.0                                                      */
8718 bd928eba j_mayer
    POWERPC_DEF("745_v2.0",      CPU_POWERPC_7x5_v20,                745),
8719 a750fc0b j_mayer
    /* PowerPC 755 v2.0                                                      */
8720 bd928eba j_mayer
    POWERPC_DEF("755_v2.0",      CPU_POWERPC_7x5_v20,                755),
8721 a750fc0b j_mayer
    /* PowerPC 745 v2.1                                                      */
8722 bd928eba j_mayer
    POWERPC_DEF("745_v2.1",      CPU_POWERPC_7x5_v21,                745),
8723 a750fc0b j_mayer
    /* PowerPC 755 v2.1                                                      */
8724 bd928eba j_mayer
    POWERPC_DEF("755_v2.1",      CPU_POWERPC_7x5_v21,                755),
8725 a750fc0b j_mayer
    /* PowerPC 745 v2.2                                                      */
8726 bd928eba j_mayer
    POWERPC_DEF("745_v2.2",      CPU_POWERPC_7x5_v22,                745),
8727 a750fc0b j_mayer
    /* PowerPC 755 v2.2                                                      */
8728 bd928eba j_mayer
    POWERPC_DEF("755_v2.2",      CPU_POWERPC_7x5_v22,                755),
8729 a750fc0b j_mayer
    /* PowerPC 745 v2.3                                                      */
8730 bd928eba j_mayer
    POWERPC_DEF("745_v2.3",      CPU_POWERPC_7x5_v23,                745),
8731 a750fc0b j_mayer
    /* PowerPC 755 v2.3                                                      */
8732 bd928eba j_mayer
    POWERPC_DEF("755_v2.3",      CPU_POWERPC_7x5_v23,                755),
8733 a750fc0b j_mayer
    /* PowerPC 745 v2.4                                                      */
8734 bd928eba j_mayer
    POWERPC_DEF("745_v2.4",      CPU_POWERPC_7x5_v24,                745),
8735 a750fc0b j_mayer
    /* PowerPC 755 v2.4                                                      */
8736 bd928eba j_mayer
    POWERPC_DEF("755_v2.4",      CPU_POWERPC_7x5_v24,                755),
8737 a750fc0b j_mayer
    /* PowerPC 745 v2.5                                                      */
8738 bd928eba j_mayer
    POWERPC_DEF("745_v2.5",      CPU_POWERPC_7x5_v25,                745),
8739 a750fc0b j_mayer
    /* PowerPC 755 v2.5                                                      */
8740 bd928eba j_mayer
    POWERPC_DEF("755_v2.5",      CPU_POWERPC_7x5_v25,                755),
8741 a750fc0b j_mayer
    /* PowerPC 745 v2.6                                                      */
8742 bd928eba j_mayer
    POWERPC_DEF("745_v2.6",      CPU_POWERPC_7x5_v26,                745),
8743 a750fc0b j_mayer
    /* PowerPC 755 v2.6                                                      */
8744 bd928eba j_mayer
    POWERPC_DEF("755_v2.6",      CPU_POWERPC_7x5_v26,                755),
8745 a750fc0b j_mayer
    /* PowerPC 745 v2.7                                                      */
8746 bd928eba j_mayer
    POWERPC_DEF("745_v2.7",      CPU_POWERPC_7x5_v27,                745),
8747 a750fc0b j_mayer
    /* PowerPC 755 v2.7                                                      */
8748 bd928eba j_mayer
    POWERPC_DEF("755_v2.7",      CPU_POWERPC_7x5_v27,                755),
8749 a750fc0b j_mayer
    /* PowerPC 745 v2.8                                                      */
8750 bd928eba j_mayer
    POWERPC_DEF("745_v2.8",      CPU_POWERPC_7x5_v28,                745),
8751 a750fc0b j_mayer
    /* PowerPC 755 v2.8                                                      */
8752 bd928eba j_mayer
    POWERPC_DEF("755_v2.8",      CPU_POWERPC_7x5_v28,                755),
8753 a750fc0b j_mayer
#if defined (TODO)
8754 a750fc0b j_mayer
    /* PowerPC 745P (G3)                                                     */
8755 bd928eba j_mayer
    POWERPC_DEF("745p",          CPU_POWERPC_7x5P,                   745),
8756 a750fc0b j_mayer
    /* PowerPC 755P (G3)                                                     */
8757 bd928eba j_mayer
    POWERPC_DEF("755p",          CPU_POWERPC_7x5P,                   755),
8758 a750fc0b j_mayer
#endif
8759 a750fc0b j_mayer
    /* PowerPC 74xx family                                                   */
8760 a750fc0b j_mayer
    /* PowerPC 7400 (G4)                                                     */
8761 80d11f44 j_mayer
    POWERPC_DEF("7400",          CPU_POWERPC_7400,                   7400),
8762 a750fc0b j_mayer
    /* Code name for PowerPC 7400                                            */
8763 80d11f44 j_mayer
    POWERPC_DEF("Max",           CPU_POWERPC_7400,                   7400),
8764 a750fc0b j_mayer
    /* PowerPC 74xx is also well known as G4                                 */
8765 80d11f44 j_mayer
    POWERPC_DEF("G4",            CPU_POWERPC_7400,                   7400),
8766 a750fc0b j_mayer
    /* PowerPC 7400 v1.0 (G4)                                                */
8767 80d11f44 j_mayer
    POWERPC_DEF("7400_v1.0",     CPU_POWERPC_7400_v10,               7400),
8768 a750fc0b j_mayer
    /* PowerPC 7400 v1.1 (G4)                                                */
8769 80d11f44 j_mayer
    POWERPC_DEF("7400_v1.1",     CPU_POWERPC_7400_v11,               7400),
8770 a750fc0b j_mayer
    /* PowerPC 7400 v2.0 (G4)                                                */
8771 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.0",     CPU_POWERPC_7400_v20,               7400),
8772 4e777442 j_mayer
    /* PowerPC 7400 v2.1 (G4)                                                */
8773 4e777442 j_mayer
    POWERPC_DEF("7400_v2.1",     CPU_POWERPC_7400_v21,               7400),
8774 a750fc0b j_mayer
    /* PowerPC 7400 v2.2 (G4)                                                */
8775 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.2",     CPU_POWERPC_7400_v22,               7400),
8776 a750fc0b j_mayer
    /* PowerPC 7400 v2.6 (G4)                                                */
8777 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.6",     CPU_POWERPC_7400_v26,               7400),
8778 a750fc0b j_mayer
    /* PowerPC 7400 v2.7 (G4)                                                */
8779 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.7",     CPU_POWERPC_7400_v27,               7400),
8780 a750fc0b j_mayer
    /* PowerPC 7400 v2.8 (G4)                                                */
8781 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.8",     CPU_POWERPC_7400_v28,               7400),
8782 a750fc0b j_mayer
    /* PowerPC 7400 v2.9 (G4)                                                */
8783 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.9",     CPU_POWERPC_7400_v29,               7400),
8784 a750fc0b j_mayer
    /* PowerPC 7410 (G4)                                                     */
8785 80d11f44 j_mayer
    POWERPC_DEF("7410",          CPU_POWERPC_7410,                   7410),
8786 a750fc0b j_mayer
    /* Code name for PowerPC 7410                                            */
8787 80d11f44 j_mayer
    POWERPC_DEF("Nitro",         CPU_POWERPC_7410,                   7410),
8788 a750fc0b j_mayer
    /* PowerPC 7410 v1.0 (G4)                                                */
8789 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.0",     CPU_POWERPC_7410_v10,               7410),
8790 a750fc0b j_mayer
    /* PowerPC 7410 v1.1 (G4)                                                */
8791 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.1",     CPU_POWERPC_7410_v11,               7410),
8792 a750fc0b j_mayer
    /* PowerPC 7410 v1.2 (G4)                                                */
8793 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.2",     CPU_POWERPC_7410_v12,               7410),
8794 a750fc0b j_mayer
    /* PowerPC 7410 v1.3 (G4)                                                */
8795 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.3",     CPU_POWERPC_7410_v13,               7410),
8796 a750fc0b j_mayer
    /* PowerPC 7410 v1.4 (G4)                                                */
8797 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.4",     CPU_POWERPC_7410_v14,               7410),
8798 a750fc0b j_mayer
    /* PowerPC 7448 (G4)                                                     */
8799 80d11f44 j_mayer
    POWERPC_DEF("7448",          CPU_POWERPC_7448,                   7400),
8800 a750fc0b j_mayer
    /* PowerPC 7448 v1.0 (G4)                                                */
8801 80d11f44 j_mayer
    POWERPC_DEF("7448_v1.0",     CPU_POWERPC_7448_v10,               7400),
8802 a750fc0b j_mayer
    /* PowerPC 7448 v1.1 (G4)                                                */
8803 80d11f44 j_mayer
    POWERPC_DEF("7448_v1.1",     CPU_POWERPC_7448_v11,               7400),
8804 a750fc0b j_mayer
    /* PowerPC 7448 v2.0 (G4)                                                */
8805 80d11f44 j_mayer
    POWERPC_DEF("7448_v2.0",     CPU_POWERPC_7448_v20,               7400),
8806 a750fc0b j_mayer
    /* PowerPC 7448 v2.1 (G4)                                                */
8807 80d11f44 j_mayer
    POWERPC_DEF("7448_v2.1",     CPU_POWERPC_7448_v21,               7400),
8808 a750fc0b j_mayer
    /* PowerPC 7450 (G4)                                                     */
8809 80d11f44 j_mayer
    POWERPC_DEF("7450",          CPU_POWERPC_7450,                   7450),
8810 a750fc0b j_mayer
    /* Code name for PowerPC 7450                                            */
8811 80d11f44 j_mayer
    POWERPC_DEF("Vger",          CPU_POWERPC_7450,                   7450),
8812 a750fc0b j_mayer
    /* PowerPC 7450 v1.0 (G4)                                                */
8813 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.0",     CPU_POWERPC_7450_v10,               7450),
8814 a750fc0b j_mayer
    /* PowerPC 7450 v1.1 (G4)                                                */
8815 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.1",     CPU_POWERPC_7450_v11,               7450),
8816 a750fc0b j_mayer
    /* PowerPC 7450 v1.2 (G4)                                                */
8817 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.2",     CPU_POWERPC_7450_v12,               7450),
8818 a750fc0b j_mayer
    /* PowerPC 7450 v2.0 (G4)                                                */
8819 80d11f44 j_mayer
    POWERPC_DEF("7450_v2.0",     CPU_POWERPC_7450_v20,               7450),
8820 a750fc0b j_mayer
    /* PowerPC 7450 v2.1 (G4)                                                */
8821 80d11f44 j_mayer
    POWERPC_DEF("7450_v2.1",     CPU_POWERPC_7450_v21,               7450),
8822 a750fc0b j_mayer
    /* PowerPC 7441 (G4)                                                     */
8823 80d11f44 j_mayer
    POWERPC_DEF("7441",          CPU_POWERPC_74x1,                   7440),
8824 a750fc0b j_mayer
    /* PowerPC 7451 (G4)                                                     */
8825 80d11f44 j_mayer
    POWERPC_DEF("7451",          CPU_POWERPC_74x1,                   7450),
8826 4e777442 j_mayer
    /* PowerPC 7441 v2.1 (G4)                                                */
8827 4e777442 j_mayer
    POWERPC_DEF("7441_v2.1",     CPU_POWERPC_7450_v21,               7440),
8828 4e777442 j_mayer
    /* PowerPC 7441 v2.3 (G4)                                                */
8829 4e777442 j_mayer
    POWERPC_DEF("7441_v2.3",     CPU_POWERPC_74x1_v23,               7440),
8830 4e777442 j_mayer
    /* PowerPC 7451 v2.3 (G4)                                                */
8831 4e777442 j_mayer
    POWERPC_DEF("7451_v2.3",     CPU_POWERPC_74x1_v23,               7450),
8832 4e777442 j_mayer
    /* PowerPC 7441 v2.10 (G4)                                                */
8833 4e777442 j_mayer
    POWERPC_DEF("7441_v2.10",    CPU_POWERPC_74x1_v210,              7440),
8834 4e777442 j_mayer
    /* PowerPC 7451 v2.10 (G4)                                               */
8835 4e777442 j_mayer
    POWERPC_DEF("7451_v2.10",    CPU_POWERPC_74x1_v210,              7450),
8836 a750fc0b j_mayer
    /* PowerPC 7445 (G4)                                                     */
8837 80d11f44 j_mayer
    POWERPC_DEF("7445",          CPU_POWERPC_74x5,                   7445),
8838 a750fc0b j_mayer
    /* PowerPC 7455 (G4)                                                     */
8839 80d11f44 j_mayer
    POWERPC_DEF("7455",          CPU_POWERPC_74x5,                   7455),
8840 a750fc0b j_mayer
    /* Code name for PowerPC 7445/7455                                       */
8841 80d11f44 j_mayer
    POWERPC_DEF("Apollo6",       CPU_POWERPC_74x5,                   7455),
8842 a750fc0b j_mayer
    /* PowerPC 7445 v1.0 (G4)                                                */
8843 80d11f44 j_mayer
    POWERPC_DEF("7445_v1.0",     CPU_POWERPC_74x5_v10,               7445),
8844 a750fc0b j_mayer
    /* PowerPC 7455 v1.0 (G4)                                                */
8845 80d11f44 j_mayer
    POWERPC_DEF("7455_v1.0",     CPU_POWERPC_74x5_v10,               7455),
8846 a750fc0b j_mayer
    /* PowerPC 7445 v2.1 (G4)                                                */
8847 80d11f44 j_mayer
    POWERPC_DEF("7445_v2.1",     CPU_POWERPC_74x5_v21,               7445),
8848 a750fc0b j_mayer
    /* PowerPC 7455 v2.1 (G4)                                                */
8849 80d11f44 j_mayer
    POWERPC_DEF("7455_v2.1",     CPU_POWERPC_74x5_v21,               7455),
8850 a750fc0b j_mayer
    /* PowerPC 7445 v3.2 (G4)                                                */
8851 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.2",     CPU_POWERPC_74x5_v32,               7445),
8852 a750fc0b j_mayer
    /* PowerPC 7455 v3.2 (G4)                                                */
8853 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.2",     CPU_POWERPC_74x5_v32,               7455),
8854 a750fc0b j_mayer
    /* PowerPC 7445 v3.3 (G4)                                                */
8855 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.3",     CPU_POWERPC_74x5_v33,               7445),
8856 a750fc0b j_mayer
    /* PowerPC 7455 v3.3 (G4)                                                */
8857 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.3",     CPU_POWERPC_74x5_v33,               7455),
8858 a750fc0b j_mayer
    /* PowerPC 7445 v3.4 (G4)                                                */
8859 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.4",     CPU_POWERPC_74x5_v34,               7445),
8860 a750fc0b j_mayer
    /* PowerPC 7455 v3.4 (G4)                                                */
8861 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.4",     CPU_POWERPC_74x5_v34,               7455),
8862 a750fc0b j_mayer
    /* PowerPC 7447 (G4)                                                     */
8863 80d11f44 j_mayer
    POWERPC_DEF("7447",          CPU_POWERPC_74x7,                   7445),
8864 a750fc0b j_mayer
    /* PowerPC 7457 (G4)                                                     */
8865 80d11f44 j_mayer
    POWERPC_DEF("7457",          CPU_POWERPC_74x7,                   7455),
8866 a750fc0b j_mayer
    /* Code name for PowerPC 7447/7457                                       */
8867 80d11f44 j_mayer
    POWERPC_DEF("Apollo7",       CPU_POWERPC_74x7,                   7455),
8868 a750fc0b j_mayer
    /* PowerPC 7447 v1.0 (G4)                                                */
8869 80d11f44 j_mayer
    POWERPC_DEF("7447_v1.0",     CPU_POWERPC_74x7_v10,               7445),
8870 a750fc0b j_mayer
    /* PowerPC 7457 v1.0 (G4)                                                */
8871 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.0",     CPU_POWERPC_74x7_v10,               7455),
8872 a750fc0b j_mayer
    /* PowerPC 7447 v1.1 (G4)                                                */
8873 80d11f44 j_mayer
    POWERPC_DEF("7447_v1.1",     CPU_POWERPC_74x7_v11,               7445),
8874 a750fc0b j_mayer
    /* PowerPC 7457 v1.1 (G4)                                                */
8875 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.1",     CPU_POWERPC_74x7_v11,               7455),
8876 a750fc0b j_mayer
    /* PowerPC 7457 v1.2 (G4)                                                */
8877 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.2",     CPU_POWERPC_74x7_v12,               7455),
8878 082c6681 j_mayer
    /* PowerPC 7447A (G4)                                                    */
8879 082c6681 j_mayer
    POWERPC_DEF("7447A",         CPU_POWERPC_74x7A,                  7445),
8880 082c6681 j_mayer
    /* PowerPC 7457A (G4)                                                    */
8881 082c6681 j_mayer
    POWERPC_DEF("7457A",         CPU_POWERPC_74x7A,                  7455),
8882 082c6681 j_mayer
    /* PowerPC 7447A v1.0 (G4)                                               */
8883 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.0",    CPU_POWERPC_74x7A_v10,              7445),
8884 082c6681 j_mayer
    /* PowerPC 7457A v1.0 (G4)                                               */
8885 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.0",    CPU_POWERPC_74x7A_v10,              7455),
8886 082c6681 j_mayer
    /* Code name for PowerPC 7447A/7457A                                     */
8887 082c6681 j_mayer
    POWERPC_DEF("Apollo7PM",     CPU_POWERPC_74x7A_v10,              7455),
8888 082c6681 j_mayer
    /* PowerPC 7447A v1.1 (G4)                                               */
8889 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.1",    CPU_POWERPC_74x7A_v11,              7445),
8890 082c6681 j_mayer
    /* PowerPC 7457A v1.1 (G4)                                               */
8891 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.1",    CPU_POWERPC_74x7A_v11,              7455),
8892 082c6681 j_mayer
    /* PowerPC 7447A v1.2 (G4)                                               */
8893 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.2",    CPU_POWERPC_74x7A_v12,              7445),
8894 082c6681 j_mayer
    /* PowerPC 7457A v1.2 (G4)                                               */
8895 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.2",    CPU_POWERPC_74x7A_v12,              7455),
8896 a750fc0b j_mayer
    /* 64 bits PowerPC                                                       */
8897 a750fc0b j_mayer
#if defined (TARGET_PPC64)
8898 a750fc0b j_mayer
    /* PowerPC 620                                                           */
8899 80d11f44 j_mayer
    POWERPC_DEF("620",           CPU_POWERPC_620,                    620),
8900 082c6681 j_mayer
    /* Code name for PowerPC 620                                             */
8901 082c6681 j_mayer
    POWERPC_DEF("Trident",       CPU_POWERPC_620,                    620),
8902 3fc6c082 bellard
#if defined (TODO)
8903 a750fc0b j_mayer
    /* PowerPC 630 (POWER3)                                                  */
8904 80d11f44 j_mayer
    POWERPC_DEF("630",           CPU_POWERPC_630,                    630),
8905 80d11f44 j_mayer
    POWERPC_DEF("POWER3",        CPU_POWERPC_630,                    630),
8906 082c6681 j_mayer
    /* Code names for POWER3                                                 */
8907 082c6681 j_mayer
    POWERPC_DEF("Boxer",         CPU_POWERPC_630,                    630),
8908 082c6681 j_mayer
    POWERPC_DEF("Dino",          CPU_POWERPC_630,                    630),
8909 a750fc0b j_mayer
#endif
8910 3a607854 j_mayer
#if defined (TODO)
8911 a750fc0b j_mayer
    /* PowerPC 631 (Power 3+)                                                */
8912 80d11f44 j_mayer
    POWERPC_DEF("631",           CPU_POWERPC_631,                    631),
8913 80d11f44 j_mayer
    POWERPC_DEF("POWER3+",       CPU_POWERPC_631,                    631),
8914 3a607854 j_mayer
#endif
8915 3a607854 j_mayer
#if defined (TODO)
8916 a750fc0b j_mayer
    /* POWER4                                                                */
8917 80d11f44 j_mayer
    POWERPC_DEF("POWER4",        CPU_POWERPC_POWER4,                 POWER4),
8918 a750fc0b j_mayer
#endif
8919 3a607854 j_mayer
#if defined (TODO)
8920 a750fc0b j_mayer
    /* POWER4p                                                               */
8921 80d11f44 j_mayer
    POWERPC_DEF("POWER4+",       CPU_POWERPC_POWER4P,                POWER4P),
8922 a750fc0b j_mayer
#endif
8923 3a607854 j_mayer
#if defined (TODO)
8924 a750fc0b j_mayer
    /* POWER5                                                                */
8925 80d11f44 j_mayer
    POWERPC_DEF("POWER5",        CPU_POWERPC_POWER5,                 POWER5),
8926 a750fc0b j_mayer
    /* POWER5GR                                                              */
8927 80d11f44 j_mayer
    POWERPC_DEF("POWER5gr",      CPU_POWERPC_POWER5GR,               POWER5),
8928 2662a059 j_mayer
#endif
8929 2662a059 j_mayer
#if defined (TODO)
8930 a750fc0b j_mayer
    /* POWER5+                                                               */
8931 80d11f44 j_mayer
    POWERPC_DEF("POWER5+",       CPU_POWERPC_POWER5P,                POWER5P),
8932 a750fc0b j_mayer
    /* POWER5GS                                                              */
8933 80d11f44 j_mayer
    POWERPC_DEF("POWER5gs",      CPU_POWERPC_POWER5GS,               POWER5P),
8934 a750fc0b j_mayer
#endif
8935 2662a059 j_mayer
#if defined (TODO)
8936 a750fc0b j_mayer
    /* POWER6                                                                */
8937 80d11f44 j_mayer
    POWERPC_DEF("POWER6",        CPU_POWERPC_POWER6,                 POWER6),
8938 a750fc0b j_mayer
    /* POWER6 running in POWER5 mode                                         */
8939 80d11f44 j_mayer
    POWERPC_DEF("POWER6_5",      CPU_POWERPC_POWER6_5,               POWER5),
8940 a750fc0b j_mayer
    /* POWER6A                                                               */
8941 80d11f44 j_mayer
    POWERPC_DEF("POWER6A",       CPU_POWERPC_POWER6A,                POWER6),
8942 2662a059 j_mayer
#endif
8943 9d52e907 David Gibson
    /* POWER7                                                                */
8944 9d52e907 David Gibson
    POWERPC_DEF("POWER7",        CPU_POWERPC_POWER7,                 POWER7),
8945 9d52e907 David Gibson
    POWERPC_DEF("POWER7_v2.0",   CPU_POWERPC_POWER7_v20,             POWER7),
8946 a750fc0b j_mayer
    /* PowerPC 970                                                           */
8947 80d11f44 j_mayer
    POWERPC_DEF("970",           CPU_POWERPC_970,                    970),
8948 a750fc0b j_mayer
    /* PowerPC 970FX (G5)                                                    */
8949 80d11f44 j_mayer
    POWERPC_DEF("970fx",         CPU_POWERPC_970FX,                  970FX),
8950 a750fc0b j_mayer
    /* PowerPC 970FX v1.0 (G5)                                               */
8951 80d11f44 j_mayer
    POWERPC_DEF("970fx_v1.0",    CPU_POWERPC_970FX_v10,              970FX),
8952 a750fc0b j_mayer
    /* PowerPC 970FX v2.0 (G5)                                               */
8953 80d11f44 j_mayer
    POWERPC_DEF("970fx_v2.0",    CPU_POWERPC_970FX_v20,              970FX),
8954 a750fc0b j_mayer
    /* PowerPC 970FX v2.1 (G5)                                               */
8955 80d11f44 j_mayer
    POWERPC_DEF("970fx_v2.1",    CPU_POWERPC_970FX_v21,              970FX),
8956 a750fc0b j_mayer
    /* PowerPC 970FX v3.0 (G5)                                               */
8957 80d11f44 j_mayer
    POWERPC_DEF("970fx_v3.0",    CPU_POWERPC_970FX_v30,              970FX),
8958 a750fc0b j_mayer
    /* PowerPC 970FX v3.1 (G5)                                               */
8959 80d11f44 j_mayer
    POWERPC_DEF("970fx_v3.1",    CPU_POWERPC_970FX_v31,              970FX),
8960 a750fc0b j_mayer
    /* PowerPC 970GX (G5)                                                    */
8961 80d11f44 j_mayer
    POWERPC_DEF("970gx",         CPU_POWERPC_970GX,                  970GX),
8962 a750fc0b j_mayer
    /* PowerPC 970MP                                                         */
8963 80d11f44 j_mayer
    POWERPC_DEF("970mp",         CPU_POWERPC_970MP,                  970MP),
8964 a750fc0b j_mayer
    /* PowerPC 970MP v1.0                                                    */
8965 80d11f44 j_mayer
    POWERPC_DEF("970mp_v1.0",    CPU_POWERPC_970MP_v10,              970MP),
8966 a750fc0b j_mayer
    /* PowerPC 970MP v1.1                                                    */
8967 80d11f44 j_mayer
    POWERPC_DEF("970mp_v1.1",    CPU_POWERPC_970MP_v11,              970MP),
8968 3a607854 j_mayer
#if defined (TODO)
8969 a750fc0b j_mayer
    /* PowerPC Cell                                                          */
8970 80d11f44 j_mayer
    POWERPC_DEF("Cell",          CPU_POWERPC_CELL,                   970),
8971 2662a059 j_mayer
#endif
8972 2662a059 j_mayer
#if defined (TODO)
8973 a750fc0b j_mayer
    /* PowerPC Cell v1.0                                                     */
8974 80d11f44 j_mayer
    POWERPC_DEF("Cell_v1.0",     CPU_POWERPC_CELL_v10,               970),
8975 2662a059 j_mayer
#endif
8976 2662a059 j_mayer
#if defined (TODO)
8977 a750fc0b j_mayer
    /* PowerPC Cell v2.0                                                     */
8978 80d11f44 j_mayer
    POWERPC_DEF("Cell_v2.0",     CPU_POWERPC_CELL_v20,               970),
8979 2662a059 j_mayer
#endif
8980 2662a059 j_mayer
#if defined (TODO)
8981 a750fc0b j_mayer
    /* PowerPC Cell v3.0                                                     */
8982 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.0",     CPU_POWERPC_CELL_v30,               970),
8983 3a607854 j_mayer
#endif
8984 3a607854 j_mayer
#if defined (TODO)
8985 a750fc0b j_mayer
    /* PowerPC Cell v3.1                                                     */
8986 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.1",     CPU_POWERPC_CELL_v31,               970),
8987 2662a059 j_mayer
#endif
8988 2662a059 j_mayer
#if defined (TODO)
8989 a750fc0b j_mayer
    /* PowerPC Cell v3.2                                                     */
8990 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.2",     CPU_POWERPC_CELL_v32,               970),
8991 2662a059 j_mayer
#endif
8992 2662a059 j_mayer
#if defined (TODO)
8993 a750fc0b j_mayer
    /* RS64 (Apache/A35)                                                     */
8994 a750fc0b j_mayer
    /* This one seems to support the whole POWER2 instruction set
8995 a750fc0b j_mayer
     * and the PowerPC 64 one.
8996 a750fc0b j_mayer
     */
8997 a750fc0b j_mayer
    /* What about A10 & A30 ? */
8998 80d11f44 j_mayer
    POWERPC_DEF("RS64",          CPU_POWERPC_RS64,                   RS64),
8999 80d11f44 j_mayer
    POWERPC_DEF("Apache",        CPU_POWERPC_RS64,                   RS64),
9000 80d11f44 j_mayer
    POWERPC_DEF("A35",           CPU_POWERPC_RS64,                   RS64),
9001 3a607854 j_mayer
#endif
9002 3a607854 j_mayer
#if defined (TODO)
9003 a750fc0b j_mayer
    /* RS64-II (NorthStar/A50)                                               */
9004 80d11f44 j_mayer
    POWERPC_DEF("RS64-II",       CPU_POWERPC_RS64II,                 RS64),
9005 80d11f44 j_mayer
    POWERPC_DEF("NorthStar",     CPU_POWERPC_RS64II,                 RS64),
9006 80d11f44 j_mayer
    POWERPC_DEF("A50",           CPU_POWERPC_RS64II,                 RS64),
9007 3a607854 j_mayer
#endif
9008 3a607854 j_mayer
#if defined (TODO)
9009 a750fc0b j_mayer
    /* RS64-III (Pulsar)                                                     */
9010 80d11f44 j_mayer
    POWERPC_DEF("RS64-III",      CPU_POWERPC_RS64III,                RS64),
9011 80d11f44 j_mayer
    POWERPC_DEF("Pulsar",        CPU_POWERPC_RS64III,                RS64),
9012 2662a059 j_mayer
#endif
9013 2662a059 j_mayer
#if defined (TODO)
9014 a750fc0b j_mayer
    /* RS64-IV (IceStar/IStar/SStar)                                         */
9015 80d11f44 j_mayer
    POWERPC_DEF("RS64-IV",       CPU_POWERPC_RS64IV,                 RS64),
9016 80d11f44 j_mayer
    POWERPC_DEF("IceStar",       CPU_POWERPC_RS64IV,                 RS64),
9017 80d11f44 j_mayer
    POWERPC_DEF("IStar",         CPU_POWERPC_RS64IV,                 RS64),
9018 80d11f44 j_mayer
    POWERPC_DEF("SStar",         CPU_POWERPC_RS64IV,                 RS64),
9019 3a607854 j_mayer
#endif
9020 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
9021 a750fc0b j_mayer
    /* POWER                                                                 */
9022 3fc6c082 bellard
#if defined (TODO)
9023 a750fc0b j_mayer
    /* Original POWER                                                        */
9024 80d11f44 j_mayer
    POWERPC_DEF("POWER",         CPU_POWERPC_POWER,                  POWER),
9025 80d11f44 j_mayer
    POWERPC_DEF("RIOS",          CPU_POWERPC_POWER,                  POWER),
9026 80d11f44 j_mayer
    POWERPC_DEF("RSC",           CPU_POWERPC_POWER,                  POWER),
9027 80d11f44 j_mayer
    POWERPC_DEF("RSC3308",       CPU_POWERPC_POWER,                  POWER),
9028 80d11f44 j_mayer
    POWERPC_DEF("RSC4608",       CPU_POWERPC_POWER,                  POWER),
9029 76a66253 j_mayer
#endif
9030 76a66253 j_mayer
#if defined (TODO)
9031 a750fc0b j_mayer
    /* POWER2                                                                */
9032 80d11f44 j_mayer
    POWERPC_DEF("POWER2",        CPU_POWERPC_POWER2,                 POWER),
9033 80d11f44 j_mayer
    POWERPC_DEF("RSC2",          CPU_POWERPC_POWER2,                 POWER),
9034 80d11f44 j_mayer
    POWERPC_DEF("P2SC",          CPU_POWERPC_POWER2,                 POWER),
9035 a750fc0b j_mayer
#endif
9036 a750fc0b j_mayer
    /* PA semi cores                                                         */
9037 a750fc0b j_mayer
#if defined (TODO)
9038 a750fc0b j_mayer
    /* PA PA6T */
9039 80d11f44 j_mayer
    POWERPC_DEF("PA6T",          CPU_POWERPC_PA6T,                   PA6T),
9040 a750fc0b j_mayer
#endif
9041 a750fc0b j_mayer
    /* Generic PowerPCs                                                      */
9042 a750fc0b j_mayer
#if defined (TARGET_PPC64)
9043 80d11f44 j_mayer
    POWERPC_DEF("ppc64",         CPU_POWERPC_PPC64,                  PPC64),
9044 a750fc0b j_mayer
#endif
9045 80d11f44 j_mayer
    POWERPC_DEF("ppc32",         CPU_POWERPC_PPC32,                  PPC32),
9046 80d11f44 j_mayer
    POWERPC_DEF("ppc",           CPU_POWERPC_DEFAULT,                DEFAULT),
9047 a750fc0b j_mayer
    /* Fallback                                                              */
9048 80d11f44 j_mayer
    POWERPC_DEF("default",       CPU_POWERPC_DEFAULT,                DEFAULT),
9049 a750fc0b j_mayer
};
9050 a750fc0b j_mayer
9051 a750fc0b j_mayer
/*****************************************************************************/
9052 a750fc0b j_mayer
/* Generic CPU instanciation routine                                         */
9053 c227f099 Anthony Liguori
static void init_ppc_proc (CPUPPCState *env, const ppc_def_t *def)
9054 a750fc0b j_mayer
{
9055 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
9056 e1833e1f j_mayer
    int i;
9057 e1833e1f j_mayer
9058 a750fc0b j_mayer
    env->irq_inputs = NULL;
9059 e1833e1f j_mayer
    /* Set all exception vectors to an invalid address */
9060 e1833e1f j_mayer
    for (i = 0; i < POWERPC_EXCP_NB; i++)
9061 e1833e1f j_mayer
        env->excp_vectors[i] = (target_ulong)(-1ULL);
9062 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000;
9063 e1833e1f j_mayer
    env->ivor_mask = 0x00000000;
9064 e1833e1f j_mayer
    env->ivpr_mask = 0x00000000;
9065 a750fc0b j_mayer
    /* Default MMU definitions */
9066 a750fc0b j_mayer
    env->nb_BATs = 0;
9067 a750fc0b j_mayer
    env->nb_tlb = 0;
9068 a750fc0b j_mayer
    env->nb_ways = 0;
9069 f2e63a42 j_mayer
#endif
9070 a750fc0b j_mayer
    /* Register SPR common to all PowerPC implementations */
9071 a750fc0b j_mayer
    gen_spr_generic(env);
9072 a750fc0b j_mayer
    spr_register(env, SPR_PVR, "PVR",
9073 a139aa17 Nathan Froyd
                 /* Linux permits userspace to read PVR */
9074 a139aa17 Nathan Froyd
#if defined(CONFIG_LINUX_USER)
9075 a139aa17 Nathan Froyd
                 &spr_read_generic,
9076 a139aa17 Nathan Froyd
#else
9077 a139aa17 Nathan Froyd
                 SPR_NOACCESS,
9078 a139aa17 Nathan Froyd
#endif
9079 a139aa17 Nathan Froyd
                 SPR_NOACCESS,
9080 a750fc0b j_mayer
                 &spr_read_generic, SPR_NOACCESS,
9081 a750fc0b j_mayer
                 def->pvr);
9082 80d11f44 j_mayer
    /* Register SVR if it's defined to anything else than POWERPC_SVR_NONE */
9083 80d11f44 j_mayer
    if (def->svr != POWERPC_SVR_NONE) {
9084 80d11f44 j_mayer
        if (def->svr & POWERPC_SVR_E500) {
9085 80d11f44 j_mayer
            spr_register(env, SPR_E500_SVR, "SVR",
9086 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
9087 80d11f44 j_mayer
                         &spr_read_generic, SPR_NOACCESS,
9088 80d11f44 j_mayer
                         def->svr & ~POWERPC_SVR_E500);
9089 80d11f44 j_mayer
        } else {
9090 80d11f44 j_mayer
            spr_register(env, SPR_SVR, "SVR",
9091 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
9092 80d11f44 j_mayer
                         &spr_read_generic, SPR_NOACCESS,
9093 80d11f44 j_mayer
                         def->svr);
9094 80d11f44 j_mayer
        }
9095 80d11f44 j_mayer
    }
9096 a750fc0b j_mayer
    /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
9097 a750fc0b j_mayer
    (*def->init_proc)(env);
9098 fc1c67bc Blue Swirl
#if !defined(CONFIG_USER_ONLY)
9099 fc1c67bc Blue Swirl
    env->excp_prefix = env->hreset_excp_prefix;
9100 fc1c67bc Blue Swirl
#endif
9101 25ba3a68 j_mayer
    /* MSR bits & flags consistency checks */
9102 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 25)) {
9103 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
9104 25ba3a68 j_mayer
        case POWERPC_FLAG_SPE:
9105 25ba3a68 j_mayer
        case POWERPC_FLAG_VRE:
9106 25ba3a68 j_mayer
            break;
9107 25ba3a68 j_mayer
        default:
9108 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9109 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SPE or POWERPC_FLAG_VRE\n");
9110 25ba3a68 j_mayer
            exit(1);
9111 25ba3a68 j_mayer
        }
9112 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
9113 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9114 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SPE nor POWERPC_FLAG_VRE\n");
9115 25ba3a68 j_mayer
        exit(1);
9116 25ba3a68 j_mayer
    }
9117 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 17)) {
9118 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
9119 25ba3a68 j_mayer
        case POWERPC_FLAG_TGPR:
9120 25ba3a68 j_mayer
        case POWERPC_FLAG_CE:
9121 25ba3a68 j_mayer
            break;
9122 25ba3a68 j_mayer
        default:
9123 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9124 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_TGPR or POWERPC_FLAG_CE\n");
9125 25ba3a68 j_mayer
            exit(1);
9126 25ba3a68 j_mayer
        }
9127 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
9128 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9129 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_TGPR nor POWERPC_FLAG_CE\n");
9130 25ba3a68 j_mayer
        exit(1);
9131 25ba3a68 j_mayer
    }
9132 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 10)) {
9133 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
9134 25ba3a68 j_mayer
                              POWERPC_FLAG_UBLE)) {
9135 25ba3a68 j_mayer
        case POWERPC_FLAG_SE:
9136 25ba3a68 j_mayer
        case POWERPC_FLAG_DWE:
9137 25ba3a68 j_mayer
        case POWERPC_FLAG_UBLE:
9138 25ba3a68 j_mayer
            break;
9139 25ba3a68 j_mayer
        default:
9140 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9141 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SE or POWERPC_FLAG_DWE or "
9142 25ba3a68 j_mayer
                    "POWERPC_FLAG_UBLE\n");
9143 25ba3a68 j_mayer
            exit(1);
9144 25ba3a68 j_mayer
        }
9145 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
9146 25ba3a68 j_mayer
                             POWERPC_FLAG_UBLE)) {
9147 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9148 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SE nor POWERPC_FLAG_DWE nor "
9149 25ba3a68 j_mayer
                "POWERPC_FLAG_UBLE\n");
9150 25ba3a68 j_mayer
            exit(1);
9151 25ba3a68 j_mayer
    }
9152 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 9)) {
9153 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
9154 25ba3a68 j_mayer
        case POWERPC_FLAG_BE:
9155 25ba3a68 j_mayer
        case POWERPC_FLAG_DE:
9156 25ba3a68 j_mayer
            break;
9157 25ba3a68 j_mayer
        default:
9158 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9159 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_BE or POWERPC_FLAG_DE\n");
9160 25ba3a68 j_mayer
            exit(1);
9161 25ba3a68 j_mayer
        }
9162 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
9163 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9164 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_BE nor POWERPC_FLAG_DE\n");
9165 25ba3a68 j_mayer
        exit(1);
9166 25ba3a68 j_mayer
    }
9167 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 2)) {
9168 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
9169 25ba3a68 j_mayer
        case POWERPC_FLAG_PX:
9170 25ba3a68 j_mayer
        case POWERPC_FLAG_PMM:
9171 25ba3a68 j_mayer
            break;
9172 25ba3a68 j_mayer
        default:
9173 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9174 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_PX or POWERPC_FLAG_PMM\n");
9175 25ba3a68 j_mayer
            exit(1);
9176 25ba3a68 j_mayer
        }
9177 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
9178 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9179 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_PX nor POWERPC_FLAG_PMM\n");
9180 25ba3a68 j_mayer
        exit(1);
9181 25ba3a68 j_mayer
    }
9182 4018bae9 j_mayer
    if ((env->flags & (POWERPC_FLAG_RTC_CLK | POWERPC_FLAG_BUS_CLK)) == 0) {
9183 4018bae9 j_mayer
        fprintf(stderr, "PowerPC flags inconsistency\n"
9184 4018bae9 j_mayer
                "Should define the time-base and decrementer clock source\n");
9185 4018bae9 j_mayer
        exit(1);
9186 4018bae9 j_mayer
    }
9187 a750fc0b j_mayer
    /* Allocate TLBs buffer when needed */
9188 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
9189 a750fc0b j_mayer
    if (env->nb_tlb != 0) {
9190 a750fc0b j_mayer
        int nb_tlb = env->nb_tlb;
9191 a750fc0b j_mayer
        if (env->id_tlbs != 0)
9192 a750fc0b j_mayer
            nb_tlb *= 2;
9193 c227f099 Anthony Liguori
        env->tlb = qemu_mallocz(nb_tlb * sizeof(ppc_tlb_t));
9194 a750fc0b j_mayer
        /* Pre-compute some useful values */
9195 a750fc0b j_mayer
        env->tlb_per_way = env->nb_tlb / env->nb_ways;
9196 a750fc0b j_mayer
    }
9197 a750fc0b j_mayer
    if (env->irq_inputs == NULL) {
9198 a750fc0b j_mayer
        fprintf(stderr, "WARNING: no internal IRQ controller registered.\n"
9199 a750fc0b j_mayer
                " Attempt Qemu to crash very soon !\n");
9200 a750fc0b j_mayer
    }
9201 a750fc0b j_mayer
#endif
9202 2f462816 j_mayer
    if (env->check_pow == NULL) {
9203 2f462816 j_mayer
        fprintf(stderr, "WARNING: no power management check handler "
9204 2f462816 j_mayer
                "registered.\n"
9205 2f462816 j_mayer
                " Attempt Qemu to crash very soon !\n");
9206 2f462816 j_mayer
    }
9207 a750fc0b j_mayer
}
9208 a750fc0b j_mayer
9209 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
9210 a750fc0b j_mayer
static void dump_ppc_sprs (CPUPPCState *env)
9211 a750fc0b j_mayer
{
9212 a750fc0b j_mayer
    ppc_spr_t *spr;
9213 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
9214 a750fc0b j_mayer
    uint32_t sr, sw;
9215 a750fc0b j_mayer
#endif
9216 a750fc0b j_mayer
    uint32_t ur, uw;
9217 a750fc0b j_mayer
    int i, j, n;
9218 a750fc0b j_mayer
9219 a750fc0b j_mayer
    printf("Special purpose registers:\n");
9220 a750fc0b j_mayer
    for (i = 0; i < 32; i++) {
9221 a750fc0b j_mayer
        for (j = 0; j < 32; j++) {
9222 a750fc0b j_mayer
            n = (i << 5) | j;
9223 a750fc0b j_mayer
            spr = &env->spr_cb[n];
9224 a750fc0b j_mayer
            uw = spr->uea_write != NULL && spr->uea_write != SPR_NOACCESS;
9225 a750fc0b j_mayer
            ur = spr->uea_read != NULL && spr->uea_read != SPR_NOACCESS;
9226 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
9227 a750fc0b j_mayer
            sw = spr->oea_write != NULL && spr->oea_write != SPR_NOACCESS;
9228 a750fc0b j_mayer
            sr = spr->oea_read != NULL && spr->oea_read != SPR_NOACCESS;
9229 a750fc0b j_mayer
            if (sw || sr || uw || ur) {
9230 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
9231 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
9232 a750fc0b j_mayer
                       sw ? 'w' : '-', sr ? 'r' : '-',
9233 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
9234 a750fc0b j_mayer
            }
9235 a750fc0b j_mayer
#else
9236 a750fc0b j_mayer
            if (uw || ur) {
9237 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s u%c%c\n",
9238 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
9239 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
9240 a750fc0b j_mayer
            }
9241 a750fc0b j_mayer
#endif
9242 a750fc0b j_mayer
        }
9243 a750fc0b j_mayer
    }
9244 a750fc0b j_mayer
    fflush(stdout);
9245 a750fc0b j_mayer
    fflush(stderr);
9246 a750fc0b j_mayer
}
9247 a750fc0b j_mayer
#endif
9248 a750fc0b j_mayer
9249 a750fc0b j_mayer
/*****************************************************************************/
9250 a750fc0b j_mayer
#include <stdlib.h>
9251 a750fc0b j_mayer
#include <string.h>
9252 a750fc0b j_mayer
9253 a750fc0b j_mayer
/* Opcode types */
9254 a750fc0b j_mayer
enum {
9255 a750fc0b j_mayer
    PPC_DIRECT   = 0, /* Opcode routine        */
9256 a750fc0b j_mayer
    PPC_INDIRECT = 1, /* Indirect opcode table */
9257 a750fc0b j_mayer
};
9258 a750fc0b j_mayer
9259 a750fc0b j_mayer
static inline int is_indirect_opcode (void *handler)
9260 a750fc0b j_mayer
{
9261 a750fc0b j_mayer
    return ((unsigned long)handler & 0x03) == PPC_INDIRECT;
9262 a750fc0b j_mayer
}
9263 a750fc0b j_mayer
9264 c227f099 Anthony Liguori
static inline opc_handler_t **ind_table(void *handler)
9265 a750fc0b j_mayer
{
9266 c227f099 Anthony Liguori
    return (opc_handler_t **)((unsigned long)handler & ~3);
9267 a750fc0b j_mayer
}
9268 a750fc0b j_mayer
9269 a750fc0b j_mayer
/* Instruction table creation */
9270 a750fc0b j_mayer
/* Opcodes tables creation */
9271 c227f099 Anthony Liguori
static void fill_new_table (opc_handler_t **table, int len)
9272 a750fc0b j_mayer
{
9273 a750fc0b j_mayer
    int i;
9274 a750fc0b j_mayer
9275 a750fc0b j_mayer
    for (i = 0; i < len; i++)
9276 a750fc0b j_mayer
        table[i] = &invalid_handler;
9277 a750fc0b j_mayer
}
9278 a750fc0b j_mayer
9279 c227f099 Anthony Liguori
static int create_new_table (opc_handler_t **table, unsigned char idx)
9280 a750fc0b j_mayer
{
9281 c227f099 Anthony Liguori
    opc_handler_t **tmp;
9282 a750fc0b j_mayer
9283 c227f099 Anthony Liguori
    tmp = malloc(0x20 * sizeof(opc_handler_t));
9284 a750fc0b j_mayer
    fill_new_table(tmp, 0x20);
9285 c227f099 Anthony Liguori
    table[idx] = (opc_handler_t *)((unsigned long)tmp | PPC_INDIRECT);
9286 a750fc0b j_mayer
9287 a750fc0b j_mayer
    return 0;
9288 a750fc0b j_mayer
}
9289 a750fc0b j_mayer
9290 c227f099 Anthony Liguori
static int insert_in_table (opc_handler_t **table, unsigned char idx,
9291 c227f099 Anthony Liguori
                            opc_handler_t *handler)
9292 a750fc0b j_mayer
{
9293 a750fc0b j_mayer
    if (table[idx] != &invalid_handler)
9294 a750fc0b j_mayer
        return -1;
9295 a750fc0b j_mayer
    table[idx] = handler;
9296 a750fc0b j_mayer
9297 a750fc0b j_mayer
    return 0;
9298 a750fc0b j_mayer
}
9299 a750fc0b j_mayer
9300 c227f099 Anthony Liguori
static int register_direct_insn (opc_handler_t **ppc_opcodes,
9301 c227f099 Anthony Liguori
                                 unsigned char idx, opc_handler_t *handler)
9302 a750fc0b j_mayer
{
9303 a750fc0b j_mayer
    if (insert_in_table(ppc_opcodes, idx, handler) < 0) {
9304 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in main "
9305 a750fc0b j_mayer
               "opcode table\n", idx);
9306 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
9307 4c1b1bfe j_mayer
        printf("           Registered handler '%s' - new handler '%s'\n",
9308 4c1b1bfe j_mayer
               ppc_opcodes[idx]->oname, handler->oname);
9309 4c1b1bfe j_mayer
#endif
9310 a750fc0b j_mayer
        return -1;
9311 a750fc0b j_mayer
    }
9312 a750fc0b j_mayer
9313 a750fc0b j_mayer
    return 0;
9314 a750fc0b j_mayer
}
9315 a750fc0b j_mayer
9316 c227f099 Anthony Liguori
static int register_ind_in_table (opc_handler_t **table,
9317 a750fc0b j_mayer
                                  unsigned char idx1, unsigned char idx2,
9318 c227f099 Anthony Liguori
                                  opc_handler_t *handler)
9319 a750fc0b j_mayer
{
9320 a750fc0b j_mayer
    if (table[idx1] == &invalid_handler) {
9321 a750fc0b j_mayer
        if (create_new_table(table, idx1) < 0) {
9322 a750fc0b j_mayer
            printf("*** ERROR: unable to create indirect table "
9323 a750fc0b j_mayer
                   "idx=%02x\n", idx1);
9324 a750fc0b j_mayer
            return -1;
9325 a750fc0b j_mayer
        }
9326 a750fc0b j_mayer
    } else {
9327 a750fc0b j_mayer
        if (!is_indirect_opcode(table[idx1])) {
9328 a750fc0b j_mayer
            printf("*** ERROR: idx %02x already assigned to a direct "
9329 a750fc0b j_mayer
                   "opcode\n", idx1);
9330 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
9331 4c1b1bfe j_mayer
            printf("           Registered handler '%s' - new handler '%s'\n",
9332 4c1b1bfe j_mayer
                   ind_table(table[idx1])[idx2]->oname, handler->oname);
9333 4c1b1bfe j_mayer
#endif
9334 a750fc0b j_mayer
            return -1;
9335 a750fc0b j_mayer
        }
9336 3a607854 j_mayer
    }
9337 a750fc0b j_mayer
    if (handler != NULL &&
9338 a750fc0b j_mayer
        insert_in_table(ind_table(table[idx1]), idx2, handler) < 0) {
9339 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in "
9340 a750fc0b j_mayer
               "opcode table %02x\n", idx2, idx1);
9341 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
9342 4c1b1bfe j_mayer
        printf("           Registered handler '%s' - new handler '%s'\n",
9343 4c1b1bfe j_mayer
               ind_table(table[idx1])[idx2]->oname, handler->oname);
9344 4c1b1bfe j_mayer
#endif
9345 a750fc0b j_mayer
        return -1;
9346 3a607854 j_mayer
    }
9347 a750fc0b j_mayer
9348 a750fc0b j_mayer
    return 0;
9349 a750fc0b j_mayer
}
9350 a750fc0b j_mayer
9351 c227f099 Anthony Liguori
static int register_ind_insn (opc_handler_t **ppc_opcodes,
9352 a750fc0b j_mayer
                              unsigned char idx1, unsigned char idx2,
9353 c227f099 Anthony Liguori
                              opc_handler_t *handler)
9354 a750fc0b j_mayer
{
9355 a750fc0b j_mayer
    int ret;
9356 a750fc0b j_mayer
9357 a750fc0b j_mayer
    ret = register_ind_in_table(ppc_opcodes, idx1, idx2, handler);
9358 a750fc0b j_mayer
9359 a750fc0b j_mayer
    return ret;
9360 a750fc0b j_mayer
}
9361 a750fc0b j_mayer
9362 c227f099 Anthony Liguori
static int register_dblind_insn (opc_handler_t **ppc_opcodes,
9363 a750fc0b j_mayer
                                 unsigned char idx1, unsigned char idx2,
9364 c227f099 Anthony Liguori
                                 unsigned char idx3, opc_handler_t *handler)
9365 a750fc0b j_mayer
{
9366 a750fc0b j_mayer
    if (register_ind_in_table(ppc_opcodes, idx1, idx2, NULL) < 0) {
9367 a750fc0b j_mayer
        printf("*** ERROR: unable to join indirect table idx "
9368 a750fc0b j_mayer
               "[%02x-%02x]\n", idx1, idx2);
9369 a750fc0b j_mayer
        return -1;
9370 a750fc0b j_mayer
    }
9371 a750fc0b j_mayer
    if (register_ind_in_table(ind_table(ppc_opcodes[idx1]), idx2, idx3,
9372 a750fc0b j_mayer
                              handler) < 0) {
9373 a750fc0b j_mayer
        printf("*** ERROR: unable to insert opcode "
9374 a750fc0b j_mayer
               "[%02x-%02x-%02x]\n", idx1, idx2, idx3);
9375 a750fc0b j_mayer
        return -1;
9376 a750fc0b j_mayer
    }
9377 a750fc0b j_mayer
9378 a750fc0b j_mayer
    return 0;
9379 a750fc0b j_mayer
}
9380 a750fc0b j_mayer
9381 c227f099 Anthony Liguori
static int register_insn (opc_handler_t **ppc_opcodes, opcode_t *insn)
9382 a750fc0b j_mayer
{
9383 a750fc0b j_mayer
    if (insn->opc2 != 0xFF) {
9384 a750fc0b j_mayer
        if (insn->opc3 != 0xFF) {
9385 a750fc0b j_mayer
            if (register_dblind_insn(ppc_opcodes, insn->opc1, insn->opc2,
9386 a750fc0b j_mayer
                                     insn->opc3, &insn->handler) < 0)
9387 a750fc0b j_mayer
                return -1;
9388 a750fc0b j_mayer
        } else {
9389 a750fc0b j_mayer
            if (register_ind_insn(ppc_opcodes, insn->opc1,
9390 a750fc0b j_mayer
                                  insn->opc2, &insn->handler) < 0)
9391 a750fc0b j_mayer
                return -1;
9392 a750fc0b j_mayer
        }
9393 a750fc0b j_mayer
    } else {
9394 a750fc0b j_mayer
        if (register_direct_insn(ppc_opcodes, insn->opc1, &insn->handler) < 0)
9395 a750fc0b j_mayer
            return -1;
9396 a750fc0b j_mayer
    }
9397 a750fc0b j_mayer
9398 a750fc0b j_mayer
    return 0;
9399 a750fc0b j_mayer
}
9400 a750fc0b j_mayer
9401 c227f099 Anthony Liguori
static int test_opcode_table (opc_handler_t **table, int len)
9402 a750fc0b j_mayer
{
9403 a750fc0b j_mayer
    int i, count, tmp;
9404 a750fc0b j_mayer
9405 a750fc0b j_mayer
    for (i = 0, count = 0; i < len; i++) {
9406 a750fc0b j_mayer
        /* Consistency fixup */
9407 a750fc0b j_mayer
        if (table[i] == NULL)
9408 a750fc0b j_mayer
            table[i] = &invalid_handler;
9409 a750fc0b j_mayer
        if (table[i] != &invalid_handler) {
9410 a750fc0b j_mayer
            if (is_indirect_opcode(table[i])) {
9411 c227f099 Anthony Liguori
                tmp = test_opcode_table(ind_table(table[i]), 0x20);
9412 a750fc0b j_mayer
                if (tmp == 0) {
9413 a750fc0b j_mayer
                    free(table[i]);
9414 a750fc0b j_mayer
                    table[i] = &invalid_handler;
9415 a750fc0b j_mayer
                } else {
9416 a750fc0b j_mayer
                    count++;
9417 a750fc0b j_mayer
                }
9418 a750fc0b j_mayer
            } else {
9419 a750fc0b j_mayer
                count++;
9420 a750fc0b j_mayer
            }
9421 a750fc0b j_mayer
        }
9422 a750fc0b j_mayer
    }
9423 a750fc0b j_mayer
9424 a750fc0b j_mayer
    return count;
9425 a750fc0b j_mayer
}
9426 a750fc0b j_mayer
9427 c227f099 Anthony Liguori
static void fix_opcode_tables (opc_handler_t **ppc_opcodes)
9428 a750fc0b j_mayer
{
9429 c227f099 Anthony Liguori
    if (test_opcode_table(ppc_opcodes, 0x40) == 0)
9430 a750fc0b j_mayer
        printf("*** WARNING: no opcode defined !\n");
9431 a750fc0b j_mayer
}
9432 a750fc0b j_mayer
9433 a750fc0b j_mayer
/*****************************************************************************/
9434 c227f099 Anthony Liguori
static int create_ppc_opcodes (CPUPPCState *env, const ppc_def_t *def)
9435 a750fc0b j_mayer
{
9436 c227f099 Anthony Liguori
    opcode_t *opc;
9437 a750fc0b j_mayer
9438 a750fc0b j_mayer
    fill_new_table(env->opcodes, 0x40);
9439 5c55ff99 Blue Swirl
    for (opc = opcodes; opc < &opcodes[ARRAY_SIZE(opcodes)]; opc++) {
9440 a750fc0b j_mayer
        if ((opc->handler.type & def->insns_flags) != 0) {
9441 a750fc0b j_mayer
            if (register_insn(env->opcodes, opc) < 0) {
9442 a750fc0b j_mayer
                printf("*** ERROR initializing PowerPC instruction "
9443 a750fc0b j_mayer
                       "0x%02x 0x%02x 0x%02x\n", opc->opc1, opc->opc2,
9444 a750fc0b j_mayer
                       opc->opc3);
9445 a750fc0b j_mayer
                return -1;
9446 a750fc0b j_mayer
            }
9447 a750fc0b j_mayer
        }
9448 a750fc0b j_mayer
    }
9449 c227f099 Anthony Liguori
    fix_opcode_tables(env->opcodes);
9450 a750fc0b j_mayer
    fflush(stdout);
9451 a750fc0b j_mayer
    fflush(stderr);
9452 a750fc0b j_mayer
9453 a750fc0b j_mayer
    return 0;
9454 a750fc0b j_mayer
}
9455 a750fc0b j_mayer
9456 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
9457 25ba3a68 j_mayer
static void dump_ppc_insns (CPUPPCState *env)
9458 a750fc0b j_mayer
{
9459 c227f099 Anthony Liguori
    opc_handler_t **table, *handler;
9460 b55266b5 blueswir1
    const char *p, *q;
9461 a750fc0b j_mayer
    uint8_t opc1, opc2, opc3;
9462 a750fc0b j_mayer
9463 a750fc0b j_mayer
    printf("Instructions set:\n");
9464 a750fc0b j_mayer
    /* opc1 is 6 bits long */
9465 a750fc0b j_mayer
    for (opc1 = 0x00; opc1 < 0x40; opc1++) {
9466 a750fc0b j_mayer
        table = env->opcodes;
9467 a750fc0b j_mayer
        handler = table[opc1];
9468 a750fc0b j_mayer
        if (is_indirect_opcode(handler)) {
9469 a750fc0b j_mayer
            /* opc2 is 5 bits long */
9470 a750fc0b j_mayer
            for (opc2 = 0; opc2 < 0x20; opc2++) {
9471 a750fc0b j_mayer
                table = env->opcodes;
9472 a750fc0b j_mayer
                handler = env->opcodes[opc1];
9473 a750fc0b j_mayer
                table = ind_table(handler);
9474 a750fc0b j_mayer
                handler = table[opc2];
9475 a750fc0b j_mayer
                if (is_indirect_opcode(handler)) {
9476 a750fc0b j_mayer
                    table = ind_table(handler);
9477 a750fc0b j_mayer
                    /* opc3 is 5 bits long */
9478 a750fc0b j_mayer
                    for (opc3 = 0; opc3 < 0x20; opc3++) {
9479 a750fc0b j_mayer
                        handler = table[opc3];
9480 a750fc0b j_mayer
                        if (handler->handler != &gen_invalid) {
9481 4c1b1bfe j_mayer
                            /* Special hack to properly dump SPE insns */
9482 4c1b1bfe j_mayer
                            p = strchr(handler->oname, '_');
9483 4c1b1bfe j_mayer
                            if (p == NULL) {
9484 4c1b1bfe j_mayer
                                printf("INSN: %02x %02x %02x (%02d %04d) : "
9485 4c1b1bfe j_mayer
                                       "%s\n",
9486 4c1b1bfe j_mayer
                                       opc1, opc2, opc3, opc1,
9487 4c1b1bfe j_mayer
                                       (opc3 << 5) | opc2,
9488 4c1b1bfe j_mayer
                                       handler->oname);
9489 4c1b1bfe j_mayer
                            } else {
9490 4c1b1bfe j_mayer
                                q = "speundef";
9491 4c1b1bfe j_mayer
                                if ((p - handler->oname) != strlen(q) ||
9492 4c1b1bfe j_mayer
                                    memcmp(handler->oname, q, strlen(q)) != 0) {
9493 4c1b1bfe j_mayer
                                    /* First instruction */
9494 4c1b1bfe j_mayer
                                    printf("INSN: %02x %02x %02x (%02d %04d) : "
9495 4c1b1bfe j_mayer
                                           "%.*s\n",
9496 4c1b1bfe j_mayer
                                           opc1, opc2 << 1, opc3, opc1,
9497 4c1b1bfe j_mayer
                                           (opc3 << 6) | (opc2 << 1),
9498 4c1b1bfe j_mayer
                                           (int)(p - handler->oname),
9499 4c1b1bfe j_mayer
                                           handler->oname);
9500 4c1b1bfe j_mayer
                                }
9501 4c1b1bfe j_mayer
                                if (strcmp(p + 1, q) != 0) {
9502 4c1b1bfe j_mayer
                                    /* Second instruction */
9503 4c1b1bfe j_mayer
                                    printf("INSN: %02x %02x %02x (%02d %04d) : "
9504 4c1b1bfe j_mayer
                                           "%s\n",
9505 4c1b1bfe j_mayer
                                           opc1, (opc2 << 1) | 1, opc3, opc1,
9506 4c1b1bfe j_mayer
                                           (opc3 << 6) | (opc2 << 1) | 1,
9507 4c1b1bfe j_mayer
                                           p + 1);
9508 4c1b1bfe j_mayer
                                }
9509 4c1b1bfe j_mayer
                            }
9510 a750fc0b j_mayer
                        }
9511 a750fc0b j_mayer
                    }
9512 a750fc0b j_mayer
                } else {
9513 a750fc0b j_mayer
                    if (handler->handler != &gen_invalid) {
9514 a750fc0b j_mayer
                        printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
9515 a750fc0b j_mayer
                               opc1, opc2, opc1, opc2, handler->oname);
9516 a750fc0b j_mayer
                    }
9517 a750fc0b j_mayer
                }
9518 a750fc0b j_mayer
            }
9519 a750fc0b j_mayer
        } else {
9520 a750fc0b j_mayer
            if (handler->handler != &gen_invalid) {
9521 a750fc0b j_mayer
                printf("INSN: %02x -- -- (%02d ----) : %s\n",
9522 a750fc0b j_mayer
                       opc1, opc1, handler->oname);
9523 a750fc0b j_mayer
            }
9524 a750fc0b j_mayer
        }
9525 a750fc0b j_mayer
    }
9526 a750fc0b j_mayer
}
9527 3a607854 j_mayer
#endif
9528 a750fc0b j_mayer
9529 24951522 aurel32
static int gdb_get_float_reg(CPUState *env, uint8_t *mem_buf, int n)
9530 24951522 aurel32
{
9531 24951522 aurel32
    if (n < 32) {
9532 24951522 aurel32
        stfq_p(mem_buf, env->fpr[n]);
9533 24951522 aurel32
        return 8;
9534 24951522 aurel32
    }
9535 24951522 aurel32
    if (n == 32) {
9536 24951522 aurel32
        /* FPSCR not implemented  */
9537 24951522 aurel32
        memset(mem_buf, 0, 4);
9538 24951522 aurel32
        return 4;
9539 24951522 aurel32
    }
9540 24951522 aurel32
    return 0;
9541 24951522 aurel32
}
9542 24951522 aurel32
9543 24951522 aurel32
static int gdb_set_float_reg(CPUState *env, uint8_t *mem_buf, int n)
9544 24951522 aurel32
{
9545 24951522 aurel32
    if (n < 32) {
9546 24951522 aurel32
        env->fpr[n] = ldfq_p(mem_buf);
9547 24951522 aurel32
        return 8;
9548 24951522 aurel32
    }
9549 24951522 aurel32
    if (n == 32) {
9550 24951522 aurel32
        /* FPSCR not implemented  */
9551 24951522 aurel32
        return 4;
9552 24951522 aurel32
    }
9553 24951522 aurel32
    return 0;
9554 24951522 aurel32
}
9555 24951522 aurel32
9556 b4f8d821 aurel32
static int gdb_get_avr_reg(CPUState *env, uint8_t *mem_buf, int n)
9557 b4f8d821 aurel32
{
9558 b4f8d821 aurel32
    if (n < 32) {
9559 e2542fe2 Juan Quintela
#ifdef HOST_WORDS_BIGENDIAN
9560 b4f8d821 aurel32
        stq_p(mem_buf, env->avr[n].u64[0]);
9561 b4f8d821 aurel32
        stq_p(mem_buf+8, env->avr[n].u64[1]);
9562 b4f8d821 aurel32
#else
9563 b4f8d821 aurel32
        stq_p(mem_buf, env->avr[n].u64[1]);
9564 b4f8d821 aurel32
        stq_p(mem_buf+8, env->avr[n].u64[0]);
9565 b4f8d821 aurel32
#endif
9566 b4f8d821 aurel32
        return 16;
9567 b4f8d821 aurel32
    }
9568 70976a79 aurel32
    if (n == 32) {
9569 b4f8d821 aurel32
        stl_p(mem_buf, env->vscr);
9570 b4f8d821 aurel32
        return 4;
9571 b4f8d821 aurel32
    }
9572 70976a79 aurel32
    if (n == 33) {
9573 b4f8d821 aurel32
        stl_p(mem_buf, (uint32_t)env->spr[SPR_VRSAVE]);
9574 b4f8d821 aurel32
        return 4;
9575 b4f8d821 aurel32
    }
9576 b4f8d821 aurel32
    return 0;
9577 b4f8d821 aurel32
}
9578 b4f8d821 aurel32
9579 b4f8d821 aurel32
static int gdb_set_avr_reg(CPUState *env, uint8_t *mem_buf, int n)
9580 b4f8d821 aurel32
{
9581 b4f8d821 aurel32
    if (n < 32) {
9582 e2542fe2 Juan Quintela
#ifdef HOST_WORDS_BIGENDIAN
9583 b4f8d821 aurel32
        env->avr[n].u64[0] = ldq_p(mem_buf);
9584 b4f8d821 aurel32
        env->avr[n].u64[1] = ldq_p(mem_buf+8);
9585 b4f8d821 aurel32
#else
9586 b4f8d821 aurel32
        env->avr[n].u64[1] = ldq_p(mem_buf);
9587 b4f8d821 aurel32
        env->avr[n].u64[0] = ldq_p(mem_buf+8);
9588 b4f8d821 aurel32
#endif
9589 b4f8d821 aurel32
        return 16;
9590 b4f8d821 aurel32
    }
9591 70976a79 aurel32
    if (n == 32) {
9592 b4f8d821 aurel32
        env->vscr = ldl_p(mem_buf);
9593 b4f8d821 aurel32
        return 4;
9594 b4f8d821 aurel32
    }
9595 70976a79 aurel32
    if (n == 33) {
9596 b4f8d821 aurel32
        env->spr[SPR_VRSAVE] = (target_ulong)ldl_p(mem_buf);
9597 b4f8d821 aurel32
        return 4;
9598 b4f8d821 aurel32
    }
9599 b4f8d821 aurel32
    return 0;
9600 b4f8d821 aurel32
}
9601 b4f8d821 aurel32
9602 688890f7 aurel32
static int gdb_get_spe_reg(CPUState *env, uint8_t *mem_buf, int n)
9603 688890f7 aurel32
{
9604 688890f7 aurel32
    if (n < 32) {
9605 688890f7 aurel32
#if defined(TARGET_PPC64)
9606 688890f7 aurel32
        stl_p(mem_buf, env->gpr[n] >> 32);
9607 688890f7 aurel32
#else
9608 688890f7 aurel32
        stl_p(mem_buf, env->gprh[n]);
9609 688890f7 aurel32
#endif
9610 688890f7 aurel32
        return 4;
9611 688890f7 aurel32
    }
9612 70976a79 aurel32
    if (n == 32) {
9613 688890f7 aurel32
        stq_p(mem_buf, env->spe_acc);
9614 688890f7 aurel32
        return 8;
9615 688890f7 aurel32
    }
9616 70976a79 aurel32
    if (n == 33) {
9617 d34defbc aurel32
        stl_p(mem_buf, env->spe_fscr);
9618 688890f7 aurel32
        return 4;
9619 688890f7 aurel32
    }
9620 688890f7 aurel32
    return 0;
9621 688890f7 aurel32
}
9622 688890f7 aurel32
9623 688890f7 aurel32
static int gdb_set_spe_reg(CPUState *env, uint8_t *mem_buf, int n)
9624 688890f7 aurel32
{
9625 688890f7 aurel32
    if (n < 32) {
9626 688890f7 aurel32
#if defined(TARGET_PPC64)
9627 688890f7 aurel32
        target_ulong lo = (uint32_t)env->gpr[n];
9628 688890f7 aurel32
        target_ulong hi = (target_ulong)ldl_p(mem_buf) << 32;
9629 688890f7 aurel32
        env->gpr[n] = lo | hi;
9630 688890f7 aurel32
#else
9631 688890f7 aurel32
        env->gprh[n] = ldl_p(mem_buf);
9632 688890f7 aurel32
#endif
9633 688890f7 aurel32
        return 4;
9634 688890f7 aurel32
    }
9635 70976a79 aurel32
    if (n == 32) {
9636 688890f7 aurel32
        env->spe_acc = ldq_p(mem_buf);
9637 688890f7 aurel32
        return 8;
9638 688890f7 aurel32
    }
9639 70976a79 aurel32
    if (n == 33) {
9640 d34defbc aurel32
        env->spe_fscr = ldl_p(mem_buf);
9641 688890f7 aurel32
        return 4;
9642 688890f7 aurel32
    }
9643 688890f7 aurel32
    return 0;
9644 688890f7 aurel32
}
9645 688890f7 aurel32
9646 c227f099 Anthony Liguori
int cpu_ppc_register_internal (CPUPPCState *env, const ppc_def_t *def)
9647 a750fc0b j_mayer
{
9648 a750fc0b j_mayer
    env->msr_mask = def->msr_mask;
9649 a750fc0b j_mayer
    env->mmu_model = def->mmu_model;
9650 a750fc0b j_mayer
    env->excp_model = def->excp_model;
9651 a750fc0b j_mayer
    env->bus_model = def->bus_model;
9652 c29b735c Nathan Froyd
    env->insns_flags = def->insns_flags;
9653 d26bfc9a j_mayer
    env->flags = def->flags;
9654 237c0af0 j_mayer
    env->bfd_mach = def->bfd_mach;
9655 2f462816 j_mayer
    env->check_pow = def->check_pow;
9656 a750fc0b j_mayer
    if (create_ppc_opcodes(env, def) < 0)
9657 a750fc0b j_mayer
        return -1;
9658 a750fc0b j_mayer
    init_ppc_proc(env, def);
9659 24951522 aurel32
9660 24951522 aurel32
    if (def->insns_flags & PPC_FLOAT) {
9661 24951522 aurel32
        gdb_register_coprocessor(env, gdb_get_float_reg, gdb_set_float_reg,
9662 24951522 aurel32
                                 33, "power-fpu.xml", 0);
9663 24951522 aurel32
    }
9664 b4f8d821 aurel32
    if (def->insns_flags & PPC_ALTIVEC) {
9665 b4f8d821 aurel32
        gdb_register_coprocessor(env, gdb_get_avr_reg, gdb_set_avr_reg,
9666 b4f8d821 aurel32
                                 34, "power-altivec.xml", 0);
9667 b4f8d821 aurel32
    }
9668 40569b7e aurel32
    if (def->insns_flags & PPC_SPE) {
9669 688890f7 aurel32
        gdb_register_coprocessor(env, gdb_get_spe_reg, gdb_set_spe_reg,
9670 688890f7 aurel32
                                 34, "power-spe.xml", 0);
9671 688890f7 aurel32
    }
9672 688890f7 aurel32
9673 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
9674 3a607854 j_mayer
    {
9675 b55266b5 blueswir1
        const char *mmu_model, *excp_model, *bus_model;
9676 a750fc0b j_mayer
        switch (env->mmu_model) {
9677 a750fc0b j_mayer
        case POWERPC_MMU_32B:
9678 a750fc0b j_mayer
            mmu_model = "PowerPC 32";
9679 a750fc0b j_mayer
            break;
9680 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_6xx:
9681 a750fc0b j_mayer
            mmu_model = "PowerPC 6xx/7xx with software driven TLBs";
9682 a750fc0b j_mayer
            break;
9683 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_74xx:
9684 a750fc0b j_mayer
            mmu_model = "PowerPC 74xx with software driven TLBs";
9685 a750fc0b j_mayer
            break;
9686 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx:
9687 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs";
9688 a750fc0b j_mayer
            break;
9689 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx_Z:
9690 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs "
9691 a750fc0b j_mayer
                "and zones protections";
9692 a750fc0b j_mayer
            break;
9693 b4095fed j_mayer
        case POWERPC_MMU_REAL:
9694 b4095fed j_mayer
            mmu_model = "PowerPC real mode only";
9695 b4095fed j_mayer
            break;
9696 b4095fed j_mayer
        case POWERPC_MMU_MPC8xx:
9697 b4095fed j_mayer
            mmu_model = "PowerPC MPC8xx";
9698 a750fc0b j_mayer
            break;
9699 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE:
9700 a750fc0b j_mayer
            mmu_model = "PowerPC BookE";
9701 a750fc0b j_mayer
            break;
9702 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE_FSL:
9703 a750fc0b j_mayer
            mmu_model = "PowerPC BookE FSL";
9704 a750fc0b j_mayer
            break;
9705 b4095fed j_mayer
        case POWERPC_MMU_601:
9706 b4095fed j_mayer
            mmu_model = "PowerPC 601";
9707 b4095fed j_mayer
            break;
9708 00af685f j_mayer
#if defined (TARGET_PPC64)
9709 00af685f j_mayer
        case POWERPC_MMU_64B:
9710 00af685f j_mayer
            mmu_model = "PowerPC 64";
9711 00af685f j_mayer
            break;
9712 add78955 j_mayer
        case POWERPC_MMU_620:
9713 add78955 j_mayer
            mmu_model = "PowerPC 620";
9714 add78955 j_mayer
            break;
9715 00af685f j_mayer
#endif
9716 a750fc0b j_mayer
        default:
9717 a750fc0b j_mayer
            mmu_model = "Unknown or invalid";
9718 a750fc0b j_mayer
            break;
9719 a750fc0b j_mayer
        }
9720 a750fc0b j_mayer
        switch (env->excp_model) {
9721 a750fc0b j_mayer
        case POWERPC_EXCP_STD:
9722 a750fc0b j_mayer
            excp_model = "PowerPC";
9723 a750fc0b j_mayer
            break;
9724 a750fc0b j_mayer
        case POWERPC_EXCP_40x:
9725 a750fc0b j_mayer
            excp_model = "PowerPC 40x";
9726 a750fc0b j_mayer
            break;
9727 a750fc0b j_mayer
        case POWERPC_EXCP_601:
9728 a750fc0b j_mayer
            excp_model = "PowerPC 601";
9729 a750fc0b j_mayer
            break;
9730 a750fc0b j_mayer
        case POWERPC_EXCP_602:
9731 a750fc0b j_mayer
            excp_model = "PowerPC 602";
9732 a750fc0b j_mayer
            break;
9733 a750fc0b j_mayer
        case POWERPC_EXCP_603:
9734 a750fc0b j_mayer
            excp_model = "PowerPC 603";
9735 a750fc0b j_mayer
            break;
9736 a750fc0b j_mayer
        case POWERPC_EXCP_603E:
9737 a750fc0b j_mayer
            excp_model = "PowerPC 603e";
9738 a750fc0b j_mayer
            break;
9739 a750fc0b j_mayer
        case POWERPC_EXCP_604:
9740 a750fc0b j_mayer
            excp_model = "PowerPC 604";
9741 a750fc0b j_mayer
            break;
9742 a750fc0b j_mayer
        case POWERPC_EXCP_7x0:
9743 a750fc0b j_mayer
            excp_model = "PowerPC 740/750";
9744 a750fc0b j_mayer
            break;
9745 a750fc0b j_mayer
        case POWERPC_EXCP_7x5:
9746 a750fc0b j_mayer
            excp_model = "PowerPC 745/755";
9747 a750fc0b j_mayer
            break;
9748 a750fc0b j_mayer
        case POWERPC_EXCP_74xx:
9749 a750fc0b j_mayer
            excp_model = "PowerPC 74xx";
9750 a750fc0b j_mayer
            break;
9751 a750fc0b j_mayer
        case POWERPC_EXCP_BOOKE:
9752 a750fc0b j_mayer
            excp_model = "PowerPC BookE";
9753 a750fc0b j_mayer
            break;
9754 00af685f j_mayer
#if defined (TARGET_PPC64)
9755 00af685f j_mayer
        case POWERPC_EXCP_970:
9756 00af685f j_mayer
            excp_model = "PowerPC 970";
9757 00af685f j_mayer
            break;
9758 00af685f j_mayer
#endif
9759 a750fc0b j_mayer
        default:
9760 a750fc0b j_mayer
            excp_model = "Unknown or invalid";
9761 a750fc0b j_mayer
            break;
9762 a750fc0b j_mayer
        }
9763 a750fc0b j_mayer
        switch (env->bus_model) {
9764 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_6xx:
9765 a750fc0b j_mayer
            bus_model = "PowerPC 6xx";
9766 a750fc0b j_mayer
            break;
9767 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_BookE:
9768 a750fc0b j_mayer
            bus_model = "PowerPC BookE";
9769 a750fc0b j_mayer
            break;
9770 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_405:
9771 a750fc0b j_mayer
            bus_model = "PowerPC 405";
9772 a750fc0b j_mayer
            break;
9773 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_401:
9774 a750fc0b j_mayer
            bus_model = "PowerPC 401/403";
9775 a750fc0b j_mayer
            break;
9776 b4095fed j_mayer
        case PPC_FLAGS_INPUT_RCPU:
9777 b4095fed j_mayer
            bus_model = "RCPU / MPC8xx";
9778 b4095fed j_mayer
            break;
9779 00af685f j_mayer
#if defined (TARGET_PPC64)
9780 00af685f j_mayer
        case PPC_FLAGS_INPUT_970:
9781 00af685f j_mayer
            bus_model = "PowerPC 970";
9782 00af685f j_mayer
            break;
9783 00af685f j_mayer
#endif
9784 a750fc0b j_mayer
        default:
9785 a750fc0b j_mayer
            bus_model = "Unknown or invalid";
9786 a750fc0b j_mayer
            break;
9787 a750fc0b j_mayer
        }
9788 a750fc0b j_mayer
        printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64 "\n"
9789 a750fc0b j_mayer
               "    MMU model        : %s\n",
9790 a750fc0b j_mayer
               def->name, def->pvr, def->msr_mask, mmu_model);
9791 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
9792 a750fc0b j_mayer
        if (env->tlb != NULL) {
9793 a750fc0b j_mayer
            printf("                       %d %s TLB in %d ways\n",
9794 a750fc0b j_mayer
                   env->nb_tlb, env->id_tlbs ? "splitted" : "merged",
9795 a750fc0b j_mayer
                   env->nb_ways);
9796 a750fc0b j_mayer
        }
9797 f2e63a42 j_mayer
#endif
9798 a750fc0b j_mayer
        printf("    Exceptions model : %s\n"
9799 a750fc0b j_mayer
               "    Bus model        : %s\n",
9800 a750fc0b j_mayer
               excp_model, bus_model);
9801 25ba3a68 j_mayer
        printf("    MSR features     :\n");
9802 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SPE)
9803 25ba3a68 j_mayer
            printf("                        signal processing engine enable"
9804 25ba3a68 j_mayer
                   "\n");
9805 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_VRE)
9806 25ba3a68 j_mayer
            printf("                        vector processor enable\n");
9807 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_TGPR)
9808 25ba3a68 j_mayer
            printf("                        temporary GPRs\n");
9809 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_CE)
9810 25ba3a68 j_mayer
            printf("                        critical input enable\n");
9811 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SE)
9812 25ba3a68 j_mayer
            printf("                        single-step trace mode\n");
9813 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DWE)
9814 25ba3a68 j_mayer
            printf("                        debug wait enable\n");
9815 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_UBLE)
9816 25ba3a68 j_mayer
            printf("                        user BTB lock enable\n");
9817 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_BE)
9818 25ba3a68 j_mayer
            printf("                        branch-step trace mode\n");
9819 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DE)
9820 25ba3a68 j_mayer
            printf("                        debug interrupt enable\n");
9821 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_PX)
9822 25ba3a68 j_mayer
            printf("                        inclusive protection\n");
9823 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_PMM)
9824 25ba3a68 j_mayer
            printf("                        performance monitor mark\n");
9825 25ba3a68 j_mayer
        if (env->flags == POWERPC_FLAG_NONE)
9826 25ba3a68 j_mayer
            printf("                        none\n");
9827 4018bae9 j_mayer
        printf("    Time-base/decrementer clock source: %s\n",
9828 4018bae9 j_mayer
               env->flags & POWERPC_FLAG_RTC_CLK ? "RTC clock" : "bus clock");
9829 a750fc0b j_mayer
    }
9830 a750fc0b j_mayer
    dump_ppc_insns(env);
9831 a750fc0b j_mayer
    dump_ppc_sprs(env);
9832 a750fc0b j_mayer
    fflush(stdout);
9833 3a607854 j_mayer
#endif
9834 a750fc0b j_mayer
9835 a750fc0b j_mayer
    return 0;
9836 a750fc0b j_mayer
}
9837 3fc6c082 bellard
9838 c227f099 Anthony Liguori
static const ppc_def_t *ppc_find_by_pvr (uint32_t pvr)
9839 3fc6c082 bellard
{
9840 c227f099 Anthony Liguori
    const ppc_def_t *ret;
9841 ee4e83ed j_mayer
    uint32_t pvr_rev;
9842 ee4e83ed j_mayer
    int i, best, match, best_match, max;
9843 3fc6c082 bellard
9844 ee4e83ed j_mayer
    ret = NULL;
9845 b1503cda malc
    max = ARRAY_SIZE(ppc_defs);
9846 ee4e83ed j_mayer
    best = -1;
9847 ee4e83ed j_mayer
    pvr_rev = pvr & 0xFFFF;
9848 ee4e83ed j_mayer
    /* We want all specified bits to match */
9849 ee4e83ed j_mayer
    best_match = 32 - ctz32(pvr_rev);
9850 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
9851 ee4e83ed j_mayer
        /* We check that the 16 higher bits are the same to ensure the CPU
9852 ee4e83ed j_mayer
         * model will be the choosen one.
9853 ee4e83ed j_mayer
         */
9854 ee4e83ed j_mayer
        if (((pvr ^ ppc_defs[i].pvr) >> 16) == 0) {
9855 ee4e83ed j_mayer
            /* We want as much as possible of the low-level 16 bits
9856 ee4e83ed j_mayer
             * to be the same but we allow inexact matches.
9857 ee4e83ed j_mayer
             */
9858 ee4e83ed j_mayer
            match = clz32(pvr_rev ^ (ppc_defs[i].pvr & 0xFFFF));
9859 ee4e83ed j_mayer
            /* We check '>=' instead of '>' because the PPC_defs table
9860 ee4e83ed j_mayer
             * is ordered by increasing revision.
9861 4c1b1bfe j_mayer
             * Then, we will match the higher revision compatible
9862 ee4e83ed j_mayer
             * with the requested PVR
9863 ee4e83ed j_mayer
             */
9864 ee4e83ed j_mayer
            if (match >= best_match) {
9865 ee4e83ed j_mayer
                best = i;
9866 ee4e83ed j_mayer
                best_match = match;
9867 ee4e83ed j_mayer
            }
9868 3fc6c082 bellard
        }
9869 3fc6c082 bellard
    }
9870 ee4e83ed j_mayer
    if (best != -1)
9871 ee4e83ed j_mayer
        ret = &ppc_defs[best];
9872 ee4e83ed j_mayer
9873 ee4e83ed j_mayer
    return ret;
9874 3fc6c082 bellard
}
9875 3fc6c082 bellard
9876 ee4e83ed j_mayer
#include <ctype.h>
9877 3fc6c082 bellard
9878 c227f099 Anthony Liguori
const ppc_def_t *cpu_ppc_find_by_name (const char *name)
9879 ee4e83ed j_mayer
{
9880 c227f099 Anthony Liguori
    const ppc_def_t *ret;
9881 b55266b5 blueswir1
    const char *p;
9882 ee4e83ed j_mayer
    int i, max, len;
9883 ee4e83ed j_mayer
9884 ee4e83ed j_mayer
    /* Check if the given name is a PVR */
9885 ee4e83ed j_mayer
    len = strlen(name);
9886 ee4e83ed j_mayer
    if (len == 10 && name[0] == '0' && name[1] == 'x') {
9887 ee4e83ed j_mayer
        p = name + 2;
9888 ee4e83ed j_mayer
        goto check_pvr;
9889 ee4e83ed j_mayer
    } else if (len == 8) {
9890 ee4e83ed j_mayer
        p = name;
9891 ee4e83ed j_mayer
    check_pvr:
9892 ee4e83ed j_mayer
        for (i = 0; i < 8; i++) {
9893 cd390083 blueswir1
            if (!qemu_isxdigit(*p++))
9894 ee4e83ed j_mayer
                break;
9895 ee4e83ed j_mayer
        }
9896 ee4e83ed j_mayer
        if (i == 8)
9897 ee4e83ed j_mayer
            return ppc_find_by_pvr(strtoul(name, NULL, 16));
9898 ee4e83ed j_mayer
    }
9899 ee4e83ed j_mayer
    ret = NULL;
9900 b1503cda malc
    max = ARRAY_SIZE(ppc_defs);
9901 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
9902 ee4e83ed j_mayer
        if (strcasecmp(name, ppc_defs[i].name) == 0) {
9903 ee4e83ed j_mayer
            ret = &ppc_defs[i];
9904 ee4e83ed j_mayer
            break;
9905 3fc6c082 bellard
        }
9906 3fc6c082 bellard
    }
9907 ee4e83ed j_mayer
9908 ee4e83ed j_mayer
    return ret;
9909 3fc6c082 bellard
}
9910 3fc6c082 bellard
9911 9a78eead Stefan Weil
void ppc_cpu_list (FILE *f, fprintf_function cpu_fprintf)
9912 3fc6c082 bellard
{
9913 068abdc8 j_mayer
    int i, max;
9914 3fc6c082 bellard
9915 b1503cda malc
    max = ARRAY_SIZE(ppc_defs);
9916 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
9917 a750fc0b j_mayer
        (*cpu_fprintf)(f, "PowerPC %-16s PVR %08x\n",
9918 a750fc0b j_mayer
                       ppc_defs[i].name, ppc_defs[i].pvr);
9919 3fc6c082 bellard
    }
9920 3fc6c082 bellard
}