mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-19 11:16:32 +00:00
lantiq: 4.19: increase usb reset timeouts
With kernel 4.19 dwc2 would not want to initialize due to reset timeouts, while it worked fine with 4.14. Increase the reset timeouts to 1 second, as it was used by the old lantiq ifxhcd usb driver. Signed-off-by: Martin Blumenstingl <martin.blumenstingl@googlemail.com> Signed-off-by: Mathias Kresin <dev@kresin.me>
This commit is contained in:
parent
f0c740650b
commit
eb72439dbb
@ -0,0 +1,35 @@
|
||||
From bfe92b01cafebb10f0d7f38dceb37433687b7887 Mon Sep 17 00:00:00 2001
|
||||
From: Martin Blumenstingl <martin.blumenstingl@googlemail.com>
|
||||
Date: Thu, 20 Jun 2019 19:50:22 +0200
|
||||
Subject: [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset()
|
||||
|
||||
Use a 10000us AHB idle timeout in dwc2_core_reset() and make it
|
||||
consistent with the other "wait for AHB master IDLE state" ocurrences.
|
||||
|
||||
This fixes a problem for me where dwc2 would not want to initialize when
|
||||
updating to 4.19 on a MIPS Lantiq VRX200 SoC. dwc2 worked fine with
|
||||
4.14.
|
||||
Testing on my board shows that it takes 180us until AHB master IDLE
|
||||
state is signalled. The very old vendor driver for this SoC (ifxhcd)
|
||||
used a 1 second timeout.
|
||||
Use the same timeout that is used everywhere when polling for
|
||||
GRSTCTL_AHBIDLE instead of using a timeout that "works for one board"
|
||||
(180us in my case) to have consistent behavior across the dwc2 driver.
|
||||
|
||||
Cc: linux-stable <stable@vger.kernel.org> # 4.19+
|
||||
Signed-off-by: Martin Blumenstingl <martin.blumenstingl@googlemail.com>
|
||||
---
|
||||
drivers/usb/dwc2/core.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
--- a/drivers/usb/dwc2/core.c
|
||||
+++ b/drivers/usb/dwc2/core.c
|
||||
@@ -531,7 +531,7 @@ int dwc2_core_reset(struct dwc2_hsotg *h
|
||||
}
|
||||
|
||||
/* Wait for AHB master IDLE state */
|
||||
- if (dwc2_hsotg_wait_bit_set(hsotg, GRSTCTL, GRSTCTL_AHBIDLE, 50)) {
|
||||
+ if (dwc2_hsotg_wait_bit_set(hsotg, GRSTCTL, GRSTCTL_AHBIDLE, 10000)) {
|
||||
dev_warn(hsotg->dev, "%s: HANG! AHB Idle timeout GRSTCTL GRSTCTL_AHBIDLE\n",
|
||||
__func__);
|
||||
return -EBUSY;
|
@ -0,0 +1,29 @@
|
||||
From 09bbf8c732e7a6ce290fc7c2d5a3e79ec6c3e8d2 Mon Sep 17 00:00:00 2001
|
||||
From: Mathias Kresin <dev@kresin.me>
|
||||
Date: Wed, 3 Jul 2019 17:03:02 +0200
|
||||
Subject: [PATCH] usb: dwc2: use a longer core rest timeout in
|
||||
dwc2_core_reset()
|
||||
|
||||
Testing on different generations of Lantiq MIPS SoC based boards, showed
|
||||
that it takes up to 1500 us until the core reset bit is cleared.
|
||||
|
||||
The driver from the vendor SDK (ifxhcd) uses a 1 second timeout. Use the
|
||||
same timeout to fix wrong hang detections and make the driver work for
|
||||
Lantiq MIPS SoCs.
|
||||
|
||||
Signed-off-by: Mathias Kresin <dev@kresin.me>
|
||||
---
|
||||
drivers/usb/dwc2/core.c | 2 +-
|
||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||
|
||||
--- a/drivers/usb/dwc2/core.c
|
||||
+++ b/drivers/usb/dwc2/core.c
|
||||
@@ -524,7 +524,7 @@ int dwc2_core_reset(struct dwc2_hsotg *h
|
||||
greset |= GRSTCTL_CSFTRST;
|
||||
dwc2_writel(hsotg, greset, GRSTCTL);
|
||||
|
||||
- if (dwc2_hsotg_wait_bit_clear(hsotg, GRSTCTL, GRSTCTL_CSFTRST, 50)) {
|
||||
+ if (dwc2_hsotg_wait_bit_clear(hsotg, GRSTCTL, GRSTCTL_CSFTRST, 10000)) {
|
||||
dev_warn(hsotg->dev, "%s: HANG! Soft Reset timeout GRSTCTL GRSTCTL_CSFTRST\n",
|
||||
__func__);
|
||||
return -EBUSY;
|
Loading…
Reference in New Issue
Block a user