Skip to content

Commit dd5d241

Browse files
gormanmtorvalds
authored andcommitted
page-allocator: always change pageblock ownership when anti-fragmentation is disabled
On low-memory systems, anti-fragmentation gets disabled as fragmentation cannot be avoided on a sufficiently large boundary to be worthwhile. Once disabled, there is a period of time when all the pageblocks are marked MOVABLE and the expectation is that they get marked UNMOVABLE at each call to __rmqueue_fallback(). However, when MAX_ORDER is large the pageblocks do not change ownership because the normal criteria are not met. This has the effect of prematurely breaking up too many large contiguous blocks. This is most serious on NOMMU systems which depend on high-order allocations to boot. This patch causes pageblocks to change ownership on every fallback when anti-fragmentation is disabled. This prevents the large blocks being prematurely broken up. This is a fix to commit 49255c6 [page allocator: move check for disabled anti-fragmentation out of fastpath] and the problem affects 2.6.31-rc8. Signed-off-by: Mel Gorman <mel@csn.ul.ie> Tested-by: Paul Mundt <lethal@linux-sh.org> Cc: David Howells <dhowells@redhat.com> Cc: Pekka Enberg <penberg@cs.helsinki.fi> Acked-by: Greg Ungerer <gerg@snapgear.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
1 parent a190887 commit dd5d241

File tree

1 file changed

+4
-2
lines changed

1 file changed

+4
-2
lines changed

mm/page_alloc.c

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -817,13 +817,15 @@ __rmqueue_fallback(struct zone *zone, int order, int start_migratetype)
817817
* agressive about taking ownership of free pages
818818
*/
819819
if (unlikely(current_order >= (pageblock_order >> 1)) ||
820-
start_migratetype == MIGRATE_RECLAIMABLE) {
820+
start_migratetype == MIGRATE_RECLAIMABLE ||
821+
page_group_by_mobility_disabled) {
821822
unsigned long pages;
822823
pages = move_freepages_block(zone, page,
823824
start_migratetype);
824825

825826
/* Claim the whole block if over half of it is free */
826-
if (pages >= (1 << (pageblock_order-1)))
827+
if (pages >= (1 << (pageblock_order-1)) ||
828+
page_group_by_mobility_disabled)
827829
set_pageblock_migratetype(page,
828830
start_migratetype);
829831

0 commit comments

Comments
 (0)