]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
iommufd/selftest: Replace mock_viommu_alloc with mock_viommu_init
authorNicolin Chen <nicolinc@nvidia.com>
Sat, 14 Jun 2025 06:35:21 +0000 (23:35 -0700)
committerJason Gunthorpe <jgg@nvidia.com>
Thu, 19 Jun 2025 18:43:29 +0000 (15:43 -0300)
To ease the for-driver iommufd APIs, get_viommu_size and viommu_init ops
are introduced.

Sanitize the inputs and report the size of struct mock_viommu on success,
in mock_get_viommu_size().

The core will ensure the viommu_type is set to the core vIOMMU object, so
simply init the driver part in mock_viommu_init().

Remove the mock_viommu_alloc, completing the replacement.

Link: https://patch.msgid.link/r/993beabbb0bc9705d979a92801ea5ed5996a34eb.1749882255.git.nicolinc@nvidia.com
Reviewed-by: Kevin Tian <kevin.tian@intel.com>
Signed-off-by: Nicolin Chen <nicolinc@nvidia.com>
Reviewed-by: Jason Gunthorpe <jgg@nvidia.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
drivers/iommu/iommufd/selftest.c

index f9cfb3a20860ef2107ba7ecb36999cb56a57bdc3..74ca955a766e75be009a8533a39d78e8910fcb3f 100644 (file)
@@ -769,25 +769,23 @@ static struct iommufd_viommu_ops mock_viommu_ops = {
        .cache_invalidate = mock_viommu_cache_invalidate,
 };
 
-static struct iommufd_viommu *mock_viommu_alloc(struct device *dev,
-                                               struct iommu_domain *domain,
-                                               struct iommufd_ctx *ictx,
-                                               unsigned int viommu_type)
+static size_t mock_get_viommu_size(struct device *dev,
+                                  enum iommu_viommu_type viommu_type)
 {
-       struct mock_iommu_device *mock_iommu =
-               iommu_get_iommu_dev(dev, struct mock_iommu_device, iommu_dev);
-       struct mock_viommu *mock_viommu;
-
        if (viommu_type != IOMMU_VIOMMU_TYPE_SELFTEST)
-               return ERR_PTR(-EOPNOTSUPP);
+               return 0;
+       return VIOMMU_STRUCT_SIZE(struct mock_viommu, core);
+}
 
-       mock_viommu = iommufd_viommu_alloc(ictx, struct mock_viommu, core,
-                                          &mock_viommu_ops);
-       if (IS_ERR(mock_viommu))
-               return ERR_CAST(mock_viommu);
+static int mock_viommu_init(struct iommufd_viommu *viommu,
+                           struct iommu_domain *parent_domain)
+{
+       struct mock_iommu_device *mock_iommu = container_of(
+               viommu->iommu_dev, struct mock_iommu_device, iommu_dev);
 
        refcount_inc(&mock_iommu->users);
-       return &mock_viommu->core;
+       viommu->ops = &mock_viommu_ops;
+       return 0;
 }
 
 static const struct iommu_ops mock_ops = {
@@ -807,7 +805,8 @@ static const struct iommu_ops mock_ops = {
        .probe_device = mock_probe_device,
        .page_response = mock_domain_page_response,
        .user_pasid_table = true,
-       .viommu_alloc = mock_viommu_alloc,
+       .get_viommu_size = mock_get_viommu_size,
+       .viommu_init = mock_viommu_init,
        .default_domain_ops =
                &(struct iommu_domain_ops){
                        .free = mock_domain_free,