NtRollforwardTransactionManager 함수(wdm.h)
ZwRollforwardTransactionManager 루틴은 지정된 트랜잭션 관리자에 할당된 진행 중인 모든 트랜잭션에 대한 복구 작업을 시작합니다.
구문
__kernel_entry NTSYSCALLAPI NTSTATUS NtRollforwardTransactionManager(
[in] HANDLE TransactionManagerHandle,
[in, optional] PLARGE_INTEGER TmVirtualClock
);
매개 변수
[in] TransactionManagerHandle
ZwCreateTransactionManager 또는 ZwOpenTransactionManager에 대한 이전 호출에서 가져온 트랜잭션 관리자 개체에 대한 핸들입니다. 핸들에는 개체에 대한 TRANSACTIONMANAGER_RECOVER 액세스 권한이 있어야 합니다.
[in, optional] TmVirtualClock
가상 클록 값에 대한 포인터입니다. 이 매개 변수는 선택 사항이며 NULL일 수 있습니다. 이 매개 변수에 대한 자세한 내용은 다음 설명 섹션을 참조하세요.
반환 값
작업이 성공하면 ZwRollforwardTransactionManager가 STATUS_SUCCESS 반환합니다. 그렇지 않으면 이 루틴이 다음 값 중 하나를 반환할 수 있습니다.
반환 코드 | 설명 |
---|---|
|
지정된 핸들은 트랜잭션 관리자 개체에 대한 핸들이 아닙니다. |
|
개체 핸들이 잘못되었습니다. |
|
호출자에게 트랜잭션 관리자 개체에 대한 적절한 액세스 권한이 없습니다. |
|
지정된 트랜잭션 관리자 개체에 로그 파일이 없으므로 복구를 사용할 수 없습니다. |
|
지정된 트랜잭션 관리자 개체가 예기치 않은 상태입니다. |
루틴은 다른 NTSTATUS 값을 반환할 수 있습니다.
설명
ZwRollforwardTransactionManager 루틴은 TmVirtualClock 매개 변수가 제공하는 가상 클록 값을 포함하여 KTM이 트랜잭션 관리자의 로그 파일에서 찾은 모든 기록된 작업을 복구합니다.
구성 요소는 ZwRollforwardTransactionManager 를 반복적으로 호출하고 VirtualClock 매개 변수를 각 호출 전에 더 높은 값으로 설정하여 로그 파일을 증분 방식으로 트래버스할 수 있습니다.
TmVirtualClock 매개 변수가 NULL인 경우 ZwRollforwardTransactionManager를 호출하는 것은 ZwRecoverTransactionManager를 호출하는 것과 같습니다.
복구 작업에 대한 자세한 내용은 복구 작업 처리를 참조하세요.
NtRollforwardTransactionManager 및 ZwRollforwardTransactionManager 는 동일한 Windows 네이티브 시스템 서비스 루틴의 두 버전입니다. Windows 커널의 NtRollforwardTransactionManager 루틴은 커널 모드 드라이버에서 직접 액세스할 수 없습니다. 그러나 커널 모드 드라이버는 ZwRollforwardTransactionManager 루틴을 호출하여 이 루틴에 간접적으로 액세스할 수 있습니다.
커널 모드 드라이버에서 호출하는 경우 Windows 네이티브 시스템 서비스 루틴의 NtXxx 및 ZwXxx 버전은 입력 매개 변수를 처리하고 해석하는 방식으로 다르게 동작할 수 있습니다. 루틴의 NtXxx 버전과 ZwXxx 버전 간의 관계에 대한 자세한 내용은 네이티브 시스템 서비스 루틴의 Nt 및 Zw 버전 사용을 참조하세요.
요구 사항
요구 사항 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows Vista 및 이후 버전의 Windows에서 사용할 수 있습니다. |
대상 플랫폼 | 유니버설 |
헤더 | wdm.h(Wdm.h, Ntddk.h, Ntifs.h 포함) |
라이브러리 | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | PASSIVE_LEVEL |
DDI 규정 준수 규칙 | HwStorPortProhibitedDDIs, PowerIrpDDis |