]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
vfio: selftests: Expose more vfio_pci_device functions
authorRaghavendra Rao Ananta <rananta@google.com>
Tue, 5 May 2026 21:28:35 +0000 (21:28 +0000)
committerAlex Williamson <alex@shazbot.org>
Wed, 20 May 2026 17:54:10 +0000 (11:54 -0600)
Refactor and make the functions called under device initialization
public. A later patch adds a test that calls these functions to validate
the UAPI of SR-IOV devices. Opportunistically, to test the success
and failure cases of the UAPI, split the functions dealing with
VFIO_GROUP_GET_DEVICE_FD and VFIO_DEVICE_BIND_IOMMUFD into a core
function and another one that asserts the ioctl. The former will be
used for testing the SR-IOV UAPI, hence only export these.

Signed-off-by: Raghavendra Rao Ananta <rananta@google.com>
Reviewed-by: David Matlack <dmatlack@google.com>
Reviewed-by: Vipin Sharma <vipinsh@google.com>
Tested-by: David Matlack <dmatlack@google.com>
Link: https://lore.kernel.org/r/20260505212838.1698034-6-rananta@google.com
Signed-off-by: Alex Williamson <alex@shazbot.org>
tools/testing/selftests/vfio/lib/include/libvfio/vfio_pci_device.h
tools/testing/selftests/vfio/lib/vfio_pci_device.c

index 2858885a89bbbf05444b6e03b1f5826fb71bec58..898de032fed5aa866d639d97a0eb7a7944feec96 100644 (file)
@@ -122,4 +122,11 @@ static inline bool vfio_pci_device_match(struct vfio_pci_device *device,
 
 const char *vfio_pci_get_cdev_path(const char *bdf);
 
+void vfio_pci_group_setup(struct vfio_pci_device *device, const char *bdf);
+void __vfio_pci_group_get_device_fd(struct vfio_pci_device *device,
+                                   const char *bdf, const char *vf_token);
+void vfio_container_set_iommu(struct vfio_pci_device *device);
+void vfio_pci_cdev_open(struct vfio_pci_device *device, const char *bdf);
+int __vfio_device_bind_iommufd(int device_fd, int iommufd, const char *vf_token);
+
 #endif /* SELFTESTS_VFIO_LIB_INCLUDE_LIBVFIO_VFIO_PCI_DEVICE_H */
index e59b6689f45769902cff002502a89cfad7b48e14..53e01cdb2b4e5d884c168124f0d8e70c85adc936 100644 (file)
@@ -204,7 +204,7 @@ void vfio_pci_device_reset(struct vfio_pci_device *device)
        ioctl_assert(device->fd, VFIO_DEVICE_RESET, NULL);
 }
 
-static void vfio_pci_group_setup(struct vfio_pci_device *device, const char *bdf)
+void vfio_pci_group_setup(struct vfio_pci_device *device, const char *bdf)
 {
        struct vfio_group_status group_status = {
                .argsz = sizeof(group_status),
@@ -224,8 +224,8 @@ static void vfio_pci_group_setup(struct vfio_pci_device *device, const char *bdf
        ioctl_assert(device->group_fd, VFIO_GROUP_SET_CONTAINER, &device->iommu->container_fd);
 }
 
-static void vfio_pci_group_get_device_fd(struct vfio_pci_device *device,
-                                        const char *bdf, const char *vf_token)
+void __vfio_pci_group_get_device_fd(struct vfio_pci_device *device,
+                                   const char *bdf, const char *vf_token)
 {
        char arg[64];
 
@@ -240,18 +240,21 @@ static void vfio_pci_group_get_device_fd(struct vfio_pci_device *device,
                snprintf_assert(arg, ARRAY_SIZE(arg), "%s", bdf);
 
        device->fd = ioctl(device->group_fd, VFIO_GROUP_GET_DEVICE_FD, arg);
+}
+
+static void vfio_pci_group_get_device_fd(struct vfio_pci_device *device,
+                                        const char *bdf, const char *vf_token)
+{
+       __vfio_pci_group_get_device_fd(device, bdf, vf_token);
        VFIO_ASSERT_GE(device->fd, 0);
 }
 
-static void vfio_pci_container_setup(struct vfio_pci_device *device,
-                                    const char *bdf, const char *vf_token)
+void vfio_container_set_iommu(struct vfio_pci_device *device)
 {
        struct iommu *iommu = device->iommu;
        unsigned long iommu_type = iommu->mode->iommu_type;
        int ret;
 
-       vfio_pci_group_setup(device, bdf);
-
        ret = ioctl(iommu->container_fd, VFIO_CHECK_EXTENSION, iommu_type);
        VFIO_ASSERT_GT(ret, 0, "VFIO IOMMU type %lu not supported\n", iommu_type);
 
@@ -261,7 +264,13 @@ static void vfio_pci_container_setup(struct vfio_pci_device *device,
         * because the IOMMU type is already set.
         */
        (void)ioctl(iommu->container_fd, VFIO_SET_IOMMU, (void *)iommu_type);
+}
 
+static void vfio_pci_container_setup(struct vfio_pci_device *device,
+                                    const char *bdf, const char *vf_token)
+{
+       vfio_pci_group_setup(device, bdf);
+       vfio_container_set_iommu(device);
        vfio_pci_group_get_device_fd(device, bdf, vf_token);
 }
 
@@ -323,8 +332,7 @@ const char *vfio_pci_get_cdev_path(const char *bdf)
        return cdev_path;
 }
 
-static void vfio_device_bind_iommufd(int device_fd, int iommufd,
-                                    const char *vf_token)
+int __vfio_device_bind_iommufd(int device_fd, int iommufd, const char *vf_token)
 {
        struct vfio_device_bind_iommufd args = {
                .argsz = sizeof(args),
@@ -338,7 +346,18 @@ static void vfio_device_bind_iommufd(int device_fd, int iommufd,
                args.token_uuid_ptr = (u64)token_uuid;
        }
 
-       ioctl_assert(device_fd, VFIO_DEVICE_BIND_IOMMUFD, &args);
+       if (ioctl(device_fd, VFIO_DEVICE_BIND_IOMMUFD, &args))
+               return -errno;
+
+       return 0;
+}
+
+static void vfio_device_bind_iommufd(int device_fd, int iommufd,
+                                    const char *vf_token)
+{
+       int ret = __vfio_device_bind_iommufd(device_fd, iommufd, vf_token);
+
+       VFIO_ASSERT_EQ(ret, 0, "Failed VFIO_DEVICE_BIND_IOMMUFD ioctl\n");
 }
 
 static void vfio_device_attach_iommufd_pt(int device_fd, u32 pt_id)
@@ -351,15 +370,19 @@ static void vfio_device_attach_iommufd_pt(int device_fd, u32 pt_id)
        ioctl_assert(device_fd, VFIO_DEVICE_ATTACH_IOMMUFD_PT, &args);
 }
 
-static void vfio_pci_iommufd_setup(struct vfio_pci_device *device,
-                                  const char *bdf, const char *vf_token)
+void vfio_pci_cdev_open(struct vfio_pci_device *device, const char *bdf)
 {
        const char *cdev_path = vfio_pci_get_cdev_path(bdf);
 
        device->fd = open(cdev_path, O_RDWR);
        VFIO_ASSERT_GE(device->fd, 0);
        free((void *)cdev_path);
+}
 
+static void vfio_pci_iommufd_setup(struct vfio_pci_device *device,
+                                  const char *bdf, const char *vf_token)
+{
+       vfio_pci_cdev_open(device, bdf);
        vfio_device_bind_iommufd(device->fd, device->iommu->iommufd, vf_token);
        vfio_device_attach_iommufd_pt(device->fd, device->iommu->ioas_id);
 }