aio: merge aio_cancel_all() with wait_for_all_aios()
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
a1c2aa1e86
commit
06af121eab
1 changed files with 7 additions and 15 deletions
22
fs/aio.c
22
fs/aio.c
|
@ -305,15 +305,18 @@ static struct kioctx *ioctx_alloc(unsigned nr_events)
|
||||||
return ERR_PTR(err);
|
return ERR_PTR(err);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* aio_cancel_all
|
/* kill_ctx
|
||||||
* Cancels all outstanding aio requests on an aio context. Used
|
* Cancels all outstanding aio requests on an aio context. Used
|
||||||
* when the processes owning a context have all exited to encourage
|
* when the processes owning a context have all exited to encourage
|
||||||
* the rapid destruction of the kioctx.
|
* the rapid destruction of the kioctx.
|
||||||
*/
|
*/
|
||||||
static void aio_cancel_all(struct kioctx *ctx)
|
static void kill_ctx(struct kioctx *ctx)
|
||||||
{
|
{
|
||||||
int (*cancel)(struct kiocb *, struct io_event *);
|
int (*cancel)(struct kiocb *, struct io_event *);
|
||||||
|
struct task_struct *tsk = current;
|
||||||
|
DECLARE_WAITQUEUE(wait, tsk);
|
||||||
struct io_event res;
|
struct io_event res;
|
||||||
|
|
||||||
spin_lock_irq(&ctx->ctx_lock);
|
spin_lock_irq(&ctx->ctx_lock);
|
||||||
ctx->dead = 1;
|
ctx->dead = 1;
|
||||||
while (!list_empty(&ctx->active_reqs)) {
|
while (!list_empty(&ctx->active_reqs)) {
|
||||||
|
@ -329,15 +332,7 @@ static void aio_cancel_all(struct kioctx *ctx)
|
||||||
spin_lock_irq(&ctx->ctx_lock);
|
spin_lock_irq(&ctx->ctx_lock);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
spin_unlock_irq(&ctx->ctx_lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void wait_for_all_aios(struct kioctx *ctx)
|
|
||||||
{
|
|
||||||
struct task_struct *tsk = current;
|
|
||||||
DECLARE_WAITQUEUE(wait, tsk);
|
|
||||||
|
|
||||||
spin_lock_irq(&ctx->ctx_lock);
|
|
||||||
if (!ctx->reqs_active)
|
if (!ctx->reqs_active)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
@ -387,9 +382,7 @@ void exit_aio(struct mm_struct *mm)
|
||||||
ctx = hlist_entry(mm->ioctx_list.first, struct kioctx, list);
|
ctx = hlist_entry(mm->ioctx_list.first, struct kioctx, list);
|
||||||
hlist_del_rcu(&ctx->list);
|
hlist_del_rcu(&ctx->list);
|
||||||
|
|
||||||
aio_cancel_all(ctx);
|
kill_ctx(ctx);
|
||||||
|
|
||||||
wait_for_all_aios(ctx);
|
|
||||||
|
|
||||||
if (1 != atomic_read(&ctx->users))
|
if (1 != atomic_read(&ctx->users))
|
||||||
printk(KERN_DEBUG
|
printk(KERN_DEBUG
|
||||||
|
@ -1269,8 +1262,7 @@ static void io_destroy(struct kioctx *ioctx)
|
||||||
if (likely(!was_dead))
|
if (likely(!was_dead))
|
||||||
put_ioctx(ioctx); /* twice for the list */
|
put_ioctx(ioctx); /* twice for the list */
|
||||||
|
|
||||||
aio_cancel_all(ioctx);
|
kill_ctx(ioctx);
|
||||||
wait_for_all_aios(ioctx);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Wake up any waiters. The setting of ctx->dead must be seen
|
* Wake up any waiters. The setting of ctx->dead must be seen
|
||||||
|
|
Loading…
Reference in a new issue