From: Patrick Delaunay Date: Fri, 9 Sep 2022 09:45:23 +0000 (+0200) Subject: usb: hub: allow to increase HUB_DEBOUNCE_TIMEOUT X-Git-Url: http://git.dujemihanovic.xyz/?a=commitdiff_plain;h=5454dea3137da465549cb08d668936552f28d0aa;p=u-boot.git usb: hub: allow to increase HUB_DEBOUNCE_TIMEOUT Add a new CONFIG_USB_HUB_DEBOUNCE_TIMEOUT to increase the HUB_DEBOUNCE_TIMEOUT value, for example to 2s because some usb device needs around 1.5s or more to make the hub port status to be connected steadily after being powered off and powered on. This 2s value is aligned with Linux driver and avoids to configure "usb_pgood_delay" as a workaround for connection timeout on some USB device; normally the env variable "usb_pgood_delay" is used to delay the first query after power ON and thus the device answer, but this variable not used to increase the connection timeout delay. Signed-off-by: Patrick Delaunay Reviewed-by: Patrice Chotard --- diff --git a/common/Kconfig b/common/Kconfig index 73e3fe3657..439b2198f6 100644 --- a/common/Kconfig +++ b/common/Kconfig @@ -1099,3 +1099,15 @@ config FDT_SIMPLEFB config IO_TRACE bool + +config USB_HUB_DEBOUNCE_TIMEOUT + int "Timeout in milliseconds for USB HUB connection" + depends on USB + default 1000 + help + Value in milliseconds of the USB connection timeout, the max delay to + wait the hub port status to be connected steadily after being powered + off and powered on in the usb hub driver. + This define allows to increase the HUB_DEBOUNCE_TIMEOUT default + value = 1s because some usb device needs around 1.5s to be initialized + and a 2s value should solve detection issue on problematic USB keys. diff --git a/common/usb_hub.c b/common/usb_hub.c index 95f1449b5c..f7fd12c045 100644 --- a/common/usb_hub.c +++ b/common/usb_hub.c @@ -47,7 +47,7 @@ #define HUB_SHORT_RESET_TIME 20 #define HUB_LONG_RESET_TIME 200 -#define HUB_DEBOUNCE_TIMEOUT 1000 +#define HUB_DEBOUNCE_TIMEOUT CONFIG_USB_HUB_DEBOUNCE_TIMEOUT #define PORT_OVERCURRENT_MAX_SCAN_COUNT 3