Commit 86e060c6 authored by Andy Whitcroft's avatar Andy Whitcroft Committed by Linus Torvalds

[PATCH] bootmem use NODE_DATA

Whilst looking at simplifying the implmentation of i386 initialisation code
I noticed the following.  This change allows these routines to be used in
both node based and flat memory models which allows more of the init code
to be common in these models.

Convert the default non-node based bootmem routines to use NODE_DATA(0).
This is semantically and functionally identical in any non-node
configuration as NODE_DATA(x) is defined as below.

#define NODE_DATA(nid)          (&contig_page_data)

For the node cases (CONFIG_NUMA and CONFIG_DISCONTIG_MEM) we can use these
non-node forms where all boot memory is defined on node 0.
Signed-off-by: default avatarAndy Whitcroft <apw@shadowen.org>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent fe184bdc
...@@ -343,31 +343,29 @@ unsigned long __init free_all_bootmem_node (pg_data_t *pgdat) ...@@ -343,31 +343,29 @@ unsigned long __init free_all_bootmem_node (pg_data_t *pgdat)
return(free_all_bootmem_core(pgdat)); return(free_all_bootmem_core(pgdat));
} }
#ifndef CONFIG_DISCONTIGMEM
unsigned long __init init_bootmem (unsigned long start, unsigned long pages) unsigned long __init init_bootmem (unsigned long start, unsigned long pages)
{ {
max_low_pfn = pages; max_low_pfn = pages;
min_low_pfn = start; min_low_pfn = start;
return(init_bootmem_core(&contig_page_data, start, 0, pages)); return(init_bootmem_core(NODE_DATA(0), start, 0, pages));
} }
#ifndef CONFIG_HAVE_ARCH_BOOTMEM_NODE #ifndef CONFIG_HAVE_ARCH_BOOTMEM_NODE
void __init reserve_bootmem (unsigned long addr, unsigned long size) void __init reserve_bootmem (unsigned long addr, unsigned long size)
{ {
reserve_bootmem_core(contig_page_data.bdata, addr, size); reserve_bootmem_core(NODE_DATA(0)->bdata, addr, size);
} }
#endif /* !CONFIG_HAVE_ARCH_BOOTMEM_NODE */ #endif /* !CONFIG_HAVE_ARCH_BOOTMEM_NODE */
void __init free_bootmem (unsigned long addr, unsigned long size) void __init free_bootmem (unsigned long addr, unsigned long size)
{ {
free_bootmem_core(contig_page_data.bdata, addr, size); free_bootmem_core(NODE_DATA(0)->bdata, addr, size);
} }
unsigned long __init free_all_bootmem (void) unsigned long __init free_all_bootmem (void)
{ {
return(free_all_bootmem_core(&contig_page_data)); return(free_all_bootmem_core(NODE_DATA(0)));
} }
#endif /* !CONFIG_DISCONTIGMEM */
void * __init __alloc_bootmem (unsigned long size, unsigned long align, unsigned long goal) void * __init __alloc_bootmem (unsigned long size, unsigned long align, unsigned long goal)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment