diff options
author | Eric Paris <eparis@redhat.com> | 2011-02-01 11:05:39 -0500 |
---|---|---|
committer | Eric Paris <eparis@redhat.com> | 2011-02-01 11:12:29 -0500 |
commit | 2a7dba391e5628ad665ce84ef9a6648da541ebab (patch) | |
tree | ba0722bd74d2c883dbda7ff721850bab411cac04 /fs/ext3 | |
parent | 821404434f3324bf23f545050ff64055a149766e (diff) |
fs/vfs/security: pass last path component to LSM on inode creation
SELinux would like to implement a new labeling behavior of newly created
inodes. We currently label new inodes based on the parent and the creating
process. This new behavior would also take into account the name of the
new object when deciding the new label. This is not the (supposed) full path,
just the last component of the path.
This is very useful because creating /etc/shadow is different than creating
/etc/passwd but the kernel hooks are unable to differentiate these
operations. We currently require that userspace realize it is doing some
difficult operation like that and than userspace jumps through SELinux hoops
to get things set up correctly. This patch does not implement new
behavior, that is obviously contained in a seperate SELinux patch, but it
does pass the needed name down to the correct LSM hook. If no such name
exists it is fine to pass NULL.
Signed-off-by: Eric Paris <eparis@redhat.com>
Diffstat (limited to 'fs/ext3')
-rw-r--r-- | fs/ext3/ialloc.c | 5 | ||||
-rw-r--r-- | fs/ext3/namei.c | 8 | ||||
-rw-r--r-- | fs/ext3/xattr.h | 4 | ||||
-rw-r--r-- | fs/ext3/xattr_security.c | 5 |
4 files changed, 12 insertions, 10 deletions
diff --git a/fs/ext3/ialloc.c b/fs/ext3/ialloc.c index 9724aef22460..bfc2dc43681d 100644 --- a/fs/ext3/ialloc.c +++ b/fs/ext3/ialloc.c | |||
@@ -404,7 +404,8 @@ static int find_group_other(struct super_block *sb, struct inode *parent) | |||
404 | * For other inodes, search forward from the parent directory's block | 404 | * For other inodes, search forward from the parent directory's block |
405 | * group to find a free inode. | 405 | * group to find a free inode. |
406 | */ | 406 | */ |
407 | struct inode *ext3_new_inode(handle_t *handle, struct inode * dir, int mode) | 407 | struct inode *ext3_new_inode(handle_t *handle, struct inode * dir, |
408 | const struct qstr *qstr, int mode) | ||
408 | { | 409 | { |
409 | struct super_block *sb; | 410 | struct super_block *sb; |
410 | struct buffer_head *bitmap_bh = NULL; | 411 | struct buffer_head *bitmap_bh = NULL; |
@@ -589,7 +590,7 @@ got: | |||
589 | if (err) | 590 | if (err) |
590 | goto fail_free_drop; | 591 | goto fail_free_drop; |
591 | 592 | ||
592 | err = ext3_init_security(handle,inode, dir); | 593 | err = ext3_init_security(handle, inode, dir, qstr); |
593 | if (err) | 594 | if (err) |
594 | goto fail_free_drop; | 595 | goto fail_free_drop; |
595 | 596 | ||
diff --git a/fs/ext3/namei.c b/fs/ext3/namei.c index bce9dce639b8..a900033efcce 100644 --- a/fs/ext3/namei.c +++ b/fs/ext3/namei.c | |||
@@ -1707,7 +1707,7 @@ retry: | |||
1707 | if (IS_DIRSYNC(dir)) | 1707 | if (IS_DIRSYNC(dir)) |
1708 | handle->h_sync = 1; | 1708 | handle->h_sync = 1; |
1709 | 1709 | ||
1710 | inode = ext3_new_inode (handle, dir, mode); | 1710 | inode = ext3_new_inode (handle, dir, &dentry->d_name, mode); |
1711 | err = PTR_ERR(inode); | 1711 | err = PTR_ERR(inode); |
1712 | if (!IS_ERR(inode)) { | 1712 | if (!IS_ERR(inode)) { |
1713 | inode->i_op = &ext3_file_inode_operations; | 1713 | inode->i_op = &ext3_file_inode_operations; |
@@ -1743,7 +1743,7 @@ retry: | |||
1743 | if (IS_DIRSYNC(dir)) | 1743 | if (IS_DIRSYNC(dir)) |
1744 | handle->h_sync = 1; | 1744 | handle->h_sync = 1; |
1745 | 1745 | ||
1746 | inode = ext3_new_inode (handle, dir, mode); | 1746 | inode = ext3_new_inode (handle, dir, &dentry->d_name, mode); |
1747 | err = PTR_ERR(inode); | 1747 | err = PTR_ERR(inode); |
1748 | if (!IS_ERR(inode)) { | 1748 | if (!IS_ERR(inode)) { |
1749 | init_special_inode(inode, inode->i_mode, rdev); | 1749 | init_special_inode(inode, inode->i_mode, rdev); |
@@ -1781,7 +1781,7 @@ retry: | |||
1781 | if (IS_DIRSYNC(dir)) | 1781 | if (IS_DIRSYNC(dir)) |
1782 | handle->h_sync = 1; | 1782 | handle->h_sync = 1; |
1783 | 1783 | ||
1784 | inode = ext3_new_inode (handle, dir, S_IFDIR | mode); | 1784 | inode = ext3_new_inode (handle, dir, &dentry->d_name, S_IFDIR | mode); |
1785 | err = PTR_ERR(inode); | 1785 | err = PTR_ERR(inode); |
1786 | if (IS_ERR(inode)) | 1786 | if (IS_ERR(inode)) |
1787 | goto out_stop; | 1787 | goto out_stop; |
@@ -2195,7 +2195,7 @@ retry: | |||
2195 | if (IS_DIRSYNC(dir)) | 2195 | if (IS_DIRSYNC(dir)) |
2196 | handle->h_sync = 1; | 2196 | handle->h_sync = 1; |
2197 | 2197 | ||
2198 | inode = ext3_new_inode (handle, dir, S_IFLNK|S_IRWXUGO); | 2198 | inode = ext3_new_inode (handle, dir, &dentry->d_name, S_IFLNK|S_IRWXUGO); |
2199 | err = PTR_ERR(inode); | 2199 | err = PTR_ERR(inode); |
2200 | if (IS_ERR(inode)) | 2200 | if (IS_ERR(inode)) |
2201 | goto out_stop; | 2201 | goto out_stop; |
diff --git a/fs/ext3/xattr.h b/fs/ext3/xattr.h index 377fe7201169..2be4f69bfa64 100644 --- a/fs/ext3/xattr.h +++ b/fs/ext3/xattr.h | |||
@@ -128,10 +128,10 @@ exit_ext3_xattr(void) | |||
128 | 128 | ||
129 | #ifdef CONFIG_EXT3_FS_SECURITY | 129 | #ifdef CONFIG_EXT3_FS_SECURITY |
130 | extern int ext3_init_security(handle_t *handle, struct inode *inode, | 130 | extern int ext3_init_security(handle_t *handle, struct inode *inode, |
131 | struct inode *dir); | 131 | struct inode *dir, const struct qstr *qstr); |
132 | #else | 132 | #else |
133 | static inline int ext3_init_security(handle_t *handle, struct inode *inode, | 133 | static inline int ext3_init_security(handle_t *handle, struct inode *inode, |
134 | struct inode *dir) | 134 | struct inode *dir, const struct qstr *qstr) |
135 | { | 135 | { |
136 | return 0; | 136 | return 0; |
137 | } | 137 | } |
diff --git a/fs/ext3/xattr_security.c b/fs/ext3/xattr_security.c index 03a99bfc59f9..b8d9f83aa5c5 100644 --- a/fs/ext3/xattr_security.c +++ b/fs/ext3/xattr_security.c | |||
@@ -49,14 +49,15 @@ ext3_xattr_security_set(struct dentry *dentry, const char *name, | |||
49 | } | 49 | } |
50 | 50 | ||
51 | int | 51 | int |
52 | ext3_init_security(handle_t *handle, struct inode *inode, struct inode *dir) | 52 | ext3_init_security(handle_t *handle, struct inode *inode, struct inode *dir, |
53 | const struct qstr *qstr) | ||
53 | { | 54 | { |
54 | int err; | 55 | int err; |
55 | size_t len; | 56 | size_t len; |
56 | void *value; | 57 | void *value; |
57 | char *name; | 58 | char *name; |
58 | 59 | ||
59 | err = security_inode_init_security(inode, dir, &name, &value, &len); | 60 | err = security_inode_init_security(inode, dir, qstr, &name, &value, &len); |
60 | if (err) { | 61 | if (err) { |
61 | if (err == -EOPNOTSUPP) | 62 | if (err == -EOPNOTSUPP) |
62 | return 0; | 63 | return 0; |