aboutsummaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
authorVladimir Davydov <vdavydov@parallels.com>2014-12-12 19:55:13 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2014-12-13 15:42:47 -0500
commit4e701d7b37789d1aeb0015210b373912e5d30733 (patch)
tree38257203476057e32f32de241f0d6dc2b7e11891 /mm
parent900a38f027b37b55ebe157a0cb31de351b91e4e2 (diff)
memcg: only check memcg_kmem_skip_account in __memcg_kmem_get_cache
__memcg_kmem_get_cache can recurse if it calls kmalloc (which it does if the cgroup's kmem cache doesn't exist), because kmalloc may call __memcg_kmem_get_cache internally again. To avoid the recursion, we use the task_struct->memcg_kmem_skip_account flag. However, there's no need checking the flag in memcg_kmem_newpage_charge, because there's no way how this function could result in recursion, if called from memcg_kmem_get_cache. So let's remove the redundant code. Signed-off-by: Vladimir Davydov <vdavydov@parallels.com> Cc: Johannes Weiner <hannes@cmpxchg.org> Cc: Michal Hocko <mhocko@suse.cz> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r--mm/memcontrol.c28
1 files changed, 0 insertions, 28 deletions
diff --git a/mm/memcontrol.c b/mm/memcontrol.c
index bb8c237026cc..d9fab72da52e 100644
--- a/mm/memcontrol.c
+++ b/mm/memcontrol.c
@@ -2905,34 +2905,6 @@ __memcg_kmem_newpage_charge(gfp_t gfp, struct mem_cgroup **_memcg, int order)
2905 2905
2906 *_memcg = NULL; 2906 *_memcg = NULL;
2907 2907
2908 /*
2909 * Disabling accounting is only relevant for some specific memcg
2910 * internal allocations. Therefore we would initially not have such
2911 * check here, since direct calls to the page allocator that are
2912 * accounted to kmemcg (alloc_kmem_pages and friends) only happen
2913 * outside memcg core. We are mostly concerned with cache allocations,
2914 * and by having this test at memcg_kmem_get_cache, we are already able
2915 * to relay the allocation to the root cache and bypass the memcg cache
2916 * altogether.
2917 *
2918 * There is one exception, though: the SLUB allocator does not create
2919 * large order caches, but rather service large kmallocs directly from
2920 * the page allocator. Therefore, the following sequence when backed by
2921 * the SLUB allocator:
2922 *
2923 * memcg_stop_kmem_account();
2924 * kmalloc(<large_number>)
2925 * memcg_resume_kmem_account();
2926 *
2927 * would effectively ignore the fact that we should skip accounting,
2928 * since it will drive us directly to this function without passing
2929 * through the cache selector memcg_kmem_get_cache. Such large
2930 * allocations are extremely rare but can happen, for instance, for the
2931 * cache arrays. We bring this test here.
2932 */
2933 if (current->memcg_kmem_skip_account)
2934 return true;
2935
2936 memcg = get_mem_cgroup_from_mm(current->mm); 2908 memcg = get_mem_cgroup_from_mm(current->mm);
2937 2909
2938 if (!memcg_kmem_is_active(memcg)) { 2910 if (!memcg_kmem_is_active(memcg)) {