提交 f5ce5a08 编写于 作者: S Sunil Mushran 提交者: Tao Ma

ocfs2: Fix incorrect checksum validation error

For local mounts, ocfs2_read_locked_inode() calls ocfs2_read_blocks_sync() to
read the inode off the disk. The latter first checks to see if that block is
cached in the journal, and, if so, returns that block. That is ok.

But ocfs2_read_locked_inode() goes wrong when it tries to validate the checksum
of such blocks. Blocks that are cached in the journal may not have had their
checksum computed as yet. We should not validate the checksums of such blocks.

Fixes ossbz#1282
http://oss.oracle.com/bugzilla/show_bug.cgi?id=1282Signed-off-by: NSunil Mushran <sunil.mushran@oracle.com>
Cc: stable@kernel.org
Singed-off-by: NTao Ma <tao.ma@oracle.com>
上级 dc696ace
...@@ -488,7 +488,11 @@ static int ocfs2_read_locked_inode(struct inode *inode, ...@@ -488,7 +488,11 @@ static int ocfs2_read_locked_inode(struct inode *inode,
OCFS2_BH_IGNORE_CACHE); OCFS2_BH_IGNORE_CACHE);
} else { } else {
status = ocfs2_read_blocks_sync(osb, args->fi_blkno, 1, &bh); status = ocfs2_read_blocks_sync(osb, args->fi_blkno, 1, &bh);
if (!status) /*
* If buffer is in jbd, then its checksum may not have been
* computed as yet.
*/
if (!status && !buffer_jbd(bh))
status = ocfs2_validate_inode_block(osb->sb, bh); status = ocfs2_validate_inode_block(osb->sb, bh);
} }
if (status < 0) { if (status < 0) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册