次の方法で共有


FltGetStreamHandleContext 関数 (fltkernel.h)

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

構文

NTSTATUS FLTAPI FltGetStreamHandleContext(
  [in]  PFLT_INSTANCE Instance,
  [in]  PFILE_OBJECT  FileObject,
  [out] PFLT_CONTEXT  *Context
);

パラメーター

[in] Instance

コンテキストを取得するミニフィルター ドライバー インスタンスの不透明なインスタンス ポインター。

[in] FileObject

ストリーム ハンドルのファイル オブジェクトへのポインター。

[out] Context

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

戻り値

FltGetStreamHandleContext は、要求されたコンテキストを正常に返したときにSTATUS_SUCCESSを返します。 それ以外の場合は、次のいずれかの適切な NTSTATUS 値を返します。

リターン コード 形容
STATUS_NOT_FOUND 現時点では、このファイルに一致するコンテキストが見つからなかったため、FltMgr コンテキスト NULL_CONTEXTに設定。 これはエラー コードです。
STATUS_NOT_SUPPORTED ファイル システムは、このファイル ストリームのストリームごとのコンテキストをサポートしていません。 これはエラー コードです。

備考

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

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

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

ストリーム ハンドルのコンテキストを設定するには、FltSetStreamHandleContext 呼び出

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

ストリーム ハンドル コンテキストを削除するには、FltDeleteStreamHandleContext呼び出すか、FltDeleteContextを呼び出します。

必要条件

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

関連項目

FltAllocateContext

FltDeleteContext

FltDeleteStreamHandleContext

FltReleaseContext

FltSetStreamHandleContext