1997-03-03 18:01:01 +00:00
|
|
|
.\" -*- nroff -*-
|
|
|
|
.\"
|
|
|
|
.\" Copyright (c) 1996 Doug Rabson
|
|
|
|
.\"
|
|
|
|
.\" All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" This program is free software.
|
|
|
|
.\"
|
|
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
|
|
.\" modification, are permitted provided that the following conditions
|
|
|
|
.\" are met:
|
|
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
|
|
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
|
|
.\" IN NO EVENT SHALL THE DEVELOPERS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
|
|
|
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
|
|
|
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
|
|
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.\"
|
1999-08-28 00:22:10 +00:00
|
|
|
.\" $FreeBSD$
|
1997-03-03 18:01:01 +00:00
|
|
|
.\"
|
2008-02-25 19:12:01 +00:00
|
|
|
.Dd February 25, 2008
|
1997-03-03 18:01:01 +00:00
|
|
|
.Dt VOP_LOCK 9
|
2010-04-14 19:08:06 +00:00
|
|
|
.Os
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh NAME
|
|
|
|
.Nm VOP_LOCK ,
|
|
|
|
.Nm VOP_UNLOCK ,
|
1999-03-17 20:17:32 +00:00
|
|
|
.Nm VOP_ISLOCKED ,
|
|
|
|
.Nm vn_lock
|
1997-03-03 18:01:01 +00:00
|
|
|
.Nd serialize access to a vnode
|
|
|
|
.Sh SYNOPSIS
|
2001-10-01 16:09:29 +00:00
|
|
|
.In sys/param.h
|
|
|
|
.In sys/lock.h
|
|
|
|
.In sys/vnode.h
|
1997-03-03 18:01:01 +00:00
|
|
|
.Ft int
|
2008-01-18 22:09:29 +00:00
|
|
|
.Fn VOP_LOCK "struct vnode *vp" "int flags"
|
1997-03-03 18:01:01 +00:00
|
|
|
.Ft int
|
2008-01-18 22:09:29 +00:00
|
|
|
.Fn VOP_UNLOCK "struct vnode *vp" "int flags"
|
1997-03-03 18:01:01 +00:00
|
|
|
.Ft int
|
2008-02-25 19:12:01 +00:00
|
|
|
.Fn VOP_ISLOCKED "struct vnode *vp"
|
1999-03-17 20:17:32 +00:00
|
|
|
.Ft int
|
2008-01-10 01:23:59 +00:00
|
|
|
.Fn vn_lock "struct vnode *vp" "int flags"
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh DESCRIPTION
|
2002-12-12 17:26:04 +00:00
|
|
|
These calls are used to serialize access to the file system, such as
|
1999-03-17 20:17:32 +00:00
|
|
|
to prevent two writes to the same file from happening at the
|
|
|
|
same time.
|
|
|
|
.Pp
|
1997-03-03 18:01:01 +00:00
|
|
|
The arguments are:
|
1999-03-17 20:17:32 +00:00
|
|
|
.Bl -tag -width flags
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa vp
|
2005-01-28 10:43:05 +00:00
|
|
|
The vnode being locked or unlocked.
|
2003-05-31 14:07:25 +00:00
|
|
|
.It Fa flags
|
1999-03-17 20:17:32 +00:00
|
|
|
One of the lock request types:
|
2005-01-28 10:43:05 +00:00
|
|
|
.Pp
|
2007-12-28 00:38:13 +00:00
|
|
|
.Bl -tag -width ".Dv LK_CANRECURSE" -offset indent -compact
|
2005-01-28 10:43:05 +00:00
|
|
|
.It Dv LK_SHARED
|
|
|
|
Shared lock.
|
|
|
|
.It Dv LK_EXCLUSIVE
|
|
|
|
Exclusive lock.
|
|
|
|
.It Dv LK_UPGRADE
|
|
|
|
Shared-to-exclusive upgrade.
|
|
|
|
.It Dv LK_DOWNGRADE
|
|
|
|
Exclusive-to-shared downgrade.
|
|
|
|
.It Dv LK_RELEASE
|
|
|
|
Release any type of lock.
|
|
|
|
.It Dv LK_DRAIN
|
|
|
|
Wait for all lock activity to end.
|
1997-03-03 18:01:01 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
1999-03-17 20:17:32 +00:00
|
|
|
The lock type may be
|
|
|
|
.Em or Ns 'ed
|
|
|
|
with these lock flags:
|
2005-01-28 10:43:05 +00:00
|
|
|
.Pp
|
2007-12-28 00:38:13 +00:00
|
|
|
.Bl -tag -width ".Dv LK_CANRECURSE" -offset indent -compact
|
2005-01-28 10:43:05 +00:00
|
|
|
.It Dv LK_NOWAIT
|
|
|
|
Do not sleep to wait for lock.
|
|
|
|
.It Dv LK_SLEEPFAIL
|
|
|
|
Sleep, then return failure.
|
|
|
|
.It Dv LK_CANRECURSE
|
|
|
|
Allow recursive exclusive lock.
|
2008-06-05 17:07:33 +00:00
|
|
|
.It Dv LK_NOWITNESS
|
|
|
|
Instruct
|
|
|
|
.Xr witness 4
|
|
|
|
to ignore this instance.
|
1999-03-17 20:17:32 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
The lock type may be
|
|
|
|
.Em or Ns 'ed
|
|
|
|
with these control flags:
|
2005-01-28 10:43:05 +00:00
|
|
|
.Pp
|
2007-12-28 00:38:13 +00:00
|
|
|
.Bl -tag -width ".Dv LK_CANRECURSE" -offset indent -compact
|
2005-01-28 10:43:05 +00:00
|
|
|
.It Dv LK_INTERLOCK
|
|
|
|
Specify when the caller already has a simple lock
|
|
|
|
.Fn ( VOP_LOCK
|
|
|
|
will unlock the simple lock after getting the lock).
|
|
|
|
.It Dv LK_RETRY
|
|
|
|
Retry until locked.
|
1999-03-17 20:17:32 +00:00
|
|
|
.El
|
|
|
|
.Pp
|
|
|
|
Kernel code should use
|
|
|
|
.Fn vn_lock
|
|
|
|
to lock a vnode rather than calling
|
|
|
|
.Fn VOP_LOCK
|
|
|
|
directly.
|
2008-01-10 01:23:59 +00:00
|
|
|
.Fn vn_lock
|
2008-01-10 19:11:37 +00:00
|
|
|
also does not want a thread specified as argument but it
|
2008-01-10 01:23:59 +00:00
|
|
|
assumes curthread to be used.
|
2010-02-27 01:17:44 +00:00
|
|
|
.El
|
1997-03-03 18:01:01 +00:00
|
|
|
.Sh RETURN VALUES
|
|
|
|
Zero is returned on success, otherwise an error is returned.
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr vnode 9
|
|
|
|
.Sh AUTHORS
|
2005-06-28 20:15:19 +00:00
|
|
|
This manual page was written by
|
1998-03-12 07:31:21 +00:00
|
|
|
.An Doug Rabson .
|