From 5bb81212edfdb7e77051f5a9cba2b7b260fa8c51 Mon Sep 17 00:00:00 2001 From: Trond Myklebust Date: Tue, 3 Jan 2006 09:55:53 +0100 Subject: [PATCH] --- yaml --- r: 16645 b: refs/heads/master c: cf3fff54a46e1f8fa4cc1deb783172a392077eb0 h: refs/heads/master i: 16643: 94c9a5f1575790e5fc013e49c7caacf617e6d01b v: v3 --- [refs] | 2 +- trunk/fs/nfs/nfs3xdr.c | 2 +- trunk/fs/nfs/nfs4xdr.c | 2 +- trunk/fs/nfs/proc.c | 3 +++ 4 files changed, 6 insertions(+), 3 deletions(-) diff --git a/[refs] b/[refs] index 930ededdc5d3..25c6bfa9be4b 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: f518e35aec984036903c1003e867f833747a9d79 +refs/heads/master: cf3fff54a46e1f8fa4cc1deb783172a392077eb0 diff --git a/trunk/fs/nfs/nfs3xdr.c b/trunk/fs/nfs/nfs3xdr.c index 0498bd36602c..b6c0b5012bce 100644 --- a/trunk/fs/nfs/nfs3xdr.c +++ b/trunk/fs/nfs/nfs3xdr.c @@ -182,7 +182,7 @@ xdr_encode_sattr(u32 *p, struct iattr *attr) { if (attr->ia_valid & ATTR_MODE) { *p++ = xdr_one; - *p++ = htonl(attr->ia_mode); + *p++ = htonl(attr->ia_mode & S_IALLUGO); } else { *p++ = xdr_zero; } diff --git a/trunk/fs/nfs/nfs4xdr.c b/trunk/fs/nfs/nfs4xdr.c index 12be1d682164..4bbf5ef57785 100644 --- a/trunk/fs/nfs/nfs4xdr.c +++ b/trunk/fs/nfs/nfs4xdr.c @@ -566,7 +566,7 @@ static int encode_attrs(struct xdr_stream *xdr, const struct iattr *iap, const s } if (iap->ia_valid & ATTR_MODE) { bmval1 |= FATTR4_WORD1_MODE; - WRITE32(iap->ia_mode); + WRITE32(iap->ia_mode & S_IALLUGO); } if (iap->ia_valid & ATTR_UID) { bmval1 |= FATTR4_WORD1_OWNER; diff --git a/trunk/fs/nfs/proc.c b/trunk/fs/nfs/proc.c index 6145e82b45e8..f5150d71c03d 100644 --- a/trunk/fs/nfs/proc.c +++ b/trunk/fs/nfs/proc.c @@ -111,6 +111,9 @@ nfs_proc_setattr(struct dentry *dentry, struct nfs_fattr *fattr, }; int status; + /* Mask out the non-modebit related stuff from attr->ia_mode */ + sattr->ia_mode &= S_IALLUGO; + dprintk("NFS call setattr\n"); nfs_fattr_init(fattr); status = rpc_call(NFS_CLIENT(inode), NFSPROC_SETATTR, &arg, fattr, 0);