Dear Matej Frančeškin,

> Timeout variable is decremented once more when while condition is not met.
> Following "if" does not detect correctly that timeout has occurred.
> Because of this bug the "usb start" command on AM335X-EVM board did not
> detect correctly that USB device was not attached.
> 
>       timeout = musb_cfg.timeout;
>       while (timeout--)
>               if (readb(&musbr->devctl) & MUSB_DEVCTL_HM)
>                       break;
>       /* if musb core is not in host mode, then return */
>       if (!timeout)
>               return -1;
> 

CCing Tom, SoB line missing, please read http://www.denx.de/wiki/U-Boot/Patches

> ---
>  drivers/usb/musb/musb_hcd.c |    2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/usb/musb/musb_hcd.c b/drivers/usb/musb/musb_hcd.c
> index 2df52c1..8d44c46 100644
> --- a/drivers/usb/musb/musb_hcd.c
> +++ b/drivers/usb/musb/musb_hcd.c
> @@ -1113,7 +1113,7 @@ int usb_lowlevel_init(void)
>        * should be a usb device connected.
>        */
>       timeout = musb_cfg.timeout;
> -     while (timeout--)
> +     while (--timeout)
>               if (readb(&musbr->devctl) & MUSB_DEVCTL_HM)
>                       break;
>       /* if musb core is not in host mode, then return */
>       if (!timeout)
>               return -1;

Best regards,
Marek Vasut
_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to