Loading fs/nfs/dir.c +9 −9 Original line number Diff line number Diff line Loading @@ -2286,8 +2286,7 @@ static int nfs_access_get_cached(struct inode *inode, struct rpc_cred *cred, str if (cache == NULL) goto out; /* Found an entry, is our attribute cache valid? */ if (!nfs_attribute_cache_expired(inode) && !(nfsi->cache_validity & NFS_INO_INVALID_ATTR)) if (!nfs_check_cache_invalid(inode, NFS_INO_INVALID_ACCESS)) break; err = -ECHILD; if (!may_block) Loading Loading @@ -2335,12 +2334,12 @@ static int nfs_access_get_cached_rcu(struct inode *inode, struct rpc_cred *cred, cache = NULL; if (cache == NULL) goto out; err = nfs_revalidate_inode_rcu(NFS_SERVER(inode), inode); if (err) if (nfs_check_cache_invalid(inode, NFS_INO_INVALID_ACCESS)) goto out; res->jiffies = cache->jiffies; res->cred = cache->cred; res->mask = cache->mask; err = 0; out: rcu_read_unlock(); return err; Loading Loading @@ -2492,12 +2491,13 @@ EXPORT_SYMBOL_GPL(nfs_may_open); static int nfs_execute_ok(struct inode *inode, int mask) { struct nfs_server *server = NFS_SERVER(inode); int ret; int ret = 0; if (nfs_check_cache_invalid(inode, NFS_INO_INVALID_ACCESS)) { if (mask & MAY_NOT_BLOCK) ret = nfs_revalidate_inode_rcu(server, inode); else ret = nfs_revalidate_inode(server, inode); return -ECHILD; ret = __nfs_revalidate_inode(server, inode); } if (ret == 0 && !execute_ok(inode)) ret = -EACCES; return ret; Loading Loading
fs/nfs/dir.c +9 −9 Original line number Diff line number Diff line Loading @@ -2286,8 +2286,7 @@ static int nfs_access_get_cached(struct inode *inode, struct rpc_cred *cred, str if (cache == NULL) goto out; /* Found an entry, is our attribute cache valid? */ if (!nfs_attribute_cache_expired(inode) && !(nfsi->cache_validity & NFS_INO_INVALID_ATTR)) if (!nfs_check_cache_invalid(inode, NFS_INO_INVALID_ACCESS)) break; err = -ECHILD; if (!may_block) Loading Loading @@ -2335,12 +2334,12 @@ static int nfs_access_get_cached_rcu(struct inode *inode, struct rpc_cred *cred, cache = NULL; if (cache == NULL) goto out; err = nfs_revalidate_inode_rcu(NFS_SERVER(inode), inode); if (err) if (nfs_check_cache_invalid(inode, NFS_INO_INVALID_ACCESS)) goto out; res->jiffies = cache->jiffies; res->cred = cache->cred; res->mask = cache->mask; err = 0; out: rcu_read_unlock(); return err; Loading Loading @@ -2492,12 +2491,13 @@ EXPORT_SYMBOL_GPL(nfs_may_open); static int nfs_execute_ok(struct inode *inode, int mask) { struct nfs_server *server = NFS_SERVER(inode); int ret; int ret = 0; if (nfs_check_cache_invalid(inode, NFS_INO_INVALID_ACCESS)) { if (mask & MAY_NOT_BLOCK) ret = nfs_revalidate_inode_rcu(server, inode); else ret = nfs_revalidate_inode(server, inode); return -ECHILD; ret = __nfs_revalidate_inode(server, inode); } if (ret == 0 && !execute_ok(inode)) ret = -EACCES; return ret; Loading