FltOplockFsctrlEx 函式 (fltkernel.h)
FltOplockFsctrlEx 例程會代表迷你篩選驅動程式執行各種 oplock (oplock) 作業。
語法
FLT_PREOP_CALLBACK_STATUS FLTAPI FltOplockFsctrlEx(
[in] POPLOCK Oplock,
[in] PFLT_CALLBACK_DATA CallbackData,
[in] ULONG OpenCount,
[in] ULONG Flags
);
參數
[in] Oplock
檔案的不透明不透明鎖定指標。 此指標必須由先前呼叫 FltInitializeOplock 來初始化。
[in] CallbackData
I/O 作業 FLT_CALLBACK_DATA 結構的指標。 這個參數是必要的,而且不能是 NULL。
[in] OpenCount
如果要求獨佔 oplock,則為檔案的使用者句柄數目。 設定層級 2、R 或 RH oplock 要求的非零值,表示檔案上有位元組範圍鎖定。 如需 oplock 類型的相關信息,請參閱 Oplock 概觀。
[in] Flags
相關聯 oplock 作業的位掩碼。 迷你篩選驅動程式會設定位以指定 FltOplockFsctrlEx 的行為。 Flags 參數具有下列選項:
值 | 意義 |
---|---|
OPLOCK_FSCTRL_FLAG_ALL_KEYS_MATCH (0x00000001) | 檔系統已驗證目前開啟相符之任何句柄上的所有 oplock 機碼。 藉由指定此旗標,當檔案有多個開啟句柄存在時,允許 oplock 套件授與層級 RW 或 RWH 的 oplock。 如需 oplock 類型的詳細資訊,請參閱 Oplock 概觀。 |
傳回值
FltOplockFsctrlEx 會針對某些 FSCTL 作業傳回FLT_PREOP_PENDING。 如需詳細資訊,請參閱下列一節中所列 FSCTL 代碼的參考頁面。 否則, FltOplockFsctrlEx 會傳回FLT_PREOP_COMPLETE。
備註
迷你篩選驅動程式會呼叫 FltOplockFsctrlEx 來執行建立作業或文件系統控制 I/O 作業的各種商機鎖定作業。
CallbackData 參數所指向的FLT_CALLBACK_DATA結構必須代表以 IRP 為基礎的IRP_MJ_FILE_SYSTEM_CONTROL或IRP_MJ_CREATE作業。
如果作業是IRP_MJ_FILE_SYSTEM_CONTROL作業, FltOplockFsctrlEx 可以搭配下列 FSCTL 程式代碼使用:
- FSCTL_OPBATCH_ACK_CLOSE_PENDING
- FSCTL_OPLOCK_BREAK_ACK_NO_2
- FSCTL_OPLOCK_BREAK_ACKNOWLEDGE
- FSCTL_OPLOCK_BREAK_NOTIFY
- FSCTL_REQUEST_BATCH_OPLOCK
- FSCTL_REQUEST_FILTER_OPLOCK
- FSCTL_REQUEST_OPLOCK_LEVEL_1
- FSCTL_REQUEST_OPLOCK_LEVEL_2
- FSCTL_REQUEST_OPLOCK
FSCTL 程式代碼是在作業FLT_PARAMETERS結構的 FsControlCode 成員中設定。 如需 FsControlCode 和其他IRP_MJ_FILE_SYSTEM_CONTROL參數的詳細資訊,請參閱 FLT_PARAMETERS for IRP_MJ_FILE_SYSTEM_CONTROL。
如需有關商機鎖定的詳細資訊,請參閱 Microsoft Windows SDK 檔。
如果作業是 IRP_MJ_CREATE 要求,如果下列所有條件都成立, 則可以使用 FltOplockFsctrl 來要求擱置篩選機率鎖定:
- OpenCount 參數的值必須是 1。
- IRP_MJ_CREATE要求的 DesiredAccess 參數值是FILE_READ_ATTRIBUTES。 此參數是在作業FLT_PARAMETERS結構的 SecurityContext 成員中設定。 如需詳細資訊,請參閱 FLT_PARAMETERS for IRP_MJ_CREATE。
- IRP_MJ_CREATE作業的 ShareAccess 參數值是FILE_SHARE_READ、FILE_SHARE_WRITE或FILE_SHARE_DELETE。 此參數是在作業FLT_PARAMETERS結構的 ShareAccess 成員中設定。 如需詳細資訊,請參閱 FLT_PARAMETERS for IRP_MJ_CREATE。
呼叫此函式的篩選和文件系統必須將呼叫同步處理至系統提供的 oplock 套件。 如需詳細資訊 ,請參閱 Oplock 同步 處理。
規格需求
需求 | 值 |
---|---|
最低支援的用戶端 | 從 Windows 8 開始,即可使用此例程。 |
目標平台 | Universal |
標頭 | fltkernel.h (包含 Fltkernel.h) |
程式庫 | FltMgr.lib |
Dll | Fltmgr.sys |
IRQL | <= APC_LEVEL |
另請參閱
IRP_MJ_FILE_SYSTEM_CONTROL的FLT_PARAMETERS
FSCTL_OPBATCH_ACK_CLOSE_PENDING