mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-28 00:11:32 +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,
|
static int do_adc_single(struct cmd_tbl *cmdtp, int flag, int argc,
|
||||||
char *const argv[])
|
char *const argv[])
|
||||||
{
|
{
|
||||||
|
char *varname = NULL;
|
||||||
struct udevice *dev;
|
struct udevice *dev;
|
||||||
unsigned int data;
|
unsigned int data;
|
||||||
int ret, uV, val;
|
int ret, uV, val;
|
||||||
|
@ -78,6 +79,9 @@ static int do_adc_single(struct cmd_tbl *cmdtp, int flag, int argc,
|
||||||
if (argc < 3)
|
if (argc < 3)
|
||||||
return CMD_RET_USAGE;
|
return CMD_RET_USAGE;
|
||||||
|
|
||||||
|
if (argc >= 4)
|
||||||
|
varname = argv[3];
|
||||||
|
|
||||||
ret = adc_channel_single_shot(argv[1], simple_strtol(argv[2], NULL, 0),
|
ret = adc_channel_single_shot(argv[1], simple_strtol(argv[2], NULL, 0),
|
||||||
&data);
|
&data);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
|
@ -95,7 +99,8 @@ static int do_adc_single(struct cmd_tbl *cmdtp, int flag, int argc,
|
||||||
printf("%u\n", data);
|
printf("%u\n", data);
|
||||||
}
|
}
|
||||||
|
|
||||||
env_set_ulong(argv[2], val);
|
if (varname)
|
||||||
|
env_set_ulong(varname, val);
|
||||||
|
|
||||||
return CMD_RET_SUCCESS;
|
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_CMD_WITH_SUBCMDS(adc, "ADC sub-system", adc_help_text,
|
||||||
U_BOOT_SUBCMD_MKENT(list, 1, 1, do_adc_list),
|
U_BOOT_SUBCMD_MKENT(list, 1, 1, do_adc_list),
|
||||||
U_BOOT_SUBCMD_MKENT(info, 2, 1, do_adc_info),
|
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));
|
U_BOOT_SUBCMD_MKENT(scan, 3, 1, do_adc_scan));
|
||||||
|
|
Loading…
Add table
Reference in a new issue