mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-16 09:54:35 +00:00
cmd: fix do_adc_single()
The source code contains an error: - argv[2] contains <channel> arg, variable for env_set is in argv[3] - number of args is 4 Revert54d24d7260
cmd: simplify do_adc_single() Fixes9de612ae4d
cmd: adc: Add support for storing ADC result in env variable Reviewed-by: Simon Glass <sjg@chromium.org>
This commit is contained in:
parent
11d30963bc
commit
6ac4774426
1 changed files with 7 additions and 2 deletions
|
@ -71,6 +71,7 @@ static int do_adc_info(struct cmd_tbl *cmdtp, int flag, int argc,
|
|||
static int do_adc_single(struct cmd_tbl *cmdtp, int flag, int argc,
|
||||
char *const argv[])
|
||||
{
|
||||
char *varname = NULL;
|
||||
struct udevice *dev;
|
||||
unsigned int data;
|
||||
int ret, uV, val;
|
||||
|
@ -78,6 +79,9 @@ static int do_adc_single(struct cmd_tbl *cmdtp, int flag, int argc,
|
|||
if (argc < 3)
|
||||
return CMD_RET_USAGE;
|
||||
|
||||
if (argc >= 4)
|
||||
varname = argv[3];
|
||||
|
||||
ret = adc_channel_single_shot(argv[1], simple_strtol(argv[2], NULL, 0),
|
||||
&data);
|
||||
if (ret) {
|
||||
|
@ -95,7 +99,8 @@ static int do_adc_single(struct cmd_tbl *cmdtp, int flag, int argc,
|
|||
printf("%u\n", data);
|
||||
}
|
||||
|
||||
env_set_ulong(argv[2], val);
|
||||
if (varname)
|
||||
env_set_ulong(varname, val);
|
||||
|
||||
return CMD_RET_SUCCESS;
|
||||
}
|
||||
|
@ -160,5 +165,5 @@ static char adc_help_text[] =
|
|||
U_BOOT_CMD_WITH_SUBCMDS(adc, "ADC sub-system", adc_help_text,
|
||||
U_BOOT_SUBCMD_MKENT(list, 1, 1, do_adc_list),
|
||||
U_BOOT_SUBCMD_MKENT(info, 2, 1, do_adc_info),
|
||||
U_BOOT_SUBCMD_MKENT(single, 3, 1, do_adc_single),
|
||||
U_BOOT_SUBCMD_MKENT(single, 4, 1, do_adc_single),
|
||||
U_BOOT_SUBCMD_MKENT(scan, 3, 1, do_adc_scan));
|
||||
|
|
Loading…
Add table
Reference in a new issue