X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=src%2Fmail-sendmail.c;h=ce2538e4d9c1c8e4a11b2cf1de6fa7c7333844ae;hb=f8f8d040b49781f7f703f50f869fd6924117a3e6;hp=bae492661eddc39de0680c3b13658da11d98ff16;hpb=508125cbe26502c05f141b9170f47852748f87e6;p=srvx.git diff --git a/src/mail-sendmail.c b/src/mail-sendmail.c index bae4926..ce2538e 100644 --- a/src/mail-sendmail.c +++ b/src/mail-sendmail.c @@ -68,9 +68,11 @@ send_flowed_text(FILE *where, const char *para) void mail_send(struct userNode *from, struct handle_info *to, const char *subject, const char *body, int first_time) { + struct sigaction sv; pid_t child; int infds[2], outfds[2]; - const char *fromaddr, *str; + const char *fromaddr; + const char *str; /* Grab some config items first. */ str = conf_get_data("mail/enable", RECDB_QSTRING); @@ -92,6 +94,11 @@ mail_send(struct userNode *from, struct handle_info *to, const char *subject, co } else if (child > 0) { return; } + /* Replace the old SIGCHLD signal handler. */ + memset(&sv, 0, sizeof(sv)); + sigemptyset(&sv.sa_mask); + sv.sa_handler = SIG_IGN; + sigaction(SIGCHLD, &sv, NULL); /* We're in a child now; must _exit() to die properly. */ if (pipe(infds) < 0) { log_module(MAIN_LOG, LOG_ERROR, "sendmail() child to %s couldn't pipe(infds): %s (%d)", to->email_addr, strerror(errno), errno);