All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ramon Fried <rfried.dev@gmail.com>
To: Simon Glass <sjg@chromium.org>
Cc: U-Boot Mailing List <u-boot@lists.denx.de>,
	Patrice Chotard <patrice.chotard@foss.st.com>,
	 Artem Lapkin <email2tema@gmail.com>,
	Tom Rini <trini@konsulko.com>,
	 Joe Hershberger <joe.hershberger@ni.com>,
	Heinrich Schuchardt <xypron.glpk@gmx.de>,
	 Peter Hoyes <Peter.Hoyes@arm.com>
Subject: Re: [PATCH v3 15/18] pxe: Return the file size from the getfile() function
Date: Tue, 9 Nov 2021 10:09:19 +0200	[thread overview]
Message-ID: <CAGi-RULXygkB8EJPYS2E4i3=qy26D6Fjw_7C=DemQ1NBUQUAxA@mail.gmail.com> (raw)
In-Reply-To: <20211014124803.v3.15.I5ea9daa8a0f8ddcedd99a7dcf136c195b5c9eb50@changeid>

On Thu, Oct 14, 2021 at 9:51 PM Simon Glass <sjg@chromium.org> wrote:
>
> It is pretty strange that the pxe code uses the 'filesize' environment
> variable find the size of a file it has just read.
>
> Partly this is because it uses the command-line interpreter to parse its
> request to load the file.
>
> As a first step towards unwinding this, return it directly from the
> getfile() function. This makes the code a bit longer, for now, but will be
> cleaned up in future patches.
>
> Signed-off-by: Simon Glass <sjg@chromium.org>
> ---
>
> (no changes since v1)
>
>  boot/pxe_utils.c    | 70 ++++++++++++++++++++++++++++-----------------
>  cmd/pxe.c           |  7 ++++-
>  cmd/sysboot.c       | 21 ++++++++++++--
>  include/pxe_utils.h | 13 ++++++++-
>  4 files changed, 79 insertions(+), 32 deletions(-)
>
> diff --git a/boot/pxe_utils.c b/boot/pxe_utils.c
> index f36f1f8a60c..e377e16be56 100644
> --- a/boot/pxe_utils.c
> +++ b/boot/pxe_utils.c
> @@ -30,6 +30,20 @@
>
>  #define MAX_TFTP_PATH_LEN 512
>
> +int pxe_get_file_size(ulong *sizep)
> +{
> +       const char *val;
> +
> +       val = from_env("filesize");
> +       if (!val)
> +               return -ENOENT;
> +
> +       if (strict_strtoul(val, 16, sizep) < 0)
> +               return -EINVAL;
> +
> +       return 0;
> +}
> +
>  /**
>   * format_mac_pxe() - obtain a MAC address in the PXE format
>   *
> @@ -75,14 +89,17 @@ int format_mac_pxe(char *outbuf, size_t outbuf_len)
>   * @ctx: PXE context
>   * @file_path: File path to read (relative to the PXE file)
>   * @file_addr: Address to load file to
> + * @filesizep: If not NULL, returns the file size in bytes
>   * Returns 1 for success, or < 0 on error
>   */
>  static int get_relfile(struct pxe_context *ctx, const char *file_path,
> -                      unsigned long file_addr)
> +                      unsigned long file_addr, ulong *filesizep)
>  {
>         size_t path_len;
>         char relfile[MAX_TFTP_PATH_LEN + 1];
>         char addr_buf[18];
> +       ulong size;
> +       int ret;
>
>         if (file_path[0] == '/' && ctx->allow_abs_path)
>                 *relfile = '\0';
> @@ -103,7 +120,13 @@ static int get_relfile(struct pxe_context *ctx, const char *file_path,
>
>         sprintf(addr_buf, "%lx", file_addr);
>
> -       return ctx->getfile(ctx, relfile, addr_buf);
> +       ret = ctx->getfile(ctx, relfile, addr_buf, &size);
> +       if (ret < 0)
> +               return log_msg_ret("get", ret);
> +       if (filesizep)
> +               *filesizep = size;
> +
> +       return 1;
>  }
>
>  /**
> @@ -117,29 +140,17 @@ static int get_relfile(struct pxe_context *ctx, const char *file_path,
>   * Returns 1 for success, or < 0 on error
>   */
>  int get_pxe_file(struct pxe_context *ctx, const char *file_path,
> -                unsigned long file_addr)
> +                ulong file_addr)
>  {
> -       unsigned long config_file_size;
> -       char *tftp_filesize;
> +       ulong size;
>         int err;
>         char *buf;
>
> -       err = get_relfile(ctx, file_path, file_addr);
> +       err = get_relfile(ctx, file_path, file_addr, &size);
>         if (err < 0)
>                 return err;
>
> -       /*
> -        * the file comes without a NUL byte at the end, so find out its size
> -        * and add the NUL byte.
> -        */
> -       tftp_filesize = from_env("filesize");
> -       if (!tftp_filesize)
> -               return -ENOENT;
> -
> -       if (strict_strtoul(tftp_filesize, 16, &config_file_size) < 0)
> -               return -EINVAL;
> -
> -       buf = map_sysmem(file_addr + config_file_size, 1);
> +       buf = map_sysmem(file_addr + size, 1);
>         *buf = '\0';
>         unmap_sysmem(buf);
>
> @@ -184,12 +195,13 @@ int get_pxelinux_path(struct pxe_context *ctx, const char *file,
>   * @file_path: File path to read (relative to the PXE file)
>   * @envaddr_name: Name of environment variable which contains the address to
>   *     load to
> + * @filesizep: Returns the file size in bytes
>   * Returns 1 on success, -ENOENT if @envaddr_name does not exist as an
>   *     environment variable, -EINVAL if its format is not valid hex, or other
>   *     value < 0 on other error
>   */
>  static int get_relfile_envaddr(struct pxe_context *ctx, const char *file_path,
> -                              const char *envaddr_name)
> +                              const char *envaddr_name, ulong *filesizep)
>  {
>         unsigned long file_addr;
>         char *envaddr;
> @@ -201,7 +213,7 @@ static int get_relfile_envaddr(struct pxe_context *ctx, const char *file_path,
>         if (strict_strtoul(envaddr, 16, &file_addr) < 0)
>                 return -EINVAL;
>
> -       return get_relfile(ctx, file_path, file_addr);
> +       return get_relfile(ctx, file_path, file_addr, filesizep);
>  }
>
>  /**
> @@ -357,8 +369,8 @@ static void label_boot_fdtoverlay(struct pxe_context *ctx,
>                         goto skip_overlay;
>
>                 /* Load overlay file */
> -               err = get_relfile_envaddr(ctx, overlayfile,
> -                                         "fdtoverlay_addr_r");
> +               err = get_relfile_envaddr(ctx, overlayfile, "fdtoverlay_addr_r",
> +                                         NULL);
>                 if (err < 0) {
>                         printf("Failed loading overlay %s\n", overlayfile);
>                         goto skip_overlay;
> @@ -438,7 +450,10 @@ static int label_boot(struct pxe_context *ctx, struct pxe_label *label)
>         }
>
>         if (label->initrd) {
> -               if (get_relfile_envaddr(ctx, label->initrd, "ramdisk_addr_r") < 0) {
> +               ulong size;
> +
> +               if (get_relfile_envaddr(ctx, label->initrd, "ramdisk_addr_r",
> +                                       &size) < 0) {
>                         printf("Skipping %s for failure retrieving initrd\n",
>                                label->name);
>                         return 1;
> @@ -447,11 +462,12 @@ static int label_boot(struct pxe_context *ctx, struct pxe_label *label)
>                 bootm_argv[2] = initrd_str;
>                 strncpy(bootm_argv[2], env_get("ramdisk_addr_r"), 18);
>                 strcat(bootm_argv[2], ":");
> -               strncat(bootm_argv[2], env_get("filesize"), 9);
> +               strcat(bootm_argv[2], simple_xtoa(size));
>                 bootm_argc = 3;
>         }
>
> -       if (get_relfile_envaddr(ctx, label->kernel, "kernel_addr_r") < 0) {
> +       if (get_relfile_envaddr(ctx, label->kernel, "kernel_addr_r",
> +                               NULL) < 0) {
>                 printf("Skipping %s for failure retrieving kernel\n",
>                        label->name);
>                 return 1;
> @@ -592,7 +608,7 @@ static int label_boot(struct pxe_context *ctx, struct pxe_label *label)
>
>                 if (fdtfile) {
>                         int err = get_relfile_envaddr(ctx, fdtfile,
> -                                                     "fdt_addr_r");
> +                                                     "fdt_addr_r", NULL);
>
>                         free(fdtfilefree);
>                         if (err < 0) {
> @@ -1384,7 +1400,7 @@ void handle_pxe_menu(struct pxe_context *ctx, struct pxe_menu *cfg)
>         if (IS_ENABLED(CONFIG_CMD_BMP)) {
>                 /* display BMP if available */
>                 if (cfg->bmp) {
> -                       if (get_relfile(ctx, cfg->bmp, image_load_addr)) {
> +                       if (get_relfile(ctx, cfg->bmp, image_load_addr, NULL)) {
>                                 if (CONFIG_IS_ENABLED(CMD_CLS))
>                                         run_command("cls", 0);
>                                 bmp_display(image_load_addr,
> diff --git a/cmd/pxe.c b/cmd/pxe.c
> index e319db51ef5..81703386c42 100644
> --- a/cmd/pxe.c
> +++ b/cmd/pxe.c
> @@ -25,15 +25,20 @@ const char *pxe_default_paths[] = {
>  };
>
>  static int do_get_tftp(struct pxe_context *ctx, const char *file_path,
> -                      char *file_addr)
> +                      char *file_addr, ulong *sizep)
>  {
>         char *tftp_argv[] = {"tftp", NULL, NULL, NULL};
> +       int ret;
>
>         tftp_argv[1] = file_addr;
>         tftp_argv[2] = (void *)file_path;
>
>         if (do_tftpb(ctx->cmdtp, 0, 3, tftp_argv))
>                 return -ENOENT;
> +       ret = pxe_get_file_size(sizep);
> +       if (ret)
> +               return log_msg_ret("tftp", ret);
> +       ctx->pxe_file_size = *sizep;
>
>         return 1;
>  }
> diff --git a/cmd/sysboot.c b/cmd/sysboot.c
> index c45fed774d6..6344ecd357b 100644
> --- a/cmd/sysboot.c
> +++ b/cmd/sysboot.c
> @@ -9,43 +9,58 @@
>  static char *fs_argv[5];
>
>  static int do_get_ext2(struct pxe_context *ctx, const char *file_path,
> -                      char *file_addr)
> +                      char *file_addr, ulong *sizep)
>  {
>  #ifdef CONFIG_CMD_EXT2
> +       int ret;
> +
>         fs_argv[0] = "ext2load";
>         fs_argv[3] = file_addr;
>         fs_argv[4] = (void *)file_path;
>
>         if (!do_ext2load(ctx->cmdtp, 0, 5, fs_argv))
>                 return 1;
> +       ret = pxe_get_file_size(sizep);
> +       if (ret)
> +               return log_msg_ret("tftp", ret);
>  #endif
>         return -ENOENT;
>  }
>
>  static int do_get_fat(struct pxe_context *ctx, const char *file_path,
> -                     char *file_addr)
> +                     char *file_addr, ulong *sizep)
>  {
>  #ifdef CONFIG_CMD_FAT
> +       int ret;
> +
>         fs_argv[0] = "fatload";
>         fs_argv[3] = file_addr;
>         fs_argv[4] = (void *)file_path;
>
>         if (!do_fat_fsload(ctx->cmdtp, 0, 5, fs_argv))
>                 return 1;
> +       ret = pxe_get_file_size(sizep);
> +       if (ret)
> +               return log_msg_ret("tftp", ret);
>  #endif
>         return -ENOENT;
>  }
>
>  static int do_get_any(struct pxe_context *ctx, const char *file_path,
> -                     char *file_addr)
> +                     char *file_addr, ulong *sizep)
>  {
>  #ifdef CONFIG_CMD_FS_GENERIC
> +       int ret;
> +
>         fs_argv[0] = "load";
>         fs_argv[3] = file_addr;
>         fs_argv[4] = (void *)file_path;
>
>         if (!do_load(ctx->cmdtp, 0, 5, fs_argv, FS_TYPE_ANY))
>                 return 1;
> +       ret = pxe_get_file_size(sizep);
> +       if (ret)
> +               return log_msg_ret("tftp", ret);
>  #endif
>         return -ENOENT;
>  }
> diff --git a/include/pxe_utils.h b/include/pxe_utils.h
> index 8b50f2e6861..194a5ed8cc7 100644
> --- a/include/pxe_utils.h
> +++ b/include/pxe_utils.h
> @@ -77,7 +77,7 @@ struct pxe_menu {
>
>  struct pxe_context;
>  typedef int (*pxe_getfile_func)(struct pxe_context *ctx, const char *file_path,
> -                               char *file_addr);
> +                               char *file_addr, ulong *filesizep);
>
>  /**
>   * struct pxe_context - context information for PXE parsing
> @@ -88,6 +88,7 @@ typedef int (*pxe_getfile_func)(struct pxe_context *ctx, const char *file_path,
>   * @allow_abs_path: true to allow absolute paths
>   * @bootdir: Directory that files are loaded from ("" if no directory). This is
>   *     allocated
> + * @pxe_file_size: Size of the PXE file
>   */
>  struct pxe_context {
>         struct cmd_tbl *cmdtp;
> @@ -98,6 +99,7 @@ struct pxe_context {
>          * @file_path: Path to the file
>          * @file_addr: String containing the hex address to put the file in
>          *      memory
> +        * @filesizep: Returns the file size in bytes
>          * Return 0 if OK, -ve on error
>          */
>         pxe_getfile_func getfile;
> @@ -105,6 +107,7 @@ struct pxe_context {
>         void *userdata;
>         bool allow_abs_path;
>         char *bootdir;
> +       ulong pxe_file_size;
>  };
>
>  /**
> @@ -225,4 +228,12 @@ void pxe_destroy_ctx(struct pxe_context *ctx);
>   */
>  int pxe_process(struct pxe_context *ctx, ulong pxefile_addr_r, bool prompt);
>
> +/**
> + * pxe_get_file_size() - Read the value of the 'filesize' environment variable
> + *
> + * @sizep: Place to put the value
> + * @return 0 if OK, -ENOENT if no such variable, -EINVAL if format is invalid
> + */
> +int pxe_get_file_size(ulong *sizep);
> +
>  #endif /* __PXE_UTILS_H */
> --
> 2.33.0.1079.g6e70778dc9-goog
>
Reviewed-by: Ramon Fried <rfried.dev@gmail.com>

  parent reply	other threads:[~2021-11-09  8:09 UTC|newest]

Thread overview: 90+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-10-14 18:47 [PATCH v3 00/18] pxe: Refactoring to tidy up and prepare for bootflow Simon Glass
2021-10-14 18:47 ` [PATCH v3 01/18] Create a new boot/ directory Simon Glass
2021-10-16  5:31   ` Art Nikpal
2021-10-18  8:41   ` art
2021-11-12 15:38   ` Tom Rini
2021-10-14 18:47 ` [PATCH v3 02/18] pxe: Move API comments to the header files Simon Glass
2021-10-18  8:42   ` art
2021-11-09  8:07   ` Ramon Fried
2021-11-09  8:52   ` Heinrich Schuchardt
2021-11-12 15:38   ` Tom Rini
2021-10-14 18:47 ` [PATCH v3 03/18] pxe: Use a context pointer Simon Glass
2021-10-18  8:45   ` art
2021-11-09  8:08   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:47 ` [PATCH v3 04/18] pxe: Move do_getfile() into the context Simon Glass
2021-10-18  8:46   ` art
2021-11-09  8:11   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:47 ` [PATCH v3 05/18] pxe: Add a userdata field to " Simon Glass
2021-10-18  8:46   ` art
2021-11-09  8:10   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:47 ` [PATCH v3 06/18] pxe: Tidy up the is_pxe global Simon Glass
2021-10-18  8:47   ` art
2021-11-09  8:10   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 07/18] pxe: Move pxe_utils files Simon Glass
2021-10-18  8:47   ` art
2021-11-09  8:10   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2022-02-09 11:40   ` Adam Ford
2022-02-09 12:32     ` Tom Rini
2022-02-09 17:16       ` Simon Glass
2022-02-10 13:56         ` Adam Ford
2022-02-10 13:57           ` Adam Ford
2022-02-10 14:32             ` Simon Glass
2022-02-10 14:41               ` Adam Ford
2022-02-10 14:57           ` Tom Rini
2022-02-11 15:50             ` Adam Ford
2022-02-11 16:12               ` Tom Rini
2022-02-11 16:39                 ` Adam Ford
2022-02-11 16:44                   ` Tom Rini
2022-02-11 17:10                     ` Adam Ford
2022-02-11 17:13                       ` Tom Rini
2022-02-12  1:09                         ` Adam Ford
2022-02-12  1:43                           ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 08/18] pxe: Tidy up some comments in pxe_utils Simon Glass
2021-10-18  8:48   ` art
2021-11-09  8:10   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 09/18] pxe: Tidy up code style a little " Simon Glass
2021-10-18  8:48   ` art
2021-11-09  8:10   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 10/18] pxe: Move common parsing coding into pxe_util Simon Glass
2021-10-18  8:49   ` art
2021-11-09  8:09   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 11/18] pxe: Clean up the use of bootfile Simon Glass
2021-10-18  8:51   ` art
2021-11-09  8:09   ` Ramon Fried
2021-11-12 15:39   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 12/18] pxe: Drop get_bootfile_path() Simon Glass
2021-10-18  8:51   ` art
2021-11-09  8:09   ` Ramon Fried
2021-11-12 15:40   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 13/18] lib: Add tests for simple_itoa() Simon Glass
2021-10-18  8:30   ` art
2021-11-12 15:40   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 14/18] lib: Add a function to convert a string to a hex value Simon Glass
2021-10-18  8:52   ` art
2021-11-12 15:40   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 15/18] pxe: Return the file size from the getfile() function Simon Glass
2021-10-18  8:53   ` art
2021-11-09  8:09   ` Ramon Fried [this message]
2021-11-12 15:40   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 16/18] pxe: Refactor sysboot to have one helper Simon Glass
2021-10-18  8:54   ` art
2021-11-09  8:09   ` Ramon Fried
2021-11-12 15:40   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 17/18] doc: Move distro boot doc to rST Simon Glass
2021-10-18  8:55   ` art
2021-11-09  8:08   ` Ramon Fried
2021-11-12 15:40   ` Tom Rini
2021-10-14 18:48 ` [PATCH v3 18/18] pxe: Allow calling the pxe_get logic directly Simon Glass
2021-10-18  8:56   ` art
2021-11-09  8:07   ` Ramon Fried
2021-11-12 15:40   ` Tom Rini
2021-10-15 10:27 ` [PATCH v3 00/18] pxe: Refactoring to tidy up and prepare for bootflow Art Nikpal
2021-10-26  1:28 ` Simon Glass

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='CAGi-RULXygkB8EJPYS2E4i3=qy26D6Fjw_7C=DemQ1NBUQUAxA@mail.gmail.com' \
    --to=rfried.dev@gmail.com \
    --cc=Peter.Hoyes@arm.com \
    --cc=email2tema@gmail.com \
    --cc=joe.hershberger@ni.com \
    --cc=patrice.chotard@foss.st.com \
    --cc=sjg@chromium.org \
    --cc=trini@konsulko.com \
    --cc=u-boot@lists.denx.de \
    --cc=xypron.glpk@gmx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.