On Wed, Sep 14, 2016 at 3:43 PM, Amir Goldstein <amir73il@xxxxxxxxx> wrote: > This is the 3rd revision of implementing overlayfs > copy up by reflink. > Ping. Dave, Christoph, Get I get your Acks please? Miklos, Can you please look at least at patches 1,2 Thanks! Amir. > Btrfs has file reflink support and XFS is about to gain > file reflink support soon. It is very useful to use reflink > to implement copy up of regular file data when possible. > > For example, on my laptop, xfstest overlay/001 (copy up of 4G > sparse files) takes less than 1 second with copy up by reflink > vs. 25 seconds with regular copy up. > > This series includes two pairs of patches: > - patches 1,2 utilize the clone_file_range() API > - patches 3,4 utilize the copy_file_range() API > > The two pairs of patches are independent of each other. > They were each tested separately and both tested together. > All combinations passed the unionmount-testsuite (over tmpfs) > All combinations passed the overlay/??? xfstests over the > following underlying fs: > 1. ext4 (copy up) > 2. xfs + reflink patches + mkfs.xfs (copy up) > 3. xfs + reflink patches + mkfs.xfs -m reflink=1 (reflink up) > > Dave Chinner suggested the following implementation for copy up, > which I implemented in this series: > 1. try to clone_file_range() entire length > 2. fallback to trying copy_file_range() in small chunks > 3. fallback to do_splice_direct() in small chunks > > This is a good general implementation to cover the future use cases of > file systems that can do either clone_file_range() or copy_file_range(). > However, currently, the only in-tree file systems that support > clone/copy_file_range are btrfs, xfs (soon), cifs and nfs. > btrfs and xfs use the same implementation for clone and copy range, > so the copy_file_range() step is never needed. > cifs supports only clone_file_range() so copy_file_range() step is moot. > nfs does have a different implementation for clone_file_range() and > copy_file_range(), but nfs is not supported as upper layer for overlayfs > at the moment. > > Please pick patches 1,2 for clear and immediate benefit to copy up > performance on filesystems with reflink support. > > Please consider picking patches 3,4 additionally for future generations > and for code consolidation into vfs helpers. > > Cheers, > Amir. > > V3: > - Address style comments from Dave Chinner > > V2: > - Re-factor vfs helpers so they can be called from copy up > - Single call to vfs_clone_file_range() and fallback to > vfs_copy_file_range() loop > > V1: > - Replace iteravite call to copy_file_range() with > a single call to clone_file_range() > > V0: > - Call clone_file_range() and fallback to do_splice_direct() > > Amir Goldstein (4): > vfs: allow vfs_clone_file_range() across mount points > ovl: use vfs_clone_file_range() for copy up if possible > vfs: allow vfs_copy_file_range() across file systems > ovl: use vfs_copy_file_range() to copy up file data > > fs/ioctl.c | 2 ++ > fs/overlayfs/copy_up.c | 22 ++++++++++++++++------ > fs/read_write.c | 25 ++++++++++++++++++------- > 3 files changed, 36 insertions(+), 13 deletions(-) > > -- > 2.7.4 > -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html