[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <020629ee-99c0-45f2-8334-80d4cd6a5da6@oracle.com>
Date: Wed, 22 Jan 2025 10:09:46 -0500
From: Chuck Lever <chuck.lever@...cle.com>
To: Jeff Layton <jlayton@...nel.org>, Neil Brown <neilb@...e.de>,
Olga Kornievskaia <okorniev@...hat.com>, Dai Ngo <Dai.Ngo@...cle.com>,
Tom Talpey <tom@...pey.com>, Trond Myklebust <trondmy@...nel.org>,
Anna Schumaker <anna@...nel.org>,
"David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>, Jakub Kicinski <kuba@...nel.org>,
Paolo Abeni <pabeni@...hat.com>, Simon Horman <horms@...nel.org>
Cc: linux-nfs@...r.kernel.org, netdev@...r.kernel.org,
linux-kernel@...r.kernel.org
Subject: Re: [PATCH] sunrpc: add netns inum and srcaddr to debugfs rpc_xprt
info
On 1/22/25 9:59 AM, Jeff Layton wrote:
> The output format should provide a value that matches the one in
> the /proc/<pid>/ns/net symlink. This makes it simpler to match the
> rpc_xprt and rpc_clnt to a particular container.
>
> Also, when the xprt defines the get_srcaddr operation, use that to
> display the source address as well.
>
> Signed-off-by: Jeff Layton <jlayton@...nel.org>
> ---
> This is more client-side code, so I figure this should go in via the NFS
> client tree, but if Chuck would rather pick it up, then that's fine too.
Hi Jeff -
The change seems sensible to me, and it would be better for Anna or
Trond to handle it IMO.
> ---
> net/sunrpc/debugfs.c | 16 ++++++++++++++++
> 1 file changed, 16 insertions(+)
>
> diff --git a/net/sunrpc/debugfs.c b/net/sunrpc/debugfs.c
> index a176d5a0b0ee9a2c0ca1d1ed3131b67b782c3296..3b39493234d7079ff762a862bdd51725f36472dc 100644
> --- a/net/sunrpc/debugfs.c
> +++ b/net/sunrpc/debugfs.c
> @@ -179,6 +179,22 @@ xprt_info_show(struct seq_file *f, void *v)
> seq_printf(f, "addr: %s\n", xprt->address_strings[RPC_DISPLAY_ADDR]);
> seq_printf(f, "port: %s\n", xprt->address_strings[RPC_DISPLAY_PORT]);
> seq_printf(f, "state: 0x%lx\n", xprt->state);
> + seq_printf(f, "netns: %u\n", xprt->xprt_net->ns.inum);
IIRC, net->ns.inum is also what the trace points use for this purpose.
> +
> + if (xprt->ops->get_srcaddr) {
> + int ret, buflen;
> + char buf[INET6_ADDRSTRLEN];
> +
> + buflen = ARRAY_SIZE(buf);
> + ret = xprt->ops->get_srcaddr(xprt, buf, buflen);
> + if (ret > 0) {
> + if (ret < buflen - 1)
> + buf[ret] = '\0';
> + } else {
> + ret = sprintf(buf, "<closed>");
> + }
> + seq_printf(f, "saddr: %s\n", buf);
> + }
> return 0;
> }
>
>
> ---
> base-commit: ffd294d346d185b70e28b1a28abe367bbfe53c04
> change-id: 20250122-nfs-6-14-7f737deb6356
>
> Best regards,
--
Chuck Lever
Powered by blists - more mailing lists