Date: 4 Jan 2016 09:11:08 +0000 From: "Mark Delany" <c2h@romeo.emu.st> To: freebsd-net@freebsd.org Subject: Re: Does FreeBSD have sendmmsg or recvmmsg system calls? Message-ID: <20160104091108.50654.qmail@f5-external.bushwire.net> In-Reply-To: <20160104085415.GS3625@kib.kiev.ua> References: <alpine.BSF.2.20.1601031833130.84701@localhost.my.domain> <1451841004.10139.34.camel@me.com> <alpine.BSF.2.20.1601031744040.20884@fledge.watson.org> <CAJ-Vmomxcn%2BiYJAzNViL8WnepsCihrkTuHd8=0O6vONKsTExCA@mail.gmail.com> <20160103214720.72014.qmail@f5-external.bushwire.net> <20160104085415.GS3625@kib.kiev.ua>
next in thread | previous in thread | raw e-mail | index | archive | help
On 04Jan16, Konstantin Belousov allegedly wrote: > On Sun, Jan 03, 2016 at 09:47:20PM +0000, Mark Delany wrote: > > Eg, if a signal arrives after > > more than zero packets have been processed by recvmmsg() what is the > > correct return value? -1 or the count of messages returned? > > This is really not a question to consider different answers. Unix > already made a (right, IMO) decision there, e.g. for read(2) syscall. > If any data was actually read, the length of the consumed data must be > returned, and not the error. So the error is lost? In that case, recvmmsg() is not the same as an iteration over recvmsg(). Besides, a signal isn't necessarily an error. Think SIGALRM. The point is that recvmmsg() may have populated the struct mmsghdr* with a number of inbound messages then it is interrupted by a signal. It then has a choice of telling user space that it has 'n' messages to be processed or -1/EINTR that a signal occurred. If the choice is the former, then the signal is lost. If the choice is the latter then 'n' messages are lost. There is no return possible which indicates that there are messages *and* a signal. Thinking out loud here: are there any other "batch" system calls like recvmmsg() that can offer guidance? Mark.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20160104091108.50654.qmail>
