다음을 통해 공유


FltEnumerateInstanceInformationByFilter 함수(fltkernel.h)

FltEnumerateInstanceInformationByFilter 루틴은 지정된 미니필터 드라이버의 인스턴스에 대한 정보를 제공합니다.

구문

NTSTATUS FLTAPI FltEnumerateInstanceInformationByFilter(
  [in]  PFLT_FILTER                Filter,
  [in]  ULONG                      Index,
  [in]  INSTANCE_INFORMATION_CLASS InformationClass,
  [out] PVOID                      Buffer,
  [in]  ULONG                      BufferSize,
  [out] PULONG                     BytesReturned
);

매개 변수

[in] Filter

호출자에 대한 불투명 필터 포인터입니다.

[in] Index

정보가 요청되는 instance 인덱스(0부터 시작)입니다.

[in] InformationClass

요청된 정보 유형입니다. 이 매개 변수는 다음 값 중 하나를 가질 수 있습니다.

의미
InstanceBasicInformation Buffer 매개 변수가 가리키는 버퍼instance 대한 INSTANCE_BASIC_INFORMATION 구조를 받습니다.
InstanceFullInformation Buffer 매개 변수가 가리키는 버instance 대한 INSTANCE_FULL_INFORMATION 구조를 받습니다.
InstancePartialInformation Buffer 매개 변수가 가리키는 버퍼는 instance 대한 INSTANCE_PARTIAL_INFORMATION 구조를 받습니다.
InstanceAggregateStandardInformation Buffer 매개 변수가 가리키는 버instance 대한 INSTANCE_AGGREGATE_STANDARD_INFORMATION 구조를 받습니다. 구조체의 LegacyFilter 부분은 사용되지 않습니다. 이 구조는 Windows Vista부터 사용할 수 있습니다.

[out] Buffer

요청된 정보를 수신하는 호출자가 할당한 버퍼에 대한 포인터입니다. 버퍼에 반환된 정보의 형식은 InformationClass 매개 변수에 의해 정의됩니다.

[in] BufferSize

Buffer 매개 변수가 가리키는 버퍼의 크기(바이트)입니다. 호출자는 지정된 InformationClass 값에 따라 이 매개 변수를 설정해야 합니다.

[out] BytesReturned

버퍼가 가리키는 버퍼에 반환된 바이트 수를 수신하는 호출자 할당 변수에 대한 포인터입니다. BufferSize의 입력 값이 너무 작으면 FltEnumerateInstanceInformationByFilter는 STATUS_BUFFER_TOO_SMALL 반환하고 이 변수를 요청된 정보를 저장하는 데 필요한 바이트 수로 설정합니다. 이 매개 변수는 필수이며 NULL일 수 없습니다.

반환 값

FltEnumerateInstanceInformationByFilter 는 STATUS_SUCCESS 또는 다음 중 하나와 같은 적절한 NTSTATUS 값을 반환합니다.

반환 코드 설명
STATUS_BUFFER_TOO_SMALL
Buffer 매개 변수가 가리키는 버 가 요청된 정보를 저장할 만큼 크지 않습니다. 오류 코드입니다.
STATUS_FLT_DELETING_OBJECT
일치하는 instance 발견되었지만 철거되고 있습니다. 오류 코드입니다.
STATUS_INVALID_PARAMETER
InformationClass 매개 변수에 잘못된 값이 지정되었습니다. 예를 들어 Windows Vista 이전의 운영 체제에서 FilterAggregateStandardInformation 이 지정된 경우 루틴은 STATUS_INVALID_PARAMETER 반환합니다. 오류 코드입니다.
STATUS_NO_MORE_ENTRIES
미니필터 드라이버의 instance 목록에는 더 이상 항목이 없습니다. 경고 코드입니다.

설명

Index 매개 변수는 FltEnumerateInstanceInformationByFilterFilter로 지정된 미니필터 드라이버에 대한 instance 목록의 인스턴스 중에서 선택할 수 있는 방법입니다. instance 목록의 미니필터 드라이버 인스턴스는 언제든지 변경할 수 있으므로 Index 및Filter 값이 동일한 FltEnumerateInstanceInformationByFilter에 대한 두 번의 호출은 동일한 결과를 반환하도록 보장되지 않습니다.

등록된 모든 미니필터 드라이버를 열거하려면 FltEnumerateFilters를 호출합니다.

등록된 모든 미니필터 드라이버에 대한 필터 정보를 나열하려면 FltEnumerateFilterInformation을 호출합니다.

지정된 미니필터 드라이버에 대한 필터 정보를 얻으려면 FltGetFilterInformation을 호출합니다.

지정된 볼륨의 모든 미니필터 드라이버 인스턴스를 열거하려면 FltEnumerateInstanceInformationByVolume을 호출합니다.

모든 볼륨에서 모든 미니필터 드라이버의 인스턴스를 열거하려면 FltEnumerateInstances를 호출합니다.

필터 관리자에 알려진 모든 볼륨을 열거하려면 FltEnumerateVolumes를 호출합니다.

.

요구 사항

요구 사항
대상 플랫폼 유니버설
헤더 fltkernel.h(FltKernel.h 포함)
라이브러리 FltMgr.lib
IRQL <= APC_LEVEL

추가 정보

FltEnumerateFilterInformation

FltEnumerateFilters

FltEnumerateInstanceInformationByVolume

FltEnumerateVolumes

FltGetFilterInformation

INSTANCE_AGGREGATE_STANDARD_INFORMATION

INSTANCE_BASIC_INFORMATION

INSTANCE_FULL_INFORMATION

INSTANCE_PARTIAL_INFORMATION