summaryrefslogtreecommitdiff
path: root/gcc/gthr-posix.h
diff options
context:
space:
mode:
authorJohn David Anglin <dave.anglin@nrc-cnrc.gc.ca>2007-10-12 00:09:10 +0000
committerJohn David Anglin <danglin@gcc.gnu.org>2007-10-12 00:09:10 +0000
commitd796bfa95cbd60745f2131875283870e3703fc0c (patch)
tree96d1a495e5c05f428f9fc1f5f90dd3d1f9669f92 /gcc/gthr-posix.h
parent8885751219b7aa0391a53af06a1d05b215cb048e (diff)
downloadgcc-d796bfa95cbd60745f2131875283870e3703fc0c.tar.gz
gthr-posix.h (__gthread_active_init): Create detached instead of joinable thread when...
* gthr-posix.h (__gthread_active_init): Create detached instead of joinable thread when testing whether threads are active on hppa-hpux. * gthr-posix95.h (__gthread_active_init): Likewise. From-SVN: r129246
Diffstat (limited to 'gcc/gthr-posix.h')
-rw-r--r--gcc/gthr-posix.h12
1 files changed, 6 insertions, 6 deletions
diff --git a/gcc/gthr-posix.h b/gcc/gthr-posix.h
index 5c00cd30862..ad6822e26ad 100644
--- a/gcc/gthr-posix.h
+++ b/gcc/gthr-posix.h
@@ -246,20 +246,20 @@ __gthread_active_init (void)
{
static pthread_mutex_t __gthread_active_mutex = PTHREAD_MUTEX_INITIALIZER;
pthread_t t;
+ pthread_attr_t a;
int result;
__gthrw_(pthread_mutex_lock) (&__gthread_active_mutex);
if (__gthread_active < 0)
{
- result = __gthrw_(pthread_create) (&t, NULL, __gthread_start, NULL);
+ __gthrw_(pthread_attr_init) (&a);
+ __gthrw_(pthread_attr_setdetachstate) (&a, PTHREAD_CREATE_DETACHED);
+ result = __gthrw_(pthread_create) (&t, &a, __gthread_start, NULL);
if (result != ENOSYS)
- {
- __gthread_active = 1;
- if (!result)
- __gthrw_(pthread_join) (t, NULL);
- }
+ __gthread_active = 1;
else
__gthread_active = 0;
+ __gthrw_(pthread_attr_destroy) (&a);
}
__gthrw_(pthread_mutex_unlock) (&__gthread_active_mutex);
}