| ![[MEGS-O-RAM]](gifs/megsoram.gif)  byAl Wong
 
 
 IntroductionI had just upgraded 
my new notebook computer
from 8 megabytes (MB) to 40 MB of RAM
(a Pentium 133Mhz with DOS 6.22 and Windows For Work Groups (WFWG) 3.11).
While I was very happy about this, I didn't know how to optimally
configure all this lovely memory! Researching the Web did not reveal
any articles that describe solutions to this problem! 
I thought this was very odd.
Inquiring in Usenet, I discovered this problem can have more than 
one answer depending on how you use your computer.
This is a description of how I determined my "best" memory configuration.
It may not be the best configuration for everyone. 
My main purpose is to describe
the different considerations involved with having lots of memory. 
Hopefully this article will help someone else with a similar problem.
I wish this page existed when I was looking for information.
 
Most of the information in this article was derived from reading
the Microsoft user manuals for DOS 6.22 and WFWG 3.11 and
after much experimenting and observation.
Special thanks to Bill Clay (wpclay@arl.mil) for clarifying 
DOS and Windows cache interaction.
 
This article is intended for 80486 machines or better, DOS 6.22 or better,
Windows 3.1 or WFWG 3.11. This information may not be accurate for less
powerful machines or earlier operating systems. And of course,
your mileage may vary.
DefinitionsBefore jumping into the configuring issues, a few definitions about
memory to make
sure everyone is on the same (Web) page. 
I get confused about PC memory terminology myself.
This is takened from the
Microsoft MS-DOS 6.22 Concise User's Guide: 
 
So any memory installed after the first MB of memory is considered
extended memory. 
Since I upgraded to 40 MB of RAM, this means 39 MB is 
extended memory.
   | Conventional Memory | Up to the first 640K of memory on a computer. All MS-DOS-based
      programs require conventional memory. (K=kilobytes.) |  
   | Upper Memory Area | The 384K of memory above your computer's 640K of 
      conventional memory. 
      The upper memory area is used by system hardware, such
      as your display adapter. Unused parts of the 
      upper memory area are
      called upper memory blocks (UMBs). |  
   | Extended Memory (XMS) | Memory beyond 1 MB on computers with 80286 or higher processors.
      Extended memory requires an extended-memory manager, 
      such as HIMEM. |  
   | High Memory Area (HMA) | The first 64K of extended memory.
      On a computer with extended memory, Setup conserves
      conventional memory by installing MS-DOS to run
      in the high memory area. |  
   | Expanded Memory (EMS) | Memory in addition to conventional memory that some
      MS-DOS-based applications can use. Expanded memory is installed
      on an expanded memory board and comes with an expanded-memory
      manager.
      (This article will not
      address expanded memory (Pun intended).
      Most DOS applications do not use
      it now.) |  Does the Computer Recognize the Memory?The first thing I did after the new memory chips were installed is
make sure the computer recognizes the new memory. On bootup, the
computer automatically does a memory test and counts the memory
addresses tested. Watching this carefully, I noted the count
was approximately 39 MB. Whee!
Another way to check is to run the DOS MEM command. The output
results from MEM displays the amounts of conventional, upper 
and extended memory.
What is the Purpose for This Memory?Before you can optimally configure your memory, you must ask yourself
for what purpose do I need the extra memory? What applications do
I use often that are memory hogs? Are they DOS or 
Windows programs? Aim your memory configuration 
so these applications can take full advantage of the extra memory.Configuring MemoryAfter I had confirmed the computer recognized the newly installed memory,
I wanted to make sure I had as much free 
conventional memory
as possible upon bootup. All applications need 
conventional memory
to load and run properly. 
I hand-optimized the various drivers on my notebook and managed
to free about 68K more than the factory settings.
Then I tried the DOS MemMaker. It squeezed out 2K more of free
conventional memory.
I discovered it can figure out the minimum size
of each driver to be stored in the 
upper memory blocks.
So MemMaker does work but 2K isn't that dramatic.
 
One thing to note. Watch the actions of other device drivers.
On bootup, the driver software for my Teac CD-ROM drive 
automatically allocates 25% of 
extended memory 
to be used as a CD cache by default.
For a while, I was wondering why about 10 MB of 
extended memory 
was taken up!
I disabled the CD cache and had 39 MB free again.
CONFIG.SYSThis is the first file read on bootup.
There are a few basic lines in this file that must be present
to use all of your computer's memory. 
 
HIMEM.SYS: Extended Memory and HMA Manager
 
This driver manages program access to the 
extended memory 
and the 
high memory area.
The first line in your CONFIG.SYS file should be loading this driver.
The line I use is:
DEVICE=C:\DOS\HIMEM.SYS /VERBOSE
 
EMM386.EXE: Upper Memory Area Manager
 
 
This driver provides access to the 
upper memory area.
The second line in the CONFIG.SYS file should be loading this driver.
The line I use is:
DEVICE=C:\DOS\EMM386.EXE NOEMS /VERBOSE
 
The NOEMS option is to disable program access to 
expanded memory.
So EMM386.EXE is mainly used to provide access to the 
upper memory area.
 
DOS Command
 
 
   There are two DOS commands that should be the third and fourth line
   in the CONFIG.SYS file:
   DOS=UMBDOS=HIGH
 
The first line, DOS=UMB,
allows DOS to manage the 
upper memory blocks
that were created by EMM386.EXE.
The second line, DOS=HIGH,
allows DOS to attempt to load part of itself in the 
high memory area.
 
DEVICEHIGH
 
 
The other thing I did is to use DEVICEHIGH as much as possible
to load the other device drivers into the 
upper memory area.
 AUTOEXEC.BATThis is the other file read on bootup. Depending on your hardware
configuration, there might be other drivers that will arbitrarily
allocate memory. For example on my system, my Teac CD drive
automatically to allocates 25% of available memory by default.
Reading the documentation for each driver and running the DOS MEM 
command helped me determine what program was allocating memory.
Apart from other device drivers, there is only one that comes
with DOS and, which I discovered, is one key for configuring
memory allocation. What the manuals don't tell you is there
should be two separate memory configurations, 
one for DOS and one for Windows.
 
SMARTDRV.EXE: The Disk Cache for DOS
 
At first, it wasn't clear to me if SMARTDRV was acting as a
RAM drive, a disk cache or both! 
I guess the SMART and DRV in SMARTDRV
implied to me it was a smart RAM drive.
It was too much to hope for.
I discovered later SMARTDRV just caches the hard disk 
but will not allow DOS programs to execute from it.
So the SMART and DRV in SMARTDRV
implies it's a smart cache for the hard drive.
So programs and data are cached by SMARTDRV but still need to be
transferred into 
conventional memory
to be executed.
For fun, I tried allocating 39 MB with SMARTDRV but that didn't
work. After much testing, I determined SMARTDRV will allocate a 
maximum cache size of 37,487K. This left about 3 MB free.
Some large DOS programs wouldn't load.
 
SMARTDRV.EXE allocates the disk cache for DOS.
There are two basic numeric arguments for SMARTDRV.EXE. The first one is the
cache size (in Kilobytes) when in DOS and the second one is 
the cache size when in Windows.
 
For DOS,
I also discovered the SMARTDRV disk cache will optimally work with
a 4 MB to 8MB allocation while in DOS. The rest of 
extended memory 
could be used by a RAM drive while in DOS.
 
For Windows,
the SMARTDRV cache should be minimized and the Window's disk cache
should be used. SMARTDRV will cache for Windows too but the
Windows cache is faster. Also the SMARTDRV cache should be minimized
so it doesn't conflict with the Windows cache. This is the line
I use:
 
C:\DOS\SMARTDRV.EXE 8192 128 /X /S
 
This allocates an 8 MB disk cache (8,192K) while in DOS and a 128K cache
while in Windows. The 128K cache is for caching the floppy drive which
the Windows cache evidently does not do. This works well if Windows
has its own disk cache.
 
The /X option makes sure SMARTDRV does not cache writes to disk.
The /S option tells SMARTDRV to display its current status.
 
For machines with 6 MB or more of 
extended memory, 
SMARTDRV will
automatically allocate 2 MB for both its DOS cache and Windows cache.
Usually, this is not optimal. If you are in Windows and 
if a disk cache is allocated under Windows,
disk accesses will be cached by both the SMARTDRV disk cache and 
the Windows disk cache!
 
 Windows For Work Groups 3.11The steps I describe here are for 
WFWG 3.11 but are valid for Windows 3.1 too. 
(Before configuring anything in Windows, it is a good idea to do a 
SCANDISK and DEFRAG /F in DOS first.)
It appears Windows is smart enough to recognize 
extended memory 
and grab all unallocated
extended memory 
for itself when it starts up.
There are at least 3 things to do to configure memory
in Windows. Find the Main program group and
go to:
 
Main | Control Panel | Enhanced | Virtual Memory | Change
 32 Bit File AccessClick ON the 32 Bit File Access Box. 
This will enable 32 bit file access which is faster than 16 bit file
access (the default).Permanent Swap FileTo enable 32 bit file access, you will probably need to
create a permanent swap file too. 
I created a 10 MB (10,240K) swap file.
With 40 MB of RAM, I found Windows almost never uses it.
By the way, it is not a good idea to use part of your RAM
for a swap file (from a RAM drive). This robs memory from other
Windows applications that probably need it.
Windows Disk CacheType the cache size (in kilobytes) 
in the Cache Size box to allocate a disk cache
in Windows. 
I use 4MB (4,096K).
This allows Windows to create a 4 MB disk cache on startup.
I found this is a good cache size.
This cache gets deallocated when you exit Windows.
You will need to restart Windows after making the above changes. 
This will leave about 32-34 MB free for Windows to allocate for itself
and dole out to other Windows programs during the current Windows session.
This is plenty for almost all Windows applications.
Summary 
Make sure the computer recognizes the extra memory.
Note which application(s) need the extra memory
and configure your memory to that.
Tweak 
conventional memory
to maximize it on bootup.
Use HIMEM.SYS and EMM386.EXE.
Tweak 
extended memory 
for DOS and for Windows. Use the SMARTDRV.EXE cache for DOS and
the Windows cache for Windows.
 
Now that you have configured your WFWG 3.11 computer memory,
perhaps you would like to 
put it on your local network.
Why not?
 |