Home | History | Annotate | Line # | Download | only in libutil
opendisk.c revision 1.10.14.1
      1  1.10.14.1   matt /*	$NetBSD: opendisk.c,v 1.10.14.1 2010/04/21 05:28:11 matt Exp $	*/
      2        1.1  lukem 
      3        1.1  lukem /*-
      4        1.1  lukem  * Copyright (c) 1997 The NetBSD Foundation, Inc.
      5        1.1  lukem  * All rights reserved.
      6        1.1  lukem  *
      7        1.1  lukem  * This code is derived from software contributed to The NetBSD Foundation
      8        1.1  lukem  * by Luke Mewburn.
      9        1.1  lukem  *
     10        1.1  lukem  * Redistribution and use in source and binary forms, with or without
     11        1.1  lukem  * modification, are permitted provided that the following conditions
     12        1.1  lukem  * are met:
     13        1.1  lukem  * 1. Redistributions of source code must retain the above copyright
     14        1.1  lukem  *    notice, this list of conditions and the following disclaimer.
     15        1.1  lukem  * 2. Redistributions in binary form must reproduce the above copyright
     16        1.1  lukem  *    notice, this list of conditions and the following disclaimer in the
     17        1.1  lukem  *    documentation and/or other materials provided with the distribution.
     18        1.1  lukem  *
     19        1.1  lukem  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     20        1.1  lukem  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     21        1.1  lukem  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     22        1.1  lukem  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     23        1.1  lukem  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     24        1.1  lukem  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     25        1.1  lukem  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     26        1.1  lukem  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     27        1.1  lukem  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     28        1.1  lukem  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     29        1.1  lukem  * POSSIBILITY OF SUCH DAMAGE.
     30        1.1  lukem  */
     31        1.1  lukem 
     32        1.1  lukem #include <sys/cdefs.h>
     33        1.1  lukem #if defined(LIBC_SCCS) && !defined(lint)
     34  1.10.14.1   matt __RCSID("$NetBSD: opendisk.c,v 1.10.14.1 2010/04/21 05:28:11 matt Exp $");
     35        1.1  lukem #endif
     36        1.1  lukem 
     37        1.1  lukem #include <sys/param.h>
     38        1.1  lukem 
     39        1.5  lukem #include <assert.h>
     40        1.1  lukem #include <errno.h>
     41        1.1  lukem #include <fcntl.h>
     42        1.9  lukem #include <util.h>
     43        1.1  lukem #include <paths.h>
     44        1.1  lukem #include <stdio.h>
     45        1.1  lukem #include <string.h>
     46        1.1  lukem 
     47  1.10.14.1   matt static int
     48  1.10.14.1   matt __opendisk(const char *path, int flags, char *buf, size_t buflen, int iscooked,
     49  1.10.14.1   matt 	int (*ofn)(const char *, int, ...))
     50        1.1  lukem {
     51        1.9  lukem 	int f, rawpart;
     52        1.1  lukem 
     53        1.2  lukem 	if (buf == NULL) {
     54        1.2  lukem 		errno = EFAULT;
     55        1.2  lukem 		return (-1);
     56        1.2  lukem 	}
     57        1.9  lukem 	snprintf(buf, buflen, "%s", path);
     58        1.9  lukem 
     59        1.1  lukem 	if ((flags & O_CREAT) != 0) {
     60        1.1  lukem 		errno = EINVAL;
     61        1.1  lukem 		return (-1);
     62        1.1  lukem 	}
     63        1.1  lukem 
     64        1.1  lukem 	rawpart = getrawpartition();
     65        1.1  lukem 	if (rawpart < 0)
     66        1.1  lukem 		return (-1);	/* sysctl(3) in getrawpartition sets errno */
     67        1.1  lukem 
     68  1.10.14.1   matt 	f = ofn(buf, flags, 0);
     69        1.9  lukem 	if (f != -1 || errno != ENOENT)
     70        1.9  lukem 		return (f);
     71        1.9  lukem 
     72        1.9  lukem 	snprintf(buf, buflen, "%s%c", path, 'a' + rawpart);
     73  1.10.14.1   matt 	f = ofn(buf, flags, 0);
     74        1.9  lukem 	if (f != -1 || errno != ENOENT)
     75        1.9  lukem 		return (f);
     76        1.9  lukem 
     77        1.9  lukem 	if (strchr(path, '/') != NULL)
     78        1.9  lukem 		return (-1);
     79        1.9  lukem 
     80        1.9  lukem 	snprintf(buf, buflen, "%s%s%s", _PATH_DEV, iscooked ? "" : "r", path);
     81  1.10.14.1   matt 	f = ofn(buf, flags, 0);
     82        1.9  lukem 	if (f != -1 || errno != ENOENT)
     83        1.9  lukem 		return (f);
     84        1.9  lukem 
     85        1.9  lukem 	snprintf(buf, buflen, "%s%s%s%c", _PATH_DEV, iscooked ? "" : "r", path,
     86        1.9  lukem 	    'a' + rawpart);
     87  1.10.14.1   matt 	f = ofn(buf, flags, 0);
     88        1.1  lukem 	return (f);
     89        1.1  lukem }
     90  1.10.14.1   matt 
     91  1.10.14.1   matt int
     92  1.10.14.1   matt opendisk(const char *path, int flags, char *buf, size_t buflen, int iscooked)
     93  1.10.14.1   matt {
     94  1.10.14.1   matt 
     95  1.10.14.1   matt 	return __opendisk(path, flags, buf, buflen, iscooked, open);
     96  1.10.14.1   matt }
     97  1.10.14.1   matt 
     98  1.10.14.1   matt int
     99  1.10.14.1   matt opendisk1(const char *path, int flags, char *buf, size_t buflen, int iscooked,
    100  1.10.14.1   matt 	int (*ofn)(const char *, int, ...))
    101  1.10.14.1   matt {
    102  1.10.14.1   matt 
    103  1.10.14.1   matt 	return __opendisk(path, flags, buf, buflen, iscooked, ofn);
    104  1.10.14.1   matt }
    105