Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit adaa4b8e authored by Jan Schmidt's avatar Jan Schmidt Committed by Josef Bacik
Browse files

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: default avatarJan Schmidt <list.btrfs@jan-o-sch.net>
Cc: Alexander Block <ablock84@gmail.com>
Signed-off-by: default avatarJosef Bacik <jbacik@fusionio.com>
parent 4adaa611
Loading
Loading
Loading
Loading
+4 −6
Original line number Diff line number Diff line
@@ -3945,13 +3945,11 @@ static int is_extent_unchanged(struct send_ctx *sctx,
		    found_key.type != key.type) {
			key.offset += right_len;
			break;
		} else {
		}
		if (found_key.offset != key.offset + right_len) {
				/* Should really not happen */
				ret = -EIO;
			ret = 0;
			goto out;
		}
		}
		key = found_key;
	}