* [RFC PATCH v2 0/1] cmd: nvedit: Forbid environment key to be empty.
@ 2021-06-29 16:18 Francis Laniel
2021-06-29 16:18 ` [RFC PATCH v2 1/1] cmd: nvedit: Forbid " Francis Laniel
0 siblings, 1 reply; 4+ messages in thread
From: Francis Laniel @ 2021-06-29 16:18 UTC (permalink / raw)
To: u-boot, joe.hershberger, wd; +Cc: michael, ondrej, Francis Laniel
Hi.
First of all, I hope you are fine and the same for your relatives.
In this patch, I modified the setenv command to decline empty variable
name.
Indeed, it was strangely possible to give the following to this command:
setenv '' foo
Which results in the following belonging to environment:
=foo
And which in turns leads to problem while rebooting:
Loading Environment from Flash... Cannot import environment: errno = 22
*** Warning - import failed, using default environment
This error message is due to varname being empty and was added in [1].
With this patch, executing the above command will lead to the following being
printed:
## Error: variable name cannot be empty
And the environment will not be changed.
Here is the diffstat for this patch:
Francis Laniel (1):
cmd: nvedit: Forbid key to be empty.
cmd/nvedit.c | 5 +++++
1 file changed, 5 insertions(+)
Change since:
v1:
* Replace call to strlen by test if variable name is '\0'.
* Modify error message printed.
If you see any way to improve the patch, feel free to share it.
Best regards.
---
[1] https://u-boot.denx.narkive.com/P4aKxVFu/patch-env-don-t-add-an-empty-key-to-the-env-hashtable
--
2.25.1
^ permalink raw reply [flat|nested] 4+ messages in thread* [RFC PATCH v2 1/1] cmd: nvedit: Forbid key to be empty. 2021-06-29 16:18 [RFC PATCH v2 0/1] cmd: nvedit: Forbid environment key to be empty Francis Laniel @ 2021-06-29 16:18 ` Francis Laniel 2021-06-30 7:38 ` Wolfgang Denk 0 siblings, 1 reply; 4+ messages in thread From: Francis Laniel @ 2021-06-29 16:18 UTC (permalink / raw) To: u-boot, joe.hershberger, wd; +Cc: michael, ondrej, Francis Laniel Before this patch, it was possible to do the following using setenv: setenv '' foo Then, on next reboot, U-Boot will not be able to parse environment due to it having: =foo Now, if the above command is given, an error message is thrown and environment is not modified. Signed-off-by: Francis Laniel <francis.laniel@amarulasolutions.com> --- cmd/nvedit.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/cmd/nvedit.c b/cmd/nvedit.c index d14ba10cef..6f99a85a9c 100644 --- a/cmd/nvedit.c +++ b/cmd/nvedit.c @@ -262,6 +262,11 @@ static int _do_env_set(int flag, int argc, char *const argv[], int env_flag) return 1; } + if (*name == '\0') { + printf("## Error: variable name must no be empty\n"); + return 1; + } + env_id++; /* Delete only ? */ -- 2.25.1 ^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [RFC PATCH v2 1/1] cmd: nvedit: Forbid key to be empty. 2021-06-29 16:18 ` [RFC PATCH v2 1/1] cmd: nvedit: Forbid " Francis Laniel @ 2021-06-30 7:38 ` Wolfgang Denk 2021-06-30 7:45 ` Francis Laniel 0 siblings, 1 reply; 4+ messages in thread From: Wolfgang Denk @ 2021-06-30 7:38 UTC (permalink / raw) To: Francis Laniel; +Cc: u-boot, joe.hershberger, michael, ondrej Dear Francis Laniel, In message <20210629161859.298630-2-francis.laniel@amarulasolutions.com> you wrote: > Before this patch, it was possible to do the following using setenv: > setenv '' foo > Then, on next reboot, U-Boot will not be able to parse environment due to it > having: > =foo > > Now, if the above command is given, an error message is thrown and environment > is not modified. > > Signed-off-by: Francis Laniel <francis.laniel@amarulasolutions.com> > --- > cmd/nvedit.c | 5 +++++ > 1 file changed, 5 insertions(+) > > diff --git a/cmd/nvedit.c b/cmd/nvedit.c > index d14ba10cef..6f99a85a9c 100644 > --- a/cmd/nvedit.c > +++ b/cmd/nvedit.c > @@ -262,6 +262,11 @@ static int _do_env_set(int flag, int argc, char *const argv[], int env_flag) > return 1; > } > > + if (*name == '\0') { > + printf("## Error: variable name must no be empty\n"); > + return 1; > + } > + > env_id++; > > /* Delete only ? */ Reviewed-by: Wolfgang Denk <wd@denx.de> Best regards, Wolfgang Denk -- DENX Software Engineering GmbH, Managing Director: Wolfgang Denk HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany Phone: (+49)-8142-66989-10 Fax: (+49)-8142-66989-80 Email: wd@denx.de "I can call spirits from the vasty deep." "Why so can I, or so can any man; but will they come when you do call for them?" - Shakespeare, 1 King Henry IV, Act III, Scene I. ^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [RFC PATCH v2 1/1] cmd: nvedit: Forbid key to be empty. 2021-06-30 7:38 ` Wolfgang Denk @ 2021-06-30 7:45 ` Francis Laniel 0 siblings, 0 replies; 4+ messages in thread From: Francis Laniel @ 2021-06-30 7:45 UTC (permalink / raw) To: Wolfgang Denk; +Cc: u-boot, joe.hershberger, michael, ondrej Hi. Le mercredi 30 juin 2021, 09:38:16 CEST Wolfgang Denk a écrit : > Dear Francis Laniel, > > In message <20210629161859.298630-2-francis.laniel@amarulasolutions.com> you wrote: > > Before this patch, it was possible to do the following using setenv: > > setenv '' foo > > Then, on next reboot, U-Boot will not be able to parse environment due to > > it having: > > =foo > > > > Now, if the above command is given, an error message is thrown and > > environment is not modified. > > > > Signed-off-by: Francis Laniel <francis.laniel@amarulasolutions.com> > > --- > > > > cmd/nvedit.c | 5 +++++ > > 1 file changed, 5 insertions(+) > > > > diff --git a/cmd/nvedit.c b/cmd/nvedit.c > > index d14ba10cef..6f99a85a9c 100644 > > --- a/cmd/nvedit.c > > +++ b/cmd/nvedit.c > > @@ -262,6 +262,11 @@ static int _do_env_set(int flag, int argc, char > > *const argv[], int env_flag)> > > return 1; > > > > } > > > > + if (*name == '\0') { > > + printf("## Error: variable name must no be empty\n"); > > + return 1; > > + } > > + > > > > env_id++; > > > > /* Delete only ? */ > > Reviewed-by: Wolfgang Denk <wd@denx.de> Thank you for the review! > > Best regards, > > Wolfgang Denk ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2021-06-30 7:45 UTC | newest] Thread overview: 4+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2021-06-29 16:18 [RFC PATCH v2 0/1] cmd: nvedit: Forbid environment key to be empty Francis Laniel 2021-06-29 16:18 ` [RFC PATCH v2 1/1] cmd: nvedit: Forbid " Francis Laniel 2021-06-30 7:38 ` Wolfgang Denk 2021-06-30 7:45 ` Francis Laniel
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox