kvm.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Kenji Kaneshige <kaneshige.kenji@jp.fujitsu.com>
To: Avi Kivity <avi@redhat.com>, Jan Kiszka <jan.kiszka@web.de>
Cc: Lai Jiangshan <laijs@cn.fujitsu.com>,
	KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>,
	"kvm@vger.kernel.org" <kvm@vger.kernel.org>,
	"qemu-devel@nongnu.org" <qemu-devel@nongnu.org>,
	seabios@seabios.org, kevin@koconnor.net, gleb@redhat.com
Subject: Re: [PATCH 1/2] seabios: Add Local APIC NMI Structure to ACPI MADT
Date: Fri, 28 Oct 2011 21:08:18 +0900	[thread overview]
Message-ID: <4EAA9B32.10706@jp.fujitsu.com> (raw)
In-Reply-To: <4E928B59.2060906@cn.fujitsu.com>

Avi, Jan,

Could you comment on these patches?

Inject-NMI doesn't work on Windows guest without these patches. Windows seems
to setup LVT based on ACPI NMI structure information which is missing in current
seabios. LVT LINT1 are never unmasked by Windows guest without the patches.

Those patches were already reviewed by seabios people, but need ack from qemu/kvm
side.

Regards,
Kenji Kaneshige



(2011/10/10 15:06), Lai Jiangshan wrote:
> From: Kenji Kaneshige<kaneshige.kenji@jp.fujitsu.com>
> 
> ACPI NMI Structure describes LINT pin (LINT0 or LINT1) information to
> which NMI is connected, and it is needed by OS to initialize local APIC.
> 
> Signed-off-by: Kenji Kaneshige<kaneshige.kenji@jp.fujitsu.com>
> Reviewed-by: Lai Jiangshan<laijs@cn.fujitsu.com>
> ---
>   src/acpi.c |   22 ++++++++++++++++++++--
>   1 file changed, 20 insertions(+), 2 deletions(-)
> 
> Index: seabios/src/acpi.c
> ===================================================================
> --- seabios.orig/src/acpi.c
> +++ seabios/src/acpi.c
> @@ -134,6 +134,14 @@ struct madt_intsrcovr {
>       u16 flags;
>   } PACKED;
> 
> +struct madt_local_nmi {
> +    ACPI_SUB_HEADER_DEF
> +    u8  processor_id;           /* ACPI processor id */
> +    u16 flags;                  /* MPS INTI flags */
> +    u8  lint;                   /* Local APIC LINT# */
> +} PACKED;
> +
> +
>   /*
>    * ACPI 2.0 Generic Address Space definition.
>    */
> @@ -288,7 +296,9 @@ build_madt(void)
>       int madt_size = (sizeof(struct multiple_apic_table)
>                        + sizeof(struct madt_processor_apic) * MaxCountCPUs
>                        + sizeof(struct madt_io_apic)
> -                     + sizeof(struct madt_intsrcovr) * 16);
> +                     + sizeof(struct madt_intsrcovr) * 16
> +                     + sizeof(struct madt_local_nmi));
> +
>       struct multiple_apic_table *madt = malloc_high(madt_size);
>       if (!madt) {
>           warn_noalloc();
> @@ -340,7 +350,15 @@ build_madt(void)
>           intsrcovr++;
>       }
> 
> -    build_header((void*)madt, APIC_SIGNATURE, (void*)intsrcovr - (void*)madt, 1);
> +    struct madt_local_nmi *local_nmi = (void*)intsrcovr;
> +    local_nmi->type         = APIC_LOCAL_NMI;
> +    local_nmi->length       = sizeof(*local_nmi);
> +    local_nmi->processor_id = 0xff; /* all processors */
> +    local_nmi->flags        = 0;
> +    local_nmi->lint         = 1; /* LINT1 */
> +    local_nmi++;
> +
> +    build_header((void*)madt, APIC_SIGNATURE, (void*)local_nmi - (void*)madt, 1);
>       return madt;
>   }
> 
> --
> To unsubscribe from this list: send the line "unsubscribe kvm" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> 
> 


  reply	other threads:[~2011-10-28 12:09 UTC|newest]

Thread overview: 69+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <20110913093835.GB4265@localhost.localdomain>
     [not found] ` <20110914093441.e2bb305c.kamezawa.hiroyu@jp.fujitsu.com>
     [not found]   ` <4E705BC3.5000508@cn.fujitsu.com>
     [not found]     ` <20110915164704.9cacd407.kamezawa.hiroyu@jp.fujitsu.com>
     [not found]       ` <4E71B28F.7030201@cn.fujitsu.com>
     [not found]         ` <4E72F3BA.2000603@jp.fujitsu.com>
     [not found]           ` <4E73200A.7040908@jp.fujitsu.com>
     [not found]             ` <4E76C6AA.9080403@cn.fujitsu.com>
2011-09-22  9:50               ` [PATCH] qemu: Fix inject-nmi Lai Jiangshan
2011-09-22 14:51                 ` Jan Kiszka
2011-09-23  9:31                   ` [Qemu-devel] " Lai Jiangshan
2011-09-23  9:35                     ` Jan Kiszka
2011-09-25 14:07                     ` Avi Kivity
2011-09-25 17:22                       ` Jan Kiszka
2011-09-26  8:21                         ` Avi Kivity
2011-10-10  6:06                           ` Lai Jiangshan
2011-10-10  6:06                           ` [PATCH] kernel/kvm: fix improper nmi emulation (was: Re: [Qemu-devel] [PATCH] qemu: Fix inject-nmi) Lai Jiangshan
2011-10-10  6:40                             ` [PATCH] kernel/kvm: fix improper nmi emulation Jan Kiszka
2011-10-10 10:26                             ` Avi Kivity
2011-10-11 17:00                               ` [PATCH 1/1 V2] " Lai Jiangshan
2011-10-11 18:06                                 ` Jan Kiszka
2011-10-14  0:54                                   ` [PATCH 1/1 V3] " Lai Jiangshan
2011-10-16  8:54                                     ` Avi Kivity
2011-10-16  9:05                                       ` Jan Kiszka
2011-10-16  9:28                                         ` Avi Kivity
2011-10-12  7:02                                 ` [PATCH 1/1 V2] " Kenji Kaneshige
2011-10-12  7:01                               ` [PATCH] " Kenji Kaneshige
2011-10-10  6:06                           ` [PATCH] qemu-kvm: fix improper nmi emulation (was: Re: [Qemu-devel] [PATCH] qemu: Fix inject-nmi) Lai Jiangshan
2011-10-10  6:49                             ` [PATCH] qemu-kvm: fix improper nmi emulation Jan Kiszka
2011-10-10  9:47                               ` Andreas Färber
2011-10-11 17:03                               ` [PATCH 1/2 V2] qemu-kvm: Synchronize kernel headers Lai Jiangshan
2011-10-11 17:03                               ` [PATCH 2/2 V2] qemu-kvm: fix improper nmi emulation Lai Jiangshan
2011-10-11 18:17                                 ` Jan Kiszka
2011-10-14  0:53                                   ` [Qemu-devel] " Lai Jiangshan
2011-10-14  5:53                                     ` Jan Kiszka
2011-10-14  6:36                                       ` [PATCH 1/1 V4] " Lai Jiangshan
2011-10-14  6:49                                         ` Jan Kiszka
2011-10-14  7:43                                           ` Lai Jiangshan
2011-10-14  8:31                                             ` Jan Kiszka
2011-10-14  9:03                                           ` [PATCH 1/1 V5] kernel/kvm: introduce KVM_SET_LINT1 and " Lai Jiangshan
2011-10-14  9:07                                             ` Jan Kiszka
2011-10-14  9:27                                               ` [Qemu-devel] " Lai Jiangshan
2011-10-14  9:32                                                 ` Jan Kiszka
2011-10-16  9:39                                             ` Avi Kivity
2011-10-17  9:17                                               ` Lai Jiangshan
2011-10-17  9:54                                                 ` Avi Kivity
2011-10-17 10:21                                                   ` Jan Kiszka
2011-10-17  9:40                                               ` Lai Jiangshan
2011-10-17  9:49                                                 ` Avi Kivity
2011-10-17 16:00                                                   ` [PATCH 1/1 V6] qemu-kvm: " Lai Jiangshan
2011-10-18 19:41                                                     ` Jan Kiszka
2011-10-19  6:33                                                       ` Lai Jiangshan
2011-10-19 10:57                                                         ` Jan Kiszka
2011-10-19 15:21                                                           ` [PATCH 1/1 V6] qemu: " Lai Jiangshan
2011-10-19  9:29                                                       ` [PATCH 1/1 V6] qemu-kvm: " Avi Kivity
2011-10-19 15:32                                                         ` Lai Jiangshan
2011-12-07 10:29                                                     ` Avi Kivity
2011-12-08  9:42                                                       ` Jan Kiszka
2011-12-08 10:20                                                         ` Jan Kiszka
2011-10-14  9:03                                           ` [PATCH 1/2 V5] qemu-kvm: Synchronize kernel headers Lai Jiangshan
2011-10-14  9:03                                           ` [PATCH 2/2 V5] qemu-kvm: fix improper nmi emulation Lai Jiangshan
2011-10-14  9:22                                             ` Jan Kiszka
2011-10-14  9:51                                           ` [PATCH 1/1 V5 tuning] kernel/kvm: introduce KVM_SET_LINT1 and " Lai Jiangshan
2011-10-14 11:59                                             ` Sasha Levin
2011-10-14 12:07                                               ` [Qemu-devel] " Jan Kiszka
2011-10-16 15:01                                                 ` Lai Jiangshan
2011-10-14  9:51                                           ` [PATCH 1/2 V5 tuning] qemu-kvm: Synchronize kernel headers Lai Jiangshan
2011-10-14  0:54                                   ` [PATCH 1/1 V3] qemu-kvm: fix improper nmi emulation Lai Jiangshan
2011-10-10  6:06                           ` [PATCH 1/2] seabios: Add Local APIC NMI Structure to ACPI MADT (was: Re: [Qemu-devel] [PATCH] qemu: Fix inject-nmi) Lai Jiangshan
2011-10-28 12:08                             ` Kenji Kaneshige [this message]
2011-10-28 12:19                               ` [PATCH 1/2] seabios: Add Local APIC NMI Structure to ACPI MADT Gleb Natapov
2011-10-28 12:48                               ` [Qemu-devel] " Jun Koi
2011-10-31  8:00                                 ` Kenji Kaneshige
2011-10-30 14:44                             ` Avi Kivity
2011-10-30 14:44                               ` Avi Kivity
2011-10-10  6:06                           ` [PATCH 2/2] seabios: fix mptable nmi entry (was: Re: [Qemu-devel] [PATCH] qemu: Fix inject-nmi) Lai Jiangshan
2011-10-30 17:52                             ` Kevin O'Connor

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4EAA9B32.10706@jp.fujitsu.com \
    --to=kaneshige.kenji@jp.fujitsu.com \
    --cc=avi@redhat.com \
    --cc=gleb@redhat.com \
    --cc=jan.kiszka@web.de \
    --cc=kamezawa.hiroyu@jp.fujitsu.com \
    --cc=kevin@koconnor.net \
    --cc=kvm@vger.kernel.org \
    --cc=laijs@cn.fujitsu.com \
    --cc=qemu-devel@nongnu.org \
    --cc=seabios@seabios.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).