Commit 3887ce1a authored by Trond Myklebust's avatar Trond Myklebust

NFSv4: Fix nfs4_inode_make_writeable()

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: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
parent 40e6aa10
...@@ -644,10 +644,18 @@ int nfs4_inode_return_delegation(struct inode *inode) ...@@ -644,10 +644,18 @@ int nfs4_inode_return_delegation(struct inode *inode)
*/ */
int nfs4_inode_make_writeable(struct inode *inode) int nfs4_inode_make_writeable(struct inode *inode)
{ {
if (!nfs4_has_session(NFS_SERVER(inode)->nfs_client) || struct nfs_delegation *delegation;
!nfs4_check_delegation(inode, FMODE_WRITE))
return nfs4_inode_return_delegation(inode); 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; return 0;
}
rcu_read_unlock();
return nfs4_inode_return_delegation(inode);
} }
static void nfs_mark_return_if_closed_delegation(struct nfs_server *server, static void nfs_mark_return_if_closed_delegation(struct nfs_server *server,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment