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

Подпрограмма TmPrepareEnlistment инициирует операцию подготовки для транзакции указанного зачисления.

Синтаксис

NTSTATUS TmPrepareEnlistment(
  [in] PKENLISTMENT   Enlistment,
  [in] PLARGE_INTEGER TmVirtualClock
);

Параметры

[in] Enlistment

Указатель на объект зачисления. Компонент может получать этот указатель в качестве входных данных для подпрограммы обратного вызова ResourceManagerNotification . Кроме того, компонент может вызывать ObReferenceObjectByHandle и предоставлять дескриптор объекта, который был предоставлен при предыдущем вызове ZwCreateEnlistment, TmCreateEnlistment или ZwOpenEnlistment .

[in] TmVirtualClock

Указатель на значение виртуальных часов. Этот параметр является необязательным и может иметь значение NULL.

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

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

Код возврата Описание
STATUS_ENLISTMENT_NOT_SUPERIOR
Вызывающий объект не является превосходным диспетчером транзакций для зачисления.
STATUS_TRANSACTION_RESPONSE_NOT_ENLISTED
Вызывающий объект не зарегистрировался для получения уведомлений TRANSACTION_NOTIFY_PREPARE_COMPLETE.
STATUS_TRANSACTION_REQUEST_NOT_VALID
Транзакция зачисления не находится в состоянии, позволяющем ей перейти на этап подготовки.
STATUS_ACCESS_DENIED
Вызывающий объект не имеет соответствующего доступа к объекту зачисления.
 

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

Комментарии

Подпрограмма TmPrepareEnlistment — это версия подпрограммы ZwPrepareEnlistment на основе указателя .

Вызывать TmPrepareEnlistment могут только диспетчеры транзакций высшего звена.

Сведения о том, когда следует использовать подпрограммы KTM TmXxx вместо процедур ZwXxx , см. в разделе Использование подпрограмм TmXxxx.

Требования

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

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

ObReferenceObjectByHandle

ResourceManagerNotification

TmCreateEnlistment

ZwCreateEnlistment

ZwOpenEnlistment

ZwPrepareEnlistment