ANDROID: add extra free kbytes tunable
authorRik van Riel <riel@redhat.com>
Thu, 1 Sep 2011 19:26:50 +0000 (15:26 -0400)
committerSuren Baghdasaryan <surenb@google.com>
Mon, 4 Jun 2018 15:48:04 +0000 (15:48 +0000)
commit019b711f9e6a391e3449beccfae3b910ffe6ea14
tree4349f3191d5a64f4f95bcdb844c4dab93fe5ee1f
parentbd5b366a50e8c9d0b6ea69ff0c585512fe8cb40d
ANDROID: add extra free kbytes tunable

Add a userspace visible knob to tell the VM to keep an extra amount
of memory free, by increasing the gap between each zone's min and
low watermarks.

This is useful for realtime applications that call system
calls and have a bound on the number of allocations that happen
in any short time period.  In this application, extra_free_kbytes
would be left at an amount equal to or larger than than the
maximum number of allocations that happen in any burst.

It may also be useful to reduce the memory use of virtual
machines (temporarily?), in a way that does not cause memory
fragmentation like ballooning does.

[ccross]
Revived for use on old kernels where no other solution exists.
The tunable will be removed on kernels that do better at avoiding
direct reclaim.

[surenb]
Will be reverted as soon as Android framework is reworked to
use upstream-supported watermark_scale_factor instead of
extra_free_kbytes.

Bug: 86445363
Change-Id: I765a42be8e964bfd3e2886d1ca85a29d60c3bb3e
Signed-off-by: Rik van Riel<riel@redhat.com>
Signed-off-by: Colin Cross <ccross@android.com>
Signed-off-by: Suren Baghdasaryan <surenb@google.com>
Documentation/sysctl/vm.txt
kernel/sysctl.c
mm/page_alloc.c