The patch titled Have ia64 use add_active_range() and free_area_init_nodes has been added to the -mm tree. Its filename is have-ia64-use-add_active_range-and-free_area_init_nodes.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this From: Mel Gorman <mel@xxxxxxxxx> Size zones and holes in an architecture independent manner for ia64. Signed-off-by: Mel Gorman <mel@xxxxxxxxx> Cc: "Luck, Tony" <tony.luck@xxxxxxxxx> Cc: Andi Kleen <ak@xxxxxx> Cc: Benjamin Herrenschmidt <benh@xxxxxxxxxxxxxxxxxxx> Cc: Paul Mackerras <paulus@xxxxxxxxx> Cc: Anton Blanchard <anton@xxxxxxxxx> Cc: Mike Kravetz <kravetz@xxxxxxxxxx> Cc: Dave Hansen <haveblue@xxxxxxxxxx> Cc: Andy Whitcroft <apw@xxxxxxxxxxxx> Cc: Yasunori Goto <y-goto@xxxxxxxxxxxxxx>, Cc: KAMEZAWA Hiroyuki <kamezawa.hiroyu@xxxxxxxxxxxxxx> Cc: Jack Steiner <steiner@xxxxxxx> Cc: "Bob Picco" <bob.picco@xxxxxx> Cc: Martin Bligh <mbligh@xxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- arch/ia64/Kconfig | 3 + arch/ia64/mm/contig.c | 60 ++++------------------------------- arch/ia64/mm/discontig.c | 41 +++-------------------- arch/ia64/mm/init.c | 12 +++++++ include/asm-ia64/meminit.h | 1 5 files changed, 30 insertions(+), 87 deletions(-) diff -puN arch/ia64/Kconfig~have-ia64-use-add_active_range-and-free_area_init_nodes arch/ia64/Kconfig --- devel/arch/ia64/Kconfig~have-ia64-use-add_active_range-and-free_area_init_nodes 2006-05-10 23:22:06.000000000 -0700 +++ devel-akpm/arch/ia64/Kconfig 2006-05-10 23:22:06.000000000 -0700 @@ -354,6 +354,9 @@ config NODES_SHIFT MAX_NUMNODES will be 2^(This value). If in doubt, use the default. +config ARCH_POPULATES_NODE_MAP + def_bool y + # VIRTUAL_MEM_MAP and FLAT_NODE_MEM_MAP are functionally equivalent. # VIRTUAL_MEM_MAP has been retained for historical reasons. config VIRTUAL_MEM_MAP diff -puN arch/ia64/mm/contig.c~have-ia64-use-add_active_range-and-free_area_init_nodes arch/ia64/mm/contig.c --- devel/arch/ia64/mm/contig.c~have-ia64-use-add_active_range-and-free_area_init_nodes 2006-05-10 23:22:06.000000000 -0700 +++ devel-akpm/arch/ia64/mm/contig.c 2006-05-10 23:22:06.000000000 -0700 @@ -26,10 +26,6 @@ #include <asm/sections.h> #include <asm/mca.h> -#ifdef CONFIG_VIRTUAL_MEM_MAP -static unsigned long num_dma_physpages; -#endif - /** * show_mem - display a memory statistics summary * @@ -212,18 +208,6 @@ count_pages (u64 start, u64 end, void *a return 0; } -#ifdef CONFIG_VIRTUAL_MEM_MAP -static int -count_dma_pages (u64 start, u64 end, void *arg) -{ - unsigned long *count = arg; - - if (start < MAX_DMA_ADDRESS) - *count += (min(end, MAX_DMA_ADDRESS) - start) >> PAGE_SHIFT; - return 0; -} -#endif - /* * Set up the page tables. */ @@ -232,47 +216,24 @@ void __init paging_init (void) { unsigned long max_dma; - unsigned long zones_size[MAX_NR_ZONES]; #ifdef CONFIG_VIRTUAL_MEM_MAP - unsigned long zholes_size[MAX_NR_ZONES]; + unsigned long nid = 0; unsigned long max_gap; #endif - /* initialize mem_map[] */ - - memset(zones_size, 0, sizeof(zones_size)); - num_physpages = 0; efi_memmap_walk(count_pages, &num_physpages); max_dma = virt_to_phys((void *) MAX_DMA_ADDRESS) >> PAGE_SHIFT; #ifdef CONFIG_VIRTUAL_MEM_MAP - memset(zholes_size, 0, sizeof(zholes_size)); - - num_dma_physpages = 0; - efi_memmap_walk(count_dma_pages, &num_dma_physpages); - - if (max_low_pfn < max_dma) { - zones_size[ZONE_DMA] = max_low_pfn; - zholes_size[ZONE_DMA] = max_low_pfn - num_dma_physpages; - } else { - zones_size[ZONE_DMA] = max_dma; - zholes_size[ZONE_DMA] = max_dma - num_dma_physpages; - if (num_physpages > num_dma_physpages) { - zones_size[ZONE_NORMAL] = max_low_pfn - max_dma; - zholes_size[ZONE_NORMAL] = - ((max_low_pfn - max_dma) - - (num_physpages - num_dma_physpages)); - } - } - max_gap = 0; + efi_memmap_walk(register_active_ranges, &nid); efi_memmap_walk(find_largest_hole, (u64 *)&max_gap); if (max_gap < LARGE_GAP) { vmem_map = (struct page *) 0; - free_area_init_node(0, NODE_DATA(0), zones_size, 0, - zholes_size); + free_area_init_nodes(max_dma, max_dma, + max_low_pfn, max_low_pfn); } else { unsigned long map_size; @@ -284,19 +245,14 @@ paging_init (void) efi_memmap_walk(create_mem_map_page_table, NULL); NODE_DATA(0)->node_mem_map = vmem_map; - free_area_init_node(0, NODE_DATA(0), zones_size, - 0, zholes_size); + free_area_init_nodes(max_dma, max_dma, + max_low_pfn, max_low_pfn); printk("Virtual mem_map starts at 0x%p\n", mem_map); } #else /* !CONFIG_VIRTUAL_MEM_MAP */ - if (max_low_pfn < max_dma) - zones_size[ZONE_DMA] = max_low_pfn; - else { - zones_size[ZONE_DMA] = max_dma; - zones_size[ZONE_NORMAL] = max_low_pfn - max_dma; - } - free_area_init(zones_size); + add_active_range(0, 0, max_low_pfn); + free_area_init_nodes(max_dma, max_dma, max_low_pfn, max_low_pfn); #endif /* !CONFIG_VIRTUAL_MEM_MAP */ zero_page_memmap_ptr = virt_to_page(ia64_imva(empty_zero_page)); } diff -puN arch/ia64/mm/discontig.c~have-ia64-use-add_active_range-and-free_area_init_nodes arch/ia64/mm/discontig.c --- devel/arch/ia64/mm/discontig.c~have-ia64-use-add_active_range-and-free_area_init_nodes 2006-05-10 23:22:06.000000000 -0700 +++ devel-akpm/arch/ia64/mm/discontig.c 2006-05-10 23:22:06.000000000 -0700 @@ -705,6 +705,7 @@ static __init int count_node_pages(unsig { unsigned long end = start + len; + add_active_range(node, start >> PAGE_SHIFT, end >> PAGE_SHIFT); mem_data[node].num_physpages += len >> PAGE_SHIFT; if (start <= __pa(MAX_DMA_ADDRESS)) mem_data[node].num_dma_physpages += @@ -729,9 +730,8 @@ static __init int count_node_pages(unsig void __init paging_init(void) { unsigned long max_dma; - unsigned long zones_size[MAX_NR_ZONES]; - unsigned long zholes_size[MAX_NR_ZONES]; unsigned long pfn_offset = 0; + unsigned long max_pfn = 0; int node; max_dma = virt_to_phys((void *) MAX_DMA_ADDRESS) >> PAGE_SHIFT; @@ -748,47 +748,18 @@ void __init paging_init(void) #endif for_each_online_node(node) { - memset(zones_size, 0, sizeof(zones_size)); - memset(zholes_size, 0, sizeof(zholes_size)); - num_physpages += mem_data[node].num_physpages; - - if (mem_data[node].min_pfn >= max_dma) { - /* All of this node's memory is above ZONE_DMA */ - zones_size[ZONE_NORMAL] = mem_data[node].max_pfn - - mem_data[node].min_pfn; - zholes_size[ZONE_NORMAL] = mem_data[node].max_pfn - - mem_data[node].min_pfn - - mem_data[node].num_physpages; - } else if (mem_data[node].max_pfn < max_dma) { - /* All of this node's memory is in ZONE_DMA */ - zones_size[ZONE_DMA] = mem_data[node].max_pfn - - mem_data[node].min_pfn; - zholes_size[ZONE_DMA] = mem_data[node].max_pfn - - mem_data[node].min_pfn - - mem_data[node].num_dma_physpages; - } else { - /* This node has memory in both zones */ - zones_size[ZONE_DMA] = max_dma - - mem_data[node].min_pfn; - zholes_size[ZONE_DMA] = zones_size[ZONE_DMA] - - mem_data[node].num_dma_physpages; - zones_size[ZONE_NORMAL] = mem_data[node].max_pfn - - max_dma; - zholes_size[ZONE_NORMAL] = zones_size[ZONE_NORMAL] - - (mem_data[node].num_physpages - - mem_data[node].num_dma_physpages); - } - pfn_offset = mem_data[node].min_pfn; #ifdef CONFIG_VIRTUAL_MEM_MAP NODE_DATA(node)->node_mem_map = vmem_map + pfn_offset; #endif - free_area_init_node(node, NODE_DATA(node), zones_size, - pfn_offset, zholes_size); + if (mem_data[node].max_pfn > max_pfn) + max_pfn = mem_data[node].max_pfn; } + free_area_init_nodes(max_dma, max_dma, max_pfn, max_pfn); + zero_page_memmap_ptr = virt_to_page(ia64_imva(empty_zero_page)); } diff -puN arch/ia64/mm/init.c~have-ia64-use-add_active_range-and-free_area_init_nodes arch/ia64/mm/init.c --- devel/arch/ia64/mm/init.c~have-ia64-use-add_active_range-and-free_area_init_nodes 2006-05-10 23:22:06.000000000 -0700 +++ devel-akpm/arch/ia64/mm/init.c 2006-05-10 23:22:06.000000000 -0700 @@ -539,6 +539,18 @@ find_largest_hole (u64 start, u64 end, v last_end = end; return 0; } + +int __init +register_active_ranges(u64 start, u64 end, void *nid) +{ + BUG_ON(nid == NULL); + BUG_ON(*(unsigned long *)nid >= MAX_NUMNODES); + + add_active_range(*(unsigned long *)nid, + __pa(start) >> PAGE_SHIFT, + __pa(end) >> PAGE_SHIFT); + return 0; +} #endif /* CONFIG_VIRTUAL_MEM_MAP */ static int __init diff -puN include/asm-ia64/meminit.h~have-ia64-use-add_active_range-and-free_area_init_nodes include/asm-ia64/meminit.h --- devel/include/asm-ia64/meminit.h~have-ia64-use-add_active_range-and-free_area_init_nodes 2006-05-10 23:22:06.000000000 -0700 +++ devel-akpm/include/asm-ia64/meminit.h 2006-05-10 23:22:06.000000000 -0700 @@ -56,6 +56,7 @@ extern void efi_memmap_init(unsigned lon extern unsigned long vmalloc_end; extern struct page *vmem_map; extern int find_largest_hole (u64 start, u64 end, void *arg); + extern int register_active_ranges (u64 start, u64 end, void *arg); extern int create_mem_map_page_table (u64 start, u64 end, void *arg); #endif _ Patches currently in -mm which might be from mel@xxxxxxxxx are introduce-mechanism-for-registering-active-regions-of-memory.patch have-power-use-add_active_range-and-free_area_init_nodes.patch have-x86-use-add_active_range-and-free_area_init_nodes.patch have-x86_64-use-add_active_range-and-free_area_init_nodes.patch have-ia64-use-add_active_range-and-free_area_init_nodes.patch - To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html