diff options
author | hobbs <hobbs> | 2007-05-29 23:35:46 (GMT) |
---|---|---|
committer | hobbs <hobbs> | 2007-05-29 23:35:46 (GMT) |
commit | dff8712f9e6e1998564fb828021902a37a3fcf36 (patch) | |
tree | 30e691cb9f8de9e93498d216a1c06f976285d5dc /unix/tclUnixThrd.c | |
parent | e68a11165d4c0cf69d5fb06da1b20e95cfbf446c (diff) | |
download | tcl-dff8712f9e6e1998564fb828021902a37a3fcf36.zip tcl-dff8712f9e6e1998564fb828021902a37a3fcf36.tar.gz tcl-dff8712f9e6e1998564fb828021902a37a3fcf36.tar.bz2 |
* unix/tclUnixThrd.c (Tcl_JoinThread): fix for 64-bit handling of
pthread_join exit return code storage. [Bug 1712723]
Diffstat (limited to 'unix/tclUnixThrd.c')
-rw-r--r-- | unix/tclUnixThrd.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/unix/tclUnixThrd.c b/unix/tclUnixThrd.c index b95e8f7..b74419b 100644 --- a/unix/tclUnixThrd.c +++ b/unix/tclUnixThrd.c @@ -165,8 +165,12 @@ Tcl_JoinThread(threadId, state) { #ifdef TCL_THREADS int result; + unsigned long retcode; - result = pthread_join ((pthread_t) threadId, (VOID**) state); + result = pthread_join((pthread_t) threadId, (void**) &retcode); + if (state) { + *state = (int) retcode; + } return (result == 0) ? TCL_OK : TCL_ERROR; #else return TCL_ERROR; |