Date: Thu, 1 Mar 2007 20:00:35 +0000 From: "N.J. Mann" <njm@njm.f2s.com> To: freebsd-net@freebsd.org Subject: Re: [PATCH] Re: is setsockopt SO_NOSIGPIPE work? Message-ID: <20070301200035.GA9041@ariel.njm.f2s.com> In-Reply-To: <45E70EBA.3030808@FreeBSD.org> References: <2110071423.20070301151729@citrin.ru> <20070301152942.GA27336@rambler-co.ru> <1047693239.20070301194653@citrin.ru> <45E70EBA.3030808@FreeBSD.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Thursday, 1 March, 2007 at 17:34:50 +0000, Bruce M. Simpson wrote:
> Anton Yuzhaninov wrote:
> >
> >Thanks, with send() it works fine.
> >I think it should be documented in setsockopt(2).
> Try this patch. The comment doesn't reflect what the code does. SIGPIPE
> may actually be getting queued twice in your case. It is most likely
> that the process's main thread wasn't preempted before return from the
> syscall.
>
> Perhaps someone more familiar with the signal code than I can chime in.
>
> --- sys_generic.c 14 Oct 2006 19:01:55 -0000 1.151
> +++ sys_generic.c 1 Mar 2007 17:30:39 -0000
> @@ -489,7 +489,7 @@ dofilewrite(td, fd, fp, auio, offset, fl
> error == EINTR || error == EWOULDBLOCK))
> error = 0;
> /* Socket layer is responsible for issuing SIGPIPE. */
> - if (error == EPIPE) {
> + if (fp->f_type != DTYPE_SOCKET && error == EPIPE) {
> PROC_LOCK(td->td_proc);
> psignal(td->td_proc, SIGPIPE);
> PROC_UNLOCK(td->td_proc);
Could this be why mail from cron doesn't work for me in 6.2? I got as
far as finding that cron receives a SIGPIPE while sending the mail
message to sendmail, but never worked out why. I ended up hacking cron
to ignore SIGPIPE and then ENOTIME to investigate further.
Cheers,
Nick.
--
Please do not CC me on replies, I read the list and don't need the dupes.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20070301200035.GA9041>
