vf/remap: return the amount of bytes actually deduplicated
authorAnsgar Lößer <ansgar.loesser@tu-darmstadt.de>
Wed, 13 Jul 2022 18:51:44 +0000 (20:51 +0200)
committerLinus Torvalds <torvalds@linux-foundation.org>
Wed, 13 Jul 2022 19:08:14 +0000 (12:08 -0700)
When using the FIDEDUPRANGE ioctl, in case of success the requested size
is returned. In some cases this might not be the actual amount of bytes
deduplicated.

This change modifies vfs_dedupe_file_range() to report the actual amount
of bytes deduplicated, instead of the requested amount.

Link: https://lore.kernel.org/linux-fsdevel/5548ef63-62f9-4f46-5793-03165ceccacc@tu-darmstadt.de/
Reported-by: Ansgar Lößer <ansgar.loesser@kom.tu-darmstadt.de>
Reported-by: Max Schlecht <max.schlecht@informatik.hu-berlin.de>
Reported-by: Björn Scheuermann <scheuermann@kom.tu-darmstadt.de>
Cc: Dave Chinner <david@fromorbit.com>
Cc: Darrick J Wong <djwong@kernel.org>
Signed-off-by: Ansgar Lößer <ansgar.loesser@kom.tu-darmstadt.de>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
fs/remap_range.c

index 881a306..5e0d97e 100644 (file)
@@ -547,7 +547,7 @@ int vfs_dedupe_file_range(struct file *file, struct file_dedupe_range *same)
                else if (deduped < 0)
                        info->status = deduped;
                else
-                       info->bytes_deduped = len;
+                       info->bytes_deduped = deduped;
 
 next_fdput:
                fdput(dst_fd);