commit cceaaa8161eb8b0b39854215417b39a9703b7aa5
parent 5a387cee873365069ad40201fa4d1c514476aa55
Author: jvoisin <julien.voisin@dustri.org>
Date: Mon, 21 Aug 2023 17:46:03 +0200
Harden umask
Diffstat:
3 files changed, 59 insertions(+), 0 deletions(-)
diff --git a/include/sys/stat.h b/include/sys/stat.h
@@ -0,0 +1,48 @@
+/*
+ * Copyright (C) 2015-2016 Dimitris Papastamos <sin@2f30.org>
+ * Copyright (C) 2022 q66 <q66@chimera-linux.org>
+ *
+ * Permission to use, copy, modify, and/or distribute this software for any
+ * purpose with or without fee is hereby granted.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+
+#ifndef _FORTIFY_SYS_STAT_H
+#define _FORTIFY_SYS_STAT_H
+
+#if !defined(__cplusplus) && !defined(__clang__)
+__extension__
+#endif
+#include_next <sys/stat.h>
+
+#if defined(_FORTIFY_SOURCE) && _FORTIFY_SOURCE > 0 && defined(__OPTIMIZE__) && __OPTIMIZE__ > 0
+#include "../fortify-headers.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#if !defined(__clang__) /* FIXME */
+#undef umask
+
+__error_if(__m & ~0777, "'umask' called with invalid mode")
+_FORTIFY_FN(umask) mode_t umask(mode_t __m)
+{
+ return __orig_umask(__m);
+}
+#endif
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
+
+#endif
diff --git a/tests/Makefile b/tests/Makefile
@@ -91,6 +91,7 @@ TARGETS= \
test_strrchr_static_read \
test_ttyname_r_dynamic \
test_ttyname_r_static \
+ test_umask \
test_vsnprintf_dynamic \
test_vsnprintf_static \
test_vsprintf \
diff --git a/tests/test_umask.c b/tests/test_umask.c
@@ -0,0 +1,10 @@
+#include "common.h"
+
+#include <sys/stat.h>
+
+int main(int argc, char** argv) {
+#if !defined(__clang__)
+ umask(0666);
+#endif
+ return ret;
+}