> You could also say that flush sequence counting code doesn't belong > to xfs code at all. There is nothing xfs specific about it. > > If we had an API: > > flush_seq = blkdev_get_flush_seq(bdev, flush_seq); > blkdev_issue_flush_after(bdev, flush_seq); > > I am sure it would have been useful to more fs. > > In fact, block drivers that use blk_insert_flush(), > already have serialized flush requests, so implementing > the above functionality would be quite trivial for those. > > I am not fluent enough in block layer to say if this makes sense. > Christoph? Should we add some block people to this discussion? Not that the interface can't be based on blkdev_issue_flush as our most important flushes are submitted asynchronously. But except for that tying into the flush state machine sounds very interesting. Let me look into that as the designate xfs <-> block layer liaison.