On Tue, 2020-08-18 at 15:36 -0300, Jason Gunthorpe wrote: > On Tue, Aug 18, 2020 at 02:26:04PM -0400, Mimi Zohar wrote: > > On Tue, 2020-08-18 at 13:46 -0300, Jason Gunthorpe wrote: > > > On Tue, Aug 18, 2020 at 07:26:30PM +0300, Jarkko Sakkinen wrote: > > > > On Tue, Aug 18, 2020 at 07:19:57PM +0300, Jarkko Sakkinen > > > > wrote: > > > > > On Tue, Aug 18, 2020 at 07:12:09PM +0300, Jarkko Sakkinen > > > > > wrote: > > > > > > On Mon, Aug 17, 2020 at 02:35:06PM -0700, James Bottomley > > > > > > wrote: > > > > > > > Create sysfs per hash groups with 24 PCR files in them > > > > > > > one group, named pcr-<hash>, for each agile hash of the > > > > > > > TPM. The files are plugged in to a PCR read function > > > > > > > which is TPM version agnostic, so this works also for TPM > > > > > > > 1.2 but the hash is only sha1 in that case. > > > > > > > > > > > > > > Note: the macros used to create the hashes emit spurious > > > > > > > checkpatch warnings. Do not try to "fix" them as > > > > > > > checkpatch recommends, otherwise they'll break. > > > > > > > > > > > > > > Signed-off-by: James Bottomley <James.Bottomley@HansenPar > > > > > > > tnership.com> > > > > > > > Reviewed-by: Jerry Snitselaar <jsnitsel@xxxxxxxxxx> > > > > > > > Tested-by: Thiago Jung Bauermann <bauerman@xxxxxxxxxxxxx> > > > > > > > > > > > > I have hard time understanding why this is required. > > > > > > > > > > > > You can grab the information through /dev/tpm0 just fine. > > > > > > > > > > I just think it is principally wrong to add sysfs files if > > > > > they don't have any measurable value other than perhaps some > > > > > convenience. > > > > > > > > > > It is trival to write only a libc dependent program that > > > > > outputs PCRs. > > > > > > > > > > I think this is essentially an user space problem that is > > > > > getting sorted out with kernel code. > > > > > > > > Jason, what do you make of this? I recall that it was you who I > > > > discussed with about this topic when TPM 2.0 support was first > > > > upstreamed. > > > > > > TPM 2.0 broke all the userspace so it made sense to get rid of > > > the non-conforming sysfs files from TPM v1.x time as part of the > > > userspace API. That was the main reason to not continue forward > > > with PCR in userspace. > > > > > > As far as doing it properly as this patch does.. I agree with you > > > that sysfs files should have some reason to be added, espcially > > > if it causes quite big code cost as this does. eg to drive a udev > > > rule decision. > > > > > > Why is PCRs so special it needs to be in sysfs? What is userspace > > > going to do with this information? > > > > The original IMA LTP "boot_aggregate" regression test is dependent > > on the exported TPM event log and PCRs. Similar support is needed > > for TPM 2.0. There isn't just a single userspace application for > > reading PCRs. As soon as we add support for one userspace > > application, support for the other applications is requested. So > > instead of a having a simple regression test with a single method > > of reading PCRs, we're now required to support multiple userspace > > applications. > > But this test already has a C program as part of the boot aggregate > test, why is it such a problem to use a C program to also read the > PCRs? > > As Jarkko says it is not so hard It's not so hard for system programmer who owns the root account, like the people who hang out on this list. For your average user, a root only device you're expected to send and receive binary packets of big endian data over is a textbook definition of an unusable interface. I can potentially buy arguments that ordinary users can get this information from TSS based toolkits (although both the Intel and the IBM TSS seem to go out of their way to make it hard to extract). Or even that the average user has no use for the information (although I've given three examples). However, it's not realistic to expect that the average user start speaking binary packet protocols from shell scripts. James