linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 00/11] usb: phy: Convert to platform remove callback returning void
@ 2023-03-19  9:24 Uwe Kleine-König
  2023-03-19  9:24 ` [PATCH 08/11] usb: phy: mxs: " Uwe Kleine-König
  0 siblings, 1 reply; 3+ messages in thread
From: Uwe Kleine-König @ 2023-03-19  9:24 UTC (permalink / raw)
  To: Greg Kroah-Hartman, Ran Wang, Yang Yingliang, Li Jun,
	Sean Anderson, Sascha Hauer, Linus Walleij, Colin Ian King,
	Shawn Guo, Frank Li, Thierry Reding, Jonathan Hunter,
	Dmitry Torokhov
  Cc: linux-usb, kernel, linuxppc-dev, Fabio Estevam, NXP Linux Team,
	linux-arm-kernel, linux-tegra

Hello,

this series adapts the platform drivers below drivers/usb/phy to use the
.remove_new() callback. Compared to the traditional .remove() callback
.remove_new() returns no value. This is a good thing because the driver core
doesn't (and cannot) cope for errors during remove. The only effect of a
non-zero return value in .remove() is that the driver core emits a warning. The
device is removed anyhow and an early return from .remove() usually yields a
resource leak.

By changing the remove callback to return void driver authors cannot
reasonably assume any more that there is some kind of cleanup later.

All drivers could be converted trivally as they all returned zero
unconditionally in their .remove() callback.

Best regards
Uwe


Uwe Kleine-König (11):
  usb: phy: ab8500: Convert to platform remove callback returning void
  usb: phy: am335x: Convert to platform remove callback returning void
  usb: phy: fsl: Convert to platform remove callback returning void
  usb: phy: generic: Convert to platform remove callback returning void
  usb: phy: gpio-vbus: Convert to platform remove callback returning
    void
  usb: phy: keystone: Convert to platform remove callback returning void
  usb: phy: mv: Convert to platform remove callback returning void
  usb: phy: mxs: Convert to platform remove callback returning void
  usb: phy: tahvo: Convert to platform remove callback returning void
  usb: phy: tegra: Convert to platform remove callback returning void
  usb: phy: twl6030: Convert to platform remove callback returning void

 drivers/usb/phy/phy-ab8500-usb.c    | 6 ++----
 drivers/usb/phy/phy-am335x.c        | 5 ++---
 drivers/usb/phy/phy-fsl-usb.c       | 6 ++----
 drivers/usb/phy/phy-generic.c       | 6 ++----
 drivers/usb/phy/phy-gpio-vbus-usb.c | 6 ++----
 drivers/usb/phy/phy-keystone.c      | 6 ++----
 drivers/usb/phy/phy-mv-usb.c        | 6 ++----
 drivers/usb/phy/phy-mxs-usb.c       | 6 ++----
 drivers/usb/phy/phy-tahvo.c         | 6 ++----
 drivers/usb/phy/phy-tegra-usb.c     | 6 ++----
 drivers/usb/phy/phy-twl6030-usb.c   | 6 ++----
 11 files changed, 22 insertions(+), 43 deletions(-)


base-commit: fe15c26ee26efa11741a7b632e9f23b01aca4cc6
-- 
2.39.2


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [PATCH 08/11] usb: phy: mxs: Convert to platform remove callback returning void
  2023-03-19  9:24 [PATCH 00/11] usb: phy: Convert to platform remove callback returning void Uwe Kleine-König
@ 2023-03-19  9:24 ` Uwe Kleine-König
  2023-03-20 14:54   ` [EXT] " Frank Li
  0 siblings, 1 reply; 3+ messages in thread
From: Uwe Kleine-König @ 2023-03-19  9:24 UTC (permalink / raw)
  To: Greg Kroah-Hartman, Shawn Guo, Sascha Hauer, Frank Li
  Cc: Fabio Estevam, NXP Linux Team, linux-usb, linux-arm-kernel, kernel

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. To improve here there is a
quest to make the remove callback return void. In the first step of this
quest all drivers are converted to .remove_new() which already returns
void.

Trivially convert this driver from always returning zero in the remove
callback to the void returning variant.

Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
---
 drivers/usb/phy/phy-mxs-usb.c | 6 ++----
 1 file changed, 2 insertions(+), 4 deletions(-)

diff --git a/drivers/usb/phy/phy-mxs-usb.c b/drivers/usb/phy/phy-mxs-usb.c
index d2836ef5d15c..b21eecacc3b7 100644
--- a/drivers/usb/phy/phy-mxs-usb.c
+++ b/drivers/usb/phy/phy-mxs-usb.c
@@ -801,13 +801,11 @@ static int mxs_phy_probe(struct platform_device *pdev)
 	return usb_add_phy_dev(&mxs_phy->phy);
 }
 
-static int mxs_phy_remove(struct platform_device *pdev)
+static void mxs_phy_remove(struct platform_device *pdev)
 {
 	struct mxs_phy *mxs_phy = platform_get_drvdata(pdev);
 
 	usb_remove_phy(&mxs_phy->phy);
-
-	return 0;
 }
 
 #ifdef CONFIG_PM_SLEEP
@@ -853,7 +851,7 @@ static SIMPLE_DEV_PM_OPS(mxs_phy_pm, mxs_phy_system_suspend,
 
 static struct platform_driver mxs_phy_driver = {
 	.probe = mxs_phy_probe,
-	.remove = mxs_phy_remove,
+	.remove_new = mxs_phy_remove,
 	.driver = {
 		.name = DRIVER_NAME,
 		.of_match_table = mxs_phy_dt_ids,
-- 
2.39.2


_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* RE: [EXT] [PATCH 08/11] usb: phy: mxs: Convert to platform remove callback returning void
  2023-03-19  9:24 ` [PATCH 08/11] usb: phy: mxs: " Uwe Kleine-König
@ 2023-03-20 14:54   ` Frank Li
  0 siblings, 0 replies; 3+ messages in thread
From: Frank Li @ 2023-03-20 14:54 UTC (permalink / raw)
  To: Uwe Kleine-König, Greg Kroah-Hartman, Shawn Guo, Sascha Hauer
  Cc: Fabio Estevam, dl-linux-imx, linux-usb, linux-arm-kernel, kernel



> -----Original Message-----
> From: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
> Sent: Sunday, March 19, 2023 4:24 AM
> To: Greg Kroah-Hartman <gregkh@linuxfoundation.org>; Shawn Guo
> <shawnguo@kernel.org>; Sascha Hauer <s.hauer@pengutronix.de>; Frank Li
> <frank.li@nxp.com>
> Cc: Fabio Estevam <festevam@gmail.com>; dl-linux-imx <linux-
> imx@nxp.com>; linux-usb@vger.kernel.org; linux-arm-
> kernel@lists.infradead.org; kernel@pengutronix.de
> Subject: [EXT] [PATCH 08/11] usb: phy: mxs: Convert to platform remove
> callback returning void
> 
> Caution: EXT Email
> 
> 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. To improve here there is a
> quest to make the remove callback return void. In the first step of this
> quest all drivers are converted to .remove_new() which already returns
> void.
> 
> Trivially convert this driver from always returning zero in the remove
> callback to the void returning variant.
> 
> Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
> ---

Reviewed-by: Frank Li <Frank.li@nxp.com>
 

>  drivers/usb/phy/phy-mxs-usb.c | 6 ++----
>  1 file changed, 2 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/usb/phy/phy-mxs-usb.c b/drivers/usb/phy/phy-mxs-
> usb.c
> index d2836ef5d15c..b21eecacc3b7 100644
> --- a/drivers/usb/phy/phy-mxs-usb.c
> +++ b/drivers/usb/phy/phy-mxs-usb.c
> @@ -801,13 +801,11 @@ static int mxs_phy_probe(struct platform_device
> *pdev)
>         return usb_add_phy_dev(&mxs_phy->phy);
>  }
> 
> -static int mxs_phy_remove(struct platform_device *pdev)
> +static void mxs_phy_remove(struct platform_device *pdev)
>  {
>         struct mxs_phy *mxs_phy = platform_get_drvdata(pdev);
> 
>         usb_remove_phy(&mxs_phy->phy);
> -
> -       return 0;
>  }
> 
>  #ifdef CONFIG_PM_SLEEP
> @@ -853,7 +851,7 @@ static SIMPLE_DEV_PM_OPS(mxs_phy_pm,
> mxs_phy_system_suspend,
> 
>  static struct platform_driver mxs_phy_driver = {
>         .probe = mxs_phy_probe,
> -       .remove = mxs_phy_remove,
> +       .remove_new = mxs_phy_remove,
>         .driver = {
>                 .name = DRIVER_NAME,
>                 .of_match_table = mxs_phy_dt_ids,
> --
> 2.39.2

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2023-03-20 15:09 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-03-19  9:24 [PATCH 00/11] usb: phy: Convert to platform remove callback returning void Uwe Kleine-König
2023-03-19  9:24 ` [PATCH 08/11] usb: phy: mxs: " Uwe Kleine-König
2023-03-20 14:54   ` [EXT] " Frank Li

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).