diff options
author | Miao Xie <miaox@cn.fujitsu.com> | 2012-11-26 03:41:29 -0500 |
---|---|---|
committer | Chris Mason <chris.mason@fusionio.com> | 2012-12-16 20:46:08 -0500 |
commit | ff7c1d33551862c86f7737fe88edc3e499d291e6 (patch) | |
tree | c6566284d5c411645a6e938f2659d478a801ab1b /fs/btrfs/transaction.c | |
parent | 9a8c28bec1b40e934ed28149b7eaa7d2fafed92d (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.c | 13 |
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 | ||