다음을 통해 공유


FWPS_CALLOUT_NOTIFY_FN3 콜백 함수(fwpsk.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 설명선 함수는 필터 엔진에 필터를 추가할 때 이 구조체의 컨텍스트 멤버가 설명선 드라이버 제공 컨텍스트 구조를 가리키도록 설정할 수 있습니다. 이 컨텍스트 구조는 필터 엔진에 불투명하며 설명선 드라이버의 classifyFn3 설명선 함수에서 호출된 드라이버별 데이터 또는 설명선 드라이버의 classifyFn3 설명선 함수에 대한 호출 간의 상태 정보를 보존하는 데 사용할 수 있습니다.

설명선의 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 . 자세한 내용은 알림 설명선처리를 참조하세요.

요구 사항

요구
지원되는 최소 클라이언트 Windows Vista부터 사용할 수 있습니다.
헤더 fwpsk.h
IRQL <= DISPATCH_LEVEL

참고 항목