X-Git-Url: https://git.kernelconcepts.de/?a=blobdiff_plain;f=common%2Fcmd_dfu.c;h=857148f8afef2562098358bc6615506d14716fc3;hb=831c8bcb7fc07f14a1221712f0b9d96d0f51f110;hp=a03538dabb370c320815aa12637fae31e5eccd3c;hpb=e7d4a88e69459547a46906dbe021ccc83c614361;p=karo-tx-uboot.git diff --git a/common/cmd_dfu.c b/common/cmd_dfu.c index a03538dabb..857148f8af 100644 --- a/common/cmd_dfu.c +++ b/common/cmd_dfu.c @@ -9,12 +9,15 @@ */ #include +#include #include #include #include static int do_dfu(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) { + bool dfu_reset = false; + if (argc < 4) return CMD_RET_USAGE; @@ -24,11 +27,11 @@ static int do_dfu(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[]) int ret, i = 0; - ret = dfu_init_env_entities(interface, simple_strtoul(devstring, - NULL, 10)); + ret = dfu_init_env_entities(interface, devstring); if (ret) - return ret; + goto done; + ret = CMD_RET_SUCCESS; if (argc > 4 && strcmp(argv[4], "list") == 0) { dfu_show_entities(); goto done; @@ -36,32 +39,47 @@ 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); - + g_dnl_clear_detach(); g_dnl_register("usb_dnl_dfu"); while (1) { - if (dfu_reset()) + if (g_dnl_detach()) { + /* + * Check if USB bus reset is performed after detach, + * which indicates that -R switch has been passed to + * dfu-util. In this case reboot the device + */ + if (dfu_usb_get_reset()) { + dfu_reset = true; + goto exit; + } + /* * This extra number of usb_gadget_handle_interrupts() * calls is necessary to assure correct transmission * completion with dfu-util */ - if (++i == 10) + if (++i == 10000) goto exit; + } 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()) + if (dfu_reset) run_command("reset", 0); - return CMD_RET_SUCCESS; + g_dnl_clear_detach(); + + return ret; } U_BOOT_CMD(dfu, CONFIG_SYS_MAXARGS, 1, do_dfu,