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:
@@ -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 \
|
||||||
|
@@ -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
45
nptl/nptl_free_tcb.c
Normal 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)
|
@@ -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. */
|
||||||
|
@@ -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.
|
||||||
|
|
||||||
|
@@ -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;
|
||||||
}
|
}
|
||||||
|
@@ -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;
|
||||||
|
Reference in New Issue
Block a user