diff options
author | Miklos Szeredi <miklos@szeredi.hu> | 2001-11-16 21:40:00 +0000 |
---|---|---|
committer | Miklos Szeredi <miklos@szeredi.hu> | 2001-11-16 21:40:00 +0000 |
commit | 4c749295c233ceaa91b53c816eb4ad3ccfee4748 (patch) | |
tree | 116ecf0a75643e389440dff9ee97c062b588aa7b /kernel/dir.c | |
parent | 66aeb510efbf3d6d46e5848be53162c156ee27a6 (diff) | |
download | libfuse-4c749295c233ceaa91b53c816eb4ad3ccfee4748.tar.gz |
fixes in kernel module
Diffstat (limited to 'kernel/dir.c')
-rw-r--r-- | kernel/dir.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/kernel/dir.c b/kernel/dir.c index 8c60afa..537b71c 100644 --- a/kernel/dir.c +++ b/kernel/dir.c @@ -545,7 +545,10 @@ static int fuse_dentry_revalidate(struct dentry *entry, int flags) { if(!entry->d_inode) return 0; - else if(!(flags & LOOKUP_CONTINUE)) + /* Must not revaidate too soon, since kernel revalidate logic is + broken, and could return ENOENT */ + else if(!(flags & LOOKUP_CONTINUE) && + time_after(jiffies, entry->d_time + FUSE_REVALIDATE_TIME)) return 0; else return 1; |