[libc-commits] [libc] [libc] Fix statfs_to_statvfs conversion function on rv32 (PR #98098)
Mikhail R. Gadelha via libc-commits
libc-commits at lists.llvm.org
Mon Jul 8 16:31:52 PDT 2024
https://github.com/mikhailramalho created https://github.com/llvm/llvm-project/pull/98098
This patch fixes implicit conversion loses integer precision warnings by adding explicit casts. Should be NFC for 64-bit systems.
>From 788ceb83927b7835bed9dce7b831044898b10a57 Mon Sep 17 00:00:00 2001
From: "Mikhail R. Gadelha" <mikhail at igalia.com>
Date: Mon, 8 Jul 2024 20:28:31 -0300
Subject: [PATCH] [libc] Fix statfs_to_statvfs conversion function on rv32
This patch fixes implicit conversion loses integer precision warnings by
adding explicit casts. Should be NFC for 64-bit systems.
---
libc/src/sys/statvfs/linux/statfs_utils.h | 17 +++++++++--------
1 file changed, 9 insertions(+), 8 deletions(-)
diff --git a/libc/src/sys/statvfs/linux/statfs_utils.h b/libc/src/sys/statvfs/linux/statfs_utils.h
index 606786a571838..52f810d702d2a 100644
--- a/libc/src/sys/statvfs/linux/statfs_utils.h
+++ b/libc/src/sys/statvfs/linux/statfs_utils.h
@@ -77,14 +77,15 @@ LIBC_INLINE struct statvfs statfs_to_statvfs(const LinuxStatFs &in) {
struct statvfs out;
out.f_bsize = in.f_bsize;
out.f_frsize = in.f_frsize;
- out.f_blocks = in.f_blocks;
- out.f_bfree = in.f_bfree;
- out.f_bavail = in.f_bavail;
- out.f_files = in.f_files;
- out.f_ffree = in.f_ffree;
- out.f_favail = in.f_ffree;
- out.f_fsid = in.f_fsid.val[0] |
- static_cast<decltype(out.f_fsid)>(in.f_fsid.val[1]) << 32;
+ out.f_blocks = static_cast<decltype(out.f_blocks)>(in.f_blocks);
+ out.f_bfree = static_cast<decltype(out.f_bfree)>(in.f_bfree);
+ out.f_bavail = static_cast<decltype(out.f_bavail)>(in.f_bavail);
+ out.f_files = static_cast<decltype(out.f_files)>(in.f_files);
+ out.f_ffree = static_cast<decltype(out.f_ffree)>(in.f_ffree);
+ out.f_favail = static_cast<decltype(out.f_favail)>(in.f_ffree);
+ out.f_fsid = in.f_fsid.val[0];
+ if constexpr (sizeof(decltype(out.f_fsid)) == sizeof(uint64_t))
+ out.f_fsid |= static_cast<decltype(out.f_fsid)>(in.f_fsid.val[1]) << 32;
out.f_flag = in.f_flags;
out.f_namemax = in.f_namelen;
return out;
More information about the libc-commits
mailing list