Compartilhar via


Macro ExAcquirePushLockShared (wdm.h)

Adquire o bloqueio de push determinado para acesso compartilhado pelo thread de chamada.

Sintaxe

void ExAcquirePushLockShared(
   Lock
);

Parâmetros

Lock

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

Valor de retorno

Nenhum

Observações

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 ExInitializePushLock.

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.

Para liberar o bloqueio por push depois de adquirido, chame ExReleasePushLockShared. Cada chamada para ExAcquirePushLockShared deve ser correspondida por uma chamada subsequente para ExReleasePushLockShared.

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.

Antes de chamar essa rotina, o driver deve desabilitar a entrega normal do Kernel APC chamando KeEnterCriticalRegion. Entrega reencável depois que o bloqueio por push é liberado chamando KeLeaveCriticalRegion. Para obter mais informações, consulte Desabilitando APCs.

Para adquirir um bloqueio por push para acesso exclusivo, chame ExAcquirePushLockExclusive .

Requisitos

Requisito Valor
de cliente com suporte mínimo Windows 10, versão 1809
cabeçalho wdm.h

Consulte também

ExInitializePushLock

KeEnterCriticalRegion

ExReleasePushLockShared

ExAcquirePushLockExclusive