[U-Boot] [PATCH 10/11] net: Use env callbacks for net variables

Joe Hershberger joe.hershberger at gmail.com
Mon Apr 27 21:38:52 CEST 2015


Hi Simon,

On Thu, Apr 23, 2015 at 11:34 PM, Simon Glass <sjg at chromium.org> wrote:
> 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)

Probably so, since it's not likely that we'll make a 4th state that
combines these "flags" even though they are all mutually exclusive.

>> +               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
> _______________________________________________
> U-Boot mailing list
> U-Boot at lists.denx.de
> http://lists.denx.de/mailman/listinfo/u-boot


More information about the U-Boot mailing list