FsRtlCheckOplock 函式 (ntifs.h)
FsRtlCheckOplock 例程會將檔案 I/O 作業的 IRP 與檔案目前的機會鎖定 (oplock) 狀態同步處理。
語法
NTSTATUS FsRtlCheckOplock(
[in] POPLOCK Oplock,
[in] PIRP Irp,
[in, optional] PVOID Context,
[in, optional] POPLOCK_WAIT_COMPLETE_ROUTINE CompletionRoutine,
[in, optional] POPLOCK_FS_PREPOST_IRP PostIrpRoutine
);
參數
[in] Oplock
檔案不透明的不透明鎖定指標。 此指標必須由先前呼叫 FsRtlInitializeOplock初始化。
[in] Irp
I/O 作業之 IRP 的指標。
[in, optional] Context
要傳遞至回呼例程的呼叫端定義內容資訊的指標,CompletionRoutine 和 PostIrpRoutine 參數所指向的回呼例程。
[in, optional] CompletionRoutine
呼叫端提供的回呼例程指標。 如果機會鎖定中斷正在進行中,當中斷完成時,就會呼叫此例程。 這個參數是選擇性的,而且可以是 NULL。 如果是 NULL,呼叫端會進入等候狀態,直到機會鎖定中斷完成為止。
此例程宣告如下:
typedef VOID
(*POPLOCK_WAIT_COMPLETE_ROUTINE) (
IN PVOID Context,
IN PIRP Irp
);
此例程具有下列參數:
參數 | 描述 |
---|---|
上下文 | 傳遞至 Context 參數的內容資訊指標,FsRtlCheckOplock。 |
Irp | I/O 作業之 IRP 的指標。 |
[in, optional] PostIrpRoutine
如果 I/O 作業張貼至工作佇列,則會呼叫呼叫端提供的回呼例程指標。 這個參數是選擇性的,而且可以是 NULL。
此例程宣告如下:
typedef VOID
(*POPLOCK_FS_PREPOST_IRP) (
IN PVOID Context,
IN PIRP Irp
);
此例程具有下列參數:
參數 | 描述 |
---|---|
上下文 | 傳遞至 Context 參數的內容資訊指標,FsRtlCheckOplock。 |
Irp | I/O 作業之 IRP 的指標。 |
傳回值
FsRtlCheckOplock 例程會傳回STATUS_SUCCESS或適當的 NTSTATUS 程式代碼,例如下列其中一項:
傳回碼 | 描述 |
---|---|
STATUS_CANCELLED | IRP 已取消。 STATUS_CANCELLED是錯誤碼。 |
STATUS_CANNOT_BREAK_OPLOCK | 如果 IRP 是IRP_MJ_CREATE,且FILE_OPEN_REQUIRING_OPLOCK位於 IRP 的 CreateOptions 中,則例程不會起始現有機會鎖定的中斷,但會失敗並出現STATUS_CANNOT_BREAK_OPLOCK。 |
STATUS_OPLOCK_BREAK_IN_PROGRESS | 機會主義鎖定中斷正在進行中。 IRP 是一個IRP_MJ_CREATE要求,而且已在作業的 create options 參數中指定FILE_COMPLETE_IF_OPLOCKED。 STATUS_OPLOCK_BREAK_IN_PROGRESS是成功的程序代碼。 |
STATUS_PENDING | 已起始機會鎖定中斷,且 IRP 的控制已傳遞至 oplock 套件。 如果 CompletionRoutine 為 NULL,此例程會在處理 oplock 中斷時封鎖,而不是傳回STATUS_PENDING。 STATUS_PENDING是成功的程序代碼。 |
言論
FsRtlCheckOplock 會根據下列條件,同步處理 I/O 作業的 IRP 與檔案目前的機會鎖定狀態:
如果 I/O 作業會導致機會鎖定中斷,則會起始機會鎖定中斷。
如果 I/O 作業在機會鎖定中斷完成之前無法繼續,FsRtlCheckOplock 會傳回STATUS_PENDING,並呼叫 PostIrpRoutine 參數指向的回呼例程。
如果文件系統或篩選驅動程式使用機會鎖定,則必須從任何可能導致機會鎖定中斷的分派例程 呼叫 FsRtlCheckOplock FsRtlCheckOplock。 此規則適用於下列類型的 I/O 作業,因為這些作業可能會導致機會鎖定中斷:
- IRP_MJ_CLEANUP
- IRP_MJ_CREATE
- IRP_MJ_FILE_SYSTEM_CONTROL
- IRP_MJ_FLUSH_BUFFERS
- IRP_MJ_LOCK_CONTROL
- IRP_MJ_READ
- IRP_MJ_SET_INFORMATION
- IRP_MJ_WRITE
如需機會鎖定的詳細資訊,請參閱 Windows SDK 檔。
迷你篩選程序應該呼叫 FltCheckOplock,而不是 FsRtlCheckOplock。
要求
要求 | 價值 |
---|---|
最低支援的用戶端 | Windows 2000 |
目標平臺 | 普遍 |
標頭 | ntifs.h (include FltKernel.h, Ntifs.h) |
連結庫 | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | <= APC_LEVEL |
另請參閱
FSCTL_OPBATCH_ACK_CLOSE_PENDING