summaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorMatt Fleming <matt@console-pimps.org>2010-04-25 17:29:07 +0100
committerMatt Fleming <matt@console-pimps.org>2010-04-25 20:44:23 +0100
commitc7b03fa0bdc04e00bfbdc4cc69da144b11108f37 (patch)
tree1dab19213c06e87818faef6badd7eb101877be2e /arch
parent9c3d936352fefaadec57bafda1fe3807890cbf2c (diff)
downloadlinux-c7b03fa0bdc04e00bfbdc4cc69da144b11108f37.tar.gz
linux-c7b03fa0bdc04e00bfbdc4cc69da144b11108f37.tar.bz2
linux-c7b03fa0bdc04e00bfbdc4cc69da144b11108f37.zip
sh: Do not try merging two 128MB PMB mappings
There is a logic error in pmb_merge() that means we will incorrectly try to merge two 128MB PMB mappings into one mapping. However, 256MB isn't a valid PMB map size and pmb_merge() will actually drop the second 128MB mapping. This patch allows my SDK7786 board to boot when configured with CONFIG_MEMORY_SIZE=0x10000000. Signed-off-by: Matt Fleming <matt@console-pimps.org>
Diffstat (limited to 'arch')
-rw-r--r--arch/sh/mm/pmb.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/sh/mm/pmb.c b/arch/sh/mm/pmb.c
index 3cc21933063b..c0fdc217ece5 100644
--- a/arch/sh/mm/pmb.c
+++ b/arch/sh/mm/pmb.c
@@ -681,7 +681,7 @@ static void __init pmb_merge(struct pmb_entry *head)
/*
* The merged page size must be valid.
*/
- if (!pmb_size_valid(newsize))
+ if (!depth || !pmb_size_valid(newsize))
return;
head->flags &= ~PMB_SZ_MASK;