fltSetStreamContext 函数 (fltkernel.h)

FltSetStreamContext 例程为文件流设置上下文。

语法

NTSTATUS FLTAPI FltSetStreamContext(
  [in]  PFLT_INSTANCE             Instance,
  [in]  PFILE_OBJECT              FileObject,
  [in]  FLT_SET_CONTEXT_OPERATION Operation,
  [in]  PFLT_CONTEXT              NewContext,
  [out] PFLT_CONTEXT              *OldContext
);

参数

[in] Instance

微筛选器驱动程序实例的不透明实例指针,该实例的上下文将插入、从中删除或替换附加到文件流的上下文列表中。

[in] FileObject

指向 文件流的文件对象的 指针。

[in] Operation

指定要执行的操作的详细信息的标志。 此参数必须是下列参数之一:

标志 含义
FLT_SET_CONTEXT_REPLACE_IF_EXISTS 如果已为 Instance 设置了上下文, 则 FltSetStreamContext 会将它替换为 NewContext 中指定的上下文。 否则,它会将 NewContext 插入到文件流的上下文列表中。
FLT_SET_CONTEXT_KEEP_IF_EXISTS 如果已为此 实例设置了上下文, 则 FltSetStreamContext 将返回STATUS_FLT_CONTEXT_ALREADY_DEFINED,并且不会替换现有上下文或递增引用计数。 如果尚未设置上下文,则例程会将 NewContext 插入到文件流的上下文列表中,并递增引用计数。

[in] NewContext

指向要为文件流设置的新上下文的指针。 此参数是必需的,不能为 NULL

[out] OldContext

指向调用方分配的变量的指针,该变量接收 实例 参数的现有流上下文的地址(如果已设置)。 此参数是可选的,可以为 NULL。 有关此参数的详细信息,请参阅以下“备注”部分。

返回值

FltSetStreamContext 例程返回STATUS_SUCCESS或适当的 NTSTATUS 值,例如以下值之一:

返回代码 说明
STATUS_FLT_CONTEXT_ALREADY_DEFINED 如果为 操作指定了FLT_SET_CONTEXT_KEEP_IF_EXISTS,则此错误代码指示流上下文已附加到文件流。
STATUS_FLT_CONTEXT_ALREADY_LINKED NewContext 参数指向的上下文已链接到 对象。 换句话说,此错误代码指示由于之前成功调用 FltSetXxxContext 例程,NewContext 已在使用中。
STATUS_FLT_DELETING_OBJECT Instance 参数中指定的 实例 正在被拆毁。 这是错误代码。
STATUS_INVALID_PARAMETER 传递的参数无效。 例如, NewContext 参数不指向有效的流上下文,或者为 Operation 参数指定了无效值。 这是错误代码。
STATUS_NOT_SUPPORTED 文件系统不支持此文件流的每个流上下文。 这是错误代码。

注解

有关上下文的详细信息,请参阅 关于微筛选器上下文

微筛选器驱动程序调用 FltSetStreamContext 以将流上下文附加到文件流,或者删除或替换现有流上下文。 微筛选器驱动程序可以将每个微筛选器驱动程序实例的一个上下文附加到文件流。

无法在未打开的 FileObject 上调用 FltSetStreamContext。 因此,无法从流的预创建回调调用它,因为该流尚未在此时打开。 但是,微筛选器驱动程序可以在预创建回调中分配和设置流上下文,使用完成上下文参数将其传递到创建后回调,并在创建后回调的流上设置流上下文。

引用计数

如果 FltSetStreamContext 成功:

  • NewContext 上的引用计数递增。 不再需要 NewContext 时,微筛选器必须调用 FltReleaseContext 以递减其引用计数。

否则,如果 FltSetStreamContext 失败:

  • NewContext 上的引用计数保持不变。
  • 如果 OldContext 不是 NULL 且不指向 NULL_CONTEXT则 OldContext 是指向当前与流关联的上下文的引用指针。 当不再需要上下文指针时,调用 FltSetStreamContext 的筛选器也必须为 OldContext 调用 FltReleaseContext

无论成功与否:

有关详细信息,请参阅 引用上下文

其他上下文操作

有关详细信息,请参阅 设置上下文发布上下文

要求

要求
最低受支持的客户端 适用于 SP4、Windows XP SP2、Windows Server 2003 SP1 和更高版本的操作系统的 Microsoft Windows 2000 更新汇总 1 中可用和支持。
目标平台 通用
标头 fltkernel.h (包括 Fltkernel.h)
Library FltMgr.lib
DLL Fltmgr.sys
IRQL <= APC_LEVEL

另请参阅

FltAllocateContext

FltDeleteContext

FltDeleteStreamContext

FltGetStreamContext

FltReleaseContext