In order to use the alternative sparsemem implementation for NUMA kernels, we need to reorganize the CONFIG options throughout. This effectively abstracts out the CONFIG_DISCONTIGMEM options to CONFIG_NUMA in most cases, allowing either the discontigmem implementation to be employed as always, but also enables the alternative sparsemem implementation to be used. Signed-off-by: Matt Tolentino Signed-off-by: Dave Hansen --- memhotplug-dave/arch/x86_64/kernel/head64.c | 2 +- memhotplug-dave/arch/x86_64/kernel/setup.c | 6 +++--- memhotplug-dave/arch/x86_64/mm/Makefile | 2 +- memhotplug-dave/arch/x86_64/mm/init.c | 9 ++++++--- memhotplug-dave/arch/x86_64/mm/ioremap.c | 2 +- memhotplug-dave/include/asm-x86_64/io.h | 5 ----- memhotplug-dave/include/asm-x86_64/mmzone.h | 15 +++++++++------ memhotplug-dave/include/asm-x86_64/page.h | 4 +++- memhotplug-dave/include/asm-x86_64/topology.h | 4 +--- 9 files changed, 25 insertions(+), 24 deletions(-) diff -puN arch/x86_64/kernel/head64.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 arch/x86_64/kernel/head64.c --- memhotplug/arch/x86_64/kernel/head64.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/arch/x86_64/kernel/head64.c 2005-03-11 10:52:29.000000000 -0800 @@ -99,7 +99,7 @@ void __init x86_64_start_kernel(char * r s = strstr(saved_command_line, "earlyprintk="); if (s != NULL) setup_early_printk(s); -#ifdef CONFIG_DISCONTIGMEM +#ifdef CONFIG_NUMA s = strstr(saved_command_line, "numa="); if (s != NULL) numa_setup(s+5); diff -puN arch/x86_64/kernel/setup.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 arch/x86_64/kernel/setup.c --- memhotplug/arch/x86_64/kernel/setup.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/arch/x86_64/kernel/setup.c 2005-03-11 10:52:29.000000000 -0800 @@ -350,7 +350,7 @@ static __init void parse_cmdline_early ( if (!memcmp(from, "mem=", 4)) parse_memopt(from+4, &from); -#ifdef CONFIG_DISCONTIGMEM +#ifdef CONFIG_NUMA if (!memcmp(from, "numa=", 5)) numa_setup(from+5); #endif @@ -379,7 +379,7 @@ static __init void parse_cmdline_early ( *cmdline_p = command_line; } -#ifndef CONFIG_DISCONTIGMEM +#ifndef CONFIG_NUMA static void __init contig_initmem_init(void) { unsigned long bootmap_size, bootmap; @@ -558,7 +558,7 @@ void __init setup_arch(char **cmdline_p) acpi_numa_init(); #endif -#ifdef CONFIG_DISCONTIGMEM +#ifdef CONFIG_NUMA numa_initmem_init(0, end_pfn); #else contig_initmem_init(); diff -puN arch/x86_64/mm/Makefile~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 arch/x86_64/mm/Makefile --- memhotplug/arch/x86_64/mm/Makefile~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/arch/x86_64/mm/Makefile 2005-03-11 10:52:29.000000000 -0800 @@ -4,7 +4,7 @@ obj-y := init.o fault.o ioremap.o extable.o pageattr.o obj-$(CONFIG_HUGETLB_PAGE) += hugetlbpage.o -obj-$(CONFIG_DISCONTIGMEM) += numa.o +obj-$(CONFIG_NUMA) += numa.o obj-$(CONFIG_K8_NUMA) += k8topology.o obj-$(CONFIG_ACPI_NUMA) += srat.o diff -puN arch/x86_64/mm/init.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 arch/x86_64/mm/init.c --- memhotplug/arch/x86_64/mm/init.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/arch/x86_64/mm/init.c 2005-03-11 10:52:29.000000000 -0800 @@ -318,7 +318,7 @@ void zap_low_mappings(void) flush_tlb_all(); } -#ifndef CONFIG_DISCONTIGMEM +#ifndef CONFIG_NUMA void __init paging_init(void) { { @@ -427,13 +427,16 @@ void __init mem_init(void) reservedpages = 0; /* this will put all low memory onto the freelists */ -#ifdef CONFIG_DISCONTIGMEM +#ifdef CONFIG_NUMA totalram_pages += numa_free_all_bootmem(); tmp = 0; /* should count reserved pages here for all nodes */ #else + +#ifdef CONFIG_FLATMEM max_mapnr = end_pfn; if (!mem_map) BUG(); +#endif totalram_pages += free_all_bootmem(); @@ -515,7 +518,7 @@ void free_initrd_mem(unsigned long start void __init reserve_bootmem_generic(unsigned long phys, unsigned len) { /* Should check here against the e820 map to avoid double free */ -#ifdef CONFIG_DISCONTIGMEM +#ifdef CONFIG_NUMA int nid = phys_to_nid(phys); reserve_bootmem_node(NODE_DATA(nid), phys, len); #else diff -puN arch/x86_64/mm/ioremap.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 arch/x86_64/mm/ioremap.c --- memhotplug/arch/x86_64/mm/ioremap.c~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/arch/x86_64/mm/ioremap.c 2005-03-11 10:52:29.000000000 -0800 @@ -175,7 +175,7 @@ void __iomem * __ioremap(unsigned long p if (phys_addr >= 0xA0000 && last_addr < 0x100000) return (__force void __iomem *)phys_to_virt(phys_addr); -#ifndef CONFIG_DISCONTIGMEM +#ifdef CONFIG_FLATMEM /* * Don't allow anybody to remap normal RAM that we're using.. */ diff -puN include/asm-x86_64/io.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 include/asm-x86_64/io.h --- memhotplug/include/asm-x86_64/io.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/include/asm-x86_64/io.h 2005-03-11 10:52:29.000000000 -0800 @@ -128,12 +128,7 @@ extern inline void * phys_to_virt(unsign /* * Change "struct page" to physical address. */ -#ifdef CONFIG_DISCONTIGMEM -#include #define page_to_phys(page) ((dma_addr_t)page_to_pfn(page) << PAGE_SHIFT) -#else -#define page_to_phys(page) ((page - mem_map) << PAGE_SHIFT) -#endif #include diff -puN include/asm-x86_64/mmzone.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 include/asm-x86_64/mmzone.h --- memhotplug/include/asm-x86_64/mmzone.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/include/asm-x86_64/mmzone.h 2005-03-11 10:52:29.000000000 -0800 @@ -6,7 +6,7 @@ #include -#ifdef CONFIG_DISCONTIGMEM +#ifdef CONFIG_NUMA #define VIRTUAL_BUG_ON(x) @@ -30,9 +30,6 @@ static inline __attribute__((pure)) int return nid; } -#define pfn_to_nid(pfn) phys_to_nid((unsigned long)(pfn) << PAGE_SHIFT) - -#define kvaddr_to_nid(kaddr) phys_to_nid(__pa(kaddr)) #define NODE_DATA(nid) (node_data[nid]) #define node_mem_map(nid) (NODE_DATA(nid)->node_mem_map) @@ -40,8 +37,10 @@ static inline __attribute__((pure)) int #define node_end_pfn(nid) (NODE_DATA(nid)->node_start_pfn + \ NODE_DATA(nid)->node_spanned_pages) -#define local_mapnr(kvaddr) \ - ( (__pa(kvaddr) >> PAGE_SHIFT) - node_start_pfn(kvaddr_to_nid(kvaddr)) ) +#ifdef CONFIG_DISCONTIGMEM + +#define pfn_to_nid(pfn) phys_to_nid((unsigned long)(pfn) << PAGE_SHIFT) +#define kvaddr_to_nid(kaddr) phys_to_nid(__pa(kaddr)) /* AK: this currently doesn't deal with invalid addresses. We'll see if the 2.5 kernel doesn't pass them @@ -58,4 +57,8 @@ static inline __attribute__((pure)) int ({ u8 nid__ = pfn_to_nid(pfn); \ nid__ != 0xff && (pfn) >= node_start_pfn(nid__) && (pfn) <= node_end_pfn(nid__); })) #endif + +#define local_mapnr(kvaddr) \ + ( (__pa(kvaddr) >> PAGE_SHIFT) - node_start_pfn(kvaddr_to_nid(kvaddr)) ) +#endif #endif diff -puN include/asm-x86_64/page.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 include/asm-x86_64/page.h --- memhotplug/include/asm-x86_64/page.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/include/asm-x86_64/page.h 2005-03-11 10:52:29.000000000 -0800 @@ -122,7 +122,9 @@ extern __inline__ int get_order(unsigned __pa(v); }) #define __va(x) ((void *)((unsigned long)(x)+PAGE_OFFSET)) -#ifndef CONFIG_DISCONTIGMEM +#define __boot_va(x) __va(x) +#define __boot_pa(x) __pa(x) +#ifdef CONFIG_FLATMEM #define pfn_to_page(pfn) (mem_map + (pfn)) #define page_to_pfn(page) ((unsigned long)((page) - mem_map)) #define pfn_valid(pfn) ((pfn) < max_mapnr) diff -puN include/asm-x86_64/topology.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 include/asm-x86_64/topology.h --- memhotplug/include/asm-x86_64/topology.h~B-sparse-192-x86_64-c-shuffle-ifdefs-around-take4 2005-03-11 10:52:29.000000000 -0800 +++ memhotplug-dave/include/asm-x86_64/topology.h 2005-03-11 10:52:29.000000000 -0800 @@ -3,7 +3,7 @@ #include -#ifdef CONFIG_DISCONTIGMEM +#ifdef CONFIG_NUMA #include #include @@ -38,7 +38,6 @@ static inline cpumask_t __pcibus_to_cpum /* broken generic file uses #ifndef later on this */ #define pcibus_to_cpumask(bus) __pcibus_to_cpumask(bus) -#ifdef CONFIG_NUMA /* sched_domains SD_NODE_INIT for x86_64 machines */ #define SD_NODE_INIT (struct sched_domain) { \ .span = CPU_MASK_NONE, \ @@ -60,7 +59,6 @@ static inline cpumask_t __pcibus_to_cpum .balance_interval = 1, \ .nr_balance_failed = 0, \ } -#endif #endif _