public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
From: christophe.ricard <christophe.ricard@gmail.com>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 00/25] dm: Convert TPM drivers to driver model
Date: Tue, 11 Aug 2015 23:50:25 +0200	[thread overview]
Message-ID: <55CA6E21.6010609@gmail.com> (raw)
In-Reply-To: <1439304497-10081-1-git-send-email-sjg@chromium.org>

Hi Simon,

I pretty much like the move to driver model for TPM.
However, i have some few remarks:

The current i2c driver stick to Infineon TPMs and will not support any 
other vendors like ST(in my case).
The main reason for this is that there is no transport protocol over I2C 
specification defined by the Trusted Computing Group for TPM1.2.
You can take a look at my release tentative here:
http://lists.denx.de/pipermail/u-boot/2015-August/222596.html

The tpm.c file was delivering a way to ajust best the waiting time for 
command duration to receive a command answer from a TPM command. It was 
ported from Linux to u-boot.
You can find in chapter 17 how the table tpm_protected_ordinal_duration, 
tpm_ordinal_duration were build. 
(https://www.trustedcomputinggroup.org/files/resource_files/E14876A3-1A4B-B294-D086297A1ED38F96/mainP2Structrev103.pdf)
This is defined by the TCG and followed by TPM vendors. In u-boot, this 
is used only by Infineon i2c driver but it could/should(?) be used
by all other drivers (i2c and lpc).

In short, the idea is to keep  the way TPM commands are transfered 
giving the hands to drivers for handling the communication over a 
specified or proprietary transport protocol.

I fear the current approach would lead to duplicated codes on may TPM 
drivers and 2 very differents kind of drivers (Linux/u-boot) very far 
from each other.

Would it be possible to have your comments on my proposal ?
http://lists.denx.de/pipermail/u-boot/2015-August/222596.html

Best Regards
Christophe

On 11/08/2015 16:47, 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 (snow, spring, nyan-big,
> pit, pi, link) since some did not have it fully enabled.
>
> As before, the 'tpm' command can be used to implement TPM functionality.
>
>
> Simon Glass (25):
>    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
>    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 +
>   common/Kconfig                                     |  12 +
>   common/cmd_i2c.c                                   |  33 +
>   common/cmd_tpm.c                                   | 100 ++-
>   configs/chromebook_link_defconfig                  |   4 +
>   configs/chromebox_panther_defconfig                |   4 +
>   .../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                     |   4 +
>   configs/nyan-big_defconfig                         |   4 +
>   configs/peach-pi_defconfig                         |   4 +
>   configs/peach-pit_defconfig                        |   4 +
>   configs/sandbox_defconfig                          |   3 +
>   configs/snow_defconfig                             |   4 +
>   configs/spring_defconfig                           |   4 +
>   drivers/tpm/Kconfig                                |  61 ++
>   drivers/tpm/Makefile                               |   4 +-
>   drivers/tpm/tpm-uclass.c                           |  57 ++
>   drivers/tpm/tpm.c                                  | 694 ---------------------
>   drivers/tpm/tpm_atmel_twi.c                        |  15 +-
>   drivers/tpm/tpm_private.h                          | 140 -----
>   drivers/tpm/tpm_tis_i2c.c                          | 594 ++++++++++--------
>   drivers/tpm/tpm_tis_i2c.h                          | 446 +++++++++++++
>   drivers/tpm/tpm_tis_lpc.c                          | 291 +++++----
>   drivers/tpm/tpm_tis_sandbox.c                      |  48 +-
>   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                                      |  97 +++
>   include/tpm.h                                      |   2 +-
>   lib/Kconfig                                        |  10 +
>   lib/fdtdec.c                                       |   2 -
>   lib/tpm.c                                          |  29 +-
>   44 files changed, 1404 insertions(+), 1347 deletions(-)
>   create mode 100644 drivers/tpm/tpm-uclass.c
>   delete mode 100644 drivers/tpm/tpm.c
>   delete mode 100644 drivers/tpm/tpm_private.h
>   create mode 100644 drivers/tpm/tpm_tis_i2c.h
>

  parent reply	other threads:[~2015-08-11 21:50 UTC|newest]

Thread overview: 64+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-08-11 14:47 [U-Boot] [PATCH 00/25] dm: Convert TPM drivers to driver model Simon Glass
2015-08-11 14:47 ` [U-Boot] [PATCH 01/25] tpm: Remove old pre-driver-model I2C code Simon Glass
2015-08-11 21:41   ` christophe.ricard
2015-08-13  1:30     ` Simon Glass
2015-08-11 14:47 ` [U-Boot] [PATCH 02/25] tpm: Drop two unused options Simon Glass
2015-08-11 21:44   ` christophe.ricard
2015-08-11 14:47 ` [U-Boot] [PATCH 03/25] tpm: Add Kconfig options for TPMs Simon Glass
2015-08-11 21:45   ` christophe.ricard
2015-08-13  1:30     ` Simon Glass
2015-08-11 14:47 ` [U-Boot] [PATCH 04/25] tpm: Convert board config TPM options to Kconfig Simon Glass
2015-08-11 21:45   ` christophe.ricard
2015-08-11 14:47 ` [U-Boot] [PATCH 05/25] tpm: Convert drivers to use SPDX Simon Glass
2015-08-11 21:41   ` christophe.ricard
2015-08-11 14:47 ` [U-Boot] [PATCH 06/25] tpm: Move the I2C TPM code into one file Simon Glass
2015-08-11 21:42   ` christophe.ricard
2015-08-13  1:30     ` Simon Glass
2015-08-13 20:26       ` Christophe Ricard
2015-08-11 14:47 ` [U-Boot] [PATCH 07/25] tpm: tpm_tis_i2c: Drop unnecessary methods Simon Glass
2015-08-11 21:47   ` christophe.ricard
2015-08-13  1:30     ` Simon Glass
2015-08-13 20:28       ` Christophe Ricard
2015-08-13 22:53         ` Simon Glass
2015-08-11 14:48 ` [U-Boot] [PATCH 08/25] tpm: tpm_tis_i2c: Drop struct tpm_vendor_specific Simon Glass
2015-08-11 21:47   ` christophe.ricard
2015-08-13  1:30     ` Simon Glass
2015-08-13 20:32       ` Christophe Ricard
2015-08-13 22:53         ` Simon Glass
2015-08-11 14:48 ` [U-Boot] [PATCH 09/25] tpm: tpm_tis_i2c: Merge struct tpm_dev into tpm_chip Simon Glass
2015-08-11 21:46   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 10/25] tpm: tpm_tis_i2c: Merge struct tpm " Simon Glass
2015-08-11 21:46   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 11/25] tpm: tpm_tis_i2c: Move definitions into the header file Simon Glass
2015-08-11 21:45   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 12/25] tpm: tpm_tis_i2c: Simplify init code Simon Glass
2015-08-11 21:45   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 13/25] tpm: tpm_tis_i2c: Use a consistent tpm_tis_i2c_ prefix Simon Glass
2015-08-11 21:44   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 14/25] tpm: tpm_tis_i2c: Tidy up delays Simon Glass
2015-08-11 21:44   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 15/25] dm: tpm: Add a uclass for Trusted Platform Modules Simon Glass
2015-08-11 21:44   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 16/25] dm: tpm: Convert the TPM command and library to driver model Simon Glass
2015-08-11 21:43   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 17/25] dm: i2c: Add a command to adjust the offset length Simon Glass
2015-08-11 14:48 ` [U-Boot] [PATCH 18/25] tpm: Report tpm errors on the command line Simon Glass
2015-08-11 21:43   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 19/25] dm: tpm: sandbox: Convert TPM driver to driver model Simon Glass
2015-08-11 21:42   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 20/25] tpm: Check that parse_byte_string() has data to parse Simon Glass
2015-08-11 21:42   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 21/25] exynos: x86: dts: Add tpm nodes to the device tree for Chrome OS devices Simon Glass
2015-08-11 14:48 ` [U-Boot] [PATCH 22/25] dm: tpm: Convert I2C driver to driver model Simon Glass
2015-08-11 21:41   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 23/25] dm: tpm: Convert LPC " Simon Glass
2015-08-11 21:41   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 24/25] tpm: Add a 'tpm info' command Simon Glass
2015-08-11 21:40   ` christophe.ricard
2015-08-11 14:48 ` [U-Boot] [PATCH 25/25] tegra: nyan: Enable TPM command and driver Simon Glass
2015-08-11 21:40   ` christophe.ricard
2015-08-11 21:50 ` christophe.ricard [this message]
2015-08-13  1:30   ` [U-Boot] [PATCH 00/25] dm: Convert TPM drivers to driver model Simon Glass
2015-08-13 20:22     ` Christophe Ricard
2015-08-13 22:52       ` Simon Glass
2015-08-20 21:39         ` 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=55CA6E21.6010609@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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox