2 * PowerPC CPU initialization for qemu.
4 * Copyright (c) 2003-2007 Jocelyn Mayer
5 * Copyright 2011 Freescale Semiconductor, Inc.
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
21 #include "disas/bfd.h"
22 #include "exec/gdbstub.h"
23 #include <sysemu/kvm.h>
25 #include "sysemu/arch_init.h"
26 #include "sysemu/cpus.h"
27 #include "cpu-models.h"
28 #include "mmu-hash32.h"
29 #include "mmu-hash64.h"
30 #include "qemu/error-report.h"
31 #include "qapi/visitor.h"
32 #include "hw/qdev-properties.h"
34 //#define PPC_DUMP_CPU
35 //#define PPC_DEBUG_SPR
36 //#define PPC_DUMP_SPR_ACCESSES
37 /* #define USE_APPLE_GDB */
39 /* For user-mode emulation, we don't emulate any IRQ controller */
40 #if defined(CONFIG_USER_ONLY)
41 #define PPC_IRQ_INIT_FN(name) \
42 static inline void glue(glue(ppc, name),_irq_init) (CPUPPCState *env) \
46 #define PPC_IRQ_INIT_FN(name) \
47 void glue(glue(ppc, name),_irq_init) (CPUPPCState *env);
53 PPC_IRQ_INIT_FN(POWER7
);
54 PPC_IRQ_INIT_FN(e500
);
57 * do nothing but store/retrieve spr value
59 static void spr_load_dump_spr(int sprn
)
61 #ifdef PPC_DUMP_SPR_ACCESSES
62 TCGv_i32 t0
= tcg_const_i32(sprn
);
63 gen_helper_load_dump_spr(cpu_env
, t0
);
64 tcg_temp_free_i32(t0
);
68 static void spr_read_generic (DisasContext
*ctx
, int gprn
, int sprn
)
70 gen_load_spr(cpu_gpr
[gprn
], sprn
);
71 spr_load_dump_spr(sprn
);
74 static void spr_store_dump_spr(int sprn
)
76 #ifdef PPC_DUMP_SPR_ACCESSES
77 TCGv_i32 t0
= tcg_const_i32(sprn
);
78 gen_helper_store_dump_spr(cpu_env
, t0
);
79 tcg_temp_free_i32(t0
);
83 static void spr_write_generic (DisasContext
*ctx
, int sprn
, int gprn
)
85 gen_store_spr(sprn
, cpu_gpr
[gprn
]);
86 spr_store_dump_spr(sprn
);
89 #if !defined(CONFIG_USER_ONLY)
90 static void spr_write_generic32(DisasContext
*ctx
, int sprn
, int gprn
)
93 TCGv t0
= tcg_temp_new();
94 tcg_gen_ext32u_tl(t0
, cpu_gpr
[gprn
]);
95 gen_store_spr(sprn
, t0
);
97 spr_store_dump_spr(sprn
);
99 spr_write_generic(ctx
, sprn
, gprn
);
103 static void spr_write_clear (DisasContext
*ctx
, int sprn
, int gprn
)
105 TCGv t0
= tcg_temp_new();
106 TCGv t1
= tcg_temp_new();
107 gen_load_spr(t0
, sprn
);
108 tcg_gen_neg_tl(t1
, cpu_gpr
[gprn
]);
109 tcg_gen_and_tl(t0
, t0
, t1
);
110 gen_store_spr(sprn
, t0
);
115 static void spr_access_nop(DisasContext
*ctx
, int sprn
, int gprn
)
121 /* SPR common to all PowerPC */
123 static void spr_read_xer (DisasContext
*ctx
, int gprn
, int sprn
)
125 gen_read_xer(cpu_gpr
[gprn
]);
128 static void spr_write_xer (DisasContext
*ctx
, int sprn
, int gprn
)
130 gen_write_xer(cpu_gpr
[gprn
]);
134 static void spr_read_lr (DisasContext
*ctx
, int gprn
, int sprn
)
136 tcg_gen_mov_tl(cpu_gpr
[gprn
], cpu_lr
);
139 static void spr_write_lr (DisasContext
*ctx
, int sprn
, int gprn
)
141 tcg_gen_mov_tl(cpu_lr
, cpu_gpr
[gprn
]);
145 #if defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY)
146 static void spr_read_cfar (DisasContext
*ctx
, int gprn
, int sprn
)
148 tcg_gen_mov_tl(cpu_gpr
[gprn
], cpu_cfar
);
151 static void spr_write_cfar (DisasContext
*ctx
, int sprn
, int gprn
)
153 tcg_gen_mov_tl(cpu_cfar
, cpu_gpr
[gprn
]);
155 #endif /* defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY) */
158 static void spr_read_ctr (DisasContext
*ctx
, int gprn
, int sprn
)
160 tcg_gen_mov_tl(cpu_gpr
[gprn
], cpu_ctr
);
163 static void spr_write_ctr (DisasContext
*ctx
, int sprn
, int gprn
)
165 tcg_gen_mov_tl(cpu_ctr
, cpu_gpr
[gprn
]);
168 /* User read access to SPR */
174 static void spr_read_ureg (DisasContext
*ctx
, int gprn
, int sprn
)
176 gen_load_spr(cpu_gpr
[gprn
], sprn
+ 0x10);
179 #if defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY)
180 static void spr_write_ureg(DisasContext
*ctx
, int sprn
, int gprn
)
182 gen_store_spr(sprn
+ 0x10, cpu_gpr
[gprn
]);
186 /* SPR common to all non-embedded PowerPC */
188 #if !defined(CONFIG_USER_ONLY)
189 static void spr_read_decr (DisasContext
*ctx
, int gprn
, int sprn
)
191 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
194 gen_helper_load_decr(cpu_gpr
[gprn
], cpu_env
);
195 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
197 gen_stop_exception(ctx
);
201 static void spr_write_decr (DisasContext
*ctx
, int sprn
, int gprn
)
203 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
206 gen_helper_store_decr(cpu_env
, cpu_gpr
[gprn
]);
207 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
209 gen_stop_exception(ctx
);
214 /* SPR common to all non-embedded PowerPC, except 601 */
216 static void spr_read_tbl (DisasContext
*ctx
, int gprn
, int sprn
)
218 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
221 gen_helper_load_tbl(cpu_gpr
[gprn
], cpu_env
);
222 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
224 gen_stop_exception(ctx
);
228 static void spr_read_tbu (DisasContext
*ctx
, int gprn
, int sprn
)
230 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
233 gen_helper_load_tbu(cpu_gpr
[gprn
], cpu_env
);
234 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
236 gen_stop_exception(ctx
);
240 __attribute__ (( unused
))
241 static void spr_read_atbl (DisasContext
*ctx
, int gprn
, int sprn
)
243 gen_helper_load_atbl(cpu_gpr
[gprn
], cpu_env
);
246 __attribute__ (( unused
))
247 static void spr_read_atbu (DisasContext
*ctx
, int gprn
, int sprn
)
249 gen_helper_load_atbu(cpu_gpr
[gprn
], cpu_env
);
252 #if !defined(CONFIG_USER_ONLY)
253 static void spr_write_tbl (DisasContext
*ctx
, int sprn
, int gprn
)
255 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
258 gen_helper_store_tbl(cpu_env
, cpu_gpr
[gprn
]);
259 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
261 gen_stop_exception(ctx
);
265 static void spr_write_tbu (DisasContext
*ctx
, int sprn
, int gprn
)
267 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
270 gen_helper_store_tbu(cpu_env
, cpu_gpr
[gprn
]);
271 if (ctx
->tb
->cflags
& CF_USE_ICOUNT
) {
273 gen_stop_exception(ctx
);
277 __attribute__ (( unused
))
278 static void spr_write_atbl (DisasContext
*ctx
, int sprn
, int gprn
)
280 gen_helper_store_atbl(cpu_env
, cpu_gpr
[gprn
]);
283 __attribute__ (( unused
))
284 static void spr_write_atbu (DisasContext
*ctx
, int sprn
, int gprn
)
286 gen_helper_store_atbu(cpu_env
, cpu_gpr
[gprn
]);
289 #if defined(TARGET_PPC64)
290 __attribute__ (( unused
))
291 static void spr_read_purr (DisasContext
*ctx
, int gprn
, int sprn
)
293 gen_helper_load_purr(cpu_gpr
[gprn
], cpu_env
);
298 #if !defined(CONFIG_USER_ONLY)
299 /* IBAT0U...IBAT0U */
300 /* IBAT0L...IBAT7L */
301 static void spr_read_ibat (DisasContext
*ctx
, int gprn
, int sprn
)
303 tcg_gen_ld_tl(cpu_gpr
[gprn
], cpu_env
, offsetof(CPUPPCState
, IBAT
[sprn
& 1][(sprn
- SPR_IBAT0U
) / 2]));
306 static void spr_read_ibat_h (DisasContext
*ctx
, int gprn
, int sprn
)
308 tcg_gen_ld_tl(cpu_gpr
[gprn
], cpu_env
, offsetof(CPUPPCState
, IBAT
[sprn
& 1][((sprn
- SPR_IBAT4U
) / 2) + 4]));
311 static void spr_write_ibatu (DisasContext
*ctx
, int sprn
, int gprn
)
313 TCGv_i32 t0
= tcg_const_i32((sprn
- SPR_IBAT0U
) / 2);
314 gen_helper_store_ibatu(cpu_env
, t0
, cpu_gpr
[gprn
]);
315 tcg_temp_free_i32(t0
);
318 static void spr_write_ibatu_h (DisasContext
*ctx
, int sprn
, int gprn
)
320 TCGv_i32 t0
= tcg_const_i32(((sprn
- SPR_IBAT4U
) / 2) + 4);
321 gen_helper_store_ibatu(cpu_env
, t0
, cpu_gpr
[gprn
]);
322 tcg_temp_free_i32(t0
);
325 static void spr_write_ibatl (DisasContext
*ctx
, int sprn
, int gprn
)
327 TCGv_i32 t0
= tcg_const_i32((sprn
- SPR_IBAT0L
) / 2);
328 gen_helper_store_ibatl(cpu_env
, t0
, cpu_gpr
[gprn
]);
329 tcg_temp_free_i32(t0
);
332 static void spr_write_ibatl_h (DisasContext
*ctx
, int sprn
, int gprn
)
334 TCGv_i32 t0
= tcg_const_i32(((sprn
- SPR_IBAT4L
) / 2) + 4);
335 gen_helper_store_ibatl(cpu_env
, t0
, cpu_gpr
[gprn
]);
336 tcg_temp_free_i32(t0
);
339 /* DBAT0U...DBAT7U */
340 /* DBAT0L...DBAT7L */
341 static void spr_read_dbat (DisasContext
*ctx
, int gprn
, int sprn
)
343 tcg_gen_ld_tl(cpu_gpr
[gprn
], cpu_env
, offsetof(CPUPPCState
, DBAT
[sprn
& 1][(sprn
- SPR_DBAT0U
) / 2]));
346 static void spr_read_dbat_h (DisasContext
*ctx
, int gprn
, int sprn
)
348 tcg_gen_ld_tl(cpu_gpr
[gprn
], cpu_env
, offsetof(CPUPPCState
, DBAT
[sprn
& 1][((sprn
- SPR_DBAT4U
) / 2) + 4]));
351 static void spr_write_dbatu (DisasContext
*ctx
, int sprn
, int gprn
)
353 TCGv_i32 t0
= tcg_const_i32((sprn
- SPR_DBAT0U
) / 2);
354 gen_helper_store_dbatu(cpu_env
, t0
, cpu_gpr
[gprn
]);
355 tcg_temp_free_i32(t0
);
358 static void spr_write_dbatu_h (DisasContext
*ctx
, int sprn
, int gprn
)
360 TCGv_i32 t0
= tcg_const_i32(((sprn
- SPR_DBAT4U
) / 2) + 4);
361 gen_helper_store_dbatu(cpu_env
, t0
, cpu_gpr
[gprn
]);
362 tcg_temp_free_i32(t0
);
365 static void spr_write_dbatl (DisasContext
*ctx
, int sprn
, int gprn
)
367 TCGv_i32 t0
= tcg_const_i32((sprn
- SPR_DBAT0L
) / 2);
368 gen_helper_store_dbatl(cpu_env
, t0
, cpu_gpr
[gprn
]);
369 tcg_temp_free_i32(t0
);
372 static void spr_write_dbatl_h (DisasContext
*ctx
, int sprn
, int gprn
)
374 TCGv_i32 t0
= tcg_const_i32(((sprn
- SPR_DBAT4L
) / 2) + 4);
375 gen_helper_store_dbatl(cpu_env
, t0
, cpu_gpr
[gprn
]);
376 tcg_temp_free_i32(t0
);
380 static void spr_write_sdr1 (DisasContext
*ctx
, int sprn
, int gprn
)
382 gen_helper_store_sdr1(cpu_env
, cpu_gpr
[gprn
]);
385 /* 64 bits PowerPC specific SPRs */
386 #if defined(TARGET_PPC64)
387 static void spr_read_hior (DisasContext
*ctx
, int gprn
, int sprn
)
389 tcg_gen_ld_tl(cpu_gpr
[gprn
], cpu_env
, offsetof(CPUPPCState
, excp_prefix
));
392 static void spr_write_hior (DisasContext
*ctx
, int sprn
, int gprn
)
394 TCGv t0
= tcg_temp_new();
395 tcg_gen_andi_tl(t0
, cpu_gpr
[gprn
], 0x3FFFFF00000ULL
);
396 tcg_gen_st_tl(t0
, cpu_env
, offsetof(CPUPPCState
, excp_prefix
));
402 /* PowerPC 601 specific registers */
404 static void spr_read_601_rtcl (DisasContext
*ctx
, int gprn
, int sprn
)
406 gen_helper_load_601_rtcl(cpu_gpr
[gprn
], cpu_env
);
409 static void spr_read_601_rtcu (DisasContext
*ctx
, int gprn
, int sprn
)
411 gen_helper_load_601_rtcu(cpu_gpr
[gprn
], cpu_env
);
414 #if !defined(CONFIG_USER_ONLY)
415 static void spr_write_601_rtcu (DisasContext
*ctx
, int sprn
, int gprn
)
417 gen_helper_store_601_rtcu(cpu_env
, cpu_gpr
[gprn
]);
420 static void spr_write_601_rtcl (DisasContext
*ctx
, int sprn
, int gprn
)
422 gen_helper_store_601_rtcl(cpu_env
, cpu_gpr
[gprn
]);
425 static void spr_write_hid0_601 (DisasContext
*ctx
, int sprn
, int gprn
)
427 gen_helper_store_hid0_601(cpu_env
, cpu_gpr
[gprn
]);
428 /* Must stop the translation as endianness may have changed */
429 gen_stop_exception(ctx
);
434 #if !defined(CONFIG_USER_ONLY)
435 static void spr_read_601_ubat (DisasContext
*ctx
, int gprn
, int sprn
)
437 tcg_gen_ld_tl(cpu_gpr
[gprn
], cpu_env
, offsetof(CPUPPCState
, IBAT
[sprn
& 1][(sprn
- SPR_IBAT0U
) / 2]));
440 static void spr_write_601_ubatu (DisasContext
*ctx
, int sprn
, int gprn
)
442 TCGv_i32 t0
= tcg_const_i32((sprn
- SPR_IBAT0U
) / 2);
443 gen_helper_store_601_batl(cpu_env
, t0
, cpu_gpr
[gprn
]);
444 tcg_temp_free_i32(t0
);
447 static void spr_write_601_ubatl (DisasContext
*ctx
, int sprn
, int gprn
)
449 TCGv_i32 t0
= tcg_const_i32((sprn
- SPR_IBAT0U
) / 2);
450 gen_helper_store_601_batu(cpu_env
, t0
, cpu_gpr
[gprn
]);
451 tcg_temp_free_i32(t0
);
455 /* PowerPC 40x specific registers */
456 #if !defined(CONFIG_USER_ONLY)
457 static void spr_read_40x_pit (DisasContext
*ctx
, int gprn
, int sprn
)
459 gen_helper_load_40x_pit(cpu_gpr
[gprn
], cpu_env
);
462 static void spr_write_40x_pit (DisasContext
*ctx
, int sprn
, int gprn
)
464 gen_helper_store_40x_pit(cpu_env
, cpu_gpr
[gprn
]);
467 static void spr_write_40x_dbcr0 (DisasContext
*ctx
, int sprn
, int gprn
)
469 gen_helper_store_40x_dbcr0(cpu_env
, cpu_gpr
[gprn
]);
470 /* We must stop translation as we may have rebooted */
471 gen_stop_exception(ctx
);
474 static void spr_write_40x_sler (DisasContext
*ctx
, int sprn
, int gprn
)
476 gen_helper_store_40x_sler(cpu_env
, cpu_gpr
[gprn
]);
479 static void spr_write_booke_tcr (DisasContext
*ctx
, int sprn
, int gprn
)
481 gen_helper_store_booke_tcr(cpu_env
, cpu_gpr
[gprn
]);
484 static void spr_write_booke_tsr (DisasContext
*ctx
, int sprn
, int gprn
)
486 gen_helper_store_booke_tsr(cpu_env
, cpu_gpr
[gprn
]);
490 /* PowerPC 403 specific registers */
491 /* PBL1 / PBU1 / PBL2 / PBU2 */
492 #if !defined(CONFIG_USER_ONLY)
493 static void spr_read_403_pbr (DisasContext
*ctx
, int gprn
, int sprn
)
495 tcg_gen_ld_tl(cpu_gpr
[gprn
], cpu_env
, offsetof(CPUPPCState
, pb
[sprn
- SPR_403_PBL1
]));
498 static void spr_write_403_pbr (DisasContext
*ctx
, int sprn
, int gprn
)
500 TCGv_i32 t0
= tcg_const_i32(sprn
- SPR_403_PBL1
);
501 gen_helper_store_403_pbr(cpu_env
, t0
, cpu_gpr
[gprn
]);
502 tcg_temp_free_i32(t0
);
505 static void spr_write_pir (DisasContext
*ctx
, int sprn
, int gprn
)
507 TCGv t0
= tcg_temp_new();
508 tcg_gen_andi_tl(t0
, cpu_gpr
[gprn
], 0xF);
509 gen_store_spr(SPR_PIR
, t0
);
514 /* SPE specific registers */
515 static void spr_read_spefscr (DisasContext
*ctx
, int gprn
, int sprn
)
517 TCGv_i32 t0
= tcg_temp_new_i32();
518 tcg_gen_ld_i32(t0
, cpu_env
, offsetof(CPUPPCState
, spe_fscr
));
519 tcg_gen_extu_i32_tl(cpu_gpr
[gprn
], t0
);
520 tcg_temp_free_i32(t0
);
523 static void spr_write_spefscr (DisasContext
*ctx
, int sprn
, int gprn
)
525 TCGv_i32 t0
= tcg_temp_new_i32();
526 tcg_gen_trunc_tl_i32(t0
, cpu_gpr
[gprn
]);
527 tcg_gen_st_i32(t0
, cpu_env
, offsetof(CPUPPCState
, spe_fscr
));
528 tcg_temp_free_i32(t0
);
531 #if !defined(CONFIG_USER_ONLY)
532 /* Callback used to write the exception vector base */
533 static void spr_write_excp_prefix (DisasContext
*ctx
, int sprn
, int gprn
)
535 TCGv t0
= tcg_temp_new();
536 tcg_gen_ld_tl(t0
, cpu_env
, offsetof(CPUPPCState
, ivpr_mask
));
537 tcg_gen_and_tl(t0
, t0
, cpu_gpr
[gprn
]);
538 tcg_gen_st_tl(t0
, cpu_env
, offsetof(CPUPPCState
, excp_prefix
));
539 gen_store_spr(sprn
, t0
);
543 static void spr_write_excp_vector (DisasContext
*ctx
, int sprn
, int gprn
)
547 if (sprn
>= SPR_BOOKE_IVOR0
&& sprn
<= SPR_BOOKE_IVOR15
) {
548 sprn_offs
= sprn
- SPR_BOOKE_IVOR0
;
549 } else if (sprn
>= SPR_BOOKE_IVOR32
&& sprn
<= SPR_BOOKE_IVOR37
) {
550 sprn_offs
= sprn
- SPR_BOOKE_IVOR32
+ 32;
551 } else if (sprn
>= SPR_BOOKE_IVOR38
&& sprn
<= SPR_BOOKE_IVOR42
) {
552 sprn_offs
= sprn
- SPR_BOOKE_IVOR38
+ 38;
554 printf("Trying to write an unknown exception vector %d %03x\n",
556 gen_inval_exception(ctx
, POWERPC_EXCP_PRIV_REG
);
560 TCGv t0
= tcg_temp_new();
561 tcg_gen_ld_tl(t0
, cpu_env
, offsetof(CPUPPCState
, ivor_mask
));
562 tcg_gen_and_tl(t0
, t0
, cpu_gpr
[gprn
]);
563 tcg_gen_st_tl(t0
, cpu_env
, offsetof(CPUPPCState
, excp_vectors
[sprn_offs
]));
564 gen_store_spr(sprn
, t0
);
569 static inline void vscr_init (CPUPPCState
*env
, uint32_t val
)
572 /* Altivec always uses round-to-nearest */
573 set_float_rounding_mode(float_round_nearest_even
, &env
->vec_status
);
574 set_flush_to_zero(vscr_nj
, &env
->vec_status
);
577 #ifdef CONFIG_USER_ONLY
578 #define spr_register_kvm(env, num, name, uea_read, uea_write, \
579 oea_read, oea_write, one_reg_id, initial_value) \
580 _spr_register(env, num, name, uea_read, uea_write, initial_value)
582 #if !defined(CONFIG_KVM)
583 #define spr_register_kvm(env, num, name, uea_read, uea_write, \
584 oea_read, oea_write, one_reg_id, initial_value) \
585 _spr_register(env, num, name, uea_read, uea_write, \
586 oea_read, oea_write, initial_value)
588 #define spr_register_kvm(env, num, name, uea_read, uea_write, \
589 oea_read, oea_write, one_reg_id, initial_value) \
590 _spr_register(env, num, name, uea_read, uea_write, \
591 oea_read, oea_write, one_reg_id, initial_value)
595 #define spr_register(env, num, name, uea_read, uea_write, \
596 oea_read, oea_write, initial_value) \
597 spr_register_kvm(env, num, name, uea_read, uea_write, \
598 oea_read, oea_write, 0, initial_value)
600 static inline void _spr_register(CPUPPCState
*env
, int num
,
602 void (*uea_read
)(DisasContext
*ctx
, int gprn
, int sprn
),
603 void (*uea_write
)(DisasContext
*ctx
, int sprn
, int gprn
),
604 #if !defined(CONFIG_USER_ONLY)
606 void (*oea_read
)(DisasContext
*ctx
, int gprn
, int sprn
),
607 void (*oea_write
)(DisasContext
*ctx
, int sprn
, int gprn
),
609 #if defined(CONFIG_KVM)
612 target_ulong initial_value
)
616 spr
= &env
->spr_cb
[num
];
617 if (spr
->name
!= NULL
||env
-> spr
[num
] != 0x00000000 ||
618 #if !defined(CONFIG_USER_ONLY)
619 spr
->oea_read
!= NULL
|| spr
->oea_write
!= NULL
||
621 spr
->uea_read
!= NULL
|| spr
->uea_write
!= NULL
) {
622 printf("Error: Trying to register SPR %d (%03x) twice !\n", num
, num
);
625 #if defined(PPC_DEBUG_SPR)
626 printf("*** register spr %d (%03x) %s val " TARGET_FMT_lx
"\n", num
, num
,
627 name
, initial_value
);
630 spr
->uea_read
= uea_read
;
631 spr
->uea_write
= uea_write
;
632 #if !defined(CONFIG_USER_ONLY)
633 spr
->oea_read
= oea_read
;
634 spr
->oea_write
= oea_write
;
636 #if defined(CONFIG_KVM)
637 spr
->one_reg_id
= one_reg_id
,
639 env
->spr
[num
] = spr
->default_value
= initial_value
;
642 /* Generic PowerPC SPRs */
643 static void gen_spr_generic (CPUPPCState
*env
)
645 /* Integer processing */
646 spr_register(env
, SPR_XER
, "XER",
647 &spr_read_xer
, &spr_write_xer
,
648 &spr_read_xer
, &spr_write_xer
,
651 spr_register(env
, SPR_LR
, "LR",
652 &spr_read_lr
, &spr_write_lr
,
653 &spr_read_lr
, &spr_write_lr
,
655 spr_register(env
, SPR_CTR
, "CTR",
656 &spr_read_ctr
, &spr_write_ctr
,
657 &spr_read_ctr
, &spr_write_ctr
,
659 /* Interrupt processing */
660 spr_register(env
, SPR_SRR0
, "SRR0",
661 SPR_NOACCESS
, SPR_NOACCESS
,
662 &spr_read_generic
, &spr_write_generic
,
664 spr_register(env
, SPR_SRR1
, "SRR1",
665 SPR_NOACCESS
, SPR_NOACCESS
,
666 &spr_read_generic
, &spr_write_generic
,
668 /* Processor control */
669 spr_register(env
, SPR_SPRG0
, "SPRG0",
670 SPR_NOACCESS
, SPR_NOACCESS
,
671 &spr_read_generic
, &spr_write_generic
,
673 spr_register(env
, SPR_SPRG1
, "SPRG1",
674 SPR_NOACCESS
, SPR_NOACCESS
,
675 &spr_read_generic
, &spr_write_generic
,
677 spr_register(env
, SPR_SPRG2
, "SPRG2",
678 SPR_NOACCESS
, SPR_NOACCESS
,
679 &spr_read_generic
, &spr_write_generic
,
681 spr_register(env
, SPR_SPRG3
, "SPRG3",
682 SPR_NOACCESS
, SPR_NOACCESS
,
683 &spr_read_generic
, &spr_write_generic
,
687 /* SPR common to all non-embedded PowerPC, including 601 */
688 static void gen_spr_ne_601 (CPUPPCState
*env
)
690 /* Exception processing */
691 spr_register_kvm(env
, SPR_DSISR
, "DSISR",
692 SPR_NOACCESS
, SPR_NOACCESS
,
693 &spr_read_generic
, &spr_write_generic
,
694 KVM_REG_PPC_DSISR
, 0x00000000);
695 spr_register_kvm(env
, SPR_DAR
, "DAR",
696 SPR_NOACCESS
, SPR_NOACCESS
,
697 &spr_read_generic
, &spr_write_generic
,
698 KVM_REG_PPC_DAR
, 0x00000000);
700 spr_register(env
, SPR_DECR
, "DECR",
701 SPR_NOACCESS
, SPR_NOACCESS
,
702 &spr_read_decr
, &spr_write_decr
,
704 /* Memory management */
705 spr_register(env
, SPR_SDR1
, "SDR1",
706 SPR_NOACCESS
, SPR_NOACCESS
,
707 &spr_read_generic
, &spr_write_sdr1
,
712 static void gen_low_BATs (CPUPPCState
*env
)
714 #if !defined(CONFIG_USER_ONLY)
715 spr_register(env
, SPR_IBAT0U
, "IBAT0U",
716 SPR_NOACCESS
, SPR_NOACCESS
,
717 &spr_read_ibat
, &spr_write_ibatu
,
719 spr_register(env
, SPR_IBAT0L
, "IBAT0L",
720 SPR_NOACCESS
, SPR_NOACCESS
,
721 &spr_read_ibat
, &spr_write_ibatl
,
723 spr_register(env
, SPR_IBAT1U
, "IBAT1U",
724 SPR_NOACCESS
, SPR_NOACCESS
,
725 &spr_read_ibat
, &spr_write_ibatu
,
727 spr_register(env
, SPR_IBAT1L
, "IBAT1L",
728 SPR_NOACCESS
, SPR_NOACCESS
,
729 &spr_read_ibat
, &spr_write_ibatl
,
731 spr_register(env
, SPR_IBAT2U
, "IBAT2U",
732 SPR_NOACCESS
, SPR_NOACCESS
,
733 &spr_read_ibat
, &spr_write_ibatu
,
735 spr_register(env
, SPR_IBAT2L
, "IBAT2L",
736 SPR_NOACCESS
, SPR_NOACCESS
,
737 &spr_read_ibat
, &spr_write_ibatl
,
739 spr_register(env
, SPR_IBAT3U
, "IBAT3U",
740 SPR_NOACCESS
, SPR_NOACCESS
,
741 &spr_read_ibat
, &spr_write_ibatu
,
743 spr_register(env
, SPR_IBAT3L
, "IBAT3L",
744 SPR_NOACCESS
, SPR_NOACCESS
,
745 &spr_read_ibat
, &spr_write_ibatl
,
747 spr_register(env
, SPR_DBAT0U
, "DBAT0U",
748 SPR_NOACCESS
, SPR_NOACCESS
,
749 &spr_read_dbat
, &spr_write_dbatu
,
751 spr_register(env
, SPR_DBAT0L
, "DBAT0L",
752 SPR_NOACCESS
, SPR_NOACCESS
,
753 &spr_read_dbat
, &spr_write_dbatl
,
755 spr_register(env
, SPR_DBAT1U
, "DBAT1U",
756 SPR_NOACCESS
, SPR_NOACCESS
,
757 &spr_read_dbat
, &spr_write_dbatu
,
759 spr_register(env
, SPR_DBAT1L
, "DBAT1L",
760 SPR_NOACCESS
, SPR_NOACCESS
,
761 &spr_read_dbat
, &spr_write_dbatl
,
763 spr_register(env
, SPR_DBAT2U
, "DBAT2U",
764 SPR_NOACCESS
, SPR_NOACCESS
,
765 &spr_read_dbat
, &spr_write_dbatu
,
767 spr_register(env
, SPR_DBAT2L
, "DBAT2L",
768 SPR_NOACCESS
, SPR_NOACCESS
,
769 &spr_read_dbat
, &spr_write_dbatl
,
771 spr_register(env
, SPR_DBAT3U
, "DBAT3U",
772 SPR_NOACCESS
, SPR_NOACCESS
,
773 &spr_read_dbat
, &spr_write_dbatu
,
775 spr_register(env
, SPR_DBAT3L
, "DBAT3L",
776 SPR_NOACCESS
, SPR_NOACCESS
,
777 &spr_read_dbat
, &spr_write_dbatl
,
784 static void gen_high_BATs (CPUPPCState
*env
)
786 #if !defined(CONFIG_USER_ONLY)
787 spr_register(env
, SPR_IBAT4U
, "IBAT4U",
788 SPR_NOACCESS
, SPR_NOACCESS
,
789 &spr_read_ibat_h
, &spr_write_ibatu_h
,
791 spr_register(env
, SPR_IBAT4L
, "IBAT4L",
792 SPR_NOACCESS
, SPR_NOACCESS
,
793 &spr_read_ibat_h
, &spr_write_ibatl_h
,
795 spr_register(env
, SPR_IBAT5U
, "IBAT5U",
796 SPR_NOACCESS
, SPR_NOACCESS
,
797 &spr_read_ibat_h
, &spr_write_ibatu_h
,
799 spr_register(env
, SPR_IBAT5L
, "IBAT5L",
800 SPR_NOACCESS
, SPR_NOACCESS
,
801 &spr_read_ibat_h
, &spr_write_ibatl_h
,
803 spr_register(env
, SPR_IBAT6U
, "IBAT6U",
804 SPR_NOACCESS
, SPR_NOACCESS
,
805 &spr_read_ibat_h
, &spr_write_ibatu_h
,
807 spr_register(env
, SPR_IBAT6L
, "IBAT6L",
808 SPR_NOACCESS
, SPR_NOACCESS
,
809 &spr_read_ibat_h
, &spr_write_ibatl_h
,
811 spr_register(env
, SPR_IBAT7U
, "IBAT7U",
812 SPR_NOACCESS
, SPR_NOACCESS
,
813 &spr_read_ibat_h
, &spr_write_ibatu_h
,
815 spr_register(env
, SPR_IBAT7L
, "IBAT7L",
816 SPR_NOACCESS
, SPR_NOACCESS
,
817 &spr_read_ibat_h
, &spr_write_ibatl_h
,
819 spr_register(env
, SPR_DBAT4U
, "DBAT4U",
820 SPR_NOACCESS
, SPR_NOACCESS
,
821 &spr_read_dbat_h
, &spr_write_dbatu_h
,
823 spr_register(env
, SPR_DBAT4L
, "DBAT4L",
824 SPR_NOACCESS
, SPR_NOACCESS
,
825 &spr_read_dbat_h
, &spr_write_dbatl_h
,
827 spr_register(env
, SPR_DBAT5U
, "DBAT5U",
828 SPR_NOACCESS
, SPR_NOACCESS
,
829 &spr_read_dbat_h
, &spr_write_dbatu_h
,
831 spr_register(env
, SPR_DBAT5L
, "DBAT5L",
832 SPR_NOACCESS
, SPR_NOACCESS
,
833 &spr_read_dbat_h
, &spr_write_dbatl_h
,
835 spr_register(env
, SPR_DBAT6U
, "DBAT6U",
836 SPR_NOACCESS
, SPR_NOACCESS
,
837 &spr_read_dbat_h
, &spr_write_dbatu_h
,
839 spr_register(env
, SPR_DBAT6L
, "DBAT6L",
840 SPR_NOACCESS
, SPR_NOACCESS
,
841 &spr_read_dbat_h
, &spr_write_dbatl_h
,
843 spr_register(env
, SPR_DBAT7U
, "DBAT7U",
844 SPR_NOACCESS
, SPR_NOACCESS
,
845 &spr_read_dbat_h
, &spr_write_dbatu_h
,
847 spr_register(env
, SPR_DBAT7L
, "DBAT7L",
848 SPR_NOACCESS
, SPR_NOACCESS
,
849 &spr_read_dbat_h
, &spr_write_dbatl_h
,
855 /* Generic PowerPC time base */
856 static void gen_tbl (CPUPPCState
*env
)
858 spr_register(env
, SPR_VTBL
, "TBL",
859 &spr_read_tbl
, SPR_NOACCESS
,
860 &spr_read_tbl
, SPR_NOACCESS
,
862 spr_register(env
, SPR_TBL
, "TBL",
863 &spr_read_tbl
, SPR_NOACCESS
,
864 &spr_read_tbl
, &spr_write_tbl
,
866 spr_register(env
, SPR_VTBU
, "TBU",
867 &spr_read_tbu
, SPR_NOACCESS
,
868 &spr_read_tbu
, SPR_NOACCESS
,
870 spr_register(env
, SPR_TBU
, "TBU",
871 &spr_read_tbu
, SPR_NOACCESS
,
872 &spr_read_tbu
, &spr_write_tbu
,
876 /* Softare table search registers */
877 static void gen_6xx_7xx_soft_tlb (CPUPPCState
*env
, int nb_tlbs
, int nb_ways
)
879 #if !defined(CONFIG_USER_ONLY)
880 env
->nb_tlb
= nb_tlbs
;
881 env
->nb_ways
= nb_ways
;
883 env
->tlb_type
= TLB_6XX
;
884 spr_register(env
, SPR_DMISS
, "DMISS",
885 SPR_NOACCESS
, SPR_NOACCESS
,
886 &spr_read_generic
, SPR_NOACCESS
,
888 spr_register(env
, SPR_DCMP
, "DCMP",
889 SPR_NOACCESS
, SPR_NOACCESS
,
890 &spr_read_generic
, SPR_NOACCESS
,
892 spr_register(env
, SPR_HASH1
, "HASH1",
893 SPR_NOACCESS
, SPR_NOACCESS
,
894 &spr_read_generic
, SPR_NOACCESS
,
896 spr_register(env
, SPR_HASH2
, "HASH2",
897 SPR_NOACCESS
, SPR_NOACCESS
,
898 &spr_read_generic
, SPR_NOACCESS
,
900 spr_register(env
, SPR_IMISS
, "IMISS",
901 SPR_NOACCESS
, SPR_NOACCESS
,
902 &spr_read_generic
, SPR_NOACCESS
,
904 spr_register(env
, SPR_ICMP
, "ICMP",
905 SPR_NOACCESS
, SPR_NOACCESS
,
906 &spr_read_generic
, SPR_NOACCESS
,
908 spr_register(env
, SPR_RPA
, "RPA",
909 SPR_NOACCESS
, SPR_NOACCESS
,
910 &spr_read_generic
, &spr_write_generic
,
915 /* SPR common to MPC755 and G2 */
916 static void gen_spr_G2_755 (CPUPPCState
*env
)
919 spr_register(env
, SPR_SPRG4
, "SPRG4",
920 SPR_NOACCESS
, SPR_NOACCESS
,
921 &spr_read_generic
, &spr_write_generic
,
923 spr_register(env
, SPR_SPRG5
, "SPRG5",
924 SPR_NOACCESS
, SPR_NOACCESS
,
925 &spr_read_generic
, &spr_write_generic
,
927 spr_register(env
, SPR_SPRG6
, "SPRG6",
928 SPR_NOACCESS
, SPR_NOACCESS
,
929 &spr_read_generic
, &spr_write_generic
,
931 spr_register(env
, SPR_SPRG7
, "SPRG7",
932 SPR_NOACCESS
, SPR_NOACCESS
,
933 &spr_read_generic
, &spr_write_generic
,
937 /* SPR common to all 7xx PowerPC implementations */
938 static void gen_spr_7xx (CPUPPCState
*env
)
941 /* XXX : not implemented */
942 spr_register_kvm(env
, SPR_DABR
, "DABR",
943 SPR_NOACCESS
, SPR_NOACCESS
,
944 &spr_read_generic
, &spr_write_generic
,
945 KVM_REG_PPC_DABR
, 0x00000000);
946 /* XXX : not implemented */
947 spr_register(env
, SPR_IABR
, "IABR",
948 SPR_NOACCESS
, SPR_NOACCESS
,
949 &spr_read_generic
, &spr_write_generic
,
951 /* Cache management */
952 /* XXX : not implemented */
953 spr_register(env
, SPR_ICTC
, "ICTC",
954 SPR_NOACCESS
, SPR_NOACCESS
,
955 &spr_read_generic
, &spr_write_generic
,
957 /* Performance monitors */
958 /* XXX : not implemented */
959 spr_register(env
, SPR_7XX_MMCR0
, "MMCR0",
960 SPR_NOACCESS
, SPR_NOACCESS
,
961 &spr_read_generic
, &spr_write_generic
,
963 /* XXX : not implemented */
964 spr_register(env
, SPR_7XX_MMCR1
, "MMCR1",
965 SPR_NOACCESS
, SPR_NOACCESS
,
966 &spr_read_generic
, &spr_write_generic
,
968 /* XXX : not implemented */
969 spr_register(env
, SPR_7XX_PMC1
, "PMC1",
970 SPR_NOACCESS
, SPR_NOACCESS
,
971 &spr_read_generic
, &spr_write_generic
,
973 /* XXX : not implemented */
974 spr_register(env
, SPR_7XX_PMC2
, "PMC2",
975 SPR_NOACCESS
, SPR_NOACCESS
,
976 &spr_read_generic
, &spr_write_generic
,
978 /* XXX : not implemented */
979 spr_register(env
, SPR_7XX_PMC3
, "PMC3",
980 SPR_NOACCESS
, SPR_NOACCESS
,
981 &spr_read_generic
, &spr_write_generic
,
983 /* XXX : not implemented */
984 spr_register(env
, SPR_7XX_PMC4
, "PMC4",
985 SPR_NOACCESS
, SPR_NOACCESS
,
986 &spr_read_generic
, &spr_write_generic
,
988 /* XXX : not implemented */
989 spr_register(env
, SPR_7XX_SIAR
, "SIAR",
990 SPR_NOACCESS
, SPR_NOACCESS
,
991 &spr_read_generic
, SPR_NOACCESS
,
993 /* XXX : not implemented */
994 spr_register(env
, SPR_7XX_UMMCR0
, "UMMCR0",
995 &spr_read_ureg
, SPR_NOACCESS
,
996 &spr_read_ureg
, SPR_NOACCESS
,
998 /* XXX : not implemented */
999 spr_register(env
, SPR_7XX_UMMCR1
, "UMMCR1",
1000 &spr_read_ureg
, SPR_NOACCESS
,
1001 &spr_read_ureg
, SPR_NOACCESS
,
1003 /* XXX : not implemented */
1004 spr_register(env
, SPR_7XX_UPMC1
, "UPMC1",
1005 &spr_read_ureg
, SPR_NOACCESS
,
1006 &spr_read_ureg
, SPR_NOACCESS
,
1008 /* XXX : not implemented */
1009 spr_register(env
, SPR_7XX_UPMC2
, "UPMC2",
1010 &spr_read_ureg
, SPR_NOACCESS
,
1011 &spr_read_ureg
, SPR_NOACCESS
,
1013 /* XXX : not implemented */
1014 spr_register(env
, SPR_7XX_UPMC3
, "UPMC3",
1015 &spr_read_ureg
, SPR_NOACCESS
,
1016 &spr_read_ureg
, SPR_NOACCESS
,
1018 /* XXX : not implemented */
1019 spr_register(env
, SPR_7XX_UPMC4
, "UPMC4",
1020 &spr_read_ureg
, SPR_NOACCESS
,
1021 &spr_read_ureg
, SPR_NOACCESS
,
1023 /* XXX : not implemented */
1024 spr_register(env
, SPR_7XX_USIAR
, "USIAR",
1025 &spr_read_ureg
, SPR_NOACCESS
,
1026 &spr_read_ureg
, SPR_NOACCESS
,
1028 /* External access control */
1029 /* XXX : not implemented */
1030 spr_register(env
, SPR_EAR
, "EAR",
1031 SPR_NOACCESS
, SPR_NOACCESS
,
1032 &spr_read_generic
, &spr_write_generic
,
1037 #ifndef CONFIG_USER_ONLY
1038 static void spr_read_uamr (DisasContext
*ctx
, int gprn
, int sprn
)
1040 gen_load_spr(cpu_gpr
[gprn
], SPR_AMR
);
1041 spr_load_dump_spr(SPR_AMR
);
1044 static void spr_write_uamr (DisasContext
*ctx
, int sprn
, int gprn
)
1046 gen_store_spr(SPR_AMR
, cpu_gpr
[gprn
]);
1047 spr_store_dump_spr(SPR_AMR
);
1050 static void spr_write_uamr_pr (DisasContext
*ctx
, int sprn
, int gprn
)
1052 TCGv t0
= tcg_temp_new();
1054 gen_load_spr(t0
, SPR_UAMOR
);
1055 tcg_gen_and_tl(t0
, t0
, cpu_gpr
[gprn
]);
1056 gen_store_spr(SPR_AMR
, t0
);
1057 spr_store_dump_spr(SPR_AMR
);
1059 #endif /* CONFIG_USER_ONLY */
1061 static void gen_spr_amr (CPUPPCState
*env
)
1063 #ifndef CONFIG_USER_ONLY
1064 /* Virtual Page Class Key protection */
1065 /* The AMR is accessible either via SPR 13 or SPR 29. 13 is
1066 * userspace accessible, 29 is privileged. So we only need to set
1067 * the kvm ONE_REG id on one of them, we use 29 */
1068 spr_register(env
, SPR_UAMR
, "UAMR",
1069 &spr_read_uamr
, &spr_write_uamr_pr
,
1070 &spr_read_uamr
, &spr_write_uamr
,
1072 spr_register_kvm(env
, SPR_AMR
, "AMR",
1073 SPR_NOACCESS
, SPR_NOACCESS
,
1074 &spr_read_generic
, &spr_write_generic
,
1075 KVM_REG_PPC_AMR
, 0);
1076 spr_register_kvm(env
, SPR_UAMOR
, "UAMOR",
1077 SPR_NOACCESS
, SPR_NOACCESS
,
1078 &spr_read_generic
, &spr_write_generic
,
1079 KVM_REG_PPC_UAMOR
, 0);
1080 #endif /* !CONFIG_USER_ONLY */
1082 #endif /* TARGET_PPC64 */
1084 static void gen_spr_thrm (CPUPPCState
*env
)
1086 /* Thermal management */
1087 /* XXX : not implemented */
1088 spr_register(env
, SPR_THRM1
, "THRM1",
1089 SPR_NOACCESS
, SPR_NOACCESS
,
1090 &spr_read_generic
, &spr_write_generic
,
1092 /* XXX : not implemented */
1093 spr_register(env
, SPR_THRM2
, "THRM2",
1094 SPR_NOACCESS
, SPR_NOACCESS
,
1095 &spr_read_generic
, &spr_write_generic
,
1097 /* XXX : not implemented */
1098 spr_register(env
, SPR_THRM3
, "THRM3",
1099 SPR_NOACCESS
, SPR_NOACCESS
,
1100 &spr_read_generic
, &spr_write_generic
,
1104 /* SPR specific to PowerPC 604 implementation */
1105 static void gen_spr_604 (CPUPPCState
*env
)
1107 /* Processor identification */
1108 spr_register(env
, SPR_PIR
, "PIR",
1109 SPR_NOACCESS
, SPR_NOACCESS
,
1110 &spr_read_generic
, &spr_write_pir
,
1113 /* XXX : not implemented */
1114 spr_register(env
, SPR_IABR
, "IABR",
1115 SPR_NOACCESS
, SPR_NOACCESS
,
1116 &spr_read_generic
, &spr_write_generic
,
1118 /* XXX : not implemented */
1119 spr_register_kvm(env
, SPR_DABR
, "DABR",
1120 SPR_NOACCESS
, SPR_NOACCESS
,
1121 &spr_read_generic
, &spr_write_generic
,
1122 KVM_REG_PPC_DABR
, 0x00000000);
1123 /* Performance counters */
1124 /* XXX : not implemented */
1125 spr_register(env
, SPR_7XX_MMCR0
, "MMCR0",
1126 SPR_NOACCESS
, SPR_NOACCESS
,
1127 &spr_read_generic
, &spr_write_generic
,
1129 /* XXX : not implemented */
1130 spr_register(env
, SPR_7XX_PMC1
, "PMC1",
1131 SPR_NOACCESS
, SPR_NOACCESS
,
1132 &spr_read_generic
, &spr_write_generic
,
1134 /* XXX : not implemented */
1135 spr_register(env
, SPR_7XX_PMC2
, "PMC2",
1136 SPR_NOACCESS
, SPR_NOACCESS
,
1137 &spr_read_generic
, &spr_write_generic
,
1139 /* XXX : not implemented */
1140 spr_register(env
, SPR_7XX_SIAR
, "SIAR",
1141 SPR_NOACCESS
, SPR_NOACCESS
,
1142 &spr_read_generic
, SPR_NOACCESS
,
1144 /* XXX : not implemented */
1145 spr_register(env
, SPR_SDA
, "SDA",
1146 SPR_NOACCESS
, SPR_NOACCESS
,
1147 &spr_read_generic
, SPR_NOACCESS
,
1149 /* External access control */
1150 /* XXX : not implemented */
1151 spr_register(env
, SPR_EAR
, "EAR",
1152 SPR_NOACCESS
, SPR_NOACCESS
,
1153 &spr_read_generic
, &spr_write_generic
,
1157 /* SPR specific to PowerPC 603 implementation */
1158 static void gen_spr_603 (CPUPPCState
*env
)
1160 /* External access control */
1161 /* XXX : not implemented */
1162 spr_register(env
, SPR_EAR
, "EAR",
1163 SPR_NOACCESS
, SPR_NOACCESS
,
1164 &spr_read_generic
, &spr_write_generic
,
1167 /* XXX : not implemented */
1168 spr_register(env
, SPR_IABR
, "IABR",
1169 SPR_NOACCESS
, SPR_NOACCESS
,
1170 &spr_read_generic
, &spr_write_generic
,
1175 /* SPR specific to PowerPC G2 implementation */
1176 static void gen_spr_G2 (CPUPPCState
*env
)
1178 /* Memory base address */
1180 /* XXX : not implemented */
1181 spr_register(env
, SPR_MBAR
, "MBAR",
1182 SPR_NOACCESS
, SPR_NOACCESS
,
1183 &spr_read_generic
, &spr_write_generic
,
1185 /* Exception processing */
1186 spr_register(env
, SPR_BOOKE_CSRR0
, "CSRR0",
1187 SPR_NOACCESS
, SPR_NOACCESS
,
1188 &spr_read_generic
, &spr_write_generic
,
1190 spr_register(env
, SPR_BOOKE_CSRR1
, "CSRR1",
1191 SPR_NOACCESS
, SPR_NOACCESS
,
1192 &spr_read_generic
, &spr_write_generic
,
1195 /* XXX : not implemented */
1196 spr_register(env
, SPR_DABR
, "DABR",
1197 SPR_NOACCESS
, SPR_NOACCESS
,
1198 &spr_read_generic
, &spr_write_generic
,
1200 /* XXX : not implemented */
1201 spr_register(env
, SPR_DABR2
, "DABR2",
1202 SPR_NOACCESS
, SPR_NOACCESS
,
1203 &spr_read_generic
, &spr_write_generic
,
1205 /* XXX : not implemented */
1206 spr_register(env
, SPR_IABR
, "IABR",
1207 SPR_NOACCESS
, SPR_NOACCESS
,
1208 &spr_read_generic
, &spr_write_generic
,
1210 /* XXX : not implemented */
1211 spr_register(env
, SPR_IABR2
, "IABR2",
1212 SPR_NOACCESS
, SPR_NOACCESS
,
1213 &spr_read_generic
, &spr_write_generic
,
1215 /* XXX : not implemented */
1216 spr_register(env
, SPR_IBCR
, "IBCR",
1217 SPR_NOACCESS
, SPR_NOACCESS
,
1218 &spr_read_generic
, &spr_write_generic
,
1220 /* XXX : not implemented */
1221 spr_register(env
, SPR_DBCR
, "DBCR",
1222 SPR_NOACCESS
, SPR_NOACCESS
,
1223 &spr_read_generic
, &spr_write_generic
,
1227 /* SPR specific to PowerPC 602 implementation */
1228 static void gen_spr_602 (CPUPPCState
*env
)
1231 /* XXX : not implemented */
1232 spr_register(env
, SPR_SER
, "SER",
1233 SPR_NOACCESS
, SPR_NOACCESS
,
1234 &spr_read_generic
, &spr_write_generic
,
1236 /* XXX : not implemented */
1237 spr_register(env
, SPR_SEBR
, "SEBR",
1238 SPR_NOACCESS
, SPR_NOACCESS
,
1239 &spr_read_generic
, &spr_write_generic
,
1241 /* XXX : not implemented */
1242 spr_register(env
, SPR_ESASRR
, "ESASRR",
1243 SPR_NOACCESS
, SPR_NOACCESS
,
1244 &spr_read_generic
, &spr_write_generic
,
1246 /* Floating point status */
1247 /* XXX : not implemented */
1248 spr_register(env
, SPR_SP
, "SP",
1249 SPR_NOACCESS
, SPR_NOACCESS
,
1250 &spr_read_generic
, &spr_write_generic
,
1252 /* XXX : not implemented */
1253 spr_register(env
, SPR_LT
, "LT",
1254 SPR_NOACCESS
, SPR_NOACCESS
,
1255 &spr_read_generic
, &spr_write_generic
,
1257 /* Watchdog timer */
1258 /* XXX : not implemented */
1259 spr_register(env
, SPR_TCR
, "TCR",
1260 SPR_NOACCESS
, SPR_NOACCESS
,
1261 &spr_read_generic
, &spr_write_generic
,
1263 /* Interrupt base */
1264 spr_register(env
, SPR_IBR
, "IBR",
1265 SPR_NOACCESS
, SPR_NOACCESS
,
1266 &spr_read_generic
, &spr_write_generic
,
1268 /* XXX : not implemented */
1269 spr_register(env
, SPR_IABR
, "IABR",
1270 SPR_NOACCESS
, SPR_NOACCESS
,
1271 &spr_read_generic
, &spr_write_generic
,
1275 /* SPR specific to PowerPC 601 implementation */
1276 static void gen_spr_601 (CPUPPCState
*env
)
1278 /* Multiplication/division register */
1280 spr_register(env
, SPR_MQ
, "MQ",
1281 &spr_read_generic
, &spr_write_generic
,
1282 &spr_read_generic
, &spr_write_generic
,
1285 spr_register(env
, SPR_601_RTCU
, "RTCU",
1286 SPR_NOACCESS
, SPR_NOACCESS
,
1287 SPR_NOACCESS
, &spr_write_601_rtcu
,
1289 spr_register(env
, SPR_601_VRTCU
, "RTCU",
1290 &spr_read_601_rtcu
, SPR_NOACCESS
,
1291 &spr_read_601_rtcu
, SPR_NOACCESS
,
1293 spr_register(env
, SPR_601_RTCL
, "RTCL",
1294 SPR_NOACCESS
, SPR_NOACCESS
,
1295 SPR_NOACCESS
, &spr_write_601_rtcl
,
1297 spr_register(env
, SPR_601_VRTCL
, "RTCL",
1298 &spr_read_601_rtcl
, SPR_NOACCESS
,
1299 &spr_read_601_rtcl
, SPR_NOACCESS
,
1303 spr_register(env
, SPR_601_UDECR
, "UDECR",
1304 &spr_read_decr
, SPR_NOACCESS
,
1305 &spr_read_decr
, SPR_NOACCESS
,
1308 /* External access control */
1309 /* XXX : not implemented */
1310 spr_register(env
, SPR_EAR
, "EAR",
1311 SPR_NOACCESS
, SPR_NOACCESS
,
1312 &spr_read_generic
, &spr_write_generic
,
1314 /* Memory management */
1315 #if !defined(CONFIG_USER_ONLY)
1316 spr_register(env
, SPR_IBAT0U
, "IBAT0U",
1317 SPR_NOACCESS
, SPR_NOACCESS
,
1318 &spr_read_601_ubat
, &spr_write_601_ubatu
,
1320 spr_register(env
, SPR_IBAT0L
, "IBAT0L",
1321 SPR_NOACCESS
, SPR_NOACCESS
,
1322 &spr_read_601_ubat
, &spr_write_601_ubatl
,
1324 spr_register(env
, SPR_IBAT1U
, "IBAT1U",
1325 SPR_NOACCESS
, SPR_NOACCESS
,
1326 &spr_read_601_ubat
, &spr_write_601_ubatu
,
1328 spr_register(env
, SPR_IBAT1L
, "IBAT1L",
1329 SPR_NOACCESS
, SPR_NOACCESS
,
1330 &spr_read_601_ubat
, &spr_write_601_ubatl
,
1332 spr_register(env
, SPR_IBAT2U
, "IBAT2U",
1333 SPR_NOACCESS
, SPR_NOACCESS
,
1334 &spr_read_601_ubat
, &spr_write_601_ubatu
,
1336 spr_register(env
, SPR_IBAT2L
, "IBAT2L",
1337 SPR_NOACCESS
, SPR_NOACCESS
,
1338 &spr_read_601_ubat
, &spr_write_601_ubatl
,
1340 spr_register(env
, SPR_IBAT3U
, "IBAT3U",
1341 SPR_NOACCESS
, SPR_NOACCESS
,
1342 &spr_read_601_ubat
, &spr_write_601_ubatu
,
1344 spr_register(env
, SPR_IBAT3L
, "IBAT3L",
1345 SPR_NOACCESS
, SPR_NOACCESS
,
1346 &spr_read_601_ubat
, &spr_write_601_ubatl
,
1352 static void gen_spr_74xx (CPUPPCState
*env
)
1354 /* Processor identification */
1355 spr_register(env
, SPR_PIR
, "PIR",
1356 SPR_NOACCESS
, SPR_NOACCESS
,
1357 &spr_read_generic
, &spr_write_pir
,
1359 /* XXX : not implemented */
1360 spr_register(env
, SPR_74XX_MMCR2
, "MMCR2",
1361 SPR_NOACCESS
, SPR_NOACCESS
,
1362 &spr_read_generic
, &spr_write_generic
,
1364 /* XXX : not implemented */
1365 spr_register(env
, SPR_74XX_UMMCR2
, "UMMCR2",
1366 &spr_read_ureg
, SPR_NOACCESS
,
1367 &spr_read_ureg
, SPR_NOACCESS
,
1369 /* XXX: not implemented */
1370 spr_register(env
, SPR_BAMR
, "BAMR",
1371 SPR_NOACCESS
, SPR_NOACCESS
,
1372 &spr_read_generic
, &spr_write_generic
,
1374 /* XXX : not implemented */
1375 spr_register(env
, SPR_MSSCR0
, "MSSCR0",
1376 SPR_NOACCESS
, SPR_NOACCESS
,
1377 &spr_read_generic
, &spr_write_generic
,
1379 /* Hardware implementation registers */
1380 /* XXX : not implemented */
1381 spr_register(env
, SPR_HID0
, "HID0",
1382 SPR_NOACCESS
, SPR_NOACCESS
,
1383 &spr_read_generic
, &spr_write_generic
,
1385 /* XXX : not implemented */
1386 spr_register(env
, SPR_HID1
, "HID1",
1387 SPR_NOACCESS
, SPR_NOACCESS
,
1388 &spr_read_generic
, &spr_write_generic
,
1391 spr_register(env
, SPR_VRSAVE
, "VRSAVE",
1392 &spr_read_generic
, &spr_write_generic
,
1393 &spr_read_generic
, &spr_write_generic
,
1395 /* XXX : not implemented */
1396 spr_register(env
, SPR_L2CR
, "L2CR",
1397 SPR_NOACCESS
, SPR_NOACCESS
,
1398 &spr_read_generic
, spr_access_nop
,
1400 /* Not strictly an SPR */
1401 vscr_init(env
, 0x00010000);
1404 static void gen_l3_ctrl (CPUPPCState
*env
)
1407 /* XXX : not implemented */
1408 spr_register(env
, SPR_L3CR
, "L3CR",
1409 SPR_NOACCESS
, SPR_NOACCESS
,
1410 &spr_read_generic
, &spr_write_generic
,
1413 /* XXX : not implemented */
1414 spr_register(env
, SPR_L3ITCR0
, "L3ITCR0",
1415 SPR_NOACCESS
, SPR_NOACCESS
,
1416 &spr_read_generic
, &spr_write_generic
,
1419 /* XXX : not implemented */
1420 spr_register(env
, SPR_L3PM
, "L3PM",
1421 SPR_NOACCESS
, SPR_NOACCESS
,
1422 &spr_read_generic
, &spr_write_generic
,
1426 static void gen_74xx_soft_tlb (CPUPPCState
*env
, int nb_tlbs
, int nb_ways
)
1428 #if !defined(CONFIG_USER_ONLY)
1429 env
->nb_tlb
= nb_tlbs
;
1430 env
->nb_ways
= nb_ways
;
1432 env
->tlb_type
= TLB_6XX
;
1433 /* XXX : not implemented */
1434 spr_register(env
, SPR_PTEHI
, "PTEHI",
1435 SPR_NOACCESS
, SPR_NOACCESS
,
1436 &spr_read_generic
, &spr_write_generic
,
1438 /* XXX : not implemented */
1439 spr_register(env
, SPR_PTELO
, "PTELO",
1440 SPR_NOACCESS
, SPR_NOACCESS
,
1441 &spr_read_generic
, &spr_write_generic
,
1443 /* XXX : not implemented */
1444 spr_register(env
, SPR_TLBMISS
, "TLBMISS",
1445 SPR_NOACCESS
, SPR_NOACCESS
,
1446 &spr_read_generic
, &spr_write_generic
,
1451 #if !defined(CONFIG_USER_ONLY)
1452 static void spr_write_e500_l1csr0 (DisasContext
*ctx
, int sprn
, int gprn
)
1454 TCGv t0
= tcg_temp_new();
1456 tcg_gen_andi_tl(t0
, cpu_gpr
[gprn
], L1CSR0_DCE
| L1CSR0_CPE
);
1457 gen_store_spr(sprn
, t0
);
1461 static void spr_write_e500_l1csr1(DisasContext
*ctx
, int sprn
, int gprn
)
1463 TCGv t0
= tcg_temp_new();
1465 tcg_gen_andi_tl(t0
, cpu_gpr
[gprn
], L1CSR1_ICE
| L1CSR1_CPE
);
1466 gen_store_spr(sprn
, t0
);
1470 static void spr_write_booke206_mmucsr0 (DisasContext
*ctx
, int sprn
, int gprn
)
1472 gen_helper_booke206_tlbflush(cpu_env
, cpu_gpr
[gprn
]);
1475 static void spr_write_booke_pid (DisasContext
*ctx
, int sprn
, int gprn
)
1477 TCGv_i32 t0
= tcg_const_i32(sprn
);
1478 gen_helper_booke_setpid(cpu_env
, t0
, cpu_gpr
[gprn
]);
1479 tcg_temp_free_i32(t0
);
1483 static void gen_spr_usprgh (CPUPPCState
*env
)
1485 spr_register(env
, SPR_USPRG4
, "USPRG4",
1486 &spr_read_ureg
, SPR_NOACCESS
,
1487 &spr_read_ureg
, SPR_NOACCESS
,
1489 spr_register(env
, SPR_USPRG5
, "USPRG5",
1490 &spr_read_ureg
, SPR_NOACCESS
,
1491 &spr_read_ureg
, SPR_NOACCESS
,
1493 spr_register(env
, SPR_USPRG6
, "USPRG6",
1494 &spr_read_ureg
, SPR_NOACCESS
,
1495 &spr_read_ureg
, SPR_NOACCESS
,
1497 spr_register(env
, SPR_USPRG7
, "USPRG7",
1498 &spr_read_ureg
, SPR_NOACCESS
,
1499 &spr_read_ureg
, SPR_NOACCESS
,
1503 /* PowerPC BookE SPR */
1504 static void gen_spr_BookE (CPUPPCState
*env
, uint64_t ivor_mask
)
1506 const char *ivor_names
[64] = {
1507 "IVOR0", "IVOR1", "IVOR2", "IVOR3",
1508 "IVOR4", "IVOR5", "IVOR6", "IVOR7",
1509 "IVOR8", "IVOR9", "IVOR10", "IVOR11",
1510 "IVOR12", "IVOR13", "IVOR14", "IVOR15",
1511 "IVOR16", "IVOR17", "IVOR18", "IVOR19",
1512 "IVOR20", "IVOR21", "IVOR22", "IVOR23",
1513 "IVOR24", "IVOR25", "IVOR26", "IVOR27",
1514 "IVOR28", "IVOR29", "IVOR30", "IVOR31",
1515 "IVOR32", "IVOR33", "IVOR34", "IVOR35",
1516 "IVOR36", "IVOR37", "IVOR38", "IVOR39",
1517 "IVOR40", "IVOR41", "IVOR42", "IVOR43",
1518 "IVOR44", "IVOR45", "IVOR46", "IVOR47",
1519 "IVOR48", "IVOR49", "IVOR50", "IVOR51",
1520 "IVOR52", "IVOR53", "IVOR54", "IVOR55",
1521 "IVOR56", "IVOR57", "IVOR58", "IVOR59",
1522 "IVOR60", "IVOR61", "IVOR62", "IVOR63",
1524 #define SPR_BOOKE_IVORxx (-1)
1525 int ivor_sprn
[64] = {
1526 SPR_BOOKE_IVOR0
, SPR_BOOKE_IVOR1
, SPR_BOOKE_IVOR2
, SPR_BOOKE_IVOR3
,
1527 SPR_BOOKE_IVOR4
, SPR_BOOKE_IVOR5
, SPR_BOOKE_IVOR6
, SPR_BOOKE_IVOR7
,
1528 SPR_BOOKE_IVOR8
, SPR_BOOKE_IVOR9
, SPR_BOOKE_IVOR10
, SPR_BOOKE_IVOR11
,
1529 SPR_BOOKE_IVOR12
, SPR_BOOKE_IVOR13
, SPR_BOOKE_IVOR14
, SPR_BOOKE_IVOR15
,
1530 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1531 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1532 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1533 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1534 SPR_BOOKE_IVOR32
, SPR_BOOKE_IVOR33
, SPR_BOOKE_IVOR34
, SPR_BOOKE_IVOR35
,
1535 SPR_BOOKE_IVOR36
, SPR_BOOKE_IVOR37
, SPR_BOOKE_IVOR38
, SPR_BOOKE_IVOR39
,
1536 SPR_BOOKE_IVOR40
, SPR_BOOKE_IVOR41
, SPR_BOOKE_IVOR42
, SPR_BOOKE_IVORxx
,
1537 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1538 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1539 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1540 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1541 SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
, SPR_BOOKE_IVORxx
,
1545 /* Interrupt processing */
1546 spr_register(env
, SPR_BOOKE_CSRR0
, "CSRR0",
1547 SPR_NOACCESS
, SPR_NOACCESS
,
1548 &spr_read_generic
, &spr_write_generic
,
1550 spr_register(env
, SPR_BOOKE_CSRR1
, "CSRR1",
1551 SPR_NOACCESS
, SPR_NOACCESS
,
1552 &spr_read_generic
, &spr_write_generic
,
1555 /* XXX : not implemented */
1556 spr_register(env
, SPR_BOOKE_IAC1
, "IAC1",
1557 SPR_NOACCESS
, SPR_NOACCESS
,
1558 &spr_read_generic
, &spr_write_generic
,
1560 /* XXX : not implemented */
1561 spr_register(env
, SPR_BOOKE_IAC2
, "IAC2",
1562 SPR_NOACCESS
, SPR_NOACCESS
,
1563 &spr_read_generic
, &spr_write_generic
,
1565 /* XXX : not implemented */
1566 spr_register(env
, SPR_BOOKE_DAC1
, "DAC1",
1567 SPR_NOACCESS
, SPR_NOACCESS
,
1568 &spr_read_generic
, &spr_write_generic
,
1570 /* XXX : not implemented */
1571 spr_register(env
, SPR_BOOKE_DAC2
, "DAC2",
1572 SPR_NOACCESS
, SPR_NOACCESS
,
1573 &spr_read_generic
, &spr_write_generic
,
1575 /* XXX : not implemented */
1576 spr_register(env
, SPR_BOOKE_DBCR0
, "DBCR0",
1577 SPR_NOACCESS
, SPR_NOACCESS
,
1578 &spr_read_generic
, &spr_write_40x_dbcr0
,
1580 /* XXX : not implemented */
1581 spr_register(env
, SPR_BOOKE_DBCR1
, "DBCR1",
1582 SPR_NOACCESS
, SPR_NOACCESS
,
1583 &spr_read_generic
, &spr_write_generic
,
1585 /* XXX : not implemented */
1586 spr_register(env
, SPR_BOOKE_DBCR2
, "DBCR2",
1587 SPR_NOACCESS
, SPR_NOACCESS
,
1588 &spr_read_generic
, &spr_write_generic
,
1590 /* XXX : not implemented */
1591 spr_register(env
, SPR_BOOKE_DBSR
, "DBSR",
1592 SPR_NOACCESS
, SPR_NOACCESS
,
1593 &spr_read_generic
, &spr_write_clear
,
1595 spr_register(env
, SPR_BOOKE_DEAR
, "DEAR",
1596 SPR_NOACCESS
, SPR_NOACCESS
,
1597 &spr_read_generic
, &spr_write_generic
,
1599 spr_register(env
, SPR_BOOKE_ESR
, "ESR",
1600 SPR_NOACCESS
, SPR_NOACCESS
,
1601 &spr_read_generic
, &spr_write_generic
,
1603 spr_register(env
, SPR_BOOKE_IVPR
, "IVPR",
1604 SPR_NOACCESS
, SPR_NOACCESS
,
1605 &spr_read_generic
, &spr_write_excp_prefix
,
1607 /* Exception vectors */
1608 for (i
= 0; i
< 64; i
++) {
1609 if (ivor_mask
& (1ULL << i
)) {
1610 if (ivor_sprn
[i
] == SPR_BOOKE_IVORxx
) {
1611 fprintf(stderr
, "ERROR: IVOR %d SPR is not defined\n", i
);
1614 spr_register(env
, ivor_sprn
[i
], ivor_names
[i
],
1615 SPR_NOACCESS
, SPR_NOACCESS
,
1616 &spr_read_generic
, &spr_write_excp_vector
,
1620 spr_register(env
, SPR_BOOKE_PID
, "PID",
1621 SPR_NOACCESS
, SPR_NOACCESS
,
1622 &spr_read_generic
, &spr_write_booke_pid
,
1624 spr_register(env
, SPR_BOOKE_TCR
, "TCR",
1625 SPR_NOACCESS
, SPR_NOACCESS
,
1626 &spr_read_generic
, &spr_write_booke_tcr
,
1628 spr_register(env
, SPR_BOOKE_TSR
, "TSR",
1629 SPR_NOACCESS
, SPR_NOACCESS
,
1630 &spr_read_generic
, &spr_write_booke_tsr
,
1633 spr_register(env
, SPR_DECR
, "DECR",
1634 SPR_NOACCESS
, SPR_NOACCESS
,
1635 &spr_read_decr
, &spr_write_decr
,
1637 spr_register(env
, SPR_BOOKE_DECAR
, "DECAR",
1638 SPR_NOACCESS
, SPR_NOACCESS
,
1639 SPR_NOACCESS
, &spr_write_generic
,
1642 spr_register(env
, SPR_USPRG0
, "USPRG0",
1643 &spr_read_generic
, &spr_write_generic
,
1644 &spr_read_generic
, &spr_write_generic
,
1646 spr_register(env
, SPR_SPRG4
, "SPRG4",
1647 SPR_NOACCESS
, SPR_NOACCESS
,
1648 &spr_read_generic
, &spr_write_generic
,
1650 spr_register(env
, SPR_SPRG5
, "SPRG5",
1651 SPR_NOACCESS
, SPR_NOACCESS
,
1652 &spr_read_generic
, &spr_write_generic
,
1654 spr_register(env
, SPR_SPRG6
, "SPRG6",
1655 SPR_NOACCESS
, SPR_NOACCESS
,
1656 &spr_read_generic
, &spr_write_generic
,
1658 spr_register(env
, SPR_SPRG7
, "SPRG7",
1659 SPR_NOACCESS
, SPR_NOACCESS
,
1660 &spr_read_generic
, &spr_write_generic
,
1664 static inline uint32_t gen_tlbncfg(uint32_t assoc
, uint32_t minsize
,
1665 uint32_t maxsize
, uint32_t flags
,
1668 return (assoc
<< TLBnCFG_ASSOC_SHIFT
) |
1669 (minsize
<< TLBnCFG_MINSIZE_SHIFT
) |
1670 (maxsize
<< TLBnCFG_MAXSIZE_SHIFT
) |
1674 /* BookE 2.06 storage control registers */
1675 static void gen_spr_BookE206(CPUPPCState
*env
, uint32_t mas_mask
,
1678 #if !defined(CONFIG_USER_ONLY)
1679 const char *mas_names
[8] = {
1680 "MAS0", "MAS1", "MAS2", "MAS3", "MAS4", "MAS5", "MAS6", "MAS7",
1683 SPR_BOOKE_MAS0
, SPR_BOOKE_MAS1
, SPR_BOOKE_MAS2
, SPR_BOOKE_MAS3
,
1684 SPR_BOOKE_MAS4
, SPR_BOOKE_MAS5
, SPR_BOOKE_MAS6
, SPR_BOOKE_MAS7
,
1688 /* TLB assist registers */
1689 /* XXX : not implemented */
1690 for (i
= 0; i
< 8; i
++) {
1691 void (*uea_write
)(DisasContext
*ctx
, int sprn
, int gprn
) = &spr_write_generic32
;
1692 if (i
== 2 && (mas_mask
& (1 << i
)) && (env
->insns_flags
& PPC_64B
)) {
1693 uea_write
= &spr_write_generic
;
1695 if (mas_mask
& (1 << i
)) {
1696 spr_register(env
, mas_sprn
[i
], mas_names
[i
],
1697 SPR_NOACCESS
, SPR_NOACCESS
,
1698 &spr_read_generic
, uea_write
,
1702 if (env
->nb_pids
> 1) {
1703 /* XXX : not implemented */
1704 spr_register(env
, SPR_BOOKE_PID1
, "PID1",
1705 SPR_NOACCESS
, SPR_NOACCESS
,
1706 &spr_read_generic
, &spr_write_booke_pid
,
1709 if (env
->nb_pids
> 2) {
1710 /* XXX : not implemented */
1711 spr_register(env
, SPR_BOOKE_PID2
, "PID2",
1712 SPR_NOACCESS
, SPR_NOACCESS
,
1713 &spr_read_generic
, &spr_write_booke_pid
,
1716 /* XXX : not implemented */
1717 spr_register(env
, SPR_MMUCFG
, "MMUCFG",
1718 SPR_NOACCESS
, SPR_NOACCESS
,
1719 &spr_read_generic
, SPR_NOACCESS
,
1720 0x00000000); /* TOFIX */
1721 switch (env
->nb_ways
) {
1723 spr_register(env
, SPR_BOOKE_TLB3CFG
, "TLB3CFG",
1724 SPR_NOACCESS
, SPR_NOACCESS
,
1725 &spr_read_generic
, SPR_NOACCESS
,
1729 spr_register(env
, SPR_BOOKE_TLB2CFG
, "TLB2CFG",
1730 SPR_NOACCESS
, SPR_NOACCESS
,
1731 &spr_read_generic
, SPR_NOACCESS
,
1735 spr_register(env
, SPR_BOOKE_TLB1CFG
, "TLB1CFG",
1736 SPR_NOACCESS
, SPR_NOACCESS
,
1737 &spr_read_generic
, SPR_NOACCESS
,
1741 spr_register(env
, SPR_BOOKE_TLB0CFG
, "TLB0CFG",
1742 SPR_NOACCESS
, SPR_NOACCESS
,
1743 &spr_read_generic
, SPR_NOACCESS
,
1752 gen_spr_usprgh(env
);
1755 /* SPR specific to PowerPC 440 implementation */
1756 static void gen_spr_440 (CPUPPCState
*env
)
1759 /* XXX : not implemented */
1760 spr_register(env
, SPR_440_DNV0
, "DNV0",
1761 SPR_NOACCESS
, SPR_NOACCESS
,
1762 &spr_read_generic
, &spr_write_generic
,
1764 /* XXX : not implemented */
1765 spr_register(env
, SPR_440_DNV1
, "DNV1",
1766 SPR_NOACCESS
, SPR_NOACCESS
,
1767 &spr_read_generic
, &spr_write_generic
,
1769 /* XXX : not implemented */
1770 spr_register(env
, SPR_440_DNV2
, "DNV2",
1771 SPR_NOACCESS
, SPR_NOACCESS
,
1772 &spr_read_generic
, &spr_write_generic
,
1774 /* XXX : not implemented */
1775 spr_register(env
, SPR_440_DNV3
, "DNV3",
1776 SPR_NOACCESS
, SPR_NOACCESS
,
1777 &spr_read_generic
, &spr_write_generic
,
1779 /* XXX : not implemented */
1780 spr_register(env
, SPR_440_DTV0
, "DTV0",
1781 SPR_NOACCESS
, SPR_NOACCESS
,
1782 &spr_read_generic
, &spr_write_generic
,
1784 /* XXX : not implemented */
1785 spr_register(env
, SPR_440_DTV1
, "DTV1",
1786 SPR_NOACCESS
, SPR_NOACCESS
,
1787 &spr_read_generic
, &spr_write_generic
,
1789 /* XXX : not implemented */
1790 spr_register(env
, SPR_440_DTV2
, "DTV2",
1791 SPR_NOACCESS
, SPR_NOACCESS
,
1792 &spr_read_generic
, &spr_write_generic
,
1794 /* XXX : not implemented */
1795 spr_register(env
, SPR_440_DTV3
, "DTV3",
1796 SPR_NOACCESS
, SPR_NOACCESS
,
1797 &spr_read_generic
, &spr_write_generic
,
1799 /* XXX : not implemented */
1800 spr_register(env
, SPR_440_DVLIM
, "DVLIM",
1801 SPR_NOACCESS
, SPR_NOACCESS
,
1802 &spr_read_generic
, &spr_write_generic
,
1804 /* XXX : not implemented */
1805 spr_register(env
, SPR_440_INV0
, "INV0",
1806 SPR_NOACCESS
, SPR_NOACCESS
,
1807 &spr_read_generic
, &spr_write_generic
,
1809 /* XXX : not implemented */
1810 spr_register(env
, SPR_440_INV1
, "INV1",
1811 SPR_NOACCESS
, SPR_NOACCESS
,
1812 &spr_read_generic
, &spr_write_generic
,
1814 /* XXX : not implemented */
1815 spr_register(env
, SPR_440_INV2
, "INV2",
1816 SPR_NOACCESS
, SPR_NOACCESS
,
1817 &spr_read_generic
, &spr_write_generic
,
1819 /* XXX : not implemented */
1820 spr_register(env
, SPR_440_INV3
, "INV3",
1821 SPR_NOACCESS
, SPR_NOACCESS
,
1822 &spr_read_generic
, &spr_write_generic
,
1824 /* XXX : not implemented */
1825 spr_register(env
, SPR_440_ITV0
, "ITV0",
1826 SPR_NOACCESS
, SPR_NOACCESS
,
1827 &spr_read_generic
, &spr_write_generic
,
1829 /* XXX : not implemented */
1830 spr_register(env
, SPR_440_ITV1
, "ITV1",
1831 SPR_NOACCESS
, SPR_NOACCESS
,
1832 &spr_read_generic
, &spr_write_generic
,
1834 /* XXX : not implemented */
1835 spr_register(env
, SPR_440_ITV2
, "ITV2",
1836 SPR_NOACCESS
, SPR_NOACCESS
,
1837 &spr_read_generic
, &spr_write_generic
,
1839 /* XXX : not implemented */
1840 spr_register(env
, SPR_440_ITV3
, "ITV3",
1841 SPR_NOACCESS
, SPR_NOACCESS
,
1842 &spr_read_generic
, &spr_write_generic
,
1844 /* XXX : not implemented */
1845 spr_register(env
, SPR_440_IVLIM
, "IVLIM",
1846 SPR_NOACCESS
, SPR_NOACCESS
,
1847 &spr_read_generic
, &spr_write_generic
,
1850 /* XXX : not implemented */
1851 spr_register(env
, SPR_BOOKE_DCDBTRH
, "DCDBTRH",
1852 SPR_NOACCESS
, SPR_NOACCESS
,
1853 &spr_read_generic
, SPR_NOACCESS
,
1855 /* XXX : not implemented */
1856 spr_register(env
, SPR_BOOKE_DCDBTRL
, "DCDBTRL",
1857 SPR_NOACCESS
, SPR_NOACCESS
,
1858 &spr_read_generic
, SPR_NOACCESS
,
1860 /* XXX : not implemented */
1861 spr_register(env
, SPR_BOOKE_ICDBDR
, "ICDBDR",
1862 SPR_NOACCESS
, SPR_NOACCESS
,
1863 &spr_read_generic
, SPR_NOACCESS
,
1865 /* XXX : not implemented */
1866 spr_register(env
, SPR_BOOKE_ICDBTRH
, "ICDBTRH",
1867 SPR_NOACCESS
, SPR_NOACCESS
,
1868 &spr_read_generic
, SPR_NOACCESS
,
1870 /* XXX : not implemented */
1871 spr_register(env
, SPR_BOOKE_ICDBTRL
, "ICDBTRL",
1872 SPR_NOACCESS
, SPR_NOACCESS
,
1873 &spr_read_generic
, SPR_NOACCESS
,
1875 /* XXX : not implemented */
1876 spr_register(env
, SPR_440_DBDR
, "DBDR",
1877 SPR_NOACCESS
, SPR_NOACCESS
,
1878 &spr_read_generic
, &spr_write_generic
,
1880 /* Processor control */
1881 spr_register(env
, SPR_4xx_CCR0
, "CCR0",
1882 SPR_NOACCESS
, SPR_NOACCESS
,
1883 &spr_read_generic
, &spr_write_generic
,
1885 spr_register(env
, SPR_440_RSTCFG
, "RSTCFG",
1886 SPR_NOACCESS
, SPR_NOACCESS
,
1887 &spr_read_generic
, SPR_NOACCESS
,
1889 /* Storage control */
1890 spr_register(env
, SPR_440_MMUCR
, "MMUCR",
1891 SPR_NOACCESS
, SPR_NOACCESS
,
1892 &spr_read_generic
, &spr_write_generic
,
1896 /* SPR shared between PowerPC 40x implementations */
1897 static void gen_spr_40x (CPUPPCState
*env
)
1900 /* not emulated, as QEMU do not emulate caches */
1901 spr_register(env
, SPR_40x_DCCR
, "DCCR",
1902 SPR_NOACCESS
, SPR_NOACCESS
,
1903 &spr_read_generic
, &spr_write_generic
,
1905 /* not emulated, as QEMU do not emulate caches */
1906 spr_register(env
, SPR_40x_ICCR
, "ICCR",
1907 SPR_NOACCESS
, SPR_NOACCESS
,
1908 &spr_read_generic
, &spr_write_generic
,
1910 /* not emulated, as QEMU do not emulate caches */
1911 spr_register(env
, SPR_BOOKE_ICDBDR
, "ICDBDR",
1912 SPR_NOACCESS
, SPR_NOACCESS
,
1913 &spr_read_generic
, SPR_NOACCESS
,
1916 spr_register(env
, SPR_40x_DEAR
, "DEAR",
1917 SPR_NOACCESS
, SPR_NOACCESS
,
1918 &spr_read_generic
, &spr_write_generic
,
1920 spr_register(env
, SPR_40x_ESR
, "ESR",
1921 SPR_NOACCESS
, SPR_NOACCESS
,
1922 &spr_read_generic
, &spr_write_generic
,
1924 spr_register(env
, SPR_40x_EVPR
, "EVPR",
1925 SPR_NOACCESS
, SPR_NOACCESS
,
1926 &spr_read_generic
, &spr_write_excp_prefix
,
1928 spr_register(env
, SPR_40x_SRR2
, "SRR2",
1929 &spr_read_generic
, &spr_write_generic
,
1930 &spr_read_generic
, &spr_write_generic
,
1932 spr_register(env
, SPR_40x_SRR3
, "SRR3",
1933 &spr_read_generic
, &spr_write_generic
,
1934 &spr_read_generic
, &spr_write_generic
,
1937 spr_register(env
, SPR_40x_PIT
, "PIT",
1938 SPR_NOACCESS
, SPR_NOACCESS
,
1939 &spr_read_40x_pit
, &spr_write_40x_pit
,
1941 spr_register(env
, SPR_40x_TCR
, "TCR",
1942 SPR_NOACCESS
, SPR_NOACCESS
,
1943 &spr_read_generic
, &spr_write_booke_tcr
,
1945 spr_register(env
, SPR_40x_TSR
, "TSR",
1946 SPR_NOACCESS
, SPR_NOACCESS
,
1947 &spr_read_generic
, &spr_write_booke_tsr
,
1951 /* SPR specific to PowerPC 405 implementation */
1952 static void gen_spr_405 (CPUPPCState
*env
)
1955 spr_register(env
, SPR_40x_PID
, "PID",
1956 SPR_NOACCESS
, SPR_NOACCESS
,
1957 &spr_read_generic
, &spr_write_generic
,
1959 spr_register(env
, SPR_4xx_CCR0
, "CCR0",
1960 SPR_NOACCESS
, SPR_NOACCESS
,
1961 &spr_read_generic
, &spr_write_generic
,
1963 /* Debug interface */
1964 /* XXX : not implemented */
1965 spr_register(env
, SPR_40x_DBCR0
, "DBCR0",
1966 SPR_NOACCESS
, SPR_NOACCESS
,
1967 &spr_read_generic
, &spr_write_40x_dbcr0
,
1969 /* XXX : not implemented */
1970 spr_register(env
, SPR_405_DBCR1
, "DBCR1",
1971 SPR_NOACCESS
, SPR_NOACCESS
,
1972 &spr_read_generic
, &spr_write_generic
,
1974 /* XXX : not implemented */
1975 spr_register(env
, SPR_40x_DBSR
, "DBSR",
1976 SPR_NOACCESS
, SPR_NOACCESS
,
1977 &spr_read_generic
, &spr_write_clear
,
1978 /* Last reset was system reset */
1980 /* XXX : not implemented */
1981 spr_register(env
, SPR_40x_DAC1
, "DAC1",
1982 SPR_NOACCESS
, SPR_NOACCESS
,
1983 &spr_read_generic
, &spr_write_generic
,
1985 spr_register(env
, SPR_40x_DAC2
, "DAC2",
1986 SPR_NOACCESS
, SPR_NOACCESS
,
1987 &spr_read_generic
, &spr_write_generic
,
1989 /* XXX : not implemented */
1990 spr_register(env
, SPR_405_DVC1
, "DVC1",
1991 SPR_NOACCESS
, SPR_NOACCESS
,
1992 &spr_read_generic
, &spr_write_generic
,
1994 /* XXX : not implemented */
1995 spr_register(env
, SPR_405_DVC2
, "DVC2",
1996 SPR_NOACCESS
, SPR_NOACCESS
,
1997 &spr_read_generic
, &spr_write_generic
,
1999 /* XXX : not implemented */
2000 spr_register(env
, SPR_40x_IAC1
, "IAC1",
2001 SPR_NOACCESS
, SPR_NOACCESS
,
2002 &spr_read_generic
, &spr_write_generic
,
2004 spr_register(env
, SPR_40x_IAC2
, "IAC2",
2005 SPR_NOACCESS
, SPR_NOACCESS
,
2006 &spr_read_generic
, &spr_write_generic
,
2008 /* XXX : not implemented */
2009 spr_register(env
, SPR_405_IAC3
, "IAC3",
2010 SPR_NOACCESS
, SPR_NOACCESS
,
2011 &spr_read_generic
, &spr_write_generic
,
2013 /* XXX : not implemented */
2014 spr_register(env
, SPR_405_IAC4
, "IAC4",
2015 SPR_NOACCESS
, SPR_NOACCESS
,
2016 &spr_read_generic
, &spr_write_generic
,
2018 /* Storage control */
2019 /* XXX: TODO: not implemented */
2020 spr_register(env
, SPR_405_SLER
, "SLER",
2021 SPR_NOACCESS
, SPR_NOACCESS
,
2022 &spr_read_generic
, &spr_write_40x_sler
,
2024 spr_register(env
, SPR_40x_ZPR
, "ZPR",
2025 SPR_NOACCESS
, SPR_NOACCESS
,
2026 &spr_read_generic
, &spr_write_generic
,
2028 /* XXX : not implemented */
2029 spr_register(env
, SPR_405_SU0R
, "SU0R",
2030 SPR_NOACCESS
, SPR_NOACCESS
,
2031 &spr_read_generic
, &spr_write_generic
,
2034 spr_register(env
, SPR_USPRG0
, "USPRG0",
2035 &spr_read_ureg
, SPR_NOACCESS
,
2036 &spr_read_ureg
, SPR_NOACCESS
,
2038 spr_register(env
, SPR_SPRG4
, "SPRG4",
2039 SPR_NOACCESS
, SPR_NOACCESS
,
2040 &spr_read_generic
, &spr_write_generic
,
2042 spr_register(env
, SPR_SPRG5
, "SPRG5",
2043 SPR_NOACCESS
, SPR_NOACCESS
,
2044 spr_read_generic
, &spr_write_generic
,
2046 spr_register(env
, SPR_SPRG6
, "SPRG6",
2047 SPR_NOACCESS
, SPR_NOACCESS
,
2048 spr_read_generic
, &spr_write_generic
,
2050 spr_register(env
, SPR_SPRG7
, "SPRG7",
2051 SPR_NOACCESS
, SPR_NOACCESS
,
2052 spr_read_generic
, &spr_write_generic
,
2054 gen_spr_usprgh(env
);
2057 /* SPR shared between PowerPC 401 & 403 implementations */
2058 static void gen_spr_401_403 (CPUPPCState
*env
)
2061 spr_register(env
, SPR_403_VTBL
, "TBL",
2062 &spr_read_tbl
, SPR_NOACCESS
,
2063 &spr_read_tbl
, SPR_NOACCESS
,
2065 spr_register(env
, SPR_403_TBL
, "TBL",
2066 SPR_NOACCESS
, SPR_NOACCESS
,
2067 SPR_NOACCESS
, &spr_write_tbl
,
2069 spr_register(env
, SPR_403_VTBU
, "TBU",
2070 &spr_read_tbu
, SPR_NOACCESS
,
2071 &spr_read_tbu
, SPR_NOACCESS
,
2073 spr_register(env
, SPR_403_TBU
, "TBU",
2074 SPR_NOACCESS
, SPR_NOACCESS
,
2075 SPR_NOACCESS
, &spr_write_tbu
,
2078 /* not emulated, as QEMU do not emulate caches */
2079 spr_register(env
, SPR_403_CDBCR
, "CDBCR",
2080 SPR_NOACCESS
, SPR_NOACCESS
,
2081 &spr_read_generic
, &spr_write_generic
,
2085 /* SPR specific to PowerPC 401 implementation */
2086 static void gen_spr_401 (CPUPPCState
*env
)
2088 /* Debug interface */
2089 /* XXX : not implemented */
2090 spr_register(env
, SPR_40x_DBCR0
, "DBCR",
2091 SPR_NOACCESS
, SPR_NOACCESS
,
2092 &spr_read_generic
, &spr_write_40x_dbcr0
,
2094 /* XXX : not implemented */
2095 spr_register(env
, SPR_40x_DBSR
, "DBSR",
2096 SPR_NOACCESS
, SPR_NOACCESS
,
2097 &spr_read_generic
, &spr_write_clear
,
2098 /* Last reset was system reset */
2100 /* XXX : not implemented */
2101 spr_register(env
, SPR_40x_DAC1
, "DAC",
2102 SPR_NOACCESS
, SPR_NOACCESS
,
2103 &spr_read_generic
, &spr_write_generic
,
2105 /* XXX : not implemented */
2106 spr_register(env
, SPR_40x_IAC1
, "IAC",
2107 SPR_NOACCESS
, SPR_NOACCESS
,
2108 &spr_read_generic
, &spr_write_generic
,
2110 /* Storage control */
2111 /* XXX: TODO: not implemented */
2112 spr_register(env
, SPR_405_SLER
, "SLER",
2113 SPR_NOACCESS
, SPR_NOACCESS
,
2114 &spr_read_generic
, &spr_write_40x_sler
,
2116 /* not emulated, as QEMU never does speculative access */
2117 spr_register(env
, SPR_40x_SGR
, "SGR",
2118 SPR_NOACCESS
, SPR_NOACCESS
,
2119 &spr_read_generic
, &spr_write_generic
,
2121 /* not emulated, as QEMU do not emulate caches */
2122 spr_register(env
, SPR_40x_DCWR
, "DCWR",
2123 SPR_NOACCESS
, SPR_NOACCESS
,
2124 &spr_read_generic
, &spr_write_generic
,
2128 static void gen_spr_401x2 (CPUPPCState
*env
)
2131 spr_register(env
, SPR_40x_PID
, "PID",
2132 SPR_NOACCESS
, SPR_NOACCESS
,
2133 &spr_read_generic
, &spr_write_generic
,
2135 spr_register(env
, SPR_40x_ZPR
, "ZPR",
2136 SPR_NOACCESS
, SPR_NOACCESS
,
2137 &spr_read_generic
, &spr_write_generic
,
2141 /* SPR specific to PowerPC 403 implementation */
2142 static void gen_spr_403 (CPUPPCState
*env
)
2144 /* Debug interface */
2145 /* XXX : not implemented */
2146 spr_register(env
, SPR_40x_DBCR0
, "DBCR0",
2147 SPR_NOACCESS
, SPR_NOACCESS
,
2148 &spr_read_generic
, &spr_write_40x_dbcr0
,
2150 /* XXX : not implemented */
2151 spr_register(env
, SPR_40x_DBSR
, "DBSR",
2152 SPR_NOACCESS
, SPR_NOACCESS
,
2153 &spr_read_generic
, &spr_write_clear
,
2154 /* Last reset was system reset */
2156 /* XXX : not implemented */
2157 spr_register(env
, SPR_40x_DAC1
, "DAC1",
2158 SPR_NOACCESS
, SPR_NOACCESS
,
2159 &spr_read_generic
, &spr_write_generic
,
2161 /* XXX : not implemented */
2162 spr_register(env
, SPR_40x_DAC2
, "DAC2",
2163 SPR_NOACCESS
, SPR_NOACCESS
,
2164 &spr_read_generic
, &spr_write_generic
,
2166 /* XXX : not implemented */
2167 spr_register(env
, SPR_40x_IAC1
, "IAC1",
2168 SPR_NOACCESS
, SPR_NOACCESS
,
2169 &spr_read_generic
, &spr_write_generic
,
2171 /* XXX : not implemented */
2172 spr_register(env
, SPR_40x_IAC2
, "IAC2",
2173 SPR_NOACCESS
, SPR_NOACCESS
,
2174 &spr_read_generic
, &spr_write_generic
,
2178 static void gen_spr_403_real (CPUPPCState
*env
)
2180 spr_register(env
, SPR_403_PBL1
, "PBL1",
2181 SPR_NOACCESS
, SPR_NOACCESS
,
2182 &spr_read_403_pbr
, &spr_write_403_pbr
,
2184 spr_register(env
, SPR_403_PBU1
, "PBU1",
2185 SPR_NOACCESS
, SPR_NOACCESS
,
2186 &spr_read_403_pbr
, &spr_write_403_pbr
,
2188 spr_register(env
, SPR_403_PBL2
, "PBL2",
2189 SPR_NOACCESS
, SPR_NOACCESS
,
2190 &spr_read_403_pbr
, &spr_write_403_pbr
,
2192 spr_register(env
, SPR_403_PBU2
, "PBU2",
2193 SPR_NOACCESS
, SPR_NOACCESS
,
2194 &spr_read_403_pbr
, &spr_write_403_pbr
,
2198 static void gen_spr_403_mmu (CPUPPCState
*env
)
2201 spr_register(env
, SPR_40x_PID
, "PID",
2202 SPR_NOACCESS
, SPR_NOACCESS
,
2203 &spr_read_generic
, &spr_write_generic
,
2205 spr_register(env
, SPR_40x_ZPR
, "ZPR",
2206 SPR_NOACCESS
, SPR_NOACCESS
,
2207 &spr_read_generic
, &spr_write_generic
,
2211 /* SPR specific to PowerPC compression coprocessor extension */
2212 static void gen_spr_compress (CPUPPCState
*env
)
2214 /* XXX : not implemented */
2215 spr_register(env
, SPR_401_SKR
, "SKR",
2216 SPR_NOACCESS
, SPR_NOACCESS
,
2217 &spr_read_generic
, &spr_write_generic
,
2221 static void gen_spr_5xx_8xx (CPUPPCState
*env
)
2223 /* Exception processing */
2224 spr_register_kvm(env
, SPR_DSISR
, "DSISR",
2225 SPR_NOACCESS
, SPR_NOACCESS
,
2226 &spr_read_generic
, &spr_write_generic
,
2227 KVM_REG_PPC_DSISR
, 0x00000000);
2228 spr_register_kvm(env
, SPR_DAR
, "DAR",
2229 SPR_NOACCESS
, SPR_NOACCESS
,
2230 &spr_read_generic
, &spr_write_generic
,
2231 KVM_REG_PPC_DAR
, 0x00000000);
2233 spr_register(env
, SPR_DECR
, "DECR",
2234 SPR_NOACCESS
, SPR_NOACCESS
,
2235 &spr_read_decr
, &spr_write_decr
,
2237 /* XXX : not implemented */
2238 spr_register(env
, SPR_MPC_EIE
, "EIE",
2239 SPR_NOACCESS
, SPR_NOACCESS
,
2240 &spr_read_generic
, &spr_write_generic
,
2242 /* XXX : not implemented */
2243 spr_register(env
, SPR_MPC_EID
, "EID",
2244 SPR_NOACCESS
, SPR_NOACCESS
,
2245 &spr_read_generic
, &spr_write_generic
,
2247 /* XXX : not implemented */
2248 spr_register(env
, SPR_MPC_NRI
, "NRI",
2249 SPR_NOACCESS
, SPR_NOACCESS
,
2250 &spr_read_generic
, &spr_write_generic
,
2252 /* XXX : not implemented */
2253 spr_register(env
, SPR_MPC_CMPA
, "CMPA",
2254 SPR_NOACCESS
, SPR_NOACCESS
,
2255 &spr_read_generic
, &spr_write_generic
,
2257 /* XXX : not implemented */
2258 spr_register(env
, SPR_MPC_CMPB
, "CMPB",
2259 SPR_NOACCESS
, SPR_NOACCESS
,
2260 &spr_read_generic
, &spr_write_generic
,
2262 /* XXX : not implemented */
2263 spr_register(env
, SPR_MPC_CMPC
, "CMPC",
2264 SPR_NOACCESS
, SPR_NOACCESS
,
2265 &spr_read_generic
, &spr_write_generic
,
2267 /* XXX : not implemented */
2268 spr_register(env
, SPR_MPC_CMPD
, "CMPD",
2269 SPR_NOACCESS
, SPR_NOACCESS
,
2270 &spr_read_generic
, &spr_write_generic
,
2272 /* XXX : not implemented */
2273 spr_register(env
, SPR_MPC_ECR
, "ECR",
2274 SPR_NOACCESS
, SPR_NOACCESS
,
2275 &spr_read_generic
, &spr_write_generic
,
2277 /* XXX : not implemented */
2278 spr_register(env
, SPR_MPC_DER
, "DER",
2279 SPR_NOACCESS
, SPR_NOACCESS
,
2280 &spr_read_generic
, &spr_write_generic
,
2282 /* XXX : not implemented */
2283 spr_register(env
, SPR_MPC_COUNTA
, "COUNTA",
2284 SPR_NOACCESS
, SPR_NOACCESS
,
2285 &spr_read_generic
, &spr_write_generic
,
2287 /* XXX : not implemented */
2288 spr_register(env
, SPR_MPC_COUNTB
, "COUNTB",
2289 SPR_NOACCESS
, SPR_NOACCESS
,
2290 &spr_read_generic
, &spr_write_generic
,
2292 /* XXX : not implemented */
2293 spr_register(env
, SPR_MPC_CMPE
, "CMPE",
2294 SPR_NOACCESS
, SPR_NOACCESS
,
2295 &spr_read_generic
, &spr_write_generic
,
2297 /* XXX : not implemented */
2298 spr_register(env
, SPR_MPC_CMPF
, "CMPF",
2299 SPR_NOACCESS
, SPR_NOACCESS
,
2300 &spr_read_generic
, &spr_write_generic
,
2302 /* XXX : not implemented */
2303 spr_register(env
, SPR_MPC_CMPG
, "CMPG",
2304 SPR_NOACCESS
, SPR_NOACCESS
,
2305 &spr_read_generic
, &spr_write_generic
,
2307 /* XXX : not implemented */
2308 spr_register(env
, SPR_MPC_CMPH
, "CMPH",
2309 SPR_NOACCESS
, SPR_NOACCESS
,
2310 &spr_read_generic
, &spr_write_generic
,
2312 /* XXX : not implemented */
2313 spr_register(env
, SPR_MPC_LCTRL1
, "LCTRL1",
2314 SPR_NOACCESS
, SPR_NOACCESS
,
2315 &spr_read_generic
, &spr_write_generic
,
2317 /* XXX : not implemented */
2318 spr_register(env
, SPR_MPC_LCTRL2
, "LCTRL2",
2319 SPR_NOACCESS
, SPR_NOACCESS
,
2320 &spr_read_generic
, &spr_write_generic
,
2322 /* XXX : not implemented */
2323 spr_register(env
, SPR_MPC_BAR
, "BAR",
2324 SPR_NOACCESS
, SPR_NOACCESS
,
2325 &spr_read_generic
, &spr_write_generic
,
2327 /* XXX : not implemented */
2328 spr_register(env
, SPR_MPC_DPDR
, "DPDR",
2329 SPR_NOACCESS
, SPR_NOACCESS
,
2330 &spr_read_generic
, &spr_write_generic
,
2332 /* XXX : not implemented */
2333 spr_register(env
, SPR_MPC_IMMR
, "IMMR",
2334 SPR_NOACCESS
, SPR_NOACCESS
,
2335 &spr_read_generic
, &spr_write_generic
,
2339 static void gen_spr_5xx (CPUPPCState
*env
)
2341 /* XXX : not implemented */
2342 spr_register(env
, SPR_RCPU_MI_GRA
, "MI_GRA",
2343 SPR_NOACCESS
, SPR_NOACCESS
,
2344 &spr_read_generic
, &spr_write_generic
,
2346 /* XXX : not implemented */
2347 spr_register(env
, SPR_RCPU_L2U_GRA
, "L2U_GRA",
2348 SPR_NOACCESS
, SPR_NOACCESS
,
2349 &spr_read_generic
, &spr_write_generic
,
2351 /* XXX : not implemented */
2352 spr_register(env
, SPR_RPCU_BBCMCR
, "L2U_BBCMCR",
2353 SPR_NOACCESS
, SPR_NOACCESS
,
2354 &spr_read_generic
, &spr_write_generic
,
2356 /* XXX : not implemented */
2357 spr_register(env
, SPR_RCPU_L2U_MCR
, "L2U_MCR",
2358 SPR_NOACCESS
, SPR_NOACCESS
,
2359 &spr_read_generic
, &spr_write_generic
,
2361 /* XXX : not implemented */
2362 spr_register(env
, SPR_RCPU_MI_RBA0
, "MI_RBA0",
2363 SPR_NOACCESS
, SPR_NOACCESS
,
2364 &spr_read_generic
, &spr_write_generic
,
2366 /* XXX : not implemented */
2367 spr_register(env
, SPR_RCPU_MI_RBA1
, "MI_RBA1",
2368 SPR_NOACCESS
, SPR_NOACCESS
,
2369 &spr_read_generic
, &spr_write_generic
,
2371 /* XXX : not implemented */
2372 spr_register(env
, SPR_RCPU_MI_RBA2
, "MI_RBA2",
2373 SPR_NOACCESS
, SPR_NOACCESS
,
2374 &spr_read_generic
, &spr_write_generic
,
2376 /* XXX : not implemented */
2377 spr_register(env
, SPR_RCPU_MI_RBA3
, "MI_RBA3",
2378 SPR_NOACCESS
, SPR_NOACCESS
,
2379 &spr_read_generic
, &spr_write_generic
,
2381 /* XXX : not implemented */
2382 spr_register(env
, SPR_RCPU_L2U_RBA0
, "L2U_RBA0",
2383 SPR_NOACCESS
, SPR_NOACCESS
,
2384 &spr_read_generic
, &spr_write_generic
,
2386 /* XXX : not implemented */
2387 spr_register(env
, SPR_RCPU_L2U_RBA1
, "L2U_RBA1",
2388 SPR_NOACCESS
, SPR_NOACCESS
,
2389 &spr_read_generic
, &spr_write_generic
,
2391 /* XXX : not implemented */
2392 spr_register(env
, SPR_RCPU_L2U_RBA2
, "L2U_RBA2",
2393 SPR_NOACCESS
, SPR_NOACCESS
,
2394 &spr_read_generic
, &spr_write_generic
,
2396 /* XXX : not implemented */
2397 spr_register(env
, SPR_RCPU_L2U_RBA3
, "L2U_RBA3",
2398 SPR_NOACCESS
, SPR_NOACCESS
,
2399 &spr_read_generic
, &spr_write_generic
,
2401 /* XXX : not implemented */
2402 spr_register(env
, SPR_RCPU_MI_RA0
, "MI_RA0",
2403 SPR_NOACCESS
, SPR_NOACCESS
,
2404 &spr_read_generic
, &spr_write_generic
,
2406 /* XXX : not implemented */
2407 spr_register(env
, SPR_RCPU_MI_RA1
, "MI_RA1",
2408 SPR_NOACCESS
, SPR_NOACCESS
,
2409 &spr_read_generic
, &spr_write_generic
,
2411 /* XXX : not implemented */
2412 spr_register(env
, SPR_RCPU_MI_RA2
, "MI_RA2",
2413 SPR_NOACCESS
, SPR_NOACCESS
,
2414 &spr_read_generic
, &spr_write_generic
,
2416 /* XXX : not implemented */
2417 spr_register(env
, SPR_RCPU_MI_RA3
, "MI_RA3",
2418 SPR_NOACCESS
, SPR_NOACCESS
,
2419 &spr_read_generic
, &spr_write_generic
,
2421 /* XXX : not implemented */
2422 spr_register(env
, SPR_RCPU_L2U_RA0
, "L2U_RA0",
2423 SPR_NOACCESS
, SPR_NOACCESS
,
2424 &spr_read_generic
, &spr_write_generic
,
2426 /* XXX : not implemented */
2427 spr_register(env
, SPR_RCPU_L2U_RA1
, "L2U_RA1",
2428 SPR_NOACCESS
, SPR_NOACCESS
,
2429 &spr_read_generic
, &spr_write_generic
,
2431 /* XXX : not implemented */
2432 spr_register(env
, SPR_RCPU_L2U_RA2
, "L2U_RA2",
2433 SPR_NOACCESS
, SPR_NOACCESS
,
2434 &spr_read_generic
, &spr_write_generic
,
2436 /* XXX : not implemented */
2437 spr_register(env
, SPR_RCPU_L2U_RA3
, "L2U_RA3",
2438 SPR_NOACCESS
, SPR_NOACCESS
,
2439 &spr_read_generic
, &spr_write_generic
,
2441 /* XXX : not implemented */
2442 spr_register(env
, SPR_RCPU_FPECR
, "FPECR",
2443 SPR_NOACCESS
, SPR_NOACCESS
,
2444 &spr_read_generic
, &spr_write_generic
,
2448 static void gen_spr_8xx (CPUPPCState
*env
)
2450 /* XXX : not implemented */
2451 spr_register(env
, SPR_MPC_IC_CST
, "IC_CST",
2452 SPR_NOACCESS
, SPR_NOACCESS
,
2453 &spr_read_generic
, &spr_write_generic
,
2455 /* XXX : not implemented */
2456 spr_register(env
, SPR_MPC_IC_ADR
, "IC_ADR",
2457 SPR_NOACCESS
, SPR_NOACCESS
,
2458 &spr_read_generic
, &spr_write_generic
,
2460 /* XXX : not implemented */
2461 spr_register(env
, SPR_MPC_IC_DAT
, "IC_DAT",
2462 SPR_NOACCESS
, SPR_NOACCESS
,
2463 &spr_read_generic
, &spr_write_generic
,
2465 /* XXX : not implemented */
2466 spr_register(env
, SPR_MPC_DC_CST
, "DC_CST",
2467 SPR_NOACCESS
, SPR_NOACCESS
,
2468 &spr_read_generic
, &spr_write_generic
,
2470 /* XXX : not implemented */
2471 spr_register(env
, SPR_MPC_DC_ADR
, "DC_ADR",
2472 SPR_NOACCESS
, SPR_NOACCESS
,
2473 &spr_read_generic
, &spr_write_generic
,
2475 /* XXX : not implemented */
2476 spr_register(env
, SPR_MPC_DC_DAT
, "DC_DAT",
2477 SPR_NOACCESS
, SPR_NOACCESS
,
2478 &spr_read_generic
, &spr_write_generic
,
2480 /* XXX : not implemented */
2481 spr_register(env
, SPR_MPC_MI_CTR
, "MI_CTR",
2482 SPR_NOACCESS
, SPR_NOACCESS
,
2483 &spr_read_generic
, &spr_write_generic
,
2485 /* XXX : not implemented */
2486 spr_register(env
, SPR_MPC_MI_AP
, "MI_AP",
2487 SPR_NOACCESS
, SPR_NOACCESS
,
2488 &spr_read_generic
, &spr_write_generic
,
2490 /* XXX : not implemented */
2491 spr_register(env
, SPR_MPC_MI_EPN
, "MI_EPN",
2492 SPR_NOACCESS
, SPR_NOACCESS
,
2493 &spr_read_generic
, &spr_write_generic
,
2495 /* XXX : not implemented */
2496 spr_register(env
, SPR_MPC_MI_TWC
, "MI_TWC",
2497 SPR_NOACCESS
, SPR_NOACCESS
,
2498 &spr_read_generic
, &spr_write_generic
,
2500 /* XXX : not implemented */
2501 spr_register(env
, SPR_MPC_MI_RPN
, "MI_RPN",
2502 SPR_NOACCESS
, SPR_NOACCESS
,
2503 &spr_read_generic
, &spr_write_generic
,
2505 /* XXX : not implemented */
2506 spr_register(env
, SPR_MPC_MI_DBCAM
, "MI_DBCAM",
2507 SPR_NOACCESS
, SPR_NOACCESS
,
2508 &spr_read_generic
, &spr_write_generic
,
2510 /* XXX : not implemented */
2511 spr_register(env
, SPR_MPC_MI_DBRAM0
, "MI_DBRAM0",
2512 SPR_NOACCESS
, SPR_NOACCESS
,
2513 &spr_read_generic
, &spr_write_generic
,
2515 /* XXX : not implemented */
2516 spr_register(env
, SPR_MPC_MI_DBRAM1
, "MI_DBRAM1",
2517 SPR_NOACCESS
, SPR_NOACCESS
,
2518 &spr_read_generic
, &spr_write_generic
,
2520 /* XXX : not implemented */
2521 spr_register(env
, SPR_MPC_MD_CTR
, "MD_CTR",
2522 SPR_NOACCESS
, SPR_NOACCESS
,
2523 &spr_read_generic
, &spr_write_generic
,
2525 /* XXX : not implemented */
2526 spr_register(env
, SPR_MPC_MD_CASID
, "MD_CASID",
2527 SPR_NOACCESS
, SPR_NOACCESS
,
2528 &spr_read_generic
, &spr_write_generic
,
2530 /* XXX : not implemented */
2531 spr_register(env
, SPR_MPC_MD_AP
, "MD_AP",
2532 SPR_NOACCESS
, SPR_NOACCESS
,
2533 &spr_read_generic
, &spr_write_generic
,
2535 /* XXX : not implemented */
2536 spr_register(env
, SPR_MPC_MD_EPN
, "MD_EPN",
2537 SPR_NOACCESS
, SPR_NOACCESS
,
2538 &spr_read_generic
, &spr_write_generic
,
2540 /* XXX : not implemented */
2541 spr_register(env
, SPR_MPC_MD_TWB
, "MD_TWB",
2542 SPR_NOACCESS
, SPR_NOACCESS
,
2543 &spr_read_generic
, &spr_write_generic
,
2545 /* XXX : not implemented */
2546 spr_register(env
, SPR_MPC_MD_TWC
, "MD_TWC",
2547 SPR_NOACCESS
, SPR_NOACCESS
,
2548 &spr_read_generic
, &spr_write_generic
,
2550 /* XXX : not implemented */
2551 spr_register(env
, SPR_MPC_MD_RPN
, "MD_RPN",
2552 SPR_NOACCESS
, SPR_NOACCESS
,
2553 &spr_read_generic
, &spr_write_generic
,
2555 /* XXX : not implemented */
2556 spr_register(env
, SPR_MPC_MD_TW
, "MD_TW",
2557 SPR_NOACCESS
, SPR_NOACCESS
,
2558 &spr_read_generic
, &spr_write_generic
,
2560 /* XXX : not implemented */
2561 spr_register(env
, SPR_MPC_MD_DBCAM
, "MD_DBCAM",
2562 SPR_NOACCESS
, SPR_NOACCESS
,
2563 &spr_read_generic
, &spr_write_generic
,
2565 /* XXX : not implemented */
2566 spr_register(env
, SPR_MPC_MD_DBRAM0
, "MD_DBRAM0",
2567 SPR_NOACCESS
, SPR_NOACCESS
,
2568 &spr_read_generic
, &spr_write_generic
,
2570 /* XXX : not implemented */
2571 spr_register(env
, SPR_MPC_MD_DBRAM1
, "MD_DBRAM1",
2572 SPR_NOACCESS
, SPR_NOACCESS
,
2573 &spr_read_generic
, &spr_write_generic
,
2579 * AMR => SPR 29 (Power 2.04)
2580 * CTRL => SPR 136 (Power 2.04)
2581 * CTRL => SPR 152 (Power 2.04)
2582 * SCOMC => SPR 276 (64 bits ?)
2583 * SCOMD => SPR 277 (64 bits ?)
2584 * TBU40 => SPR 286 (Power 2.04 hypv)
2585 * HSPRG0 => SPR 304 (Power 2.04 hypv)
2586 * HSPRG1 => SPR 305 (Power 2.04 hypv)
2587 * HDSISR => SPR 306 (Power 2.04 hypv)
2588 * HDAR => SPR 307 (Power 2.04 hypv)
2589 * PURR => SPR 309 (Power 2.04 hypv)
2590 * HDEC => SPR 310 (Power 2.04 hypv)
2591 * HIOR => SPR 311 (hypv)
2592 * RMOR => SPR 312 (970)
2593 * HRMOR => SPR 313 (Power 2.04 hypv)
2594 * HSRR0 => SPR 314 (Power 2.04 hypv)
2595 * HSRR1 => SPR 315 (Power 2.04 hypv)
2596 * LPIDR => SPR 317 (970)
2597 * EPR => SPR 702 (Power 2.04 emb)
2598 * perf => 768-783 (Power 2.04)
2599 * perf => 784-799 (Power 2.04)
2600 * PPR => SPR 896 (Power 2.04)
2601 * EPLC => SPR 947 (Power 2.04 emb)
2602 * EPSC => SPR 948 (Power 2.04 emb)
2603 * DABRX => 1015 (Power 2.04 hypv)
2604 * FPECR => SPR 1022 (?)
2605 * ... and more (thermal management, performance counters, ...)
2608 /*****************************************************************************/
2609 /* Exception vectors models */
2610 static void init_excp_4xx_real (CPUPPCState
*env
)
2612 #if !defined(CONFIG_USER_ONLY)
2613 env
->excp_vectors
[POWERPC_EXCP_CRITICAL
] = 0x00000100;
2614 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2615 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2616 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2617 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2618 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2619 env
->excp_vectors
[POWERPC_EXCP_PIT
] = 0x00001000;
2620 env
->excp_vectors
[POWERPC_EXCP_FIT
] = 0x00001010;
2621 env
->excp_vectors
[POWERPC_EXCP_WDT
] = 0x00001020;
2622 env
->excp_vectors
[POWERPC_EXCP_DEBUG
] = 0x00002000;
2623 env
->ivor_mask
= 0x0000FFF0UL
;
2624 env
->ivpr_mask
= 0xFFFF0000UL
;
2625 /* Hardware reset vector */
2626 env
->hreset_vector
= 0xFFFFFFFCUL
;
2630 static void init_excp_4xx_softmmu (CPUPPCState
*env
)
2632 #if !defined(CONFIG_USER_ONLY)
2633 env
->excp_vectors
[POWERPC_EXCP_CRITICAL
] = 0x00000100;
2634 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2635 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2636 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2637 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2638 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2639 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2640 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2641 env
->excp_vectors
[POWERPC_EXCP_PIT
] = 0x00001000;
2642 env
->excp_vectors
[POWERPC_EXCP_FIT
] = 0x00001010;
2643 env
->excp_vectors
[POWERPC_EXCP_WDT
] = 0x00001020;
2644 env
->excp_vectors
[POWERPC_EXCP_DTLB
] = 0x00001100;
2645 env
->excp_vectors
[POWERPC_EXCP_ITLB
] = 0x00001200;
2646 env
->excp_vectors
[POWERPC_EXCP_DEBUG
] = 0x00002000;
2647 env
->ivor_mask
= 0x0000FFF0UL
;
2648 env
->ivpr_mask
= 0xFFFF0000UL
;
2649 /* Hardware reset vector */
2650 env
->hreset_vector
= 0xFFFFFFFCUL
;
2654 static void init_excp_MPC5xx (CPUPPCState
*env
)
2656 #if !defined(CONFIG_USER_ONLY)
2657 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2658 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2659 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2660 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2661 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2662 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000900;
2663 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2664 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2665 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2666 env
->excp_vectors
[POWERPC_EXCP_FPA
] = 0x00000E00;
2667 env
->excp_vectors
[POWERPC_EXCP_EMUL
] = 0x00001000;
2668 env
->excp_vectors
[POWERPC_EXCP_DABR
] = 0x00001C00;
2669 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001C00;
2670 env
->excp_vectors
[POWERPC_EXCP_MEXTBR
] = 0x00001E00;
2671 env
->excp_vectors
[POWERPC_EXCP_NMEXTBR
] = 0x00001F00;
2672 env
->ivor_mask
= 0x0000FFF0UL
;
2673 env
->ivpr_mask
= 0xFFFF0000UL
;
2674 /* Hardware reset vector */
2675 env
->hreset_vector
= 0x00000100UL
;
2679 static void init_excp_MPC8xx (CPUPPCState
*env
)
2681 #if !defined(CONFIG_USER_ONLY)
2682 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2683 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2684 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2685 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2686 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2687 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2688 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2689 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000900;
2690 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2691 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2692 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2693 env
->excp_vectors
[POWERPC_EXCP_FPA
] = 0x00000E00;
2694 env
->excp_vectors
[POWERPC_EXCP_EMUL
] = 0x00001000;
2695 env
->excp_vectors
[POWERPC_EXCP_ITLB
] = 0x00001100;
2696 env
->excp_vectors
[POWERPC_EXCP_DTLB
] = 0x00001200;
2697 env
->excp_vectors
[POWERPC_EXCP_ITLBE
] = 0x00001300;
2698 env
->excp_vectors
[POWERPC_EXCP_DTLBE
] = 0x00001400;
2699 env
->excp_vectors
[POWERPC_EXCP_DABR
] = 0x00001C00;
2700 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001C00;
2701 env
->excp_vectors
[POWERPC_EXCP_MEXTBR
] = 0x00001E00;
2702 env
->excp_vectors
[POWERPC_EXCP_NMEXTBR
] = 0x00001F00;
2703 env
->ivor_mask
= 0x0000FFF0UL
;
2704 env
->ivpr_mask
= 0xFFFF0000UL
;
2705 /* Hardware reset vector */
2706 env
->hreset_vector
= 0x00000100UL
;
2710 static void init_excp_G2 (CPUPPCState
*env
)
2712 #if !defined(CONFIG_USER_ONLY)
2713 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2714 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2715 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2716 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2717 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2718 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2719 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2720 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2721 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2722 env
->excp_vectors
[POWERPC_EXCP_CRITICAL
] = 0x00000A00;
2723 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2724 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2725 env
->excp_vectors
[POWERPC_EXCP_IFTLB
] = 0x00001000;
2726 env
->excp_vectors
[POWERPC_EXCP_DLTLB
] = 0x00001100;
2727 env
->excp_vectors
[POWERPC_EXCP_DSTLB
] = 0x00001200;
2728 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2729 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2730 /* Hardware reset vector */
2731 env
->hreset_vector
= 0x00000100UL
;
2735 static void init_excp_e200(CPUPPCState
*env
, target_ulong ivpr_mask
)
2737 #if !defined(CONFIG_USER_ONLY)
2738 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000FFC;
2739 env
->excp_vectors
[POWERPC_EXCP_CRITICAL
] = 0x00000000;
2740 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000000;
2741 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000000;
2742 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000000;
2743 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000000;
2744 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000000;
2745 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000000;
2746 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000000;
2747 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000000;
2748 env
->excp_vectors
[POWERPC_EXCP_APU
] = 0x00000000;
2749 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000000;
2750 env
->excp_vectors
[POWERPC_EXCP_FIT
] = 0x00000000;
2751 env
->excp_vectors
[POWERPC_EXCP_WDT
] = 0x00000000;
2752 env
->excp_vectors
[POWERPC_EXCP_DTLB
] = 0x00000000;
2753 env
->excp_vectors
[POWERPC_EXCP_ITLB
] = 0x00000000;
2754 env
->excp_vectors
[POWERPC_EXCP_DEBUG
] = 0x00000000;
2755 env
->excp_vectors
[POWERPC_EXCP_SPEU
] = 0x00000000;
2756 env
->excp_vectors
[POWERPC_EXCP_EFPDI
] = 0x00000000;
2757 env
->excp_vectors
[POWERPC_EXCP_EFPRI
] = 0x00000000;
2758 env
->ivor_mask
= 0x0000FFF7UL
;
2759 env
->ivpr_mask
= ivpr_mask
;
2760 /* Hardware reset vector */
2761 env
->hreset_vector
= 0xFFFFFFFCUL
;
2765 static void init_excp_BookE (CPUPPCState
*env
)
2767 #if !defined(CONFIG_USER_ONLY)
2768 env
->excp_vectors
[POWERPC_EXCP_CRITICAL
] = 0x00000000;
2769 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000000;
2770 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000000;
2771 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000000;
2772 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000000;
2773 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000000;
2774 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000000;
2775 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000000;
2776 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000000;
2777 env
->excp_vectors
[POWERPC_EXCP_APU
] = 0x00000000;
2778 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000000;
2779 env
->excp_vectors
[POWERPC_EXCP_FIT
] = 0x00000000;
2780 env
->excp_vectors
[POWERPC_EXCP_WDT
] = 0x00000000;
2781 env
->excp_vectors
[POWERPC_EXCP_DTLB
] = 0x00000000;
2782 env
->excp_vectors
[POWERPC_EXCP_ITLB
] = 0x00000000;
2783 env
->excp_vectors
[POWERPC_EXCP_DEBUG
] = 0x00000000;
2784 env
->ivor_mask
= 0x0000FFF0UL
;
2785 env
->ivpr_mask
= 0xFFFF0000UL
;
2786 /* Hardware reset vector */
2787 env
->hreset_vector
= 0xFFFFFFFCUL
;
2791 static void init_excp_601 (CPUPPCState
*env
)
2793 #if !defined(CONFIG_USER_ONLY)
2794 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2795 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2796 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2797 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2798 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2799 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2800 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2801 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2802 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2803 env
->excp_vectors
[POWERPC_EXCP_IO
] = 0x00000A00;
2804 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2805 env
->excp_vectors
[POWERPC_EXCP_RUNM
] = 0x00002000;
2806 /* Hardware reset vector */
2807 env
->hreset_vector
= 0x00000100UL
;
2811 static void init_excp_602 (CPUPPCState
*env
)
2813 #if !defined(CONFIG_USER_ONLY)
2814 /* XXX: exception prefix has a special behavior on 602 */
2815 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2816 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2817 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2818 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2819 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2820 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2821 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2822 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2823 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2824 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2825 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2826 env
->excp_vectors
[POWERPC_EXCP_IFTLB
] = 0x00001000;
2827 env
->excp_vectors
[POWERPC_EXCP_DLTLB
] = 0x00001100;
2828 env
->excp_vectors
[POWERPC_EXCP_DSTLB
] = 0x00001200;
2829 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2830 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2831 env
->excp_vectors
[POWERPC_EXCP_WDT
] = 0x00001500;
2832 env
->excp_vectors
[POWERPC_EXCP_EMUL
] = 0x00001600;
2833 /* Hardware reset vector */
2834 env
->hreset_vector
= 0x00000100UL
;
2838 static void init_excp_603 (CPUPPCState
*env
)
2840 #if !defined(CONFIG_USER_ONLY)
2841 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2842 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2843 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2844 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2845 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2846 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2847 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2848 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2849 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2850 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2851 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2852 env
->excp_vectors
[POWERPC_EXCP_IFTLB
] = 0x00001000;
2853 env
->excp_vectors
[POWERPC_EXCP_DLTLB
] = 0x00001100;
2854 env
->excp_vectors
[POWERPC_EXCP_DSTLB
] = 0x00001200;
2855 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2856 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2857 /* Hardware reset vector */
2858 env
->hreset_vector
= 0x00000100UL
;
2862 static void init_excp_604 (CPUPPCState
*env
)
2864 #if !defined(CONFIG_USER_ONLY)
2865 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2866 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2867 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2868 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2869 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2870 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2871 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2872 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2873 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2874 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2875 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2876 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
2877 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2878 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2879 /* Hardware reset vector */
2880 env
->hreset_vector
= 0x00000100UL
;
2884 static void init_excp_7x0 (CPUPPCState
*env
)
2886 #if !defined(CONFIG_USER_ONLY)
2887 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2888 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2889 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2890 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2891 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2892 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2893 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2894 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2895 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2896 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2897 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2898 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
2899 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2900 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2901 env
->excp_vectors
[POWERPC_EXCP_THERM
] = 0x00001700;
2902 /* Hardware reset vector */
2903 env
->hreset_vector
= 0x00000100UL
;
2907 static void init_excp_750cl (CPUPPCState
*env
)
2909 #if !defined(CONFIG_USER_ONLY)
2910 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2911 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2912 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2913 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2914 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2915 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2916 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2917 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2918 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2919 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2920 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2921 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
2922 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2923 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2924 /* Hardware reset vector */
2925 env
->hreset_vector
= 0x00000100UL
;
2929 static void init_excp_750cx (CPUPPCState
*env
)
2931 #if !defined(CONFIG_USER_ONLY)
2932 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2933 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2934 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2935 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2936 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2937 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2938 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2939 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2940 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2941 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2942 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2943 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
2944 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2945 env
->excp_vectors
[POWERPC_EXCP_THERM
] = 0x00001700;
2946 /* Hardware reset vector */
2947 env
->hreset_vector
= 0x00000100UL
;
2951 /* XXX: Check if this is correct */
2952 static void init_excp_7x5 (CPUPPCState
*env
)
2954 #if !defined(CONFIG_USER_ONLY)
2955 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2956 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2957 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2958 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2959 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2960 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2961 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2962 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2963 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2964 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2965 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2966 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
2967 env
->excp_vectors
[POWERPC_EXCP_IFTLB
] = 0x00001000;
2968 env
->excp_vectors
[POWERPC_EXCP_DLTLB
] = 0x00001100;
2969 env
->excp_vectors
[POWERPC_EXCP_DSTLB
] = 0x00001200;
2970 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2971 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2972 env
->excp_vectors
[POWERPC_EXCP_THERM
] = 0x00001700;
2973 /* Hardware reset vector */
2974 env
->hreset_vector
= 0x00000100UL
;
2978 static void init_excp_7400 (CPUPPCState
*env
)
2980 #if !defined(CONFIG_USER_ONLY)
2981 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
2982 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
2983 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
2984 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
2985 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
2986 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
2987 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
2988 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
2989 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
2990 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
2991 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
2992 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
2993 env
->excp_vectors
[POWERPC_EXCP_VPU
] = 0x00000F20;
2994 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
2995 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
2996 env
->excp_vectors
[POWERPC_EXCP_VPUA
] = 0x00001600;
2997 env
->excp_vectors
[POWERPC_EXCP_THERM
] = 0x00001700;
2998 /* Hardware reset vector */
2999 env
->hreset_vector
= 0x00000100UL
;
3003 static void init_excp_7450 (CPUPPCState
*env
)
3005 #if !defined(CONFIG_USER_ONLY)
3006 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
3007 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
3008 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
3009 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
3010 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
3011 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
3012 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
3013 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
3014 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
3015 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
3016 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
3017 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
3018 env
->excp_vectors
[POWERPC_EXCP_VPU
] = 0x00000F20;
3019 env
->excp_vectors
[POWERPC_EXCP_IFTLB
] = 0x00001000;
3020 env
->excp_vectors
[POWERPC_EXCP_DLTLB
] = 0x00001100;
3021 env
->excp_vectors
[POWERPC_EXCP_DSTLB
] = 0x00001200;
3022 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
3023 env
->excp_vectors
[POWERPC_EXCP_SMI
] = 0x00001400;
3024 env
->excp_vectors
[POWERPC_EXCP_VPUA
] = 0x00001600;
3025 /* Hardware reset vector */
3026 env
->hreset_vector
= 0x00000100UL
;
3030 #if defined (TARGET_PPC64)
3031 static void init_excp_970 (CPUPPCState
*env
)
3033 #if !defined(CONFIG_USER_ONLY)
3034 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
3035 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
3036 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
3037 env
->excp_vectors
[POWERPC_EXCP_DSEG
] = 0x00000380;
3038 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
3039 env
->excp_vectors
[POWERPC_EXCP_ISEG
] = 0x00000480;
3040 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
3041 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
3042 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
3043 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
3044 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
3045 env
->excp_vectors
[POWERPC_EXCP_HDECR
] = 0x00000980;
3046 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
3047 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
3048 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
3049 env
->excp_vectors
[POWERPC_EXCP_VPU
] = 0x00000F20;
3050 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
3051 env
->excp_vectors
[POWERPC_EXCP_MAINT
] = 0x00001600;
3052 env
->excp_vectors
[POWERPC_EXCP_VPUA
] = 0x00001700;
3053 env
->excp_vectors
[POWERPC_EXCP_THERM
] = 0x00001800;
3054 /* Hardware reset vector */
3055 env
->hreset_vector
= 0x0000000000000100ULL
;
3059 static void init_excp_POWER7 (CPUPPCState
*env
)
3061 #if !defined(CONFIG_USER_ONLY)
3062 env
->excp_vectors
[POWERPC_EXCP_RESET
] = 0x00000100;
3063 env
->excp_vectors
[POWERPC_EXCP_MCHECK
] = 0x00000200;
3064 env
->excp_vectors
[POWERPC_EXCP_DSI
] = 0x00000300;
3065 env
->excp_vectors
[POWERPC_EXCP_DSEG
] = 0x00000380;
3066 env
->excp_vectors
[POWERPC_EXCP_ISI
] = 0x00000400;
3067 env
->excp_vectors
[POWERPC_EXCP_ISEG
] = 0x00000480;
3068 env
->excp_vectors
[POWERPC_EXCP_EXTERNAL
] = 0x00000500;
3069 env
->excp_vectors
[POWERPC_EXCP_ALIGN
] = 0x00000600;
3070 env
->excp_vectors
[POWERPC_EXCP_PROGRAM
] = 0x00000700;
3071 env
->excp_vectors
[POWERPC_EXCP_FPU
] = 0x00000800;
3072 env
->excp_vectors
[POWERPC_EXCP_DECR
] = 0x00000900;
3073 env
->excp_vectors
[POWERPC_EXCP_HDECR
] = 0x00000980;
3074 env
->excp_vectors
[POWERPC_EXCP_SYSCALL
] = 0x00000C00;
3075 env
->excp_vectors
[POWERPC_EXCP_TRACE
] = 0x00000D00;
3076 env
->excp_vectors
[POWERPC_EXCP_PERFM
] = 0x00000F00;
3077 env
->excp_vectors
[POWERPC_EXCP_VPU
] = 0x00000F20;
3078 env
->excp_vectors
[POWERPC_EXCP_VSXU
] = 0x00000F40;
3079 env
->excp_vectors
[POWERPC_EXCP_FU
] = 0x00000F60;
3080 env
->excp_vectors
[POWERPC_EXCP_IABR
] = 0x00001300;
3081 env
->excp_vectors
[POWERPC_EXCP_MAINT
] = 0x00001600;
3082 env
->excp_vectors
[POWERPC_EXCP_VPUA
] = 0x00001700;
3083 env
->excp_vectors
[POWERPC_EXCP_THERM
] = 0x00001800;
3084 /* Hardware reset vector */
3085 env
->hreset_vector
= 0x0000000000000100ULL
;
3090 /*****************************************************************************/
3091 /* Power management enable checks */
3092 static int check_pow_none (CPUPPCState
*env
)
3097 static int check_pow_nocheck (CPUPPCState
*env
)
3102 static int check_pow_hid0 (CPUPPCState
*env
)
3104 if (env
->spr
[SPR_HID0
] & 0x00E00000)
3110 static int check_pow_hid0_74xx (CPUPPCState
*env
)
3112 if (env
->spr
[SPR_HID0
] & 0x00600000)
3118 static bool ppc_cpu_interrupts_big_endian_always(PowerPCCPU
*cpu
)
3124 static bool ppc_cpu_interrupts_big_endian_lpcr(PowerPCCPU
*cpu
)
3126 return !(cpu
->env
.spr
[SPR_LPCR
] & LPCR_ILE
);
3130 /*****************************************************************************/
3131 /* PowerPC implementations definitions */
3133 #define POWERPC_FAMILY(_name) \
3135 glue(glue(ppc_, _name), _cpu_family_class_init)(ObjectClass *, void *); \
3137 static const TypeInfo \
3138 glue(glue(ppc_, _name), _cpu_family_type_info) = { \
3139 .name = stringify(_name) "-family-" TYPE_POWERPC_CPU, \
3140 .parent = TYPE_POWERPC_CPU, \
3142 .class_init = glue(glue(ppc_, _name), _cpu_family_class_init), \
3145 static void glue(glue(ppc_, _name), _cpu_family_register_types)(void) \
3147 type_register_static( \
3148 &glue(glue(ppc_, _name), _cpu_family_type_info)); \
3151 type_init(glue(glue(ppc_, _name), _cpu_family_register_types)) \
3153 static void glue(glue(ppc_, _name), _cpu_family_class_init)
3155 static void init_proc_401 (CPUPPCState
*env
)
3158 gen_spr_401_403(env
);
3160 init_excp_4xx_real(env
);
3161 env
->dcache_line_size
= 32;
3162 env
->icache_line_size
= 32;
3163 /* Allocate hardware IRQ controller */
3164 ppc40x_irq_init(env
);
3166 SET_FIT_PERIOD(12, 16, 20, 24);
3167 SET_WDT_PERIOD(16, 20, 24, 28);
3170 POWERPC_FAMILY(401)(ObjectClass
*oc
, void *data
)
3172 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3173 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3175 dc
->desc
= "PowerPC 401";
3176 pcc
->init_proc
= init_proc_401
;
3177 pcc
->check_pow
= check_pow_nocheck
;
3178 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3179 PPC_WRTEE
| PPC_DCR
|
3180 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_40x_ICBT
|
3182 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
3183 PPC_4xx_COMMON
| PPC_40x_EXCP
;
3184 pcc
->msr_mask
= (1ull << MSR_KEY
) |
3193 pcc
->mmu_model
= POWERPC_MMU_REAL
;
3194 pcc
->excp_model
= POWERPC_EXCP_40x
;
3195 pcc
->bus_model
= PPC_FLAGS_INPUT_401
;
3196 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3197 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DE
|
3198 POWERPC_FLAG_BUS_CLK
;
3201 static void init_proc_401x2 (CPUPPCState
*env
)
3204 gen_spr_401_403(env
);
3206 gen_spr_compress(env
);
3207 /* Memory management */
3208 #if !defined(CONFIG_USER_ONLY)
3212 env
->tlb_type
= TLB_EMB
;
3214 init_excp_4xx_softmmu(env
);
3215 env
->dcache_line_size
= 32;
3216 env
->icache_line_size
= 32;
3217 /* Allocate hardware IRQ controller */
3218 ppc40x_irq_init(env
);
3220 SET_FIT_PERIOD(12, 16, 20, 24);
3221 SET_WDT_PERIOD(16, 20, 24, 28);
3224 POWERPC_FAMILY(401x2
)(ObjectClass
*oc
, void *data
)
3226 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3227 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3229 dc
->desc
= "PowerPC 401x2";
3230 pcc
->init_proc
= init_proc_401x2
;
3231 pcc
->check_pow
= check_pow_nocheck
;
3232 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
3233 PPC_DCR
| PPC_WRTEE
|
3234 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_40x_ICBT
|
3235 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3236 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
3237 PPC_40x_TLB
| PPC_MEM_TLBIA
| PPC_MEM_TLBSYNC
|
3238 PPC_4xx_COMMON
| PPC_40x_EXCP
;
3239 pcc
->msr_mask
= (1ull << 20) |
3251 pcc
->mmu_model
= POWERPC_MMU_SOFT_4xx_Z
;
3252 pcc
->excp_model
= POWERPC_EXCP_40x
;
3253 pcc
->bus_model
= PPC_FLAGS_INPUT_401
;
3254 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3255 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DE
|
3256 POWERPC_FLAG_BUS_CLK
;
3259 static void init_proc_401x3 (CPUPPCState
*env
)
3262 gen_spr_401_403(env
);
3265 gen_spr_compress(env
);
3266 init_excp_4xx_softmmu(env
);
3267 env
->dcache_line_size
= 32;
3268 env
->icache_line_size
= 32;
3269 /* Allocate hardware IRQ controller */
3270 ppc40x_irq_init(env
);
3272 SET_FIT_PERIOD(12, 16, 20, 24);
3273 SET_WDT_PERIOD(16, 20, 24, 28);
3276 POWERPC_FAMILY(401x3
)(ObjectClass
*oc
, void *data
)
3278 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3279 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3281 dc
->desc
= "PowerPC 401x3";
3282 pcc
->init_proc
= init_proc_401x3
;
3283 pcc
->check_pow
= check_pow_nocheck
;
3284 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
3285 PPC_DCR
| PPC_WRTEE
|
3286 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_40x_ICBT
|
3287 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3288 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
3289 PPC_40x_TLB
| PPC_MEM_TLBIA
| PPC_MEM_TLBSYNC
|
3290 PPC_4xx_COMMON
| PPC_40x_EXCP
;
3291 pcc
->msr_mask
= (1ull << 20) |
3304 pcc
->mmu_model
= POWERPC_MMU_SOFT_4xx_Z
;
3305 pcc
->excp_model
= POWERPC_EXCP_40x
;
3306 pcc
->bus_model
= PPC_FLAGS_INPUT_401
;
3307 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3308 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DE
|
3309 POWERPC_FLAG_BUS_CLK
;
3312 static void init_proc_IOP480 (CPUPPCState
*env
)
3315 gen_spr_401_403(env
);
3317 gen_spr_compress(env
);
3318 /* Memory management */
3319 #if !defined(CONFIG_USER_ONLY)
3323 env
->tlb_type
= TLB_EMB
;
3325 init_excp_4xx_softmmu(env
);
3326 env
->dcache_line_size
= 32;
3327 env
->icache_line_size
= 32;
3328 /* Allocate hardware IRQ controller */
3329 ppc40x_irq_init(env
);
3331 SET_FIT_PERIOD(8, 12, 16, 20);
3332 SET_WDT_PERIOD(16, 20, 24, 28);
3335 POWERPC_FAMILY(IOP480
)(ObjectClass
*oc
, void *data
)
3337 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3338 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3340 dc
->desc
= "IOP480";
3341 pcc
->init_proc
= init_proc_IOP480
;
3342 pcc
->check_pow
= check_pow_nocheck
;
3343 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3344 PPC_DCR
| PPC_WRTEE
|
3345 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_40x_ICBT
|
3346 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3347 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
3348 PPC_40x_TLB
| PPC_MEM_TLBIA
| PPC_MEM_TLBSYNC
|
3349 PPC_4xx_COMMON
| PPC_40x_EXCP
;
3350 pcc
->msr_mask
= (1ull << 20) |
3362 pcc
->mmu_model
= POWERPC_MMU_SOFT_4xx_Z
;
3363 pcc
->excp_model
= POWERPC_EXCP_40x
;
3364 pcc
->bus_model
= PPC_FLAGS_INPUT_401
;
3365 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3366 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DE
|
3367 POWERPC_FLAG_BUS_CLK
;
3370 static void init_proc_403 (CPUPPCState
*env
)
3373 gen_spr_401_403(env
);
3375 gen_spr_403_real(env
);
3376 init_excp_4xx_real(env
);
3377 env
->dcache_line_size
= 32;
3378 env
->icache_line_size
= 32;
3379 /* Allocate hardware IRQ controller */
3380 ppc40x_irq_init(env
);
3382 SET_FIT_PERIOD(8, 12, 16, 20);
3383 SET_WDT_PERIOD(16, 20, 24, 28);
3386 POWERPC_FAMILY(403)(ObjectClass
*oc
, void *data
)
3388 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3389 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3391 dc
->desc
= "PowerPC 403";
3392 pcc
->init_proc
= init_proc_403
;
3393 pcc
->check_pow
= check_pow_nocheck
;
3394 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3395 PPC_DCR
| PPC_WRTEE
|
3396 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_40x_ICBT
|
3398 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
3399 PPC_4xx_COMMON
| PPC_40x_EXCP
;
3400 pcc
->msr_mask
= (1ull << MSR_POW
) |
3409 pcc
->mmu_model
= POWERPC_MMU_REAL
;
3410 pcc
->excp_model
= POWERPC_EXCP_40x
;
3411 pcc
->bus_model
= PPC_FLAGS_INPUT_401
;
3412 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3413 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_PX
|
3414 POWERPC_FLAG_BUS_CLK
;
3417 static void init_proc_403GCX (CPUPPCState
*env
)
3420 gen_spr_401_403(env
);
3422 gen_spr_403_real(env
);
3423 gen_spr_403_mmu(env
);
3424 /* Bus access control */
3425 /* not emulated, as QEMU never does speculative access */
3426 spr_register(env
, SPR_40x_SGR
, "SGR",
3427 SPR_NOACCESS
, SPR_NOACCESS
,
3428 &spr_read_generic
, &spr_write_generic
,
3430 /* not emulated, as QEMU do not emulate caches */
3431 spr_register(env
, SPR_40x_DCWR
, "DCWR",
3432 SPR_NOACCESS
, SPR_NOACCESS
,
3433 &spr_read_generic
, &spr_write_generic
,
3435 /* Memory management */
3436 #if !defined(CONFIG_USER_ONLY)
3440 env
->tlb_type
= TLB_EMB
;
3442 init_excp_4xx_softmmu(env
);
3443 env
->dcache_line_size
= 32;
3444 env
->icache_line_size
= 32;
3445 /* Allocate hardware IRQ controller */
3446 ppc40x_irq_init(env
);
3448 SET_FIT_PERIOD(8, 12, 16, 20);
3449 SET_WDT_PERIOD(16, 20, 24, 28);
3452 POWERPC_FAMILY(403GCX
)(ObjectClass
*oc
, void *data
)
3454 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3455 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3457 dc
->desc
= "PowerPC 403 GCX";
3458 pcc
->init_proc
= init_proc_403GCX
;
3459 pcc
->check_pow
= check_pow_nocheck
;
3460 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3461 PPC_DCR
| PPC_WRTEE
|
3462 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_40x_ICBT
|
3464 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
3465 PPC_40x_TLB
| PPC_MEM_TLBIA
| PPC_MEM_TLBSYNC
|
3466 PPC_4xx_COMMON
| PPC_40x_EXCP
;
3467 pcc
->msr_mask
= (1ull << MSR_POW
) |
3476 pcc
->mmu_model
= POWERPC_MMU_SOFT_4xx_Z
;
3477 pcc
->excp_model
= POWERPC_EXCP_40x
;
3478 pcc
->bus_model
= PPC_FLAGS_INPUT_401
;
3479 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3480 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_PX
|
3481 POWERPC_FLAG_BUS_CLK
;
3484 static void init_proc_405 (CPUPPCState
*env
)
3490 /* Bus access control */
3491 /* not emulated, as QEMU never does speculative access */
3492 spr_register(env
, SPR_40x_SGR
, "SGR",
3493 SPR_NOACCESS
, SPR_NOACCESS
,
3494 &spr_read_generic
, &spr_write_generic
,
3496 /* not emulated, as QEMU do not emulate caches */
3497 spr_register(env
, SPR_40x_DCWR
, "DCWR",
3498 SPR_NOACCESS
, SPR_NOACCESS
,
3499 &spr_read_generic
, &spr_write_generic
,
3501 /* Memory management */
3502 #if !defined(CONFIG_USER_ONLY)
3506 env
->tlb_type
= TLB_EMB
;
3508 init_excp_4xx_softmmu(env
);
3509 env
->dcache_line_size
= 32;
3510 env
->icache_line_size
= 32;
3511 /* Allocate hardware IRQ controller */
3512 ppc40x_irq_init(env
);
3514 SET_FIT_PERIOD(8, 12, 16, 20);
3515 SET_WDT_PERIOD(16, 20, 24, 28);
3518 POWERPC_FAMILY(405)(ObjectClass
*oc
, void *data
)
3520 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3521 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3523 dc
->desc
= "PowerPC 405";
3524 pcc
->init_proc
= init_proc_405
;
3525 pcc
->check_pow
= check_pow_nocheck
;
3526 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
3527 PPC_DCR
| PPC_WRTEE
|
3528 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_40x_ICBT
|
3529 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3530 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
3531 PPC_40x_TLB
| PPC_MEM_TLBIA
| PPC_MEM_TLBSYNC
|
3532 PPC_4xx_COMMON
| PPC_405_MAC
| PPC_40x_EXCP
;
3533 pcc
->msr_mask
= (1ull << MSR_POW
) |
3542 pcc
->mmu_model
= POWERPC_MMU_SOFT_4xx
;
3543 pcc
->excp_model
= POWERPC_EXCP_40x
;
3544 pcc
->bus_model
= PPC_FLAGS_INPUT_405
;
3545 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3546 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
3547 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
3550 static void init_proc_440EP (CPUPPCState
*env
)
3554 gen_spr_BookE(env
, 0x000000000000FFFFULL
);
3556 gen_spr_usprgh(env
);
3557 /* Processor identification */
3558 spr_register(env
, SPR_BOOKE_PIR
, "PIR",
3559 SPR_NOACCESS
, SPR_NOACCESS
,
3560 &spr_read_generic
, &spr_write_pir
,
3562 /* XXX : not implemented */
3563 spr_register(env
, SPR_BOOKE_IAC3
, "IAC3",
3564 SPR_NOACCESS
, SPR_NOACCESS
,
3565 &spr_read_generic
, &spr_write_generic
,
3567 /* XXX : not implemented */
3568 spr_register(env
, SPR_BOOKE_IAC4
, "IAC4",
3569 SPR_NOACCESS
, SPR_NOACCESS
,
3570 &spr_read_generic
, &spr_write_generic
,
3572 /* XXX : not implemented */
3573 spr_register(env
, SPR_BOOKE_DVC1
, "DVC1",
3574 SPR_NOACCESS
, SPR_NOACCESS
,
3575 &spr_read_generic
, &spr_write_generic
,
3577 /* XXX : not implemented */
3578 spr_register(env
, SPR_BOOKE_DVC2
, "DVC2",
3579 SPR_NOACCESS
, SPR_NOACCESS
,
3580 &spr_read_generic
, &spr_write_generic
,
3582 /* XXX : not implemented */
3583 spr_register(env
, SPR_BOOKE_MCSR
, "MCSR",
3584 SPR_NOACCESS
, SPR_NOACCESS
,
3585 &spr_read_generic
, &spr_write_generic
,
3587 spr_register(env
, SPR_BOOKE_MCSRR0
, "MCSRR0",
3588 SPR_NOACCESS
, SPR_NOACCESS
,
3589 &spr_read_generic
, &spr_write_generic
,
3591 spr_register(env
, SPR_BOOKE_MCSRR1
, "MCSRR1",
3592 SPR_NOACCESS
, SPR_NOACCESS
,
3593 &spr_read_generic
, &spr_write_generic
,
3595 /* XXX : not implemented */
3596 spr_register(env
, SPR_440_CCR1
, "CCR1",
3597 SPR_NOACCESS
, SPR_NOACCESS
,
3598 &spr_read_generic
, &spr_write_generic
,
3600 /* Memory management */
3601 #if !defined(CONFIG_USER_ONLY)
3605 env
->tlb_type
= TLB_EMB
;
3607 init_excp_BookE(env
);
3608 env
->dcache_line_size
= 32;
3609 env
->icache_line_size
= 32;
3610 ppc40x_irq_init(env
);
3612 SET_FIT_PERIOD(12, 16, 20, 24);
3613 SET_WDT_PERIOD(20, 24, 28, 32);
3616 POWERPC_FAMILY(440EP
)(ObjectClass
*oc
, void *data
)
3618 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3619 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3621 dc
->desc
= "PowerPC 440 EP";
3622 pcc
->init_proc
= init_proc_440EP
;
3623 pcc
->check_pow
= check_pow_nocheck
;
3624 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3625 PPC_FLOAT
| PPC_FLOAT_FRES
| PPC_FLOAT_FSEL
|
3626 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
3628 PPC_DCR
| PPC_WRTEE
| PPC_RFMCI
|
3629 PPC_CACHE
| PPC_CACHE_ICBI
|
3630 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3631 PPC_MEM_TLBSYNC
| PPC_MFTB
|
3632 PPC_BOOKE
| PPC_4xx_COMMON
| PPC_405_MAC
|
3634 pcc
->msr_mask
= (1ull << MSR_POW
) |
3646 pcc
->mmu_model
= POWERPC_MMU_BOOKE
;
3647 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
3648 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
3649 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3650 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
3651 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
3654 static void init_proc_440GP (CPUPPCState
*env
)
3658 gen_spr_BookE(env
, 0x000000000000FFFFULL
);
3660 gen_spr_usprgh(env
);
3661 /* Processor identification */
3662 spr_register(env
, SPR_BOOKE_PIR
, "PIR",
3663 SPR_NOACCESS
, SPR_NOACCESS
,
3664 &spr_read_generic
, &spr_write_pir
,
3666 /* XXX : not implemented */
3667 spr_register(env
, SPR_BOOKE_IAC3
, "IAC3",
3668 SPR_NOACCESS
, SPR_NOACCESS
,
3669 &spr_read_generic
, &spr_write_generic
,
3671 /* XXX : not implemented */
3672 spr_register(env
, SPR_BOOKE_IAC4
, "IAC4",
3673 SPR_NOACCESS
, SPR_NOACCESS
,
3674 &spr_read_generic
, &spr_write_generic
,
3676 /* XXX : not implemented */
3677 spr_register(env
, SPR_BOOKE_DVC1
, "DVC1",
3678 SPR_NOACCESS
, SPR_NOACCESS
,
3679 &spr_read_generic
, &spr_write_generic
,
3681 /* XXX : not implemented */
3682 spr_register(env
, SPR_BOOKE_DVC2
, "DVC2",
3683 SPR_NOACCESS
, SPR_NOACCESS
,
3684 &spr_read_generic
, &spr_write_generic
,
3686 /* Memory management */
3687 #if !defined(CONFIG_USER_ONLY)
3691 env
->tlb_type
= TLB_EMB
;
3693 init_excp_BookE(env
);
3694 env
->dcache_line_size
= 32;
3695 env
->icache_line_size
= 32;
3696 /* XXX: TODO: allocate internal IRQ controller */
3698 SET_FIT_PERIOD(12, 16, 20, 24);
3699 SET_WDT_PERIOD(20, 24, 28, 32);
3702 POWERPC_FAMILY(440GP
)(ObjectClass
*oc
, void *data
)
3704 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3705 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3707 dc
->desc
= "PowerPC 440 GP";
3708 pcc
->init_proc
= init_proc_440GP
;
3709 pcc
->check_pow
= check_pow_nocheck
;
3710 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3711 PPC_DCR
| PPC_DCRX
| PPC_WRTEE
| PPC_MFAPIDI
|
3712 PPC_CACHE
| PPC_CACHE_ICBI
|
3713 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3714 PPC_MEM_TLBSYNC
| PPC_TLBIVA
| PPC_MFTB
|
3715 PPC_BOOKE
| PPC_4xx_COMMON
| PPC_405_MAC
|
3717 pcc
->msr_mask
= (1ull << MSR_POW
) |
3729 pcc
->mmu_model
= POWERPC_MMU_BOOKE
;
3730 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
3731 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
3732 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3733 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
3734 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
3737 static void init_proc_440x4 (CPUPPCState
*env
)
3741 gen_spr_BookE(env
, 0x000000000000FFFFULL
);
3743 gen_spr_usprgh(env
);
3744 /* Processor identification */
3745 spr_register(env
, SPR_BOOKE_PIR
, "PIR",
3746 SPR_NOACCESS
, SPR_NOACCESS
,
3747 &spr_read_generic
, &spr_write_pir
,
3749 /* XXX : not implemented */
3750 spr_register(env
, SPR_BOOKE_IAC3
, "IAC3",
3751 SPR_NOACCESS
, SPR_NOACCESS
,
3752 &spr_read_generic
, &spr_write_generic
,
3754 /* XXX : not implemented */
3755 spr_register(env
, SPR_BOOKE_IAC4
, "IAC4",
3756 SPR_NOACCESS
, SPR_NOACCESS
,
3757 &spr_read_generic
, &spr_write_generic
,
3759 /* XXX : not implemented */
3760 spr_register(env
, SPR_BOOKE_DVC1
, "DVC1",
3761 SPR_NOACCESS
, SPR_NOACCESS
,
3762 &spr_read_generic
, &spr_write_generic
,
3764 /* XXX : not implemented */
3765 spr_register(env
, SPR_BOOKE_DVC2
, "DVC2",
3766 SPR_NOACCESS
, SPR_NOACCESS
,
3767 &spr_read_generic
, &spr_write_generic
,
3769 /* Memory management */
3770 #if !defined(CONFIG_USER_ONLY)
3774 env
->tlb_type
= TLB_EMB
;
3776 init_excp_BookE(env
);
3777 env
->dcache_line_size
= 32;
3778 env
->icache_line_size
= 32;
3779 /* XXX: TODO: allocate internal IRQ controller */
3781 SET_FIT_PERIOD(12, 16, 20, 24);
3782 SET_WDT_PERIOD(20, 24, 28, 32);
3785 POWERPC_FAMILY(440x4
)(ObjectClass
*oc
, void *data
)
3787 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3788 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3790 dc
->desc
= "PowerPC 440x4";
3791 pcc
->init_proc
= init_proc_440x4
;
3792 pcc
->check_pow
= check_pow_nocheck
;
3793 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3794 PPC_DCR
| PPC_WRTEE
|
3795 PPC_CACHE
| PPC_CACHE_ICBI
|
3796 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3797 PPC_MEM_TLBSYNC
| PPC_MFTB
|
3798 PPC_BOOKE
| PPC_4xx_COMMON
| PPC_405_MAC
|
3800 pcc
->msr_mask
= (1ull << MSR_POW
) |
3812 pcc
->mmu_model
= POWERPC_MMU_BOOKE
;
3813 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
3814 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
3815 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3816 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
3817 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
3820 static void init_proc_440x5 (CPUPPCState
*env
)
3824 gen_spr_BookE(env
, 0x000000000000FFFFULL
);
3826 gen_spr_usprgh(env
);
3827 /* Processor identification */
3828 spr_register(env
, SPR_BOOKE_PIR
, "PIR",
3829 SPR_NOACCESS
, SPR_NOACCESS
,
3830 &spr_read_generic
, &spr_write_pir
,
3832 /* XXX : not implemented */
3833 spr_register(env
, SPR_BOOKE_IAC3
, "IAC3",
3834 SPR_NOACCESS
, SPR_NOACCESS
,
3835 &spr_read_generic
, &spr_write_generic
,
3837 /* XXX : not implemented */
3838 spr_register(env
, SPR_BOOKE_IAC4
, "IAC4",
3839 SPR_NOACCESS
, SPR_NOACCESS
,
3840 &spr_read_generic
, &spr_write_generic
,
3842 /* XXX : not implemented */
3843 spr_register(env
, SPR_BOOKE_DVC1
, "DVC1",
3844 SPR_NOACCESS
, SPR_NOACCESS
,
3845 &spr_read_generic
, &spr_write_generic
,
3847 /* XXX : not implemented */
3848 spr_register(env
, SPR_BOOKE_DVC2
, "DVC2",
3849 SPR_NOACCESS
, SPR_NOACCESS
,
3850 &spr_read_generic
, &spr_write_generic
,
3852 /* XXX : not implemented */
3853 spr_register(env
, SPR_BOOKE_MCSR
, "MCSR",
3854 SPR_NOACCESS
, SPR_NOACCESS
,
3855 &spr_read_generic
, &spr_write_generic
,
3857 spr_register(env
, SPR_BOOKE_MCSRR0
, "MCSRR0",
3858 SPR_NOACCESS
, SPR_NOACCESS
,
3859 &spr_read_generic
, &spr_write_generic
,
3861 spr_register(env
, SPR_BOOKE_MCSRR1
, "MCSRR1",
3862 SPR_NOACCESS
, SPR_NOACCESS
,
3863 &spr_read_generic
, &spr_write_generic
,
3865 /* XXX : not implemented */
3866 spr_register(env
, SPR_440_CCR1
, "CCR1",
3867 SPR_NOACCESS
, SPR_NOACCESS
,
3868 &spr_read_generic
, &spr_write_generic
,
3870 /* Memory management */
3871 #if !defined(CONFIG_USER_ONLY)
3875 env
->tlb_type
= TLB_EMB
;
3877 init_excp_BookE(env
);
3878 env
->dcache_line_size
= 32;
3879 env
->icache_line_size
= 32;
3880 ppc40x_irq_init(env
);
3882 SET_FIT_PERIOD(12, 16, 20, 24);
3883 SET_WDT_PERIOD(20, 24, 28, 32);
3886 POWERPC_FAMILY(440x5
)(ObjectClass
*oc
, void *data
)
3888 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3889 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3891 dc
->desc
= "PowerPC 440x5";
3892 pcc
->init_proc
= init_proc_440x5
;
3893 pcc
->check_pow
= check_pow_nocheck
;
3894 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3895 PPC_DCR
| PPC_WRTEE
| PPC_RFMCI
|
3896 PPC_CACHE
| PPC_CACHE_ICBI
|
3897 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3898 PPC_MEM_TLBSYNC
| PPC_MFTB
|
3899 PPC_BOOKE
| PPC_4xx_COMMON
| PPC_405_MAC
|
3901 pcc
->msr_mask
= (1ull << MSR_POW
) |
3913 pcc
->mmu_model
= POWERPC_MMU_BOOKE
;
3914 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
3915 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
3916 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3917 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
3918 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
3921 POWERPC_FAMILY(440x5wDFPU
)(ObjectClass
*oc
, void *data
)
3923 DeviceClass
*dc
= DEVICE_CLASS(oc
);
3924 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
3926 dc
->desc
= "PowerPC 440x5 with double precision FPU";
3927 pcc
->init_proc
= init_proc_440x5
;
3928 pcc
->check_pow
= check_pow_nocheck
;
3929 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
3930 PPC_FLOAT
| PPC_FLOAT_FSQRT
|
3932 PPC_DCR
| PPC_WRTEE
| PPC_RFMCI
|
3933 PPC_CACHE
| PPC_CACHE_ICBI
|
3934 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
3935 PPC_MEM_TLBSYNC
| PPC_MFTB
|
3936 PPC_BOOKE
| PPC_4xx_COMMON
| PPC_405_MAC
|
3938 pcc
->insns_flags2
= PPC2_FP_CVT_S64
;
3939 pcc
->msr_mask
= (1ull << MSR_POW
) |
3951 pcc
->mmu_model
= POWERPC_MMU_BOOKE
;
3952 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
3953 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
3954 pcc
->bfd_mach
= bfd_mach_ppc_403
;
3955 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
3956 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
3959 static void init_proc_460 (CPUPPCState
*env
)
3963 gen_spr_BookE(env
, 0x000000000000FFFFULL
);
3965 gen_spr_usprgh(env
);
3966 /* Processor identification */
3967 spr_register(env
, SPR_BOOKE_PIR
, "PIR",
3968 SPR_NOACCESS
, SPR_NOACCESS
,
3969 &spr_read_generic
, &spr_write_pir
,
3971 /* XXX : not implemented */
3972 spr_register(env
, SPR_BOOKE_IAC3
, "IAC3",
3973 SPR_NOACCESS
, SPR_NOACCESS
,
3974 &spr_read_generic
, &spr_write_generic
,
3976 /* XXX : not implemented */
3977 spr_register(env
, SPR_BOOKE_IAC4
, "IAC4",
3978 SPR_NOACCESS
, SPR_NOACCESS
,
3979 &spr_read_generic
, &spr_write_generic
,
3981 /* XXX : not implemented */
3982 spr_register(env
, SPR_BOOKE_DVC1
, "DVC1",
3983 SPR_NOACCESS
, SPR_NOACCESS
,
3984 &spr_read_generic
, &spr_write_generic
,
3986 /* XXX : not implemented */
3987 spr_register(env
, SPR_BOOKE_DVC2
, "DVC2",
3988 SPR_NOACCESS
, SPR_NOACCESS
,
3989 &spr_read_generic
, &spr_write_generic
,
3991 /* XXX : not implemented */
3992 spr_register(env
, SPR_BOOKE_MCSR
, "MCSR",
3993 SPR_NOACCESS
, SPR_NOACCESS
,
3994 &spr_read_generic
, &spr_write_generic
,
3996 spr_register(env
, SPR_BOOKE_MCSRR0
, "MCSRR0",
3997 SPR_NOACCESS
, SPR_NOACCESS
,
3998 &spr_read_generic
, &spr_write_generic
,
4000 spr_register(env
, SPR_BOOKE_MCSRR1
, "MCSRR1",
4001 SPR_NOACCESS
, SPR_NOACCESS
,
4002 &spr_read_generic
, &spr_write_generic
,
4004 /* XXX : not implemented */
4005 spr_register(env
, SPR_440_CCR1
, "CCR1",
4006 SPR_NOACCESS
, SPR_NOACCESS
,
4007 &spr_read_generic
, &spr_write_generic
,
4009 /* XXX : not implemented */
4010 spr_register(env
, SPR_DCRIPR
, "SPR_DCRIPR",
4011 &spr_read_generic
, &spr_write_generic
,
4012 &spr_read_generic
, &spr_write_generic
,
4014 /* Memory management */
4015 #if !defined(CONFIG_USER_ONLY)
4019 env
->tlb_type
= TLB_EMB
;
4021 init_excp_BookE(env
);
4022 env
->dcache_line_size
= 32;
4023 env
->icache_line_size
= 32;
4024 /* XXX: TODO: allocate internal IRQ controller */
4026 SET_FIT_PERIOD(12, 16, 20, 24);
4027 SET_WDT_PERIOD(20, 24, 28, 32);
4030 POWERPC_FAMILY(460)(ObjectClass
*oc
, void *data
)
4032 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4033 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4035 dc
->desc
= "PowerPC 460 (guessed)";
4036 pcc
->init_proc
= init_proc_460
;
4037 pcc
->check_pow
= check_pow_nocheck
;
4038 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
4039 PPC_DCR
| PPC_DCRX
| PPC_DCRUX
|
4040 PPC_WRTEE
| PPC_MFAPIDI
| PPC_MFTB
|
4041 PPC_CACHE
| PPC_CACHE_ICBI
|
4042 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
4043 PPC_MEM_TLBSYNC
| PPC_TLBIVA
|
4044 PPC_BOOKE
| PPC_4xx_COMMON
| PPC_405_MAC
|
4046 pcc
->msr_mask
= (1ull << MSR_POW
) |
4058 pcc
->mmu_model
= POWERPC_MMU_BOOKE
;
4059 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
4060 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
4061 pcc
->bfd_mach
= bfd_mach_ppc_403
;
4062 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
4063 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
4066 static void init_proc_460F (CPUPPCState
*env
)
4070 gen_spr_BookE(env
, 0x000000000000FFFFULL
);
4072 gen_spr_usprgh(env
);
4073 /* Processor identification */
4074 spr_register(env
, SPR_BOOKE_PIR
, "PIR",
4075 SPR_NOACCESS
, SPR_NOACCESS
,
4076 &spr_read_generic
, &spr_write_pir
,
4078 /* XXX : not implemented */
4079 spr_register(env
, SPR_BOOKE_IAC3
, "IAC3",
4080 SPR_NOACCESS
, SPR_NOACCESS
,
4081 &spr_read_generic
, &spr_write_generic
,
4083 /* XXX : not implemented */
4084 spr_register(env
, SPR_BOOKE_IAC4
, "IAC4",
4085 SPR_NOACCESS
, SPR_NOACCESS
,
4086 &spr_read_generic
, &spr_write_generic
,
4088 /* XXX : not implemented */
4089 spr_register(env
, SPR_BOOKE_DVC1
, "DVC1",
4090 SPR_NOACCESS
, SPR_NOACCESS
,
4091 &spr_read_generic
, &spr_write_generic
,
4093 /* XXX : not implemented */
4094 spr_register(env
, SPR_BOOKE_DVC2
, "DVC2",
4095 SPR_NOACCESS
, SPR_NOACCESS
,
4096 &spr_read_generic
, &spr_write_generic
,
4098 /* XXX : not implemented */
4099 spr_register(env
, SPR_BOOKE_MCSR
, "MCSR",
4100 SPR_NOACCESS
, SPR_NOACCESS
,
4101 &spr_read_generic
, &spr_write_generic
,
4103 spr_register(env
, SPR_BOOKE_MCSRR0
, "MCSRR0",
4104 SPR_NOACCESS
, SPR_NOACCESS
,
4105 &spr_read_generic
, &spr_write_generic
,
4107 spr_register(env
, SPR_BOOKE_MCSRR1
, "MCSRR1",
4108 SPR_NOACCESS
, SPR_NOACCESS
,
4109 &spr_read_generic
, &spr_write_generic
,
4111 /* XXX : not implemented */
4112 spr_register(env
, SPR_440_CCR1
, "CCR1",
4113 SPR_NOACCESS
, SPR_NOACCESS
,
4114 &spr_read_generic
, &spr_write_generic
,
4116 /* XXX : not implemented */
4117 spr_register(env
, SPR_DCRIPR
, "SPR_DCRIPR",
4118 &spr_read_generic
, &spr_write_generic
,
4119 &spr_read_generic
, &spr_write_generic
,
4121 /* Memory management */
4122 #if !defined(CONFIG_USER_ONLY)
4126 env
->tlb_type
= TLB_EMB
;
4128 init_excp_BookE(env
);
4129 env
->dcache_line_size
= 32;
4130 env
->icache_line_size
= 32;
4131 /* XXX: TODO: allocate internal IRQ controller */
4133 SET_FIT_PERIOD(12, 16, 20, 24);
4134 SET_WDT_PERIOD(20, 24, 28, 32);
4137 POWERPC_FAMILY(460F
)(ObjectClass
*oc
, void *data
)
4139 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4140 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4142 dc
->desc
= "PowerPC 460F (guessed)";
4143 pcc
->init_proc
= init_proc_460F
;
4144 pcc
->check_pow
= check_pow_nocheck
;
4145 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
4146 PPC_FLOAT
| PPC_FLOAT_FRES
| PPC_FLOAT_FSEL
|
4147 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
4148 PPC_FLOAT_STFIWX
| PPC_MFTB
|
4149 PPC_DCR
| PPC_DCRX
| PPC_DCRUX
|
4150 PPC_WRTEE
| PPC_MFAPIDI
|
4151 PPC_CACHE
| PPC_CACHE_ICBI
|
4152 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
4153 PPC_MEM_TLBSYNC
| PPC_TLBIVA
|
4154 PPC_BOOKE
| PPC_4xx_COMMON
| PPC_405_MAC
|
4156 pcc
->msr_mask
= (1ull << MSR_POW
) |
4168 pcc
->mmu_model
= POWERPC_MMU_BOOKE
;
4169 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
4170 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
4171 pcc
->bfd_mach
= bfd_mach_ppc_403
;
4172 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DWE
|
4173 POWERPC_FLAG_DE
| POWERPC_FLAG_BUS_CLK
;
4176 static void init_proc_MPC5xx (CPUPPCState
*env
)
4180 gen_spr_5xx_8xx(env
);
4182 init_excp_MPC5xx(env
);
4183 env
->dcache_line_size
= 32;
4184 env
->icache_line_size
= 32;
4185 /* XXX: TODO: allocate internal IRQ controller */
4188 POWERPC_FAMILY(MPC5xx
)(ObjectClass
*oc
, void *data
)
4190 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4191 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4193 dc
->desc
= "Freescale 5xx cores (aka RCPU)";
4194 pcc
->init_proc
= init_proc_MPC5xx
;
4195 pcc
->check_pow
= check_pow_none
;
4196 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
4197 PPC_MEM_EIEIO
| PPC_MEM_SYNC
|
4198 PPC_CACHE_ICBI
| PPC_FLOAT
| PPC_FLOAT_STFIWX
|
4200 pcc
->msr_mask
= (1ull << MSR_ILE
) |
4212 pcc
->mmu_model
= POWERPC_MMU_REAL
;
4213 pcc
->excp_model
= POWERPC_EXCP_603
;
4214 pcc
->bus_model
= PPC_FLAGS_INPUT_RCPU
;
4215 pcc
->bfd_mach
= bfd_mach_ppc_505
;
4216 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
4217 POWERPC_FLAG_BUS_CLK
;
4220 static void init_proc_MPC8xx (CPUPPCState
*env
)
4224 gen_spr_5xx_8xx(env
);
4226 init_excp_MPC8xx(env
);
4227 env
->dcache_line_size
= 32;
4228 env
->icache_line_size
= 32;
4229 /* XXX: TODO: allocate internal IRQ controller */
4232 POWERPC_FAMILY(MPC8xx
)(ObjectClass
*oc
, void *data
)
4234 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4235 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4237 dc
->desc
= "Freescale 8xx cores (aka PowerQUICC)";
4238 pcc
->init_proc
= init_proc_MPC8xx
;
4239 pcc
->check_pow
= check_pow_none
;
4240 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
|
4241 PPC_MEM_EIEIO
| PPC_MEM_SYNC
|
4242 PPC_CACHE_ICBI
| PPC_MFTB
;
4243 pcc
->msr_mask
= (1ull << MSR_ILE
) |
4255 pcc
->mmu_model
= POWERPC_MMU_MPC8xx
;
4256 pcc
->excp_model
= POWERPC_EXCP_603
;
4257 pcc
->bus_model
= PPC_FLAGS_INPUT_RCPU
;
4258 pcc
->bfd_mach
= bfd_mach_ppc_860
;
4259 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
4260 POWERPC_FLAG_BUS_CLK
;
4263 /* Freescale 82xx cores (aka PowerQUICC-II) */
4265 static void init_proc_G2 (CPUPPCState
*env
)
4267 gen_spr_ne_601(env
);
4268 gen_spr_G2_755(env
);
4272 /* External access control */
4273 /* XXX : not implemented */
4274 spr_register(env
, SPR_EAR
, "EAR",
4275 SPR_NOACCESS
, SPR_NOACCESS
,
4276 &spr_read_generic
, &spr_write_generic
,
4278 /* Hardware implementation register */
4279 /* XXX : not implemented */
4280 spr_register(env
, SPR_HID0
, "HID0",
4281 SPR_NOACCESS
, SPR_NOACCESS
,
4282 &spr_read_generic
, &spr_write_generic
,
4284 /* XXX : not implemented */
4285 spr_register(env
, SPR_HID1
, "HID1",
4286 SPR_NOACCESS
, SPR_NOACCESS
,
4287 &spr_read_generic
, &spr_write_generic
,
4289 /* XXX : not implemented */
4290 spr_register(env
, SPR_HID2
, "HID2",
4291 SPR_NOACCESS
, SPR_NOACCESS
,
4292 &spr_read_generic
, &spr_write_generic
,
4294 /* Memory management */
4297 gen_6xx_7xx_soft_tlb(env
, 64, 2);
4299 env
->dcache_line_size
= 32;
4300 env
->icache_line_size
= 32;
4301 /* Allocate hardware IRQ controller */
4302 ppc6xx_irq_init(env
);
4305 POWERPC_FAMILY(G2
)(ObjectClass
*oc
, void *data
)
4307 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4308 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4310 dc
->desc
= "PowerPC G2";
4311 pcc
->init_proc
= init_proc_G2
;
4312 pcc
->check_pow
= check_pow_hid0
;
4313 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
4314 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
4316 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
4317 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
4318 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
| PPC_6xx_TLB
|
4319 PPC_SEGMENT
| PPC_EXTERN
;
4320 pcc
->msr_mask
= (1ull << MSR_POW
) |
4321 (1ull << MSR_TGPR
) |
4335 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
4336 pcc
->excp_model
= POWERPC_EXCP_G2
;
4337 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
4338 pcc
->bfd_mach
= bfd_mach_ppc_ec603e
;
4339 pcc
->flags
= POWERPC_FLAG_TGPR
| POWERPC_FLAG_SE
|
4340 POWERPC_FLAG_BE
| POWERPC_FLAG_BUS_CLK
;
4343 static void init_proc_G2LE (CPUPPCState
*env
)
4345 gen_spr_ne_601(env
);
4346 gen_spr_G2_755(env
);
4350 /* External access control */
4351 /* XXX : not implemented */
4352 spr_register(env
, SPR_EAR
, "EAR",
4353 SPR_NOACCESS
, SPR_NOACCESS
,
4354 &spr_read_generic
, &spr_write_generic
,
4356 /* Hardware implementation register */
4357 /* XXX : not implemented */
4358 spr_register(env
, SPR_HID0
, "HID0",
4359 SPR_NOACCESS
, SPR_NOACCESS
,
4360 &spr_read_generic
, &spr_write_generic
,
4362 /* XXX : not implemented */
4363 spr_register(env
, SPR_HID1
, "HID1",
4364 SPR_NOACCESS
, SPR_NOACCESS
,
4365 &spr_read_generic
, &spr_write_generic
,
4367 /* XXX : not implemented */
4368 spr_register(env
, SPR_HID2
, "HID2",
4369 SPR_NOACCESS
, SPR_NOACCESS
,
4370 &spr_read_generic
, &spr_write_generic
,
4373 /* Memory management */
4376 gen_6xx_7xx_soft_tlb(env
, 64, 2);
4378 env
->dcache_line_size
= 32;
4379 env
->icache_line_size
= 32;
4380 /* Allocate hardware IRQ controller */
4381 ppc6xx_irq_init(env
);
4384 POWERPC_FAMILY(G2LE
)(ObjectClass
*oc
, void *data
)
4386 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4387 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4389 dc
->desc
= "PowerPC G2LE";
4390 pcc
->init_proc
= init_proc_G2LE
;
4391 pcc
->check_pow
= check_pow_hid0
;
4392 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
4393 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
4395 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
4396 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
4397 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
| PPC_6xx_TLB
|
4398 PPC_SEGMENT
| PPC_EXTERN
;
4399 pcc
->msr_mask
= (1ull << MSR_POW
) |
4400 (1ull << MSR_TGPR
) |
4416 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
4417 pcc
->excp_model
= POWERPC_EXCP_G2
;
4418 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
4419 pcc
->bfd_mach
= bfd_mach_ppc_ec603e
;
4420 pcc
->flags
= POWERPC_FLAG_TGPR
| POWERPC_FLAG_SE
|
4421 POWERPC_FLAG_BE
| POWERPC_FLAG_BUS_CLK
;
4424 static void init_proc_e200 (CPUPPCState
*env
)
4428 gen_spr_BookE(env
, 0x000000070000FFFFULL
);
4429 /* XXX : not implemented */
4430 spr_register(env
, SPR_BOOKE_SPEFSCR
, "SPEFSCR",
4431 &spr_read_spefscr
, &spr_write_spefscr
,
4432 &spr_read_spefscr
, &spr_write_spefscr
,
4434 /* Memory management */
4435 gen_spr_BookE206(env
, 0x0000005D, NULL
);
4436 /* XXX : not implemented */
4437 spr_register(env
, SPR_HID0
, "HID0",
4438 SPR_NOACCESS
, SPR_NOACCESS
,
4439 &spr_read_generic
, &spr_write_generic
,
4441 /* XXX : not implemented */
4442 spr_register(env
, SPR_HID1
, "HID1",
4443 SPR_NOACCESS
, SPR_NOACCESS
,
4444 &spr_read_generic
, &spr_write_generic
,
4446 /* XXX : not implemented */
4447 spr_register(env
, SPR_Exxx_ALTCTXCR
, "ALTCTXCR",
4448 SPR_NOACCESS
, SPR_NOACCESS
,
4449 &spr_read_generic
, &spr_write_generic
,
4451 /* XXX : not implemented */
4452 spr_register(env
, SPR_Exxx_BUCSR
, "BUCSR",
4453 SPR_NOACCESS
, SPR_NOACCESS
,
4454 &spr_read_generic
, &spr_write_generic
,
4456 /* XXX : not implemented */
4457 spr_register(env
, SPR_Exxx_CTXCR
, "CTXCR",
4458 SPR_NOACCESS
, SPR_NOACCESS
,
4459 &spr_read_generic
, &spr_write_generic
,
4461 /* XXX : not implemented */
4462 spr_register(env
, SPR_Exxx_DBCNT
, "DBCNT",
4463 SPR_NOACCESS
, SPR_NOACCESS
,
4464 &spr_read_generic
, &spr_write_generic
,
4466 /* XXX : not implemented */
4467 spr_register(env
, SPR_Exxx_DBCR3
, "DBCR3",
4468 SPR_NOACCESS
, SPR_NOACCESS
,
4469 &spr_read_generic
, &spr_write_generic
,
4471 /* XXX : not implemented */
4472 spr_register(env
, SPR_Exxx_L1CFG0
, "L1CFG0",
4473 &spr_read_generic
, SPR_NOACCESS
,
4474 &spr_read_generic
, SPR_NOACCESS
,
4476 /* XXX : not implemented */
4477 spr_register(env
, SPR_Exxx_L1CSR0
, "L1CSR0",
4478 SPR_NOACCESS
, SPR_NOACCESS
,
4479 &spr_read_generic
, &spr_write_generic
,
4481 /* XXX : not implemented */
4482 spr_register(env
, SPR_Exxx_L1FINV0
, "L1FINV0",
4483 SPR_NOACCESS
, SPR_NOACCESS
,
4484 &spr_read_generic
, &spr_write_generic
,
4486 /* XXX : not implemented */
4487 spr_register(env
, SPR_BOOKE_TLB0CFG
, "TLB0CFG",
4488 SPR_NOACCESS
, SPR_NOACCESS
,
4489 &spr_read_generic
, &spr_write_generic
,
4491 /* XXX : not implemented */
4492 spr_register(env
, SPR_BOOKE_TLB1CFG
, "TLB1CFG",
4493 SPR_NOACCESS
, SPR_NOACCESS
,
4494 &spr_read_generic
, &spr_write_generic
,
4496 /* XXX : not implemented */
4497 spr_register(env
, SPR_BOOKE_IAC3
, "IAC3",
4498 SPR_NOACCESS
, SPR_NOACCESS
,
4499 &spr_read_generic
, &spr_write_generic
,
4501 /* XXX : not implemented */
4502 spr_register(env
, SPR_BOOKE_IAC4
, "IAC4",
4503 SPR_NOACCESS
, SPR_NOACCESS
,
4504 &spr_read_generic
, &spr_write_generic
,
4506 /* XXX : not implemented */
4507 spr_register(env
, SPR_MMUCSR0
, "MMUCSR0",
4508 SPR_NOACCESS
, SPR_NOACCESS
,
4509 &spr_read_generic
, &spr_write_generic
,
4510 0x00000000); /* TOFIX */
4511 spr_register(env
, SPR_BOOKE_DSRR0
, "DSRR0",
4512 SPR_NOACCESS
, SPR_NOACCESS
,
4513 &spr_read_generic
, &spr_write_generic
,
4515 spr_register(env
, SPR_BOOKE_DSRR1
, "DSRR1",
4516 SPR_NOACCESS
, SPR_NOACCESS
,
4517 &spr_read_generic
, &spr_write_generic
,
4519 #if !defined(CONFIG_USER_ONLY)
4523 env
->tlb_type
= TLB_EMB
;
4525 init_excp_e200(env
, 0xFFFF0000UL
);
4526 env
->dcache_line_size
= 32;
4527 env
->icache_line_size
= 32;
4528 /* XXX: TODO: allocate internal IRQ controller */
4531 POWERPC_FAMILY(e200
)(ObjectClass
*oc
, void *data
)
4533 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4534 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4536 dc
->desc
= "e200 core";
4537 pcc
->init_proc
= init_proc_e200
;
4538 pcc
->check_pow
= check_pow_hid0
;
4539 /* XXX: unimplemented instructions:
4546 * all SPE multiply-accumulate instructions
4548 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_ISEL
|
4549 PPC_SPE
| PPC_SPE_SINGLE
|
4550 PPC_WRTEE
| PPC_RFDI
|
4551 PPC_CACHE
| PPC_CACHE_LOCK
| PPC_CACHE_ICBI
|
4552 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
4553 PPC_MEM_TLBSYNC
| PPC_TLBIVAX
|
4555 pcc
->msr_mask
= (1ull << MSR_UCLE
) |
4569 pcc
->mmu_model
= POWERPC_MMU_BOOKE206
;
4570 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
4571 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
4572 pcc
->bfd_mach
= bfd_mach_ppc_860
;
4573 pcc
->flags
= POWERPC_FLAG_SPE
| POWERPC_FLAG_CE
|
4574 POWERPC_FLAG_UBLE
| POWERPC_FLAG_DE
|
4575 POWERPC_FLAG_BUS_CLK
;
4578 static void init_proc_e300 (CPUPPCState
*env
)
4580 gen_spr_ne_601(env
);
4584 /* hardware implementation registers */
4585 /* XXX : not implemented */
4586 spr_register(env
, SPR_HID0
, "HID0",
4587 SPR_NOACCESS
, SPR_NOACCESS
,
4588 &spr_read_generic
, &spr_write_generic
,
4590 /* XXX : not implemented */
4591 spr_register(env
, SPR_HID1
, "HID1",
4592 SPR_NOACCESS
, SPR_NOACCESS
,
4593 &spr_read_generic
, &spr_write_generic
,
4595 /* XXX : not implemented */
4596 spr_register(env
, SPR_HID2
, "HID2",
4597 SPR_NOACCESS
, SPR_NOACCESS
,
4598 &spr_read_generic
, &spr_write_generic
,
4601 /* XXX : not implemented */
4602 spr_register(env
, SPR_DABR
, "DABR",
4603 SPR_NOACCESS
, SPR_NOACCESS
,
4604 &spr_read_generic
, &spr_write_generic
,
4606 /* XXX : not implemented */
4607 spr_register(env
, SPR_DABR2
, "DABR2",
4608 SPR_NOACCESS
, SPR_NOACCESS
,
4609 &spr_read_generic
, &spr_write_generic
,
4611 /* XXX : not implemented */
4612 spr_register(env
, SPR_IABR2
, "IABR2",
4613 SPR_NOACCESS
, SPR_NOACCESS
,
4614 &spr_read_generic
, &spr_write_generic
,
4616 /* XXX : not implemented */
4617 spr_register(env
, SPR_IBCR
, "IBCR",
4618 SPR_NOACCESS
, SPR_NOACCESS
,
4619 &spr_read_generic
, &spr_write_generic
,
4621 /* XXX : not implemented */
4622 spr_register(env
, SPR_DBCR
, "DBCR",
4623 SPR_NOACCESS
, SPR_NOACCESS
,
4624 &spr_read_generic
, &spr_write_generic
,
4626 /* Memory management */
4629 gen_6xx_7xx_soft_tlb(env
, 64, 2);
4631 env
->dcache_line_size
= 32;
4632 env
->icache_line_size
= 32;
4633 /* Allocate hardware IRQ controller */
4634 ppc6xx_irq_init(env
);
4637 POWERPC_FAMILY(e300
)(ObjectClass
*oc
, void *data
)
4639 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4640 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4642 dc
->desc
= "e300 core";
4643 pcc
->init_proc
= init_proc_e300
;
4644 pcc
->check_pow
= check_pow_hid0
;
4645 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
4646 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
4648 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
4649 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
4650 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
| PPC_6xx_TLB
|
4651 PPC_SEGMENT
| PPC_EXTERN
;
4652 pcc
->msr_mask
= (1ull << MSR_POW
) |
4653 (1ull << MSR_TGPR
) |
4669 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
4670 pcc
->excp_model
= POWERPC_EXCP_603
;
4671 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
4672 pcc
->bfd_mach
= bfd_mach_ppc_603
;
4673 pcc
->flags
= POWERPC_FLAG_TGPR
| POWERPC_FLAG_SE
|
4674 POWERPC_FLAG_BE
| POWERPC_FLAG_BUS_CLK
;
4677 #if !defined(CONFIG_USER_ONLY)
4678 static void spr_write_mas73(DisasContext
*ctx
, int sprn
, int gprn
)
4680 TCGv val
= tcg_temp_new();
4681 tcg_gen_ext32u_tl(val
, cpu_gpr
[gprn
]);
4682 gen_store_spr(SPR_BOOKE_MAS3
, val
);
4683 tcg_gen_shri_tl(val
, cpu_gpr
[gprn
], 32);
4684 gen_store_spr(SPR_BOOKE_MAS7
, val
);
4688 static void spr_read_mas73(DisasContext
*ctx
, int gprn
, int sprn
)
4690 TCGv mas7
= tcg_temp_new();
4691 TCGv mas3
= tcg_temp_new();
4692 gen_load_spr(mas7
, SPR_BOOKE_MAS7
);
4693 tcg_gen_shli_tl(mas7
, mas7
, 32);
4694 gen_load_spr(mas3
, SPR_BOOKE_MAS3
);
4695 tcg_gen_or_tl(cpu_gpr
[gprn
], mas3
, mas7
);
4696 tcg_temp_free(mas3
);
4697 tcg_temp_free(mas7
);
4702 enum fsl_e500_version
{
4709 static void init_proc_e500 (CPUPPCState
*env
, int version
)
4711 PowerPCCPU
*cpu
= ppc_env_get_cpu(env
);
4712 uint32_t tlbncfg
[2];
4714 uint64_t ivpr_mask
= 0xFFFF0000ULL
;
4715 uint32_t l1cfg0
= 0x3800 /* 8 ways */
4716 | 0x0020; /* 32 kb */
4717 uint32_t l1cfg1
= 0x3800 /* 8 ways */
4718 | 0x0020; /* 32 kb */
4719 #if !defined(CONFIG_USER_ONLY)
4726 * XXX The e500 doesn't implement IVOR7 and IVOR9, but doesn't
4727 * complain when accessing them.
4728 * gen_spr_BookE(env, 0x0000000F0000FD7FULL);
4734 ivor_mask
= 0x0000000F0000FFFFULL
;
4738 ivor_mask
= 0x000003FE0000FFFFULL
;
4741 gen_spr_BookE(env
, ivor_mask
);
4742 /* Processor identification */
4743 spr_register(env
, SPR_BOOKE_PIR
, "PIR",
4744 SPR_NOACCESS
, SPR_NOACCESS
,
4745 &spr_read_generic
, &spr_write_pir
,
4747 /* XXX : not implemented */
4748 spr_register(env
, SPR_BOOKE_SPEFSCR
, "SPEFSCR",
4749 &spr_read_spefscr
, &spr_write_spefscr
,
4750 &spr_read_spefscr
, &spr_write_spefscr
,
4752 #if !defined(CONFIG_USER_ONLY)
4753 /* Memory management */
4759 tlbncfg
[0] = gen_tlbncfg(2, 1, 1, 0, 256);
4760 tlbncfg
[1] = gen_tlbncfg(16, 1, 9, TLBnCFG_AVAIL
| TLBnCFG_IPROT
, 16);
4763 tlbncfg
[0] = gen_tlbncfg(4, 1, 1, 0, 512);
4764 tlbncfg
[1] = gen_tlbncfg(16, 1, 12, TLBnCFG_AVAIL
| TLBnCFG_IPROT
, 16);
4768 tlbncfg
[0] = gen_tlbncfg(4, 1, 1, 0, 512);
4769 tlbncfg
[1] = gen_tlbncfg(64, 1, 12, TLBnCFG_AVAIL
| TLBnCFG_IPROT
, 64);
4772 cpu_abort(CPU(cpu
), "Unknown CPU: " TARGET_FMT_lx
"\n", env
->spr
[SPR_PVR
]);
4779 env
->dcache_line_size
= 32;
4780 env
->icache_line_size
= 32;
4784 env
->dcache_line_size
= 64;
4785 env
->icache_line_size
= 64;
4786 l1cfg0
|= 0x1000000; /* 64 byte cache block size */
4787 l1cfg1
|= 0x1000000; /* 64 byte cache block size */
4790 cpu_abort(CPU(cpu
), "Unknown CPU: " TARGET_FMT_lx
"\n", env
->spr
[SPR_PVR
]);
4792 gen_spr_BookE206(env
, 0x000000DF, tlbncfg
);
4793 /* XXX : not implemented */
4794 spr_register(env
, SPR_HID0
, "HID0",
4795 SPR_NOACCESS
, SPR_NOACCESS
,
4796 &spr_read_generic
, &spr_write_generic
,
4798 /* XXX : not implemented */
4799 spr_register(env
, SPR_HID1
, "HID1",
4800 SPR_NOACCESS
, SPR_NOACCESS
,
4801 &spr_read_generic
, &spr_write_generic
,
4803 /* XXX : not implemented */
4804 spr_register(env
, SPR_Exxx_BBEAR
, "BBEAR",
4805 SPR_NOACCESS
, SPR_NOACCESS
,
4806 &spr_read_generic
, &spr_write_generic
,
4808 /* XXX : not implemented */
4809 spr_register(env
, SPR_Exxx_BBTAR
, "BBTAR",
4810 SPR_NOACCESS
, SPR_NOACCESS
,
4811 &spr_read_generic
, &spr_write_generic
,
4813 /* XXX : not implemented */
4814 spr_register(env
, SPR_Exxx_MCAR
, "MCAR",
4815 SPR_NOACCESS
, SPR_NOACCESS
,
4816 &spr_read_generic
, &spr_write_generic
,
4818 /* XXX : not implemented */
4819 spr_register(env
, SPR_BOOKE_MCSR
, "MCSR",
4820 SPR_NOACCESS
, SPR_NOACCESS
,
4821 &spr_read_generic
, &spr_write_generic
,
4823 /* XXX : not implemented */
4824 spr_register(env
, SPR_Exxx_NPIDR
, "NPIDR",
4825 SPR_NOACCESS
, SPR_NOACCESS
,
4826 &spr_read_generic
, &spr_write_generic
,
4828 /* XXX : not implemented */
4829 spr_register(env
, SPR_Exxx_BUCSR
, "BUCSR",
4830 SPR_NOACCESS
, SPR_NOACCESS
,
4831 &spr_read_generic
, &spr_write_generic
,
4833 /* XXX : not implemented */
4834 spr_register(env
, SPR_Exxx_L1CFG0
, "L1CFG0",
4835 &spr_read_generic
, SPR_NOACCESS
,
4836 &spr_read_generic
, SPR_NOACCESS
,
4838 spr_register(env
, SPR_Exxx_L1CFG1
, "L1CFG1",
4839 &spr_read_generic
, SPR_NOACCESS
,
4840 &spr_read_generic
, SPR_NOACCESS
,
4842 spr_register(env
, SPR_Exxx_L1CSR0
, "L1CSR0",
4843 SPR_NOACCESS
, SPR_NOACCESS
,
4844 &spr_read_generic
, &spr_write_e500_l1csr0
,
4846 spr_register(env
, SPR_Exxx_L1CSR1
, "L1CSR1",
4847 SPR_NOACCESS
, SPR_NOACCESS
,
4848 &spr_read_generic
, &spr_write_e500_l1csr1
,
4850 spr_register(env
, SPR_BOOKE_MCSRR0
, "MCSRR0",
4851 SPR_NOACCESS
, SPR_NOACCESS
,
4852 &spr_read_generic
, &spr_write_generic
,
4854 spr_register(env
, SPR_BOOKE_MCSRR1
, "MCSRR1",
4855 SPR_NOACCESS
, SPR_NOACCESS
,
4856 &spr_read_generic
, &spr_write_generic
,
4858 spr_register(env
, SPR_MMUCSR0
, "MMUCSR0",
4859 SPR_NOACCESS
, SPR_NOACCESS
,
4860 &spr_read_generic
, &spr_write_booke206_mmucsr0
,
4862 spr_register(env
, SPR_BOOKE_EPR
, "EPR",
4863 SPR_NOACCESS
, SPR_NOACCESS
,
4864 &spr_read_generic
, SPR_NOACCESS
,
4866 /* XXX better abstract into Emb.xxx features */
4867 if (version
== fsl_e5500
) {
4868 spr_register(env
, SPR_BOOKE_EPCR
, "EPCR",
4869 SPR_NOACCESS
, SPR_NOACCESS
,
4870 &spr_read_generic
, &spr_write_generic
,
4872 spr_register(env
, SPR_BOOKE_MAS7_MAS3
, "MAS7_MAS3",
4873 SPR_NOACCESS
, SPR_NOACCESS
,
4874 &spr_read_mas73
, &spr_write_mas73
,
4876 ivpr_mask
= (target_ulong
)~0xFFFFULL
;
4879 #if !defined(CONFIG_USER_ONLY)
4881 env
->tlb_type
= TLB_MAS
;
4882 for (i
= 0; i
< BOOKE206_MAX_TLBN
; i
++) {
4883 env
->nb_tlb
+= booke206_tlb_size(env
, i
);
4887 init_excp_e200(env
, ivpr_mask
);
4888 /* Allocate hardware IRQ controller */
4889 ppce500_irq_init(env
);
4892 static void init_proc_e500v1(CPUPPCState
*env
)
4894 init_proc_e500(env
, fsl_e500v1
);
4897 POWERPC_FAMILY(e500v1
)(ObjectClass
*oc
, void *data
)
4899 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4900 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4902 dc
->desc
= "e500v1 core";
4903 pcc
->init_proc
= init_proc_e500v1
;
4904 pcc
->check_pow
= check_pow_hid0
;
4905 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_ISEL
|
4906 PPC_SPE
| PPC_SPE_SINGLE
|
4907 PPC_WRTEE
| PPC_RFDI
|
4908 PPC_CACHE
| PPC_CACHE_LOCK
| PPC_CACHE_ICBI
|
4909 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
4910 PPC_MEM_TLBSYNC
| PPC_TLBIVAX
| PPC_MEM_SYNC
;
4911 pcc
->insns_flags2
= PPC2_BOOKE206
;
4912 pcc
->msr_mask
= (1ull << MSR_UCLE
) |
4926 pcc
->mmu_model
= POWERPC_MMU_BOOKE206
;
4927 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
4928 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
4929 pcc
->bfd_mach
= bfd_mach_ppc_860
;
4930 pcc
->flags
= POWERPC_FLAG_SPE
| POWERPC_FLAG_CE
|
4931 POWERPC_FLAG_UBLE
| POWERPC_FLAG_DE
|
4932 POWERPC_FLAG_BUS_CLK
;
4935 static void init_proc_e500v2(CPUPPCState
*env
)
4937 init_proc_e500(env
, fsl_e500v2
);
4940 POWERPC_FAMILY(e500v2
)(ObjectClass
*oc
, void *data
)
4942 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4943 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4945 dc
->desc
= "e500v2 core";
4946 pcc
->init_proc
= init_proc_e500v2
;
4947 pcc
->check_pow
= check_pow_hid0
;
4948 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_ISEL
|
4949 PPC_SPE
| PPC_SPE_SINGLE
| PPC_SPE_DOUBLE
|
4950 PPC_WRTEE
| PPC_RFDI
|
4951 PPC_CACHE
| PPC_CACHE_LOCK
| PPC_CACHE_ICBI
|
4952 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
4953 PPC_MEM_TLBSYNC
| PPC_TLBIVAX
| PPC_MEM_SYNC
;
4954 pcc
->insns_flags2
= PPC2_BOOKE206
;
4955 pcc
->msr_mask
= (1ull << MSR_UCLE
) |
4969 pcc
->mmu_model
= POWERPC_MMU_BOOKE206
;
4970 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
4971 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
4972 pcc
->bfd_mach
= bfd_mach_ppc_860
;
4973 pcc
->flags
= POWERPC_FLAG_SPE
| POWERPC_FLAG_CE
|
4974 POWERPC_FLAG_UBLE
| POWERPC_FLAG_DE
|
4975 POWERPC_FLAG_BUS_CLK
;
4978 static void init_proc_e500mc(CPUPPCState
*env
)
4980 init_proc_e500(env
, fsl_e500mc
);
4983 POWERPC_FAMILY(e500mc
)(ObjectClass
*oc
, void *data
)
4985 DeviceClass
*dc
= DEVICE_CLASS(oc
);
4986 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
4988 dc
->desc
= "e500mc core";
4989 pcc
->init_proc
= init_proc_e500mc
;
4990 pcc
->check_pow
= check_pow_none
;
4991 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_ISEL
|
4992 PPC_WRTEE
| PPC_RFDI
| PPC_RFMCI
|
4993 PPC_CACHE
| PPC_CACHE_LOCK
| PPC_CACHE_ICBI
|
4994 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
4995 PPC_FLOAT
| PPC_FLOAT_FRES
|
4996 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_FSEL
|
4997 PPC_FLOAT_STFIWX
| PPC_WAIT
|
4998 PPC_MEM_TLBSYNC
| PPC_TLBIVAX
| PPC_MEM_SYNC
;
4999 pcc
->insns_flags2
= PPC2_BOOKE206
| PPC2_PRCNTL
;
5000 pcc
->msr_mask
= (1ull << MSR_GS
) |
5001 (1ull << MSR_UCLE
) |
5014 pcc
->mmu_model
= POWERPC_MMU_BOOKE206
;
5015 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
5016 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
5017 /* FIXME: figure out the correct flag for e500mc */
5018 pcc
->bfd_mach
= bfd_mach_ppc_e500
;
5019 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DE
|
5020 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5024 static void init_proc_e5500(CPUPPCState
*env
)
5026 init_proc_e500(env
, fsl_e5500
);
5029 POWERPC_FAMILY(e5500
)(ObjectClass
*oc
, void *data
)
5031 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5032 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5034 dc
->desc
= "e5500 core";
5035 pcc
->init_proc
= init_proc_e5500
;
5036 pcc
->check_pow
= check_pow_none
;
5037 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_ISEL
|
5038 PPC_WRTEE
| PPC_RFDI
| PPC_RFMCI
|
5039 PPC_CACHE
| PPC_CACHE_LOCK
| PPC_CACHE_ICBI
|
5040 PPC_CACHE_DCBZ
| PPC_CACHE_DCBA
|
5041 PPC_FLOAT
| PPC_FLOAT_FRES
|
5042 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_FSEL
|
5043 PPC_FLOAT_STFIWX
| PPC_WAIT
|
5044 PPC_MEM_TLBSYNC
| PPC_TLBIVAX
| PPC_MEM_SYNC
|
5045 PPC_64B
| PPC_POPCNTB
| PPC_POPCNTWD
;
5046 pcc
->insns_flags2
= PPC2_BOOKE206
| PPC2_PRCNTL
| PPC2_PERM_ISA206
| \
5048 pcc
->msr_mask
= (1ull << MSR_CM
) |
5050 (1ull << MSR_UCLE
) |
5063 pcc
->mmu_model
= POWERPC_MMU_BOOKE206
;
5064 pcc
->excp_model
= POWERPC_EXCP_BOOKE
;
5065 pcc
->bus_model
= PPC_FLAGS_INPUT_BookE
;
5066 /* FIXME: figure out the correct flag for e5500 */
5067 pcc
->bfd_mach
= bfd_mach_ppc_e500
;
5068 pcc
->flags
= POWERPC_FLAG_CE
| POWERPC_FLAG_DE
|
5069 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5073 /* Non-embedded PowerPC */
5075 /* POWER : same as 601, without mfmsr, mfsr */
5076 POWERPC_FAMILY(POWER
)(ObjectClass
*oc
, void *data
)
5078 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5079 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5082 /* pcc->insns_flags = XXX_TODO; */
5083 /* POWER RSC (from RAD6000) */
5084 pcc
->msr_mask
= (1ull << MSR_EE
) |
5097 #define POWERPC_MSRR_601 (0x0000000000001040ULL)
5099 static void init_proc_601 (CPUPPCState
*env
)
5101 gen_spr_ne_601(env
);
5103 /* Hardware implementation registers */
5104 /* XXX : not implemented */
5105 spr_register(env
, SPR_HID0
, "HID0",
5106 SPR_NOACCESS
, SPR_NOACCESS
,
5107 &spr_read_generic
, &spr_write_hid0_601
,
5109 /* XXX : not implemented */
5110 spr_register(env
, SPR_HID1
, "HID1",
5111 SPR_NOACCESS
, SPR_NOACCESS
,
5112 &spr_read_generic
, &spr_write_generic
,
5114 /* XXX : not implemented */
5115 spr_register(env
, SPR_601_HID2
, "HID2",
5116 SPR_NOACCESS
, SPR_NOACCESS
,
5117 &spr_read_generic
, &spr_write_generic
,
5119 /* XXX : not implemented */
5120 spr_register(env
, SPR_601_HID5
, "HID5",
5121 SPR_NOACCESS
, SPR_NOACCESS
,
5122 &spr_read_generic
, &spr_write_generic
,
5124 /* Memory management */
5126 /* XXX: beware that dcache line size is 64
5127 * but dcbz uses 32 bytes "sectors"
5128 * XXX: this breaks clcs instruction !
5130 env
->dcache_line_size
= 32;
5131 env
->icache_line_size
= 64;
5132 /* Allocate hardware IRQ controller */
5133 ppc6xx_irq_init(env
);
5136 POWERPC_FAMILY(601)(ObjectClass
*oc
, void *data
)
5138 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5139 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5141 dc
->desc
= "PowerPC 601";
5142 pcc
->init_proc
= init_proc_601
;
5143 pcc
->check_pow
= check_pow_none
;
5144 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_POWER_BR
|
5146 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5147 PPC_MEM_SYNC
| PPC_MEM_EIEIO
| PPC_MEM_TLBIE
|
5148 PPC_SEGMENT
| PPC_EXTERN
;
5149 pcc
->msr_mask
= (1ull << MSR_EE
) |
5159 pcc
->mmu_model
= POWERPC_MMU_601
;
5160 #if defined(CONFIG_SOFTMMU)
5161 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5163 pcc
->excp_model
= POWERPC_EXCP_601
;
5164 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5165 pcc
->bfd_mach
= bfd_mach_ppc_601
;
5166 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_RTC_CLK
;
5169 #define POWERPC_MSRR_601v (0x0000000000001040ULL)
5171 static void init_proc_601v (CPUPPCState
*env
)
5174 /* XXX : not implemented */
5175 spr_register(env
, SPR_601_HID15
, "HID15",
5176 SPR_NOACCESS
, SPR_NOACCESS
,
5177 &spr_read_generic
, &spr_write_generic
,
5181 POWERPC_FAMILY(601v
)(ObjectClass
*oc
, void *data
)
5183 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5184 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5186 dc
->desc
= "PowerPC 601v";
5187 pcc
->init_proc
= init_proc_601v
;
5188 pcc
->check_pow
= check_pow_none
;
5189 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_POWER_BR
|
5191 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5192 PPC_MEM_SYNC
| PPC_MEM_EIEIO
| PPC_MEM_TLBIE
|
5193 PPC_SEGMENT
| PPC_EXTERN
;
5194 pcc
->msr_mask
= (1ull << MSR_EE
) |
5204 pcc
->mmu_model
= POWERPC_MMU_601
;
5205 #if defined(CONFIG_SOFTMMU)
5206 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5208 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5209 pcc
->bfd_mach
= bfd_mach_ppc_601
;
5210 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_RTC_CLK
;
5213 static void init_proc_602 (CPUPPCState
*env
)
5215 gen_spr_ne_601(env
);
5219 /* hardware implementation registers */
5220 /* XXX : not implemented */
5221 spr_register(env
, SPR_HID0
, "HID0",
5222 SPR_NOACCESS
, SPR_NOACCESS
,
5223 &spr_read_generic
, &spr_write_generic
,
5225 /* XXX : not implemented */
5226 spr_register(env
, SPR_HID1
, "HID1",
5227 SPR_NOACCESS
, SPR_NOACCESS
,
5228 &spr_read_generic
, &spr_write_generic
,
5230 /* Memory management */
5232 gen_6xx_7xx_soft_tlb(env
, 64, 2);
5234 env
->dcache_line_size
= 32;
5235 env
->icache_line_size
= 32;
5236 /* Allocate hardware IRQ controller */
5237 ppc6xx_irq_init(env
);
5240 POWERPC_FAMILY(602)(ObjectClass
*oc
, void *data
)
5242 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5243 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5245 dc
->desc
= "PowerPC 602";
5246 pcc
->init_proc
= init_proc_602
;
5247 pcc
->check_pow
= check_pow_hid0
;
5248 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5249 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5250 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5251 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5252 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5253 PPC_MEM_TLBIE
| PPC_6xx_TLB
| PPC_MEM_TLBSYNC
|
5254 PPC_SEGMENT
| PPC_602_SPEC
;
5255 pcc
->msr_mask
= (1ull << MSR_VSX
) |
5258 (1ull << MSR_TGPR
) |
5273 /* XXX: 602 MMU is quite specific. Should add a special case */
5274 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
5275 pcc
->excp_model
= POWERPC_EXCP_602
;
5276 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5277 pcc
->bfd_mach
= bfd_mach_ppc_602
;
5278 pcc
->flags
= POWERPC_FLAG_TGPR
| POWERPC_FLAG_SE
|
5279 POWERPC_FLAG_BE
| POWERPC_FLAG_BUS_CLK
;
5282 static void init_proc_603 (CPUPPCState
*env
)
5284 gen_spr_ne_601(env
);
5288 /* hardware implementation registers */
5289 /* XXX : not implemented */
5290 spr_register(env
, SPR_HID0
, "HID0",
5291 SPR_NOACCESS
, SPR_NOACCESS
,
5292 &spr_read_generic
, &spr_write_generic
,
5294 /* XXX : not implemented */
5295 spr_register(env
, SPR_HID1
, "HID1",
5296 SPR_NOACCESS
, SPR_NOACCESS
,
5297 &spr_read_generic
, &spr_write_generic
,
5299 /* Memory management */
5301 gen_6xx_7xx_soft_tlb(env
, 64, 2);
5303 env
->dcache_line_size
= 32;
5304 env
->icache_line_size
= 32;
5305 /* Allocate hardware IRQ controller */
5306 ppc6xx_irq_init(env
);
5309 POWERPC_FAMILY(603)(ObjectClass
*oc
, void *data
)
5311 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5312 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5314 dc
->desc
= "PowerPC 603";
5315 pcc
->init_proc
= init_proc_603
;
5316 pcc
->check_pow
= check_pow_hid0
;
5317 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5318 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5319 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5320 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5321 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5322 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
| PPC_6xx_TLB
|
5323 PPC_SEGMENT
| PPC_EXTERN
;
5324 pcc
->msr_mask
= (1ull << MSR_POW
) |
5325 (1ull << MSR_TGPR
) |
5340 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
5341 pcc
->excp_model
= POWERPC_EXCP_603
;
5342 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5343 pcc
->bfd_mach
= bfd_mach_ppc_603
;
5344 pcc
->flags
= POWERPC_FLAG_TGPR
| POWERPC_FLAG_SE
|
5345 POWERPC_FLAG_BE
| POWERPC_FLAG_BUS_CLK
;
5348 static void init_proc_603E (CPUPPCState
*env
)
5350 gen_spr_ne_601(env
);
5354 /* hardware implementation registers */
5355 /* XXX : not implemented */
5356 spr_register(env
, SPR_HID0
, "HID0",
5357 SPR_NOACCESS
, SPR_NOACCESS
,
5358 &spr_read_generic
, &spr_write_generic
,
5360 /* XXX : not implemented */
5361 spr_register(env
, SPR_HID1
, "HID1",
5362 SPR_NOACCESS
, SPR_NOACCESS
,
5363 &spr_read_generic
, &spr_write_generic
,
5365 /* Memory management */
5367 gen_6xx_7xx_soft_tlb(env
, 64, 2);
5369 env
->dcache_line_size
= 32;
5370 env
->icache_line_size
= 32;
5371 /* Allocate hardware IRQ controller */
5372 ppc6xx_irq_init(env
);
5375 POWERPC_FAMILY(603E
)(ObjectClass
*oc
, void *data
)
5377 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5378 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5380 dc
->desc
= "PowerPC 603e";
5381 pcc
->init_proc
= init_proc_603E
;
5382 pcc
->check_pow
= check_pow_hid0
;
5383 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5384 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5385 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5386 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5387 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5388 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
| PPC_6xx_TLB
|
5389 PPC_SEGMENT
| PPC_EXTERN
;
5390 pcc
->msr_mask
= (1ull << MSR_POW
) |
5391 (1ull << MSR_TGPR
) |
5406 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
5407 pcc
->excp_model
= POWERPC_EXCP_603E
;
5408 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5409 pcc
->bfd_mach
= bfd_mach_ppc_ec603e
;
5410 pcc
->flags
= POWERPC_FLAG_TGPR
| POWERPC_FLAG_SE
|
5411 POWERPC_FLAG_BE
| POWERPC_FLAG_BUS_CLK
;
5414 static void init_proc_604 (CPUPPCState
*env
)
5416 gen_spr_ne_601(env
);
5420 /* Hardware implementation registers */
5421 /* XXX : not implemented */
5422 spr_register(env
, SPR_HID0
, "HID0",
5423 SPR_NOACCESS
, SPR_NOACCESS
,
5424 &spr_read_generic
, &spr_write_generic
,
5426 /* Memory management */
5429 env
->dcache_line_size
= 32;
5430 env
->icache_line_size
= 32;
5431 /* Allocate hardware IRQ controller */
5432 ppc6xx_irq_init(env
);
5435 POWERPC_FAMILY(604)(ObjectClass
*oc
, void *data
)
5437 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5438 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5440 dc
->desc
= "PowerPC 604";
5441 pcc
->init_proc
= init_proc_604
;
5442 pcc
->check_pow
= check_pow_nocheck
;
5443 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5444 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5445 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5446 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5447 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5448 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
5449 PPC_SEGMENT
| PPC_EXTERN
;
5450 pcc
->msr_mask
= (1ull << MSR_POW
) |
5466 pcc
->mmu_model
= POWERPC_MMU_32B
;
5467 #if defined(CONFIG_SOFTMMU)
5468 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5470 pcc
->excp_model
= POWERPC_EXCP_604
;
5471 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5472 pcc
->bfd_mach
= bfd_mach_ppc_604
;
5473 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
5474 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5477 static void init_proc_604E (CPUPPCState
*env
)
5479 gen_spr_ne_601(env
);
5481 /* XXX : not implemented */
5482 spr_register(env
, SPR_7XX_MMCR1
, "MMCR1",
5483 SPR_NOACCESS
, SPR_NOACCESS
,
5484 &spr_read_generic
, &spr_write_generic
,
5486 /* XXX : not implemented */
5487 spr_register(env
, SPR_7XX_PMC3
, "PMC3",
5488 SPR_NOACCESS
, SPR_NOACCESS
,
5489 &spr_read_generic
, &spr_write_generic
,
5491 /* XXX : not implemented */
5492 spr_register(env
, SPR_7XX_PMC4
, "PMC4",
5493 SPR_NOACCESS
, SPR_NOACCESS
,
5494 &spr_read_generic
, &spr_write_generic
,
5498 /* Hardware implementation registers */
5499 /* XXX : not implemented */
5500 spr_register(env
, SPR_HID0
, "HID0",
5501 SPR_NOACCESS
, SPR_NOACCESS
,
5502 &spr_read_generic
, &spr_write_generic
,
5504 /* XXX : not implemented */
5505 spr_register(env
, SPR_HID1
, "HID1",
5506 SPR_NOACCESS
, SPR_NOACCESS
,
5507 &spr_read_generic
, &spr_write_generic
,
5509 /* Memory management */
5512 env
->dcache_line_size
= 32;
5513 env
->icache_line_size
= 32;
5514 /* Allocate hardware IRQ controller */
5515 ppc6xx_irq_init(env
);
5518 POWERPC_FAMILY(604E
)(ObjectClass
*oc
, void *data
)
5520 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5521 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5523 dc
->desc
= "PowerPC 604E";
5524 pcc
->init_proc
= init_proc_604E
;
5525 pcc
->check_pow
= check_pow_nocheck
;
5526 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5527 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5528 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5529 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5530 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5531 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
5532 PPC_SEGMENT
| PPC_EXTERN
;
5533 pcc
->msr_mask
= (1ull << MSR_POW
) |
5549 pcc
->mmu_model
= POWERPC_MMU_32B
;
5550 #if defined(CONFIG_SOFTMMU)
5551 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5553 pcc
->excp_model
= POWERPC_EXCP_604
;
5554 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5555 pcc
->bfd_mach
= bfd_mach_ppc_604
;
5556 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
5557 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5560 static void init_proc_740 (CPUPPCState
*env
)
5562 gen_spr_ne_601(env
);
5566 /* Thermal management */
5568 /* Hardware implementation registers */
5569 /* XXX : not implemented */
5570 spr_register(env
, SPR_HID0
, "HID0",
5571 SPR_NOACCESS
, SPR_NOACCESS
,
5572 &spr_read_generic
, &spr_write_generic
,
5574 /* XXX : not implemented */
5575 spr_register(env
, SPR_HID1
, "HID1",
5576 SPR_NOACCESS
, SPR_NOACCESS
,
5577 &spr_read_generic
, &spr_write_generic
,
5579 /* Memory management */
5582 env
->dcache_line_size
= 32;
5583 env
->icache_line_size
= 32;
5584 /* Allocate hardware IRQ controller */
5585 ppc6xx_irq_init(env
);
5588 POWERPC_FAMILY(740)(ObjectClass
*oc
, void *data
)
5590 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5591 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5593 dc
->desc
= "PowerPC 740";
5594 pcc
->init_proc
= init_proc_740
;
5595 pcc
->check_pow
= check_pow_hid0
;
5596 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5597 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5598 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5599 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5600 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5601 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
5602 PPC_SEGMENT
| PPC_EXTERN
;
5603 pcc
->msr_mask
= (1ull << MSR_POW
) |
5619 pcc
->mmu_model
= POWERPC_MMU_32B
;
5620 #if defined(CONFIG_SOFTMMU)
5621 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5623 pcc
->excp_model
= POWERPC_EXCP_7x0
;
5624 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5625 pcc
->bfd_mach
= bfd_mach_ppc_750
;
5626 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
5627 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5630 static void init_proc_750 (CPUPPCState
*env
)
5632 gen_spr_ne_601(env
);
5634 /* XXX : not implemented */
5635 spr_register(env
, SPR_L2CR
, "L2CR",
5636 SPR_NOACCESS
, SPR_NOACCESS
,
5637 &spr_read_generic
, spr_access_nop
,
5641 /* Thermal management */
5643 /* Hardware implementation registers */
5644 /* XXX : not implemented */
5645 spr_register(env
, SPR_HID0
, "HID0",
5646 SPR_NOACCESS
, SPR_NOACCESS
,
5647 &spr_read_generic
, &spr_write_generic
,
5649 /* XXX : not implemented */
5650 spr_register(env
, SPR_HID1
, "HID1",
5651 SPR_NOACCESS
, SPR_NOACCESS
,
5652 &spr_read_generic
, &spr_write_generic
,
5654 /* Memory management */
5656 /* XXX: high BATs are also present but are known to be bugged on
5660 env
->dcache_line_size
= 32;
5661 env
->icache_line_size
= 32;
5662 /* Allocate hardware IRQ controller */
5663 ppc6xx_irq_init(env
);
5666 POWERPC_FAMILY(750)(ObjectClass
*oc
, void *data
)
5668 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5669 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5671 dc
->desc
= "PowerPC 750";
5672 pcc
->init_proc
= init_proc_750
;
5673 pcc
->check_pow
= check_pow_hid0
;
5674 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5675 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5676 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5677 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5678 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5679 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
5680 PPC_SEGMENT
| PPC_EXTERN
;
5681 pcc
->msr_mask
= (1ull << MSR_POW
) |
5697 pcc
->mmu_model
= POWERPC_MMU_32B
;
5698 #if defined(CONFIG_SOFTMMU)
5699 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5701 pcc
->excp_model
= POWERPC_EXCP_7x0
;
5702 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5703 pcc
->bfd_mach
= bfd_mach_ppc_750
;
5704 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
5705 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5708 static void init_proc_750cl (CPUPPCState
*env
)
5710 gen_spr_ne_601(env
);
5712 /* XXX : not implemented */
5713 spr_register(env
, SPR_L2CR
, "L2CR",
5714 SPR_NOACCESS
, SPR_NOACCESS
,
5715 &spr_read_generic
, spr_access_nop
,
5719 /* Thermal management */
5720 /* Those registers are fake on 750CL */
5721 spr_register(env
, SPR_THRM1
, "THRM1",
5722 SPR_NOACCESS
, SPR_NOACCESS
,
5723 &spr_read_generic
, &spr_write_generic
,
5725 spr_register(env
, SPR_THRM2
, "THRM2",
5726 SPR_NOACCESS
, SPR_NOACCESS
,
5727 &spr_read_generic
, &spr_write_generic
,
5729 spr_register(env
, SPR_THRM3
, "THRM3",
5730 SPR_NOACCESS
, SPR_NOACCESS
,
5731 &spr_read_generic
, &spr_write_generic
,
5733 /* XXX: not implemented */
5734 spr_register(env
, SPR_750_TDCL
, "TDCL",
5735 SPR_NOACCESS
, SPR_NOACCESS
,
5736 &spr_read_generic
, &spr_write_generic
,
5738 spr_register(env
, SPR_750_TDCH
, "TDCH",
5739 SPR_NOACCESS
, SPR_NOACCESS
,
5740 &spr_read_generic
, &spr_write_generic
,
5743 /* XXX : not implemented */
5744 spr_register(env
, SPR_750_WPAR
, "WPAR",
5745 SPR_NOACCESS
, SPR_NOACCESS
,
5746 &spr_read_generic
, &spr_write_generic
,
5748 spr_register(env
, SPR_750_DMAL
, "DMAL",
5749 SPR_NOACCESS
, SPR_NOACCESS
,
5750 &spr_read_generic
, &spr_write_generic
,
5752 spr_register(env
, SPR_750_DMAU
, "DMAU",
5753 SPR_NOACCESS
, SPR_NOACCESS
,
5754 &spr_read_generic
, &spr_write_generic
,
5756 /* Hardware implementation registers */
5757 /* XXX : not implemented */
5758 spr_register(env
, SPR_HID0
, "HID0",
5759 SPR_NOACCESS
, SPR_NOACCESS
,
5760 &spr_read_generic
, &spr_write_generic
,
5762 /* XXX : not implemented */
5763 spr_register(env
, SPR_HID1
, "HID1",
5764 SPR_NOACCESS
, SPR_NOACCESS
,
5765 &spr_read_generic
, &spr_write_generic
,
5767 /* XXX : not implemented */
5768 spr_register(env
, SPR_750CL_HID2
, "HID2",
5769 SPR_NOACCESS
, SPR_NOACCESS
,
5770 &spr_read_generic
, &spr_write_generic
,
5772 /* XXX : not implemented */
5773 spr_register(env
, SPR_750CL_HID4
, "HID4",
5774 SPR_NOACCESS
, SPR_NOACCESS
,
5775 &spr_read_generic
, &spr_write_generic
,
5777 /* Quantization registers */
5778 /* XXX : not implemented */
5779 spr_register(env
, SPR_750_GQR0
, "GQR0",
5780 SPR_NOACCESS
, SPR_NOACCESS
,
5781 &spr_read_generic
, &spr_write_generic
,
5783 /* XXX : not implemented */
5784 spr_register(env
, SPR_750_GQR1
, "GQR1",
5785 SPR_NOACCESS
, SPR_NOACCESS
,
5786 &spr_read_generic
, &spr_write_generic
,
5788 /* XXX : not implemented */
5789 spr_register(env
, SPR_750_GQR2
, "GQR2",
5790 SPR_NOACCESS
, SPR_NOACCESS
,
5791 &spr_read_generic
, &spr_write_generic
,
5793 /* XXX : not implemented */
5794 spr_register(env
, SPR_750_GQR3
, "GQR3",
5795 SPR_NOACCESS
, SPR_NOACCESS
,
5796 &spr_read_generic
, &spr_write_generic
,
5798 /* XXX : not implemented */
5799 spr_register(env
, SPR_750_GQR4
, "GQR4",
5800 SPR_NOACCESS
, SPR_NOACCESS
,
5801 &spr_read_generic
, &spr_write_generic
,
5803 /* XXX : not implemented */
5804 spr_register(env
, SPR_750_GQR5
, "GQR5",
5805 SPR_NOACCESS
, SPR_NOACCESS
,
5806 &spr_read_generic
, &spr_write_generic
,
5808 /* XXX : not implemented */
5809 spr_register(env
, SPR_750_GQR6
, "GQR6",
5810 SPR_NOACCESS
, SPR_NOACCESS
,
5811 &spr_read_generic
, &spr_write_generic
,
5813 /* XXX : not implemented */
5814 spr_register(env
, SPR_750_GQR7
, "GQR7",
5815 SPR_NOACCESS
, SPR_NOACCESS
,
5816 &spr_read_generic
, &spr_write_generic
,
5818 /* Memory management */
5820 /* PowerPC 750cl has 8 DBATs and 8 IBATs */
5822 init_excp_750cl(env
);
5823 env
->dcache_line_size
= 32;
5824 env
->icache_line_size
= 32;
5825 /* Allocate hardware IRQ controller */
5826 ppc6xx_irq_init(env
);
5829 POWERPC_FAMILY(750cl
)(ObjectClass
*oc
, void *data
)
5831 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5832 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5834 dc
->desc
= "PowerPC 750 CL";
5835 pcc
->init_proc
= init_proc_750cl
;
5836 pcc
->check_pow
= check_pow_hid0
;
5837 /* XXX: not implemented:
5838 * cache lock instructions:
5840 * floating point paired instructions
5875 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5876 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5877 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5878 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5879 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5880 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
5881 PPC_SEGMENT
| PPC_EXTERN
;
5882 pcc
->msr_mask
= (1ull << MSR_POW
) |
5898 pcc
->mmu_model
= POWERPC_MMU_32B
;
5899 #if defined(CONFIG_SOFTMMU)
5900 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5902 pcc
->excp_model
= POWERPC_EXCP_7x0
;
5903 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5904 pcc
->bfd_mach
= bfd_mach_ppc_750
;
5905 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
5906 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5909 static void init_proc_750cx (CPUPPCState
*env
)
5911 gen_spr_ne_601(env
);
5913 /* XXX : not implemented */
5914 spr_register(env
, SPR_L2CR
, "L2CR",
5915 SPR_NOACCESS
, SPR_NOACCESS
,
5916 &spr_read_generic
, spr_access_nop
,
5920 /* Thermal management */
5922 /* This register is not implemented but is present for compatibility */
5923 spr_register(env
, SPR_SDA
, "SDA",
5924 SPR_NOACCESS
, SPR_NOACCESS
,
5925 &spr_read_generic
, &spr_write_generic
,
5927 /* Hardware implementation registers */
5928 /* XXX : not implemented */
5929 spr_register(env
, SPR_HID0
, "HID0",
5930 SPR_NOACCESS
, SPR_NOACCESS
,
5931 &spr_read_generic
, &spr_write_generic
,
5933 /* XXX : not implemented */
5934 spr_register(env
, SPR_HID1
, "HID1",
5935 SPR_NOACCESS
, SPR_NOACCESS
,
5936 &spr_read_generic
, &spr_write_generic
,
5938 /* Memory management */
5940 /* PowerPC 750cx has 8 DBATs and 8 IBATs */
5942 init_excp_750cx(env
);
5943 env
->dcache_line_size
= 32;
5944 env
->icache_line_size
= 32;
5945 /* Allocate hardware IRQ controller */
5946 ppc6xx_irq_init(env
);
5949 POWERPC_FAMILY(750cx
)(ObjectClass
*oc
, void *data
)
5951 DeviceClass
*dc
= DEVICE_CLASS(oc
);
5952 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
5954 dc
->desc
= "PowerPC 750CX";
5955 pcc
->init_proc
= init_proc_750cx
;
5956 pcc
->check_pow
= check_pow_hid0
;
5957 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
5958 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
5959 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
5960 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
5961 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
5962 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
5963 PPC_SEGMENT
| PPC_EXTERN
;
5964 pcc
->msr_mask
= (1ull << MSR_POW
) |
5980 pcc
->mmu_model
= POWERPC_MMU_32B
;
5981 #if defined(CONFIG_SOFTMMU)
5982 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
5984 pcc
->excp_model
= POWERPC_EXCP_7x0
;
5985 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
5986 pcc
->bfd_mach
= bfd_mach_ppc_750
;
5987 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
5988 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
5991 static void init_proc_750fx (CPUPPCState
*env
)
5993 gen_spr_ne_601(env
);
5995 /* XXX : not implemented */
5996 spr_register(env
, SPR_L2CR
, "L2CR",
5997 SPR_NOACCESS
, SPR_NOACCESS
,
5998 &spr_read_generic
, spr_access_nop
,
6002 /* Thermal management */
6004 /* XXX : not implemented */
6005 spr_register(env
, SPR_750_THRM4
, "THRM4",
6006 SPR_NOACCESS
, SPR_NOACCESS
,
6007 &spr_read_generic
, &spr_write_generic
,
6009 /* Hardware implementation registers */
6010 /* XXX : not implemented */
6011 spr_register(env
, SPR_HID0
, "HID0",
6012 SPR_NOACCESS
, SPR_NOACCESS
,
6013 &spr_read_generic
, &spr_write_generic
,
6015 /* XXX : not implemented */
6016 spr_register(env
, SPR_HID1
, "HID1",
6017 SPR_NOACCESS
, SPR_NOACCESS
,
6018 &spr_read_generic
, &spr_write_generic
,
6020 /* XXX : not implemented */
6021 spr_register(env
, SPR_750FX_HID2
, "HID2",
6022 SPR_NOACCESS
, SPR_NOACCESS
,
6023 &spr_read_generic
, &spr_write_generic
,
6025 /* Memory management */
6027 /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
6030 env
->dcache_line_size
= 32;
6031 env
->icache_line_size
= 32;
6032 /* Allocate hardware IRQ controller */
6033 ppc6xx_irq_init(env
);
6036 POWERPC_FAMILY(750fx
)(ObjectClass
*oc
, void *data
)
6038 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6039 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6041 dc
->desc
= "PowerPC 750FX";
6042 pcc
->init_proc
= init_proc_750fx
;
6043 pcc
->check_pow
= check_pow_hid0
;
6044 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6045 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6046 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
6047 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
6048 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6049 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6050 PPC_SEGMENT
| PPC_EXTERN
;
6051 pcc
->msr_mask
= (1ull << MSR_POW
) |
6067 pcc
->mmu_model
= POWERPC_MMU_32B
;
6068 #if defined(CONFIG_SOFTMMU)
6069 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
6071 pcc
->excp_model
= POWERPC_EXCP_7x0
;
6072 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6073 pcc
->bfd_mach
= bfd_mach_ppc_750
;
6074 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
6075 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
6078 static void init_proc_750gx (CPUPPCState
*env
)
6080 gen_spr_ne_601(env
);
6082 /* XXX : not implemented (XXX: different from 750fx) */
6083 spr_register(env
, SPR_L2CR
, "L2CR",
6084 SPR_NOACCESS
, SPR_NOACCESS
,
6085 &spr_read_generic
, spr_access_nop
,
6089 /* Thermal management */
6091 /* XXX : not implemented */
6092 spr_register(env
, SPR_750_THRM4
, "THRM4",
6093 SPR_NOACCESS
, SPR_NOACCESS
,
6094 &spr_read_generic
, &spr_write_generic
,
6096 /* Hardware implementation registers */
6097 /* XXX : not implemented (XXX: different from 750fx) */
6098 spr_register(env
, SPR_HID0
, "HID0",
6099 SPR_NOACCESS
, SPR_NOACCESS
,
6100 &spr_read_generic
, &spr_write_generic
,
6102 /* XXX : not implemented */
6103 spr_register(env
, SPR_HID1
, "HID1",
6104 SPR_NOACCESS
, SPR_NOACCESS
,
6105 &spr_read_generic
, &spr_write_generic
,
6107 /* XXX : not implemented (XXX: different from 750fx) */
6108 spr_register(env
, SPR_750FX_HID2
, "HID2",
6109 SPR_NOACCESS
, SPR_NOACCESS
,
6110 &spr_read_generic
, &spr_write_generic
,
6112 /* Memory management */
6114 /* PowerPC 750fx & 750gx has 8 DBATs and 8 IBATs */
6117 env
->dcache_line_size
= 32;
6118 env
->icache_line_size
= 32;
6119 /* Allocate hardware IRQ controller */
6120 ppc6xx_irq_init(env
);
6123 POWERPC_FAMILY(750gx
)(ObjectClass
*oc
, void *data
)
6125 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6126 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6128 dc
->desc
= "PowerPC 750GX";
6129 pcc
->init_proc
= init_proc_750gx
;
6130 pcc
->check_pow
= check_pow_hid0
;
6131 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6132 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6133 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
6134 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
6135 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6136 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6137 PPC_SEGMENT
| PPC_EXTERN
;
6138 pcc
->msr_mask
= (1ull << MSR_POW
) |
6154 pcc
->mmu_model
= POWERPC_MMU_32B
;
6155 #if defined(CONFIG_SOFTMMU)
6156 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
6158 pcc
->excp_model
= POWERPC_EXCP_7x0
;
6159 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6160 pcc
->bfd_mach
= bfd_mach_ppc_750
;
6161 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
6162 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
6165 static void init_proc_745 (CPUPPCState
*env
)
6167 gen_spr_ne_601(env
);
6169 gen_spr_G2_755(env
);
6172 /* Thermal management */
6174 /* Hardware implementation registers */
6175 /* XXX : not implemented */
6176 spr_register(env
, SPR_HID0
, "HID0",
6177 SPR_NOACCESS
, SPR_NOACCESS
,
6178 &spr_read_generic
, &spr_write_generic
,
6180 /* XXX : not implemented */
6181 spr_register(env
, SPR_HID1
, "HID1",
6182 SPR_NOACCESS
, SPR_NOACCESS
,
6183 &spr_read_generic
, &spr_write_generic
,
6185 /* XXX : not implemented */
6186 spr_register(env
, SPR_HID2
, "HID2",
6187 SPR_NOACCESS
, SPR_NOACCESS
,
6188 &spr_read_generic
, &spr_write_generic
,
6190 /* Memory management */
6193 gen_6xx_7xx_soft_tlb(env
, 64, 2);
6195 env
->dcache_line_size
= 32;
6196 env
->icache_line_size
= 32;
6197 /* Allocate hardware IRQ controller */
6198 ppc6xx_irq_init(env
);
6201 POWERPC_FAMILY(745)(ObjectClass
*oc
, void *data
)
6203 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6204 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6206 dc
->desc
= "PowerPC 745";
6207 pcc
->init_proc
= init_proc_745
;
6208 pcc
->check_pow
= check_pow_hid0
;
6209 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6210 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6211 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
6212 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
6213 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6214 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
| PPC_6xx_TLB
|
6215 PPC_SEGMENT
| PPC_EXTERN
;
6216 pcc
->msr_mask
= (1ull << MSR_POW
) |
6232 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
6233 pcc
->excp_model
= POWERPC_EXCP_7x5
;
6234 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6235 pcc
->bfd_mach
= bfd_mach_ppc_750
;
6236 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
6237 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
6240 static void init_proc_755 (CPUPPCState
*env
)
6242 gen_spr_ne_601(env
);
6244 gen_spr_G2_755(env
);
6247 /* L2 cache control */
6248 /* XXX : not implemented */
6249 spr_register(env
, SPR_L2CR
, "L2CR",
6250 SPR_NOACCESS
, SPR_NOACCESS
,
6251 &spr_read_generic
, spr_access_nop
,
6253 /* XXX : not implemented */
6254 spr_register(env
, SPR_L2PMCR
, "L2PMCR",
6255 SPR_NOACCESS
, SPR_NOACCESS
,
6256 &spr_read_generic
, &spr_write_generic
,
6258 /* Thermal management */
6260 /* Hardware implementation registers */
6261 /* XXX : not implemented */
6262 spr_register(env
, SPR_HID0
, "HID0",
6263 SPR_NOACCESS
, SPR_NOACCESS
,
6264 &spr_read_generic
, &spr_write_generic
,
6266 /* XXX : not implemented */
6267 spr_register(env
, SPR_HID1
, "HID1",
6268 SPR_NOACCESS
, SPR_NOACCESS
,
6269 &spr_read_generic
, &spr_write_generic
,
6271 /* XXX : not implemented */
6272 spr_register(env
, SPR_HID2
, "HID2",
6273 SPR_NOACCESS
, SPR_NOACCESS
,
6274 &spr_read_generic
, &spr_write_generic
,
6276 /* Memory management */
6279 gen_6xx_7xx_soft_tlb(env
, 64, 2);
6281 env
->dcache_line_size
= 32;
6282 env
->icache_line_size
= 32;
6283 /* Allocate hardware IRQ controller */
6284 ppc6xx_irq_init(env
);
6287 POWERPC_FAMILY(755)(ObjectClass
*oc
, void *data
)
6289 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6290 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6292 dc
->desc
= "PowerPC 755";
6293 pcc
->init_proc
= init_proc_755
;
6294 pcc
->check_pow
= check_pow_hid0
;
6295 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6296 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6297 PPC_FLOAT_FRSQRTE
| PPC_FLOAT_STFIWX
|
6298 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
6299 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6300 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
| PPC_6xx_TLB
|
6301 PPC_SEGMENT
| PPC_EXTERN
;
6302 pcc
->msr_mask
= (1ull << MSR_POW
) |
6318 pcc
->mmu_model
= POWERPC_MMU_SOFT_6xx
;
6319 pcc
->excp_model
= POWERPC_EXCP_7x5
;
6320 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6321 pcc
->bfd_mach
= bfd_mach_ppc_750
;
6322 pcc
->flags
= POWERPC_FLAG_SE
| POWERPC_FLAG_BE
|
6323 POWERPC_FLAG_PMM
| POWERPC_FLAG_BUS_CLK
;
6326 static void init_proc_7400 (CPUPPCState
*env
)
6328 gen_spr_ne_601(env
);
6332 /* 74xx specific SPR */
6334 /* XXX : not implemented */
6335 spr_register(env
, SPR_UBAMR
, "UBAMR",
6336 &spr_read_ureg
, SPR_NOACCESS
,
6337 &spr_read_ureg
, SPR_NOACCESS
,
6339 /* XXX: this seems not implemented on all revisions. */
6340 /* XXX : not implemented */
6341 spr_register(env
, SPR_MSSCR1
, "MSSCR1",
6342 SPR_NOACCESS
, SPR_NOACCESS
,
6343 &spr_read_generic
, &spr_write_generic
,
6345 /* Thermal management */
6347 /* Memory management */
6349 init_excp_7400(env
);
6350 env
->dcache_line_size
= 32;
6351 env
->icache_line_size
= 32;
6352 /* Allocate hardware IRQ controller */
6353 ppc6xx_irq_init(env
);
6356 POWERPC_FAMILY(7400)(ObjectClass
*oc
, void *data
)
6358 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6359 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6361 dc
->desc
= "PowerPC 7400 (aka G4)";
6362 pcc
->init_proc
= init_proc_7400
;
6363 pcc
->check_pow
= check_pow_hid0
;
6364 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6365 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6366 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
6368 PPC_CACHE
| PPC_CACHE_ICBI
|
6369 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
6370 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6371 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6373 PPC_SEGMENT
| PPC_EXTERN
|
6375 pcc
->msr_mask
= (1ull << MSR_VR
) |
6392 pcc
->mmu_model
= POWERPC_MMU_32B
;
6393 #if defined(CONFIG_SOFTMMU)
6394 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
6396 pcc
->excp_model
= POWERPC_EXCP_74xx
;
6397 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6398 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
6399 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
6400 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
6401 POWERPC_FLAG_BUS_CLK
;
6404 static void init_proc_7410 (CPUPPCState
*env
)
6406 gen_spr_ne_601(env
);
6410 /* 74xx specific SPR */
6412 /* XXX : not implemented */
6413 spr_register(env
, SPR_UBAMR
, "UBAMR",
6414 &spr_read_ureg
, SPR_NOACCESS
,
6415 &spr_read_ureg
, SPR_NOACCESS
,
6417 /* Thermal management */
6420 /* XXX : not implemented */
6421 spr_register(env
, SPR_L2PMCR
, "L2PMCR",
6422 SPR_NOACCESS
, SPR_NOACCESS
,
6423 &spr_read_generic
, &spr_write_generic
,
6426 /* XXX : not implemented */
6427 spr_register(env
, SPR_LDSTDB
, "LDSTDB",
6428 SPR_NOACCESS
, SPR_NOACCESS
,
6429 &spr_read_generic
, &spr_write_generic
,
6431 /* Memory management */
6433 init_excp_7400(env
);
6434 env
->dcache_line_size
= 32;
6435 env
->icache_line_size
= 32;
6436 /* Allocate hardware IRQ controller */
6437 ppc6xx_irq_init(env
);
6440 POWERPC_FAMILY(7410)(ObjectClass
*oc
, void *data
)
6442 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6443 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6445 dc
->desc
= "PowerPC 7410 (aka G4)";
6446 pcc
->init_proc
= init_proc_7410
;
6447 pcc
->check_pow
= check_pow_hid0
;
6448 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6449 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6450 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
6452 PPC_CACHE
| PPC_CACHE_ICBI
|
6453 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
6454 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6455 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6457 PPC_SEGMENT
| PPC_EXTERN
|
6459 pcc
->msr_mask
= (1ull << MSR_VR
) |
6476 pcc
->mmu_model
= POWERPC_MMU_32B
;
6477 #if defined(CONFIG_SOFTMMU)
6478 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
6480 pcc
->excp_model
= POWERPC_EXCP_74xx
;
6481 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6482 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
6483 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
6484 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
6485 POWERPC_FLAG_BUS_CLK
;
6488 static void init_proc_7440 (CPUPPCState
*env
)
6490 gen_spr_ne_601(env
);
6494 /* 74xx specific SPR */
6496 /* XXX : not implemented */
6497 spr_register(env
, SPR_UBAMR
, "UBAMR",
6498 &spr_read_ureg
, SPR_NOACCESS
,
6499 &spr_read_ureg
, SPR_NOACCESS
,
6502 /* XXX : not implemented */
6503 spr_register(env
, SPR_LDSTCR
, "LDSTCR",
6504 SPR_NOACCESS
, SPR_NOACCESS
,
6505 &spr_read_generic
, &spr_write_generic
,
6508 /* XXX : not implemented */
6509 spr_register(env
, SPR_ICTRL
, "ICTRL",
6510 SPR_NOACCESS
, SPR_NOACCESS
,
6511 &spr_read_generic
, &spr_write_generic
,
6514 /* XXX : not implemented */
6515 spr_register(env
, SPR_MSSSR0
, "MSSSR0",
6516 SPR_NOACCESS
, SPR_NOACCESS
,
6517 &spr_read_generic
, &spr_write_generic
,
6520 /* XXX : not implemented */
6521 spr_register(env
, SPR_7XX_PMC5
, "PMC5",
6522 SPR_NOACCESS
, SPR_NOACCESS
,
6523 &spr_read_generic
, &spr_write_generic
,
6525 /* XXX : not implemented */
6526 spr_register(env
, SPR_7XX_UPMC5
, "UPMC5",
6527 &spr_read_ureg
, SPR_NOACCESS
,
6528 &spr_read_ureg
, SPR_NOACCESS
,
6530 /* XXX : not implemented */
6531 spr_register(env
, SPR_7XX_PMC6
, "PMC6",
6532 SPR_NOACCESS
, SPR_NOACCESS
,
6533 &spr_read_generic
, &spr_write_generic
,
6535 /* XXX : not implemented */
6536 spr_register(env
, SPR_7XX_UPMC6
, "UPMC6",
6537 &spr_read_ureg
, SPR_NOACCESS
,
6538 &spr_read_ureg
, SPR_NOACCESS
,
6540 /* Memory management */
6542 gen_74xx_soft_tlb(env
, 128, 2);
6543 init_excp_7450(env
);
6544 env
->dcache_line_size
= 32;
6545 env
->icache_line_size
= 32;
6546 /* Allocate hardware IRQ controller */
6547 ppc6xx_irq_init(env
);
6550 POWERPC_FAMILY(7440)(ObjectClass
*oc
, void *data
)
6552 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6553 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6555 dc
->desc
= "PowerPC 7440 (aka G4)";
6556 pcc
->init_proc
= init_proc_7440
;
6557 pcc
->check_pow
= check_pow_hid0_74xx
;
6558 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6559 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6560 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
6562 PPC_CACHE
| PPC_CACHE_ICBI
|
6563 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
6564 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6565 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6566 PPC_MEM_TLBIA
| PPC_74xx_TLB
|
6567 PPC_SEGMENT
| PPC_EXTERN
|
6569 pcc
->msr_mask
= (1ull << MSR_VR
) |
6586 pcc
->mmu_model
= POWERPC_MMU_SOFT_74xx
;
6587 pcc
->excp_model
= POWERPC_EXCP_74xx
;
6588 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6589 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
6590 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
6591 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
6592 POWERPC_FLAG_BUS_CLK
;
6595 static void init_proc_7450 (CPUPPCState
*env
)
6597 gen_spr_ne_601(env
);
6601 /* 74xx specific SPR */
6603 /* Level 3 cache control */
6606 /* XXX : not implemented */
6607 spr_register(env
, SPR_L3ITCR1
, "L3ITCR1",
6608 SPR_NOACCESS
, SPR_NOACCESS
,
6609 &spr_read_generic
, &spr_write_generic
,
6612 /* XXX : not implemented */
6613 spr_register(env
, SPR_L3ITCR2
, "L3ITCR2",
6614 SPR_NOACCESS
, SPR_NOACCESS
,
6615 &spr_read_generic
, &spr_write_generic
,
6618 /* XXX : not implemented */
6619 spr_register(env
, SPR_L3ITCR3
, "L3ITCR3",
6620 SPR_NOACCESS
, SPR_NOACCESS
,
6621 &spr_read_generic
, &spr_write_generic
,
6624 /* XXX : not implemented */
6625 spr_register(env
, SPR_L3OHCR
, "L3OHCR",
6626 SPR_NOACCESS
, SPR_NOACCESS
,
6627 &spr_read_generic
, &spr_write_generic
,
6629 /* XXX : not implemented */
6630 spr_register(env
, SPR_UBAMR
, "UBAMR",
6631 &spr_read_ureg
, SPR_NOACCESS
,
6632 &spr_read_ureg
, SPR_NOACCESS
,
6635 /* XXX : not implemented */
6636 spr_register(env
, SPR_LDSTCR
, "LDSTCR",
6637 SPR_NOACCESS
, SPR_NOACCESS
,
6638 &spr_read_generic
, &spr_write_generic
,
6641 /* XXX : not implemented */
6642 spr_register(env
, SPR_ICTRL
, "ICTRL",
6643 SPR_NOACCESS
, SPR_NOACCESS
,
6644 &spr_read_generic
, &spr_write_generic
,
6647 /* XXX : not implemented */
6648 spr_register(env
, SPR_MSSSR0
, "MSSSR0",
6649 SPR_NOACCESS
, SPR_NOACCESS
,
6650 &spr_read_generic
, &spr_write_generic
,
6653 /* XXX : not implemented */
6654 spr_register(env
, SPR_7XX_PMC5
, "PMC5",
6655 SPR_NOACCESS
, SPR_NOACCESS
,
6656 &spr_read_generic
, &spr_write_generic
,
6658 /* XXX : not implemented */
6659 spr_register(env
, SPR_7XX_UPMC5
, "UPMC5",
6660 &spr_read_ureg
, SPR_NOACCESS
,
6661 &spr_read_ureg
, SPR_NOACCESS
,
6663 /* XXX : not implemented */
6664 spr_register(env
, SPR_7XX_PMC6
, "PMC6",
6665 SPR_NOACCESS
, SPR_NOACCESS
,
6666 &spr_read_generic
, &spr_write_generic
,
6668 /* XXX : not implemented */
6669 spr_register(env
, SPR_7XX_UPMC6
, "UPMC6",
6670 &spr_read_ureg
, SPR_NOACCESS
,
6671 &spr_read_ureg
, SPR_NOACCESS
,
6673 /* Memory management */
6675 gen_74xx_soft_tlb(env
, 128, 2);
6676 init_excp_7450(env
);
6677 env
->dcache_line_size
= 32;
6678 env
->icache_line_size
= 32;
6679 /* Allocate hardware IRQ controller */
6680 ppc6xx_irq_init(env
);
6683 POWERPC_FAMILY(7450)(ObjectClass
*oc
, void *data
)
6685 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6686 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6688 dc
->desc
= "PowerPC 7450 (aka G4)";
6689 pcc
->init_proc
= init_proc_7450
;
6690 pcc
->check_pow
= check_pow_hid0_74xx
;
6691 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6692 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6693 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
6695 PPC_CACHE
| PPC_CACHE_ICBI
|
6696 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
6697 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6698 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6699 PPC_MEM_TLBIA
| PPC_74xx_TLB
|
6700 PPC_SEGMENT
| PPC_EXTERN
|
6702 pcc
->msr_mask
= (1ull << MSR_VR
) |
6719 pcc
->mmu_model
= POWERPC_MMU_SOFT_74xx
;
6720 pcc
->excp_model
= POWERPC_EXCP_74xx
;
6721 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6722 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
6723 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
6724 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
6725 POWERPC_FLAG_BUS_CLK
;
6728 static void init_proc_7445 (CPUPPCState
*env
)
6730 gen_spr_ne_601(env
);
6734 /* 74xx specific SPR */
6737 /* XXX : not implemented */
6738 spr_register(env
, SPR_LDSTCR
, "LDSTCR",
6739 SPR_NOACCESS
, SPR_NOACCESS
,
6740 &spr_read_generic
, &spr_write_generic
,
6743 /* XXX : not implemented */
6744 spr_register(env
, SPR_ICTRL
, "ICTRL",
6745 SPR_NOACCESS
, SPR_NOACCESS
,
6746 &spr_read_generic
, &spr_write_generic
,
6749 /* XXX : not implemented */
6750 spr_register(env
, SPR_MSSSR0
, "MSSSR0",
6751 SPR_NOACCESS
, SPR_NOACCESS
,
6752 &spr_read_generic
, &spr_write_generic
,
6755 /* XXX : not implemented */
6756 spr_register(env
, SPR_7XX_PMC5
, "PMC5",
6757 SPR_NOACCESS
, SPR_NOACCESS
,
6758 &spr_read_generic
, &spr_write_generic
,
6760 /* XXX : not implemented */
6761 spr_register(env
, SPR_7XX_UPMC5
, "UPMC5",
6762 &spr_read_ureg
, SPR_NOACCESS
,
6763 &spr_read_ureg
, SPR_NOACCESS
,
6765 /* XXX : not implemented */
6766 spr_register(env
, SPR_7XX_PMC6
, "PMC6",
6767 SPR_NOACCESS
, SPR_NOACCESS
,
6768 &spr_read_generic
, &spr_write_generic
,
6770 /* XXX : not implemented */
6771 spr_register(env
, SPR_7XX_UPMC6
, "UPMC6",
6772 &spr_read_ureg
, SPR_NOACCESS
,
6773 &spr_read_ureg
, SPR_NOACCESS
,
6776 spr_register(env
, SPR_SPRG4
, "SPRG4",
6777 SPR_NOACCESS
, SPR_NOACCESS
,
6778 &spr_read_generic
, &spr_write_generic
,
6780 spr_register(env
, SPR_USPRG4
, "USPRG4",
6781 &spr_read_ureg
, SPR_NOACCESS
,
6782 &spr_read_ureg
, SPR_NOACCESS
,
6784 spr_register(env
, SPR_SPRG5
, "SPRG5",
6785 SPR_NOACCESS
, SPR_NOACCESS
,
6786 &spr_read_generic
, &spr_write_generic
,
6788 spr_register(env
, SPR_USPRG5
, "USPRG5",
6789 &spr_read_ureg
, SPR_NOACCESS
,
6790 &spr_read_ureg
, SPR_NOACCESS
,
6792 spr_register(env
, SPR_SPRG6
, "SPRG6",
6793 SPR_NOACCESS
, SPR_NOACCESS
,
6794 &spr_read_generic
, &spr_write_generic
,
6796 spr_register(env
, SPR_USPRG6
, "USPRG6",
6797 &spr_read_ureg
, SPR_NOACCESS
,
6798 &spr_read_ureg
, SPR_NOACCESS
,
6800 spr_register(env
, SPR_SPRG7
, "SPRG7",
6801 SPR_NOACCESS
, SPR_NOACCESS
,
6802 &spr_read_generic
, &spr_write_generic
,
6804 spr_register(env
, SPR_USPRG7
, "USPRG7",
6805 &spr_read_ureg
, SPR_NOACCESS
,
6806 &spr_read_ureg
, SPR_NOACCESS
,
6808 /* Memory management */
6811 gen_74xx_soft_tlb(env
, 128, 2);
6812 init_excp_7450(env
);
6813 env
->dcache_line_size
= 32;
6814 env
->icache_line_size
= 32;
6815 /* Allocate hardware IRQ controller */
6816 ppc6xx_irq_init(env
);
6819 POWERPC_FAMILY(7445)(ObjectClass
*oc
, void *data
)
6821 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6822 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6824 dc
->desc
= "PowerPC 7445 (aka G4)";
6825 pcc
->init_proc
= init_proc_7445
;
6826 pcc
->check_pow
= check_pow_hid0_74xx
;
6827 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6828 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6829 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
6831 PPC_CACHE
| PPC_CACHE_ICBI
|
6832 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
6833 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6834 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6835 PPC_MEM_TLBIA
| PPC_74xx_TLB
|
6836 PPC_SEGMENT
| PPC_EXTERN
|
6838 pcc
->msr_mask
= (1ull << MSR_VR
) |
6855 pcc
->mmu_model
= POWERPC_MMU_SOFT_74xx
;
6856 pcc
->excp_model
= POWERPC_EXCP_74xx
;
6857 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6858 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
6859 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
6860 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
6861 POWERPC_FLAG_BUS_CLK
;
6864 static void init_proc_7455 (CPUPPCState
*env
)
6866 gen_spr_ne_601(env
);
6870 /* 74xx specific SPR */
6872 /* Level 3 cache control */
6875 /* XXX : not implemented */
6876 spr_register(env
, SPR_LDSTCR
, "LDSTCR",
6877 SPR_NOACCESS
, SPR_NOACCESS
,
6878 &spr_read_generic
, &spr_write_generic
,
6881 /* XXX : not implemented */
6882 spr_register(env
, SPR_ICTRL
, "ICTRL",
6883 SPR_NOACCESS
, SPR_NOACCESS
,
6884 &spr_read_generic
, &spr_write_generic
,
6887 /* XXX : not implemented */
6888 spr_register(env
, SPR_MSSSR0
, "MSSSR0",
6889 SPR_NOACCESS
, SPR_NOACCESS
,
6890 &spr_read_generic
, &spr_write_generic
,
6893 /* XXX : not implemented */
6894 spr_register(env
, SPR_7XX_PMC5
, "PMC5",
6895 SPR_NOACCESS
, SPR_NOACCESS
,
6896 &spr_read_generic
, &spr_write_generic
,
6898 /* XXX : not implemented */
6899 spr_register(env
, SPR_7XX_UPMC5
, "UPMC5",
6900 &spr_read_ureg
, SPR_NOACCESS
,
6901 &spr_read_ureg
, SPR_NOACCESS
,
6903 /* XXX : not implemented */
6904 spr_register(env
, SPR_7XX_PMC6
, "PMC6",
6905 SPR_NOACCESS
, SPR_NOACCESS
,
6906 &spr_read_generic
, &spr_write_generic
,
6908 /* XXX : not implemented */
6909 spr_register(env
, SPR_7XX_UPMC6
, "UPMC6",
6910 &spr_read_ureg
, SPR_NOACCESS
,
6911 &spr_read_ureg
, SPR_NOACCESS
,
6914 spr_register(env
, SPR_SPRG4
, "SPRG4",
6915 SPR_NOACCESS
, SPR_NOACCESS
,
6916 &spr_read_generic
, &spr_write_generic
,
6918 spr_register(env
, SPR_USPRG4
, "USPRG4",
6919 &spr_read_ureg
, SPR_NOACCESS
,
6920 &spr_read_ureg
, SPR_NOACCESS
,
6922 spr_register(env
, SPR_SPRG5
, "SPRG5",
6923 SPR_NOACCESS
, SPR_NOACCESS
,
6924 &spr_read_generic
, &spr_write_generic
,
6926 spr_register(env
, SPR_USPRG5
, "USPRG5",
6927 &spr_read_ureg
, SPR_NOACCESS
,
6928 &spr_read_ureg
, SPR_NOACCESS
,
6930 spr_register(env
, SPR_SPRG6
, "SPRG6",
6931 SPR_NOACCESS
, SPR_NOACCESS
,
6932 &spr_read_generic
, &spr_write_generic
,
6934 spr_register(env
, SPR_USPRG6
, "USPRG6",
6935 &spr_read_ureg
, SPR_NOACCESS
,
6936 &spr_read_ureg
, SPR_NOACCESS
,
6938 spr_register(env
, SPR_SPRG7
, "SPRG7",
6939 SPR_NOACCESS
, SPR_NOACCESS
,
6940 &spr_read_generic
, &spr_write_generic
,
6942 spr_register(env
, SPR_USPRG7
, "USPRG7",
6943 &spr_read_ureg
, SPR_NOACCESS
,
6944 &spr_read_ureg
, SPR_NOACCESS
,
6946 /* Memory management */
6949 gen_74xx_soft_tlb(env
, 128, 2);
6950 init_excp_7450(env
);
6951 env
->dcache_line_size
= 32;
6952 env
->icache_line_size
= 32;
6953 /* Allocate hardware IRQ controller */
6954 ppc6xx_irq_init(env
);
6957 POWERPC_FAMILY(7455)(ObjectClass
*oc
, void *data
)
6959 DeviceClass
*dc
= DEVICE_CLASS(oc
);
6960 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
6962 dc
->desc
= "PowerPC 7455 (aka G4)";
6963 pcc
->init_proc
= init_proc_7455
;
6964 pcc
->check_pow
= check_pow_hid0_74xx
;
6965 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
6966 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
6967 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
6969 PPC_CACHE
| PPC_CACHE_ICBI
|
6970 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
6971 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
6972 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
6973 PPC_MEM_TLBIA
| PPC_74xx_TLB
|
6974 PPC_SEGMENT
| PPC_EXTERN
|
6976 pcc
->msr_mask
= (1ull << MSR_VR
) |
6993 pcc
->mmu_model
= POWERPC_MMU_SOFT_74xx
;
6994 pcc
->excp_model
= POWERPC_EXCP_74xx
;
6995 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
6996 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
6997 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
6998 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
6999 POWERPC_FLAG_BUS_CLK
;
7002 static void init_proc_7457 (CPUPPCState
*env
)
7004 gen_spr_ne_601(env
);
7008 /* 74xx specific SPR */
7010 /* Level 3 cache control */
7013 /* XXX : not implemented */
7014 spr_register(env
, SPR_L3ITCR1
, "L3ITCR1",
7015 SPR_NOACCESS
, SPR_NOACCESS
,
7016 &spr_read_generic
, &spr_write_generic
,
7019 /* XXX : not implemented */
7020 spr_register(env
, SPR_L3ITCR2
, "L3ITCR2",
7021 SPR_NOACCESS
, SPR_NOACCESS
,
7022 &spr_read_generic
, &spr_write_generic
,
7025 /* XXX : not implemented */
7026 spr_register(env
, SPR_L3ITCR3
, "L3ITCR3",
7027 SPR_NOACCESS
, SPR_NOACCESS
,
7028 &spr_read_generic
, &spr_write_generic
,
7031 /* XXX : not implemented */
7032 spr_register(env
, SPR_L3OHCR
, "L3OHCR",
7033 SPR_NOACCESS
, SPR_NOACCESS
,
7034 &spr_read_generic
, &spr_write_generic
,
7037 /* XXX : not implemented */
7038 spr_register(env
, SPR_LDSTCR
, "LDSTCR",
7039 SPR_NOACCESS
, SPR_NOACCESS
,
7040 &spr_read_generic
, &spr_write_generic
,
7043 /* XXX : not implemented */
7044 spr_register(env
, SPR_ICTRL
, "ICTRL",
7045 SPR_NOACCESS
, SPR_NOACCESS
,
7046 &spr_read_generic
, &spr_write_generic
,
7049 /* XXX : not implemented */
7050 spr_register(env
, SPR_MSSSR0
, "MSSSR0",
7051 SPR_NOACCESS
, SPR_NOACCESS
,
7052 &spr_read_generic
, &spr_write_generic
,
7055 /* XXX : not implemented */
7056 spr_register(env
, SPR_7XX_PMC5
, "PMC5",
7057 SPR_NOACCESS
, SPR_NOACCESS
,
7058 &spr_read_generic
, &spr_write_generic
,
7060 /* XXX : not implemented */
7061 spr_register(env
, SPR_7XX_UPMC5
, "UPMC5",
7062 &spr_read_ureg
, SPR_NOACCESS
,
7063 &spr_read_ureg
, SPR_NOACCESS
,
7065 /* XXX : not implemented */
7066 spr_register(env
, SPR_7XX_PMC6
, "PMC6",
7067 SPR_NOACCESS
, SPR_NOACCESS
,
7068 &spr_read_generic
, &spr_write_generic
,
7070 /* XXX : not implemented */
7071 spr_register(env
, SPR_7XX_UPMC6
, "UPMC6",
7072 &spr_read_ureg
, SPR_NOACCESS
,
7073 &spr_read_ureg
, SPR_NOACCESS
,
7076 spr_register(env
, SPR_SPRG4
, "SPRG4",
7077 SPR_NOACCESS
, SPR_NOACCESS
,
7078 &spr_read_generic
, &spr_write_generic
,
7080 spr_register(env
, SPR_USPRG4
, "USPRG4",
7081 &spr_read_ureg
, SPR_NOACCESS
,
7082 &spr_read_ureg
, SPR_NOACCESS
,
7084 spr_register(env
, SPR_SPRG5
, "SPRG5",
7085 SPR_NOACCESS
, SPR_NOACCESS
,
7086 &spr_read_generic
, &spr_write_generic
,
7088 spr_register(env
, SPR_USPRG5
, "USPRG5",
7089 &spr_read_ureg
, SPR_NOACCESS
,
7090 &spr_read_ureg
, SPR_NOACCESS
,
7092 spr_register(env
, SPR_SPRG6
, "SPRG6",
7093 SPR_NOACCESS
, SPR_NOACCESS
,
7094 &spr_read_generic
, &spr_write_generic
,
7096 spr_register(env
, SPR_USPRG6
, "USPRG6",
7097 &spr_read_ureg
, SPR_NOACCESS
,
7098 &spr_read_ureg
, SPR_NOACCESS
,
7100 spr_register(env
, SPR_SPRG7
, "SPRG7",
7101 SPR_NOACCESS
, SPR_NOACCESS
,
7102 &spr_read_generic
, &spr_write_generic
,
7104 spr_register(env
, SPR_USPRG7
, "USPRG7",
7105 &spr_read_ureg
, SPR_NOACCESS
,
7106 &spr_read_ureg
, SPR_NOACCESS
,
7108 /* Memory management */
7111 gen_74xx_soft_tlb(env
, 128, 2);
7112 init_excp_7450(env
);
7113 env
->dcache_line_size
= 32;
7114 env
->icache_line_size
= 32;
7115 /* Allocate hardware IRQ controller */
7116 ppc6xx_irq_init(env
);
7119 POWERPC_FAMILY(7457)(ObjectClass
*oc
, void *data
)
7121 DeviceClass
*dc
= DEVICE_CLASS(oc
);
7122 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
7124 dc
->desc
= "PowerPC 7457 (aka G4)";
7125 pcc
->init_proc
= init_proc_7457
;
7126 pcc
->check_pow
= check_pow_hid0_74xx
;
7127 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
7128 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
7129 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
7131 PPC_CACHE
| PPC_CACHE_ICBI
|
7132 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
7133 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
7134 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
7135 PPC_MEM_TLBIA
| PPC_74xx_TLB
|
7136 PPC_SEGMENT
| PPC_EXTERN
|
7138 pcc
->msr_mask
= (1ull << MSR_VR
) |
7155 pcc
->mmu_model
= POWERPC_MMU_SOFT_74xx
;
7156 pcc
->excp_model
= POWERPC_EXCP_74xx
;
7157 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
7158 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
7159 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
7160 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
7161 POWERPC_FLAG_BUS_CLK
;
7164 static void init_proc_e600 (CPUPPCState
*env
)
7166 gen_spr_ne_601(env
);
7170 /* 74xx specific SPR */
7172 /* XXX : not implemented */
7173 spr_register(env
, SPR_UBAMR
, "UBAMR",
7174 &spr_read_ureg
, SPR_NOACCESS
,
7175 &spr_read_ureg
, SPR_NOACCESS
,
7177 /* XXX : not implemented */
7178 spr_register(env
, SPR_LDSTCR
, "LDSTCR",
7179 SPR_NOACCESS
, SPR_NOACCESS
,
7180 &spr_read_generic
, &spr_write_generic
,
7182 /* XXX : not implemented */
7183 spr_register(env
, SPR_ICTRL
, "ICTRL",
7184 SPR_NOACCESS
, SPR_NOACCESS
,
7185 &spr_read_generic
, &spr_write_generic
,
7187 /* XXX : not implemented */
7188 spr_register(env
, SPR_MSSSR0
, "MSSSR0",
7189 SPR_NOACCESS
, SPR_NOACCESS
,
7190 &spr_read_generic
, &spr_write_generic
,
7192 /* XXX : not implemented */
7193 spr_register(env
, SPR_7XX_PMC5
, "PMC5",
7194 SPR_NOACCESS
, SPR_NOACCESS
,
7195 &spr_read_generic
, &spr_write_generic
,
7197 /* XXX : not implemented */
7198 spr_register(env
, SPR_7XX_UPMC5
, "UPMC5",
7199 &spr_read_ureg
, SPR_NOACCESS
,
7200 &spr_read_ureg
, SPR_NOACCESS
,
7202 /* XXX : not implemented */
7203 spr_register(env
, SPR_7XX_PMC6
, "PMC6",
7204 SPR_NOACCESS
, SPR_NOACCESS
,
7205 &spr_read_generic
, &spr_write_generic
,
7207 /* XXX : not implemented */
7208 spr_register(env
, SPR_7XX_UPMC6
, "UPMC6",
7209 &spr_read_ureg
, SPR_NOACCESS
,
7210 &spr_read_ureg
, SPR_NOACCESS
,
7213 spr_register(env
, SPR_SPRG4
, "SPRG4",
7214 SPR_NOACCESS
, SPR_NOACCESS
,
7215 &spr_read_generic
, &spr_write_generic
,
7217 spr_register(env
, SPR_USPRG4
, "USPRG4",
7218 &spr_read_ureg
, SPR_NOACCESS
,
7219 &spr_read_ureg
, SPR_NOACCESS
,
7221 spr_register(env
, SPR_SPRG5
, "SPRG5",
7222 SPR_NOACCESS
, SPR_NOACCESS
,
7223 &spr_read_generic
, &spr_write_generic
,
7225 spr_register(env
, SPR_USPRG5
, "USPRG5",
7226 &spr_read_ureg
, SPR_NOACCESS
,
7227 &spr_read_ureg
, SPR_NOACCESS
,
7229 spr_register(env
, SPR_SPRG6
, "SPRG6",
7230 SPR_NOACCESS
, SPR_NOACCESS
,
7231 &spr_read_generic
, &spr_write_generic
,
7233 spr_register(env
, SPR_USPRG6
, "USPRG6",
7234 &spr_read_ureg
, SPR_NOACCESS
,
7235 &spr_read_ureg
, SPR_NOACCESS
,
7237 spr_register(env
, SPR_SPRG7
, "SPRG7",
7238 SPR_NOACCESS
, SPR_NOACCESS
,
7239 &spr_read_generic
, &spr_write_generic
,
7241 spr_register(env
, SPR_USPRG7
, "USPRG7",
7242 &spr_read_ureg
, SPR_NOACCESS
,
7243 &spr_read_ureg
, SPR_NOACCESS
,
7245 /* Memory management */
7248 gen_74xx_soft_tlb(env
, 128, 2);
7249 init_excp_7450(env
);
7250 env
->dcache_line_size
= 32;
7251 env
->icache_line_size
= 32;
7252 /* Allocate hardware IRQ controller */
7253 ppc6xx_irq_init(env
);
7256 POWERPC_FAMILY(e600
)(ObjectClass
*oc
, void *data
)
7258 DeviceClass
*dc
= DEVICE_CLASS(oc
);
7259 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
7261 dc
->desc
= "PowerPC e600";
7262 pcc
->init_proc
= init_proc_e600
;
7263 pcc
->check_pow
= check_pow_hid0_74xx
;
7264 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
7265 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
7266 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
7268 PPC_CACHE
| PPC_CACHE_ICBI
|
7269 PPC_CACHE_DCBA
| PPC_CACHE_DCBZ
|
7270 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
7271 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
7272 PPC_MEM_TLBIA
| PPC_74xx_TLB
|
7273 PPC_SEGMENT
| PPC_EXTERN
|
7275 pcc
->insns_flags2
= PPC_NONE
;
7276 pcc
->msr_mask
= (1ull << MSR_VR
) |
7293 pcc
->mmu_model
= POWERPC_MMU_32B
;
7294 #if defined(CONFIG_SOFTMMU)
7295 pcc
->handle_mmu_fault
= ppc_hash32_handle_mmu_fault
;
7297 pcc
->excp_model
= POWERPC_EXCP_74xx
;
7298 pcc
->bus_model
= PPC_FLAGS_INPUT_6xx
;
7299 pcc
->bfd_mach
= bfd_mach_ppc_7400
;
7300 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
7301 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
7302 POWERPC_FLAG_BUS_CLK
;
7305 #if defined (TARGET_PPC64)
7306 #if defined(CONFIG_USER_ONLY)
7307 #define POWERPC970_HID5_INIT 0x00000080
7309 #define POWERPC970_HID5_INIT 0x00000000
7312 enum BOOK3S_CPU_TYPE
{
7314 BOOK3S_CPU_POWER5PLUS
,
7320 static void gen_fscr_facility_check(DisasContext
*ctx
, int facility_sprn
,
7321 int bit
, int sprn
, int cause
)
7323 TCGv_i32 t1
= tcg_const_i32(bit
);
7324 TCGv_i32 t2
= tcg_const_i32(sprn
);
7325 TCGv_i32 t3
= tcg_const_i32(cause
);
7327 gen_update_current_nip(ctx
);
7328 gen_helper_fscr_facility_check(cpu_env
, t1
, t2
, t3
);
7330 tcg_temp_free_i32(t3
);
7331 tcg_temp_free_i32(t2
);
7332 tcg_temp_free_i32(t1
);
7335 static void gen_msr_facility_check(DisasContext
*ctx
, int facility_sprn
,
7336 int bit
, int sprn
, int cause
)
7338 TCGv_i32 t1
= tcg_const_i32(bit
);
7339 TCGv_i32 t2
= tcg_const_i32(sprn
);
7340 TCGv_i32 t3
= tcg_const_i32(cause
);
7342 gen_update_current_nip(ctx
);
7343 gen_helper_msr_facility_check(cpu_env
, t1
, t2
, t3
);
7345 tcg_temp_free_i32(t3
);
7346 tcg_temp_free_i32(t2
);
7347 tcg_temp_free_i32(t1
);
7350 static void spr_read_prev_upper32(DisasContext
*ctx
, int gprn
, int sprn
)
7352 TCGv spr_up
= tcg_temp_new();
7353 TCGv spr
= tcg_temp_new();
7355 gen_load_spr(spr
, sprn
- 1);
7356 tcg_gen_shri_tl(spr_up
, spr
, 32);
7357 tcg_gen_ext32u_tl(cpu_gpr
[gprn
], spr_up
);
7360 tcg_temp_free(spr_up
);
7363 static void spr_write_prev_upper32(DisasContext
*ctx
, int sprn
, int gprn
)
7365 TCGv spr
= tcg_temp_new();
7367 gen_load_spr(spr
, sprn
- 1);
7368 tcg_gen_deposit_tl(spr
, spr
, cpu_gpr
[gprn
], 32, 32);
7369 gen_store_spr(sprn
- 1, spr
);
7374 static int check_pow_970 (CPUPPCState
*env
)
7376 if (env
->spr
[SPR_HID0
] & (HID0_DEEPNAP
| HID0_DOZE
| HID0_NAP
)) {
7383 static void gen_spr_970_hid(CPUPPCState
*env
)
7385 /* Hardware implementation registers */
7386 /* XXX : not implemented */
7387 spr_register(env
, SPR_HID0
, "HID0",
7388 SPR_NOACCESS
, SPR_NOACCESS
,
7389 &spr_read_generic
, &spr_write_clear
,
7391 spr_register(env
, SPR_HID1
, "HID1",
7392 SPR_NOACCESS
, SPR_NOACCESS
,
7393 &spr_read_generic
, &spr_write_generic
,
7395 spr_register(env
, SPR_970_HID5
, "HID5",
7396 SPR_NOACCESS
, SPR_NOACCESS
,
7397 &spr_read_generic
, &spr_write_generic
,
7398 POWERPC970_HID5_INIT
);
7401 static void gen_spr_970_hior(CPUPPCState
*env
)
7403 spr_register(env
, SPR_HIOR
, "SPR_HIOR",
7404 SPR_NOACCESS
, SPR_NOACCESS
,
7405 &spr_read_hior
, &spr_write_hior
,
7409 static void gen_spr_970_lpar(CPUPPCState
*env
)
7411 /* Logical partitionning */
7412 /* PPC970: HID4 is effectively the LPCR */
7413 spr_register(env
, SPR_970_HID4
, "HID4",
7414 SPR_NOACCESS
, SPR_NOACCESS
,
7415 &spr_read_generic
, &spr_write_generic
,
7419 static void gen_spr_book3s_common(CPUPPCState
*env
)
7421 spr_register(env
, SPR_CTRL
, "SPR_CTRL",
7422 SPR_NOACCESS
, SPR_NOACCESS
,
7423 SPR_NOACCESS
, &spr_write_generic
,
7425 spr_register(env
, SPR_UCTRL
, "SPR_UCTRL",
7426 &spr_read_ureg
, SPR_NOACCESS
,
7427 &spr_read_ureg
, SPR_NOACCESS
,
7431 static void gen_spr_book3s_altivec(CPUPPCState
*env
)
7433 if (!(env
->insns_flags
& PPC_ALTIVEC
)) {
7437 spr_register_kvm(env
, SPR_VRSAVE
, "VRSAVE",
7438 &spr_read_generic
, &spr_write_generic
,
7439 &spr_read_generic
, &spr_write_generic
,
7440 KVM_REG_PPC_VRSAVE
, 0x00000000);
7442 /* Can't find information on what this should be on reset. This
7443 * value is the one used by 74xx processors. */
7444 vscr_init(env
, 0x00010000);
7447 static void gen_spr_book3s_dbg(CPUPPCState
*env
)
7450 * TODO: different specs define different scopes for these,
7451 * will have to address this:
7452 * 970: super/write and super/read
7453 * powerisa 2.03..2.04: hypv/write and super/read.
7454 * powerisa 2.05 and newer: hypv/write and hypv/read.
7456 spr_register_kvm(env
, SPR_DABR
, "DABR",
7457 SPR_NOACCESS
, SPR_NOACCESS
,
7458 &spr_read_generic
, &spr_write_generic
,
7459 KVM_REG_PPC_DABR
, 0x00000000);
7460 spr_register_kvm(env
, SPR_DABRX
, "DABRX",
7461 SPR_NOACCESS
, SPR_NOACCESS
,
7462 &spr_read_generic
, &spr_write_generic
,
7463 KVM_REG_PPC_DABRX
, 0x00000000);
7466 static void gen_spr_970_dbg(CPUPPCState
*env
)
7469 spr_register(env
, SPR_IABR
, "IABR",
7470 SPR_NOACCESS
, SPR_NOACCESS
,
7471 &spr_read_generic
, &spr_write_generic
,
7475 static void gen_spr_book3s_pmu_sup(CPUPPCState
*env
)
7477 spr_register_kvm(env
, SPR_POWER_MMCR0
, "MMCR0",
7478 SPR_NOACCESS
, SPR_NOACCESS
,
7479 &spr_read_generic
, &spr_write_generic
,
7480 KVM_REG_PPC_MMCR0
, 0x00000000);
7481 spr_register_kvm(env
, SPR_POWER_MMCR1
, "MMCR1",
7482 SPR_NOACCESS
, SPR_NOACCESS
,
7483 &spr_read_generic
, &spr_write_generic
,
7484 KVM_REG_PPC_MMCR1
, 0x00000000);
7485 spr_register_kvm(env
, SPR_POWER_MMCRA
, "MMCRA",
7486 SPR_NOACCESS
, SPR_NOACCESS
,
7487 &spr_read_generic
, &spr_write_generic
,
7488 KVM_REG_PPC_MMCRA
, 0x00000000);
7489 spr_register_kvm(env
, SPR_POWER_PMC1
, "PMC1",
7490 SPR_NOACCESS
, SPR_NOACCESS
,
7491 &spr_read_generic
, &spr_write_generic
,
7492 KVM_REG_PPC_PMC1
, 0x00000000);
7493 spr_register_kvm(env
, SPR_POWER_PMC2
, "PMC2",
7494 SPR_NOACCESS
, SPR_NOACCESS
,
7495 &spr_read_generic
, &spr_write_generic
,
7496 KVM_REG_PPC_PMC2
, 0x00000000);
7497 spr_register_kvm(env
, SPR_POWER_PMC3
, "PMC3",
7498 SPR_NOACCESS
, SPR_NOACCESS
,
7499 &spr_read_generic
, &spr_write_generic
,
7500 KVM_REG_PPC_PMC3
, 0x00000000);
7501 spr_register_kvm(env
, SPR_POWER_PMC4
, "PMC4",
7502 SPR_NOACCESS
, SPR_NOACCESS
,
7503 &spr_read_generic
, &spr_write_generic
,
7504 KVM_REG_PPC_PMC4
, 0x00000000);
7505 spr_register_kvm(env
, SPR_POWER_PMC5
, "PMC5",
7506 SPR_NOACCESS
, SPR_NOACCESS
,
7507 &spr_read_generic
, &spr_write_generic
,
7508 KVM_REG_PPC_PMC5
, 0x00000000);
7509 spr_register_kvm(env
, SPR_POWER_PMC6
, "PMC6",
7510 SPR_NOACCESS
, SPR_NOACCESS
,
7511 &spr_read_generic
, &spr_write_generic
,
7512 KVM_REG_PPC_PMC6
, 0x00000000);
7513 spr_register_kvm(env
, SPR_POWER_SIAR
, "SIAR",
7514 SPR_NOACCESS
, SPR_NOACCESS
,
7515 &spr_read_generic
, &spr_write_generic
,
7516 KVM_REG_PPC_SIAR
, 0x00000000);
7517 spr_register_kvm(env
, SPR_POWER_SDAR
, "SDAR",
7518 SPR_NOACCESS
, SPR_NOACCESS
,
7519 &spr_read_generic
, &spr_write_generic
,
7520 KVM_REG_PPC_SDAR
, 0x00000000);
7523 static void gen_spr_book3s_pmu_user(CPUPPCState
*env
)
7525 spr_register(env
, SPR_POWER_UMMCR0
, "UMMCR0",
7526 &spr_read_ureg
, SPR_NOACCESS
,
7527 &spr_read_ureg
, &spr_write_ureg
,
7529 spr_register(env
, SPR_POWER_UMMCR1
, "UMMCR1",
7530 &spr_read_ureg
, SPR_NOACCESS
,
7531 &spr_read_ureg
, &spr_write_ureg
,
7533 spr_register(env
, SPR_POWER_UMMCRA
, "UMMCRA",
7534 &spr_read_ureg
, SPR_NOACCESS
,
7535 &spr_read_ureg
, &spr_write_ureg
,
7537 spr_register(env
, SPR_POWER_UPMC1
, "UPMC1",
7538 &spr_read_ureg
, SPR_NOACCESS
,
7539 &spr_read_ureg
, &spr_write_ureg
,
7541 spr_register(env
, SPR_POWER_UPMC2
, "UPMC2",
7542 &spr_read_ureg
, SPR_NOACCESS
,
7543 &spr_read_ureg
, &spr_write_ureg
,
7545 spr_register(env
, SPR_POWER_UPMC3
, "UPMC3",
7546 &spr_read_ureg
, SPR_NOACCESS
,
7547 &spr_read_ureg
, &spr_write_ureg
,
7549 spr_register(env
, SPR_POWER_UPMC4
, "UPMC4",
7550 &spr_read_ureg
, SPR_NOACCESS
,
7551 &spr_read_ureg
, &spr_write_ureg
,
7553 spr_register(env
, SPR_POWER_UPMC5
, "UPMC5",
7554 &spr_read_ureg
, SPR_NOACCESS
,
7555 &spr_read_ureg
, &spr_write_ureg
,
7557 spr_register(env
, SPR_POWER_UPMC6
, "UPMC6",
7558 &spr_read_ureg
, SPR_NOACCESS
,
7559 &spr_read_ureg
, &spr_write_ureg
,
7561 spr_register(env
, SPR_POWER_USIAR
, "USIAR",
7562 &spr_read_ureg
, SPR_NOACCESS
,
7563 &spr_read_ureg
, &spr_write_ureg
,
7565 spr_register(env
, SPR_POWER_USDAR
, "USDAR",
7566 &spr_read_ureg
, SPR_NOACCESS
,
7567 &spr_read_ureg
, &spr_write_ureg
,
7571 static void gen_spr_970_pmu_sup(CPUPPCState
*env
)
7573 spr_register_kvm(env
, SPR_970_PMC7
, "PMC7",
7574 SPR_NOACCESS
, SPR_NOACCESS
,
7575 &spr_read_generic
, &spr_write_generic
,
7576 KVM_REG_PPC_PMC7
, 0x00000000);
7577 spr_register_kvm(env
, SPR_970_PMC8
, "PMC8",
7578 SPR_NOACCESS
, SPR_NOACCESS
,
7579 &spr_read_generic
, &spr_write_generic
,
7580 KVM_REG_PPC_PMC8
, 0x00000000);
7583 static void gen_spr_970_pmu_user(CPUPPCState
*env
)
7585 spr_register(env
, SPR_970_UPMC7
, "UPMC7",
7586 &spr_read_ureg
, SPR_NOACCESS
,
7587 &spr_read_ureg
, &spr_write_ureg
,
7589 spr_register(env
, SPR_970_UPMC8
, "UPMC8",
7590 &spr_read_ureg
, SPR_NOACCESS
,
7591 &spr_read_ureg
, &spr_write_ureg
,
7595 static void gen_spr_power8_pmu_sup(CPUPPCState
*env
)
7597 spr_register_kvm(env
, SPR_POWER_MMCR2
, "MMCR2",
7598 SPR_NOACCESS
, SPR_NOACCESS
,
7599 &spr_read_generic
, &spr_write_generic
,
7600 KVM_REG_PPC_MMCR2
, 0x00000000);
7601 spr_register_kvm(env
, SPR_POWER_MMCRS
, "MMCRS",
7602 SPR_NOACCESS
, SPR_NOACCESS
,
7603 &spr_read_generic
, &spr_write_generic
,
7604 KVM_REG_PPC_MMCRS
, 0x00000000);
7607 static void gen_spr_power8_pmu_user(CPUPPCState
*env
)
7609 spr_register(env
, SPR_POWER_UMMCR2
, "UMMCR2",
7610 &spr_read_ureg
, SPR_NOACCESS
,
7611 &spr_read_ureg
, &spr_write_ureg
,
7615 static void gen_spr_power5p_ear(CPUPPCState
*env
)
7617 /* External access control */
7618 spr_register(env
, SPR_EAR
, "EAR",
7619 SPR_NOACCESS
, SPR_NOACCESS
,
7620 &spr_read_generic
, &spr_write_generic
,
7624 static void gen_spr_power5p_lpar(CPUPPCState
*env
)
7626 /* Logical partitionning */
7627 spr_register_kvm(env
, SPR_LPCR
, "LPCR",
7628 SPR_NOACCESS
, SPR_NOACCESS
,
7629 &spr_read_generic
, &spr_write_generic
,
7630 KVM_REG_PPC_LPCR
, 0x00000000);
7633 static void gen_spr_book3s_ids(CPUPPCState
*env
)
7635 /* Processor identification */
7636 spr_register(env
, SPR_PIR
, "PIR",
7637 SPR_NOACCESS
, SPR_NOACCESS
,
7638 &spr_read_generic
, &spr_write_pir
,
7642 static void gen_spr_power8_ids(CPUPPCState
*env
)
7644 /* Thread identification */
7645 spr_register(env
, SPR_TIR
, "TIR",
7646 SPR_NOACCESS
, SPR_NOACCESS
,
7647 &spr_read_generic
, SPR_NOACCESS
,
7651 static void gen_spr_book3s_purr(CPUPPCState
*env
)
7653 #if !defined(CONFIG_USER_ONLY)
7654 /* PURR & SPURR: Hack - treat these as aliases for the TB for now */
7655 spr_register_kvm(env
, SPR_PURR
, "PURR",
7656 &spr_read_purr
, SPR_NOACCESS
,
7657 &spr_read_purr
, SPR_NOACCESS
,
7658 KVM_REG_PPC_PURR
, 0x00000000);
7659 spr_register_kvm(env
, SPR_SPURR
, "SPURR",
7660 &spr_read_purr
, SPR_NOACCESS
,
7661 &spr_read_purr
, SPR_NOACCESS
,
7662 KVM_REG_PPC_SPURR
, 0x00000000);
7666 static void gen_spr_power6_dbg(CPUPPCState
*env
)
7668 #if !defined(CONFIG_USER_ONLY)
7669 spr_register(env
, SPR_CFAR
, "SPR_CFAR",
7670 SPR_NOACCESS
, SPR_NOACCESS
,
7671 &spr_read_cfar
, &spr_write_cfar
,
7676 static void gen_spr_power5p_common(CPUPPCState
*env
)
7678 spr_register_kvm(env
, SPR_PPR
, "PPR",
7679 &spr_read_generic
, &spr_write_generic
,
7680 &spr_read_generic
, &spr_write_generic
,
7681 KVM_REG_PPC_PPR
, 0x00000000);
7684 static void gen_spr_power6_common(CPUPPCState
*env
)
7686 #if !defined(CONFIG_USER_ONLY)
7687 spr_register_kvm(env
, SPR_DSCR
, "SPR_DSCR",
7688 SPR_NOACCESS
, SPR_NOACCESS
,
7689 &spr_read_generic
, &spr_write_generic
,
7690 KVM_REG_PPC_DSCR
, 0x00000000);
7693 * Register PCR to report POWERPC_EXCP_PRIV_REG instead of
7694 * POWERPC_EXCP_INVAL_SPR.
7696 spr_register(env
, SPR_PCR
, "PCR",
7697 SPR_NOACCESS
, SPR_NOACCESS
,
7698 SPR_NOACCESS
, SPR_NOACCESS
,
7702 static void spr_read_tar(DisasContext
*ctx
, int gprn
, int sprn
)
7704 gen_fscr_facility_check(ctx
, SPR_FSCR
, FSCR_TAR
, sprn
, FSCR_IC_TAR
);
7705 spr_read_generic(ctx
, gprn
, sprn
);
7708 static void spr_write_tar(DisasContext
*ctx
, int sprn
, int gprn
)
7710 gen_fscr_facility_check(ctx
, SPR_FSCR
, FSCR_TAR
, sprn
, FSCR_IC_TAR
);
7711 spr_write_generic(ctx
, sprn
, gprn
);
7714 static void gen_spr_power8_tce_address_control(CPUPPCState
*env
)
7716 spr_register(env
, SPR_TAR
, "TAR",
7717 &spr_read_tar
, &spr_write_tar
,
7718 &spr_read_generic
, &spr_write_generic
,
7722 static void spr_read_tm(DisasContext
*ctx
, int gprn
, int sprn
)
7724 gen_msr_facility_check(ctx
, SPR_FSCR
, MSR_TM
, sprn
, FSCR_IC_TM
);
7725 spr_read_generic(ctx
, gprn
, sprn
);
7728 static void spr_write_tm(DisasContext
*ctx
, int sprn
, int gprn
)
7730 gen_msr_facility_check(ctx
, SPR_FSCR
, MSR_TM
, sprn
, FSCR_IC_TM
);
7731 spr_write_generic(ctx
, sprn
, gprn
);
7734 static void spr_read_tm_upper32(DisasContext
*ctx
, int gprn
, int sprn
)
7736 gen_msr_facility_check(ctx
, SPR_FSCR
, MSR_TM
, sprn
, FSCR_IC_TM
);
7737 spr_read_prev_upper32(ctx
, gprn
, sprn
);
7740 static void spr_write_tm_upper32(DisasContext
*ctx
, int sprn
, int gprn
)
7742 gen_msr_facility_check(ctx
, SPR_FSCR
, MSR_TM
, sprn
, FSCR_IC_TM
);
7743 spr_write_prev_upper32(ctx
, sprn
, gprn
);
7746 static void gen_spr_power8_tm(CPUPPCState
*env
)
7748 spr_register_kvm(env
, SPR_TFHAR
, "TFHAR",
7749 &spr_read_tm
, &spr_write_tm
,
7750 &spr_read_tm
, &spr_write_tm
,
7751 KVM_REG_PPC_TFHAR
, 0x00000000);
7752 spr_register_kvm(env
, SPR_TFIAR
, "TFIAR",
7753 &spr_read_tm
, &spr_write_tm
,
7754 &spr_read_tm
, &spr_write_tm
,
7755 KVM_REG_PPC_TFIAR
, 0x00000000);
7756 spr_register_kvm(env
, SPR_TEXASR
, "TEXASR",
7757 &spr_read_tm
, &spr_write_tm
,
7758 &spr_read_tm
, &spr_write_tm
,
7759 KVM_REG_PPC_TEXASR
, 0x00000000);
7760 spr_register(env
, SPR_TEXASRU
, "TEXASRU",
7761 &spr_read_tm_upper32
, &spr_write_tm_upper32
,
7762 &spr_read_tm_upper32
, &spr_write_tm_upper32
,
7766 static void spr_read_ebb(DisasContext
*ctx
, int gprn
, int sprn
)
7768 gen_fscr_facility_check(ctx
, SPR_FSCR
, FSCR_EBB
, sprn
, FSCR_IC_EBB
);
7769 spr_read_generic(ctx
, gprn
, sprn
);
7772 static void spr_write_ebb(DisasContext
*ctx
, int sprn
, int gprn
)
7774 gen_fscr_facility_check(ctx
, SPR_FSCR
, FSCR_EBB
, sprn
, FSCR_IC_EBB
);
7775 spr_write_generic(ctx
, sprn
, gprn
);
7778 static void spr_read_ebb_upper32(DisasContext
*ctx
, int gprn
, int sprn
)
7780 gen_fscr_facility_check(ctx
, SPR_FSCR
, FSCR_EBB
, sprn
, FSCR_IC_EBB
);
7781 spr_read_prev_upper32(ctx
, gprn
, sprn
);
7784 static void spr_write_ebb_upper32(DisasContext
*ctx
, int sprn
, int gprn
)
7786 gen_fscr_facility_check(ctx
, SPR_FSCR
, FSCR_EBB
, sprn
, FSCR_IC_EBB
);
7787 spr_write_prev_upper32(ctx
, sprn
, gprn
);
7790 static void gen_spr_power8_ebb(CPUPPCState
*env
)
7792 spr_register(env
, SPR_BESCRS
, "BESCRS",
7793 &spr_read_ebb
, &spr_write_ebb
,
7794 &spr_read_generic
, &spr_write_generic
,
7796 spr_register(env
, SPR_BESCRSU
, "BESCRSU",
7797 &spr_read_ebb_upper32
, &spr_write_ebb_upper32
,
7798 &spr_read_prev_upper32
, &spr_write_prev_upper32
,
7800 spr_register(env
, SPR_BESCRR
, "BESCRR",
7801 &spr_read_ebb
, &spr_write_ebb
,
7802 &spr_read_generic
, &spr_write_generic
,
7804 spr_register(env
, SPR_BESCRRU
, "BESCRRU",
7805 &spr_read_ebb_upper32
, &spr_write_ebb_upper32
,
7806 &spr_read_prev_upper32
, &spr_write_prev_upper32
,
7808 spr_register_kvm(env
, SPR_EBBHR
, "EBBHR",
7809 &spr_read_ebb
, &spr_write_ebb
,
7810 &spr_read_generic
, &spr_write_generic
,
7811 KVM_REG_PPC_EBBHR
, 0x00000000);
7812 spr_register_kvm(env
, SPR_EBBRR
, "EBBRR",
7813 &spr_read_ebb
, &spr_write_ebb
,
7814 &spr_read_generic
, &spr_write_generic
,
7815 KVM_REG_PPC_EBBRR
, 0x00000000);
7816 spr_register_kvm(env
, SPR_BESCR
, "BESCR",
7817 &spr_read_ebb
, &spr_write_ebb
,
7818 &spr_read_generic
, &spr_write_generic
,
7819 KVM_REG_PPC_BESCR
, 0x00000000);
7822 /* Virtual Time Base */
7823 static void gen_spr_vtb(CPUPPCState
*env
)
7825 spr_register(env
, SPR_VTB
, "VTB",
7826 SPR_NOACCESS
, SPR_NOACCESS
,
7827 &spr_read_tbl
, SPR_NOACCESS
,
7831 static void gen_spr_power8_fscr(CPUPPCState
*env
)
7833 #if defined(CONFIG_USER_ONLY)
7834 target_ulong initval
= 1ULL << FSCR_TAR
;
7836 target_ulong initval
= 0;
7838 spr_register_kvm(env
, SPR_FSCR
, "FSCR",
7839 SPR_NOACCESS
, SPR_NOACCESS
,
7840 &spr_read_generic
, &spr_write_generic
,
7841 KVM_REG_PPC_FSCR
, initval
);
7844 static void init_proc_book3s_64(CPUPPCState
*env
, int version
)
7846 gen_spr_ne_601(env
);
7848 gen_spr_book3s_altivec(env
);
7849 gen_spr_book3s_pmu_sup(env
);
7850 gen_spr_book3s_pmu_user(env
);
7851 gen_spr_book3s_common(env
);
7854 case BOOK3S_CPU_970
:
7855 case BOOK3S_CPU_POWER5PLUS
:
7856 gen_spr_970_hid(env
);
7857 gen_spr_970_hior(env
);
7859 gen_spr_970_pmu_sup(env
);
7860 gen_spr_970_pmu_user(env
);
7862 case BOOK3S_CPU_POWER7
:
7863 case BOOK3S_CPU_POWER8
:
7864 gen_spr_book3s_ids(env
);
7866 gen_spr_book3s_purr(env
);
7867 env
->ci_large_pages
= true;
7870 g_assert_not_reached();
7872 if (version
>= BOOK3S_CPU_POWER5PLUS
) {
7873 gen_spr_power5p_common(env
);
7874 gen_spr_power5p_lpar(env
);
7875 gen_spr_power5p_ear(env
);
7877 gen_spr_970_lpar(env
);
7879 if (version
== BOOK3S_CPU_970
) {
7880 gen_spr_970_dbg(env
);
7882 if (version
>= BOOK3S_CPU_POWER6
) {
7883 gen_spr_power6_common(env
);
7884 gen_spr_power6_dbg(env
);
7886 if (version
>= BOOK3S_CPU_POWER8
) {
7887 gen_spr_power8_tce_address_control(env
);
7888 gen_spr_power8_ids(env
);
7889 gen_spr_power8_ebb(env
);
7890 gen_spr_power8_fscr(env
);
7891 gen_spr_power8_pmu_sup(env
);
7892 gen_spr_power8_pmu_user(env
);
7893 gen_spr_power8_tm(env
);
7896 if (version
< BOOK3S_CPU_POWER8
) {
7897 gen_spr_book3s_dbg(env
);
7899 #if !defined(CONFIG_USER_ONLY)
7901 case BOOK3S_CPU_970
:
7902 case BOOK3S_CPU_POWER5PLUS
:
7905 case BOOK3S_CPU_POWER7
:
7906 case BOOK3S_CPU_POWER8
:
7912 /* Allocate hardware IRQ controller */
7914 case BOOK3S_CPU_970
:
7915 case BOOK3S_CPU_POWER5PLUS
:
7917 ppc970_irq_init(env
);
7919 case BOOK3S_CPU_POWER7
:
7920 case BOOK3S_CPU_POWER8
:
7921 init_excp_POWER7(env
);
7922 ppcPOWER7_irq_init(env
);
7925 g_assert_not_reached();
7928 env
->dcache_line_size
= 128;
7929 env
->icache_line_size
= 128;
7932 static void init_proc_970(CPUPPCState
*env
)
7934 init_proc_book3s_64(env
, BOOK3S_CPU_970
);
7937 POWERPC_FAMILY(970)(ObjectClass
*oc
, void *data
)
7939 DeviceClass
*dc
= DEVICE_CLASS(oc
);
7940 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
7942 dc
->desc
= "PowerPC 970";
7943 pcc
->init_proc
= init_proc_970
;
7944 pcc
->check_pow
= check_pow_970
;
7945 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
7946 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
7947 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
7949 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
7950 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
7951 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
7952 PPC_64B
| PPC_ALTIVEC
|
7953 PPC_SEGMENT_64B
| PPC_SLBI
;
7954 pcc
->insns_flags2
= PPC2_FP_CVT_S64
;
7955 pcc
->msr_mask
= (1ull << MSR_SF
) |
7970 pcc
->mmu_model
= POWERPC_MMU_64B
;
7971 #if defined(CONFIG_SOFTMMU)
7972 pcc
->handle_mmu_fault
= ppc_hash64_handle_mmu_fault
;
7974 pcc
->excp_model
= POWERPC_EXCP_970
;
7975 pcc
->bus_model
= PPC_FLAGS_INPUT_970
;
7976 pcc
->bfd_mach
= bfd_mach_ppc64
;
7977 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
7978 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
7979 POWERPC_FLAG_BUS_CLK
;
7980 pcc
->l1_dcache_size
= 0x8000;
7981 pcc
->l1_icache_size
= 0x10000;
7984 static void init_proc_power5plus(CPUPPCState
*env
)
7986 init_proc_book3s_64(env
, BOOK3S_CPU_POWER5PLUS
);
7989 POWERPC_FAMILY(POWER5P
)(ObjectClass
*oc
, void *data
)
7991 DeviceClass
*dc
= DEVICE_CLASS(oc
);
7992 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
7994 dc
->fw_name
= "PowerPC,POWER5";
7995 dc
->desc
= "POWER5+";
7996 pcc
->init_proc
= init_proc_power5plus
;
7997 pcc
->check_pow
= check_pow_970
;
7998 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_STRING
| PPC_MFTB
|
7999 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
8000 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
8002 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
8003 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
8004 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
8006 PPC_SEGMENT_64B
| PPC_SLBI
;
8007 pcc
->insns_flags2
= PPC2_FP_CVT_S64
;
8008 pcc
->msr_mask
= (1ull << MSR_SF
) |
8023 pcc
->mmu_model
= POWERPC_MMU_2_03
;
8024 #if defined(CONFIG_SOFTMMU)
8025 pcc
->handle_mmu_fault
= ppc_hash64_handle_mmu_fault
;
8027 pcc
->excp_model
= POWERPC_EXCP_970
;
8028 pcc
->bus_model
= PPC_FLAGS_INPUT_970
;
8029 pcc
->bfd_mach
= bfd_mach_ppc64
;
8030 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
8031 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
8032 POWERPC_FLAG_BUS_CLK
;
8033 pcc
->l1_dcache_size
= 0x8000;
8034 pcc
->l1_icache_size
= 0x10000;
8037 static void powerpc_get_compat(Object
*obj
, Visitor
*v
,
8038 void *opaque
, const char *name
, Error
**errp
)
8040 char *value
= (char *)"";
8041 Property
*prop
= opaque
;
8042 uint32_t *max_compat
= qdev_get_prop_ptr(DEVICE(obj
), prop
);
8044 switch (*max_compat
) {
8045 case CPU_POWERPC_LOGICAL_2_05
:
8046 value
= (char *)"power6";
8048 case CPU_POWERPC_LOGICAL_2_06
:
8049 value
= (char *)"power7";
8051 case CPU_POWERPC_LOGICAL_2_07
:
8052 value
= (char *)"power8";
8057 error_setg(errp
, "Internal error: compat is set to %x",
8058 max_compat
? *max_compat
: -1);
8062 visit_type_str(v
, &value
, name
, errp
);
8065 static void powerpc_set_compat(Object
*obj
, Visitor
*v
,
8066 void *opaque
, const char *name
, Error
**errp
)
8068 Error
*error
= NULL
;
8070 Property
*prop
= opaque
;
8071 uint32_t *max_compat
= qdev_get_prop_ptr(DEVICE(obj
), prop
);
8073 visit_type_str(v
, &value
, name
, &error
);
8075 error_propagate(errp
, error
);
8079 if (strcmp(value
, "power6") == 0) {
8080 *max_compat
= CPU_POWERPC_LOGICAL_2_05
;
8081 } else if (strcmp(value
, "power7") == 0) {
8082 *max_compat
= CPU_POWERPC_LOGICAL_2_06
;
8083 } else if (strcmp(value
, "power8") == 0) {
8084 *max_compat
= CPU_POWERPC_LOGICAL_2_07
;
8086 error_setg(errp
, "Invalid compatibility mode \"%s\"", value
);
8092 static PropertyInfo powerpc_compat_propinfo
= {
8094 .description
= "compatibility mode, power6/power7/power8",
8095 .get
= powerpc_get_compat
,
8096 .set
= powerpc_set_compat
,
8099 #define DEFINE_PROP_POWERPC_COMPAT(_n, _s, _f) \
8100 DEFINE_PROP(_n, _s, _f, powerpc_compat_propinfo, uint32_t)
8102 static Property powerpc_servercpu_properties
[] = {
8103 DEFINE_PROP_POWERPC_COMPAT("compat", PowerPCCPU
, max_compat
),
8104 DEFINE_PROP_END_OF_LIST(),
8107 static void init_proc_POWER7 (CPUPPCState
*env
)
8109 init_proc_book3s_64(env
, BOOK3S_CPU_POWER7
);
8112 static bool ppc_pvr_match_power7(PowerPCCPUClass
*pcc
, uint32_t pvr
)
8114 if ((pvr
& CPU_POWERPC_POWER_SERVER_MASK
) == CPU_POWERPC_POWER7P_BASE
) {
8117 if ((pvr
& CPU_POWERPC_POWER_SERVER_MASK
) == CPU_POWERPC_POWER7_BASE
) {
8123 POWERPC_FAMILY(POWER7
)(ObjectClass
*oc
, void *data
)
8125 DeviceClass
*dc
= DEVICE_CLASS(oc
);
8126 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
8128 dc
->fw_name
= "PowerPC,POWER7";
8129 dc
->desc
= "POWER7";
8130 dc
->props
= powerpc_servercpu_properties
;
8131 pcc
->pvr_match
= ppc_pvr_match_power7
;
8132 pcc
->pcr_mask
= PCR_COMPAT_2_05
| PCR_COMPAT_2_06
;
8133 pcc
->init_proc
= init_proc_POWER7
;
8134 pcc
->check_pow
= check_pow_nocheck
;
8135 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_ISEL
| PPC_STRING
| PPC_MFTB
|
8136 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
8137 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
8138 PPC_FLOAT_FRSQRTES
|
8141 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
8142 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
8143 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
8144 PPC_64B
| PPC_ALTIVEC
|
8145 PPC_SEGMENT_64B
| PPC_SLBI
|
8146 PPC_POPCNTB
| PPC_POPCNTWD
;
8147 pcc
->insns_flags2
= PPC2_VSX
| PPC2_DFP
| PPC2_DBRX
| PPC2_ISA205
|
8148 PPC2_PERM_ISA206
| PPC2_DIVE_ISA206
|
8149 PPC2_ATOMIC_ISA206
| PPC2_FP_CVT_ISA206
|
8150 PPC2_FP_TST_ISA206
| PPC2_FP_CVT_S64
;
8151 pcc
->msr_mask
= (1ull << MSR_SF
) |
8167 pcc
->mmu_model
= POWERPC_MMU_2_06
;
8168 #if defined(CONFIG_SOFTMMU)
8169 pcc
->handle_mmu_fault
= ppc_hash64_handle_mmu_fault
;
8171 pcc
->excp_model
= POWERPC_EXCP_POWER7
;
8172 pcc
->bus_model
= PPC_FLAGS_INPUT_POWER7
;
8173 pcc
->bfd_mach
= bfd_mach_ppc64
;
8174 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
8175 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
8176 POWERPC_FLAG_BUS_CLK
| POWERPC_FLAG_CFAR
|
8178 pcc
->l1_dcache_size
= 0x8000;
8179 pcc
->l1_icache_size
= 0x8000;
8180 pcc
->interrupts_big_endian
= ppc_cpu_interrupts_big_endian_lpcr
;
8183 static void init_proc_POWER8(CPUPPCState
*env
)
8185 init_proc_book3s_64(env
, BOOK3S_CPU_POWER8
);
8188 static bool ppc_pvr_match_power8(PowerPCCPUClass
*pcc
, uint32_t pvr
)
8190 if ((pvr
& CPU_POWERPC_POWER_SERVER_MASK
) == CPU_POWERPC_POWER8E_BASE
) {
8193 if ((pvr
& CPU_POWERPC_POWER_SERVER_MASK
) == CPU_POWERPC_POWER8_BASE
) {
8199 POWERPC_FAMILY(POWER8
)(ObjectClass
*oc
, void *data
)
8201 DeviceClass
*dc
= DEVICE_CLASS(oc
);
8202 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
8204 dc
->fw_name
= "PowerPC,POWER8";
8205 dc
->desc
= "POWER8";
8206 dc
->props
= powerpc_servercpu_properties
;
8207 pcc
->pvr_match
= ppc_pvr_match_power8
;
8208 pcc
->pcr_mask
= PCR_COMPAT_2_05
| PCR_COMPAT_2_06
;
8209 pcc
->init_proc
= init_proc_POWER8
;
8210 pcc
->check_pow
= check_pow_nocheck
;
8211 pcc
->insns_flags
= PPC_INSNS_BASE
| PPC_ISEL
| PPC_STRING
| PPC_MFTB
|
8212 PPC_FLOAT
| PPC_FLOAT_FSEL
| PPC_FLOAT_FRES
|
8213 PPC_FLOAT_FSQRT
| PPC_FLOAT_FRSQRTE
|
8214 PPC_FLOAT_FRSQRTES
|
8217 PPC_CACHE
| PPC_CACHE_ICBI
| PPC_CACHE_DCBZ
|
8218 PPC_MEM_SYNC
| PPC_MEM_EIEIO
|
8219 PPC_MEM_TLBIE
| PPC_MEM_TLBSYNC
|
8220 PPC_64B
| PPC_64BX
| PPC_ALTIVEC
|
8221 PPC_SEGMENT_64B
| PPC_SLBI
|
8222 PPC_POPCNTB
| PPC_POPCNTWD
;
8223 pcc
->insns_flags2
= PPC2_VSX
| PPC2_VSX207
| PPC2_DFP
| PPC2_DBRX
|
8224 PPC2_PERM_ISA206
| PPC2_DIVE_ISA206
|
8225 PPC2_ATOMIC_ISA206
| PPC2_FP_CVT_ISA206
|
8226 PPC2_FP_TST_ISA206
| PPC2_BCTAR_ISA207
|
8227 PPC2_LSQ_ISA207
| PPC2_ALTIVEC_207
|
8228 PPC2_ISA205
| PPC2_ISA207S
| PPC2_FP_CVT_S64
|
8230 pcc
->msr_mask
= (1ull << MSR_SF
) |
8247 pcc
->mmu_model
= POWERPC_MMU_2_07
;
8248 #if defined(CONFIG_SOFTMMU)
8249 pcc
->handle_mmu_fault
= ppc_hash64_handle_mmu_fault
;
8251 pcc
->excp_model
= POWERPC_EXCP_POWER7
;
8252 pcc
->bus_model
= PPC_FLAGS_INPUT_POWER7
;
8253 pcc
->bfd_mach
= bfd_mach_ppc64
;
8254 pcc
->flags
= POWERPC_FLAG_VRE
| POWERPC_FLAG_SE
|
8255 POWERPC_FLAG_BE
| POWERPC_FLAG_PMM
|
8256 POWERPC_FLAG_BUS_CLK
| POWERPC_FLAG_CFAR
|
8257 POWERPC_FLAG_VSX
| POWERPC_FLAG_TM
;
8258 pcc
->l1_dcache_size
= 0x8000;
8259 pcc
->l1_icache_size
= 0x8000;
8260 pcc
->interrupts_big_endian
= ppc_cpu_interrupts_big_endian_lpcr
;
8262 #endif /* defined (TARGET_PPC64) */
8265 /*****************************************************************************/
8266 /* Generic CPU instantiation routine */
8267 static void init_ppc_proc(PowerPCCPU
*cpu
)
8269 PowerPCCPUClass
*pcc
= POWERPC_CPU_GET_CLASS(cpu
);
8270 CPUPPCState
*env
= &cpu
->env
;
8271 #if !defined(CONFIG_USER_ONLY)
8274 env
->irq_inputs
= NULL
;
8275 /* Set all exception vectors to an invalid address */
8276 for (i
= 0; i
< POWERPC_EXCP_NB
; i
++)
8277 env
->excp_vectors
[i
] = (target_ulong
)(-1ULL);
8278 env
->ivor_mask
= 0x00000000;
8279 env
->ivpr_mask
= 0x00000000;
8280 /* Default MMU definitions */
8284 env
->tlb_type
= TLB_NONE
;
8286 /* Register SPR common to all PowerPC implementations */
8287 gen_spr_generic(env
);
8288 spr_register(env
, SPR_PVR
, "PVR",
8289 /* Linux permits userspace to read PVR */
8290 #if defined(CONFIG_LINUX_USER)
8296 &spr_read_generic
, SPR_NOACCESS
,
8298 /* Register SVR if it's defined to anything else than POWERPC_SVR_NONE */
8299 if (pcc
->svr
!= POWERPC_SVR_NONE
) {
8300 if (pcc
->svr
& POWERPC_SVR_E500
) {
8301 spr_register(env
, SPR_E500_SVR
, "SVR",
8302 SPR_NOACCESS
, SPR_NOACCESS
,
8303 &spr_read_generic
, SPR_NOACCESS
,
8304 pcc
->svr
& ~POWERPC_SVR_E500
);
8306 spr_register(env
, SPR_SVR
, "SVR",
8307 SPR_NOACCESS
, SPR_NOACCESS
,
8308 &spr_read_generic
, SPR_NOACCESS
,
8312 /* PowerPC implementation specific initialisations (SPRs, timers, ...) */
8313 (*pcc
->init_proc
)(env
);
8315 /* MSR bits & flags consistency checks */
8316 if (env
->msr_mask
& (1 << 25)) {
8317 switch (env
->flags
& (POWERPC_FLAG_SPE
| POWERPC_FLAG_VRE
)) {
8318 case POWERPC_FLAG_SPE
:
8319 case POWERPC_FLAG_VRE
:
8322 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8323 "Should define POWERPC_FLAG_SPE or POWERPC_FLAG_VRE\n");
8326 } else if (env
->flags
& (POWERPC_FLAG_SPE
| POWERPC_FLAG_VRE
)) {
8327 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8328 "Should not define POWERPC_FLAG_SPE nor POWERPC_FLAG_VRE\n");
8331 if (env
->msr_mask
& (1 << 17)) {
8332 switch (env
->flags
& (POWERPC_FLAG_TGPR
| POWERPC_FLAG_CE
)) {
8333 case POWERPC_FLAG_TGPR
:
8334 case POWERPC_FLAG_CE
:
8337 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8338 "Should define POWERPC_FLAG_TGPR or POWERPC_FLAG_CE\n");
8341 } else if (env
->flags
& (POWERPC_FLAG_TGPR
| POWERPC_FLAG_CE
)) {
8342 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8343 "Should not define POWERPC_FLAG_TGPR nor POWERPC_FLAG_CE\n");
8346 if (env
->msr_mask
& (1 << 10)) {
8347 switch (env
->flags
& (POWERPC_FLAG_SE
| POWERPC_FLAG_DWE
|
8348 POWERPC_FLAG_UBLE
)) {
8349 case POWERPC_FLAG_SE
:
8350 case POWERPC_FLAG_DWE
:
8351 case POWERPC_FLAG_UBLE
:
8354 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8355 "Should define POWERPC_FLAG_SE or POWERPC_FLAG_DWE or "
8356 "POWERPC_FLAG_UBLE\n");
8359 } else if (env
->flags
& (POWERPC_FLAG_SE
| POWERPC_FLAG_DWE
|
8360 POWERPC_FLAG_UBLE
)) {
8361 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8362 "Should not define POWERPC_FLAG_SE nor POWERPC_FLAG_DWE nor "
8363 "POWERPC_FLAG_UBLE\n");
8366 if (env
->msr_mask
& (1 << 9)) {
8367 switch (env
->flags
& (POWERPC_FLAG_BE
| POWERPC_FLAG_DE
)) {
8368 case POWERPC_FLAG_BE
:
8369 case POWERPC_FLAG_DE
:
8372 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8373 "Should define POWERPC_FLAG_BE or POWERPC_FLAG_DE\n");
8376 } else if (env
->flags
& (POWERPC_FLAG_BE
| POWERPC_FLAG_DE
)) {
8377 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8378 "Should not define POWERPC_FLAG_BE nor POWERPC_FLAG_DE\n");
8381 if (env
->msr_mask
& (1 << 2)) {
8382 switch (env
->flags
& (POWERPC_FLAG_PX
| POWERPC_FLAG_PMM
)) {
8383 case POWERPC_FLAG_PX
:
8384 case POWERPC_FLAG_PMM
:
8387 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8388 "Should define POWERPC_FLAG_PX or POWERPC_FLAG_PMM\n");
8391 } else if (env
->flags
& (POWERPC_FLAG_PX
| POWERPC_FLAG_PMM
)) {
8392 fprintf(stderr
, "PowerPC MSR definition inconsistency\n"
8393 "Should not define POWERPC_FLAG_PX nor POWERPC_FLAG_PMM\n");
8396 if ((env
->flags
& (POWERPC_FLAG_RTC_CLK
| POWERPC_FLAG_BUS_CLK
)) == 0) {
8397 fprintf(stderr
, "PowerPC flags inconsistency\n"
8398 "Should define the time-base and decrementer clock source\n");
8401 /* Allocate TLBs buffer when needed */
8402 #if !defined(CONFIG_USER_ONLY)
8403 if (env
->nb_tlb
!= 0) {
8404 int nb_tlb
= env
->nb_tlb
;
8405 if (env
->id_tlbs
!= 0)
8407 switch (env
->tlb_type
) {
8409 env
->tlb
.tlb6
= g_malloc0(nb_tlb
* sizeof(ppc6xx_tlb_t
));
8412 env
->tlb
.tlbe
= g_malloc0(nb_tlb
* sizeof(ppcemb_tlb_t
));
8415 env
->tlb
.tlbm
= g_malloc0(nb_tlb
* sizeof(ppcmas_tlb_t
));
8418 /* Pre-compute some useful values */
8419 env
->tlb_per_way
= env
->nb_tlb
/ env
->nb_ways
;
8421 if (env
->irq_inputs
== NULL
) {
8422 fprintf(stderr
, "WARNING: no internal IRQ controller registered.\n"
8423 " Attempt QEMU to crash very soon !\n");
8426 if (env
->check_pow
== NULL
) {
8427 fprintf(stderr
, "WARNING: no power management check handler "
8429 " Attempt QEMU to crash very soon !\n");
8433 #if defined(PPC_DUMP_CPU)
8434 static void dump_ppc_sprs (CPUPPCState
*env
)
8437 #if !defined(CONFIG_USER_ONLY)
8443 printf("Special purpose registers:\n");
8444 for (i
= 0; i
< 32; i
++) {
8445 for (j
= 0; j
< 32; j
++) {
8447 spr
= &env
->spr_cb
[n
];
8448 uw
= spr
->uea_write
!= NULL
&& spr
->uea_write
!= SPR_NOACCESS
;
8449 ur
= spr
->uea_read
!= NULL
&& spr
->uea_read
!= SPR_NOACCESS
;
8450 #if !defined(CONFIG_USER_ONLY)
8451 sw
= spr
->oea_write
!= NULL
&& spr
->oea_write
!= SPR_NOACCESS
;
8452 sr
= spr
->oea_read
!= NULL
&& spr
->oea_read
!= SPR_NOACCESS
;
8453 if (sw
|| sr
|| uw
|| ur
) {
8454 printf("SPR: %4d (%03x) %-8s s%c%c u%c%c\n",
8455 (i
<< 5) | j
, (i
<< 5) | j
, spr
->name
,
8456 sw
? 'w' : '-', sr
? 'r' : '-',
8457 uw
? 'w' : '-', ur
? 'r' : '-');
8461 printf("SPR: %4d (%03x) %-8s u%c%c\n",
8462 (i
<< 5) | j
, (i
<< 5) | j
, spr
->name
,
8463 uw
? 'w' : '-', ur
? 'r' : '-');
8473 /*****************************************************************************/
8479 PPC_DIRECT
= 0, /* Opcode routine */
8480 PPC_INDIRECT
= 1, /* Indirect opcode table */
8483 #define PPC_OPCODE_MASK 0x3
8485 static inline int is_indirect_opcode (void *handler
)
8487 return ((uintptr_t)handler
& PPC_OPCODE_MASK
) == PPC_INDIRECT
;
8490 static inline opc_handler_t
**ind_table(void *handler
)
8492 return (opc_handler_t
**)((uintptr_t)handler
& ~PPC_OPCODE_MASK
);
8495 /* Instruction table creation */
8496 /* Opcodes tables creation */
8497 static void fill_new_table (opc_handler_t
**table
, int len
)
8501 for (i
= 0; i
< len
; i
++)
8502 table
[i
] = &invalid_handler
;
8505 static int create_new_table (opc_handler_t
**table
, unsigned char idx
)
8507 opc_handler_t
**tmp
;
8509 tmp
= g_new(opc_handler_t
*, PPC_CPU_INDIRECT_OPCODES_LEN
);
8510 fill_new_table(tmp
, PPC_CPU_INDIRECT_OPCODES_LEN
);
8511 table
[idx
] = (opc_handler_t
*)((uintptr_t)tmp
| PPC_INDIRECT
);
8516 static int insert_in_table (opc_handler_t
**table
, unsigned char idx
,
8517 opc_handler_t
*handler
)
8519 if (table
[idx
] != &invalid_handler
)
8521 table
[idx
] = handler
;
8526 static int register_direct_insn (opc_handler_t
**ppc_opcodes
,
8527 unsigned char idx
, opc_handler_t
*handler
)
8529 if (insert_in_table(ppc_opcodes
, idx
, handler
) < 0) {
8530 printf("*** ERROR: opcode %02x already assigned in main "
8531 "opcode table\n", idx
);
8532 #if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
8533 printf(" Registered handler '%s' - new handler '%s'\n",
8534 ppc_opcodes
[idx
]->oname
, handler
->oname
);
8542 static int register_ind_in_table (opc_handler_t
**table
,
8543 unsigned char idx1
, unsigned char idx2
,
8544 opc_handler_t
*handler
)
8546 if (table
[idx1
] == &invalid_handler
) {
8547 if (create_new_table(table
, idx1
) < 0) {
8548 printf("*** ERROR: unable to create indirect table "
8549 "idx=%02x\n", idx1
);
8553 if (!is_indirect_opcode(table
[idx1
])) {
8554 printf("*** ERROR: idx %02x already assigned to a direct "
8556 #if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
8557 printf(" Registered handler '%s' - new handler '%s'\n",
8558 ind_table(table
[idx1
])[idx2
]->oname
, handler
->oname
);
8563 if (handler
!= NULL
&&
8564 insert_in_table(ind_table(table
[idx1
]), idx2
, handler
) < 0) {
8565 printf("*** ERROR: opcode %02x already assigned in "
8566 "opcode table %02x\n", idx2
, idx1
);
8567 #if defined(DO_PPC_STATISTICS) || defined(PPC_DUMP_CPU)
8568 printf(" Registered handler '%s' - new handler '%s'\n",
8569 ind_table(table
[idx1
])[idx2
]->oname
, handler
->oname
);
8577 static int register_ind_insn (opc_handler_t
**ppc_opcodes
,
8578 unsigned char idx1
, unsigned char idx2
,
8579 opc_handler_t
*handler
)
8581 return register_ind_in_table(ppc_opcodes
, idx1
, idx2
, handler
);
8584 static int register_dblind_insn (opc_handler_t
**ppc_opcodes
,
8585 unsigned char idx1
, unsigned char idx2
,
8586 unsigned char idx3
, opc_handler_t
*handler
)
8588 if (register_ind_in_table(ppc_opcodes
, idx1
, idx2
, NULL
) < 0) {
8589 printf("*** ERROR: unable to join indirect table idx "
8590 "[%02x-%02x]\n", idx1
, idx2
);
8593 if (register_ind_in_table(ind_table(ppc_opcodes
[idx1
]), idx2
, idx3
,
8595 printf("*** ERROR: unable to insert opcode "
8596 "[%02x-%02x-%02x]\n", idx1
, idx2
, idx3
);
8603 static int register_insn (opc_handler_t
**ppc_opcodes
, opcode_t
*insn
)
8605 if (insn
->opc2
!= 0xFF) {
8606 if (insn
->opc3
!= 0xFF) {
8607 if (register_dblind_insn(ppc_opcodes
, insn
->opc1
, insn
->opc2
,
8608 insn
->opc3
, &insn
->handler
) < 0)
8611 if (register_ind_insn(ppc_opcodes
, insn
->opc1
,
8612 insn
->opc2
, &insn
->handler
) < 0)
8616 if (register_direct_insn(ppc_opcodes
, insn
->opc1
, &insn
->handler
) < 0)
8623 static int test_opcode_table (opc_handler_t
**table
, int len
)
8627 for (i
= 0, count
= 0; i
< len
; i
++) {
8628 /* Consistency fixup */
8629 if (table
[i
] == NULL
)
8630 table
[i
] = &invalid_handler
;
8631 if (table
[i
] != &invalid_handler
) {
8632 if (is_indirect_opcode(table
[i
])) {
8633 tmp
= test_opcode_table(ind_table(table
[i
]),
8634 PPC_CPU_INDIRECT_OPCODES_LEN
);
8637 table
[i
] = &invalid_handler
;
8650 static void fix_opcode_tables (opc_handler_t
**ppc_opcodes
)
8652 if (test_opcode_table(ppc_opcodes
, PPC_CPU_OPCODES_LEN
) == 0)
8653 printf("*** WARNING: no opcode defined !\n");
8656 /*****************************************************************************/
8657 static void create_ppc_opcodes(PowerPCCPU
*cpu
, Error
**errp
)
8659 PowerPCCPUClass
*pcc
= POWERPC_CPU_GET_CLASS(cpu
);
8660 CPUPPCState
*env
= &cpu
->env
;
8663 fill_new_table(env
->opcodes
, PPC_CPU_OPCODES_LEN
);
8664 for (opc
= opcodes
; opc
< &opcodes
[ARRAY_SIZE(opcodes
)]; opc
++) {
8665 if (((opc
->handler
.type
& pcc
->insns_flags
) != 0) ||
8666 ((opc
->handler
.type2
& pcc
->insns_flags2
) != 0)) {
8667 if (register_insn(env
->opcodes
, opc
) < 0) {
8668 error_setg(errp
, "ERROR initializing PowerPC instruction "
8669 "0x%02x 0x%02x 0x%02x", opc
->opc1
, opc
->opc2
,
8675 fix_opcode_tables(env
->opcodes
);
8680 #if defined(PPC_DUMP_CPU)
8681 static void dump_ppc_insns (CPUPPCState
*env
)
8683 opc_handler_t
**table
, *handler
;
8685 uint8_t opc1
, opc2
, opc3
;
8687 printf("Instructions set:\n");
8688 /* opc1 is 6 bits long */
8689 for (opc1
= 0x00; opc1
< PPC_CPU_OPCODES_LEN
; opc1
++) {
8690 table
= env
->opcodes
;
8691 handler
= table
[opc1
];
8692 if (is_indirect_opcode(handler
)) {
8693 /* opc2 is 5 bits long */
8694 for (opc2
= 0; opc2
< PPC_CPU_INDIRECT_OPCODES_LEN
; opc2
++) {
8695 table
= env
->opcodes
;
8696 handler
= env
->opcodes
[opc1
];
8697 table
= ind_table(handler
);
8698 handler
= table
[opc2
];
8699 if (is_indirect_opcode(handler
)) {
8700 table
= ind_table(handler
);
8701 /* opc3 is 5 bits long */
8702 for (opc3
= 0; opc3
< PPC_CPU_INDIRECT_OPCODES_LEN
;
8704 handler
= table
[opc3
];
8705 if (handler
->handler
!= &gen_invalid
) {
8706 /* Special hack to properly dump SPE insns */
8707 p
= strchr(handler
->oname
, '_');
8709 printf("INSN: %02x %02x %02x (%02d %04d) : "
8711 opc1
, opc2
, opc3
, opc1
,
8716 if ((p
- handler
->oname
) != strlen(q
) ||
8717 memcmp(handler
->oname
, q
, strlen(q
)) != 0) {
8718 /* First instruction */
8719 printf("INSN: %02x %02x %02x (%02d %04d) : "
8721 opc1
, opc2
<< 1, opc3
, opc1
,
8722 (opc3
<< 6) | (opc2
<< 1),
8723 (int)(p
- handler
->oname
),
8726 if (strcmp(p
+ 1, q
) != 0) {
8727 /* Second instruction */
8728 printf("INSN: %02x %02x %02x (%02d %04d) : "
8730 opc1
, (opc2
<< 1) | 1, opc3
, opc1
,
8731 (opc3
<< 6) | (opc2
<< 1) | 1,
8738 if (handler
->handler
!= &gen_invalid
) {
8739 printf("INSN: %02x %02x -- (%02d %04d) : %s\n",
8740 opc1
, opc2
, opc1
, opc2
, handler
->oname
);
8745 if (handler
->handler
!= &gen_invalid
) {
8746 printf("INSN: %02x -- -- (%02d ----) : %s\n",
8747 opc1
, opc1
, handler
->oname
);
8754 static int gdb_get_float_reg(CPUPPCState
*env
, uint8_t *mem_buf
, int n
)
8757 stfq_p(mem_buf
, env
->fpr
[n
]);
8761 stl_p(mem_buf
, env
->fpscr
);
8767 static int gdb_set_float_reg(CPUPPCState
*env
, uint8_t *mem_buf
, int n
)
8770 env
->fpr
[n
] = ldfq_p(mem_buf
);
8774 helper_store_fpscr(env
, ldl_p(mem_buf
), 0xffffffff);
8780 static int gdb_get_avr_reg(CPUPPCState
*env
, uint8_t *mem_buf
, int n
)
8783 #ifdef HOST_WORDS_BIGENDIAN
8784 stq_p(mem_buf
, env
->avr
[n
].u64
[0]);
8785 stq_p(mem_buf
+8, env
->avr
[n
].u64
[1]);
8787 stq_p(mem_buf
, env
->avr
[n
].u64
[1]);
8788 stq_p(mem_buf
+8, env
->avr
[n
].u64
[0]);
8793 stl_p(mem_buf
, env
->vscr
);
8797 stl_p(mem_buf
, (uint32_t)env
->spr
[SPR_VRSAVE
]);
8803 static int gdb_set_avr_reg(CPUPPCState
*env
, uint8_t *mem_buf
, int n
)
8806 #ifdef HOST_WORDS_BIGENDIAN
8807 env
->avr
[n
].u64
[0] = ldq_p(mem_buf
);
8808 env
->avr
[n
].u64
[1] = ldq_p(mem_buf
+8);
8810 env
->avr
[n
].u64
[1] = ldq_p(mem_buf
);
8811 env
->avr
[n
].u64
[0] = ldq_p(mem_buf
+8);
8816 env
->vscr
= ldl_p(mem_buf
);
8820 env
->spr
[SPR_VRSAVE
] = (target_ulong
)ldl_p(mem_buf
);
8826 static int gdb_get_spe_reg(CPUPPCState
*env
, uint8_t *mem_buf
, int n
)
8829 #if defined(TARGET_PPC64)
8830 stl_p(mem_buf
, env
->gpr
[n
] >> 32);
8832 stl_p(mem_buf
, env
->gprh
[n
]);
8837 stq_p(mem_buf
, env
->spe_acc
);
8841 stl_p(mem_buf
, env
->spe_fscr
);
8847 static int gdb_set_spe_reg(CPUPPCState
*env
, uint8_t *mem_buf
, int n
)
8850 #if defined(TARGET_PPC64)
8851 target_ulong lo
= (uint32_t)env
->gpr
[n
];
8852 target_ulong hi
= (target_ulong
)ldl_p(mem_buf
) << 32;
8853 env
->gpr
[n
] = lo
| hi
;
8855 env
->gprh
[n
] = ldl_p(mem_buf
);
8860 env
->spe_acc
= ldq_p(mem_buf
);
8864 env
->spe_fscr
= ldl_p(mem_buf
);
8870 static int ppc_fixup_cpu(PowerPCCPU
*cpu
)
8872 CPUPPCState
*env
= &cpu
->env
;
8874 /* TCG doesn't (yet) emulate some groups of instructions that
8875 * are implemented on some otherwise supported CPUs (e.g. VSX
8876 * and decimal floating point instructions on POWER7). We
8877 * remove unsupported instruction groups from the cpu state's
8878 * instruction masks and hope the guest can cope. For at
8879 * least the pseries machine, the unavailability of these
8880 * instructions can be advertised to the guest via the device
8882 if ((env
->insns_flags
& ~PPC_TCG_INSNS
)
8883 || (env
->insns_flags2
& ~PPC_TCG_INSNS2
)) {
8884 fprintf(stderr
, "Warning: Disabling some instructions which are not "
8885 "emulated by TCG (0x%" PRIx64
", 0x%" PRIx64
")\n",
8886 env
->insns_flags
& ~PPC_TCG_INSNS
,
8887 env
->insns_flags2
& ~PPC_TCG_INSNS2
);
8889 env
->insns_flags
&= PPC_TCG_INSNS
;
8890 env
->insns_flags2
&= PPC_TCG_INSNS2
;
8894 static inline bool ppc_cpu_is_valid(PowerPCCPUClass
*pcc
)
8896 #ifdef TARGET_PPCEMB
8897 return pcc
->mmu_model
== POWERPC_MMU_BOOKE
||
8898 pcc
->mmu_model
== POWERPC_MMU_SOFT_4xx
||
8899 pcc
->mmu_model
== POWERPC_MMU_SOFT_4xx_Z
;
8905 static void ppc_cpu_realizefn(DeviceState
*dev
, Error
**errp
)
8907 CPUState
*cs
= CPU(dev
);
8908 PowerPCCPU
*cpu
= POWERPC_CPU(dev
);
8909 PowerPCCPUClass
*pcc
= POWERPC_CPU_GET_CLASS(cpu
);
8910 Error
*local_err
= NULL
;
8911 #if !defined(CONFIG_USER_ONLY)
8912 int max_smt
= kvm_enabled() ? kvmppc_smt_threads() : 1;
8915 #if !defined(CONFIG_USER_ONLY)
8916 if (smp_threads
> max_smt
) {
8917 error_setg(errp
, "Cannot support more than %d threads on PPC with %s",
8918 max_smt
, kvm_enabled() ? "KVM" : "TCG");
8921 if (!is_power_of_2(smp_threads
)) {
8922 error_setg(errp
, "Cannot support %d threads on PPC with %s, "
8923 "threads count must be a power of 2.",
8924 smp_threads
, kvm_enabled() ? "KVM" : "TCG");
8929 cpu_exec_init(cs
, &local_err
);
8930 if (local_err
!= NULL
) {
8931 error_propagate(errp
, local_err
);
8935 #if !defined(CONFIG_USER_ONLY)
8936 cpu
->cpu_dt_id
= (cs
->cpu_index
/ smp_threads
) * max_smt
8937 + (cs
->cpu_index
% smp_threads
);
8940 if (tcg_enabled()) {
8941 if (ppc_fixup_cpu(cpu
) != 0) {
8942 error_setg(errp
, "Unable to emulate selected CPU with TCG");
8947 #if defined(TARGET_PPCEMB)
8948 if (!ppc_cpu_is_valid(pcc
)) {
8949 error_setg(errp
, "CPU does not possess a BookE or 4xx MMU. "
8950 "Please use qemu-system-ppc or qemu-system-ppc64 instead "
8951 "or choose another CPU model.");
8956 create_ppc_opcodes(cpu
, &local_err
);
8957 if (local_err
!= NULL
) {
8958 error_propagate(errp
, local_err
);
8963 if (pcc
->insns_flags
& PPC_FLOAT
) {
8964 gdb_register_coprocessor(cs
, gdb_get_float_reg
, gdb_set_float_reg
,
8965 33, "power-fpu.xml", 0);
8967 if (pcc
->insns_flags
& PPC_ALTIVEC
) {
8968 gdb_register_coprocessor(cs
, gdb_get_avr_reg
, gdb_set_avr_reg
,
8969 34, "power-altivec.xml", 0);
8971 if (pcc
->insns_flags
& PPC_SPE
) {
8972 gdb_register_coprocessor(cs
, gdb_get_spe_reg
, gdb_set_spe_reg
,
8973 34, "power-spe.xml", 0);
8978 pcc
->parent_realize(dev
, errp
);
8980 #if defined(PPC_DUMP_CPU)
8982 CPUPPCState
*env
= &cpu
->env
;
8983 const char *mmu_model
, *excp_model
, *bus_model
;
8984 switch (env
->mmu_model
) {
8985 case POWERPC_MMU_32B
:
8986 mmu_model
= "PowerPC 32";
8988 case POWERPC_MMU_SOFT_6xx
:
8989 mmu_model
= "PowerPC 6xx/7xx with software driven TLBs";
8991 case POWERPC_MMU_SOFT_74xx
:
8992 mmu_model
= "PowerPC 74xx with software driven TLBs";
8994 case POWERPC_MMU_SOFT_4xx
:
8995 mmu_model
= "PowerPC 4xx with software driven TLBs";
8997 case POWERPC_MMU_SOFT_4xx_Z
:
8998 mmu_model
= "PowerPC 4xx with software driven TLBs "
8999 "and zones protections";
9001 case POWERPC_MMU_REAL
:
9002 mmu_model
= "PowerPC real mode only";
9004 case POWERPC_MMU_MPC8xx
:
9005 mmu_model
= "PowerPC MPC8xx";
9007 case POWERPC_MMU_BOOKE
:
9008 mmu_model
= "PowerPC BookE";
9010 case POWERPC_MMU_BOOKE206
:
9011 mmu_model
= "PowerPC BookE 2.06";
9013 case POWERPC_MMU_601
:
9014 mmu_model
= "PowerPC 601";
9016 #if defined (TARGET_PPC64)
9017 case POWERPC_MMU_64B
:
9018 mmu_model
= "PowerPC 64";
9022 mmu_model
= "Unknown or invalid";
9025 switch (env
->excp_model
) {
9026 case POWERPC_EXCP_STD
:
9027 excp_model
= "PowerPC";
9029 case POWERPC_EXCP_40x
:
9030 excp_model
= "PowerPC 40x";
9032 case POWERPC_EXCP_601
:
9033 excp_model
= "PowerPC 601";
9035 case POWERPC_EXCP_602
:
9036 excp_model
= "PowerPC 602";
9038 case POWERPC_EXCP_603
:
9039 excp_model
= "PowerPC 603";
9041 case POWERPC_EXCP_603E
:
9042 excp_model
= "PowerPC 603e";
9044 case POWERPC_EXCP_604
:
9045 excp_model
= "PowerPC 604";
9047 case POWERPC_EXCP_7x0
:
9048 excp_model
= "PowerPC 740/750";
9050 case POWERPC_EXCP_7x5
:
9051 excp_model
= "PowerPC 745/755";
9053 case POWERPC_EXCP_74xx
:
9054 excp_model
= "PowerPC 74xx";
9056 case POWERPC_EXCP_BOOKE
:
9057 excp_model
= "PowerPC BookE";
9059 #if defined (TARGET_PPC64)
9060 case POWERPC_EXCP_970
:
9061 excp_model
= "PowerPC 970";
9065 excp_model
= "Unknown or invalid";
9068 switch (env
->bus_model
) {
9069 case PPC_FLAGS_INPUT_6xx
:
9070 bus_model
= "PowerPC 6xx";
9072 case PPC_FLAGS_INPUT_BookE
:
9073 bus_model
= "PowerPC BookE";
9075 case PPC_FLAGS_INPUT_405
:
9076 bus_model
= "PowerPC 405";
9078 case PPC_FLAGS_INPUT_401
:
9079 bus_model
= "PowerPC 401/403";
9081 case PPC_FLAGS_INPUT_RCPU
:
9082 bus_model
= "RCPU / MPC8xx";
9084 #if defined (TARGET_PPC64)
9085 case PPC_FLAGS_INPUT_970
:
9086 bus_model
= "PowerPC 970";
9090 bus_model
= "Unknown or invalid";
9093 printf("PowerPC %-12s : PVR %08x MSR %016" PRIx64
"\n"
9094 " MMU model : %s\n",
9095 object_class_get_name(OBJECT_CLASS(pcc
)),
9096 pcc
->pvr
, pcc
->msr_mask
, mmu_model
);
9097 #if !defined(CONFIG_USER_ONLY)
9098 if (env
->tlb
.tlb6
) {
9099 printf(" %d %s TLB in %d ways\n",
9100 env
->nb_tlb
, env
->id_tlbs
? "splitted" : "merged",
9104 printf(" Exceptions model : %s\n"
9105 " Bus model : %s\n",
9106 excp_model
, bus_model
);
9107 printf(" MSR features :\n");
9108 if (env
->flags
& POWERPC_FLAG_SPE
)
9109 printf(" signal processing engine enable"
9111 else if (env
->flags
& POWERPC_FLAG_VRE
)
9112 printf(" vector processor enable\n");
9113 if (env
->flags
& POWERPC_FLAG_TGPR
)
9114 printf(" temporary GPRs\n");
9115 else if (env
->flags
& POWERPC_FLAG_CE
)
9116 printf(" critical input enable\n");
9117 if (env
->flags
& POWERPC_FLAG_SE
)
9118 printf(" single-step trace mode\n");
9119 else if (env
->flags
& POWERPC_FLAG_DWE
)
9120 printf(" debug wait enable\n");
9121 else if (env
->flags
& POWERPC_FLAG_UBLE
)
9122 printf(" user BTB lock enable\n");
9123 if (env
->flags
& POWERPC_FLAG_BE
)
9124 printf(" branch-step trace mode\n");
9125 else if (env
->flags
& POWERPC_FLAG_DE
)
9126 printf(" debug interrupt enable\n");
9127 if (env
->flags
& POWERPC_FLAG_PX
)
9128 printf(" inclusive protection\n");
9129 else if (env
->flags
& POWERPC_FLAG_PMM
)
9130 printf(" performance monitor mark\n");
9131 if (env
->flags
== POWERPC_FLAG_NONE
)
9133 printf(" Time-base/decrementer clock source: %s\n",
9134 env
->flags
& POWERPC_FLAG_RTC_CLK
? "RTC clock" : "bus clock");
9135 dump_ppc_insns(env
);
9142 static void ppc_cpu_unrealizefn(DeviceState
*dev
, Error
**errp
)
9144 PowerPCCPU
*cpu
= POWERPC_CPU(dev
);
9145 CPUPPCState
*env
= &cpu
->env
;
9146 opc_handler_t
**table
;
9149 cpu_exec_exit(CPU(dev
));
9151 for (i
= 0; i
< PPC_CPU_OPCODES_LEN
; i
++) {
9152 if (env
->opcodes
[i
] == &invalid_handler
) {
9155 if (is_indirect_opcode(env
->opcodes
[i
])) {
9156 table
= ind_table(env
->opcodes
[i
]);
9157 for (j
= 0; j
< PPC_CPU_INDIRECT_OPCODES_LEN
; j
++) {
9158 if (table
[j
] != &invalid_handler
&&
9159 is_indirect_opcode(table
[j
])) {
9160 g_free((opc_handler_t
*)((uintptr_t)table
[j
] &
9164 g_free((opc_handler_t
*)((uintptr_t)env
->opcodes
[i
] &
9170 int ppc_get_compat_smt_threads(PowerPCCPU
*cpu
)
9172 int ret
= MIN(smp_threads
, kvmppc_smt_threads());
9174 switch (cpu
->cpu_version
) {
9175 case CPU_POWERPC_LOGICAL_2_05
:
9178 case CPU_POWERPC_LOGICAL_2_06
:
9181 case CPU_POWERPC_LOGICAL_2_07
:
9189 int ppc_set_compat(PowerPCCPU
*cpu
, uint32_t cpu_version
)
9192 CPUPPCState
*env
= &cpu
->env
;
9194 cpu
->cpu_version
= cpu_version
;
9196 switch (cpu_version
) {
9197 case CPU_POWERPC_LOGICAL_2_05
:
9198 env
->spr
[SPR_PCR
] = PCR_COMPAT_2_05
;
9200 case CPU_POWERPC_LOGICAL_2_06
:
9201 env
->spr
[SPR_PCR
] = PCR_COMPAT_2_06
;
9203 case CPU_POWERPC_LOGICAL_2_06_PLUS
:
9204 env
->spr
[SPR_PCR
] = PCR_COMPAT_2_06
;
9207 env
->spr
[SPR_PCR
] = 0;
9211 if (kvm_enabled() && kvmppc_set_compat(cpu
, cpu
->cpu_version
) < 0) {
9212 error_report("Unable to set compatibility mode in KVM");
9219 static gint
ppc_cpu_compare_class_pvr(gconstpointer a
, gconstpointer b
)
9221 ObjectClass
*oc
= (ObjectClass
*)a
;
9222 uint32_t pvr
= *(uint32_t *)b
;
9223 PowerPCCPUClass
*pcc
= (PowerPCCPUClass
*)a
;
9225 /* -cpu host does a PVR lookup during construction */
9226 if (unlikely(strcmp(object_class_get_name(oc
),
9227 TYPE_HOST_POWERPC_CPU
) == 0)) {
9231 if (!ppc_cpu_is_valid(pcc
)) {
9235 return pcc
->pvr
== pvr
? 0 : -1;
9238 PowerPCCPUClass
*ppc_cpu_class_by_pvr(uint32_t pvr
)
9240 GSList
*list
, *item
;
9241 PowerPCCPUClass
*pcc
= NULL
;
9243 list
= object_class_get_list(TYPE_POWERPC_CPU
, false);
9244 item
= g_slist_find_custom(list
, &pvr
, ppc_cpu_compare_class_pvr
);
9246 pcc
= POWERPC_CPU_CLASS(item
->data
);
9253 static gint
ppc_cpu_compare_class_pvr_mask(gconstpointer a
, gconstpointer b
)
9255 ObjectClass
*oc
= (ObjectClass
*)a
;
9256 uint32_t pvr
= *(uint32_t *)b
;
9257 PowerPCCPUClass
*pcc
= (PowerPCCPUClass
*)a
;
9259 /* -cpu host does a PVR lookup during construction */
9260 if (unlikely(strcmp(object_class_get_name(oc
),
9261 TYPE_HOST_POWERPC_CPU
) == 0)) {
9265 if (!ppc_cpu_is_valid(pcc
)) {
9269 if (pcc
->pvr_match(pcc
, pvr
)) {
9276 PowerPCCPUClass
*ppc_cpu_class_by_pvr_mask(uint32_t pvr
)
9278 GSList
*list
, *item
;
9279 PowerPCCPUClass
*pcc
= NULL
;
9281 list
= object_class_get_list(TYPE_POWERPC_CPU
, true);
9282 item
= g_slist_find_custom(list
, &pvr
, ppc_cpu_compare_class_pvr_mask
);
9284 pcc
= POWERPC_CPU_CLASS(item
->data
);
9291 static gint
ppc_cpu_compare_class_name(gconstpointer a
, gconstpointer b
)
9293 ObjectClass
*oc
= (ObjectClass
*)a
;
9294 const char *name
= b
;
9295 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
9297 if (strncasecmp(name
, object_class_get_name(oc
), strlen(name
)) == 0 &&
9298 ppc_cpu_is_valid(pcc
) &&
9299 strcmp(object_class_get_name(oc
) + strlen(name
),
9300 "-" TYPE_POWERPC_CPU
) == 0) {
9308 static ObjectClass
*ppc_cpu_class_by_name(const char *name
);
9310 static ObjectClass
*ppc_cpu_class_by_alias(PowerPCCPUAlias
*alias
)
9312 ObjectClass
*invalid_class
= (void*)ppc_cpu_class_by_alias
;
9314 /* Cache target class lookups in the alias table */
9316 alias
->oc
= ppc_cpu_class_by_name(alias
->model
);
9318 /* Fast check for non-existing aliases */
9319 alias
->oc
= invalid_class
;
9323 if (alias
->oc
== invalid_class
) {
9330 static ObjectClass
*ppc_cpu_class_by_name(const char *name
)
9332 GSList
*list
, *item
;
9333 ObjectClass
*ret
= NULL
;
9337 /* Check if the given name is a PVR */
9339 if (len
== 10 && name
[0] == '0' && name
[1] == 'x') {
9342 } else if (len
== 8) {
9345 for (i
= 0; i
< 8; i
++) {
9346 if (!qemu_isxdigit(*p
++))
9350 return OBJECT_CLASS(ppc_cpu_class_by_pvr(strtoul(name
, NULL
, 16)));
9354 list
= object_class_get_list(TYPE_POWERPC_CPU
, false);
9355 item
= g_slist_find_custom(list
, name
, ppc_cpu_compare_class_name
);
9357 ret
= OBJECT_CLASS(item
->data
);
9365 for (i
= 0; ppc_cpu_aliases
[i
].alias
!= NULL
; i
++) {
9366 if (strcmp(ppc_cpu_aliases
[i
].alias
, name
) == 0) {
9367 return ppc_cpu_class_by_alias(&ppc_cpu_aliases
[i
]);
9374 PowerPCCPU
*cpu_ppc_init(const char *cpu_model
)
9376 return POWERPC_CPU(cpu_generic_init(TYPE_POWERPC_CPU
, cpu_model
));
9379 /* Sort by PVR, ordering special case "host" last. */
9380 static gint
ppc_cpu_list_compare(gconstpointer a
, gconstpointer b
)
9382 ObjectClass
*oc_a
= (ObjectClass
*)a
;
9383 ObjectClass
*oc_b
= (ObjectClass
*)b
;
9384 PowerPCCPUClass
*pcc_a
= POWERPC_CPU_CLASS(oc_a
);
9385 PowerPCCPUClass
*pcc_b
= POWERPC_CPU_CLASS(oc_b
);
9386 const char *name_a
= object_class_get_name(oc_a
);
9387 const char *name_b
= object_class_get_name(oc_b
);
9389 if (strcmp(name_a
, TYPE_HOST_POWERPC_CPU
) == 0) {
9391 } else if (strcmp(name_b
, TYPE_HOST_POWERPC_CPU
) == 0) {
9394 /* Avoid an integer overflow during subtraction */
9395 if (pcc_a
->pvr
< pcc_b
->pvr
) {
9397 } else if (pcc_a
->pvr
> pcc_b
->pvr
) {
9405 static void ppc_cpu_list_entry(gpointer data
, gpointer user_data
)
9407 ObjectClass
*oc
= data
;
9408 CPUListState
*s
= user_data
;
9409 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
9410 const char *typename
= object_class_get_name(oc
);
9414 if (!ppc_cpu_is_valid(pcc
)) {
9417 if (unlikely(strcmp(typename
, TYPE_HOST_POWERPC_CPU
) == 0)) {
9421 name
= g_strndup(typename
,
9422 strlen(typename
) - strlen("-" TYPE_POWERPC_CPU
));
9423 (*s
->cpu_fprintf
)(s
->file
, "PowerPC %-16s PVR %08x\n",
9425 for (i
= 0; ppc_cpu_aliases
[i
].alias
!= NULL
; i
++) {
9426 PowerPCCPUAlias
*alias
= &ppc_cpu_aliases
[i
];
9427 ObjectClass
*alias_oc
= ppc_cpu_class_by_alias(alias
);
9429 if (alias_oc
!= oc
) {
9432 (*s
->cpu_fprintf
)(s
->file
, "PowerPC %-16s (alias for %s)\n",
9433 alias
->alias
, name
);
9438 void ppc_cpu_list(FILE *f
, fprintf_function cpu_fprintf
)
9442 .cpu_fprintf
= cpu_fprintf
,
9446 list
= object_class_get_list(TYPE_POWERPC_CPU
, false);
9447 list
= g_slist_sort(list
, ppc_cpu_list_compare
);
9448 g_slist_foreach(list
, ppc_cpu_list_entry
, &s
);
9452 cpu_fprintf(f
, "\n");
9453 cpu_fprintf(f
, "PowerPC %-16s\n", "host");
9457 static void ppc_cpu_defs_entry(gpointer data
, gpointer user_data
)
9459 ObjectClass
*oc
= data
;
9460 CpuDefinitionInfoList
**first
= user_data
;
9461 const char *typename
;
9462 CpuDefinitionInfoList
*entry
;
9463 CpuDefinitionInfo
*info
;
9464 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
9466 if (!ppc_cpu_is_valid(pcc
)) {
9470 typename
= object_class_get_name(oc
);
9471 info
= g_malloc0(sizeof(*info
));
9472 info
->name
= g_strndup(typename
,
9473 strlen(typename
) - strlen("-" TYPE_POWERPC_CPU
));
9475 entry
= g_malloc0(sizeof(*entry
));
9476 entry
->value
= info
;
9477 entry
->next
= *first
;
9481 CpuDefinitionInfoList
*arch_query_cpu_definitions(Error
**errp
)
9483 CpuDefinitionInfoList
*cpu_list
= NULL
;
9487 list
= object_class_get_list(TYPE_POWERPC_CPU
, false);
9488 g_slist_foreach(list
, ppc_cpu_defs_entry
, &cpu_list
);
9491 for (i
= 0; ppc_cpu_aliases
[i
].alias
!= NULL
; i
++) {
9492 PowerPCCPUAlias
*alias
= &ppc_cpu_aliases
[i
];
9494 CpuDefinitionInfoList
*entry
;
9495 CpuDefinitionInfo
*info
;
9497 oc
= ppc_cpu_class_by_alias(alias
);
9502 info
= g_malloc0(sizeof(*info
));
9503 info
->name
= g_strdup(alias
->alias
);
9505 entry
= g_malloc0(sizeof(*entry
));
9506 entry
->value
= info
;
9507 entry
->next
= cpu_list
;
9514 static void ppc_cpu_set_pc(CPUState
*cs
, vaddr value
)
9516 PowerPCCPU
*cpu
= POWERPC_CPU(cs
);
9518 cpu
->env
.nip
= value
;
9521 static bool ppc_cpu_has_work(CPUState
*cs
)
9523 PowerPCCPU
*cpu
= POWERPC_CPU(cs
);
9524 CPUPPCState
*env
= &cpu
->env
;
9526 return msr_ee
&& (cs
->interrupt_request
& CPU_INTERRUPT_HARD
);
9529 static void ppc_cpu_exec_enter(CPUState
*cs
)
9531 PowerPCCPU
*cpu
= POWERPC_CPU(cs
);
9532 CPUPPCState
*env
= &cpu
->env
;
9534 env
->reserve_addr
= -1;
9537 /* CPUClass::reset() */
9538 static void ppc_cpu_reset(CPUState
*s
)
9540 PowerPCCPU
*cpu
= POWERPC_CPU(s
);
9541 PowerPCCPUClass
*pcc
= POWERPC_CPU_GET_CLASS(cpu
);
9542 CPUPPCState
*env
= &cpu
->env
;
9546 pcc
->parent_reset(s
);
9548 msr
= (target_ulong
)0;
9550 /* XXX: find a suitable condition to enable the hypervisor mode */
9551 msr
|= (target_ulong
)MSR_HVB
;
9553 msr
|= (target_ulong
)0 << MSR_AP
; /* TO BE CHECKED */
9554 msr
|= (target_ulong
)0 << MSR_SA
; /* TO BE CHECKED */
9555 msr
|= (target_ulong
)1 << MSR_EP
;
9556 #if defined(DO_SINGLE_STEP) && 0
9557 /* Single step trace mode */
9558 msr
|= (target_ulong
)1 << MSR_SE
;
9559 msr
|= (target_ulong
)1 << MSR_BE
;
9561 #if defined(CONFIG_USER_ONLY)
9562 msr
|= (target_ulong
)1 << MSR_FP
; /* Allow floating point usage */
9563 msr
|= (target_ulong
)1 << MSR_VR
; /* Allow altivec usage */
9564 msr
|= (target_ulong
)1 << MSR_VSX
; /* Allow VSX usage */
9565 msr
|= (target_ulong
)1 << MSR_SPE
; /* Allow SPE usage */
9566 msr
|= (target_ulong
)1 << MSR_PR
;
9567 #if defined(TARGET_PPC64)
9568 msr
|= (target_ulong
)1 << MSR_TM
; /* Transactional memory */
9570 #if !defined(TARGET_WORDS_BIGENDIAN)
9571 msr
|= (target_ulong
)1 << MSR_LE
; /* Little-endian user mode */
9572 if (!((env
->msr_mask
>> MSR_LE
) & 1)) {
9573 fprintf(stderr
, "Selected CPU does not support little-endian.\n");
9579 #if defined(TARGET_PPC64)
9580 if (env
->mmu_model
& POWERPC_MMU_64
) {
9581 env
->msr
|= (1ULL << MSR_SF
);
9585 hreg_store_msr(env
, msr
, 1);
9587 #if !defined(CONFIG_USER_ONLY)
9588 env
->nip
= env
->hreset_vector
| env
->excp_prefix
;
9589 if (env
->mmu_model
!= POWERPC_MMU_REAL
) {
9590 ppc_tlb_invalidate_all(env
);
9594 hreg_compute_hflags(env
);
9595 env
->reserve_addr
= (target_ulong
)-1ULL;
9596 /* Be sure no exception or interrupt is pending */
9597 env
->pending_interrupts
= 0;
9598 s
->exception_index
= POWERPC_EXCP_NONE
;
9599 env
->error_code
= 0;
9601 #if defined(TARGET_PPC64) && !defined(CONFIG_USER_ONLY)
9603 env
->slb_shadow_addr
= 0;
9604 env
->slb_shadow_size
= 0;
9607 #endif /* TARGET_PPC64 */
9609 for (i
= 0; i
< ARRAY_SIZE(env
->spr_cb
); i
++) {
9610 ppc_spr_t
*spr
= &env
->spr_cb
[i
];
9615 env
->spr
[i
] = spr
->default_value
;
9618 /* Flush all TLBs */
9622 #ifndef CONFIG_USER_ONLY
9623 static bool ppc_cpu_is_big_endian(CPUState
*cs
)
9625 PowerPCCPU
*cpu
= POWERPC_CPU(cs
);
9626 CPUPPCState
*env
= &cpu
->env
;
9628 cpu_synchronize_state(cs
);
9634 static void ppc_cpu_initfn(Object
*obj
)
9636 CPUState
*cs
= CPU(obj
);
9637 PowerPCCPU
*cpu
= POWERPC_CPU(obj
);
9638 PowerPCCPUClass
*pcc
= POWERPC_CPU_GET_CLASS(cpu
);
9639 CPUPPCState
*env
= &cpu
->env
;
9643 env
->msr_mask
= pcc
->msr_mask
;
9644 env
->mmu_model
= pcc
->mmu_model
;
9645 env
->excp_model
= pcc
->excp_model
;
9646 env
->bus_model
= pcc
->bus_model
;
9647 env
->insns_flags
= pcc
->insns_flags
;
9648 env
->insns_flags2
= pcc
->insns_flags2
;
9649 env
->flags
= pcc
->flags
;
9650 env
->bfd_mach
= pcc
->bfd_mach
;
9651 env
->check_pow
= pcc
->check_pow
;
9653 #if defined(TARGET_PPC64)
9655 env
->sps
= *pcc
->sps
;
9656 } else if (env
->mmu_model
& POWERPC_MMU_64
) {
9657 /* Use default sets of page sizes */
9658 static const struct ppc_segment_page_sizes defsps
= {
9660 { .page_shift
= 12, /* 4K */
9662 .enc
= { { .page_shift
= 12, .pte_enc
= 0 } }
9664 { .page_shift
= 24, /* 16M */
9666 .enc
= { { .page_shift
= 24, .pte_enc
= 0 } }
9672 #endif /* defined(TARGET_PPC64) */
9674 if (tcg_enabled()) {
9675 ppc_translate_init();
9679 static bool ppc_pvr_match_default(PowerPCCPUClass
*pcc
, uint32_t pvr
)
9681 return pcc
->pvr
== pvr
;
9684 static void ppc_cpu_class_init(ObjectClass
*oc
, void *data
)
9686 PowerPCCPUClass
*pcc
= POWERPC_CPU_CLASS(oc
);
9687 CPUClass
*cc
= CPU_CLASS(oc
);
9688 DeviceClass
*dc
= DEVICE_CLASS(oc
);
9690 pcc
->parent_realize
= dc
->realize
;
9691 pcc
->pvr_match
= ppc_pvr_match_default
;
9692 pcc
->interrupts_big_endian
= ppc_cpu_interrupts_big_endian_always
;
9693 dc
->realize
= ppc_cpu_realizefn
;
9694 dc
->unrealize
= ppc_cpu_unrealizefn
;
9696 pcc
->parent_reset
= cc
->reset
;
9697 cc
->reset
= ppc_cpu_reset
;
9699 cc
->class_by_name
= ppc_cpu_class_by_name
;
9700 cc
->has_work
= ppc_cpu_has_work
;
9701 cc
->do_interrupt
= ppc_cpu_do_interrupt
;
9702 cc
->cpu_exec_interrupt
= ppc_cpu_exec_interrupt
;
9703 cc
->dump_state
= ppc_cpu_dump_state
;
9704 cc
->dump_statistics
= ppc_cpu_dump_statistics
;
9705 cc
->set_pc
= ppc_cpu_set_pc
;
9706 cc
->gdb_read_register
= ppc_cpu_gdb_read_register
;
9707 cc
->gdb_write_register
= ppc_cpu_gdb_write_register
;
9708 #ifdef CONFIG_USER_ONLY
9709 cc
->handle_mmu_fault
= ppc_cpu_handle_mmu_fault
;
9711 cc
->get_phys_page_debug
= ppc_cpu_get_phys_page_debug
;
9712 cc
->vmsd
= &vmstate_ppc_cpu
;
9713 #if defined(TARGET_PPC64)
9714 cc
->write_elf64_note
= ppc64_cpu_write_elf64_note
;
9717 cc
->cpu_exec_enter
= ppc_cpu_exec_enter
;
9719 cc
->gdb_num_core_regs
= 71;
9721 #ifdef USE_APPLE_GDB
9722 cc
->gdb_read_register
= ppc_cpu_gdb_read_register_apple
;
9723 cc
->gdb_write_register
= ppc_cpu_gdb_write_register_apple
;
9724 cc
->gdb_num_core_regs
= 71 + 32;
9727 #if defined(TARGET_PPC64)
9728 cc
->gdb_core_xml_file
= "power64-core.xml";
9730 cc
->gdb_core_xml_file
= "power-core.xml";
9732 #ifndef CONFIG_USER_ONLY
9733 cc
->virtio_is_big_endian
= ppc_cpu_is_big_endian
;
9736 dc
->fw_name
= "PowerPC,UNKNOWN";
9739 static const TypeInfo ppc_cpu_type_info
= {
9740 .name
= TYPE_POWERPC_CPU
,
9742 .instance_size
= sizeof(PowerPCCPU
),
9743 .instance_init
= ppc_cpu_initfn
,
9745 .class_size
= sizeof(PowerPCCPUClass
),
9746 .class_init
= ppc_cpu_class_init
,
9749 static void ppc_cpu_register_types(void)
9751 type_register_static(&ppc_cpu_type_info
);
9754 type_init(ppc_cpu_register_types
)