Re: [PATCH] x86/pci: make pci_mem_start to be aligned only -v4
From: Linus Torvalds
Date: Thu Apr 16 2009 - 19:24:56 EST
On Thu, 16 Apr 2009, Yinghai Lu wrote:
>
> please check.
>
> [PATCH] x86/pci: make pci_mem_start to be aligned only -v4
I like the approach. That said, I think that rather than do the "modify
the e820 array" thing, why not just do it in the in the resource tree, and
do it at "e820_reserve_resources_late()" time?
IOW, something like this.
TOTALLY UNTESTED! The point is to take all RAM resources we haev, and
_after_ we've added all the resources we've seen in the E820 tree, we then
_also_ try to add fake reserved entries for any "round up to X" at the end
of the RAM resources.
NOTE! I really didn't want to use "reserve_region_with_split()". I didn't
want to recurse into any conflicting resources, I really wanted to just do
the other failure cases.
THIS PATCH IS NOT MEANT TO BE USED. Just a rough "almost like this" kind
of thing. That includes the rough draft of how much to round things up to
based on where the end of RAM region is etc. I'm really throwing this out
more as a "wouldn't this be a readable way to handle any missing reserved
entries" kind of thing..
Linus
---
arch/x86/kernel/e820.c | 34 ++++++++++++++++++++++++++++++++++
1 files changed, 34 insertions(+), 0 deletions(-)
diff --git a/arch/x86/kernel/e820.c b/arch/x86/kernel/e820.c
index ef2c356..e8b8d33 100644
--- a/arch/x86/kernel/e820.c
+++ b/arch/x86/kernel/e820.c
@@ -1370,6 +1370,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;
@@ -1381,6 +1398,23 @@ 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, "RAM buffer");
+ }
}
char *__init default_machine_specific_memory_setup(void)
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/