Commit ffa038ba authored by Haroldo Gamal's avatar Haroldo Gamal Committed by Linus Torvalds

[PATCH] smbfs: Bug #3758 - Broken symlinks on smbfs

The patches attached here fixes the BUG #3758 - "Broken symlinks on smbfs
with 2.6.10-rc[12]".  There are two patches, one to be applied over version
2.6.9 and the other over 2.6.10-rc2.

The old utilities (and the old driver) uses uid=0, gid=0, dmask=0 and
fmask=0 to flag the lack of this parameters on the mount command line.
When the user do not specify the uid, gid, fmask or dmask, the current
driver will assign gid=root, gid=root, dmask=755, fmask=755.  This behavior
is similar to the old 2.x samba versions.

To make the driver see the permissions and ownership assigned on the
server, "smbmount" and "smbmnt" utilities must be patched.  The patches is
already available on the attached patches at Bug #3330 or Samba Bug #999.
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent bbb0dbfc
...@@ -574,10 +574,10 @@ int smb_fill_super(struct super_block *sb, void *raw_data, int silent) ...@@ -574,10 +574,10 @@ int smb_fill_super(struct super_block *sb, void *raw_data, int silent)
mnt->flags = (oldmnt->file_mode >> 9) | SMB_MOUNT_UID | mnt->flags = (oldmnt->file_mode >> 9) | SMB_MOUNT_UID |
SMB_MOUNT_GID | SMB_MOUNT_FMODE | SMB_MOUNT_DMODE; SMB_MOUNT_GID | SMB_MOUNT_FMODE | SMB_MOUNT_DMODE;
} else { } else {
mnt->file_mode = mnt->dir_mode = S_IRWXU | S_IRGRP | S_IXGRP | mnt->file_mode = S_IRWXU | S_IRGRP | S_IXGRP |
S_IROTH | S_IXOTH | S_IFREG; S_IROTH | S_IXOTH | S_IFREG;
mnt->dir_mode = mnt->dir_mode = S_IRWXU | S_IRGRP | S_IXGRP | mnt->dir_mode = S_IRWXU | S_IRGRP | S_IXGRP |
S_IROTH | S_IXOTH | S_IFDIR; S_IROTH | S_IXOTH | S_IFDIR;
if (parse_options(mnt, raw_data)) if (parse_options(mnt, raw_data))
goto out_bad_option; goto out_bad_option;
} }
......
...@@ -2138,10 +2138,11 @@ void smb_decode_unix_basic(struct smb_fattr *fattr, struct smb_sb_info *server, ...@@ -2138,10 +2138,11 @@ void smb_decode_unix_basic(struct smb_fattr *fattr, struct smb_sb_info *server,
if ( (server->mnt->flags & SMB_MOUNT_DMODE) && if ( (server->mnt->flags & SMB_MOUNT_DMODE) &&
(S_ISDIR(fattr->f_mode)) ) (S_ISDIR(fattr->f_mode)) )
fattr->f_mode = (server->mnt->dir_mode & (S_IRWXU | S_IRWXG | S_IRWXO)) | S_IFDIR; fattr->f_mode = (server->mnt->dir_mode & S_IRWXUGO) | S_IFDIR;
else if ( (server->mnt->flags & SMB_MOUNT_FMODE) && else if ( (server->mnt->flags & SMB_MOUNT_FMODE) &&
!(S_ISDIR(fattr->f_mode)) ) !(S_ISDIR(fattr->f_mode)) )
fattr->f_mode = (server->mnt->file_mode & (S_IRWXU | S_IRWXG | S_IRWXO)) | S_IFREG; fattr->f_mode = (server->mnt->file_mode & S_IRWXUGO) |
(fattr->f_mode & S_IFMT);
} }
......
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