mirror of
https://gitlab.com/sortix/sortix.git
synced 2023-02-13 20:55:38 -05:00
Thread-secure exit(3).
This commit is contained in:
parent
a96aca09c1
commit
e1db06c1c9
1 changed files with 11 additions and 0 deletions
|
@ -23,18 +23,29 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
|
#include <pthread.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
extern "C" { struct exit_handler* __exit_handler_stack = NULL; }
|
extern "C" { struct exit_handler* __exit_handler_stack = NULL; }
|
||||||
|
|
||||||
|
static pthread_mutex_t exit_lock = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
|
||||||
extern "C" void exit(int status)
|
extern "C" void exit(int status)
|
||||||
{
|
{
|
||||||
|
// Only allow a single thread to do the exit cleanup. If somehow the cleanup
|
||||||
|
// code calls exit, then we'll self-destruct. If multiple threads attempt to
|
||||||
|
// call exit, then we'll destroy the ones that got here too late.
|
||||||
|
if ( pthread_mutex_trylock(&exit_lock) != 0 )
|
||||||
|
exit_thread(status, 0, NULL);
|
||||||
|
|
||||||
while ( __exit_handler_stack )
|
while ( __exit_handler_stack )
|
||||||
{
|
{
|
||||||
__exit_handler_stack->hook(status, __exit_handler_stack->param);
|
__exit_handler_stack->hook(status, __exit_handler_stack->param);
|
||||||
__exit_handler_stack = __exit_handler_stack->next;
|
__exit_handler_stack = __exit_handler_stack->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
dcloseall();
|
dcloseall();
|
||||||
fcloseall();
|
fcloseall();
|
||||||
_Exit(status);
|
_Exit(status);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue