次の方法で共有


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要求であり、操作の作成オプション パラメーターにFILE_COMPLETE_IF_OPLOCKEDが指定されています。 STATUS_OPLOCK_BREAK_IN_PROGRESSは成功コードです。
STATUS_PENDING 日和見ロックの中断が開始され、IRP の制御が oplock パッケージに渡されました。 CompletionRoutine が NULL の場合、このルーチンは、STATUS_PENDINGを返すのではなく、oplock ブレークの処理中にブロックされます。 STATUS_PENDINGは成功コードです。

備考

FsRtlCheckOplock は、I/O 操作の IRP を、次の条件に従ってファイルの現在の日和見ロック状態と同期します。

  • I/O 操作によって日和見ロックが中断される場合、日和見ロックの中断が開始されます。

  • 日和見ロックの中断が完了するまで I/O 操作を続行できない場合、FsRtlCheckOplock はSTATUS_PENDINGを返し、PostIrpRoutine パラメーターが指すコールバック ルーチンを呼び出します。

ファイル システムまたはフィルター ドライバーが日和見ロックを使用する場合は、I/O 操作のディスパッチ ルーチンから 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 のドキュメントを参照してください。

ミニフィルターでは、FsRtlCheckOplock ではなく、FltCheckOplock 呼び出す必要があります。

必要条件

要件 価値
サポートされる最小クライアント Windows 2000
ターゲット プラットフォーム の 万国
ヘッダー ntifs.h (FltKernel.h、Ntifs.h を含む)
ライブラリ NtosKrnl.lib
DLL NtosKrnl.exe
IRQL <= APC_LEVEL

関連項目

FSCTL_OPBATCH_ACK_CLOSE_PENDING

FSCTL_OPLOCK_BREAK_ACKNOWLEDGE

FSCTL_OPLOCK_BREAK_ACK_NO_2

FSCTL_OPLOCK_BREAK_NOTIFY

FSCTL_REQUEST_BATCH_OPLOCK

FSCTL_REQUEST_FILTER_OPLOCK

FSCTL_REQUEST_OPLOCK_LEVEL_1

FSCTL_REQUEST_OPLOCK_LEVEL_2

FltCheckOplock を する

FsRtlCurrentBatchOplock

FsRtlInitializeOplock

FsRtlOplockFsctrl

FsRtlOplockIsFastIoPossible

FsRtlUninitializeOplock