[PATCH v3 4/4] efi_loader: simplify tcg2_measure_secure_boot_variable()
Ilias Apalodimas
ilias.apalodimas at linaro.org
Wed Oct 6 08:26:23 CEST 2021
On Sun, Oct 03, 2021 at 11:23:20AM +0200, Heinrich Schuchardt wrote:
> Don't duplicate GUIDs.
>
> Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
> ---
> v3:
> no change
> v2:
> no change
> ---
> lib/efi_loader/efi_tcg2.c | 29 +++++++++++++----------------
> 1 file changed, 13 insertions(+), 16 deletions(-)
>
> diff --git a/lib/efi_loader/efi_tcg2.c b/lib/efi_loader/efi_tcg2.c
> index ed1506012b..52bf1b775f 100644
> --- a/lib/efi_loader/efi_tcg2.c
> +++ b/lib/efi_loader/efi_tcg2.c
> @@ -11,6 +11,7 @@
> #include <common.h>
> #include <dm.h>
> #include <efi_loader.h>
> +#include <efi_variable.h>
> #include <efi_tcg2.h>
> #include <log.h>
> #include <malloc.h>
> @@ -79,17 +80,12 @@ static const struct digest_info hash_algo_list[] = {
> },
> };
>
> -struct variable_info {
> - u16 *name;
> - const efi_guid_t *guid;
> -};
> -
> -static struct variable_info secure_variables[] = {
> - {L"SecureBoot", &efi_global_variable_guid},
> - {L"PK", &efi_global_variable_guid},
> - {L"KEK", &efi_global_variable_guid},
> - {L"db", &efi_guid_image_security_database},
> - {L"dbx", &efi_guid_image_security_database},
> +static const u16 *secure_variables[] = {
> + u"SecureBoot",
> + u"PK",
> + u"KEK",
> + u"db",
> + u"dbx",
> };
>
> #define MAX_HASH_COUNT ARRAY_SIZE(hash_algo_list)
> @@ -1593,19 +1589,20 @@ static efi_status_t tcg2_measure_secure_boot_variable(struct udevice *dev)
>
> count = ARRAY_SIZE(secure_variables);
> for (i = 0; i < count; i++) {
> + const efi_guid_t *guid;
> +
> + guid = efi_auth_var_get_guid(secure_variables[i]);
> +
> /*
> * According to the TCG2 PC Client PFP spec, "SecureBoot",
> * "PK", "KEK", "db" and "dbx" variables must be measured
> * even if they are empty.
> */
> - data = efi_get_var(secure_variables[i].name,
> - secure_variables[i].guid,
> - &data_size);
> + data = efi_get_var(secure_variables[i], guid, &data_size);
>
> ret = tcg2_measure_variable(dev, 7,
> EV_EFI_VARIABLE_DRIVER_CONFIG,
> - secure_variables[i].name,
> - secure_variables[i].guid,
> + secure_variables[i], guid,
> data_size, data);
> free(data);
> if (ret != EFI_SUCCESS)
> --
> 2.32.0
>
Reviewed-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>
More information about the U-Boot
mailing list