Thread (29 messages) 29 messages, 7 authors, 2021-05-05

Re: [PATCH 2/9] tpm: Allow PCR 23 to be restricted to kernel-only use

From: James Bottomley <hidden>
Date: 2021-02-24 18:02:15
Also in: keyrings, linux-pm, lkml

On Sat, 2021-02-20 at 01:32 +0000, Matthew Garrett wrote:
Under certain circumstances it might be desirable to enable the
creation of TPM-backed secrets that are only accessible to the
kernel. In an ideal world this could be achieved by using TPM
localities, but these don't appear to be available on consumer
systems.
I don't understand this ... the localities seem to work fine on all the
systems I have ... is this some embedded thing?
 An alternative is to simply block userland from modifying one of the
resettable PCRs, leaving it available to the kernel. If the kernel
ensures that no userland can access the TPM while it is carrying out
work, it can reset PCR 23, extend it to an arbitrary value, create or
load a secret, and then reset the PCR again. Even if userland somehow
obtains the sealed material, it will be unable to unseal it since PCR
23 will never be in the appropriate state.
This seems a bit arbitrary: You're removing this PCR from user space
accessibility, but PCR 23 is defined as "Application Support" how can
we be sure no application will actually want to use it (and then fail)?

Since PCRs are very scarce, why not use a NV index instead.  They're
still a bounded resource, but most TPMs have far more of them than they
do PCRs, and the address space is much bigger so picking a nice
arbitrary 24 bit value reduces the chance of collisions.

James

Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help