summaryrefslogtreecommitdiffstats
path: root/arch/arm/include/asm/memory.h
diff options
context:
space:
mode:
authorJonathan Austin <Jonathan.Austin@arm.com>2012-08-23 14:02:59 +0100
committerRussell King <rmk+kernel@arm.linux.org.uk>2012-08-25 09:20:40 +0100
commit36418c516b31bff4ff949c7c618430a1a514debe (patch)
treea17ddc5786e7761e0e9bd1668a4e4a6e4b48c8c0 /arch/arm/include/asm/memory.h
parentdf547e08e800275a431e560a7f0a6b6f24ab2904 (diff)
downloadlinux-36418c516b31bff4ff949c7c618430a1a514debe.tar.bz2
ARM: 7499/1: mm: Fix vmalloc overlap check for !HIGHMEM
With !HIGHMEM, sanity_check_meminfo checks for banks that completely or partially overlap the vmalloc region. The test for partial overlap checks __va(bank->start + bank->size) > vmalloc_min. This is not appropriate if there is a non-linear translation between virtual and physical addresses, as bank->start + bank->size is actually in the bank following the one being interrogated. In most cases, even when using SPARSEMEM, this is not problematic as the subsequent bank will start at a higher va than the one in question. However if the physical to virtual address conversion is not monotonic increasing, the incorrect test could result in a bank not being truncated when it should be. This patch ensures we perform the va-pa conversion on memory from the bank we are interested in, not the following one. Reported-by: ??? (Steve) <zhanzhenbo@gmail.com> Signed-off-by: Jonathan Austin <jonathan.austin@arm.com> Acked-by: Nicolas Pitre <nico@linaro.org> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/include/asm/memory.h')
0 files changed, 0 insertions, 0 deletions