From ffec2db822701c2fea1832f3e4febe4dd3c30b37 Mon Sep 17 00:00:00 2001 From: ZhangXiaoxu <zhangxiaoxu5@huawei.com> Date: Tue, 26 Feb 2019 13:52:24 +0800 Subject: [PATCH] nfs: fix xfstest generic/099 failed on nfsv3 mainline inclusion from linux-next/master commit ded52fbe7020a5696b0b0a0fdbf234e37bf16f94 category: bugfix bugzilla: NA CVE: NA ------------------------------------------------- After setxattr, the nfsv3 cached the acl which set by user. But at the backend, the shared file system (eg. ext4) will check the acl, if it can merged with mode, it won't add acl to the file. So, the nfsv3 cached acl is redundant. Don't 'set_cached_acl' when setxattr. Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com> Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com> Signed-off-by: ZhangXiaoxu <zhangxiaoxu5@huawei.com> Reviewed-by: yangerkun <yangerkun@huawei.com> Signed-off-by: Yang Yingliang <yangyingliang@huawei.com> --- fs/nfs/nfs3acl.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/fs/nfs/nfs3acl.c b/fs/nfs/nfs3acl.c index 9fce18548f7e..c5c3fc6e6c60 100644 --- a/fs/nfs/nfs3acl.c +++ b/fs/nfs/nfs3acl.c @@ -222,8 +222,6 @@ static int __nfs3_proc_setacls(struct inode *inode, struct posix_acl *acl, switch (status) { case 0: status = nfs_refresh_inode(inode, fattr); - set_cached_acl(inode, ACL_TYPE_ACCESS, acl); - set_cached_acl(inode, ACL_TYPE_DEFAULT, dfacl); break; case -EPFNOSUPPORT: case -EPROTONOSUPPORT: -- GitLab