xref: /freebsd/share/man/man3/pthread_rwlock_wrlock.3 (revision ec7452f103d56cccf279cec74a22025f980bbda5)
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
36ec7452f1SRuslan Ermilov.Lb libpthread
37c0e36632SAlexander Langer.Sh SYNOPSIS
3832eef9aeSRuslan Ermilov.In pthread.h
39c0e36632SAlexander Langer.Ft int
40c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock "pthread_rwlock_t *lock"
41c0e36632SAlexander Langer.Ft int
42c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock "pthread_rwlock_t *lock"
43c0e36632SAlexander Langer.Sh DESCRIPTION
44c0e36632SAlexander LangerThe
45c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock
46c0e36632SAlexander Langerfunction blocks until a write lock can be acquired against
47c0e36632SAlexander Langer.Fa lock .
48c0e36632SAlexander LangerThe
49c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock
50c0e36632SAlexander Langerfunction performs the same action, but does not block if the lock
51c0e36632SAlexander Langercannot be immediately obtained.
52c0e36632SAlexander Langer.Pp
53c0e36632SAlexander LangerThe results are undefined if the calling thread already holds the
54c0e36632SAlexander Langerlock at the time the call is made.
55c0e36632SAlexander Langer.Sh IMPLEMENTATION NOTES
56c0e36632SAlexander LangerTo prevent writer starvation, writers are favored over readers.
57c0e36632SAlexander Langer.Sh RETURN VALUES
58c0e36632SAlexander LangerIf successful, the
59c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock
60c0e36632SAlexander Langerand
61c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock
62c0e36632SAlexander Langerfunctions will return zero.  Otherwise an error number will be returned
63c0e36632SAlexander Langerto indicate the error.
64c0e36632SAlexander Langer.Sh SEE ALSO
65facc6767SRuslan Ermilov.Xr pthread_rwlock_init 3 ,
66facc6767SRuslan Ermilov.Xr pthread_rwlock_rdlock 3 ,
67facc6767SRuslan Ermilov.Xr pthread_rwlock_tryrdlock 3 ,
68facc6767SRuslan Ermilov.Xr pthread_rwlock_unlock 3
69c0e36632SAlexander Langer.Sh STANDARDS
70c0e36632SAlexander LangerThe
71c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock
72c0e36632SAlexander Langerand
73c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock
74c0e36632SAlexander Langerfunctions are expected to conform to
75c0e36632SAlexander Langer.St -susv2 .
76c0e36632SAlexander Langer.Sh ERRORS
77c0e36632SAlexander LangerThe
78c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock
79c0e36632SAlexander Langerfunction will fail if:
80c0e36632SAlexander Langer.Bl -tag -width Er
81c0e36632SAlexander Langer.It Bq Er EBUSY
82c0e36632SAlexander LangerThe calling thread is not able to acquire the lock without blocking.
83c0e36632SAlexander Langer.El
84c0e36632SAlexander Langer.Pp
85c0e36632SAlexander LangerThe
86c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock
87c0e36632SAlexander Langerand
88c0e36632SAlexander Langer.Fn pthread_rwlock_trywrlock
89c0e36632SAlexander Langerfunctions may fail if:
90c0e36632SAlexander Langer.Bl -tag -width Er
91c0e36632SAlexander Langer.It Bq Er EDEADLK
92c0e36632SAlexander LangerThe calling thread already owns the read/write lock (for reading
93c0e36632SAlexander Langeror writing).
94c0e36632SAlexander Langer.It Bq Er EINVAL
95c0e36632SAlexander LangerThe value specified by
96c0e36632SAlexander Langer.Fa lock
97c0e36632SAlexander Langeris invalid.
98c0e36632SAlexander Langer.It Bq Er ENOMEM
99c0e36632SAlexander LangerInsufficient memory exists to initialize the lock (applies to
100c0e36632SAlexander Langerstatically initialized locks only).
101c0e36632SAlexander Langer.El
102c0e36632SAlexander Langer.Sh HISTORY
103c0e36632SAlexander LangerThe
104c0e36632SAlexander Langer.Fn pthread_rwlock_wrlock
105c0e36632SAlexander Langerfunction first appeared in
106c0e36632SAlexander Langer.Fx 3.0 .
107