From: Marek BehĂșn Date: Sun, 17 Oct 2021 15:36:36 +0000 (+0200) Subject: env: Use memcpy() instead of ad-hoc code to copy variable value X-Git-Tag: v2025.01-rc5-pxa1908~1671^2~2 X-Git-Url: http://git.dujemihanovic.xyz/img/login.html?a=commitdiff_plain;h=a473766cce44882237e567bcd58f7559ecdd0440;p=u-boot.git env: Use memcpy() instead of ad-hoc code to copy variable value Copy the value of the found variable into given buffer with memcpy() instead of ad-hoc code. Signed-off-by: Marek BehĂșn Reviewed-by: Simon Glass --- diff --git a/cmd/nvedit.c b/cmd/nvedit.c index 527b522e9e..ffcfb55f10 100644 --- a/cmd/nvedit.c +++ b/cmd/nvedit.c @@ -735,7 +735,7 @@ int env_get_f(const char *name, char *buf, unsigned len) for (p = env; *p != '\0'; p = end + 1) { const char *value; - int n, res; + unsigned res; for (end = p; *end != '\0'; ++end) if (end - env >= CONFIG_ENV_SIZE) @@ -746,20 +746,14 @@ int env_get_f(const char *name, char *buf, unsigned len) continue; res = end - value; + memcpy(buf, value, min(len, res + 1)); - /* found; copy out */ - for (n = 0; n < len; ++n, ++buf) { - *buf = *value++; - if (*buf == '\0') - return res; + if (len <= res) { + buf[len - 1] = '\0'; + printf("env_buf [%u bytes] too small for value of \"%s\"\n", + len, name); } - if (n) - *--buf = '\0'; - - printf("env_buf [%u bytes] too small for value of \"%s\"\n", - len, name); - return res; }