diff options
Diffstat (limited to 'arch/mips/kernel/setup.c')
| -rw-r--r-- | arch/mips/kernel/setup.c | 22 | 
1 files changed, 21 insertions, 1 deletions
| diff --git a/arch/mips/kernel/setup.c b/arch/mips/kernel/setup.c index 36cf8d65c47d..f66e5ce505b2 100644 --- a/arch/mips/kernel/setup.c +++ b/arch/mips/kernel/setup.c @@ -87,6 +87,13 @@ void __init add_memory_region(phys_addr_t start, phys_addr_t size, long type)  	int x = boot_mem_map.nr_map;  	int i; +	/* +	 * If the region reaches the top of the physical address space, adjust +	 * the size slightly so that (start + size) doesn't overflow +	 */ +	if (start + size - 1 == (phys_addr_t)ULLONG_MAX) +		--size; +  	/* Sanity check */  	if (start + size < start) {  		pr_warn("Trying to add an invalid memory region, skipped\n"); @@ -361,6 +368,19 @@ static void __init bootmem_init(void)  		end = PFN_DOWN(boot_mem_map.map[i].addr  				+ boot_mem_map.map[i].size); +#ifndef CONFIG_HIGHMEM +		/* +		 * Skip highmem here so we get an accurate max_low_pfn if low +		 * memory stops short of high memory. +		 * If the region overlaps HIGHMEM_START, end is clipped so +		 * max_pfn excludes the highmem portion. +		 */ +		if (start >= PFN_DOWN(HIGHMEM_START)) +			continue; +		if (end > PFN_DOWN(HIGHMEM_START)) +			end = PFN_DOWN(HIGHMEM_START); +#endif +  		if (end > max_low_pfn)  			max_low_pfn = end;  		if (start < min_low_pfn) @@ -757,7 +777,6 @@ static void __init arch_mem_init(char **cmdline_p)  	device_tree_init();  	sparse_init();  	plat_swiotlb_setup(); -	paging_init();  	dma_contiguous_reserve(PFN_PHYS(max_low_pfn));  	/* Tell bootmem about cma reserved memblock section */ @@ -870,6 +889,7 @@ void __init setup_arch(char **cmdline_p)  	prefill_possible_map();  	cpu_cache_init(); +	paging_init();  }  unsigned long kernelsp[NR_CPUS]; |