MDL(内存描述符表) 详解.doc

MDL(内存描述符表) 详解.doc

ID:53872186

大小:31.00 KB

页数:4页

时间:2020-04-10

MDL(内存描述符表) 详解.doc_第1页
MDL(内存描述符表) 详解.doc_第2页
MDL(内存描述符表) 详解.doc_第3页
MDL(内存描述符表) 详解.doc_第4页
资源描述:

《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

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。