sunrpc: Re-purpose trace_svc_process
Currently, trace_svc_process has two call sites: 1. Just after a call to svc_send. svc_send already invokes trace_svc_send with the same arguments just before returning 2. Just before a call to svc_drop. svc_drop already invokes trace_svc_drop with the same arguments just after it is called Therefore trace_svc_process does not provide any additional information not already provided by these other trace points. However, it would be useful to record the incoming RPC procedure. So reuse trace_svc_process for this purpose. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: J. Bruce Fields <bfields@redhat.com>
This commit is contained in:
parent
ece200ddd5
commit
0b9547bf6b
|
@ -508,6 +508,32 @@ TRACE_EVENT(svc_recv,
|
||||||
show_rqstp_flags(__entry->flags))
|
show_rqstp_flags(__entry->flags))
|
||||||
);
|
);
|
||||||
|
|
||||||
|
TRACE_EVENT(svc_process,
|
||||||
|
TP_PROTO(const struct svc_rqst *rqst, const char *name),
|
||||||
|
|
||||||
|
TP_ARGS(rqst, name),
|
||||||
|
|
||||||
|
TP_STRUCT__entry(
|
||||||
|
__field(u32, xid)
|
||||||
|
__field(u32, vers)
|
||||||
|
__field(u32, proc)
|
||||||
|
__string(service, name)
|
||||||
|
__string(addr, rqst->rq_xprt->xpt_remotebuf)
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_fast_assign(
|
||||||
|
__entry->xid = be32_to_cpu(rqst->rq_xid);
|
||||||
|
__entry->vers = rqst->rq_vers;
|
||||||
|
__entry->proc = rqst->rq_proc;
|
||||||
|
__assign_str(service, name);
|
||||||
|
__assign_str(addr, rqst->rq_xprt->xpt_remotebuf);
|
||||||
|
),
|
||||||
|
|
||||||
|
TP_printk("addr=%s xid=0x%08x service=%s vers=%u proc=%u",
|
||||||
|
__get_str(addr), __entry->xid,
|
||||||
|
__get_str(service), __entry->vers, __entry->proc)
|
||||||
|
);
|
||||||
|
|
||||||
DECLARE_EVENT_CLASS(svc_rqst_event,
|
DECLARE_EVENT_CLASS(svc_rqst_event,
|
||||||
|
|
||||||
TP_PROTO(struct svc_rqst *rqst),
|
TP_PROTO(struct svc_rqst *rqst),
|
||||||
|
@ -564,10 +590,6 @@ DECLARE_EVENT_CLASS(svc_rqst_status,
|
||||||
__entry->status, show_rqstp_flags(__entry->flags))
|
__entry->status, show_rqstp_flags(__entry->flags))
|
||||||
);
|
);
|
||||||
|
|
||||||
DEFINE_EVENT(svc_rqst_status, svc_process,
|
|
||||||
TP_PROTO(struct svc_rqst *rqst, int status),
|
|
||||||
TP_ARGS(rqst, status));
|
|
||||||
|
|
||||||
DEFINE_EVENT(svc_rqst_status, svc_send,
|
DEFINE_EVENT(svc_rqst_status, svc_send,
|
||||||
TP_PROTO(struct svc_rqst *rqst, int status),
|
TP_PROTO(struct svc_rqst *rqst, int status),
|
||||||
TP_ARGS(rqst, status));
|
TP_ARGS(rqst, status));
|
||||||
|
|
|
@ -1255,6 +1255,7 @@ svc_process_common(struct svc_rqst *rqstp, struct kvec *argv, struct kvec *resv)
|
||||||
|
|
||||||
/* Syntactic check complete */
|
/* Syntactic check complete */
|
||||||
serv->sv_stats->rpccnt++;
|
serv->sv_stats->rpccnt++;
|
||||||
|
trace_svc_process(rqstp, progp->pg_name);
|
||||||
|
|
||||||
/* Build the reply header. */
|
/* Build the reply header. */
|
||||||
statp = resv->iov_base +resv->iov_len;
|
statp = resv->iov_base +resv->iov_len;
|
||||||
|
@ -1431,14 +1432,10 @@ svc_process(struct svc_rqst *rqstp)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Returns 1 for send, 0 for drop */
|
/* Returns 1 for send, 0 for drop */
|
||||||
if (likely(svc_process_common(rqstp, argv, resv))) {
|
if (likely(svc_process_common(rqstp, argv, resv)))
|
||||||
int ret = svc_send(rqstp);
|
return svc_send(rqstp);
|
||||||
|
|
||||||
trace_svc_process(rqstp, ret);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
out_drop:
|
out_drop:
|
||||||
trace_svc_process(rqstp, 0);
|
|
||||||
svc_drop(rqstp);
|
svc_drop(rqstp);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue