NFS: Fix incorrect mapping revalidation when holding a delegation

We should only care about checking the attributes if the page cache
is marked as dubious (using NFS_INO_REVAL_PAGECACHE) and the
NFS_INO_REVAL_FORCED flag is set.
Signed-off-by: NTrond Myklebust <trond.myklebust@primarydata.com>
上级 230bc962
...@@ -1114,9 +1114,15 @@ static int nfs_invalidate_mapping(struct inode *inode, struct address_space *map ...@@ -1114,9 +1114,15 @@ static int nfs_invalidate_mapping(struct inode *inode, struct address_space *map
static bool nfs_mapping_need_revalidate_inode(struct inode *inode) static bool nfs_mapping_need_revalidate_inode(struct inode *inode)
{ {
if (nfs_have_delegated_attributes(inode)) unsigned long cache_validity = NFS_I(inode)->cache_validity;
return false;
return (NFS_I(inode)->cache_validity & NFS_INO_REVAL_PAGECACHE) if (NFS_PROTO(inode)->have_delegation(inode, FMODE_READ)) {
const unsigned long force_reval =
NFS_INO_REVAL_PAGECACHE|NFS_INO_REVAL_FORCED;
return (cache_validity & force_reval) == force_reval;
}
return (cache_validity & NFS_INO_REVAL_PAGECACHE)
|| nfs_attribute_timeout(inode) || nfs_attribute_timeout(inode)
|| NFS_STALE(inode); || NFS_STALE(inode);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部