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>