FILTER_CANCEL_SEND_NET_BUFFER_LISTS 콜백 함수(ndis.h)

NDIS는 필터 드라이버의 FilterCancelSendNetBufferLists 함수를 호출하여 지정된 취소 식별자로 표시된 모든 NET_BUFFER_LIST 구조체의 전송을 취소합니다.

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

구문

FILTER_CANCEL_SEND_NET_BUFFER_LISTS FilterCancelSendNetBufferLists;

void FilterCancelSendNetBufferLists(
  [in] NDIS_HANDLE FilterModuleContext,
  [in] PVOID CancelId
)
{...}

매개 변수

[in] FilterModuleContext

FilterAttach 함수에서 필터 드라이버가 할당한 컨텍스트 영역에 대한 핸들입니다. 필터 드라이버는 이 컨텍스트 영역을 사용하여 필터 모듈에 대한 상태 정보를 유지 관리합니다.

[in] CancelId

취소 식별자입니다. 이 식별자는 취소되는 NET_BUFFER_LIST 구조를 지정합니다.

반환 값

없음

설명

FilterCancelSendNetBufferLists 함수는 선택 사항입니다. 필터 드라이버가 송신 요청을 필터링하지 않는 경우 이 함수가 를 호출할 때 이 함수의 진입점을 NULL 로 설정할 수 있습니다. NdisFRegisterFilterDriver 함수입니다.

보내기 전에 NET_BUFFER_LIST 구조를 큐에 대기하는 필터 드라이버는 FilterCancelSendNetBufferLists 함수를 내보내야 합니다. FilterCancelSendNetBufferLists 함수는 지정된 NET_BUFFER_LIST 구조체의 보류 중인 전송을 취소합니다.

지나치게 NDIS 드라이버가 를 호출하는 경우 NdisCancelSendNetBufferLists 또는 NdisFCancelSendNetBufferLists 함수, NDIS는 바인딩에서 필터 모듈의 FilterCancelSendNetBufferLists 함수를 호출합니다.

필터 드라이버의 FilterCancelSendNetBufferLists 함수는 다음 작업을 수행합니다.

  1. 지정된 필터 모듈에 대해 큐에 대기된 NET_BUFFER_LIST 구조 목록을 트래버스하고 매크로를 NDIS_GET_NET_BUFFER_LIST_CANCEL_ID 큐에 대기된 각 NET_BUFFER_LIST 구조에 대한 취소 식별자를 가져옵니다. 필터 드라이버는 NDIS_GET_NET_BUFFER_LIST_CANCEL_ID 반환하는 취소 ID를 NDIS가 FilterCancelSendNetBufferLists에 전달한 취소 ID와 비교합니다.
  2. 취소 식별자가 지정된 취소 식별자와 일치하는 모든 NET_BUFFER_LIST 구조체를 송신 큐(연결 해제)에서 제거합니다.
  3. 다음을 호출합니다.구조체를 반환하기 위해 연결되지 않은 모든 NET_BUFFER_LIST 구조체에 대한 NdisFSendNetBufferListsComplete 함수입니다. 필터 드라이버는 NET_BUFFER_LIST 구조체의 상태 필드를 NDIS_STATUS_SEND_ABORTED 설정합니다.
  4. NdisFCancelSendNetBufferLists 함수를 호출하여 기본 드라이버에 취소 보내기 요청을 전달합니다.
NDIS는 IRQL <= DISPATCH_LEVEL FilterCancelSendNetBufferLists 를 호출합니다.

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

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

FILTER_CANCEL_SEND_NET_BUFFER_LISTS MyCancelSendNetBufferLists;

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

_Use_decl_annotations_
VOID
 MyCancelSendNetBufferLists(
    NDIS_HANDLE  FilterModuleContext,
    PVOID  CancelId
    )
  {...}

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

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

요구 사항

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

추가 정보

FilterAttach

NDIS_GET_NET_BUFFER_LIST_CANCEL_ID

NET_BUFFER

NET_BUFFER_LIST

NdisCancelSendNetBufferLists

NdisFCancelSendNetBufferLists

NdisFRegisterFilterDriver

NdisFSendNetBufferListsComplete