From aa3c85dc48617dbdb565d33b294cad2931b5ac73 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Fri, 1 May 2015 20:09:33 +0300 Subject: Add extended sanitify flags. Configure option: --enable-sanitize=full --- configure.in | 25 +++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/configure.in b/configure.in index 1f2001981..3b5420c8b 100644 --- a/configure.in +++ b/configure.in @@ -300,9 +300,9 @@ AC_ARG_ENABLE( AC_ARG_ENABLE( [sanitize], AC_HELP_STRING( - [--enable-sanitize], + [--enable-sanitize@<:@=ARG@:>@], [ - Enables or Disables Sanitize Address Checking (SANITIZE is disabled by default) + Sanitize: yes, no, full) ] ), [ @@ -310,6 +310,7 @@ AC_ARG_ENABLE( case $enableval in "no");; "yes");; + "full");; *) AC_MSG_ERROR([[invalid argument --enable-sanitize=$disableval... stopping]]);; esac ], @@ -625,14 +626,25 @@ fi # sanitize Support test # if test "$enable_sanitize" != "no" ; then + if test "$enable_sanitize" == "full" ; then + # skipped because server have multiply issues -fsanitize=alignment + SAN="-fsanitize=address \ +-fsanitize=shift -fsanitize=integer-divide-by-zero -fsanitize=unreachable \ +-fsanitize=vla-bound -fsanitize=null -fsanitize=return \ +-fsanitize=signed-integer-overflow -fsanitize=bounds \ +-fsanitize=object-size -fsanitize=float-divide-by-zero -fsanitize=float-cast-overflow \ +-fsanitize=nonnull-attribute -fsanitize=returns-nonnull-attribute -fsanitize=bool \ +-fsanitize=enum -fsanitize=vptr" + else + SAN="-fsanitize=address" + fi OLD_CFLAGS="$CFLAGS" - CFLAGS="$CFLAGS -fsanitize=address" - + CFLAGS="$CFLAGS $SAN" OLD_LDFLAGS="$LDFLAGS" - LDFLAGS="$LDFLAGS -fsanitize=address" + LDFLAGS="$LDFLAGS $SAN" - AC_MSG_CHECKING([whether $CC supports -fsanitize=address]) + AC_MSG_CHECKING([whether $CC supports $SAN]) AC_RUN_IFELSE( [AC_LANG_SOURCE([ int main(int argc, char **argv){ @@ -651,6 +663,7 @@ if test "$enable_sanitize" != "no" ; then AC_MSG_RESULT([guessing no]) ] ) + fi -- cgit v1.2.3-70-g09d2