On Tue, 6 Feb 2007, Joel Becker wrote: > On Tue, Feb 06, 2007 at 03:23:47PM -0800, Davide Libenzi wrote: > > struct async_submit { > > void *cookie; > > int sysc_nbr; > > int nargs; > > long args[ASYNC_MAX_ARGS]; > > int async_result; > > }; > > > > int async_submit(struct async_submit *a, int n); > > > > And async_submit() can mark each one ->async_result with -EASYNC (syscall > > has been batched), or another code (syscall completed w/out schedule). > > IMO, once you get a -EASYNC for a syscall, you *have* to retire the result. > > There are pains here, though. On every submit, you have to walk > the entire vector just to know what did or did not complete. I've seen > this in other APIs (eg, async_result would be -EAGAIN for lack of > resources to start this particular fibril). Userspace submit ends up > always walking the array of submissions twice - once to prep them, and > once to check if they actually went async. For longer lists of I/Os, > this is expensive.
Async syscall submissions are a _one time_ things. It's not like a live fd that you can push inside epoll and avoid the multiple O(N) passes. First of all, the amount of syscalls that you'd submit in a vectored way are limited. They do not depend on the total number of connections, but on the number of syscalls that you are actualy able to submit in parallel. Note that it's not a trivial tasks to extract a long enough level of parallelism, that would make you feel pain in having to walk through the submission array. Think about the trivial web server case. Remote HTTP client asks one page, and you may think to batch a few ops together (like a stat, open, send headers, and sendfile for example), but those cannot be vectored since they have to complete in order. The stat would even trigger different response to the HTTP client. You need the open() fd to submit the send-headers and sendfile. IMO there are no scalability problems in a multiple submission/retrieval API like the above (or any variation of it). - Davide - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/