X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=common%2Fcmd_dfu.c;h=857148f8afef2562098358bc6615506d14716fc3;hb=ebc3328cccc2bc7968fbd179e8e30fa1282b391a;hp=9e020b40be8a853e5e9bfd6a1dfbcd36100ae5b0;hpb=48f892dc7370a23882239be06b4ec2ce60273e57;p=u-boot diff --git a/common/cmd_dfu.c b/common/cmd_dfu.c index 9e020b40be..857148f8af 100644 --- a/common/cmd_dfu.c +++ b/common/cmd_dfu.c @@ -9,6 +9,7 @@ */ #include +#include #include #include #include @@ -38,10 +39,10 @@ static int do_dfu(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) int controller_index = simple_strtoul(usb_controller, NULL, 0); board_usb_init(controller_index, USB_INIT_DEVICE); - dfu_clear_detach(); + g_dnl_clear_detach(); g_dnl_register("usb_dnl_dfu"); while (1) { - if (dfu_detach()) { + if (g_dnl_detach()) { /* * Check if USB bus reset is performed after detach, * which indicates that -R switch has been passed to @@ -64,17 +65,19 @@ static int do_dfu(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) if (ctrlc()) goto exit; - usb_gadget_handle_interrupts(); + WATCHDOG_RESET(); + usb_gadget_handle_interrupts(controller_index); } exit: g_dnl_unregister(); + board_usb_cleanup(controller_index, USB_INIT_DEVICE); done: dfu_free_entities(); if (dfu_reset) run_command("reset", 0); - dfu_clear_detach(); + g_dnl_clear_detach(); return ret; }