]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
sunrpc: don't change ->sv_stats if it doesn't exist
authorJosef Bacik <josef@toxicpanda.com>
Thu, 5 Sep 2024 15:30:52 +0000 (11:30 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 12 Sep 2024 09:06:44 +0000 (11:06 +0200)
[ 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>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/sunrpc/svc.c

index f8815ae776e684ebc2e916de6b6fddaee21eca88..8ee5fc21e1cefbdaa069b8a737806e78c3eed634 100644 (file)
@@ -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 @@ err_short_len:
        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 @@ err_release_bad_auth:
 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 @@ err_bad_auth:
 
 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 @@ err_bad_vers:
        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 @@ err_bad_vers:
 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 @@ err_garbage:
 
        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;
        }