From 395f8adfab4a00db22d5a600fba6d77ef85a452b Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Wed, 6 May 2009 08:06:44 -0700 Subject: [PATCH] --- yaml --- r: 145775 b: refs/heads/master c: 45fbe3ee01b8e463b28c2751b5dcc0cbdc142d90 h: refs/heads/master i: 145773: f3cdb394bc665660eafebdc2ef91cffc66b510eb 145771: d393ae9862063e4ba975340d5ed966754512b30a 145767: a4d162f232fab269f388ac75149431a3ab456e44 145759: ab6ef6e6edb206521c4b6e9ff2327a499ce25ad2 v: v3 --- [refs] | 2 +- trunk/arch/x86/kernel/e820.c | 35 +++++++++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 176ca72371d2..9f021deea0e2 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 134cbf35c739bf89c51fd975a33a6b87507482c4 +refs/heads/master: 45fbe3ee01b8e463b28c2751b5dcc0cbdc142d90 diff --git a/trunk/arch/x86/kernel/e820.c b/trunk/arch/x86/kernel/e820.c index 006281302925..a2335d9de052 100644 --- a/trunk/arch/x86/kernel/e820.c +++ b/trunk/arch/x86/kernel/e820.c @@ -1371,6 +1371,23 @@ void __init e820_reserve_resources(void) } } +/* How much should we pad RAM ending depending on where it is? */ +static unsigned long ram_alignment(resource_size_t pos) +{ + unsigned long mb = pos >> 20; + + /* To 64kB in the first megabyte */ + if (!mb) + return 64*1024; + + /* To 1MB in the first 16MB */ + if (mb < 16) + return 1024*1024; + + /* To 32MB for anything above that */ + return 32*1024*1024; +} + void __init e820_reserve_resources_late(void) { int i; @@ -1382,6 +1399,24 @@ void __init e820_reserve_resources_late(void) insert_resource_expand_to_fit(&iomem_resource, res); res++; } + + /* + * Try to bump up RAM regions to reasonable boundaries to + * avoid stolen RAM: + */ + for (i = 0; i < e820.nr_map; i++) { + struct e820entry *entry = &e820_saved.map[i]; + resource_size_t start, end; + + if (entry->type != E820_RAM) + continue; + start = entry->addr + entry->size; + end = round_up(start, ram_alignment(start)); + if (start == end) + continue; + reserve_region_with_split(&iomem_resource, start, + end - 1, "RAM buffer"); + } } char *__init default_machine_specific_memory_setup(void)