SUNRPC: Fix a NULL pointer deref in trace_svc_stats_latency()
[ Upstream commit 5c11720767f70d34357d00a15ba5a0ad052c40fe ] Some paths through svc_process() leave rqst->rq_procinfo set to NULL, which triggers a crash if tracing happens to be enabled. Fixes: 89ff87494c6e ("SUNRPC: Display RPC procedure names instead of proc numbers") Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
3de81c1e84
commit
be20af2458
@@ -498,6 +498,7 @@ void svc_wake_up(struct svc_serv *);
|
|||||||
void svc_reserve(struct svc_rqst *rqstp, int space);
|
void svc_reserve(struct svc_rqst *rqstp, int space);
|
||||||
struct svc_pool * svc_pool_for_cpu(struct svc_serv *serv, int cpu);
|
struct svc_pool * svc_pool_for_cpu(struct svc_serv *serv, int cpu);
|
||||||
char * svc_print_addr(struct svc_rqst *, char *, size_t);
|
char * svc_print_addr(struct svc_rqst *, char *, size_t);
|
||||||
|
const char * svc_proc_name(const struct svc_rqst *rqstp);
|
||||||
int svc_encode_result_payload(struct svc_rqst *rqstp,
|
int svc_encode_result_payload(struct svc_rqst *rqstp,
|
||||||
unsigned int offset,
|
unsigned int offset,
|
||||||
unsigned int length);
|
unsigned int length);
|
||||||
|
@@ -1578,7 +1578,7 @@ TRACE_EVENT(svc_process,
|
|||||||
__field(u32, vers)
|
__field(u32, vers)
|
||||||
__field(u32, proc)
|
__field(u32, proc)
|
||||||
__string(service, name)
|
__string(service, name)
|
||||||
__string(procedure, rqst->rq_procinfo->pc_name)
|
__string(procedure, svc_proc_name(rqst))
|
||||||
__string(addr, rqst->rq_xprt ?
|
__string(addr, rqst->rq_xprt ?
|
||||||
rqst->rq_xprt->xpt_remotebuf : "(null)")
|
rqst->rq_xprt->xpt_remotebuf : "(null)")
|
||||||
),
|
),
|
||||||
@@ -1588,7 +1588,7 @@ TRACE_EVENT(svc_process,
|
|||||||
__entry->vers = rqst->rq_vers;
|
__entry->vers = rqst->rq_vers;
|
||||||
__entry->proc = rqst->rq_proc;
|
__entry->proc = rqst->rq_proc;
|
||||||
__assign_str(service, name);
|
__assign_str(service, name);
|
||||||
__assign_str(procedure, rqst->rq_procinfo->pc_name);
|
__assign_str(procedure, svc_proc_name(rqst));
|
||||||
__assign_str(addr, rqst->rq_xprt ?
|
__assign_str(addr, rqst->rq_xprt ?
|
||||||
rqst->rq_xprt->xpt_remotebuf : "(null)");
|
rqst->rq_xprt->xpt_remotebuf : "(null)");
|
||||||
),
|
),
|
||||||
@@ -1854,7 +1854,7 @@ TRACE_EVENT(svc_stats_latency,
|
|||||||
TP_STRUCT__entry(
|
TP_STRUCT__entry(
|
||||||
__field(u32, xid)
|
__field(u32, xid)
|
||||||
__field(unsigned long, execute)
|
__field(unsigned long, execute)
|
||||||
__string(procedure, rqst->rq_procinfo->pc_name)
|
__string(procedure, svc_proc_name(rqst))
|
||||||
__string(addr, rqst->rq_xprt->xpt_remotebuf)
|
__string(addr, rqst->rq_xprt->xpt_remotebuf)
|
||||||
),
|
),
|
||||||
|
|
||||||
@@ -1862,7 +1862,7 @@ TRACE_EVENT(svc_stats_latency,
|
|||||||
__entry->xid = be32_to_cpu(rqst->rq_xid);
|
__entry->xid = be32_to_cpu(rqst->rq_xid);
|
||||||
__entry->execute = ktime_to_us(ktime_sub(ktime_get(),
|
__entry->execute = ktime_to_us(ktime_sub(ktime_get(),
|
||||||
rqst->rq_stime));
|
rqst->rq_stime));
|
||||||
__assign_str(procedure, rqst->rq_procinfo->pc_name);
|
__assign_str(procedure, svc_proc_name(rqst));
|
||||||
__assign_str(addr, rqst->rq_xprt->xpt_remotebuf);
|
__assign_str(addr, rqst->rq_xprt->xpt_remotebuf);
|
||||||
),
|
),
|
||||||
|
|
||||||
|
@@ -1612,6 +1612,21 @@ u32 svc_max_payload(const struct svc_rqst *rqstp)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(svc_max_payload);
|
EXPORT_SYMBOL_GPL(svc_max_payload);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* svc_proc_name - Return RPC procedure name in string form
|
||||||
|
* @rqstp: svc_rqst to operate on
|
||||||
|
*
|
||||||
|
* Return value:
|
||||||
|
* Pointer to a NUL-terminated string
|
||||||
|
*/
|
||||||
|
const char *svc_proc_name(const struct svc_rqst *rqstp)
|
||||||
|
{
|
||||||
|
if (rqstp && rqstp->rq_procinfo)
|
||||||
|
return rqstp->rq_procinfo->pc_name;
|
||||||
|
return "unknown";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* svc_encode_result_payload - mark a range of bytes as a result payload
|
* svc_encode_result_payload - mark a range of bytes as a result payload
|
||||||
* @rqstp: svc_rqst to operate on
|
* @rqstp: svc_rqst to operate on
|
||||||
|
Reference in New Issue
Block a user