xref: /freebsd/include/fstab.h (revision 5a1d14419a5b620430949a46cb6ee63148a43cb9)
1*2321c474SPedro F. Giffuni /*-
2*2321c474SPedro F. Giffuni  * SPDX-License-Identifier: BSD-3-Clause
3*2321c474SPedro F. Giffuni  *
459deaec5SRodney W. Grimes  * Copyright (c) 1980, 1993
559deaec5SRodney W. Grimes  *	The Regents of the University of California.  All rights reserved.
659deaec5SRodney W. Grimes  *
759deaec5SRodney W. Grimes  * Redistribution and use in source and binary forms, with or without
859deaec5SRodney W. Grimes  * modification, are permitted provided that the following conditions
959deaec5SRodney W. Grimes  * are met:
1059deaec5SRodney W. Grimes  * 1. Redistributions of source code must retain the above copyright
1159deaec5SRodney W. Grimes  *    notice, this list of conditions and the following disclaimer.
1259deaec5SRodney W. Grimes  * 2. Redistributions in binary form must reproduce the above copyright
1359deaec5SRodney W. Grimes  *    notice, this list of conditions and the following disclaimer in the
1459deaec5SRodney W. Grimes  *    documentation and/or other materials provided with the distribution.
15f2556687SWarner Losh  * 3. Neither the name of the University nor the names of its contributors
1659deaec5SRodney W. Grimes  *    may be used to endorse or promote products derived from this software
1759deaec5SRodney W. Grimes  *    without specific prior written permission.
1859deaec5SRodney W. Grimes  *
1959deaec5SRodney W. Grimes  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
2059deaec5SRodney W. Grimes  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2159deaec5SRodney W. Grimes  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2259deaec5SRodney W. Grimes  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
2359deaec5SRodney W. Grimes  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2459deaec5SRodney W. Grimes  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2559deaec5SRodney W. Grimes  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2659deaec5SRodney W. Grimes  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2759deaec5SRodney W. Grimes  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2859deaec5SRodney W. Grimes  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2959deaec5SRodney W. Grimes  * SUCH DAMAGE.
3059deaec5SRodney W. Grimes  */
3159deaec5SRodney W. Grimes 
3259deaec5SRodney W. Grimes #ifndef _FSTAB_H_
3359deaec5SRodney W. Grimes #define _FSTAB_H_
3459deaec5SRodney W. Grimes 
3559deaec5SRodney W. Grimes /*
3659deaec5SRodney W. Grimes  * File system table, see fstab(5).
3759deaec5SRodney W. Grimes  *
3859deaec5SRodney W. Grimes  * Used by dump, mount, umount, swapon, fsck, df, ...
3959deaec5SRodney W. Grimes  *
4059deaec5SRodney W. Grimes  * For ufs fs_spec field is the block special name.  Programs that want to
4159deaec5SRodney W. Grimes  * use the character special name must create that name by prepending a 'r'
4259deaec5SRodney W. Grimes  * after the right most slash.  Quota files are always named "quotas", so
4359deaec5SRodney W. Grimes  * if type is "rq", then use concatenation of fs_file and "quotas" to locate
4459deaec5SRodney W. Grimes  * quota file.
4559deaec5SRodney W. Grimes  */
4659deaec5SRodney W. Grimes #define	_PATH_FSTAB	"/etc/fstab"
4759deaec5SRodney W. Grimes #define	FSTAB		"/etc/fstab"	/* deprecated */
4859deaec5SRodney W. Grimes 
4959deaec5SRodney W. Grimes #define	FSTAB_RW	"rw"		/* read/write device */
5059deaec5SRodney W. Grimes #define	FSTAB_RQ	"rq"		/* read/write with quotas */
5159deaec5SRodney W. Grimes #define	FSTAB_RO	"ro"		/* read-only device */
5259deaec5SRodney W. Grimes #define	FSTAB_SW	"sw"		/* swap device */
5359deaec5SRodney W. Grimes #define	FSTAB_XX	"xx"		/* ignore totally */
5459deaec5SRodney W. Grimes 
5559deaec5SRodney W. Grimes struct fstab {
5659deaec5SRodney W. Grimes 	char	*fs_spec;		/* block special device name */
5759deaec5SRodney W. Grimes 	char	*fs_file;		/* file system path prefix */
5859deaec5SRodney W. Grimes 	char	*fs_vfstype;		/* File system type, ufs, nfs */
5959deaec5SRodney W. Grimes 	char	*fs_mntops;		/* Mount options ala -o */
6059deaec5SRodney W. Grimes 	char	*fs_type;		/* FSTAB_* from fs_mntops */
6159deaec5SRodney W. Grimes 	int	fs_freq;		/* dump frequency, in days */
62b6febe7aSMike Pritchard 	int	fs_passno;		/* pass number on parallel fsck */
6359deaec5SRodney W. Grimes };
6459deaec5SRodney W. Grimes 
6559deaec5SRodney W. Grimes #include <sys/cdefs.h>
6659deaec5SRodney W. Grimes 
6759deaec5SRodney W. Grimes __BEGIN_DECLS
68bb28f3c2SWarner Losh struct fstab *getfsent(void);
69bb28f3c2SWarner Losh struct fstab *getfsspec(const char *);
70bb28f3c2SWarner Losh struct fstab *getfsfile(const char *);
71bb28f3c2SWarner Losh int setfsent(void);
72bb28f3c2SWarner Losh void endfsent(void);
73134dbc4cSMatthew N. Dodd void setfstab(const char *);
74134dbc4cSMatthew N. Dodd const char *getfstab(void);
7559deaec5SRodney W. Grimes __END_DECLS
7659deaec5SRodney W. Grimes 
7759deaec5SRodney W. Grimes #endif /* !_FSTAB_H_ */
78