次の方法で共有


FltGetStreamContext 関数 (fltkernel.h)

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

構文

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

パラメーター

[in] Instance

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

[in] FileObject

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

[out] Context

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

戻り値

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

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

備考

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

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

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

ファイル ストリームのコンテキストを設定するには、FltSetStreamContext呼び出します。

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

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

必要条件

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

関連項目

FltAllocateContext

FltDeleteContext

FltDeleteStreamContext

FltReleaseContext

FltSetStreamContext