diff --git a/fs/btrfs/scrub.c b/fs/btrfs/scrub.c index beb441d0c5c6c02e816d8d5c74bebf8fb5c92c0a..9fb7d09842e641fe4bd5b731e7da0d769a3c9e24 100644 --- a/fs/btrfs/scrub.c +++ b/fs/btrfs/scrub.c @@ -4480,7 +4480,8 @@ static int check_extent_to_block(struct btrfs_inode *inode, u64 start, u64 len, * move on to the next inode. */ if (em->block_start > logical || - em->block_start + em->block_len < logical + len) { + em->block_start + em->block_len < logical + len || + test_bit(EXTENT_FLAG_PREALLOC, &em->flags)) { free_extent_map(em); ret = 1; goto out_unlock;