This patch insert memory pressure notify point into vmscan.c Most problem in system slowness is swap-in. swap-in is a synchronous opeartion so that it affects heavily system response. This patch alert it when reclaimer start to reclaim inactive anon list. It seems rather earlier but not bad than too late. Other alert point is when there is few cache pages In this implementation, if it is (cache < free pages), memory pressure notify happens. It has to need more testing and tuning or other hueristic. Any suggesion are welcome. Signed-off-by: Minchan Kim <minchan@xxxxxxxxxx> --- mm/vmscan.c | 28 ++++++++++++++++++++++++++++ 1 files changed, 28 insertions(+), 0 deletions(-) diff --git a/mm/vmscan.c b/mm/vmscan.c index 2880396..cfa2e2d 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -43,6 +43,7 @@ #include <linux/sysctl.h> #include <linux/oom.h> #include <linux/prefetch.h> +#include <linux/low_mem_notify.h> #include <asm/tlbflush.h> #include <asm/div64.h> @@ -2082,16 +2083,43 @@ static void shrink_mem_cgroup_zone(int priority, struct mem_cgroup_zone *mz, { unsigned long nr[NR_LRU_LISTS]; unsigned long nr_to_scan; + enum lru_list lru; unsigned long nr_reclaimed, nr_scanned; unsigned long nr_to_reclaim = sc->nr_to_reclaim; struct blk_plug plug; +#ifdef CONFIG_LOW_MEM_NOTIFY + bool low_mem = false; + unsigned long free, file; +#endif restart: nr_reclaimed = 0; nr_scanned = sc->nr_scanned; get_scan_count(mz, sc, nr, priority); +#ifdef CONFIG_LOW_MEM_NOTIFY + /* We want to avoid swapout */ + if (nr[LRU_INACTIVE_ANON]) + low_mem = true; + /* + * We want to avoid dropping page cache excessively + * in no swap system + */ + if (nr_swap_pages <= 0) { + free = zone_page_state(mz->zone, NR_FREE_PAGES); + file = zone_page_state(mz->zone, NR_ACTIVE_FILE) + + zone_page_state(mz->zone, NR_INACTIVE_FILE); + /* + * If we have very few page cache pages, + * notify to user + */ + if (file < free) + low_mem = true; + } + if (low_mem) + low_memory_pressure(); +#endif blk_start_plug(&plug); while (nr[LRU_INACTIVE_ANON] || nr[LRU_ACTIVE_FILE] || nr[LRU_INACTIVE_FILE]) { -- 1.7.7.5 -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. 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@xxxxxxxxx"> email@xxxxxxxxx </a>