(pthread_mutex_timedlock): Document restrictions of mutex types.

This commit is contained in:
Ulrich Drepper 2000-06-26 16:39:37 +00:00
parent c49ebf7645
commit 1e9bbdd87f

View File

@ -27,9 +27,9 @@ use @var{errno}.
different threads. different threads.
* Threads and Signal Handling:: Why you should avoid mixing the two, and * Threads and Signal Handling:: Why you should avoid mixing the two, and
how to do it if you must. how to do it if you must.
* Threads and Fork:: Interactions between threads and the * Threads and Fork:: Interactions between threads and the
@code{fork} function. @code{fork} function.
* Streams and Fork:: Interactions between stdio streams and * Streams and Fork:: Interactions between stdio streams and
@code{fork}. @code{fork}.
* Miscellaneous Thread Functions:: A grab bag of utility routines. * Miscellaneous Thread Functions:: A grab bag of utility routines.
@end menu @end menu
@ -597,6 +597,25 @@ calling thread in the case of a ``fast'' mutex). Instead,
@code{EBUSY}. @code{EBUSY}.
@end deftypefun @end deftypefun
@comment pthread.h
@comment POSIX
@deftypefun int pthread_mutex_timedlock (pthread_mutex_t *@var{mutex}, const struct timespec *@var{abstime})
The @code{pthread_mutex_timedlock} is similar to the
@code{pthread_mutex_lock} function but instead of blocking for in
indefinite time if the mutex is locked by another thread, it returns
when the time specified in @var{abstime} is reached.
This function can only be used on standard (``timed'') and ``error
checking'' mutexes. It behaves just like @code{pthread_mutex_lock} for
all other types.
If the mutex is successfully locked, the function returns zero. If the
time specified in @var{abstime} is reached without the mutex being locked,
@code{ETIMEDOUT} is returned.
This function was introduced in the POSIX.1d revision of the POSIX standard.
@end deftypefun
@comment pthread.h @comment pthread.h
@comment POSIX @comment POSIX
@deftypefun int pthread_mutex_unlock (pthread_mutex_t *@var{mutex}) @deftypefun int pthread_mutex_unlock (pthread_mutex_t *@var{mutex})
@ -1254,7 +1273,7 @@ interaction between @code{fork} and some library features like
When @code{fork} is called by one of the threads of a process, it creates a new When @code{fork} is called by one of the threads of a process, it creates a new
process which is copy of the calling process. Effectively, in addition to process which is copy of the calling process. Effectively, in addition to
copying certain system objects, the function takes a snapshot of the memory copying certain system objects, the function takes a snapshot of the memory
areas of the parent process, and creates identical areas in the child. areas of the parent process, and creates identical areas in the child.
To make matters more complicated, with threads it's possible for two or more To make matters more complicated, with threads it's possible for two or more
threads to concurrently call fork to create two or more child processes. threads to concurrently call fork to create two or more child processes.
@ -1311,7 +1330,7 @@ Registering a triplet of handlers is an atomic operation with respect to fork.
If new handlers are registered at about the same time as a fork occurs, either If new handlers are registered at about the same time as a fork occurs, either
all three handlers will be called, or none of them will be called. all three handlers will be called, or none of them will be called.
The handlers are inherited by the child process, and there is no The handlers are inherited by the child process, and there is no
way to remove them, short of using @code{exec} to load a new way to remove them, short of using @code{exec} to load a new
pocess image. pocess image.
@ -1324,7 +1343,7 @@ are not running in the child process. Thus, if a mutex is locked by a
thread other than the thread calling @code{fork}, that mutex will remain thread other than the thread calling @code{fork}, that mutex will remain
locked forever in the child process, possibly blocking the execution of locked forever in the child process, possibly blocking the execution of
the child process. Or if some shared data, such as a linked list, was in the the child process. Or if some shared data, such as a linked list, was in the
middle of being updated by a thread in the parent process, the child middle of being updated by a thread in the parent process, the child
will get a copy of the incompletely updated data which it cannot use. will get a copy of the incompletely updated data which it cannot use.
To avoid this, install handlers with @code{pthread_atfork} as follows: have the To avoid this, install handlers with @code{pthread_atfork} as follows: have the
@ -1363,7 +1382,7 @@ ensure this is to use @code{flockfile} to lock the stream prior to calling
@code{fork} and then unlock it with @code{funlockfile} inside the parent @code{fork} and then unlock it with @code{funlockfile} inside the parent
process, provided that the parent's threads properly honor these locks. process, provided that the parent's threads properly honor these locks.
Nothing special needs to be done in the child process, since the library Nothing special needs to be done in the child process, since the library
internally resets all stream locks. internally resets all stream locks.
Note that the stream locks are not shared between the parent and child. Note that the stream locks are not shared between the parent and child.
For example, even if you ensure that, say, the stream @code{stdout} is properly For example, even if you ensure that, say, the stream @code{stdout} is properly