fortify-headers

standalone fortify-source implementation
git clone git://git.2f30.org/fortify-headers
Log | Files | Refs | README | LICENSE

commit cceaaa8161eb8b0b39854215417b39a9703b7aa5
parent 5a387cee873365069ad40201fa4d1c514476aa55
Author: jvoisin <julien.voisin@dustri.org>
Date:   Mon, 21 Aug 2023 17:46:03 +0200

Harden umask

Diffstat:
Ainclude/sys/stat.h | 48++++++++++++++++++++++++++++++++++++++++++++++++
Mtests/Makefile | 1+
Atests/test_umask.c | 10++++++++++
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; +}