From: Ilya Dryomov Date: Sun, 3 Nov 2013 17:06:40 +0000 (+0200) Subject: Btrfs: fix __btrfs_start_workers retval X-Git-Tag: v3.13-rc1~13^2~12 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=ba69994a40b242bef26ab2683ea84aa29e2e429f;p=users%2Fwilly%2Flinux.git Btrfs: fix __btrfs_start_workers retval __btrfs_start_workers returns 0 in case it raced with btrfs_stop_workers and lost the race. This is wrong because worker in this case is not allowed to start and is in fact destroyed. Return -EINVAL instead. Signed-off-by: Ilya Dryomov Signed-off-by: Josef Bacik Signed-off-by: Chris Mason --- diff --git a/fs/btrfs/async-thread.c b/fs/btrfs/async-thread.c index 8aec751fa464..c1e0b0caf9cc 100644 --- a/fs/btrfs/async-thread.c +++ b/fs/btrfs/async-thread.c @@ -495,6 +495,7 @@ static int __btrfs_start_workers(struct btrfs_workers *workers) spin_lock_irq(&workers->lock); if (workers->stopping) { spin_unlock_irq(&workers->lock); + ret = -EINVAL; goto fail_kthread; } list_add_tail(&worker->worker_list, &workers->idle_list);