[PATCH v2 5/6] efi_loader: move path out of file_handle
Ilias Apalodimas
ilias.apalodimas at linaro.org
Thu Feb 20 08:55:21 CET 2025
Hi Gabriel,
On Mon, 17 Feb 2025 at 20:31, Gabriel Dalimonte
<gabriel.dalimonte at gmail.com> wrote:
>
> In order to support renaming via SetInfo(), path must allow for longer
> values than what was originally present when file_handle was allocated.
>
> Signed-off-by: Gabriel Dalimonte <gabriel.dalimonte at gmail.com>
> ---
>
> (no changes since v1)
>
> lib/efi_loader/efi_file.c | 13 +++++++++----
> 1 file changed, 9 insertions(+), 4 deletions(-)
>
> diff --git a/lib/efi_loader/efi_file.c b/lib/efi_loader/efi_file.c
> index 201fa5f8f3c..6b15c1f3d27 100644
> --- a/lib/efi_loader/efi_file.c
> +++ b/lib/efi_loader/efi_file.c
> @@ -40,7 +40,7 @@ struct file_handle {
> struct fs_dir_stream *dirs;
> struct fs_dirent *dent;
>
> - char path[0];
> + char *path;
> };
> #define to_fh(x) container_of(x, struct file_handle, base)
>
> @@ -178,6 +178,7 @@ static struct efi_file_handle *file_open(struct file_system *fs,
> u64 attributes)
> {
> struct file_handle *fh;
> + char *path;
> char f0[MAX_UTF8_PER_UTF16] = {0};
> int plen = 0;
> int flen = 0;
> @@ -194,11 +195,13 @@ static struct efi_file_handle *file_open(struct file_system *fs,
> plen = strlen(parent->path) + 1;
> }
>
> + fh = calloc(1, sizeof(*fh));
> /* +2 is for null and '/' */
> - fh = calloc(1, sizeof(*fh) + plen + (flen * MAX_UTF8_PER_UTF16) + 2);
> - if (!fh)
> - return NULL;
> + path = calloc(1, plen + (flen * MAX_UTF8_PER_UTF16) + 2);
I assume the new allocation gets freed in patch #6 right?
Is there an easy way to include this change in the current patch?
Otherwise, we'll end up not freeing memory on a specific sha commit.
I can live with it if the change is too tricky though.
> + if (!fh || !path)
> + goto error;
>
> + fh->path = path;
> fh->open_mode = open_mode;
> fh->base = efi_file_handle_protocol;
> fh->fs = fs;
> @@ -245,6 +248,7 @@ static struct efi_file_handle *file_open(struct file_system *fs,
> return &fh->base;
>
> error:
> + free(fh->path);
> free(fh);
> return NULL;
> }
> @@ -368,6 +372,7 @@ out:
> static efi_status_t file_close(struct file_handle *fh)
> {
> fs_closedir(fh->dirs);
> + free(fh->path);
> free(fh);
> return EFI_SUCCESS;
> }
> --
> 2.34.1
>
Thanks
/Ilias
More information about the U-Boot
mailing list