xref: /linux/Documentation/translations/zh_CN/security/tpm/tpm_tis.rst (revision bbfd5594756011167b8f8de9a00e0c946afda1e6)
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