summaryrefslogtreecommitdiff
path: root/mm
diff options
context:
space:
mode:
author=?UTF-8?q?Arve=20Hj=C3=B8nnev=C3=A5g?= <arve@android.com>2011-12-13 01:04:07 +0800
committerAndy Green <andy.green@linaro.org>2011-12-26 16:33:42 +0800
commit9cd19b0c55b565d811a56b7eeef421d0e63c6b62 (patch)
treecadd8232d16de349da48fdf351aaa9315d16ee7d /mm
parent710468e44459e4f5fdda44118ff49d266f276cb5 (diff)
mm: Add min_free_order_shift tunable.
MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit By default the kernel tries to keep half as much memory free at each order as it does for one order below. This can be too agressive when running without swap. Change-Id: I5efc1a0b50f41ff3ac71e92d2efd175dedd54ead Signed-off-by: Arve Hjønnevåg <arve@android.com>
Diffstat (limited to 'mm')
-rw-r--r--mm/page_alloc.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/mm/page_alloc.c b/mm/page_alloc.c
index e3dc43f1585..eee9cedfb77 100644
--- a/mm/page_alloc.c
+++ b/mm/page_alloc.c
@@ -177,6 +177,7 @@ static char * const zone_names[MAX_NR_ZONES] = {
};
int min_free_kbytes = 1024;
+int min_free_order_shift = 1;
static unsigned long __meminitdata nr_kernel_pages;
static unsigned long __meminitdata nr_all_pages;
@@ -1519,7 +1520,7 @@ static bool __zone_watermark_ok(struct zone *z, int order, unsigned long mark,
free_pages -= z->free_area[o].nr_free << o;
/* Require fewer higher order pages to be free */
- min >>= 1;
+ min >>= min_free_order_shift;
if (free_pages <= min)
return false;