On Thu, Jun 27, 2013 at 09:14:07AM +0900, OGAWA Hirofumi wrote: > Dave Chinner <david@xxxxxxxxxxxxx> writes: > > >> On another view, wait_sb_inodes() would (arguably) be necessary for > >> legacy FSes. But, for example, if data=journal on ext*, wait_sb_inodes() > >> would be more than useless, because ext* can be done it by own > >> transaction list (and more efficient way). > >> > >> Likewise, on tux3, the state is same with data=journal. > >> > >> Also, even if data=ordered, ext* might be able to check in-flight I/O by > >> ordered data list (with some new additional check, I'm not sure). > > > > Why would you bother solving this problem differently in every > > single filesystem? It's solvable at the VFS by tracking inodes that > > are no longer dirty but still under writeback on the BDI. Then > > converting wait_sb_inodes() to walk all the dirty and writeback > > inodes would be sufficient for data integrity purposes, and it would > > be done under the bdi writeback lock, not the inode_sb_list_lock.... > > > > Alternatively, splitting up the inode sb list and lock (say via the > > per-node list_lru structures in -mm and -next that are being added > > for exactly this purpose) would also significantly reduce lock > > contention on both the create/evict fast paths and the > > wait_sb_inodes() walk that is currently done.... > > > > So I think that you should address the problem properly at the VFS > > level so everyone benefits, not push interfaces that allow > > filesystem specific hacks to work around VFS level deficiencies... > > Optimizing wait_sb_inodes() might help lock contention, but it doesn't > help unnecessary wait/check. You have your own wait code, that doesn't make what the VFS does unnecesary. Quite frankly, I don't trust individual filesystems to get it right - there's a long history of filesystem specific data sync problems (including in XFS), and the best way to avoid that is to ensure the VFS gets it right for you. Indeed, we've gone from having sooper special secret sauce data sync code in XFS to using the VFS over the past few years, and the result is that it is now more reliable and faster than when we were trying to be smart and do it all ourselves. We got to where we are by fixing the problems in the VFS rather than continuing to try to work around them. > Since some FSes know about current > in-flight I/O already in those internal, so I think, those FSes can be > done it here, or are already doing in ->sync_fs(). Sure, do your internal checks in ->sync_fs(), but if wait_sb_inodes() does not have any lock contention and very little overhead, then why do you need to avoid it? This wait has to be done somewhere between sync_inodes_sb() dispatching all the IO and ->sync_fs completing, so what's the problem with hving the VFS do that *for everyone* efficiently? Fix the root cause of the problem - the sub-optimal VFS code. Hacking around it specifically for out-of-tree code is not the way things get done around here... Cheers, Dave. -- Dave Chinner david@xxxxxxxxxxxxx -- 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