Partilhar via


Função FltAcquirePushLockSharedEx (fltkernel.h)

A rotina FltAcquirePushLockSharedEx adquire o bloqueio de push determinado para acesso compartilhado pelo thread de chamada.

Sintaxe

VOID FLTAPI FltAcquirePushLockSharedEx(
  PEX_PUSH_LOCK PushLock,
  ULONG         Flags
);

Parâmetros

PushLock

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

Flags

Uma máscara de bits de sinalizadores que controlam os atributos do bloqueio.

Valor de retorno

Nenhum.

Observações

A rotina FltAcquirePushLockSharedEx adquire o bloqueio de push determinado para acesso compartilhado pelo thread de chamada.

Os bloqueios por push são semelhantes às estruturas ERESOURCE (também chamados de recursos) na medida em que podem ser adquiridos para acesso compartilhado ou exclusivo. Para obter mais informações sobre bloqueios por 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 por 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 não for semeado 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 por push, o acesso compartilhado será concedido ao chamador imediatamente. O chamador é colocado em um estado de espera se houver um garçom exclusivo.

  • Se o bloqueio por 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 por push possa ser adquirido.

Requisitos

Requisito Valor
cabeçalho fltkernel.h
biblioteca FltMgr.lib

Consulte também

FltInitializePushLock