9220592
From 6b7025ea927d290a59d2772828435c1893f0267f Mon Sep 17 00:00:00 2001
9220592
From: Rik van Riel <riel@redhat.com>
9220592
Date: Fri, 7 Oct 2011 16:17:22 +0100
9220592
Subject: [PATCH 1/2] mm: vmscan: Limit direct reclaim for higher order
9220592
 allocations
9220592
9220592
When suffering from memory fragmentation due to unfreeable pages,
9220592
THP page faults will repeatedly try to compact memory.  Due to the
9220592
unfreeable pages, compaction fails.
9220592
9220592
Needless to say, at that point page reclaim also fails to create
9220592
free contiguous 2MB areas.  However, that doesn't stop the current
9220592
code from trying, over and over again, and freeing a minimum of 4MB
9220592
(2UL << sc->order pages) at every single invocation.
9220592
9220592
This resulted in my 12GB system having 2-3GB free memory, a
9220592
corresponding amount of used swap and very sluggish response times.
9220592
9220592
This can be avoided by having the direct reclaim code not reclaim from
9220592
zones that already have plenty of free memory available for compaction.
9220592
9220592
If compaction still fails due to unmovable memory, doing additional
9220592
reclaim will only hurt the system, not help.
9220592
9220592
Signed-off-by: Rik van Riel <riel@redhat.com>
9220592
Signed-off-by: Mel Gorman <mgorman@suse.de>
9220592
---
9220592
 mm/vmscan.c |   10 ++++++++++
9220592
 1 files changed, 10 insertions(+), 0 deletions(-)
9220592
9220592
diff --git a/mm/vmscan.c b/mm/vmscan.c
9220592
index 6072d74..8c03534 100644
9220592
--- a/mm/vmscan.c
9220592
+++ b/mm/vmscan.c
9220592
@@ -2022,6 +2022,16 @@ static void shrink_zones(int priority, struct zonelist *zonelist,
9220592
 				continue;
9220592
 			if (zone->all_unreclaimable && priority != DEF_PRIORITY)
9220592
 				continue;	/* Let kswapd poll it */
9220592
+			if (COMPACTION_BUILD) {
9220592
+				/*
9220592
+				 * If we already have plenty of memory free
9220592
+				 * for compaction, don't free any more.
9220592
+				 */
9220592
+				if (sc->order > PAGE_ALLOC_COSTLY_ORDER &&
9220592
+					(compaction_suitable(zone, sc->order) ||
9220592
+					 compaction_deferred(zone)))
9220592
+					continue;
9220592
+			}
9220592
 			/*
9220592
 			 * This steals pages from memory cgroups over softlimit
9220592
 			 * and returns the number of reclaimed pages and
9220592
-- 
9220592
1.7.6.4
9220592