diff options
Diffstat (limited to 'fs/btrfs/inode.c')
| -rw-r--r-- | fs/btrfs/inode.c | 23 |
1 files changed, 19 insertions, 4 deletions
diff --git a/fs/btrfs/inode.c b/fs/btrfs/inode.c index 2bb65e9b1448..4a79e1c5ebd0 100644 --- a/fs/btrfs/inode.c +++ b/fs/btrfs/inode.c | |||
| @@ -90,6 +90,16 @@ static noinline int cow_file_range(struct inode *inode, | |||
| 90 | u64 start, u64 end, int *page_started, | 90 | u64 start, u64 end, int *page_started, |
| 91 | unsigned long *nr_written, int unlock); | 91 | unsigned long *nr_written, int unlock); |
| 92 | 92 | ||
| 93 | static int btrfs_init_inode_security(struct inode *inode, struct inode *dir) | ||
| 94 | { | ||
| 95 | int err; | ||
| 96 | |||
| 97 | err = btrfs_init_acl(inode, dir); | ||
| 98 | if (!err) | ||
| 99 | err = btrfs_xattr_security_init(inode, dir); | ||
| 100 | return err; | ||
| 101 | } | ||
| 102 | |||
| 93 | /* | 103 | /* |
| 94 | * a very lame attempt at stopping writes when the FS is 85% full. There | 104 | * a very lame attempt at stopping writes when the FS is 85% full. There |
| 95 | * are countless ways this is incorrect, but it is better than nothing. | 105 | * are countless ways this is incorrect, but it is better than nothing. |
| @@ -2037,6 +2047,7 @@ void btrfs_read_locked_inode(struct inode *inode) | |||
| 2037 | inode->i_mapping->backing_dev_info = &root->fs_info->bdi; | 2047 | inode->i_mapping->backing_dev_info = &root->fs_info->bdi; |
| 2038 | break; | 2048 | break; |
| 2039 | default: | 2049 | default: |
| 2050 | inode->i_op = &btrfs_special_inode_operations; | ||
| 2040 | init_special_inode(inode, inode->i_mode, rdev); | 2051 | init_special_inode(inode, inode->i_mode, rdev); |
| 2041 | break; | 2052 | break; |
| 2042 | } | 2053 | } |
| @@ -3584,7 +3595,7 @@ static int btrfs_mknod(struct inode *dir, struct dentry *dentry, | |||
| 3584 | if (IS_ERR(inode)) | 3595 | if (IS_ERR(inode)) |
| 3585 | goto out_unlock; | 3596 | goto out_unlock; |
| 3586 | 3597 | ||
| 3587 | err = btrfs_init_acl(inode, dir); | 3598 | err = btrfs_init_inode_security(inode, dir); |
| 3588 | if (err) { | 3599 | if (err) { |
| 3589 | drop_inode = 1; | 3600 | drop_inode = 1; |
| 3590 | goto out_unlock; | 3601 | goto out_unlock; |
| @@ -3647,7 +3658,7 @@ static int btrfs_create(struct inode *dir, struct dentry *dentry, | |||
| 3647 | if (IS_ERR(inode)) | 3658 | if (IS_ERR(inode)) |
| 3648 | goto out_unlock; | 3659 | goto out_unlock; |
| 3649 | 3660 | ||
| 3650 | err = btrfs_init_acl(inode, dir); | 3661 | err = btrfs_init_inode_security(inode, dir); |
| 3651 | if (err) { | 3662 | if (err) { |
| 3652 | drop_inode = 1; | 3663 | drop_inode = 1; |
| 3653 | goto out_unlock; | 3664 | goto out_unlock; |
| @@ -3770,7 +3781,7 @@ static int btrfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) | |||
| 3770 | 3781 | ||
| 3771 | drop_on_err = 1; | 3782 | drop_on_err = 1; |
| 3772 | 3783 | ||
| 3773 | err = btrfs_init_acl(inode, dir); | 3784 | err = btrfs_init_inode_security(inode, dir); |
| 3774 | if (err) | 3785 | if (err) |
| 3775 | goto out_fail; | 3786 | goto out_fail; |
| 3776 | 3787 | ||
| @@ -4732,7 +4743,7 @@ static int btrfs_symlink(struct inode *dir, struct dentry *dentry, | |||
| 4732 | if (IS_ERR(inode)) | 4743 | if (IS_ERR(inode)) |
| 4733 | goto out_unlock; | 4744 | goto out_unlock; |
| 4734 | 4745 | ||
| 4735 | err = btrfs_init_acl(inode, dir); | 4746 | err = btrfs_init_inode_security(inode, dir); |
| 4736 | if (err) { | 4747 | if (err) { |
| 4737 | drop_inode = 1; | 4748 | drop_inode = 1; |
| 4738 | goto out_unlock; | 4749 | goto out_unlock; |
| @@ -5043,4 +5054,8 @@ static struct inode_operations btrfs_symlink_inode_operations = { | |||
| 5043 | .follow_link = page_follow_link_light, | 5054 | .follow_link = page_follow_link_light, |
| 5044 | .put_link = page_put_link, | 5055 | .put_link = page_put_link, |
| 5045 | .permission = btrfs_permission, | 5056 | .permission = btrfs_permission, |
| 5057 | .setxattr = btrfs_setxattr, | ||
| 5058 | .getxattr = btrfs_getxattr, | ||
| 5059 | .listxattr = btrfs_listxattr, | ||
| 5060 | .removexattr = btrfs_removexattr, | ||
| 5046 | }; | 5061 | }; |
