From: AKASHI Takahiro <takahiro.akashi@linaro.org>
To: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
Cc: u-boot@lists.denx.de, Ilias Apalodimas <ilias.apalodimas@linaro.org>
Subject: Re: [PATCH 1/1] efi_loader: remove efi_disk_is_system_part()
Date: Sat, 5 Mar 2022 10:03:05 +0900 [thread overview]
Message-ID: <20220305010305.GA6345@laputa> (raw)
In-Reply-To: <20220304235100.43127-1-heinrich.schuchardt@canonical.com>
Heinrich,
On Sat, Mar 05, 2022 at 12:51:00AM +0100, Heinrich Schuchardt wrote:
> The block IO protocol may be installed on any handle. We should make
> no assumption about the structure the handle points to.
>
> efi_disk_is_system_part() makes an illegal widening cast from a handle
> to a struct efi_disk_obj. Remove the function.
NAK.
If this is a problem, please fix the function rather than remove it.
> As side effect capsules might be read from non-ESP partitions.
UEFI specification requires that capsules be loaded from ESP.
-Takahiro Akashi
>
> Fixes: Fixes: 41fd506842c2 ("efi_loader: disk: add efi_disk_is_system_part()")
> Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt@canonical.com>
> ---
> include/efi_loader.h | 2 --
> lib/efi_loader/efi_capsule.c | 4 +++-
> lib/efi_loader/efi_disk.c | 29 -----------------------------
> 3 files changed, 3 insertions(+), 32 deletions(-)
>
> diff --git a/include/efi_loader.h b/include/efi_loader.h
> index e390d323a9..5ac736ebce 100644
> --- a/include/efi_loader.h
> +++ b/include/efi_loader.h
> @@ -539,8 +539,6 @@ efi_status_t tcg2_measure_pe_image(void *efi, u64 efi_size,
> int efi_disk_create_partitions(efi_handle_t parent, struct blk_desc *desc,
> const char *if_typename, int diskid,
> const char *pdevname);
> -/* Check if it is EFI system partition */
> -bool efi_disk_is_system_part(efi_handle_t handle);
> /* Called by bootefi to make GOP (graphical) interface available */
> efi_status_t efi_gop_register(void);
> /* Called by bootefi to make the network interface available */
> diff --git a/lib/efi_loader/efi_capsule.c b/lib/efi_loader/efi_capsule.c
> index 613b531b82..2e7474a5d0 100644
> --- a/lib/efi_loader/efi_capsule.c
> +++ b/lib/efi_loader/efi_capsule.c
> @@ -684,7 +684,9 @@ static bool device_is_present_and_system_part(struct efi_device_path *dp)
> if (!handle)
> return false;
>
> - return efi_disk_is_system_part(handle);
> + /* TODO: add system partition check */
> +
> + return true;
> }
>
> /**
> diff --git a/lib/efi_loader/efi_disk.c b/lib/efi_loader/efi_disk.c
> index 45127d1768..97223537a1 100644
> --- a/lib/efi_loader/efi_disk.c
> +++ b/lib/efi_loader/efi_disk.c
> @@ -587,32 +587,3 @@ efi_status_t efi_disk_register(void)
>
> return EFI_SUCCESS;
> }
> -
> -/**
> - * efi_disk_is_system_part() - check if handle refers to an EFI system partition
> - *
> - * @handle: handle of partition
> - *
> - * Return: true if handle refers to an EFI system partition
> - */
> -bool efi_disk_is_system_part(efi_handle_t handle)
> -{
> - struct efi_handler *handler;
> - struct efi_disk_obj *diskobj;
> - struct disk_partition info;
> - efi_status_t ret;
> - int r;
> -
> - /* check if this is a block device */
> - ret = efi_search_protocol(handle, &efi_block_io_guid, &handler);
> - if (ret != EFI_SUCCESS)
> - return false;
> -
> - diskobj = container_of(handle, struct efi_disk_obj, header);
> -
> - r = part_get_info(diskobj->desc, diskobj->part, &info);
> - if (r)
> - return false;
> -
> - return !!(info.bootable & PART_EFI_SYSTEM_PARTITION);
> -}
> --
> 2.34.1
>
next prev parent reply other threads:[~2022-03-05 1:03 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-03-04 23:51 [PATCH 1/1] efi_loader: remove efi_disk_is_system_part() Heinrich Schuchardt
2022-03-05 1:03 ` AKASHI Takahiro [this message]
2022-03-05 9:37 ` Heinrich Schuchardt
2022-03-08 0:50 ` AKASHI Takahiro
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=20220305010305.GA6345@laputa \
--to=takahiro.akashi@linaro.org \
--cc=heinrich.schuchardt@canonical.com \
--cc=ilias.apalodimas@linaro.org \
--cc=u-boot@lists.denx.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox