Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ 1b413d55

History | View | Annotate | Download (266.8 kB)

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
#include "host-utils.h"
28

    
29
//#define PPC_DUMP_CPU
30
//#define PPC_DEBUG_SPR
31
//#define PPC_DEBUG_IRQ
32

    
33
struct ppc_def_t {
34
    const unsigned char *name;
35
    uint32_t pvr;
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
    uint32_t flags;
43
    int bfd_mach;
44
    void (*init_proc)(CPUPPCState *env);
45
    int (*check_pow)(CPUPPCState *env);
46
};
47

    
48
/* For user-mode emulation, we don't emulate any IRQ controller */
49
#if defined(CONFIG_USER_ONLY)
50
#define PPC_IRQ_INIT_FN(name)                                                 \
51
static inline void glue(glue(ppc, name),_irq_init) (CPUPPCState *env)         \
52
{                                                                             \
53
}
54
#else
55
#define PPC_IRQ_INIT_FN(name)                                                 \
56
void glue(glue(ppc, name),_irq_init) (CPUPPCState *env);
57
#endif
58

    
59
PPC_IRQ_INIT_FN(40x);
60
PPC_IRQ_INIT_FN(6xx);
61
PPC_IRQ_INIT_FN(970);
62

    
63
/* Generic callbacks:
64
 * do nothing but store/retrieve spr value
65
 */
66
#ifdef PPC_DUMP_SPR_ACCESSES
67
static void spr_read_generic (void *opaque, int sprn)
68
{
69
    gen_op_load_dump_spr(sprn);
70
}
71

    
72
static void spr_write_generic (void *opaque, int sprn)
73
{
74
    gen_op_store_dump_spr(sprn);
75
}
76
#else
77
static void spr_read_generic (void *opaque, int sprn)
78
{
79
    gen_op_load_spr(sprn);
80
}
81

    
82
static void spr_write_generic (void *opaque, int sprn)
83
{
84
    gen_op_store_spr(sprn);
85
}
86
#endif
87

    
88
#if !defined(CONFIG_USER_ONLY)
89
static void spr_write_clear (void *opaque, int sprn)
90
{
91
    gen_op_mask_spr(sprn);
92
}
93
#endif
94

    
95
/* SPR common to all PowerPC */
96
/* XER */
97
static void spr_read_xer (void *opaque, int sprn)
98
{
99
    gen_op_load_xer();
100
}
101

    
102
static void spr_write_xer (void *opaque, int sprn)
103
{
104
    gen_op_store_xer();
105
}
106

    
107
/* LR */
108
static void spr_read_lr (void *opaque, int sprn)
109
{
110
    gen_op_load_lr();
111
}
112

    
113
static void spr_write_lr (void *opaque, int sprn)
114
{
115
    gen_op_store_lr();
116
}
117

    
118
/* CTR */
119
static void spr_read_ctr (void *opaque, int sprn)
120
{
121
    gen_op_load_ctr();
122
}
123

    
124
static void spr_write_ctr (void *opaque, int sprn)
125
{
126
    gen_op_store_ctr();
127
}
128

    
129
/* User read access to SPR */
130
/* USPRx */
131
/* UMMCRx */
132
/* UPMCx */
133
/* USIA */
134
/* UDECR */
135
static void spr_read_ureg (void *opaque, int sprn)
136
{
137
    gen_op_load_spr(sprn + 0x10);
138
}
139

    
140
/* SPR common to all non-embedded PowerPC */
141
/* DECR */
142
#if !defined(CONFIG_USER_ONLY)
143
static void spr_read_decr (void *opaque, int sprn)
144
{
145
    gen_op_load_decr();
146
}
147

    
148
static void spr_write_decr (void *opaque, int sprn)
149
{
150
    gen_op_store_decr();
151
}
152
#endif
153

    
154
/* SPR common to all non-embedded PowerPC, except 601 */
155
/* Time base */
156
static void spr_read_tbl (void *opaque, int sprn)
157
{
158
    gen_op_load_tbl();
159
}
160

    
161
static void spr_read_tbu (void *opaque, int sprn)
162
{
163
    gen_op_load_tbu();
164
}
165

    
166
__attribute__ (( unused ))
167
static void spr_read_atbl (void *opaque, int sprn)
168
{
169
    gen_op_load_atbl();
170
}
171

    
172
__attribute__ (( unused ))
173
static void spr_read_atbu (void *opaque, int sprn)
174
{
175
    gen_op_load_atbu();
176
}
177

    
178
#if !defined(CONFIG_USER_ONLY)
179
static void spr_write_tbl (void *opaque, int sprn)
180
{
181
    gen_op_store_tbl();
182
}
183

    
184
static void spr_write_tbu (void *opaque, int sprn)
185
{
186
    gen_op_store_tbu();
187
}
188

    
189
__attribute__ (( unused ))
190
static void spr_write_atbl (void *opaque, int sprn)
191
{
192
    gen_op_store_atbl();
193
}
194

    
195
__attribute__ (( unused ))
196
static void spr_write_atbu (void *opaque, int sprn)
197
{
198
    gen_op_store_atbu();
199
}
200
#endif
201

    
202
#if !defined(CONFIG_USER_ONLY)
203
/* IBAT0U...IBAT0U */
204
/* IBAT0L...IBAT7L */
205
static void spr_read_ibat (void *opaque, int sprn)
206
{
207
    gen_op_load_ibat(sprn & 1, (sprn - SPR_IBAT0U) / 2);
208
}
209

    
210
static void spr_read_ibat_h (void *opaque, int sprn)
211
{
212
    gen_op_load_ibat(sprn & 1, (sprn - SPR_IBAT4U) / 2);
213
}
214

    
215
static void spr_write_ibatu (void *opaque, int sprn)
216
{
217
    gen_op_store_ibatu((sprn - SPR_IBAT0U) / 2);
218
}
219

    
220
static void spr_write_ibatu_h (void *opaque, int sprn)
221
{
222
    gen_op_store_ibatu((sprn - SPR_IBAT4U) / 2);
223
}
224

    
225
static void spr_write_ibatl (void *opaque, int sprn)
226
{
227
    gen_op_store_ibatl((sprn - SPR_IBAT0L) / 2);
228
}
229

    
230
static void spr_write_ibatl_h (void *opaque, int sprn)
231
{
232
    gen_op_store_ibatl((sprn - SPR_IBAT4L) / 2);
233
}
234

    
235
/* DBAT0U...DBAT7U */
236
/* DBAT0L...DBAT7L */
237
static void spr_read_dbat (void *opaque, int sprn)
238
{
239
    gen_op_load_dbat(sprn & 1, (sprn - SPR_DBAT0U) / 2);
240
}
241

    
242
static void spr_read_dbat_h (void *opaque, int sprn)
243
{
244
    gen_op_load_dbat(sprn & 1, ((sprn - SPR_DBAT4U) / 2) + 4);
245
}
246

    
247
static void spr_write_dbatu (void *opaque, int sprn)
248
{
249
    gen_op_store_dbatu((sprn - SPR_DBAT0U) / 2);
250
}
251

    
252
static void spr_write_dbatu_h (void *opaque, int sprn)
253
{
254
    gen_op_store_dbatu(((sprn - SPR_DBAT4U) / 2) + 4);
255
}
256

    
257
static void spr_write_dbatl (void *opaque, int sprn)
258
{
259
    gen_op_store_dbatl((sprn - SPR_DBAT0L) / 2);
260
}
261

    
262
static void spr_write_dbatl_h (void *opaque, int sprn)
263
{
264
    gen_op_store_dbatl(((sprn - SPR_DBAT4L) / 2) + 4);
265
}
266

    
267
/* SDR1 */
268
static void spr_read_sdr1 (void *opaque, int sprn)
269
{
270
    gen_op_load_sdr1();
271
}
272

    
273
static void spr_write_sdr1 (void *opaque, int sprn)
274
{
275
    gen_op_store_sdr1();
276
}
277

    
278
/* 64 bits PowerPC specific SPRs */
279
/* ASR */
280
#if defined(TARGET_PPC64)
281
__attribute__ (( unused ))
282
static void spr_read_asr (void *opaque, int sprn)
283
{
284
    gen_op_load_asr();
285
}
286

    
287
__attribute__ (( unused ))
288
static void spr_write_asr (void *opaque, int sprn)
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

    
318
static void spr_write_hid0_601 (void *opaque, int sprn)
319
{
320
    DisasContext *ctx = opaque;
321

    
322
    gen_op_store_hid0_601();
323
    /* Must stop the translation as endianness may have changed */
324
    GEN_STOP(ctx);
325
}
326
#endif
327

    
328
/* Unified bats */
329
#if !defined(CONFIG_USER_ONLY)
330
static void spr_read_601_ubat (void *opaque, int sprn)
331
{
332
    gen_op_load_601_bat(sprn & 1, (sprn - SPR_IBAT0U) / 2);
333
}
334

    
335
static void spr_write_601_ubatu (void *opaque, int sprn)
336
{
337
    gen_op_store_601_batu((sprn - SPR_IBAT0U) / 2);
338
}
339

    
340
static void spr_write_601_ubatl (void *opaque, int sprn)
341
{
342
    gen_op_store_601_batl((sprn - SPR_IBAT0L) / 2);
343
}
344
#endif
345

    
346
/* PowerPC 40x specific registers */
347
#if !defined(CONFIG_USER_ONLY)
348
static void spr_read_40x_pit (void *opaque, int sprn)
349
{
350
    gen_op_load_40x_pit();
351
}
352

    
353
static void spr_write_40x_pit (void *opaque, int sprn)
354
{
355
    gen_op_store_40x_pit();
356
}
357

    
358
static void spr_write_40x_dbcr0 (void *opaque, int sprn)
359
{
360
    DisasContext *ctx = opaque;
361

    
362
    gen_op_store_40x_dbcr0();
363
    /* We must stop translation as we may have rebooted */
364
    GEN_STOP(ctx);
365
}
366

    
367
static void spr_write_40x_sler (void *opaque, int sprn)
368
{
369
    gen_op_store_40x_sler();
370
}
371

    
372
static void spr_write_booke_tcr (void *opaque, int sprn)
373
{
374
    gen_op_store_booke_tcr();
375
}
376

    
377
static void spr_write_booke_tsr (void *opaque, int sprn)
378
{
379
    gen_op_store_booke_tsr();
380
}
381
#endif
382

    
383
/* PowerPC 403 specific registers */
384
/* PBL1 / PBU1 / PBL2 / PBU2 */
385
#if !defined(CONFIG_USER_ONLY)
386
static void spr_read_403_pbr (void *opaque, int sprn)
387
{
388
    gen_op_load_403_pb(sprn - SPR_403_PBL1);
389
}
390

    
391
static void spr_write_403_pbr (void *opaque, int sprn)
392
{
393
    gen_op_store_403_pb(sprn - SPR_403_PBL1);
394
}
395

    
396
static void spr_write_pir (void *opaque, int sprn)
397
{
398
    gen_op_store_pir();
399
}
400
#endif
401

    
402
#if !defined(CONFIG_USER_ONLY)
403
/* Callback used to write the exception vector base */
404
static void spr_write_excp_prefix (void *opaque, int sprn)
405
{
406
    gen_op_store_excp_prefix();
407
    gen_op_store_spr(sprn);
408
}
409

    
410
static void spr_write_excp_vector (void *opaque, int sprn)
411
{
412
    DisasContext *ctx = opaque;
413

    
414
    if (sprn >= SPR_BOOKE_IVOR0 && sprn <= SPR_BOOKE_IVOR15) {
415
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR0);
416
        gen_op_store_spr(sprn);
417
    } else if (sprn >= SPR_BOOKE_IVOR32 && sprn <= SPR_BOOKE_IVOR37) {
418
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR32 + 32);
419
        gen_op_store_spr(sprn);
420
    } else {
421
        printf("Trying to write an unknown exception vector %d %03x\n",
422
               sprn, sprn);
423
        GEN_EXCP_PRIVREG(ctx);
424
    }
425
}
426
#endif
427

    
428
#if defined(CONFIG_USER_ONLY)
429
#define spr_register(env, num, name, uea_read, uea_write,                     \
430
                     oea_read, oea_write, initial_value)                      \
431
do {                                                                          \
432
     _spr_register(env, num, name, uea_read, uea_write, initial_value);       \
433
} while (0)
434
static inline void _spr_register (CPUPPCState *env, int num,
435
                                  const unsigned char *name,
436
                                  void (*uea_read)(void *opaque, int sprn),
437
                                  void (*uea_write)(void *opaque, int sprn),
438
                                  target_ulong initial_value)
439
#else
440
static inline void spr_register (CPUPPCState *env, int num,
441
                                 const unsigned char *name,
442
                                 void (*uea_read)(void *opaque, int sprn),
443
                                 void (*uea_write)(void *opaque, int sprn),
444
                                 void (*oea_read)(void *opaque, int sprn),
445
                                 void (*oea_write)(void *opaque, int sprn),
446
                                 target_ulong initial_value)
447
#endif
448
{
449
    ppc_spr_t *spr;
450

    
451
    spr = &env->spr_cb[num];
452
    if (spr->name != NULL ||env-> spr[num] != 0x00000000 ||
453
#if !defined(CONFIG_USER_ONLY)
454
        spr->oea_read != NULL || spr->oea_write != NULL ||
455
#endif
456
        spr->uea_read != NULL || spr->uea_write != NULL) {
457
        printf("Error: Trying to register SPR %d (%03x) twice !\n", num, num);
458
        exit(1);
459
    }
460
#if defined(PPC_DEBUG_SPR)
461
    printf("*** register spr %d (%03x) %s val " ADDRX "\n", num, num, name,
462
           initial_value);
463
#endif
464
    spr->name = name;
465
    spr->uea_read = uea_read;
466
    spr->uea_write = uea_write;
467
#if !defined(CONFIG_USER_ONLY)
468
    spr->oea_read = oea_read;
469
    spr->oea_write = oea_write;
470
#endif
471
    env->spr[num] = initial_value;
472
}
473

    
474
/* Generic PowerPC SPRs */
475
static void gen_spr_generic (CPUPPCState *env)
476
{
477
    /* Integer processing */
478
    spr_register(env, SPR_XER, "XER",
479
                 &spr_read_xer, &spr_write_xer,
480
                 &spr_read_xer, &spr_write_xer,
481
                 0x00000000);
482
    /* Branch contol */
483
    spr_register(env, SPR_LR, "LR",
484
                 &spr_read_lr, &spr_write_lr,
485
                 &spr_read_lr, &spr_write_lr,
486
                 0x00000000);
487
    spr_register(env, SPR_CTR, "CTR",
488
                 &spr_read_ctr, &spr_write_ctr,
489
                 &spr_read_ctr, &spr_write_ctr,
490
                 0x00000000);
491
    /* Interrupt processing */
492
    spr_register(env, SPR_SRR0, "SRR0",
493
                 SPR_NOACCESS, SPR_NOACCESS,
494
                 &spr_read_generic, &spr_write_generic,
495
                 0x00000000);
496
    spr_register(env, SPR_SRR1, "SRR1",
497
                 SPR_NOACCESS, SPR_NOACCESS,
498
                 &spr_read_generic, &spr_write_generic,
499
                 0x00000000);
500
    /* Processor control */
501
    spr_register(env, SPR_SPRG0, "SPRG0",
502
                 SPR_NOACCESS, SPR_NOACCESS,
503
                 &spr_read_generic, &spr_write_generic,
504
                 0x00000000);
505
    spr_register(env, SPR_SPRG1, "SPRG1",
506
                 SPR_NOACCESS, SPR_NOACCESS,
507
                 &spr_read_generic, &spr_write_generic,
508
                 0x00000000);
509
    spr_register(env, SPR_SPRG2, "SPRG2",
510
                 SPR_NOACCESS, SPR_NOACCESS,
511
                 &spr_read_generic, &spr_write_generic,
512
                 0x00000000);
513
    spr_register(env, SPR_SPRG3, "SPRG3",
514
                 SPR_NOACCESS, SPR_NOACCESS,
515
                 &spr_read_generic, &spr_write_generic,
516
                 0x00000000);
517
}
518

    
519
/* SPR common to all non-embedded PowerPC, including 601 */
520
static void gen_spr_ne_601 (CPUPPCState *env)
521
{
522
    /* Exception processing */
523
    spr_register(env, SPR_DSISR, "DSISR",
524
                 SPR_NOACCESS, SPR_NOACCESS,
525
                 &spr_read_generic, &spr_write_generic,
526
                 0x00000000);
527
    spr_register(env, SPR_DAR, "DAR",
528
                 SPR_NOACCESS, SPR_NOACCESS,
529
                 &spr_read_generic, &spr_write_generic,
530
                 0x00000000);
531
    /* Timer */
532
    spr_register(env, SPR_DECR, "DECR",
533
                 SPR_NOACCESS, SPR_NOACCESS,
534
                 &spr_read_decr, &spr_write_decr,
535
                 0x00000000);
536
    /* Memory management */
537
    spr_register(env, SPR_SDR1, "SDR1",
538
                 SPR_NOACCESS, SPR_NOACCESS,
539
                 &spr_read_sdr1, &spr_write_sdr1,
540
                 0x00000000);
541
}
542

    
543
/* BATs 0-3 */
544
static void gen_low_BATs (CPUPPCState *env)
545
{
546
#if !defined(CONFIG_USER_ONLY)
547
    spr_register(env, SPR_IBAT0U, "IBAT0U",
548
                 SPR_NOACCESS, SPR_NOACCESS,
549
                 &spr_read_ibat, &spr_write_ibatu,
550
                 0x00000000);
551
    spr_register(env, SPR_IBAT0L, "IBAT0L",
552
                 SPR_NOACCESS, SPR_NOACCESS,
553
                 &spr_read_ibat, &spr_write_ibatl,
554
                 0x00000000);
555
    spr_register(env, SPR_IBAT1U, "IBAT1U",
556
                 SPR_NOACCESS, SPR_NOACCESS,
557
                 &spr_read_ibat, &spr_write_ibatu,
558
                 0x00000000);
559
    spr_register(env, SPR_IBAT1L, "IBAT1L",
560
                 SPR_NOACCESS, SPR_NOACCESS,
561
                 &spr_read_ibat, &spr_write_ibatl,
562
                 0x00000000);
563
    spr_register(env, SPR_IBAT2U, "IBAT2U",
564
                 SPR_NOACCESS, SPR_NOACCESS,
565
                 &spr_read_ibat, &spr_write_ibatu,
566
                 0x00000000);
567
    spr_register(env, SPR_IBAT2L, "IBAT2L",
568
                 SPR_NOACCESS, SPR_NOACCESS,
569
                 &spr_read_ibat, &spr_write_ibatl,
570
                 0x00000000);
571
    spr_register(env, SPR_IBAT3U, "IBAT3U",
572
                 SPR_NOACCESS, SPR_NOACCESS,
573
                 &spr_read_ibat, &spr_write_ibatu,
574
                 0x00000000);
575
    spr_register(env, SPR_IBAT3L, "IBAT3L",
576
                 SPR_NOACCESS, SPR_NOACCESS,
577
                 &spr_read_ibat, &spr_write_ibatl,
578
                 0x00000000);
579
    spr_register(env, SPR_DBAT0U, "DBAT0U",
580
                 SPR_NOACCESS, SPR_NOACCESS,
581
                 &spr_read_dbat, &spr_write_dbatu,
582
                 0x00000000);
583
    spr_register(env, SPR_DBAT0L, "DBAT0L",
584
                 SPR_NOACCESS, SPR_NOACCESS,
585
                 &spr_read_dbat, &spr_write_dbatl,
586
                 0x00000000);
587
    spr_register(env, SPR_DBAT1U, "DBAT1U",
588
                 SPR_NOACCESS, SPR_NOACCESS,
589
                 &spr_read_dbat, &spr_write_dbatu,
590
                 0x00000000);
591
    spr_register(env, SPR_DBAT1L, "DBAT1L",
592
                 SPR_NOACCESS, SPR_NOACCESS,
593
                 &spr_read_dbat, &spr_write_dbatl,
594
                 0x00000000);
595
    spr_register(env, SPR_DBAT2U, "DBAT2U",
596
                 SPR_NOACCESS, SPR_NOACCESS,
597
                 &spr_read_dbat, &spr_write_dbatu,
598
                 0x00000000);
599
    spr_register(env, SPR_DBAT2L, "DBAT2L",
600
                 SPR_NOACCESS, SPR_NOACCESS,
601
                 &spr_read_dbat, &spr_write_dbatl,
602
                 0x00000000);
603
    spr_register(env, SPR_DBAT3U, "DBAT3U",
604
                 SPR_NOACCESS, SPR_NOACCESS,
605
                 &spr_read_dbat, &spr_write_dbatu,
606
                 0x00000000);
607
    spr_register(env, SPR_DBAT3L, "DBAT3L",
608
                 SPR_NOACCESS, SPR_NOACCESS,
609
                 &spr_read_dbat, &spr_write_dbatl,
610
                 0x00000000);
611
    env->nb_BATs += 4;
612
#endif
613
}
614

    
615
/* BATs 4-7 */
616
static void gen_high_BATs (CPUPPCState *env)
617
{
618
#if !defined(CONFIG_USER_ONLY)
619
    spr_register(env, SPR_IBAT4U, "IBAT4U",
620
                 SPR_NOACCESS, SPR_NOACCESS,
621
                 &spr_read_ibat_h, &spr_write_ibatu_h,
622
                 0x00000000);
623
    spr_register(env, SPR_IBAT4L, "IBAT4L",
624
                 SPR_NOACCESS, SPR_NOACCESS,
625
                 &spr_read_ibat_h, &spr_write_ibatl_h,
626
                 0x00000000);
627
    spr_register(env, SPR_IBAT5U, "IBAT5U",
628
                 SPR_NOACCESS, SPR_NOACCESS,
629
                 &spr_read_ibat_h, &spr_write_ibatu_h,
630
                 0x00000000);
631
    spr_register(env, SPR_IBAT5L, "IBAT5L",
632
                 SPR_NOACCESS, SPR_NOACCESS,
633
                 &spr_read_ibat_h, &spr_write_ibatl_h,
634
                 0x00000000);
635
    spr_register(env, SPR_IBAT6U, "IBAT6U",
636
                 SPR_NOACCESS, SPR_NOACCESS,
637
                 &spr_read_ibat_h, &spr_write_ibatu_h,
638
                 0x00000000);
639
    spr_register(env, SPR_IBAT6L, "IBAT6L",
640
                 SPR_NOACCESS, SPR_NOACCESS,
641
                 &spr_read_ibat_h, &spr_write_ibatl_h,
642
                 0x00000000);
643
    spr_register(env, SPR_IBAT7U, "IBAT7U",
644
                 SPR_NOACCESS, SPR_NOACCESS,
645
                 &spr_read_ibat_h, &spr_write_ibatu_h,
646
                 0x00000000);
647
    spr_register(env, SPR_IBAT7L, "IBAT7L",
648
                 SPR_NOACCESS, SPR_NOACCESS,
649
                 &spr_read_ibat_h, &spr_write_ibatl_h,
650
                 0x00000000);
651
    spr_register(env, SPR_DBAT4U, "DBAT4U",
652
                 SPR_NOACCESS, SPR_NOACCESS,
653
                 &spr_read_dbat_h, &spr_write_dbatu_h,
654
                 0x00000000);
655
    spr_register(env, SPR_DBAT4L, "DBAT4L",
656
                 SPR_NOACCESS, SPR_NOACCESS,
657
                 &spr_read_dbat_h, &spr_write_dbatl_h,
658
                 0x00000000);
659
    spr_register(env, SPR_DBAT5U, "DBAT5U",
660
                 SPR_NOACCESS, SPR_NOACCESS,
661
                 &spr_read_dbat_h, &spr_write_dbatu_h,
662
                 0x00000000);
663
    spr_register(env, SPR_DBAT5L, "DBAT5L",
664
                 SPR_NOACCESS, SPR_NOACCESS,
665
                 &spr_read_dbat_h, &spr_write_dbatl_h,
666
                 0x00000000);
667
    spr_register(env, SPR_DBAT6U, "DBAT6U",
668
                 SPR_NOACCESS, SPR_NOACCESS,
669
                 &spr_read_dbat_h, &spr_write_dbatu_h,
670
                 0x00000000);
671
    spr_register(env, SPR_DBAT6L, "DBAT6L",
672
                 SPR_NOACCESS, SPR_NOACCESS,
673
                 &spr_read_dbat_h, &spr_write_dbatl_h,
674
                 0x00000000);
675
    spr_register(env, SPR_DBAT7U, "DBAT7U",
676
                 SPR_NOACCESS, SPR_NOACCESS,
677
                 &spr_read_dbat_h, &spr_write_dbatu_h,
678
                 0x00000000);
679
    spr_register(env, SPR_DBAT7L, "DBAT7L",
680
                 SPR_NOACCESS, SPR_NOACCESS,
681
                 &spr_read_dbat_h, &spr_write_dbatl_h,
682
                 0x00000000);
683
    env->nb_BATs += 4;
684
#endif
685
}
686

    
687
/* Generic PowerPC time base */
688
static void gen_tbl (CPUPPCState *env)
689
{
690
    spr_register(env, SPR_VTBL,  "TBL",
691
                 &spr_read_tbl, SPR_NOACCESS,
692
                 &spr_read_tbl, SPR_NOACCESS,
693
                 0x00000000);
694
    spr_register(env, SPR_TBL,   "TBL",
695
                 SPR_NOACCESS, SPR_NOACCESS,
696
                 SPR_NOACCESS, &spr_write_tbl,
697
                 0x00000000);
698
    spr_register(env, SPR_VTBU,  "TBU",
699
                 &spr_read_tbu, SPR_NOACCESS,
700
                 &spr_read_tbu, SPR_NOACCESS,
701
                 0x00000000);
702
    spr_register(env, SPR_TBU,   "TBU",
703
                 SPR_NOACCESS, SPR_NOACCESS,
704
                 SPR_NOACCESS, &spr_write_tbu,
705
                 0x00000000);
706
}
707

    
708
/* Softare table search registers */
709
static void gen_6xx_7xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
710
{
711
#if !defined(CONFIG_USER_ONLY)
712
    env->nb_tlb = nb_tlbs;
713
    env->nb_ways = nb_ways;
714
    env->id_tlbs = 1;
715
    spr_register(env, SPR_DMISS, "DMISS",
716
                 SPR_NOACCESS, SPR_NOACCESS,
717
                 &spr_read_generic, SPR_NOACCESS,
718
                 0x00000000);
719
    spr_register(env, SPR_DCMP, "DCMP",
720
                 SPR_NOACCESS, SPR_NOACCESS,
721
                 &spr_read_generic, SPR_NOACCESS,
722
                 0x00000000);
723
    spr_register(env, SPR_HASH1, "HASH1",
724
                 SPR_NOACCESS, SPR_NOACCESS,
725
                 &spr_read_generic, SPR_NOACCESS,
726
                 0x00000000);
727
    spr_register(env, SPR_HASH2, "HASH2",
728
                 SPR_NOACCESS, SPR_NOACCESS,
729
                 &spr_read_generic, SPR_NOACCESS,
730
                 0x00000000);
731
    spr_register(env, SPR_IMISS, "IMISS",
732
                 SPR_NOACCESS, SPR_NOACCESS,
733
                 &spr_read_generic, SPR_NOACCESS,
734
                 0x00000000);
735
    spr_register(env, SPR_ICMP, "ICMP",
736
                 SPR_NOACCESS, SPR_NOACCESS,
737
                 &spr_read_generic, SPR_NOACCESS,
738
                 0x00000000);
739
    spr_register(env, SPR_RPA, "RPA",
740
                 SPR_NOACCESS, SPR_NOACCESS,
741
                 &spr_read_generic, &spr_write_generic,
742
                 0x00000000);
743
#endif
744
}
745

    
746
/* SPR common to MPC755 and G2 */
747
static void gen_spr_G2_755 (CPUPPCState *env)
748
{
749
    /* SGPRs */
750
    spr_register(env, SPR_SPRG4, "SPRG4",
751
                 SPR_NOACCESS, SPR_NOACCESS,
752
                 &spr_read_generic, &spr_write_generic,
753
                 0x00000000);
754
    spr_register(env, SPR_SPRG5, "SPRG5",
755
                 SPR_NOACCESS, SPR_NOACCESS,
756
                 &spr_read_generic, &spr_write_generic,
757
                 0x00000000);
758
    spr_register(env, SPR_SPRG6, "SPRG6",
759
                 SPR_NOACCESS, SPR_NOACCESS,
760
                 &spr_read_generic, &spr_write_generic,
761
                 0x00000000);
762
    spr_register(env, SPR_SPRG7, "SPRG7",
763
                 SPR_NOACCESS, SPR_NOACCESS,
764
                 &spr_read_generic, &spr_write_generic,
765
                 0x00000000);
766
    /* External access control */
767
    /* XXX : not implemented */
768
    spr_register(env, SPR_EAR, "EAR",
769
                 SPR_NOACCESS, SPR_NOACCESS,
770
                 &spr_read_generic, &spr_write_generic,
771
                 0x00000000);
772
}
773

    
774
/* SPR common to all 7xx PowerPC implementations */
775
static void gen_spr_7xx (CPUPPCState *env)
776
{
777
    /* Breakpoints */
778
    /* XXX : not implemented */
779
    spr_register(env, SPR_DABR, "DABR",
780
                 SPR_NOACCESS, SPR_NOACCESS,
781
                 &spr_read_generic, &spr_write_generic,
782
                 0x00000000);
783
    /* XXX : not implemented */
784
    spr_register(env, SPR_IABR, "IABR",
785
                 SPR_NOACCESS, SPR_NOACCESS,
786
                 &spr_read_generic, &spr_write_generic,
787
                 0x00000000);
788
    /* Cache management */
789
    /* XXX : not implemented */
790
    spr_register(env, SPR_ICTC, "ICTC",
791
                 SPR_NOACCESS, SPR_NOACCESS,
792
                 &spr_read_generic, &spr_write_generic,
793
                 0x00000000);
794
    /* XXX : not implemented */
795
    spr_register(env, SPR_L2CR, "L2CR",
796
                 SPR_NOACCESS, SPR_NOACCESS,
797
                 &spr_read_generic, &spr_write_generic,
798
                 0x00000000);
799
    /* Performance monitors */
800
    /* XXX : not implemented */
801
    spr_register(env, SPR_MMCR0, "MMCR0",
802
                 SPR_NOACCESS, SPR_NOACCESS,
803
                 &spr_read_generic, &spr_write_generic,
804
                 0x00000000);
805
    /* XXX : not implemented */
806
    spr_register(env, SPR_MMCR1, "MMCR1",
807
                 SPR_NOACCESS, SPR_NOACCESS,
808
                 &spr_read_generic, &spr_write_generic,
809
                 0x00000000);
810
    /* XXX : not implemented */
811
    spr_register(env, SPR_PMC1, "PMC1",
812
                 SPR_NOACCESS, SPR_NOACCESS,
813
                 &spr_read_generic, &spr_write_generic,
814
                 0x00000000);
815
    /* XXX : not implemented */
816
    spr_register(env, SPR_PMC2, "PMC2",
817
                 SPR_NOACCESS, SPR_NOACCESS,
818
                 &spr_read_generic, &spr_write_generic,
819
                 0x00000000);
820
    /* XXX : not implemented */
821
    spr_register(env, SPR_PMC3, "PMC3",
822
                 SPR_NOACCESS, SPR_NOACCESS,
823
                 &spr_read_generic, &spr_write_generic,
824
                 0x00000000);
825
    /* XXX : not implemented */
826
    spr_register(env, SPR_PMC4, "PMC4",
827
                 SPR_NOACCESS, SPR_NOACCESS,
828
                 &spr_read_generic, &spr_write_generic,
829
                 0x00000000);
830
    /* XXX : not implemented */
831
    spr_register(env, SPR_SIAR, "SIAR",
832
                 SPR_NOACCESS, SPR_NOACCESS,
833
                 &spr_read_generic, SPR_NOACCESS,
834
                 0x00000000);
835
    /* XXX : not implemented */
836
    spr_register(env, SPR_UMMCR0, "UMMCR0",
837
                 &spr_read_ureg, SPR_NOACCESS,
838
                 &spr_read_ureg, SPR_NOACCESS,
839
                 0x00000000);
840
    /* XXX : not implemented */
841
    spr_register(env, SPR_UMMCR1, "UMMCR1",
842
                 &spr_read_ureg, SPR_NOACCESS,
843
                 &spr_read_ureg, SPR_NOACCESS,
844
                 0x00000000);
845
    /* XXX : not implemented */
846
    spr_register(env, SPR_UPMC1, "UPMC1",
847
                 &spr_read_ureg, SPR_NOACCESS,
848
                 &spr_read_ureg, SPR_NOACCESS,
849
                 0x00000000);
850
    /* XXX : not implemented */
851
    spr_register(env, SPR_UPMC2, "UPMC2",
852
                 &spr_read_ureg, SPR_NOACCESS,
853
                 &spr_read_ureg, SPR_NOACCESS,
854
                 0x00000000);
855
    /* XXX : not implemented */
856
    spr_register(env, SPR_UPMC3, "UPMC3",
857
                 &spr_read_ureg, SPR_NOACCESS,
858
                 &spr_read_ureg, SPR_NOACCESS,
859
                 0x00000000);
860
    /* XXX : not implemented */
861
    spr_register(env, SPR_UPMC4, "UPMC4",
862
                 &spr_read_ureg, SPR_NOACCESS,
863
                 &spr_read_ureg, SPR_NOACCESS,
864
                 0x00000000);
865
    /* XXX : not implemented */
866
    spr_register(env, SPR_USIAR, "USIAR",
867
                 &spr_read_ureg, SPR_NOACCESS,
868
                 &spr_read_ureg, SPR_NOACCESS,
869
                 0x00000000);
870
    /* External access control */
871
    /* XXX : not implemented */
872
    spr_register(env, SPR_EAR, "EAR",
873
                 SPR_NOACCESS, SPR_NOACCESS,
874
                 &spr_read_generic, &spr_write_generic,
875
                 0x00000000);
876
}
877

    
878
static void gen_spr_thrm (CPUPPCState *env)
879
{
880
    /* Thermal management */
881
    /* XXX : not implemented */
882
    spr_register(env, SPR_THRM1, "THRM1",
883
                 SPR_NOACCESS, SPR_NOACCESS,
884
                 &spr_read_generic, &spr_write_generic,
885
                 0x00000000);
886
    /* XXX : not implemented */
887
    spr_register(env, SPR_THRM2, "THRM2",
888
                 SPR_NOACCESS, SPR_NOACCESS,
889
                 &spr_read_generic, &spr_write_generic,
890
                 0x00000000);
891
    /* XXX : not implemented */
892
    spr_register(env, SPR_THRM3, "THRM3",
893
                 SPR_NOACCESS, SPR_NOACCESS,
894
                 &spr_read_generic, &spr_write_generic,
895
                 0x00000000);
896
}
897

    
898
/* SPR specific to PowerPC 604 implementation */
899
static void gen_spr_604 (CPUPPCState *env)
900
{
901
    /* Processor identification */
902
    spr_register(env, SPR_PIR, "PIR",
903
                 SPR_NOACCESS, SPR_NOACCESS,
904
                 &spr_read_generic, &spr_write_pir,
905
                 0x00000000);
906
    /* Breakpoints */
907
    /* XXX : not implemented */
908
    spr_register(env, SPR_IABR, "IABR",
909
                 SPR_NOACCESS, SPR_NOACCESS,
910
                 &spr_read_generic, &spr_write_generic,
911
                 0x00000000);
912
    /* XXX : not implemented */
913
    spr_register(env, SPR_DABR, "DABR",
914
                 SPR_NOACCESS, SPR_NOACCESS,
915
                 &spr_read_generic, &spr_write_generic,
916
                 0x00000000);
917
    /* Performance counters */
918
    /* XXX : not implemented */
919
    spr_register(env, SPR_MMCR0, "MMCR0",
920
                 SPR_NOACCESS, SPR_NOACCESS,
921
                 &spr_read_generic, &spr_write_generic,
922
                 0x00000000);
923
    /* XXX : not implemented */
924
    spr_register(env, SPR_MMCR1, "MMCR1",
925
                 SPR_NOACCESS, SPR_NOACCESS,
926
                 &spr_read_generic, &spr_write_generic,
927
                 0x00000000);
928
    /* XXX : not implemented */
929
    spr_register(env, SPR_PMC1, "PMC1",
930
                 SPR_NOACCESS, SPR_NOACCESS,
931
                 &spr_read_generic, &spr_write_generic,
932
                 0x00000000);
933
    /* XXX : not implemented */
934
    spr_register(env, SPR_PMC2, "PMC2",
935
                 SPR_NOACCESS, SPR_NOACCESS,
936
                 &spr_read_generic, &spr_write_generic,
937
                 0x00000000);
938
    /* XXX : not implemented */
939
    spr_register(env, SPR_PMC3, "PMC3",
940
                 SPR_NOACCESS, SPR_NOACCESS,
941
                 &spr_read_generic, &spr_write_generic,
942
                 0x00000000);
943
    /* XXX : not implemented */
944
    spr_register(env, SPR_PMC4, "PMC4",
945
                 SPR_NOACCESS, SPR_NOACCESS,
946
                 &spr_read_generic, &spr_write_generic,
947
                 0x00000000);
948
    /* XXX : not implemented */
949
    spr_register(env, SPR_SIAR, "SIAR",
950
                 SPR_NOACCESS, SPR_NOACCESS,
951
                 &spr_read_generic, SPR_NOACCESS,
952
                 0x00000000);
953
    /* XXX : not implemented */
954
    spr_register(env, SPR_SDA, "SDA",
955
                 SPR_NOACCESS, SPR_NOACCESS,
956
                 &spr_read_generic, SPR_NOACCESS,
957
                 0x00000000);
958
    /* External access control */
959
    /* XXX : not implemented */
960
    spr_register(env, SPR_EAR, "EAR",
961
                 SPR_NOACCESS, SPR_NOACCESS,
962
                 &spr_read_generic, &spr_write_generic,
963
                 0x00000000);
964
}
965

    
966
/* SPR specific to PowerPC 603 implementation */
967
static void gen_spr_603 (CPUPPCState *env)
968
{
969
    /* External access control */
970
    /* XXX : not implemented */
971
    spr_register(env, SPR_EAR, "EAR",
972
                 SPR_NOACCESS, SPR_NOACCESS,
973
                 &spr_read_generic, &spr_write_generic,
974
                 0x00000000);
975
}
976

    
977
/* SPR specific to PowerPC G2 implementation */
978
static void gen_spr_G2 (CPUPPCState *env)
979
{
980
    /* Memory base address */
981
    /* MBAR */
982
    /* XXX : not implemented */
983
    spr_register(env, SPR_MBAR, "MBAR",
984
                 SPR_NOACCESS, SPR_NOACCESS,
985
                 &spr_read_generic, &spr_write_generic,
986
                 0x00000000);
987
    /* System version register */
988
    /* SVR */
989
    /* XXX : TODO: initialize it to an appropriate value */
990
    spr_register(env, SPR_SVR, "SVR",
991
                 SPR_NOACCESS, SPR_NOACCESS,
992
                 &spr_read_generic, SPR_NOACCESS,
993
                 0x00000000);
994
    /* Exception processing */
995
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
996
                 SPR_NOACCESS, SPR_NOACCESS,
997
                 &spr_read_generic, &spr_write_generic,
998
                 0x00000000);
999
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
1000
                 SPR_NOACCESS, SPR_NOACCESS,
1001
                 &spr_read_generic, &spr_write_generic,
1002
                 0x00000000);
1003
    /* Breakpoints */
1004
    /* XXX : not implemented */
1005
    spr_register(env, SPR_DABR, "DABR",
1006
                 SPR_NOACCESS, SPR_NOACCESS,
1007
                 &spr_read_generic, &spr_write_generic,
1008
                 0x00000000);
1009
    /* XXX : not implemented */
1010
    spr_register(env, SPR_DABR2, "DABR2",
1011
                 SPR_NOACCESS, SPR_NOACCESS,
1012
                 &spr_read_generic, &spr_write_generic,
1013
                 0x00000000);
1014
    /* XXX : not implemented */
1015
    spr_register(env, SPR_IABR, "IABR",
1016
                 SPR_NOACCESS, SPR_NOACCESS,
1017
                 &spr_read_generic, &spr_write_generic,
1018
                 0x00000000);
1019
    /* XXX : not implemented */
1020
    spr_register(env, SPR_IABR2, "IABR2",
1021
                 SPR_NOACCESS, SPR_NOACCESS,
1022
                 &spr_read_generic, &spr_write_generic,
1023
                 0x00000000);
1024
    /* XXX : not implemented */
1025
    spr_register(env, SPR_IBCR, "IBCR",
1026
                 SPR_NOACCESS, SPR_NOACCESS,
1027
                 &spr_read_generic, &spr_write_generic,
1028
                 0x00000000);
1029
    /* XXX : not implemented */
1030
    spr_register(env, SPR_DBCR, "DBCR",
1031
                 SPR_NOACCESS, SPR_NOACCESS,
1032
                 &spr_read_generic, &spr_write_generic,
1033
                 0x00000000);
1034
}
1035

    
1036
/* SPR specific to PowerPC 602 implementation */
1037
static void gen_spr_602 (CPUPPCState *env)
1038
{
1039
    /* ESA registers */
1040
    /* XXX : not implemented */
1041
    spr_register(env, SPR_SER, "SER",
1042
                 SPR_NOACCESS, SPR_NOACCESS,
1043
                 &spr_read_generic, &spr_write_generic,
1044
                 0x00000000);
1045
    /* XXX : not implemented */
1046
    spr_register(env, SPR_SEBR, "SEBR",
1047
                 SPR_NOACCESS, SPR_NOACCESS,
1048
                 &spr_read_generic, &spr_write_generic,
1049
                 0x00000000);
1050
    /* XXX : not implemented */
1051
    spr_register(env, SPR_ESASRR, "ESASRR",
1052
                 SPR_NOACCESS, SPR_NOACCESS,
1053
                 &spr_read_generic, &spr_write_generic,
1054
                 0x00000000);
1055
    /* Floating point status */
1056
    /* XXX : not implemented */
1057
    spr_register(env, SPR_SP, "SP",
1058
                 SPR_NOACCESS, SPR_NOACCESS,
1059
                 &spr_read_generic, &spr_write_generic,
1060
                 0x00000000);
1061
    /* XXX : not implemented */
1062
    spr_register(env, SPR_LT, "LT",
1063
                 SPR_NOACCESS, SPR_NOACCESS,
1064
                 &spr_read_generic, &spr_write_generic,
1065
                 0x00000000);
1066
    /* Watchdog timer */
1067
    /* XXX : not implemented */
1068
    spr_register(env, SPR_TCR, "TCR",
1069
                 SPR_NOACCESS, SPR_NOACCESS,
1070
                 &spr_read_generic, &spr_write_generic,
1071
                 0x00000000);
1072
    /* Interrupt base */
1073
    spr_register(env, SPR_IBR, "IBR",
1074
                 SPR_NOACCESS, SPR_NOACCESS,
1075
                 &spr_read_generic, &spr_write_generic,
1076
                 0x00000000);
1077
    /* XXX : not implemented */
1078
    spr_register(env, SPR_IABR, "IABR",
1079
                 SPR_NOACCESS, SPR_NOACCESS,
1080
                 &spr_read_generic, &spr_write_generic,
1081
                 0x00000000);
1082
}
1083

    
1084
/* SPR specific to PowerPC 601 implementation */
1085
static void gen_spr_601 (CPUPPCState *env)
1086
{
1087
    /* Multiplication/division register */
1088
    /* MQ */
1089
    spr_register(env, SPR_MQ, "MQ",
1090
                 &spr_read_generic, &spr_write_generic,
1091
                 &spr_read_generic, &spr_write_generic,
1092
                 0x00000000);
1093
    /* RTC registers */
1094
    spr_register(env, SPR_601_RTCU, "RTCU",
1095
                 SPR_NOACCESS, SPR_NOACCESS,
1096
                 SPR_NOACCESS, &spr_write_601_rtcu,
1097
                 0x00000000);
1098
    spr_register(env, SPR_601_VRTCU, "RTCU",
1099
                 &spr_read_601_rtcu, SPR_NOACCESS,
1100
                 &spr_read_601_rtcu, SPR_NOACCESS,
1101
                 0x00000000);
1102
    spr_register(env, SPR_601_RTCL, "RTCL",
1103
                 SPR_NOACCESS, SPR_NOACCESS,
1104
                 SPR_NOACCESS, &spr_write_601_rtcl,
1105
                 0x00000000);
1106
    spr_register(env, SPR_601_VRTCL, "RTCL",
1107
                 &spr_read_601_rtcl, SPR_NOACCESS,
1108
                 &spr_read_601_rtcl, SPR_NOACCESS,
1109
                 0x00000000);
1110
    /* Timer */
1111
#if 0 /* ? */
1112
    spr_register(env, SPR_601_UDECR, "UDECR",
1113
                 &spr_read_decr, SPR_NOACCESS,
1114
                 &spr_read_decr, SPR_NOACCESS,
1115
                 0x00000000);
1116
#endif
1117
    /* External access control */
1118
    /* XXX : not implemented */
1119
    spr_register(env, SPR_EAR, "EAR",
1120
                 SPR_NOACCESS, SPR_NOACCESS,
1121
                 &spr_read_generic, &spr_write_generic,
1122
                 0x00000000);
1123
    /* Memory management */
1124
#if !defined(CONFIG_USER_ONLY)
1125
    spr_register(env, SPR_IBAT0U, "IBAT0U",
1126
                 SPR_NOACCESS, SPR_NOACCESS,
1127
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1128
                 0x00000000);
1129
    spr_register(env, SPR_IBAT0L, "IBAT0L",
1130
                 SPR_NOACCESS, SPR_NOACCESS,
1131
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1132
                 0x00000000);
1133
    spr_register(env, SPR_IBAT1U, "IBAT1U",
1134
                 SPR_NOACCESS, SPR_NOACCESS,
1135
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1136
                 0x00000000);
1137
    spr_register(env, SPR_IBAT1L, "IBAT1L",
1138
                 SPR_NOACCESS, SPR_NOACCESS,
1139
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1140
                 0x00000000);
1141
    spr_register(env, SPR_IBAT2U, "IBAT2U",
1142
                 SPR_NOACCESS, SPR_NOACCESS,
1143
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1144
                 0x00000000);
1145
    spr_register(env, SPR_IBAT2L, "IBAT2L",
1146
                 SPR_NOACCESS, SPR_NOACCESS,
1147
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1148
                 0x00000000);
1149
    spr_register(env, SPR_IBAT3U, "IBAT3U",
1150
                 SPR_NOACCESS, SPR_NOACCESS,
1151
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1152
                 0x00000000);
1153
    spr_register(env, SPR_IBAT3L, "IBAT3L",
1154
                 SPR_NOACCESS, SPR_NOACCESS,
1155
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1156
                 0x00000000);
1157
    env->nb_BATs = 4;
1158
#endif
1159
}
1160

    
1161
static void gen_spr_74xx (CPUPPCState *env)
1162
{
1163
    /* Processor identification */
1164
    spr_register(env, SPR_PIR, "PIR",
1165
                 SPR_NOACCESS, SPR_NOACCESS,
1166
                 &spr_read_generic, &spr_write_pir,
1167
                 0x00000000);
1168
    /* XXX : not implemented */
1169
    spr_register(env, SPR_MMCR2, "MMCR2",
1170
                 SPR_NOACCESS, SPR_NOACCESS,
1171
                 &spr_read_generic, &spr_write_generic,
1172
                 0x00000000);
1173
    /* XXX : not implemented */
1174
    spr_register(env, SPR_UMMCR2, "UMMCR2",
1175
                 &spr_read_ureg, SPR_NOACCESS,
1176
                 &spr_read_ureg, SPR_NOACCESS,
1177
                 0x00000000);
1178
    /* XXX: not implemented */
1179
    spr_register(env, SPR_BAMR, "BAMR",
1180
                 SPR_NOACCESS, SPR_NOACCESS,
1181
                 &spr_read_generic, &spr_write_generic,
1182
                 0x00000000);
1183
    /* XXX : not implemented */
1184
    spr_register(env, SPR_UBAMR, "UBAMR",
1185
                 &spr_read_ureg, SPR_NOACCESS,
1186
                 &spr_read_ureg, SPR_NOACCESS,
1187
                 0x00000000);
1188
    /* XXX : not implemented */
1189
    spr_register(env, SPR_MSSCR0, "MSSCR0",
1190
                 SPR_NOACCESS, SPR_NOACCESS,
1191
                 &spr_read_generic, &spr_write_generic,
1192
                 0x00000000);
1193
    /* Hardware implementation registers */
1194
    /* XXX : not implemented */
1195
    spr_register(env, SPR_HID0, "HID0",
1196
                 SPR_NOACCESS, SPR_NOACCESS,
1197
                 &spr_read_generic, &spr_write_generic,
1198
                 0x00000000);
1199
    /* XXX : not implemented */
1200
    spr_register(env, SPR_HID1, "HID1",
1201
                 SPR_NOACCESS, SPR_NOACCESS,
1202
                 &spr_read_generic, &spr_write_generic,
1203
                 0x00000000);
1204
    /* Altivec */
1205
    spr_register(env, SPR_VRSAVE, "VRSAVE",
1206
                 &spr_read_generic, &spr_write_generic,
1207
                 &spr_read_generic, &spr_write_generic,
1208
                 0x00000000);
1209
}
1210

    
1211
static void gen_l3_ctrl (CPUPPCState *env)
1212
{
1213
    /* L3CR */
1214
    /* XXX : not implemented */
1215
    spr_register(env, SPR_L3CR, "L3CR",
1216
                 SPR_NOACCESS, SPR_NOACCESS,
1217
                 &spr_read_generic, &spr_write_generic,
1218
                 0x00000000);
1219
    /* L3ITCR0 */
1220
    /* XXX : not implemented */
1221
    spr_register(env, SPR_L3ITCR0, "L3ITCR0",
1222
                 SPR_NOACCESS, SPR_NOACCESS,
1223
                 &spr_read_generic, &spr_write_generic,
1224
                 0x00000000);
1225
    /* L3ITCR1 */
1226
    /* XXX : not implemented */
1227
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
1228
                 SPR_NOACCESS, SPR_NOACCESS,
1229
                 &spr_read_generic, &spr_write_generic,
1230
                 0x00000000);
1231
    /* L3ITCR2 */
1232
    /* XXX : not implemented */
1233
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
1234
                 SPR_NOACCESS, SPR_NOACCESS,
1235
                 &spr_read_generic, &spr_write_generic,
1236
                 0x00000000);
1237
    /* L3ITCR3 */
1238
    /* XXX : not implemented */
1239
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
1240
                 SPR_NOACCESS, SPR_NOACCESS,
1241
                 &spr_read_generic, &spr_write_generic,
1242
                 0x00000000);
1243
    /* L3OHCR */
1244
    /* XXX : not implemented */
1245
    spr_register(env, SPR_L3OHCR, "L3OHCR",
1246
                 SPR_NOACCESS, SPR_NOACCESS,
1247
                 &spr_read_generic, &spr_write_generic,
1248
                 0x00000000);
1249
    /* L3PM */
1250
    /* XXX : not implemented */
1251
    spr_register(env, SPR_L3PM, "L3PM",
1252
                 SPR_NOACCESS, SPR_NOACCESS,
1253
                 &spr_read_generic, &spr_write_generic,
1254
                 0x00000000);
1255
}
1256

    
1257
static void gen_74xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
1258
{
1259
#if !defined(CONFIG_USER_ONLY)
1260
    env->nb_tlb = nb_tlbs;
1261
    env->nb_ways = nb_ways;
1262
    env->id_tlbs = 1;
1263
    /* XXX : not implemented */
1264
    spr_register(env, SPR_PTEHI, "PTEHI",
1265
                 SPR_NOACCESS, SPR_NOACCESS,
1266
                 &spr_read_generic, &spr_write_generic,
1267
                 0x00000000);
1268
    /* XXX : not implemented */
1269
    spr_register(env, SPR_PTELO, "PTELO",
1270
                 SPR_NOACCESS, SPR_NOACCESS,
1271
                 &spr_read_generic, &spr_write_generic,
1272
                 0x00000000);
1273
    /* XXX : not implemented */
1274
    spr_register(env, SPR_TLBMISS, "TLBMISS",
1275
                 SPR_NOACCESS, SPR_NOACCESS,
1276
                 &spr_read_generic, &spr_write_generic,
1277
                 0x00000000);
1278
#endif
1279
}
1280

    
1281
/* PowerPC BookE SPR */
1282
static void gen_spr_BookE (CPUPPCState *env)
1283
{
1284
    /* Processor identification */
1285
    spr_register(env, SPR_BOOKE_PIR, "PIR",
1286
                 SPR_NOACCESS, SPR_NOACCESS,
1287
                 &spr_read_generic, &spr_write_pir,
1288
                 0x00000000);
1289
    /* Interrupt processing */
1290
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
1291
                 SPR_NOACCESS, SPR_NOACCESS,
1292
                 &spr_read_generic, &spr_write_generic,
1293
                 0x00000000);
1294
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
1295
                 SPR_NOACCESS, SPR_NOACCESS,
1296
                 &spr_read_generic, &spr_write_generic,
1297
                 0x00000000);
1298
#if 0
1299
    spr_register(env, SPR_BOOKE_DSRR0, "DSRR0",
1300
                 SPR_NOACCESS, SPR_NOACCESS,
1301
                 &spr_read_generic, &spr_write_generic,
1302
                 0x00000000);
1303
    spr_register(env, SPR_BOOKE_DSRR1, "DSRR1",
1304
                 SPR_NOACCESS, SPR_NOACCESS,
1305
                 &spr_read_generic, &spr_write_generic,
1306
                 0x00000000);
1307
#endif
1308
    /* Debug */
1309
    /* XXX : not implemented */
1310
    spr_register(env, SPR_BOOKE_IAC1, "IAC1",
1311
                 SPR_NOACCESS, SPR_NOACCESS,
1312
                 &spr_read_generic, &spr_write_generic,
1313
                 0x00000000);
1314
    /* XXX : not implemented */
1315
    spr_register(env, SPR_BOOKE_IAC2, "IAC2",
1316
                 SPR_NOACCESS, SPR_NOACCESS,
1317
                 &spr_read_generic, &spr_write_generic,
1318
                 0x00000000);
1319
    /* XXX : not implemented */
1320
    spr_register(env, SPR_BOOKE_IAC3, "IAC3",
1321
                 SPR_NOACCESS, SPR_NOACCESS,
1322
                 &spr_read_generic, &spr_write_generic,
1323
                 0x00000000);
1324
    /* XXX : not implemented */
1325
    spr_register(env, SPR_BOOKE_IAC4, "IAC4",
1326
                 SPR_NOACCESS, SPR_NOACCESS,
1327
                 &spr_read_generic, &spr_write_generic,
1328
                 0x00000000);
1329
    /* XXX : not implemented */
1330
    spr_register(env, SPR_BOOKE_DAC1, "DAC1",
1331
                 SPR_NOACCESS, SPR_NOACCESS,
1332
                 &spr_read_generic, &spr_write_generic,
1333
                 0x00000000);
1334
    /* XXX : not implemented */
1335
    spr_register(env, SPR_BOOKE_DAC2, "DAC2",
1336
                 SPR_NOACCESS, SPR_NOACCESS,
1337
                 &spr_read_generic, &spr_write_generic,
1338
                 0x00000000);
1339
    /* XXX : not implemented */
1340
    spr_register(env, SPR_BOOKE_DVC1, "DVC1",
1341
                 SPR_NOACCESS, SPR_NOACCESS,
1342
                 &spr_read_generic, &spr_write_generic,
1343
                 0x00000000);
1344
    /* XXX : not implemented */
1345
    spr_register(env, SPR_BOOKE_DVC2, "DVC2",
1346
                 SPR_NOACCESS, SPR_NOACCESS,
1347
                 &spr_read_generic, &spr_write_generic,
1348
                 0x00000000);
1349
    /* XXX : not implemented */
1350
    spr_register(env, SPR_BOOKE_DBCR0, "DBCR0",
1351
                 SPR_NOACCESS, SPR_NOACCESS,
1352
                 &spr_read_generic, &spr_write_generic,
1353
                 0x00000000);
1354
    /* XXX : not implemented */
1355
    spr_register(env, SPR_BOOKE_DBCR1, "DBCR1",
1356
                 SPR_NOACCESS, SPR_NOACCESS,
1357
                 &spr_read_generic, &spr_write_generic,
1358
                 0x00000000);
1359
    /* XXX : not implemented */
1360
    spr_register(env, SPR_BOOKE_DBCR2, "DBCR2",
1361
                 SPR_NOACCESS, SPR_NOACCESS,
1362
                 &spr_read_generic, &spr_write_generic,
1363
                 0x00000000);
1364
    /* XXX : not implemented */
1365
    spr_register(env, SPR_BOOKE_DBSR, "DBSR",
1366
                 SPR_NOACCESS, SPR_NOACCESS,
1367
                 &spr_read_generic, &spr_write_clear,
1368
                 0x00000000);
1369
    spr_register(env, SPR_BOOKE_DEAR, "DEAR",
1370
                 SPR_NOACCESS, SPR_NOACCESS,
1371
                 &spr_read_generic, &spr_write_generic,
1372
                 0x00000000);
1373
    spr_register(env, SPR_BOOKE_ESR, "ESR",
1374
                 SPR_NOACCESS, SPR_NOACCESS,
1375
                 &spr_read_generic, &spr_write_generic,
1376
                 0x00000000);
1377
    spr_register(env, SPR_BOOKE_IVPR, "IVPR",
1378
                 SPR_NOACCESS, SPR_NOACCESS,
1379
                 &spr_read_generic, &spr_write_excp_prefix,
1380
                 0x00000000);
1381
    /* Exception vectors */
1382
    spr_register(env, SPR_BOOKE_IVOR0, "IVOR0",
1383
                 SPR_NOACCESS, SPR_NOACCESS,
1384
                 &spr_read_generic, &spr_write_excp_vector,
1385
                 0x00000000);
1386
    spr_register(env, SPR_BOOKE_IVOR1, "IVOR1",
1387
                 SPR_NOACCESS, SPR_NOACCESS,
1388
                 &spr_read_generic, &spr_write_excp_vector,
1389
                 0x00000000);
1390
    spr_register(env, SPR_BOOKE_IVOR2, "IVOR2",
1391
                 SPR_NOACCESS, SPR_NOACCESS,
1392
                 &spr_read_generic, &spr_write_excp_vector,
1393
                 0x00000000);
1394
    spr_register(env, SPR_BOOKE_IVOR3, "IVOR3",
1395
                 SPR_NOACCESS, SPR_NOACCESS,
1396
                 &spr_read_generic, &spr_write_excp_vector,
1397
                 0x00000000);
1398
    spr_register(env, SPR_BOOKE_IVOR4, "IVOR4",
1399
                 SPR_NOACCESS, SPR_NOACCESS,
1400
                 &spr_read_generic, &spr_write_excp_vector,
1401
                 0x00000000);
1402
    spr_register(env, SPR_BOOKE_IVOR5, "IVOR5",
1403
                 SPR_NOACCESS, SPR_NOACCESS,
1404
                 &spr_read_generic, &spr_write_excp_vector,
1405
                 0x00000000);
1406
    spr_register(env, SPR_BOOKE_IVOR6, "IVOR6",
1407
                 SPR_NOACCESS, SPR_NOACCESS,
1408
                 &spr_read_generic, &spr_write_excp_vector,
1409
                 0x00000000);
1410
    spr_register(env, SPR_BOOKE_IVOR7, "IVOR7",
1411
                 SPR_NOACCESS, SPR_NOACCESS,
1412
                 &spr_read_generic, &spr_write_excp_vector,
1413
                 0x00000000);
1414
    spr_register(env, SPR_BOOKE_IVOR8, "IVOR8",
1415
                 SPR_NOACCESS, SPR_NOACCESS,
1416
                 &spr_read_generic, &spr_write_excp_vector,
1417
                 0x00000000);
1418
    spr_register(env, SPR_BOOKE_IVOR9, "IVOR9",
1419
                 SPR_NOACCESS, SPR_NOACCESS,
1420
                 &spr_read_generic, &spr_write_excp_vector,
1421
                 0x00000000);
1422
    spr_register(env, SPR_BOOKE_IVOR10, "IVOR10",
1423
                 SPR_NOACCESS, SPR_NOACCESS,
1424
                 &spr_read_generic, &spr_write_excp_vector,
1425
                 0x00000000);
1426
    spr_register(env, SPR_BOOKE_IVOR11, "IVOR11",
1427
                 SPR_NOACCESS, SPR_NOACCESS,
1428
                 &spr_read_generic, &spr_write_excp_vector,
1429
                 0x00000000);
1430
    spr_register(env, SPR_BOOKE_IVOR12, "IVOR12",
1431
                 SPR_NOACCESS, SPR_NOACCESS,
1432
                 &spr_read_generic, &spr_write_excp_vector,
1433
                 0x00000000);
1434
    spr_register(env, SPR_BOOKE_IVOR13, "IVOR13",
1435
                 SPR_NOACCESS, SPR_NOACCESS,
1436
                 &spr_read_generic, &spr_write_excp_vector,
1437
                 0x00000000);
1438
    spr_register(env, SPR_BOOKE_IVOR14, "IVOR14",
1439
                 SPR_NOACCESS, SPR_NOACCESS,
1440
                 &spr_read_generic, &spr_write_excp_vector,
1441
                 0x00000000);
1442
    spr_register(env, SPR_BOOKE_IVOR15, "IVOR15",
1443
                 SPR_NOACCESS, SPR_NOACCESS,
1444
                 &spr_read_generic, &spr_write_excp_vector,
1445
                 0x00000000);
1446
#if 0
1447
    spr_register(env, SPR_BOOKE_IVOR32, "IVOR32",
1448
                 SPR_NOACCESS, SPR_NOACCESS,
1449
                 &spr_read_generic, &spr_write_excp_vector,
1450
                 0x00000000);
1451
    spr_register(env, SPR_BOOKE_IVOR33, "IVOR33",
1452
                 SPR_NOACCESS, SPR_NOACCESS,
1453
                 &spr_read_generic, &spr_write_excp_vector,
1454
                 0x00000000);
1455
    spr_register(env, SPR_BOOKE_IVOR34, "IVOR34",
1456
                 SPR_NOACCESS, SPR_NOACCESS,
1457
                 &spr_read_generic, &spr_write_excp_vector,
1458
                 0x00000000);
1459
    spr_register(env, SPR_BOOKE_IVOR35, "IVOR35",
1460
                 SPR_NOACCESS, SPR_NOACCESS,
1461
                 &spr_read_generic, &spr_write_excp_vector,
1462
                 0x00000000);
1463
    spr_register(env, SPR_BOOKE_IVOR36, "IVOR36",
1464
                 SPR_NOACCESS, SPR_NOACCESS,
1465
                 &spr_read_generic, &spr_write_excp_vector,
1466
                 0x00000000);
1467
    spr_register(env, SPR_BOOKE_IVOR37, "IVOR37",
1468
                 SPR_NOACCESS, SPR_NOACCESS,
1469
                 &spr_read_generic, &spr_write_excp_vector,
1470
                 0x00000000);
1471
#endif
1472
    spr_register(env, SPR_BOOKE_PID, "PID",
1473
                 SPR_NOACCESS, SPR_NOACCESS,
1474
                 &spr_read_generic, &spr_write_generic,
1475
                 0x00000000);
1476
    spr_register(env, SPR_BOOKE_TCR, "TCR",
1477
                 SPR_NOACCESS, SPR_NOACCESS,
1478
                 &spr_read_generic, &spr_write_booke_tcr,
1479
                 0x00000000);
1480
    spr_register(env, SPR_BOOKE_TSR, "TSR",
1481
                 SPR_NOACCESS, SPR_NOACCESS,
1482
                 &spr_read_generic, &spr_write_booke_tsr,
1483
                 0x00000000);
1484
    /* Timer */
1485
    spr_register(env, SPR_DECR, "DECR",
1486
                 SPR_NOACCESS, SPR_NOACCESS,
1487
                 &spr_read_decr, &spr_write_decr,
1488
                 0x00000000);
1489
    spr_register(env, SPR_BOOKE_DECAR, "DECAR",
1490
                 SPR_NOACCESS, SPR_NOACCESS,
1491
                 SPR_NOACCESS, &spr_write_generic,
1492
                 0x00000000);
1493
    /* SPRGs */
1494
    spr_register(env, SPR_USPRG0, "USPRG0",
1495
                 &spr_read_generic, &spr_write_generic,
1496
                 &spr_read_generic, &spr_write_generic,
1497
                 0x00000000);
1498
    spr_register(env, SPR_SPRG4, "SPRG4",
1499
                 SPR_NOACCESS, SPR_NOACCESS,
1500
                 &spr_read_generic, &spr_write_generic,
1501
                 0x00000000);
1502
    spr_register(env, SPR_USPRG4, "USPRG4",
1503
                 &spr_read_ureg, SPR_NOACCESS,
1504
                 &spr_read_ureg, SPR_NOACCESS,
1505
                 0x00000000);
1506
    spr_register(env, SPR_SPRG5, "SPRG5",
1507
                 SPR_NOACCESS, SPR_NOACCESS,
1508
                 &spr_read_generic, &spr_write_generic,
1509
                 0x00000000);
1510
    spr_register(env, SPR_USPRG5, "USPRG5",
1511
                 &spr_read_ureg, SPR_NOACCESS,
1512
                 &spr_read_ureg, SPR_NOACCESS,
1513
                 0x00000000);
1514
    spr_register(env, SPR_SPRG6, "SPRG6",
1515
                 SPR_NOACCESS, SPR_NOACCESS,
1516
                 &spr_read_generic, &spr_write_generic,
1517
                 0x00000000);
1518
    spr_register(env, SPR_USPRG6, "USPRG6",
1519
                 &spr_read_ureg, SPR_NOACCESS,
1520
                 &spr_read_ureg, SPR_NOACCESS,
1521
                 0x00000000);
1522
    spr_register(env, SPR_SPRG7, "SPRG7",
1523
                 SPR_NOACCESS, SPR_NOACCESS,
1524
                 &spr_read_generic, &spr_write_generic,
1525
                 0x00000000);
1526
    spr_register(env, SPR_USPRG7, "USPRG7",
1527
                 &spr_read_ureg, SPR_NOACCESS,
1528
                 &spr_read_ureg, SPR_NOACCESS,
1529
                 0x00000000);
1530
}
1531

    
1532
/* FSL storage control registers */
1533
static void gen_spr_BookE_FSL (CPUPPCState *env)
1534
{
1535
#if !defined(CONFIG_USER_ONLY)
1536
    /* TLB assist registers */
1537
    /* XXX : not implemented */
1538
    spr_register(env, SPR_BOOKE_MAS0, "MAS0",
1539
                 SPR_NOACCESS, SPR_NOACCESS,
1540
                 &spr_read_generic, &spr_write_generic,
1541
                 0x00000000);
1542
    /* XXX : not implemented */
1543
    spr_register(env, SPR_BOOKE_MAS1, "MAS2",
1544
                 SPR_NOACCESS, SPR_NOACCESS,
1545
                 &spr_read_generic, &spr_write_generic,
1546
                 0x00000000);
1547
    /* XXX : not implemented */
1548
    spr_register(env, SPR_BOOKE_MAS2, "MAS3",
1549
                 SPR_NOACCESS, SPR_NOACCESS,
1550
                 &spr_read_generic, &spr_write_generic,
1551
                 0x00000000);
1552
    /* XXX : not implemented */
1553
    spr_register(env, SPR_BOOKE_MAS3, "MAS4",
1554
                 SPR_NOACCESS, SPR_NOACCESS,
1555
                 &spr_read_generic, &spr_write_generic,
1556
                 0x00000000);
1557
    /* XXX : not implemented */
1558
    spr_register(env, SPR_BOOKE_MAS4, "MAS5",
1559
                 SPR_NOACCESS, SPR_NOACCESS,
1560
                 &spr_read_generic, &spr_write_generic,
1561
                 0x00000000);
1562
    /* XXX : not implemented */
1563
    spr_register(env, SPR_BOOKE_MAS6, "MAS6",
1564
                 SPR_NOACCESS, SPR_NOACCESS,
1565
                 &spr_read_generic, &spr_write_generic,
1566
                 0x00000000);
1567
    /* XXX : not implemented */
1568
    spr_register(env, SPR_BOOKE_MAS7, "MAS7",
1569
                 SPR_NOACCESS, SPR_NOACCESS,
1570
                 &spr_read_generic, &spr_write_generic,
1571
                 0x00000000);
1572
    if (env->nb_pids > 1) {
1573
        /* XXX : not implemented */
1574
        spr_register(env, SPR_BOOKE_PID1, "PID1",
1575
                     SPR_NOACCESS, SPR_NOACCESS,
1576
                     &spr_read_generic, &spr_write_generic,
1577
                     0x00000000);
1578
    }
1579
    if (env->nb_pids > 2) {
1580
        /* XXX : not implemented */
1581
        spr_register(env, SPR_BOOKE_PID2, "PID2",
1582
                     SPR_NOACCESS, SPR_NOACCESS,
1583
                     &spr_read_generic, &spr_write_generic,
1584
                     0x00000000);
1585
    }
1586
    /* XXX : not implemented */
1587
    spr_register(env, SPR_MMUCFG, "MMUCFG",
1588
                 SPR_NOACCESS, SPR_NOACCESS,
1589
                 &spr_read_generic, SPR_NOACCESS,
1590
                 0x00000000); /* TOFIX */
1591
    /* XXX : not implemented */
1592
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
1593
                 SPR_NOACCESS, SPR_NOACCESS,
1594
                 &spr_read_generic, &spr_write_generic,
1595
                 0x00000000); /* TOFIX */
1596
    switch (env->nb_ways) {
1597
    case 4:
1598
        /* XXX : not implemented */
1599
        spr_register(env, SPR_BOOKE_TLB3CFG, "TLB3CFG",
1600
                     SPR_NOACCESS, SPR_NOACCESS,
1601
                     &spr_read_generic, SPR_NOACCESS,
1602
                     0x00000000); /* TOFIX */
1603
        /* Fallthru */
1604
    case 3:
1605
        /* XXX : not implemented */
1606
        spr_register(env, SPR_BOOKE_TLB2CFG, "TLB2CFG",
1607
                     SPR_NOACCESS, SPR_NOACCESS,
1608
                     &spr_read_generic, SPR_NOACCESS,
1609
                     0x00000000); /* TOFIX */
1610
        /* Fallthru */
1611
    case 2:
1612
        /* XXX : not implemented */
1613
        spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
1614
                     SPR_NOACCESS, SPR_NOACCESS,
1615
                     &spr_read_generic, SPR_NOACCESS,
1616
                     0x00000000); /* TOFIX */
1617
        /* Fallthru */
1618
    case 1:
1619
        /* XXX : not implemented */
1620
        spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
1621
                     SPR_NOACCESS, SPR_NOACCESS,
1622
                     &spr_read_generic, SPR_NOACCESS,
1623
                     0x00000000); /* TOFIX */
1624
        /* Fallthru */
1625
    case 0:
1626
    default:
1627
        break;
1628
    }
1629
#endif
1630
}
1631

    
1632
/* SPR specific to PowerPC 440 implementation */
1633
static void gen_spr_440 (CPUPPCState *env)
1634
{
1635
    /* Cache control */
1636
    /* XXX : not implemented */
1637
    spr_register(env, SPR_440_DNV0, "DNV0",
1638
                 SPR_NOACCESS, SPR_NOACCESS,
1639
                 &spr_read_generic, &spr_write_generic,
1640
                 0x00000000);
1641
    /* XXX : not implemented */
1642
    spr_register(env, SPR_440_DNV1, "DNV1",
1643
                 SPR_NOACCESS, SPR_NOACCESS,
1644
                 &spr_read_generic, &spr_write_generic,
1645
                 0x00000000);
1646
    /* XXX : not implemented */
1647
    spr_register(env, SPR_440_DNV2, "DNV2",
1648
                 SPR_NOACCESS, SPR_NOACCESS,
1649
                 &spr_read_generic, &spr_write_generic,
1650
                 0x00000000);
1651
    /* XXX : not implemented */
1652
    spr_register(env, SPR_440_DNV3, "DNV3",
1653
                 SPR_NOACCESS, SPR_NOACCESS,
1654
                 &spr_read_generic, &spr_write_generic,
1655
                 0x00000000);
1656
    /* XXX : not implemented */
1657
    spr_register(env, SPR_440_DTV0, "DTV0",
1658
                 SPR_NOACCESS, SPR_NOACCESS,
1659
                 &spr_read_generic, &spr_write_generic,
1660
                 0x00000000);
1661
    /* XXX : not implemented */
1662
    spr_register(env, SPR_440_DTV1, "DTV1",
1663
                 SPR_NOACCESS, SPR_NOACCESS,
1664
                 &spr_read_generic, &spr_write_generic,
1665
                 0x00000000);
1666
    /* XXX : not implemented */
1667
    spr_register(env, SPR_440_DTV2, "DTV2",
1668
                 SPR_NOACCESS, SPR_NOACCESS,
1669
                 &spr_read_generic, &spr_write_generic,
1670
                 0x00000000);
1671
    /* XXX : not implemented */
1672
    spr_register(env, SPR_440_DTV3, "DTV3",
1673
                 SPR_NOACCESS, SPR_NOACCESS,
1674
                 &spr_read_generic, &spr_write_generic,
1675
                 0x00000000);
1676
    /* XXX : not implemented */
1677
    spr_register(env, SPR_440_DVLIM, "DVLIM",
1678
                 SPR_NOACCESS, SPR_NOACCESS,
1679
                 &spr_read_generic, &spr_write_generic,
1680
                 0x00000000);
1681
    /* XXX : not implemented */
1682
    spr_register(env, SPR_440_INV0, "INV0",
1683
                 SPR_NOACCESS, SPR_NOACCESS,
1684
                 &spr_read_generic, &spr_write_generic,
1685
                 0x00000000);
1686
    /* XXX : not implemented */
1687
    spr_register(env, SPR_440_INV1, "INV1",
1688
                 SPR_NOACCESS, SPR_NOACCESS,
1689
                 &spr_read_generic, &spr_write_generic,
1690
                 0x00000000);
1691
    /* XXX : not implemented */
1692
    spr_register(env, SPR_440_INV2, "INV2",
1693
                 SPR_NOACCESS, SPR_NOACCESS,
1694
                 &spr_read_generic, &spr_write_generic,
1695
                 0x00000000);
1696
    /* XXX : not implemented */
1697
    spr_register(env, SPR_440_INV3, "INV3",
1698
                 SPR_NOACCESS, SPR_NOACCESS,
1699
                 &spr_read_generic, &spr_write_generic,
1700
                 0x00000000);
1701
    /* XXX : not implemented */
1702
    spr_register(env, SPR_440_ITV0, "ITV0",
1703
                 SPR_NOACCESS, SPR_NOACCESS,
1704
                 &spr_read_generic, &spr_write_generic,
1705
                 0x00000000);
1706
    /* XXX : not implemented */
1707
    spr_register(env, SPR_440_ITV1, "ITV1",
1708
                 SPR_NOACCESS, SPR_NOACCESS,
1709
                 &spr_read_generic, &spr_write_generic,
1710
                 0x00000000);
1711
    /* XXX : not implemented */
1712
    spr_register(env, SPR_440_ITV2, "ITV2",
1713
                 SPR_NOACCESS, SPR_NOACCESS,
1714
                 &spr_read_generic, &spr_write_generic,
1715
                 0x00000000);
1716
    /* XXX : not implemented */
1717
    spr_register(env, SPR_440_ITV3, "ITV3",
1718
                 SPR_NOACCESS, SPR_NOACCESS,
1719
                 &spr_read_generic, &spr_write_generic,
1720
                 0x00000000);
1721
    /* XXX : not implemented */
1722
    spr_register(env, SPR_440_IVLIM, "IVLIM",
1723
                 SPR_NOACCESS, SPR_NOACCESS,
1724
                 &spr_read_generic, &spr_write_generic,
1725
                 0x00000000);
1726
    /* Cache debug */
1727
    /* XXX : not implemented */
1728
    spr_register(env, SPR_BOOKE_DCDBTRH, "DCDBTRH",
1729
                 SPR_NOACCESS, SPR_NOACCESS,
1730
                 &spr_read_generic, SPR_NOACCESS,
1731
                 0x00000000);
1732
    /* XXX : not implemented */
1733
    spr_register(env, SPR_BOOKE_DCDBTRL, "DCDBTRL",
1734
                 SPR_NOACCESS, SPR_NOACCESS,
1735
                 &spr_read_generic, SPR_NOACCESS,
1736
                 0x00000000);
1737
    /* XXX : not implemented */
1738
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1739
                 SPR_NOACCESS, SPR_NOACCESS,
1740
                 &spr_read_generic, SPR_NOACCESS,
1741
                 0x00000000);
1742
    /* XXX : not implemented */
1743
    spr_register(env, SPR_BOOKE_ICDBTRH, "ICDBTRH",
1744
                 SPR_NOACCESS, SPR_NOACCESS,
1745
                 &spr_read_generic, SPR_NOACCESS,
1746
                 0x00000000);
1747
    /* XXX : not implemented */
1748
    spr_register(env, SPR_BOOKE_ICDBTRL, "ICDBTRL",
1749
                 SPR_NOACCESS, SPR_NOACCESS,
1750
                 &spr_read_generic, SPR_NOACCESS,
1751
                 0x00000000);
1752
    /* XXX : not implemented */
1753
    spr_register(env, SPR_440_DBDR, "DBDR",
1754
                 SPR_NOACCESS, SPR_NOACCESS,
1755
                 &spr_read_generic, &spr_write_generic,
1756
                 0x00000000);
1757
    /* Processor control */
1758
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1759
                 SPR_NOACCESS, SPR_NOACCESS,
1760
                 &spr_read_generic, &spr_write_generic,
1761
                 0x00000000);
1762
    spr_register(env, SPR_440_RSTCFG, "RSTCFG",
1763
                 SPR_NOACCESS, SPR_NOACCESS,
1764
                 &spr_read_generic, SPR_NOACCESS,
1765
                 0x00000000);
1766
    /* Storage control */
1767
    spr_register(env, SPR_440_MMUCR, "MMUCR",
1768
                 SPR_NOACCESS, SPR_NOACCESS,
1769
                 &spr_read_generic, &spr_write_generic,
1770
                 0x00000000);
1771
}
1772

    
1773
/* SPR shared between PowerPC 40x implementations */
1774
static void gen_spr_40x (CPUPPCState *env)
1775
{
1776
    /* Cache */
1777
    /* not emulated, as Qemu do not emulate caches */
1778
    spr_register(env, SPR_40x_DCCR, "DCCR",
1779
                 SPR_NOACCESS, SPR_NOACCESS,
1780
                 &spr_read_generic, &spr_write_generic,
1781
                 0x00000000);
1782
    /* not emulated, as Qemu do not emulate caches */
1783
    spr_register(env, SPR_40x_ICCR, "ICCR",
1784
                 SPR_NOACCESS, SPR_NOACCESS,
1785
                 &spr_read_generic, &spr_write_generic,
1786
                 0x00000000);
1787
    /* not emulated, as Qemu do not emulate caches */
1788
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1789
                 SPR_NOACCESS, SPR_NOACCESS,
1790
                 &spr_read_generic, SPR_NOACCESS,
1791
                 0x00000000);
1792
    /* Exception */
1793
    spr_register(env, SPR_40x_DEAR, "DEAR",
1794
                 SPR_NOACCESS, SPR_NOACCESS,
1795
                 &spr_read_generic, &spr_write_generic,
1796
                 0x00000000);
1797
    spr_register(env, SPR_40x_ESR, "ESR",
1798
                 SPR_NOACCESS, SPR_NOACCESS,
1799
                 &spr_read_generic, &spr_write_generic,
1800
                 0x00000000);
1801
    spr_register(env, SPR_40x_EVPR, "EVPR",
1802
                 SPR_NOACCESS, SPR_NOACCESS,
1803
                 &spr_read_generic, &spr_write_excp_prefix,
1804
                 0x00000000);
1805
    spr_register(env, SPR_40x_SRR2, "SRR2",
1806
                 &spr_read_generic, &spr_write_generic,
1807
                 &spr_read_generic, &spr_write_generic,
1808
                 0x00000000);
1809
    spr_register(env, SPR_40x_SRR3, "SRR3",
1810
                 &spr_read_generic, &spr_write_generic,
1811
                 &spr_read_generic, &spr_write_generic,
1812
                 0x00000000);
1813
    /* Timers */
1814
    spr_register(env, SPR_40x_PIT, "PIT",
1815
                 SPR_NOACCESS, SPR_NOACCESS,
1816
                 &spr_read_40x_pit, &spr_write_40x_pit,
1817
                 0x00000000);
1818
    spr_register(env, SPR_40x_TCR, "TCR",
1819
                 SPR_NOACCESS, SPR_NOACCESS,
1820
                 &spr_read_generic, &spr_write_booke_tcr,
1821
                 0x00000000);
1822
    spr_register(env, SPR_40x_TSR, "TSR",
1823
                 SPR_NOACCESS, SPR_NOACCESS,
1824
                 &spr_read_generic, &spr_write_booke_tsr,
1825
                 0x00000000);
1826
}
1827

    
1828
/* SPR specific to PowerPC 405 implementation */
1829
static void gen_spr_405 (CPUPPCState *env)
1830
{
1831
    /* MMU */
1832
    spr_register(env, SPR_40x_PID, "PID",
1833
                 SPR_NOACCESS, SPR_NOACCESS,
1834
                 &spr_read_generic, &spr_write_generic,
1835
                 0x00000000);
1836
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1837
                 SPR_NOACCESS, SPR_NOACCESS,
1838
                 &spr_read_generic, &spr_write_generic,
1839
                 0x00700000);
1840
    /* Debug interface */
1841
    /* XXX : not implemented */
1842
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1843
                 SPR_NOACCESS, SPR_NOACCESS,
1844
                 &spr_read_generic, &spr_write_40x_dbcr0,
1845
                 0x00000000);
1846
    /* XXX : not implemented */
1847
    spr_register(env, SPR_405_DBCR1, "DBCR1",
1848
                 SPR_NOACCESS, SPR_NOACCESS,
1849
                 &spr_read_generic, &spr_write_generic,
1850
                 0x00000000);
1851
    /* XXX : not implemented */
1852
    spr_register(env, SPR_40x_DBSR, "DBSR",
1853
                 SPR_NOACCESS, SPR_NOACCESS,
1854
                 &spr_read_generic, &spr_write_clear,
1855
                 /* Last reset was system reset */
1856
                 0x00000300);
1857
    /* XXX : not implemented */
1858
    spr_register(env, SPR_40x_DAC1, "DAC1",
1859
                 SPR_NOACCESS, SPR_NOACCESS,
1860
                 &spr_read_generic, &spr_write_generic,
1861
                 0x00000000);
1862
    spr_register(env, SPR_40x_DAC2, "DAC2",
1863
                 SPR_NOACCESS, SPR_NOACCESS,
1864
                 &spr_read_generic, &spr_write_generic,
1865
                 0x00000000);
1866
    /* XXX : not implemented */
1867
    spr_register(env, SPR_405_DVC1, "DVC1",
1868
                 SPR_NOACCESS, SPR_NOACCESS,
1869
                 &spr_read_generic, &spr_write_generic,
1870
                 0x00000000);
1871
    /* XXX : not implemented */
1872
    spr_register(env, SPR_405_DVC2, "DVC2",
1873
                 SPR_NOACCESS, SPR_NOACCESS,
1874
                 &spr_read_generic, &spr_write_generic,
1875
                 0x00000000);
1876
    /* XXX : not implemented */
1877
    spr_register(env, SPR_40x_IAC1, "IAC1",
1878
                 SPR_NOACCESS, SPR_NOACCESS,
1879
                 &spr_read_generic, &spr_write_generic,
1880
                 0x00000000);
1881
    spr_register(env, SPR_40x_IAC2, "IAC2",
1882
                 SPR_NOACCESS, SPR_NOACCESS,
1883
                 &spr_read_generic, &spr_write_generic,
1884
                 0x00000000);
1885
    /* XXX : not implemented */
1886
    spr_register(env, SPR_405_IAC3, "IAC3",
1887
                 SPR_NOACCESS, SPR_NOACCESS,
1888
                 &spr_read_generic, &spr_write_generic,
1889
                 0x00000000);
1890
    /* XXX : not implemented */
1891
    spr_register(env, SPR_405_IAC4, "IAC4",
1892
                 SPR_NOACCESS, SPR_NOACCESS,
1893
                 &spr_read_generic, &spr_write_generic,
1894
                 0x00000000);
1895
    /* Storage control */
1896
    /* XXX: TODO: not implemented */
1897
    spr_register(env, SPR_405_SLER, "SLER",
1898
                 SPR_NOACCESS, SPR_NOACCESS,
1899
                 &spr_read_generic, &spr_write_40x_sler,
1900
                 0x00000000);
1901
    spr_register(env, SPR_40x_ZPR, "ZPR",
1902
                 SPR_NOACCESS, SPR_NOACCESS,
1903
                 &spr_read_generic, &spr_write_generic,
1904
                 0x00000000);
1905
    /* XXX : not implemented */
1906
    spr_register(env, SPR_405_SU0R, "SU0R",
1907
                 SPR_NOACCESS, SPR_NOACCESS,
1908
                 &spr_read_generic, &spr_write_generic,
1909
                 0x00000000);
1910
    /* SPRG */
1911
    spr_register(env, SPR_USPRG0, "USPRG0",
1912
                 &spr_read_ureg, SPR_NOACCESS,
1913
                 &spr_read_ureg, SPR_NOACCESS,
1914
                 0x00000000);
1915
    spr_register(env, SPR_SPRG4, "SPRG4",
1916
                 SPR_NOACCESS, SPR_NOACCESS,
1917
                 &spr_read_generic, &spr_write_generic,
1918
                 0x00000000);
1919
    spr_register(env, SPR_USPRG4, "USPRG4",
1920
                 &spr_read_ureg, SPR_NOACCESS,
1921
                 &spr_read_ureg, SPR_NOACCESS,
1922
                 0x00000000);
1923
    spr_register(env, SPR_SPRG5, "SPRG5",
1924
                 SPR_NOACCESS, SPR_NOACCESS,
1925
                 spr_read_generic, &spr_write_generic,
1926
                 0x00000000);
1927
    spr_register(env, SPR_USPRG5, "USPRG5",
1928
                 &spr_read_ureg, SPR_NOACCESS,
1929
                 &spr_read_ureg, SPR_NOACCESS,
1930
                 0x00000000);
1931
    spr_register(env, SPR_SPRG6, "SPRG6",
1932
                 SPR_NOACCESS, SPR_NOACCESS,
1933
                 spr_read_generic, &spr_write_generic,
1934
                 0x00000000);
1935
    spr_register(env, SPR_USPRG6, "USPRG6",
1936
                 &spr_read_ureg, SPR_NOACCESS,
1937
                 &spr_read_ureg, SPR_NOACCESS,
1938
                 0x00000000);
1939
    spr_register(env, SPR_SPRG7, "SPRG7",
1940
                 SPR_NOACCESS, SPR_NOACCESS,
1941
                 spr_read_generic, &spr_write_generic,
1942
                 0x00000000);
1943
    spr_register(env, SPR_USPRG7, "USPRG7",
1944
                 &spr_read_ureg, SPR_NOACCESS,
1945
                 &spr_read_ureg, SPR_NOACCESS,
1946
                 0x00000000);
1947
}
1948

    
1949
/* SPR shared between PowerPC 401 & 403 implementations */
1950
static void gen_spr_401_403 (CPUPPCState *env)
1951
{
1952
    /* Time base */
1953
    spr_register(env, SPR_403_VTBL,  "TBL",
1954
                 &spr_read_tbl, SPR_NOACCESS,
1955
                 &spr_read_tbl, SPR_NOACCESS,
1956
                 0x00000000);
1957
    spr_register(env, SPR_403_TBL,   "TBL",
1958
                 SPR_NOACCESS, SPR_NOACCESS,
1959
                 SPR_NOACCESS, &spr_write_tbl,
1960
                 0x00000000);
1961
    spr_register(env, SPR_403_VTBU,  "TBU",
1962
                 &spr_read_tbu, SPR_NOACCESS,
1963
                 &spr_read_tbu, SPR_NOACCESS,
1964
                 0x00000000);
1965
    spr_register(env, SPR_403_TBU,   "TBU",
1966
                 SPR_NOACCESS, SPR_NOACCESS,
1967
                 SPR_NOACCESS, &spr_write_tbu,
1968
                 0x00000000);
1969
    /* Debug */
1970
    /* not emulated, as Qemu do not emulate caches */
1971
    spr_register(env, SPR_403_CDBCR, "CDBCR",
1972
                 SPR_NOACCESS, SPR_NOACCESS,
1973
                 &spr_read_generic, &spr_write_generic,
1974
                 0x00000000);
1975
}
1976

    
1977
/* SPR specific to PowerPC 401 implementation */
1978
static void gen_spr_401 (CPUPPCState *env)
1979
{
1980
    /* Debug interface */
1981
    /* XXX : not implemented */
1982
    spr_register(env, SPR_40x_DBCR0, "DBCR",
1983
                 SPR_NOACCESS, SPR_NOACCESS,
1984
                 &spr_read_generic, &spr_write_40x_dbcr0,
1985
                 0x00000000);
1986
    /* XXX : not implemented */
1987
    spr_register(env, SPR_40x_DBSR, "DBSR",
1988
                 SPR_NOACCESS, SPR_NOACCESS,
1989
                 &spr_read_generic, &spr_write_clear,
1990
                 /* Last reset was system reset */
1991
                 0x00000300);
1992
    /* XXX : not implemented */
1993
    spr_register(env, SPR_40x_DAC1, "DAC",
1994
                 SPR_NOACCESS, SPR_NOACCESS,
1995
                 &spr_read_generic, &spr_write_generic,
1996
                 0x00000000);
1997
    /* XXX : not implemented */
1998
    spr_register(env, SPR_40x_IAC1, "IAC",
1999
                 SPR_NOACCESS, SPR_NOACCESS,
2000
                 &spr_read_generic, &spr_write_generic,
2001
                 0x00000000);
2002
    /* Storage control */
2003
    /* XXX: TODO: not implemented */
2004
    spr_register(env, SPR_405_SLER, "SLER",
2005
                 SPR_NOACCESS, SPR_NOACCESS,
2006
                 &spr_read_generic, &spr_write_40x_sler,
2007
                 0x00000000);
2008
    /* not emulated, as Qemu never does speculative access */
2009
    spr_register(env, SPR_40x_SGR, "SGR",
2010
                 SPR_NOACCESS, SPR_NOACCESS,
2011
                 &spr_read_generic, &spr_write_generic,
2012
                 0xFFFFFFFF);
2013
    /* not emulated, as Qemu do not emulate caches */
2014
    spr_register(env, SPR_40x_DCWR, "DCWR",
2015
                 SPR_NOACCESS, SPR_NOACCESS,
2016
                 &spr_read_generic, &spr_write_generic,
2017
                 0x00000000);
2018
}
2019

    
2020
static void gen_spr_401x2 (CPUPPCState *env)
2021
{
2022
    gen_spr_401(env);
2023
    spr_register(env, SPR_40x_PID, "PID",
2024
                 SPR_NOACCESS, SPR_NOACCESS,
2025
                 &spr_read_generic, &spr_write_generic,
2026
                 0x00000000);
2027
    spr_register(env, SPR_40x_ZPR, "ZPR",
2028
                 SPR_NOACCESS, SPR_NOACCESS,
2029
                 &spr_read_generic, &spr_write_generic,
2030
                 0x00000000);
2031
}
2032

    
2033
/* SPR specific to PowerPC 403 implementation */
2034
static void gen_spr_403 (CPUPPCState *env)
2035
{
2036
    /* Debug interface */
2037
    /* XXX : not implemented */
2038
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
2039
                 SPR_NOACCESS, SPR_NOACCESS,
2040
                 &spr_read_generic, &spr_write_40x_dbcr0,
2041
                 0x00000000);
2042
    /* XXX : not implemented */
2043
    spr_register(env, SPR_40x_DBSR, "DBSR",
2044
                 SPR_NOACCESS, SPR_NOACCESS,
2045
                 &spr_read_generic, &spr_write_clear,
2046
                 /* Last reset was system reset */
2047
                 0x00000300);
2048
    /* XXX : not implemented */
2049
    spr_register(env, SPR_40x_DAC1, "DAC1",
2050
                 SPR_NOACCESS, SPR_NOACCESS,
2051
                 &spr_read_generic, &spr_write_generic,
2052
                 0x00000000);
2053
    /* XXX : not implemented */
2054
    spr_register(env, SPR_40x_DAC2, "DAC2",
2055
                 SPR_NOACCESS, SPR_NOACCESS,
2056
                 &spr_read_generic, &spr_write_generic,
2057
                 0x00000000);
2058
    /* XXX : not implemented */
2059
    spr_register(env, SPR_40x_IAC1, "IAC1",
2060
                 SPR_NOACCESS, SPR_NOACCESS,
2061
                 &spr_read_generic, &spr_write_generic,
2062
                 0x00000000);
2063
    /* XXX : not implemented */
2064
    spr_register(env, SPR_40x_IAC2, "IAC2",
2065
                 SPR_NOACCESS, SPR_NOACCESS,
2066
                 &spr_read_generic, &spr_write_generic,
2067
                 0x00000000);
2068
}
2069

    
2070
static void gen_spr_403_real (CPUPPCState *env)
2071
{
2072
    spr_register(env, SPR_403_PBL1,  "PBL1",
2073
                 SPR_NOACCESS, SPR_NOACCESS,
2074
                 &spr_read_403_pbr, &spr_write_403_pbr,
2075
                 0x00000000);
2076
    spr_register(env, SPR_403_PBU1,  "PBU1",
2077
                 SPR_NOACCESS, SPR_NOACCESS,
2078
                 &spr_read_403_pbr, &spr_write_403_pbr,
2079
                 0x00000000);
2080
    spr_register(env, SPR_403_PBL2,  "PBL2",
2081
                 SPR_NOACCESS, SPR_NOACCESS,
2082
                 &spr_read_403_pbr, &spr_write_403_pbr,
2083
                 0x00000000);
2084
    spr_register(env, SPR_403_PBU2,  "PBU2",
2085
                 SPR_NOACCESS, SPR_NOACCESS,
2086
                 &spr_read_403_pbr, &spr_write_403_pbr,
2087
                 0x00000000);
2088
}
2089

    
2090
static void gen_spr_403_mmu (CPUPPCState *env)
2091
{
2092
    /* MMU */
2093
    spr_register(env, SPR_40x_PID, "PID",
2094
                 SPR_NOACCESS, SPR_NOACCESS,
2095
                 &spr_read_generic, &spr_write_generic,
2096
                 0x00000000);
2097
    spr_register(env, SPR_40x_ZPR, "ZPR",
2098
                 SPR_NOACCESS, SPR_NOACCESS,
2099
                 &spr_read_generic, &spr_write_generic,
2100
                 0x00000000);
2101
}
2102

    
2103
/* SPR specific to PowerPC compression coprocessor extension */
2104
static void gen_spr_compress (CPUPPCState *env)
2105
{
2106
    /* XXX : not implemented */
2107
    spr_register(env, SPR_401_SKR, "SKR",
2108
                 SPR_NOACCESS, SPR_NOACCESS,
2109
                 &spr_read_generic, &spr_write_generic,
2110
                 0x00000000);
2111
}
2112

    
2113
#if defined (TARGET_PPC64)
2114
/* SPR specific to PowerPC 620 */
2115
static void gen_spr_620 (CPUPPCState *env)
2116
{
2117
    /* XXX : not implemented */
2118
    spr_register(env, SPR_620_PMR0, "PMR0",
2119
                 SPR_NOACCESS, SPR_NOACCESS,
2120
                 &spr_read_generic, &spr_write_generic,
2121
                 0x00000000);
2122
    /* XXX : not implemented */
2123
    spr_register(env, SPR_620_PMR1, "PMR1",
2124
                 SPR_NOACCESS, SPR_NOACCESS,
2125
                 &spr_read_generic, &spr_write_generic,
2126
                 0x00000000);
2127
    /* XXX : not implemented */
2128
    spr_register(env, SPR_620_PMR2, "PMR2",
2129
                 SPR_NOACCESS, SPR_NOACCESS,
2130
                 &spr_read_generic, &spr_write_generic,
2131
                 0x00000000);
2132
    /* XXX : not implemented */
2133
    spr_register(env, SPR_620_PMR3, "PMR3",
2134
                 SPR_NOACCESS, SPR_NOACCESS,
2135
                 &spr_read_generic, &spr_write_generic,
2136
                 0x00000000);
2137
    /* XXX : not implemented */
2138
    spr_register(env, SPR_620_PMR4, "PMR4",
2139
                 SPR_NOACCESS, SPR_NOACCESS,
2140
                 &spr_read_generic, &spr_write_generic,
2141
                 0x00000000);
2142
    /* XXX : not implemented */
2143
    spr_register(env, SPR_620_PMR5, "PMR5",
2144
                 SPR_NOACCESS, SPR_NOACCESS,
2145
                 &spr_read_generic, &spr_write_generic,
2146
                 0x00000000);
2147
    /* XXX : not implemented */
2148
    spr_register(env, SPR_620_PMR6, "PMR6",
2149
                 SPR_NOACCESS, SPR_NOACCESS,
2150
                 &spr_read_generic, &spr_write_generic,
2151
                 0x00000000);
2152
    /* XXX : not implemented */
2153
    spr_register(env, SPR_620_PMR7, "PMR7",
2154
                 SPR_NOACCESS, SPR_NOACCESS,
2155
                 &spr_read_generic, &spr_write_generic,
2156
                 0x00000000);
2157
    /* XXX : not implemented */
2158
    spr_register(env, SPR_620_PMR8, "PMR8",
2159
                 SPR_NOACCESS, SPR_NOACCESS,
2160
                 &spr_read_generic, &spr_write_generic,
2161
                 0x00000000);
2162
    /* XXX : not implemented */
2163
    spr_register(env, SPR_620_PMR9, "PMR9",
2164
                 SPR_NOACCESS, SPR_NOACCESS,
2165
                 &spr_read_generic, &spr_write_generic,
2166
                 0x00000000);
2167
    /* XXX : not implemented */
2168
    spr_register(env, SPR_620_PMRA, "PMR10",
2169
                 SPR_NOACCESS, SPR_NOACCESS,
2170
                 &spr_read_generic, &spr_write_generic,
2171
                 0x00000000);
2172
    /* XXX : not implemented */
2173
    spr_register(env, SPR_620_PMRB, "PMR11",
2174
                 SPR_NOACCESS, SPR_NOACCESS,
2175
                 &spr_read_generic, &spr_write_generic,
2176
                 0x00000000);
2177
    /* XXX : not implemented */
2178
    spr_register(env, SPR_620_PMRC, "PMR12",
2179
                 SPR_NOACCESS, SPR_NOACCESS,
2180
                 &spr_read_generic, &spr_write_generic,
2181
                 0x00000000);
2182
    /* XXX : not implemented */
2183
    spr_register(env, SPR_620_PMRD, "PMR13",
2184
                 SPR_NOACCESS, SPR_NOACCESS,
2185
                 &spr_read_generic, &spr_write_generic,
2186
                 0x00000000);
2187
    /* XXX : not implemented */
2188
    spr_register(env, SPR_620_PMRE, "PMR14",
2189
                 SPR_NOACCESS, SPR_NOACCESS,
2190
                 &spr_read_generic, &spr_write_generic,
2191
                 0x00000000);
2192
    /* XXX : not implemented */
2193
    spr_register(env, SPR_620_PMRF, "PMR15",
2194
                 SPR_NOACCESS, SPR_NOACCESS,
2195
                 &spr_read_generic, &spr_write_generic,
2196
                 0x00000000);
2197
    /* XXX : not implemented */
2198
    spr_register(env, SPR_620_HID8, "HID8",
2199
                 SPR_NOACCESS, SPR_NOACCESS,
2200
                 &spr_read_generic, &spr_write_generic,
2201
                 0x00000000);
2202
    /* XXX : not implemented */
2203
    spr_register(env, SPR_620_HID9, "HID9",
2204
                 SPR_NOACCESS, SPR_NOACCESS,
2205
                 &spr_read_generic, &spr_write_generic,
2206
                 0x00000000);
2207
}
2208
#endif /* defined (TARGET_PPC64) */
2209

    
2210
// XXX: TODO
2211
/*
2212
 * AMR     => SPR 29 (Power 2.04)
2213
 * CTRL    => SPR 136 (Power 2.04)
2214
 * CTRL    => SPR 152 (Power 2.04)
2215
 * SCOMC   => SPR 276 (64 bits ?)
2216
 * SCOMD   => SPR 277 (64 bits ?)
2217
 * TBU40   => SPR 286 (Power 2.04 hypv)
2218
 * HSPRG0  => SPR 304 (Power 2.04 hypv)
2219
 * HSPRG1  => SPR 305 (Power 2.04 hypv)
2220
 * HDSISR  => SPR 306 (Power 2.04 hypv)
2221
 * HDAR    => SPR 307 (Power 2.04 hypv)
2222
 * PURR    => SPR 309 (Power 2.04 hypv)
2223
 * HDEC    => SPR 310 (Power 2.04 hypv)
2224
 * HIOR    => SPR 311 (hypv)
2225
 * RMOR    => SPR 312 (970)
2226
 * HRMOR   => SPR 313 (Power 2.04 hypv)
2227
 * HSRR0   => SPR 314 (Power 2.04 hypv)
2228
 * HSRR1   => SPR 315 (Power 2.04 hypv)
2229
 * LPCR    => SPR 316 (970)
2230
 * LPIDR   => SPR 317 (970)
2231
 * SPEFSCR => SPR 512 (Power 2.04 emb)
2232
 * EPR     => SPR 702 (Power 2.04 emb)
2233
 * perf    => 768-783 (Power 2.04)
2234
 * perf    => 784-799 (Power 2.04)
2235
 * PPR     => SPR 896 (Power 2.04)
2236
 * EPLC    => SPR 947 (Power 2.04 emb)
2237
 * EPSC    => SPR 948 (Power 2.04 emb)
2238
 * DABRX   => 1015    (Power 2.04 hypv)
2239
 * FPECR   => SPR 1022 (?)
2240
 * ... and more (thermal management, performance counters, ...)
2241
 */
2242

    
2243
/*****************************************************************************/
2244
/* Exception vectors models                                                  */
2245
static void init_excp_4xx_real (CPUPPCState *env)
2246
{
2247
#if !defined(CONFIG_USER_ONLY)
2248
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2249
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2250
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2251
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2252
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2253
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2254
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2255
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2256
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2257
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2258
    env->excp_prefix = 0x00000000UL;
2259
    env->ivor_mask = 0x0000FFF0UL;
2260
    env->ivpr_mask = 0xFFFF0000UL;
2261
    /* Hardware reset vector */
2262
    env->hreset_vector = 0xFFFFFFFCUL;
2263
#endif
2264
}
2265

    
2266
static void init_excp_4xx_softmmu (CPUPPCState *env)
2267
{
2268
#if !defined(CONFIG_USER_ONLY)
2269
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 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_SYSCALL]  = 0x00000C00;
2277
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2278
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2279
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2280
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001100;
2281
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001200;
2282
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2283
    env->excp_prefix = 0x00000000UL;
2284
    env->ivor_mask = 0x0000FFF0UL;
2285
    env->ivpr_mask = 0xFFFF0000UL;
2286
    /* Hardware reset vector */
2287
    env->hreset_vector = 0xFFFFFFFCUL;
2288
#endif
2289
}
2290

    
2291
static void init_excp_BookE (CPUPPCState *env)
2292
{
2293
#if !defined(CONFIG_USER_ONLY)
2294
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2295
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2296
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2297
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2298
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2299
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2300
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2301
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2302
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2303
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2304
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2305
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2306
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2307
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2308
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2309
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2310
    env->excp_prefix = 0x00000000UL;
2311
    env->ivor_mask = 0x0000FFE0UL;
2312
    env->ivpr_mask = 0xFFFF0000UL;
2313
    /* Hardware reset vector */
2314
    env->hreset_vector = 0xFFFFFFFCUL;
2315
#endif
2316
}
2317

    
2318
static void init_excp_601 (CPUPPCState *env)
2319
{
2320
#if !defined(CONFIG_USER_ONLY)
2321
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2322
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2323
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2324
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2325
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2326
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2327
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2328
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2329
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2330
    env->excp_vectors[POWERPC_EXCP_IO]       = 0x00000A00;
2331
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2332
    env->excp_vectors[POWERPC_EXCP_RUNM]     = 0x00002000;
2333
    env->excp_prefix = 0xFFF00000UL;
2334
    /* Hardware reset vector */
2335
    env->hreset_vector = 0x00000100UL;
2336
#endif
2337
}
2338

    
2339
static void init_excp_602 (CPUPPCState *env)
2340
{
2341
#if !defined(CONFIG_USER_ONLY)
2342
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2343
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2344
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2345
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2346
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2347
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2348
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2349
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2350
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2351
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2352
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2353
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2354
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2355
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2356
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2357
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2358
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2359
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001500;
2360
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001600;
2361
    env->excp_prefix = 0xFFF00000UL;
2362
    /* Hardware reset vector */
2363
    env->hreset_vector = 0xFFFFFFFCUL;
2364
#endif
2365
}
2366

    
2367
static void init_excp_603 (CPUPPCState *env)
2368
{
2369
#if !defined(CONFIG_USER_ONLY)
2370
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2371
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2372
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2373
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2374
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2375
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2376
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2377
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2378
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2379
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2380
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2381
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2382
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2383
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2384
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2385
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2386
    env->excp_prefix = 0x00000000UL;
2387
    /* Hardware reset vector */
2388
    env->hreset_vector = 0xFFFFFFFCUL;
2389
#endif
2390
}
2391

    
2392
static void init_excp_G2 (CPUPPCState *env)
2393
{
2394
#if !defined(CONFIG_USER_ONLY)
2395
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2396
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2397
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2398
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2399
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2400
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2401
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2402
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2403
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2404
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000A00;
2405
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2406
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2407
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2408
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2409
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2410
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2411
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2412
    env->excp_prefix = 0x00000000UL;
2413
    /* Hardware reset vector */
2414
    env->hreset_vector = 0xFFFFFFFCUL;
2415
#endif
2416
}
2417

    
2418
static void init_excp_604 (CPUPPCState *env)
2419
{
2420
#if !defined(CONFIG_USER_ONLY)
2421
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2422
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2423
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2424
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2425
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2426
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2427
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2428
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2429
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2430
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2431
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2432
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2433
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2434
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2435
    env->excp_prefix = 0x00000000UL;
2436
    /* Hardware reset vector */
2437
    env->hreset_vector = 0xFFFFFFFCUL;
2438
#endif
2439
}
2440

    
2441
#if defined(TARGET_PPC64)
2442
static void init_excp_620 (CPUPPCState *env)
2443
{
2444
#if !defined(CONFIG_USER_ONLY)
2445
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2446
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2447
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2448
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
2449
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2450
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
2451
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2452
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2453
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2454
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2455
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2456
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2457
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2458
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2459
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2460
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2461
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2462
    env->excp_prefix = 0xFFF00000UL;
2463
    /* Hardware reset vector */
2464
    env->hreset_vector = 0x0000000000000100ULL;
2465
#endif
2466
}
2467
#endif /* defined(TARGET_PPC64) */
2468

    
2469
static void init_excp_7x0 (CPUPPCState *env)
2470
{
2471
#if !defined(CONFIG_USER_ONLY)
2472
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2473
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2474
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2475
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2476
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2477
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2478
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2479
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2480
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2481
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2482
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2483
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2484
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2485
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2486
    env->excp_prefix = 0x00000000UL;
2487
    /* Hardware reset vector */
2488
    env->hreset_vector = 0xFFFFFFFCUL;
2489
#endif
2490
}
2491

    
2492
static void init_excp_750FX (CPUPPCState *env)
2493
{
2494
#if !defined(CONFIG_USER_ONLY)
2495
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2496
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2497
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2498
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2499
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2500
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2501
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2502
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2503
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2504
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2505
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2506
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2507
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2508
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2509
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2510
    env->excp_prefix = 0x00000000UL;
2511
    /* Hardware reset vector */
2512
    env->hreset_vector = 0xFFFFFFFCUL;
2513
#endif
2514
}
2515

    
2516
/* XXX: Check if this is correct */
2517
static void init_excp_7x5 (CPUPPCState *env)
2518
{
2519
#if !defined(CONFIG_USER_ONLY)
2520
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2521
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2522
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2523
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2524
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2525
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2526
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2527
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2528
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2529
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2530
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2531
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2532
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2533
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2534
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2535
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2536
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2537
    env->excp_prefix = 0x00000000UL;
2538
    /* Hardware reset vector */
2539
    env->hreset_vector = 0xFFFFFFFCUL;
2540
#endif
2541
}
2542

    
2543
static void init_excp_7400 (CPUPPCState *env)
2544
{
2545
#if !defined(CONFIG_USER_ONLY)
2546
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2547
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2548
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2549
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2550
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2551
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2552
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2553
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2554
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2555
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2556
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2557
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2558
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2559
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2560
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2561
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2562
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2563
    env->excp_prefix = 0x00000000UL;
2564
    /* Hardware reset vector */
2565
    env->hreset_vector = 0xFFFFFFFCUL;
2566
#endif
2567
}
2568

    
2569
static void init_excp_7450 (CPUPPCState *env)
2570
{
2571
#if !defined(CONFIG_USER_ONLY)
2572
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2573
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2574
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2575
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2576
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2577
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2578
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2579
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2580
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2581
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2582
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2583
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2584
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2585
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2586
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2587
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2588
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2589
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2590
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2591
    env->excp_prefix = 0x00000000UL;
2592
    /* Hardware reset vector */
2593
    env->hreset_vector = 0xFFFFFFFCUL;
2594
#endif
2595
}
2596

    
2597
#if defined (TARGET_PPC64)
2598
static void init_excp_970 (CPUPPCState *env)
2599
{
2600
#if !defined(CONFIG_USER_ONLY)
2601
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2602
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2603
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2604
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
2605
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2606
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
2607
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2608
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2609
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2610
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2611
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2612
#if defined(TARGET_PPC64H) /* PowerPC 64 with hypervisor mode support */
2613
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
2614
#endif
2615
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2616
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2617
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2618
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2619
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2620
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
2621
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
2622
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
2623
    env->excp_prefix   = 0x00000000FFF00000ULL;
2624
    /* Hardware reset vector */
2625
    env->hreset_vector = 0x0000000000000100ULL;
2626
#endif
2627
}
2628
#endif
2629

    
2630
/*****************************************************************************/
2631
/* Power management enable checks                                            */
2632
static int check_pow_none (CPUPPCState *env)
2633
{
2634
    return 0;
2635
}
2636

    
2637
static int check_pow_nocheck (CPUPPCState *env)
2638
{
2639
    return 1;
2640
}
2641

    
2642
static int check_pow_hid0 (CPUPPCState *env)
2643
{
2644
    if (env->spr[SPR_HID0] & 0x00E00000)
2645
        return 1;
2646

    
2647
    return 0;
2648
}
2649

    
2650
/*****************************************************************************/
2651
/* PowerPC implementations definitions                                       */
2652

    
2653
/* PowerPC 40x instruction set                                               */
2654
#define POWERPC_INSNS_EMB    (PPC_INSNS_BASE | PPC_EMB_COMMON |               \
2655
                              PPC_CACHE | PPC_CACHE_ICBI | PPC_CACHE_DCBZ)
2656

    
2657
/* PowerPC 401                                                               */
2658
#define POWERPC_INSNS_401    (POWERPC_INSNS_EMB |                             \
2659
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2660
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2661
#define POWERPC_MSRM_401     (0x00000000000FD201ULL)
2662
#define POWERPC_MMU_401      (POWERPC_MMU_REAL_4xx)
2663
#define POWERPC_EXCP_401     (POWERPC_EXCP_40x)
2664
#define POWERPC_INPUT_401    (PPC_FLAGS_INPUT_401)
2665
#define POWERPC_BFDM_401     (bfd_mach_ppc_403)
2666
#define POWERPC_FLAG_401     (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2667
#define check_pow_401        check_pow_nocheck
2668

    
2669
static void init_proc_401 (CPUPPCState *env)
2670
{
2671
    gen_spr_40x(env);
2672
    gen_spr_401_403(env);
2673
    gen_spr_401(env);
2674
    init_excp_4xx_real(env);
2675
    env->dcache_line_size = 32;
2676
    env->icache_line_size = 32;
2677
    /* Allocate hardware IRQ controller */
2678
    ppc40x_irq_init(env);
2679
}
2680

    
2681
/* PowerPC 401x2                                                             */
2682
#define POWERPC_INSNS_401x2  (POWERPC_INSNS_EMB |                             \
2683
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2684
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2685
                              PPC_CACHE_DCBA | PPC_MFTB |                     \
2686
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2687
#define POWERPC_MSRM_401x2   (0x00000000001FD231ULL)
2688
#define POWERPC_MMU_401x2    (POWERPC_MMU_SOFT_4xx_Z)
2689
#define POWERPC_EXCP_401x2   (POWERPC_EXCP_40x)
2690
#define POWERPC_INPUT_401x2  (PPC_FLAGS_INPUT_401)
2691
#define POWERPC_BFDM_401x2   (bfd_mach_ppc_403)
2692
#define POWERPC_FLAG_401x2   (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2693
#define check_pow_401x2      check_pow_nocheck
2694

    
2695
static void init_proc_401x2 (CPUPPCState *env)
2696
{
2697
    gen_spr_40x(env);
2698
    gen_spr_401_403(env);
2699
    gen_spr_401x2(env);
2700
    gen_spr_compress(env);
2701
    /* Memory management */
2702
#if !defined(CONFIG_USER_ONLY)
2703
    env->nb_tlb = 64;
2704
    env->nb_ways = 1;
2705
    env->id_tlbs = 0;
2706
#endif
2707
    init_excp_4xx_softmmu(env);
2708
    env->dcache_line_size = 32;
2709
    env->icache_line_size = 32;
2710
    /* Allocate hardware IRQ controller */
2711
    ppc40x_irq_init(env);
2712
}
2713

    
2714
/* PowerPC 401x3                                                             */
2715
#define POWERPC_INSNS_401x3  (POWERPC_INSNS_EMB |                             \
2716
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2717
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2718
                              PPC_CACHE_DCBA | PPC_MFTB |                     \
2719
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2720
#define POWERPC_MSRM_401x3   (0x00000000001FD631ULL)
2721
#define POWERPC_MMU_401x3    (POWERPC_MMU_SOFT_4xx_Z)
2722
#define POWERPC_EXCP_401x3   (POWERPC_EXCP_40x)
2723
#define POWERPC_INPUT_401x3  (PPC_FLAGS_INPUT_401)
2724
#define POWERPC_BFDM_401x3   (bfd_mach_ppc_403)
2725
#define POWERPC_FLAG_401x3   (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2726
#define check_pow_401x3      check_pow_nocheck
2727

    
2728
__attribute__ (( unused ))
2729
static void init_proc_401x3 (CPUPPCState *env)
2730
{
2731
    gen_spr_40x(env);
2732
    gen_spr_401_403(env);
2733
    gen_spr_401(env);
2734
    gen_spr_401x2(env);
2735
    gen_spr_compress(env);
2736
    init_excp_4xx_softmmu(env);
2737
    env->dcache_line_size = 32;
2738
    env->icache_line_size = 32;
2739
    /* Allocate hardware IRQ controller */
2740
    ppc40x_irq_init(env);
2741
}
2742

    
2743
/* IOP480                                                                    */
2744
#define POWERPC_INSNS_IOP480 (POWERPC_INSNS_EMB |                             \
2745
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2746
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2747
                              PPC_CACHE_DCBA |                                \
2748
                              PPC_4xx_COMMON | PPC_40x_EXCP |  PPC_40x_ICBT)
2749
#define POWERPC_MSRM_IOP480  (0x00000000001FD231ULL)
2750
#define POWERPC_MMU_IOP480   (POWERPC_MMU_SOFT_4xx_Z)
2751
#define POWERPC_EXCP_IOP480  (POWERPC_EXCP_40x)
2752
#define POWERPC_INPUT_IOP480 (PPC_FLAGS_INPUT_401)
2753
#define POWERPC_BFDM_IOP480  (bfd_mach_ppc_403)
2754
#define POWERPC_FLAG_IOP480  (POWERPC_FLAG_CE | POWERPC_FLAG_DE)
2755
#define check_pow_IOP480     check_pow_nocheck
2756

    
2757
static void init_proc_IOP480 (CPUPPCState *env)
2758
{
2759
    gen_spr_40x(env);
2760
    gen_spr_401_403(env);
2761
    gen_spr_401x2(env);
2762
    gen_spr_compress(env);
2763
    /* Memory management */
2764
#if !defined(CONFIG_USER_ONLY)
2765
    env->nb_tlb = 64;
2766
    env->nb_ways = 1;
2767
    env->id_tlbs = 0;
2768
#endif
2769
    init_excp_4xx_softmmu(env);
2770
    env->dcache_line_size = 32;
2771
    env->icache_line_size = 32;
2772
    /* Allocate hardware IRQ controller */
2773
    ppc40x_irq_init(env);
2774
}
2775

    
2776
/* PowerPC 403                                                               */
2777
#define POWERPC_INSNS_403    (POWERPC_INSNS_EMB |                             \
2778
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2779
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2780
#define POWERPC_MSRM_403     (0x000000000007D00DULL)
2781
#define POWERPC_MMU_403      (POWERPC_MMU_REAL_4xx)
2782
#define POWERPC_EXCP_403     (POWERPC_EXCP_40x)
2783
#define POWERPC_INPUT_403    (PPC_FLAGS_INPUT_401)
2784
#define POWERPC_BFDM_403     (bfd_mach_ppc_403)
2785
#define POWERPC_FLAG_403     (POWERPC_FLAG_CE | POWERPC_FLAG_PX)
2786
#define check_pow_403        check_pow_nocheck
2787

    
2788
static void init_proc_403 (CPUPPCState *env)
2789
{
2790
    gen_spr_40x(env);
2791
    gen_spr_401_403(env);
2792
    gen_spr_403(env);
2793
    gen_spr_403_real(env);
2794
    init_excp_4xx_real(env);
2795
    env->dcache_line_size = 32;
2796
    env->icache_line_size = 32;
2797
    /* Allocate hardware IRQ controller */
2798
    ppc40x_irq_init(env);
2799
#if !defined(CONFIG_USER_ONLY)
2800
    /* Hardware reset vector */
2801
    env->hreset_vector = 0xFFFFFFFCUL;
2802
#endif
2803
}
2804

    
2805
/* PowerPC 403 GCX                                                           */
2806
#define POWERPC_INSNS_403GCX (POWERPC_INSNS_EMB |                             \
2807
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2808
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2809
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2810
#define POWERPC_MSRM_403GCX  (0x000000000007D00DULL)
2811
#define POWERPC_MMU_403GCX   (POWERPC_MMU_SOFT_4xx_Z)
2812
#define POWERPC_EXCP_403GCX  (POWERPC_EXCP_40x)
2813
#define POWERPC_INPUT_403GCX (PPC_FLAGS_INPUT_401)
2814
#define POWERPC_BFDM_403GCX  (bfd_mach_ppc_403)
2815
#define POWERPC_FLAG_403GCX  (POWERPC_FLAG_CE | POWERPC_FLAG_PX)
2816
#define check_pow_403GCX     check_pow_nocheck
2817

    
2818
static void init_proc_403GCX (CPUPPCState *env)
2819
{
2820
    gen_spr_40x(env);
2821
    gen_spr_401_403(env);
2822
    gen_spr_403(env);
2823
    gen_spr_403_real(env);
2824
    gen_spr_403_mmu(env);
2825
    /* Bus access control */
2826
    /* not emulated, as Qemu never does speculative access */
2827
    spr_register(env, SPR_40x_SGR, "SGR",
2828
                 SPR_NOACCESS, SPR_NOACCESS,
2829
                 &spr_read_generic, &spr_write_generic,
2830
                 0xFFFFFFFF);
2831
    /* not emulated, as Qemu do not emulate caches */
2832
    spr_register(env, SPR_40x_DCWR, "DCWR",
2833
                 SPR_NOACCESS, SPR_NOACCESS,
2834
                 &spr_read_generic, &spr_write_generic,
2835
                 0x00000000);
2836
    /* Memory management */
2837
#if !defined(CONFIG_USER_ONLY)
2838
    env->nb_tlb = 64;
2839
    env->nb_ways = 1;
2840
    env->id_tlbs = 0;
2841
#endif
2842
    init_excp_4xx_softmmu(env);
2843
    env->dcache_line_size = 32;
2844
    env->icache_line_size = 32;
2845
    /* Allocate hardware IRQ controller */
2846
    ppc40x_irq_init(env);
2847
}
2848

    
2849
/* PowerPC 405                                                               */
2850
#define POWERPC_INSNS_405    (POWERPC_INSNS_EMB | PPC_MFTB |                  \
2851
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_CACHE_DCBA | \
2852
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2853
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT |  \
2854
                              PPC_405_MAC)
2855
#define POWERPC_MSRM_405     (0x000000000006E630ULL)
2856
#define POWERPC_MMU_405      (POWERPC_MMU_SOFT_4xx)
2857
#define POWERPC_EXCP_405     (POWERPC_EXCP_40x)
2858
#define POWERPC_INPUT_405    (PPC_FLAGS_INPUT_405)
2859
#define POWERPC_BFDM_405     (bfd_mach_ppc_403)
2860
#define POWERPC_FLAG_405     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2861
                              POWERPC_FLAG_DE)
2862
#define check_pow_405        check_pow_nocheck
2863

    
2864
static void init_proc_405 (CPUPPCState *env)
2865
{
2866
    /* Time base */
2867
    gen_tbl(env);
2868
    gen_spr_40x(env);
2869
    gen_spr_405(env);
2870
    /* Bus access control */
2871
    /* not emulated, as Qemu never does speculative access */
2872
    spr_register(env, SPR_40x_SGR, "SGR",
2873
                 SPR_NOACCESS, SPR_NOACCESS,
2874
                 &spr_read_generic, &spr_write_generic,
2875
                 0xFFFFFFFF);
2876
    /* not emulated, as Qemu do not emulate caches */
2877
    spr_register(env, SPR_40x_DCWR, "DCWR",
2878
                 SPR_NOACCESS, SPR_NOACCESS,
2879
                 &spr_read_generic, &spr_write_generic,
2880
                 0x00000000);
2881
    /* Memory management */
2882
#if !defined(CONFIG_USER_ONLY)
2883
    env->nb_tlb = 64;
2884
    env->nb_ways = 1;
2885
    env->id_tlbs = 0;
2886
#endif
2887
    init_excp_4xx_softmmu(env);
2888
    env->dcache_line_size = 32;
2889
    env->icache_line_size = 32;
2890
    /* Allocate hardware IRQ controller */
2891
    ppc40x_irq_init(env);
2892
}
2893

    
2894
/* PowerPC 440 EP                                                            */
2895
#define POWERPC_INSNS_440EP  (POWERPC_INSNS_EMB |                             \
2896
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2897
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2898
                              PPC_440_SPEC | PPC_RFMCI)
2899
#define POWERPC_MSRM_440EP   (0x000000000006D630ULL)
2900
#define POWERPC_MMU_440EP    (POWERPC_MMU_BOOKE)
2901
#define POWERPC_EXCP_440EP   (POWERPC_EXCP_BOOKE)
2902
#define POWERPC_INPUT_440EP  (PPC_FLAGS_INPUT_BookE)
2903
#define POWERPC_BFDM_440EP   (bfd_mach_ppc_403)
2904
#define POWERPC_FLAG_440EP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2905
                              POWERPC_FLAG_DE)
2906
#define check_pow_440EP      check_pow_nocheck
2907

    
2908
static void init_proc_440EP (CPUPPCState *env)
2909
{
2910
    /* Time base */
2911
    gen_tbl(env);
2912
    gen_spr_BookE(env);
2913
    gen_spr_440(env);
2914
    /* XXX : not implemented */
2915
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
2916
                 SPR_NOACCESS, SPR_NOACCESS,
2917
                 &spr_read_generic, &spr_write_generic,
2918
                 0x00000000);
2919
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
2920
                 SPR_NOACCESS, SPR_NOACCESS,
2921
                 &spr_read_generic, &spr_write_generic,
2922
                 0x00000000);
2923
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
2924
                 SPR_NOACCESS, SPR_NOACCESS,
2925
                 &spr_read_generic, &spr_write_generic,
2926
                 0x00000000);
2927
    /* XXX : not implemented */
2928
    spr_register(env, SPR_440_CCR1, "CCR1",
2929
                 SPR_NOACCESS, SPR_NOACCESS,
2930
                 &spr_read_generic, &spr_write_generic,
2931
                 0x00000000);
2932
    /* Memory management */
2933
#if !defined(CONFIG_USER_ONLY)
2934
    env->nb_tlb = 64;
2935
    env->nb_ways = 1;
2936
    env->id_tlbs = 0;
2937
#endif
2938
    init_excp_BookE(env);
2939
    env->dcache_line_size = 32;
2940
    env->icache_line_size = 32;
2941
    /* XXX: TODO: allocate internal IRQ controller */
2942
}
2943

    
2944
/* PowerPC 440 GP                                                            */
2945
#define POWERPC_INSNS_440GP  (POWERPC_INSNS_EMB |                             \
2946
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2947
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
2948
                              PPC_405_MAC | PPC_440_SPEC)
2949
#define POWERPC_MSRM_440GP   (0x000000000006FF30ULL)
2950
#define POWERPC_MMU_440GP    (POWERPC_MMU_BOOKE)
2951
#define POWERPC_EXCP_440GP   (POWERPC_EXCP_BOOKE)
2952
#define POWERPC_INPUT_440GP  (PPC_FLAGS_INPUT_BookE)
2953
#define POWERPC_BFDM_440GP   (bfd_mach_ppc_403)
2954
#define POWERPC_FLAG_440GP   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2955
                              POWERPC_FLAG_DE)
2956
#define check_pow_440GP      check_pow_nocheck
2957

    
2958
static void init_proc_440GP (CPUPPCState *env)
2959
{
2960
    /* Time base */
2961
    gen_tbl(env);
2962
    gen_spr_BookE(env);
2963
    gen_spr_440(env);
2964
    /* Memory management */
2965
#if !defined(CONFIG_USER_ONLY)
2966
    env->nb_tlb = 64;
2967
    env->nb_ways = 1;
2968
    env->id_tlbs = 0;
2969
#endif
2970
    init_excp_BookE(env);
2971
    env->dcache_line_size = 32;
2972
    env->icache_line_size = 32;
2973
    /* XXX: TODO: allocate internal IRQ controller */
2974
}
2975

    
2976
/* PowerPC 440x4                                                             */
2977
#define POWERPC_INSNS_440x4  (POWERPC_INSNS_EMB |                             \
2978
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2979
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2980
                              PPC_440_SPEC)
2981
#define POWERPC_MSRM_440x4   (0x000000000006FF30ULL)
2982
#define POWERPC_MMU_440x4    (POWERPC_MMU_BOOKE)
2983
#define POWERPC_EXCP_440x4   (POWERPC_EXCP_BOOKE)
2984
#define POWERPC_INPUT_440x4  (PPC_FLAGS_INPUT_BookE)
2985
#define POWERPC_BFDM_440x4   (bfd_mach_ppc_403)
2986
#define POWERPC_FLAG_440x4   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
2987
                              POWERPC_FLAG_DE)
2988
#define check_pow_440x4      check_pow_nocheck
2989

    
2990
__attribute__ (( unused ))
2991
static void init_proc_440x4 (CPUPPCState *env)
2992
{
2993
    /* Time base */
2994
    gen_tbl(env);
2995
    gen_spr_BookE(env);
2996
    gen_spr_440(env);
2997
    /* Memory management */
2998
#if !defined(CONFIG_USER_ONLY)
2999
    env->nb_tlb = 64;
3000
    env->nb_ways = 1;
3001
    env->id_tlbs = 0;
3002
#endif
3003
    init_excp_BookE(env);
3004
    env->dcache_line_size = 32;
3005
    env->icache_line_size = 32;
3006
    /* XXX: TODO: allocate internal IRQ controller */
3007
}
3008

    
3009
/* PowerPC 440x5                                                             */
3010
#define POWERPC_INSNS_440x5  (POWERPC_INSNS_EMB |                             \
3011
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
3012
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
3013
                              PPC_440_SPEC | PPC_RFMCI)
3014
#define POWERPC_MSRM_440x5   (0x000000000006FF30ULL)
3015
#define POWERPC_MMU_440x5    (POWERPC_MMU_BOOKE)
3016
#define POWERPC_EXCP_440x5   (POWERPC_EXCP_BOOKE)
3017
#define POWERPC_INPUT_440x5  (PPC_FLAGS_INPUT_BookE)
3018
#define POWERPC_BFDM_440x5   (bfd_mach_ppc_403)
3019
#define POWERPC_FLAG_440x5   (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |           \
3020
                              POWERPC_FLAG_DE)
3021
#define check_pow_440x5      check_pow_nocheck
3022

    
3023
static void init_proc_440x5 (CPUPPCState *env)
3024
{
3025
    /* Time base */
3026
    gen_tbl(env);
3027
    gen_spr_BookE(env);
3028
    gen_spr_440(env);
3029
    /* XXX : not implemented */
3030
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3031
                 SPR_NOACCESS, SPR_NOACCESS,
3032
                 &spr_read_generic, &spr_write_generic,
3033
                 0x00000000);
3034
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3035
                 SPR_NOACCESS, SPR_NOACCESS,
3036
                 &spr_read_generic, &spr_write_generic,
3037
                 0x00000000);
3038
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3039
                 SPR_NOACCESS, SPR_NOACCESS,
3040
                 &spr_read_generic, &spr_write_generic,
3041
                 0x00000000);
3042
    /* XXX : not implemented */
3043
    spr_register(env, SPR_440_CCR1, "CCR1",
3044
                 SPR_NOACCESS, SPR_NOACCESS,
3045
                 &spr_read_generic, &spr_write_generic,
3046
                 0x00000000);
3047
    /* Memory management */
3048
#if !defined(CONFIG_USER_ONLY)
3049
    env->nb_tlb = 64;
3050
    env->nb_ways = 1;
3051
    env->id_tlbs = 0;
3052
#endif
3053
    init_excp_BookE(env);
3054
    env->dcache_line_size = 32;
3055
    env->icache_line_size = 32;
3056
    /* XXX: TODO: allocate internal IRQ controller */
3057
}
3058

    
3059
/* PowerPC 460 (guessed)                                                     */
3060
#define POWERPC_INSNS_460    (POWERPC_INSNS_EMB |                             \
3061
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
3062
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
3063
                              PPC_405_MAC | PPC_440_SPEC | PPC_DCRUX)
3064
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3065
#define POWERPC_MMU_460      (POWERPC_MMU_BOOKE)
3066
#define POWERPC_EXCP_460     (POWERPC_EXCP_BOOKE)
3067
#define POWERPC_INPUT_460    (PPC_FLAGS_INPUT_BookE)
3068
#define POWERPC_BFDM_460     (bfd_mach_ppc_403)
3069
#define POWERPC_FLAG_460     (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3070
                              POWERPC_FLAG_DE)
3071
#define check_pow_460        check_pow_nocheck
3072

    
3073
__attribute__ (( unused ))
3074
static void init_proc_460 (CPUPPCState *env)
3075
{
3076
    /* Time base */
3077
    gen_tbl(env);
3078
    gen_spr_BookE(env);
3079
    gen_spr_440(env);
3080
    /* XXX : not implemented */
3081
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3082
                 SPR_NOACCESS, SPR_NOACCESS,
3083
                 &spr_read_generic, &spr_write_generic,
3084
                 0x00000000);
3085
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3086
                 SPR_NOACCESS, SPR_NOACCESS,
3087
                 &spr_read_generic, &spr_write_generic,
3088
                 0x00000000);
3089
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3090
                 SPR_NOACCESS, SPR_NOACCESS,
3091
                 &spr_read_generic, &spr_write_generic,
3092
                 0x00000000);
3093
    /* XXX : not implemented */
3094
    spr_register(env, SPR_440_CCR1, "CCR1",
3095
                 SPR_NOACCESS, SPR_NOACCESS,
3096
                 &spr_read_generic, &spr_write_generic,
3097
                 0x00000000);
3098
    /* XXX : not implemented */
3099
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3100
                 &spr_read_generic, &spr_write_generic,
3101
                 &spr_read_generic, &spr_write_generic,
3102
                 0x00000000);
3103
    /* Memory management */
3104
#if !defined(CONFIG_USER_ONLY)
3105
    env->nb_tlb = 64;
3106
    env->nb_ways = 1;
3107
    env->id_tlbs = 0;
3108
#endif
3109
    init_excp_BookE(env);
3110
    env->dcache_line_size = 32;
3111
    env->icache_line_size = 32;
3112
    /* XXX: TODO: allocate internal IRQ controller */
3113
}
3114

    
3115
/* PowerPC 460F (guessed)                                                    */
3116
#define POWERPC_INSNS_460F   (POWERPC_INSNS_EMB |                             \
3117
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
3118
                              PPC_FLOAT | PPC_FLOAT_FSQRT | PPC_FLOAT_FRES |  \
3119
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_FSEL |            \
3120
                              PPC_FLOAT_STFIWX |                              \
3121
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
3122
                              PPC_405_MAC | PPC_440_SPEC | PPC_DCRUX)
3123
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
3124
#define POWERPC_MMU_460F     (POWERPC_MMU_BOOKE)
3125
#define POWERPC_EXCP_460F    (POWERPC_EXCP_BOOKE)
3126
#define POWERPC_INPUT_460F   (PPC_FLAGS_INPUT_BookE)
3127
#define POWERPC_BFDM_460F    (bfd_mach_ppc_403)
3128
#define POWERPC_FLAG_460F    (POWERPC_FLAG_CE | POWERPC_FLAG_DWE |            \
3129
                              POWERPC_FLAG_DE)
3130
#define check_pow_460F       check_pow_nocheck
3131

    
3132
__attribute__ (( unused ))
3133
static void init_proc_460F (CPUPPCState *env)
3134
{
3135
    /* Time base */
3136
    gen_tbl(env);
3137
    gen_spr_BookE(env);
3138
    gen_spr_440(env);
3139
    /* XXX : not implemented */
3140
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
3141
                 SPR_NOACCESS, SPR_NOACCESS,
3142
                 &spr_read_generic, &spr_write_generic,
3143
                 0x00000000);
3144
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
3145
                 SPR_NOACCESS, SPR_NOACCESS,
3146
                 &spr_read_generic, &spr_write_generic,
3147
                 0x00000000);
3148
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
3149
                 SPR_NOACCESS, SPR_NOACCESS,
3150
                 &spr_read_generic, &spr_write_generic,
3151
                 0x00000000);
3152
    /* XXX : not implemented */
3153
    spr_register(env, SPR_440_CCR1, "CCR1",
3154
                 SPR_NOACCESS, SPR_NOACCESS,
3155
                 &spr_read_generic, &spr_write_generic,
3156
                 0x00000000);
3157
    /* XXX : not implemented */
3158
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
3159
                 &spr_read_generic, &spr_write_generic,
3160
                 &spr_read_generic, &spr_write_generic,
3161
                 0x00000000);
3162
    /* Memory management */
3163
#if !defined(CONFIG_USER_ONLY)
3164
    env->nb_tlb = 64;
3165
    env->nb_ways = 1;
3166
    env->id_tlbs = 0;
3167
#endif
3168
    init_excp_BookE(env);
3169
    env->dcache_line_size = 32;
3170
    env->icache_line_size = 32;
3171
    /* XXX: TODO: allocate internal IRQ controller */
3172
}
3173

    
3174
/* Generic BookE PowerPC                                                     */
3175
#define POWERPC_INSNS_BookE  (POWERPC_INSNS_EMB |                             \
3176
                              PPC_MEM_EIEIO | PPC_MEM_TLBSYNC |               \
3177
                              PPC_CACHE_DCBA |                                \
3178
                              PPC_FLOAT | PPC_FLOAT_FSQRT |                   \
3179
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3180
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |             \
3181
                              PPC_BOOKE)
3182
#define POWERPC_MSRM_BookE   (0x000000000006D630ULL)
3183
#define POWERPC_MMU_BookE    (POWERPC_MMU_BOOKE)
3184
#define POWERPC_EXCP_BookE   (POWERPC_EXCP_BOOKE)
3185
#define POWERPC_INPUT_BookE  (PPC_FLAGS_INPUT_BookE)
3186
#define POWERPC_BFDM_BookE   (bfd_mach_ppc_403)
3187
#define POWERPC_FLAG_BookE   (POWERPC_FLAG_NONE)
3188
#define check_pow_BookE      check_pow_nocheck
3189

    
3190
__attribute__ (( unused ))
3191
static void init_proc_BookE (CPUPPCState *env)
3192
{
3193
    init_excp_BookE(env);
3194
    env->dcache_line_size = 32;
3195
    env->icache_line_size = 32;
3196
}
3197

    
3198
/* e200 core                                                                 */
3199

    
3200
/* e300 core                                                                 */
3201

    
3202
/* e500 core                                                                 */
3203
#define POWERPC_INSNS_e500   (POWERPC_INSNS_EMB |                             \
3204
                              PPC_MEM_EIEIO | PPC_MEM_TLBSYNC |               \
3205
                              PPC_CACHE_DCBA |                                \
3206
                              PPC_BOOKE | PPC_E500_VECTOR)
3207
#define POWERPC_MMU_e500     (POWERPC_MMU_SOFT_4xx)
3208
#define POWERPC_EXCP_e500    (POWERPC_EXCP_40x)
3209
#define POWERPC_INPUT_e500   (PPC_FLAGS_INPUT_BookE)
3210
#define POWERPC_BFDM_e500    (bfd_mach_ppc_403)
3211
#define POWERPC_FLAG_e500    (POWERPC_FLAG_SPE)
3212
#define check_pow_e500       check_pow_hid0
3213

    
3214
__attribute__ (( unused ))
3215
static void init_proc_e500 (CPUPPCState *env)
3216
{
3217
    /* Time base */
3218
    gen_tbl(env);
3219
    gen_spr_BookE(env);
3220
    /* Memory management */
3221
    gen_spr_BookE_FSL(env);
3222
#if !defined(CONFIG_USER_ONLY)
3223
    env->nb_tlb = 64;
3224
    env->nb_ways = 1;
3225
    env->id_tlbs = 0;
3226
#endif
3227
    init_excp_BookE(env);
3228
    env->dcache_line_size = 32;
3229
    env->icache_line_size = 32;
3230
    /* XXX: TODO: allocate internal IRQ controller */
3231
}
3232

    
3233
/* e600 core                                                                 */
3234

    
3235
/* Non-embedded PowerPC                                                      */
3236
/* Base instructions set for all 6xx/7xx/74xx/970 PowerPC                    */
3237
#define POWERPC_INSNS_6xx    (PPC_INSNS_BASE | PPC_FLOAT |                    \
3238
                              PPC_CACHE | PPC_CACHE_ICBI |                    \
3239
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_MEM_TLBIE)
3240
/* Instructions common to all 6xx/7xx/74xx/970 PowerPC except 601 & 602      */
3241
#define POWERPC_INSNS_WORKS  (POWERPC_INSNS_6xx | PPC_FLOAT_FSQRT |           \
3242
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3243
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |             \
3244
                              PPC_MEM_TLBSYNC | PPC_CACHE_DCBZ | PPC_MFTB |   \
3245
                              PPC_SEGMENT)
3246

    
3247
/* POWER : same as 601, without mfmsr, mfsr                                  */
3248
#if defined(TODO)
3249
#define POWERPC_INSNS_POWER  (XXX_TODO)
3250
/* POWER RSC (from RAD6000) */
3251
#define POWERPC_MSRM_POWER   (0x00000000FEF0ULL)
3252
#endif /* TODO */
3253

    
3254
/* PowerPC 601                                                               */
3255
#define POWERPC_INSNS_601    (POWERPC_INSNS_6xx | PPC_CACHE_DCBZ |            \
3256
                              PPC_SEGMENT | PPC_EXTERN | PPC_POWER_BR)
3257
#define POWERPC_MSRM_601     (0x000000000000FD70ULL)
3258
//#define POWERPC_MMU_601      (POWERPC_MMU_601)
3259
//#define POWERPC_EXCP_601     (POWERPC_EXCP_601)
3260
#define POWERPC_INPUT_601    (PPC_FLAGS_INPUT_6xx)
3261
#define POWERPC_BFDM_601     (bfd_mach_ppc_601)
3262
#define POWERPC_FLAG_601     (POWERPC_FLAG_SE)
3263
#define check_pow_601        check_pow_none
3264

    
3265
static void init_proc_601 (CPUPPCState *env)
3266
{
3267
    gen_spr_ne_601(env);
3268
    gen_spr_601(env);
3269
    /* Hardware implementation registers */
3270
    /* XXX : not implemented */
3271
    spr_register(env, SPR_HID0, "HID0",
3272
                 SPR_NOACCESS, SPR_NOACCESS,
3273
                 &spr_read_generic, &spr_write_hid0_601,
3274
                 0x80010080);
3275
    /* XXX : not implemented */
3276
    spr_register(env, SPR_HID1, "HID1",
3277
                 SPR_NOACCESS, SPR_NOACCESS,
3278
                 &spr_read_generic, &spr_write_generic,
3279
                 0x00000000);
3280
    /* XXX : not implemented */
3281
    spr_register(env, SPR_601_HID2, "HID2",
3282
                 SPR_NOACCESS, SPR_NOACCESS,
3283
                 &spr_read_generic, &spr_write_generic,
3284
                 0x00000000);
3285
    /* XXX : not implemented */
3286
    spr_register(env, SPR_601_HID5, "HID5",
3287
                 SPR_NOACCESS, SPR_NOACCESS,
3288
                 &spr_read_generic, &spr_write_generic,
3289
                 0x00000000);
3290
    /* XXX : not implemented */
3291
    spr_register(env, SPR_601_HID15, "HID15",
3292
                 SPR_NOACCESS, SPR_NOACCESS,
3293
                 &spr_read_generic, &spr_write_generic,
3294
                 0x00000000);
3295
    /* Memory management */
3296
#if !defined(CONFIG_USER_ONLY)
3297
    env->nb_tlb = 64;
3298
    env->nb_ways = 2;
3299
    env->id_tlbs = 0;
3300
#endif
3301
    init_excp_601(env);
3302
    env->dcache_line_size = 64;
3303
    env->icache_line_size = 64;
3304
    /* Allocate hardware IRQ controller */
3305
    ppc6xx_irq_init(env);
3306
}
3307

    
3308
/* PowerPC 602                                                               */
3309
#define POWERPC_INSNS_602    (POWERPC_INSNS_6xx | PPC_MFTB |                  \
3310
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3311
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |             \
3312
                              PPC_6xx_TLB | PPC_MEM_TLBSYNC | PPC_CACHE_DCBZ |\
3313
                              PPC_SEGMENT | PPC_602_SPEC)
3314
#define POWERPC_MSRM_602     (0x000000000033FF73ULL)
3315
#define POWERPC_MMU_602      (POWERPC_MMU_SOFT_6xx)
3316
//#define POWERPC_EXCP_602     (POWERPC_EXCP_602)
3317
#define POWERPC_INPUT_602    (PPC_FLAGS_INPUT_6xx)
3318
#define POWERPC_BFDM_602     (bfd_mach_ppc_602)
3319
#define POWERPC_FLAG_602     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3320
                              POWERPC_FLAG_BE)
3321
#define check_pow_602        check_pow_hid0
3322

    
3323
static void init_proc_602 (CPUPPCState *env)
3324
{
3325
    gen_spr_ne_601(env);
3326
    gen_spr_602(env);
3327
    /* Time base */
3328
    gen_tbl(env);
3329
    /* hardware implementation registers */
3330
    /* XXX : not implemented */
3331
    spr_register(env, SPR_HID0, "HID0",
3332
                 SPR_NOACCESS, SPR_NOACCESS,
3333
                 &spr_read_generic, &spr_write_generic,
3334
                 0x00000000);
3335
    /* XXX : not implemented */
3336
    spr_register(env, SPR_HID1, "HID1",
3337
                 SPR_NOACCESS, SPR_NOACCESS,
3338
                 &spr_read_generic, &spr_write_generic,
3339
                 0x00000000);
3340
    /* Memory management */
3341
    gen_low_BATs(env);
3342
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3343
    init_excp_602(env);
3344
    env->dcache_line_size = 32;
3345
    env->icache_line_size = 32;
3346
    /* Allocate hardware IRQ controller */
3347
    ppc6xx_irq_init(env);
3348
}
3349

    
3350
/* PowerPC 603                                                               */
3351
#define POWERPC_INSNS_603    (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3352
#define POWERPC_MSRM_603     (0x000000000007FF73ULL)
3353
#define POWERPC_MMU_603      (POWERPC_MMU_SOFT_6xx)
3354
//#define POWERPC_EXCP_603     (POWERPC_EXCP_603)
3355
#define POWERPC_INPUT_603    (PPC_FLAGS_INPUT_6xx)
3356
#define POWERPC_BFDM_603     (bfd_mach_ppc_603)
3357
#define POWERPC_FLAG_603     (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3358
                              POWERPC_FLAG_BE)
3359
#define check_pow_603        check_pow_hid0
3360

    
3361
static void init_proc_603 (CPUPPCState *env)
3362
{
3363
    gen_spr_ne_601(env);
3364
    gen_spr_603(env);
3365
    /* Time base */
3366
    gen_tbl(env);
3367
    /* hardware implementation registers */
3368
    /* XXX : not implemented */
3369
    spr_register(env, SPR_HID0, "HID0",
3370
                 SPR_NOACCESS, SPR_NOACCESS,
3371
                 &spr_read_generic, &spr_write_generic,
3372
                 0x00000000);
3373
    /* XXX : not implemented */
3374
    spr_register(env, SPR_HID1, "HID1",
3375
                 SPR_NOACCESS, SPR_NOACCESS,
3376
                 &spr_read_generic, &spr_write_generic,
3377
                 0x00000000);
3378
    /* Memory management */
3379
    gen_low_BATs(env);
3380
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3381
    init_excp_603(env);
3382
    env->dcache_line_size = 32;
3383
    env->icache_line_size = 32;
3384
    /* Allocate hardware IRQ controller */
3385
    ppc6xx_irq_init(env);
3386
}
3387

    
3388
/* PowerPC 603e                                                              */
3389
#define POWERPC_INSNS_603E   (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3390
#define POWERPC_MSRM_603E    (0x000000000007FF73ULL)
3391
#define POWERPC_MMU_603E     (POWERPC_MMU_SOFT_6xx)
3392
//#define POWERPC_EXCP_603E    (POWERPC_EXCP_603E)
3393
#define POWERPC_INPUT_603E   (PPC_FLAGS_INPUT_6xx)
3394
#define POWERPC_BFDM_603E    (bfd_mach_ppc_ec603e)
3395
#define POWERPC_FLAG_603E    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3396
                              POWERPC_FLAG_BE)
3397
#define check_pow_603E       check_pow_hid0
3398

    
3399
static void init_proc_603E (CPUPPCState *env)
3400
{
3401
    gen_spr_ne_601(env);
3402
    gen_spr_603(env);
3403
    /* Time base */
3404
    gen_tbl(env);
3405
    /* hardware implementation registers */
3406
    /* XXX : not implemented */
3407
    spr_register(env, SPR_HID0, "HID0",
3408
                 SPR_NOACCESS, SPR_NOACCESS,
3409
                 &spr_read_generic, &spr_write_generic,
3410
                 0x00000000);
3411
    /* XXX : not implemented */
3412
    spr_register(env, SPR_HID1, "HID1",
3413
                 SPR_NOACCESS, SPR_NOACCESS,
3414
                 &spr_read_generic, &spr_write_generic,
3415
                 0x00000000);
3416
    /* XXX : not implemented */
3417
    spr_register(env, SPR_IABR, "IABR",
3418
                 SPR_NOACCESS, SPR_NOACCESS,
3419
                 &spr_read_generic, &spr_write_generic,
3420
                 0x00000000);
3421
    /* Memory management */
3422
    gen_low_BATs(env);
3423
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3424
    init_excp_603(env);
3425
    env->dcache_line_size = 32;
3426
    env->icache_line_size = 32;
3427
    /* Allocate hardware IRQ controller */
3428
    ppc6xx_irq_init(env);
3429
}
3430

    
3431
/* PowerPC G2                                                                */
3432
#define POWERPC_INSNS_G2     (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3433
#define POWERPC_MSRM_G2      (0x000000000006FFF2ULL)
3434
#define POWERPC_MMU_G2       (POWERPC_MMU_SOFT_6xx)
3435
//#define POWERPC_EXCP_G2      (POWERPC_EXCP_G2)
3436
#define POWERPC_INPUT_G2     (PPC_FLAGS_INPUT_6xx)
3437
#define POWERPC_BFDM_G2      (bfd_mach_ppc_ec603e)
3438
#define POWERPC_FLAG_G2      (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3439
                              POWERPC_FLAG_BE)
3440
#define check_pow_G2         check_pow_hid0
3441

    
3442
static void init_proc_G2 (CPUPPCState *env)
3443
{
3444
    gen_spr_ne_601(env);
3445
    gen_spr_G2_755(env);
3446
    gen_spr_G2(env);
3447
    /* Time base */
3448
    gen_tbl(env);
3449
    /* Hardware implementation register */
3450
    /* XXX : not implemented */
3451
    spr_register(env, SPR_HID0, "HID0",
3452
                 SPR_NOACCESS, SPR_NOACCESS,
3453
                 &spr_read_generic, &spr_write_generic,
3454
                 0x00000000);
3455
    /* XXX : not implemented */
3456
    spr_register(env, SPR_HID1, "HID1",
3457
                 SPR_NOACCESS, SPR_NOACCESS,
3458
                 &spr_read_generic, &spr_write_generic,
3459
                 0x00000000);
3460
    /* XXX : not implemented */
3461
    spr_register(env, SPR_HID2, "HID2",
3462
                 SPR_NOACCESS, SPR_NOACCESS,
3463
                 &spr_read_generic, &spr_write_generic,
3464
                 0x00000000);
3465
    /* Memory management */
3466
    gen_low_BATs(env);
3467
    gen_high_BATs(env);
3468
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3469
    init_excp_G2(env);
3470
    env->dcache_line_size = 32;
3471
    env->icache_line_size = 32;
3472
    /* Allocate hardware IRQ controller */
3473
    ppc6xx_irq_init(env);
3474
}
3475

    
3476
/* PowerPC G2LE                                                              */
3477
#define POWERPC_INSNS_G2LE   (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3478
#define POWERPC_MSRM_G2LE    (0x000000000007FFF3ULL)
3479
#define POWERPC_MMU_G2LE     (POWERPC_MMU_SOFT_6xx)
3480
#define POWERPC_EXCP_G2LE    (POWERPC_EXCP_G2)
3481
#define POWERPC_INPUT_G2LE   (PPC_FLAGS_INPUT_6xx)
3482
#define POWERPC_BFDM_G2LE    (bfd_mach_ppc_ec603e)
3483
#define POWERPC_FLAG_G2LE    (POWERPC_FLAG_TGPR | POWERPC_FLAG_SE |           \
3484
                              POWERPC_FLAG_BE)
3485
#define check_pow_G2LE       check_pow_hid0
3486

    
3487
static void init_proc_G2LE (CPUPPCState *env)
3488
{
3489
    gen_spr_ne_601(env);
3490
    gen_spr_G2_755(env);
3491
    gen_spr_G2(env);
3492
    /* Time base */
3493
    gen_tbl(env);
3494
    /* Hardware implementation register */
3495
    /* XXX : not implemented */
3496
    spr_register(env, SPR_HID0, "HID0",
3497
                 SPR_NOACCESS, SPR_NOACCESS,
3498
                 &spr_read_generic, &spr_write_generic,
3499
                 0x00000000);
3500
    /* XXX : not implemented */
3501
    spr_register(env, SPR_HID1, "HID1",
3502
                 SPR_NOACCESS, SPR_NOACCESS,
3503
                 &spr_read_generic, &spr_write_generic,
3504
                 0x00000000);
3505
    /* XXX : not implemented */
3506
    spr_register(env, SPR_HID2, "HID2",
3507
                 SPR_NOACCESS, SPR_NOACCESS,
3508
                 &spr_read_generic, &spr_write_generic,
3509
                 0x00000000);
3510
    /* Memory management */
3511
    gen_low_BATs(env);
3512
    gen_high_BATs(env);
3513
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3514
    init_excp_G2(env);
3515
    env->dcache_line_size = 32;
3516
    env->icache_line_size = 32;
3517
    /* Allocate hardware IRQ controller */
3518
    ppc6xx_irq_init(env);
3519
}
3520

    
3521
/* PowerPC 604                                                               */
3522
#define POWERPC_INSNS_604    (POWERPC_INSNS_WORKS | PPC_EXTERN)
3523
#define POWERPC_MSRM_604     (0x000000000005FF77ULL)
3524
#define POWERPC_MMU_604      (POWERPC_MMU_32B)
3525
//#define POWERPC_EXCP_604     (POWERPC_EXCP_604)
3526
#define POWERPC_INPUT_604    (PPC_FLAGS_INPUT_6xx)
3527
#define POWERPC_BFDM_604     (bfd_mach_ppc_604)
3528
#define POWERPC_FLAG_604     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3529
                              POWERPC_FLAG_PMM)
3530
#define check_pow_604        check_pow_nocheck
3531

    
3532
static void init_proc_604 (CPUPPCState *env)
3533
{
3534
    gen_spr_ne_601(env);
3535
    gen_spr_604(env);
3536
    /* Time base */
3537
    gen_tbl(env);
3538
    /* Hardware implementation registers */
3539
    /* XXX : not implemented */
3540
    spr_register(env, SPR_HID0, "HID0",
3541
                 SPR_NOACCESS, SPR_NOACCESS,
3542
                 &spr_read_generic, &spr_write_generic,
3543
                 0x00000000);
3544
    /* XXX : not implemented */
3545
    spr_register(env, SPR_HID1, "HID1",
3546
                 SPR_NOACCESS, SPR_NOACCESS,
3547
                 &spr_read_generic, &spr_write_generic,
3548
                 0x00000000);
3549
    /* Memory management */
3550
    gen_low_BATs(env);
3551
    init_excp_604(env);
3552
    env->dcache_line_size = 32;
3553
    env->icache_line_size = 32;
3554
    /* Allocate hardware IRQ controller */
3555
    ppc6xx_irq_init(env);
3556
}
3557

    
3558
/* PowerPC 740/750 (aka G3)                                                  */
3559
#define POWERPC_INSNS_7x0    (POWERPC_INSNS_WORKS | PPC_EXTERN)
3560
#define POWERPC_MSRM_7x0     (0x000000000005FF77ULL)
3561
#define POWERPC_MMU_7x0      (POWERPC_MMU_32B)
3562
//#define POWERPC_EXCP_7x0     (POWERPC_EXCP_7x0)
3563
#define POWERPC_INPUT_7x0    (PPC_FLAGS_INPUT_6xx)
3564
#define POWERPC_BFDM_7x0     (bfd_mach_ppc_750)
3565
#define POWERPC_FLAG_7x0     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3566
                              POWERPC_FLAG_PMM)
3567
#define check_pow_7x0        check_pow_hid0
3568

    
3569
static void init_proc_7x0 (CPUPPCState *env)
3570
{
3571
    gen_spr_ne_601(env);
3572
    gen_spr_7xx(env);
3573
    /* Time base */
3574
    gen_tbl(env);
3575
    /* Thermal management */
3576
    gen_spr_thrm(env);
3577
    /* Hardware implementation registers */
3578
    /* XXX : not implemented */
3579
    spr_register(env, SPR_HID0, "HID0",
3580
                 SPR_NOACCESS, SPR_NOACCESS,
3581
                 &spr_read_generic, &spr_write_generic,
3582
                 0x00000000);
3583
    /* XXX : not implemented */
3584
    spr_register(env, SPR_HID1, "HID1",
3585
                 SPR_NOACCESS, SPR_NOACCESS,
3586
                 &spr_read_generic, &spr_write_generic,
3587
                 0x00000000);
3588
    /* Memory management */
3589
    gen_low_BATs(env);
3590
    init_excp_7x0(env);
3591
    env->dcache_line_size = 32;
3592
    env->icache_line_size = 32;
3593
    /* Allocate hardware IRQ controller */
3594
    ppc6xx_irq_init(env);
3595
}
3596

    
3597
/* PowerPC 750FX/GX                                                          */
3598
#define POWERPC_INSNS_750fx  (POWERPC_INSNS_WORKS | PPC_EXTERN)
3599
#define POWERPC_MSRM_750fx   (0x000000000005FF77ULL)
3600
#define POWERPC_MMU_750fx    (POWERPC_MMU_32B)
3601
#define POWERPC_EXCP_750fx   (POWERPC_EXCP_7x0)
3602
#define POWERPC_INPUT_750fx  (PPC_FLAGS_INPUT_6xx)
3603
#define POWERPC_BFDM_750fx   (bfd_mach_ppc_750)
3604
#define POWERPC_FLAG_750fx   (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3605
                              POWERPC_FLAG_PMM)
3606
#define check_pow_750fx      check_pow_hid0
3607

    
3608
static void init_proc_750fx (CPUPPCState *env)
3609
{
3610
    gen_spr_ne_601(env);
3611
    gen_spr_7xx(env);
3612
    /* Time base */
3613
    gen_tbl(env);
3614
    /* Thermal management */
3615
    gen_spr_thrm(env);
3616
    /* Hardware implementation registers */
3617
    /* XXX : not implemented */
3618
    spr_register(env, SPR_HID0, "HID0",
3619
                 SPR_NOACCESS, SPR_NOACCESS,
3620
                 &spr_read_generic, &spr_write_generic,
3621
                 0x00000000);
3622
    /* XXX : not implemented */
3623
    spr_register(env, SPR_HID1, "HID1",
3624
                 SPR_NOACCESS, SPR_NOACCESS,
3625
                 &spr_read_generic, &spr_write_generic,
3626
                 0x00000000);
3627
    /* XXX : not implemented */
3628
    spr_register(env, SPR_750_HID2, "HID2",
3629
                 SPR_NOACCESS, SPR_NOACCESS,
3630
                 &spr_read_generic, &spr_write_generic,
3631
                 0x00000000);
3632
    /* Memory management */
3633
    gen_low_BATs(env);
3634
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
3635
    gen_high_BATs(env);
3636
    init_excp_750FX(env);
3637
    env->dcache_line_size = 32;
3638
    env->icache_line_size = 32;
3639
    /* Allocate hardware IRQ controller */
3640
    ppc6xx_irq_init(env);
3641
}
3642

    
3643
/* PowerPC 745/755                                                           */
3644
#define POWERPC_INSNS_7x5    (POWERPC_INSNS_WORKS | PPC_EXTERN | PPC_6xx_TLB)
3645
#define POWERPC_MSRM_7x5     (0x000000000005FF77ULL)
3646
#define POWERPC_MMU_7x5      (POWERPC_MMU_SOFT_6xx)
3647
//#define POWERPC_EXCP_7x5     (POWERPC_EXCP_7x5)
3648
#define POWERPC_INPUT_7x5    (PPC_FLAGS_INPUT_6xx)
3649
#define POWERPC_BFDM_7x5     (bfd_mach_ppc_750)
3650
#define POWERPC_FLAG_7x5     (POWERPC_FLAG_SE | POWERPC_FLAG_BE |             \
3651
                              POWERPC_FLAG_PMM)
3652
#define check_pow_7x5        check_pow_hid0
3653

    
3654
static void init_proc_7x5 (CPUPPCState *env)
3655
{
3656
    gen_spr_ne_601(env);
3657
    gen_spr_G2_755(env);
3658
    /* Time base */
3659
    gen_tbl(env);
3660
    /* L2 cache control */
3661
    /* XXX : not implemented */
3662
    spr_register(env, SPR_ICTC, "ICTC",
3663
                 SPR_NOACCESS, SPR_NOACCESS,
3664
                 &spr_read_generic, &spr_write_generic,
3665
                 0x00000000);
3666
    /* XXX : not implemented */
3667
    spr_register(env, SPR_L2PMCR, "L2PMCR",
3668
                 SPR_NOACCESS, SPR_NOACCESS,
3669
                 &spr_read_generic, &spr_write_generic,
3670
                 0x00000000);
3671
    /* Hardware implementation registers */
3672
    /* XXX : not implemented */
3673
    spr_register(env, SPR_HID0, "HID0",
3674
                 SPR_NOACCESS, SPR_NOACCESS,
3675
                 &spr_read_generic, &spr_write_generic,
3676
                 0x00000000);
3677
    /* XXX : not implemented */
3678
    spr_register(env, SPR_HID1, "HID1",
3679
                 SPR_NOACCESS, SPR_NOACCESS,
3680
                 &spr_read_generic, &spr_write_generic,
3681
                 0x00000000);
3682
    /* XXX : not implemented */
3683
    spr_register(env, SPR_HID2, "HID2",
3684
                 SPR_NOACCESS, SPR_NOACCESS,
3685
                 &spr_read_generic, &spr_write_generic,
3686
                 0x00000000);
3687
    /* Memory management */
3688
    gen_low_BATs(env);
3689
    gen_high_BATs(env);
3690
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3691
    init_excp_7x5(env);
3692
    env->dcache_line_size = 32;
3693
    env->icache_line_size = 32;
3694
    /* Allocate hardware IRQ controller */
3695
    ppc6xx_irq_init(env);
3696
#if !defined(CONFIG_USER_ONLY)
3697
    /* Hardware reset vector */
3698
    env->hreset_vector = 0xFFFFFFFCUL;
3699
#endif
3700
}
3701

    
3702
/* PowerPC 7400 (aka G4)                                                     */
3703
#define POWERPC_INSNS_7400   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3704
                              PPC_EXTERN | PPC_MEM_TLBIA |                    \
3705
                              PPC_ALTIVEC)
3706
#define POWERPC_MSRM_7400    (0x000000000205FF77ULL)
3707
#define POWERPC_MMU_7400     (POWERPC_MMU_32B)
3708
#define POWERPC_EXCP_7400    (POWERPC_EXCP_74xx)
3709
#define POWERPC_INPUT_7400   (PPC_FLAGS_INPUT_6xx)
3710
#define POWERPC_BFDM_7400    (bfd_mach_ppc_7400)
3711
#define POWERPC_FLAG_7400    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3712
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3713
#define check_pow_7400       check_pow_hid0
3714

    
3715
static void init_proc_7400 (CPUPPCState *env)
3716
{
3717
    gen_spr_ne_601(env);
3718
    gen_spr_7xx(env);
3719
    /* Time base */
3720
    gen_tbl(env);
3721
    /* 74xx specific SPR */
3722
    gen_spr_74xx(env);
3723
    /* Thermal management */
3724
    gen_spr_thrm(env);
3725
    /* Memory management */
3726
    gen_low_BATs(env);
3727
    init_excp_7400(env);
3728
    env->dcache_line_size = 32;
3729
    env->icache_line_size = 32;
3730
    /* Allocate hardware IRQ controller */
3731
    ppc6xx_irq_init(env);
3732
}
3733

    
3734
/* PowerPC 7410 (aka G4)                                                     */
3735
#define POWERPC_INSNS_7410   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3736
                              PPC_EXTERN | PPC_MEM_TLBIA |                    \
3737
                              PPC_ALTIVEC)
3738
#define POWERPC_MSRM_7410    (0x000000000205FF77ULL)
3739
#define POWERPC_MMU_7410     (POWERPC_MMU_32B)
3740
#define POWERPC_EXCP_7410    (POWERPC_EXCP_74xx)
3741
#define POWERPC_INPUT_7410   (PPC_FLAGS_INPUT_6xx)
3742
#define POWERPC_BFDM_7410    (bfd_mach_ppc_7400)
3743
#define POWERPC_FLAG_7410    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3744
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3745
#define check_pow_7410       check_pow_hid0
3746

    
3747
static void init_proc_7410 (CPUPPCState *env)
3748
{
3749
    gen_spr_ne_601(env);
3750
    gen_spr_7xx(env);
3751
    /* Time base */
3752
    gen_tbl(env);
3753
    /* 74xx specific SPR */
3754
    gen_spr_74xx(env);
3755
    /* Thermal management */
3756
    gen_spr_thrm(env);
3757
    /* L2PMCR */
3758
    /* XXX : not implemented */
3759
    spr_register(env, SPR_L2PMCR, "L2PMCR",
3760
                 SPR_NOACCESS, SPR_NOACCESS,
3761
                 &spr_read_generic, &spr_write_generic,
3762
                 0x00000000);
3763
    /* LDSTDB */
3764
    /* XXX : not implemented */
3765
    spr_register(env, SPR_LDSTDB, "LDSTDB",
3766
                 SPR_NOACCESS, SPR_NOACCESS,
3767
                 &spr_read_generic, &spr_write_generic,
3768
                 0x00000000);
3769
    /* Memory management */
3770
    gen_low_BATs(env);
3771
    init_excp_7400(env);
3772
    env->dcache_line_size = 32;
3773
    env->icache_line_size = 32;
3774
    /* Allocate hardware IRQ controller */
3775
    ppc6xx_irq_init(env);
3776
}
3777

    
3778
/* PowerPC 7440 (aka G4)                                                     */
3779
#define POWERPC_INSNS_7440   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3780
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3781
                              PPC_ALTIVEC)
3782
#define POWERPC_MSRM_7440    (0x000000000205FF77ULL)
3783
#define POWERPC_MMU_7440     (POWERPC_MMU_SOFT_74xx)
3784
#define POWERPC_EXCP_7440    (POWERPC_EXCP_74xx)
3785
#define POWERPC_INPUT_7440   (PPC_FLAGS_INPUT_6xx)
3786
#define POWERPC_BFDM_7440    (bfd_mach_ppc_7400)
3787
#define POWERPC_FLAG_7440    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3788
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3789
#define check_pow_7440       check_pow_hid0
3790

    
3791
__attribute__ (( unused ))
3792
static void init_proc_7440 (CPUPPCState *env)
3793
{
3794
    gen_spr_ne_601(env);
3795
    gen_spr_7xx(env);
3796
    /* Time base */
3797
    gen_tbl(env);
3798
    /* 74xx specific SPR */
3799
    gen_spr_74xx(env);
3800
    /* LDSTCR */
3801
    /* XXX : not implemented */
3802
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3803
                 SPR_NOACCESS, SPR_NOACCESS,
3804
                 &spr_read_generic, &spr_write_generic,
3805
                 0x00000000);
3806
    /* ICTRL */
3807
    /* XXX : not implemented */
3808
    spr_register(env, SPR_ICTRL, "ICTRL",
3809
                 SPR_NOACCESS, SPR_NOACCESS,
3810
                 &spr_read_generic, &spr_write_generic,
3811
                 0x00000000);
3812
    /* MSSSR0 */
3813
    /* XXX : not implemented */
3814
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3815
                 SPR_NOACCESS, SPR_NOACCESS,
3816
                 &spr_read_generic, &spr_write_generic,
3817
                 0x00000000);
3818
    /* PMC */
3819
    /* XXX : not implemented */
3820
    spr_register(env, SPR_PMC5, "PMC5",
3821
                 SPR_NOACCESS, SPR_NOACCESS,
3822
                 &spr_read_generic, &spr_write_generic,
3823
                 0x00000000);
3824
    /* XXX : not implemented */
3825
    spr_register(env, SPR_UPMC5, "UPMC5",
3826
                 &spr_read_ureg, SPR_NOACCESS,
3827
                 &spr_read_ureg, SPR_NOACCESS,
3828
                 0x00000000);
3829
    /* XXX : not implemented */
3830
    spr_register(env, SPR_PMC6, "PMC6",
3831
                 SPR_NOACCESS, SPR_NOACCESS,
3832
                 &spr_read_generic, &spr_write_generic,
3833
                 0x00000000);
3834
    /* XXX : not implemented */
3835
    spr_register(env, SPR_UPMC6, "UPMC6",
3836
                 &spr_read_ureg, SPR_NOACCESS,
3837
                 &spr_read_ureg, SPR_NOACCESS,
3838
                 0x00000000);
3839
    /* Memory management */
3840
    gen_low_BATs(env);
3841
    gen_74xx_soft_tlb(env, 128, 2);
3842
    init_excp_7450(env);
3843
    env->dcache_line_size = 32;
3844
    env->icache_line_size = 32;
3845
    /* Allocate hardware IRQ controller */
3846
    ppc6xx_irq_init(env);
3847
}
3848

    
3849
/* PowerPC 7450 (aka G4)                                                     */
3850
#define POWERPC_INSNS_7450   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3851
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3852
                              PPC_ALTIVEC)
3853
#define POWERPC_MSRM_7450    (0x000000000205FF77ULL)
3854
#define POWERPC_MMU_7450     (POWERPC_MMU_SOFT_74xx)
3855
#define POWERPC_EXCP_7450    (POWERPC_EXCP_74xx)
3856
#define POWERPC_INPUT_7450   (PPC_FLAGS_INPUT_6xx)
3857
#define POWERPC_BFDM_7450    (bfd_mach_ppc_7400)
3858
#define POWERPC_FLAG_7450    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3859
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3860
#define check_pow_7450       check_pow_hid0
3861

    
3862
__attribute__ (( unused ))
3863
static void init_proc_7450 (CPUPPCState *env)
3864
{
3865
    gen_spr_ne_601(env);
3866
    gen_spr_7xx(env);
3867
    /* Time base */
3868
    gen_tbl(env);
3869
    /* 74xx specific SPR */
3870
    gen_spr_74xx(env);
3871
    /* Level 3 cache control */
3872
    gen_l3_ctrl(env);
3873
    /* LDSTCR */
3874
    /* XXX : not implemented */
3875
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3876
                 SPR_NOACCESS, SPR_NOACCESS,
3877
                 &spr_read_generic, &spr_write_generic,
3878
                 0x00000000);
3879
    /* ICTRL */
3880
    /* XXX : not implemented */
3881
    spr_register(env, SPR_ICTRL, "ICTRL",
3882
                 SPR_NOACCESS, SPR_NOACCESS,
3883
                 &spr_read_generic, &spr_write_generic,
3884
                 0x00000000);
3885
    /* MSSSR0 */
3886
    /* XXX : not implemented */
3887
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3888
                 SPR_NOACCESS, SPR_NOACCESS,
3889
                 &spr_read_generic, &spr_write_generic,
3890
                 0x00000000);
3891
    /* PMC */
3892
    /* XXX : not implemented */
3893
    spr_register(env, SPR_PMC5, "PMC5",
3894
                 SPR_NOACCESS, SPR_NOACCESS,
3895
                 &spr_read_generic, &spr_write_generic,
3896
                 0x00000000);
3897
    /* XXX : not implemented */
3898
    spr_register(env, SPR_UPMC5, "UPMC5",
3899
                 &spr_read_ureg, SPR_NOACCESS,
3900
                 &spr_read_ureg, SPR_NOACCESS,
3901
                 0x00000000);
3902
    /* XXX : not implemented */
3903
    spr_register(env, SPR_PMC6, "PMC6",
3904
                 SPR_NOACCESS, SPR_NOACCESS,
3905
                 &spr_read_generic, &spr_write_generic,
3906
                 0x00000000);
3907
    /* XXX : not implemented */
3908
    spr_register(env, SPR_UPMC6, "UPMC6",
3909
                 &spr_read_ureg, SPR_NOACCESS,
3910
                 &spr_read_ureg, SPR_NOACCESS,
3911
                 0x00000000);
3912
    /* Memory management */
3913
    gen_low_BATs(env);
3914
    gen_74xx_soft_tlb(env, 128, 2);
3915
    init_excp_7450(env);
3916
    env->dcache_line_size = 32;
3917
    env->icache_line_size = 32;
3918
    /* Allocate hardware IRQ controller */
3919
    ppc6xx_irq_init(env);
3920
}
3921

    
3922
/* PowerPC 7445 (aka G4)                                                     */
3923
#define POWERPC_INSNS_7445   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3924
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3925
                              PPC_ALTIVEC)
3926
#define POWERPC_MSRM_7445    (0x000000000205FF77ULL)
3927
#define POWERPC_MMU_7445     (POWERPC_MMU_SOFT_74xx)
3928
#define POWERPC_EXCP_7445    (POWERPC_EXCP_74xx)
3929
#define POWERPC_INPUT_7445   (PPC_FLAGS_INPUT_6xx)
3930
#define POWERPC_BFDM_7445    (bfd_mach_ppc_7400)
3931
#define POWERPC_FLAG_7445    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
3932
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
3933
#define check_pow_7445       check_pow_hid0
3934

    
3935
__attribute__ (( unused ))
3936
static void init_proc_7445 (CPUPPCState *env)
3937
{
3938
    gen_spr_ne_601(env);
3939
    gen_spr_7xx(env);
3940
    /* Time base */
3941
    gen_tbl(env);
3942
    /* 74xx specific SPR */
3943
    gen_spr_74xx(env);
3944
    /* LDSTCR */
3945
    /* XXX : not implemented */
3946
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3947
                 SPR_NOACCESS, SPR_NOACCESS,
3948
                 &spr_read_generic, &spr_write_generic,
3949
                 0x00000000);
3950
    /* ICTRL */
3951
    /* XXX : not implemented */
3952
    spr_register(env, SPR_ICTRL, "ICTRL",
3953
                 SPR_NOACCESS, SPR_NOACCESS,
3954
                 &spr_read_generic, &spr_write_generic,
3955
                 0x00000000);
3956
    /* MSSSR0 */
3957
    /* XXX : not implemented */
3958
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3959
                 SPR_NOACCESS, SPR_NOACCESS,
3960
                 &spr_read_generic, &spr_write_generic,
3961
                 0x00000000);
3962
    /* PMC */
3963
    /* XXX : not implemented */
3964
    spr_register(env, SPR_PMC5, "PMC5",
3965
                 SPR_NOACCESS, SPR_NOACCESS,
3966
                 &spr_read_generic, &spr_write_generic,
3967
                 0x00000000);
3968
    /* XXX : not implemented */
3969
    spr_register(env, SPR_UPMC5, "UPMC5",
3970
                 &spr_read_ureg, SPR_NOACCESS,
3971
                 &spr_read_ureg, SPR_NOACCESS,
3972
                 0x00000000);
3973
    /* XXX : not implemented */
3974
    spr_register(env, SPR_PMC6, "PMC6",
3975
                 SPR_NOACCESS, SPR_NOACCESS,
3976
                 &spr_read_generic, &spr_write_generic,
3977
                 0x00000000);
3978
    /* XXX : not implemented */
3979
    spr_register(env, SPR_UPMC6, "UPMC6",
3980
                 &spr_read_ureg, SPR_NOACCESS,
3981
                 &spr_read_ureg, SPR_NOACCESS,
3982
                 0x00000000);
3983
    /* SPRGs */
3984
    spr_register(env, SPR_SPRG4, "SPRG4",
3985
                 SPR_NOACCESS, SPR_NOACCESS,
3986
                 &spr_read_generic, &spr_write_generic,
3987
                 0x00000000);
3988
    spr_register(env, SPR_USPRG4, "USPRG4",
3989
                 &spr_read_ureg, SPR_NOACCESS,
3990
                 &spr_read_ureg, SPR_NOACCESS,
3991
                 0x00000000);
3992
    spr_register(env, SPR_SPRG5, "SPRG5",
3993
                 SPR_NOACCESS, SPR_NOACCESS,
3994
                 &spr_read_generic, &spr_write_generic,
3995
                 0x00000000);
3996
    spr_register(env, SPR_USPRG5, "USPRG5",
3997
                 &spr_read_ureg, SPR_NOACCESS,
3998
                 &spr_read_ureg, SPR_NOACCESS,
3999
                 0x00000000);
4000
    spr_register(env, SPR_SPRG6, "SPRG6",
4001
                 SPR_NOACCESS, SPR_NOACCESS,
4002
                 &spr_read_generic, &spr_write_generic,
4003
                 0x00000000);
4004
    spr_register(env, SPR_USPRG6, "USPRG6",
4005
                 &spr_read_ureg, SPR_NOACCESS,
4006
                 &spr_read_ureg, SPR_NOACCESS,
4007
                 0x00000000);
4008
    spr_register(env, SPR_SPRG7, "SPRG7",
4009
                 SPR_NOACCESS, SPR_NOACCESS,
4010
                 &spr_read_generic, &spr_write_generic,
4011
                 0x00000000);
4012
    spr_register(env, SPR_USPRG7, "USPRG7",
4013
                 &spr_read_ureg, SPR_NOACCESS,
4014
                 &spr_read_ureg, SPR_NOACCESS,
4015
                 0x00000000);
4016
    /* Memory management */
4017
    gen_low_BATs(env);
4018
    gen_high_BATs(env);
4019
    gen_74xx_soft_tlb(env, 128, 2);
4020
    init_excp_7450(env);
4021
    env->dcache_line_size = 32;
4022
    env->icache_line_size = 32;
4023
    /* Allocate hardware IRQ controller */
4024
    ppc6xx_irq_init(env);
4025
}
4026

    
4027
/* PowerPC 7455 (aka G4)                                                     */
4028
#define POWERPC_INSNS_7455   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
4029
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
4030
                              PPC_ALTIVEC)
4031
#define POWERPC_MSRM_7455    (0x000000000205FF77ULL)
4032
#define POWERPC_MMU_7455     (POWERPC_MMU_SOFT_74xx)
4033
#define POWERPC_EXCP_7455    (POWERPC_EXCP_74xx)
4034
#define POWERPC_INPUT_7455   (PPC_FLAGS_INPUT_6xx)
4035
#define POWERPC_BFDM_7455    (bfd_mach_ppc_7400)
4036
#define POWERPC_FLAG_7455    (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4037
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4038
#define check_pow_7455       check_pow_hid0
4039

    
4040
__attribute__ (( unused ))
4041
static void init_proc_7455 (CPUPPCState *env)
4042
{
4043
    gen_spr_ne_601(env);
4044
    gen_spr_7xx(env);
4045
    /* Time base */
4046
    gen_tbl(env);
4047
    /* 74xx specific SPR */
4048
    gen_spr_74xx(env);
4049
    /* Level 3 cache control */
4050
    gen_l3_ctrl(env);
4051
    /* LDSTCR */
4052
    /* XXX : not implemented */
4053
    spr_register(env, SPR_LDSTCR, "LDSTCR",
4054
                 SPR_NOACCESS, SPR_NOACCESS,
4055
                 &spr_read_generic, &spr_write_generic,
4056
                 0x00000000);
4057
    /* ICTRL */
4058
    /* XXX : not implemented */
4059
    spr_register(env, SPR_ICTRL, "ICTRL",
4060
                 SPR_NOACCESS, SPR_NOACCESS,
4061
                 &spr_read_generic, &spr_write_generic,
4062
                 0x00000000);
4063
    /* MSSSR0 */
4064
    /* XXX : not implemented */
4065
    spr_register(env, SPR_MSSSR0, "MSSSR0",
4066
                 SPR_NOACCESS, SPR_NOACCESS,
4067
                 &spr_read_generic, &spr_write_generic,
4068
                 0x00000000);
4069
    /* PMC */
4070
    /* XXX : not implemented */
4071
    spr_register(env, SPR_PMC5, "PMC5",
4072
                 SPR_NOACCESS, SPR_NOACCESS,
4073
                 &spr_read_generic, &spr_write_generic,
4074
                 0x00000000);
4075
    /* XXX : not implemented */
4076
    spr_register(env, SPR_UPMC5, "UPMC5",
4077
                 &spr_read_ureg, SPR_NOACCESS,
4078
                 &spr_read_ureg, SPR_NOACCESS,
4079
                 0x00000000);
4080
    /* XXX : not implemented */
4081
    spr_register(env, SPR_PMC6, "PMC6",
4082
                 SPR_NOACCESS, SPR_NOACCESS,
4083
                 &spr_read_generic, &spr_write_generic,
4084
                 0x00000000);
4085
    /* XXX : not implemented */
4086
    spr_register(env, SPR_UPMC6, "UPMC6",
4087
                 &spr_read_ureg, SPR_NOACCESS,
4088
                 &spr_read_ureg, SPR_NOACCESS,
4089
                 0x00000000);
4090
    /* SPRGs */
4091
    spr_register(env, SPR_SPRG4, "SPRG4",
4092
                 SPR_NOACCESS, SPR_NOACCESS,
4093
                 &spr_read_generic, &spr_write_generic,
4094
                 0x00000000);
4095
    spr_register(env, SPR_USPRG4, "USPRG4",
4096
                 &spr_read_ureg, SPR_NOACCESS,
4097
                 &spr_read_ureg, SPR_NOACCESS,
4098
                 0x00000000);
4099
    spr_register(env, SPR_SPRG5, "SPRG5",
4100
                 SPR_NOACCESS, SPR_NOACCESS,
4101
                 &spr_read_generic, &spr_write_generic,
4102
                 0x00000000);
4103
    spr_register(env, SPR_USPRG5, "USPRG5",
4104
                 &spr_read_ureg, SPR_NOACCESS,
4105
                 &spr_read_ureg, SPR_NOACCESS,
4106
                 0x00000000);
4107
    spr_register(env, SPR_SPRG6, "SPRG6",
4108
                 SPR_NOACCESS, SPR_NOACCESS,
4109
                 &spr_read_generic, &spr_write_generic,
4110
                 0x00000000);
4111
    spr_register(env, SPR_USPRG6, "USPRG6",
4112
                 &spr_read_ureg, SPR_NOACCESS,
4113
                 &spr_read_ureg, SPR_NOACCESS,
4114
                 0x00000000);
4115
    spr_register(env, SPR_SPRG7, "SPRG7",
4116
                 SPR_NOACCESS, SPR_NOACCESS,
4117
                 &spr_read_generic, &spr_write_generic,
4118
                 0x00000000);
4119
    spr_register(env, SPR_USPRG7, "USPRG7",
4120
                 &spr_read_ureg, SPR_NOACCESS,
4121
                 &spr_read_ureg, SPR_NOACCESS,
4122
                 0x00000000);
4123
    /* Memory management */
4124
    gen_low_BATs(env);
4125
    gen_high_BATs(env);
4126
    gen_74xx_soft_tlb(env, 128, 2);
4127
    init_excp_7450(env);
4128
    env->dcache_line_size = 32;
4129
    env->icache_line_size = 32;
4130
    /* Allocate hardware IRQ controller */
4131
    ppc6xx_irq_init(env);
4132
}
4133

    
4134
#if defined (TARGET_PPC64)
4135
#define POWERPC_INSNS_WORK64  (POWERPC_INSNS_6xx | PPC_FLOAT_FSQRT |          \
4136
                               PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |           \
4137
                               PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |            \
4138
                               PPC_MEM_TLBSYNC | PPC_CACHE_DCBZT | PPC_MFTB)
4139
/* PowerPC 970                                                               */
4140
#define POWERPC_INSNS_970    (POWERPC_INSNS_WORK64 | PPC_FLOAT_FSQRT |        \
4141
                              PPC_64B | PPC_ALTIVEC |                         \
4142
                              PPC_SEGMENT_64B | PPC_SLBI)
4143
#define POWERPC_MSRM_970     (0x900000000204FF36ULL)
4144
#define POWERPC_MMU_970      (POWERPC_MMU_64B)
4145
//#define POWERPC_EXCP_970     (POWERPC_EXCP_970)
4146
#define POWERPC_INPUT_970    (PPC_FLAGS_INPUT_970)
4147
#define POWERPC_BFDM_970     (bfd_mach_ppc64)
4148
#define POWERPC_FLAG_970     (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4149
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4150

    
4151
#if defined(CONFIG_USER_ONLY)
4152
#define POWERPC970_HID5_INIT 0x00000080
4153
#else
4154
#define POWERPC970_HID5_INIT 0x00000000
4155
#endif
4156

    
4157
static int check_pow_970 (CPUPPCState *env)
4158
{
4159
    if (env->spr[SPR_HID0] & 0x00600000)
4160
        return 1;
4161

    
4162
    return 0;
4163
}
4164

    
4165
static void init_proc_970 (CPUPPCState *env)
4166
{
4167
    gen_spr_ne_601(env);
4168
    gen_spr_7xx(env);
4169
    /* Time base */
4170
    gen_tbl(env);
4171
    /* Hardware implementation registers */
4172
    /* XXX : not implemented */
4173
    spr_register(env, SPR_HID0, "HID0",
4174
                 SPR_NOACCESS, SPR_NOACCESS,
4175
                 &spr_read_generic, &spr_write_clear,
4176
                 0x60000000);
4177
    /* XXX : not implemented */
4178
    spr_register(env, SPR_HID1, "HID1",
4179
                 SPR_NOACCESS, SPR_NOACCESS,
4180
                 &spr_read_generic, &spr_write_generic,
4181
                 0x00000000);
4182
    /* XXX : not implemented */
4183
    spr_register(env, SPR_750_HID2, "HID2",
4184
                 SPR_NOACCESS, SPR_NOACCESS,
4185
                 &spr_read_generic, &spr_write_generic,
4186
                 0x00000000);
4187
    /* XXX : not implemented */
4188
    spr_register(env, SPR_970_HID5, "HID5",
4189
                 SPR_NOACCESS, SPR_NOACCESS,
4190
                 &spr_read_generic, &spr_write_generic,
4191
                 POWERPC970_HID5_INIT);
4192
    /* Memory management */
4193
    /* XXX: not correct */
4194
    gen_low_BATs(env);
4195
    /* XXX : not implemented */
4196
    spr_register(env, SPR_MMUCFG, "MMUCFG",
4197
                 SPR_NOACCESS, SPR_NOACCESS,
4198
                 &spr_read_generic, SPR_NOACCESS,
4199
                 0x00000000); /* TOFIX */
4200
    /* XXX : not implemented */
4201
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4202
                 SPR_NOACCESS, SPR_NOACCESS,
4203
                 &spr_read_generic, &spr_write_generic,
4204
                 0x00000000); /* TOFIX */
4205
    spr_register(env, SPR_HIOR, "SPR_HIOR",
4206
                 SPR_NOACCESS, SPR_NOACCESS,
4207
                 &spr_read_generic, &spr_write_generic,
4208
                 0xFFF00000); /* XXX: This is a hack */
4209
#if !defined(CONFIG_USER_ONLY)
4210
    env->slb_nr = 32;
4211
#endif
4212
    init_excp_970(env);
4213
    env->dcache_line_size = 128;
4214
    env->icache_line_size = 128;
4215
    /* Allocate hardware IRQ controller */
4216
    ppc970_irq_init(env);
4217
}
4218

    
4219
/* PowerPC 970FX (aka G5)                                                    */
4220
#define POWERPC_INSNS_970FX  (POWERPC_INSNS_WORK64 | PPC_FLOAT_FSQRT |        \
4221
                              PPC_64B | PPC_ALTIVEC |                         \
4222
                              PPC_SEGMENT_64B | PPC_SLBI)
4223
#define POWERPC_MSRM_970FX   (0x800000000204FF36ULL)
4224
#define POWERPC_MMU_970FX    (POWERPC_MMU_64B)
4225
#define POWERPC_EXCP_970FX   (POWERPC_EXCP_970)
4226
#define POWERPC_INPUT_970FX  (PPC_FLAGS_INPUT_970)
4227
#define POWERPC_BFDM_970FX   (bfd_mach_ppc64)
4228
#define POWERPC_FLAG_970FX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4229
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4230

    
4231
static int check_pow_970FX (CPUPPCState *env)
4232
{
4233
    if (env->spr[SPR_HID0] & 0x00600000)
4234
        return 1;
4235

    
4236
    return 0;
4237
}
4238

    
4239
static void init_proc_970FX (CPUPPCState *env)
4240
{
4241
    gen_spr_ne_601(env);
4242
    gen_spr_7xx(env);
4243
    /* Time base */
4244
    gen_tbl(env);
4245
    /* Hardware implementation registers */
4246
    /* XXX : not implemented */
4247
    spr_register(env, SPR_HID0, "HID0",
4248
                 SPR_NOACCESS, SPR_NOACCESS,
4249
                 &spr_read_generic, &spr_write_clear,
4250
                 0x60000000);
4251
    /* XXX : not implemented */
4252
    spr_register(env, SPR_HID1, "HID1",
4253
                 SPR_NOACCESS, SPR_NOACCESS,
4254
                 &spr_read_generic, &spr_write_generic,
4255
                 0x00000000);
4256
    /* XXX : not implemented */
4257
    spr_register(env, SPR_750_HID2, "HID2",
4258
                 SPR_NOACCESS, SPR_NOACCESS,
4259
                 &spr_read_generic, &spr_write_generic,
4260
                 0x00000000);
4261
    /* XXX : not implemented */
4262
    spr_register(env, SPR_970_HID5, "HID5",
4263
                 SPR_NOACCESS, SPR_NOACCESS,
4264
                 &spr_read_generic, &spr_write_generic,
4265
                 POWERPC970_HID5_INIT);
4266
    /* Memory management */
4267
    /* XXX: not correct */
4268
    gen_low_BATs(env);
4269
    /* XXX : not implemented */
4270
    spr_register(env, SPR_MMUCFG, "MMUCFG",
4271
                 SPR_NOACCESS, SPR_NOACCESS,
4272
                 &spr_read_generic, SPR_NOACCESS,
4273
                 0x00000000); /* TOFIX */
4274
    /* XXX : not implemented */
4275
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4276
                 SPR_NOACCESS, SPR_NOACCESS,
4277
                 &spr_read_generic, &spr_write_generic,
4278
                 0x00000000); /* TOFIX */
4279
    spr_register(env, SPR_HIOR, "SPR_HIOR",
4280
                 SPR_NOACCESS, SPR_NOACCESS,
4281
                 &spr_read_generic, &spr_write_generic,
4282
                 0xFFF00000); /* XXX: This is a hack */
4283
#if !defined(CONFIG_USER_ONLY)
4284
    env->slb_nr = 32;
4285
#endif
4286
    init_excp_970(env);
4287
    env->dcache_line_size = 128;
4288
    env->icache_line_size = 128;
4289
    /* Allocate hardware IRQ controller */
4290
    ppc970_irq_init(env);
4291
}
4292

    
4293
/* PowerPC 970 GX                                                            */
4294
#define POWERPC_INSNS_970GX  (POWERPC_INSNS_WORK64 | PPC_FLOAT_FSQRT |        \
4295
                              PPC_64B | PPC_ALTIVEC |                         \
4296
                              PPC_SEGMENT_64B | PPC_SLBI)
4297
#define POWERPC_MSRM_970GX   (0x800000000204FF36ULL)
4298
#define POWERPC_MMU_970GX    (POWERPC_MMU_64B)
4299
#define POWERPC_EXCP_970GX   (POWERPC_EXCP_970)
4300
#define POWERPC_INPUT_970GX  (PPC_FLAGS_INPUT_970)
4301
#define POWERPC_BFDM_970GX   (bfd_mach_ppc64)
4302
#define POWERPC_FLAG_970GX   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4303
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4304

    
4305
static int check_pow_970GX (CPUPPCState *env)
4306
{
4307
    if (env->spr[SPR_HID0] & 0x00600000)
4308
        return 1;
4309

    
4310
    return 0;
4311
}
4312

    
4313
static void init_proc_970GX (CPUPPCState *env)
4314
{
4315
    gen_spr_ne_601(env);
4316
    gen_spr_7xx(env);
4317
    /* Time base */
4318
    gen_tbl(env);
4319
    /* Hardware implementation registers */
4320
    /* XXX : not implemented */
4321
    spr_register(env, SPR_HID0, "HID0",
4322
                 SPR_NOACCESS, SPR_NOACCESS,
4323
                 &spr_read_generic, &spr_write_clear,
4324
                 0x60000000);
4325
    /* XXX : not implemented */
4326
    spr_register(env, SPR_HID1, "HID1",
4327
                 SPR_NOACCESS, SPR_NOACCESS,
4328
                 &spr_read_generic, &spr_write_generic,
4329
                 0x00000000);
4330
    /* XXX : not implemented */
4331
    spr_register(env, SPR_750_HID2, "HID2",
4332
                 SPR_NOACCESS, SPR_NOACCESS,
4333
                 &spr_read_generic, &spr_write_generic,
4334
                 0x00000000);
4335
    /* XXX : not implemented */
4336
    spr_register(env, SPR_970_HID5, "HID5",
4337
                 SPR_NOACCESS, SPR_NOACCESS,
4338
                 &spr_read_generic, &spr_write_generic,
4339
                 POWERPC970_HID5_INIT);
4340
    /* Memory management */
4341
    /* XXX: not correct */
4342
    gen_low_BATs(env);
4343
    /* XXX : not implemented */
4344
    spr_register(env, SPR_MMUCFG, "MMUCFG",
4345
                 SPR_NOACCESS, SPR_NOACCESS,
4346
                 &spr_read_generic, SPR_NOACCESS,
4347
                 0x00000000); /* TOFIX */
4348
    /* XXX : not implemented */
4349
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4350
                 SPR_NOACCESS, SPR_NOACCESS,
4351
                 &spr_read_generic, &spr_write_generic,
4352
                 0x00000000); /* TOFIX */
4353
    spr_register(env, SPR_HIOR, "SPR_HIOR",
4354
                 SPR_NOACCESS, SPR_NOACCESS,
4355
                 &spr_read_generic, &spr_write_generic,
4356
                 0xFFF00000); /* XXX: This is a hack */
4357
#if !defined(CONFIG_USER_ONLY)
4358
    env->slb_nr = 32;
4359
#endif
4360
    init_excp_970(env);
4361
    env->dcache_line_size = 128;
4362
    env->icache_line_size = 128;
4363
    /* Allocate hardware IRQ controller */
4364
    ppc970_irq_init(env);
4365
}
4366

    
4367
/* PowerPC 970 MP                                                            */
4368
#define POWERPC_INSNS_970MP  (POWERPC_INSNS_WORK64 | PPC_FLOAT_FSQRT |        \
4369
                              PPC_64B | PPC_ALTIVEC |                         \
4370
                              PPC_SEGMENT_64B | PPC_SLBI)
4371
#define POWERPC_MSRM_970MP   (0x900000000204FF36ULL)
4372
#define POWERPC_MMU_970MP    (POWERPC_MMU_64B)
4373
#define POWERPC_EXCP_970MP   (POWERPC_EXCP_970)
4374
#define POWERPC_INPUT_970MP  (PPC_FLAGS_INPUT_970)
4375
#define POWERPC_BFDM_970MP   (bfd_mach_ppc64)
4376
#define POWERPC_FLAG_970MP   (POWERPC_FLAG_VRE | POWERPC_FLAG_SE |            \
4377
                              POWERPC_FLAG_BE | POWERPC_FLAG_PMM)
4378

    
4379
static int check_pow_970MP (CPUPPCState *env)
4380
{
4381
    if (env->spr[SPR_HID0] & 0x01C00000)
4382
        return 1;
4383

    
4384
    return 0;
4385
}
4386

    
4387
static void init_proc_970MP (CPUPPCState *env)
4388
{
4389
    gen_spr_ne_601(env);
4390
    gen_spr_7xx(env);
4391
    /* Time base */
4392
    gen_tbl(env);
4393
    /* Hardware implementation registers */
4394
    /* XXX : not implemented */
4395
    spr_register(env, SPR_HID0, "HID0",
4396
                 SPR_NOACCESS, SPR_NOACCESS,
4397
                 &spr_read_generic, &spr_write_clear,
4398
                 0x60000000);
4399
    /* XXX : not implemented */
4400
    spr_register(env, SPR_HID1, "HID1",
4401
                 SPR_NOACCESS, SPR_NOACCESS,
4402
                 &spr_read_generic, &spr_write_generic,
4403
                 0x00000000);
4404
    /* XXX : not implemented */
4405
    spr_register(env, SPR_750_HID2, "HID2",
4406
                 SPR_NOACCESS, SPR_NOACCESS,
4407
                 &spr_read_generic, &spr_write_generic,
4408
                 0x00000000);
4409
    /* XXX : not implemented */
4410
    spr_register(env, SPR_970_HID5, "HID5",
4411
                 SPR_NOACCESS, SPR_NOACCESS,
4412
                 &spr_read_generic, &spr_write_generic,
4413
                 POWERPC970_HID5_INIT);
4414
    /* Memory management */
4415
    /* XXX: not correct */
4416
    gen_low_BATs(env);
4417
    /* XXX : not implemented */
4418
    spr_register(env, SPR_MMUCFG, "MMUCFG",
4419
                 SPR_NOACCESS, SPR_NOACCESS,
4420
                 &spr_read_generic, SPR_NOACCESS,
4421
                 0x00000000); /* TOFIX */
4422
    /* XXX : not implemented */
4423
    spr_register(env, SPR_MMUCSR0, "MMUCSR0",
4424
                 SPR_NOACCESS, SPR_NOACCESS,
4425
                 &spr_read_generic, &spr_write_generic,
4426
                 0x00000000); /* TOFIX */
4427
    spr_register(env, SPR_HIOR, "SPR_HIOR",
4428
                 SPR_NOACCESS, SPR_NOACCESS,
4429
                 &spr_read_generic, &spr_write_generic,
4430
                 0xFFF00000); /* XXX: This is a hack */
4431
#if !defined(CONFIG_USER_ONLY)
4432
    env->slb_nr = 32;
4433
#endif
4434
    init_excp_970(env);
4435
    env->dcache_line_size = 128;
4436
    env->icache_line_size = 128;
4437
    /* Allocate hardware IRQ controller */
4438
    ppc970_irq_init(env);
4439
}
4440

    
4441
/* PowerPC 620                                                               */
4442
#define POWERPC_INSNS_620    (POWERPC_INSNS_WORKS | PPC_FLOAT_FSQRT |         \
4443
                              PPC_64B | PPC_SLBI)
4444
#define POWERPC_MSRM_620     (0x800000000005FF73ULL)
4445
#define POWERPC_MMU_620      (POWERPC_MMU_64B)
4446
#define POWERPC_EXCP_620     (POWERPC_EXCP_970)
4447
#define POWERPC_INPUT_620    (PPC_FLAGS_INPUT_6xx)
4448
#define POWERPC_BFDM_620     (bfd_mach_ppc64)
4449
#define POWERPC_FLAG_620     (POWERPC_FLAG_SE | POWERPC_FLAG_BE)
4450
#define check_pow_620        check_pow_nocheck /* Check this */
4451

    
4452
__attribute__ (( unused ))
4453
static void init_proc_620 (CPUPPCState *env)
4454
{
4455
    gen_spr_ne_601(env);
4456
    gen_spr_620(env);
4457
    /* Time base */
4458
    gen_tbl(env);
4459
    /* Hardware implementation registers */
4460
    /* XXX : not implemented */
4461
    spr_register(env, SPR_HID0, "HID0",
4462
                 SPR_NOACCESS, SPR_NOACCESS,
4463
                 &spr_read_generic, &spr_write_generic,
4464
                 0x00000000);
4465
    /* Memory management */
4466
    gen_low_BATs(env);
4467
    gen_high_BATs(env);
4468
    init_excp_620(env);
4469
    env->dcache_line_size = 64;
4470
    env->icache_line_size = 64;
4471
    /* Allocate hardware IRQ controller */
4472
    ppc6xx_irq_init(env);
4473
}
4474
#endif /* defined (TARGET_PPC64) */
4475

    
4476
/* Default 32 bits PowerPC target will be 604 */
4477
#define CPU_POWERPC_PPC32     CPU_POWERPC_604
4478
#define POWERPC_INSNS_PPC32   POWERPC_INSNS_604
4479
#define POWERPC_MSRM_PPC32    POWERPC_MSRM_604
4480
#define POWERPC_MMU_PPC32     POWERPC_MMU_604
4481
#define POWERPC_EXCP_PPC32    POWERPC_EXCP_604
4482
#define POWERPC_INPUT_PPC32   POWERPC_INPUT_604
4483
#define POWERPC_BFDM_PPC32    POWERPC_BFDM_604
4484
#define POWERPC_FLAG_PPC32    POWERPC_FLAG_604
4485
#define check_pow_PPC32       check_pow_604
4486
#define init_proc_PPC32       init_proc_604
4487

    
4488
/* Default 64 bits PowerPC target will be 970 FX */
4489
#define CPU_POWERPC_PPC64     CPU_POWERPC_970FX
4490
#define POWERPC_INSNS_PPC64   POWERPC_INSNS_970FX
4491
#define POWERPC_MSRM_PPC64    POWERPC_MSRM_970FX
4492
#define POWERPC_MMU_PPC64     POWERPC_MMU_970FX
4493
#define POWERPC_EXCP_PPC64    POWERPC_EXCP_970FX
4494
#define POWERPC_INPUT_PPC64   POWERPC_INPUT_970FX
4495
#define POWERPC_BFDM_PPC64    POWERPC_BFDM_970FX
4496
#define POWERPC_FLAG_PPC64    POWERPC_FLAG_970FX
4497
#define check_pow_PPC64       check_pow_970FX
4498
#define init_proc_PPC64       init_proc_970FX
4499

    
4500
/* Default PowerPC target will be PowerPC 32 */
4501
#if defined (TARGET_PPC64) && 0 // XXX: TODO
4502
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC64
4503
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC64
4504
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC64
4505
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC64
4506
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC64
4507
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC64
4508
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC64
4509
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC64
4510
#define check_pow_DEFAULT     check_pow_PPC64
4511
#define init_proc_DEFAULT     init_proc_PPC64
4512
#else
4513
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC32
4514
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC32
4515
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC32
4516
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC32
4517
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC32
4518
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC32
4519
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC32
4520
#define POWERPC_FLAG_DEFAULT  POWERPC_FLAG_PPC32
4521
#define check_pow_DEFAULT     check_pow_PPC32
4522
#define init_proc_DEFAULT     init_proc_PPC32
4523
#endif
4524

    
4525
/*****************************************************************************/
4526
/* PVR definitions for most known PowerPC                                    */
4527
enum {
4528
    /* PowerPC 401 family */
4529
    /* Generic PowerPC 401 */
4530
#define CPU_POWERPC_401       CPU_POWERPC_401G2
4531
    /* PowerPC 401 cores */
4532
    CPU_POWERPC_401A1       = 0x00210000,
4533
    CPU_POWERPC_401B2       = 0x00220000,
4534
#if 0
4535
    CPU_POWERPC_401B3       = xxx,
4536
#endif
4537
    CPU_POWERPC_401C2       = 0x00230000,
4538
    CPU_POWERPC_401D2       = 0x00240000,
4539
    CPU_POWERPC_401E2       = 0x00250000,
4540
    CPU_POWERPC_401F2       = 0x00260000,
4541
    CPU_POWERPC_401G2       = 0x00270000,
4542
    /* PowerPC 401 microcontrolers */
4543
#if 0
4544
    CPU_POWERPC_401GF       = xxx,
4545
#endif
4546
#define CPU_POWERPC_IOP480    CPU_POWERPC_401B2
4547
    /* IBM Processor for Network Resources */
4548
    CPU_POWERPC_COBRA       = 0x10100000, /* XXX: 405 ? */
4549
#if 0
4550
    CPU_POWERPC_XIPCHIP     = xxx,
4551
#endif
4552
    /* PowerPC 403 family */
4553
    /* Generic PowerPC 403 */
4554
#define CPU_POWERPC_403       CPU_POWERPC_403GC
4555
    /* PowerPC 403 microcontrollers */
4556
    CPU_POWERPC_403GA       = 0x00200011,
4557
    CPU_POWERPC_403GB       = 0x00200100,
4558
    CPU_POWERPC_403GC       = 0x00200200,
4559
    CPU_POWERPC_403GCX      = 0x00201400,
4560
#if 0
4561
    CPU_POWERPC_403GP       = xxx,
4562
#endif
4563
    /* PowerPC 405 family */
4564
    /* Generic PowerPC 405 */
4565
#define CPU_POWERPC_405       CPU_POWERPC_405D4
4566
    /* PowerPC 405 cores */
4567
#if 0
4568
    CPU_POWERPC_405A3       = xxx,
4569
#endif
4570
#if 0
4571
    CPU_POWERPC_405A4       = xxx,
4572
#endif
4573
#if 0
4574
    CPU_POWERPC_405B3       = xxx,
4575
#endif
4576
#if 0
4577
    CPU_POWERPC_405B4       = xxx,
4578
#endif
4579
#if 0
4580
    CPU_POWERPC_405C3       = xxx,
4581
#endif
4582
#if 0
4583
    CPU_POWERPC_405C4       = xxx,
4584
#endif
4585
    CPU_POWERPC_405D2       = 0x20010000,
4586
#if 0
4587
    CPU_POWERPC_405D3       = xxx,
4588
#endif
4589
    CPU_POWERPC_405D4       = 0x41810000,
4590
#if 0
4591
    CPU_POWERPC_405D5       = xxx,
4592
#endif
4593
#if 0
4594
    CPU_POWERPC_405E4       = xxx,
4595
#endif
4596
#if 0
4597
    CPU_POWERPC_405F4       = xxx,
4598
#endif
4599
#if 0
4600
    CPU_POWERPC_405F5       = xxx,
4601
#endif
4602
#if 0
4603
    CPU_POWERPC_405F6       = xxx,
4604
#endif
4605
    /* PowerPC 405 microcontrolers */
4606
    /* XXX: missing 0x200108a0 */
4607
#define CPU_POWERPC_405CR     CPU_POWERPC_405CRc
4608
    CPU_POWERPC_405CRa      = 0x40110041,
4609
    CPU_POWERPC_405CRb      = 0x401100C5,
4610
    CPU_POWERPC_405CRc      = 0x40110145,
4611
    CPU_POWERPC_405EP       = 0x51210950,
4612
#if 0
4613
    CPU_POWERPC_405EXr      = xxx,
4614
#endif
4615
    CPU_POWERPC_405EZ       = 0x41511460, /* 0x51210950 ? */
4616
#if 0
4617
    CPU_POWERPC_405FX       = xxx,
4618
#endif
4619
#define CPU_POWERPC_405GP     CPU_POWERPC_405GPd
4620
    CPU_POWERPC_405GPa      = 0x40110000,
4621
    CPU_POWERPC_405GPb      = 0x40110040,
4622
    CPU_POWERPC_405GPc      = 0x40110082,
4623
    CPU_POWERPC_405GPd      = 0x401100C4,
4624
#define CPU_POWERPC_405GPe    CPU_POWERPC_405CRc
4625
    CPU_POWERPC_405GPR      = 0x50910951,
4626
#if 0
4627
    CPU_POWERPC_405H        = xxx,
4628
#endif
4629
#if 0
4630
    CPU_POWERPC_405L        = xxx,
4631
#endif
4632
    CPU_POWERPC_405LP       = 0x41F10000,
4633
#if 0
4634
    CPU_POWERPC_405PM       = xxx,
4635
#endif
4636
#if 0
4637
    CPU_POWERPC_405PS       = xxx,
4638
#endif
4639
#if 0
4640
    CPU_POWERPC_405S        = xxx,
4641
#endif
4642
    /* IBM network processors */
4643
    CPU_POWERPC_NPE405H     = 0x414100C0,
4644
    CPU_POWERPC_NPE405H2    = 0x41410140,
4645
    CPU_POWERPC_NPE405L     = 0x416100C0,
4646
    CPU_POWERPC_NPE4GS3     = 0x40B10000,
4647
#if 0
4648
    CPU_POWERPC_NPCxx1      = xxx,
4649
#endif
4650
#if 0
4651
    CPU_POWERPC_NPR161      = xxx,
4652
#endif
4653
#if 0
4654
    CPU_POWERPC_LC77700     = xxx,
4655
#endif
4656
    /* IBM STBxxx (PowerPC 401/403/405 core based microcontrollers) */
4657
#if 0
4658
    CPU_POWERPC_STB01000    = xxx,
4659
#endif
4660
#if 0
4661
    CPU_POWERPC_STB01010    = xxx,
4662
#endif
4663
#if 0
4664
    CPU_POWERPC_STB0210     = xxx, /* 401B3 */
4665
#endif
4666
    CPU_POWERPC_STB03       = 0x40310000, /* 0x40130000 ? */
4667
#if 0
4668
    CPU_POWERPC_STB043      = xxx,
4669
#endif
4670
#if 0
4671
    CPU_POWERPC_STB045      = xxx,
4672
#endif
4673
    CPU_POWERPC_STB04       = 0x41810000,
4674
    CPU_POWERPC_STB25       = 0x51510950,
4675
#if 0
4676
    CPU_POWERPC_STB130      = xxx,
4677
#endif
4678
    /* Xilinx cores */
4679
    CPU_POWERPC_X2VP4       = 0x20010820,
4680
#define CPU_POWERPC_X2VP7     CPU_POWERPC_X2VP4
4681
    CPU_POWERPC_X2VP20      = 0x20010860,
4682
#define CPU_POWERPC_X2VP50    CPU_POWERPC_X2VP20
4683
#if 0
4684
    CPU_POWERPC_ZL10310     = xxx,
4685
#endif
4686
#if 0
4687
    CPU_POWERPC_ZL10311     = xxx,
4688
#endif
4689
#if 0
4690
    CPU_POWERPC_ZL10320     = xxx,
4691
#endif
4692
#if 0
4693
    CPU_POWERPC_ZL10321     = xxx,
4694
#endif
4695
    /* PowerPC 440 family */
4696
    /* Generic PowerPC 440 */
4697
#define CPU_POWERPC_440       CPU_POWERPC_440GXf
4698
    /* PowerPC 440 cores */
4699
#if 0
4700
    CPU_POWERPC_440A4       = xxx,
4701
#endif
4702
#if 0
4703
    CPU_POWERPC_440A5       = xxx,
4704
#endif
4705
#if 0
4706
    CPU_POWERPC_440B4       = xxx,
4707
#endif
4708
#if 0
4709
    CPU_POWERPC_440F5       = xxx,
4710
#endif
4711
#if 0
4712
    CPU_POWERPC_440G5       = xxx,
4713
#endif
4714
#if 0
4715
    CPU_POWERPC_440H4       = xxx,
4716
#endif
4717
#if 0
4718
    CPU_POWERPC_440H6       = xxx,
4719
#endif
4720
    /* PowerPC 440 microcontrolers */
4721
#define CPU_POWERPC_440EP     CPU_POWERPC_440EPb
4722
    CPU_POWERPC_440EPa      = 0x42221850,
4723
    CPU_POWERPC_440EPb      = 0x422218D3,
4724
#define CPU_POWERPC_440GP     CPU_POWERPC_440GPc
4725
    CPU_POWERPC_440GPb      = 0x40120440,
4726
    CPU_POWERPC_440GPc      = 0x40120481,
4727
#define CPU_POWERPC_440GR     CPU_POWERPC_440GRa
4728
#define CPU_POWERPC_440GRa    CPU_POWERPC_440EPb
4729
    CPU_POWERPC_440GRX      = 0x200008D0,
4730
#define CPU_POWERPC_440EPX    CPU_POWERPC_440GRX
4731
#define CPU_POWERPC_440GX     CPU_POWERPC_440GXf
4732
    CPU_POWERPC_440GXa      = 0x51B21850,
4733
    CPU_POWERPC_440GXb      = 0x51B21851,
4734
    CPU_POWERPC_440GXc      = 0x51B21892,
4735
    CPU_POWERPC_440GXf      = 0x51B21894,
4736
#if 0
4737
    CPU_POWERPC_440S        = xxx,
4738
#endif
4739
    CPU_POWERPC_440SP       = 0x53221850,
4740
    CPU_POWERPC_440SP2      = 0x53221891,
4741
    CPU_POWERPC_440SPE      = 0x53421890,
4742
    /* PowerPC 460 family */
4743
#if 0
4744
    /* Generic PowerPC 464 */
4745
#define CPU_POWERPC_464       CPU_POWERPC_464H90
4746
#endif
4747
    /* PowerPC 464 microcontrolers */
4748
#if 0
4749
    CPU_POWERPC_464H90      = xxx,
4750
#endif
4751
#if 0
4752
    CPU_POWERPC_464H90FP    = xxx,
4753
#endif
4754
    /* Freescale embedded PowerPC cores */
4755
    /* PowerPC MPC 5xx cores (aka RCPU) */
4756
    CPU_POWERPC_5xx         = 0x00020020,
4757
#define CPU_POWERPC_509       CPU_POWERPC_5xx
4758
#define CPU_POWERPC_533       CPU_POWERPC_5xx
4759
#define CPU_POWERPC_534       CPU_POWERPC_5xx
4760
#define CPU_POWERPC_555       CPU_POWERPC_5xx
4761
#define CPU_POWERPC_556       CPU_POWERPC_5xx
4762
#define CPU_POWERPC_560       CPU_POWERPC_5xx
4763
#define CPU_POWERPC_561       CPU_POWERPC_5xx
4764
#define CPU_POWERPC_562       CPU_POWERPC_5xx
4765
#define CPU_POWERPC_563       CPU_POWERPC_5xx
4766
#define CPU_POWERPC_564       CPU_POWERPC_5xx
4767
#define CPU_POWERPC_565       CPU_POWERPC_5xx
4768
#define CPU_POWERPC_566       CPU_POWERPC_5xx
4769
    /* PowerPC MPC 8xx cores (aka PowerQUICC) */
4770
    CPU_POWERPC_8xx         = 0x00500000,
4771
#define CPU_POWERPC_821       CPU_POWERPC_8xx
4772
#define CPU_POWERPC_823       CPU_POWERPC_8xx
4773
#define CPU_POWERPC_850       CPU_POWERPC_8xx
4774
#define CPU_POWERPC_852T      CPU_POWERPC_8xx
4775
#define CPU_POWERPC_855T      CPU_POWERPC_8xx
4776
#define CPU_POWERPC_859       CPU_POWERPC_8xx
4777
#define CPU_POWERPC_860       CPU_POWERPC_8xx
4778
#define CPU_POWERPC_862       CPU_POWERPC_8xx
4779
#define CPU_POWERPC_866       CPU_POWERPC_8xx
4780
#define CPU_POWERPC_857       CPU_POWERPC_8xx
4781
#define CPU_POWERPC_870       CPU_POWERPC_8xx
4782
#define CPU_POWERPC_875       CPU_POWERPC_8xx
4783
#define CPU_POWERPC_880       CPU_POWERPC_8xx
4784
#define CPU_POWERPC_885       CPU_POWERPC_8xx
4785
    /* G2 cores (aka PowerQUICC-II) */
4786
    CPU_POWERPC_G2          = 0x00810011,
4787
    CPU_POWERPC_G2H4        = 0x80811010,
4788
    CPU_POWERPC_G2gp        = 0x80821010,
4789
    CPU_POWERPC_G2ls        = 0x90810010,
4790
    CPU_POWERPC_MPC603      = 0x00810100,
4791
#define CPU_POWERPC_MPC8240   CPU_POWERPC_MPC603
4792
    CPU_POWERPC_G2_HIP3     = 0x00810101,
4793
#define CPU_POWERPC_MPC8250_HiP3 CPU_POWERPC_G2_HIP3
4794
#define CPU_POWERPC_MPC8255_HiP3 CPU_POWERPC_G2_HIP3
4795
#define CPU_POWERPC_MPC8260_HiP3 CPU_POWERPC_G2_HIP3
4796
#define CPU_POWERPC_MPC8264_HiP3 CPU_POWERPC_G2_HIP3
4797
#define CPU_POWERPC_MPC8265_HiP3 CPU_POWERPC_G2_HIP3
4798
#define CPU_POWERPC_MPC8266_HiP3 CPU_POWERPC_G2_HIP3
4799
    CPU_POWERPC_G2_HIP4     = 0x80811014,
4800
#define CPU_POWERPC_MPC8241   CPU_POWERPC_G2_HIP4
4801
#define CPU_POWERPC_MPC8245   CPU_POWERPC_G2_HIP4
4802
#define CPU_POWERPC_MPC8250_HiP4 CPU_POWERPC_G2_HIP4
4803
#define CPU_POWERPC_MPC8255_HiP4 CPU_POWERPC_G2_HIP4
4804
#define CPU_POWERPC_MPC8260_HiP4 CPU_POWERPC_G2_HIP4
4805
#define CPU_POWERPC_MPC8264_HiP4 CPU_POWERPC_G2_HIP4
4806
#define CPU_POWERPC_MPC8265_HiP4 CPU_POWERPC_G2_HIP4
4807
#define CPU_POWERPC_MPC8266_HiP4 CPU_POWERPC_G2_HIP4
4808
    /*   G2_LE core (aka PowerQUICC-II) */
4809
    CPU_POWERPC_G2LE        = 0x80820010,
4810
    CPU_POWERPC_G2LEgp      = 0x80822010,
4811
    CPU_POWERPC_G2LEls      = 0xA0822010,
4812
    CPU_POWERPC_G2LEgp1     = 0x80822011,
4813
    /* XXX: MPC 5121 ? */
4814
#define CPU_POWERPC_MPC5200   CPU_POWERPC_G2LEgp1
4815
    CPU_POWERPC_G2LEgp3     = 0x80822013,
4816
#define CPU_POWERPC_MPC8247   CPU_POWERPC_G2LEgp3
4817
#define CPU_POWERPC_MPC8248   CPU_POWERPC_G2LEgp3
4818
#define CPU_POWERPC_MPC8270   CPU_POWERPC_G2LEgp3
4819
#define CPU_POWERPC_MPC8271   CPU_POWERPC_G2LEgp3
4820
#define CPU_POWERPC_MPC8272   CPU_POWERPC_G2LEgp3
4821
#define CPU_POWERPC_MPC8275   CPU_POWERPC_G2LEgp3
4822
#define CPU_POWERPC_MPC8280   CPU_POWERPC_G2LEgp3
4823
    /* e200 family */
4824
#define CPU_POWERPC_e200      CPU_POWERPC_e200z6
4825
#if 0
4826
    CPU_POWERPC_e200z0      = xxx,
4827
#define CPU_POWERPC_MPC5514E_v0  CPU_POWERPC_e200z0
4828
#define CPU_POWERPC_MPC5514G_v0  CPU_POWERPC_e200z0
4829
#define CPU_POWERPC_MPC5516E_v0  CPU_POWERPC_e200z0
4830
#define CPU_POWERPC_MPC5516G_v0  CPU_POWERPC_e200z0
4831
#endif
4832
#if 0
4833
    CPU_POWERPC_e200z1      = xxx,
4834
#define CPU_POWERPC_MPC5514E_v1  CPU_POWERPC_e200z1
4835
#define CPU_POWERPC_MPC5514G_v1  CPU_POWERPC_e200z1
4836
#define CPU_POWERPC_MPC5515S  CPU_POWERPC_e200z1
4837
#define CPU_POWERPC_MPC5516E_v1  CPU_POWERPC_e200z1
4838
#define CPU_POWERPC_MPC5516G_v1  CPU_POWERPC_e200z1
4839
#define CPU_POWERPC_MPC5516S  CPU_POWERPC_e200z1
4840
#endif
4841
#if 0 /* ? */
4842
    CPU_POWERPC_e200z3      = 0x81120000,
4843
#define CPU_POWERPC_MPC5533   CPU_POWERPC_e200z3
4844
#define CPU_POWERPC_MPC5534   CPU_POWERPC_e200z3
4845
#endif
4846
    CPU_POWERPC_e200z5      = 0x81000000,
4847
    CPU_POWERPC_e200z6      = 0x81120000,
4848
#define CPU_POWERPC_MPC5553   CPU_POWERPC_e200z6
4849
#define CPU_POWERPC_MPC5554   CPU_POWERPC_e200z6
4850
#define CPU_POWERPC_MPC5561   CPU_POWERPC_e200z6
4851
#define CPU_POWERPC_MPC5565   CPU_POWERPC_e200z6
4852
#define CPU_POWERPC_MPC5566   CPU_POWERPC_e200z6
4853
#define CPU_POWERPC_MPC5567   CPU_POWERPC_e200z6
4854
    /* e300 family */
4855
#define CPU_POWERPC_e300      CPU_POWERPC_e300c3
4856
    CPU_POWERPC_e300c1      = 0x00830000,
4857
#define CPU_POWERPC_MPC8343A  CPU_POWERPC_e300c1
4858
#define CPU_POWERPC_MPC8343EA CPU_POWERPC_e300c1
4859
#define CPU_POWERPC_MPC8347A  CPU_POWERPC_e300c1
4860
#define CPU_POWERPC_MPC8347EA CPU_POWERPC_e300c1
4861
#define CPU_POWERPC_MPC8349   CPU_POWERPC_e300c1
4862
#define CPU_POWERPC_MPC8349E  CPU_POWERPC_e300c1
4863
#define CPU_POWERPC_MPC8358E  CPU_POWERPC_e300c1
4864
#define CPU_POWERPC_MPC8360E  CPU_POWERPC_e300c1
4865
    CPU_POWERPC_e300c2      = 0x00840000,
4866
#define CPU_POWERPC_MPC8321   CPU_POWERPC_e300c2
4867
#define CPU_POWERPC_MPC8321E  CPU_POWERPC_e300c2
4868
#define CPU_POWERPC_MPC8323   CPU_POWERPC_e300c2
4869
#define CPU_POWERPC_MPC8323E  CPU_POWERPC_e300c2
4870
    CPU_POWERPC_e300c3      = 0x00850000,
4871
#define CPU_POWERPC_MPC8313   CPU_POWERPC_e300c3
4872
#define CPU_POWERPC_MPC8313E  CPU_POWERPC_e300c3
4873
#define CPU_POWERPC_MPC8314   CPU_POWERPC_e300c3
4874
#define CPU_POWERPC_MPC8314E  CPU_POWERPC_e300c3
4875
#define CPU_POWERPC_MPC8315   CPU_POWERPC_e300c3
4876
#define CPU_POWERPC_MPC8315E  CPU_POWERPC_e300c3
4877
    CPU_POWERPC_e300c4      = 0x00860000,
4878
#define CPU_POWERPC_MPC8377   CPU_POWERPC_e300c4
4879
#define CPU_POWERPC_MPC8377E  CPU_POWERPC_e300c4
4880
#define CPU_POWERPC_MPC8378   CPU_POWERPC_e300c4
4881
#define CPU_POWERPC_MPC8378E  CPU_POWERPC_e300c4
4882
#define CPU_POWERPC_MPC8379   CPU_POWERPC_e300c4
4883
#define CPU_POWERPC_MPC8379E  CPU_POWERPC_e300c4
4884
    /* e500 family */
4885
#define CPU_POWERPC_e500      CPU_POWERPC_e500_v22
4886
    CPU_POWERPC_e500_v10    = 0x80200010,
4887
#define CPU_POWERPC_MPC8540_v1 CPU_POWERPC_e500_v10
4888
    CPU_POWERPC_e500_v20    = 0x80200020,
4889
#define CPU_POWERPC_MPC8540_v2 CPU_POWERPC_e500_v20
4890
#define CPU_POWERPC_MPC8541   CPU_POWERPC_e500_v20
4891
#define CPU_POWERPC_MPC8541E  CPU_POWERPC_e500_v20
4892
#define CPU_POWERPC_MPC8555   CPU_POWERPC_e500_v20
4893
#define CPU_POWERPC_MPC8555E  CPU_POWERPC_e500_v20
4894
#define CPU_POWERPC_MPC8560   CPU_POWERPC_e500_v20
4895
    CPU_POWERPC_e500v2_v10  = 0x80210010,
4896
#define CPU_POWERPC_MPC8543   CPU_POWERPC_e500v2_v10
4897
#define CPU_POWERPC_MPC8543E  CPU_POWERPC_e500v2_v10
4898
#define CPU_POWERPC_MPC8545   CPU_POWERPC_e500v2_v10
4899
#define CPU_POWERPC_MPC8545E  CPU_POWERPC_e500v2_v10
4900
#define CPU_POWERPC_MPC8547E  CPU_POWERPC_e500v2_v10
4901
#define CPU_POWERPC_MPC8548   CPU_POWERPC_e500v2_v10
4902
#define CPU_POWERPC_MPC8548E  CPU_POWERPC_e500v2_v10
4903
    CPU_POWERPC_e500v2_v20  = 0x80210020,
4904
    CPU_POWERPC_e500v2_v21  = 0x80210021,
4905
#define CPU_POWERPC_MPC8533_v10  CPU_POWERPC_e500v2_v21
4906
#define CPU_POWERPC_MPC8533E_v10 CPU_POWERPC_e500v2_v21
4907
#define CPU_POWERPC_MPC8544_v10  CPU_POWERPC_e500v2_v21
4908
#define CPU_POWERPC_MPC8544E_v10 CPU_POWERPC_e500v2_v21
4909
    CPU_POWERPC_e500v2_v22  = 0x80210022,
4910
#define CPU_POWERPC_MPC8533_v11  CPU_POWERPC_e500v2_v22
4911
#define CPU_POWERPC_MPC8533E_v11 CPU_POWERPC_e500v2_v22
4912
#define CPU_POWERPC_MPC8544_v11  CPU_POWERPC_e500v2_v22
4913
#define CPU_POWERPC_MPC8544E_v11 CPU_POWERPC_e500v2_v22
4914
#define CPU_POWERPC_MPC8567   CPU_POWERPC_e500v2_v22
4915
#define CPU_POWERPC_MPC8568   CPU_POWERPC_e500v2_v22
4916
    CPU_POWERPC_e500v2_v30  = 0x80210030,
4917
#define CPU_POWERPC_MPC8572   CPU_POWERPC_e500v2_v30
4918
    /* e600 family */
4919
    CPU_POWERPC_e600        = 0x80040010,
4920
#define CPU_POWERPC_MPC8610   CPU_POWERPC_e600
4921
#define CPU_POWERPC_MPC8641   CPU_POWERPC_e600
4922
#define CPU_POWERPC_MPC8641D  CPU_POWERPC_e600
4923
    /* PowerPC 6xx cores */
4924
#define CPU_POWERPC_601       CPU_POWERPC_601_v2
4925
    CPU_POWERPC_601_v0      = 0x00010001,
4926
    CPU_POWERPC_601_v1      = 0x00010001,
4927
    CPU_POWERPC_601_v2      = 0x00010002,
4928
    CPU_POWERPC_602         = 0x00050100,
4929
    CPU_POWERPC_603         = 0x00030100,
4930
#define CPU_POWERPC_603E      CPU_POWERPC_603E_v41
4931
    CPU_POWERPC_603E_v11    = 0x00060101,
4932
    CPU_POWERPC_603E_v12    = 0x00060102,
4933
    CPU_POWERPC_603E_v13    = 0x00060103,
4934
    CPU_POWERPC_603E_v14    = 0x00060104,
4935
    CPU_POWERPC_603E_v22    = 0x00060202,
4936
    CPU_POWERPC_603E_v3     = 0x00060300,
4937
    CPU_POWERPC_603E_v4     = 0x00060400,
4938
    CPU_POWERPC_603E_v41    = 0x00060401,
4939
    CPU_POWERPC_603E7t      = 0x00071201,
4940
    CPU_POWERPC_603E7v      = 0x00070100,
4941
    CPU_POWERPC_603E7v1     = 0x00070101,
4942
    CPU_POWERPC_603E7v2     = 0x00070201,
4943
    CPU_POWERPC_603E7       = 0x00070200,
4944
    CPU_POWERPC_603P        = 0x00070000,
4945
#define CPU_POWERPC_603R      CPU_POWERPC_603E7t
4946
    /* XXX: missing 0x00040303 (604) */
4947
    CPU_POWERPC_604         = 0x00040103,
4948
#define CPU_POWERPC_604E      CPU_POWERPC_604E_v24
4949
    /* XXX: missing 0x00091203 */
4950
    /* XXX: missing 0x00092110 */
4951
    /* XXX: missing 0x00092120 */
4952
    CPU_POWERPC_604E_v10    = 0x00090100,
4953
    CPU_POWERPC_604E_v22    = 0x00090202,
4954
    CPU_POWERPC_604E_v24    = 0x00090204,
4955
    /* XXX: missing 0x000a0100 */
4956
    /* XXX: missing 0x00093102 */
4957
    CPU_POWERPC_604R        = 0x000a0101,
4958
#if 0
4959
    CPU_POWERPC_604EV       = xxx, /* XXX: same as 604R ? */
4960
#endif
4961
    /* PowerPC 740/750 cores (aka G3) */
4962
    /* XXX: missing 0x00084202 */
4963
#define CPU_POWERPC_7x0       CPU_POWERPC_7x0_v31
4964
    CPU_POWERPC_7x0_v20     = 0x00080200,
4965
    CPU_POWERPC_7x0_v21     = 0x00080201,
4966
    CPU_POWERPC_7x0_v22     = 0x00080202,
4967
    CPU_POWERPC_7x0_v30     = 0x00080300,
4968
    CPU_POWERPC_7x0_v31     = 0x00080301,
4969
    CPU_POWERPC_740E        = 0x00080100,
4970
    CPU_POWERPC_7x0P        = 0x10080000,
4971
    /* XXX: missing 0x00087010 (CL ?) */
4972
    CPU_POWERPC_750CL       = 0x00087200,
4973
#define CPU_POWERPC_750CX     CPU_POWERPC_750CX_v22
4974
    CPU_POWERPC_750CX_v21   = 0x00082201,
4975
    CPU_POWERPC_750CX_v22   = 0x00082202,
4976
#define CPU_POWERPC_750CXE    CPU_POWERPC_750CXE_v31b
4977
    CPU_POWERPC_750CXE_v21  = 0x00082211,
4978
    CPU_POWERPC_750CXE_v22  = 0x00082212,
4979
    CPU_POWERPC_750CXE_v23  = 0x00082213,
4980
    CPU_POWERPC_750CXE_v24  = 0x00082214,
4981
    CPU_POWERPC_750CXE_v24b = 0x00083214,
4982
    CPU_POWERPC_750CXE_v31  = 0x00083211,
4983
    CPU_POWERPC_750CXE_v31b = 0x00083311,
4984
    CPU_POWERPC_750CXR      = 0x00083410,
4985
    CPU_POWERPC_750E        = 0x00080200,
4986
    CPU_POWERPC_750FL       = 0x700A0203,
4987
#define CPU_POWERPC_750FX     CPU_POWERPC_750FX_v23
4988
    CPU_POWERPC_750FX_v10   = 0x70000100,
4989
    CPU_POWERPC_750FX_v20   = 0x70000200,
4990
    CPU_POWERPC_750FX_v21   = 0x70000201,
4991
    CPU_POWERPC_750FX_v22   = 0x70000202,
4992
    CPU_POWERPC_750FX_v23   = 0x70000203,
4993
    CPU_POWERPC_750GL       = 0x70020102,
4994
#define CPU_POWERPC_750GX     CPU_POWERPC_750GX_v12
4995
    CPU_POWERPC_750GX_v10   = 0x70020100,
4996
    CPU_POWERPC_750GX_v11   = 0x70020101,
4997
    CPU_POWERPC_750GX_v12   = 0x70020102,
4998
#define CPU_POWERPC_750L      CPU_POWERPC_750L_v32 /* Aka LoneStar */
4999
    CPU_POWERPC_750L_v22    = 0x00088202,
5000
    CPU_POWERPC_750L_v30    = 0x00088300,
5001
    CPU_POWERPC_750L_v32    = 0x00088302,
5002
    /* PowerPC 745/755 cores */
5003
#define CPU_POWERPC_7x5       CPU_POWERPC_7x5_v28
5004
    CPU_POWERPC_7x5_v10     = 0x00083100,
5005
    CPU_POWERPC_7x5_v11     = 0x00083101,
5006
    CPU_POWERPC_7x5_v20     = 0x00083200,
5007
    CPU_POWERPC_7x5_v21     = 0x00083201,
5008
    CPU_POWERPC_7x5_v22     = 0x00083202, /* aka D */
5009
    CPU_POWERPC_7x5_v23     = 0x00083203, /* aka E */
5010
    CPU_POWERPC_7x5_v24     = 0x00083204,
5011
    CPU_POWERPC_7x5_v25     = 0x00083205,
5012
    CPU_POWERPC_7x5_v26     = 0x00083206,
5013
    CPU_POWERPC_7x5_v27     = 0x00083207,
5014
    CPU_POWERPC_7x5_v28     = 0x00083208,
5015
#if 0
5016
    CPU_POWERPC_7x5P        = xxx,
5017
#endif
5018
    /* PowerPC 74xx cores (aka G4) */
5019
    /* XXX: missing 0x000C1101 */
5020
#define CPU_POWERPC_7400      CPU_POWERPC_7400_v29
5021
    CPU_POWERPC_7400_v10    = 0x000C0100,
5022
    CPU_POWERPC_7400_v11    = 0x000C0101,
5023
    CPU_POWERPC_7400_v20    = 0x000C0200,
5024
    CPU_POWERPC_7400_v22    = 0x000C0202,
5025
    CPU_POWERPC_7400_v26    = 0x000C0206,
5026
    CPU_POWERPC_7400_v27    = 0x000C0207,
5027
    CPU_POWERPC_7400_v28    = 0x000C0208,
5028
    CPU_POWERPC_7400_v29    = 0x000C0209,
5029
#define CPU_POWERPC_7410      CPU_POWERPC_7410_v14
5030
    CPU_POWERPC_7410_v10    = 0x800C1100,
5031
    CPU_POWERPC_7410_v11    = 0x800C1101,
5032
    CPU_POWERPC_7410_v12    = 0x800C1102, /* aka C */
5033
    CPU_POWERPC_7410_v13    = 0x800C1103, /* aka D */
5034
    CPU_POWERPC_7410_v14    = 0x800C1104, /* aka E */
5035
#define CPU_POWERPC_7448      CPU_POWERPC_7448_v21
5036
    CPU_POWERPC_7448_v10    = 0x80040100,
5037
    CPU_POWERPC_7448_v11    = 0x80040101,
5038
    CPU_POWERPC_7448_v20    = 0x80040200,
5039
    CPU_POWERPC_7448_v21    = 0x80040201,
5040
#define CPU_POWERPC_7450      CPU_POWERPC_7450_v21
5041
    CPU_POWERPC_7450_v10    = 0x80000100,
5042
    CPU_POWERPC_7450_v11    = 0x80000101,
5043
    CPU_POWERPC_7450_v12    = 0x80000102,
5044
    CPU_POWERPC_7450_v20    = 0x80000200, /* aka D: 2.04 */
5045
    CPU_POWERPC_7450_v21    = 0x80000201, /* aka E */
5046
    CPU_POWERPC_74x1        = 0x80000203,
5047
    CPU_POWERPC_74x1G       = 0x80000210, /* aka G: 2.3 */
5048
#define CPU_POWERPC_74x5      CPU_POWERPC_74x5_v32
5049
    CPU_POWERPC_74x5_v10    = 0x80010100,
5050
    /* XXX: missing 0x80010200 */
5051
    CPU_POWERPC_74x5_v21    = 0x80010201, /* aka C: 2.1 */
5052
    CPU_POWERPC_74x5_v32    = 0x80010302,
5053
    CPU_POWERPC_74x5_v33    = 0x80010303, /* aka F: 3.3 */
5054
    CPU_POWERPC_74x5_v34    = 0x80010304, /* aka G: 3.4 */
5055
#define CPU_POWERPC_74x7      CPU_POWERPC_74x7_v12
5056
    /* XXX: is 0x8002xxxx 7447 and 0x8003xxxx 7457 ? */
5057
    /* XXX: missing 0x80030102 */
5058
    /* XXX: missing 0x80020101 */
5059
    CPU_POWERPC_74x7_v10    = 0x80020100, /* aka A: 1.0 */
5060
    CPU_POWERPC_74x7_v11    = 0x80030101, /* aka B: 1.1 */
5061
    CPU_POWERPC_74x7_v12    = 0x80020102, /* aka C: 1.2 */
5062
    /* 64 bits PowerPC */
5063
#if defined(TARGET_PPC64)
5064
    CPU_POWERPC_620         = 0x00140000,
5065
    CPU_POWERPC_630         = 0x00400000,
5066
    CPU_POWERPC_631         = 0x00410104,
5067
    CPU_POWERPC_POWER4      = 0x00350000,
5068
    CPU_POWERPC_POWER4P     = 0x00380000,
5069
     /* XXX: missing 0x003A0201 */
5070
    CPU_POWERPC_POWER5      = 0x003A0203,
5071
#define CPU_POWERPC_POWER5GR  CPU_POWERPC_POWER5
5072
    CPU_POWERPC_POWER5P     = 0x003B0000,
5073
#define CPU_POWERPC_POWER5GS  CPU_POWERPC_POWER5P
5074
    CPU_POWERPC_POWER6      = 0x003E0000,
5075
    CPU_POWERPC_POWER6_5    = 0x0F000001, /* POWER6 running POWER5 mode */
5076
    CPU_POWERPC_POWER6A     = 0x0F000002,
5077
    CPU_POWERPC_970         = 0x00390202,
5078
#define CPU_POWERPC_970FX     CPU_POWERPC_970FX_v31
5079
    CPU_POWERPC_970FX_v10   = 0x00391100,
5080
    CPU_POWERPC_970FX_v20   = 0x003C0200,
5081
    CPU_POWERPC_970FX_v21   = 0x003C0201,
5082
    CPU_POWERPC_970FX_v30   = 0x003C0300,
5083
    CPU_POWERPC_970FX_v31   = 0x003C0301,
5084
    CPU_POWERPC_970GX       = 0x00450000,
5085
#define CPU_POWERPC_970MP     CPU_POWERPC_970MP_v11
5086
    CPU_POWERPC_970MP_v10   = 0x00440100,
5087
    CPU_POWERPC_970MP_v11   = 0x00440101,
5088
#define CPU_POWERPC_CELL      CPU_POWERPC_CELL_v32
5089
    CPU_POWERPC_CELL_v10    = 0x00700100,
5090
    CPU_POWERPC_CELL_v20    = 0x00700400,
5091
    CPU_POWERPC_CELL_v30    = 0x00700500,
5092
    CPU_POWERPC_CELL_v31    = 0x00700501,
5093
#define CPU_POWERPC_CELL_v32  CPU_POWERPC_CELL_v31
5094
    CPU_POWERPC_RS64        = 0x00330000,
5095
    CPU_POWERPC_RS64II      = 0x00340000,
5096
    CPU_POWERPC_RS64III     = 0x00360000,
5097
    CPU_POWERPC_RS64IV      = 0x00370000,
5098
#endif /* defined(TARGET_PPC64) */
5099
    /* Original POWER */
5100
    /* XXX: should be POWER (RIOS), RSC3308, RSC4608,
5101
     * POWER2 (RIOS2) & RSC2 (P2SC) here
5102
     */
5103
#if 0
5104
    CPU_POWER           = xxx, /* 0x20000 ? 0x30000 for RSC ? */
5105
#endif
5106
#if 0
5107
    CPU_POWER2          = xxx, /* 0x40000 ? */
5108
#endif
5109
    /* PA Semi core */
5110
    CPU_POWERPC_PA6T        = 0x00900000,
5111
};
5112

    
5113
/* System version register (used on MPC 8xxx)                                */
5114
enum {
5115
    PPC_SVR_5200_v10  = 0x80110010,
5116
    PPC_SVR_5200_v11  = 0x80110011,
5117
    PPC_SVR_5200_v12  = 0x80110012,
5118
    PPC_SVR_5200B_v20 = 0x80110020,
5119
    PPC_SVR_5200B_v21 = 0x80110021,
5120
#if 0
5121
    PPC_SVR_5533      = xxx,
5122
#endif
5123
#if 0
5124
    PPC_SVR_5534      = xxx,
5125
#endif
5126
#if 0
5127
    PPC_SVR_5553      = xxx,
5128
#endif
5129
#if 0
5130
    PPC_SVR_5554      = xxx,
5131
#endif
5132
#if 0
5133
    PPC_SVR_5561      = xxx,
5134
#endif
5135
#if 0
5136
    PPC_SVR_5565      = xxx,
5137
#endif
5138
#if 0
5139
    PPC_SVR_5566      = xxx,
5140
#endif
5141
#if 0
5142
    PPC_SVR_5567      = xxx,
5143
#endif
5144
#if 0
5145
    PPC_SVR_8313      = xxx,
5146
#endif
5147
#if 0
5148
    PPC_SVR_8313E     = xxx,
5149
#endif
5150
#if 0
5151
    PPC_SVR_8314      = xxx,
5152
#endif
5153
#if 0
5154
    PPC_SVR_8314E     = xxx,
5155
#endif
5156
#if 0
5157
    PPC_SVR_8315      = xxx,
5158
#endif
5159
#if 0
5160
    PPC_SVR_8315E     = xxx,
5161
#endif
5162
#if 0
5163
    PPC_SVR_8321      = xxx,
5164
#endif
5165
#if 0
5166
    PPC_SVR_8321E     = xxx,
5167
#endif
5168
#if 0
5169
    PPC_SVR_8323      = xxx,
5170
#endif
5171
#if 0
5172
    PPC_SVR_8323E     = xxx,
5173
#endif
5174
    PPC_SVR_8343A     = 0x80570030,
5175
    PPC_SVR_8343EA    = 0x80560030,
5176
    PPC_SVR_8347AP    = 0x80550030, /* PBGA package */
5177
    PPC_SVR_8347AT    = 0x80530030, /* TBGA package */
5178
    PPC_SVR_8347EAP   = 0x80540030, /* PBGA package */
5179
    PPC_SVR_8347EAT   = 0x80520030, /* TBGA package */
5180
    PPC_SVR_8349      = 0x80510010,
5181
    PPC_SVR_8349A     = 0x80510030,
5182
    PPC_SVR_8349E     = 0x80500010,
5183
    PPC_SVR_8349EA    = 0x80500030,
5184
#if 0
5185
    PPC_SVR_8358E     = xxx,
5186
#endif
5187
#if 0
5188
    PPC_SVR_8360E     = xxx,
5189
#endif
5190
    PPC_SVR_8377      = 0x80C70010,
5191
    PPC_SVR_8377E     = 0x80C60010,
5192
    PPC_SVR_8378      = 0x80C50010,
5193
    PPC_SVR_8378E     = 0x80C40010,
5194
    PPC_SVR_8379      = 0x80C30010,
5195
    PPC_SVR_8379E     = 0x80C00010,
5196
    PPC_SVR_8533_v10  = 0x80340010,
5197
    PPC_SVR_8533_v11  = 0x80340011,
5198
    PPC_SVR_8533E_v10 = 0x803C0010,
5199
    PPC_SVR_8533E_v11 = 0x803C0011,
5200
    PPC_SVR_8540_v10  = 0x80300010,
5201
    PPC_SVR_8540_v20  = 0x80300020,
5202
    PPC_SVR_8540_v21  = 0x80300021,
5203
    PPC_SVR_8541_v10  = 0x80720010,
5204
    PPC_SVR_8541_v11  = 0x80720011,
5205
    PPC_SVR_8541E_v10 = 0x807A0010,
5206
    PPC_SVR_8541E_v11 = 0x807A0011,
5207
    PPC_SVR_8543_v10  = 0x80320010,
5208
    PPC_SVR_8543_v11  = 0x80320011,
5209
    PPC_SVR_8543_v20  = 0x80320020,
5210
    PPC_SVR_8543_v21  = 0x80320021,
5211
    PPC_SVR_8543E_v10 = 0x803A0010,
5212
    PPC_SVR_8543E_v11 = 0x803A0011,
5213
    PPC_SVR_8543E_v20 = 0x803A0020,
5214
    PPC_SVR_8543E_v21 = 0x803A0021,
5215
    PPC_SVR_8544_v10  = 0x80340110,
5216
    PPC_SVR_8544_v11  = 0x80340111,
5217
    PPC_SVR_8544E_v10 = 0x803C0110,
5218
    PPC_SVR_8544E_v11 = 0x803C0111,
5219
    PPC_SVR_8545_v20  = 0x80310220,
5220
    PPC_SVR_8545_v21  = 0x80310221,
5221
    PPC_SVR_8545E_v20 = 0x80390220,
5222
    PPC_SVR_8545E_v21 = 0x80390221,
5223
    PPC_SVR_8547E_v20 = 0x80390120,
5224
    PPC_SVR_8547E_v21 = 0x80390121,
5225
    PPC_SCR_8548_v10  = 0x80310010,
5226
    PPC_SCR_8548_v11  = 0x80310011,
5227
    PPC_SCR_8548_v20  = 0x80310020,
5228
    PPC_SCR_8548_v21  = 0x80310021,
5229
    PPC_SVR_8548E_v10 = 0x80390010,
5230
    PPC_SVR_8548E_v11 = 0x80390011,
5231
    PPC_SVR_8548E_v20 = 0x80390020,
5232
    PPC_SVR_8548E_v21 = 0x80390021,
5233
    PPC_SVR_8555_v10  = 0x80710010,
5234
    PPC_SVR_8555_v11  = 0x80710011,
5235
    PPC_SVR_8555E_v10 = 0x80790010,
5236
    PPC_SVR_8555E_v11 = 0x80790011,
5237
    PPC_SVR_8560_v10  = 0x80700010,
5238
    PPC_SVR_8560_v20  = 0x80700020,
5239
    PPC_SVR_8560_v21  = 0x80700021,
5240
    PPC_SVR_8567      = 0x80750111,
5241
    PPC_SVR_8567E     = 0x807D0111,
5242
    PPC_SVR_8568      = 0x80750011,
5243
    PPC_SVR_8568E     = 0x807D0011,
5244
    PPC_SVR_8572      = 0x80E00010,
5245
    PPC_SVR_8572E     = 0x80E80010,
5246
#if 0
5247
    PPC_SVR_8610      = xxx,
5248
#endif
5249
    PPC_SVR_8641      = 0x80900021,
5250
    PPC_SVR_8641D     = 0x80900121,
5251
};
5252

    
5253
/*****************************************************************************/
5254
/* PowerPC CPU definitions                                                   */
5255
#define POWERPC_DEF(_name, _pvr, _type)                                       \
5256
    {                                                                         \
5257
        .name        = _name,                                                 \
5258
        .pvr         = _pvr,                                                  \
5259
        .insns_flags = glue(POWERPC_INSNS_,_type),                            \
5260
        .msr_mask    = glue(POWERPC_MSRM_,_type),                             \
5261
        .mmu_model   = glue(POWERPC_MMU_,_type),                              \
5262
        .excp_model  = glue(POWERPC_EXCP_,_type),                             \
5263
        .bus_model   = glue(POWERPC_INPUT_,_type),                            \
5264
        .bfd_mach    = glue(POWERPC_BFDM_,_type),                             \
5265
        .flags       = glue(POWERPC_FLAG_,_type),                             \
5266
        .init_proc   = &glue(init_proc_,_type),                               \
5267
        .check_pow   = &glue(check_pow_,_type),                               \
5268
    }
5269

    
5270
static const ppc_def_t ppc_defs[] = {
5271
    /* Embedded PowerPC                                                      */
5272
    /* PowerPC 401 family                                                    */
5273
    /* Generic PowerPC 401 */
5274
    POWERPC_DEF("401",         CPU_POWERPC_401,         401),
5275
    /* PowerPC 401 cores                                                     */
5276
    /* PowerPC 401A1 */
5277
    POWERPC_DEF("401A1",       CPU_POWERPC_401A1,       401),
5278
    /* PowerPC 401B2                                                         */
5279
    POWERPC_DEF("401B2",       CPU_POWERPC_401B2,       401x2),
5280
#if defined (TODO)
5281
    /* PowerPC 401B3                                                         */
5282
    POWERPC_DEF("401B3",       CPU_POWERPC_401B3,       401x3),
5283
#endif
5284
    /* PowerPC 401C2                                                         */
5285
    POWERPC_DEF("401C2",       CPU_POWERPC_401C2,       401x2),
5286
    /* PowerPC 401D2                                                         */
5287
    POWERPC_DEF("401D2",       CPU_POWERPC_401D2,       401x2),
5288
    /* PowerPC 401E2                                                         */
5289
    POWERPC_DEF("401E2",       CPU_POWERPC_401E2,       401x2),
5290
    /* PowerPC 401F2                                                         */
5291
    POWERPC_DEF("401F2",       CPU_POWERPC_401F2,       401x2),
5292
    /* PowerPC 401G2                                                         */
5293
    /* XXX: to be checked */
5294
    POWERPC_DEF("401G2",       CPU_POWERPC_401G2,       401x2),
5295
    /* PowerPC 401 microcontrolers                                           */
5296
#if defined (TODO)
5297
    /* PowerPC 401GF                                                         */
5298
    POWERPC_DEF("401GF",       CPU_POWERPC_401GF,       401),
5299
#endif
5300
    /* IOP480 (401 microcontroler)                                           */
5301
    POWERPC_DEF("IOP480",      CPU_POWERPC_IOP480,      IOP480),
5302
    /* IBM Processor for Network Resources                                   */
5303
    POWERPC_DEF("Cobra",       CPU_POWERPC_COBRA,       401),
5304
#if defined (TODO)
5305
    POWERPC_DEF("Xipchip",     CPU_POWERPC_XIPCHIP,     401),
5306
#endif
5307
    /* PowerPC 403 family                                                    */
5308
    /* Generic PowerPC 403                                                   */
5309
    POWERPC_DEF("403",         CPU_POWERPC_403,         403),
5310
    /* PowerPC 403 microcontrolers                                           */
5311
    /* PowerPC 403 GA                                                        */
5312
    POWERPC_DEF("403GA",       CPU_POWERPC_403GA,       403),
5313
    /* PowerPC 403 GB                                                        */
5314
    POWERPC_DEF("403GB",       CPU_POWERPC_403GB,       403),
5315
    /* PowerPC 403 GC                                                        */
5316
    POWERPC_DEF("403GC",       CPU_POWERPC_403GC,       403),
5317
    /* PowerPC 403 GCX                                                       */
5318
    POWERPC_DEF("403GCX",      CPU_POWERPC_403GCX,      403GCX),
5319
#if defined (TODO)
5320
    /* PowerPC 403 GP                                                        */
5321
    POWERPC_DEF("403GP",       CPU_POWERPC_403GP,       403),
5322
#endif
5323
    /* PowerPC 405 family                                                    */
5324
    /* Generic PowerPC 405                                                   */
5325
    POWERPC_DEF("405",         CPU_POWERPC_405,         405),
5326
    /* PowerPC 405 cores                                                     */
5327
#if defined (TODO)
5328
    /* PowerPC 405 A3                                                        */
5329
    POWERPC_DEF("405A3",       CPU_POWERPC_405A3,       405),
5330
#endif
5331
#if defined (TODO)
5332
    /* PowerPC 405 A4                                                        */
5333
    POWERPC_DEF("405A4",       CPU_POWERPC_405A4,       405),
5334
#endif
5335
#if defined (TODO)
5336
    /* PowerPC 405 B3                                                        */
5337
    POWERPC_DEF("405B3",       CPU_POWERPC_405B3,       405),
5338
#endif
5339
#if defined (TODO)
5340
    /* PowerPC 405 B4                                                        */
5341
    POWERPC_DEF("405B4",       CPU_POWERPC_405B4,       405),
5342
#endif
5343
#if defined (TODO)
5344
    /* PowerPC 405 C3                                                        */
5345
    POWERPC_DEF("405C3",       CPU_POWERPC_405C3,       405),
5346
#endif
5347
#if defined (TODO)
5348
    /* PowerPC 405 C4                                                        */
5349
    POWERPC_DEF("405C4",       CPU_POWERPC_405C4,       405),
5350
#endif
5351
    /* PowerPC 405 D2                                                        */
5352
    POWERPC_DEF("405D2",       CPU_POWERPC_405D2,       405),
5353
#if defined (TODO)
5354
    /* PowerPC 405 D3                                                        */
5355
    POWERPC_DEF("405D3",       CPU_POWERPC_405D3,       405),
5356
#endif
5357
    /* PowerPC 405 D4                                                        */
5358
    POWERPC_DEF("405D4",       CPU_POWERPC_405D4,       405),
5359
#if defined (TODO)
5360
    /* PowerPC 405 D5                                                        */
5361
    POWERPC_DEF("405D5",       CPU_POWERPC_405D5,       405),
5362
#endif
5363
#if defined (TODO)
5364
    /* PowerPC 405 E4                                                        */
5365
    POWERPC_DEF("405E4",       CPU_POWERPC_405E4,       405),
5366
#endif
5367
#if defined (TODO)
5368
    /* PowerPC 405 F4                                                        */
5369
    POWERPC_DEF("405F4",       CPU_POWERPC_405F4,       405),
5370
#endif
5371
#if defined (TODO)
5372
    /* PowerPC 405 F5                                                        */
5373
    POWERPC_DEF("405F5",       CPU_POWERPC_405F5,       405),
5374
#endif
5375
#if defined (TODO)
5376
    /* PowerPC 405 F6                                                        */
5377
    POWERPC_DEF("405F6",       CPU_POWERPC_405F6,       405),
5378
#endif
5379
    /* PowerPC 405 microcontrolers                                           */
5380
    /* PowerPC 405 CR                                                        */
5381
    POWERPC_DEF("405CR",       CPU_POWERPC_405CR,       405),
5382
    /* PowerPC 405 CRa                                                       */
5383
    POWERPC_DEF("405CRa",      CPU_POWERPC_405CRa,      405),
5384
    /* PowerPC 405 CRb                                                       */
5385
    POWERPC_DEF("405CRb",      CPU_POWERPC_405CRb,      405),
5386
    /* PowerPC 405 CRc                                                       */
5387
    POWERPC_DEF("405CRc",      CPU_POWERPC_405CRc,      405),
5388
    /* PowerPC 405 EP                                                        */
5389
    POWERPC_DEF("405EP",       CPU_POWERPC_405EP,       405),
5390
#if defined(TODO)
5391
    /* PowerPC 405 EXr                                                       */
5392
    POWERPC_DEF("405EXr",      CPU_POWERPC_405EXr,      405),
5393
#endif
5394
    /* PowerPC 405 EZ                                                        */
5395
    POWERPC_DEF("405EZ",       CPU_POWERPC_405EZ,       405),
5396
#if defined(TODO)
5397
    /* PowerPC 405 FX                                                        */
5398
    POWERPC_DEF("405FX",       CPU_POWERPC_405FX,       405),
5399
#endif
5400
    /* PowerPC 405 GP                                                        */
5401
    POWERPC_DEF("405GP",       CPU_POWERPC_405GP,       405),
5402
    /* PowerPC 405 GPa                                                       */
5403
    POWERPC_DEF("405GPa",      CPU_POWERPC_405GPa,      405),
5404
    /* PowerPC 405 GPb                                                       */
5405
    POWERPC_DEF("405GPb",      CPU_POWERPC_405GPb,      405),
5406
    /* PowerPC 405 GPc                                                       */
5407
    POWERPC_DEF("405GPc",      CPU_POWERPC_405GPc,      405),
5408
    /* PowerPC 405 GPd                                                       */
5409
    POWERPC_DEF("405GPd",      CPU_POWERPC_405GPd,      405),
5410
    /* PowerPC 405 GPe                                                       */
5411
    POWERPC_DEF("405GPe",      CPU_POWERPC_405GPe,      405),
5412
    /* PowerPC 405 GPR                                                       */
5413
    POWERPC_DEF("405GPR",      CPU_POWERPC_405GPR,      405),
5414
#if defined(TODO)
5415
    /* PowerPC 405 H                                                         */
5416
    POWERPC_DEF("405H",        CPU_POWERPC_405H,        405),
5417
#endif
5418
#if defined(TODO)
5419
    /* PowerPC 405 L                                                         */
5420
    POWERPC_DEF("405L",        CPU_POWERPC_405L,        405),
5421
#endif
5422
    /* PowerPC 405 LP                                                        */
5423
    POWERPC_DEF("405LP",       CPU_POWERPC_405LP,       405),
5424
#if defined(TODO)
5425
    /* PowerPC 405 PM                                                        */
5426
    POWERPC_DEF("405PM",       CPU_POWERPC_405PM,       405),
5427
#endif
5428
#if defined(TODO)
5429
    /* PowerPC 405 PS                                                        */
5430
    POWERPC_DEF("405PS",       CPU_POWERPC_405PS,       405),
5431
#endif
5432
#if defined(TODO)
5433
    /* PowerPC 405 S                                                         */
5434
    POWERPC_DEF("405S",        CPU_POWERPC_405S,        405),
5435
#endif
5436
    /* Npe405 H                                                              */
5437
    POWERPC_DEF("Npe405H",     CPU_POWERPC_NPE405H,     405),
5438
    /* Npe405 H2                                                             */
5439
    POWERPC_DEF("Npe405H2",    CPU_POWERPC_NPE405H2,    405),
5440
    /* Npe405 L                                                              */
5441
    POWERPC_DEF("Npe405L",     CPU_POWERPC_NPE405L,     405),
5442
    /* Npe4GS3                                                               */
5443
    POWERPC_DEF("Npe4GS3",     CPU_POWERPC_NPE4GS3,     405),
5444
#if defined (TODO)
5445
    POWERPC_DEF("Npcxx1",      CPU_POWERPC_NPCxx1,      405),
5446
#endif
5447
#if defined (TODO)
5448
    POWERPC_DEF("Npr161",      CPU_POWERPC_NPR161,      405),
5449
#endif
5450
#if defined (TODO)
5451
    /* PowerPC LC77700 (Sanyo)                                               */
5452
    POWERPC_DEF("LC77700",     CPU_POWERPC_LC77700,     405),
5453
#endif
5454
    /* PowerPC 401/403/405 based set-top-box microcontrolers                 */
5455
#if defined (TODO)
5456
    /* STB010000                                                             */
5457
    POWERPC_DEF("STB01000",    CPU_POWERPC_STB01000,    401x2),
5458
#endif
5459
#if defined (TODO)
5460
    /* STB01010                                                              */
5461
    POWERPC_DEF("STB01010",    CPU_POWERPC_STB01010,    401x2),
5462
#endif
5463
#if defined (TODO)
5464
    /* STB0210                                                               */
5465
    POWERPC_DEF("STB0210",     CPU_POWERPC_STB0210,     401x3),
5466
#endif
5467
    /* STB03xx                                                               */
5468
    POWERPC_DEF("STB03",       CPU_POWERPC_STB03,       405),
5469
#if defined (TODO)
5470
    /* STB043x                                                               */
5471
    POWERPC_DEF("STB043",      CPU_POWERPC_STB043,      405),
5472
#endif
5473
#if defined (TODO)
5474
    /* STB045x                                                               */
5475
    POWERPC_DEF("STB045",      CPU_POWERPC_STB045,      405),
5476
#endif
5477
    /* STB04xx                                                               */
5478
    POWERPC_DEF("STB04",       CPU_POWERPC_STB04,       405),
5479
    /* STB25xx                                                               */
5480
    POWERPC_DEF("STB25",       CPU_POWERPC_STB25,       405),
5481
#if defined (TODO)
5482
    /* STB130                                                                */
5483
    POWERPC_DEF("STB130",      CPU_POWERPC_STB130,      405),
5484
#endif
5485
    /* Xilinx PowerPC 405 cores                                              */
5486
    POWERPC_DEF("x2vp4",       CPU_POWERPC_X2VP4,       405),
5487
    POWERPC_DEF("x2vp7",       CPU_POWERPC_X2VP7,       405),
5488
    POWERPC_DEF("x2vp20",      CPU_POWERPC_X2VP20,      405),
5489
    POWERPC_DEF("x2vp50",      CPU_POWERPC_X2VP50,      405),
5490
#if defined (TODO)
5491
    /* Zarlink ZL10310                                                       */
5492
    POWERPC_DEF("zl10310",     CPU_POWERPC_ZL10310,     405),
5493
#endif
5494
#if defined (TODO)
5495
    /* Zarlink ZL10311                                                       */
5496
    POWERPC_DEF("zl10311",     CPU_POWERPC_ZL10311,     405),
5497
#endif
5498
#if defined (TODO)
5499
    /* Zarlink ZL10320                                                       */
5500
    POWERPC_DEF("zl10320",     CPU_POWERPC_ZL10320,     405),
5501
#endif
5502
#if defined (TODO)
5503
    /* Zarlink ZL10321                                                       */
5504
    POWERPC_DEF("zl10321",     CPU_POWERPC_ZL10321,     405),
5505
#endif
5506
    /* PowerPC 440 family                                                    */
5507
    /* Generic PowerPC 440                                                   */
5508
    POWERPC_DEF("440",         CPU_POWERPC_440,         440GP),
5509
    /* PowerPC 440 cores                                                     */
5510
#if defined (TODO)
5511
    /* PowerPC 440 A4                                                        */
5512
    POWERPC_DEF("440A4",       CPU_POWERPC_440A4,       440x4),
5513
#endif
5514
#if defined (TODO)
5515
    /* PowerPC 440 A5                                                        */
5516
    POWERPC_DEF("440A5",       CPU_POWERPC_440A5,       440x5),
5517
#endif
5518
#if defined (TODO)
5519
    /* PowerPC 440 B4                                                        */
5520
    POWERPC_DEF("440B4",       CPU_POWERPC_440B4,       440x4),
5521
#endif
5522
#if defined (TODO)
5523
    /* PowerPC 440 G4                                                        */
5524
    POWERPC_DEF("440G4",       CPU_POWERPC_440G4,       440x4),
5525
#endif
5526
#if defined (TODO)
5527
    /* PowerPC 440 F5                                                        */
5528
    POWERPC_DEF("440F5",       CPU_POWERPC_440F5,       440x5),
5529
#endif
5530
#if defined (TODO)
5531
    /* PowerPC 440 G5                                                        */
5532
    POWERPC_DEF("440G5",       CPU_POWERPC_440G5,       440x5),
5533
#endif
5534
#if defined (TODO)
5535
    /* PowerPC 440H4                                                         */
5536
    POWERPC_DEF("440H4",       CPU_POWERPC_440H4,       440x4),
5537
#endif
5538
#if defined (TODO)
5539
    /* PowerPC 440H6                                                         */
5540
    POWERPC_DEF("440H6",       CPU_POWERPC_440H6,       440Gx5),
5541
#endif
5542
    /* PowerPC 440 microcontrolers                                           */
5543
    /* PowerPC 440 EP                                                        */
5544
    POWERPC_DEF("440EP",       CPU_POWERPC_440EP,       440EP),
5545
    /* PowerPC 440 EPa                                                       */
5546
    POWERPC_DEF("440EPa",      CPU_POWERPC_440EPa,      440EP),
5547
    /* PowerPC 440 EPb                                                       */
5548
    POWERPC_DEF("440EPb",      CPU_POWERPC_440EPb,      440EP),
5549
    /* PowerPC 440 EPX                                                       */
5550
    POWERPC_DEF("440EPX",      CPU_POWERPC_440EPX,      440EP),
5551
    /* PowerPC 440 GP                                                        */
5552
    POWERPC_DEF("440GP",       CPU_POWERPC_440GP,       440GP),
5553
    /* PowerPC 440 GPb                                                       */
5554
    POWERPC_DEF("440GPb",      CPU_POWERPC_440GPb,      440GP),
5555
    /* PowerPC 440 GPc                                                       */
5556
    POWERPC_DEF("440GPc",      CPU_POWERPC_440GPc,      440GP),
5557
    /* PowerPC 440 GR                                                        */
5558
    POWERPC_DEF("440GR",       CPU_POWERPC_440GR,       440x5),
5559
    /* PowerPC 440 GRa                                                       */
5560
    POWERPC_DEF("440GRa",      CPU_POWERPC_440GRa,      440x5),
5561
    /* PowerPC 440 GRX                                                       */
5562
    POWERPC_DEF("440GRX",      CPU_POWERPC_440GRX,      440x5),
5563
    /* PowerPC 440 GX                                                        */
5564
    POWERPC_DEF("440GX",       CPU_POWERPC_440GX,       440EP),
5565
    /* PowerPC 440 GXa                                                       */
5566
    POWERPC_DEF("440GXa",      CPU_POWERPC_440GXa,      440EP),
5567
    /* PowerPC 440 GXb                                                       */
5568
    POWERPC_DEF("440GXb",      CPU_POWERPC_440GXb,      440EP),
5569
    /* PowerPC 440 GXc                                                       */
5570
    POWERPC_DEF("440GXc",      CPU_POWERPC_440GXc,      440EP),
5571
    /* PowerPC 440 GXf                                                       */
5572
    POWERPC_DEF("440GXf",      CPU_POWERPC_440GXf,      440EP),
5573
#if defined(TODO)
5574
    /* PowerPC 440 S                                                         */
5575
    POWERPC_DEF("440S",        CPU_POWERPC_440S,        440),
5576
#endif
5577
    /* PowerPC 440 SP                                                        */
5578
    POWERPC_DEF("440SP",       CPU_POWERPC_440SP,       440EP),
5579
    /* PowerPC 440 SP2                                                       */
5580
    POWERPC_DEF("440SP2",      CPU_POWERPC_440SP2,      440EP),
5581
    /* PowerPC 440 SPE                                                       */
5582
    POWERPC_DEF("440SPE",      CPU_POWERPC_440SPE,      440EP),
5583
    /* PowerPC 460 family                                                    */
5584
#if defined (TODO)
5585
    /* Generic PowerPC 464                                                   */
5586
    POWERPC_DEF("464",         CPU_POWERPC_464,         460),
5587
#endif
5588
    /* PowerPC 464 microcontrolers                                           */
5589
#if defined (TODO)
5590
    /* PowerPC 464H90                                                        */
5591
    POWERPC_DEF("464H90",      CPU_POWERPC_464H90,      460),
5592
#endif
5593
#if defined (TODO)
5594
    /* PowerPC 464H90F                                                       */
5595
    POWERPC_DEF("464H90F",     CPU_POWERPC_464H90F,     460F),
5596
#endif
5597
    /* Freescale embedded PowerPC cores                                      */
5598
    /* e200 family                                                           */
5599
#if defined (TODO)
5600
    /* Generic PowerPC e200 core                                             */
5601
    POWERPC_DEF("e200",        CPU_POWERPC_e200,        e200),
5602
#endif
5603
#if defined (TODO)
5604
    /* PowerPC e200z5 core                                                   */
5605
    POWERPC_DEF("e200z5",      CPU_POWERPC_e200z5,      e200),
5606
#endif
5607
#if defined (TODO)
5608
    /* PowerPC e200z6 core                                                   */
5609
    POWERPC_DEF("e200z6",      CPU_POWERPC_e200z6,      e200),
5610
#endif
5611
    /* e300 family                                                           */
5612
#if defined (TODO)
5613
    /* Generic PowerPC e300 core                                             */
5614
    POWERPC_DEF("e300",        CPU_POWERPC_e300,        e300),
5615
#endif
5616
#if defined (TODO)
5617
    /* PowerPC e300c1 core                                                   */
5618
    POWERPC_DEF("e300c1",      CPU_POWERPC_e300c1,      e300),
5619
#endif
5620
#if defined (TODO)
5621
    /* PowerPC e300c2 core                                                   */
5622
    POWERPC_DEF("e300c2",      CPU_POWERPC_e300c2,      e300),
5623
#endif
5624
#if defined (TODO)
5625
    /* PowerPC e300c3 core                                                   */
5626
    POWERPC_DEF("e300c3",      CPU_POWERPC_e300c3,      e300),
5627
#endif
5628
    /* e500 family                                                           */
5629
#if defined (TODO)
5630
    /* PowerPC e500 core                                                     */
5631
    POWERPC_DEF("e500",        CPU_POWERPC_e500,        e500),
5632
#endif
5633
#if defined (TODO)
5634
    /* PowerPC e500 v1.1 core                                                */
5635
    POWERPC_DEF("e500v1.1",    CPU_POWERPC_e500_v11,    e500),
5636
#endif
5637
#if defined (TODO)
5638
    /* PowerPC e500 v1.2 core                                                */
5639
    POWERPC_DEF("e500v1.2",    CPU_POWERPC_e500_v12,    e500),
5640
#endif
5641
#if defined (TODO)
5642
    /* PowerPC e500 v2.1 core                                                */
5643
    POWERPC_DEF("e500v2.1",    CPU_POWERPC_e500_v21,    e500),
5644
#endif
5645
#if defined (TODO)
5646
    /* PowerPC e500 v2.2 core                                                */
5647
    POWERPC_DEF("e500v2.2",    CPU_POWERPC_e500_v22,    e500),
5648
#endif
5649
    /* e600 family                                                           */
5650
#if defined (TODO)
5651
    /* PowerPC e600 core                                                     */
5652
    POWERPC_DEF("e600",        CPU_POWERPC_e600,        e600),
5653
#endif
5654
    /* PowerPC MPC 5xx cores                                                 */
5655
#if defined (TODO)
5656
    /* PowerPC MPC 5xx                                                       */
5657
    POWERPC_DEF("mpc5xx",      CPU_POWERPC_5xx,         5xx),
5658
#endif
5659
    /* PowerPC MPC 8xx cores                                                 */
5660
#if defined (TODO)
5661
    /* PowerPC MPC 8xx                                                       */
5662
    POWERPC_DEF("mpc8xx",      CPU_POWERPC_8xx,         8xx),
5663
#endif
5664
    /* PowerPC MPC 8xxx cores                                                */
5665
#if defined (TODO)
5666
    /* PowerPC MPC 82xx HIP3                                                 */
5667
    POWERPC_DEF("mpc82xxhip3", CPU_POWERPC_82xx_HIP3,   82xx),
5668
#endif
5669
#if defined (TODO)
5670
    /* PowerPC MPC 82xx HIP4                                                 */
5671
    POWERPC_DEF("mpc82xxhip4", CPU_POWERPC_82xx_HIP4,   82xx),
5672
#endif
5673
#if defined (TODO)
5674
    /* PowerPC MPC 827x                                                      */
5675
    POWERPC_DEF("mpc827x",     CPU_POWERPC_827x,        827x),
5676
#endif
5677

    
5678
    /* 32 bits "classic" PowerPC                                             */
5679
    /* PowerPC 6xx family                                                    */
5680
    /* PowerPC 601                                                           */
5681
    POWERPC_DEF("601",         CPU_POWERPC_601,         601),
5682
    /* PowerPC 601v0                                                         */
5683
    POWERPC_DEF("601v0",       CPU_POWERPC_601_v0,      601),
5684
    /* PowerPC 601v1                                                         */
5685
    POWERPC_DEF("601v1",       CPU_POWERPC_601_v1,      601),
5686
    /* PowerPC 601v2                                                         */
5687
    POWERPC_DEF("601v2",       CPU_POWERPC_601_v2,      601),
5688
    /* PowerPC 602                                                           */
5689
    POWERPC_DEF("602",         CPU_POWERPC_602,         602),
5690
    /* PowerPC 603                                                           */
5691
    POWERPC_DEF("603",         CPU_POWERPC_603,         603),
5692
    /* Code name for PowerPC 603                                             */
5693
    POWERPC_DEF("Vanilla",     CPU_POWERPC_603,         603),
5694
    /* PowerPC 603e                                                          */
5695
    POWERPC_DEF("603e",        CPU_POWERPC_603E,        603E),
5696
    /* Code name for PowerPC 603e                                            */
5697
    POWERPC_DEF("Stretch",     CPU_POWERPC_603E,        603E),
5698
    /* PowerPC 603e v1.1                                                     */
5699
    POWERPC_DEF("603e1.1",     CPU_POWERPC_603E_v11,    603E),
5700
    /* PowerPC 603e v1.2                                                     */
5701
    POWERPC_DEF("603e1.2",     CPU_POWERPC_603E_v12,    603E),
5702
    /* PowerPC 603e v1.3                                                     */
5703
    POWERPC_DEF("603e1.3",     CPU_POWERPC_603E_v13,    603E),
5704
    /* PowerPC 603e v1.4                                                     */
5705
    POWERPC_DEF("603e1.4",     CPU_POWERPC_603E_v14,    603E),
5706
    /* PowerPC 603e v2.2                                                     */
5707
    POWERPC_DEF("603e2.2",     CPU_POWERPC_603E_v22,    603E),
5708
    /* PowerPC 603e v3                                                       */
5709
    POWERPC_DEF("603e3",       CPU_POWERPC_603E_v3,     603E),
5710
    /* PowerPC 603e v4                                                       */
5711
    POWERPC_DEF("603e4",       CPU_POWERPC_603E_v4,     603E),
5712
    /* PowerPC 603e v4.1                                                     */
5713
    POWERPC_DEF("603e4.1",     CPU_POWERPC_603E_v41,    603E),
5714
    /* PowerPC 603e                                                          */
5715
    POWERPC_DEF("603e7",       CPU_POWERPC_603E7,       603E),
5716
    /* PowerPC 603e7t                                                        */
5717
    POWERPC_DEF("603e7t",      CPU_POWERPC_603E7t,      603E),
5718
    /* PowerPC 603e7v                                                        */
5719
    POWERPC_DEF("603e7v",      CPU_POWERPC_603E7v,      603E),
5720
    /* Code name for PowerPC 603ev                                           */
5721
    POWERPC_DEF("Vaillant",    CPU_POWERPC_603E7v,      603E),
5722
    /* PowerPC 603e7v1                                                       */
5723
    POWERPC_DEF("603e7v1",     CPU_POWERPC_603E7v1,     603E),
5724
    /* PowerPC 603e7v2                                                       */
5725
    POWERPC_DEF("603e7v2",     CPU_POWERPC_603E7v2,     603E),
5726
    /* PowerPC 603p                                                          */
5727
    /* to be checked */
5728
    POWERPC_DEF("603p",        CPU_POWERPC_603P,        603),
5729
    /* PowerPC 603r                                                          */
5730
    POWERPC_DEF("603r",        CPU_POWERPC_603R,        603E),
5731
    /* Code name for PowerPC 603r                                            */
5732
    POWERPC_DEF("Goldeneye",   CPU_POWERPC_603R,        603E),
5733
    /* PowerPC G2 core                                                       */
5734
    POWERPC_DEF("G2",          CPU_POWERPC_G2,          G2),
5735
    /* PowerPC G2 H4                                                         */
5736
    POWERPC_DEF("G2H4",        CPU_POWERPC_G2H4,        G2),
5737
    /* PowerPC G2 GP                                                         */
5738
    POWERPC_DEF("G2GP",        CPU_POWERPC_G2gp,        G2),
5739
    /* PowerPC G2 LS                                                         */
5740
    POWERPC_DEF("G2LS",        CPU_POWERPC_G2ls,        G2),
5741
    /* PowerPC G2LE                                                          */
5742
    /* Same as G2, with little-endian mode support                           */
5743
    POWERPC_DEF("G2le",        CPU_POWERPC_G2LE,        G2LE),
5744
    /* PowerPC G2LE GP                                                       */
5745
    POWERPC_DEF("G2leGP",      CPU_POWERPC_G2LEgp,      G2LE),
5746
    /* PowerPC G2LE LS                                                       */
5747
    POWERPC_DEF("G2leLS",      CPU_POWERPC_G2LEls,      G2LE),
5748
    /* PowerPC 604                                                           */
5749
    POWERPC_DEF("604",         CPU_POWERPC_604,         604),
5750
    /* PowerPC 604e                                                          */
5751
    /* XXX: code names "Sirocco" "Mach 5" */
5752
    POWERPC_DEF("604e",        CPU_POWERPC_604E,        604),
5753
    /* PowerPC 604e v1.0                                                     */
5754
    POWERPC_DEF("604e1.0",     CPU_POWERPC_604E_v10,    604),
5755
    /* PowerPC 604e v2.2                                                     */
5756
    POWERPC_DEF("604e2.2",     CPU_POWERPC_604E_v22,    604),
5757
    /* PowerPC 604e v2.4                                                     */
5758
    POWERPC_DEF("604e2.4",     CPU_POWERPC_604E_v24,    604),
5759
    /* PowerPC 604r                                                          */
5760
    POWERPC_DEF("604r",        CPU_POWERPC_604R,        604),
5761
#if defined(TODO)
5762
    /* PowerPC 604ev                                                         */
5763
    POWERPC_DEF("604ev",       CPU_POWERPC_604EV,       604),
5764
#endif
5765
    /* PowerPC 7xx family                                                    */
5766
    /* Generic PowerPC 740 (G3)                                              */
5767
    POWERPC_DEF("740",         CPU_POWERPC_7x0,         7x0),
5768
    /* Generic PowerPC 750 (G3)                                              */
5769
    POWERPC_DEF("750",         CPU_POWERPC_7x0,         7x0),
5770
    /* Code name for generic PowerPC 740/750 (G3)                            */
5771
    POWERPC_DEF("Arthur",      CPU_POWERPC_7x0,         7x0),
5772
    /* XXX: 750 codename "Typhoon" */
5773
    /* PowerPC 740/750 is also known as G3                                   */
5774
    POWERPC_DEF("G3",          CPU_POWERPC_7x0,         7x0),
5775
    /* PowerPC 740 v2.0 (G3)                                                 */
5776
    POWERPC_DEF("740v2.0",     CPU_POWERPC_7x0_v20,     7x0),
5777
    /* PowerPC 750 v2.0 (G3)                                                 */
5778
    POWERPC_DEF("750v2.0",     CPU_POWERPC_7x0_v20,     7x0),
5779
    /* PowerPC 740 v2.1 (G3)                                                 */
5780
    POWERPC_DEF("740v2.1",     CPU_POWERPC_7x0_v21,     7x0),
5781
    /* PowerPC 750 v2.1 (G3)                                                 */
5782
    POWERPC_DEF("750v2.1",     CPU_POWERPC_7x0_v21,     7x0),
5783
    /* PowerPC 740 v2.2 (G3)                                                 */
5784
    POWERPC_DEF("740v2.2",     CPU_POWERPC_7x0_v22,     7x0),
5785
    /* PowerPC 750 v2.2 (G3)                                                 */
5786
    POWERPC_DEF("750v2.2",     CPU_POWERPC_7x0_v22,     7x0),
5787
    /* PowerPC 740 v3.0 (G3)                                                 */
5788
    POWERPC_DEF("740v3.0",     CPU_POWERPC_7x0_v30,     7x0),
5789
    /* PowerPC 750 v3.0 (G3)                                                 */
5790
    POWERPC_DEF("750v3.0",     CPU_POWERPC_7x0_v30,     7x0),
5791
    /* PowerPC 740 v3.1 (G3)                                                 */
5792
    POWERPC_DEF("740v3.1",     CPU_POWERPC_7x0_v31,     7x0),
5793
    /* PowerPC 750 v3.1 (G3)                                                 */
5794
    POWERPC_DEF("750v3.1",     CPU_POWERPC_7x0_v31,     7x0),
5795
    /* PowerPC 740E (G3)                                                     */
5796
    POWERPC_DEF("740e",        CPU_POWERPC_740E,        7x0),
5797
    /* PowerPC 740P (G3)                                                     */
5798
    POWERPC_DEF("740p",        CPU_POWERPC_7x0P,        7x0),
5799
    /* PowerPC 750P (G3)                                                     */
5800
    POWERPC_DEF("750p",        CPU_POWERPC_7x0P,        7x0),
5801
    /* Code name for PowerPC 740P/750P (G3)                                  */
5802
    POWERPC_DEF("Conan/Doyle", CPU_POWERPC_7x0P,        7x0),
5803
    /* PowerPC 750CL (G3 embedded)                                           */
5804
    POWERPC_DEF("750cl",       CPU_POWERPC_750CL,       7x0),
5805
    /* PowerPC 750CX (G3 embedded)                                           */
5806
    POWERPC_DEF("750cx",       CPU_POWERPC_750CX,       7x0),
5807
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
5808
    POWERPC_DEF("750cx2.1",    CPU_POWERPC_750CX_v21,   7x0),
5809
    /* PowerPC 750CX v2.2 (G3 embedded)                                      */
5810
    POWERPC_DEF("750cx2.2",    CPU_POWERPC_750CX_v22,   7x0),
5811
    /* PowerPC 750CXe (G3 embedded)                                          */
5812
    POWERPC_DEF("750cxe",      CPU_POWERPC_750CXE,      7x0),
5813
    /* PowerPC 750CXe v2.1 (G3 embedded)                                     */
5814
    POWERPC_DEF("750cxe21",    CPU_POWERPC_750CXE_v21,  7x0),
5815
    /* PowerPC 750CXe v2.2 (G3 embedded)                                     */
5816
    POWERPC_DEF("750cxe22",    CPU_POWERPC_750CXE_v22,  7x0),
5817
    /* PowerPC 750CXe v2.3 (G3 embedded)                                     */
5818
    POWERPC_DEF("750cxe23",    CPU_POWERPC_750CXE_v23,  7x0),
5819
    /* PowerPC 750CXe v2.4 (G3 embedded)                                     */
5820
    POWERPC_DEF("750cxe24",    CPU_POWERPC_750CXE_v24,  7x0),
5821
    /* PowerPC 750CXe v2.4b (G3 embedded)                                    */
5822
    POWERPC_DEF("750cxe24b",   CPU_POWERPC_750CXE_v24b, 7x0),
5823
    /* PowerPC 750CXe v3.1 (G3 embedded)                                     */
5824
    POWERPC_DEF("750cxe31",    CPU_POWERPC_750CXE_v31,  7x0),
5825
    /* PowerPC 750CXe v3.1b (G3 embedded)                                    */
5826
    POWERPC_DEF("750cxe3.1b",  CPU_POWERPC_750CXE_v31b, 7x0),
5827
    /* PowerPC 750CXr (G3 embedded)                                          */
5828
    POWERPC_DEF("750cxr",      CPU_POWERPC_750CXR,      7x0),
5829
    /* PowerPC 750E (G3)                                                     */
5830
    POWERPC_DEF("750e",        CPU_POWERPC_750E,        7x0),
5831
    /* PowerPC 750FL (G3 embedded)                                           */
5832
    POWERPC_DEF("750fl",       CPU_POWERPC_750FL,       750fx),
5833
    /* PowerPC 750FX (G3 embedded)                                           */
5834
    POWERPC_DEF("750fx",       CPU_POWERPC_750FX,       750fx),
5835
    /* PowerPC 750FX v1.0 (G3 embedded)                                      */
5836
    POWERPC_DEF("750fx1.0",    CPU_POWERPC_750FX_v10,   750fx),
5837
    /* PowerPC 750FX v2.0 (G3 embedded)                                      */
5838
    POWERPC_DEF("750fx2.0",    CPU_POWERPC_750FX_v20,   750fx),
5839
    /* PowerPC 750FX v2.1 (G3 embedded)                                      */
5840
    POWERPC_DEF("750fx2.1",    CPU_POWERPC_750FX_v21,   750fx),
5841
    /* PowerPC 750FX v2.2 (G3 embedded)                                      */
5842
    POWERPC_DEF("750fx2.2",    CPU_POWERPC_750FX_v22,   750fx),
5843
    /* PowerPC 750FX v2.3 (G3 embedded)                                      */
5844
    POWERPC_DEF("750fx2.3",    CPU_POWERPC_750FX_v23,   750fx),
5845
    /* PowerPC 750GL (G3 embedded)                                           */
5846
    POWERPC_DEF("750gl",       CPU_POWERPC_750GL,       750fx),
5847
    /* PowerPC 750GX (G3 embedded)                                           */
5848
    POWERPC_DEF("750gx",       CPU_POWERPC_750GX,       750fx),
5849
    /* PowerPC 750GX v1.0 (G3 embedded)                                      */
5850
    POWERPC_DEF("750gx1.0",    CPU_POWERPC_750GX_v10,   750fx),
5851
    /* PowerPC 750GX v1.1 (G3 embedded)                                      */
5852
    POWERPC_DEF("750gx1.1",    CPU_POWERPC_750GX_v11,   750fx),
5853
    /* PowerPC 750GX v1.2 (G3 embedded)                                      */
5854
    POWERPC_DEF("750gx1.2",    CPU_POWERPC_750GX_v12,   750fx),
5855
    /* PowerPC 750L (G3 embedded)                                            */
5856
    POWERPC_DEF("750l",        CPU_POWERPC_750L,        7x0),
5857
    /* Code name for PowerPC 750L (G3 embedded)                              */
5858
    POWERPC_DEF("LoneStar",    CPU_POWERPC_750L,        7x0),
5859
    /* PowerPC 750L v2.2 (G3 embedded)                                       */
5860
    POWERPC_DEF("750l2.2",     CPU_POWERPC_750L_v22,    7x0),
5861
    /* PowerPC 750L v3.0 (G3 embedded)                                       */
5862
    POWERPC_DEF("750l3.0",     CPU_POWERPC_750L_v30,    7x0),
5863
    /* PowerPC 750L v3.2 (G3 embedded)                                       */
5864
    POWERPC_DEF("750l3.2",     CPU_POWERPC_750L_v32,    7x0),
5865
    /* Generic PowerPC 745                                                   */
5866
    POWERPC_DEF("745",         CPU_POWERPC_7x5,         7x5),
5867
    /* Generic PowerPC 755                                                   */
5868
    POWERPC_DEF("755",         CPU_POWERPC_7x5,         7x5),
5869
    /* Code name for PowerPC 745/755                                         */
5870
    POWERPC_DEF("Goldfinger",  CPU_POWERPC_7x5,         7x5),
5871
    /* PowerPC 745 v1.0                                                      */
5872
    POWERPC_DEF("745v1.0",     CPU_POWERPC_7x5_v10,     7x5),
5873
    /* PowerPC 755 v1.0                                                      */
5874
    POWERPC_DEF("755v1.0",     CPU_POWERPC_7x5_v10,     7x5),
5875
    /* PowerPC 745 v1.1                                                      */
5876
    POWERPC_DEF("745v1.1",     CPU_POWERPC_7x5_v11,     7x5),
5877
    /* PowerPC 755 v1.1                                                      */
5878
    POWERPC_DEF("755v1.1",     CPU_POWERPC_7x5_v11,     7x5),
5879
    /* PowerPC 745 v2.0                                                      */
5880
    POWERPC_DEF("745v2.0",     CPU_POWERPC_7x5_v20,     7x5),
5881
    /* PowerPC 755 v2.0                                                      */
5882
    POWERPC_DEF("755v2.0",     CPU_POWERPC_7x5_v20,     7x5),
5883
    /* PowerPC 745 v2.1                                                      */
5884
    POWERPC_DEF("745v2.1",     CPU_POWERPC_7x5_v21,     7x5),
5885
    /* PowerPC 755 v2.1                                                      */
5886
    POWERPC_DEF("755v2.1",     CPU_POWERPC_7x5_v21,     7x5),
5887
    /* PowerPC 745 v2.2                                                      */
5888
    POWERPC_DEF("745v2.2",     CPU_POWERPC_7x5_v22,     7x5),
5889
    /* PowerPC 755 v2.2                                                      */
5890
    POWERPC_DEF("755v2.2",     CPU_POWERPC_7x5_v22,     7x5),
5891
    /* PowerPC 745 v2.3                                                      */
5892
    POWERPC_DEF("745v2.3",     CPU_POWERPC_7x5_v23,     7x5),
5893
    /* PowerPC 755 v2.3                                                      */
5894
    POWERPC_DEF("755v2.3",     CPU_POWERPC_7x5_v23,     7x5),
5895
    /* PowerPC 745 v2.4                                                      */
5896
    POWERPC_DEF("745v2.4",     CPU_POWERPC_7x5_v24,     7x5),
5897
    /* PowerPC 755 v2.4                                                      */
5898
    POWERPC_DEF("755v2.4",     CPU_POWERPC_7x5_v24,     7x5),
5899
    /* PowerPC 745 v2.5                                                      */
5900
    POWERPC_DEF("745v2.5",     CPU_POWERPC_7x5_v25,     7x5),
5901
    /* PowerPC 755 v2.5                                                      */
5902
    POWERPC_DEF("755v2.5",     CPU_POWERPC_7x5_v25,     7x5),
5903
    /* PowerPC 745 v2.6                                                      */
5904
    POWERPC_DEF("745v2.6",     CPU_POWERPC_7x5_v26,     7x5),
5905
    /* PowerPC 755 v2.6                                                      */
5906
    POWERPC_DEF("755v2.6",     CPU_POWERPC_7x5_v26,     7x5),
5907
    /* PowerPC 745 v2.7                                                      */
5908
    POWERPC_DEF("745v2.7",     CPU_POWERPC_7x5_v27,     7x5),
5909
    /* PowerPC 755 v2.7                                                      */
5910
    POWERPC_DEF("755v2.7",     CPU_POWERPC_7x5_v27,     7x5),
5911
    /* PowerPC 745 v2.8                                                      */
5912
    POWERPC_DEF("745v2.8",     CPU_POWERPC_7x5_v28,     7x5),
5913
    /* PowerPC 755 v2.8                                                      */
5914
    POWERPC_DEF("755v2.8",     CPU_POWERPC_7x5_v28,     7x5),
5915
#if defined (TODO)
5916
    /* PowerPC 745P (G3)                                                     */
5917
    POWERPC_DEF("745p",        CPU_POWERPC_7x5P,        7x5),
5918
    /* PowerPC 755P (G3)                                                     */
5919
    POWERPC_DEF("755p",        CPU_POWERPC_7x5P,        7x5),
5920
#endif
5921
    /* PowerPC 74xx family                                                   */
5922
    /* PowerPC 7400 (G4)                                                     */
5923
    POWERPC_DEF("7400",        CPU_POWERPC_7400,        7400),
5924
    /* Code name for PowerPC 7400                                            */
5925
    POWERPC_DEF("Max",         CPU_POWERPC_7400,        7400),
5926
    /* PowerPC 74xx is also well known as G4                                 */
5927
    POWERPC_DEF("G4",          CPU_POWERPC_7400,        7400),
5928
    /* PowerPC 7400 v1.0 (G4)                                                */
5929
    POWERPC_DEF("7400v1.0",    CPU_POWERPC_7400_v10,    7400),
5930
    /* PowerPC 7400 v1.1 (G4)                                                */
5931
    POWERPC_DEF("7400v1.1",    CPU_POWERPC_7400_v11,    7400),
5932
    /* PowerPC 7400 v2.0 (G4)                                                */
5933
    POWERPC_DEF("7400v2.0",    CPU_POWERPC_7400_v20,    7400),
5934
    /* PowerPC 7400 v2.2 (G4)                                                */
5935
    POWERPC_DEF("7400v2.2",    CPU_POWERPC_7400_v22,    7400),
5936
    /* PowerPC 7400 v2.6 (G4)                                                */
5937
    POWERPC_DEF("7400v2.6",    CPU_POWERPC_7400_v26,    7400),
5938
    /* PowerPC 7400 v2.7 (G4)                                                */
5939
    POWERPC_DEF("7400v2.7",    CPU_POWERPC_7400_v27,    7400),
5940
    /* PowerPC 7400 v2.8 (G4)                                                */
5941
    POWERPC_DEF("7400v2.8",    CPU_POWERPC_7400_v28,    7400),
5942
    /* PowerPC 7400 v2.9 (G4)                                                */
5943
    POWERPC_DEF("7400v2.9",    CPU_POWERPC_7400_v29,    7400),
5944
    /* PowerPC 7410 (G4)                                                     */
5945
    POWERPC_DEF("7410",        CPU_POWERPC_7410,        7410),
5946
    /* Code name for PowerPC 7410                                            */
5947
    POWERPC_DEF("Nitro",       CPU_POWERPC_7410,        7410),
5948
    /* PowerPC 7410 v1.0 (G4)                                                */
5949
    POWERPC_DEF("7410v1.0",    CPU_POWERPC_7410_v10,    7410),
5950
    /* PowerPC 7410 v1.1 (G4)                                                */
5951
    POWERPC_DEF("7410v1.1",    CPU_POWERPC_7410_v11,    7410),
5952
    /* PowerPC 7410 v1.2 (G4)                                                */
5953
    POWERPC_DEF("7410v1.2",    CPU_POWERPC_7410_v12,    7410),
5954
    /* PowerPC 7410 v1.3 (G4)                                                */
5955
    POWERPC_DEF("7410v1.3",    CPU_POWERPC_7410_v13,    7410),
5956
    /* PowerPC 7410 v1.4 (G4)                                                */
5957
    POWERPC_DEF("7410v1.4",    CPU_POWERPC_7410_v14,    7410),
5958
    /* PowerPC 7448 (G4)                                                     */
5959
    POWERPC_DEF("7448",        CPU_POWERPC_7448,        7400),
5960
    /* PowerPC 7448 v1.0 (G4)                                                */
5961
    POWERPC_DEF("7448v1.0",    CPU_POWERPC_7448_v10,    7400),
5962
    /* PowerPC 7448 v1.1 (G4)                                                */
5963
    POWERPC_DEF("7448v1.1",    CPU_POWERPC_7448_v11,    7400),
5964
    /* PowerPC 7448 v2.0 (G4)                                                */
5965
    POWERPC_DEF("7448v2.0",    CPU_POWERPC_7448_v20,    7400),
5966
    /* PowerPC 7448 v2.1 (G4)                                                */
5967
    POWERPC_DEF("7448v2.1",    CPU_POWERPC_7448_v21,    7400),
5968
    /* PowerPC 7450 (G4)                                                     */
5969
    POWERPC_DEF("7450",        CPU_POWERPC_7450,        7450),
5970
    /* Code name for PowerPC 7450                                            */
5971
    POWERPC_DEF("Vger",        CPU_POWERPC_7450,        7450),
5972
    /* PowerPC 7450 v1.0 (G4)                                                */
5973
    POWERPC_DEF("7450v1.0",    CPU_POWERPC_7450_v10,    7450),
5974
    /* PowerPC 7450 v1.1 (G4)                                                */
5975
    POWERPC_DEF("7450v1.1",    CPU_POWERPC_7450_v11,    7450),
5976
    /* PowerPC 7450 v1.2 (G4)                                                */
5977
    POWERPC_DEF("7450v1.2",    CPU_POWERPC_7450_v12,    7450),
5978
    /* PowerPC 7450 v2.0 (G4)                                                */
5979
    POWERPC_DEF("7450v2.0",    CPU_POWERPC_7450_v20,    7450),
5980
    /* PowerPC 7450 v2.1 (G4)                                                */
5981
    POWERPC_DEF("7450v2.1",    CPU_POWERPC_7450_v21,    7450),
5982
    /* PowerPC 7441 (G4)                                                     */
5983
    POWERPC_DEF("7441",        CPU_POWERPC_74x1,        7440),
5984
    /* PowerPC 7451 (G4)                                                     */
5985
    POWERPC_DEF("7451",        CPU_POWERPC_74x1,        7450),
5986
    /* PowerPC 7441g (G4)                                                    */
5987
    POWERPC_DEF("7441g",       CPU_POWERPC_74x1G,       7440),
5988
    /* PowerPC 7451g (G4)                                                    */
5989
    POWERPC_DEF("7451g",       CPU_POWERPC_74x1G,       7450),
5990
    /* PowerPC 7445 (G4)                                                     */
5991
    POWERPC_DEF("7445",        CPU_POWERPC_74x5,        7445),
5992
    /* PowerPC 7455 (G4)                                                     */
5993
    POWERPC_DEF("7455",        CPU_POWERPC_74x5,        7455),
5994
    /* Code name for PowerPC 7445/7455                                       */
5995
    POWERPC_DEF("Apollo6",     CPU_POWERPC_74x5,        7455),
5996
    /* PowerPC 7445 v1.0 (G4)                                                */
5997
    POWERPC_DEF("7445v1.0",    CPU_POWERPC_74x5_v10,    7445),
5998
    /* PowerPC 7455 v1.0 (G4)                                                */
5999
    POWERPC_DEF("7455v1.0",    CPU_POWERPC_74x5_v10,    7455),
6000
    /* PowerPC 7445 v2.1 (G4)                                                */
6001
    POWERPC_DEF("7445v2.1",    CPU_POWERPC_74x5_v21,    7445),
6002
    /* PowerPC 7455 v2.1 (G4)                                                */
6003
    POWERPC_DEF("7455v2.1",    CPU_POWERPC_74x5_v21,    7455),
6004
    /* PowerPC 7445 v3.2 (G4)                                                */
6005
    POWERPC_DEF("7445v3.2",    CPU_POWERPC_74x5_v32,    7445),
6006
    /* PowerPC 7455 v3.2 (G4)                                                */
6007
    POWERPC_DEF("7455v3.2",    CPU_POWERPC_74x5_v32,    7455),
6008
    /* PowerPC 7445 v3.3 (G4)                                                */
6009
    POWERPC_DEF("7445v3.3",    CPU_POWERPC_74x5_v33,    7445),
6010
    /* PowerPC 7455 v3.3 (G4)                                                */
6011
    POWERPC_DEF("7455v3.3",    CPU_POWERPC_74x5_v33,    7455),
6012
    /* PowerPC 7445 v3.4 (G4)                                                */
6013
    POWERPC_DEF("7445v3.4",    CPU_POWERPC_74x5_v34,    7445),
6014
    /* PowerPC 7455 v3.4 (G4)                                                */
6015
    POWERPC_DEF("7455v3.4",    CPU_POWERPC_74x5_v34,    7455),
6016
    /* PowerPC 7447 (G4)                                                     */
6017
    POWERPC_DEF("7447",        CPU_POWERPC_74x7,        7445),
6018
    /* PowerPC 7457 (G4)                                                     */
6019
    POWERPC_DEF("7457",        CPU_POWERPC_74x7,        7455),
6020
    /* Code name for PowerPC 7447/7457                                       */
6021
    POWERPC_DEF("Apollo7",     CPU_POWERPC_74x7,        7455),
6022
    /* PowerPC 7447 v1.0 (G4)                                                */
6023
    POWERPC_DEF("7447v1.0",    CPU_POWERPC_74x7_v10,    7445),
6024
    /* PowerPC 7457 v1.0 (G4)                                                */
6025
    POWERPC_DEF("7457v1.0",    CPU_POWERPC_74x7_v10,    7455),
6026
    /* Code name for PowerPC 7447A/7457A                                     */
6027
    POWERPC_DEF("Apollo7PM",   CPU_POWERPC_74x7_v10,    7455),
6028
    /* PowerPC 7447 v1.1 (G4)                                                */
6029
    POWERPC_DEF("7447v1.1",    CPU_POWERPC_74x7_v11,    7445),
6030
    /* PowerPC 7457 v1.1 (G4)                                                */
6031
    POWERPC_DEF("7457v1.1",    CPU_POWERPC_74x7_v11,    7455),
6032
    /* PowerPC 7447 v1.2 (G4)                                                */
6033
    POWERPC_DEF("7447v1.2",    CPU_POWERPC_74x7_v12,    7445),
6034
    /* PowerPC 7457 v1.2 (G4)                                                */
6035
    POWERPC_DEF("7457v1.2",    CPU_POWERPC_74x7_v12,    7455),
6036
    /* 64 bits PowerPC                                                       */
6037
#if defined (TARGET_PPC64)
6038
    /* PowerPC 620                                                           */
6039
    /* XXX: code name "Trident" */
6040
    POWERPC_DEF("620",         CPU_POWERPC_620,         620),
6041
#if defined (TODO)
6042
    /* PowerPC 630 (POWER3)                                                  */
6043
    /* XXX: code names: "Boxer" "Dino" */
6044
    POWERPC_DEF("630",         CPU_POWERPC_630,         630),
6045
    POWERPC_DEF("POWER3",      CPU_POWERPC_630,         630),
6046
#endif
6047
#if defined (TODO)
6048
    /* PowerPC 631 (Power 3+)                                                */
6049
    POWERPC_DEF("631",         CPU_POWERPC_631,         631),
6050
    POWERPC_DEF("POWER3+",     CPU_POWERPC_631,         631),
6051
#endif
6052
#if defined (TODO)
6053
    /* POWER4                                                                */
6054
    POWERPC_DEF("POWER4",      CPU_POWERPC_POWER4,      POWER4),
6055
#endif
6056
#if defined (TODO)
6057
    /* POWER4p                                                               */
6058
    POWERPC_DEF("POWER4+",     CPU_POWERPC_POWER4P,     POWER4P),
6059
#endif
6060
#if defined (TODO)
6061
    /* POWER5                                                                */
6062
    POWERPC_DEF("POWER5",      CPU_POWERPC_POWER5,      POWER5),
6063
    /* POWER5GR                                                              */
6064
    POWERPC_DEF("POWER5gr",    CPU_POWERPC_POWER5GR,    POWER5),
6065
#endif
6066
#if defined (TODO)
6067
    /* POWER5+                                                               */
6068
    POWERPC_DEF("POWER5+",     CPU_POWERPC_POWER5P,     POWER5P),
6069
    /* POWER5GS                                                              */
6070
    POWERPC_DEF("POWER5gs",    CPU_POWERPC_POWER5GS,    POWER5P),
6071
#endif
6072
#if defined (TODO)
6073
    /* POWER6                                                                */
6074
    POWERPC_DEF("POWER6",      CPU_POWERPC_POWER6,      POWER6),
6075
    /* POWER6 running in POWER5 mode                                         */
6076
    POWERPC_DEF("POWER6_5",    CPU_POWERPC_POWER6_5,    POWER5),
6077
    /* POWER6A                                                               */
6078
    POWERPC_DEF("POWER6A",     CPU_POWERPC_POWER6A,     POWER6),
6079
#endif
6080
    /* PowerPC 970                                                           */
6081
    POWERPC_DEF("970",         CPU_POWERPC_970,         970),
6082
    /* PowerPC 970FX (G5)                                                    */
6083
    POWERPC_DEF("970fx",       CPU_POWERPC_970FX,       970FX),
6084
    /* PowerPC 970FX v1.0 (G5)                                               */
6085
    POWERPC_DEF("970fx1.0",    CPU_POWERPC_970FX_v10,   970FX),
6086
    /* PowerPC 970FX v2.0 (G5)                                               */
6087
    POWERPC_DEF("970fx2.0",    CPU_POWERPC_970FX_v20,   970FX),
6088
    /* PowerPC 970FX v2.1 (G5)                                               */
6089
    POWERPC_DEF("970fx2.1",    CPU_POWERPC_970FX_v21,   970FX),
6090
    /* PowerPC 970FX v3.0 (G5)                                               */
6091
    POWERPC_DEF("970fx3.0",    CPU_POWERPC_970FX_v30,   970FX),
6092
    /* PowerPC 970FX v3.1 (G5)                                               */
6093
    POWERPC_DEF("970fx3.1",    CPU_POWERPC_970FX_v31,   970FX),
6094
    /* PowerPC 970GX (G5)                                                    */
6095
    POWERPC_DEF("970gx",       CPU_POWERPC_970GX,       970GX),
6096
    /* PowerPC 970MP                                                         */
6097
    POWERPC_DEF("970mp",       CPU_POWERPC_970MP,       970MP),
6098
    /* PowerPC 970MP v1.0                                                    */
6099
    POWERPC_DEF("970mp1.0",    CPU_POWERPC_970MP_v10,   970MP),
6100
    /* PowerPC 970MP v1.1                                                    */
6101
    POWERPC_DEF("970mp1.1",    CPU_POWERPC_970MP_v11,   970MP),
6102
#if defined (TODO)
6103
    /* PowerPC Cell                                                          */
6104
    POWERPC_DEF("Cell",        CPU_POWERPC_CELL,        970),
6105
#endif
6106
#if defined (TODO)
6107
    /* PowerPC Cell v1.0                                                     */
6108
    POWERPC_DEF("Cell1.0",     CPU_POWERPC_CELL_v10,    970),
6109
#endif
6110
#if defined (TODO)
6111
    /* PowerPC Cell v2.0                                                     */
6112
    POWERPC_DEF("Cell2.0",     CPU_POWERPC_CELL_v20,    970),
6113
#endif
6114
#if defined (TODO)
6115
    /* PowerPC Cell v3.0                                                     */
6116
    POWERPC_DEF("Cell3.0",     CPU_POWERPC_CELL_v30,    970),
6117
#endif
6118
#if defined (TODO)
6119
    /* PowerPC Cell v3.1                                                     */
6120
    POWERPC_DEF("Cell3.1",     CPU_POWERPC_CELL_v31,    970),
6121
#endif
6122
#if defined (TODO)
6123
    /* PowerPC Cell v3.2                                                     */
6124
    POWERPC_DEF("Cell3.2",     CPU_POWERPC_CELL_v32,    970),
6125
#endif
6126
#if defined (TODO)
6127
    /* RS64 (Apache/A35)                                                     */
6128
    /* This one seems to support the whole POWER2 instruction set
6129
     * and the PowerPC 64 one.
6130
     */
6131
    /* What about A10 & A30 ? */
6132
    POWERPC_DEF("RS64",        CPU_POWERPC_RS64,        RS64),
6133
    POWERPC_DEF("Apache",      CPU_POWERPC_RS64,        RS64),
6134
    POWERPC_DEF("A35",         CPU_POWERPC_RS64,        RS64),
6135
#endif
6136
#if defined (TODO)
6137
    /* RS64-II (NorthStar/A50)                                               */
6138
    POWERPC_DEF("RS64-II",     CPU_POWERPC_RS64II,      RS64),
6139
    POWERPC_DEF("NorthStar",   CPU_POWERPC_RS64II,      RS64),
6140
    POWERPC_DEF("A50",         CPU_POWERPC_RS64II,      RS64),
6141
#endif
6142
#if defined (TODO)
6143
    /* RS64-III (Pulsar)                                                     */
6144
    POWERPC_DEF("RS64-III",    CPU_POWERPC_RS64III,     RS64),
6145
    POWERPC_DEF("Pulsar",      CPU_POWERPC_RS64III,     RS64),
6146
#endif
6147
#if defined (TODO)
6148
    /* RS64-IV (IceStar/IStar/SStar)                                         */
6149
    POWERPC_DEF("RS64-IV",     CPU_POWERPC_RS64IV,      RS64),
6150
    POWERPC_DEF("IceStar",     CPU_POWERPC_RS64IV,      RS64),
6151
    POWERPC_DEF("IStar",       CPU_POWERPC_RS64IV,      RS64),
6152
    POWERPC_DEF("SStar",       CPU_POWERPC_RS64IV,      RS64),
6153
#endif
6154
#endif /* defined (TARGET_PPC64) */
6155
    /* POWER                                                                 */
6156
#if defined (TODO)
6157
    /* Original POWER                                                        */
6158
    POWERPC_DEF("POWER",       CPU_POWERPC_POWER,       POWER),
6159
    POWERPC_DEF("RIOS",        CPU_POWERPC_POWER,       POWER),
6160
    POWERPC_DEF("RSC",         CPU_POWERPC_POWER,       POWER),
6161
    POWERPC_DEF("RSC3308",     CPU_POWERPC_POWER,       POWER),
6162
    POWERPC_DEF("RSC4608",     CPU_POWERPC_POWER,       POWER),
6163
#endif
6164
#if defined (TODO)
6165
    /* POWER2                                                                */
6166
    POWERPC_DEF("POWER2",      CPU_POWERPC_POWER2,      POWER),
6167
    POWERPC_DEF("RSC2",        CPU_POWERPC_POWER2,      POWER),
6168
    POWERPC_DEF("P2SC",        CPU_POWERPC_POWER2,      POWER),
6169
#endif
6170
    /* PA semi cores                                                         */
6171
#if defined (TODO)
6172
    /* PA PA6T */
6173
    POWERPC_DEF("PA6T",        CPU_POWERPC_PA6T,        PA6T),
6174
#endif
6175
    /* Generic PowerPCs                                                      */
6176
#if defined (TARGET_PPC64)
6177
#if defined (TODO)
6178
    POWERPC_DEF("ppc64",       CPU_POWERPC_PPC64,       PPC64),
6179
#endif
6180
#endif
6181
    POWERPC_DEF("ppc32",       CPU_POWERPC_PPC32,       PPC32),
6182
    POWERPC_DEF("ppc",         CPU_POWERPC_DEFAULT,     DEFAULT),
6183
    /* Fallback                                                              */
6184
    POWERPC_DEF("default",     CPU_POWERPC_DEFAULT,     DEFAULT),
6185
};
6186

    
6187
/*****************************************************************************/
6188
/* Generic CPU instanciation routine                                         */
6189
static void init_ppc_proc (CPUPPCState *env, const ppc_def_t *def)
6190
{
6191
#if !defined(CONFIG_USER_ONLY)
6192
    int i;
6193

    
6194
    env->irq_inputs = NULL;
6195
    /* Set all exception vectors to an invalid address */
6196
    for (i = 0; i < POWERPC_EXCP_NB; i++)
6197
        env->excp_vectors[i] = (target_ulong)(-1ULL);
6198
    env->excp_prefix = 0x00000000;
6199
    env->ivor_mask = 0x00000000;
6200
    env->ivpr_mask = 0x00000000;
6201
    /* Default MMU definitions */
6202
    env->nb_BATs = 0;
6203
    env->nb_tlb = 0;
6204
    env->nb_ways = 0;
6205
#endif
6206
    /* Register SPR common to all PowerPC implementations */
6207
    gen_spr_generic(env);
6208
    spr_register(env, SPR_PVR, "PVR",
6209
                 SPR_NOACCESS, SPR_NOACCESS,
6210
                 &spr_read_generic, SPR_NOACCESS,
6211
                 def->pvr);
6212
    /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
6213
    (*def->init_proc)(env);
6214
    /* MSR bits & flags consistency checks */
6215
    if (env->msr_mask & (1 << 25)) {
6216
        switch (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
6217
        case POWERPC_FLAG_SPE:
6218
        case POWERPC_FLAG_VRE:
6219
            break;
6220
        default:
6221
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6222
                    "Should define POWERPC_FLAG_SPE or POWERPC_FLAG_VRE\n");
6223
            exit(1);
6224
        }
6225
    } else if (env->flags & (POWERPC_FLAG_SPE | POWERPC_FLAG_VRE)) {
6226
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6227
                "Should not define POWERPC_FLAG_SPE nor POWERPC_FLAG_VRE\n");
6228
        exit(1);
6229
    }
6230
    if (env->msr_mask & (1 << 17)) {
6231
        switch (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
6232
        case POWERPC_FLAG_TGPR:
6233
        case POWERPC_FLAG_CE:
6234
            break;
6235
        default:
6236
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6237
                    "Should define POWERPC_FLAG_TGPR or POWERPC_FLAG_CE\n");
6238
            exit(1);
6239
        }
6240
    } else if (env->flags & (POWERPC_FLAG_TGPR | POWERPC_FLAG_CE)) {
6241
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6242
                "Should not define POWERPC_FLAG_TGPR nor POWERPC_FLAG_CE\n");
6243
        exit(1);
6244
    }
6245
    if (env->msr_mask & (1 << 10)) {
6246
        switch (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
6247
                              POWERPC_FLAG_UBLE)) {
6248
        case POWERPC_FLAG_SE:
6249
        case POWERPC_FLAG_DWE:
6250
        case POWERPC_FLAG_UBLE:
6251
            break;
6252
        default:
6253
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6254
                    "Should define POWERPC_FLAG_SE or POWERPC_FLAG_DWE or "
6255
                    "POWERPC_FLAG_UBLE\n");
6256
            exit(1);
6257
        }
6258
    } else if (env->flags & (POWERPC_FLAG_SE | POWERPC_FLAG_DWE |
6259
                             POWERPC_FLAG_UBLE)) {
6260
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6261
                "Should not define POWERPC_FLAG_SE nor POWERPC_FLAG_DWE nor "
6262
                "POWERPC_FLAG_UBLE\n");
6263
            exit(1);
6264
    }
6265
    if (env->msr_mask & (1 << 9)) {
6266
        switch (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
6267
        case POWERPC_FLAG_BE:
6268
        case POWERPC_FLAG_DE:
6269
            break;
6270
        default:
6271
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6272
                    "Should define POWERPC_FLAG_BE or POWERPC_FLAG_DE\n");
6273
            exit(1);
6274
        }
6275
    } else if (env->flags & (POWERPC_FLAG_BE | POWERPC_FLAG_DE)) {
6276
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6277
                "Should not define POWERPC_FLAG_BE nor POWERPC_FLAG_DE\n");
6278
        exit(1);
6279
    }
6280
    if (env->msr_mask & (1 << 2)) {
6281
        switch (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
6282
        case POWERPC_FLAG_PX:
6283
        case POWERPC_FLAG_PMM:
6284
            break;
6285
        default:
6286
            fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6287
                    "Should define POWERPC_FLAG_PX or POWERPC_FLAG_PMM\n");
6288
            exit(1);
6289
        }
6290
    } else if (env->flags & (POWERPC_FLAG_PX | POWERPC_FLAG_PMM)) {
6291
        fprintf(stderr, "PowerPC MSR definition inconsistency\n"
6292
                "Should not define POWERPC_FLAG_PX nor POWERPC_FLAG_PMM\n");
6293
        exit(1);
6294
    }
6295
    /* Allocate TLBs buffer when needed */
6296
#if !defined(CONFIG_USER_ONLY)
6297
    if (env->nb_tlb != 0) {
6298
        int nb_tlb = env->nb_tlb;
6299
        if (env->id_tlbs != 0)
6300
            nb_tlb *= 2;
6301
        env->tlb = qemu_mallocz(nb_tlb * sizeof(ppc_tlb_t));
6302
        /* Pre-compute some useful values */
6303
        env->tlb_per_way = env->nb_tlb / env->nb_ways;
6304
    }
6305
    if (env->irq_inputs == NULL) {
6306
        fprintf(stderr, "WARNING: no internal IRQ controller registered.\n"
6307
                " Attempt Qemu to crash very soon !\n");
6308
    }
6309
#endif
6310
    if (env->check_pow == NULL) {
6311
        fprintf(stderr, "WARNING: no power management check handler "
6312
                "registered.\n"
6313
                " Attempt Qemu to crash very soon !\n");
6314
    }
6315
}
6316

    
6317
#if defined(PPC_DUMP_CPU)
6318
static void dump_ppc_sprs (CPUPPCState *env)
6319
{
6320
    ppc_spr_t *spr;
6321
#if !defined(CONFIG_USER_ONLY)
6322
    uint32_t sr, sw;
6323
#endif
6324
    uint32_t ur, uw;
6325
    int i, j, n;
6326

    
6327
    printf("Special purpose registers:\n");
6328
    for (i = 0; i < 32; i++) {
6329
        for (j = 0; j < 32; j++) {
6330
            n = (i << 5) | j;
6331
            spr = &env->spr_cb[n];
6332
            uw = spr->uea_write != NULL && spr->uea_write != SPR_NOACCESS;
6333
            ur = spr->uea_read != NULL && spr->uea_read != SPR_NOACCESS;
6334
#if !defined(CONFIG_USER_ONLY)
6335
            sw = spr->oea_write != NULL && spr->oea_write != SPR_NOACCESS;
6336
            sr = spr->oea_read != NULL && spr->oea_read != SPR_NOACCESS;
6337
            if (sw || sr || uw || ur) {
6338
                printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
6339
                       (i << 5) | j, (i << 5) | j, spr->name,
6340
                       sw ? 'w' : '-', sr ? 'r' : '-',
6341
                       uw ? 'w' : '-', ur ? 'r' : '-');
6342
            }
6343
#else
6344
            if (uw || ur) {
6345
                printf("SPR: %4d (%03x) %-8s u%c%c\n",
6346
                       (i << 5) | j, (i << 5) | j, spr->name,
6347
                       uw ? 'w' : '-', ur ? 'r' : '-');
6348
            }
6349
#endif
6350
        }
6351
    }
6352
    fflush(stdout);
6353
    fflush(stderr);
6354
}
6355
#endif
6356

    
6357
/*****************************************************************************/
6358
#include <stdlib.h>
6359
#include <string.h>
6360

    
6361
int fflush (FILE *stream);
6362

    
6363
/* Opcode types */
6364
enum {
6365
    PPC_DIRECT   = 0, /* Opcode routine        */
6366
    PPC_INDIRECT = 1, /* Indirect opcode table */
6367
};
6368

    
6369
static inline int is_indirect_opcode (void *handler)
6370
{
6371
    return ((unsigned long)handler & 0x03) == PPC_INDIRECT;
6372
}
6373

    
6374
static inline opc_handler_t **ind_table(void *handler)
6375
{
6376
    return (opc_handler_t **)((unsigned long)handler & ~3);
6377
}
6378

    
6379
/* Instruction table creation */
6380
/* Opcodes tables creation */
6381
static void fill_new_table (opc_handler_t **table, int len)
6382
{
6383
    int i;
6384

    
6385
    for (i = 0; i < len; i++)
6386
        table[i] = &invalid_handler;
6387
}
6388

    
6389
static int create_new_table (opc_handler_t **table, unsigned char idx)
6390
{
6391
    opc_handler_t **tmp;
6392

    
6393
    tmp = malloc(0x20 * sizeof(opc_handler_t));
6394
    if (tmp == NULL)
6395
        return -1;
6396
    fill_new_table(tmp, 0x20);
6397
    table[idx] = (opc_handler_t *)((unsigned long)tmp | PPC_INDIRECT);
6398

    
6399
    return 0;
6400
}
6401

    
6402
static int insert_in_table (opc_handler_t **table, unsigned char idx,
6403
                            opc_handler_t *handler)
6404
{
6405
    if (table[idx] != &invalid_handler)
6406
        return -1;
6407
    table[idx] = handler;
6408

    
6409
    return 0;
6410
}
6411

    
6412
static int register_direct_insn (opc_handler_t **ppc_opcodes,
6413
                                 unsigned char idx, opc_handler_t *handler)
6414
{
6415
    if (insert_in_table(ppc_opcodes, idx, handler) < 0) {
6416
        printf("*** ERROR: opcode %02x already assigned in main "
6417
               "opcode table\n", idx);
6418
        return -1;
6419
    }
6420

    
6421
    return 0;
6422
}
6423

    
6424
static int register_ind_in_table (opc_handler_t **table,
6425
                                  unsigned char idx1, unsigned char idx2,
6426
                                  opc_handler_t *handler)
6427
{
6428
    if (table[idx1] == &invalid_handler) {
6429
        if (create_new_table(table, idx1) < 0) {
6430
            printf("*** ERROR: unable to create indirect table "
6431
                   "idx=%02x\n", idx1);
6432
            return -1;
6433
        }
6434
    } else {
6435
        if (!is_indirect_opcode(table[idx1])) {
6436
            printf("*** ERROR: idx %02x already assigned to a direct "
6437
                   "opcode\n", idx1);
6438
            return -1;
6439
        }
6440
    }
6441
    if (handler != NULL &&
6442
        insert_in_table(ind_table(table[idx1]), idx2, handler) < 0) {
6443
        printf("*** ERROR: opcode %02x already assigned in "
6444
               "opcode table %02x\n", idx2, idx1);
6445
        return -1;
6446
    }
6447

    
6448
    return 0;
6449
}
6450

    
6451
static int register_ind_insn (opc_handler_t **ppc_opcodes,
6452
                              unsigned char idx1, unsigned char idx2,
6453
                              opc_handler_t *handler)
6454
{
6455
    int ret;
6456

    
6457
    ret = register_ind_in_table(ppc_opcodes, idx1, idx2, handler);
6458

    
6459
    return ret;
6460
}
6461

    
6462
static int register_dblind_insn (opc_handler_t **ppc_opcodes,
6463
                                 unsigned char idx1, unsigned char idx2,
6464
                                 unsigned char idx3, opc_handler_t *handler)
6465
{
6466
    if (register_ind_in_table(ppc_opcodes, idx1, idx2, NULL) < 0) {
6467
        printf("*** ERROR: unable to join indirect table idx "
6468
               "[%02x-%02x]\n", idx1, idx2);
6469
        return -1;
6470
    }
6471
    if (register_ind_in_table(ind_table(ppc_opcodes[idx1]), idx2, idx3,
6472
                              handler) < 0) {
6473
        printf("*** ERROR: unable to insert opcode "
6474
               "[%02x-%02x-%02x]\n", idx1, idx2, idx3);
6475
        return -1;
6476
    }
6477

    
6478
    return 0;
6479
}
6480

    
6481
static int register_insn (opc_handler_t **ppc_opcodes, opcode_t *insn)
6482
{
6483
    if (insn->opc2 != 0xFF) {
6484
        if (insn->opc3 != 0xFF) {
6485
            if (register_dblind_insn(ppc_opcodes, insn->opc1, insn->opc2,
6486
                                     insn->opc3, &insn->handler) < 0)
6487
                return -1;
6488
        } else {
6489
            if (register_ind_insn(ppc_opcodes, insn->opc1,
6490
                                  insn->opc2, &insn->handler) < 0)
6491
                return -1;
6492
        }
6493
    } else {
6494
        if (register_direct_insn(ppc_opcodes, insn->opc1, &insn->handler) < 0)
6495
            return -1;
6496
    }
6497

    
6498
    return 0;
6499
}
6500

    
6501
static int test_opcode_table (opc_handler_t **table, int len)
6502
{
6503
    int i, count, tmp;
6504

    
6505
    for (i = 0, count = 0; i < len; i++) {
6506
        /* Consistency fixup */
6507
        if (table[i] == NULL)
6508
            table[i] = &invalid_handler;
6509
        if (table[i] != &invalid_handler) {
6510
            if (is_indirect_opcode(table[i])) {
6511
                tmp = test_opcode_table(ind_table(table[i]), 0x20);
6512
                if (tmp == 0) {
6513
                    free(table[i]);
6514
                    table[i] = &invalid_handler;
6515
                } else {
6516
                    count++;
6517
                }
6518
            } else {
6519
                count++;
6520
            }
6521
        }
6522
    }
6523

    
6524
    return count;
6525
}
6526

    
6527
static void fix_opcode_tables (opc_handler_t **ppc_opcodes)
6528
{
6529
    if (test_opcode_table(ppc_opcodes, 0x40) == 0)
6530
        printf("*** WARNING: no opcode defined !\n");
6531
}
6532

    
6533
/*****************************************************************************/
6534
static int create_ppc_opcodes (CPUPPCState *env, const ppc_def_t *def)
6535
{
6536
    opcode_t *opc, *start, *end;
6537

    
6538
    fill_new_table(env->opcodes, 0x40);
6539
    if (&opc_start < &opc_end) {
6540
        start = &opc_start;
6541
        end = &opc_end;
6542
    } else {
6543
        start = &opc_end;
6544
        end = &opc_start;
6545
    }
6546
    for (opc = start + 1; opc != end; opc++) {
6547
        if ((opc->handler.type & def->insns_flags) != 0) {
6548
            if (register_insn(env->opcodes, opc) < 0) {
6549
                printf("*** ERROR initializing PowerPC instruction "
6550
                       "0x%02x 0x%02x 0x%02x\n", opc->opc1, opc->opc2,
6551
                       opc->opc3);
6552
                return -1;
6553
            }
6554
        }
6555
    }
6556
    fix_opcode_tables(env->opcodes);
6557
    fflush(stdout);
6558
    fflush(stderr);
6559

    
6560
    return 0;
6561
}
6562

    
6563
#if defined(PPC_DUMP_CPU)
6564
static void dump_ppc_insns (CPUPPCState *env)
6565
{
6566
    opc_handler_t **table, *handler;
6567
    uint8_t opc1, opc2, opc3;
6568

    
6569
    printf("Instructions set:\n");
6570
    /* opc1 is 6 bits long */
6571
    for (opc1 = 0x00; opc1 < 0x40; opc1++) {
6572
        table = env->opcodes;
6573
        handler = table[opc1];
6574
        if (is_indirect_opcode(handler)) {
6575
            /* opc2 is 5 bits long */
6576
            for (opc2 = 0; opc2 < 0x20; opc2++) {
6577
                table = env->opcodes;
6578
                handler = env->opcodes[opc1];
6579
                table = ind_table(handler);
6580
                handler = table[opc2];
6581
                if (is_indirect_opcode(handler)) {
6582
                    table = ind_table(handler);
6583
                    /* opc3 is 5 bits long */
6584
                    for (opc3 = 0; opc3 < 0x20; opc3++) {
6585
                        handler = table[opc3];
6586
                        if (handler->handler != &gen_invalid) {
6587
                            printf("INSN: %02x %02x %02x (%02d %04d) : %s\n",
6588
                                   opc1, opc2, opc3, opc1, (opc3 << 5) | opc2,
6589
                                   handler->oname);
6590
                        }
6591
                    }
6592
                } else {
6593
                    if (handler->handler != &gen_invalid) {
6594
                        printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
6595
                               opc1, opc2, opc1, opc2, handler->oname);
6596
                    }
6597
                }
6598
            }
6599
        } else {
6600
            if (handler->handler != &gen_invalid) {
6601
                printf("INSN: %02x -- -- (%02d ----) : %s\n",
6602
                       opc1, opc1, handler->oname);
6603
            }
6604
        }
6605
    }
6606
}
6607
#endif
6608

    
6609
int cpu_ppc_register_internal (CPUPPCState *env, const ppc_def_t *def)
6610
{
6611
    env->msr_mask = def->msr_mask;
6612
    env->mmu_model = def->mmu_model;
6613
    env->excp_model = def->excp_model;
6614
    env->bus_model = def->bus_model;
6615
    env->flags = def->flags;
6616
    env->bfd_mach = def->bfd_mach;
6617
    env->check_pow = def->check_pow;
6618
    if (create_ppc_opcodes(env, def) < 0)
6619
        return -1;
6620
    init_ppc_proc(env, def);
6621
#if defined(PPC_DUMP_CPU)
6622
    {
6623
        const unsigned char *mmu_model, *excp_model, *bus_model;
6624
        switch (env->mmu_model) {
6625
        case POWERPC_MMU_32B:
6626
            mmu_model = "PowerPC 32";
6627
            break;
6628
        case POWERPC_MMU_SOFT_6xx:
6629
            mmu_model = "PowerPC 6xx/7xx with software driven TLBs";
6630
            break;
6631
        case POWERPC_MMU_SOFT_74xx:
6632
            mmu_model = "PowerPC 74xx with software driven TLBs";
6633
            break;
6634
        case POWERPC_MMU_SOFT_4xx:
6635
            mmu_model = "PowerPC 4xx with software driven TLBs";
6636
            break;
6637
        case POWERPC_MMU_SOFT_4xx_Z:
6638
            mmu_model = "PowerPC 4xx with software driven TLBs "
6639
                "and zones protections";
6640
            break;
6641
        case POWERPC_MMU_REAL_4xx:
6642
            mmu_model = "PowerPC 4xx real mode only";
6643
            break;
6644
        case POWERPC_MMU_BOOKE:
6645
            mmu_model = "PowerPC BookE";
6646
            break;
6647
        case POWERPC_MMU_BOOKE_FSL:
6648
            mmu_model = "PowerPC BookE FSL";
6649
            break;
6650
#if defined (TARGET_PPC64)
6651
        case POWERPC_MMU_64B:
6652
            mmu_model = "PowerPC 64";
6653
            break;
6654
#endif
6655
        default:
6656
            mmu_model = "Unknown or invalid";
6657
            break;
6658
        }
6659
        switch (env->excp_model) {
6660
        case POWERPC_EXCP_STD:
6661
            excp_model = "PowerPC";
6662
            break;
6663
        case POWERPC_EXCP_40x:
6664
            excp_model = "PowerPC 40x";
6665
            break;
6666
        case POWERPC_EXCP_601:
6667
            excp_model = "PowerPC 601";
6668
            break;
6669
        case POWERPC_EXCP_602:
6670
            excp_model = "PowerPC 602";
6671
            break;
6672
        case POWERPC_EXCP_603:
6673
            excp_model = "PowerPC 603";
6674
            break;
6675
        case POWERPC_EXCP_603E:
6676
            excp_model = "PowerPC 603e";
6677
            break;
6678
        case POWERPC_EXCP_604:
6679
            excp_model = "PowerPC 604";
6680
            break;
6681
        case POWERPC_EXCP_7x0:
6682
            excp_model = "PowerPC 740/750";
6683
            break;
6684
        case POWERPC_EXCP_7x5:
6685
            excp_model = "PowerPC 745/755";
6686
            break;
6687
        case POWERPC_EXCP_74xx:
6688
            excp_model = "PowerPC 74xx";
6689
            break;
6690
        case POWERPC_EXCP_BOOKE:
6691
            excp_model = "PowerPC BookE";
6692
            break;
6693
#if defined (TARGET_PPC64)
6694
        case POWERPC_EXCP_970:
6695
            excp_model = "PowerPC 970";
6696
            break;
6697
#endif
6698
        default:
6699
            excp_model = "Unknown or invalid";
6700
            break;
6701
        }
6702
        switch (env->bus_model) {
6703
        case PPC_FLAGS_INPUT_6xx:
6704
            bus_model = "PowerPC 6xx";
6705
            break;
6706
        case PPC_FLAGS_INPUT_BookE:
6707
            bus_model = "PowerPC BookE";
6708
            break;
6709
        case PPC_FLAGS_INPUT_405:
6710
            bus_model = "PowerPC 405";
6711
            break;
6712
        case PPC_FLAGS_INPUT_401:
6713
            bus_model = "PowerPC 401/403";
6714
            break;
6715
#if defined (TARGET_PPC64)
6716
        case PPC_FLAGS_INPUT_970:
6717
            bus_model = "PowerPC 970";
6718
            break;
6719
#endif
6720
        default:
6721
            bus_model = "Unknown or invalid";
6722
            break;
6723
        }
6724
        printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64 "\n"
6725
               "    MMU model        : %s\n",
6726
               def->name, def->pvr, def->msr_mask, mmu_model);
6727
#if !defined(CONFIG_USER_ONLY)
6728
        if (env->tlb != NULL) {
6729
            printf("                       %d %s TLB in %d ways\n",
6730
                   env->nb_tlb, env->id_tlbs ? "splitted" : "merged",
6731
                   env->nb_ways);
6732
        }
6733
#endif
6734
        printf("    Exceptions model : %s\n"
6735
               "    Bus model        : %s\n",
6736
               excp_model, bus_model);
6737
        printf("    MSR features     :\n");
6738
        if (env->flags & POWERPC_FLAG_SPE)
6739
            printf("                        signal processing engine enable"
6740
                   "\n");
6741
        else if (env->flags & POWERPC_FLAG_VRE)
6742
            printf("                        vector processor enable\n");
6743
        if (env->flags & POWERPC_FLAG_TGPR)
6744
            printf("                        temporary GPRs\n");
6745
        else if (env->flags & POWERPC_FLAG_CE)
6746
            printf("                        critical input enable\n");
6747
        if (env->flags & POWERPC_FLAG_SE)
6748
            printf("                        single-step trace mode\n");
6749
        else if (env->flags & POWERPC_FLAG_DWE)
6750
            printf("                        debug wait enable\n");
6751
        else if (env->flags & POWERPC_FLAG_UBLE)
6752
            printf("                        user BTB lock enable\n");
6753
        if (env->flags & POWERPC_FLAG_BE)
6754
            printf("                        branch-step trace mode\n");
6755
        else if (env->flags & POWERPC_FLAG_DE)
6756
            printf("                        debug interrupt enable\n");
6757
        if (env->flags & POWERPC_FLAG_PX)
6758
            printf("                        inclusive protection\n");
6759
        else if (env->flags & POWERPC_FLAG_PMM)
6760
            printf("                        performance monitor mark\n");
6761
        if (env->flags == POWERPC_FLAG_NONE)
6762
            printf("                        none\n");
6763
    }
6764
    dump_ppc_insns(env);
6765
    dump_ppc_sprs(env);
6766
    fflush(stdout);
6767
#endif
6768

    
6769
    return 0;
6770
}
6771

    
6772
static const ppc_def_t *ppc_find_by_pvr (uint32_t pvr)
6773
{
6774
    const ppc_def_t *ret;
6775
    uint32_t pvr_rev;
6776
    int i, best, match, best_match, max;
6777

    
6778
    ret = NULL;
6779
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6780
    best = -1;
6781
    pvr_rev = pvr & 0xFFFF;
6782
    /* We want all specified bits to match */
6783
    best_match = 32 - ctz32(pvr_rev);
6784
    for (i = 0; i < max; i++) {
6785
        /* We check that the 16 higher bits are the same to ensure the CPU
6786
         * model will be the choosen one.
6787
         */
6788
        if (((pvr ^ ppc_defs[i].pvr) >> 16) == 0) {
6789
            /* We want as much as possible of the low-level 16 bits
6790
             * to be the same but we allow inexact matches.
6791
             */
6792
            match = clz32(pvr_rev ^ (ppc_defs[i].pvr & 0xFFFF));
6793
            /* We check '>=' instead of '>' because the PPC_defs table
6794
             * is ordered by increasing revision.
6795
             * Then, we will match the higher revision compatible 
6796
             * with the requested PVR
6797
             */
6798
            if (match >= best_match) {
6799
                best = i;
6800
                best_match = match;
6801
            }
6802
        }
6803
    }
6804
    if (best != -1)
6805
        ret = &ppc_defs[best];
6806

    
6807
    return ret;
6808
}
6809

    
6810
#include <ctype.h>
6811

    
6812
const ppc_def_t *cpu_ppc_find_by_name (const unsigned char *name)
6813
{
6814
    const ppc_def_t *ret;
6815
    const unsigned char *p;
6816
    int i, max, len;
6817

    
6818
    /* Check if the given name is a PVR */
6819
    len = strlen(name);
6820
    if (len == 10 && name[0] == '0' && name[1] == 'x') {
6821
        p = name + 2;
6822
        goto check_pvr;
6823
    } else if (len == 8) {
6824
        p = name;
6825
    check_pvr:
6826
        for (i = 0; i < 8; i++) {
6827
            if (!isxdigit(*p++))
6828
                break;
6829
        }
6830
        if (i == 8)
6831
            return ppc_find_by_pvr(strtoul(name, NULL, 16));
6832
    }
6833
    ret = NULL;
6834
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6835
    for (i = 0; i < max; i++) {
6836
        if (strcasecmp(name, ppc_defs[i].name) == 0) {
6837
            ret = &ppc_defs[i];
6838
            break;
6839
        }
6840
    }
6841

    
6842
    return ret;
6843
}
6844

    
6845
void ppc_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...))
6846
{
6847
    int i, max;
6848

    
6849
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
6850
    for (i = 0; i < max; i++) {
6851
        (*cpu_fprintf)(f, "PowerPC %-16s PVR %08x\n",
6852
                       ppc_defs[i].name, ppc_defs[i].pvr);
6853
    }
6854
}