summaryrefslogtreecommitdiff
path: root/socket.c
diff options
context:
space:
mode:
authorWayne Davison <wayned@samba.org>2006-02-02 02:39:25 +0000
committerWayne Davison <wayned@samba.org>2006-02-02 02:39:25 +0000
commit2b28968dfb36792ccdbe3b7b9be800b97d3f13f6 (patch)
tree8d5b215b0736ec18a4c9a7733683143333c4dc52 /socket.c
parent90b13cf60687c4d2e18964423cd44abab6500167 (diff)
downloadrsync-2b28968dfb36792ccdbe3b7b9be800b97d3f13f6.tar.gz
rsync-2b28968dfb36792ccdbe3b7b9be800b97d3f13f6.tar.bz2
rsync-2b28968dfb36792ccdbe3b7b9be800b97d3f13f6.zip
Call SIGACTION() instead of signal().
Diffstat (limited to 'socket.c')
-rw-r--r--socket.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/socket.c b/socket.c
index bc61baeb..7e779695 100644
--- a/socket.c
+++ b/socket.c
@@ -36,6 +36,10 @@
extern char *bind_address;
extern int default_af_hint;
+#if defined HAVE_SIGACTION && defined HAVE_SIGPROCMASK
+static struct sigaction sigact;
+#endif
+
/**
* Establish a proxy connection on an open socket to a web proxy by
* using the CONNECT method. If proxy_user and proxy_pass are not NULL,
@@ -433,7 +437,9 @@ static RETSIGTYPE sigchld_handler(UNUSED(int val))
#ifdef WNOHANG
while (waitpid(-1, NULL, WNOHANG) > 0) {}
#endif
+#if !defined HAVE_SIGACTION && !defined HAVE_SIGPROCMASK
signal(SIGCHLD, sigchld_handler);
+#endif
}
@@ -442,6 +448,10 @@ void start_accept_loop(int port, int (*fn)(int, int))
fd_set deffds;
int *sp, maxfd, i;
+#if defined HAVE_SIGACTION && defined HAVE_SIGPROCMASK
+ sigact.sa_flags = SA_NOCLDSTOP;
+#endif
+
/* open an incoming socket */
sp = open_socket_in(SOCK_STREAM, port, bind_address, default_af_hint);
if (sp == NULL)
@@ -499,7 +509,7 @@ void start_accept_loop(int port, int (*fn)(int, int))
if (fd < 0)
continue;
- signal(SIGCHLD, sigchld_handler);
+ SIGACTION(SIGCHLD, sigchld_handler);
if ((pid = fork()) == 0) {
int ret;