From: Miklos Szeredi mszeredi@redhat.com
commit df8629af293493757beccac2d3168fe5a315636e upstream.
Failure to do so may result in EEXIST even if the file only exists in the cache and not in the filesystem.
The atomic nature of O_EXCL mandates that the cached state should be ignored and existence verified anew.
Change-Id: I0f173de6f9f1af05d6e816246b5c56b670ec079c Reported-by: Ken Schalk kschalk@nvidia.com Signed-off-by: Miklos Szeredi mszeredi@redhat.com Signed-off-by: Wu Bo bo.wu@vivo.com --- fs/fuse/dir.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/fs/fuse/dir.c b/fs/fuse/dir.c index 8e95a75a4559..80a9e50392a0 100644 --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c @@ -205,7 +205,7 @@ static int fuse_dentry_revalidate(struct dentry *entry, unsigned int flags) if (inode && fuse_is_bad(inode)) goto invalid; else if (time_before64(fuse_dentry_time(entry), get_jiffies_64()) || - (flags & LOOKUP_REVAL)) { + (flags & (LOOKUP_EXCL | LOOKUP_REVAL))) { struct fuse_entry_out outarg; FUSE_ARGS(args); struct fuse_forget_link *forget;
On Thu, Dec 15, 2022 at 05:34:08PM +0800, Wu Bo wrote:
From: Miklos Szeredi mszeredi@redhat.com
commit df8629af293493757beccac2d3168fe5a315636e upstream.
Failure to do so may result in EEXIST even if the file only exists in the cache and not in the filesystem.
The atomic nature of O_EXCL mandates that the cached state should be ignored and existence verified anew.
Change-Id: I0f173de6f9f1af05d6e816246b5c56b670ec079c
Where did this change-id come from?
thanks,
greg k-h
linux-stable-mirror@lists.linaro.org