WdfDeviceInitSetFileObjectConfig 函式 (wdfdevice.h)
[適用於 KMDF 和 UMDF]
WdfDeviceInitSetFileObjectConfig 方法會註冊事件回呼函式,並設定驅動程式架構檔案物件的組態資訊。
語法
void WdfDeviceInitSetFileObjectConfig(
[in] PWDFDEVICE_INIT DeviceInit,
[in] PWDF_FILEOBJECT_CONFIG FileObjectConfig,
[in, optional] PWDF_OBJECT_ATTRIBUTES FileObjectAttributes
);
參數
[in] DeviceInit
WDFDEVICE_INIT 結構的指標。
[in] FileObjectConfig
呼叫端配置之 WDF_FILEOBJECT_CONFIG 結構的指標。
[in, optional] FileObjectAttributes
呼叫端配置的 WDF_OBJECT_ATTRIBUTES 結構的指標,其中包含驅動程式架構檔案對象的驅動程式提供物件屬性。 這個參數是選擇性的,而且可以WDF_NO_OBJECT_ATTRIBUTES。
傳回值
沒有
言論
如果驅動程式呼叫 WdfDeviceInitSetFileObjectConfig,則必須先執行此動作,才能呼叫 WdfDeviceCreate。
根據預設,每個架構檔案物件都會從其父裝置物件繼承其同步處理範圍和執行層級。 如果父裝置物件的同步處理範圍和執行層級未 WdfSynchronizationScopeNone 且 WdfExecutionLevelPassive,驅動程式必須設定 WdfSynchronizationScopeNone 和 WdfExecutionLevelPassiveWDF_OBJECT_ATTRIBUTES 結構中的值,FileObjectAttributes 參數所指定。 否則,WdfDeviceCreate 會傳回錯誤狀態代碼。 如需同步處理範圍和執行層級的詳細資訊,請參閱使用自動同步處理 。
如需呼叫 WdfDeviceCreate的詳細資訊,請參閱 建立 Framework Device Object。
如需架構檔案對象的詳細資訊,請參閱 Framework 檔案物件
例子
下列程式代碼範例會初始化 WDF_OBJECT_ATTRIBUTES 結構和 WDF_FILEOBJECT_CONFIG 結構,然後呼叫 WdfDeviceInitSetFileObjectConfig。
WDF_OBJECT_ATTRIBUTES attributes;
WDF_OBJECT_ATTRIBUTES_INIT(&attributes);
attributes.SynchronizationScope = WdfSynchronizationScopeNone;
WDF_FILEOBJECT_CONFIG_INIT(
&deviceConfig,
MyEvtDeviceFileCreate,
MyEvtFileClose,
WDF_NO_EVENT_CALLBACK // No cleanup callback function
);
WdfDeviceInitSetFileObjectConfig(
DeviceInit,
&deviceConfig,
&attributes
);
要求
要求 | 價值 |
---|---|
目標平臺 | 普遍 |
最低 KMDF 版本 | 1.0 |
最低 UMDF 版本 | 2.0 |
標頭 | wdfdevice.h (包括 Wdf.h) |
連結庫 | Wdf01000.sys (KMDF):WUDFx02000.dll (UMDF) |
IRQL | <= DISPATCH_LEVEL |
DDI 合規性規則 | ChildDeviceInitAPI(kmdf),ControlDeviceInitAPI(kmdf),DeviceInitAPI(kmdf),DriverCreate(kmdf),FileObjectConfigured(kmdf),KmdfIrql(kmdf),KmdfIrql2(kmdf),KmdfIrqlExplicit(kmdf),PdoDeviceInitAPI(kmdf) |