Commit 8247b41a authored by Yan Zheng's avatar Yan Zheng Committed by Chris Mason

Btrfs: Fix starting search offset inside btrfs_drop_extents

btrfs_drop_extents will drop paths and search again when it needs to
force COW of higher nodes.  It was using the key it found during the last
search as the offset for the next search.

But, this wasn't always correct.  The key could be from before our desired
range, and because we're dropping the path, it is possible for file's items
to change while we do the search again.

The fix here is to make sure we don't search for something smaller than
the offset btrfs_drop_extents was called with.
Signed-off-by: default avatarChris Mason <chris.mason@oracle.com>
parent 8a1413a2
...@@ -436,7 +436,7 @@ int noinline btrfs_drop_extents(struct btrfs_trans_handle *trans, ...@@ -436,7 +436,7 @@ int noinline btrfs_drop_extents(struct btrfs_trans_handle *trans,
goto out; goto out;
} }
if (recow) { if (recow) {
search_start = key.offset; search_start = max(key.offset, start);
continue; continue;
} }
if (btrfs_key_type(&key) == BTRFS_EXTENT_DATA_KEY) { if (btrfs_key_type(&key) == BTRFS_EXTENT_DATA_KEY) {
......
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