mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-24 14:00:30 +00:00
scripts: Add fortify checks on installed headers
The _FORTIFY_SOURCE is used as default by some system compilers, and there is no way to check if some fortify extension does not trigger any conformance issue. Checked on x86_64-linux-gnu. Reviewed-by: Carlos O'Donell <carlos@redhat.com>
This commit is contained in:
parent
6d457ff36a
commit
30379efad1
@ -29,6 +29,9 @@ cxx_modes="-std=c++98 -std=gnu++98 -std=c++11 -std=gnu++11"
|
||||
# These are probably the most commonly used three.
|
||||
lib_modes="-D_DEFAULT_SOURCE=1 -D_GNU_SOURCE=1 -D_XOPEN_SOURCE=700"
|
||||
|
||||
# Also check for fortify modes, since it might be enabled as default.
|
||||
fortify_modes="1 2 3"
|
||||
|
||||
if [ $# -lt 3 ]; then
|
||||
echo "usage: $0 c|c++ \"compile command\" header header header..." >&2
|
||||
exit 2
|
||||
@ -100,18 +103,24 @@ EOF
|
||||
echo :: "$header"
|
||||
for lang_mode in "" $lang_modes; do
|
||||
for lib_mode in "" $lib_modes; do
|
||||
echo :::: $lang_mode $lib_mode
|
||||
for fortify_mode in "" $fortify_modes; do
|
||||
echo :::: $lang_mode $lib_mode $fortify_mode
|
||||
if [ -z "$lib_mode" ]; then
|
||||
expanded_lib_mode='/* default library mode */'
|
||||
else
|
||||
expanded_lib_mode=$(echo : $lib_mode | \
|
||||
sed 's/^: -D/#define /; s/=/ /')
|
||||
fi
|
||||
if [ ! -z $fortify_mode ]; then
|
||||
fortify_mode="#define _FORTIFY_SOURCE $fortify_mode"
|
||||
fi
|
||||
cat >"$cih_test_c" <<EOF
|
||||
/* These macros may have been defined on the command line. They are
|
||||
inappropriate for this test. */
|
||||
#undef _LIBC
|
||||
#undef _GNU_SOURCE
|
||||
#undef _FORTIFY_SOURCE
|
||||
$fortify_mode
|
||||
/* The library mode is selected here rather than on the command line to
|
||||
ensure that this selection wins. */
|
||||
$expanded_lib_mode
|
||||
@ -126,4 +135,5 @@ EOF
|
||||
done
|
||||
done
|
||||
done
|
||||
done
|
||||
exit $failed
|
||||
|
Loading…
Reference in New Issue
Block a user