diff options
| author | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2013-08-15 11:11:45 -0700 | 
| commit | ee3e542fec6e69bc9fb668698889a37d93950ddf (patch) | |
| tree | e74ee766a4764769ef1d3d45d266b4dea64101d3 /arch/arm64/mm/mmu.c | |
| parent | fe2a801b50c0bb8039d627e5ae1fec249d10ff39 (diff) | |
| parent | f1d6e17f540af37bb1891480143669ba7636c4cf (diff) | |
Merge remote-tracking branch 'linus/master' into testing
Diffstat (limited to 'arch/arm64/mm/mmu.c')
| -rw-r--r-- | arch/arm64/mm/mmu.c | 20 | 
1 files changed, 13 insertions, 7 deletions
| diff --git a/arch/arm64/mm/mmu.c b/arch/arm64/mm/mmu.c index eeecc9c8ed6..a8d1059b91b 100644 --- a/arch/arm64/mm/mmu.c +++ b/arch/arm64/mm/mmu.c @@ -297,6 +297,16 @@ static void __init map_mem(void)  {  	struct memblock_region *reg; +	/* +	 * Temporarily limit the memblock range. We need to do this as +	 * create_mapping requires puds, pmds and ptes to be allocated from +	 * memory addressable from the initial direct kernel mapping. +	 * +	 * The initial direct kernel mapping, located at swapper_pg_dir, +	 * gives us PGDIR_SIZE memory starting from PHYS_OFFSET (aligned). +	 */ +	memblock_set_current_limit((PHYS_OFFSET & PGDIR_MASK) + PGDIR_SIZE); +  	/* map all the memory banks */  	for_each_memblock(memory, reg) {  		phys_addr_t start = reg->base; @@ -307,6 +317,9 @@ static void __init map_mem(void)  		create_mapping(start, __phys_to_virt(start), end - start);  	} + +	/* Limit no longer required. */ +	memblock_set_current_limit(MEMBLOCK_ALLOC_ANYWHERE);  }  /* @@ -317,12 +330,6 @@ void __init paging_init(void)  {  	void *zero_page; -	/* -	 * Maximum PGDIR_SIZE addressable via the initial direct kernel -	 * mapping in swapper_pg_dir. -	 */ -	memblock_set_current_limit((PHYS_OFFSET & PGDIR_MASK) + PGDIR_SIZE); -  	init_mem_pgprot();  	map_mem(); @@ -339,7 +346,6 @@ void __init paging_init(void)  	bootmem_init();  	empty_zero_page = virt_to_page(zero_page); -	__flush_dcache_page(empty_zero_page);  	/*  	 * TTBR0 is only used for the identity mapping at this stage. Make it | 
