summaryrefslogtreecommitdiff
path: root/lib/libutil
diff options
context:
space:
mode:
authorJason Downs <downsj@cvs.openbsd.org>1996-12-03 01:05:37 +0000
committerJason Downs <downsj@cvs.openbsd.org>1996-12-03 01:05:37 +0000
commit4e3cf5ae51e6086fa825eb14dabe972a3825b88f (patch)
treef603fa47cce05fd6b90d181d8e85c40202b1c3e9 /lib/libutil
parent0d21ef0815f117f6c6ea39a71f98d7d6689eb7ba (diff)
Add readlabelfs().
Diffstat (limited to 'lib/libutil')
-rw-r--r--lib/libutil/Makefile4
-rw-r--r--lib/libutil/readlabel.c115
-rw-r--r--lib/libutil/util.h13
3 files changed, 124 insertions, 8 deletions
diff --git a/lib/libutil/Makefile b/lib/libutil/Makefile
index f053d07588a..34811926e6d 100644
--- a/lib/libutil/Makefile
+++ b/lib/libutil/Makefile
@@ -1,4 +1,4 @@
-# $OpenBSD: Makefile,v 1.8 1996/07/31 17:46:51 deraadt Exp $
+# $OpenBSD: Makefile,v 1.9 1996/12/03 01:05:35 downsj Exp $
# $NetBSD: Makefile,v 1.8 1996/05/16 07:03:28 thorpej Exp $
LIB= util
@@ -6,7 +6,7 @@ CFLAGS+=-DLIBC_SCCS
HDRS= util.h scsi.h
SRCS= getmaxpartitions.c getrawpartition.c login.c login_tty.c logout.c \
- logwtmp.c opendev.c passwd.c pty.c scsi.c login_fbtab.c
+ logwtmp.c opendev.c passwd.c pty.c readlabel.c scsi.c login_fbtab.c
# XXX need login_fbtab.3
MAN= getmaxpartitions.3 getrawpartition.3 login.3 opendev.3 openpty.3 \
diff --git a/lib/libutil/readlabel.c b/lib/libutil/readlabel.c
new file mode 100644
index 00000000000..f78ce580cfc
--- /dev/null
+++ b/lib/libutil/readlabel.c
@@ -0,0 +1,115 @@
+/* $OpenBSD: readlabel.c,v 1.1 1996/12/03 01:05:35 downsj Exp $ */
+
+/*
+ * Copyright (c) 1996, Jason Downs. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS
+ * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT,
+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/types.h>
+#include <stdio.h>
+#include <err.h>
+#include <errno.h>
+#include <fcntl.h>
+#include <paths.h>
+#include <string.h>
+#include <util.h>
+#include <sys/dkio.h>
+#define DKTYPENAMES
+#include <sys/disklabel.h>
+#include <sys/param.h>
+#include <sys/stat.h>
+
+/*
+ * Try to get a disklabel for the specified device, and return mount_xxx
+ * style filesystem type name for the specified partition.
+ */
+
+char *readlabelfs(device)
+ char *device;
+{
+ char rpath[MAXPATHLEN];
+ char part;
+ struct stat sbuf;
+ struct disklabel dk;
+ int fd;
+
+ /* Assuming device is of the form /dev/??p, build a raw partition. */
+ if (stat(device, &sbuf) < 0) {
+ warn("%s", device);
+ return(NULL);
+ }
+ switch(sbuf.st_mode & S_IFMT) {
+ case S_IFCHR:
+ /* Ok... already a raw device. Hmm. */
+ strncpy(rpath, device, sizeof(rpath));
+ rpath[sizeof(rpath) - 1] = '\0';
+
+ /* Change partition name. */
+ part = rpath[strlen(rpath) - 1];
+ rpath[strlen(rpath) - 1] = 'a' + getrawpartition();
+ break;
+ case S_IFBLK:
+ if (strlen(device) > strlen(_PATH_DEV)) {
+ snprintf(rpath, sizeof(rpath), "%sr%s", _PATH_DEV,
+ &device[strlen(_PATH_DEV)]);
+
+ /* Change partition name. */
+ part = rpath[strlen(rpath) - 1];
+ rpath[strlen(rpath) - 1] = 'a' + getrawpartition();
+ break;
+ }
+ default:
+ warnx("%s: not a device node", device);
+ return(NULL);
+ }
+
+ /* If rpath doesn't exist, change that partition back. */
+ fd = open(rpath, O_RDONLY);
+ if (fd < 0) {
+ if (errno == ENOENT) {
+ rpath[strlen(rpath) - 1] = part;
+
+ fd = open(rpath, O_RDONLY);
+ if (fd < 0) {
+ warn("%s", rpath);
+ return(NULL);
+ }
+ } else {
+ warn("%s", rpath);
+ return(NULL);
+ }
+ }
+ if (ioctl(fd, DIOCGDINFO, &dk) < 0) {
+ warn("%s: couldn't read disklabel", rpath);
+ close(fd);
+ return(NULL);
+ }
+ close(fd);
+
+ if (dk.d_partitions[part - 'a'].p_fstype > FSMAXTYPES) {
+ warnx("%s: bad filesystem type in label", rpath);
+ return(NULL);
+ }
+
+ return(fstypesnames[dk.d_partitions[part - 'a'].p_fstype]);
+}
diff --git a/lib/libutil/util.h b/lib/libutil/util.h
index f4d63703e16..6206c8a1e25 100644
--- a/lib/libutil/util.h
+++ b/lib/libutil/util.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: util.h,v 1.2 1996/07/31 17:44:22 deraadt Exp $ */
+/* $OpenBSD: util.h,v 1.3 1996/12/03 01:05:36 downsj Exp $ */
/* $NetBSD: util.h,v 1.2 1996/05/16 07:00:22 thorpej Exp $ */
/*-
@@ -61,17 +61,18 @@ int pw_lock __P((int retries));
int pw_mkdb __P((void));
int pw_abort __P((void));
void pw_init __P((void));
-void pw_edit __P((int notsetuid, const char *filename));
+void pw_edit __P((int, const char *));
void pw_prompt __P((void));
-void pw_copy __P((int ffd, int tfd, struct passwd *pw));
-int pw_scan __P((char *bp, struct passwd *pw, int *flags));
-void pw_error __P((const char *name, int err, int eval));
+void pw_copy __P((int, int, struct passwd *));
+int pw_scan __P((char *, struct passwd *, int *));
+void pw_error __P((const char *, int, int));
int openpty __P((int *, int *, char *, struct termios *,
struct winsize *));
pid_t forkpty __P((int *, char *, struct termios *, struct winsize *));
int getmaxpartitions __P((void));
int getrawpartition __P((void));
-void login_fbtab __P((char *tty, uid_t uid, gid_t gid));
+void login_fbtab __P((char *, uid_t, gid_t));
+char *readlabelfs __P((char *));
__END_DECLS
#endif /* !_UTIL_H_ */