FWPS_CALLOUT_NOTIFY_FN3回调函数 (fwpsu.h)

当标注筛选器匹配时,在分类期间调用的函数的版本 3。 不同之处在于此回调返回 FWPS_FILTER3 结构。

语法

FWPS_CALLOUT_NOTIFY_FN3 FwpsCalloutNotifyFn3;

NTSTATUS FwpsCalloutNotifyFn3(
  FWPS_CALLOUT_NOTIFY_TYPE notifyType,
  const GUID *filterKey,
  FWPS_FILTER3 *filter
)
{...}

参数

notifyType

一个 值,该值指示筛选器引擎正在向标注发送的通知类型。 此参数的有效值是:

FWPS_CALLOUT_NOTIFY_ADD_FILTER。 正在向筛选器引擎添加筛选器,该筛选器引擎指定筛选器操作的标注。

FWPS_CALLOUT_NOTIFY_DELETE_FILTER。 正在从筛选器引擎中删除筛选器,该筛选器引擎指定筛选器操作的标注。

FWPS_CALLOUT_NOTIFY_TYPE_MAX。 用于测试的最大值。

filterKey

指向筛选器的管理标识符的指针,由添加或删除筛选器的应用程序或驱动程序指定。 如果 notifyType 参数设置为 FWPS_CALLOUT_NOTIFY_DELETE_FILTER,则必须为 NULL。 有关详细信息,请参阅“备注”。

filter

指向 FWPS_FILTER3 结构的指针。 此结构描述要添加到筛选器引擎或从筛选器引擎中删除的筛选器。

将筛选器添加到筛选器引擎时,标注的 notifyFn3 标注函数可以将此结构的 上下文 成员设置为指向标注驱动程序提供的上下文结构。 此上下文结构对筛选器引擎不透明,标注驱动程序的 分类Fn3 标注函数可用于保留筛选器引擎对标注驱动程序分类 Fn3 标注函数的调用之间的任何特定于驱动程序的数据或状态信息。

从筛选器引擎中删除筛选器时,标注的 notifyFn3 标注函数可以清理与筛选器关联的任何上下文。

返回值

标注的 notifyFn3 函数返回以下 NTSTATUS 代码之一。

返回代码 说明
STATUS_SUCCESS 标注驱动程序接受来自筛选器引擎的通知。
其他状态代码 出现了错误。 如果 notifyType 参数 FWPS_CALLOUT_NOTIFY_ADD_FILTER,则不会将筛选器添加到筛选器引擎。 如果 notifyType 参数 FWPS_CALLOUT_NOTIFY_DELETE_FILTER,则筛选器仍会从筛选器引擎中删除。

注解

标注驱动程序通过调用 FwpsCalloutRegister2 函数向筛选器引擎注册标注的标注函数。

筛选器引擎调用标注的 notifyFn3 标注函数,以通知标注驱动程序与标注关联的事件。 如果标注驱动程序的 notifyFn3 标注函数无法识别 notifyType 参数中传递的通知类型,它将忽略通知并返回 STATUS_SUCCESS

如果在为筛选器操作指定标注的筛选器已添加到筛选器引擎后,标注驱动程序向筛选器引擎注册标注,则筛选器引擎不会调用标注驱动程序的 notifyFn3 标注函数来通知任何现有筛选器的标注。 筛选器引擎调用标注驱动程序的 notifyFn3 标注函数,以便在为筛选器操作指定标注的新筛选器添加到筛选器引擎时通知标注。 在这种情况下,对于筛选器引擎中指定筛选器操作的标注的每个筛选器,标注的 notifyFn3 标注函数可能不会被调用。 如果标注驱动程序在启动筛选器引擎后注册标注,并且标注需要知道筛选器引擎中指定筛选器操作标注的每个筛选器,则标注驱动程序必须调用相应的管理功能来枚举筛选器引擎中的所有筛选器,并按生成的筛选器列表进行排序,以查找为筛选器操作指定标注的筛选器。 有关调用这些函数的详细信息,请参阅调用 其他 Windows 筛选平台 函数。

当从筛选器引擎中删除为筛选器操作指定标注的筛选器时,筛选器引擎将调用标注驱动程序的 notifyFn3 标注函数,并在 notifyType 参数中传递FWP_CALLOUT_NOTIFY_DELETE_FILTER,在 filterKey 参数中传递 NULL 。 有关详细信息,请参阅 处理通知标注

要求

要求
Header fwpsu.h