Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp778398ybb; Wed, 1 Apr 2020 09:26:52 -0700 (PDT) X-Google-Smtp-Source: APiQypJ9+kuZlYc21qIuUr+9jkqmiPWzPxq7mGJcQwk59IuEXAYme2FX3hfRc5mUidTZMa7b9dYU X-Received: by 2002:a05:6808:2d9:: with SMTP id a25mr3426457oid.125.1585758412382; Wed, 01 Apr 2020 09:26:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585758412; cv=none; d=google.com; s=arc-20160816; b=mbO5AIkm9my0HoY8wRkw9fzqljaSv8VL4uRk9XPnqqfsidE/Qh1DzKU6xhRteMqJDx 3Ys7EWUYup8/BMyWJH9txLIRRbSBC2euLHWgwWpss2lUxoDp7BF08jee75VKnbbRrnsR alNBpopDT8g35U3VdwXQEChQ5ofzfLbH60c6fIpr87q3Y3/5grpZDpQ+/5eGzz8T4rna WTwo2J/P8E1afLB+vHrdERqYYQXf6u0I81uGuCSGNPOB1xxotCbnTzWkJt+Koz0raUUd ruyaz7aUxRYkM1vwxgHaxcJndBE/DzhcJwptQnzLh2pk5k/cMRtSWobLGxXWn8zznL3p /vHQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=y+9slIkM+JHdCQwf9A/3e2vtkxImge3aWMn8/Sw20zw=; b=Vxio7zKZtlIonHNaClsUhOSTP0rjK3W7UCBsALfQyi95fXb/14zSRsLdVT9hNZ+HU6 lhZ0j1Xt92+lLwMell3Dnrv92+x1MKDDbe9PpTRCw9KAJVXtByQHOX6djNnwDsthL6BM DfcryZolgSdrtJvFfqDb9efczHumYFU5pEejHVKHqJvYGPGTWdqyv5Ekc9pe+UjEPm7y 9vyirqLQSNooUi4F68s8th3F64cUhifWF220qhJHuEmS+NfsJo3t4E23HQ1T7ej6BGoP raqW7ACdm0tA2LVCK4LD0MATSAZYYU5L99tXqN+dpJ8dixKjt0YR0IsrJeVTgNNWneLX lMuA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=LBkQb9l7; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-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 w8si898570otg.26.2020.04.01.09.26.39; Wed, 01 Apr 2020 09:26:52 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=LBkQb9l7; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732273AbgDAQYe (ORCPT + 99 others); Wed, 1 Apr 2020 12:24:34 -0400 Received: from mail.kernel.org ([198.145.29.99]:48062 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1733249AbgDAQYZ (ORCPT ); Wed, 1 Apr 2020 12:24:25 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 25E99212CC; Wed, 1 Apr 2020 16:24:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1585758264; bh=8gWxQB1hy2Rs45/USgNRR4m1Ti7GPXXLLt/ZXidVBr0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LBkQb9l7gRHySzXmdYrGh7/x2wp2mkVTR5EH8mrGUQZpjBguWSBNGzBDic9kbfV+y FpZed7AyUayEqvz0uOWws+gkk+mr24f+QVySS904+JDlJ/pD4UwpHjV6HQYDm9YUJc y4jbaU0Bw95w8La64wWbF0cAYNfMLmoXo6eRPnEs= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Scott Mayhew , Dave Wysochanski , Anna Schumaker , Sasha Levin Subject: [PATCH 4.19 034/116] nfs: add minor version to nfs_server_key for fscache Date: Wed, 1 Apr 2020 18:16:50 +0200 Message-Id: <20200401161546.788908370@linuxfoundation.org> X-Mailer: git-send-email 2.26.0 In-Reply-To: <20200401161542.669484650@linuxfoundation.org> References: <20200401161542.669484650@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Scott Mayhew [ Upstream commit 55dee1bc0d72877b99805e42e0205087e98b9edd ] An NFS client that mounts multiple exports from the same NFS server with higher NFSv4 versions disabled (i.e. 4.2) and without forcing a specific NFS version results in fscache index cookie collisions and the following messages: [ 570.004348] FS-Cache: Duplicate cookie detected Each nfs_client structure should have its own fscache index cookie, so add the minorversion to nfs_server_key. Link: https://bugzilla.kernel.org/show_bug.cgi?id=200145 Signed-off-by: Scott Mayhew Signed-off-by: Dave Wysochanski Signed-off-by: Anna Schumaker Signed-off-by: Sasha Levin --- fs/nfs/client.c | 1 + fs/nfs/fscache.c | 2 ++ fs/nfs/nfs4client.c | 1 - 3 files changed, 3 insertions(+), 1 deletion(-) diff --git a/fs/nfs/client.c b/fs/nfs/client.c index 0a2b59c1ecb3d..07c5ddd5d6d50 100644 --- a/fs/nfs/client.c +++ b/fs/nfs/client.c @@ -157,6 +157,7 @@ struct nfs_client *nfs_alloc_client(const struct nfs_client_initdata *cl_init) if ((clp = kzalloc(sizeof(*clp), GFP_KERNEL)) == NULL) goto error_0; + clp->cl_minorversion = cl_init->minorversion; clp->cl_nfs_mod = cl_init->nfs_mod; if (!try_module_get(clp->cl_nfs_mod->owner)) goto error_dealloc; diff --git a/fs/nfs/fscache.c b/fs/nfs/fscache.c index a7bc4e0494f92..6f45b1a957397 100644 --- a/fs/nfs/fscache.c +++ b/fs/nfs/fscache.c @@ -35,6 +35,7 @@ static DEFINE_SPINLOCK(nfs_fscache_keys_lock); struct nfs_server_key { struct { uint16_t nfsversion; /* NFS protocol version */ + uint32_t minorversion; /* NFSv4 minor version */ uint16_t family; /* address family */ __be16 port; /* IP port */ } hdr; @@ -59,6 +60,7 @@ void nfs_fscache_get_client_cookie(struct nfs_client *clp) memset(&key, 0, sizeof(key)); key.hdr.nfsversion = clp->rpc_ops->version; + key.hdr.minorversion = clp->cl_minorversion; key.hdr.family = clp->cl_addr.ss_family; switch (clp->cl_addr.ss_family) { diff --git a/fs/nfs/nfs4client.c b/fs/nfs/nfs4client.c index 86991bcfbeb12..faaabbedc891d 100644 --- a/fs/nfs/nfs4client.c +++ b/fs/nfs/nfs4client.c @@ -210,7 +210,6 @@ struct nfs_client *nfs4_alloc_client(const struct nfs_client_initdata *cl_init) INIT_LIST_HEAD(&clp->cl_ds_clients); rpc_init_wait_queue(&clp->cl_rpcwaitq, "NFS client"); clp->cl_state = 1 << NFS4CLNT_LEASE_EXPIRED; - clp->cl_minorversion = cl_init->minorversion; clp->cl_mvops = nfs_v4_minor_ops[cl_init->minorversion]; clp->cl_mig_gen = 1; #if IS_ENABLED(CONFIG_NFS_V4_1) -- 2.20.1