Commit 8dd5c128 authored by Jan-Marek Glogowski's avatar Jan-Marek Glogowski Committed by Sasha Levin

Reset TreeId to zero on SMB2 TREE_CONNECT

[ Upstream commit 806a28ef ]

Currently the cifs module breaks the CIFS specs on reconnect as
described in http://msdn.microsoft.com/en-us/library/cc246529.aspx:

"TreeId (4 bytes): Uniquely identifies the tree connect for the
command. This MUST be 0 for the SMB2 TREE_CONNECT Request."
Signed-off-by: default avatarJan-Marek Glogowski <glogow@fbihome.de>
Reviewed-by: default avatarAurelien Aptel <aaptel@suse.com>
Tested-by: default avatarAurelien Aptel <aaptel@suse.com>
Signed-off-by: default avatarSteve French <smfrench@gmail.com>
CC: Stable <stable@vger.kernel.org>
Signed-off-by: default avatarSasha Levin <alexander.levin@verizon.com>
parent 3707e32c
...@@ -868,6 +868,10 @@ SMB2_tcon(const unsigned int xid, struct cifs_ses *ses, const char *tree, ...@@ -868,6 +868,10 @@ SMB2_tcon(const unsigned int xid, struct cifs_ses *ses, const char *tree,
return -EINVAL; return -EINVAL;
} }
/* SMB2 TREE_CONNECT request must be called with TreeId == 0 */
if (tcon)
tcon->tid = 0;
rc = small_smb2_init(SMB2_TREE_CONNECT, tcon, (void **) &req); rc = small_smb2_init(SMB2_TREE_CONNECT, tcon, (void **) &req);
if (rc) { if (rc) {
kfree(unc_path); kfree(unc_path);
......
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