summaryrefslogtreecommitdiff
path: root/pthread/pt-exit.c
diff options
context:
space:
mode:
authorThomas Schwinge <thomas@schwinge.name>2011-10-20 18:42:15 +0200
committerThomas Schwinge <thomas@schwinge.name>2011-10-20 18:42:15 +0200
commit7f16d31c9904fba13f643e7523ae73eeb1178b06 (patch)
tree8bfd51b9d1c5d1ce4fa1ee2e137f7c35ff876962 /pthread/pt-exit.c
parent2b52fcee6552b568b1dd59b5c89beae48cba9d00 (diff)
parent081c7aeb4d4de82ab615db565c60dd776a385c34 (diff)
Merge commit 'refs/top-bases/t/fix_inline' into t/fix_inline
Conflicts: sysdeps/mach/hurd/pt-sysdep.h
Diffstat (limited to 'pthread/pt-exit.c')
-rw-r--r--pthread/pt-exit.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/pthread/pt-exit.c b/pthread/pt-exit.c
index 3b3853e..c01efda 100644
--- a/pthread/pt-exit.c
+++ b/pthread/pt-exit.c
@@ -1,5 +1,5 @@
/* Thread termination.
- Copyright (C) 2000, 2002, 2005 Free Software Foundation, Inc.
+ Copyright (C) 2000, 2002, 2005, 2007, 2011 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@@ -69,6 +69,11 @@ pthread_exit (void *status)
if (self->cancel_state == PTHREAD_CANCEL_ENABLE && self->cancel_pending)
status = PTHREAD_CANCELED;
+#ifdef ENABLE_TLS
+ if (self->tcb)
+ _dl_deallocate_tls (self->tcb, 1);
+#endif /* ENABLE_TLS */
+
switch (self->state)
{
default: