|
@@ -3834,7 +3834,7 @@ array_state_store(struct mddev *mddev, const char *buf, size_t len)
|
|
|
err = -EBUSY;
|
|
|
}
|
|
|
spin_unlock(&mddev->lock);
|
|
|
- return err;
|
|
|
+ return err ?: len;
|
|
|
}
|
|
|
err = mddev_lock(mddev);
|
|
|
if (err)
|
|
@@ -4217,13 +4217,14 @@ action_store(struct mddev *mddev, const char *page, size_t len)
|
|
|
set_bit(MD_RECOVERY_FROZEN, &mddev->recovery);
|
|
|
else
|
|
|
clear_bit(MD_RECOVERY_FROZEN, &mddev->recovery);
|
|
|
- flush_workqueue(md_misc_wq);
|
|
|
- if (mddev->sync_thread) {
|
|
|
- set_bit(MD_RECOVERY_INTR, &mddev->recovery);
|
|
|
- if (mddev_lock(mddev) == 0) {
|
|
|
+ if (test_bit(MD_RECOVERY_RUNNING, &mddev->recovery) &&
|
|
|
+ mddev_lock(mddev) == 0) {
|
|
|
+ flush_workqueue(md_misc_wq);
|
|
|
+ if (mddev->sync_thread) {
|
|
|
+ set_bit(MD_RECOVERY_INTR, &mddev->recovery);
|
|
|
md_reap_sync_thread(mddev);
|
|
|
- mddev_unlock(mddev);
|
|
|
}
|
|
|
+ mddev_unlock(mddev);
|
|
|
}
|
|
|
} else if (test_bit(MD_RECOVERY_RUNNING, &mddev->recovery) ||
|
|
|
test_bit(MD_RECOVERY_NEEDED, &mddev->recovery))
|
|
@@ -8261,6 +8262,7 @@ void md_reap_sync_thread(struct mddev *mddev)
|
|
|
if (mddev_is_clustered(mddev))
|
|
|
md_cluster_ops->metadata_update_finish(mddev);
|
|
|
clear_bit(MD_RECOVERY_RUNNING, &mddev->recovery);
|
|
|
+ clear_bit(MD_RECOVERY_DONE, &mddev->recovery);
|
|
|
clear_bit(MD_RECOVERY_SYNC, &mddev->recovery);
|
|
|
clear_bit(MD_RECOVERY_RESHAPE, &mddev->recovery);
|
|
|
clear_bit(MD_RECOVERY_REQUESTED, &mddev->recovery);
|