|
@@ -1229,6 +1229,14 @@ static void do_async_commit(struct work_struct *work)
|
|
|
struct btrfs_async_commit *ac =
|
|
|
container_of(work, struct btrfs_async_commit, work.work);
|
|
|
|
|
|
+ /*
|
|
|
+ * We've got freeze protection passed with the transaction.
|
|
|
+ * Tell lockdep about it.
|
|
|
+ */
|
|
|
+ rwsem_acquire_read(
|
|
|
+ &ac->root->fs_info->sb->s_writers.lock_map[SB_FREEZE_FS-1],
|
|
|
+ 0, 1, _THIS_IP_);
|
|
|
+
|
|
|
btrfs_commit_transaction(ac->newtrans, ac->root);
|
|
|
kfree(ac);
|
|
|
}
|
|
@@ -1258,6 +1266,14 @@ int btrfs_commit_transaction_async(struct btrfs_trans_handle *trans,
|
|
|
atomic_inc(&cur_trans->use_count);
|
|
|
|
|
|
btrfs_end_transaction(trans, root);
|
|
|
+
|
|
|
+ /*
|
|
|
+ * Tell lockdep we've released the freeze rwsem, since the
|
|
|
+ * async commit thread will be the one to unlock it.
|
|
|
+ */
|
|
|
+ rwsem_release(&root->fs_info->sb->s_writers.lock_map[SB_FREEZE_FS-1],
|
|
|
+ 1, _THIS_IP_);
|
|
|
+
|
|
|
schedule_delayed_work(&ac->work, 0);
|
|
|
|
|
|
/* wait for transaction to start and unblock */
|