On Tue, Nov 13, 2012 at 11:40 AM, Alan Cox <alan@xxxxxxxxxxxxxxxxxxx> wrote: >> > Barriers are pretty much universal as you need them for power off ! >> >> I'm afraid, no storage (drives, if you like this term more) at the moment supports >> barriers and, as far as I know the storage history, has never supported. > > The ATA cache flush is a write barrier, and given you have no NV cache > visible to the controller it's the same thing. > >> Instead, what storage does support in this area are: > > Yes - the devil is in the detail once you go beyond simple capabilities. Right: barriers are trivial to program with. Ordered writes less so. One could declare all writes to be ordered with respect to each other, but this will almost certainly hurt performance (at least with disks, though probably not SSDs) as opposed to barriers, which order one group of internally-not-order writes relative to another. And declaring groups of internally-unordered writes where the groups are ordered with respect to each other... is practically the same as barriers. There's a lot to be said for simplicity... as long as the system is not so simple as to not work at all. My p.o.v. is that a filesystem write barrier is effectively the same as fsync() with the ability to return sooner (before writes hit stable storage) when the filesystem and hardware support on-disk layouts and primitives which can be used to order writes preceding and succeeding the barrier. Nico -- -- 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