diff options
author | Mystery Man <unknown@mandriva.org> | 2001-05-14 14:17:54 +0000 |
---|---|---|
committer | Mystery Man <unknown@mandriva.org> | 2001-05-14 14:17:54 +0000 |
commit | 16984701aa5165b77f229cc318e8025ee8cf81b5 (patch) | |
tree | 923ed2780582f751b2be106641be35cf71fedd66 /mdk-stage1/dietlibc/libpthread/pthread_join.c | |
parent | c5050eb3ba91cf0eab748b773dcbb34b88ae88bc (diff) | |
download | drakx-backup-do-not-use-topic/dietlibc.tar drakx-backup-do-not-use-topic/dietlibc.tar.gz drakx-backup-do-not-use-topic/dietlibc.tar.bz2 drakx-backup-do-not-use-topic/dietlibc.tar.xz drakx-backup-do-not-use-topic/dietlibc.zip |
This commit was manufactured by cvs2svn to create branch 'dietlibc'.topic/dietlibc
Diffstat (limited to 'mdk-stage1/dietlibc/libpthread/pthread_join.c')
-rw-r--r-- | mdk-stage1/dietlibc/libpthread/pthread_join.c | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/mdk-stage1/dietlibc/libpthread/pthread_join.c b/mdk-stage1/dietlibc/libpthread/pthread_join.c new file mode 100644 index 000000000..5b295bad1 --- /dev/null +++ b/mdk-stage1/dietlibc/libpthread/pthread_join.c @@ -0,0 +1,50 @@ +#include <unistd.h> +#include <stdlib.h> +#include <errno.h> + +#include "thread_internal.h" +#include <pthread.h> + +int pthread_join(pthread_t th, void **thread_return) +{ + pthread_t j; + _pthread_descr this, thread; + + __THREAD_INIT(); + + this = __thread_self(); + j=__find_thread_id(th); + + if (j==-1) { + (*(__errno_location()))=ESRCH; + return -1; + } + + thread = __get_thread_struct(j); + + /* error handling */ + if (thread==0) { + (*(__errno_location()))=ESRCH; + return -1; + } + + if (this==thread) { + (*(__errno_location()))=EDEADLK; + return -1; + } + + if (thread->detached || thread->joined) { + (*(__errno_location()))=EINVAL; + return -1; + } + + thread->joined=this; + this->join=1; + + while(this->join) __thread_wait_some_time(); + + if (thread_return) *thread_return=this->retval; + + return 0; +} + |