Função FltAcquirePushLockShared (fltkernel.h)

A rotina FltAcquirePushLockShared adquire o bloqueio de push fornecido para acesso compartilhado pelo thread de chamada.

Sintaxe

VOID FLTAPI FltAcquirePushLockShared(
  [in, out] PEX_PUSH_LOCK PushLock
);

Parâmetros

[in, out] PushLock

Ponteiro de bloqueio de push opaco do tipo PEX_PUSH_LOCK. Esse ponteiro deve ter sido inicializado por uma chamada anterior para FltInitializePushLock.

Valor retornado

Nenhum.

Comentários

A rotina FltAcquirePushLockShared adquire o bloqueio de push fornecido para acesso compartilhado pelo thread de chamada.

Os bloqueios por push são semelhantes às estruturas ERESOURCE (também chamadas de recursos) na medida em que podem ser adquiridos para acesso compartilhado ou exclusivo. Para obter mais informações sobre bloqueios de push, consulte a entrada de referência para FltInitializePushLock.

Ao contrário das estruturas ERESOURCE, os bloqueios de push não podem ser adquiridos recursivamente. Se o chamador já tiver adquirido o bloqueio de push para acesso exclusivo, o sistema será travado. Se o chamador já tiver adquirido o bloqueio de push para acesso compartilhado, ele poderá receber acesso compartilhado novamente. No entanto, cada chamada para FltAcquirePushLockShared deve ser correspondida por uma chamada subsequente para FltReleasePushLock.

Quando o chamador receberá acesso compartilhado ao bloqueio de push especificado, depende do seguinte:

  • Se o bloqueio por push estiver sem proprietário no momento, o acesso compartilhado será concedido imediatamente ao thread atual.

  • Se o bloqueio por push já tiver sido adquirido para acesso compartilhado por outro thread e nenhum thread estiver aguardando acesso exclusivo ao bloqueio de push, o acesso compartilhado será concedido ao chamador imediatamente. O chamador será colocado em estado de espera se houver um garçom exclusivo.

  • Se o bloqueio de push já tiver sido adquirido para acesso exclusivo por outro thread ou se houver outro thread aguardando acesso exclusivo, o thread atual será colocado em um estado de espera até que o bloqueio de push possa ser adquirido.

Como FltAcquirePushLockShared desabilita a entrega normal do kernel APC, não é necessário chamar KeEnterCriticalRegion ou FsRtlEnterFileSystem antes de chamar FltAcquirePushLockShared.

Para liberar o bloqueio de push depois que ele for adquirido, chame FltReleasePushLock. Cada chamada para FltAcquirePushLockShared deve ser correspondida por uma chamada subsequente para FltReleasePushLock.

Para adquirir um bloqueio de push para acesso exclusivo, chame FltAcquirePushLockExclusive.

Para inicializar um bloqueio por push, chame FltInitializePushLock.

Para excluir um bloqueio por push, chame FltDeletePushLock.

Requisitos

Requisito Valor
Plataforma de Destino Universal
Cabeçalho fltkernel.h (inclua Fltkernel.h)
Biblioteca FltMgr.lib
IRQL <= APC_LEVEL

Confira também

FltAcquirePushLockExclusive

FltAcquirePushLockSharedEx

FltDeletePushLock

FltInitializePushLock

FltReleasePushLock

FsRtlEnterFileSystem

KeEnterCriticalRegion