aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/arch/arm/mm/mmu.c
diff options
context:
space:
mode:
authorChester Lin <clin@suse.com>2019-08-30 14:30:07 +0100
committerRussell King <rmk+kernel@armlinux.org.uk>2019-09-10 15:22:35 +0100
commit1d31999cf04c21709f72ceb17e65b54a401330da (patch)
treed0e5ed8124601ecfda3fe5c4794649cca9ff57e1 /arch/arm/mm/mmu.c
parentARM: 8903/1: ensure that usable memory in bank 0 starts from a PMD-aligned address (diff)
downloadwireguard-linux-1d31999cf04c21709f72ceb17e65b54a401330da.tar.xz
wireguard-linux-1d31999cf04c21709f72ceb17e65b54a401330da.zip
ARM: 8904/1: skip nomap memblocks while finding the lowmem/highmem boundary
adjust_lowmem_bounds() checks every memblocks in order to find the boundary between lowmem and highmem. However some memblocks could be marked as NOMAP so they are not used by kernel, which should be skipped while calculating the boundary. Signed-off-by: Chester Lin <clin@suse.com> Reviewed-by: Mike Rapoport <rppt@linux.ibm.com> Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
Diffstat (limited to 'arch/arm/mm/mmu.c')
-rw-r--r--arch/arm/mm/mmu.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/arm/mm/mmu.c b/arch/arm/mm/mmu.c
index d5e0b908f0ba..25da9b2d9610 100644
--- a/arch/arm/mm/mmu.c
+++ b/arch/arm/mm/mmu.c
@@ -1197,6 +1197,9 @@ void __init adjust_lowmem_bounds(void)
phys_addr_t block_start = reg->base;
phys_addr_t block_end = reg->base + reg->size;
+ if (memblock_is_nomap(reg))
+ continue;
+
if (reg->base < vmalloc_limit) {
if (block_end > lowmem_limit)
/*