Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 25 Nov 2002 02:21:36 -0800
From:      Terry Lambert <tlambert2@mindspring.com>
To:        Kenneth Culver <culverk@yumyumyum.org>
Cc:        freebsd-questions@freebsd.org, freebsd-hackers@freebsd.org
Subject:   Re: Wierd message followed mem prob
Message-ID:  <3DE1F9B0.19CEAB5F@mindspring.com>
References:  <20021125044616.E24473-100000@alpha.yumyumyum.org>

next in thread | previous in thread | raw e-mail | index | archive | help
Kenneth Culver wrote:
>         This is in addition to my last mail. Just to reiterate, I'm using
> FreeBSD 4.7-STABLE as of a few days ago, and I've never seen this problem
> before. The wierd message comes from /usr/src/sys/i386/i386/machdep.c:
> 
> "Too many holes in the physical address space, giving up"
> 
> It prints before even the copyright message on bootup. Second is (I think
> as a result of this message) My total memory is too small by over 100M (I
> have 512M):

Your physical memory map is laid out such that it has holes in;
in general, the code, as written, can tolerate up to 7 holes...
8 discontiguous chunks.

In a properly functioning system, you will not have more than that,
and will generally have much less (the number goes up if 384K is
remapped from expansion RAM to back-fill the "hole" above 640K; in
general, you should turn this off in the BIOS, if you can, unless
you are multibooting the system in DOS, and are using QEMM or a
similar TSR to access expansion RAM).

In general, the message is mostly harmless.  What it means is that
there is some physical memory that was not mapped into the address
space as a known chunk, because of regions within memory that have
been "mapped out" -- "holes".  You lose access to chunks above the
last chunk.

If it's complaining about holes, rather than segments, then it means
that "INT 15:E820" is succeeding without leaving anything out, but
that the number of holes detected are larger than the number of holes
that the BIOS knows about -- there is a mismatch -- and that the
number of holes is greater than 8.

The number of holes available to be mapped this way are limited to
PHYS_AVAIL_ARRAY_END.  By default, this will be 8... the maximum
number supported is limited by the index for the declaration of
the phys_avail[] array, minus 2 (default: 10).

You can increase this number by modifying the "10" in the
phys_avail[] array declaration.  You may want to try jumping it
up to 20, and recompiling the kernel (the declaration is around
line 206 of /sys/i386/i386/machdep.c).

In general, this is a bad way to work around the problem.  If
you have many detected holes like this in your address space,
it is usually indicative of a hardware problem.  This is usually
either a brocken interior address line (but above a page worth
of bits - bit 12) in the memory bus circuitry, or a broken RAM
chip and/or bad connections on a SIMM.

NB: Given address space layout on PC's, the algorithm would lose
less total RAM in the situation where it has chunk issues like
this, if it started from the top down, instead of the bottom up,
since the "chunkiness" will be found below 540K and/or in the bus
I/O address space.

-- Terry

To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-hackers" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3DE1F9B0.19CEAB5F>