xref: /netbsd-src/share/man/man9/vfsops.9 (revision bf1e9b32e27832f0c493206710fb8b58a980838a)
1.\"     $NetBSD: vfsops.9,v 1.18 2005/06/20 13:25:25 peter Exp $
2.\"
3.\" Copyright (c) 2001 The NetBSD Foundation, Inc.
4.\" All rights reserved.
5.\"
6.\" This code is derived from software contributed to The NetBSD Foundation
7.\" by Gregory McGarry.
8.\"
9.\" Redistribution and use in source and binary forms, with or without
10.\" modification, are permitted provided that the following conditions
11.\" are met:
12.\" 1. Redistributions of source code must retain the above copyright
13.\"    notice, this list of conditions and the following disclaimer.
14.\" 2. Redistributions in binary form must reproduce the above copyright
15.\"    notice, this list of conditions and the following disclaimer in the
16.\"    documentation and/or other materials provided with the distribution.
17.\" 3. All advertising materials mentioning features or use of this software
18.\"    must display the following acknowledgement:
19.\"        This product includes software developed by the NetBSD
20.\"        Foundation, Inc. and its contributors.
21.\" 4. Neither the name of The NetBSD Foundation nor the names of its
22.\"    contributors may be used to endorse or promote products derived
23.\"    from this software without specific prior written permission.
24.\"
25.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
26.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
27.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28.\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
29.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
35.\" POSSIBILITY OF SUCH DAMAGE.
36.\"
37.Dd June 20, 2004
38.Dt VFSOPS 9
39.Os
40.Sh NAME
41.Nm vfsops ,
42.Nm VFS_MOUNT ,
43.Nm VFS_START ,
44.Nm VFS_UNMOUNT ,
45.Nm VFS_ROOT ,
46.Nm VFS_QUOTACTL ,
47.Nm VFS_STATFS ,
48.Nm VFS_STATFS ,
49.Nm VFS_SYNC ,
50.Nm VFS_VGET ,
51.Nm VFS_FHTOVP ,
52.Nm VFS_VPTOFH ,
53.Nm VFS_CHECKEXP ,
54.Nm VFS_SNAPSHOT
55.Nd kernel file system interface
56.Sh SYNOPSIS
57.In sys/param.h
58.In sys/mount.h
59.In sys/vnode.h
60.Ft int
61.Fn VFS_MOUNT "struct mount *mp" "const char *path" "void *data" \
62"struct nameidata *ndp" "struct proc *p"
63.Ft int
64.Fn VFS_START "struct mount *mp" "int flags" "struct proc *p"
65.Ft int
66.Fn VFS_UNMOUNT "struct mount *mp" "int mntflags" "struct proc *p"
67.Ft int
68.Fn VFS_ROOT "struct mount *mp" "struct vnode **vpp"
69.Ft int
70.Fn VFS_QUOTACTL "struct mount *mp" "int cmds" "uid_t uid" \
71"caddr_t arg" "struct proc *p"
72.Ft int
73.Fn VFS_STATFS "struct mount *mp" "struct statfs *sbp" "struct proc *p"
74.Ft int
75.Fn VFS_SYNC "struct mount *mp" "int waitfor" "struct ucred *cred" \
76"struct proc *p"
77.Ft int
78.Fn VFS_VGET "struct mount *mp" "ino_t ino" "struct vnode **vpp"
79.Ft int
80.Fn VFS_FHTOVP "struct mount *mp" "struct fid *fhp" "struct vnode **vpp"
81.Ft int
82.Fn VFS_VPTOFH "struct vnode *vp" "struct fid *fhp"
83.Ft int
84.Fn VFS_CHECKEXP "struct mount *mp" "struct mbuf *nam" \
85"int *extflagsp" "struct ucred **credanonp"
86.Ft int
87.Fn VFS_SNAPSHOT "struct mount *mp" "struct vnode *vp" "struct timespec *ts"
88.Sh DESCRIPTION
89In a similar fashion to the
90.Xr vnode 9
91interface, all operations that are done on a file system are conducted
92through a single interface that allows the system to carry out
93operations on a file system without knowing its construction or type.
94.Pp
95All supported file systems in the kernel have an entry in the
96.Va vfs_list_initial
97table.
98This table is generated by
99.Xr config 1
100and is a
101.Dv NULL Ns No -terminated
102list of
103.Em vfsops
104structures.
105The vfsops structure describes the operations that can be done to a
106specific file system type.
107The following table list the elements of the vfsops vector, the
108corresponding invocation macro, and a description of the element.
109.Pp
110.nf
111.ta \w'int (*vfs_mountroot)()'u+2n +\w'VFS_QUOTACTL'u+2n +\w'Get the file system root vnode'u
112\fIVector element\fP	\fIMacro\fP	\fIDescription\fP
113.ta \w'int (*vfs_mountroot)()'u+2n +\w'VFS_QUOTACTL'u+2n +\w'Get the file system root vnode'u+6nC
114.sp 5p
115int  (*vfs_mount)()	VFS_MOUNT	Mount a file system
116int  (*vfs_start)()	VFS_START	Make operational
117int  (*vfs_unmount)()	VFS_UMOUNT	Unmount a file system
118int  (*vfs_root)()	VFS_ROOT	Get the file system root vnode
119int  (*vfs_quotactl)()	VFS_QUOTACTL	Query/modify space quotas
120int  (*vfs_statfs)()	VFS_STATFS	Get file system statistics
121int  (*vfs_sync)()	VFS_SYNC	Flush file system buffers
122int  (*vfs_vget)()	VFS_VGET	Get vnode from file id
123int  (*vfs_fhtovp)()	VFS_FHTOVP	NFS file handle to vnode lookup
124int  (*vfs_vptofh)()	VFS_VPTOFH	Vnode to NFS file handle lookup
125void (*vfs_init)()	-	Initialise file system
126void (*vfs_reinit)()	-	Reinitialise file system
127void (*vfs_done)()	-	Cleanup unmounted file system
128int  (*vfs_mountroot)()	-	Mount the root file system
129int  (*vfs_checkexp)()	VFS_CHECKEXP	Check if file system is exported
130int  (*vfs_snapshot)()	VFS_SNAPSHOT	Take a snapshot
131.fi
132.Pp
133Some additional non-function members of the vfsops structure are the
134file system name
135.Ns Em vfs_name
136and a reference count
137.Ns Em vfs_refcount  .
138It is not mandatory for a file system type to support a particular
139operation, but it must assign each member function pointer to a
140suitable function to do the minimum required of it.
141In most cases, such functions either do nothing or return an error
142value to the effect that it is not supported.
143.Em vfs_reinit
144and
145.Em vfs_mountroot
146may
147be
148.Dv NULL .
149.Pp
150At system boot, each file system with an entry in
151.Va vfs_list_initial
152is established and initialised.
153Each initialised file system is recorded by the kernel in the list
154.Va vfs_list
155and the file system specific initialisation function
156.Em vfs_init
157in its vfsops vector is invoked.
158When the file system is not longer needed
159.Em vfs_done
160is invoked to run file system specific cleanups and the file system is
161removed from the kernel list.
162.Pp
163At system boot, the root filesystem is mounted by invoking the file
164system type specific
165.Em vfs_mountroot
166function in the vfsops vector.
167All filesystems that can be mounted as a root file system must define
168this function.
169It is responsible for initialising to list of mount structures for
170all future mounted file systems.
171.Pp
172Kernel state which affects a specific file system type can be
173queried and modified using the
174.Xr sysctl 8
175interface.
176.Sh FUNCTIONS
177.Bl -tag -width compact
178.It Fn VFS_MOUNT "mp" "path" "data" "ndp" "p"
179Mount a file system specified by the mount structure
180.Fa mp
181on the mount point described by
182.Fa path .
183The argument
184.Fa data
185contains file system type specific data and is read into the kernel
186using
187.Xr copyin 9 .
188The argument
189.Fa ndp
190contains the result of a
191.Xr namei 9
192call on the pathname of the mount point and
193.Fa p
194is the calling process.
195.Fn VFS_MOUNT
196initialises the mount structure for the mounted file system.
197This structure records mount-specific information for the file system and
198records the list of vnodes associated with the file system.
199This function is invoked both to mount new file systems and to change the
200attributes of an existing file system.
201If the MNT_UPDATE flag is set in
202.Em mp-\*[Gt]mnt_flag
203then the filesystem should update its internal state from the value of
204.Em mp-\*[Gt]mnt_flag .
205This can be used, for instance, to convert a read-only filesystem to
206read-write.
207If the MNT_UPDATE flag is not specified, then this is a newly
208mounted filesystem.
209.It Fn VFS_START "mp" "flags" "p"
210Make the file system specified by the mount structure
211.Fa mp
212operational.
213The argument
214.Fa p
215is the calling process.
216The argument
217.Fa flags
218is a set of flags for controlling the operation of
219.Fn VOP_START .
220This function is invoked after
221.Fn VFS_MOUNT
222and before the first access to the file system.
223.It Fn VFS_UNMOUNT "mp" "mntflags" "p"
224Unmount a file system specified by the mount structure
225.Fa mp .
226The argument
227.Fa p
228is the calling process.
229.Fn VFS_UNMOUNT
230performs any file system type specific operations required before the
231file system is unmounted, such are flushing buffers.
232If MNT_FORCE is specified in the flags
233.Fa mntflags
234then open files are forcibly closed.
235The function also deallocates space associated with data structure
236that were allocated for the file system when it was mounted.
237.It Fn VFS_ROOT "mp" "vpp"
238Get the root vnode of the file system specified by the mount
239structure
240.Fa mp .
241The vnode is returned in the address given by
242.Fa vpp .
243This function is used by the pathname translation algorithms when a
244vnode that has been covered by a mounted file system is encountered.
245While resolving the pathname, the pathname translation algorithm will
246have to go through the directory tree in the file system associated
247with that mount point and therefore requires the root vnode of the
248file system.
249.It Fn VFS_QUOTACTL "mp" "cmds" "uid" "arg" "p"
250Query/modify user space quotas for the file system specified by the
251mount structure
252.Fa mp .
253The argument specifies the control command to perform.
254The userid is specified in
255.Fa id ,
256the calling process is
257.Fa p
258and
259.Fa arg
260allows command-specific data to be returned to the system call
261interface.
262.Fn VFS_QUOTACTL
263is the file system type specific implementation of the
264.Xr quotactl 2
265system call.
266.It Fn VFS_STATFS "mp" "sbp" "p"
267Get file system statistics for the file system specified by the mount
268structure
269.Fa mp .
270The argument
271.Fa p
272is the calling process.
273A statfs structure filled with the statistics is returned in
274.Fa sbp .
275.Fn VFS_STATFS
276is the file system type specific implementation of the
277.Xr statfs 2
278and
279.Xr fstatfs 2
280system calls.
281.It Fn VFS_SYNC "mp" "waitfor" "cred" "p"
282Flush file system I/O buffers for the file system specified by the mount
283structure
284.Fa mp .
285The
286.Fa waitfor
287argument indicates whether a partial flush or complete flush should be
288performed.
289The arguments
290.Fa p
291and
292.Fa cred
293specific the calling process and its credentials respectively.
294.Fn VFS_SYNC
295does not provide any return value since the operation can never fail.
296.It Fn VFS_VGET "mp" "ino" "vpp"
297Get vnode for a file system type specific file id
298.Fa ino
299for the file system specified by the mount structure
300.Fa mp .
301The vnode is returned in the address specified
302.Fa vpp .
303The function is optional for file systems which have a unique id
304number for every file in the file system.
305It is used internally by the UFS file system and also by the NFSv3
306server to implement the READDIRPLUS nfs call.
307If the file system does not support this function, it should return
308.Er EOPNOTSUPP .
309.It Fn VFS_FHTOVP "mp" "fhp" "vpp"
310Get the vnode for the NFS file specified by the file handle
311.Fa fhp
312in the file system specified by the mount structure
313.Fa mp .
314The locked vnode is returned in
315.Fa vpp .
316.Pp
317A call to
318.Fn VFS_FHTOVP
319should generally be followed by a call to
320.Fn VFS_CHECKEXP
321to check if the file is accessable to the client.
322.It Fn VFS_VPTOFH "vp" "fhp"
323Get a unique NFS file handle for the file specified by the vnode
324.Fa vp .
325The file handle is returned in
326.Fa fhp .
327The contents of the file handle are defined by the file system and are
328not examined by any other subsystems.
329It should contain enough information to uniquely identify a file within
330the file system as well as noticing when a file has been removed and
331the file system resources have been recycled for a new file.
332.It Fn VFS_CHECKEXP "mp" "nam" "extflagsp" "credanonp"
333Check if the file system specified by the mount structure
334.Fa mp
335is exported to a client with anonymous credentials
336.Fa credanonp .
337The argument
338.Fa nam
339is an mbuf containing the network address of the client.
340The return parameters for the export flags for the client are returned
341in the address specified by
342.Fa exflagsp .
343This function is used by the NFS server.
344It is generally invoked before
345.Fn VFS_FHTOVP
346to validate that client has access to the file system.
347The file system should call
348.Fn vfs_export_lookup
349with the address of an appropriate netexport structure and the address
350of the client to verify that the client can access this file system.
351.It Fn VFS_SNAPSHOT "mp" "vp" "ts"
352Take a snapshot of the file system specified by the mount structure
353.Fa mp
354and make it accessible through the locked vnode
355.Fa vp .
356If
357.Fa ts
358is not
359.Dv NULL
360it will receive the time this snapshot was taken.
361If the file system does not support this function, it should return
362.Er EOPNOTSUPP .
363.El
364.Sh CODE REFERENCES
365This section describes places within the
366.Nx
367source tree where actual code implementing or using the vfs
368operations can be found.
369All pathnames are relative to
370.Pa /usr/src .
371.Pp
372The vfs operations are implemented within the files
373.Pa sys/kern/vfs_subr.c
374and
375.Pa sys/kern/vfs_init.c .
376.Sh SEE ALSO
377.Xr intro 9 ,
378.Xr namei 9 ,
379.Xr vfs 9 ,
380.Xr vfssubr 9 ,
381.Xr vnode 9 ,
382.Xr vnodeops 9
383.Sh HISTORY
384The vfs operations vector, its functions and the corresponding macros
385appeared in
386.Bx 4.3 .
387