__ufs_truncate_blocks(): avoid excessive dirtying of indirect blocks
authorAl Viro <viro@zeniv.linux.org.uk>
Fri, 19 Jun 2015 00:17:32 +0000 (20:17 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Mon, 6 Jul 2015 21:39:51 +0000 (17:39 -0400)
There's a case when an indirect block gets dirtied for no good
reason - when there's a hole starting in the middle of area
covered by it and spanning past its end, and truncate() is done
precisely to the beginning of the hole.

The block is obviously not modified at all - all removals happen
beyond it.  However, existing code ends up dirtying it just in
case.  It's trivial to fix and while it's not a real bug by any
stretch of imagination, it makes the damn thing harder to follow.

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/ufs/inode.c

index 424949f459c8cd801ce1df67cf90e4c87ecb6c7b..86cc1eea0fb23c86c97483c633ac7d4ede136358 100644 (file)
@@ -1251,10 +1251,8 @@ static void __ufs_truncate_blocks(struct inode *inode)
                        }
                        p = ubh_get_data_ptr(uspi, ubh[i], offsets[i + 1]);
                }
-               while (i--) {
-                       ubh_mark_buffer_dirty(ubh[i]);
+               while (i--)
                        free_branch_tail(inode, offsets[i + 1], ubh[i], depth - i - 1);
-               }
        }
        for (i = offsets[0]; i <= UFS_TIND_BLOCK; i++) {
                p = ufs_get_direct_data_ptr(uspi, ufsi, i);