mm: add WasActive page flag

Zcache could be ineffective if the compressed memory pool is full with
compressed inactive file pages and most of them will be never used again.

So we pick up pages from active file list only, those pages would probably
be accessed again. Compress them in memory can reduce the latency
significantly compared with rereading from disk.

When a file page is shrunk from active file list to inactive file list,
PageActive flag is also cleared.
So adding an extra WasActive page flag for zcache to know whether the
file page was shrunk from the active list.

Change-Id: Ida1f4db17075d1f6f825ef7ce2b3bae4eb799e3f
Signed-off-by: Bob Liu <bob.liu@oracle.com>
Patch-mainline: linux-mm @ 2013-08-06 11:36:17
[vinmenon@codeaurora.org: trivial merge conflict fixes, checkpatch fixes,
fix the definitions of was_active page flag so that it does not create
compile time errors with CONFIG_CLEANCACHE disabled. Also remove the
unnecessary use of PG_was_active in PAGE_FLAGS_CHECK_AT_PREP. Since
was_active is a requirement for zcache, make the definitions dependent on
CONFIG_ZCACHE rather than CONFIG_CLEANCACHE.]
Signed-off-by: Vinayak Menon <vinmenon@codeaurora.org>
This commit is contained in:
Bob Liu 2013-08-06 19:36:17 +08:00 committed by Kyle Yan
parent a851b0a3c8
commit 5248c3b4e4
4 changed files with 35 additions and 1 deletions

View file

@ -107,6 +107,9 @@ enum pageflags {
#if defined(CONFIG_IDLE_PAGE_TRACKING) && defined(CONFIG_64BIT)
PG_young,
PG_idle,
#endif
#ifdef CONFIG_ZCACHE
PG_was_active,
#endif
__NR_PAGEFLAGS,
@ -224,6 +227,11 @@ PAGEFLAG(SwapBacked, swapbacked) __CLEARPAGEFLAG(SwapBacked, swapbacked)
__SETPAGEFLAG(SwapBacked, swapbacked)
__PAGEFLAG(SlobFree, slob_free)
#ifdef CONFIG_ZCACHE
PAGEFLAG(WasActive, was_active)
#else
PAGEFLAG_FALSE(WasActive)
#endif
/*
* Private page markings that may be used by the filesystem that owns the page

View file

@ -47,6 +47,9 @@ static const struct trace_print_flags pageflag_names[] = {
{1UL << PG_young, "young" },
{1UL << PG_idle, "idle" },
#endif
#ifdef CONFIG_ZCACHE
{1UL << PG_was_active, "was_active" },
#endif
};
static void dump_flags(unsigned long flags,

View file

@ -1575,6 +1575,7 @@ putback_inactive_pages(struct lruvec *lruvec, struct list_head *page_list)
while (!list_empty(page_list)) {
struct page *page = lru_to_page(page_list);
int lru;
int file;
VM_BUG_ON_PAGE(PageLRU(page), page);
list_del(&page->lru);
@ -1591,8 +1592,11 @@ putback_inactive_pages(struct lruvec *lruvec, struct list_head *page_list)
lru = page_lru(page);
add_page_to_lru_list(page, lruvec, lru);
file = is_file_lru(lru);
if (IS_ENABLED(CONFIG_ZCACHE))
if (file)
SetPageWasActive(page);
if (is_active_lru(lru)) {
int file = is_file_lru(lru);
int numpages = hpage_nr_pages(page);
reclaim_stat->recent_rotated[file] += numpages;
}
@ -1917,6 +1921,12 @@ static void shrink_active_list(unsigned long nr_to_scan,
}
ClearPageActive(page); /* we are de-activating */
if (IS_ENABLED(CONFIG_ZCACHE))
/*
* For zcache to know whether the page is from active
* file list
*/
SetPageWasActive(page);
list_add(&page->lru, &l_inactive);
}

View file

@ -68,6 +68,7 @@ static u64 zcache_dup_entry;
static u64 zcache_zbud_alloc_fail;
static u64 zcache_evict_zpages;
static u64 zcache_evict_filepages;
static u64 zcache_inactive_pages_refused;
static u64 zcache_reclaim_fail;
static u64 zcache_pool_shrink;
static u64 zcache_pool_shrink_fail;
@ -648,6 +649,17 @@ static void zcache_store_page(int pool_id, struct cleancache_filekey key,
struct zcache_pool *zpool = zcache.pools[pool_id];
/*
* Zcache will be ineffective if the compressed memory pool is full with
* compressed inactive file pages and most of them will never be used
* again.
* So we refuse to compress pages that are not from active file list.
*/
if (!PageWasActive(page)) {
zcache_inactive_pages_refused++;
return;
}
if (zcache_is_full()) {
zcache_pool_limit_hit++;
if (zbud_reclaim_page(zpool->pool, 8)) {
@ -762,6 +774,7 @@ map:
/* update stats */
atomic_dec(&zcache_stored_pages);
zpool->size = zbud_get_pool_size(zpool->pool);
SetPageWasActive(page);
return ret;
}