User: Password:
Subscribe / Log in / New account

Re: [RFC 1/2] net: Introduce recvmmsg socket syscall

From:  David Miller <>
Subject:  Re: [RFC 1/2] net: Introduce recvmmsg socket syscall
Date:  Wed, 20 May 2009 20:50:44 -0700 (PDT)
Message-ID:  <>
Archive-link:  Article

From: Neil Horman <>
Date: Wed, 20 May 2009 22:26:21 -0400

> I agree, your way of doing this definately lets you layer on top of
> the existing vetted implementation, which is nice, I just thought
> that avoiding the creation of another syscall might be worth a
> little extra work in the kernel.  Instead of arrays of msghdrs, We'd
> be looking at chains like this: msghdr->(struct msghdr
> *)msg_control[i].data->msghdr->etc
> Not too hard to parse, I dont think.  But I'll defer to brighter
> minds than mine.  If the creation of another syscall isn't too
> difficult a barrier to overcome (assuming this is going to occur for
> sendmsg, and various other i/o ops as well), then your way here is
> probably the way to go.

Unfortunately you can't use msg flags for this.

We accept any message flag we don't understand without signalling
any errors.

So there is no way to determine if the kernel supports the flag
or not.  Whereas with a socket option, we'll always get an error
on older kernels for unsupported options.

I think the system call is the cleanest, because it's not only a
semantic change but also a data type change.  I also think the
socket option scheme is too cumbersome.  I think it would be
common for an application to want to use both modes of sending,
especially if that application uses lots of existing library
mode to compose some messages.  And extra setsockopt() around
every call down into that library?  Yikes, good luck getting
that right all the time.  It's way too error prone.
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to
More majordomo info at

(Log in to post comments)

Copyright © 2009, Eklektix, Inc.
Comments and public postings are copyrighted by their creators.
Linux is a registered trademark of Linus Torvalds