Commit 69885683 authored by Mikulas Patocka's avatar Mikulas Patocka Committed by Alasdair G Kergon

dm raid1: wake kmirrord when requeueing delayed bios after remote recovery

The recent commit 7513c2a7 (dm raid1:
add is_remote_recovering hook for clusters) changed do_writes() to
update the ms->writes list but forgot to wake up kmirrord to process it.

The rule is that when anything is being added on ms->reads, ms->writes
or ms->failures and the list was empty before we must call
wakeup_mirrord (for immediate processing) or delayed_wake (for delayed
processing).  Otherwise the bios could sit on the list indefinitely.
Signed-off-by: default avatarMikulas Patocka <mpatocka@redhat.com>
CC: stable@kernel.org
Signed-off-by: default avatarAlasdair G Kergon <agk@redhat.com>
parent 4be3bd78
...@@ -638,6 +638,7 @@ static void do_writes(struct mirror_set *ms, struct bio_list *writes) ...@@ -638,6 +638,7 @@ static void do_writes(struct mirror_set *ms, struct bio_list *writes)
spin_lock_irq(&ms->lock); spin_lock_irq(&ms->lock);
bio_list_merge(&ms->writes, &requeue); bio_list_merge(&ms->writes, &requeue);
spin_unlock_irq(&ms->lock); spin_unlock_irq(&ms->lock);
delayed_wake(ms);
} }
/* /*
......
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