1
0
mirror of https://sourceware.org/git/glibc.git synced 2025-08-08 17:42:12 +03:00

nptl: Move __free_tcb into libc

Under the name __nptl_free_tcb.

Reviewed-by: Adhemerval Zanella  <adhemerval.zanella@linaro.org>
This commit is contained in:
Florian Weimer
2021-05-11 11:08:00 +02:00
parent c79a31fb36
commit 8fbb33b3f7
7 changed files with 52 additions and 29 deletions

View File

@@ -46,6 +46,7 @@ routines = \
lowlevellock \ lowlevellock \
nptl-stack \ nptl-stack \
nptl_deallocate_tsd \ nptl_deallocate_tsd \
nptl_free_tcb \
nptl_nthreads \ nptl_nthreads \
nptl_setxid \ nptl_setxid \
nptlfreeres \ nptlfreeres \

View File

@@ -321,6 +321,7 @@ libc {
__mutex_aconf; __mutex_aconf;
__nptl_deallocate_stack; __nptl_deallocate_stack;
__nptl_deallocate_tsd; __nptl_deallocate_tsd;
__nptl_free_tcb;
__nptl_nthreads; __nptl_nthreads;
__nptl_setxid_sighandler; __nptl_setxid_sighandler;
__nptl_stack_list_add; __nptl_stack_list_add;

45
nptl/nptl_free_tcb.c Normal file
View File

@@ -0,0 +1,45 @@
/* TCB deallocation for NPTL.
Copyright (C) 2002-2021 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@redhat.com>, 2002.
The GNU C Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
The GNU C Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with the GNU C Library; if not, see
<https://www.gnu.org/licenses/>. */
#include <nptl-stack.h>
#include <pthreadP.h>
#include <stdlib.h>
void
__nptl_free_tcb (struct pthread *pd)
{
/* The thread is exiting now. */
if (atomic_bit_test_set (&pd->cancelhandling, TERMINATED_BIT) == 0)
{
/* Free TPP data. */
if (pd->tpp != NULL)
{
struct priority_protection_data *tpp = pd->tpp;
pd->tpp = NULL;
free (tpp);
}
/* Queue the stack memory block for reuse and exit the process. The
kernel will signal via writing to the address returned by
QUEUE-STACK when the stack is available. */
__nptl_deallocate_stack (pd);
}
}
libc_hidden_def (__nptl_free_tcb)

View File

@@ -312,7 +312,8 @@ __do_cancel (void)
/* Deallocate a thread's stack after optionally making sure the thread /* Deallocate a thread's stack after optionally making sure the thread
descriptor is still valid. */ descriptor is still valid. */
extern void __free_tcb (struct pthread *pd) attribute_hidden; extern void __nptl_free_tcb (struct pthread *pd);
libc_hidden_proto (__nptl_free_tcb)
/* Change the permissions of a thread stack. Called from /* Change the permissions of a thread stack. Called from
_dl_make_stacks_executable and pthread_create. */ _dl_make_stacks_executable and pthread_create. */

View File

@@ -207,31 +207,6 @@ static int create_thread (struct pthread *pd, const struct pthread_attr *attr,
#include <createthread.c> #include <createthread.c>
/* Deallocate a thread's stack after optionally making sure the thread
descriptor is still valid. */
void
__free_tcb (struct pthread *pd)
{
/* The thread is exiting now. */
if (__builtin_expect (atomic_bit_test_set (&pd->cancelhandling,
TERMINATED_BIT) == 0, 1))
{
/* Free TPP data. */
if (__glibc_unlikely (pd->tpp != NULL))
{
struct priority_protection_data *tpp = pd->tpp;
pd->tpp = NULL;
free (tpp);
}
/* Queue the stack memory block for reuse and exit the process. The
kernel will signal via writing to the address returned by
QUEUE-STACK when the stack is available. */
__nptl_deallocate_stack (pd);
}
}
/* Local function to start thread and handle cleanup. /* Local function to start thread and handle cleanup.
createthread.c defines the macro START_THREAD_DEFN to the createthread.c defines the macro START_THREAD_DEFN to the
declaration that its create_thread function will refer to, and declaration that its create_thread function will refer to, and
@@ -444,7 +419,7 @@ START_THREAD_DEFN
/* If the thread is detached free the TCB. */ /* If the thread is detached free the TCB. */
if (IS_DETACHED (pd)) if (IS_DETACHED (pd))
/* Free the TCB. */ /* Free the TCB. */
__free_tcb (pd); __nptl_free_tcb (pd);
/* We cannot call '_exit' here. '_exit' will terminate the process. /* We cannot call '_exit' here. '_exit' will terminate the process.

View File

@@ -49,7 +49,7 @@ __pthread_detach (pthread_t th)
if ((pd->cancelhandling & EXITING_BITMASK) != 0) if ((pd->cancelhandling & EXITING_BITMASK) != 0)
/* Note that the code in __free_tcb makes sure each thread /* Note that the code in __free_tcb makes sure each thread
control block is freed only once. */ control block is freed only once. */
__free_tcb (pd); __nptl_free_tcb (pd);
return result; return result;
} }

View File

@@ -122,7 +122,7 @@ __pthread_clockjoin_ex (pthread_t threadid, void **thread_return,
*thread_return = pd_result; *thread_return = pd_result;
/* Free the TCB. */ /* Free the TCB. */
__free_tcb (pd); __nptl_free_tcb (pd);
} }
else else
pd->joinid = NULL; pd->joinid = NULL;