- array.spare_disks=sparedisks;
- array.failed_disks=missing_disks;
- array.nr_disks = array.working_disks + array.failed_disks;
- array.layout = layout;
- array.chunk_size = chunk*1024;
- array.major_version = st->ss->major;
-
- if (!st->ss->init_super(st, &super, &array, size, name))
+ info.array.spare_disks=sparedisks;
+ info.array.failed_disks=missing_disks;
+ info.array.nr_disks = info.array.working_disks
+ + info.array.failed_disks;
+ info.array.layout = layout;
+ info.array.chunk_size = chunk*1024;
+ info.array.major_version = st->ss->major;
+
+ if (name == NULL || *name == 0) {
+ /* base name on mddev */
+ /* /dev/md0 -> 0
+ * /dev/md_d0 -> d0
+ * /dev/md/1 -> 1
+ * /dev/md/d1 -> d1
+ * /dev/md/home -> home
+ * /dev/mdhome -> home
+ */
+ name = strrchr(mddev, '/');
+ if (name) {
+ name++;
+ if (strncmp(name, "md_d", 4)==0 &&
+ strlen(name) > 4 &&
+ isdigit(name[4]) &&
+ (name-mddev) == 5 /* /dev/ */)
+ name += 3;
+ else if (strncmp(name, "md", 2)==0 &&
+ strlen(name) > 2 &&
+ isdigit(name[2]) &&
+ (name-mddev) == 5 /* /dev/ */)
+ name += 2;
+ }
+ }
+ if (!st->ss->init_super(st, &info.array, size, name, homehost, uuid))