linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [PATCH -mm] limit direct reclaim for higher order allocations
@ 2011-09-26 13:55 Rik van Riel
  2011-09-26 15:02 ` Mel Gorman
  0 siblings, 1 reply; 3+ messages in thread
From: Rik van Riel @ 2011-09-26 13:55 UTC (permalink / raw)
  To: linux-mm; +Cc: linux-kernel, akpm, Mel Gorman, Johannes Weiner

When suffering from memory fragmentation due to unfreeable pages,
THP page faults will repeatedly try to compact memory.  Due to
the unfreeable pages, compaction fails.

Needless to say, at that point page reclaim also fails to create
free contiguous 2MB areas.  However, that doesn't stop the current
code from trying, over and over again, and freeing a minimum of
4MB (2UL << sc->order pages) at every single invocation.

This resulted in my 12GB system having 2-3GB free memory, a
corresponding amount of used swap and very sluggish response times.

This can be avoided by having the direct reclaim code not reclaim
from zones that already have plenty of free memory available for
compaction.

If compaction still fails due to unmovable memory, doing additional
reclaim will only hurt the system, not help.

Signed-off-by: Rik van Riel <riel@redhat.com>
---
I believe Mel has another idea in mind on how to fix this issue. 
I believe it will be good to compare both approaches side by side...

 mm/vmscan.c |   16 ++++++++++++++++
 1 files changed, 16 insertions(+), 0 deletions(-)

diff --git a/mm/vmscan.c b/mm/vmscan.c
index b7719ec..56811a1 100644
--- a/mm/vmscan.c
+++ b/mm/vmscan.c
@@ -2083,6 +2083,22 @@ static void shrink_zones(int priority, struct zonelist *zonelist,
 				continue;
 			if (zone->all_unreclaimable && priority != DEF_PRIORITY)
 				continue;	/* Let kswapd poll it */
+			if (COMPACTION_BUILD) {
+				/*
+				 * If we already have plenty of memory free
+				 * for compaction, don't free any more.
+				 */
+				unsigned long balance_gap;
+				balance_gap = min(low_wmark_pages(zone),
+					(zone->present_pages +
+					KSWAPD_ZONE_BALANCE_GAP_RATIO-1) /
+					KSWAPD_ZONE_BALANCE_GAP_RATIO);
+				if (sc->order > PAGE_ALLOC_COSTLY_ORDER &&
+					zone_watermark_ok_safe(zone, 0,
+					high_wmark_pages(zone) + balance_gap +
+					(2UL << sc->order), 0, 0))
+					continue;
+			}
 			/*
 			 * This steals pages from memory cgroups over softlimit
 			 * and returns the number of reclaimed pages and

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2011-09-26 15:31 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-09-26 13:55 [PATCH -mm] limit direct reclaim for higher order allocations Rik van Riel
2011-09-26 15:02 ` Mel Gorman
2011-09-26 15:31   ` Rik van Riel

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).