diff options
author | Vladimir Davydov <vdavydov@parallels.com> | 2014-10-09 18:28:43 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-10-09 22:25:59 -0400 |
commit | 33a690c45b202e4c6483bfd1d93ad8d0f51df2ca (patch) | |
tree | 7dd3e77ff0007b5c03dd9622f5d0b5e63bc357be /include/linux/memcontrol.h | |
parent | 7a82ca0d6437261d0727ce472ae4f3a05a9ce5f7 (diff) |
memcg: move memcg_{alloc,free}_cache_params to slab_common.c
The only reason why they live in memcontrol.c is that we get/put css
reference to the owner memory cgroup in them. However, we can do that in
memcg_{un,}register_cache. OTOH, there are several reasons to move them
to slab_common.c.
First, I think that the less public interface functions we have in
memcontrol.h the better. Since the functions I move don't depend on
memcontrol, I think it's worth making them private to slab, especially
taking into account that the arrays are defined on the slab's side too.
Second, the way how per-memcg arrays are updated looks rather awkward: it
proceeds from memcontrol.c (__memcg_activate_kmem) to slab_common.c
(memcg_update_all_caches) and back to memcontrol.c again
(memcg_update_array_size). In the following patches I move the function
relocating the arrays (memcg_update_array_size) to slab_common.c and
therefore get rid this circular call path. I think we should have the
cache allocation stuff in the same place where we have relocation, because
it's easier to follow the code then. So I move arrays alloc/free
functions to slab_common.c too.
The third point isn't obvious. I'm going to make the list_lru structure
per-memcg to allow targeted kmem reclaim. That means we will have
per-memcg arrays in list_lrus too. It turns out that it's much easier to
update these arrays in list_lru.c rather than in memcontrol.c, because all
the stuff we need is defined there. This patch makes memcg caches arrays
allocation path conform that of the upcoming list_lru.
So let's move these functions to slab_common.c and make them static.
Signed-off-by: Vladimir Davydov <vdavydov@parallels.com>
Acked-by: Johannes Weiner <hannes@cmpxchg.org>
Acked-by: Michal Hocko <mhocko@suse.cz>
Cc: Christoph Lameter <cl@linux.com>
Cc: Glauber Costa <glommer@gmail.com>
Cc: Joonsoo Kim <iamjoonsoo.kim@lge.com>
Cc: David Rientjes <rientjes@google.com>
Cc: Pekka Enberg <penberg@kernel.org>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include/linux/memcontrol.h')
-rw-r--r-- | include/linux/memcontrol.h | 14 |
1 files changed, 0 insertions, 14 deletions
diff --git a/include/linux/memcontrol.h b/include/linux/memcontrol.h index e0752d204d9e..4d17242eeff7 100644 --- a/include/linux/memcontrol.h +++ b/include/linux/memcontrol.h | |||
@@ -440,10 +440,6 @@ void __memcg_kmem_uncharge_pages(struct page *page, int order); | |||
440 | 440 | ||
441 | int memcg_cache_id(struct mem_cgroup *memcg); | 441 | int memcg_cache_id(struct mem_cgroup *memcg); |
442 | 442 | ||
443 | int memcg_alloc_cache_params(struct mem_cgroup *memcg, struct kmem_cache *s, | ||
444 | struct kmem_cache *root_cache); | ||
445 | void memcg_free_cache_params(struct kmem_cache *s); | ||
446 | |||
447 | int memcg_update_cache_size(struct kmem_cache *s, int num_groups); | 443 | int memcg_update_cache_size(struct kmem_cache *s, int num_groups); |
448 | void memcg_update_array_size(int num_groups); | 444 | void memcg_update_array_size(int num_groups); |
449 | 445 | ||
@@ -574,16 +570,6 @@ static inline int memcg_cache_id(struct mem_cgroup *memcg) | |||
574 | return -1; | 570 | return -1; |
575 | } | 571 | } |
576 | 572 | ||
577 | static inline int memcg_alloc_cache_params(struct mem_cgroup *memcg, | ||
578 | struct kmem_cache *s, struct kmem_cache *root_cache) | ||
579 | { | ||
580 | return 0; | ||
581 | } | ||
582 | |||
583 | static inline void memcg_free_cache_params(struct kmem_cache *s) | ||
584 | { | ||
585 | } | ||
586 | |||
587 | static inline struct kmem_cache * | 573 | static inline struct kmem_cache * |
588 | memcg_kmem_get_cache(struct kmem_cache *cachep, gfp_t gfp) | 574 | memcg_kmem_get_cache(struct kmem_cache *cachep, gfp_t gfp) |
589 | { | 575 | { |