mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-06-26 16:41:25 +00:00
[PATCH] sparsemem extreme implementation
With cleanups from Dave Hansen <haveblue@us.ibm.com> SPARSEMEM_EXTREME makes mem_section a one dimensional array of pointers to mem_sections. This two level layout scheme is able to achieve smaller memory requirements for SPARSEMEM with the tradeoff of an additional shift and load when fetching the memory section. The current SPARSEMEM implementation is a one dimensional array of mem_sections which is the default SPARSEMEM configuration. The patch attempts isolates the implementation details of the physical layout of the sparsemem section array. SPARSEMEM_EXTREME requires bootmem to be functioning at the time of memory_present() calls. This is not always feasible, so architectures which do not need it may allocate everything statically by using SPARSEMEM_STATIC. Signed-off-by: Andy Whitcroft <apw@shadowen.org> Signed-off-by: Bob Picco <bob.picco@hp.com> Signed-off-by: Dave Hansen <haveblue@us.ibm.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
802f192e4a
commit
3e347261a8
4 changed files with 50 additions and 38 deletions
26
mm/sparse.c
26
mm/sparse.c
|
@ -13,28 +13,36 @@
|
|||
*
|
||||
* 1) mem_section - memory sections, mem_map's for valid memory
|
||||
*/
|
||||
#ifdef CONFIG_ARCH_SPARSEMEM_EXTREME
|
||||
#ifdef CONFIG_SPARSEMEM_EXTREME
|
||||
struct mem_section *mem_section[NR_SECTION_ROOTS]
|
||||
____cacheline_maxaligned_in_smp;
|
||||
#else
|
||||
struct mem_section mem_section[NR_SECTION_ROOTS][SECTIONS_PER_ROOT]
|
||||
____cacheline_maxaligned_in_smp;
|
||||
#endif
|
||||
EXPORT_SYMBOL(mem_section);
|
||||
|
||||
static void sparse_alloc_root(unsigned long root, int nid)
|
||||
{
|
||||
#ifdef CONFIG_SPARSEMEM_EXTREME
|
||||
mem_section[root] = alloc_bootmem_node(NODE_DATA(nid), PAGE_SIZE);
|
||||
#endif
|
||||
}
|
||||
|
||||
static void sparse_index_init(unsigned long section, int nid)
|
||||
{
|
||||
unsigned long root = SECTION_TO_ROOT(section);
|
||||
unsigned long root = SECTION_NR_TO_ROOT(section);
|
||||
|
||||
if (mem_section[root])
|
||||
return;
|
||||
mem_section[root] = alloc_bootmem_node(NODE_DATA(nid), PAGE_SIZE);
|
||||
|
||||
sparse_alloc_root(root, nid);
|
||||
|
||||
if (mem_section[root])
|
||||
memset(mem_section[root], 0, PAGE_SIZE);
|
||||
else
|
||||
panic("memory_present: NO MEMORY\n");
|
||||
}
|
||||
#else
|
||||
struct mem_section mem_section[NR_MEM_SECTIONS]
|
||||
____cacheline_maxaligned_in_smp;
|
||||
#endif
|
||||
EXPORT_SYMBOL(mem_section);
|
||||
|
||||
/* Record a memory area against a node. */
|
||||
void memory_present(int nid, unsigned long start, unsigned long end)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue