summaryrefslogtreecommitdiff
path: root/linuxthreads/cancel.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2001-03-20 18:26:06 +0000
committerUlrich Drepper <drepper@redhat.com>2001-03-20 18:26:06 +0000
commit373e6a512c30b2e34ac4a6f5b154edf45f400b35 (patch)
treeeb653da420e923bea1f9a5d66b856469f88017e9 /linuxthreads/cancel.c
parent55c910213e5af21ea4a1df7dadda4906a5c0a131 (diff)
downloadglibc-373e6a512c30b2e34ac4a6f5b154edf45f400b35.tar.gz
Update.
2001-03-20 Ulrich Drepper <drepper@redhat.com> * cancel.c (__pthread_perform_cleanup): Call __rpc_thread_destroy.
Diffstat (limited to 'linuxthreads/cancel.c')
-rw-r--r--linuxthreads/cancel.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/linuxthreads/cancel.c b/linuxthreads/cancel.c
index b05d8bf66e..0ae0d12887 100644
--- a/linuxthreads/cancel.c
+++ b/linuxthreads/cancel.c
@@ -15,6 +15,7 @@
/* Thread cancellation */
#include <errno.h>
+#include <rpc/rpc.h>
#include "pthread.h"
#include "internals.h"
#include "spinlock.h"
@@ -163,6 +164,10 @@ void __pthread_perform_cleanup(void)
struct _pthread_cleanup_buffer * c;
for (c = THREAD_GETMEM(self, p_cleanup); c != NULL; c = c->__prev)
c->__routine(c->__arg);
+
+ /* And the TSD which needs special help. */
+ if (THREAD_GETMEM(self, p_libc_specific[_LIBC_TSD_KEY_RPC_VARS]) != NULL)
+ __rpc_thread_destroy ();
}
#ifndef SHARED