mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-05 18:41:58 +09:00
cifs: cifs_chan_is_iface_active should be called with chan_lock held
commit 7257bcf3bdc785eabc4eef1f329a59815b032508 upstream.
cifs_chan_is_iface_active checks the channels of a session to see
if the associated iface is active. This should always happen
with chan_lock held. However, these two callers of this function
were missing this locking.
This change makes sure the function calls are protected with
proper locking.
Fixes: b54034a73b ("cifs: during reconnect, update interface if necessary")
Fixes: fa1d0508bdd4 ("cifs: account for primary channel in the interface list")
Cc: stable@vger.kernel.org
Signed-off-by: Shyam Prasad N <sprasad@microsoft.com>
Signed-off-by: Steve French <stfrench@microsoft.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
4afcb82518
commit
5982a625fc
@@ -258,10 +258,13 @@ cifs_mark_tcp_ses_conns_for_reconnect(struct TCP_Server_Info *server,
|
|||||||
spin_lock(&cifs_tcp_ses_lock);
|
spin_lock(&cifs_tcp_ses_lock);
|
||||||
list_for_each_entry_safe(ses, nses, &pserver->smb_ses_list, smb_ses_list) {
|
list_for_each_entry_safe(ses, nses, &pserver->smb_ses_list, smb_ses_list) {
|
||||||
/* check if iface is still active */
|
/* check if iface is still active */
|
||||||
if (!cifs_chan_is_iface_active(ses, server))
|
|
||||||
cifs_chan_update_iface(ses, server);
|
|
||||||
|
|
||||||
spin_lock(&ses->chan_lock);
|
spin_lock(&ses->chan_lock);
|
||||||
|
if (!cifs_chan_is_iface_active(ses, server)) {
|
||||||
|
spin_unlock(&ses->chan_lock);
|
||||||
|
cifs_chan_update_iface(ses, server);
|
||||||
|
spin_lock(&ses->chan_lock);
|
||||||
|
}
|
||||||
|
|
||||||
if (!mark_smb_session && cifs_chan_needs_reconnect(ses, server)) {
|
if (!mark_smb_session && cifs_chan_needs_reconnect(ses, server)) {
|
||||||
spin_unlock(&ses->chan_lock);
|
spin_unlock(&ses->chan_lock);
|
||||||
continue;
|
continue;
|
||||||
|
|||||||
@@ -778,9 +778,14 @@ SMB3_request_interfaces(const unsigned int xid, struct cifs_tcon *tcon, bool in_
|
|||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
/* check if iface is still active */
|
/* check if iface is still active */
|
||||||
|
spin_lock(&ses->chan_lock);
|
||||||
pserver = ses->chans[0].server;
|
pserver = ses->chans[0].server;
|
||||||
if (pserver && !cifs_chan_is_iface_active(ses, pserver))
|
if (pserver && !cifs_chan_is_iface_active(ses, pserver)) {
|
||||||
|
spin_unlock(&ses->chan_lock);
|
||||||
cifs_chan_update_iface(ses, pserver);
|
cifs_chan_update_iface(ses, pserver);
|
||||||
|
spin_lock(&ses->chan_lock);
|
||||||
|
}
|
||||||
|
spin_unlock(&ses->chan_lock);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
kfree(out_buf);
|
kfree(out_buf);
|
||||||
|
|||||||
Reference in New Issue
Block a user