From: Avi Kivity <avi@redhat.com>
To: Bernhard Kohl <bernhard.kohl@nsn.com>
Cc: kvm@vger.kernel.org
Subject: Re: [PATCH] KVM: IOAPIC: Do not check polarity
Date: Sun, 15 Mar 2009 12:38:37 +0200 [thread overview]
Message-ID: <49BCDAAD.7000706@redhat.com> (raw)
In-Reply-To: <loom.20090313T105104-837@post.gmane.org>
Bernhard Kohl wrote:
> NSN's proprietary OS DMX heavily depends on a correct BIOS MP table.
> From there it also gets the information for initialization of PCI
> devices. We defined the polarity and trigger mode as for standard
> PCI devices "low level". The OS programs the ioapic the same way.
>
> Nothing else in QEMU's and KVM's IRQ, PIC, IOAPIC and LAPIC code
> cares about interrupt polarity. The "level" is always used as a
> logical value. So we must not change the level here. If we do so,
> PCI low level interrupts are not fired if the guest raises the
> interrupt (level=1), but first if it is reset again (level=0). This
> can result in infinite waiting for a single interupt. For example
> the DMX guest waits for the link up interupt of the E1000
> ethernet device before enabling the TX and RX interupts of
> this device. E1000 emulation sets level=1, no interrupt is fired,
> deadlock.
>
> This does not happen if we use the -no-kvm-irqchip option.
> This means that qemu's ioapic does not care about the polarity and
> kvm's ioapic shouldn't do either.
>
While qemu uses active-high interrupts throughout, kvm is meant to be
useful with other userspace (or for emulating other chipsets) and thus
needs correct polarity emulation.
If the guest programs polarity to active-low, this indicates either a
guest bug or a bios bug. Is it possible the bios does not communicate
the fact that pci interrupts are active high correctly?
--
error compiling committee.c: too many arguments to function
next prev parent reply other threads:[~2009-03-15 10:38 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-03-13 10:53 [PATCH] KVM: IOAPIC: Do not check polarity Bernhard Kohl
2009-03-15 10:38 ` Avi Kivity [this message]
2009-03-16 22:30 ` Bernhard Kohl
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=49BCDAAD.7000706@redhat.com \
--to=avi@redhat.com \
--cc=bernhard.kohl@nsn.com \
--cc=kvm@vger.kernel.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