[PATCH] net: ipv6: IPv6 environment variable cleanup
Ramon Fried
rfried.dev at gmail.com
Sat Feb 18 21:09:56 CET 2023
On Thu, Feb 16, 2023 at 6:39 AM <seanedmond at linux.microsoft.com> wrote:
>
> From: Sean Edmond <seanedmond at microsoft.com>
>
> Fix "setenv gatewayip6".
>
> Synchronize IPv6 local variables with environment variables
> in netboot_update_env()
>
> Signed-off-by: Sean Edmond <seanedmond at microsoft.com>
> ---
> cmd/net.c | 23 ++++++++++++++++++++++-
> include/env_flags.h | 2 +-
> 2 files changed, 23 insertions(+), 2 deletions(-)
>
> diff --git a/cmd/net.c b/cmd/net.c
> index 88d53d14d5..0161c87529 100644
> --- a/cmd/net.c
> +++ b/cmd/net.c
> @@ -208,7 +208,7 @@ U_BOOT_CMD(
>
> static void netboot_update_env(void)
> {
> - char tmp[22];
> + char tmp[44];
>
> if (net_gateway.s_addr) {
> ip_to_string(net_gateway, tmp);
> @@ -269,6 +269,27 @@ static void netboot_update_env(void)
> env_set("ntpserverip", tmp);
> }
> #endif
> +
> + if (IS_ENABLED(CONFIG_IPV6)) {
> + if (!ip6_is_unspecified_addr(&net_ip6) ||
> + net_prefix_length != 0) {
> + sprintf(tmp, "%pI6c", &net_ip6);
> + if (net_prefix_length != 0)
> + sprintf(tmp, "%s/%d", tmp, net_prefix_length);
> +
> + env_set("ip6addr", tmp);
> + }
> +
> + if (!ip6_is_unspecified_addr(&net_server_ip6)) {
> + sprintf(tmp, "%pI6c", &net_server_ip6);
> + env_set("serverip6", tmp);
> + }
> +
> + if (!ip6_is_unspecified_addr(&net_gateway6)) {
> + sprintf(tmp, "%pI6c", &net_gateway6);
> + env_set("gatewayip6", tmp);
> + }
> + }
> }
>
> /**
> diff --git a/include/env_flags.h b/include/env_flags.h
> index 6bd574c2bd..7df40c59be 100644
> --- a/include/env_flags.h
> +++ b/include/env_flags.h
> @@ -71,7 +71,7 @@ enum env_flags_varaccess {
> #define NET6_FLAGS \
> "ip6addr:s," \
> "serverip6:s," \
> - "gatewayip6:s"
> + "gatewayip6:s,"
Why is this needed ?
> #else
> #define NET6_FLAGS
> #endif
> --
> 2.39.0
>
More information about the U-Boot
mailing list