[U-Boot] [PATCH 10/11] net: Use env callbacks for net variables
Simon Glass
sjg at chromium.org
Fri Apr 24 06:34:53 CEST 2015
Hi Joe,
On 21 April 2015 at 16:02, Joe Hershberger <joe.hershberger at ni.com> wrote:
> Instead of checking for changes to the env each time we enter the
> net_loop, use the env callbacks to update the values of the variables.
> Don't update the variables when the source was programmatic, since the
> variables were the source of the new value.
>
> Signed-off-by: Joe Hershberger <joe.hershberger at ni.com>
> ---
>
> include/env_callback.h | 22 ++++++++++-
> net/net.c | 105 +++++++++++++++++++++++++++++++++++++++++--------
> 2 files changed, 110 insertions(+), 17 deletions(-)
Reviewed-by: Simon Glass <sjg at chromium.org>
Q below.
>
> diff --git a/include/env_callback.h b/include/env_callback.h
> index 3de1093..91f3cc0 100644
> --- a/include/env_callback.h
> +++ b/include/env_callback.h
> @@ -37,6 +37,26 @@
> #define ENV_DOT_ESCAPE
> #endif
>
> +#ifdef CONFIG_CMD_DNS
> +#define DNS_CALLBACK "dnsip:dnsip,"
> +#else
> +#define DNS_CALLBACK
> +#endif
> +
> +#ifdef CONFIG_NET
> +#define NET_CALLBACKS \
> + "bootfile:bootfile," \
> + "ipaddr:ipaddr," \
> + "gatewayip:gatewayip," \
> + "netmask:netmask," \
> + "serverip:serverip," \
> + "nvlan:nvlan," \
> + "vlan:vlan," \
> + DNS_CALLBACK
> +#else
> +#define NET_CALLBACKS
> +#endif
> +
> /*
> * This list of callback bindings is static, but may be overridden by defining
> * a new association in the ".callbacks" environment variable.
> @@ -44,7 +64,7 @@
> #define ENV_CALLBACK_LIST_STATIC ENV_DOT_ESCAPE ENV_CALLBACK_VAR ":callbacks," \
> ENV_DOT_ESCAPE ENV_FLAGS_VAR ":flags," \
> "baudrate:baudrate," \
> - "bootfile:bootfile," \
> + NET_CALLBACKS \
> "loadaddr:loadaddr," \
> SILENT_CALLBACK \
> SPLASHIMAGE_CALLBACK \
> diff --git a/net/net.c b/net/net.c
> index a365df0..57111ad 100644
> --- a/net/net.c
> +++ b/net/net.c
> @@ -208,6 +208,9 @@ int __maybe_unused net_busy_flag;
> static int on_bootfile(const char *name, const char *value, enum env_op op,
> int flags)
> {
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
> + return 0;
> +
> switch (op) {
> case env_op_create:
> case env_op_overwrite:
> @@ -222,6 +225,92 @@ static int on_bootfile(const char *name, const char *value, enum env_op op,
> }
> U_BOOT_ENV_CALLBACK(bootfile, on_bootfile);
>
> +static int on_ipaddr(const char *name, const char *value, enum env_op op,
> + int flags)
> +{
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
Can you just do this?
if (flags & H_PROGRAMMATIC)
> + return 0;
> +
> + net_ip = string_to_ip(value);
> +
> + return 0;
> +}
> +U_BOOT_ENV_CALLBACK(ipaddr, on_ipaddr);
> +
> +static int on_gatewayip(const char *name, const char *value, enum env_op op,
> + int flags)
> +{
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
> + return 0;
> +
> + net_gateway = string_to_ip(value);
> +
> + return 0;
> +}
> +U_BOOT_ENV_CALLBACK(gatewayip, on_gatewayip);
> +
> +static int on_netmask(const char *name, const char *value, enum env_op op,
> + int flags)
> +{
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
> + return 0;
> +
> + net_netmask = string_to_ip(value);
> +
> + return 0;
> +}
> +U_BOOT_ENV_CALLBACK(netmask, on_netmask);
> +
> +static int on_serverip(const char *name, const char *value, enum env_op op,
> + int flags)
> +{
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
> + return 0;
> +
> + net_server_ip = string_to_ip(value);
> +
> + return 0;
> +}
> +U_BOOT_ENV_CALLBACK(serverip, on_serverip);
> +
> +static int on_nvlan(const char *name, const char *value, enum env_op op,
> + int flags)
> +{
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
> + return 0;
> +
> + net_native_vlan = string_to_vlan(value);
> +
> + return 0;
> +}
> +U_BOOT_ENV_CALLBACK(nvlan, on_nvlan);
> +
> +static int on_vlan(const char *name, const char *value, enum env_op op,
> + int flags)
> +{
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
> + return 0;
> +
> + net_our_vlan = string_to_vlan(value);
> +
> + return 0;
> +}
> +U_BOOT_ENV_CALLBACK(vlan, on_vlan);
> +
> +#if defined(CONFIG_CMD_DNS)
> +static int on_dnsip(const char *name, const char *value, enum env_op op,
> + int flags)
> +{
> + if ((flags & H_ORIGIN_FLAGS) == H_PROGRAMMATIC)
> + return 0;
> +
> + net_dns_server = string_to_ip(value);
> +
> + return 0;
> +}
> +U_BOOT_ENV_CALLBACK(dnsip, on_dnsip);
> +#endif
> +
> /*
> * Check if autoload is enabled. If so, use either NFS or TFTP to download
> * the boot file.
> @@ -252,22 +341,6 @@ void net_auto_load(void)
>
> static void net_init_loop(void)
> {
> - static int env_changed_id;
> - int env_id = get_env_id();
> -
> - /* update only when the environment has changed */
> - if (env_changed_id != env_id) {
> - net_ip = getenv_ip("ipaddr");
> - net_gateway = getenv_ip("gatewayip");
> - net_netmask = getenv_ip("netmask");
> - net_server_ip = getenv_ip("serverip");
> - net_native_vlan = getenv_vlan("nvlan");
> - net_our_vlan = getenv_vlan("vlan");
> -#if defined(CONFIG_CMD_DNS)
> - net_dns_server = getenv_ip("dnsip");
> -#endif
> - env_changed_id = env_id;
> - }
> if (eth_get_dev())
> memcpy(net_ethaddr, eth_get_ethaddr(), 6);
Regards,
Simon
More information about the U-Boot
mailing list