From aef553fdcabbea8760cd4647ab14859095300023 Mon Sep 17 00:00:00 2001 From: Peter Maydell Date: Fri, 16 May 2014 14:00:03 +0100 Subject: iohandler.c: Properly initialize sigaction struct The code in qemu_init_child_watch() wasn't clearing the 'struct sigaction' before passing it to sigaction(); this meant that we would block a random set of signals while executing the SIGCHLD handler. Initialize properly by using memset() on the struct, as we do in similar cases elsewhere. Signed-off-by: Peter Maydell Signed-off-by: Michael Tokarev --- iohandler.c | 1 + 1 file changed, 1 insertion(+) (limited to 'iohandler.c') diff --git a/iohandler.c b/iohandler.c index ae2ef8f..cca614f 100644 --- a/iohandler.c +++ b/iohandler.c @@ -191,6 +191,7 @@ static void qemu_init_child_watch(void) struct sigaction act; sigchld_bh = qemu_bh_new(sigchld_bh_handler, NULL); + memset(&act, 0, sizeof(act)); act.sa_handler = sigchld_handler; act.sa_flags = SA_NOCLDSTOP; sigaction(SIGCHLD, &act, NULL); -- cgit v1.1