[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-ppc] [PATCHv2 7/7] vfio: Expose a VFIO PCI device's group for EEH
From: |
David Gibson |
Subject: |
[Qemu-ppc] [PATCHv2 7/7] vfio: Expose a VFIO PCI device's group for EEH |
Date: |
Fri, 25 Sep 2015 21:35:08 +1000 |
The Enhanced Error Handling (EEH) interface in PAPR operates on units of a
Partitionable Endpoint (PE). For VFIO devices, the PE boundaries the guest
sees must match the PE (i.e. IOMMU group) boundaries on the host. To
implement this it will need to discover from VFIO which group a given
device belongs to.
This exposes a new vfio_pci_device_group() function for this purpose.
Signed-off-by: David Gibson <address@hidden>
---
hw/vfio/pci.c | 14 ++++++++++++++
include/hw/vfio/vfio-pci.h | 11 +++++++++++
2 files changed, 25 insertions(+)
create mode 100644 include/hw/vfio/vfio-pci.h
diff --git a/hw/vfio/pci.c b/hw/vfio/pci.c
index dcabb6d..49ae834 100644
--- a/hw/vfio/pci.c
+++ b/hw/vfio/pci.c
@@ -35,6 +35,8 @@
#include "pci.h"
#include "trace.h"
+#include "hw/vfio/vfio-pci.h"
+
#define MSIX_CAP_LENGTH 12
static void vfio_disable_interrupts(VFIOPCIDevice *vdev);
@@ -2312,6 +2314,18 @@ static void vfio_unregister_req_notifier(VFIOPCIDevice
*vdev)
vdev->req_enabled = false;
}
+VFIOGroup *vfio_pci_device_group(PCIDevice *pdev)
+{
+ VFIOPCIDevice *vdev;
+
+ if (!object_dynamic_cast(OBJECT(pdev), "vfio-pci")) {
+ return NULL;
+ }
+
+ vdev = DO_UPCAST(VFIOPCIDevice, pdev, pdev);
+ return vdev->vbasedev.group;
+}
+
static int vfio_initfn(PCIDevice *pdev)
{
VFIOPCIDevice *vdev = DO_UPCAST(VFIOPCIDevice, pdev, pdev);
diff --git a/include/hw/vfio/vfio-pci.h b/include/hw/vfio/vfio-pci.h
new file mode 100644
index 0000000..32105f7
--- /dev/null
+++ b/include/hw/vfio/vfio-pci.h
@@ -0,0 +1,11 @@
+#ifndef VFIO_PCI_H
+#define VFIO_PCI_H
+
+#include "qemu/typedefs.h"
+
+/* We expose the concept of a VFIOGroup, though not its internals */
+typedef struct VFIOGroup VFIOGroup;
+
+extern VFIOGroup *vfio_pci_device_group(PCIDevice *pdev);
+
+#endif /* VFIO_PCI_H */
--
2.4.3
- [Qemu-ppc] [PATCHv2 0/7] VFIO extensions to allow VFIO devices on spapr-pci-host-bridge, David Gibson, 2015/09/25
- [Qemu-ppc] [PATCHv2 4/7] vfio: Record host IOMMU's available IO page sizes, David Gibson, 2015/09/25
- [Qemu-ppc] [PATCHv2 1/7] vfio: Remove unneeded union from VFIOContainer, David Gibson, 2015/09/25
- [Qemu-ppc] [PATCHv2 5/7] memory: Allow replay of IOMMU mapping notifications, David Gibson, 2015/09/25
- [Qemu-ppc] [PATCHv2 2/7] vfio: Generalize vfio_listener_region_add failure path, David Gibson, 2015/09/25
- [Qemu-ppc] [PATCHv2 6/7] vfio: Allow hotplug of containers onto existing guest IOMMU mappings, David Gibson, 2015/09/25
- [Qemu-ppc] [PATCHv2 3/7] vfio: Check guest IOVA ranges against host IOMMU capabilities, David Gibson, 2015/09/25
- [Qemu-ppc] [PATCHv2 7/7] vfio: Expose a VFIO PCI device's group for EEH,
David Gibson <=
- Re: [Qemu-ppc] [PATCHv2 0/7] VFIO extensions to allow VFIO devices on spapr-pci-host-bridge, Laurent Vivier, 2015/09/25