On Thu, Mar 21, 2013 at 09:35:32AM -0700, Kent Overstreet wrote:
> Freeing a kiocb needed to touch the kioctx for three things:
> 
>  * Pull it off the reqs_active list
>  * Decrementing reqs_active
>  * Issuing a wakeup, if the kioctx was in the process of being freed.
> 
> This patch moves these to aio_complete(), for a couple reasons:
> 
>  * aio_complete() already has to issue the wakeup, so if we drop the
>    kioctx refcount before aio_complete does its wakeup we don't have to
>    do it twice.
>  * aio_complete currently has to take the kioctx lock, so it makes sense
>    for it to pull the kiocb off the reqs_active list too.
>  * A later patch is going to change reqs_active to include unreaped
>    completions - this will mean allocating a kiocb doesn't have to look
>    at the ringbuffer. So taking the decrement of reqs_active out of
>    kiocb_free() is useful prep work for that patch.
> 
> This doesn't really affect cancellation, since existing (usb) code that
> implements a cancel function still calls aio_complete() - we just have
> to make sure that aio_complete does the necessary teardown for cancelled
> kiocbs.
> 
> It does affect code paths where we free kiocbs that were never
> submitted; they need to decrement reqs_active and pull the kiocb off the
> reqs_active list. This occurs in two places: kiocb_batch_free(), which
> is going away in a later patch, and the error path in io_submit_one.
> 
> Signed-off-by: Kent Overstreet <[email protected]>

Reviewed-by: "Theodore Ts'o" <[email protected]>
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to