EVT_ACX_FACTORY_CIRCUIT_PREPARE_HARDWARE回调函数 (acxcircuit.h)

当线路工厂处于准备硬件阶段时,驱动程序使用 EVT_ACX_FACTORY_CIRCUIT_PREPARE_HARDWARE 回调来添加功能。

语法

EVT_ACX_FACTORY_CIRCUIT_PREPARE_HARDWARE EvtAcxFactoryCircuitPrepareHardware;

NTSTATUS EvtAcxFactoryCircuitPrepareHardware(
  WDFDEVICE Device,
  ACXFACTORYCIRCUIT Factory,
  WDFCMRESLIST ResourcesRaw,
  WDFCMRESLIST ResourcesTranslated
)
{...}

参数

Device

与 ACX 线路关联的 框架对象) 摘要 中所述的 WDFDEVICE 对象 (。

Factory

现有线路工厂 ACXFACTORYCIRCUIT 对象。 有关 ACX 对象的详细信息,请参阅 ACX 对象的摘要

ResourcesRaw

描述要用于准备硬件阶段的原始资源的 WDF 资源列表。 这是一个 WDF 框架资源列表对象,表示设备的硬件资源列表。 有关原始资源的详细信息,请参阅 Framework-Based 驱动程序的硬件资源

ResourcesTranslated

一个 WDF 资源列表,用于描述要用于准备硬件阶段的已翻译资源。 这是一个 WDF 框架资源列表对象,表示设备的硬件资源列表。 有关已翻译的资源列表的详细信息,请参阅 原始资源和翻译的资源

返回值

STATUS_SUCCESS如果调用成功,则返回 。 否则,它将返回相应的错误代码。 有关详细信息,请参阅 使用 NTSTATUS 值

注解

若要注册 EvtAcxFactoryCircuitPrepareHardware 回调函数,驱动程序必须调用 AcxFactoryCircuitInitSetAcxCircuitPnpPowerCallbacks 方法

如果驱动程序已为 ACXFACTORYCIRCUIT 注册了 EvtAcxFactoryCircuitPrepareHardware 回调函数,则 ACX 框架在 WDF 框架调用驱动程序的 EvtDevicePrepareHardware 回调函数后调用该函数。

EvtAcxFactoryCircuitPrepareHardware 回调函数使用收到的 ResourcesRaw 和 ResourcesTranslated 句柄访问设备的原始和已翻译的硬件资源。 回调函数可以调用 WdfCmResourceListGetCountWdfCmResourceListGetDescriptor 来遍历资源列表。 此回调函数无法修改资源列表。

有关资源列表和资源显示顺序的详细信息,请参阅 原始资源和翻译的资源

通常,驱动程序的 EvtAcxFactoryCircuitPrepareHardware 回调函数将在必要时执行以下操作:

  • 将物理内存地址映射到 ACXFACTORYCIRCUIT 的虚拟地址,以便驱动程序可以访问分配给设备的内存。
  • (可选)驱动程序的 EvtAcxFactoryCircuitPrepareHardware 回调函数可能会对工作项进行排队,以完成任何其他耗时的配置任务。 将工作项用于此类操作有助于确保设备的启动时间不会增加系统启动时间。 有关详细信息,请参阅 使用框架工作项
  • 通常,所有其他硬件初始化操作(包括加载固件)应在每次设备进入其工作 (D0) 状态时发生,因此应在驱动程序的 EvtDeviceD0Entry 回调函数中发生。

在驱动程序的 EvtDeviceReleaseHardware 回调函数返回之前,EvtAcxCircuitPrepareHardware/EvtDevicePrepareHardware 回调函数接收的 ResourcesRaw 和 ResourcesTranslated 处理保持有效。

如果驱动程序未通过 EvtAcxFactoryCircuitPrepareHardware 回调,ACXFACTORYCIRCUIT 对象将处于删除挂起状态。

有关硬件资源的详细信息,请参阅 硬件资源简介

有关 ACX 和 WDF 框架何时调用这些回调函数的详细信息,请参阅 PnP 和电源管理方案

有关提供此回调函数的驱动程序的详细信息,请参阅 在函数驱动程序中支持 PnP 和电源管理

ACX 要求

最低 ACX 版本: 1.0

有关 ACX 版本的详细信息,请参阅 ACX 版本概述

要求

要求
Header acxcircuit.h
IRQL PASSIVE_LEVEL

另请参阅