Commit 74e4b956 authored by Michal Koutný's avatar Michal Koutný Committed by Tejun Heo

cgroup: Honor caller's cgroup NS when resolving path

cgroup_get_from_path() is not widely used function. Its callers presume
the path is resolved under cgroup namespace. (There is one caller
currently and resolving in init NS won't make harm (netfilter). However,
future users may be subject to different effects when resolving
globally.)
Since, there's currently no use for the global resolution, modify the
existing function to take cgroup NS into account.

Fixes: a79a908f ("cgroup: introduce cgroup namespaces")
Signed-off-by: default avatarMichal Koutný <mkoutny@suse.com>
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
parent 7f203bc8
...@@ -6602,8 +6602,12 @@ struct cgroup *cgroup_get_from_path(const char *path) ...@@ -6602,8 +6602,12 @@ struct cgroup *cgroup_get_from_path(const char *path)
{ {
struct kernfs_node *kn; struct kernfs_node *kn;
struct cgroup *cgrp = ERR_PTR(-ENOENT); struct cgroup *cgrp = ERR_PTR(-ENOENT);
struct cgroup *root_cgrp;
kn = kernfs_walk_and_get(cgrp_dfl_root.cgrp.kn, path); spin_lock_irq(&css_set_lock);
root_cgrp = current_cgns_cgroup_from_root(&cgrp_dfl_root);
kn = kernfs_walk_and_get(root_cgrp->kn, path);
spin_unlock_irq(&css_set_lock);
if (!kn) if (!kn)
goto out; goto out;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment