aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mm/memcontrol.c54
1 files changed, 32 insertions, 22 deletions
diff --git a/mm/memcontrol.c b/mm/memcontrol.c
index b00ec74a4c18..5f8f93d83edf 100644
--- a/mm/memcontrol.c
+++ b/mm/memcontrol.c
@@ -2857,40 +2857,50 @@ mem_cgroup_get_recursive_idx_stat(struct mem_cgroup *mem,
2857 *val = d.val; 2857 *val = d.val;
2858} 2858}
2859 2859
2860static inline u64 mem_cgroup_usage(struct mem_cgroup *mem, bool swap)
2861{
2862 u64 idx_val, val;
2863
2864 if (!mem_cgroup_is_root(mem)) {
2865 if (!swap)
2866 return res_counter_read_u64(&mem->res, RES_USAGE);
2867 else
2868 return res_counter_read_u64(&mem->memsw, RES_USAGE);
2869 }
2870
2871 mem_cgroup_get_recursive_idx_stat(mem, MEM_CGROUP_STAT_CACHE, &idx_val);
2872 val = idx_val;
2873 mem_cgroup_get_recursive_idx_stat(mem, MEM_CGROUP_STAT_RSS, &idx_val);
2874 val += idx_val;
2875
2876 if (swap) {
2877 mem_cgroup_get_recursive_idx_stat(mem,
2878 MEM_CGROUP_STAT_SWAPOUT, &idx_val);
2879 val += idx_val;
2880 }
2881
2882 return val << PAGE_SHIFT;
2883}
2884
2860static u64 mem_cgroup_read(struct cgroup *cont, struct cftype *cft) 2885static u64 mem_cgroup_read(struct cgroup *cont, struct cftype *cft)
2861{ 2886{
2862 struct mem_cgroup *mem = mem_cgroup_from_cont(cont); 2887 struct mem_cgroup *mem = mem_cgroup_from_cont(cont);
2863 u64 idx_val, val; 2888 u64 val;
2864 int type, name; 2889 int type, name;
2865 2890
2866 type = MEMFILE_TYPE(cft->private); 2891 type = MEMFILE_TYPE(cft->private);
2867 name = MEMFILE_ATTR(cft->private); 2892 name = MEMFILE_ATTR(cft->private);
2868 switch (type) { 2893 switch (type) {
2869 case _MEM: 2894 case _MEM:
2870 if (name == RES_USAGE && mem_cgroup_is_root(mem)) { 2895 if (name == RES_USAGE)
2871 mem_cgroup_get_recursive_idx_stat(mem, 2896 val = mem_cgroup_usage(mem, false);
2872 MEM_CGROUP_STAT_CACHE, &idx_val); 2897 else
2873 val = idx_val;
2874 mem_cgroup_get_recursive_idx_stat(mem,
2875 MEM_CGROUP_STAT_RSS, &idx_val);
2876 val += idx_val;
2877 val <<= PAGE_SHIFT;
2878 } else
2879 val = res_counter_read_u64(&mem->res, name); 2898 val = res_counter_read_u64(&mem->res, name);
2880 break; 2899 break;
2881 case _MEMSWAP: 2900 case _MEMSWAP:
2882 if (name == RES_USAGE && mem_cgroup_is_root(mem)) { 2901 if (name == RES_USAGE)
2883 mem_cgroup_get_recursive_idx_stat(mem, 2902 val = mem_cgroup_usage(mem, true);
2884 MEM_CGROUP_STAT_CACHE, &idx_val); 2903 else
2885 val = idx_val;
2886 mem_cgroup_get_recursive_idx_stat(mem,
2887 MEM_CGROUP_STAT_RSS, &idx_val);
2888 val += idx_val;
2889 mem_cgroup_get_recursive_idx_stat(mem,
2890 MEM_CGROUP_STAT_SWAPOUT, &idx_val);
2891 val += idx_val;
2892 val <<= PAGE_SHIFT;
2893 } else
2894 val = res_counter_read_u64(&mem->memsw, name); 2904 val = res_counter_read_u64(&mem->memsw, name);
2895 break; 2905 break;
2896 default: 2906 default: