From: Mark Wielaard Date: Sat, 13 Feb 2016 18:10:00 +0000 (+0100) Subject: config: Check for and use gcc -Wnull-dereference. X-Git-Tag: elfutils-0.166~13 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=6993d408fac1ff9aa23281cb6ab010920f7d624c;p=thirdparty%2Felfutils.git config: Check for and use gcc -Wnull-dereference. -Wnull-dereference is new in GCC6 Signed-off-by: Mark Wielaard --- diff --git a/ChangeLog b/ChangeLog index dce61adf5..07b525c38 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +2016-02-13 Mark Wielaard + + * configure.ac: Add check for whether gcc accepts -Wnull-dereference. + 2016-02-08 Mark Wielaard * configure.ac: Add checks for sane -Wlogical-op and whether gcc diff --git a/config/ChangeLog b/config/ChangeLog index 8523cb317..494778a42 100644 --- a/config/ChangeLog +++ b/config/ChangeLog @@ -1,3 +1,8 @@ +2016-02-13 Mark Wielaard + + * eu.am: Check HAVE_NULL_DEREFERENCE_WARNING. + (AM_CFLAGS): Add NULL_DEREFERENCE_WARNING. + 2016-02-09 Mark Wielaard * eu.am: Check SANE_LOGICAL_OP_WARNING and diff --git a/config/eu.am b/config/eu.am index c4e9279ad..4998771dc 100644 --- a/config/eu.am +++ b/config/eu.am @@ -55,9 +55,16 @@ else DUPLICATED_COND_WARNING= endif +if HAVE_NULL_DEREFERENCE_WARNING +NULL_DEREFERENCE_WARNING=-Wnull-dereference +else +NULL_DEREFERENCE_WARNING= +endif + AM_CFLAGS = -std=gnu99 -Wall -Wshadow -Wformat=2 \ -Wold-style-definition -Wstrict-prototypes \ $(LOGICAL_OP_WARNING) $(DUPLICATED_COND_WARNING) \ + $(NULL_DEREFERENCE_WARNING) \ $(if $($(*F)_no_Werror),,-Werror) \ $(if $($(*F)_no_Wunused),,-Wunused -Wextra) \ $(if $($(*F)_no_Wstack_usage),,$(STACK_USAGE_WARNING)) \ diff --git a/configure.ac b/configure.ac index d447db7e1..df58b5b9a 100644 --- a/configure.ac +++ b/configure.ac @@ -313,6 +313,16 @@ CFLAGS="$old_CFLAGS"]) AM_CONDITIONAL(HAVE_DUPLICATED_COND_WARNING, [test "x$ac_cv_duplicated_cond" != "xno"]) +# -Wnull-dereference was added by GCC6 +AC_CACHE_CHECK([whether gcc accepts -Wnull-dereference], ac_cv_null_dereference, [dnl +old_CFLAGS="$CFLAGS" +CFLAGS="$CFLAGS -Wnull-dereference" +AC_COMPILE_IFELSE([AC_LANG_SOURCE([])], + ac_cv_null_dereference=yes, ac_cv_null_dereference=no) +CFLAGS="$old_CFLAGS"]) +AM_CONDITIONAL(HAVE_NULL_DEREFERENCE_WARNING, + [test "x$ac_cv_null_dereference" != "xno"]) + dnl Check if we have argp available from our libc AC_LINK_IFELSE( [AC_LANG_PROGRAM(