FILTER_PAUSE 콜백 함수(ndis.h)
NDIS는 필터 드라이버의 FilterPause 함수를 호출하여 지정된 필터 모듈에 대한 일시 중지 작업을 시작합니다.
구문
FILTER_PAUSE FilterPause;
NDIS_STATUS FilterPause(
[in] NDIS_HANDLE FilterModuleContext,
[in] PNDIS_FILTER_PAUSE_PARAMETERS PauseParameters
)
{...}
매개 변수
[in] FilterModuleContext
필터 드라이버가 일시 중지해야 하는 필터 모듈의 컨텍스트 영역에 대한 핸들입니다. FilterAttach 함수에서 이 컨텍스트 영역을 만들고 초기화한 필터 드라이버입니다.
[in] PauseParameters
필터 모듈에 대한 일시 중지 매개 변수를 정의하는 NDIS_FILTER_PAUSE_PARAMETERS 구조체에 대한 포인터입니다.
반환 값
NDIS 드라이버는 일시 중지 요청을 실패할 수 없습니다. 필터 드라이버는 오류 발생 이유를 지정하는 매개 변수와 함께 NdisWriteEventLogEntry 함수를 호출해야 합니다.
| 반환 코드 | 설명 |
|---|---|
|
FilterPause 가 지정된 필터 모듈을 일시 중지했습니다. |
|
필터 드라이버는 NdisFPauseComplete 함수를 호출하여 요청을 비동기적으로 완료합니다. |
설명
FilterPause 는 필수 함수입니다. NDIS는 필터 모듈이 실행 중 상태일 때 FilterPause를 호출할 수 있습니다. 필터 모듈은 FilterPause 함수에서 실행이 시작될 때 일시 중지 상태로 들어갑니다.
필터 드라이버는 NDIS가 FilterPause를 호출할 때 다음 작업을 수행합니다.
- 오버리싱 드라이버가 만든 큐에 대기 중인 송신 버퍼에 대해 NdisFSendNetBufferListsComplete 함수를 호출해야 합니다.
- 기본 드라이버가 만든 큐에 대기 중인 수신 버퍼에 대해 NdisFReturnNetBufferLists 함수를 호출해야 합니다.
- NDIS가 드라이버가 FilterSendNetBufferListsComplete 함수로 시작된 미해결 송신 요청을 모두 반환할 때까지 기다려야 합니다.
- NDIS가 드라이버가 FilterReturnNetBufferLists 함수에서 시작되었음을 나타내는 미해결 수신 표시를 모두 반환할 때까지 기다려야 합니다.
일시 중지 또는 일시 중지된 상태에서 필터 드라이버는 OID 요청 또는 상태 표시를 계속 처리해야 합니다. 드라이버는 FilterSendNetBufferLists 함수에 대한 호출을 거부해야 합니다. 드라이버는 FilterReceiveNetBufferLists 함수에 대한 호출을 전달할 수 있습니다. 그러나 드라이버는 만든 버퍼를 전달할 수 없습니다. 드라이버는 수신 표시를 시작하거나 요청을 보내면 안 됩니다.
일시 중지된 상태에서 필터 모듈은 송신 요청을 생성하거나 표시를 수신해서는 안 됩니다.
NDIS는 FilterRestart 함수를 호출하여 일시 중지 된 상태에 있는 필터 모듈에 대한 다시 시작 요청을 시작합니다.
NDIS는 IRQL = PASSIVE_LEVEL FilterPause 를 호출합니다.
예제
FilterPause 함수를 정의하려면 먼저 정의하려는 함수의 형식을 식별하는 함수 선언을 제공해야 합니다. Windows 드라이버에 대한 함수 형식 집합을 제공합니다. 함수 형식을 사용하여 함수를 선언하면 드라이버, SDV(정적 드라이버 검증 도구) 및 기타 확인 도구에 대한 Code Analysis 오류를 찾을 수 있으며 Windows 운영 체제용 드라이버를 작성해야 합니다.예를 들어 " MyPause"라는 FilterPause 함수를 정의하려면 이 코드 예제와 같이 FILTER_PAUSE 형식을 사용합니다.
FILTER_PAUSE MyPause;
그런 다음 다음과 같이 함수를 구현합니다.
_Use_decl_annotations_
NDIS_STATUS
MyPause(
NDIS_HANDLE FilterModuleContext,
PNDIS_FILTER_PAUSE_PARAMETERS FilterPauseParameters
)
{...}
FILTER_PAUSE 함수 형식은 Ndis.h 헤더 파일에 정의되어 있습니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 Use_decl_annotations 주석을 추가해야 합니다. Use_decl_annotations 주석은 헤더 파일의 FILTER_PAUSE 함수 형식에 적용되는 주석이 사용되는지 확인합니다. 함수 선언에 대한 요구 사항에 대한 자세한 내용은 NDIS 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요.
Use_decl_annotations 대한 자세한 내용은 함수 동작에 주석을 추가하세요.
요구 사항
| 지원되는 최소 클라이언트 | NDIS 6.0 이상에서 지원됩니다. |
| 대상 플랫폼 | Windows |
| 헤더 | ndis.h(Ndis.h 포함) |
| IRQL | PASSIVE_LEVEL |
참조
FilterSendNetBufferListsComplete
피드백
다음에 대한 사용자 의견 제출 및 보기