Commit 5cf66426 authored by Yan's avatar Yan Committed by Chris Mason

Btrfs: Off by one fixes for extent-tree.c

Signed-off-by: default avatarChris Mason <chris.mason@oracle.com>
parent 5e5745dc
...@@ -150,12 +150,9 @@ struct btrfs_block_group_cache *btrfs_lookup_block_group(struct ...@@ -150,12 +150,9 @@ struct btrfs_block_group_cache *btrfs_lookup_block_group(struct
return NULL; return NULL;
block_group = (struct btrfs_block_group_cache *)(unsigned long)ptr; block_group = (struct btrfs_block_group_cache *)(unsigned long)ptr;
if (block_group->key.objectid <= bytenr && bytenr <
if (block_group->key.objectid <= bytenr && bytenr <=
block_group->key.objectid + block_group->key.offset) block_group->key.objectid + block_group->key.offset)
return block_group; return block_group;
return NULL; return NULL;
} }
static u64 find_search_start(struct btrfs_root *root, static u64 find_search_start(struct btrfs_root *root,
...@@ -195,7 +192,7 @@ again: ...@@ -195,7 +192,7 @@ again:
continue; continue;
} }
if (data != BTRFS_BLOCK_GROUP_MIXED && if (data != BTRFS_BLOCK_GROUP_MIXED &&
start + num >= cache->key.objectid + cache->key.offset) start + num > cache->key.objectid + cache->key.offset)
goto new_group; goto new_group;
return start; return start;
} }
...@@ -1088,9 +1085,8 @@ check_pending: ...@@ -1088,9 +1085,8 @@ check_pending:
if (ins->objectid + num_bytes >= search_end) if (ins->objectid + num_bytes >= search_end)
goto enospc; goto enospc;
if (!full_scan && data != BTRFS_BLOCK_GROUP_MIXED && if (!full_scan && data != BTRFS_BLOCK_GROUP_MIXED &&
ins->objectid + num_bytes >= block_group-> ins->objectid + num_bytes > block_group->
key.objectid + block_group->key.offset) { key.objectid + block_group->key.offset) {
search_start = block_group->key.objectid + search_start = block_group->key.objectid +
block_group->key.offset; block_group->key.offset;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment