mirror of
https://github.com/sheumann/hush.git
synced 2025-01-04 22:34:37 +00:00
9bc48e5ebf
Our approach is to have the parent wait for SIGUSR2, and send that from the child just before it calls exec* or _exit.
47 lines
1.1 KiB
C
47 lines
1.1 KiB
C
/* vi: set sw=4 ts=4: */
|
|
/*
|
|
* Utility routines.
|
|
*
|
|
* Copyright (C) 2008 by Denys Vlasenko <vda.linux@googlemail.com>
|
|
*
|
|
* Licensed under GPLv2, see file LICENSE in this source tree.
|
|
*/
|
|
|
|
/* Keeping it separate allows to NOT suck in stdio for VERY small applets.
|
|
* Try building busybox with only "true" enabled... */
|
|
|
|
#include "libbb.h"
|
|
|
|
int die_sleep;
|
|
#if ENABLE_FEATURE_PREFER_APPLETS || ENABLE_HUSH
|
|
jmp_buf die_jmp;
|
|
#endif
|
|
|
|
void FAST_FUNC xfunc_die(void)
|
|
{
|
|
int forked;
|
|
|
|
if (die_sleep) {
|
|
if ((ENABLE_FEATURE_PREFER_APPLETS || ENABLE_HUSH)
|
|
&& die_sleep < 0
|
|
) {
|
|
/* Special case. We arrive here if NOFORK applet
|
|
* calls xfunc, which then decides to die.
|
|
* We don't die, but jump instead back to caller.
|
|
* NOFORK applets still cannot carelessly call xfuncs:
|
|
* p = xmalloc(10);
|
|
* q = xmalloc(10); // BUG! if this dies, we leak p!
|
|
*/
|
|
/* -2222 means "zero" (longjmp can't pass 0)
|
|
* run_nofork_applet() catches -2222. */
|
|
longjmp(die_jmp, xfunc_error_retval ? xfunc_error_retval : -2222);
|
|
}
|
|
sleep(die_sleep);
|
|
}
|
|
forked = signal_parent_to_resume();
|
|
if (!forked)
|
|
exit(xfunc_error_retval);
|
|
else
|
|
_exit(xfunc_error_retval);
|
|
}
|