stable.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: cel@kernel.org
To: <stable@vger.kernel.org>
Cc: <linux-nfs@vger.kernel.org>, Petr Vorel <pvorel@suse.cz>,
	sherry.yang@oracle.com, calum.mackay@oracle.com,
	kernel-team@fb.com, Jeff Layton <jlayton@kernel.org>,
	Dai Ngo <dai.ngo@oracle.com>
Subject: [PATCH 5.10.y 01/19] nfsd: move reply cache initialization into nfsd startup
Date: Thu,  5 Sep 2024 11:30:43 -0400	[thread overview]
Message-ID: <20240905153101.59927-2-cel@kernel.org> (raw)
In-Reply-To: <20240905153101.59927-1-cel@kernel.org>

From: Jeff Layton <jlayton@kernel.org>

[ Upstream commit f5f9d4a314da88c0a5faa6d168bf69081b7a25ae ]

There's no need to start the reply cache before nfsd is up and running,
and doing so means that we register a shrinker for every net namespace
instead of just the ones where nfsd is running.

Move it to the per-net nfsd startup instead.

Reported-by: Dai Ngo <dai.ngo@oracle.com>
Signed-off-by: Jeff Layton <jlayton@kernel.org>
Stable-dep-of: ed9ab7346e90 ("nfsd: move init of percpu reply_cache_stats counters back to nfsd_init_net")
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
---
 fs/nfsd/nfsctl.c |  8 --------
 fs/nfsd/nfssvc.c | 10 +++++++++-
 2 files changed, 9 insertions(+), 9 deletions(-)

diff --git a/fs/nfsd/nfsctl.c b/fs/nfsd/nfsctl.c
index f77f00c93172..1c39a4e6294d 100644
--- a/fs/nfsd/nfsctl.c
+++ b/fs/nfsd/nfsctl.c
@@ -1461,16 +1461,11 @@ static __net_init int nfsd_init_net(struct net *net)
 	nn->nfsd_versions = NULL;
 	nn->nfsd4_minorversions = NULL;
 	nfsd4_init_leases_net(nn);
-	retval = nfsd_reply_cache_init(nn);
-	if (retval)
-		goto out_cache_error;
 	get_random_bytes(&nn->siphash_key, sizeof(nn->siphash_key));
 	seqlock_init(&nn->writeverf_lock);
 
 	return 0;
 
-out_cache_error:
-	nfsd_idmap_shutdown(net);
 out_idmap_error:
 	nfsd_export_shutdown(net);
 out_export_error:
@@ -1479,9 +1474,6 @@ static __net_init int nfsd_init_net(struct net *net)
 
 static __net_exit void nfsd_exit_net(struct net *net)
 {
-	struct nfsd_net *nn = net_generic(net, nfsd_net_id);
-
-	nfsd_reply_cache_shutdown(nn);
 	nfsd_idmap_shutdown(net);
 	nfsd_export_shutdown(net);
 	nfsd_netns_free_versions(net_generic(net, nfsd_net_id));
diff --git a/fs/nfsd/nfssvc.c b/fs/nfsd/nfssvc.c
index 3d4fd40c987b..a68e9904224a 100644
--- a/fs/nfsd/nfssvc.c
+++ b/fs/nfsd/nfssvc.c
@@ -427,16 +427,23 @@ static int nfsd_startup_net(struct net *net, const struct cred *cred)
 	ret = nfsd_file_cache_start_net(net);
 	if (ret)
 		goto out_lockd;
-	ret = nfs4_state_start_net(net);
+
+	ret = nfsd_reply_cache_init(nn);
 	if (ret)
 		goto out_filecache;
 
+	ret = nfs4_state_start_net(net);
+	if (ret)
+		goto out_reply_cache;
+
 #ifdef CONFIG_NFSD_V4_2_INTER_SSC
 	nfsd4_ssc_init_umount_work(nn);
 #endif
 	nn->nfsd_net_up = true;
 	return 0;
 
+out_reply_cache:
+	nfsd_reply_cache_shutdown(nn);
 out_filecache:
 	nfsd_file_cache_shutdown_net(net);
 out_lockd:
@@ -454,6 +461,7 @@ static void nfsd_shutdown_net(struct net *net)
 	struct nfsd_net *nn = net_generic(net, nfsd_net_id);
 
 	nfs4_state_shutdown_net(net);
+	nfsd_reply_cache_shutdown(nn);
 	nfsd_file_cache_shutdown_net(net);
 	if (nn->lockd_up) {
 		lockd_down(net);
-- 
2.45.1


  reply	other threads:[~2024-09-05 15:31 UTC|newest]

Thread overview: 21+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-09-05 15:30 [PATCH 5.10.y 00/19] Backport "make svc_stat per-net instead of global" cel
2024-09-05 15:30 ` cel [this message]
2024-09-08 13:03   ` [PATCH 5.10.y 01/19] nfsd: move reply cache initialization into nfsd startup Greg KH
2024-09-05 15:30 ` [PATCH 5.10.y 02/19] nfsd: move init of percpu reply_cache_stats counters back to nfsd_init_net cel
2024-09-05 15:30 ` [PATCH 5.10.y 03/19] NFSD: Refactor nfsd_reply_cache_free_locked() cel
2024-09-05 15:30 ` [PATCH 5.10.y 04/19] NFSD: Rename nfsd_reply_cache_alloc() cel
2024-09-05 15:30 ` [PATCH 5.10.y 05/19] NFSD: Replace nfsd_prune_bucket() cel
2024-09-05 15:30 ` [PATCH 5.10.y 06/19] NFSD: Refactor the duplicate reply cache shrinker cel
2024-09-05 15:30 ` [PATCH 5.10.y 07/19] NFSD: simplify error paths in nfsd_svc() cel
2024-09-05 15:30 ` [PATCH 5.10.y 08/19] NFSD: Rewrite synopsis of nfsd_percpu_counters_init() cel
2024-09-05 15:30 ` [PATCH 5.10.y 09/19] NFSD: Fix frame size warning in svc_export_parse() cel
2024-09-05 15:30 ` [PATCH 5.10.y 10/19] sunrpc: don't change ->sv_stats if it doesn't exist cel
2024-09-05 15:30 ` [PATCH 5.10.y 11/19] nfsd: stop setting ->pg_stats for unused stats cel
2024-09-05 15:30 ` [PATCH 5.10.y 12/19] sunrpc: pass in the sv_stats struct through svc_create_pooled cel
2024-09-05 15:30 ` [PATCH 5.10.y 13/19] sunrpc: remove ->pg_stats from svc_program cel
2024-09-05 15:30 ` [PATCH 5.10.y 14/19] sunrpc: use the struct net as the svc proc private cel
2024-09-05 15:30 ` [PATCH 5.10.y 15/19] nfsd: rename NFSD_NET_* to NFSD_STATS_* cel
2024-09-05 15:30 ` [PATCH 5.10.y 16/19] nfsd: expose /proc/net/sunrpc/nfsd in net namespaces cel
2024-09-05 15:30 ` [PATCH 5.10.y 17/19] nfsd: make all of the nfsd stats per-network namespace cel
2024-09-05 15:31 ` [PATCH 5.10.y 18/19] nfsd: remove nfsd_stats, make th_cnt a global counter cel
2024-09-05 15:31 ` [PATCH 5.10.y 19/19] nfsd: make svc_stat per-network namespace instead of global cel

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=20240905153101.59927-2-cel@kernel.org \
    --to=cel@kernel.org \
    --cc=calum.mackay@oracle.com \
    --cc=dai.ngo@oracle.com \
    --cc=jlayton@kernel.org \
    --cc=kernel-team@fb.com \
    --cc=linux-nfs@vger.kernel.org \
    --cc=pvorel@suse.cz \
    --cc=sherry.yang@oracle.com \
    --cc=stable@vger.kernel.org \
    /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).