Función ExAcquireSpinLockShared (wdm.h)

La rutina ExAcquireSpinLockShared adquiere un bloqueo de número para el acceso compartido por parte del autor de la llamada y eleva irQL a 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 número.

Valor devuelto

La rutina ExAcquireSpinLockShared devuelve el valor IRQL anterior. Para más información, vea la sección Comentarios.

Comentarios

Al entrar en 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 (en entrada).

Para liberar el bloqueo de número, llame a la rutina ExReleaseSpinLockShared . ExReleaseSpinLockShared restaura irQL al valor original que tenía en la entrada 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 número e inicializar el bloqueo de número en cero. Este almacenamiento debe encontrarse en memoria de espacio del sistema no paginado.

El autor de la llamada debe contener el bloqueo de giro solo brevemente antes de liberarlo. Para obtener más información, consulte 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
Header wdm.h
IRQL DISPATCH_LEVEL (ver comentarios).

Consulte también

ExReleaseSpinLockShared