aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHannes Reinecke <hare@suse.de>2013-04-02 02:38:55 -0400
committerNeilBrown <neilb@suse.de>2013-06-13 18:10:26 -0400
commit90f5f7ad4f38d67626b0c220a0ac390603e0bded (patch)
tree740a41f4c451e0ee0f65f4fb3ca3120bce8b4189
parent3f6bbd3ffd7b733dd705e494663e5761aa2cb9c1 (diff)
md: Wait for md_check_recovery before attempting device removal.
When a device has failed, it needs to be removed from the personality module before it can be removed from the array as a whole. The first step is performed by md_check_recovery() which is called from the raid management thread. So when a HOT_REMOVE ioctl arrives, wait briefly for md_check_recovery to have run. This increases the chance that the ioctl will succeed. Signed-off-by: Hannes Reinecke <hare@suse.de> Signed-off-by: Neil Brown <nfbrown@suse.de>
-rw-r--r--drivers/md/md.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c
index 9b82377a833b..3b25b72ef0b6 100644
--- a/drivers/md/md.c
+++ b/drivers/md/md.c
@@ -6405,6 +6405,12 @@ static int md_ioctl(struct block_device *bdev, fmode_t mode,
6405 /* need to ensure md_delayed_delete() has completed */ 6405 /* need to ensure md_delayed_delete() has completed */
6406 flush_workqueue(md_misc_wq); 6406 flush_workqueue(md_misc_wq);
6407 6407
6408 if (cmd == HOT_REMOVE_DISK)
6409 /* need to ensure recovery thread has run */
6410 wait_event_interruptible_timeout(mddev->sb_wait,
6411 !test_bit(MD_RECOVERY_NEEDED,
6412 &mddev->flags),
6413 msecs_to_jiffies(5000));
6408 err = mddev_lock(mddev); 6414 err = mddev_lock(mddev);
6409 if (err) { 6415 if (err) {
6410 printk(KERN_INFO 6416 printk(KERN_INFO
@@ -7892,6 +7898,8 @@ void md_check_recovery(struct mddev *mddev)
7892 md_new_event(mddev); 7898 md_new_event(mddev);
7893 } 7899 }
7894 unlock: 7900 unlock:
7901 wake_up(&mddev->sb_wait);
7902
7895 if (!mddev->sync_thread) { 7903 if (!mddev->sync_thread) {
7896 clear_bit(MD_RECOVERY_RUNNING, &mddev->recovery); 7904 clear_bit(MD_RECOVERY_RUNNING, &mddev->recovery);
7897 if (test_and_clear_bit(MD_RECOVERY_RECOVER, 7905 if (test_and_clear_bit(MD_RECOVERY_RECOVER,