]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
PCI: iproc: Convert to platform remove callback returning void
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Tue, 21 Mar 2023 19:32:01 +0000 (20:32 +0100)
committerKrzysztof Wilczyński <kwilczynski@kernel.org>
Sat, 24 Jun 2023 14:12:36 +0000 (14:12 +0000)
The .remove() callback for a platform driver returns an int which makes
many driver authors wrongly assume it's possible to do error handling by
returning an error code. However the value returned is (mostly) ignored
and this typically results in resource leaks.

The iproc driver always returns 0, it's just a bit hidden. So make
iproc_pcie_remove() return void instead of always zero and convert the
platform driver to the alternative remove callback that returns void and
eventually replaces the int returning callback.

Link: https://lore.kernel.org/linux-pci/20230321193208.366561-9-u.kleine-koenig@pengutronix.de
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Krzysztof Wilczyński <kwilczynski@kernel.org>
Acked-by: Florian Fainelli <f.fainelli@gmail.com>
drivers/pci/controller/pcie-iproc-platform.c
drivers/pci/controller/pcie-iproc.c
drivers/pci/controller/pcie-iproc.h

index 4142a73e611d111553d83d8fbff788d2b1e55a5a..acdc583d29802ca3a33e62aec8c7de02b6fbc32c 100644 (file)
@@ -114,11 +114,11 @@ static int iproc_pltfm_pcie_probe(struct platform_device *pdev)
        return 0;
 }
 
-static int iproc_pltfm_pcie_remove(struct platform_device *pdev)
+static void iproc_pltfm_pcie_remove(struct platform_device *pdev)
 {
        struct iproc_pcie *pcie = platform_get_drvdata(pdev);
 
-       return iproc_pcie_remove(pcie);
+       iproc_pcie_remove(pcie);
 }
 
 static void iproc_pltfm_pcie_shutdown(struct platform_device *pdev)
@@ -134,7 +134,7 @@ static struct platform_driver iproc_pltfm_pcie_driver = {
                .of_match_table = of_match_ptr(iproc_pcie_of_match_table),
        },
        .probe = iproc_pltfm_pcie_probe,
-       .remove = iproc_pltfm_pcie_remove,
+       .remove_new = iproc_pltfm_pcie_remove,
        .shutdown = iproc_pltfm_pcie_shutdown,
 };
 module_platform_driver(iproc_pltfm_pcie_driver);
index 83029bdfd88444966da8215a2d4a2120d254a15f..bd1c98b688516cc9b96a5dc43e4723c4b7de410d 100644 (file)
@@ -1537,7 +1537,7 @@ err_exit_phy:
 }
 EXPORT_SYMBOL(iproc_pcie_setup);
 
-int iproc_pcie_remove(struct iproc_pcie *pcie)
+void iproc_pcie_remove(struct iproc_pcie *pcie)
 {
        struct pci_host_bridge *host = pci_host_bridge_from_priv(pcie);
 
@@ -1548,8 +1548,6 @@ int iproc_pcie_remove(struct iproc_pcie *pcie)
 
        phy_power_off(pcie->phy);
        phy_exit(pcie->phy);
-
-       return 0;
 }
 EXPORT_SYMBOL(iproc_pcie_remove);
 
index dcca315897c8ef83658652095ae3a39da36aab84..969ded03b8c2daf4ebb953b0997ac51c6fa3823c 100644 (file)
@@ -111,7 +111,7 @@ struct iproc_pcie {
 };
 
 int iproc_pcie_setup(struct iproc_pcie *pcie, struct list_head *res);
-int iproc_pcie_remove(struct iproc_pcie *pcie);
+void iproc_pcie_remove(struct iproc_pcie *pcie);
 int iproc_pcie_shutdown(struct iproc_pcie *pcie);
 
 #ifdef CONFIG_PCIE_IPROC_MSI