FILTER_RETURN_NET_BUFFER_LISTS 콜백 함수(ndis.h)

NDIS는 FilterReturnNetBufferLists 함수를 호출하여 NET_BUFFER_LIST 구조 및 관련 데이터의 연결된 목록을 필터 드라이버에 반환합니다.

참고FILTER_RETURN_NET_BUFFER_LISTS 형식을 사용하여 함수를 선언해야 합니다. 자세한 내용은 다음 예제 섹션을 참조하세요.
 

구문

FILTER_RETURN_NET_BUFFER_LISTS FilterReturnNetBufferLists;

void FilterReturnNetBufferLists(
  [in] NDIS_HANDLE FilterModuleContext,
  [in] PNET_BUFFER_LIST NetBufferLists,
  [in] ULONG ReturnFlags
)
{...}

매개 변수

[in] FilterModuleContext

필터 모듈의 컨텍스트 영역에 대한 핸들입니다. FilterAttach 함수에서 이 컨텍스트 영역을 만들고 초기화한 필터 드라이버입니다.

[in] NetBufferLists

필터 드라이버가 를 호출하여 표시한 NET_BUFFER_LIST 구조체의 연결된 목록 NdisFIndicateReceiveNetBufferLists 함수입니다. 목록에는 NdisFIndicateReceiveNetBufferLists에 대한 여러 호출의 NET_BUFFER_LIST 구조가 포함될 수 있습니다.

[in] ReturnFlags

OR 작업과 결합할 수 있는 NDIS 플래그입니다. 모든 플래그를 지우려면 이 멤버를 0으로 설정합니다. 이 함수는 다음 플래그를 지원합니다.

NDIS_RETURN_FLAGS_DISPATCH_LEVEL

현재 IRQL이 DISPATCH_LEVEL 지정합니다. 이 플래그에 대한 자세한 내용은 디스패치 IRQL 추적을 참조하세요.

NDIS_RETURN_FLAGS_SWITCH_SINGLE_SOURCE

이 플래그를 설정하면 NET_BUFFER_LIST 구조체의 연결된 목록에 있는 모든 패킷이 동일한 Hyper-V 확장 가능한 스위치 원본 포트에서 시작됩니다.

자세한 내용은 Hyper-V 확장 가능 스위치 보내기 및 받기 플래그를 참조하세요.

참고연결된 NET_BUFFER_LIST 구조 목록의 각 패킷이 동일한 원본 포트를 사용하는 경우 확장은 요청을 보낼 때 FilterReceiveNetBufferListsReceiveFlags 매개 변수에서 NDIS_RECEIVE_FLAGS_SWITCH_SINGLE_SOURCE 플래그를 설정해야 합니다.
 

반환 값

없음

설명

FilterReturnNetBufferLists 는 선택적 함수입니다. 필터 드라이버가 수신 표시를 필터링하지 않으면 를 호출할 때 이 함수의 진입점을 NULL 로 설정할 수 있습니다. NdisFRegisterFilterDriver 함수입니다.

필터 드라이버는 FilterSetModuleOptions 함수에서 NdisSetOptionalHandlers 함수를 호출하여 필터 모듈에 FilterReturnNetBufferLists 함수를 지정할 수 있습니다.

참고FilterReturnNetBufferLists 함수를 제공하지 않는 필터 드라이버는 다음을 호출할 수 없습니다. NdisFIndicateReceiveNetBufferLists 함수는 수신 표시를 시작합니다.
 
참고FilterReturnNetBufferLists 함수를 제공하는 필터 드라이버는 FilterStatus 함수를 제공해야 합니다.
 
NDIS가 FilterReturnNetBufferLists를 호출하면 필터 드라이버가 NET_BUFFER_LIST 구조체 및 관련 데이터의 소유권을 되찾습니다.

기본 드라이버가 수신 표시를 시작한 경우 필터 드라이버는 다음을 호출해야 합니다. NdisFReturnNetBufferLists 함수는 수신 표시를 완료합니다.

필터 드라이버가 수신 표시를 시작한 경우 FilterReturnNetBufferLists 는 NET_BUFFER_LIST 구조체 및 관련 데이터를 해제하거나 NdisFIndicateReceiveNetBufferLists에 대한 후속 호출에서 다시 사용할 수 있도록 준비할 수 있습니다.

필터 드라이버는 시작되는 수신 표시를 추적하고 NDIS에서 FilterReturnNetBufferLists를 호출할 때 NdisFReturnNetBufferLists 를 호출하지 않는지 확인해야 합니다.

NDIS는 IRQL <= DISPATCH_LEVEL FilterReturnNetBufferLists를 호출합니다.

FilterReturnNetBufferLists 함수를 정의하려면 먼저 정의 중인 함수의 형식을 식별하는 함수 선언을 제공해야 합니다. Windows는 드라이버에 대한 함수 형식 집합을 제공합니다. 함수 형식을 사용하여 함수를 선언하면 드라이버에 대한 코드 분석, SDV( 정적 드라이버 검증 도구 ) 및 기타 확인 도구에서 오류를 찾을 수 있으며 Windows 운영 체제용 드라이버를 작성하기 위한 요구 사항입니다.

예를 들어 이름이 " MyReturnNetBufferLists"인 FilterReturnNetBufferLists 함수를 정의하려면 다음 코드 예제와 같이 FILTER_RETURN_NET_BUFFER_LISTS 형식을 사용합니다.

FILTER_RETURN_NET_BUFFER_LISTS MyReturnNetBufferLists;

그런 다음 다음과 같이 함수를 구현합니다.

_Use_decl_annotations_
VOID
 MyReturnNetBufferLists(
    NDIS_HANDLE  FilterModuleContext,
    PNET_BUFFER_LIST  NetBufferLists,
    ULONG  ReturnFlags
    )
  {...}

FILTER_RETURN_NET_BUFFER_LISTS 함수 형식은 Ndis.h 헤더 파일에 정의되어 있습니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 Use_decl_annotations 주석을 추가해야 합니다. Use_decl_annotations 주석은 헤더 파일의 FILTER_RETURN_NET_BUFFER_LISTS 함수 형식에 적용되는 주석이 사용되도록 합니다. 함수 선언 요구 사항에 대한 자세한 내용은 NDIS 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요.

Use_decl_annotations 대한 자세한 내용은 함수 동작 주석 지정을 참조하세요.

요구 사항

요구 사항
지원되는 최소 클라이언트 NDIS 6.0 이상에서 지원됩니다.
대상 플랫폼 Windows
헤더 ndis.h(Ndis.h 포함)
IRQL <= DISPATCH_LEVEL

추가 정보

FilterAttach

FilterSetModuleOptions

FilterStatus

NET_BUFFER

NET_BUFFER_LIST

NdisFIndicateReceiveNetBufferLists

NdisFRegisterFilterDriver

NdisFReturnNetBufferLists

NdisSetOptionalHandlers