The patch titled virtual memmap on sparsemem: ia64 support has been added to the -mm tree. Its filename is virtual-memmap-on-sparsemem-v3-ia64-support.patch See http://www.zip.com.au/~akpm/linux/patches/stuff/added-to-mm.txt to find out what to do about this ------------------------------------------------------ Subject: virtual memmap on sparsemem: ia64 support From: KAMEZAWA Hiroyuki <kamezawa.hiroyu@xxxxxxxxxxxxxx> ia64 support for sparsemem/vmem_map. * defines mem_map[] and set its value (by static way). * changes definitions of VMALLOC_START. * adds CONFIGS. Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@xxxxxxxxxxxxxx> Cc: Andy Whitcroft <apw@xxxxxxxxxxxx> Cc: Dave Hansen <haveblue@xxxxxxxxxx> Cc: Martin Bligh <mbligh@xxxxxxxxxx> Cc: "Luck, Tony" <tony.luck@xxxxxxxxx> Cc: Christoph Lameter <clameter@xxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxx> --- arch/ia64/Kconfig | 8 ++++++++ arch/ia64/kernel/vmlinux.lds.S | 4 ++++ include/asm-ia64/pgtable.h | 16 ++++++++++++---- include/asm-ia64/sparsemem.h | 9 +++++++++ 4 files changed, 33 insertions(+), 4 deletions(-) diff -puN arch/ia64/Kconfig~virtual-memmap-on-sparsemem-v3-ia64-support arch/ia64/Kconfig --- a/arch/ia64/Kconfig~virtual-memmap-on-sparsemem-v3-ia64-support +++ a/arch/ia64/Kconfig @@ -341,6 +341,14 @@ config ARCH_SPARSEMEM_ENABLE def_bool y depends on ARCH_DISCONTIGMEM_ENABLE +config ARCH_SPARSEMEM_VMEMMAP + def_bool y + depends on ARCH_SPARSEMEM_ENABLE + +config ARCH_SPARSEMEM_VMEMMAP_STATIC + def_bool y + depends on SPARSEMEM_VMEMMAP + config ARCH_DISCONTIGMEM_DEFAULT def_bool y if (IA64_SGI_SN2 || IA64_GENERIC || IA64_HP_ZX1 || IA64_HP_ZX1_SWIOTLB) depends on ARCH_DISCONTIGMEM_ENABLE diff -puN arch/ia64/kernel/vmlinux.lds.S~virtual-memmap-on-sparsemem-v3-ia64-support arch/ia64/kernel/vmlinux.lds.S --- a/arch/ia64/kernel/vmlinux.lds.S~virtual-memmap-on-sparsemem-v3-ia64-support +++ a/arch/ia64/kernel/vmlinux.lds.S @@ -2,6 +2,7 @@ #include <asm/cache.h> #include <asm/ptrace.h> #include <asm/system.h> +#include <asm/sparsemem.h> #include <asm/pgtable.h> #define LOAD_OFFSET (KERNEL_START - KERNEL_TR_PAGE_SIZE) @@ -34,6 +35,9 @@ SECTIONS v = PAGE_OFFSET; /* this symbol is here to make debugging easier... */ phys_start = _start - LOAD_OFFSET; +#ifdef CONFIG_SPARSEMEM_VMEMMAP + mem_map = VIRTUAL_MEM_MAP_START; +#endif code : { } :code . = KERNEL_START; diff -puN include/asm-ia64/pgtable.h~virtual-memmap-on-sparsemem-v3-ia64-support include/asm-ia64/pgtable.h --- a/include/asm-ia64/pgtable.h~virtual-memmap-on-sparsemem-v3-ia64-support +++ a/include/asm-ia64/pgtable.h @@ -230,13 +230,21 @@ ia64_phys_addr_valid (unsigned long addr #define set_pte(ptep, pteval) (*(ptep) = (pteval)) #define set_pte_at(mm,addr,ptep,pteval) set_pte(ptep,pteval) +#if defined(CONFIG_SPARSEMEM_VMEMMAP) +#define VMALLOC_START (VIRTUAL_MEM_MAP_END) +#define VMALLOC_END (RGN_BASE(RGN_GATE) + (1UL << (4*PAGE_SHIFT - 9))) + +#elif defined(CONFIG_VIRTUAL_MEM_MAP) #define VMALLOC_START (RGN_BASE(RGN_GATE) + 0x200000000UL) -#ifdef CONFIG_VIRTUAL_MEM_MAP -# define VMALLOC_END_INIT (RGN_BASE(RGN_GATE) + (1UL << (4*PAGE_SHIFT - 9))) -# define VMALLOC_END vmalloc_end - extern unsigned long vmalloc_end; + +#defineVMALLOC_END_INIT (RGN_BASE(RGN_GATE) + (1UL << (4*PAGE_SHIFT - 9))) +#define VMALLOC_END vmalloc_end +extern unsigned long vmalloc_end; #else + +#define VMALLOC_START (RGN_BASE(RGN_GATE) + 0x200000000UL) # define VMALLOC_END (RGN_BASE(RGN_GATE) + (1UL << (4*PAGE_SHIFT - 9))) + #endif /* fs/proc/kcore.c */ diff -puN include/asm-ia64/sparsemem.h~virtual-memmap-on-sparsemem-v3-ia64-support include/asm-ia64/sparsemem.h --- a/include/asm-ia64/sparsemem.h~virtual-memmap-on-sparsemem-v3-ia64-support +++ a/include/asm-ia64/sparsemem.h @@ -16,5 +16,14 @@ #endif #endif +#ifdef CONFIG_SPARSEMEM_VMEMMAP +#define VIRTUAL_MEM_MAP_START (RGN_BASE(RGN_GATE) + 0x200000000) + +#ifndef __ASSEMBLY__ +#define VIRTUAL_MEM_MAP_SIZE ((1UL << (MAX_PHYSMEM_BITS - PAGE_SHIFT)) * sizeof(struct page)) +#define VIRTUAL_MEM_MAP_END (VIRTUAL_MEM_MAP_START + VIRTUAL_MEM_MAP_SIZE) +#endif +#endif + #endif /* CONFIG_SPARSEMEM */ #endif /* _ASM_IA64_SPARSEMEM_H */ _ Patches currently in -mm which might be from kamezawa.hiroyu@xxxxxxxxxxxxxx are origin.patch virtual-memmap-on-sparsemem-v3-map-and-unmap.patch virtual-memmap-on-sparsemem-v3-generic-virtual.patch virtual-memmap-on-sparsemem-v3-static-virtual.patch virtual-memmap-on-sparsemem-v3-ia64-support.patch sched-avoid-taking-rq-lock-in-wake_priority_sleeper.patch sched-remove-staggering-of-load-balancing.patch sched-disable-interrupts-for-locking-in-load_balance.patch sched-extract-load-calculation-from-rebalance_tick.patch sched-move-idle-status-calculation-into-rebalance_tick.patch sched-use-softirq-for-load-balancing.patch sched-call-tasklet-less-frequently.patch sched-add-option-to-serialize-load-balancing.patch sched-add-option-to-serialize-load-balancing-fix.patch mm-only-sched-add-a-few-scheduler-event-counters.patch reiser4-hardirq-include-fix.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