rmutex(3synch)


rmutex: rmutex_init, rmutex_lock, rmutex_trylock, rmutex_unlock, rmutex_destroy -- overview of mutual exclusion lock routines

Synopsis

   cc [options] -Kthread file 
   

#include <synch.h>

int rmutex_init(rmutex_t *rmutex, int type, void *arg);

int rmutex_lock(rmutex_t *rmutex);

int rmutex_trylock(rmutex_t *rmutex);

int rmutex_unlock(rmutex_t *rmutex);

int rmutex_destroy(rmutex_t *rmutex);

Description

Mutual exclusion locks, or mutexes, are used to serialize the execution of threads. They are typically used to ensure that only one thread at a time accesses shared data. Recursive mutual exclusion locks, or rmutexes, are mutexes that can be locked recursively. That is, a thread that has locked an rmutex can lock it again without releasing it; the thread that has locked an rmutex is referred to as the owner of the rmutex. Only the owner of an rmutex can lock it again while the rmutex is locked; other threads are denied access as with ordinary mutexes. Each rmutex_lock(3synch) or rmutex_trylock(3synch) call must be matched by a corresponding rmutex_unlock before the rmutex is made available to threads other than the owner.

Note that rmutexes, like mutexes, protect data only when the convention of acquiring the rmutex is faithfully followed before any access of the data.

The Threads Library provides five routines to manipulate rmutexes; these are outlined below and described in more detail on individual manual pages.

Parameters

rmutex
pointer to rmutex to be initialized, locked, unlocked, or destroyed

type
USYNC_THREAD or USYNC_PROCESS

arg
NULL (reserved for future use)

rmutex_init(3synch)

rmutex_init initializes an rmutex to be of type type and in the unlocked state.

rmutex_lock(3synch)

rmutex_lock locks the rmutex pointed to by rmutex. If rmutex is locked by another thread, the calling thread is blocked until rmutex becomes available. When rmutex_lock returns successfully, the caller has locked rmutex.

If rmutex is already locked by the calling thread, the recursive depth is incremented and control is returned to the caller, as if the lock had just been acquired.

rmutex_trylock(3synch)

rmutex_trylock attempts once to acquire the rmutex pointed to by rmutex.

If rmutex is available, rmutex_trylock will return successfully with rmutex locked. If rmutex is already locked by another thread, rmutex_trylock immediately returns EBUSY to the caller without acquiring rmutex or blocking. If rmutex is already held by the calling thread, the recursive depth is incremented and control is returned to the caller, as if the lock had just been acquired.

rmutex_unlock(3synch)

rmutex_unlock unlocks the rmutex pointed to by rmutex. rmutex_unlock checks the identity of the caller and, if the caller is the current owner of rmutex, it checks the depth count.

If the caller is not the current owner of rmutex, that is, the caller does not hold the lock, rmutex_unlock will fail and return EACCES.

If there are one or more threads waiting for rmutex when it is unlocked, at least one waiting thread is allowed to try again to lock rmutex.

rmutex_destroy

rmutex_destroy destroys the rmutex pointed to by rmutex. This includes invalidating rmutex and freeing any associated implementation-allocated dynamic resources.

USYNC_THREAD and USYNC_PROCESS recursive mutexes

Recursive mutexes are initialized to be one of two types: USYNC_THREAD or USYNC_PROCESS. USYNC_THREAD rmutexes are available only to threads within the current process. USYNC_PROCESS rmutexes can be used by threads in different processes.

General information

Recursive mutexes must be initialized (see rmutex_init(3synch)), before being passed to any of the other rmutex routines.

Locks acquired with rmutex_lock or rmutex_trylock must be released with rmutex_unlock.

From the point of view of the caller, rmutex_lock is atomic: even if interrupted by a signal or forkall (see fork(2)), rmutex_lock will not return until it holds the locked rmutex. As a consequence, if rmutex_lock is interrupted, an error indication such as EINTR is never returned to the caller.

Warnings

If a thread exits while holding an rmutex, the rmutex will not be unlocked, and other threads waiting for the rmutex will wait forever. Similarly, if a process exits while holding a USYNC_PROCESS rmutex, the rmutex will not be unlocked, and other processes or threads waiting for the rmutex will wait forever.

References

fork(2), Intro(3synch), mutex(3synch), rmutex_init(3synch), rmutex_destroy(3synch), rmutex_lock(3synch), rmutex_trylock(3synch), rmutex_unlock(3synch)
30 January 1998
© 1998 The Santa Cruz Operation, Inc. All rights reserved.