Commit 61cc74fb authored by Louis Rilling's avatar Louis Rilling Committed by Jens Axboe

block: Fix io_context leak after clone with CLONE_IO

With CLONE_IO, copy_io() increments both ioc->refcount and ioc->nr_tasks.
However exit_io_context() only decrements ioc->refcount if ioc->nr_tasks
reaches 0.

Always call put_io_context() in exit_io_context().
Signed-off-by: default avatarLouis Rilling <louis.rilling@kerlabs.com>
Signed-off-by: default avatarJens Axboe <jens.axboe@oracle.com>
parent 3c764b7a
...@@ -80,8 +80,8 @@ void exit_io_context(void) ...@@ -80,8 +80,8 @@ void exit_io_context(void)
ioc->aic->exit(ioc->aic); ioc->aic->exit(ioc->aic);
cfq_exit(ioc); cfq_exit(ioc);
put_io_context(ioc);
} }
put_io_context(ioc);
} }
struct io_context *alloc_io_context(gfp_t gfp_flags, int node) struct io_context *alloc_io_context(gfp_t gfp_flags, int node)
......
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