Fanr

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

以下观点可能和实际情况有点不符合,因为本人没有阅读过微软的内部文档,也找不到其他资料

只能根据现有的资料,推测,希望懂的人或者牛人能够指点。指出其中的问题,欢迎拍砖

普通内存分配方式:

  图的左边,是普通内存分配方式。

  当程序中的虚拟内存提交时,程序会向系统申请内存,系统会分配一个PFN,一个PFN包含了很多信息,主要是代表内存页,有时候也可以把它看成内存页,这样比较容易理解

  PTE是如果从VAS 也就是 虚拟内存,提交到物理内存时,PTE会记录映射的信息。

  普通分配的基本流程可能是这样。申请到PFN 后,PTE 会映射到相应的PFN,并把VAS中的页读到PFN对应的物理内存页中。

  这个感觉比较简单

AWE内存分配:

  对SQL Server 了解比较深的朋友会知道,SQL Server 启用了AWE之后,分配的内存将会被锁住,也就是 locked page,在程序停止前是无法被释放的。

  当程序想系统以AWE方式请求内存时,系统会从PFN Database 也就是一个管理 PFN 的地方,申请出一块内存,并把 PFN 对应的物理内存映射到虚拟内存中。

     也就是虚拟内存通过指针指向了物理内存。请看图:

            

                                                 

    在PFN映射到虚拟内存的时候,PTE会被分配,与PFN绑定加锁。但是PFN的内存已经映射到了虚拟内存中,PFN会把指向内存的指针指到PTE上。

    所以,PTE无法探测出有多少内存被AWE分配到了程序中。因此也无法对AWE分配的内存做页换出,造成Locked Page。

  

posted on 2011-12-09 00:02  Fanr_Zh  阅读(3098)  评论(0编辑  收藏  举报