On Sat, Mar 19, 2016 at 6:26 PM, Al Viro <viro@xxxxxxxxxxxxxxxxxx> wrote: > > Umm... You do realize that LOOKUP_RCU in flags does *NOT* guarantee that > it won't block, right? At the very least one would need to refuse to > fall back on non-RCU mode without a full restart. It actually does seem to do that, although in an admittedly rather questionable way. I think it should use path_openat() rather than do_filp_open(), but passing in LOOKUP_RCU to do_filp_open() actually does work: it just means that the retry after ECHILD/ESTALE will just do it *again* with LOOKUP_RCU. It won't fall back to non-rcu mode, it just won't or in the LOOKUP_RCU flag that is already set. So I agree that it should be cleaned up, but the basic model seems fine. I'm sure you're right about do_last() not necessarily being the best place either. But that doesn't really change that the approach seems *much* better than the old unconditional "do in a work queue". Also, the whole "no guarantees of never blocking" is a specious argument. Just copying the iocb from user space can block. Copying the pathname likewise (or copying the iovec in the case of reads and writes). So the aio interface at no point is "guaranteed to never block". Blocking will happen. You can block on allocating the "struct file", or on extending the filp table. In the end it's about _performance_, and if the performance is better with very unlikely blocking synchronous calls, then that's the right thing to do. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html