|
@@ -25,6 +25,11 @@ struct page_cgroup;
|
|
|
struct page;
|
|
|
struct mm_struct;
|
|
|
|
|
|
+/* Stats that can be updated by kernel. */
|
|
|
+enum mem_cgroup_page_stat_item {
|
|
|
+ MEMCG_NR_FILE_MAPPED, /* # of pages charged as file rss */
|
|
|
+};
|
|
|
+
|
|
|
extern unsigned long mem_cgroup_isolate_pages(unsigned long nr_to_scan,
|
|
|
struct list_head *dst,
|
|
|
unsigned long *scanned, int order,
|
|
@@ -121,7 +126,22 @@ static inline bool mem_cgroup_disabled(void)
|
|
|
return false;
|
|
|
}
|
|
|
|
|
|
-void mem_cgroup_update_file_mapped(struct page *page, int val);
|
|
|
+void mem_cgroup_update_page_stat(struct page *page,
|
|
|
+ enum mem_cgroup_page_stat_item idx,
|
|
|
+ int val);
|
|
|
+
|
|
|
+static inline void mem_cgroup_inc_page_stat(struct page *page,
|
|
|
+ enum mem_cgroup_page_stat_item idx)
|
|
|
+{
|
|
|
+ mem_cgroup_update_page_stat(page, idx, 1);
|
|
|
+}
|
|
|
+
|
|
|
+static inline void mem_cgroup_dec_page_stat(struct page *page,
|
|
|
+ enum mem_cgroup_page_stat_item idx)
|
|
|
+{
|
|
|
+ mem_cgroup_update_page_stat(page, idx, -1);
|
|
|
+}
|
|
|
+
|
|
|
unsigned long mem_cgroup_soft_limit_reclaim(struct zone *zone, int order,
|
|
|
gfp_t gfp_mask);
|
|
|
u64 mem_cgroup_get_limit(struct mem_cgroup *mem);
|
|
@@ -293,8 +313,13 @@ mem_cgroup_print_oom_info(struct mem_cgroup *memcg, struct task_struct *p)
|
|
|
{
|
|
|
}
|
|
|
|
|
|
-static inline void mem_cgroup_update_file_mapped(struct page *page,
|
|
|
- int val)
|
|
|
+static inline void mem_cgroup_inc_page_stat(struct page *page,
|
|
|
+ enum mem_cgroup_page_stat_item idx)
|
|
|
+{
|
|
|
+}
|
|
|
+
|
|
|
+static inline void mem_cgroup_dec_page_stat(struct page *page,
|
|
|
+ enum mem_cgroup_page_stat_item idx)
|
|
|
{
|
|
|
}
|
|
|
|