* [PATCH] Fix SRAO/SRAR MCE injecting on guest without MCG_SER_P
@ 2010-10-08 8:25 Huang Ying
2010-10-08 8:31 ` Hidetoshi Seto
0 siblings, 1 reply; 2+ messages in thread
From: Huang Ying @ 2010-10-08 8:25 UTC (permalink / raw)
To: Avi Kivity, Marcelo Tosatti
Cc: Hidetoshi Seto, kvm@vger.kernel.org, Andi Kleen, Dean Nelson
On real machine, if MCG_SER_P in MSR_MCG_CAP is not set, SRAO/SRAR MCE
should not be raised by hardware. This patch makes QEMU-KVM to follow
the same rule.
Reported-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
Signed-off-by: Huang Ying <ying.huang@intel.com>
---
qemu-kvm.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
--- a/qemu-kvm.c
+++ b/qemu-kvm.c
@@ -1134,7 +1134,7 @@ static void sigbus_handler(int n, struct
void *ctx)
{
#if defined(KVM_CAP_MCE) && defined(TARGET_I386)
- if (first_cpu->mcg_cap && siginfo->ssi_addr
+ if ((first_cpu->mcg_cap & MCG_SER_P) && siginfo->ssi_addr
&& siginfo->ssi_code == BUS_MCEERR_AO) {
uint64_t status;
void *vaddr;
@@ -1324,7 +1324,7 @@ static void kvm_on_sigbus(CPUState *env,
unsigned long paddr;
int r;
- if (env->mcg_cap && siginfo->si_addr
+ if ((env->mcg_cap & MCG_SER_P) && siginfo->si_addr
&& (siginfo->si_code == BUS_MCEERR_AR
|| siginfo->si_code == BUS_MCEERR_AO)) {
if (siginfo->si_code == BUS_MCEERR_AR) {
@@ -1356,7 +1356,7 @@ static void kvm_on_sigbus(CPUState *env,
if (do_qemu_ram_addr_from_host(vaddr, &ram_addr) ||
!kvm_physical_memory_addr_from_ram(kvm_state, ram_addr, (target_phys_addr_t *)&paddr)) {
fprintf(stderr, "Hardware memory error for memory used by "
- "QEMU itself instaed of guest system!\n");
+ "QEMU itself instead of guest system!\n");
/* Hope we are lucky for AO MCE */
if (siginfo->si_code == BUS_MCEERR_AO) {
return;
^ permalink raw reply [flat|nested] 2+ messages in thread* Re: [PATCH] Fix SRAO/SRAR MCE injecting on guest without MCG_SER_P
2010-10-08 8:25 [PATCH] Fix SRAO/SRAR MCE injecting on guest without MCG_SER_P Huang Ying
@ 2010-10-08 8:31 ` Hidetoshi Seto
0 siblings, 0 replies; 2+ messages in thread
From: Hidetoshi Seto @ 2010-10-08 8:31 UTC (permalink / raw)
To: Huang Ying
Cc: Avi Kivity, Marcelo Tosatti, kvm@vger.kernel.org, Andi Kleen,
Dean Nelson
(2010/10/08 17:25), Huang Ying wrote:
> On real machine, if MCG_SER_P in MSR_MCG_CAP is not set, SRAO/SRAR MCE
> should not be raised by hardware. This patch makes QEMU-KVM to follow
> the same rule.
>
> Reported-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
> Signed-off-by: Huang Ying <ying.huang@intel.com>
> ---
> qemu-kvm.c | 6 +++---
> 1 file changed, 3 insertions(+), 3 deletions(-)
>
> --- a/qemu-kvm.c
> +++ b/qemu-kvm.c
> @@ -1134,7 +1134,7 @@ static void sigbus_handler(int n, struct
> void *ctx)
> {
> #if defined(KVM_CAP_MCE) && defined(TARGET_I386)
> - if (first_cpu->mcg_cap && siginfo->ssi_addr
> + if ((first_cpu->mcg_cap & MCG_SER_P) && siginfo->ssi_addr
> && siginfo->ssi_code == BUS_MCEERR_AO) {
> uint64_t status;
> void *vaddr;
> @@ -1324,7 +1324,7 @@ static void kvm_on_sigbus(CPUState *env,
> unsigned long paddr;
> int r;
>
> - if (env->mcg_cap && siginfo->si_addr
> + if ((env->mcg_cap & MCG_SER_P) && siginfo->si_addr
> && (siginfo->si_code == BUS_MCEERR_AR
> || siginfo->si_code == BUS_MCEERR_AO)) {
> if (siginfo->si_code == BUS_MCEERR_AR) {
> @@ -1356,7 +1356,7 @@ static void kvm_on_sigbus(CPUState *env,
> if (do_qemu_ram_addr_from_host(vaddr, &ram_addr) ||
> !kvm_physical_memory_addr_from_ram(kvm_state, ram_addr, (target_phys_addr_t *)&paddr)) {
> fprintf(stderr, "Hardware memory error for memory used by "
> - "QEMU itself instaed of guest system!\n");
> + "QEMU itself instead of guest system!\n");
> /* Hope we are lucky for AO MCE */
> if (siginfo->si_code == BUS_MCEERR_AO) {
> return;
Reviewed-by: Hidetoshi Seto <seto.hidetoshi@jp.fujitsu.com>
Thanks,
H.Seto
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2010-10-08 8:32 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2010-10-08 8:25 [PATCH] Fix SRAO/SRAR MCE injecting on guest without MCG_SER_P Huang Ying
2010-10-08 8:31 ` Hidetoshi Seto
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox