aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--target-ppc/cpu.h2
-rw-r--r--target-ppc/helper.c7
2 files changed, 5 insertions, 4 deletions
diff --git a/target-ppc/cpu.h b/target-ppc/cpu.h
index 3ca22e57b9..e2cf956b4a 100644
--- a/target-ppc/cpu.h
+++ b/target-ppc/cpu.h
@@ -807,7 +807,7 @@ struct CPUPPCState {
/* Those resources are used only in Qemu core */
jmp_buf jmp_env;
int user_mode_only; /* user mode only simulation */
- uint32_t hflags;
+ target_ulong hflags; /* hflags is a MSR & HFLAGS_MASK */
/* Power management */
int power_mode;
diff --git a/target-ppc/helper.c b/target-ppc/helper.c
index 80315f6de2..534ad6b5d3 100644
--- a/target-ppc/helper.c
+++ b/target-ppc/helper.c
@@ -1776,13 +1776,14 @@ void ppc_store_msr_32 (CPUPPCState *env, uint32_t value)
void do_compute_hflags (CPUPPCState *env)
{
/* Compute current hflags */
- env->hflags = (msr_cm << MSR_CM) | (msr_vr << MSR_VR) |
+ env->hflags = (msr_vr << MSR_VR) |
(msr_ap << MSR_AP) | (msr_sa << MSR_SA) | (msr_pr << MSR_PR) |
(msr_fp << MSR_FP) | (msr_fe0 << MSR_FE0) | (msr_se << MSR_SE) |
(msr_be << MSR_BE) | (msr_fe1 << MSR_FE1) | (msr_le << MSR_LE);
#if defined (TARGET_PPC64)
- /* No care here: PowerPC 64 MSR_SF means the same as MSR_CM for BookE */
- env->hflags |= (msr_sf << (MSR_SF - 32)) | (msr_hv << (MSR_HV - 32));
+ env->hflags |= msr_cm << MSR_CM;
+ env->hflags |= (uint64_t)msr_sf << MSR_SF;
+ env->hflags |= (uint64_t)msr_hv << MSR_HV;
#endif
}