ExInterlockedPopEntrySList 함수(wdm.h)
ExInterlockedPopEntrySList 루틴은 순차적으로 연결된 목록에서 첫 번째 항목을 원자성으로 제거합니다.
통사론
NTKERNELAPI
PSLIST_ENTRY
FASTCALL
ExInterlockedPopEntrySList (
_Inout_ PSLIST_HEADER ListHead,
_Inout_opt_ _Requires_lock_not_held_(*_Curr_) PKSPIN_LOCK Lock
);
매개 변수
[in, out] ListHead
시퀀싱된 singly 연결된 목록의 헤더 역할을 하는 SLIST_HEADER 구조체에 대한 포인터입니다. ListHeadExInitializeSListHead호출하여 초기화되어야 합니다.
[in, out] Lock
목록에 대한 액세스를 동기화하는 데 사용되는 스핀 잠금 역할을 하는 KSPIN_LOCK 구조체에 대한 포인터입니다. 스핀 잠금에 대한 스토리지는 상주해야 하며 KeInitializeSpinLock호출하여 초기화되어야 합니다. Xxx목록 루틴에 ExInterlocked경우에만 이 스핀 잠금을 사용해야 합니다.
반환 값
ExInterlockedPopEntrySList 목록의 첫 번째 SLIST_ENTRY 구조체에 대한 포인터를 반환합니다. 목록이 비어 있으면 루틴은 NULL을 반환합니다.
발언
이 루틴을 사용하여 시퀀싱된 Singly 연결된 목록을 구현하는 방법에 대한 자세한 내용은 Singly 및 두 배로 연결된 목록참조하세요.
Windows 2000에서 드라이버는 -D_WIN2K_COMPAT_SLIST_USAGE 스위치를 사용하여 ExInterlockedPopEntrySList사용하는 코드를 성공적으로 연결해야 합니다.
ExInterlockedPopEntrySList 모든 IRQL에서 호출할 수 있습니다. ListHead 매개 변수의 스토리지는 모든 IRQL에 상주해야 합니다.
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 2000부터 사용할 수 있습니다. |
대상 플랫폼 | 보편적 |
헤더 | wdm.h(Wdm.h, Ntddk.h, Ntifs.h 포함) |
라이브러리 | NtosKrnl.lib |
DLL | NtosKrnl.exe |
IRQL | 모든 수준(설명 섹션 참조) |