[JFFS2] Set i_blocks when truncating files
authorDavid Woodhouse <dwmw2@infradead.org>
Mon, 25 Feb 2008 15:20:50 +0000 (15:20 +0000)
committerDavid Woodhouse <dwmw2@infradead.org>
Mon, 25 Feb 2008 15:20:50 +0000 (15:20 +0000)
Addresses OLPC trac #6480

Signed-off-by: David Woodhouse <dwmw2@infradead.org>
fs/jffs2/fs.c

index e26ea78c7892f7a4f157819a06e052add03057fd..3f49562dc508219c04b2d9cc719e163c58729d9a 100644 (file)
@@ -149,6 +149,7 @@ int jffs2_do_setattr (struct inode *inode, struct iattr *iattr)
        if (ivalid & ATTR_SIZE && inode->i_size < iattr->ia_size) {
                jffs2_add_full_dnode_to_inode(c, f, new_metadata);
                inode->i_size = iattr->ia_size;
+               inode->i_blocks = (inode->i_size + 511) >> 9;
                f->metadata = NULL;
        } else {
                f->metadata = new_metadata;
@@ -167,8 +168,10 @@ int jffs2_do_setattr (struct inode *inode, struct iattr *iattr)
           We are protected from a simultaneous write() extending i_size
           back past iattr->ia_size, because do_truncate() holds the
           generic inode semaphore. */
-       if (ivalid & ATTR_SIZE && inode->i_size > iattr->ia_size)
-               vmtruncate(inode, iattr->ia_size);
+       if (ivalid & ATTR_SIZE && inode->i_size > iattr->ia_size) {
+               vmtruncate(inode, iattr->ia_size);      
+               inode->i_blocks = (inode->i_size + 511) >> 9;
+       }       
 
        return 0;
 }