[PATCH] fix bootmem allocator on machines with holes in memory

From: Anton Blanchard (anton@samba.org)
Date: Wed Jul 16 2003 - 14:46:46 EST


Hi,

If the memory we are trying to allocate is too large to fit in the
current region, we should skip to the end. We currently search the
available bitmap, find the area is too small, increment the start by
incr and try again. This resulted in an apparent lockup on a 64GB
machine that had a 3GB IO hole starting at 1GB (and the mem_map array
would not fit in the first region).

Also use ALIGN macro instead of an open coded version.

Anton

===== mm/bootmem.c 1.18 vs edited =====
--- 1.18/mm/bootmem.c Sat Jul 5 16:52:55 2003
+++ edited/mm/bootmem.c Thu Jul 17 05:00:42 2003
@@ -183,7 +183,7 @@
         for (i = preferred; i < eidx; i += incr) {
                 unsigned long j;
                 i = find_next_zero_bit(bdata->node_bootmem_map, eidx, i);
- i = (i + incr - 1) & -incr;
+ i = ALIGN(i, incr);
                 if (test_bit(i, bdata->node_bootmem_map))
                         continue;
                 for (j = i + 1; j < i + areasize; ++j) {
@@ -195,7 +195,7 @@
                 start = i;
                 goto found;
         fail_block:
- ;
+ i = ALIGN(j, incr);
         }
 
         if (preferred > offset) {
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Wed Jul 23 2003 - 22:00:26 EST