diff options
Diffstat (limited to 'main/fortify-headers')
-rw-r--r-- | main/fortify-headers/0001-Only-include-limits.h-when-actually-used.patch | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/main/fortify-headers/0001-Only-include-limits.h-when-actually-used.patch b/main/fortify-headers/0001-Only-include-limits.h-when-actually-used.patch new file mode 100644 index 0000000000..2093e98a33 --- /dev/null +++ b/main/fortify-headers/0001-Only-include-limits.h-when-actually-used.patch @@ -0,0 +1,43 @@ +From a1445561442c19f2354b31ea4ac0084d2bd3b34f Mon Sep 17 00:00:00 2001 +From: Natanael Copa <ncopa@alpinelinux.org> +Date: Thu, 14 Jul 2016 16:33:29 +0200 +Subject: [PATCH] Only include limits.h when actually used + +The __extension__ seems to trigger a bug in gcc when there are no +identifier specified afterwards. + +Testcase: + echo "#include <stdlib.h>" > try.c && cc -O0 -c try.c + try.c:2:0: error: expected identifier or '(' at end of input + +With -O2 it does not happen. + +We work around this by only pulling in limits.h when we actually need the +PATH_MAX. + +Signed-off-by: Natanael Copa <ncopa@alpinelinux.org> +--- + include/stdlib.h | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +diff --git a/include/stdlib.h b/include/stdlib.h +index 26c7e44..0717e81 100644 +--- a/include/stdlib.h ++++ b/include/stdlib.h +@@ -19,12 +19,12 @@ + __extension__ + #include_next <stdlib.h> + ++#if defined(_FORTIFY_SOURCE) && _FORTIFY_SOURCE > 0 && defined(__OPTIMIZE__) && __OPTIMIZE__ > 0 + #if defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) || defined(_BSD_SOURCE) + __extension__ + #include_next <limits.h> + #endif + +-#if defined(_FORTIFY_SOURCE) && _FORTIFY_SOURCE > 0 && defined(__OPTIMIZE__) && __OPTIMIZE__ > 0 + #include "fortify-headers.h" + + #ifdef __cplusplus +-- +2.9.0 + |