diff options
author | Josef Bacik <josef@redhat.com> | 2011-03-16 13:42:43 -0400 |
---|---|---|
committer | Josef Bacik <josef@redhat.com> | 2011-03-17 14:21:37 -0400 |
commit | a826d6dcb32d811b4c81df57a5ef1367516586b0 (patch) | |
tree | 4853d5acf6cde4dfb0eeb19f5c74dc3d7934359b /fs/btrfs/extent-tree.c | |
parent | 850265335f792f5d39ab24e5fb7160bac28d77e5 (diff) |
Btrfs: check items for correctness as we search
Currently if we have corrupted items things will blow up in spectacular ways.
So as we read in blocks and they are leaves, check the entire leaf to make sure
all of the items are correct and point to valid parts in the leaf for the item
data the are responsible for. If the item is corrupt we will kick back EIO and
not read any of the copies since they are likely to not be correct either. This
will catch generic corruptions, it will be up to the individual callers of
btrfs_search_slot to make sure their items are right. Thanks,
Signed-off-by: Josef Bacik <josef@redhat.com>
Diffstat (limited to 'fs/btrfs/extent-tree.c')
-rw-r--r-- | fs/btrfs/extent-tree.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index a8f4e8d2ba60..cd794c35a636 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c | |||
@@ -4754,6 +4754,11 @@ pin: | |||
4754 | } | 4754 | } |
4755 | } | 4755 | } |
4756 | out: | 4756 | out: |
4757 | /* | ||
4758 | * Deleting the buffer, clear the corrupt flag since it doesn't matter | ||
4759 | * anymore. | ||
4760 | */ | ||
4761 | clear_bit(EXTENT_BUFFER_CORRUPT, &buf->bflags); | ||
4757 | btrfs_put_block_group(cache); | 4762 | btrfs_put_block_group(cache); |
4758 | } | 4763 | } |
4759 | 4764 | ||