On Wed, Aug 29, 2012 at 02:17:12PM +0800, Miao Xie wrote: > writeback_inodes_sb(_nr)_if_idle() is re-implemented by replacing down_read() > with down_read_trylock() because > - If ->s_umount is write locked, then the sb is not idle. That is > writeback_inodes_sb(_nr)_if_idle() needn't wait for the lock. > - writeback_inodes_sb(_nr)_if_idle() grabs s_umount lock when it want to start > writeback, it may bring us deadlock problem when doing umount. > (Ex. Btrfs has such a problem, see the following URL > http://marc.info/?l=linux-btrfs&m=133540923510561&w=2) > > The name of these two functions is cumbersome, so rename them to > try_to_writeback_inodes_sb(_nr). > > This idea came from Christoph Hellwig. > Some code is from the patch of Kamal Mostafa. > > Signed-off-by: Miao Xie <miaox@xxxxxxxxxxxxxx> Tested-by: David Sterba <dsterba@xxxxxxx> > --- > Many users who use btrfs met the deadlock problem caused by writeback_inodes_sb(_nr)_if_idle(), > so I send this patch again and hope it will be received as soon as possible if nobody objects. Yes please, this makes testing of the 'autodefrag' mount option hard as the deadlock occurs frequently upon umount (when there's a background snapshot cleanup in progress). >From the user's POV, the autodefrag improves performance, it's not yet on by default until it proves to be stable, the deadlocks were standing in the way for long. thanks, david -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html