Compartir a través de


Función ExInterlockedPopEntryList (wdm.h)

El ExInterlockedPopEntryList rutina quita de forma atómica una entrada desde el principio de una lista vinculada singly de estructuras de SINGLE_LIST_ENTRY.

Sintaxis

PSINGLE_LIST_ENTRY ExInterlockedPopEntryList(
  [in, out] PSINGLE_LIST_ENTRY ListHead,
  [in, out] PKSPIN_LOCK        Lock
);

Parámetros

[in, out] ListHead

Puntero a la estructura SINGLE_LIST_ENTRY que actúa como encabezado de lista. El almacenamiento de ListHead debe estar residente en todos los IRQL.

[in, out] Lock

Puntero a una estructura de KSPIN_LOCK que actúa como bloqueo de número usado para sincronizar el acceso a la lista. El almacenamiento del bloqueo de número debe estar residente y debe haberse inicializado llamando a KeInitializeSpinLock. Debe usar este bloqueo de giro solo con las rutinas deXxxList ExInterlocked.

Valor devuelto

ExInterlockedPopEntryList devuelve un puntero a la estructura SINGLE_LIST_ENTRY quitada de la lista. Si la lista estaba vacía, la rutina devuelve NULL.

Observaciones

ExInterlockedPopEntryList realiza la misma operación que PopEntryList, pero atómicamente. No combine llamadas atómicas y no atómicas en la misma lista.

Para obtener más información sobre el uso de esta rutina para implementar una lista vinculada singly, vea Listas vinculadas duplicadas y.

Se puede llamar a la rutina ExInterlockedPopEntryList en cualquier IRQL. El almacenamiento del parámetro ListHead debe estar residente en todos los IRQLs.

Requisitos

Requisito Valor
cliente mínimo admitido Disponible a partir de Windows 2000.
de la plataforma de destino de Universal
encabezado de wdm.h (include Wdm.h, Ntddk.h, Ntifs.h)
biblioteca de NtosKrnl.lib
DLL de NtosKrnl.exe
irQL Cualquier nivel (consulte la sección Comentarios)

Consulte también

ExInitializeSListHead

ExInterlockedPopEntrySList

ExInterlockedPushEntryList

keInitializeSpinLock

popEntryList