FILTER_RECEIVE_NET_BUFFER_LISTS 콜백 함수(ndis.h)

NDIS 는 FilterReceiveNetBufferLists 함수를 호출하여 수신 표시를 처리하는 필터 드라이버를 요청합니다.

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

구문

FILTER_RECEIVE_NET_BUFFER_LISTS FilterReceiveNetBufferLists;

void FilterReceiveNetBufferLists(
  [in] NDIS_HANDLE FilterModuleContext,
  [in] PNET_BUFFER_LIST NetBufferLists,
  [in] NDIS_PORT_NUMBER PortNumber,
  [in] ULONG NumberOfNetBufferLists,
  [in] ULONG ReceiveFlags
)
{...}

매개 변수

[in] FilterModuleContext

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

[in] NetBufferLists

기본 드라이버에서 할당한 NET_BUFFER_LIST 구조체의 연결된 목록입니다. 각 NET_BUFFER_LIST 구조체에는 하나의 NET_BUFFER 구조가 포함됩니다.

[in] PortNumber

미니포트 어댑터 포트를 식별하는 포트 번호입니다. 미니포트 어댑터 포트 번호는 NdisMAllocatePort 함수를 호출하여 할당됩니다. 0 값은 미니포트 어댑터의 기본 포트를 식별합니다.

[in] NumberOfNetBufferLists

NetBufferLists 의 연결된 구조 목록에 있는 NET_BUFFER_LIST 구조체의 수입니다.

[in] ReceiveFlags

수신 표시에 대한 특성을 정의하는 플래그입니다. 플래그를 OR 작업과 결합할 수 있습니다. 모든 플래그를 지우려면 이 멤버를 0으로 설정합니다. 이 함수는 다음 플래그를 지원합니다.

NDIS_RECEIVE_FLAGS_DISPATCH_LEVEL

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

NDIS_RECEIVE_FLAGS_RESOURCES

NDIS가 FilterReceiveNetBufferLists를 호출한 직후 NET_BUFFER_LIST 구조체 및 연결된 모든 NET_BUFFER 구조체의 소유권을 회수하도록 지정합니다.

NDIS_RECEIVE_FLAGS_SINGLE_ETHER_TYPE

NetBufferLists 목록의 모든 NET_BUFFER_LIST 구조체가 동일한 프로토콜 형식(EtherType)을 가지게 지정합니다.

NDIS_RECEIVE_FLAGS_SINGLE_VLAN

NetBufferLists 목록의 모든 NET_BUFFER_LIST 구조체가 동일한 VLAN에 속하도록 지정합니다.

NDIS_RECEIVE_FLAGS_PERFECT_FILTERED

NetBufferLists 목록의 모든 NET_BUFFER_LIST 구조에 미니포트 어댑터에 할당된 패킷 필터 및 멀티캐스트 주소 목록과 일치하는 데이터만 포함하도록 지정합니다.

NDIS_RECEIVE_FLAGS_SINGLE_QUEUE

NetBufferLists 목록의 모든 NET_BUFFER_LIST 구조체가 동일한 VM 큐에 속하도록 지정합니다. 미니포트 드라이버는 NDIS_RECEIVE_QUEUE_PARAMETERS_PER_QUEUE_RECEIVE_INDICATION 플래그가 의 Flags 멤버에 설정된 경우 큐의 모든 수신 표시에 대해 이 플래그를 설정해야 합니다. 해당 큐가 할당된 NDIS_RECEIVE_QUEUE_PARAMETERS 구조입니다.

NDIS_RECEIVE_FLAGS_SHARED_MEMORY_INFO_VALID

NetBufferLists 목록의 모든 NET_BUFFER_LIST 구조에 유효한 공유 메모리 정보가 포함되도록 지정합니다. 수신된 NET_BUFFER_LIST 이 플래그가 설정되면 NDIS는 공유 메모리 정보를 유효한 것으로 처리합니다. 이 플래그를 설정하지 않으면 NDIS 및 드라이버는 공유 메모리 정보를 무시합니다. 예를 들어 패킷 데이터를 수정하는 중간 드라이버는 이 플래그를 사용하여 데이터를 복사해야 하는지 여부를 결정할 수 있습니다. 미니포트 드라이버는 플래그를 사용하여 큐가 삭제될 때 VM 큐와 연결된 메모리를 해제하는 방법을 결정할 수 있습니다.

NDIS_RECEIVE_FLAGS_MORE_NBLS

예약되어 있습니다.

NDIS_RECEIVE_FLAGS_SWITCH_SINGLE_SOURCE

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

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

참고연결된 NET_BUFFER_LIST 구조 목록의 각 패킷이 동일한 원본 포트를 사용하는 경우 수신 요청이 완료될 때 확장은 FilterReturnNetBufferListsReturnFlags 매개 변수에 NDIS_RETURN_FLAGS_SWITCH_SINGLE_SOURCE 플래그를 설정해야 합니다. 확장은 NdisFReturnNetBufferLists를 호출하여 시작되거나 복제되지 않은 패킷을 반환하는 경우 ReturnFlags 매개 변수에서 이 플래그를 설정해야 합니다.
 

NDIS_RECEIVE_FLAGS_SWITCH_DESTINATION_GROUP

이 플래그를 설정하면 NET_BUFFER_LIST 구조체의 연결된 목록에 있는 모든 패킷을 동일한 확장 가능한 스위치 대상 포트로 전달해야 합니다.

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

참고연결된 NET_BUFFER_LIST 구조 목록의 각 패킷이 동일한 대상 포트를 사용하는 경우 수신 요청이 완료될 때 확장은 FilterReturnNetBufferListsReturnFlags 매개 변수에서 NDIS_RECEIVE_FLAGS_SWITCH_DESTINATION_GROUP 플래그를 설정해야 합니다. 확장은 NdisFReturnNetBufferLists를 호출하여 시작되거나 복제되지 않은 패킷을 반환하는 경우 ReturnFlags 매개 변수에서 이 플래그를 설정해야 합니다.
 

반환 값

없음

설명

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

참고FilterReceiveNetBufferLists 함수를 제공하는 필터 드라이버는 FilterStatus 함수를 제공해야 합니다.
 
필터 드라이버는 FilterSetModuleOptions 함수에서 NdisSetOptionalHandlers 함수를 호출하여 필터 모듈에 FilterReceiveNetBufferLists 함수를 지정할 수 있습니다.

NDIS 는 FilterReceiveNetBufferLists 를 호출하여 기본 드라이버에서 시작하는 표시를 처리합니다. NDIS는 루프백의 결과로 이 함수를 호출할 수도 있습니다.

필터 드라이버가 FilterReceiveNetBufferLists 함수를 지정하지 않은 경우 NDIS는 FilterReceiveNetBufferLists 함수를 지정한 스택의 다음 상위 필터 드라이버를 호출합니다. 이러한 필터 드라이버가 없으면 NDIS는 오버리싱 드라이버의 를 호출합니다. ProtocolReceiveNetBufferLists 함수입니다 .

ReceiveFlags 매개 변수의 NDIS_RECEIVE_FLAGS_RESOURCES 플래그가 설정되지 않은 경우 필터 드라이버는 를 호출할 때까지 NET_BUFFER_LIST 구조체의 소유권을 유지합니다. NdisFReturnNetBufferLists 함수입니다.

ReceiveFlags 매개 변수의 NDIS_RECEIVE_FLAGS_RESOURCES 플래그가 설정된 경우 필터 드라이버는 NET_BUFFER_LIST 구조 및 연결된 기본 드라이버 할당 리소스를 유지할 수 없습니다. 이 플래그는 기본 드라이버가 수신 리소스에서 부족함을 나타낼 수 있습니다. FilterReceiveNetBufferLists 함수는 가능한 한 빨리 반환되어야 합니다. 반환하기 전에 FilterReceiveNetBufferLists 함수는 수신된 데이터를 필터 드라이버 할당 스토리지에 복사하거나 를 호출하여 버퍼를 전달할 수 있습니다. NdisFIndicateReceiveNetBufferLists 함수입니다.

참고NDIS_RECEIVE_FLAGS_RESOURCES 플래그가 설정된 경우 필터 드라이버는 연결된 목록에 원래 NET_BUFFER_LIST 구조 집합을 유지해야 합니다. 예를 들어 이 플래그가 설정되면 드라이버는 구조를 처리하고 스택을 한 번에 하나씩 표시할 수 있지만 함수가 반환되기 전에 원래 연결된 목록을 복원해야 합니다.
 
필터 드라이버는 데이터를 오버리싱 드라이버로 표시하기 전에 수신된 데이터를 필터링할 수 있습니다. FilterReceiveNetBufferLists 함수에 제출되는 각 버퍼에 대해 필터 드라이버는 다음을 수행할 수 있습니다.
  • 를 호출하여 다음 오버리싱 드라이버에 버퍼를 전달합니다. NdisFIndicateReceiveNetBufferLists 함수입니다.

    드라이버는 NdisFIndicateReceiveNetBufferLists를 호출하기 전에 버퍼의 내용을 수정할 수 있습니다.

    드라이버는 NDIS가 FilterReceiveNetBufferLists에 전달한 NDIS_RECEIVE_FLAGS_RESOURCES 플래그 설정을 변경하거나 단순히 NdisFIndicateReceiveNetBufferLists에 전달할 수 있습니다.

  • 버퍼를 삭제합니다. NDIS가 NDIS_RECEIVE_FLAGS_RESOURCES 플래그를 지우면 NdisFReturnNetBufferLists 함수를 호출하여 버퍼를 삭제합니다. NDIS가 NDIS_RECEIVE_FLAGS_RESOURCES 플래그를 설정하는 경우 아무 작업도 수행하지 않고 FilterReceiveNetBufferLists 에서 반환하여 버퍼를 삭제합니다.
  • 나중에 처리하기 위해 로컬 데이터 구조에서 버퍼를 큐에 대기합니다. NDIS가 FilterReceiveNetBufferListsNDIS_RECEIVE_FLAGS_RESOURCES 플래그를 설정하는 경우 필터 드라이버는 FilterReceiveNetBufferLists에서 반환하기 전에 복사본을 만들어야 합니다.
  • 버퍼를 복사하고 복사본을 사용하여 수신 표시를 시작합니다. 수신 표시는 필터 드라이버 시작 수신 표시와 유사합니다. 이 경우 드라이버는 원래 버퍼를 기본 드라이버로 반환해야 합니다.
NdisFIndicateReceiveNetBufferLists라는 필터 드라이버가 NDIS_RECEIVE_FLAGS_RESOURCES 플래그를 설정하지 않은 경우 NDIS는필터 모듈에 대한 FilterReturnNetBufferLists 함수입니다. FilterReturnNetBufferLists 함수에서 필터 드라이버는 수신 표시 경로의 버퍼에서 수행한 작업을 실행 취소합니다.

필터 모듈이 일시 중지됨 상태인 경우 필터 드라이버는 해당 필터 모듈에 대한 수신 표시를 발생시키지 않아야 합니다. 필터 드라이버는 만든 버퍼를 NdisFIndicateReceiveNetBufferLists에 전달해서는 안 됩니다. 그러나 드라이버는 기본 드라이버에서 수신 표시를 전달할 수 있습니다.

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

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

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

FILTER_RECEIVE_NET_BUFFER_LISTS MyReceiveNetBufferLists;

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

_Use_decl_annotations_
VOID
 MyReceiveNetBufferLists(
    NDIS_HANDLE  FilterModuleContext,
    PNET_BUFFER_LIST  NetBufferLists,
    NDIS_PORT_NUMBER  PortNumber,
    ULONG  NumberOfNetBufferLists,
    ULONG  ReceiveFlags
    )
  {...}

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

Use_decl_annotations 대한 자세한 내용은 함수 동작에 주석을 추가를 참조하세요.

요구 사항

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

추가 정보

FilterAttach

FilterReturnNetBufferLists

FilterSetModuleOptions

NDIS_RECEIVE_QUEUE_PARAMETERS

NET_BUFFER

NET_BUFFER_LIST

NdisFIndicateReceiveNetBufferLists

NdisFRegisterFilterDriver

NdisFReturnNetBufferLists

NdisMAllocatePort

NdisSetOptionalHandlers

ProtocolReceiveNetBufferLists