[U-Boot] [PATCH] env: Provide programmatic equivalent to 'setenv -f'

James Byrne james.byrne at origamienergy.com
Wed Nov 20 18:49:52 UTC 2019


On 19/11/2019 21:01, Simon Goldschmidt wrote:
> 
> 
> Heinrich Schuchardt <xypron.glpk at gmx.de <mailto:xypron.glpk at gmx.de>> 
> schrieb am Di., 19. Nov. 2019, 21:56:
> 
>     On 11/19/19 9:30 PM, Simon Goldschmidt wrote:
>      > Am 19.11.2019 um 18:31 schrieb James Byrne:
>      >> Add env_force() to provide an equivalent to 'setenv -f' that can
>     be used
>      >> programmatically.
>      >>
>      >> Also tighten up the definition of argv in _do_env_set() so that
>      >> 'const char *' pointers are used.
>      >>
>      >> Signed-off-by: James Byrne <james.byrne at origamienergy.com
>     <mailto:james.byrne at origamienergy.com>>
>      >
>      > OK, I'm on CC, so I'll give my two cent:
>      >
>      > I always thought this code to be messed up a bit: I think it's better
>      > programming style to have the "string argument parsing" code call
>     real C
>      > functions with typed arguments. The env code instead does it the
>     other
>      > way round (here, you add do_programmatic_env_set() that sets up an
>      > argv[] array to call another function).
>      >
>      > I'm not a maintainer for the ENV code, but maybe that should be
>     sorted
>      > out instead of adding yet more code that goes this way?
> 
>     There is no maintainer for the ENV code. Simon makes a valid point here.
>     By creating a function for setting variables and separating it from
>     parsing arguments you get the function you need for forcing the value of
>     a variable for free.
> 
> 
> Right. I thought someone had volunteered but a look at the maintainers 
> file proves me wrong.
> 
> In any way, I'd be more open to review a cleanup patch than a patch 
> continuing this messy code flow.

Having looked at it again, I agree. I have now redone it, but I have 
ended up changing quite a lot more of the underlying code. I will 
resubmit a revised patch (probably tomorrow) in two parts, one to apply 
some tidying up to the env code, and one to add the new function. It 
will be a much bigger patch set though!

James


More information about the U-Boot mailing list