aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/tree-log.c
diff options
context:
space:
mode:
authorLiu Bo <bo.li.liu@oracle.com>2012-11-01 02:38:47 -0400
committerJosef Bacik <jbacik@fusionio.com>2012-12-12 17:15:18 -0500
commit183f37fa3503332740c76f1b493f4304ec889358 (patch)
tree8b3eb78cb9b62da3eebca87cf3e883ebee70543a /fs/btrfs/tree-log.c
parent292fd7fc39aa06668f3a8db546714e727120cb3e (diff)
Btrfs: do not log extents when we only log new names
When we log new names, we need to log just enough to recreate the inode during log replay, and there is no need to log extents along with it. This actually fixes a bug revealed by xfstests 241, where it shows that we're logging some extents that have not updated metadata, so we don't get proper EXTENT_DATA items to be copied to log tree. Signed-off-by: Liu Bo <bo.li.liu@oracle.com> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs/btrfs/tree-log.c')
-rw-r--r--fs/btrfs/tree-log.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/btrfs/tree-log.c b/fs/btrfs/tree-log.c
index 81e407d9677a..4ec41ecb4d65 100644
--- a/fs/btrfs/tree-log.c
+++ b/fs/btrfs/tree-log.c
@@ -3435,7 +3435,8 @@ static int btrfs_log_inode(struct btrfs_trans_handle *trans,
3435 ret = btrfs_truncate_inode_items(trans, log, 3435 ret = btrfs_truncate_inode_items(trans, log,
3436 inode, 0, 0); 3436 inode, 0, 0);
3437 } else { 3437 } else {
3438 fast_search = true; 3438 if (inode_only == LOG_INODE_ALL)
3439 fast_search = true;
3439 max_key.type = BTRFS_XATTR_ITEM_KEY; 3440 max_key.type = BTRFS_XATTR_ITEM_KEY;
3440 ret = drop_objectid_items(trans, log, path, ino, 3441 ret = drop_objectid_items(trans, log, path, ino,
3441 BTRFS_XATTR_ITEM_KEY); 3442 BTRFS_XATTR_ITEM_KEY);