aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/mm
diff options
context:
space:
mode:
authorYinghai Lu <yinghai@kernel.org>2010-10-12 17:07:09 -0400
committerH. Peter Anvin <hpa@linux.intel.com>2010-10-12 18:37:51 -0400
commitc7fc2de0c83dbd2eaf759c5cd0e2b9cf1eb4df3a (patch)
treec4413e9b3bc164394c2daccf34e18e0b1d6c8811 /arch/powerpc/mm
parent8e4029ee3517084ae00fbfbcb51cc365d8857061 (diff)
memblock, bootmem: Round pfn properly for memory and reserved regions
We need to round memory regions correctly -- specifically, we need to round reserved region in the more expansive direction (lower limit down, upper limit up) whereas usable memory regions need to be rounded in the more restrictive direction (lower limit up, upper limit down). This introduces two set of inlines: memblock_region_memory_base_pfn() memblock_region_memory_end_pfn() memblock_region_reserved_base_pfn() memblock_region_reserved_end_pfn() Although they are antisymmetric (and therefore are technically duplicates) the use of the different inlines explicitly documents the programmer's intention. The lack of proper rounding caused a bug on ARM, which was then found to also affect other architectures. Reported-by: Russell King <rmk@arm.linux.org.uk> Signed-off-by: Yinghai Lu <yinghai@kernel.org> LKML-Reference: <4CB4CDFD.4020105@kernel.org> Cc: Jeremy Fitzhardinge <jeremy@goop.org> Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
Diffstat (limited to 'arch/powerpc/mm')
-rw-r--r--arch/powerpc/mm/mem.c14
-rw-r--r--arch/powerpc/mm/numa.c4
2 files changed, 9 insertions, 9 deletions
diff --git a/arch/powerpc/mm/mem.c b/arch/powerpc/mm/mem.c
index f661f6c527da..a66499650909 100644
--- a/arch/powerpc/mm/mem.c
+++ b/arch/powerpc/mm/mem.c
@@ -148,8 +148,8 @@ walk_system_ram_range(unsigned long start_pfn, unsigned long nr_pages,
148 int ret = -1; 148 int ret = -1;
149 149
150 for_each_memblock(memory, reg) { 150 for_each_memblock(memory, reg) {
151 tstart = max(start_pfn, memblock_region_base_pfn(reg)); 151 tstart = max(start_pfn, memblock_region_memory_base_pfn(reg));
152 tend = min(end_pfn, memblock_region_end_pfn(reg)); 152 tend = min(end_pfn, memblock_region_memory_end_pfn(reg));
153 if (tstart >= tend) 153 if (tstart >= tend)
154 continue; 154 continue;
155 ret = (*func)(tstart, tend - tstart, arg); 155 ret = (*func)(tstart, tend - tstart, arg);
@@ -195,8 +195,8 @@ void __init do_init_bootmem(void)
195 /* Add active regions with valid PFNs */ 195 /* Add active regions with valid PFNs */
196 for_each_memblock(memory, reg) { 196 for_each_memblock(memory, reg) {
197 unsigned long start_pfn, end_pfn; 197 unsigned long start_pfn, end_pfn;
198 start_pfn = memblock_region_base_pfn(reg); 198 start_pfn = memblock_region_memory_base_pfn(reg);
199 end_pfn = memblock_region_end_pfn(reg); 199 end_pfn = memblock_region_memory_end_pfn(reg);
200 add_active_range(0, start_pfn, end_pfn); 200 add_active_range(0, start_pfn, end_pfn);
201 } 201 }
202 202
@@ -236,9 +236,9 @@ static int __init mark_nonram_nosave(void)
236 236
237 for_each_memblock(memory, reg) { 237 for_each_memblock(memory, reg) {
238 if (prev && 238 if (prev &&
239 memblock_region_end_pfn(prev) < memblock_region_base_pfn(reg)) 239 memblock_region_memory_end_pfn(prev) < memblock_region_memory_base_pfn(reg))
240 register_nosave_region(memblock_region_end_pfn(prev), 240 register_nosave_region(memblock_region_memory_end_pfn(prev),
241 memblock_region_base_pfn(reg)); 241 memblock_region_memory_base_pfn(reg));
242 prev = reg; 242 prev = reg;
243 } 243 }
244 return 0; 244 return 0;
diff --git a/arch/powerpc/mm/numa.c b/arch/powerpc/mm/numa.c
index 066fb443ba5a..74505b245374 100644
--- a/arch/powerpc/mm/numa.c
+++ b/arch/powerpc/mm/numa.c
@@ -811,8 +811,8 @@ static void __init setup_nonnuma(void)
811 (top_of_ram - total_ram) >> 20); 811 (top_of_ram - total_ram) >> 20);
812 812
813 for_each_memblock(memory, reg) { 813 for_each_memblock(memory, reg) {
814 start_pfn = memblock_region_base_pfn(reg); 814 start_pfn = memblock_region_memory_base_pfn(reg);
815 end_pfn = memblock_region_end_pfn(reg); 815 end_pfn = memblock_region_memory_end_pfn(reg);
816 816
817 fake_numa_create_new_node(end_pfn, &nid); 817 fake_numa_create_new_node(end_pfn, &nid);
818 add_active_range(nid, start_pfn, end_pfn); 818 add_active_range(nid, start_pfn, end_pfn);