Prev: [PATCH] Add MSG_WAITFORONE flag to recvmmsg
Next: x86: Make sure free_init_pages() free pages in boundary
From: Eric Dumazet on 26 Mar 2010 18:50 Le vendredi 26 mars 2010 à 17:35 -0500, Brandon L Black a écrit : > From: Brandon L Black <blblack(a)gmail.com> > > Add new flag MSG_WAITFORONE for the recvmmsg() syscall. > When this flag is specified for a blocking socket, recvmmsg() > will only block until at least 1 packet is available. The > default behavior is to block until all vlen packets are > available. This flag has no effect on non-blocking sockets > or when used in combination with MSG_DONTWAIT. > > Signed-off-by: Brandon L Black <blblack(a)gmail.com> > > --- > diff --git a/include/linux/socket.h b/include/linux/socket.h > index 7b3aae2..354cc56 100644 > --- a/include/linux/socket.h > +++ b/include/linux/socket.h > @@ -255,6 +255,7 @@ struct ucred { > #define MSG_ERRQUEUE 0x2000 /* Fetch message from error queue */ > #define MSG_NOSIGNAL 0x4000 /* Do not generate SIGPIPE */ > #define MSG_MORE 0x8000 /* Sender will send more */ > +#define MSG_WAITFORONE 0x10000 /* recvmmsg(): block until 1+ packets avail */ > > #define MSG_EOF MSG_FIN > > diff --git a/net/socket.c b/net/socket.c > index 769c386..33304d1 100644 > --- a/net/socket.c > +++ b/net/socket.c > @@ -2133,7 +2133,10 @@ int __sys_recvmmsg(int fd, struct mmsghdr __user *mmsg, unsigned int vlen, > > if (err) > break; > - ++datagrams; > + > + /* MSG_WAITFORONE turns on MSG_DONTWAIT after one packet */ > + if (!datagrams++ && (flags & MSG_WAITFORONE)) > + flags |= MSG_DONTWAIT; Hmmm, no need to test !datagram, just do : ++datagrams; if (flags & MSG_WAITFORONE) flags |= MSG_DONTWAIT; -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Brandon Black on 26 Mar 2010 19:00 On Fri, Mar 26, 2010 at 5:44 PM, Eric Dumazet <eric.dumazet(a)gmail.com> wrote: > Hmmm, no need to test !datagram, just do : > > ++datagrams; > > if (flags & MSG_WAITFORONE) > flags |= MSG_DONTWAIT; > Ok. I've never been through this process before. Do I resubmit a new subject/thread with the changed patch and [PATCH v2] at this point? Any other nits about how the patch was sent before I do? Thanks, -- Brandon -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Ulrich Drepper on 26 Mar 2010 22:10 On Fri, Mar 26, 2010 at 15:55, Brandon Black <blblack(a)gmail.com> wrote: > Ok. I've never been through this process before. Do I resubmit a new > subject/thread with the changed patch and [PATCH v2] at this point? The patch is small enough for this to be OK. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: David Miller on 27 Mar 2010 00:00 From: Brandon L Black <blblack(a)gmail.com> Date: Fri, 26 Mar 2010 21:18:03 -0500 > > From: Brandon L Black <blblack(a)gmail.com> > > Add new flag MSG_WAITFORONE for the recvmmsg() syscall. > When this flag is specified for a blocking socket, recvmmsg() > will only block until at least 1 packet is available. The > default behavior is to block until all vlen packets are > available. This flag has no effect on non-blocking sockets > or when used in combination with MSG_DONTWAIT. > > Signed-off-by: Brandon L Black <blblack(a)gmail.com> Arnaldo, please review this, thanks. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
From: Ulrich Drepper on 27 Mar 2010 01:00 On Fri, Mar 26, 2010 at 19:18, Brandon L Black <blblack(a)gmail.com> wrote: > Add new flag MSG_WAITFORONE for the recvmmsg() syscall. > When this flag is specified for a blocking socket, recvmmsg() > will only block until at least 1 packet is available. The > default behavior is to block until all vlen packets are > available. This flag has no effect on non-blocking sockets > or when used in combination with MSG_DONTWAIT. > > Signed-off-by: Brandon L Black <blblack(a)gmail.com> This is useful and looks OK to me. Acked-by: Ulrich Drepper <drepper(a)redhat.com> -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/
|
Next
|
Last
Pages: 1 2 Prev: [PATCH] Add MSG_WAITFORONE flag to recvmmsg Next: x86: Make sure free_init_pages() free pages in boundary |