On Sun, Jan 10, 1999 at 05:22:59PM +0100, Thomas Bogendoerfer wrote:

> I now know the reason for this. Before giving out memory via brk() the
> kernel checks, whether there is enough memory. The kernel holds back
> (2 + page_cache.min_percent + buffer_mem.min_pecent) percent of the
> available memory (see function vm_enough_memory() in mm/mmap.c). Problem
> on the Indy is, that num_physpages is wrong by 128MB, because we account
> the memory by only looking at the highest page number and forget about 
> holes in the memory map. And the Indy has a big hole between 0x80002000 
> and 0x88002000 ...
> 
> Right now I can't think of a good fix for this problem. Any ideas ?

Attached is a quickfix which just fixes the calculation of num_physpages.
The real thing is to us the PG_skip flag and implement the PageSkip macro.
See the Sparc / Sparc64 code for how to implement.  Implementing this
will save us alot of memory as well.  I'll post a real patch later.

  Ralf

--- arch/mips/mm/init.c.orig    Sun Jan 10 23:50:12 1999
+++ arch/mips/mm/init.c Sun Jan 10 23:50:53 1999
@@ -247,8 +247,9 @@
 #endif
 
        end_mem &= PAGE_MASK;
-       max_mapnr = num_physpages = MAP_NR(end_mem);
+       max_mapnr = MAP_NR(end_mem);
        high_memory = (void *)end_mem;
+       num_physpages = 0;
 
        /* mark usable pages in the mem_map[] */
        start_mem = PAGE_ALIGN(start_mem);
@@ -278,6 +279,7 @@
                                datapages++;
                        continue;
                }
+               num_physpages++;
                atomic_set(&mem_map[MAP_NR(tmp)].count, 1);
 #ifdef CONFIG_BLK_DEV_INITRD
                if (!initrd_start || (tmp < initrd_start || tmp >=

Reply via email to