]> git.ipfire.org Git - thirdparty/mdadm.git/blobdiff - Create.c
Tidyup automatic name choice for v-1 arrays
[thirdparty/mdadm.git] / Create.c
index 75db38235efe647e00b4b8cea99cd2c9075f39a0..ba6a8247444bf350e6d803e339e76ac9191b0293 100644 (file)
--- a/Create.c
+++ b/Create.c
@@ -30,6 +30,7 @@
 #include "mdadm.h"
 #include       "md_u.h"
 #include       "md_p.h"
+#include       <ctype.h>
 
 int Create(struct supertype *st, char *mddev, int mdfd,
           int chunk, int level, int layout, unsigned long long size, int raiddisks, int sparedisks,
@@ -399,9 +400,15 @@ int Create(struct supertype *st, char *mddev, int mdfd,
                name = strrchr(mddev, '/');
                if (name) {
                        name++;
-                       if (strncmp(name, "md", 2)==0 &&
-                           strlen(name) > 2 &&
+                       if (strncmp(name, "md_d", 4)==0 &&
+                           strlen(name) > 4 &&
+                           isdigit(name[4]) &&
                            (name-mddev) == 5 /* /dev/ */)
+                               name += 4;
+                       else if (strncmp(name, "md", 2)==0 &&
+                                strlen(name) > 2 &&
+                                isdigit(name[2]) &&
+                                (name-mddev) == 5 /* /dev/ */)
                                name += 2;
                }
        }