다음을 통해 공유


PFLT_NORMALIZE_NAME_COMPONENT_EX 콜백 함수(fltkernel.h)

필터 관리자의 이름 캐시에 대한 파일 이름을 제공하는 미니필터 드라이버는 PFLT_NORMALIZE_NAME_COMPONENT_EX 형식의 루틴을 미니필터 드라이버의 NormalizeNameComponentExCallback 콜백 루틴으로 등록할 수 있습니다.

구문

PFLT_NORMALIZE_NAME_COMPONENT_EX PfltNormalizeNameComponentEx;

NTSTATUS PfltNormalizeNameComponentEx(
  [in]      PFLT_INSTANCE Instance,
  [in]      PFILE_OBJECT FileObject,
  [in]      PCUNICODE_STRING ParentDirectory,
  [in]      USHORT VolumeNameLength,
  [in]      PCUNICODE_STRING Component,
  [out]     PFILE_NAMES_INFORMATION ExpandComponentName,
  [in]      ULONG ExpandComponentNameLength,
  [in]      FLT_NORMALIZE_NAME_FLAGS Flags,
  [in, out] PVOID *NormalizationContext
)
{...}

매개 변수

[in] Instance

이 콜백 루틴이 등록된 미니필터 드라이버 instance 대한 불투명 instance 포인터입니다.

[in] FileObject

이름이 요청되는 파일의 파일 개체 또는 FLTFL_NORMALIZE_NAME_DESTINATION_FILE_NAME 플래그가 설정된 경우 IRP_MJ_SET_INFORMATION 작업의 대상인 파일에 대한 포인터입니다. 자세한 내용은 아래 Flags 매개 변수를 참조하세요.

[in] ParentDirectory

이 이름 구성 요소에 대한 부모 디렉터리의 이름을 포함하는 UNICODE_STRING 구조체에 대한 포인터입니다.

[in] VolumeNameLength

ParentDirectory 매개 변수가 가리키는 구조체에 저장된 부모 디렉터리 이름의 길이(바이트)입니다.

[in] Component

확장할 이름 구성 요소가 포함된 UNICODE_STRING 구조체에 대한 포인터입니다.

[out] ExpandComponentName

이름 구성 요소에 대한 확장(정규화된) 파일 이름 정보를 수신하는 FILE_NAMES_INFORMATION 구조체에 대한 포인터입니다.

[in] ExpandComponentNameLength

ExpandComponentName 매개 변수가 가리키는 버퍼의 길이(바이트)입니다.

[in] Flags

이름 정규화 플래그입니다. FLTFL_NORMALIZE_NAME_CASE_SENSITIVE 정규화할 이름이 대/소문자를 구분하도록 지정합니다. FLTFL_NORMALIZE_NAME_DESTINATION_FILE_NAME FltGetDestinationFileNameInformation 루틴 호출을 서비스하기 위해 콜백 루틴이 호출되었음을 지정합니다. FLTFL_NORMALIZE_NAME_DESTINATION_FILE_NAME 플래그가 설정되면 FileObject 는 IRP_MJ_SET_INFORMATION 작업의 대상인 파일/디렉터리를 나타냅니다. FLTFL_NORMALIZE_NAME_DESTINATION_FILE_NAME 플래그가 설정되지 않은 경우 FileObject 는 이름이 요청되는 파일/디렉터리를 나타냅니다.

[in, out] NormalizationContext

동일한 파일 이름 경로의 나머지 구성 요소를 정규화하기 위해 만들어진 이 콜백 루틴에 대한 후속 호출에서 전달될 미니필터 드라이버 제공 컨텍스트 정보에 대한 포인터입니다.

반환 값

이 콜백 루틴은 STATUS_SUCCESS 또는 적절한 NTSTATUS 값을 반환합니다. Component 매개 변수가 지정하는 이름 구성 요소가 ParentDirectory 매개 변수가 지정하는 부모 디렉터리에 없는 경우 이 콜백 루틴은 STATUS_NO_SUCH_FILE 반환해야 합니다. 이 콜백 루틴이 부모 디렉터리에 대한 IRP_MN_QUERY_DIRECTORY(FileNamesInformation) 요청을 발급하는 경우 파일 시스템은 올바른 상태 코드를 반환합니다. 이 경우 이 콜백은 파일 시스템에서 반환하는 상태 코드를 반환할 수 있습니다.

설명

필터 관리자의 이름 캐시에 대한 파일 이름을 제공하는 미니필터 드라이버는 PFLT_NORMALIZE_NAME_COMPONENT_EX 형식의 루틴을 미니필터 드라이버의 NormalizeNameComponentExCallback 콜백 루틴으로 등록할 수 있습니다.

NormalizeNameComponentExCallback 콜백 루틴과 NormalizeNameComponentCallback 콜백 루틴(PFLT_NORMALIZE_NAME_COMPONENT 형식)의 주요 차이점은 NormalizeNameComponentExCallback 콜백 루틴이 추가 FileObject 매개 변수를 지원한다는 것입니다. 파일 개체(FileObject)는 미니필터 드라이버에서 IoGetTransactionParameterBlock 루틴을 호출하여 파일/디렉터리가 참여하는 작업에 대한 TXN_PARAMETER_BLOCK 구조를 검색하는 데 사용할 수 있습니다. TXN_PARAMETER_BLOCK 구조체는 미니필터 드라이버가 이 파일 개체가 참여하는 트랜잭션의 컨텍스트에서 자체 만들기 요청을 발급하는 데 사용할 수 있습니다.

이 콜백 루틴을 등록하기 위해 미니필터 드라이버는 미니필터 드라이버가 FltRegisterFilter에 매개 변수로 전달하는 FLT_REGISTRATION 구조체의 NormalizeNameComponentExCallback 멤버에 PFLT_NORMALIZE_NAME_COMPONENT_EX 형식의 루틴 주소를 저장합니다.

필터 관리자는 이 콜백 루틴을 호출하여 미니필터 드라이버의 이름이 수정된 파일 이름 경로의 구성 요소에 대한 정규화된 이름을 미니필터 드라이버에 쿼리합니다. 파일 이름 경로에 두 개 이상의 구성 요소가 포함된 경우 필터 관리자는 경로의 모든 구성 요소를 정규화하는 과정에서 이 콜백 루틴을 여러 번 호출할 수 있습니다. 미니필터 드라이버는 NormalizationContext 매개 변수를 사용하여 컨텍스트 정보를 이 콜백 루틴에 대한 후속 호출에 전달할 수 있습니다.

미니필터 드라이버가 NormalizationContext 매개 변수를 사용하는 경우 정규화 컨텍스트 정리 콜백 루틴도 등록해야 합니다. 자세한 내용은 PFLT_NORMALIZE_CONTEXT_CLEANUP 대한 참조 항목을 참조하세요.

요구 사항

요구 사항
대상 플랫폼 데스크톱
머리글 fltkernel.h(Fltkernel.h 포함)
IRQL PASSIVE_LEVEL

추가 정보

FILE_NAMES_INFORMATION

FLT_REGISTRATION

FltGetDestinationFileNameInformation

FltRegisterFilter

IRP_MJ_SET_INFORMATION

IoGetTransactionParameterBlock

PFLT_GENERATE_FILE_NAME

PFLT_NORMALIZE_CONTEXT_CLEANUP

PFLT_NORMALIZE_NAME_COMPONENT

TXN_PARAMETER_BLOCK

UNICODE_STRING