From: Huang Ying Date: Tue, 5 Jan 2010 08:32:24 +0000 (+0800) Subject: MCE: Fix bug of IA32_MCG_STATUS after system reset X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=af364b418cc57c53275c76ee5e0e0645908605b9;p=qemu.git MCE: Fix bug of IA32_MCG_STATUS after system reset Now, if we inject a fatal MCE into guest OS, for example Linux, Linux will go panic and then reboot. But if we inject another MCE now, system will reset directly instead of go panic firstly, because MCG_STATUS.MCIP is set to 1 and not cleared after reboot. This is does not follow the behavior in real hardware. This patch fixes this via set env->mcg_status to 0 during system reset. Signed-off-by: Huang Ying Signed-off-by: Anthony Liguori --- diff --git a/target-i386/helper.c b/target-i386/helper.c index c39a993902..049fccfc72 100644 --- a/target-i386/helper.c +++ b/target-i386/helper.c @@ -617,6 +617,8 @@ void cpu_reset(CPUX86State *env) env->dr[7] = DR7_FIXED_1; cpu_breakpoint_remove_all(env, BP_CPU); cpu_watchpoint_remove_all(env, BP_CPU); + + env->mcg_status = 0; } void cpu_x86_close(CPUX86State *env)