PKDEVICE_QUEUE_ENTRY
KeRemoveByKeyDeviceQueue(
IN PKDEVICE_QUEUE DeviceQueue,
IN ULONG SortKey
);
KeRemoveByKeyDeviceQueue removes an entry, selected according to a sort-key value, from a given device queue.
Parameters
DeviceQueue
Points to an initialized device queue object for which the caller provides the storage.
SortKey
Specifies the position in the DeviceQueue from which the entry is to be removed.
Return Value
If the given device queue is empty but the device queue object’s state is Busy, KeRemoveByKeyDeviceQueue returns NULL.
Comments
It is an error to call KeRemoveByKeyDeviceQueue when the state of the device queue object is Not-Busy. If the state is Busy and an IRP is queued, this routine dequeues the entry and returns a pointer to the IRP. A call to KeRemoveByKeyDeviceQueue when the state of the device queue object is Busy but no IRPs are queued causes the state transition to Not-Busy.
Callers of KeRemoveByKeyDeviceQueue must be running at IRQL DISPATCH_LEVEL.
See Also
KeInitializeDeviceQueue, KeInsertByKeyDeviceQueue, KeInsertDeviceQueue, KeRemoveDeviceQueue, KeRemoveEntryDeviceQueue