функция обратного вызова IO_CSQ_INSERT_IRP (wdm.h)
Подпрограмма CsqInsertIrp используется системой для вставки IRP в реализованную драйвером, безопасную для отмены очередь IRP.
Синтаксис
IO_CSQ_INSERT_IRP IoCsqInsertIrp;
void IoCsqInsertIrp(
[in] _IO_CSQ *Csq,
[in] PIRP Irp
)
{...}
Параметры
[in] Csq
Указатель на структуру IO_CSQ для очереди IRP с безопасной отменой.
[in] Irp
Указатель на IRP для вставки в очередь IRP.
Возвращаемое значение
None
Remarks
Драйвер указывает подпрограмму CsqInsertIrp для безопасной с отменой очереди IRP при инициализации структуры IO_CSQ очереди. Драйвер указывает подпрограмму в качестве параметра CsqInsertIrpioCsqInitialize при инициализации IO_CSQ. Дополнительные сведения см. в разделе Отмена безопасных очередей IRP.
Процедуры IoCsqInsertIrp и IoCsqInsertIrpEx вызывают CsqInsertIrp , чтобы вставить IRP в очередь.
Примеры
Чтобы определить подпрограмму обратного вызова CsqInsertIrp , необходимо сначала предоставить объявление функции, определяющее тип определяемой процедуры обратного вызова. Windows предоставляет набор типов функций обратного вызова для драйверов. Объявление функции с помощью типов функций обратного вызова помогает анализу кода для драйверов, средству проверки статических драйверов (SDV) и другим средствам проверки находить ошибки, и это требование для написания драйверов для операционной системы Windows.
Например, чтобы определить подпрограмму обратного вызова CsqInsertIrp с именем MyCsqInsertIrp
, используйте тип IO_CSQ_INSERT_IRP, как показано в следующем примере кода:
IO_CSQ_INSERT_IRP MyCsqInsertIrp;
Затем реализуйте процедуру обратного вызова следующим образом:
_Use_decl_annotations_
NTSTATUS
MyCsqInsertIrp(
struct _IO_CSQ *Csq,
PIRP Irp
)
{
// Function body
}
Тип функции IO_CSQ_INSERT_IRP определяется в файле заголовка Wdm.h. Чтобы более точно определить ошибки при запуске средств анализа кода, обязательно добавьте заметку в _Use_decl_annotations_
определение функции. Заметка _Use_decl_annotations_
гарантирует, что будут использоваться заметки, которые применяются к типу функции IO_CSQ_INSERT_IRP в файле заголовка. Дополнительные сведения о требованиях к объявлениям функций см. в разделе Объявление функций с помощью типов ролей функций для драйверов WDM. Дополнительные сведения о _Use_decl_annotations_
см. в статье Поведение функции с заметками.
Требования
Требование | Значение |
---|---|
Целевая платформа | Персональный компьютер |
Верхняя часть | wdm.h (включая Wdm.h, Ntddk.h, Ntifs.h) |