diff options
author | Minkyu Kang <mk7.kang@samsung.com> | 2009-03-30 14:55:51 +0900 |
---|---|---|
committer | Wolfgang Denk <wd@denx.de> | 2009-04-04 23:07:19 +0200 |
commit | 869f6bf4def5a053fbd1aecd8b2fc36f05196c0b (patch) | |
tree | 9110d0be787b6f2c3d541142018bf837afd9bcda | |
parent | 9abc9ef8fbe079bf75a634ce64b7dcdb7b0d8bdc (diff) | |
download | u-boot-imx-869f6bf4def5a053fbd1aecd8b2fc36f05196c0b.zip u-boot-imx-869f6bf4def5a053fbd1aecd8b2fc36f05196c0b.tar.gz u-boot-imx-869f6bf4def5a053fbd1aecd8b2fc36f05196c0b.tar.bz2 |
cmd_mmc: add support for device command for selecting mmc device
This patch improves device command for selecting mmc device
Signed-off-by: Minkyu Kang <mk7.kang@samsung.com>
-rw-r--r-- | common/cmd_mmc.c | 61 |
1 files changed, 56 insertions, 5 deletions
diff --git a/common/cmd_mmc.c b/common/cmd_mmc.c index ee94470..f1fa32f 100644 --- a/common/cmd_mmc.c +++ b/common/cmd_mmc.c @@ -26,19 +26,70 @@ #include <mmc.h> #ifndef CONFIG_GENERIC_MMC +int curr_device = -1; + int do_mmc (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]) { - if (mmc_legacy_init (1) != 0) { - printf ("No MMC card found\n"); + int dev; + + if (argc < 2) { + cmd_usage(cmdtp); return 1; } + + if (strcmp(argv[1], "init") == 0) { + if (argc == 2) { + if (curr_device < 0) + dev = 1; + else + dev = curr_device; + } else if (argc == 3) { + dev = (int)simple_strtoul(argv[2], NULL, 10); + } else { + cmd_usage(cmdtp); + return 1; + } + + if (mmc_legacy_init(dev) != 0) { + puts("No MMC card found\n"); + return 1; + } + + curr_device = dev; + printf("mmc%d is available\n", curr_device); + } else if (strcmp(argv[1], "device") == 0) { + if (argc == 2) { + if (curr_device < 0) { + puts("No MMC device available\n"); + return 1; + } + } else if (argc == 3) { + dev = (int)simple_strtoul(argv[2], NULL, 10); + +#ifdef CONFIG_SYS_MMC_SET_DEV + if (mmc_set_dev(dev) != 0) + return 1; +#endif + curr_device = dev; + } else { + cmd_usage(cmdtp); + return 1; + } + + printf("mmc%d is current device\n", curr_device); + } else { + cmd_usage(cmdtp); + return 1; + } + return 0; } U_BOOT_CMD( - mmcinit, 1, 0, do_mmc, - "init mmc card", - NULL + mmc, 3, 1, do_mmc, + "MMC sub-system", + "init [dev] - init MMC sub system\n" + "mmc device [dev] - show or set current device\n" ); #else /* !CONFIG_GENERIC_MMC */ |