tpm: Extend common APIs to support TPM TIS I2C
authorNinad Palsule <ninad@linux.ibm.com>
Fri, 14 Apr 2023 22:07:53 +0000 (17:07 -0500)
committerStefan Berger <stefanb@linux.ibm.com>
Thu, 20 Apr 2023 12:17:15 +0000 (08:17 -0400)
commitbbadfb2e0af238576646e0fc8e0b5e4f4fe29648
tree53eb2c59bdd38d8ac709a1f3a80eeed4447cbb60
parentfbd945e7831b45b266dae292e79b6cce2b94924f
tpm: Extend common APIs to support TPM TIS I2C

Qemu already supports devices attached to ISA and sysbus. This drop adds
support for the I2C bus attached TPM devices.

This commit includes changes for the common code.
- Added support for the new checksum registers which are required for
  the I2C support. The checksum calculation is handled in the qemu
  common code.
- Added wrapper function for read and write data so that I2C code can
  call it without MMIO interface.

The TPM TIS I2C spec describes in the table in section "Interface Locality
Usage per Register" that the TPM_INT_ENABLE and TPM_INT_STATUS registers
must be writable for any locality even if the locality is not the active
locality. Therefore, remove the checks whether the writing locality is the
active locality for these registers.

Signed-off-by: Ninad Palsule <ninad@linux.ibm.com>
Signed-off-by: Stefan Berger <stefanb@linux.ibm.com>
Reviewed-by: Stefan Berger <stefanb@linux.ibm.com>
Tested-by: Stefan Berger <stefanb@linux.ibm.com>
Reviewed-by: Cédric Le Goater <clg@kaod.org>
Reviewed-by: Joel Stanley <joel@jms.id.au>
Tested-by: Joel Stanley <joel@jms.id.au>
Message-id: 20230414220754.1191476-3-ninadpalsule@us.ibm.com
hw/tpm/tpm_tis.h
hw/tpm/tpm_tis_common.c
include/hw/acpi/tpm.h