From: Dan Williams Date: Sun, 12 Apr 2009 07:58:28 +0000 (-0700) Subject: imsm: defend against unsupported migrations (temporary) X-Git-Tag: mdadm-3.0-rc1~28^2~7 X-Git-Url: http://git.ipfire.org/?p=thirdparty%2Fmdadm.git;a=commitdiff_plain;h=1ce0101c9a16ab5ffa148a0b8f5c9ac0d7b81684 imsm: defend against unsupported migrations (temporary) Until support for higher order migrations (online capacity expansion, raid level migration, chunk size migration...) are implemented do not allow arrays in these states to be assembled. Signed-off-by: Dan Williams --- diff --git a/super-intel.c b/super-intel.c index 266d734d..41e91689 100644 --- a/super-intel.c +++ b/super-intel.c @@ -3355,6 +3355,18 @@ static struct mdinfo *container_content_imsm(struct supertype *st) struct mdinfo *this; int slot; + /* do not publish arrays that are in the middle of an + * unsupported migration + */ + if (dev->vol.migr_state && + (migr_type(dev) == MIGR_GEN_MIGR || + migr_type(dev) == MIGR_STATE_CHANGE)) { + fprintf(stderr, Name ": cannot assemble volume '%.16s':" + " unsupported migration in progress\n", + dev->volume); + continue; + } + this = malloc(sizeof(*this)); memset(this, 0, sizeof(*this)); this->next = rest; @@ -3401,7 +3413,7 @@ static struct mdinfo *container_content_imsm(struct supertype *st) info_d = malloc(sizeof(*info_d)); if (!info_d) { fprintf(stderr, Name ": failed to allocate disk" - " for volume %s\n", (char *) dev->volume); + " for volume %.16s\n", dev->volume); free(this); this = rest; break;