updated patch to: 1) log the server name for this message 2) only log on mount (not every ten minutes) See attached On Mon, Oct 3, 2022 at 9:21 AM Tom Talpey <tom@xxxxxxxxxx> wrote: > > On 10/3/2022 12:38 AM, Steve French wrote: > > On Sat, Oct 1, 2022 at 6:22 PM Tom Talpey <tom@xxxxxxxxxx> wrote: > >> > >> On 10/1/2022 12:54 PM, Steve French wrote: > >>> Some servers can return an empty network interface list so, unless > >>> multichannel is requested, no need to log an error for this, and > >>> when multichannel is requested on mount but no interfaces, log > >>> something less confusing. For this case change > >>> parse_server_interfaces: malformed interface info > >>> to > >>> empty network interface list returned by server > >> > >> Will this spam the log if it happens on every MC refresh (10 mins)? > >> It might be helpful to identify the servername, too. > > > > Yes - I just noticed that in this case (multichannel mount to Samba > > where no valid interfaces) we log it every ten minutes. > > Maybe best way to fix this is to change it to a log once error (with > > server name is fine with me) since it is probably legal to return an > > empty list (so not serious enough to be worth logging every ten > > minutes) and in theory server could fix its interfaces later. > > Ten minutes is the default recommended polling interval in the doc. > > While it's odd, it's not prevented by the protocol. I could guess > that a server running in a namespace might return strange things > as devices came and went, for example. > > It's not an error, so the message is purely informational. It is > useful though. Is it possible to suppress the logging if the > message *doesn't* change, but otherwise emit new ones? That might > require some per-server fiddling to avoid multiple servers flipping > the message. > > A boolean or bit in the server struct? A little ugly for the purpose, > but surfacing multichannel events - especially ones that prevent it > from happening - seems worthwhile. > > Tom. > > > Tom. > > > >>> Cc: <stable@xxxxxxxxxxxxxxx> > >>> Signed-off-by: Steve French <stfrench@xxxxxxxxxxxxx> > >>> > >>> See attached patch > >>> > > > > > > -- Thanks, Steve
From 952672f57f3d94a631ca890e96bf70740c36758b Mon Sep 17 00:00:00 2001 From: Steve French <stfrench@xxxxxxxxxxxxx> Date: Mon, 3 Oct 2022 17:25:41 -0500 Subject: [PATCH] smb3: do not log confusing message when server returns no network interfaces Some servers can return an empty network interface list so, unless multichannel is requested, no need to log an error for this, and when multichannel is requested on mount but no interfaces, log something less confusing. For this case change parse_server_interfaces: malformed interface info to empty network interface list returned by server localhost Also do not relog this error every ten minutes (only log on mount, once) Cc: <stable@xxxxxxxxxxxxxxx> Signed-off-by: Steve French <stfrench@xxxxxxxxxxxxx> --- fs/cifs/cifsproto.h | 2 +- fs/cifs/connect.c | 2 +- fs/cifs/smb2ops.c | 16 +++++++++------- 3 files changed, 11 insertions(+), 9 deletions(-) diff --git a/fs/cifs/cifsproto.h b/fs/cifs/cifsproto.h index f5adcb8ea04d..84ec71bdfacd 100644 --- a/fs/cifs/cifsproto.h +++ b/fs/cifs/cifsproto.h @@ -638,7 +638,7 @@ cifs_chan_is_iface_active(struct cifs_ses *ses, int cifs_chan_update_iface(struct cifs_ses *ses, struct TCP_Server_Info *server); int -SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon); +SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon, bool in_mount); void extract_unc_hostname(const char *unc, const char **h, size_t *len); int copy_path_name(char *dst, const char *src); diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index ad81d7d43eaf..93e59b3b36c7 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c @@ -155,7 +155,7 @@ static void smb2_query_server_interfaces(struct work_struct *work) /* * query server network interfaces, in case they change */ - rc = SMB3_request_interfaces(0, tcon); + rc = SMB3_request_interfaces(0, tcon, false); if (rc) { cifs_dbg(FYI, "%s: failed to query server interfaces: %d\n", __func__, rc); diff --git a/fs/cifs/smb2ops.c b/fs/cifs/smb2ops.c index ef88f95302f6..b0d93188631e 100644 --- a/fs/cifs/smb2ops.c +++ b/fs/cifs/smb2ops.c @@ -512,8 +512,7 @@ smb3_negotiate_rsize(struct cifs_tcon *tcon, struct smb3_fs_context *ctx) static int parse_server_interfaces(struct network_interface_info_ioctl_rsp *buf, - size_t buf_len, - struct cifs_ses *ses) + size_t buf_len, struct cifs_ses *ses, bool in_mount) { struct network_interface_info_ioctl_rsp *p; struct sockaddr_in *addr4; @@ -548,8 +547,11 @@ parse_server_interfaces(struct network_interface_info_ioctl_rsp *buf, * which would only be a problem if we were requesting multichannel */ if (bytes_left == 0) { - if (ses->chan_max > 1) - cifs_dbg(VFS, "empty network interface list returned by server\n"); + /* avoid spamming logs every 10 minutes, so log only in mount */ + if ((ses->chan_max > 1) && in_mount) + cifs_dbg(VFS, + "empty network interface list returned by server %s\n", + ses->server->hostname); rc = -EINVAL; goto out; } @@ -684,7 +686,7 @@ parse_server_interfaces(struct network_interface_info_ioctl_rsp *buf, } int -SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon) +SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon, bool in_mount) { int rc; unsigned int ret_data_len = 0; @@ -704,7 +706,7 @@ SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon) goto out; } - rc = parse_server_interfaces(out_buf, ret_data_len, ses); + rc = parse_server_interfaces(out_buf, ret_data_len, ses, in_mount); if (rc) goto out; @@ -740,7 +742,7 @@ smb3_qfs_tcon(const unsigned int xid, struct cifs_tcon *tcon, if (rc) return; - SMB3_request_interfaces(xid, tcon); + SMB3_request_interfaces(xid, tcon, true /* called during mount */); SMB2_QFS_attr(xid, tcon, fid.persistent_fid, fid.volatile_fid, FS_ATTRIBUTE_INFORMATION); -- 2.34.1