From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jeff Layton Subject: [PATCH 13/15] cifs: on multises mount, set ownership to current_fsuid/current_fsgid Date: Tue, 30 Mar 2010 15:51:15 -0400 Message-ID: <1269978677-6817-14-git-send-email-jlayton@samba.org> References: <1269978677-6817-1-git-send-email-jlayton@samba.org> Cc: linux-fsdevel@vger.kernel.org To: linux-cifs-client@lists.samba.org Return-path: Received: from mx1.redhat.com ([209.132.183.28]:49806 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754899Ab0C3TvV (ORCPT ); Tue, 30 Mar 2010 15:51:21 -0400 In-Reply-To: <1269978677-6817-1-git-send-email-jlayton@samba.org> Sender: linux-fsdevel-owner@vger.kernel.org List-ID: From: Jeff Layton ...when unix extensions aren't enabled. This makes everything on the mount appear to be owned by the current user. Signed-off-by: Jeff Layton --- fs/cifs/inode.c | 8 ++++++++ 1 files changed, 8 insertions(+), 0 deletions(-) diff --git a/fs/cifs/inode.c b/fs/cifs/inode.c index e8cb95d..4a0e5e7 100644 --- a/fs/cifs/inode.c +++ b/fs/cifs/inode.c @@ -1659,11 +1659,19 @@ check_inval: int cifs_getattr(struct vfsmount *mnt, struct dentry *dentry, struct kstat *stat) { + struct cifs_sb_info *cifs_sb = CIFS_SB(dentry->d_sb); + struct cifsTconInfo *tcon = cifs_sb_tcon(cifs_sb); int err = cifs_revalidate_dentry(dentry); + if (!err) { 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_MULTISES && + !tcon->unix_ext) { + stat->uid = current_fsuid(); + stat->gid = current_fsgid(); + } } return err; } -- 1.6.6.1