summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>2005-11-14 17:17:12 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>2005-11-14 17:17:12 +0000
commit5900ee260c1b56a45ab9c25a9e882f89200e02d1 (patch)
tree61429ef543fef97981efcf45be1ce8057fe4857f
parentb12d0890e79a61439c2ddaa8cebdb5b984a96503 (diff)
use asprintf
and do fstat() on the opened fd, instead of stat() before open() from dhill@mindcry.org
-rw-r--r--sbin/raidctl/raidctl.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/sbin/raidctl/raidctl.c b/sbin/raidctl/raidctl.c
index 01f31748596..c1cf113bc42 100644
--- a/sbin/raidctl/raidctl.c
+++ b/sbin/raidctl/raidctl.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: raidctl.c,v 1.23 2004/07/17 02:14:33 deraadt Exp $ */
+/* $OpenBSD: raidctl.c,v 1.24 2005/11/14 17:17:11 deraadt Exp $ */
/* $NetBSD: raidctl.c,v 1.27 2001/07/10 01:30:52 lukem Exp $ */
/*-
@@ -1137,8 +1137,10 @@ open_device(fdidpair **devfd, char *name)
nfd = get_all_devices(&devname, "raid");
} else {
nfd = 1;
- devname = malloc(sizeof(void*));
- devname[0] = malloc(PATH_MAX);
+ if ((devname = malloc(sizeof(void*))) == NULL)
+ err(1, "malloc");
+ if ((devname[0] = malloc(PATH_MAX)) == NULL)
+ err(1, "malloc");
if ((name[0] == '/') || (name[0] == '.')) {
/* they've (apparently) given a full path... */
@@ -1159,13 +1161,13 @@ open_device(fdidpair **devfd, char *name)
i = nfd;
while (i--) {
- if (stat(devname[i], &st) != 0)
- errx(errno, "stat failure on: %s", devname[i]);
+ if (((*devfd)[i].fd = open(devname[i], O_RDWR, 0640)) < 0)
+ errx(1, "unable to open device file: %s", devname[i]);
+ if (fstat((*devfd)[i].fd, &st) != 0)
+ errx(errno, "fstat failure on: %s", devname[i]);
if (!S_ISBLK(st.st_mode) && !S_ISCHR(st.st_mode))
errx(EINVAL, "invalid device: %s", devname[i]);
- if (((*devfd)[i].fd = open(devname[i], O_RDWR, 0640)) < 0)
- errx(1, "unable to open device file: %s", devname[i]);
(*devfd)[i].id = RF_DEV2RAIDID(st.st_rdev);
free(devname[i]);
@@ -1205,11 +1207,9 @@ get_all_devices(char ***diskarray, const char *genericname)
fp = disks;
while ((p = strsep(&fp, ",")) != NULL) {
if (strstr((const char*)p, genericname) != NULL) {
- int len = strlen(p) + 7;
-
- (*diskarray)[i] = (char*) malloc(len);
- snprintf((*diskarray)[i++], len, "/dev/%s%c", p,
- 'a' + getrawpartition());
+ if (asprintf(&(*diskarray)[i++], "/dev/%s%c", p,
+ 'a' + getrawpartition()) == -1)
+ err(1, "asprintf");
}
}