1d3980376SJohn Polstra.\" 24e1635feSJohn Polstra.\" Copyright (c) 1999, 2000 John D. Polstra 3d3980376SJohn Polstra.\" All rights reserved. 4d3980376SJohn Polstra.\" 5d3980376SJohn Polstra.\" Redistribution and use in source and binary forms, with or without 6d3980376SJohn Polstra.\" modification, are permitted provided that the following conditions 7d3980376SJohn Polstra.\" are met: 8d3980376SJohn Polstra.\" 1. Redistributions of source code must retain the above copyright 9d3980376SJohn Polstra.\" notice, this list of conditions and the following disclaimer. 10d3980376SJohn Polstra.\" 2. Redistributions in binary form must reproduce the above copyright 11d3980376SJohn Polstra.\" notice, this list of conditions and the following disclaimer in the 12d3980376SJohn Polstra.\" documentation and/or other materials provided with the distribution. 13d3980376SJohn Polstra.\" 14d3980376SJohn Polstra.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15d3980376SJohn Polstra.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16d3980376SJohn Polstra.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17d3980376SJohn Polstra.\" ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18d3980376SJohn Polstra.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19d3980376SJohn Polstra.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20d3980376SJohn Polstra.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21d3980376SJohn Polstra.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22d3980376SJohn Polstra.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23d3980376SJohn Polstra.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24d3980376SJohn Polstra.\" SUCH DAMAGE. 25d3980376SJohn Polstra.\" 2659a821daSJohn Polstra.Dd July 5, 2000 27d3980376SJohn Polstra.Dt DLLOCKINIT 3 28*aa12cea2SUlrich Spörlein.Os 29d3980376SJohn Polstra.Sh NAME 30d3980376SJohn Polstra.Nm dllockinit 31d3980376SJohn Polstra.Nd register thread locking methods with the dynamic linker 3225bb73e0SAlexey Zelkin.Sh LIBRARY 3325bb73e0SAlexey Zelkin.Lb libc 34d3980376SJohn Polstra.Sh SYNOPSIS 3532eef9aeSRuslan Ermilov.In dlfcn.h 36d3980376SJohn Polstra.Ft void 37a37e09e4SBruce Evans.Fn dllockinit "void *context" "void *(*lock_create)(void *context)" "void (*rlock_acquire)(void *lock)" "void (*wlock_acquire)(void *lock)" "void (*lock_release)(void *lock)" "void (*lock_destroy)(void *lock)" "void (*context_destroy)(void *context)" 38d3980376SJohn Polstra.Sh DESCRIPTION 394e1635feSJohn Polstra.Bf Sy 4059a821daSJohn PolstraDue to enhancements in the dynamic linker, this interface is no longer 411a0a9345SRuslan Ermilovneeded. 421a0a9345SRuslan ErmilovIt is deprecated and will be removed from future releases. 4359a821daSJohn PolstraIn current releases it still exists, but only as a stub which does nothing. 444e1635feSJohn Polstra.Ef 454e1635feSJohn Polstra.Pp 46d3980376SJohn PolstraThreads packages can call 4795f4226bSRuslan Ermilov.Fn dllockinit 48d3980376SJohn Polstraat initialization time to register locking functions for the dynamic 491a0a9345SRuslan Ermilovlinker to use. 501a0a9345SRuslan ErmilovThis enables the dynamic linker to prevent multiple 51d3980376SJohn Polstrathreads from entering its critical sections simultaneously. 52d3980376SJohn Polstra.Pp 53d3980376SJohn PolstraThe 54d3980376SJohn Polstra.Fa context 551a0a9345SRuslan Ermilovargument specifies an opaque context for creating locks. 561a0a9345SRuslan ErmilovThe 57d3980376SJohn Polstradynamic linker will pass it to the 58d3980376SJohn Polstra.Fa lock_create 591a0a9345SRuslan Ermilovfunction when creating the locks it needs. 601a0a9345SRuslan ErmilovWhen the dynamic linker 61d3980376SJohn Polstrais permanently finished using the locking functions (e.g., if the 62d3980376SJohn Polstraprogram makes a subsequent call to 6395f4226bSRuslan Ermilov.Fn dllockinit 64d3980376SJohn Polstrato register new locking functions) it will call 65d3980376SJohn Polstra.Fa context_destroy 66d3980376SJohn Polstrato destroy the context. 67d3980376SJohn Polstra.Pp 68d3980376SJohn PolstraThe 69d3980376SJohn Polstra.Fa lock_create 701a0a9345SRuslan Ermilovargument specifies a function for creating a read/write lock. 711a0a9345SRuslan ErmilovIt 72d3980376SJohn Polstramust return a pointer to the new lock. 73d3980376SJohn Polstra.Pp 74d3980376SJohn PolstraThe 75d3980376SJohn Polstra.Fa rlock_acquire 76d3980376SJohn Polstraand 77d3980376SJohn Polstra.Fa wlock_acquire 782efeeba5SRuslan Ermilovarguments specify functions which lock a lock for reading or 791a0a9345SRuslan Ermilovwriting, respectively. 801a0a9345SRuslan ErmilovThe 81d3980376SJohn Polstra.Fa lock_release 821a0a9345SRuslan Ermilovargument specifies a function which unlocks a lock. 831a0a9345SRuslan ErmilovEach of these 84d3980376SJohn Polstrafunctions is passed a pointer to the lock. 85d3980376SJohn Polstra.Pp 86d3980376SJohn PolstraThe 87d3980376SJohn Polstra.Fa lock_destroy 881a0a9345SRuslan Ermilovargument specifies a function to destroy a lock. 891a0a9345SRuslan ErmilovIt may be 90d3980376SJohn Polstra.Dv NULL 911a0a9345SRuslan Ermilovif locks do not need to be destroyed. 921a0a9345SRuslan ErmilovThe 93d3980376SJohn Polstra.Fa context_destroy 941a0a9345SRuslan Ermilovargument specifies a function to destroy the context. 951a0a9345SRuslan ErmilovIt may be 96d3980376SJohn Polstra.Dv NULL 97d3980376SJohn Polstraif the context does not need to be destroyed. 98d3980376SJohn Polstra.Pp 997f205788SJohn PolstraUntil 10095f4226bSRuslan Ermilov.Fn dllockinit 1017f205788SJohn Polstrais called, the dynamic linker protects its critical sections using 1027f205788SJohn Polstraa default locking mechanism which works by blocking the 103d3980376SJohn Polstra.Dv SIGVTALRM , 104d3980376SJohn Polstra.Dv SIGPROF , 105d3980376SJohn Polstraand 106d3980376SJohn Polstra.Dv SIGALRM 1071a0a9345SRuslan Ermilovsignals. 1081a0a9345SRuslan ErmilovThis is sufficient for many application level threads 109d3980376SJohn Polstrapackages, which typically use one of these signals to implement 1101a0a9345SRuslan Ermilovpreemption. 1111a0a9345SRuslan ErmilovAn application which has registered its own locking 112d3980376SJohn Polstramethods with 11395f4226bSRuslan Ermilov.Fn dllockinit 114d3980376SJohn Polstracan restore the default locking by calling 11595f4226bSRuslan Ermilov.Fn dllockinit 116d3980376SJohn Polstrawith all arguments 117d3980376SJohn Polstra.Dv NULL . 118d3980376SJohn Polstra.Sh SEE ALSO 119d3980376SJohn Polstra.Xr rtld 1 , 120d3980376SJohn Polstra.Xr signal 3 121d3980376SJohn Polstra.Sh HISTORY 122d3980376SJohn PolstraThe 12395f4226bSRuslan Ermilov.Fn dllockinit 124b5c508fbSRuslan Ermilovfunction first appeared in 125b5c508fbSRuslan Ermilov.Fx 4.0 . 126