aboutsummaryrefslogtreecommitdiff
path: root/lib/tpm_api.c
diff options
context:
space:
mode:
authorIlias Apalodimas2023-01-25 12:18:36 +0200
committerIlias Apalodimas2023-02-28 09:44:19 +0200
commita595be3a4af116a9559a3868f81dcad55d01b8dd (patch)
tree514219591d90388d18495638c3de6800a2cd5438 /lib/tpm_api.c
parent5b197eee334bdf75cc9e9148161299679a5251ea (diff)
tpm: add a function that performs selftest + startup
As described in [0] if a command requires use of an untested algorithm or functional module, the TPM performs the test and then completes the command actions. Since we don't check for TPM_RC_NEEDS_TEST (which is the return code of the TPM in that case) and even if we would, it would complicate our TPM code for no apparent reason, add a wrapper function that performs both the selftest and the startup sequence of the TPM. It's worth noting that this is implemented on TPMv2.0. The code for 1.2 would look similar, but I don't have a device available to test. [0] https://trustedcomputinggroup.org/wp-content/uploads/TPM-Rev-2.0-Part-1-Architecture-01.07-2014-03-13.pdf ยง12.3 Self-test modes Reviewed-by: Simon Glass <sjg@chromium.org> Signed-off-by: Ilias Apalodimas <ilias.apalodimas@linaro.org>
Diffstat (limited to 'lib/tpm_api.c')
-rw-r--r--lib/tpm_api.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/tpm_api.c b/lib/tpm_api.c
index 7e8df8795ef..5b2c11a277c 100644
--- a/lib/tpm_api.c
+++ b/lib/tpm_api.c
@@ -35,6 +35,14 @@ u32 tpm_startup(struct udevice *dev, enum tpm_startup_type mode)
}
}
+u32 tpm_auto_start(struct udevice *dev)
+{
+ if (tpm_is_v2(dev))
+ return tpm2_auto_start(dev);
+
+ return -ENOSYS;
+}
+
u32 tpm_resume(struct udevice *dev)
{
if (tpm_is_v1(dev))