Date: Fri, 22 Jan 2016 00:27:14 +1100 (EST) From: Bruce Evans <brde@optusnet.com.au> To: Konstantin Belousov <kostikbel@gmail.com> Cc: Boris Astardzhiev <boris.astardzhiev@gmail.com>, threads@freebsd.org, Jilles Tjoelker <jilles@stack.nl>, net@freebsd.org Subject: Re: Does FreeBSD have sendmmsg or recvmmsg system calls? Message-ID: <20160121233040.E1864@besplex.bde.org> In-Reply-To: <20160121093509.GK3942@kib.kiev.ua> References: <CAP=KkTxVaqZvigg78Dg%2Bv8kuTCaZyky8x15NHqD9uabuRKRkMw@mail.gmail.com> <20160116195657.GJ3942@kib.kiev.ua> <20160116202534.GK3942@kib.kiev.ua> <20160117211853.GA37847@stack.nl> <20160118044826.GS3942@kib.kiev.ua> <CAP=KkTy3J=k7hokGhohcGXv%2BWLnaxJmiAPxqmX9FHt7k0=Dp7Q@mail.gmail.com> <20160118140811.GW3942@kib.kiev.ua> <CAP=KkTzLCOnJVqt5F3ZuuZUiwkmWcne2Ynpi6-daE2jTzSBtfw@mail.gmail.com> <20160120073154.GB3942@kib.kiev.ua> <CAP=KkTx3dAUuSBrJiwNAAe%2BhHSG4j5Qp7sAcgtOgmVi8a12k1A@mail.gmail.com> <20160121093509.GK3942@kib.kiev.ua>
next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, 21 Jan 2016, Konstantin Belousov wrote: > On Wed, Jan 20, 2016 at 10:29:47AM +0200, Boris Astardzhiev wrote: >> kb>Shouldn't i and rcvd be unsigned as well ? Shouldn't return value >> kb>also be unsigned ? >> I think i and rcvd should be unsigned whereas ret should not - after all >> if an error occurred we get -1. > I looked at the real signatures and man pages for the Linux functions, > finally. There is indeed the timeout arg, the MSG_WAITFORONE flag for > recvmmsg(3), and Linux uses ints for what would be naturally size_t. It knows better than POSIX, so has restored the v7 types :-). Probably not intentionally. FreeBSD-1 used the v7 types for recv* in FreeBSD-1, but this was changed in 4.4BSD-Lite1. >> kb>> + rcvd = 0; >> kb>> + for (i = 0; i < vlen; i++) { >> kb>> + errno = 0; >> kb>> + ret = __sys_recvmsg(s, &msgvec[i].msg_hdr, flags); >> kb>> + if (ret < 0 || errno != 0) { >> kb>I do not see why do you need to clear errno before, and then do this >> test. >> kb>Just check ret == -1, in which case errno was set from the immediate >> syscall. >> kb> >> kb>> + if (rcvd != 0) { >> kb>> + /* We've received messages. Let caller >> know. */ >> kb>> + errno = 0; >> kb>This cleaning is not needed as well. For successfull functions returns, >> kb>errno value is undefined. >> >> Wouldn't I confuse apps if they check errno in the follow case - I want to >> receive two messages. The first __sys_recvmsg succeeds and then for the >> second __sys_recvmsg fails. Thus errno will be != 0 and I'm telling the app >> that I have received one message by returning 1 but errno will be != 0. >> Is this correct? > > errno value is only defined after the function explicitely returned error. > Apps which test for errno without testing for error are wrong. Mostly such tests find wrong implementations. Only low quality implmentations set error for non-errors. I checked some details: - both C99 and POSIX.1-2001 forbid setting errno to 0 in library functions - C99 and draft C11 explicitly say that errno may be clobbered for non-errors by functions that are not documented to set errno. It intends to also say that errno may not be clobbered for non-errors by functions are documented to set errno, but actually says nothing about this case (except in a footnote, it says "Thus [the usual method of setting errno before the call and checking it after ``should'' be used to check for errors]." Footnotes are not part of the standard, so this also says nothing. But it gives the intent. - C99 doesn't say anything specific about this for strtol. But strtol needs errno to not be set on non-error for its API. This gives the intent of the documentation for errno in the standard itself. - POSIX.1-2001 says that applications "should" only be examined when it is indicated to be valid by a function's return value. This is wrong for all functions where errno is part of the API (like strtol), and it would be inconsistent with C99 and C11 if these standards said what they intend to say, for many more functions. First, all of the C99 functions that are documented to set errno. Then, if POSIX follows the spirit of the intent of C99, then just about all POSIX functions must not clobber errno for non-errors, since (unlike in C99) just about all functions in POSIX are documented to set errno. - POSIX.1-2001 apparently agrees with me that C99 doesn't say what it intends to say. It explicitly says that strtol shall not change "t setting of" errno on success, and marks this as an extension of C99. - I couldn't find even a buggy generic clause in POSIX.1-2001 saying what C99 intends to say even for the C99 parts of POSIX. If there were such a clause, then strtol wouldn't need a special extension. This means that some other C99 functions need special clauses, and there are likely to be bugs in this since some don't really need them except to conform with C99's intentions. - not many C99 functions are specified to set errno. The main ones are the strtol family, math functions (most can set ERANGE or EDOM), and wide character functions (many can set EILSEQ). POSIX.1-2001 seems to be missing a special clause for the first wide character function that I looked at -- fputwc(). For math functions, it has special statements ad nauseum (about 20 lines per function for duplicated for 20-50 functions). Bruce
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20160121233040.E1864>