diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-26 15:45:41 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-26 15:45:41 -0500 |
commit | 2437dcbf555bff04e4ee8b8dba4587f946c1cd3d (patch) | |
tree | f04f3ed779c25caa933744d2d5965ca4e297f05d /mm | |
parent | 0dbfe8ddaaab9fe5bc8672c064d3ede6cd66201a (diff) | |
parent | b64b223aed5f8aeeb6c046f1b050a8f976b87de0 (diff) |
Merge branch 'core-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
* 'core-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
rcu: Add missing __cpuinit annotation in rcutorture code
sched: Add "const" to is_idle_task() parameter
rcu: Make rcutorture bool parameters really bool (core code)
memblock: Fix alloc failure due to dumb underflow protection in memblock_find_in_range_node()
Diffstat (limited to 'mm')
-rw-r--r-- | mm/memblock.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/mm/memblock.c b/mm/memblock.c index 2f55f19b7c86..77b5f227e1d8 100644 --- a/mm/memblock.c +++ b/mm/memblock.c | |||
@@ -106,14 +106,17 @@ phys_addr_t __init_memblock memblock_find_in_range_node(phys_addr_t start, | |||
106 | if (end == MEMBLOCK_ALLOC_ACCESSIBLE) | 106 | if (end == MEMBLOCK_ALLOC_ACCESSIBLE) |
107 | end = memblock.current_limit; | 107 | end = memblock.current_limit; |
108 | 108 | ||
109 | /* adjust @start to avoid underflow and allocating the first page */ | 109 | /* avoid allocating the first page */ |
110 | start = max3(start, size, (phys_addr_t)PAGE_SIZE); | 110 | start = max_t(phys_addr_t, start, PAGE_SIZE); |
111 | end = max(start, end); | 111 | end = max(start, end); |
112 | 112 | ||
113 | for_each_free_mem_range_reverse(i, nid, &this_start, &this_end, NULL) { | 113 | for_each_free_mem_range_reverse(i, nid, &this_start, &this_end, NULL) { |
114 | this_start = clamp(this_start, start, end); | 114 | this_start = clamp(this_start, start, end); |
115 | this_end = clamp(this_end, start, end); | 115 | this_end = clamp(this_end, start, end); |
116 | 116 | ||
117 | if (this_end < size) | ||
118 | continue; | ||
119 | |||
117 | cand = round_down(this_end - size, align); | 120 | cand = round_down(this_end - size, align); |
118 | if (cand >= this_start) | 121 | if (cand >= this_start) |
119 | return cand; | 122 | return cand; |