FILTER_DIRECT_OID_REQUEST 콜백 함수(ndis.h)
NDIS는 필터 드라이버의 FilterDirectOidRequest 함수를 호출하여 지정된 필터 모듈과 연결된 직접 OID 요청을 처리합니다.
구문
FILTER_DIRECT_OID_REQUEST FilterDirectOidRequest;
NDIS_STATUS FilterDirectOidRequest(
[in] NDIS_HANDLE FilterModuleContext,
[in] PNDIS_OID_REQUEST OidRequest
)
{...}
매개 변수
[in] FilterModuleContext
이 요청의 대상인 필터 모듈의 컨텍스트 영역에 대한 핸들입니다. FilterAttach 함수에서 이 컨텍스트 영역을 만들고 초기화한 필터 드라이버입니다.
[in] OidRequest
OID_ Xx 코드를 포함하여 요청된 작업을 지정하는 NDIS_OID_REQUEST 구조체에 대한 포인터입니다. 구조는 쿼리 요청 또는 집합 요청을 지정할 수 있습니다.
반환 값
FilterDirectOidRequest 는 다음 상태 값 중 하나를 반환합니다.
| 반환 코드 | 설명 |
|---|---|
|
FilterDirectOidRequest 가 이 필터 모듈에 대한 필터 드라이버의 쿼리 또는 설정 작업을 성공적으로 완료했습니다. |
|
필터 드라이버는 요청을 비동기적으로 완료합니다. 드라이버가 요청을 완료한 후 NdisFDirectOidRequestComplete 함수를 호출하여 요청이 완료되었다는 것을 NDIS에 알려야 합니다. |
|
OidRequest가 지정한 요청이 잘못되었거나 인식되지 않았습니다. |
|
FilterDirectOidRequest 는 OID를 지원하지 않습니다. OID는 선택 사항입니다. |
|
OidRequest가 제공한 버퍼가 너무 작아서 요청된 데이터를 저장할 수 없습니다. |
|
쿼리 작업의 경우 NDIS_OID_REQUEST 구조체의 InformationBufferLength 멤버가 지정된 OID에 필요한 길이와 일치하지 않습니다. FilterDirectOidRequest 는 NDIS_OID_REQUEST 구조체의 BytesNeeded 멤버에서 필요한 버퍼 크기(바이트)를 반환했습니다. |
|
set 작업의 경우 NDIS_OID_REQUEST 구조체의 InformationBuffer 멤버에 제공된 데이터가 지정된 OID에 유효하지 않습니다. |
|
FilterDirectOidRequest 가 요청된 정보를 수집하려고 했지만 실패했습니다. |
|
리소스가 부족하여 FilterDirectOidRequest가 실패했습니다. |
|
앞의 반환 값 중 N이 적용됩니다. 필터 드라이버는 실패 이유를 지정하는 매개 변수를 사용하여 NdisWriteErrorLogEntry 함수를 호출해야 합니다. |
설명
FilterDirectOidRequest 는 선택적 함수입니다. 필터 드라이버가 직접 OID 요청을 사용하지 않는 경우 NdisFRegisterFilterDriver 함수를 호출할 때 이 함수의 진입점을 NULL로 설정할 수 있습니다. 필터 드라이버가 FilterDirectOidRequestComplete 함수를 정의하는 경우 FilterDirectOidRequest 함수를 제공해야 합니다.
NDIS는 필터 드라이버의 FilterDirectOidRequest 함수를 호출하여 지나치게 드라이버에서 시작된 직접 OID 요청을 처리합니다. 필터 드라이버는 NdisFDirectOidRequest 함수를 호출하여 이러한 요청을 기본 드라이버에 전달할 수 있습니다. 옵션으로 필터 드라이버는 요청을 전달하지 않고 즉시 요청을 완료할 수도 있습니다.
드라이버가 NdisFDirectOidRequest를 호출하기 전에 드라이버는 NDIS_OID_REQUEST 구조를 할당하고 NdisAllocateCloneOidRequest 함수를 호출하여 요청 정보를 새 구조로 전송해야 합니다.
요청을 동기적으로 완료하기 위해 필터 드라이버는 NDIS_STATUS_SUCCESS 또는 실패 상태를 반환합니다. 드라이버가 NDIS_STATUS_PENDING 반환하는 경우 NdisFDirectOidRequestComplete 함수를 호출하여 요청이 완료되었다는 것을 NDIS에 알려야 합니다.
쿼리 작업의 경우 FilterDirectOidRequest 는 InformationBuffer 멤버에서 요청된 정보를 반환하고 NDIS_OID_REQUEST 구조체의 BytesWritten 멤버에 있는 변수를 반환된 정보의 양으로 설정합니다. 필터 드라이버가 NdisFDirectOidRequest를 사용하여 요청을 전달한 경우 기본 드라이버에서 이 작업을 수행합니다.
set 작업의 경우 FilterDirectOidRequest 는 NDIS_OID_REQUEST 구조체의 InformationBuffer 멤버에 있는 데이터를 사용하여 지정된 OID에 필요한 정보를 설정할 수 있습니다. 이 경우 FilterDirectOidRequest 는 BytesRead 의 변수를 사용한 제공된 데이터의 양으로 설정합니다. 기본 드라이버는 필터 드라이버가 NdisFDirectOidRequest를 사용하여 요청을 전달한 경우 이러한 방식으로 BytesRead를 설정합니다.
NDIS는 다른 OID 요청과 함께 FilterDirectOidRequest 로 보내는 요청을 직렬화하지 않습니다. FilterOidRequest 또는 FilterDirectOidRequest로 전송되는 다른 요청이 처리되지 않는 경우 필터 드라이버는 FilterDirectOidRequest에 대한 여러 호출을 처리할 수 있어야 합니다.
NDIS는 IRQL <= DISPATCH_LEVEL FilterDirectOidRequest 를 호출합니다.
예제
FilterDirectOidRequest 함수를 정의하려면 먼저 정의 중인 함수의 형식을 식별하는 함수 선언을 제공해야 합니다. Windows 드라이버에 대한 함수 형식 집합을 제공합니다. 함수 형식을 사용하여 함수를 선언하면 드라이버, SDV(정적 드라이버 검증 도구) 및 기타 확인 도구에 대한 Code Analysis 오류를 찾는 데 도움이 되며, Windows 운영 체제용 드라이버를 작성하기 위한 요구 사항입니다.예를 들어 " MyDirectOidRequest"라는 FilterDirectOidRequest 함수를 정의하려면 다음 코드 예제와 같이 FILTER_DIRECT_OID_REQUEST 형식을 사용합니다.
FILTER_DIRECT_OID_REQUEST MyDirectOidRequest;
그런 다음 다음과 같이 함수를 구현합니다.
_Use_decl_annotations_
NDIS_STATUS
MyDirectOidRequest(
NDIS_HANDLE FilterModuleContext,
PNDIS_OID_REQUEST OidRequest
)
{...}
FILTER_DIRECT_OID_REQUEST 함수 형식은 Ndis.h 헤더 파일에 정의됩니다. 코드 분석 도구를 실행할 때 오류를 보다 정확하게 식별하려면 함수 정의에 Use_decl_annotations 주석을 추가해야 합니다. Use_decl_annotations 주석은 헤더 파일의 FILTER_DIRECT_OID_REQUEST 함수 형식에 적용되는 주석이 사용되도록 합니다. 함수 선언에 대한 요구 사항에 대한 자세한 내용은 NDIS 드라이버에 함수 역할 형식을 사용하여 함수 선언을 참조하세요.
Use_decl_annotations 대한 자세한 내용은 함수 동작 주석 지정을 참조하세요.
요구 사항
| 지원되는 최소 클라이언트 | NDIS 6.1 이상에서 지원됩니다. |
| 대상 플랫폼 | Windows |
| 헤더 | ndis.h(Ndis.h 포함) |
| IRQL | <= DISPATCH_LEVEL |
참고 항목
피드백
다음에 대한 사용자 의견 제출 및 보기