Blame view
mm/bootmem.c
12 KB
1da177e4c Linux-2.6.12-rc2 |
1 2 3 4 5 6 7 8 9 10 |
/* * linux/mm/bootmem.c * * Copyright (C) 1999 Ingo Molnar * Discontiguous memory support, Kanoj Sarcar, SGI, Nov 1999 * * simple boot-time physical memory area allocator and * free memory collector. It's used to deal with reserved * system memory and memory holes as well. */ |
1da177e4c Linux-2.6.12-rc2 |
11 |
#include <linux/init.h> |
bbc7b92e3 [PATCH] bootmem: ... |
12 |
#include <linux/pfn.h> |
1da177e4c Linux-2.6.12-rc2 |
13 |
#include <linux/bootmem.h> |
1da177e4c Linux-2.6.12-rc2 |
14 |
#include <linux/module.h> |
e786e86a5 [PATCH] bootmem: ... |
15 16 |
#include <asm/bug.h> |
1da177e4c Linux-2.6.12-rc2 |
17 |
#include <asm/io.h> |
dfd54cbcc [PATCH] bootmem: ... |
18 |
#include <asm/processor.h> |
e786e86a5 [PATCH] bootmem: ... |
19 |
|
1da177e4c Linux-2.6.12-rc2 |
20 21 22 23 24 25 26 27 28 |
#include "internal.h" /* * Access to this subsystem has to be serialized externally. (this is * true for the boot process anyway) */ unsigned long max_low_pfn; unsigned long min_low_pfn; unsigned long max_pfn; |
6d46cc6b9 [PATCH] mm/bootme... |
29 |
EXPORT_UNUSED_SYMBOL(max_pfn); /* June 2006 */ |
1da177e4c Linux-2.6.12-rc2 |
30 |
|
679bc9fbb [PATCH] for_each_... |
31 |
static LIST_HEAD(bdata_list); |
92aa63a5a [PATCH] kdump: Re... |
32 33 34 35 36 37 38 |
#ifdef CONFIG_CRASH_DUMP /* * If we have booted due to a crash, max_pfn will be a very low value. We need * to know the amount of memory that the previous kernel used. */ unsigned long saved_max_pfn; #endif |
1da177e4c Linux-2.6.12-rc2 |
39 |
/* return the number of _pages_ that will be allocated for the boot bitmap */ |
f71bf0cac [PATCH] bootmem: ... |
40 |
unsigned long __init bootmem_bootmap_pages(unsigned long pages) |
1da177e4c Linux-2.6.12-rc2 |
41 42 43 44 45 46 47 48 49 |
{ unsigned long mapsize; mapsize = (pages+7)/8; mapsize = (mapsize + ~PAGE_MASK) & PAGE_MASK; mapsize >>= PAGE_SHIFT; return mapsize; } |
f71bf0cac [PATCH] bootmem: ... |
50 |
|
679bc9fbb [PATCH] for_each_... |
51 52 53 |
/* * link bdata in order */ |
69d49e681 [PATCH] bootmem: ... |
54 |
static void __init link_bootmem(bootmem_data_t *bdata) |
679bc9fbb [PATCH] for_each_... |
55 56 |
{ bootmem_data_t *ent; |
f71bf0cac [PATCH] bootmem: ... |
57 |
|
679bc9fbb [PATCH] for_each_... |
58 59 60 61 62 63 64 65 66 67 68 69 |
if (list_empty(&bdata_list)) { list_add(&bdata->list, &bdata_list); return; } /* insert in order */ list_for_each_entry(ent, &bdata_list, list) { if (bdata->node_boot_start < ent->node_boot_start) { list_add_tail(&bdata->list, &ent->list); return; } } list_add_tail(&bdata->list, &bdata_list); |
679bc9fbb [PATCH] for_each_... |
70 |
} |
bbc7b92e3 [PATCH] bootmem: ... |
71 72 73 74 75 76 77 78 79 80 81 82 |
/* * Given an initialised bdata, it returns the size of the boot bitmap */ static unsigned long __init get_mapsize(bootmem_data_t *bdata) { unsigned long mapsize; unsigned long start = PFN_DOWN(bdata->node_boot_start); unsigned long end = bdata->node_low_pfn; mapsize = ((end - start) + 7) / 8; return ALIGN(mapsize, sizeof(long)); } |
1da177e4c Linux-2.6.12-rc2 |
83 84 85 86 |
/* * Called once to set up the allocator itself. */ |
f71bf0cac [PATCH] bootmem: ... |
87 |
static unsigned long __init init_bootmem_core(pg_data_t *pgdat, |
1da177e4c Linux-2.6.12-rc2 |
88 89 90 |
unsigned long mapstart, unsigned long start, unsigned long end) { bootmem_data_t *bdata = pgdat->bdata; |
bbc7b92e3 [PATCH] bootmem: ... |
91 |
unsigned long mapsize; |
1da177e4c Linux-2.6.12-rc2 |
92 |
|
bbc7b92e3 [PATCH] bootmem: ... |
93 94 |
bdata->node_bootmem_map = phys_to_virt(PFN_PHYS(mapstart)); bdata->node_boot_start = PFN_PHYS(start); |
1da177e4c Linux-2.6.12-rc2 |
95 |
bdata->node_low_pfn = end; |
679bc9fbb [PATCH] for_each_... |
96 |
link_bootmem(bdata); |
1da177e4c Linux-2.6.12-rc2 |
97 98 99 100 101 |
/* * Initially all pages are reserved - setup_arch() has to * register free RAM areas explicitly. */ |
bbc7b92e3 [PATCH] bootmem: ... |
102 |
mapsize = get_mapsize(bdata); |
1da177e4c Linux-2.6.12-rc2 |
103 104 105 106 107 108 109 110 111 112 |
memset(bdata->node_bootmem_map, 0xff, mapsize); return mapsize; } /* * Marks a particular physical memory range as unallocatable. Usable RAM * might be used for boot-time allocations - or it might get added * to the free page pool later on. */ |
bb0923a66 [PATCH] bootmem: ... |
113 114 |
static void __init reserve_bootmem_core(bootmem_data_t *bdata, unsigned long addr, unsigned long size) |
1da177e4c Linux-2.6.12-rc2 |
115 |
{ |
bbc7b92e3 [PATCH] bootmem: ... |
116 |
unsigned long sidx, eidx; |
1da177e4c Linux-2.6.12-rc2 |
117 |
unsigned long i; |
bbc7b92e3 [PATCH] bootmem: ... |
118 |
|
1da177e4c Linux-2.6.12-rc2 |
119 120 121 122 |
/* * round up, partially reserved pages are considered * fully reserved. */ |
1da177e4c Linux-2.6.12-rc2 |
123 |
BUG_ON(!size); |
bbc7b92e3 [PATCH] bootmem: ... |
124 125 126 127 128 |
BUG_ON(PFN_DOWN(addr) >= bdata->node_low_pfn); BUG_ON(PFN_UP(addr + size) > bdata->node_low_pfn); sidx = PFN_DOWN(addr - bdata->node_boot_start); eidx = PFN_UP(addr + size - bdata->node_boot_start); |
1da177e4c Linux-2.6.12-rc2 |
129 130 131 132 133 134 135 136 137 |
for (i = sidx; i < eidx; i++) if (test_and_set_bit(i, bdata->node_bootmem_map)) { #ifdef CONFIG_DEBUG_BOOTMEM printk("hm, page %08lx reserved twice. ", i*PAGE_SIZE); #endif } } |
bb0923a66 [PATCH] bootmem: ... |
138 139 |
static void __init free_bootmem_core(bootmem_data_t *bdata, unsigned long addr, unsigned long size) |
1da177e4c Linux-2.6.12-rc2 |
140 |
{ |
bbc7b92e3 [PATCH] bootmem: ... |
141 |
unsigned long sidx, eidx; |
1da177e4c Linux-2.6.12-rc2 |
142 |
unsigned long i; |
bbc7b92e3 [PATCH] bootmem: ... |
143 |
|
1da177e4c Linux-2.6.12-rc2 |
144 145 146 147 |
/* * round down end of usable mem, partially free pages are * considered reserved. */ |
1da177e4c Linux-2.6.12-rc2 |
148 |
BUG_ON(!size); |
bbc7b92e3 [PATCH] bootmem: ... |
149 |
BUG_ON(PFN_DOWN(addr + size) > bdata->node_low_pfn); |
1da177e4c Linux-2.6.12-rc2 |
150 151 152 153 154 155 156 |
if (addr < bdata->last_success) bdata->last_success = addr; /* * Round up the beginning of the address. */ |
bbc7b92e3 [PATCH] bootmem: ... |
157 158 |
sidx = PFN_UP(addr) - PFN_DOWN(bdata->node_boot_start); eidx = PFN_DOWN(addr + size - bdata->node_boot_start); |
1da177e4c Linux-2.6.12-rc2 |
159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 |
for (i = sidx; i < eidx; i++) { if (unlikely(!test_and_clear_bit(i, bdata->node_bootmem_map))) BUG(); } } /* * We 'merge' subsequent allocations to save space. We might 'lose' * some fraction of a page if allocations cannot be satisfied due to * size constraints on boxes where there is physical RAM space * fragmentation - in these cases (mostly large memory boxes) this * is not a problem. * * On low memory boxes we get it right in 100% of the cases. * * alignment has to be a power of 2 value. * * NOTE: This function is _not_ reentrant. */ |
267b48014 [PATCH] x86_64: T... |
179 |
void * __init |
1da177e4c Linux-2.6.12-rc2 |
180 |
__alloc_bootmem_core(struct bootmem_data *bdata, unsigned long size, |
281dd25cd [PATCH] swiotlb: ... |
181 |
unsigned long align, unsigned long goal, unsigned long limit) |
1da177e4c Linux-2.6.12-rc2 |
182 183 |
{ unsigned long offset, remaining_size, areasize, preferred; |
bbc7b92e3 [PATCH] bootmem: ... |
184 |
unsigned long i, start = 0, incr, eidx, end_pfn; |
1da177e4c Linux-2.6.12-rc2 |
185 |
void *ret; |
f71bf0cac [PATCH] bootmem: ... |
186 |
if (!size) { |
1da177e4c Linux-2.6.12-rc2 |
187 188 189 190 191 |
printk("__alloc_bootmem_core(): zero-sized request "); BUG(); } BUG_ON(align & (align-1)); |
281dd25cd [PATCH] swiotlb: ... |
192 193 |
if (limit && bdata->node_boot_start >= limit) return NULL; |
bbc7b92e3 [PATCH] bootmem: ... |
194 195 |
end_pfn = bdata->node_low_pfn; limit = PFN_DOWN(limit); |
281dd25cd [PATCH] swiotlb: ... |
196 197 |
if (limit && end_pfn > limit) end_pfn = limit; |
bbc7b92e3 [PATCH] bootmem: ... |
198 |
eidx = end_pfn - PFN_DOWN(bdata->node_boot_start); |
1da177e4c Linux-2.6.12-rc2 |
199 |
offset = 0; |
bbc7b92e3 [PATCH] bootmem: ... |
200 201 202 |
if (align && (bdata->node_boot_start & (align - 1UL)) != 0) offset = align - (bdata->node_boot_start & (align - 1UL)); offset = PFN_DOWN(offset); |
1da177e4c Linux-2.6.12-rc2 |
203 204 205 206 207 |
/* * We try to allocate bootmem pages above 'goal' * first, then we try to allocate lower pages. */ |
bbc7b92e3 [PATCH] bootmem: ... |
208 |
if (goal && goal >= bdata->node_boot_start && PFN_DOWN(goal) < end_pfn) { |
1da177e4c Linux-2.6.12-rc2 |
209 210 211 |
preferred = goal - bdata->node_boot_start; if (bdata->last_success >= preferred) |
281dd25cd [PATCH] swiotlb: ... |
212 213 |
if (!limit || (limit && limit > bdata->last_success)) preferred = bdata->last_success; |
1da177e4c Linux-2.6.12-rc2 |
214 215 |
} else preferred = 0; |
bbc7b92e3 [PATCH] bootmem: ... |
216 217 |
preferred = PFN_DOWN(ALIGN(preferred, align)) + offset; areasize = (size + PAGE_SIZE-1) / PAGE_SIZE; |
1da177e4c Linux-2.6.12-rc2 |
218 219 220 221 222 223 224 |
incr = align >> PAGE_SHIFT ? : 1; restart_scan: for (i = preferred; i < eidx; i += incr) { unsigned long j; i = find_next_zero_bit(bdata->node_bootmem_map, eidx, i); i = ALIGN(i, incr); |
66d43e98e [PATCH] fix in __... |
225 226 |
if (i >= eidx) break; |
1da177e4c Linux-2.6.12-rc2 |
227 228 229 230 231 |
if (test_bit(i, bdata->node_bootmem_map)) continue; for (j = i + 1; j < i + areasize; ++j) { if (j >= eidx) goto fail_block; |
f71bf0cac [PATCH] bootmem: ... |
232 |
if (test_bit(j, bdata->node_bootmem_map)) |
1da177e4c Linux-2.6.12-rc2 |
233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 |
goto fail_block; } start = i; goto found; fail_block: i = ALIGN(j, incr); } if (preferred > offset) { preferred = offset; goto restart_scan; } return NULL; found: |
bbc7b92e3 [PATCH] bootmem: ... |
248 |
bdata->last_success = PFN_PHYS(start); |
1da177e4c Linux-2.6.12-rc2 |
249 250 251 252 253 254 255 256 257 |
BUG_ON(start >= eidx); /* * Is the next page of the previous allocation-end the start * of this allocation's buffer? If yes then we can 'merge' * the previous partial page with this allocation. */ if (align < PAGE_SIZE && bdata->last_offset && bdata->last_pos+1 == start) { |
8c0e33c13 [PATCH] Use ALIGN... |
258 |
offset = ALIGN(bdata->last_offset, align); |
1da177e4c Linux-2.6.12-rc2 |
259 |
BUG_ON(offset > PAGE_SIZE); |
f71bf0cac [PATCH] bootmem: ... |
260 |
remaining_size = PAGE_SIZE - offset; |
1da177e4c Linux-2.6.12-rc2 |
261 262 263 |
if (size < remaining_size) { areasize = 0; /* last_pos unchanged */ |
f71bf0cac [PATCH] bootmem: ... |
264 265 266 267 |
bdata->last_offset = offset + size; ret = phys_to_virt(bdata->last_pos * PAGE_SIZE + offset + bdata->node_boot_start); |
1da177e4c Linux-2.6.12-rc2 |
268 269 |
} else { remaining_size = size - remaining_size; |
f71bf0cac [PATCH] bootmem: ... |
270 271 272 273 274 |
areasize = (remaining_size + PAGE_SIZE-1) / PAGE_SIZE; ret = phys_to_virt(bdata->last_pos * PAGE_SIZE + offset + bdata->node_boot_start); bdata->last_pos = start + areasize - 1; |
1da177e4c Linux-2.6.12-rc2 |
275 276 277 278 279 280 281 282 283 284 285 286 |
bdata->last_offset = remaining_size; } bdata->last_offset &= ~PAGE_MASK; } else { bdata->last_pos = start + areasize - 1; bdata->last_offset = size & ~PAGE_MASK; ret = phys_to_virt(start * PAGE_SIZE + bdata->node_boot_start); } /* * Reserve the area now: */ |
f71bf0cac [PATCH] bootmem: ... |
287 |
for (i = start; i < start + areasize; i++) |
1da177e4c Linux-2.6.12-rc2 |
288 289 290 291 292 293 294 295 296 |
if (unlikely(test_and_set_bit(i, bdata->node_bootmem_map))) BUG(); memset(ret, 0, size); return ret; } static unsigned long __init free_all_bootmem_core(pg_data_t *pgdat) { struct page *page; |
d41dee369 [PATCH] sparsemem... |
297 |
unsigned long pfn; |
1da177e4c Linux-2.6.12-rc2 |
298 299 300 301 302 303 304 305 306 307 |
bootmem_data_t *bdata = pgdat->bdata; unsigned long i, count, total = 0; unsigned long idx; unsigned long *map; int gofast = 0; BUG_ON(!bdata->node_bootmem_map); count = 0; /* first extant page of the node */ |
bbc7b92e3 [PATCH] bootmem: ... |
308 309 |
pfn = PFN_DOWN(bdata->node_boot_start); idx = bdata->node_low_pfn - pfn; |
1da177e4c Linux-2.6.12-rc2 |
310 311 312 313 314 315 316 |
map = bdata->node_bootmem_map; /* Check physaddr is O(LOG2(BITS_PER_LONG)) page aligned */ if (bdata->node_boot_start == 0 || ffs(bdata->node_boot_start) - PAGE_SHIFT > ffs(BITS_PER_LONG)) gofast = 1; for (i = 0; i < idx; ) { unsigned long v = ~map[i / BITS_PER_LONG]; |
d41dee369 [PATCH] sparsemem... |
317 |
|
1da177e4c Linux-2.6.12-rc2 |
318 |
if (gofast && v == ~0UL) { |
a226f6c89 [PATCH] FRV: Clea... |
319 |
int order; |
1da177e4c Linux-2.6.12-rc2 |
320 |
|
d41dee369 [PATCH] sparsemem... |
321 |
page = pfn_to_page(pfn); |
1da177e4c Linux-2.6.12-rc2 |
322 |
count += BITS_PER_LONG; |
1da177e4c Linux-2.6.12-rc2 |
323 |
order = ffs(BITS_PER_LONG) - 1; |
a226f6c89 [PATCH] FRV: Clea... |
324 |
__free_pages_bootmem(page, order); |
1da177e4c Linux-2.6.12-rc2 |
325 326 327 328 |
i += BITS_PER_LONG; page += BITS_PER_LONG; } else if (v) { unsigned long m; |
d41dee369 [PATCH] sparsemem... |
329 330 |
page = pfn_to_page(pfn); |
1da177e4c Linux-2.6.12-rc2 |
331 332 333 |
for (m = 1; m && i < idx; m<<=1, page++, i++) { if (v & m) { count++; |
a226f6c89 [PATCH] FRV: Clea... |
334 |
__free_pages_bootmem(page, 0); |
1da177e4c Linux-2.6.12-rc2 |
335 336 337 |
} } } else { |
f71bf0cac [PATCH] bootmem: ... |
338 |
i += BITS_PER_LONG; |
1da177e4c Linux-2.6.12-rc2 |
339 |
} |
d41dee369 [PATCH] sparsemem... |
340 |
pfn += BITS_PER_LONG; |
1da177e4c Linux-2.6.12-rc2 |
341 342 343 344 345 346 347 348 349 |
} total += count; /* * Now free the allocator bitmap itself, it's not * needed anymore: */ page = virt_to_page(bdata->node_bootmem_map); count = 0; |
bbc7b92e3 [PATCH] bootmem: ... |
350 351 |
idx = (get_mapsize(bdata) + PAGE_SIZE-1) >> PAGE_SHIFT; for (i = 0; i < idx; i++, page++) { |
a226f6c89 [PATCH] FRV: Clea... |
352 |
__free_pages_bootmem(page, 0); |
bbc7b92e3 [PATCH] bootmem: ... |
353 |
count++; |
1da177e4c Linux-2.6.12-rc2 |
354 355 356 357 358 359 |
} total += count; bdata->node_bootmem_map = NULL; return total; } |
f71bf0cac [PATCH] bootmem: ... |
360 |
unsigned long __init init_bootmem_node(pg_data_t *pgdat, unsigned long freepfn, |
bb0923a66 [PATCH] bootmem: ... |
361 |
unsigned long startpfn, unsigned long endpfn) |
1da177e4c Linux-2.6.12-rc2 |
362 |
{ |
f71bf0cac [PATCH] bootmem: ... |
363 |
return init_bootmem_core(pgdat, freepfn, startpfn, endpfn); |
1da177e4c Linux-2.6.12-rc2 |
364 |
} |
f71bf0cac [PATCH] bootmem: ... |
365 366 |
void __init reserve_bootmem_node(pg_data_t *pgdat, unsigned long physaddr, unsigned long size) |
1da177e4c Linux-2.6.12-rc2 |
367 368 369 |
{ reserve_bootmem_core(pgdat->bdata, physaddr, size); } |
f71bf0cac [PATCH] bootmem: ... |
370 371 |
void __init free_bootmem_node(pg_data_t *pgdat, unsigned long physaddr, unsigned long size) |
1da177e4c Linux-2.6.12-rc2 |
372 373 374 |
{ free_bootmem_core(pgdat->bdata, physaddr, size); } |
f71bf0cac [PATCH] bootmem: ... |
375 |
unsigned long __init free_all_bootmem_node(pg_data_t *pgdat) |
1da177e4c Linux-2.6.12-rc2 |
376 |
{ |
f71bf0cac [PATCH] bootmem: ... |
377 |
return free_all_bootmem_core(pgdat); |
1da177e4c Linux-2.6.12-rc2 |
378 |
} |
f71bf0cac [PATCH] bootmem: ... |
379 |
unsigned long __init init_bootmem(unsigned long start, unsigned long pages) |
1da177e4c Linux-2.6.12-rc2 |
380 381 382 |
{ max_low_pfn = pages; min_low_pfn = start; |
f71bf0cac [PATCH] bootmem: ... |
383 |
return init_bootmem_core(NODE_DATA(0), start, 0, pages); |
1da177e4c Linux-2.6.12-rc2 |
384 385 386 |
} #ifndef CONFIG_HAVE_ARCH_BOOTMEM_NODE |
f71bf0cac [PATCH] bootmem: ... |
387 |
void __init reserve_bootmem(unsigned long addr, unsigned long size) |
1da177e4c Linux-2.6.12-rc2 |
388 389 390 391 |
{ reserve_bootmem_core(NODE_DATA(0)->bdata, addr, size); } #endif /* !CONFIG_HAVE_ARCH_BOOTMEM_NODE */ |
f71bf0cac [PATCH] bootmem: ... |
392 |
void __init free_bootmem(unsigned long addr, unsigned long size) |
1da177e4c Linux-2.6.12-rc2 |
393 394 395 |
{ free_bootmem_core(NODE_DATA(0)->bdata, addr, size); } |
f71bf0cac [PATCH] bootmem: ... |
396 |
unsigned long __init free_all_bootmem(void) |
1da177e4c Linux-2.6.12-rc2 |
397 |
{ |
f71bf0cac [PATCH] bootmem: ... |
398 |
return free_all_bootmem_core(NODE_DATA(0)); |
1da177e4c Linux-2.6.12-rc2 |
399 |
} |
bb0923a66 [PATCH] bootmem: ... |
400 401 |
void * __init __alloc_bootmem_nopanic(unsigned long size, unsigned long align, unsigned long goal) |
1da177e4c Linux-2.6.12-rc2 |
402 |
{ |
679bc9fbb [PATCH] for_each_... |
403 |
bootmem_data_t *bdata; |
1da177e4c Linux-2.6.12-rc2 |
404 |
void *ptr; |
f71bf0cac [PATCH] bootmem: ... |
405 406 407 408 409 |
list_for_each_entry(bdata, &bdata_list, list) { ptr = __alloc_bootmem_core(bdata, size, align, goal, 0); if (ptr) return ptr; } |
a8062231d [PATCH] x86_64: H... |
410 411 |
return NULL; } |
1da177e4c Linux-2.6.12-rc2 |
412 |
|
bb0923a66 [PATCH] bootmem: ... |
413 414 |
void * __init __alloc_bootmem(unsigned long size, unsigned long align, unsigned long goal) |
a8062231d [PATCH] x86_64: H... |
415 416 |
{ void *mem = __alloc_bootmem_nopanic(size,align,goal); |
f71bf0cac [PATCH] bootmem: ... |
417 |
|
a8062231d [PATCH] x86_64: H... |
418 419 |
if (mem) return mem; |
1da177e4c Linux-2.6.12-rc2 |
420 421 422 423 424 425 426 427 |
/* * Whoops, we cannot satisfy the allocation request. */ printk(KERN_ALERT "bootmem alloc of %lu bytes failed! ", size); panic("Out of memory"); return NULL; } |
281dd25cd [PATCH] swiotlb: ... |
428 |
|
bb0923a66 [PATCH] bootmem: ... |
429 430 |
void * __init __alloc_bootmem_node(pg_data_t *pgdat, unsigned long size, unsigned long align, unsigned long goal) |
1da177e4c Linux-2.6.12-rc2 |
431 432 |
{ void *ptr; |
008857c1a [PATCH] Cleanup b... |
433 |
ptr = __alloc_bootmem_core(pgdat->bdata, size, align, goal, 0); |
1da177e4c Linux-2.6.12-rc2 |
434 |
if (ptr) |
f71bf0cac [PATCH] bootmem: ... |
435 |
return ptr; |
1da177e4c Linux-2.6.12-rc2 |
436 |
|
008857c1a [PATCH] Cleanup b... |
437 |
return __alloc_bootmem(size, align, goal); |
1da177e4c Linux-2.6.12-rc2 |
438 |
} |
dfd54cbcc [PATCH] bootmem: ... |
439 440 441 |
#ifndef ARCH_LOW_ADDRESS_LIMIT #define ARCH_LOW_ADDRESS_LIMIT 0xffffffffUL #endif |
008857c1a [PATCH] Cleanup b... |
442 |
|
bb0923a66 [PATCH] bootmem: ... |
443 444 |
void * __init __alloc_bootmem_low(unsigned long size, unsigned long align, unsigned long goal) |
008857c1a [PATCH] Cleanup b... |
445 |
{ |
679bc9fbb [PATCH] for_each_... |
446 |
bootmem_data_t *bdata; |
008857c1a [PATCH] Cleanup b... |
447 |
void *ptr; |
f71bf0cac [PATCH] bootmem: ... |
448 |
list_for_each_entry(bdata, &bdata_list, list) { |
dfd54cbcc [PATCH] bootmem: ... |
449 450 |
ptr = __alloc_bootmem_core(bdata, size, align, goal, ARCH_LOW_ADDRESS_LIMIT); |
f71bf0cac [PATCH] bootmem: ... |
451 452 453 |
if (ptr) return ptr; } |
008857c1a [PATCH] Cleanup b... |
454 455 456 457 458 459 460 461 462 463 464 465 466 |
/* * Whoops, we cannot satisfy the allocation request. */ printk(KERN_ALERT "low bootmem alloc of %lu bytes failed! ", size); panic("Out of low memory"); return NULL; } void * __init __alloc_bootmem_low_node(pg_data_t *pgdat, unsigned long size, unsigned long align, unsigned long goal) { |
dfd54cbcc [PATCH] bootmem: ... |
467 468 |
return __alloc_bootmem_core(pgdat->bdata, size, align, goal, ARCH_LOW_ADDRESS_LIMIT); |
008857c1a [PATCH] Cleanup b... |
469 |
} |