次の方法で共有


FltOplockBreakH 関数 (fltkernel.h)

FltOplockBreakH ルーチンは、日和見ロック (oplocks) CACHE_HANDLE_LEVEL中断します。

構文

FLT_PREOP_CALLBACK_STATUS FLTAPI FltOplockBreakH(
  [in]           POPLOCK                                 Oplock,
  [in]           PFLT_CALLBACK_DATA                      CallbackData,
  [in]           ULONG                                   Flags,
  [in, optional] PVOID                                   Context,
  [in, optional] PFLTOPLOCK_WAIT_COMPLETE_ROUTINE        WaitCompletionRoutine,
  [in, optional] PFLTOPLOCK_PREPOST_CALLBACKDATA_ROUTINE PrePostCallbackDataRoutine
);

パラメーター

[in] Oplock

ファイルの不透明な oplock ポインター。 このポインターは、FltInitializeOplock する前の呼び出しによって初期化されている必要があります。

[in] CallbackData

I/O 操作のコールバック データ (FLT_CALLBACK_DATA) 構造体へのポインター。

[in] Flags

関連付けられているファイル I/O 操作のビットマスク。 ミニフィルター ドライバーは、fltOplockBreakH の動作指定するビットを設定します。 Flags パラメーターには、次のオプションがあります。

OPLOCK_FLAG_COMPLETE_IF_OPLOCKED (0x00000001)

oplock 中断の原因となった操作をブロックまたは保留せずに、oplock の中断を続行できるようにします。

OPLOCK_FLAG_IGNORE_OPLOCK_KEYS (0x00000008)

oplock キー CACHE_HANDLE_LEVEL関係なく、oplock の中断を続行できるようにします。

[in, optional] Context

WaitCompletionRoutine および prePostCallbackDataRoutine パラメーターが指すコールバック ルーチン に渡される呼び出し元定義コンテキスト情報へのポインター。

[in, optional] WaitCompletionRoutine

呼び出し元が指定したコールバック ルーチンへのポインター。 oplock の中断が進行中の場合、このルーチンは、中断が完了したときに呼び出されます。 このパラメーターは省略可能であり、NULL できます。 NULL 場合、呼び出し元は oplock の中断が完了するまで待機状態になります。

このルーチンは、次のように宣言されます。

typedef VOID
(*PFLTOPLOCK_WAIT_COMPLETE_ROUTINE) (
    __in PFLT_CALLBACK_DATA CallbackData,
 __in_opt PVOID Context
    );

このルーチンには、次のパラメーターがあります。

CallbackData

I/O 操作のコールバック データ構造へのポインター。

文脈

FltOplockBreakH するために、Context パラメーターで渡されたコンテキスト情報ポインター。

[in, optional] PrePostCallbackDataRoutine

I/O 操作をペンドする必要がある場合に呼び出される呼び出し元が指定したコールバック ルーチンへのポインター。 ルーチンは、oplock パッケージが IRP をペンする前に呼び出されます。 このパラメーターは省略可能であり、NULL できます。

このルーチンは、次のように宣言されます。

typedef VOID
(*PFLTOPLOCK_PREPOST_CALLBACKDATA_ROUTINE) (
    __in PFLT_CALLBACK_DATA CallbackData,
 __in_opt PVOID Context
      );

このルーチンには、次のパラメーターがあります。

CallbackData

I/O 操作のコールバック データ構造へのポインター。

文脈

FltOplockBreakH するために、Context パラメーターで渡されたコンテキスト情報ポインター。

戻り値

FltOplockBreakH は、次のFLT_PREOP_CALLBACK_STATUS コードのいずれかを返します。

リターン コード 形容
FLT_PREOP_COMPLETE
FltOplockBreakH プールの割り当てエラーが発生した、または FsRtlOplockBreakH 関数の呼び出しでエラーが返されました。 FltOplockBreakH は、IO_STATUS_BLOCK 構造体の Status メンバーにエラー コードを設定します。 IO_STATUS_BLOCK構造体は、FLT_CALLBACK_DATA コールバック データ構造の IoStatus メンバーで指定されます。 CallbackData パラメーターは、このFLT_CALLBACK_DATAを指します。
FLT_PREOP_PENDING
oplock の中断が開始され、フィルター マネージャーが I/O 操作を作業キューにポストしました。 I/O 操作は、CallbackData パラメーターが指すコールバック データによって表されます。
FLT_PREOP_SUCCESS_WITH_CALLBACK
CallbackData パラメーターが指すコールバック データはペンドされず、I/O 操作が直ちに実行されました。 呼び出し元が Flags パラメーターにOPLOCK_FLAG_COMPLETE_IF_OPLOCKEDを指定した場合、I/O 操作が実行されなかった場合でも、実際には oplock の中断が進行中である可能性があることに注意してください。 これが状況であるかどうかを判断するには、呼び出し元は、IO_STATUS_BLOCK 構造体の Status メンバーのSTATUS_OPLOCK_BREAK_IN_PROGRESSを確認する必要があります。 IO_STATUS_BLOCK構造体は、FLT_CALLBACK_DATA コールバック データ構造の IoStatus メンバーで指定されます。

備考

日和見ロックの詳細については、Microsoft Windows SDK のドキュメントを参照してください。

必要条件

要件 価値
サポートされる最小クライアント FltOplockBreakH ルーチンは、Windows 7 以降で使用できます。
ターゲット プラットフォーム 万国
ヘッダー fltkernel.h (Fltkernel.h を含む)
ライブラリ FltMgr.lib
DLL Fltmgr.sys
IRQL <= APC_LEVEL

関連項目

FLT_CALLBACK_DATA

FltInitializeOplock

FsRtlOplockBreakH

IO_STATUS_BLOCK