|
@@ -420,6 +420,23 @@ void mem_cgroup_move_lists(struct page_cgroup *pc, bool active)
|
|
|
spin_unlock(&mem->lru_lock);
|
|
|
}
|
|
|
|
|
|
+/*
|
|
|
+ * Calculate mapped_ratio under memory controller. This will be used in
|
|
|
+ * vmscan.c for deteremining we have to reclaim mapped pages.
|
|
|
+ */
|
|
|
+int mem_cgroup_calc_mapped_ratio(struct mem_cgroup *mem)
|
|
|
+{
|
|
|
+ long total, rss;
|
|
|
+
|
|
|
+ /*
|
|
|
+ * usage is recorded in bytes. But, here, we assume the number of
|
|
|
+ * physical pages can be represented by "long" on any arch.
|
|
|
+ */
|
|
|
+ total = (long) (mem->res.usage >> PAGE_SHIFT) + 1L;
|
|
|
+ rss = (long)mem_cgroup_read_stat(&mem->stat, MEM_CGROUP_STAT_RSS);
|
|
|
+ return (int)((rss * 100L) / total);
|
|
|
+}
|
|
|
+
|
|
|
unsigned long mem_cgroup_isolate_pages(unsigned long nr_to_scan,
|
|
|
struct list_head *dst,
|
|
|
unsigned long *scanned, int order,
|