访问 PCI 设备配置空间

外围组件互连 (PCI) 设备上的某些操作保留给设备的功能驱动程序。 例如,此类操作包括访问总线的设备特定配置空间,以及 (DMA) 控制器对直接内存访问进行编程。 Microsoft 通过两种方法为访问 PCI 设备的配置空间提供系统支持:

注意

从 Windows 10 版本 2004 开始,如果设备具有安全设备 (SDEV) ACPI 表且启用了基于虚拟化的安全性,则会对不受支持的 PCI 设备配置空间访问方法施加限制。 如果驱动程序或进程尝试使用上面未列出的方法读取或操作 PCI 设备配置空间,则访问将被阻止,并导致系统 bug 检查。

根据 PCI 本地总线 规范的定义,Windows XP 和 Windows Server 2003 及更高版本的操作系统对配置空间标头以及功能链接列表中的所有功能具有独占控制权。 驱动程序不得尝试修改这些寄存器。

但是,驱动程序可以使用 IRP_MN_WRITE_CONFIG 请求或 BUS_INTERFACE_STANDARD 的 SetBusData 方法写入不属于供应商定义的标头或功能列表的配置空间。 驱动程序还可以使用 BUS_INTERFACE_STANDARD 的 IRP_MN_READ_CONFIG 请求或 GetBusData 方法读取设备的功能。 若要使用IRP_MN_READ_CONFIG或IRP_MN_WRITE_CONFIG,驱动程序必须在PASSIVE_LEVEL运行。 有关驱动程序可以查询的功能和相应结构的列表,请参阅 PCI 结构 部分。

驱动程序可以从扩展 PCI 设备配置空间 (读取,即使用 IRP_MN_READ_CONFIG 请求或 getBusData BUS_INTERFACE_STANDARD 方法) 超过 256 字节的配置数据。 同样,驱动程序可以使用 IRP_MN_WRITE_CONFIG 请求或 BUS_INTERFACE_STANDARD 的 SetBusData 方法写入扩展的 PCI 设备配置空间。 如果设备没有扩展配置空间,或者平台未定义设备上扩展配置空间的路径,则读取请求将返回0xFFFF,写入请求将不起作用。 若要确定操作是否成功,驱动程序可以检查读取或写入的字节数。

PCI Express 和 PCI-X 模式 2 支持大于 256 字节的扩展 PCI 设备配置空间。 驱动程序可以读取和写入此配置空间,但只能使用适当的硬件和 BIOS 支持。 在 ACPI BIOS 中,根总线的 PNP ID 必须为 PNP0A08 或 PNP0A03。 对于 PNP ID 为 PNP0A03 的根总线,具有函数 4 的 _DSM 方法应指示当前模式为 PCI-X 模式 2。 所有网桥和设备都应为 PCI express 或在 PCI-X 模式 2 中运行。

此外,系统应支持内存映射配置空间访问。 这是通过在系统 BIOS/固件中定义 MCFG 表。 Windows Vista 和 Windows Server 2008 及更高版本的操作系统自动支持内存映射配置空间访问。

警告

HalGetBusDataByOffsetHalSetBusDataByOffset 是为向后兼容而提供的,但仅当无法使用上述两种方法时才应使用。

另请参阅

访问设备配置空间