diff options
author | j_mayer <j_mayer@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-04-17 02:50:56 +0000 |
---|---|---|
committer | j_mayer <j_mayer@c046a42c-6fe2-441c-8c8c-71466251a162> | 2007-04-17 02:50:56 +0000 |
commit | 04f20795ac815cf3ad5d1fdc99462f60eb871f25 (patch) | |
tree | 0a76f74c3e36de1353597d3655b92889743e8f12 /target-ppc/translate_init.c | |
parent | 80355292503667b5367f09ec8716126c3caa1e3a (diff) |
Move PowerPC 405 specific definitions into a separate file
Preliminary code for -kernel option support for PowerPC 405 boards
Fix DBSR in case of PowerPC 405 chip reset
Add enums for PowerPC 405 clocks.
Fix IRQ numbers (IBM reversed bits numbering...)
Fix SPRG4-7 read access right
Fix MSR mask in CPU definitions
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2692 c046a42c-6fe2-441c-8c8c-71466251a162
Diffstat (limited to 'target-ppc/translate_init.c')
-rw-r--r-- | target-ppc/translate_init.c | 220 |
1 files changed, 109 insertions, 111 deletions
diff --git a/target-ppc/translate_init.c b/target-ppc/translate_init.c index cb40dfbdde..0868f308cf 100644 --- a/target-ppc/translate_init.c +++ b/target-ppc/translate_init.c @@ -53,25 +53,27 @@ PPC_IRQ_INIT_FN(970); /* Generic callbacks: * do nothing but store/retrieve spr value */ +#ifdef PPC_DUMP_SPR_ACCESSES static void spr_read_generic (void *opaque, int sprn) { - gen_op_load_spr(sprn); + gen_op_load_dump_spr(sprn); } static void spr_write_generic (void *opaque, int sprn) { - gen_op_store_spr(sprn); + gen_op_store_dump_spr(sprn); } - -static void spr_read_dump (void *opaque, int sprn) +#else +static void spr_read_generic (void *opaque, int sprn) { - gen_op_load_dump_spr(sprn); + gen_op_load_spr(sprn); } -static void spr_write_dump (void *opaque, int sprn) +static void spr_write_generic (void *opaque, int sprn) { - gen_op_store_dump_spr(sprn); + gen_op_store_spr(sprn); } +#endif #if !defined(CONFIG_USER_ONLY) static void spr_write_clear (void *opaque, int sprn) @@ -1730,7 +1732,7 @@ static void gen_spr_405 (CPUPPCState *env) 0x00000000); spr_register(env, SPR_SPRG4, "SPRG4", SPR_NOACCESS, SPR_NOACCESS, - SPR_NOACCESS, &spr_write_generic, + &spr_read_generic, &spr_write_generic, 0x00000000); spr_register(env, SPR_USPRG4, "USPRG4", &spr_read_ureg, SPR_NOACCESS, @@ -1738,7 +1740,7 @@ static void gen_spr_405 (CPUPPCState *env) 0x00000000); spr_register(env, SPR_SPRG5, "SPRG5", SPR_NOACCESS, SPR_NOACCESS, - SPR_NOACCESS, &spr_write_generic, + spr_read_generic, &spr_write_generic, 0x00000000); spr_register(env, SPR_USPRG5, "USPRG5", &spr_read_ureg, SPR_NOACCESS, @@ -1746,7 +1748,7 @@ static void gen_spr_405 (CPUPPCState *env) 0x00000000); spr_register(env, SPR_SPRG6, "SPRG6", SPR_NOACCESS, SPR_NOACCESS, - SPR_NOACCESS, &spr_write_generic, + spr_read_generic, &spr_write_generic, 0x00000000); spr_register(env, SPR_USPRG6, "USPRG6", &spr_read_ureg, SPR_NOACCESS, @@ -1754,7 +1756,7 @@ static void gen_spr_405 (CPUPPCState *env) 0x00000000); spr_register(env, SPR_SPRG7, "SPRG7", SPR_NOACCESS, SPR_NOACCESS, - SPR_NOACCESS, &spr_write_generic, + spr_read_generic, &spr_write_generic, 0x00000000); spr_register(env, SPR_USPRG7, "USPRG7", &spr_read_ureg, SPR_NOACCESS, @@ -2756,7 +2758,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFF00, .insns_flags = PPC_INSNS_403, .flags = PPC_FLAGS_403, - .msr_mask = 0x000000000007D23D, + .msr_mask = 0x000000000007D23DULL, }, #endif #if defined (TODO) @@ -2767,7 +2769,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFF00, .insns_flags = PPC_INSNS_403, .flags = PPC_FLAGS_403, - .msr_mask = 0x000000000007D23D, + .msr_mask = 0x000000000007D23DULL, }, #endif #if defined (TODO) @@ -2778,7 +2780,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFF00, .insns_flags = PPC_INSNS_403, .flags = PPC_FLAGS_403, - .msr_mask = 0x000000000007D23D, + .msr_mask = 0x000000000007D23DULL, }, #endif #if defined (TODO) @@ -2789,7 +2791,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFF00, .insns_flags = PPC_INSNS_403, .flags = PPC_FLAGS_403, - .msr_mask = 0x000000000007D23D, + .msr_mask = 0x000000000007D23DULL, }, #endif #if defined (TODO) @@ -2800,7 +2802,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFF00, .insns_flags = PPC_INSNS_403, .flags = PPC_FLAGS_403, - .msr_mask = 0x000000000007D23D, + .msr_mask = 0x000000000007D23DULL, }, #endif /* Generic PowerPC 405 */ @@ -2810,7 +2812,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, /* PowerPC 405 CR */ { @@ -2819,7 +2821,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #if defined (TODO) /* PowerPC 405 GP */ @@ -2829,7 +2831,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif /* PowerPC 405 EP */ @@ -2839,7 +2841,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #if defined (TODO) /* PowerPC 405 EZ */ @@ -2849,7 +2851,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2860,10 +2862,9 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif -#if defined (TODO) /* PowerPC 405 D2 */ { .name = "405d2", @@ -2871,10 +2872,8 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, -#endif -#if defined (TODO) /* PowerPC 405 D4 */ { .name = "405d4", @@ -2882,9 +2881,8 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, -#endif #if defined (TODO) /* Npe405 H */ { @@ -2893,7 +2891,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2904,7 +2902,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2915,7 +2913,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2926,7 +2924,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2937,10 +2935,10 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif -#if defined (TODO) || 1 +#if defined (TODO) /* STB03xx */ { .name = "STB03", @@ -2948,7 +2946,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2959,7 +2957,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2970,10 +2968,10 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif -#if defined (TODO) || 1 +#if defined (TODO) /* STB25xx */ { .name = "STB25", @@ -2981,7 +2979,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -2992,7 +2990,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif /* Xilinx PowerPC 405 cores */ @@ -3003,7 +3001,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, { .name = "x2vp7", @@ -3011,7 +3009,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, { .name = "x2vp20", @@ -3019,7 +3017,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, { .name = "x2vp50", @@ -3027,7 +3025,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_405, - .msr_mask = 0x00000000020EFF30, + .msr_mask = 0x00000000020EFF30ULL, }, #endif #if defined (TODO) @@ -3038,7 +3036,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_440, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3049,7 +3047,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_440, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3060,7 +3058,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFF00, .insns_flags = PPC_INSNS_440, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3071,7 +3069,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3082,7 +3080,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3093,7 +3091,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3104,7 +3102,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3115,7 +3113,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif #if defined (TODO) @@ -3126,7 +3124,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_405, .flags = PPC_FLAGS_440, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, #endif /* Fake generic BookE PowerPC */ @@ -3136,7 +3134,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_BOOKE, .flags = PPC_FLAGS_BOOKE, - .msr_mask = 0x000000000006D630, + .msr_mask = 0x000000000006D630ULL, }, /* PowerPC 460 cores - TODO */ /* PowerPC MPC 5xx cores - TODO */ @@ -3155,7 +3153,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_601, .flags = PPC_FLAGS_601, - .msr_mask = 0x000000000000FD70, + .msr_mask = 0x000000000000FD70ULL, }, #endif #if defined (TODO) @@ -3166,7 +3164,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_602, .flags = PPC_FLAGS_602, - .msr_mask = 0x0000000000C7FF73, + .msr_mask = 0x0000000000C7FF73ULL, }, #endif /* PowerPC 603 */ @@ -3176,7 +3174,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, /* PowerPC 603e */ { @@ -3185,7 +3183,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, { .name = "Stretch", @@ -3193,7 +3191,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, /* PowerPC 603p */ { @@ -3202,7 +3200,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, /* PowerPC 603e7 */ { @@ -3211,7 +3209,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, /* PowerPC 603e7v */ { @@ -3220,7 +3218,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, /* PowerPC 603e7v2 */ { @@ -3229,7 +3227,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, /* PowerPC 603r */ { @@ -3238,7 +3236,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, { .name = "Goldeneye", @@ -3246,7 +3244,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_603, .flags = PPC_FLAGS_603, - .msr_mask = 0x000000000007FF73, + .msr_mask = 0x000000000007FF73ULL, }, #if defined (TODO) /* XXX: TODO: according to Motorola UM, this is a derivative to 603e */ @@ -3256,7 +3254,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_G2, .flags = PPC_FLAGS_G2, - .msr_mask = 0x000000000006FFF2, + .msr_mask = 0x000000000006FFF2ULL, }, { .name = "G2h4", @@ -3264,7 +3262,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_G2, .flags = PPC_FLAGS_G2, - .msr_mask = 0x000000000006FFF2, + .msr_mask = 0x000000000006FFF2ULL, }, { .name = "G2gp", @@ -3272,7 +3270,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_G2, .flags = PPC_FLAGS_G2, - .msr_mask = 0x000000000006FFF2, + .msr_mask = 0x000000000006FFF2ULL, }, { .name = "G2ls", @@ -3280,7 +3278,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_G2, .flags = PPC_FLAGS_G2, - .msr_mask = 0x000000000006FFF2, + .msr_mask = 0x000000000006FFF2ULL, }, { /* Same as G2, with LE mode support */ .name = "G2le", @@ -3288,7 +3286,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_G2, .flags = PPC_FLAGS_G2, - .msr_mask = 0x000000000007FFF3, + .msr_mask = 0x000000000007FFF3ULL, }, { .name = "G2legp", @@ -3296,7 +3294,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_G2, .flags = PPC_FLAGS_G2, - .msr_mask = 0x000000000007FFF3, + .msr_mask = 0x000000000007FFF3ULL, }, { .name = "G2lels", @@ -3304,7 +3302,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_G2, .flags = PPC_FLAGS_G2, - .msr_mask = 0x000000000007FFF3, + .msr_mask = 0x000000000007FFF3ULL, }, #endif /* PowerPC 604 */ @@ -3314,7 +3312,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_604, .flags = PPC_FLAGS_604, - .msr_mask = 0x000000000005FF77, + .msr_mask = 0x000000000005FF77ULL, }, /* PowerPC 604e */ { @@ -3323,7 +3321,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_604, .flags = PPC_FLAGS_604, - .msr_mask = 0x000000000005FF77, + .msr_mask = 0x000000000005FF77ULL, }, /* PowerPC 604r */ { @@ -3332,7 +3330,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_604, .flags = PPC_FLAGS_604, - .msr_mask = 0x000000000005FF77, + .msr_mask = 0x000000000005FF77ULL, }, /* generic G3 */ { @@ -3341,7 +3339,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, /* MPC740 (G3) */ { @@ -3350,7 +3348,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, { .name = "Arthur", @@ -3358,7 +3356,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #if defined (TODO) /* MPC745 (G3) */ @@ -3368,7 +3366,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFF000, .insns_flags = PPC_INSNS_7x5, .flags = PPC_FLAGS_7x5, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, { .name = "Goldfinger", @@ -3376,7 +3374,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFF000, .insns_flags = PPC_INSNS_7x5, .flags = PPC_FLAGS_7x5, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #endif /* MPC750 (G3) */ @@ -3386,7 +3384,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #if defined (TODO) /* MPC755 (G3) */ @@ -3396,7 +3394,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFF000, .insns_flags = PPC_INSNS_7x5, .flags = PPC_FLAGS_7x5, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #endif /* MPC740P (G3) */ @@ -3406,7 +3404,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, { .name = "Conan/Doyle", @@ -3414,7 +3412,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #if defined (TODO) /* MPC745P (G3) */ @@ -3424,7 +3422,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFF000, .insns_flags = PPC_INSNS_7x5, .flags = PPC_FLAGS_7x5, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #endif /* MPC750P (G3) */ @@ -3434,7 +3432,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #if defined (TODO) /* MPC755P (G3) */ @@ -3444,7 +3442,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFF000, .insns_flags = PPC_INSNS_7x5, .flags = PPC_FLAGS_7x5, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #endif /* IBM 750CXe (G3 embedded) */ @@ -3454,7 +3452,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, /* IBM 750FX (G3 embedded) */ { @@ -3463,7 +3461,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, /* IBM 750GX (G3 embedded) */ { @@ -3472,7 +3470,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_7x0, .flags = PPC_FLAGS_7x0, - .msr_mask = 0x000000000007FF77, + .msr_mask = 0x000000000007FF77ULL, }, #if defined (TODO) /* generic G4 */ @@ -3482,7 +3480,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, #endif #if defined (TODO) @@ -3493,7 +3491,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, { .name = "Max", @@ -3501,7 +3499,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, #endif #if defined (TODO) @@ -3512,7 +3510,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, { .name = "Nitro", @@ -3520,7 +3518,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, #endif /* XXX: 7441 */ @@ -3535,7 +3533,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, { .name = "Vger", @@ -3543,7 +3541,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, #endif /* XXX: 7451 */ @@ -3555,7 +3553,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, { .name = "Apollo 6", @@ -3563,7 +3561,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, #endif #if defined (TODO) @@ -3574,7 +3572,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, { .name = "Apollo 7", @@ -3582,7 +3580,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, #endif #if defined (TODO) @@ -3593,7 +3591,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, { .name = "Apollo 7 PM", @@ -3601,7 +3599,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_74xx, .flags = PPC_FLAGS_74xx, - .msr_mask = 0x000000000205FF77, + .msr_mask = 0x000000000205FF77ULL, }, #endif /* 64 bits PowerPC */ @@ -3614,7 +3612,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_620, .flags = PPC_FLAGS_620, - .msr_mask = 0x800000000005FF73, + .msr_mask = 0x800000000005FF73ULL, }, #endif #if defined (TODO) @@ -3699,7 +3697,7 @@ static ppc_def_t ppc_defs[] = { .msr_mask = xxx, }, #endif -#if defined (TODO) || 1 +#if defined (TODO) /* PowerPC 970 */ { .name = "970", @@ -3707,7 +3705,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_970, .flags = PPC_FLAGS_970, - .msr_mask = 0x900000000204FF36, + .msr_mask = 0x900000000204FF36ULL, }, #endif #if defined (TODO) @@ -3718,7 +3716,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_970FX, .flags = PPC_FLAGS_970FX, - .msr_mask = 0x800000000204FF36, + .msr_mask = 0x800000000204FF36ULL, }, #endif #if defined (TODO) @@ -3857,14 +3855,14 @@ static ppc_def_t ppc_defs[] = { }, #endif /* Generic PowerPCs */ -#if defined (TODO) || 1 +#if defined (TODO) { .name = "ppc64", .pvr = CPU_PPC_970, .pvr_mask = 0xFFFF0000, .insns_flags = PPC_INSNS_PPC64, .flags = PPC_FLAGS_PPC64, - .msr_mask = 0xA00000000204FF36, + .msr_mask = 0xA00000000204FF36ULL, }, #endif { @@ -3873,7 +3871,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_PPC32, .flags = PPC_FLAGS_PPC32, - .msr_mask = 0x000000000005FF77, + .msr_mask = 0x000000000005FF77ULL, }, /* Fallback */ { @@ -3882,7 +3880,7 @@ static ppc_def_t ppc_defs[] = { .pvr_mask = 0xFFFFFFFF, .insns_flags = PPC_INSNS_PPC32, .flags = PPC_FLAGS_PPC32, - .msr_mask = 0x000000000005FF77, + .msr_mask = 0x000000000005FF77ULL, }, }; |