diff options
author | NeilBrown <neilb@suse.de> | 2010-12-01 11:03:28 +1100 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2010-12-01 11:03:28 +1100 |
commit | 4c8214543f5cffefd093722227d2fb1fb81a683e (patch) | |
tree | 1cd69664d002a0afc2d4fe4d6d729084cc14396e /Create.c | |
parent | 97c9c10014f5c1392edcbd8da1870a4a68270ece (diff) |
Create: report failure if array cannot be started.
We weren't checking the result of writing 'active' to array_state
Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'Create.c')
-rw-r--r-- | Create.c | 15 |
1 files changed, 11 insertions, 4 deletions
@@ -872,20 +872,27 @@ int Create(struct supertype *st, char *mddev, wait_for(chosen_name, mdfd); } else if (runstop == 1 || subdevs >= raiddisks) { if (st->ss->external) { + int err; switch(level) { case LEVEL_LINEAR: case LEVEL_MULTIPATH: case 0: - sysfs_set_str(&info, NULL, "array_state", - "active"); + err = sysfs_set_str(&info, NULL, "array_state", + "active"); need_mdmon = 0; break; default: - sysfs_set_str(&info, NULL, "array_state", - "readonly"); + err = sysfs_set_str(&info, NULL, "array_state", + "readonly"); break; } sysfs_set_safemode(&info, safe_mode_delay); + if (err) { + fprintf(stderr, Name ": failed to" + " activate array.\n"); + ioctl(mdfd, STOP_ARRAY, NULL); + goto abort; + } } else { /* param is not actually used */ mdu_param_t param; |