[U-Boot] [PATCH] MUSB driver: Timeout is never detected as the while loop does not end

Marek Vasut marex at denx.de
Wed Aug 29 13:00:01 CEST 2012


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


More information about the U-Boot mailing list