diff options
Diffstat (limited to 'common')
| -rw-r--r-- | common/cmd_usb_mass_storage.c | 51 | 
1 files changed, 23 insertions, 28 deletions
| diff --git a/common/cmd_usb_mass_storage.c b/common/cmd_usb_mass_storage.c index f583cafa3..99487f4d0 100644 --- a/common/cmd_usb_mass_storage.c +++ b/common/cmd_usb_mass_storage.c @@ -5,6 +5,7 @@   * SPDX-License-Identifier:	GPL-2.0+   */ +#include <errno.h>  #include <common.h>  #include <command.h>  #include <g_dnl.h> @@ -20,55 +21,49 @@ int do_usb_mass_storage(cmd_tbl_t *cmdtp, int flag,  	const char *usb_controller = argv[1];  	const char *mmc_devstring  = argv[2]; -	unsigned int dev_num = (unsigned int)(simple_strtoul(mmc_devstring, -				NULL, 0)); -	if (dev_num) { -		error("Set eMMC device to 0! - e.g. ums 0"); -		goto fail; -	} +	unsigned int dev_num = simple_strtoul(mmc_devstring, NULL, 0); + +	struct ums *ums = ums_init(dev_num); +	if (!ums) +		return CMD_RET_FAILURE;  	unsigned int controller_index = (unsigned int)(simple_strtoul(  					usb_controller,	NULL, 0));  	if (board_usb_init(controller_index, USB_INIT_DEVICE)) {  		error("Couldn't init USB controller."); -		goto fail; -	} - -	struct ums_board_info *ums_info = board_ums_init(dev_num, 0, 0); -	if (!ums_info) { -		error("MMC: %d -> NOT available", dev_num); -		goto fail; +		return CMD_RET_FAILURE;  	} -	int rc = fsg_init(ums_info); +	int rc = fsg_init(ums);  	if (rc) {  		error("fsg_init failed"); -		goto fail; +		return CMD_RET_FAILURE;  	}  	g_dnl_register("ums");  	while (1) { -		/* Handle control-c and timeouts */ -		if (ctrlc()) { -			error("The remote end did not respond in time."); -			goto exit; -		} -  		usb_gadget_handle_interrupts(); -		/* Check if USB cable has been detached */ -		if (fsg_main_thread(NULL) == EIO) + +		rc = fsg_main_thread(NULL); +		if (rc) { +			/* Check I/O error */ +			if (rc == -EIO) +				printf("\rCheck USB cable connection\n"); + +			/* Check CTRL+C */ +			if (rc == -EPIPE) +				printf("\rCTRL+C - Operation aborted\n"); +  			goto exit; +		}  	}  exit:  	g_dnl_unregister(); -	return 0; - -fail: -	return -1; +	return CMD_RET_SUCCESS;  }  U_BOOT_CMD(ums, CONFIG_SYS_MAXARGS, 1, do_usb_mass_storage,  	"Use the UMS [User Mass Storage]", -	"<USB_controller> <mmc_dev>" +	"ums <USB_controller> <mmc_dev>  e.g. ums 0 0"  ); |