diff mbox

NFSv3/acl: forget acl cache after setattr

Message ID ca4d7366-bc4c-1710-13a2-f99510c53be4@cn.fujitsu.com (mailing list archive)
State New, archived
Headers show

Commit Message

chenditang March 28, 2018, 10:12 a.m. UTC
Sync of ACL with std permissions fail,do We need to forget the ACL
cache after setattr?

Reproduction:
#!/bin/bash
touch testfile
cat <<EOF >testfile
#!/bin/bash
echo "Test was executed"
EOF
chmod u=rwx testfile
chmod g=rw- testfile
chmod o=r-- testfile

chacl u::r--,g::rwx,o:rw- testfile
chmod u+w testfile
ls -ln testfile
chacl -l testfile

Output:
-rw-rwxrw- 1 root root 0 Mar 28 05:29 testfile
testfile [u::r--,g::rwx,o::rw-]

Signed-off-by: chendt.fnst <chendt.fnst@cn.fujitsu.com>
---
 fs/nfs/nfs3proc.c | 1 +
 1 file changed, 1 insertion(+)

Comments

Benjamin Coddington March 28, 2018, 8:48 p.m. UTC | #1
I'm seeing this on xfstests generic/099 as well. Do we want to use 
nfs_zap_acl_cache() instead so that we clear NFS_INO_INVALID_ACL?

Ben

On 28 Mar 2018, at 6:12, chendt wrote:

> Sync of ACL with std permissions fail,do We need to forget the ACL
> cache after setattr?
>
> Reproduction:
> #!/bin/bash
> touch testfile
> cat <<EOF >testfile
> #!/bin/bash
> echo "Test was executed"
> EOF
> chmod u=rwx testfile
> chmod g=rw- testfile
> chmod o=r-- testfile
>
> chacl u::r--,g::rwx,o:rw- testfile
> chmod u+w testfile
> ls -ln testfile
> chacl -l testfile
>
> Output:
> -rw-rwxrw- 1 root root 0 Mar 28 05:29 testfile
> testfile [u::r--,g::rwx,o::rw-]
>
> Signed-off-by: chendt.fnst <chendt.fnst@cn.fujitsu.com>
> ---
>  fs/nfs/nfs3proc.c | 1 +
>  1 file changed, 1 insertion(+)
>
> diff --git a/fs/nfs/nfs3proc.c b/fs/nfs/nfs3proc.c
> index 7327930..ef3e17c 100644
> --- a/fs/nfs/nfs3proc.c
> +++ b/fs/nfs/nfs3proc.c
> @@ -140,6 +140,7 @@
>  	status = rpc_call_sync(NFS_CLIENT(inode), &msg, 0);
>  	if (status == 0)
>  		nfs_setattr_update_inode(inode, sattr, fattr);
> +		forget_all_cached_acls(inode);
>  	dprintk("NFS reply setattr: %d\n", status);
>  	return status;
>  }
> -- 
> 1.8.3.1
>
>
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-nfs" 
> in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
kernel test robot March 29, 2018, 10:07 a.m. UTC | #2
Hi chendt,

Thank you for the patch! Perhaps something to improve:

[auto build test WARNING on nfs/linux-next]
[also build test WARNING on v4.16-rc7 next-20180328]
[if your patch is applied to the wrong git tree, please drop us a note to help improve the system]

url:    https://github.com/0day-ci/linux/commits/chendt/NFSv3-acl-forget-acl-cache-after-setattr/20180329-173503
base:   git://git.linux-nfs.org/projects/trondmy/linux-nfs.git linux-next
config: x86_64-randconfig-x010-201812 (attached as .config)
compiler: gcc-7 (Debian 7.3.0-1) 7.3.0
reproduce:
        # save the attached .config to linux build tree
        make ARCH=x86_64 

All warnings (new ones prefixed by >>):

   fs/nfs/nfs3proc.c: In function 'nfs3_proc_setattr':
>> fs/nfs/nfs3proc.c:141:2: warning: this 'if' clause does not guard... [-Wmisleading-indentation]
     if (status == 0)
     ^~
   fs/nfs/nfs3proc.c:143:3: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'if'
      forget_all_cached_acls(inode);
      ^~~~~~~~~~~~~~~~~~~~~~

vim +/if +141 fs/nfs/nfs3proc.c

^1da177e Linus Torvalds  2005-04-16  119  
^1da177e Linus Torvalds  2005-04-16  120  static int
^1da177e Linus Torvalds  2005-04-16  121  nfs3_proc_setattr(struct dentry *dentry, struct nfs_fattr *fattr,
^1da177e Linus Torvalds  2005-04-16  122  			struct iattr *sattr)
^1da177e Linus Torvalds  2005-04-16  123  {
2b0143b5 David Howells   2015-03-17  124  	struct inode *inode = d_inode(dentry);
^1da177e Linus Torvalds  2005-04-16  125  	struct nfs3_sattrargs	arg = {
^1da177e Linus Torvalds  2005-04-16  126  		.fh		= NFS_FH(inode),
^1da177e Linus Torvalds  2005-04-16  127  		.sattr		= sattr,
^1da177e Linus Torvalds  2005-04-16  128  	};
dead28da Chuck Lever     2006-03-20  129  	struct rpc_message msg = {
dead28da Chuck Lever     2006-03-20  130  		.rpc_proc	= &nfs3_procedures[NFS3PROC_SETATTR],
dead28da Chuck Lever     2006-03-20  131  		.rpc_argp	= &arg,
dead28da Chuck Lever     2006-03-20  132  		.rpc_resp	= fattr,
dead28da Chuck Lever     2006-03-20  133  	};
^1da177e Linus Torvalds  2005-04-16  134  	int	status;
^1da177e Linus Torvalds  2005-04-16  135  
^1da177e Linus Torvalds  2005-04-16  136  	dprintk("NFS call  setattr\n");
659bfcd6 Trond Myklebust 2008-06-10  137  	if (sattr->ia_valid & ATTR_FILE)
659bfcd6 Trond Myklebust 2008-06-10  138  		msg.rpc_cred = nfs_file_cred(sattr->ia_file);
0e574af1 Trond Myklebust 2005-10-27  139  	nfs_fattr_init(fattr);
dead28da Chuck Lever     2006-03-20  140  	status = rpc_call_sync(NFS_CLIENT(inode), &msg, 0);
65e4308d Trond Myklebust 2005-08-16 @141  	if (status == 0)
f044636d Trond Myklebust 2015-02-26  142  		nfs_setattr_update_inode(inode, sattr, fattr);
34de94ef chendt          2018-03-28  143  		forget_all_cached_acls(inode);
^1da177e Linus Torvalds  2005-04-16  144  	dprintk("NFS reply setattr: %d\n", status);
^1da177e Linus Torvalds  2005-04-16  145  	return status;
^1da177e Linus Torvalds  2005-04-16  146  }
^1da177e Linus Torvalds  2005-04-16  147  

:::::: The code at line 141 was first introduced by commit
:::::: 65e4308d2500e7daf60c3dccc202c61ffb066c63 [PATCH] NFS: Ensure we always update inode->i_mode when doing O_EXCL creates

:::::: TO: Trond Myklebust <Trond.Myklebust@netapp.com>
:::::: CC: Linus Torvalds <torvalds@g5.osdl.org>

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation
kernel test robot March 29, 2018, 11:39 a.m. UTC | #3
Hi chendt,

Thank you for the patch! Perhaps something to improve:

[auto build test WARNING on nfs/linux-next]
[also build test WARNING on v4.16-rc7 next-20180328]
[if your patch is applied to the wrong git tree, please drop us a note to help improve the system]

url:    https://github.com/0day-ci/linux/commits/chendt/NFSv3-acl-forget-acl-cache-after-setattr/20180329-173503
base:   git://git.linux-nfs.org/projects/trondmy/linux-nfs.git linux-next
config: x86_64-randconfig-x019-201812 (attached as .config)
compiler: gcc-7 (Debian 7.3.0-1) 7.3.0
reproduce:
        # save the attached .config to linux build tree
        make ARCH=x86_64 

All warnings (new ones prefixed by >>):

   In file included from include/asm-generic/bug.h:5:0,
                    from arch/x86/include/asm/bug.h:83,
                    from include/linux/bug.h:5,
                    from include/linux/mmdebug.h:5,
                    from include/linux/mm.h:9,
                    from fs/nfs/nfs3proc.c:10:
   fs/nfs/nfs3proc.c: In function 'nfs3_proc_setattr':
   include/linux/compiler.h:58:2: warning: this 'if' clause does not guard... [-Wmisleading-indentation]
     if (__builtin_constant_p(!!(cond)) ? !!(cond) :   \
     ^
   include/linux/compiler.h:56:23: note: in expansion of macro '__trace_if'
    #define if(cond, ...) __trace_if( (cond , ## __VA_ARGS__) )
                          ^~~~~~~~~~
>> fs/nfs/nfs3proc.c:141:2: note: in expansion of macro 'if'
     if (status == 0)
     ^~
   fs/nfs/nfs3proc.c:143:3: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'if'
      forget_all_cached_acls(inode);
      ^~~~~~~~~~~~~~~~~~~~~~

vim +/if +141 fs/nfs/nfs3proc.c

^1da177e4 Linus Torvalds      2005-04-16  @10  #include <linux/mm.h>
^1da177e4 Linus Torvalds      2005-04-16   11  #include <linux/errno.h>
^1da177e4 Linus Torvalds      2005-04-16   12  #include <linux/string.h>
^1da177e4 Linus Torvalds      2005-04-16   13  #include <linux/sunrpc/clnt.h>
5a0e3ad6a Tejun Heo           2010-03-24   14  #include <linux/slab.h>
^1da177e4 Linus Torvalds      2005-04-16   15  #include <linux/nfs.h>
^1da177e4 Linus Torvalds      2005-04-16   16  #include <linux/nfs3.h>
^1da177e4 Linus Torvalds      2005-04-16   17  #include <linux/nfs_fs.h>
^1da177e4 Linus Torvalds      2005-04-16   18  #include <linux/nfs_page.h>
^1da177e4 Linus Torvalds      2005-04-16   19  #include <linux/lockd/bind.h>
b7fa0554c Andreas Gruenbacher 2005-06-22   20  #include <linux/nfs_mount.h>
d310310cb Jeff Layton         2011-12-01   21  #include <linux/freezer.h>
0a6be6555 Tejun Heo           2014-02-03   22  #include <linux/xattr.h>
^1da177e4 Linus Torvalds      2005-04-16   23  
006ea73e5 Chuck Lever         2006-03-20   24  #include "iostat.h"
f7b422b17 David Howells       2006-06-09   25  #include "internal.h"
00a36a109 Anna Schumaker      2014-09-03   26  #include "nfs3_fs.h"
006ea73e5 Chuck Lever         2006-03-20   27  
^1da177e4 Linus Torvalds      2005-04-16   28  #define NFSDBG_FACILITY		NFSDBG_PROC
^1da177e4 Linus Torvalds      2005-04-16   29  
eb96d5c97 Andy Adamson        2012-11-27   30  /* A wrapper to handle the EJUKEBOX error messages */
^1da177e4 Linus Torvalds      2005-04-16   31  static int
^1da177e4 Linus Torvalds      2005-04-16   32  nfs3_rpc_wrapper(struct rpc_clnt *clnt, struct rpc_message *msg, int flags)
^1da177e4 Linus Torvalds      2005-04-16   33  {
^1da177e4 Linus Torvalds      2005-04-16   34  	int res;
^1da177e4 Linus Torvalds      2005-04-16   35  	do {
^1da177e4 Linus Torvalds      2005-04-16   36  		res = rpc_call_sync(clnt, msg, flags);
eb96d5c97 Andy Adamson        2012-11-27   37  		if (res != -EJUKEBOX)
^1da177e4 Linus Torvalds      2005-04-16   38  			break;
416ad3c9c Colin Cross         2013-05-06   39  		freezable_schedule_timeout_killable_unsafe(NFS_JUKEBOX_RETRY_TIME);
^1da177e4 Linus Torvalds      2005-04-16   40  		res = -ERESTARTSYS;
150030b78 Matthew Wilcox      2007-12-06   41  	} while (!fatal_signal_pending(current));
^1da177e4 Linus Torvalds      2005-04-16   42  	return res;
^1da177e4 Linus Torvalds      2005-04-16   43  }
^1da177e4 Linus Torvalds      2005-04-16   44  
dead28da8 Chuck Lever         2006-03-20   45  #define rpc_call_sync(clnt, msg, flags)	nfs3_rpc_wrapper(clnt, msg, flags)
^1da177e4 Linus Torvalds      2005-04-16   46  
^1da177e4 Linus Torvalds      2005-04-16   47  static int
006ea73e5 Chuck Lever         2006-03-20   48  nfs3_async_handle_jukebox(struct rpc_task *task, struct inode *inode)
^1da177e4 Linus Torvalds      2005-04-16   49  {
eb96d5c97 Andy Adamson        2012-11-27   50  	if (task->tk_status != -EJUKEBOX)
^1da177e4 Linus Torvalds      2005-04-16   51  		return 0;
b68d69b8c Jeff Layton         2010-01-07   52  	if (task->tk_status == -EJUKEBOX)
006ea73e5 Chuck Lever         2006-03-20   53  		nfs_inc_stats(inode, NFSIOS_DELAY);
^1da177e4 Linus Torvalds      2005-04-16   54  	task->tk_status = 0;
^1da177e4 Linus Torvalds      2005-04-16   55  	rpc_restart_call(task);
^1da177e4 Linus Torvalds      2005-04-16   56  	rpc_delay(task, NFS_JUKEBOX_RETRY_TIME);
^1da177e4 Linus Torvalds      2005-04-16   57  	return 1;
^1da177e4 Linus Torvalds      2005-04-16   58  }
^1da177e4 Linus Torvalds      2005-04-16   59  
^1da177e4 Linus Torvalds      2005-04-16   60  static int
03c217339 J. Bruce Fields     2006-01-03   61  do_proc_get_root(struct rpc_clnt *client, struct nfs_fh *fhandle,
^1da177e4 Linus Torvalds      2005-04-16   62  		 struct nfs_fsinfo *info)
^1da177e4 Linus Torvalds      2005-04-16   63  {
dead28da8 Chuck Lever         2006-03-20   64  	struct rpc_message msg = {
dead28da8 Chuck Lever         2006-03-20   65  		.rpc_proc	= &nfs3_procedures[NFS3PROC_FSINFO],
dead28da8 Chuck Lever         2006-03-20   66  		.rpc_argp	= fhandle,
dead28da8 Chuck Lever         2006-03-20   67  		.rpc_resp	= info,
dead28da8 Chuck Lever         2006-03-20   68  	};
^1da177e4 Linus Torvalds      2005-04-16   69  	int	status;
^1da177e4 Linus Torvalds      2005-04-16   70  
3110ff804 Harvey Harrison     2008-05-02   71  	dprintk("%s: call  fsinfo\n", __func__);
0e574af1b Trond Myklebust     2005-10-27   72  	nfs_fattr_init(info->fattr);
dead28da8 Chuck Lever         2006-03-20   73  	status = rpc_call_sync(client, &msg, 0);
3110ff804 Harvey Harrison     2008-05-02   74  	dprintk("%s: reply fsinfo: %d\n", __func__, status);
086600430 Trond Myklebust     2012-08-20   75  	if (status == 0 && !(info->fattr->valid & NFS_ATTR_FATTR)) {
dead28da8 Chuck Lever         2006-03-20   76  		msg.rpc_proc = &nfs3_procedures[NFS3PROC_GETATTR];
dead28da8 Chuck Lever         2006-03-20   77  		msg.rpc_resp = info->fattr;
dead28da8 Chuck Lever         2006-03-20   78  		status = rpc_call_sync(client, &msg, 0);
3110ff804 Harvey Harrison     2008-05-02   79  		dprintk("%s: reply getattr: %d\n", __func__, status);
^1da177e4 Linus Torvalds      2005-04-16   80  	}
^1da177e4 Linus Torvalds      2005-04-16   81  	return status;
^1da177e4 Linus Torvalds      2005-04-16   82  }
^1da177e4 Linus Torvalds      2005-04-16   83  
^1da177e4 Linus Torvalds      2005-04-16   84  /*
54ceac451 David Howells       2006-08-22   85   * Bare-bones access to getattr: this is for nfs_get_root/nfs_get_sb
03c217339 J. Bruce Fields     2006-01-03   86   */
03c217339 J. Bruce Fields     2006-01-03   87  static int
03c217339 J. Bruce Fields     2006-01-03   88  nfs3_proc_get_root(struct nfs_server *server, struct nfs_fh *fhandle,
03c217339 J. Bruce Fields     2006-01-03   89  		   struct nfs_fsinfo *info)
03c217339 J. Bruce Fields     2006-01-03   90  {
03c217339 J. Bruce Fields     2006-01-03   91  	int	status;
03c217339 J. Bruce Fields     2006-01-03   92  
03c217339 J. Bruce Fields     2006-01-03   93  	status = do_proc_get_root(server->client, fhandle, info);
5006a76cc David Howells       2006-08-22   94  	if (status && server->nfs_client->cl_rpcclient != server->client)
5006a76cc David Howells       2006-08-22   95  		status = do_proc_get_root(server->nfs_client->cl_rpcclient, fhandle, info);
03c217339 J. Bruce Fields     2006-01-03   96  	return status;
03c217339 J. Bruce Fields     2006-01-03   97  }
03c217339 J. Bruce Fields     2006-01-03   98  
03c217339 J. Bruce Fields     2006-01-03   99  /*
^1da177e4 Linus Torvalds      2005-04-16  100   * One function for each procedure in the NFS protocol.
^1da177e4 Linus Torvalds      2005-04-16  101   */
^1da177e4 Linus Torvalds      2005-04-16  102  static int
^1da177e4 Linus Torvalds      2005-04-16  103  nfs3_proc_getattr(struct nfs_server *server, struct nfs_fh *fhandle,
1775fd3e8 David Quigley       2013-05-22  104  		struct nfs_fattr *fattr, struct nfs4_label *label)
^1da177e4 Linus Torvalds      2005-04-16  105  {
dead28da8 Chuck Lever         2006-03-20  106  	struct rpc_message msg = {
dead28da8 Chuck Lever         2006-03-20  107  		.rpc_proc	= &nfs3_procedures[NFS3PROC_GETATTR],
dead28da8 Chuck Lever         2006-03-20  108  		.rpc_argp	= fhandle,
dead28da8 Chuck Lever         2006-03-20  109  		.rpc_resp	= fattr,
dead28da8 Chuck Lever         2006-03-20  110  	};
^1da177e4 Linus Torvalds      2005-04-16  111  	int	status;
^1da177e4 Linus Torvalds      2005-04-16  112  
^1da177e4 Linus Torvalds      2005-04-16  113  	dprintk("NFS call  getattr\n");
0e574af1b Trond Myklebust     2005-10-27  114  	nfs_fattr_init(fattr);
dead28da8 Chuck Lever         2006-03-20  115  	status = rpc_call_sync(server->client, &msg, 0);
^1da177e4 Linus Torvalds      2005-04-16  116  	dprintk("NFS reply getattr: %d\n", status);
^1da177e4 Linus Torvalds      2005-04-16  117  	return status;
^1da177e4 Linus Torvalds      2005-04-16  118  }
^1da177e4 Linus Torvalds      2005-04-16  119  
^1da177e4 Linus Torvalds      2005-04-16  120  static int
^1da177e4 Linus Torvalds      2005-04-16  121  nfs3_proc_setattr(struct dentry *dentry, struct nfs_fattr *fattr,
^1da177e4 Linus Torvalds      2005-04-16  122  			struct iattr *sattr)
^1da177e4 Linus Torvalds      2005-04-16  123  {
2b0143b5c David Howells       2015-03-17  124  	struct inode *inode = d_inode(dentry);
^1da177e4 Linus Torvalds      2005-04-16  125  	struct nfs3_sattrargs	arg = {
^1da177e4 Linus Torvalds      2005-04-16  126  		.fh		= NFS_FH(inode),
^1da177e4 Linus Torvalds      2005-04-16  127  		.sattr		= sattr,
^1da177e4 Linus Torvalds      2005-04-16  128  	};
dead28da8 Chuck Lever         2006-03-20  129  	struct rpc_message msg = {
dead28da8 Chuck Lever         2006-03-20  130  		.rpc_proc	= &nfs3_procedures[NFS3PROC_SETATTR],
dead28da8 Chuck Lever         2006-03-20  131  		.rpc_argp	= &arg,
dead28da8 Chuck Lever         2006-03-20  132  		.rpc_resp	= fattr,
dead28da8 Chuck Lever         2006-03-20  133  	};
^1da177e4 Linus Torvalds      2005-04-16  134  	int	status;
^1da177e4 Linus Torvalds      2005-04-16  135  
^1da177e4 Linus Torvalds      2005-04-16  136  	dprintk("NFS call  setattr\n");
659bfcd6d Trond Myklebust     2008-06-10  137  	if (sattr->ia_valid & ATTR_FILE)
659bfcd6d Trond Myklebust     2008-06-10  138  		msg.rpc_cred = nfs_file_cred(sattr->ia_file);
0e574af1b Trond Myklebust     2005-10-27  139  	nfs_fattr_init(fattr);
dead28da8 Chuck Lever         2006-03-20  140  	status = rpc_call_sync(NFS_CLIENT(inode), &msg, 0);
65e4308d2 Trond Myklebust     2005-08-16 @141  	if (status == 0)
f044636d9 Trond Myklebust     2015-02-26  142  		nfs_setattr_update_inode(inode, sattr, fattr);
34de94ef5 chendt              2018-03-28  143  		forget_all_cached_acls(inode);
^1da177e4 Linus Torvalds      2005-04-16  144  	dprintk("NFS reply setattr: %d\n", status);
^1da177e4 Linus Torvalds      2005-04-16  145  	return status;
^1da177e4 Linus Torvalds      2005-04-16  146  }
^1da177e4 Linus Torvalds      2005-04-16  147  

:::::: The code at line 141 was first introduced by commit
:::::: 65e4308d2500e7daf60c3dccc202c61ffb066c63 [PATCH] NFS: Ensure we always update inode->i_mode when doing O_EXCL creates

:::::: TO: Trond Myklebust <Trond.Myklebust@netapp.com>
:::::: CC: Linus Torvalds <torvalds@g5.osdl.org>

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation
diff mbox

Patch

diff --git a/fs/nfs/nfs3proc.c b/fs/nfs/nfs3proc.c
index 7327930..ef3e17c 100644
--- a/fs/nfs/nfs3proc.c
+++ b/fs/nfs/nfs3proc.c
@@ -140,6 +140,7 @@ 
 	status = rpc_call_sync(NFS_CLIENT(inode), &msg, 0);
 	if (status == 0)
 		nfs_setattr_update_inode(inode, sattr, fattr);
+		forget_all_cached_acls(inode);
 	dprintk("NFS reply setattr: %d\n", status);
 	return status;
 }