From: Sage Weil Date: Tue, 29 Sep 2009 22:38:44 +0000 (-0400) Subject: Btrfs: fix deadlock with free space handling and user transactions X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=dd7e0b7b02ccff73b87032e20fc5b4f2c1cfcc14;p=openwrt%2Fstaging%2Fblogic.git Btrfs: fix deadlock with free space handling and user transactions If an ioctl-initiated transaction is open, we can't force a commit during the free space checks in order to free up pinned extents or else we deadlock. Just ENOSPC instead. A more satisfying solution that reserves space for the entire user transaction up front is forthcoming... Signed-off-by: Sage Weil Signed-off-by: Chris Mason --- diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index a4b2b03cd682..d119c0388af1 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c @@ -3168,7 +3168,7 @@ alloc: spin_unlock(&data_sinfo->lock); /* commit the current transaction and try again */ - if (!committed) { + if (!committed && !root->fs_info->open_ioctl_trans) { committed = 1; trans = btrfs_join_transaction(root, 1); if (!trans)