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. Joel -- "Too much walking shoes worn thin. Too much trippin' and my soul's worn thin. Time to catch a ride it leaves today Her name is what it means. Too much walking shoes worn thin." Joel Becker Principal Software Developer Oracle E-mail: [EMAIL PROTECTED] Phone: (650) 506-8127 - 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/