Page MenuHomeFreeBSD

tpm: Refactor TIS and add a SPI attachment
ClosedPublic

Authored by jhibbits on May 2 2024, 7:52 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 12, 2:48 PM
Unknown Object (File)
Fri, Jan 10, 5:31 AM
Unknown Object (File)
Fri, Jan 10, 5:16 AM
Unknown Object (File)
Thu, Jan 9, 9:05 PM
Unknown Object (File)
Dec 10 2024, 4:48 AM
Unknown Object (File)
Dec 9 2024, 7:05 AM
Unknown Object (File)
Dec 6 2024, 2:30 PM
Unknown Object (File)
Nov 23 2024, 12:26 PM
Subscribers

Details

Summary

Though mostly used in x86 devices, TPM can be used on others, with a
direct SPI attachment. Refactor the TPM 2.0 driver set to use an
attachment interface, and implement a SPI bus interface.

Obtained from: Juniper Networks, Inc.

Test Plan

Tested on a Raspberry Pi 4, with a GeeekPi TPM2.0 module (SLB9670
TPM) using security/tpm2-tools tpm2_getcaps for very light testing against the
spibus attachment.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 57556
Build 54444: arc lint + arc unit

Event Timeline

sys/conf/files
3186

Other TPM ACPI dependent files are only included files.amd64.
Could you also move them here as a part of this commit?
This way we could support TPM in ARM64 based boards that run ACPI.

sys/dev/tpm/tpm_tis.h
28

Do we really need this?
Looks like an empty header.

sys/modules/tpm/Makefile
15

How about .if defined(${OPT_ACPI})?
Also please move this below the #TPM 2.0 comment (line 21).
This way it'll be easier to differenciate which files are used for the old (TPM1.2) driver.

jhibbits added inline comments.
sys/conf/files
3186

This does allow ACPI ARM64 to do TPM2 with TIS. I can't verify CRB at all.

sys/dev/tpm/tpm_tis.h
28

Oops. This was leftover from dev.

sys/modules/tpm/Makefile
15

I can sort it, but I don't see OPT_ACPI anywhere existing.

This revision is now accepted and ready to land.May 3 2024, 7:40 PM
This revision was automatically updated to reflect the committed changes.
jhibbits marked an inline comment as done.