mirror of
https://git.proxmox.com/git/mirror_ubuntu-kernels.git
synced 2026-01-14 12:10:33 +00:00
Currently tpm transactions are executed unconditionally in
tpm_pm_suspend() function, which may lead to races with other tpm
accessors in the system.
Specifically, the hw_random tpm driver makes use of tpm_get_random(),
and this function is called in a loop from a kthread, which means it's
not frozen alongside userspace, and so can race with the work done
during system suspend:
tpm tpm0: tpm_transmit: tpm_recv: error -52
tpm tpm0: invalid TPM_STS.x 0xff, dumping stack for forensics
CPU: 0 PID: 1 Comm: init Not tainted 6.1.0-rc5+ #135
Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS 1.16.0-20220807_005459-localhost 04/01/2014
Call Trace:
tpm_tis_status.cold+0x19/0x20
tpm_transmit+0x13b/0x390
tpm_transmit_cmd+0x20/0x80
tpm1_pm_suspend+0xa6/0x110
tpm_pm_suspend+0x53/0x80
__pnp_bus_suspend+0x35/0xe0
__device_suspend+0x10f/0x350
Fix this by calling tpm_try_get_ops(), which itself is a wrapper around
tpm_chip_start(), but takes the appropriate mutex.
Signed-off-by: Jan Dabros <jsd@semihalf.com>
Reported-by: Vlastimil Babka <vbabka@suse.cz>
Tested-by: Jason A. Donenfeld <Jason@zx2c4.com>
Tested-by: Vlastimil Babka <vbabka@suse.cz>
Link: https://lore.kernel.org/all/c5ba47ef-393f-1fba-30bd-1230d1b4b592@suse.cz/
Cc: stable@vger.kernel.org
Fixes:
|
||
|---|---|---|
| .. | ||
| eventlog | ||
| st33zp24 | ||
| Kconfig | ||
| Makefile | ||
| tpm1-cmd.c | ||
| tpm2-cmd.c | ||
| tpm2-space.c | ||
| tpm_atmel.c | ||
| tpm_atmel.h | ||
| tpm_crb.c | ||
| tpm_ftpm_tee.c | ||
| tpm_ftpm_tee.h | ||
| tpm_i2c_atmel.c | ||
| tpm_i2c_infineon.c | ||
| tpm_i2c_nuvoton.c | ||
| tpm_ibmvtpm.c | ||
| tpm_ibmvtpm.h | ||
| tpm_infineon.c | ||
| tpm_nsc.c | ||
| tpm_ppi.c | ||
| tpm_tis_core.c | ||
| tpm_tis_core.h | ||
| tpm_tis_i2c_cr50.c | ||
| tpm_tis_i2c.c | ||
| tpm_tis_spi_cr50.c | ||
| tpm_tis_spi_main.c | ||
| tpm_tis_spi.h | ||
| tpm_tis_synquacer.c | ||
| tpm_tis.c | ||
| tpm_vtpm_proxy.c | ||
| tpm-chip.c | ||
| tpm-dev-common.c | ||
| tpm-dev.c | ||
| tpm-dev.h | ||
| tpm-interface.c | ||
| tpm-sysfs.c | ||
| tpm.h | ||
| tpmrm-dev.c | ||
| xen-tpmfront.c | ||