iommu: Fix error unwind in iommu_group_alloc()
authorJason Gunthorpe <jgg@nvidia.com>
Thu, 16 Feb 2023 01:21:16 +0000 (21:21 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 10 Mar 2023 08:33:39 +0000 (09:33 +0100)
[ Upstream commit 4daa861174d56023c2068ddb03de0752f07fa199 ]

If either iommu_group_grate_file() fails then the
iommu_group is leaked.

Destroy it on these error paths.

Found by kselftest/iommu/iommufd_fail_nth

Fixes: bc7d12b91bd3 ("iommu: Implement reserved_regions iommu-group sysfs file")
Fixes: c52c72d3dee8 ("iommu: Add sysfs attribyte for domain type")
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
Reviewed-by: Lu Baolu <baolu.lu@linux.intel.com>
Link: https://lore.kernel.org/r/0-v1-8f616bee028d+8b-iommu_group_alloc_leak_jgg@nvidia.com
Signed-off-by: Joerg Roedel <jroedel@suse.de>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/iommu/iommu.c

index 959d895..fd8c8ae 100644 (file)
@@ -749,12 +749,16 @@ struct iommu_group *iommu_group_alloc(void)
 
        ret = iommu_group_create_file(group,
                                      &iommu_group_attr_reserved_regions);
-       if (ret)
+       if (ret) {
+               kobject_put(group->devices_kobj);
                return ERR_PTR(ret);
+       }
 
        ret = iommu_group_create_file(group, &iommu_group_attr_type);
-       if (ret)
+       if (ret) {
+               kobject_put(group->devices_kobj);
                return ERR_PTR(ret);
+       }
 
        pr_debug("Allocated group %d\n", group->id);