diff options
Diffstat (limited to 'arch/arm64/mm/init.c')
| -rw-r--r-- | arch/arm64/mm/init.c | 33 | 
1 files changed, 18 insertions, 15 deletions
diff --git a/arch/arm64/mm/init.c b/arch/arm64/mm/init.c index 75addb36354a..709d98fea90c 100644 --- a/arch/arm64/mm/init.c +++ b/arch/arm64/mm/init.c @@ -53,13 +53,13 @@ s64 memstart_addr __ro_after_init = -1;  EXPORT_SYMBOL(memstart_addr);  /* - * We create both ZONE_DMA and ZONE_DMA32. ZONE_DMA covers the first 1G of - * memory as some devices, namely the Raspberry Pi 4, have peripherals with - * this limited view of the memory. ZONE_DMA32 will cover the rest of the 32 - * bit addressable memory area. + * If the corresponding config options are enabled, we create both ZONE_DMA + * and ZONE_DMA32. By default ZONE_DMA covers the 32-bit addressable memory + * unless restricted on specific platforms (e.g. 30-bit on Raspberry Pi 4). + * In such case, ZONE_DMA32 covers the rest of the 32-bit addressable memory, + * otherwise it is empty.   */  phys_addr_t arm64_dma_phys_limit __ro_after_init; -static phys_addr_t arm64_dma32_phys_limit __ro_after_init;  #ifdef CONFIG_KEXEC_CORE  /* @@ -84,7 +84,7 @@ static void __init reserve_crashkernel(void)  	if (crash_base == 0) {  		/* Current arm64 boot protocol requires 2MB alignment */ -		crash_base = memblock_find_in_range(0, arm64_dma32_phys_limit, +		crash_base = memblock_find_in_range(0, arm64_dma_phys_limit,  				crash_size, SZ_2M);  		if (crash_base == 0) {  			pr_warn("cannot allocate crashkernel (size:0x%llx)\n", @@ -196,6 +196,7 @@ static void __init zone_sizes_init(unsigned long min, unsigned long max)  	unsigned long max_zone_pfns[MAX_NR_ZONES]  = {0};  	unsigned int __maybe_unused acpi_zone_dma_bits;  	unsigned int __maybe_unused dt_zone_dma_bits; +	phys_addr_t __maybe_unused dma32_phys_limit = max_zone_phys(32);  #ifdef CONFIG_ZONE_DMA  	acpi_zone_dma_bits = fls64(acpi_iort_dma_get_max_cpu_address()); @@ -205,8 +206,12 @@ static void __init zone_sizes_init(unsigned long min, unsigned long max)  	max_zone_pfns[ZONE_DMA] = PFN_DOWN(arm64_dma_phys_limit);  #endif  #ifdef CONFIG_ZONE_DMA32 -	max_zone_pfns[ZONE_DMA32] = PFN_DOWN(arm64_dma32_phys_limit); +	max_zone_pfns[ZONE_DMA32] = PFN_DOWN(dma32_phys_limit); +	if (!arm64_dma_phys_limit) +		arm64_dma_phys_limit = dma32_phys_limit;  #endif +	if (!arm64_dma_phys_limit) +		arm64_dma_phys_limit = PHYS_MASK + 1;  	max_zone_pfns[ZONE_NORMAL] = max;  	free_area_init(max_zone_pfns); @@ -394,16 +399,9 @@ void __init arm64_memblock_init(void)  	early_init_fdt_scan_reserved_mem(); -	if (IS_ENABLED(CONFIG_ZONE_DMA32)) -		arm64_dma32_phys_limit = max_zone_phys(32); -	else -		arm64_dma32_phys_limit = PHYS_MASK + 1; -  	reserve_elfcorehdr();  	high_memory = __va(memblock_end_of_DRAM() - 1) + 1; - -	dma_contiguous_reserve(arm64_dma32_phys_limit);  }  void __init bootmem_init(void) @@ -439,6 +437,11 @@ void __init bootmem_init(void)  	zone_sizes_init(min, max);  	/* +	 * Reserve the CMA area after arm64_dma_phys_limit was initialised. +	 */ +	dma_contiguous_reserve(arm64_dma_phys_limit); + +	/*  	 * request_standard_resources() depends on crashkernel's memory being  	 * reserved, so do it here.  	 */ @@ -455,7 +458,7 @@ void __init bootmem_init(void)  void __init mem_init(void)  {  	if (swiotlb_force == SWIOTLB_FORCE || -	    max_pfn > PFN_DOWN(arm64_dma_phys_limit ? : arm64_dma32_phys_limit)) +	    max_pfn > PFN_DOWN(arm64_dma_phys_limit))  		swiotlb_init(1);  	else  		swiotlb_force = SWIOTLB_NO_FORCE;  | 
