summaryrefslogtreecommitdiffstats
path: root/lib/libpthread
diff options
context:
space:
mode:
authorjb <jb@FreeBSD.org>1998-04-04 11:33:01 +0000
committerjb <jb@FreeBSD.org>1998-04-04 11:33:01 +0000
commitddcbf85eb29fd2d50ce1afa0243be370d4893370 (patch)
tree6098bb7060d793dec64ddd28bc6d9cda781d96ed /lib/libpthread
parent43c228762029d6d4e7c66cfd6c4d1e88d807dba1 (diff)
downloadFreeBSD-src-ddcbf85eb29fd2d50ce1afa0243be370d4893370.zip
FreeBSD-src-ddcbf85eb29fd2d50ce1afa0243be370d4893370.tar.gz
Enable static initialisation of mutexes and condition variables.
Diffstat (limited to 'lib/libpthread')
-rw-r--r--lib/libpthread/thread/thr_cond.c20
-rw-r--r--lib/libpthread/thread/thr_mutex.c20
2 files changed, 32 insertions, 8 deletions
diff --git a/lib/libpthread/thread/thr_cond.c b/lib/libpthread/thread/thr_cond.c
index 978ad04..e7fcc62 100644
--- a/lib/libpthread/thread/thr_cond.c
+++ b/lib/libpthread/thread/thr_cond.c
@@ -134,9 +134,15 @@ pthread_cond_wait(pthread_cond_t * cond, pthread_mutex_t * mutex)
int rval = 0;
int status;
- if (cond == NULL || *cond == NULL) {
+ if (cond == NULL)
rval = EINVAL;
- } else {
+
+ /*
+ * If the condition variable is statically initialized,
+ * perform the dynamic initialization:
+ */
+ else if (*cond != NULL ||
+ (rval = pthread_cond_init(cond,NULL)) == 0) {
/* Block signals: */
_thread_kern_sig_block(&status);
@@ -189,9 +195,15 @@ pthread_cond_timedwait(pthread_cond_t * cond, pthread_mutex_t * mutex,
int rval = 0;
int status;
- if (cond == NULL || *cond == NULL) {
+ if (cond == NULL)
rval = EINVAL;
- } else {
+
+ /*
+ * If the condition variable is statically initialized,
+ * perform the dynamic initialization:
+ */
+ else if (*cond != NULL ||
+ (rval = pthread_cond_init(cond,NULL)) == 0) {
/* Block signals: */
_thread_kern_sig_block(&status);
diff --git a/lib/libpthread/thread/thr_mutex.c b/lib/libpthread/thread/thr_mutex.c
index e6be6de..9f92de9 100644
--- a/lib/libpthread/thread/thr_mutex.c
+++ b/lib/libpthread/thread/thr_mutex.c
@@ -162,9 +162,15 @@ pthread_mutex_trylock(pthread_mutex_t * mutex)
int ret = 0;
int status;
- if (mutex == NULL || *mutex == NULL) {
+ if (mutex == NULL)
ret = EINVAL;
- } else {
+
+ /*
+ * If the mutex is statically initialized, perform the dynamic
+ * initialization:
+ */
+ else if (*mutex != NULL ||
+ (ret = pthread_mutex_init(mutex,NULL)) == 0) {
/* Block signals: */
_thread_kern_sig_block(&status);
@@ -224,9 +230,15 @@ pthread_mutex_lock(pthread_mutex_t * mutex)
int ret = 0;
int status;
- if (mutex == NULL || *mutex == NULL) {
+ if (mutex == NULL)
ret = EINVAL;
- } else {
+
+ /*
+ * If the mutex is statically initialized, perform the dynamic
+ * initialization:
+ */
+ else if (*mutex != NULL ||
+ (ret = pthread_mutex_init(mutex,NULL)) == 0) {
/* Block signals: */
_thread_kern_sig_block(&status);
OpenPOWER on IntegriCloud