aboutsummaryrefslogtreecommitdiffstats
path: root/mm/bootmem.c
diff options
context:
space:
mode:
authorDave Kleikamp <shaggy@austin.ibm.com>2006-01-24 15:34:47 -0500
committerDave Kleikamp <shaggy@austin.ibm.com>2006-01-24 15:34:47 -0500
commit0a0fc0ddbe732779366ab6b1b879f62195e65967 (patch)
tree7b42490a676cf39ae0691b6859ecf7fd410f229b /mm/bootmem.c
parent4d5dbd0945d9e0833dd7964a3d6ee33157f7cc7a (diff)
parent3ee68c4af3fd7228c1be63254b9f884614f9ebb2 (diff)
Merge with /home/shaggy/git/linus-clean/
Diffstat (limited to 'mm/bootmem.c')
-rw-r--r--mm/bootmem.c60
1 files changed, 37 insertions, 23 deletions
diff --git a/mm/bootmem.c b/mm/bootmem.c
index e8c567177dcf..35c32290f717 100644
--- a/mm/bootmem.c
+++ b/mm/bootmem.c
@@ -204,6 +204,8 @@ restart_scan:
204 unsigned long j; 204 unsigned long j;
205 i = find_next_zero_bit(bdata->node_bootmem_map, eidx, i); 205 i = find_next_zero_bit(bdata->node_bootmem_map, eidx, i);
206 i = ALIGN(i, incr); 206 i = ALIGN(i, incr);
207 if (i >= eidx)
208 break;
207 if (test_bit(i, bdata->node_bootmem_map)) 209 if (test_bit(i, bdata->node_bootmem_map))
208 continue; 210 continue;
209 for (j = i + 1; j < i + areasize; ++j) { 211 for (j = i + 1; j < i + areasize; ++j) {
@@ -294,20 +296,12 @@ static unsigned long __init free_all_bootmem_core(pg_data_t *pgdat)
294 unsigned long v = ~map[i / BITS_PER_LONG]; 296 unsigned long v = ~map[i / BITS_PER_LONG];
295 297
296 if (gofast && v == ~0UL) { 298 if (gofast && v == ~0UL) {
297 int j, order; 299 int order;
298 300
299 page = pfn_to_page(pfn); 301 page = pfn_to_page(pfn);
300 count += BITS_PER_LONG; 302 count += BITS_PER_LONG;
301 __ClearPageReserved(page);
302 order = ffs(BITS_PER_LONG) - 1; 303 order = ffs(BITS_PER_LONG) - 1;
303 set_page_refs(page, order); 304 __free_pages_bootmem(page, order);
304 for (j = 1; j < BITS_PER_LONG; j++) {
305 if (j + 16 < BITS_PER_LONG)
306 prefetchw(page + j + 16);
307 __ClearPageReserved(page + j);
308 set_page_count(page + j, 0);
309 }
310 __free_pages(page, order);
311 i += BITS_PER_LONG; 305 i += BITS_PER_LONG;
312 page += BITS_PER_LONG; 306 page += BITS_PER_LONG;
313 } else if (v) { 307 } else if (v) {
@@ -317,9 +311,7 @@ static unsigned long __init free_all_bootmem_core(pg_data_t *pgdat)
317 for (m = 1; m && i < idx; m<<=1, page++, i++) { 311 for (m = 1; m && i < idx; m<<=1, page++, i++) {
318 if (v & m) { 312 if (v & m) {
319 count++; 313 count++;
320 __ClearPageReserved(page); 314 __free_pages_bootmem(page, 0);
321 set_page_refs(page, 0);
322 __free_page(page);
323 } 315 }
324 } 316 }
325 } else { 317 } else {
@@ -337,9 +329,7 @@ static unsigned long __init free_all_bootmem_core(pg_data_t *pgdat)
337 count = 0; 329 count = 0;
338 for (i = 0; i < ((bdata->node_low_pfn-(bdata->node_boot_start >> PAGE_SHIFT))/8 + PAGE_SIZE-1)/PAGE_SIZE; i++,page++) { 330 for (i = 0; i < ((bdata->node_low_pfn-(bdata->node_boot_start >> PAGE_SHIFT))/8 + PAGE_SIZE-1)/PAGE_SIZE; i++,page++) {
339 count++; 331 count++;
340 __ClearPageReserved(page); 332 __free_pages_bootmem(page, 0);
341 set_page_count(page, 1);
342 __free_page(page);
343 } 333 }
344 total += count; 334 total += count;
345 bdata->node_bootmem_map = NULL; 335 bdata->node_bootmem_map = NULL;
@@ -391,15 +381,14 @@ unsigned long __init free_all_bootmem (void)
391 return(free_all_bootmem_core(NODE_DATA(0))); 381 return(free_all_bootmem_core(NODE_DATA(0)));
392} 382}
393 383
394void * __init __alloc_bootmem_limit (unsigned long size, unsigned long align, unsigned long goal, 384void * __init __alloc_bootmem(unsigned long size, unsigned long align, unsigned long goal)
395 unsigned long limit)
396{ 385{
397 pg_data_t *pgdat = pgdat_list; 386 pg_data_t *pgdat = pgdat_list;
398 void *ptr; 387 void *ptr;
399 388
400 for_each_pgdat(pgdat) 389 for_each_pgdat(pgdat)
401 if ((ptr = __alloc_bootmem_core(pgdat->bdata, size, 390 if ((ptr = __alloc_bootmem_core(pgdat->bdata, size,
402 align, goal, limit))) 391 align, goal, 0)))
403 return(ptr); 392 return(ptr);
404 393
405 /* 394 /*
@@ -411,15 +400,40 @@ void * __init __alloc_bootmem_limit (unsigned long size, unsigned long align, un
411} 400}
412 401
413 402
414void * __init __alloc_bootmem_node_limit (pg_data_t *pgdat, unsigned long size, unsigned long align, 403void * __init __alloc_bootmem_node(pg_data_t *pgdat, unsigned long size, unsigned long align,
415 unsigned long goal, unsigned long limit) 404 unsigned long goal)
416{ 405{
417 void *ptr; 406 void *ptr;
418 407
419 ptr = __alloc_bootmem_core(pgdat->bdata, size, align, goal, limit); 408 ptr = __alloc_bootmem_core(pgdat->bdata, size, align, goal, 0);
420 if (ptr) 409 if (ptr)
421 return (ptr); 410 return (ptr);
422 411
423 return __alloc_bootmem_limit(size, align, goal, limit); 412 return __alloc_bootmem(size, align, goal);
413}
414
415#define LOW32LIMIT 0xffffffff
416
417void * __init __alloc_bootmem_low(unsigned long size, unsigned long align, unsigned long goal)
418{
419 pg_data_t *pgdat = pgdat_list;
420 void *ptr;
421
422 for_each_pgdat(pgdat)
423 if ((ptr = __alloc_bootmem_core(pgdat->bdata, size,
424 align, goal, LOW32LIMIT)))
425 return(ptr);
426
427 /*
428 * Whoops, we cannot satisfy the allocation request.
429 */
430 printk(KERN_ALERT "low bootmem alloc of %lu bytes failed!\n", size);
431 panic("Out of low memory");
432 return NULL;
424} 433}
425 434
435void * __init __alloc_bootmem_low_node(pg_data_t *pgdat, unsigned long size,
436 unsigned long align, unsigned long goal)
437{
438 return __alloc_bootmem_core(pgdat->bdata, size, align, goal, LOW32LIMIT);
439}