fltAllocateCallbackData 函数 (fltkernel.h)
FltAllocateCallbackData 分配微筛选器驱动程序可用于启动 I/O 请求的回调数据结构。
语法
NTSTATUS FLTAPI FltAllocateCallbackData(
[in] PFLT_INSTANCE Instance,
[in, optional] PFILE_OBJECT FileObject,
[out] PFLT_CALLBACK_DATA *RetNewCallbackData
);
参数
[in] Instance
启动 I/O 操作的微筛选器驱动程序实例的不透明实例指针。 此参数是必需的,不能为 NULL。
[in, optional] FileObject
要用于 I/O 操作的文件对象指针。 此参数是可选的,可以为 NULL。
[out] RetNewCallbackData
指向调用方分配的变量的指针,该变量接收新分配的回调数据的地址 (FLT_CALLBACK_DATA) 结构。
返回值
FltAllocateCallbackData 返回STATUS_SUCCESS或相应的 NTSTATUS 值,如下所示:
返回代码 | 说明 |
---|---|
|
尝试分配回调数据结构时,FltAllocateCallbackData 遇到池分配失败。 这是错误代码。 |
注解
微筛选器驱动程序可以调用 FltAllocateCallbackData ,为微筛选器驱动程序启动的 I/O 操作分配回调数据 (FLT_CALLBACK_DATA) 结构。
初始化 FltAllocateCallbackData 返回的回调数据结构的参数后,调用方通过将结构传递给 FltPerformSynchronousIo 或 FltPerformAsynchronousIo 来启动 I/O 操作。 这些例程仅将 I/O 操作发送到在 实例 参数 () 中指定的启动实例下面附加的微筛选器驱动程序实例,并发送到文件系统。 附加到指定实例上方的微筛选器驱动程序不会接收 I/O 操作。
微筛选器驱动程序只能启动基于 IRP 的 I/O 操作。 它们无法启动快速 I/O 或文件系统筛选器 (FSFilter) 回调操作。
微型筛选器驱动程序应仅将 FltAllocateCallbackData、 FltPerformAsynchronousIo 和 FltPerformSynchronousIo 用于无法使用以下例程的 I/O 操作:
不再需要 FltAllocateCallbackData 分配的回调数据结构时,调用方负责通过调用 FltFreeCallbackData 来释放它。
要求
要求 | 值 |
---|---|
目标平台 | 通用 |
标头 | fltkernel.h (包括 Fltkernel.h) |
Library | FltMgr.lib |
IRQL | <= APC_LEVEL |