summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeil Brown <neilb@suse.de>2005-06-14 06:37:57 +0000
committerNeil Brown <neilb@suse.de>2005-06-14 06:37:57 +0000
commit173fc51539683030178a8f833281c787b1933ffd (patch)
tree87c64d23442729edcd62a2afbade24eed1c1b2b8
parentbd72c2b2b81926ee5dc13c96512bc8a8b6b77e6a (diff)
downloadmdadm-173fc51539683030178a8f833281c787b1933ffd.tar.gz
mdadm-173fc51539683030178a8f833281c787b1933ffd.tar.xz
mdadm-173fc51539683030178a8f833281c787b1933ffd.zip
Add device files created with --auto to list of known device files.
Signed-off-by: Neil Brown <neilb@cse.unsw.edu.au>
-rw-r--r--mdadm.h13
-rw-r--r--mdopen.c4
-rw-r--r--util.c23
3 files changed, 30 insertions, 10 deletions
diff --git a/mdadm.h b/mdadm.h
index 41e6702..bb12477 100644
--- a/mdadm.h
+++ b/mdadm.h
@@ -200,6 +200,19 @@ struct supertype {
extern struct supertype *super_by_version(int vers, int minor);
extern struct supertype *guess_super(int fd);
+#ifdef UCLIBC
+ struct FTW {};
+# define FTW_PHYS 1
+#else
+# define __USE_XOPEN_EXTENDED
+# include <ftw.h>
+# ifdef __dietlibc__
+# define FTW_PHYS 1
+# endif
+#endif
+
+extern int add_dev(const char *name, const struct stat *stb, int flag, struct FTW *s);
+
extern int Manage_ro(char *devname, int fd, int readonly);
extern int Manage_runstop(char *devname, int fd, int runstop, int quiet);
diff --git a/mdopen.c b/mdopen.c
index 721d74a..9309fbd 100644
--- a/mdopen.c
+++ b/mdopen.c
@@ -66,6 +66,8 @@ void make_parts(char *dev, int cnt)
mknod(name, S_IFBLK | 0600, makedev(major, minor+i));
chown(name, stb2.st_uid, stb2.st_gid);
chmod(name, stb2.st_mode & 07777);
+ stat(name, &stb2);
+ add_dev(name, &stb2, 0, NULL);
}
}
@@ -205,6 +207,8 @@ int open_mddev(char *dev, int autof)
chown(dev, stb.st_uid, stb.st_gid);
chmod(dev, stb.st_mode & 07777);
}
+ stat(dev, &stb);
+ add_dev(dev, &stb, 0, NULL);
make_parts(dev,autof);
}
}
diff --git a/util.c b/util.c
index f3f6446..4445b16 100644
--- a/util.c
+++ b/util.c
@@ -313,6 +313,9 @@ struct devmap {
int devlist_ready = 0;
#ifdef UCLIBC
+int add_dev(const char *name, const struct stat *stb, int flag, struct FTW *s)
+{
+}
char *map_dev(int major, int minor)
{
#if 0
@@ -322,15 +325,19 @@ char *map_dev(int major, int minor)
return NULL;
}
#else
-#define __USE_XOPEN_EXTENDED
-#include <ftw.h>
+#ifdef __dietlibc__
+int add_dev_1(const char *name, const struct stat *stb, int flag)
+{
+ return add_dev(name, stb, flag, NULL);
+}
+int nftw(const char *path, int (*han)(const char *name, const struct stat *stb, int flag, struct FTW *s), int nopenfd, int flags)
+{
+ ftw(path, add_dev_1, nopenfd);
+}
+#endif
-#ifndef __dietlibc__
int add_dev(const char *name, const struct stat *stb, int flag, struct FTW *s)
-#else
-int add_dev(const char *name, const struct stat *stb, int flag)
-#endif
{
if ((stb->st_mode&S_IFMT)== S_IFBLK) {
char *n = strdup(name);
@@ -358,11 +365,7 @@ char *map_dev(int major, int minor)
struct devmap *p;
char *std = NULL, *nonstd=NULL;
if (!devlist_ready) {
-#ifndef __dietlibc__
nftw("/dev", add_dev, 10, FTW_PHYS);
-#else
- ftw("/dev", add_dev, 10);
-#endif
devlist_ready=1;
}