提交 413918bb 编写于 作者: J Johannes Weiner 提交者: Linus Torvalds

mm: memcontrol: pull the NULL check from __mem_cgroup_same_or_subtree()

The NULL in mm_match_cgroup() comes from a possibly exiting mm->owner.  It
makes a lot more sense to check where it's looked up, rather than check
for it in __mem_cgroup_same_or_subtree() where it's unexpected.

No other callsite passes NULL to __mem_cgroup_same_or_subtree().
Signed-off-by: NJohannes Weiner <hannes@cmpxchg.org>
Reviewed-by: NVladimir Davydov <vdavydov@parallels.com>
Acked-by: NMichal Hocko <mhocko@suse.cz>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 c01f46c7
...@@ -83,11 +83,12 @@ static inline ...@@ -83,11 +83,12 @@ static inline
bool mm_match_cgroup(const struct mm_struct *mm, const struct mem_cgroup *memcg) bool mm_match_cgroup(const struct mm_struct *mm, const struct mem_cgroup *memcg)
{ {
struct mem_cgroup *task_memcg; struct mem_cgroup *task_memcg;
bool match; bool match = false;
rcu_read_lock(); rcu_read_lock();
task_memcg = mem_cgroup_from_task(rcu_dereference(mm->owner)); task_memcg = mem_cgroup_from_task(rcu_dereference(mm->owner));
match = __mem_cgroup_same_or_subtree(memcg, task_memcg); if (task_memcg)
match = __mem_cgroup_same_or_subtree(memcg, task_memcg);
rcu_read_unlock(); rcu_read_unlock();
return match; return match;
} }
......
...@@ -1337,7 +1337,7 @@ bool __mem_cgroup_same_or_subtree(const struct mem_cgroup *root_memcg, ...@@ -1337,7 +1337,7 @@ bool __mem_cgroup_same_or_subtree(const struct mem_cgroup *root_memcg,
{ {
if (root_memcg == memcg) if (root_memcg == memcg)
return true; return true;
if (!root_memcg->use_hierarchy || !memcg) if (!root_memcg->use_hierarchy)
return false; return false;
return cgroup_is_descendant(memcg->css.cgroup, root_memcg->css.cgroup); return cgroup_is_descendant(memcg->css.cgroup, root_memcg->css.cgroup);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册