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