summaryrefslogtreecommitdiffstats
path: root/ctdb/common/ctdb_daemon.c
diff options
context:
space:
mode:
authorRonnie sahlberg <ronniesahlberg@gmail.com>2007-04-17 15:35:06 +1000
committerRonnie sahlberg <ronniesahlberg@gmail.com>2007-04-17 15:35:06 +1000
commit6a2579cea919b7570e2c166260a097540cf98d2c (patch)
tree4634a3c1586c55c6967ca6d5f7e3bf667034d62d /ctdb/common/ctdb_daemon.c
parent67a9f54dabeeb0ec5d8de54e3c7c290cfe392901 (diff)
parentae6722e84568cda9b3dc494a3e7fd10bbeacdb8c (diff)
downloadsamba-6a2579cea919b7570e2c166260a097540cf98d2c.tar.gz
samba-6a2579cea919b7570e2c166260a097540cf98d2c.tar.xz
samba-6a2579cea919b7570e2c166260a097540cf98d2c.zip
merge from tridge
(This used to be ctdb commit c4531b6de9189c3cd80862e29d2dd37aab36b9b4)
Diffstat (limited to 'ctdb/common/ctdb_daemon.c')
-rw-r--r--ctdb/common/ctdb_daemon.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/ctdb/common/ctdb_daemon.c b/ctdb/common/ctdb_daemon.c
index 5a90003bc0..67653202af 100644
--- a/ctdb/common/ctdb_daemon.c
+++ b/ctdb/common/ctdb_daemon.c
@@ -25,6 +25,7 @@
#include "lib/util/dlinklist.h"
#include "system/network.h"
#include "system/filesys.h"
+#include "system/wait.h"
#include "../include/ctdb.h"
#include "../include/ctdb_private.h"
@@ -47,6 +48,18 @@ static void set_non_blocking(int fd)
fcntl(fd, F_SETFL, v | O_NONBLOCK);
}
+static void block_signal(int signum)
+{
+ struct sigaction act;
+
+ memset(&act, 0, sizeof(act));
+
+ act.sa_handler = SIG_IGN;
+ sigemptyset(&act.sa_mask);
+ sigaddset(&act.sa_mask, signum);
+ sigaction(signum, &act, NULL);
+}
+
/*
structure describing a connected client in the daemon
@@ -558,6 +571,8 @@ int ctdb_start(struct ctdb_context *ctdb)
return 0;
}
+ block_signal(SIGPIPE);
+
/* ensure the socket is deleted on exit of the daemon */
domain_socket_name = talloc_strdup(talloc_autofree_context(), ctdb->daemon.name);
talloc_set_destructor(domain_socket_name, unlink_destructor);