NtUnlockFile 함수(ntifs.h)
NtUnlockFile 루틴은 파일의 바이트 범위 잠금을 잠금 해제합니다.
통사론
__kernel_entry NTSYSCALLAPI NTSTATUS NtUnlockFile(
[in] HANDLE FileHandle,
[out] PIO_STATUS_BLOCK IoStatusBlock,
[in] PLARGE_INTEGER ByteOffset,
[in] PLARGE_INTEGER Length,
[in] ULONG Key
);
매개 변수
[in] FileHandle
바이트 범위의 잠금을 해제할 파일을 나타내는 파일 개체에 대한 핸들입니다.
[out] IoStatusBlock
최종 상태를 포함하는 IO_STATUS_BLOCK 구조체에 대한 포인터입니다.
[in] ByteOffset
잠금을 해제할 바이트 범위의 시작 바이트 오프셋을 지정하는 변수에 대한 포인터입니다.
[in] Length
잠금을 해제할 바이트 범위의 길이(바이트)를 지정하는 변수에 대한 포인터입니다.
[in] Key
관련된 잠금 그룹을 설명하는 데 사용되는 호출자 할당 값입니다. 이 값은 0으로 설정해야 합니다.
반환 값
NtUnlockFile 루틴은 성공 또는 적절한 NTSTATUS 값에 대한 STATUS_SUCCESS 반환합니다. 가능한 NTSTATUS 값은 다음과 같습니다.
반환 코드 | 묘사 |
---|---|
STATUS_RANGE_NOT_LOCKED | 지정된 바이트 범위가 잠겨 있지 않습니다. |
발언
NtUnlockFile 루틴은 ByteOffset 지정된 바이트 범위와 Length 인수를 사용합니다. 이 범위는 이전에 NtUnlockFile 루틴에 대한 단일 호출로 잠긴 파일의 바이트 범위와 동일해야 합니다. NtUnlockFile한 번의 호출로 이전에 잠긴 인접한 두 범위의 잠금을 해제할 수 없습니다. NtUnlockFile 루틴에 대한 단일 호출로 이전에 잠긴 범위의 일부를 잠금 해제할 수도 없습니다.
NtUnlockFile 호출자는 IRQL = PASSIVE_LEVEL 및 특수 커널 APC를 사용하도록 설정된 **실행되어야 합니다.
메모
커널 모드에서 NtUnlockFile 함수에 대한 호출이 발생하는 경우 "NtUnlockFile" 대신 "ZwUnlockFile" 이름을 사용해야 합니다.
커널 모드 드라이버의 호출의 경우 NtXxx 및 ZwXxx 버전의 Windows Native System Services 루틴은 입력 매개 변수를 처리하고 해석하는 방식으로 다르게 동작할 수 있습니다.
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 7 |
대상 플랫폼 | 보편적 |
헤더 | ntifs.h(Ntifs.h, FltKernel.h 포함) |
라이브러리 | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL |
PASSIVE_LEVEL(설명 섹션 참조) |
DDI 규정 준수 규칙 |
HwStorPortProhibitedDDIs, PowerIrpDDis |
참고 항목
네이티브 시스템 서비스 루틴 Nt 및 Zw 버전 사용