iommu/tegra241-cmdqv: Fix ioremap() error handling in probe()
authorDan Carpenter <dan.carpenter@linaro.org>
Wed, 4 Sep 2024 08:02:43 +0000 (11:02 +0300)
committerWill Deacon <will@kernel.org>
Wed, 4 Sep 2024 15:42:49 +0000 (16:42 +0100)
The ioremap() function doesn't return error pointers, it returns NULL
on error so update the error handling.  Also just return directly
instead of calling iounmap() on the NULL pointer.  Calling
iounmap(NULL) doesn't cause a problem on ARM but on other architectures
it can trigger a warning so it'a bad habbit.

Fixes: 918eb5c856f6 ("iommu/arm-smmu-v3: Add in-kernel support for NVIDIA Tegra241 (Grace) CMDQV")
Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
Reviewed-by: Nicolin Chen <nicolinc@nvidia.com>
Link: https://lore.kernel.org/r/5a6c1e9a-0724-41b1-86d4-36335d3768ea@stanley.mountain
Signed-off-by: Will Deacon <will@kernel.org>
drivers/iommu/arm/arm-smmu-v3/tegra241-cmdqv.c

index 03fd13c21dcc35ae76fd9360047ba271f2b35fde..240b5419217715967a227e98d634e725de339f0d 100644 (file)
@@ -772,9 +772,9 @@ __tegra241_cmdqv_probe(struct arm_smmu_device *smmu, struct resource *res,
        static_assert(offsetof(struct tegra241_cmdqv, smmu) == 0);
 
        base = ioremap(res->start, resource_size(res));
-       if (IS_ERR(base)) {
-               dev_err(smmu->dev, "failed to ioremap: %ld\n", PTR_ERR(base));
-               goto iounmap;
+       if (!base) {
+               dev_err(smmu->dev, "failed to ioremap\n");
+               return NULL;
        }
 
        regval = readl(base + TEGRA241_CMDQV_CONFIG);