From: Christophe Ricard <christophe.ricard@gmail.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH v2 00/28] dm: Convert TPM drivers to driver model
Date: Mon, 24 Aug 2015 22:20:13 +0200 [thread overview]
Message-ID: <55DB7C7D.1090201@gmail.com> (raw)
In-Reply-To: <1440289904-31280-1-git-send-email-sjg@chromium.org>
Hi Simon,
I like your updates but i have few comments:
- I believe tpm_tis_i2c should be renamed as tpm_tis_infineon to be
aligned with Linux naming.
Also as there is no standard for i2c for tpm, every vendor does have
their own low level transport protocol.
I believe this is confusing.
- I think atmel tpm driver can be easily move to driver model with this
new tpm class. I would cleanup some few
#ifdef and make the code even clearer. May be i can try to send an
update when sending ST33ZP24 TPM driver ?
Other than that, i looks pretty good.
Thanks a lot.
Christophe
On 23/08/2015 02:31, Simon Glass wrote:
> This series adds driver model support for Trusted Platform Modules (TPMs).
> These have a very simple interface and are configured via the device tree.
>
> Two bus types are supported at present: I2C and LPC (Intel Low-Pin-Count).
>
> Most drivers and users are converted over to driver model. The exception is
> the Atmel TPM and its users.
>
> The I2C driver has been cleaned up and simplified. It was ported from Linux
> and was pretty hard to follow. This series includes patches to unify the
> code, remove duplicated data structures and drop unnecessary indirection.
>
> Also this series enables the TPM on all Chromebooks supported by upstream
> U-Boot (snow, spring, nyan-big, pit, pi, link, panther) since some did not
> have it fully enabled.
>
> As before, the 'tpm' command can be used to implement TPM functionality. In
> addition a 'tpmtest' command provides some basic TPM tests taken from
> Chrome OS U-Boot. These are fairly rudimentary but are useful if you know
> what you are doing.
>
> Changes in v2:
> - Add a 'TPM' menu in Kconfig
> - Add new patch with a 'tpmtest' command
> - Add new patch with functions to access flags and permissions
> - Add tpm device tree node for panther also
> - Correct error checking code in tpm_sendrecv_command()
> - Correct error-checking code in report_return_code()
> - Enable 'tpmtest' command for nyan
> - Enhance uclass to support timeouts with new send()/recv() methods
> - Implement the get_desc() method
> - Include tpm.h header file instead of tis.h
> - Move the timeout definitions into a new tpm_internal.h header
> - Update cover letter to mention panther and the tpmtest command.
> - Update driver for the new uclass interface
> - Update driver for v2 TPM uclass which supports timeouts
> - Use tpm_ prefix instead of tis_ for TPM functions
>
> Simon Glass (28):
> tpm: Remove old pre-driver-model I2C code
> tpm: Drop two unused options
> tpm: Add Kconfig options for TPMs
> tpm: Convert board config TPM options to Kconfig
> tpm: Convert drivers to use SPDX
> tpm: Move the I2C TPM code into one file
> tpm: tpm_tis_i2c: Drop unnecessary methods
> tpm: tpm_tis_i2c: Drop struct tpm_vendor_specific
> tpm: tpm_tis_i2c: Merge struct tpm_dev into tpm_chip
> tpm: tpm_tis_i2c: Merge struct tpm into tpm_chip
> tpm: tpm_tis_i2c: Move definitions into the header file
> tpm: tpm_tis_i2c: Simplify init code
> tpm: tpm_tis_i2c: Use a consistent tpm_tis_i2c_ prefix
> tpm: tpm_tis_i2c: Tidy up delays
> dm: tpm: Add a uclass for Trusted Platform Modules
> dm: tpm: Convert the TPM command and library to driver model
> dm: i2c: Add a command to adjust the offset length
> tpm: Report tpm errors on the command line
> dm: tpm: sandbox: Convert TPM driver to driver model
> tpm: Check that parse_byte_string() has data to parse
> exynos: x86: dts: Add tpm nodes to the device tree for Chrome OS
> devices
> dm: tpm: Convert I2C driver to driver model
> dm: tpm: Convert LPC driver to driver model
> tpm: Add a 'tpm info' command
> tpm: Add functions to access flags and permissions
> dm: tpm: Add a 'tpmtest' command
> tpm: Enable 'tpmtest' command for Chrome OS boards with TPMs
> tegra: nyan: Enable TPM command and driver
>
> README | 6 -
> arch/arm/dts/exynos5250-snow.dts | 9 +
> arch/arm/dts/exynos5250-spring.dts | 8 +
> arch/arm/dts/exynos5420-peach-pit.dts | 6 +-
> arch/arm/dts/exynos5800-peach-pi.dts | 6 +-
> arch/sandbox/dts/sandbox.dts | 4 +
> arch/x86/dts/chromebook_link.dts | 5 +
> arch/x86/dts/chromebox_panther.dts | 5 +
> common/Kconfig | 22 +
> common/Makefile | 1 +
> common/cmd_i2c.c | 33 +
> common/cmd_tpm.c | 100 ++-
> common/cmd_tpm_test.c | 565 +++++++++++++++++
> configs/chromebook_link_defconfig | 5 +
> configs/chromebox_panther_defconfig | 5 +
> .../controlcenterd_36BIT_SDCARD_DEVELOP_defconfig | 4 +
> configs/controlcenterd_36BIT_SDCARD_defconfig | 4 +
> .../controlcenterd_TRAILBLAZER_DEVELOP_defconfig | 4 +
> configs/controlcenterd_TRAILBLAZER_defconfig | 4 +
> configs/coreboot-x86_defconfig | 5 +
> configs/nyan-big_defconfig | 5 +
> configs/peach-pi_defconfig | 5 +
> configs/peach-pit_defconfig | 5 +
> configs/sandbox_defconfig | 4 +
> configs/snow_defconfig | 5 +
> configs/spring_defconfig | 5 +
> drivers/tpm/Kconfig | 69 ++
> drivers/tpm/Makefile | 4 +-
> drivers/tpm/tpm-uclass.c | 133 ++++
> drivers/tpm/tpm.c | 694 ---------------------
> drivers/tpm/tpm_atmel_twi.c | 15 +-
> drivers/tpm/tpm_internal.h | 287 +++++++++
> drivers/tpm/tpm_tis_i2c.c | 572 ++++++++---------
> drivers/tpm/{tpm_private.h => tpm_tis_i2c.h} | 88 +--
> drivers/tpm/tpm_tis_lpc.c | 290 ++++-----
> drivers/tpm/tpm_tis_sandbox.c | 57 +-
> include/configs/controlcenterd.h | 7 -
> include/configs/efi-x86.h | 2 -
> include/configs/exynos5-common.h | 7 -
> include/configs/x86-common.h | 2 -
> include/dm/uclass-id.h | 1 +
> include/fdtdec.h | 2 -
> include/tis.h | 3 +
> include/tpm.h | 243 +++++++-
> lib/Kconfig | 10 +
> lib/fdtdec.c | 2 -
> lib/tpm.c | 82 ++-
> 47 files changed, 2102 insertions(+), 1298 deletions(-)
> create mode 100644 common/cmd_tpm_test.c
> create mode 100644 drivers/tpm/tpm-uclass.c
> delete mode 100644 drivers/tpm/tpm.c
> create mode 100644 drivers/tpm/tpm_internal.h
> rename drivers/tpm/{tpm_private.h => tpm_tis_i2c.h} (54%)
>
next prev parent reply other threads:[~2015-08-24 20:20 UTC|newest]
Thread overview: 81+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-08-23 0:31 [U-Boot] [PATCH v2 00/28] dm: Convert TPM drivers to driver model Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 01/28] tpm: Remove old pre-driver-model I2C code Simon Glass
2015-08-24 4:50 ` Heiko Schocher
2015-08-24 4:52 ` Simon Glass
2015-08-24 5:15 ` Heiko Schocher
2015-08-30 22:42 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 02/28] tpm: Drop two unused options Simon Glass
2015-08-30 22:42 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 03/28] tpm: Add Kconfig options for TPMs Simon Glass
2015-08-24 20:24 ` Christophe Ricard
2015-08-30 22:42 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 04/28] tpm: Convert board config TPM options to Kconfig Simon Glass
2015-08-24 20:20 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 05/28] tpm: Convert drivers to use SPDX Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 06/28] tpm: Move the I2C TPM code into one file Simon Glass
2015-08-24 20:24 ` Christophe Ricard
2015-08-25 4:13 ` Simon Glass
2015-08-25 18:38 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 07/28] tpm: tpm_tis_i2c: Drop unnecessary methods Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 08/28] tpm: tpm_tis_i2c: Drop struct tpm_vendor_specific Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 09/28] tpm: tpm_tis_i2c: Merge struct tpm_dev into tpm_chip Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 10/28] tpm: tpm_tis_i2c: Merge struct tpm " Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 11/28] tpm: tpm_tis_i2c: Move definitions into the header file Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 12/28] tpm: tpm_tis_i2c: Simplify init code Simon Glass
2015-08-24 20:20 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 13/28] tpm: tpm_tis_i2c: Use a consistent tpm_tis_i2c_ prefix Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 14/28] tpm: tpm_tis_i2c: Tidy up delays Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 15/28] dm: tpm: Add a uclass for Trusted Platform Modules Simon Glass
2015-08-24 20:21 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 16/28] dm: tpm: Convert the TPM command and library to driver model Simon Glass
2015-08-24 20:21 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 17/28] dm: i2c: Add a command to adjust the offset length Simon Glass
2015-08-24 20:21 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 18/28] tpm: Report tpm errors on the command line Simon Glass
2015-08-24 20:21 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 19/28] dm: tpm: sandbox: Convert TPM driver to driver model Simon Glass
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 20/28] tpm: Check that parse_byte_string() has data to parse Simon Glass
2015-08-24 20:22 ` Christophe Ricard
2015-08-25 4:13 ` Simon Glass
2015-08-25 18:40 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 21/28] exynos: x86: dts: Add tpm nodes to the device tree for Chrome OS devices Simon Glass
2015-08-24 20:22 ` Christophe Ricard
2015-08-30 22:43 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 22/28] dm: tpm: Convert I2C driver to driver model Simon Glass
2015-08-24 20:22 ` Christophe Ricard
2015-08-30 22:44 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 23/28] dm: tpm: Convert LPC " Simon Glass
2015-08-24 20:23 ` Christophe Ricard
2015-08-30 22:44 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 24/28] tpm: Add a 'tpm info' command Simon Glass
2015-08-30 22:44 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 25/28] tpm: Add functions to access flags and permissions Simon Glass
2015-08-24 20:23 ` Christophe Ricard
2015-08-30 22:44 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 26/28] dm: tpm: Add a 'tpmtest' command Simon Glass
2015-08-24 20:23 ` Christophe Ricard
2015-08-30 22:44 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 27/28] tpm: Enable 'tpmtest' command for Chrome OS boards with TPMs Simon Glass
2015-08-24 20:23 ` Christophe Ricard
2015-08-30 22:44 ` Simon Glass
2015-08-23 0:31 ` [U-Boot] [PATCH v2 28/28] tegra: nyan: Enable TPM command and driver Simon Glass
2015-08-30 22:44 ` Simon Glass
2015-08-24 20:20 ` Christophe Ricard [this message]
2015-08-25 4:13 ` [U-Boot] [PATCH v2 00/28] dm: Convert TPM drivers to driver model Simon Glass
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=55DB7C7D.1090201@gmail.com \
--to=christophe.ricard@gmail.com \
--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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.