PROTOCOL_SEND_NET_BUFFER_LISTS_COMPLETE 콜백 함수(ndis.h)
ProtocolSendNetBufferListsComplete 함수는 프로토콜 드라이버가 에 대한 호출로 시작한 보내기 작업을 완료합니다. NdisSendNetBufferLists 함수입니다 .
구문
PROTOCOL_SEND_NET_BUFFER_LISTS_COMPLETE ProtocolSendNetBufferListsComplete;
void ProtocolSendNetBufferListsComplete(
[in] NDIS_HANDLE ProtocolBindingContext,
[in] PNET_BUFFER_LIST NetBufferList,
[in] ULONG SendCompleteFlags
)
{...}
매개 변수
[in] ProtocolBindingContext
바인딩에 대한 상태 정보를 유지하기 위해 프로토콜 드라이버가 할당한 컨텍스트 영역에 대한 핸들입니다. 이 핸들은 NdisOpenAdapterEx에 대한 이전 호출에서 NDIS에 전달되었습니다.
[in] NetBufferList
프로토콜 드라이버가 NdisSendNetBufferLists에 대한 이전 호출에서 제공한 NET_BUFFER_LIST 구조 목록에 대한 포인터입니다.
[in] SendCompleteFlags
OR 작업과 결합할 수 있는 NDIS 플래그입니다. 모든 플래그를 지우려면 이 멤버를 0으로 설정합니다. 이 함수는 NDIS_SEND_COMPLETE_FLAGS_DISPATCH_LEVEL 플래그를 지원합니다. 설정되면 현재 IRQL이 DISPATCH_LEVEL 나타냅니다. 이 플래그에 대한 자세한 내용은 디스패치 IRQL 추적을 참조하세요.
반환 값
없음
설명
ProtocolSendNetBufferListsComplete 는 프로토콜 드라이버에 필요한 함수입니다. ProtocolSendNetBufferListsComplete 는 송신 작업을 완료하는 데 필요한 후처리를 수행합니다. 예를 들어 프로토콜 드라이버는 송신 작업이 완료되었음을 네트워크 데이터를 보내도록 프로토콜을 요청한 클라이언트에 알릴 수 있습니다.
기본 미니포트 드라이버가 를 호출한 후 NDIS는 ProtocolSendNetBufferListsComplete 를 호출합니다. NdisMSendNetBufferListsComplete 함수. 전송 작업을 완료하면 일반적으로 기본 미니포트 드라이버가 지정된 네트워크 데이터를 전송했음을 의미합니다. 그러나 미니포트 드라이버는 네트워크 데이터를 NIC로 전송하는 즉시 송신 작업이 완료되었음을 나타낼 수 있습니다.
NDIS가 ProtocolSendNetBufferListsComplete를 호출하면 프로토콜 드라이버는 NetBufferLists 매개 변수로 지정된 NET_BUFFER_LIST 구조와 연결된 모든 리소스의 소유권을 되찾습니다.
NDIS는 항상 프로토콜 제공 네트워크 데이터를 NdisSendNetBufferLists에 전달된 프로토콜 결정 순서로 기본 미니포트 드라이버에 제출합니다. 그러나 기본 드라이버는 순서에 따라 보내기 요청을 완료할 수 있습니다. 즉, 프로토콜 드라이버는 NDIS를 사용하여 기본 드라이버에 FIFO 순서로 네트워크 데이터를 제출할 수 있습니다. 그러나 프로토콜 드라이버는 기본 드라이버를 사용하여 동일한 순서로 NdisMSendNetBufferListsComplete 를 호출할 수 없습니다.
NDIS는 IRQL<= DISPATCH_LEVEL ProtocolSendNetBufferListsComplete를 호출합니다.
예
ProtocolSendNetBufferListsComplete 함수를 정의하려면 먼저 정의 중인 함수 유형을 식별하는 함수 선언을 제공해야 합니다. Windows는 드라이버에 대한 함수 형식 집합을 제공합니다. 함수 형식을 사용하여 함수를 선언하면 드라이버에 대한 코드 분석, SDV( 정적 드라이버 검증 도구 ) 및 기타 확인 도구에서 오류를 찾을 수 있으며 Windows 운영 체제용 드라이버를 작성하기 위한 요구 사항입니다.예를 들어 " MySendNetBufferListsComplete"라는 ProtocolSendNetBufferListsComplete 함수를 정의하려면 다음 코드 예제와 같이 PROTOCOL_SEND_NET_BUFFER_LISTS_COMPLETE 형식을 사용합니다.
PROTOCOL_SEND_NET_BUFFER_LISTS_COMPLETE MySendNetBufferListsComplete;
그런 다음 다음과 같이 함수를 구현합니다.
_Use_decl_annotations_
VOID
MySendNetBufferListsComplete(
NDIS_HANDLE ProtocolBindingContext,
PNET_BUFFER_LIST NetBufferLists,
ULONG SendCompleteFlags
)
{...}
PROTOCOL_SEND_NET_BUFFER_LISTS_COMPLETE 함수 형식은 Ndis.h 헤더 파일에 정의되어 있습니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 Use_decl_annotations 주석을 추가해야 합니다. Use_decl_annotations 주석은 헤더 파일의 PROTOCOL_SEND_NET_BUFFER_LISTS_COMPLETE 함수 형식에 적용되는 주석이 사용되도록 합니다. 함수 선언 요구 사항에 대한 자세한 내용은 NDIS 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요.
Use_decl_annotations 대한 자세한 내용은 함수 동작 주석 지정을 참조하세요.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | NDIS 6.0 이상에서 지원됩니다. |
대상 플랫폼 | Windows |
헤더 | ndis.h(Ndis.h 포함) |
IRQL | <= DISPATCH_LEVEL |