|
@@ -2595,8 +2595,10 @@ state_store(struct md_rdev *rdev, const char *buf, size_t len)
|
|
else
|
|
else
|
|
err = -EBUSY;
|
|
err = -EBUSY;
|
|
} else if (cmd_match(buf, "remove")) {
|
|
} else if (cmd_match(buf, "remove")) {
|
|
- clear_bit(Blocked, &rdev->flags);
|
|
|
|
- remove_and_add_spares(rdev->mddev, rdev);
|
|
|
|
|
|
+ if (rdev->mddev->pers) {
|
|
|
|
+ clear_bit(Blocked, &rdev->flags);
|
|
|
|
+ remove_and_add_spares(rdev->mddev, rdev);
|
|
|
|
+ }
|
|
if (rdev->raid_disk >= 0)
|
|
if (rdev->raid_disk >= 0)
|
|
err = -EBUSY;
|
|
err = -EBUSY;
|
|
else {
|
|
else {
|