欢迎来到天天文库
浏览记录
ID:53872186
大小:31.00 KB
页数:4页
时间:2020-04-10
《MDL(内存描述符表) 详解.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、MDL(内存描述符表)详解分类: 初学驱动2013-01-2518:07 308人阅读 评论(0) 收藏 举报mdl 以下的虚拟内存可以理解成逻辑内存,因为我觉得只有这样才能讲通下面所有的东西。以下的“未分页”指没有为页进行编码。以下为MDL结构体(我很郁闷,我在MSDN上没有找到这个结构体)typedefstruct_MDL{ struct_MDL*Next; //下一个MDL CSHORTSize; //大小 CSHORTMdlFlags; //标志,保护属性等 struct_EPR
2、OCESS*Process;// PVOIDMappedSystemVa; PVOIDStartVa; ULONGByteCount; ULONGByteOffset; }MDL,*PMDL;如何使用MDL:一个连续的虚拟内存地址范围可能是由多个分布(spreadover)在不相邻的物理页所组成的。系统使用MDL(内存描述符表)结构体来表明虚拟内存缓冲区的物理页面布局。我们应该避免直接访问MDL。我们可以使用MS-Windows提供的宏,他们提供了对这个结构体基本的访问。·MmGetMdlVirt
3、ualAddress获取缓冲区的虚拟内存地址·MmGetMdlByteCount获取缓冲区的大小(字节数)·MmGetMdlByteOffset获取缓冲区开端的物理页的大小(字节数)·MmGetMdlPfnArray 获取记录物理页码的一个数组指针。 我们可以用IoAllocateMdl函数来分配一个MDL。如果要取消分配,可是使用IoFreeMdl函数。或者,可以使用MmInitializeMdl来把一个之前定义的缓冲区定制成一个MDL。但是以上两种方式都不能初始化物理页码数组。 对于在未分页
4、池中分配的缓冲区,可以用MmBuidlMdlForNonpagedPool函数来初始化页码数组。对于可分页的内存,虚拟内存和物理内存之间的联系是暂时的,所以MDL的页码数组只在特定的环境和时间段有效,因为很可能其他的程序对它们进行重新分配,为了使其他的程序无法对他们进行修改和重新分配(在我们释放之前),我们就需要把这段内存锁定,防止其他程序修改,我们可以用MmProbeAndLockPages来实现,这个函数同时还为当前的布局初始化了页码数组。当我们用MmUnlockPages来释放被锁定的内存时,页码数组
5、也会随之无效。 假如MDL指定的是映射一块内核级别的虚拟地址空间,那么我们要用MmGetSystemAddressForMdlSafe,这样我们就能防止映射目标是来自用户模式的空间,而来自用户模式空间的物理页只能在用户模式上下文环境中使用,并且随时可能被清空。用函数进行申明后,就可以防止以上情况发生了。以下这个函数是用于新创建一个MDL的:参数详解可翻阅MSDNPMDLIoAllocateMdl( INPVOID VirtualAddress, INULONG Length, INBOOL
6、EAN SecondaryBuffer, INBOOLEAN ChargeQuota, INOUTPIRP Irp OPTIONAL );最后一个参数是指IRP(输入输出请求包),也就是将新建的这个MDL缓冲区和指定的IRP关联,为什么要关联?举个例子,比如网络驱动中就应该为每一个发送到本机的IP数据报建立一个临时缓冲区,而最终用户——应用程序要读取这个缓冲区的数据,必须使用IRP请求驱动程序来完成,所以要提取某个IP数据报,只要发送相关IRP给驱动程序,驱动程序遍历其创建的MDL链找到相应的M
7、DL,然后进行数据提取和发送,请求处理完之后,驱动程序会自动清除这个MDL。一个IRP可以关联多个MDL,就像上面举的例子一样,一个IRP关联到多个IP数据报(也就是多个MDL)。当应用成语的某个IRP要求一个新的请求(可能是一个新的IP地址的IP数据报)时,驱动程序发现没有MDL与之联,这个时候该IP发送来一个IP数据报,这时驱动程序便建立一个MDL与之关联,如果这是第一个新建的与这个IRP关联的MDL,那么驱动程把该MDL的地址赋值给MdlAddress。如果不是第一个,那么将把新建的MDL放到上一个M
8、DL的下一个单位,形成MDL链。这就是MDL结构体中的第一个成员的含义所在。总结:MDL就是描述一块虚拟内存的结构体,里面有个成员记录了多个页码,这些页码即处于各个不同物理地址的物理块的页号。所以要对一块受系统保护的区域进行写操作的话,可以这样来修改它的保护属性:1.创建一个MDL,显然里面的物理页号数组没有初始化 IoAllocateMdl2.初始化页码数组,使之成为实际有效的MDL MmBui
此文档下载收益归作者所有