Compartir a través de


Función ExAcquireSpinLockShared (wdm.h)

La rutina exAcquireSpinLockShare d adquiere un bloqueo de giro para el acceso compartido por parte del autor de la llamada y genera irQL en DISPATCH_LEVEL.

Sintaxis

KIRQL ExAcquireSpinLockShared(
  [in, out] PEX_SPIN_LOCK SpinLock
);

Parámetros

[in, out] SpinLock

Puntero al bloqueo de número que se va a adquirir para el acceso compartido. El autor de la llamada aún no debe poseer este bloqueo de giro.

Valor devuelto

La rutina ExAcquireSpinLockShared devuelve el valor IRQL anterior. Para obtener más información, consulte la sección comentarios de.

Observaciones

Al entrar a esta rutina, el autor de la llamada debe ejecutarse en IRQL <= DISPATCH_LEVEL. Esta rutina genera irQL para DISPATCH_LEVEL y devuelve el valor IRQL original (entrada).

Para liberar el bloqueo de número, llame a la rutina exReleaseSpinLockShared. ExReleaseSpinLockShared restaura irQL al valor original que tenía al entrar a ExAcquireSpinLockShared.

Un bloqueo de número es una variable de 32 bits de tipo EX_SPIN_LOCK. El controlador debe asignar el almacenamiento para el bloqueo de giro e inicializar el bloqueo de giro en cero. Este almacenamiento debe encontrarse en memoria de espacio del sistema no paginada.

El autor de la llamada debe contener el bloqueo de giro solo brevemente antes de liberarlo. Para obtener más información, vea Introducción a los bloqueos de número.

La adquisición recursiva de un bloqueo de número provoca interbloqueo y no se permite.

Requisitos

Requisito Valor
encabezado de wdm.h
irQL DISPATCH_LEVEL (ver comentarios).

Consulte también

ExReleaseSpinLockShared