aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/disk-io.c
diff options
context:
space:
mode:
authorJosef Bacik <jbacik@fusionio.com>2012-10-12 15:27:49 -0400
committerJosef Bacik <jbacik@fusionio.com>2013-02-20 09:37:04 -0500
commit2ab28f322f9896782da904f5942f3873432addc8 (patch)
treed8d136d90b96f96d63262f8d2eb11680bed80aab /fs/btrfs/disk-io.c
parentdfd79829b709af3c2ac55951353a874ae89f41c3 (diff)
Btrfs: wait on ordered extents at the last possible moment
Since we don't actually copy the extent information from the source tree in the fast case we don't need to wait for ordered io to be completed in order to fsync, we just need to wait for the io to be completed. So when we're logging our file just attach all of the ordered extents to the log, and then when the log syncs just wait for IO_DONE on the ordered extents and then write the super. Thanks, Signed-off-by: Josef Bacik <jbacik@fusionio.com>
Diffstat (limited to 'fs/btrfs/disk-io.c')
-rw-r--r--fs/btrfs/disk-io.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c
index a762f9137610..1db8a9938829 100644
--- a/fs/btrfs/disk-io.c
+++ b/fs/btrfs/disk-io.c
@@ -1178,9 +1178,13 @@ static void __setup_root(u32 nodesize, u32 leafsize, u32 sectorsize,
1178 1178
1179 INIT_LIST_HEAD(&root->dirty_list); 1179 INIT_LIST_HEAD(&root->dirty_list);
1180 INIT_LIST_HEAD(&root->root_list); 1180 INIT_LIST_HEAD(&root->root_list);
1181 INIT_LIST_HEAD(&root->logged_list[0]);
1182 INIT_LIST_HEAD(&root->logged_list[1]);
1181 spin_lock_init(&root->orphan_lock); 1183 spin_lock_init(&root->orphan_lock);
1182 spin_lock_init(&root->inode_lock); 1184 spin_lock_init(&root->inode_lock);
1183 spin_lock_init(&root->accounting_lock); 1185 spin_lock_init(&root->accounting_lock);
1186 spin_lock_init(&root->log_extents_lock[0]);
1187 spin_lock_init(&root->log_extents_lock[1]);
1184 mutex_init(&root->objectid_mutex); 1188 mutex_init(&root->objectid_mutex);
1185 mutex_init(&root->log_mutex); 1189 mutex_init(&root->log_mutex);
1186 init_waitqueue_head(&root->log_writer_wait); 1190 init_waitqueue_head(&root->log_writer_wait);