From 10b36f94bb3e10681acaf43938f25622baf4d6b9 Mon Sep 17 00:00:00 2001 From: Rob Landley Date: Thu, 10 Aug 2006 01:09:37 +0000 Subject: Patch from Chris Steel to fix mdev deleting device nodes. --- util-linux/mdev.c | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) (limited to 'util-linux') diff --git a/util-linux/mdev.c b/util-linux/mdev.c index 7c1223d..b6ca004 100644 --- a/util-linux/mdev.c +++ b/util-linux/mdev.c @@ -37,18 +37,19 @@ static void make_device(char *path, int delete) * because sscanf() will stop at the first nondigit, which \n is. We * also depend on path having writeable space after it. */ - strcat(path, "/dev"); - fd = open(path, O_RDONLY); - len = read(fd, temp + 1, 64); - *temp++ = 0; - close(fd); - if (len < 1) return; + if (!delete) { + strcat(path, "/dev"); + fd = open(path, O_RDONLY); + len = read(fd, temp + 1, 64); + *temp++ = 0; + close(fd); + if (len < 1) return; + } /* Determine device name, type, major and minor */ device_name = strrchr(path, '/') + 1; type = path[5]=='c' ? S_IFCHR : S_IFBLK; - if (sscanf(temp, "%d:%d", &major, &minor) != 2) return; /* If we have a config file, look up permissions for this device */ @@ -164,6 +165,7 @@ static void make_device(char *path, int delete) umask(0); if (!delete) { + if (sscanf(temp, "%d:%d", &major, &minor) != 2) return; if (mknod(device_name, mode | type, makedev(major, minor)) && errno != EEXIST) bb_perror_msg_and_die("mknod %s failed", device_name); -- cgit v1.1