Build fuzzer with autotools
authorMathis Rosenhauer <rosenhauer@dkrz.de>
Thu, 13 Jul 2017 14:59:52 +0000 (16:59 +0200)
committerMathis Rosenhauer <rosenhauer@dkrz.de>
Mon, 17 Jul 2017 07:40:29 +0000 (09:40 +0200)
.gitignore
CMakeLists.txt
Makefile.am
configure.ac
fuzzing/CMakeLists.txt [moved from fuzz/CMakeLists.txt with 100% similarity]
fuzzing/Makefile.am [new file with mode: 0644]
fuzzing/fuzz_target.cc [moved from fuzz/fuzz_target.cc with 100% similarity]
m4/.gitignore [deleted file]
m4/m4_ax_compiler_vendor.m4 [new file with mode: 0644]
tests/Makefile.am

index 254bdbe..defede5 100644 (file)
@@ -17,3 +17,5 @@ autom4te.cache
 .DS_Store
 build*
 data/121B2TestData
+m4/libtool.m4
+m4/lt*
index 7d109bc..02e87ba 100644 (file)
@@ -1,4 +1,4 @@
-cmake_minimum_required(VERSION 2.8.6)
+cmake_minimum_required(VERSION 3.0.0)
 include(CheckIncludeFiles)
 include(TestBigEndian)
 include(CheckCSourceCompiles)
@@ -48,7 +48,7 @@ add_subdirectory(tests)
 
 option(AEC_FUZZING "Enable build of fuzzing targets" OFF)
 if(AEC_FUZZING)
-  add_subdirectory(fuzz)
+  add_subdirectory(fuzzing)
 endif()
 
 set(CPACK_PACKAGE_NAME "libaec")
index 2676248..3a22d37 100644 (file)
@@ -1,5 +1,8 @@
 ACLOCAL_AMFLAGS = -I m4
-SUBDIRS = src tests
+if AEC_FUZZING
+  FUZZDIR = fuzzing
+endif
+SUBDIRS = src tests $(FUZZDIR)
 EXTRA_DIST = doc/patent.txt CMakeLists.txt cmake/config.h.in \
 cmake/macros.cmake README.md README.SZIP CHANGELOG.md Copyright.txt data
 
index 66fe7bd..513bc0a 100644 (file)
@@ -9,14 +9,13 @@ AC_CONFIG_HEADERS(config/config.h)
 LT_INIT
 gl_VISIBILITY
 AM_INIT_AUTOMAKE([foreign])
+AM_MAINTAINER_MODE([enable])
 
-# Checks for programs.
 AC_PROG_CC
+AC_PROG_CXX
 
-# Checks for header files.
 AC_HEADER_STDC
 
-# Checks for typedefs, structures, and compiler characteristics.
 AC_C_BIGENDIAN
 AC_C_INLINE
 AC_TYPE_INT64_T
@@ -27,12 +26,28 @@ AC_TYPE_UINT8_T
 AC_C_INLINE
 AC_C_RESTRICT
 
-# Checks for library functions.
 AC_CHECK_FUNCS([memset strstr])
 AC_CHECK_DECLS(__builtin_clzll)
 
 AM_EXTRA_RECURSIVE_TARGETS([bench benc bdec])
-AC_CONFIG_FILES([Makefile         \
-                 src/Makefile     \
-                 tests/Makefile])
+
+AC_ARG_ENABLE([fuzzing],
+  AS_HELP_STRING([--enable-fuzzing], [Enable fuzzing of libaec]))
+
+AS_IF([test "x$enable_fuzzing" = "xyes"], [
+  AX_COMPILER_VENDOR
+  AS_IF([test "x$ax_cv_c_compiler_vendor" = "xclang"], [
+    AC_LANG_PUSH([C++])
+    AX_COMPILER_VENDOR
+    AC_LANG_POP([C++])
+    AS_IF([test "x$ax_cv_cxx_compiler_vendor" = "xclang"], [], [
+      AC_MSG_ERROR([You need to build with Clang as CXX for fuzzing to work])
+    ])
+  ], [
+    AC_MSG_ERROR([You need to build with Clang as CC for fuzzing to work])
+  ])
+])
+AM_CONDITIONAL([AEC_FUZZING], [test x$enable_fuzzing = xyes])
+
+AC_CONFIG_FILES([Makefile src/Makefile tests/Makefile fuzzing/Makefile])
 AC_OUTPUT
similarity index 100%
rename from fuzz/CMakeLists.txt
rename to fuzzing/CMakeLists.txt
diff --git a/fuzzing/Makefile.am b/fuzzing/Makefile.am
new file mode 100644 (file)
index 0000000..700de3b
--- /dev/null
@@ -0,0 +1,16 @@
+FUZZING_FLAGS = -g -fsanitize=address \
+-fsanitize-coverage=trace-pc-guard,indirect-calls,edge
+noinst_LIBRARIES = libaec_fuzz.a
+libaec_fuzz_a_SOURCES = $(top_srcdir)/src/encode.c \
+$(top_srcdir)/src/encode_accessors.c \
+$(top_srcdir)/src/decode.c \
+$(top_srcdir)/src/encode.h \
+$(top_srcdir)/src/encode_accessors.h \
+$(top_srcdir)/src/decode.h
+libaec_fuzz_a_CFLAGS = $(FUZZING_FLAGS)
+aec_fuzz_SOURCES = fuzz_target.cc
+aec_fuzz_CXXFLAGS = $(FUZZING_FLAGS)
+aec_fuzz_LDFLAGS = -fsanitize=address -lFuzzer
+aec_fuzz_LDADD = libaec_fuzz.a
+noinst_PROGRAMS = aec_fuzz
+EXTRA_DIST = CMakeLists.txt
similarity index 100%
rename from fuzz/fuzz_target.cc
rename to fuzzing/fuzz_target.cc
diff --git a/m4/.gitignore b/m4/.gitignore
deleted file mode 100644 (file)
index d6b7ef3..0000000
+++ /dev/null
@@ -1,2 +0,0 @@
-*
-!.gitignore
diff --git a/m4/m4_ax_compiler_vendor.m4 b/m4/m4_ax_compiler_vendor.m4
new file mode 100644 (file)
index 0000000..4ca8089
--- /dev/null
@@ -0,0 +1,87 @@
+# ===========================================================================
+#    https://www.gnu.org/software/autoconf-archive/ax_compiler_vendor.html
+# ===========================================================================
+#
+# SYNOPSIS
+#
+#   AX_COMPILER_VENDOR
+#
+# DESCRIPTION
+#
+#   Determine the vendor of the C/C++ compiler, e.g., gnu, intel, ibm, sun,
+#   hp, borland, comeau, dec, cray, kai, lcc, metrowerks, sgi, microsoft,
+#   watcom, etc. The vendor is returned in the cache variable
+#   $ax_cv_c_compiler_vendor for C and $ax_cv_cxx_compiler_vendor for C++.
+#
+# LICENSE
+#
+#   Copyright (c) 2008 Steven G. Johnson <stevenj@alum.mit.edu>
+#   Copyright (c) 2008 Matteo Frigo
+#
+#   This program is free software: you can redistribute it and/or modify it
+#   under the terms of the GNU General Public License as published by the
+#   Free Software Foundation, either version 3 of the License, or (at your
+#   option) any later version.
+#
+#   This program is distributed in the hope that it will be useful, but
+#   WITHOUT ANY WARRANTY; without even the implied warranty of
+#   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General
+#   Public License for more details.
+#
+#   You should have received a copy of the GNU General Public License along
+#   with this program. If not, see <https://www.gnu.org/licenses/>.
+#
+#   As a special exception, the respective Autoconf Macro's copyright owner
+#   gives unlimited permission to copy, distribute and modify the configure
+#   scripts that are the output of Autoconf when processing the Macro. You
+#   need not follow the terms of the GNU General Public License when using
+#   or distributing such scripts, even though portions of the text of the
+#   Macro appear in them. The GNU General Public License (GPL) does govern
+#   all other use of the material that constitutes the Autoconf Macro.
+#
+#   This special exception to the GPL applies to versions of the Autoconf
+#   Macro released by the Autoconf Archive. When you make and distribute a
+#   modified version of the Autoconf Macro, you may extend this special
+#   exception to the GPL to apply to your modified version as well.
+
+#serial 16
+
+AC_DEFUN([AX_COMPILER_VENDOR],
+[AC_CACHE_CHECK([for _AC_LANG compiler vendor], ax_cv_[]_AC_LANG_ABBREV[]_compiler_vendor,
+  dnl Please add if possible support to ax_compiler_version.m4
+  [# note: don't check for gcc first since some other compilers define __GNUC__
+  vendors="intel:     __ICC,__ECC,__INTEL_COMPILER
+           ibm:       __xlc__,__xlC__,__IBMC__,__IBMCPP__
+           pathscale: __PATHCC__,__PATHSCALE__
+           clang:     __clang__
+           cray:      _CRAYC
+           fujitsu:   __FUJITSU
+           gnu:       __GNUC__
+           sun:       __SUNPRO_C,__SUNPRO_CC
+           hp:        __HP_cc,__HP_aCC
+           dec:       __DECC,__DECCXX,__DECC_VER,__DECCXX_VER
+           borland:   __BORLANDC__,__CODEGEARC__,__TURBOC__
+           comeau:    __COMO__
+           kai:       __KCC
+           lcc:       __LCC__
+           sgi:       __sgi,sgi
+           microsoft: _MSC_VER
+           metrowerks: __MWERKS__
+           watcom:    __WATCOMC__
+           portland:  __PGI
+          tcc:       __TINYC__
+           unknown:   UNKNOWN"
+  for ventest in $vendors; do
+    case $ventest in
+      *:) vendor=$ventest; continue ;;
+      *)  vencpp="defined("`echo $ventest | sed 's/,/) || defined(/g'`")" ;;
+    esac
+    AC_COMPILE_IFELSE([AC_LANG_PROGRAM(,[
+      #if !($vencpp)
+        thisisanerror;
+      #endif
+    ])], [break])
+  done
+  ax_cv_[]_AC_LANG_ABBREV[]_compiler_vendor=`echo $vendor | cut -d: -f1`
+ ])
+])
index 8829293..eb62414 100644 (file)
@@ -10,15 +10,15 @@ check_PROGRAMS = check_code_options check_buffer_sizes check_long_fs \
 check_szcomp
 
 check_code_options_SOURCES = check_code_options.c check_aec.h \
-$(top_builddir)/src/libaec.h
+$(top_srcdir)/src/libaec.h
 
 check_buffer_sizes_SOURCES = check_buffer_sizes.c check_aec.h \
-$(top_builddir)/src/libaec.h
+$(top_srcdir)/src/libaec.h
 
 check_long_fs_SOURCES = check_long_fs.c check_aec.h \
-$(top_builddir)/src/libaec.h
+$(top_srcdir)/src/libaec.h
 
-check_szcomp_SOURCES = check_szcomp.c $(top_builddir)/src/szlib.h
+check_szcomp_SOURCES = check_szcomp.c $(top_srcdir)/src/szlib.h
 
 LDADD = libcheck_aec.la $(top_builddir)/src/libaec.la
 check_szcomp_LDADD = $(top_builddir)/src/libsz.la