mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-08 14:20:07 +00:00
2b47727c68
Both htl and nptl uses a different data structure to implement atfork
handlers. The nptl one was refactored by 27761a1042
to use a dynarray
which simplifies the code.
This patch moves the nptl one to be the generic implementation and
replace Hurd linked one. Different than previous NPTL, Hurd also uses
a global lock, so performance should be similar.
Checked on x86_64-linux-gnu, i686-linux-gnu, and with a build for
i686-gnu.
64 lines
2.1 KiB
C
64 lines
2.1 KiB
C
/* Internal pthread_atfork definitions.
|
|
Copyright (C) 2021 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
|
|
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/>. */
|
|
|
|
#ifndef _REGISTER_ATFORK_H
|
|
#define _REGISTER_ATFORK_H
|
|
|
|
/* Elements of the fork handler lists. */
|
|
struct fork_handler
|
|
{
|
|
void (*prepare_handler) (void);
|
|
void (*parent_handler) (void);
|
|
void (*child_handler) (void);
|
|
void *dso_handle;
|
|
};
|
|
|
|
/* Function to call to unregister fork handlers. */
|
|
extern void __unregister_atfork (void *dso_handle) attribute_hidden;
|
|
#define UNREGISTER_ATFORK(dso_handle) __unregister_atfork (dso_handle)
|
|
|
|
enum __run_fork_handler_type
|
|
{
|
|
atfork_run_prepare,
|
|
atfork_run_child,
|
|
atfork_run_parent
|
|
};
|
|
|
|
/* Run the atfork handlers and lock/unlock the internal lock depending
|
|
of the WHO argument:
|
|
|
|
- atfork_run_prepare: run all the PREPARE_HANDLER in reverse order of
|
|
insertion and locks the internal lock.
|
|
- atfork_run_child: run all the CHILD_HANDLER and unlocks the internal
|
|
lock.
|
|
- atfork_run_parent: run all the PARENT_HANDLER and unlocks the internal
|
|
lock.
|
|
|
|
Perform locking only if DO_LOCKING. */
|
|
extern void __run_fork_handlers (enum __run_fork_handler_type who,
|
|
_Bool do_locking) attribute_hidden;
|
|
|
|
/* C library side function to register new fork handlers. */
|
|
extern int __register_atfork (void (*__prepare) (void),
|
|
void (*__parent) (void),
|
|
void (*__child) (void),
|
|
void *dso_handle);
|
|
libc_hidden_proto (__register_atfork)
|
|
|
|
#endif
|