33 DeviceQueue->Busy=
FALSE;
54 if (!DeviceQueue->Busy)
58 DeviceQueue->Busy =
TRUE;
102 if (!DeviceQueue->Busy)
106 DeviceQueue->Busy =
TRUE;
111 NextEntry = &DeviceQueue->DeviceListHead;
120 if (SortKey < LastEntry->
SortKey)
126 NextEntry = NextEntry->
Flink;
160 DPRINT(
"KeRemoveDeviceQueue() DevQueue %p\n", DeviceQueue);
164 ASSERT(DeviceQueue->Busy);
170 DeviceQueue->Busy =
FALSE;
205 DPRINT(
"KeRemoveByKeyDeviceQueue() DevQueue %p, SortKey 0x%x\n", DeviceQueue,
SortKey);
209 ASSERT(DeviceQueue->Busy);
215 DeviceQueue->Busy =
FALSE;
221 NextEntry = &DeviceQueue->DeviceListHead;
237 NextEntry = DeviceQueue->DeviceListHead.
Flink;
241 ASSERT(NextEntry != &DeviceQueue->DeviceListHead);
247 if (SortKey <= ReturnEntry->
SortKey)
break;
250 NextEntry = NextEntry->
Flink;
281 DPRINT(
"KeRemoveByKeyDeviceQueueIfBusy() DevQueue %p, SortKey 0x%x\n", DeviceQueue,
SortKey);
287 if (!(DeviceQueue->Busy) || (
IsListEmpty(&DeviceQueue->DeviceListHead)))
290 DeviceQueue->Busy =
FALSE;
296 NextEntry = &DeviceQueue->DeviceListHead;
312 NextEntry = DeviceQueue->DeviceListHead.
Flink;
316 ASSERT(NextEntry != &DeviceQueue->DeviceListHead);
322 if (SortKey <= ReturnEntry->
SortKey)
break;
325 NextEntry = NextEntry->
Flink;
359 ASSERT(DeviceQueue->Busy);
struct _KDEVICE_QUEUE KDEVICE_QUEUE
struct _LIST_ENTRY * Blink
_Inout_ PKDEVICE_QUEUE_ENTRY _In_ ULONG SortKey
FORCEINLINE VOID KiAcquireDeviceQueueLock(IN PKDEVICE_QUEUE DeviceQueue, IN PKLOCK_QUEUE_HANDLE DeviceLock)
VOID NTAPI KeInitializeDeviceQueue(IN PKDEVICE_QUEUE DeviceQueue)
#define InsertTailList(ListHead, Entry)
_Must_inspect_result_ FORCEINLINE BOOLEAN IsListEmpty(_In_ const LIST_ENTRY *ListHead)
FORCEINLINE BOOLEAN RemoveEntryList(_In_ PLIST_ENTRY Entry)
NTSTATUS(* NTAPI)(IN PFILE_FULL_EA_INFORMATION EaBuffer, IN ULONG EaLength, OUT PULONG ErrorOffset)
FORCEINLINE VOID KeInitializeSpinLock(_Out_ PKSPIN_LOCK SpinLock)
BOOLEAN NTAPI KeInsertByKeyDeviceQueue(IN PKDEVICE_QUEUE DeviceQueue, IN PKDEVICE_QUEUE_ENTRY DeviceQueueEntry, IN ULONG SortKey)
FORCEINLINE PLIST_ENTRY RemoveHeadList(_Inout_ PLIST_ENTRY ListHead)
PKDEVICE_QUEUE_ENTRY NTAPI KeRemoveByKeyDeviceQueueIfBusy(IN PKDEVICE_QUEUE DeviceQueue, IN ULONG SortKey)
PFLT_MESSAGE_WAITER_QUEUE CONTAINING_RECORD(Csq, DEVICE_EXTENSION, IrpQueue)) -> WaiterQ.mLock) _IRQL_raises_(DISPATCH_LEVEL) VOID NTAPI FltpAcquireMessageWaiterLock(_In_ PIO_CSQ Csq, _Out_ PKIRQL Irql)
struct _LIST_ENTRY * Flink
BOOLEAN NTAPI KeInsertDeviceQueue(IN PKDEVICE_QUEUE DeviceQueue, IN PKDEVICE_QUEUE_ENTRY DeviceQueueEntry)
BOOLEAN NTAPI KeRemoveEntryDeviceQueue(IN PKDEVICE_QUEUE DeviceQueue, IN PKDEVICE_QUEUE_ENTRY DeviceQueueEntry)
LIST_ENTRY DeviceListEntry
#define InitializeListHead(ListHead)
PKDEVICE_QUEUE_ENTRY NTAPI KeRemoveDeviceQueue(IN PKDEVICE_QUEUE DeviceQueue)
PKDEVICE_QUEUE_ENTRY NTAPI KeRemoveByKeyDeviceQueue(IN PKDEVICE_QUEUE DeviceQueue, IN ULONG SortKey)
FORCEINLINE VOID KiReleaseDeviceQueueLock(IN PKLOCK_QUEUE_HANDLE DeviceLock)
#define ASSERT_DEVICE_QUEUE(Object)
_Inout_ PKDEVICE_QUEUE_ENTRY DeviceQueueEntry