diff options
author | Sage Weil <sage@newdream.net> | 2009-07-24 13:17:44 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@oracle.com> | 2009-07-24 13:17:44 -0400 |
commit | ebecd3d9d2adba144c15f1d35c78e0c26ead1bfd (patch) | |
tree | 605fdb3fcc3c9543d0a69987fcfd89ad3c7fb144 | |
parent | d717aa1d31c36cb56059e97966cb76f0be021969 (diff) |
Btrfs: make flushoncommit mount option correctly wait on ordered_extents
The commit_transaction call to wait_ordered_extents when snap_pending
passes nocow_only=1 to process only NOCOW or PREALLOC extents. This isn't
correct for the 'flushoncommit' mode, as it skips extents we just started
IO on in start_delalloc_inodes.
So, in the flushoncommit case, wait on all ordered extents. Otherwise,
only pass the nocow_only flag to wait_ordered_extents if snap_pending.
Signed-off-by: Sage Weil <sage@newdream.net>
Signed-off-by: Chris Mason <chris.mason@oracle.com>
-rw-r--r-- | fs/btrfs/transaction.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c index 32454d1c566f..e51d2bc532f8 100644 --- a/fs/btrfs/transaction.c +++ b/fs/btrfs/transaction.c | |||
@@ -942,9 +942,11 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans, | |||
942 | 942 | ||
943 | mutex_unlock(&root->fs_info->trans_mutex); | 943 | mutex_unlock(&root->fs_info->trans_mutex); |
944 | 944 | ||
945 | if (flush_on_commit || snap_pending) { | 945 | if (flush_on_commit) { |
946 | if (flush_on_commit) | 946 | btrfs_start_delalloc_inodes(root); |
947 | btrfs_start_delalloc_inodes(root); | 947 | ret = btrfs_wait_ordered_extents(root, 0); |
948 | BUG_ON(ret); | ||
949 | } else if (snap_pending) { | ||
948 | ret = btrfs_wait_ordered_extents(root, 1); | 950 | ret = btrfs_wait_ordered_extents(root, 1); |
949 | BUG_ON(ret); | 951 | BUG_ON(ret); |
950 | } | 952 | } |