Compartilhar via


Função ZwCommitEnlistment (wdm.h)

A rotina ZwCommitEnlistment inicia a operação de confirmação para uma transação de inscrição especificada.

Sintaxe

NTSYSCALLAPI NTSTATUS ZwCommitEnlistment(
  [in]           HANDLE         EnlistmentHandle,
  [in, optional] PLARGE_INTEGER TmVirtualClock
);

Parâmetros

[in] EnlistmentHandle

Um identificador para um objeto de inscrição que foi obtido por uma chamada anterior para ZwCreateEnlistment ou ZwOpenEnlistment. O objeto deve representar uma inscrição superior e o identificador deve ter ENLISTMENT_SUPERIOR_RIGHTS acesso ao objeto.

[in, optional] TmVirtualClock

Um ponteiro para um valor de relógio virtual. Esse parâmetro é opcional e pode ser NULL.

Retornar valor

ZwCommitEnlistment retornará STATUS_SUCCESS se a operação for bem-sucedida. Caso contrário, essa rotina pode retornar um dos seguintes valores:

Código de retorno Descrição
STATUS_OBJECT_TYPE_MISMATCH
O identificador especificado não é um identificador para um objeto de inscrição.
STATUS_INVALID_HANDLE
O identificador do objeto é inválido.
STATUS_ACCESS_DENIED
O chamador não tem acesso apropriado ao objeto de inscrição.
STATUS_ENLISTMENT_NOT_SUPERIOR
O chamador não é um gerenciador de transações superior para a inscrição.
STATUS_TRANSACTION_RESPONSE_NOT_ENLISTED
O chamador não se registrou para receber TRANSACTION_NOTIFY_COMMIT_COMPLETE notificações.
STATUS_TRANSACTION_REQUEST_NOT_VALID
A transação da inscrição não está em um estado que permite que ela seja confirmada.
STATUS_TRANSACTION_NOT_ACTIVE
A operação de confirmação para essa transação já foi iniciada.
STATUS_TRANSACTION_ALREADY_ABORTED
A transação não pode ser confirmada porque foi revertida.
 

A rotina pode retornar outros valores NTSTATUS.

Comentários

Somente gerenciadores de transações superiores podem chamar ZwCommitEnlistment.

Os chamadores de ZwCommitEnlistment devem se registrar para receber TRANSACTION_NOTIFY_COMMIT_COMPLETE notificações.

A rotina ZwCommitEnlistment faz com que o KTM envie TRANSACTION_NOTIFY_COMMIT notificações para todos os gerenciadores de recursos que se inscreveram na transação.

Para obter mais informações sobre ZwCommitEnlistment, consulte Criando um gerenciador de transações superior e tratando operações de confirmação.

Para chamadas de drivers de modo kernel, as versões NtXxx e ZwXxx de uma rotina do Windows Native System Services podem se comportar de forma diferente na maneira como lidam e interpretam parâmetros de entrada. Para obter mais informações sobre a relação entre as versões NtXxx e ZwXxx de uma rotina, consulte Using Nt and Zw Versions of the Native System Services Routines.

Requisitos

Requisito Valor
Cliente mínimo com suporte Disponível no Windows Vista e versões posteriores do sistema operacional.
Plataforma de Destino Universal
Cabeçalho wdm.h (include Wdm.h, Ntifs.h)
Biblioteca NtosKrnl.lib
DLL NtosKrnl.exe
IRQL PASSIVE_LEVEL
Regras de conformidade da DDI HwStorPortProhibitedDDIs(storport), PowerIrpDDis(wdm)

Confira também

TmCommitEnlistment

Usando versões Nt e Zw das rotinas de serviços do sistema nativo

ZwCreateEnlistment

ZwOpenEnlistment