summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--share/man/man9/vnsubr.974
1 files changed, 45 insertions, 29 deletions
diff --git a/share/man/man9/vnsubr.9 b/share/man/man9/vnsubr.9
index 291235cf42c..bcdac61c796 100644
--- a/share/man/man9/vnsubr.9
+++ b/share/man/man9/vnsubr.9
@@ -1,4 +1,4 @@
-.\" $OpenBSD: vnsubr.9,v 1.3 2005/05/31 22:59:29 jmc Exp $
+.\" $OpenBSD: vnsubr.9,v 1.4 2005/06/02 15:42:12 jaredy Exp $
.\" $NetBSD: vnsubr.9,v 1.21 2004/05/25 14:54:56 hannken Exp $
.\"
.\" Copyright (c) 2001 The NetBSD Foundation, Inc.
@@ -48,7 +48,7 @@
.Nm vn_rdwr ,
.Nm vn_open ,
.Nm vn_stat ,
-.Nm vn_writechk ,
+.Nm vn_writechk
.Nd high-level convenience functions for vnode operations
.Sh SYNOPSIS
.In sys/param.h
@@ -90,13 +90,13 @@ is the unlocked vnode of the vnode to close.
simply locks the vnode, invokes the vnode operation
.Fn VOP_CLOSE
and calls
-.Fn vput
+.Xr vput 9
to return the vnode to the freelist or holdlist.
Note that
.Fn vn_close
expects an unlocked, referenced vnode and will dereference the vnode
prior to returning.
-If the operation is successful zero is returned,
+If the operation is successful, zero is returned;
otherwise an appropriate error is returned.
.It Fn vn_default_error "v"
A generic "default" routine that just returns error.
@@ -118,7 +118,7 @@ is intended to be used in
etc., to ensure that
.Xr chroot 2
actually means something.
-If the operation is successful zero is returned, otherwise 1 is returned.
+If the operation is successful, zero is returned; otherwise 1 is returned.
.It Fn vn_lock "vp" "flags" "p"
Acquire the vnode lock.
Certain file system operations require that
@@ -132,7 +132,7 @@ The
function must not be called when the vnode's reference count is
zero.
Instead, the
-.Fn vget
+.Xr vget 9
function should be used.
.Pp
The
@@ -145,7 +145,7 @@ Return the vnode even if it has been reclaimed.
Must be set if the caller owns the vnode interlock.
.It Dv LK_NOWAIT Ta
Don't wait if the vnode lock is held by someone else (may still
-wait on reclamation lock on or interlock).
+wait on reclamation lock or on interlock).
Must not be used with
.Dv LK_RETRY .
.It Dv LK_EXCLUSIVE Ta
@@ -157,7 +157,6 @@ Acquire a shared lock.
The
.Fn vn_lock
function can sleep.
-The
.Fn vn_lock
releases the vnode interlock before exit.
.It Fn vn_marktext "vp"
@@ -166,7 +165,9 @@ Common code to mark the vnode
as being the text of a running process.
.It Fn vn_open "ndp" "fmode" "cmode"
Common code for vnode open operations.
-The pathname is described in the nameidata pointer (see
+The pathname is described in the
+.Vt nameidata
+pointer (see
.Xr namei 9 ) .
The arguments
.Fa fmode
@@ -176,23 +177,28 @@ specify the
.Xr open 2
file mode and the access permissions for creation.
.Fn vn_open
-checks permissions and invokes the
-.Fn VOP_OPEN
+checks permissions and invokes the
+.Xr VOP_OPEN 9
or
.Xr VOP_CREATE 9
vnode operations.
-If the operation is successful zero is returned,
+If the operation is successful, zero is returned;
otherwise an appropriate error code is returned.
-.It Xo Fo vn_rdwr "enum uio_rw rw" "struct vnode *vp" "caddr_t base"
-.Fa "int len" "off_t offset" "enum uio_seg segflg" "int ioflg"
-.Fa "struct ucred *cred" "size_t *aresid" "struct proc *p"
+.It Xo
+.Fo vn_rdwr
+.Fa "rw" "vp" "base" "len" "offset"
+.Fa "segflg" "ioflg" "cred" "aresid" "p"
.Fc
.Xc
-Common code to package up an I/O request on a vnode into a uio and
-then perform the I/O.
+Common code to package up an I/O request on a vnode into a
+.Vt uio
+and then perform the I/O.
The argument
.Fa rw
-specifies whether the I/O is a read (UIO_READ) or write (UIO_WRITE)
+specifies whether the I/O is a read
+.Pq Dv UIO_READ
+or write
+.Pq Dv UIO_WRITE
operation.
The unlocked vnode is specified by
.Fa vp .
@@ -201,8 +207,10 @@ The arguments
and
.Fa cred
are the calling process and its credentials.
-The remaining arguments specify the uio parameters.
-For further information on these parameters see
+The remaining arguments specify the
+.Vt uio
+parameters.
+For further information on these parameters, see
.Xr uiomove 9 .
.It Fn vn_stat "vp" "sb" "p"
Common code for a vnode stat operation.
@@ -210,33 +218,42 @@ The vnode is specified by the argument
.Fa vp ,
and
.Fa sb
-is the buffer to return the stat information.
+is the buffer in which to store the stat information.
The argument
.Fa p
is the calling process.
.Fn vn_stat
basically calls the vnode operation
-.Fn VOP_GETATTR
-and transfers the contents of a vattr structure into a struct stat.
-If the operation is successful zero is returned, otherwise an
+.Xr VOP_GETATTR 9
+and transfers the contents of a
+.Vt vattr
+structure into a
+.Vt struct stat .
+If the operation is successful, zero is returned; otherwise an
appropriate error code is returned.
.It Fn vn_writechk "vp"
Common code to check for write permission on the vnode
.Fa vp .
A vnode is read-only if it is in use as a process's text image.
-If the vnode is read-only ETEXTBSY is returned, otherwise zero is
+If the vnode is read-only,
+.Er ETXTBSY
+is returned; otherwise zero is
returned to indicate that the vnode can be written to.
.El
.Sh ERRORS
.Bl -tag -width Er
.It Bq Er ETXTBSY
-Cannot write to a vnode since is a process's text image.
+Cannot write to a vnode since it is a process's text image.
.It Bq Er ENOENT
The vnode has been reclaimed and is dead.
-This error is only returned if the LK_RETRY flag is not passed to
+This error is only returned if the
+.Dv LK_RETRY
+flag is not passed to
.Fn vn_lock .
.It Bq Er EBUSY
-The LK_NOWAIT flag was set and
+The
+.Dv LK_NOWAIT
+flag was set and
.Fn vn_lock
would have slept.
.El
@@ -254,7 +271,6 @@ and
.Pa sys/sys/vnode.h .
.Sh SEE ALSO
.Xr file 9 ,
-.Xr intro 9 ,
.Xr lock 9 ,
.Xr namei 9 ,
.Xr vfs 9 ,