Macro ExAcquirePushLockShared (wdm.h)

Adquiere el bloqueo de inserción especificado para el acceso compartido mediante el subproceso que realiza la llamada.

Sintaxis

void ExAcquirePushLockShared(
   Lock
);

Parámetros

Lock

Puntero de bloqueo de inserción opaco. Este puntero debe haberse inicializado mediante una llamada anterior a ExInitializePushLock.

Valor devuelto

None

Observaciones

Los bloqueos de inserción son similares a las estructuras ERESOURCE (también denominadas recursos) en que se pueden adquirir para el acceso compartido o exclusivo. Para obtener más información sobre los bloqueos de inserción, vea la entrada de referencia para ExInitializePushLock.

A diferencia de las estructuras ERESOURCE, los bloqueos de inserción no se pueden adquirir de forma recursiva. Si el autor de la llamada ya ha adquirido el bloqueo de inserción para el acceso exclusivo, el sistema se bloqueará. Si el autor de la llamada ya ha adquirido el bloqueo de inserción para el acceso compartido, puede volver a recibir acceso compartido.

Para liberar el bloqueo de inserción después de adquirirlo, llame a ExReleasePushLockShared. Cada llamada a ExAcquirePushLockShared debe coincidir con una llamada posterior a ExReleasePushLockShared.

Cuando el autor de la llamada tenga acceso compartido al bloqueo de inserción especificado depende de lo siguiente:

  • Si el bloqueo de inserción no está propietario actualmente, se concede acceso compartido inmediatamente al subproceso actual.

  • Si otro subproceso ya ha adquirido el bloqueo de inserción para el acceso compartido y no hay ningún subproceso esperando acceso exclusivo al bloqueo de inserción, el acceso compartido se concede al autor de la llamada inmediatamente. El autor de la llamada se coloca en un estado de espera si hay un camarero exclusivo.

  • Si otro subproceso ya ha adquirido el bloqueo de inserción para el acceso exclusivo o si hay otro subproceso esperando acceso exclusivo, el subproceso actual se coloca en un estado de espera hasta que se pueda adquirir el bloqueo de inserción.

Antes de llamar a esta rutina, el controlador debe deshabilitar la entrega normal del kernel APC mediante una llamada a KeEnterCriticalRegion. Entrega reenable después de liberar el bloqueo de inserción llamando a KeLeaveCriticalRegion. Para obtener más información, vea Deshabilitar LAS API.

Para adquirir un bloqueo de inserción para el acceso exclusivo, llame a ExAcquirePushLockExclusive.

Requisitos

Requisito Value
Cliente mínimo compatible Windows 10, versión 1809
Encabezado wdm.h

Consulte también

ExInitializePushLock

KeEnterCriticalRegion

ExReleasePushLockShared

ExAcquirePushLockExclusive