Don't use sa_sigaction (which NetBSD doesn't like) at all if we don't use siginfo.

This commit is contained in:
Guus Sliepen 2002-02-12 14:29:00 +00:00
parent d9a62c6354
commit dd611fb4f9

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: process.c,v 1.1.2.33 2002/02/10 21:57:54 guus Exp $ $Id: process.c,v 1.1.2.34 2002/02/12 14:29:00 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -307,7 +307,7 @@ cp
*/ */
RETSIGTYPE RETSIGTYPE
sigterm_handler(int a, siginfo_t *info, void *b) sigterm_handler(int a)
{ {
if(debug_lvl > DEBUG_NOTHING) if(debug_lvl > DEBUG_NOTHING)
syslog(LOG_NOTICE, _("Got TERM signal")); syslog(LOG_NOTICE, _("Got TERM signal"));
@ -316,7 +316,7 @@ sigterm_handler(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sigquit_handler(int a, siginfo_t *info, void *b) sigquit_handler(int a)
{ {
if(debug_lvl > DEBUG_NOTHING) if(debug_lvl > DEBUG_NOTHING)
syslog(LOG_NOTICE, _("Got QUIT signal")); syslog(LOG_NOTICE, _("Got QUIT signal"));
@ -324,7 +324,7 @@ sigquit_handler(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sigsegv_square(int a, siginfo_t *info, void *b) sigsegv_square(int a)
{ {
syslog(LOG_ERR, _("Got another SEGV signal: not restarting")); syslog(LOG_ERR, _("Got another SEGV signal: not restarting"));
cp_trace(); cp_trace();
@ -332,7 +332,7 @@ sigsegv_square(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sigsegv_handler(int a, siginfo_t *info, void *b) sigsegv_handler(int a)
{ {
struct sigaction act; struct sigaction act;
syslog(LOG_ERR, _("Got SEGV signal")); syslog(LOG_ERR, _("Got SEGV signal"));
@ -342,10 +342,9 @@ sigsegv_handler(int a, siginfo_t *info, void *b)
{ {
syslog(LOG_NOTICE, _("Trying to re-execute in 5 seconds...")); syslog(LOG_NOTICE, _("Trying to re-execute in 5 seconds..."));
act.sa_handler = NULL; act.sa_handler = sigsegv_square;
act.sa_mask = emptysigset; act.sa_mask = emptysigset;
act.sa_flags = SA_SIGINFO; act.sa_flags = 0;
act.sa_sigaction = sigsegv_square;
sigaction(SIGSEGV, &act, NULL); sigaction(SIGSEGV, &act, NULL);
close_network_connections(); close_network_connections();
@ -361,7 +360,7 @@ sigsegv_handler(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sighup_handler(int a, siginfo_t *info, void *b) sighup_handler(int a)
{ {
if(debug_lvl > DEBUG_NOTHING) if(debug_lvl > DEBUG_NOTHING)
syslog(LOG_NOTICE, _("Got HUP signal")); syslog(LOG_NOTICE, _("Got HUP signal"));
@ -369,7 +368,7 @@ sighup_handler(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sigint_handler(int a, siginfo_t *info, void *b) sigint_handler(int a)
{ {
if(saved_debug_lvl) if(saved_debug_lvl)
{ {
@ -388,7 +387,7 @@ sigint_handler(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sigalrm_handler(int a, siginfo_t *info, void *b) sigalrm_handler(int a)
{ {
if(debug_lvl > DEBUG_NOTHING) if(debug_lvl > DEBUG_NOTHING)
syslog(LOG_NOTICE, _("Got ALRM signal")); syslog(LOG_NOTICE, _("Got ALRM signal"));
@ -396,13 +395,13 @@ sigalrm_handler(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sigusr1_handler(int a, siginfo_t *info, void *b) sigusr1_handler(int a)
{ {
dump_connections(); dump_connections();
} }
RETSIGTYPE RETSIGTYPE
sigusr2_handler(int a, siginfo_t *info, void *b) sigusr2_handler(int a)
{ {
dump_device_stats(); dump_device_stats();
dump_nodes(); dump_nodes();
@ -411,21 +410,21 @@ sigusr2_handler(int a, siginfo_t *info, void *b)
} }
RETSIGTYPE RETSIGTYPE
sigwinch_handler(int a, siginfo_t *info, void *b) sigwinch_handler(int a)
{ {
extern int do_purge; extern int do_purge;
do_purge = 1; do_purge = 1;
} }
RETSIGTYPE RETSIGTYPE
unexpected_signal_handler(int a, siginfo_t *info, void *b) unexpected_signal_handler(int a)
{ {
syslog(LOG_WARNING, _("Got unexpected signal %d (%s)"), a, strsignal(a)); syslog(LOG_WARNING, _("Got unexpected signal %d (%s)"), a, strsignal(a));
cp_trace(); cp_trace();
} }
RETSIGTYPE RETSIGTYPE
ignore_signal_handler(int a, siginfo_t *info, void *b) ignore_signal_handler(int a)
{ {
if(debug_lvl >= DEBUG_SCARY_THINGS) if(debug_lvl >= DEBUG_SCARY_THINGS)
{ {
@ -436,7 +435,7 @@ ignore_signal_handler(int a, siginfo_t *info, void *b)
struct { struct {
int signal; int signal;
void (*handler)(int, siginfo_t *, void *); void (*handler)(int);
} sighandlers[] = { } sighandlers[] = {
{ SIGHUP, sighup_handler }, { SIGHUP, sighup_handler },
{ SIGTERM, sigterm_handler }, { SIGTERM, sigterm_handler },
@ -461,28 +460,28 @@ setup_signals(void)
sigemptyset(&emptysigset); sigemptyset(&emptysigset);
act.sa_handler = NULL; act.sa_handler = NULL;
act.sa_mask = emptysigset; act.sa_mask = emptysigset;
act.sa_flags = SA_SIGINFO; act.sa_flags = 0;
/* Set a default signal handler for every signal, errors will be /* Set a default signal handler for every signal, errors will be
ignored. */ ignored. */
for(i = 0; i < NSIG; i++) for(i = 0; i < NSIG; i++)
{ {
if(!do_detach) if(!do_detach)
act.sa_sigaction = (void(*)(int, siginfo_t *, void *))SIG_DFL; act.sa_handler = SIG_DFL;
else else
act.sa_sigaction = unexpected_signal_handler; act.sa_handler = unexpected_signal_handler;
sigaction(i, &act, NULL); sigaction(i, &act, NULL);
} }
/* If we didn't detach, allow coredumps */ /* If we didn't detach, allow coredumps */
if(!do_detach) if(!do_detach)
sighandlers[3].handler = (void(*)(int, siginfo_t *, void *))SIG_DFL; sighandlers[3].handler = SIG_DFL;
/* Then, for each known signal that we want to catch, assign a /* Then, for each known signal that we want to catch, assign a
handler to the signal, with error checking this time. */ handler to the signal, with error checking this time. */
for(i = 0; sighandlers[i].signal; i++) for(i = 0; sighandlers[i].signal; i++)
{ {
act.sa_sigaction = sighandlers[i].handler; act.sa_handler = sighandlers[i].handler;
if(sigaction(sighandlers[i].signal, &act, NULL) < 0) if(sigaction(sighandlers[i].signal, &act, NULL) < 0)
fprintf(stderr, _("Installing signal handler for signal %d (%s) failed: %s\n"), fprintf(stderr, _("Installing signal handler for signal %d (%s) failed: %s\n"),
sighandlers[i].signal, strsignal(sighandlers[i].signal), strerror(errno)); sighandlers[i].signal, strsignal(sighandlers[i].signal), strerror(errno));