From: Paulo Alcantara <pc@manguebit.com>
To: nspmangalore@gmail.com, smfrench@gmail.com,
bharathsm.hsk@gmail.com, linux-cifs@vger.kernel.org
Cc: Shyam Prasad N <sprasad@microsoft.com>
Subject: Re: [PATCH 13/14] cifs: display the endpoint IP details in DebugData
Date: Tue, 31 Oct 2023 12:18:14 -0300 [thread overview]
Message-ID: <364e6840dba943b3d23e5b50b793550d.pc@manguebit.com> (raw)
In-Reply-To: <20231030110020.45627-13-sprasad@microsoft.com>
nspmangalore@gmail.com writes:
> From: Shyam Prasad N <sprasad@microsoft.com>
>
> With multichannel, it is useful to know the src port details
> for each channel. This change will print the ip addr and
> port details for both the socket dest and src endpoints.
>
> Signed-off-by: Shyam Prasad N <sprasad@microsoft.com>
> ---
> fs/smb/client/cifs_debug.c | 73 ++++++++++++++++++++++++++++++++++++--
> 1 file changed, 71 insertions(+), 2 deletions(-)
>
> diff --git a/fs/smb/client/cifs_debug.c b/fs/smb/client/cifs_debug.c
> index e23fcabb78d6..d8362e098310 100644
> --- a/fs/smb/client/cifs_debug.c
> +++ b/fs/smb/client/cifs_debug.c
> @@ -13,6 +13,7 @@
> #include <linux/proc_fs.h>
> #include <linux/uaccess.h>
> #include <uapi/linux/ethtool.h>
> +#include <net/inet_sock.h>
> #include "cifspdu.h"
> #include "cifsglob.h"
> #include "cifsproto.h"
> @@ -158,11 +159,37 @@ cifs_dump_channel(struct seq_file *m, int i, struct cifs_chan *chan)
> in_flight(server),
> atomic_read(&server->in_send),
> atomic_read(&server->num_waiters));
> +
> #ifdef CONFIG_NET_NS
> if (server->net)
> seq_printf(m, " Net namespace: %u ", server->net->ns.inum);
> #endif /* NET_NS */
>
> +#ifdef CONFIG_CIFS_SMB_DIRECT
No need to check for CONFIG_CIFS_SMB_DIRECT as @server->{rdma,smbd_conn}
are always defined.
> + if (!server->rdma)
cifs_rdma_enabled()? To be consistent with other places.
> + goto skip_rdma;
> +
> + if (server->smbd_conn && server->smbd_conn->id) {
> + struct rdma_addr *addr =
> + &server->smbd_conn->id->route.addr;
> + seq_printf(m, "\n\t\tIP addr: dst: %pISpc, src: %pISpc",
> + &addr->dst_addr, &addr->src_addr);
> + }
> +
> +skip_rdma:
> +#endif
The goto is no longer necessary when removing above #ifdef.
> + if (server->ssocket) {
> + struct sockaddr src;
> + int addrlen;
> +
> + addrlen = kernel_getsockname(server->ssocket, &src);
> + if (addrlen != sizeof(struct sockaddr_in) &&
> + addrlen != sizeof(struct sockaddr_in6))
> + return;
> +
> + seq_printf(m, "\n\t\tIP addr: dst: %pISpc, src: %pISpc",
> + &server->dstaddr, &src);
> + }
> }
>
> static inline const char *smb_speed_to_str(size_t bps)
> @@ -279,7 +306,7 @@ static int cifs_debug_files_proc_show(struct seq_file *m, void *v)
> static int cifs_debug_data_proc_show(struct seq_file *m, void *v)
> {
> struct mid_q_entry *mid_entry;
> - struct TCP_Server_Info *server;
> + struct TCP_Server_Info *server, *nserver;
> struct TCP_Server_Info *chan_server;
> struct cifs_ses *ses;
> struct cifs_tcon *tcon;
> @@ -336,7 +363,7 @@ static int cifs_debug_data_proc_show(struct seq_file *m, void *v)
>
> c = 0;
> spin_lock(&cifs_tcp_ses_lock);
> - list_for_each_entry(server, &cifs_tcp_ses_list, tcp_ses_list) {
> + list_for_each_entry_safe(server, nserver, &cifs_tcp_ses_list, tcp_ses_list) {
> /* channel info will be printed as a part of sessions below */
> if (SERVER_IS_CHAN(server))
> continue;
> @@ -414,8 +441,39 @@ static int cifs_debug_data_proc_show(struct seq_file *m, void *v)
> seq_printf(m, "\nMR mr_ready_count: %x mr_used_count: %x",
> atomic_read(&server->smbd_conn->mr_ready_count),
> atomic_read(&server->smbd_conn->mr_used_count));
> + if (server->smbd_conn->id) {
> + struct rdma_addr *addr =
> + &server->smbd_conn->id->route.addr;
> + seq_printf(m, "\nIP addr: dst: %pISpc, src: %pISpc",
> + &addr->dst_addr, &addr->src_addr);
> + }
> skip_rdma:
> #endif
> + if (server->ssocket) {
> + struct sockaddr src;
> + int addrlen;
> +
> + /* kernel_getsockname can block. so drop the lock first */
> + server->srv_count++;
> + spin_unlock(&cifs_tcp_ses_lock);
> +
> + addrlen = kernel_getsockname(server->ssocket, &src);
> + if (addrlen != sizeof(struct sockaddr_in) &&
> + addrlen != sizeof(struct sockaddr_in6)) {
> + cifs_put_tcp_session(server, 0);
> + spin_lock(&cifs_tcp_ses_lock);
> +
> + goto skip_addr_details;
> + }
What about
addrlen = kernel_getsockname(server->ssocket, &src);
if (addrlen == sizeof(struct sockaddr_in) &&
addrlen == sizeof(struct sockaddr_in6)) {
seq_printf(m, "\nIP addr: dst: %pISpc, src: %pISpc",
&server->dstaddr, &src);
cifs_put_tcp_session(server, 0);
spin_lock(&cifs_tcp_ses_lock);
}
> +
> + seq_printf(m, "\nIP addr: dst: %pISpc, src: %pISpc",
> + &server->dstaddr, &src);
> +
> + cifs_put_tcp_session(server, 0);
> + spin_lock(&cifs_tcp_ses_lock);
> + }
> +
> +skip_addr_details:
Then you can get rid of this goto as well.
> seq_printf(m, "\nNumber of credits: %d,%d,%d Dialect 0x%x",
> server->credits,
> server->echo_credits,
> @@ -515,7 +573,18 @@ static int cifs_debug_data_proc_show(struct seq_file *m, void *v)
> seq_printf(m, "\n\n\tExtra Channels: %zu ",
> ses->chan_count-1);
> for (j = 1; j < ses->chan_count; j++) {
> + /*
> + * kernel_getsockname can block inside
> + * cifs_dump_channel. so drop the lock first
> + */
> + server->srv_count++;
> + spin_unlock(&cifs_tcp_ses_lock);
> +
> cifs_dump_channel(m, j, &ses->chans[j]);
> +
> + cifs_put_tcp_session(server, 0);
> + spin_lock(&cifs_tcp_ses_lock);
Here you are re-acquiring @cifs_tcp_ses_lock spinlock under
@ses->chan_lock, which will introduce deadlocks in threads calling
cifs_match_super(), cifs_signal_cifsd_for_reconnect(),
cifs_mark_tcp_ses_conns_for_reconnect(), cifs_find_smb_ses(), ...
next prev parent reply other threads:[~2023-10-31 15:19 UTC|newest]
Thread overview: 61+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-10-30 11:00 [PATCH 01/14] cifs: print server capabilities in DebugData nspmangalore
2023-10-30 11:00 ` [PATCH 02/14] cifs: add xid to query server interface call nspmangalore
2023-10-31 5:35 ` Bharath SM
2023-10-30 11:00 ` [PATCH 03/14] cifs: reconnect helper should set reconnect for the right channel nspmangalore
2023-10-31 15:27 ` Paulo Alcantara
2023-10-31 18:29 ` Steve French
2023-10-30 11:00 ` [PATCH 04/14] cifs: do not reset chan_max if multichannel is not supported at mount nspmangalore
2023-11-01 2:57 ` Steve French
2023-11-01 3:14 ` Steve French
2023-10-30 11:00 ` [PATCH 05/14] cifs: force interface update before a fresh session setup nspmangalore
2023-11-01 3:14 ` Steve French
2023-10-30 11:00 ` [PATCH 06/14] cifs: handle cases where a channel is closed nspmangalore
2023-11-01 3:09 ` Steve French
2023-11-02 12:26 ` Shyam Prasad N
2023-10-30 11:00 ` [PATCH 07/14] cifs: distribute channels across interfaces based on speed nspmangalore
2023-10-30 11:00 ` [PATCH 08/14] cifs: account for primary channel in the interface list nspmangalore
2023-11-08 15:44 ` Paulo Alcantara
2023-11-08 18:16 ` Steve French
2023-11-08 19:03 ` Paulo Alcantara
2023-10-30 11:00 ` [PATCH 09/14] cifs: add a back pointer to cifs_sb from tcon nspmangalore
2023-11-01 3:30 ` Steve French
2023-11-03 21:03 ` Paulo Alcantara
2023-11-06 16:12 ` Shyam Prasad N
2023-11-06 17:04 ` Shyam Prasad N
[not found] ` <CAH2r5msQLTcdiHBrOKd+q6LPPHW_Jj3QbpFZyZ48CJbrtDqC5w@mail.gmail.com>
[not found] ` <CAH2r5mt4hC5x2w2D46y13j_OtjkJk9_ZaeGXbb7YKukffBk2LQ@mail.gmail.com>
2023-11-06 19:36 ` Fwd: " Steve French
2023-11-08 15:24 ` Paulo Alcantara
2023-11-08 16:11 ` Steve French
2023-10-30 11:00 ` [PATCH 10/14] cifs: reconnect work should have reference on server struct nspmangalore
2023-11-16 17:10 ` Paulo Alcantara
[not found] ` <CAH2r5mtDeP323Z8=9WjCCYVVb9B2AmO5Q4PDtcMz8wxVUCVRBA@mail.gmail.com>
2023-11-16 19:35 ` Paulo Alcantara
2023-10-30 11:00 ` [PATCH 11/14] cifs: handle when server starts supporting multichannel nspmangalore
2023-11-01 3:30 ` Steve French
2023-11-01 15:52 ` Paulo Alcantara
2023-11-04 7:50 ` Shyam Prasad N
2023-11-02 20:28 ` Paulo Alcantara
2023-11-03 0:43 ` Steve French
2023-11-03 20:32 ` Paulo Alcantara
[not found] ` <notmuch-sha1-c3bfa7f4ae0bb24c5ee7cfddb408c2fbeca5d8f7>
2023-11-08 16:02 ` Paulo Alcantara
2023-11-08 19:25 ` Steve French
2023-11-08 19:31 ` Paulo Alcantara
2023-10-30 11:00 ` [PATCH 12/14] cifs: handle when server stops " nspmangalore
2023-11-08 16:35 ` Paulo Alcantara
[not found] ` <notmuch-sha1-9ed0289358ca5c90903408ad9c0ac0310afee598>
2023-11-08 19:13 ` Paulo Alcantara
2023-11-08 19:41 ` Paulo Alcantara
2023-11-09 11:44 ` Shyam Prasad N
2023-11-09 13:28 ` Paulo Alcantara
2023-11-09 13:49 ` Shyam Prasad N
2023-11-10 4:09 ` Shyam Prasad N
2023-11-11 17:23 ` Paulo Alcantara
2023-11-12 18:52 ` Steve French
[not found] ` <CAH2r5mvG3zLBxknPOuaz9=GarZO6n6bhcduiZHHfiqVYZYJiVQ@mail.gmail.com>
2023-11-12 19:32 ` Paulo Alcantara
2023-10-30 11:00 ` [PATCH 13/14] cifs: display the endpoint IP details in DebugData nspmangalore
2023-10-31 15:18 ` Paulo Alcantara [this message]
[not found] ` <notmuch-sha1-260ef7fe7af7face0e1486229c0fda5149fe14e2>
2023-11-01 14:12 ` Paulo Alcantara
2023-11-01 14:19 ` Steve French
2023-11-04 7:44 ` Shyam Prasad N
2023-11-04 19:00 ` Paulo Alcantara
2023-10-30 12:34 ` [PATCH 01/14] cifs: print server capabilities " Bharath SM
2023-10-30 12:40 ` Shyam Prasad N
2023-10-30 12:51 ` Shyam Prasad N
2023-10-30 14:54 ` Steve French
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=364e6840dba943b3d23e5b50b793550d.pc@manguebit.com \
--to=pc@manguebit.com \
--cc=bharathsm.hsk@gmail.com \
--cc=linux-cifs@vger.kernel.org \
--cc=nspmangalore@gmail.com \
--cc=smfrench@gmail.com \
--cc=sprasad@microsoft.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox