Message ID | 20210812054618.26057-2-jefflexu@linux.alibaba.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | virtiofs: miscellaneous fixes | expand |
On Thu, 12 Aug 2021 at 07:46, Jeffle Xu <jefflexu@linux.alibaba.com> wrote: > > From: Liu Bo <bo.liu@linux.alibaba.com> > > When 'no_open' is used by virtiofsd, guest kernel won't send OPEN request > any more. However, with atomic_o_trunc, SETATTR request is also omitted in > OPEN(O_TRUNC) so that the backend file is not truncated. With a following > GETATTR, inode size on guest side is updated to be same with that on host > side, the end result is that O_TRUNC semantic is broken. > > This disables atomic_o_trunc as well if with no_open. I don't quite get it why one would want to enable atomic_o_trunc with no_open in the first place? Thanks, Miklos
On 9/7/21 4:34 PM, Miklos Szeredi wrote: > On Thu, 12 Aug 2021 at 07:46, Jeffle Xu <jefflexu@linux.alibaba.com> wrote: >> >> From: Liu Bo <bo.liu@linux.alibaba.com> >> >> When 'no_open' is used by virtiofsd, guest kernel won't send OPEN request >> any more. However, with atomic_o_trunc, SETATTR request is also omitted in >> OPEN(O_TRUNC) so that the backend file is not truncated. With a following >> GETATTR, inode size on guest side is updated to be same with that on host >> side, the end result is that O_TRUNC semantic is broken. >> >> This disables atomic_o_trunc as well if with no_open. > > I don't quite get it why one would want to enable atomic_o_trunc with > no_open in the first place? Oops..We didn't realize that it could also be worked around by fuse daemon side. Please ignore this.
diff --git a/fs/fuse/file.c b/fs/fuse/file.c index b494ff08f08c..1231128f8dd6 100644 --- a/fs/fuse/file.c +++ b/fs/fuse/file.c @@ -151,10 +151,16 @@ struct fuse_file *fuse_file_open(struct fuse_mount *fm, u64 nodeid, fuse_file_free(ff); return ERR_PTR(err); } else { - if (isdir) + if (isdir) { fc->no_opendir = 1; - else + } else { fc->no_open = 1; + /* + * In case of no_open, disable atomic_o_trunc as + * well. + */ + fc->atomic_o_trunc = 0; + } } }