diff options
author | Rob Landley <rob@landley.net> | 2006-08-10 01:09:37 +0000 |
---|---|---|
committer | Rob Landley <rob@landley.net> | 2006-08-10 01:09:37 +0000 |
commit | 10b36f94bb3e10681acaf43938f25622baf4d6b9 (patch) | |
tree | 486972a4553c75528863727f3de7e80040da40da /util-linux/mdev.c | |
parent | b988462d3e419559cf34c59d06323c59ba0a38df (diff) | |
download | busybox-w32-10b36f94bb3e10681acaf43938f25622baf4d6b9.tar.gz busybox-w32-10b36f94bb3e10681acaf43938f25622baf4d6b9.tar.bz2 busybox-w32-10b36f94bb3e10681acaf43938f25622baf4d6b9.zip |
Patch from Chris Steel to fix mdev deleting device nodes.
Diffstat (limited to 'util-linux/mdev.c')
-rw-r--r-- | util-linux/mdev.c | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/util-linux/mdev.c b/util-linux/mdev.c index 7c1223dcb..b6ca00409 100644 --- a/util-linux/mdev.c +++ b/util-linux/mdev.c | |||
@@ -37,18 +37,19 @@ static void make_device(char *path, int delete) | |||
37 | * because sscanf() will stop at the first nondigit, which \n is. We | 37 | * because sscanf() will stop at the first nondigit, which \n is. We |
38 | * also depend on path having writeable space after it. */ | 38 | * also depend on path having writeable space after it. */ |
39 | 39 | ||
40 | strcat(path, "/dev"); | 40 | if (!delete) { |
41 | fd = open(path, O_RDONLY); | 41 | strcat(path, "/dev"); |
42 | len = read(fd, temp + 1, 64); | 42 | fd = open(path, O_RDONLY); |
43 | *temp++ = 0; | 43 | len = read(fd, temp + 1, 64); |
44 | close(fd); | 44 | *temp++ = 0; |
45 | if (len < 1) return; | 45 | close(fd); |
46 | if (len < 1) return; | ||
47 | } | ||
46 | 48 | ||
47 | /* Determine device name, type, major and minor */ | 49 | /* Determine device name, type, major and minor */ |
48 | 50 | ||
49 | device_name = strrchr(path, '/') + 1; | 51 | device_name = strrchr(path, '/') + 1; |
50 | type = path[5]=='c' ? S_IFCHR : S_IFBLK; | 52 | type = path[5]=='c' ? S_IFCHR : S_IFBLK; |
51 | if (sscanf(temp, "%d:%d", &major, &minor) != 2) return; | ||
52 | 53 | ||
53 | /* If we have a config file, look up permissions for this device */ | 54 | /* If we have a config file, look up permissions for this device */ |
54 | 55 | ||
@@ -164,6 +165,7 @@ static void make_device(char *path, int delete) | |||
164 | 165 | ||
165 | umask(0); | 166 | umask(0); |
166 | if (!delete) { | 167 | if (!delete) { |
168 | if (sscanf(temp, "%d:%d", &major, &minor) != 2) return; | ||
167 | if (mknod(device_name, mode | type, makedev(major, minor)) && errno != EEXIST) | 169 | if (mknod(device_name, mode | type, makedev(major, minor)) && errno != EEXIST) |
168 | bb_perror_msg_and_die("mknod %s failed", device_name); | 170 | bb_perror_msg_and_die("mknod %s failed", device_name); |
169 | 171 | ||