构造读写IRP(转)
DDK示例中的代码。
NTSTATUS
FltReadSectors(
IN PDEVICE_OBJECT
DeviceObject,
OUT PVOID Buffer,
IN ULONG Length,
IN LONGLONG ByteOffset,
IN BOOLEAN Wait
)
{
PIRP irp;
IO_STATUS_BLOCK iosb;
KEVENT event;
NTSTATUS status;
irp =
IoBuildAsynchronousFsdRequest(IRP_MJ_READ, DeviceObject,
Buffer,
Length, (PLARGE_INTEGER) &ByteOffset, &iosb);
if (!irp)
{
return STATUS_INSUFFICIENT_RESOURCES;
}
if
(Wait) {
KeInitializeEvent(&event, NotificationEvent,
FALSE);
IoSetCompletionRoutine(irp,
FltReadWriteSectorsCompletion,
&event, TRUE, TRUE,
TRUE);
status = IoCallDriver(DeviceObject, irp);
if
(STATUS_PENDING == status) {
KeWaitForSingleObject(&event,
Executive, KernelMode, FALSE, NULL);
status = iosb.Status;
}
} else {
IoSetCompletionRoutine(irp,
FltReadWriteSectorsCompletion,
NULL, TRUE, TRUE, TRUE);
irp->UserIosb = NULL;
status = IoCallDriver(DeviceObject,
irp);
}
return
status;
}
NTSTATUS
FltWriteSectors(
IN PDEVICE_OBJECT
DeviceObject,
IN PVOID Buffer,
IN ULONG Length,
IN
LONGLONG ByteOffset,
IN BOOLEAN Wait
)
{
PIRP irp;
IO_STATUS_BLOCK iosb;
KEVENT event;
NTSTATUS status;
irp =
IoBuildAsynchronousFsdRequest(IRP_MJ_WRITE, DeviceObject,
Buffer,
Length, (PLARGE_INTEGER) &ByteOffset, &iosb);
if (!irp)
{
return STATUS_INSUFFICIENT_RESOURCES;
}
if
(Wait) {
KeInitializeEvent(&event, NotificationEvent,
FALSE);
IoSetCompletionRoutine(irp,
FltReadWriteSectorsCompletion,
&event, TRUE, TRUE,
TRUE);
status = IoCallDriver(DeviceObject, irp);
if
(STATUS_PENDING == status) {
KeWaitForSingleObject(&event,
Executive, KernelMode, FALSE, NULL);
status = iosb.Status;
}
} else {
IoSetCompletionRoutine(irp,
FltReadWriteSectorsCompletion,
NULL, TRUE, TRUE, TRUE);
irp->UserIosb = NULL;
status = IoCallDriver(DeviceObject,
irp);
}
return
status;
}
NTSTATUS
FltReadWriteSectorsCompletion(
IN
PDEVICE_OBJECT DeviceObject,
IN PIRP Irp,
IN PVOID
Context
)
{
PMDL mdl;
UNREFERENCED_PARAMETER(DeviceObject);
//
// Free
resources
//
if (Irp->AssociatedIrp.SystemBuffer
&& (Irp->Flags & IRP_DEALLOCATE_BUFFER)) {
ExFreePool(Irp->AssociatedIrp.SystemBuffer);
}
while
(Irp->MdlAddress) {
mdl = Irp->MdlAddress;
Irp->MdlAddress = mdl->Next;
MmUnlockPages(mdl);
IoFreeMdl(mdl);
}
if (Irp->PendingReturned &&
(Context != NULL)) {
*Irp->UserIosb = Irp->IoStatus;
KeSetEvent((PKEVENT) Context, IO_DISK_INCREMENT, FALSE);
}
IoFreeIrp(Irp);
//
// Don't touch irp
any more
//
return STATUS_MORE_PROCESSING_REQUIRED;
}
构造读写IRP(转)的更多相关文章
- IRP小结 0x01 IRP & IO_STACK_LOCATION(结合WRK理解)
写博客整理记录一下IRP相关的知识点,加深一下印象. 所有的I/O请求都是以IRP的形式提交的.当I/O管理器为了响应某个线程调用的的I/O API的时候,就会构造一个IRP,用于在I/O系统处理这个 ...
- USB设备驱动概述
USB设备驱动 · )USB Hub:每个USBHost控制器都会自带一个USB Hub,被称为根(Root)Hub.这个根Hub可以接子(Sub)Hub,每个Hub上挂载USB设备.一般PC有8个 ...
- [14]Windows内核情景分析 --- 文件系统
文件系统 一台机器上可以安装很多物理介质来存放资料(如磁盘.光盘.软盘.U盘等).各种物理介质千差万别,都配备有各自的驱动程序,为了统一地访问这些物理介质,windows设计了文件系统机制.应用程序要 ...
- [6]Windows内核情景分析 --APC
APC:异步过程调用.这是一种常见的技术.前面进程启动的初始过程就是:主线程在内核构造好运行环境后,从KiThreadStartup开始运行,然后调用PspUserThreadStartup,在该线程 ...
- Java 线程并发策略
1 什么是并发问题. 多个进程或线程同时(或着说在同一段时间内)访问同一资源会产生并发问题. 2 java中synchronized的用法 用法1 public class Test{ public ...
- java io读书笔记(8)FileInputStream/FileOutputStream的应用
转自:http://www.cnblogs.com/jjtech/archive/2011/04/17/2019210.html 这是一对继承于InputStream和OutputStream的类,用 ...
- Android系统在超级终端下必会的命令大全(adb shell命令大全)
. 显示系统中全部Android平台: android list targets . 显示系统中全部AVD(模拟器): android list avd . 创建AVD(模拟器): android c ...
- APC -- Asynchronous Procedure Call 异步过程调用
异步过程调用(APC -- Asynchronous Procedure Call )是一种与常用的和简单的同步对象不同的一种同步机制. 我们在我们线程里使用基本的同步对象如MUTEX去通知其它线程, ...
- 理解和使用NT驱动程序的执行上下文
理解Windows NT驱动程序最重要的概念之一就是驱动程序运行时所处的“执行上下文”.理解并小心地应用这个概念可以帮助你构建更快.更高效的驱动程序. NT标准内核模式驱动程序编程的一个重要观念是某个 ...
随机推荐
- 使用ApiPost测试接口时需要先登录的接口怎么办(基于Cookie)?
在后台在开发.调试接口时,常常会遇到需要登陆才能请求的接口. 比如:获取登陆用户的收藏列表,此时,我们就需要模拟登陆状态进行接口调试了.如图: 今天,我们讲解利用ApiPost的环境变量,解决这种需要 ...
- 10BASE
10BASE-T,10BASE-5,10BASE-2,以太网的技术标准,10Base-2.10Base-5.10Base-T都是以太网的技术标准,传输速率为10Mbps. 10Base-2技术以细 ...
- 面向对象设计原则 里氏替换原则(Liskov Substitution Principle)
里氏替换原则(Liskov Substitution Principle LSP)面向对象设计的基本原则之一. 里氏替换原则中说,任何基类可以出现的地方,子类一定可以出现. LSP是继承复用的基石,只 ...
- CSDN博客栏目设置个性化
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha ====== <a href=" http://weibo.com/23 ...
- 【转载】gdi+ 内存泄漏
[转载]http://issf.blog.163.com/blog/static/1941290822009111894413472/ 最近用GDI+实现了几个自定义控件,但是发现存在内存泄露问题 B ...
- QThreadPool线程池的使用,线程与Widget通过信号与槽的方式通信。
因为QRunnable类并非继承自QObject,不能使用信号和槽,为了能够使用信号与槽和Widget通信,需要对QRunnable进行封装. 定义一个类QMyRunnable,该类首先继承自QObj ...
- POP3_使用SSL链接邮箱并获取邮件
Gmail目前已经启用了POP3和SMTP服务,与其他邮箱不同的是Gmail提供的POP3和SMTP是使用安全套接字层SSL的,因此常规的JavaMail程序是无法收发邮件的,下面是使用JavaMai ...
- CentOS 7设置KVM硬盘模式为SCSI
找到一下节点,把target节点的dev改成s开头,bus改成scsi即可,并删除address节点: 以此内推,如果要修改为ide需要修改dev为h开头,bus改成ide. 参考: https:// ...
- 解决Android LogCat 输出乱码的问题(转)
Android日志系统提供了记录和查看系统调试信息的功能.日志都是从各种软件和一些系统的缓冲区中记录下来的. 可以使用adb的logcat 命令来查看系统日志缓冲区的内容,但是在实际操作时,会发现在C ...
- echarts 怎样去掉白色边框线 和怎样去除背景中的网格
echarts怎样去掉白色边框线: echarts怎样去除背景中的网格线