zoukankan      html  css  js  c++  java
  • 微软的操作系统中让 32 位支持大于 4GB 的内存。

    先给一个参考文献:The RAM reported by the System Properties dialog box and the System Information tool is less than you expect in Windows Vista or in Windows XP Service Pack 2 or later version

    先说结论:

    1、PAE允许操作系统在32位模式下使用大于4G的物理内存。

    2、不管是否使用PAE,对于单个进程而言,32位系统下可见的地址空间最大只有4G。

    3、PAE的优势是可以让不同的进程(在不同的地址空间里)累计使用大于4G的内存,因此而达到使用超过4G内存的目的。

    4、WindowsXP系列虽然支持PAE,但实际在使用中最大内存限制在了4G,是人为限制的,原因后面给分析(楼上给出的各种理由都不成立,这里是有技术原因的)。

    5、Linux则在开启PAE的模式下能支持在32位系统中使用超过4G的内存。

    然后给原因,其实就是我最初给的链接里的内容:

    This issue occurs because of a design change in Windows XP SP2 that is also included in Windows Vista. The changes were made to PAE mode behavior to improve driver compatibility.

    To reduce driver compatibility issues, Windows Vista and Windows XP Service Pack 2 or a later version include hardware abstraction layer (HAL) changes that mimic the 32-bit HAL DMA behavior. The modified HAL grants unlimited map registers when the computer is running in PAE mode. Additionally, the kernel memory manager ignores any physical address that is more than 4 GB. Any system RAM that is more than the 4 GB barrier would be made unaddressable by Windows and be unusable in the system. By limiting the address space to 4 GB, devices with 32-bit DMA bus master capability will not see a transaction with an address that is more than the 4 GB barrier. Because these changes remove the need to double-buffer the transactions, they avoid a class of bugs in some drivers that is related to the correct implementation of double buffering support.


    英文比较长我大概解释一下(以下仅限x86-32/64bit平台,不考虑其它arch):

    首先要先科普一下DMA:DMA的意思可以大概理解为:让硬件(比如显卡、声卡、USB、磁盘控制器等)直接操作物理内存,等操作完成以后返回一个中断给操作系统,告诉操作系统说我干完了。

    DMA的好处就是:假如我想要往磁盘上写数据,数据已经在内存里了,那么CPU只需要把内存地址告诉磁盘控制器,剩下就不用管了,磁盘控制器完成写操作以后会告诉CPU说写完了,这个期间不耽误CPU做其它的事情。

    DMA跟4G内存有什么关系?当然有关系了,因为不是所有内存都是随便都能做DMA的

    如果写过64位操作系统的驱动的话,应该会了解到:有一些外设是无法访问超过4G的内存地址的,有些外设做DMA的时候,能访问的地址都是4G以下的地址(如果我没记错,USB-EHCI控制器好像就是这样的)。

    因此在64位操作系统里,所有DMA操作都是先专门申请一块专门的DMA内存(4G以下),然后再进行操作。而32位系统里,则一般没有这个限制。

    好了,问题就来了:

    微软的XP是十几年前的操作系统,在当时的硬件环境里,所有内存都是可以做DMA的。所以在XP的内核API里,没有考虑过内存不能DMA的情况,所以,XP里的各种驱动、软件在写代码的时候,也都没有考虑过内存能不能DMA,只要拿来用就是了。

    而十几年间,硬件发生了翻天覆地的变化,而XP由于其强大的兼容性,这方面的API一直都没改进。况且,想改进也不行,因为必须二进制兼容旧代码,并且由于这个兼容性的问题从XP一直延续到了Vista,所以包括Win7在内的各种版本,都必须保持这个兼容性。

    二进制兼容这个巨大的包袱使得MS如果真使用了大于4G的内存,那么很有可能出现蓝屏之类的异常情况,因为微软也不知道用户的驱动代码是怎么写的,会不会直接使用内存进行DMA。

    所以,微软强行把内存限制在4G以下是为了保持可恨的兼容性。

    如果放弃了兼容性可不可以?当然可以了,但那就不是XP而是另一个版本的Windows了。

    为什么Server版一直都支持超过4G的内存?因为Server版的驱动跟普通版的不兼容。

    所以楼上的所有解释都是不对的,不是市场定位或者照顾用户情绪或者不想让用户这么做,而是因为兼容性无法保证DMA正确执行(微软也解释的很清楚了,但是国内用户似乎没人注意)。

    有人提了Ready For 4G,这东西会导致某些程序异常,原因就是这些程序在运行中尝试直接使用物理地址(很多软件就是这么流氓),而代码中获得的物理地址都是32bit的,在某些情况下代码中获得的地址不是实际的物理地址,而导致程序崩溃,说实话,没蓝屏已经很不错了。

    如果要让Windows支持超过4G内存,那么几乎所有驱动都要重写一遍,这里还包括操作系统中运行的大量第三方未签名的驱动,这么大的负担显然是谁也承担不了的,因此在32位系统上无法使用4G内存。所以,不是不想,是不能

    评论里有人提出,如果专门识别一下驱动,对于非认证的驱动强制限制在4G以下,认证过的驱动允许使用高于4G的地址,这样是否可以?

    答案是可以的。问题是这么做代价很大,内核中各个API都要多一条甚至几条检查路径来判断驱动的情况,甚至还要小心驱动代码直接用non-paged内存搞DMA,这么做效率就是一个问题,而且微软是无法拿到所有驱动的源码的,比如显卡厂商一般就只发布binary的驱动,所以,微软无法知道这个驱动里究竟搞了什么小动作。所以不得不把这条路堵死。

    ******************************************************************************************************************************************

    这个问题是这样子的,32位的大限就是4G,这个是一个无法改变的事实,通过什么技术手段都无法改变。每一个32位进程都独享4G的虚拟地址空间,其中低2G是给用户的,高2G是给系统预留的。也就是每一个32位进程中,实际能够使用的内存不到2G。

    但是应用程序对于内存的需求总是无止境的,恨不得所有东西都存在内存里面,完全没有磁盘IO。微软对于32位系统有两种使用更大内存的方法。一种是4GT,就是为了让应用程序能够使用更多的内存,压榨一下操作系统保留的地址空间,也就是低3G留给用户,高1G给系统保留,也就是能够利用的内存空间仅仅多了1G而已。但是这种情况,操作系统支持的总物理内存大小没有改变。

    另外一种是上面有人提到的PAE,PAE这种支持大内存的方法,也并不能真正解决对于大内存的需求。首先PAE需要硬件支持,也就是CPU具有支持PAE的相关指令。其次,也是最重要的,PAE不能改变每一个进程的虚拟地址空间4G的上限,而是使得操作系统能够分配的物理内存更多一些而已。也就是说,虽然操作系统支持的物理内存总量可以达到32G,但是每一个进程能够使用的最大内存空间也还是2G,开启4GT之后能够达到3G,然后就上不去了。这种利用大内存的方法对于普通用户并不是非常有意义。毕竟服务器上还可以这样,6G内存中,2G给数据库(进程),2G给缓存(进程),2G留给操作系统的其他服务,通过多个进程瓜分大内存。普通家用系统,玩游戏是单独的游戏进程需要大量的内存,而这种情况即使使用PAE也是解决不了的。

    所以,如果我们对于内存的需求,是单个进程需要使用大量的内存,那么32位根本不能满足我们的需求,什么样的技术手段都不能够改善。只有升级到64位系统才能够解决这个问题。如果要想在32位系统上充分利用大内存,只能够使用多进程,但是对于大部分需要使用大内存的应用,这种方式也很不靠谱,不同进程之间通信的效率并不高,开发起来还很麻烦,也就是像Chrome这样多进程的程序才能够利用了。

    如果微软在非服务器版本中启用PAE支持4G以上的内存,按照现在舆论的风气,一定会被骂出翔。

    为什么明明我配了16G的内存也还是玩不了这个内存需求只有4G的游戏啊!!微软你这个大垃圾!!!

    像这样的抱怨一定到处都是,微软费力不讨好,何必呢?

    Memory Limits for Windows Releases (Windows)

    references:

    http://www.zhihu.com/question/22594254

  • 相关阅读:
    android 开发 View _3_ View的属性动画ValueAnimator
    android 开发 View _2_ View的属性动画ObjectAnimator ,动画效果一览
    android 开发 View _1_ View的子类们 和 视图坐标系图
    android 开发 ScrollView 控件的一些api描述与自定义ScrollView接口回调方法
    android 开发 我的高德地图代码例子
    android 开发 singleTask启动模式下传值的坑
    android 开发 时间选择器TimePicker的使用
    android 开发 实现一个activity变成dialog对话框
    android 开发 实现一个ListView套嵌GirdView的滚动布局
    android 开发 使用自定义布局实现标题栏复用(标题栏内容自定义:使用代码实现和xml布局自定义属性2种办法实现)
  • 原文地址:https://www.cnblogs.com/foohack/p/4596776.html
Copyright © 2011-2022 走看看