diff options
Diffstat (limited to 'arch/x86/mm')
| -rw-r--r-- | arch/x86/mm/highmem_32.c | 6 | ||||
| -rw-r--r-- | arch/x86/mm/hugetlbpage.c | 187 | ||||
| -rw-r--r-- | arch/x86/mm/init.c | 14 | ||||
| -rw-r--r-- | arch/x86/mm/init_32.c | 32 | ||||
| -rw-r--r-- | arch/x86/mm/init_64.c | 47 | ||||
| -rw-r--r-- | arch/x86/mm/ioremap.c | 8 | ||||
| -rw-r--r-- | arch/x86/mm/mmap.c | 4 | ||||
| -rw-r--r-- | arch/x86/mm/mmio-mod.c | 4 | ||||
| -rw-r--r-- | arch/x86/mm/numa.c | 12 | ||||
| -rw-r--r-- | arch/x86/mm/numa_32.c | 2 | ||||
| -rw-r--r-- | arch/x86/mm/numa_emulation.c | 12 | ||||
| -rw-r--r-- | arch/x86/mm/pgtable.c | 4 | ||||
| -rw-r--r-- | arch/x86/mm/setup_nx.c | 4 | 
13 files changed, 40 insertions, 296 deletions
| diff --git a/arch/x86/mm/highmem_32.c b/arch/x86/mm/highmem_32.c index 252b8f5489b..4500142bc4a 100644 --- a/arch/x86/mm/highmem_32.c +++ b/arch/x86/mm/highmem_32.c @@ -1,6 +1,7 @@  #include <linux/highmem.h>  #include <linux/module.h>  #include <linux/swap.h> /* for totalram_pages */ +#include <linux/bootmem.h>  void *kmap(struct page *page)  { @@ -121,6 +122,11 @@ void __init set_highmem_pages_init(void)  	struct zone *zone;  	int nid; +	/* +	 * Explicitly reset zone->managed_pages because set_highmem_pages_init() +	 * is invoked before free_all_bootmem() +	 */ +	reset_all_zones_managed_pages();  	for_each_zone(zone) {  		unsigned long zone_start_pfn, zone_end_pfn; diff --git a/arch/x86/mm/hugetlbpage.c b/arch/x86/mm/hugetlbpage.c index ae1aa71d011..7e73e8c6909 100644 --- a/arch/x86/mm/hugetlbpage.c +++ b/arch/x86/mm/hugetlbpage.c @@ -16,169 +16,6 @@  #include <asm/tlbflush.h>  #include <asm/pgalloc.h> -static unsigned long page_table_shareable(struct vm_area_struct *svma, -				struct vm_area_struct *vma, -				unsigned long addr, pgoff_t idx) -{ -	unsigned long saddr = ((idx - svma->vm_pgoff) << PAGE_SHIFT) + -				svma->vm_start; -	unsigned long sbase = saddr & PUD_MASK; -	unsigned long s_end = sbase + PUD_SIZE; - -	/* Allow segments to share if only one is marked locked */ -	unsigned long vm_flags = vma->vm_flags & ~VM_LOCKED; -	unsigned long svm_flags = svma->vm_flags & ~VM_LOCKED; - -	/* -	 * match the virtual addresses, permission and the alignment of the -	 * page table page. -	 */ -	if (pmd_index(addr) != pmd_index(saddr) || -	    vm_flags != svm_flags || -	    sbase < svma->vm_start || svma->vm_end < s_end) -		return 0; - -	return saddr; -} - -static int vma_shareable(struct vm_area_struct *vma, unsigned long addr) -{ -	unsigned long base = addr & PUD_MASK; -	unsigned long end = base + PUD_SIZE; - -	/* -	 * check on proper vm_flags and page table alignment -	 */ -	if (vma->vm_flags & VM_MAYSHARE && -	    vma->vm_start <= base && end <= vma->vm_end) -		return 1; -	return 0; -} - -/* - * Search for a shareable pmd page for hugetlb. In any case calls pmd_alloc() - * and returns the corresponding pte. While this is not necessary for the - * !shared pmd case because we can allocate the pmd later as well, it makes the - * code much cleaner. pmd allocation is essential for the shared case because - * pud has to be populated inside the same i_mmap_mutex section - otherwise - * racing tasks could either miss the sharing (see huge_pte_offset) or select a - * bad pmd for sharing. - */ -static pte_t * -huge_pmd_share(struct mm_struct *mm, unsigned long addr, pud_t *pud) -{ -	struct vm_area_struct *vma = find_vma(mm, addr); -	struct address_space *mapping = vma->vm_file->f_mapping; -	pgoff_t idx = ((addr - vma->vm_start) >> PAGE_SHIFT) + -			vma->vm_pgoff; -	struct vm_area_struct *svma; -	unsigned long saddr; -	pte_t *spte = NULL; -	pte_t *pte; - -	if (!vma_shareable(vma, addr)) -		return (pte_t *)pmd_alloc(mm, pud, addr); - -	mutex_lock(&mapping->i_mmap_mutex); -	vma_interval_tree_foreach(svma, &mapping->i_mmap, idx, idx) { -		if (svma == vma) -			continue; - -		saddr = page_table_shareable(svma, vma, addr, idx); -		if (saddr) { -			spte = huge_pte_offset(svma->vm_mm, saddr); -			if (spte) { -				get_page(virt_to_page(spte)); -				break; -			} -		} -	} - -	if (!spte) -		goto out; - -	spin_lock(&mm->page_table_lock); -	if (pud_none(*pud)) -		pud_populate(mm, pud, (pmd_t *)((unsigned long)spte & PAGE_MASK)); -	else -		put_page(virt_to_page(spte)); -	spin_unlock(&mm->page_table_lock); -out: -	pte = (pte_t *)pmd_alloc(mm, pud, addr); -	mutex_unlock(&mapping->i_mmap_mutex); -	return pte; -} - -/* - * unmap huge page backed by shared pte. - * - * Hugetlb pte page is ref counted at the time of mapping.  If pte is shared - * indicated by page_count > 1, unmap is achieved by clearing pud and - * decrementing the ref count. If count == 1, the pte page is not shared. - * - * called with vma->vm_mm->page_table_lock held. - * - * returns: 1 successfully unmapped a shared pte page - *	    0 the underlying pte page is not shared, or it is the last user - */ -int huge_pmd_unshare(struct mm_struct *mm, unsigned long *addr, pte_t *ptep) -{ -	pgd_t *pgd = pgd_offset(mm, *addr); -	pud_t *pud = pud_offset(pgd, *addr); - -	BUG_ON(page_count(virt_to_page(ptep)) == 0); -	if (page_count(virt_to_page(ptep)) == 1) -		return 0; - -	pud_clear(pud); -	put_page(virt_to_page(ptep)); -	*addr = ALIGN(*addr, HPAGE_SIZE * PTRS_PER_PTE) - HPAGE_SIZE; -	return 1; -} - -pte_t *huge_pte_alloc(struct mm_struct *mm, -			unsigned long addr, unsigned long sz) -{ -	pgd_t *pgd; -	pud_t *pud; -	pte_t *pte = NULL; - -	pgd = pgd_offset(mm, addr); -	pud = pud_alloc(mm, pgd, addr); -	if (pud) { -		if (sz == PUD_SIZE) { -			pte = (pte_t *)pud; -		} else { -			BUG_ON(sz != PMD_SIZE); -			if (pud_none(*pud)) -				pte = huge_pmd_share(mm, addr, pud); -			else -				pte = (pte_t *)pmd_alloc(mm, pud, addr); -		} -	} -	BUG_ON(pte && !pte_none(*pte) && !pte_huge(*pte)); - -	return pte; -} - -pte_t *huge_pte_offset(struct mm_struct *mm, unsigned long addr) -{ -	pgd_t *pgd; -	pud_t *pud; -	pmd_t *pmd = NULL; - -	pgd = pgd_offset(mm, addr); -	if (pgd_present(*pgd)) { -		pud = pud_offset(pgd, addr); -		if (pud_present(*pud)) { -			if (pud_large(*pud)) -				return (pte_t *)pud; -			pmd = pmd_offset(pud, addr); -		} -	} -	return (pte_t *) pmd; -} -  #if 0	/* This is just for testing */  struct page *  follow_huge_addr(struct mm_struct *mm, unsigned long address, int write) @@ -240,30 +77,6 @@ int pud_huge(pud_t pud)  	return !!(pud_val(pud) & _PAGE_PSE);  } -struct page * -follow_huge_pmd(struct mm_struct *mm, unsigned long address, -		pmd_t *pmd, int write) -{ -	struct page *page; - -	page = pte_page(*(pte_t *)pmd); -	if (page) -		page += ((address & ~PMD_MASK) >> PAGE_SHIFT); -	return page; -} - -struct page * -follow_huge_pud(struct mm_struct *mm, unsigned long address, -		pud_t *pud, int write) -{ -	struct page *page; - -	page = pte_page(*(pte_t *)pud); -	if (page) -		page += ((address & ~PUD_MASK) >> PAGE_SHIFT); -	return page; -} -  #endif  /* x86_64 also uses this file */ diff --git a/arch/x86/mm/init.c b/arch/x86/mm/init.c index 1f34e921977..2ec29ac78ae 100644 --- a/arch/x86/mm/init.c +++ b/arch/x86/mm/init.c @@ -494,7 +494,6 @@ int devmem_is_allowed(unsigned long pagenr)  void free_init_pages(char *what, unsigned long begin, unsigned long end)  { -	unsigned long addr;  	unsigned long begin_aligned, end_aligned;  	/* Make sure boundaries are page aligned */ @@ -509,8 +508,6 @@ void free_init_pages(char *what, unsigned long begin, unsigned long end)  	if (begin >= end)  		return; -	addr = begin; -  	/*  	 * If debugging page accesses then do not free this memory but  	 * mark them not present - any buggy init-section access will @@ -529,18 +526,13 @@ void free_init_pages(char *what, unsigned long begin, unsigned long end)  	set_memory_nx(begin, (end - begin) >> PAGE_SHIFT);  	set_memory_rw(begin, (end - begin) >> PAGE_SHIFT); -	printk(KERN_INFO "Freeing %s: %luk freed\n", what, (end - begin) >> 10); - -	for (; addr < end; addr += PAGE_SIZE) { -		memset((void *)addr, POISON_FREE_INITMEM, PAGE_SIZE); -		free_reserved_page(virt_to_page(addr)); -	} +	free_reserved_area((void *)begin, (void *)end, POISON_FREE_INITMEM, what);  #endif  }  void free_initmem(void)  { -	free_init_pages("unused kernel memory", +	free_init_pages("unused kernel",  			(unsigned long)(&__init_begin),  			(unsigned long)(&__init_end));  } @@ -566,7 +558,7 @@ void __init free_initrd_mem(unsigned long start, unsigned long end)  	 *   - relocate_initrd()  	 * So here We can do PAGE_ALIGN() safely to get partial page to be freed  	 */ -	free_init_pages("initrd memory", start, PAGE_ALIGN(end)); +	free_init_pages("initrd", start, PAGE_ALIGN(end));  }  #endif diff --git a/arch/x86/mm/init_32.c b/arch/x86/mm/init_32.c index 3ac7e319918..4287f1ffba7 100644 --- a/arch/x86/mm/init_32.c +++ b/arch/x86/mm/init_32.c @@ -660,10 +660,8 @@ void __init initmem_init(void)  		highstart_pfn = max_low_pfn;  	printk(KERN_NOTICE "%ldMB HIGHMEM available.\n",  		pages_to_mb(highend_pfn - highstart_pfn)); -	num_physpages = highend_pfn;  	high_memory = (void *) __va(highstart_pfn * PAGE_SIZE - 1) + 1;  #else -	num_physpages = max_low_pfn;  	high_memory = (void *) __va(max_low_pfn * PAGE_SIZE - 1) + 1;  #endif @@ -671,7 +669,7 @@ void __init initmem_init(void)  	sparse_memory_present_with_active_regions(0);  #ifdef CONFIG_FLATMEM -	max_mapnr = num_physpages; +	max_mapnr = IS_ENABLED(CONFIG_HIGHMEM) ? highend_pfn : max_low_pfn;  #endif  	__vmalloc_start_set = true; @@ -739,9 +737,6 @@ static void __init test_wp_bit(void)  void __init mem_init(void)  { -	int codesize, reservedpages, datasize, initsize; -	int tmp; -  	pci_iommu_alloc();  #ifdef CONFIG_FLATMEM @@ -759,32 +754,11 @@ void __init mem_init(void)  	set_highmem_pages_init();  	/* this will put all low memory onto the freelists */ -	totalram_pages += free_all_bootmem(); - -	reservedpages = 0; -	for (tmp = 0; tmp < max_low_pfn; tmp++) -		/* -		 * Only count reserved RAM pages: -		 */ -		if (page_is_ram(tmp) && PageReserved(pfn_to_page(tmp))) -			reservedpages++; +	free_all_bootmem();  	after_bootmem = 1; -	codesize =  (unsigned long) &_etext - (unsigned long) &_text; -	datasize =  (unsigned long) &_edata - (unsigned long) &_etext; -	initsize =  (unsigned long) &__init_end - (unsigned long) &__init_begin; - -	printk(KERN_INFO "Memory: %luk/%luk available (%dk kernel code, " -			"%dk reserved, %dk data, %dk init, %ldk highmem)\n", -		nr_free_pages() << (PAGE_SHIFT-10), -		num_physpages << (PAGE_SHIFT-10), -		codesize >> 10, -		reservedpages << (PAGE_SHIFT-10), -		datasize >> 10, -		initsize >> 10, -		totalhigh_pages << (PAGE_SHIFT-10)); - +	mem_init_print_info(NULL);  	printk(KERN_INFO "virtual kernel memory layout:\n"  		"    fixmap  : 0x%08lx - 0x%08lx   (%4ld kB)\n"  #ifdef CONFIG_HIGHMEM diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c index bb00c4672ad..104d56a9245 100644 --- a/arch/x86/mm/init_64.c +++ b/arch/x86/mm/init_64.c @@ -368,7 +368,7 @@ void __init init_extra_mapping_uc(unsigned long phys, unsigned long size)   *   *   from __START_KERNEL_map to __START_KERNEL_map + size (== _end-_text)   * - * phys_addr holds the negative offset to the kernel, which is added + * phys_base holds the negative offset to the kernel, which is added   * to the compile time generated pmds. This results in invalid pmds up   * to the point where we hit the physaddr 0 mapping.   * @@ -712,36 +712,22 @@ EXPORT_SYMBOL_GPL(arch_add_memory);  static void __meminit free_pagetable(struct page *page, int order)  { -	struct zone *zone; -	bool bootmem = false;  	unsigned long magic;  	unsigned int nr_pages = 1 << order;  	/* bootmem page has reserved flag */  	if (PageReserved(page)) {  		__ClearPageReserved(page); -		bootmem = true;  		magic = (unsigned long)page->lru.next;  		if (magic == SECTION_INFO || magic == MIX_SECTION_INFO) {  			while (nr_pages--)  				put_page_bootmem(page++);  		} else -			__free_pages_bootmem(page, order); +			while (nr_pages--) +				free_reserved_page(page++);  	} else  		free_pages((unsigned long)page_address(page), order); - -	/* -	 * SECTION_INFO pages and MIX_SECTION_INFO pages -	 * are all allocated by bootmem. -	 */ -	if (bootmem) { -		zone = page_zone(page); -		zone_span_writelock(zone); -		zone->present_pages += nr_pages; -		zone_span_writeunlock(zone); -		totalram_pages += nr_pages; -	}  }  static void __meminit free_pte_table(pte_t *pte_start, pmd_t *pmd) @@ -1058,9 +1044,6 @@ static void __init register_page_bootmem_info(void)  void __init mem_init(void)  { -	long codesize, reservedpages, datasize, initsize; -	unsigned long absent_pages; -  	pci_iommu_alloc();  	/* clear_bss() already clear the empty_zero_page */ @@ -1068,29 +1051,14 @@ void __init mem_init(void)  	register_page_bootmem_info();  	/* this will put all memory onto the freelists */ -	totalram_pages = free_all_bootmem(); - -	absent_pages = absent_pages_in_range(0, max_pfn); -	reservedpages = max_pfn - totalram_pages - absent_pages; +	free_all_bootmem();  	after_bootmem = 1; -	codesize =  (unsigned long) &_etext - (unsigned long) &_text; -	datasize =  (unsigned long) &_edata - (unsigned long) &_etext; -	initsize =  (unsigned long) &__init_end - (unsigned long) &__init_begin; -  	/* Register memory areas for /proc/kcore */  	kclist_add(&kcore_vsyscall, (void *)VSYSCALL_START,  			 VSYSCALL_END - VSYSCALL_START, KCORE_OTHER); -	printk(KERN_INFO "Memory: %luk/%luk available (%ldk kernel code, " -			 "%ldk absent, %ldk reserved, %ldk data, %ldk init)\n", -		nr_free_pages() << (PAGE_SHIFT-10), -		max_pfn << (PAGE_SHIFT-10), -		codesize >> 10, -		absent_pages << (PAGE_SHIFT-10), -		reservedpages << (PAGE_SHIFT-10), -		datasize >> 10, -		initsize >> 10); +	mem_init_print_info(NULL);  }  #ifdef CONFIG_DEBUG_RODATA @@ -1166,11 +1134,10 @@ void mark_rodata_ro(void)  	set_memory_ro(start, (end-start) >> PAGE_SHIFT);  #endif -	free_init_pages("unused kernel memory", +	free_init_pages("unused kernel",  			(unsigned long) __va(__pa_symbol(text_end)),  			(unsigned long) __va(__pa_symbol(rodata_start))); - -	free_init_pages("unused kernel memory", +	free_init_pages("unused kernel",  			(unsigned long) __va(__pa_symbol(rodata_end)),  			(unsigned long) __va(__pa_symbol(_sdata)));  } diff --git a/arch/x86/mm/ioremap.c b/arch/x86/mm/ioremap.c index 9a1e6583910..0215e2c563e 100644 --- a/arch/x86/mm/ioremap.c +++ b/arch/x86/mm/ioremap.c @@ -501,15 +501,15 @@ __early_ioremap(resource_size_t phys_addr, unsigned long size, pgprot_t prot)  	}  	if (slot < 0) { -		printk(KERN_INFO "early_iomap(%08llx, %08lx) not found slot\n", -			 (u64)phys_addr, size); +		printk(KERN_INFO "%s(%08llx, %08lx) not found slot\n", +		       __func__, (u64)phys_addr, size);  		WARN_ON(1);  		return NULL;  	}  	if (early_ioremap_debug) { -		printk(KERN_INFO "early_ioremap(%08llx, %08lx) [%d] => ", -		       (u64)phys_addr, size, slot); +		printk(KERN_INFO "%s(%08llx, %08lx) [%d] => ", +		       __func__, (u64)phys_addr, size, slot);  		dump_stack();  	} diff --git a/arch/x86/mm/mmap.c b/arch/x86/mm/mmap.c index 845df6835f9..f63778cb236 100644 --- a/arch/x86/mm/mmap.c +++ b/arch/x86/mm/mmap.c @@ -98,7 +98,7 @@ static unsigned long mmap_base(void)   * Bottom-up (legacy) layout on X86_32 did not support randomization, X86_64   * does, but not when emulating X86_32   */ -static unsigned long mmap_legacy_base(void) +unsigned long mmap_legacy_base(void)  {  	if (mmap_is_ia32())  		return TASK_UNMAPPED_BASE; @@ -115,10 +115,8 @@ void arch_pick_mmap_layout(struct mm_struct *mm)  	if (mmap_is_legacy()) {  		mm->mmap_base = mmap_legacy_base();  		mm->get_unmapped_area = arch_get_unmapped_area; -		mm->unmap_area = arch_unmap_area;  	} else {  		mm->mmap_base = mmap_base();  		mm->get_unmapped_area = arch_get_unmapped_area_topdown; -		mm->unmap_area = arch_unmap_area_topdown;  	}  } diff --git a/arch/x86/mm/mmio-mod.c b/arch/x86/mm/mmio-mod.c index dc0b727742f..0057a7accfb 100644 --- a/arch/x86/mm/mmio-mod.c +++ b/arch/x86/mm/mmio-mod.c @@ -410,9 +410,7 @@ out:  		pr_warning("multiple CPUs still online, may miss events.\n");  } -/* __ref because leave_uniprocessor calls cpu_up which is __cpuinit, -   but this whole function is ifdefed CONFIG_HOTPLUG_CPU */ -static void __ref leave_uniprocessor(void) +static void leave_uniprocessor(void)  {  	int cpu;  	int err; diff --git a/arch/x86/mm/numa.c b/arch/x86/mm/numa.c index a71c4e20767..8bf93bae1f1 100644 --- a/arch/x86/mm/numa.c +++ b/arch/x86/mm/numa.c @@ -60,7 +60,7 @@ s16 __apicid_to_node[MAX_LOCAL_APIC] = {  	[0 ... MAX_LOCAL_APIC-1] = NUMA_NO_NODE  }; -int __cpuinit numa_cpu_node(int cpu) +int numa_cpu_node(int cpu)  {  	int apicid = early_per_cpu(x86_cpu_to_apicid, cpu); @@ -691,12 +691,12 @@ void __init init_cpu_to_node(void)  #ifndef CONFIG_DEBUG_PER_CPU_MAPS  # ifndef CONFIG_NUMA_EMU -void __cpuinit numa_add_cpu(int cpu) +void numa_add_cpu(int cpu)  {  	cpumask_set_cpu(cpu, node_to_cpumask_map[early_cpu_to_node(cpu)]);  } -void __cpuinit numa_remove_cpu(int cpu) +void numa_remove_cpu(int cpu)  {  	cpumask_clear_cpu(cpu, node_to_cpumask_map[early_cpu_to_node(cpu)]);  } @@ -763,17 +763,17 @@ void debug_cpumask_set_cpu(int cpu, int node, bool enable)  }  # ifndef CONFIG_NUMA_EMU -static void __cpuinit numa_set_cpumask(int cpu, bool enable) +static void numa_set_cpumask(int cpu, bool enable)  {  	debug_cpumask_set_cpu(cpu, early_cpu_to_node(cpu), enable);  } -void __cpuinit numa_add_cpu(int cpu) +void numa_add_cpu(int cpu)  {  	numa_set_cpumask(cpu, true);  } -void __cpuinit numa_remove_cpu(int cpu) +void numa_remove_cpu(int cpu)  {  	numa_set_cpumask(cpu, false);  } diff --git a/arch/x86/mm/numa_32.c b/arch/x86/mm/numa_32.c index 73a6d7395bd..0342d27ca79 100644 --- a/arch/x86/mm/numa_32.c +++ b/arch/x86/mm/numa_32.c @@ -83,10 +83,8 @@ void __init initmem_init(void)  		highstart_pfn = max_low_pfn;  	printk(KERN_NOTICE "%ldMB HIGHMEM available.\n",  	       pages_to_mb(highend_pfn - highstart_pfn)); -	num_physpages = highend_pfn;  	high_memory = (void *) __va(highstart_pfn * PAGE_SIZE - 1) + 1;  #else -	num_physpages = max_low_pfn;  	high_memory = (void *) __va(max_low_pfn * PAGE_SIZE - 1) + 1;  #endif  	printk(KERN_NOTICE "%ldMB LOWMEM available.\n", diff --git a/arch/x86/mm/numa_emulation.c b/arch/x86/mm/numa_emulation.c index dbbbb47260c..a8f90ce3ded 100644 --- a/arch/x86/mm/numa_emulation.c +++ b/arch/x86/mm/numa_emulation.c @@ -10,7 +10,7 @@  #include "numa_internal.h" -static int emu_nid_to_phys[MAX_NUMNODES] __cpuinitdata; +static int emu_nid_to_phys[MAX_NUMNODES];  static char *emu_cmdline __initdata;  void __init numa_emu_cmdline(char *str) @@ -444,7 +444,7 @@ no_emu:  }  #ifndef CONFIG_DEBUG_PER_CPU_MAPS -void __cpuinit numa_add_cpu(int cpu) +void numa_add_cpu(int cpu)  {  	int physnid, nid; @@ -462,7 +462,7 @@ void __cpuinit numa_add_cpu(int cpu)  			cpumask_set_cpu(cpu, node_to_cpumask_map[nid]);  } -void __cpuinit numa_remove_cpu(int cpu) +void numa_remove_cpu(int cpu)  {  	int i; @@ -470,7 +470,7 @@ void __cpuinit numa_remove_cpu(int cpu)  		cpumask_clear_cpu(cpu, node_to_cpumask_map[i]);  }  #else	/* !CONFIG_DEBUG_PER_CPU_MAPS */ -static void __cpuinit numa_set_cpumask(int cpu, bool enable) +static void numa_set_cpumask(int cpu, bool enable)  {  	int nid, physnid; @@ -490,12 +490,12 @@ static void __cpuinit numa_set_cpumask(int cpu, bool enable)  	}  } -void __cpuinit numa_add_cpu(int cpu) +void numa_add_cpu(int cpu)  {  	numa_set_cpumask(cpu, true);  } -void __cpuinit numa_remove_cpu(int cpu) +void numa_remove_cpu(int cpu)  {  	numa_set_cpumask(cpu, false);  } diff --git a/arch/x86/mm/pgtable.c b/arch/x86/mm/pgtable.c index 17fda6a8b3c..dfa537a03be 100644 --- a/arch/x86/mm/pgtable.c +++ b/arch/x86/mm/pgtable.c @@ -240,7 +240,6 @@ static void pgd_mop_up_pmds(struct mm_struct *mm, pgd_t *pgdp)  static void pgd_prepopulate_pmd(struct mm_struct *mm, pgd_t *pgd, pmd_t *pmds[])  {  	pud_t *pud; -	unsigned long addr;  	int i;  	if (PREALLOCATED_PMDS == 0) /* Work around gcc-3.4.x bug */ @@ -248,8 +247,7 @@ static void pgd_prepopulate_pmd(struct mm_struct *mm, pgd_t *pgd, pmd_t *pmds[])  	pud = pud_offset(pgd, 0); - 	for (addr = i = 0; i < PREALLOCATED_PMDS; -	     i++, pud++, addr += PUD_SIZE) { +	for (i = 0; i < PREALLOCATED_PMDS; i++, pud++) {  		pmd_t *pmd = pmds[i];  		if (i >= KERNEL_PGD_BOUNDARY) diff --git a/arch/x86/mm/setup_nx.c b/arch/x86/mm/setup_nx.c index 410531d3c29..90555bf60aa 100644 --- a/arch/x86/mm/setup_nx.c +++ b/arch/x86/mm/setup_nx.c @@ -5,7 +5,7 @@  #include <asm/pgtable.h>  #include <asm/proto.h> -static int disable_nx __cpuinitdata; +static int disable_nx;  /*   * noexec = on|off @@ -29,7 +29,7 @@ static int __init noexec_setup(char *str)  }  early_param("noexec", noexec_setup); -void __cpuinit x86_configure_nx(void) +void x86_configure_nx(void)  {  	if (cpu_has_nx && !disable_nx)  		__supported_pte_mask |= _PAGE_NX; | 
