xref: /minix3/include/fstab.h (revision 2fe8fb192fe7e8720e3e7a77f928da545e872a6a)
1*2fe8fb19SBen Gras /*	$NetBSD: fstab.h,v 1.11 2005/02/03 04:39:32 perry Exp $	*/
2*2fe8fb19SBen Gras 
3*2fe8fb19SBen Gras /*
4*2fe8fb19SBen Gras  * Copyright (c) 1980, 1993
5*2fe8fb19SBen Gras  *	The Regents of the University of California.  All rights reserved.
6*2fe8fb19SBen Gras  *
7*2fe8fb19SBen Gras  * Redistribution and use in source and binary forms, with or without
8*2fe8fb19SBen Gras  * modification, are permitted provided that the following conditions
9*2fe8fb19SBen Gras  * are met:
10*2fe8fb19SBen Gras  * 1. Redistributions of source code must retain the above copyright
11*2fe8fb19SBen Gras  *    notice, this list of conditions and the following disclaimer.
12*2fe8fb19SBen Gras  * 2. Redistributions in binary form must reproduce the above copyright
13*2fe8fb19SBen Gras  *    notice, this list of conditions and the following disclaimer in the
14*2fe8fb19SBen Gras  *    documentation and/or other materials provided with the distribution.
15*2fe8fb19SBen Gras  * 3. Neither the name of the University nor the names of its contributors
16*2fe8fb19SBen Gras  *    may be used to endorse or promote products derived from this software
17*2fe8fb19SBen Gras  *    without specific prior written permission.
18*2fe8fb19SBen Gras  *
19*2fe8fb19SBen Gras  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20*2fe8fb19SBen Gras  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21*2fe8fb19SBen Gras  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22*2fe8fb19SBen Gras  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23*2fe8fb19SBen Gras  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24*2fe8fb19SBen Gras  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25*2fe8fb19SBen Gras  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26*2fe8fb19SBen Gras  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27*2fe8fb19SBen Gras  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28*2fe8fb19SBen Gras  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29*2fe8fb19SBen Gras  * SUCH DAMAGE.
30*2fe8fb19SBen Gras  *
31*2fe8fb19SBen Gras  *	@(#)fstab.h	8.1 (Berkeley) 6/2/93
32*2fe8fb19SBen Gras  */
33*2fe8fb19SBen Gras 
34*2fe8fb19SBen Gras #ifndef _FSTAB_H_
35*2fe8fb19SBen Gras #define _FSTAB_H_
36*2fe8fb19SBen Gras 
37*2fe8fb19SBen Gras #include <sys/cdefs.h>
38*2fe8fb19SBen Gras 
39*2fe8fb19SBen Gras /*
40*2fe8fb19SBen Gras  * File system table, see fstab(5).
41*2fe8fb19SBen Gras  *
42*2fe8fb19SBen Gras  * Used by dump, mount, umount, swapon, fsck, df, ...
43*2fe8fb19SBen Gras  *
44*2fe8fb19SBen Gras  * For ufs fs_spec field is the block special name.  Programs that want to
45*2fe8fb19SBen Gras  * use the character special name must create that name by prepending a 'r'
46*2fe8fb19SBen Gras  * after the right most slash.  Quota files are always named "quotas", so
47*2fe8fb19SBen Gras  * if type is "rq", then use concatenation of fs_file and "quotas" to locate
48*2fe8fb19SBen Gras  * quota file.
49*2fe8fb19SBen Gras  */
50*2fe8fb19SBen Gras #define	_PATH_FSTAB	"/etc/fstab"
51*2fe8fb19SBen Gras #define	FSTAB		"/etc/fstab"	/* deprecated */
52*2fe8fb19SBen Gras 
53*2fe8fb19SBen Gras #define	FSTAB_RW	"rw"		/* read/write device */
54*2fe8fb19SBen Gras #define	FSTAB_RQ	"rq"		/* read/write with quotas */
55*2fe8fb19SBen Gras #define	FSTAB_RO	"ro"		/* read-only device */
56*2fe8fb19SBen Gras #define	FSTAB_SW	"sw"		/* swap device */
57*2fe8fb19SBen Gras #define	FSTAB_DP	"dp"		/* dump device */
58*2fe8fb19SBen Gras #define	FSTAB_XX	"xx"		/* ignore totally */
59*2fe8fb19SBen Gras 
60*2fe8fb19SBen Gras struct fstab {
61*2fe8fb19SBen Gras 	__aconst char *fs_spec;		/* block special device name */
62*2fe8fb19SBen Gras 	__aconst char *fs_file;		/* file system path prefix */
63*2fe8fb19SBen Gras 	__aconst char *fs_vfstype;	/* File system type, ufs, nfs */
64*2fe8fb19SBen Gras 	__aconst char *fs_mntops;	/* Mount options ala -o */
65*2fe8fb19SBen Gras 	__aconst char *fs_type;		/* FSTAB_* from fs_mntops */
66*2fe8fb19SBen Gras 	int	fs_freq;		/* dump frequency, in days */
67*2fe8fb19SBen Gras 	int	fs_passno;		/* pass number on parallel fsck */
68*2fe8fb19SBen Gras };
69*2fe8fb19SBen Gras 
70*2fe8fb19SBen Gras __BEGIN_DECLS
71*2fe8fb19SBen Gras struct fstab *getfsent(void);
72*2fe8fb19SBen Gras struct fstab *getfsspec(const char *);
73*2fe8fb19SBen Gras struct fstab *getfsfile(const char *);
74*2fe8fb19SBen Gras int setfsent(void);
75*2fe8fb19SBen Gras void endfsent(void);
76*2fe8fb19SBen Gras __END_DECLS
77*2fe8fb19SBen Gras 
78*2fe8fb19SBen Gras #endif /* !_FSTAB_H_ */
79