diff options
author | KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com> | 2012-01-12 20:18:55 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-12 23:13:07 -0500 |
commit | dc67d50465f249bb357bf85b3ed1f642eb00130a (patch) | |
tree | f3808a1bebe5dfbf1691603007966b7222376d55 | |
parent | de077d222d5ca6108cab119a09593344c12100ab (diff) |
memcg: simplify page cache charging
This patch is a clean up. No functional/logical changes.
Because of commit ef6a3c6311 ("mm: add replace_page_cache_page()
function") , FUSE uses replace_page_cache() instead of
add_to_page_cache(). Then, mem_cgroup_cache_charge() is not called
against FUSE's pages from splice.
So now, mem_cgroup_cache_charge() gets pages that are not on the LRU
with the exception of PageSwapCache pages. For checking,
WARN_ON_ONCE(PageLRU(page)) is added.
Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
Cc: Miklos Szeredi <mszeredi@suse.cz>
Acked-by: Michal Hocko <mhocko@suse.cz>
Acked-by: Johannes Weiner <hannes@cmpxchg.org>
Cc: Ying Han <yinghan@google.com>
Cc: Hugh Dickins <hughd@google.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | mm/memcontrol.c | 31 |
1 files changed, 9 insertions, 22 deletions
diff --git a/mm/memcontrol.c b/mm/memcontrol.c index 7bc30707d0c6..71bac4d720d7 100644 --- a/mm/memcontrol.c +++ b/mm/memcontrol.c | |||
@@ -2790,6 +2790,7 @@ int mem_cgroup_cache_charge(struct page *page, struct mm_struct *mm, | |||
2790 | gfp_t gfp_mask) | 2790 | gfp_t gfp_mask) |
2791 | { | 2791 | { |
2792 | struct mem_cgroup *memcg = NULL; | 2792 | struct mem_cgroup *memcg = NULL; |
2793 | enum charge_type type = MEM_CGROUP_CHARGE_TYPE_CACHE; | ||
2793 | int ret; | 2794 | int ret; |
2794 | 2795 | ||
2795 | if (mem_cgroup_disabled()) | 2796 | if (mem_cgroup_disabled()) |
@@ -2799,31 +2800,17 @@ int mem_cgroup_cache_charge(struct page *page, struct mm_struct *mm, | |||
2799 | 2800 | ||
2800 | if (unlikely(!mm)) | 2801 | if (unlikely(!mm)) |
2801 | mm = &init_mm; | 2802 | mm = &init_mm; |
2803 | if (!page_is_file_cache(page)) | ||
2804 | type = MEM_CGROUP_CHARGE_TYPE_SHMEM; | ||
2802 | 2805 | ||
2803 | if (page_is_file_cache(page)) { | 2806 | if (!PageSwapCache(page)) { |
2804 | ret = __mem_cgroup_try_charge(mm, gfp_mask, 1, &memcg, true); | 2807 | ret = mem_cgroup_charge_common(page, mm, gfp_mask, type); |
2805 | if (ret || !memcg) | 2808 | WARN_ON_ONCE(PageLRU(page)); |
2806 | return ret; | 2809 | } else { /* page is swapcache/shmem */ |
2807 | |||
2808 | /* | ||
2809 | * FUSE reuses pages without going through the final | ||
2810 | * put that would remove them from the LRU list, make | ||
2811 | * sure that they get relinked properly. | ||
2812 | */ | ||
2813 | __mem_cgroup_commit_charge_lrucare(page, memcg, | ||
2814 | MEM_CGROUP_CHARGE_TYPE_CACHE); | ||
2815 | return ret; | ||
2816 | } | ||
2817 | /* shmem */ | ||
2818 | if (PageSwapCache(page)) { | ||
2819 | ret = mem_cgroup_try_charge_swapin(mm, page, gfp_mask, &memcg); | 2810 | ret = mem_cgroup_try_charge_swapin(mm, page, gfp_mask, &memcg); |
2820 | if (!ret) | 2811 | if (!ret) |
2821 | __mem_cgroup_commit_charge_swapin(page, memcg, | 2812 | __mem_cgroup_commit_charge_swapin(page, memcg, type); |
2822 | MEM_CGROUP_CHARGE_TYPE_SHMEM); | 2813 | } |
2823 | } else | ||
2824 | ret = mem_cgroup_charge_common(page, mm, gfp_mask, | ||
2825 | MEM_CGROUP_CHARGE_TYPE_SHMEM); | ||
2826 | |||
2827 | return ret; | 2814 | return ret; |
2828 | } | 2815 | } |
2829 | 2816 | ||