Statistics
| Branch: | Revision:

root / target-ppc / translate_init.c @ 6f5d427d

History | View | Annotate | Download (235.4 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

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

    
32
struct ppc_def_t {
33
    const unsigned char *name;
34
    uint32_t pvr;
35
    uint32_t pvr_mask;
36
    uint64_t insns_flags;
37
    uint64_t msr_mask;
38
    uint8_t mmu_model;
39
    uint8_t excp_model;
40
    uint8_t bus_model;
41
    uint8_t pad;
42
    int bfd_mach;
43
    void (*init_proc)(CPUPPCState *env);
44
};
45

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

    
57
PPC_IRQ_INIT_FN(40x);
58
PPC_IRQ_INIT_FN(6xx);
59
PPC_IRQ_INIT_FN(970);
60

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    
240
static void spr_read_dbat_h (void *opaque, int sprn)
241
{
242
    gen_op_load_dbat(sprn & 1, (sprn - SPR_DBAT4U) / 2);
243
}
244

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

    
250
static void spr_write_dbatu_h (void *opaque, int sprn)
251
{
252
    gen_op_store_dbatu((sprn - SPR_DBAT4U) / 2);
253
}
254

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

    
260
static void spr_write_dbatl_h (void *opaque, int sprn)
261
{
262
    gen_op_store_dbatl((sprn - SPR_DBAT4L) / 2);
263
}
264

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

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

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

285
static void spr_write_asr (void *opaque, int sprn)
286
{
287
    DisasContext *ctx = opaque;
288

289
    gen_op_store_asr();
290
}
291
#endif
292
#endif
293

    
294
/* PowerPC 601 specific registers */
295
/* RTC */
296
static void spr_read_601_rtcl (void *opaque, int sprn)
297
{
298
    gen_op_load_601_rtcl();
299
}
300

    
301
static void spr_read_601_rtcu (void *opaque, int sprn)
302
{
303
    gen_op_load_601_rtcu();
304
}
305

    
306
#if !defined(CONFIG_USER_ONLY)
307
static void spr_write_601_rtcu (void *opaque, int sprn)
308
{
309
    gen_op_store_601_rtcu();
310
}
311

    
312
static void spr_write_601_rtcl (void *opaque, int sprn)
313
{
314
    gen_op_store_601_rtcl();
315
}
316
#endif
317

    
318
/* Unified bats */
319
#if !defined(CONFIG_USER_ONLY)
320
static void spr_read_601_ubat (void *opaque, int sprn)
321
{
322
    gen_op_load_601_bat(sprn & 1, (sprn - SPR_IBAT0U) / 2);
323
}
324

    
325
static void spr_write_601_ubatu (void *opaque, int sprn)
326
{
327
    gen_op_store_601_batu((sprn - SPR_IBAT0U) / 2);
328
}
329

    
330
static void spr_write_601_ubatl (void *opaque, int sprn)
331
{
332
    gen_op_store_601_batl((sprn - SPR_IBAT0L) / 2);
333
}
334
#endif
335

    
336
/* PowerPC 40x specific registers */
337
#if !defined(CONFIG_USER_ONLY)
338
static void spr_read_40x_pit (void *opaque, int sprn)
339
{
340
    gen_op_load_40x_pit();
341
}
342

    
343
static void spr_write_40x_pit (void *opaque, int sprn)
344
{
345
    gen_op_store_40x_pit();
346
}
347

    
348
static void spr_write_40x_dbcr0 (void *opaque, int sprn)
349
{
350
    DisasContext *ctx = opaque;
351

    
352
    gen_op_store_40x_dbcr0();
353
    /* We must stop translation as we may have rebooted */
354
    GEN_STOP(ctx);
355
}
356

    
357
static void spr_write_40x_sler (void *opaque, int sprn)
358
{
359
    gen_op_store_40x_sler();
360
}
361

    
362
static void spr_write_booke_tcr (void *opaque, int sprn)
363
{
364
    gen_op_store_booke_tcr();
365
}
366

    
367
static void spr_write_booke_tsr (void *opaque, int sprn)
368
{
369
    gen_op_store_booke_tsr();
370
}
371
#endif
372

    
373
/* PowerPC 403 specific registers */
374
/* PBL1 / PBU1 / PBL2 / PBU2 */
375
#if !defined(CONFIG_USER_ONLY)
376
static void spr_read_403_pbr (void *opaque, int sprn)
377
{
378
    gen_op_load_403_pb(sprn - SPR_403_PBL1);
379
}
380

    
381
static void spr_write_403_pbr (void *opaque, int sprn)
382
{
383
    gen_op_store_403_pb(sprn - SPR_403_PBL1);
384
}
385

    
386
static void spr_write_pir (void *opaque, int sprn)
387
{
388
    gen_op_store_pir();
389
}
390
#endif
391

    
392
#if !defined(CONFIG_USER_ONLY)
393
/* Callback used to write the exception vector base */
394
static void spr_write_excp_prefix (void *opaque, int sprn)
395
{
396
    gen_op_store_excp_prefix();
397
    gen_op_store_spr(sprn);
398
}
399

    
400
static void spr_write_excp_vector (void *opaque, int sprn)
401
{
402
    DisasContext *ctx = opaque;
403

    
404
    if (sprn >= SPR_BOOKE_IVOR0 && sprn <= SPR_BOOKE_IVOR15) {
405
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR0);
406
        gen_op_store_spr(sprn);
407
    } else if (sprn >= SPR_BOOKE_IVOR32 && sprn <= SPR_BOOKE_IVOR37) {
408
        gen_op_store_excp_vector(sprn - SPR_BOOKE_IVOR32 + 32);
409
        gen_op_store_spr(sprn);
410
    } else {
411
        printf("Trying to write an unknown exception vector %d %03x\n",
412
               sprn, sprn);
413
        GEN_EXCP_PRIVREG(ctx);
414
    }
415
}
416
#endif
417

    
418
#if defined(CONFIG_USER_ONLY)
419
#define spr_register(env, num, name, uea_read, uea_write,                     \
420
                     oea_read, oea_write, initial_value)                      \
421
do {                                                                          \
422
     _spr_register(env, num, name, uea_read, uea_write, initial_value);       \
423
} while (0)
424
static inline void _spr_register (CPUPPCState *env, int num,
425
                                  const unsigned char *name,
426
                                  void (*uea_read)(void *opaque, int sprn),
427
                                  void (*uea_write)(void *opaque, int sprn),
428
                                  target_ulong initial_value)
429
#else
430
static inline void spr_register (CPUPPCState *env, int num,
431
                                 const unsigned char *name,
432
                                 void (*uea_read)(void *opaque, int sprn),
433
                                 void (*uea_write)(void *opaque, int sprn),
434
                                 void (*oea_read)(void *opaque, int sprn),
435
                                 void (*oea_write)(void *opaque, int sprn),
436
                                 target_ulong initial_value)
437
#endif
438
{
439
    ppc_spr_t *spr;
440

    
441
    spr = &env->spr_cb[num];
442
    if (spr->name != NULL ||env-> spr[num] != 0x00000000 ||
443
#if !defined(CONFIG_USER_ONLY)
444
        spr->oea_read != NULL || spr->oea_write != NULL ||
445
#endif
446
        spr->uea_read != NULL || spr->uea_write != NULL) {
447
        printf("Error: Trying to register SPR %d (%03x) twice !\n", num, num);
448
        exit(1);
449
    }
450
#if defined(PPC_DEBUG_SPR)
451
    printf("*** register spr %d (%03x) %s val " ADDRX "\n", num, num, name,
452
           initial_value);
453
#endif
454
    spr->name = name;
455
    spr->uea_read = uea_read;
456
    spr->uea_write = uea_write;
457
#if !defined(CONFIG_USER_ONLY)
458
    spr->oea_read = oea_read;
459
    spr->oea_write = oea_write;
460
#endif
461
    env->spr[num] = initial_value;
462
}
463

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

    
509
/* SPR common to all non-embedded PowerPC, including 601 */
510
static void gen_spr_ne_601 (CPUPPCState *env)
511
{
512
    /* Exception processing */
513
    spr_register(env, SPR_DSISR, "DSISR",
514
                 SPR_NOACCESS, SPR_NOACCESS,
515
                 &spr_read_generic, &spr_write_generic,
516
                 0x00000000);
517
    spr_register(env, SPR_DAR, "DAR",
518
                 SPR_NOACCESS, SPR_NOACCESS,
519
                 &spr_read_generic, &spr_write_generic,
520
                 0x00000000);
521
    /* Timer */
522
    spr_register(env, SPR_DECR, "DECR",
523
                 SPR_NOACCESS, SPR_NOACCESS,
524
                 &spr_read_decr, &spr_write_decr,
525
                 0x00000000);
526
    /* Memory management */
527
    spr_register(env, SPR_SDR1, "SDR1",
528
                 SPR_NOACCESS, SPR_NOACCESS,
529
                 &spr_read_sdr1, &spr_write_sdr1,
530
                 0x00000000);
531
}
532

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

    
603
/* BATs 4-7 */
604
static void gen_high_BATs (CPUPPCState *env)
605
{
606
    spr_register(env, SPR_IBAT4U, "IBAT4U",
607
                 SPR_NOACCESS, SPR_NOACCESS,
608
                 &spr_read_ibat_h, &spr_write_ibatu_h,
609
                 0x00000000);
610
    spr_register(env, SPR_IBAT4L, "IBAT4L",
611
                 SPR_NOACCESS, SPR_NOACCESS,
612
                 &spr_read_ibat_h, &spr_write_ibatl_h,
613
                 0x00000000);
614
    spr_register(env, SPR_IBAT5U, "IBAT5U",
615
                 SPR_NOACCESS, SPR_NOACCESS,
616
                 &spr_read_ibat_h, &spr_write_ibatu_h,
617
                 0x00000000);
618
    spr_register(env, SPR_IBAT5L, "IBAT5L",
619
                 SPR_NOACCESS, SPR_NOACCESS,
620
                 &spr_read_ibat_h, &spr_write_ibatl_h,
621
                 0x00000000);
622
    spr_register(env, SPR_IBAT6U, "IBAT6U",
623
                 SPR_NOACCESS, SPR_NOACCESS,
624
                 &spr_read_ibat_h, &spr_write_ibatu_h,
625
                 0x00000000);
626
    spr_register(env, SPR_IBAT6L, "IBAT6L",
627
                 SPR_NOACCESS, SPR_NOACCESS,
628
                 &spr_read_ibat_h, &spr_write_ibatl_h,
629
                 0x00000000);
630
    spr_register(env, SPR_IBAT7U, "IBAT7U",
631
                 SPR_NOACCESS, SPR_NOACCESS,
632
                 &spr_read_ibat_h, &spr_write_ibatu_h,
633
                 0x00000000);
634
    spr_register(env, SPR_IBAT7L, "IBAT7L",
635
                 SPR_NOACCESS, SPR_NOACCESS,
636
                 &spr_read_ibat_h, &spr_write_ibatl_h,
637
                 0x00000000);
638
    spr_register(env, SPR_DBAT4U, "DBAT4U",
639
                 SPR_NOACCESS, SPR_NOACCESS,
640
                 &spr_read_dbat_h, &spr_write_dbatu_h,
641
                 0x00000000);
642
    spr_register(env, SPR_DBAT4L, "DBAT4L",
643
                 SPR_NOACCESS, SPR_NOACCESS,
644
                 &spr_read_dbat_h, &spr_write_dbatl_h,
645
                 0x00000000);
646
    spr_register(env, SPR_DBAT5U, "DBAT5U",
647
                 SPR_NOACCESS, SPR_NOACCESS,
648
                 &spr_read_dbat_h, &spr_write_dbatu_h,
649
                 0x00000000);
650
    spr_register(env, SPR_DBAT5L, "DBAT5L",
651
                 SPR_NOACCESS, SPR_NOACCESS,
652
                 &spr_read_dbat_h, &spr_write_dbatl_h,
653
                 0x00000000);
654
    spr_register(env, SPR_DBAT6U, "DBAT6U",
655
                 SPR_NOACCESS, SPR_NOACCESS,
656
                 &spr_read_dbat_h, &spr_write_dbatu_h,
657
                 0x00000000);
658
    spr_register(env, SPR_DBAT6L, "DBAT6L",
659
                 SPR_NOACCESS, SPR_NOACCESS,
660
                 &spr_read_dbat_h, &spr_write_dbatl_h,
661
                 0x00000000);
662
    spr_register(env, SPR_DBAT7U, "DBAT7U",
663
                 SPR_NOACCESS, SPR_NOACCESS,
664
                 &spr_read_dbat_h, &spr_write_dbatu_h,
665
                 0x00000000);
666
    spr_register(env, SPR_DBAT7L, "DBAT7L",
667
                 SPR_NOACCESS, SPR_NOACCESS,
668
                 &spr_read_dbat_h, &spr_write_dbatl_h,
669
                 0x00000000);
670
    env->nb_BATs += 4;
671
}
672

    
673
/* Generic PowerPC time base */
674
static void gen_tbl (CPUPPCState *env)
675
{
676
    spr_register(env, SPR_VTBL,  "TBL",
677
                 &spr_read_tbl, SPR_NOACCESS,
678
                 &spr_read_tbl, SPR_NOACCESS,
679
                 0x00000000);
680
    spr_register(env, SPR_TBL,   "TBL",
681
                 SPR_NOACCESS, SPR_NOACCESS,
682
                 SPR_NOACCESS, &spr_write_tbl,
683
                 0x00000000);
684
    spr_register(env, SPR_VTBU,  "TBU",
685
                 &spr_read_tbu, SPR_NOACCESS,
686
                 &spr_read_tbu, SPR_NOACCESS,
687
                 0x00000000);
688
    spr_register(env, SPR_TBU,   "TBU",
689
                 SPR_NOACCESS, SPR_NOACCESS,
690
                 SPR_NOACCESS, &spr_write_tbu,
691
                 0x00000000);
692
}
693

    
694
/* Softare table search registers */
695
static void gen_6xx_7xx_soft_tlb (CPUPPCState *env, int nb_tlbs, int nb_ways)
696
{
697
    env->nb_tlb = nb_tlbs;
698
    env->nb_ways = nb_ways;
699
    env->id_tlbs = 1;
700
    spr_register(env, SPR_DMISS, "DMISS",
701
                 SPR_NOACCESS, SPR_NOACCESS,
702
                 &spr_read_generic, SPR_NOACCESS,
703
                 0x00000000);
704
    spr_register(env, SPR_DCMP, "DCMP",
705
                 SPR_NOACCESS, SPR_NOACCESS,
706
                 &spr_read_generic, SPR_NOACCESS,
707
                 0x00000000);
708
    spr_register(env, SPR_HASH1, "HASH1",
709
                 SPR_NOACCESS, SPR_NOACCESS,
710
                 &spr_read_generic, SPR_NOACCESS,
711
                 0x00000000);
712
    spr_register(env, SPR_HASH2, "HASH2",
713
                 SPR_NOACCESS, SPR_NOACCESS,
714
                 &spr_read_generic, SPR_NOACCESS,
715
                 0x00000000);
716
    spr_register(env, SPR_IMISS, "IMISS",
717
                 SPR_NOACCESS, SPR_NOACCESS,
718
                 &spr_read_generic, SPR_NOACCESS,
719
                 0x00000000);
720
    spr_register(env, SPR_ICMP, "ICMP",
721
                 SPR_NOACCESS, SPR_NOACCESS,
722
                 &spr_read_generic, SPR_NOACCESS,
723
                 0x00000000);
724
    spr_register(env, SPR_RPA, "RPA",
725
                 SPR_NOACCESS, SPR_NOACCESS,
726
                 &spr_read_generic, &spr_write_generic,
727
                 0x00000000);
728
}
729

    
730
/* SPR common to MPC755 and G2 */
731
static void gen_spr_G2_755 (CPUPPCState *env)
732
{
733
    /* SGPRs */
734
    spr_register(env, SPR_SPRG4, "SPRG4",
735
                 SPR_NOACCESS, SPR_NOACCESS,
736
                 &spr_read_generic, &spr_write_generic,
737
                 0x00000000);
738
    spr_register(env, SPR_SPRG5, "SPRG5",
739
                 SPR_NOACCESS, SPR_NOACCESS,
740
                 &spr_read_generic, &spr_write_generic,
741
                 0x00000000);
742
    spr_register(env, SPR_SPRG6, "SPRG6",
743
                 SPR_NOACCESS, SPR_NOACCESS,
744
                 &spr_read_generic, &spr_write_generic,
745
                 0x00000000);
746
    spr_register(env, SPR_SPRG7, "SPRG7",
747
                 SPR_NOACCESS, SPR_NOACCESS,
748
                 &spr_read_generic, &spr_write_generic,
749
                 0x00000000);
750
    /* External access control */
751
    /* XXX : not implemented */
752
    spr_register(env, SPR_EAR, "EAR",
753
                 SPR_NOACCESS, SPR_NOACCESS,
754
                 &spr_read_generic, &spr_write_generic,
755
                 0x00000000);
756
}
757

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

    
855
static void gen_spr_thrm (CPUPPCState *env)
856
{
857
    /* Thermal management */
858
    /* XXX : not implemented */
859
    spr_register(env, SPR_THRM1, "THRM1",
860
                 SPR_NOACCESS, SPR_NOACCESS,
861
                 &spr_read_generic, &spr_write_generic,
862
                 0x00000000);
863
    /* XXX : not implemented */
864
    spr_register(env, SPR_THRM2, "THRM2",
865
                 SPR_NOACCESS, SPR_NOACCESS,
866
                 &spr_read_generic, &spr_write_generic,
867
                 0x00000000);
868
    /* XXX : not implemented */
869
    spr_register(env, SPR_THRM3, "THRM3",
870
                 SPR_NOACCESS, SPR_NOACCESS,
871
                 &spr_read_generic, &spr_write_generic,
872
                 0x00000000);
873
}
874

    
875
/* SPR specific to PowerPC 604 implementation */
876
static void gen_spr_604 (CPUPPCState *env)
877
{
878
    /* Processor identification */
879
    spr_register(env, SPR_PIR, "PIR",
880
                 SPR_NOACCESS, SPR_NOACCESS,
881
                 &spr_read_generic, &spr_write_pir,
882
                 0x00000000);
883
    /* Breakpoints */
884
    /* XXX : not implemented */
885
    spr_register(env, SPR_IABR, "IABR",
886
                 SPR_NOACCESS, SPR_NOACCESS,
887
                 &spr_read_generic, &spr_write_generic,
888
                 0x00000000);
889
    /* XXX : not implemented */
890
    spr_register(env, SPR_DABR, "DABR",
891
                 SPR_NOACCESS, SPR_NOACCESS,
892
                 &spr_read_generic, &spr_write_generic,
893
                 0x00000000);
894
    /* Performance counters */
895
    /* XXX : not implemented */
896
    spr_register(env, SPR_MMCR0, "MMCR0",
897
                 SPR_NOACCESS, SPR_NOACCESS,
898
                 &spr_read_generic, &spr_write_generic,
899
                 0x00000000);
900
    /* XXX : not implemented */
901
    spr_register(env, SPR_MMCR1, "MMCR1",
902
                 SPR_NOACCESS, SPR_NOACCESS,
903
                 &spr_read_generic, &spr_write_generic,
904
                 0x00000000);
905
    /* XXX : not implemented */
906
    spr_register(env, SPR_PMC1, "PMC1",
907
                 SPR_NOACCESS, SPR_NOACCESS,
908
                 &spr_read_generic, &spr_write_generic,
909
                 0x00000000);
910
    /* XXX : not implemented */
911
    spr_register(env, SPR_PMC2, "PMC2",
912
                 SPR_NOACCESS, SPR_NOACCESS,
913
                 &spr_read_generic, &spr_write_generic,
914
                 0x00000000);
915
    /* XXX : not implemented */
916
    spr_register(env, SPR_PMC3, "PMC3",
917
                 SPR_NOACCESS, SPR_NOACCESS,
918
                 &spr_read_generic, &spr_write_generic,
919
                 0x00000000);
920
    /* XXX : not implemented */
921
    spr_register(env, SPR_PMC4, "PMC4",
922
                 SPR_NOACCESS, SPR_NOACCESS,
923
                 &spr_read_generic, &spr_write_generic,
924
                 0x00000000);
925
    /* XXX : not implemented */
926
    spr_register(env, SPR_SIAR, "SIAR",
927
                 SPR_NOACCESS, SPR_NOACCESS,
928
                 &spr_read_generic, SPR_NOACCESS,
929
                 0x00000000);
930
    /* XXX : not implemented */
931
    spr_register(env, SPR_SDA, "SDA",
932
                 SPR_NOACCESS, SPR_NOACCESS,
933
                 &spr_read_generic, SPR_NOACCESS,
934
                 0x00000000);
935
    /* External access control */
936
    /* XXX : not implemented */
937
    spr_register(env, SPR_EAR, "EAR",
938
                 SPR_NOACCESS, SPR_NOACCESS,
939
                 &spr_read_generic, &spr_write_generic,
940
                 0x00000000);
941
}
942

    
943
/* SPR specific to PowerPC 603 implementation */
944
static void gen_spr_603 (CPUPPCState *env)
945
{
946
    /* External access control */
947
    /* XXX : not implemented */
948
    spr_register(env, SPR_EAR, "EAR",
949
                 SPR_NOACCESS, SPR_NOACCESS,
950
                 &spr_read_generic, &spr_write_generic,
951
                 0x00000000);
952
}
953

    
954
/* SPR specific to PowerPC G2 implementation */
955
static void gen_spr_G2 (CPUPPCState *env)
956
{
957
    /* Memory base address */
958
    /* MBAR */
959
    spr_register(env, SPR_MBAR, "MBAR",
960
                 SPR_NOACCESS, SPR_NOACCESS,
961
                 &spr_read_generic, &spr_write_generic,
962
                 0x00000000);
963
    /* System version register */
964
    /* SVR */
965
    spr_register(env, SPR_SVR, "SVR",
966
                 SPR_NOACCESS, SPR_NOACCESS,
967
                 &spr_read_generic, SPR_NOACCESS,
968
                 0x00000000);
969
    /* Exception processing */
970
    spr_register(env, SPR_BOOKE_CSRR0, "CSRR0",
971
                 SPR_NOACCESS, SPR_NOACCESS,
972
                 &spr_read_generic, &spr_write_generic,
973
                 0x00000000);
974
    spr_register(env, SPR_BOOKE_CSRR1, "CSRR1",
975
                 SPR_NOACCESS, SPR_NOACCESS,
976
                 &spr_read_generic, &spr_write_generic,
977
                 0x00000000);
978
    /* Breakpoints */
979
    /* XXX : not implemented */
980
    spr_register(env, SPR_DABR, "DABR",
981
                 SPR_NOACCESS, SPR_NOACCESS,
982
                 &spr_read_generic, &spr_write_generic,
983
                 0x00000000);
984
    /* XXX : not implemented */
985
    spr_register(env, SPR_DABR2, "DABR2",
986
                 SPR_NOACCESS, SPR_NOACCESS,
987
                 &spr_read_generic, &spr_write_generic,
988
                 0x00000000);
989
    /* XXX : not implemented */
990
    spr_register(env, SPR_IABR, "IABR",
991
                 SPR_NOACCESS, SPR_NOACCESS,
992
                 &spr_read_generic, &spr_write_generic,
993
                 0x00000000);
994
    /* XXX : not implemented */
995
    spr_register(env, SPR_IABR2, "IABR2",
996
                 SPR_NOACCESS, SPR_NOACCESS,
997
                 &spr_read_generic, &spr_write_generic,
998
                 0x00000000);
999
    /* XXX : not implemented */
1000
    spr_register(env, SPR_IBCR, "IBCR",
1001
                 SPR_NOACCESS, SPR_NOACCESS,
1002
                 &spr_read_generic, &spr_write_generic,
1003
                 0x00000000);
1004
    /* XXX : not implemented */
1005
    spr_register(env, SPR_DBCR, "DBCR",
1006
                 SPR_NOACCESS, SPR_NOACCESS,
1007
                 &spr_read_generic, &spr_write_generic,
1008
                 0x00000000);
1009
}
1010

    
1011
/* SPR specific to PowerPC 602 implementation */
1012
static void gen_spr_602 (CPUPPCState *env)
1013
{
1014
    /* ESA registers */
1015
    /* XXX : not implemented */
1016
    spr_register(env, SPR_SER, "SER",
1017
                 SPR_NOACCESS, SPR_NOACCESS,
1018
                 &spr_read_generic, &spr_write_generic,
1019
                 0x00000000);
1020
    /* XXX : not implemented */
1021
    spr_register(env, SPR_SEBR, "SEBR",
1022
                 SPR_NOACCESS, SPR_NOACCESS,
1023
                 &spr_read_generic, &spr_write_generic,
1024
                 0x00000000);
1025
    /* XXX : not implemented */
1026
    spr_register(env, SPR_ESASRR, "ESASRR",
1027
                 SPR_NOACCESS, SPR_NOACCESS,
1028
                 &spr_read_generic, &spr_write_generic,
1029
                 0x00000000);
1030
    /* Floating point status */
1031
    /* XXX : not implemented */
1032
    spr_register(env, SPR_SP, "SP",
1033
                 SPR_NOACCESS, SPR_NOACCESS,
1034
                 &spr_read_generic, &spr_write_generic,
1035
                 0x00000000);
1036
    /* XXX : not implemented */
1037
    spr_register(env, SPR_LT, "LT",
1038
                 SPR_NOACCESS, SPR_NOACCESS,
1039
                 &spr_read_generic, &spr_write_generic,
1040
                 0x00000000);
1041
    /* Watchdog timer */
1042
    /* XXX : not implemented */
1043
    spr_register(env, SPR_TCR, "TCR",
1044
                 SPR_NOACCESS, SPR_NOACCESS,
1045
                 &spr_read_generic, &spr_write_generic,
1046
                 0x00000000);
1047
    /* Interrupt base */
1048
    spr_register(env, SPR_IBR, "IBR",
1049
                 SPR_NOACCESS, SPR_NOACCESS,
1050
                 &spr_read_generic, &spr_write_generic,
1051
                 0x00000000);
1052
    /* XXX : not implemented */
1053
    spr_register(env, SPR_IABR, "IABR",
1054
                 SPR_NOACCESS, SPR_NOACCESS,
1055
                 &spr_read_generic, &spr_write_generic,
1056
                 0x00000000);
1057
}
1058

    
1059
/* SPR specific to PowerPC 601 implementation */
1060
static void gen_spr_601 (CPUPPCState *env)
1061
{
1062
    /* Multiplication/division register */
1063
    /* MQ */
1064
    spr_register(env, SPR_MQ, "MQ",
1065
                 &spr_read_generic, &spr_write_generic,
1066
                 &spr_read_generic, &spr_write_generic,
1067
                 0x00000000);
1068
    /* RTC registers */
1069
    spr_register(env, SPR_601_RTCU, "RTCU",
1070
                 SPR_NOACCESS, SPR_NOACCESS,
1071
                 SPR_NOACCESS, &spr_write_601_rtcu,
1072
                 0x00000000);
1073
    spr_register(env, SPR_601_VRTCU, "RTCU",
1074
                 &spr_read_601_rtcu, SPR_NOACCESS,
1075
                 &spr_read_601_rtcu, SPR_NOACCESS,
1076
                 0x00000000);
1077
    spr_register(env, SPR_601_RTCL, "RTCL",
1078
                 SPR_NOACCESS, SPR_NOACCESS,
1079
                 SPR_NOACCESS, &spr_write_601_rtcl,
1080
                 0x00000000);
1081
    spr_register(env, SPR_601_VRTCL, "RTCL",
1082
                 &spr_read_601_rtcl, SPR_NOACCESS,
1083
                 &spr_read_601_rtcl, SPR_NOACCESS,
1084
                 0x00000000);
1085
    /* Timer */
1086
#if 0 /* ? */
1087
    spr_register(env, SPR_601_UDECR, "UDECR",
1088
                 &spr_read_decr, SPR_NOACCESS,
1089
                 &spr_read_decr, SPR_NOACCESS,
1090
                 0x00000000);
1091
#endif
1092
    /* External access control */
1093
    /* XXX : not implemented */
1094
    spr_register(env, SPR_EAR, "EAR",
1095
                 SPR_NOACCESS, SPR_NOACCESS,
1096
                 &spr_read_generic, &spr_write_generic,
1097
                 0x00000000);
1098
    /* Memory management */
1099
    spr_register(env, SPR_IBAT0U, "IBAT0U",
1100
                 SPR_NOACCESS, SPR_NOACCESS,
1101
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1102
                 0x00000000);
1103
    spr_register(env, SPR_IBAT0L, "IBAT0L",
1104
                 SPR_NOACCESS, SPR_NOACCESS,
1105
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1106
                 0x00000000);
1107
    spr_register(env, SPR_IBAT1U, "IBAT1U",
1108
                 SPR_NOACCESS, SPR_NOACCESS,
1109
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1110
                 0x00000000);
1111
    spr_register(env, SPR_IBAT1L, "IBAT1L",
1112
                 SPR_NOACCESS, SPR_NOACCESS,
1113
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1114
                 0x00000000);
1115
    spr_register(env, SPR_IBAT2U, "IBAT2U",
1116
                 SPR_NOACCESS, SPR_NOACCESS,
1117
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1118
                 0x00000000);
1119
    spr_register(env, SPR_IBAT2L, "IBAT2L",
1120
                 SPR_NOACCESS, SPR_NOACCESS,
1121
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1122
                 0x00000000);
1123
    spr_register(env, SPR_IBAT3U, "IBAT3U",
1124
                 SPR_NOACCESS, SPR_NOACCESS,
1125
                 &spr_read_601_ubat, &spr_write_601_ubatu,
1126
                 0x00000000);
1127
    spr_register(env, SPR_IBAT3L, "IBAT3L",
1128
                 SPR_NOACCESS, SPR_NOACCESS,
1129
                 &spr_read_601_ubat, &spr_write_601_ubatl,
1130
                 0x00000000);
1131
    env->nb_BATs = 4;
1132
}
1133

    
1134
static void gen_spr_74xx (CPUPPCState *env)
1135
{
1136
    /* Processor identification */
1137
    spr_register(env, SPR_PIR, "PIR",
1138
                 SPR_NOACCESS, SPR_NOACCESS,
1139
                 &spr_read_generic, &spr_write_pir,
1140
                 0x00000000);
1141
    /* XXX : not implemented */
1142
    spr_register(env, SPR_MMCR2, "MMCR2",
1143
                 SPR_NOACCESS, SPR_NOACCESS,
1144
                 &spr_read_generic, &spr_write_generic,
1145
                 0x00000000);
1146
    spr_register(env, SPR_UMMCR2, "UMMCR2",
1147
                 &spr_read_ureg, SPR_NOACCESS,
1148
                 &spr_read_ureg, SPR_NOACCESS,
1149
                 0x00000000);
1150
    /* XXX: not implemented */
1151
    spr_register(env, SPR_BAMR, "BAMR",
1152
                 SPR_NOACCESS, SPR_NOACCESS,
1153
                 &spr_read_generic, &spr_write_generic,
1154
                 0x00000000);
1155
    spr_register(env, SPR_UBAMR, "UBAMR",
1156
                 &spr_read_ureg, SPR_NOACCESS,
1157
                 &spr_read_ureg, SPR_NOACCESS,
1158
                 0x00000000);
1159
    spr_register(env, SPR_MSSCR0, "MSSCR0",
1160
                 SPR_NOACCESS, SPR_NOACCESS,
1161
                 &spr_read_generic, &spr_write_generic,
1162
                 0x00000000);
1163
    /* Hardware implementation registers */
1164
    /* XXX : not implemented */
1165
    spr_register(env, SPR_HID0, "HID0",
1166
                 SPR_NOACCESS, SPR_NOACCESS,
1167
                 &spr_read_generic, &spr_write_generic,
1168
                 0x00000000);
1169
    /* XXX : not implemented */
1170
    spr_register(env, SPR_HID1, "HID1",
1171
                 SPR_NOACCESS, SPR_NOACCESS,
1172
                 &spr_read_generic, &spr_write_generic,
1173
                 0x00000000);
1174
    /* Altivec */
1175
    spr_register(env, SPR_VRSAVE, "VRSAVE",
1176
                 &spr_read_generic, &spr_write_generic,
1177
                 &spr_read_generic, &spr_write_generic,
1178
                 0x00000000);
1179
}
1180

    
1181
#if defined (TODO)
1182
static void gen_l3_ctrl (CPUPPCState *env)
1183
{
1184
    /* L3CR */
1185
    /* XXX : not implemented */
1186
    spr_register(env, SPR_L3CR, "L3CR",
1187
                 SPR_NOACCESS, SPR_NOACCESS,
1188
                 &spr_read_generic, &spr_write_generic,
1189
                 0x00000000);
1190
    /* L3ITCR0 */
1191
    spr_register(env, SPR_L3ITCR0, "L3ITCR0",
1192
                 SPR_NOACCESS, SPR_NOACCESS,
1193
                 &spr_read_generic, &spr_write_generic,
1194
                 0x00000000);
1195
    /* L3ITCR1 */
1196
    spr_register(env, SPR_L3ITCR1, "L3ITCR1",
1197
                 SPR_NOACCESS, SPR_NOACCESS,
1198
                 &spr_read_generic, &spr_write_generic,
1199
                 0x00000000);
1200
    /* L3ITCR2 */
1201
    spr_register(env, SPR_L3ITCR2, "L3ITCR2",
1202
                 SPR_NOACCESS, SPR_NOACCESS,
1203
                 &spr_read_generic, &spr_write_generic,
1204
                 0x00000000);
1205
    /* L3ITCR3 */
1206
    spr_register(env, SPR_L3ITCR3, "L3ITCR3",
1207
                 SPR_NOACCESS, SPR_NOACCESS,
1208
                 &spr_read_generic, &spr_write_generic,
1209
                 0x00000000);
1210
    /* L3OHCR */
1211
    spr_register(env, SPR_L3OHCR, "L3OHCR",
1212
                 SPR_NOACCESS, SPR_NOACCESS,
1213
                 &spr_read_generic, &spr_write_generic,
1214
                 0x00000000);
1215
    /* L3PM */
1216
    spr_register(env, SPR_L3PM, "L3PM",
1217
                 SPR_NOACCESS, SPR_NOACCESS,
1218
                 &spr_read_generic, &spr_write_generic,
1219
                 0x00000000);
1220
}
1221
#endif /* TODO */
1222

    
1223
#if defined (TODO)
1224
static void gen_74xx_soft_tlb (CPUPPCState *env)
1225
{
1226
    /* XXX: TODO */
1227
    spr_register(env, SPR_PTEHI, "PTEHI",
1228
                 SPR_NOACCESS, SPR_NOACCESS,
1229
                 &spr_read_generic, &spr_write_generic,
1230
                 0x00000000);
1231
    spr_register(env, SPR_PTELO, "PTELO",
1232
                 SPR_NOACCESS, SPR_NOACCESS,
1233
                 &spr_read_generic, &spr_write_generic,
1234
                 0x00000000);
1235
    spr_register(env, SPR_TLBMISS, "TLBMISS",
1236
                 SPR_NOACCESS, SPR_NOACCESS,
1237
                 &spr_read_generic, &spr_write_generic,
1238
                 0x00000000);
1239
}
1240
#endif /* TODO */
1241

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

    
1493
/* FSL storage control registers */
1494
#if defined(TODO)
1495
static void gen_spr_BookE_FSL (CPUPPCState *env)
1496
{
1497
    /* TLB assist registers */
1498
    spr_register(env, SPR_BOOKE_MAS0, "MAS0",
1499
                 SPR_NOACCESS, SPR_NOACCESS,
1500
                 &spr_read_generic, &spr_write_generic,
1501
                 0x00000000);
1502
    spr_register(env, SPR_BOOKE_MAS1, "MAS2",
1503
                 SPR_NOACCESS, SPR_NOACCESS,
1504
                 &spr_read_generic, &spr_write_generic,
1505
                 0x00000000);
1506
    spr_register(env, SPR_BOOKE_MAS2, "MAS3",
1507
                 SPR_NOACCESS, SPR_NOACCESS,
1508
                 &spr_read_generic, &spr_write_generic,
1509
                 0x00000000);
1510
    spr_register(env, SPR_BOOKE_MAS3, "MAS4",
1511
                 SPR_NOACCESS, SPR_NOACCESS,
1512
                 &spr_read_generic, &spr_write_generic,
1513
                 0x00000000);
1514
    spr_register(env, SPR_BOOKE_MAS4, "MAS5",
1515
                 SPR_NOACCESS, SPR_NOACCESS,
1516
                 &spr_read_generic, &spr_write_generic,
1517
                 0x00000000);
1518
    spr_register(env, SPR_BOOKE_MAS6, "MAS6",
1519
                 SPR_NOACCESS, SPR_NOACCESS,
1520
                 &spr_read_generic, &spr_write_generic,
1521
                 0x00000000);
1522
    spr_register(env, SPR_BOOKE_MAS7, "MAS7",
1523
                 SPR_NOACCESS, SPR_NOACCESS,
1524
                 &spr_read_generic, &spr_write_generic,
1525
                 0x00000000);
1526
    if (env->nb_pids > 1) {
1527
        spr_register(env, SPR_BOOKE_PID1, "PID1",
1528
                     SPR_NOACCESS, SPR_NOACCESS,
1529
                     &spr_read_generic, &spr_write_generic,
1530
                     0x00000000);
1531
    }
1532
    if (env->nb_pids > 2) {
1533
        spr_register(env, SPR_BOOKE_PID2, "PID2",
1534
                     SPR_NOACCESS, SPR_NOACCESS,
1535
                     &spr_read_generic, &spr_write_generic,
1536
                     0x00000000);
1537
    }
1538
    spr_register(env, SPR_BOOKE_MMUCFG, "MMUCFG",
1539
                 SPR_NOACCESS, SPR_NOACCESS,
1540
                 &spr_read_generic, SPR_NOACCESS,
1541
                 0x00000000); /* TOFIX */
1542
    spr_register(env, SPR_BOOKE_MMUCSR0, "MMUCSR0",
1543
                 SPR_NOACCESS, SPR_NOACCESS,
1544
                 &spr_read_generic, &spr_write_generic,
1545
                 0x00000000); /* TOFIX */
1546
    switch (env->nb_ways) {
1547
    case 4:
1548
        spr_register(env, SPR_BOOKE_TLB3CFG, "TLB3CFG",
1549
                     SPR_NOACCESS, SPR_NOACCESS,
1550
                     &spr_read_generic, SPR_NOACCESS,
1551
                     0x00000000); /* TOFIX */
1552
        /* Fallthru */
1553
    case 3:
1554
        spr_register(env, SPR_BOOKE_TLB2CFG, "TLB2CFG",
1555
                     SPR_NOACCESS, SPR_NOACCESS,
1556
                     &spr_read_generic, SPR_NOACCESS,
1557
                     0x00000000); /* TOFIX */
1558
        /* Fallthru */
1559
    case 2:
1560
        spr_register(env, SPR_BOOKE_TLB1CFG, "TLB1CFG",
1561
                     SPR_NOACCESS, SPR_NOACCESS,
1562
                     &spr_read_generic, SPR_NOACCESS,
1563
                     0x00000000); /* TOFIX */
1564
        /* Fallthru */
1565
    case 1:
1566
        spr_register(env, SPR_BOOKE_TLB0CFG, "TLB0CFG",
1567
                     SPR_NOACCESS, SPR_NOACCESS,
1568
                     &spr_read_generic, SPR_NOACCESS,
1569
                     0x00000000); /* TOFIX */
1570
        /* Fallthru */
1571
    case 0:
1572
    default:
1573
        break;
1574
    }
1575
}
1576
#endif
1577

    
1578
/* SPR specific to PowerPC 440 implementation */
1579
static void gen_spr_440 (CPUPPCState *env)
1580
{
1581
    /* Cache control */
1582
    /* XXX : not implemented */
1583
    spr_register(env, SPR_440_DNV0, "DNV0",
1584
                 SPR_NOACCESS, SPR_NOACCESS,
1585
                 &spr_read_generic, &spr_write_generic,
1586
                 0x00000000);
1587
    /* XXX : not implemented */
1588
    spr_register(env, SPR_440_DNV1, "DNV1",
1589
                 SPR_NOACCESS, SPR_NOACCESS,
1590
                 &spr_read_generic, &spr_write_generic,
1591
                 0x00000000);
1592
    /* XXX : not implemented */
1593
    spr_register(env, SPR_440_DNV2, "DNV2",
1594
                 SPR_NOACCESS, SPR_NOACCESS,
1595
                 &spr_read_generic, &spr_write_generic,
1596
                 0x00000000);
1597
    /* XXX : not implemented */
1598
    spr_register(env, SPR_440_DNV3, "DNV3",
1599
                 SPR_NOACCESS, SPR_NOACCESS,
1600
                 &spr_read_generic, &spr_write_generic,
1601
                 0x00000000);
1602
    /* XXX : not implemented */
1603
    spr_register(env, SPR_440_DTV0, "DTV0",
1604
                 SPR_NOACCESS, SPR_NOACCESS,
1605
                 &spr_read_generic, &spr_write_generic,
1606
                 0x00000000);
1607
    /* XXX : not implemented */
1608
    spr_register(env, SPR_440_DTV1, "DTV1",
1609
                 SPR_NOACCESS, SPR_NOACCESS,
1610
                 &spr_read_generic, &spr_write_generic,
1611
                 0x00000000);
1612
    /* XXX : not implemented */
1613
    spr_register(env, SPR_440_DTV2, "DTV2",
1614
                 SPR_NOACCESS, SPR_NOACCESS,
1615
                 &spr_read_generic, &spr_write_generic,
1616
                 0x00000000);
1617
    /* XXX : not implemented */
1618
    spr_register(env, SPR_440_DTV3, "DTV3",
1619
                 SPR_NOACCESS, SPR_NOACCESS,
1620
                 &spr_read_generic, &spr_write_generic,
1621
                 0x00000000);
1622
    /* XXX : not implemented */
1623
    spr_register(env, SPR_440_DVLIM, "DVLIM",
1624
                 SPR_NOACCESS, SPR_NOACCESS,
1625
                 &spr_read_generic, &spr_write_generic,
1626
                 0x00000000);
1627
    /* XXX : not implemented */
1628
    spr_register(env, SPR_440_INV0, "INV0",
1629
                 SPR_NOACCESS, SPR_NOACCESS,
1630
                 &spr_read_generic, &spr_write_generic,
1631
                 0x00000000);
1632
    /* XXX : not implemented */
1633
    spr_register(env, SPR_440_INV1, "INV1",
1634
                 SPR_NOACCESS, SPR_NOACCESS,
1635
                 &spr_read_generic, &spr_write_generic,
1636
                 0x00000000);
1637
    /* XXX : not implemented */
1638
    spr_register(env, SPR_440_INV2, "INV2",
1639
                 SPR_NOACCESS, SPR_NOACCESS,
1640
                 &spr_read_generic, &spr_write_generic,
1641
                 0x00000000);
1642
    /* XXX : not implemented */
1643
    spr_register(env, SPR_440_INV3, "INV3",
1644
                 SPR_NOACCESS, SPR_NOACCESS,
1645
                 &spr_read_generic, &spr_write_generic,
1646
                 0x00000000);
1647
    /* XXX : not implemented */
1648
    spr_register(env, SPR_440_ITV0, "ITV0",
1649
                 SPR_NOACCESS, SPR_NOACCESS,
1650
                 &spr_read_generic, &spr_write_generic,
1651
                 0x00000000);
1652
    /* XXX : not implemented */
1653
    spr_register(env, SPR_440_ITV1, "ITV1",
1654
                 SPR_NOACCESS, SPR_NOACCESS,
1655
                 &spr_read_generic, &spr_write_generic,
1656
                 0x00000000);
1657
    /* XXX : not implemented */
1658
    spr_register(env, SPR_440_ITV2, "ITV2",
1659
                 SPR_NOACCESS, SPR_NOACCESS,
1660
                 &spr_read_generic, &spr_write_generic,
1661
                 0x00000000);
1662
    /* XXX : not implemented */
1663
    spr_register(env, SPR_440_ITV3, "ITV3",
1664
                 SPR_NOACCESS, SPR_NOACCESS,
1665
                 &spr_read_generic, &spr_write_generic,
1666
                 0x00000000);
1667
    /* XXX : not implemented */
1668
    spr_register(env, SPR_440_IVLIM, "IVLIM",
1669
                 SPR_NOACCESS, SPR_NOACCESS,
1670
                 &spr_read_generic, &spr_write_generic,
1671
                 0x00000000);
1672
    /* Cache debug */
1673
    /* XXX : not implemented */
1674
    spr_register(env, SPR_BOOKE_DCDBTRH, "DCDBTRH",
1675
                 SPR_NOACCESS, SPR_NOACCESS,
1676
                 &spr_read_generic, SPR_NOACCESS,
1677
                 0x00000000);
1678
    /* XXX : not implemented */
1679
    spr_register(env, SPR_BOOKE_DCDBTRL, "DCDBTRL",
1680
                 SPR_NOACCESS, SPR_NOACCESS,
1681
                 &spr_read_generic, SPR_NOACCESS,
1682
                 0x00000000);
1683
    /* XXX : not implemented */
1684
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1685
                 SPR_NOACCESS, SPR_NOACCESS,
1686
                 &spr_read_generic, SPR_NOACCESS,
1687
                 0x00000000);
1688
    /* XXX : not implemented */
1689
    spr_register(env, SPR_BOOKE_ICDBTRH, "ICDBTRH",
1690
                 SPR_NOACCESS, SPR_NOACCESS,
1691
                 &spr_read_generic, SPR_NOACCESS,
1692
                 0x00000000);
1693
    /* XXX : not implemented */
1694
    spr_register(env, SPR_BOOKE_ICDBTRL, "ICDBTRL",
1695
                 SPR_NOACCESS, SPR_NOACCESS,
1696
                 &spr_read_generic, SPR_NOACCESS,
1697
                 0x00000000);
1698
    /* XXX : not implemented */
1699
    spr_register(env, SPR_440_DBDR, "DBDR",
1700
                 SPR_NOACCESS, SPR_NOACCESS,
1701
                 &spr_read_generic, &spr_write_generic,
1702
                 0x00000000);
1703
    /* Processor control */
1704
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1705
                 SPR_NOACCESS, SPR_NOACCESS,
1706
                 &spr_read_generic, &spr_write_generic,
1707
                 0x00000000);
1708
    spr_register(env, SPR_440_RSTCFG, "RSTCFG",
1709
                 SPR_NOACCESS, SPR_NOACCESS,
1710
                 &spr_read_generic, SPR_NOACCESS,
1711
                 0x00000000);
1712
    /* Storage control */
1713
    spr_register(env, SPR_440_MMUCR, "MMUCR",
1714
                 SPR_NOACCESS, SPR_NOACCESS,
1715
                 &spr_read_generic, &spr_write_generic,
1716
                 0x00000000);
1717
}
1718

    
1719
/* SPR shared between PowerPC 40x implementations */
1720
static void gen_spr_40x (CPUPPCState *env)
1721
{
1722
    /* Cache */
1723
    /* XXX : not implemented */
1724
    spr_register(env, SPR_40x_DCCR, "DCCR",
1725
                 SPR_NOACCESS, SPR_NOACCESS,
1726
                 &spr_read_generic, &spr_write_generic,
1727
                 0x00000000);
1728
    /* XXX : not implemented */
1729
    spr_register(env, SPR_40x_ICCR, "ICCR",
1730
                 SPR_NOACCESS, SPR_NOACCESS,
1731
                 &spr_read_generic, &spr_write_generic,
1732
                 0x00000000);
1733
    /* XXX : not implemented */
1734
    spr_register(env, SPR_BOOKE_ICDBDR, "ICDBDR",
1735
                 SPR_NOACCESS, SPR_NOACCESS,
1736
                 &spr_read_generic, SPR_NOACCESS,
1737
                 0x00000000);
1738
    /* Exception */
1739
    spr_register(env, SPR_40x_DEAR, "DEAR",
1740
                 SPR_NOACCESS, SPR_NOACCESS,
1741
                 &spr_read_generic, &spr_write_generic,
1742
                 0x00000000);
1743
    spr_register(env, SPR_40x_ESR, "ESR",
1744
                 SPR_NOACCESS, SPR_NOACCESS,
1745
                 &spr_read_generic, &spr_write_generic,
1746
                 0x00000000);
1747
    spr_register(env, SPR_40x_EVPR, "EVPR",
1748
                 SPR_NOACCESS, SPR_NOACCESS,
1749
                 &spr_read_generic, &spr_write_excp_prefix,
1750
                 0x00000000);
1751
    spr_register(env, SPR_40x_SRR2, "SRR2",
1752
                 &spr_read_generic, &spr_write_generic,
1753
                 &spr_read_generic, &spr_write_generic,
1754
                 0x00000000);
1755
    spr_register(env, SPR_40x_SRR3, "SRR3",
1756
                 &spr_read_generic, &spr_write_generic,
1757
                 &spr_read_generic, &spr_write_generic,
1758
                 0x00000000);
1759
    /* Timers */
1760
    spr_register(env, SPR_40x_PIT, "PIT",
1761
                 SPR_NOACCESS, SPR_NOACCESS,
1762
                 &spr_read_40x_pit, &spr_write_40x_pit,
1763
                 0x00000000);
1764
    spr_register(env, SPR_40x_TCR, "TCR",
1765
                 SPR_NOACCESS, SPR_NOACCESS,
1766
                 &spr_read_generic, &spr_write_booke_tcr,
1767
                 0x00000000);
1768
    spr_register(env, SPR_40x_TSR, "TSR",
1769
                 SPR_NOACCESS, SPR_NOACCESS,
1770
                 &spr_read_generic, &spr_write_booke_tsr,
1771
                 0x00000000);
1772
}
1773

    
1774
/* SPR specific to PowerPC 405 implementation */
1775
static void gen_spr_405 (CPUPPCState *env)
1776
{
1777
    /* MMU */
1778
    spr_register(env, SPR_40x_PID, "PID",
1779
                 SPR_NOACCESS, SPR_NOACCESS,
1780
                 &spr_read_generic, &spr_write_generic,
1781
                 0x00000000);
1782
    spr_register(env, SPR_4xx_CCR0, "CCR0",
1783
                 SPR_NOACCESS, SPR_NOACCESS,
1784
                 &spr_read_generic, &spr_write_generic,
1785
                 0x00700000);
1786
    /* Debug interface */
1787
    /* XXX : not implemented */
1788
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1789
                 SPR_NOACCESS, SPR_NOACCESS,
1790
                 &spr_read_generic, &spr_write_40x_dbcr0,
1791
                 0x00000000);
1792
    /* XXX : not implemented */
1793
    spr_register(env, SPR_405_DBCR1, "DBCR1",
1794
                 SPR_NOACCESS, SPR_NOACCESS,
1795
                 &spr_read_generic, &spr_write_generic,
1796
                 0x00000000);
1797
    /* XXX : not implemented */
1798
    spr_register(env, SPR_40x_DBSR, "DBSR",
1799
                 SPR_NOACCESS, SPR_NOACCESS,
1800
                 &spr_read_generic, &spr_write_clear,
1801
                 /* Last reset was system reset */
1802
                 0x00000300);
1803
    /* XXX : not implemented */
1804
    spr_register(env, SPR_40x_DAC1, "DAC1",
1805
                 SPR_NOACCESS, SPR_NOACCESS,
1806
                 &spr_read_generic, &spr_write_generic,
1807
                 0x00000000);
1808
    spr_register(env, SPR_40x_DAC2, "DAC2",
1809
                 SPR_NOACCESS, SPR_NOACCESS,
1810
                 &spr_read_generic, &spr_write_generic,
1811
                 0x00000000);
1812
    /* XXX : not implemented */
1813
    spr_register(env, SPR_405_DVC1, "DVC1",
1814
                 SPR_NOACCESS, SPR_NOACCESS,
1815
                 &spr_read_generic, &spr_write_generic,
1816
                 0x00000000);
1817
    /* XXX : not implemented */
1818
    spr_register(env, SPR_405_DVC2, "DVC2",
1819
                 SPR_NOACCESS, SPR_NOACCESS,
1820
                 &spr_read_generic, &spr_write_generic,
1821
                 0x00000000);
1822
    /* XXX : not implemented */
1823
    spr_register(env, SPR_40x_IAC1, "IAC1",
1824
                 SPR_NOACCESS, SPR_NOACCESS,
1825
                 &spr_read_generic, &spr_write_generic,
1826
                 0x00000000);
1827
    spr_register(env, SPR_40x_IAC2, "IAC2",
1828
                 SPR_NOACCESS, SPR_NOACCESS,
1829
                 &spr_read_generic, &spr_write_generic,
1830
                 0x00000000);
1831
    /* XXX : not implemented */
1832
    spr_register(env, SPR_405_IAC3, "IAC3",
1833
                 SPR_NOACCESS, SPR_NOACCESS,
1834
                 &spr_read_generic, &spr_write_generic,
1835
                 0x00000000);
1836
    /* XXX : not implemented */
1837
    spr_register(env, SPR_405_IAC4, "IAC4",
1838
                 SPR_NOACCESS, SPR_NOACCESS,
1839
                 &spr_read_generic, &spr_write_generic,
1840
                 0x00000000);
1841
    /* Storage control */
1842
    spr_register(env, SPR_405_SLER, "SLER",
1843
                 SPR_NOACCESS, SPR_NOACCESS,
1844
                 &spr_read_generic, &spr_write_40x_sler,
1845
                 0x00000000);
1846
    spr_register(env, SPR_40x_ZPR, "ZPR",
1847
                 SPR_NOACCESS, SPR_NOACCESS,
1848
                 &spr_read_generic, &spr_write_generic,
1849
                 0x00000000);
1850
    /* XXX : not implemented */
1851
    spr_register(env, SPR_405_SU0R, "SU0R",
1852
                 SPR_NOACCESS, SPR_NOACCESS,
1853
                 &spr_read_generic, &spr_write_generic,
1854
                 0x00000000);
1855
    /* SPRG */
1856
    spr_register(env, SPR_USPRG0, "USPRG0",
1857
                 &spr_read_ureg, SPR_NOACCESS,
1858
                 &spr_read_ureg, SPR_NOACCESS,
1859
                 0x00000000);
1860
    spr_register(env, SPR_SPRG4, "SPRG4",
1861
                 SPR_NOACCESS, SPR_NOACCESS,
1862
                 &spr_read_generic, &spr_write_generic,
1863
                 0x00000000);
1864
    spr_register(env, SPR_USPRG4, "USPRG4",
1865
                 &spr_read_ureg, SPR_NOACCESS,
1866
                 &spr_read_ureg, SPR_NOACCESS,
1867
                 0x00000000);
1868
    spr_register(env, SPR_SPRG5, "SPRG5",
1869
                 SPR_NOACCESS, SPR_NOACCESS,
1870
                 spr_read_generic, &spr_write_generic,
1871
                 0x00000000);
1872
    spr_register(env, SPR_USPRG5, "USPRG5",
1873
                 &spr_read_ureg, SPR_NOACCESS,
1874
                 &spr_read_ureg, SPR_NOACCESS,
1875
                 0x00000000);
1876
    spr_register(env, SPR_SPRG6, "SPRG6",
1877
                 SPR_NOACCESS, SPR_NOACCESS,
1878
                 spr_read_generic, &spr_write_generic,
1879
                 0x00000000);
1880
    spr_register(env, SPR_USPRG6, "USPRG6",
1881
                 &spr_read_ureg, SPR_NOACCESS,
1882
                 &spr_read_ureg, SPR_NOACCESS,
1883
                 0x00000000);
1884
    spr_register(env, SPR_SPRG7, "SPRG7",
1885
                 SPR_NOACCESS, SPR_NOACCESS,
1886
                 spr_read_generic, &spr_write_generic,
1887
                 0x00000000);
1888
    spr_register(env, SPR_USPRG7, "USPRG7",
1889
                 &spr_read_ureg, SPR_NOACCESS,
1890
                 &spr_read_ureg, SPR_NOACCESS,
1891
                 0x00000000);
1892
}
1893

    
1894
/* SPR shared between PowerPC 401 & 403 implementations */
1895
static void gen_spr_401_403 (CPUPPCState *env)
1896
{
1897
    /* Time base */
1898
    spr_register(env, SPR_403_VTBL,  "TBL",
1899
                 &spr_read_tbl, SPR_NOACCESS,
1900
                 &spr_read_tbl, SPR_NOACCESS,
1901
                 0x00000000);
1902
    spr_register(env, SPR_403_TBL,   "TBL",
1903
                 SPR_NOACCESS, SPR_NOACCESS,
1904
                 SPR_NOACCESS, &spr_write_tbl,
1905
                 0x00000000);
1906
    spr_register(env, SPR_403_VTBU,  "TBU",
1907
                 &spr_read_tbu, SPR_NOACCESS,
1908
                 &spr_read_tbu, SPR_NOACCESS,
1909
                 0x00000000);
1910
    spr_register(env, SPR_403_TBU,   "TBU",
1911
                 SPR_NOACCESS, SPR_NOACCESS,
1912
                 SPR_NOACCESS, &spr_write_tbu,
1913
                 0x00000000);
1914
    /* Debug */
1915
    /* XXX: not implemented */
1916
    spr_register(env, SPR_403_CDBCR, "CDBCR",
1917
                 SPR_NOACCESS, SPR_NOACCESS,
1918
                 &spr_read_generic, &spr_write_generic,
1919
                 0x00000000);
1920
}
1921

    
1922
/* SPR specific to PowerPC 401 implementation */
1923
static void gen_spr_401 (CPUPPCState *env)
1924
{
1925
    /* Debug interface */
1926
    /* XXX : not implemented */
1927
    spr_register(env, SPR_40x_DBCR0, "DBCR",
1928
                 SPR_NOACCESS, SPR_NOACCESS,
1929
                 &spr_read_generic, &spr_write_40x_dbcr0,
1930
                 0x00000000);
1931
    /* XXX : not implemented */
1932
    spr_register(env, SPR_40x_DBSR, "DBSR",
1933
                 SPR_NOACCESS, SPR_NOACCESS,
1934
                 &spr_read_generic, &spr_write_clear,
1935
                 /* Last reset was system reset */
1936
                 0x00000300);
1937
    /* XXX : not implemented */
1938
    spr_register(env, SPR_40x_DAC1, "DAC",
1939
                 SPR_NOACCESS, SPR_NOACCESS,
1940
                 &spr_read_generic, &spr_write_generic,
1941
                 0x00000000);
1942
    /* XXX : not implemented */
1943
    spr_register(env, SPR_40x_IAC1, "IAC",
1944
                 SPR_NOACCESS, SPR_NOACCESS,
1945
                 &spr_read_generic, &spr_write_generic,
1946
                 0x00000000);
1947
    /* Storage control */
1948
    spr_register(env, SPR_405_SLER, "SLER",
1949
                 SPR_NOACCESS, SPR_NOACCESS,
1950
                 &spr_read_generic, &spr_write_40x_sler,
1951
                 0x00000000);
1952
}
1953

    
1954
static void gen_spr_401x2 (CPUPPCState *env)
1955
{
1956
    gen_spr_401(env);
1957
    spr_register(env, SPR_40x_PID, "PID",
1958
                 SPR_NOACCESS, SPR_NOACCESS,
1959
                 &spr_read_generic, &spr_write_generic,
1960
                 0x00000000);
1961
    spr_register(env, SPR_40x_ZPR, "ZPR",
1962
                 SPR_NOACCESS, SPR_NOACCESS,
1963
                 &spr_read_generic, &spr_write_generic,
1964
                 0x00000000);
1965
}
1966

    
1967
/* SPR specific to PowerPC 403 implementation */
1968
static void gen_spr_403 (CPUPPCState *env)
1969
{
1970
    /* Debug interface */
1971
    /* XXX : not implemented */
1972
    spr_register(env, SPR_40x_DBCR0, "DBCR0",
1973
                 SPR_NOACCESS, SPR_NOACCESS,
1974
                 &spr_read_generic, &spr_write_40x_dbcr0,
1975
                 0x00000000);
1976
    /* XXX : not implemented */
1977
    spr_register(env, SPR_40x_DBSR, "DBSR",
1978
                 SPR_NOACCESS, SPR_NOACCESS,
1979
                 &spr_read_generic, &spr_write_clear,
1980
                 /* Last reset was system reset */
1981
                 0x00000300);
1982
    /* XXX : not implemented */
1983
    spr_register(env, SPR_40x_DAC1, "DAC1",
1984
                 SPR_NOACCESS, SPR_NOACCESS,
1985
                 &spr_read_generic, &spr_write_generic,
1986
                 0x00000000);
1987
    spr_register(env, SPR_40x_DAC2, "DAC2",
1988
                 SPR_NOACCESS, SPR_NOACCESS,
1989
                 &spr_read_generic, &spr_write_generic,
1990
                 0x00000000);
1991
    /* XXX : not implemented */
1992
    spr_register(env, SPR_40x_IAC1, "IAC1",
1993
                 SPR_NOACCESS, SPR_NOACCESS,
1994
                 &spr_read_generic, &spr_write_generic,
1995
                 0x00000000);
1996
    spr_register(env, SPR_40x_IAC2, "IAC2",
1997
                 SPR_NOACCESS, SPR_NOACCESS,
1998
                 &spr_read_generic, &spr_write_generic,
1999
                 0x00000000);
2000
}
2001

    
2002
static void gen_spr_403_real (CPUPPCState *env)
2003
{
2004
    spr_register(env, SPR_403_PBL1,  "PBL1",
2005
                 SPR_NOACCESS, SPR_NOACCESS,
2006
                 &spr_read_403_pbr, &spr_write_403_pbr,
2007
                 0x00000000);
2008
    spr_register(env, SPR_403_PBU1,  "PBU1",
2009
                 SPR_NOACCESS, SPR_NOACCESS,
2010
                 &spr_read_403_pbr, &spr_write_403_pbr,
2011
                 0x00000000);
2012
    spr_register(env, SPR_403_PBL2,  "PBL2",
2013
                 SPR_NOACCESS, SPR_NOACCESS,
2014
                 &spr_read_403_pbr, &spr_write_403_pbr,
2015
                 0x00000000);
2016
    spr_register(env, SPR_403_PBU2,  "PBU2",
2017
                 SPR_NOACCESS, SPR_NOACCESS,
2018
                 &spr_read_403_pbr, &spr_write_403_pbr,
2019
                 0x00000000);
2020
}
2021

    
2022
static void gen_spr_403_mmu (CPUPPCState *env)
2023
{
2024
    /* MMU */
2025
    spr_register(env, SPR_40x_PID, "PID",
2026
                 SPR_NOACCESS, SPR_NOACCESS,
2027
                 &spr_read_generic, &spr_write_generic,
2028
                 0x00000000);
2029
    spr_register(env, SPR_40x_ZPR, "ZPR",
2030
                 SPR_NOACCESS, SPR_NOACCESS,
2031
                 &spr_read_generic, &spr_write_generic,
2032
                 0x00000000);
2033
}
2034

    
2035
/* SPR specific to PowerPC compression coprocessor extension */
2036
static void gen_spr_compress (CPUPPCState *env)
2037
{
2038
    spr_register(env, SPR_401_SKR, "SKR",
2039
                 SPR_NOACCESS, SPR_NOACCESS,
2040
                 &spr_read_generic, &spr_write_generic,
2041
                 0x00000000);
2042
}
2043

    
2044
#if defined (TARGET_PPC64)
2045
#if defined (TODO)
2046
/* SPR specific to PowerPC 620 */
2047
static void gen_spr_620 (CPUPPCState *env)
2048
{
2049
    spr_register(env, SPR_620_PMR0, "PMR0",
2050
                 SPR_NOACCESS, SPR_NOACCESS,
2051
                 &spr_read_generic, &spr_write_generic,
2052
                 0x00000000);
2053
    spr_register(env, SPR_620_PMR1, "PMR1",
2054
                 SPR_NOACCESS, SPR_NOACCESS,
2055
                 &spr_read_generic, &spr_write_generic,
2056
                 0x00000000);
2057
    spr_register(env, SPR_620_PMR2, "PMR2",
2058
                 SPR_NOACCESS, SPR_NOACCESS,
2059
                 &spr_read_generic, &spr_write_generic,
2060
                 0x00000000);
2061
    spr_register(env, SPR_620_PMR3, "PMR3",
2062
                 SPR_NOACCESS, SPR_NOACCESS,
2063
                 &spr_read_generic, &spr_write_generic,
2064
                 0x00000000);
2065
    spr_register(env, SPR_620_PMR4, "PMR4",
2066
                 SPR_NOACCESS, SPR_NOACCESS,
2067
                 &spr_read_generic, &spr_write_generic,
2068
                 0x00000000);
2069
    spr_register(env, SPR_620_PMR5, "PMR5",
2070
                 SPR_NOACCESS, SPR_NOACCESS,
2071
                 &spr_read_generic, &spr_write_generic,
2072
                 0x00000000);
2073
    spr_register(env, SPR_620_PMR6, "PMR6",
2074
                 SPR_NOACCESS, SPR_NOACCESS,
2075
                 &spr_read_generic, &spr_write_generic,
2076
                 0x00000000);
2077
    spr_register(env, SPR_620_PMR7, "PMR7",
2078
                 SPR_NOACCESS, SPR_NOACCESS,
2079
                 &spr_read_generic, &spr_write_generic,
2080
                 0x00000000);
2081
    spr_register(env, SPR_620_PMR8, "PMR8",
2082
                 SPR_NOACCESS, SPR_NOACCESS,
2083
                 &spr_read_generic, &spr_write_generic,
2084
                 0x00000000);
2085
    spr_register(env, SPR_620_PMR9, "PMR9",
2086
                 SPR_NOACCESS, SPR_NOACCESS,
2087
                 &spr_read_generic, &spr_write_generic,
2088
                 0x00000000);
2089
    spr_register(env, SPR_620_PMRA, "PMR10",
2090
                 SPR_NOACCESS, SPR_NOACCESS,
2091
                 &spr_read_generic, &spr_write_generic,
2092
                 0x00000000);
2093
    spr_register(env, SPR_620_PMRB, "PMR11",
2094
                 SPR_NOACCESS, SPR_NOACCESS,
2095
                 &spr_read_generic, &spr_write_generic,
2096
                 0x00000000);
2097
    spr_register(env, SPR_620_PMRC, "PMR12",
2098
                 SPR_NOACCESS, SPR_NOACCESS,
2099
                 &spr_read_generic, &spr_write_generic,
2100
                 0x00000000);
2101
    spr_register(env, SPR_620_PMRD, "PMR13",
2102
                 SPR_NOACCESS, SPR_NOACCESS,
2103
                 &spr_read_generic, &spr_write_generic,
2104
                 0x00000000);
2105
    spr_register(env, SPR_620_PMRE, "PMR14",
2106
                 SPR_NOACCESS, SPR_NOACCESS,
2107
                 &spr_read_generic, &spr_write_generic,
2108
                 0x00000000);
2109
    spr_register(env, SPR_620_PMRF, "PMR15",
2110
                 SPR_NOACCESS, SPR_NOACCESS,
2111
                 &spr_read_generic, &spr_write_generic,
2112
                 0x00000000);
2113
    spr_register(env, SPR_620_HID8, "HID8",
2114
                 SPR_NOACCESS, SPR_NOACCESS,
2115
                 &spr_read_generic, &spr_write_generic,
2116
                 0x00000000);
2117
    spr_register(env, SPR_620_HID9, "HID9",
2118
                 SPR_NOACCESS, SPR_NOACCESS,
2119
                 &spr_read_generic, &spr_write_generic,
2120
                 0x00000000);
2121
}
2122
#endif
2123
#endif /* defined (TARGET_PPC64) */
2124

    
2125
// XXX: TODO
2126
/*
2127
 * AMR     => SPR 29 (Power 2.04)
2128
 * CTRL    => SPR 136 (Power 2.04)
2129
 * CTRL    => SPR 152 (Power 2.04)
2130
 * SCOMC   => SPR 276 (64 bits ?)
2131
 * SCOMD   => SPR 277 (64 bits ?)
2132
 * ASR     => SPR 280 (64 bits)
2133
 * TBU40   => SPR 286 (Power 2.04 hypv)
2134
 * HSPRG0  => SPR 304 (Power 2.04 hypv)
2135
 * HSPRG1  => SPR 305 (Power 2.04 hypv)
2136
 * HDSISR  => SPR 306 (Power 2.04 hypv)
2137
 * HDAR    => SPR 307 (Power 2.04 hypv)
2138
 * PURR    => SPR 309 (Power 2.04 hypv)
2139
 * HDEC    => SPR 310 (Power 2.04 hypv)
2140
 * HIOR    => SPR 311 (hypv)
2141
 * RMOR    => SPR 312 (970)
2142
 * HRMOR   => SPR 313 (Power 2.04 hypv)
2143
 * HSRR0   => SPR 314 (Power 2.04 hypv)
2144
 * HSRR1   => SPR 315 (Power 2.04 hypv)
2145
 * LPCR    => SPR 316 (970)
2146
 * LPIDR   => SPR 317 (970)
2147
 * SPEFSCR => SPR 512 (Power 2.04 emb)
2148
 * ATBL    => SPR 526 (Power 2.04 emb)
2149
 * ATBU    => SPR 527 (Power 2.04 emb)
2150
 * EPR     => SPR 702 (Power 2.04 emb)
2151
 * perf    => 768-783 (Power 2.04)
2152
 * perf    => 784-799 (Power 2.04)
2153
 * PPR     => SPR 896 (Power 2.04)
2154
 * EPLC    => SPR 947 (Power 2.04 emb)
2155
 * EPSC    => SPR 948 (Power 2.04 emb)
2156
 * DABRX   => 1015    (Power 2.04 hypv)
2157
 * FPECR   => SPR 1022 (?)
2158
 * ... and more (thermal management, performance counters, ...)
2159
 */
2160

    
2161
/*****************************************************************************/
2162
/* Exception vectors models                                                  */
2163
static void init_excp_4xx_real (CPUPPCState *env)
2164
{
2165
#if !defined(CONFIG_USER_ONLY)
2166
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2167
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2168
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2169
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2170
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2171
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2172
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2173
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2174
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2175
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2176
    env->excp_prefix = 0x00000000;
2177
    env->ivor_mask = 0x0000FFF0;
2178
    env->ivpr_mask = 0xFFFF0000;
2179
#endif
2180
}
2181

    
2182
static void init_excp_4xx_softmmu (CPUPPCState *env)
2183
{
2184
#if !defined(CONFIG_USER_ONLY)
2185
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000100;
2186
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2187
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2188
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2189
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2190
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2191
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2192
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2193
    env->excp_vectors[POWERPC_EXCP_PIT]      = 0x00001000;
2194
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00001010;
2195
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001020;
2196
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00001100;
2197
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00001200;
2198
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00002000;
2199
    env->excp_prefix = 0x00000000;
2200
    env->ivor_mask = 0x0000FFF0;
2201
    env->ivpr_mask = 0xFFFF0000;
2202
#endif
2203
}
2204

    
2205
static void init_excp_BookE (CPUPPCState *env)
2206
{
2207
#if !defined(CONFIG_USER_ONLY)
2208
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000000;
2209
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000000;
2210
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000000;
2211
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000000;
2212
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000000;
2213
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000000;
2214
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000000;
2215
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000000;
2216
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000000;
2217
    env->excp_vectors[POWERPC_EXCP_APU]      = 0x00000000;
2218
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000000;
2219
    env->excp_vectors[POWERPC_EXCP_FIT]      = 0x00000000;
2220
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00000000;
2221
    env->excp_vectors[POWERPC_EXCP_DTLB]     = 0x00000000;
2222
    env->excp_vectors[POWERPC_EXCP_ITLB]     = 0x00000000;
2223
    env->excp_vectors[POWERPC_EXCP_DEBUG]    = 0x00000000;
2224
    env->excp_prefix = 0x00000000;
2225
    env->ivor_mask = 0x0000FFE0;
2226
    env->ivpr_mask = 0xFFFF0000;
2227
#endif
2228
}
2229

    
2230
static void init_excp_601 (CPUPPCState *env)
2231
{
2232
#if !defined(CONFIG_USER_ONLY)
2233
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2234
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2235
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2236
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2237
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2238
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2239
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2240
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2241
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2242
    env->excp_vectors[POWERPC_EXCP_IO]       = 0x00000A00;
2243
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2244
    env->excp_vectors[POWERPC_EXCP_RUNM]     = 0x00002000;
2245
    env->excp_prefix = 0xFFF00000;
2246
#endif
2247
}
2248

    
2249
static void init_excp_602 (CPUPPCState *env)
2250
{
2251
#if !defined(CONFIG_USER_ONLY)
2252
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2253
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2254
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2255
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2256
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2257
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2258
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2259
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2260
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2261
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2262
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2263
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2264
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2265
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2266
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2267
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2268
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2269
    env->excp_vectors[POWERPC_EXCP_WDT]      = 0x00001500;
2270
    env->excp_vectors[POWERPC_EXCP_EMUL]     = 0x00001600;
2271
    env->excp_prefix = 0xFFF00000;
2272
#endif
2273
}
2274

    
2275
static void init_excp_603 (CPUPPCState *env)
2276
{
2277
#if !defined(CONFIG_USER_ONLY)
2278
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2279
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2280
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2281
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2282
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2283
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2284
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2285
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2286
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2287
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2288
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2289
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2290
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2291
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2292
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2293
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2294
#endif
2295
}
2296

    
2297
static void init_excp_G2 (CPUPPCState *env)
2298
{
2299
#if !defined(CONFIG_USER_ONLY)
2300
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2301
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2302
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2303
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2304
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2305
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2306
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2307
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2308
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2309
    env->excp_vectors[POWERPC_EXCP_CRITICAL] = 0x00000A00;
2310
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2311
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2312
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2313
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2314
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2315
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2316
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2317
#endif
2318
}
2319

    
2320
static void init_excp_604 (CPUPPCState *env)
2321
{
2322
#if !defined(CONFIG_USER_ONLY)
2323
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2324
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2325
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2326
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2327
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2328
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2329
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2330
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2331
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2332
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2333
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2334
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2335
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2336
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2337
#endif
2338
}
2339

    
2340
#if defined (TODO)
2341
static void init_excp_620 (CPUPPCState *env)
2342
{
2343
#if !defined(CONFIG_USER_ONLY)
2344
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2345
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2346
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2347
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2348
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2349
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2350
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2351
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2352
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2353
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2354
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2355
    env->excp_vectors[POWERPC_EXCP_FPA]      = 0x00000E00;
2356
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2357
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2358
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2359
#endif
2360
}
2361
#endif /* defined (TODO) */
2362

    
2363
static void init_excp_7x0 (CPUPPCState *env)
2364
{
2365
#if !defined(CONFIG_USER_ONLY)
2366
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2367
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2368
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2369
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2370
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2371
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2372
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2373
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2374
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2375
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2376
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2377
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2378
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2379
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2380
#endif
2381
}
2382

    
2383
static void init_excp_750FX (CPUPPCState *env)
2384
{
2385
#if !defined(CONFIG_USER_ONLY)
2386
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2387
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2388
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2389
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2390
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2391
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2392
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2393
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2394
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2395
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2396
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2397
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2398
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2399
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2400
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2401
#endif
2402
}
2403

    
2404
static void init_excp_7400 (CPUPPCState *env)
2405
{
2406
#if !defined(CONFIG_USER_ONLY)
2407
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2408
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2409
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2410
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2411
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2412
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2413
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2414
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2415
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2416
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2417
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2418
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2419
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2420
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2421
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2422
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2423
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001700;
2424
#endif
2425
}
2426

    
2427
#if defined (TODO)
2428
static void init_excp_7450 (CPUPPCState *env)
2429
{
2430
#if !defined(CONFIG_USER_ONLY)
2431
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2432
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2433
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2434
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2435
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2436
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2437
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2438
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2439
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2440
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2441
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2442
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2443
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2444
    env->excp_vectors[POWERPC_EXCP_IFTLB]    = 0x00001000;
2445
    env->excp_vectors[POWERPC_EXCP_DLTLB]    = 0x00001100;
2446
    env->excp_vectors[POWERPC_EXCP_DSTLB]    = 0x00001200;
2447
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2448
    env->excp_vectors[POWERPC_EXCP_SMI]      = 0x00001400;
2449
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001600;
2450
#endif
2451
}
2452
#endif /* defined (TODO) */
2453

    
2454
#if defined (TARGET_PPC64)
2455
static void init_excp_970 (CPUPPCState *env)
2456
{
2457
#if !defined(CONFIG_USER_ONLY)
2458
    env->excp_vectors[POWERPC_EXCP_RESET]    = 0x00000100;
2459
    env->excp_vectors[POWERPC_EXCP_MCHECK]   = 0x00000200;
2460
    env->excp_vectors[POWERPC_EXCP_DSI]      = 0x00000300;
2461
    env->excp_vectors[POWERPC_EXCP_DSEG]     = 0x00000380;
2462
    env->excp_vectors[POWERPC_EXCP_ISI]      = 0x00000400;
2463
    env->excp_vectors[POWERPC_EXCP_ISEG]     = 0x00000480;
2464
    env->excp_vectors[POWERPC_EXCP_EXTERNAL] = 0x00000500;
2465
    env->excp_vectors[POWERPC_EXCP_ALIGN]    = 0x00000600;
2466
    env->excp_vectors[POWERPC_EXCP_PROGRAM]  = 0x00000700;
2467
    env->excp_vectors[POWERPC_EXCP_FPU]      = 0x00000800;
2468
    env->excp_vectors[POWERPC_EXCP_DECR]     = 0x00000900;
2469
#if defined(TARGET_PPC64H) /* PowerPC 64 with hypervisor mode support */
2470
    env->excp_vectors[POWERPC_EXCP_HDECR]    = 0x00000980;
2471
#endif
2472
    env->excp_vectors[POWERPC_EXCP_SYSCALL]  = 0x00000C00;
2473
    env->excp_vectors[POWERPC_EXCP_TRACE]    = 0x00000D00;
2474
    env->excp_vectors[POWERPC_EXCP_PERFM]    = 0x00000F00;
2475
    env->excp_vectors[POWERPC_EXCP_VPU]      = 0x00000F20;
2476
    env->excp_vectors[POWERPC_EXCP_IABR]     = 0x00001300;
2477
    env->excp_vectors[POWERPC_EXCP_MAINT]    = 0x00001600;
2478
    env->excp_vectors[POWERPC_EXCP_VPUA]     = 0x00001700;
2479
    env->excp_vectors[POWERPC_EXCP_THERM]    = 0x00001800;
2480
#endif
2481
}
2482
#endif
2483

    
2484
/*****************************************************************************/
2485
/* PowerPC implementations definitions                                       */
2486

    
2487
/* PowerPC 40x instruction set                                               */
2488
#define POWERPC_INSNS_EMB    (PPC_INSNS_BASE | PPC_EMB_COMMON)
2489

    
2490
/* PowerPC 401                                                               */
2491
#define POWERPC_INSNS_401    (POWERPC_INSNS_EMB |                             \
2492
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2493
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2494
#define POWERPC_MSRM_401     (0x00000000000FD201ULL)
2495
#define POWERPC_MMU_401      (POWERPC_MMU_REAL_4xx)
2496
#define POWERPC_EXCP_401     (POWERPC_EXCP_40x)
2497
#define POWERPC_INPUT_401    (PPC_FLAGS_INPUT_401)
2498
#define POWERPC_BFDM_401     (bfd_mach_ppc_403)
2499

    
2500
static void init_proc_401 (CPUPPCState *env)
2501
{
2502
    gen_spr_40x(env);
2503
    gen_spr_401_403(env);
2504
    gen_spr_401(env);
2505
    /* Bus access control */
2506
    spr_register(env, SPR_40x_SGR, "SGR",
2507
                 SPR_NOACCESS, SPR_NOACCESS,
2508
                 &spr_read_generic, &spr_write_generic,
2509
                 0xFFFFFFFF);
2510
    /* XXX : not implemented */
2511
    spr_register(env, SPR_40x_DCWR, "DCWR",
2512
                 SPR_NOACCESS, SPR_NOACCESS,
2513
                 &spr_read_generic, &spr_write_generic,
2514
                 0x00000000);
2515
    init_excp_4xx_real(env);
2516
    /* Allocate hardware IRQ controller */
2517
    ppc40x_irq_init(env);
2518
}
2519

    
2520
/* PowerPC 401x2                                                             */
2521
#define POWERPC_INSNS_401x2  (POWERPC_INSNS_EMB |                             \
2522
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2523
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2524
                              PPC_CACHE_DCBA | PPC_MFTB |                     \
2525
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2526
#define POWERPC_MSRM_401x2   (0x00000000001FD231ULL)
2527
#define POWERPC_MMU_401x2    (POWERPC_MMU_SOFT_4xx_Z)
2528
#define POWERPC_EXCP_401x2   (POWERPC_EXCP_40x)
2529
#define POWERPC_INPUT_401x2  (PPC_FLAGS_INPUT_401)
2530
#define POWERPC_BFDM_401x2   (bfd_mach_ppc_403)
2531

    
2532
static void init_proc_401x2 (CPUPPCState *env)
2533
{
2534
    gen_spr_40x(env);
2535
    gen_spr_401_403(env);
2536
    gen_spr_401x2(env);
2537
    gen_spr_compress(env);
2538
    /* Bus access control */
2539
    spr_register(env, SPR_40x_SGR, "SGR",
2540
                 SPR_NOACCESS, SPR_NOACCESS,
2541
                 &spr_read_generic, &spr_write_generic,
2542
                 0xFFFFFFFF);
2543
    /* XXX : not implemented */
2544
    spr_register(env, SPR_40x_DCWR, "DCWR",
2545
                 SPR_NOACCESS, SPR_NOACCESS,
2546
                 &spr_read_generic, &spr_write_generic,
2547
                 0x00000000);
2548
    /* Memory management */
2549
    env->nb_tlb = 64;
2550
    env->nb_ways = 1;
2551
    env->id_tlbs = 0;
2552
    init_excp_4xx_softmmu(env);
2553
    /* Allocate hardware IRQ controller */
2554
    ppc40x_irq_init(env);
2555
}
2556

    
2557
/* PowerPC 401x3                                                             */
2558
#if defined(TODO)
2559
#define POWERPC_INSNS_401x3  (POWERPC_INSNS_EMB |                             \
2560
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2561
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2562
                              PPC_CACHE_DCBA | PPC_MFTB |                     \
2563
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2564
#define POWERPC_MSRM_401x3   (0x00000000001FD631ULL)
2565
#define POWERPC_MMU_401x3    (POWERPC_MMU_SOFT_4xx_Z)
2566
#define POWERPC_EXCP_401x3   (POWERPC_EXCP_40x)
2567
#define POWERPC_INPUT_401x3  (PPC_FLAGS_INPUT_401)
2568
#define POWERPC_BFDM_401x3   (bfd_mach_ppc_403)
2569

    
2570
static void init_proc_401x3 (CPUPPCState *env)
2571
{
2572
    gen_spr_40x(env);
2573
    gen_spr_401_403(env);
2574
    gen_spr_401(env);
2575
    gen_spr_401x2(env);
2576
    gen_spr_compress(env);
2577
    init_excp_4xx_softmmu(env);
2578
    /* Allocate hardware IRQ controller */
2579
    ppc40x_irq_init(env);
2580
}
2581
#endif /* TODO */
2582

    
2583
/* IOP480                                                                    */
2584
#define POWERPC_INSNS_IOP480 (POWERPC_INSNS_EMB |                             \
2585
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2586
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2587
                              PPC_CACHE_DCBA |                                \
2588
                              PPC_4xx_COMMON | PPC_40x_EXCP |  PPC_40x_ICBT)
2589
#define POWERPC_MSRM_IOP480  (0x00000000001FD231ULL)
2590
#define POWERPC_MMU_IOP480   (POWERPC_MMU_SOFT_4xx_Z)
2591
#define POWERPC_EXCP_IOP480  (POWERPC_EXCP_40x)
2592
#define POWERPC_INPUT_IOP480 (PPC_FLAGS_INPUT_401)
2593
#define POWERPC_BFDM_IOP480  (bfd_mach_ppc_403)
2594

    
2595
static void init_proc_IOP480 (CPUPPCState *env)
2596
{
2597
    gen_spr_40x(env);
2598
    gen_spr_401_403(env);
2599
    gen_spr_401x2(env);
2600
    gen_spr_compress(env);
2601
    /* Bus access control */
2602
    spr_register(env, SPR_40x_SGR, "SGR",
2603
                 SPR_NOACCESS, SPR_NOACCESS,
2604
                 &spr_read_generic, &spr_write_generic,
2605
                 0xFFFFFFFF);
2606
    /* XXX : not implemented */
2607
    spr_register(env, SPR_40x_DCWR, "DCWR",
2608
                 SPR_NOACCESS, SPR_NOACCESS,
2609
                 &spr_read_generic, &spr_write_generic,
2610
                 0x00000000);
2611
    /* Memory management */
2612
    env->nb_tlb = 64;
2613
    env->nb_ways = 1;
2614
    env->id_tlbs = 0;
2615
    init_excp_4xx_softmmu(env);
2616
    /* Allocate hardware IRQ controller */
2617
    ppc40x_irq_init(env);
2618
}
2619

    
2620
/* PowerPC 403                                                               */
2621
#define POWERPC_INSNS_403    (POWERPC_INSNS_EMB |                             \
2622
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2623
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2624
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2625
#define POWERPC_MSRM_403     (0x000000000007D00DULL)
2626
#define POWERPC_MMU_403      (POWERPC_MMU_REAL_4xx)
2627
#define POWERPC_EXCP_403     (POWERPC_EXCP_40x)
2628
#define POWERPC_INPUT_403    (PPC_FLAGS_INPUT_401)
2629
#define POWERPC_BFDM_403     (bfd_mach_ppc_403)
2630

    
2631
static void init_proc_403 (CPUPPCState *env)
2632
{
2633
    gen_spr_40x(env);
2634
    gen_spr_401_403(env);
2635
    gen_spr_403(env);
2636
    gen_spr_403_real(env);
2637
    init_excp_4xx_real(env);
2638
    /* Allocate hardware IRQ controller */
2639
    ppc40x_irq_init(env);
2640
}
2641

    
2642
/* PowerPC 403 GCX                                                           */
2643
#define POWERPC_INSNS_403GCX (POWERPC_INSNS_EMB |                             \
2644
                              PPC_MEM_SYNC | PPC_MEM_EIEIO |                  \
2645
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2646
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT)
2647
#define POWERPC_MSRM_403GCX  (0x000000000007D00DULL)
2648
#define POWERPC_MMU_403GCX   (POWERPC_MMU_SOFT_4xx_Z)
2649
#define POWERPC_EXCP_403GCX  (POWERPC_EXCP_40x)
2650
#define POWERPC_INPUT_403GCX (PPC_FLAGS_INPUT_401)
2651
#define POWERPC_BFDM_403GCX  (bfd_mach_ppc_403)
2652

    
2653
static void init_proc_403GCX (CPUPPCState *env)
2654
{
2655
    gen_spr_40x(env);
2656
    gen_spr_401_403(env);
2657
    gen_spr_403(env);
2658
    gen_spr_403_real(env);
2659
    gen_spr_403_mmu(env);
2660
    /* Bus access control */
2661
    spr_register(env, SPR_40x_SGR, "SGR",
2662
                 SPR_NOACCESS, SPR_NOACCESS,
2663
                 &spr_read_generic, &spr_write_generic,
2664
                 0xFFFFFFFF);
2665
    /* XXX : not implemented */
2666
    spr_register(env, SPR_40x_DCWR, "DCWR",
2667
                 SPR_NOACCESS, SPR_NOACCESS,
2668
                 &spr_read_generic, &spr_write_generic,
2669
                 0x00000000);
2670
    /* Memory management */
2671
    env->nb_tlb = 64;
2672
    env->nb_ways = 1;
2673
    env->id_tlbs = 0;
2674
    init_excp_4xx_softmmu(env);
2675
    /* Allocate hardware IRQ controller */
2676
    ppc40x_irq_init(env);
2677
}
2678

    
2679
/* PowerPC 405                                                               */
2680
#define POWERPC_INSNS_405    (POWERPC_INSNS_EMB | PPC_MFTB |                  \
2681
                              PPC_MEM_SYNC | PPC_MEM_EIEIO | PPC_CACHE_DCBA | \
2682
                              PPC_40x_TLB | PPC_MEM_TLBIA | PPC_MEM_TLBSYNC | \
2683
                              PPC_4xx_COMMON | PPC_40x_EXCP | PPC_40x_ICBT |  \
2684
                              PPC_405_MAC)
2685
#define POWERPC_MSRM_405     (0x000000000006E630ULL)
2686
#define POWERPC_MMU_405      (POWERPC_MMU_SOFT_4xx)
2687
#define POWERPC_EXCP_405     (POWERPC_EXCP_40x)
2688
#define POWERPC_INPUT_405    (PPC_FLAGS_INPUT_405)
2689
#define POWERPC_BFDM_405     (bfd_mach_ppc_403)
2690

    
2691
static void init_proc_405 (CPUPPCState *env)
2692
{
2693
    /* Time base */
2694
    gen_tbl(env);
2695
    gen_spr_40x(env);
2696
    gen_spr_405(env);
2697
    /* Bus access control */
2698
    spr_register(env, SPR_40x_SGR, "SGR",
2699
                 SPR_NOACCESS, SPR_NOACCESS,
2700
                 &spr_read_generic, &spr_write_generic,
2701
                 0xFFFFFFFF);
2702
    /* XXX : not implemented */
2703
    spr_register(env, SPR_40x_DCWR, "DCWR",
2704
                 SPR_NOACCESS, SPR_NOACCESS,
2705
                 &spr_read_generic, &spr_write_generic,
2706
                 0x00000000);
2707
    /* Memory management */
2708
    env->nb_tlb = 64;
2709
    env->nb_ways = 1;
2710
    env->id_tlbs = 0;
2711
    init_excp_4xx_softmmu(env);
2712
    /* Allocate hardware IRQ controller */
2713
    ppc40x_irq_init(env);
2714
}
2715

    
2716
/* PowerPC 440 EP                                                            */
2717
#define POWERPC_INSNS_440EP  (POWERPC_INSNS_EMB |                             \
2718
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2719
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2720
                              PPC_440_SPEC | PPC_RFMCI)
2721
#define POWERPC_MSRM_440EP   (0x000000000006D630ULL)
2722
#define POWERPC_MMU_440EP    (POWERPC_MMU_BOOKE)
2723
#define POWERPC_EXCP_440EP   (POWERPC_EXCP_BOOKE)
2724
#define POWERPC_INPUT_440EP  (PPC_FLAGS_INPUT_BookE)
2725
#define POWERPC_BFDM_440EP   (bfd_mach_ppc_403)
2726

    
2727
static void init_proc_440EP (CPUPPCState *env)
2728
{
2729
    /* Time base */
2730
    gen_tbl(env);
2731
    gen_spr_BookE(env);
2732
    gen_spr_440(env);
2733
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
2734
                 SPR_NOACCESS, SPR_NOACCESS,
2735
                 &spr_read_generic, &spr_write_generic,
2736
                 0x00000000);
2737
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
2738
                 SPR_NOACCESS, SPR_NOACCESS,
2739
                 &spr_read_generic, &spr_write_generic,
2740
                 0x00000000);
2741
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
2742
                 SPR_NOACCESS, SPR_NOACCESS,
2743
                 &spr_read_generic, &spr_write_generic,
2744
                 0x00000000);
2745
    spr_register(env, SPR_440_CCR1, "CCR1",
2746
                 SPR_NOACCESS, SPR_NOACCESS,
2747
                 &spr_read_generic, &spr_write_generic,
2748
                 0x00000000);
2749
    /* Memory management */
2750
    env->nb_tlb = 64;
2751
    env->nb_ways = 1;
2752
    env->id_tlbs = 0;
2753
    init_excp_BookE(env);
2754
    /* XXX: TODO: allocate internal IRQ controller */
2755
}
2756

    
2757
/* PowerPC 440 GP                                                            */
2758
#define POWERPC_INSNS_440GP  (POWERPC_INSNS_EMB |                             \
2759
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2760
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
2761
                              PPC_405_MAC | PPC_440_SPEC)
2762
#define POWERPC_MSRM_440GP   (0x000000000006FF30ULL)
2763
#define POWERPC_MMU_440GP    (POWERPC_MMU_BOOKE)
2764
#define POWERPC_EXCP_440GP   (POWERPC_EXCP_BOOKE)
2765
#define POWERPC_INPUT_440GP  (PPC_FLAGS_INPUT_BookE)
2766
#define POWERPC_BFDM_440GP   (bfd_mach_ppc_403)
2767

    
2768
static void init_proc_440GP (CPUPPCState *env)
2769
{
2770
    /* Time base */
2771
    gen_tbl(env);
2772
    gen_spr_BookE(env);
2773
    gen_spr_440(env);
2774
    /* Memory management */
2775
    env->nb_tlb = 64;
2776
    env->nb_ways = 1;
2777
    env->id_tlbs = 0;
2778
    init_excp_BookE(env);
2779
    /* XXX: TODO: allocate internal IRQ controller */
2780
}
2781

    
2782
/* PowerPC 440x4                                                             */
2783
#if defined(TODO)
2784
#define POWERPC_INSNS_440x4  (POWERPC_INSNS_EMB |                             \
2785
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2786
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2787
                              PPC_440_SPEC)
2788
#define POWERPC_MSRM_440x4   (0x000000000006FF30ULL)
2789
#define POWERPC_MMU_440x4    (POWERPC_MMU_BOOKE)
2790
#define POWERPC_EXCP_440x4   (POWERPC_EXCP_BOOKE)
2791
#define POWERPC_INPUT_440x4  (PPC_FLAGS_INPUT_BookE)
2792
#define POWERPC_BFDM_440x4   (bfd_mach_ppc_403)
2793

    
2794
static void init_proc_440x4 (CPUPPCState *env)
2795
{
2796
    /* Time base */
2797
    gen_tbl(env);
2798
    gen_spr_BookE(env);
2799
    gen_spr_440(env);
2800
    /* Memory management */
2801
    env->nb_tlb = 64;
2802
    env->nb_ways = 1;
2803
    env->id_tlbs = 0;
2804
    init_excp_BookE(env);
2805
    /* XXX: TODO: allocate internal IRQ controller */
2806
}
2807
#endif /* TODO */
2808

    
2809
/* PowerPC 440x5                                                             */
2810
#define POWERPC_INSNS_440x5  (POWERPC_INSNS_EMB |                             \
2811
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2812
                              PPC_BOOKE | PPC_4xx_COMMON | PPC_405_MAC |      \
2813
                              PPC_440_SPEC | PPC_RFMCI)
2814
#define POWERPC_MSRM_440x5   (0x000000000006FF30ULL)
2815
#define POWERPC_MMU_440x5    (POWERPC_MMU_BOOKE)
2816
#define POWERPC_EXCP_440x5   (POWERPC_EXCP_BOOKE)
2817
#define POWERPC_INPUT_440x5  (PPC_FLAGS_INPUT_BookE)
2818
#define POWERPC_BFDM_440x5   (bfd_mach_ppc_403)
2819

    
2820
static void init_proc_440x5 (CPUPPCState *env)
2821
{
2822
    /* Time base */
2823
    gen_tbl(env);
2824
    gen_spr_BookE(env);
2825
    gen_spr_440(env);
2826
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
2827
                 SPR_NOACCESS, SPR_NOACCESS,
2828
                 &spr_read_generic, &spr_write_generic,
2829
                 0x00000000);
2830
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
2831
                 SPR_NOACCESS, SPR_NOACCESS,
2832
                 &spr_read_generic, &spr_write_generic,
2833
                 0x00000000);
2834
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
2835
                 SPR_NOACCESS, SPR_NOACCESS,
2836
                 &spr_read_generic, &spr_write_generic,
2837
                 0x00000000);
2838
    spr_register(env, SPR_440_CCR1, "CCR1",
2839
                 SPR_NOACCESS, SPR_NOACCESS,
2840
                 &spr_read_generic, &spr_write_generic,
2841
                 0x00000000);
2842
    /* Memory management */
2843
    env->nb_tlb = 64;
2844
    env->nb_ways = 1;
2845
    env->id_tlbs = 0;
2846
    init_excp_BookE(env);
2847
    /* XXX: TODO: allocate internal IRQ controller */
2848
}
2849

    
2850
/* PowerPC 460 (guessed)                                                     */
2851
#if defined(TODO)
2852
#define POWERPC_INSNS_460F   (POWERPC_INSNS_EMB |                             \
2853
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2854
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
2855
                              PPC_405_MAC | PPC_440_SPEC | PPC_DCRUX)
2856
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
2857
#define POWERPC_MMU_460      (POWERPC_MMU_BOOKE)
2858
#define POWERPC_EXCP_460     (POWERPC_EXCP_BOOKE)
2859
#define POWERPC_INPUT_460    (PPC_FLAGS_INPUT_BookE)
2860
#define POWERPC_BFDM_460     (bfd_mach_ppc_403)
2861

    
2862
static void init_proc_460 (CPUPPCState *env)
2863
{
2864
    /* Time base */
2865
    gen_tbl(env);
2866
    gen_spr_BookE(env);
2867
    gen_spr_440(env);
2868
    spr_register(env, SPR_BOOKE_MCSR, "MCSR",
2869
                 SPR_NOACCESS, SPR_NOACCESS,
2870
                 &spr_read_generic, &spr_write_generic,
2871
                 0x00000000);
2872
    spr_register(env, SPR_BOOKE_MCSRR0, "MCSRR0",
2873
                 SPR_NOACCESS, SPR_NOACCESS,
2874
                 &spr_read_generic, &spr_write_generic,
2875
                 0x00000000);
2876
    spr_register(env, SPR_BOOKE_MCSRR1, "MCSRR1",
2877
                 SPR_NOACCESS, SPR_NOACCESS,
2878
                 &spr_read_generic, &spr_write_generic,
2879
                 0x00000000);
2880
    spr_register(env, SPR_440_CCR1, "CCR1",
2881
                 SPR_NOACCESS, SPR_NOACCESS,
2882
                 &spr_read_generic, &spr_write_generic,
2883
                 0x00000000);
2884
    spr_register(env, SPR_DCRIPR, "SPR_DCRIPR",
2885
                 &spr_read_generic, &spr_write_generic,
2886
                 &spr_read_generic, &spr_write_generic,
2887
                 0x00000000);
2888
    /* Memory management */
2889
    env->nb_tlb = 64;
2890
    env->nb_ways = 1;
2891
    env->id_tlbs = 0;
2892
    init_excp_BookE(env);
2893
    /* XXX: TODO: allocate internal IRQ controller */
2894
}
2895
#endif /* TODO */
2896

    
2897
/* PowerPC 460F (guessed)                                                    */
2898
#if defined(TODO)
2899
#define POWERPC_INSNS_460F   (POWERPC_INSNS_EMB |                             \
2900
                              PPC_CACHE_DCBA | PPC_MEM_TLBSYNC |              \
2901
                              PPC_FLOAT | PPC_FLOAT_FSQRT | PPC_FLOAT_FRES |  \
2902
                              PPC_FLOAT_FRSQRTE | PPC_FLOAT_FSEL |            \
2903
                              PPC_FLOAT_STFIWX |                              \
2904
                              PPC_BOOKE | PPC_BOOKE_EXT | PPC_4xx_COMMON |    \
2905
                              PPC_405_MAC | PPC_440_SPEC | PPC_DCRUX)
2906
#define POWERPC_MSRM_460     (0x000000000006FF30ULL)
2907
#define POWERPC_MMU_460F     (POWERPC_MMU_BOOKE)
2908
#define POWERPC_EXCP_460F    (POWERPC_EXCP_BOOKE)
2909
#define POWERPC_INPUT_460F   (PPC_FLAGS_INPUT_BookE)
2910
#define POWERPC_BFDM_460F    (bfd_mach_ppc_403)
2911

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

    
2947
/* Generic BookE PowerPC                                                     */
2948
#if defined(TODO)
2949
#define POWERPC_INSNS_BookE  (POWERPC_INSNS_EMB |                             \
2950
                              PPC_MEM_EIEIO | PPC_MEM_TLBSYNC |               \
2951
                              PPC_CACHE_DCBA |                                \
2952
                              PPC_FLOAT | PPC_FLOAT_FSQRT |                   \
2953
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
2954
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIW |              \
2955
                              PPC_BOOKE)
2956
#define POWERPC_MSRM_BookE   (0x000000000006D630ULL)
2957
#define POWERPC_MMU_BookE    (POWERPC_MMU_BOOKE)
2958
#define POWERPC_EXCP_BookE   (POWERPC_EXCP_BOOKE)
2959
#define POWERPC_INPUT_BookE  (PPC_FLAGS_INPUT_BookE)
2960
#define POWERPC_BFDM_BookE   (bfd_mach_ppc_403)
2961

    
2962
static void init_proc_BookE (CPUPPCState *env)
2963
{
2964
    init_excp_BookE(env);
2965
}
2966
#endif /* TODO */
2967

    
2968
/* e200 core                                                                 */
2969
#if defined(TODO)
2970
#endif /* TODO */
2971

    
2972
/* e300 core                                                                 */
2973
#if defined(TODO)
2974
#endif /* TODO */
2975

    
2976
/* e500 core                                                                 */
2977
#if defined(TODO)
2978
#define POWERPC_INSNS_e500   (POWERPC_INSNS_EMB |                             \
2979
                              PPC_MEM_EIEIO | PPC_MEM_TLBSYNC |               \
2980
                              PPC_CACHE_DCBA |                                \
2981
                              PPC_BOOKE | PPC_E500_VECTOR)
2982
#define POWERPC_MMU_e500     (POWERPC_MMU_SOFT_4xx)
2983
#define POWERPC_EXCP_e500    (POWERPC_EXCP_40x)
2984
#define POWERPC_INPUT_e500   (PPC_FLAGS_INPUT_BookE)
2985
#define POWERPC_BFDM_e500    (bfd_mach_ppc_403)
2986

    
2987
static void init_proc_e500 (CPUPPCState *env)
2988
{
2989
    /* Time base */
2990
    gen_tbl(env);
2991
    gen_spr_BookE(env);
2992
    /* Memory management */
2993
    gen_spr_BookE_FSL(env);
2994
    env->nb_tlb = 64;
2995
    env->nb_ways = 1;
2996
    env->id_tlbs = 0;
2997
    init_excp_BookE(env);
2998
    /* XXX: TODO: allocate internal IRQ controller */
2999
}
3000
#endif /* TODO */
3001

    
3002
/* e600 core                                                                 */
3003
#if defined(TODO)
3004
#endif /* TODO */
3005

    
3006
/* Non-embedded PowerPC                                                      */
3007
/* Base instructions set for all 6xx/7xx/74xx/970 PowerPC                    */
3008
#define POWERPC_INSNS_6xx    (PPC_INSNS_BASE | PPC_FLOAT | PPC_MEM_SYNC |     \
3009
                              PPC_MEM_EIEIO | PPC_SEGMENT | PPC_MEM_TLBIE)
3010
/* Instructions common to all 6xx/7xx/74xx/970 PowerPC except 601 & 602      */
3011
#define POWERPC_INSNS_WORKS  (POWERPC_INSNS_6xx | PPC_FLOAT_FSQRT |           \
3012
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3013
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |             \
3014
                              PPC_MEM_TLBSYNC | PPC_MFTB)
3015

    
3016
/* POWER : same as 601, without mfmsr, mfsr                                  */
3017
#if defined(TODO)
3018
#define POWERPC_INSNS_POWER  (XXX_TODO)
3019
/* POWER RSC (from RAD6000) */
3020
#define POWERPC_MSRM_POWER   (0x00000000FEF0ULL)
3021
#endif /* TODO */
3022

    
3023
/* PowerPC 601                                                               */
3024
#define POWERPC_INSNS_601    (POWERPC_INSNS_6xx | PPC_EXTERN | PPC_POWER_BR)
3025
#define POWERPC_MSRM_601     (0x000000000000FE70ULL)
3026
//#define POWERPC_MMU_601      (POWERPC_MMU_601)
3027
//#define POWERPC_EXCP_601     (POWERPC_EXCP_601)
3028
#define POWERPC_INPUT_601    (PPC_FLAGS_INPUT_6xx)
3029
#define POWERPC_BFDM_601     (bfd_mach_ppc_601)
3030

    
3031
static void init_proc_601 (CPUPPCState *env)
3032
{
3033
    gen_spr_ne_601(env);
3034
    gen_spr_601(env);
3035
    /* Hardware implementation registers */
3036
    /* XXX : not implemented */
3037
    spr_register(env, SPR_HID0, "HID0",
3038
                 SPR_NOACCESS, SPR_NOACCESS,
3039
                 &spr_read_generic, &spr_write_generic,
3040
                 0x00000000);
3041
    /* XXX : not implemented */
3042
    spr_register(env, SPR_HID1, "HID1",
3043
                 SPR_NOACCESS, SPR_NOACCESS,
3044
                 &spr_read_generic, &spr_write_generic,
3045
                 0x00000000);
3046
    /* XXX : not implemented */
3047
    spr_register(env, SPR_601_HID2, "HID2",
3048
                 SPR_NOACCESS, SPR_NOACCESS,
3049
                 &spr_read_generic, &spr_write_generic,
3050
                 0x00000000);
3051
    /* XXX : not implemented */
3052
    spr_register(env, SPR_601_HID5, "HID5",
3053
                 SPR_NOACCESS, SPR_NOACCESS,
3054
                 &spr_read_generic, &spr_write_generic,
3055
                 0x00000000);
3056
    /* XXX : not implemented */
3057
    spr_register(env, SPR_601_HID15, "HID15",
3058
                 SPR_NOACCESS, SPR_NOACCESS,
3059
                 &spr_read_generic, &spr_write_generic,
3060
                 0x00000000);
3061
    /* Memory management */
3062
    env->nb_tlb = 64;
3063
    env->nb_ways = 2;
3064
    env->id_tlbs = 0;
3065
    env->id_tlbs = 0;
3066
    init_excp_601(env);
3067
    /* XXX: TODO: allocate internal IRQ controller */
3068
}
3069

    
3070
/* PowerPC 602                                                               */
3071
#define POWERPC_INSNS_602    (POWERPC_INSNS_6xx | PPC_MFTB |                  \
3072
                              PPC_FLOAT_FRES | PPC_FLOAT_FRSQRTE |            \
3073
                              PPC_FLOAT_FSEL | PPC_FLOAT_STFIWX |             \
3074
                              PPC_6xx_TLB | PPC_MEM_TLBSYNC | PPC_602_SPEC)
3075
#define POWERPC_MSRM_602     (0x000000000033FF73ULL)
3076
#define POWERPC_MMU_602      (POWERPC_MMU_SOFT_6xx)
3077
//#define POWERPC_EXCP_602     (POWERPC_EXCP_602)
3078
#define POWERPC_INPUT_602    (PPC_FLAGS_INPUT_6xx)
3079
#define POWERPC_BFDM_602     (bfd_mach_ppc_602)
3080

    
3081
static void init_proc_602 (CPUPPCState *env)
3082
{
3083
    gen_spr_ne_601(env);
3084
    gen_spr_602(env);
3085
    /* Time base */
3086
    gen_tbl(env);
3087
    /* hardware implementation registers */
3088
    /* XXX : not implemented */
3089
    spr_register(env, SPR_HID0, "HID0",
3090
                 SPR_NOACCESS, SPR_NOACCESS,
3091
                 &spr_read_generic, &spr_write_generic,
3092
                 0x00000000);
3093
    /* XXX : not implemented */
3094
    spr_register(env, SPR_HID1, "HID1",
3095
                 SPR_NOACCESS, SPR_NOACCESS,
3096
                 &spr_read_generic, &spr_write_generic,
3097
                 0x00000000);
3098
    /* Memory management */
3099
    gen_low_BATs(env);
3100
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3101
    init_excp_602(env);
3102
    /* Allocate hardware IRQ controller */
3103
    ppc6xx_irq_init(env);
3104
}
3105

    
3106
/* PowerPC 603                                                               */
3107
#define POWERPC_INSNS_603    (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3108
#define POWERPC_MSRM_603     (0x000000000001FF73ULL)
3109
#define POWERPC_MMU_603      (POWERPC_MMU_SOFT_6xx)
3110
//#define POWERPC_EXCP_603     (POWERPC_EXCP_603)
3111
#define POWERPC_INPUT_603    (PPC_FLAGS_INPUT_6xx)
3112
#define POWERPC_BFDM_603     (bfd_mach_ppc_603)
3113

    
3114
static void init_proc_603 (CPUPPCState *env)
3115
{
3116
    gen_spr_ne_601(env);
3117
    gen_spr_603(env);
3118
    /* Time base */
3119
    gen_tbl(env);
3120
    /* hardware implementation registers */
3121
    /* XXX : not implemented */
3122
    spr_register(env, SPR_HID0, "HID0",
3123
                 SPR_NOACCESS, SPR_NOACCESS,
3124
                 &spr_read_generic, &spr_write_generic,
3125
                 0x00000000);
3126
    /* XXX : not implemented */
3127
    spr_register(env, SPR_HID1, "HID1",
3128
                 SPR_NOACCESS, SPR_NOACCESS,
3129
                 &spr_read_generic, &spr_write_generic,
3130
                 0x00000000);
3131
    /* Memory management */
3132
    gen_low_BATs(env);
3133
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3134
    init_excp_603(env);
3135
    /* Allocate hardware IRQ controller */
3136
    ppc6xx_irq_init(env);
3137
}
3138

    
3139
/* PowerPC 603e                                                              */
3140
#define POWERPC_INSNS_603E   (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3141
#define POWERPC_MSRM_603E    (0x000000000007FF73ULL)
3142
#define POWERPC_MMU_603E     (POWERPC_MMU_SOFT_6xx)
3143
//#define POWERPC_EXCP_603E    (POWERPC_EXCP_603E)
3144
#define POWERPC_INPUT_603E   (PPC_FLAGS_INPUT_6xx)
3145
#define POWERPC_BFDM_603E    (bfd_mach_ppc_ec603e)
3146

    
3147
static void init_proc_603E (CPUPPCState *env)
3148
{
3149
    gen_spr_ne_601(env);
3150
    gen_spr_603(env);
3151
    /* Time base */
3152
    gen_tbl(env);
3153
    /* hardware implementation registers */
3154
    /* XXX : not implemented */
3155
    spr_register(env, SPR_HID0, "HID0",
3156
                 SPR_NOACCESS, SPR_NOACCESS,
3157
                 &spr_read_generic, &spr_write_generic,
3158
                 0x00000000);
3159
    /* XXX : not implemented */
3160
    spr_register(env, SPR_HID1, "HID1",
3161
                 SPR_NOACCESS, SPR_NOACCESS,
3162
                 &spr_read_generic, &spr_write_generic,
3163
                 0x00000000);
3164
    /* XXX : not implemented */
3165
    spr_register(env, SPR_IABR, "IABR",
3166
                 SPR_NOACCESS, SPR_NOACCESS,
3167
                 &spr_read_generic, &spr_write_generic,
3168
                 0x00000000);
3169
    /* Memory management */
3170
    gen_low_BATs(env);
3171
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3172
    init_excp_603(env);
3173
    /* Allocate hardware IRQ controller */
3174
    ppc6xx_irq_init(env);
3175
}
3176

    
3177
/* PowerPC G2                                                                */
3178
#define POWERPC_INSNS_G2     (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3179
#define POWERPC_MSRM_G2      (0x000000000006FFF2ULL)
3180
#define POWERPC_MMU_G2       (POWERPC_MMU_SOFT_6xx)
3181
//#define POWERPC_EXCP_G2      (POWERPC_EXCP_G2)
3182
#define POWERPC_INPUT_G2     (PPC_FLAGS_INPUT_6xx)
3183
#define POWERPC_BFDM_G2      (bfd_mach_ppc_ec603e)
3184

    
3185
static void init_proc_G2 (CPUPPCState *env)
3186
{
3187
    gen_spr_ne_601(env);
3188
    gen_spr_G2_755(env);
3189
    gen_spr_G2(env);
3190
    /* Time base */
3191
    gen_tbl(env);
3192
    /* Hardware implementation register */
3193
    /* XXX : not implemented */
3194
    spr_register(env, SPR_HID0, "HID0",
3195
                 SPR_NOACCESS, SPR_NOACCESS,
3196
                 &spr_read_generic, &spr_write_generic,
3197
                 0x00000000);
3198
    /* XXX : not implemented */
3199
    spr_register(env, SPR_HID1, "HID1",
3200
                 SPR_NOACCESS, SPR_NOACCESS,
3201
                 &spr_read_generic, &spr_write_generic,
3202
                 0x00000000);
3203
    /* XXX : not implemented */
3204
    spr_register(env, SPR_HID2, "HID2",
3205
                 SPR_NOACCESS, SPR_NOACCESS,
3206
                 &spr_read_generic, &spr_write_generic,
3207
                 0x00000000);
3208
    /* Memory management */
3209
    gen_low_BATs(env);
3210
    gen_high_BATs(env);
3211
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3212
    init_excp_G2(env);
3213
    /* Allocate hardware IRQ controller */
3214
    ppc6xx_irq_init(env);
3215
}
3216

    
3217
/* PowerPC G2LE                                                              */
3218
#define POWERPC_INSNS_G2LE   (POWERPC_INSNS_WORKS | PPC_6xx_TLB | PPC_EXTERN)
3219
#define POWERPC_MSRM_G2LE    (0x000000000007FFF3ULL)
3220
#define POWERPC_MMU_G2LE     (POWERPC_MMU_SOFT_6xx)
3221
#define POWERPC_EXCP_G2LE    (POWERPC_EXCP_G2)
3222
#define POWERPC_INPUT_G2LE   (PPC_FLAGS_INPUT_6xx)
3223
#define POWERPC_BFDM_G2LE    (bfd_mach_ppc_ec603e)
3224

    
3225
static void init_proc_G2LE (CPUPPCState *env)
3226
{
3227
    gen_spr_ne_601(env);
3228
    gen_spr_G2_755(env);
3229
    gen_spr_G2(env);
3230
    /* Time base */
3231
    gen_tbl(env);
3232
    /* Hardware implementation register */
3233
    /* XXX : not implemented */
3234
    spr_register(env, SPR_HID0, "HID0",
3235
                 SPR_NOACCESS, SPR_NOACCESS,
3236
                 &spr_read_generic, &spr_write_generic,
3237
                 0x00000000);
3238
    /* XXX : not implemented */
3239
    spr_register(env, SPR_HID1, "HID1",
3240
                 SPR_NOACCESS, SPR_NOACCESS,
3241
                 &spr_read_generic, &spr_write_generic,
3242
                 0x00000000);
3243
    /* XXX : not implemented */
3244
    spr_register(env, SPR_HID2, "HID2",
3245
                 SPR_NOACCESS, SPR_NOACCESS,
3246
                 &spr_read_generic, &spr_write_generic,
3247
                 0x00000000);
3248
    /* Memory management */
3249
    gen_low_BATs(env);
3250
    gen_high_BATs(env);
3251
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3252
    init_excp_G2(env);
3253
    /* Allocate hardware IRQ controller */
3254
    ppc6xx_irq_init(env);
3255
}
3256

    
3257
/* PowerPC 604                                                               */
3258
#define POWERPC_INSNS_604    (POWERPC_INSNS_WORKS | PPC_EXTERN)
3259
#define POWERPC_MSRM_604     (0x000000000005FF77ULL)
3260
#define POWERPC_MMU_604      (POWERPC_MMU_32B)
3261
//#define POWERPC_EXCP_604     (POWERPC_EXCP_604)
3262
#define POWERPC_INPUT_604    (PPC_FLAGS_INPUT_6xx)
3263
#define POWERPC_BFDM_604     (bfd_mach_ppc_604)
3264

    
3265
static void init_proc_604 (CPUPPCState *env)
3266
{
3267
    gen_spr_ne_601(env);
3268
    gen_spr_604(env);
3269
    /* Time base */
3270
    gen_tbl(env);
3271
    /* Hardware implementation registers */
3272
    /* XXX : not implemented */
3273
    spr_register(env, SPR_HID0, "HID0",
3274
                 SPR_NOACCESS, SPR_NOACCESS,
3275
                 &spr_read_generic, &spr_write_generic,
3276
                 0x00000000);
3277
    /* XXX : not implemented */
3278
    spr_register(env, SPR_HID1, "HID1",
3279
                 SPR_NOACCESS, SPR_NOACCESS,
3280
                 &spr_read_generic, &spr_write_generic,
3281
                 0x00000000);
3282
    /* Memory management */
3283
    gen_low_BATs(env);
3284
    init_excp_604(env);
3285
    /* Allocate hardware IRQ controller */
3286
    ppc6xx_irq_init(env);
3287
}
3288

    
3289
/* PowerPC 740/750 (aka G3)                                                  */
3290
#define POWERPC_INSNS_7x0    (POWERPC_INSNS_WORKS | PPC_EXTERN)
3291
#define POWERPC_MSRM_7x0     (0x000000000007FF77ULL)
3292
#define POWERPC_MMU_7x0      (POWERPC_MMU_32B)
3293
//#define POWERPC_EXCP_7x0     (POWERPC_EXCP_7x0)
3294
#define POWERPC_INPUT_7x0    (PPC_FLAGS_INPUT_6xx)
3295
#define POWERPC_BFDM_7x0     (bfd_mach_ppc_750)
3296

    
3297
static void init_proc_7x0 (CPUPPCState *env)
3298
{
3299
    gen_spr_ne_601(env);
3300
    gen_spr_7xx(env);
3301
    /* Time base */
3302
    gen_tbl(env);
3303
    /* Thermal management */
3304
    gen_spr_thrm(env);
3305
    /* Hardware implementation registers */
3306
    /* XXX : not implemented */
3307
    spr_register(env, SPR_HID0, "HID0",
3308
                 SPR_NOACCESS, SPR_NOACCESS,
3309
                 &spr_read_generic, &spr_write_generic,
3310
                 0x00000000);
3311
    /* XXX : not implemented */
3312
    spr_register(env, SPR_HID1, "HID1",
3313
                 SPR_NOACCESS, SPR_NOACCESS,
3314
                 &spr_read_generic, &spr_write_generic,
3315
                 0x00000000);
3316
    /* Memory management */
3317
    gen_low_BATs(env);
3318
    init_excp_7x0(env);
3319
    /* Allocate hardware IRQ controller */
3320
    ppc6xx_irq_init(env);
3321
}
3322

    
3323
/* PowerPC 750FX/GX                                                          */
3324
#define POWERPC_INSNS_750fx  (POWERPC_INSNS_WORKS | PPC_EXTERN)
3325
#define POWERPC_MSRM_750fx   (0x000000000007FF77ULL)
3326
#define POWERPC_MMU_750fx    (POWERPC_MMU_32B)
3327
#define POWERPC_EXCP_750fx   (POWERPC_EXCP_7x0)
3328
#define POWERPC_INPUT_750fx  (PPC_FLAGS_INPUT_6xx)
3329
#define POWERPC_BFDM_750fx   (bfd_mach_ppc_750)
3330

    
3331
static void init_proc_750fx (CPUPPCState *env)
3332
{
3333
    gen_spr_ne_601(env);
3334
    gen_spr_7xx(env);
3335
    /* Time base */
3336
    gen_tbl(env);
3337
    /* Thermal management */
3338
    gen_spr_thrm(env);
3339
    /* Hardware implementation registers */
3340
    /* XXX : not implemented */
3341
    spr_register(env, SPR_HID0, "HID0",
3342
                 SPR_NOACCESS, SPR_NOACCESS,
3343
                 &spr_read_generic, &spr_write_generic,
3344
                 0x00000000);
3345
    /* XXX : not implemented */
3346
    spr_register(env, SPR_HID1, "HID1",
3347
                 SPR_NOACCESS, SPR_NOACCESS,
3348
                 &spr_read_generic, &spr_write_generic,
3349
                 0x00000000);
3350
    /* XXX : not implemented */
3351
    spr_register(env, SPR_750_HID2, "HID2",
3352
                 SPR_NOACCESS, SPR_NOACCESS,
3353
                 &spr_read_generic, &spr_write_generic,
3354
                 0x00000000);
3355
    /* Memory management */
3356
    gen_low_BATs(env);
3357
    /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
3358
    gen_high_BATs(env);
3359
    init_excp_750FX(env);
3360
    /* Allocate hardware IRQ controller */
3361
    ppc6xx_irq_init(env);
3362
}
3363

    
3364
/* PowerPC 745/755                                                           */
3365
#define POWERPC_INSNS_7x5    (POWERPC_INSNS_WORKS | PPC_EXTERN | PPC_6xx_TLB)
3366
#define POWERPC_MSRM_7x5     (0x000000000007FF77ULL)
3367
#define POWERPC_MMU_7x5      (POWERPC_MMU_SOFT_6xx)
3368
//#define POWERPC_EXCP_7x5     (POWERPC_EXCP_7x5)
3369
#define POWERPC_INPUT_7x5    (PPC_FLAGS_INPUT_6xx)
3370
#define POWERPC_BFDM_7x5     (bfd_mach_ppc_750)
3371

    
3372
static void init_proc_7x5 (CPUPPCState *env)
3373
{
3374
    gen_spr_ne_601(env);
3375
    gen_spr_G2_755(env);
3376
    /* Time base */
3377
    gen_tbl(env);
3378
    /* L2 cache control */
3379
    /* XXX : not implemented */
3380
    spr_register(env, SPR_ICTC, "ICTC",
3381
                 SPR_NOACCESS, SPR_NOACCESS,
3382
                 &spr_read_generic, &spr_write_generic,
3383
                 0x00000000);
3384
    /* XXX : not implemented */
3385
    spr_register(env, SPR_L2PMCR, "L2PMCR",
3386
                 SPR_NOACCESS, SPR_NOACCESS,
3387
                 &spr_read_generic, &spr_write_generic,
3388
                 0x00000000);
3389
    /* Hardware implementation registers */
3390
    /* XXX : not implemented */
3391
    spr_register(env, SPR_HID0, "HID0",
3392
                 SPR_NOACCESS, SPR_NOACCESS,
3393
                 &spr_read_generic, &spr_write_generic,
3394
                 0x00000000);
3395
    /* XXX : not implemented */
3396
    spr_register(env, SPR_HID1, "HID1",
3397
                 SPR_NOACCESS, SPR_NOACCESS,
3398
                 &spr_read_generic, &spr_write_generic,
3399
                 0x00000000);
3400
    /* XXX : not implemented */
3401
    spr_register(env, SPR_HID2, "HID2",
3402
                 SPR_NOACCESS, SPR_NOACCESS,
3403
                 &spr_read_generic, &spr_write_generic,
3404
                 0x00000000);
3405
    /* Memory management */
3406
    gen_low_BATs(env);
3407
    gen_high_BATs(env);
3408
    gen_6xx_7xx_soft_tlb(env, 64, 2);
3409
    /* Allocate hardware IRQ controller */
3410
    ppc6xx_irq_init(env);
3411
}
3412

    
3413
/* PowerPC 7400 (aka G4)                                                     */
3414
#define POWERPC_INSNS_7400   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3415
                              PPC_EXTERN | PPC_MEM_TLBIA |                    \
3416
                              PPC_ALTIVEC)
3417
#define POWERPC_MSRM_7400    (0x000000000205FF77ULL)
3418
#define POWERPC_MMU_7400     (POWERPC_MMU_32B)
3419
#define POWERPC_EXCP_7400    (POWERPC_EXCP_74xx)
3420
#define POWERPC_INPUT_7400   (PPC_FLAGS_INPUT_6xx)
3421
#define POWERPC_BFDM_7400    (bfd_mach_ppc_7400)
3422

    
3423
static void init_proc_7400 (CPUPPCState *env)
3424
{
3425
    gen_spr_ne_601(env);
3426
    gen_spr_7xx(env);
3427
    /* Time base */
3428
    gen_tbl(env);
3429
    /* 74xx specific SPR */
3430
    gen_spr_74xx(env);
3431
    /* Thermal management */
3432
    gen_spr_thrm(env);
3433
    /* Memory management */
3434
    gen_low_BATs(env);
3435
    init_excp_7400(env);
3436
    /* Allocate hardware IRQ controller */
3437
    ppc6xx_irq_init(env);
3438
}
3439

    
3440
/* PowerPC 7410 (aka G4)                                                     */
3441
#define POWERPC_INSNS_7410   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3442
                              PPC_EXTERN | PPC_MEM_TLBIA |                    \
3443
                              PPC_ALTIVEC)
3444
#define POWERPC_MSRM_7410    (0x000000000205FF77ULL)
3445
#define POWERPC_MMU_7410     (POWERPC_MMU_32B)
3446
#define POWERPC_EXCP_7410    (POWERPC_EXCP_74xx)
3447
#define POWERPC_INPUT_7410   (PPC_FLAGS_INPUT_6xx)
3448
#define POWERPC_BFDM_7410    (bfd_mach_ppc_7400)
3449

    
3450
static void init_proc_7410 (CPUPPCState *env)
3451
{
3452
    gen_spr_ne_601(env);
3453
    gen_spr_7xx(env);
3454
    /* Time base */
3455
    gen_tbl(env);
3456
    /* 74xx specific SPR */
3457
    gen_spr_74xx(env);
3458
    /* Thermal management */
3459
    gen_spr_thrm(env);
3460
    /* L2PMCR */
3461
    /* XXX : not implemented */
3462
    spr_register(env, SPR_L2PMCR, "L2PMCR",
3463
                 SPR_NOACCESS, SPR_NOACCESS,
3464
                 &spr_read_generic, &spr_write_generic,
3465
                 0x00000000);
3466
    /* LDSTDB */
3467
    /* XXX : not implemented */
3468
    spr_register(env, SPR_LDSTDB, "LDSTDB",
3469
                 SPR_NOACCESS, SPR_NOACCESS,
3470
                 &spr_read_generic, &spr_write_generic,
3471
                 0x00000000);
3472
    /* Memory management */
3473
    gen_low_BATs(env);
3474
    init_excp_7400(env);
3475
    /* Allocate hardware IRQ controller */
3476
    ppc6xx_irq_init(env);
3477
}
3478

    
3479
/* PowerPC 7440 (aka G4)                                                     */
3480
#if defined (TODO)
3481
#define POWERPC_INSNS_7440   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3482
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3483
                              PPC_ALTIVEC)
3484
#define POWERPC_MSRM_7440    (0x000000000205FF77ULL)
3485
#define POWERPC_MMU_7440     (POWERPC_MMU_SOFT_74xx)
3486
#define POWERPC_EXCP_7440    (POWERPC_EXCP_74xx)
3487
#define POWERPC_INPUT_7440   (PPC_FLAGS_INPUT_6xx)
3488
#define POWERPC_BFDM_7440    (bfd_mach_ppc_7400)
3489

    
3490
static void init_proc_7440 (CPUPPCState *env)
3491
{
3492
    gen_spr_ne_601(env);
3493
    gen_spr_7xx(env);
3494
    /* Time base */
3495
    gen_tbl(env);
3496
    /* 74xx specific SPR */
3497
    gen_spr_74xx(env);
3498
    /* LDSTCR */
3499
    /* XXX : not implemented */
3500
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3501
                 SPR_NOACCESS, SPR_NOACCESS,
3502
                 &spr_read_generic, &spr_write_generic,
3503
                 0x00000000);
3504
    /* ICTRL */
3505
    /* XXX : not implemented */
3506
    spr_register(env, SPR_ICTRL, "ICTRL",
3507
                 SPR_NOACCESS, SPR_NOACCESS,
3508
                 &spr_read_generic, &spr_write_generic,
3509
                 0x00000000);
3510
    /* MSSSR0 */
3511
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3512
                 SPR_NOACCESS, SPR_NOACCESS,
3513
                 &spr_read_generic, &spr_write_generic,
3514
                 0x00000000);
3515
    /* PMC */
3516
    /* XXX : not implemented */
3517
    spr_register(env, SPR_PMC5, "PMC5",
3518
                 SPR_NOACCESS, SPR_NOACCESS,
3519
                 &spr_read_generic, &spr_write_generic,
3520
                 0x00000000);
3521
    spr_register(env, SPR_UPMC5, "UPMC5",
3522
                 &spr_read_ureg, SPR_NOACCESS,
3523
                 &spr_read_ureg, SPR_NOACCESS,
3524
                 0x00000000);
3525
    spr_register(env, SPR_PMC6, "PMC6",
3526
                 SPR_NOACCESS, SPR_NOACCESS,
3527
                 &spr_read_generic, &spr_write_generic,
3528
                 0x00000000);
3529
    spr_register(env, SPR_UPMC6, "UPMC6",
3530
                 &spr_read_ureg, SPR_NOACCESS,
3531
                 &spr_read_ureg, SPR_NOACCESS,
3532
                 0x00000000);
3533
    /* Memory management */
3534
    gen_low_BATs(env);
3535
    gen_74xx_soft_tlb(env);
3536
    /* Allocate hardware IRQ controller */
3537
    ppc6xx_irq_init(env);
3538
}
3539
#endif /* TODO */
3540

    
3541
/* PowerPC 7450 (aka G4)                                                     */
3542
#if defined (TODO)
3543
#define POWERPC_INSNS_7450   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3544
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3545
                              PPC_ALTIVEC)
3546
#define POWERPC_MSRM_7450    (0x000000000205FF77ULL)
3547
#define POWERPC_MMU_7450     (POWERPC_MMU_SOFT_74xx)
3548
#define POWERPC_EXCP_7450    (POWERPC_EXCP_74xx)
3549
#define POWERPC_INPUT_7450   (PPC_FLAGS_INPUT_6xx)
3550
#define POWERPC_BFDM_7450    (bfd_mach_ppc_7400)
3551

    
3552
static void init_proc_7450 (CPUPPCState *env)
3553
{
3554
    gen_spr_ne_601(env);
3555
    gen_spr_7xx(env);
3556
    /* Time base */
3557
    gen_tbl(env);
3558
    /* 74xx specific SPR */
3559
    gen_spr_74xx(env);
3560
    /* Level 3 cache control */
3561
    gen_l3_ctrl(env);
3562
    /* LDSTCR */
3563
    /* XXX : not implemented */
3564
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3565
                 SPR_NOACCESS, SPR_NOACCESS,
3566
                 &spr_read_generic, &spr_write_generic,
3567
                 0x00000000);
3568
    /* ICTRL */
3569
    /* XXX : not implemented */
3570
    spr_register(env, SPR_ICTRL, "ICTRL",
3571
                 SPR_NOACCESS, SPR_NOACCESS,
3572
                 &spr_read_generic, &spr_write_generic,
3573
                 0x00000000);
3574
    /* MSSSR0 */
3575
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3576
                 SPR_NOACCESS, SPR_NOACCESS,
3577
                 &spr_read_generic, &spr_write_generic,
3578
                 0x00000000);
3579
    /* PMC */
3580
    /* XXX : not implemented */
3581
    spr_register(env, SPR_PMC5, "PMC5",
3582
                 SPR_NOACCESS, SPR_NOACCESS,
3583
                 &spr_read_generic, &spr_write_generic,
3584
                 0x00000000);
3585
    spr_register(env, SPR_UPMC5, "UPMC5",
3586
                 &spr_read_ureg, SPR_NOACCESS,
3587
                 &spr_read_ureg, SPR_NOACCESS,
3588
                 0x00000000);
3589
    spr_register(env, SPR_PMC6, "PMC6",
3590
                 SPR_NOACCESS, SPR_NOACCESS,
3591
                 &spr_read_generic, &spr_write_generic,
3592
                 0x00000000);
3593
    spr_register(env, SPR_UPMC6, "UPMC6",
3594
                 &spr_read_ureg, SPR_NOACCESS,
3595
                 &spr_read_ureg, SPR_NOACCESS,
3596
                 0x00000000);
3597
    /* Memory management */
3598
    gen_low_BATs(env);
3599
    gen_74xx_soft_tlb(env);
3600
    init_excp_7450(env);
3601
    /* Allocate hardware IRQ controller */
3602
    ppc6xx_irq_init(env);
3603
}
3604
#endif /* TODO */
3605

    
3606
/* PowerPC 7445 (aka G4)                                                     */
3607
#if defined (TODO)
3608
#define POWERPC_INSNS_7445   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3609
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3610
                              PPC_ALTIVEC)
3611
#define POWERPC_MSRM_7445    (0x000000000205FF77ULL)
3612
#define POWERPC_MMU_7445     (POWERPC_MMU_SOFT_74xx)
3613
#define POWERPC_EXCP_7445    (POWERPC_EXCP_74xx)
3614
#define POWERPC_INPUT_7445   (PPC_FLAGS_INPUT_6xx)
3615
#define POWERPC_BFDM_7445    (bfd_mach_ppc_7400)
3616

    
3617
static void init_proc_7445 (CPUPPCState *env)
3618
{
3619
    gen_spr_ne_601(env);
3620
    gen_spr_7xx(env);
3621
    /* Time base */
3622
    gen_tbl(env);
3623
    /* 74xx specific SPR */
3624
    gen_spr_74xx(env);
3625
    /* LDSTCR */
3626
    /* XXX : not implemented */
3627
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3628
                 SPR_NOACCESS, SPR_NOACCESS,
3629
                 &spr_read_generic, &spr_write_generic,
3630
                 0x00000000);
3631
    /* ICTRL */
3632
    /* XXX : not implemented */
3633
    spr_register(env, SPR_ICTRL, "ICTRL",
3634
                 SPR_NOACCESS, SPR_NOACCESS,
3635
                 &spr_read_generic, &spr_write_generic,
3636
                 0x00000000);
3637
    /* MSSSR0 */
3638
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3639
                 SPR_NOACCESS, SPR_NOACCESS,
3640
                 &spr_read_generic, &spr_write_generic,
3641
                 0x00000000);
3642
    /* PMC */
3643
    /* XXX : not implemented */
3644
    spr_register(env, SPR_PMC5, "PMC5",
3645
                 SPR_NOACCESS, SPR_NOACCESS,
3646
                 &spr_read_generic, &spr_write_generic,
3647
                 0x00000000);
3648
    spr_register(env, SPR_UPMC5, "UPMC5",
3649
                 &spr_read_ureg, SPR_NOACCESS,
3650
                 &spr_read_ureg, SPR_NOACCESS,
3651
                 0x00000000);
3652
    spr_register(env, SPR_PMC6, "PMC6",
3653
                 SPR_NOACCESS, SPR_NOACCESS,
3654
                 &spr_read_generic, &spr_write_generic,
3655
                 0x00000000);
3656
    spr_register(env, SPR_UPMC6, "UPMC6",
3657
                 &spr_read_ureg, SPR_NOACCESS,
3658
                 &spr_read_ureg, SPR_NOACCESS,
3659
                 0x00000000);
3660
    /* SPRGs */
3661
    spr_register(env, SPR_SPRG4, "SPRG4",
3662
                 SPR_NOACCESS, SPR_NOACCESS,
3663
                 &spr_read_generic, &spr_write_generic,
3664
                 0x00000000);
3665
    spr_register(env, SPR_USPRG4, "USPRG4",
3666
                 &spr_read_ureg, SPR_NOACCESS,
3667
                 &spr_read_ureg, SPR_NOACCESS,
3668
                 0x00000000);
3669
    spr_register(env, SPR_SPRG5, "SPRG5",
3670
                 SPR_NOACCESS, SPR_NOACCESS,
3671
                 &spr_read_generic, &spr_write_generic,
3672
                 0x00000000);
3673
    spr_register(env, SPR_USPRG5, "USPRG5",
3674
                 &spr_read_ureg, SPR_NOACCESS,
3675
                 &spr_read_ureg, SPR_NOACCESS,
3676
                 0x00000000);
3677
    spr_register(env, SPR_SPRG6, "SPRG6",
3678
                 SPR_NOACCESS, SPR_NOACCESS,
3679
                 &spr_read_generic, &spr_write_generic,
3680
                 0x00000000);
3681
    spr_register(env, SPR_USPRG6, "USPRG6",
3682
                 &spr_read_ureg, SPR_NOACCESS,
3683
                 &spr_read_ureg, SPR_NOACCESS,
3684
                 0x00000000);
3685
    spr_register(env, SPR_SPRG7, "SPRG7",
3686
                 SPR_NOACCESS, SPR_NOACCESS,
3687
                 &spr_read_generic, &spr_write_generic,
3688
                 0x00000000);
3689
    spr_register(env, SPR_USPRG7, "USPRG7",
3690
                 &spr_read_ureg, SPR_NOACCESS,
3691
                 &spr_read_ureg, SPR_NOACCESS,
3692
                 0x00000000);
3693
    /* Memory management */
3694
    gen_low_BATs(env);
3695
    gen_high_BATs(env);
3696
    gen_74xx_soft_tlb(env);
3697
    init_excp_7450(env);
3698
    /* Allocate hardware IRQ controller */
3699
    ppc6xx_irq_init(env);
3700
}
3701
#endif /* TODO */
3702

    
3703
/* PowerPC 7455 (aka G4)                                                     */
3704
#if defined (TODO)
3705
#define POWERPC_INSNS_7455   (POWERPC_INSNS_WORKS | PPC_CACHE_DCBA |          \
3706
                              PPC_EXTERN | PPC_74xx_TLB | PPC_MEM_TLBIA |     \
3707
                              PPC_ALTIVEC)
3708
#define POWERPC_MSRM_7455    (0x000000000205FF77ULL)
3709
#define POWERPC_MMU_7455     (POWERPC_MMU_SOFT_74xx)
3710
#define POWERPC_EXCP_7455    (POWERPC_EXCP_74xx)
3711
#define POWERPC_INPUT_7455   (PPC_FLAGS_INPUT_6xx)
3712
#define POWERPC_BFDM_7455    (bfd_mach_ppc_7400)
3713

    
3714
static void init_proc_7455 (CPUPPCState *env)
3715
{
3716
    gen_spr_ne_601(env);
3717
    gen_spr_7xx(env);
3718
    /* Time base */
3719
    gen_tbl(env);
3720
    /* 74xx specific SPR */
3721
    gen_spr_74xx(env);
3722
    /* Level 3 cache control */
3723
    gen_l3_ctrl(env);
3724
    /* LDSTCR */
3725
    /* XXX : not implemented */
3726
    spr_register(env, SPR_LDSTCR, "LDSTCR",
3727
                 SPR_NOACCESS, SPR_NOACCESS,
3728
                 &spr_read_generic, &spr_write_generic,
3729
                 0x00000000);
3730
    /* ICTRL */
3731
    /* XXX : not implemented */
3732
    spr_register(env, SPR_ICTRL, "ICTRL",
3733
                 SPR_NOACCESS, SPR_NOACCESS,
3734
                 &spr_read_generic, &spr_write_generic,
3735
                 0x00000000);
3736
    /* MSSSR0 */
3737
    spr_register(env, SPR_MSSSR0, "MSSSR0",
3738
                 SPR_NOACCESS, SPR_NOACCESS,
3739
                 &spr_read_generic, &spr_write_generic,
3740
                 0x00000000);
3741
    /* PMC */
3742
    /* XXX : not implemented */
3743
    spr_register(env, SPR_PMC5, "PMC5",
3744
                 SPR_NOACCESS, SPR_NOACCESS,
3745
                 &spr_read_generic, &spr_write_generic,
3746
                 0x00000000);
3747
    spr_register(env, SPR_UPMC5, "UPMC5",
3748
                 &spr_read_ureg, SPR_NOACCESS,
3749
                 &spr_read_ureg, SPR_NOACCESS,
3750
                 0x00000000);
3751
    spr_register(env, SPR_PMC6, "PMC6",
3752
                 SPR_NOACCESS, SPR_NOACCESS,
3753
                 &spr_read_generic, &spr_write_generic,
3754
                 0x00000000);
3755
    spr_register(env, SPR_UPMC6, "UPMC6",
3756
                 &spr_read_ureg, SPR_NOACCESS,
3757
                 &spr_read_ureg, SPR_NOACCESS,
3758
                 0x00000000);
3759
    /* SPRGs */
3760
    spr_register(env, SPR_SPRG4, "SPRG4",
3761
                 SPR_NOACCESS, SPR_NOACCESS,
3762
                 &spr_read_generic, &spr_write_generic,
3763
                 0x00000000);
3764
    spr_register(env, SPR_USPRG4, "USPRG4",
3765
                 &spr_read_ureg, SPR_NOACCESS,
3766
                 &spr_read_ureg, SPR_NOACCESS,
3767
                 0x00000000);
3768
    spr_register(env, SPR_SPRG5, "SPRG5",
3769
                 SPR_NOACCESS, SPR_NOACCESS,
3770
                 &spr_read_generic, &spr_write_generic,
3771
                 0x00000000);
3772
    spr_register(env, SPR_USPRG5, "USPRG5",
3773
                 &spr_read_ureg, SPR_NOACCESS,
3774
                 &spr_read_ureg, SPR_NOACCESS,
3775
                 0x00000000);
3776
    spr_register(env, SPR_SPRG6, "SPRG6",
3777
                 SPR_NOACCESS, SPR_NOACCESS,
3778
                 &spr_read_generic, &spr_write_generic,
3779
                 0x00000000);
3780
    spr_register(env, SPR_USPRG6, "USPRG6",
3781
                 &spr_read_ureg, SPR_NOACCESS,
3782
                 &spr_read_ureg, SPR_NOACCESS,
3783
                 0x00000000);
3784
    spr_register(env, SPR_SPRG7, "SPRG7",
3785
                 SPR_NOACCESS, SPR_NOACCESS,
3786
                 &spr_read_generic, &spr_write_generic,
3787
                 0x00000000);
3788
    spr_register(env, SPR_USPRG7, "USPRG7",
3789
                 &spr_read_ureg, SPR_NOACCESS,
3790
                 &spr_read_ureg, SPR_NOACCESS,
3791
                 0x00000000);
3792
    /* Memory management */
3793
    gen_low_BATs(env);
3794
    gen_high_BATs(env);
3795
    gen_74xx_soft_tlb(env);
3796
    init_excp_7450(env);
3797
    /* Allocate hardware IRQ controller */
3798
    ppc6xx_irq_init(env);
3799
}
3800
#endif /* TODO */
3801

    
3802
#if defined (TARGET_PPC64)
3803
/* PowerPC 970                                                               */
3804
#define POWERPC_INSNS_970    (POWERPC_INSNS_WORKS | PPC_FLOAT_FSQRT |         \
3805
                              PPC_64B | PPC_ALTIVEC |                         \
3806
                              PPC_64_BRIDGE | PPC_SLBI)
3807
#define POWERPC_MSRM_970     (0x900000000204FF36ULL)
3808
#define POWERPC_MMU_970      (POWERPC_MMU_64BRIDGE)
3809
//#define POWERPC_EXCP_970     (POWERPC_EXCP_970)
3810
#define POWERPC_INPUT_970    (PPC_FLAGS_INPUT_970)
3811
#define POWERPC_BFDM_970     (bfd_mach_ppc64)
3812

    
3813
static void init_proc_970 (CPUPPCState *env)
3814
{
3815
    gen_spr_ne_601(env);
3816
    gen_spr_7xx(env);
3817
    /* Time base */
3818
    gen_tbl(env);
3819
    /* Hardware implementation registers */
3820
    /* XXX : not implemented */
3821
    spr_register(env, SPR_HID0, "HID0",
3822
                 SPR_NOACCESS, SPR_NOACCESS,
3823
                 &spr_read_generic, &spr_write_generic,
3824
                 0x00000000);
3825
    /* XXX : not implemented */
3826
    spr_register(env, SPR_HID1, "HID1",
3827
                 SPR_NOACCESS, SPR_NOACCESS,
3828
                 &spr_read_generic, &spr_write_generic,
3829
                 0x00000000);
3830
    /* XXX : not implemented */
3831
    spr_register(env, SPR_750_HID2, "HID2",
3832
                 SPR_NOACCESS, SPR_NOACCESS,
3833
                 &spr_read_generic, &spr_write_generic,
3834
                 0x00000000);
3835
    /* Memory management */
3836
    /* XXX: not correct */
3837
    gen_low_BATs(env);
3838
#if 0 // TODO
3839
    env->slb_nr = 32;
3840
#endif
3841
    init_excp_970(env);
3842
    /* Allocate hardware IRQ controller */
3843
    ppc970_irq_init(env);
3844
}
3845

    
3846
/* PowerPC 970FX (aka G5)                                                    */
3847
#define POWERPC_INSNS_970FX  (POWERPC_INSNS_WORKS | PPC_FLOAT_FSQRT |         \
3848
                              PPC_64B | PPC_ALTIVEC |                         \
3849
                              PPC_64_BRIDGE | PPC_SLBI)
3850
#define POWERPC_MSRM_970FX   (0x800000000204FF36ULL)
3851
#define POWERPC_MMU_970FX    (POWERPC_MMU_64BRIDGE)
3852
#define POWERPC_EXCP_970FX   (POWERPC_EXCP_970)
3853
#define POWERPC_INPUT_970FX  (PPC_FLAGS_INPUT_970)
3854
#define POWERPC_BFDM_970FX   (bfd_mach_ppc64)
3855

    
3856
static void init_proc_970FX (CPUPPCState *env)
3857
{
3858
    gen_spr_ne_601(env);
3859
    gen_spr_7xx(env);
3860
    /* Time base */
3861
    gen_tbl(env);
3862
    /* Hardware implementation registers */
3863
    /* XXX : not implemented */
3864
    spr_register(env, SPR_HID0, "HID0",
3865
                 SPR_NOACCESS, SPR_NOACCESS,
3866
                 &spr_read_generic, &spr_write_generic,
3867
                 0x00000000);
3868
    /* XXX : not implemented */
3869
    spr_register(env, SPR_HID1, "HID1",
3870
                 SPR_NOACCESS, SPR_NOACCESS,
3871
                 &spr_read_generic, &spr_write_generic,
3872
                 0x00000000);
3873
    /* XXX : not implemented */
3874
    spr_register(env, SPR_750_HID2, "HID2",
3875
                 SPR_NOACCESS, SPR_NOACCESS,
3876
                 &spr_read_generic, &spr_write_generic,
3877
                 0x00000000);
3878
    /* Memory management */
3879
    /* XXX: not correct */
3880
    gen_low_BATs(env);
3881
#if 0 // TODO
3882
    env->slb_nr = 32;
3883
#endif
3884
    init_excp_970(env);
3885
    /* Allocate hardware IRQ controller */
3886
    ppc970_irq_init(env);
3887
}
3888

    
3889
/* PowerPC 970 GX                                                            */
3890
#define POWERPC_INSNS_970GX  (POWERPC_INSNS_WORKS | PPC_FLOAT_FSQRT |         \
3891
                              PPC_64B | PPC_ALTIVEC |                         \
3892
                              PPC_64_BRIDGE | PPC_SLBI)
3893
#define POWERPC_MSRM_970GX   (0x800000000204FF36ULL)
3894
#define POWERPC_MMU_970GX    (POWERPC_MMU_64BRIDGE)
3895
#define POWERPC_EXCP_970GX   (POWERPC_EXCP_970)
3896
#define POWERPC_INPUT_970GX  (PPC_FLAGS_INPUT_970)
3897
#define POWERPC_BFDM_970GX   (bfd_mach_ppc64)
3898

    
3899
static void init_proc_970GX (CPUPPCState *env)
3900
{
3901
    gen_spr_ne_601(env);
3902
    gen_spr_7xx(env);
3903
    /* Time base */
3904
    gen_tbl(env);
3905
    /* Hardware implementation registers */
3906
    /* XXX : not implemented */
3907
    spr_register(env, SPR_HID0, "HID0",
3908
                 SPR_NOACCESS, SPR_NOACCESS,
3909
                 &spr_read_generic, &spr_write_generic,
3910
                 0x00000000);
3911
    /* XXX : not implemented */
3912
    spr_register(env, SPR_HID1, "HID1",
3913
                 SPR_NOACCESS, SPR_NOACCESS,
3914
                 &spr_read_generic, &spr_write_generic,
3915
                 0x00000000);
3916
    /* XXX : not implemented */
3917
    spr_register(env, SPR_750_HID2, "HID2",
3918
                 SPR_NOACCESS, SPR_NOACCESS,
3919
                 &spr_read_generic, &spr_write_generic,
3920
                 0x00000000);
3921
    /* Memory management */
3922
    /* XXX: not correct */
3923
    gen_low_BATs(env);
3924
#if 0 // TODO
3925
    env->slb_nr = 32;
3926
#endif
3927
    init_excp_970(env);
3928
    /* Allocate hardware IRQ controller */
3929
    ppc970_irq_init(env);
3930
}
3931

    
3932
/* PowerPC 620                                                               */
3933
#if defined (TODO)
3934
#define POWERPC_INSNS_620    (POWERPC_INSNS_WORKS | PPC_FLOAT_FSQRT |         \
3935
                              PPC_64B | PPC_SLBI)
3936
#define POWERPC_MSRM_620     (0x800000000005FF73ULL)
3937
#define POWERPC_MMU_620      (POWERPC_MMU_64B)
3938
#define POWERPC_EXCP_620     (POWERPC_EXCP_970)
3939
#define POWERPC_INPUT_620    (PPC_FLAGS_INPUT_970)
3940
#define POWERPC_BFDM_620     (bfd_mach_ppc64)
3941

    
3942
static void init_proc_620 (CPUPPCState *env)
3943
{
3944
    gen_spr_ne_601(env);
3945
    gen_spr_620(env);
3946
    /* Time base */
3947
    gen_tbl(env);
3948
    /* Hardware implementation registers */
3949
    /* XXX : not implemented */
3950
    spr_register(env, SPR_HID0, "HID0",
3951
                 SPR_NOACCESS, SPR_NOACCESS,
3952
                 &spr_read_generic, &spr_write_generic,
3953
                 0x00000000);
3954
    /* Memory management */
3955
    gen_low_BATs(env);
3956
    gen_high_BATs(env);
3957
    init_excp_620(env);
3958
    /* XXX: TODO: initialize internal interrupt controller */
3959
}
3960
#endif /* TODO */
3961
#endif /* defined (TARGET_PPC64) */
3962

    
3963
/* Default 32 bits PowerPC target will be 604 */
3964
#define CPU_POWERPC_PPC32     CPU_POWERPC_604
3965
#define POWERPC_INSNS_PPC32   POWERPC_INSNS_604
3966
#define POWERPC_MSRM_PPC32    POWERPC_MSRM_604
3967
#define POWERPC_MMU_PPC32     POWERPC_MMU_604
3968
#define POWERPC_EXCP_PPC32    POWERPC_EXCP_604
3969
#define POWERPC_INPUT_PPC32   POWERPC_INPUT_604
3970
#define init_proc_PPC32       init_proc_604
3971
#define POWERPC_BFDM_PPC32    POWERPC_BFDM_604
3972

    
3973
/* Default 64 bits PowerPC target will be 970 FX */
3974
#define CPU_POWERPC_PPC64     CPU_POWERPC_970FX
3975
#define POWERPC_INSNS_PPC64   POWERPC_INSNS_970FX
3976
#define POWERPC_MSRM_PPC64    POWERPC_MSRM_970FX
3977
#define POWERPC_MMU_PPC64     POWERPC_MMU_970FX
3978
#define POWERPC_EXCP_PPC64    POWERPC_EXCP_970FX
3979
#define POWERPC_INPUT_PPC64   POWERPC_INPUT_970FX
3980
#define init_proc_PPC64       init_proc_970FX
3981
#define POWERPC_BFDM_PPC64    POWERPC_BFDM_970FX
3982

    
3983
/* Default PowerPC target will be PowerPC 32 */
3984
#if defined (TARGET_PPC64) && 0 // XXX: TODO
3985
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC64
3986
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC64
3987
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC64
3988
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC64
3989
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC64
3990
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC64
3991
#define init_proc_DEFAULT     init_proc_PPC64
3992
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC64
3993
#else
3994
#define CPU_POWERPC_DEFAULT   CPU_POWERPC_PPC32
3995
#define POWERPC_INSNS_DEFAULT POWERPC_INSNS_PPC32
3996
#define POWERPC_MSRM_DEFAULT  POWERPC_MSRM_PPC32
3997
#define POWERPC_MMU_DEFAULT   POWERPC_MMU_PPC32
3998
#define POWERPC_EXCP_DEFAULT  POWERPC_EXCP_PPC32
3999
#define POWERPC_INPUT_DEFAULT POWERPC_INPUT_PPC32
4000
#define init_proc_DEFAULT     init_proc_PPC32
4001
#define POWERPC_BFDM_DEFAULT  POWERPC_BFDM_PPC32
4002
#endif
4003

    
4004
/*****************************************************************************/
4005
/* PVR definitions for most known PowerPC                                    */
4006
enum {
4007
    /* PowerPC 401 family */
4008
    /* Generic PowerPC 401 */
4009
#define CPU_POWERPC_401       CPU_POWERPC_401G2
4010
    /* PowerPC 401 cores */
4011
    CPU_POWERPC_401A1       = 0x00210000,
4012
    CPU_POWERPC_401B2       = 0x00220000,
4013
#if 0
4014
    CPU_POWERPC_401B3       = xxx,
4015
#endif
4016
    CPU_POWERPC_401C2       = 0x00230000,
4017
    CPU_POWERPC_401D2       = 0x00240000,
4018
    CPU_POWERPC_401E2       = 0x00250000,
4019
    CPU_POWERPC_401F2       = 0x00260000,
4020
    CPU_POWERPC_401G2       = 0x00270000,
4021
    /* PowerPC 401 microcontrolers */
4022
#if 0
4023
    CPU_POWERPC_401GF       = xxx,
4024
#endif
4025
#define CPU_POWERPC_IOP480    CPU_POWERPC_401B2
4026
    /* IBM Processor for Network Resources */
4027
    CPU_POWERPC_COBRA       = 0x10100000, /* XXX: 405 ? */
4028
#if 0
4029
    CPU_POWERPC_XIPCHIP     = xxx,
4030
#endif
4031
    /* PowerPC 403 family */
4032
    /* Generic PowerPC 403 */
4033
#define CPU_POWERPC_403       CPU_POWERPC_403GC
4034
    /* PowerPC 403 microcontrollers */
4035
    CPU_POWERPC_403GA       = 0x00200011,
4036
    CPU_POWERPC_403GB       = 0x00200100,
4037
    CPU_POWERPC_403GC       = 0x00200200,
4038
    CPU_POWERPC_403GCX      = 0x00201400,
4039
#if 0
4040
    CPU_POWERPC_403GP       = xxx,
4041
#endif
4042
    /* PowerPC 405 family */
4043
    /* Generic PowerPC 405 */
4044
#define CPU_POWERPC_405       CPU_POWERPC_405D4
4045
    /* PowerPC 405 cores */
4046
#if 0
4047
    CPU_POWERPC_405A3       = xxx,
4048
#endif
4049
#if 0
4050
    CPU_POWERPC_405A4       = xxx,
4051
#endif
4052
#if 0
4053
    CPU_POWERPC_405B3       = xxx,
4054
#endif
4055
#if 0
4056
    CPU_POWERPC_405B4       = xxx,
4057
#endif
4058
#if 0
4059
    CPU_POWERPC_405C3       = xxx,
4060
#endif
4061
#if 0
4062
    CPU_POWERPC_405C4       = xxx,
4063
#endif
4064
    CPU_POWERPC_405D2       = 0x20010000,
4065
#if 0
4066
    CPU_POWERPC_405D3       = xxx,
4067
#endif
4068
    CPU_POWERPC_405D4       = 0x41810000,
4069
#if 0
4070
    CPU_POWERPC_405D5       = xxx,
4071
#endif
4072
#if 0
4073
    CPU_POWERPC_405E4       = xxx,
4074
#endif
4075
#if 0
4076
    CPU_POWERPC_405F4       = xxx,
4077
#endif
4078
#if 0
4079
    CPU_POWERPC_405F5       = xxx,
4080
#endif
4081
#if 0
4082
    CPU_POWERPC_405F6       = xxx,
4083
#endif
4084
    /* PowerPC 405 microcontrolers */
4085
    /* XXX: missing 0x200108a0 */
4086
#define CPU_POWERPC_405CR     CPU_POWERPC_405CRc
4087
    CPU_POWERPC_405CRa      = 0x40110041,
4088
    CPU_POWERPC_405CRb      = 0x401100C5,
4089
    CPU_POWERPC_405CRc      = 0x40110145,
4090
    CPU_POWERPC_405EP       = 0x51210950,
4091
#if 0
4092
    CPU_POWERPC_405EXr      = xxx,
4093
#endif
4094
    CPU_POWERPC_405EZ       = 0x41511460, /* 0x51210950 ? */
4095
#if 0
4096
    CPU_POWERPC_405FX       = xxx,
4097
#endif
4098
#define CPU_POWERPC_405GP     CPU_POWERPC_405GPd
4099
    CPU_POWERPC_405GPa      = 0x40110000,
4100
    CPU_POWERPC_405GPb      = 0x40110040,
4101
    CPU_POWERPC_405GPc      = 0x40110082,
4102
    CPU_POWERPC_405GPd      = 0x401100C4,
4103
#define CPU_POWERPC_405GPe    CPU_POWERPC_405CRc
4104
    CPU_POWERPC_405GPR      = 0x50910951,
4105
#if 0
4106
    CPU_POWERPC_405H        = xxx,
4107
#endif
4108
#if 0
4109
    CPU_POWERPC_405L        = xxx,
4110
#endif
4111
    CPU_POWERPC_405LP       = 0x41F10000,
4112
#if 0
4113
    CPU_POWERPC_405PM       = xxx,
4114
#endif
4115
#if 0
4116
    CPU_POWERPC_405PS       = xxx,
4117
#endif
4118
#if 0
4119
    CPU_POWERPC_405S        = xxx,
4120
#endif
4121
    /* IBM network processors */
4122
    CPU_POWERPC_NPE405H     = 0x414100C0,
4123
    CPU_POWERPC_NPE405H2    = 0x41410140,
4124
    CPU_POWERPC_NPE405L     = 0x416100C0,
4125
    CPU_POWERPC_NPE4GS3     = 0x40B10000,
4126
#if 0
4127
    CPU_POWERPC_NPCxx1      = xxx,
4128
#endif
4129
#if 0
4130
    CPU_POWERPC_NPR161      = xxx,
4131
#endif
4132
#if 0
4133
    CPU_POWERPC_LC77700     = xxx,
4134
#endif
4135
    /* IBM STBxxx (PowerPC 401/403/405 core based microcontrollers) */
4136
#if 0
4137
    CPU_POWERPC_STB01000    = xxx,
4138
#endif
4139
#if 0
4140
    CPU_POWERPC_STB01010    = xxx,
4141
#endif
4142
#if 0
4143
    CPU_POWERPC_STB0210     = xxx, /* 401B3 */
4144
#endif
4145
    CPU_POWERPC_STB03       = 0x40310000, /* 0x40130000 ? */
4146
#if 0
4147
    CPU_POWERPC_STB043      = xxx,
4148
#endif
4149
#if 0
4150
    CPU_POWERPC_STB045      = xxx,
4151
#endif
4152
    CPU_POWERPC_STB04       = 0x41810000,
4153
    CPU_POWERPC_STB25       = 0x51510950,
4154
#if 0
4155
    CPU_POWERPC_STB130      = xxx,
4156
#endif
4157
    /* Xilinx cores */
4158
    CPU_POWERPC_X2VP4       = 0x20010820,
4159
#define CPU_POWERPC_X2VP7     CPU_POWERPC_X2VP4
4160
    CPU_POWERPC_X2VP20      = 0x20010860,
4161
#define CPU_POWERPC_X2VP50    CPU_POWERPC_X2VP20
4162
#if 0
4163
    CPU_POWERPC_ZL10310     = xxx,
4164
#endif
4165
#if 0
4166
    CPU_POWERPC_ZL10311     = xxx,
4167
#endif
4168
#if 0
4169
    CPU_POWERPC_ZL10320     = xxx,
4170
#endif
4171
#if 0
4172
    CPU_POWERPC_ZL10321     = xxx,
4173
#endif
4174
    /* PowerPC 440 family */
4175
    /* Generic PowerPC 440 */
4176
#define CPU_POWERPC_440       CPU_POWERPC_440GXf
4177
    /* PowerPC 440 cores */
4178
#if 0
4179
    CPU_POWERPC_440A4       = xxx,
4180
#endif
4181
#if 0
4182
    CPU_POWERPC_440A5       = xxx,
4183
#endif
4184
#if 0
4185
    CPU_POWERPC_440B4       = xxx,
4186
#endif
4187
#if 0
4188
    CPU_POWERPC_440F5       = xxx,
4189
#endif
4190
#if 0
4191
    CPU_POWERPC_440G5       = xxx,
4192
#endif
4193
#if 0
4194
    CPU_POWERPC_440H4       = xxx,
4195
#endif
4196
#if 0
4197
    CPU_POWERPC_440H6       = xxx,
4198
#endif
4199
    /* PowerPC 440 microcontrolers */
4200
#define CPU_POWERPC_440EP     CPU_POWERPC_440EPb
4201
    CPU_POWERPC_440EPa      = 0x42221850,
4202
    CPU_POWERPC_440EPb      = 0x422218D3,
4203
#define CPU_POWERPC_440GP     CPU_POWERPC_440GPc
4204
    CPU_POWERPC_440GPb      = 0x40120440,
4205
    CPU_POWERPC_440GPc      = 0x40120481,
4206
#define CPU_POWERPC_440GR     CPU_POWERPC_440GRa
4207
#define CPU_POWERPC_440GRa    CPU_POWERPC_440EPb
4208
    CPU_POWERPC_440GRX      = 0x200008D0,
4209
#define CPU_POWERPC_440EPX    CPU_POWERPC_440GRX
4210
#define CPU_POWERPC_440GX     CPU_POWERPC_440GXf
4211
    CPU_POWERPC_440GXa      = 0x51B21850,
4212
    CPU_POWERPC_440GXb      = 0x51B21851,
4213
    CPU_POWERPC_440GXc      = 0x51B21892,
4214
    CPU_POWERPC_440GXf      = 0x51B21894,
4215
#if 0
4216
    CPU_POWERPC_440S        = xxx,
4217
#endif
4218
    CPU_POWERPC_440SP       = 0x53221850,
4219
    CPU_POWERPC_440SP2      = 0x53221891,
4220
    CPU_POWERPC_440SPE      = 0x53421890,
4221
    /* PowerPC 460 family */
4222
#if 0
4223
    /* Generic PowerPC 464 */
4224
#define CPU_POWERPC_464       CPU_POWERPC_464H90
4225
#endif
4226
    /* PowerPC 464 microcontrolers */
4227
#if 0
4228
    CPU_POWERPC_464H90      = xxx,
4229
#endif
4230
#if 0
4231
    CPU_POWERPC_464H90FP    = xxx,
4232
#endif
4233
    /* Freescale embedded PowerPC cores */
4234
    /* e200 family */
4235
#define CPU_POWERPC_e200      CPU_POWERPC_e200z6
4236
#if 0
4237
    CPU_POWERPC_e200z0      = xxx,
4238
#endif
4239
#if 0
4240
    CPU_POWERPC_e200z3      = xxx,
4241
#endif
4242
    CPU_POWERPC_e200z5      = 0x81000000,
4243
    CPU_POWERPC_e200z6      = 0x81120000,
4244
    /* e300 family */
4245
#define CPU_POWERPC_e300      CPU_POWERPC_e300c3
4246
    CPU_POWERPC_e300c1      = 0x00830000,
4247
    CPU_POWERPC_e300c2      = 0x00840000,
4248
    CPU_POWERPC_e300c3      = 0x00850000,
4249
    /* e500 family */
4250
#define CPU_POWERPC_e500      CPU_POWERPC_e500_v22
4251
    CPU_POWERPC_e500_v11    = 0x80200010,
4252
    CPU_POWERPC_e500_v12    = 0x80200020,
4253
    CPU_POWERPC_e500_v21    = 0x80210010,
4254
    CPU_POWERPC_e500_v22    = 0x80210020,
4255
#if 0
4256
    CPU_POWERPC_e500mc      = xxx,
4257
#endif
4258
    /* e600 family */
4259
    CPU_POWERPC_e600        = 0x80040010,
4260
    /* PowerPC MPC 5xx cores */
4261
    CPU_POWERPC_5xx         = 0x00020020,
4262
    /* PowerPC MPC 8xx cores (aka PowerQUICC) */
4263
    CPU_POWERPC_8xx         = 0x00500000,
4264
    /* PowerPC MPC 8xxx cores (aka PowerQUICC-II) */
4265
    CPU_POWERPC_82xx_HIP3   = 0x00810101,
4266
    CPU_POWERPC_82xx_HIP4   = 0x80811014,
4267
    CPU_POWERPC_827x        = 0x80822013,
4268
    /* PowerPC 6xx cores */
4269
    CPU_POWERPC_601         = 0x00010001,
4270
    CPU_POWERPC_601a        = 0x00010002,
4271
    CPU_POWERPC_602         = 0x00050100,
4272
    CPU_POWERPC_603         = 0x00030100,
4273
#define CPU_POWERPC_603E      CPU_POWERPC_603E_v41
4274
    CPU_POWERPC_603E_v11    = 0x00060101,
4275
    CPU_POWERPC_603E_v12    = 0x00060102,
4276
    CPU_POWERPC_603E_v13    = 0x00060103,
4277
    CPU_POWERPC_603E_v14    = 0x00060104,
4278
    CPU_POWERPC_603E_v22    = 0x00060202,
4279
    CPU_POWERPC_603E_v3     = 0x00060300,
4280
    CPU_POWERPC_603E_v4     = 0x00060400,
4281
    CPU_POWERPC_603E_v41    = 0x00060401,
4282
    CPU_POWERPC_603E7t      = 0x00071201,
4283
    CPU_POWERPC_603E7v      = 0x00070100,
4284
    CPU_POWERPC_603E7v1     = 0x00070101,
4285
    CPU_POWERPC_603E7v2     = 0x00070201,
4286
    CPU_POWERPC_603E7       = 0x00070200,
4287
    CPU_POWERPC_603P        = 0x00070000,
4288
#define CPU_POWERPC_603R      CPU_POWERPC_603E7t
4289
    CPU_POWERPC_G2          = 0x00810011,
4290
#if 0 // Linux pretends the MSB is zero...
4291
    CPU_POWERPC_G2H4        = 0x80811010,
4292
    CPU_POWERPC_G2gp        = 0x80821010,
4293
    CPU_POWERPC_G2ls        = 0x90810010,
4294
    CPU_POWERPC_G2LE        = 0x80820010,
4295
    CPU_POWERPC_G2LEgp      = 0x80822010,
4296
    CPU_POWERPC_G2LEls      = 0xA0822010,
4297
#else
4298
    CPU_POWERPC_G2H4        = 0x00811010,
4299
    CPU_POWERPC_G2gp        = 0x00821010,
4300
    CPU_POWERPC_G2ls        = 0x10810010,
4301
    CPU_POWERPC_G2LE        = 0x00820010,
4302
    CPU_POWERPC_G2LEgp      = 0x00822010,
4303
    CPU_POWERPC_G2LEls      = 0x20822010,
4304
#endif
4305
    CPU_POWERPC_604         = 0x00040103,
4306
#define CPU_POWERPC_604E      CPU_POWERPC_604E_v24
4307
    CPU_POWERPC_604E_v10    = 0x00090100, /* Also 2110 & 2120 */
4308
    CPU_POWERPC_604E_v22    = 0x00090202,
4309
    CPU_POWERPC_604E_v24    = 0x00090204,
4310
    CPU_POWERPC_604R        = 0x000a0101, /* Also 0x00093102 */
4311
#if 0
4312
    CPU_POWERPC_604EV       = xxx,
4313
#endif
4314
    /* PowerPC 740/750 cores (aka G3) */
4315
    /* XXX: missing 0x00084202 */
4316
#define CPU_POWERPC_7x0       CPU_POWERPC_7x0_v31
4317
    CPU_POWERPC_7x0_v20     = 0x00080200,
4318
    CPU_POWERPC_7x0_v21     = 0x00080201,
4319
    CPU_POWERPC_7x0_v22     = 0x00080202,
4320
    CPU_POWERPC_7x0_v30     = 0x00080300,
4321
    CPU_POWERPC_7x0_v31     = 0x00080301,
4322
    CPU_POWERPC_740E        = 0x00080100,
4323
    CPU_POWERPC_7x0P        = 0x10080000,
4324
    /* XXX: missing 0x00087010 (CL ?) */
4325
    CPU_POWERPC_750CL       = 0x00087200,
4326
#define CPU_POWERPC_750CX     CPU_POWERPC_750CX_v22
4327
    CPU_POWERPC_750CX_v21   = 0x00082201,
4328
    CPU_POWERPC_750CX_v22   = 0x00082202,
4329
#define CPU_POWERPC_750CXE    CPU_POWERPC_750CXE_v31b
4330
    CPU_POWERPC_750CXE_v21  = 0x00082211,
4331
    CPU_POWERPC_750CXE_v22  = 0x00082212,
4332
    CPU_POWERPC_750CXE_v23  = 0x00082213,
4333
    CPU_POWERPC_750CXE_v24  = 0x00082214,
4334
    CPU_POWERPC_750CXE_v24b = 0x00083214,
4335
    CPU_POWERPC_750CXE_v31  = 0x00083211,
4336
    CPU_POWERPC_750CXE_v31b = 0x00083311,
4337
    CPU_POWERPC_750CXR      = 0x00083410,
4338
    CPU_POWERPC_750E        = 0x00080200,
4339
    CPU_POWERPC_750FL       = 0x700A0203,
4340
#define CPU_POWERPC_750FX     CPU_POWERPC_750FX_v23
4341
    CPU_POWERPC_750FX_v10   = 0x70000100,
4342
    CPU_POWERPC_750FX_v20   = 0x70000200,
4343
    CPU_POWERPC_750FX_v21   = 0x70000201,
4344
    CPU_POWERPC_750FX_v22   = 0x70000202,
4345
    CPU_POWERPC_750FX_v23   = 0x70000203,
4346
    CPU_POWERPC_750GL       = 0x70020102,
4347
#define CPU_POWERPC_750GX     CPU_POWERPC_750GX_v12
4348
    CPU_POWERPC_750GX_v10   = 0x70020100,
4349
    CPU_POWERPC_750GX_v11   = 0x70020101,
4350
    CPU_POWERPC_750GX_v12   = 0x70020102,
4351
#define CPU_POWERPC_750L      CPU_POWERPC_750L_v32 /* Aka LoneStar */
4352
    CPU_POWERPC_750L_v22    = 0x00088202,
4353
    CPU_POWERPC_750L_v30    = 0x00088300,
4354
    CPU_POWERPC_750L_v32    = 0x00088302,
4355
    /* PowerPC 745/755 cores */
4356
#define CPU_POWERPC_7x5       CPU_POWERPC_7x5_v28
4357
    CPU_POWERPC_7x5_v10     = 0x00083100,
4358
    CPU_POWERPC_7x5_v11     = 0x00083101,
4359
    CPU_POWERPC_7x5_v20     = 0x00083200,
4360
    CPU_POWERPC_7x5_v21     = 0x00083201,
4361
    CPU_POWERPC_7x5_v22     = 0x00083202, /* aka D */
4362
    CPU_POWERPC_7x5_v23     = 0x00083203, /* aka E */
4363
    CPU_POWERPC_7x5_v24     = 0x00083204,
4364
    CPU_POWERPC_7x5_v25     = 0x00083205,
4365
    CPU_POWERPC_7x5_v26     = 0x00083206,
4366
    CPU_POWERPC_7x5_v27     = 0x00083207,
4367
    CPU_POWERPC_7x5_v28     = 0x00083208,
4368
#if 0
4369
    CPU_POWERPC_7x5P        = xxx,
4370
#endif
4371
    /* PowerPC 74xx cores (aka G4) */
4372
    /* XXX: missing 0x000C1101 */
4373
#define CPU_POWERPC_7400      CPU_POWERPC_7400_v29
4374
    CPU_POWERPC_7400_v10    = 0x000C0100,
4375
    CPU_POWERPC_7400_v11    = 0x000C0101,
4376
    CPU_POWERPC_7400_v20    = 0x000C0200,
4377
    CPU_POWERPC_7400_v22    = 0x000C0202,
4378
    CPU_POWERPC_7400_v26    = 0x000C0206,
4379
    CPU_POWERPC_7400_v27    = 0x000C0207,
4380
    CPU_POWERPC_7400_v28    = 0x000C0208,
4381
    CPU_POWERPC_7400_v29    = 0x000C0209,
4382
#define CPU_POWERPC_7410      CPU_POWERPC_7410_v14
4383
    CPU_POWERPC_7410_v10    = 0x800C1100,
4384
    CPU_POWERPC_7410_v11    = 0x800C1101,
4385
    CPU_POWERPC_7410_v12    = 0x800C1102, /* aka C */
4386
    CPU_POWERPC_7410_v13    = 0x800C1103, /* aka D */
4387
    CPU_POWERPC_7410_v14    = 0x800C1104, /* aka E */
4388
#define CPU_POWERPC_7448      CPU_POWERPC_7448_v21
4389
    CPU_POWERPC_7448_v10    = 0x80040100,
4390
    CPU_POWERPC_7448_v11    = 0x80040101,
4391
    CPU_POWERPC_7448_v20    = 0x80040200,
4392
    CPU_POWERPC_7448_v21    = 0x80040201,
4393
#define CPU_POWERPC_7450      CPU_POWERPC_7450_v21
4394
    CPU_POWERPC_7450_v10    = 0x80000100,
4395
    CPU_POWERPC_7450_v11    = 0x80000101,
4396
    CPU_POWERPC_7450_v12    = 0x80000102,
4397
    CPU_POWERPC_7450_v20    = 0x80000200, /* aka D: 2.04 */
4398
    CPU_POWERPC_7450_v21    = 0x80000201, /* aka E */
4399
    CPU_POWERPC_74x1        = 0x80000203,
4400
    CPU_POWERPC_74x1G       = 0x80000210, /* aka G: 2.3 */
4401
    /* XXX: missing 0x80010200 */
4402
#define CPU_POWERPC_74x5      CPU_POWERPC_74x5_v32
4403
    CPU_POWERPC_74x5_v10    = 0x80010100,
4404
    CPU_POWERPC_74x5_v21    = 0x80010201, /* aka C: 2.1 */
4405
    CPU_POWERPC_74x5_v32    = 0x80010302,
4406
    CPU_POWERPC_74x5_v33    = 0x80010303, /* aka F: 3.3 */
4407
    CPU_POWERPC_74x5_v34    = 0x80010304, /* aka G: 3.4 */
4408
#define CPU_POWERPC_74x7      CPU_POWERPC_74x7_v12
4409
    CPU_POWERPC_74x7_v10    = 0x80020100, /* aka A: 1.0 */
4410
    CPU_POWERPC_74x7_v11    = 0x80030101, /* aka B: 1.1 */
4411
    CPU_POWERPC_74x7_v12    = 0x80020102, /* aka C: 1.2 */
4412
    /* 64 bits PowerPC */
4413
    CPU_POWERPC_620         = 0x00140000,
4414
    CPU_POWERPC_630         = 0x00400000,
4415
    CPU_POWERPC_631         = 0x00410104,
4416
    CPU_POWERPC_POWER4      = 0x00350000,
4417
    CPU_POWERPC_POWER4P     = 0x00380000,
4418
    CPU_POWERPC_POWER5      = 0x003A0203,
4419
#define CPU_POWERPC_POWER5GR  CPU_POWERPC_POWER5
4420
    CPU_POWERPC_POWER5P     = 0x003B0000,
4421
#define CPU_POWERPC_POWER5GS  CPU_POWERPC_POWER5P
4422
    CPU_POWERPC_POWER6      = 0x003E0000,
4423
    CPU_POWERPC_POWER6_5    = 0x0F000001, /* POWER6 running POWER5 mode */
4424
    CPU_POWERPC_POWER6A     = 0x0F000002,
4425
    CPU_POWERPC_970         = 0x00390202,
4426
#define CPU_POWERPC_970FX     CPU_POWERPC_970FX_v31
4427
    CPU_POWERPC_970FX_v10   = 0x00391100,
4428
    CPU_POWERPC_970FX_v20   = 0x003C0200,
4429
    CPU_POWERPC_970FX_v21   = 0x003C0201,
4430
    CPU_POWERPC_970FX_v30   = 0x003C0300,
4431
    CPU_POWERPC_970FX_v31   = 0x003C0301,
4432
    CPU_POWERPC_970GX       = 0x00450000,
4433
#define CPU_POWERPC_970MP     CPU_POWERPC_970MP_v11
4434
    CPU_POWERPC_970MP_v10   = 0x00440100,
4435
    CPU_POWERPC_970MP_v11   = 0x00440101,
4436
#define CPU_POWERPC_CELL      CPU_POWERPC_CELL_v32
4437
    CPU_POWERPC_CELL_v10    = 0x00700100,
4438
    CPU_POWERPC_CELL_v20    = 0x00700400,
4439
    CPU_POWERPC_CELL_v30    = 0x00700500,
4440
    CPU_POWERPC_CELL_v31    = 0x00700501,
4441
#define CPU_POWERPC_CELL_v32  CPU_POWERPC_CELL_v31
4442
    CPU_POWERPC_RS64        = 0x00330000,
4443
    CPU_POWERPC_RS64II      = 0x00340000,
4444
    CPU_POWERPC_RS64III     = 0x00360000,
4445
    CPU_POWERPC_RS64IV      = 0x00370000,
4446
    /* Original POWER */
4447
    /* XXX: should be POWER (RIOS), RSC3308, RSC4608,
4448
     * POWER2 (RIOS2) & RSC2 (P2SC) here
4449
     */
4450
#if 0
4451
    CPU_POWER           = xxx, /* 0x20000 ? 0x30000 for RSC ? */
4452
#endif
4453
#if 0
4454
    CPU_POWER2          = xxx, /* 0x40000 ? */
4455
#endif
4456
    /* PA Semi core */
4457
    CPU_POWERPC_PA6T        = 0x00900000,
4458
};
4459

    
4460
/* System version register (used on MPC 8xxx)                                */
4461
enum {
4462
    PPC_SVR_8540      = 0x80300000,
4463
    PPC_SVR_8541E     = 0x807A0010,
4464
    PPC_SVR_8543v10   = 0x80320010,
4465
    PPC_SVR_8543v11   = 0x80320011,
4466
    PPC_SVR_8543v20   = 0x80320020,
4467
    PPC_SVR_8543Ev10  = 0x803A0010,
4468
    PPC_SVR_8543Ev11  = 0x803A0011,
4469
    PPC_SVR_8543Ev20  = 0x803A0020,
4470
    PPC_SVR_8545      = 0x80310220,
4471
    PPC_SVR_8545E     = 0x80390220,
4472
    PPC_SVR_8547E     = 0x80390120,
4473
    PPC_SCR_8548v10   = 0x80310010,
4474
    PPC_SCR_8548v11   = 0x80310011,
4475
    PPC_SCR_8548v20   = 0x80310020,
4476
    PPC_SVR_8548Ev10  = 0x80390010,
4477
    PPC_SVR_8548Ev11  = 0x80390011,
4478
    PPC_SVR_8548Ev20  = 0x80390020,
4479
    PPC_SVR_8555E     = 0x80790010,
4480
    PPC_SVR_8560v10   = 0x80700010,
4481
    PPC_SVR_8560v20   = 0x80700020,
4482
};
4483

    
4484
/*****************************************************************************/
4485
/* PowerPC CPU definitions                                                   */
4486
#define POWERPC_DEF(_name, _pvr, _pvr_mask, _type)                            \
4487
    {                                                                         \
4488
        .name        = _name,                                                 \
4489
        .pvr         = _pvr,                                                  \
4490
        .pvr_mask    = _pvr_mask,                                             \
4491
        .insns_flags = glue(POWERPC_INSNS_,_type),                            \
4492
        .msr_mask    = glue(POWERPC_MSRM_,_type),                             \
4493
        .mmu_model   = glue(POWERPC_MMU_,_type),                              \
4494
        .excp_model  = glue(POWERPC_EXCP_,_type),                             \
4495
        .bus_model   = glue(POWERPC_INPUT_,_type),                            \
4496
        .bfd_mach    = glue(POWERPC_BFDM_,_type),                             \
4497
        .init_proc   = &glue(init_proc_,_type),                               \
4498
    }
4499

    
4500
static ppc_def_t ppc_defs[] = {
4501
    /* Embedded PowerPC                                                      */
4502
    /* PowerPC 401 family                                                    */
4503
    /* Generic PowerPC 401 */
4504
    POWERPC_DEF("401",         CPU_POWERPC_401,         0xFFFF0000, 401),
4505
    /* PowerPC 401 cores                                                     */
4506
    /* PowerPC 401A1 */
4507
    POWERPC_DEF("401A1",       CPU_POWERPC_401A1,       0xFFFFFFFF, 401),
4508
    /* PowerPC 401B2                                                         */
4509
    POWERPC_DEF("401B2",       CPU_POWERPC_401B2,       0xFFFFFFFF, 401x2),
4510
#if defined (TODO)
4511
    /* PowerPC 401B3                                                         */
4512
    POWERPC_DEF("401B3",       CPU_POWERPC_401B3,       0xFFFFFFFF, 401x3),
4513
#endif
4514
    /* PowerPC 401C2                                                         */
4515
    POWERPC_DEF("401C2",       CPU_POWERPC_401C2,       0xFFFFFFFF, 401x2),
4516
    /* PowerPC 401D2                                                         */
4517
    POWERPC_DEF("401D2",       CPU_POWERPC_401D2,       0xFFFFFFFF, 401x2),
4518
    /* PowerPC 401E2                                                         */
4519
    POWERPC_DEF("401E2",       CPU_POWERPC_401E2,       0xFFFFFFFF, 401x2),
4520
    /* PowerPC 401F2                                                         */
4521
    POWERPC_DEF("401F2",       CPU_POWERPC_401F2,       0xFFFFFFFF, 401x2),
4522
    /* PowerPC 401G2                                                         */
4523
    /* XXX: to be checked */
4524
    POWERPC_DEF("401G2",       CPU_POWERPC_401G2,       0xFFFFFFFF, 401x2),
4525
    /* PowerPC 401 microcontrolers                                           */
4526
#if defined (TODO)
4527
    /* PowerPC 401GF                                                         */
4528
    POWERPC_DEF("401GF",       CPU_POWERPC_401GF,       0xFFFFFFFF, 401),
4529
#endif
4530
    /* IOP480 (401 microcontroler)                                           */
4531
    POWERPC_DEF("IOP480",      CPU_POWERPC_IOP480,      0xFFFFFFFF, IOP480),
4532
    /* IBM Processor for Network Resources                                   */
4533
    POWERPC_DEF("Cobra",       CPU_POWERPC_COBRA,       0xFFFFFFFF, 401),
4534
#if defined (TODO)
4535
    POWERPC_DEF("Xipchip",     CPU_POWERPC_XIPCHIP,     0xFFFFFFFF, 401),
4536
#endif
4537
    /* PowerPC 403 family                                                    */
4538
    /* Generic PowerPC 403                                                   */
4539
    POWERPC_DEF("403",         CPU_POWERPC_403,         0xFFFF0000, 403),
4540
    /* PowerPC 403 microcontrolers                                           */
4541
    /* PowerPC 403 GA                                                        */
4542
    POWERPC_DEF("403GA",       CPU_POWERPC_403GA,       0xFFFFFFFF, 403),
4543
    /* PowerPC 403 GB                                                        */
4544
    POWERPC_DEF("403GB",       CPU_POWERPC_403GB,       0xFFFFFFFF, 403),
4545
    /* PowerPC 403 GC                                                        */
4546
    POWERPC_DEF("403GC",       CPU_POWERPC_403GC,       0xFFFFFFFF, 403),
4547
    /* PowerPC 403 GCX                                                       */
4548
    POWERPC_DEF("403GCX",      CPU_POWERPC_403GCX,      0xFFFFFFFF, 403GCX),
4549
#if defined (TODO)
4550
    /* PowerPC 403 GP                                                        */
4551
    POWERPC_DEF("403GP",       CPU_POWERPC_403GP,       0xFFFFFFFF, 403),
4552
#endif
4553
    /* PowerPC 405 family                                                    */
4554
    /* Generic PowerPC 405                                                   */
4555
    POWERPC_DEF("405",         CPU_POWERPC_405,         0xFFFF0000, 405),
4556
    /* PowerPC 405 cores                                                     */
4557
#if defined (TODO)
4558
    /* PowerPC 405 A3                                                        */
4559
    POWERPC_DEF("405A3",       CPU_POWERPC_405A3,       0xFFFFFFFF, 405),
4560
#endif
4561
#if defined (TODO)
4562
    /* PowerPC 405 A4                                                        */
4563
    POWERPC_DEF("405A4",       CPU_POWERPC_405A4,       0xFFFFFFFF, 405),
4564
#endif
4565
#if defined (TODO)
4566
    /* PowerPC 405 B3                                                        */
4567
    POWERPC_DEF("405B3",       CPU_POWERPC_405B3,       0xFFFFFFFF, 405),
4568
#endif
4569
#if defined (TODO)
4570
    /* PowerPC 405 B4                                                        */
4571
    POWERPC_DEF("405B4",       CPU_POWERPC_405B4,       0xFFFFFFFF, 405),
4572
#endif
4573
#if defined (TODO)
4574
    /* PowerPC 405 C3                                                        */
4575
    POWERPC_DEF("405C3",       CPU_POWERPC_405C3,       0xFFFFFFFF, 405),
4576
#endif
4577
#if defined (TODO)
4578
    /* PowerPC 405 C4                                                        */
4579
    POWERPC_DEF("405C4",       CPU_POWERPC_405C4,       0xFFFFFFFF, 405),
4580
#endif
4581
    /* PowerPC 405 D2                                                        */
4582
    POWERPC_DEF("405D2",       CPU_POWERPC_405D2,       0xFFFFFFFF, 405),
4583
#if defined (TODO)
4584
    /* PowerPC 405 D3                                                        */
4585
    POWERPC_DEF("405D3",       CPU_POWERPC_405D3,       0xFFFFFFFF, 405),
4586
#endif
4587
    /* PowerPC 405 D4                                                        */
4588
    POWERPC_DEF("405D4",       CPU_POWERPC_405D4,       0xFFFFFFFF, 405),
4589
#if defined (TODO)
4590
    /* PowerPC 405 D5                                                        */
4591
    POWERPC_DEF("405D5",       CPU_POWERPC_405D5,       0xFFFFFFFF, 405),
4592
#endif
4593
#if defined (TODO)
4594
    /* PowerPC 405 E4                                                        */
4595
    POWERPC_DEF("405E4",       CPU_POWERPC_405E4,       0xFFFFFFFF, 405),
4596
#endif
4597
#if defined (TODO)
4598
    /* PowerPC 405 F4                                                        */
4599
    POWERPC_DEF("405F4",       CPU_POWERPC_405F4,       0xFFFFFFFF, 405),
4600
#endif
4601
#if defined (TODO)
4602
    /* PowerPC 405 F5                                                        */
4603
    POWERPC_DEF("405F5",       CPU_POWERPC_405F5,       0xFFFFFFFF, 405),
4604
#endif
4605
#if defined (TODO)
4606
    /* PowerPC 405 F6                                                        */
4607
    POWERPC_DEF("405F6",       CPU_POWERPC_405F6,       0xFFFFFFFF, 405),
4608
#endif
4609
    /* PowerPC 405 microcontrolers                                           */
4610
    /* PowerPC 405 CR                                                        */
4611
    POWERPC_DEF("405CR",       CPU_POWERPC_405CR,       0xFFFFFFFF, 405),
4612
    /* PowerPC 405 CRa                                                       */
4613
    POWERPC_DEF("405CRa",      CPU_POWERPC_405CRa,      0xFFFFFFFF, 405),
4614
    /* PowerPC 405 CRb                                                       */
4615
    POWERPC_DEF("405CRb",      CPU_POWERPC_405CRb,      0xFFFFFFFF, 405),
4616
    /* PowerPC 405 CRc                                                       */
4617
    POWERPC_DEF("405CRc",      CPU_POWERPC_405CRc,      0xFFFFFFFF, 405),
4618
    /* PowerPC 405 EP                                                        */
4619
    POWERPC_DEF("405EP",       CPU_POWERPC_405EP,       0xFFFFFFFF, 405),
4620
#if defined(TODO)
4621
    /* PowerPC 405 EXr                                                       */
4622
    POWERPC_DEF("405EXr",      CPU_POWERPC_405EXr,      0xFFFFFFFF, 405),
4623
#endif
4624
    /* PowerPC 405 EZ                                                        */
4625
    POWERPC_DEF("405EZ",       CPU_POWERPC_405EZ,       0xFFFFFFFF, 405),
4626
#if defined(TODO)
4627
    /* PowerPC 405 FX                                                        */
4628
    POWERPC_DEF("405FX",       CPU_POWERPC_405FX,       0xFFFFFFFF, 405),
4629
#endif
4630
    /* PowerPC 405 GP                                                        */
4631
    POWERPC_DEF("405GP",       CPU_POWERPC_405GP,       0xFFFFFFFF, 405),
4632
    /* PowerPC 405 GPa                                                       */
4633
    POWERPC_DEF("405GPa",      CPU_POWERPC_405GPa,      0xFFFFFFFF, 405),
4634
    /* PowerPC 405 GPb                                                       */
4635
    POWERPC_DEF("405GPb",      CPU_POWERPC_405GPb,      0xFFFFFFFF, 405),
4636
    /* PowerPC 405 GPc                                                       */
4637
    POWERPC_DEF("405GPc",      CPU_POWERPC_405GPc,      0xFFFFFFFF, 405),
4638
    /* PowerPC 405 GPd                                                       */
4639
    POWERPC_DEF("405GPd",      CPU_POWERPC_405GPd,      0xFFFFFFFF, 405),
4640
    /* PowerPC 405 GPe                                                       */
4641
    POWERPC_DEF("405GPe",      CPU_POWERPC_405GPe,      0xFFFFFFFF, 405),
4642
    /* PowerPC 405 GPR                                                       */
4643
    POWERPC_DEF("405GPR",      CPU_POWERPC_405GPR,      0xFFFFFFFF, 405),
4644
#if defined(TODO)
4645
    /* PowerPC 405 H                                                         */
4646
    POWERPC_DEF("405H",        CPU_POWERPC_405H,        0xFFFFFFFF, 405),
4647
#endif
4648
#if defined(TODO)
4649
    /* PowerPC 405 L                                                         */
4650
    POWERPC_DEF("405L",        CPU_POWERPC_405L,        0xFFFFFFFF, 405),
4651
#endif
4652
    /* PowerPC 405 LP                                                        */
4653
    POWERPC_DEF("405LP",       CPU_POWERPC_405LP,       0xFFFFFFFF, 405),
4654
#if defined(TODO)
4655
    /* PowerPC 405 PM                                                        */
4656
    POWERPC_DEF("405PM",       CPU_POWERPC_405PM,       0xFFFFFFFF, 405),
4657
#endif
4658
#if defined(TODO)
4659
    /* PowerPC 405 PS                                                        */
4660
    POWERPC_DEF("405PS",       CPU_POWERPC_405PS,       0xFFFFFFFF, 405),
4661
#endif
4662
#if defined(TODO)
4663
    /* PowerPC 405 S                                                         */
4664
    POWERPC_DEF("405S",        CPU_POWERPC_405S,        0xFFFFFFFF, 405),
4665
#endif
4666
    /* Npe405 H                                                              */
4667
    POWERPC_DEF("Npe405H",     CPU_POWERPC_NPE405H,     0xFFFFFFFF, 405),
4668
    /* Npe405 H2                                                             */
4669
    POWERPC_DEF("Npe405H2",    CPU_POWERPC_NPE405H2,    0xFFFFFFFF, 405),
4670
    /* Npe405 L                                                              */
4671
    POWERPC_DEF("Npe405L",     CPU_POWERPC_NPE405L,     0xFFFFFFFF, 405),
4672
    /* Npe4GS3                                                               */
4673
    POWERPC_DEF("Npe4GS3",     CPU_POWERPC_NPE4GS3,     0xFFFFFFFF, 405),
4674
#if defined (TODO)
4675
    POWERPC_DEF("Npcxx1",      CPU_POWERPC_NPCxx1,      0xFFFFFFFF, 405),
4676
#endif
4677
#if defined (TODO)
4678
    POWERPC_DEF("Npr161",      CPU_POWERPC_NPR161,      0xFFFFFFFF, 405),
4679
#endif
4680
#if defined (TODO)
4681
    /* PowerPC LC77700 (Sanyo)                                               */
4682
    POWERPC_DEF("LC77700",     CPU_POWERPC_LC77700,     0xFFFFFFFF, 405),
4683
#endif
4684
    /* PowerPC 401/403/405 based set-top-box microcontrolers                 */
4685
#if defined (TODO)
4686
    /* STB010000                                                             */
4687
    POWERPC_DEF("STB01000",    CPU_POWERPC_STB01000,    0xFFFFFFFF, 401x2),
4688
#endif
4689
#if defined (TODO)
4690
    /* STB01010                                                              */
4691
    POWERPC_DEF("STB01010",    CPU_POWERPC_STB01010,    0xFFFFFFFF, 401x2),
4692
#endif
4693
#if defined (TODO)
4694
    /* STB0210                                                               */
4695
    POWERPC_DEF("STB0210",     CPU_POWERPC_STB0210,     0xFFFFFFFF, 401x3),
4696
#endif
4697
    /* STB03xx                                                               */
4698
    POWERPC_DEF("STB03",       CPU_POWERPC_STB03,       0xFFFFFFFF, 405),
4699
#if defined (TODO)
4700
    /* STB043x                                                               */
4701
    POWERPC_DEF("STB043",      CPU_POWERPC_STB043,      0xFFFFFFFF, 405),
4702
#endif
4703
#if defined (TODO)
4704
    /* STB045x                                                               */
4705
    POWERPC_DEF("STB045",      CPU_POWERPC_STB045,      0xFFFFFFFF, 405),
4706
#endif
4707
    /* STB04xx                                                               */
4708
    POWERPC_DEF("STB04",       CPU_POWERPC_STB04,       0xFFFF0000, 405),
4709
    /* STB25xx                                                               */
4710
    POWERPC_DEF("STB25",       CPU_POWERPC_STB25,       0xFFFFFFFF, 405),
4711
#if defined (TODO)
4712
    /* STB130                                                                */
4713
    POWERPC_DEF("STB130",      CPU_POWERPC_STB130,      0xFFFFFFFF, 405),
4714
#endif
4715
    /* Xilinx PowerPC 405 cores                                              */
4716
    POWERPC_DEF("x2vp4",       CPU_POWERPC_X2VP4,       0xFFFFFFFF, 405),
4717
    POWERPC_DEF("x2vp7",       CPU_POWERPC_X2VP7,       0xFFFFFFFF, 405),
4718
    POWERPC_DEF("x2vp20",      CPU_POWERPC_X2VP20,      0xFFFFFFFF, 405),
4719
    POWERPC_DEF("x2vp50",      CPU_POWERPC_X2VP50,      0xFFFFFFFF, 405),
4720
#if defined (TODO)
4721
    /* Zarlink ZL10310                                                       */
4722
    POWERPC_DEF("zl10310",     CPU_POWERPC_ZL10310,     0xFFFFFFFF, 405),
4723
#endif
4724
#if defined (TODO)
4725
    /* Zarlink ZL10311                                                       */
4726
    POWERPC_DEF("zl10311",     CPU_POWERPC_ZL10311,     0xFFFFFFFF, 405),
4727
#endif
4728
#if defined (TODO)
4729
    /* Zarlink ZL10320                                                       */
4730
    POWERPC_DEF("zl10320",     CPU_POWERPC_ZL10320,     0xFFFFFFFF, 405),
4731
#endif
4732
#if defined (TODO)
4733
    /* Zarlink ZL10321                                                       */
4734
    POWERPC_DEF("zl10321",     CPU_POWERPC_ZL10321,     0xFFFFFFFF, 405),
4735
#endif
4736
    /* PowerPC 440 family                                                    */
4737
    /* Generic PowerPC 440                                                   */
4738
    POWERPC_DEF("440",         CPU_POWERPC_440,         0xFFFFFFFF, 440GP),
4739
    /* PowerPC 440 cores                                                     */
4740
#if defined (TODO)
4741
    /* PowerPC 440 A4                                                        */
4742
    POWERPC_DEF("440A4",       CPU_POWERPC_440A4,       0xFFFFFFFF, 440x4),
4743
#endif
4744
#if defined (TODO)
4745
    /* PowerPC 440 A5                                                        */
4746
    POWERPC_DEF("440A5",       CPU_POWERPC_440A5,       0xFFFFFFFF, 440x5),
4747
#endif
4748
#if defined (TODO)
4749
    /* PowerPC 440 B4                                                        */
4750
    POWERPC_DEF("440B4",       CPU_POWERPC_440B4,       0xFFFFFFFF, 440x4),
4751
#endif
4752
#if defined (TODO)
4753
    /* PowerPC 440 G4                                                        */
4754
    POWERPC_DEF("440G4",       CPU_POWERPC_440G4,       0xFFFFFFFF, 440x4),
4755
#endif
4756
#if defined (TODO)
4757
    /* PowerPC 440 F5                                                        */
4758
    POWERPC_DEF("440F5",       CPU_POWERPC_440F5,       0xFFFFFFFF, 440x5),
4759
#endif
4760
#if defined (TODO)
4761
    /* PowerPC 440 G5                                                        */
4762
    POWERPC_DEF("440G5",       CPU_POWERPC_440G5,       0xFFFFFFFF, 440x5),
4763
#endif
4764
#if defined (TODO)
4765
    /* PowerPC 440H4                                                         */
4766
    POWERPC_DEF("440H4",       CPU_POWERPC_440H4,       0xFFFFFFFF, 440x4),
4767
#endif
4768
#if defined (TODO)
4769
    /* PowerPC 440H6                                                         */
4770
    POWERPC_DEF("440H6",       CPU_POWERPC_440H6,       0xFFFFFFFF, 440Gx5),
4771
#endif
4772
    /* PowerPC 440 microcontrolers                                           */
4773
    /* PowerPC 440 EP                                                        */
4774
    POWERPC_DEF("440EP",       CPU_POWERPC_440EP,       0xFFFFFFFF, 440EP),
4775
    /* PowerPC 440 EPa                                                       */
4776
    POWERPC_DEF("440EPa",      CPU_POWERPC_440EPa,      0xFFFFFFFF, 440EP),
4777
    /* PowerPC 440 EPb                                                       */
4778
    POWERPC_DEF("440EPb",      CPU_POWERPC_440EPb,      0xFFFFFFFF, 440EP),
4779
    /* PowerPC 440 EPX                                                       */
4780
    POWERPC_DEF("440EPX",      CPU_POWERPC_440EPX,      0xFFFFFFFF, 440EP),
4781
    /* PowerPC 440 GP                                                        */
4782
    POWERPC_DEF("440GP",       CPU_POWERPC_440GP,       0xFFFFFFFF, 440GP),
4783
    /* PowerPC 440 GPb                                                       */
4784
    POWERPC_DEF("440GPb",      CPU_POWERPC_440GPb,      0xFFFFFFFF, 440GP),
4785
    /* PowerPC 440 GPc                                                       */
4786
    POWERPC_DEF("440GPc",      CPU_POWERPC_440GPc,      0xFFFFFFFF, 440GP),
4787
    /* PowerPC 440 GR                                                        */
4788
    POWERPC_DEF("440GR",       CPU_POWERPC_440GR,       0xFFFFFFFF, 440x5),
4789
    /* PowerPC 440 GRa                                                       */
4790
    POWERPC_DEF("440GRa",      CPU_POWERPC_440GRa,      0xFFFFFFFF, 440x5),
4791
    /* PowerPC 440 GRX                                                       */
4792
    POWERPC_DEF("440GRX",      CPU_POWERPC_440GRX,      0xFFFFFFFF, 440x5),
4793
    /* PowerPC 440 GX                                                        */
4794
    POWERPC_DEF("440GX",       CPU_POWERPC_440GX,       0xFFFFFFFF, 440EP),
4795
    /* PowerPC 440 GXa                                                       */
4796
    POWERPC_DEF("440GXa",      CPU_POWERPC_440GXa,      0xFFFFFFFF, 440EP),
4797
    /* PowerPC 440 GXb                                                       */
4798
    POWERPC_DEF("440GXb",      CPU_POWERPC_440GXb,      0xFFFFFFFF, 440EP),
4799
    /* PowerPC 440 GXc                                                       */
4800
    POWERPC_DEF("440GXc",      CPU_POWERPC_440GXc,      0xFFFFFFFF, 440EP),
4801
    /* PowerPC 440 GXf                                                       */
4802
    POWERPC_DEF("440GXf",      CPU_POWERPC_440GXf,      0xFFFFFFFF, 440EP),
4803
#if defined(TODO)
4804
    /* PowerPC 440 S                                                         */
4805
    POWERPC_DEF("440S",        CPU_POWERPC_440S,        0xFFFFFFFF, 440),
4806
#endif
4807
    /* PowerPC 440 SP                                                        */
4808
    POWERPC_DEF("440SP",       CPU_POWERPC_440SP,       0xFFFFFFFF, 440EP),
4809
    /* PowerPC 440 SP2                                                       */
4810
    POWERPC_DEF("440SP2",      CPU_POWERPC_440SP2,      0xFFFFFFFF, 440EP),
4811
    /* PowerPC 440 SPE                                                       */
4812
    POWERPC_DEF("440SPE",      CPU_POWERPC_440SPE,      0xFFFFFFFF, 440EP),
4813
    /* PowerPC 460 family                                                    */
4814
#if defined (TODO)
4815
    /* Generic PowerPC 464                                                   */
4816
    POWERPC_DEF("464",         CPU_POWERPC_464,         0xFFFFFFFF, 460),
4817
#endif
4818
    /* PowerPC 464 microcontrolers                                           */
4819
#if defined (TODO)
4820
    /* PowerPC 464H90                                                        */
4821
    POWERPC_DEF("464H90",      CPU_POWERPC_464H90,      0xFFFFFFFF, 460),
4822
#endif
4823
#if defined (TODO)
4824
    /* PowerPC 464H90F                                                       */
4825
    POWERPC_DEF("464H90F",     CPU_POWERPC_464H90F,     0xFFFFFFFF, 460F),
4826
#endif
4827
    /* Freescale embedded PowerPC cores                                      */
4828
    /* e200 family                                                           */
4829
#if defined (TODO)
4830
    /* Generic PowerPC e200 core                                             */
4831
    POWERPC_DEF("e200",        CPU_POWERPC_e200,        0xFFFFFFFF, e200),
4832
#endif
4833
#if defined (TODO)
4834
    /* PowerPC e200z5 core                                                   */
4835
    POWERPC_DEF("e200z5",      CPU_POWERPC_e200z5,      0xFFFFFFFF, e200),
4836
#endif
4837
#if defined (TODO)
4838
    /* PowerPC e200z6 core                                                   */
4839
    POWERPC_DEF("e200z6",      CPU_POWERPC_e200z6,      0xFFFFFFFF, e200),
4840
#endif
4841
    /* e300 family                                                           */
4842
#if defined (TODO)
4843
    /* Generic PowerPC e300 core                                             */
4844
    POWERPC_DEF("e300",        CPU_POWERPC_e300,        0xFFFFFFFF, e300),
4845
#endif
4846
#if defined (TODO)
4847
    /* PowerPC e300c1 core                                                   */
4848
    POWERPC_DEF("e300c1",      CPU_POWERPC_e300c1,      0xFFFFFFFF, e300),
4849
#endif
4850
#if defined (TODO)
4851
    /* PowerPC e300c2 core                                                   */
4852
    POWERPC_DEF("e300c2",      CPU_POWERPC_e300c2,      0xFFFFFFFF, e300),
4853
#endif
4854
#if defined (TODO)
4855
    /* PowerPC e300c3 core                                                   */
4856
    POWERPC_DEF("e300c3",      CPU_POWERPC_e300c3,      0xFFFFFFFF, e300),
4857
#endif
4858
    /* e500 family                                                           */
4859
#if defined (TODO)
4860
    /* PowerPC e500 core                                                     */
4861
    POWERPC_DEF("e500",        CPU_POWERPC_e500,        0xFFFFFFFF, e500),
4862
#endif
4863
#if defined (TODO)
4864
    /* PowerPC e500 v1.1 core                                                */
4865
    POWERPC_DEF("e500v1.1",    CPU_POWERPC_e500_v11,    0xFFFFFFFF, e500),
4866
#endif
4867
#if defined (TODO)
4868
    /* PowerPC e500 v1.2 core                                                */
4869
    POWERPC_DEF("e500v1.2",    CPU_POWERPC_e500_v12,    0xFFFFFFFF, e500),
4870
#endif
4871
#if defined (TODO)
4872
    /* PowerPC e500 v2.1 core                                                */
4873
    POWERPC_DEF("e500v2.1",    CPU_POWERPC_e500_v21,    0xFFFFFFFF, e500),
4874
#endif
4875
#if defined (TODO)
4876
    /* PowerPC e500 v2.2 core                                                */
4877
    POWERPC_DEF("e500v2.2",    CPU_POWERPC_e500_v22,    0xFFFFFFFF, e500),
4878
#endif
4879
    /* e600 family                                                           */
4880
#if defined (TODO)
4881
    /* PowerPC e600 core                                                     */
4882
    POWERPC_DEF("e600",        CPU_POWERPC_e600,        0xFFFFFFFF, e600),
4883
#endif
4884
    /* PowerPC MPC 5xx cores                                                 */
4885
#if defined (TODO)
4886
    /* PowerPC MPC 5xx                                                       */
4887
    POWERPC_DEF("mpc5xx",      CPU_POWERPC_5xx,         0xFFFFFFFF, 5xx),
4888
#endif
4889
    /* PowerPC MPC 8xx cores                                                 */
4890
#if defined (TODO)
4891
    /* PowerPC MPC 8xx                                                       */
4892
    POWERPC_DEF("mpc8xx",      CPU_POWERPC_8xx,         0xFFFFFFFF, 8xx),
4893
#endif
4894
    /* PowerPC MPC 8xxx cores                                                */
4895
#if defined (TODO)
4896
    /* PowerPC MPC 82xx HIP3                                                 */
4897
    POWERPC_DEF("mpc82xxhip3", CPU_POWERPC_82xx_HIP3,   0xFFFFFFFF, 82xx),
4898
#endif
4899
#if defined (TODO)
4900
    /* PowerPC MPC 82xx HIP4                                                 */
4901
    POWERPC_DEF("mpc82xxhip4", CPU_POWERPC_82xx_HIP4,   0xFFFFFFFF, 82xx),
4902
#endif
4903
#if defined (TODO)
4904
    /* PowerPC MPC 827x                                                      */
4905
    POWERPC_DEF("mpc827x",     CPU_POWERPC_827x,        0xFFFFFFFF, 827x),
4906
#endif
4907

    
4908
    /* 32 bits "classic" PowerPC                                             */
4909
    /* PowerPC 6xx family                                                    */
4910
    /* PowerPC 601                                                           */
4911
    POWERPC_DEF("601",         CPU_POWERPC_601,         0xFFFFFFFF, 601),
4912
    /* PowerPC 601v2                                                         */
4913
    POWERPC_DEF("601a",        CPU_POWERPC_601a,        0xFFFFFFFF, 601),
4914
    /* PowerPC 602                                                           */
4915
    POWERPC_DEF("602",         CPU_POWERPC_602,         0xFFFFFFFF, 602),
4916
    /* PowerPC 603                                                           */
4917
    POWERPC_DEF("603",         CPU_POWERPC_603,         0xFFFFFFFF, 603),
4918
    /* Code name for PowerPC 603                                             */
4919
    POWERPC_DEF("Vanilla",     CPU_POWERPC_603,         0xFFFFFFFF, 603),
4920
    /* PowerPC 603e                                                          */
4921
    POWERPC_DEF("603e",        CPU_POWERPC_603E,        0xFFFFFFFF, 603E),
4922
    /* Code name for PowerPC 603e                                            */
4923
    POWERPC_DEF("Stretch",     CPU_POWERPC_603E,        0xFFFFFFFF, 603E),
4924
    /* PowerPC 603e v1.1                                                     */
4925
    POWERPC_DEF("603e1.1",     CPU_POWERPC_603E_v11,    0xFFFFFFFF, 603E),
4926
    /* PowerPC 603e v1.2                                                     */
4927
    POWERPC_DEF("603e1.2",     CPU_POWERPC_603E_v12,    0xFFFFFFFF, 603E),
4928
    /* PowerPC 603e v1.3                                                     */
4929
    POWERPC_DEF("603e1.3",     CPU_POWERPC_603E_v13,    0xFFFFFFFF, 603E),
4930
    /* PowerPC 603e v1.4                                                     */
4931
    POWERPC_DEF("603e1.4",     CPU_POWERPC_603E_v14,    0xFFFFFFFF, 603E),
4932
    /* PowerPC 603e v2.2                                                     */
4933
    POWERPC_DEF("603e2.2",     CPU_POWERPC_603E_v22,    0xFFFFFFFF, 603E),
4934
    /* PowerPC 603e v3                                                       */
4935
    POWERPC_DEF("603e3",       CPU_POWERPC_603E_v3,     0xFFFFFFFF, 603E),
4936
    /* PowerPC 603e v4                                                       */
4937
    POWERPC_DEF("603e4",       CPU_POWERPC_603E_v4,     0xFFFFFFFF, 603E),
4938
    /* PowerPC 603e v4.1                                                     */
4939
    POWERPC_DEF("603e4.1",     CPU_POWERPC_603E_v41,    0xFFFFFFFF, 603E),
4940
    /* PowerPC 603e                                                          */
4941
    POWERPC_DEF("603e7",       CPU_POWERPC_603E7,       0xFFFFFFFF, 603E),
4942
    /* PowerPC 603e7t                                                        */
4943
    POWERPC_DEF("603e7t",      CPU_POWERPC_603E7t,      0xFFFFFFFF, 603E),
4944
    /* PowerPC 603e7v                                                        */
4945
    POWERPC_DEF("603e7v",      CPU_POWERPC_603E7v,      0xFFFFFFFF, 603E),
4946
    /* Code name for PowerPC 603ev                                           */
4947
    POWERPC_DEF("Vaillant",    CPU_POWERPC_603E7v,      0xFFFFFFFF, 603E),
4948
    /* PowerPC 603e7v1                                                       */
4949
    POWERPC_DEF("603e7v1",     CPU_POWERPC_603E7v1,     0xFFFFFFFF, 603E),
4950
    /* PowerPC 603e7v2                                                       */
4951
    POWERPC_DEF("603e7v2",     CPU_POWERPC_603E7v2,     0xFFFFFFFF, 603E),
4952
    /* PowerPC 603p                                                          */
4953
    /* to be checked */
4954
    POWERPC_DEF("603p",        CPU_POWERPC_603P,        0xFFFFFFFF, 603),
4955
    /* PowerPC 603r                                                          */
4956
    POWERPC_DEF("603r",        CPU_POWERPC_603R,        0xFFFFFFFF, 603E),
4957
    /* Code name for PowerPC 603r                                            */
4958
    POWERPC_DEF("Goldeneye",   CPU_POWERPC_603R,        0xFFFFFFFF, 603E),
4959
    /* PowerPC G2 core                                                       */
4960
    POWERPC_DEF("G2",          CPU_POWERPC_G2,          0xFFFFFFFF, G2),
4961
    /* PowerPC G2 H4                                                         */
4962
    POWERPC_DEF("G2H4",        CPU_POWERPC_G2H4,        0xFFFFFFFF, G2),
4963
    /* PowerPC G2 GP                                                         */
4964
    POWERPC_DEF("G2GP",        CPU_POWERPC_G2gp,        0xFFFFFFFF, G2),
4965
    /* PowerPC G2 LS                                                         */
4966
    POWERPC_DEF("G2LS",        CPU_POWERPC_G2ls,        0xFFFFFFFF, G2),
4967
    /* PowerPC G2LE                                                          */
4968
    /* Same as G2, with little-endian mode support                           */
4969
    POWERPC_DEF("G2le",        CPU_POWERPC_G2LE,        0xFFFFFFFF, G2LE),
4970
    /* PowerPC G2LE GP                                                       */
4971
    POWERPC_DEF("G2leGP",      CPU_POWERPC_G2LEgp,      0xFFFFFFFF, G2LE),
4972
    /* PowerPC G2LE LS                                                       */
4973
    POWERPC_DEF("G2leLS",      CPU_POWERPC_G2LEls,      0xFFFFFFFF, G2LE),
4974
    /* PowerPC 604                                                           */
4975
    POWERPC_DEF("604",         CPU_POWERPC_604,         0xFFFFFFFF, 604),
4976
    /* PowerPC 604e                                                          */
4977
    POWERPC_DEF("604e",        CPU_POWERPC_604E,        0xFFFFFFFF, 604),
4978
    /* PowerPC 604e v1.0                                                     */
4979
    POWERPC_DEF("604e1.0",     CPU_POWERPC_604E_v10,    0xFFFFFFFF, 604),
4980
    /* PowerPC 604e v2.2                                                     */
4981
    POWERPC_DEF("604e2.2",     CPU_POWERPC_604E_v22,    0xFFFFFFFF, 604),
4982
    /* PowerPC 604e v2.4                                                     */
4983
    POWERPC_DEF("604e2.4",     CPU_POWERPC_604E_v24,    0xFFFFFFFF, 604),
4984
    /* PowerPC 604r                                                          */
4985
    POWERPC_DEF("604r",        CPU_POWERPC_604R,        0xFFFFFFFF, 604),
4986
#if defined(TODO)
4987
    /* PowerPC 604ev                                                         */
4988
    POWERPC_DEF("604ev",       CPU_POWERPC_604EV,       0xFFFFFFFF, 604),
4989
#endif
4990
    /* PowerPC 7xx family                                                    */
4991
    /* Generic PowerPC 740 (G3)                                              */
4992
    POWERPC_DEF("740",         CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
4993
    /* Generic PowerPC 750 (G3)                                              */
4994
    POWERPC_DEF("750",         CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
4995
    /* Code name for generic PowerPC 740/750 (G3)                            */
4996
    POWERPC_DEF("Arthur",      CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
4997
    /* PowerPC 740/750 is also known as G3                                   */
4998
    POWERPC_DEF("G3",          CPU_POWERPC_7x0,         0xFFFFFFFF, 7x0),
4999
    /* PowerPC 740 v2.0 (G3)                                                 */
5000
    POWERPC_DEF("740v2.0",     CPU_POWERPC_7x0_v20,     0xFFFFFFFF, 7x0),
5001
    /* PowerPC 750 v2.0 (G3)                                                 */
5002
    POWERPC_DEF("750v2.0",     CPU_POWERPC_7x0_v20,     0xFFFFFFFF, 7x0),
5003
    /* PowerPC 740 v2.1 (G3)                                                 */
5004
    POWERPC_DEF("740v2.1",     CPU_POWERPC_7x0_v21,     0xFFFFFFFF, 7x0),
5005
    /* PowerPC 750 v2.1 (G3)                                                 */
5006
    POWERPC_DEF("750v2.1",     CPU_POWERPC_7x0_v21,     0xFFFFFFFF, 7x0),
5007
    /* PowerPC 740 v2.2 (G3)                                                 */
5008
    POWERPC_DEF("740v2.2",     CPU_POWERPC_7x0_v22,     0xFFFFFFFF, 7x0),
5009
    /* PowerPC 750 v2.2 (G3)                                                 */
5010
    POWERPC_DEF("750v2.2",     CPU_POWERPC_7x0_v22,     0xFFFFFFFF, 7x0),
5011
    /* PowerPC 740 v3.0 (G3)                                                 */
5012
    POWERPC_DEF("740v3.0",     CPU_POWERPC_7x0_v30,     0xFFFFFFFF, 7x0),
5013
    /* PowerPC 750 v3.0 (G3)                                                 */
5014
    POWERPC_DEF("750v3.0",     CPU_POWERPC_7x0_v30,     0xFFFFFFFF, 7x0),
5015
    /* PowerPC 740 v3.1 (G3)                                                 */
5016
    POWERPC_DEF("740v3.1",     CPU_POWERPC_7x0_v31,     0xFFFFFFFF, 7x0),
5017
    /* PowerPC 750 v3.1 (G3)                                                 */
5018
    POWERPC_DEF("750v3.1",     CPU_POWERPC_7x0_v31,     0xFFFFFFFF, 7x0),
5019
    /* PowerPC 740E (G3)                                                     */
5020
    POWERPC_DEF("740e",        CPU_POWERPC_740E,        0xFFFFFFFF, 7x0),
5021
    /* PowerPC 740P (G3)                                                     */
5022
    POWERPC_DEF("740p",        CPU_POWERPC_7x0P,        0xFFFFFFFF, 7x0),
5023
    /* PowerPC 750P (G3)                                                     */
5024
    POWERPC_DEF("750p",        CPU_POWERPC_7x0P,        0xFFFFFFFF, 7x0),
5025
    /* Code name for PowerPC 740P/750P (G3)                                  */
5026
    POWERPC_DEF("Conan/Doyle", CPU_POWERPC_7x0P,        0xFFFFFFFF, 7x0),
5027
    /* PowerPC 750CL (G3 embedded)                                           */
5028
    POWERPC_DEF("750cl",       CPU_POWERPC_750CL,       0xFFFFFFFF, 7x0),
5029
    /* PowerPC 750CX (G3 embedded)                                           */
5030
    POWERPC_DEF("750cx",       CPU_POWERPC_750CX,       0xFFFFFFFF, 7x0),
5031
    /* PowerPC 750CX v2.1 (G3 embedded)                                      */
5032
    POWERPC_DEF("750cx2.1",    CPU_POWERPC_750CX_v21,   0xFFFFFFFF, 7x0),
5033
    /* PowerPC 750CX v2.2 (G3 embedded)                                      */
5034
    POWERPC_DEF("750cx2.2",    CPU_POWERPC_750CX_v22,   0xFFFFFFFF, 7x0),
5035
    /* PowerPC 750CXe (G3 embedded)                                          */
5036
    POWERPC_DEF("750cxe",      CPU_POWERPC_750CXE,      0xFFFFFFFF, 7x0),
5037
    /* PowerPC 750CXe v2.1 (G3 embedded)                                     */
5038
    POWERPC_DEF("750cxe21",    CPU_POWERPC_750CXE_v21,  0xFFFFFFFF, 7x0),
5039
    /* PowerPC 750CXe v2.2 (G3 embedded)                                     */
5040
    POWERPC_DEF("750cxe22",    CPU_POWERPC_750CXE_v22,  0xFFFFFFFF, 7x0),
5041
    /* PowerPC 750CXe v2.3 (G3 embedded)                                     */
5042
    POWERPC_DEF("750cxe23",    CPU_POWERPC_750CXE_v23,  0xFFFFFFFF, 7x0),
5043
    /* PowerPC 750CXe v2.4 (G3 embedded)                                     */
5044
    POWERPC_DEF("750cxe24",    CPU_POWERPC_750CXE_v24,  0xFFFFFFFF, 7x0),
5045
    /* PowerPC 750CXe v2.4b (G3 embedded)                                    */
5046
    POWERPC_DEF("750cxe24b",   CPU_POWERPC_750CXE_v24b, 0xFFFFFFFF, 7x0),
5047
    /* PowerPC 750CXe v3.1 (G3 embedded)                                     */
5048
    POWERPC_DEF("750cxe31",    CPU_POWERPC_750CXE_v31,  0xFFFFFFFF, 7x0),
5049
    /* PowerPC 750CXe v3.1b (G3 embedded)                                    */
5050
    POWERPC_DEF("750cxe3.1b",  CPU_POWERPC_750CXE_v31b, 0xFFFFFFFF, 7x0),
5051
    /* PowerPC 750CXr (G3 embedded)                                          */
5052
    POWERPC_DEF("750cxr",      CPU_POWERPC_750CXR,      0xFFFFFFFF, 7x0),
5053
    /* PowerPC 750E (G3)                                                     */
5054
    POWERPC_DEF("750e",        CPU_POWERPC_750E,        0xFFFFFFFF, 7x0),
5055
    /* PowerPC 750FL (G3 embedded)                                           */
5056
    POWERPC_DEF("750fl",       CPU_POWERPC_750FL,       0xFFFFFFFF, 750fx),
5057
    /* PowerPC 750FX (G3 embedded)                                           */
5058
    POWERPC_DEF("750fx",       CPU_POWERPC_750FX,       0xFFFFFFFF, 750fx),
5059
    /* PowerPC 750FX v1.0 (G3 embedded)                                      */
5060
    POWERPC_DEF("750fx1.0",    CPU_POWERPC_750FX_v10,   0xFFFFFFFF, 750fx),
5061
    /* PowerPC 750FX v2.0 (G3 embedded)                                      */
5062
    POWERPC_DEF("750fx2.0",    CPU_POWERPC_750FX_v20,   0xFFFFFFFF, 750fx),
5063
    /* PowerPC 750FX v2.1 (G3 embedded)                                      */
5064
    POWERPC_DEF("750fx2.1",    CPU_POWERPC_750FX_v21,   0xFFFFFFFF, 750fx),
5065
    /* PowerPC 750FX v2.2 (G3 embedded)                                      */
5066
    POWERPC_DEF("750fx2.2",    CPU_POWERPC_750FX_v22,   0xFFFFFFFF, 750fx),
5067
    /* PowerPC 750FX v2.3 (G3 embedded)                                      */
5068
    POWERPC_DEF("750fx2.3",    CPU_POWERPC_750FX_v23,   0xFFFFFFFF, 750fx),
5069
    /* PowerPC 750GL (G3 embedded)                                           */
5070
    POWERPC_DEF("750gl",       CPU_POWERPC_750GL,       0xFFFFFFFF, 750fx),
5071
    /* PowerPC 750GX (G3 embedded)                                           */
5072
    POWERPC_DEF("750gx",       CPU_POWERPC_750GX,       0xFFFFFFFF, 750fx),
5073
    /* PowerPC 750GX v1.0 (G3 embedded)                                      */
5074
    POWERPC_DEF("750gx1.0",    CPU_POWERPC_750GX_v10,   0xFFFFFFFF, 750fx),
5075
    /* PowerPC 750GX v1.1 (G3 embedded)                                      */
5076
    POWERPC_DEF("750gx1.1",    CPU_POWERPC_750GX_v11,   0xFFFFFFFF, 750fx),
5077
    /* PowerPC 750GX v1.2 (G3 embedded)                                      */
5078
    POWERPC_DEF("750gx1.2",    CPU_POWERPC_750GX_v12,   0xFFFFFFFF, 750fx),
5079
    /* PowerPC 750L (G3 embedded)                                            */
5080
    POWERPC_DEF("750l",        CPU_POWERPC_750L,        0xFFFFFFFF, 7x0),
5081
    /* Code name for PowerPC 750L (G3 embedded)                              */
5082
    POWERPC_DEF("LoneStar",    CPU_POWERPC_750L,        0xFFFFFFFF, 7x0),
5083
    /* PowerPC 750L v2.2 (G3 embedded)                                       */
5084
    POWERPC_DEF("750l2.2",     CPU_POWERPC_750L_v22,    0xFFFFFFFF, 7x0),
5085
    /* PowerPC 750L v3.0 (G3 embedded)                                       */
5086
    POWERPC_DEF("750l3.0",     CPU_POWERPC_750L_v30,    0xFFFFFFFF, 7x0),
5087
    /* PowerPC 750L v3.2 (G3 embedded)                                       */
5088
    POWERPC_DEF("750l3.2",     CPU_POWERPC_750L_v32,    0xFFFFFFFF, 7x0),
5089
    /* Generic PowerPC 745                                                   */
5090
    POWERPC_DEF("745",         CPU_POWERPC_7x5,         0xFFFFFFFF, 7x5),
5091
    /* Generic PowerPC 755                                                   */
5092
    POWERPC_DEF("755",         CPU_POWERPC_7x5,         0xFFFFFFFF, 7x5),
5093
    /* Code name for PowerPC 745/755                                         */
5094
    POWERPC_DEF("Goldfinger",  CPU_POWERPC_7x5,         0xFFFFFFFF, 7x5),
5095
    /* PowerPC 745 v1.0                                                      */
5096
    POWERPC_DEF("745v1.0",     CPU_POWERPC_7x5_v10,     0xFFFFFFFF, 7x5),
5097
    /* PowerPC 755 v1.0                                                      */
5098
    POWERPC_DEF("755v1.0",     CPU_POWERPC_7x5_v10,     0xFFFFFFFF, 7x5),
5099
    /* PowerPC 745 v1.1                                                      */
5100
    POWERPC_DEF("745v1.1",     CPU_POWERPC_7x5_v11,     0xFFFFFFFF, 7x5),
5101
    /* PowerPC 755 v1.1                                                      */
5102
    POWERPC_DEF("755v1.1",     CPU_POWERPC_7x5_v11,     0xFFFFFFFF, 7x5),
5103
    /* PowerPC 745 v2.0                                                      */
5104
    POWERPC_DEF("745v2.0",     CPU_POWERPC_7x5_v20,     0xFFFFFFFF, 7x5),
5105
    /* PowerPC 755 v2.0                                                      */
5106
    POWERPC_DEF("755v2.0",     CPU_POWERPC_7x5_v20,     0xFFFFFFFF, 7x5),
5107
    /* PowerPC 745 v2.1                                                      */
5108
    POWERPC_DEF("745v2.1",     CPU_POWERPC_7x5_v21,     0xFFFFFFFF, 7x5),
5109
    /* PowerPC 755 v2.1                                                      */
5110
    POWERPC_DEF("755v2.1",     CPU_POWERPC_7x5_v21,     0xFFFFFFFF, 7x5),
5111
    /* PowerPC 745 v2.2                                                      */
5112
    POWERPC_DEF("745v2.2",     CPU_POWERPC_7x5_v22,     0xFFFFFFFF, 7x5),
5113
    /* PowerPC 755 v2.2                                                      */
5114
    POWERPC_DEF("755v2.2",     CPU_POWERPC_7x5_v22,     0xFFFFFFFF, 7x5),
5115
    /* PowerPC 745 v2.3                                                      */
5116
    POWERPC_DEF("745v2.3",     CPU_POWERPC_7x5_v23,     0xFFFFFFFF, 7x5),
5117
    /* PowerPC 755 v2.3                                                      */
5118
    POWERPC_DEF("755v2.3",     CPU_POWERPC_7x5_v23,     0xFFFFFFFF, 7x5),
5119
    /* PowerPC 745 v2.4                                                      */
5120
    POWERPC_DEF("745v2.4",     CPU_POWERPC_7x5_v24,     0xFFFFFFFF, 7x5),
5121
    /* PowerPC 755 v2.4                                                      */
5122
    POWERPC_DEF("755v2.4",     CPU_POWERPC_7x5_v24,     0xFFFFFFFF, 7x5),
5123
    /* PowerPC 745 v2.5                                                      */
5124
    POWERPC_DEF("745v2.5",     CPU_POWERPC_7x5_v25,     0xFFFFFFFF, 7x5),
5125
    /* PowerPC 755 v2.5                                                      */
5126
    POWERPC_DEF("755v2.5",     CPU_POWERPC_7x5_v25,     0xFFFFFFFF, 7x5),
5127
    /* PowerPC 745 v2.6                                                      */
5128
    POWERPC_DEF("745v2.6",     CPU_POWERPC_7x5_v26,     0xFFFFFFFF, 7x5),
5129
    /* PowerPC 755 v2.6                                                      */
5130
    POWERPC_DEF("755v2.6",     CPU_POWERPC_7x5_v26,     0xFFFFFFFF, 7x5),
5131
    /* PowerPC 745 v2.7                                                      */
5132
    POWERPC_DEF("745v2.7",     CPU_POWERPC_7x5_v27,     0xFFFFFFFF, 7x5),
5133
    /* PowerPC 755 v2.7                                                      */
5134
    POWERPC_DEF("755v2.7",     CPU_POWERPC_7x5_v27,     0xFFFFFFFF, 7x5),
5135
    /* PowerPC 745 v2.8                                                      */
5136
    POWERPC_DEF("745v2.8",     CPU_POWERPC_7x5_v28,     0xFFFFFFFF, 7x5),
5137
    /* PowerPC 755 v2.8                                                      */
5138
    POWERPC_DEF("755v2.8",     CPU_POWERPC_7x5_v28,     0xFFFFFFFF, 7x5),
5139
#if defined (TODO)
5140
    /* PowerPC 745P (G3)                                                     */
5141
    POWERPC_DEF("745p",        CPU_POWERPC_7x5P,        0xFFFFFFFF, 7x5),
5142
    /* PowerPC 755P (G3)                                                     */
5143
    POWERPC_DEF("755p",        CPU_POWERPC_7x5P,        0xFFFFFFFF, 7x5),
5144
#endif
5145
    /* PowerPC 74xx family                                                   */
5146
    /* PowerPC 7400 (G4)                                                     */
5147
    POWERPC_DEF("7400",        CPU_POWERPC_7400,        0xFFFFFFFF, 7400),
5148
    /* Code name for PowerPC 7400                                            */
5149
    POWERPC_DEF("Max",         CPU_POWERPC_7400,        0xFFFFFFFF, 7400),
5150
    /* PowerPC 74xx is also well known as G4                                 */
5151
    POWERPC_DEF("G4",          CPU_POWERPC_7400,        0xFFFFFFFF, 7400),
5152
    /* PowerPC 7400 v1.0 (G4)                                                */
5153
    POWERPC_DEF("7400v1.0",    CPU_POWERPC_7400_v10,    0xFFFFFFFF, 7400),
5154
    /* PowerPC 7400 v1.1 (G4)                                                */
5155
    POWERPC_DEF("7400v1.1",    CPU_POWERPC_7400_v11,    0xFFFFFFFF, 7400),
5156
    /* PowerPC 7400 v2.0 (G4)                                                */
5157
    POWERPC_DEF("7400v2.0",    CPU_POWERPC_7400_v20,    0xFFFFFFFF, 7400),
5158
    /* PowerPC 7400 v2.2 (G4)                                                */
5159
    POWERPC_DEF("7400v2.2",    CPU_POWERPC_7400_v22,    0xFFFFFFFF, 7400),
5160
    /* PowerPC 7400 v2.6 (G4)                                                */
5161
    POWERPC_DEF("7400v2.6",    CPU_POWERPC_7400_v26,    0xFFFFFFFF, 7400),
5162
    /* PowerPC 7400 v2.7 (G4)                                                */
5163
    POWERPC_DEF("7400v2.7",    CPU_POWERPC_7400_v27,    0xFFFFFFFF, 7400),
5164
    /* PowerPC 7400 v2.8 (G4)                                                */
5165
    POWERPC_DEF("7400v2.8",    CPU_POWERPC_7400_v28,    0xFFFFFFFF, 7400),
5166
    /* PowerPC 7400 v2.9 (G4)                                                */
5167
    POWERPC_DEF("7400v2.9",    CPU_POWERPC_7400_v29,    0xFFFFFFFF, 7400),
5168
    /* PowerPC 7410 (G4)                                                     */
5169
    POWERPC_DEF("7410",        CPU_POWERPC_7410,        0xFFFFFFFF, 7410),
5170
    /* Code name for PowerPC 7410                                            */
5171
    POWERPC_DEF("Nitro",       CPU_POWERPC_7410,        0xFFFFFFFF, 7410),
5172
    /* PowerPC 7410 v1.0 (G4)                                                */
5173
    POWERPC_DEF("7410v1.0",    CPU_POWERPC_7410_v10,    0xFFFFFFFF, 7410),
5174
    /* PowerPC 7410 v1.1 (G4)                                                */
5175
    POWERPC_DEF("7410v1.1",    CPU_POWERPC_7410_v11,    0xFFFFFFFF, 7410),
5176
    /* PowerPC 7410 v1.2 (G4)                                                */
5177
    POWERPC_DEF("7410v1.2",    CPU_POWERPC_7410_v12,    0xFFFFFFFF, 7410),
5178
    /* PowerPC 7410 v1.3 (G4)                                                */
5179
    POWERPC_DEF("7410v1.3",    CPU_POWERPC_7410_v13,    0xFFFFFFFF, 7410),
5180
    /* PowerPC 7410 v1.4 (G4)                                                */
5181
    POWERPC_DEF("7410v1.4",    CPU_POWERPC_7410_v14,    0xFFFFFFFF, 7410),
5182
    /* PowerPC 7448 (G4)                                                     */
5183
    POWERPC_DEF("7448",        CPU_POWERPC_7448,        0xFFFFFFFF, 7400),
5184
    /* PowerPC 7448 v1.0 (G4)                                                */
5185
    POWERPC_DEF("7448v1.0",    CPU_POWERPC_7448_v10,    0xFFFFFFFF, 7400),
5186
    /* PowerPC 7448 v1.1 (G4)                                                */
5187
    POWERPC_DEF("7448v1.1",    CPU_POWERPC_7448_v11,    0xFFFFFFFF, 7400),
5188
    /* PowerPC 7448 v2.0 (G4)                                                */
5189
    POWERPC_DEF("7448v2.0",    CPU_POWERPC_7448_v20,    0xFFFFFFFF, 7400),
5190
    /* PowerPC 7448 v2.1 (G4)                                                */
5191
    POWERPC_DEF("7448v2.1",    CPU_POWERPC_7448_v21,    0xFFFFFFFF, 7400),
5192
#if defined (TODO)
5193
    /* PowerPC 7450 (G4)                                                     */
5194
    POWERPC_DEF("7450",        CPU_POWERPC_7450,        0xFFFFFFFF, 7450),
5195
    /* Code name for PowerPC 7450                                            */
5196
    POWERPC_DEF("Vger",        CPU_POWERPC_7450,        0xFFFFFFFF, 7450),
5197
#endif
5198
#if defined (TODO)
5199
    /* PowerPC 7450 v1.0 (G4)                                                */
5200
    POWERPC_DEF("7450v1.0",    CPU_POWERPC_7450_v10,    0xFFFFFFFF, 7450),
5201
#endif
5202
#if defined (TODO)
5203
    /* PowerPC 7450 v1.1 (G4)                                                */
5204
    POWERPC_DEF("7450v1.1",    CPU_POWERPC_7450_v11,    0xFFFFFFFF, 7450),
5205
#endif
5206
#if defined (TODO)
5207
    /* PowerPC 7450 v1.2 (G4)                                                */
5208
    POWERPC_DEF("7450v1.2",    CPU_POWERPC_7450_v12,    0xFFFFFFFF, 7450),
5209
#endif
5210
#if defined (TODO)
5211
    /* PowerPC 7450 v2.0 (G4)                                                */
5212
    POWERPC_DEF("7450v2.0",    CPU_POWERPC_7450_v20,    0xFFFFFFFF, 7450),
5213
#endif
5214
#if defined (TODO)
5215
    /* PowerPC 7450 v2.1 (G4)                                                */
5216
    POWERPC_DEF("7450v2.1",    CPU_POWERPC_7450_v21,    0xFFFFFFFF, 7450),
5217
#endif
5218
#if defined (TODO)
5219
    /* PowerPC 7441 (G4)                                                     */
5220
    POWERPC_DEF("7441",        CPU_POWERPC_74x1,        0xFFFFFFFF, 7440),
5221
    /* PowerPC 7451 (G4)                                                     */
5222
    POWERPC_DEF("7451",        CPU_POWERPC_74x1,        0xFFFFFFFF, 7450),
5223
#endif
5224
#if defined (TODO)
5225
    /* PowerPC 7441g (G4)                                                    */
5226
    POWERPC_DEF("7441g",       CPU_POWERPC_74x1G,       0xFFFFFFFF, 7440),
5227
    /* PowerPC 7451g (G4)                                                    */
5228
    POWERPC_DEF("7451g",       CPU_POWERPC_74x1G,       0xFFFFFFFF, 7450),
5229
#endif
5230
#if defined (TODO)
5231
    /* PowerPC 7445 (G4)                                                     */
5232
    POWERPC_DEF("7445",        CPU_POWERPC_74x5,        0xFFFFFFFF, 7445),
5233
    /* PowerPC 7455 (G4)                                                     */
5234
    POWERPC_DEF("7455",        CPU_POWERPC_74x5,        0xFFFFFFFF, 7455),
5235
    /* Code name for PowerPC 7445/7455                                       */
5236
    POWERPC_DEF("Apollo6",     CPU_POWERPC_74x5,        0xFFFFFFFF, 7455),
5237
#endif
5238
#if defined (TODO)
5239
    /* PowerPC 7445 v1.0 (G4)                                                */
5240
    POWERPC_DEF("7445v1.0",    CPU_POWERPC_74x5_v10,    0xFFFFFFFF, 7445),
5241
    /* PowerPC 7455 v1.0 (G4)                                                */
5242
    POWERPC_DEF("7455v1.0",    CPU_POWERPC_74x5_v10,    0xFFFFFFFF, 7455),
5243
#endif
5244
#if defined (TODO)
5245
    /* PowerPC 7445 v2.1 (G4)                                                */
5246
    POWERPC_DEF("7445v2.1",    CPU_POWERPC_74x5_v21,    0xFFFFFFFF, 7445),
5247
    /* PowerPC 7455 v2.1 (G4)                                                */
5248
    POWERPC_DEF("7455v2.1",    CPU_POWERPC_74x5_v21,    0xFFFFFFFF, 7455),
5249
#endif
5250
#if defined (TODO)
5251
    /* PowerPC 7445 v3.2 (G4)                                                */
5252
    POWERPC_DEF("7445v3.2",    CPU_POWERPC_74x5_v32,    0xFFFFFFFF, 7445),
5253
    /* PowerPC 7455 v3.2 (G4)                                                */
5254
    POWERPC_DEF("7455v3.2",    CPU_POWERPC_74x5_v32,    0xFFFFFFFF, 7455),
5255
#endif
5256
#if defined (TODO)
5257
    /* PowerPC 7445 v3.3 (G4)                                                */
5258
    POWERPC_DEF("7445v3.3",    CPU_POWERPC_74x5_v33,    0xFFFFFFFF, 7445),
5259
    /* PowerPC 7455 v3.3 (G4)                                                */
5260
    POWERPC_DEF("7455v3.3",    CPU_POWERPC_74x5_v33,    0xFFFFFFFF, 7455),
5261
#endif
5262
#if defined (TODO)
5263
    /* PowerPC 7445 v3.4 (G4)                                                */
5264
    POWERPC_DEF("7445v3.4",    CPU_POWERPC_74x5_v34,    0xFFFFFFFF, 7445),
5265
    /* PowerPC 7455 v3.4 (G4)                                                */
5266
    POWERPC_DEF("7455v3.4",    CPU_POWERPC_74x5_v34,    0xFFFFFFFF, 7455),
5267
#endif
5268
#if defined (TODO)
5269
    /* PowerPC 7447 (G4)                                                     */
5270
    POWERPC_DEF("7447",        CPU_POWERPC_74x7,        0xFFFFFFFF, 7445),
5271
    /* PowerPC 7457 (G4)                                                     */
5272
    POWERPC_DEF("7457",        CPU_POWERPC_74x7,        0xFFFFFFFF, 7455),
5273
    /* Code name for PowerPC 7447/7457                                       */
5274
    POWERPC_DEF("Apollo7",     CPU_POWERPC_74x7,        0xFFFFFFFF, 7455),
5275
#endif
5276
#if defined (TODO)
5277
    /* PowerPC 7447 v1.0 (G4)                                                */
5278
    POWERPC_DEF("7447v1.0",    CPU_POWERPC_74x7_v10,    0xFFFFFFFF, 7445),
5279
    /* PowerPC 7457 v1.0 (G4)                                                */
5280
    POWERPC_DEF("7457v1.0",    CPU_POWERPC_74x7_v10,    0xFFFFFFFF, 7455),
5281
    /* Code name for PowerPC 7447A/7457A                                     */
5282
    POWERPC_DEF("Apollo7PM",   CPU_POWERPC_74x7_v10,    0xFFFFFFFF, 7455),
5283
#endif
5284
#if defined (TODO)
5285
    /* PowerPC 7447 v1.1 (G4)                                                */
5286
    POWERPC_DEF("7447v1.1",    CPU_POWERPC_74x7_v11,    0xFFFFFFFF, 7445),
5287
    /* PowerPC 7457 v1.1 (G4)                                                */
5288
    POWERPC_DEF("7457v1.1",    CPU_POWERPC_74x7_v11,    0xFFFFFFFF, 7455),
5289
#endif
5290
#if defined (TODO)
5291
    /* PowerPC 7447 v1.2 (G4)                                                */
5292
    POWERPC_DEF("7447v1.2",    CPU_POWERPC_74x7_v12,    0xFFFFFFFF, 7445),
5293
    /* PowerPC 7457 v1.2 (G4)                                                */
5294
    POWERPC_DEF("7457v1.2",    CPU_POWERPC_74x7_v12,    0xFFFFFFFF, 7455),
5295
#endif
5296
    /* 64 bits PowerPC                                                       */
5297
#if defined (TARGET_PPC64)
5298
#if defined (TODO)
5299
    /* PowerPC 620                                                           */
5300
    POWERPC_DEF("620",         CPU_POWERPC_620,         0xFFFFFFFF, 620),
5301
#endif
5302
#if defined (TODO)
5303
    /* PowerPC 630 (POWER3)                                                  */
5304
    POWERPC_DEF("630",         CPU_POWERPC_630,         0xFFFFFFFF, 630),
5305
    POWERPC_DEF("POWER3",      CPU_POWERPC_630,         0xFFFFFFFF, 630),
5306
#endif
5307
#if defined (TODO)
5308
    /* PowerPC 631 (Power 3+)                                                */
5309
    POWERPC_DEF("631",         CPU_POWERPC_631,         0xFFFFFFFF, 631),
5310
    POWERPC_DEF("POWER3+",     CPU_POWERPC_631,         0xFFFFFFFF, 631),
5311
#endif
5312
#if defined (TODO)
5313
    /* POWER4                                                                */
5314
    POWERPC_DEF("POWER4",      CPU_POWERPC_POWER4,      0xFFFFFFFF, POWER4),
5315
#endif
5316
#if defined (TODO)
5317
    /* POWER4p                                                               */
5318
    POWERPC_DEF("POWER4+",     CPU_POWERPC_POWER4P,     0xFFFFFFFF, POWER4P),
5319
#endif
5320
#if defined (TODO)
5321
    /* POWER5                                                                */
5322
    POWERPC_DEF("POWER5",      CPU_POWERPC_POWER5,      0xFFFFFFFF, POWER5),
5323
    /* POWER5GR                                                              */
5324
    POWERPC_DEF("POWER5gr",    CPU_POWERPC_POWER5GR,    0xFFFFFFFF, POWER5),
5325
#endif
5326
#if defined (TODO)
5327
    /* POWER5+                                                               */
5328
    POWERPC_DEF("POWER5+",     CPU_POWERPC_POWER5P,     0xFFFFFFFF, POWER5P),
5329
    /* POWER5GS                                                              */
5330
    POWERPC_DEF("POWER5gs",    CPU_POWERPC_POWER5GS,    0xFFFFFFFF, POWER5P),
5331
#endif
5332
#if defined (TODO)
5333
    /* POWER6                                                                */
5334
    POWERPC_DEF("POWER6",      CPU_POWERPC_POWER6,      0xFFFFFFFF, POWER6),
5335
    /* POWER6 running in POWER5 mode                                         */
5336
    POWERPC_DEF("POWER6_5",    CPU_POWERPC_POWER6_5,    0xFFFFFFFF, POWER5),
5337
    /* POWER6A                                                               */
5338
    POWERPC_DEF("POWER6A",     CPU_POWERPC_POWER6A,     0xFFFFFFFF, POWER6),
5339
#endif
5340
    /* PowerPC 970                                                           */
5341
    POWERPC_DEF("970",         CPU_POWERPC_970,         0xFFFFFFFF, 970),
5342
    /* PowerPC 970FX (G5)                                                    */
5343
    POWERPC_DEF("970fx",       CPU_POWERPC_970FX,       0xFFFFFFFF, 970FX),
5344
    /* PowerPC 970FX v1.0 (G5)                                               */
5345
    POWERPC_DEF("970fx1.0",    CPU_POWERPC_970FX_v10,   0xFFFFFFFF, 970FX),
5346
    /* PowerPC 970FX v2.0 (G5)                                               */
5347
    POWERPC_DEF("970fx2.0",    CPU_POWERPC_970FX_v20,   0xFFFFFFFF, 970FX),
5348
    /* PowerPC 970FX v2.1 (G5)                                               */
5349
    POWERPC_DEF("970fx2.1",    CPU_POWERPC_970FX_v21,   0xFFFFFFFF, 970FX),
5350
    /* PowerPC 970FX v3.0 (G5)                                               */
5351
    POWERPC_DEF("970fx3.0",    CPU_POWERPC_970FX_v30,   0xFFFFFFFF, 970FX),
5352
    /* PowerPC 970FX v3.1 (G5)                                               */
5353
    POWERPC_DEF("970fx3.1",    CPU_POWERPC_970FX_v31,   0xFFFFFFFF, 970FX),
5354
    /* PowerPC 970GX (G5)                                                    */
5355
    POWERPC_DEF("970gx",       CPU_POWERPC_970GX,       0xFFFFFFFF, 970GX),
5356
    /* PowerPC 970MP                                                         */
5357
    POWERPC_DEF("970mp",       CPU_POWERPC_970MP,       0xFFFFFFFF, 970),
5358
    /* PowerPC 970MP v1.0                                                    */
5359
    POWERPC_DEF("970mp1.0",    CPU_POWERPC_970MP_v10,   0xFFFFFFFF, 970),
5360
    /* PowerPC 970MP v1.1                                                    */
5361
    POWERPC_DEF("970mp1.1",    CPU_POWERPC_970MP_v11,   0xFFFFFFFF, 970),
5362
#if defined (TODO)
5363
    /* PowerPC Cell                                                          */
5364
    POWERPC_DEF("Cell",        CPU_POWERPC_CELL,        0xFFFFFFFF, 970),
5365
#endif
5366
#if defined (TODO)
5367
    /* PowerPC Cell v1.0                                                     */
5368
    POWERPC_DEF("Cell1.0",     CPU_POWERPC_CELL_v10,    0xFFFFFFFF, 970),
5369
#endif
5370
#if defined (TODO)
5371
    /* PowerPC Cell v2.0                                                     */
5372
    POWERPC_DEF("Cell2.0",     CPU_POWERPC_CELL_v20,    0xFFFFFFFF, 970),
5373
#endif
5374
#if defined (TODO)
5375
    /* PowerPC Cell v3.0                                                     */
5376
    POWERPC_DEF("Cell3.0",     CPU_POWERPC_CELL_v30,    0xFFFFFFFF, 970),
5377
#endif
5378
#if defined (TODO)
5379
    /* PowerPC Cell v3.1                                                     */
5380
    POWERPC_DEF("Cell3.1",     CPU_POWERPC_CELL_v31,    0xFFFFFFFF, 970),
5381
#endif
5382
#if defined (TODO)
5383
    /* PowerPC Cell v3.2                                                     */
5384
    POWERPC_DEF("Cell3.2",     CPU_POWERPC_CELL_v32,    0xFFFFFFFF, 970),
5385
#endif
5386
#if defined (TODO)
5387
    /* RS64 (Apache/A35)                                                     */
5388
    /* This one seems to support the whole POWER2 instruction set
5389
     * and the PowerPC 64 one.
5390
     */
5391
    /* What about A10 & A30 ? */
5392
    POWERPC_DEF("RS64",        CPU_POWERPC_RS64,        0xFFFFFFFF, RS64),
5393
    POWERPC_DEF("Apache",      CPU_POWERPC_RS64,        0xFFFFFFFF, RS64),
5394
    POWERPC_DEF("A35",         CPU_POWERPC_RS64,        0xFFFFFFFF, RS64),
5395
#endif
5396
#if defined (TODO)
5397
    /* RS64-II (NorthStar/A50)                                               */
5398
    POWERPC_DEF("RS64-II",     CPU_POWERPC_RS64II,      0xFFFFFFFF, RS64),
5399
    POWERPC_DEF("NorthStar",   CPU_POWERPC_RS64II,      0xFFFFFFFF, RS64),
5400
    POWERPC_DEF("A50",         CPU_POWERPC_RS64II,      0xFFFFFFFF, RS64),
5401
#endif
5402
#if defined (TODO)
5403
    /* RS64-III (Pulsar)                                                     */
5404
    POWERPC_DEF("RS64-III",    CPU_POWERPC_RS64III,     0xFFFFFFFF, RS64),
5405
    POWERPC_DEF("Pulsar",      CPU_POWERPC_RS64III,     0xFFFFFFFF, RS64),
5406
#endif
5407
#if defined (TODO)
5408
    /* RS64-IV (IceStar/IStar/SStar)                                         */
5409
    POWERPC_DEF("RS64-IV",     CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5410
    POWERPC_DEF("IceStar",     CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5411
    POWERPC_DEF("IStar",       CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5412
    POWERPC_DEF("SStar",       CPU_POWERPC_RS64IV,      0xFFFFFFFF, RS64),
5413
#endif
5414
#endif /* defined (TARGET_PPC64) */
5415
    /* POWER                                                                 */
5416
#if defined (TODO)
5417
    /* Original POWER                                                        */
5418
    POWERPC_DEF("POWER",       CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5419
    POWERPC_DEF("RIOS",        CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5420
    POWERPC_DEF("RSC",         CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5421
    POWERPC_DEF("RSC3308",     CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5422
    POWERPC_DEF("RSC4608",     CPU_POWERPC_POWER,       0xFFFFFFFF, POWER),
5423
#endif
5424
#if defined (TODO)
5425
    /* POWER2                                                                */
5426
    POWERPC_DEF("POWER2",      CPU_POWERPC_POWER2,      0xFFFFFFFF, POWER),
5427
    POWERPC_DEF("RSC2",        CPU_POWERPC_POWER2,      0xFFFFFFFF, POWER),
5428
    POWERPC_DEF("P2SC",        CPU_POWERPC_POWER2,      0xFFFFFFFF, POWER),
5429
#endif
5430
    /* PA semi cores                                                         */
5431
#if defined (TODO)
5432
    /* PA PA6T */
5433
    POWERPC_DEF("PA6T",        CPU_POWERPC_PA6T,        0xFFFFFFFF, PA6T),
5434
#endif
5435
    /* Generic PowerPCs                                                      */
5436
#if defined (TARGET_PPC64)
5437
#if defined (TODO)
5438
    POWERPC_DEF("ppc64",       CPU_POWERPC_PPC64,       0xFFFFFFFF, PPC64),
5439
#endif
5440
#endif
5441
    POWERPC_DEF("ppc32",       CPU_POWERPC_PPC32,       0xFFFFFFFF, PPC32),
5442
    POWERPC_DEF("ppc",         CPU_POWERPC_DEFAULT,     0xFFFFFFFF, DEFAULT),
5443
    /* Fallback                                                              */
5444
    POWERPC_DEF("default",     CPU_POWERPC_DEFAULT,     0xFFFFFFFF, DEFAULT),
5445
};
5446

    
5447
/*****************************************************************************/
5448
/* Generic CPU instanciation routine                                         */
5449
static void init_ppc_proc (CPUPPCState *env, ppc_def_t *def)
5450
{
5451
#if !defined(CONFIG_USER_ONLY)
5452
    int i;
5453

    
5454
    env->irq_inputs = NULL;
5455
    /* Set all exception vectors to an invalid address */
5456
    for (i = 0; i < POWERPC_EXCP_NB; i++)
5457
        env->excp_vectors[i] = (target_ulong)(-1ULL);
5458
    env->excp_prefix = 0x00000000;
5459
    env->ivor_mask = 0x00000000;
5460
    env->ivpr_mask = 0x00000000;
5461
#endif
5462
    /* Default MMU definitions */
5463
    env->nb_BATs = 0;
5464
    env->nb_tlb = 0;
5465
    env->nb_ways = 0;
5466
    /* Register SPR common to all PowerPC implementations */
5467
    gen_spr_generic(env);
5468
    spr_register(env, SPR_PVR, "PVR",
5469
                 SPR_NOACCESS, SPR_NOACCESS,
5470
                 &spr_read_generic, SPR_NOACCESS,
5471
                 def->pvr);
5472
    /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
5473
    (*def->init_proc)(env);
5474
    /* Allocate TLBs buffer when needed */
5475
    if (env->nb_tlb != 0) {
5476
        int nb_tlb = env->nb_tlb;
5477
        if (env->id_tlbs != 0)
5478
            nb_tlb *= 2;
5479
        env->tlb = qemu_mallocz(nb_tlb * sizeof(ppc_tlb_t));
5480
        /* Pre-compute some useful values */
5481
        env->tlb_per_way = env->nb_tlb / env->nb_ways;
5482
    }
5483
#if !defined(CONFIG_USER_ONLY)
5484
    if (env->irq_inputs == NULL) {
5485
        fprintf(stderr, "WARNING: no internal IRQ controller registered.\n"
5486
                " Attempt Qemu to crash very soon !\n");
5487
    }
5488
#endif
5489
}
5490

    
5491
#if defined(PPC_DUMP_CPU)
5492
static void dump_ppc_sprs (CPUPPCState *env)
5493
{
5494
    ppc_spr_t *spr;
5495
#if !defined(CONFIG_USER_ONLY)
5496
    uint32_t sr, sw;
5497
#endif
5498
    uint32_t ur, uw;
5499
    int i, j, n;
5500

    
5501
    printf("Special purpose registers:\n");
5502
    for (i = 0; i < 32; i++) {
5503
        for (j = 0; j < 32; j++) {
5504
            n = (i << 5) | j;
5505
            spr = &env->spr_cb[n];
5506
            uw = spr->uea_write != NULL && spr->uea_write != SPR_NOACCESS;
5507
            ur = spr->uea_read != NULL && spr->uea_read != SPR_NOACCESS;
5508
#if !defined(CONFIG_USER_ONLY)
5509
            sw = spr->oea_write != NULL && spr->oea_write != SPR_NOACCESS;
5510
            sr = spr->oea_read != NULL && spr->oea_read != SPR_NOACCESS;
5511
            if (sw || sr || uw || ur) {
5512
                printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
5513
                       (i << 5) | j, (i << 5) | j, spr->name,
5514
                       sw ? 'w' : '-', sr ? 'r' : '-',
5515
                       uw ? 'w' : '-', ur ? 'r' : '-');
5516
            }
5517
#else
5518
            if (uw || ur) {
5519
                printf("SPR: %4d (%03x) %-8s u%c%c\n",
5520
                       (i << 5) | j, (i << 5) | j, spr->name,
5521
                       uw ? 'w' : '-', ur ? 'r' : '-');
5522
            }
5523
#endif
5524
        }
5525
    }
5526
    fflush(stdout);
5527
    fflush(stderr);
5528
}
5529
#endif
5530

    
5531
/*****************************************************************************/
5532
#include <stdlib.h>
5533
#include <string.h>
5534

    
5535
int fflush (FILE *stream);
5536

    
5537
/* Opcode types */
5538
enum {
5539
    PPC_DIRECT   = 0, /* Opcode routine        */
5540
    PPC_INDIRECT = 1, /* Indirect opcode table */
5541
};
5542

    
5543
static inline int is_indirect_opcode (void *handler)
5544
{
5545
    return ((unsigned long)handler & 0x03) == PPC_INDIRECT;
5546
}
5547

    
5548
static inline opc_handler_t **ind_table(void *handler)
5549
{
5550
    return (opc_handler_t **)((unsigned long)handler & ~3);
5551
}
5552

    
5553
/* Instruction table creation */
5554
/* Opcodes tables creation */
5555
static void fill_new_table (opc_handler_t **table, int len)
5556
{
5557
    int i;
5558

    
5559
    for (i = 0; i < len; i++)
5560
        table[i] = &invalid_handler;
5561
}
5562

    
5563
static int create_new_table (opc_handler_t **table, unsigned char idx)
5564
{
5565
    opc_handler_t **tmp;
5566

    
5567
    tmp = malloc(0x20 * sizeof(opc_handler_t));
5568
    if (tmp == NULL)
5569
        return -1;
5570
    fill_new_table(tmp, 0x20);
5571
    table[idx] = (opc_handler_t *)((unsigned long)tmp | PPC_INDIRECT);
5572

    
5573
    return 0;
5574
}
5575

    
5576
static int insert_in_table (opc_handler_t **table, unsigned char idx,
5577
                            opc_handler_t *handler)
5578
{
5579
    if (table[idx] != &invalid_handler)
5580
        return -1;
5581
    table[idx] = handler;
5582

    
5583
    return 0;
5584
}
5585

    
5586
static int register_direct_insn (opc_handler_t **ppc_opcodes,
5587
                                 unsigned char idx, opc_handler_t *handler)
5588
{
5589
    if (insert_in_table(ppc_opcodes, idx, handler) < 0) {
5590
        printf("*** ERROR: opcode %02x already assigned in main "
5591
               "opcode table\n", idx);
5592
        return -1;
5593
    }
5594

    
5595
    return 0;
5596
}
5597

    
5598
static int register_ind_in_table (opc_handler_t **table,
5599
                                  unsigned char idx1, unsigned char idx2,
5600
                                  opc_handler_t *handler)
5601
{
5602
    if (table[idx1] == &invalid_handler) {
5603
        if (create_new_table(table, idx1) < 0) {
5604
            printf("*** ERROR: unable to create indirect table "
5605
                   "idx=%02x\n", idx1);
5606
            return -1;
5607
        }
5608
    } else {
5609
        if (!is_indirect_opcode(table[idx1])) {
5610
            printf("*** ERROR: idx %02x already assigned to a direct "
5611
                   "opcode\n", idx1);
5612
            return -1;
5613
        }
5614
    }
5615
    if (handler != NULL &&
5616
        insert_in_table(ind_table(table[idx1]), idx2, handler) < 0) {
5617
        printf("*** ERROR: opcode %02x already assigned in "
5618
               "opcode table %02x\n", idx2, idx1);
5619
        return -1;
5620
    }
5621

    
5622
    return 0;
5623
}
5624

    
5625
static int register_ind_insn (opc_handler_t **ppc_opcodes,
5626
                              unsigned char idx1, unsigned char idx2,
5627
                              opc_handler_t *handler)
5628
{
5629
    int ret;
5630

    
5631
    ret = register_ind_in_table(ppc_opcodes, idx1, idx2, handler);
5632

    
5633
    return ret;
5634
}
5635

    
5636
static int register_dblind_insn (opc_handler_t **ppc_opcodes,
5637
                                 unsigned char idx1, unsigned char idx2,
5638
                                 unsigned char idx3, opc_handler_t *handler)
5639
{
5640
    if (register_ind_in_table(ppc_opcodes, idx1, idx2, NULL) < 0) {
5641
        printf("*** ERROR: unable to join indirect table idx "
5642
               "[%02x-%02x]\n", idx1, idx2);
5643
        return -1;
5644
    }
5645
    if (register_ind_in_table(ind_table(ppc_opcodes[idx1]), idx2, idx3,
5646
                              handler) < 0) {
5647
        printf("*** ERROR: unable to insert opcode "
5648
               "[%02x-%02x-%02x]\n", idx1, idx2, idx3);
5649
        return -1;
5650
    }
5651

    
5652
    return 0;
5653
}
5654

    
5655
static int register_insn (opc_handler_t **ppc_opcodes, opcode_t *insn)
5656
{
5657
    if (insn->opc2 != 0xFF) {
5658
        if (insn->opc3 != 0xFF) {
5659
            if (register_dblind_insn(ppc_opcodes, insn->opc1, insn->opc2,
5660
                                     insn->opc3, &insn->handler) < 0)
5661
                return -1;
5662
        } else {
5663
            if (register_ind_insn(ppc_opcodes, insn->opc1,
5664
                                  insn->opc2, &insn->handler) < 0)
5665
                return -1;
5666
        }
5667
    } else {
5668
        if (register_direct_insn(ppc_opcodes, insn->opc1, &insn->handler) < 0)
5669
            return -1;
5670
    }
5671

    
5672
    return 0;
5673
}
5674

    
5675
static int test_opcode_table (opc_handler_t **table, int len)
5676
{
5677
    int i, count, tmp;
5678

    
5679
    for (i = 0, count = 0; i < len; i++) {
5680
        /* Consistency fixup */
5681
        if (table[i] == NULL)
5682
            table[i] = &invalid_handler;
5683
        if (table[i] != &invalid_handler) {
5684
            if (is_indirect_opcode(table[i])) {
5685
                tmp = test_opcode_table(ind_table(table[i]), 0x20);
5686
                if (tmp == 0) {
5687
                    free(table[i]);
5688
                    table[i] = &invalid_handler;
5689
                } else {
5690
                    count++;
5691
                }
5692
            } else {
5693
                count++;
5694
            }
5695
        }
5696
    }
5697

    
5698
    return count;
5699
}
5700

    
5701
static void fix_opcode_tables (opc_handler_t **ppc_opcodes)
5702
{
5703
    if (test_opcode_table(ppc_opcodes, 0x40) == 0)
5704
        printf("*** WARNING: no opcode defined !\n");
5705
}
5706

    
5707
/*****************************************************************************/
5708
static int create_ppc_opcodes (CPUPPCState *env, ppc_def_t *def)
5709
{
5710
    opcode_t *opc, *start, *end;
5711

    
5712
    fill_new_table(env->opcodes, 0x40);
5713
    if (&opc_start < &opc_end) {
5714
        start = &opc_start;
5715
        end = &opc_end;
5716
    } else {
5717
        start = &opc_end;
5718
        end = &opc_start;
5719
    }
5720
    for (opc = start + 1; opc != end; opc++) {
5721
        if ((opc->handler.type & def->insns_flags) != 0) {
5722
            if (register_insn(env->opcodes, opc) < 0) {
5723
                printf("*** ERROR initializing PowerPC instruction "
5724
                       "0x%02x 0x%02x 0x%02x\n", opc->opc1, opc->opc2,
5725
                       opc->opc3);
5726
                return -1;
5727
            }
5728
        }
5729
    }
5730
    fix_opcode_tables(env->opcodes);
5731
    fflush(stdout);
5732
    fflush(stderr);
5733

    
5734
    return 0;
5735
}
5736

    
5737
#if defined(PPC_DUMP_CPU)
5738
static int dump_ppc_insns (CPUPPCState *env)
5739
{
5740
    opc_handler_t **table, *handler;
5741
    uint8_t opc1, opc2, opc3;
5742

    
5743
    printf("Instructions set:\n");
5744
    /* opc1 is 6 bits long */
5745
    for (opc1 = 0x00; opc1 < 0x40; opc1++) {
5746
        table = env->opcodes;
5747
        handler = table[opc1];
5748
        if (is_indirect_opcode(handler)) {
5749
            /* opc2 is 5 bits long */
5750
            for (opc2 = 0; opc2 < 0x20; opc2++) {
5751
                table = env->opcodes;
5752
                handler = env->opcodes[opc1];
5753
                table = ind_table(handler);
5754
                handler = table[opc2];
5755
                if (is_indirect_opcode(handler)) {
5756
                    table = ind_table(handler);
5757
                    /* opc3 is 5 bits long */
5758
                    for (opc3 = 0; opc3 < 0x20; opc3++) {
5759
                        handler = table[opc3];
5760
                        if (handler->handler != &gen_invalid) {
5761
                            printf("INSN: %02x %02x %02x (%02d %04d) : %s\n",
5762
                                   opc1, opc2, opc3, opc1, (opc3 << 5) | opc2,
5763
                                   handler->oname);
5764
                        }
5765
                    }
5766
                } else {
5767
                    if (handler->handler != &gen_invalid) {
5768
                        printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
5769
                               opc1, opc2, opc1, opc2, handler->oname);
5770
                    }
5771
                }
5772
            }
5773
        } else {
5774
            if (handler->handler != &gen_invalid) {
5775
                printf("INSN: %02x -- -- (%02d ----) : %s\n",
5776
                       opc1, opc1, handler->oname);
5777
            }
5778
        }
5779
    }
5780
}
5781
#endif
5782

    
5783
int cpu_ppc_register (CPUPPCState *env, ppc_def_t *def)
5784
{
5785
    env->msr_mask = def->msr_mask;
5786
    env->mmu_model = def->mmu_model;
5787
    env->excp_model = def->excp_model;
5788
    env->bus_model = def->bus_model;
5789
    env->bfd_mach = def->bfd_mach;
5790
    if (create_ppc_opcodes(env, def) < 0)
5791
        return -1;
5792
    init_ppc_proc(env, def);
5793
#if defined(PPC_DUMP_CPU)
5794
    {
5795
        const unsigned char *mmu_model, *excp_model, *bus_model;
5796
        switch (env->mmu_model) {
5797
        case POWERPC_MMU_32B:
5798
            mmu_model = "PowerPC 32";
5799
            break;
5800
        case POWERPC_MMU_64B:
5801
            mmu_model = "PowerPC 64";
5802
            break;
5803
        case POWERPC_MMU_601:
5804
            mmu_model = "PowerPC 601";
5805
            break;
5806
        case POWERPC_MMU_SOFT_6xx:
5807
            mmu_model = "PowerPC 6xx/7xx with software driven TLBs";
5808
            break;
5809
        case POWERPC_MMU_SOFT_74xx:
5810
            mmu_model = "PowerPC 74xx with software driven TLBs";
5811
            break;
5812
        case POWERPC_MMU_SOFT_4xx:
5813
            mmu_model = "PowerPC 4xx with software driven TLBs";
5814
            break;
5815
        case POWERPC_MMU_SOFT_4xx_Z:
5816
            mmu_model = "PowerPC 4xx with software driven TLBs "
5817
                "and zones protections";
5818
            break;
5819
        case POWERPC_MMU_REAL_4xx:
5820
            mmu_model = "PowerPC 4xx real mode only";
5821
            break;
5822
        case POWERPC_MMU_BOOKE:
5823
            mmu_model = "PowerPC BookE";
5824
            break;
5825
        case POWERPC_MMU_BOOKE_FSL:
5826
            mmu_model = "PowerPC BookE FSL";
5827
            break;
5828
        case POWERPC_MMU_64BRIDGE:
5829
            mmu_model = "PowerPC 64 bridge";
5830
            break;
5831
        default:
5832
            mmu_model = "Unknown or invalid";
5833
            break;
5834
        }
5835
        switch (env->excp_model) {
5836
        case POWERPC_EXCP_STD:
5837
            excp_model = "PowerPC";
5838
            break;
5839
        case POWERPC_EXCP_40x:
5840
            excp_model = "PowerPC 40x";
5841
            break;
5842
        case POWERPC_EXCP_601:
5843
            excp_model = "PowerPC 601";
5844
            break;
5845
        case POWERPC_EXCP_602:
5846
            excp_model = "PowerPC 602";
5847
            break;
5848
        case POWERPC_EXCP_603:
5849
            excp_model = "PowerPC 603";
5850
            break;
5851
        case POWERPC_EXCP_603E:
5852
            excp_model = "PowerPC 603e";
5853
            break;
5854
        case POWERPC_EXCP_604:
5855
            excp_model = "PowerPC 604";
5856
            break;
5857
        case POWERPC_EXCP_7x0:
5858
            excp_model = "PowerPC 740/750";
5859
            break;
5860
        case POWERPC_EXCP_7x5:
5861
            excp_model = "PowerPC 745/755";
5862
            break;
5863
        case POWERPC_EXCP_74xx:
5864
            excp_model = "PowerPC 74xx";
5865
            break;
5866
        case POWERPC_EXCP_970:
5867
            excp_model = "PowerPC 970";
5868
            break;
5869
        case POWERPC_EXCP_BOOKE:
5870
            excp_model = "PowerPC BookE";
5871
            break;
5872
        default:
5873
            excp_model = "Unknown or invalid";
5874
            break;
5875
        }
5876
        switch (env->bus_model) {
5877
        case PPC_FLAGS_INPUT_6xx:
5878
            bus_model = "PowerPC 6xx";
5879
            break;
5880
        case PPC_FLAGS_INPUT_BookE:
5881
            bus_model = "PowerPC BookE";
5882
            break;
5883
        case PPC_FLAGS_INPUT_405:
5884
            bus_model = "PowerPC 405";
5885
            break;
5886
        case PPC_FLAGS_INPUT_970:
5887
            bus_model = "PowerPC 970";
5888
            break;
5889
        case PPC_FLAGS_INPUT_401:
5890
            bus_model = "PowerPC 401/403";
5891
            break;
5892
        default:
5893
            bus_model = "Unknown or invalid";
5894
            break;
5895
        }
5896
        printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64 "\n"
5897
               "    MMU model        : %s\n",
5898
               def->name, def->pvr, def->msr_mask, mmu_model);
5899
        if (env->tlb != NULL) {
5900
            printf("                       %d %s TLB in %d ways\n",
5901
                   env->nb_tlb, env->id_tlbs ? "splitted" : "merged",
5902
                   env->nb_ways);
5903
        }
5904
        printf("    Exceptions model : %s\n"
5905
               "    Bus model        : %s\n",
5906
               excp_model, bus_model);
5907
    }
5908
    dump_ppc_insns(env);
5909
    dump_ppc_sprs(env);
5910
    fflush(stdout);
5911
#endif
5912

    
5913
    return 0;
5914
}
5915

    
5916
int ppc_find_by_name (const unsigned char *name, ppc_def_t **def)
5917
{
5918
    int i, max, ret;
5919

    
5920
    ret = -1;
5921
    *def = NULL;
5922
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
5923
    for (i = 0; i < max; i++) {
5924
        if (strcasecmp(name, ppc_defs[i].name) == 0) {
5925
            *def = &ppc_defs[i];
5926
            ret = 0;
5927
            break;
5928
        }
5929
    }
5930

    
5931
    return ret;
5932
}
5933

    
5934
int ppc_find_by_pvr (uint32_t pvr, ppc_def_t **def)
5935
{
5936
    int i, max, ret;
5937

    
5938
    ret = -1;
5939
    *def = NULL;
5940
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
5941
    for (i = 0; i < max; i++) {
5942
        if ((pvr & ppc_defs[i].pvr_mask) ==
5943
            (ppc_defs[i].pvr & ppc_defs[i].pvr_mask)) {
5944
            *def = &ppc_defs[i];
5945
            ret = 0;
5946
            break;
5947
        }
5948
    }
5949

    
5950
    return ret;
5951
}
5952

    
5953
void ppc_cpu_list (FILE *f, int (*cpu_fprintf)(FILE *f, const char *fmt, ...))
5954
{
5955
    int i, max;
5956

    
5957
    max = sizeof(ppc_defs) / sizeof(ppc_def_t);
5958
    for (i = 0; i < max; i++) {
5959
        (*cpu_fprintf)(f, "PowerPC %-16s PVR %08x\n",
5960
                       ppc_defs[i].name, ppc_defs[i].pvr);
5961
    }
5962
}