]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blobdiff - fs/ufs/truncate.c
quota: unify quota init condition in setattr
[mirror_ubuntu-artful-kernel.git] / fs / ufs / truncate.c
index ee8db3e77bfedd74f067f0d7352bc464f7703482..f294c44577dced33302a121561a8c65815da4a8c 100644 (file)
@@ -518,18 +518,18 @@ int ufs_setattr(struct dentry *dentry, struct iattr *attr)
        if (error)
                return error;
 
+       if (is_quota_modification(inode, attr))
+               dquot_initialize(inode);
+
        if ((ia_valid & ATTR_UID && attr->ia_uid != inode->i_uid) ||
            (ia_valid & ATTR_GID && attr->ia_gid != inode->i_gid)) {
                error = dquot_transfer(inode, attr);
                if (error)
                        return error;
        }
-       if (ia_valid & ATTR_SIZE &&
-           attr->ia_size != i_size_read(inode)) {
+       if (ia_valid & ATTR_SIZE && attr->ia_size != inode->i_size) {
                loff_t old_i_size = inode->i_size;
 
-               dquot_initialize(inode);
-
                error = vmtruncate(inode, attr->ia_size);
                if (error)
                        return error;