irqchip/gic-v5: iwb: Fix iounmap probe failure path
authorLorenzo Pieralisi <lpieralisi@kernel.org>
Fri, 1 Aug 2025 07:58:18 +0000 (09:58 +0200)
committerThomas Gleixner <tglx@linutronix.de>
Tue, 5 Aug 2025 08:43:48 +0000 (10:43 +0200)
The 0-day bot reported that on the failure path the driver iounmap()s IWB
resources that are managed through devm_ioremap(), which is clearly wrong
because the driver would end up unmapping the MMIO resource twice on
probing failure.

Fix this by removing the error path altogether and by letting devres manage
the iounmapping on clean-up.

Fixes: 695949d8b16f ("irqchip/gic-v5: Add GICv5 IWB support")
Reported-by: kernel test robot <lkp@intel.com>
Signed-off-by: Lorenzo Pieralisi <lpieralisi@kernel.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Reviewed-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/all/20250801-gic-v5-fixes-6-17-v1-1-4fcedaccf9e6@kernel.org
Closes: https://lore.kernel.org/oe-kbuild-all/202508010038.N3r4ZmII-lkp@intel.com

drivers/irqchip/irq-gic-v5-iwb.c

index ed72fbdd4900a4361943d9407b9badc0d2e940a6..ad9fdc14d1c632ecd034ffb54d760c2384768cea 100644 (file)
@@ -241,7 +241,6 @@ static int gicv5_iwb_device_probe(struct platform_device *pdev)
        struct gicv5_iwb_chip_data *iwb_node;
        void __iomem *iwb_base;
        struct resource *res;
-       int ret;
 
        res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
        if (!res)
@@ -254,16 +253,10 @@ static int gicv5_iwb_device_probe(struct platform_device *pdev)
        }
 
        iwb_node = gicv5_iwb_init_bases(iwb_base, pdev);
-       if (IS_ERR(iwb_node)) {
-               ret = PTR_ERR(iwb_node);
-               goto out_unmap;
-       }
+       if (IS_ERR(iwb_node))
+               return PTR_ERR(iwb_node);
 
        return 0;
-
-out_unmap:
-       iounmap(iwb_base);
-       return ret;
 }
 
 static const struct of_device_id gicv5_iwb_of_match[] = {