[PATCH V2] cmd: env: select: Add output for available evironment targets

Marek Vasut marex at denx.de
Fri Mar 21 20:22:55 CET 2025


On 3/21/25 7:43 PM, Christoph Niedermaier wrote:
> Add parameter "-l" for printing available environment targets. The
> active target is marked with an asterisk. This is done by adding
> the function env_select_print_list().
> 
> If "env select" is called without a target parameter the result is
> "Select Environment on <NULL>: driver not found". Replace this not
> so useful output by showing the env usage message instead.
> 
> Signed-off-by: Christoph Niedermaier <cniedermaier at dh-electronics.com>
> ---
> Cc: Marek Vasut <marex at denx.de>
> Cc: Patrick Delaunay <patrick.delaunay at foss.st.com>
> Cc: Joe Hershberger <joe.hershberger at ni.com>
> Cc: Tom Rini <trini at konsulko.com>
> ---
> V2: - Showing available environment targets by parameter "-l"
>      - Showing env usage message if env select is called without a target
> ---
>   cmd/nvedit.c  | 19 ++++++++++++++++++-
>   env/env.c     | 16 ++++++++++++++++
>   include/env.h |  7 +++++++
>   3 files changed, 41 insertions(+), 1 deletion(-)
> 
> diff --git a/cmd/nvedit.c b/cmd/nvedit.c
> index 1f259801293..de64094db4d 100644
> --- a/cmd/nvedit.c
> +++ b/cmd/nvedit.c
> @@ -499,6 +499,23 @@ static int do_env_load(struct cmd_tbl *cmdtp, int flag, int argc,
>   static int do_env_select(struct cmd_tbl *cmdtp, int flag, int argc,
>   			 char *const argv[])
>   {
> +	if (!argv[1])
> +		return CMD_RET_USAGE;
> +
> +	while (argc > 1 && **(argv + 1) == '-') {
Two higher level things:

- Can you first convert cmd/nvedit.h to use include/getopt.h and then
   use getopt() here too ? This hand rolled arg parsing is repulsive,
   the multiple ad-hoc copies of that are even worse.
- Please write a test for this, see test/cmd/ , maybe Simon can help
   with details of this ... ?


More information about the U-Boot mailing list