Revert "Use ev_signal to avoid async-unsafe functions (Thanks Markus)"

This makes our signal handler useless and leads to infinite SIGSEGV
loops because the ev callback handler gets called only from within the
event loop, and control doesn’t necessary get to the event loop…

This reverts commit 514265b529ac78b7778eeee2db3dddb6f3a1c24c.
This commit is contained in:
Michael Stapelberg 2012-09-27 12:34:09 +02:00
parent 87525ad2d6
commit 9c01bdeef7

View File

@ -232,15 +232,13 @@ static void i3_exit(void) {
* Unlinks the SHM log and re-raises the signal. * Unlinks the SHM log and re-raises the signal.
* *
*/ */
static void handle_signal(struct ev_loop *loop, ev_signal *w, int revents) { static void handle_signal(int sig, siginfo_t *info, void *data) {
int sig = w->signum;
fprintf(stderr, "Received signal %d, terminating\n", sig); fprintf(stderr, "Received signal %d, terminating\n", sig);
if (*shmlogname != '\0') { if (*shmlogname != '\0') {
fprintf(stderr, "Closing SHM log \"%s\"\n", shmlogname); fprintf(stderr, "Closing SHM log \"%s\"\n", shmlogname);
shm_unlink(shmlogname); shm_unlink(shmlogname);
} }
fflush(stderr); fflush(stderr);
ev_signal_stop(loop, w);
raise(sig); raise(sig);
} }
@ -783,32 +781,31 @@ int main(int argc, char *argv[]) {
} }
xcb_ungrab_server(conn); xcb_ungrab_server(conn);
struct sigaction action;
#define HANDLE_SIGNAL_EV(signum) \ action.sa_sigaction = handle_signal;
do { \ action.sa_flags = SA_NODEFER | SA_RESETHAND | SA_SIGINFO;
struct ev_signal *signal_watcher = scalloc(sizeof(struct ev_signal)); \ sigemptyset(&action.sa_mask);
ev_signal_init(signal_watcher, handle_signal, signum); \
ev_signal_start(main_loop, signal_watcher); \
} while (0)
if (!disable_signalhandler) if (!disable_signalhandler)
setup_signal_handler(); setup_signal_handler();
else { else {
/* Catch all signals with default action "Core", see signal(7) */ /* Catch all signals with default action "Core", see signal(7) */
HANDLE_SIGNAL_EV(SIGQUIT); if (sigaction(SIGQUIT, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGILL); sigaction(SIGILL, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGABRT); sigaction(SIGABRT, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGFPE); sigaction(SIGFPE, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGSEGV); sigaction(SIGSEGV, &action, NULL) == -1)
ELOG("Could not setup signal handler");
} }
/* Catch all signals with default action "Term", see signal(7) */ /* Catch all signals with default action "Term", see signal(7) */
HANDLE_SIGNAL_EV(SIGHUP); if (sigaction(SIGHUP, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGINT); sigaction(SIGINT, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGALRM); sigaction(SIGALRM, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGTERM); sigaction(SIGUSR1, &action, NULL) == -1 ||
HANDLE_SIGNAL_EV(SIGUSR1); sigaction(SIGUSR2, &action, NULL) == -1)
HANDLE_SIGNAL_EV(SIGUSR2); ELOG("Could not setup signal handler");
/* Ignore SIGPIPE to survive errors when an IPC client disconnects /* Ignore SIGPIPE to survive errors when an IPC client disconnects
* while we are sending him a message */ * while we are sending him a message */