[PATCH v2 2/6] net: wget: add wget with dns utility function

Masahisa Kojima masahisa.kojima at linaro.org
Fri Sep 15 01:20:51 CEST 2023


Hi Ilias,

On Thu, 14 Sept 2023 at 21:52, Ilias Apalodimas
<ilias.apalodimas at linaro.org> wrote:
>
> Kojima-san
>
> [...]
>
> >  }
> > +
> > +#if (IS_ENABLED(CONFIG_CMD_DNS))
> > +int wget_with_dns(ulong dst_addr, char *uri)
> > +{
> > +     int ret;
> > +     char *s, *host_name, *file_name, *str_copy;
> > +
> > +     /*
> > +      * Download file using wget.
> > +      *
> > +      * U-Boot wget takes the target uri in this format.
> > +      *  "<http server ip>:<file path>"  e.g.) 192.168.1.1:/sample/test.iso
> > +      * Need to resolve the http server ip address before starting wget.
> > +      */
> > +     str_copy = strdup(uri);
> > +     if (!str_copy)
> > +             return -ENOMEM;
> > +
> > +     s = str_copy + strlen("http://");
> > +     host_name = strsep(&s, "/");
> > +     if (!s) {
> > +             log_err("Error: invalied uri, no file path\n");
> > +             ret = -EINVAL;
> > +             goto out;
> > +     }
> > +     file_name = s;
> > +
> > +     /* TODO: If the given uri has ip address for the http server, skip dns */
> > +     net_dns_resolve = host_name;
> > +     net_dns_env_var = "httpserverip";
>
> This is not idea, but I understand this is how dns currently works.  We
> can take another look on improving this when LWIP lands

Yes.
Note that the prototype of this function is the same as the  Maxim's LWIP port
"int ulwip_wget(ulong addr, char *url)", so we can easily replace it
when the LWIP lands.

>
> > +     if (net_loop(DNS) < 0) {
> > +             log_err("Error: dns lookup of %s failed, check setup\n", net_dns_resolve);
> > +             ret = -EINVAL;
> > +             goto out;
> > +     }
> > +     s = env_get("httpserverip");
> > +     if (!s) {
> > +             ret = -EINVAL;
> > +             goto out;
> > +     }
> > +
> > +     strlcpy(net_boot_file_name, s, 1024);
>
> sizeof(net_boot_file_name) here please
OK.

>
> > +     strlcat(net_boot_file_name, ":/", 1024); /* append '/' which is removed by strsep() */
> > +     strlcat(net_boot_file_name, file_name, 1024);
>
> Don't you have to limit the size of subsequent writes depending on what
> previous calls wrote? IOW that can't always be 1024.

strlcat() appends the string with the limit of "buf_size - strlen(dst)
- 1", so current code should be OK.
1024 should be sizeof(net_boot_file_name) same as above.

Thanks,
Masahisa Kojima

>
> > +     image_load_addr = dst_addr;
> > +     ret = net_loop(WGET);
> > +
> > +out:
> > +     free(str_copy);
> > +
> > +     return ret;
> > +}
> > +#endif
> > --
> > 2.34.1
> >
>
> Thanks
> /Ilias


More information about the U-Boot mailing list