diff options
author | Joel Becker <joel.becker@oracle.com> | 2008-11-13 17:49:11 -0500 |
---|---|---|
committer | Mark Fasheh <mfasheh@suse.com> | 2009-01-05 11:36:52 -0500 |
commit | b657c95c11088d77fc1bfc9c84d940f778bf9d12 (patch) | |
tree | 7e52e73aabbdbc55f644ad26735edc25a652ac32 /fs/ocfs2/dlmglue.c | |
parent | a68979b857283daf4acc405e476dcc8812a3ff2b (diff) |
ocfs2: Wrap inode block reads in a dedicated function.
The ocfs2 code currently reads inodes off disk with a simple
ocfs2_read_block() call. Each place that does this has a different set
of sanity checks it performs. Some check only the signature. A couple
validate the block number (the block read vs di->i_blkno). A couple
others check for VALID_FL. Only one place validates i_fs_generation. A
couple check nothing. Even when an error is found, they don't all do
the same thing.
We wrap inode reading into ocfs2_read_inode_block(). This will validate
all the above fields, going readonly if they are invalid (they never
should be). ocfs2_read_inode_block_full() is provided for the places
that want to pass read_block flags. Every caller is passing a struct
inode with a valid ip_blkno, so we don't need a separate blkno argument
either.
We will remove the validation checks from the rest of the code in a
later commit, as they are no longer necessary.
Signed-off-by: Joel Becker <joel.becker@oracle.com>
Signed-off-by: Mark Fasheh <mfasheh@suse.com>
Diffstat (limited to 'fs/ocfs2/dlmglue.c')
-rw-r--r-- | fs/ocfs2/dlmglue.c | 12 |
1 files changed, 4 insertions, 8 deletions
diff --git a/fs/ocfs2/dlmglue.c b/fs/ocfs2/dlmglue.c index 6e6cc0a2e5f7..9f2a7f75d1b3 100644 --- a/fs/ocfs2/dlmglue.c +++ b/fs/ocfs2/dlmglue.c | |||
@@ -2024,7 +2024,7 @@ static int ocfs2_inode_lock_update(struct inode *inode, | |||
2024 | } else { | 2024 | } else { |
2025 | /* Boo, we have to go to disk. */ | 2025 | /* Boo, we have to go to disk. */ |
2026 | /* read bh, cast, ocfs2_refresh_inode */ | 2026 | /* read bh, cast, ocfs2_refresh_inode */ |
2027 | status = ocfs2_read_block(inode, oi->ip_blkno, bh); | 2027 | status = ocfs2_read_inode_block(inode, bh); |
2028 | if (status < 0) { | 2028 | if (status < 0) { |
2029 | mlog_errno(status); | 2029 | mlog_errno(status); |
2030 | goto bail_refresh; | 2030 | goto bail_refresh; |
@@ -2032,18 +2032,14 @@ static int ocfs2_inode_lock_update(struct inode *inode, | |||
2032 | fe = (struct ocfs2_dinode *) (*bh)->b_data; | 2032 | fe = (struct ocfs2_dinode *) (*bh)->b_data; |
2033 | 2033 | ||
2034 | /* This is a good chance to make sure we're not | 2034 | /* This is a good chance to make sure we're not |
2035 | * locking an invalid object. | 2035 | * locking an invalid object. ocfs2_read_inode_block() |
2036 | * already checked that the inode block is sane. | ||
2036 | * | 2037 | * |
2037 | * We bug on a stale inode here because we checked | 2038 | * We bug on a stale inode here because we checked |
2038 | * above whether it was wiped from disk. The wiping | 2039 | * above whether it was wiped from disk. The wiping |
2039 | * node provides a guarantee that we receive that | 2040 | * node provides a guarantee that we receive that |
2040 | * message and can mark the inode before dropping any | 2041 | * message and can mark the inode before dropping any |
2041 | * locks associated with it. */ | 2042 | * locks associated with it. */ |
2042 | if (!OCFS2_IS_VALID_DINODE(fe)) { | ||
2043 | OCFS2_RO_ON_INVALID_DINODE(inode->i_sb, fe); | ||
2044 | status = -EIO; | ||
2045 | goto bail_refresh; | ||
2046 | } | ||
2047 | mlog_bug_on_msg(inode->i_generation != | 2043 | mlog_bug_on_msg(inode->i_generation != |
2048 | le32_to_cpu(fe->i_generation), | 2044 | le32_to_cpu(fe->i_generation), |
2049 | "Invalid dinode %llu disk generation: %u " | 2045 | "Invalid dinode %llu disk generation: %u " |
@@ -2085,7 +2081,7 @@ static int ocfs2_assign_bh(struct inode *inode, | |||
2085 | return 0; | 2081 | return 0; |
2086 | } | 2082 | } |
2087 | 2083 | ||
2088 | status = ocfs2_read_block(inode, OCFS2_I(inode)->ip_blkno, ret_bh); | 2084 | status = ocfs2_read_inode_block(inode, ret_bh); |
2089 | if (status < 0) | 2085 | if (status < 0) |
2090 | mlog_errno(status); | 2086 | mlog_errno(status); |
2091 | 2087 | ||