qemu-e2k/hw/pci
Stefano Stabellini 428c3ece97 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>
2016-02-06 20:44:10 +02:00
..
Makefile.objs
msi.c fix MSI injection on Xen 2016-02-06 20:44:10 +02:00
msix.c fix MSI injection on Xen 2016-02-06 20:44:10 +02:00
pci_bridge.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
pci_host.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
pci-stub.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
pci.c hw/pci: ensure that only PCI/PCIe bridges can be attached to pxb/pxb-pcie devices 2016-02-06 20:44:08 +02:00
pcie_aer.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
pcie_host.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
pcie_port.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
pcie.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
shpc.c pci: Clean up includes 2016-01-29 15:07:24 +00:00
slotid_cap.c pci: Clean up includes 2016-01-29 15:07:24 +00:00