summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBjorn Helgaas <bjorn.helgaas@hp.com>2010-10-26 23:41:54 +0200
committerJesse Barnes <jbarnes@virtuousgeek.org>2010-10-27 00:33:45 +0200
commit1af3c2e45e7a641e774bbb84fa428f2f0bf2d9c9 (patch)
tree039efdb6eecc9d28e7bef5486a1b02527838c23d
parentx86: update iomem_resource end based on CPU physical address capabilities (diff)
downloadlinux-1af3c2e45e7a641e774bbb84fa428f2f0bf2d9c9.tar.xz
linux-1af3c2e45e7a641e774bbb84fa428f2f0bf2d9c9.zip
x86: allocate space within a region top-down
Request that allocate_resource() use available space from high addresses first, rather than the default of using low addresses first. The most common place this makes a difference is when we move or assign new PCI device resources. Low addresses are generally scarce, so it's better to use high addresses when possible. This follows Windows practice for PCI allocation. Reference: https://bugzilla.kernel.org/show_bug.cgi?id=16228#c42 Signed-off-by: Bjorn Helgaas <bjorn.helgaas@hp.com> Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
-rw-r--r--arch/x86/kernel/setup.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
index 922b5a1f978b..0fe76df866db 100644
--- a/arch/x86/kernel/setup.c
+++ b/arch/x86/kernel/setup.c
@@ -788,6 +788,7 @@ void __init setup_arch(char **cmdline_p)
x86_init.oem.arch_setup();
+ resource_alloc_from_bottom = 0;
iomem_resource.end = (1ULL << boot_cpu_data.x86_phys_bits) - 1;
setup_memory_map();
parse_setup_data();