diff options
author | Steve French <smfrench@gmail.com> | 2014-08-16 06:49:01 +0200 |
---|---|---|
committer | Steve French <smfrench@gmail.com> | 2014-08-16 06:49:01 +0200 |
commit | 754789a1c046106cfdb067102642f73e0fd35fb3 (patch) | |
tree | e1c9ea733b2647a868f68eaaff987750adad83bb /fs/cifs/readdir.c | |
parent | cifs: handle lease F_UNLCK requests properly (diff) | |
download | linux-754789a1c046106cfdb067102642f73e0fd35fb3.tar.xz linux-754789a1c046106cfdb067102642f73e0fd35fb3.zip |
[CIFS] Workaround MacOS server problem with SMB2.1 write
response
Writes fail to Mac servers with SMB2.1 mounts (works with cifs though) due
to them sending an incorrect RFC1001 length for the SMB2.1 Write response.
Workaround this problem. MacOS server sends a write response with 3 bytes
of pad beyond the end of the SMB itself. The RFC1001 length is 3 bytes
more than the sum of the SMB2.1 header length + the write reponse.
Incorporate feedback from Jeff and JRA to allow servers to send
a tcp frame that is even more than three bytes too long
(ie much longer than the SMB2/SMB3 request that it contains) but
we do log it once now. In the earlier version of the patch I had
limited how far off the length field could be before we fail the request.
Signed-off-by: Steve French <smfrench@gmail.com>
Diffstat (limited to 'fs/cifs/readdir.c')
0 files changed, 0 insertions, 0 deletions