Commit f73016b6 authored by Bernd Schubert's avatar Bernd Schubert Committed by Miklos Szeredi

fuse: conditionally fill kstat in fuse_do_statx()

The code path

fuse_update_attributes
    fuse_update_get_attr
        fuse_do_statx

has the risk to use a NULL pointer for struct kstat *stat, although current
callers of fuse_update_attributes() only set request_mask to values that
will trigger the call of fuse_do_getattr(), which already handles the NULL
pointer.  Future updates might miss that fuse_do_statx() does not handle it
it is safer to add a condition already right now.
Signed-off-by: default avatarBernd Schubert <bschubert@ddn.com>
Fixes: d3045530 ("fuse: implement statx")
Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
parent 7d875e66
...@@ -1219,11 +1219,14 @@ static int fuse_do_statx(struct inode *inode, struct file *file, ...@@ -1219,11 +1219,14 @@ static int fuse_do_statx(struct inode *inode, struct file *file,
fuse_change_attributes(inode, &attr, &outarg.stat, fuse_change_attributes(inode, &attr, &outarg.stat,
ATTR_TIMEOUT(&outarg), attr_version); ATTR_TIMEOUT(&outarg), attr_version);
} }
stat->result_mask = sx->mask & (STATX_BASIC_STATS | STATX_BTIME);
stat->btime.tv_sec = sx->btime.tv_sec; if (stat) {
stat->btime.tv_nsec = min_t(u32, sx->btime.tv_nsec, NSEC_PER_SEC - 1); stat->result_mask = sx->mask & (STATX_BASIC_STATS | STATX_BTIME);
fuse_fillattr(inode, &attr, stat); stat->btime.tv_sec = sx->btime.tv_sec;
stat->result_mask |= STATX_TYPE; stat->btime.tv_nsec = min_t(u32, sx->btime.tv_nsec, NSEC_PER_SEC - 1);
fuse_fillattr(inode, &attr, stat);
stat->result_mask |= STATX_TYPE;
}
return 0; return 0;
} }
......
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