commit 3aa1c8c2900065a51268430ab48a1b42fdfe5b45 made cifs_getattr set
the ownership of files to current_fsuid/current_fsgid when multiuser
mounts were in use and when mnt_uid/mnt_gid were non-zero.

It should have instead based that decision on the
CIFS_MOUNT_OVERR_UID/GID flags. Also, since this is really more about
permissions presentation than multiuser access, base that decision on
CIFS_MOUNT_NO_PERM instead of CIFS_MOUNT_MULTIUSER. That changes the
behavior for users using -o noperm, but makes a bit more sense than
basing this decision on whether this is a multiuser mount.

Signed-off-by: Jeff Layton <[email protected]>
---
 fs/cifs/inode.c |   14 ++++++++++----
 1 files changed, 10 insertions(+), 4 deletions(-)

diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c
index 7cf3d93..d3f9a18 100644
--- a/fs/cifs/inode.c
+++ b/fs/cifs/inode.c
@@ -1759,7 +1759,7 @@ check_inval:
 }
 
 int cifs_getattr(struct vfsmount *mnt, struct dentry *dentry,
-       struct kstat *stat)
+                struct kstat *stat)
 {
        struct cifs_sb_info *cifs_sb = CIFS_SB(dentry->d_sb);
        struct cifsTconInfo *tcon = cifs_sb_master_tcon(cifs_sb);
@@ -1769,11 +1769,17 @@ int cifs_getattr(struct vfsmount *mnt, struct dentry 
*dentry,
                generic_fillattr(dentry->d_inode, stat);
                stat->blksize = CIFS_MAX_MSGSIZE;
                stat->ino = CIFS_I(dentry->d_inode)->uniqueid;
-               if ((cifs_sb->mnt_cifs_flags & CIFS_MOUNT_MULTIUSER) &&
+
+               /*
+                * If on a noperm mount without unix extensions, and the
+                * admin hasn't overridden them, set the ownership to the
+                * fsuid/fsgid of the current process.
+                */
+               if ((cifs_sb->mnt_cifs_flags & CIFS_MOUNT_NO_PERM) &&
                    !tcon->unix_ext) {
-                       if (!cifs_sb->mnt_uid)
+                       if (!(cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_UID))
                                stat->uid = current_fsuid();
-                       if (!cifs_sb->mnt_uid)
+                       if (!(cifs_sb->mnt_cifs_flags & CIFS_MOUNT_OVERR_GID))
                                stat->gid = current_fsgid();
                }
        }
-- 
1.7.2.3

--
To unsubscribe from this list: send the line "unsubscribe linux-cifs" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to