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