summaryrefslogtreecommitdiff
path: root/exit.c
diff options
context:
space:
mode:
authorrpj <rpj>1999-08-19 05:26:02 +0000
committerrpj <rpj>1999-08-19 05:26:02 +0000
commit5e87a0d9bdd4c2c2ab0e45a6379b4df0f1471ffa (patch)
treec8b65744680e1ca884470f2f345b929e2abc4ff8 /exit.c
parentb1972e47c0359b818522f6aa822f3457be938060 (diff)
1999-08-19 Ross Johnson <rpj@ixobrychus.canberra.edu.au>
* private.c (_pthread_threadStart): Return exit status from the application thread startup routine. - Milan Gardian <mg@tatramed.sk> 1999-08-18 Ross Johnson <rpj@ixobrychus.canberra.edu.au> * exit.c (pthread_exit): Put status into pthread_t->exitStatus - John Bossom <john.Bossom@cognos.com> * private.c (_pthread_threadStart): Set pthread->exitStatus on exit of try{} block. - John Bossom <john.Bossom@cognos.com> * sync.c (pthread_join): use pthread_exitStatus value if the thread exit doesn't return a value (for Mingw32 CRTDLL which uses endthread instead of _endthreadex). - John Bossom <john.Bossom@cognos.com> Tue Aug 17 20:17:58 CDT 1999 Mumit Khan <khan@xraylith.wisc.edu> * create.c (pthread_create): Add CRTDLL suppport. * exit.c (pthread_exit): Likewise. * private.c (_pthread_threadStart): Likewise. (_pthread_threadDestroy): Likewise. * sync.c (pthread_join): Likewise. * tests/join1.c (main): Warn about partial support for CRTDLL. Tue Aug 17 20:00:08 1999 Mumit Khan <khan@xraylith.wisc.edu> * Makefile.in (LD): Delete entry point. * acconfig.h (STDCALL): Delete unused macro. * configure.in: Remove test for STDCALL. * config.h.in: Regenerate. * errno.c (_errno): Fix self type. * pthread.h (PT_STDCALL): Move from here to * implement.h (PT_STDCALL): here. (_pthread_threadStart): Fix prototype. * private.c (_pthread_threadStart): Likewise. 1999-08-14 Ross Johnson <rpj@ixobrychus.canberra.edu.au> * exit.c (pthread_exit): Don't call pthread_self() but get thread handle directly from TSD for efficiency.
Diffstat (limited to 'exit.c')
-rw-r--r--exit.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/exit.c b/exit.c
index 18592a2..32468d9 100644
--- a/exit.c
+++ b/exit.c
@@ -61,12 +61,17 @@ pthread_exit (void *value_ptr)
*/
self = (pthread_t) pthread_getspecific (_pthread_selfThreadKey);
+ self->exitStatus = value_ptr;
if (self == NULL || self->implicit)
{
_pthread_callUserDestroyRoutines(self);
+#if ! defined (__MINGW32__) || defined (__MSVCRT__)
_endthreadex ((unsigned) value_ptr);
+#else
+ _endthread ();
+#endif
/* Never reached */
}
@@ -90,7 +95,6 @@ pthread_exit (void *value_ptr)
#ifdef __cplusplus
- self->exceptionInformation = value_ptr;
throw Pthread_exception_exit();
#else /* ! __cplusplus */
@@ -99,7 +103,11 @@ pthread_exit (void *value_ptr)
_pthread_callUserDestroyRoutines(self);
+#if ! defined (__MINGW32__) || defined (__MSVCRT__)
_endthreadex ((unsigned) value_ptr);
+#else
+ _endthread ();
+#endif
#endif /* __cplusplus */