This patch adds vmstat information about discarded page in vrange
so admin can see how many of volatile pages are discarded by VM
and efficieny. it could be indicator for seeing vrange working
well.

PG_VRANGE_SCAN : the number of scanned pages for discarding
PG_VRANGE_DISCARD: the number of discarded pages in kswapd's vrange LRU order
PGDISCARD_DIRECT : the number of discarded pages in process context
PGDISCARD_KSWAPD : the number of discarded pages in kswapd's page LRU order

Signed-off-by: Minchan Kim <minc...@kernel.org>
---
 include/linux/vm_event_item.h | 4 ++++
 mm/vmstat.c                   | 4 ++++
 mm/vrange.c                   | 9 +++++++++
 3 files changed, 17 insertions(+)

diff --git a/include/linux/vm_event_item.h b/include/linux/vm_event_item.h
index bd6cf61..3d8ad18 100644
--- a/include/linux/vm_event_item.h
+++ b/include/linux/vm_event_item.h
@@ -25,6 +25,10 @@ enum vm_event_item { PGPGIN, PGPGOUT, PSWPIN, PSWPOUT,
                FOR_ALL_ZONES(PGALLOC),
                PGFREE, PGACTIVATE, PGDEACTIVATE,
                PGFAULT, PGMAJFAULT,
+               PG_VRANGE_SCAN,
+               PG_VRANGE_DISCARD,
+               PGDISCARD_DIRECT,
+               PGDISCARD_KSWAPD,
                FOR_ALL_ZONES(PGREFILL),
                FOR_ALL_ZONES(PGSTEAL_KSWAPD),
                FOR_ALL_ZONES(PGSTEAL_DIRECT),
diff --git a/mm/vmstat.c b/mm/vmstat.c
index e1d8ed1..55806d2 100644
--- a/mm/vmstat.c
+++ b/mm/vmstat.c
@@ -754,6 +754,10 @@ const char * const vmstat_text[] = {
 
        "pgfault",
        "pgmajfault",
+       "pgvrange_scan",
+       "pgvrange_discard",
+       "pgdiscard_direct",
+       "pgdiscard_kswapd",
 
        TEXTS_FOR_ZONES("pgrefill")
        TEXTS_FOR_ZONES("pgsteal_kswapd")
diff --git a/mm/vrange.c b/mm/vrange.c
index 2f56d36..c0c5d50 100644
--- a/mm/vrange.c
+++ b/mm/vrange.c
@@ -518,6 +518,10 @@ int discard_vpage(struct page *page)
                if (page_freeze_refs(page, 1)) {
                        unlock_page(page);
                        dec_zone_page_state(page, NR_ISOLATED_ANON);
+                       if (current_is_kswapd())
+                               count_vm_event(PGDISCARD_KSWAPD);
+                       else
+                               count_vm_event(PGDISCARD_DIRECT);
                        return 1;
                }
        }
@@ -584,11 +588,15 @@ static int vrange_pte_range(pmd_t *pmd, unsigned long 
addr, unsigned long end,
 {
        pte_t *pte;
        spinlock_t *ptl;
+       unsigned long start = addr;
 
        pte = pte_offset_map_lock(walk->mm, pmd, addr, &ptl);
        for (; addr != end; pte++, addr += PAGE_SIZE)
                vrange_pte_entry(*pte, addr, PAGE_SIZE, walk);
        pte_unmap_unlock(pte - 1, ptl);
+
+       count_vm_events(PG_VRANGE_SCAN, (end - start) / PAGE_SIZE);
+
        cond_resched();
        return 0;
 
@@ -741,5 +749,6 @@ unsigned int discard_vrange_pages(struct zone *zone, int 
nr_to_discard)
        if (start_vrange)
                put_victim_range(start_vrange);
 
+       count_vm_events(PG_VRANGE_DISCARD, nr_discarded);
        return nr_discarded;
 }
-- 
1.8.1.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to