]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
vfio: add a singleton check for vfio_group_pin_pages
authorYan Zhao <yan.y.zhao@intel.com>
Wed, 16 Sep 2020 02:28:33 +0000 (10:28 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 29 Oct 2020 09:08:05 +0000 (10:08 +0100)
[ Upstream commit 7ef32e52368f62a4e041a4f0abefb4fb64e7fd4a ]

Page pinning is used both to translate and pin device mappings for DMA
purpose, as well as to indicate to the IOMMU backend to limit the dirty
page scope to those pages that have been pinned, in the case of an IOMMU
backed device.
To support this, the vfio_pin_pages() interface limits itself to only
singleton groups such that the IOMMU backend can consider dirty page
scope only at the group level.  Implement the same requirement for the
vfio_group_pin_pages() interface.

Fixes: 95fc87b44104 ("vfio: Selective dirty page tracking if IOMMU backed device pins pages")
Signed-off-by: Yan Zhao <yan.y.zhao@intel.com>
Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/vfio/vfio.c

index 580099afeaffad38fc40105301af22af27ad1921..2a70e25cfe954428b3b8b9e62c05ad65b943230d 100644 (file)
@@ -2050,6 +2050,9 @@ int vfio_group_pin_pages(struct vfio_group *group,
        if (!group || !user_iova_pfn || !phys_pfn || !npage)
                return -EINVAL;
 
+       if (group->dev_counter > 1)
+               return -EINVAL;
+
        if (npage > VFIO_PIN_PAGES_MAX_ENTRIES)
                return -E2BIG;