summaryrefslogtreecommitdiffstats
path: root/fs/btrfs
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2009-09-24 02:23:16 +0200
committerChris Mason <chris.mason@oracle.com>2009-09-24 02:30:52 +0200
commit46562cec98368623bcd18d7fd30f20c04afd5978 (patch)
tree4e5bbba7f459a1094b09413f65239b26401117f8 /fs/btrfs
parentBtrfs: fix errors handling cached state in set/clear_extent_bit (diff)
downloadlinux-46562cec98368623bcd18d7fd30f20c04afd5978.tar.xz
linux-46562cec98368623bcd18d7fd30f20c04afd5978.zip
Btrfs: Fix test_range_bit for whole file extents
If test_range_bit finds an extent that goes all the way to (u64)-1, it can incorrectly wrap the u64 instead of treaing it like the end of the address space. This just adds a check for the highest possible offset so we don't wrap. Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs')
-rw-r--r--fs/btrfs/extent_io.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/btrfs/extent_io.c b/fs/btrfs/extent_io.c
index b9506548853b..dcce98d0ec4f 100644
--- a/fs/btrfs/extent_io.c
+++ b/fs/btrfs/extent_io.c
@@ -1564,6 +1564,10 @@ int test_range_bit(struct extent_io_tree *tree, u64 start, u64 end,
bitset = 0;
break;
}
+
+ if (state->end == (u64)-1)
+ break;
+
start = state->end + 1;
if (start > end)
break;