]> xenbits.xensource.com Git - qemu-upstream-4.4-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:26:16 +0000 (15:26 +0000)
commite2888602131248aae6bb49243a03ec811d6508a3
tree01a4019e7ccebf3e523887596a51dc700ed95ea8
parent11ac1da95c4e8b2c9c627e0cbcaa50c90c298a1b
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-all.c
xen-stub.c