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 /kernel | |
| 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>
Diffstat (limited to 'kernel')
| -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 | } |
