ext4, jbd2: Add barriers for file systems with exernal journals
authorTheodore Ts'o <tytso@mit.edu>
Wed, 23 Dec 2009 11:52:08 +0000 (06:52 -0500)
committerTheodore Ts'o <tytso@mit.edu>
Wed, 23 Dec 2009 11:52:08 +0000 (06:52 -0500)
commitcc3e1bea5d87635c519da657303690f5538bb4eb
tree727b348d0389a2fe6618fb224fe1d81d207668c4
parent034fb4c95fc0fed4ec4a50778127b92c6f2aec01
ext4, jbd2: Add barriers for file systems with exernal journals

This is a bit complicated because we are trying to optimize when we
send barriers to the fs data disk.  We could just throw in an extra
barrier to the data disk whenever we send a barrier to the journal
disk, but that's not always strictly necessary.

We only need to send a barrier during a commit when there are data
blocks which are must be written out due to an inode written in
ordered mode, or if fsync() depends on the commit to force data blocks
to disk.  Finally, before we drop transactions from the beginning of
the journal during a checkpoint operation, we need to guarantee that
any blocks that were flushed out to the data disk are firmly on the
rust platter before we drop the transaction from the journal.

Thanks to Oleg Drokin for pointing out this flaw in ext3/ext4.

Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
fs/ext4/fsync.c
fs/jbd2/checkpoint.c
fs/jbd2/commit.c
include/linux/jbd2.h