Commit bf5c1898 authored by Miklos Szeredi's avatar Miklos Szeredi

fuse: honor AT_STATX_FORCE_SYNC

Force a refresh of attributes from the fuse server in this case.
Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
parent ff1b89f3
...@@ -928,9 +928,16 @@ static int fuse_update_get_attr(struct inode *inode, struct file *file, ...@@ -928,9 +928,16 @@ static int fuse_update_get_attr(struct inode *inode, struct file *file,
{ {
struct fuse_inode *fi = get_fuse_inode(inode); struct fuse_inode *fi = get_fuse_inode(inode);
int err = 0; int err = 0;
bool sync;
if (!(flags & AT_STATX_DONT_SYNC) && if (flags & AT_STATX_FORCE_SYNC)
time_before64(fi->i_time, get_jiffies_64())) { sync = true;
else if (flags & AT_STATX_DONT_SYNC)
sync = false;
else
sync = time_before64(fi->i_time, get_jiffies_64());
if (sync) {
forget_all_cached_acls(inode); forget_all_cached_acls(inode);
err = fuse_do_getattr(inode, stat, file); err = fuse_do_getattr(inode, stat, file);
} else if (stat) { } else if (stat) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment