Unionfs: update our inode size correctly upon partial write
authorErez Zadok <ezk@cs.sunysb.edu>
Sun, 25 Nov 2007 18:34:04 +0000 (13:34 -0500)
committerErez Zadok <ezk@cs.sunysb.edu>
Sun, 6 Mar 2011 08:43:00 +0000 (03:43 -0500)
Signed-off-by: Erez Zadok <ezk@cs.sunysb.edu>
fs/unionfs/mmap.c

index ea5ef3d590102749b1a6b57cfd0907efc0ade5fa..8c07eed40cbd4121c995df508043734619e5f23a 100644 (file)
@@ -250,7 +250,6 @@ static int unionfs_commit_write(struct file *file, struct page *page,
        int err = -ENOMEM;
        struct inode *inode, *lower_inode;
        struct file *lower_file = NULL;
-       loff_t pos;
        unsigned bytes = to - from;
        char *page_data = NULL;
        mm_segment_t old_fs;
@@ -293,12 +292,8 @@ static int unionfs_commit_write(struct file *file, struct page *page,
        if (err < 0)
                goto out;
 
-       inode->i_blocks = lower_inode->i_blocks;
-       /* we may have to update i_size */
-       pos = page_offset(page) + to;
-       if (pos > i_size_read(inode))
-               i_size_write(inode, pos);
-       /* if vfs_write succeeded above, sync up our times */
+       /* if vfs_write succeeded above, sync up our times/sizes */
+       fsstack_copy_inode_size(inode, lower_inode);
        unionfs_copy_attr_times(inode);
        mark_inode_dirty_sync(inode);