1.. SPDX-License-Identifier: GPL-2.0 2.. include:: ../../disclaimer-zh_CN.rst 3 4:Original: Documentation/security/tpm/tpm_tis.rst 5 6:翻译: 7 赵硕 Shuo Zhao <zhaoshuo@cqsoftware.com.cn> 8 9TPM FIFO接口驱动 10================ 11 12TCG PTP规范定义了两种接口类型:FIFO和CRB。前者基于顺序的读写操作, 13后者基于包含完整命令或响应的缓冲区。 14 15FIFO(先进先出)接口被tpm_tis_core依赖的驱动程序使用。最初,Linux只 16有一个名为tpm_tis的驱动,覆盖了内存映射(即 MMIO)接口,但后来它被 17扩展以支持TCG标准所支持的其他物理接口。 18 19由于历史原因,最初的MMIO驱动被称为tpm_tis,而FIFO驱动的框架被命名为 20tpm_tis_core。在tpm_tis中的“tis”后缀来自TPM接口规范,这是针对TPM1.x 21芯片的硬件接口规范。 22 23通信基于一个由TPM芯片通过硬件总线或内存映射共享的20KiB 缓冲区,具体 24取决于物理接线。该缓冲区进一步分为五个相等大小的4KiB缓冲区,为CPU和 25TPM之间的通信提供等效的寄存器集。这些通信端点在TCG术语中称为localities。 26 27当内核想要向TPM芯片发送命令时,它首先通过在TPM_ACCESS寄存器中设置 28requestUse位来保留locality0。当访问被授予时,该位由芯片清除。一旦完成 29通信,内核会写入TPM_ACCESS.activeLocality位。这告诉芯片该本地性已被 30释放。 31 32待处理的本地性由芯片按优先级降序逐个服务,一次一个: 33 34- Locality0优先级最低。 35- Locality5优先级最高。 36 37关于localities的更多信息和含义,请参阅TCG PC客户端平台TPM 配置文件规范的第3.2节。 38 39参考文献 40======== 41 42TCG PC客户端平台TPM配置文件(PTP)规范 43https://trustedcomputinggroup.org/resource/pc-client-platform-tpm-profile-ptp-specification/ 44