diff options
author | Li Zefan <lizefan@huawei.com> | 2013-05-14 07:44:20 -0400 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2013-05-14 11:24:15 -0400 |
commit | d6cbf35dac8a3dadb9103379820c96d7c85df3d9 (patch) | |
tree | bd25f2bebf2620ab87440e1e8b167e7bf3cdca20 | |
parent | f722406faae2d073cc1d01063d1123c35425939e (diff) |
cgroup: initialize xattr before calling d_instantiate()
cgroup_create_file() calls d_instantiate(), which may decide to look
at the xattrs on the file. Smack always does this and SELinux can be
configured to do so.
But cgroup_add_file() didn't initialize xattrs before calling
cgroup_create_file(), which finally leads to dereferencing NULL
dentry->d_fsdata.
This bug has been there since cgroup xattr was introduced.
Cc: <stable@vger.kernel.org> # 3.8.x
Reported-by: Ivan Bulatovic <combuster@archlinux.us>
Reported-by: Casey Schaufler <casey@schaufler-ca.com>
Signed-off-by: Li Zefan <lizefan@huawei.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
-rw-r--r-- | kernel/cgroup.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/kernel/cgroup.c b/kernel/cgroup.c index 2a9926275f80..38b136553044 100644 --- a/kernel/cgroup.c +++ b/kernel/cgroup.c | |||
@@ -2699,13 +2699,14 @@ static int cgroup_add_file(struct cgroup *cgrp, struct cgroup_subsys *subsys, | |||
2699 | goto out; | 2699 | goto out; |
2700 | } | 2700 | } |
2701 | 2701 | ||
2702 | cfe->type = (void *)cft; | ||
2703 | cfe->dentry = dentry; | ||
2704 | dentry->d_fsdata = cfe; | ||
2705 | simple_xattrs_init(&cfe->xattrs); | ||
2706 | |||
2702 | mode = cgroup_file_mode(cft); | 2707 | mode = cgroup_file_mode(cft); |
2703 | error = cgroup_create_file(dentry, mode | S_IFREG, cgrp->root->sb); | 2708 | error = cgroup_create_file(dentry, mode | S_IFREG, cgrp->root->sb); |
2704 | if (!error) { | 2709 | if (!error) { |
2705 | cfe->type = (void *)cft; | ||
2706 | cfe->dentry = dentry; | ||
2707 | dentry->d_fsdata = cfe; | ||
2708 | simple_xattrs_init(&cfe->xattrs); | ||
2709 | list_add_tail(&cfe->node, &parent->files); | 2710 | list_add_tail(&cfe->node, &parent->files); |
2710 | cfe = NULL; | 2711 | cfe = NULL; |
2711 | } | 2712 | } |