diff options
author | Jan Beulich <jbeulich@novell.com> | 2008-09-12 15:43:04 +0100 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-10-13 10:21:16 +0200 |
commit | 5e72d9e4850c91b6a0f06fa803f7393b55a38aa8 (patch) | |
tree | 8c4aff01fd6538abad4a25f9cbfdc09180f29069 | |
parent | 59ef48a58e59cc27255d526ae3fa60ddcd977208 (diff) | |
download | lwn-5e72d9e4850c91b6a0f06fa803f7393b55a38aa8.tar.gz lwn-5e72d9e4850c91b6a0f06fa803f7393b55a38aa8.zip |
x86-64: fix combining of regions in init_memory_mapping()
When nr_range gets decremented, the same slot must be considered for
coalescing with its new successor again.
The issue is apparently pretty benign to native code, but surfaces as a
boot time crash in our forward ported Xen tree (where the page table
setup overall works differently than in native).
Signed-off-by: Jan Beulich <jbeulich@novell.com>
Acked-by: Yinghai Lu <yhlu.kernel@gmail.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
-rw-r--r-- | arch/x86/mm/init_64.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/x86/mm/init_64.c b/arch/x86/mm/init_64.c index 7c8bb46e83e4..b8e461d49412 100644 --- a/arch/x86/mm/init_64.c +++ b/arch/x86/mm/init_64.c @@ -746,7 +746,7 @@ unsigned long __init_refok init_memory_mapping(unsigned long start, old_start = mr[i].start; memmove(&mr[i], &mr[i+1], (nr_range - 1 - i) * sizeof (struct map_range)); - mr[i].start = old_start; + mr[i--].start = old_start; nr_range--; } |