fix sendmmsg emulation return value for zero-length vector
authorRich Felker <dalias@aerifal.cx>
Fri, 20 Jun 2014 06:13:38 +0000 (02:13 -0400)
committerRich Felker <dalias@aerifal.cx>
Fri, 20 Jun 2014 06:13:38 +0000 (02:13 -0400)
this case is not even documented, but the kernel returns 0 here and it
makes sense to be consistent.

src/network/sendmmsg.c

index ff9f861..eeae1d0 100644 (file)
@@ -12,6 +12,7 @@ int sendmmsg(int fd, struct mmsghdr *msgvec, unsigned int vlen, unsigned int fla
         * and the cmsg blocks cannot be modified in-place. */
        int i;
        if (vlen > IOV_MAX) vlen = IOV_MAX; /* This matches the kernel. */
+       if (!vlen) return 0;
        for (i=0; i<vlen; i++) {
                /* As an unfortunate inconsistency, the sendmmsg API uses
                 * unsigned int for the resulting msg_len, despite sendmsg