다음을 통해 공유


FsRtlCopyWrite 함수(ntifs.h)

FsRtlCopyWrite 루틴은 사용자 버퍼에서 캐시된 파일로 데이터를 복사합니다.

통사론

BOOLEAN FsRtlCopyWrite(
  [in]  PFILE_OBJECT     FileObject,
  [in]  PLARGE_INTEGER   FileOffset,
  [in]  ULONG            Length,
  [in]  BOOLEAN          Wait,
  [in]  ULONG            LockKey,
  [in]  PVOID            Buffer,
  [out] PIO_STATUS_BLOCK IoStatus,
  [in]  PDEVICE_OBJECT   DeviceObject
);

매개 변수

[in] FileObject

데이터를 쓸 캐시된 파일의 파일 개체에 대한 포인터입니다.

[in] FileOffset

캐시된 파일 내의 시작 바이트 오프셋을 지정하는 변수에 대한 포인터입니다.

[in] Length

쓸 데이터의 길이(바이트)입니다.

[in] Wait

모든 데이터가 복사될 때까지 호출자를 대기 상태로 전환할 수 있으면 TRUE로 설정하고, 그렇지 않으면 FALSE로 설정합니다.

[in] LockKey

잠글 바이트 범위와 연결된 값입니다. 잠글 범위가 비클러스터적 잠금으로 이미 잠긴 다른 범위와 겹치거나 읽을 범위가 이미 비클러스터적으로 잠겨 있는 다른 범위의 하위 범위인 경우 이 매개 변수의 값은 비클러스터형 잠금의 키여야 합니다. 잠금은 호출 스레드의 부모 프로세스에 의해 유지되어야 합니다. 그렇지 않으면 이 매개 변수는 영향을 주지 않습니다.

[in] Buffer

데이터를 복사할 버퍼에 대한 포인터입니다.

[out] IoStatus

작업에 대한 최종 완료 상태 및 정보를 수신하는 호출자 할당 구조체에 대한 포인터입니다. 데이터가 성공적으로 복사되면 IoStatus.Status STATUS_SUCCESS 포함됩니다. 모든 데이터가 성공적으로 복사되지 않은 경우 IoStatus.Information 복사된 실제 바이트 수가 포함됩니다.

[in] DeviceObject

파일 데이터를 보유하는 탑재된 볼륨의 디바이스 개체에 대한 포인터입니다.

반환 값

FsRtlCopyWrite 복사 요청이 완료되면 TRUE를 반환하고, 그렇지 않으면 FALSE를 반환합니다. TRUE의 반환 값이 반드시 복사 작업이 성공했음을 의미하지는 않습니다.

FsRtlCopyWrite FALSE를 반환하거나 IoStatus의 내용이 복사 작업이 실패했음을 나타낼 경우 호출자는 FsRtlCopyWrite호출하는 대신 쓰기 IRP를 할당해야 합니다.

발언

파일 시스템별 빠른 I/O 쓰기 루틴을 구현하는 대신 파일 캐싱을 지원하는 파일 시스템 개발자는 빠른 I/O 쓰기 요청을 처리하기 위한 파일 시스템의 진입점으로 FsRtlCopyWrite 사용하는 것을 고려해야 합니다. 이렇게 하려면 파일 시스템의 DriverEntry 루틴이 파일 시스템 드라이버 개체의 FAST_IO_DISPATCH 구조에서 FsRtlCopyWrite FastIoWrite 진입점을 설정해야 합니다. 또한 파일 시스템은 다음을 수행해야 합니다.

  1. 빠른 I/O를 수행할 수 있는 각 파일에 대해 파일 시스템은 FSRTL_COMMON_FCB_HEADER 구조를 할당하고 초기화해야 합니다.

    대부분의 파일 시스템에서는 FCB(파일 제어 블록)에 FSRTL_COMMON_FCB_HEADER 구조체를 포함하거나 열려 있는 파일의 상태를 유지하는 데 사용되는 비교 가능한 구조를 포함하여 이 작업을 수행합니다.

    FSRTL_COMMON_FCB_HEADER 구조에 대한 스토리지는 일반적으로 페이징 풀에서 할당됩니다.

  2. 빠른 I/O를 수행할 수 있는 각 파일에 대해 파일 시스템은 파일의 모든 파일 개체를 FSRTL_COMMON_FCB_HEADER 구조에 연결해야 합니다. 이 작업은 각 파일 개체의 FsContext 멤버를 설정하여 이 구조체(또는 FCB 또는 FSRTL_COMMON_FCB_HEADER 구조체가 포함된 다른 구조체)를 가리킵니다.

  3. 파일을 캐싱할 때 파일 시스템은 파일 FSRTL_COMMON_FCB_HEADER 구조체의 IsFastIoPossible 멤버를 적절한 값으로 설정해야 합니다. 이 값은 파일이 캐시된 상태로 유지되는 동안 필요에 따라 업데이트해야 합니다.

    특히 파일 시스템은 캐시된 파일에 대한 배타적 바이트 범위 잠금이 있는 즉시 FSRTL_COMMON_FCB_HEADER 구조의 IsFastIoPossible 멤버를 fastIoIsQuestionable 설정해야 합니다.

Wait TRUE이면 FsRtlCopyWrite 데이터를 복사하고 TRUE를 반환합니다. 캐시된 파일의 필수 페이지가 이미 메모리에 있는 경우 데이터가 즉시 복사되고 차단이 발생하지 않습니다. 필요한 페이지가 없는 경우 모든 필수 페이지가 상주하고 데이터를 복사할 수 있을 때까지 호출자가 대기 상태로 전환됩니다.

Wait FALSE이면 FsRtlCopyWrite 차단을 거부하고 파일의 주 리소스를 가져올 수 없거나 캐시된 파일의 필수 페이지가 메모리에 아직 상주하지 않은 경우 FALSE를 반환합니다.

파일 시스템의 FastIoCheckIfPossible 루틴은 FileOffsetLength 정의된 바이트 범위가 호출자가 적절한 LockKey 값을 전달하지 않는 단독으로 잠긴 바이트 범위를 포함하지 않도록 합니다. 파일 시스템에서 FsRtlXxxLockYyy를 사용하는 경우 바이트 범위 잠금을 관리하는 루틴을 지원합니다. FsRtlCopyRead호출하기 전에 FastIoCheckIfPossible 루틴에서 FsRtlFastCheckLockForWrite 호출하여 이 작업을 수행할 수 있습니다.

파일을 캐시하려면 CcInitializeCacheMap 루틴을 사용합니다.

요구 사항

요구
대상 플랫폼 보편적
헤더 ntifs.h(Ntifs.h 포함)
라이브러리 NtosKrnl.lib
DLL NtosKrnl.exe
IRQL PASSIVE_LEVEL
DDI 규정 준수 규칙 HwStorPortProhibitedDDIs(storport), PowerIrpDDis(wdm)

참고 항목

ccInitializeCacheMap

FsRtlCopyRead

FsRtlFastCheckLockForWrite