On Thu, Nov 24, 2011 at 11:46:26AM -0800, Tejun Heo wrote: > ext4_end_io_dio() queues io_end->work and then clears iocb->private; > however, io_end->work completes the iocb by calling aio_complete(), > which may happen before io_end->work clearing thus leading to > use-after-free. > > Detected and tested with slab poisoning. > > Signed-off-by: Tejun Heo <tj@xxxxxxxxxx> > Reported-by: Kent Overstreet <koverstreet@xxxxxxxxxx> > Tested-by: Kent Overstreet <koverstreet@xxxxxxxxxx> > Cc: stable@xxxxxxxxxx Thanks!! I've been trying to track down this bug for a while. The repro case I had ran the 12 fio's against 12 different file systems with the following configuration: [global] direct=1 ioengine=libaio iodepth=1 bs=4k ba=4k size=128m [create] filename=${TESTDIR} rw=write ... and would leave a few inodes with elevated i_ioend_counts, which means any attempt to delete those inodes or to unmount the file system owning those inodes would hang forever. With your patch this problem goes away. >I *think* this is the correct fix but am not too familiar with code >path, so please proceed with caution. Looks good to me. Thanks, applied. >Thank you. No, thank *you*! :-) - Ted P.S. It would be nice to get this into xfstests, but it requires at least 10-12 (12 to repro it reliably) HDD's, and a fairly high core count machine in order to reproduce it. I played around with trying to create a reproducer that worked on a smaller number of disks and/or fio's/CPU's, but I was never able to manage it. -- To unsubscribe from this list: send the line "unsubscribe linux-ext4" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html