linux-fsdevel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Peng Tao <tao.peng@primarydata.com>
To: linux-fsdevel@vger.kernel.org
Cc: Trond Myklebust <trond.myklebust@primarydata.com>,
	Anna Schumaker <anna.schumaker@netapp.com>,
	Christoph Hellwig <hch@infradead.org>, Zach Brown <zab@zabbo.net>,
	Darren Hart <dvhart@linux.intel.com>,
	bfields@fieldses.org, Jeff Layton <jeff.layton@primarydata.com>,
	linux-nfs@vger.kernel.org,
	"Darrick J. Wong" <darrick.wong@oracle.com>,
	linux-btrfs@vger.kernel.org, Peng Tao <tao.peng@primarydata.com>
Subject: [PATCH-RFC-RESEND 0/9] NFS/NFSD: add NFSv42 CLONE operation support
Date: Wed, 26 Aug 2015 16:16:41 +0800	[thread overview]
Message-ID: <1440577010-122867-1-git-send-email-tao.peng@primarydata.com> (raw)

[resend ccing linux-fsdevel list and dropping the two nfs cleanup patches,
 which were sent to nfs list separately.]

This patchset adds NFSv42 COPY support to nfs and nfsd. As suggested by Christoph,
it pulls btrfs BTRFS_IOC_CLONE/BTRFS_IOC_CLONE_RANGE ioctls to generic layer and
adds a new file operation to call down to file systems. Then the CLONE ioctl
is implemented for NFS and NFSD.

I took a slightly different approach from Anna's NFS42 COPY implementation
(http://www.spinics.net/lists/linux-nfs/msg53009.html) mainly because CLONE
has different requirements than COPY. And the main differences between the two are:
1. well, CLONE is supported rather than COPY.
2. vfs_file_clone_range() does not expect file systems to do data copy, and thus
no rw_verify_area() required.
3. clone does not expect partial success.
4. clone does not fall back to data copy if underlying storage does not support it.
5. no new system call required. We reuse existing BTRFS_IOC_CLONE/BTRFS_IOC_CLONE_RANGE
and make it generic to all file systems.

This overlaps with Anna's COPY work. We'll deal with the conflicts after figuring out
what to do with both patchsets.

Cheers,
Tao

Anna Schumaker (2):
  nfsd: Pass filehandle to nfs4_preprocess_stateid_op()
  NFSD: Implement the CLONE call

Peng Tao (7):
  vfs: pull btrfs clone API to vfs layer
  vfs/btrfs: add .clone_range file operation
  nfs42: add CLONE xdr functions
  nfs42: add CLONE proc functions
  nfs42: add .copy_range file operation
  nfs: get clone_blksize when probing fsinfo
  nfs42: respect clone_blksize

 fs/btrfs/ctree.h           |  2 +
 fs/btrfs/file.c            |  1 +
 fs/btrfs/ioctl.c           | 68 ++++----------------------------
 fs/ioctl.c                 | 30 ++++++++++++++
 fs/nfs/client.c            |  1 +
 fs/nfs/nfs42.h             |  1 +
 fs/nfs/nfs42proc.c         | 71 +++++++++++++++++++++++++++++++++
 fs/nfs/nfs42xdr.c          | 97 +++++++++++++++++++++++++++++++++++++++++++++-
 fs/nfs/nfs4file.c          | 58 +++++++++++++++++++++++++++
 fs/nfs/nfs4proc.c          |  4 +-
 fs/nfs/nfs4xdr.c           | 26 +++++++++++++
 fs/nfsd/nfs4proc.c         | 95 +++++++++++++++++++++++++++++++++++++++++----
 fs/nfsd/nfs4state.c        |  5 +--
 fs/nfsd/nfs4xdr.c          | 21 ++++++++++
 fs/nfsd/state.h            |  4 +-
 fs/nfsd/vfs.c              |  7 ++++
 fs/nfsd/vfs.h              |  1 +
 fs/nfsd/xdr4.h             | 10 +++++
 fs/read_write.c            | 45 +++++++++++++++++++++
 include/linux/fs.h         |  4 ++
 include/linux/nfs4.h       |  7 +++-
 include/linux/nfs_fs_sb.h  |  2 +
 include/linux/nfs_xdr.h    | 20 ++++++++++
 include/uapi/linux/btrfs.h | 10 -----
 include/uapi/linux/fs.h    |  9 +++++
 25 files changed, 512 insertions(+), 87 deletions(-)

-- 
1.8.3.1


             reply	other threads:[~2015-08-26  8:18 UTC|newest]

Thread overview: 22+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-08-26  8:16 Peng Tao [this message]
2015-08-26  8:16 ` [PATCH-RFC-RESEND 1/9] vfs: pull btrfs clone API to vfs layer Peng Tao
     [not found]   ` <1440577010-122867-2-git-send-email-tao.peng-7I+n7zu2hftEKMMhf/gKZA@public.gmane.org>
2015-08-26 13:37     ` David Sterba
2015-08-26 16:21       ` Darrick J. Wong
     [not found]         ` <20150826162154.GD10038-PTl6brltDGh4DFYR7WNSRA@public.gmane.org>
2015-08-26 16:36           ` David Sterba
     [not found]       ` <20150826133723.GX10756-1ReQVI26iDCaZKY3DrU6dA@public.gmane.org>
2015-08-28  3:09         ` Peng Tao
2015-08-26 22:52     ` Dave Chinner
2015-08-27  6:23       ` Peng Tao
2015-08-26  8:16 ` [PATCH-RFC-RESEND 2/9] vfs/btrfs: add .clone_range file operation Peng Tao
2015-08-26 13:17   ` Christoph Hellwig
2015-08-27  6:15     ` Peng Tao
2015-08-26  8:16 ` [PATCH-RFC-RESEND 3/9] nfs42: add CLONE xdr functions Peng Tao
2015-08-26  8:16 ` [PATCH-RFC-RESEND 4/9] nfs42: add CLONE proc functions Peng Tao
2015-08-26  8:16 ` [PATCH-RFC-RESEND 5/9] nfs42: add .copy_range file operation Peng Tao
     [not found]   ` <1440577010-122867-6-git-send-email-tao.peng-7I+n7zu2hftEKMMhf/gKZA@public.gmane.org>
2015-08-26 22:48     ` Dave Chinner
2015-08-27  6:17       ` Peng Tao
2015-08-26  8:16 ` [PATCH-RFC-RESEND 6/9] nfs: get clone_blksize when probing fsinfo Peng Tao
2015-08-26  8:16 ` [PATCH-RFC-RESEND 7/9] nfs42: respect clone_blksize Peng Tao
2015-08-26  8:16 ` [PATCH-RFC-RESEND 8/9] nfsd: Pass filehandle to nfs4_preprocess_stateid_op() Peng Tao
     [not found] ` <1440577010-122867-1-git-send-email-tao.peng-7I+n7zu2hftEKMMhf/gKZA@public.gmane.org>
2015-08-26  8:16   ` [PATCH-RFC-RESEND 9/9] NFSD: Implement the CLONE call Peng Tao
2015-08-26 13:11   ` [PATCH-RFC-RESEND 0/9] NFS/NFSD: add NFSv42 CLONE operation support Christoph Hellwig
2015-08-27  6:24     ` Peng Tao

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1440577010-122867-1-git-send-email-tao.peng@primarydata.com \
    --to=tao.peng@primarydata.com \
    --cc=anna.schumaker@netapp.com \
    --cc=bfields@fieldses.org \
    --cc=darrick.wong@oracle.com \
    --cc=dvhart@linux.intel.com \
    --cc=hch@infradead.org \
    --cc=jeff.layton@primarydata.com \
    --cc=linux-btrfs@vger.kernel.org \
    --cc=linux-fsdevel@vger.kernel.org \
    --cc=linux-nfs@vger.kernel.org \
    --cc=trond.myklebust@primarydata.com \
    --cc=zab@zabbo.net \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).