Received: by 2002:a25:c593:0:0:0:0:0 with SMTP id v141csp42309ybe; Thu, 12 Sep 2019 15:16:52 -0700 (PDT) X-Google-Smtp-Source: APXvYqzvVdKTxqgVkbRAfzeyvs89wGUqizGn7zn7BNLC40W2KT4/Bg+3t6qmmKh/9F2b1fkZCGsF X-Received: by 2002:a50:b924:: with SMTP id m33mr44233006ede.61.1568326612820; Thu, 12 Sep 2019 15:16:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1568326612; cv=none; d=google.com; s=arc-20160816; b=R3v2XNRbnrZP1WsDXbspxHmPzQfHdfQCRK966Fa0aImTRjQwpvGt0GBnH/uB5zePR/ jDfsAJYAaNwZPN2dodIgsqSPgXPfkchKeWilp3xUGLBzMnwU+PStu0vlDlq2Kue/dsG8 IY2fNsuSr67SkGYBk0I6pqnS3XGhYKjvAjNtxb7IqDcVvFgi+P+vcEXuKy60tuLAHB4f GTLDXDz+1d7QkcrqiD66gdly00x1KJ0Xx080oeenb5lLjxNnK0Ah0MI3tHORnrFGRBFM BuOn3sEf820EiPuEsCmpWkGYcxISxL38AdhQdWbkSWFrxknX4Ib9rZ/4w38Q4HWk2Wpj AaZA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:from:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:date; bh=dt6C+cSN2nUuayHp//MBJ6xDNmpikfjOLB5yk79p4hY=; b=H4pWE4RgcVRcu/c0dvNL7DKq4cV80smgIUkOIbzNGf227gw5WTvYx67AcKJ4SKZgGJ Ksv5KwuMbHF2fBkjZIaV0aBz4SW1ZT0HKSy84tfIFTEc+r9z2A/OWTatw87t2/nGQgfI 2x3PF3tnkWZK+6hUwomRdH+ziKof7N+VRiD77gOD1exUMyJLUzeiU2YhpUFoYliobcfY LwNdvsF+y/4dglcjceN7YUXioeO5NsagNVhDwC74IvpRHIunpq9zMo6ONBgiYOKVAjJn bkL5a6pWkfmhyNY3mcvhY9RDiDx+X2VW61WJ+Ik1k8+WHSISW21+tCf8S/2/SH//E5Sg 3FrQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-nfs-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c23si9757500edt.376.2019.09.12.15.16.28; Thu, 12 Sep 2019 15:16:52 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-nfs-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-nfs-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-nfs-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726164AbfILU0Z (ORCPT + 99 others); Thu, 12 Sep 2019 16:26:25 -0400 Received: from fieldses.org ([173.255.197.46]:35192 "EHLO fieldses.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725995AbfILU0Z (ORCPT ); Thu, 12 Sep 2019 16:26:25 -0400 Received: by fieldses.org (Postfix, from userid 2815) id CCD851B96; Thu, 12 Sep 2019 16:26:24 -0400 (EDT) Date: Thu, 12 Sep 2019 16:26:24 -0400 To: Olga Kornievskaia Cc: trond.myklebust@hammerspace.com, Anna Schumaker , "J. Bruce Fields" , linux-nfs Subject: Re: [PATCH v6 00/19] client and server support for "inter" SSC copy Message-ID: <20190912202624.GC5054@fieldses.org> References: <20190906194631.3216-1-olga.kornievskaia@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) From: bfields@fieldses.org (J. Bruce Fields) Sender: linux-nfs-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-nfs@vger.kernel.org On Fri, Sep 06, 2019 at 04:27:32PM -0400, Olga Kornievskaia wrote: > Trond/Anna, > > Please ignore this current version. With working on the server, I have > forgotten that I had change(s) to the client side but didn't include > them here. I'll repost with those changes. > > Bruce, server side changes are all here. There are conflicts with my 5.4 tree, mostly due to the file caching stuff. I started trying to fix them up myself but there were more than I expected and as I was afraid I'd screw it up. Could you take a look? --b. > > On Fri, Sep 6, 2019 at 3:46 PM Olga Kornievskaia > wrote: > > > > As per Bruce's request submitting the client and server series together > > as there is a common patch that's needed by both. > > > > No client side changes were made since the previous submission > > > > v6 server-side changes > > --- removed global copy notify list and instead relying only on the idr > > list of stateids. Laundromat now traverses that list and if copy notify > > state wasn't referenced in a lease period, state is deleted. > > --- removed storing parent's stid pointer in the copy notify state. > > instead storing the parent's stateid and client id then using it to > > lookup the stid structure and client structure during validation of > > the stateid of the READ. > > --- added a refcount to the copy notify state to make sure only 1 will > > delete it (as it can be delete either by the nfs4_put_stid(), > > laundromat, or offload_cancel op. basically all access to the copy state > > is using just one global lock now (netd->s2s_cp_lock). > > --- added a type to the copy_stateid_t to distinguish copy notify state > > kept by the source server and copy state used by the destination server. > > --- previously with a global copy notify list, the check if client has > > state before unmounting checked if the list was empty, now the code > > traverses the idr list and looks for anything with a matching clientid > > (again under the global s2s_cp_lock). > > > > Olga Kornievskaia (19): > > NFS NFSD: defining nl4_servers structure needed by both > > NFS: add COPY_NOTIFY operation > > NFS: add ca_source_server<> to COPY > > NFS: also send OFFLOAD_CANCEL to source server > > NFS: inter ssc open > > NFS: skip recovery of copy open on dest server > > NFS: for "inter" copy treat ESTALE as ENOTSUPP > > NFS: COPY handle ERR_OFFLOAD_DENIED > > NFS: handle source server reboot > > NFS: replace cross device check in copy_file_range > > NFSD fill-in netloc4 structure > > NFSD add ca_source_server<> to COPY > > NFSD return nfs4_stid in nfs4_preprocess_stateid_op > > NFSD COPY_NOTIFY xdr > > NFSD add COPY_NOTIFY operation > > NFSD check stateids against copy stateids > > NFSD generalize nfsd4_compound_state flag names > > NFSD: allow inter server COPY to have a STALE source server fh > > NFSD add nfs4 inter ssc to nfsd4_copy > > > > fs/nfs/nfs42.h | 15 +- > > fs/nfs/nfs42proc.c | 193 ++++++++++++++++---- > > fs/nfs/nfs42xdr.c | 190 +++++++++++++++++++- > > fs/nfs/nfs4_fs.h | 11 ++ > > fs/nfs/nfs4client.c | 2 +- > > fs/nfs/nfs4file.c | 125 ++++++++++++- > > fs/nfs/nfs4proc.c | 6 +- > > fs/nfs/nfs4state.c | 29 ++- > > fs/nfs/nfs4xdr.c | 1 + > > fs/nfsd/Kconfig | 10 ++ > > fs/nfsd/nfs4proc.c | 440 ++++++++++++++++++++++++++++++++++++++++++---- > > fs/nfsd/nfs4state.c | 215 +++++++++++++++++++--- > > fs/nfsd/nfs4xdr.c | 154 +++++++++++++++- > > fs/nfsd/nfsd.h | 32 ++++ > > fs/nfsd/nfsfh.h | 5 +- > > fs/nfsd/nfssvc.c | 6 + > > fs/nfsd/state.h | 34 +++- > > fs/nfsd/xdr4.h | 39 +++- > > include/linux/nfs4.h | 25 +++ > > include/linux/nfs_fs.h | 3 +- > > include/linux/nfs_fs_sb.h | 1 + > > include/linux/nfs_xdr.h | 17 ++ > > 22 files changed, 1431 insertions(+), 122 deletions(-) > > > > -- > > 1.8.3.1 > >