25. TSX 异步中止 (TAA) 缓解¶
25.1. 概述¶
TSX 异步中止 (TAA) 是一种针对某些 Intel 处理器内部缓冲区的侧信道攻击,类似于微架构数据采样 (MDS)。在这种情况下,当事务同步扩展 (TSX) 事务中存在异步中止条件时,某些加载可能会将无效数据推测性地传递给依赖操作。这包括没有故障或辅助条件的加载。此类加载可能会推测性地公开来自与 MDS 相同的 uarch 数据结构的陈旧数据,具有相同的公开范围,即同线程和跨线程。此问题影响所有当前支持 TSX 的处理器。
25.2. 缓解策略¶
a) 禁用 TSX - 缓解措施之一是禁用 TSX。新的 MSR IA32_TSX_CTRL 将在未来的和当前的处理器中通过微码更新后可用,可用于禁用 TSX。此外,它还控制 CPUID 中 TSX 特性位(RTM 和 HLE)的枚举。
b) 清除 CPU 缓冲区 - 类似于 MDS,清除 CPU 缓冲区可以缓解此漏洞。有关此方法的更多详细信息,请参见 Documentation/admin-guide/hw-vuln/mds.rst。
25.3. 内核内部缓解模式¶
off
禁用缓解。要么 CPU 不受影响,要么在内核命令行上提供 tsx_async_abort=off。
tsx disabled
启用缓解。在支持 TSX 控制的处理器上,默认情况下在启动时禁用 TSX 功能。
verw
启用缓解。CPU 受到影响,并且在 CPUID 中公布了 MD_CLEAR。
ucode needed
启用缓解。CPU 受到影响,并且在 CPUID 中未公布 MD_CLEAR。这主要用于虚拟化场景,其中主机具有更新的微码,但虚拟机管理程序未在 CPUID 中公开 MD_CLEAR。这是一种尽力而为的方法,不保证有效。
如果 CPU 受到影响,并且未提供“tsx_async_abort”内核命令行参数,则内核会根据 RTM 和 MD_CLEAR CPUID 位的状态选择适当的缓解措施。
下表指示 tsx=on|off|auto cmdline 选项对各种 MSR_IA32_ARCH_CAPABILITIES 位组合的 TAA 缓解、VERW 行为和 TSX 功能状态的影响。
“tsx=off”
MSR_IA32_ARCH_CAPABILITIES 位 |
使用 cmdline tsx=off 的结果 |
|||||
---|---|---|---|---|---|---|
TAA_NO |
MDS_NO |
TSX_CTRL_MSR |
启动后的 TSX 状态 |
VERW 可以清除 CPU 缓冲区 |
TAA 缓解 tsx_async_abort=off |
TAA 缓解 tsx_async_abort=full |
0 |
0 |
0 |
硬件默认 |
是 |
与 MDS 相同 |
与 MDS 相同 |
0 |
0 |
1 |
无效情况 |
无效情况 |
无效情况 |
无效情况 |
0 |
1 |
0 |
硬件默认 |
否 |
需要 ucode 更新 |
需要 ucode 更新 |
0 |
1 |
1 |
已禁用 |
是 |
TSX 已禁用 |
TSX 已禁用 |
1 |
X |
1 |
已禁用 |
X |
无需 |
无需 |
“tsx=on”
MSR_IA32_ARCH_CAPABILITIES 位 |
使用 cmdline tsx=on 的结果 |
|||||
---|---|---|---|---|---|---|
TAA_NO |
MDS_NO |
TSX_CTRL_MSR |
启动后的 TSX 状态 |
VERW 可以清除 CPU 缓冲区 |
TAA 缓解 tsx_async_abort=off |
TAA 缓解 tsx_async_abort=full |
0 |
0 |
0 |
硬件默认 |
是 |
与 MDS 相同 |
与 MDS 相同 |
0 |
0 |
1 |
无效情况 |
无效情况 |
无效情况 |
无效情况 |
0 |
1 |
0 |
硬件默认 |
否 |
需要 ucode 更新 |
需要 ucode 更新 |
0 |
1 |
1 |
已启用 |
是 |
无 |
与 MDS 相同 |
1 |
X |
1 |
已启用 |
X |
无需 |
无需 |
“tsx=auto”
MSR_IA32_ARCH_CAPABILITIES 位 |
使用 cmdline tsx=auto 的结果 |
|||||
---|---|---|---|---|---|---|
TAA_NO |
MDS_NO |
TSX_CTRL_MSR |
启动后的 TSX 状态 |
VERW 可以清除 CPU 缓冲区 |
TAA 缓解 tsx_async_abort=off |
TAA 缓解 tsx_async_abort=full |
0 |
0 |
0 |
硬件默认 |
是 |
与 MDS 相同 |
与 MDS 相同 |
0 |
0 |
1 |
无效情况 |
无效情况 |
无效情况 |
无效情况 |
0 |
1 |
0 |
硬件默认 |
否 |
需要 ucode 更新 |
需要 ucode 更新 |
0 |
1 |
1 |
已禁用 |
是 |
TSX 已禁用 |
TSX 已禁用 |
1 |
X |
1 |
已启用 |
X |
无需 |
无需 |
在表中,TSX_CTRL_MSR 是 MSR_IA32_ARCH_CAPABILITIES 中的一个新位,指示是否支持 MSR_IA32_TSX_CTRL。
IA32_TSX_CTRL MSR 中有两个控制位
- 位 0:设置后,它将禁用 TSX 的受限事务内存 (RTM)
子功能(将强制所有事务在 XBEGIN 指令上中止)。
- 位 1:设置后,它将禁用 RTM 和 HLE 功能的枚举
(即,它将使 CPUID(EAX=7).EBX{bit4} 和 CPUID(EAX=7).EBX{bit11} 读取为 0)。