[PATCH v2] ARM: mm: Align bank start to MAX_ORDER_NR_PAGES
Linus Walleij
linus.walleij at linaro.org
Thu Sep 29 04:36:10 EDT 2011
From: Johan Palsson <johan.palsson at stericsson.com>
The VM subsystem assumes that there are valid memmap entries from
the bank start aligned to MAX_ORDER_NR_PAGES.
On the Ux500 we have a lot of mem=N arguments on the commandline
triggering this bug several times over and causing kernel
oops messages.
Cc: stable at kernel.org
Cc: Russell King <rmk+kernel at arm.linux.org.uk>
Cc: Michael Bohan <mbohan at codeaurora.org>
Cc: Nicolas Pitre <nico at fluxnic.net>
Signed-off-by: Johan Palsson <johan.palsson at stericsson.com>
Signed-off-by: Rabin Vincent <rabin.vincent at stericsson.com>
Signed-off-by: Linus Walleij <linus.walleij at linaro.org>
---
arch/arm/mm/init.c | 7 +++++++
1 files changed, 7 insertions(+), 0 deletions(-)
diff --git a/arch/arm/mm/init.c b/arch/arm/mm/init.c
index cc7e2d8..f8037ba 100644
--- a/arch/arm/mm/init.c
+++ b/arch/arm/mm/init.c
@@ -496,6 +496,13 @@ static void __init free_unused_memmap(struct meminfo *mi)
*/
bank_start = min(bank_start,
ALIGN(prev_bank_end, PAGES_PER_SECTION));
+#else
+ /*
+ * Align down here since the VM subsystem insists that the
+ * memmap entries are valid from the bank start aligned to
+ * MAX_ORDER_NR_PAGES.
+ */
+ bank_start = round_down(bank_start, MAX_ORDER_NR_PAGES);
#endif
/*
* If we had a previous bank, and there is a space
--
1.7.6.2
More information about the linux-arm-kernel
mailing list