public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] [PATCH 00/25] dm: Convert TPM drivers to driver model
@ 2015-08-11 14:47 Simon Glass
  2015-08-11 14:47 ` [U-Boot] [PATCH 01/25] tpm: Remove old pre-driver-model I2C code Simon Glass
                   ` (25 more replies)
  0 siblings, 26 replies; 64+ messages in thread
From: Simon Glass @ 2015-08-11 14:47 UTC (permalink / raw)
  To: u-boot

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

-- 
2.5.0.rc2.392.g76e840b

^ permalink raw reply	[flat|nested] 64+ messages in thread

end of thread, other threads:[~2015-08-20 21:39 UTC | newest]

Thread overview: 64+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
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 ` [U-Boot] [PATCH 00/25] dm: Convert TPM drivers to driver model christophe.ricard
2015-08-13  1:30   ` Simon Glass
2015-08-13 20:22     ` Christophe Ricard
2015-08-13 22:52       ` Simon Glass
2015-08-20 21:39         ` Simon Glass

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox