[PATCH v2 0/3] USB: add generic onboard USB HUB driver
Peter Chen
peter.chen at freescale.com
Mon Dec 14 22:28:42 PST 2015
On Mon, Dec 14, 2015 at 09:26:55AM -0200, Fabio Estevam wrote:
> Hi Peter,
>
> On Mon, Dec 14, 2015 at 5:26 AM, Peter Chen <peter.chen at freescale.com> wrote:
>
> > Hi all,
> >
> > There is a known issue that the USB code can't handle USB HUB's
> > external pins well, in that case, it may cause some onboard
> > USB HUBs can't work since their PHY's clock or reset pin needs to
> > operate.
> >
> > The user reported this issue at below:
> > http://www.spinics.net/lists/linux-usb/msg131502.html
> >
> > In this patch set, I add a generic onboard USB HUB driver to
> > handle this problem, the external signals will be configured
> > before usb controller's initialization, it much likes we did
> > it at board code before.
> >
> > The user needs to add this generic hub node at dts to support it.
> >
> > @The udoo users, help to test please.
>
> This is what I get with your series applied:
>
> [ 2.288300] usb 1-1: device descriptor read/64, error -71
> [ 2.518083] usb 1-1: new full-speed USB device number 3 using ci_hdrc
> [ 2.738078] usb 1-1: device descriptor read/64, error -71
> [ 3.058078] usb 1-1: device descriptor read/64, error -71
> [ 3.288079] usb 1-1: new full-speed USB device number 4 using ci_hdrc
> [ 3.768069] usb 1-1: device not accepting address 4, error -71
> [ 3.888084] usb 1-1: new full-speed USB device number 5 using ci_hdrc
> [ 4.368067] usb 1-1: device not accepting address 5, error -71
> [ 4.374117] usb usb1-port1: unable to enumerate USB device
Thanks, Fabio.
I am afraid I forget to set gpio as output, would you please apply
below patch against my original ones:
diff --git a/arch/arm/boot/dts/imx6qdl-udoo.dtsi b/arch/arm/boot/dts/imx6qdl-udoo.dtsi
index 64eabe2..34b0708 100644
--- a/arch/arm/boot/dts/imx6qdl-udoo.dtsi
+++ b/arch/arm/boot/dts/imx6qdl-udoo.dtsi
@@ -24,7 +24,7 @@
compatible = "generic-onboard-hub";
clocks = <&clks IMX6QDL_CLK_CKO>;
reset-gpios = <&gpio7 12 GPIO_ACTIVE_LOW>;
- reset-duration-us = <2>;
+ reset-duration-us = <10>;
};
};
diff --git a/drivers/usb/misc/generic_onboard_hub.c b/drivers/usb/misc/generic_onboard_hub.c
index 7db5b78..2f0afa7 100644
--- a/drivers/usb/misc/generic_onboard_hub.c
+++ b/drivers/usb/misc/generic_onboard_hub.c
@@ -89,6 +89,8 @@ static int usb_hub_generic_probe(struct platform_device *pdev)
of_property_read_u32(node, "reset-duration-us", &duration_us);
if (gpiod_reset) {
+ gpiod_direction_output(gpiod_reset, 1);
+
gpiod_set_value(gpiod_reset, 1);
usleep_range(duration_us, duration_us + 10);
gpiod_set_value(gpiod_reset, 0);
--
Best Regards,
Peter Chen
More information about the linux-arm-kernel
mailing list