|
Line 0
Link Here
|
|
|
1 |
.\" |
| 2 |
.\" Copyright (c) 2003 Bruce M Simpson <bms@spc.org> |
| 3 |
.\" All rights reserved. |
| 4 |
.\" |
| 5 |
.\" Redistribution and use in source and binary forms, with or without |
| 6 |
.\" modification, are permitted provided that the following conditions |
| 7 |
.\" are met: |
| 8 |
.\" 1. Redistributions of source code must retain the above copyright |
| 9 |
.\" notice, this list of conditions and the following disclaimer. |
| 10 |
.\" 2. Redistributions in binary form must reproduce the above copyright |
| 11 |
.\" notice, this list of conditions and the following disclaimer in the |
| 12 |
.\" documentation and/or other materials provided with the distribution. |
| 13 |
.\" |
| 14 |
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND |
| 15 |
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 16 |
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| 17 |
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE |
| 18 |
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
| 19 |
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS |
| 20 |
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) |
| 21 |
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT |
| 22 |
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY |
| 23 |
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF |
| 24 |
.\" SUCH DAMAGE. |
| 25 |
.\" |
| 26 |
.\" $FreeBSD$ |
| 27 |
.\" |
| 28 |
.Dd July 19, 2003 |
| 29 |
.Dt vm_map_lock 9 |
| 30 |
.Sh NAME |
| 31 |
.Nm vm_map_lock , |
| 32 |
.Nm vm_map_unlock , |
| 33 |
.Nm vm_map_lock_read , |
| 34 |
.Nm vm_map_unlock_read , |
| 35 |
.Nm vm_map_trylock , |
| 36 |
.Nm vm_map_trylock_read , |
| 37 |
.Nm vm_map_lock_upgrade , |
| 38 |
.Nm vm_map_lock_downgrade |
| 39 |
.Nd vm_map locking macros |
| 40 |
.Sh SYNOPSIS |
| 41 |
.In sys/param.h |
| 42 |
.In vm/vm.h |
| 43 |
.In vm/vm_map.h |
| 44 |
.Ft void |
| 45 |
.Fn vm_map_lock "vm_map_t map" |
| 46 |
.Ft void |
| 47 |
.Fn vm_map_unlock "vm_map_t map" |
| 48 |
.Ft void |
| 49 |
.Fn vm_map_lock_read "vm_map_t map" |
| 50 |
.Ft void |
| 51 |
.Fn vm_map_unlock_read "vm_map_t map" |
| 52 |
.Ft int |
| 53 |
.Fn vm_map_trylock "vm_map_t map" |
| 54 |
.Ft int |
| 55 |
.Fn vm_map_trylock_read "vm_map_t map" |
| 56 |
.Ft int |
| 57 |
.Fn vm_map_lock_upgrade "vm_map_t map" |
| 58 |
.Ft int |
| 59 |
.Fn vm_map_lock_downgrade "vm_map_t map" |
| 60 |
.Sh DESCRIPTION |
| 61 |
The |
| 62 |
.Fn vm_map_lock |
| 63 |
macro obtains an exclusive lock on |
| 64 |
.Fa map . |
| 65 |
.Pp |
| 66 |
The |
| 67 |
.Fn vm_map_unlock |
| 68 |
macro releases an exclusive lock on |
| 69 |
.Fa map . |
| 70 |
.Pp |
| 71 |
The |
| 72 |
.Fn vm_map_lock_read |
| 73 |
macro obtains a read-lock on |
| 74 |
.Fa map . |
| 75 |
Currently this is implemented as an exclusive lock. |
| 76 |
.Pp |
| 77 |
The |
| 78 |
.Fn vm_map_unlock_read |
| 79 |
macro releases a read-lock on |
| 80 |
.Fa map . |
| 81 |
.Pp |
| 82 |
The |
| 83 |
.Fn vm_map_trylock |
| 84 |
macro attempts to obtain an exclusive lock on |
| 85 |
.Fa map . |
| 86 |
It returns FALSE if the lock cannot be immediately acquired; |
| 87 |
otherwise return TRUE with the lock acquired. |
| 88 |
.Pp |
| 89 |
The |
| 90 |
.Fn vm_map_trylock_read |
| 91 |
macro attempts to obtain a read-lock on |
| 92 |
.Fa map . |
| 93 |
It returns FALSE if the lock cannot be immediately acquired; |
| 94 |
otherwise return TRUE with the lock acquired. |
| 95 |
Currently this is implemented as an exclusive lock. |
| 96 |
.Pp |
| 97 |
The |
| 98 |
.Fn vm_map_lock_upgrade |
| 99 |
macro attempts to atomically upgrade a read-lock on |
| 100 |
.Fa map |
| 101 |
to an exclusive lock. |
| 102 |
As read-locks are currently implemented as exclusive locks, |
| 103 |
this macro is a no-op. |
| 104 |
.Pp |
| 105 |
The |
| 106 |
.Fn vm_map_lock_downgrade |
| 107 |
macro attempts to downgrade an exclusive lock on |
| 108 |
.Fa map |
| 109 |
to a read-lock. |
| 110 |
As read-locks are currently implemented as exclusive locks, |
| 111 |
this macro is a no-op. |
| 112 |
.Sh SEE ALSO |
| 113 |
.Xr vm_map 9 |
| 114 |
.Sh AUTHORS |
| 115 |
This man page was written by |
| 116 |
.An Bruce M Simpson Aq bms@spc.org . |