要知道内核模式地址和用户模式地址是不可以直接互相读写的,那么它们之间的数据传递,是通过请求作为载体。IRP里有三个地方可以描述缓冲区:一个是irp->MdlAddress,一个是irp->UserBuffer,一个是irp->AssociatedIrp.SystemBuffer
这样产生了三种读写方式:1.缓冲区设备读写
2.直接设备读写
3.其他方式设备读写
一、缓冲区设备读写
1.原理:
缓冲区设备读写是应用程序将数据传通过请求递给内核缓冲区,它的优点是,比较简单的解决了用户地址传入的问题,缺点是应用程序与内核之间相互复制数据,效率较差。
2.基本形态
//////FunctionBufferWriter_and _Read.cpp
extern "C" NTSTATUS FunctionBufferWriter_and_Read(PDEVICE_OBJECT pDevice,P

本文介绍了内核驱动中处理读写操作的三种方式:缓冲区设备读写、直接设备读写和其他方式。详细阐述了每种方式的原理、优缺点,并提供了代码示例,帮助理解如何在内核与用户模式间安全地传递数据。
最低0.47元/天 解锁文章
3317

被折叠的 条评论
为什么被折叠?



