Commit ab42f4d9 authored by Josef Bacik's avatar Josef Bacik Committed by Chuck Lever

sunrpc: don't change ->sv_stats if it doesn't exist

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: default avatarJosef Bacik <josef@toxicpanda.com>
Reviewed-by: default avatarJeff Layton <jlayton@kernel.org>
Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
parent 31e4bb8f
...@@ -1375,7 +1375,8 @@ svc_process_common(struct svc_rqst *rqstp) ...@@ -1375,7 +1375,8 @@ svc_process_common(struct svc_rqst *rqstp)
goto err_bad_proc; goto err_bad_proc;
/* Syntactic check complete */ /* Syntactic check complete */
serv->sv_stats->rpccnt++; if (serv->sv_stats)
serv->sv_stats->rpccnt++;
trace_svc_process(rqstp, progp->pg_name); trace_svc_process(rqstp, progp->pg_name);
aoffset = xdr_stream_pos(xdr); aoffset = xdr_stream_pos(xdr);
...@@ -1427,7 +1428,8 @@ svc_process_common(struct svc_rqst *rqstp) ...@@ -1427,7 +1428,8 @@ svc_process_common(struct svc_rqst *rqstp)
goto close_xprt; goto close_xprt;
err_bad_rpc: err_bad_rpc:
serv->sv_stats->rpcbadfmt++; if (serv->sv_stats)
serv->sv_stats->rpcbadfmt++;
xdr_stream_encode_u32(xdr, RPC_MSG_DENIED); xdr_stream_encode_u32(xdr, RPC_MSG_DENIED);
xdr_stream_encode_u32(xdr, RPC_MISMATCH); xdr_stream_encode_u32(xdr, RPC_MISMATCH);
/* Only RPCv2 supported */ /* Only RPCv2 supported */
...@@ -1438,7 +1440,8 @@ svc_process_common(struct svc_rqst *rqstp) ...@@ -1438,7 +1440,8 @@ svc_process_common(struct svc_rqst *rqstp)
err_bad_auth: err_bad_auth:
dprintk("svc: authentication failed (%d)\n", dprintk("svc: authentication failed (%d)\n",
be32_to_cpu(rqstp->rq_auth_stat)); 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 reply status: */ /* Restore write pointer to location of reply status: */
xdr_truncate_encode(xdr, XDR_UNIT * 2); xdr_truncate_encode(xdr, XDR_UNIT * 2);
xdr_stream_encode_u32(xdr, RPC_MSG_DENIED); xdr_stream_encode_u32(xdr, RPC_MSG_DENIED);
...@@ -1448,7 +1451,8 @@ svc_process_common(struct svc_rqst *rqstp) ...@@ -1448,7 +1451,8 @@ svc_process_common(struct svc_rqst *rqstp)
err_bad_prog: err_bad_prog:
dprintk("svc: unknown program %d\n", rqstp->rq_prog); dprintk("svc: unknown program %d\n", rqstp->rq_prog);
serv->sv_stats->rpcbadfmt++; if (serv->sv_stats)
serv->sv_stats->rpcbadfmt++;
*rqstp->rq_accept_statp = rpc_prog_unavail; *rqstp->rq_accept_statp = rpc_prog_unavail;
goto sendit; goto sendit;
...@@ -1456,7 +1460,8 @@ svc_process_common(struct svc_rqst *rqstp) ...@@ -1456,7 +1460,8 @@ svc_process_common(struct svc_rqst *rqstp)
svc_printk(rqstp, "unknown version (%d for prog %d, %s)\n", svc_printk(rqstp, "unknown version (%d for prog %d, %s)\n",
rqstp->rq_vers, rqstp->rq_prog, progp->pg_name); rqstp->rq_vers, rqstp->rq_prog, progp->pg_name);
serv->sv_stats->rpcbadfmt++; if (serv->sv_stats)
serv->sv_stats->rpcbadfmt++;
*rqstp->rq_accept_statp = rpc_prog_mismatch; *rqstp->rq_accept_statp = rpc_prog_mismatch;
/* /*
...@@ -1470,19 +1475,22 @@ svc_process_common(struct svc_rqst *rqstp) ...@@ -1470,19 +1475,22 @@ svc_process_common(struct svc_rqst *rqstp)
err_bad_proc: err_bad_proc:
svc_printk(rqstp, "unknown procedure (%d)\n", rqstp->rq_proc); svc_printk(rqstp, "unknown procedure (%d)\n", rqstp->rq_proc);
serv->sv_stats->rpcbadfmt++; if (serv->sv_stats)
serv->sv_stats->rpcbadfmt++;
*rqstp->rq_accept_statp = rpc_proc_unavail; *rqstp->rq_accept_statp = rpc_proc_unavail;
goto sendit; goto sendit;
err_garbage_args: err_garbage_args:
svc_printk(rqstp, "failed to decode RPC header\n"); svc_printk(rqstp, "failed to decode RPC header\n");
serv->sv_stats->rpcbadfmt++; if (serv->sv_stats)
serv->sv_stats->rpcbadfmt++;
*rqstp->rq_accept_statp = rpc_garbage_args; *rqstp->rq_accept_statp = rpc_garbage_args;
goto sendit; goto sendit;
err_system_err: err_system_err:
serv->sv_stats->rpcbadfmt++; if (serv->sv_stats)
serv->sv_stats->rpcbadfmt++;
*rqstp->rq_accept_statp = rpc_system_err; *rqstp->rq_accept_statp = rpc_system_err;
goto sendit; goto sendit;
} }
...@@ -1534,7 +1542,8 @@ void svc_process(struct svc_rqst *rqstp) ...@@ -1534,7 +1542,8 @@ void svc_process(struct svc_rqst *rqstp)
out_baddir: out_baddir:
svc_printk(rqstp, "bad direction 0x%08x, dropping request\n", svc_printk(rqstp, "bad direction 0x%08x, dropping request\n",
be32_to_cpu(*p)); be32_to_cpu(*p));
rqstp->rq_server->sv_stats->rpcbadfmt++; if (rqstp->rq_server->sv_stats)
rqstp->rq_server->sv_stats->rpcbadfmt++;
out_drop: out_drop:
svc_drop(rqstp); svc_drop(rqstp);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment