cifs: update the same create_guid on replay
authorShyam Prasad N <sprasad@microsoft.com>
Fri, 9 Feb 2024 11:25:42 +0000 (11:25 +0000)
committerSteve French <stfrench@microsoft.com>
Mon, 12 Feb 2024 01:07:08 +0000 (19:07 -0600)
commit79520587fe42cd4988aff8695d60621e689109cb
tree2b304831d7dfeb669eb2dd399b77d3811953e6dc
parentcffe487026be13eaf37ea28b783d9638ab147204
cifs: update the same create_guid on replay

File open requests made to the server contain a
CreateGuid, which is used by the server to identify
the open request. If the same request needs to be
replayed, it needs to be sent with the same CreateGuid
in the durable handle v2 context.

Without doing so, we could end up leaking handles on
the server when:
1. multichannel is used AND
2. connection goes down, but not for all channels

This is because the replayed open request would have a
new CreateGuid and the server will treat this as a new
request and open a new handle.

This change fixes this by reusing the existing create_guid
stored in the cached fid struct.

REF: MS-SMB2 4.9 Replay Create Request on an Alternate Channel

Fixes: 4f1fffa23769 ("cifs: commands that are retried should have replay flag set")
Signed-off-by: Shyam Prasad N <sprasad@microsoft.com>
Signed-off-by: Steve French <stfrench@microsoft.com>
fs/smb/client/cached_dir.c
fs/smb/client/cifsglob.h
fs/smb/client/smb2ops.c
fs/smb/client/smb2pdu.c