提交 adaa4b8e 编写于 作者: J Jan Schmidt 提交者: Josef Bacik

Btrfs: fix EIO from btrfs send in is_extent_unchanged for punched holes

When you take a snapshot, punch a hole where there has been data, then take
another snapshot and try to send an incremental stream, btrfs send would
give you EIO. That is because is_extent_unchanged had no support for holes
being punched. With this patch, instead of returning EIO we just return
0 (== the extent is not unchanged) and we're good.
Signed-off-by: NJan Schmidt <list.btrfs@jan-o-sch.net>
Cc: Alexander Block <ablock84@gmail.com>
Signed-off-by: NJosef Bacik <jbacik@fusionio.com>
上级 4adaa611
...@@ -3945,12 +3945,10 @@ static int is_extent_unchanged(struct send_ctx *sctx, ...@@ -3945,12 +3945,10 @@ static int is_extent_unchanged(struct send_ctx *sctx,
found_key.type != key.type) { found_key.type != key.type) {
key.offset += right_len; key.offset += right_len;
break; break;
} else { }
if (found_key.offset != key.offset + right_len) { if (found_key.offset != key.offset + right_len) {
/* Should really not happen */ ret = 0;
ret = -EIO; goto out;
goto out;
}
} }
key = found_key; key = found_key;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册