halt state support for ppc
authorbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>
Wed, 23 Nov 2005 22:05:28 +0000 (22:05 +0000)
committerbellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162>
Wed, 23 Nov 2005 22:05:28 +0000 (22:05 +0000)
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1657 c046a42c-6fe2-441c-8c8c-71466251a162

cpu-exec.c
monitor.c
target-ppc/helper.c
target-ppc/translate.c

index de1fff212245b7f92fa24a11593412e588e8d3e7..9543c636c76f9aa6dab79f5328bea7199862dc0e 100644 (file)
@@ -262,6 +262,16 @@ int cpu_exec(CPUState *env1)
             return EXCP_HALTED;
         }
     }
+#elif defined(TARGET_PPC)
+    if (env1->msr[MSR_POW]) {
+        if (env1->msr[MSR_EE] && 
+            (env1->interrupt_request & 
+             (CPU_INTERRUPT_HARD | CPU_INTERRUPT_TIMER))) {
+            env1->msr[MSR_POW] = 0;
+        } else {
+            return EXCP_HALTED;
+        }
+    }
 #endif
 
     cpu_single_env = env1; 
index 9befd82b06eb0607f9ef34678a10c5f24c6589b0..70b473ddbff6ba7b3b3373485a05640675a88d2e 100644 (file)
--- a/monitor.c
+++ b/monitor.c
@@ -255,6 +255,10 @@ static void do_info_cpus(void)
         term_printf(" pc=0x" TARGET_FMT_lx, env->eip + env->segs[R_CS].base);
         if (env->hflags & HF_HALTED_MASK)
             term_printf(" (halted)");
+#elif defined(TARGET_PPC)
+        term_printf(" nip=0x" TARGET_FMT_lx, env->nip);
+        if (msr_pow)
+            term_printf(" (halted)");
 #endif
         term_printf("\n");
     }
index c3b02d8cc723a2d54284257e373128d4aaf6fc7b..ff1355c54116963a34400ca8221ca44aeffff01d 100644 (file)
@@ -846,6 +846,11 @@ void do_store_msr (CPUPPCState *env, target_ulong value)
     msr_ri  = (value >> MSR_RI)  & 1;
     msr_le  = (value >> MSR_LE)  & 1;
     do_compute_hflags(env);
+    if (msr_pow) {
+        /* power save: exit cpu loop */
+        env->exception_index = EXCP_HLT;
+        cpu_loop_exit();
+    }
 }
 
 float64 do_load_fpscr (CPUPPCState *env)
index 391f82f1d0b3f51aafb6954803882ffe43d629a3..3bc6aa376e5f1ebc0884c7bce9addc1a70040f44 100644 (file)
@@ -2097,10 +2097,11 @@ GEN_HANDLER(mtmsr, 0x1F, 0x12, 0x04, 0x001FF801, PPC_MISC)
         RET_PRIVREG(ctx);
         return;
     }
+    gen_op_update_nip((ctx)->nip);
     gen_op_load_gpr_T0(rS(ctx->opcode));
     gen_op_store_msr();
     /* Must stop the translation as machine state (may have) changed */
-    RET_STOP(ctx);
+    RET_CHG_FLOW(ctx);
 #endif
 }