[PATCH][2.6.8-rc1-mm1] Autotune swappiness01
From: Con Kolivas
Date: Sun Jul 25 2004 - 19:26:29 EST
Attached is a patch designed to improve the behaviour of the swappiness knob
in 2.6.8-rc1-mm1.
The current mechanism decides to reclaim mapped pages based on the
combination of mapped_ratio/2 and the manual setting of swappiness currently
tuned to 60. Biasing this mechanism to be proportional to the square root of
mapped_ratio gives good overall performance improvement for desktop
workloads without any noticable detriment to other loads. It has the effect
of being fairly aggressive at avoiding loss of applications to swap under
conditions of heavy or sustained file stress while allowing applications to
swap out under what would be considered "application" memory stresses on a
desktop. It has no measurable effect on any known benchmarks.
The swappiness knob is kept intact and ironically is set to the same value
of 60, and overall behaves the same as previous patches posted for
autoregulating swappiness. The idea of this patch is to ultimately deprecate
the need for a swappiness knob if this achieves good performance in most
workloads.
Signed-off-by: Con Kolivas <kernel@xxxxxxxxxxx>
Index: linux-2.6.8-rc1/mm/vmscan.c
===================================================================
--- linux-2.6.8-rc1.orig/mm/vmscan.c 2004-07-15 09:59:34.820962044 +1000
+++ linux-2.6.8-rc1/mm/vmscan.c 2004-07-15 10:03:06.243433612 +1000
@@ -119,6 +119,7 @@
* From 0 .. 100. Higher means more swappy.
*/
int vm_swappiness = 60;
+static int mapped_bias;
static long total_memory;
static LIST_HEAD(shrinker_list);
@@ -646,6 +647,7 @@
struct page *page;
struct pagevec pvec;
int reclaim_mapped = 0;
+ int swappiness_bias;
long mapped_ratio;
long distress;
long swap_tendency;
@@ -690,6 +692,7 @@
* is mapped.
*/
mapped_ratio = (sc->nr_mapped * 100) / total_memory;
+ mapped_bias = mapped_ratio * mapped_ratio;
/*
* Now decide how much we really want to unmap some pages. The mapped
@@ -700,7 +703,9 @@
*
* A 100% value of vm_swappiness overrides this algorithm altogether.
*/
- swap_tendency = mapped_ratio / 2 + distress + vm_swappiness;
+ swappiness_bias = vm_swappiness * vm_swappiness / 100;
+ swappiness_bias = 101 - swappiness_bias;
+ swap_tendency = distress + mapped_bias / swappiness_bias;
/*
* Now use this metric to decide whether to start moving mapped memory