X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fprocd.git;a=blobdiff_plain;f=signal.c;h=74cabcbaf13c829f8be119a700a831860bb7796f;hp=f705e5d2a091729240b66877a4934127a3178a48;hb=bc0900b190015b3018adc652d91c4dfd6851aadd;hpb=9961e88dd853a30503298378679d2cedc497410e diff --git a/signal.c b/signal.c index f705e5d..74cabcb 100644 --- a/signal.c +++ b/signal.c @@ -19,14 +19,12 @@ #include "procd.h" -static int preinit; - static void do_reboot(void) { LOG("reboot\n"); fflush(stderr); sync(); - sleep(1); + sleep(2); reboot(RB_AUTOBOOT); while (1) ; @@ -37,9 +35,6 @@ static void signal_shutdown(int signal, siginfo_t *siginfo, void *data) int event = 0; char *msg = NULL; - if (preinit) - do_reboot(); - switch(signal) { case SIGTERM: event = RB_AUTOBOOT; @@ -85,7 +80,7 @@ struct sigaction sa_dummy = { void procd_signal(void) { - sigaction(SIGPIPE, &sa_dummy, NULL); + signal(SIGPIPE, SIG_IGN); if (getpid() != 1) return; sigaction(SIGTERM, &sa_shutdown, NULL); @@ -97,11 +92,3 @@ void procd_signal(void) sigaction(SIGKILL, &sa_dummy, NULL); sigaction(SIGSTOP, &sa_dummy, NULL); } - -void procd_signal_preinit(void) -{ - preinit = 1; - sigaction(SIGTERM, &sa_shutdown, NULL); - sigaction(SIGUSR1, &sa_shutdown, NULL); - sigaction(SIGUSR2, &sa_shutdown, NULL); -}