Board logo

标题: 问个内存的问题 [打印本页]

作者: Rinrin     时间: 2009-4-6 00:39    标题: 问个内存的问题



如图所示,UMBPCI开启的内存分为两块:
CC00-DFFF
E400-EFFF
现在想让CC00段的程序全部移动至E400段,使空闲块最大,请问如何处理?

在COMMAND加载后,再enable CC00段是否可行?
作者: wl00560     时间: 2009-4-7 03:57
lh可以加参数,让程序到某个区块的……
作者: Rinrin     时间: 2009-4-7 09:22
像SYSTEM, FILES, STACKS这些,不能用LH指定吧?
COMMAND也可以指定加载位置吗?
作者: Climbing     时间: 2009-4-7 10:51
此Rinrin是彼Rinrin吗?

你的问题我也不懂。
作者: netbenton     时间: 2009-4-7 12:23
command.com 虽然不能指定,但是它会自动放到最合理的地方吧
作者: wl00560     时间: 2009-4-7 13:09
原来你移这些啊,那我就没办法了……
作者: DOSforever     时间: 2009-4-11 09:15


  Quote:
Originally posted by Rinrin at 2009-4-7 09:22:
像SYSTEM, FILES, STACKS这些,不能用LH指定吧?
COMMAND也可以指定加载位置吗?

这些系统数据可能无法指定加载到什么位置。
如果用 QEMM386 的话,可以用 LOADHI.SYS 加载 COMMAND.COM 到指定的 UMB 区域。
作者: Rinrin     时间: 2009-4-19 05:31
使用/L的区域参数似乎会稍微浪费一点空间
使用之前:
Upper memory detail:

  Segment  Region        Size        Name         Type
  -------  ------  ----------------  -----------  --------
   0B01F       1     32,256   (32K)  MS-DOS       -- Free --

   0C700       2     58,080   (57K)  SYSTEM       System Data
                        848    (1K)     SETVERXX  Installed Driver SETVER  
                      1,776    (2K)     U-CD-DVD  Installed Driver UIDE   
                      6,512    (6K)     PROTMAN$  Installed Driver PROTMAN
                      2,656    (3K)     PKTDRV$   Installed Driver DIS_PKT
                     27,696   (27K)     PCNTND$   Installed Driver PCNTND  
                      2,080    (2K)               FILES=40
                        256    (0K)               FCBS=4
                     10,720   (10K)               BUFFERS=20
                      2,288    (2K)               LASTDRIVE=Z
                      3,072    (3K)               STACKS=9,256
   0D52E       2        176    (0K)  MS-DOS       -- Free --
   0D539       2        400    (0K)  KILLER       Program
   0D552       2      3,968    (4K)  DOSKEY       Program
   0D64A       2      5,856    (6K)  SHARE        Program
   0D7B8       2      3,872    (4K)  NLSFUNC      Program
   0D8AA       2        208    (0K)  MS-DOS       -- Free --
   0D8B7       2      3,104    (3K)  CTMOUSE      Program
   0D979       2        224    (0K)  MS-DOS       -- Free --
   0D987       2     13,632   (13K)  DOSLFN       Program
   0DCDB       2        368    (0K)  DOSIDLE      Program
   0DCF2       2     12,496   (12K)  MS-DOS       -- Free --

   0E400       3      5,728    (6K)  COMMAND      Program
   0E566       3      1,696    (2K)  COMMAND      Environment
   0E5D0       3      4,864    (5K)  MS-DOS       -- Free --
使用/L:2之后:
Upper memory detail:

  Segment  Region        Size        Name         Type
  -------  ------  ----------------  -----------  --------
   0B01F       1     32,256   (32K)  MS-DOS       -- Free --

   0C700       2        880    (1K)  SYSTEM       System Data
                        848    (1K)     SETVERXX  Installed Driver SETVER  
   0C737       2      1,808    (2K)  SYSTEM       System Data
                      1,776    (2K)     U-CD-DVD  Installed Driver UIDE   
   0C7A8       2      6,544    (6K)  SYSTEM       System Data
                      6,512    (6K)     PROTMAN$  Installed Driver PROTMAN
   0C941       2      2,688    (3K)  SYSTEM       System Data
                      2,656    (3K)     PKTDRV$   Installed Driver DIS_PKT
   0C9E9       2     46,224   (45K)  SYSTEM       System Data
                     27,696   (27K)     PCNTND$   Installed Driver PCNTND  
                      2,080    (2K)               FILES=40
                        256    (0K)               FCBS=4
                     10,720   (10K)               BUFFERS=20
                      2,288    (2K)               LASTDRIVE=Z
                      3,072    (3K)               STACKS=9,256
   0D532       2        176    (0K)  MS-DOS       -- Free --
   0D53D       2        400    (0K)  KILLER       Program
   0D556       2      3,968    (4K)  DOSKEY       Program
   0D64E       2      5,856    (6K)  SHARE        Program
   0D7BC       2      3,872    (4K)  NLSFUNC      Program
   0D8AE       2        208    (0K)  MS-DOS       -- Free --
   0D8BB       2      3,104    (3K)  CTMOUSE      Program
   0D97D       2        224    (0K)  MS-DOS       -- Free --
   0D98B       2     13,632   (13K)  DOSLFN       Program
   0DCDF       2        368    (0K)  DOSIDLE      Program
   0DCF6       2     12,432   (12K)  MS-DOS       -- Free --

   0E400       3      5,728    (6K)  COMMAND      Program
   0E566       3      1,696    (2K)  COMMAND      Environment
   0E5D0       3      4,864    (5K)  MS-DOS       -- Free --
损失64字节
而且,这些TSR程序,似乎一般会留出几百个字节的空间,不知是做什么用的?
楼上说的QEMM,我先试试

[ Last edited by Rinrin on 2009-4-19 at 06:02 ]
作者: DOSforever     时间: 2009-4-20 10:58
哈哈!好啊!损失64个字节也计较啊!哈哈哈哈!有我当年B(yte)B(yte)计较的精神。冲你这精神我就把我多年的经验拿出来共享下,大家讨论下吧。

许多 TSR 驻留内存后都会留出几十到几百甚至十几、几十K不等的间隔,那是因为一般 TSR 在加载时所占用的内存要比驻留后要大,因为加载时它还需要一定的环境空间,加载后就不需要了,至于为什么有的有,有的没有,具体我就不知道了,不知是不是和程序的编写有关。

还有一件怪事,有时候我没有改动任何内存配置,也没有改动硬件,但有时候启动后的原来有间隔的会没有,原来没间隔的又会有?下次启动又会正常?而且我还特意 reset 而不是 reboot 。有时候你多启动几次又会和平常一样了。这就是我说的,计算机中常有许多说不清道不明的事情。不过,遇上这样的事情概率很少,总之,计算机中的事情就是“不稳定”的。

从你这情况来看,加不加 /L:2 参数具体指明哪个区域没什么关系,因为 lh 不加参数时总是把 TSR 加载到最大的 UMB ,你这情况最大的 UMB 就是 2 ,所以加不加结果一样。
作者: netbenton     时间: 2009-4-20 12:54


  Quote:
而且,这些TSR程序,似乎一般会留出几百个字节的空间,不知是做什么用的?

程序驻留是以段为单位的16字节,特别是以前的dos版本,在读取文件时以扇区为单位的最小512字节。

还有dos的exe程序在编写时都要指定对齐方式,和连接方式,有:字节,双字,段(16)字节,512,4k,16k,64k,等,合理的分段对齐,可以提高程序的效率。
所看到的,驻留程序后面有几十,或几百个字节,不是因为该程序,而是后的程序造成的。

偶也是大概了解一点,再多的就不知道了。
作者: Rinrin     时间: 2009-4-23 09:06
to Climbing:是我
楼上的解答有点道理,但这个似乎不属于这种情况
我用debug看了这些空闲块,貌似存放的是环境变量
而且doslfn是个com程序,不是exe程序,不应该存在对齐的问题



[ Last edited by Rinrin on 2009-4-23 at 09:10 ]
作者: netbenton     时间: 2009-4-23 11:37
dos好像是会给com程序配一个环境段的,而驻留程序本身一般不会自行移动自身代码(病毒除外),dos系统对已经驻留的程序,也是不会去移动它的。由于空闲的空间太小,是无法再分配给其它的程序的。通常dos驻留程序都会有中断向量指向,要想把这个小空间合并成一个较大的空间,要考虑的问题太多了。