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#},
            }
        })
    }
}

另请参阅

在 Windows 中启用 PCI Express 原生控制

适用于 Thunderbolt 3 的内核 DMA 防护

为设备驱动程序启用 DMA 重新映射

D3COLD_AUX_POWER_AND_TIMING_INTERFACE 结构