summaryrefslogtreecommitdiffstats
path: root/server.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2010-05-04 08:48:06 +0000
committerNicholas Marriott <nicm@openbsd.org>2010-05-04 08:48:06 +0000
commitaf5e0bd15affd358017e43110ac5a6c3b22233bc (patch)
treee1930b88f5378d0e412a7d6584a313ae614fdc11 /server.c
parentec1d37b1b259e8a3502646876b60eb42c2c5c740 (diff)
Revert last change, it appears to be broken somehow.
Diffstat (limited to 'server.c')
-rw-r--r--server.c68
1 files changed, 61 insertions, 7 deletions
diff --git a/server.c b/server.c
index e583b44f..017cc729 100644
--- a/server.c
+++ b/server.c
@@ -49,6 +49,9 @@ struct clients dead_clients;
int server_fd;
int server_shutdown;
struct event server_ev_accept;
+struct event server_ev_sigterm;
+struct event server_ev_sigusr1;
+struct event server_ev_sigchld;
struct event server_ev_second;
int server_create_socket(void);
@@ -131,12 +134,6 @@ server_start(char *path)
}
close(pair[0]);
- /* event_init() was called by the parent, need to reinit. */
- if (event_reinit(ev_base) != 0)
- fatal("event_reinit failed");
-
- clear_signals();
-
/*
* Must daemonise before loading configuration as the PID changes so
* $TMUX would be wrong for sessions created in the config file.
@@ -165,6 +162,8 @@ server_start(char *path)
log_debug("socket path %s", socket_path);
setproctitle("server (%s)", rpathbuf);
+ event_init();
+
server_fd = server_create_socket();
server_client_create(pair[1]);
@@ -203,7 +202,7 @@ server_start(char *path)
evtimer_set(&server_ev_second, server_second_callback, NULL);
evtimer_add(&server_ev_second, &tv);
- set_signals(server_signal_callback);
+ server_signal_set();
server_loop();
exit(0);
}
@@ -342,6 +341,61 @@ server_accept_callback(int fd, short events, unused void *data)
server_client_create(newfd);
}
+/* Set up server signal handling. */
+void
+server_signal_set(void)
+{
+ struct sigaction sigact;
+
+ memset(&sigact, 0, sizeof sigact);
+ sigemptyset(&sigact.sa_mask);
+ sigact.sa_flags = SA_RESTART;
+ sigact.sa_handler = SIG_IGN;
+ if (sigaction(SIGINT, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGPIPE, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGUSR2, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGTSTP, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGHUP, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+
+ signal_set(&server_ev_sigchld, SIGCHLD, server_signal_callback, NULL);
+ signal_add(&server_ev_sigchld, NULL);
+ signal_set(&server_ev_sigterm, SIGTERM, server_signal_callback, NULL);
+ signal_add(&server_ev_sigterm, NULL);
+ signal_set(&server_ev_sigusr1, SIGUSR1, server_signal_callback, NULL);
+ signal_add(&server_ev_sigusr1, NULL);
+}
+
+/* Destroy server signal events. */
+void
+server_signal_clear(void)
+{
+ struct sigaction sigact;
+
+ memset(&sigact, 0, sizeof sigact);
+ sigemptyset(&sigact.sa_mask);
+ sigact.sa_flags = SA_RESTART;
+ sigact.sa_handler = SIG_DFL;
+ if (sigaction(SIGINT, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGPIPE, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGUSR2, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGTSTP, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+ if (sigaction(SIGHUP, &sigact, NULL) != 0)
+ fatal("sigaction failed");
+
+ signal_del(&server_ev_sigchld);
+ signal_del(&server_ev_sigterm);
+ signal_del(&server_ev_sigusr1);
+}
+
/* Signal handler. */
/* ARGSUSED */
void