diff mbox series

[fix] Revert "USB: bcma: Add a check for devm_gpiod_get"

Message ID 20210831065419.18371-1-zajec5@gmail.com
State New
Headers show
Series [fix] Revert "USB: bcma: Add a check for devm_gpiod_get" | expand

Commit Message

Rafał Miłecki Aug. 31, 2021, 6:54 a.m. UTC
From: Rafał Miłecki <rafal@milecki.pl>

This reverts commit f3de5d857bb2362b00e2a8d4bc886cd49dcb66db.

That commit broke USB on all routers that have USB always powered on and
don't require toggling any GPIO. It's a majority of devices actually.

The original code worked and seemed safe: vcc GPIO is optional and
bcma_hci_platform_power_gpio() takes care of checking the pointer before
using it.

This revert fixes:
[   10.801127] bcma_hcd: probe of bcma0:11 failed with error -2

Cc: Chuhong Yuan <hslester96@gmail.com>
Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
---
 drivers/usb/host/bcma-hcd.c | 5 +----
 1 file changed, 1 insertion(+), 4 deletions(-)

Comments

Geert Uytterhoeven Oct. 1, 2021, 8:59 a.m. UTC | #1
Hi Rafał,

On Tue, 31 Aug 2021, Rafał Miłecki wrote:
> From: Rafał Miłecki <rafal@milecki.pl>

>

> This reverts commit f3de5d857bb2362b00e2a8d4bc886cd49dcb66db.

>

> That commit broke USB on all routers that have USB always powered on and

> don't require toggling any GPIO. It's a majority of devices actually.

>

> The original code worked and seemed safe: vcc GPIO is optional and

> bcma_hci_platform_power_gpio() takes care of checking the pointer before

> using it.

>

> This revert fixes:

> [   10.801127] bcma_hcd: probe of bcma0:11 failed with error -2

>

> Cc: Chuhong Yuan <hslester96@gmail.com>

> Signed-off-by: Rafał Miłecki <rafal@milecki.pl>


Thanks for your patch, which is being backported to stable.

> --- a/drivers/usb/host/bcma-hcd.c

> +++ b/drivers/usb/host/bcma-hcd.c

> @@ -406,12 +406,9 @@ static int bcma_hcd_probe(struct bcma_device *core)

> 		return -ENOMEM;

> 	usb_dev->core = core;

>

> -	if (core->dev.of_node) {

> +	if (core->dev.of_node)

> 		usb_dev->gpio_desc = devm_gpiod_get(&core->dev, "vcc",

> 						    GPIOD_OUT_HIGH);



> -		if (IS_ERR(usb_dev->gpio_desc))

> -			return PTR_ERR(usb_dev->gpio_desc);

> -	}


This means real errors and probe deferral are no longer handled.
What about using devm_gpiod_get_optional() instead?
After that, the check in bcma_hci_platform_power_gpio() can be removed,
as gpiod_set_value() handles NULL pointers fine.

Gr{oetje,eeting}s,

 						Geert

--
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@linux-m68k.org

In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
 							    -- Linus Torvalds
diff mbox series

Patch

diff --git a/drivers/usb/host/bcma-hcd.c b/drivers/usb/host/bcma-hcd.c
index 337b425dd4b0..2df52f75f6b3 100644
--- a/drivers/usb/host/bcma-hcd.c
+++ b/drivers/usb/host/bcma-hcd.c
@@ -406,12 +406,9 @@  static int bcma_hcd_probe(struct bcma_device *core)
 		return -ENOMEM;
 	usb_dev->core = core;
 
-	if (core->dev.of_node) {
+	if (core->dev.of_node)
 		usb_dev->gpio_desc = devm_gpiod_get(&core->dev, "vcc",
 						    GPIOD_OUT_HIGH);
-		if (IS_ERR(usb_dev->gpio_desc))
-			return PTR_ERR(usb_dev->gpio_desc);
-	}
 
 	switch (core->id.id) {
 	case BCMA_CORE_USB20_HOST: