On Thu, Dec 27, 2012 at 9:59 AM, Kent Overstreet <koverstreet@xxxxxxxxxx> wrote: > @@ -1585,18 +1278,27 @@ static int io_submit_one(struct kioctx *ctx, struct iocb __user *user_iocb, > * don't see ctx->dead set here, io_destroy() waits for our IO to > * finish. > */ > - if (ctx->dead) { > - spin_unlock_irq(&ctx->ctx_lock); > + if (ctx->dead) > ret = -EINVAL; > + spin_unlock_irq(&ctx->ctx_lock); > + if (ret) > goto out_put_req; > + > + if (unlikely(kiocbIsCancelled(req))) { > + ret = -EINTR; > + } else { > + ret = req->ki_retry(req); > } > - aio_run_iocb(req); > - if (!list_empty(&ctx->run_list)) { > - /* drain the run list */ > - while (__aio_run_iocbs(ctx)) > - ; > + if (ret != -EIOCBQUEUED) { > + /* > + * There's no easy way to restart the syscall since other AIO's > + * may be already running. Just fail this IO with EINTR. > + */ > + if (unlikely(ret == -ERESTARTSYS || ret == -ERESTARTNOINTR || > + ret == -ERESTARTNOHAND || ret == -ERESTART_RESTARTBLOCK)) > + ret = -EINTR; > + aio_complete(req, ret, 0); > } > - spin_unlock_irq(&ctx->ctx_lock); > > aio_put_req(req); /* drop extra ref to req */ > return 0; return ret; yes? -- 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