Partilhar via


Macro ExAcquirePushLockShared (wdm.h)

Adquire o bloqueio de push fornecido 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.

Retornar valor

Nenhum

Comentários

Os bloqueios por push são semelhantes às estruturas ERESOURCE (também chamadas de recursos), pois podem ser adquiridos para acesso compartilhado ou exclusivo. Para obter mais informações sobre bloqueios de 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 de push para acesso compartilhado, ele poderá receber acesso compartilhado novamente.

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

Quando o chamador recebe acesso compartilhado ao bloqueio de push determinado depende do seguinte:

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

  • Se o bloqueio de 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 é colocado em um 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.

Antes de chamar essa rotina, o driver deve desabilitar a entrega normal de APC do kernel chamando KeEnterCriticalRegion. Reabilite a entrega depois que o bloqueio de push for liberado chamando KeLeaveCriticalRegion. Para obter mais informações, consulte Desabilitando APCs.

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

Requisitos

Requisito Valor
Cliente mínimo com suporte Windows 10, versão 1809
Cabeçalho wdm.h

Confira também

ExInitializePushLock

KeEnterCriticalRegion

ExReleasePushLockShared

ExAcquirePushLockExclusive