[libc-commits] [libc] [libc] Pull more definitions from linux/stat.h (PR #67071)
Jeff Bailey via libc-commits
libc-commits at lists.llvm.org
Thu Sep 21 16:32:13 PDT 2023
https://github.com/kaladron updated https://github.com/llvm/llvm-project/pull/67071
>From 822312d19d7bb73e0dfbe54ea32ac8469d5a930a Mon Sep 17 00:00:00 2001
From: Jeff Bailey <jeffbailey at google.com>
Date: Thu, 21 Sep 2023 23:10:45 +0000
Subject: [PATCH 1/2] [libc] Pull more definitions from linux/stat.h
For file handling, we need more definitions from
linux/stat.h, so this pulls them in. It also adjusts other
definitions to match the kernel's exactly [NFC] so that it's easy to
verify that there's been no divergence one day when it's time to use
linux/stat.h directly.
Tested:
check-libc
---
.../llvm-libc-macros/linux/sys-stat-macros.h | 55 ++++++++++++++-----
1 file changed, 40 insertions(+), 15 deletions(-)
diff --git a/libc/include/llvm-libc-macros/linux/sys-stat-macros.h b/libc/include/llvm-libc-macros/linux/sys-stat-macros.h
index 59f29e80a31ab41..a0c72c39287d2d8 100644
--- a/libc/include/llvm-libc-macros/linux/sys-stat-macros.h
+++ b/libc/include/llvm-libc-macros/linux/sys-stat-macros.h
@@ -9,20 +9,45 @@
#ifndef __LLVM_LIBC_MACROS_LINUX_SYS_STAT_MACROS_H
#define __LLVM_LIBC_MACROS_LINUX_SYS_STAT_MACROS_H
-// File mode flags
-#define S_IRWXU 0700
-#define S_IRUSR 0400
-#define S_IWUSR 0200
-#define S_IXUSR 0100
-#define S_IRWXG 070
-#define S_IRGRP 040
-#define S_IWGRP 020
-#define S_IXGRP 010
-#define S_IRWXO 07
-#define S_IROTH 04
-#define S_IWOTH 02
-#define S_IXOTH 01
-#define S_ISUID 04000
-#define S_ISGID 02000
+// Definitions from linux/stat.h
+#define S_IFMT 00170000
+#define S_IFSOCK 0140000
+#define S_IFLNK 0120000
+#define S_IFREG 0100000
+#define S_IFBLK 0060000
+#define S_IFDIR 0040000
+#define S_IFCHR 0020000
+#define S_IFIFO 0010000
+#define S_ISUID 0004000
+#define S_ISGID 0002000
+#define S_ISVTX 0001000
+
+#define S_ISLNK(m) (((m) & S_IFMT) == S_IFLNK)
+#define S_ISREG(m) (((m) & S_IFMT) == S_IFREG)
+#define S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR)
+#define S_ISCHR(m) (((m) & S_IFMT) == S_IFCHR)
+#define S_ISBLK(m) (((m) & S_IFMT) == S_IFBLK)
+#define S_ISFIFO(m) (((m) & S_IFMT) == S_IFIFO)
+#define S_ISSOCK(m) (((m) & S_IFMT) == S_IFSOCK)
+
+#define S_IRWXU 00700
+#define S_IRUSR 00400
+#define S_IWUSR 00200
+#define S_IXUSR 00100
+
+#define S_IRWXG 00070
+#define S_IRGRP 00040
+#define S_IWGRP 00020
+#define S_IXGRP 00010
+
+#define S_IRWXU 00700
+#define S_IRUSR 00400
+#define S_IWUSR 00200
+#define S_IXUSR 00100
+
+#define S_IRWXG 00070
+#define S_IRGRP 00040
+#define S_IWGRP 00020
+#define S_IXGRP 00010
#endif // __LLVM_LIBC_MACROS_LINUX_SYS_STAT_MACROS_H
>From 17a4419938a5a6fcf7f750317e5d6d4b816377f0 Mon Sep 17 00:00:00 2001
From: Jeff Bailey <jeffbailey at google.com>
Date: Thu, 21 Sep 2023 23:32:01 +0000
Subject: [PATCH 2/2] Remove accidentally duplicated includes.
---
libc/include/llvm-libc-macros/linux/sys-stat-macros.h | 10 ----------
1 file changed, 10 deletions(-)
diff --git a/libc/include/llvm-libc-macros/linux/sys-stat-macros.h b/libc/include/llvm-libc-macros/linux/sys-stat-macros.h
index a0c72c39287d2d8..b622165738f1174 100644
--- a/libc/include/llvm-libc-macros/linux/sys-stat-macros.h
+++ b/libc/include/llvm-libc-macros/linux/sys-stat-macros.h
@@ -40,14 +40,4 @@
#define S_IWGRP 00020
#define S_IXGRP 00010
-#define S_IRWXU 00700
-#define S_IRUSR 00400
-#define S_IWUSR 00200
-#define S_IXUSR 00100
-
-#define S_IRWXG 00070
-#define S_IRGRP 00040
-#define S_IWGRP 00020
-#define S_IXGRP 00010
-
#endif // __LLVM_LIBC_MACROS_LINUX_SYS_STAT_MACROS_H
More information about the libc-commits
mailing list