다음을 통해 공유


FwpsAllocateDeepCloneNetBufferList0 함수(fwpsk.h)

FwpsAllocateDeepCloneNetBufferList0 함수는 기존 NET_BUFFER_LIST 구조체의 심층 복제본인 NET_BUFFER_LIST 구조를 할당합니다.

구문

NTSTATUS FwpsAllocateDeepCloneNetBufferList0(
  [in, out]      NET_BUFFER_LIST *originalNetBufferList,
  [in, optional] NDIS_HANDLE     netBufferListPoolHandle,
  [in, optional] NDIS_HANDLE     netBufferPoolHandle,
  [out]          NET_BUFFER_LIST **netBufferList
);

매개 변수

[in, out] originalNetBufferList

복제되는 원래 NET_BUFFER_LIST 구조체에 대한 포인터입니다.

[in, optional] netBufferListPoolHandle

NdisAllocateNetBufferListPool 함수에 대한 이전 호출에서 가져온 NET_BUFFER_LIST 풀 핸들입니다. 이 매개 변수는 선택 사항이며 NULL일 수 있습니다.

[in, optional] netBufferPoolHandle

NdisAllocateNetBufferPool 함수에 대한 이전 호출에서 가져온 NET_BUFFER_LIST 풀 핸들입니다. 이 매개 변수는 선택 사항이며 NULL일 수 있습니다.

[out] netBufferList

딥 클론 NET_BUFFER_LIST 구조체에 대한 포인터를 수신하는 변수에 대한 포인터입니다.

반환 값

FwpsAllocateDeepCloneNetBufferList0 함수는 다음 NTSTATUS 코드 중 하나를 반환합니다.

반환 코드 설명
STATUS_SUCCESS 심층 복제 NET_BUFFER_LIST 구조가 성공적으로 할당되었습니다.
기타 상태 코드 오류가 발생했습니다.

설명

설명선 드라이버는 FwpsAllocateDeepCloneNetBufferList0 함수를 호출하여 기존 NET_BUFFER_LIST 구조체의 심층 클론 NET_BUFFER_LIST 구조를 할당합니다.

이 함수는 NdisAllocateCloneNetBufferList 함수에 대한 래퍼이지만 WFP 패킷 삽입 함수에서 사용하기 위해 특수화되어 있습니다.

딥 클론 NET_BUFFER_LIST 구조에 특정 풀과 연결된 특성이 있어야 하는 경우 설명선 드라이버는 NetBufferListPoolHandle 또는 NetBufferPoolHandle 매개 변수에서 풀 핸들을 지정해야 합니다. 이러한 매개 변수가 NULL인 경우 NDIS가 미리 할당한 기본 풀이 사용됩니다.

심층 클론 NET_BUFFER_LIST 구조체는 원래 NET_BUFFER_LIST 구조체에서 설명하는 것과 동일한 데이터를 설명합니다. FwpsAllocateDeepCloneNetBufferList0 함수는 원래 MDL에서 설명하는 데이터를 새 데이터 버퍼에 복사합니다. 복제 NET_BUFFER_LIST 구조체에는 초기 NET_BUFFER_LIST_CONTEXT 구조체 포함됩니다.

이 함수는 부모 NET_BUFFER_LIST 구조를 가리키도록 새로 만든 클론 NET_BUFFER_LIST 구조체의 ParentNetBufferList 멤버를 설정합니다. 부모 구조체의 ChildRefCount 멤버는 1씩 증가합니다.

설명선 드라이버는 복제 NET_BUFFER_LIST 구조를 수정하고 패킷 삽입 함수를 호출하여 원래 NET_BUFFER_LIST 구조 대신 네트워크 스택에 삽입할 수 있습니다. 복제본 NET_BUFFER_LIST 구조에서 설명하는 데이터가 네트워크 스택에 성공적으로 삽입된 후 설명선 드라이버는 FwpsFreeCloneNetBufferList0 함수를 호출하여 복제본 NET_BUFFER_LIST 구조를 해제합니다.

설명선 드라이버는 심층 클론 NET_BUFFER_LIST 내의 개별 순 버퍼(NET_BUFFER) 또는 MDL을 삽입하거나 바꿀 수 있습니다. 드라이버는 FwpsFreeCloneNetBufferList0 함수를 호출하기 전에 이러한 수정을 실행 취소해야 합니다.

복제된 패킷을 관리하기 위한 지침

설명선 드라이버는 복제된 패킷을 무기한 보유해서는 안 됩니다. 복제된 패킷은 유휴 컴퓨터에서 전원 관리 작업을 방해할 수 있습니다.

WFP에서 심층 복제된 패킷에 대한 용도는 사용자 모드 애플리케이션 또는 원본과 독립적인 패킷이 필요한 기타 비교적 빠른 작업에서 설명을 가져오는 것입니다. 설명선 드라이버는 사용자 입력, 웹 서비스 정리 또는 임의 시간이 걸릴 수 있는 기타 작업을 기다리는 동안 복제된 패킷을 보유하지 않아야 합니다.

설명선 드라이버는 항상 가능한 한 빨리 저장된 패킷을 반환해야 합니다.

요구 사항

요구 사항
지원되는 최소 클라이언트 WIP 빌드 25324
대상 플랫폼 유니버설
헤더 fwpsk.h(Fwpsk.h 포함)
라이브러리 Fwpkclnt.lib
IRQL <= DISPATCH_LEVEL

추가 정보

FwpsFreeCloneNetBufferList0

NET_BUFFER

NET_BUFFER_LIST

NET_BUFFER_LIST_CONTEXT

NdisAllocateNetBufferListPool

NdisAllocateNetBufferPool

패킷 삽입 함수