diff options
author | Tobias Brunner <tobias@strongswan.org> | 2015-09-17 17:52:14 +0200 |
---|---|---|
committer | Tobias Brunner <tobias@strongswan.org> | 2015-10-29 15:38:37 +0100 |
commit | 858148092d1ef755cd40fea0169259e4ad3e9f02 (patch) | |
tree | 850f6521d1e5247290f6e4f958a00a481f9f3389 /src/charon/charon.c | |
parent | c6aa606a659704d4a4855a6ab1f698fada9dd77e (diff) | |
download | strongswan-858148092d1e.tar.bz2 strongswan-858148092d1e.tar.xz |
Replace usages of sigwait(3) with sigwaitinfo(2)
This is basically the same call, but it has the advantage of being
supported by FreeBSD's valgrind, which sigwait() is not.
References #1106.
Diffstat (limited to 'src/charon/charon.c')
-rw-r--r-- | src/charon/charon.c | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/src/charon/charon.c b/src/charon/charon.c index 081e49490..f03b6e1ba 100644 --- a/src/charon/charon.c +++ b/src/charon/charon.c @@ -17,9 +17,7 @@ */ #include <stdio.h> -#define _POSIX_PTHREAD_SEMANTICS /* for two param sigwait on OpenSolaris */ #include <signal.h> -#undef _POSIX_PTHREAD_SEMANTICS #include <pthread.h> #include <sys/stat.h> #include <sys/types.h> @@ -110,12 +108,11 @@ static void run() while (TRUE) { int sig; - int error; - error = sigwait(&set, &sig); - if (error) + sig = sigwaitinfo(&set, NULL); + if (sig == -1) { - DBG1(DBG_DMN, "error %d while waiting for a signal", error); + DBG1(DBG_DMN, "waiting for signal failed: %s", strerror(errno)); return; } switch (sig) @@ -434,7 +431,7 @@ int main(int argc, char *argv[]) } /* add handler for SEGV and ILL, - * INT, TERM and HUP are handled by sigwait() in run() */ + * INT, TERM and HUP are handled by sigwaitinfo() in run() */ action.sa_handler = segv_handler; action.sa_flags = 0; sigemptyset(&action.sa_mask); |