diff options
author | Sachin Prabhu <sprabhu@redhat.com> | 2015-06-16 17:36:17 +0200 |
---|---|---|
committer | Steve French <steve.french@primarydata.com> | 2015-06-29 21:50:22 +0200 |
commit | 1dfd18d0571231d030f325bfcd80f5c42a56a53e (patch) | |
tree | 09a9a6d2f687562535829346aebe48ecc9d646d2 /fs/cifs/connect.c | |
parent | Update negotiate protocol for SMB3.11 dialect (diff) | |
download | linux-1dfd18d0571231d030f325bfcd80f5c42a56a53e.tar.xz linux-1dfd18d0571231d030f325bfcd80f5c42a56a53e.zip |
cifs: Unset CIFS_MOUNT_POSIX_PATHS flag when following dfs mounts
In a dfs setup where the client transitions from a server which supports
posix paths to a server which doesn't support posix paths, the flag
CIFS_MOUNT_POSIX_PATHS is not reset. This leads to the wrong directory
separator being used causing smb commands to fail.
Consider the following case where a dfs share on a samba server points
to a share on windows smb server.
# mount -t cifs -o .. //vm140-31/dfsroot/testwin/
# ls -l /mnt; touch /mnt/a
total 0
touch: cannot touch ‘/mnt/a’: No such file or directory
Signed-off-by: Sachin Prabhu <sprabhu@redhat.com>
Acked-by: Jeff Layton <jlayton@samba.org>
Signed-off-by: Steve French <steve.french@primarydata.com>
Diffstat (limited to '')
-rw-r--r-- | fs/cifs/connect.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index 247f4dd228cc..773f4dc77630 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c @@ -3472,6 +3472,8 @@ try_mount_again: else if (ses) cifs_put_smb_ses(ses); + cifs_sb->mnt_cifs_flags &= ~CIFS_MOUNT_POSIX_PATHS; + free_xid(xid); } #endif |