]> www.infradead.org Git - users/hch/xfs.git/commitdiff
fs/stat.c: avoid harmless garbage value problem in vfs_statx_path()
authorSu Hui <suhui@nfschina.com>
Sun, 19 Jan 2025 02:59:47 +0000 (10:59 +0800)
committerChristian Brauner <brauner@kernel.org>
Fri, 7 Feb 2025 09:27:24 +0000 (10:27 +0100)
Clang static checker(scan-build) warning:
fs/stat.c:287:21: warning: The left expression of the compound assignment is
an uninitialized value. The computed value will also be garbage.
  287 |                 stat->result_mask |= STATX_MNT_ID_UNIQUE;
      |                 ~~~~~~~~~~~~~~~~~ ^
fs/stat.c:290:21: warning: The left expression of the compound assignment is
an uninitialized value. The computed value will also be garbage.
  290 |                 stat->result_mask |= STATX_MNT_ID;

When vfs_getattr() failed because of security_inode_getattr(), 'stat' is
uninitialized. In this case, there is a harmless garbage problem in
vfs_statx_path(). It's better to return error directly when
vfs_getattr() failed, avoiding garbage value and more clearly.

Signed-off-by: Su Hui <suhui@nfschina.com>
Link: https://lore.kernel.org/r/20250119025946.1168957-1-suhui@nfschina.com
Signed-off-by: Christian Brauner <brauner@kernel.org>
fs/stat.c

index 2c0e111a098a1ec99b93dae6d90ad786da6571ec..f13308bfdc983a1670f83ec23f235c17fb19adfc 100644 (file)
--- a/fs/stat.c
+++ b/fs/stat.c
@@ -281,6 +281,8 @@ static int vfs_statx_path(struct path *path, int flags, struct kstat *stat,
                          u32 request_mask)
 {
        int error = vfs_getattr(path, stat, request_mask, flags);
+       if (error)
+               return error;
 
        if (request_mask & STATX_MNT_ID_UNIQUE) {
                stat->mnt_id = real_mount(path->mnt)->mnt_id_unique;
@@ -302,7 +304,7 @@ static int vfs_statx_path(struct path *path, int flags, struct kstat *stat,
        if (S_ISBLK(stat->mode))
                bdev_statx(path, stat, request_mask);
 
-       return error;
+       return 0;
 }
 
 static int vfs_statx_fd(int fd, int flags, struct kstat *stat,