aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/transaction.c
diff options
context:
space:
mode:
authorMiao Xie <miaox@cn.fujitsu.com>2012-11-26 03:41:29 -0500
committerChris Mason <chris.mason@fusionio.com>2012-12-16 20:46:08 -0500
commitff7c1d33551862c86f7737fe88edc3e499d291e6 (patch)
treec6566284d5c411645a6e938f2659d478a801ab1b /fs/btrfs/transaction.c
parent9a8c28bec1b40e934ed28149b7eaa7d2fafed92d (diff)
Btrfs: don't start a new transaction when starting sync
If there is no running transaction in the fs, we needn't start a new one when we want to start sync. Signed-off-by: Miao Xie <miaox@cn.fujitsu.com> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs/btrfs/transaction.c')
-rw-r--r--fs/btrfs/transaction.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c
index bcc6b65be3b0..8db401fa2f8f 100644
--- a/fs/btrfs/transaction.c
+++ b/fs/btrfs/transaction.c
@@ -1307,9 +1307,10 @@ static void do_async_commit(struct work_struct *work)
1307 * We've got freeze protection passed with the transaction. 1307 * We've got freeze protection passed with the transaction.
1308 * Tell lockdep about it. 1308 * Tell lockdep about it.
1309 */ 1309 */
1310 rwsem_acquire_read( 1310 if (ac->newtrans->type < TRANS_JOIN_NOLOCK)
1311 &ac->root->fs_info->sb->s_writers.lock_map[SB_FREEZE_FS-1], 1311 rwsem_acquire_read(
1312 0, 1, _THIS_IP_); 1312 &ac->root->fs_info->sb->s_writers.lock_map[SB_FREEZE_FS-1],
1313 0, 1, _THIS_IP_);
1313 1314
1314 current->journal_info = ac->newtrans; 1315 current->journal_info = ac->newtrans;
1315 1316
@@ -1347,8 +1348,10 @@ int btrfs_commit_transaction_async(struct btrfs_trans_handle *trans,
1347 * Tell lockdep we've released the freeze rwsem, since the 1348 * Tell lockdep we've released the freeze rwsem, since the
1348 * async commit thread will be the one to unlock it. 1349 * async commit thread will be the one to unlock it.
1349 */ 1350 */
1350 rwsem_release(&root->fs_info->sb->s_writers.lock_map[SB_FREEZE_FS-1], 1351 if (trans->type < TRANS_JOIN_NOLOCK)
1351 1, _THIS_IP_); 1352 rwsem_release(
1353 &root->fs_info->sb->s_writers.lock_map[SB_FREEZE_FS-1],
1354 1, _THIS_IP_);
1352 1355
1353 schedule_delayed_work(&ac->work, 0); 1356 schedule_delayed_work(&ac->work, 0);
1354 1357