OSDN Git Service

NFSv4: Fix nfs4_inode_make_writeable()
authorTrond Myklebust <trond.myklebust@hammerspace.com>
Sun, 27 Oct 2019 17:48:18 +0000 (13:48 -0400)
committerTrond Myklebust <trond.myklebust@hammerspace.com>
Mon, 4 Nov 2019 02:28:46 +0000 (21:28 -0500)
Fix the checks in nfs4_inode_make_writeable() to ignore the case where
we hold no delegations. Currently, in such a case, we automatically
flush writes.

Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
fs/nfs/delegation.c

index 78df1cd..e3d8055 100644 (file)
@@ -644,10 +644,18 @@ int nfs4_inode_return_delegation(struct inode *inode)
  */
 int nfs4_inode_make_writeable(struct inode *inode)
 {
-       if (!nfs4_has_session(NFS_SERVER(inode)->nfs_client) ||
-           !nfs4_check_delegation(inode, FMODE_WRITE))
-               return nfs4_inode_return_delegation(inode);
-       return 0;
+       struct nfs_delegation *delegation;
+
+       rcu_read_lock();
+       delegation = nfs4_get_valid_delegation(inode);
+       if (delegation == NULL ||
+           (nfs4_has_session(NFS_SERVER(inode)->nfs_client) &&
+            (delegation->type & FMODE_WRITE))) {
+               rcu_read_unlock();
+               return 0;
+       }
+       rcu_read_unlock();
+       return nfs4_inode_return_delegation(inode);
 }
 
 static void nfs_mark_return_if_closed_delegation(struct nfs_server *server,