]> xenbits.xensource.com Git - qemu-upstream-4.5-testing.git/commit
fix MSI injection on Xen
authorStefano Stabellini <stefano.stabellini@eu.citrix.com>
Wed, 13 Jan 2016 14:59:09 +0000 (14:59 +0000)
committerStefano Stabellini <stefano.stabellini@eu.citrix.com>
Mon, 8 Feb 2016 15:20:32 +0000 (15:20 +0000)
commitdf8471f739cc24211fd42964de4367e72ab433f5
tree427f21e4b53c9361bbf91b89ab6252e923d7c89f
parent9497b3fec7842f42617a6aa479b5e4f4bcdbeb1d
fix MSI injection on Xen

On Xen MSIs can be remapped into pirqs, which are a type of event
channels. It's mostly for the benefit of PCI passthrough devices, to
avoid the overhead of interacting with the emulated lapic.

However remapping interrupts and MSIs is also supported for emulated
devices, such as the e1000 and virtio-net.

When an interrupt or an MSI is remapped into a pirq, masking and
unmasking is done by masking and unmasking the event channel. The
masking bit on the PCI config space or MSI-X table should be ignored,
but it isn't at the moment.

As a consequence emulated devices which use MSI or MSI-X, such as
virtio-net, don't work properly (the guest doesn't receive any
notifications). The mechanism was working properly when xen_apic was
introduced, but I haven't narrowed down which commit in particular is
causing the regression.

Fix the issue by ignoring the masking bit for MSI and MSI-X which have
been remapped into pirqs.

Signed-off-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
hw/pci/msi.c
hw/pci/msix.c
hw/xen/xen_pt_msi.c
include/hw/xen/xen.h
xen-hvm-stub.c
xen-hvm.c