Here is the port of MSI-X support patches to upstream qemu. Please comment or commit. This patchset adds generic support for MSI-X, adds implementation in APIC, and uses MSI-X in virtio-net. Changelog: - since v5 make sure that load does not modify registers that guest can not change replace global msix disable flag with a per-device flag to control the number of vectors - since v4 rebased to latest bits - since v3 call to resize_region on load split patches a bit differently to address style comments by Glauber update commit message to clarify what msix_support flag does - since v2 rename mask -> wmask to avoid conflict with work by Yamahata - since v1 At Paul's suggestion, use stl_phy to decouple APIC and MSI-X implementation This uses the mask table patch that I posted previously, and which is included in the series. That patch has been slightly updated due to mask -> wmask rename. Isaku Yamahata, maybe you want to update your patch series with that. -- MST Michael S. Tsirkin (12): qemu/pci: make default_write_config use mask table qemu/pci: helper routines for pci access qemu/pci: add routines to manage PCI capabilities qemu/pci: check constant registers on load qemu/pci: MSI-X support functions qemu/apic: minimal MSI/MSI-X implementation for PC qemu/virtio: virtio support for many interrupt vectors qemu/virtio: MSI-X support in virtio PCI qemu/virtio: virtio save/load bindings qemu/pci: add pci_get/set_byte qemu/net: request 3 vectors in virtio-net qemu/net: flag to control the number of vectors a nic has Makefile.target | 2 +- hw/apic.c | 43 ++++++- hw/msix.c | 378 ++++++++++++++++++++++++++++++++++++++++++++++++++++ hw/msix.h | 34 +++++ hw/pci.c | 245 ++++++++++++++++++---------------- hw/pci.h | 106 ++++++++++++++- hw/syborg_virtio.c | 13 ++- hw/virtio-net.c | 4 + hw/virtio-pci.c | 212 +++++++++++++++++++++++------ hw/virtio.c | 70 +++++++--- hw/virtio.h | 14 ++- net.c | 18 +++- net.h | 4 + qemu-options.hx | 14 +- rules.mak | 2 +- 15 files changed, 956 insertions(+), 203 deletions(-) create mode 100644 hw/msix.c create mode 100644 hw/msix.h -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html