linux-usb.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset()
@ 2019-06-20 17:50 Martin Blumenstingl
  2019-06-24  5:41 ` Minas Harutyunyan
  0 siblings, 1 reply; 5+ messages in thread
From: Martin Blumenstingl @ 2019-06-20 17:50 UTC (permalink / raw)
  To: hminas, linux-usb, felipe.balbi
  Cc: gregkh, linux-kernel, Martin Blumenstingl, linux-stable

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(-)

diff --git a/drivers/usb/dwc2/core.c b/drivers/usb/dwc2/core.c
index 8b499d643461..8e41d70fd298 100644
--- a/drivers/usb/dwc2/core.c
+++ b/drivers/usb/dwc2/core.c
@@ -531,7 +531,7 @@ int dwc2_core_reset(struct dwc2_hsotg *hsotg, bool skip_wait)
 	}
 
 	/* 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;
-- 
2.22.0


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* Re: [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset()
  2019-06-20 17:50 [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset() Martin Blumenstingl
@ 2019-06-24  5:41 ` Minas Harutyunyan
  2019-07-01 17:54   ` Martin Blumenstingl
  0 siblings, 1 reply; 5+ messages in thread
From: Minas Harutyunyan @ 2019-06-24  5:41 UTC (permalink / raw)
  To: Martin Blumenstingl, linux-usb, felipe.balbi
  Cc: gregkh, linux-kernel, linux-stable

On 6/20/2019 9:51 PM, Martin Blumenstingl wrote:
> 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>
> ---

Acked-by: Minas Harutyunyan <hminas@synopsys.com>

>   drivers/usb/dwc2/core.c | 2 +-
>   1 file changed, 1 insertion(+), 1 deletion(-)
> 
> diff --git a/drivers/usb/dwc2/core.c b/drivers/usb/dwc2/core.c
> index 8b499d643461..8e41d70fd298 100644
> --- a/drivers/usb/dwc2/core.c
> +++ b/drivers/usb/dwc2/core.c
> @@ -531,7 +531,7 @@ int dwc2_core_reset(struct dwc2_hsotg *hsotg, bool skip_wait)
>   	}
>   
>   	/* 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;
> 


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset()
  2019-06-24  5:41 ` Minas Harutyunyan
@ 2019-07-01 17:54   ` Martin Blumenstingl
  2019-07-03  9:01     ` Martin Blumenstingl
  0 siblings, 1 reply; 5+ messages in thread
From: Martin Blumenstingl @ 2019-07-01 17:54 UTC (permalink / raw)
  To: linux-usb, felipe.balbi, gregkh
  Cc: Minas Harutyunyan, linux-kernel, linux-stable

On Mon, Jun 24, 2019 at 7:41 AM Minas Harutyunyan
<Minas.Harutyunyan@synopsys.com> wrote:
>
> On 6/20/2019 9:51 PM, Martin Blumenstingl wrote:
> > 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>
> > ---
>
> Acked-by: Minas Harutyunyan <hminas@synopsys.com>
thank you for reviewing this!

is there any chance we can get this fix into Linux 5.3? I know that
it's too late for 5.2 so I'm fine with skipping that.


Martin

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset()
  2019-07-01 17:54   ` Martin Blumenstingl
@ 2019-07-03  9:01     ` Martin Blumenstingl
  2019-07-03 11:38       ` Felipe Balbi
  0 siblings, 1 reply; 5+ messages in thread
From: Martin Blumenstingl @ 2019-07-03  9:01 UTC (permalink / raw)
  To: felipe.balbi
  Cc: linux-usb, Minas Harutyunyan, linux-kernel, linux-stable, gregkh

On Mon, Jul 1, 2019 at 7:54 PM Martin Blumenstingl
<martin.blumenstingl@googlemail.com> wrote:
>
> On Mon, Jun 24, 2019 at 7:41 AM Minas Harutyunyan
> <Minas.Harutyunyan@synopsys.com> wrote:
> >
> > On 6/20/2019 9:51 PM, Martin Blumenstingl wrote:
> > > 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>
> > > ---
> >
> > Acked-by: Minas Harutyunyan <hminas@synopsys.com>
> thank you for reviewing this!
>
> is there any chance we can get this fix into Linux 5.3? I know that
> it's too late for 5.2 so I'm fine with skipping that.
thank you Felipe for queuing this for v5.3!
for reference, this patch is now in the usb-for-v5.3-part2 tag: [0]


[0] https://git.kernel.org/pub/scm/linux/kernel/git/balbi/usb.git/commit/?h=usb-for-v5.3-part2&id=dfc4fdebc5d62ac4e2fe5428e59b273675515fb2

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset()
  2019-07-03  9:01     ` Martin Blumenstingl
@ 2019-07-03 11:38       ` Felipe Balbi
  0 siblings, 0 replies; 5+ messages in thread
From: Felipe Balbi @ 2019-07-03 11:38 UTC (permalink / raw)
  To: Martin Blumenstingl
  Cc: linux-usb, Minas Harutyunyan, linux-kernel, linux-stable, gregkh


Hi,

Martin Blumenstingl <martin.blumenstingl@googlemail.com> writes:

> On Mon, Jul 1, 2019 at 7:54 PM Martin Blumenstingl
> <martin.blumenstingl@googlemail.com> wrote:
>>
>> On Mon, Jun 24, 2019 at 7:41 AM Minas Harutyunyan
>> <Minas.Harutyunyan@synopsys.com> wrote:
>> >
>> > On 6/20/2019 9:51 PM, Martin Blumenstingl wrote:
>> > > 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>
>> > > ---
>> >
>> > Acked-by: Minas Harutyunyan <hminas@synopsys.com>
>> thank you for reviewing this!
>>
>> is there any chance we can get this fix into Linux 5.3? I know that
>> it's too late for 5.2 so I'm fine with skipping that.
> thank you Felipe for queuing this for v5.3!
> for reference, this patch is now in the usb-for-v5.3-part2 tag: [0]
>
>
> [0] https://git.kernel.org/pub/scm/linux/kernel/git/balbi/usb.git/commit/?h=usb-for-v5.3-part2&id=dfc4fdebc5d62ac4e2fe5428e59b273675515fb2

I'll send pull request soon :-)

-- 
balbi

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2019-07-03 11:38 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-06-20 17:50 [PATCH] usb: dwc2: use a longer AHB idle timeout in dwc2_core_reset() Martin Blumenstingl
2019-06-24  5:41 ` Minas Harutyunyan
2019-07-01 17:54   ` Martin Blumenstingl
2019-07-03  9:01     ` Martin Blumenstingl
2019-07-03 11:38       ` Felipe Balbi

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).