diff options
author | Yongqiang Yang <xiaoqiangnk@gmail.com> | 2011-12-28 13:55:51 -0500 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2011-12-28 13:55:51 -0500 |
commit | 5872ddaaf05bf25e3ab90580295ebc946405928c (patch) | |
tree | 6dacee8fbc61ae67e9853edfdcddc8b9bc788b00 /fs/ext4 | |
parent | 2aff57b0c052344e8401a8b4a33c2a1ecb0f627c (diff) | |
download | linux-stable-5872ddaaf05bf25e3ab90580295ebc946405928c.tar.gz linux-stable-5872ddaaf05bf25e3ab90580295ebc946405928c.tar.bz2 linux-stable-5872ddaaf05bf25e3ab90580295ebc946405928c.zip |
ext4: flush journal when switching from data=journal mode
It's necessary to flush the journal when switching away from
data=journal mode. This is because there are no revoke records when
data blocks are journalled, but revoke records are required in the
other journal modes.
However, it is not necessary to flush the journal when switching into
data=journal mode, and flushing the journal is expensive. So let's
avoid it in that case.
Signed-off-by: Yongqiang Yang <xiaoqiangnk@gmail.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'fs/ext4')
-rw-r--r-- | fs/ext4/inode.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index cb0ba9d77a8e..1254934de693 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c @@ -4660,7 +4660,6 @@ int ext4_change_inode_journal_flag(struct inode *inode, int val) } jbd2_journal_lock_updates(journal); - jbd2_journal_flush(journal); /* * OK, there are no updates running now, and all cached data is @@ -4672,8 +4671,10 @@ int ext4_change_inode_journal_flag(struct inode *inode, int val) if (val) ext4_set_inode_flag(inode, EXT4_INODE_JOURNAL_DATA); - else + else { + jbd2_journal_flush(journal); ext4_clear_inode_flag(inode, EXT4_INODE_JOURNAL_DATA); + } ext4_set_aops(inode); jbd2_journal_unlock_updates(journal); |