[PATCH v2 09/13] env: Use string pointer instead of indexes in env_get_f()
Simon Glass
sjg at chromium.org
Fri Oct 15 02:40:02 CEST 2021
Hi Marek,
On Wed, 13 Oct 2021 at 09:46, Marek Behún <kabel at kernel.org> wrote:
>
> From: Marek Behún <marek.behun at nic.cz>
>
> Since we no longer use env_get_char() to access n-th character of
> linearized environment data, but rather access the arrays themselves, we
> can convert the iteration to use string pointers instead of position
> indexes.
>
> Signed-off-by: Marek Behún <marek.behun at nic.cz>
> ---
> cmd/nvedit.c | 34 +++++++++++++++++-----------------
> 1 file changed, 17 insertions(+), 17 deletions(-)
>
> diff --git a/cmd/nvedit.c b/cmd/nvedit.c
> index 7c99a693ea..6eabd51209 100644
> --- a/cmd/nvedit.c
> +++ b/cmd/nvedit.c
> @@ -706,17 +706,17 @@ char *from_env(const char *envvar)
> return ret;
> }
>
> -static int env_match(const char *env, const char *s1, int i2)
> +static const char *matching_name_get_value(const char *p, const char *name)
OK so this is the function where I would like a nice comment, please.
> {
> - while (*s1 == env[i2++] && *s1 != '\0')
> - if (*s1++ == '=')
> - return i2;
> + while (*name == *p++ && *name != '\0')
> + if (*name++ == '=')
> + return p;
>
> - /* We can look at env[i2-1] because i2 was incremented at least once. */
> - if (*s1 == '\0' && env[i2-1] == '=')
> - return i2;
> + /* We can look at p[-1] because p was incremented at least once. */
> + if (*name == '\0' && p[-1] == '=')
> + return p;
>
> - return -1;
> + return NULL;
> }
>
> /*
> @@ -724,8 +724,7 @@ static int env_match(const char *env, const char *s1, int i2)
> */
> int env_get_f(const char *name, char *buf, unsigned len)
> {
> - const char *env;
> - int i, nxt;
> + const char *env, *p, *nxt;
>
> if (name == NULL || *name == '\0')
> return -1;
> @@ -735,20 +734,21 @@ int env_get_f(const char *name, char *buf, unsigned len)
> else
> env = (const char *)gd->env_addr;
>
> - for (i = 0; env[i] != '\0'; i = nxt + 1) {
> - int val, n;
> + for (p = env; *p != '\0'; p = nxt + 1) {
> + const char *value;
> + int n;
>
> - for (nxt = i; env[nxt] != '\0'; ++nxt)
> - if (nxt >= CONFIG_ENV_SIZE)
> + for (nxt = p; *nxt != '\0'; ++nxt)
> + if (nxt - env >= CONFIG_ENV_SIZE)
> return -1;
>
> - val = env_match(env, name, i);
> - if (val < 0)
> + value = matching_name_get_value(p, name);
> + if (value == NULL)
> continue;
>
> /* found; copy out */
> for (n = 0; n < len; ++n, ++buf) {
> - *buf = env[val++];
> + *buf = *value++;
> if (*buf == '\0')
> return n;
> }
> --
> 2.32.0
>
Regards,
Simon
More information about the U-Boot
mailing list