다음을 통해 공유


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
설정된 작업의 경우 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에 알려야 합니다.

쿼리 작업의 경우 FilterOidRequestInformationBuffer 멤버에서 요청된 정보를 반환하고 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