Commit d9a6d780 authored by Shyam Prasad N's avatar Shyam Prasad N Committed by Steve French

cifs: force interface update before a fresh session setup

During a session reconnect, it is possible that the
server moved to another physical server (happens in case
of Azure files). So at this time, force a query of server
interfaces again (in case of multichannel session), such
that the secondary channels connect to the right
IP addresses (possibly updated now).

Cc: stable@vger.kernel.org
Signed-off-by: default avatarShyam Prasad N <sprasad@microsoft.com>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent 6e5e64c9
...@@ -3849,8 +3849,12 @@ cifs_setup_session(const unsigned int xid, struct cifs_ses *ses, ...@@ -3849,8 +3849,12 @@ cifs_setup_session(const unsigned int xid, struct cifs_ses *ses,
is_binding = !CIFS_ALL_CHANS_NEED_RECONNECT(ses); is_binding = !CIFS_ALL_CHANS_NEED_RECONNECT(ses);
spin_unlock(&ses->chan_lock); spin_unlock(&ses->chan_lock);
if (!is_binding) if (!is_binding) {
ses->ses_status = SES_IN_SETUP; ses->ses_status = SES_IN_SETUP;
/* force iface_list refresh */
ses->iface_last_update = 0;
}
spin_unlock(&ses->ses_lock); spin_unlock(&ses->ses_lock);
/* update ses ip_addr only for primary chan */ /* update ses ip_addr only for primary chan */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment