ACPI 接口:PCIe 根端口的设备特定数据 (_DSD)
在 Windows 10(版本 1803)中,添加了新的 ACPI _DSD 方法,以支持新式待机和 PCI 热插拔方案。
PCIe 根端口上的定向最深运行时空闲平台状态 (DRIPS) 支持
此 ACPI 对象必须在能够实现导向式电源管理框架 (DFx) 的支持新式待机的系统上用户可访问的每个 PCIe 根端口/插槽的 ACPI 范围内实现。
Name (_DSD, Package () {
ToUUID("FDF06FAD-F744-4451-BB64-ECD792215B10"),
Package () {
Package (2) {"FundamentalDeviceResetTriggeredOnD3ToD0", 1},
}
}
)
在 D3 中识别支持热插拔的 PCIe 根端口
此 ACPI 对象使操作系统能够识别并电源管理能够在 D3 状态下处理热插拔事件的 PCIe 根端口。 如果此对象未在支持 PCIe 热插拔的端口上实现,则如果该端口没有子 PCIe 设备,则系统不会对其进行电源管理,从而导致系统消耗的功率超过所需。
此对象必须在根端口 ACPI 设备范围内的 Thunderbolt 层次结构的所有 PCIe 根端口、支持运行时 D3 (RTD3) 的系统上实现。
Name (_DSD, Package () {
ToUUID("6211E2C0-58A3-4AF3-90E1-927A4E0C55A4"),
Package () {
Package (2) {"HotPlugSupportInD3", 1},
}
}
)
识别外部公开的 PCIe 根端口
此 ACPI 对象使操作系统能够识别外部公开的 PCIe 层次结构,例如 Thunderbolt。 此对象必须在根端口 ACPI 设备作用域中实现。
注意:在随 Windows 10 1803 版本一起提供的系统上,此对象应仅在 Thunderbolt 层次结构的 PCIe 根端口上实现。
Name (_DSD, Package () {
ToUUID("EFCC06CC-73AC-4BC3-BFF0-76143807C389"),
Package () {
Package (2) {"ExternalFacingPort", 1}, // Property 1: This is an externally facing port/hierarchy
Package (2) {"UID", 0}, // Property 2: UID of the externally facing port on platform, range is: 0, 1, …, n-1
}
}
)
识别用户可访问并需要 DMA 保护的内部 PCIe 端口
此 ACPI 对象使操作系统能够识别用户易于访问的内部 PCIe 层次结构(例如,通过闩锁访问的 Laptop M.2 PCIe 插槽),并需要 OS 内核 DMA 保护机制的保护。 此对象必须在根端口 ACPI 设备作用域中实现。
关键注意事项:
仅在 Windows 10 1903 及更高版本中支持使用此 ACPI 对象保护 PCI 端口。
必须在系统 BIOS/UEFI 中启用内核 DMA 保护,以便 OS 分析 _DSD,并对 PCI 端口应用必要的保护。
连接到此端口的设备驱动程序必须支持 DMA 重新映射,否则 Windows 10 可能会阻止这些设备运行,直到用户登录或无限期登录,具体取决于 DMAGuard 策略。
Name (_DSD, Package () {
ToUUID("70D24161-6DD5-4C9E-8070-705531292865"),
Package () {
Package (2) {"DmaProperty", 1}, // Property 1: This port needs to be protected by the OS
Package (2) {"UID", 0}, // Property 2: UID of the PCIe port on platform, range is: 0, 1, …, n-1
}
}
)
标识支持 D3_COLD_AUX_POWER ECN 接口的 PCIe 端口
此 ACPI 对象使操作系统能够识别支持 D3_COLD_AUX_POWER ECN 接口的 PCIe 端口,这允许 PCIe 设备从 D3 中向平台请求高于默认 375 mA @3.3V 的额外辅助电源。 定义此 DSD 的任何 PCI 端口或网桥都必须保证在对以前协商的辅助电源值进行编程时,操作会成功。
Name (_DSD, Package () {
ToUUID("6B4AD420-8FD3-4364-ACF8-EB94876FD9EB"),
Package () {
}
}
)
将通过 USB4 隧道传输的本机协议(PCIe、DisplayPort)映射到 USB4 主机路由器
此 ACPI 对象使操作系统能够将通过 USB4 隧道传输的本机协议(如 PCIe 和 DisplayPort)映射到正确的 USB4 主机路由器。
在下面的示例中,Device (DSB0)
依赖于 \_SB.PCI0.NHI0
。
Scope (\_SB.PCI0)
{
Device (NHI0) { } //Host interface instance which has dependency on \_SB.PCI0.NHI0
Device (DSB0) //Tunneled PCIe port instance
{
Name (_DSD, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"), //Device Properties UUID
Package () {
Package () { "usb4-host-interface", \_SB.PCI0.NHI0 },
Package () { "usb4-port-number", PortInstance#},
}
})
}
Device (…) //Extend to DP and USB tunneled ports, as needed
{
Name (_DSD, Package () {
ToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"), //Device Properties UUID
Package () {
Package () { "usb4-host-interface", \_SB.PCI0.NHI0 },
Package () { "usb4-port-number", PortInstance#},
}
})
}
}