diff options
Diffstat (limited to 'arch/x86/kernel/setup.c')
| -rw-r--r-- | arch/x86/kernel/setup.c | 51 | 
1 files changed, 25 insertions, 26 deletions
| diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c index b3143bc74e6c..b176f2b1f45d 100644 --- a/arch/x86/kernel/setup.c +++ b/arch/x86/kernel/setup.c @@ -294,10 +294,32 @@ static void __init init_gbpages(void)  	else  		direct_gbpages = 0;  } + +static void __init cleanup_highmap_brk_end(void) +{ +	pud_t *pud; +	pmd_t *pmd; + +	mmu_cr4_features = read_cr4(); + +	/* +	 * _brk_end cannot change anymore, but it and _end may be +	 * located on different 2M pages. cleanup_highmap(), however, +	 * can only consider _end when it runs, so destroy any +	 * mappings beyond _brk_end here. +	 */ +	pud = pud_offset(pgd_offset_k(_brk_end), _brk_end); +	pmd = pmd_offset(pud, _brk_end - 1); +	while (++pmd <= pmd_offset(pud, (unsigned long)_end - 1)) +		pmd_clear(pmd); +}  #else  static inline void init_gbpages(void)  {  } +static inline void cleanup_highmap_brk_end(void) +{ +}  #endif  static void __init reserve_brk(void) @@ -308,6 +330,8 @@ static void __init reserve_brk(void)  	/* Mark brk area as locked down and no longer taking any  	   new allocations */  	_brk_start = 0; + +	cleanup_highmap_brk_end();  }  #ifdef CONFIG_BLK_DEV_INITRD @@ -695,15 +719,6 @@ static int __init parse_reservelow(char *p)  early_param("reservelow", parse_reservelow); -static u64 __init get_max_mapped(void) -{ -	u64 end = max_pfn_mapped; - -	end <<= PAGE_SHIFT; - -	return end; -} -  /*   * Determine if we were loaded by an EFI loader.  If so, then we have also been   * passed the efi memmap, systab, etc., so we should use these data structures @@ -719,8 +734,6 @@ static u64 __init get_max_mapped(void)  void __init setup_arch(char **cmdline_p)  { -	int acpi = 0; -	int amd = 0;  	unsigned long flags;  #ifdef CONFIG_X86_32 @@ -999,19 +1012,7 @@ void __init setup_arch(char **cmdline_p)  	early_acpi_boot_init(); -#ifdef CONFIG_ACPI_NUMA -	/* -	 * Parse SRAT to discover nodes. -	 */ -	acpi = acpi_numa_init(); -#endif - -#ifdef CONFIG_AMD_NUMA -	if (!acpi) -		amd = !amd_numa_init(0, max_pfn); -#endif - -	initmem_init(0, max_pfn, acpi, amd); +	initmem_init();  	memblock_find_dma_reserve();  	dma32_reserve_bootmem(); @@ -1055,9 +1056,7 @@ void __init setup_arch(char **cmdline_p)  	prefill_possible_map(); -#ifdef CONFIG_X86_64  	init_cpu_to_node(); -#endif  	init_apic_mappings();  	ioapic_and_gsi_init(); |