다음을 통해 공유


FILTER_OID_REQUEST 콜백 함수(ndis.h)

NDIS는 필터 드라이버의 FilterOidRequest 함수를 호출하여 지정된 필터 모듈과 연결된 OID 요청을 처리합니다.

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

통사론

FILTER_OID_REQUEST FilterOidRequest;

NDIS_STATUS FilterOidRequest(
  [in] NDIS_HANDLE FilterModuleContext,
  [in] PNDIS_OID_REQUEST OidRequest
)
{...}

매개 변수

[in] FilterModuleContext

이 요청의 대상인 필터 모듈의 컨텍스트 영역에 대한 핸들입니다. 필터 드라이버는 FilterAttach 함수에서 이 컨텍스트 영역을 만들고 초기화했습니다.

[in] OidRequest

OID_XXX 코드를 포함하여 요청된 작업을 지정하는 NDIS_OID_REQUEST 구조체에 대한 포인터입니다. 구조체는 OID 쿼리 요청 또는 OID 집합 요청을 지정할 수 있습니다. OID에 대한 자세한 내용은 NDIS OID참조하세요.

반환 값

FilterOidRequest 다음 상태 값 중 하나를 반환합니다.

반환 코드 묘사
NDIS_STATUS_SUCCESS
FilterOidRequest 이 필터 모듈에 대한 필터 드라이버의 쿼리 또는 설정 작업을 성공적으로 완료했습니다.
NDIS_STATUS_PENDING
필터 드라이버가 요청을 비동기적으로 완료했음을 나타냅니다. 드라이버가 요청을 완료한 후 다음을 호출해야 합니다. NdisFOidRequestComplete 함수를 사용하여 요청이 완료되었다는 것을 NDIS에 알릴 수 있습니다.
NDIS_STATUS_INVALID_OID
OidRequest지정된 요청이 잘못되었거나 인식되지 않음을 나타냅니다.
NDIS_STATUS_NOT_SUPPORTED
FilterOidRequest OID를 지원하지 않는 OID는 선택 사항입니다.
NDIS_STATUS_BUFFER_TOO_SHORT
OidRequest제공된 버퍼가 너무 작아서 요청된 데이터를 저장할 수 없다는 것을 나타냅니다.
NDIS_STATUS_INVALID_LENGTH
쿼리 작업의 경우 NDIS_OID_REQUEST 구조체의 InformationBufferLength 멤버가 지정된 OID에 필요한 길이와 일치하지 않습니다. FilterOidRequest NDIS_OID_REQUEST 구조체의 BytesNeeded 멤버에서 필요한 버퍼 크기를 바이트 단위로 반환했습니다.
NDIS_STATUS_INVALID_DATA
set 작업의 경우 NDIS_OID_REQUEST 구조체의 InformationBuffer 멤버에 제공된 데이터가 지정된 OID에 유효하지 않습니다.
NDIS_STATUS_NOT_ACCEPTED
FilterOidRequest 요청된 정보를 수집하려고 했지만 실패했습니다.
NDIS_STATUS_RESOURCES
FilterOidRequest 리소스 부족으로 인해 실패했습니다.
NDIS_STATUS_FAILURE
FilterOidRequest 이전 값이 적용되지 않으면 NDIS_STATUS_FAILURE 반환합니다. 필터 드라이버는 실패 이유를 지정하는 매개 변수를 사용하여 NdisWriteErrorLogEntry 함수를 호출해야 합니다.

발언

FilterOidRequest 선택적 함수입니다. 필터 드라이버가 OID 요청을 사용하지 않는 경우 NdisFRegisterFilterDriver 함수를 호출할 때 이 함수가 NULL 진입점을 설정할 수 있습니다. 필터 드라이버가 FilterOidRequestComplete 함수를 정의하는 경우 FilterOidRequest 함수를 제공해야 합니다.

NDIS는 필터 드라이버의 FilterOidRequest 함수를 호출하여 지나치게 많은 드라이버에서 시작된 OID 요청을 처리합니다. 필터 드라이버는 NdisFOidRequest 함수를 호출하여 이러한 요청을 기본 드라이버에 전달할 수 있습니다.

드라이버가 NdisFOidRequest호출하기 전에 드라이버는 NDIS_OID_REQUEST 구조를 할당하고 NdisAllocateCloneOidRequest호출하여 요청 정보를 새 구조로 전송해야 합니다. 옵션으로 필터 드라이버는 요청을 전달하지 않고 즉시 요청을 완료할 수 있습니다.

요청을 동기적으로 완료하기 위해 필터 드라이버는 NDIS_STATUS_SUCCESS 또는 실패 상태를 반환합니다. 드라이버가 NDIS_STATUS_PENDING 반환하는 경우 NdisFOidRequestComplete 함수를 호출하여 요청이 완료되었다는 것을 NDIS에 알려야 합니다.

쿼리 작업의 경우 filterOidRequest InformationBuffer 멤버에서 요청된 정보를 반환하고 NDIS_OID_REQUEST 구조체의 BytesWritten 멤버의 변수를 반환된 정보의 양으로 설정합니다. 기본 드라이버는 필터 드라이버가 NdisFOidRequest요청을 전달한 경우 이 작업을 수행합니다.

set 작업의 경우 filterOidRequest NDIS_OID_REQUEST 구조체의 InformationBuffer 멤버의 데이터를 사용하여 지정된 OID에 필요한 정보를 설정할 수 있습니다. 이 경우 FilterOidRequestBytesRead 변수를 사용한 제공된 데이터의 양으로 설정합니다. 기본 드라이버는 필터 드라이버가 NdisFOidRequest요청을 전달한 경우 이 작업을 수행합니다.

미니포트 드라이버와 마찬가지로 필터 드라이버는 한 번에 하나의 요청만 받을 수 있습니다. NDIS는 필터 드라이버에 보내는 요청을 직렬화합니다. 필터 드라이버가 현재 요청을 완료하기 전에 NDIS는 FilterOidRequest 호출할 수 없습니다.

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

예제

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

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

FILTER_OID_REQUEST MyOidRequest;

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

_Use_decl_annotations_
NDIS_STATUS
 MyOidRequest(
    NDIS_HANDLE  FilterModuleContext,
    PNDIS_OID_REQUEST  OidRequest
    )
  {...}

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

Use_decl_annotations대한 자세한 내용은 함수 동작 주석참조하세요.

요구 사항

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

참고 항목

filterAttach

NDIS_OID_REQUEST

NdisAllocateCloneOidRequest

NdisFOidRequest

NdisFOidRequestComplete

NdisWriteErrorLogEntry