[PATCH 04/11] tpm: refactor tcg2_get_pcr_info()

Ilias Apalodimas ilias.apalodimas at linaro.org
Tue Dec 24 08:02:21 CET 2024


On Mon, 23 Dec 2024 at 16:48, Raymond Mao <raymond.mao at linaro.org> wrote:
>
> Rename the arguments of tcg2_get_pcr_info() to clarify
> they are bank masks, not PCR mask.
> Remove the unused local variable.
>
> Signed-off-by: Raymond Mao <raymond.mao at linaro.org>
> ---
>  include/tpm_tcg2.h | 12 ++++++------
>  lib/tpm_tcg2.c     | 19 ++++++++-----------
>  2 files changed, 14 insertions(+), 17 deletions(-)
>
> diff --git a/include/tpm_tcg2.h b/include/tpm_tcg2.h
> index 6519004cc4..eb6afe49e7 100644
> --- a/include/tpm_tcg2.h
> +++ b/include/tpm_tcg2.h
> @@ -94,17 +94,17 @@ struct tcg_pcr_event {
>  } __packed;
>
>  /**
> - * tcg2_get_pcr_info() - get the supported, active PCRs and number of banks
> + * tcg2_get_pcr_info() - get the supported, active banks and number of banks
>   *
>   * @dev:               TPM device
> - * @supported_pcr:     bitmask with the algorithms supported
> - * @active_pcr:                bitmask with the active algorithms
> - * @pcr_banks:         number of PCR banks
> + * @supported_bank:    bitmask with the algorithms supported
> + * @active_bank:       bitmask with the active algorithms
> + * @bank_num:          number of PCR banks
>   *
>   * @return 0 on success, code of operation or negative errno on failure
>   */
> -int tcg2_get_pcr_info(struct udevice *dev, u32 *supported_pcr, u32 *active_pcr,
> -                     u32 *pcr_banks);
> +int tcg2_get_pcr_info(struct udevice *dev, u32 *supported_bank, u32 *active_bank,
> +                     u32 *bank_num);
>
>  /**
>   * Crypto Agile Log Entry Format
> diff --git a/lib/tpm_tcg2.c b/lib/tpm_tcg2.c
> index dc5a0644fd..16f41cbfd1 100644
> --- a/lib/tpm_tcg2.c
> +++ b/lib/tpm_tcg2.c
> @@ -21,19 +21,16 @@
>  #include "tpm-utils.h"
>  #include <bloblist.h>
>
> -int tcg2_get_pcr_info(struct udevice *dev, u32 *supported_pcr, u32 *active_pcr,
> -                     u32 *pcr_banks)
> +int tcg2_get_pcr_info(struct udevice *dev, u32 *supported_bank, u32 *active_bank,
> +                     u32 *bank_num)
>  {
> -       u8 response[(sizeof(struct tpms_capability_data) -
> -               offsetof(struct tpms_capability_data, data))];
>         struct tpml_pcr_selection pcrs;
>         size_t i;
>         u32 ret;
>
> -       *supported_pcr = 0;
> -       *active_pcr = 0;
> -       *pcr_banks = 0;
> -       memset(response, 0, sizeof(response));
> +       *supported_bank = 0;
> +       *active_bank = 0;
> +       *bank_num = 0;
>
>         ret = tpm2_get_pcr_info(dev, &pcrs);
>         if (ret)
> @@ -43,16 +40,16 @@ int tcg2_get_pcr_info(struct udevice *dev, u32 *supported_pcr, u32 *active_pcr,
>                 u32 hash_mask = tcg2_algorithm_to_mask(pcrs.selection[i].hash);
>
>                 if (hash_mask) {
> -                       *supported_pcr |= hash_mask;
> +                       *supported_bank |= hash_mask;
>                         if (tpm2_is_active_bank(&pcrs.selection[i]))
> -                               *active_pcr |= hash_mask;
> +                               *active_bank |= hash_mask;
>                 } else {
>                         printf("%s: unknown algorithm %x\n", __func__,
>                                pcrs.selection[i].hash);
>                 }
>         }
>
> -       *pcr_banks = pcrs.count;
> +       *bank_num = pcrs.count;
>
>         return 0;
>  }
> --
> 2.25.1
>

Reviewed-by: Ilias Apalodimas <ilias.apalodimas at linaro.org>


More information about the U-Boot mailing list