|
@@ -742,9 +742,14 @@ int nfs_attribute_timeout(struct inode *inode)
|
|
|
{
|
|
|
struct nfs_inode *nfsi = NFS_I(inode);
|
|
|
|
|
|
+ return !time_in_range_open(jiffies, nfsi->read_cache_jiffies, nfsi->read_cache_jiffies + nfsi->attrtimeo);
|
|
|
+}
|
|
|
+
|
|
|
+static int nfs_attribute_cache_expired(struct inode *inode)
|
|
|
+{
|
|
|
if (nfs_have_delegated_attributes(inode))
|
|
|
return 0;
|
|
|
- return !time_in_range_open(jiffies, nfsi->read_cache_jiffies, nfsi->read_cache_jiffies + nfsi->attrtimeo);
|
|
|
+ return nfs_attribute_timeout(inode);
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -757,7 +762,7 @@ int nfs_attribute_timeout(struct inode *inode)
|
|
|
int nfs_revalidate_inode(struct nfs_server *server, struct inode *inode)
|
|
|
{
|
|
|
if (!(NFS_I(inode)->cache_validity & NFS_INO_INVALID_ATTR)
|
|
|
- && !nfs_attribute_timeout(inode))
|
|
|
+ && !nfs_attribute_cache_expired(inode))
|
|
|
return NFS_STALE(inode) ? -ESTALE : 0;
|
|
|
return __nfs_revalidate_inode(server, inode);
|
|
|
}
|
|
@@ -794,7 +799,8 @@ int nfs_revalidate_mapping(struct inode *inode, struct address_space *mapping)
|
|
|
int ret = 0;
|
|
|
|
|
|
if ((nfsi->cache_validity & NFS_INO_REVAL_PAGECACHE)
|
|
|
- || nfs_attribute_timeout(inode) || NFS_STALE(inode)) {
|
|
|
+ || nfs_attribute_cache_expired(inode)
|
|
|
+ || NFS_STALE(inode)) {
|
|
|
ret = __nfs_revalidate_inode(NFS_SERVER(inode), inode);
|
|
|
if (ret < 0)
|
|
|
goto out;
|