次の方法で共有


FltGetInstanceContext 関数 (fltkernel.h)

fltGetInstanceContext ルーチン は、特定のミニフィルター ドライバーによってインスタンスに設定されたコンテキストを取得します。

構文

NTSTATUS FLTAPI FltGetInstanceContext(
  [in]  PFLT_INSTANCE Instance,
  [out] PFLT_CONTEXT  *Context
);

パラメーター

[in] Instance

インスタンスの不透明なインスタンス ポインター。

[out] Context

インスタンス コンテキストのアドレスを受け取る呼び出し元によって割り当てられた変数へのポインター。 このパラメーターは必須であり、NULL に設定することはできません。

戻り値

FltGetInstanceContext 、要求されたインスタンス コンテキストが正常に返されたときにSTATUS_SUCCESSを返します。 それ以外の場合は、次のような適切な NTSTATUS 値が返されます。

リターン コード 形容
STATUS_NOT_FOUND 現時点では、このインスタンスで一致するコンテキストが見つかりませんでした。 FltMgr 、コンテキスト NULL_CONTEXTに設定されます。 これはエラー コードです。

備考

コンテキストの詳細については、「ミニフィルター コンテキストについて」を参照してください。

FltGetInstanceContext は、特定のミニフィルター ドライバーによってインスタンスに設定されたコンテキストを取得します。

FltGetInstanceContext Context パラメーターが指すコンテキストの参照カウントをインクリメントします。 このコンテキスト ポインターが不要になった場合、呼び出し元は FltReleaseContext呼び出すことによって、その参照カウントをデクリメントする必要があります。 したがって、FltGetInstanceContext 正常に呼び出すたびに、FltReleaseContext への後続の呼び出し照合する必要があります。

インスタンスのコンテキストを設定するには、FltSetInstanceContext呼び出します。

新しいコンテキストを割り当てるには、FltAllocateContext呼び出します。

ファイル コンテキストを削除するには、FltDeleteInstanceContext呼び出すか、FltDeleteContextします。

必要条件

要件 価値
ターゲット プラットフォーム 万国
ヘッダー fltkernel.h (Fltkernel.h を含む)
ライブラリ FltMgr.lib
DLL Fltmgr.sys
IRQL <= APC_LEVEL

関連項目

FltAllocateContext

FltDeleteContext

FltDeleteInstanceContext

FltReleaseContext

FltSetInstanceContext