xref: /netbsd-src/external/cddl/osnet/sys/sys/vfs.h (revision ba2539a9805a0544ff82c0003cc02fe1eee5603d)
1 /*	$NetBSD: vfs.h,v 1.5 2018/05/28 21:05:10 chs Exp $	*/
2 
3 /*-
4  * Copyright (c) 2007 Pawel Jakub Dawidek <pjd@FreeBSD.org>
5  * All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
17  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
20  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26  * SUCH DAMAGE.
27  *
28  * $FreeBSD: head/sys/cddl/compat/opensolaris/sys/vfs.h 297513 2016-04-02 16:25:46Z avg $
29  */
30 
31 #ifndef _OPENSOLARIS_SYS_VFS_H_
32 #define	_OPENSOLARIS_SYS_VFS_H_
33 
34 #include <sys/param.h>
35 
36 #ifdef _KERNEL
37 
38 #include <sys/mount.h>
39 #include <sys/vnode.h>
40 
41 #define	rootdir	rootvnode
42 
43 typedef	struct mount	vfs_t;
44 
45 #define	vfs_flag	mnt_flag
46 #define	vfs_data	mnt_data
47 #define	vfs_count	mnt_refcnt
48 #define	vfs_bsize	mnt_stat.f_bsize
49 #define	vfs_resource	mnt_stat.f_mntfromname
50 
51 #define	v_flag		v_vflag
52 #define	v_vfsp		v_mount
53 
54 #define	VFS_RDONLY	MNT_RDONLY
55 #define	VFS_NOSETUID	MNT_NOSUID
56 #define	VFS_NOEXEC	MNT_NOEXEC
57 
58 #define fs_vscan(vp, cr, async) (0)
59 
60 #define	VROOT		VV_ROOT
61 
62 /*
63  * Structure defining a mount option for a filesystem.
64  * option names are found in mntent.h
65  */
66 typedef struct mntopt {
67 	char	*mo_name;	/* option name */
68 	char	**mo_cancel;	/* list of options cancelled by this one */
69 	char	*mo_arg;	/* argument string for this option */
70 	int	mo_flags;	/* flags for this mount option */
71 	void	*mo_data;	/* filesystem specific data */
72 } mntopt_t;
73 
74 /*
75  * Flags that apply to mount options
76  */
77 
78 #define	MO_SET		0x01		/* option is set */
79 #define	MO_NODISPLAY	0x02		/* option not listed in mnttab */
80 #define	MO_HASVALUE	0x04		/* option takes a value */
81 #define	MO_IGNORE	0x08		/* option ignored by parser */
82 #define	MO_DEFAULT	MO_SET		/* option is on by default */
83 #define	MO_TAG		0x10		/* flags a tag set by user program */
84 #define	MO_EMPTY	0x20		/* empty space in option table */
85 
86 #define	VFS_NOFORCEOPT	0x01		/* honor MO_IGNORE (don't set option) */
87 #define	VFS_DISPLAY	0x02		/* Turn off MO_NODISPLAY bit for opt */
88 #define	VFS_NODISPLAY	0x04		/* Turn on MO_NODISPLAY bit for opt */
89 #define	VFS_CREATEOPT	0x08		/* Create the opt if it's not there */
90 #define VFS_UNMOUNTED   0x100           /* file system has been unmounted */
91 
92 /*
93  * Structure holding mount option strings for the mounted file system.
94  */
95 typedef struct mntopts {
96 	uint_t		mo_count;		/* number of entries in table */
97 	mntopt_t	*mo_list;		/* list of mount options */
98 } mntopts_t;
99 
100  /*
101   * Argument structure for mount(2).
102   *
103   * Flags are defined in <sys/mount.h>.
104   *
105   * Note that if the MS_SYSSPACE bit is set in flags, the pointer fields in
106   * this structure are to be interpreted as kernel addresses.  File systems
107   * should be prepared for this possibility.
108   */
109 struct mounta {
110 	char fspec[MAXNAMELEN - 1];
111 	char dataptr[MAXPATHLEN];
112 	char optptr[MAXPATHLEN];
113 	char *fstype; /* Unused */
114 	int  mflag;
115 	int  datalen;
116 	int  optlen;
117 	int  flags; /* Unused */
118 };
119 
120 #define vfs_devismounted(dev) 0
121 
122 void vfs_setmntopt(vfs_t *vfsp, const char *name, const char *arg,
123     int flags __unused);
124 void vfs_clearmntopt(vfs_t *vfsp, const char *name);
125 int vfs_optionisset(const vfs_t *vfsp, const char *opt, char **argp);
126 int mount_snapshot(kthread_t *td, vnode_t **vpp, const char *fstype,
127     char *fspath, char *fspec, int fsflags);
128 
129 typedef	uint64_t	vfs_feature_t;
130 
131 #define	VFSFT_XVATTR		0x100000001	/* Supports xvattr for attrs */
132 #define	VFSFT_CASEINSENSITIVE	0x100000002	/* Supports case-insensitive */
133 #define	VFSFT_NOCASESENSITIVE	0x100000004	/* NOT case-sensitive */
134 #define	VFSFT_DIRENTFLAGS	0x100000008	/* Supports dirent flags */
135 #define	VFSFT_ACLONCREATE	0x100000010	/* Supports ACL on create */
136 #define	VFSFT_ACEMASKONACCESS	0x100000020	/* Can use ACEMASK for access */
137 #define	VFSFT_SYSATTR_VIEWS	0x100000040	/* Supports sysattr view i/f */
138 #define	VFSFT_ACCESS_FILTER	0x100000080	/* dirents filtered by access */
139 #define	VFSFT_REPARSE		0x100000100	/* Supports reparse point */
140 #define	VFSFT_ZEROCOPY_SUPPORTED	0x100000200
141 				/* Support loaning /returning cache buffer */
142 
143 #define	vfs_set_feature(vfsp, feature)		do { } while (0)
144 #define	vfs_clear_feature(vfsp, feature)	do { } while (0)
145 #define	vfs_has_feature(vfsp, feature)		(0)
146 
147 #define	VFS_HOLD(vfsp)	do {						\
148 	/* XXXNETBSD nothing */						\
149 } while (0)
150 #define	VFS_RELE(vfsp)	do {						\
151 	/* XXXNETBSD nothing */						\
152 } while (0)
153 
154 #endif	/* _KERNEL */
155 
156 #endif	/* _OPENSOLARIS_SYS_VFS_H_ */
157