Statistics
| Branch: | Revision:

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

History | View | Annotate | Download (428.8 kB)

1 3fc6c082 bellard
/*
2 3fc6c082 bellard
 *  PowerPC CPU initialization for qemu.
3 5fafdf24 ths
 *
4 76a66253 j_mayer
 *  Copyright (c) 2003-2007 Jocelyn Mayer
5 f7aa5583 Varun Sethi
 *  Copyright 2011 Freescale Semiconductor, Inc.
6 3fc6c082 bellard
 *
7 3fc6c082 bellard
 * This library is free software; you can redistribute it and/or
8 3fc6c082 bellard
 * modify it under the terms of the GNU Lesser General Public
9 3fc6c082 bellard
 * License as published by the Free Software Foundation; either
10 3fc6c082 bellard
 * version 2 of the License, or (at your option) any later version.
11 3fc6c082 bellard
 *
12 3fc6c082 bellard
 * This library is distributed in the hope that it will be useful,
13 3fc6c082 bellard
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 3fc6c082 bellard
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15 3fc6c082 bellard
 * Lesser General Public License for more details.
16 3fc6c082 bellard
 *
17 3fc6c082 bellard
 * You should have received a copy of the GNU Lesser General Public
18 8167ee88 Blue Swirl
 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
19 3fc6c082 bellard
 */
20 3fc6c082 bellard
21 3fc6c082 bellard
/* A lot of PowerPC definition have been included here.
22 3fc6c082 bellard
 * Most of them are not usable for now but have been kept
23 3fc6c082 bellard
 * inside "#if defined(TODO) ... #endif" statements to make tests easier.
24 3fc6c082 bellard
 */
25 3fc6c082 bellard
26 237c0af0 j_mayer
#include "dis-asm.h"
27 4e47ea67 aurel32
#include "gdbstub.h"
28 a1e98583 David Gibson
#include <kvm.h>
29 a1e98583 David Gibson
#include "kvm_ppc.h"
30 237c0af0 j_mayer
31 3fc6c082 bellard
//#define PPC_DUMP_CPU
32 3fc6c082 bellard
//#define PPC_DEBUG_SPR
33 80d11f44 j_mayer
//#define PPC_DUMP_SPR_ACCESSES
34 80d11f44 j_mayer
#if defined(CONFIG_USER_ONLY)
35 80d11f44 j_mayer
#define TODO_USER_ONLY 1
36 80d11f44 j_mayer
#endif
37 3fc6c082 bellard
38 e9df014c j_mayer
/* For user-mode emulation, we don't emulate any IRQ controller */
39 e9df014c j_mayer
#if defined(CONFIG_USER_ONLY)
40 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
41 a750fc0b j_mayer
static inline void glue(glue(ppc, name),_irq_init) (CPUPPCState *env)         \
42 a750fc0b j_mayer
{                                                                             \
43 e9df014c j_mayer
}
44 e9df014c j_mayer
#else
45 a750fc0b j_mayer
#define PPC_IRQ_INIT_FN(name)                                                 \
46 e9df014c j_mayer
void glue(glue(ppc, name),_irq_init) (CPUPPCState *env);
47 e9df014c j_mayer
#endif
48 a750fc0b j_mayer
49 4e290a0b j_mayer
PPC_IRQ_INIT_FN(40x);
50 e9df014c j_mayer
PPC_IRQ_INIT_FN(6xx);
51 d0dfae6e j_mayer
PPC_IRQ_INIT_FN(970);
52 9d52e907 David Gibson
PPC_IRQ_INIT_FN(POWER7);
53 9fdc60bf aurel32
PPC_IRQ_INIT_FN(e500);
54 e9df014c j_mayer
55 3fc6c082 bellard
/* Generic callbacks:
56 3fc6c082 bellard
 * do nothing but store/retrieve spr value
57 3fc6c082 bellard
 */
58 45d827d2 aurel32
static void spr_read_generic (void *opaque, int gprn, int sprn)
59 a496775f j_mayer
{
60 45d827d2 aurel32
    gen_load_spr(cpu_gpr[gprn], sprn);
61 45d827d2 aurel32
#ifdef PPC_DUMP_SPR_ACCESSES
62 45d827d2 aurel32
    {
63 1ff7854e Stefan Weil
        TCGv_i32 t0 = tcg_const_i32(sprn);
64 45d827d2 aurel32
        gen_helper_load_dump_spr(t0);
65 45d827d2 aurel32
        tcg_temp_free_i32(t0);
66 45d827d2 aurel32
    }
67 45d827d2 aurel32
#endif
68 a496775f j_mayer
}
69 a496775f j_mayer
70 45d827d2 aurel32
static void spr_write_generic (void *opaque, int sprn, int gprn)
71 a496775f j_mayer
{
72 45d827d2 aurel32
    gen_store_spr(sprn, cpu_gpr[gprn]);
73 45d827d2 aurel32
#ifdef PPC_DUMP_SPR_ACCESSES
74 45d827d2 aurel32
    {
75 1ff7854e Stefan Weil
        TCGv_i32 t0 = tcg_const_i32(sprn);
76 45d827d2 aurel32
        gen_helper_store_dump_spr(t0);
77 45d827d2 aurel32
        tcg_temp_free_i32(t0);
78 45d827d2 aurel32
    }
79 04f20795 j_mayer
#endif
80 45d827d2 aurel32
}
81 a496775f j_mayer
82 a496775f j_mayer
#if !defined(CONFIG_USER_ONLY)
83 45d827d2 aurel32
static void spr_write_clear (void *opaque, int sprn, int gprn)
84 a496775f j_mayer
{
85 45d827d2 aurel32
    TCGv t0 = tcg_temp_new();
86 45d827d2 aurel32
    TCGv t1 = tcg_temp_new();
87 45d827d2 aurel32
    gen_load_spr(t0, sprn);
88 45d827d2 aurel32
    tcg_gen_neg_tl(t1, cpu_gpr[gprn]);
89 45d827d2 aurel32
    tcg_gen_and_tl(t0, t0, t1);
90 45d827d2 aurel32
    gen_store_spr(sprn, t0);
91 45d827d2 aurel32
    tcg_temp_free(t0);
92 45d827d2 aurel32
    tcg_temp_free(t1);
93 a496775f j_mayer
}
94 a496775f j_mayer
#endif
95 a496775f j_mayer
96 76a66253 j_mayer
/* SPR common to all PowerPC */
97 3fc6c082 bellard
/* XER */
98 45d827d2 aurel32
static void spr_read_xer (void *opaque, int gprn, int sprn)
99 3fc6c082 bellard
{
100 45d827d2 aurel32
    tcg_gen_mov_tl(cpu_gpr[gprn], cpu_xer);
101 3fc6c082 bellard
}
102 3fc6c082 bellard
103 45d827d2 aurel32
static void spr_write_xer (void *opaque, int sprn, int gprn)
104 3fc6c082 bellard
{
105 45d827d2 aurel32
    tcg_gen_mov_tl(cpu_xer, cpu_gpr[gprn]);
106 3fc6c082 bellard
}
107 3fc6c082 bellard
108 3fc6c082 bellard
/* LR */
109 45d827d2 aurel32
static void spr_read_lr (void *opaque, int gprn, int sprn)
110 3fc6c082 bellard
{
111 45d827d2 aurel32
    tcg_gen_mov_tl(cpu_gpr[gprn], cpu_lr);
112 3fc6c082 bellard
}
113 3fc6c082 bellard
114 45d827d2 aurel32
static void spr_write_lr (void *opaque, int sprn, int gprn)
115 3fc6c082 bellard
{
116 45d827d2 aurel32
    tcg_gen_mov_tl(cpu_lr, cpu_gpr[gprn]);
117 3fc6c082 bellard
}
118 3fc6c082 bellard
119 697ab892 David Gibson
/* CFAR */
120 697ab892 David Gibson
#if defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY)
121 697ab892 David Gibson
static void spr_read_cfar (void *opaque, int gprn, int sprn)
122 697ab892 David Gibson
{
123 697ab892 David Gibson
    tcg_gen_mov_tl(cpu_gpr[gprn], cpu_cfar);
124 697ab892 David Gibson
}
125 697ab892 David Gibson
126 697ab892 David Gibson
static void spr_write_cfar (void *opaque, int sprn, int gprn)
127 697ab892 David Gibson
{
128 697ab892 David Gibson
    tcg_gen_mov_tl(cpu_cfar, cpu_gpr[gprn]);
129 697ab892 David Gibson
}
130 697ab892 David Gibson
#endif /* defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY) */
131 697ab892 David Gibson
132 3fc6c082 bellard
/* CTR */
133 45d827d2 aurel32
static void spr_read_ctr (void *opaque, int gprn, int sprn)
134 3fc6c082 bellard
{
135 45d827d2 aurel32
    tcg_gen_mov_tl(cpu_gpr[gprn], cpu_ctr);
136 3fc6c082 bellard
}
137 3fc6c082 bellard
138 45d827d2 aurel32
static void spr_write_ctr (void *opaque, int sprn, int gprn)
139 3fc6c082 bellard
{
140 45d827d2 aurel32
    tcg_gen_mov_tl(cpu_ctr, cpu_gpr[gprn]);
141 3fc6c082 bellard
}
142 3fc6c082 bellard
143 3fc6c082 bellard
/* User read access to SPR */
144 3fc6c082 bellard
/* USPRx */
145 3fc6c082 bellard
/* UMMCRx */
146 3fc6c082 bellard
/* UPMCx */
147 3fc6c082 bellard
/* USIA */
148 3fc6c082 bellard
/* UDECR */
149 45d827d2 aurel32
static void spr_read_ureg (void *opaque, int gprn, int sprn)
150 3fc6c082 bellard
{
151 45d827d2 aurel32
    gen_load_spr(cpu_gpr[gprn], sprn + 0x10);
152 3fc6c082 bellard
}
153 3fc6c082 bellard
154 76a66253 j_mayer
/* SPR common to all non-embedded PowerPC */
155 3fc6c082 bellard
/* DECR */
156 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
157 45d827d2 aurel32
static void spr_read_decr (void *opaque, int gprn, int sprn)
158 3fc6c082 bellard
{
159 630ecca0 Tristan Gingold
    if (use_icount) {
160 630ecca0 Tristan Gingold
        gen_io_start();
161 630ecca0 Tristan Gingold
    }
162 45d827d2 aurel32
    gen_helper_load_decr(cpu_gpr[gprn]);
163 630ecca0 Tristan Gingold
    if (use_icount) {
164 630ecca0 Tristan Gingold
        gen_io_end();
165 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
166 630ecca0 Tristan Gingold
    }
167 3fc6c082 bellard
}
168 3fc6c082 bellard
169 45d827d2 aurel32
static void spr_write_decr (void *opaque, int sprn, int gprn)
170 3fc6c082 bellard
{
171 630ecca0 Tristan Gingold
    if (use_icount) {
172 630ecca0 Tristan Gingold
        gen_io_start();
173 630ecca0 Tristan Gingold
    }
174 45d827d2 aurel32
    gen_helper_store_decr(cpu_gpr[gprn]);
175 630ecca0 Tristan Gingold
    if (use_icount) {
176 630ecca0 Tristan Gingold
        gen_io_end();
177 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
178 630ecca0 Tristan Gingold
    }
179 3fc6c082 bellard
}
180 76a66253 j_mayer
#endif
181 3fc6c082 bellard
182 76a66253 j_mayer
/* SPR common to all non-embedded PowerPC, except 601 */
183 3fc6c082 bellard
/* Time base */
184 45d827d2 aurel32
static void spr_read_tbl (void *opaque, int gprn, int sprn)
185 3fc6c082 bellard
{
186 630ecca0 Tristan Gingold
    if (use_icount) {
187 630ecca0 Tristan Gingold
        gen_io_start();
188 630ecca0 Tristan Gingold
    }
189 45d827d2 aurel32
    gen_helper_load_tbl(cpu_gpr[gprn]);
190 630ecca0 Tristan Gingold
    if (use_icount) {
191 630ecca0 Tristan Gingold
        gen_io_end();
192 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
193 630ecca0 Tristan Gingold
    }
194 3fc6c082 bellard
}
195 3fc6c082 bellard
196 45d827d2 aurel32
static void spr_read_tbu (void *opaque, int gprn, int sprn)
197 3fc6c082 bellard
{
198 630ecca0 Tristan Gingold
    if (use_icount) {
199 630ecca0 Tristan Gingold
        gen_io_start();
200 630ecca0 Tristan Gingold
    }
201 45d827d2 aurel32
    gen_helper_load_tbu(cpu_gpr[gprn]);
202 630ecca0 Tristan Gingold
    if (use_icount) {
203 630ecca0 Tristan Gingold
        gen_io_end();
204 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
205 630ecca0 Tristan Gingold
    }
206 3fc6c082 bellard
}
207 3fc6c082 bellard
208 a062e36c j_mayer
__attribute__ (( unused ))
209 45d827d2 aurel32
static void spr_read_atbl (void *opaque, int gprn, int sprn)
210 a062e36c j_mayer
{
211 45d827d2 aurel32
    gen_helper_load_atbl(cpu_gpr[gprn]);
212 a062e36c j_mayer
}
213 a062e36c j_mayer
214 a062e36c j_mayer
__attribute__ (( unused ))
215 45d827d2 aurel32
static void spr_read_atbu (void *opaque, int gprn, int sprn)
216 a062e36c j_mayer
{
217 45d827d2 aurel32
    gen_helper_load_atbu(cpu_gpr[gprn]);
218 a062e36c j_mayer
}
219 a062e36c j_mayer
220 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
221 45d827d2 aurel32
static void spr_write_tbl (void *opaque, int sprn, int gprn)
222 3fc6c082 bellard
{
223 630ecca0 Tristan Gingold
    if (use_icount) {
224 630ecca0 Tristan Gingold
        gen_io_start();
225 630ecca0 Tristan Gingold
    }
226 45d827d2 aurel32
    gen_helper_store_tbl(cpu_gpr[gprn]);
227 630ecca0 Tristan Gingold
    if (use_icount) {
228 630ecca0 Tristan Gingold
        gen_io_end();
229 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
230 630ecca0 Tristan Gingold
    }
231 3fc6c082 bellard
}
232 3fc6c082 bellard
233 45d827d2 aurel32
static void spr_write_tbu (void *opaque, int sprn, int gprn)
234 3fc6c082 bellard
{
235 630ecca0 Tristan Gingold
    if (use_icount) {
236 630ecca0 Tristan Gingold
        gen_io_start();
237 630ecca0 Tristan Gingold
    }
238 45d827d2 aurel32
    gen_helper_store_tbu(cpu_gpr[gprn]);
239 630ecca0 Tristan Gingold
    if (use_icount) {
240 630ecca0 Tristan Gingold
        gen_io_end();
241 630ecca0 Tristan Gingold
        gen_stop_exception(opaque);
242 630ecca0 Tristan Gingold
    }
243 3fc6c082 bellard
}
244 a062e36c j_mayer
245 a062e36c j_mayer
__attribute__ (( unused ))
246 45d827d2 aurel32
static void spr_write_atbl (void *opaque, int sprn, int gprn)
247 a062e36c j_mayer
{
248 45d827d2 aurel32
    gen_helper_store_atbl(cpu_gpr[gprn]);
249 a062e36c j_mayer
}
250 a062e36c j_mayer
251 a062e36c j_mayer
__attribute__ (( unused ))
252 45d827d2 aurel32
static void spr_write_atbu (void *opaque, int sprn, int gprn)
253 a062e36c j_mayer
{
254 45d827d2 aurel32
    gen_helper_store_atbu(cpu_gpr[gprn]);
255 a062e36c j_mayer
}
256 3a7f009a David Gibson
257 3a7f009a David Gibson
#if defined(TARGET_PPC64)
258 3a7f009a David Gibson
__attribute__ (( unused ))
259 3a7f009a David Gibson
static void spr_read_purr (void *opaque, int gprn, int sprn)
260 3a7f009a David Gibson
{
261 3a7f009a David Gibson
    gen_helper_load_purr(cpu_gpr[gprn]);
262 3a7f009a David Gibson
}
263 3a7f009a David Gibson
#endif
264 76a66253 j_mayer
#endif
265 3fc6c082 bellard
266 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
267 3fc6c082 bellard
/* IBAT0U...IBAT0U */
268 3fc6c082 bellard
/* IBAT0L...IBAT7L */
269 45d827d2 aurel32
static void spr_read_ibat (void *opaque, int gprn, int sprn)
270 3fc6c082 bellard
{
271 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, IBAT[sprn & 1][(sprn - SPR_IBAT0U) / 2]));
272 3fc6c082 bellard
}
273 3fc6c082 bellard
274 45d827d2 aurel32
static void spr_read_ibat_h (void *opaque, int gprn, int sprn)
275 3fc6c082 bellard
{
276 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, IBAT[sprn & 1][(sprn - SPR_IBAT4U) / 2]));
277 3fc6c082 bellard
}
278 3fc6c082 bellard
279 45d827d2 aurel32
static void spr_write_ibatu (void *opaque, int sprn, int gprn)
280 3fc6c082 bellard
{
281 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
282 45d827d2 aurel32
    gen_helper_store_ibatu(t0, cpu_gpr[gprn]);
283 45d827d2 aurel32
    tcg_temp_free_i32(t0);
284 3fc6c082 bellard
}
285 3fc6c082 bellard
286 45d827d2 aurel32
static void spr_write_ibatu_h (void *opaque, int sprn, int gprn)
287 3fc6c082 bellard
{
288 8daf1781 Thomas Monjalon
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_IBAT4U) / 2) + 4);
289 45d827d2 aurel32
    gen_helper_store_ibatu(t0, cpu_gpr[gprn]);
290 45d827d2 aurel32
    tcg_temp_free_i32(t0);
291 3fc6c082 bellard
}
292 3fc6c082 bellard
293 45d827d2 aurel32
static void spr_write_ibatl (void *opaque, int sprn, int gprn)
294 3fc6c082 bellard
{
295 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0L) / 2);
296 45d827d2 aurel32
    gen_helper_store_ibatl(t0, cpu_gpr[gprn]);
297 45d827d2 aurel32
    tcg_temp_free_i32(t0);
298 3fc6c082 bellard
}
299 3fc6c082 bellard
300 45d827d2 aurel32
static void spr_write_ibatl_h (void *opaque, int sprn, int gprn)
301 3fc6c082 bellard
{
302 8daf1781 Thomas Monjalon
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_IBAT4L) / 2) + 4);
303 45d827d2 aurel32
    gen_helper_store_ibatl(t0, cpu_gpr[gprn]);
304 45d827d2 aurel32
    tcg_temp_free_i32(t0);
305 3fc6c082 bellard
}
306 3fc6c082 bellard
307 3fc6c082 bellard
/* DBAT0U...DBAT7U */
308 3fc6c082 bellard
/* DBAT0L...DBAT7L */
309 45d827d2 aurel32
static void spr_read_dbat (void *opaque, int gprn, int sprn)
310 3fc6c082 bellard
{
311 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, DBAT[sprn & 1][(sprn - SPR_DBAT0U) / 2]));
312 3fc6c082 bellard
}
313 3fc6c082 bellard
314 45d827d2 aurel32
static void spr_read_dbat_h (void *opaque, int gprn, int sprn)
315 3fc6c082 bellard
{
316 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, DBAT[sprn & 1][((sprn - SPR_DBAT4U) / 2) + 4]));
317 3fc6c082 bellard
}
318 3fc6c082 bellard
319 45d827d2 aurel32
static void spr_write_dbatu (void *opaque, int sprn, int gprn)
320 3fc6c082 bellard
{
321 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_DBAT0U) / 2);
322 45d827d2 aurel32
    gen_helper_store_dbatu(t0, cpu_gpr[gprn]);
323 45d827d2 aurel32
    tcg_temp_free_i32(t0);
324 3fc6c082 bellard
}
325 3fc6c082 bellard
326 45d827d2 aurel32
static void spr_write_dbatu_h (void *opaque, int sprn, int gprn)
327 3fc6c082 bellard
{
328 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_DBAT4U) / 2) + 4);
329 45d827d2 aurel32
    gen_helper_store_dbatu(t0, cpu_gpr[gprn]);
330 45d827d2 aurel32
    tcg_temp_free_i32(t0);
331 3fc6c082 bellard
}
332 3fc6c082 bellard
333 45d827d2 aurel32
static void spr_write_dbatl (void *opaque, int sprn, int gprn)
334 3fc6c082 bellard
{
335 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_DBAT0L) / 2);
336 45d827d2 aurel32
    gen_helper_store_dbatl(t0, cpu_gpr[gprn]);
337 45d827d2 aurel32
    tcg_temp_free_i32(t0);
338 3fc6c082 bellard
}
339 3fc6c082 bellard
340 45d827d2 aurel32
static void spr_write_dbatl_h (void *opaque, int sprn, int gprn)
341 3fc6c082 bellard
{
342 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32(((sprn - SPR_DBAT4L) / 2) + 4);
343 45d827d2 aurel32
    gen_helper_store_dbatl(t0, cpu_gpr[gprn]);
344 45d827d2 aurel32
    tcg_temp_free_i32(t0);
345 3fc6c082 bellard
}
346 3fc6c082 bellard
347 3fc6c082 bellard
/* SDR1 */
348 45d827d2 aurel32
static void spr_write_sdr1 (void *opaque, int sprn, int gprn)
349 3fc6c082 bellard
{
350 45d827d2 aurel32
    gen_helper_store_sdr1(cpu_gpr[gprn]);
351 3fc6c082 bellard
}
352 3fc6c082 bellard
353 76a66253 j_mayer
/* 64 bits PowerPC specific SPRs */
354 76a66253 j_mayer
/* ASR */
355 578bb252 j_mayer
#if defined(TARGET_PPC64)
356 2adab7d6 blueswir1
static void spr_read_hior (void *opaque, int gprn, int sprn)
357 2adab7d6 blueswir1
{
358 2adab7d6 blueswir1
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, excp_prefix));
359 2adab7d6 blueswir1
}
360 2adab7d6 blueswir1
361 2adab7d6 blueswir1
static void spr_write_hior (void *opaque, int sprn, int gprn)
362 2adab7d6 blueswir1
{
363 2adab7d6 blueswir1
    TCGv t0 = tcg_temp_new();
364 2adab7d6 blueswir1
    tcg_gen_andi_tl(t0, cpu_gpr[gprn], 0x3FFFFF00000ULL);
365 2adab7d6 blueswir1
    tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, excp_prefix));
366 2adab7d6 blueswir1
    tcg_temp_free(t0);
367 2adab7d6 blueswir1
}
368 2adab7d6 blueswir1
369 45d827d2 aurel32
static void spr_read_asr (void *opaque, int gprn, int sprn)
370 76a66253 j_mayer
{
371 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, asr));
372 76a66253 j_mayer
}
373 76a66253 j_mayer
374 45d827d2 aurel32
static void spr_write_asr (void *opaque, int sprn, int gprn)
375 76a66253 j_mayer
{
376 45d827d2 aurel32
    gen_helper_store_asr(cpu_gpr[gprn]);
377 76a66253 j_mayer
}
378 76a66253 j_mayer
#endif
379 a750fc0b j_mayer
#endif
380 76a66253 j_mayer
381 76a66253 j_mayer
/* PowerPC 601 specific registers */
382 76a66253 j_mayer
/* RTC */
383 45d827d2 aurel32
static void spr_read_601_rtcl (void *opaque, int gprn, int sprn)
384 76a66253 j_mayer
{
385 45d827d2 aurel32
    gen_helper_load_601_rtcl(cpu_gpr[gprn]);
386 76a66253 j_mayer
}
387 76a66253 j_mayer
388 45d827d2 aurel32
static void spr_read_601_rtcu (void *opaque, int gprn, int sprn)
389 76a66253 j_mayer
{
390 45d827d2 aurel32
    gen_helper_load_601_rtcu(cpu_gpr[gprn]);
391 76a66253 j_mayer
}
392 76a66253 j_mayer
393 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
394 45d827d2 aurel32
static void spr_write_601_rtcu (void *opaque, int sprn, int gprn)
395 76a66253 j_mayer
{
396 45d827d2 aurel32
    gen_helper_store_601_rtcu(cpu_gpr[gprn]);
397 76a66253 j_mayer
}
398 76a66253 j_mayer
399 45d827d2 aurel32
static void spr_write_601_rtcl (void *opaque, int sprn, int gprn)
400 76a66253 j_mayer
{
401 45d827d2 aurel32
    gen_helper_store_601_rtcl(cpu_gpr[gprn]);
402 76a66253 j_mayer
}
403 056401ea j_mayer
404 45d827d2 aurel32
static void spr_write_hid0_601 (void *opaque, int sprn, int gprn)
405 056401ea j_mayer
{
406 056401ea j_mayer
    DisasContext *ctx = opaque;
407 056401ea j_mayer
408 45d827d2 aurel32
    gen_helper_store_hid0_601(cpu_gpr[gprn]);
409 056401ea j_mayer
    /* Must stop the translation as endianness may have changed */
410 e06fcd75 aurel32
    gen_stop_exception(ctx);
411 056401ea j_mayer
}
412 76a66253 j_mayer
#endif
413 76a66253 j_mayer
414 76a66253 j_mayer
/* Unified bats */
415 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
416 45d827d2 aurel32
static void spr_read_601_ubat (void *opaque, int gprn, int sprn)
417 76a66253 j_mayer
{
418 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, IBAT[sprn & 1][(sprn - SPR_IBAT0U) / 2]));
419 76a66253 j_mayer
}
420 76a66253 j_mayer
421 45d827d2 aurel32
static void spr_write_601_ubatu (void *opaque, int sprn, int gprn)
422 76a66253 j_mayer
{
423 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
424 45d827d2 aurel32
    gen_helper_store_601_batl(t0, cpu_gpr[gprn]);
425 45d827d2 aurel32
    tcg_temp_free_i32(t0);
426 76a66253 j_mayer
}
427 76a66253 j_mayer
428 45d827d2 aurel32
static void spr_write_601_ubatl (void *opaque, int sprn, int gprn)
429 76a66253 j_mayer
{
430 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32((sprn - SPR_IBAT0U) / 2);
431 45d827d2 aurel32
    gen_helper_store_601_batu(t0, cpu_gpr[gprn]);
432 45d827d2 aurel32
    tcg_temp_free_i32(t0);
433 76a66253 j_mayer
}
434 76a66253 j_mayer
#endif
435 76a66253 j_mayer
436 76a66253 j_mayer
/* PowerPC 40x specific registers */
437 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
438 45d827d2 aurel32
static void spr_read_40x_pit (void *opaque, int gprn, int sprn)
439 76a66253 j_mayer
{
440 45d827d2 aurel32
    gen_helper_load_40x_pit(cpu_gpr[gprn]);
441 76a66253 j_mayer
}
442 76a66253 j_mayer
443 45d827d2 aurel32
static void spr_write_40x_pit (void *opaque, int sprn, int gprn)
444 76a66253 j_mayer
{
445 45d827d2 aurel32
    gen_helper_store_40x_pit(cpu_gpr[gprn]);
446 76a66253 j_mayer
}
447 76a66253 j_mayer
448 45d827d2 aurel32
static void spr_write_40x_dbcr0 (void *opaque, int sprn, int gprn)
449 8ecc7913 j_mayer
{
450 8ecc7913 j_mayer
    DisasContext *ctx = opaque;
451 8ecc7913 j_mayer
452 45d827d2 aurel32
    gen_helper_store_40x_dbcr0(cpu_gpr[gprn]);
453 8ecc7913 j_mayer
    /* We must stop translation as we may have rebooted */
454 e06fcd75 aurel32
    gen_stop_exception(ctx);
455 8ecc7913 j_mayer
}
456 8ecc7913 j_mayer
457 45d827d2 aurel32
static void spr_write_40x_sler (void *opaque, int sprn, int gprn)
458 c294fc58 j_mayer
{
459 45d827d2 aurel32
    gen_helper_store_40x_sler(cpu_gpr[gprn]);
460 c294fc58 j_mayer
}
461 c294fc58 j_mayer
462 45d827d2 aurel32
static void spr_write_booke_tcr (void *opaque, int sprn, int gprn)
463 76a66253 j_mayer
{
464 45d827d2 aurel32
    gen_helper_store_booke_tcr(cpu_gpr[gprn]);
465 76a66253 j_mayer
}
466 76a66253 j_mayer
467 45d827d2 aurel32
static void spr_write_booke_tsr (void *opaque, int sprn, int gprn)
468 76a66253 j_mayer
{
469 45d827d2 aurel32
    gen_helper_store_booke_tsr(cpu_gpr[gprn]);
470 76a66253 j_mayer
}
471 76a66253 j_mayer
#endif
472 76a66253 j_mayer
473 76a66253 j_mayer
/* PowerPC 403 specific registers */
474 76a66253 j_mayer
/* PBL1 / PBU1 / PBL2 / PBU2 */
475 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
476 45d827d2 aurel32
static void spr_read_403_pbr (void *opaque, int gprn, int sprn)
477 76a66253 j_mayer
{
478 45d827d2 aurel32
    tcg_gen_ld_tl(cpu_gpr[gprn], cpu_env, offsetof(CPUState, pb[sprn - SPR_403_PBL1]));
479 76a66253 j_mayer
}
480 76a66253 j_mayer
481 45d827d2 aurel32
static void spr_write_403_pbr (void *opaque, int sprn, int gprn)
482 76a66253 j_mayer
{
483 45d827d2 aurel32
    TCGv_i32 t0 = tcg_const_i32(sprn - SPR_403_PBL1);
484 45d827d2 aurel32
    gen_helper_store_403_pbr(t0, cpu_gpr[gprn]);
485 45d827d2 aurel32
    tcg_temp_free_i32(t0);
486 76a66253 j_mayer
}
487 76a66253 j_mayer
488 45d827d2 aurel32
static void spr_write_pir (void *opaque, int sprn, int gprn)
489 3fc6c082 bellard
{
490 45d827d2 aurel32
    TCGv t0 = tcg_temp_new();
491 45d827d2 aurel32
    tcg_gen_andi_tl(t0, cpu_gpr[gprn], 0xF);
492 45d827d2 aurel32
    gen_store_spr(SPR_PIR, t0);
493 45d827d2 aurel32
    tcg_temp_free(t0);
494 3fc6c082 bellard
}
495 76a66253 j_mayer
#endif
496 3fc6c082 bellard
497 d34defbc aurel32
/* SPE specific registers */
498 d34defbc aurel32
static void spr_read_spefscr (void *opaque, int gprn, int sprn)
499 d34defbc aurel32
{
500 d34defbc aurel32
    TCGv_i32 t0 = tcg_temp_new_i32();
501 515e2f7e aurel32
    tcg_gen_ld_i32(t0, cpu_env, offsetof(CPUState, spe_fscr));
502 d34defbc aurel32
    tcg_gen_extu_i32_tl(cpu_gpr[gprn], t0);
503 d34defbc aurel32
    tcg_temp_free_i32(t0);
504 d34defbc aurel32
}
505 d34defbc aurel32
506 d34defbc aurel32
static void spr_write_spefscr (void *opaque, int sprn, int gprn)
507 d34defbc aurel32
{
508 d34defbc aurel32
    TCGv_i32 t0 = tcg_temp_new_i32();
509 d34defbc aurel32
    tcg_gen_trunc_tl_i32(t0, cpu_gpr[gprn]);
510 515e2f7e aurel32
    tcg_gen_st_i32(t0, cpu_env, offsetof(CPUState, spe_fscr));
511 d34defbc aurel32
    tcg_temp_free_i32(t0);
512 d34defbc aurel32
}
513 d34defbc aurel32
514 6f5d427d j_mayer
#if !defined(CONFIG_USER_ONLY)
515 6f5d427d j_mayer
/* Callback used to write the exception vector base */
516 45d827d2 aurel32
static void spr_write_excp_prefix (void *opaque, int sprn, int gprn)
517 6f5d427d j_mayer
{
518 45d827d2 aurel32
    TCGv t0 = tcg_temp_new();
519 45d827d2 aurel32
    tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, ivpr_mask));
520 45d827d2 aurel32
    tcg_gen_and_tl(t0, t0, cpu_gpr[gprn]);
521 45d827d2 aurel32
    tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, excp_prefix));
522 45d827d2 aurel32
    gen_store_spr(sprn, t0);
523 69bd5820 aurel32
    tcg_temp_free(t0);
524 6f5d427d j_mayer
}
525 6f5d427d j_mayer
526 45d827d2 aurel32
static void spr_write_excp_vector (void *opaque, int sprn, int gprn)
527 6f5d427d j_mayer
{
528 6f5d427d j_mayer
    DisasContext *ctx = opaque;
529 e9205258 Alexander Graf
    int sprn_offs;
530 6f5d427d j_mayer
531 6f5d427d j_mayer
    if (sprn >= SPR_BOOKE_IVOR0 && sprn <= SPR_BOOKE_IVOR15) {
532 e9205258 Alexander Graf
        sprn_offs = sprn - SPR_BOOKE_IVOR0;
533 6f5d427d j_mayer
    } else if (sprn >= SPR_BOOKE_IVOR32 && sprn <= SPR_BOOKE_IVOR37) {
534 e9205258 Alexander Graf
        sprn_offs = sprn - SPR_BOOKE_IVOR32 + 32;
535 e9205258 Alexander Graf
    } else if (sprn >= SPR_BOOKE_IVOR38 && sprn <= SPR_BOOKE_IVOR42) {
536 e9205258 Alexander Graf
        sprn_offs = sprn - SPR_BOOKE_IVOR38 + 38;
537 6f5d427d j_mayer
    } else {
538 6f5d427d j_mayer
        printf("Trying to write an unknown exception vector %d %03x\n",
539 6f5d427d j_mayer
               sprn, sprn);
540 e06fcd75 aurel32
        gen_inval_exception(ctx, POWERPC_EXCP_PRIV_REG);
541 e9205258 Alexander Graf
        return;
542 6f5d427d j_mayer
    }
543 e9205258 Alexander Graf
544 e9205258 Alexander Graf
    TCGv t0 = tcg_temp_new();
545 e9205258 Alexander Graf
    tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, ivor_mask));
546 e9205258 Alexander Graf
    tcg_gen_and_tl(t0, t0, cpu_gpr[gprn]);
547 e9205258 Alexander Graf
    tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, excp_vectors[sprn_offs]));
548 e9205258 Alexander Graf
    gen_store_spr(sprn, t0);
549 e9205258 Alexander Graf
    tcg_temp_free(t0);
550 6f5d427d j_mayer
}
551 6f5d427d j_mayer
#endif
552 6f5d427d j_mayer
553 cf8358c8 aurel32
static inline void vscr_init (CPUPPCState *env, uint32_t val)
554 cf8358c8 aurel32
{
555 cf8358c8 aurel32
    env->vscr = val;
556 cf8358c8 aurel32
    /* Altivec always uses round-to-nearest */
557 cf8358c8 aurel32
    set_float_rounding_mode(float_round_nearest_even, &env->vec_status);
558 cf8358c8 aurel32
    set_flush_to_zero(vscr_nj, &env->vec_status);
559 cf8358c8 aurel32
}
560 cf8358c8 aurel32
561 76a66253 j_mayer
#if defined(CONFIG_USER_ONLY)
562 76a66253 j_mayer
#define spr_register(env, num, name, uea_read, uea_write,                     \
563 76a66253 j_mayer
                     oea_read, oea_write, initial_value)                      \
564 76a66253 j_mayer
do {                                                                          \
565 76a66253 j_mayer
     _spr_register(env, num, name, uea_read, uea_write, initial_value);       \
566 76a66253 j_mayer
} while (0)
567 76a66253 j_mayer
static inline void _spr_register (CPUPPCState *env, int num,
568 b55266b5 blueswir1
                                  const char *name,
569 45d827d2 aurel32
                                  void (*uea_read)(void *opaque, int gprn, int sprn),
570 45d827d2 aurel32
                                  void (*uea_write)(void *opaque, int sprn, int gprn),
571 76a66253 j_mayer
                                  target_ulong initial_value)
572 76a66253 j_mayer
#else
573 3fc6c082 bellard
static inline void spr_register (CPUPPCState *env, int num,
574 b55266b5 blueswir1
                                 const char *name,
575 45d827d2 aurel32
                                 void (*uea_read)(void *opaque, int gprn, int sprn),
576 45d827d2 aurel32
                                 void (*uea_write)(void *opaque, int sprn, int gprn),
577 45d827d2 aurel32
                                 void (*oea_read)(void *opaque, int gprn, int sprn),
578 45d827d2 aurel32
                                 void (*oea_write)(void *opaque, int sprn, int gprn),
579 3fc6c082 bellard
                                 target_ulong initial_value)
580 76a66253 j_mayer
#endif
581 3fc6c082 bellard
{
582 c227f099 Anthony Liguori
    ppc_spr_t *spr;
583 3fc6c082 bellard
584 3fc6c082 bellard
    spr = &env->spr_cb[num];
585 3fc6c082 bellard
    if (spr->name != NULL ||env-> spr[num] != 0x00000000 ||
586 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
587 76a66253 j_mayer
        spr->oea_read != NULL || spr->oea_write != NULL ||
588 76a66253 j_mayer
#endif
589 76a66253 j_mayer
        spr->uea_read != NULL || spr->uea_write != NULL) {
590 3fc6c082 bellard
        printf("Error: Trying to register SPR %d (%03x) twice !\n", num, num);
591 3fc6c082 bellard
        exit(1);
592 3fc6c082 bellard
    }
593 3fc6c082 bellard
#if defined(PPC_DEBUG_SPR)
594 90e189ec Blue Swirl
    printf("*** register spr %d (%03x) %s val " TARGET_FMT_lx "\n", num, num,
595 90e189ec Blue Swirl
           name, initial_value);
596 3fc6c082 bellard
#endif
597 3fc6c082 bellard
    spr->name = name;
598 3fc6c082 bellard
    spr->uea_read = uea_read;
599 3fc6c082 bellard
    spr->uea_write = uea_write;
600 76a66253 j_mayer
#if !defined(CONFIG_USER_ONLY)
601 3fc6c082 bellard
    spr->oea_read = oea_read;
602 3fc6c082 bellard
    spr->oea_write = oea_write;
603 76a66253 j_mayer
#endif
604 3fc6c082 bellard
    env->spr[num] = initial_value;
605 3fc6c082 bellard
}
606 3fc6c082 bellard
607 3fc6c082 bellard
/* Generic PowerPC SPRs */
608 3fc6c082 bellard
static void gen_spr_generic (CPUPPCState *env)
609 3fc6c082 bellard
{
610 3fc6c082 bellard
    /* Integer processing */
611 3fc6c082 bellard
    spr_register(env, SPR_XER, "XER",
612 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
613 3fc6c082 bellard
                 &spr_read_xer, &spr_write_xer,
614 3fc6c082 bellard
                 0x00000000);
615 3fc6c082 bellard
    /* Branch contol */
616 3fc6c082 bellard
    spr_register(env, SPR_LR, "LR",
617 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
618 3fc6c082 bellard
                 &spr_read_lr, &spr_write_lr,
619 3fc6c082 bellard
                 0x00000000);
620 3fc6c082 bellard
    spr_register(env, SPR_CTR, "CTR",
621 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
622 3fc6c082 bellard
                 &spr_read_ctr, &spr_write_ctr,
623 3fc6c082 bellard
                 0x00000000);
624 3fc6c082 bellard
    /* Interrupt processing */
625 3fc6c082 bellard
    spr_register(env, SPR_SRR0, "SRR0",
626 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
627 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
628 3fc6c082 bellard
                 0x00000000);
629 3fc6c082 bellard
    spr_register(env, SPR_SRR1, "SRR1",
630 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
631 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
632 3fc6c082 bellard
                 0x00000000);
633 3fc6c082 bellard
    /* Processor control */
634 3fc6c082 bellard
    spr_register(env, SPR_SPRG0, "SPRG0",
635 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
636 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
637 3fc6c082 bellard
                 0x00000000);
638 3fc6c082 bellard
    spr_register(env, SPR_SPRG1, "SPRG1",
639 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
640 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
641 3fc6c082 bellard
                 0x00000000);
642 3fc6c082 bellard
    spr_register(env, SPR_SPRG2, "SPRG2",
643 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
644 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
645 3fc6c082 bellard
                 0x00000000);
646 3fc6c082 bellard
    spr_register(env, SPR_SPRG3, "SPRG3",
647 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
648 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
649 3fc6c082 bellard
                 0x00000000);
650 3fc6c082 bellard
}
651 3fc6c082 bellard
652 3fc6c082 bellard
/* SPR common to all non-embedded PowerPC, including 601 */
653 3fc6c082 bellard
static void gen_spr_ne_601 (CPUPPCState *env)
654 3fc6c082 bellard
{
655 3fc6c082 bellard
    /* Exception processing */
656 3fc6c082 bellard
    spr_register(env, SPR_DSISR, "DSISR",
657 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
658 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
659 3fc6c082 bellard
                 0x00000000);
660 3fc6c082 bellard
    spr_register(env, SPR_DAR, "DAR",
661 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
662 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
663 3fc6c082 bellard
                 0x00000000);
664 3fc6c082 bellard
    /* Timer */
665 3fc6c082 bellard
    spr_register(env, SPR_DECR, "DECR",
666 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
667 3fc6c082 bellard
                 &spr_read_decr, &spr_write_decr,
668 3fc6c082 bellard
                 0x00000000);
669 3fc6c082 bellard
    /* Memory management */
670 3fc6c082 bellard
    spr_register(env, SPR_SDR1, "SDR1",
671 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
672 bb593904 David Gibson
                 &spr_read_generic, &spr_write_sdr1,
673 3fc6c082 bellard
                 0x00000000);
674 3fc6c082 bellard
}
675 3fc6c082 bellard
676 3fc6c082 bellard
/* BATs 0-3 */
677 3fc6c082 bellard
static void gen_low_BATs (CPUPPCState *env)
678 3fc6c082 bellard
{
679 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
680 3fc6c082 bellard
    spr_register(env, SPR_IBAT0U, "IBAT0U",
681 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
682 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
683 3fc6c082 bellard
                 0x00000000);
684 3fc6c082 bellard
    spr_register(env, SPR_IBAT0L, "IBAT0L",
685 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
686 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
687 3fc6c082 bellard
                 0x00000000);
688 3fc6c082 bellard
    spr_register(env, SPR_IBAT1U, "IBAT1U",
689 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
690 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
691 3fc6c082 bellard
                 0x00000000);
692 3fc6c082 bellard
    spr_register(env, SPR_IBAT1L, "IBAT1L",
693 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
694 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
695 3fc6c082 bellard
                 0x00000000);
696 3fc6c082 bellard
    spr_register(env, SPR_IBAT2U, "IBAT2U",
697 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
698 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
699 3fc6c082 bellard
                 0x00000000);
700 3fc6c082 bellard
    spr_register(env, SPR_IBAT2L, "IBAT2L",
701 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
702 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
703 3fc6c082 bellard
                 0x00000000);
704 3fc6c082 bellard
    spr_register(env, SPR_IBAT3U, "IBAT3U",
705 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
706 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatu,
707 3fc6c082 bellard
                 0x00000000);
708 3fc6c082 bellard
    spr_register(env, SPR_IBAT3L, "IBAT3L",
709 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
710 3fc6c082 bellard
                 &spr_read_ibat, &spr_write_ibatl,
711 3fc6c082 bellard
                 0x00000000);
712 3fc6c082 bellard
    spr_register(env, SPR_DBAT0U, "DBAT0U",
713 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
714 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
715 3fc6c082 bellard
                 0x00000000);
716 3fc6c082 bellard
    spr_register(env, SPR_DBAT0L, "DBAT0L",
717 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
718 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
719 3fc6c082 bellard
                 0x00000000);
720 3fc6c082 bellard
    spr_register(env, SPR_DBAT1U, "DBAT1U",
721 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
722 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
723 3fc6c082 bellard
                 0x00000000);
724 3fc6c082 bellard
    spr_register(env, SPR_DBAT1L, "DBAT1L",
725 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
726 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
727 3fc6c082 bellard
                 0x00000000);
728 3fc6c082 bellard
    spr_register(env, SPR_DBAT2U, "DBAT2U",
729 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
730 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
731 3fc6c082 bellard
                 0x00000000);
732 3fc6c082 bellard
    spr_register(env, SPR_DBAT2L, "DBAT2L",
733 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
734 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
735 3fc6c082 bellard
                 0x00000000);
736 3fc6c082 bellard
    spr_register(env, SPR_DBAT3U, "DBAT3U",
737 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
738 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatu,
739 3fc6c082 bellard
                 0x00000000);
740 3fc6c082 bellard
    spr_register(env, SPR_DBAT3L, "DBAT3L",
741 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
742 3fc6c082 bellard
                 &spr_read_dbat, &spr_write_dbatl,
743 3fc6c082 bellard
                 0x00000000);
744 a750fc0b j_mayer
    env->nb_BATs += 4;
745 f2e63a42 j_mayer
#endif
746 3fc6c082 bellard
}
747 3fc6c082 bellard
748 3fc6c082 bellard
/* BATs 4-7 */
749 3fc6c082 bellard
static void gen_high_BATs (CPUPPCState *env)
750 3fc6c082 bellard
{
751 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
752 3fc6c082 bellard
    spr_register(env, SPR_IBAT4U, "IBAT4U",
753 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
754 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
755 3fc6c082 bellard
                 0x00000000);
756 3fc6c082 bellard
    spr_register(env, SPR_IBAT4L, "IBAT4L",
757 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
758 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
759 3fc6c082 bellard
                 0x00000000);
760 3fc6c082 bellard
    spr_register(env, SPR_IBAT5U, "IBAT5U",
761 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
762 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
763 3fc6c082 bellard
                 0x00000000);
764 3fc6c082 bellard
    spr_register(env, SPR_IBAT5L, "IBAT5L",
765 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
766 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
767 3fc6c082 bellard
                 0x00000000);
768 3fc6c082 bellard
    spr_register(env, SPR_IBAT6U, "IBAT6U",
769 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
770 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
771 3fc6c082 bellard
                 0x00000000);
772 3fc6c082 bellard
    spr_register(env, SPR_IBAT6L, "IBAT6L",
773 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
774 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
775 3fc6c082 bellard
                 0x00000000);
776 3fc6c082 bellard
    spr_register(env, SPR_IBAT7U, "IBAT7U",
777 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
778 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatu_h,
779 3fc6c082 bellard
                 0x00000000);
780 3fc6c082 bellard
    spr_register(env, SPR_IBAT7L, "IBAT7L",
781 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
782 3fc6c082 bellard
                 &spr_read_ibat_h, &spr_write_ibatl_h,
783 3fc6c082 bellard
                 0x00000000);
784 3fc6c082 bellard
    spr_register(env, SPR_DBAT4U, "DBAT4U",
785 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
786 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
787 3fc6c082 bellard
                 0x00000000);
788 3fc6c082 bellard
    spr_register(env, SPR_DBAT4L, "DBAT4L",
789 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
790 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
791 3fc6c082 bellard
                 0x00000000);
792 3fc6c082 bellard
    spr_register(env, SPR_DBAT5U, "DBAT5U",
793 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
794 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
795 3fc6c082 bellard
                 0x00000000);
796 3fc6c082 bellard
    spr_register(env, SPR_DBAT5L, "DBAT5L",
797 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
798 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
799 3fc6c082 bellard
                 0x00000000);
800 3fc6c082 bellard
    spr_register(env, SPR_DBAT6U, "DBAT6U",
801 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
802 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
803 3fc6c082 bellard
                 0x00000000);
804 3fc6c082 bellard
    spr_register(env, SPR_DBAT6L, "DBAT6L",
805 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
806 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
807 3fc6c082 bellard
                 0x00000000);
808 3fc6c082 bellard
    spr_register(env, SPR_DBAT7U, "DBAT7U",
809 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
810 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatu_h,
811 3fc6c082 bellard
                 0x00000000);
812 3fc6c082 bellard
    spr_register(env, SPR_DBAT7L, "DBAT7L",
813 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
814 3fc6c082 bellard
                 &spr_read_dbat_h, &spr_write_dbatl_h,
815 3fc6c082 bellard
                 0x00000000);
816 a750fc0b j_mayer
    env->nb_BATs += 4;
817 f2e63a42 j_mayer
#endif
818 3fc6c082 bellard
}
819 3fc6c082 bellard
820 3fc6c082 bellard
/* Generic PowerPC time base */
821 3fc6c082 bellard
static void gen_tbl (CPUPPCState *env)
822 3fc6c082 bellard
{
823 3fc6c082 bellard
    spr_register(env, SPR_VTBL,  "TBL",
824 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
825 3fc6c082 bellard
                 &spr_read_tbl, SPR_NOACCESS,
826 3fc6c082 bellard
                 0x00000000);
827 3fc6c082 bellard
    spr_register(env, SPR_TBL,   "TBL",
828 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbl, SPR_NOACCESS,
829 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbl, &spr_write_tbl,
830 3fc6c082 bellard
                 0x00000000);
831 3fc6c082 bellard
    spr_register(env, SPR_VTBU,  "TBU",
832 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
833 3fc6c082 bellard
                 &spr_read_tbu, SPR_NOACCESS,
834 3fc6c082 bellard
                 0x00000000);
835 3fc6c082 bellard
    spr_register(env, SPR_TBU,   "TBU",
836 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbu, SPR_NOACCESS,
837 de6a1dec Dmitry Ilyevsky
                 &spr_read_tbu, &spr_write_tbu,
838 3fc6c082 bellard
                 0x00000000);
839 3fc6c082 bellard
}
840 3fc6c082 bellard
841 76a66253 j_mayer
/* Softare table search registers */
842 76a66253 j_mayer
static void gen_6xx_7xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
843 76a66253 j_mayer
{
844 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
845 76a66253 j_mayer
    env->nb_tlb = nb_tlbs;
846 76a66253 j_mayer
    env->nb_ways = nb_ways;
847 76a66253 j_mayer
    env->id_tlbs = 1;
848 1c53accc Alexander Graf
    env->tlb_type = TLB_6XX;
849 76a66253 j_mayer
    spr_register(env, SPR_DMISS, "DMISS",
850 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
851 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
852 76a66253 j_mayer
                 0x00000000);
853 76a66253 j_mayer
    spr_register(env, SPR_DCMP, "DCMP",
854 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
855 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
856 76a66253 j_mayer
                 0x00000000);
857 76a66253 j_mayer
    spr_register(env, SPR_HASH1, "HASH1",
858 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
859 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
860 76a66253 j_mayer
                 0x00000000);
861 76a66253 j_mayer
    spr_register(env, SPR_HASH2, "HASH2",
862 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
863 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
864 76a66253 j_mayer
                 0x00000000);
865 76a66253 j_mayer
    spr_register(env, SPR_IMISS, "IMISS",
866 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
867 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
868 76a66253 j_mayer
                 0x00000000);
869 76a66253 j_mayer
    spr_register(env, SPR_ICMP, "ICMP",
870 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
871 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
872 76a66253 j_mayer
                 0x00000000);
873 76a66253 j_mayer
    spr_register(env, SPR_RPA, "RPA",
874 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
875 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
876 76a66253 j_mayer
                 0x00000000);
877 f2e63a42 j_mayer
#endif
878 76a66253 j_mayer
}
879 76a66253 j_mayer
880 76a66253 j_mayer
/* SPR common to MPC755 and G2 */
881 76a66253 j_mayer
static void gen_spr_G2_755 (CPUPPCState *env)
882 76a66253 j_mayer
{
883 76a66253 j_mayer
    /* SGPRs */
884 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
885 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
886 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
887 76a66253 j_mayer
                 0x00000000);
888 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
889 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
890 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
891 76a66253 j_mayer
                 0x00000000);
892 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
893 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
894 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
895 76a66253 j_mayer
                 0x00000000);
896 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
897 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
898 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
899 76a66253 j_mayer
                 0x00000000);
900 76a66253 j_mayer
}
901 76a66253 j_mayer
902 3fc6c082 bellard
/* SPR common to all 7xx PowerPC implementations */
903 3fc6c082 bellard
static void gen_spr_7xx (CPUPPCState *env)
904 3fc6c082 bellard
{
905 3fc6c082 bellard
    /* Breakpoints */
906 3fc6c082 bellard
    /* XXX : not implemented */
907 3fc6c082 bellard
    spr_register(env, SPR_DABR, "DABR",
908 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
909 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
910 3fc6c082 bellard
                 0x00000000);
911 3fc6c082 bellard
    /* XXX : not implemented */
912 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
913 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
914 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
915 3fc6c082 bellard
                 0x00000000);
916 3fc6c082 bellard
    /* Cache management */
917 3fc6c082 bellard
    /* XXX : not implemented */
918 3fc6c082 bellard
    spr_register(env, SPR_ICTC, "ICTC",
919 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
920 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
921 3fc6c082 bellard
                 0x00000000);
922 3fc6c082 bellard
    /* Performance monitors */
923 3fc6c082 bellard
    /* XXX : not implemented */
924 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
925 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
926 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
927 3fc6c082 bellard
                 0x00000000);
928 3fc6c082 bellard
    /* XXX : not implemented */
929 3fc6c082 bellard
    spr_register(env, SPR_MMCR1, "MMCR1",
930 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
931 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
932 3fc6c082 bellard
                 0x00000000);
933 3fc6c082 bellard
    /* XXX : not implemented */
934 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
935 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
936 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
937 3fc6c082 bellard
                 0x00000000);
938 3fc6c082 bellard
    /* XXX : not implemented */
939 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
940 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
941 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
942 3fc6c082 bellard
                 0x00000000);
943 3fc6c082 bellard
    /* XXX : not implemented */
944 3fc6c082 bellard
    spr_register(env, SPR_PMC3, "PMC3",
945 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
946 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
947 3fc6c082 bellard
                 0x00000000);
948 3fc6c082 bellard
    /* XXX : not implemented */
949 3fc6c082 bellard
    spr_register(env, SPR_PMC4, "PMC4",
950 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
951 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
952 3fc6c082 bellard
                 0x00000000);
953 3fc6c082 bellard
    /* XXX : not implemented */
954 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
955 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
956 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
957 3fc6c082 bellard
                 0x00000000);
958 578bb252 j_mayer
    /* XXX : not implemented */
959 3fc6c082 bellard
    spr_register(env, SPR_UMMCR0, "UMMCR0",
960 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
961 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
962 3fc6c082 bellard
                 0x00000000);
963 578bb252 j_mayer
    /* XXX : not implemented */
964 3fc6c082 bellard
    spr_register(env, SPR_UMMCR1, "UMMCR1",
965 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
966 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
967 3fc6c082 bellard
                 0x00000000);
968 578bb252 j_mayer
    /* XXX : not implemented */
969 3fc6c082 bellard
    spr_register(env, SPR_UPMC1, "UPMC1",
970 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
971 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
972 3fc6c082 bellard
                 0x00000000);
973 578bb252 j_mayer
    /* XXX : not implemented */
974 3fc6c082 bellard
    spr_register(env, SPR_UPMC2, "UPMC2",
975 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
976 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
977 3fc6c082 bellard
                 0x00000000);
978 578bb252 j_mayer
    /* XXX : not implemented */
979 3fc6c082 bellard
    spr_register(env, SPR_UPMC3, "UPMC3",
980 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
981 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
982 3fc6c082 bellard
                 0x00000000);
983 578bb252 j_mayer
    /* XXX : not implemented */
984 3fc6c082 bellard
    spr_register(env, SPR_UPMC4, "UPMC4",
985 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
986 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
987 3fc6c082 bellard
                 0x00000000);
988 578bb252 j_mayer
    /* XXX : not implemented */
989 a750fc0b j_mayer
    spr_register(env, SPR_USIAR, "USIAR",
990 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
991 3fc6c082 bellard
                 &spr_read_ureg, SPR_NOACCESS,
992 3fc6c082 bellard
                 0x00000000);
993 a750fc0b j_mayer
    /* External access control */
994 3fc6c082 bellard
    /* XXX : not implemented */
995 a750fc0b j_mayer
    spr_register(env, SPR_EAR, "EAR",
996 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
997 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
998 3fc6c082 bellard
                 0x00000000);
999 a750fc0b j_mayer
}
1000 a750fc0b j_mayer
1001 a750fc0b j_mayer
static void gen_spr_thrm (CPUPPCState *env)
1002 a750fc0b j_mayer
{
1003 a750fc0b j_mayer
    /* Thermal management */
1004 3fc6c082 bellard
    /* XXX : not implemented */
1005 a750fc0b j_mayer
    spr_register(env, SPR_THRM1, "THRM1",
1006 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1007 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1008 3fc6c082 bellard
                 0x00000000);
1009 3fc6c082 bellard
    /* XXX : not implemented */
1010 a750fc0b j_mayer
    spr_register(env, SPR_THRM2, "THRM2",
1011 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1012 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1013 3fc6c082 bellard
                 0x00000000);
1014 3fc6c082 bellard
    /* XXX : not implemented */
1015 a750fc0b j_mayer
    spr_register(env, SPR_THRM3, "THRM3",
1016 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1017 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1018 3fc6c082 bellard
                 0x00000000);
1019 3fc6c082 bellard
}
1020 3fc6c082 bellard
1021 3fc6c082 bellard
/* SPR specific to PowerPC 604 implementation */
1022 3fc6c082 bellard
static void gen_spr_604 (CPUPPCState *env)
1023 3fc6c082 bellard
{
1024 3fc6c082 bellard
    /* Processor identification */
1025 3fc6c082 bellard
    spr_register(env, SPR_PIR, "PIR",
1026 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1027 3fc6c082 bellard
                 &spr_read_generic, &spr_write_pir,
1028 3fc6c082 bellard
                 0x00000000);
1029 3fc6c082 bellard
    /* Breakpoints */
1030 3fc6c082 bellard
    /* XXX : not implemented */
1031 3fc6c082 bellard
    spr_register(env, SPR_IABR, "IABR",
1032 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1033 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1034 3fc6c082 bellard
                 0x00000000);
1035 3fc6c082 bellard
    /* XXX : not implemented */
1036 3fc6c082 bellard
    spr_register(env, SPR_DABR, "DABR",
1037 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1038 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1039 3fc6c082 bellard
                 0x00000000);
1040 3fc6c082 bellard
    /* Performance counters */
1041 3fc6c082 bellard
    /* XXX : not implemented */
1042 3fc6c082 bellard
    spr_register(env, SPR_MMCR0, "MMCR0",
1043 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1044 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1045 3fc6c082 bellard
                 0x00000000);
1046 3fc6c082 bellard
    /* XXX : not implemented */
1047 3fc6c082 bellard
    spr_register(env, SPR_PMC1, "PMC1",
1048 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1049 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1050 3fc6c082 bellard
                 0x00000000);
1051 3fc6c082 bellard
    /* XXX : not implemented */
1052 3fc6c082 bellard
    spr_register(env, SPR_PMC2, "PMC2",
1053 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1054 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1055 3fc6c082 bellard
                 0x00000000);
1056 3fc6c082 bellard
    /* XXX : not implemented */
1057 a750fc0b j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
1058 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1059 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
1060 3fc6c082 bellard
                 0x00000000);
1061 3fc6c082 bellard
    /* XXX : not implemented */
1062 3fc6c082 bellard
    spr_register(env, SPR_SDA, "SDA",
1063 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1064 3fc6c082 bellard
                 &spr_read_generic, SPR_NOACCESS,
1065 3fc6c082 bellard
                 0x00000000);
1066 3fc6c082 bellard
    /* External access control */
1067 3fc6c082 bellard
    /* XXX : not implemented */
1068 3fc6c082 bellard
    spr_register(env, SPR_EAR, "EAR",
1069 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1070 3fc6c082 bellard
                 &spr_read_generic, &spr_write_generic,
1071 3fc6c082 bellard
                 0x00000000);
1072 3fc6c082 bellard
}
1073 3fc6c082 bellard
1074 76a66253 j_mayer
/* SPR specific to PowerPC 603 implementation */
1075 76a66253 j_mayer
static void gen_spr_603 (CPUPPCState *env)
1076 3fc6c082 bellard
{
1077 76a66253 j_mayer
    /* External access control */
1078 76a66253 j_mayer
    /* XXX : not implemented */
1079 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
1080 3fc6c082 bellard
                 SPR_NOACCESS, SPR_NOACCESS,
1081 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1082 76a66253 j_mayer
                 0x00000000);
1083 3fc6c082 bellard
}
1084 3fc6c082 bellard
1085 76a66253 j_mayer
/* SPR specific to PowerPC G2 implementation */
1086 76a66253 j_mayer
static void gen_spr_G2 (CPUPPCState *env)
1087 3fc6c082 bellard
{
1088 76a66253 j_mayer
    /* Memory base address */
1089 76a66253 j_mayer
    /* MBAR */
1090 578bb252 j_mayer
    /* XXX : not implemented */
1091 76a66253 j_mayer
    spr_register(env, SPR_MBAR, "MBAR",
1092 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1093 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1094 76a66253 j_mayer
                 0x00000000);
1095 76a66253 j_mayer
    /* Exception processing */
1096 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
1097 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1098 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1099 76a66253 j_mayer
                 0x00000000);
1100 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
1101 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1102 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1103 76a66253 j_mayer
                 0x00000000);
1104 76a66253 j_mayer
    /* Breakpoints */
1105 76a66253 j_mayer
    /* XXX : not implemented */
1106 76a66253 j_mayer
    spr_register(env, SPR_DABR, "DABR",
1107 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1108 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1109 76a66253 j_mayer
                 0x00000000);
1110 76a66253 j_mayer
    /* XXX : not implemented */
1111 76a66253 j_mayer
    spr_register(env, SPR_DABR2, "DABR2",
1112 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1113 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1114 76a66253 j_mayer
                 0x00000000);
1115 76a66253 j_mayer
    /* XXX : not implemented */
1116 76a66253 j_mayer
    spr_register(env, SPR_IABR, "IABR",
1117 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1118 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1119 76a66253 j_mayer
                 0x00000000);
1120 76a66253 j_mayer
    /* XXX : not implemented */
1121 76a66253 j_mayer
    spr_register(env, SPR_IABR2, "IABR2",
1122 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1123 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1124 76a66253 j_mayer
                 0x00000000);
1125 76a66253 j_mayer
    /* XXX : not implemented */
1126 76a66253 j_mayer
    spr_register(env, SPR_IBCR, "IBCR",
1127 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1128 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1129 76a66253 j_mayer
                 0x00000000);
1130 76a66253 j_mayer
    /* XXX : not implemented */
1131 76a66253 j_mayer
    spr_register(env, SPR_DBCR, "DBCR",
1132 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1133 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1134 76a66253 j_mayer
                 0x00000000);
1135 76a66253 j_mayer
}
1136 76a66253 j_mayer
1137 76a66253 j_mayer
/* SPR specific to PowerPC 602 implementation */
1138 76a66253 j_mayer
static void gen_spr_602 (CPUPPCState *env)
1139 76a66253 j_mayer
{
1140 76a66253 j_mayer
    /* ESA registers */
1141 76a66253 j_mayer
    /* XXX : not implemented */
1142 76a66253 j_mayer
    spr_register(env, SPR_SER, "SER",
1143 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1144 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1145 76a66253 j_mayer
                 0x00000000);
1146 76a66253 j_mayer
    /* XXX : not implemented */
1147 76a66253 j_mayer
    spr_register(env, SPR_SEBR, "SEBR",
1148 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1149 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1150 76a66253 j_mayer
                 0x00000000);
1151 76a66253 j_mayer
    /* XXX : not implemented */
1152 a750fc0b j_mayer
    spr_register(env, SPR_ESASRR, "ESASRR",
1153 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1154 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1155 76a66253 j_mayer
                 0x00000000);
1156 76a66253 j_mayer
    /* Floating point status */
1157 76a66253 j_mayer
    /* XXX : not implemented */
1158 76a66253 j_mayer
    spr_register(env, SPR_SP, "SP",
1159 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1160 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1161 76a66253 j_mayer
                 0x00000000);
1162 76a66253 j_mayer
    /* XXX : not implemented */
1163 76a66253 j_mayer
    spr_register(env, SPR_LT, "LT",
1164 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1165 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1166 76a66253 j_mayer
                 0x00000000);
1167 76a66253 j_mayer
    /* Watchdog timer */
1168 76a66253 j_mayer
    /* XXX : not implemented */
1169 76a66253 j_mayer
    spr_register(env, SPR_TCR, "TCR",
1170 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1171 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1172 76a66253 j_mayer
                 0x00000000);
1173 76a66253 j_mayer
    /* Interrupt base */
1174 76a66253 j_mayer
    spr_register(env, SPR_IBR, "IBR",
1175 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1176 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1177 76a66253 j_mayer
                 0x00000000);
1178 a750fc0b j_mayer
    /* XXX : not implemented */
1179 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
1180 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1181 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1182 a750fc0b j_mayer
                 0x00000000);
1183 76a66253 j_mayer
}
1184 76a66253 j_mayer
1185 76a66253 j_mayer
/* SPR specific to PowerPC 601 implementation */
1186 76a66253 j_mayer
static void gen_spr_601 (CPUPPCState *env)
1187 76a66253 j_mayer
{
1188 76a66253 j_mayer
    /* Multiplication/division register */
1189 76a66253 j_mayer
    /* MQ */
1190 76a66253 j_mayer
    spr_register(env, SPR_MQ, "MQ",
1191 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1192 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1193 76a66253 j_mayer
                 0x00000000);
1194 76a66253 j_mayer
    /* RTC registers */
1195 76a66253 j_mayer
    spr_register(env, SPR_601_RTCU, "RTCU",
1196 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1197 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcu,
1198 76a66253 j_mayer
                 0x00000000);
1199 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCU, "RTCU",
1200 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1201 76a66253 j_mayer
                 &spr_read_601_rtcu, SPR_NOACCESS,
1202 76a66253 j_mayer
                 0x00000000);
1203 76a66253 j_mayer
    spr_register(env, SPR_601_RTCL, "RTCL",
1204 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1205 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_601_rtcl,
1206 76a66253 j_mayer
                 0x00000000);
1207 76a66253 j_mayer
    spr_register(env, SPR_601_VRTCL, "RTCL",
1208 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1209 76a66253 j_mayer
                 &spr_read_601_rtcl, SPR_NOACCESS,
1210 76a66253 j_mayer
                 0x00000000);
1211 76a66253 j_mayer
    /* Timer */
1212 76a66253 j_mayer
#if 0 /* ? */
1213 76a66253 j_mayer
    spr_register(env, SPR_601_UDECR, "UDECR",
1214 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1215 76a66253 j_mayer
                 &spr_read_decr, SPR_NOACCESS,
1216 76a66253 j_mayer
                 0x00000000);
1217 76a66253 j_mayer
#endif
1218 76a66253 j_mayer
    /* External access control */
1219 76a66253 j_mayer
    /* XXX : not implemented */
1220 76a66253 j_mayer
    spr_register(env, SPR_EAR, "EAR",
1221 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1222 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1223 76a66253 j_mayer
                 0x00000000);
1224 76a66253 j_mayer
    /* Memory management */
1225 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1226 76a66253 j_mayer
    spr_register(env, SPR_IBAT0U, "IBAT0U",
1227 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1228 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1229 76a66253 j_mayer
                 0x00000000);
1230 76a66253 j_mayer
    spr_register(env, SPR_IBAT0L, "IBAT0L",
1231 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1232 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1233 76a66253 j_mayer
                 0x00000000);
1234 76a66253 j_mayer
    spr_register(env, SPR_IBAT1U, "IBAT1U",
1235 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1236 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1237 76a66253 j_mayer
                 0x00000000);
1238 76a66253 j_mayer
    spr_register(env, SPR_IBAT1L, "IBAT1L",
1239 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1240 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1241 76a66253 j_mayer
                 0x00000000);
1242 76a66253 j_mayer
    spr_register(env, SPR_IBAT2U, "IBAT2U",
1243 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1244 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1245 76a66253 j_mayer
                 0x00000000);
1246 76a66253 j_mayer
    spr_register(env, SPR_IBAT2L, "IBAT2L",
1247 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1248 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1249 76a66253 j_mayer
                 0x00000000);
1250 76a66253 j_mayer
    spr_register(env, SPR_IBAT3U, "IBAT3U",
1251 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1252 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1253 76a66253 j_mayer
                 0x00000000);
1254 76a66253 j_mayer
    spr_register(env, SPR_IBAT3L, "IBAT3L",
1255 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1256 76a66253 j_mayer
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1257 76a66253 j_mayer
                 0x00000000);
1258 a750fc0b j_mayer
    env->nb_BATs = 4;
1259 f2e63a42 j_mayer
#endif
1260 a750fc0b j_mayer
}
1261 a750fc0b j_mayer
1262 a750fc0b j_mayer
static void gen_spr_74xx (CPUPPCState *env)
1263 a750fc0b j_mayer
{
1264 a750fc0b j_mayer
    /* Processor identification */
1265 a750fc0b j_mayer
    spr_register(env, SPR_PIR, "PIR",
1266 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1267 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_pir,
1268 a750fc0b j_mayer
                 0x00000000);
1269 a750fc0b j_mayer
    /* XXX : not implemented */
1270 a750fc0b j_mayer
    spr_register(env, SPR_MMCR2, "MMCR2",
1271 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1272 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1273 a750fc0b j_mayer
                 0x00000000);
1274 578bb252 j_mayer
    /* XXX : not implemented */
1275 a750fc0b j_mayer
    spr_register(env, SPR_UMMCR2, "UMMCR2",
1276 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1277 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1278 a750fc0b j_mayer
                 0x00000000);
1279 a750fc0b j_mayer
    /* XXX: not implemented */
1280 a750fc0b j_mayer
    spr_register(env, SPR_BAMR, "BAMR",
1281 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1282 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1283 a750fc0b j_mayer
                 0x00000000);
1284 578bb252 j_mayer
    /* XXX : not implemented */
1285 a750fc0b j_mayer
    spr_register(env, SPR_MSSCR0, "MSSCR0",
1286 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1287 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1288 a750fc0b j_mayer
                 0x00000000);
1289 a750fc0b j_mayer
    /* Hardware implementation registers */
1290 a750fc0b j_mayer
    /* XXX : not implemented */
1291 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
1292 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1293 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1294 a750fc0b j_mayer
                 0x00000000);
1295 a750fc0b j_mayer
    /* XXX : not implemented */
1296 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
1297 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1298 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1299 a750fc0b j_mayer
                 0x00000000);
1300 a750fc0b j_mayer
    /* Altivec */
1301 a750fc0b j_mayer
    spr_register(env, SPR_VRSAVE, "VRSAVE",
1302 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1303 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1304 a750fc0b j_mayer
                 0x00000000);
1305 bd928eba j_mayer
    /* XXX : not implemented */
1306 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
1307 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1308 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
1309 bd928eba j_mayer
                 0x00000000);
1310 cf8358c8 aurel32
    /* Not strictly an SPR */
1311 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
1312 a750fc0b j_mayer
}
1313 a750fc0b j_mayer
1314 a750fc0b j_mayer
static void gen_l3_ctrl (CPUPPCState *env)
1315 a750fc0b j_mayer
{
1316 a750fc0b j_mayer
    /* L3CR */
1317 a750fc0b j_mayer
    /* XXX : not implemented */
1318 a750fc0b j_mayer
    spr_register(env, SPR_L3CR, "L3CR",
1319 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1320 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1321 a750fc0b j_mayer
                 0x00000000);
1322 a750fc0b j_mayer
    /* L3ITCR0 */
1323 578bb252 j_mayer
    /* XXX : not implemented */
1324 a750fc0b j_mayer
    spr_register(env, SPR_L3ITCR0, "L3ITCR0",
1325 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1326 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1327 a750fc0b j_mayer
                 0x00000000);
1328 a750fc0b j_mayer
    /* L3PM */
1329 578bb252 j_mayer
    /* XXX : not implemented */
1330 a750fc0b j_mayer
    spr_register(env, SPR_L3PM, "L3PM",
1331 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1332 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1333 a750fc0b j_mayer
                 0x00000000);
1334 a750fc0b j_mayer
}
1335 a750fc0b j_mayer
1336 578bb252 j_mayer
static void gen_74xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
1337 a750fc0b j_mayer
{
1338 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1339 578bb252 j_mayer
    env->nb_tlb = nb_tlbs;
1340 578bb252 j_mayer
    env->nb_ways = nb_ways;
1341 578bb252 j_mayer
    env->id_tlbs = 1;
1342 1c53accc Alexander Graf
    env->tlb_type = TLB_6XX;
1343 578bb252 j_mayer
    /* XXX : not implemented */
1344 a750fc0b j_mayer
    spr_register(env, SPR_PTEHI, "PTEHI",
1345 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1346 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1347 a750fc0b j_mayer
                 0x00000000);
1348 578bb252 j_mayer
    /* XXX : not implemented */
1349 a750fc0b j_mayer
    spr_register(env, SPR_PTELO, "PTELO",
1350 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1351 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1352 a750fc0b j_mayer
                 0x00000000);
1353 578bb252 j_mayer
    /* XXX : not implemented */
1354 a750fc0b j_mayer
    spr_register(env, SPR_TLBMISS, "TLBMISS",
1355 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1356 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
1357 a750fc0b j_mayer
                 0x00000000);
1358 f2e63a42 j_mayer
#endif
1359 76a66253 j_mayer
}
1360 76a66253 j_mayer
1361 01662f3e Alexander Graf
#if !defined(CONFIG_USER_ONLY)
1362 01662f3e Alexander Graf
static void spr_write_e500_l1csr0 (void *opaque, int sprn, int gprn)
1363 01662f3e Alexander Graf
{
1364 01662f3e Alexander Graf
    TCGv t0 = tcg_temp_new();
1365 01662f3e Alexander Graf
1366 01662f3e Alexander Graf
    tcg_gen_andi_tl(t0, cpu_gpr[gprn], ~256);
1367 01662f3e Alexander Graf
    gen_store_spr(sprn, t0);
1368 01662f3e Alexander Graf
    tcg_temp_free(t0);
1369 01662f3e Alexander Graf
}
1370 01662f3e Alexander Graf
1371 01662f3e Alexander Graf
static void spr_write_booke206_mmucsr0 (void *opaque, int sprn, int gprn)
1372 01662f3e Alexander Graf
{
1373 1ff7854e Stefan Weil
    TCGv_i32 t0 = tcg_const_i32(sprn);
1374 01662f3e Alexander Graf
    gen_helper_booke206_tlbflush(t0);
1375 1ff7854e Stefan Weil
    tcg_temp_free_i32(t0);
1376 01662f3e Alexander Graf
}
1377 01662f3e Alexander Graf
1378 01662f3e Alexander Graf
static void spr_write_booke_pid (void *opaque, int sprn, int gprn)
1379 01662f3e Alexander Graf
{
1380 1ff7854e Stefan Weil
    TCGv_i32 t0 = tcg_const_i32(sprn);
1381 01662f3e Alexander Graf
    gen_helper_booke_setpid(t0, cpu_gpr[gprn]);
1382 1ff7854e Stefan Weil
    tcg_temp_free_i32(t0);
1383 01662f3e Alexander Graf
}
1384 01662f3e Alexander Graf
#endif
1385 01662f3e Alexander Graf
1386 80d11f44 j_mayer
static void gen_spr_usprgh (CPUPPCState *env)
1387 76a66253 j_mayer
{
1388 80d11f44 j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
1389 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1390 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1391 80d11f44 j_mayer
                 0x00000000);
1392 80d11f44 j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
1393 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1394 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1395 80d11f44 j_mayer
                 0x00000000);
1396 80d11f44 j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
1397 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1398 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1399 80d11f44 j_mayer
                 0x00000000);
1400 80d11f44 j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
1401 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1402 80d11f44 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1403 76a66253 j_mayer
                 0x00000000);
1404 80d11f44 j_mayer
}
1405 80d11f44 j_mayer
1406 80d11f44 j_mayer
/* PowerPC BookE SPR */
1407 80d11f44 j_mayer
static void gen_spr_BookE (CPUPPCState *env, uint64_t ivor_mask)
1408 80d11f44 j_mayer
{
1409 b55266b5 blueswir1
    const char *ivor_names[64] = {
1410 80d11f44 j_mayer
        "IVOR0",  "IVOR1",  "IVOR2",  "IVOR3",
1411 80d11f44 j_mayer
        "IVOR4",  "IVOR5",  "IVOR6",  "IVOR7",
1412 80d11f44 j_mayer
        "IVOR8",  "IVOR9",  "IVOR10", "IVOR11",
1413 80d11f44 j_mayer
        "IVOR12", "IVOR13", "IVOR14", "IVOR15",
1414 80d11f44 j_mayer
        "IVOR16", "IVOR17", "IVOR18", "IVOR19",
1415 80d11f44 j_mayer
        "IVOR20", "IVOR21", "IVOR22", "IVOR23",
1416 80d11f44 j_mayer
        "IVOR24", "IVOR25", "IVOR26", "IVOR27",
1417 80d11f44 j_mayer
        "IVOR28", "IVOR29", "IVOR30", "IVOR31",
1418 80d11f44 j_mayer
        "IVOR32", "IVOR33", "IVOR34", "IVOR35",
1419 80d11f44 j_mayer
        "IVOR36", "IVOR37", "IVOR38", "IVOR39",
1420 80d11f44 j_mayer
        "IVOR40", "IVOR41", "IVOR42", "IVOR43",
1421 80d11f44 j_mayer
        "IVOR44", "IVOR45", "IVOR46", "IVOR47",
1422 80d11f44 j_mayer
        "IVOR48", "IVOR49", "IVOR50", "IVOR51",
1423 80d11f44 j_mayer
        "IVOR52", "IVOR53", "IVOR54", "IVOR55",
1424 80d11f44 j_mayer
        "IVOR56", "IVOR57", "IVOR58", "IVOR59",
1425 80d11f44 j_mayer
        "IVOR60", "IVOR61", "IVOR62", "IVOR63",
1426 80d11f44 j_mayer
    };
1427 80d11f44 j_mayer
#define SPR_BOOKE_IVORxx (-1)
1428 80d11f44 j_mayer
    int ivor_sprn[64] = {
1429 80d11f44 j_mayer
        SPR_BOOKE_IVOR0,  SPR_BOOKE_IVOR1,  SPR_BOOKE_IVOR2,  SPR_BOOKE_IVOR3,
1430 80d11f44 j_mayer
        SPR_BOOKE_IVOR4,  SPR_BOOKE_IVOR5,  SPR_BOOKE_IVOR6,  SPR_BOOKE_IVOR7,
1431 80d11f44 j_mayer
        SPR_BOOKE_IVOR8,  SPR_BOOKE_IVOR9,  SPR_BOOKE_IVOR10, SPR_BOOKE_IVOR11,
1432 80d11f44 j_mayer
        SPR_BOOKE_IVOR12, SPR_BOOKE_IVOR13, SPR_BOOKE_IVOR14, SPR_BOOKE_IVOR15,
1433 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1434 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1435 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1436 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1437 80d11f44 j_mayer
        SPR_BOOKE_IVOR32, SPR_BOOKE_IVOR33, SPR_BOOKE_IVOR34, SPR_BOOKE_IVOR35,
1438 e9205258 Alexander Graf
        SPR_BOOKE_IVOR36, SPR_BOOKE_IVOR37, SPR_BOOKE_IVOR38, SPR_BOOKE_IVOR39,
1439 e9205258 Alexander Graf
        SPR_BOOKE_IVOR40, SPR_BOOKE_IVOR41, SPR_BOOKE_IVOR42, SPR_BOOKE_IVORxx,
1440 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1441 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1442 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1443 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1444 80d11f44 j_mayer
        SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx, SPR_BOOKE_IVORxx,
1445 80d11f44 j_mayer
    };
1446 80d11f44 j_mayer
    int i;
1447 80d11f44 j_mayer
1448 76a66253 j_mayer
    /* Interrupt processing */
1449 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
1450 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1451 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1452 76a66253 j_mayer
                 0x00000000);
1453 363be49c j_mayer
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
1454 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1455 363be49c j_mayer
                 &spr_read_generic, &spr_write_generic,
1456 363be49c j_mayer
                 0x00000000);
1457 76a66253 j_mayer
    /* Debug */
1458 76a66253 j_mayer
    /* XXX : not implemented */
1459 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC1, "IAC1",
1460 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1461 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1462 76a66253 j_mayer
                 0x00000000);
1463 76a66253 j_mayer
    /* XXX : not implemented */
1464 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_IAC2, "IAC2",
1465 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1466 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1467 76a66253 j_mayer
                 0x00000000);
1468 76a66253 j_mayer
    /* XXX : not implemented */
1469 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC1, "DAC1",
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
    /* XXX : not implemented */
1474 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DAC2, "DAC2",
1475 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1476 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1477 76a66253 j_mayer
                 0x00000000);
1478 76a66253 j_mayer
    /* XXX : not implemented */
1479 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR0, "DBCR0",
1480 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1481 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1482 76a66253 j_mayer
                 0x00000000);
1483 76a66253 j_mayer
    /* XXX : not implemented */
1484 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR1, "DBCR1",
1485 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1486 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1487 76a66253 j_mayer
                 0x00000000);
1488 76a66253 j_mayer
    /* XXX : not implemented */
1489 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBCR2, "DBCR2",
1490 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1491 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1492 76a66253 j_mayer
                 0x00000000);
1493 76a66253 j_mayer
    /* XXX : not implemented */
1494 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DBSR, "DBSR",
1495 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1496 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1497 76a66253 j_mayer
                 0x00000000);
1498 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DEAR, "DEAR",
1499 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1500 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1501 76a66253 j_mayer
                 0x00000000);
1502 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_ESR, "ESR",
1503 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1504 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1505 76a66253 j_mayer
                 0x00000000);
1506 363be49c j_mayer
    spr_register(env, SPR_BOOKE_IVPR, "IVPR",
1507 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1508 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1509 363be49c j_mayer
                 0x00000000);
1510 363be49c j_mayer
    /* Exception vectors */
1511 80d11f44 j_mayer
    for (i = 0; i < 64; i++) {
1512 80d11f44 j_mayer
        if (ivor_mask & (1ULL << i)) {
1513 80d11f44 j_mayer
            if (ivor_sprn[i] == SPR_BOOKE_IVORxx) {
1514 80d11f44 j_mayer
                fprintf(stderr, "ERROR: IVOR %d SPR is not defined\n", i);
1515 80d11f44 j_mayer
                exit(1);
1516 80d11f44 j_mayer
            }
1517 80d11f44 j_mayer
            spr_register(env, ivor_sprn[i], ivor_names[i],
1518 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
1519 80d11f44 j_mayer
                         &spr_read_generic, &spr_write_excp_vector,
1520 80d11f44 j_mayer
                         0x00000000);
1521 80d11f44 j_mayer
        }
1522 80d11f44 j_mayer
    }
1523 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_PID, "PID",
1524 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1525 01662f3e Alexander Graf
                 &spr_read_generic, &spr_write_booke_pid,
1526 76a66253 j_mayer
                 0x00000000);
1527 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TCR, "TCR",
1528 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1529 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1530 76a66253 j_mayer
                 0x00000000);
1531 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_TSR, "TSR",
1532 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1533 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1534 76a66253 j_mayer
                 0x00000000);
1535 76a66253 j_mayer
    /* Timer */
1536 76a66253 j_mayer
    spr_register(env, SPR_DECR, "DECR",
1537 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1538 76a66253 j_mayer
                 &spr_read_decr, &spr_write_decr,
1539 76a66253 j_mayer
                 0x00000000);
1540 76a66253 j_mayer
    spr_register(env, SPR_BOOKE_DECAR, "DECAR",
1541 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1542 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_generic,
1543 76a66253 j_mayer
                 0x00000000);
1544 76a66253 j_mayer
    /* SPRGs */
1545 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1546 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1547 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1548 76a66253 j_mayer
                 0x00000000);
1549 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1550 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1551 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1552 76a66253 j_mayer
                 0x00000000);
1553 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1554 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1555 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1556 76a66253 j_mayer
                 0x00000000);
1557 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1558 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1559 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1560 76a66253 j_mayer
                 0x00000000);
1561 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1562 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1563 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1564 76a66253 j_mayer
                 0x00000000);
1565 76a66253 j_mayer
}
1566 76a66253 j_mayer
1567 01662f3e Alexander Graf
static inline uint32_t gen_tlbncfg(uint32_t assoc, uint32_t minsize,
1568 01662f3e Alexander Graf
                                   uint32_t maxsize, uint32_t flags,
1569 01662f3e Alexander Graf
                                   uint32_t nentries)
1570 01662f3e Alexander Graf
{
1571 01662f3e Alexander Graf
    return (assoc << TLBnCFG_ASSOC_SHIFT) |
1572 01662f3e Alexander Graf
           (minsize << TLBnCFG_MINSIZE_SHIFT) |
1573 01662f3e Alexander Graf
           (maxsize << TLBnCFG_MAXSIZE_SHIFT) |
1574 01662f3e Alexander Graf
           flags | nentries;
1575 01662f3e Alexander Graf
}
1576 01662f3e Alexander Graf
1577 01662f3e Alexander Graf
/* BookE 2.06 storage control registers */
1578 01662f3e Alexander Graf
static void gen_spr_BookE206(CPUPPCState *env, uint32_t mas_mask,
1579 01662f3e Alexander Graf
                              uint32_t *tlbncfg)
1580 363be49c j_mayer
{
1581 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
1582 b55266b5 blueswir1
    const char *mas_names[8] = {
1583 80d11f44 j_mayer
        "MAS0", "MAS1", "MAS2", "MAS3", "MAS4", "MAS5", "MAS6", "MAS7",
1584 80d11f44 j_mayer
    };
1585 80d11f44 j_mayer
    int mas_sprn[8] = {
1586 80d11f44 j_mayer
        SPR_BOOKE_MAS0, SPR_BOOKE_MAS1, SPR_BOOKE_MAS2, SPR_BOOKE_MAS3,
1587 80d11f44 j_mayer
        SPR_BOOKE_MAS4, SPR_BOOKE_MAS5, SPR_BOOKE_MAS6, SPR_BOOKE_MAS7,
1588 80d11f44 j_mayer
    };
1589 80d11f44 j_mayer
    int i;
1590 80d11f44 j_mayer
1591 363be49c j_mayer
    /* TLB assist registers */
1592 578bb252 j_mayer
    /* XXX : not implemented */
1593 80d11f44 j_mayer
    for (i = 0; i < 8; i++) {
1594 80d11f44 j_mayer
        if (mas_mask & (1 << i)) {
1595 80d11f44 j_mayer
            spr_register(env, mas_sprn[i], mas_names[i],
1596 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
1597 80d11f44 j_mayer
                         &spr_read_generic, &spr_write_generic,
1598 80d11f44 j_mayer
                         0x00000000);
1599 80d11f44 j_mayer
        }
1600 80d11f44 j_mayer
    }
1601 363be49c j_mayer
    if (env->nb_pids > 1) {
1602 578bb252 j_mayer
        /* XXX : not implemented */
1603 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID1, "PID1",
1604 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1605 01662f3e Alexander Graf
                     &spr_read_generic, &spr_write_booke_pid,
1606 363be49c j_mayer
                     0x00000000);
1607 363be49c j_mayer
    }
1608 363be49c j_mayer
    if (env->nb_pids > 2) {
1609 578bb252 j_mayer
        /* XXX : not implemented */
1610 363be49c j_mayer
        spr_register(env, SPR_BOOKE_PID2, "PID2",
1611 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1612 01662f3e Alexander Graf
                     &spr_read_generic, &spr_write_booke_pid,
1613 363be49c j_mayer
                     0x00000000);
1614 363be49c j_mayer
    }
1615 578bb252 j_mayer
    /* XXX : not implemented */
1616 65f9ee8d j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
1617 363be49c j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1618 363be49c j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1619 363be49c j_mayer
                 0x00000000); /* TOFIX */
1620 363be49c j_mayer
    switch (env->nb_ways) {
1621 363be49c j_mayer
    case 4:
1622 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB3CFG, "TLB3CFG",
1623 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1624 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1625 01662f3e Alexander Graf
                     tlbncfg[3]);
1626 363be49c j_mayer
        /* Fallthru */
1627 363be49c j_mayer
    case 3:
1628 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB2CFG, "TLB2CFG",
1629 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1630 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1631 01662f3e Alexander Graf
                     tlbncfg[2]);
1632 363be49c j_mayer
        /* Fallthru */
1633 363be49c j_mayer
    case 2:
1634 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
1635 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1636 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1637 01662f3e Alexander Graf
                     tlbncfg[1]);
1638 363be49c j_mayer
        /* Fallthru */
1639 363be49c j_mayer
    case 1:
1640 363be49c j_mayer
        spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
1641 363be49c j_mayer
                     SPR_NOACCESS, SPR_NOACCESS,
1642 363be49c j_mayer
                     &spr_read_generic, SPR_NOACCESS,
1643 01662f3e Alexander Graf
                     tlbncfg[0]);
1644 363be49c j_mayer
        /* Fallthru */
1645 363be49c j_mayer
    case 0:
1646 363be49c j_mayer
    default:
1647 363be49c j_mayer
        break;
1648 363be49c j_mayer
    }
1649 f2e63a42 j_mayer
#endif
1650 01662f3e Alexander Graf
1651 01662f3e Alexander Graf
    gen_spr_usprgh(env);
1652 363be49c j_mayer
}
1653 363be49c j_mayer
1654 76a66253 j_mayer
/* SPR specific to PowerPC 440 implementation */
1655 76a66253 j_mayer
static void gen_spr_440 (CPUPPCState *env)
1656 76a66253 j_mayer
{
1657 76a66253 j_mayer
    /* Cache control */
1658 76a66253 j_mayer
    /* XXX : not implemented */
1659 76a66253 j_mayer
    spr_register(env, SPR_440_DNV0, "DNV0",
1660 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1661 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1662 76a66253 j_mayer
                 0x00000000);
1663 76a66253 j_mayer
    /* XXX : not implemented */
1664 76a66253 j_mayer
    spr_register(env, SPR_440_DNV1, "DNV1",
1665 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1666 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1667 76a66253 j_mayer
                 0x00000000);
1668 76a66253 j_mayer
    /* XXX : not implemented */
1669 76a66253 j_mayer
    spr_register(env, SPR_440_DNV2, "DNV2",
1670 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1671 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1672 76a66253 j_mayer
                 0x00000000);
1673 76a66253 j_mayer
    /* XXX : not implemented */
1674 76a66253 j_mayer
    spr_register(env, SPR_440_DNV3, "DNV3",
1675 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1676 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1677 76a66253 j_mayer
                 0x00000000);
1678 76a66253 j_mayer
    /* XXX : not implemented */
1679 2662a059 j_mayer
    spr_register(env, SPR_440_DTV0, "DTV0",
1680 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1681 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1682 76a66253 j_mayer
                 0x00000000);
1683 76a66253 j_mayer
    /* XXX : not implemented */
1684 2662a059 j_mayer
    spr_register(env, SPR_440_DTV1, "DTV1",
1685 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1686 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1687 76a66253 j_mayer
                 0x00000000);
1688 76a66253 j_mayer
    /* XXX : not implemented */
1689 2662a059 j_mayer
    spr_register(env, SPR_440_DTV2, "DTV2",
1690 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1691 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1692 76a66253 j_mayer
                 0x00000000);
1693 76a66253 j_mayer
    /* XXX : not implemented */
1694 2662a059 j_mayer
    spr_register(env, SPR_440_DTV3, "DTV3",
1695 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1696 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1697 76a66253 j_mayer
                 0x00000000);
1698 76a66253 j_mayer
    /* XXX : not implemented */
1699 76a66253 j_mayer
    spr_register(env, SPR_440_DVLIM, "DVLIM",
1700 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1701 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1702 76a66253 j_mayer
                 0x00000000);
1703 76a66253 j_mayer
    /* XXX : not implemented */
1704 76a66253 j_mayer
    spr_register(env, SPR_440_INV0, "INV0",
1705 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1706 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1707 76a66253 j_mayer
                 0x00000000);
1708 76a66253 j_mayer
    /* XXX : not implemented */
1709 76a66253 j_mayer
    spr_register(env, SPR_440_INV1, "INV1",
1710 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1711 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1712 76a66253 j_mayer
                 0x00000000);
1713 76a66253 j_mayer
    /* XXX : not implemented */
1714 76a66253 j_mayer
    spr_register(env, SPR_440_INV2, "INV2",
1715 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1716 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1717 76a66253 j_mayer
                 0x00000000);
1718 76a66253 j_mayer
    /* XXX : not implemented */
1719 76a66253 j_mayer
    spr_register(env, SPR_440_INV3, "INV3",
1720 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1721 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1722 76a66253 j_mayer
                 0x00000000);
1723 76a66253 j_mayer
    /* XXX : not implemented */
1724 2662a059 j_mayer
    spr_register(env, SPR_440_ITV0, "ITV0",
1725 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1726 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1727 76a66253 j_mayer
                 0x00000000);
1728 76a66253 j_mayer
    /* XXX : not implemented */
1729 2662a059 j_mayer
    spr_register(env, SPR_440_ITV1, "ITV1",
1730 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1731 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1732 76a66253 j_mayer
                 0x00000000);
1733 76a66253 j_mayer
    /* XXX : not implemented */
1734 2662a059 j_mayer
    spr_register(env, SPR_440_ITV2, "ITV2",
1735 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1736 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1737 76a66253 j_mayer
                 0x00000000);
1738 76a66253 j_mayer
    /* XXX : not implemented */
1739 2662a059 j_mayer
    spr_register(env, SPR_440_ITV3, "ITV3",
1740 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1741 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1742 76a66253 j_mayer
                 0x00000000);
1743 76a66253 j_mayer
    /* XXX : not implemented */
1744 76a66253 j_mayer
    spr_register(env, SPR_440_IVLIM, "IVLIM",
1745 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1746 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1747 76a66253 j_mayer
                 0x00000000);
1748 76a66253 j_mayer
    /* Cache debug */
1749 76a66253 j_mayer
    /* XXX : not implemented */
1750 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRH, "DCDBTRH",
1751 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1752 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1753 76a66253 j_mayer
                 0x00000000);
1754 76a66253 j_mayer
    /* XXX : not implemented */
1755 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_DCDBTRL, "DCDBTRL",
1756 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1757 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1758 76a66253 j_mayer
                 0x00000000);
1759 76a66253 j_mayer
    /* XXX : not implemented */
1760 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1761 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1762 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1763 76a66253 j_mayer
                 0x00000000);
1764 76a66253 j_mayer
    /* XXX : not implemented */
1765 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRH, "ICDBTRH",
1766 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1767 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1768 76a66253 j_mayer
                 0x00000000);
1769 76a66253 j_mayer
    /* XXX : not implemented */
1770 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBTRL, "ICDBTRL",
1771 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1772 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1773 76a66253 j_mayer
                 0x00000000);
1774 76a66253 j_mayer
    /* XXX : not implemented */
1775 76a66253 j_mayer
    spr_register(env, SPR_440_DBDR, "DBDR",
1776 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1777 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1778 76a66253 j_mayer
                 0x00000000);
1779 76a66253 j_mayer
    /* Processor control */
1780 76a66253 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1781 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1782 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1783 76a66253 j_mayer
                 0x00000000);
1784 76a66253 j_mayer
    spr_register(env, SPR_440_RSTCFG, "RSTCFG",
1785 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1786 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1787 76a66253 j_mayer
                 0x00000000);
1788 76a66253 j_mayer
    /* Storage control */
1789 76a66253 j_mayer
    spr_register(env, SPR_440_MMUCR, "MMUCR",
1790 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1791 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1792 76a66253 j_mayer
                 0x00000000);
1793 76a66253 j_mayer
}
1794 76a66253 j_mayer
1795 76a66253 j_mayer
/* SPR shared between PowerPC 40x implementations */
1796 76a66253 j_mayer
static void gen_spr_40x (CPUPPCState *env)
1797 76a66253 j_mayer
{
1798 76a66253 j_mayer
    /* Cache */
1799 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1800 76a66253 j_mayer
    spr_register(env, SPR_40x_DCCR, "DCCR",
1801 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1802 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1803 76a66253 j_mayer
                 0x00000000);
1804 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1805 76a66253 j_mayer
    spr_register(env, SPR_40x_ICCR, "ICCR",
1806 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1807 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1808 76a66253 j_mayer
                 0x00000000);
1809 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1810 2662a059 j_mayer
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1811 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1812 76a66253 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
1813 76a66253 j_mayer
                 0x00000000);
1814 76a66253 j_mayer
    /* Exception */
1815 76a66253 j_mayer
    spr_register(env, SPR_40x_DEAR, "DEAR",
1816 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1817 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1818 76a66253 j_mayer
                 0x00000000);
1819 76a66253 j_mayer
    spr_register(env, SPR_40x_ESR, "ESR",
1820 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1821 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1822 76a66253 j_mayer
                 0x00000000);
1823 76a66253 j_mayer
    spr_register(env, SPR_40x_EVPR, "EVPR",
1824 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1825 6f5d427d j_mayer
                 &spr_read_generic, &spr_write_excp_prefix,
1826 76a66253 j_mayer
                 0x00000000);
1827 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR2, "SRR2",
1828 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1829 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1830 76a66253 j_mayer
                 0x00000000);
1831 76a66253 j_mayer
    spr_register(env, SPR_40x_SRR3, "SRR3",
1832 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1833 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1834 76a66253 j_mayer
                 0x00000000);
1835 76a66253 j_mayer
    /* Timers */
1836 76a66253 j_mayer
    spr_register(env, SPR_40x_PIT, "PIT",
1837 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1838 76a66253 j_mayer
                 &spr_read_40x_pit, &spr_write_40x_pit,
1839 76a66253 j_mayer
                 0x00000000);
1840 76a66253 j_mayer
    spr_register(env, SPR_40x_TCR, "TCR",
1841 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1842 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tcr,
1843 76a66253 j_mayer
                 0x00000000);
1844 76a66253 j_mayer
    spr_register(env, SPR_40x_TSR, "TSR",
1845 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1846 76a66253 j_mayer
                 &spr_read_generic, &spr_write_booke_tsr,
1847 76a66253 j_mayer
                 0x00000000);
1848 2662a059 j_mayer
}
1849 2662a059 j_mayer
1850 2662a059 j_mayer
/* SPR specific to PowerPC 405 implementation */
1851 2662a059 j_mayer
static void gen_spr_405 (CPUPPCState *env)
1852 2662a059 j_mayer
{
1853 2662a059 j_mayer
    /* MMU */
1854 2662a059 j_mayer
    spr_register(env, SPR_40x_PID, "PID",
1855 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1856 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1857 76a66253 j_mayer
                 0x00000000);
1858 2662a059 j_mayer
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1859 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1860 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1861 2662a059 j_mayer
                 0x00700000);
1862 2662a059 j_mayer
    /* Debug interface */
1863 76a66253 j_mayer
    /* XXX : not implemented */
1864 76a66253 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1865 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1866 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1867 76a66253 j_mayer
                 0x00000000);
1868 76a66253 j_mayer
    /* XXX : not implemented */
1869 2662a059 j_mayer
    spr_register(env, SPR_405_DBCR1, "DBCR1",
1870 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1871 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1872 2662a059 j_mayer
                 0x00000000);
1873 2662a059 j_mayer
    /* XXX : not implemented */
1874 76a66253 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1875 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1876 8ecc7913 j_mayer
                 &spr_read_generic, &spr_write_clear,
1877 8ecc7913 j_mayer
                 /* Last reset was system reset */
1878 76a66253 j_mayer
                 0x00000300);
1879 76a66253 j_mayer
    /* XXX : not implemented */
1880 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
1881 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1882 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1883 76a66253 j_mayer
                 0x00000000);
1884 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
1885 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1886 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1887 76a66253 j_mayer
                 0x00000000);
1888 2662a059 j_mayer
    /* XXX : not implemented */
1889 2662a059 j_mayer
    spr_register(env, SPR_405_DVC1, "DVC1",
1890 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1891 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1892 2662a059 j_mayer
                 0x00000000);
1893 76a66253 j_mayer
    /* XXX : not implemented */
1894 2662a059 j_mayer
    spr_register(env, SPR_405_DVC2, "DVC2",
1895 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1896 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1897 76a66253 j_mayer
                 0x00000000);
1898 76a66253 j_mayer
    /* XXX : not implemented */
1899 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
1900 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1901 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1902 76a66253 j_mayer
                 0x00000000);
1903 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
1904 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1905 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1906 76a66253 j_mayer
                 0x00000000);
1907 76a66253 j_mayer
    /* XXX : not implemented */
1908 76a66253 j_mayer
    spr_register(env, SPR_405_IAC3, "IAC3",
1909 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1910 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1911 76a66253 j_mayer
                 0x00000000);
1912 76a66253 j_mayer
    /* XXX : not implemented */
1913 76a66253 j_mayer
    spr_register(env, SPR_405_IAC4, "IAC4",
1914 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1915 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1916 76a66253 j_mayer
                 0x00000000);
1917 76a66253 j_mayer
    /* Storage control */
1918 035feb88 j_mayer
    /* XXX: TODO: not implemented */
1919 76a66253 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
1920 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1921 c294fc58 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
1922 76a66253 j_mayer
                 0x00000000);
1923 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
1924 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1925 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
1926 2662a059 j_mayer
                 0x00000000);
1927 76a66253 j_mayer
    /* XXX : not implemented */
1928 76a66253 j_mayer
    spr_register(env, SPR_405_SU0R, "SU0R",
1929 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1930 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1931 76a66253 j_mayer
                 0x00000000);
1932 76a66253 j_mayer
    /* SPRG */
1933 76a66253 j_mayer
    spr_register(env, SPR_USPRG0, "USPRG0",
1934 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1935 76a66253 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
1936 76a66253 j_mayer
                 0x00000000);
1937 76a66253 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
1938 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1939 04f20795 j_mayer
                 &spr_read_generic, &spr_write_generic,
1940 76a66253 j_mayer
                 0x00000000);
1941 76a66253 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
1942 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1943 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1944 76a66253 j_mayer
                 0x00000000);
1945 76a66253 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
1946 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1947 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1948 76a66253 j_mayer
                 0x00000000);
1949 76a66253 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
1950 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1951 04f20795 j_mayer
                 spr_read_generic, &spr_write_generic,
1952 76a66253 j_mayer
                 0x00000000);
1953 80d11f44 j_mayer
    gen_spr_usprgh(env);
1954 76a66253 j_mayer
}
1955 76a66253 j_mayer
1956 76a66253 j_mayer
/* SPR shared between PowerPC 401 & 403 implementations */
1957 76a66253 j_mayer
static void gen_spr_401_403 (CPUPPCState *env)
1958 76a66253 j_mayer
{
1959 76a66253 j_mayer
    /* Time base */
1960 76a66253 j_mayer
    spr_register(env, SPR_403_VTBL,  "TBL",
1961 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1962 76a66253 j_mayer
                 &spr_read_tbl, SPR_NOACCESS,
1963 76a66253 j_mayer
                 0x00000000);
1964 76a66253 j_mayer
    spr_register(env, SPR_403_TBL,   "TBL",
1965 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1966 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbl,
1967 76a66253 j_mayer
                 0x00000000);
1968 76a66253 j_mayer
    spr_register(env, SPR_403_VTBU,  "TBU",
1969 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1970 76a66253 j_mayer
                 &spr_read_tbu, SPR_NOACCESS,
1971 76a66253 j_mayer
                 0x00000000);
1972 76a66253 j_mayer
    spr_register(env, SPR_403_TBU,   "TBU",
1973 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1974 76a66253 j_mayer
                 SPR_NOACCESS, &spr_write_tbu,
1975 76a66253 j_mayer
                 0x00000000);
1976 76a66253 j_mayer
    /* Debug */
1977 578bb252 j_mayer
    /* not emulated, as Qemu do not emulate caches */
1978 76a66253 j_mayer
    spr_register(env, SPR_403_CDBCR, "CDBCR",
1979 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1980 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
1981 76a66253 j_mayer
                 0x00000000);
1982 76a66253 j_mayer
}
1983 76a66253 j_mayer
1984 2662a059 j_mayer
/* SPR specific to PowerPC 401 implementation */
1985 2662a059 j_mayer
static void gen_spr_401 (CPUPPCState *env)
1986 2662a059 j_mayer
{
1987 2662a059 j_mayer
    /* Debug interface */
1988 2662a059 j_mayer
    /* XXX : not implemented */
1989 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR",
1990 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1991 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
1992 2662a059 j_mayer
                 0x00000000);
1993 2662a059 j_mayer
    /* XXX : not implemented */
1994 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
1995 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
1996 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
1997 2662a059 j_mayer
                 /* Last reset was system reset */
1998 2662a059 j_mayer
                 0x00000300);
1999 2662a059 j_mayer
    /* XXX : not implemented */
2000 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC",
2001 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2002 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2003 2662a059 j_mayer
                 0x00000000);
2004 2662a059 j_mayer
    /* XXX : not implemented */
2005 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC",
2006 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2007 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2008 2662a059 j_mayer
                 0x00000000);
2009 2662a059 j_mayer
    /* Storage control */
2010 035feb88 j_mayer
    /* XXX: TODO: not implemented */
2011 2662a059 j_mayer
    spr_register(env, SPR_405_SLER, "SLER",
2012 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2013 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_sler,
2014 2662a059 j_mayer
                 0x00000000);
2015 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
2016 035feb88 j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
2017 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2018 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
2019 035feb88 j_mayer
                 0xFFFFFFFF);
2020 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
2021 035feb88 j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
2022 035feb88 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2023 035feb88 j_mayer
                 &spr_read_generic, &spr_write_generic,
2024 035feb88 j_mayer
                 0x00000000);
2025 2662a059 j_mayer
}
2026 2662a059 j_mayer
2027 a750fc0b j_mayer
static void gen_spr_401x2 (CPUPPCState *env)
2028 a750fc0b j_mayer
{
2029 a750fc0b j_mayer
    gen_spr_401(env);
2030 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
2031 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2032 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2033 a750fc0b j_mayer
                 0x00000000);
2034 a750fc0b j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
2035 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2036 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2037 a750fc0b j_mayer
                 0x00000000);
2038 a750fc0b j_mayer
}
2039 a750fc0b j_mayer
2040 76a66253 j_mayer
/* SPR specific to PowerPC 403 implementation */
2041 76a66253 j_mayer
static void gen_spr_403 (CPUPPCState *env)
2042 76a66253 j_mayer
{
2043 2662a059 j_mayer
    /* Debug interface */
2044 2662a059 j_mayer
    /* XXX : not implemented */
2045 2662a059 j_mayer
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
2046 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2047 2662a059 j_mayer
                 &spr_read_generic, &spr_write_40x_dbcr0,
2048 2662a059 j_mayer
                 0x00000000);
2049 2662a059 j_mayer
    /* XXX : not implemented */
2050 2662a059 j_mayer
    spr_register(env, SPR_40x_DBSR, "DBSR",
2051 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2052 2662a059 j_mayer
                 &spr_read_generic, &spr_write_clear,
2053 2662a059 j_mayer
                 /* Last reset was system reset */
2054 2662a059 j_mayer
                 0x00000300);
2055 2662a059 j_mayer
    /* XXX : not implemented */
2056 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC1, "DAC1",
2057 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2058 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2059 2662a059 j_mayer
                 0x00000000);
2060 578bb252 j_mayer
    /* XXX : not implemented */
2061 2662a059 j_mayer
    spr_register(env, SPR_40x_DAC2, "DAC2",
2062 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2063 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2064 2662a059 j_mayer
                 0x00000000);
2065 2662a059 j_mayer
    /* XXX : not implemented */
2066 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC1, "IAC1",
2067 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2068 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2069 2662a059 j_mayer
                 0x00000000);
2070 578bb252 j_mayer
    /* XXX : not implemented */
2071 2662a059 j_mayer
    spr_register(env, SPR_40x_IAC2, "IAC2",
2072 2662a059 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2073 2662a059 j_mayer
                 &spr_read_generic, &spr_write_generic,
2074 2662a059 j_mayer
                 0x00000000);
2075 a750fc0b j_mayer
}
2076 a750fc0b j_mayer
2077 a750fc0b j_mayer
static void gen_spr_403_real (CPUPPCState *env)
2078 a750fc0b j_mayer
{
2079 76a66253 j_mayer
    spr_register(env, SPR_403_PBL1,  "PBL1",
2080 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2081 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2082 76a66253 j_mayer
                 0x00000000);
2083 76a66253 j_mayer
    spr_register(env, SPR_403_PBU1,  "PBU1",
2084 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2085 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2086 76a66253 j_mayer
                 0x00000000);
2087 76a66253 j_mayer
    spr_register(env, SPR_403_PBL2,  "PBL2",
2088 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2089 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2090 76a66253 j_mayer
                 0x00000000);
2091 76a66253 j_mayer
    spr_register(env, SPR_403_PBU2,  "PBU2",
2092 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2093 76a66253 j_mayer
                 &spr_read_403_pbr, &spr_write_403_pbr,
2094 76a66253 j_mayer
                 0x00000000);
2095 a750fc0b j_mayer
}
2096 a750fc0b j_mayer
2097 a750fc0b j_mayer
static void gen_spr_403_mmu (CPUPPCState *env)
2098 a750fc0b j_mayer
{
2099 a750fc0b j_mayer
    /* MMU */
2100 a750fc0b j_mayer
    spr_register(env, SPR_40x_PID, "PID",
2101 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2102 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2103 a750fc0b j_mayer
                 0x00000000);
2104 2662a059 j_mayer
    spr_register(env, SPR_40x_ZPR, "ZPR",
2105 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2106 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
2107 76a66253 j_mayer
                 0x00000000);
2108 76a66253 j_mayer
}
2109 76a66253 j_mayer
2110 76a66253 j_mayer
/* SPR specific to PowerPC compression coprocessor extension */
2111 76a66253 j_mayer
static void gen_spr_compress (CPUPPCState *env)
2112 76a66253 j_mayer
{
2113 578bb252 j_mayer
    /* XXX : not implemented */
2114 76a66253 j_mayer
    spr_register(env, SPR_401_SKR, "SKR",
2115 76a66253 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2116 76a66253 j_mayer
                 &spr_read_generic, &spr_write_generic,
2117 76a66253 j_mayer
                 0x00000000);
2118 76a66253 j_mayer
}
2119 a750fc0b j_mayer
2120 a750fc0b j_mayer
#if defined (TARGET_PPC64)
2121 a750fc0b j_mayer
/* SPR specific to PowerPC 620 */
2122 a750fc0b j_mayer
static void gen_spr_620 (CPUPPCState *env)
2123 a750fc0b j_mayer
{
2124 082c6681 j_mayer
    /* Processor identification */
2125 082c6681 j_mayer
    spr_register(env, SPR_PIR, "PIR",
2126 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2127 082c6681 j_mayer
                 &spr_read_generic, &spr_write_pir,
2128 082c6681 j_mayer
                 0x00000000);
2129 082c6681 j_mayer
    spr_register(env, SPR_ASR, "ASR",
2130 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2131 082c6681 j_mayer
                 &spr_read_asr, &spr_write_asr,
2132 082c6681 j_mayer
                 0x00000000);
2133 082c6681 j_mayer
    /* Breakpoints */
2134 082c6681 j_mayer
    /* XXX : not implemented */
2135 082c6681 j_mayer
    spr_register(env, SPR_IABR, "IABR",
2136 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2137 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2138 082c6681 j_mayer
                 0x00000000);
2139 082c6681 j_mayer
    /* XXX : not implemented */
2140 082c6681 j_mayer
    spr_register(env, SPR_DABR, "DABR",
2141 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2142 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2143 082c6681 j_mayer
                 0x00000000);
2144 082c6681 j_mayer
    /* XXX : not implemented */
2145 082c6681 j_mayer
    spr_register(env, SPR_SIAR, "SIAR",
2146 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2147 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2148 082c6681 j_mayer
                 0x00000000);
2149 082c6681 j_mayer
    /* XXX : not implemented */
2150 082c6681 j_mayer
    spr_register(env, SPR_SDA, "SDA",
2151 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2152 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2153 082c6681 j_mayer
                 0x00000000);
2154 082c6681 j_mayer
    /* XXX : not implemented */
2155 082c6681 j_mayer
    spr_register(env, SPR_620_PMC1R, "PMC1",
2156 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2157 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2158 082c6681 j_mayer
                 0x00000000);
2159 082c6681 j_mayer
    spr_register(env, SPR_620_PMC1W, "PMC1",
2160 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2161 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2162 082c6681 j_mayer
                 0x00000000);
2163 082c6681 j_mayer
    /* XXX : not implemented */
2164 082c6681 j_mayer
    spr_register(env, SPR_620_PMC2R, "PMC2",
2165 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2166 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2167 082c6681 j_mayer
                 0x00000000);
2168 082c6681 j_mayer
    spr_register(env, SPR_620_PMC2W, "PMC2",
2169 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2170 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2171 082c6681 j_mayer
                 0x00000000);
2172 082c6681 j_mayer
    /* XXX : not implemented */
2173 082c6681 j_mayer
    spr_register(env, SPR_620_MMCR0R, "MMCR0",
2174 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2175 082c6681 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
2176 082c6681 j_mayer
                 0x00000000);
2177 082c6681 j_mayer
    spr_register(env, SPR_620_MMCR0W, "MMCR0",
2178 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2179 082c6681 j_mayer
                  SPR_NOACCESS, &spr_write_generic,
2180 082c6681 j_mayer
                 0x00000000);
2181 082c6681 j_mayer
    /* External access control */
2182 082c6681 j_mayer
    /* XXX : not implemented */
2183 082c6681 j_mayer
    spr_register(env, SPR_EAR, "EAR",
2184 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2185 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2186 082c6681 j_mayer
                 0x00000000);
2187 082c6681 j_mayer
#if 0 // XXX: check this
2188 578bb252 j_mayer
    /* XXX : not implemented */
2189 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR0, "PMR0",
2190 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2191 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2192 a750fc0b j_mayer
                 0x00000000);
2193 578bb252 j_mayer
    /* XXX : not implemented */
2194 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR1, "PMR1",
2195 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2196 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2197 a750fc0b j_mayer
                 0x00000000);
2198 578bb252 j_mayer
    /* XXX : not implemented */
2199 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR2, "PMR2",
2200 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2201 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2202 a750fc0b j_mayer
                 0x00000000);
2203 578bb252 j_mayer
    /* XXX : not implemented */
2204 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR3, "PMR3",
2205 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2206 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2207 a750fc0b j_mayer
                 0x00000000);
2208 578bb252 j_mayer
    /* XXX : not implemented */
2209 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR4, "PMR4",
2210 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2211 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2212 a750fc0b j_mayer
                 0x00000000);
2213 578bb252 j_mayer
    /* XXX : not implemented */
2214 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR5, "PMR5",
2215 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2216 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2217 a750fc0b j_mayer
                 0x00000000);
2218 578bb252 j_mayer
    /* XXX : not implemented */
2219 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR6, "PMR6",
2220 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2221 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2222 a750fc0b j_mayer
                 0x00000000);
2223 578bb252 j_mayer
    /* XXX : not implemented */
2224 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR7, "PMR7",
2225 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2226 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2227 a750fc0b j_mayer
                 0x00000000);
2228 578bb252 j_mayer
    /* XXX : not implemented */
2229 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR8, "PMR8",
2230 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2231 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2232 a750fc0b j_mayer
                 0x00000000);
2233 578bb252 j_mayer
    /* XXX : not implemented */
2234 a750fc0b j_mayer
    spr_register(env, SPR_620_PMR9, "PMR9",
2235 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2236 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2237 a750fc0b j_mayer
                 0x00000000);
2238 578bb252 j_mayer
    /* XXX : not implemented */
2239 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRA, "PMR10",
2240 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2241 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2242 a750fc0b j_mayer
                 0x00000000);
2243 578bb252 j_mayer
    /* XXX : not implemented */
2244 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRB, "PMR11",
2245 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2246 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2247 a750fc0b j_mayer
                 0x00000000);
2248 578bb252 j_mayer
    /* XXX : not implemented */
2249 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRC, "PMR12",
2250 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2251 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2252 a750fc0b j_mayer
                 0x00000000);
2253 578bb252 j_mayer
    /* XXX : not implemented */
2254 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRD, "PMR13",
2255 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2256 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2257 a750fc0b j_mayer
                 0x00000000);
2258 578bb252 j_mayer
    /* XXX : not implemented */
2259 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRE, "PMR14",
2260 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2261 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2262 a750fc0b j_mayer
                 0x00000000);
2263 578bb252 j_mayer
    /* XXX : not implemented */
2264 a750fc0b j_mayer
    spr_register(env, SPR_620_PMRF, "PMR15",
2265 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2266 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2267 a750fc0b j_mayer
                 0x00000000);
2268 082c6681 j_mayer
#endif
2269 578bb252 j_mayer
    /* XXX : not implemented */
2270 082c6681 j_mayer
    spr_register(env, SPR_620_BUSCSR, "BUSCSR",
2271 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2272 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2273 a750fc0b j_mayer
                 0x00000000);
2274 578bb252 j_mayer
    /* XXX : not implemented */
2275 082c6681 j_mayer
    spr_register(env, SPR_620_L2CR, "L2CR",
2276 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2277 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
2278 082c6681 j_mayer
                 0x00000000);
2279 082c6681 j_mayer
    /* XXX : not implemented */
2280 082c6681 j_mayer
    spr_register(env, SPR_620_L2SR, "L2SR",
2281 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2282 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
2283 a750fc0b j_mayer
                 0x00000000);
2284 a750fc0b j_mayer
}
2285 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
2286 76a66253 j_mayer
2287 80d11f44 j_mayer
static void gen_spr_5xx_8xx (CPUPPCState *env)
2288 e1833e1f j_mayer
{
2289 80d11f44 j_mayer
    /* Exception processing */
2290 80d11f44 j_mayer
    spr_register(env, SPR_DSISR, "DSISR",
2291 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2292 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2293 80d11f44 j_mayer
                 0x00000000);
2294 80d11f44 j_mayer
    spr_register(env, SPR_DAR, "DAR",
2295 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2296 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2297 80d11f44 j_mayer
                 0x00000000);
2298 80d11f44 j_mayer
    /* Timer */
2299 80d11f44 j_mayer
    spr_register(env, SPR_DECR, "DECR",
2300 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2301 80d11f44 j_mayer
                 &spr_read_decr, &spr_write_decr,
2302 80d11f44 j_mayer
                 0x00000000);
2303 80d11f44 j_mayer
    /* XXX : not implemented */
2304 80d11f44 j_mayer
    spr_register(env, SPR_MPC_EIE, "EIE",
2305 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2306 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2307 80d11f44 j_mayer
                 0x00000000);
2308 80d11f44 j_mayer
    /* XXX : not implemented */
2309 80d11f44 j_mayer
    spr_register(env, SPR_MPC_EID, "EID",
2310 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2311 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2312 80d11f44 j_mayer
                 0x00000000);
2313 80d11f44 j_mayer
    /* XXX : not implemented */
2314 80d11f44 j_mayer
    spr_register(env, SPR_MPC_NRI, "NRI",
2315 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2316 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2317 80d11f44 j_mayer
                 0x00000000);
2318 80d11f44 j_mayer
    /* XXX : not implemented */
2319 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPA, "CMPA",
2320 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2321 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2322 80d11f44 j_mayer
                 0x00000000);
2323 80d11f44 j_mayer
    /* XXX : not implemented */
2324 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPB, "CMPB",
2325 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2326 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2327 80d11f44 j_mayer
                 0x00000000);
2328 80d11f44 j_mayer
    /* XXX : not implemented */
2329 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPC, "CMPC",
2330 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2331 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2332 80d11f44 j_mayer
                 0x00000000);
2333 80d11f44 j_mayer
    /* XXX : not implemented */
2334 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPD, "CMPD",
2335 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2336 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2337 80d11f44 j_mayer
                 0x00000000);
2338 80d11f44 j_mayer
    /* XXX : not implemented */
2339 80d11f44 j_mayer
    spr_register(env, SPR_MPC_ECR, "ECR",
2340 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2341 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2342 80d11f44 j_mayer
                 0x00000000);
2343 80d11f44 j_mayer
    /* XXX : not implemented */
2344 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DER, "DER",
2345 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2346 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2347 80d11f44 j_mayer
                 0x00000000);
2348 80d11f44 j_mayer
    /* XXX : not implemented */
2349 80d11f44 j_mayer
    spr_register(env, SPR_MPC_COUNTA, "COUNTA",
2350 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2351 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2352 80d11f44 j_mayer
                 0x00000000);
2353 80d11f44 j_mayer
    /* XXX : not implemented */
2354 80d11f44 j_mayer
    spr_register(env, SPR_MPC_COUNTB, "COUNTB",
2355 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2356 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2357 80d11f44 j_mayer
                 0x00000000);
2358 80d11f44 j_mayer
    /* XXX : not implemented */
2359 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPE, "CMPE",
2360 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2361 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2362 80d11f44 j_mayer
                 0x00000000);
2363 80d11f44 j_mayer
    /* XXX : not implemented */
2364 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPF, "CMPF",
2365 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2366 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2367 80d11f44 j_mayer
                 0x00000000);
2368 80d11f44 j_mayer
    /* XXX : not implemented */
2369 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPG, "CMPG",
2370 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2371 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2372 80d11f44 j_mayer
                 0x00000000);
2373 80d11f44 j_mayer
    /* XXX : not implemented */
2374 80d11f44 j_mayer
    spr_register(env, SPR_MPC_CMPH, "CMPH",
2375 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2376 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2377 80d11f44 j_mayer
                 0x00000000);
2378 80d11f44 j_mayer
    /* XXX : not implemented */
2379 80d11f44 j_mayer
    spr_register(env, SPR_MPC_LCTRL1, "LCTRL1",
2380 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2381 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2382 80d11f44 j_mayer
                 0x00000000);
2383 80d11f44 j_mayer
    /* XXX : not implemented */
2384 80d11f44 j_mayer
    spr_register(env, SPR_MPC_LCTRL2, "LCTRL2",
2385 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2386 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2387 80d11f44 j_mayer
                 0x00000000);
2388 80d11f44 j_mayer
    /* XXX : not implemented */
2389 80d11f44 j_mayer
    spr_register(env, SPR_MPC_BAR, "BAR",
2390 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2391 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2392 80d11f44 j_mayer
                 0x00000000);
2393 80d11f44 j_mayer
    /* XXX : not implemented */
2394 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DPDR, "DPDR",
2395 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2396 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2397 80d11f44 j_mayer
                 0x00000000);
2398 80d11f44 j_mayer
    /* XXX : not implemented */
2399 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IMMR, "IMMR",
2400 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2401 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2402 80d11f44 j_mayer
                 0x00000000);
2403 80d11f44 j_mayer
}
2404 80d11f44 j_mayer
2405 80d11f44 j_mayer
static void gen_spr_5xx (CPUPPCState *env)
2406 80d11f44 j_mayer
{
2407 80d11f44 j_mayer
    /* XXX : not implemented */
2408 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_GRA, "MI_GRA",
2409 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2410 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2411 80d11f44 j_mayer
                 0x00000000);
2412 80d11f44 j_mayer
    /* XXX : not implemented */
2413 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_GRA, "L2U_GRA",
2414 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2415 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2416 80d11f44 j_mayer
                 0x00000000);
2417 80d11f44 j_mayer
    /* XXX : not implemented */
2418 80d11f44 j_mayer
    spr_register(env, SPR_RPCU_BBCMCR, "L2U_BBCMCR",
2419 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2420 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2421 80d11f44 j_mayer
                 0x00000000);
2422 80d11f44 j_mayer
    /* XXX : not implemented */
2423 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_MCR, "L2U_MCR",
2424 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2425 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2426 80d11f44 j_mayer
                 0x00000000);
2427 80d11f44 j_mayer
    /* XXX : not implemented */
2428 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA0, "MI_RBA0",
2429 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2430 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2431 80d11f44 j_mayer
                 0x00000000);
2432 80d11f44 j_mayer
    /* XXX : not implemented */
2433 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA1, "MI_RBA1",
2434 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2435 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2436 80d11f44 j_mayer
                 0x00000000);
2437 80d11f44 j_mayer
    /* XXX : not implemented */
2438 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA2, "MI_RBA2",
2439 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2440 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2441 80d11f44 j_mayer
                 0x00000000);
2442 80d11f44 j_mayer
    /* XXX : not implemented */
2443 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RBA3, "MI_RBA3",
2444 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2445 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2446 80d11f44 j_mayer
                 0x00000000);
2447 80d11f44 j_mayer
    /* XXX : not implemented */
2448 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA0, "L2U_RBA0",
2449 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2450 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2451 80d11f44 j_mayer
                 0x00000000);
2452 80d11f44 j_mayer
    /* XXX : not implemented */
2453 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA1, "L2U_RBA1",
2454 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2455 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2456 80d11f44 j_mayer
                 0x00000000);
2457 80d11f44 j_mayer
    /* XXX : not implemented */
2458 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA2, "L2U_RBA2",
2459 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2460 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2461 80d11f44 j_mayer
                 0x00000000);
2462 80d11f44 j_mayer
    /* XXX : not implemented */
2463 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RBA3, "L2U_RBA3",
2464 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2465 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2466 80d11f44 j_mayer
                 0x00000000);
2467 80d11f44 j_mayer
    /* XXX : not implemented */
2468 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA0, "MI_RA0",
2469 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2470 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2471 80d11f44 j_mayer
                 0x00000000);
2472 80d11f44 j_mayer
    /* XXX : not implemented */
2473 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA1, "MI_RA1",
2474 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2475 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2476 80d11f44 j_mayer
                 0x00000000);
2477 80d11f44 j_mayer
    /* XXX : not implemented */
2478 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA2, "MI_RA2",
2479 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2480 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2481 80d11f44 j_mayer
                 0x00000000);
2482 80d11f44 j_mayer
    /* XXX : not implemented */
2483 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_MI_RA3, "MI_RA3",
2484 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2485 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2486 80d11f44 j_mayer
                 0x00000000);
2487 80d11f44 j_mayer
    /* XXX : not implemented */
2488 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA0, "L2U_RA0",
2489 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2490 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2491 80d11f44 j_mayer
                 0x00000000);
2492 80d11f44 j_mayer
    /* XXX : not implemented */
2493 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA1, "L2U_RA1",
2494 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2495 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2496 80d11f44 j_mayer
                 0x00000000);
2497 80d11f44 j_mayer
    /* XXX : not implemented */
2498 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA2, "L2U_RA2",
2499 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2500 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2501 80d11f44 j_mayer
                 0x00000000);
2502 80d11f44 j_mayer
    /* XXX : not implemented */
2503 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_L2U_RA3, "L2U_RA3",
2504 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2505 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2506 80d11f44 j_mayer
                 0x00000000);
2507 80d11f44 j_mayer
    /* XXX : not implemented */
2508 80d11f44 j_mayer
    spr_register(env, SPR_RCPU_FPECR, "FPECR",
2509 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2510 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2511 80d11f44 j_mayer
                 0x00000000);
2512 80d11f44 j_mayer
}
2513 80d11f44 j_mayer
2514 80d11f44 j_mayer
static void gen_spr_8xx (CPUPPCState *env)
2515 80d11f44 j_mayer
{
2516 80d11f44 j_mayer
    /* XXX : not implemented */
2517 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_CST, "IC_CST",
2518 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2519 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2520 80d11f44 j_mayer
                 0x00000000);
2521 80d11f44 j_mayer
    /* XXX : not implemented */
2522 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_ADR, "IC_ADR",
2523 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2524 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2525 80d11f44 j_mayer
                 0x00000000);
2526 80d11f44 j_mayer
    /* XXX : not implemented */
2527 80d11f44 j_mayer
    spr_register(env, SPR_MPC_IC_DAT, "IC_DAT",
2528 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2529 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2530 80d11f44 j_mayer
                 0x00000000);
2531 80d11f44 j_mayer
    /* XXX : not implemented */
2532 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_CST, "DC_CST",
2533 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2534 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2535 80d11f44 j_mayer
                 0x00000000);
2536 80d11f44 j_mayer
    /* XXX : not implemented */
2537 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_ADR, "DC_ADR",
2538 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2539 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2540 80d11f44 j_mayer
                 0x00000000);
2541 80d11f44 j_mayer
    /* XXX : not implemented */
2542 80d11f44 j_mayer
    spr_register(env, SPR_MPC_DC_DAT, "DC_DAT",
2543 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2544 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2545 80d11f44 j_mayer
                 0x00000000);
2546 80d11f44 j_mayer
    /* XXX : not implemented */
2547 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_CTR, "MI_CTR",
2548 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2549 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2550 80d11f44 j_mayer
                 0x00000000);
2551 80d11f44 j_mayer
    /* XXX : not implemented */
2552 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_AP, "MI_AP",
2553 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2554 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2555 80d11f44 j_mayer
                 0x00000000);
2556 80d11f44 j_mayer
    /* XXX : not implemented */
2557 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_EPN, "MI_EPN",
2558 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2559 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2560 80d11f44 j_mayer
                 0x00000000);
2561 80d11f44 j_mayer
    /* XXX : not implemented */
2562 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_TWC, "MI_TWC",
2563 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2564 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2565 80d11f44 j_mayer
                 0x00000000);
2566 80d11f44 j_mayer
    /* XXX : not implemented */
2567 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_RPN, "MI_RPN",
2568 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2569 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2570 80d11f44 j_mayer
                 0x00000000);
2571 80d11f44 j_mayer
    /* XXX : not implemented */
2572 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBCAM, "MI_DBCAM",
2573 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2574 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2575 80d11f44 j_mayer
                 0x00000000);
2576 80d11f44 j_mayer
    /* XXX : not implemented */
2577 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBRAM0, "MI_DBRAM0",
2578 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2579 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2580 80d11f44 j_mayer
                 0x00000000);
2581 80d11f44 j_mayer
    /* XXX : not implemented */
2582 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MI_DBRAM1, "MI_DBRAM1",
2583 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2584 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2585 80d11f44 j_mayer
                 0x00000000);
2586 80d11f44 j_mayer
    /* XXX : not implemented */
2587 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_CTR, "MD_CTR",
2588 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2589 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2590 80d11f44 j_mayer
                 0x00000000);
2591 80d11f44 j_mayer
    /* XXX : not implemented */
2592 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_CASID, "MD_CASID",
2593 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2594 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2595 80d11f44 j_mayer
                 0x00000000);
2596 80d11f44 j_mayer
    /* XXX : not implemented */
2597 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_AP, "MD_AP",
2598 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2599 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2600 80d11f44 j_mayer
                 0x00000000);
2601 80d11f44 j_mayer
    /* XXX : not implemented */
2602 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_EPN, "MD_EPN",
2603 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2604 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2605 80d11f44 j_mayer
                 0x00000000);
2606 80d11f44 j_mayer
    /* XXX : not implemented */
2607 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TWB, "MD_TWB",
2608 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2609 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2610 80d11f44 j_mayer
                 0x00000000);
2611 80d11f44 j_mayer
    /* XXX : not implemented */
2612 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TWC, "MD_TWC",
2613 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2614 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2615 80d11f44 j_mayer
                 0x00000000);
2616 80d11f44 j_mayer
    /* XXX : not implemented */
2617 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_RPN, "MD_RPN",
2618 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2619 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2620 80d11f44 j_mayer
                 0x00000000);
2621 80d11f44 j_mayer
    /* XXX : not implemented */
2622 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_TW, "MD_TW",
2623 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2624 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2625 80d11f44 j_mayer
                 0x00000000);
2626 80d11f44 j_mayer
    /* XXX : not implemented */
2627 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBCAM, "MD_DBCAM",
2628 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2629 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2630 80d11f44 j_mayer
                 0x00000000);
2631 80d11f44 j_mayer
    /* XXX : not implemented */
2632 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBRAM0, "MD_DBRAM0",
2633 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2634 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2635 80d11f44 j_mayer
                 0x00000000);
2636 80d11f44 j_mayer
    /* XXX : not implemented */
2637 80d11f44 j_mayer
    spr_register(env, SPR_MPC_MD_DBRAM1, "MD_DBRAM1",
2638 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
2639 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
2640 80d11f44 j_mayer
                 0x00000000);
2641 80d11f44 j_mayer
}
2642 80d11f44 j_mayer
2643 80d11f44 j_mayer
// XXX: TODO
2644 80d11f44 j_mayer
/*
2645 80d11f44 j_mayer
 * AMR     => SPR 29 (Power 2.04)
2646 80d11f44 j_mayer
 * CTRL    => SPR 136 (Power 2.04)
2647 80d11f44 j_mayer
 * CTRL    => SPR 152 (Power 2.04)
2648 80d11f44 j_mayer
 * SCOMC   => SPR 276 (64 bits ?)
2649 80d11f44 j_mayer
 * SCOMD   => SPR 277 (64 bits ?)
2650 80d11f44 j_mayer
 * TBU40   => SPR 286 (Power 2.04 hypv)
2651 80d11f44 j_mayer
 * HSPRG0  => SPR 304 (Power 2.04 hypv)
2652 80d11f44 j_mayer
 * HSPRG1  => SPR 305 (Power 2.04 hypv)
2653 80d11f44 j_mayer
 * HDSISR  => SPR 306 (Power 2.04 hypv)
2654 80d11f44 j_mayer
 * HDAR    => SPR 307 (Power 2.04 hypv)
2655 80d11f44 j_mayer
 * PURR    => SPR 309 (Power 2.04 hypv)
2656 80d11f44 j_mayer
 * HDEC    => SPR 310 (Power 2.04 hypv)
2657 80d11f44 j_mayer
 * HIOR    => SPR 311 (hypv)
2658 80d11f44 j_mayer
 * RMOR    => SPR 312 (970)
2659 80d11f44 j_mayer
 * HRMOR   => SPR 313 (Power 2.04 hypv)
2660 80d11f44 j_mayer
 * HSRR0   => SPR 314 (Power 2.04 hypv)
2661 80d11f44 j_mayer
 * HSRR1   => SPR 315 (Power 2.04 hypv)
2662 80d11f44 j_mayer
 * LPCR    => SPR 316 (970)
2663 80d11f44 j_mayer
 * LPIDR   => SPR 317 (970)
2664 80d11f44 j_mayer
 * EPR     => SPR 702 (Power 2.04 emb)
2665 80d11f44 j_mayer
 * perf    => 768-783 (Power 2.04)
2666 80d11f44 j_mayer
 * perf    => 784-799 (Power 2.04)
2667 80d11f44 j_mayer
 * PPR     => SPR 896 (Power 2.04)
2668 80d11f44 j_mayer
 * EPLC    => SPR 947 (Power 2.04 emb)
2669 80d11f44 j_mayer
 * EPSC    => SPR 948 (Power 2.04 emb)
2670 80d11f44 j_mayer
 * DABRX   => 1015    (Power 2.04 hypv)
2671 80d11f44 j_mayer
 * FPECR   => SPR 1022 (?)
2672 80d11f44 j_mayer
 * ... and more (thermal management, performance counters, ...)
2673 80d11f44 j_mayer
 */
2674 80d11f44 j_mayer
2675 80d11f44 j_mayer
/*****************************************************************************/
2676 80d11f44 j_mayer
/* Exception vectors models                                                  */
2677 80d11f44 j_mayer
static void init_excp_4xx_real (CPUPPCState *env)
2678 80d11f44 j_mayer
{
2679 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2680 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2681 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2682 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2683 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2684 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2685 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2686 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2687 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2688 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2689 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2690 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2691 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2692 faadf50e j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2693 1c27f8fb j_mayer
    /* Hardware reset vector */
2694 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2695 e1833e1f j_mayer
#endif
2696 e1833e1f j_mayer
}
2697 e1833e1f j_mayer
2698 80d11f44 j_mayer
static void init_excp_4xx_softmmu (CPUPPCState *env)
2699 80d11f44 j_mayer
{
2700 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2701 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2702 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2703 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2704 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2705 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2706 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2707 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2708 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2709 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2710 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2711 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2712 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001100;
2713 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001200;
2714 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2715 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2716 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2717 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2718 80d11f44 j_mayer
    /* Hardware reset vector */
2719 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2720 80d11f44 j_mayer
#endif
2721 80d11f44 j_mayer
}
2722 80d11f44 j_mayer
2723 80d11f44 j_mayer
static void init_excp_MPC5xx (CPUPPCState *env)
2724 80d11f44 j_mayer
{
2725 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2726 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2727 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2728 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2729 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2730 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2731 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000900;
2732 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2733 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2734 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2735 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2736 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001000;
2737 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DABR]     = 0x00001C00;
2738 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001C00;
2739 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MEXTBR]   = 0x00001E00;
2740 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_NMEXTBR]  = 0x00001F00;
2741 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2742 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2743 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2744 80d11f44 j_mayer
    /* Hardware reset vector */
2745 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2746 80d11f44 j_mayer
#endif
2747 80d11f44 j_mayer
}
2748 80d11f44 j_mayer
2749 80d11f44 j_mayer
static void init_excp_MPC8xx (CPUPPCState *env)
2750 e1833e1f j_mayer
{
2751 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2752 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2753 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2754 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2755 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2756 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2757 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2758 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2759 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000900;
2760 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2761 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2762 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2763 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2764 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001000;
2765 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001100;
2766 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001200;
2767 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLBE]    = 0x00001300;
2768 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLBE]    = 0x00001400;
2769 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DABR]     = 0x00001C00;
2770 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001C00;
2771 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MEXTBR]   = 0x00001E00;
2772 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_NMEXTBR]  = 0x00001F00;
2773 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2774 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF0UL;
2775 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2776 1c27f8fb j_mayer
    /* Hardware reset vector */
2777 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2778 e1833e1f j_mayer
#endif
2779 e1833e1f j_mayer
}
2780 e1833e1f j_mayer
2781 80d11f44 j_mayer
static void init_excp_G2 (CPUPPCState *env)
2782 e1833e1f j_mayer
{
2783 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2784 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2785 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2786 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2787 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2788 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2789 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2790 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2791 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2792 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2793 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000A00;
2794 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2795 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2796 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2797 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2798 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2799 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2800 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2801 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2802 80d11f44 j_mayer
    /* Hardware reset vector */
2803 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2804 80d11f44 j_mayer
#endif
2805 80d11f44 j_mayer
}
2806 80d11f44 j_mayer
2807 80d11f44 j_mayer
static void init_excp_e200 (CPUPPCState *env)
2808 80d11f44 j_mayer
{
2809 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2810 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000FFC;
2811 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2812 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2813 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2814 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2815 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2816 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2817 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2818 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2819 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2820 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2821 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2822 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2823 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2824 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2825 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2826 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2827 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SPEU]     = 0x00000000;
2828 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EFPDI]    = 0x00000000;
2829 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EFPRI]    = 0x00000000;
2830 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2831 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFF7UL;
2832 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2833 80d11f44 j_mayer
    /* Hardware reset vector */
2834 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2835 80d11f44 j_mayer
#endif
2836 80d11f44 j_mayer
}
2837 80d11f44 j_mayer
2838 80d11f44 j_mayer
static void init_excp_BookE (CPUPPCState *env)
2839 80d11f44 j_mayer
{
2840 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2841 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2842 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2843 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2844 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2845 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2846 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2847 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2848 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2849 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2850 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2851 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2852 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2853 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2854 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2855 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2856 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2857 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2858 80d11f44 j_mayer
    env->ivor_mask = 0x0000FFE0UL;
2859 80d11f44 j_mayer
    env->ivpr_mask = 0xFFFF0000UL;
2860 80d11f44 j_mayer
    /* Hardware reset vector */
2861 80d11f44 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2862 80d11f44 j_mayer
#endif
2863 80d11f44 j_mayer
}
2864 80d11f44 j_mayer
2865 80d11f44 j_mayer
static void init_excp_601 (CPUPPCState *env)
2866 80d11f44 j_mayer
{
2867 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
2868 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2869 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2870 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2871 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2872 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2873 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2874 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2875 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2876 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2877 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_IO]       = 0x00000A00;
2878 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2879 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_RUNM]     = 0x00002000;
2880 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0xFFF00000UL;
2881 1c27f8fb j_mayer
    /* Hardware reset vector */
2882 80d11f44 j_mayer
    env->hreset_vector = 0x00000100UL;
2883 e1833e1f j_mayer
#endif
2884 e1833e1f j_mayer
}
2885 e1833e1f j_mayer
2886 80d11f44 j_mayer
static void init_excp_602 (CPUPPCState *env)
2887 e1833e1f j_mayer
{
2888 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2889 082c6681 j_mayer
    /* XXX: exception prefix has a special behavior on 602 */
2890 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2891 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2892 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2893 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2894 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2895 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2896 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2897 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2898 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2899 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2900 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2901 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2902 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2903 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2904 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2905 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2906 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001500;
2907 80d11f44 j_mayer
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001600;
2908 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0xFFF00000UL;
2909 1c27f8fb j_mayer
    /* Hardware reset vector */
2910 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2911 e1833e1f j_mayer
#endif
2912 e1833e1f j_mayer
}
2913 e1833e1f j_mayer
2914 80d11f44 j_mayer
static void init_excp_603 (CPUPPCState *env)
2915 e1833e1f j_mayer
{
2916 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2917 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2918 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2919 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2920 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2921 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2922 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2923 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2924 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2925 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2926 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2927 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2928 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2929 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2930 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2931 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2932 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2933 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
2934 1c27f8fb j_mayer
    /* Hardware reset vector */
2935 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
2936 e1833e1f j_mayer
#endif
2937 e1833e1f j_mayer
}
2938 e1833e1f j_mayer
2939 e1833e1f j_mayer
static void init_excp_604 (CPUPPCState *env)
2940 e1833e1f j_mayer
{
2941 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2942 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2943 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2944 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2945 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2946 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2947 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2948 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2949 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2950 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2951 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2952 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2953 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2954 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2955 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2956 2d3eb7bf Tristan Gingold
    env->hreset_excp_prefix = 0xFFF00000UL;
2957 1c27f8fb j_mayer
    /* Hardware reset vector */
2958 2d3eb7bf Tristan Gingold
    env->hreset_vector = 0x00000100UL;
2959 e1833e1f j_mayer
#endif
2960 e1833e1f j_mayer
}
2961 e1833e1f j_mayer
2962 578bb252 j_mayer
#if defined(TARGET_PPC64)
2963 e1833e1f j_mayer
static void init_excp_620 (CPUPPCState *env)
2964 e1833e1f j_mayer
{
2965 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2966 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2967 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2968 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2969 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2970 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2971 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2972 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2973 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2974 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2975 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2976 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2977 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2978 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2979 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2980 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0xFFF00000UL;
2981 1c27f8fb j_mayer
    /* Hardware reset vector */
2982 faadf50e j_mayer
    env->hreset_vector = 0x0000000000000100ULL;
2983 e1833e1f j_mayer
#endif
2984 e1833e1f j_mayer
}
2985 578bb252 j_mayer
#endif /* defined(TARGET_PPC64) */
2986 e1833e1f j_mayer
2987 e1833e1f j_mayer
static void init_excp_7x0 (CPUPPCState *env)
2988 e1833e1f j_mayer
{
2989 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
2990 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2991 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2992 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2993 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2994 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2995 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2996 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2997 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2998 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2999 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3000 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3001 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3002 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3003 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3004 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
3005 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3006 1c27f8fb j_mayer
    /* Hardware reset vector */
3007 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3008 e1833e1f j_mayer
#endif
3009 e1833e1f j_mayer
}
3010 e1833e1f j_mayer
3011 bd928eba j_mayer
static void init_excp_750cl (CPUPPCState *env)
3012 e1833e1f j_mayer
{
3013 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
3014 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3015 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3016 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3017 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3018 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3019 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3020 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3021 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3022 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3023 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3024 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3025 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3026 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3027 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3028 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3029 bd928eba j_mayer
    /* Hardware reset vector */
3030 bd928eba j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3031 bd928eba j_mayer
#endif
3032 bd928eba j_mayer
}
3033 bd928eba j_mayer
3034 bd928eba j_mayer
static void init_excp_750cx (CPUPPCState *env)
3035 bd928eba j_mayer
{
3036 bd928eba j_mayer
#if !defined(CONFIG_USER_ONLY)
3037 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3038 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3039 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3040 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3041 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3042 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3043 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3044 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3045 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3046 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3047 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3048 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3049 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3050 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
3051 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3052 1c27f8fb j_mayer
    /* Hardware reset vector */
3053 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3054 e1833e1f j_mayer
#endif
3055 e1833e1f j_mayer
}
3056 e1833e1f j_mayer
3057 7a3a6927 j_mayer
/* XXX: Check if this is correct */
3058 7a3a6927 j_mayer
static void init_excp_7x5 (CPUPPCState *env)
3059 7a3a6927 j_mayer
{
3060 7a3a6927 j_mayer
#if !defined(CONFIG_USER_ONLY)
3061 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3062 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3063 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3064 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3065 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3066 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3067 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3068 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3069 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3070 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3071 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3072 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3073 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
3074 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
3075 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
3076 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3077 7a3a6927 j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3078 bd928eba j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
3079 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3080 7a3a6927 j_mayer
    /* Hardware reset vector */
3081 7a3a6927 j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3082 7a3a6927 j_mayer
#endif
3083 7a3a6927 j_mayer
}
3084 7a3a6927 j_mayer
3085 e1833e1f j_mayer
static void init_excp_7400 (CPUPPCState *env)
3086 e1833e1f j_mayer
{
3087 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
3088 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3089 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3090 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3091 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3092 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3093 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3094 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3095 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3096 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3097 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3098 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3099 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3100 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3101 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3102 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3103 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
3104 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
3105 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3106 1c27f8fb j_mayer
    /* Hardware reset vector */
3107 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3108 e1833e1f j_mayer
#endif
3109 e1833e1f j_mayer
}
3110 e1833e1f j_mayer
3111 e1833e1f j_mayer
static void init_excp_7450 (CPUPPCState *env)
3112 e1833e1f j_mayer
{
3113 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
3114 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3115 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3116 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3117 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3118 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3119 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3120 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3121 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3122 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3123 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3124 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3125 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3126 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3127 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
3128 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
3129 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
3130 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3131 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
3132 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
3133 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000UL;
3134 1c27f8fb j_mayer
    /* Hardware reset vector */
3135 1c27f8fb j_mayer
    env->hreset_vector = 0xFFFFFFFCUL;
3136 e1833e1f j_mayer
#endif
3137 e1833e1f j_mayer
}
3138 e1833e1f j_mayer
3139 e1833e1f j_mayer
#if defined (TARGET_PPC64)
3140 e1833e1f j_mayer
static void init_excp_970 (CPUPPCState *env)
3141 e1833e1f j_mayer
{
3142 e1833e1f j_mayer
#if !defined(CONFIG_USER_ONLY)
3143 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3144 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3145 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3146 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
3147 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3148 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
3149 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3150 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3151 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3152 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3153 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3154 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
3155 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3156 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3157 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3158 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3159 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3160 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
3161 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
3162 e1833e1f j_mayer
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
3163 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000FFF00000ULL;
3164 1c27f8fb j_mayer
    /* Hardware reset vector */
3165 1c27f8fb j_mayer
    env->hreset_vector = 0x0000000000000100ULL;
3166 e1833e1f j_mayer
#endif
3167 e1833e1f j_mayer
}
3168 9d52e907 David Gibson
3169 9d52e907 David Gibson
static void init_excp_POWER7 (CPUPPCState *env)
3170 9d52e907 David Gibson
{
3171 9d52e907 David Gibson
#if !defined(CONFIG_USER_ONLY)
3172 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
3173 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
3174 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
3175 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
3176 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
3177 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
3178 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
3179 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
3180 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
3181 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
3182 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
3183 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
3184 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
3185 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
3186 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
3187 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
3188 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
3189 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
3190 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
3191 9d52e907 David Gibson
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
3192 9d52e907 David Gibson
    env->hreset_excp_prefix = 0;
3193 9d52e907 David Gibson
    /* Hardware reset vector */
3194 9d52e907 David Gibson
    env->hreset_vector = 0x0000000000000100ULL;
3195 9d52e907 David Gibson
#endif
3196 9d52e907 David Gibson
}
3197 e1833e1f j_mayer
#endif
3198 e1833e1f j_mayer
3199 e1833e1f j_mayer
/*****************************************************************************/
3200 2f462816 j_mayer
/* Power management enable checks                                            */
3201 2f462816 j_mayer
static int check_pow_none (CPUPPCState *env)
3202 2f462816 j_mayer
{
3203 2f462816 j_mayer
    return 0;
3204 2f462816 j_mayer
}
3205 2f462816 j_mayer
3206 2f462816 j_mayer
static int check_pow_nocheck (CPUPPCState *env)
3207 2f462816 j_mayer
{
3208 2f462816 j_mayer
    return 1;
3209 2f462816 j_mayer
}
3210 2f462816 j_mayer
3211 2f462816 j_mayer
static int check_pow_hid0 (CPUPPCState *env)
3212 2f462816 j_mayer
{
3213 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00E00000)
3214 2f462816 j_mayer
        return 1;
3215 2f462816 j_mayer
3216 2f462816 j_mayer
    return 0;
3217 2f462816 j_mayer
}
3218 2f462816 j_mayer
3219 4e777442 j_mayer
static int check_pow_hid0_74xx (CPUPPCState *env)
3220 4e777442 j_mayer
{
3221 4e777442 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
3222 4e777442 j_mayer
        return 1;
3223 4e777442 j_mayer
3224 4e777442 j_mayer
    return 0;
3225 4e777442 j_mayer
}
3226 4e777442 j_mayer
3227 2f462816 j_mayer
/*****************************************************************************/
3228 a750fc0b j_mayer
/* PowerPC implementations definitions                                       */
3229 76a66253 j_mayer
3230 a750fc0b j_mayer
/* PowerPC 401                                                               */
3231 082c6681 j_mayer
#define POWERPC_INSNS_401    (PPC_INSNS_BASE | PPC_STRING |                   \
3232 082c6681 j_mayer
                              PPC_WRTEE | PPC_DCR |                           \
3233 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3234 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3235 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3236 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3237 a5858d7a Alexander Graf
#define POWERPC_INSNS2_401   (PPC_NONE)
3238 a750fc0b j_mayer
#define POWERPC_MSRM_401     (0x00000000000FD201ULL)
3239 b4095fed j_mayer
#define POWERPC_MMU_401      (POWERPC_MMU_REAL)
3240 a750fc0b j_mayer
#define POWERPC_EXCP_401     (POWERPC_EXCP_40x)
3241 a750fc0b j_mayer
#define POWERPC_INPUT_401    (PPC_FLAGS_INPUT_401)
3242 237c0af0 j_mayer
#define POWERPC_BFDM_401     (bfd_mach_ppc_403)
3243 4018bae9 j_mayer
#define POWERPC_FLAG_401     (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3244 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3245 2f462816 j_mayer
#define check_pow_401        check_pow_nocheck
3246 76a66253 j_mayer
3247 a750fc0b j_mayer
static void init_proc_401 (CPUPPCState *env)
3248 a750fc0b j_mayer
{
3249 a750fc0b j_mayer
    gen_spr_40x(env);
3250 a750fc0b j_mayer
    gen_spr_401_403(env);
3251 a750fc0b j_mayer
    gen_spr_401(env);
3252 e1833e1f j_mayer
    init_excp_4xx_real(env);
3253 d63001d1 j_mayer
    env->dcache_line_size = 32;
3254 d63001d1 j_mayer
    env->icache_line_size = 32;
3255 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3256 4e290a0b j_mayer
    ppc40x_irq_init(env);
3257 ddd1055b Fabien Chouteau
3258 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3259 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(16, 20, 24, 28);
3260 a750fc0b j_mayer
}
3261 76a66253 j_mayer
3262 a750fc0b j_mayer
/* PowerPC 401x2                                                             */
3263 082c6681 j_mayer
#define POWERPC_INSNS_401x2  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3264 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3265 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3266 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3267 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3268 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3269 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3270 a5858d7a Alexander Graf
#define POWERPC_INSNS2_401x2 (PPC_NONE)
3271 a750fc0b j_mayer
#define POWERPC_MSRM_401x2   (0x00000000001FD231ULL)
3272 a750fc0b j_mayer
#define POWERPC_MMU_401x2    (POWERPC_MMU_SOFT_4xx_Z)
3273 a750fc0b j_mayer
#define POWERPC_EXCP_401x2   (POWERPC_EXCP_40x)
3274 a750fc0b j_mayer
#define POWERPC_INPUT_401x2  (PPC_FLAGS_INPUT_401)
3275 237c0af0 j_mayer
#define POWERPC_BFDM_401x2   (bfd_mach_ppc_403)
3276 4018bae9 j_mayer
#define POWERPC_FLAG_401x2   (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3277 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3278 2f462816 j_mayer
#define check_pow_401x2      check_pow_nocheck
3279 a750fc0b j_mayer
3280 a750fc0b j_mayer
static void init_proc_401x2 (CPUPPCState *env)
3281 a750fc0b j_mayer
{
3282 a750fc0b j_mayer
    gen_spr_40x(env);
3283 a750fc0b j_mayer
    gen_spr_401_403(env);
3284 a750fc0b j_mayer
    gen_spr_401x2(env);
3285 a750fc0b j_mayer
    gen_spr_compress(env);
3286 a750fc0b j_mayer
    /* Memory management */
3287 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3288 a750fc0b j_mayer
    env->nb_tlb = 64;
3289 a750fc0b j_mayer
    env->nb_ways = 1;
3290 a750fc0b j_mayer
    env->id_tlbs = 0;
3291 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3292 f2e63a42 j_mayer
#endif
3293 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3294 d63001d1 j_mayer
    env->dcache_line_size = 32;
3295 d63001d1 j_mayer
    env->icache_line_size = 32;
3296 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3297 4e290a0b j_mayer
    ppc40x_irq_init(env);
3298 ddd1055b Fabien Chouteau
3299 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3300 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(16, 20, 24, 28);
3301 76a66253 j_mayer
}
3302 76a66253 j_mayer
3303 a750fc0b j_mayer
/* PowerPC 401x3                                                             */
3304 082c6681 j_mayer
#define POWERPC_INSNS_401x3  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3305 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3306 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3307 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3308 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3309 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3310 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3311 a5858d7a Alexander Graf
#define POWERPC_INSNS2_401x3 (PPC_NONE)
3312 a750fc0b j_mayer
#define POWERPC_MSRM_401x3   (0x00000000001FD631ULL)
3313 a750fc0b j_mayer
#define POWERPC_MMU_401x3    (POWERPC_MMU_SOFT_4xx_Z)
3314 a750fc0b j_mayer
#define POWERPC_EXCP_401x3   (POWERPC_EXCP_40x)
3315 a750fc0b j_mayer
#define POWERPC_INPUT_401x3  (PPC_FLAGS_INPUT_401)
3316 237c0af0 j_mayer
#define POWERPC_BFDM_401x3   (bfd_mach_ppc_403)
3317 4018bae9 j_mayer
#define POWERPC_FLAG_401x3   (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3318 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3319 2f462816 j_mayer
#define check_pow_401x3      check_pow_nocheck
3320 a750fc0b j_mayer
3321 578bb252 j_mayer
__attribute__ (( unused ))
3322 e1833e1f j_mayer
static void init_proc_401x3 (CPUPPCState *env)
3323 76a66253 j_mayer
{
3324 4e290a0b j_mayer
    gen_spr_40x(env);
3325 4e290a0b j_mayer
    gen_spr_401_403(env);
3326 4e290a0b j_mayer
    gen_spr_401(env);
3327 4e290a0b j_mayer
    gen_spr_401x2(env);
3328 4e290a0b j_mayer
    gen_spr_compress(env);
3329 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3330 d63001d1 j_mayer
    env->dcache_line_size = 32;
3331 d63001d1 j_mayer
    env->icache_line_size = 32;
3332 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3333 4e290a0b j_mayer
    ppc40x_irq_init(env);
3334 ddd1055b Fabien Chouteau
3335 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3336 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(16, 20, 24, 28);
3337 3fc6c082 bellard
}
3338 a750fc0b j_mayer
3339 a750fc0b j_mayer
/* IOP480                                                                    */
3340 082c6681 j_mayer
#define POWERPC_INSNS_IOP480 (PPC_INSNS_BASE | PPC_STRING |                   \
3341 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3342 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |  PPC_40x_ICBT |    \
3343 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3344 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3345 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3346 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3347 a5858d7a Alexander Graf
#define POWERPC_INSNS2_IOP480 (PPC_NONE)
3348 a750fc0b j_mayer
#define POWERPC_MSRM_IOP480  (0x00000000001FD231ULL)
3349 a750fc0b j_mayer
#define POWERPC_MMU_IOP480   (POWERPC_MMU_SOFT_4xx_Z)
3350 a750fc0b j_mayer
#define POWERPC_EXCP_IOP480  (POWERPC_EXCP_40x)
3351 a750fc0b j_mayer
#define POWERPC_INPUT_IOP480 (PPC_FLAGS_INPUT_401)
3352 237c0af0 j_mayer
#define POWERPC_BFDM_IOP480  (bfd_mach_ppc_403)
3353 4018bae9 j_mayer
#define POWERPC_FLAG_IOP480  (POWERPC_FLAG_CE | POWERPC_FLAG_DE |             \
3354 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3355 2f462816 j_mayer
#define check_pow_IOP480     check_pow_nocheck
3356 a750fc0b j_mayer
3357 a750fc0b j_mayer
static void init_proc_IOP480 (CPUPPCState *env)
3358 3fc6c082 bellard
{
3359 a750fc0b j_mayer
    gen_spr_40x(env);
3360 a750fc0b j_mayer
    gen_spr_401_403(env);
3361 a750fc0b j_mayer
    gen_spr_401x2(env);
3362 a750fc0b j_mayer
    gen_spr_compress(env);
3363 a750fc0b j_mayer
    /* Memory management */
3364 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3365 a750fc0b j_mayer
    env->nb_tlb = 64;
3366 a750fc0b j_mayer
    env->nb_ways = 1;
3367 a750fc0b j_mayer
    env->id_tlbs = 0;
3368 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3369 f2e63a42 j_mayer
#endif
3370 e1833e1f j_mayer
    init_excp_4xx_softmmu(env);
3371 d63001d1 j_mayer
    env->dcache_line_size = 32;
3372 d63001d1 j_mayer
    env->icache_line_size = 32;
3373 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3374 4e290a0b j_mayer
    ppc40x_irq_init(env);
3375 ddd1055b Fabien Chouteau
3376 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(8, 12, 16, 20);
3377 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(16, 20, 24, 28);
3378 3fc6c082 bellard
}
3379 3fc6c082 bellard
3380 a750fc0b j_mayer
/* PowerPC 403                                                               */
3381 082c6681 j_mayer
#define POWERPC_INSNS_403    (PPC_INSNS_BASE | PPC_STRING |                   \
3382 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3383 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3384 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3385 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3386 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3387 a5858d7a Alexander Graf
#define POWERPC_INSNS2_403   (PPC_NONE)
3388 a750fc0b j_mayer
#define POWERPC_MSRM_403     (0x000000000007D00DULL)
3389 b4095fed j_mayer
#define POWERPC_MMU_403      (POWERPC_MMU_REAL)
3390 a750fc0b j_mayer
#define POWERPC_EXCP_403     (POWERPC_EXCP_40x)
3391 a750fc0b j_mayer
#define POWERPC_INPUT_403    (PPC_FLAGS_INPUT_401)
3392 237c0af0 j_mayer
#define POWERPC_BFDM_403     (bfd_mach_ppc_403)
3393 4018bae9 j_mayer
#define POWERPC_FLAG_403     (POWERPC_FLAG_CE | POWERPC_FLAG_PX |             \
3394 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3395 2f462816 j_mayer
#define check_pow_403        check_pow_nocheck
3396 a750fc0b j_mayer
3397 a750fc0b j_mayer
static void init_proc_403 (CPUPPCState *env)
3398 3fc6c082 bellard
{
3399 a750fc0b j_mayer
    gen_spr_40x(env);
3400 a750fc0b j_mayer
    gen_spr_401_403(env);
3401 a750fc0b j_mayer
    gen_spr_403(env);
3402 a750fc0b j_mayer
    gen_spr_403_real(env);
3403 e1833e1f j_mayer
    init_excp_4xx_real(env);
3404 d63001d1 j_mayer
    env->dcache_line_size = 32;
3405 d63001d1 j_mayer
    env->icache_line_size = 32;
3406 4e290a0b j_mayer
    /* Allocate hardware IRQ controller */
3407 4e290a0b j_mayer
    ppc40x_irq_init(env);
3408 ddd1055b Fabien Chouteau
3409 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(8, 12, 16, 20);
3410 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(16, 20, 24, 28);
3411 3fc6c082 bellard
}
3412 3fc6c082 bellard
3413 a750fc0b j_mayer
/* PowerPC 403 GCX                                                           */
3414 082c6681 j_mayer
#define POWERPC_INSNS_403GCX (PPC_INSNS_BASE | PPC_STRING |                   \
3415 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3416 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3417 082c6681 j_mayer
                              PPC_CACHE_DCBZ |                                \
3418 a750fc0b j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3419 a750fc0b j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3420 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_40x_EXCP)
3421 a5858d7a Alexander Graf
#define POWERPC_INSNS2_403GCX (PPC_NONE)
3422 a750fc0b j_mayer
#define POWERPC_MSRM_403GCX  (0x000000000007D00DULL)
3423 a750fc0b j_mayer
#define POWERPC_MMU_403GCX   (POWERPC_MMU_SOFT_4xx_Z)
3424 a750fc0b j_mayer
#define POWERPC_EXCP_403GCX  (POWERPC_EXCP_40x)
3425 a750fc0b j_mayer
#define POWERPC_INPUT_403GCX (PPC_FLAGS_INPUT_401)
3426 237c0af0 j_mayer
#define POWERPC_BFDM_403GCX  (bfd_mach_ppc_403)
3427 4018bae9 j_mayer
#define POWERPC_FLAG_403GCX  (POWERPC_FLAG_CE | POWERPC_FLAG_PX |             \
3428 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
3429 2f462816 j_mayer
#define check_pow_403GCX     check_pow_nocheck
3430 a750fc0b j_mayer
3431 a750fc0b j_mayer
static void init_proc_403GCX (CPUPPCState *env)
3432 3fc6c082 bellard
{
3433 a750fc0b j_mayer
    gen_spr_40x(env);
3434 a750fc0b j_mayer
    gen_spr_401_403(env);
3435 a750fc0b j_mayer
    gen_spr_403(env);
3436 a750fc0b j_mayer
    gen_spr_403_real(env);
3437 a750fc0b j_mayer
    gen_spr_403_mmu(env);
3438 a750fc0b j_mayer
    /* Bus access control */
3439 035feb88 j_mayer
    /* not emulated, as Qemu never does speculative access */
3440 a750fc0b j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
3441 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3442 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3443 a750fc0b j_mayer
                 0xFFFFFFFF);
3444 035feb88 j_mayer
    /* not emulated, as Qemu do not emulate caches */
3445 a750fc0b j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
3446 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3447 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3448 a750fc0b j_mayer
                 0x00000000);
3449 a750fc0b j_mayer
    /* Memory management */
3450 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3451 a750fc0b j_mayer
    env->nb_tlb = 64;
3452 a750fc0b j_mayer
    env->nb_ways = 1;
3453 a750fc0b j_mayer
    env->id_tlbs = 0;
3454 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3455 f2e63a42 j_mayer
#endif
3456 80d11f44 j_mayer
    init_excp_4xx_softmmu(env);
3457 80d11f44 j_mayer
    env->dcache_line_size = 32;
3458 80d11f44 j_mayer
    env->icache_line_size = 32;
3459 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3460 80d11f44 j_mayer
    ppc40x_irq_init(env);
3461 ddd1055b Fabien Chouteau
3462 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(8, 12, 16, 20);
3463 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(16, 20, 24, 28);
3464 80d11f44 j_mayer
}
3465 80d11f44 j_mayer
3466 80d11f44 j_mayer
/* PowerPC 405                                                               */
3467 082c6681 j_mayer
#define POWERPC_INSNS_405    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
3468 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3469 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_40x_ICBT |     \
3470 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3471 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
3472 80d11f44 j_mayer
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
3473 082c6681 j_mayer
                              PPC_4xx_COMMON | PPC_405_MAC | PPC_40x_EXCP)
3474 a5858d7a Alexander Graf
#define POWERPC_INSNS2_405   (PPC_NONE)
3475 80d11f44 j_mayer
#define POWERPC_MSRM_405     (0x000000000006E630ULL)
3476 80d11f44 j_mayer
#define POWERPC_MMU_405      (POWERPC_MMU_SOFT_4xx)
3477 80d11f44 j_mayer
#define POWERPC_EXCP_405     (POWERPC_EXCP_40x)
3478 80d11f44 j_mayer
#define POWERPC_INPUT_405    (PPC_FLAGS_INPUT_405)
3479 80d11f44 j_mayer
#define POWERPC_BFDM_405     (bfd_mach_ppc_403)
3480 80d11f44 j_mayer
#define POWERPC_FLAG_405     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3481 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3482 80d11f44 j_mayer
#define check_pow_405        check_pow_nocheck
3483 80d11f44 j_mayer
3484 80d11f44 j_mayer
static void init_proc_405 (CPUPPCState *env)
3485 80d11f44 j_mayer
{
3486 80d11f44 j_mayer
    /* Time base */
3487 80d11f44 j_mayer
    gen_tbl(env);
3488 80d11f44 j_mayer
    gen_spr_40x(env);
3489 80d11f44 j_mayer
    gen_spr_405(env);
3490 80d11f44 j_mayer
    /* Bus access control */
3491 80d11f44 j_mayer
    /* not emulated, as Qemu never does speculative access */
3492 80d11f44 j_mayer
    spr_register(env, SPR_40x_SGR, "SGR",
3493 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3494 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3495 80d11f44 j_mayer
                 0xFFFFFFFF);
3496 80d11f44 j_mayer
    /* not emulated, as Qemu do not emulate caches */
3497 80d11f44 j_mayer
    spr_register(env, SPR_40x_DCWR, "DCWR",
3498 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3499 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3500 80d11f44 j_mayer
                 0x00000000);
3501 80d11f44 j_mayer
    /* Memory management */
3502 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3503 80d11f44 j_mayer
    env->nb_tlb = 64;
3504 80d11f44 j_mayer
    env->nb_ways = 1;
3505 80d11f44 j_mayer
    env->id_tlbs = 0;
3506 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3507 80d11f44 j_mayer
#endif
3508 80d11f44 j_mayer
    init_excp_4xx_softmmu(env);
3509 80d11f44 j_mayer
    env->dcache_line_size = 32;
3510 80d11f44 j_mayer
    env->icache_line_size = 32;
3511 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
3512 80d11f44 j_mayer
    ppc40x_irq_init(env);
3513 ddd1055b Fabien Chouteau
3514 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(8, 12, 16, 20);
3515 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(16, 20, 24, 28);
3516 80d11f44 j_mayer
}
3517 80d11f44 j_mayer
3518 80d11f44 j_mayer
/* PowerPC 440 EP                                                            */
3519 082c6681 j_mayer
#define POWERPC_INSNS_440EP  (PPC_INSNS_BASE | PPC_STRING |                   \
3520 c0a7e81a Alexander Graf
                              PPC_FLOAT | PPC_FLOAT_FRES | PPC_FLOAT_FSEL |   \
3521 c0a7e81a Alexander Graf
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
3522 c0a7e81a Alexander Graf
                              PPC_FLOAT_STFIWX |                              \
3523 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE | PPC_RFMCI |               \
3524 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3525 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3526 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_MFTB |                    \
3527 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3528 082c6681 j_mayer
                              PPC_440_SPEC)
3529 a5858d7a Alexander Graf
#define POWERPC_INSNS2_440EP (PPC_NONE)
3530 c0a7e81a Alexander Graf
#define POWERPC_MSRM_440EP   (0x000000000006FF30ULL)
3531 80d11f44 j_mayer
#define POWERPC_MMU_440EP    (POWERPC_MMU_BOOKE)
3532 80d11f44 j_mayer
#define POWERPC_EXCP_440EP   (POWERPC_EXCP_BOOKE)
3533 80d11f44 j_mayer
#define POWERPC_INPUT_440EP  (PPC_FLAGS_INPUT_BookE)
3534 80d11f44 j_mayer
#define POWERPC_BFDM_440EP   (bfd_mach_ppc_403)
3535 80d11f44 j_mayer
#define POWERPC_FLAG_440EP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3536 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3537 80d11f44 j_mayer
#define check_pow_440EP      check_pow_nocheck
3538 80d11f44 j_mayer
3539 80d11f44 j_mayer
static void init_proc_440EP (CPUPPCState *env)
3540 80d11f44 j_mayer
{
3541 80d11f44 j_mayer
    /* Time base */
3542 80d11f44 j_mayer
    gen_tbl(env);
3543 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3544 80d11f44 j_mayer
    gen_spr_440(env);
3545 80d11f44 j_mayer
    gen_spr_usprgh(env);
3546 80d11f44 j_mayer
    /* Processor identification */
3547 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3548 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3549 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3550 80d11f44 j_mayer
                 0x00000000);
3551 80d11f44 j_mayer
    /* XXX : not implemented */
3552 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3553 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3554 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3555 80d11f44 j_mayer
                 0x00000000);
3556 80d11f44 j_mayer
    /* XXX : not implemented */
3557 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3558 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3559 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3560 80d11f44 j_mayer
                 0x00000000);
3561 80d11f44 j_mayer
    /* XXX : not implemented */
3562 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3563 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3564 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3565 80d11f44 j_mayer
                 0x00000000);
3566 80d11f44 j_mayer
    /* XXX : not implemented */
3567 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3568 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3569 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3570 80d11f44 j_mayer
                 0x00000000);
3571 80d11f44 j_mayer
    /* XXX : not implemented */
3572 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3573 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3574 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3575 80d11f44 j_mayer
                 0x00000000);
3576 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3577 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3578 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3579 80d11f44 j_mayer
                 0x00000000);
3580 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3581 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3582 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3583 80d11f44 j_mayer
                 0x00000000);
3584 80d11f44 j_mayer
    /* XXX : not implemented */
3585 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3586 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3587 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3588 80d11f44 j_mayer
                 0x00000000);
3589 80d11f44 j_mayer
    /* Memory management */
3590 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3591 80d11f44 j_mayer
    env->nb_tlb = 64;
3592 80d11f44 j_mayer
    env->nb_ways = 1;
3593 80d11f44 j_mayer
    env->id_tlbs = 0;
3594 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3595 80d11f44 j_mayer
#endif
3596 80d11f44 j_mayer
    init_excp_BookE(env);
3597 80d11f44 j_mayer
    env->dcache_line_size = 32;
3598 80d11f44 j_mayer
    env->icache_line_size = 32;
3599 c0a7e81a Alexander Graf
    ppc40x_irq_init(env);
3600 ddd1055b Fabien Chouteau
3601 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3602 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(20, 24, 28, 32);
3603 80d11f44 j_mayer
}
3604 80d11f44 j_mayer
3605 80d11f44 j_mayer
/* PowerPC 440 GP                                                            */
3606 082c6681 j_mayer
#define POWERPC_INSNS_440GP  (PPC_INSNS_BASE | PPC_STRING |                   \
3607 082c6681 j_mayer
                              PPC_DCR | PPC_DCRX | PPC_WRTEE | PPC_MFAPIDI |  \
3608 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3609 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3610 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_TLBIVA | PPC_MFTB |       \
3611 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3612 082c6681 j_mayer
                              PPC_440_SPEC)
3613 a5858d7a Alexander Graf
#define POWERPC_INSNS2_440GP (PPC_NONE)
3614 80d11f44 j_mayer
#define POWERPC_MSRM_440GP   (0x000000000006FF30ULL)
3615 80d11f44 j_mayer
#define POWERPC_MMU_440GP    (POWERPC_MMU_BOOKE)
3616 80d11f44 j_mayer
#define POWERPC_EXCP_440GP   (POWERPC_EXCP_BOOKE)
3617 80d11f44 j_mayer
#define POWERPC_INPUT_440GP  (PPC_FLAGS_INPUT_BookE)
3618 80d11f44 j_mayer
#define POWERPC_BFDM_440GP   (bfd_mach_ppc_403)
3619 80d11f44 j_mayer
#define POWERPC_FLAG_440GP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3620 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3621 80d11f44 j_mayer
#define check_pow_440GP      check_pow_nocheck
3622 80d11f44 j_mayer
3623 80d11f44 j_mayer
__attribute__ (( unused ))
3624 80d11f44 j_mayer
static void init_proc_440GP (CPUPPCState *env)
3625 80d11f44 j_mayer
{
3626 80d11f44 j_mayer
    /* Time base */
3627 80d11f44 j_mayer
    gen_tbl(env);
3628 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3629 80d11f44 j_mayer
    gen_spr_440(env);
3630 80d11f44 j_mayer
    gen_spr_usprgh(env);
3631 80d11f44 j_mayer
    /* Processor identification */
3632 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3633 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3634 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3635 80d11f44 j_mayer
                 0x00000000);
3636 80d11f44 j_mayer
    /* XXX : not implemented */
3637 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3638 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3639 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3640 80d11f44 j_mayer
                 0x00000000);
3641 80d11f44 j_mayer
    /* XXX : not implemented */
3642 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3643 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3644 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3645 80d11f44 j_mayer
                 0x00000000);
3646 80d11f44 j_mayer
    /* XXX : not implemented */
3647 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3648 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3649 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3650 80d11f44 j_mayer
                 0x00000000);
3651 80d11f44 j_mayer
    /* XXX : not implemented */
3652 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3653 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3654 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3655 80d11f44 j_mayer
                 0x00000000);
3656 80d11f44 j_mayer
    /* Memory management */
3657 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3658 80d11f44 j_mayer
    env->nb_tlb = 64;
3659 80d11f44 j_mayer
    env->nb_ways = 1;
3660 80d11f44 j_mayer
    env->id_tlbs = 0;
3661 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3662 80d11f44 j_mayer
#endif
3663 80d11f44 j_mayer
    init_excp_BookE(env);
3664 80d11f44 j_mayer
    env->dcache_line_size = 32;
3665 80d11f44 j_mayer
    env->icache_line_size = 32;
3666 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3667 ddd1055b Fabien Chouteau
3668 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3669 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(20, 24, 28, 32);
3670 80d11f44 j_mayer
}
3671 80d11f44 j_mayer
3672 80d11f44 j_mayer
/* PowerPC 440x4                                                             */
3673 082c6681 j_mayer
#define POWERPC_INSNS_440x4  (PPC_INSNS_BASE | PPC_STRING |                   \
3674 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE |                           \
3675 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3676 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3677 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_MFTB |                    \
3678 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3679 80d11f44 j_mayer
                              PPC_440_SPEC)
3680 a5858d7a Alexander Graf
#define POWERPC_INSNS2_440x4 (PPC_NONE)
3681 80d11f44 j_mayer
#define POWERPC_MSRM_440x4   (0x000000000006FF30ULL)
3682 80d11f44 j_mayer
#define POWERPC_MMU_440x4    (POWERPC_MMU_BOOKE)
3683 80d11f44 j_mayer
#define POWERPC_EXCP_440x4   (POWERPC_EXCP_BOOKE)
3684 80d11f44 j_mayer
#define POWERPC_INPUT_440x4  (PPC_FLAGS_INPUT_BookE)
3685 80d11f44 j_mayer
#define POWERPC_BFDM_440x4   (bfd_mach_ppc_403)
3686 80d11f44 j_mayer
#define POWERPC_FLAG_440x4   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3687 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3688 80d11f44 j_mayer
#define check_pow_440x4      check_pow_nocheck
3689 80d11f44 j_mayer
3690 80d11f44 j_mayer
__attribute__ (( unused ))
3691 80d11f44 j_mayer
static void init_proc_440x4 (CPUPPCState *env)
3692 80d11f44 j_mayer
{
3693 80d11f44 j_mayer
    /* Time base */
3694 80d11f44 j_mayer
    gen_tbl(env);
3695 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3696 80d11f44 j_mayer
    gen_spr_440(env);
3697 80d11f44 j_mayer
    gen_spr_usprgh(env);
3698 80d11f44 j_mayer
    /* Processor identification */
3699 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3700 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3701 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3702 80d11f44 j_mayer
                 0x00000000);
3703 80d11f44 j_mayer
    /* XXX : not implemented */
3704 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3705 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3706 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3707 80d11f44 j_mayer
                 0x00000000);
3708 80d11f44 j_mayer
    /* XXX : not implemented */
3709 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3710 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3711 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3712 80d11f44 j_mayer
                 0x00000000);
3713 80d11f44 j_mayer
    /* XXX : not implemented */
3714 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3715 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3716 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3717 80d11f44 j_mayer
                 0x00000000);
3718 80d11f44 j_mayer
    /* XXX : not implemented */
3719 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3720 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3721 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3722 80d11f44 j_mayer
                 0x00000000);
3723 80d11f44 j_mayer
    /* Memory management */
3724 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
3725 80d11f44 j_mayer
    env->nb_tlb = 64;
3726 80d11f44 j_mayer
    env->nb_ways = 1;
3727 80d11f44 j_mayer
    env->id_tlbs = 0;
3728 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3729 80d11f44 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 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
3734 ddd1055b Fabien Chouteau
3735 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3736 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(20, 24, 28, 32);
3737 3fc6c082 bellard
}
3738 3fc6c082 bellard
3739 80d11f44 j_mayer
/* PowerPC 440x5                                                             */
3740 082c6681 j_mayer
#define POWERPC_INSNS_440x5  (PPC_INSNS_BASE | PPC_STRING |                   \
3741 082c6681 j_mayer
                              PPC_DCR | PPC_WRTEE | PPC_RFMCI |               \
3742 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3743 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3744 f4078236 Baojun Wang
                              PPC_MEM_TLBSYNC | PPC_MFTB |                    \
3745 80d11f44 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3746 082c6681 j_mayer
                              PPC_440_SPEC)
3747 a5858d7a Alexander Graf
#define POWERPC_INSNS2_440x5 (PPC_NONE)
3748 80d11f44 j_mayer
#define POWERPC_MSRM_440x5   (0x000000000006FF30ULL)
3749 80d11f44 j_mayer
#define POWERPC_MMU_440x5    (POWERPC_MMU_BOOKE)
3750 80d11f44 j_mayer
#define POWERPC_EXCP_440x5   (POWERPC_EXCP_BOOKE)
3751 80d11f44 j_mayer
#define POWERPC_INPUT_440x5  (PPC_FLAGS_INPUT_BookE)
3752 80d11f44 j_mayer
#define POWERPC_BFDM_440x5   (bfd_mach_ppc_403)
3753 80d11f44 j_mayer
#define POWERPC_FLAG_440x5   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |           \
3754 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3755 80d11f44 j_mayer
#define check_pow_440x5      check_pow_nocheck
3756 a750fc0b j_mayer
3757 80d11f44 j_mayer
static void init_proc_440x5 (CPUPPCState *env)
3758 3fc6c082 bellard
{
3759 a750fc0b j_mayer
    /* Time base */
3760 a750fc0b j_mayer
    gen_tbl(env);
3761 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3762 80d11f44 j_mayer
    gen_spr_440(env);
3763 80d11f44 j_mayer
    gen_spr_usprgh(env);
3764 80d11f44 j_mayer
    /* Processor identification */
3765 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3766 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3767 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3768 80d11f44 j_mayer
                 0x00000000);
3769 80d11f44 j_mayer
    /* XXX : not implemented */
3770 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3771 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3772 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3773 80d11f44 j_mayer
                 0x00000000);
3774 80d11f44 j_mayer
    /* XXX : not implemented */
3775 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3776 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3777 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3778 80d11f44 j_mayer
                 0x00000000);
3779 80d11f44 j_mayer
    /* XXX : not implemented */
3780 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3781 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3782 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3783 80d11f44 j_mayer
                 0x00000000);
3784 80d11f44 j_mayer
    /* XXX : not implemented */
3785 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3786 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3787 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3788 80d11f44 j_mayer
                 0x00000000);
3789 80d11f44 j_mayer
    /* XXX : not implemented */
3790 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3791 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3792 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3793 80d11f44 j_mayer
                 0x00000000);
3794 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3795 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3796 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3797 80d11f44 j_mayer
                 0x00000000);
3798 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3799 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3800 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3801 80d11f44 j_mayer
                 0x00000000);
3802 80d11f44 j_mayer
    /* XXX : not implemented */
3803 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3804 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3805 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3806 a750fc0b j_mayer
                 0x00000000);
3807 a750fc0b j_mayer
    /* Memory management */
3808 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3809 a750fc0b j_mayer
    env->nb_tlb = 64;
3810 a750fc0b j_mayer
    env->nb_ways = 1;
3811 a750fc0b j_mayer
    env->id_tlbs = 0;
3812 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3813 f2e63a42 j_mayer
#endif
3814 80d11f44 j_mayer
    init_excp_BookE(env);
3815 d63001d1 j_mayer
    env->dcache_line_size = 32;
3816 d63001d1 j_mayer
    env->icache_line_size = 32;
3817 95070372 Edgar E. Iglesias
    ppc40x_irq_init(env);
3818 ddd1055b Fabien Chouteau
3819 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3820 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(20, 24, 28, 32);
3821 3fc6c082 bellard
}
3822 3fc6c082 bellard
3823 80d11f44 j_mayer
/* PowerPC 460 (guessed)                                                     */
3824 082c6681 j_mayer
#define POWERPC_INSNS_460    (PPC_INSNS_BASE | PPC_STRING |                   \
3825 80d11f44 j_mayer
                              PPC_DCR | PPC_DCRX  | PPC_DCRUX |               \
3826 f4078236 Baojun Wang
                              PPC_WRTEE | PPC_MFAPIDI | PPC_MFTB |            \
3827 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3828 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3829 082c6681 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVA |                  \
3830 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3831 082c6681 j_mayer
                              PPC_440_SPEC)
3832 a5858d7a Alexander Graf
#define POWERPC_INSNS2_460   (PPC_NONE)
3833 80d11f44 j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3834 80d11f44 j_mayer
#define POWERPC_MMU_460      (POWERPC_MMU_BOOKE)
3835 80d11f44 j_mayer
#define POWERPC_EXCP_460     (POWERPC_EXCP_BOOKE)
3836 80d11f44 j_mayer
#define POWERPC_INPUT_460    (PPC_FLAGS_INPUT_BookE)
3837 80d11f44 j_mayer
#define POWERPC_BFDM_460     (bfd_mach_ppc_403)
3838 80d11f44 j_mayer
#define POWERPC_FLAG_460     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3839 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3840 80d11f44 j_mayer
#define check_pow_460        check_pow_nocheck
3841 a750fc0b j_mayer
3842 80d11f44 j_mayer
__attribute__ (( unused ))
3843 80d11f44 j_mayer
static void init_proc_460 (CPUPPCState *env)
3844 3fc6c082 bellard
{
3845 a750fc0b j_mayer
    /* Time base */
3846 a750fc0b j_mayer
    gen_tbl(env);
3847 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3848 a750fc0b j_mayer
    gen_spr_440(env);
3849 80d11f44 j_mayer
    gen_spr_usprgh(env);
3850 80d11f44 j_mayer
    /* Processor identification */
3851 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3852 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3853 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3854 80d11f44 j_mayer
                 0x00000000);
3855 80d11f44 j_mayer
    /* XXX : not implemented */
3856 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3857 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3858 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3859 80d11f44 j_mayer
                 0x00000000);
3860 80d11f44 j_mayer
    /* XXX : not implemented */
3861 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3862 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3863 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3864 80d11f44 j_mayer
                 0x00000000);
3865 80d11f44 j_mayer
    /* XXX : not implemented */
3866 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3867 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3868 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3869 80d11f44 j_mayer
                 0x00000000);
3870 80d11f44 j_mayer
    /* XXX : not implemented */
3871 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3872 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3873 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3874 80d11f44 j_mayer
                 0x00000000);
3875 578bb252 j_mayer
    /* XXX : not implemented */
3876 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3877 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3878 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3879 a750fc0b j_mayer
                 0x00000000);
3880 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3881 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3882 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3883 a750fc0b j_mayer
                 0x00000000);
3884 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3885 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3886 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3887 a750fc0b j_mayer
                 0x00000000);
3888 578bb252 j_mayer
    /* XXX : not implemented */
3889 a750fc0b j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3890 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3891 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
3892 a750fc0b j_mayer
                 0x00000000);
3893 80d11f44 j_mayer
    /* XXX : not implemented */
3894 80d11f44 j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3895 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3896 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3897 80d11f44 j_mayer
                 0x00000000);
3898 a750fc0b j_mayer
    /* Memory management */
3899 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3900 a750fc0b j_mayer
    env->nb_tlb = 64;
3901 a750fc0b j_mayer
    env->nb_ways = 1;
3902 a750fc0b j_mayer
    env->id_tlbs = 0;
3903 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
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 ddd1055b Fabien Chouteau
3910 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
3911 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(20, 24, 28, 32);
3912 3fc6c082 bellard
}
3913 3fc6c082 bellard
3914 80d11f44 j_mayer
/* PowerPC 460F (guessed)                                                    */
3915 082c6681 j_mayer
#define POWERPC_INSNS_460F   (PPC_INSNS_BASE | PPC_STRING |                   \
3916 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FRES | PPC_FLOAT_FSEL |   \
3917 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
3918 f4078236 Baojun Wang
                              PPC_FLOAT_STFIWX | PPC_MFTB |                   \
3919 082c6681 j_mayer
                              PPC_DCR | PPC_DCRX | PPC_DCRUX |                \
3920 082c6681 j_mayer
                              PPC_WRTEE | PPC_MFAPIDI |                       \
3921 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3922 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
3923 082c6681 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVA |                  \
3924 082c6681 j_mayer
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3925 082c6681 j_mayer
                              PPC_440_SPEC)
3926 a5858d7a Alexander Graf
#define POWERPC_INSNS2_460F  (PPC_NONE)
3927 80d11f44 j_mayer
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3928 80d11f44 j_mayer
#define POWERPC_MMU_460F     (POWERPC_MMU_BOOKE)
3929 80d11f44 j_mayer
#define POWERPC_EXCP_460F    (POWERPC_EXCP_BOOKE)
3930 80d11f44 j_mayer
#define POWERPC_INPUT_460F   (PPC_FLAGS_INPUT_BookE)
3931 80d11f44 j_mayer
#define POWERPC_BFDM_460F    (bfd_mach_ppc_403)
3932 80d11f44 j_mayer
#define POWERPC_FLAG_460F    (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3933 4018bae9 j_mayer
                              POWERPC_FLAG_DE | POWERPC_FLAG_BUS_CLK)
3934 80d11f44 j_mayer
#define check_pow_460F       check_pow_nocheck
3935 a750fc0b j_mayer
3936 80d11f44 j_mayer
__attribute__ (( unused ))
3937 80d11f44 j_mayer
static void init_proc_460F (CPUPPCState *env)
3938 3fc6c082 bellard
{
3939 a750fc0b j_mayer
    /* Time base */
3940 a750fc0b j_mayer
    gen_tbl(env);
3941 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000000000FFFFULL);
3942 a750fc0b j_mayer
    gen_spr_440(env);
3943 80d11f44 j_mayer
    gen_spr_usprgh(env);
3944 80d11f44 j_mayer
    /* Processor identification */
3945 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
3946 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3947 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
3948 80d11f44 j_mayer
                 0x00000000);
3949 80d11f44 j_mayer
    /* XXX : not implemented */
3950 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
3951 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3952 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3953 80d11f44 j_mayer
                 0x00000000);
3954 80d11f44 j_mayer
    /* XXX : not implemented */
3955 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
3956 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3957 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3958 80d11f44 j_mayer
                 0x00000000);
3959 80d11f44 j_mayer
    /* XXX : not implemented */
3960 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
3961 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3962 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3963 80d11f44 j_mayer
                 0x00000000);
3964 80d11f44 j_mayer
    /* XXX : not implemented */
3965 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
3966 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3967 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3968 80d11f44 j_mayer
                 0x00000000);
3969 80d11f44 j_mayer
    /* XXX : not implemented */
3970 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3971 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3972 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3973 80d11f44 j_mayer
                 0x00000000);
3974 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3975 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3976 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3977 80d11f44 j_mayer
                 0x00000000);
3978 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3979 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3980 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3981 80d11f44 j_mayer
                 0x00000000);
3982 80d11f44 j_mayer
    /* XXX : not implemented */
3983 80d11f44 j_mayer
    spr_register(env, SPR_440_CCR1, "CCR1",
3984 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
3985 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3986 80d11f44 j_mayer
                 0x00000000);
3987 80d11f44 j_mayer
    /* XXX : not implemented */
3988 80d11f44 j_mayer
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3989 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3990 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
3991 80d11f44 j_mayer
                 0x00000000);
3992 a750fc0b j_mayer
    /* Memory management */
3993 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
3994 a750fc0b j_mayer
    env->nb_tlb = 64;
3995 a750fc0b j_mayer
    env->nb_ways = 1;
3996 a750fc0b j_mayer
    env->id_tlbs = 0;
3997 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
3998 f2e63a42 j_mayer
#endif
3999 e1833e1f j_mayer
    init_excp_BookE(env);
4000 d63001d1 j_mayer
    env->dcache_line_size = 32;
4001 d63001d1 j_mayer
    env->icache_line_size = 32;
4002 a750fc0b j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
4003 ddd1055b Fabien Chouteau
4004 ddd1055b Fabien Chouteau
    SET_FIT_PERIOD(12, 16, 20, 24);
4005 ddd1055b Fabien Chouteau
    SET_WDT_PERIOD(20, 24, 28, 32);
4006 3fc6c082 bellard
}
4007 3fc6c082 bellard
4008 80d11f44 j_mayer
/* Freescale 5xx cores (aka RCPU) */
4009 80d11f44 j_mayer
#define POWERPC_INSNS_MPC5xx (PPC_INSNS_BASE | PPC_STRING |                   \
4010 80d11f44 j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_SYNC |                  \
4011 80d11f44 j_mayer
                              PPC_CACHE_ICBI | PPC_FLOAT | PPC_FLOAT_STFIWX | \
4012 80d11f44 j_mayer
                              PPC_MFTB)
4013 a5858d7a Alexander Graf
#define POWERPC_INSNS2_MPC5xx (PPC_NONE)
4014 80d11f44 j_mayer
#define POWERPC_MSRM_MPC5xx  (0x000000000001FF43ULL)
4015 80d11f44 j_mayer
#define POWERPC_MMU_MPC5xx   (POWERPC_MMU_REAL)
4016 80d11f44 j_mayer
#define POWERPC_EXCP_MPC5xx  (POWERPC_EXCP_603)
4017 80d11f44 j_mayer
#define POWERPC_INPUT_MPC5xx (PPC_FLAGS_INPUT_RCPU)
4018 80d11f44 j_mayer
#define POWERPC_BFDM_MPC5xx  (bfd_mach_ppc_505)
4019 4018bae9 j_mayer
#define POWERPC_FLAG_MPC5xx  (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4020 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4021 80d11f44 j_mayer
#define check_pow_MPC5xx     check_pow_none
4022 80d11f44 j_mayer
4023 80d11f44 j_mayer
__attribute__ (( unused ))
4024 80d11f44 j_mayer
static void init_proc_MPC5xx (CPUPPCState *env)
4025 80d11f44 j_mayer
{
4026 80d11f44 j_mayer
    /* Time base */
4027 80d11f44 j_mayer
    gen_tbl(env);
4028 80d11f44 j_mayer
    gen_spr_5xx_8xx(env);
4029 80d11f44 j_mayer
    gen_spr_5xx(env);
4030 80d11f44 j_mayer
    init_excp_MPC5xx(env);
4031 80d11f44 j_mayer
    env->dcache_line_size = 32;
4032 80d11f44 j_mayer
    env->icache_line_size = 32;
4033 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
4034 80d11f44 j_mayer
}
4035 80d11f44 j_mayer
4036 80d11f44 j_mayer
/* Freescale 8xx cores (aka PowerQUICC) */
4037 80d11f44 j_mayer
#define POWERPC_INSNS_MPC8xx (PPC_INSNS_BASE | PPC_STRING  |                  \
4038 80d11f44 j_mayer
                              PPC_MEM_EIEIO | PPC_MEM_SYNC |                  \
4039 80d11f44 j_mayer
                              PPC_CACHE_ICBI | PPC_MFTB)
4040 a5858d7a Alexander Graf
#define POWERPC_INSNS2_MPC8xx (PPC_NONE)
4041 80d11f44 j_mayer
#define POWERPC_MSRM_MPC8xx  (0x000000000001F673ULL)
4042 80d11f44 j_mayer
#define POWERPC_MMU_MPC8xx   (POWERPC_MMU_MPC8xx)
4043 80d11f44 j_mayer
#define POWERPC_EXCP_MPC8xx  (POWERPC_EXCP_603)
4044 80d11f44 j_mayer
#define POWERPC_INPUT_MPC8xx (PPC_FLAGS_INPUT_RCPU)
4045 80d11f44 j_mayer
#define POWERPC_BFDM_MPC8xx  (bfd_mach_ppc_860)
4046 4018bae9 j_mayer
#define POWERPC_FLAG_MPC8xx  (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4047 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4048 80d11f44 j_mayer
#define check_pow_MPC8xx     check_pow_none
4049 80d11f44 j_mayer
4050 80d11f44 j_mayer
__attribute__ (( unused ))
4051 80d11f44 j_mayer
static void init_proc_MPC8xx (CPUPPCState *env)
4052 80d11f44 j_mayer
{
4053 80d11f44 j_mayer
    /* Time base */
4054 80d11f44 j_mayer
    gen_tbl(env);
4055 80d11f44 j_mayer
    gen_spr_5xx_8xx(env);
4056 80d11f44 j_mayer
    gen_spr_8xx(env);
4057 80d11f44 j_mayer
    init_excp_MPC8xx(env);
4058 80d11f44 j_mayer
    env->dcache_line_size = 32;
4059 80d11f44 j_mayer
    env->icache_line_size = 32;
4060 80d11f44 j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
4061 80d11f44 j_mayer
}
4062 80d11f44 j_mayer
4063 80d11f44 j_mayer
/* Freescale 82xx cores (aka PowerQUICC-II)                                  */
4064 80d11f44 j_mayer
/* PowerPC G2                                                                */
4065 082c6681 j_mayer
#define POWERPC_INSNS_G2     (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4066 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4067 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4068 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4069 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4070 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4071 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4072 a5858d7a Alexander Graf
#define POWERPC_INSNS2_G2    (PPC_NONE)
4073 80d11f44 j_mayer
#define POWERPC_MSRM_G2      (0x000000000006FFF2ULL)
4074 80d11f44 j_mayer
#define POWERPC_MMU_G2       (POWERPC_MMU_SOFT_6xx)
4075 80d11f44 j_mayer
//#define POWERPC_EXCP_G2      (POWERPC_EXCP_G2)
4076 80d11f44 j_mayer
#define POWERPC_INPUT_G2     (PPC_FLAGS_INPUT_6xx)
4077 80d11f44 j_mayer
#define POWERPC_BFDM_G2      (bfd_mach_ppc_ec603e)
4078 80d11f44 j_mayer
#define POWERPC_FLAG_G2      (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4079 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4080 80d11f44 j_mayer
#define check_pow_G2         check_pow_hid0
4081 a750fc0b j_mayer
4082 80d11f44 j_mayer
static void init_proc_G2 (CPUPPCState *env)
4083 3fc6c082 bellard
{
4084 80d11f44 j_mayer
    gen_spr_ne_601(env);
4085 80d11f44 j_mayer
    gen_spr_G2_755(env);
4086 80d11f44 j_mayer
    gen_spr_G2(env);
4087 a750fc0b j_mayer
    /* Time base */
4088 a750fc0b j_mayer
    gen_tbl(env);
4089 bd928eba j_mayer
    /* External access control */
4090 bd928eba j_mayer
    /* XXX : not implemented */
4091 bd928eba j_mayer
    spr_register(env, SPR_EAR, "EAR",
4092 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4093 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4094 bd928eba j_mayer
                 0x00000000);
4095 80d11f44 j_mayer
    /* Hardware implementation register */
4096 80d11f44 j_mayer
    /* XXX : not implemented */
4097 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4098 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4099 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4100 80d11f44 j_mayer
                 0x00000000);
4101 80d11f44 j_mayer
    /* XXX : not implemented */
4102 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4103 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4104 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4105 80d11f44 j_mayer
                 0x00000000);
4106 80d11f44 j_mayer
    /* XXX : not implemented */
4107 80d11f44 j_mayer
    spr_register(env, SPR_HID2, "HID2",
4108 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4109 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4110 80d11f44 j_mayer
                 0x00000000);
4111 a750fc0b j_mayer
    /* Memory management */
4112 80d11f44 j_mayer
    gen_low_BATs(env);
4113 80d11f44 j_mayer
    gen_high_BATs(env);
4114 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4115 80d11f44 j_mayer
    init_excp_G2(env);
4116 d63001d1 j_mayer
    env->dcache_line_size = 32;
4117 d63001d1 j_mayer
    env->icache_line_size = 32;
4118 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
4119 80d11f44 j_mayer
    ppc6xx_irq_init(env);
4120 3fc6c082 bellard
}
4121 a750fc0b j_mayer
4122 80d11f44 j_mayer
/* PowerPC G2LE                                                              */
4123 082c6681 j_mayer
#define POWERPC_INSNS_G2LE   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4124 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4125 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4126 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4127 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4128 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4129 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4130 a5858d7a Alexander Graf
#define POWERPC_INSNS2_G2LE  (PPC_NONE)
4131 80d11f44 j_mayer
#define POWERPC_MSRM_G2LE    (0x000000000007FFF3ULL)
4132 80d11f44 j_mayer
#define POWERPC_MMU_G2LE     (POWERPC_MMU_SOFT_6xx)
4133 80d11f44 j_mayer
#define POWERPC_EXCP_G2LE    (POWERPC_EXCP_G2)
4134 80d11f44 j_mayer
#define POWERPC_INPUT_G2LE   (PPC_FLAGS_INPUT_6xx)
4135 80d11f44 j_mayer
#define POWERPC_BFDM_G2LE    (bfd_mach_ppc_ec603e)
4136 80d11f44 j_mayer
#define POWERPC_FLAG_G2LE    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4137 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4138 80d11f44 j_mayer
#define check_pow_G2LE       check_pow_hid0
4139 a750fc0b j_mayer
4140 80d11f44 j_mayer
static void init_proc_G2LE (CPUPPCState *env)
4141 3fc6c082 bellard
{
4142 80d11f44 j_mayer
    gen_spr_ne_601(env);
4143 80d11f44 j_mayer
    gen_spr_G2_755(env);
4144 80d11f44 j_mayer
    gen_spr_G2(env);
4145 a750fc0b j_mayer
    /* Time base */
4146 a750fc0b j_mayer
    gen_tbl(env);
4147 bd928eba j_mayer
    /* External access control */
4148 bd928eba j_mayer
    /* XXX : not implemented */
4149 bd928eba j_mayer
    spr_register(env, SPR_EAR, "EAR",
4150 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4151 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4152 bd928eba j_mayer
                 0x00000000);
4153 80d11f44 j_mayer
    /* Hardware implementation register */
4154 578bb252 j_mayer
    /* XXX : not implemented */
4155 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4156 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4157 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4158 a750fc0b j_mayer
                 0x00000000);
4159 80d11f44 j_mayer
    /* XXX : not implemented */
4160 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4161 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4162 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4163 a750fc0b j_mayer
                 0x00000000);
4164 578bb252 j_mayer
    /* XXX : not implemented */
4165 80d11f44 j_mayer
    spr_register(env, SPR_HID2, "HID2",
4166 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4167 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4168 a750fc0b j_mayer
                 0x00000000);
4169 a750fc0b j_mayer
    /* Memory management */
4170 80d11f44 j_mayer
    gen_low_BATs(env);
4171 80d11f44 j_mayer
    gen_high_BATs(env);
4172 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4173 80d11f44 j_mayer
    init_excp_G2(env);
4174 d63001d1 j_mayer
    env->dcache_line_size = 32;
4175 d63001d1 j_mayer
    env->icache_line_size = 32;
4176 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
4177 80d11f44 j_mayer
    ppc6xx_irq_init(env);
4178 3fc6c082 bellard
}
4179 3fc6c082 bellard
4180 80d11f44 j_mayer
/* e200 core                                                                 */
4181 80d11f44 j_mayer
/* XXX: unimplemented instructions:
4182 80d11f44 j_mayer
 * dcblc
4183 80d11f44 j_mayer
 * dcbtlst
4184 80d11f44 j_mayer
 * dcbtstls
4185 80d11f44 j_mayer
 * icblc
4186 80d11f44 j_mayer
 * icbtls
4187 80d11f44 j_mayer
 * tlbivax
4188 80d11f44 j_mayer
 * all SPE multiply-accumulate instructions
4189 80d11f44 j_mayer
 */
4190 082c6681 j_mayer
#define POWERPC_INSNS_e200   (PPC_INSNS_BASE | PPC_ISEL |                     \
4191 40569b7e aurel32
                              PPC_SPE | PPC_SPE_SINGLE |                      \
4192 082c6681 j_mayer
                              PPC_WRTEE | PPC_RFDI |                          \
4193 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI |   \
4194 082c6681 j_mayer
                              PPC_CACHE_DCBZ | PPC_CACHE_DCBA |               \
4195 80d11f44 j_mayer
                              PPC_MEM_TLBSYNC | PPC_TLBIVAX |                 \
4196 082c6681 j_mayer
                              PPC_BOOKE)
4197 a5858d7a Alexander Graf
#define POWERPC_INSNS2_e200  (PPC_NONE)
4198 80d11f44 j_mayer
#define POWERPC_MSRM_e200    (0x000000000606FF30ULL)
4199 01662f3e Alexander Graf
#define POWERPC_MMU_e200     (POWERPC_MMU_BOOKE206)
4200 80d11f44 j_mayer
#define POWERPC_EXCP_e200    (POWERPC_EXCP_BOOKE)
4201 80d11f44 j_mayer
#define POWERPC_INPUT_e200   (PPC_FLAGS_INPUT_BookE)
4202 80d11f44 j_mayer
#define POWERPC_BFDM_e200    (bfd_mach_ppc_860)
4203 80d11f44 j_mayer
#define POWERPC_FLAG_e200    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |            \
4204 4018bae9 j_mayer
                              POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |           \
4205 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
4206 80d11f44 j_mayer
#define check_pow_e200       check_pow_hid0
4207 80d11f44 j_mayer
4208 578bb252 j_mayer
__attribute__ (( unused ))
4209 80d11f44 j_mayer
static void init_proc_e200 (CPUPPCState *env)
4210 3fc6c082 bellard
{
4211 e1833e1f j_mayer
    /* Time base */
4212 e1833e1f j_mayer
    gen_tbl(env);
4213 80d11f44 j_mayer
    gen_spr_BookE(env, 0x000000070000FFFFULL);
4214 578bb252 j_mayer
    /* XXX : not implemented */
4215 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_SPEFSCR, "SPEFSCR",
4216 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4217 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4218 e1833e1f j_mayer
                 0x00000000);
4219 80d11f44 j_mayer
    /* Memory management */
4220 01662f3e Alexander Graf
    gen_spr_BookE206(env, 0x0000005D, NULL);
4221 80d11f44 j_mayer
    /* XXX : not implemented */
4222 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4223 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4224 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4225 e1833e1f j_mayer
                 0x00000000);
4226 80d11f44 j_mayer
    /* XXX : not implemented */
4227 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4228 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4229 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4230 e1833e1f j_mayer
                 0x00000000);
4231 578bb252 j_mayer
    /* XXX : not implemented */
4232 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_ALTCTXCR, "ALTCTXCR",
4233 e1833e1f j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4234 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4235 e1833e1f j_mayer
                 0x00000000);
4236 578bb252 j_mayer
    /* XXX : not implemented */
4237 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BUCSR, "BUCSR",
4238 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4239 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4240 80d11f44 j_mayer
                 0x00000000);
4241 80d11f44 j_mayer
    /* XXX : not implemented */
4242 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_CTXCR, "CTXCR",
4243 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4244 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4245 80d11f44 j_mayer
                 0x00000000);
4246 80d11f44 j_mayer
    /* XXX : not implemented */
4247 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_DBCNT, "DBCNT",
4248 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4249 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4250 80d11f44 j_mayer
                 0x00000000);
4251 80d11f44 j_mayer
    /* XXX : not implemented */
4252 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_DBCR3, "DBCR3",
4253 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4254 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4255 80d11f44 j_mayer
                 0x00000000);
4256 80d11f44 j_mayer
    /* XXX : not implemented */
4257 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CFG0, "L1CFG0",
4258 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4259 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4260 80d11f44 j_mayer
                 0x00000000);
4261 80d11f44 j_mayer
    /* XXX : not implemented */
4262 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR0, "L1CSR0",
4263 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4264 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4265 80d11f44 j_mayer
                 0x00000000);
4266 80d11f44 j_mayer
    /* XXX : not implemented */
4267 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1FINV0, "L1FINV0",
4268 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4269 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4270 80d11f44 j_mayer
                 0x00000000);
4271 80d11f44 j_mayer
    /* XXX : not implemented */
4272 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
4273 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4274 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4275 80d11f44 j_mayer
                 0x00000000);
4276 80d11f44 j_mayer
    /* XXX : not implemented */
4277 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
4278 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4279 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4280 80d11f44 j_mayer
                 0x00000000);
4281 80d11f44 j_mayer
    /* XXX : not implemented */
4282 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
4283 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4284 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4285 80d11f44 j_mayer
                 0x00000000);
4286 80d11f44 j_mayer
    /* XXX : not implemented */
4287 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
4288 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4289 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4290 80d11f44 j_mayer
                 0x00000000);
4291 01662f3e Alexander Graf
    /* XXX : not implemented */
4292 01662f3e Alexander Graf
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4293 01662f3e Alexander Graf
                 SPR_NOACCESS, SPR_NOACCESS,
4294 01662f3e Alexander Graf
                 &spr_read_generic, &spr_write_generic,
4295 01662f3e Alexander Graf
                 0x00000000); /* TOFIX */
4296 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DSRR0, "DSRR0",
4297 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4298 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4299 80d11f44 j_mayer
                 0x00000000);
4300 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_DSRR1, "DSRR1",
4301 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4302 e1833e1f j_mayer
                 &spr_read_generic, &spr_write_generic,
4303 e1833e1f j_mayer
                 0x00000000);
4304 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4305 e1833e1f j_mayer
    env->nb_tlb = 64;
4306 e1833e1f j_mayer
    env->nb_ways = 1;
4307 e1833e1f j_mayer
    env->id_tlbs = 0;
4308 1c53accc Alexander Graf
    env->tlb_type = TLB_EMB;
4309 f2e63a42 j_mayer
#endif
4310 80d11f44 j_mayer
    init_excp_e200(env);
4311 d63001d1 j_mayer
    env->dcache_line_size = 32;
4312 d63001d1 j_mayer
    env->icache_line_size = 32;
4313 e1833e1f j_mayer
    /* XXX: TODO: allocate internal IRQ controller */
4314 3fc6c082 bellard
}
4315 a750fc0b j_mayer
4316 80d11f44 j_mayer
/* e300 core                                                                 */
4317 082c6681 j_mayer
#define POWERPC_INSNS_e300   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4318 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4319 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
4320 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4321 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4322 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4323 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4324 a5858d7a Alexander Graf
#define POWERPC_INSNS2_e300  (PPC_NONE)
4325 80d11f44 j_mayer
#define POWERPC_MSRM_e300    (0x000000000007FFF3ULL)
4326 80d11f44 j_mayer
#define POWERPC_MMU_e300     (POWERPC_MMU_SOFT_6xx)
4327 80d11f44 j_mayer
#define POWERPC_EXCP_e300    (POWERPC_EXCP_603)
4328 80d11f44 j_mayer
#define POWERPC_INPUT_e300   (PPC_FLAGS_INPUT_6xx)
4329 80d11f44 j_mayer
#define POWERPC_BFDM_e300    (bfd_mach_ppc_603)
4330 80d11f44 j_mayer
#define POWERPC_FLAG_e300    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4331 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4332 80d11f44 j_mayer
#define check_pow_e300       check_pow_hid0
4333 a750fc0b j_mayer
4334 578bb252 j_mayer
__attribute__ (( unused ))
4335 80d11f44 j_mayer
static void init_proc_e300 (CPUPPCState *env)
4336 3fc6c082 bellard
{
4337 80d11f44 j_mayer
    gen_spr_ne_601(env);
4338 80d11f44 j_mayer
    gen_spr_603(env);
4339 a750fc0b j_mayer
    /* Time base */
4340 a750fc0b j_mayer
    gen_tbl(env);
4341 80d11f44 j_mayer
    /* hardware implementation registers */
4342 80d11f44 j_mayer
    /* XXX : not implemented */
4343 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4344 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4345 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4346 80d11f44 j_mayer
                 0x00000000);
4347 80d11f44 j_mayer
    /* XXX : not implemented */
4348 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4349 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4350 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4351 80d11f44 j_mayer
                 0x00000000);
4352 8daf1781 Thomas Monjalon
    /* XXX : not implemented */
4353 8daf1781 Thomas Monjalon
    spr_register(env, SPR_HID2, "HID2",
4354 8daf1781 Thomas Monjalon
                 SPR_NOACCESS, SPR_NOACCESS,
4355 8daf1781 Thomas Monjalon
                 &spr_read_generic, &spr_write_generic,
4356 8daf1781 Thomas Monjalon
                 0x00000000);
4357 80d11f44 j_mayer
    /* Memory management */
4358 80d11f44 j_mayer
    gen_low_BATs(env);
4359 8daf1781 Thomas Monjalon
    gen_high_BATs(env);
4360 80d11f44 j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4361 80d11f44 j_mayer
    init_excp_603(env);
4362 80d11f44 j_mayer
    env->dcache_line_size = 32;
4363 80d11f44 j_mayer
    env->icache_line_size = 32;
4364 80d11f44 j_mayer
    /* Allocate hardware IRQ controller */
4365 80d11f44 j_mayer
    ppc6xx_irq_init(env);
4366 80d11f44 j_mayer
}
4367 80d11f44 j_mayer
4368 bd5ea513 aurel32
/* e500v1 core                                                               */
4369 bd5ea513 aurel32
#define POWERPC_INSNS_e500v1   (PPC_INSNS_BASE | PPC_ISEL |             \
4370 bd5ea513 aurel32
                                PPC_SPE | PPC_SPE_SINGLE |              \
4371 bd5ea513 aurel32
                                PPC_WRTEE | PPC_RFDI |                  \
4372 bd5ea513 aurel32
                                PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI | \
4373 bd5ea513 aurel32
                                PPC_CACHE_DCBZ | PPC_CACHE_DCBA |       \
4374 53319166 Alexander Graf
                                PPC_MEM_TLBSYNC | PPC_TLBIVAX | PPC_MEM_SYNC)
4375 01662f3e Alexander Graf
#define POWERPC_INSNS2_e500v1  (PPC2_BOOKE206)
4376 bd5ea513 aurel32
#define POWERPC_MSRM_e500v1    (0x000000000606FF30ULL)
4377 01662f3e Alexander Graf
#define POWERPC_MMU_e500v1     (POWERPC_MMU_BOOKE206)
4378 bd5ea513 aurel32
#define POWERPC_EXCP_e500v1    (POWERPC_EXCP_BOOKE)
4379 bd5ea513 aurel32
#define POWERPC_INPUT_e500v1   (PPC_FLAGS_INPUT_BookE)
4380 bd5ea513 aurel32
#define POWERPC_BFDM_e500v1    (bfd_mach_ppc_860)
4381 bd5ea513 aurel32
#define POWERPC_FLAG_e500v1    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |    \
4382 bd5ea513 aurel32
                                POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |   \
4383 bd5ea513 aurel32
                                POWERPC_FLAG_BUS_CLK)
4384 bd5ea513 aurel32
#define check_pow_e500v1       check_pow_hid0
4385 01662f3e Alexander Graf
#define init_proc_e500v1       init_proc_e500v1
4386 bd5ea513 aurel32
4387 bd5ea513 aurel32
/* e500v2 core                                                               */
4388 bd5ea513 aurel32
#define POWERPC_INSNS_e500v2   (PPC_INSNS_BASE | PPC_ISEL |             \
4389 bd5ea513 aurel32
                                PPC_SPE | PPC_SPE_SINGLE | PPC_SPE_DOUBLE |   \
4390 bd5ea513 aurel32
                                PPC_WRTEE | PPC_RFDI |                  \
4391 bd5ea513 aurel32
                                PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI | \
4392 bd5ea513 aurel32
                                PPC_CACHE_DCBZ | PPC_CACHE_DCBA |       \
4393 53319166 Alexander Graf
                                PPC_MEM_TLBSYNC | PPC_TLBIVAX | PPC_MEM_SYNC)
4394 01662f3e Alexander Graf
#define POWERPC_INSNS2_e500v2  (PPC2_BOOKE206)
4395 bd5ea513 aurel32
#define POWERPC_MSRM_e500v2    (0x000000000606FF30ULL)
4396 01662f3e Alexander Graf
#define POWERPC_MMU_e500v2     (POWERPC_MMU_BOOKE206)
4397 bd5ea513 aurel32
#define POWERPC_EXCP_e500v2    (POWERPC_EXCP_BOOKE)
4398 bd5ea513 aurel32
#define POWERPC_INPUT_e500v2   (PPC_FLAGS_INPUT_BookE)
4399 bd5ea513 aurel32
#define POWERPC_BFDM_e500v2    (bfd_mach_ppc_860)
4400 bd5ea513 aurel32
#define POWERPC_FLAG_e500v2    (POWERPC_FLAG_SPE | POWERPC_FLAG_CE |    \
4401 bd5ea513 aurel32
                                POWERPC_FLAG_UBLE | POWERPC_FLAG_DE |   \
4402 bd5ea513 aurel32
                                POWERPC_FLAG_BUS_CLK)
4403 bd5ea513 aurel32
#define check_pow_e500v2       check_pow_hid0
4404 01662f3e Alexander Graf
#define init_proc_e500v2       init_proc_e500v2
4405 80d11f44 j_mayer
4406 f7aa5583 Varun Sethi
/* e500mc core                                                               */
4407 f7aa5583 Varun Sethi
#define POWERPC_INSNS_e500mc   (PPC_INSNS_BASE | PPC_ISEL |                 \
4408 f7aa5583 Varun Sethi
                                PPC_WRTEE | PPC_RFDI | PPC_RFMCI |          \
4409 f7aa5583 Varun Sethi
                                PPC_CACHE | PPC_CACHE_LOCK | PPC_CACHE_ICBI | \
4410 f7aa5583 Varun Sethi
                                PPC_CACHE_DCBZ | PPC_CACHE_DCBA |           \
4411 f7aa5583 Varun Sethi
                                PPC_FLOAT | PPC_FLOAT_FRES |                \
4412 f7aa5583 Varun Sethi
                                PPC_FLOAT_FRSQRTE | PPC_FLOAT_FSEL |        \
4413 f7aa5583 Varun Sethi
                                PPC_FLOAT_STFIWX | PPC_WAIT |               \
4414 53319166 Alexander Graf
                                PPC_MEM_TLBSYNC | PPC_TLBIVAX | PPC_MEM_SYNC)
4415 f7aa5583 Varun Sethi
#define POWERPC_INSNS2_e500mc  (PPC2_BOOKE206)
4416 f7aa5583 Varun Sethi
#define POWERPC_MSRM_e500mc    (0x000000001402FB36ULL)
4417 f7aa5583 Varun Sethi
#define POWERPC_MMU_e500mc     (POWERPC_MMU_BOOKE206)
4418 f7aa5583 Varun Sethi
#define POWERPC_EXCP_e500mc    (POWERPC_EXCP_BOOKE)
4419 f7aa5583 Varun Sethi
#define POWERPC_INPUT_e500mc   (PPC_FLAGS_INPUT_BookE)
4420 f7aa5583 Varun Sethi
/* Fixme: figure out the correct flag for e500mc */
4421 f7aa5583 Varun Sethi
#define POWERPC_BFDM_e500mc    (bfd_mach_ppc_e500)
4422 f7aa5583 Varun Sethi
#define POWERPC_FLAG_e500mc    (POWERPC_FLAG_CE | POWERPC_FLAG_DE | \
4423 f7aa5583 Varun Sethi
                                POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4424 f7aa5583 Varun Sethi
#define check_pow_e500mc       check_pow_none
4425 f7aa5583 Varun Sethi
#define init_proc_e500mc       init_proc_e500mc
4426 f7aa5583 Varun Sethi
4427 f7aa5583 Varun Sethi
enum fsl_e500_version {
4428 f7aa5583 Varun Sethi
    fsl_e500v1,
4429 f7aa5583 Varun Sethi
    fsl_e500v2,
4430 f7aa5583 Varun Sethi
    fsl_e500mc,
4431 f7aa5583 Varun Sethi
};
4432 f7aa5583 Varun Sethi
4433 01662f3e Alexander Graf
static void init_proc_e500 (CPUPPCState *env, int version)
4434 80d11f44 j_mayer
{
4435 01662f3e Alexander Graf
    uint32_t tlbncfg[2];
4436 2c9732db Alexander Graf
    uint64_t ivor_mask = 0x0000000F0000FFFFULL;
4437 01662f3e Alexander Graf
#if !defined(CONFIG_USER_ONLY)
4438 01662f3e Alexander Graf
    int i;
4439 01662f3e Alexander Graf
#endif
4440 01662f3e Alexander Graf
4441 80d11f44 j_mayer
    /* Time base */
4442 80d11f44 j_mayer
    gen_tbl(env);
4443 01662f3e Alexander Graf
    /*
4444 01662f3e Alexander Graf
     * XXX The e500 doesn't implement IVOR7 and IVOR9, but doesn't
4445 01662f3e Alexander Graf
     *     complain when accessing them.
4446 01662f3e Alexander Graf
     * gen_spr_BookE(env, 0x0000000F0000FD7FULL);
4447 01662f3e Alexander Graf
     */
4448 2c9732db Alexander Graf
    if (version == fsl_e500mc) {
4449 2c9732db Alexander Graf
        ivor_mask = 0x000003FE0000FFFFULL;
4450 2c9732db Alexander Graf
    }
4451 2c9732db Alexander Graf
    gen_spr_BookE(env, ivor_mask);
4452 80d11f44 j_mayer
    /* Processor identification */
4453 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_PIR, "PIR",
4454 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4455 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_pir,
4456 80d11f44 j_mayer
                 0x00000000);
4457 80d11f44 j_mayer
    /* XXX : not implemented */
4458 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_SPEFSCR, "SPEFSCR",
4459 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4460 d34defbc aurel32
                 &spr_read_spefscr, &spr_write_spefscr,
4461 80d11f44 j_mayer
                 0x00000000);
4462 80d11f44 j_mayer
    /* Memory management */
4463 80d11f44 j_mayer
#if !defined(CONFIG_USER_ONLY)
4464 80d11f44 j_mayer
    env->nb_pids = 3;
4465 01662f3e Alexander Graf
    env->nb_ways = 2;
4466 01662f3e Alexander Graf
    env->id_tlbs = 0;
4467 01662f3e Alexander Graf
    switch (version) {
4468 f7aa5583 Varun Sethi
    case fsl_e500v1:
4469 01662f3e Alexander Graf
        /* e500v1 */
4470 01662f3e Alexander Graf
        tlbncfg[0] = gen_tlbncfg(2, 1, 1, 0, 256);
4471 01662f3e Alexander Graf
        tlbncfg[1] = gen_tlbncfg(16, 1, 9, TLBnCFG_AVAIL | TLBnCFG_IPROT, 16);
4472 f7aa5583 Varun Sethi
        env->dcache_line_size = 32;
4473 f7aa5583 Varun Sethi
        env->icache_line_size = 32;
4474 01662f3e Alexander Graf
        break;
4475 f7aa5583 Varun Sethi
    case fsl_e500v2:
4476 01662f3e Alexander Graf
        /* e500v2 */
4477 01662f3e Alexander Graf
        tlbncfg[0] = gen_tlbncfg(4, 1, 1, 0, 512);
4478 01662f3e Alexander Graf
        tlbncfg[1] = gen_tlbncfg(16, 1, 12, TLBnCFG_AVAIL | TLBnCFG_IPROT, 16);
4479 f7aa5583 Varun Sethi
        env->dcache_line_size = 32;
4480 f7aa5583 Varun Sethi
        env->icache_line_size = 32;
4481 f7aa5583 Varun Sethi
        break;
4482 f7aa5583 Varun Sethi
    case fsl_e500mc:
4483 f7aa5583 Varun Sethi
        /* e500mc */
4484 f7aa5583 Varun Sethi
        tlbncfg[0] = gen_tlbncfg(4, 1, 1, 0, 512);
4485 f7aa5583 Varun Sethi
        tlbncfg[1] = gen_tlbncfg(64, 1, 12, TLBnCFG_AVAIL | TLBnCFG_IPROT, 64);
4486 f7aa5583 Varun Sethi
        env->dcache_line_size = 64;
4487 f7aa5583 Varun Sethi
        env->icache_line_size = 64;
4488 01662f3e Alexander Graf
        break;
4489 01662f3e Alexander Graf
    default:
4490 01662f3e Alexander Graf
        cpu_abort(env, "Unknown CPU: " TARGET_FMT_lx "\n", env->spr[SPR_PVR]);
4491 01662f3e Alexander Graf
    }
4492 80d11f44 j_mayer
#endif
4493 01662f3e Alexander Graf
    gen_spr_BookE206(env, 0x000000DF, tlbncfg);
4494 80d11f44 j_mayer
    /* XXX : not implemented */
4495 80d11f44 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4496 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4497 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4498 80d11f44 j_mayer
                 0x00000000);
4499 80d11f44 j_mayer
    /* XXX : not implemented */
4500 80d11f44 j_mayer
    spr_register(env, SPR_HID1, "HID1",
4501 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4502 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4503 80d11f44 j_mayer
                 0x00000000);
4504 80d11f44 j_mayer
    /* XXX : not implemented */
4505 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BBEAR, "BBEAR",
4506 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4507 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4508 80d11f44 j_mayer
                 0x00000000);
4509 80d11f44 j_mayer
    /* XXX : not implemented */
4510 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BBTAR, "BBTAR",
4511 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4512 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4513 80d11f44 j_mayer
                 0x00000000);
4514 80d11f44 j_mayer
    /* XXX : not implemented */
4515 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_MCAR, "MCAR",
4516 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4517 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4518 80d11f44 j_mayer
                 0x00000000);
4519 578bb252 j_mayer
    /* XXX : not implemented */
4520 a750fc0b j_mayer
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
4521 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4522 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4523 a750fc0b j_mayer
                 0x00000000);
4524 80d11f44 j_mayer
    /* XXX : not implemented */
4525 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_NPIDR, "NPIDR",
4526 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4527 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4528 a750fc0b j_mayer
                 0x00000000);
4529 80d11f44 j_mayer
    /* XXX : not implemented */
4530 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_BUCSR, "BUCSR",
4531 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4532 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4533 a750fc0b j_mayer
                 0x00000000);
4534 578bb252 j_mayer
    /* XXX : not implemented */
4535 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CFG0, "L1CFG0",
4536 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4537 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4538 a750fc0b j_mayer
                 0x00000000);
4539 578bb252 j_mayer
    /* XXX : not implemented */
4540 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR0, "L1CSR0",
4541 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4542 01662f3e Alexander Graf
                 &spr_read_generic, &spr_write_e500_l1csr0,
4543 80d11f44 j_mayer
                 0x00000000);
4544 80d11f44 j_mayer
    /* XXX : not implemented */
4545 80d11f44 j_mayer
    spr_register(env, SPR_Exxx_L1CSR1, "L1CSR1",
4546 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4547 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4548 80d11f44 j_mayer
                 0x00000000);
4549 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
4550 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4551 80d11f44 j_mayer
                 &spr_read_generic, &spr_write_generic,
4552 80d11f44 j_mayer
                 0x00000000);
4553 80d11f44 j_mayer
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
4554 80d11f44 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4555 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4556 a750fc0b j_mayer
                 0x00000000);
4557 01662f3e Alexander Graf
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4558 01662f3e Alexander Graf
                 SPR_NOACCESS, SPR_NOACCESS,
4559 01662f3e Alexander Graf
                 &spr_read_generic, &spr_write_booke206_mmucsr0,
4560 01662f3e Alexander Graf
                 0x00000000);
4561 01662f3e Alexander Graf
4562 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
4563 01662f3e Alexander Graf
    env->nb_tlb = 0;
4564 1c53accc Alexander Graf
    env->tlb_type = TLB_MAS;
4565 01662f3e Alexander Graf
    for (i = 0; i < BOOKE206_MAX_TLBN; i++) {
4566 01662f3e Alexander Graf
        env->nb_tlb += booke206_tlb_size(env, i);
4567 01662f3e Alexander Graf
    }
4568 f2e63a42 j_mayer
#endif
4569 01662f3e Alexander Graf
4570 80d11f44 j_mayer
    init_excp_e200(env);
4571 9fdc60bf aurel32
    /* Allocate hardware IRQ controller */
4572 9fdc60bf aurel32
    ppce500_irq_init(env);
4573 3fc6c082 bellard
}
4574 a750fc0b j_mayer
4575 01662f3e Alexander Graf
static void init_proc_e500v1(CPUPPCState *env)
4576 01662f3e Alexander Graf
{
4577 f7aa5583 Varun Sethi
    init_proc_e500(env, fsl_e500v1);
4578 01662f3e Alexander Graf
}
4579 01662f3e Alexander Graf
4580 01662f3e Alexander Graf
static void init_proc_e500v2(CPUPPCState *env)
4581 01662f3e Alexander Graf
{
4582 f7aa5583 Varun Sethi
    init_proc_e500(env, fsl_e500v2);
4583 f7aa5583 Varun Sethi
}
4584 f7aa5583 Varun Sethi
4585 f7aa5583 Varun Sethi
static void init_proc_e500mc(CPUPPCState *env)
4586 f7aa5583 Varun Sethi
{
4587 f7aa5583 Varun Sethi
    init_proc_e500(env, fsl_e500mc);
4588 01662f3e Alexander Graf
}
4589 01662f3e Alexander Graf
4590 a750fc0b j_mayer
/* Non-embedded PowerPC                                                      */
4591 a750fc0b j_mayer
4592 a750fc0b j_mayer
/* POWER : same as 601, without mfmsr, mfsr                                  */
4593 a750fc0b j_mayer
#if defined(TODO)
4594 a750fc0b j_mayer
#define POWERPC_INSNS_POWER  (XXX_TODO)
4595 a750fc0b j_mayer
/* POWER RSC (from RAD6000) */
4596 a750fc0b j_mayer
#define POWERPC_MSRM_POWER   (0x00000000FEF0ULL)
4597 a750fc0b j_mayer
#endif /* TODO */
4598 a750fc0b j_mayer
4599 a750fc0b j_mayer
/* PowerPC 601                                                               */
4600 082c6681 j_mayer
#define POWERPC_INSNS_601    (PPC_INSNS_BASE | PPC_STRING | PPC_POWER_BR |    \
4601 082c6681 j_mayer
                              PPC_FLOAT |                                     \
4602 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4603 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_MEM_TLBIE |  \
4604 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4605 a5858d7a Alexander Graf
#define POWERPC_INSNS2_601   (PPC_NONE)
4606 25ba3a68 j_mayer
#define POWERPC_MSRM_601     (0x000000000000FD70ULL)
4607 082c6681 j_mayer
#define POWERPC_MSRR_601     (0x0000000000001040ULL)
4608 faadf50e j_mayer
//#define POWERPC_MMU_601      (POWERPC_MMU_601)
4609 a750fc0b j_mayer
//#define POWERPC_EXCP_601     (POWERPC_EXCP_601)
4610 a750fc0b j_mayer
#define POWERPC_INPUT_601    (PPC_FLAGS_INPUT_6xx)
4611 237c0af0 j_mayer
#define POWERPC_BFDM_601     (bfd_mach_ppc_601)
4612 4018bae9 j_mayer
#define POWERPC_FLAG_601     (POWERPC_FLAG_SE | POWERPC_FLAG_RTC_CLK)
4613 2f462816 j_mayer
#define check_pow_601        check_pow_none
4614 a750fc0b j_mayer
4615 a750fc0b j_mayer
static void init_proc_601 (CPUPPCState *env)
4616 3fc6c082 bellard
{
4617 a750fc0b j_mayer
    gen_spr_ne_601(env);
4618 a750fc0b j_mayer
    gen_spr_601(env);
4619 a750fc0b j_mayer
    /* Hardware implementation registers */
4620 a750fc0b j_mayer
    /* XXX : not implemented */
4621 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4622 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4623 056401ea j_mayer
                 &spr_read_generic, &spr_write_hid0_601,
4624 faadf50e j_mayer
                 0x80010080);
4625 a750fc0b j_mayer
    /* XXX : not implemented */
4626 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4627 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4628 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4629 a750fc0b j_mayer
                 0x00000000);
4630 a750fc0b j_mayer
    /* XXX : not implemented */
4631 a750fc0b j_mayer
    spr_register(env, SPR_601_HID2, "HID2",
4632 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4633 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4634 a750fc0b j_mayer
                 0x00000000);
4635 a750fc0b j_mayer
    /* XXX : not implemented */
4636 a750fc0b j_mayer
    spr_register(env, SPR_601_HID5, "HID5",
4637 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4638 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4639 a750fc0b j_mayer
                 0x00000000);
4640 a750fc0b j_mayer
    /* Memory management */
4641 e1833e1f j_mayer
    init_excp_601(env);
4642 082c6681 j_mayer
    /* XXX: beware that dcache line size is 64 
4643 082c6681 j_mayer
     *      but dcbz uses 32 bytes "sectors"
4644 082c6681 j_mayer
     * XXX: this breaks clcs instruction !
4645 082c6681 j_mayer
     */
4646 082c6681 j_mayer
    env->dcache_line_size = 32;
4647 d63001d1 j_mayer
    env->icache_line_size = 64;
4648 faadf50e j_mayer
    /* Allocate hardware IRQ controller */
4649 faadf50e j_mayer
    ppc6xx_irq_init(env);
4650 3fc6c082 bellard
}
4651 3fc6c082 bellard
4652 082c6681 j_mayer
/* PowerPC 601v                                                              */
4653 082c6681 j_mayer
#define POWERPC_INSNS_601v   (PPC_INSNS_BASE | PPC_STRING | PPC_POWER_BR |    \
4654 082c6681 j_mayer
                              PPC_FLOAT |                                     \
4655 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4656 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_MEM_TLBIE |  \
4657 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4658 a5858d7a Alexander Graf
#define POWERPC_INSNS2_601v  (PPC_NONE)
4659 082c6681 j_mayer
#define POWERPC_MSRM_601v    (0x000000000000FD70ULL)
4660 082c6681 j_mayer
#define POWERPC_MSRR_601v    (0x0000000000001040ULL)
4661 082c6681 j_mayer
#define POWERPC_MMU_601v     (POWERPC_MMU_601)
4662 082c6681 j_mayer
#define POWERPC_EXCP_601v    (POWERPC_EXCP_601)
4663 082c6681 j_mayer
#define POWERPC_INPUT_601v   (PPC_FLAGS_INPUT_6xx)
4664 082c6681 j_mayer
#define POWERPC_BFDM_601v    (bfd_mach_ppc_601)
4665 082c6681 j_mayer
#define POWERPC_FLAG_601v    (POWERPC_FLAG_SE | POWERPC_FLAG_RTC_CLK)
4666 082c6681 j_mayer
#define check_pow_601v       check_pow_none
4667 082c6681 j_mayer
4668 082c6681 j_mayer
static void init_proc_601v (CPUPPCState *env)
4669 082c6681 j_mayer
{
4670 082c6681 j_mayer
    init_proc_601(env);
4671 082c6681 j_mayer
    /* XXX : not implemented */
4672 082c6681 j_mayer
    spr_register(env, SPR_601_HID15, "HID15",
4673 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4674 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4675 082c6681 j_mayer
                 0x00000000);
4676 082c6681 j_mayer
}
4677 082c6681 j_mayer
4678 a750fc0b j_mayer
/* PowerPC 602                                                               */
4679 082c6681 j_mayer
#define POWERPC_INSNS_602    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4680 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4681 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4682 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4683 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4684 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_6xx_TLB | PPC_MEM_TLBSYNC | \
4685 12de9a39 j_mayer
                              PPC_SEGMENT | PPC_602_SPEC)
4686 a5858d7a Alexander Graf
#define POWERPC_INSNS2_602   (PPC_NONE)
4687 082c6681 j_mayer
#define POWERPC_MSRM_602     (0x0000000000C7FF73ULL)
4688 082c6681 j_mayer
/* XXX: 602 MMU is quite specific. Should add a special case */
4689 a750fc0b j_mayer
#define POWERPC_MMU_602      (POWERPC_MMU_SOFT_6xx)
4690 a750fc0b j_mayer
//#define POWERPC_EXCP_602     (POWERPC_EXCP_602)
4691 a750fc0b j_mayer
#define POWERPC_INPUT_602    (PPC_FLAGS_INPUT_6xx)
4692 237c0af0 j_mayer
#define POWERPC_BFDM_602     (bfd_mach_ppc_602)
4693 25ba3a68 j_mayer
#define POWERPC_FLAG_602     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4694 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4695 2f462816 j_mayer
#define check_pow_602        check_pow_hid0
4696 a750fc0b j_mayer
4697 a750fc0b j_mayer
static void init_proc_602 (CPUPPCState *env)
4698 3fc6c082 bellard
{
4699 a750fc0b j_mayer
    gen_spr_ne_601(env);
4700 a750fc0b j_mayer
    gen_spr_602(env);
4701 a750fc0b j_mayer
    /* Time base */
4702 a750fc0b j_mayer
    gen_tbl(env);
4703 a750fc0b j_mayer
    /* hardware implementation registers */
4704 a750fc0b j_mayer
    /* XXX : not implemented */
4705 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4706 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4707 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4708 a750fc0b j_mayer
                 0x00000000);
4709 a750fc0b j_mayer
    /* XXX : not implemented */
4710 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4711 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4712 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4713 a750fc0b j_mayer
                 0x00000000);
4714 a750fc0b j_mayer
    /* Memory management */
4715 a750fc0b j_mayer
    gen_low_BATs(env);
4716 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4717 e1833e1f j_mayer
    init_excp_602(env);
4718 d63001d1 j_mayer
    env->dcache_line_size = 32;
4719 d63001d1 j_mayer
    env->icache_line_size = 32;
4720 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4721 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4722 a750fc0b j_mayer
}
4723 3fc6c082 bellard
4724 a750fc0b j_mayer
/* PowerPC 603                                                               */
4725 082c6681 j_mayer
#define POWERPC_INSNS_603    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4726 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4727 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4728 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4729 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4730 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4731 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4732 a5858d7a Alexander Graf
#define POWERPC_INSNS2_603   (PPC_NONE)
4733 25ba3a68 j_mayer
#define POWERPC_MSRM_603     (0x000000000007FF73ULL)
4734 a750fc0b j_mayer
#define POWERPC_MMU_603      (POWERPC_MMU_SOFT_6xx)
4735 a750fc0b j_mayer
//#define POWERPC_EXCP_603     (POWERPC_EXCP_603)
4736 a750fc0b j_mayer
#define POWERPC_INPUT_603    (PPC_FLAGS_INPUT_6xx)
4737 237c0af0 j_mayer
#define POWERPC_BFDM_603     (bfd_mach_ppc_603)
4738 25ba3a68 j_mayer
#define POWERPC_FLAG_603     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4739 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4740 2f462816 j_mayer
#define check_pow_603        check_pow_hid0
4741 a750fc0b j_mayer
4742 a750fc0b j_mayer
static void init_proc_603 (CPUPPCState *env)
4743 a750fc0b j_mayer
{
4744 a750fc0b j_mayer
    gen_spr_ne_601(env);
4745 a750fc0b j_mayer
    gen_spr_603(env);
4746 a750fc0b j_mayer
    /* Time base */
4747 a750fc0b j_mayer
    gen_tbl(env);
4748 a750fc0b j_mayer
    /* hardware implementation registers */
4749 a750fc0b j_mayer
    /* XXX : not implemented */
4750 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4751 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4752 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4753 a750fc0b j_mayer
                 0x00000000);
4754 a750fc0b j_mayer
    /* XXX : not implemented */
4755 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4756 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4757 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4758 a750fc0b j_mayer
                 0x00000000);
4759 a750fc0b j_mayer
    /* Memory management */
4760 a750fc0b j_mayer
    gen_low_BATs(env);
4761 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4762 e1833e1f j_mayer
    init_excp_603(env);
4763 d63001d1 j_mayer
    env->dcache_line_size = 32;
4764 d63001d1 j_mayer
    env->icache_line_size = 32;
4765 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4766 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4767 3fc6c082 bellard
}
4768 3fc6c082 bellard
4769 a750fc0b j_mayer
/* PowerPC 603e                                                              */
4770 082c6681 j_mayer
#define POWERPC_INSNS_603E   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4771 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4772 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4773 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4774 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4775 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
4776 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4777 a5858d7a Alexander Graf
#define POWERPC_INSNS2_603E  (PPC_NONE)
4778 a750fc0b j_mayer
#define POWERPC_MSRM_603E    (0x000000000007FF73ULL)
4779 a750fc0b j_mayer
#define POWERPC_MMU_603E     (POWERPC_MMU_SOFT_6xx)
4780 a750fc0b j_mayer
//#define POWERPC_EXCP_603E    (POWERPC_EXCP_603E)
4781 a750fc0b j_mayer
#define POWERPC_INPUT_603E   (PPC_FLAGS_INPUT_6xx)
4782 237c0af0 j_mayer
#define POWERPC_BFDM_603E    (bfd_mach_ppc_ec603e)
4783 25ba3a68 j_mayer
#define POWERPC_FLAG_603E    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
4784 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_BUS_CLK)
4785 2f462816 j_mayer
#define check_pow_603E       check_pow_hid0
4786 a750fc0b j_mayer
4787 a750fc0b j_mayer
static void init_proc_603E (CPUPPCState *env)
4788 a750fc0b j_mayer
{
4789 a750fc0b j_mayer
    gen_spr_ne_601(env);
4790 a750fc0b j_mayer
    gen_spr_603(env);
4791 a750fc0b j_mayer
    /* Time base */
4792 a750fc0b j_mayer
    gen_tbl(env);
4793 a750fc0b j_mayer
    /* hardware implementation registers */
4794 a750fc0b j_mayer
    /* XXX : not implemented */
4795 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4796 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4797 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4798 a750fc0b j_mayer
                 0x00000000);
4799 a750fc0b j_mayer
    /* XXX : not implemented */
4800 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4801 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4802 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4803 a750fc0b j_mayer
                 0x00000000);
4804 a750fc0b j_mayer
    /* XXX : not implemented */
4805 a750fc0b j_mayer
    spr_register(env, SPR_IABR, "IABR",
4806 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4807 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4808 a750fc0b j_mayer
                 0x00000000);
4809 a750fc0b j_mayer
    /* Memory management */
4810 a750fc0b j_mayer
    gen_low_BATs(env);
4811 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
4812 e1833e1f j_mayer
    init_excp_603(env);
4813 d63001d1 j_mayer
    env->dcache_line_size = 32;
4814 d63001d1 j_mayer
    env->icache_line_size = 32;
4815 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4816 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4817 a750fc0b j_mayer
}
4818 a750fc0b j_mayer
4819 a750fc0b j_mayer
/* PowerPC 604                                                               */
4820 082c6681 j_mayer
#define POWERPC_INSNS_604    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4821 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4822 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4823 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4824 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4825 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4826 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4827 a5858d7a Alexander Graf
#define POWERPC_INSNS2_604   (PPC_NONE)
4828 a750fc0b j_mayer
#define POWERPC_MSRM_604     (0x000000000005FF77ULL)
4829 a750fc0b j_mayer
#define POWERPC_MMU_604      (POWERPC_MMU_32B)
4830 a750fc0b j_mayer
//#define POWERPC_EXCP_604     (POWERPC_EXCP_604)
4831 a750fc0b j_mayer
#define POWERPC_INPUT_604    (PPC_FLAGS_INPUT_6xx)
4832 237c0af0 j_mayer
#define POWERPC_BFDM_604     (bfd_mach_ppc_604)
4833 25ba3a68 j_mayer
#define POWERPC_FLAG_604     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4834 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4835 2f462816 j_mayer
#define check_pow_604        check_pow_nocheck
4836 a750fc0b j_mayer
4837 a750fc0b j_mayer
static void init_proc_604 (CPUPPCState *env)
4838 a750fc0b j_mayer
{
4839 a750fc0b j_mayer
    gen_spr_ne_601(env);
4840 a750fc0b j_mayer
    gen_spr_604(env);
4841 a750fc0b j_mayer
    /* Time base */
4842 a750fc0b j_mayer
    gen_tbl(env);
4843 a750fc0b j_mayer
    /* Hardware implementation registers */
4844 a750fc0b j_mayer
    /* XXX : not implemented */
4845 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4846 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4847 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4848 a750fc0b j_mayer
                 0x00000000);
4849 082c6681 j_mayer
    /* Memory management */
4850 082c6681 j_mayer
    gen_low_BATs(env);
4851 082c6681 j_mayer
    init_excp_604(env);
4852 082c6681 j_mayer
    env->dcache_line_size = 32;
4853 082c6681 j_mayer
    env->icache_line_size = 32;
4854 082c6681 j_mayer
    /* Allocate hardware IRQ controller */
4855 082c6681 j_mayer
    ppc6xx_irq_init(env);
4856 082c6681 j_mayer
}
4857 082c6681 j_mayer
4858 082c6681 j_mayer
/* PowerPC 604E                                                              */
4859 082c6681 j_mayer
#define POWERPC_INSNS_604E   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4860 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4861 082c6681 j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4862 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4863 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4864 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4865 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4866 a5858d7a Alexander Graf
#define POWERPC_INSNS2_604E  (PPC_NONE)
4867 082c6681 j_mayer
#define POWERPC_MSRM_604E    (0x000000000005FF77ULL)
4868 082c6681 j_mayer
#define POWERPC_MMU_604E     (POWERPC_MMU_32B)
4869 082c6681 j_mayer
#define POWERPC_EXCP_604E    (POWERPC_EXCP_604)
4870 082c6681 j_mayer
#define POWERPC_INPUT_604E   (PPC_FLAGS_INPUT_6xx)
4871 082c6681 j_mayer
#define POWERPC_BFDM_604E    (bfd_mach_ppc_604)
4872 082c6681 j_mayer
#define POWERPC_FLAG_604E    (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4873 082c6681 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4874 082c6681 j_mayer
#define check_pow_604E       check_pow_nocheck
4875 082c6681 j_mayer
4876 082c6681 j_mayer
static void init_proc_604E (CPUPPCState *env)
4877 082c6681 j_mayer
{
4878 082c6681 j_mayer
    gen_spr_ne_601(env);
4879 082c6681 j_mayer
    gen_spr_604(env);
4880 082c6681 j_mayer
    /* XXX : not implemented */
4881 082c6681 j_mayer
    spr_register(env, SPR_MMCR1, "MMCR1",
4882 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4883 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4884 082c6681 j_mayer
                 0x00000000);
4885 082c6681 j_mayer
    /* XXX : not implemented */
4886 082c6681 j_mayer
    spr_register(env, SPR_PMC3, "PMC3",
4887 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4888 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4889 082c6681 j_mayer
                 0x00000000);
4890 082c6681 j_mayer
    /* XXX : not implemented */
4891 082c6681 j_mayer
    spr_register(env, SPR_PMC4, "PMC4",
4892 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4893 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4894 082c6681 j_mayer
                 0x00000000);
4895 082c6681 j_mayer
    /* Time base */
4896 082c6681 j_mayer
    gen_tbl(env);
4897 082c6681 j_mayer
    /* Hardware implementation registers */
4898 082c6681 j_mayer
    /* XXX : not implemented */
4899 082c6681 j_mayer
    spr_register(env, SPR_HID0, "HID0",
4900 082c6681 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4901 082c6681 j_mayer
                 &spr_read_generic, &spr_write_generic,
4902 082c6681 j_mayer
                 0x00000000);
4903 a750fc0b j_mayer
    /* XXX : not implemented */
4904 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4905 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4906 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4907 a750fc0b j_mayer
                 0x00000000);
4908 a750fc0b j_mayer
    /* Memory management */
4909 a750fc0b j_mayer
    gen_low_BATs(env);
4910 e1833e1f j_mayer
    init_excp_604(env);
4911 d63001d1 j_mayer
    env->dcache_line_size = 32;
4912 d63001d1 j_mayer
    env->icache_line_size = 32;
4913 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4914 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4915 a750fc0b j_mayer
}
4916 a750fc0b j_mayer
4917 bd928eba j_mayer
/* PowerPC 740                                                               */
4918 bd928eba j_mayer
#define POWERPC_INSNS_740    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4919 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4920 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4921 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4922 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4923 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4924 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4925 a5858d7a Alexander Graf
#define POWERPC_INSNS2_740   (PPC_NONE)
4926 bd928eba j_mayer
#define POWERPC_MSRM_740     (0x000000000005FF77ULL)
4927 bd928eba j_mayer
#define POWERPC_MMU_740      (POWERPC_MMU_32B)
4928 bd928eba j_mayer
#define POWERPC_EXCP_740     (POWERPC_EXCP_7x0)
4929 bd928eba j_mayer
#define POWERPC_INPUT_740    (PPC_FLAGS_INPUT_6xx)
4930 bd928eba j_mayer
#define POWERPC_BFDM_740     (bfd_mach_ppc_750)
4931 bd928eba j_mayer
#define POWERPC_FLAG_740     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4932 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4933 bd928eba j_mayer
#define check_pow_740        check_pow_hid0
4934 a750fc0b j_mayer
4935 bd928eba j_mayer
static void init_proc_740 (CPUPPCState *env)
4936 a750fc0b j_mayer
{
4937 a750fc0b j_mayer
    gen_spr_ne_601(env);
4938 a750fc0b j_mayer
    gen_spr_7xx(env);
4939 a750fc0b j_mayer
    /* Time base */
4940 a750fc0b j_mayer
    gen_tbl(env);
4941 a750fc0b j_mayer
    /* Thermal management */
4942 a750fc0b j_mayer
    gen_spr_thrm(env);
4943 a750fc0b j_mayer
    /* Hardware implementation registers */
4944 a750fc0b j_mayer
    /* XXX : not implemented */
4945 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
4946 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4947 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4948 a750fc0b j_mayer
                 0x00000000);
4949 a750fc0b j_mayer
    /* XXX : not implemented */
4950 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
4951 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4952 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
4953 a750fc0b j_mayer
                 0x00000000);
4954 a750fc0b j_mayer
    /* Memory management */
4955 a750fc0b j_mayer
    gen_low_BATs(env);
4956 e1833e1f j_mayer
    init_excp_7x0(env);
4957 d63001d1 j_mayer
    env->dcache_line_size = 32;
4958 d63001d1 j_mayer
    env->icache_line_size = 32;
4959 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
4960 a750fc0b j_mayer
    ppc6xx_irq_init(env);
4961 a750fc0b j_mayer
}
4962 a750fc0b j_mayer
4963 bd928eba j_mayer
/* PowerPC 750                                                               */
4964 bd928eba j_mayer
#define POWERPC_INSNS_750    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
4965 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
4966 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
4967 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
4968 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
4969 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
4970 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
4971 a5858d7a Alexander Graf
#define POWERPC_INSNS2_750   (PPC_NONE)
4972 bd928eba j_mayer
#define POWERPC_MSRM_750     (0x000000000005FF77ULL)
4973 bd928eba j_mayer
#define POWERPC_MMU_750      (POWERPC_MMU_32B)
4974 bd928eba j_mayer
#define POWERPC_EXCP_750     (POWERPC_EXCP_7x0)
4975 bd928eba j_mayer
#define POWERPC_INPUT_750    (PPC_FLAGS_INPUT_6xx)
4976 bd928eba j_mayer
#define POWERPC_BFDM_750     (bfd_mach_ppc_750)
4977 bd928eba j_mayer
#define POWERPC_FLAG_750     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
4978 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
4979 bd928eba j_mayer
#define check_pow_750        check_pow_hid0
4980 bd928eba j_mayer
4981 bd928eba j_mayer
static void init_proc_750 (CPUPPCState *env)
4982 bd928eba j_mayer
{
4983 bd928eba j_mayer
    gen_spr_ne_601(env);
4984 bd928eba j_mayer
    gen_spr_7xx(env);
4985 bd928eba j_mayer
    /* XXX : not implemented */
4986 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
4987 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4988 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4989 bd928eba j_mayer
                 0x00000000);
4990 bd928eba j_mayer
    /* Time base */
4991 bd928eba j_mayer
    gen_tbl(env);
4992 bd928eba j_mayer
    /* Thermal management */
4993 bd928eba j_mayer
    gen_spr_thrm(env);
4994 bd928eba j_mayer
    /* Hardware implementation registers */
4995 bd928eba j_mayer
    /* XXX : not implemented */
4996 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
4997 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
4998 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
4999 bd928eba j_mayer
                 0x00000000);
5000 bd928eba j_mayer
    /* XXX : not implemented */
5001 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5002 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5003 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5004 bd928eba j_mayer
                 0x00000000);
5005 bd928eba j_mayer
    /* Memory management */
5006 bd928eba j_mayer
    gen_low_BATs(env);
5007 bd928eba j_mayer
    /* XXX: high BATs are also present but are known to be bugged on
5008 bd928eba j_mayer
     *      die version 1.x
5009 bd928eba j_mayer
     */
5010 bd928eba j_mayer
    init_excp_7x0(env);
5011 bd928eba j_mayer
    env->dcache_line_size = 32;
5012 bd928eba j_mayer
    env->icache_line_size = 32;
5013 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5014 bd928eba j_mayer
    ppc6xx_irq_init(env);
5015 bd928eba j_mayer
}
5016 bd928eba j_mayer
5017 bd928eba j_mayer
/* PowerPC 750 CL                                                            */
5018 bd928eba j_mayer
/* XXX: not implemented:
5019 bd928eba j_mayer
 * cache lock instructions:
5020 bd928eba j_mayer
 * dcbz_l
5021 bd928eba j_mayer
 * floating point paired instructions
5022 bd928eba j_mayer
 * psq_lux
5023 bd928eba j_mayer
 * psq_lx
5024 bd928eba j_mayer
 * psq_stux
5025 bd928eba j_mayer
 * psq_stx
5026 bd928eba j_mayer
 * ps_abs
5027 bd928eba j_mayer
 * ps_add
5028 bd928eba j_mayer
 * ps_cmpo0
5029 bd928eba j_mayer
 * ps_cmpo1
5030 bd928eba j_mayer
 * ps_cmpu0
5031 bd928eba j_mayer
 * ps_cmpu1
5032 bd928eba j_mayer
 * ps_div
5033 bd928eba j_mayer
 * ps_madd
5034 bd928eba j_mayer
 * ps_madds0
5035 bd928eba j_mayer
 * ps_madds1
5036 bd928eba j_mayer
 * ps_merge00
5037 bd928eba j_mayer
 * ps_merge01
5038 bd928eba j_mayer
 * ps_merge10
5039 bd928eba j_mayer
 * ps_merge11
5040 bd928eba j_mayer
 * ps_mr
5041 bd928eba j_mayer
 * ps_msub
5042 bd928eba j_mayer
 * ps_mul
5043 bd928eba j_mayer
 * ps_muls0
5044 bd928eba j_mayer
 * ps_muls1
5045 bd928eba j_mayer
 * ps_nabs
5046 bd928eba j_mayer
 * ps_neg
5047 bd928eba j_mayer
 * ps_nmadd
5048 bd928eba j_mayer
 * ps_nmsub
5049 bd928eba j_mayer
 * ps_res
5050 bd928eba j_mayer
 * ps_rsqrte
5051 bd928eba j_mayer
 * ps_sel
5052 bd928eba j_mayer
 * ps_sub
5053 bd928eba j_mayer
 * ps_sum0
5054 bd928eba j_mayer
 * ps_sum1
5055 bd928eba j_mayer
 */
5056 bd928eba j_mayer
#define POWERPC_INSNS_750cl  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5057 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5058 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5059 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5060 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5061 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5062 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
5063 a5858d7a Alexander Graf
#define POWERPC_INSNS2_750cl (PPC_NONE)
5064 bd928eba j_mayer
#define POWERPC_MSRM_750cl   (0x000000000005FF77ULL)
5065 bd928eba j_mayer
#define POWERPC_MMU_750cl    (POWERPC_MMU_32B)
5066 bd928eba j_mayer
#define POWERPC_EXCP_750cl   (POWERPC_EXCP_7x0)
5067 bd928eba j_mayer
#define POWERPC_INPUT_750cl  (PPC_FLAGS_INPUT_6xx)
5068 bd928eba j_mayer
#define POWERPC_BFDM_750cl   (bfd_mach_ppc_750)
5069 bd928eba j_mayer
#define POWERPC_FLAG_750cl   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5070 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5071 bd928eba j_mayer
#define check_pow_750cl      check_pow_hid0
5072 bd928eba j_mayer
5073 bd928eba j_mayer
static void init_proc_750cl (CPUPPCState *env)
5074 bd928eba j_mayer
{
5075 bd928eba j_mayer
    gen_spr_ne_601(env);
5076 bd928eba j_mayer
    gen_spr_7xx(env);
5077 bd928eba j_mayer
    /* XXX : not implemented */
5078 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5079 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5080 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5081 bd928eba j_mayer
                 0x00000000);
5082 bd928eba j_mayer
    /* Time base */
5083 bd928eba j_mayer
    gen_tbl(env);
5084 bd928eba j_mayer
    /* Thermal management */
5085 bd928eba j_mayer
    /* Those registers are fake on 750CL */
5086 bd928eba j_mayer
    spr_register(env, SPR_THRM1, "THRM1",
5087 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5088 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5089 bd928eba j_mayer
                 0x00000000);
5090 bd928eba j_mayer
    spr_register(env, SPR_THRM2, "THRM2",
5091 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5092 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5093 bd928eba j_mayer
                 0x00000000);
5094 bd928eba j_mayer
    spr_register(env, SPR_THRM3, "THRM3",
5095 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5096 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5097 bd928eba j_mayer
                 0x00000000);
5098 bd928eba j_mayer
    /* XXX: not implemented */
5099 bd928eba j_mayer
    spr_register(env, SPR_750_TDCL, "TDCL",
5100 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5101 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5102 bd928eba j_mayer
                 0x00000000);
5103 bd928eba j_mayer
    spr_register(env, SPR_750_TDCH, "TDCH",
5104 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5105 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5106 bd928eba j_mayer
                 0x00000000);
5107 bd928eba j_mayer
    /* DMA */
5108 bd928eba j_mayer
    /* XXX : not implemented */
5109 bd928eba j_mayer
    spr_register(env, SPR_750_WPAR, "WPAR",
5110 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5111 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5112 bd928eba j_mayer
                 0x00000000);
5113 bd928eba j_mayer
    spr_register(env, SPR_750_DMAL, "DMAL",
5114 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5115 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5116 bd928eba j_mayer
                 0x00000000);
5117 bd928eba j_mayer
    spr_register(env, SPR_750_DMAU, "DMAU",
5118 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5119 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5120 bd928eba j_mayer
                 0x00000000);
5121 bd928eba j_mayer
    /* Hardware implementation registers */
5122 bd928eba j_mayer
    /* XXX : not implemented */
5123 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
5124 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5125 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5126 bd928eba j_mayer
                 0x00000000);
5127 bd928eba j_mayer
    /* XXX : not implemented */
5128 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5129 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5130 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5131 bd928eba j_mayer
                 0x00000000);
5132 bd928eba j_mayer
    /* XXX : not implemented */
5133 bd928eba j_mayer
    spr_register(env, SPR_750CL_HID2, "HID2",
5134 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5135 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5136 bd928eba j_mayer
                 0x00000000);
5137 bd928eba j_mayer
    /* XXX : not implemented */
5138 bd928eba j_mayer
    spr_register(env, SPR_750CL_HID4, "HID4",
5139 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5140 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5141 bd928eba j_mayer
                 0x00000000);
5142 bd928eba j_mayer
    /* Quantization registers */
5143 bd928eba j_mayer
    /* XXX : not implemented */
5144 bd928eba j_mayer
    spr_register(env, SPR_750_GQR0, "GQR0",
5145 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5146 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5147 bd928eba j_mayer
                 0x00000000);
5148 bd928eba j_mayer
    /* XXX : not implemented */
5149 bd928eba j_mayer
    spr_register(env, SPR_750_GQR1, "GQR1",
5150 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5151 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5152 bd928eba j_mayer
                 0x00000000);
5153 bd928eba j_mayer
    /* XXX : not implemented */
5154 bd928eba j_mayer
    spr_register(env, SPR_750_GQR2, "GQR2",
5155 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5156 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5157 bd928eba j_mayer
                 0x00000000);
5158 bd928eba j_mayer
    /* XXX : not implemented */
5159 bd928eba j_mayer
    spr_register(env, SPR_750_GQR3, "GQR3",
5160 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5161 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5162 bd928eba j_mayer
                 0x00000000);
5163 bd928eba j_mayer
    /* XXX : not implemented */
5164 bd928eba j_mayer
    spr_register(env, SPR_750_GQR4, "GQR4",
5165 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5166 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5167 bd928eba j_mayer
                 0x00000000);
5168 bd928eba j_mayer
    /* XXX : not implemented */
5169 bd928eba j_mayer
    spr_register(env, SPR_750_GQR5, "GQR5",
5170 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5171 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5172 bd928eba j_mayer
                 0x00000000);
5173 bd928eba j_mayer
    /* XXX : not implemented */
5174 bd928eba j_mayer
    spr_register(env, SPR_750_GQR6, "GQR6",
5175 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5176 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5177 bd928eba j_mayer
                 0x00000000);
5178 bd928eba j_mayer
    /* XXX : not implemented */
5179 bd928eba j_mayer
    spr_register(env, SPR_750_GQR7, "GQR7",
5180 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5181 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5182 bd928eba j_mayer
                 0x00000000);
5183 bd928eba j_mayer
    /* Memory management */
5184 bd928eba j_mayer
    gen_low_BATs(env);
5185 bd928eba j_mayer
    /* PowerPC 750cl has 8 DBATs and 8 IBATs */
5186 bd928eba j_mayer
    gen_high_BATs(env);
5187 bd928eba j_mayer
    init_excp_750cl(env);
5188 bd928eba j_mayer
    env->dcache_line_size = 32;
5189 bd928eba j_mayer
    env->icache_line_size = 32;
5190 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5191 bd928eba j_mayer
    ppc6xx_irq_init(env);
5192 bd928eba j_mayer
}
5193 bd928eba j_mayer
5194 4e777442 j_mayer
/* PowerPC 750CX                                                             */
5195 bd928eba j_mayer
#define POWERPC_INSNS_750cx  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5196 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5197 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5198 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5199 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5200 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5201 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
5202 a5858d7a Alexander Graf
#define POWERPC_INSNS2_750cx (PPC_NONE)
5203 bd928eba j_mayer
#define POWERPC_MSRM_750cx   (0x000000000005FF77ULL)
5204 bd928eba j_mayer
#define POWERPC_MMU_750cx    (POWERPC_MMU_32B)
5205 bd928eba j_mayer
#define POWERPC_EXCP_750cx   (POWERPC_EXCP_7x0)
5206 bd928eba j_mayer
#define POWERPC_INPUT_750cx  (PPC_FLAGS_INPUT_6xx)
5207 bd928eba j_mayer
#define POWERPC_BFDM_750cx   (bfd_mach_ppc_750)
5208 bd928eba j_mayer
#define POWERPC_FLAG_750cx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5209 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5210 bd928eba j_mayer
#define check_pow_750cx      check_pow_hid0
5211 bd928eba j_mayer
5212 bd928eba j_mayer
static void init_proc_750cx (CPUPPCState *env)
5213 bd928eba j_mayer
{
5214 bd928eba j_mayer
    gen_spr_ne_601(env);
5215 bd928eba j_mayer
    gen_spr_7xx(env);
5216 bd928eba j_mayer
    /* XXX : not implemented */
5217 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5218 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5219 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5220 bd928eba j_mayer
                 0x00000000);
5221 bd928eba j_mayer
    /* Time base */
5222 bd928eba j_mayer
    gen_tbl(env);
5223 bd928eba j_mayer
    /* Thermal management */
5224 bd928eba j_mayer
    gen_spr_thrm(env);
5225 bd928eba j_mayer
    /* This register is not implemented but is present for compatibility */
5226 bd928eba j_mayer
    spr_register(env, SPR_SDA, "SDA",
5227 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5228 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5229 bd928eba j_mayer
                 0x00000000);
5230 bd928eba j_mayer
    /* Hardware implementation registers */
5231 bd928eba j_mayer
    /* XXX : not implemented */
5232 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
5233 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5234 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5235 bd928eba j_mayer
                 0x00000000);
5236 bd928eba j_mayer
    /* XXX : not implemented */
5237 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5238 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5239 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5240 bd928eba j_mayer
                 0x00000000);
5241 bd928eba j_mayer
    /* Memory management */
5242 bd928eba j_mayer
    gen_low_BATs(env);
5243 4e777442 j_mayer
    /* PowerPC 750cx has 8 DBATs and 8 IBATs */
5244 4e777442 j_mayer
    gen_high_BATs(env);
5245 bd928eba j_mayer
    init_excp_750cx(env);
5246 bd928eba j_mayer
    env->dcache_line_size = 32;
5247 bd928eba j_mayer
    env->icache_line_size = 32;
5248 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5249 bd928eba j_mayer
    ppc6xx_irq_init(env);
5250 bd928eba j_mayer
}
5251 bd928eba j_mayer
5252 bd928eba j_mayer
/* PowerPC 750FX                                                             */
5253 082c6681 j_mayer
#define POWERPC_INSNS_750fx  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5254 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5255 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5256 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5257 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5258 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5259 082c6681 j_mayer
                              PPC_SEGMENT  | PPC_EXTERN)
5260 a5858d7a Alexander Graf
#define POWERPC_INSNS2_750fx (PPC_NONE)
5261 25ba3a68 j_mayer
#define POWERPC_MSRM_750fx   (0x000000000005FF77ULL)
5262 a750fc0b j_mayer
#define POWERPC_MMU_750fx    (POWERPC_MMU_32B)
5263 a750fc0b j_mayer
#define POWERPC_EXCP_750fx   (POWERPC_EXCP_7x0)
5264 a750fc0b j_mayer
#define POWERPC_INPUT_750fx  (PPC_FLAGS_INPUT_6xx)
5265 237c0af0 j_mayer
#define POWERPC_BFDM_750fx   (bfd_mach_ppc_750)
5266 25ba3a68 j_mayer
#define POWERPC_FLAG_750fx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5267 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5268 2f462816 j_mayer
#define check_pow_750fx      check_pow_hid0
5269 a750fc0b j_mayer
5270 a750fc0b j_mayer
static void init_proc_750fx (CPUPPCState *env)
5271 a750fc0b j_mayer
{
5272 a750fc0b j_mayer
    gen_spr_ne_601(env);
5273 a750fc0b j_mayer
    gen_spr_7xx(env);
5274 bd928eba j_mayer
    /* XXX : not implemented */
5275 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5276 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5277 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5278 bd928eba j_mayer
                 0x00000000);
5279 a750fc0b j_mayer
    /* Time base */
5280 a750fc0b j_mayer
    gen_tbl(env);
5281 a750fc0b j_mayer
    /* Thermal management */
5282 a750fc0b j_mayer
    gen_spr_thrm(env);
5283 bd928eba j_mayer
    /* XXX : not implemented */
5284 bd928eba j_mayer
    spr_register(env, SPR_750_THRM4, "THRM4",
5285 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5286 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5287 bd928eba j_mayer
                 0x00000000);
5288 a750fc0b j_mayer
    /* Hardware implementation registers */
5289 a750fc0b j_mayer
    /* XXX : not implemented */
5290 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5291 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5292 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5293 a750fc0b j_mayer
                 0x00000000);
5294 a750fc0b j_mayer
    /* XXX : not implemented */
5295 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
5296 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5297 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5298 a750fc0b j_mayer
                 0x00000000);
5299 a750fc0b j_mayer
    /* XXX : not implemented */
5300 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
5301 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5302 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5303 a750fc0b j_mayer
                 0x00000000);
5304 a750fc0b j_mayer
    /* Memory management */
5305 a750fc0b j_mayer
    gen_low_BATs(env);
5306 a750fc0b j_mayer
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
5307 a750fc0b j_mayer
    gen_high_BATs(env);
5308 bd928eba j_mayer
    init_excp_7x0(env);
5309 d63001d1 j_mayer
    env->dcache_line_size = 32;
5310 d63001d1 j_mayer
    env->icache_line_size = 32;
5311 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5312 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5313 a750fc0b j_mayer
}
5314 a750fc0b j_mayer
5315 bd928eba j_mayer
/* PowerPC 750GX                                                             */
5316 bd928eba j_mayer
#define POWERPC_INSNS_750gx  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5317 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5318 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5319 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5320 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5321 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5322 bd928eba j_mayer
                              PPC_SEGMENT  | PPC_EXTERN)
5323 a5858d7a Alexander Graf
#define POWERPC_INSNS2_750gx (PPC_NONE)
5324 bd928eba j_mayer
#define POWERPC_MSRM_750gx   (0x000000000005FF77ULL)
5325 bd928eba j_mayer
#define POWERPC_MMU_750gx    (POWERPC_MMU_32B)
5326 bd928eba j_mayer
#define POWERPC_EXCP_750gx   (POWERPC_EXCP_7x0)
5327 bd928eba j_mayer
#define POWERPC_INPUT_750gx  (PPC_FLAGS_INPUT_6xx)
5328 bd928eba j_mayer
#define POWERPC_BFDM_750gx   (bfd_mach_ppc_750)
5329 bd928eba j_mayer
#define POWERPC_FLAG_750gx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5330 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5331 bd928eba j_mayer
#define check_pow_750gx      check_pow_hid0
5332 bd928eba j_mayer
5333 bd928eba j_mayer
static void init_proc_750gx (CPUPPCState *env)
5334 bd928eba j_mayer
{
5335 bd928eba j_mayer
    gen_spr_ne_601(env);
5336 bd928eba j_mayer
    gen_spr_7xx(env);
5337 bd928eba j_mayer
    /* XXX : not implemented (XXX: different from 750fx) */
5338 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5339 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5340 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5341 bd928eba j_mayer
                 0x00000000);
5342 bd928eba j_mayer
    /* Time base */
5343 bd928eba j_mayer
    gen_tbl(env);
5344 bd928eba j_mayer
    /* Thermal management */
5345 bd928eba j_mayer
    gen_spr_thrm(env);
5346 bd928eba j_mayer
    /* XXX : not implemented */
5347 bd928eba j_mayer
    spr_register(env, SPR_750_THRM4, "THRM4",
5348 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5349 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5350 bd928eba j_mayer
                 0x00000000);
5351 bd928eba j_mayer
    /* Hardware implementation registers */
5352 bd928eba j_mayer
    /* XXX : not implemented (XXX: different from 750fx) */
5353 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
5354 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5355 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5356 bd928eba j_mayer
                 0x00000000);
5357 bd928eba j_mayer
    /* XXX : not implemented */
5358 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5359 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5360 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5361 bd928eba j_mayer
                 0x00000000);
5362 bd928eba j_mayer
    /* XXX : not implemented (XXX: different from 750fx) */
5363 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
5364 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5365 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5366 bd928eba j_mayer
                 0x00000000);
5367 bd928eba j_mayer
    /* Memory management */
5368 bd928eba j_mayer
    gen_low_BATs(env);
5369 bd928eba j_mayer
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
5370 bd928eba j_mayer
    gen_high_BATs(env);
5371 bd928eba j_mayer
    init_excp_7x0(env);
5372 bd928eba j_mayer
    env->dcache_line_size = 32;
5373 bd928eba j_mayer
    env->icache_line_size = 32;
5374 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5375 bd928eba j_mayer
    ppc6xx_irq_init(env);
5376 bd928eba j_mayer
}
5377 bd928eba j_mayer
5378 bd928eba j_mayer
/* PowerPC 745                                                               */
5379 bd928eba j_mayer
#define POWERPC_INSNS_745    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5380 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5381 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5382 bd928eba j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5383 bd928eba j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5384 bd928eba j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
5385 bd928eba j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
5386 a5858d7a Alexander Graf
#define POWERPC_INSNS2_745   (PPC_NONE)
5387 bd928eba j_mayer
#define POWERPC_MSRM_745     (0x000000000005FF77ULL)
5388 bd928eba j_mayer
#define POWERPC_MMU_745      (POWERPC_MMU_SOFT_6xx)
5389 bd928eba j_mayer
#define POWERPC_EXCP_745     (POWERPC_EXCP_7x5)
5390 bd928eba j_mayer
#define POWERPC_INPUT_745    (PPC_FLAGS_INPUT_6xx)
5391 bd928eba j_mayer
#define POWERPC_BFDM_745     (bfd_mach_ppc_750)
5392 bd928eba j_mayer
#define POWERPC_FLAG_745     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5393 bd928eba j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5394 bd928eba j_mayer
#define check_pow_745        check_pow_hid0
5395 bd928eba j_mayer
5396 bd928eba j_mayer
static void init_proc_745 (CPUPPCState *env)
5397 bd928eba j_mayer
{
5398 bd928eba j_mayer
    gen_spr_ne_601(env);
5399 bd928eba j_mayer
    gen_spr_7xx(env);
5400 bd928eba j_mayer
    gen_spr_G2_755(env);
5401 bd928eba j_mayer
    /* Time base */
5402 bd928eba j_mayer
    gen_tbl(env);
5403 bd928eba j_mayer
    /* Thermal management */
5404 bd928eba j_mayer
    gen_spr_thrm(env);
5405 bd928eba j_mayer
    /* Hardware implementation registers */
5406 bd928eba j_mayer
    /* XXX : not implemented */
5407 bd928eba j_mayer
    spr_register(env, SPR_HID0, "HID0",
5408 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5409 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5410 bd928eba j_mayer
                 0x00000000);
5411 bd928eba j_mayer
    /* XXX : not implemented */
5412 bd928eba j_mayer
    spr_register(env, SPR_HID1, "HID1",
5413 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5414 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5415 bd928eba j_mayer
                 0x00000000);
5416 bd928eba j_mayer
    /* XXX : not implemented */
5417 bd928eba j_mayer
    spr_register(env, SPR_HID2, "HID2",
5418 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5419 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
5420 bd928eba j_mayer
                 0x00000000);
5421 bd928eba j_mayer
    /* Memory management */
5422 bd928eba j_mayer
    gen_low_BATs(env);
5423 bd928eba j_mayer
    gen_high_BATs(env);
5424 bd928eba j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
5425 bd928eba j_mayer
    init_excp_7x5(env);
5426 bd928eba j_mayer
    env->dcache_line_size = 32;
5427 bd928eba j_mayer
    env->icache_line_size = 32;
5428 bd928eba j_mayer
    /* Allocate hardware IRQ controller */
5429 bd928eba j_mayer
    ppc6xx_irq_init(env);
5430 bd928eba j_mayer
}
5431 bd928eba j_mayer
5432 bd928eba j_mayer
/* PowerPC 755                                                               */
5433 bd928eba j_mayer
#define POWERPC_INSNS_755    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5434 bd928eba j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5435 bd928eba j_mayer
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_STFIWX |          \
5436 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
5437 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5438 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC | PPC_6xx_TLB | \
5439 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN)
5440 a5858d7a Alexander Graf
#define POWERPC_INSNS2_755   (PPC_NONE)
5441 bd928eba j_mayer
#define POWERPC_MSRM_755     (0x000000000005FF77ULL)
5442 bd928eba j_mayer
#define POWERPC_MMU_755      (POWERPC_MMU_SOFT_6xx)
5443 bd928eba j_mayer
#define POWERPC_EXCP_755     (POWERPC_EXCP_7x5)
5444 bd928eba j_mayer
#define POWERPC_INPUT_755    (PPC_FLAGS_INPUT_6xx)
5445 bd928eba j_mayer
#define POWERPC_BFDM_755     (bfd_mach_ppc_750)
5446 bd928eba j_mayer
#define POWERPC_FLAG_755     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
5447 4018bae9 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
5448 bd928eba j_mayer
#define check_pow_755        check_pow_hid0
5449 a750fc0b j_mayer
5450 bd928eba j_mayer
static void init_proc_755 (CPUPPCState *env)
5451 a750fc0b j_mayer
{
5452 a750fc0b j_mayer
    gen_spr_ne_601(env);
5453 bd928eba j_mayer
    gen_spr_7xx(env);
5454 a750fc0b j_mayer
    gen_spr_G2_755(env);
5455 a750fc0b j_mayer
    /* Time base */
5456 a750fc0b j_mayer
    gen_tbl(env);
5457 a750fc0b j_mayer
    /* L2 cache control */
5458 a750fc0b j_mayer
    /* XXX : not implemented */
5459 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
5460 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5461 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5462 a750fc0b j_mayer
                 0x00000000);
5463 a750fc0b j_mayer
    /* XXX : not implemented */
5464 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
5465 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5466 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5467 a750fc0b j_mayer
                 0x00000000);
5468 bd928eba j_mayer
    /* Thermal management */
5469 bd928eba j_mayer
    gen_spr_thrm(env);
5470 a750fc0b j_mayer
    /* Hardware implementation registers */
5471 a750fc0b j_mayer
    /* XXX : not implemented */
5472 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
5473 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5474 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5475 a750fc0b j_mayer
                 0x00000000);
5476 a750fc0b j_mayer
    /* XXX : not implemented */
5477 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
5478 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5479 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5480 a750fc0b j_mayer
                 0x00000000);
5481 a750fc0b j_mayer
    /* XXX : not implemented */
5482 a750fc0b j_mayer
    spr_register(env, SPR_HID2, "HID2",
5483 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5484 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5485 a750fc0b j_mayer
                 0x00000000);
5486 a750fc0b j_mayer
    /* Memory management */
5487 a750fc0b j_mayer
    gen_low_BATs(env);
5488 a750fc0b j_mayer
    gen_high_BATs(env);
5489 a750fc0b j_mayer
    gen_6xx_7xx_soft_tlb(env, 64, 2);
5490 7a3a6927 j_mayer
    init_excp_7x5(env);
5491 d63001d1 j_mayer
    env->dcache_line_size = 32;
5492 d63001d1 j_mayer
    env->icache_line_size = 32;
5493 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5494 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5495 a750fc0b j_mayer
}
5496 a750fc0b j_mayer
5497 a750fc0b j_mayer
/* PowerPC 7400 (aka G4)                                                     */
5498 082c6681 j_mayer
#define POWERPC_INSNS_7400   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5499 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5500 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5501 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5502 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5503 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5504 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5505 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5506 082c6681 j_mayer
                              PPC_MEM_TLBIA |                                 \
5507 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5508 a750fc0b j_mayer
                              PPC_ALTIVEC)
5509 a5858d7a Alexander Graf
#define POWERPC_INSNS2_7400  (PPC_NONE)
5510 a750fc0b j_mayer
#define POWERPC_MSRM_7400    (0x000000000205FF77ULL)
5511 a750fc0b j_mayer
#define POWERPC_MMU_7400     (POWERPC_MMU_32B)
5512 a750fc0b j_mayer
#define POWERPC_EXCP_7400    (POWERPC_EXCP_74xx)
5513 a750fc0b j_mayer
#define POWERPC_INPUT_7400   (PPC_FLAGS_INPUT_6xx)
5514 237c0af0 j_mayer
#define POWERPC_BFDM_7400    (bfd_mach_ppc_7400)
5515 25ba3a68 j_mayer
#define POWERPC_FLAG_7400    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5516 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5517 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5518 488243b0 Aurelien Jarno
#define check_pow_7400       check_pow_hid0
5519 a750fc0b j_mayer
5520 a750fc0b j_mayer
static void init_proc_7400 (CPUPPCState *env)
5521 a750fc0b j_mayer
{
5522 a750fc0b j_mayer
    gen_spr_ne_601(env);
5523 a750fc0b j_mayer
    gen_spr_7xx(env);
5524 a750fc0b j_mayer
    /* Time base */
5525 a750fc0b j_mayer
    gen_tbl(env);
5526 a750fc0b j_mayer
    /* 74xx specific SPR */
5527 a750fc0b j_mayer
    gen_spr_74xx(env);
5528 4e777442 j_mayer
    /* XXX : not implemented */
5529 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5530 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5531 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5532 4e777442 j_mayer
                 0x00000000);
5533 4e777442 j_mayer
    /* XXX: this seems not implemented on all revisions. */
5534 4e777442 j_mayer
    /* XXX : not implemented */
5535 4e777442 j_mayer
    spr_register(env, SPR_MSSCR1, "MSSCR1",
5536 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5537 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5538 4e777442 j_mayer
                 0x00000000);
5539 a750fc0b j_mayer
    /* Thermal management */
5540 a750fc0b j_mayer
    gen_spr_thrm(env);
5541 a750fc0b j_mayer
    /* Memory management */
5542 a750fc0b j_mayer
    gen_low_BATs(env);
5543 e1833e1f j_mayer
    init_excp_7400(env);
5544 d63001d1 j_mayer
    env->dcache_line_size = 32;
5545 d63001d1 j_mayer
    env->icache_line_size = 32;
5546 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5547 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5548 a750fc0b j_mayer
}
5549 a750fc0b j_mayer
5550 a750fc0b j_mayer
/* PowerPC 7410 (aka G4)                                                     */
5551 082c6681 j_mayer
#define POWERPC_INSNS_7410   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5552 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5553 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5554 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5555 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5556 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5557 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5558 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5559 082c6681 j_mayer
                              PPC_MEM_TLBIA |                                 \
5560 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5561 a750fc0b j_mayer
                              PPC_ALTIVEC)
5562 a5858d7a Alexander Graf
#define POWERPC_INSNS2_7410  (PPC_NONE)
5563 a750fc0b j_mayer
#define POWERPC_MSRM_7410    (0x000000000205FF77ULL)
5564 a750fc0b j_mayer
#define POWERPC_MMU_7410     (POWERPC_MMU_32B)
5565 a750fc0b j_mayer
#define POWERPC_EXCP_7410    (POWERPC_EXCP_74xx)
5566 a750fc0b j_mayer
#define POWERPC_INPUT_7410   (PPC_FLAGS_INPUT_6xx)
5567 237c0af0 j_mayer
#define POWERPC_BFDM_7410    (bfd_mach_ppc_7400)
5568 25ba3a68 j_mayer
#define POWERPC_FLAG_7410    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5569 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5570 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5571 488243b0 Aurelien Jarno
#define check_pow_7410       check_pow_hid0
5572 a750fc0b j_mayer
5573 a750fc0b j_mayer
static void init_proc_7410 (CPUPPCState *env)
5574 a750fc0b j_mayer
{
5575 a750fc0b j_mayer
    gen_spr_ne_601(env);
5576 a750fc0b j_mayer
    gen_spr_7xx(env);
5577 a750fc0b j_mayer
    /* Time base */
5578 a750fc0b j_mayer
    gen_tbl(env);
5579 a750fc0b j_mayer
    /* 74xx specific SPR */
5580 a750fc0b j_mayer
    gen_spr_74xx(env);
5581 4e777442 j_mayer
    /* XXX : not implemented */
5582 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5583 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5584 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5585 4e777442 j_mayer
                 0x00000000);
5586 a750fc0b j_mayer
    /* Thermal management */
5587 a750fc0b j_mayer
    gen_spr_thrm(env);
5588 a750fc0b j_mayer
    /* L2PMCR */
5589 a750fc0b j_mayer
    /* XXX : not implemented */
5590 a750fc0b j_mayer
    spr_register(env, SPR_L2PMCR, "L2PMCR",
5591 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5592 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5593 a750fc0b j_mayer
                 0x00000000);
5594 a750fc0b j_mayer
    /* LDSTDB */
5595 a750fc0b j_mayer
    /* XXX : not implemented */
5596 a750fc0b j_mayer
    spr_register(env, SPR_LDSTDB, "LDSTDB",
5597 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5598 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5599 a750fc0b j_mayer
                 0x00000000);
5600 a750fc0b j_mayer
    /* Memory management */
5601 a750fc0b j_mayer
    gen_low_BATs(env);
5602 e1833e1f j_mayer
    init_excp_7400(env);
5603 d63001d1 j_mayer
    env->dcache_line_size = 32;
5604 d63001d1 j_mayer
    env->icache_line_size = 32;
5605 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5606 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5607 a750fc0b j_mayer
}
5608 a750fc0b j_mayer
5609 a750fc0b j_mayer
/* PowerPC 7440 (aka G4)                                                     */
5610 082c6681 j_mayer
#define POWERPC_INSNS_7440   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5611 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5612 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5613 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5614 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5615 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5616 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5617 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5618 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5619 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5620 a750fc0b j_mayer
                              PPC_ALTIVEC)
5621 a5858d7a Alexander Graf
#define POWERPC_INSNS2_7440  (PPC_NONE)
5622 a750fc0b j_mayer
#define POWERPC_MSRM_7440    (0x000000000205FF77ULL)
5623 a750fc0b j_mayer
#define POWERPC_MMU_7440     (POWERPC_MMU_SOFT_74xx)
5624 a750fc0b j_mayer
#define POWERPC_EXCP_7440    (POWERPC_EXCP_74xx)
5625 a750fc0b j_mayer
#define POWERPC_INPUT_7440   (PPC_FLAGS_INPUT_6xx)
5626 237c0af0 j_mayer
#define POWERPC_BFDM_7440    (bfd_mach_ppc_7400)
5627 25ba3a68 j_mayer
#define POWERPC_FLAG_7440    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5628 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5629 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5630 4e777442 j_mayer
#define check_pow_7440       check_pow_hid0_74xx
5631 a750fc0b j_mayer
5632 578bb252 j_mayer
__attribute__ (( unused ))
5633 a750fc0b j_mayer
static void init_proc_7440 (CPUPPCState *env)
5634 a750fc0b j_mayer
{
5635 a750fc0b j_mayer
    gen_spr_ne_601(env);
5636 a750fc0b j_mayer
    gen_spr_7xx(env);
5637 a750fc0b j_mayer
    /* Time base */
5638 a750fc0b j_mayer
    gen_tbl(env);
5639 a750fc0b j_mayer
    /* 74xx specific SPR */
5640 a750fc0b j_mayer
    gen_spr_74xx(env);
5641 4e777442 j_mayer
    /* XXX : not implemented */
5642 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5643 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5644 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5645 4e777442 j_mayer
                 0x00000000);
5646 a750fc0b j_mayer
    /* LDSTCR */
5647 a750fc0b j_mayer
    /* XXX : not implemented */
5648 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5649 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5650 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5651 a750fc0b j_mayer
                 0x00000000);
5652 a750fc0b j_mayer
    /* ICTRL */
5653 a750fc0b j_mayer
    /* XXX : not implemented */
5654 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5655 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5656 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5657 a750fc0b j_mayer
                 0x00000000);
5658 a750fc0b j_mayer
    /* MSSSR0 */
5659 578bb252 j_mayer
    /* XXX : not implemented */
5660 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5661 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5662 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5663 a750fc0b j_mayer
                 0x00000000);
5664 a750fc0b j_mayer
    /* PMC */
5665 a750fc0b j_mayer
    /* XXX : not implemented */
5666 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5667 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5668 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5669 a750fc0b j_mayer
                 0x00000000);
5670 578bb252 j_mayer
    /* XXX : not implemented */
5671 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5672 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5673 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5674 a750fc0b j_mayer
                 0x00000000);
5675 578bb252 j_mayer
    /* XXX : not implemented */
5676 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5677 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5678 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5679 a750fc0b j_mayer
                 0x00000000);
5680 578bb252 j_mayer
    /* XXX : not implemented */
5681 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5682 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5683 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5684 a750fc0b j_mayer
                 0x00000000);
5685 a750fc0b j_mayer
    /* Memory management */
5686 a750fc0b j_mayer
    gen_low_BATs(env);
5687 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5688 1c27f8fb j_mayer
    init_excp_7450(env);
5689 d63001d1 j_mayer
    env->dcache_line_size = 32;
5690 d63001d1 j_mayer
    env->icache_line_size = 32;
5691 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5692 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5693 a750fc0b j_mayer
}
5694 a750fc0b j_mayer
5695 a750fc0b j_mayer
/* PowerPC 7450 (aka G4)                                                     */
5696 082c6681 j_mayer
#define POWERPC_INSNS_7450   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5697 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5698 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5699 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5700 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5701 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5702 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5703 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5704 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5705 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5706 a750fc0b j_mayer
                              PPC_ALTIVEC)
5707 a5858d7a Alexander Graf
#define POWERPC_INSNS2_7450  (PPC_NONE)
5708 a750fc0b j_mayer
#define POWERPC_MSRM_7450    (0x000000000205FF77ULL)
5709 a750fc0b j_mayer
#define POWERPC_MMU_7450     (POWERPC_MMU_SOFT_74xx)
5710 a750fc0b j_mayer
#define POWERPC_EXCP_7450    (POWERPC_EXCP_74xx)
5711 a750fc0b j_mayer
#define POWERPC_INPUT_7450   (PPC_FLAGS_INPUT_6xx)
5712 237c0af0 j_mayer
#define POWERPC_BFDM_7450    (bfd_mach_ppc_7400)
5713 25ba3a68 j_mayer
#define POWERPC_FLAG_7450    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5714 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5715 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5716 4e777442 j_mayer
#define check_pow_7450       check_pow_hid0_74xx
5717 a750fc0b j_mayer
5718 578bb252 j_mayer
__attribute__ (( unused ))
5719 a750fc0b j_mayer
static void init_proc_7450 (CPUPPCState *env)
5720 a750fc0b j_mayer
{
5721 a750fc0b j_mayer
    gen_spr_ne_601(env);
5722 a750fc0b j_mayer
    gen_spr_7xx(env);
5723 a750fc0b j_mayer
    /* Time base */
5724 a750fc0b j_mayer
    gen_tbl(env);
5725 a750fc0b j_mayer
    /* 74xx specific SPR */
5726 a750fc0b j_mayer
    gen_spr_74xx(env);
5727 a750fc0b j_mayer
    /* Level 3 cache control */
5728 a750fc0b j_mayer
    gen_l3_ctrl(env);
5729 4e777442 j_mayer
    /* L3ITCR1 */
5730 4e777442 j_mayer
    /* XXX : not implemented */
5731 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
5732 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5733 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5734 4e777442 j_mayer
                 0x00000000);
5735 4e777442 j_mayer
    /* L3ITCR2 */
5736 4e777442 j_mayer
    /* XXX : not implemented */
5737 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
5738 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5739 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5740 4e777442 j_mayer
                 0x00000000);
5741 4e777442 j_mayer
    /* L3ITCR3 */
5742 4e777442 j_mayer
    /* XXX : not implemented */
5743 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
5744 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5745 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5746 4e777442 j_mayer
                 0x00000000);
5747 4e777442 j_mayer
    /* L3OHCR */
5748 4e777442 j_mayer
    /* XXX : not implemented */
5749 4e777442 j_mayer
    spr_register(env, SPR_L3OHCR, "L3OHCR",
5750 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5751 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
5752 4e777442 j_mayer
                 0x00000000);
5753 4e777442 j_mayer
    /* XXX : not implemented */
5754 4e777442 j_mayer
    spr_register(env, SPR_UBAMR, "UBAMR",
5755 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5756 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5757 4e777442 j_mayer
                 0x00000000);
5758 a750fc0b j_mayer
    /* LDSTCR */
5759 a750fc0b j_mayer
    /* XXX : not implemented */
5760 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5761 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5762 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5763 a750fc0b j_mayer
                 0x00000000);
5764 a750fc0b j_mayer
    /* ICTRL */
5765 a750fc0b j_mayer
    /* XXX : not implemented */
5766 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5767 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5768 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5769 a750fc0b j_mayer
                 0x00000000);
5770 a750fc0b j_mayer
    /* MSSSR0 */
5771 578bb252 j_mayer
    /* XXX : not implemented */
5772 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5773 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5774 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5775 a750fc0b j_mayer
                 0x00000000);
5776 a750fc0b j_mayer
    /* PMC */
5777 a750fc0b j_mayer
    /* XXX : not implemented */
5778 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5779 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5780 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5781 a750fc0b j_mayer
                 0x00000000);
5782 578bb252 j_mayer
    /* XXX : not implemented */
5783 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5784 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5785 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5786 a750fc0b j_mayer
                 0x00000000);
5787 578bb252 j_mayer
    /* XXX : not implemented */
5788 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5789 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5790 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5791 a750fc0b j_mayer
                 0x00000000);
5792 578bb252 j_mayer
    /* XXX : not implemented */
5793 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5794 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5795 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5796 a750fc0b j_mayer
                 0x00000000);
5797 a750fc0b j_mayer
    /* Memory management */
5798 a750fc0b j_mayer
    gen_low_BATs(env);
5799 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5800 e1833e1f j_mayer
    init_excp_7450(env);
5801 d63001d1 j_mayer
    env->dcache_line_size = 32;
5802 d63001d1 j_mayer
    env->icache_line_size = 32;
5803 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5804 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5805 a750fc0b j_mayer
}
5806 a750fc0b j_mayer
5807 a750fc0b j_mayer
/* PowerPC 7445 (aka G4)                                                     */
5808 082c6681 j_mayer
#define POWERPC_INSNS_7445   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5809 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5810 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5811 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5812 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5813 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5814 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5815 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5816 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5817 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5818 a750fc0b j_mayer
                              PPC_ALTIVEC)
5819 a5858d7a Alexander Graf
#define POWERPC_INSNS2_7445  (PPC_NONE)
5820 a750fc0b j_mayer
#define POWERPC_MSRM_7445    (0x000000000205FF77ULL)
5821 a750fc0b j_mayer
#define POWERPC_MMU_7445     (POWERPC_MMU_SOFT_74xx)
5822 a750fc0b j_mayer
#define POWERPC_EXCP_7445    (POWERPC_EXCP_74xx)
5823 a750fc0b j_mayer
#define POWERPC_INPUT_7445   (PPC_FLAGS_INPUT_6xx)
5824 237c0af0 j_mayer
#define POWERPC_BFDM_7445    (bfd_mach_ppc_7400)
5825 25ba3a68 j_mayer
#define POWERPC_FLAG_7445    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5826 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5827 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5828 4e777442 j_mayer
#define check_pow_7445       check_pow_hid0_74xx
5829 a750fc0b j_mayer
5830 578bb252 j_mayer
__attribute__ (( unused ))
5831 a750fc0b j_mayer
static void init_proc_7445 (CPUPPCState *env)
5832 a750fc0b j_mayer
{
5833 a750fc0b j_mayer
    gen_spr_ne_601(env);
5834 a750fc0b j_mayer
    gen_spr_7xx(env);
5835 a750fc0b j_mayer
    /* Time base */
5836 a750fc0b j_mayer
    gen_tbl(env);
5837 a750fc0b j_mayer
    /* 74xx specific SPR */
5838 a750fc0b j_mayer
    gen_spr_74xx(env);
5839 a750fc0b j_mayer
    /* LDSTCR */
5840 a750fc0b j_mayer
    /* XXX : not implemented */
5841 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5842 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5843 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5844 a750fc0b j_mayer
                 0x00000000);
5845 a750fc0b j_mayer
    /* ICTRL */
5846 a750fc0b j_mayer
    /* XXX : not implemented */
5847 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5848 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5849 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5850 a750fc0b j_mayer
                 0x00000000);
5851 a750fc0b j_mayer
    /* MSSSR0 */
5852 578bb252 j_mayer
    /* XXX : not implemented */
5853 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5854 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5855 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5856 a750fc0b j_mayer
                 0x00000000);
5857 a750fc0b j_mayer
    /* PMC */
5858 a750fc0b j_mayer
    /* XXX : not implemented */
5859 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5860 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5861 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5862 a750fc0b j_mayer
                 0x00000000);
5863 578bb252 j_mayer
    /* XXX : not implemented */
5864 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5865 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5866 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5867 a750fc0b j_mayer
                 0x00000000);
5868 578bb252 j_mayer
    /* XXX : not implemented */
5869 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5870 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5871 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5872 a750fc0b j_mayer
                 0x00000000);
5873 578bb252 j_mayer
    /* XXX : not implemented */
5874 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5875 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5876 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5877 a750fc0b j_mayer
                 0x00000000);
5878 a750fc0b j_mayer
    /* SPRGs */
5879 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
5880 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5881 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5882 a750fc0b j_mayer
                 0x00000000);
5883 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
5884 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5885 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5886 a750fc0b j_mayer
                 0x00000000);
5887 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
5888 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5889 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5890 a750fc0b j_mayer
                 0x00000000);
5891 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
5892 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5893 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5894 a750fc0b j_mayer
                 0x00000000);
5895 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
5896 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5897 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5898 a750fc0b j_mayer
                 0x00000000);
5899 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
5900 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5901 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5902 a750fc0b j_mayer
                 0x00000000);
5903 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
5904 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5905 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5906 a750fc0b j_mayer
                 0x00000000);
5907 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
5908 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5909 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5910 a750fc0b j_mayer
                 0x00000000);
5911 a750fc0b j_mayer
    /* Memory management */
5912 a750fc0b j_mayer
    gen_low_BATs(env);
5913 a750fc0b j_mayer
    gen_high_BATs(env);
5914 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
5915 e1833e1f j_mayer
    init_excp_7450(env);
5916 d63001d1 j_mayer
    env->dcache_line_size = 32;
5917 d63001d1 j_mayer
    env->icache_line_size = 32;
5918 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
5919 a750fc0b j_mayer
    ppc6xx_irq_init(env);
5920 a750fc0b j_mayer
}
5921 a750fc0b j_mayer
5922 a750fc0b j_mayer
/* PowerPC 7455 (aka G4)                                                     */
5923 082c6681 j_mayer
#define POWERPC_INSNS_7455   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
5924 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
5925 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
5926 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
5927 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
5928 082c6681 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
5929 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
5930 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
5931 082c6681 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
5932 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
5933 a750fc0b j_mayer
                              PPC_ALTIVEC)
5934 a5858d7a Alexander Graf
#define POWERPC_INSNS2_7455  (PPC_NONE)
5935 a750fc0b j_mayer
#define POWERPC_MSRM_7455    (0x000000000205FF77ULL)
5936 a750fc0b j_mayer
#define POWERPC_MMU_7455     (POWERPC_MMU_SOFT_74xx)
5937 a750fc0b j_mayer
#define POWERPC_EXCP_7455    (POWERPC_EXCP_74xx)
5938 a750fc0b j_mayer
#define POWERPC_INPUT_7455   (PPC_FLAGS_INPUT_6xx)
5939 237c0af0 j_mayer
#define POWERPC_BFDM_7455    (bfd_mach_ppc_7400)
5940 25ba3a68 j_mayer
#define POWERPC_FLAG_7455    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
5941 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
5942 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
5943 4e777442 j_mayer
#define check_pow_7455       check_pow_hid0_74xx
5944 a750fc0b j_mayer
5945 578bb252 j_mayer
__attribute__ (( unused ))
5946 a750fc0b j_mayer
static void init_proc_7455 (CPUPPCState *env)
5947 a750fc0b j_mayer
{
5948 a750fc0b j_mayer
    gen_spr_ne_601(env);
5949 a750fc0b j_mayer
    gen_spr_7xx(env);
5950 a750fc0b j_mayer
    /* Time base */
5951 a750fc0b j_mayer
    gen_tbl(env);
5952 a750fc0b j_mayer
    /* 74xx specific SPR */
5953 a750fc0b j_mayer
    gen_spr_74xx(env);
5954 a750fc0b j_mayer
    /* Level 3 cache control */
5955 a750fc0b j_mayer
    gen_l3_ctrl(env);
5956 a750fc0b j_mayer
    /* LDSTCR */
5957 a750fc0b j_mayer
    /* XXX : not implemented */
5958 a750fc0b j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
5959 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5960 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5961 a750fc0b j_mayer
                 0x00000000);
5962 a750fc0b j_mayer
    /* ICTRL */
5963 a750fc0b j_mayer
    /* XXX : not implemented */
5964 a750fc0b j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
5965 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5966 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5967 a750fc0b j_mayer
                 0x00000000);
5968 a750fc0b j_mayer
    /* MSSSR0 */
5969 578bb252 j_mayer
    /* XXX : not implemented */
5970 a750fc0b j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
5971 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5972 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5973 a750fc0b j_mayer
                 0x00000000);
5974 a750fc0b j_mayer
    /* PMC */
5975 a750fc0b j_mayer
    /* XXX : not implemented */
5976 a750fc0b j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
5977 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5978 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5979 a750fc0b j_mayer
                 0x00000000);
5980 578bb252 j_mayer
    /* XXX : not implemented */
5981 a750fc0b j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
5982 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5983 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5984 a750fc0b j_mayer
                 0x00000000);
5985 578bb252 j_mayer
    /* XXX : not implemented */
5986 a750fc0b j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
5987 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5988 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5989 a750fc0b j_mayer
                 0x00000000);
5990 578bb252 j_mayer
    /* XXX : not implemented */
5991 a750fc0b j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
5992 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5993 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
5994 a750fc0b j_mayer
                 0x00000000);
5995 a750fc0b j_mayer
    /* SPRGs */
5996 a750fc0b j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
5997 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
5998 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
5999 a750fc0b j_mayer
                 0x00000000);
6000 a750fc0b j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
6001 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6002 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6003 a750fc0b j_mayer
                 0x00000000);
6004 a750fc0b j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
6005 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6006 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6007 a750fc0b j_mayer
                 0x00000000);
6008 a750fc0b j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
6009 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6010 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6011 a750fc0b j_mayer
                 0x00000000);
6012 a750fc0b j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
6013 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6014 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6015 a750fc0b j_mayer
                 0x00000000);
6016 a750fc0b j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
6017 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6018 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6019 a750fc0b j_mayer
                 0x00000000);
6020 a750fc0b j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
6021 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6022 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6023 a750fc0b j_mayer
                 0x00000000);
6024 a750fc0b j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
6025 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6026 a750fc0b j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6027 a750fc0b j_mayer
                 0x00000000);
6028 a750fc0b j_mayer
    /* Memory management */
6029 a750fc0b j_mayer
    gen_low_BATs(env);
6030 a750fc0b j_mayer
    gen_high_BATs(env);
6031 578bb252 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
6032 e1833e1f j_mayer
    init_excp_7450(env);
6033 d63001d1 j_mayer
    env->dcache_line_size = 32;
6034 d63001d1 j_mayer
    env->icache_line_size = 32;
6035 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
6036 a750fc0b j_mayer
    ppc6xx_irq_init(env);
6037 a750fc0b j_mayer
}
6038 a750fc0b j_mayer
6039 4e777442 j_mayer
/* PowerPC 7457 (aka G4)                                                     */
6040 4e777442 j_mayer
#define POWERPC_INSNS_7457   (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6041 4e777442 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6042 4e777442 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6043 4e777442 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6044 4e777442 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
6045 4e777442 j_mayer
                              PPC_CACHE_DCBA | PPC_CACHE_DCBZ |               \
6046 4e777442 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6047 4e777442 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6048 4e777442 j_mayer
                              PPC_MEM_TLBIA | PPC_74xx_TLB |                  \
6049 4e777442 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
6050 4e777442 j_mayer
                              PPC_ALTIVEC)
6051 a5858d7a Alexander Graf
#define POWERPC_INSNS2_7457  (PPC_NONE)
6052 4e777442 j_mayer
#define POWERPC_MSRM_7457    (0x000000000205FF77ULL)
6053 4e777442 j_mayer
#define POWERPC_MMU_7457     (POWERPC_MMU_SOFT_74xx)
6054 4e777442 j_mayer
#define POWERPC_EXCP_7457    (POWERPC_EXCP_74xx)
6055 4e777442 j_mayer
#define POWERPC_INPUT_7457   (PPC_FLAGS_INPUT_6xx)
6056 4e777442 j_mayer
#define POWERPC_BFDM_7457    (bfd_mach_ppc_7400)
6057 4e777442 j_mayer
#define POWERPC_FLAG_7457    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6058 4e777442 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6059 4e777442 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6060 4e777442 j_mayer
#define check_pow_7457       check_pow_hid0_74xx
6061 4e777442 j_mayer
6062 4e777442 j_mayer
__attribute__ (( unused ))
6063 4e777442 j_mayer
static void init_proc_7457 (CPUPPCState *env)
6064 4e777442 j_mayer
{
6065 4e777442 j_mayer
    gen_spr_ne_601(env);
6066 4e777442 j_mayer
    gen_spr_7xx(env);
6067 4e777442 j_mayer
    /* Time base */
6068 4e777442 j_mayer
    gen_tbl(env);
6069 4e777442 j_mayer
    /* 74xx specific SPR */
6070 4e777442 j_mayer
    gen_spr_74xx(env);
6071 4e777442 j_mayer
    /* Level 3 cache control */
6072 4e777442 j_mayer
    gen_l3_ctrl(env);
6073 4e777442 j_mayer
    /* L3ITCR1 */
6074 4e777442 j_mayer
    /* XXX : not implemented */
6075 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
6076 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6077 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6078 4e777442 j_mayer
                 0x00000000);
6079 4e777442 j_mayer
    /* L3ITCR2 */
6080 4e777442 j_mayer
    /* XXX : not implemented */
6081 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
6082 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6083 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6084 4e777442 j_mayer
                 0x00000000);
6085 4e777442 j_mayer
    /* L3ITCR3 */
6086 4e777442 j_mayer
    /* XXX : not implemented */
6087 4e777442 j_mayer
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
6088 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6089 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6090 4e777442 j_mayer
                 0x00000000);
6091 4e777442 j_mayer
    /* L3OHCR */
6092 4e777442 j_mayer
    /* XXX : not implemented */
6093 4e777442 j_mayer
    spr_register(env, SPR_L3OHCR, "L3OHCR",
6094 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6095 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6096 4e777442 j_mayer
                 0x00000000);
6097 4e777442 j_mayer
    /* LDSTCR */
6098 4e777442 j_mayer
    /* XXX : not implemented */
6099 4e777442 j_mayer
    spr_register(env, SPR_LDSTCR, "LDSTCR",
6100 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6101 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6102 4e777442 j_mayer
                 0x00000000);
6103 4e777442 j_mayer
    /* ICTRL */
6104 4e777442 j_mayer
    /* XXX : not implemented */
6105 4e777442 j_mayer
    spr_register(env, SPR_ICTRL, "ICTRL",
6106 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6107 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6108 4e777442 j_mayer
                 0x00000000);
6109 4e777442 j_mayer
    /* MSSSR0 */
6110 4e777442 j_mayer
    /* XXX : not implemented */
6111 4e777442 j_mayer
    spr_register(env, SPR_MSSSR0, "MSSSR0",
6112 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6113 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6114 4e777442 j_mayer
                 0x00000000);
6115 4e777442 j_mayer
    /* PMC */
6116 4e777442 j_mayer
    /* XXX : not implemented */
6117 4e777442 j_mayer
    spr_register(env, SPR_PMC5, "PMC5",
6118 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6119 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6120 4e777442 j_mayer
                 0x00000000);
6121 4e777442 j_mayer
    /* XXX : not implemented */
6122 4e777442 j_mayer
    spr_register(env, SPR_UPMC5, "UPMC5",
6123 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6124 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6125 4e777442 j_mayer
                 0x00000000);
6126 4e777442 j_mayer
    /* XXX : not implemented */
6127 4e777442 j_mayer
    spr_register(env, SPR_PMC6, "PMC6",
6128 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6129 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6130 4e777442 j_mayer
                 0x00000000);
6131 4e777442 j_mayer
    /* XXX : not implemented */
6132 4e777442 j_mayer
    spr_register(env, SPR_UPMC6, "UPMC6",
6133 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6134 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6135 4e777442 j_mayer
                 0x00000000);
6136 4e777442 j_mayer
    /* SPRGs */
6137 4e777442 j_mayer
    spr_register(env, SPR_SPRG4, "SPRG4",
6138 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6139 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6140 4e777442 j_mayer
                 0x00000000);
6141 4e777442 j_mayer
    spr_register(env, SPR_USPRG4, "USPRG4",
6142 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6143 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6144 4e777442 j_mayer
                 0x00000000);
6145 4e777442 j_mayer
    spr_register(env, SPR_SPRG5, "SPRG5",
6146 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6147 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6148 4e777442 j_mayer
                 0x00000000);
6149 4e777442 j_mayer
    spr_register(env, SPR_USPRG5, "USPRG5",
6150 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6151 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6152 4e777442 j_mayer
                 0x00000000);
6153 4e777442 j_mayer
    spr_register(env, SPR_SPRG6, "SPRG6",
6154 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6155 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6156 4e777442 j_mayer
                 0x00000000);
6157 4e777442 j_mayer
    spr_register(env, SPR_USPRG6, "USPRG6",
6158 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6159 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6160 4e777442 j_mayer
                 0x00000000);
6161 4e777442 j_mayer
    spr_register(env, SPR_SPRG7, "SPRG7",
6162 4e777442 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6163 4e777442 j_mayer
                 &spr_read_generic, &spr_write_generic,
6164 4e777442 j_mayer
                 0x00000000);
6165 4e777442 j_mayer
    spr_register(env, SPR_USPRG7, "USPRG7",
6166 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6167 4e777442 j_mayer
                 &spr_read_ureg, SPR_NOACCESS,
6168 4e777442 j_mayer
                 0x00000000);
6169 4e777442 j_mayer
    /* Memory management */
6170 4e777442 j_mayer
    gen_low_BATs(env);
6171 4e777442 j_mayer
    gen_high_BATs(env);
6172 4e777442 j_mayer
    gen_74xx_soft_tlb(env, 128, 2);
6173 4e777442 j_mayer
    init_excp_7450(env);
6174 4e777442 j_mayer
    env->dcache_line_size = 32;
6175 4e777442 j_mayer
    env->icache_line_size = 32;
6176 4e777442 j_mayer
    /* Allocate hardware IRQ controller */
6177 4e777442 j_mayer
    ppc6xx_irq_init(env);
6178 4e777442 j_mayer
}
6179 4e777442 j_mayer
6180 a750fc0b j_mayer
#if defined (TARGET_PPC64)
6181 a750fc0b j_mayer
/* PowerPC 970                                                               */
6182 082c6681 j_mayer
#define POWERPC_INSNS_970    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6183 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6184 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6185 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6186 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6187 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6188 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6189 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
6190 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
6191 a5858d7a Alexander Graf
#define POWERPC_INSNS2_970   (PPC_NONE)
6192 a750fc0b j_mayer
#define POWERPC_MSRM_970     (0x900000000204FF36ULL)
6193 12de9a39 j_mayer
#define POWERPC_MMU_970      (POWERPC_MMU_64B)
6194 a750fc0b j_mayer
//#define POWERPC_EXCP_970     (POWERPC_EXCP_970)
6195 a750fc0b j_mayer
#define POWERPC_INPUT_970    (PPC_FLAGS_INPUT_970)
6196 237c0af0 j_mayer
#define POWERPC_BFDM_970     (bfd_mach_ppc64)
6197 25ba3a68 j_mayer
#define POWERPC_FLAG_970     (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6198 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6199 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6200 a750fc0b j_mayer
6201 417bf010 j_mayer
#if defined(CONFIG_USER_ONLY)
6202 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000080
6203 417bf010 j_mayer
#else
6204 417bf010 j_mayer
#define POWERPC970_HID5_INIT 0x00000000
6205 417bf010 j_mayer
#endif
6206 417bf010 j_mayer
6207 2f462816 j_mayer
static int check_pow_970 (CPUPPCState *env)
6208 2f462816 j_mayer
{
6209 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
6210 2f462816 j_mayer
        return 1;
6211 2f462816 j_mayer
6212 2f462816 j_mayer
    return 0;
6213 2f462816 j_mayer
}
6214 2f462816 j_mayer
6215 a750fc0b j_mayer
static void init_proc_970 (CPUPPCState *env)
6216 a750fc0b j_mayer
{
6217 a750fc0b j_mayer
    gen_spr_ne_601(env);
6218 a750fc0b j_mayer
    gen_spr_7xx(env);
6219 a750fc0b j_mayer
    /* Time base */
6220 a750fc0b j_mayer
    gen_tbl(env);
6221 a750fc0b j_mayer
    /* Hardware implementation registers */
6222 a750fc0b j_mayer
    /* XXX : not implemented */
6223 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6224 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6225 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
6226 d63001d1 j_mayer
                 0x60000000);
6227 a750fc0b j_mayer
    /* XXX : not implemented */
6228 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
6229 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6230 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6231 a750fc0b j_mayer
                 0x00000000);
6232 a750fc0b j_mayer
    /* XXX : not implemented */
6233 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6234 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6235 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6236 a750fc0b j_mayer
                 0x00000000);
6237 e57448f1 j_mayer
    /* XXX : not implemented */
6238 e57448f1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6239 e57448f1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6240 e57448f1 j_mayer
                 &spr_read_generic, &spr_write_generic,
6241 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
6242 bd928eba j_mayer
    /* XXX : not implemented */
6243 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6244 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6245 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6246 bd928eba j_mayer
                 0x00000000);
6247 a750fc0b j_mayer
    /* Memory management */
6248 a750fc0b j_mayer
    /* XXX: not correct */
6249 a750fc0b j_mayer
    gen_low_BATs(env);
6250 12de9a39 j_mayer
    /* XXX : not implemented */
6251 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6252 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6253 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6254 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6255 12de9a39 j_mayer
    /* XXX : not implemented */
6256 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6257 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6258 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
6259 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6260 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6261 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6262 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6263 2adab7d6 blueswir1
                 0x00000000);
6264 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
6265 12de9a39 j_mayer
    env->slb_nr = 32;
6266 f2e63a42 j_mayer
#endif
6267 e1833e1f j_mayer
    init_excp_970(env);
6268 d63001d1 j_mayer
    env->dcache_line_size = 128;
6269 d63001d1 j_mayer
    env->icache_line_size = 128;
6270 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
6271 a750fc0b j_mayer
    ppc970_irq_init(env);
6272 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6273 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6274 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6275 a750fc0b j_mayer
}
6276 a750fc0b j_mayer
6277 a750fc0b j_mayer
/* PowerPC 970FX (aka G5)                                                    */
6278 082c6681 j_mayer
#define POWERPC_INSNS_970FX  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6279 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6280 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6281 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6282 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6283 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6284 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6285 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
6286 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
6287 a5858d7a Alexander Graf
#define POWERPC_INSNS2_970FX (PPC_NONE)
6288 a750fc0b j_mayer
#define POWERPC_MSRM_970FX   (0x800000000204FF36ULL)
6289 12de9a39 j_mayer
#define POWERPC_MMU_970FX    (POWERPC_MMU_64B)
6290 a750fc0b j_mayer
#define POWERPC_EXCP_970FX   (POWERPC_EXCP_970)
6291 a750fc0b j_mayer
#define POWERPC_INPUT_970FX  (PPC_FLAGS_INPUT_970)
6292 237c0af0 j_mayer
#define POWERPC_BFDM_970FX   (bfd_mach_ppc64)
6293 25ba3a68 j_mayer
#define POWERPC_FLAG_970FX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6294 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6295 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6296 a750fc0b j_mayer
6297 2f462816 j_mayer
static int check_pow_970FX (CPUPPCState *env)
6298 2f462816 j_mayer
{
6299 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
6300 2f462816 j_mayer
        return 1;
6301 2f462816 j_mayer
6302 2f462816 j_mayer
    return 0;
6303 2f462816 j_mayer
}
6304 2f462816 j_mayer
6305 a750fc0b j_mayer
static void init_proc_970FX (CPUPPCState *env)
6306 a750fc0b j_mayer
{
6307 a750fc0b j_mayer
    gen_spr_ne_601(env);
6308 a750fc0b j_mayer
    gen_spr_7xx(env);
6309 a750fc0b j_mayer
    /* Time base */
6310 a750fc0b j_mayer
    gen_tbl(env);
6311 a750fc0b j_mayer
    /* Hardware implementation registers */
6312 a750fc0b j_mayer
    /* XXX : not implemented */
6313 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6314 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6315 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
6316 d63001d1 j_mayer
                 0x60000000);
6317 a750fc0b j_mayer
    /* XXX : not implemented */
6318 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
6319 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6320 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6321 a750fc0b j_mayer
                 0x00000000);
6322 a750fc0b j_mayer
    /* XXX : not implemented */
6323 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6324 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6325 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6326 a750fc0b j_mayer
                 0x00000000);
6327 d63001d1 j_mayer
    /* XXX : not implemented */
6328 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6329 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6330 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
6331 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
6332 bd928eba j_mayer
    /* XXX : not implemented */
6333 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6334 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6335 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6336 bd928eba j_mayer
                 0x00000000);
6337 a750fc0b j_mayer
    /* Memory management */
6338 a750fc0b j_mayer
    /* XXX: not correct */
6339 a750fc0b j_mayer
    gen_low_BATs(env);
6340 12de9a39 j_mayer
    /* XXX : not implemented */
6341 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6342 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6343 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6344 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6345 12de9a39 j_mayer
    /* XXX : not implemented */
6346 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6347 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6348 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
6349 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6350 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6351 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6352 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6353 2adab7d6 blueswir1
                 0x00000000);
6354 4e98d8cf blueswir1
    spr_register(env, SPR_CTRL, "SPR_CTRL",
6355 4e98d8cf blueswir1
                 SPR_NOACCESS, SPR_NOACCESS,
6356 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6357 4e98d8cf blueswir1
                 0x00000000);
6358 4e98d8cf blueswir1
    spr_register(env, SPR_UCTRL, "SPR_UCTRL",
6359 4e98d8cf blueswir1
                 SPR_NOACCESS, SPR_NOACCESS,
6360 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6361 4e98d8cf blueswir1
                 0x00000000);
6362 4e98d8cf blueswir1
    spr_register(env, SPR_VRSAVE, "SPR_VRSAVE",
6363 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6364 4e98d8cf blueswir1
                 &spr_read_generic, &spr_write_generic,
6365 4e98d8cf blueswir1
                 0x00000000);
6366 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
6367 8eee0af9 blueswir1
    env->slb_nr = 64;
6368 f2e63a42 j_mayer
#endif
6369 e1833e1f j_mayer
    init_excp_970(env);
6370 d63001d1 j_mayer
    env->dcache_line_size = 128;
6371 d63001d1 j_mayer
    env->icache_line_size = 128;
6372 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
6373 a750fc0b j_mayer
    ppc970_irq_init(env);
6374 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6375 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6376 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6377 a750fc0b j_mayer
}
6378 a750fc0b j_mayer
6379 a750fc0b j_mayer
/* PowerPC 970 GX                                                            */
6380 082c6681 j_mayer
#define POWERPC_INSNS_970GX  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6381 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6382 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6383 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6384 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6385 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6386 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6387 a750fc0b j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
6388 12de9a39 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
6389 a5858d7a Alexander Graf
#define POWERPC_INSNS2_970GX (PPC_NONE)
6390 a750fc0b j_mayer
#define POWERPC_MSRM_970GX   (0x800000000204FF36ULL)
6391 12de9a39 j_mayer
#define POWERPC_MMU_970GX    (POWERPC_MMU_64B)
6392 a750fc0b j_mayer
#define POWERPC_EXCP_970GX   (POWERPC_EXCP_970)
6393 a750fc0b j_mayer
#define POWERPC_INPUT_970GX  (PPC_FLAGS_INPUT_970)
6394 237c0af0 j_mayer
#define POWERPC_BFDM_970GX   (bfd_mach_ppc64)
6395 25ba3a68 j_mayer
#define POWERPC_FLAG_970GX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6396 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6397 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6398 a750fc0b j_mayer
6399 2f462816 j_mayer
static int check_pow_970GX (CPUPPCState *env)
6400 2f462816 j_mayer
{
6401 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x00600000)
6402 2f462816 j_mayer
        return 1;
6403 2f462816 j_mayer
6404 2f462816 j_mayer
    return 0;
6405 2f462816 j_mayer
}
6406 2f462816 j_mayer
6407 a750fc0b j_mayer
static void init_proc_970GX (CPUPPCState *env)
6408 a750fc0b j_mayer
{
6409 a750fc0b j_mayer
    gen_spr_ne_601(env);
6410 a750fc0b j_mayer
    gen_spr_7xx(env);
6411 a750fc0b j_mayer
    /* Time base */
6412 a750fc0b j_mayer
    gen_tbl(env);
6413 a750fc0b j_mayer
    /* Hardware implementation registers */
6414 a750fc0b j_mayer
    /* XXX : not implemented */
6415 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6416 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6417 06403421 j_mayer
                 &spr_read_generic, &spr_write_clear,
6418 d63001d1 j_mayer
                 0x60000000);
6419 a750fc0b j_mayer
    /* XXX : not implemented */
6420 a750fc0b j_mayer
    spr_register(env, SPR_HID1, "HID1",
6421 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6422 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6423 a750fc0b j_mayer
                 0x00000000);
6424 a750fc0b j_mayer
    /* XXX : not implemented */
6425 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6426 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6427 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6428 a750fc0b j_mayer
                 0x00000000);
6429 d63001d1 j_mayer
    /* XXX : not implemented */
6430 d63001d1 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6431 d63001d1 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6432 d63001d1 j_mayer
                 &spr_read_generic, &spr_write_generic,
6433 417bf010 j_mayer
                 POWERPC970_HID5_INIT);
6434 bd928eba j_mayer
    /* XXX : not implemented */
6435 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6436 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6437 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6438 bd928eba j_mayer
                 0x00000000);
6439 a750fc0b j_mayer
    /* Memory management */
6440 a750fc0b j_mayer
    /* XXX: not correct */
6441 a750fc0b j_mayer
    gen_low_BATs(env);
6442 12de9a39 j_mayer
    /* XXX : not implemented */
6443 12de9a39 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6444 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6445 12de9a39 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6446 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6447 12de9a39 j_mayer
    /* XXX : not implemented */
6448 12de9a39 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6449 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6450 12de9a39 j_mayer
                 &spr_read_generic, &spr_write_generic,
6451 12de9a39 j_mayer
                 0x00000000); /* TOFIX */
6452 12de9a39 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6453 12de9a39 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6454 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6455 2adab7d6 blueswir1
                 0x00000000);
6456 12de9a39 j_mayer
#if !defined(CONFIG_USER_ONLY)
6457 12de9a39 j_mayer
    env->slb_nr = 32;
6458 f2e63a42 j_mayer
#endif
6459 e1833e1f j_mayer
    init_excp_970(env);
6460 d63001d1 j_mayer
    env->dcache_line_size = 128;
6461 d63001d1 j_mayer
    env->icache_line_size = 128;
6462 a750fc0b j_mayer
    /* Allocate hardware IRQ controller */
6463 a750fc0b j_mayer
    ppc970_irq_init(env);
6464 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6465 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6466 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6467 a750fc0b j_mayer
}
6468 a750fc0b j_mayer
6469 2f462816 j_mayer
/* PowerPC 970 MP                                                            */
6470 082c6681 j_mayer
#define POWERPC_INSNS_970MP  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6471 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6472 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6473 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6474 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6475 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6476 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6477 2f462816 j_mayer
                              PPC_64B | PPC_ALTIVEC |                         \
6478 2f462816 j_mayer
                              PPC_SEGMENT_64B | PPC_SLBI)
6479 a5858d7a Alexander Graf
#define POWERPC_INSNS2_970MP (PPC_NONE)
6480 2f462816 j_mayer
#define POWERPC_MSRM_970MP   (0x900000000204FF36ULL)
6481 2f462816 j_mayer
#define POWERPC_MMU_970MP    (POWERPC_MMU_64B)
6482 2f462816 j_mayer
#define POWERPC_EXCP_970MP   (POWERPC_EXCP_970)
6483 2f462816 j_mayer
#define POWERPC_INPUT_970MP  (PPC_FLAGS_INPUT_970)
6484 2f462816 j_mayer
#define POWERPC_BFDM_970MP   (bfd_mach_ppc64)
6485 2f462816 j_mayer
#define POWERPC_FLAG_970MP   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6486 4018bae9 j_mayer
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6487 4018bae9 j_mayer
                              POWERPC_FLAG_BUS_CLK)
6488 2f462816 j_mayer
6489 2f462816 j_mayer
static int check_pow_970MP (CPUPPCState *env)
6490 2f462816 j_mayer
{
6491 2f462816 j_mayer
    if (env->spr[SPR_HID0] & 0x01C00000)
6492 2f462816 j_mayer
        return 1;
6493 2f462816 j_mayer
6494 2f462816 j_mayer
    return 0;
6495 2f462816 j_mayer
}
6496 2f462816 j_mayer
6497 2f462816 j_mayer
static void init_proc_970MP (CPUPPCState *env)
6498 2f462816 j_mayer
{
6499 2f462816 j_mayer
    gen_spr_ne_601(env);
6500 2f462816 j_mayer
    gen_spr_7xx(env);
6501 2f462816 j_mayer
    /* Time base */
6502 2f462816 j_mayer
    gen_tbl(env);
6503 2f462816 j_mayer
    /* Hardware implementation registers */
6504 2f462816 j_mayer
    /* XXX : not implemented */
6505 2f462816 j_mayer
    spr_register(env, SPR_HID0, "HID0",
6506 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6507 2f462816 j_mayer
                 &spr_read_generic, &spr_write_clear,
6508 2f462816 j_mayer
                 0x60000000);
6509 2f462816 j_mayer
    /* XXX : not implemented */
6510 2f462816 j_mayer
    spr_register(env, SPR_HID1, "HID1",
6511 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6512 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6513 2f462816 j_mayer
                 0x00000000);
6514 2f462816 j_mayer
    /* XXX : not implemented */
6515 bd928eba j_mayer
    spr_register(env, SPR_750FX_HID2, "HID2",
6516 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6517 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6518 2f462816 j_mayer
                 0x00000000);
6519 2f462816 j_mayer
    /* XXX : not implemented */
6520 2f462816 j_mayer
    spr_register(env, SPR_970_HID5, "HID5",
6521 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6522 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6523 2f462816 j_mayer
                 POWERPC970_HID5_INIT);
6524 bd928eba j_mayer
    /* XXX : not implemented */
6525 bd928eba j_mayer
    spr_register(env, SPR_L2CR, "L2CR",
6526 bd928eba j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6527 bd928eba j_mayer
                 &spr_read_generic, &spr_write_generic,
6528 bd928eba j_mayer
                 0x00000000);
6529 2f462816 j_mayer
    /* Memory management */
6530 2f462816 j_mayer
    /* XXX: not correct */
6531 2f462816 j_mayer
    gen_low_BATs(env);
6532 2f462816 j_mayer
    /* XXX : not implemented */
6533 2f462816 j_mayer
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6534 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6535 2f462816 j_mayer
                 &spr_read_generic, SPR_NOACCESS,
6536 2f462816 j_mayer
                 0x00000000); /* TOFIX */
6537 2f462816 j_mayer
    /* XXX : not implemented */
6538 2f462816 j_mayer
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
6539 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6540 2f462816 j_mayer
                 &spr_read_generic, &spr_write_generic,
6541 2f462816 j_mayer
                 0x00000000); /* TOFIX */
6542 2f462816 j_mayer
    spr_register(env, SPR_HIOR, "SPR_HIOR",
6543 2f462816 j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6544 2adab7d6 blueswir1
                 &spr_read_hior, &spr_write_hior,
6545 2adab7d6 blueswir1
                 0x00000000);
6546 2f462816 j_mayer
#if !defined(CONFIG_USER_ONLY)
6547 2f462816 j_mayer
    env->slb_nr = 32;
6548 2f462816 j_mayer
#endif
6549 2f462816 j_mayer
    init_excp_970(env);
6550 2f462816 j_mayer
    env->dcache_line_size = 128;
6551 2f462816 j_mayer
    env->icache_line_size = 128;
6552 2f462816 j_mayer
    /* Allocate hardware IRQ controller */
6553 2f462816 j_mayer
    ppc970_irq_init(env);
6554 cf8358c8 aurel32
    /* Can't find information on what this should be on reset.  This
6555 cf8358c8 aurel32
     * value is the one used by 74xx processors. */
6556 cf8358c8 aurel32
    vscr_init(env, 0x00010000);
6557 2f462816 j_mayer
}
6558 2f462816 j_mayer
6559 9d52e907 David Gibson
#if defined(TARGET_PPC64)
6560 9d52e907 David Gibson
/* POWER7 */
6561 9d52e907 David Gibson
#define POWERPC_INSNS_POWER7  (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6562 9d52e907 David Gibson
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6563 9d52e907 David Gibson
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6564 9d52e907 David Gibson
                              PPC_FLOAT_STFIWX |                              \
6565 9d52e907 David Gibson
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZT |  \
6566 9d52e907 David Gibson
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6567 9d52e907 David Gibson
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6568 9d52e907 David Gibson
                              PPC_64B | PPC_ALTIVEC |                         \
6569 9d52e907 David Gibson
                              PPC_SEGMENT_64B | PPC_SLBI |                    \
6570 9d52e907 David Gibson
                              PPC_POPCNTB | PPC_POPCNTWD)
6571 02d4eae4 David Gibson
#define POWERPC_INSNS2_POWER7 (PPC2_VSX | PPC2_DFP)
6572 9d52e907 David Gibson
#define POWERPC_MSRM_POWER7   (0x800000000204FF36ULL)
6573 9d52e907 David Gibson
#define POWERPC_MMU_POWER7    (POWERPC_MMU_2_06)
6574 9d52e907 David Gibson
#define POWERPC_EXCP_POWER7   (POWERPC_EXCP_POWER7)
6575 9d52e907 David Gibson
#define POWERPC_INPUT_POWER7  (PPC_FLAGS_INPUT_POWER7)
6576 9d52e907 David Gibson
#define POWERPC_BFDM_POWER7   (bfd_mach_ppc64)
6577 9d52e907 David Gibson
#define POWERPC_FLAG_POWER7   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
6578 9d52e907 David Gibson
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM |            \
6579 697ab892 David Gibson
                              POWERPC_FLAG_BUS_CLK | POWERPC_FLAG_CFAR)
6580 9d52e907 David Gibson
#define check_pow_POWER7    check_pow_nocheck
6581 9d52e907 David Gibson
6582 9d52e907 David Gibson
static void init_proc_POWER7 (CPUPPCState *env)
6583 9d52e907 David Gibson
{
6584 9d52e907 David Gibson
    gen_spr_ne_601(env);
6585 9d52e907 David Gibson
    gen_spr_7xx(env);
6586 9d52e907 David Gibson
    /* Time base */
6587 9d52e907 David Gibson
    gen_tbl(env);
6588 9d52e907 David Gibson
#if !defined(CONFIG_USER_ONLY)
6589 9d52e907 David Gibson
    /* PURR & SPURR: Hack - treat these as aliases for the TB for now */
6590 9d52e907 David Gibson
    spr_register(env, SPR_PURR,   "PURR",
6591 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6592 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6593 9d52e907 David Gibson
                 0x00000000);
6594 9d52e907 David Gibson
    spr_register(env, SPR_SPURR,   "SPURR",
6595 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6596 9d52e907 David Gibson
                 &spr_read_purr, SPR_NOACCESS,
6597 9d52e907 David Gibson
                 0x00000000);
6598 697ab892 David Gibson
    spr_register(env, SPR_CFAR, "SPR_CFAR",
6599 697ab892 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6600 697ab892 David Gibson
                 &spr_read_cfar, &spr_write_cfar,
6601 697ab892 David Gibson
                 0x00000000);
6602 697ab892 David Gibson
    spr_register(env, SPR_DSCR, "SPR_DSCR",
6603 697ab892 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6604 697ab892 David Gibson
                 &spr_read_generic, &spr_write_generic,
6605 697ab892 David Gibson
                 0x00000000);
6606 9d52e907 David Gibson
#endif /* !CONFIG_USER_ONLY */
6607 9d52e907 David Gibson
    /* Memory management */
6608 9d52e907 David Gibson
    /* XXX : not implemented */
6609 9d52e907 David Gibson
    spr_register(env, SPR_MMUCFG, "MMUCFG",
6610 9d52e907 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6611 9d52e907 David Gibson
                 &spr_read_generic, SPR_NOACCESS,
6612 9d52e907 David Gibson
                 0x00000000); /* TOFIX */
6613 9d52e907 David Gibson
    /* XXX : not implemented */
6614 9d52e907 David Gibson
    spr_register(env, SPR_CTRL, "SPR_CTRLT",
6615 9d52e907 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6616 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6617 9d52e907 David Gibson
                 0x80800000);
6618 9d52e907 David Gibson
    spr_register(env, SPR_UCTRL, "SPR_CTRLF",
6619 9d52e907 David Gibson
                 SPR_NOACCESS, SPR_NOACCESS,
6620 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6621 9d52e907 David Gibson
                 0x80800000);
6622 9d52e907 David Gibson
    spr_register(env, SPR_VRSAVE, "SPR_VRSAVE",
6623 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6624 9d52e907 David Gibson
                 &spr_read_generic, &spr_write_generic,
6625 9d52e907 David Gibson
                 0x00000000);
6626 9d52e907 David Gibson
#if !defined(CONFIG_USER_ONLY)
6627 9d52e907 David Gibson
    env->slb_nr = 32;
6628 9d52e907 David Gibson
#endif
6629 9d52e907 David Gibson
    init_excp_POWER7(env);
6630 9d52e907 David Gibson
    env->dcache_line_size = 128;
6631 9d52e907 David Gibson
    env->icache_line_size = 128;
6632 9d52e907 David Gibson
    /* Allocate hardware IRQ controller */
6633 9d52e907 David Gibson
    ppcPOWER7_irq_init(env);
6634 9d52e907 David Gibson
    /* Can't find information on what this should be on reset.  This
6635 9d52e907 David Gibson
     * value is the one used by 74xx processors. */
6636 9d52e907 David Gibson
    vscr_init(env, 0x00010000);
6637 9d52e907 David Gibson
}
6638 9d52e907 David Gibson
#endif /* TARGET_PPC64 */
6639 9d52e907 David Gibson
6640 a750fc0b j_mayer
/* PowerPC 620                                                               */
6641 082c6681 j_mayer
#define POWERPC_INSNS_620    (PPC_INSNS_BASE | PPC_STRING | PPC_MFTB |        \
6642 082c6681 j_mayer
                              PPC_FLOAT | PPC_FLOAT_FSEL | PPC_FLOAT_FRES |   \
6643 082c6681 j_mayer
                              PPC_FLOAT_FSQRT | PPC_FLOAT_FRSQRTE |           \
6644 082c6681 j_mayer
                              PPC_FLOAT_STFIWX |                              \
6645 082c6681 j_mayer
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ |   \
6646 082c6681 j_mayer
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
6647 082c6681 j_mayer
                              PPC_MEM_TLBIE | PPC_MEM_TLBSYNC |               \
6648 082c6681 j_mayer
                              PPC_SEGMENT | PPC_EXTERN |                      \
6649 a750fc0b j_mayer
                              PPC_64B | PPC_SLBI)
6650 a5858d7a Alexander Graf
#define POWERPC_INSNS2_620   (PPC_NONE)
6651 add78955 j_mayer
#define POWERPC_MSRM_620     (0x800000000005FF77ULL)
6652 add78955 j_mayer
//#define POWERPC_MMU_620      (POWERPC_MMU_620)
6653 a750fc0b j_mayer
#define POWERPC_EXCP_620     (POWERPC_EXCP_970)
6654 faadf50e j_mayer
#define POWERPC_INPUT_620    (PPC_FLAGS_INPUT_6xx)
6655 237c0af0 j_mayer
#define POWERPC_BFDM_620     (bfd_mach_ppc64)
6656 4018bae9 j_mayer
#define POWERPC_FLAG_620     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |            \
6657 add78955 j_mayer
                              POWERPC_FLAG_PMM | POWERPC_FLAG_BUS_CLK)
6658 2f462816 j_mayer
#define check_pow_620        check_pow_nocheck /* Check this */
6659 a750fc0b j_mayer
6660 578bb252 j_mayer
__attribute__ (( unused ))
6661 a750fc0b j_mayer
static void init_proc_620 (CPUPPCState *env)
6662 a750fc0b j_mayer
{
6663 a750fc0b j_mayer
    gen_spr_ne_601(env);
6664 a750fc0b j_mayer
    gen_spr_620(env);
6665 a750fc0b j_mayer
    /* Time base */
6666 a750fc0b j_mayer
    gen_tbl(env);
6667 a750fc0b j_mayer
    /* Hardware implementation registers */
6668 a750fc0b j_mayer
    /* XXX : not implemented */
6669 a750fc0b j_mayer
    spr_register(env, SPR_HID0, "HID0",
6670 a750fc0b j_mayer
                 SPR_NOACCESS, SPR_NOACCESS,
6671 a750fc0b j_mayer
                 &spr_read_generic, &spr_write_generic,
6672 a750fc0b j_mayer
                 0x00000000);
6673 a750fc0b j_mayer
    /* Memory management */
6674 a750fc0b j_mayer
    gen_low_BATs(env);
6675 e1833e1f j_mayer
    init_excp_620(env);
6676 d63001d1 j_mayer
    env->dcache_line_size = 64;
6677 d63001d1 j_mayer
    env->icache_line_size = 64;
6678 faadf50e j_mayer
    /* Allocate hardware IRQ controller */
6679 faadf50e j_mayer
    ppc6xx_irq_init(env);
6680 a750fc0b j_mayer
}
6681 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
6682 a750fc0b j_mayer
6683 a750fc0b j_mayer
/* Default 32 bits PowerPC target will be 604 */
6684 a750fc0b j_mayer
#define CPU_POWERPC_PPC32     CPU_POWERPC_604
6685 a750fc0b j_mayer
#define POWERPC_INSNS_PPC32   POWERPC_INSNS_604
6686 a5858d7a Alexander Graf
#define POWERPC_INSNS2_PPC32  POWERPC_INSNS2_604
6687 a750fc0b j_mayer
#define POWERPC_MSRM_PPC32    POWERPC_MSRM_604
6688 a750fc0b j_mayer
#define POWERPC_MMU_PPC32     POWERPC_MMU_604
6689 a750fc0b j_mayer
#define POWERPC_EXCP_PPC32    POWERPC_EXCP_604
6690 a750fc0b j_mayer
#define POWERPC_INPUT_PPC32   POWERPC_INPUT_604
6691 237c0af0 j_mayer
#define POWERPC_BFDM_PPC32    POWERPC_BFDM_604
6692 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC32    POWERPC_FLAG_604
6693 2f462816 j_mayer
#define check_pow_PPC32       check_pow_604
6694 2f462816 j_mayer
#define init_proc_PPC32       init_proc_604
6695 a750fc0b j_mayer
6696 a750fc0b j_mayer
/* Default 64 bits PowerPC target will be 970 FX */
6697 a750fc0b j_mayer
#define CPU_POWERPC_PPC64     CPU_POWERPC_970FX
6698 a750fc0b j_mayer
#define POWERPC_INSNS_PPC64   POWERPC_INSNS_970FX
6699 a5858d7a Alexander Graf
#define POWERPC_INSNS2_PPC64  POWERPC_INSNS2_970FX
6700 a750fc0b j_mayer
#define POWERPC_MSRM_PPC64    POWERPC_MSRM_970FX
6701 a750fc0b j_mayer
#define POWERPC_MMU_PPC64     POWERPC_MMU_970FX
6702 a750fc0b j_mayer
#define POWERPC_EXCP_PPC64    POWERPC_EXCP_970FX
6703 a750fc0b j_mayer
#define POWERPC_INPUT_PPC64   POWERPC_INPUT_970FX
6704 237c0af0 j_mayer
#define POWERPC_BFDM_PPC64    POWERPC_BFDM_970FX
6705 d26bfc9a j_mayer
#define POWERPC_FLAG_PPC64    POWERPC_FLAG_970FX
6706 2f462816 j_mayer
#define check_pow_PPC64       check_pow_970FX
6707 2f462816 j_mayer
#define init_proc_PPC64       init_proc_970FX
6708 a750fc0b j_mayer
6709 a750fc0b j_mayer
/* Default PowerPC target will be PowerPC 32 */
6710 a750fc0b j_mayer
#if defined (TARGET_PPC64) && 0 // XXX: TODO
6711 a5858d7a Alexander Graf
#define CPU_POWERPC_DEFAULT    CPU_POWERPC_PPC64
6712 a5858d7a Alexander Graf
#define POWERPC_INSNS_DEFAULT  POWERPC_INSNS_PPC64
6713 a5858d7a Alexander Graf
#define POWERPC_INSNS2_DEFAULT POWERPC_INSNS_PPC64
6714 a5858d7a Alexander Graf
#define POWERPC_MSRM_DEFAULT   POWERPC_MSRM_PPC64
6715 a5858d7a Alexander Graf
#define POWERPC_MMU_DEFAULT    POWERPC_MMU_PPC64
6716 a5858d7a Alexander Graf
#define POWERPC_EXCP_DEFAULT   POWERPC_EXCP_PPC64
6717 a5858d7a Alexander Graf
#define POWERPC_INPUT_DEFAULT  POWERPC_INPUT_PPC64
6718 a5858d7a Alexander Graf
#define POWERPC_BFDM_DEFAULT   POWERPC_BFDM_PPC64
6719 a5858d7a Alexander Graf
#define POWERPC_FLAG_DEFAULT   POWERPC_FLAG_PPC64
6720 a5858d7a Alexander Graf
#define check_pow_DEFAULT      check_pow_PPC64
6721 a5858d7a Alexander Graf
#define init_proc_DEFAULT      init_proc_PPC64
6722 a750fc0b j_mayer
#else
6723 a5858d7a Alexander Graf
#define CPU_POWERPC_DEFAULT    CPU_POWERPC_PPC32
6724 a5858d7a Alexander Graf
#define POWERPC_INSNS_DEFAULT  POWERPC_INSNS_PPC32
6725 a5858d7a Alexander Graf
#define POWERPC_INSNS2_DEFAULT POWERPC_INSNS_PPC32
6726 a5858d7a Alexander Graf
#define POWERPC_MSRM_DEFAULT   POWERPC_MSRM_PPC32
6727 a5858d7a Alexander Graf
#define POWERPC_MMU_DEFAULT    POWERPC_MMU_PPC32
6728 a5858d7a Alexander Graf
#define POWERPC_EXCP_DEFAULT   POWERPC_EXCP_PPC32
6729 a5858d7a Alexander Graf
#define POWERPC_INPUT_DEFAULT  POWERPC_INPUT_PPC32
6730 a5858d7a Alexander Graf
#define POWERPC_BFDM_DEFAULT   POWERPC_BFDM_PPC32
6731 a5858d7a Alexander Graf
#define POWERPC_FLAG_DEFAULT   POWERPC_FLAG_PPC32
6732 a5858d7a Alexander Graf
#define check_pow_DEFAULT      check_pow_PPC32
6733 a5858d7a Alexander Graf
#define init_proc_DEFAULT      init_proc_PPC32
6734 a750fc0b j_mayer
#endif
6735 a750fc0b j_mayer
6736 a750fc0b j_mayer
/*****************************************************************************/
6737 a750fc0b j_mayer
/* PVR definitions for most known PowerPC                                    */
6738 a750fc0b j_mayer
enum {
6739 a750fc0b j_mayer
    /* PowerPC 401 family */
6740 a750fc0b j_mayer
    /* Generic PowerPC 401 */
6741 80d11f44 j_mayer
#define CPU_POWERPC_401              CPU_POWERPC_401G2
6742 a750fc0b j_mayer
    /* PowerPC 401 cores */
6743 80d11f44 j_mayer
    CPU_POWERPC_401A1              = 0x00210000,
6744 80d11f44 j_mayer
    CPU_POWERPC_401B2              = 0x00220000,
6745 a750fc0b j_mayer
#if 0
6746 80d11f44 j_mayer
    CPU_POWERPC_401B3              = xxx,
6747 a750fc0b j_mayer
#endif
6748 80d11f44 j_mayer
    CPU_POWERPC_401C2              = 0x00230000,
6749 80d11f44 j_mayer
    CPU_POWERPC_401D2              = 0x00240000,
6750 80d11f44 j_mayer
    CPU_POWERPC_401E2              = 0x00250000,
6751 80d11f44 j_mayer
    CPU_POWERPC_401F2              = 0x00260000,
6752 80d11f44 j_mayer
    CPU_POWERPC_401G2              = 0x00270000,
6753 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers */
6754 a750fc0b j_mayer
#if 0
6755 80d11f44 j_mayer
    CPU_POWERPC_401GF              = xxx,
6756 a750fc0b j_mayer
#endif
6757 80d11f44 j_mayer
#define CPU_POWERPC_IOP480           CPU_POWERPC_401B2
6758 a750fc0b j_mayer
    /* IBM Processor for Network Resources */
6759 80d11f44 j_mayer
    CPU_POWERPC_COBRA              = 0x10100000, /* XXX: 405 ? */
6760 a750fc0b j_mayer
#if 0
6761 80d11f44 j_mayer
    CPU_POWERPC_XIPCHIP            = xxx,
6762 a750fc0b j_mayer
#endif
6763 a750fc0b j_mayer
    /* PowerPC 403 family */
6764 a750fc0b j_mayer
    /* Generic PowerPC 403 */
6765 80d11f44 j_mayer
#define CPU_POWERPC_403              CPU_POWERPC_403GC
6766 a750fc0b j_mayer
    /* PowerPC 403 microcontrollers */
6767 80d11f44 j_mayer
    CPU_POWERPC_403GA              = 0x00200011,
6768 80d11f44 j_mayer
    CPU_POWERPC_403GB              = 0x00200100,
6769 80d11f44 j_mayer
    CPU_POWERPC_403GC              = 0x00200200,
6770 80d11f44 j_mayer
    CPU_POWERPC_403GCX             = 0x00201400,
6771 a750fc0b j_mayer
#if 0
6772 80d11f44 j_mayer
    CPU_POWERPC_403GP              = xxx,
6773 a750fc0b j_mayer
#endif
6774 a750fc0b j_mayer
    /* PowerPC 405 family */
6775 a750fc0b j_mayer
    /* Generic PowerPC 405 */
6776 80d11f44 j_mayer
#define CPU_POWERPC_405              CPU_POWERPC_405D4
6777 a750fc0b j_mayer
    /* PowerPC 405 cores */
6778 a750fc0b j_mayer
#if 0
6779 80d11f44 j_mayer
    CPU_POWERPC_405A3              = xxx,
6780 a750fc0b j_mayer
#endif
6781 a750fc0b j_mayer
#if 0
6782 80d11f44 j_mayer
    CPU_POWERPC_405A4              = xxx,
6783 a750fc0b j_mayer
#endif
6784 a750fc0b j_mayer
#if 0
6785 80d11f44 j_mayer
    CPU_POWERPC_405B3              = xxx,
6786 a750fc0b j_mayer
#endif
6787 a750fc0b j_mayer
#if 0
6788 80d11f44 j_mayer
    CPU_POWERPC_405B4              = xxx,
6789 a750fc0b j_mayer
#endif
6790 a750fc0b j_mayer
#if 0
6791 80d11f44 j_mayer
    CPU_POWERPC_405C3              = xxx,
6792 a750fc0b j_mayer
#endif
6793 a750fc0b j_mayer
#if 0
6794 80d11f44 j_mayer
    CPU_POWERPC_405C4              = xxx,
6795 a750fc0b j_mayer
#endif
6796 80d11f44 j_mayer
    CPU_POWERPC_405D2              = 0x20010000,
6797 a750fc0b j_mayer
#if 0
6798 80d11f44 j_mayer
    CPU_POWERPC_405D3              = xxx,
6799 a750fc0b j_mayer
#endif
6800 80d11f44 j_mayer
    CPU_POWERPC_405D4              = 0x41810000,
6801 a750fc0b j_mayer
#if 0
6802 80d11f44 j_mayer
    CPU_POWERPC_405D5              = xxx,
6803 a750fc0b j_mayer
#endif
6804 a750fc0b j_mayer
#if 0
6805 80d11f44 j_mayer
    CPU_POWERPC_405E4              = xxx,
6806 a750fc0b j_mayer
#endif
6807 a750fc0b j_mayer
#if 0
6808 80d11f44 j_mayer
    CPU_POWERPC_405F4              = xxx,
6809 a750fc0b j_mayer
#endif
6810 a750fc0b j_mayer
#if 0
6811 80d11f44 j_mayer
    CPU_POWERPC_405F5              = xxx,
6812 a750fc0b j_mayer
#endif
6813 a750fc0b j_mayer
#if 0
6814 80d11f44 j_mayer
    CPU_POWERPC_405F6              = xxx,
6815 a750fc0b j_mayer
#endif
6816 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers */
6817 a750fc0b j_mayer
    /* XXX: missing 0x200108a0 */
6818 80d11f44 j_mayer
#define CPU_POWERPC_405CR            CPU_POWERPC_405CRc
6819 80d11f44 j_mayer
    CPU_POWERPC_405CRa             = 0x40110041,
6820 80d11f44 j_mayer
    CPU_POWERPC_405CRb             = 0x401100C5,
6821 80d11f44 j_mayer
    CPU_POWERPC_405CRc             = 0x40110145,
6822 80d11f44 j_mayer
    CPU_POWERPC_405EP              = 0x51210950,
6823 a750fc0b j_mayer
#if 0
6824 80d11f44 j_mayer
    CPU_POWERPC_405EXr             = xxx,
6825 a750fc0b j_mayer
#endif
6826 80d11f44 j_mayer
    CPU_POWERPC_405EZ              = 0x41511460, /* 0x51210950 ? */
6827 a750fc0b j_mayer
#if 0
6828 80d11f44 j_mayer
    CPU_POWERPC_405FX              = xxx,
6829 80d11f44 j_mayer
#endif
6830 80d11f44 j_mayer
#define CPU_POWERPC_405GP            CPU_POWERPC_405GPd
6831 80d11f44 j_mayer
    CPU_POWERPC_405GPa             = 0x40110000,
6832 80d11f44 j_mayer
    CPU_POWERPC_405GPb             = 0x40110040,
6833 80d11f44 j_mayer
    CPU_POWERPC_405GPc             = 0x40110082,
6834 80d11f44 j_mayer
    CPU_POWERPC_405GPd             = 0x401100C4,
6835 80d11f44 j_mayer
#define CPU_POWERPC_405GPe           CPU_POWERPC_405CRc
6836 80d11f44 j_mayer
    CPU_POWERPC_405GPR             = 0x50910951,
6837 a750fc0b j_mayer
#if 0
6838 80d11f44 j_mayer
    CPU_POWERPC_405H               = xxx,
6839 a750fc0b j_mayer
#endif
6840 a750fc0b j_mayer
#if 0
6841 80d11f44 j_mayer
    CPU_POWERPC_405L               = xxx,
6842 a750fc0b j_mayer
#endif
6843 80d11f44 j_mayer
    CPU_POWERPC_405LP              = 0x41F10000,
6844 a750fc0b j_mayer
#if 0
6845 80d11f44 j_mayer
    CPU_POWERPC_405PM              = xxx,
6846 a750fc0b j_mayer
#endif
6847 a750fc0b j_mayer
#if 0
6848 80d11f44 j_mayer
    CPU_POWERPC_405PS              = xxx,
6849 a750fc0b j_mayer
#endif
6850 a750fc0b j_mayer
#if 0
6851 80d11f44 j_mayer
    CPU_POWERPC_405S               = xxx,
6852 a750fc0b j_mayer
#endif
6853 a750fc0b j_mayer
    /* IBM network processors */
6854 80d11f44 j_mayer
    CPU_POWERPC_NPE405H            = 0x414100C0,
6855 80d11f44 j_mayer
    CPU_POWERPC_NPE405H2           = 0x41410140,
6856 80d11f44 j_mayer
    CPU_POWERPC_NPE405L            = 0x416100C0,
6857 80d11f44 j_mayer
    CPU_POWERPC_NPE4GS3            = 0x40B10000,
6858 a750fc0b j_mayer
#if 0
6859 80d11f44 j_mayer
    CPU_POWERPC_NPCxx1             = xxx,
6860 a750fc0b j_mayer
#endif
6861 a750fc0b j_mayer
#if 0
6862 80d11f44 j_mayer
    CPU_POWERPC_NPR161             = xxx,
6863 a750fc0b j_mayer
#endif
6864 a750fc0b j_mayer
#if 0
6865 80d11f44 j_mayer
    CPU_POWERPC_LC77700            = xxx,
6866 a750fc0b j_mayer
#endif
6867 a750fc0b j_mayer
    /* IBM STBxxx (PowerPC 401/403/405 core based microcontrollers) */
6868 a750fc0b j_mayer
#if 0
6869 80d11f44 j_mayer
    CPU_POWERPC_STB01000           = xxx,
6870 a750fc0b j_mayer
#endif
6871 a750fc0b j_mayer
#if 0
6872 80d11f44 j_mayer
    CPU_POWERPC_STB01010           = xxx,
6873 a750fc0b j_mayer
#endif
6874 a750fc0b j_mayer
#if 0
6875 80d11f44 j_mayer
    CPU_POWERPC_STB0210            = xxx, /* 401B3 */
6876 a750fc0b j_mayer
#endif
6877 80d11f44 j_mayer
    CPU_POWERPC_STB03              = 0x40310000, /* 0x40130000 ? */
6878 a750fc0b j_mayer
#if 0
6879 80d11f44 j_mayer
    CPU_POWERPC_STB043             = xxx,
6880 a750fc0b j_mayer
#endif
6881 a750fc0b j_mayer
#if 0
6882 80d11f44 j_mayer
    CPU_POWERPC_STB045             = xxx,
6883 a750fc0b j_mayer
#endif
6884 80d11f44 j_mayer
    CPU_POWERPC_STB04              = 0x41810000,
6885 80d11f44 j_mayer
    CPU_POWERPC_STB25              = 0x51510950,
6886 a750fc0b j_mayer
#if 0
6887 80d11f44 j_mayer
    CPU_POWERPC_STB130             = xxx,
6888 a750fc0b j_mayer
#endif
6889 a750fc0b j_mayer
    /* Xilinx cores */
6890 80d11f44 j_mayer
    CPU_POWERPC_X2VP4              = 0x20010820,
6891 80d11f44 j_mayer
#define CPU_POWERPC_X2VP7            CPU_POWERPC_X2VP4
6892 80d11f44 j_mayer
    CPU_POWERPC_X2VP20             = 0x20010860,
6893 80d11f44 j_mayer
#define CPU_POWERPC_X2VP50           CPU_POWERPC_X2VP20
6894 a750fc0b j_mayer
#if 0
6895 80d11f44 j_mayer
    CPU_POWERPC_ZL10310            = xxx,
6896 a750fc0b j_mayer
#endif
6897 a750fc0b j_mayer
#if 0
6898 80d11f44 j_mayer
    CPU_POWERPC_ZL10311            = xxx,
6899 a750fc0b j_mayer
#endif
6900 a750fc0b j_mayer
#if 0
6901 80d11f44 j_mayer
    CPU_POWERPC_ZL10320            = xxx,
6902 a750fc0b j_mayer
#endif
6903 a750fc0b j_mayer
#if 0
6904 80d11f44 j_mayer
    CPU_POWERPC_ZL10321            = xxx,
6905 a750fc0b j_mayer
#endif
6906 a750fc0b j_mayer
    /* PowerPC 440 family */
6907 a750fc0b j_mayer
    /* Generic PowerPC 440 */
6908 80d11f44 j_mayer
#define CPU_POWERPC_440              CPU_POWERPC_440GXf
6909 a750fc0b j_mayer
    /* PowerPC 440 cores */
6910 a750fc0b j_mayer
#if 0
6911 80d11f44 j_mayer
    CPU_POWERPC_440A4              = xxx,
6912 a750fc0b j_mayer
#endif
6913 95070372 Edgar E. Iglesias
    CPU_POWERPC_440_XILINX         = 0x7ff21910,
6914 a750fc0b j_mayer
#if 0
6915 80d11f44 j_mayer
    CPU_POWERPC_440A5              = xxx,
6916 a750fc0b j_mayer
#endif
6917 a750fc0b j_mayer
#if 0
6918 80d11f44 j_mayer
    CPU_POWERPC_440B4              = xxx,
6919 a750fc0b j_mayer
#endif
6920 a750fc0b j_mayer
#if 0
6921 80d11f44 j_mayer
    CPU_POWERPC_440F5              = xxx,
6922 a750fc0b j_mayer
#endif
6923 a750fc0b j_mayer
#if 0
6924 80d11f44 j_mayer
    CPU_POWERPC_440G5              = xxx,
6925 a750fc0b j_mayer
#endif
6926 a750fc0b j_mayer
#if 0
6927 80d11f44 j_mayer
    CPU_POWERPC_440H4              = xxx,
6928 a750fc0b j_mayer
#endif
6929 a750fc0b j_mayer
#if 0
6930 80d11f44 j_mayer
    CPU_POWERPC_440H6              = xxx,
6931 a750fc0b j_mayer
#endif
6932 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers */
6933 80d11f44 j_mayer
#define CPU_POWERPC_440EP            CPU_POWERPC_440EPb
6934 80d11f44 j_mayer
    CPU_POWERPC_440EPa             = 0x42221850,
6935 80d11f44 j_mayer
    CPU_POWERPC_440EPb             = 0x422218D3,
6936 80d11f44 j_mayer
#define CPU_POWERPC_440GP            CPU_POWERPC_440GPc
6937 80d11f44 j_mayer
    CPU_POWERPC_440GPb             = 0x40120440,
6938 80d11f44 j_mayer
    CPU_POWERPC_440GPc             = 0x40120481,
6939 80d11f44 j_mayer
#define CPU_POWERPC_440GR            CPU_POWERPC_440GRa
6940 80d11f44 j_mayer
#define CPU_POWERPC_440GRa           CPU_POWERPC_440EPb
6941 80d11f44 j_mayer
    CPU_POWERPC_440GRX             = 0x200008D0,
6942 80d11f44 j_mayer
#define CPU_POWERPC_440EPX           CPU_POWERPC_440GRX
6943 80d11f44 j_mayer
#define CPU_POWERPC_440GX            CPU_POWERPC_440GXf
6944 80d11f44 j_mayer
    CPU_POWERPC_440GXa             = 0x51B21850,
6945 80d11f44 j_mayer
    CPU_POWERPC_440GXb             = 0x51B21851,
6946 80d11f44 j_mayer
    CPU_POWERPC_440GXc             = 0x51B21892,
6947 80d11f44 j_mayer
    CPU_POWERPC_440GXf             = 0x51B21894,
6948 a750fc0b j_mayer
#if 0
6949 80d11f44 j_mayer
    CPU_POWERPC_440S               = xxx,
6950 a750fc0b j_mayer
#endif
6951 80d11f44 j_mayer
    CPU_POWERPC_440SP              = 0x53221850,
6952 80d11f44 j_mayer
    CPU_POWERPC_440SP2             = 0x53221891,
6953 80d11f44 j_mayer
    CPU_POWERPC_440SPE             = 0x53421890,
6954 a750fc0b j_mayer
    /* PowerPC 460 family */
6955 a750fc0b j_mayer
#if 0
6956 a750fc0b j_mayer
    /* Generic PowerPC 464 */
6957 80d11f44 j_mayer
#define CPU_POWERPC_464              CPU_POWERPC_464H90
6958 a750fc0b j_mayer
#endif
6959 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers */
6960 a750fc0b j_mayer
#if 0
6961 80d11f44 j_mayer
    CPU_POWERPC_464H90             = xxx,
6962 a750fc0b j_mayer
#endif
6963 a750fc0b j_mayer
#if 0
6964 80d11f44 j_mayer
    CPU_POWERPC_464H90FP           = xxx,
6965 a750fc0b j_mayer
#endif
6966 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores */
6967 c3e36823 j_mayer
    /* PowerPC MPC 5xx cores (aka RCPU) */
6968 80d11f44 j_mayer
    CPU_POWERPC_MPC5xx             = 0x00020020,
6969 80d11f44 j_mayer
#define CPU_POWERPC_MGT560           CPU_POWERPC_MPC5xx
6970 80d11f44 j_mayer
#define CPU_POWERPC_MPC509           CPU_POWERPC_MPC5xx
6971 80d11f44 j_mayer
#define CPU_POWERPC_MPC533           CPU_POWERPC_MPC5xx
6972 80d11f44 j_mayer
#define CPU_POWERPC_MPC534           CPU_POWERPC_MPC5xx
6973 80d11f44 j_mayer
#define CPU_POWERPC_MPC555           CPU_POWERPC_MPC5xx
6974 80d11f44 j_mayer
#define CPU_POWERPC_MPC556           CPU_POWERPC_MPC5xx
6975 80d11f44 j_mayer
#define CPU_POWERPC_MPC560           CPU_POWERPC_MPC5xx
6976 80d11f44 j_mayer
#define CPU_POWERPC_MPC561           CPU_POWERPC_MPC5xx
6977 80d11f44 j_mayer
#define CPU_POWERPC_MPC562           CPU_POWERPC_MPC5xx
6978 80d11f44 j_mayer
#define CPU_POWERPC_MPC563           CPU_POWERPC_MPC5xx
6979 80d11f44 j_mayer
#define CPU_POWERPC_MPC564           CPU_POWERPC_MPC5xx
6980 80d11f44 j_mayer
#define CPU_POWERPC_MPC565           CPU_POWERPC_MPC5xx
6981 80d11f44 j_mayer
#define CPU_POWERPC_MPC566           CPU_POWERPC_MPC5xx
6982 c3e36823 j_mayer
    /* PowerPC MPC 8xx cores (aka PowerQUICC) */
6983 80d11f44 j_mayer
    CPU_POWERPC_MPC8xx             = 0x00500000,
6984 80d11f44 j_mayer
#define CPU_POWERPC_MGT823           CPU_POWERPC_MPC8xx
6985 80d11f44 j_mayer
#define CPU_POWERPC_MPC821           CPU_POWERPC_MPC8xx
6986 80d11f44 j_mayer
#define CPU_POWERPC_MPC823           CPU_POWERPC_MPC8xx
6987 80d11f44 j_mayer
#define CPU_POWERPC_MPC850           CPU_POWERPC_MPC8xx
6988 80d11f44 j_mayer
#define CPU_POWERPC_MPC852T          CPU_POWERPC_MPC8xx
6989 80d11f44 j_mayer
#define CPU_POWERPC_MPC855T          CPU_POWERPC_MPC8xx
6990 80d11f44 j_mayer
#define CPU_POWERPC_MPC857           CPU_POWERPC_MPC8xx
6991 80d11f44 j_mayer
#define CPU_POWERPC_MPC859           CPU_POWERPC_MPC8xx
6992 80d11f44 j_mayer
#define CPU_POWERPC_MPC860           CPU_POWERPC_MPC8xx
6993 80d11f44 j_mayer
#define CPU_POWERPC_MPC862           CPU_POWERPC_MPC8xx
6994 80d11f44 j_mayer
#define CPU_POWERPC_MPC866           CPU_POWERPC_MPC8xx
6995 80d11f44 j_mayer
#define CPU_POWERPC_MPC870           CPU_POWERPC_MPC8xx
6996 80d11f44 j_mayer
#define CPU_POWERPC_MPC875           CPU_POWERPC_MPC8xx
6997 80d11f44 j_mayer
#define CPU_POWERPC_MPC880           CPU_POWERPC_MPC8xx
6998 80d11f44 j_mayer
#define CPU_POWERPC_MPC885           CPU_POWERPC_MPC8xx
6999 c3e36823 j_mayer
    /* G2 cores (aka PowerQUICC-II) */
7000 80d11f44 j_mayer
    CPU_POWERPC_G2                 = 0x00810011,
7001 80d11f44 j_mayer
    CPU_POWERPC_G2H4               = 0x80811010,
7002 80d11f44 j_mayer
    CPU_POWERPC_G2gp               = 0x80821010,
7003 80d11f44 j_mayer
    CPU_POWERPC_G2ls               = 0x90810010,
7004 80d11f44 j_mayer
    CPU_POWERPC_MPC603             = 0x00810100,
7005 80d11f44 j_mayer
    CPU_POWERPC_G2_HIP3            = 0x00810101,
7006 80d11f44 j_mayer
    CPU_POWERPC_G2_HIP4            = 0x80811014,
7007 c3e36823 j_mayer
    /*   G2_LE core (aka PowerQUICC-II) */
7008 80d11f44 j_mayer
    CPU_POWERPC_G2LE               = 0x80820010,
7009 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp             = 0x80822010,
7010 80d11f44 j_mayer
    CPU_POWERPC_G2LEls             = 0xA0822010,
7011 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp1            = 0x80822011,
7012 80d11f44 j_mayer
    CPU_POWERPC_G2LEgp3            = 0x80822013,
7013 80d11f44 j_mayer
    /* MPC52xx microcontrollers  */
7014 c3e36823 j_mayer
    /* XXX: MPC 5121 ? */
7015 80d11f44 j_mayer
#define CPU_POWERPC_MPC52xx          CPU_POWERPC_MPC5200
7016 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200          CPU_POWERPC_MPC5200_v12
7017 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v10      CPU_POWERPC_G2LEgp1
7018 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v11      CPU_POWERPC_G2LEgp1
7019 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200_v12      CPU_POWERPC_G2LEgp1
7020 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B         CPU_POWERPC_MPC5200B_v21
7021 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B_v20     CPU_POWERPC_G2LEgp1
7022 80d11f44 j_mayer
#define CPU_POWERPC_MPC5200B_v21     CPU_POWERPC_G2LEgp1
7023 80d11f44 j_mayer
    /* MPC82xx microcontrollers */
7024 80d11f44 j_mayer
#define CPU_POWERPC_MPC82xx          CPU_POWERPC_MPC8280
7025 80d11f44 j_mayer
#define CPU_POWERPC_MPC8240          CPU_POWERPC_MPC603
7026 80d11f44 j_mayer
#define CPU_POWERPC_MPC8241          CPU_POWERPC_G2_HIP4
7027 80d11f44 j_mayer
#define CPU_POWERPC_MPC8245          CPU_POWERPC_G2_HIP4
7028 80d11f44 j_mayer
#define CPU_POWERPC_MPC8247          CPU_POWERPC_G2LEgp3
7029 80d11f44 j_mayer
#define CPU_POWERPC_MPC8248          CPU_POWERPC_G2LEgp3
7030 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250          CPU_POWERPC_MPC8250_HiP4
7031 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250_HiP3     CPU_POWERPC_G2_HIP3
7032 80d11f44 j_mayer
#define CPU_POWERPC_MPC8250_HiP4     CPU_POWERPC_G2_HIP4
7033 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255          CPU_POWERPC_MPC8255_HiP4
7034 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255_HiP3     CPU_POWERPC_G2_HIP3
7035 80d11f44 j_mayer
#define CPU_POWERPC_MPC8255_HiP4     CPU_POWERPC_G2_HIP4
7036 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260          CPU_POWERPC_MPC8260_HiP4
7037 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260_HiP3     CPU_POWERPC_G2_HIP3
7038 80d11f44 j_mayer
#define CPU_POWERPC_MPC8260_HiP4     CPU_POWERPC_G2_HIP4
7039 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264          CPU_POWERPC_MPC8264_HiP4
7040 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264_HiP3     CPU_POWERPC_G2_HIP3
7041 80d11f44 j_mayer
#define CPU_POWERPC_MPC8264_HiP4     CPU_POWERPC_G2_HIP4
7042 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265          CPU_POWERPC_MPC8265_HiP4
7043 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265_HiP3     CPU_POWERPC_G2_HIP3
7044 80d11f44 j_mayer
#define CPU_POWERPC_MPC8265_HiP4     CPU_POWERPC_G2_HIP4
7045 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266          CPU_POWERPC_MPC8266_HiP4
7046 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266_HiP3     CPU_POWERPC_G2_HIP3
7047 80d11f44 j_mayer
#define CPU_POWERPC_MPC8266_HiP4     CPU_POWERPC_G2_HIP4
7048 80d11f44 j_mayer
#define CPU_POWERPC_MPC8270          CPU_POWERPC_G2LEgp3
7049 80d11f44 j_mayer
#define CPU_POWERPC_MPC8271          CPU_POWERPC_G2LEgp3
7050 80d11f44 j_mayer
#define CPU_POWERPC_MPC8272          CPU_POWERPC_G2LEgp3
7051 80d11f44 j_mayer
#define CPU_POWERPC_MPC8275          CPU_POWERPC_G2LEgp3
7052 80d11f44 j_mayer
#define CPU_POWERPC_MPC8280          CPU_POWERPC_G2LEgp3
7053 a750fc0b j_mayer
    /* e200 family */
7054 80d11f44 j_mayer
    /* e200 cores */
7055 80d11f44 j_mayer
#define CPU_POWERPC_e200             CPU_POWERPC_e200z6
7056 a750fc0b j_mayer
#if 0
7057 80d11f44 j_mayer
    CPU_POWERPC_e200z0             = xxx,
7058 a750fc0b j_mayer
#endif
7059 a750fc0b j_mayer
#if 0
7060 80d11f44 j_mayer
    CPU_POWERPC_e200z1             = xxx,
7061 c3e36823 j_mayer
#endif
7062 c3e36823 j_mayer
#if 0 /* ? */
7063 80d11f44 j_mayer
    CPU_POWERPC_e200z3             = 0x81120000,
7064 80d11f44 j_mayer
#endif
7065 80d11f44 j_mayer
    CPU_POWERPC_e200z5             = 0x81000000,
7066 80d11f44 j_mayer
    CPU_POWERPC_e200z6             = 0x81120000,
7067 80d11f44 j_mayer
    /* MPC55xx microcontrollers */
7068 80d11f44 j_mayer
#define CPU_POWERPC_MPC55xx          CPU_POWERPC_MPC5567
7069 80d11f44 j_mayer
#if 0
7070 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E         CPU_POWERPC_MPC5514E_v1
7071 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E_v0      CPU_POWERPC_e200z0
7072 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514E_v1      CPU_POWERPC_e200z1
7073 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G         CPU_POWERPC_MPC5514G_v1
7074 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G_v0      CPU_POWERPC_e200z0
7075 80d11f44 j_mayer
#define CPU_POWERPC_MPC5514G_v1      CPU_POWERPC_e200z1
7076 80d11f44 j_mayer
#define CPU_POWERPC_MPC5515S         CPU_POWERPC_e200z1
7077 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E         CPU_POWERPC_MPC5516E_v1
7078 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E_v0      CPU_POWERPC_e200z0
7079 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516E_v1      CPU_POWERPC_e200z1
7080 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G         CPU_POWERPC_MPC5516G_v1
7081 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G_v0      CPU_POWERPC_e200z0
7082 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516G_v1      CPU_POWERPC_e200z1
7083 80d11f44 j_mayer
#define CPU_POWERPC_MPC5516S         CPU_POWERPC_e200z1
7084 80d11f44 j_mayer
#endif
7085 80d11f44 j_mayer
#if 0
7086 80d11f44 j_mayer
#define CPU_POWERPC_MPC5533          CPU_POWERPC_e200z3
7087 80d11f44 j_mayer
#define CPU_POWERPC_MPC5534          CPU_POWERPC_e200z3
7088 80d11f44 j_mayer
#endif
7089 80d11f44 j_mayer
#define CPU_POWERPC_MPC5553          CPU_POWERPC_e200z6
7090 80d11f44 j_mayer
#define CPU_POWERPC_MPC5554          CPU_POWERPC_e200z6
7091 80d11f44 j_mayer
#define CPU_POWERPC_MPC5561          CPU_POWERPC_e200z6
7092 80d11f44 j_mayer
#define CPU_POWERPC_MPC5565          CPU_POWERPC_e200z6
7093 80d11f44 j_mayer
#define CPU_POWERPC_MPC5566          CPU_POWERPC_e200z6
7094 80d11f44 j_mayer
#define CPU_POWERPC_MPC5567          CPU_POWERPC_e200z6
7095 a750fc0b j_mayer
    /* e300 family */
7096 80d11f44 j_mayer
    /* e300 cores */
7097 80d11f44 j_mayer
#define CPU_POWERPC_e300             CPU_POWERPC_e300c3
7098 80d11f44 j_mayer
    CPU_POWERPC_e300c1             = 0x00830010,
7099 80d11f44 j_mayer
    CPU_POWERPC_e300c2             = 0x00840010,
7100 80d11f44 j_mayer
    CPU_POWERPC_e300c3             = 0x00850010,
7101 80d11f44 j_mayer
    CPU_POWERPC_e300c4             = 0x00860010,
7102 80d11f44 j_mayer
    /* MPC83xx microcontrollers */
7103 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC831x          CPU_POWERPC_e300c3
7104 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC832x          CPU_POWERPC_e300c2
7105 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC834x          CPU_POWERPC_e300c1
7106 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC835x          CPU_POWERPC_e300c1
7107 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC836x          CPU_POWERPC_e300c1
7108 74d77cae Thomas Monjalon
#define CPU_POWERPC_MPC837x          CPU_POWERPC_e300c4
7109 a750fc0b j_mayer
    /* e500 family */
7110 80d11f44 j_mayer
    /* e500 cores  */
7111 80d11f44 j_mayer
#define CPU_POWERPC_e500             CPU_POWERPC_e500v2_v22
7112 bd5ea513 aurel32
#define CPU_POWERPC_e500v1           CPU_POWERPC_e500v1_v20
7113 80d11f44 j_mayer
#define CPU_POWERPC_e500v2           CPU_POWERPC_e500v2_v22
7114 bd5ea513 aurel32
    CPU_POWERPC_e500v1_v10         = 0x80200010,
7115 bd5ea513 aurel32
    CPU_POWERPC_e500v1_v20         = 0x80200020,
7116 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v10         = 0x80210010,
7117 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v11         = 0x80210011,
7118 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v20         = 0x80210020,
7119 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v21         = 0x80210021,
7120 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v22         = 0x80210022,
7121 80d11f44 j_mayer
    CPU_POWERPC_e500v2_v30         = 0x80210030,
7122 f7aa5583 Varun Sethi
    CPU_POWERPC_e500mc             = 0x80230020,
7123 80d11f44 j_mayer
    /* MPC85xx microcontrollers */
7124 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533          CPU_POWERPC_MPC8533_v11
7125 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533_v10      CPU_POWERPC_e500v2_v21
7126 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533_v11      CPU_POWERPC_e500v2_v22
7127 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E         CPU_POWERPC_MPC8533E_v11
7128 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E_v10     CPU_POWERPC_e500v2_v21
7129 80d11f44 j_mayer
#define CPU_POWERPC_MPC8533E_v11     CPU_POWERPC_e500v2_v22
7130 80d11f44 j_mayer
#define CPU_POWERPC_MPC8540          CPU_POWERPC_MPC8540_v21
7131 bd5ea513 aurel32
#define CPU_POWERPC_MPC8540_v10      CPU_POWERPC_e500v1_v10
7132 bd5ea513 aurel32
#define CPU_POWERPC_MPC8540_v20      CPU_POWERPC_e500v1_v20
7133 bd5ea513 aurel32
#define CPU_POWERPC_MPC8540_v21      CPU_POWERPC_e500v1_v20
7134 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541          CPU_POWERPC_MPC8541_v11
7135 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541_v10      CPU_POWERPC_e500v1_v20
7136 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541_v11      CPU_POWERPC_e500v1_v20
7137 80d11f44 j_mayer
#define CPU_POWERPC_MPC8541E         CPU_POWERPC_MPC8541E_v11
7138 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541E_v10     CPU_POWERPC_e500v1_v20
7139 bd5ea513 aurel32
#define CPU_POWERPC_MPC8541E_v11     CPU_POWERPC_e500v1_v20
7140 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543          CPU_POWERPC_MPC8543_v21
7141 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v10      CPU_POWERPC_e500v2_v10
7142 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v11      CPU_POWERPC_e500v2_v11
7143 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v20      CPU_POWERPC_e500v2_v20
7144 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543_v21      CPU_POWERPC_e500v2_v21
7145 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E         CPU_POWERPC_MPC8543E_v21
7146 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v10     CPU_POWERPC_e500v2_v10
7147 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v11     CPU_POWERPC_e500v2_v11
7148 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v20     CPU_POWERPC_e500v2_v20
7149 80d11f44 j_mayer
#define CPU_POWERPC_MPC8543E_v21     CPU_POWERPC_e500v2_v21
7150 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544          CPU_POWERPC_MPC8544_v11
7151 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544_v10      CPU_POWERPC_e500v2_v21
7152 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544_v11      CPU_POWERPC_e500v2_v22
7153 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E_v11     CPU_POWERPC_e500v2_v22
7154 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E         CPU_POWERPC_MPC8544E_v11
7155 80d11f44 j_mayer
#define CPU_POWERPC_MPC8544E_v10     CPU_POWERPC_e500v2_v21
7156 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545          CPU_POWERPC_MPC8545_v21
7157 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v10      CPU_POWERPC_e500v2_v10
7158 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v20      CPU_POWERPC_e500v2_v20
7159 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545_v21      CPU_POWERPC_e500v2_v21
7160 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E         CPU_POWERPC_MPC8545E_v21
7161 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v10     CPU_POWERPC_e500v2_v10
7162 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v20     CPU_POWERPC_e500v2_v20
7163 80d11f44 j_mayer
#define CPU_POWERPC_MPC8545E_v21     CPU_POWERPC_e500v2_v21
7164 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E         CPU_POWERPC_MPC8545E_v21
7165 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v10     CPU_POWERPC_e500v2_v10
7166 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v20     CPU_POWERPC_e500v2_v20
7167 80d11f44 j_mayer
#define CPU_POWERPC_MPC8547E_v21     CPU_POWERPC_e500v2_v21
7168 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548          CPU_POWERPC_MPC8548_v21
7169 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v10      CPU_POWERPC_e500v2_v10
7170 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v11      CPU_POWERPC_e500v2_v11
7171 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v20      CPU_POWERPC_e500v2_v20
7172 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548_v21      CPU_POWERPC_e500v2_v21
7173 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E         CPU_POWERPC_MPC8548E_v21
7174 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v10     CPU_POWERPC_e500v2_v10
7175 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v11     CPU_POWERPC_e500v2_v11
7176 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v20     CPU_POWERPC_e500v2_v20
7177 80d11f44 j_mayer
#define CPU_POWERPC_MPC8548E_v21     CPU_POWERPC_e500v2_v21
7178 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555          CPU_POWERPC_MPC8555_v11
7179 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555_v10      CPU_POWERPC_e500v2_v10
7180 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555_v11      CPU_POWERPC_e500v2_v11
7181 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E         CPU_POWERPC_MPC8555E_v11
7182 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E_v10     CPU_POWERPC_e500v2_v10
7183 80d11f44 j_mayer
#define CPU_POWERPC_MPC8555E_v11     CPU_POWERPC_e500v2_v11
7184 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560          CPU_POWERPC_MPC8560_v21
7185 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v10      CPU_POWERPC_e500v2_v10
7186 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v20      CPU_POWERPC_e500v2_v20
7187 80d11f44 j_mayer
#define CPU_POWERPC_MPC8560_v21      CPU_POWERPC_e500v2_v21
7188 80d11f44 j_mayer
#define CPU_POWERPC_MPC8567          CPU_POWERPC_e500v2_v22
7189 80d11f44 j_mayer
#define CPU_POWERPC_MPC8567E         CPU_POWERPC_e500v2_v22
7190 80d11f44 j_mayer
#define CPU_POWERPC_MPC8568          CPU_POWERPC_e500v2_v22
7191 80d11f44 j_mayer
#define CPU_POWERPC_MPC8568E         CPU_POWERPC_e500v2_v22
7192 80d11f44 j_mayer
#define CPU_POWERPC_MPC8572          CPU_POWERPC_e500v2_v30
7193 80d11f44 j_mayer
#define CPU_POWERPC_MPC8572E         CPU_POWERPC_e500v2_v30
7194 a750fc0b j_mayer
    /* e600 family */
7195 80d11f44 j_mayer
    /* e600 cores */
7196 80d11f44 j_mayer
    CPU_POWERPC_e600               = 0x80040010,
7197 80d11f44 j_mayer
    /* MPC86xx microcontrollers */
7198 80d11f44 j_mayer
#define CPU_POWERPC_MPC8610          CPU_POWERPC_e600
7199 80d11f44 j_mayer
#define CPU_POWERPC_MPC8641          CPU_POWERPC_e600
7200 80d11f44 j_mayer
#define CPU_POWERPC_MPC8641D         CPU_POWERPC_e600
7201 a750fc0b j_mayer
    /* PowerPC 6xx cores */
7202 80d11f44 j_mayer
#define CPU_POWERPC_601              CPU_POWERPC_601_v2
7203 80d11f44 j_mayer
    CPU_POWERPC_601_v0             = 0x00010001,
7204 80d11f44 j_mayer
    CPU_POWERPC_601_v1             = 0x00010001,
7205 bd928eba j_mayer
#define CPU_POWERPC_601v             CPU_POWERPC_601_v2
7206 80d11f44 j_mayer
    CPU_POWERPC_601_v2             = 0x00010002,
7207 80d11f44 j_mayer
    CPU_POWERPC_602                = 0x00050100,
7208 80d11f44 j_mayer
    CPU_POWERPC_603                = 0x00030100,
7209 80d11f44 j_mayer
#define CPU_POWERPC_603E             CPU_POWERPC_603E_v41
7210 80d11f44 j_mayer
    CPU_POWERPC_603E_v11           = 0x00060101,
7211 80d11f44 j_mayer
    CPU_POWERPC_603E_v12           = 0x00060102,
7212 80d11f44 j_mayer
    CPU_POWERPC_603E_v13           = 0x00060103,
7213 80d11f44 j_mayer
    CPU_POWERPC_603E_v14           = 0x00060104,
7214 80d11f44 j_mayer
    CPU_POWERPC_603E_v22           = 0x00060202,
7215 80d11f44 j_mayer
    CPU_POWERPC_603E_v3            = 0x00060300,
7216 80d11f44 j_mayer
    CPU_POWERPC_603E_v4            = 0x00060400,
7217 80d11f44 j_mayer
    CPU_POWERPC_603E_v41           = 0x00060401,
7218 80d11f44 j_mayer
    CPU_POWERPC_603E7t             = 0x00071201,
7219 80d11f44 j_mayer
    CPU_POWERPC_603E7v             = 0x00070100,
7220 80d11f44 j_mayer
    CPU_POWERPC_603E7v1            = 0x00070101,
7221 80d11f44 j_mayer
    CPU_POWERPC_603E7v2            = 0x00070201,
7222 80d11f44 j_mayer
    CPU_POWERPC_603E7              = 0x00070200,
7223 80d11f44 j_mayer
    CPU_POWERPC_603P               = 0x00070000,
7224 80d11f44 j_mayer
#define CPU_POWERPC_603R             CPU_POWERPC_603E7t
7225 c3e36823 j_mayer
    /* XXX: missing 0x00040303 (604) */
7226 80d11f44 j_mayer
    CPU_POWERPC_604                = 0x00040103,
7227 80d11f44 j_mayer
#define CPU_POWERPC_604E             CPU_POWERPC_604E_v24
7228 c3e36823 j_mayer
    /* XXX: missing 0x00091203 */
7229 c3e36823 j_mayer
    /* XXX: missing 0x00092110 */
7230 c3e36823 j_mayer
    /* XXX: missing 0x00092120 */
7231 80d11f44 j_mayer
    CPU_POWERPC_604E_v10           = 0x00090100,
7232 80d11f44 j_mayer
    CPU_POWERPC_604E_v22           = 0x00090202,
7233 80d11f44 j_mayer
    CPU_POWERPC_604E_v24           = 0x00090204,
7234 c3e36823 j_mayer
    /* XXX: missing 0x000a0100 */
7235 c3e36823 j_mayer
    /* XXX: missing 0x00093102 */
7236 80d11f44 j_mayer
    CPU_POWERPC_604R               = 0x000a0101,
7237 a750fc0b j_mayer
#if 0
7238 80d11f44 j_mayer
    CPU_POWERPC_604EV              = xxx, /* XXX: same as 604R ? */
7239 a750fc0b j_mayer
#endif
7240 a750fc0b j_mayer
    /* PowerPC 740/750 cores (aka G3) */
7241 a750fc0b j_mayer
    /* XXX: missing 0x00084202 */
7242 80d11f44 j_mayer
#define CPU_POWERPC_7x0              CPU_POWERPC_7x0_v31
7243 bd928eba j_mayer
    CPU_POWERPC_7x0_v10            = 0x00080100,
7244 80d11f44 j_mayer
    CPU_POWERPC_7x0_v20            = 0x00080200,
7245 80d11f44 j_mayer
    CPU_POWERPC_7x0_v21            = 0x00080201,
7246 80d11f44 j_mayer
    CPU_POWERPC_7x0_v22            = 0x00080202,
7247 80d11f44 j_mayer
    CPU_POWERPC_7x0_v30            = 0x00080300,
7248 80d11f44 j_mayer
    CPU_POWERPC_7x0_v31            = 0x00080301,
7249 80d11f44 j_mayer
    CPU_POWERPC_740E               = 0x00080100,
7250 bd928eba j_mayer
    CPU_POWERPC_750E               = 0x00080200,
7251 80d11f44 j_mayer
    CPU_POWERPC_7x0P               = 0x10080000,
7252 a750fc0b j_mayer
    /* XXX: missing 0x00087010 (CL ?) */
7253 bd928eba j_mayer
#define CPU_POWERPC_750CL            CPU_POWERPC_750CL_v20
7254 bd928eba j_mayer
    CPU_POWERPC_750CL_v10          = 0x00087200,
7255 bd928eba j_mayer
    CPU_POWERPC_750CL_v20          = 0x00087210, /* aka rev E */
7256 80d11f44 j_mayer
#define CPU_POWERPC_750CX            CPU_POWERPC_750CX_v22
7257 bd928eba j_mayer
    CPU_POWERPC_750CX_v10          = 0x00082100,
7258 bd928eba j_mayer
    CPU_POWERPC_750CX_v20          = 0x00082200,
7259 80d11f44 j_mayer
    CPU_POWERPC_750CX_v21          = 0x00082201,
7260 80d11f44 j_mayer
    CPU_POWERPC_750CX_v22          = 0x00082202,
7261 80d11f44 j_mayer
#define CPU_POWERPC_750CXE           CPU_POWERPC_750CXE_v31b
7262 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v21         = 0x00082211,
7263 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v22         = 0x00082212,
7264 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v23         = 0x00082213,
7265 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v24         = 0x00082214,
7266 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v24b        = 0x00083214,
7267 bd928eba j_mayer
    CPU_POWERPC_750CXE_v30         = 0x00082310,
7268 bd928eba j_mayer
    CPU_POWERPC_750CXE_v31         = 0x00082311,
7269 80d11f44 j_mayer
    CPU_POWERPC_750CXE_v31b        = 0x00083311,
7270 80d11f44 j_mayer
    CPU_POWERPC_750CXR             = 0x00083410,
7271 bd928eba j_mayer
    CPU_POWERPC_750FL              = 0x70000203,
7272 80d11f44 j_mayer
#define CPU_POWERPC_750FX            CPU_POWERPC_750FX_v23
7273 80d11f44 j_mayer
    CPU_POWERPC_750FX_v10          = 0x70000100,
7274 80d11f44 j_mayer
    CPU_POWERPC_750FX_v20          = 0x70000200,
7275 80d11f44 j_mayer
    CPU_POWERPC_750FX_v21          = 0x70000201,
7276 80d11f44 j_mayer
    CPU_POWERPC_750FX_v22          = 0x70000202,
7277 80d11f44 j_mayer
    CPU_POWERPC_750FX_v23          = 0x70000203,
7278 80d11f44 j_mayer
    CPU_POWERPC_750GL              = 0x70020102,
7279 80d11f44 j_mayer
#define CPU_POWERPC_750GX            CPU_POWERPC_750GX_v12
7280 80d11f44 j_mayer
    CPU_POWERPC_750GX_v10          = 0x70020100,
7281 80d11f44 j_mayer
    CPU_POWERPC_750GX_v11          = 0x70020101,
7282 80d11f44 j_mayer
    CPU_POWERPC_750GX_v12          = 0x70020102,
7283 80d11f44 j_mayer
#define CPU_POWERPC_750L             CPU_POWERPC_750L_v32 /* Aka LoneStar */
7284 bd928eba j_mayer
    CPU_POWERPC_750L_v20           = 0x00088200,
7285 bd928eba j_mayer
    CPU_POWERPC_750L_v21           = 0x00088201,
7286 80d11f44 j_mayer
    CPU_POWERPC_750L_v22           = 0x00088202,
7287 80d11f44 j_mayer
    CPU_POWERPC_750L_v30           = 0x00088300,
7288 80d11f44 j_mayer
    CPU_POWERPC_750L_v32           = 0x00088302,
7289 a750fc0b j_mayer
    /* PowerPC 745/755 cores */
7290 80d11f44 j_mayer
#define CPU_POWERPC_7x5              CPU_POWERPC_7x5_v28
7291 80d11f44 j_mayer
    CPU_POWERPC_7x5_v10            = 0x00083100,
7292 80d11f44 j_mayer
    CPU_POWERPC_7x5_v11            = 0x00083101,
7293 80d11f44 j_mayer
    CPU_POWERPC_7x5_v20            = 0x00083200,
7294 80d11f44 j_mayer
    CPU_POWERPC_7x5_v21            = 0x00083201,
7295 80d11f44 j_mayer
    CPU_POWERPC_7x5_v22            = 0x00083202, /* aka D */
7296 80d11f44 j_mayer
    CPU_POWERPC_7x5_v23            = 0x00083203, /* aka E */
7297 80d11f44 j_mayer
    CPU_POWERPC_7x5_v24            = 0x00083204,
7298 80d11f44 j_mayer
    CPU_POWERPC_7x5_v25            = 0x00083205,
7299 80d11f44 j_mayer
    CPU_POWERPC_7x5_v26            = 0x00083206,
7300 80d11f44 j_mayer
    CPU_POWERPC_7x5_v27            = 0x00083207,
7301 80d11f44 j_mayer
    CPU_POWERPC_7x5_v28            = 0x00083208,
7302 a750fc0b j_mayer
#if 0
7303 80d11f44 j_mayer
    CPU_POWERPC_7x5P               = xxx,
7304 a750fc0b j_mayer
#endif
7305 a750fc0b j_mayer
    /* PowerPC 74xx cores (aka G4) */
7306 a750fc0b j_mayer
    /* XXX: missing 0x000C1101 */
7307 80d11f44 j_mayer
#define CPU_POWERPC_7400             CPU_POWERPC_7400_v29
7308 80d11f44 j_mayer
    CPU_POWERPC_7400_v10           = 0x000C0100,
7309 80d11f44 j_mayer
    CPU_POWERPC_7400_v11           = 0x000C0101,
7310 80d11f44 j_mayer
    CPU_POWERPC_7400_v20           = 0x000C0200,
7311 4e777442 j_mayer
    CPU_POWERPC_7400_v21           = 0x000C0201,
7312 80d11f44 j_mayer
    CPU_POWERPC_7400_v22           = 0x000C0202,
7313 80d11f44 j_mayer
    CPU_POWERPC_7400_v26           = 0x000C0206,
7314 80d11f44 j_mayer
    CPU_POWERPC_7400_v27           = 0x000C0207,
7315 80d11f44 j_mayer
    CPU_POWERPC_7400_v28           = 0x000C0208,
7316 80d11f44 j_mayer
    CPU_POWERPC_7400_v29           = 0x000C0209,
7317 80d11f44 j_mayer
#define CPU_POWERPC_7410             CPU_POWERPC_7410_v14
7318 80d11f44 j_mayer
    CPU_POWERPC_7410_v10           = 0x800C1100,
7319 80d11f44 j_mayer
    CPU_POWERPC_7410_v11           = 0x800C1101,
7320 80d11f44 j_mayer
    CPU_POWERPC_7410_v12           = 0x800C1102, /* aka C */
7321 80d11f44 j_mayer
    CPU_POWERPC_7410_v13           = 0x800C1103, /* aka D */
7322 80d11f44 j_mayer
    CPU_POWERPC_7410_v14           = 0x800C1104, /* aka E */
7323 80d11f44 j_mayer
#define CPU_POWERPC_7448             CPU_POWERPC_7448_v21
7324 80d11f44 j_mayer
    CPU_POWERPC_7448_v10           = 0x80040100,
7325 80d11f44 j_mayer
    CPU_POWERPC_7448_v11           = 0x80040101,
7326 80d11f44 j_mayer
    CPU_POWERPC_7448_v20           = 0x80040200,
7327 80d11f44 j_mayer
    CPU_POWERPC_7448_v21           = 0x80040201,
7328 80d11f44 j_mayer
#define CPU_POWERPC_7450             CPU_POWERPC_7450_v21
7329 80d11f44 j_mayer
    CPU_POWERPC_7450_v10           = 0x80000100,
7330 80d11f44 j_mayer
    CPU_POWERPC_7450_v11           = 0x80000101,
7331 80d11f44 j_mayer
    CPU_POWERPC_7450_v12           = 0x80000102,
7332 4e777442 j_mayer
    CPU_POWERPC_7450_v20           = 0x80000200, /* aka A, B, C, D: 2.04 */
7333 80d11f44 j_mayer
    CPU_POWERPC_7450_v21           = 0x80000201, /* aka E */
7334 4e777442 j_mayer
#define CPU_POWERPC_74x1             CPU_POWERPC_74x1_v23
7335 4e777442 j_mayer
    CPU_POWERPC_74x1_v23           = 0x80000203, /* aka G: 2.3 */
7336 4e777442 j_mayer
    /* XXX: this entry might be a bug in some documentation */
7337 4e777442 j_mayer
    CPU_POWERPC_74x1_v210          = 0x80000210, /* aka G: 2.3 ? */
7338 80d11f44 j_mayer
#define CPU_POWERPC_74x5             CPU_POWERPC_74x5_v32
7339 80d11f44 j_mayer
    CPU_POWERPC_74x5_v10           = 0x80010100,
7340 c3e36823 j_mayer
    /* XXX: missing 0x80010200 */
7341 80d11f44 j_mayer
    CPU_POWERPC_74x5_v21           = 0x80010201, /* aka C: 2.1 */
7342 80d11f44 j_mayer
    CPU_POWERPC_74x5_v32           = 0x80010302,
7343 80d11f44 j_mayer
    CPU_POWERPC_74x5_v33           = 0x80010303, /* aka F: 3.3 */
7344 80d11f44 j_mayer
    CPU_POWERPC_74x5_v34           = 0x80010304, /* aka G: 3.4 */
7345 80d11f44 j_mayer
#define CPU_POWERPC_74x7             CPU_POWERPC_74x7_v12
7346 80d11f44 j_mayer
    CPU_POWERPC_74x7_v10           = 0x80020100, /* aka A: 1.0 */
7347 082c6681 j_mayer
    CPU_POWERPC_74x7_v11           = 0x80020101, /* aka B: 1.1 */
7348 80d11f44 j_mayer
    CPU_POWERPC_74x7_v12           = 0x80020102, /* aka C: 1.2 */
7349 082c6681 j_mayer
#define CPU_POWERPC_74x7A            CPU_POWERPC_74x7A_v12
7350 082c6681 j_mayer
    CPU_POWERPC_74x7A_v10          = 0x80030100, /* aka A: 1.0 */
7351 082c6681 j_mayer
    CPU_POWERPC_74x7A_v11          = 0x80030101, /* aka B: 1.1 */
7352 082c6681 j_mayer
    CPU_POWERPC_74x7A_v12          = 0x80030102, /* aka C: 1.2 */
7353 a750fc0b j_mayer
    /* 64 bits PowerPC */
7354 00af685f j_mayer
#if defined(TARGET_PPC64)
7355 80d11f44 j_mayer
    CPU_POWERPC_620                = 0x00140000,
7356 80d11f44 j_mayer
    CPU_POWERPC_630                = 0x00400000,
7357 80d11f44 j_mayer
    CPU_POWERPC_631                = 0x00410104,
7358 80d11f44 j_mayer
    CPU_POWERPC_POWER4             = 0x00350000,
7359 80d11f44 j_mayer
    CPU_POWERPC_POWER4P            = 0x00380000,
7360 c3e36823 j_mayer
     /* XXX: missing 0x003A0201 */
7361 80d11f44 j_mayer
    CPU_POWERPC_POWER5             = 0x003A0203,
7362 80d11f44 j_mayer
#define CPU_POWERPC_POWER5GR         CPU_POWERPC_POWER5
7363 80d11f44 j_mayer
    CPU_POWERPC_POWER5P            = 0x003B0000,
7364 80d11f44 j_mayer
#define CPU_POWERPC_POWER5GS         CPU_POWERPC_POWER5P
7365 80d11f44 j_mayer
    CPU_POWERPC_POWER6             = 0x003E0000,
7366 80d11f44 j_mayer
    CPU_POWERPC_POWER6_5           = 0x0F000001, /* POWER6 in POWER5 mode */
7367 80d11f44 j_mayer
    CPU_POWERPC_POWER6A            = 0x0F000002,
7368 9d52e907 David Gibson
#define CPU_POWERPC_POWER7           CPU_POWERPC_POWER7_v20
7369 9d52e907 David Gibson
    CPU_POWERPC_POWER7_v20         = 0x003F0200,
7370 37e305ce David Gibson
    CPU_POWERPC_POWER7_v21         = 0x003F0201,
7371 37e305ce David Gibson
    CPU_POWERPC_POWER7_v23         = 0x003F0203,
7372 80d11f44 j_mayer
    CPU_POWERPC_970                = 0x00390202,
7373 80d11f44 j_mayer
#define CPU_POWERPC_970FX            CPU_POWERPC_970FX_v31
7374 80d11f44 j_mayer
    CPU_POWERPC_970FX_v10          = 0x00391100,
7375 80d11f44 j_mayer
    CPU_POWERPC_970FX_v20          = 0x003C0200,
7376 80d11f44 j_mayer
    CPU_POWERPC_970FX_v21          = 0x003C0201,
7377 80d11f44 j_mayer
    CPU_POWERPC_970FX_v30          = 0x003C0300,
7378 80d11f44 j_mayer
    CPU_POWERPC_970FX_v31          = 0x003C0301,
7379 80d11f44 j_mayer
    CPU_POWERPC_970GX              = 0x00450000,
7380 80d11f44 j_mayer
#define CPU_POWERPC_970MP            CPU_POWERPC_970MP_v11
7381 80d11f44 j_mayer
    CPU_POWERPC_970MP_v10          = 0x00440100,
7382 80d11f44 j_mayer
    CPU_POWERPC_970MP_v11          = 0x00440101,
7383 80d11f44 j_mayer
#define CPU_POWERPC_CELL             CPU_POWERPC_CELL_v32
7384 80d11f44 j_mayer
    CPU_POWERPC_CELL_v10           = 0x00700100,
7385 80d11f44 j_mayer
    CPU_POWERPC_CELL_v20           = 0x00700400,
7386 80d11f44 j_mayer
    CPU_POWERPC_CELL_v30           = 0x00700500,
7387 80d11f44 j_mayer
    CPU_POWERPC_CELL_v31           = 0x00700501,
7388 80d11f44 j_mayer
#define CPU_POWERPC_CELL_v32         CPU_POWERPC_CELL_v31
7389 80d11f44 j_mayer
    CPU_POWERPC_RS64               = 0x00330000,
7390 80d11f44 j_mayer
    CPU_POWERPC_RS64II             = 0x00340000,
7391 80d11f44 j_mayer
    CPU_POWERPC_RS64III            = 0x00360000,
7392 80d11f44 j_mayer
    CPU_POWERPC_RS64IV             = 0x00370000,
7393 00af685f j_mayer
#endif /* defined(TARGET_PPC64) */
7394 a750fc0b j_mayer
    /* Original POWER */
7395 a750fc0b j_mayer
    /* XXX: should be POWER (RIOS), RSC3308, RSC4608,
7396 a750fc0b j_mayer
     * POWER2 (RIOS2) & RSC2 (P2SC) here
7397 a750fc0b j_mayer
     */
7398 a750fc0b j_mayer
#if 0
7399 80d11f44 j_mayer
    CPU_POWER                      = xxx, /* 0x20000 ? 0x30000 for RSC ? */
7400 a750fc0b j_mayer
#endif
7401 a750fc0b j_mayer
#if 0
7402 80d11f44 j_mayer
    CPU_POWER2                     = xxx, /* 0x40000 ? */
7403 a750fc0b j_mayer
#endif
7404 a750fc0b j_mayer
    /* PA Semi core */
7405 80d11f44 j_mayer
    CPU_POWERPC_PA6T               = 0x00900000,
7406 a750fc0b j_mayer
};
7407 a750fc0b j_mayer
7408 a750fc0b j_mayer
/* System version register (used on MPC 8xxx)                                */
7409 a750fc0b j_mayer
enum {
7410 80d11f44 j_mayer
    POWERPC_SVR_NONE               = 0x00000000,
7411 80d11f44 j_mayer
#define POWERPC_SVR_52xx             POWERPC_SVR_5200
7412 80d11f44 j_mayer
#define POWERPC_SVR_5200             POWERPC_SVR_5200_v12
7413 80d11f44 j_mayer
    POWERPC_SVR_5200_v10           = 0x80110010,
7414 80d11f44 j_mayer
    POWERPC_SVR_5200_v11           = 0x80110011,
7415 80d11f44 j_mayer
    POWERPC_SVR_5200_v12           = 0x80110012,
7416 80d11f44 j_mayer
#define POWERPC_SVR_5200B            POWERPC_SVR_5200B_v21
7417 80d11f44 j_mayer
    POWERPC_SVR_5200B_v20          = 0x80110020,
7418 80d11f44 j_mayer
    POWERPC_SVR_5200B_v21          = 0x80110021,
7419 80d11f44 j_mayer
#define POWERPC_SVR_55xx             POWERPC_SVR_5567
7420 c3e36823 j_mayer
#if 0
7421 80d11f44 j_mayer
    POWERPC_SVR_5533               = xxx,
7422 c3e36823 j_mayer
#endif
7423 c3e36823 j_mayer
#if 0
7424 80d11f44 j_mayer
    POWERPC_SVR_5534               = xxx,
7425 c3e36823 j_mayer
#endif
7426 c3e36823 j_mayer
#if 0
7427 80d11f44 j_mayer
    POWERPC_SVR_5553               = xxx,
7428 c3e36823 j_mayer
#endif
7429 c3e36823 j_mayer
#if 0
7430 80d11f44 j_mayer
    POWERPC_SVR_5554               = xxx,
7431 c3e36823 j_mayer
#endif
7432 c3e36823 j_mayer
#if 0
7433 80d11f44 j_mayer
    POWERPC_SVR_5561               = xxx,
7434 c3e36823 j_mayer
#endif
7435 c3e36823 j_mayer
#if 0
7436 80d11f44 j_mayer
    POWERPC_SVR_5565               = xxx,
7437 c3e36823 j_mayer
#endif
7438 c3e36823 j_mayer
#if 0
7439 80d11f44 j_mayer
    POWERPC_SVR_5566               = xxx,
7440 c3e36823 j_mayer
#endif
7441 c3e36823 j_mayer
#if 0
7442 80d11f44 j_mayer
    POWERPC_SVR_5567               = xxx,
7443 c3e36823 j_mayer
#endif
7444 c3e36823 j_mayer
#if 0
7445 80d11f44 j_mayer
    POWERPC_SVR_8313               = xxx,
7446 c3e36823 j_mayer
#endif
7447 c3e36823 j_mayer
#if 0
7448 80d11f44 j_mayer
    POWERPC_SVR_8313E              = xxx,
7449 c3e36823 j_mayer
#endif
7450 c3e36823 j_mayer
#if 0
7451 80d11f44 j_mayer
    POWERPC_SVR_8314               = xxx,
7452 c3e36823 j_mayer
#endif
7453 c3e36823 j_mayer
#if 0
7454 80d11f44 j_mayer
    POWERPC_SVR_8314E              = xxx,
7455 c3e36823 j_mayer
#endif
7456 c3e36823 j_mayer
#if 0
7457 80d11f44 j_mayer
    POWERPC_SVR_8315               = xxx,
7458 c3e36823 j_mayer
#endif
7459 c3e36823 j_mayer
#if 0
7460 80d11f44 j_mayer
    POWERPC_SVR_8315E              = xxx,
7461 c3e36823 j_mayer
#endif
7462 c3e36823 j_mayer
#if 0
7463 80d11f44 j_mayer
    POWERPC_SVR_8321               = xxx,
7464 c3e36823 j_mayer
#endif
7465 c3e36823 j_mayer
#if 0
7466 80d11f44 j_mayer
    POWERPC_SVR_8321E              = xxx,
7467 c3e36823 j_mayer
#endif
7468 c3e36823 j_mayer
#if 0
7469 80d11f44 j_mayer
    POWERPC_SVR_8323               = xxx,
7470 c3e36823 j_mayer
#endif
7471 c3e36823 j_mayer
#if 0
7472 80d11f44 j_mayer
    POWERPC_SVR_8323E              = xxx,
7473 80d11f44 j_mayer
#endif
7474 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8343               = 0x80570010,
7475 80d11f44 j_mayer
    POWERPC_SVR_8343A              = 0x80570030,
7476 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8343E              = 0x80560010,
7477 80d11f44 j_mayer
    POWERPC_SVR_8343EA             = 0x80560030,
7478 492d7bf5 Thomas Monjalon
#define POWERPC_SVR_8347             POWERPC_SVR_8347T
7479 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347P              = 0x80550010, /* PBGA package */
7480 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347T              = 0x80530010, /* TBGA package */
7481 80d11f44 j_mayer
#define POWERPC_SVR_8347A            POWERPC_SVR_8347AT
7482 80d11f44 j_mayer
    POWERPC_SVR_8347AP             = 0x80550030, /* PBGA package */
7483 80d11f44 j_mayer
    POWERPC_SVR_8347AT             = 0x80530030, /* TBGA package */
7484 492d7bf5 Thomas Monjalon
#define POWERPC_SVR_8347E            POWERPC_SVR_8347ET
7485 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347EP             = 0x80540010, /* PBGA package */
7486 492d7bf5 Thomas Monjalon
    POWERPC_SVR_8347ET             = 0x80520010, /* TBGA package */
7487 80d11f44 j_mayer
#define POWERPC_SVR_8347EA            POWERPC_SVR_8347EAT
7488 80d11f44 j_mayer
    POWERPC_SVR_8347EAP            = 0x80540030, /* PBGA package */
7489 80d11f44 j_mayer
    POWERPC_SVR_8347EAT            = 0x80520030, /* TBGA package */
7490 80d11f44 j_mayer
    POWERPC_SVR_8349               = 0x80510010,
7491 80d11f44 j_mayer
    POWERPC_SVR_8349A              = 0x80510030,
7492 80d11f44 j_mayer
    POWERPC_SVR_8349E              = 0x80500010,
7493 80d11f44 j_mayer
    POWERPC_SVR_8349EA             = 0x80500030,
7494 c3e36823 j_mayer
#if 0
7495 80d11f44 j_mayer
    POWERPC_SVR_8358E              = xxx,
7496 c3e36823 j_mayer
#endif
7497 c3e36823 j_mayer
#if 0
7498 80d11f44 j_mayer
    POWERPC_SVR_8360E              = xxx,
7499 80d11f44 j_mayer
#endif
7500 80d11f44 j_mayer
#define POWERPC_SVR_E500             0x40000000
7501 80d11f44 j_mayer
    POWERPC_SVR_8377               = 0x80C70010 | POWERPC_SVR_E500,
7502 80d11f44 j_mayer
    POWERPC_SVR_8377E              = 0x80C60010 | POWERPC_SVR_E500,
7503 80d11f44 j_mayer
    POWERPC_SVR_8378               = 0x80C50010 | POWERPC_SVR_E500,
7504 80d11f44 j_mayer
    POWERPC_SVR_8378E              = 0x80C40010 | POWERPC_SVR_E500,
7505 80d11f44 j_mayer
    POWERPC_SVR_8379               = 0x80C30010 | POWERPC_SVR_E500,
7506 80d11f44 j_mayer
    POWERPC_SVR_8379E              = 0x80C00010 | POWERPC_SVR_E500,
7507 80d11f44 j_mayer
#define POWERPC_SVR_8533             POWERPC_SVR_8533_v11
7508 80d11f44 j_mayer
    POWERPC_SVR_8533_v10           = 0x80340010 | POWERPC_SVR_E500,
7509 80d11f44 j_mayer
    POWERPC_SVR_8533_v11           = 0x80340011 | POWERPC_SVR_E500,
7510 80d11f44 j_mayer
#define POWERPC_SVR_8533E            POWERPC_SVR_8533E_v11
7511 80d11f44 j_mayer
    POWERPC_SVR_8533E_v10          = 0x803C0010 | POWERPC_SVR_E500,
7512 80d11f44 j_mayer
    POWERPC_SVR_8533E_v11          = 0x803C0011 | POWERPC_SVR_E500,
7513 80d11f44 j_mayer
#define POWERPC_SVR_8540             POWERPC_SVR_8540_v21
7514 80d11f44 j_mayer
    POWERPC_SVR_8540_v10           = 0x80300010 | POWERPC_SVR_E500,
7515 80d11f44 j_mayer
    POWERPC_SVR_8540_v20           = 0x80300020 | POWERPC_SVR_E500,
7516 80d11f44 j_mayer
    POWERPC_SVR_8540_v21           = 0x80300021 | POWERPC_SVR_E500,
7517 80d11f44 j_mayer
#define POWERPC_SVR_8541             POWERPC_SVR_8541_v11
7518 80d11f44 j_mayer
    POWERPC_SVR_8541_v10           = 0x80720010 | POWERPC_SVR_E500,
7519 80d11f44 j_mayer
    POWERPC_SVR_8541_v11           = 0x80720011 | POWERPC_SVR_E500,
7520 80d11f44 j_mayer
#define POWERPC_SVR_8541E            POWERPC_SVR_8541E_v11
7521 80d11f44 j_mayer
    POWERPC_SVR_8541E_v10          = 0x807A0010 | POWERPC_SVR_E500,
7522 80d11f44 j_mayer
    POWERPC_SVR_8541E_v11          = 0x807A0011 | POWERPC_SVR_E500,
7523 80d11f44 j_mayer
#define POWERPC_SVR_8543             POWERPC_SVR_8543_v21
7524 80d11f44 j_mayer
    POWERPC_SVR_8543_v10           = 0x80320010 | POWERPC_SVR_E500,
7525 80d11f44 j_mayer
    POWERPC_SVR_8543_v11           = 0x80320011 | POWERPC_SVR_E500,
7526 80d11f44 j_mayer
    POWERPC_SVR_8543_v20           = 0x80320020 | POWERPC_SVR_E500,
7527 80d11f44 j_mayer
    POWERPC_SVR_8543_v21           = 0x80320021 | POWERPC_SVR_E500,
7528 80d11f44 j_mayer
#define POWERPC_SVR_8543E            POWERPC_SVR_8543E_v21
7529 80d11f44 j_mayer
    POWERPC_SVR_8543E_v10          = 0x803A0010 | POWERPC_SVR_E500,
7530 80d11f44 j_mayer
    POWERPC_SVR_8543E_v11          = 0x803A0011 | POWERPC_SVR_E500,
7531 80d11f44 j_mayer
    POWERPC_SVR_8543E_v20          = 0x803A0020 | POWERPC_SVR_E500,
7532 80d11f44 j_mayer
    POWERPC_SVR_8543E_v21          = 0x803A0021 | POWERPC_SVR_E500,
7533 80d11f44 j_mayer
#define POWERPC_SVR_8544             POWERPC_SVR_8544_v11
7534 80d11f44 j_mayer
    POWERPC_SVR_8544_v10           = 0x80340110 | POWERPC_SVR_E500,
7535 80d11f44 j_mayer
    POWERPC_SVR_8544_v11           = 0x80340111 | POWERPC_SVR_E500,
7536 80d11f44 j_mayer
#define POWERPC_SVR_8544E            POWERPC_SVR_8544E_v11
7537 80d11f44 j_mayer
    POWERPC_SVR_8544E_v10          = 0x803C0110 | POWERPC_SVR_E500,
7538 80d11f44 j_mayer
    POWERPC_SVR_8544E_v11          = 0x803C0111 | POWERPC_SVR_E500,
7539 80d11f44 j_mayer
#define POWERPC_SVR_8545             POWERPC_SVR_8545_v21
7540 80d11f44 j_mayer
    POWERPC_SVR_8545_v20           = 0x80310220 | POWERPC_SVR_E500,
7541 80d11f44 j_mayer
    POWERPC_SVR_8545_v21           = 0x80310221 | POWERPC_SVR_E500,
7542 80d11f44 j_mayer
#define POWERPC_SVR_8545E            POWERPC_SVR_8545E_v21
7543 80d11f44 j_mayer
    POWERPC_SVR_8545E_v20          = 0x80390220 | POWERPC_SVR_E500,
7544 80d11f44 j_mayer
    POWERPC_SVR_8545E_v21          = 0x80390221 | POWERPC_SVR_E500,
7545 80d11f44 j_mayer
#define POWERPC_SVR_8547E            POWERPC_SVR_8547E_v21
7546 80d11f44 j_mayer
    POWERPC_SVR_8547E_v20          = 0x80390120 | POWERPC_SVR_E500,
7547 80d11f44 j_mayer
    POWERPC_SVR_8547E_v21          = 0x80390121 | POWERPC_SVR_E500,
7548 80d11f44 j_mayer
#define POWERPC_SVR_8548             POWERPC_SVR_8548_v21
7549 80d11f44 j_mayer
    POWERPC_SVR_8548_v10           = 0x80310010 | POWERPC_SVR_E500,
7550 80d11f44 j_mayer
    POWERPC_SVR_8548_v11           = 0x80310011 | POWERPC_SVR_E500,
7551 80d11f44 j_mayer
    POWERPC_SVR_8548_v20           = 0x80310020 | POWERPC_SVR_E500,
7552 80d11f44 j_mayer
    POWERPC_SVR_8548_v21           = 0x80310021 | POWERPC_SVR_E500,
7553 80d11f44 j_mayer
#define POWERPC_SVR_8548E            POWERPC_SVR_8548E_v21
7554 80d11f44 j_mayer
    POWERPC_SVR_8548E_v10          = 0x80390010 | POWERPC_SVR_E500,
7555 80d11f44 j_mayer
    POWERPC_SVR_8548E_v11          = 0x80390011 | POWERPC_SVR_E500,
7556 80d11f44 j_mayer
    POWERPC_SVR_8548E_v20          = 0x80390020 | POWERPC_SVR_E500,
7557 80d11f44 j_mayer
    POWERPC_SVR_8548E_v21          = 0x80390021 | POWERPC_SVR_E500,
7558 80d11f44 j_mayer
#define POWERPC_SVR_8555             POWERPC_SVR_8555_v11
7559 80d11f44 j_mayer
    POWERPC_SVR_8555_v10           = 0x80710010 | POWERPC_SVR_E500,
7560 80d11f44 j_mayer
    POWERPC_SVR_8555_v11           = 0x80710011 | POWERPC_SVR_E500,
7561 80d11f44 j_mayer
#define POWERPC_SVR_8555E            POWERPC_SVR_8555_v11
7562 80d11f44 j_mayer
    POWERPC_SVR_8555E_v10          = 0x80790010 | POWERPC_SVR_E500,
7563 80d11f44 j_mayer
    POWERPC_SVR_8555E_v11          = 0x80790011 | POWERPC_SVR_E500,
7564 80d11f44 j_mayer
#define POWERPC_SVR_8560             POWERPC_SVR_8560_v21
7565 80d11f44 j_mayer
    POWERPC_SVR_8560_v10           = 0x80700010 | POWERPC_SVR_E500,
7566 80d11f44 j_mayer
    POWERPC_SVR_8560_v20           = 0x80700020 | POWERPC_SVR_E500,
7567 80d11f44 j_mayer
    POWERPC_SVR_8560_v21           = 0x80700021 | POWERPC_SVR_E500,
7568 80d11f44 j_mayer
    POWERPC_SVR_8567               = 0x80750111 | POWERPC_SVR_E500,
7569 80d11f44 j_mayer
    POWERPC_SVR_8567E              = 0x807D0111 | POWERPC_SVR_E500,
7570 80d11f44 j_mayer
    POWERPC_SVR_8568               = 0x80750011 | POWERPC_SVR_E500,
7571 80d11f44 j_mayer
    POWERPC_SVR_8568E              = 0x807D0011 | POWERPC_SVR_E500,
7572 80d11f44 j_mayer
    POWERPC_SVR_8572               = 0x80E00010 | POWERPC_SVR_E500,
7573 80d11f44 j_mayer
    POWERPC_SVR_8572E              = 0x80E80010 | POWERPC_SVR_E500,
7574 c3e36823 j_mayer
#if 0
7575 80d11f44 j_mayer
    POWERPC_SVR_8610               = xxx,
7576 c3e36823 j_mayer
#endif
7577 80d11f44 j_mayer
    POWERPC_SVR_8641               = 0x80900021,
7578 80d11f44 j_mayer
    POWERPC_SVR_8641D              = 0x80900121,
7579 a750fc0b j_mayer
};
7580 a750fc0b j_mayer
7581 3fc6c082 bellard
/*****************************************************************************/
7582 a750fc0b j_mayer
/* PowerPC CPU definitions                                                   */
7583 80d11f44 j_mayer
#define POWERPC_DEF_SVR(_name, _pvr, _svr, _type)                             \
7584 a750fc0b j_mayer
    {                                                                         \
7585 a5858d7a Alexander Graf
        .name         = _name,                                                \
7586 a5858d7a Alexander Graf
        .pvr          = _pvr,                                                 \
7587 a5858d7a Alexander Graf
        .svr          = _svr,                                                 \
7588 a5858d7a Alexander Graf
        .insns_flags  = glue(POWERPC_INSNS_,_type),                           \
7589 a5858d7a Alexander Graf
        .insns_flags2 = glue(POWERPC_INSNS2_,_type),                          \
7590 a5858d7a Alexander Graf
        .msr_mask     = glue(POWERPC_MSRM_,_type),                            \
7591 a5858d7a Alexander Graf
        .mmu_model    = glue(POWERPC_MMU_,_type),                             \
7592 a5858d7a Alexander Graf
        .excp_model   = glue(POWERPC_EXCP_,_type),                            \
7593 a5858d7a Alexander Graf
        .bus_model    = glue(POWERPC_INPUT_,_type),                           \
7594 a5858d7a Alexander Graf
        .bfd_mach     = glue(POWERPC_BFDM_,_type),                            \
7595 a5858d7a Alexander Graf
        .flags        = glue(POWERPC_FLAG_,_type),                            \
7596 a5858d7a Alexander Graf
        .init_proc    = &glue(init_proc_,_type),                              \
7597 a5858d7a Alexander Graf
        .check_pow    = &glue(check_pow_,_type),                              \
7598 a750fc0b j_mayer
    }
7599 80d11f44 j_mayer
#define POWERPC_DEF(_name, _pvr, _type)                                       \
7600 80d11f44 j_mayer
POWERPC_DEF_SVR(_name, _pvr, POWERPC_SVR_NONE, _type)
7601 a750fc0b j_mayer
7602 c227f099 Anthony Liguori
static const ppc_def_t ppc_defs[] = {
7603 a750fc0b j_mayer
    /* Embedded PowerPC                                                      */
7604 a750fc0b j_mayer
    /* PowerPC 401 family                                                    */
7605 2662a059 j_mayer
    /* Generic PowerPC 401 */
7606 80d11f44 j_mayer
    POWERPC_DEF("401",           CPU_POWERPC_401,                    401),
7607 a750fc0b j_mayer
    /* PowerPC 401 cores                                                     */
7608 2662a059 j_mayer
    /* PowerPC 401A1 */
7609 80d11f44 j_mayer
    POWERPC_DEF("401A1",         CPU_POWERPC_401A1,                  401),
7610 a750fc0b j_mayer
    /* PowerPC 401B2                                                         */
7611 80d11f44 j_mayer
    POWERPC_DEF("401B2",         CPU_POWERPC_401B2,                  401x2),
7612 2662a059 j_mayer
#if defined (TODO)
7613 a750fc0b j_mayer
    /* PowerPC 401B3                                                         */
7614 80d11f44 j_mayer
    POWERPC_DEF("401B3",         CPU_POWERPC_401B3,                  401x3),
7615 a750fc0b j_mayer
#endif
7616 a750fc0b j_mayer
    /* PowerPC 401C2                                                         */
7617 80d11f44 j_mayer
    POWERPC_DEF("401C2",         CPU_POWERPC_401C2,                  401x2),
7618 a750fc0b j_mayer
    /* PowerPC 401D2                                                         */
7619 80d11f44 j_mayer
    POWERPC_DEF("401D2",         CPU_POWERPC_401D2,                  401x2),
7620 a750fc0b j_mayer
    /* PowerPC 401E2                                                         */
7621 80d11f44 j_mayer
    POWERPC_DEF("401E2",         CPU_POWERPC_401E2,                  401x2),
7622 a750fc0b j_mayer
    /* PowerPC 401F2                                                         */
7623 80d11f44 j_mayer
    POWERPC_DEF("401F2",         CPU_POWERPC_401F2,                  401x2),
7624 a750fc0b j_mayer
    /* PowerPC 401G2                                                         */
7625 a750fc0b j_mayer
    /* XXX: to be checked */
7626 80d11f44 j_mayer
    POWERPC_DEF("401G2",         CPU_POWERPC_401G2,                  401x2),
7627 a750fc0b j_mayer
    /* PowerPC 401 microcontrolers                                           */
7628 2662a059 j_mayer
#if defined (TODO)
7629 a750fc0b j_mayer
    /* PowerPC 401GF                                                         */
7630 80d11f44 j_mayer
    POWERPC_DEF("401GF",         CPU_POWERPC_401GF,                  401),
7631 3fc6c082 bellard
#endif
7632 a750fc0b j_mayer
    /* IOP480 (401 microcontroler)                                           */
7633 80d11f44 j_mayer
    POWERPC_DEF("IOP480",        CPU_POWERPC_IOP480,                 IOP480),
7634 a750fc0b j_mayer
    /* IBM Processor for Network Resources                                   */
7635 80d11f44 j_mayer
    POWERPC_DEF("Cobra",         CPU_POWERPC_COBRA,                  401),
7636 3fc6c082 bellard
#if defined (TODO)
7637 80d11f44 j_mayer
    POWERPC_DEF("Xipchip",       CPU_POWERPC_XIPCHIP,                401),
7638 3fc6c082 bellard
#endif
7639 a750fc0b j_mayer
    /* PowerPC 403 family                                                    */
7640 a750fc0b j_mayer
    /* Generic PowerPC 403                                                   */
7641 80d11f44 j_mayer
    POWERPC_DEF("403",           CPU_POWERPC_403,                    403),
7642 a750fc0b j_mayer
    /* PowerPC 403 microcontrolers                                           */
7643 a750fc0b j_mayer
    /* PowerPC 403 GA                                                        */
7644 80d11f44 j_mayer
    POWERPC_DEF("403GA",         CPU_POWERPC_403GA,                  403),
7645 a750fc0b j_mayer
    /* PowerPC 403 GB                                                        */
7646 80d11f44 j_mayer
    POWERPC_DEF("403GB",         CPU_POWERPC_403GB,                  403),
7647 a750fc0b j_mayer
    /* PowerPC 403 GC                                                        */
7648 80d11f44 j_mayer
    POWERPC_DEF("403GC",         CPU_POWERPC_403GC,                  403),
7649 a750fc0b j_mayer
    /* PowerPC 403 GCX                                                       */
7650 80d11f44 j_mayer
    POWERPC_DEF("403GCX",        CPU_POWERPC_403GCX,                 403GCX),
7651 3fc6c082 bellard
#if defined (TODO)
7652 a750fc0b j_mayer
    /* PowerPC 403 GP                                                        */
7653 80d11f44 j_mayer
    POWERPC_DEF("403GP",         CPU_POWERPC_403GP,                  403),
7654 3fc6c082 bellard
#endif
7655 a750fc0b j_mayer
    /* PowerPC 405 family                                                    */
7656 a750fc0b j_mayer
    /* Generic PowerPC 405                                                   */
7657 80d11f44 j_mayer
    POWERPC_DEF("405",           CPU_POWERPC_405,                    405),
7658 a750fc0b j_mayer
    /* PowerPC 405 cores                                                     */
7659 2662a059 j_mayer
#if defined (TODO)
7660 a750fc0b j_mayer
    /* PowerPC 405 A3                                                        */
7661 80d11f44 j_mayer
    POWERPC_DEF("405A3",         CPU_POWERPC_405A3,                  405),
7662 3a607854 j_mayer
#endif
7663 3a607854 j_mayer
#if defined (TODO)
7664 a750fc0b j_mayer
    /* PowerPC 405 A4                                                        */
7665 80d11f44 j_mayer
    POWERPC_DEF("405A4",         CPU_POWERPC_405A4,                  405),
7666 3a607854 j_mayer
#endif
7667 3a607854 j_mayer
#if defined (TODO)
7668 a750fc0b j_mayer
    /* PowerPC 405 B3                                                        */
7669 80d11f44 j_mayer
    POWERPC_DEF("405B3",         CPU_POWERPC_405B3,                  405),
7670 3fc6c082 bellard
#endif
7671 3fc6c082 bellard
#if defined (TODO)
7672 a750fc0b j_mayer
    /* PowerPC 405 B4                                                        */
7673 80d11f44 j_mayer
    POWERPC_DEF("405B4",         CPU_POWERPC_405B4,                  405),
7674 a750fc0b j_mayer
#endif
7675 a750fc0b j_mayer
#if defined (TODO)
7676 a750fc0b j_mayer
    /* PowerPC 405 C3                                                        */
7677 80d11f44 j_mayer
    POWERPC_DEF("405C3",         CPU_POWERPC_405C3,                  405),
7678 a750fc0b j_mayer
#endif
7679 a750fc0b j_mayer
#if defined (TODO)
7680 a750fc0b j_mayer
    /* PowerPC 405 C4                                                        */
7681 80d11f44 j_mayer
    POWERPC_DEF("405C4",         CPU_POWERPC_405C4,                  405),
7682 a750fc0b j_mayer
#endif
7683 a750fc0b j_mayer
    /* PowerPC 405 D2                                                        */
7684 80d11f44 j_mayer
    POWERPC_DEF("405D2",         CPU_POWERPC_405D2,                  405),
7685 a750fc0b j_mayer
#if defined (TODO)
7686 a750fc0b j_mayer
    /* PowerPC 405 D3                                                        */
7687 80d11f44 j_mayer
    POWERPC_DEF("405D3",         CPU_POWERPC_405D3,                  405),
7688 a750fc0b j_mayer
#endif
7689 a750fc0b j_mayer
    /* PowerPC 405 D4                                                        */
7690 80d11f44 j_mayer
    POWERPC_DEF("405D4",         CPU_POWERPC_405D4,                  405),
7691 a750fc0b j_mayer
#if defined (TODO)
7692 a750fc0b j_mayer
    /* PowerPC 405 D5                                                        */
7693 80d11f44 j_mayer
    POWERPC_DEF("405D5",         CPU_POWERPC_405D5,                  405),
7694 a750fc0b j_mayer
#endif
7695 a750fc0b j_mayer
#if defined (TODO)
7696 a750fc0b j_mayer
    /* PowerPC 405 E4                                                        */
7697 80d11f44 j_mayer
    POWERPC_DEF("405E4",         CPU_POWERPC_405E4,                  405),
7698 a750fc0b j_mayer
#endif
7699 a750fc0b j_mayer
#if defined (TODO)
7700 a750fc0b j_mayer
    /* PowerPC 405 F4                                                        */
7701 80d11f44 j_mayer
    POWERPC_DEF("405F4",         CPU_POWERPC_405F4,                  405),
7702 a750fc0b j_mayer
#endif
7703 a750fc0b j_mayer
#if defined (TODO)
7704 a750fc0b j_mayer
    /* PowerPC 405 F5                                                        */
7705 80d11f44 j_mayer
    POWERPC_DEF("405F5",         CPU_POWERPC_405F5,                  405),
7706 a750fc0b j_mayer
#endif
7707 a750fc0b j_mayer
#if defined (TODO)
7708 a750fc0b j_mayer
    /* PowerPC 405 F6                                                        */
7709 80d11f44 j_mayer
    POWERPC_DEF("405F6",         CPU_POWERPC_405F6,                  405),
7710 a750fc0b j_mayer
#endif
7711 a750fc0b j_mayer
    /* PowerPC 405 microcontrolers                                           */
7712 a750fc0b j_mayer
    /* PowerPC 405 CR                                                        */
7713 80d11f44 j_mayer
    POWERPC_DEF("405CR",         CPU_POWERPC_405CR,                  405),
7714 a750fc0b j_mayer
    /* PowerPC 405 CRa                                                       */
7715 80d11f44 j_mayer
    POWERPC_DEF("405CRa",        CPU_POWERPC_405CRa,                 405),
7716 a750fc0b j_mayer
    /* PowerPC 405 CRb                                                       */
7717 80d11f44 j_mayer
    POWERPC_DEF("405CRb",        CPU_POWERPC_405CRb,                 405),
7718 a750fc0b j_mayer
    /* PowerPC 405 CRc                                                       */
7719 80d11f44 j_mayer
    POWERPC_DEF("405CRc",        CPU_POWERPC_405CRc,                 405),
7720 a750fc0b j_mayer
    /* PowerPC 405 EP                                                        */
7721 80d11f44 j_mayer
    POWERPC_DEF("405EP",         CPU_POWERPC_405EP,                  405),
7722 a750fc0b j_mayer
#if defined(TODO)
7723 a750fc0b j_mayer
    /* PowerPC 405 EXr                                                       */
7724 80d11f44 j_mayer
    POWERPC_DEF("405EXr",        CPU_POWERPC_405EXr,                 405),
7725 a750fc0b j_mayer
#endif
7726 a750fc0b j_mayer
    /* PowerPC 405 EZ                                                        */
7727 80d11f44 j_mayer
    POWERPC_DEF("405EZ",         CPU_POWERPC_405EZ,                  405),
7728 a750fc0b j_mayer
#if defined(TODO)
7729 a750fc0b j_mayer
    /* PowerPC 405 FX                                                        */
7730 80d11f44 j_mayer
    POWERPC_DEF("405FX",         CPU_POWERPC_405FX,                  405),
7731 a750fc0b j_mayer
#endif
7732 a750fc0b j_mayer
    /* PowerPC 405 GP                                                        */
7733 80d11f44 j_mayer
    POWERPC_DEF("405GP",         CPU_POWERPC_405GP,                  405),
7734 a750fc0b j_mayer
    /* PowerPC 405 GPa                                                       */
7735 80d11f44 j_mayer
    POWERPC_DEF("405GPa",        CPU_POWERPC_405GPa,                 405),
7736 a750fc0b j_mayer
    /* PowerPC 405 GPb                                                       */
7737 80d11f44 j_mayer
    POWERPC_DEF("405GPb",        CPU_POWERPC_405GPb,                 405),
7738 a750fc0b j_mayer
    /* PowerPC 405 GPc                                                       */
7739 80d11f44 j_mayer
    POWERPC_DEF("405GPc",        CPU_POWERPC_405GPc,                 405),
7740 a750fc0b j_mayer
    /* PowerPC 405 GPd                                                       */
7741 80d11f44 j_mayer
    POWERPC_DEF("405GPd",        CPU_POWERPC_405GPd,                 405),
7742 a750fc0b j_mayer
    /* PowerPC 405 GPe                                                       */
7743 80d11f44 j_mayer
    POWERPC_DEF("405GPe",        CPU_POWERPC_405GPe,                 405),
7744 a750fc0b j_mayer
    /* PowerPC 405 GPR                                                       */
7745 80d11f44 j_mayer
    POWERPC_DEF("405GPR",        CPU_POWERPC_405GPR,                 405),
7746 a750fc0b j_mayer
#if defined(TODO)
7747 a750fc0b j_mayer
    /* PowerPC 405 H                                                         */
7748 80d11f44 j_mayer
    POWERPC_DEF("405H",          CPU_POWERPC_405H,                   405),
7749 a750fc0b j_mayer
#endif
7750 a750fc0b j_mayer
#if defined(TODO)
7751 a750fc0b j_mayer
    /* PowerPC 405 L                                                         */
7752 80d11f44 j_mayer
    POWERPC_DEF("405L",          CPU_POWERPC_405L,                   405),
7753 a750fc0b j_mayer
#endif
7754 a750fc0b j_mayer
    /* PowerPC 405 LP                                                        */
7755 80d11f44 j_mayer
    POWERPC_DEF("405LP",         CPU_POWERPC_405LP,                  405),
7756 a750fc0b j_mayer
#if defined(TODO)
7757 a750fc0b j_mayer
    /* PowerPC 405 PM                                                        */
7758 80d11f44 j_mayer
    POWERPC_DEF("405PM",         CPU_POWERPC_405PM,                  405),
7759 a750fc0b j_mayer
#endif
7760 a750fc0b j_mayer
#if defined(TODO)
7761 a750fc0b j_mayer
    /* PowerPC 405 PS                                                        */
7762 80d11f44 j_mayer
    POWERPC_DEF("405PS",         CPU_POWERPC_405PS,                  405),
7763 a750fc0b j_mayer
#endif
7764 a750fc0b j_mayer
#if defined(TODO)
7765 a750fc0b j_mayer
    /* PowerPC 405 S                                                         */
7766 80d11f44 j_mayer
    POWERPC_DEF("405S",          CPU_POWERPC_405S,                   405),
7767 a750fc0b j_mayer
#endif
7768 a750fc0b j_mayer
    /* Npe405 H                                                              */
7769 80d11f44 j_mayer
    POWERPC_DEF("Npe405H",       CPU_POWERPC_NPE405H,                405),
7770 a750fc0b j_mayer
    /* Npe405 H2                                                             */
7771 80d11f44 j_mayer
    POWERPC_DEF("Npe405H2",      CPU_POWERPC_NPE405H2,               405),
7772 a750fc0b j_mayer
    /* Npe405 L                                                              */
7773 80d11f44 j_mayer
    POWERPC_DEF("Npe405L",       CPU_POWERPC_NPE405L,                405),
7774 a750fc0b j_mayer
    /* Npe4GS3                                                               */
7775 80d11f44 j_mayer
    POWERPC_DEF("Npe4GS3",       CPU_POWERPC_NPE4GS3,                405),
7776 a750fc0b j_mayer
#if defined (TODO)
7777 80d11f44 j_mayer
    POWERPC_DEF("Npcxx1",        CPU_POWERPC_NPCxx1,                 405),
7778 a750fc0b j_mayer
#endif
7779 a750fc0b j_mayer
#if defined (TODO)
7780 80d11f44 j_mayer
    POWERPC_DEF("Npr161",        CPU_POWERPC_NPR161,                 405),
7781 a750fc0b j_mayer
#endif
7782 a750fc0b j_mayer
#if defined (TODO)
7783 a750fc0b j_mayer
    /* PowerPC LC77700 (Sanyo)                                               */
7784 80d11f44 j_mayer
    POWERPC_DEF("LC77700",       CPU_POWERPC_LC77700,                405),
7785 a750fc0b j_mayer
#endif
7786 a750fc0b j_mayer
    /* PowerPC 401/403/405 based set-top-box microcontrolers                 */
7787 a750fc0b j_mayer
#if defined (TODO)
7788 a750fc0b j_mayer
    /* STB010000                                                             */
7789 80d11f44 j_mayer
    POWERPC_DEF("STB01000",      CPU_POWERPC_STB01000,               401x2),
7790 a750fc0b j_mayer
#endif
7791 a750fc0b j_mayer
#if defined (TODO)
7792 a750fc0b j_mayer
    /* STB01010                                                              */
7793 80d11f44 j_mayer
    POWERPC_DEF("STB01010",      CPU_POWERPC_STB01010,               401x2),
7794 a750fc0b j_mayer
#endif
7795 a750fc0b j_mayer
#if defined (TODO)
7796 a750fc0b j_mayer
    /* STB0210                                                               */
7797 80d11f44 j_mayer
    POWERPC_DEF("STB0210",       CPU_POWERPC_STB0210,                401x3),
7798 a750fc0b j_mayer
#endif
7799 a750fc0b j_mayer
    /* STB03xx                                                               */
7800 80d11f44 j_mayer
    POWERPC_DEF("STB03",         CPU_POWERPC_STB03,                  405),
7801 a750fc0b j_mayer
#if defined (TODO)
7802 a750fc0b j_mayer
    /* STB043x                                                               */
7803 80d11f44 j_mayer
    POWERPC_DEF("STB043",        CPU_POWERPC_STB043,                 405),
7804 a750fc0b j_mayer
#endif
7805 a750fc0b j_mayer
#if defined (TODO)
7806 a750fc0b j_mayer
    /* STB045x                                                               */
7807 80d11f44 j_mayer
    POWERPC_DEF("STB045",        CPU_POWERPC_STB045,                 405),
7808 a750fc0b j_mayer
#endif
7809 a750fc0b j_mayer
    /* STB04xx                                                               */
7810 80d11f44 j_mayer
    POWERPC_DEF("STB04",         CPU_POWERPC_STB04,                  405),
7811 a750fc0b j_mayer
    /* STB25xx                                                               */
7812 80d11f44 j_mayer
    POWERPC_DEF("STB25",         CPU_POWERPC_STB25,                  405),
7813 a750fc0b j_mayer
#if defined (TODO)
7814 a750fc0b j_mayer
    /* STB130                                                                */
7815 80d11f44 j_mayer
    POWERPC_DEF("STB130",        CPU_POWERPC_STB130,                 405),
7816 a750fc0b j_mayer
#endif
7817 a750fc0b j_mayer
    /* Xilinx PowerPC 405 cores                                              */
7818 80d11f44 j_mayer
    POWERPC_DEF("x2vp4",         CPU_POWERPC_X2VP4,                  405),
7819 80d11f44 j_mayer
    POWERPC_DEF("x2vp7",         CPU_POWERPC_X2VP7,                  405),
7820 80d11f44 j_mayer
    POWERPC_DEF("x2vp20",        CPU_POWERPC_X2VP20,                 405),
7821 80d11f44 j_mayer
    POWERPC_DEF("x2vp50",        CPU_POWERPC_X2VP50,                 405),
7822 a750fc0b j_mayer
#if defined (TODO)
7823 a750fc0b j_mayer
    /* Zarlink ZL10310                                                       */
7824 80d11f44 j_mayer
    POWERPC_DEF("zl10310",       CPU_POWERPC_ZL10310,                405),
7825 a750fc0b j_mayer
#endif
7826 a750fc0b j_mayer
#if defined (TODO)
7827 a750fc0b j_mayer
    /* Zarlink ZL10311                                                       */
7828 80d11f44 j_mayer
    POWERPC_DEF("zl10311",       CPU_POWERPC_ZL10311,                405),
7829 a750fc0b j_mayer
#endif
7830 a750fc0b j_mayer
#if defined (TODO)
7831 a750fc0b j_mayer
    /* Zarlink ZL10320                                                       */
7832 80d11f44 j_mayer
    POWERPC_DEF("zl10320",       CPU_POWERPC_ZL10320,                405),
7833 a750fc0b j_mayer
#endif
7834 a750fc0b j_mayer
#if defined (TODO)
7835 a750fc0b j_mayer
    /* Zarlink ZL10321                                                       */
7836 80d11f44 j_mayer
    POWERPC_DEF("zl10321",       CPU_POWERPC_ZL10321,                405),
7837 a750fc0b j_mayer
#endif
7838 a750fc0b j_mayer
    /* PowerPC 440 family                                                    */
7839 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7840 a750fc0b j_mayer
    /* Generic PowerPC 440                                                   */
7841 80d11f44 j_mayer
    POWERPC_DEF("440",           CPU_POWERPC_440,                    440GP),
7842 80d11f44 j_mayer
#endif
7843 a750fc0b j_mayer
    /* PowerPC 440 cores                                                     */
7844 a750fc0b j_mayer
#if defined (TODO)
7845 a750fc0b j_mayer
    /* PowerPC 440 A4                                                        */
7846 80d11f44 j_mayer
    POWERPC_DEF("440A4",         CPU_POWERPC_440A4,                  440x4),
7847 a750fc0b j_mayer
#endif
7848 95070372 Edgar E. Iglesias
    /* PowerPC 440 Xilinx 5                                                  */
7849 95070372 Edgar E. Iglesias
    POWERPC_DEF("440-Xilinx",    CPU_POWERPC_440_XILINX,             440x5),
7850 a750fc0b j_mayer
#if defined (TODO)
7851 a750fc0b j_mayer
    /* PowerPC 440 A5                                                        */
7852 80d11f44 j_mayer
    POWERPC_DEF("440A5",         CPU_POWERPC_440A5,                  440x5),
7853 a750fc0b j_mayer
#endif
7854 a750fc0b j_mayer
#if defined (TODO)
7855 a750fc0b j_mayer
    /* PowerPC 440 B4                                                        */
7856 80d11f44 j_mayer
    POWERPC_DEF("440B4",         CPU_POWERPC_440B4,                  440x4),
7857 a750fc0b j_mayer
#endif
7858 a750fc0b j_mayer
#if defined (TODO)
7859 a750fc0b j_mayer
    /* PowerPC 440 G4                                                        */
7860 80d11f44 j_mayer
    POWERPC_DEF("440G4",         CPU_POWERPC_440G4,                  440x4),
7861 a750fc0b j_mayer
#endif
7862 a750fc0b j_mayer
#if defined (TODO)
7863 a750fc0b j_mayer
    /* PowerPC 440 F5                                                        */
7864 80d11f44 j_mayer
    POWERPC_DEF("440F5",         CPU_POWERPC_440F5,                  440x5),
7865 a750fc0b j_mayer
#endif
7866 a750fc0b j_mayer
#if defined (TODO)
7867 a750fc0b j_mayer
    /* PowerPC 440 G5                                                        */
7868 80d11f44 j_mayer
    POWERPC_DEF("440G5",         CPU_POWERPC_440G5,                  440x5),
7869 a750fc0b j_mayer
#endif
7870 a750fc0b j_mayer
#if defined (TODO)
7871 a750fc0b j_mayer
    /* PowerPC 440H4                                                         */
7872 80d11f44 j_mayer
    POWERPC_DEF("440H4",         CPU_POWERPC_440H4,                  440x4),
7873 a750fc0b j_mayer
#endif
7874 a750fc0b j_mayer
#if defined (TODO)
7875 a750fc0b j_mayer
    /* PowerPC 440H6                                                         */
7876 80d11f44 j_mayer
    POWERPC_DEF("440H6",         CPU_POWERPC_440H6,                  440Gx5),
7877 a750fc0b j_mayer
#endif
7878 a750fc0b j_mayer
    /* PowerPC 440 microcontrolers                                           */
7879 a750fc0b j_mayer
    /* PowerPC 440 EP                                                        */
7880 80d11f44 j_mayer
    POWERPC_DEF("440EP",         CPU_POWERPC_440EP,                  440EP),
7881 a750fc0b j_mayer
    /* PowerPC 440 EPa                                                       */
7882 80d11f44 j_mayer
    POWERPC_DEF("440EPa",        CPU_POWERPC_440EPa,                 440EP),
7883 a750fc0b j_mayer
    /* PowerPC 440 EPb                                                       */
7884 80d11f44 j_mayer
    POWERPC_DEF("440EPb",        CPU_POWERPC_440EPb,                 440EP),
7885 a750fc0b j_mayer
    /* PowerPC 440 EPX                                                       */
7886 80d11f44 j_mayer
    POWERPC_DEF("440EPX",        CPU_POWERPC_440EPX,                 440EP),
7887 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7888 a750fc0b j_mayer
    /* PowerPC 440 GP                                                        */
7889 80d11f44 j_mayer
    POWERPC_DEF("440GP",         CPU_POWERPC_440GP,                  440GP),
7890 80d11f44 j_mayer
#endif
7891 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7892 a750fc0b j_mayer
    /* PowerPC 440 GPb                                                       */
7893 80d11f44 j_mayer
    POWERPC_DEF("440GPb",        CPU_POWERPC_440GPb,                 440GP),
7894 80d11f44 j_mayer
#endif
7895 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7896 a750fc0b j_mayer
    /* PowerPC 440 GPc                                                       */
7897 80d11f44 j_mayer
    POWERPC_DEF("440GPc",        CPU_POWERPC_440GPc,                 440GP),
7898 80d11f44 j_mayer
#endif
7899 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7900 a750fc0b j_mayer
    /* PowerPC 440 GR                                                        */
7901 80d11f44 j_mayer
    POWERPC_DEF("440GR",         CPU_POWERPC_440GR,                  440x5),
7902 80d11f44 j_mayer
#endif
7903 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7904 a750fc0b j_mayer
    /* PowerPC 440 GRa                                                       */
7905 80d11f44 j_mayer
    POWERPC_DEF("440GRa",        CPU_POWERPC_440GRa,                 440x5),
7906 80d11f44 j_mayer
#endif
7907 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7908 a750fc0b j_mayer
    /* PowerPC 440 GRX                                                       */
7909 80d11f44 j_mayer
    POWERPC_DEF("440GRX",        CPU_POWERPC_440GRX,                 440x5),
7910 80d11f44 j_mayer
#endif
7911 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7912 a750fc0b j_mayer
    /* PowerPC 440 GX                                                        */
7913 80d11f44 j_mayer
    POWERPC_DEF("440GX",         CPU_POWERPC_440GX,                  440EP),
7914 80d11f44 j_mayer
#endif
7915 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7916 a750fc0b j_mayer
    /* PowerPC 440 GXa                                                       */
7917 80d11f44 j_mayer
    POWERPC_DEF("440GXa",        CPU_POWERPC_440GXa,                 440EP),
7918 80d11f44 j_mayer
#endif
7919 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7920 a750fc0b j_mayer
    /* PowerPC 440 GXb                                                       */
7921 80d11f44 j_mayer
    POWERPC_DEF("440GXb",        CPU_POWERPC_440GXb,                 440EP),
7922 80d11f44 j_mayer
#endif
7923 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7924 a750fc0b j_mayer
    /* PowerPC 440 GXc                                                       */
7925 80d11f44 j_mayer
    POWERPC_DEF("440GXc",        CPU_POWERPC_440GXc,                 440EP),
7926 80d11f44 j_mayer
#endif
7927 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7928 a750fc0b j_mayer
    /* PowerPC 440 GXf                                                       */
7929 80d11f44 j_mayer
    POWERPC_DEF("440GXf",        CPU_POWERPC_440GXf,                 440EP),
7930 80d11f44 j_mayer
#endif
7931 a750fc0b j_mayer
#if defined(TODO)
7932 a750fc0b j_mayer
    /* PowerPC 440 S                                                         */
7933 80d11f44 j_mayer
    POWERPC_DEF("440S",          CPU_POWERPC_440S,                   440),
7934 a750fc0b j_mayer
#endif
7935 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7936 a750fc0b j_mayer
    /* PowerPC 440 SP                                                        */
7937 80d11f44 j_mayer
    POWERPC_DEF("440SP",         CPU_POWERPC_440SP,                  440EP),
7938 80d11f44 j_mayer
#endif
7939 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7940 a750fc0b j_mayer
    /* PowerPC 440 SP2                                                       */
7941 80d11f44 j_mayer
    POWERPC_DEF("440SP2",        CPU_POWERPC_440SP2,                 440EP),
7942 80d11f44 j_mayer
#endif
7943 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7944 a750fc0b j_mayer
    /* PowerPC 440 SPE                                                       */
7945 80d11f44 j_mayer
    POWERPC_DEF("440SPE",        CPU_POWERPC_440SPE,                 440EP),
7946 80d11f44 j_mayer
#endif
7947 a750fc0b j_mayer
    /* PowerPC 460 family                                                    */
7948 a750fc0b j_mayer
#if defined (TODO)
7949 a750fc0b j_mayer
    /* Generic PowerPC 464                                                   */
7950 80d11f44 j_mayer
    POWERPC_DEF("464",           CPU_POWERPC_464,                    460),
7951 a750fc0b j_mayer
#endif
7952 a750fc0b j_mayer
    /* PowerPC 464 microcontrolers                                           */
7953 a750fc0b j_mayer
#if defined (TODO)
7954 a750fc0b j_mayer
    /* PowerPC 464H90                                                        */
7955 80d11f44 j_mayer
    POWERPC_DEF("464H90",        CPU_POWERPC_464H90,                 460),
7956 a750fc0b j_mayer
#endif
7957 a750fc0b j_mayer
#if defined (TODO)
7958 a750fc0b j_mayer
    /* PowerPC 464H90F                                                       */
7959 80d11f44 j_mayer
    POWERPC_DEF("464H90F",       CPU_POWERPC_464H90F,                460F),
7960 a750fc0b j_mayer
#endif
7961 a750fc0b j_mayer
    /* Freescale embedded PowerPC cores                                      */
7962 80d11f44 j_mayer
    /* MPC5xx family (aka RCPU)                                              */
7963 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7964 80d11f44 j_mayer
    /* Generic MPC5xx core                                                   */
7965 80d11f44 j_mayer
    POWERPC_DEF("MPC5xx",        CPU_POWERPC_MPC5xx,                 MPC5xx),
7966 80d11f44 j_mayer
#endif
7967 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7968 80d11f44 j_mayer
    /* Codename for MPC5xx core                                              */
7969 80d11f44 j_mayer
    POWERPC_DEF("RCPU",          CPU_POWERPC_MPC5xx,                 MPC5xx),
7970 80d11f44 j_mayer
#endif
7971 80d11f44 j_mayer
    /* MPC5xx microcontrollers                                               */
7972 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7973 80d11f44 j_mayer
    /* MGT560                                                                */
7974 80d11f44 j_mayer
    POWERPC_DEF("MGT560",        CPU_POWERPC_MGT560,                 MPC5xx),
7975 80d11f44 j_mayer
#endif
7976 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7977 80d11f44 j_mayer
    /* MPC509                                                                */
7978 80d11f44 j_mayer
    POWERPC_DEF("MPC509",        CPU_POWERPC_MPC509,                 MPC5xx),
7979 80d11f44 j_mayer
#endif
7980 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7981 80d11f44 j_mayer
    /* MPC533                                                                */
7982 80d11f44 j_mayer
    POWERPC_DEF("MPC533",        CPU_POWERPC_MPC533,                 MPC5xx),
7983 80d11f44 j_mayer
#endif
7984 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7985 80d11f44 j_mayer
    /* MPC534                                                                */
7986 80d11f44 j_mayer
    POWERPC_DEF("MPC534",        CPU_POWERPC_MPC534,                 MPC5xx),
7987 80d11f44 j_mayer
#endif
7988 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7989 80d11f44 j_mayer
    /* MPC555                                                                */
7990 80d11f44 j_mayer
    POWERPC_DEF("MPC555",        CPU_POWERPC_MPC555,                 MPC5xx),
7991 80d11f44 j_mayer
#endif
7992 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7993 80d11f44 j_mayer
    /* MPC556                                                                */
7994 80d11f44 j_mayer
    POWERPC_DEF("MPC556",        CPU_POWERPC_MPC556,                 MPC5xx),
7995 80d11f44 j_mayer
#endif
7996 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
7997 80d11f44 j_mayer
    /* MPC560                                                                */
7998 80d11f44 j_mayer
    POWERPC_DEF("MPC560",        CPU_POWERPC_MPC560,                 MPC5xx),
7999 80d11f44 j_mayer
#endif
8000 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8001 80d11f44 j_mayer
    /* MPC561                                                                */
8002 80d11f44 j_mayer
    POWERPC_DEF("MPC561",        CPU_POWERPC_MPC561,                 MPC5xx),
8003 80d11f44 j_mayer
#endif
8004 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8005 80d11f44 j_mayer
    /* MPC562                                                                */
8006 80d11f44 j_mayer
    POWERPC_DEF("MPC562",        CPU_POWERPC_MPC562,                 MPC5xx),
8007 80d11f44 j_mayer
#endif
8008 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8009 80d11f44 j_mayer
    /* MPC563                                                                */
8010 80d11f44 j_mayer
    POWERPC_DEF("MPC563",        CPU_POWERPC_MPC563,                 MPC5xx),
8011 80d11f44 j_mayer
#endif
8012 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8013 80d11f44 j_mayer
    /* MPC564                                                                */
8014 80d11f44 j_mayer
    POWERPC_DEF("MPC564",        CPU_POWERPC_MPC564,                 MPC5xx),
8015 80d11f44 j_mayer
#endif
8016 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8017 80d11f44 j_mayer
    /* MPC565                                                                */
8018 80d11f44 j_mayer
    POWERPC_DEF("MPC565",        CPU_POWERPC_MPC565,                 MPC5xx),
8019 80d11f44 j_mayer
#endif
8020 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8021 80d11f44 j_mayer
    /* MPC566                                                                */
8022 80d11f44 j_mayer
    POWERPC_DEF("MPC566",        CPU_POWERPC_MPC566,                 MPC5xx),
8023 80d11f44 j_mayer
#endif
8024 80d11f44 j_mayer
    /* MPC8xx family (aka PowerQUICC)                                        */
8025 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8026 80d11f44 j_mayer
    /* Generic MPC8xx core                                                   */
8027 80d11f44 j_mayer
    POWERPC_DEF("MPC8xx",        CPU_POWERPC_MPC8xx,                 MPC8xx),
8028 80d11f44 j_mayer
#endif
8029 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8030 80d11f44 j_mayer
    /* Codename for MPC8xx core                                              */
8031 80d11f44 j_mayer
    POWERPC_DEF("PowerQUICC",    CPU_POWERPC_MPC8xx,                 MPC8xx),
8032 80d11f44 j_mayer
#endif
8033 80d11f44 j_mayer
    /* MPC8xx microcontrollers                                               */
8034 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8035 80d11f44 j_mayer
    /* MGT823                                                                */
8036 80d11f44 j_mayer
    POWERPC_DEF("MGT823",        CPU_POWERPC_MGT823,                 MPC8xx),
8037 80d11f44 j_mayer
#endif
8038 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8039 80d11f44 j_mayer
    /* MPC821                                                                */
8040 80d11f44 j_mayer
    POWERPC_DEF("MPC821",        CPU_POWERPC_MPC821,                 MPC8xx),
8041 80d11f44 j_mayer
#endif
8042 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8043 80d11f44 j_mayer
    /* MPC823                                                                */
8044 80d11f44 j_mayer
    POWERPC_DEF("MPC823",        CPU_POWERPC_MPC823,                 MPC8xx),
8045 80d11f44 j_mayer
#endif
8046 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8047 80d11f44 j_mayer
    /* MPC850                                                                */
8048 80d11f44 j_mayer
    POWERPC_DEF("MPC850",        CPU_POWERPC_MPC850,                 MPC8xx),
8049 80d11f44 j_mayer
#endif
8050 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8051 80d11f44 j_mayer
    /* MPC852T                                                               */
8052 80d11f44 j_mayer
    POWERPC_DEF("MPC852T",       CPU_POWERPC_MPC852T,                MPC8xx),
8053 80d11f44 j_mayer
#endif
8054 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8055 80d11f44 j_mayer
    /* MPC855T                                                               */
8056 80d11f44 j_mayer
    POWERPC_DEF("MPC855T",       CPU_POWERPC_MPC855T,                MPC8xx),
8057 80d11f44 j_mayer
#endif
8058 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8059 80d11f44 j_mayer
    /* MPC857                                                                */
8060 80d11f44 j_mayer
    POWERPC_DEF("MPC857",        CPU_POWERPC_MPC857,                 MPC8xx),
8061 80d11f44 j_mayer
#endif
8062 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8063 80d11f44 j_mayer
    /* MPC859                                                                */
8064 80d11f44 j_mayer
    POWERPC_DEF("MPC859",        CPU_POWERPC_MPC859,                 MPC8xx),
8065 80d11f44 j_mayer
#endif
8066 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8067 80d11f44 j_mayer
    /* MPC860                                                                */
8068 80d11f44 j_mayer
    POWERPC_DEF("MPC860",        CPU_POWERPC_MPC860,                 MPC8xx),
8069 80d11f44 j_mayer
#endif
8070 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8071 80d11f44 j_mayer
    /* MPC862                                                                */
8072 80d11f44 j_mayer
    POWERPC_DEF("MPC862",        CPU_POWERPC_MPC862,                 MPC8xx),
8073 80d11f44 j_mayer
#endif
8074 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8075 80d11f44 j_mayer
    /* MPC866                                                                */
8076 80d11f44 j_mayer
    POWERPC_DEF("MPC866",        CPU_POWERPC_MPC866,                 MPC8xx),
8077 80d11f44 j_mayer
#endif
8078 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8079 80d11f44 j_mayer
    /* MPC870                                                                */
8080 80d11f44 j_mayer
    POWERPC_DEF("MPC870",        CPU_POWERPC_MPC870,                 MPC8xx),
8081 80d11f44 j_mayer
#endif
8082 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8083 80d11f44 j_mayer
    /* MPC875                                                                */
8084 80d11f44 j_mayer
    POWERPC_DEF("MPC875",        CPU_POWERPC_MPC875,                 MPC8xx),
8085 80d11f44 j_mayer
#endif
8086 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8087 80d11f44 j_mayer
    /* MPC880                                                                */
8088 80d11f44 j_mayer
    POWERPC_DEF("MPC880",        CPU_POWERPC_MPC880,                 MPC8xx),
8089 80d11f44 j_mayer
#endif
8090 80d11f44 j_mayer
#if defined(TODO_USER_ONLY)
8091 80d11f44 j_mayer
    /* MPC885                                                                */
8092 80d11f44 j_mayer
    POWERPC_DEF("MPC885",        CPU_POWERPC_MPC885,                 MPC8xx),
8093 80d11f44 j_mayer
#endif
8094 80d11f44 j_mayer
    /* MPC82xx family (aka PowerQUICC-II)                                    */
8095 80d11f44 j_mayer
    /* Generic MPC52xx core                                                  */
8096 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC52xx",
8097 80d11f44 j_mayer
                    CPU_POWERPC_MPC52xx,      POWERPC_SVR_52xx,      G2LE),
8098 80d11f44 j_mayer
    /* Generic MPC82xx core                                                  */
8099 80d11f44 j_mayer
    POWERPC_DEF("MPC82xx",       CPU_POWERPC_MPC82xx,                G2),
8100 80d11f44 j_mayer
    /* Codename for MPC82xx                                                  */
8101 80d11f44 j_mayer
    POWERPC_DEF("PowerQUICC-II", CPU_POWERPC_MPC82xx,                G2),
8102 80d11f44 j_mayer
    /* PowerPC G2 core                                                       */
8103 80d11f44 j_mayer
    POWERPC_DEF("G2",            CPU_POWERPC_G2,                     G2),
8104 80d11f44 j_mayer
    /* PowerPC G2 H4 core                                                    */
8105 80d11f44 j_mayer
    POWERPC_DEF("G2H4",          CPU_POWERPC_G2H4,                   G2),
8106 80d11f44 j_mayer
    /* PowerPC G2 GP core                                                    */
8107 80d11f44 j_mayer
    POWERPC_DEF("G2GP",          CPU_POWERPC_G2gp,                   G2),
8108 80d11f44 j_mayer
    /* PowerPC G2 LS core                                                    */
8109 80d11f44 j_mayer
    POWERPC_DEF("G2LS",          CPU_POWERPC_G2ls,                   G2),
8110 80d11f44 j_mayer
    /* PowerPC G2 HiP3 core                                                  */
8111 80d11f44 j_mayer
    POWERPC_DEF("G2HiP3",        CPU_POWERPC_G2_HIP3,                G2),
8112 80d11f44 j_mayer
    /* PowerPC G2 HiP4 core                                                  */
8113 80d11f44 j_mayer
    POWERPC_DEF("G2HiP4",        CPU_POWERPC_G2_HIP4,                G2),
8114 80d11f44 j_mayer
    /* PowerPC MPC603 core                                                   */
8115 80d11f44 j_mayer
    POWERPC_DEF("MPC603",        CPU_POWERPC_MPC603,                 603E),
8116 80d11f44 j_mayer
    /* PowerPC G2le core (same as G2 plus little-endian mode support)        */
8117 80d11f44 j_mayer
    POWERPC_DEF("G2le",          CPU_POWERPC_G2LE,                   G2LE),
8118 80d11f44 j_mayer
    /* PowerPC G2LE GP core                                                  */
8119 80d11f44 j_mayer
    POWERPC_DEF("G2leGP",        CPU_POWERPC_G2LEgp,                 G2LE),
8120 80d11f44 j_mayer
    /* PowerPC G2LE LS core                                                  */
8121 80d11f44 j_mayer
    POWERPC_DEF("G2leLS",        CPU_POWERPC_G2LEls,                 G2LE),
8122 80d11f44 j_mayer
    /* PowerPC G2LE GP1 core                                                 */
8123 80d11f44 j_mayer
    POWERPC_DEF("G2leGP1",       CPU_POWERPC_G2LEgp1,                G2LE),
8124 80d11f44 j_mayer
    /* PowerPC G2LE GP3 core                                                 */
8125 80d11f44 j_mayer
    POWERPC_DEF("G2leGP3",       CPU_POWERPC_G2LEgp1,                G2LE),
8126 80d11f44 j_mayer
    /* PowerPC MPC603 microcontrollers                                       */
8127 80d11f44 j_mayer
    /* MPC8240                                                               */
8128 80d11f44 j_mayer
    POWERPC_DEF("MPC8240",       CPU_POWERPC_MPC8240,                603E),
8129 80d11f44 j_mayer
    /* PowerPC G2 microcontrollers                                           */
8130 082c6681 j_mayer
#if defined(TODO)
8131 80d11f44 j_mayer
    /* MPC5121                                                               */
8132 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5121",
8133 80d11f44 j_mayer
                    CPU_POWERPC_MPC5121,      POWERPC_SVR_5121,      G2LE),
8134 80d11f44 j_mayer
#endif
8135 80d11f44 j_mayer
    /* MPC5200                                                               */
8136 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200",
8137 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200,      POWERPC_SVR_5200,      G2LE),
8138 80d11f44 j_mayer
    /* MPC5200 v1.0                                                          */
8139 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v10",
8140 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v10,  POWERPC_SVR_5200_v10,  G2LE),
8141 80d11f44 j_mayer
    /* MPC5200 v1.1                                                          */
8142 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v11",
8143 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v11,  POWERPC_SVR_5200_v11,  G2LE),
8144 80d11f44 j_mayer
    /* MPC5200 v1.2                                                          */
8145 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200_v12",
8146 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200_v12,  POWERPC_SVR_5200_v12,  G2LE),
8147 80d11f44 j_mayer
    /* MPC5200B                                                              */
8148 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B",
8149 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B,     POWERPC_SVR_5200B,     G2LE),
8150 80d11f44 j_mayer
    /* MPC5200B v2.0                                                         */
8151 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B_v20",
8152 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B_v20, POWERPC_SVR_5200B_v20, G2LE),
8153 80d11f44 j_mayer
    /* MPC5200B v2.1                                                         */
8154 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5200B_v21",
8155 80d11f44 j_mayer
                    CPU_POWERPC_MPC5200B_v21, POWERPC_SVR_5200B_v21, G2LE),
8156 80d11f44 j_mayer
    /* MPC8241                                                               */
8157 80d11f44 j_mayer
    POWERPC_DEF("MPC8241",       CPU_POWERPC_MPC8241,                G2),
8158 80d11f44 j_mayer
    /* MPC8245                                                               */
8159 80d11f44 j_mayer
    POWERPC_DEF("MPC8245",       CPU_POWERPC_MPC8245,                G2),
8160 80d11f44 j_mayer
    /* MPC8247                                                               */
8161 80d11f44 j_mayer
    POWERPC_DEF("MPC8247",       CPU_POWERPC_MPC8247,                G2LE),
8162 80d11f44 j_mayer
    /* MPC8248                                                               */
8163 80d11f44 j_mayer
    POWERPC_DEF("MPC8248",       CPU_POWERPC_MPC8248,                G2LE),
8164 80d11f44 j_mayer
    /* MPC8250                                                               */
8165 80d11f44 j_mayer
    POWERPC_DEF("MPC8250",       CPU_POWERPC_MPC8250,                G2),
8166 80d11f44 j_mayer
    /* MPC8250 HiP3                                                          */
8167 80d11f44 j_mayer
    POWERPC_DEF("MPC8250_HiP3",  CPU_POWERPC_MPC8250_HiP3,           G2),
8168 80d11f44 j_mayer
    /* MPC8250 HiP4                                                          */
8169 80d11f44 j_mayer
    POWERPC_DEF("MPC8250_HiP4",  CPU_POWERPC_MPC8250_HiP4,           G2),
8170 80d11f44 j_mayer
    /* MPC8255                                                               */
8171 80d11f44 j_mayer
    POWERPC_DEF("MPC8255",       CPU_POWERPC_MPC8255,                G2),
8172 80d11f44 j_mayer
    /* MPC8255 HiP3                                                          */
8173 80d11f44 j_mayer
    POWERPC_DEF("MPC8255_HiP3",  CPU_POWERPC_MPC8255_HiP3,           G2),
8174 80d11f44 j_mayer
    /* MPC8255 HiP4                                                          */
8175 80d11f44 j_mayer
    POWERPC_DEF("MPC8255_HiP4",  CPU_POWERPC_MPC8255_HiP4,           G2),
8176 80d11f44 j_mayer
    /* MPC8260                                                               */
8177 80d11f44 j_mayer
    POWERPC_DEF("MPC8260",       CPU_POWERPC_MPC8260,                G2),
8178 80d11f44 j_mayer
    /* MPC8260 HiP3                                                          */
8179 80d11f44 j_mayer
    POWERPC_DEF("MPC8260_HiP3",  CPU_POWERPC_MPC8260_HiP3,           G2),
8180 80d11f44 j_mayer
    /* MPC8260 HiP4                                                          */
8181 80d11f44 j_mayer
    POWERPC_DEF("MPC8260_HiP4",  CPU_POWERPC_MPC8260_HiP4,           G2),
8182 80d11f44 j_mayer
    /* MPC8264                                                               */
8183 80d11f44 j_mayer
    POWERPC_DEF("MPC8264",       CPU_POWERPC_MPC8264,                G2),
8184 80d11f44 j_mayer
    /* MPC8264 HiP3                                                          */
8185 80d11f44 j_mayer
    POWERPC_DEF("MPC8264_HiP3",  CPU_POWERPC_MPC8264_HiP3,           G2),
8186 80d11f44 j_mayer
    /* MPC8264 HiP4                                                          */
8187 80d11f44 j_mayer
    POWERPC_DEF("MPC8264_HiP4",  CPU_POWERPC_MPC8264_HiP4,           G2),
8188 80d11f44 j_mayer
    /* MPC8265                                                               */
8189 80d11f44 j_mayer
    POWERPC_DEF("MPC8265",       CPU_POWERPC_MPC8265,                G2),
8190 80d11f44 j_mayer
    /* MPC8265 HiP3                                                          */
8191 80d11f44 j_mayer
    POWERPC_DEF("MPC8265_HiP3",  CPU_POWERPC_MPC8265_HiP3,           G2),
8192 80d11f44 j_mayer
    /* MPC8265 HiP4                                                          */
8193 80d11f44 j_mayer
    POWERPC_DEF("MPC8265_HiP4",  CPU_POWERPC_MPC8265_HiP4,           G2),
8194 80d11f44 j_mayer
    /* MPC8266                                                               */
8195 80d11f44 j_mayer
    POWERPC_DEF("MPC8266",       CPU_POWERPC_MPC8266,                G2),
8196 80d11f44 j_mayer
    /* MPC8266 HiP3                                                          */
8197 80d11f44 j_mayer
    POWERPC_DEF("MPC8266_HiP3",  CPU_POWERPC_MPC8266_HiP3,           G2),
8198 80d11f44 j_mayer
    /* MPC8266 HiP4                                                          */
8199 80d11f44 j_mayer
    POWERPC_DEF("MPC8266_HiP4",  CPU_POWERPC_MPC8266_HiP4,           G2),
8200 80d11f44 j_mayer
    /* MPC8270                                                               */
8201 80d11f44 j_mayer
    POWERPC_DEF("MPC8270",       CPU_POWERPC_MPC8270,                G2LE),
8202 80d11f44 j_mayer
    /* MPC8271                                                               */
8203 80d11f44 j_mayer
    POWERPC_DEF("MPC8271",       CPU_POWERPC_MPC8271,                G2LE),
8204 80d11f44 j_mayer
    /* MPC8272                                                               */
8205 80d11f44 j_mayer
    POWERPC_DEF("MPC8272",       CPU_POWERPC_MPC8272,                G2LE),
8206 80d11f44 j_mayer
    /* MPC8275                                                               */
8207 80d11f44 j_mayer
    POWERPC_DEF("MPC8275",       CPU_POWERPC_MPC8275,                G2LE),
8208 80d11f44 j_mayer
    /* MPC8280                                                               */
8209 80d11f44 j_mayer
    POWERPC_DEF("MPC8280",       CPU_POWERPC_MPC8280,                G2LE),
8210 a750fc0b j_mayer
    /* e200 family                                                           */
8211 a750fc0b j_mayer
    /* Generic PowerPC e200 core                                             */
8212 80d11f44 j_mayer
    POWERPC_DEF("e200",          CPU_POWERPC_e200,                   e200),
8213 80d11f44 j_mayer
    /* Generic MPC55xx core                                                  */
8214 80d11f44 j_mayer
#if defined (TODO)
8215 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC55xx",
8216 80d11f44 j_mayer
                    CPU_POWERPC_MPC55xx,      POWERPC_SVR_55xx,      e200),
8217 a750fc0b j_mayer
#endif
8218 a750fc0b j_mayer
#if defined (TODO)
8219 80d11f44 j_mayer
    /* PowerPC e200z0 core                                                   */
8220 80d11f44 j_mayer
    POWERPC_DEF("e200z0",        CPU_POWERPC_e200z0,                 e200),
8221 a750fc0b j_mayer
#endif
8222 a750fc0b j_mayer
#if defined (TODO)
8223 80d11f44 j_mayer
    /* PowerPC e200z1 core                                                   */
8224 80d11f44 j_mayer
    POWERPC_DEF("e200z1",        CPU_POWERPC_e200z1,                 e200),
8225 80d11f44 j_mayer
#endif
8226 80d11f44 j_mayer
#if defined (TODO)
8227 80d11f44 j_mayer
    /* PowerPC e200z3 core                                                   */
8228 80d11f44 j_mayer
    POWERPC_DEF("e200z3",        CPU_POWERPC_e200z3,                 e200),
8229 80d11f44 j_mayer
#endif
8230 80d11f44 j_mayer
    /* PowerPC e200z5 core                                                   */
8231 80d11f44 j_mayer
    POWERPC_DEF("e200z5",        CPU_POWERPC_e200z5,                 e200),
8232 a750fc0b j_mayer
    /* PowerPC e200z6 core                                                   */
8233 80d11f44 j_mayer
    POWERPC_DEF("e200z6",        CPU_POWERPC_e200z6,                 e200),
8234 80d11f44 j_mayer
    /* PowerPC e200 microcontrollers                                         */
8235 80d11f44 j_mayer
#if defined (TODO)
8236 80d11f44 j_mayer
    /* MPC5514E                                                              */
8237 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E",
8238 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E,     POWERPC_SVR_5514E,     e200),
8239 a750fc0b j_mayer
#endif
8240 a750fc0b j_mayer
#if defined (TODO)
8241 80d11f44 j_mayer
    /* MPC5514E v0                                                           */
8242 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E_v0",
8243 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E_v0,  POWERPC_SVR_5514E_v0,  e200),
8244 a750fc0b j_mayer
#endif
8245 a750fc0b j_mayer
#if defined (TODO)
8246 80d11f44 j_mayer
    /* MPC5514E v1                                                           */
8247 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514E_v1",
8248 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514E_v1,  POWERPC_SVR_5514E_v1,  e200),
8249 a750fc0b j_mayer
#endif
8250 a750fc0b j_mayer
#if defined (TODO)
8251 80d11f44 j_mayer
    /* MPC5514G                                                              */
8252 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G",
8253 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G,     POWERPC_SVR_5514G,     e200),
8254 a750fc0b j_mayer
#endif
8255 a750fc0b j_mayer
#if defined (TODO)
8256 80d11f44 j_mayer
    /* MPC5514G v0                                                           */
8257 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G_v0",
8258 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G_v0,  POWERPC_SVR_5514G_v0,  e200),
8259 a750fc0b j_mayer
#endif
8260 a750fc0b j_mayer
#if defined (TODO)
8261 80d11f44 j_mayer
    /* MPC5514G v1                                                           */
8262 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5514G_v1",
8263 80d11f44 j_mayer
                    CPU_POWERPC_MPC5514G_v1,  POWERPC_SVR_5514G_v1,  e200),
8264 a750fc0b j_mayer
#endif
8265 a750fc0b j_mayer
#if defined (TODO)
8266 80d11f44 j_mayer
    /* MPC5515S                                                              */
8267 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5515S",
8268 80d11f44 j_mayer
                    CPU_POWERPC_MPC5515S,     POWERPC_SVR_5515S,     e200),
8269 a750fc0b j_mayer
#endif
8270 a750fc0b j_mayer
#if defined (TODO)
8271 80d11f44 j_mayer
    /* MPC5516E                                                              */
8272 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E",
8273 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E,     POWERPC_SVR_5516E,     e200),
8274 a750fc0b j_mayer
#endif
8275 a750fc0b j_mayer
#if defined (TODO)
8276 80d11f44 j_mayer
    /* MPC5516E v0                                                           */
8277 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E_v0",
8278 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E_v0,  POWERPC_SVR_5516E_v0,  e200),
8279 a750fc0b j_mayer
#endif
8280 a750fc0b j_mayer
#if defined (TODO)
8281 80d11f44 j_mayer
    /* MPC5516E v1                                                           */
8282 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516E_v1",
8283 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516E_v1,  POWERPC_SVR_5516E_v1,  e200),
8284 a750fc0b j_mayer
#endif
8285 a750fc0b j_mayer
#if defined (TODO)
8286 80d11f44 j_mayer
    /* MPC5516G                                                              */
8287 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G",
8288 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G,     POWERPC_SVR_5516G,     e200),
8289 a750fc0b j_mayer
#endif
8290 a750fc0b j_mayer
#if defined (TODO)
8291 80d11f44 j_mayer
    /* MPC5516G v0                                                           */
8292 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G_v0",
8293 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G_v0,  POWERPC_SVR_5516G_v0,  e200),
8294 a750fc0b j_mayer
#endif
8295 a750fc0b j_mayer
#if defined (TODO)
8296 80d11f44 j_mayer
    /* MPC5516G v1                                                           */
8297 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516G_v1",
8298 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516G_v1,  POWERPC_SVR_5516G_v1,  e200),
8299 a750fc0b j_mayer
#endif
8300 a750fc0b j_mayer
#if defined (TODO)
8301 80d11f44 j_mayer
    /* MPC5516S                                                              */
8302 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5516S",
8303 80d11f44 j_mayer
                    CPU_POWERPC_MPC5516S,     POWERPC_SVR_5516S,     e200),
8304 a750fc0b j_mayer
#endif
8305 a750fc0b j_mayer
#if defined (TODO)
8306 80d11f44 j_mayer
    /* MPC5533                                                               */
8307 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5533",
8308 80d11f44 j_mayer
                    CPU_POWERPC_MPC5533,      POWERPC_SVR_5533,      e200),
8309 a750fc0b j_mayer
#endif
8310 a750fc0b j_mayer
#if defined (TODO)
8311 80d11f44 j_mayer
    /* MPC5534                                                               */
8312 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5534",
8313 80d11f44 j_mayer
                    CPU_POWERPC_MPC5534,      POWERPC_SVR_5534,      e200),
8314 a750fc0b j_mayer
#endif
8315 80d11f44 j_mayer
#if defined (TODO)
8316 80d11f44 j_mayer
    /* MPC5553                                                               */
8317 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5553",
8318 80d11f44 j_mayer
                    CPU_POWERPC_MPC5553,      POWERPC_SVR_5553,      e200),
8319 80d11f44 j_mayer
#endif
8320 80d11f44 j_mayer
#if defined (TODO)
8321 80d11f44 j_mayer
    /* MPC5554                                                               */
8322 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5554",
8323 80d11f44 j_mayer
                    CPU_POWERPC_MPC5554,      POWERPC_SVR_5554,      e200),
8324 80d11f44 j_mayer
#endif
8325 80d11f44 j_mayer
#if defined (TODO)
8326 80d11f44 j_mayer
    /* MPC5561                                                               */
8327 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5561",
8328 80d11f44 j_mayer
                    CPU_POWERPC_MPC5561,      POWERPC_SVR_5561,      e200),
8329 80d11f44 j_mayer
#endif
8330 80d11f44 j_mayer
#if defined (TODO)
8331 80d11f44 j_mayer
    /* MPC5565                                                               */
8332 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5565",
8333 80d11f44 j_mayer
                    CPU_POWERPC_MPC5565,      POWERPC_SVR_5565,      e200),
8334 80d11f44 j_mayer
#endif
8335 80d11f44 j_mayer
#if defined (TODO)
8336 80d11f44 j_mayer
    /* MPC5566                                                               */
8337 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5566",
8338 80d11f44 j_mayer
                    CPU_POWERPC_MPC5566,      POWERPC_SVR_5566,      e200),
8339 80d11f44 j_mayer
#endif
8340 80d11f44 j_mayer
#if defined (TODO)
8341 80d11f44 j_mayer
    /* MPC5567                                                               */
8342 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC5567",
8343 80d11f44 j_mayer
                    CPU_POWERPC_MPC5567,      POWERPC_SVR_5567,      e200),
8344 80d11f44 j_mayer
#endif
8345 80d11f44 j_mayer
    /* e300 family                                                           */
8346 80d11f44 j_mayer
    /* Generic PowerPC e300 core                                             */
8347 80d11f44 j_mayer
    POWERPC_DEF("e300",          CPU_POWERPC_e300,                   e300),
8348 80d11f44 j_mayer
    /* PowerPC e300c1 core                                                   */
8349 80d11f44 j_mayer
    POWERPC_DEF("e300c1",        CPU_POWERPC_e300c1,                 e300),
8350 80d11f44 j_mayer
    /* PowerPC e300c2 core                                                   */
8351 80d11f44 j_mayer
    POWERPC_DEF("e300c2",        CPU_POWERPC_e300c2,                 e300),
8352 80d11f44 j_mayer
    /* PowerPC e300c3 core                                                   */
8353 80d11f44 j_mayer
    POWERPC_DEF("e300c3",        CPU_POWERPC_e300c3,                 e300),
8354 80d11f44 j_mayer
    /* PowerPC e300c4 core                                                   */
8355 80d11f44 j_mayer
    POWERPC_DEF("e300c4",        CPU_POWERPC_e300c4,                 e300),
8356 80d11f44 j_mayer
    /* PowerPC e300 microcontrollers                                         */
8357 80d11f44 j_mayer
#if defined (TODO)
8358 80d11f44 j_mayer
    /* MPC8313                                                               */
8359 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8313",
8360 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8313,      e300),
8361 80d11f44 j_mayer
#endif
8362 80d11f44 j_mayer
#if defined (TODO)
8363 80d11f44 j_mayer
    /* MPC8313E                                                              */
8364 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8313E",
8365 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8313E,     e300),
8366 80d11f44 j_mayer
#endif
8367 80d11f44 j_mayer
#if defined (TODO)
8368 80d11f44 j_mayer
    /* MPC8314                                                               */
8369 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8314",
8370 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8314,      e300),
8371 80d11f44 j_mayer
#endif
8372 80d11f44 j_mayer
#if defined (TODO)
8373 80d11f44 j_mayer
    /* MPC8314E                                                              */
8374 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8314E",
8375 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8314E,     e300),
8376 80d11f44 j_mayer
#endif
8377 80d11f44 j_mayer
#if defined (TODO)
8378 80d11f44 j_mayer
    /* MPC8315                                                               */
8379 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8315",
8380 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8315,      e300),
8381 80d11f44 j_mayer
#endif
8382 80d11f44 j_mayer
#if defined (TODO)
8383 80d11f44 j_mayer
    /* MPC8315E                                                              */
8384 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8315E",
8385 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC831x,      POWERPC_SVR_8315E,     e300),
8386 80d11f44 j_mayer
#endif
8387 80d11f44 j_mayer
#if defined (TODO)
8388 80d11f44 j_mayer
    /* MPC8321                                                               */
8389 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8321",
8390 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8321,      e300),
8391 80d11f44 j_mayer
#endif
8392 80d11f44 j_mayer
#if defined (TODO)
8393 80d11f44 j_mayer
    /* MPC8321E                                                              */
8394 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8321E",
8395 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8321E,     e300),
8396 80d11f44 j_mayer
#endif
8397 80d11f44 j_mayer
#if defined (TODO)
8398 80d11f44 j_mayer
    /* MPC8323                                                               */
8399 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8323",
8400 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8323,      e300),
8401 80d11f44 j_mayer
#endif
8402 80d11f44 j_mayer
#if defined (TODO)
8403 80d11f44 j_mayer
    /* MPC8323E                                                              */
8404 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8323E",
8405 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC832x,      POWERPC_SVR_8323E,     e300),
8406 80d11f44 j_mayer
#endif
8407 492d7bf5 Thomas Monjalon
    /* MPC8343                                                               */
8408 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8343",
8409 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343,      e300),
8410 80d11f44 j_mayer
    /* MPC8343A                                                              */
8411 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8343A",
8412 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343A,     e300),
8413 492d7bf5 Thomas Monjalon
    /* MPC8343E                                                              */
8414 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8343E",
8415 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343E,     e300),
8416 80d11f44 j_mayer
    /* MPC8343EA                                                             */
8417 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8343EA",
8418 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8343EA,    e300),
8419 492d7bf5 Thomas Monjalon
    /* MPC8347                                                               */
8420 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347",
8421 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347,      e300),
8422 492d7bf5 Thomas Monjalon
    /* MPC8347T                                                              */
8423 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347T",
8424 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347T,     e300),
8425 492d7bf5 Thomas Monjalon
    /* MPC8347P                                                              */
8426 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347P",
8427 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347P,     e300),
8428 80d11f44 j_mayer
    /* MPC8347A                                                              */
8429 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347A",
8430 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347A,     e300),
8431 80d11f44 j_mayer
    /* MPC8347AT                                                             */
8432 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347AT",
8433 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347AT,    e300),
8434 80d11f44 j_mayer
    /* MPC8347AP                                                             */
8435 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347AP",
8436 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347AP,    e300),
8437 492d7bf5 Thomas Monjalon
    /* MPC8347E                                                              */
8438 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347E",
8439 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347E,     e300),
8440 492d7bf5 Thomas Monjalon
    /* MPC8347ET                                                             */
8441 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347ET",
8442 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347ET,    e300),
8443 492d7bf5 Thomas Monjalon
    /* MPC8343EP                                                             */
8444 492d7bf5 Thomas Monjalon
    POWERPC_DEF_SVR("MPC8347EP",
8445 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EP,    e300),
8446 80d11f44 j_mayer
    /* MPC8347EA                                                             */
8447 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EA",
8448 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EA,    e300),
8449 80d11f44 j_mayer
    /* MPC8347EAT                                                            */
8450 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EAT",
8451 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EAT,   e300),
8452 80d11f44 j_mayer
    /* MPC8343EAP                                                            */
8453 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8347EAP",
8454 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8347EAP,   e300),
8455 80d11f44 j_mayer
    /* MPC8349                                                               */
8456 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349",
8457 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349,      e300),
8458 80d11f44 j_mayer
    /* MPC8349A                                                              */
8459 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349A",
8460 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349A,     e300),
8461 80d11f44 j_mayer
    /* MPC8349E                                                              */
8462 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349E",
8463 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349E,     e300),
8464 80d11f44 j_mayer
    /* MPC8349EA                                                             */
8465 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8349EA",
8466 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC834x,      POWERPC_SVR_8349EA,    e300),
8467 80d11f44 j_mayer
#if defined (TODO)
8468 80d11f44 j_mayer
    /* MPC8358E                                                              */
8469 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8358E",
8470 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC835x,      POWERPC_SVR_8358E,     e300),
8471 80d11f44 j_mayer
#endif
8472 80d11f44 j_mayer
#if defined (TODO)
8473 80d11f44 j_mayer
    /* MPC8360E                                                              */
8474 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8360E",
8475 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC836x,      POWERPC_SVR_8360E,     e300),
8476 80d11f44 j_mayer
#endif
8477 80d11f44 j_mayer
    /* MPC8377                                                               */
8478 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8377",
8479 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8377,      e300),
8480 80d11f44 j_mayer
    /* MPC8377E                                                              */
8481 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8377E",
8482 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8377E,     e300),
8483 80d11f44 j_mayer
    /* MPC8378                                                               */
8484 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8378",
8485 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8378,      e300),
8486 80d11f44 j_mayer
    /* MPC8378E                                                              */
8487 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8378E",
8488 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8378E,     e300),
8489 80d11f44 j_mayer
    /* MPC8379                                                               */
8490 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8379",
8491 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8379,      e300),
8492 80d11f44 j_mayer
    /* MPC8379E                                                              */
8493 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8379E",
8494 74d77cae Thomas Monjalon
                    CPU_POWERPC_MPC837x,      POWERPC_SVR_8379E,     e300),
8495 80d11f44 j_mayer
    /* e500 family                                                           */
8496 80d11f44 j_mayer
    /* PowerPC e500 core                                                     */
8497 bd5ea513 aurel32
    POWERPC_DEF("e500",          CPU_POWERPC_e500v2_v22,             e500v2),
8498 bd5ea513 aurel32
    /* PowerPC e500v1 core                                                   */
8499 bd5ea513 aurel32
    POWERPC_DEF("e500v1",        CPU_POWERPC_e500v1,                 e500v1),
8500 80d11f44 j_mayer
    /* PowerPC e500 v1.0 core                                                */
8501 bd5ea513 aurel32
    POWERPC_DEF("e500_v10",      CPU_POWERPC_e500v1_v10,             e500v1),
8502 80d11f44 j_mayer
    /* PowerPC e500 v2.0 core                                                */
8503 bd5ea513 aurel32
    POWERPC_DEF("e500_v20",      CPU_POWERPC_e500v1_v20,             e500v1),
8504 80d11f44 j_mayer
    /* PowerPC e500v2 core                                                   */
8505 bd5ea513 aurel32
    POWERPC_DEF("e500v2",        CPU_POWERPC_e500v2,                 e500v2),
8506 80d11f44 j_mayer
    /* PowerPC e500v2 v1.0 core                                              */
8507 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v10",    CPU_POWERPC_e500v2_v10,             e500v2),
8508 80d11f44 j_mayer
    /* PowerPC e500v2 v2.0 core                                              */
8509 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v20",    CPU_POWERPC_e500v2_v20,             e500v2),
8510 80d11f44 j_mayer
    /* PowerPC e500v2 v2.1 core                                              */
8511 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v21",    CPU_POWERPC_e500v2_v21,             e500v2),
8512 80d11f44 j_mayer
    /* PowerPC e500v2 v2.2 core                                              */
8513 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v22",    CPU_POWERPC_e500v2_v22,             e500v2),
8514 80d11f44 j_mayer
    /* PowerPC e500v2 v3.0 core                                              */
8515 bd5ea513 aurel32
    POWERPC_DEF("e500v2_v30",    CPU_POWERPC_e500v2_v30,             e500v2),
8516 f7aa5583 Varun Sethi
    POWERPC_DEF("e500mc",        CPU_POWERPC_e500mc,                 e500mc),
8517 80d11f44 j_mayer
    /* PowerPC e500 microcontrollers                                         */
8518 80d11f44 j_mayer
    /* MPC8533                                                               */
8519 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533",
8520 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533,      POWERPC_SVR_8533,      e500v2),
8521 80d11f44 j_mayer
    /* MPC8533 v1.0                                                          */
8522 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533_v10",
8523 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533_v10,  POWERPC_SVR_8533_v10,  e500v2),
8524 80d11f44 j_mayer
    /* MPC8533 v1.1                                                          */
8525 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533_v11",
8526 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533_v11,  POWERPC_SVR_8533_v11,  e500v2),
8527 80d11f44 j_mayer
    /* MPC8533E                                                              */
8528 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E",
8529 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533E,     POWERPC_SVR_8533E,     e500v2),
8530 80d11f44 j_mayer
    /* MPC8533E v1.0                                                         */
8531 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E_v10",
8532 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533E_v10, POWERPC_SVR_8533E_v10, e500v2),
8533 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8533E_v11",
8534 bd5ea513 aurel32
                    CPU_POWERPC_MPC8533E_v11, POWERPC_SVR_8533E_v11, e500v2),
8535 80d11f44 j_mayer
    /* MPC8540                                                               */
8536 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540",
8537 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540,      POWERPC_SVR_8540,      e500v1),
8538 80d11f44 j_mayer
    /* MPC8540 v1.0                                                          */
8539 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v10",
8540 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540_v10,  POWERPC_SVR_8540_v10,  e500v1),
8541 80d11f44 j_mayer
    /* MPC8540 v2.0                                                          */
8542 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v20",
8543 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540_v20,  POWERPC_SVR_8540_v20,  e500v1),
8544 80d11f44 j_mayer
    /* MPC8540 v2.1                                                          */
8545 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8540_v21",
8546 bd5ea513 aurel32
                    CPU_POWERPC_MPC8540_v21,  POWERPC_SVR_8540_v21,  e500v1),
8547 80d11f44 j_mayer
    /* MPC8541                                                               */
8548 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541",
8549 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541,      POWERPC_SVR_8541,      e500v1),
8550 80d11f44 j_mayer
    /* MPC8541 v1.0                                                          */
8551 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541_v10",
8552 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541_v10,  POWERPC_SVR_8541_v10,  e500v1),
8553 80d11f44 j_mayer
    /* MPC8541 v1.1                                                          */
8554 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541_v11",
8555 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541_v11,  POWERPC_SVR_8541_v11,  e500v1),
8556 80d11f44 j_mayer
    /* MPC8541E                                                              */
8557 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E",
8558 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541E,     POWERPC_SVR_8541E,     e500v1),
8559 80d11f44 j_mayer
    /* MPC8541E v1.0                                                         */
8560 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E_v10",
8561 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541E_v10, POWERPC_SVR_8541E_v10, e500v1),
8562 80d11f44 j_mayer
    /* MPC8541E v1.1                                                         */
8563 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8541E_v11",
8564 bd5ea513 aurel32
                    CPU_POWERPC_MPC8541E_v11, POWERPC_SVR_8541E_v11, e500v1),
8565 80d11f44 j_mayer
    /* MPC8543                                                               */
8566 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543",
8567 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543,      POWERPC_SVR_8543,      e500v2),
8568 80d11f44 j_mayer
    /* MPC8543 v1.0                                                          */
8569 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v10",
8570 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v10,  POWERPC_SVR_8543_v10,  e500v2),
8571 80d11f44 j_mayer
    /* MPC8543 v1.1                                                          */
8572 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v11",
8573 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v11,  POWERPC_SVR_8543_v11,  e500v2),
8574 80d11f44 j_mayer
    /* MPC8543 v2.0                                                          */
8575 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v20",
8576 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v20,  POWERPC_SVR_8543_v20,  e500v2),
8577 80d11f44 j_mayer
    /* MPC8543 v2.1                                                          */
8578 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543_v21",
8579 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543_v21,  POWERPC_SVR_8543_v21,  e500v2),
8580 80d11f44 j_mayer
    /* MPC8543E                                                              */
8581 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E",
8582 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E,     POWERPC_SVR_8543E,     e500v2),
8583 80d11f44 j_mayer
    /* MPC8543E v1.0                                                         */
8584 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v10",
8585 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v10, POWERPC_SVR_8543E_v10, e500v2),
8586 80d11f44 j_mayer
    /* MPC8543E v1.1                                                         */
8587 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v11",
8588 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v11, POWERPC_SVR_8543E_v11, e500v2),
8589 80d11f44 j_mayer
    /* MPC8543E v2.0                                                         */
8590 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v20",
8591 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v20, POWERPC_SVR_8543E_v20, e500v2),
8592 80d11f44 j_mayer
    /* MPC8543E v2.1                                                         */
8593 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8543E_v21",
8594 bd5ea513 aurel32
                    CPU_POWERPC_MPC8543E_v21, POWERPC_SVR_8543E_v21, e500v2),
8595 80d11f44 j_mayer
    /* MPC8544                                                               */
8596 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544",
8597 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544,      POWERPC_SVR_8544,      e500v2),
8598 80d11f44 j_mayer
    /* MPC8544 v1.0                                                          */
8599 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544_v10",
8600 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544_v10,  POWERPC_SVR_8544_v10,  e500v2),
8601 80d11f44 j_mayer
    /* MPC8544 v1.1                                                          */
8602 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544_v11",
8603 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544_v11,  POWERPC_SVR_8544_v11,  e500v2),
8604 80d11f44 j_mayer
    /* MPC8544E                                                              */
8605 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E",
8606 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544E,     POWERPC_SVR_8544E,     e500v2),
8607 80d11f44 j_mayer
    /* MPC8544E v1.0                                                         */
8608 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E_v10",
8609 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544E_v10, POWERPC_SVR_8544E_v10, e500v2),
8610 80d11f44 j_mayer
    /* MPC8544E v1.1                                                         */
8611 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8544E_v11",
8612 bd5ea513 aurel32
                    CPU_POWERPC_MPC8544E_v11, POWERPC_SVR_8544E_v11, e500v2),
8613 80d11f44 j_mayer
    /* MPC8545                                                               */
8614 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545",
8615 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545,      POWERPC_SVR_8545,      e500v2),
8616 80d11f44 j_mayer
    /* MPC8545 v2.0                                                          */
8617 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545_v20",
8618 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545_v20,  POWERPC_SVR_8545_v20,  e500v2),
8619 80d11f44 j_mayer
    /* MPC8545 v2.1                                                          */
8620 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545_v21",
8621 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545_v21,  POWERPC_SVR_8545_v21,  e500v2),
8622 80d11f44 j_mayer
    /* MPC8545E                                                              */
8623 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E",
8624 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545E,     POWERPC_SVR_8545E,     e500v2),
8625 80d11f44 j_mayer
    /* MPC8545E v2.0                                                         */
8626 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E_v20",
8627 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545E_v20, POWERPC_SVR_8545E_v20, e500v2),
8628 80d11f44 j_mayer
    /* MPC8545E v2.1                                                         */
8629 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8545E_v21",
8630 bd5ea513 aurel32
                    CPU_POWERPC_MPC8545E_v21, POWERPC_SVR_8545E_v21, e500v2),
8631 80d11f44 j_mayer
    /* MPC8547E                                                              */
8632 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E",
8633 bd5ea513 aurel32
                    CPU_POWERPC_MPC8547E,     POWERPC_SVR_8547E,     e500v2),
8634 80d11f44 j_mayer
    /* MPC8547E v2.0                                                         */
8635 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E_v20",
8636 bd5ea513 aurel32
                    CPU_POWERPC_MPC8547E_v20, POWERPC_SVR_8547E_v20, e500v2),
8637 80d11f44 j_mayer
    /* MPC8547E v2.1                                                         */
8638 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8547E_v21",
8639 bd5ea513 aurel32
                    CPU_POWERPC_MPC8547E_v21, POWERPC_SVR_8547E_v21, e500v2),
8640 80d11f44 j_mayer
    /* MPC8548                                                               */
8641 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548",
8642 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548,      POWERPC_SVR_8548,      e500v2),
8643 80d11f44 j_mayer
    /* MPC8548 v1.0                                                          */
8644 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v10",
8645 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v10,  POWERPC_SVR_8548_v10,  e500v2),
8646 80d11f44 j_mayer
    /* MPC8548 v1.1                                                          */
8647 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v11",
8648 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v11,  POWERPC_SVR_8548_v11,  e500v2),
8649 80d11f44 j_mayer
    /* MPC8548 v2.0                                                          */
8650 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v20",
8651 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v20,  POWERPC_SVR_8548_v20,  e500v2),
8652 80d11f44 j_mayer
    /* MPC8548 v2.1                                                          */
8653 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548_v21",
8654 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548_v21,  POWERPC_SVR_8548_v21,  e500v2),
8655 80d11f44 j_mayer
    /* MPC8548E                                                              */
8656 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E",
8657 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E,     POWERPC_SVR_8548E,     e500v2),
8658 80d11f44 j_mayer
    /* MPC8548E v1.0                                                         */
8659 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v10",
8660 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v10, POWERPC_SVR_8548E_v10, e500v2),
8661 80d11f44 j_mayer
    /* MPC8548E v1.1                                                         */
8662 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v11",
8663 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v11, POWERPC_SVR_8548E_v11, e500v2),
8664 80d11f44 j_mayer
    /* MPC8548E v2.0                                                         */
8665 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v20",
8666 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v20, POWERPC_SVR_8548E_v20, e500v2),
8667 80d11f44 j_mayer
    /* MPC8548E v2.1                                                         */
8668 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8548E_v21",
8669 bd5ea513 aurel32
                    CPU_POWERPC_MPC8548E_v21, POWERPC_SVR_8548E_v21, e500v2),
8670 80d11f44 j_mayer
    /* MPC8555                                                               */
8671 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555",
8672 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555,      POWERPC_SVR_8555,      e500v2),
8673 80d11f44 j_mayer
    /* MPC8555 v1.0                                                          */
8674 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555_v10",
8675 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555_v10,  POWERPC_SVR_8555_v10,  e500v2),
8676 80d11f44 j_mayer
    /* MPC8555 v1.1                                                          */
8677 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555_v11",
8678 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555_v11,  POWERPC_SVR_8555_v11,  e500v2),
8679 80d11f44 j_mayer
    /* MPC8555E                                                              */
8680 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E",
8681 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555E,     POWERPC_SVR_8555E,     e500v2),
8682 80d11f44 j_mayer
    /* MPC8555E v1.0                                                         */
8683 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E_v10",
8684 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555E_v10, POWERPC_SVR_8555E_v10, e500v2),
8685 80d11f44 j_mayer
    /* MPC8555E v1.1                                                         */
8686 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8555E_v11",
8687 bd5ea513 aurel32
                    CPU_POWERPC_MPC8555E_v11, POWERPC_SVR_8555E_v11, e500v2),
8688 80d11f44 j_mayer
    /* MPC8560                                                               */
8689 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560",
8690 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560,      POWERPC_SVR_8560,      e500v2),
8691 80d11f44 j_mayer
    /* MPC8560 v1.0                                                          */
8692 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v10",
8693 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560_v10,  POWERPC_SVR_8560_v10,  e500v2),
8694 80d11f44 j_mayer
    /* MPC8560 v2.0                                                          */
8695 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v20",
8696 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560_v20,  POWERPC_SVR_8560_v20,  e500v2),
8697 80d11f44 j_mayer
    /* MPC8560 v2.1                                                          */
8698 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8560_v21",
8699 bd5ea513 aurel32
                    CPU_POWERPC_MPC8560_v21,  POWERPC_SVR_8560_v21,  e500v2),
8700 80d11f44 j_mayer
    /* MPC8567                                                               */
8701 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8567",
8702 bd5ea513 aurel32
                    CPU_POWERPC_MPC8567,      POWERPC_SVR_8567,      e500v2),
8703 80d11f44 j_mayer
    /* MPC8567E                                                              */
8704 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8567E",
8705 bd5ea513 aurel32
                    CPU_POWERPC_MPC8567E,     POWERPC_SVR_8567E,     e500v2),
8706 80d11f44 j_mayer
    /* MPC8568                                                               */
8707 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8568",
8708 bd5ea513 aurel32
                    CPU_POWERPC_MPC8568,      POWERPC_SVR_8568,      e500v2),
8709 80d11f44 j_mayer
    /* MPC8568E                                                              */
8710 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8568E",
8711 bd5ea513 aurel32
                    CPU_POWERPC_MPC8568E,     POWERPC_SVR_8568E,     e500v2),
8712 80d11f44 j_mayer
    /* MPC8572                                                               */
8713 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8572",
8714 bd5ea513 aurel32
                    CPU_POWERPC_MPC8572,      POWERPC_SVR_8572,      e500v2),
8715 80d11f44 j_mayer
    /* MPC8572E                                                              */
8716 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8572E",
8717 bd5ea513 aurel32
                    CPU_POWERPC_MPC8572E,     POWERPC_SVR_8572E,     e500v2),
8718 80d11f44 j_mayer
    /* e600 family                                                           */
8719 80d11f44 j_mayer
    /* PowerPC e600 core                                                     */
8720 80d11f44 j_mayer
    POWERPC_DEF("e600",          CPU_POWERPC_e600,                   7400),
8721 80d11f44 j_mayer
    /* PowerPC e600 microcontrollers                                         */
8722 80d11f44 j_mayer
#if defined (TODO)
8723 80d11f44 j_mayer
    /* MPC8610                                                               */
8724 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8610",
8725 80d11f44 j_mayer
                    CPU_POWERPC_MPC8610,      POWERPC_SVR_8610,      7400),
8726 80d11f44 j_mayer
#endif
8727 80d11f44 j_mayer
    /* MPC8641                                                               */
8728 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8641",
8729 80d11f44 j_mayer
                    CPU_POWERPC_MPC8641,      POWERPC_SVR_8641,      7400),
8730 80d11f44 j_mayer
    /* MPC8641D                                                              */
8731 80d11f44 j_mayer
    POWERPC_DEF_SVR("MPC8641D",
8732 80d11f44 j_mayer
                    CPU_POWERPC_MPC8641D,     POWERPC_SVR_8641D,     7400),
8733 a750fc0b j_mayer
    /* 32 bits "classic" PowerPC                                             */
8734 a750fc0b j_mayer
    /* PowerPC 6xx family                                                    */
8735 a750fc0b j_mayer
    /* PowerPC 601                                                           */
8736 bd928eba j_mayer
    POWERPC_DEF("601",           CPU_POWERPC_601,                    601v),
8737 c3e36823 j_mayer
    /* PowerPC 601v0                                                         */
8738 082c6681 j_mayer
    POWERPC_DEF("601_v0",        CPU_POWERPC_601_v0,                 601),
8739 c3e36823 j_mayer
    /* PowerPC 601v1                                                         */
8740 082c6681 j_mayer
    POWERPC_DEF("601_v1",        CPU_POWERPC_601_v1,                 601),
8741 082c6681 j_mayer
    /* PowerPC 601v                                                          */
8742 bd928eba j_mayer
    POWERPC_DEF("601v",          CPU_POWERPC_601v,                   601v),
8743 a750fc0b j_mayer
    /* PowerPC 601v2                                                         */
8744 082c6681 j_mayer
    POWERPC_DEF("601_v2",        CPU_POWERPC_601_v2,                 601v),
8745 a750fc0b j_mayer
    /* PowerPC 602                                                           */
8746 80d11f44 j_mayer
    POWERPC_DEF("602",           CPU_POWERPC_602,                    602),
8747 a750fc0b j_mayer
    /* PowerPC 603                                                           */
8748 80d11f44 j_mayer
    POWERPC_DEF("603",           CPU_POWERPC_603,                    603),
8749 a750fc0b j_mayer
    /* Code name for PowerPC 603                                             */
8750 80d11f44 j_mayer
    POWERPC_DEF("Vanilla",       CPU_POWERPC_603,                    603),
8751 082c6681 j_mayer
    /* PowerPC 603e (aka PID6)                                               */
8752 80d11f44 j_mayer
    POWERPC_DEF("603e",          CPU_POWERPC_603E,                   603E),
8753 a750fc0b j_mayer
    /* Code name for PowerPC 603e                                            */
8754 80d11f44 j_mayer
    POWERPC_DEF("Stretch",       CPU_POWERPC_603E,                   603E),
8755 a750fc0b j_mayer
    /* PowerPC 603e v1.1                                                     */
8756 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.1",     CPU_POWERPC_603E_v11,               603E),
8757 a750fc0b j_mayer
    /* PowerPC 603e v1.2                                                     */
8758 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.2",     CPU_POWERPC_603E_v12,               603E),
8759 a750fc0b j_mayer
    /* PowerPC 603e v1.3                                                     */
8760 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.3",     CPU_POWERPC_603E_v13,               603E),
8761 a750fc0b j_mayer
    /* PowerPC 603e v1.4                                                     */
8762 80d11f44 j_mayer
    POWERPC_DEF("603e_v1.4",     CPU_POWERPC_603E_v14,               603E),
8763 a750fc0b j_mayer
    /* PowerPC 603e v2.2                                                     */
8764 80d11f44 j_mayer
    POWERPC_DEF("603e_v2.2",     CPU_POWERPC_603E_v22,               603E),
8765 a750fc0b j_mayer
    /* PowerPC 603e v3                                                       */
8766 80d11f44 j_mayer
    POWERPC_DEF("603e_v3",       CPU_POWERPC_603E_v3,                603E),
8767 a750fc0b j_mayer
    /* PowerPC 603e v4                                                       */
8768 80d11f44 j_mayer
    POWERPC_DEF("603e_v4",       CPU_POWERPC_603E_v4,                603E),
8769 a750fc0b j_mayer
    /* PowerPC 603e v4.1                                                     */
8770 80d11f44 j_mayer
    POWERPC_DEF("603e_v4.1",     CPU_POWERPC_603E_v41,               603E),
8771 082c6681 j_mayer
    /* PowerPC 603e (aka PID7)                                               */
8772 80d11f44 j_mayer
    POWERPC_DEF("603e7",         CPU_POWERPC_603E7,                  603E),
8773 a750fc0b j_mayer
    /* PowerPC 603e7t                                                        */
8774 80d11f44 j_mayer
    POWERPC_DEF("603e7t",        CPU_POWERPC_603E7t,                 603E),
8775 a750fc0b j_mayer
    /* PowerPC 603e7v                                                        */
8776 80d11f44 j_mayer
    POWERPC_DEF("603e7v",        CPU_POWERPC_603E7v,                 603E),
8777 a750fc0b j_mayer
    /* Code name for PowerPC 603ev                                           */
8778 80d11f44 j_mayer
    POWERPC_DEF("Vaillant",      CPU_POWERPC_603E7v,                 603E),
8779 a750fc0b j_mayer
    /* PowerPC 603e7v1                                                       */
8780 80d11f44 j_mayer
    POWERPC_DEF("603e7v1",       CPU_POWERPC_603E7v1,                603E),
8781 a750fc0b j_mayer
    /* PowerPC 603e7v2                                                       */
8782 80d11f44 j_mayer
    POWERPC_DEF("603e7v2",       CPU_POWERPC_603E7v2,                603E),
8783 082c6681 j_mayer
    /* PowerPC 603p (aka PID7v)                                              */
8784 082c6681 j_mayer
    POWERPC_DEF("603p",          CPU_POWERPC_603P,                   603E),
8785 082c6681 j_mayer
    /* PowerPC 603r (aka PID7t)                                              */
8786 80d11f44 j_mayer
    POWERPC_DEF("603r",          CPU_POWERPC_603R,                   603E),
8787 a750fc0b j_mayer
    /* Code name for PowerPC 603r                                            */
8788 80d11f44 j_mayer
    POWERPC_DEF("Goldeneye",     CPU_POWERPC_603R,                   603E),
8789 a750fc0b j_mayer
    /* PowerPC 604                                                           */
8790 80d11f44 j_mayer
    POWERPC_DEF("604",           CPU_POWERPC_604,                    604),
8791 082c6681 j_mayer
    /* PowerPC 604e (aka PID9)                                               */
8792 082c6681 j_mayer
    POWERPC_DEF("604e",          CPU_POWERPC_604E,                   604E),
8793 082c6681 j_mayer
    /* Code name for PowerPC 604e                                            */
8794 082c6681 j_mayer
    POWERPC_DEF("Sirocco",       CPU_POWERPC_604E,                   604E),
8795 a750fc0b j_mayer
    /* PowerPC 604e v1.0                                                     */
8796 082c6681 j_mayer
    POWERPC_DEF("604e_v1.0",     CPU_POWERPC_604E_v10,               604E),
8797 a750fc0b j_mayer
    /* PowerPC 604e v2.2                                                     */
8798 082c6681 j_mayer
    POWERPC_DEF("604e_v2.2",     CPU_POWERPC_604E_v22,               604E),
8799 a750fc0b j_mayer
    /* PowerPC 604e v2.4                                                     */
8800 082c6681 j_mayer
    POWERPC_DEF("604e_v2.4",     CPU_POWERPC_604E_v24,               604E),
8801 082c6681 j_mayer
    /* PowerPC 604r (aka PIDA)                                               */
8802 082c6681 j_mayer
    POWERPC_DEF("604r",          CPU_POWERPC_604R,                   604E),
8803 082c6681 j_mayer
    /* Code name for PowerPC 604r                                            */
8804 082c6681 j_mayer
    POWERPC_DEF("Mach5",         CPU_POWERPC_604R,                   604E),
8805 a750fc0b j_mayer
#if defined(TODO)
8806 a750fc0b j_mayer
    /* PowerPC 604ev                                                         */
8807 082c6681 j_mayer
    POWERPC_DEF("604ev",         CPU_POWERPC_604EV,                  604E),
8808 a750fc0b j_mayer
#endif
8809 a750fc0b j_mayer
    /* PowerPC 7xx family                                                    */
8810 a750fc0b j_mayer
    /* Generic PowerPC 740 (G3)                                              */
8811 bd928eba j_mayer
    POWERPC_DEF("740",           CPU_POWERPC_7x0,                    740),
8812 082c6681 j_mayer
    /* Code name for PowerPC 740                                             */
8813 bd928eba j_mayer
    POWERPC_DEF("Arthur",        CPU_POWERPC_7x0,                    740),
8814 a750fc0b j_mayer
    /* Generic PowerPC 750 (G3)                                              */
8815 bd928eba j_mayer
    POWERPC_DEF("750",           CPU_POWERPC_7x0,                    750),
8816 082c6681 j_mayer
    /* Code name for PowerPC 750                                             */
8817 bd928eba j_mayer
    POWERPC_DEF("Typhoon",       CPU_POWERPC_7x0,                    750),
8818 a750fc0b j_mayer
    /* PowerPC 740/750 is also known as G3                                   */
8819 bd928eba j_mayer
    POWERPC_DEF("G3",            CPU_POWERPC_7x0,                    750),
8820 bd928eba j_mayer
    /* PowerPC 740 v1.0 (G3)                                                 */
8821 bd928eba j_mayer
    POWERPC_DEF("740_v1.0",      CPU_POWERPC_7x0_v10,                740),
8822 bd928eba j_mayer
    /* PowerPC 750 v1.0 (G3)                                                 */
8823 bd928eba j_mayer
    POWERPC_DEF("750_v1.0",      CPU_POWERPC_7x0_v10,                750),
8824 a750fc0b j_mayer
    /* PowerPC 740 v2.0 (G3)                                                 */
8825 bd928eba j_mayer
    POWERPC_DEF("740_v2.0",      CPU_POWERPC_7x0_v20,                740),
8826 a750fc0b j_mayer
    /* PowerPC 750 v2.0 (G3)                                                 */
8827 bd928eba j_mayer
    POWERPC_DEF("750_v2.0",      CPU_POWERPC_7x0_v20,                750),
8828 a750fc0b j_mayer
    /* PowerPC 740 v2.1 (G3)                                                 */
8829 bd928eba j_mayer
    POWERPC_DEF("740_v2.1",      CPU_POWERPC_7x0_v21,                740),
8830 a750fc0b j_mayer
    /* PowerPC 750 v2.1 (G3)                                                 */
8831 bd928eba j_mayer
    POWERPC_DEF("750_v2.1",      CPU_POWERPC_7x0_v21,                750),
8832 a750fc0b j_mayer
    /* PowerPC 740 v2.2 (G3)                                                 */
8833 bd928eba j_mayer
    POWERPC_DEF("740_v2.2",      CPU_POWERPC_7x0_v22,                740),
8834 a750fc0b j_mayer
    /* PowerPC 750 v2.2 (G3)                                                 */
8835 bd928eba j_mayer
    POWERPC_DEF("750_v2.2",      CPU_POWERPC_7x0_v22,                750),
8836 a750fc0b j_mayer
    /* PowerPC 740 v3.0 (G3)                                                 */
8837 bd928eba j_mayer
    POWERPC_DEF("740_v3.0",      CPU_POWERPC_7x0_v30,                740),
8838 a750fc0b j_mayer
    /* PowerPC 750 v3.0 (G3)                                                 */
8839 bd928eba j_mayer
    POWERPC_DEF("750_v3.0",      CPU_POWERPC_7x0_v30,                750),
8840 a750fc0b j_mayer
    /* PowerPC 740 v3.1 (G3)                                                 */
8841 bd928eba j_mayer
    POWERPC_DEF("740_v3.1",      CPU_POWERPC_7x0_v31,                740),
8842 a750fc0b j_mayer
    /* PowerPC 750 v3.1 (G3)                                                 */
8843 bd928eba j_mayer
    POWERPC_DEF("750_v3.1",      CPU_POWERPC_7x0_v31,                750),
8844 a750fc0b j_mayer
    /* PowerPC 740E (G3)                                                     */
8845 bd928eba j_mayer
    POWERPC_DEF("740e",          CPU_POWERPC_740E,                   740),
8846 bd928eba j_mayer
    /* PowerPC 750E (G3)                                                     */
8847 bd928eba j_mayer
    POWERPC_DEF("750e",          CPU_POWERPC_750E,                   750),
8848 a750fc0b j_mayer
    /* PowerPC 740P (G3)                                                     */
8849 bd928eba j_mayer
    POWERPC_DEF("740p",          CPU_POWERPC_7x0P,                   740),
8850 a750fc0b j_mayer
    /* PowerPC 750P (G3)                                                     */
8851 bd928eba j_mayer
    POWERPC_DEF("750p",          CPU_POWERPC_7x0P,                   750),
8852 a750fc0b j_mayer
    /* Code name for PowerPC 740P/750P (G3)                                  */
8853 bd928eba j_mayer
    POWERPC_DEF("Conan/Doyle",   CPU_POWERPC_7x0P,                   750),
8854 a750fc0b j_mayer
    /* PowerPC 750CL (G3 embedded)                                           */
8855 bd928eba j_mayer
    POWERPC_DEF("750cl",         CPU_POWERPC_750CL,                  750cl),
8856 bd928eba j_mayer
    /* PowerPC 750CL v1.0                                                    */
8857 bd928eba j_mayer
    POWERPC_DEF("750cl_v1.0",    CPU_POWERPC_750CL_v10,              750cl),
8858 bd928eba j_mayer
    /* PowerPC 750CL v2.0                                                    */
8859 bd928eba j_mayer
    POWERPC_DEF("750cl_v2.0",    CPU_POWERPC_750CL_v20,              750cl),
8860 a750fc0b j_mayer
    /* PowerPC 750CX (G3 embedded)                                           */
8861 bd928eba j_mayer
    POWERPC_DEF("750cx",         CPU_POWERPC_750CX,                  750cx),
8862 bd928eba j_mayer
    /* PowerPC 750CX v1.0 (G3 embedded)                                      */
8863 bd928eba j_mayer
    POWERPC_DEF("750cx_v1.0",    CPU_POWERPC_750CX_v10,              750cx),
8864 bd928eba j_mayer
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
8865 bd928eba j_mayer
    POWERPC_DEF("750cx_v2.0",    CPU_POWERPC_750CX_v20,              750cx),
8866 a750fc0b j_mayer
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
8867 bd928eba j_mayer
    POWERPC_DEF("750cx_v2.1",    CPU_POWERPC_750CX_v21,              750cx),
8868 a750fc0b j_mayer
    /* PowerPC 750CX v2.2 (G3 embedded)                                      */
8869 bd928eba j_mayer
    POWERPC_DEF("750cx_v2.2",    CPU_POWERPC_750CX_v22,              750cx),
8870 a750fc0b j_mayer
    /* PowerPC 750CXe (G3 embedded)                                          */
8871 bd928eba j_mayer
    POWERPC_DEF("750cxe",        CPU_POWERPC_750CXE,                 750cx),
8872 a750fc0b j_mayer
    /* PowerPC 750CXe v2.1 (G3 embedded)                                     */
8873 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.1",   CPU_POWERPC_750CXE_v21,             750cx),
8874 a750fc0b j_mayer
    /* PowerPC 750CXe v2.2 (G3 embedded)                                     */
8875 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.2",   CPU_POWERPC_750CXE_v22,             750cx),
8876 a750fc0b j_mayer
    /* PowerPC 750CXe v2.3 (G3 embedded)                                     */
8877 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.3",   CPU_POWERPC_750CXE_v23,             750cx),
8878 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4 (G3 embedded)                                     */
8879 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.4",   CPU_POWERPC_750CXE_v24,             750cx),
8880 a750fc0b j_mayer
    /* PowerPC 750CXe v2.4b (G3 embedded)                                    */
8881 bd928eba j_mayer
    POWERPC_DEF("750cxe_v2.4b",  CPU_POWERPC_750CXE_v24b,            750cx),
8882 bd928eba j_mayer
    /* PowerPC 750CXe v3.0 (G3 embedded)                                     */
8883 bd928eba j_mayer
    POWERPC_DEF("750cxe_v3.0",   CPU_POWERPC_750CXE_v30,             750cx),
8884 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1 (G3 embedded)                                     */
8885 bd928eba j_mayer
    POWERPC_DEF("750cxe_v3.1",   CPU_POWERPC_750CXE_v31,             750cx),
8886 a750fc0b j_mayer
    /* PowerPC 750CXe v3.1b (G3 embedded)                                    */
8887 bd928eba j_mayer
    POWERPC_DEF("750cxe_v3.1b",  CPU_POWERPC_750CXE_v31b,            750cx),
8888 a750fc0b j_mayer
    /* PowerPC 750CXr (G3 embedded)                                          */
8889 bd928eba j_mayer
    POWERPC_DEF("750cxr",        CPU_POWERPC_750CXR,                 750cx),
8890 a750fc0b j_mayer
    /* PowerPC 750FL (G3 embedded)                                           */
8891 80d11f44 j_mayer
    POWERPC_DEF("750fl",         CPU_POWERPC_750FL,                  750fx),
8892 a750fc0b j_mayer
    /* PowerPC 750FX (G3 embedded)                                           */
8893 80d11f44 j_mayer
    POWERPC_DEF("750fx",         CPU_POWERPC_750FX,                  750fx),
8894 a750fc0b j_mayer
    /* PowerPC 750FX v1.0 (G3 embedded)                                      */
8895 80d11f44 j_mayer
    POWERPC_DEF("750fx_v1.0",    CPU_POWERPC_750FX_v10,              750fx),
8896 a750fc0b j_mayer
    /* PowerPC 750FX v2.0 (G3 embedded)                                      */
8897 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.0",    CPU_POWERPC_750FX_v20,              750fx),
8898 a750fc0b j_mayer
    /* PowerPC 750FX v2.1 (G3 embedded)                                      */
8899 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.1",    CPU_POWERPC_750FX_v21,              750fx),
8900 a750fc0b j_mayer
    /* PowerPC 750FX v2.2 (G3 embedded)                                      */
8901 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.2",    CPU_POWERPC_750FX_v22,              750fx),
8902 a750fc0b j_mayer
    /* PowerPC 750FX v2.3 (G3 embedded)                                      */
8903 80d11f44 j_mayer
    POWERPC_DEF("750fx_v2.3",    CPU_POWERPC_750FX_v23,              750fx),
8904 a750fc0b j_mayer
    /* PowerPC 750GL (G3 embedded)                                           */
8905 bd928eba j_mayer
    POWERPC_DEF("750gl",         CPU_POWERPC_750GL,                  750gx),
8906 a750fc0b j_mayer
    /* PowerPC 750GX (G3 embedded)                                           */
8907 bd928eba j_mayer
    POWERPC_DEF("750gx",         CPU_POWERPC_750GX,                  750gx),
8908 a750fc0b j_mayer
    /* PowerPC 750GX v1.0 (G3 embedded)                                      */
8909 bd928eba j_mayer
    POWERPC_DEF("750gx_v1.0",    CPU_POWERPC_750GX_v10,              750gx),
8910 a750fc0b j_mayer
    /* PowerPC 750GX v1.1 (G3 embedded)                                      */
8911 bd928eba j_mayer
    POWERPC_DEF("750gx_v1.1",    CPU_POWERPC_750GX_v11,              750gx),
8912 a750fc0b j_mayer
    /* PowerPC 750GX v1.2 (G3 embedded)                                      */
8913 bd928eba j_mayer
    POWERPC_DEF("750gx_v1.2",    CPU_POWERPC_750GX_v12,              750gx),
8914 a750fc0b j_mayer
    /* PowerPC 750L (G3 embedded)                                            */
8915 bd928eba j_mayer
    POWERPC_DEF("750l",          CPU_POWERPC_750L,                   750),
8916 a750fc0b j_mayer
    /* Code name for PowerPC 750L (G3 embedded)                              */
8917 bd928eba j_mayer
    POWERPC_DEF("LoneStar",      CPU_POWERPC_750L,                   750),
8918 bd928eba j_mayer
    /* PowerPC 750L v2.0 (G3 embedded)                                       */
8919 bd928eba j_mayer
    POWERPC_DEF("750l_v2.0",     CPU_POWERPC_750L_v20,               750),
8920 bd928eba j_mayer
    /* PowerPC 750L v2.1 (G3 embedded)                                       */
8921 bd928eba j_mayer
    POWERPC_DEF("750l_v2.1",     CPU_POWERPC_750L_v21,               750),
8922 a750fc0b j_mayer
    /* PowerPC 750L v2.2 (G3 embedded)                                       */
8923 bd928eba j_mayer
    POWERPC_DEF("750l_v2.2",     CPU_POWERPC_750L_v22,               750),
8924 a750fc0b j_mayer
    /* PowerPC 750L v3.0 (G3 embedded)                                       */
8925 bd928eba j_mayer
    POWERPC_DEF("750l_v3.0",     CPU_POWERPC_750L_v30,               750),
8926 a750fc0b j_mayer
    /* PowerPC 750L v3.2 (G3 embedded)                                       */
8927 bd928eba j_mayer
    POWERPC_DEF("750l_v3.2",     CPU_POWERPC_750L_v32,               750),
8928 a750fc0b j_mayer
    /* Generic PowerPC 745                                                   */
8929 bd928eba j_mayer
    POWERPC_DEF("745",           CPU_POWERPC_7x5,                    745),
8930 a750fc0b j_mayer
    /* Generic PowerPC 755                                                   */
8931 bd928eba j_mayer
    POWERPC_DEF("755",           CPU_POWERPC_7x5,                    755),
8932 a750fc0b j_mayer
    /* Code name for PowerPC 745/755                                         */
8933 bd928eba j_mayer
    POWERPC_DEF("Goldfinger",    CPU_POWERPC_7x5,                    755),
8934 a750fc0b j_mayer
    /* PowerPC 745 v1.0                                                      */
8935 bd928eba j_mayer
    POWERPC_DEF("745_v1.0",      CPU_POWERPC_7x5_v10,                745),
8936 a750fc0b j_mayer
    /* PowerPC 755 v1.0                                                      */
8937 bd928eba j_mayer
    POWERPC_DEF("755_v1.0",      CPU_POWERPC_7x5_v10,                755),
8938 a750fc0b j_mayer
    /* PowerPC 745 v1.1                                                      */
8939 bd928eba j_mayer
    POWERPC_DEF("745_v1.1",      CPU_POWERPC_7x5_v11,                745),
8940 a750fc0b j_mayer
    /* PowerPC 755 v1.1                                                      */
8941 bd928eba j_mayer
    POWERPC_DEF("755_v1.1",      CPU_POWERPC_7x5_v11,                755),
8942 a750fc0b j_mayer
    /* PowerPC 745 v2.0                                                      */
8943 bd928eba j_mayer
    POWERPC_DEF("745_v2.0",      CPU_POWERPC_7x5_v20,                745),
8944 a750fc0b j_mayer
    /* PowerPC 755 v2.0                                                      */
8945 bd928eba j_mayer
    POWERPC_DEF("755_v2.0",      CPU_POWERPC_7x5_v20,                755),
8946 a750fc0b j_mayer
    /* PowerPC 745 v2.1                                                      */
8947 bd928eba j_mayer
    POWERPC_DEF("745_v2.1",      CPU_POWERPC_7x5_v21,                745),
8948 a750fc0b j_mayer
    /* PowerPC 755 v2.1                                                      */
8949 bd928eba j_mayer
    POWERPC_DEF("755_v2.1",      CPU_POWERPC_7x5_v21,                755),
8950 a750fc0b j_mayer
    /* PowerPC 745 v2.2                                                      */
8951 bd928eba j_mayer
    POWERPC_DEF("745_v2.2",      CPU_POWERPC_7x5_v22,                745),
8952 a750fc0b j_mayer
    /* PowerPC 755 v2.2                                                      */
8953 bd928eba j_mayer
    POWERPC_DEF("755_v2.2",      CPU_POWERPC_7x5_v22,                755),
8954 a750fc0b j_mayer
    /* PowerPC 745 v2.3                                                      */
8955 bd928eba j_mayer
    POWERPC_DEF("745_v2.3",      CPU_POWERPC_7x5_v23,                745),
8956 a750fc0b j_mayer
    /* PowerPC 755 v2.3                                                      */
8957 bd928eba j_mayer
    POWERPC_DEF("755_v2.3",      CPU_POWERPC_7x5_v23,                755),
8958 a750fc0b j_mayer
    /* PowerPC 745 v2.4                                                      */
8959 bd928eba j_mayer
    POWERPC_DEF("745_v2.4",      CPU_POWERPC_7x5_v24,                745),
8960 a750fc0b j_mayer
    /* PowerPC 755 v2.4                                                      */
8961 bd928eba j_mayer
    POWERPC_DEF("755_v2.4",      CPU_POWERPC_7x5_v24,                755),
8962 a750fc0b j_mayer
    /* PowerPC 745 v2.5                                                      */
8963 bd928eba j_mayer
    POWERPC_DEF("745_v2.5",      CPU_POWERPC_7x5_v25,                745),
8964 a750fc0b j_mayer
    /* PowerPC 755 v2.5                                                      */
8965 bd928eba j_mayer
    POWERPC_DEF("755_v2.5",      CPU_POWERPC_7x5_v25,                755),
8966 a750fc0b j_mayer
    /* PowerPC 745 v2.6                                                      */
8967 bd928eba j_mayer
    POWERPC_DEF("745_v2.6",      CPU_POWERPC_7x5_v26,                745),
8968 a750fc0b j_mayer
    /* PowerPC 755 v2.6                                                      */
8969 bd928eba j_mayer
    POWERPC_DEF("755_v2.6",      CPU_POWERPC_7x5_v26,                755),
8970 a750fc0b j_mayer
    /* PowerPC 745 v2.7                                                      */
8971 bd928eba j_mayer
    POWERPC_DEF("745_v2.7",      CPU_POWERPC_7x5_v27,                745),
8972 a750fc0b j_mayer
    /* PowerPC 755 v2.7                                                      */
8973 bd928eba j_mayer
    POWERPC_DEF("755_v2.7",      CPU_POWERPC_7x5_v27,                755),
8974 a750fc0b j_mayer
    /* PowerPC 745 v2.8                                                      */
8975 bd928eba j_mayer
    POWERPC_DEF("745_v2.8",      CPU_POWERPC_7x5_v28,                745),
8976 a750fc0b j_mayer
    /* PowerPC 755 v2.8                                                      */
8977 bd928eba j_mayer
    POWERPC_DEF("755_v2.8",      CPU_POWERPC_7x5_v28,                755),
8978 a750fc0b j_mayer
#if defined (TODO)
8979 a750fc0b j_mayer
    /* PowerPC 745P (G3)                                                     */
8980 bd928eba j_mayer
    POWERPC_DEF("745p",          CPU_POWERPC_7x5P,                   745),
8981 a750fc0b j_mayer
    /* PowerPC 755P (G3)                                                     */
8982 bd928eba j_mayer
    POWERPC_DEF("755p",          CPU_POWERPC_7x5P,                   755),
8983 a750fc0b j_mayer
#endif
8984 a750fc0b j_mayer
    /* PowerPC 74xx family                                                   */
8985 a750fc0b j_mayer
    /* PowerPC 7400 (G4)                                                     */
8986 80d11f44 j_mayer
    POWERPC_DEF("7400",          CPU_POWERPC_7400,                   7400),
8987 a750fc0b j_mayer
    /* Code name for PowerPC 7400                                            */
8988 80d11f44 j_mayer
    POWERPC_DEF("Max",           CPU_POWERPC_7400,                   7400),
8989 a750fc0b j_mayer
    /* PowerPC 74xx is also well known as G4                                 */
8990 80d11f44 j_mayer
    POWERPC_DEF("G4",            CPU_POWERPC_7400,                   7400),
8991 a750fc0b j_mayer
    /* PowerPC 7400 v1.0 (G4)                                                */
8992 80d11f44 j_mayer
    POWERPC_DEF("7400_v1.0",     CPU_POWERPC_7400_v10,               7400),
8993 a750fc0b j_mayer
    /* PowerPC 7400 v1.1 (G4)                                                */
8994 80d11f44 j_mayer
    POWERPC_DEF("7400_v1.1",     CPU_POWERPC_7400_v11,               7400),
8995 a750fc0b j_mayer
    /* PowerPC 7400 v2.0 (G4)                                                */
8996 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.0",     CPU_POWERPC_7400_v20,               7400),
8997 4e777442 j_mayer
    /* PowerPC 7400 v2.1 (G4)                                                */
8998 4e777442 j_mayer
    POWERPC_DEF("7400_v2.1",     CPU_POWERPC_7400_v21,               7400),
8999 a750fc0b j_mayer
    /* PowerPC 7400 v2.2 (G4)                                                */
9000 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.2",     CPU_POWERPC_7400_v22,               7400),
9001 a750fc0b j_mayer
    /* PowerPC 7400 v2.6 (G4)                                                */
9002 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.6",     CPU_POWERPC_7400_v26,               7400),
9003 a750fc0b j_mayer
    /* PowerPC 7400 v2.7 (G4)                                                */
9004 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.7",     CPU_POWERPC_7400_v27,               7400),
9005 a750fc0b j_mayer
    /* PowerPC 7400 v2.8 (G4)                                                */
9006 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.8",     CPU_POWERPC_7400_v28,               7400),
9007 a750fc0b j_mayer
    /* PowerPC 7400 v2.9 (G4)                                                */
9008 80d11f44 j_mayer
    POWERPC_DEF("7400_v2.9",     CPU_POWERPC_7400_v29,               7400),
9009 a750fc0b j_mayer
    /* PowerPC 7410 (G4)                                                     */
9010 80d11f44 j_mayer
    POWERPC_DEF("7410",          CPU_POWERPC_7410,                   7410),
9011 a750fc0b j_mayer
    /* Code name for PowerPC 7410                                            */
9012 80d11f44 j_mayer
    POWERPC_DEF("Nitro",         CPU_POWERPC_7410,                   7410),
9013 a750fc0b j_mayer
    /* PowerPC 7410 v1.0 (G4)                                                */
9014 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.0",     CPU_POWERPC_7410_v10,               7410),
9015 a750fc0b j_mayer
    /* PowerPC 7410 v1.1 (G4)                                                */
9016 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.1",     CPU_POWERPC_7410_v11,               7410),
9017 a750fc0b j_mayer
    /* PowerPC 7410 v1.2 (G4)                                                */
9018 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.2",     CPU_POWERPC_7410_v12,               7410),
9019 a750fc0b j_mayer
    /* PowerPC 7410 v1.3 (G4)                                                */
9020 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.3",     CPU_POWERPC_7410_v13,               7410),
9021 a750fc0b j_mayer
    /* PowerPC 7410 v1.4 (G4)                                                */
9022 80d11f44 j_mayer
    POWERPC_DEF("7410_v1.4",     CPU_POWERPC_7410_v14,               7410),
9023 a750fc0b j_mayer
    /* PowerPC 7448 (G4)                                                     */
9024 80d11f44 j_mayer
    POWERPC_DEF("7448",          CPU_POWERPC_7448,                   7400),
9025 a750fc0b j_mayer
    /* PowerPC 7448 v1.0 (G4)                                                */
9026 80d11f44 j_mayer
    POWERPC_DEF("7448_v1.0",     CPU_POWERPC_7448_v10,               7400),
9027 a750fc0b j_mayer
    /* PowerPC 7448 v1.1 (G4)                                                */
9028 80d11f44 j_mayer
    POWERPC_DEF("7448_v1.1",     CPU_POWERPC_7448_v11,               7400),
9029 a750fc0b j_mayer
    /* PowerPC 7448 v2.0 (G4)                                                */
9030 80d11f44 j_mayer
    POWERPC_DEF("7448_v2.0",     CPU_POWERPC_7448_v20,               7400),
9031 a750fc0b j_mayer
    /* PowerPC 7448 v2.1 (G4)                                                */
9032 80d11f44 j_mayer
    POWERPC_DEF("7448_v2.1",     CPU_POWERPC_7448_v21,               7400),
9033 a750fc0b j_mayer
    /* PowerPC 7450 (G4)                                                     */
9034 80d11f44 j_mayer
    POWERPC_DEF("7450",          CPU_POWERPC_7450,                   7450),
9035 a750fc0b j_mayer
    /* Code name for PowerPC 7450                                            */
9036 80d11f44 j_mayer
    POWERPC_DEF("Vger",          CPU_POWERPC_7450,                   7450),
9037 a750fc0b j_mayer
    /* PowerPC 7450 v1.0 (G4)                                                */
9038 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.0",     CPU_POWERPC_7450_v10,               7450),
9039 a750fc0b j_mayer
    /* PowerPC 7450 v1.1 (G4)                                                */
9040 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.1",     CPU_POWERPC_7450_v11,               7450),
9041 a750fc0b j_mayer
    /* PowerPC 7450 v1.2 (G4)                                                */
9042 80d11f44 j_mayer
    POWERPC_DEF("7450_v1.2",     CPU_POWERPC_7450_v12,               7450),
9043 a750fc0b j_mayer
    /* PowerPC 7450 v2.0 (G4)                                                */
9044 80d11f44 j_mayer
    POWERPC_DEF("7450_v2.0",     CPU_POWERPC_7450_v20,               7450),
9045 a750fc0b j_mayer
    /* PowerPC 7450 v2.1 (G4)                                                */
9046 80d11f44 j_mayer
    POWERPC_DEF("7450_v2.1",     CPU_POWERPC_7450_v21,               7450),
9047 a750fc0b j_mayer
    /* PowerPC 7441 (G4)                                                     */
9048 80d11f44 j_mayer
    POWERPC_DEF("7441",          CPU_POWERPC_74x1,                   7440),
9049 a750fc0b j_mayer
    /* PowerPC 7451 (G4)                                                     */
9050 80d11f44 j_mayer
    POWERPC_DEF("7451",          CPU_POWERPC_74x1,                   7450),
9051 4e777442 j_mayer
    /* PowerPC 7441 v2.1 (G4)                                                */
9052 4e777442 j_mayer
    POWERPC_DEF("7441_v2.1",     CPU_POWERPC_7450_v21,               7440),
9053 4e777442 j_mayer
    /* PowerPC 7441 v2.3 (G4)                                                */
9054 4e777442 j_mayer
    POWERPC_DEF("7441_v2.3",     CPU_POWERPC_74x1_v23,               7440),
9055 4e777442 j_mayer
    /* PowerPC 7451 v2.3 (G4)                                                */
9056 4e777442 j_mayer
    POWERPC_DEF("7451_v2.3",     CPU_POWERPC_74x1_v23,               7450),
9057 4e777442 j_mayer
    /* PowerPC 7441 v2.10 (G4)                                                */
9058 4e777442 j_mayer
    POWERPC_DEF("7441_v2.10",    CPU_POWERPC_74x1_v210,              7440),
9059 4e777442 j_mayer
    /* PowerPC 7451 v2.10 (G4)                                               */
9060 4e777442 j_mayer
    POWERPC_DEF("7451_v2.10",    CPU_POWERPC_74x1_v210,              7450),
9061 a750fc0b j_mayer
    /* PowerPC 7445 (G4)                                                     */
9062 80d11f44 j_mayer
    POWERPC_DEF("7445",          CPU_POWERPC_74x5,                   7445),
9063 a750fc0b j_mayer
    /* PowerPC 7455 (G4)                                                     */
9064 80d11f44 j_mayer
    POWERPC_DEF("7455",          CPU_POWERPC_74x5,                   7455),
9065 a750fc0b j_mayer
    /* Code name for PowerPC 7445/7455                                       */
9066 80d11f44 j_mayer
    POWERPC_DEF("Apollo6",       CPU_POWERPC_74x5,                   7455),
9067 a750fc0b j_mayer
    /* PowerPC 7445 v1.0 (G4)                                                */
9068 80d11f44 j_mayer
    POWERPC_DEF("7445_v1.0",     CPU_POWERPC_74x5_v10,               7445),
9069 a750fc0b j_mayer
    /* PowerPC 7455 v1.0 (G4)                                                */
9070 80d11f44 j_mayer
    POWERPC_DEF("7455_v1.0",     CPU_POWERPC_74x5_v10,               7455),
9071 a750fc0b j_mayer
    /* PowerPC 7445 v2.1 (G4)                                                */
9072 80d11f44 j_mayer
    POWERPC_DEF("7445_v2.1",     CPU_POWERPC_74x5_v21,               7445),
9073 a750fc0b j_mayer
    /* PowerPC 7455 v2.1 (G4)                                                */
9074 80d11f44 j_mayer
    POWERPC_DEF("7455_v2.1",     CPU_POWERPC_74x5_v21,               7455),
9075 a750fc0b j_mayer
    /* PowerPC 7445 v3.2 (G4)                                                */
9076 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.2",     CPU_POWERPC_74x5_v32,               7445),
9077 a750fc0b j_mayer
    /* PowerPC 7455 v3.2 (G4)                                                */
9078 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.2",     CPU_POWERPC_74x5_v32,               7455),
9079 a750fc0b j_mayer
    /* PowerPC 7445 v3.3 (G4)                                                */
9080 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.3",     CPU_POWERPC_74x5_v33,               7445),
9081 a750fc0b j_mayer
    /* PowerPC 7455 v3.3 (G4)                                                */
9082 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.3",     CPU_POWERPC_74x5_v33,               7455),
9083 a750fc0b j_mayer
    /* PowerPC 7445 v3.4 (G4)                                                */
9084 80d11f44 j_mayer
    POWERPC_DEF("7445_v3.4",     CPU_POWERPC_74x5_v34,               7445),
9085 a750fc0b j_mayer
    /* PowerPC 7455 v3.4 (G4)                                                */
9086 80d11f44 j_mayer
    POWERPC_DEF("7455_v3.4",     CPU_POWERPC_74x5_v34,               7455),
9087 a750fc0b j_mayer
    /* PowerPC 7447 (G4)                                                     */
9088 80d11f44 j_mayer
    POWERPC_DEF("7447",          CPU_POWERPC_74x7,                   7445),
9089 a750fc0b j_mayer
    /* PowerPC 7457 (G4)                                                     */
9090 80d11f44 j_mayer
    POWERPC_DEF("7457",          CPU_POWERPC_74x7,                   7455),
9091 a750fc0b j_mayer
    /* Code name for PowerPC 7447/7457                                       */
9092 80d11f44 j_mayer
    POWERPC_DEF("Apollo7",       CPU_POWERPC_74x7,                   7455),
9093 a750fc0b j_mayer
    /* PowerPC 7447 v1.0 (G4)                                                */
9094 80d11f44 j_mayer
    POWERPC_DEF("7447_v1.0",     CPU_POWERPC_74x7_v10,               7445),
9095 a750fc0b j_mayer
    /* PowerPC 7457 v1.0 (G4)                                                */
9096 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.0",     CPU_POWERPC_74x7_v10,               7455),
9097 a750fc0b j_mayer
    /* PowerPC 7447 v1.1 (G4)                                                */
9098 80d11f44 j_mayer
    POWERPC_DEF("7447_v1.1",     CPU_POWERPC_74x7_v11,               7445),
9099 a750fc0b j_mayer
    /* PowerPC 7457 v1.1 (G4)                                                */
9100 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.1",     CPU_POWERPC_74x7_v11,               7455),
9101 a750fc0b j_mayer
    /* PowerPC 7457 v1.2 (G4)                                                */
9102 80d11f44 j_mayer
    POWERPC_DEF("7457_v1.2",     CPU_POWERPC_74x7_v12,               7455),
9103 082c6681 j_mayer
    /* PowerPC 7447A (G4)                                                    */
9104 082c6681 j_mayer
    POWERPC_DEF("7447A",         CPU_POWERPC_74x7A,                  7445),
9105 082c6681 j_mayer
    /* PowerPC 7457A (G4)                                                    */
9106 082c6681 j_mayer
    POWERPC_DEF("7457A",         CPU_POWERPC_74x7A,                  7455),
9107 082c6681 j_mayer
    /* PowerPC 7447A v1.0 (G4)                                               */
9108 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.0",    CPU_POWERPC_74x7A_v10,              7445),
9109 082c6681 j_mayer
    /* PowerPC 7457A v1.0 (G4)                                               */
9110 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.0",    CPU_POWERPC_74x7A_v10,              7455),
9111 082c6681 j_mayer
    /* Code name for PowerPC 7447A/7457A                                     */
9112 082c6681 j_mayer
    POWERPC_DEF("Apollo7PM",     CPU_POWERPC_74x7A_v10,              7455),
9113 082c6681 j_mayer
    /* PowerPC 7447A v1.1 (G4)                                               */
9114 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.1",    CPU_POWERPC_74x7A_v11,              7445),
9115 082c6681 j_mayer
    /* PowerPC 7457A v1.1 (G4)                                               */
9116 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.1",    CPU_POWERPC_74x7A_v11,              7455),
9117 082c6681 j_mayer
    /* PowerPC 7447A v1.2 (G4)                                               */
9118 082c6681 j_mayer
    POWERPC_DEF("7447A_v1.2",    CPU_POWERPC_74x7A_v12,              7445),
9119 082c6681 j_mayer
    /* PowerPC 7457A v1.2 (G4)                                               */
9120 082c6681 j_mayer
    POWERPC_DEF("7457A_v1.2",    CPU_POWERPC_74x7A_v12,              7455),
9121 a750fc0b j_mayer
    /* 64 bits PowerPC                                                       */
9122 a750fc0b j_mayer
#if defined (TARGET_PPC64)
9123 a750fc0b j_mayer
    /* PowerPC 620                                                           */
9124 80d11f44 j_mayer
    POWERPC_DEF("620",           CPU_POWERPC_620,                    620),
9125 082c6681 j_mayer
    /* Code name for PowerPC 620                                             */
9126 082c6681 j_mayer
    POWERPC_DEF("Trident",       CPU_POWERPC_620,                    620),
9127 3fc6c082 bellard
#if defined (TODO)
9128 a750fc0b j_mayer
    /* PowerPC 630 (POWER3)                                                  */
9129 80d11f44 j_mayer
    POWERPC_DEF("630",           CPU_POWERPC_630,                    630),
9130 80d11f44 j_mayer
    POWERPC_DEF("POWER3",        CPU_POWERPC_630,                    630),
9131 082c6681 j_mayer
    /* Code names for POWER3                                                 */
9132 082c6681 j_mayer
    POWERPC_DEF("Boxer",         CPU_POWERPC_630,                    630),
9133 082c6681 j_mayer
    POWERPC_DEF("Dino",          CPU_POWERPC_630,                    630),
9134 a750fc0b j_mayer
#endif
9135 3a607854 j_mayer
#if defined (TODO)
9136 a750fc0b j_mayer
    /* PowerPC 631 (Power 3+)                                                */
9137 80d11f44 j_mayer
    POWERPC_DEF("631",           CPU_POWERPC_631,                    631),
9138 80d11f44 j_mayer
    POWERPC_DEF("POWER3+",       CPU_POWERPC_631,                    631),
9139 3a607854 j_mayer
#endif
9140 3a607854 j_mayer
#if defined (TODO)
9141 a750fc0b j_mayer
    /* POWER4                                                                */
9142 80d11f44 j_mayer
    POWERPC_DEF("POWER4",        CPU_POWERPC_POWER4,                 POWER4),
9143 a750fc0b j_mayer
#endif
9144 3a607854 j_mayer
#if defined (TODO)
9145 a750fc0b j_mayer
    /* POWER4p                                                               */
9146 80d11f44 j_mayer
    POWERPC_DEF("POWER4+",       CPU_POWERPC_POWER4P,                POWER4P),
9147 a750fc0b j_mayer
#endif
9148 3a607854 j_mayer
#if defined (TODO)
9149 a750fc0b j_mayer
    /* POWER5                                                                */
9150 80d11f44 j_mayer
    POWERPC_DEF("POWER5",        CPU_POWERPC_POWER5,                 POWER5),
9151 a750fc0b j_mayer
    /* POWER5GR                                                              */
9152 80d11f44 j_mayer
    POWERPC_DEF("POWER5gr",      CPU_POWERPC_POWER5GR,               POWER5),
9153 2662a059 j_mayer
#endif
9154 2662a059 j_mayer
#if defined (TODO)
9155 a750fc0b j_mayer
    /* POWER5+                                                               */
9156 80d11f44 j_mayer
    POWERPC_DEF("POWER5+",       CPU_POWERPC_POWER5P,                POWER5P),
9157 a750fc0b j_mayer
    /* POWER5GS                                                              */
9158 80d11f44 j_mayer
    POWERPC_DEF("POWER5gs",      CPU_POWERPC_POWER5GS,               POWER5P),
9159 a750fc0b j_mayer
#endif
9160 2662a059 j_mayer
#if defined (TODO)
9161 a750fc0b j_mayer
    /* POWER6                                                                */
9162 80d11f44 j_mayer
    POWERPC_DEF("POWER6",        CPU_POWERPC_POWER6,                 POWER6),
9163 a750fc0b j_mayer
    /* POWER6 running in POWER5 mode                                         */
9164 80d11f44 j_mayer
    POWERPC_DEF("POWER6_5",      CPU_POWERPC_POWER6_5,               POWER5),
9165 a750fc0b j_mayer
    /* POWER6A                                                               */
9166 80d11f44 j_mayer
    POWERPC_DEF("POWER6A",       CPU_POWERPC_POWER6A,                POWER6),
9167 2662a059 j_mayer
#endif
9168 9d52e907 David Gibson
    /* POWER7                                                                */
9169 9d52e907 David Gibson
    POWERPC_DEF("POWER7",        CPU_POWERPC_POWER7,                 POWER7),
9170 9d52e907 David Gibson
    POWERPC_DEF("POWER7_v2.0",   CPU_POWERPC_POWER7_v20,             POWER7),
9171 37e305ce David Gibson
    POWERPC_DEF("POWER7_v2.1",   CPU_POWERPC_POWER7_v21,             POWER7),
9172 37e305ce David Gibson
    POWERPC_DEF("POWER7_v2.3",   CPU_POWERPC_POWER7_v23,             POWER7),
9173 a750fc0b j_mayer
    /* PowerPC 970                                                           */
9174 80d11f44 j_mayer
    POWERPC_DEF("970",           CPU_POWERPC_970,                    970),
9175 a750fc0b j_mayer
    /* PowerPC 970FX (G5)                                                    */
9176 80d11f44 j_mayer
    POWERPC_DEF("970fx",         CPU_POWERPC_970FX,                  970FX),
9177 a750fc0b j_mayer
    /* PowerPC 970FX v1.0 (G5)                                               */
9178 80d11f44 j_mayer
    POWERPC_DEF("970fx_v1.0",    CPU_POWERPC_970FX_v10,              970FX),
9179 a750fc0b j_mayer
    /* PowerPC 970FX v2.0 (G5)                                               */
9180 80d11f44 j_mayer
    POWERPC_DEF("970fx_v2.0",    CPU_POWERPC_970FX_v20,              970FX),
9181 a750fc0b j_mayer
    /* PowerPC 970FX v2.1 (G5)                                               */
9182 80d11f44 j_mayer
    POWERPC_DEF("970fx_v2.1",    CPU_POWERPC_970FX_v21,              970FX),
9183 a750fc0b j_mayer
    /* PowerPC 970FX v3.0 (G5)                                               */
9184 80d11f44 j_mayer
    POWERPC_DEF("970fx_v3.0",    CPU_POWERPC_970FX_v30,              970FX),
9185 a750fc0b j_mayer
    /* PowerPC 970FX v3.1 (G5)                                               */
9186 80d11f44 j_mayer
    POWERPC_DEF("970fx_v3.1",    CPU_POWERPC_970FX_v31,              970FX),
9187 a750fc0b j_mayer
    /* PowerPC 970GX (G5)                                                    */
9188 80d11f44 j_mayer
    POWERPC_DEF("970gx",         CPU_POWERPC_970GX,                  970GX),
9189 a750fc0b j_mayer
    /* PowerPC 970MP                                                         */
9190 80d11f44 j_mayer
    POWERPC_DEF("970mp",         CPU_POWERPC_970MP,                  970MP),
9191 a750fc0b j_mayer
    /* PowerPC 970MP v1.0                                                    */
9192 80d11f44 j_mayer
    POWERPC_DEF("970mp_v1.0",    CPU_POWERPC_970MP_v10,              970MP),
9193 a750fc0b j_mayer
    /* PowerPC 970MP v1.1                                                    */
9194 80d11f44 j_mayer
    POWERPC_DEF("970mp_v1.1",    CPU_POWERPC_970MP_v11,              970MP),
9195 3a607854 j_mayer
#if defined (TODO)
9196 a750fc0b j_mayer
    /* PowerPC Cell                                                          */
9197 80d11f44 j_mayer
    POWERPC_DEF("Cell",          CPU_POWERPC_CELL,                   970),
9198 2662a059 j_mayer
#endif
9199 2662a059 j_mayer
#if defined (TODO)
9200 a750fc0b j_mayer
    /* PowerPC Cell v1.0                                                     */
9201 80d11f44 j_mayer
    POWERPC_DEF("Cell_v1.0",     CPU_POWERPC_CELL_v10,               970),
9202 2662a059 j_mayer
#endif
9203 2662a059 j_mayer
#if defined (TODO)
9204 a750fc0b j_mayer
    /* PowerPC Cell v2.0                                                     */
9205 80d11f44 j_mayer
    POWERPC_DEF("Cell_v2.0",     CPU_POWERPC_CELL_v20,               970),
9206 2662a059 j_mayer
#endif
9207 2662a059 j_mayer
#if defined (TODO)
9208 a750fc0b j_mayer
    /* PowerPC Cell v3.0                                                     */
9209 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.0",     CPU_POWERPC_CELL_v30,               970),
9210 3a607854 j_mayer
#endif
9211 3a607854 j_mayer
#if defined (TODO)
9212 a750fc0b j_mayer
    /* PowerPC Cell v3.1                                                     */
9213 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.1",     CPU_POWERPC_CELL_v31,               970),
9214 2662a059 j_mayer
#endif
9215 2662a059 j_mayer
#if defined (TODO)
9216 a750fc0b j_mayer
    /* PowerPC Cell v3.2                                                     */
9217 80d11f44 j_mayer
    POWERPC_DEF("Cell_v3.2",     CPU_POWERPC_CELL_v32,               970),
9218 2662a059 j_mayer
#endif
9219 2662a059 j_mayer
#if defined (TODO)
9220 a750fc0b j_mayer
    /* RS64 (Apache/A35)                                                     */
9221 a750fc0b j_mayer
    /* This one seems to support the whole POWER2 instruction set
9222 a750fc0b j_mayer
     * and the PowerPC 64 one.
9223 a750fc0b j_mayer
     */
9224 a750fc0b j_mayer
    /* What about A10 & A30 ? */
9225 80d11f44 j_mayer
    POWERPC_DEF("RS64",          CPU_POWERPC_RS64,                   RS64),
9226 80d11f44 j_mayer
    POWERPC_DEF("Apache",        CPU_POWERPC_RS64,                   RS64),
9227 80d11f44 j_mayer
    POWERPC_DEF("A35",           CPU_POWERPC_RS64,                   RS64),
9228 3a607854 j_mayer
#endif
9229 3a607854 j_mayer
#if defined (TODO)
9230 a750fc0b j_mayer
    /* RS64-II (NorthStar/A50)                                               */
9231 80d11f44 j_mayer
    POWERPC_DEF("RS64-II",       CPU_POWERPC_RS64II,                 RS64),
9232 80d11f44 j_mayer
    POWERPC_DEF("NorthStar",     CPU_POWERPC_RS64II,                 RS64),
9233 80d11f44 j_mayer
    POWERPC_DEF("A50",           CPU_POWERPC_RS64II,                 RS64),
9234 3a607854 j_mayer
#endif
9235 3a607854 j_mayer
#if defined (TODO)
9236 a750fc0b j_mayer
    /* RS64-III (Pulsar)                                                     */
9237 80d11f44 j_mayer
    POWERPC_DEF("RS64-III",      CPU_POWERPC_RS64III,                RS64),
9238 80d11f44 j_mayer
    POWERPC_DEF("Pulsar",        CPU_POWERPC_RS64III,                RS64),
9239 2662a059 j_mayer
#endif
9240 2662a059 j_mayer
#if defined (TODO)
9241 a750fc0b j_mayer
    /* RS64-IV (IceStar/IStar/SStar)                                         */
9242 80d11f44 j_mayer
    POWERPC_DEF("RS64-IV",       CPU_POWERPC_RS64IV,                 RS64),
9243 80d11f44 j_mayer
    POWERPC_DEF("IceStar",       CPU_POWERPC_RS64IV,                 RS64),
9244 80d11f44 j_mayer
    POWERPC_DEF("IStar",         CPU_POWERPC_RS64IV,                 RS64),
9245 80d11f44 j_mayer
    POWERPC_DEF("SStar",         CPU_POWERPC_RS64IV,                 RS64),
9246 3a607854 j_mayer
#endif
9247 a750fc0b j_mayer
#endif /* defined (TARGET_PPC64) */
9248 a750fc0b j_mayer
    /* POWER                                                                 */
9249 3fc6c082 bellard
#if defined (TODO)
9250 a750fc0b j_mayer
    /* Original POWER                                                        */
9251 80d11f44 j_mayer
    POWERPC_DEF("POWER",         CPU_POWERPC_POWER,                  POWER),
9252 80d11f44 j_mayer
    POWERPC_DEF("RIOS",          CPU_POWERPC_POWER,                  POWER),
9253 80d11f44 j_mayer
    POWERPC_DEF("RSC",           CPU_POWERPC_POWER,                  POWER),
9254 80d11f44 j_mayer
    POWERPC_DEF("RSC3308",       CPU_POWERPC_POWER,                  POWER),
9255 80d11f44 j_mayer
    POWERPC_DEF("RSC4608",       CPU_POWERPC_POWER,                  POWER),
9256 76a66253 j_mayer
#endif
9257 76a66253 j_mayer
#if defined (TODO)
9258 a750fc0b j_mayer
    /* POWER2                                                                */
9259 80d11f44 j_mayer
    POWERPC_DEF("POWER2",        CPU_POWERPC_POWER2,                 POWER),
9260 80d11f44 j_mayer
    POWERPC_DEF("RSC2",          CPU_POWERPC_POWER2,                 POWER),
9261 80d11f44 j_mayer
    POWERPC_DEF("P2SC",          CPU_POWERPC_POWER2,                 POWER),
9262 a750fc0b j_mayer
#endif
9263 a750fc0b j_mayer
    /* PA semi cores                                                         */
9264 a750fc0b j_mayer
#if defined (TODO)
9265 a750fc0b j_mayer
    /* PA PA6T */
9266 80d11f44 j_mayer
    POWERPC_DEF("PA6T",          CPU_POWERPC_PA6T,                   PA6T),
9267 a750fc0b j_mayer
#endif
9268 a750fc0b j_mayer
    /* Generic PowerPCs                                                      */
9269 a750fc0b j_mayer
#if defined (TARGET_PPC64)
9270 80d11f44 j_mayer
    POWERPC_DEF("ppc64",         CPU_POWERPC_PPC64,                  PPC64),
9271 a750fc0b j_mayer
#endif
9272 80d11f44 j_mayer
    POWERPC_DEF("ppc32",         CPU_POWERPC_PPC32,                  PPC32),
9273 80d11f44 j_mayer
    POWERPC_DEF("ppc",           CPU_POWERPC_DEFAULT,                DEFAULT),
9274 a750fc0b j_mayer
    /* Fallback                                                              */
9275 80d11f44 j_mayer
    POWERPC_DEF("default",       CPU_POWERPC_DEFAULT,                DEFAULT),
9276 a750fc0b j_mayer
};
9277 a750fc0b j_mayer
9278 a750fc0b j_mayer
/*****************************************************************************/
9279 60b14d95 Stefan Weil
/* Generic CPU instantiation routine                                         */
9280 c227f099 Anthony Liguori
static void init_ppc_proc (CPUPPCState *env, const ppc_def_t *def)
9281 a750fc0b j_mayer
{
9282 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
9283 e1833e1f j_mayer
    int i;
9284 e1833e1f j_mayer
9285 a750fc0b j_mayer
    env->irq_inputs = NULL;
9286 e1833e1f j_mayer
    /* Set all exception vectors to an invalid address */
9287 e1833e1f j_mayer
    for (i = 0; i < POWERPC_EXCP_NB; i++)
9288 e1833e1f j_mayer
        env->excp_vectors[i] = (target_ulong)(-1ULL);
9289 fc1c67bc Blue Swirl
    env->hreset_excp_prefix = 0x00000000;
9290 e1833e1f j_mayer
    env->ivor_mask = 0x00000000;
9291 e1833e1f j_mayer
    env->ivpr_mask = 0x00000000;
9292 a750fc0b j_mayer
    /* Default MMU definitions */
9293 a750fc0b j_mayer
    env->nb_BATs = 0;
9294 a750fc0b j_mayer
    env->nb_tlb = 0;
9295 a750fc0b j_mayer
    env->nb_ways = 0;
9296 1c53accc Alexander Graf
    env->tlb_type = TLB_NONE;
9297 f2e63a42 j_mayer
#endif
9298 a750fc0b j_mayer
    /* Register SPR common to all PowerPC implementations */
9299 a750fc0b j_mayer
    gen_spr_generic(env);
9300 a750fc0b j_mayer
    spr_register(env, SPR_PVR, "PVR",
9301 a139aa17 Nathan Froyd
                 /* Linux permits userspace to read PVR */
9302 a139aa17 Nathan Froyd
#if defined(CONFIG_LINUX_USER)
9303 a139aa17 Nathan Froyd
                 &spr_read_generic,
9304 a139aa17 Nathan Froyd
#else
9305 a139aa17 Nathan Froyd
                 SPR_NOACCESS,
9306 a139aa17 Nathan Froyd
#endif
9307 a139aa17 Nathan Froyd
                 SPR_NOACCESS,
9308 a750fc0b j_mayer
                 &spr_read_generic, SPR_NOACCESS,
9309 a750fc0b j_mayer
                 def->pvr);
9310 80d11f44 j_mayer
    /* Register SVR if it's defined to anything else than POWERPC_SVR_NONE */
9311 80d11f44 j_mayer
    if (def->svr != POWERPC_SVR_NONE) {
9312 80d11f44 j_mayer
        if (def->svr & POWERPC_SVR_E500) {
9313 80d11f44 j_mayer
            spr_register(env, SPR_E500_SVR, "SVR",
9314 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
9315 80d11f44 j_mayer
                         &spr_read_generic, SPR_NOACCESS,
9316 80d11f44 j_mayer
                         def->svr & ~POWERPC_SVR_E500);
9317 80d11f44 j_mayer
        } else {
9318 80d11f44 j_mayer
            spr_register(env, SPR_SVR, "SVR",
9319 80d11f44 j_mayer
                         SPR_NOACCESS, SPR_NOACCESS,
9320 80d11f44 j_mayer
                         &spr_read_generic, SPR_NOACCESS,
9321 80d11f44 j_mayer
                         def->svr);
9322 80d11f44 j_mayer
        }
9323 80d11f44 j_mayer
    }
9324 a750fc0b j_mayer
    /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
9325 a750fc0b j_mayer
    (*def->init_proc)(env);
9326 fc1c67bc Blue Swirl
#if !defined(CONFIG_USER_ONLY)
9327 fc1c67bc Blue Swirl
    env->excp_prefix = env->hreset_excp_prefix;
9328 fc1c67bc Blue Swirl
#endif
9329 25ba3a68 j_mayer
    /* MSR bits & flags consistency checks */
9330 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 25)) {
9331 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
9332 25ba3a68 j_mayer
        case POWERPC_FLAG_SPE:
9333 25ba3a68 j_mayer
        case POWERPC_FLAG_VRE:
9334 25ba3a68 j_mayer
            break;
9335 25ba3a68 j_mayer
        default:
9336 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9337 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SPE or POWERPC_FLAG_VRE\n");
9338 25ba3a68 j_mayer
            exit(1);
9339 25ba3a68 j_mayer
        }
9340 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
9341 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9342 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SPE nor POWERPC_FLAG_VRE\n");
9343 25ba3a68 j_mayer
        exit(1);
9344 25ba3a68 j_mayer
    }
9345 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 17)) {
9346 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
9347 25ba3a68 j_mayer
        case POWERPC_FLAG_TGPR:
9348 25ba3a68 j_mayer
        case POWERPC_FLAG_CE:
9349 25ba3a68 j_mayer
            break;
9350 25ba3a68 j_mayer
        default:
9351 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9352 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_TGPR or POWERPC_FLAG_CE\n");
9353 25ba3a68 j_mayer
            exit(1);
9354 25ba3a68 j_mayer
        }
9355 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
9356 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9357 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_TGPR nor POWERPC_FLAG_CE\n");
9358 25ba3a68 j_mayer
        exit(1);
9359 25ba3a68 j_mayer
    }
9360 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 10)) {
9361 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
9362 25ba3a68 j_mayer
                              POWERPC_FLAG_UBLE)) {
9363 25ba3a68 j_mayer
        case POWERPC_FLAG_SE:
9364 25ba3a68 j_mayer
        case POWERPC_FLAG_DWE:
9365 25ba3a68 j_mayer
        case POWERPC_FLAG_UBLE:
9366 25ba3a68 j_mayer
            break;
9367 25ba3a68 j_mayer
        default:
9368 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9369 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_SE or POWERPC_FLAG_DWE or "
9370 25ba3a68 j_mayer
                    "POWERPC_FLAG_UBLE\n");
9371 25ba3a68 j_mayer
            exit(1);
9372 25ba3a68 j_mayer
        }
9373 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
9374 25ba3a68 j_mayer
                             POWERPC_FLAG_UBLE)) {
9375 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9376 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_SE nor POWERPC_FLAG_DWE nor "
9377 25ba3a68 j_mayer
                "POWERPC_FLAG_UBLE\n");
9378 25ba3a68 j_mayer
            exit(1);
9379 25ba3a68 j_mayer
    }
9380 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 9)) {
9381 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
9382 25ba3a68 j_mayer
        case POWERPC_FLAG_BE:
9383 25ba3a68 j_mayer
        case POWERPC_FLAG_DE:
9384 25ba3a68 j_mayer
            break;
9385 25ba3a68 j_mayer
        default:
9386 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9387 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_BE or POWERPC_FLAG_DE\n");
9388 25ba3a68 j_mayer
            exit(1);
9389 25ba3a68 j_mayer
        }
9390 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
9391 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9392 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_BE nor POWERPC_FLAG_DE\n");
9393 25ba3a68 j_mayer
        exit(1);
9394 25ba3a68 j_mayer
    }
9395 25ba3a68 j_mayer
    if (env->msr_mask & (1 << 2)) {
9396 25ba3a68 j_mayer
        switch (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
9397 25ba3a68 j_mayer
        case POWERPC_FLAG_PX:
9398 25ba3a68 j_mayer
        case POWERPC_FLAG_PMM:
9399 25ba3a68 j_mayer
            break;
9400 25ba3a68 j_mayer
        default:
9401 25ba3a68 j_mayer
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9402 25ba3a68 j_mayer
                    "Should define POWERPC_FLAG_PX or POWERPC_FLAG_PMM\n");
9403 25ba3a68 j_mayer
            exit(1);
9404 25ba3a68 j_mayer
        }
9405 25ba3a68 j_mayer
    } else if (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
9406 25ba3a68 j_mayer
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
9407 25ba3a68 j_mayer
                "Should not define POWERPC_FLAG_PX nor POWERPC_FLAG_PMM\n");
9408 25ba3a68 j_mayer
        exit(1);
9409 25ba3a68 j_mayer
    }
9410 4018bae9 j_mayer
    if ((env->flags & (POWERPC_FLAG_RTC_CLK | POWERPC_FLAG_BUS_CLK)) == 0) {
9411 4018bae9 j_mayer
        fprintf(stderr, "PowerPC flags inconsistency\n"
9412 4018bae9 j_mayer
                "Should define the time-base and decrementer clock source\n");
9413 4018bae9 j_mayer
        exit(1);
9414 4018bae9 j_mayer
    }
9415 a750fc0b j_mayer
    /* Allocate TLBs buffer when needed */
9416 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
9417 a750fc0b j_mayer
    if (env->nb_tlb != 0) {
9418 a750fc0b j_mayer
        int nb_tlb = env->nb_tlb;
9419 a750fc0b j_mayer
        if (env->id_tlbs != 0)
9420 a750fc0b j_mayer
            nb_tlb *= 2;
9421 1c53accc Alexander Graf
        switch (env->tlb_type) {
9422 1c53accc Alexander Graf
        case TLB_6XX:
9423 7267c094 Anthony Liguori
            env->tlb.tlb6 = g_malloc0(nb_tlb * sizeof(ppc6xx_tlb_t));
9424 1c53accc Alexander Graf
            break;
9425 1c53accc Alexander Graf
        case TLB_EMB:
9426 7267c094 Anthony Liguori
            env->tlb.tlbe = g_malloc0(nb_tlb * sizeof(ppcemb_tlb_t));
9427 1c53accc Alexander Graf
            break;
9428 1c53accc Alexander Graf
        case TLB_MAS:
9429 7267c094 Anthony Liguori
            env->tlb.tlbm = g_malloc0(nb_tlb * sizeof(ppcmas_tlb_t));
9430 1c53accc Alexander Graf
            break;
9431 1c53accc Alexander Graf
        }
9432 a750fc0b j_mayer
        /* Pre-compute some useful values */
9433 a750fc0b j_mayer
        env->tlb_per_way = env->nb_tlb / env->nb_ways;
9434 a750fc0b j_mayer
    }
9435 a750fc0b j_mayer
    if (env->irq_inputs == NULL) {
9436 a750fc0b j_mayer
        fprintf(stderr, "WARNING: no internal IRQ controller registered.\n"
9437 a750fc0b j_mayer
                " Attempt Qemu to crash very soon !\n");
9438 a750fc0b j_mayer
    }
9439 a750fc0b j_mayer
#endif
9440 2f462816 j_mayer
    if (env->check_pow == NULL) {
9441 2f462816 j_mayer
        fprintf(stderr, "WARNING: no power management check handler "
9442 2f462816 j_mayer
                "registered.\n"
9443 2f462816 j_mayer
                " Attempt Qemu to crash very soon !\n");
9444 2f462816 j_mayer
    }
9445 a750fc0b j_mayer
}
9446 a750fc0b j_mayer
9447 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
9448 a750fc0b j_mayer
static void dump_ppc_sprs (CPUPPCState *env)
9449 a750fc0b j_mayer
{
9450 a750fc0b j_mayer
    ppc_spr_t *spr;
9451 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
9452 a750fc0b j_mayer
    uint32_t sr, sw;
9453 a750fc0b j_mayer
#endif
9454 a750fc0b j_mayer
    uint32_t ur, uw;
9455 a750fc0b j_mayer
    int i, j, n;
9456 a750fc0b j_mayer
9457 a750fc0b j_mayer
    printf("Special purpose registers:\n");
9458 a750fc0b j_mayer
    for (i = 0; i < 32; i++) {
9459 a750fc0b j_mayer
        for (j = 0; j < 32; j++) {
9460 a750fc0b j_mayer
            n = (i << 5) | j;
9461 a750fc0b j_mayer
            spr = &env->spr_cb[n];
9462 a750fc0b j_mayer
            uw = spr->uea_write != NULL && spr->uea_write != SPR_NOACCESS;
9463 a750fc0b j_mayer
            ur = spr->uea_read != NULL && spr->uea_read != SPR_NOACCESS;
9464 a750fc0b j_mayer
#if !defined(CONFIG_USER_ONLY)
9465 a750fc0b j_mayer
            sw = spr->oea_write != NULL && spr->oea_write != SPR_NOACCESS;
9466 a750fc0b j_mayer
            sr = spr->oea_read != NULL && spr->oea_read != SPR_NOACCESS;
9467 a750fc0b j_mayer
            if (sw || sr || uw || ur) {
9468 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
9469 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
9470 a750fc0b j_mayer
                       sw ? 'w' : '-', sr ? 'r' : '-',
9471 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
9472 a750fc0b j_mayer
            }
9473 a750fc0b j_mayer
#else
9474 a750fc0b j_mayer
            if (uw || ur) {
9475 a750fc0b j_mayer
                printf("SPR: %4d (%03x) %-8s u%c%c\n",
9476 a750fc0b j_mayer
                       (i << 5) | j, (i << 5) | j, spr->name,
9477 a750fc0b j_mayer
                       uw ? 'w' : '-', ur ? 'r' : '-');
9478 a750fc0b j_mayer
            }
9479 a750fc0b j_mayer
#endif
9480 a750fc0b j_mayer
        }
9481 a750fc0b j_mayer
    }
9482 a750fc0b j_mayer
    fflush(stdout);
9483 a750fc0b j_mayer
    fflush(stderr);
9484 a750fc0b j_mayer
}
9485 a750fc0b j_mayer
#endif
9486 a750fc0b j_mayer
9487 a750fc0b j_mayer
/*****************************************************************************/
9488 a750fc0b j_mayer
#include <stdlib.h>
9489 a750fc0b j_mayer
#include <string.h>
9490 a750fc0b j_mayer
9491 a750fc0b j_mayer
/* Opcode types */
9492 a750fc0b j_mayer
enum {
9493 a750fc0b j_mayer
    PPC_DIRECT   = 0, /* Opcode routine        */
9494 a750fc0b j_mayer
    PPC_INDIRECT = 1, /* Indirect opcode table */
9495 a750fc0b j_mayer
};
9496 a750fc0b j_mayer
9497 a750fc0b j_mayer
static inline int is_indirect_opcode (void *handler)
9498 a750fc0b j_mayer
{
9499 a750fc0b j_mayer
    return ((unsigned long)handler & 0x03) == PPC_INDIRECT;
9500 a750fc0b j_mayer
}
9501 a750fc0b j_mayer
9502 c227f099 Anthony Liguori
static inline opc_handler_t **ind_table(void *handler)
9503 a750fc0b j_mayer
{
9504 c227f099 Anthony Liguori
    return (opc_handler_t **)((unsigned long)handler & ~3);
9505 a750fc0b j_mayer
}
9506 a750fc0b j_mayer
9507 a750fc0b j_mayer
/* Instruction table creation */
9508 a750fc0b j_mayer
/* Opcodes tables creation */
9509 c227f099 Anthony Liguori
static void fill_new_table (opc_handler_t **table, int len)
9510 a750fc0b j_mayer
{
9511 a750fc0b j_mayer
    int i;
9512 a750fc0b j_mayer
9513 a750fc0b j_mayer
    for (i = 0; i < len; i++)
9514 a750fc0b j_mayer
        table[i] = &invalid_handler;
9515 a750fc0b j_mayer
}
9516 a750fc0b j_mayer
9517 c227f099 Anthony Liguori
static int create_new_table (opc_handler_t **table, unsigned char idx)
9518 a750fc0b j_mayer
{
9519 c227f099 Anthony Liguori
    opc_handler_t **tmp;
9520 a750fc0b j_mayer
9521 c227f099 Anthony Liguori
    tmp = malloc(0x20 * sizeof(opc_handler_t));
9522 a750fc0b j_mayer
    fill_new_table(tmp, 0x20);
9523 c227f099 Anthony Liguori
    table[idx] = (opc_handler_t *)((unsigned long)tmp | PPC_INDIRECT);
9524 a750fc0b j_mayer
9525 a750fc0b j_mayer
    return 0;
9526 a750fc0b j_mayer
}
9527 a750fc0b j_mayer
9528 c227f099 Anthony Liguori
static int insert_in_table (opc_handler_t **table, unsigned char idx,
9529 c227f099 Anthony Liguori
                            opc_handler_t *handler)
9530 a750fc0b j_mayer
{
9531 a750fc0b j_mayer
    if (table[idx] != &invalid_handler)
9532 a750fc0b j_mayer
        return -1;
9533 a750fc0b j_mayer
    table[idx] = handler;
9534 a750fc0b j_mayer
9535 a750fc0b j_mayer
    return 0;
9536 a750fc0b j_mayer
}
9537 a750fc0b j_mayer
9538 c227f099 Anthony Liguori
static int register_direct_insn (opc_handler_t **ppc_opcodes,
9539 c227f099 Anthony Liguori
                                 unsigned char idx, opc_handler_t *handler)
9540 a750fc0b j_mayer
{
9541 a750fc0b j_mayer
    if (insert_in_table(ppc_opcodes, idx, handler) < 0) {
9542 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in main "
9543 a750fc0b j_mayer
               "opcode table\n", idx);
9544 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
9545 4c1b1bfe j_mayer
        printf("           Registered handler '%s' - new handler '%s'\n",
9546 4c1b1bfe j_mayer
               ppc_opcodes[idx]->oname, handler->oname);
9547 4c1b1bfe j_mayer
#endif
9548 a750fc0b j_mayer
        return -1;
9549 a750fc0b j_mayer
    }
9550 a750fc0b j_mayer
9551 a750fc0b j_mayer
    return 0;
9552 a750fc0b j_mayer
}
9553 a750fc0b j_mayer
9554 c227f099 Anthony Liguori
static int register_ind_in_table (opc_handler_t **table,
9555 a750fc0b j_mayer
                                  unsigned char idx1, unsigned char idx2,
9556 c227f099 Anthony Liguori
                                  opc_handler_t *handler)
9557 a750fc0b j_mayer
{
9558 a750fc0b j_mayer
    if (table[idx1] == &invalid_handler) {
9559 a750fc0b j_mayer
        if (create_new_table(table, idx1) < 0) {
9560 a750fc0b j_mayer
            printf("*** ERROR: unable to create indirect table "
9561 a750fc0b j_mayer
                   "idx=%02x\n", idx1);
9562 a750fc0b j_mayer
            return -1;
9563 a750fc0b j_mayer
        }
9564 a750fc0b j_mayer
    } else {
9565 a750fc0b j_mayer
        if (!is_indirect_opcode(table[idx1])) {
9566 a750fc0b j_mayer
            printf("*** ERROR: idx %02x already assigned to a direct "
9567 a750fc0b j_mayer
                   "opcode\n", idx1);
9568 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
9569 4c1b1bfe j_mayer
            printf("           Registered handler '%s' - new handler '%s'\n",
9570 4c1b1bfe j_mayer
                   ind_table(table[idx1])[idx2]->oname, handler->oname);
9571 4c1b1bfe j_mayer
#endif
9572 a750fc0b j_mayer
            return -1;
9573 a750fc0b j_mayer
        }
9574 3a607854 j_mayer
    }
9575 a750fc0b j_mayer
    if (handler != NULL &&
9576 a750fc0b j_mayer
        insert_in_table(ind_table(table[idx1]), idx2, handler) < 0) {
9577 a750fc0b j_mayer
        printf("*** ERROR: opcode %02x already assigned in "
9578 a750fc0b j_mayer
               "opcode table %02x\n", idx2, idx1);
9579 4c1b1bfe j_mayer
#if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
9580 4c1b1bfe j_mayer
        printf("           Registered handler '%s' - new handler '%s'\n",
9581 4c1b1bfe j_mayer
               ind_table(table[idx1])[idx2]->oname, handler->oname);
9582 4c1b1bfe j_mayer
#endif
9583 a750fc0b j_mayer
        return -1;
9584 3a607854 j_mayer
    }
9585 a750fc0b j_mayer
9586 a750fc0b j_mayer
    return 0;
9587 a750fc0b j_mayer
}
9588 a750fc0b j_mayer
9589 c227f099 Anthony Liguori
static int register_ind_insn (opc_handler_t **ppc_opcodes,
9590 a750fc0b j_mayer
                              unsigned char idx1, unsigned char idx2,
9591 c227f099 Anthony Liguori
                              opc_handler_t *handler)
9592 a750fc0b j_mayer
{
9593 a750fc0b j_mayer
    int ret;
9594 a750fc0b j_mayer
9595 a750fc0b j_mayer
    ret = register_ind_in_table(ppc_opcodes, idx1, idx2, handler);
9596 a750fc0b j_mayer
9597 a750fc0b j_mayer
    return ret;
9598 a750fc0b j_mayer
}
9599 a750fc0b j_mayer
9600 c227f099 Anthony Liguori
static int register_dblind_insn (opc_handler_t **ppc_opcodes,
9601 a750fc0b j_mayer
                                 unsigned char idx1, unsigned char idx2,
9602 c227f099 Anthony Liguori
                                 unsigned char idx3, opc_handler_t *handler)
9603 a750fc0b j_mayer
{
9604 a750fc0b j_mayer
    if (register_ind_in_table(ppc_opcodes, idx1, idx2, NULL) < 0) {
9605 a750fc0b j_mayer
        printf("*** ERROR: unable to join indirect table idx "
9606 a750fc0b j_mayer
               "[%02x-%02x]\n", idx1, idx2);
9607 a750fc0b j_mayer
        return -1;
9608 a750fc0b j_mayer
    }
9609 a750fc0b j_mayer
    if (register_ind_in_table(ind_table(ppc_opcodes[idx1]), idx2, idx3,
9610 a750fc0b j_mayer
                              handler) < 0) {
9611 a750fc0b j_mayer
        printf("*** ERROR: unable to insert opcode "
9612 a750fc0b j_mayer
               "[%02x-%02x-%02x]\n", idx1, idx2, idx3);
9613 a750fc0b j_mayer
        return -1;
9614 a750fc0b j_mayer
    }
9615 a750fc0b j_mayer
9616 a750fc0b j_mayer
    return 0;
9617 a750fc0b j_mayer
}
9618 a750fc0b j_mayer
9619 c227f099 Anthony Liguori
static int register_insn (opc_handler_t **ppc_opcodes, opcode_t *insn)
9620 a750fc0b j_mayer
{
9621 a750fc0b j_mayer
    if (insn->opc2 != 0xFF) {
9622 a750fc0b j_mayer
        if (insn->opc3 != 0xFF) {
9623 a750fc0b j_mayer
            if (register_dblind_insn(ppc_opcodes, insn->opc1, insn->opc2,
9624 a750fc0b j_mayer
                                     insn->opc3, &insn->handler) < 0)
9625 a750fc0b j_mayer
                return -1;
9626 a750fc0b j_mayer
        } else {
9627 a750fc0b j_mayer
            if (register_ind_insn(ppc_opcodes, insn->opc1,
9628 a750fc0b j_mayer
                                  insn->opc2, &insn->handler) < 0)
9629 a750fc0b j_mayer
                return -1;
9630 a750fc0b j_mayer
        }
9631 a750fc0b j_mayer
    } else {
9632 a750fc0b j_mayer
        if (register_direct_insn(ppc_opcodes, insn->opc1, &insn->handler) < 0)
9633 a750fc0b j_mayer
            return -1;
9634 a750fc0b j_mayer
    }
9635 a750fc0b j_mayer
9636 a750fc0b j_mayer
    return 0;
9637 a750fc0b j_mayer
}
9638 a750fc0b j_mayer
9639 c227f099 Anthony Liguori
static int test_opcode_table (opc_handler_t **table, int len)
9640 a750fc0b j_mayer
{
9641 a750fc0b j_mayer
    int i, count, tmp;
9642 a750fc0b j_mayer
9643 a750fc0b j_mayer
    for (i = 0, count = 0; i < len; i++) {
9644 a750fc0b j_mayer
        /* Consistency fixup */
9645 a750fc0b j_mayer
        if (table[i] == NULL)
9646 a750fc0b j_mayer
            table[i] = &invalid_handler;
9647 a750fc0b j_mayer
        if (table[i] != &invalid_handler) {
9648 a750fc0b j_mayer
            if (is_indirect_opcode(table[i])) {
9649 c227f099 Anthony Liguori
                tmp = test_opcode_table(ind_table(table[i]), 0x20);
9650 a750fc0b j_mayer
                if (tmp == 0) {
9651 a750fc0b j_mayer
                    free(table[i]);
9652 a750fc0b j_mayer
                    table[i] = &invalid_handler;
9653 a750fc0b j_mayer
                } else {
9654 a750fc0b j_mayer
                    count++;
9655 a750fc0b j_mayer
                }
9656 a750fc0b j_mayer
            } else {
9657 a750fc0b j_mayer
                count++;
9658 a750fc0b j_mayer
            }
9659 a750fc0b j_mayer
        }
9660 a750fc0b j_mayer
    }
9661 a750fc0b j_mayer
9662 a750fc0b j_mayer
    return count;
9663 a750fc0b j_mayer
}
9664 a750fc0b j_mayer
9665 c227f099 Anthony Liguori
static void fix_opcode_tables (opc_handler_t **ppc_opcodes)
9666 a750fc0b j_mayer
{
9667 c227f099 Anthony Liguori
    if (test_opcode_table(ppc_opcodes, 0x40) == 0)
9668 a750fc0b j_mayer
        printf("*** WARNING: no opcode defined !\n");
9669 a750fc0b j_mayer
}
9670 a750fc0b j_mayer
9671 a750fc0b j_mayer
/*****************************************************************************/
9672 c227f099 Anthony Liguori
static int create_ppc_opcodes (CPUPPCState *env, const ppc_def_t *def)
9673 a750fc0b j_mayer
{
9674 c227f099 Anthony Liguori
    opcode_t *opc;
9675 a750fc0b j_mayer
9676 a750fc0b j_mayer
    fill_new_table(env->opcodes, 0x40);
9677 5c55ff99 Blue Swirl
    for (opc = opcodes; opc < &opcodes[ARRAY_SIZE(opcodes)]; opc++) {
9678 a5858d7a Alexander Graf
        if (((opc->handler.type & def->insns_flags) != 0) ||
9679 a5858d7a Alexander Graf
            ((opc->handler.type2 & def->insns_flags2) != 0)) {
9680 a750fc0b j_mayer
            if (register_insn(env->opcodes, opc) < 0) {
9681 a750fc0b j_mayer
                printf("*** ERROR initializing PowerPC instruction "
9682 a750fc0b j_mayer
                       "0x%02x 0x%02x 0x%02x\n", opc->opc1, opc->opc2,
9683 a750fc0b j_mayer
                       opc->opc3);
9684 a750fc0b j_mayer
                return -1;
9685 a750fc0b j_mayer
            }
9686 a750fc0b j_mayer
        }
9687 a750fc0b j_mayer
    }
9688 c227f099 Anthony Liguori
    fix_opcode_tables(env->opcodes);
9689 a750fc0b j_mayer
    fflush(stdout);
9690 a750fc0b j_mayer
    fflush(stderr);
9691 a750fc0b j_mayer
9692 a750fc0b j_mayer
    return 0;
9693 a750fc0b j_mayer
}
9694 a750fc0b j_mayer
9695 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
9696 25ba3a68 j_mayer
static void dump_ppc_insns (CPUPPCState *env)
9697 a750fc0b j_mayer
{
9698 c227f099 Anthony Liguori
    opc_handler_t **table, *handler;
9699 b55266b5 blueswir1
    const char *p, *q;
9700 a750fc0b j_mayer
    uint8_t opc1, opc2, opc3;
9701 a750fc0b j_mayer
9702 a750fc0b j_mayer
    printf("Instructions set:\n");
9703 a750fc0b j_mayer
    /* opc1 is 6 bits long */
9704 a750fc0b j_mayer
    for (opc1 = 0x00; opc1 < 0x40; opc1++) {
9705 a750fc0b j_mayer
        table = env->opcodes;
9706 a750fc0b j_mayer
        handler = table[opc1];
9707 a750fc0b j_mayer
        if (is_indirect_opcode(handler)) {
9708 a750fc0b j_mayer
            /* opc2 is 5 bits long */
9709 a750fc0b j_mayer
            for (opc2 = 0; opc2 < 0x20; opc2++) {
9710 a750fc0b j_mayer
                table = env->opcodes;
9711 a750fc0b j_mayer
                handler = env->opcodes[opc1];
9712 a750fc0b j_mayer
                table = ind_table(handler);
9713 a750fc0b j_mayer
                handler = table[opc2];
9714 a750fc0b j_mayer
                if (is_indirect_opcode(handler)) {
9715 a750fc0b j_mayer
                    table = ind_table(handler);
9716 a750fc0b j_mayer
                    /* opc3 is 5 bits long */
9717 a750fc0b j_mayer
                    for (opc3 = 0; opc3 < 0x20; opc3++) {
9718 a750fc0b j_mayer
                        handler = table[opc3];
9719 a750fc0b j_mayer
                        if (handler->handler != &gen_invalid) {
9720 4c1b1bfe j_mayer
                            /* Special hack to properly dump SPE insns */
9721 4c1b1bfe j_mayer
                            p = strchr(handler->oname, '_');
9722 4c1b1bfe j_mayer
                            if (p == NULL) {
9723 4c1b1bfe j_mayer
                                printf("INSN: %02x %02x %02x (%02d %04d) : "
9724 4c1b1bfe j_mayer
                                       "%s\n",
9725 4c1b1bfe j_mayer
                                       opc1, opc2, opc3, opc1,
9726 4c1b1bfe j_mayer
                                       (opc3 << 5) | opc2,
9727 4c1b1bfe j_mayer
                                       handler->oname);
9728 4c1b1bfe j_mayer
                            } else {
9729 4c1b1bfe j_mayer
                                q = "speundef";
9730 4c1b1bfe j_mayer
                                if ((p - handler->oname) != strlen(q) ||
9731 4c1b1bfe j_mayer
                                    memcmp(handler->oname, q, strlen(q)) != 0) {
9732 4c1b1bfe j_mayer
                                    /* First instruction */
9733 4c1b1bfe j_mayer
                                    printf("INSN: %02x %02x %02x (%02d %04d) : "
9734 4c1b1bfe j_mayer
                                           "%.*s\n",
9735 4c1b1bfe j_mayer
                                           opc1, opc2 << 1, opc3, opc1,
9736 4c1b1bfe j_mayer
                                           (opc3 << 6) | (opc2 << 1),
9737 4c1b1bfe j_mayer
                                           (int)(p - handler->oname),
9738 4c1b1bfe j_mayer
                                           handler->oname);
9739 4c1b1bfe j_mayer
                                }
9740 4c1b1bfe j_mayer
                                if (strcmp(p + 1, q) != 0) {
9741 4c1b1bfe j_mayer
                                    /* Second instruction */
9742 4c1b1bfe j_mayer
                                    printf("INSN: %02x %02x %02x (%02d %04d) : "
9743 4c1b1bfe j_mayer
                                           "%s\n",
9744 4c1b1bfe j_mayer
                                           opc1, (opc2 << 1) | 1, opc3, opc1,
9745 4c1b1bfe j_mayer
                                           (opc3 << 6) | (opc2 << 1) | 1,
9746 4c1b1bfe j_mayer
                                           p + 1);
9747 4c1b1bfe j_mayer
                                }
9748 4c1b1bfe j_mayer
                            }
9749 a750fc0b j_mayer
                        }
9750 a750fc0b j_mayer
                    }
9751 a750fc0b j_mayer
                } else {
9752 a750fc0b j_mayer
                    if (handler->handler != &gen_invalid) {
9753 a750fc0b j_mayer
                        printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
9754 a750fc0b j_mayer
                               opc1, opc2, opc1, opc2, handler->oname);
9755 a750fc0b j_mayer
                    }
9756 a750fc0b j_mayer
                }
9757 a750fc0b j_mayer
            }
9758 a750fc0b j_mayer
        } else {
9759 a750fc0b j_mayer
            if (handler->handler != &gen_invalid) {
9760 a750fc0b j_mayer
                printf("INSN: %02x -- -- (%02d ----) : %s\n",
9761 a750fc0b j_mayer
                       opc1, opc1, handler->oname);
9762 a750fc0b j_mayer
            }
9763 a750fc0b j_mayer
        }
9764 a750fc0b j_mayer
    }
9765 a750fc0b j_mayer
}
9766 3a607854 j_mayer
#endif
9767 a750fc0b j_mayer
9768 24951522 aurel32
static int gdb_get_float_reg(CPUState *env, uint8_t *mem_buf, int n)
9769 24951522 aurel32
{
9770 24951522 aurel32
    if (n < 32) {
9771 24951522 aurel32
        stfq_p(mem_buf, env->fpr[n]);
9772 24951522 aurel32
        return 8;
9773 24951522 aurel32
    }
9774 24951522 aurel32
    if (n == 32) {
9775 5a576fb3 Fabien Chouteau
        stl_p(mem_buf, env->fpscr);
9776 24951522 aurel32
        return 4;
9777 24951522 aurel32
    }
9778 24951522 aurel32
    return 0;
9779 24951522 aurel32
}
9780 24951522 aurel32
9781 24951522 aurel32
static int gdb_set_float_reg(CPUState *env, uint8_t *mem_buf, int n)
9782 24951522 aurel32
{
9783 24951522 aurel32
    if (n < 32) {
9784 24951522 aurel32
        env->fpr[n] = ldfq_p(mem_buf);
9785 24951522 aurel32
        return 8;
9786 24951522 aurel32
    }
9787 24951522 aurel32
    if (n == 32) {
9788 24951522 aurel32
        /* FPSCR not implemented  */
9789 24951522 aurel32
        return 4;
9790 24951522 aurel32
    }
9791 24951522 aurel32
    return 0;
9792 24951522 aurel32
}
9793 24951522 aurel32
9794 b4f8d821 aurel32
static int gdb_get_avr_reg(CPUState *env, uint8_t *mem_buf, int n)
9795 b4f8d821 aurel32
{
9796 b4f8d821 aurel32
    if (n < 32) {
9797 e2542fe2 Juan Quintela
#ifdef HOST_WORDS_BIGENDIAN
9798 b4f8d821 aurel32
        stq_p(mem_buf, env->avr[n].u64[0]);
9799 b4f8d821 aurel32
        stq_p(mem_buf+8, env->avr[n].u64[1]);
9800 b4f8d821 aurel32
#else
9801 b4f8d821 aurel32
        stq_p(mem_buf, env->avr[n].u64[1]);
9802 b4f8d821 aurel32
        stq_p(mem_buf+8, env->avr[n].u64[0]);
9803 b4f8d821 aurel32
#endif
9804 b4f8d821 aurel32
        return 16;
9805 b4f8d821 aurel32
    }
9806 70976a79 aurel32
    if (n == 32) {
9807 b4f8d821 aurel32
        stl_p(mem_buf, env->vscr);
9808 b4f8d821 aurel32
        return 4;
9809 b4f8d821 aurel32
    }
9810 70976a79 aurel32
    if (n == 33) {
9811 b4f8d821 aurel32
        stl_p(mem_buf, (uint32_t)env->spr[SPR_VRSAVE]);
9812 b4f8d821 aurel32
        return 4;
9813 b4f8d821 aurel32
    }
9814 b4f8d821 aurel32
    return 0;
9815 b4f8d821 aurel32
}
9816 b4f8d821 aurel32
9817 b4f8d821 aurel32
static int gdb_set_avr_reg(CPUState *env, uint8_t *mem_buf, int n)
9818 b4f8d821 aurel32
{
9819 b4f8d821 aurel32
    if (n < 32) {
9820 e2542fe2 Juan Quintela
#ifdef HOST_WORDS_BIGENDIAN
9821 b4f8d821 aurel32
        env->avr[n].u64[0] = ldq_p(mem_buf);
9822 b4f8d821 aurel32
        env->avr[n].u64[1] = ldq_p(mem_buf+8);
9823 b4f8d821 aurel32
#else
9824 b4f8d821 aurel32
        env->avr[n].u64[1] = ldq_p(mem_buf);
9825 b4f8d821 aurel32
        env->avr[n].u64[0] = ldq_p(mem_buf+8);
9826 b4f8d821 aurel32
#endif
9827 b4f8d821 aurel32
        return 16;
9828 b4f8d821 aurel32
    }
9829 70976a79 aurel32
    if (n == 32) {
9830 b4f8d821 aurel32
        env->vscr = ldl_p(mem_buf);
9831 b4f8d821 aurel32
        return 4;
9832 b4f8d821 aurel32
    }
9833 70976a79 aurel32
    if (n == 33) {
9834 b4f8d821 aurel32
        env->spr[SPR_VRSAVE] = (target_ulong)ldl_p(mem_buf);
9835 b4f8d821 aurel32
        return 4;
9836 b4f8d821 aurel32
    }
9837 b4f8d821 aurel32
    return 0;
9838 b4f8d821 aurel32
}
9839 b4f8d821 aurel32
9840 688890f7 aurel32
static int gdb_get_spe_reg(CPUState *env, uint8_t *mem_buf, int n)
9841 688890f7 aurel32
{
9842 688890f7 aurel32
    if (n < 32) {
9843 688890f7 aurel32
#if defined(TARGET_PPC64)
9844 688890f7 aurel32
        stl_p(mem_buf, env->gpr[n] >> 32);
9845 688890f7 aurel32
#else
9846 688890f7 aurel32
        stl_p(mem_buf, env->gprh[n]);
9847 688890f7 aurel32
#endif
9848 688890f7 aurel32
        return 4;
9849 688890f7 aurel32
    }
9850 70976a79 aurel32
    if (n == 32) {
9851 688890f7 aurel32
        stq_p(mem_buf, env->spe_acc);
9852 688890f7 aurel32
        return 8;
9853 688890f7 aurel32
    }
9854 70976a79 aurel32
    if (n == 33) {
9855 d34defbc aurel32
        stl_p(mem_buf, env->spe_fscr);
9856 688890f7 aurel32
        return 4;
9857 688890f7 aurel32
    }
9858 688890f7 aurel32
    return 0;
9859 688890f7 aurel32
}
9860 688890f7 aurel32
9861 688890f7 aurel32
static int gdb_set_spe_reg(CPUState *env, uint8_t *mem_buf, int n)
9862 688890f7 aurel32
{
9863 688890f7 aurel32
    if (n < 32) {
9864 688890f7 aurel32
#if defined(TARGET_PPC64)
9865 688890f7 aurel32
        target_ulong lo = (uint32_t)env->gpr[n];
9866 688890f7 aurel32
        target_ulong hi = (target_ulong)ldl_p(mem_buf) << 32;
9867 688890f7 aurel32
        env->gpr[n] = lo | hi;
9868 688890f7 aurel32
#else
9869 688890f7 aurel32
        env->gprh[n] = ldl_p(mem_buf);
9870 688890f7 aurel32
#endif
9871 688890f7 aurel32
        return 4;
9872 688890f7 aurel32
    }
9873 70976a79 aurel32
    if (n == 32) {
9874 688890f7 aurel32
        env->spe_acc = ldq_p(mem_buf);
9875 688890f7 aurel32
        return 8;
9876 688890f7 aurel32
    }
9877 70976a79 aurel32
    if (n == 33) {
9878 d34defbc aurel32
        env->spe_fscr = ldl_p(mem_buf);
9879 688890f7 aurel32
        return 4;
9880 688890f7 aurel32
    }
9881 688890f7 aurel32
    return 0;
9882 688890f7 aurel32
}
9883 688890f7 aurel32
9884 c227f099 Anthony Liguori
int cpu_ppc_register_internal (CPUPPCState *env, const ppc_def_t *def)
9885 a750fc0b j_mayer
{
9886 a750fc0b j_mayer
    env->msr_mask = def->msr_mask;
9887 a750fc0b j_mayer
    env->mmu_model = def->mmu_model;
9888 a750fc0b j_mayer
    env->excp_model = def->excp_model;
9889 a750fc0b j_mayer
    env->bus_model = def->bus_model;
9890 c29b735c Nathan Froyd
    env->insns_flags = def->insns_flags;
9891 a5858d7a Alexander Graf
    env->insns_flags2 = def->insns_flags2;
9892 02d4eae4 David Gibson
    if (!kvm_enabled()) {
9893 02d4eae4 David Gibson
        /* TCG doesn't (yet) emulate some groups of instructions that
9894 02d4eae4 David Gibson
         * are implemented on some otherwise supported CPUs (e.g. VSX
9895 02d4eae4 David Gibson
         * and decimal floating point instructions on POWER7).  We
9896 02d4eae4 David Gibson
         * remove unsupported instruction groups from the cpu state's
9897 02d4eae4 David Gibson
         * instruction masks and hope the guest can cope.  For at
9898 02d4eae4 David Gibson
         * least the pseries machine, the unavailability of these
9899 02d4eae4 David Gibson
         * instructions can be advertise to the guest via the device
9900 02d4eae4 David Gibson
         * tree.
9901 02d4eae4 David Gibson
         *
9902 02d4eae4 David Gibson
         * FIXME: we should have a similar masking for CPU features
9903 02d4eae4 David Gibson
         * not accessible under KVM, but so far, there aren't any of
9904 02d4eae4 David Gibson
         * those. */
9905 02d4eae4 David Gibson
        env->insns_flags &= PPC_TCG_INSNS;
9906 02d4eae4 David Gibson
        env->insns_flags2 &= PPC_TCG_INSNS2;
9907 02d4eae4 David Gibson
    }
9908 d26bfc9a j_mayer
    env->flags = def->flags;
9909 237c0af0 j_mayer
    env->bfd_mach = def->bfd_mach;
9910 2f462816 j_mayer
    env->check_pow = def->check_pow;
9911 a750fc0b j_mayer
    if (create_ppc_opcodes(env, def) < 0)
9912 a750fc0b j_mayer
        return -1;
9913 a750fc0b j_mayer
    init_ppc_proc(env, def);
9914 24951522 aurel32
9915 24951522 aurel32
    if (def->insns_flags & PPC_FLOAT) {
9916 24951522 aurel32
        gdb_register_coprocessor(env, gdb_get_float_reg, gdb_set_float_reg,
9917 24951522 aurel32
                                 33, "power-fpu.xml", 0);
9918 24951522 aurel32
    }
9919 b4f8d821 aurel32
    if (def->insns_flags & PPC_ALTIVEC) {
9920 b4f8d821 aurel32
        gdb_register_coprocessor(env, gdb_get_avr_reg, gdb_set_avr_reg,
9921 b4f8d821 aurel32
                                 34, "power-altivec.xml", 0);
9922 b4f8d821 aurel32
    }
9923 40569b7e aurel32
    if (def->insns_flags & PPC_SPE) {
9924 688890f7 aurel32
        gdb_register_coprocessor(env, gdb_get_spe_reg, gdb_set_spe_reg,
9925 688890f7 aurel32
                                 34, "power-spe.xml", 0);
9926 688890f7 aurel32
    }
9927 688890f7 aurel32
9928 a750fc0b j_mayer
#if defined(PPC_DUMP_CPU)
9929 3a607854 j_mayer
    {
9930 b55266b5 blueswir1
        const char *mmu_model, *excp_model, *bus_model;
9931 a750fc0b j_mayer
        switch (env->mmu_model) {
9932 a750fc0b j_mayer
        case POWERPC_MMU_32B:
9933 a750fc0b j_mayer
            mmu_model = "PowerPC 32";
9934 a750fc0b j_mayer
            break;
9935 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_6xx:
9936 a750fc0b j_mayer
            mmu_model = "PowerPC 6xx/7xx with software driven TLBs";
9937 a750fc0b j_mayer
            break;
9938 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_74xx:
9939 a750fc0b j_mayer
            mmu_model = "PowerPC 74xx with software driven TLBs";
9940 a750fc0b j_mayer
            break;
9941 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx:
9942 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs";
9943 a750fc0b j_mayer
            break;
9944 a750fc0b j_mayer
        case POWERPC_MMU_SOFT_4xx_Z:
9945 a750fc0b j_mayer
            mmu_model = "PowerPC 4xx with software driven TLBs "
9946 a750fc0b j_mayer
                "and zones protections";
9947 a750fc0b j_mayer
            break;
9948 b4095fed j_mayer
        case POWERPC_MMU_REAL:
9949 b4095fed j_mayer
            mmu_model = "PowerPC real mode only";
9950 b4095fed j_mayer
            break;
9951 b4095fed j_mayer
        case POWERPC_MMU_MPC8xx:
9952 b4095fed j_mayer
            mmu_model = "PowerPC MPC8xx";
9953 a750fc0b j_mayer
            break;
9954 a750fc0b j_mayer
        case POWERPC_MMU_BOOKE:
9955 a750fc0b j_mayer
            mmu_model = "PowerPC BookE";
9956 a750fc0b j_mayer
            break;
9957 01662f3e Alexander Graf
        case POWERPC_MMU_BOOKE206:
9958 01662f3e Alexander Graf
            mmu_model = "PowerPC BookE 2.06";
9959 a750fc0b j_mayer
            break;
9960 b4095fed j_mayer
        case POWERPC_MMU_601:
9961 b4095fed j_mayer
            mmu_model = "PowerPC 601";
9962 b4095fed j_mayer
            break;
9963 00af685f j_mayer
#if defined (TARGET_PPC64)
9964 00af685f j_mayer
        case POWERPC_MMU_64B:
9965 00af685f j_mayer
            mmu_model = "PowerPC 64";
9966 00af685f j_mayer
            break;
9967 add78955 j_mayer
        case POWERPC_MMU_620:
9968 add78955 j_mayer
            mmu_model = "PowerPC 620";
9969 add78955 j_mayer
            break;
9970 00af685f j_mayer
#endif
9971 a750fc0b j_mayer
        default:
9972 a750fc0b j_mayer
            mmu_model = "Unknown or invalid";
9973 a750fc0b j_mayer
            break;
9974 a750fc0b j_mayer
        }
9975 a750fc0b j_mayer
        switch (env->excp_model) {
9976 a750fc0b j_mayer
        case POWERPC_EXCP_STD:
9977 a750fc0b j_mayer
            excp_model = "PowerPC";
9978 a750fc0b j_mayer
            break;
9979 a750fc0b j_mayer
        case POWERPC_EXCP_40x:
9980 a750fc0b j_mayer
            excp_model = "PowerPC 40x";
9981 a750fc0b j_mayer
            break;
9982 a750fc0b j_mayer
        case POWERPC_EXCP_601:
9983 a750fc0b j_mayer
            excp_model = "PowerPC 601";
9984 a750fc0b j_mayer
            break;
9985 a750fc0b j_mayer
        case POWERPC_EXCP_602:
9986 a750fc0b j_mayer
            excp_model = "PowerPC 602";
9987 a750fc0b j_mayer
            break;
9988 a750fc0b j_mayer
        case POWERPC_EXCP_603:
9989 a750fc0b j_mayer
            excp_model = "PowerPC 603";
9990 a750fc0b j_mayer
            break;
9991 a750fc0b j_mayer
        case POWERPC_EXCP_603E:
9992 a750fc0b j_mayer
            excp_model = "PowerPC 603e";
9993 a750fc0b j_mayer
            break;
9994 a750fc0b j_mayer
        case POWERPC_EXCP_604:
9995 a750fc0b j_mayer
            excp_model = "PowerPC 604";
9996 a750fc0b j_mayer
            break;
9997 a750fc0b j_mayer
        case POWERPC_EXCP_7x0:
9998 a750fc0b j_mayer
            excp_model = "PowerPC 740/750";
9999 a750fc0b j_mayer
            break;
10000 a750fc0b j_mayer
        case POWERPC_EXCP_7x5:
10001 a750fc0b j_mayer
            excp_model = "PowerPC 745/755";
10002 a750fc0b j_mayer
            break;
10003 a750fc0b j_mayer
        case POWERPC_EXCP_74xx:
10004 a750fc0b j_mayer
            excp_model = "PowerPC 74xx";
10005 a750fc0b j_mayer
            break;
10006 a750fc0b j_mayer
        case POWERPC_EXCP_BOOKE:
10007 a750fc0b j_mayer
            excp_model = "PowerPC BookE";
10008 a750fc0b j_mayer
            break;
10009 00af685f j_mayer
#if defined (TARGET_PPC64)
10010 00af685f j_mayer
        case POWERPC_EXCP_970:
10011 00af685f j_mayer
            excp_model = "PowerPC 970";
10012 00af685f j_mayer
            break;
10013 00af685f j_mayer
#endif
10014 a750fc0b j_mayer
        default:
10015 a750fc0b j_mayer
            excp_model = "Unknown or invalid";
10016 a750fc0b j_mayer
            break;
10017 a750fc0b j_mayer
        }
10018 a750fc0b j_mayer
        switch (env->bus_model) {
10019 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_6xx:
10020 a750fc0b j_mayer
            bus_model = "PowerPC 6xx";
10021 a750fc0b j_mayer
            break;
10022 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_BookE:
10023 a750fc0b j_mayer
            bus_model = "PowerPC BookE";
10024 a750fc0b j_mayer
            break;
10025 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_405:
10026 a750fc0b j_mayer
            bus_model = "PowerPC 405";
10027 a750fc0b j_mayer
            break;
10028 a750fc0b j_mayer
        case PPC_FLAGS_INPUT_401:
10029 a750fc0b j_mayer
            bus_model = "PowerPC 401/403";
10030 a750fc0b j_mayer
            break;
10031 b4095fed j_mayer
        case PPC_FLAGS_INPUT_RCPU:
10032 b4095fed j_mayer
            bus_model = "RCPU / MPC8xx";
10033 b4095fed j_mayer
            break;
10034 00af685f j_mayer
#if defined (TARGET_PPC64)
10035 00af685f j_mayer
        case PPC_FLAGS_INPUT_970:
10036 00af685f j_mayer
            bus_model = "PowerPC 970";
10037 00af685f j_mayer
            break;
10038 00af685f j_mayer
#endif
10039 a750fc0b j_mayer
        default:
10040 a750fc0b j_mayer
            bus_model = "Unknown or invalid";
10041 a750fc0b j_mayer
            break;
10042 a750fc0b j_mayer
        }
10043 a750fc0b j_mayer
        printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64 "\n"
10044 a750fc0b j_mayer
               "    MMU model        : %s\n",
10045 a750fc0b j_mayer
               def->name, def->pvr, def->msr_mask, mmu_model);
10046 f2e63a42 j_mayer
#if !defined(CONFIG_USER_ONLY)
10047 a750fc0b j_mayer
        if (env->tlb != NULL) {
10048 a750fc0b j_mayer
            printf("                       %d %s TLB in %d ways\n",
10049 a750fc0b j_mayer
                   env->nb_tlb, env->id_tlbs ? "splitted" : "merged",
10050 a750fc0b j_mayer
                   env->nb_ways);
10051 a750fc0b j_mayer
        }
10052 f2e63a42 j_mayer
#endif
10053 a750fc0b j_mayer
        printf("    Exceptions model : %s\n"
10054 a750fc0b j_mayer
               "    Bus model        : %s\n",
10055 a750fc0b j_mayer
               excp_model, bus_model);
10056 25ba3a68 j_mayer
        printf("    MSR features     :\n");
10057 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SPE)
10058 25ba3a68 j_mayer
            printf("                        signal processing engine enable"
10059 25ba3a68 j_mayer
                   "\n");
10060 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_VRE)
10061 25ba3a68 j_mayer
            printf("                        vector processor enable\n");
10062 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_TGPR)
10063 25ba3a68 j_mayer
            printf("                        temporary GPRs\n");
10064 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_CE)
10065 25ba3a68 j_mayer
            printf("                        critical input enable\n");
10066 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_SE)
10067 25ba3a68 j_mayer
            printf("                        single-step trace mode\n");
10068 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DWE)
10069 25ba3a68 j_mayer
            printf("                        debug wait enable\n");
10070 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_UBLE)
10071 25ba3a68 j_mayer
            printf("                        user BTB lock enable\n");
10072 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_BE)
10073 25ba3a68 j_mayer
            printf("                        branch-step trace mode\n");
10074 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_DE)
10075 25ba3a68 j_mayer
            printf("                        debug interrupt enable\n");
10076 25ba3a68 j_mayer
        if (env->flags & POWERPC_FLAG_PX)
10077 25ba3a68 j_mayer
            printf("                        inclusive protection\n");
10078 25ba3a68 j_mayer
        else if (env->flags & POWERPC_FLAG_PMM)
10079 25ba3a68 j_mayer
            printf("                        performance monitor mark\n");
10080 25ba3a68 j_mayer
        if (env->flags == POWERPC_FLAG_NONE)
10081 25ba3a68 j_mayer
            printf("                        none\n");
10082 4018bae9 j_mayer
        printf("    Time-base/decrementer clock source: %s\n",
10083 4018bae9 j_mayer
               env->flags & POWERPC_FLAG_RTC_CLK ? "RTC clock" : "bus clock");
10084 a750fc0b j_mayer
    }
10085 a750fc0b j_mayer
    dump_ppc_insns(env);
10086 a750fc0b j_mayer
    dump_ppc_sprs(env);
10087 a750fc0b j_mayer
    fflush(stdout);
10088 3a607854 j_mayer
#endif
10089 a750fc0b j_mayer
10090 a750fc0b j_mayer
    return 0;
10091 a750fc0b j_mayer
}
10092 3fc6c082 bellard
10093 f0ad8c34 Alexander Graf
static bool ppc_cpu_usable(const ppc_def_t *def)
10094 f0ad8c34 Alexander Graf
{
10095 f0ad8c34 Alexander Graf
#if defined(TARGET_PPCEMB)
10096 f0ad8c34 Alexander Graf
    /* When using the ppcemb target, we only support 440 style cores */
10097 f0ad8c34 Alexander Graf
    if (def->mmu_model != POWERPC_MMU_BOOKE) {
10098 f0ad8c34 Alexander Graf
        return false;
10099 f0ad8c34 Alexander Graf
    }
10100 f0ad8c34 Alexander Graf
#endif
10101 f0ad8c34 Alexander Graf
10102 f0ad8c34 Alexander Graf
    return true;
10103 f0ad8c34 Alexander Graf
}
10104 f0ad8c34 Alexander Graf
10105 a1e98583 David Gibson
const ppc_def_t *ppc_find_by_pvr(uint32_t pvr)
10106 3fc6c082 bellard
{
10107 be40edcd David Gibson
    int i;
10108 be40edcd David Gibson
10109 be40edcd David Gibson
    for (i = 0; i < ARRAY_SIZE(ppc_defs); i++) {
10110 f0ad8c34 Alexander Graf
        if (!ppc_cpu_usable(&ppc_defs[i])) {
10111 f0ad8c34 Alexander Graf
            continue;
10112 f0ad8c34 Alexander Graf
        }
10113 f0ad8c34 Alexander Graf
10114 be40edcd David Gibson
        /* If we have an exact match, we're done */
10115 be40edcd David Gibson
        if (pvr == ppc_defs[i].pvr) {
10116 be40edcd David Gibson
            return &ppc_defs[i];
10117 3fc6c082 bellard
        }
10118 3fc6c082 bellard
    }
10119 ee4e83ed j_mayer
10120 be40edcd David Gibson
    return NULL;
10121 3fc6c082 bellard
}
10122 3fc6c082 bellard
10123 ee4e83ed j_mayer
#include <ctype.h>
10124 3fc6c082 bellard
10125 c227f099 Anthony Liguori
const ppc_def_t *cpu_ppc_find_by_name (const char *name)
10126 ee4e83ed j_mayer
{
10127 c227f099 Anthony Liguori
    const ppc_def_t *ret;
10128 b55266b5 blueswir1
    const char *p;
10129 ee4e83ed j_mayer
    int i, max, len;
10130 ee4e83ed j_mayer
10131 a1e98583 David Gibson
    if (kvm_enabled() && (strcasecmp(name, "host") == 0)) {
10132 a1e98583 David Gibson
        return kvmppc_host_cpu_def();
10133 a1e98583 David Gibson
    }
10134 a1e98583 David Gibson
10135 ee4e83ed j_mayer
    /* Check if the given name is a PVR */
10136 ee4e83ed j_mayer
    len = strlen(name);
10137 ee4e83ed j_mayer
    if (len == 10 && name[0] == '0' && name[1] == 'x') {
10138 ee4e83ed j_mayer
        p = name + 2;
10139 ee4e83ed j_mayer
        goto check_pvr;
10140 ee4e83ed j_mayer
    } else if (len == 8) {
10141 ee4e83ed j_mayer
        p = name;
10142 ee4e83ed j_mayer
    check_pvr:
10143 ee4e83ed j_mayer
        for (i = 0; i < 8; i++) {
10144 cd390083 blueswir1
            if (!qemu_isxdigit(*p++))
10145 ee4e83ed j_mayer
                break;
10146 ee4e83ed j_mayer
        }
10147 ee4e83ed j_mayer
        if (i == 8)
10148 ee4e83ed j_mayer
            return ppc_find_by_pvr(strtoul(name, NULL, 16));
10149 ee4e83ed j_mayer
    }
10150 ee4e83ed j_mayer
    ret = NULL;
10151 b1503cda malc
    max = ARRAY_SIZE(ppc_defs);
10152 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
10153 f0ad8c34 Alexander Graf
        if (!ppc_cpu_usable(&ppc_defs[i])) {
10154 f0ad8c34 Alexander Graf
            continue;
10155 f0ad8c34 Alexander Graf
        }
10156 f0ad8c34 Alexander Graf
10157 ee4e83ed j_mayer
        if (strcasecmp(name, ppc_defs[i].name) == 0) {
10158 ee4e83ed j_mayer
            ret = &ppc_defs[i];
10159 ee4e83ed j_mayer
            break;
10160 3fc6c082 bellard
        }
10161 3fc6c082 bellard
    }
10162 ee4e83ed j_mayer
10163 ee4e83ed j_mayer
    return ret;
10164 3fc6c082 bellard
}
10165 3fc6c082 bellard
10166 9a78eead Stefan Weil
void ppc_cpu_list (FILE *f, fprintf_function cpu_fprintf)
10167 3fc6c082 bellard
{
10168 068abdc8 j_mayer
    int i, max;
10169 3fc6c082 bellard
10170 b1503cda malc
    max = ARRAY_SIZE(ppc_defs);
10171 068abdc8 j_mayer
    for (i = 0; i < max; i++) {
10172 f0ad8c34 Alexander Graf
        if (!ppc_cpu_usable(&ppc_defs[i])) {
10173 f0ad8c34 Alexander Graf
            continue;
10174 f0ad8c34 Alexander Graf
        }
10175 f0ad8c34 Alexander Graf
10176 a750fc0b j_mayer
        (*cpu_fprintf)(f, "PowerPC %-16s PVR %08x\n",
10177 a750fc0b j_mayer
                       ppc_defs[i].name, ppc_defs[i].pvr);
10178 3fc6c082 bellard
    }
10179 3fc6c082 bellard
}