drivers/vfio: Enable VFIO if EEH is not supported
authorAlexey Kardashevskiy <aik@ozlabs.ru>
Fri, 8 Aug 2014 16:39:16 +0000 (10:39 -0600)
committerAlex Williamson <alex.williamson@redhat.com>
Fri, 8 Aug 2014 16:39:16 +0000 (10:39 -0600)
The existing vfio_pci_open() fails upon error returned from
vfio_spapr_pci_eeh_open(), which breaks POWER7's P5IOC2 PHB
support which this patch brings back.

The patch fixes the issue by dropping the return value of
vfio_spapr_pci_eeh_open().

Signed-off-by: Alexey Kardashevskiy <aik@ozlabs.ru>
Signed-off-by: Gavin Shan <gwshan@linux.vnet.ibm.com>
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
drivers/vfio/pci/vfio_pci.c
drivers/vfio/vfio_spapr_eeh.c
include/linux/vfio.h

index 1651c0769b728905ba759a87f0d1d3efcc2adcf7..f7825332a3251b2001645b581eec09524562fbec 100644 (file)
@@ -200,11 +200,7 @@ static int vfio_pci_open(void *device_data)
                if (ret)
                        goto error;
 
-               ret = vfio_spapr_pci_eeh_open(vdev->pdev);
-               if (ret) {
-                       vfio_pci_disable(vdev);
-                       goto error;
-               }
+               vfio_spapr_pci_eeh_open(vdev->pdev);
        }
        vdev->refcnt++;
 error:
index 4779cace803600b7dca44f339c2c310b9a062a9c..86dfceb9201f2503e2050dc71c8906fcd8abf281 100644 (file)
@@ -19,9 +19,9 @@
 #define DRIVER_DESC    "VFIO IOMMU SPAPR EEH"
 
 /* We might build address mapping here for "fast" path later */
-int vfio_spapr_pci_eeh_open(struct pci_dev *pdev)
+void vfio_spapr_pci_eeh_open(struct pci_dev *pdev)
 {
-       return eeh_dev_open(pdev);
+       eeh_dev_open(pdev);
 }
 EXPORT_SYMBOL_GPL(vfio_spapr_pci_eeh_open);
 
index 224128a96b7f5b28e7c3b00b8b72024b5b3d0759..d3204115f15d21dd7ef3d879df2393884795b037 100644 (file)
@@ -100,15 +100,14 @@ extern long vfio_external_check_extension(struct vfio_group *group,
 
 struct pci_dev;
 #ifdef CONFIG_EEH
-extern int vfio_spapr_pci_eeh_open(struct pci_dev *pdev);
+extern void vfio_spapr_pci_eeh_open(struct pci_dev *pdev);
 extern void vfio_spapr_pci_eeh_release(struct pci_dev *pdev);
 extern long vfio_spapr_iommu_eeh_ioctl(struct iommu_group *group,
                                       unsigned int cmd,
                                       unsigned long arg);
 #else
-static inline int vfio_spapr_pci_eeh_open(struct pci_dev *pdev)
+static inline void vfio_spapr_pci_eeh_open(struct pci_dev *pdev)
 {
-       return 0;
 }
 
 static inline void vfio_spapr_pci_eeh_release(struct pci_dev *pdev)