[PATCH v1] dfu: Reset timeout in case of DFU request
Ferry Toth
ftoth at telfort.nl
Thu Jan 30 10:27:20 CET 2020
Op 29-01-2020 om 16:23 schreef Andy Shevchenko:
> In case dfu command is being executed with timeout option,
> the timer may expire in the middle of DFU operation. If there
> is DFU request coming, we may simple reset timeout value
> to prevent aborting of ongoing DFU operation.
>
> Signed-off-by: Andy Shevchenko <andriy.shevchenko at linux.intel.com>
> ---
> drivers/usb/gadget/f_dfu.c | 5 +++++
> 1 file changed, 5 insertions(+)
>
> diff --git a/drivers/usb/gadget/f_dfu.c b/drivers/usb/gadget/f_dfu.c
> index 6756155133..a4a57ba5f5 100644
> --- a/drivers/usb/gadget/f_dfu.c
> +++ b/drivers/usb/gadget/f_dfu.c
> @@ -596,6 +596,11 @@ dfu_handle(struct usb_function *f, const struct usb_ctrlrequest *ctrl)
> debug("req_type: 0x%x ctrl->bRequest: 0x%x f_dfu->dfu_state: 0x%x\n",
> req_type, ctrl->bRequest, f_dfu->dfu_state);
>
> +#ifdef CONFIG_DFU_TIMEOUT
> + /* Forbid aborting by timeout. Next dfu command may update this */
> + dfu_set_timeout(0);
> +#endif
> +
> if (req_type == USB_TYPE_STANDARD) {
> if (ctrl->bRequest == USB_REQ_GET_DESCRIPTOR &&
> (w_value >> 8) == DFU_DT_FUNC) {
>
Tested-by: Ferry Toth <ftoth at exalondelft.nl>
More information about the U-Boot
mailing list