Board logo

标题: 【转帖】终于知道ramdisk 4g是如何使用4G以上内存了,慎用! [打印本页]

作者: 天地遥昭    时间: 2009-5-7 08:17     标题: 【转帖】终于知道ramdisk 4g是如何使用4G以上内存了,慎用!

终于知道ramdisk 4g是如何使用4G以上内存了,慎用!

终于知道ramdisk 4g是如何使用4G以上内存了,慎用!
之前帖子询问了下,没什么结果,不过我自己找到结果了.
http://bbs.pcbeta.com/thread-413755-1-1.html

我找到的是MS做kernel内存管理的developer,所以应该是最权威的了. 目前驱动程序唯一能达到访问4gb以上地址内存的方法是通过一个ddk api: MmMapIoSpace. 其实这个api本来是用来给设备驱动程序进行特殊的地址映射用的,并非用来管理内存.

简单地说, bios会把可用的内存映射到一个并不一定连续的物理地址空间中,比如0地址开始的一段空间需要留给bios自己所以无法映射内存, 3gb-4gb范围内的地址有可能留给各种pci设备,也不能用作内存,这也是为什么win7 32bit在4gb地址线下看不到全部4gb内存的原因.

当然如果bios支持memory remap,那么多余的内存会比map到4gb以上的地址空间,而由于目前win7 32bit强行忽略掉了这部分mapping,所以即使bios map了也不会被使用.

ramdisk 4g的原理就是使用MmMapIoSpace来强行读写4gb以上的地址空间,注意是跳过操作系统的强行读写,把这段地址当作是io设备来操作,而并不一定是内存.

这种做法,主要有两个问题:

第一: 作为驱动程序,你是无法确切地知道究竟哪段物理地址空间里面是映射的你的多余的内存,目前的bios架构中,只有通过中断int 25, function 0xE820才能获知, 而这个bios中断只能在实模式下调用,也就是说windows启动之后,驱动程序是无法调用这个中断去获知的. 那么,ramdisk驱动就只能靠猜, 比如说他可以知道你装了4gb内存,而目前只认了3.5gb, 那么多出来的512m应该在4g-4.5g这个物理地址段.

但是,这个只是猜测,bios并不一定会把多出来的内存映射到那里, 也可能是4.1g-4.6g区间,甚至不一定是连续的空间. 而且,各种奇怪的硬件设备也有可能自己占用特殊的物理地址空间,比如假设有一块硬件占用了4g开始的16m空间,那么显然这段地址里面就不再是内存了.

好吧,那么如果ramdisk强行去读写错误的地址空间会如何呢? 简单地说: cpu不会报错, 但是结果是不可预料的, 比如如果这段地址空间根本是一个memory hole,那么往里面写东西就是白写,读操作返回的有可能都是0xFFFFFFFF, 这样地话,作为一个虚拟磁盘而言,其结果就是数据损坏.

更为严重的是:如果有一块特殊的硬件的io空间映射在4g以上的一段地址,而ramdisk强行去写入数据,就会直接对那块硬件进行io操作,有可能会损坏硬件或者发生更奇怪的事情,比如该设备莫名其妙开始工作了等等.

第二: 即使你的运气很好,bios把多余的内存正好连续地映射在4g开始的空间,也就是ramdisk完全猜对了的情况,还有一个问题是,ramdisk无法保证有没有其他任何代码也会去读写这段地址空间. 因为ramdisk是跳过os的内存管理直接进行io的,其他驱动程序也有可能做相同的事情,这样的结果一样是数据损坏. 比如ramdisk先往里面写了一个文件的内容,之后另一个驱动程序也在相同地址写了一些其他数据,那么ramdisk再读出来的时候就拿不到原来的数据了.

综上,在你无法100%确保以上两点肯定没事的情况下,使用ramdisk还是有风险的,最坏情况是用户数据丢失甚至硬件设备损坏.

其实真的要用超过4g内存,还是有其他更安全的办法的,比如换64位系统,或者用server版本(完全支持pae的),或者直接patch kernel (这个在上面的帖子里面有链接,可以在vista 32位里面直接用到128g内存)

如果真的一定要用ramdisk,请在设置好之后一定要做一个测试: copy一个可以撑满ramdisk大小的真实文件(比如电影之类),然后再从ramdisk里面copy出来,再用fc /b和原始文件进行二进制比较.多做几次测试,以确保正确性.每一个使用ramdisk的机器都应该做这样的测试,因为每台机器bios映射的方式可能不一样.

当然这个只能基本确保第一个问题不存在,还是无法排除第二个问题的可能性.万一有个驱动突然想起来往4g以上某个地址写点东西的话,你的文件就坏了.

ps. 如果有人知道如何联系ramdisk作者的话,请替我转发下. 希望作者在发布这样一个好工具的同时,一定要详细说明可能造成的后果极其原因.

原帖地址:http://bbs.pcbeta.com/thread-413990-1-1.html

作者: woairtt    时间: 2009-5-7 08:23

抢了沙发  哈哈
作者: woairtt    时间: 2009-5-7 08:23

学习了  
作者: hitlove    时间: 2009-5-7 08:23

好像看过。。。。
作者: hitlove    时间: 2009-5-7 08:24

原帖由 woairtt 于 2009-5-7 08:23 发表
抢了沙发  哈哈
原帖由 woairtt 于 2009-5-7 08:23 发表
学习了  

服了你了,能不能干点正事。。。
作者: mafa    时间: 2009-5-7 08:30

原帖由 hitlove 于 2009-5-7 08:24 发表


服了你了,能不能干点正事。。。
不要见怪呀!人都是这样的!
作者: 月的影子    时间: 2009-5-7 08:34

口头表扬一下
作者: fjhyr    时间: 2009-5-7 08:36

学习下。。。 系统的局限,不能太折腾4G内存的问题,导致数据的丢失划不来。
作者: 雪叶青灵    时间: 2009-5-7 08:45

很辛苦的分析贴啊
作者: athlonxing    时间: 2009-5-7 08:50

学习了,哈哈。
作者: smilezhang    时间: 2009-5-7 08:51

感谢分享,学习下 值得表扬!
作者: 魔幻天王    时间: 2009-5-7 09:08

学习了,哈哈。
作者: yjj336    时间: 2009-5-7 09:36

学习了,虽然看着有点晕
作者: tylgon    时间: 2009-5-7 10:13

太长了没看懂,谁能用一句话概括一下。
作者: benson_hxl    时间: 2009-5-7 10:28

学习一下。
作者: hnuyl    时间: 2009-5-7 10:56

反正是用来装缓存一类的东西,丢就丢吧。
作者: hitlove    时间: 2009-5-7 11:05

不如上次介绍的简单。。
作者: luckyjun    时间: 2009-5-7 11:48

呵呵!了解学习一下!
作者: liuxingzixin    时间: 2009-5-7 12:22

学习一下了-----------
作者: crazytomcn    时间: 2009-5-7 13:48

我就在用ramdisk,  4G物理内存, 从高位开始用了1G虚拟盘。
这个区用来放TEMP目录。没有出现任何问题。

如果3G以上空间是给硬件的,ramdisk不知道使用情况?只能靠猜?
那硬件之间也会存在冲突啊,可以肯定的是,这种使用情况是可以准确获知的。这一点硬件本身、操作系统、Ramdisk都可以获知。
作者: 乐色    时间: 2009-5-7 13:52

等系统支持再说吧   反正硬件也赶上去了
作者: I小B黑M    时间: 2009-5-14 14:21

了解了
作者: SoraJio    时间: 2009-9-18 03:17

学习了




欢迎光临 鸿利在线|北京Thinkpad水货|IBM水货|Thinkpad笔记本|Thinkpad全球购|Thinkpad美行|Thinkpad水货笔记本|Thinkpad港行笔记本|Thinkpad T14|X13|P15|P17|P1隐士| X1 Carbon 9代 |T14S|2021款X1 Carbon|X1 隐士|Thinkpad非官方论坛|Thinkpad工作站|Thinkpad笔记本论坛|Thinkpad水货 (http://nb591.com:8989/) Powered by Discuz! 7.2