Поделиться через


Функция NtSetInformationEnlistment (wdm.h)

Подпрограмма ZwSetInformationEnlistment задает сведения для указанного объекта зачисления.

Синтаксис

__kernel_entry NTSYSCALLAPI NTSTATUS NtSetInformationEnlistment(
  [in] HANDLE                       EnlistmentHandle,
  [in] ENLISTMENT_INFORMATION_CLASS EnlistmentInformationClass,
  [in] PVOID                        EnlistmentInformation,
  [in] ULONG                        EnlistmentInformationLength
);

Параметры

[in] EnlistmentHandle

Дескриптор объекта зачисления, полученный при предыдущем вызове ZwCreateEnlistment или ZwOpenEnlistment. Дескриптор должен иметь ENLISTMENT_SET_INFORMATION доступ к объекту .

[in] EnlistmentInformationClass

ENLISTMENT_INFORMATION_CLASS типизированное значение перечисления, указывающее тип задающейся информации. Это значение должно быть EnlistmentRecoveryInformation.

Значения Перечисления EnlistmentBasicInformation и EnlistmentFullInformation не используются с ZwSetInformationEnlistment.

[in] EnlistmentInformation

Указатель на буфер, выделенный вызывающим объектом, который содержит определяемые вызывающим объектом сведения о восстановлении для зачисления.

[in] EnlistmentInformationLength

Длина (в байтах) буфера, на который указывает параметр EnlistmentInformation .

Возвращаемое значение

ZwSetInformationEnlistment возвращает STATUS_SUCCESS, если операция выполнена успешно. В противном случае эта подпрограмма может возвращать одно из следующих значений:

Код возврата Описание
STATUS_OBJECT_TYPE_MISMATCH
Указанный дескриптор не является дескриптором для объекта зачисления.
STATUS_INVALID_HANDLE
Недопустимый дескриптор объекта.
STATUS_INVALID_INFO_CLASS
Недопустимое значение параметра EnlistmentInformationClass .
STATUS_INFO_LENGTH_MISMATCH
Недопустимое значение параметра EnlistmentInformationLength .
STATUS_ACCESS_DENIED
Вызывающий объект не имеет соответствующего доступа к объекту зачисления.
 

Подпрограмма может возвращать другие значения NTSTATUS.

Комментарии

Диспетчер ресурсов может использовать подпрограмму ZwSetInformationEnlistment для задания сведений о восстановлении для зачисления. KTM записывает сведения о восстановлении в поток журнала, и диспетчер ресурсов может вызвать ZwQueryInformationEnlistment , чтобы в любое время считывать эти сведения из потока журнала.

Каждый последующий вызов ZwSetInformationEnlistment удаляет сведения о восстановлении, указанные в предыдущем вызове перед сохранением новых сведений о восстановлении.

Дополнительные сведения об использовании ZwSetInformationEnlistment см. в статье Использование потоков журналов с KTM.

NtSetInformationEnlistment и ZwSetInformationEnlistment — это две версии одной и той же подпрограммы windows Native System Services.

Для вызовов из драйверов режима ядра версии NtXxx и ZwXxx подпрограммы собственных системных служб Windows могут вести себя по-разному, так как они обрабатывают и интерпретируют входные параметры. Дополнительные сведения о связи между версиями процедуры NtXxx и ZwXxx см. в разделе Использование версий Nt и Zw для процедур собственных системных служб.

Требования

Требование Значение
Минимальная версия клиента Доступно в Windows Vista и более поздних версиях операционной системы.
Целевая платформа Универсальное
Верхняя часть wdm.h (включая Wdm.h, Ntddk.h, Ntifs.h)
Библиотека NtosKrnl.lib
DLL NtosKrnl.exe
IRQL PASSIVE_LEVEL
Правила соответствия DDI HwStorPortProhibitedDIs, PowerIrpDDis

См. также раздел

ENLISTMENT_INFORMATION_CLASS

Использование версий Nt и Zw собственных процедур системных служб

ZwCreateEnlistment

ZwOpenEnlistment

ZwQueryInformationEnlistment