cifs: allow matching of tcp sessions in CifsNew state
With commit 7332f2a621
, cifsd will no
longer exit when the socket abends and the tcpStatus is CifsNew. With
that change, there's no reason to avoid matching an existing session in
this state.
Signed-off-by: Jeff Layton <jlayton@redhat.com>
Signed-off-by: Steve French <sfrench@us.ibm.com>
This commit is contained in:
parent
5fe97cfddc
commit
ab9db8b737
|
@ -1511,15 +1511,6 @@ cifs_find_tcp_session(struct sockaddr *addr, struct smb_vol *vol)
|
||||||
|
|
||||||
write_lock(&cifs_tcp_ses_lock);
|
write_lock(&cifs_tcp_ses_lock);
|
||||||
list_for_each_entry(server, &cifs_tcp_ses_list, tcp_ses_list) {
|
list_for_each_entry(server, &cifs_tcp_ses_list, tcp_ses_list) {
|
||||||
/*
|
|
||||||
* the demux thread can exit on its own while still in CifsNew
|
|
||||||
* so don't accept any sockets in that state. Since the
|
|
||||||
* tcpStatus never changes back to CifsNew it's safe to check
|
|
||||||
* for this without a lock.
|
|
||||||
*/
|
|
||||||
if (server->tcpStatus == CifsNew)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!match_address(server, addr,
|
if (!match_address(server, addr,
|
||||||
(struct sockaddr *)&vol->srcaddr))
|
(struct sockaddr *)&vol->srcaddr))
|
||||||
continue;
|
continue;
|
||||||
|
|
Loading…
Reference in New Issue