vfio: fix race condition with sysfs
authorMichael Haeuptle <michael.haeuptle@hpe.com>
Mon, 6 Apr 2020 22:23:23 +0000 (22:23 +0000)
committerDavid Marchand <david.marchand@redhat.com>
Tue, 21 Apr 2020 16:13:44 +0000 (18:13 +0200)
This fix treats a 0 return value from vfio_open_group_fd
in vfio_get_group_fd as the intended error condition instead
of putting an incorrect 0 file descriptor in the vfio_group table.

Sometimes, the creation of device files in sysfs is not
instantaneously causing vfio_open_groupfd to return 0.
This has been observed when hot removing/adding multiple
NVMe devices (>=4).

Fixes: 340b7bb8d583 ("vfio: extend data structure for multi container")
Cc: stable@dpdk.org
Signed-off-by: Michael Haeuptle <michael.haeuptle@hpe.com>
Acked-by: Darek Stojaczyk <dariusz.stojaczyk@intel.com>
Acked-by: Anatoly Burakov <anatoly.burakov@intel.com>
lib/librte_eal/linux/eal_vfio.c

index 4502aef..1979f6f 100644 (file)
@@ -379,7 +379,7 @@ vfio_get_group_fd(struct vfio_config *vfio_cfg,
        }
 
        vfio_group_fd = vfio_open_group_fd(iommu_group_num);
-       if (vfio_group_fd < 0) {
+       if (vfio_group_fd <= 0) {
                RTE_LOG(ERR, EAL, "Failed to open group %d\n", iommu_group_num);
                return -1;
        }