aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--target-ppc/cpu.h4
-rw-r--r--target-ppc/helper.c18
-rw-r--r--target-ppc/op.c10
3 files changed, 16 insertions, 16 deletions
diff --git a/target-ppc/cpu.h b/target-ppc/cpu.h
index c4ae414..396a588 100644
--- a/target-ppc/cpu.h
+++ b/target-ppc/cpu.h
@@ -611,9 +611,9 @@ void do_store_sr (CPUPPCState *env, int srnum, target_ulong value);
target_ulong ppc_load_xer (CPUPPCState *env);
void ppc_store_xer (CPUPPCState *env, target_ulong value);
target_ulong do_load_msr (CPUPPCState *env);
-void do_store_msr (CPUPPCState *env, target_ulong value);
+int do_store_msr (CPUPPCState *env, target_ulong value);
#if defined(TARGET_PPC64)
-void ppc_store_msr_32 (CPUPPCState *env, uint32_t value);
+int ppc_store_msr_32 (CPUPPCState *env, uint32_t value);
#endif
void do_compute_hflags (CPUPPCState *env);
diff --git a/target-ppc/helper.c b/target-ppc/helper.c
index 5b0fd09..5fa5ee0 100644
--- a/target-ppc/helper.c
+++ b/target-ppc/helper.c
@@ -1839,7 +1839,7 @@ target_ulong do_load_msr (CPUPPCState *env)
((target_ulong)msr_le << MSR_LE);
}
-void do_store_msr (CPUPPCState *env, target_ulong value)
+int do_store_msr (CPUPPCState *env, target_ulong value)
{
int enter_pm;
@@ -1921,21 +1921,15 @@ void do_store_msr (CPUPPCState *env, target_ulong value)
default:
break;
}
- if (enter_pm) {
- if (likely(!env->halted)) {
- /* power save: exit cpu loop */
- env->halted = 1;
- env->exception_index = EXCP_HLT;
- cpu_loop_exit();
- }
- }
+
+ return enter_pm;
}
#if defined(TARGET_PPC64)
-void ppc_store_msr_32 (CPUPPCState *env, uint32_t value)
+int ppc_store_msr_32 (CPUPPCState *env, uint32_t value)
{
- do_store_msr(env,
- (do_load_msr(env) & ~0xFFFFFFFFULL) | (value & 0xFFFFFFFF));
+ return do_store_msr(env, (do_load_msr(env) & ~0xFFFFFFFFULL) |
+ (value & 0xFFFFFFFF));
}
#endif
diff --git a/target-ppc/op.c b/target-ppc/op.c
index 822c267..72fd483 100644
--- a/target-ppc/op.c
+++ b/target-ppc/op.c
@@ -351,7 +351,10 @@ void OPPROTO op_load_msr (void)
void OPPROTO op_store_msr (void)
{
- do_store_msr(env, T0);
+ if (do_store_msr(env, T0)) {
+ env->halted = 1;
+ do_raise_exception(EXCP_HLT);
+ }
RETURN();
}
@@ -365,7 +368,10 @@ void OPPROTO op_update_riee (void)
#if defined (TARGET_PPC64)
void OPPROTO op_store_msr_32 (void)
{
- ppc_store_msr_32(env, T0);
+ if (ppc_store_msr_32(env, T0)) {
+ env->halted = 1;
+ do_raise_exception(EXCP_HLT);
+ }
RETURN();
}
#endif