md: fix deadlock error in recent patch.
authorNeilBrown <neilb@suse.com>
Thu, 5 Oct 2017 05:23:16 +0000 (16:23 +1100)
committerShaohua Li <shli@fb.com>
Thu, 5 Oct 2017 17:09:22 +0000 (10:09 -0700)
commitd47c8ad261f787af22a220ffcc2d07afba809223
tree4f943cc91af125c4326526b88b9240a9adc00dae
parent9e66317d3c92ddaab330c125dfe9d06eee268aff
md: fix deadlock error in recent patch.

A recent patch aimed to cause md_write_start() to fail (rather than
block) when the mddev was suspending, so as to avoid deadlocks.
Unfortunately the test in wait_event() was wrong, and it didn't change
behaviour at all.

We wait_event() must wait until the metadata is written OR the array is
suspending.

Fixes: cc27b0c78c79 ("md: fix deadlock between mddev_suspend() and md_write_start()")
Cc: stable@vger.kernel.org
Reported-by: Xiao Ni <xni@redhat.com>
Signed-off-by: NeilBrown <neilb@suse.com>
Signed-off-by: Shaohua Li <shli@fb.com>
drivers/md/md.c