Commit e807626e authored by Jan Kara's avatar Jan Kara Committed by Ben Hutchings

xfs: Fix possible use-after-free with AIO

commit 4b05d09c upstream.

Running AIO is pinning inode in memory using file reference. Once AIO
is completed using aio_complete(), file reference is put and inode can
be freed from memory. So we have to be sure that calling aio_complete()
is the last thing we do with the inode.

CC: xfs@oss.sgi.com
CC: Ben Myers <bpm@sgi.com>
Signed-off-by: default avatarJan Kara <jack@suse.cz>
Reviewed-by: default avatarBen Myers <bpm@sgi.com>
Signed-off-by: default avatarBen Myers <bpm@sgi.com>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 122927b0
...@@ -88,11 +88,11 @@ xfs_destroy_ioend( ...@@ -88,11 +88,11 @@ xfs_destroy_ioend(
} }
if (ioend->io_iocb) { if (ioend->io_iocb) {
inode_dio_done(ioend->io_inode);
if (ioend->io_isasync) { if (ioend->io_isasync) {
aio_complete(ioend->io_iocb, ioend->io_error ? aio_complete(ioend->io_iocb, ioend->io_error ?
ioend->io_error : ioend->io_result, 0); ioend->io_error : ioend->io_result, 0);
} }
inode_dio_done(ioend->io_inode);
} }
mempool_free(ioend, xfs_ioend_pool); mempool_free(ioend, xfs_ioend_pool);
......
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