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@xxxxxxxxxxxxxxxxxxxxx> > > > > > 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. I'm definitely in favor of exporting the PCRs, just as the TPM 2.0 event log and version are now exported. Mimi