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, Josef Bacik <josef@toxicpanda.com>,
Jeff Layton <jlayton@kernel.org>
Subject: [PATCH 5.10.y 10/19] sunrpc: don't change ->sv_stats if it doesn't exist
Date: Thu, 5 Sep 2024 11:30:52 -0400 [thread overview]
Message-ID: <20240905153101.59927-11-cel@kernel.org> (raw)
In-Reply-To: <20240905153101.59927-1-cel@kernel.org>
From: Josef Bacik <josef@toxicpanda.com>
[ Upstream commit ab42f4d9a26f1723dcfd6c93fcf768032b2bb5e7 ]
We check for the existence of ->sv_stats elsewhere except in the core
processing code. It appears that only nfsd actual exports these values
anywhere, everybody else just has a write only copy of sv_stats in their
svc_program. Add a check for ->sv_stats before every adjustment to
allow us to eliminate the stats struct from all the users who don't
report the stats.
Signed-off-by: Josef Bacik <josef@toxicpanda.com>
Reviewed-by: Jeff Layton <jlayton@kernel.org>
[ cel: adjusted to apply to v5.10.y ]
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
---
net/sunrpc/svc.c | 24 ++++++++++++++++--------
1 file changed, 16 insertions(+), 8 deletions(-)
diff --git a/net/sunrpc/svc.c b/net/sunrpc/svc.c
index f8815ae776e6..8ee5fc21e1ce 100644
--- a/net/sunrpc/svc.c
+++ b/net/sunrpc/svc.c
@@ -1355,7 +1355,8 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
goto err_bad_proc;
/* Syntactic check complete */
- serv->sv_stats->rpccnt++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpccnt++;
trace_svc_process(rqstp, progp->pg_name);
/* Build the reply header. */
@@ -1421,7 +1422,8 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
goto close_xprt;
err_bad_rpc:
- serv->sv_stats->rpcbadfmt++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpcbadfmt++;
svc_putnl(resv, 1); /* REJECT */
svc_putnl(resv, 0); /* RPC_MISMATCH */
svc_putnl(resv, 2); /* Only RPCv2 supported */
@@ -1434,7 +1436,8 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
err_bad_auth:
dprintk("svc: authentication failed (%d)\n",
be32_to_cpu(rqstp->rq_auth_stat));
- serv->sv_stats->rpcbadauth++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpcbadauth++;
/* Restore write pointer to location of accept status: */
xdr_ressize_check(rqstp, reply_statp);
svc_putnl(resv, 1); /* REJECT */
@@ -1444,7 +1447,8 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
err_bad_prog:
dprintk("svc: unknown program %d\n", prog);
- serv->sv_stats->rpcbadfmt++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpcbadfmt++;
svc_putnl(resv, RPC_PROG_UNAVAIL);
goto sendit;
@@ -1452,7 +1456,8 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
svc_printk(rqstp, "unknown version (%d for prog %d, %s)\n",
rqstp->rq_vers, rqstp->rq_prog, progp->pg_name);
- serv->sv_stats->rpcbadfmt++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpcbadfmt++;
svc_putnl(resv, RPC_PROG_MISMATCH);
svc_putnl(resv, process.mismatch.lovers);
svc_putnl(resv, process.mismatch.hivers);
@@ -1461,7 +1466,8 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
err_bad_proc:
svc_printk(rqstp, "unknown procedure (%d)\n", rqstp->rq_proc);
- serv->sv_stats->rpcbadfmt++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpcbadfmt++;
svc_putnl(resv, RPC_PROC_UNAVAIL);
goto sendit;
@@ -1470,7 +1476,8 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
rpc_stat = rpc_garbage_args;
err_bad:
- serv->sv_stats->rpcbadfmt++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpcbadfmt++;
svc_putnl(resv, ntohl(rpc_stat));
goto sendit;
}
@@ -1505,7 +1512,8 @@ svc_process(struct svc_rqst *rqstp)
if (dir != 0) {
/* direction != CALL */
svc_printk(rqstp, "bad direction %d, dropping request\n", dir);
- serv->sv_stats->rpcbadfmt++;
+ if (serv->sv_stats)
+ serv->sv_stats->rpcbadfmt++;
goto out_drop;
}
--
2.45.1
next prev parent 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 ` [PATCH 5.10.y 01/19] nfsd: move reply cache initialization into nfsd startup cel
2024-09-08 13:03 ` 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 ` cel [this message]
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-11-cel@kernel.org \
--to=cel@kernel.org \
--cc=calum.mackay@oracle.com \
--cc=jlayton@kernel.org \
--cc=josef@toxicpanda.com \
--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).