diff options
Diffstat (limited to 'kernel/resource.c')
-rw-r--r-- | kernel/resource.c | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/kernel/resource.c b/kernel/resource.c index 24e9e60c1459..2d5be5d9bf5f 100644 --- a/kernel/resource.c +++ b/kernel/resource.c | |||
@@ -304,7 +304,7 @@ int walk_system_ram_range(unsigned long start_pfn, unsigned long nr_pages, | |||
304 | void *arg, int (*func)(unsigned long, unsigned long, void *)) | 304 | void *arg, int (*func)(unsigned long, unsigned long, void *)) |
305 | { | 305 | { |
306 | struct resource res; | 306 | struct resource res; |
307 | unsigned long pfn, len; | 307 | unsigned long pfn, end_pfn; |
308 | u64 orig_end; | 308 | u64 orig_end; |
309 | int ret = -1; | 309 | int ret = -1; |
310 | 310 | ||
@@ -314,9 +314,10 @@ int walk_system_ram_range(unsigned long start_pfn, unsigned long nr_pages, | |||
314 | orig_end = res.end; | 314 | orig_end = res.end; |
315 | while ((res.start < res.end) && | 315 | while ((res.start < res.end) && |
316 | (find_next_system_ram(&res, "System RAM") >= 0)) { | 316 | (find_next_system_ram(&res, "System RAM") >= 0)) { |
317 | pfn = (unsigned long)(res.start >> PAGE_SHIFT); | 317 | pfn = (res.start + PAGE_SIZE - 1) >> PAGE_SHIFT; |
318 | len = (unsigned long)((res.end + 1 - res.start) >> PAGE_SHIFT); | 318 | end_pfn = (res.end + 1) >> PAGE_SHIFT; |
319 | ret = (*func)(pfn, len, arg); | 319 | if (end_pfn > pfn) |
320 | ret = (*func)(pfn, end_pfn - pfn, arg); | ||
320 | if (ret) | 321 | if (ret) |
321 | break; | 322 | break; |
322 | res.start = res.end + 1; | 323 | res.start = res.end + 1; |
@@ -327,6 +328,19 @@ int walk_system_ram_range(unsigned long start_pfn, unsigned long nr_pages, | |||
327 | 328 | ||
328 | #endif | 329 | #endif |
329 | 330 | ||
331 | static int __is_ram(unsigned long pfn, unsigned long nr_pages, void *arg) | ||
332 | { | ||
333 | return 1; | ||
334 | } | ||
335 | /* | ||
336 | * This generic page_is_ram() returns true if specified address is | ||
337 | * registered as "System RAM" in iomem_resource list. | ||
338 | */ | ||
339 | int __weak page_is_ram(unsigned long pfn) | ||
340 | { | ||
341 | return walk_system_ram_range(pfn, 1, NULL, __is_ram) == 1; | ||
342 | } | ||
343 | |||
330 | /* | 344 | /* |
331 | * Find empty slot in the resource tree given range and alignment. | 345 | * Find empty slot in the resource tree given range and alignment. |
332 | */ | 346 | */ |