[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-ppc] [PATCH 7/7] vfio: Expose a VFIO PCI device's group for EEH
From: |
David Gibson |
Subject: |
[Qemu-ppc] [PATCH 7/7] vfio: Expose a VFIO PCI device's group for EEH |
Date: |
Thu, 24 Sep 2015 14:33:51 +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
- Re: [Qemu-ppc] [PATCH 5/7] memory: Allow replay of IOMMU mapping notifications, (continued)
- Re: [Qemu-ppc] [PATCH 5/7] memory: Allow replay of IOMMU mapping notifications, Paolo Bonzini, 2015/09/25
- Re: [Qemu-ppc] [PATCH 5/7] memory: Allow replay of IOMMU mapping notifications, David Gibson, 2015/09/25
- Re: [Qemu-ppc] [PATCH 5/7] memory: Allow replay of IOMMU mapping notifications, Paolo Bonzini, 2015/09/25
- Re: [Qemu-ppc] [PATCH 5/7] memory: Allow replay of IOMMU mapping notifications, David Gibson, 2015/09/26
- Re: [Qemu-ppc] [PATCH 5/7] memory: Allow replay of IOMMU mapping notifications, Paolo Bonzini, 2015/09/28
- Re: [Qemu-ppc] [PATCH 5/7] memory: Allow replay of IOMMU mapping notifications, David Gibson, 2015/09/29
[Qemu-ppc] [PATCH 7/7] vfio: Expose a VFIO PCI device's group for EEH,
David Gibson <=
[Qemu-ppc] [PATCH 3/7] vfio: Check guest IOVA ranges against host IOMMU capabilities, David Gibson, 2015/09/24
[Qemu-ppc] [PATCH 6/7] vfio: Allow hotplug of containers onto existing guest IOMMU mappings, David Gibson, 2015/09/24
[Qemu-ppc] [PATCH 1/7] vfio: Remove unneeded union from VFIOContainer, David Gibson, 2015/09/24