FltGetSectionContext 函数 (fltkernel.h)

FltGetSectionContext 例程检索为指定的微型筛选器驱动程序实例为文件流创建的节上下文。

语法

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

参数

[in] Instance

要检索其上下文的微型筛选器驱动程序实例的不透明实例指针。

[in] FileObject

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

[out] Context

指向接收上下文地址的调用方分配变量的指针。 此参数是必需的,不能设置为 NULL。

返回值

FltGetSectionContext 成功返回请求的节上下文时返回STATUS_SUCCESS。 否则,它将返回适当的 NTSTATUS 值,例如以下值之一:

返回代码 描述
STATUS_NOT_FOUND 此时在此文件中找不到匹配的上下文,因此 FltMgr上下文 设置为NULL_CONTEXT。 这是一个错误代码。
STATUS_NOT_SUPPORTED 附加到此实例的卷不支持节上下文。 这是一个错误代码。

言论

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

FltGetSectionContext 检索由指定的微型筛选器驱动程序实例为文件流创建的节上下文。 通过调用 FltCreateSectionForDataScan创建节上下文。

FltGetSectionContext 递增 上下文 参数指向的上下文的引用计数。 当不再需要此上下文指针时,调用方必须通过调用 FltReleaseContext来递减其引用计数。 因此,对 FltGetSectionContext 的每个成功调用都必须匹配对 FltReleaseContext的后续调用。

若要分配新上下文,请调用 FltAllocateContext

微型筛选器不得显式删除传递给 FltCreateSectionForDataScan的节上下文。 在本例中,通过调用 FltCloseSectionForDataScan 从流中解除分配和删除节上下文。

要求

要求 价值
最低支持的客户端 Windows 8
目标平台 普遍
标头 fltkernel.h (包括 Fltkernel.h)
FltMgr.lib
DLL Fltmgr.sys
IRQL <= APC_LEVEL

另请参阅

FltAllocateContext

FltCloseSectionForDataScan

FltCreateSectionForDataScan

FltReleaseContext