BOOLEAN
KeInsertByKeyDeviceQueue(
IN PKDEVICE_QUEUE DeviceQueue,
IN PKDEVICE_QUEUE_ENTRY DeviceQueueEntry,
IN ULONG SortKey
);
KeInsertByKeyDeviceQueue acquires the spin lock for the given DeviceQueue and queues an entry according to the given sort-key value if the state of the device queue is Busy.
If the device queue is empty, FALSE is returned, meaning the DeviceQueueEntry is not inserted in the device queue.
The given device queue spin lock is acquired and the state of the device queue is checked. If the state of the device queue is Busy, the IRP specified by the DeviceQueueEntry is inserted into the device queue according to its sort-key value and the device queue spin lock is released.
The new entry is positioned in the device queue after any entries in the queue with sort-key values less than or equal to its sort-key value and preceding any entries with sort-key values that are greater.
If KeInsertByKeyDeviceQueue returns FALSE, the caller must begin processing the IRP. A call to KeInsertDeviceQueue or KeInsertByKeyDeviceQueue when the queue is empty causes the device queue state transition from Not-Busy to Busy.
This routine is for code that queues an I/O request to a device driver.
Callers of KeInsertByKeyDeviceQueue must be running at IRQL DISPATCH_LEVEL.
KeInitializeDeviceQueue, KeInsertDeviceQueue, KeRemoveDeviceQueue, KeRemoveEntryDeviceQueue