From: Jarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
To: Roberto Sassu <roberto.sassu@huawei.com>
Cc: zohar@linux.ibm.com, david.safford@ge.com, monty.wiseman@ge.com,
linux-integrity@vger.kernel.org,
linux-security-module@vger.kernel.org,
linux-kernel@vger.kernel.org, silviu.vlasceanu@huawei.com
Subject: Re: [PATCH v6 0/7] tpm: retrieve digest size of unknown algorithms from TPM
Date: Tue, 4 Dec 2018 16:21:55 -0800 [thread overview]
Message-ID: <20181205002155.GA12210@linux.intel.com> (raw)
In-Reply-To: <20181204082138.24600-1-roberto.sassu@huawei.com>
On Tue, Dec 04, 2018 at 09:21:31AM +0100, Roberto Sassu wrote:
> Update
>
> This version of the patch set includes an additional patch (7/7) which
> modifies the definition of tpm_pcr_extend() and tpm2_pcr_extend(). The new
> patch has been included to facilitate the review of the changes to support
> TPM 2.0 crypto agility for reading/extending PCRs.
>
>
> Original patch set description
>
> The TPM driver currently relies on the crypto subsystem to determine the
> digest size of supported TPM algorithms. In the future, TPM vendors might
> implement new algorithms in their chips, and those algorithms might not
> be supported by the crypto subsystem.
>
> Usually, vendors provide patches for the new hardware, and likely
> the crypto subsystem will be updated before the new algorithm is
> introduced. However, old kernels might be updated later, after patches
> are included in the mainline kernel. This would leave the opportunity
> for attackers to misuse PCRs, as PCR banks with an unknown algorithm
> are not extended.
>
> This patch set provides a long term solution for this issue. If a TPM
> algorithm is not known by the crypto subsystem, the TPM driver retrieves
> the digest size from the TPM with a PCR read. All the PCR banks are
> extended, even if the algorithm is not yet supported by the crypto
> subsystem.
>
> PCR bank information (TPM algorithm ID, digest size, crypto subsystem ID)
> is stored in the tpm_chip structure and available for users of the TPM
> driver.
>
> Changelog
>
> v5:
> - rename digest_struct variable to digest
> - add _head suffix to tcg_efi_specid_event and tcg_pcr_event2
> - rename digest_size member of tpm_bank_list to extend_size
> - change type of alg_id member of tpm_bank list from u8 to u16
> - add missing semi-colon in pcrlock()
>
> v4:
> - rename active_banks to allocated_banks
> - replace kmalloc_array() with kcalloc()
> - increment nr_allocated_banks if at least one PCR in the bank is selected
> - pass multiple digests to tpm_pcr_extend()
>
> v3:
> - remove end marker change
> - replace active_banks static array with pointer to dynamic array
> - remove TPM2_ACTIVE_PCR_BANKS
>
> v2:
> - change the end marker of the active_banks array
> - check digest size from output of PCR read command
> - remove count parameter from tpm_pcr_read() and tpm2_pcr_read()
>
> v1:
> - modify definition of tpm_pcr_read()
> - move hash algorithms and definition of tpm2_digest to include/linux/tpm.h
>
> Roberto Sassu (7):
> tpm: dynamically allocate the allocated_banks array
> tpm: add _head suffix to tcg_efi_specid_event and tcg_pcr_event2
> tpm: rename and export tpm2_digest and tpm2_algorithms
> tpm: modify tpm_pcr_read() definition to pass a TPM hash algorithm
> tpm: retrieve digest size of unknown algorithms with PCR read
> tpm: ensure that the output of PCR read contains the correct digest
> size
> tpm: pass an array of tpm_bank_list structures to tpm_pcr_extend()
>
> drivers/char/tpm/eventlog/tpm2.c | 12 +--
> drivers/char/tpm/tpm-chip.c | 1 +
> drivers/char/tpm/tpm-interface.c | 36 +++----
> drivers/char/tpm/tpm.h | 23 ++---
> drivers/char/tpm/tpm1-cmd.c | 26 ++++-
> drivers/char/tpm/tpm2-cmd.c | 154 +++++++++++++++++++++-------
> include/linux/tpm.h | 43 +++++++-
> include/linux/tpm_eventlog.h | 19 +---
> security/integrity/ima/ima_crypto.c | 10 +-
> security/integrity/ima/ima_queue.c | 5 +-
> security/keys/trusted.c | 5 +-
> 11 files changed, 220 insertions(+), 114 deletions(-)
>
> --
> 2.17.1
>
Some generic stuff I noticed:
* Use SHA1_DIGEST_SIZE, not TPM_DIGEST_SIZE. The latter is just
uninforming constant that we want to get rid off.
/Jarkko
next prev parent reply other threads:[~2018-12-05 0:22 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-12-04 8:21 [PATCH v6 0/7] tpm: retrieve digest size of unknown algorithms from TPM Roberto Sassu
2018-12-04 8:21 ` [PATCH v6 1/7] tpm: dynamically allocate the allocated_banks array Roberto Sassu
2018-12-04 23:18 ` Jarkko Sakkinen
2018-12-06 17:56 ` Roberto Sassu
2018-12-12 18:32 ` Jarkko Sakkinen
2018-12-13 8:14 ` Roberto Sassu
2018-12-11 21:01 ` Ken Goldman
2018-12-04 8:21 ` [PATCH v6 2/7] tpm: add _head suffix to tcg_efi_specid_event and tcg_pcr_event2 Roberto Sassu
2018-12-04 23:26 ` Jarkko Sakkinen
2018-12-09 12:10 ` Nayna Jain
2018-12-04 8:21 ` [PATCH v6 3/7] tpm: rename and export tpm2_digest and tpm2_algorithms Roberto Sassu
2018-12-04 8:21 ` [PATCH v6 4/7] tpm: modify tpm_pcr_read() definition to pass a TPM hash algorithm Roberto Sassu
2018-12-04 23:40 ` Jarkko Sakkinen
2018-12-05 20:31 ` Mimi Zohar
2018-12-06 19:49 ` Mimi Zohar
2018-12-07 14:51 ` Roberto Sassu
2018-12-09 20:32 ` Mimi Zohar
2018-12-10 7:55 ` Roberto Sassu
2018-12-06 8:14 ` Nayna Jain
2018-12-12 18:29 ` Jarkko Sakkinen
2018-12-09 12:04 ` Nayna Jain
2018-12-04 8:21 ` [PATCH v6 5/7] tpm: retrieve digest size of unknown algorithms with PCR read Roberto Sassu
2018-12-04 23:53 ` Jarkko Sakkinen
2018-12-06 18:00 ` Roberto Sassu
2018-12-12 18:16 ` Jarkko Sakkinen
2018-12-04 8:21 ` [PATCH v6 6/7] tpm: ensure that the output of PCR read contains the correct digest size Roberto Sassu
2018-12-05 0:09 ` Jarkko Sakkinen
2018-12-05 0:46 ` Jarkko Sakkinen
2018-12-06 18:07 ` Roberto Sassu
2018-12-12 18:18 ` Jarkko Sakkinen
2018-12-04 8:21 ` [PATCH v6 7/7] tpm: pass an array of tpm_bank_list structures to tpm_pcr_extend() Roberto Sassu
2018-12-05 0:14 ` Jarkko Sakkinen
2018-12-06 18:09 ` Roberto Sassu
2018-12-12 18:25 ` Jarkko Sakkinen
2018-12-06 18:38 ` Roberto Sassu
2018-12-12 18:27 ` Jarkko Sakkinen
2018-12-13 7:57 ` Roberto Sassu
2018-12-14 7:58 ` Jarkko Sakkinen
2018-12-05 0:21 ` Jarkko Sakkinen [this message]
2018-12-05 0:23 ` [PATCH v6 0/7] tpm: retrieve digest size of unknown algorithms from TPM Jarkko Sakkinen
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=20181205002155.GA12210@linux.intel.com \
--to=jarkko.sakkinen@linux.intel.com \
--cc=david.safford@ge.com \
--cc=linux-integrity@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-security-module@vger.kernel.org \
--cc=monty.wiseman@ge.com \
--cc=roberto.sassu@huawei.com \
--cc=silviu.vlasceanu@huawei.com \
--cc=zohar@linux.ibm.com \
/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;
as well as URLs for NNTP newsgroup(s).