diff options
Diffstat (limited to 'share/man')
-rw-r--r-- | share/man/man9/lock.9 | 291 |
1 files changed, 291 insertions, 0 deletions
diff --git a/share/man/man9/lock.9 b/share/man/man9/lock.9 new file mode 100644 index 00000000000..c1c2492b671 --- /dev/null +++ b/share/man/man9/lock.9 @@ -0,0 +1,291 @@ +.\" $NetBSD: lock.9,v 1.12 2001/11/01 01:13:43 wiz Exp $ +.\" +.\" Copyright (c) 2000 The NetBSD Foundation, Inc. +.\" All rights reserved. +.\" +.\" 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. +.\" 3. All advertising materials mentioning features or use of this software +.\" must display the following acknowledgement: +.\" This product includes software developed by the NetBSD +.\" Foundation, Inc. and its contributors. +.\" 4. Neither the name of The NetBSD Foundation nor the names of its +.\" contributors may be used to endorse or promote products derived +.\" from this software without specific prior written permission. +.\" +.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS +.\" ``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 FOUNDATION OR CONTRIBUTORS +.\" 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. +.\" +.Dd June 23, 2000 +.Dt LOCK 9 +.Os +.Sh NAME +.Nm lock , +.Nm simple_lock_init , +.Nm simple_lock , +.Nm simple_lock_try , +.Nm simple_unlock , +.Nm lockinit , +.Nm lockmgr , +.Nm lockstatus , +.Nm lockmgr_printinfo , +.Nd kernel lock functions +.Sh SYNOPSIS +.Fd #include \*[Lt]sys/lock.h\*[Gt] +.Ft void +.Fn simple_lock_init "struct simplelock *slock" +.Ft void +.Fn simple_lock "struct simplelock *slock" +.Ft int +.Fn simple_lock_try "struct simplelock *slock" +.Ft void +.Fn simple_unlock "struct simplelock *slock" +.Ft void +.Fn lockinit "struct lock *lock" "int prio" "const char *wmesg" \ +"int timo" "int flags" +.Ft int +.Fn lockmgr "struct lock *lock" "u_int flags" "struct simplelock *slock" \ +"struct proc *p" +.Ft int +.Fn lockstatus "struct lock *lock" +.Ft void +.Fn lockmgr_printinfo "struct lock *lock" +.Sh DESCRIPTION +The +.Nm +functions provide synchronisation in the kernel by preventing multiple +processes from simultaneously executing critical sections of code +accessing shared data. A number of different locks are available: +.Pp +.Bl -tag -width compact +.It struct simplelock +Provides a simple spinning mutex. A processor will busy-wait while +trying to acquire a simplelock. The simplelock operations are +implemented with machine-dependent locking primitives. +.Pp +Simplelocks are usually used only by the high-level lock manager and +to protect short, critical sections of code. Simplelocks are the only +locks that can be be used inside an interrupt handler. For a +simplelock to be used in an interrupt handler, care must be taken to +disable the interrupt, acquire the lock, do any processing, release +the simplelock and re-enable the interrupt. This procedure is +necessary to avoid deadlock between the interrupt handler and other +processes executing on the same processor. +.It struct lock +Provides a high-level lock supporting sleeping/spinning until the lock +can be acquired. The lock manager supplies both exclusive-access and +shared-access locks, with recursive exclusive-access locks within a +single process. It also allows upgrading a shared-access lock to an +exclusive-access lock, as well as downgrading an exclusive-access lock +to a shared-access lock. +.El +.Pp +If the kernel option LOCKDEBUG is enabled, additional facilities +are provided to record additional lock information. These facilities are +provided to assist in determining deadlock occurrences. +.Sh FUNCTIONS +The functions which operate on simplelocks are: +.Pp +.Bl -tag -width compact +.It Fn simple_lock_init "slock" +The simplelock +.Fa slock +is initialised to the unlocked state. A statically allocated simplelock +also can be initialised with the macro SIMPLELOCK_INITIALIZER. The +effect is the same as the dynamic initialisation by a call to +simple_lock_init. For example, +.Pp +struct simplelock slock = SIMPLELOCK_INITIALIZER; +.It Fn simple_lock "slock" +The simplelock +.Fa slock +is locked. If the simplelock is held then execution will +spin until the simplelock is acquired. Care must be taken that the +calling process does not already hold the simplelock. In this case, the +simplelock can never be acquired. If kernel option LOCKDEBUG is enabled, +a "locking against myself" panic will occur. +.It Fn simple_lock_try "slock" +Try to acquire the simplelock +.Fa slock +without spinning. If the simplelock is held by another process +then the return value is 0. If the simplelock was acquired +successfully then the return value is 1. +.It Fn simple_lock_unlock "slock" +The simplelock +.Fa slock +is unlocked. The simplelock must be locked and the calling process must +be the one that last acquired the simplelock. If the calling +process does not hold the simplelock, the simplelock will be released +but the kernel behaviour is undefined. +.El +.Pp +The functions which operate on locks are: +.Pp +.Bl -tag -width compact +.It Fn lockinit "lock" "prio" "wmesg" "timo" "flags" +The lock +.Fa lock +is initialised according to the parameters provided. Arguments are as +follows: +.Bl -tag -width compact +.It Fa lock +The lock. +.It Fa prio +The process priority when it is woken up after sleeping on the lock. +.It Fa wmesg +A sleep message used when a process goes to sleep waiting for the lock, so +that the exact reason it is sleeping can easily be identified. +.It Fa timo +The maximum sleep time. Used by +.Xr tsleep 9 . +.It Fa flags +Flags to specify the lock behaviour permanently over the lifetime of +the lock. Valid lock flags are: +.Bl -tag -width compact +.It LK_NOWAIT +Processes should not sleep when attempting to acquire the lock. +.It LK_SLEEPFAIL +Processes should sleep, then return failure when acquiring the lock. +.It LK_CANRECURSE +Processes can acquire the lock recursively. +.El +.El +.It Fn lockmgr "lock" "flags" "slock" +Set, change or release a lock according to the parameters provided. +Arguments are as follows: +.Bl -tag -width compact +.It Fa lock +The lock. +.It Fa slock +Simplelock interlock. If the flag LK_INTERLOCK is set in +.Fa flags , +.Fa slock +is a simplelock held by the caller. When the lock +.Fa lock +is acquired, the simplelock is released. If the flag LK_INTERLOCK is +not set, +.Fa slock +is ignored. +.It Fa flags +Flags to specify the lock request type. In addition to the flags +specified above, the following flags are valid: +.Bl -tag -width compact +.It LK_SHARED +Get one of many possible shared-access locks. If a process holding an +exclusive-access lock requests a shared-access lock, the +exclusive-access lock is downgraded to a shared-access lock. +.It LK_EXCLUSIVE +Stop further shared-access locks, when they are cleared, grant a +pending upgrade if it exists, then grant an exclusive-access lock. +Only one exclusive-access lock may exist at a time, except that a +process holding an exclusive-access lock may get additional +exclusive-access locks if it explicitly sets the LK_CANRECURSE flag in +the lock request, or if the LK_CANRECURSE flag was set when the lock +was initialised. +.It LK_UPGRADE +The process must hold a shared-access lock that it wants to have +upgraded to an exclusive-access lock. Other processes may get exclusive +access to the protected resource between the time that the upgrade is +requested and the time that it is granted. +.It LK_EXCLUPGRADE +The process must hold a shared-access lock that it wants to have +upgraded to an exclusive-access lock. If the request succeeds, no +other processes will have acquired exclusive access to the protected +resource between the time that the upgrade is requested and the time +that it is granted. However, if another process has already requested +an upgrade, the request will fail. +.It LK_DOWNGRADE +The process must hold an exclusive-access lock that it wants to have +downgraded to a shared-access lock. If the process holds multiple +(recursive) exclusive-access locks, they will all be downgraded to +shared-access locks. +.It LK_RELEASE +Release one instance of a lock. +.It LK_DRAIN +Wait for all activity on the lock to end, then mark it decommissioned. +This feature is used before freeing a lock that is part of a piece of +memory that is about to be freed. +.It LK_REENABLE +Lock is to be re-enabled after drain. The LK_REENABLE flag may be set +only at the release of a lock obtained by a drain. +.It LK_SETRECURSE +Other locks while we have it OK. +.It LK_RECURSEFAIL +Attempt at recursive lock fails. +.It LK_SPIN +Lock spins instead of sleeping. +.It LK_INTERLOCK +Unlock the simplelock +.Fa slock +when the lock is acquired. +.El +.El +.It Fn lockstatus "lock" +Determine the status of lock +.Fa lock . +Returns LK_EXCLUSIVE or LK_SHARED for exclusive-access and +shared-access locks respectively. +.It Fn lockmgr_printinfo "lock" +Print out information about state of lock +.Fa lock . +.El +.Sh RETURN VALUES +Successfully acquired locks return 0. A failed lock attempt always +returns a non-zero error value. No lock is held after an error +return (in particular, a failed LK_UPGRADE or LK_FORCEUPGRADE will +have released its shared-access lock). Locks will always succeed +unless one of the following is true: +.Bl -tag -width Er +.It Bq Er EBUSY +LK_FORCEUPGRADE is requested and some other process has already +requested a lock upgrade or LK_NOWAIT is set and a sleep would +be required. +.It Bq Er ENOLCK +LK_SLEEPFAIL is set and a sleep was done. +.It Bq Er EINTR +PCATCH is set in lock priority and a signal arrives to interrupt +a system call. +.It Bq Er ERESTART +PCATCH is set in lock priority and a signal arrives so that +the system call is restarted. +.It Bq Er EWOULDBLOCK +Non-null lock timeout and timeout expires. +.El +.Sh CODE REFERENCES +This section describes places within the +.Nx +source tree where actual code implementing or utilising the locking +framework can be found. All pathnames are relative to +.Pa /usr/src . +.Pp +The locking framework itself is implemented within the file +.Pa sys/kern/kern_lock.c . +Data structures and function prototypes for the framework are located +in +.Pa sys/sys/lock.h . +Machine-dependent simplelock primitives are implemented within the +file +.Pa sys/arch/\*[Lt]arch\*[Gt]/include/lock.h . +.Sh SEE ALSO +.Xr pmap 9 , +.Xr spl 9 , +.Xr tsleep 9 , +.Xr uvm 9 +.Sh HISTORY +The kernel locking API first appeared in +.Bx 4.4 -lite2 . |