diff options
author | Filipe Manana <fdmanana@suse.com> | 2018-02-06 15:39:20 -0500 |
---|---|---|
committer | David Sterba <dsterba@suse.com> | 2018-03-01 10:18:07 -0500 |
commit | d4dfc0f4d39475ccbbac947880b5464a74c30b99 (patch) | |
tree | eb49060c37aad9e3e08368868075bd41efed2f33 /fs | |
parent | 3c181c12c431fe33b669410d663beb9cceefcd1b (diff) |
Btrfs: send, fix issuing write op when processing hole in no data mode
When doing an incremental send of a filesystem with the no-holes feature
enabled, we end up issuing a write operation when using the no data mode
send flag, instead of issuing an update extent operation. Fix this by
issuing the update extent operation instead.
Trivial reproducer:
$ mkfs.btrfs -f -O no-holes /dev/sdc
$ mkfs.btrfs -f /dev/sdd
$ mount /dev/sdc /mnt/sdc
$ mount /dev/sdd /mnt/sdd
$ xfs_io -f -c "pwrite -S 0xab 0 32K" /mnt/sdc/foobar
$ btrfs subvolume snapshot -r /mnt/sdc /mnt/sdc/snap1
$ xfs_io -c "fpunch 8K 8K" /mnt/sdc/foobar
$ btrfs subvolume snapshot -r /mnt/sdc /mnt/sdc/snap2
$ btrfs send /mnt/sdc/snap1 | btrfs receive /mnt/sdd
$ btrfs send --no-data -p /mnt/sdc/snap1 /mnt/sdc/snap2 \
| btrfs receive -vv /mnt/sdd
Before this change the output of the second receive command is:
receiving snapshot snap2 uuid=f6922049-8c22-e544-9ff9-fc6755918447...
utimes
write foobar, offset 8192, len 8192
utimes foobar
BTRFS_IOC_SET_RECEIVED_SUBVOL uuid=f6922049-8c22-e544-9ff9-...
After this change it is:
receiving snapshot snap2 uuid=564d36a3-ebc8-7343-aec9-bf6fda278e64...
utimes
update_extent foobar: offset=8192, len=8192
utimes foobar
BTRFS_IOC_SET_RECEIVED_SUBVOL uuid=564d36a3-ebc8-7343-aec9-bf6fda278e64...
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/btrfs/send.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/btrfs/send.c b/fs/btrfs/send.c index f306c608dc28..484e2af793de 100644 --- a/fs/btrfs/send.c +++ b/fs/btrfs/send.c | |||
@@ -5005,6 +5005,9 @@ static int send_hole(struct send_ctx *sctx, u64 end) | |||
5005 | u64 len; | 5005 | u64 len; |
5006 | int ret = 0; | 5006 | int ret = 0; |
5007 | 5007 | ||
5008 | if (sctx->flags & BTRFS_SEND_FLAG_NO_FILE_DATA) | ||
5009 | return send_update_extent(sctx, offset, end - offset); | ||
5010 | |||
5008 | p = fs_path_alloc(); | 5011 | p = fs_path_alloc(); |
5009 | if (!p) | 5012 | if (!p) |
5010 | return -ENOMEM; | 5013 | return -ENOMEM; |