Commit c016e225 authored by Sébastien Dugu's avatar Sébastien Dugu Committed by Linus Torvalds

[PATCH] aio-retry-fix: fix aio retry work queueing

In the case of buffered AIO, in the aio retry path (aio_run_iocb), when the
retry method returns EIOCBRETRY the kicked iocb is added to the context run
list but is never queued onto the work queue.  The request therefore is
never completed.

This patch fixes that by adding the appropriate call to aio_queue_work in
aio_run_aiocb so that subsequent retries will be handled by the aio worker
thread.
Signed-off-by: default avatarSébastien Dugué <sebastien.dugue@bull.net>
Acked-by: default avatarBenjamin LaHaise <benjamin.c.lahaise@intel.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 334a13ec
...@@ -58,6 +58,7 @@ static DEFINE_SPINLOCK(fput_lock); ...@@ -58,6 +58,7 @@ static DEFINE_SPINLOCK(fput_lock);
static LIST_HEAD(fput_head); static LIST_HEAD(fput_head);
static void aio_kick_handler(void *); static void aio_kick_handler(void *);
static void aio_queue_work(struct kioctx *);
/* aio_setup /* aio_setup
* Creates the slab caches used by the aio routines, panic on * Creates the slab caches used by the aio routines, panic on
...@@ -747,6 +748,14 @@ out: ...@@ -747,6 +748,14 @@ out:
* has already been kicked */ * has already been kicked */
if (kiocbIsKicked(iocb)) { if (kiocbIsKicked(iocb)) {
__queue_kicked_iocb(iocb); __queue_kicked_iocb(iocb);
/*
* __queue_kicked_iocb will always return 1 here, because
* iocb->ki_run_list is empty at this point so it should
* be safe to unconditionally queue the context into the
* work queue.
*/
aio_queue_work(ctx);
} }
} }
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment