NFSD: Use sockaddr instead of a generic array
authorChuck Lever <chuck.lever@oracle.com>
Sat, 3 May 2025 19:59:19 +0000 (15:59 -0400)
committerChuck Lever <chuck.lever@oracle.com>
Sun, 11 May 2025 23:48:29 +0000 (19:48 -0400)
Record and emit presentation addresses using tracing helpers
designed for the task.

Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
fs/nfsd/trace.h

index 0d49fc064f7273f32c93732a993fd77bc0783f5d..f67ab3d1b5063880706e1075150dd7f94319fcba 100644 (file)
 #include "nfsfh.h"
 #include "xdr4.h"
 
-#define NFSD_TRACE_PROC_RES_FIELDS \
+#define NFSD_TRACE_PROC_RES_FIELDS(r) \
                __field(unsigned int, netns_ino) \
                __field(u32, xid) \
                __field(unsigned long, status) \
-               __array(unsigned char, server, sizeof(struct sockaddr_in6)) \
-               __array(unsigned char, client, sizeof(struct sockaddr_in6))
+               __sockaddr(server, (r)->rq_xprt->xpt_locallen) \
+               __sockaddr(client, (r)->rq_xprt->xpt_remotelen)
 
-#define NFSD_TRACE_PROC_RES_ASSIGNMENTS(error) \
+#define NFSD_TRACE_PROC_RES_ASSIGNMENTS(r, error) \
                do { \
-                       __entry->netns_ino = SVC_NET(rqstp)->ns.inum; \
-                       __entry->xid = be32_to_cpu(rqstp->rq_xid); \
+                       struct svc_xprt *xprt = (r)->rq_xprt; \
+                       __entry->netns_ino = SVC_NET(r)->ns.inum; \
+                       __entry->xid = be32_to_cpu((r)->rq_xid); \
                        __entry->status = be32_to_cpu(error); \
-                       memcpy(__entry->server, &rqstp->rq_xprt->xpt_local, \
-                              rqstp->rq_xprt->xpt_locallen); \
-                       memcpy(__entry->client, &rqstp->rq_xprt->xpt_remote, \
-                              rqstp->rq_xprt->xpt_remotelen); \
+                       __assign_sockaddr(server, &xprt->xpt_local, \
+                                         xprt->xpt_locallen); \
+                       __assign_sockaddr(client, &xprt->xpt_remote, \
+                                         xprt->xpt_remotelen); \
                } while (0);
 
 DECLARE_EVENT_CLASS(nfsd_xdr_err_class,
@@ -145,14 +146,14 @@ TRACE_EVENT(nfsd_compound_decode_err,
        ),
        TP_ARGS(rqstp, args_opcnt, resp_opcnt, opnum, status),
        TP_STRUCT__entry(
-               NFSD_TRACE_PROC_RES_FIELDS
+               NFSD_TRACE_PROC_RES_FIELDS(rqstp)
 
                __field(u32, args_opcnt)
                __field(u32, resp_opcnt)
                __field(u32, opnum)
        ),
        TP_fast_assign(
-               NFSD_TRACE_PROC_RES_ASSIGNMENTS(status)
+               NFSD_TRACE_PROC_RES_ASSIGNMENTS(rqstp, status)
 
                __entry->args_opcnt = args_opcnt;
                __entry->resp_opcnt = resp_opcnt;
@@ -171,12 +172,12 @@ DECLARE_EVENT_CLASS(nfsd_compound_err_class,
        ),
        TP_ARGS(rqstp, opnum, status),
        TP_STRUCT__entry(
-               NFSD_TRACE_PROC_RES_FIELDS
+               NFSD_TRACE_PROC_RES_FIELDS(rqstp)
 
                __field(u32, opnum)
        ),
        TP_fast_assign(
-               NFSD_TRACE_PROC_RES_ASSIGNMENTS(status)
+               NFSD_TRACE_PROC_RES_ASSIGNMENTS(rqstp, status)
 
                __entry->opnum = opnum;
        ),