]> git.baikalelectronics.ru Git - kernel.git/commit
jbd: clear revoked flag on buffers before a new transaction started
authorYongqiang Yang <xiaoqiangnk@gmail.com>
Sat, 19 Nov 2011 09:34:29 +0000 (17:34 +0800)
committerJan Kara <jack@suse.cz>
Tue, 22 Nov 2011 00:20:53 +0000 (01:20 +0100)
commitb63ca9699a87ae3d89d3ed34517b2297ab425616
tree9295744be006082391c9bfeed2cabf43b29cc4ea
parent6771335023fa96532f2010b85116b4e062919c3c
jbd: clear revoked flag on buffers before a new transaction started

Currently, we clear revoked flag only when a block is reused.  However,
this can tigger a false journal error.  Consider a situation when a block
is used as a meta block and is deleted(revoked) in ordered mode, then the
block is allocated as a data block to a file.  At this moment, user changes
the file's journal mode from ordered to journaled and truncates the file.
The block will be considered re-revoked by journal because it has revoked
flag still pending from the last transaction and an assertion triggers.

We fix the problem by keeping the revoked status more uptodate - we clear
revoked flag when switching revoke tables to reflect there is no revoked
buffers in current transaction any more.

Signed-off-by: Yongqiang Yang <xiaoqiangnk@gmail.com>
Signed-off-by: Jan Kara <jack@suse.cz>
fs/jbd/commit.c
fs/jbd/revoke.c
include/linux/jbd.h