In commit 64574746, "vmscan: detect mapped file pages used only once", Johannes Weiner, added logic to page_check_reference to cycle again used once pages. In commit 8cab4754, "vmscan: make mapped executable pages the first class citizen", Wu Fengguang, added logic to shrink_active_list which protects file-backed VM_EXEC pages by keeping them in the active_list if they are referenced. This patch adds logic to move such pages from the inactive list to the active list immediately if they have been referenced. If a VM_EXEC page is seen as referenced during an inactive list scan, that reference must have occurred after the page was put on the inactive list. There is no need to wait for the page to be referenced again. Change-Id: I17c312e916377e93e5a92c52518b6c829f9ab30b Signed-off-by: Mandeep Singh Baines <msb@xxxxxxxxxxxx> --- mm/vmscan.c | 11 +++++++++++ 1 files changed, 11 insertions(+), 0 deletions(-) diff --git a/mm/vmscan.c b/mm/vmscan.c index c5dfabf..0984dee 100644 --- a/mm/vmscan.c +++ b/mm/vmscan.c @@ -593,6 +593,17 @@ static enum page_references page_check_references(struct page *page, if (referenced_ptes) { if (PageAnon(page)) return PAGEREF_ACTIVATE; + + /* + * Identify referenced, file-backed active pages and move them + * to the active list. We know that this page has been + * referenced since being put on the inactive list. VM_EXEC + * pages are only moved to the inactive list when they have not + * been referenced between scans (see shrink_active_list). + */ + if ((vm_flags & VM_EXEC) && page_is_file_cache(page)) + return PAGEREF_ACTIVATE; + /* * All mapped pages start out with page table * references from the instantiating fault, so we need -- 1.7.1 -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxxx For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>