diff options
author | Chris Mason <chris.mason@oracle.com> | 2011-06-17 14:16:13 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@oracle.com> | 2011-06-17 14:16:13 -0400 |
commit | e038dca803423bb7a3fa9a162b7dcc225efe9bf9 (patch) | |
tree | efd5d76b77f21b4a9e570f2cb5bed9f95970f7a0 /fs/btrfs/transaction.c | |
parent | 7585717f304f5ed005cc4ad933a69aab3efbd136 (diff) | |
parent | ed0ca14021e5ae3147602128641aa7f742ab227c (diff) |
Merge branch 'for-chris' of git://git.kernel.org/pub/scm/linux/kernel/git/josef/btrfs-work into for-linus
Conflicts:
fs/btrfs/transaction.c
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/transaction.c')
-rw-r--r-- | fs/btrfs/transaction.c | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c index 833996a0c628..c073d85e14f3 100644 --- a/fs/btrfs/transaction.c +++ b/fs/btrfs/transaction.c | |||
@@ -1298,13 +1298,21 @@ int btrfs_commit_transaction(struct btrfs_trans_handle *trans, | |||
1298 | schedule_timeout(1); | 1298 | schedule_timeout(1); |
1299 | 1299 | ||
1300 | finish_wait(&cur_trans->writer_wait, &wait); | 1300 | finish_wait(&cur_trans->writer_wait, &wait); |
1301 | spin_lock(&root->fs_info->trans_lock); | ||
1302 | root->fs_info->trans_no_join = 1; | ||
1303 | spin_unlock(&root->fs_info->trans_lock); | ||
1304 | } while (atomic_read(&cur_trans->num_writers) > 1 || | 1301 | } while (atomic_read(&cur_trans->num_writers) > 1 || |
1305 | (should_grow && cur_trans->num_joined != joined)); | 1302 | (should_grow && cur_trans->num_joined != joined)); |
1306 | 1303 | ||
1307 | /* | 1304 | /* |
1305 | * Ok now we need to make sure to block out any other joins while we | ||
1306 | * commit the transaction. We could have started a join before setting | ||
1307 | * no_join so make sure to wait for num_writers to == 1 again. | ||
1308 | */ | ||
1309 | spin_lock(&root->fs_info->trans_lock); | ||
1310 | root->fs_info->trans_no_join = 1; | ||
1311 | spin_unlock(&root->fs_info->trans_lock); | ||
1312 | wait_event(cur_trans->writer_wait, | ||
1313 | atomic_read(&cur_trans->num_writers) == 1); | ||
1314 | |||
1315 | /* | ||
1308 | * the reloc mutex makes sure that we stop | 1316 | * the reloc mutex makes sure that we stop |
1309 | * the balancing code from coming in and moving | 1317 | * the balancing code from coming in and moving |
1310 | * extents around in the middle of the commit | 1318 | * extents around in the middle of the commit |