构造读写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标准内核模式驱动程序编程的一个重要观念是某个 ...
随机推荐
- Redis 复制原理及分析
1.测试 见master-slave测试帖 2 原理 第一次.Slave向Master同步的实现是: Slave向Master发出同步请求(发送sync命令),Master先dump出rdb文件,然后 ...
- Android 获取手机信息,设置权限,申请权限,查询联系人,获取手机定位信息
Android 获取手机信息,设置权限,申请权限,查询联系人,获取手机定位信息 本文目录: 获取手机信息 设置权限 申请权限 查询联系人 获取手机定位信息 调用高德地图,设置显示2个坐标点的位置,以及 ...
- spring boot 集成 shiro
写在前面 1.Shiro是Apache下的一个开源项目,我们称之为Apache Shiro.它是一个很易用与Java项目的的安全框架,提供了认证.授权.加密.会话管理,与spring Security ...
- FireDAC 下的 Sqlite [1] - 前言
很长时间没静下心来写博客了, 现在回来, 是 Delphi 不断地进步让我感动.振奋. Delphi XE5 并入了 FireDAC, 第一印象非常好, 恐怕 dbExpress 等等都要靠边站了. ...
- Android四种Activity的加载模式
建议首先阅读下面两篇文章,这样才可以更好的理解Activity的加载模式: Android的进程,线程模型 http://www.cnblogs.com/ghj1976/archive/2011/04 ...
- BrowserLog——使用Chrome控制台作为Log查看器
Chrome控制台是十分强大的,即使将它作为一个log查看器也是非常强大的,BrowserLog就是一个.net下的把Chrome作为log输出的程序包. 原理非常简单,server端将log数据通过 ...
- LPCScrypt, DFUSec : USB FLASH download, programming, and security tool, LPC-Link 2 Configuration tool, Firmware Programming
What does this tool do? The LPC18xx/43xx DFUSec utility is a Windows PC tool that provides support f ...
- STM32 通用定时器相关寄存器
TIMx_CR1(控制寄存器1) 9-8位:CKD[1:0]时钟分频因子,定义在定时器时钟(CK_INT)频率与数字滤波器(ETR,TIx)使用的采样频率之间的分频比例. 定义:00(tDTS = t ...
- [Go] 判断 文件/文件夹 是否存在?
Golang 判断文件是否存在有点怪异,是根据在操作文件时返回的错误信息来判断的,而不能直接根据路径判断 版本1: func IsExists(path string) (bool, error) { ...
- Linux kernel AIO
http://blog.csdn.net/abcd1f2/article/details/47440087