1c0e36632SAlexander Langer.\" Copyright (c) 1998 Alex Nash 2c0e36632SAlexander Langer.\" All rights reserved. 3c0e36632SAlexander Langer.\" 4c0e36632SAlexander Langer.\" Redistribution and use in source and binary forms, with or without 5c0e36632SAlexander Langer.\" modification, are permitted provided that the following conditions 6c0e36632SAlexander Langer.\" are met: 7c0e36632SAlexander Langer.\" 1. Redistributions of source code must retain the above copyright 8c0e36632SAlexander Langer.\" notice, this list of conditions and the following disclaimer. 9c0e36632SAlexander Langer.\" 2. Redistributions in binary form must reproduce the above copyright 10c0e36632SAlexander Langer.\" notice, this list of conditions and the following disclaimer in the 11c0e36632SAlexander Langer.\" documentation and/or other materials provided with the distribution. 12c0e36632SAlexander Langer.\" 13c0e36632SAlexander Langer.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 14c0e36632SAlexander Langer.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15c0e36632SAlexander Langer.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16c0e36632SAlexander Langer.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 17c0e36632SAlexander Langer.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18c0e36632SAlexander Langer.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19c0e36632SAlexander Langer.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20c0e36632SAlexander Langer.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21c0e36632SAlexander Langer.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22c0e36632SAlexander Langer.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23c0e36632SAlexander Langer.\" SUCH DAMAGE. 24c0e36632SAlexander Langer.\" 257f3dea24SPeter Wemm.\" $FreeBSD$ 26c0e36632SAlexander Langer.\" 27c0e36632SAlexander Langer.Dd August 4, 1998 28c0e36632SAlexander Langer.Dt PTHREAD_RWLOCK_WRLOCK 3 29c0e36632SAlexander Langer.Os 30c0e36632SAlexander Langer.Sh NAME 31c0e36632SAlexander Langer.Nm pthread_rwlock_wrlock , 32c0e36632SAlexander Langer.Nm pthread_rwlock_trywrlock 33c0e36632SAlexander Langer.Nd acquire a read/write lock for writing 34d8a78688SAlexey Zelkin.Sh LIBRARY 35d8a78688SAlexey Zelkin.Lb libc_r 36c0e36632SAlexander Langer.Sh SYNOPSIS 3732eef9aeSRuslan Ermilov.In pthread.h 38c0e36632SAlexander Langer.Ft int 39c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock "pthread_rwlock_t *lock" 40c0e36632SAlexander Langer.Ft int 41c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock "pthread_rwlock_t *lock" 42c0e36632SAlexander Langer.Sh DESCRIPTION 43c0e36632SAlexander LangerThe 44c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock 45c0e36632SAlexander Langerfunction blocks until a write lock can be acquired against 46c0e36632SAlexander Langer.Fa lock . 47c0e36632SAlexander LangerThe 48c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock 49c0e36632SAlexander Langerfunction performs the same action, but does not block if the lock 50c0e36632SAlexander Langercannot be immediately obtained. 51c0e36632SAlexander Langer.Pp 52c0e36632SAlexander LangerThe results are undefined if the calling thread already holds the 53c0e36632SAlexander Langerlock at the time the call is made. 54c0e36632SAlexander Langer.Sh IMPLEMENTATION NOTES 55c0e36632SAlexander LangerTo prevent writer starvation, writers are favored over readers. 56c0e36632SAlexander Langer.Sh RETURN VALUES 57c0e36632SAlexander LangerIf successful, the 58c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock 59c0e36632SAlexander Langerand 60c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock 61c0e36632SAlexander Langerfunctions will return zero. Otherwise an error number will be returned 62c0e36632SAlexander Langerto indicate the error. 63c0e36632SAlexander Langer.Sh SEE ALSO 64c0e36632SAlexander Langer.Xr pthread_rwlock_trywrlock 3 , 65c0e36632SAlexander Langer.Xr pthread_rwlock_unlock 3 , 66c0e36632SAlexander Langer.Xr pthread_rwlock_wrlock 3 67c0e36632SAlexander Langer.Sh STANDARDS 68c0e36632SAlexander LangerThe 69c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock 70c0e36632SAlexander Langerand 71c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock 72c0e36632SAlexander Langerfunctions are expected to conform to 73c0e36632SAlexander Langer.St -susv2 . 74c0e36632SAlexander Langer.Sh ERRORS 75c0e36632SAlexander LangerThe 76c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock 77c0e36632SAlexander Langerfunction will fail if: 78c0e36632SAlexander Langer.Bl -tag -width Er 79c0e36632SAlexander Langer.It Bq Er EBUSY 80c0e36632SAlexander LangerThe calling thread is not able to acquire the lock without blocking. 81c0e36632SAlexander Langer.El 82c0e36632SAlexander Langer.Pp 83c0e36632SAlexander LangerThe 84c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock 85c0e36632SAlexander Langerand 86c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock 87c0e36632SAlexander Langerfunctions may fail if: 88c0e36632SAlexander Langer.Bl -tag -width Er 89c0e36632SAlexander Langer.It Bq Er EDEADLK 90c0e36632SAlexander LangerThe calling thread already owns the read/write lock (for reading 91c0e36632SAlexander Langeror writing). 92c0e36632SAlexander Langer.It Bq Er EINVAL 93c0e36632SAlexander LangerThe value specified by 94c0e36632SAlexander Langer.Fa lock 95c0e36632SAlexander Langeris invalid. 96c0e36632SAlexander Langer.It Bq Er ENOMEM 97c0e36632SAlexander LangerInsufficient memory exists to initialize the lock (applies to 98c0e36632SAlexander Langerstatically initialized locks only). 99c0e36632SAlexander Langer.El 100c0e36632SAlexander Langer.Sh HISTORY 101c0e36632SAlexander LangerThe 102c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock 103c0e36632SAlexander Langerfunction first appeared in 104c0e36632SAlexander Langer.Fx 3.0 . 105