派遣函数学习3)其他方式读写设备
来源:互联网 发布:js json 数组 编辑:程序博客网 时间:2024/05/29 14:36
首先 既不设置 DO_DIRECT_IO / DO_BUFFER_IO
派遣函数直接读写应用程序提供的缓冲区地址。 直接操应用程序的缓冲区地址是很危险的
只有驱动程序与应用程序运行再相同线程上下文的时候,才能用这种方式
探测可读可写用: ProbeForWrite + try 块
NTSTATUS HelloDDKRead(IN PDEVICE_OBJECT pDevObj, IN PIRP pIrp) {KdPrint(("Enter HelloDDKRead\n"));PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)pDevObj->DeviceExtension;NTSTATUS status = STATUS_SUCCESS;//得到当前堆栈PIO_STACK_LOCATION stack = IoGetCurrentIrpStackLocation(pIrp);//得到读的长度ULONG ulReadLength = stack->Parameters.Read.Length;//得到读的偏移量ULONG ulReadOffset = (ULONG)stack->Parameters.Read.ByteOffset.QuadPart;//得到用户模式地址PVOID user_address = pIrp->UserBuffer;KdPrint(("user_address:0X%0X\n",user_address));__try{KdPrint(("Enter __try block\n"));//判断空指针是否可写,显然会导致异常ProbeForWrite(user_address,ulReadLength,4);memset(user_address,0xAA,ulReadLength);//由于在上面引发异常,所以以后语句不会被执行!KdPrint(("Leave __try block\n"));}__except(EXCEPTION_EXECUTE_HANDLER){KdPrint(("Catch the exception\n"));KdPrint(("The program will keep going\n"));status = STATUS_UNSUCCESSFUL;}pIrp->IoStatus.Status = status;pIrp->IoStatus.Information = ulReadLength;// bytes xferedIoCompleteRequest( pIrp, IO_NO_INCREMENT );KdPrint(("Leave HelloDDKRead\n"));return status;}
- 派遣函数学习3)其他方式读写设备
- 派遣函数(2) - 设备对象的3种读写方式
- 派遣函数学习1)缓冲区方式读写
- 派遣函数学习2)直接读写
- 派遣函数(3) - IO设备控制操作
- 派遣函数
- Windows驱动派遣函数的学习
- Windows驱动开发WDM (3)- 设备内存读写方式
- Windows驱动程序开发(七)--- 派遣函数
- 派遣函数(1) - 初识派遣函数
- <学习笔记>Windows驱动开发技术详解__派遣函数
- <学习笔记>Windows驱动开发技术详解__派遣函数
- IRP与派遣函数
- IRP派遣函数
- 派遣函数IRP
- IRP 与 派遣函数
- 枚举驱动设备,并获得驱动文件,查看派遣函数的小工具
- 设备读写 之 直接方式(Direct I/O)
- sysbench小文件测试问题解决
- Android Activity之间传递数据的四种方法
- Intent示例
- snappy jetty error:SnappyNative.maxCompressedLength(I)I
- Securing Business Objects Content – Folder Level, Top Level and Application Security
- 派遣函数学习3)其他方式读写设备
- Android(Java):滑动删除实现——手势识别类
- vim 命令 随手记
- “求包养”是新浪微博开发平台的典型案例
- Disaster Recovery: What to do when the SA account password is lost in SQL Server 2005
- python super()用法
- 内联函数和宏定义的区别
- ShellExecute打开文件目录
- QT编译oci 驱动