다음을 통해 공유


PROTOCOL_CO_SEND_NET_BUFFER_LISTS_COMPLETE 콜백 함수(ndis.h)

ProtocolCoSendNetBufferListsComplete 함수는 프로토콜 드라이버가 에 대한 호출로 시작한 보내기 작업을 완료합니다. NdisCoSendNetBufferLists 함수.

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

구문

PROTOCOL_CO_SEND_NET_BUFFER_LISTS_COMPLETE ProtocolCoSendNetBufferListsComplete;

void ProtocolCoSendNetBufferListsComplete(
  [in] NDIS_HANDLE ProtocolVcContext,
  [in] PNET_BUFFER_LIST NetBufferLists,
  [in] ULONG SendCompleteFlags
)
{...}

매개 변수

[in] ProtocolVcContext

이 드라이버가 VC(가상 연결) 런타임 상태 정보를 유지하는 프로토콜 드라이버 할당 컨텍스트 영역에 대한 핸들입니다. 클라이언트 또는 독립 실행형 호출 관리자는 NdisCoCreateVc 함수를 호출하거나 ProtocolCoCreateVc 함수에서 이 핸들을 제공했습니다.

[in] NetBufferLists

프로토콜 드라이버가 이전 호출에서 제공한 NET_BUFFER_LIST 구조 목록의 포인터입니다. NdisCoSendNetBufferLists 함수.

[in] SendCompleteFlags

비트 OR 연산과 결합할 수 있는 NDIS 플래그입니다. 모든 플래그를 지우려면 이 매개 변수를 0으로 설정합니다. ProtocolCoSendNetBufferListsComplete 는 NDIS_SEND_COMPLETE_FLAGS_DISPATCH_LEVEL 플래그를 지원합니다. 설정되면 현재 IRQL이 DISPATCH_LEVEL 나타냅니다. 이 플래그에 대한 자세한 내용은 디스패치 IRQL 추적을 참조하세요.

반환 값

없음

설명

CoNDIS 프로토콜 드라이버에는 ProtocolCoSendNetBufferListsComplete 함수가 필요합니다. ProtocolCoSendNetBufferListsComplete 는 보내기 작업을 완료하는 데 필요한 후처리를 수행합니다. 예를 들어 프로토콜 드라이버는 전송 작업이 완료되었음을 드라이버에 네트워크 데이터를 보내도록 요청한 클라이언트에 알릴 수 있습니다.

기본 미니포트 드라이버가 를 호출한 후 NDIS는 ProtocolCoSendNetBufferListsComplete 를 호출합니다. NdisMCoSendNetBufferListsComplete 함수. 전체 보내기 작업이 반드시 기본 미니포트 드라이버가 지정된 네트워크 데이터를 전송했음을 의미하지는 않습니다. 예를 들어 미니포트 드라이버는 네트워크 데이터를 NIC(네트워크 인터페이스 카드) 하드웨어로 전송하는 즉시 전송 작업이 완료되었음을 나타낼 수 있습니다.

NDIS가 ProtocolCoSendNetBufferListsComplete를 호출하면 프로토콜 드라이버는 NetBufferLists 매개 변수가 지정하는 NET_BUFFER_LIST 구조와 연결된 모든 리소스의 소유권을 되찾습니다.

NDIS는 항상 프로토콜 드라이버 제공 네트워크 데이터를 NdisCoSendNetBufferLists에 전달된 프로토콜 결정 순서로 기본 드라이버에 제출합니다. 그러나 기본 드라이버는 모든 순서로 보내기 요청을 완료할 수 있습니다. 즉, 프로토콜 드라이버는 NDIS를 사용하여 기본 드라이버에 "FIFO(First in, first out) 순서로 네트워크 데이터를 제출할 수 있습니다. 그러나 프로토콜 드라이버는 기본 드라이버를 사용하여 동일한 순서로 NdisMCoSendNetBufferListsComplete 를 호출할 수 없습니다.

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

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

예를 들어 " MyCoSendNetBufferListsComplete"라는 ProtocolCoSendNetBufferListsComplete 함수를 정의하려면 이 코드 예제와 같이 PROTOCOL_CO_SEND_NET_BUFFER_LISTS_COMPLETE 형식을 사용합니다.

PROTOCOL_CO_SEND_NET_BUFFER_LISTS_COMPLETE MyCoSendNetBufferListsComplete;

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

_Use_decl_annotations_
VOID
 MyCoSendNetBufferListsComplete(
    NDIS_HANDLE  ProtocolVcContext,
    PNET_BUFFER_LIST  NetBufferLists,
    ULONG  SendCompleteFlags
    )
  {...}

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

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

요구 사항

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

추가 정보

CoNDIS 프로토콜 드라이버 송신 및 수신 함수

NET_BUFFER_LIST

NdisCoCreateVc

NdisCoSendNetBufferLists

NdisMCoSendNetBufferListsComplete

ProtocolCoCreateVc

ProtocolCoReceiveNetBufferLists