On Sat 02-07-16 23:42:42, Vegard Nossum wrote: > Certain combinations of mount options in the superblock will cause > set_journal_csum_feature_set() in ext4_fill_super() to fail after the > journal has been created. When iput() is called on the journal inode, > we will hit the BUG() in ext4_should_journal_data(). We can prevent > this by only calling ext4_should_journal_data() if we already know > that it's not the journal inode. > > Fixes: 2d859db3e4 ("ext4: fix data corruption in inodes with journalled data") > Fixes: 2b405bfa84 ("ext4: fix data=journal fast mount/umount hang") > Cc: Jan Kara <jack@xxxxxxx> > Cc: stable@xxxxxxxxxxxxxxx > Signed-off-by: Vegard Nossum <vegard.nossum@xxxxxxxxxx> The patch looks good. You can add: Reviewed-by: Jan Kara <jack@xxxxxxx> Honza > --- > fs/ext4/inode.c | 6 +++--- > 1 file changed, 3 insertions(+), 3 deletions(-) > > diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c > index 91b66db..2591236 100644 > --- a/fs/ext4/inode.c > +++ b/fs/ext4/inode.c > @@ -207,9 +207,9 @@ void ext4_evict_inode(struct inode *inode) > * Note that directories do not have this problem because they > * don't use page cache. > */ > - if (ext4_should_journal_data(inode) && > - (S_ISLNK(inode->i_mode) || S_ISREG(inode->i_mode)) && > - inode->i_ino != EXT4_JOURNAL_INO) { > + if (inode->i_ino != EXT4_JOURNAL_INO && > + ext4_should_journal_data(inode) && > + (S_ISLNK(inode->i_mode) || S_ISREG(inode->i_mode))) { > journal_t *journal = EXT4_SB(inode->i_sb)->s_journal; > tid_t commit_tid = EXT4_I(inode)->i_datasync_tid; > > -- > 1.9.1 > -- Jan Kara <jack@xxxxxxxx> SUSE Labs, CR -- 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