Take dirtying the inode to callers of ext2_free_blocks()
authorAl Viro <viro@zeniv.linux.org.uk>
Wed, 21 Jul 2010 21:19:42 +0000 (01:19 +0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Mon, 9 Aug 2010 20:47:55 +0000 (16:47 -0400)
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/ext2/balloc.c
fs/ext2/inode.c
fs/ext2/xattr.c

index db69c1206f13cf87853689badadd4c957734505f..c6c684b44ea1ca6386105496c3f5a349987fef40 100644 (file)
@@ -572,7 +572,6 @@ error_return:
        brelse(bitmap_bh);
        release_blocks(sb, freed);
        dquot_free_block_nodirty(inode, freed);
-       mark_inode_dirty(inode);
 }
 
 /**
index 069620b30d4d87a800573abfe2b47f69bb344305..e8af26dd67156a59b9101b97c1abb8e1acfd5fd9 100644 (file)
@@ -423,6 +423,8 @@ static int ext2_alloc_blocks(struct inode *inode,
 failed_out:
        for (i = 0; i <index; i++)
                ext2_free_blocks(inode, new_blocks[i], 1);
+       if (index)
+               mark_inode_dirty(inode);
        return ret;
 }
 
@@ -993,8 +995,8 @@ static inline void ext2_free_data(struct inode *inode, __le32 *p, __le32 *q)
                        else if (block_to_free == nr - count)
                                count++;
                        else {
-                               mark_inode_dirty(inode);
                                ext2_free_blocks (inode, block_to_free, count);
+                               mark_inode_dirty(inode);
                        free_this:
                                block_to_free = nr;
                                count = 1;
@@ -1002,8 +1004,8 @@ static inline void ext2_free_data(struct inode *inode, __le32 *p, __le32 *q)
                }
        }
        if (count > 0) {
-               mark_inode_dirty(inode);
                ext2_free_blocks (inode, block_to_free, count);
+               mark_inode_dirty(inode);
        }
 }
 
index 0fa24e814d8a7a5816dc8560448407e880998aae..25ff041058a74147bcd2ea12ff784700bd19132c 100644 (file)
@@ -674,6 +674,7 @@ ext2_xattr_set2(struct inode *inode, struct buffer_head *old_bh,
                        new_bh = sb_getblk(sb, block);
                        if (!new_bh) {
                                ext2_free_blocks(inode, block, 1);
+                               mark_inode_dirty(inode);
                                error = -EIO;
                                goto cleanup;
                        }
@@ -729,6 +730,7 @@ ext2_xattr_set2(struct inode *inode, struct buffer_head *old_bh,
                                mb_cache_entry_free(ce);
                        ea_bdebug(old_bh, "freeing");
                        ext2_free_blocks(inode, old_bh->b_blocknr, 1);
+                       mark_inode_dirty(inode);
                        /* We let our caller release old_bh, so we
                         * need to duplicate the buffer before. */
                        get_bh(old_bh);
@@ -789,6 +791,7 @@ ext2_xattr_delete_inode(struct inode *inode)
                if (ce)
                        mb_cache_entry_free(ce);
                ext2_free_blocks(inode, EXT2_I(inode)->i_file_acl, 1);
+               mark_inode_dirty(inode);
                get_bh(bh);
                bforget(bh);
                unlock_buffer(bh);