diff options
Diffstat (limited to 'arch/arm/mm/init.c')
| -rw-r--r-- | arch/arm/mm/init.c | 28 | 
1 files changed, 11 insertions, 17 deletions
| diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c index febaee7ca57b..3e8f106ee5fe 100644 --- a/arch/arm/mm/init.c +++ b/arch/arm/mm/init.c @@ -17,7 +17,6 @@  #include <linux/nodemask.h>  #include <linux/initrd.h>  #include <linux/of_fdt.h> -#include <linux/of_reserved_mem.h>  #include <linux/highmem.h>  #include <linux/gfp.h>  #include <linux/memblock.h> @@ -77,14 +76,6 @@ static int __init parse_tag_initrd2(const struct tag *tag)  __tagtable(ATAG_INITRD2, parse_tag_initrd2); -#ifdef CONFIG_OF_FLATTREE -void __init early_init_dt_setup_initrd_arch(u64 start, u64 end) -{ -	phys_initrd_start = start; -	phys_initrd_size = end - start; -} -#endif /* CONFIG_OF_FLATTREE */ -  /*   * This keeps memory configuration data used by a couple memory   * initialization functions, as well as show_mem() for the skipping @@ -218,6 +209,7 @@ EXPORT_SYMBOL(arm_dma_zone_size);   * so a successful GFP_DMA allocation will always satisfy this.   */  phys_addr_t arm_dma_limit; +unsigned long arm_dma_pfn_limit;  static void __init arm_adjust_dma_zone(unsigned long *size, unsigned long *hole,  	unsigned long dma_size) @@ -240,6 +232,7 @@ void __init setup_dma_zone(const struct machine_desc *mdesc)  		arm_dma_limit = PHYS_OFFSET + arm_dma_zone_size - 1;  	} else  		arm_dma_limit = 0xffffffff; +	arm_dma_pfn_limit = arm_dma_limit >> PAGE_SHIFT;  #endif  } @@ -351,6 +344,11 @@ void __init arm_memblock_init(struct meminfo *mi,  	memblock_reserve(__pa(_stext), _end - _stext);  #endif  #ifdef CONFIG_BLK_DEV_INITRD +	/* FDT scan will populate initrd_start */ +	if (initrd_start) { +		phys_initrd_start = __virt_to_phys(initrd_start); +		phys_initrd_size = initrd_end - initrd_start; +	}  	if (phys_initrd_size &&  	    !memblock_is_region_memory(phys_initrd_start, phys_initrd_size)) {  		pr_err("INITRD: 0x%08llx+0x%08lx is not a memory region - disabling initrd\n", @@ -379,8 +377,6 @@ void __init arm_memblock_init(struct meminfo *mi,  	if (mdesc->reserve)  		mdesc->reserve(); -	early_init_dt_scan_reserved_mem(); -  	/*  	 * reserve memory for DMA contigouos allocations,  	 * must come from DMA area inside low memory @@ -424,12 +420,10 @@ void __init bootmem_init(void)  	 * This doesn't seem to be used by the Linux memory manager any  	 * more, but is used by ll_rw_block.  If we can get rid of it, we  	 * also get rid of some of the stuff above as well. -	 * -	 * Note: max_low_pfn and max_pfn reflect the number of _pages_ in -	 * the system, not the maximum PFN.  	 */ -	max_low_pfn = max_low - PHYS_PFN_OFFSET; -	max_pfn = max_high - PHYS_PFN_OFFSET; +	min_low_pfn = min; +	max_low_pfn = max_low; +	max_pfn = max_high;  }  /* @@ -535,7 +529,7 @@ static inline void free_area_high(unsigned long pfn, unsigned long end)  static void __init free_highpages(void)  {  #ifdef CONFIG_HIGHMEM -	unsigned long max_low = max_low_pfn + PHYS_PFN_OFFSET; +	unsigned long max_low = max_low_pfn;  	struct memblock_region *mem, *res;  	/* set highmem page free */ | 
