Commit e2eca69d authored by Wang Shilong's avatar Wang Shilong Committed by Chris Mason

Btrfs: fix wrong extent mapping for DirectIO

btrfs_next_leaf() will use current leaf's last key to search
and then return a bigger one. So it may still return a file extent
item that is smaller than expected value and we will
get an overflow here for @em->len.

This is easy to reproduce for Btrfs Direct writting, it did not
cause any problem, because writting will re-insert right mapping later.

However, by hacking code to make DIO support compression, wrong extent
mapping is kept and it encounter merging failure(EEXIST) quickly.

Fix this problem by looping to find next file extent item that is bigger
than @start or we could not find anything more.
Signed-off-by: default avatarWang Shilong <wangsl.fnst@cn.fujitsu.com>
Reviewed-by: default avatarDavid Sterba <dsterba@suse.cz>
Signed-off-by: default avatarChris Mason <clm@fb.com>
parent 9a025a08
...@@ -6275,6 +6275,8 @@ struct extent_map *btrfs_get_extent(struct inode *inode, struct page *page, ...@@ -6275,6 +6275,8 @@ struct extent_map *btrfs_get_extent(struct inode *inode, struct page *page,
goto not_found; goto not_found;
if (start + len <= found_key.offset) if (start + len <= found_key.offset)
goto not_found; goto not_found;
if (start > found_key.offset)
goto next;
em->start = start; em->start = start;
em->orig_start = start; em->orig_start = start;
em->len = found_key.offset - start; em->len = found_key.offset - start;
......
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