From d130a3415649b36ac672ab49068aec7c02a8135c Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Sat, 8 Mar 2003 09:41:16 +0000 Subject: Update. 2003-03-08 Ulrich Drepper * allocatestack.c (allocate_stack): If mprotect() fails free the TLS memory. --- nptl/allocatestack.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'nptl/allocatestack.c') diff --git a/nptl/allocatestack.c b/nptl/allocatestack.c index 4aec875548..31cff2a1c2 100644 --- a/nptl/allocatestack.c +++ b/nptl/allocatestack.c @@ -439,9 +439,12 @@ allocate_stack (const struct pthread_attr *attr, struct pthread **pdp, lll_unlock (stack_cache_lock); - /* Free the memory regardless of whether the size of the - cache is over the limit or not. If this piece of - memory caused problems we better do not use it + /* Get rid of the TLS block we allocated. */ + _dl_deallocate_tls (pd, false); + + /* Free the stack memory regardless of whether the size + of the cache is over the limit or not. If this piece + of memory caused problems we better do not use it anymore. Uh, and we ignore possible errors. There is nothing we could do. */ (void) munmap (mem, size); -- cgit v1.2.3