[PATCH 1/1] tpm: update descriptions in tpm-v2.h header

Ilias Apalodimas ilias.apalodimas at linaro.org
Fri Dec 27 12:14:05 CET 2024


Thanks Heinrich,

On Wed, 25 Dec 2024 at 00:00, Heinrich Schuchardt
<heinrich.schuchardt at canonical.com> wrote:
>
> * Provide a link to 'TPM 2.0 Library Specification'
> * Remove outdated comment for TPM2_NUM_PCR_BANKS.
>   The value 16 can be found in the current standard
>   TCG TSS 2.0 Overview and Common Structures Specification 1.0, rev 10
> * Describe some of the structures in Sphinx style.
>
> Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
> ---
>  include/tpm-v2.h | 42 +++++++++++++++++++++++++++++++++---------
>  1 file changed, 33 insertions(+), 9 deletions(-)
>
> diff --git a/include/tpm-v2.h b/include/tpm-v2.h
> index 4fd19c52fd7..0f388b26496 100644
> --- a/include/tpm-v2.h
> +++ b/include/tpm-v2.h
> @@ -6,6 +6,11 @@
>   * Copyright (c) 2020 Linaro
>   * Copyright (c) 2018 Bootlin
>   *
> + * The structures are described in
> + * Trusted Platform Module Library Part 2: Structures
> + * http://tcg.tjn.chef.causewaynow.com/resource/tpm-library-specification/
> + *
> + * C header files are listed in
>   * https://trustedcomputinggroup.org/resource/tss-overview-common-structures-specification/

We already define that a few lines above
>   *
>   * Author: Miquel Raynal <miquel.raynal at bootlin.com>
> @@ -34,12 +39,8 @@ struct udevice;
>
>  #define TPM2_HDR_LEN           10
>
> -/*
> - *  We deviate from this draft of the specification by increasing the value of
> - *  TPM2_NUM_PCR_BANKS from 3 to 16 to ensure compatibility with TPM2
> - *  implementations that have enabled a larger than typical number of PCR
> - *  banks. This larger value for TPM2_NUM_PCR_BANKS is expected to be included
> - *  in a future revision of the specification.
> +/**
> + * define TPM2_NUM_PCR_BANKS - number of PCR banks
>   */
>  #define TPM2_NUM_PCR_BANKS 16
>
> @@ -55,20 +56,43 @@ struct udevice;
>  #define TPM2_PT_MAX_COMMAND_SIZE       (u32)(TPM2_PT_FIXED + 30)
>  #define TPM2_PT_MAX_RESPONSE_SIZE      (u32)(TPM2_PT_FIXED + 31)
>
> -/* TPMS_TAGGED_PROPERTY Structure */
> +/**
> + * struct tpms_tagged_property - TPMS_TAGGED_PROPERTY structure
> + *
> + * This structure is returned by TPM2_GetCapability() to report
> + * a u32 property value.
> + *
> + * @property:  property identifier
> + * @value:     value of the property
> + */
>  struct tpms_tagged_property {
>         u32 property;
>         u32 value;
>  } __packed;
>
> -/* TPMS_PCR_SELECTION Structure */
> +/**
> + * struct tpms_pcr_selection - TPMS_PCR_SELECTION structure
> + *
> + * This structure allows to specify a hash algorithm and a list of
> + * selected PCRs. A PCR is selected by setting the related bit in
> + * @pcr_select to 1.
> + *
> + * @hash:              hash algorithm associated with the selection
> + * @size_of_select:    size in bytes of the @pcr_select array
> + * @pcr_select:                bit map of selected PCRs
> + */
>  struct tpms_pcr_selection {
>         u16 hash;
>         u8 size_of_select;
>         u8 pcr_select[TPM2_PCR_SELECT_MAX];
>  } __packed;
>
> -/* TPML_PCR_SELECTION Structure */
> +/**
> + * struct tpml_pcr_selection - TPML_PCR_SELECTION structure
> + *
> + * @count:     number of selection structures, may be zero
> + * @selection: list of selections
> + */
>  struct tpml_pcr_selection {
>         u32 count;
>         struct tpms_pcr_selection selection[TPM2_NUM_PCR_BANKS];
> --
> 2.47.1
>

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


More information about the U-Boot mailing list