X-Git-Url: http://plrg.eecs.uci.edu/git/?a=blobdiff_plain;f=folly%2Fconfigure.ac;h=9ab499aa230441c943aebc5f9c24b2c6c7ff3caa;hb=422c78beb630d6d5518ba357d3f8ae7d792d6415;hp=8741396cfc4120d957628e09f69106aae1d63a05;hpb=c6b307876b4977227f2f40270b6a35a80f05b473;p=folly.git diff --git a/folly/configure.ac b/folly/configure.ac index 8741396c..9ab499aa 100644 --- a/folly/configure.ac +++ b/folly/configure.ac @@ -107,8 +107,9 @@ AC_CHECK_LIB(ssl, # check for boost libs AX_BOOST_BASE([1.51.0], [], [AC_MSG_ERROR( - [Please install boost >= 1.51.0 (context, thread, regex, and system)])]) + [Please install boost >= 1.51.0 (context, thread, program_options, regex, and system)])]) AX_BOOST_CONTEXT +AX_BOOST_PROGRAM_OPTIONS AX_BOOST_THREAD AX_BOOST_REGEX AX_BOOST_SYSTEM @@ -119,7 +120,7 @@ AM_PATH_PYTHON # Checks for header files. AC_HEADER_STDC -AC_CHECK_HEADERS([fcntl.h features.h inttypes.h limits.h stdint.h stdlib.h string.h sys/time.h unistd.h mutex.h malloc.h emmintrin.h byteswap.h bits/functexcept.h bits/c++config.h]) +AC_CHECK_HEADERS([fcntl.h features.h inttypes.h limits.h stdint.h stdlib.h string.h sys/time.h unistd.h mutex.h malloc.h byteswap.h bits/functexcept.h bits/c++config.h]) AC_CHECK_HEADER(double-conversion/double-conversion.h, [], [AC_MSG_ERROR( [Couldn't find double-conversion.h, please download from \ @@ -227,7 +228,27 @@ AC_CACHE_CHECK( [folly_cv_lib_libcpp=no])]) if test "$folly_cv_lib_libcpp" = yes; then - AC_DEFINE([USE_LIBCPP], [1], [Define to 1 if we're using libc++.]) + AC_DEFINE([USE_LIBCPP], [1], [Define to 1 if we are using libc++.]) +fi + +AC_CACHE_CHECK( + [for c++11 atomic support without GNU Atomic library], + [folly_cv_lib_libatomic], + [AC_LINK_IFELSE( + [AC_LANG_SOURCE[ + #include + int main() { + struct Test { int val; }; + std::atomic s; + s.is_lock_free(); + } + ]], + [folly_cv_lib_libatomic=yes], + [folly_cv_lib_libatomic=no])]) + +if test "$folly_cv_lib_libatomic" = no; then + AC_HAVE_LIBRARY([atomic],[],[AC_MSG_ERROR( + [Please install the GNU Atomic library])]) fi AC_CACHE_CHECK( @@ -346,6 +367,63 @@ if test "$folly_cv_prog_cc_pthread_atfork" = "yes"; then AC_DEFINE([HAVE_PTHREAD_ATFORK], [1], [Define to 1 if the compiler supports pthread_atfork]) fi +# Check for XSI-compatible strerror_r as default implementation +AC_CACHE_CHECK( + [for XSI style strerror_r support], + [folly_cv_prog_cc_xsi_strerror_r], + [AC_RUN_IFELSE( + [AC_LANG_SOURCE[ + #include + #include + int main(int argc, char** argv) { + char buf[1024]; + buf[0] = 0; + int ret = strerror_r(ENOMEM, buf, sizeof(buf)); + return ret; + } + ]], + [folly_cv_prog_cc_xsi_strerror_r=yes], + [folly_cv_prog_cc_xsi_strerror_r=no])]) + +if test "$folly_cv_prog_cc_xsi_strerror_r" = "yes"; then + AC_DEFINE([HAVE_XSI_STRERROR_R], [1], [Define to 1 if the runtime supports XSI-style strerror_r]) +fi + +AC_CACHE_CHECK( + [for ext/random and __gnu_cxx::sfmt19937], + [folly_cv_prog_cc_have_extrandom_sfmt19937], + [AC_COMPILE_IFELSE( + [AC_LANG_SOURCE[ + #include + int main(int argc, char** argv) { + __gnu_cxx::sfmt19937 rng; + return 0; + } + ]], + [folly_cv_prog_cc_have_extrandom_sfmt19937=yes], + [folly_cv_prog_cc_have_extrandom_sfmt19937=no])]) + +AC_CACHE_CHECK( + [for VLA (variable-length array) support], + [folly_cv_prog_cc_have_vla], + [AC_COMPILE_IFELSE( + [AC_LANG_SOURCE[ + int main(int argc, char** argv) { + unsigned size = argc; + char data[size]; + return 0; + } + ]], + [folly_cv_prog_cc_have_vla=yes], + [folly_cv_prog_cc_have_vla=no])]) + +test "$folly_cv_prog_cc_have_vla" = yes && have_vla=1 || have_vla=0 +AC_DEFINE_UNQUOTED( + [HAVE_VLA], + [$have_vla], + [Define to 1 if the compiler has VLA (variable-length array) support, + otherwise define to 0]) + # Checks for library functions. AC_CHECK_FUNCS([getdelim \ gettimeofday \ @@ -368,11 +446,13 @@ AC_CHECK_HEADER([lz4.h], AC_CHECK_LIB([lz4], [LZ4_decompress_safe])) AC_CHECK_HEADER([snappy.h], AC_CHECK_LIB([snappy], [main])) AC_CHECK_HEADER([zlib.h], AC_CHECK_LIB([z], [main])) AC_CHECK_HEADER([lzma.h], AC_CHECK_LIB([lzma], [main])) +AC_CHECK_HEADER([zstd.h], AC_CHECK_LIB([zstd], [main])) # Include directory that contains "folly" so #include works AM_CPPFLAGS='-I$(top_srcdir)/..' AM_CPPFLAGS="$AM_CPPFLAGS $BOOST_CPPFLAGS" -AM_LDFLAGS="$AM_LDFLAGS $BOOST_CONTEXT_LIB $BOOST_THREAD_LIB $BOOST_FILESYSTEM_LIB" +AM_LDFLAGS="$AM_LDFLAGS $BOOST_CONTEXT_LIB $BOOST_PROGRAM_OPTIONS_LIB" +AM_LDFLAGS="$AM_LDFLAGS $BOOST_THREAD_LIB $BOOST_FILESYSTEM_LIB" AM_LDFLAGS="$AM_LDFLAGS $BOOST_SYSTEM_LIB $BOOST_REGEX_LIB -lpthread" AC_SUBST([AM_CPPFLAGS]) @@ -380,10 +460,14 @@ AC_SUBST([AM_LDFLAGS]) AM_CONDITIONAL([HAVE_STD_THREAD], [test "$ac_cv_header_features" = "yes"]) AM_CONDITIONAL([HAVE_X86_64], [test "$build_cpu" = "x86_64"]) +AM_CONDITIONAL([HAVE_PPC64], [test "$build_cpu" = "powerpc64le"]) +AM_CONDITIONAL([RUN_ARCH_SPECIFIC_TESTS], [test "$build_cpu" = "x86_64" || test "$build_cpu" = "powerpc64le"]) AM_CONDITIONAL([HAVE_LINUX], [test "$build_os" == "linux-gnu"]) AM_CONDITIONAL([HAVE_WEAK_SYMBOLS], [test "$folly_cv_prog_cc_weak_symbols" = "yes"]) AM_CONDITIONAL([HAVE_BITS_FUNCTEXCEPT], [test "$ac_cv_header_bits_functexcept_h" = "yes"]) +AM_CONDITIONAL([HAVE_EXTRANDOM_SFMT19937], + [test "$folly_cv_prog_cc_have_extrandom_sfmt19937" = "yes"]) # Output AC_CONFIG_FILES([Makefile