Función ExInterlockedInsertHeadList (wdm.h)
La rutina ExInterlockedInsertHeadList inserta de forma atómica una entrada al principio de una lista vinculada duplicada de estructuras de LIST_ENTRY .
Sintaxis
PLIST_ENTRY ExInterlockedInsertHeadList(
[in, out] PLIST_ENTRY ListHead,
[in, out] __drv_aliasesMem PLIST_ENTRY ListEntry,
[in, out] PKSPIN_LOCK Lock
);
Parámetros
[in, out] ListHead
Puntero a la estructura LIST_ENTRY que actúa como encabezado de lista.
[in, out] ListEntry
Puntero a la estructura LIST_ENTRY que representa la entrada que se va a insertar en la lista.
[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 número solo con las rutinas ExInterlockedXxxList .
Valor devuelto
ExInterlockedInsertHeadList devuelve un puntero a la primera entrada de la lista antes de insertar la nueva entrada. Si la lista estaba vacía, la rutina devuelve NULL.
Comentarios
ExInterlockedInsertHeadList realiza la misma operación que InsertHeadList, 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 doblemente, consulte Singly and Duplicay Linked Listas.
Se puede llamar a la rutina ExInterlockedInsertHeadList en cualquier IRQL. El almacenamiento para el parámetro ListHead y las entradas de lista deben estar residentes en todos los IRQL.