diff options
| -rw-r--r-- | fs/attr.c | 11 | ||||
| -rw-r--r-- | fs/jfs/acl.c | 26 | ||||
| -rw-r--r-- | fs/jfs/file.c | 26 | ||||
| -rw-r--r-- | fs/jfs/jfs_acl.h | 7 | ||||
| -rw-r--r-- | fs/jfs/jfs_inode.h | 1 | ||||
| -rw-r--r-- | fs/jfs/namei.c | 2 | ||||
| -rw-r--r-- | fs/udf/file.c | 23 | ||||
| -rw-r--r-- | fs/ufs/truncate.c | 7 |
8 files changed, 65 insertions, 38 deletions
| @@ -12,7 +12,6 @@ | |||
| 12 | #include <linux/capability.h> | 12 | #include <linux/capability.h> |
| 13 | #include <linux/fsnotify.h> | 13 | #include <linux/fsnotify.h> |
| 14 | #include <linux/fcntl.h> | 14 | #include <linux/fcntl.h> |
| 15 | #include <linux/quotaops.h> | ||
| 16 | #include <linux/security.h> | 15 | #include <linux/security.h> |
| 17 | 16 | ||
| 18 | /* Taken over from the old code... */ | 17 | /* Taken over from the old code... */ |
| @@ -212,14 +211,8 @@ int notify_change(struct dentry * dentry, struct iattr * attr) | |||
| 212 | error = inode->i_op->setattr(dentry, attr); | 211 | error = inode->i_op->setattr(dentry, attr); |
| 213 | } else { | 212 | } else { |
| 214 | error = inode_change_ok(inode, attr); | 213 | error = inode_change_ok(inode, attr); |
| 215 | if (!error) { | 214 | if (!error) |
| 216 | if ((ia_valid & ATTR_UID && attr->ia_uid != inode->i_uid) || | 215 | error = inode_setattr(inode, attr); |
| 217 | (ia_valid & ATTR_GID && attr->ia_gid != inode->i_gid)) | ||
| 218 | error = vfs_dq_transfer(inode, attr) ? | ||
| 219 | -EDQUOT : 0; | ||
| 220 | if (!error) | ||
| 221 | error = inode_setattr(inode, attr); | ||
| 222 | } | ||
| 223 | } | 216 | } |
| 224 | 217 | ||
| 225 | if (ia_valid & ATTR_SIZE) | 218 | if (ia_valid & ATTR_SIZE) |
diff --git a/fs/jfs/acl.c b/fs/jfs/acl.c index d66477c34306..213169780b6c 100644 --- a/fs/jfs/acl.c +++ b/fs/jfs/acl.c | |||
| @@ -20,7 +20,6 @@ | |||
| 20 | 20 | ||
| 21 | #include <linux/sched.h> | 21 | #include <linux/sched.h> |
| 22 | #include <linux/fs.h> | 22 | #include <linux/fs.h> |
| 23 | #include <linux/quotaops.h> | ||
| 24 | #include <linux/posix_acl_xattr.h> | 23 | #include <linux/posix_acl_xattr.h> |
| 25 | #include "jfs_incore.h" | 24 | #include "jfs_incore.h" |
| 26 | #include "jfs_txnmgr.h" | 25 | #include "jfs_txnmgr.h" |
| @@ -174,7 +173,7 @@ cleanup: | |||
| 174 | return rc; | 173 | return rc; |
| 175 | } | 174 | } |
| 176 | 175 | ||
| 177 | static int jfs_acl_chmod(struct inode *inode) | 176 | int jfs_acl_chmod(struct inode *inode) |
| 178 | { | 177 | { |
| 179 | struct posix_acl *acl, *clone; | 178 | struct posix_acl *acl, *clone; |
| 180 | int rc; | 179 | int rc; |
| @@ -205,26 +204,3 @@ static int jfs_acl_chmod(struct inode *inode) | |||
| 205 | posix_acl_release(clone); | 204 | posix_acl_release(clone); |
| 206 | return rc; | 205 | return rc; |
| 207 | } | 206 | } |
| 208 | |||
| 209 | int jfs_setattr(struct dentry *dentry, struct iattr *iattr) | ||
| 210 | { | ||
| 211 | struct inode *inode = dentry->d_inode; | ||
| 212 | int rc; | ||
| 213 | |||
| 214 | rc = inode_change_ok(inode, iattr); | ||
| 215 | if (rc) | ||
| 216 | return rc; | ||
| 217 | |||
| 218 | if ((iattr->ia_valid & ATTR_UID && iattr->ia_uid != inode->i_uid) || | ||
| 219 | (iattr->ia_valid & ATTR_GID && iattr->ia_gid != inode->i_gid)) { | ||
| 220 | if (vfs_dq_transfer(inode, iattr)) | ||
| 221 | return -EDQUOT; | ||
| 222 | } | ||
| 223 | |||
| 224 | rc = inode_setattr(inode, iattr); | ||
| 225 | |||
| 226 | if (!rc && (iattr->ia_valid & ATTR_MODE)) | ||
| 227 | rc = jfs_acl_chmod(inode); | ||
| 228 | |||
| 229 | return rc; | ||
| 230 | } | ||
diff --git a/fs/jfs/file.c b/fs/jfs/file.c index 2b70fa78e4a7..a4229e49330e 100644 --- a/fs/jfs/file.c +++ b/fs/jfs/file.c | |||
| @@ -18,6 +18,7 @@ | |||
| 18 | */ | 18 | */ |
| 19 | 19 | ||
| 20 | #include <linux/fs.h> | 20 | #include <linux/fs.h> |
| 21 | #include <linux/quotaops.h> | ||
| 21 | #include "jfs_incore.h" | 22 | #include "jfs_incore.h" |
| 22 | #include "jfs_inode.h" | 23 | #include "jfs_inode.h" |
| 23 | #include "jfs_dmap.h" | 24 | #include "jfs_dmap.h" |
| @@ -88,14 +89,37 @@ static int jfs_release(struct inode *inode, struct file *file) | |||
| 88 | return 0; | 89 | return 0; |
| 89 | } | 90 | } |
| 90 | 91 | ||
| 92 | int jfs_setattr(struct dentry *dentry, struct iattr *iattr) | ||
| 93 | { | ||
| 94 | struct inode *inode = dentry->d_inode; | ||
| 95 | int rc; | ||
| 96 | |||
| 97 | rc = inode_change_ok(inode, iattr); | ||
| 98 | if (rc) | ||
| 99 | return rc; | ||
| 100 | |||
| 101 | if ((iattr->ia_valid & ATTR_UID && iattr->ia_uid != inode->i_uid) || | ||
| 102 | (iattr->ia_valid & ATTR_GID && iattr->ia_gid != inode->i_gid)) { | ||
| 103 | if (vfs_dq_transfer(inode, iattr)) | ||
| 104 | return -EDQUOT; | ||
| 105 | } | ||
| 106 | |||
| 107 | rc = inode_setattr(inode, iattr); | ||
| 108 | |||
| 109 | if (!rc && (iattr->ia_valid & ATTR_MODE)) | ||
| 110 | rc = jfs_acl_chmod(inode); | ||
| 111 | |||
| 112 | return rc; | ||
| 113 | } | ||
| 114 | |||
| 91 | const struct inode_operations jfs_file_inode_operations = { | 115 | const struct inode_operations jfs_file_inode_operations = { |
| 92 | .truncate = jfs_truncate, | 116 | .truncate = jfs_truncate, |
| 93 | .setxattr = jfs_setxattr, | 117 | .setxattr = jfs_setxattr, |
| 94 | .getxattr = jfs_getxattr, | 118 | .getxattr = jfs_getxattr, |
| 95 | .listxattr = jfs_listxattr, | 119 | .listxattr = jfs_listxattr, |
| 96 | .removexattr = jfs_removexattr, | 120 | .removexattr = jfs_removexattr, |
| 97 | #ifdef CONFIG_JFS_POSIX_ACL | ||
| 98 | .setattr = jfs_setattr, | 121 | .setattr = jfs_setattr, |
| 122 | #ifdef CONFIG_JFS_POSIX_ACL | ||
| 99 | .check_acl = jfs_check_acl, | 123 | .check_acl = jfs_check_acl, |
| 100 | #endif | 124 | #endif |
| 101 | }; | 125 | }; |
diff --git a/fs/jfs/jfs_acl.h b/fs/jfs/jfs_acl.h index b07bd417ef85..54e07559878d 100644 --- a/fs/jfs/jfs_acl.h +++ b/fs/jfs/jfs_acl.h | |||
| @@ -22,7 +22,7 @@ | |||
| 22 | 22 | ||
| 23 | int jfs_check_acl(struct inode *, int); | 23 | int jfs_check_acl(struct inode *, int); |
| 24 | int jfs_init_acl(tid_t, struct inode *, struct inode *); | 24 | int jfs_init_acl(tid_t, struct inode *, struct inode *); |
| 25 | int jfs_setattr(struct dentry *, struct iattr *); | 25 | int jfs_acl_chmod(struct inode *inode); |
| 26 | 26 | ||
| 27 | #else | 27 | #else |
| 28 | 28 | ||
| @@ -32,5 +32,10 @@ static inline int jfs_init_acl(tid_t tid, struct inode *inode, | |||
| 32 | return 0; | 32 | return 0; |
| 33 | } | 33 | } |
| 34 | 34 | ||
| 35 | static inline int jfs_acl_chmod(struct inode *inode) | ||
| 36 | { | ||
| 37 | return 0; | ||
| 38 | } | ||
| 39 | |||
| 35 | #endif | 40 | #endif |
| 36 | #endif /* _H_JFS_ACL */ | 41 | #endif /* _H_JFS_ACL */ |
diff --git a/fs/jfs/jfs_inode.h b/fs/jfs/jfs_inode.h index 1eff7db34d63..4b91b2787835 100644 --- a/fs/jfs/jfs_inode.h +++ b/fs/jfs/jfs_inode.h | |||
| @@ -40,6 +40,7 @@ extern struct dentry *jfs_fh_to_parent(struct super_block *sb, struct fid *fid, | |||
| 40 | int fh_len, int fh_type); | 40 | int fh_len, int fh_type); |
| 41 | extern void jfs_set_inode_flags(struct inode *); | 41 | extern void jfs_set_inode_flags(struct inode *); |
| 42 | extern int jfs_get_block(struct inode *, sector_t, struct buffer_head *, int); | 42 | extern int jfs_get_block(struct inode *, sector_t, struct buffer_head *, int); |
| 43 | extern int jfs_setattr(struct dentry *, struct iattr *); | ||
| 43 | 44 | ||
| 44 | extern const struct address_space_operations jfs_aops; | 45 | extern const struct address_space_operations jfs_aops; |
| 45 | extern const struct inode_operations jfs_dir_inode_operations; | 46 | extern const struct inode_operations jfs_dir_inode_operations; |
diff --git a/fs/jfs/namei.c b/fs/jfs/namei.c index c79a4270f083..1d1390afe55e 100644 --- a/fs/jfs/namei.c +++ b/fs/jfs/namei.c | |||
| @@ -1541,8 +1541,8 @@ const struct inode_operations jfs_dir_inode_operations = { | |||
| 1541 | .getxattr = jfs_getxattr, | 1541 | .getxattr = jfs_getxattr, |
| 1542 | .listxattr = jfs_listxattr, | 1542 | .listxattr = jfs_listxattr, |
| 1543 | .removexattr = jfs_removexattr, | 1543 | .removexattr = jfs_removexattr, |
| 1544 | #ifdef CONFIG_JFS_POSIX_ACL | ||
| 1545 | .setattr = jfs_setattr, | 1544 | .setattr = jfs_setattr, |
| 1545 | #ifdef CONFIG_JFS_POSIX_ACL | ||
| 1546 | .check_acl = jfs_check_acl, | 1546 | .check_acl = jfs_check_acl, |
| 1547 | #endif | 1547 | #endif |
| 1548 | }; | 1548 | }; |
diff --git a/fs/udf/file.c b/fs/udf/file.c index f311d509b6a3..35ca47281faa 100644 --- a/fs/udf/file.c +++ b/fs/udf/file.c | |||
| @@ -34,6 +34,7 @@ | |||
| 34 | #include <linux/errno.h> | 34 | #include <linux/errno.h> |
| 35 | #include <linux/smp_lock.h> | 35 | #include <linux/smp_lock.h> |
| 36 | #include <linux/pagemap.h> | 36 | #include <linux/pagemap.h> |
| 37 | #include <linux/quotaops.h> | ||
| 37 | #include <linux/buffer_head.h> | 38 | #include <linux/buffer_head.h> |
| 38 | #include <linux/aio.h> | 39 | #include <linux/aio.h> |
| 39 | 40 | ||
| @@ -217,6 +218,26 @@ const struct file_operations udf_file_operations = { | |||
| 217 | .llseek = generic_file_llseek, | 218 | .llseek = generic_file_llseek, |
| 218 | }; | 219 | }; |
| 219 | 220 | ||
| 221 | static int udf_setattr(struct dentry *dentry, struct iattr *iattr) | ||
| 222 | { | ||
| 223 | struct inode *inode = dentry->d_inode; | ||
| 224 | int error; | ||
| 225 | |||
| 226 | error = inode_change_ok(inode, iattr); | ||
| 227 | if (error) | ||
| 228 | return error; | ||
| 229 | |||
| 230 | if ((iattr->ia_valid & ATTR_UID && iattr->ia_uid != inode->i_uid) || | ||
| 231 | (iattr->ia_valid & ATTR_GID && iattr->ia_gid != inode->i_gid)) { | ||
| 232 | error = vfs_dq_transfer(inode, iattr) ? -EDQUOT : 0; | ||
| 233 | if (error) | ||
| 234 | return error; | ||
| 235 | } | ||
| 236 | |||
| 237 | return inode_setattr(inode, iattr); | ||
| 238 | } | ||
| 239 | |||
| 220 | const struct inode_operations udf_file_inode_operations = { | 240 | const struct inode_operations udf_file_inode_operations = { |
| 221 | .truncate = udf_truncate, | 241 | .truncate = udf_truncate, |
| 242 | .setattr = udf_setattr, | ||
| 222 | }; | 243 | }; |
diff --git a/fs/ufs/truncate.c b/fs/ufs/truncate.c index 41dd431ce228..56ab31f00bd0 100644 --- a/fs/ufs/truncate.c +++ b/fs/ufs/truncate.c | |||
| @@ -44,6 +44,7 @@ | |||
| 44 | #include <linux/buffer_head.h> | 44 | #include <linux/buffer_head.h> |
| 45 | #include <linux/blkdev.h> | 45 | #include <linux/blkdev.h> |
| 46 | #include <linux/sched.h> | 46 | #include <linux/sched.h> |
| 47 | #include <linux/quotaops.h> | ||
| 47 | 48 | ||
| 48 | #include "ufs_fs.h" | 49 | #include "ufs_fs.h" |
| 49 | #include "ufs.h" | 50 | #include "ufs.h" |
| @@ -517,6 +518,12 @@ static int ufs_setattr(struct dentry *dentry, struct iattr *attr) | |||
| 517 | if (error) | 518 | if (error) |
| 518 | return error; | 519 | return error; |
| 519 | 520 | ||
| 521 | if ((ia_valid & ATTR_UID && attr->ia_uid != inode->i_uid) || | ||
| 522 | (ia_valid & ATTR_GID && attr->ia_gid != inode->i_gid)) { | ||
| 523 | error = vfs_dq_transfer(inode, attr) ? -EDQUOT : 0; | ||
| 524 | if (error) | ||
| 525 | return error; | ||
| 526 | } | ||
| 520 | if (ia_valid & ATTR_SIZE && | 527 | if (ia_valid & ATTR_SIZE && |
| 521 | attr->ia_size != i_size_read(inode)) { | 528 | attr->ia_size != i_size_read(inode)) { |
| 522 | loff_t old_i_size = inode->i_size; | 529 | loff_t old_i_size = inode->i_size; |
