Commit 80fab1d7 authored by Andre Noll's avatar Andre Noll Committed by Neil Brown

md: Simplify restart_array().

Signed-off-by: default avatarAndre Noll <maan@systemlinux.org>
Signed-off-by: default avatarNeil Brown <neilb@suse.de>
parent ebc24337
...@@ -3766,40 +3766,25 @@ static int do_md_run(mddev_t * mddev) ...@@ -3766,40 +3766,25 @@ static int do_md_run(mddev_t * mddev)
static int restart_array(mddev_t *mddev) static int restart_array(mddev_t *mddev)
{ {
struct gendisk *disk = mddev->gendisk; struct gendisk *disk = mddev->gendisk;
int err;
/* /* Complain if it has no devices */
* Complain if it has no devices
*/
err = -ENXIO;
if (list_empty(&mddev->disks)) if (list_empty(&mddev->disks))
goto out; return -ENXIO;
if (!mddev->pers)
if (mddev->pers) { return -EINVAL;
err = -EBUSY;
if (!mddev->ro) if (!mddev->ro)
goto out; return -EBUSY;
mddev->safemode = 0; mddev->safemode = 0;
mddev->ro = 0; mddev->ro = 0;
set_disk_ro(disk, 0); set_disk_ro(disk, 0);
printk(KERN_INFO "md: %s switched to read-write mode.\n", printk(KERN_INFO "md: %s switched to read-write mode.\n",
mdname(mddev)); mdname(mddev));
/* /* Kick recovery or resync if necessary */
* Kick recovery or resync if necessary
*/
set_bit(MD_RECOVERY_NEEDED, &mddev->recovery); set_bit(MD_RECOVERY_NEEDED, &mddev->recovery);
md_wakeup_thread(mddev->thread); md_wakeup_thread(mddev->thread);
md_wakeup_thread(mddev->sync_thread); md_wakeup_thread(mddev->sync_thread);
err = 0;
sysfs_notify(&mddev->kobj, NULL, "array_state"); sysfs_notify(&mddev->kobj, NULL, "array_state");
return 0;
} else
err = -EINVAL;
out:
return err;
} }
/* similar to deny_write_access, but accounts for our holding a reference /* similar to deny_write_access, but accounts for our holding a reference
......
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