cifs: fix leak of iface for primary channel
My last change in this area introduced a change which accounted for primary channel in the interface ref count. However, it did not reduce this ref count on deallocation of the primary channel. i.e. during umount. Fixing this leak here, by dropping this ref count for primary channel while freeing up the session. Fixes: fa1d0508bdd4 ("cifs: account for primary channel in the interface list") Cc: stable@vger.kernel.org Reported-by: Paulo Alcantara <pc@manguebit.com> Signed-off-by: Shyam Prasad N <sprasad@microsoft.com> Signed-off-by: Steve French <stfrench@microsoft.com>
This commit is contained in:
parent
181724fc72
commit
29954d5b1e
@ -2065,6 +2065,12 @@ void __cifs_put_smb_ses(struct cifs_ses *ses)
|
|||||||
ses->chans[i].server = NULL;
|
ses->chans[i].server = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* we now account for primary channel in iface->refcount */
|
||||||
|
if (ses->chans[0].iface) {
|
||||||
|
kref_put(&ses->chans[0].iface->refcount, release_iface);
|
||||||
|
ses->chans[0].server = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
sesInfoFree(ses);
|
sesInfoFree(ses);
|
||||||
cifs_put_tcp_session(server, 0);
|
cifs_put_tcp_session(server, 0);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user