Commit 7a3ab908 authored by Dan Williams's avatar Dan Williams Committed by NeilBrown

md/raid5: add missing call to schedule() after prepare_to_wait()

In the unlikely event that reshape progresses past the current request
while it is waiting for a stripe we need to schedule() before retrying
for 2 reasons:
1/ Prevent list corruption from duplicated list_add() calls without
   intervening list_del().
2/ Give the reshape code a chance to make some progress to resolve the
   conflict.

Cc: <stable@kernel.org>
Signed-off-by: default avatarDan Williams <dan.j.williams@intel.com>
Signed-off-by: default avatarNeilBrown <neilb@suse.de>
parent 495d3573
...@@ -3695,6 +3695,7 @@ static int make_request(struct request_queue *q, struct bio * bi) ...@@ -3695,6 +3695,7 @@ static int make_request(struct request_queue *q, struct bio * bi)
spin_unlock_irq(&conf->device_lock); spin_unlock_irq(&conf->device_lock);
if (must_retry) { if (must_retry) {
release_stripe(sh); release_stripe(sh);
schedule();
goto retry; goto retry;
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment