Message ID | 20230804190039.72143-1-seanedmond@linux.microsoft.com |
---|---|
State | Accepted |
Commit | fe91450a596b558de31ae23f917e53201bc6b4c7 |
Delegated to: | Marek Vasut |
Headers | show |
Series | usb: xhci: pet watchdog during transfers | expand |
On 8/4/23 21:00, seanedmond@linux.microsoft.com wrote: > From: Godfrey Mwangi <godmwan@microsoft.com> > > On some platforms with low USB throughput, tranfers > of huge files take a long time and watchdog timer can > expire resulting in hardware reset. Avoid this by > petting the watchdog as long as we have pending transfers. > > Signed-off-by: Godfrey Mwangi <godmwan@microsoft.com> > --- > drivers/usb/host/xhci-ring.c | 3 +++ > 1 file changed, 3 insertions(+) > > diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c > index c8260cbdf9..de954314bc 100644 > --- a/drivers/usb/host/xhci-ring.c > +++ b/drivers/usb/host/xhci-ring.c > @@ -18,6 +18,7 @@ > #include <log.h> > #include <asm/byteorder.h> > #include <usb.h> > +#include <watchdog.h> > #include <asm/unaligned.h> > #include <linux/bug.h> > #include <linux/errno.h> > @@ -758,6 +759,8 @@ int xhci_bulk_tx(struct usb_device *udev, unsigned long pipe, > /* Calculate length for next transfer */ > addr += trb_buff_len; > trb_buff_len = min((length - running_total), TRB_MAX_BUFF_SIZE); > + > + schedule(); > } while (running_total < length); > > giveback_first_trb(udev, ep_index, start_cycle, start_trb); s@pet@ping@ or trigger . With that fixed: Reviewed-by: Marek Vasut <marex@denx.de> Thanks !
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c index c8260cbdf9..de954314bc 100644 --- a/drivers/usb/host/xhci-ring.c +++ b/drivers/usb/host/xhci-ring.c @@ -18,6 +18,7 @@ #include <log.h> #include <asm/byteorder.h> #include <usb.h> +#include <watchdog.h> #include <asm/unaligned.h> #include <linux/bug.h> #include <linux/errno.h> @@ -758,6 +759,8 @@ int xhci_bulk_tx(struct usb_device *udev, unsigned long pipe, /* Calculate length for next transfer */ addr += trb_buff_len; trb_buff_len = min((length - running_total), TRB_MAX_BUFF_SIZE); + + schedule(); } while (running_total < length); giveback_first_trb(udev, ep_index, start_cycle, start_trb);