2021-05-25 10:16:00 -07:00
AC_PREREQ([2.69])
2023-09-08 12:44:54 -07:00
AC_INIT([libsodium],[1.0.20],[https://github.com/jedisct1/libsodium/issues],[libsodium],[https://libsodium.org])
2014-11-02 17:49:17 -07:00
AC_CONFIG_AUX_DIR([build-aux])
2013-01-19 17:02:02 -07:00
AC_CONFIG_MACRO_DIR([m4])
2013-04-18 06:24:07 -07:00
AC_CONFIG_SRCDIR([src/libsodium/sodium/version.c])
2013-01-19 17:02:02 -07:00
AC_CANONICAL_HOST
2021-05-22 03:21:58 -07:00
AC_CANONICAL_TARGET
2013-08-05 11:19:13 -07:00
AM_INIT_AUTOMAKE([1.11 dist-bzip2 tar-ustar foreign subdir-objects])
2013-01-20 19:06:07 -07:00
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
2013-01-19 17:02:02 -07:00
AM_MAINTAINER_MODE
AM_DEP_TRACK
AC_SUBST(VERSION)
2023-09-08 12:44:54 -07:00
SODIUM_LIBRARY_VERSION_MAJOR=28
2020-03-31 03:21:14 -07:00
SODIUM_LIBRARY_VERSION_MINOR=0
2023-09-08 12:44:54 -07:00
DLL_VERSION=28
SODIUM_LIBRARY_VERSION=28:0:0
2014-05-12 14:07:48 -07:00
# | | |
# +------+ | +---+
# | | |
# current:revision:age
# | | |
# | | +- increment if interfaces have been added
# | | set to zero if interfaces have been removed
# | | or changed
# | +- increment if source code has changed
# | set to zero if current is incremented
# +- increment if interfaces have been added, removed or changed
2013-03-31 15:22:43 -07:00
AC_SUBST(SODIUM_LIBRARY_VERSION_MAJOR)
AC_SUBST(SODIUM_LIBRARY_VERSION_MINOR)
2013-01-20 18:51:57 -07:00
AC_SUBST(SODIUM_LIBRARY_VERSION)
2013-04-23 21:24:35 -07:00
AC_SUBST(DLL_VERSION)
2013-01-20 18:51:57 -07:00
2016-12-28 23:51:50 -07:00
AC_LANG_ASSERT(C)
2013-07-07 22:25:20 -07:00
LX_CFLAGS=${CFLAGS-NONE}
2019-01-14 14:53:12 -07:00
PKGCONFIG_LIBS_PRIVATE=""
2013-07-07 22:25:20 -07:00
2014-12-21 01:51:32 -07:00
dnl Path check
2016-06-15 00:50:45 -07:00
AS_IF([pwd | fgrep ' ' > /dev/null 2>&1],
[AC_MSG_ERROR([The build directory contains whitespaces - This can cause tests/installation to fail due to limitations of some libtool versions])]
2014-12-21 01:51:32 -07:00
)
2022-11-13 14:52:29 -07:00
sodium_CFLAGS=${CFLAGS+set}
: ${CFLAGS=""}
2021-03-16 11:30:52 -07:00
AC_PROG_CC
2020-05-26 05:26:24 -07:00
AM_PROG_AS
AC_USE_SYSTEM_EXTENSIONS
2022-11-13 14:52:29 -07:00
dnl Default optimization flags
if test "$sodium_CFLAGS" != "set" ; then
AX_CHECK_COMPILE_FLAG([-Ofast], [CFLAGS="$CFLAGS -Ofast"],
[AX_CHECK_COMPILE_FLAG([-O3], [CFLAGS="$CFLAGS -O3"],
[AX_CHECK_COMPILE_FLAG([-O2], [CFLAGS="$CFLAGS -O2"],
[AX_CHECK_COMPILE_FLAG([-O1], [CFLAGS="$CFLAGS -O1"],
[AX_CHECK_COMPILE_FLAG([-O], [CFLAGS="$CFLAGS -O"])])])])])
fi
2013-07-07 21:46:44 -07:00
dnl Switches
2013-07-07 22:20:27 -07:00
AC_ARG_ENABLE(ssp,
2013-07-07 22:38:51 -07:00
[AS_HELP_STRING(--disable-ssp,Do not compile with -fstack-protector)],
2013-07-07 22:20:27 -07:00
[
AS_IF([test "x$enableval" = "xno"], [
enable_ssp="no"
], [
enable_ssp="yes"
])
],
[
enable_ssp="yes"
])
2013-07-07 21:46:44 -07:00
AC_ARG_ENABLE(asm,
2019-02-14 06:41:09 -07:00
[AS_HELP_STRING(--disable-asm,[Do not compile assembly code -- As a side effect, this disables CPU-specific implementations on non-Windows platforms. Only for use with targets such as WebAssembly.])],
2013-07-07 21:46:44 -07:00
[
AS_IF([test "x$enableval" = "xno"], [
enable_asm="no"
], [
enable_asm="yes"
])
],
[
enable_asm="yes"
])
2016-04-28 12:31:18 -07:00
AS_IF([test "x$EMSCRIPTEN" != "x"], [
2017-09-11 05:06:07 -07:00
AX_CHECK_COMPILE_FLAG([-s ASSERTIONS=0], [
enable_asm="no"
AC_MSG_WARN([compiling to JavaScript - asm implementations disabled])
], [
AC_MSG_WARN([EMSCRIPTEN environment variable defined, but emcc doesn't appear to be used - Assuming compilation to native code])
CFLAGS="$CFLAGS -U__EMSCRIPTEN__"
unset EMSCRIPTEN
])
2016-04-28 12:31:18 -07:00
])
2013-07-07 21:46:44 -07:00
2013-07-07 22:29:58 -07:00
AC_ARG_ENABLE(pie,
2013-07-07 22:35:34 -07:00
[AS_HELP_STRING(--disable-pie,Do not produce position independent executables)],
2013-07-07 22:29:58 -07:00
enable_pie=$enableval, enable_pie="maybe")
2020-07-03 02:45:52 -07:00
AS_CASE([$host_os], [mingw*|cygwin*|msys|eabi*], [enable_pie="no"])
2013-09-08 22:06:27 -07:00
2013-07-07 21:46:44 -07:00
AC_ARG_ENABLE(blocking-random,
2014-12-23 12:24:23 -07:00
[AS_HELP_STRING(--enable-blocking-random,Enable this switch only if /dev/urandom is totally broken on the target platform)],
2013-08-18 13:06:00 -07:00
[
AS_IF([test "x$enableval" = "xyes"], [
2014-12-23 12:24:23 -07:00
AC_DEFINE([USE_BLOCKING_RANDOM], [1], [/dev/urandom is insecure on the target platform])
2013-08-18 13:06:00 -07:00
])
])
2013-07-07 21:46:44 -07:00
2014-07-09 20:24:04 -07:00
AC_ARG_ENABLE(minimal,
[AS_HELP_STRING(--enable-minimal,
2014-07-14 18:43:46 -07:00
[Only compile the minimum set of functions required for the high-level API])],
2014-07-09 20:24:04 -07:00
[
AS_IF([test "x$enableval" = "xyes"], [
enable_minimal="yes"
2017-03-06 01:47:09 -07:00
SODIUM_LIBRARY_MINIMAL_DEF="#define SODIUM_LIBRARY_MINIMAL 1"
2017-02-26 08:49:15 -07:00
AC_DEFINE([MINIMAL], [1], [Define for a minimal build, without deprecated functions and functions that high-level APIs depend on])
2014-07-09 20:24:04 -07:00
], [
enable_minimal="no"
])
],
[
enable_minimal="no"
])
AM_CONDITIONAL([MINIMAL], [test x$enable_minimal = xyes])
2017-03-06 01:47:09 -07:00
AC_SUBST(SODIUM_LIBRARY_MINIMAL_DEF)
2014-07-09 20:24:04 -07:00
2021-03-16 11:30:52 -07:00
AC_ARG_WITH(pthreads, AS_HELP_STRING([--with-pthreads],
[use pthreads library, or --without-pthreads to disable threading support]),
2016-04-18 11:54:46 -07:00
[ ], [withval="yes"])
AS_IF([test "x$withval" = "xyes"], [
AX_PTHREAD([
2019-03-30 03:22:10 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
#include <pthread.h>
]], [[
pthread_mutex_t mutex;
pthread_mutex_lock(&mutex);
2019-03-30 03:26:05 -07:00
pthread_mutex_unlock(&mutex)
2019-03-30 03:22:10 -07:00
]]
)], [
AC_DEFINE([HAVE_PTHREAD], [1], [Define if you have POSIX threads libraries and header files])
with_threads="yes"
LIBS="$PTHREAD_LIBS $LIBS"
PKGCONFIG_LIBS_PRIVATE="$PTHREAD_LIBS $PTHREAD_CFLAGS $PKGCONFIG_LIBS_PRIVATE"
CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
CC="$PTHREAD_CC"
])
],
[ AC_MSG_NOTICE(pthread mutexes are not available) ]
)
2017-11-25 14:46:31 -07:00
], [with_threads="no"])
2016-04-18 11:54:46 -07:00
2013-07-07 21:46:44 -07:00
AC_ARG_WITH(safecode,
[AS_HELP_STRING(--with-safecode,For maintainers only - please do not use)],
[AS_IF([test "x$withval" = "xyes"], [
AC_ARG_VAR([SAFECODE_HOME], [set to the safecode base directory])
: ${SAFECODE_HOME:=/opt/safecode}
LDFLAGS="$LDFLAGS -L${SAFECODE_HOME}/lib"
LIBS="$LIBS -lsc_dbg_rt -lpoolalloc_bitmap -lstdc++"
CFLAGS="$CFLAGS -fmemsafety"
])
])
2017-11-03 09:15:02 -07:00
AC_ARG_WITH(ctgrind,
[AS_HELP_STRING(--with-ctgrind,For maintainers only - please do not use)],
[AS_IF([test "x$withval" = "xyes"], [
2017-11-06 15:34:45 -07:00
AC_CHECK_LIB(ctgrind, ct_poison)
2017-11-03 09:15:02 -07:00
])
])
2019-01-04 04:43:47 -07:00
AC_ARG_ENABLE(retpoline,
[AS_HELP_STRING(--enable-retpoline,Use return trampolines for indirect calls)],
[AS_IF([test "x$enableval" = "xyes"], [
AX_CHECK_COMPILE_FLAG([-mindirect-branch=thunk-inline],
[CFLAGS="$CFLAGS -mindirect-branch=thunk-inline"],
[AX_CHECK_COMPILE_FLAG([-mretpoline], [CFLAGS="$CFLAGS -mretpoline"])]
)
AX_CHECK_COMPILE_FLAG([-mindirect-branch-register])
])
])
2017-10-05 01:31:19 -07:00
ENABLE_CWFLAGS=no
2013-07-07 22:25:20 -07:00
AC_ARG_ENABLE(debug,
[AS_HELP_STRING(--enable-debug,For maintainers only - please do not use)],
[
2013-08-18 13:06:00 -07:00
AS_IF([test "x$enableval" = "xyes"], [
AS_IF([test "x$LX_CFLAGS" = "xNONE"], [
nxflags=""
for flag in `echo $CFLAGS`; do
2013-09-08 10:44:07 -07:00
AS_CASE([$flag],
[-O*], [ ],
[-g*], [ ],
[*], [AS_VAR_APPEND([nxflags], [" $flag"])])
2013-08-18 13:06:00 -07:00
done
2017-10-05 01:41:15 -07:00
CFLAGS="$nxflags -O -g3"
2013-08-18 13:06:00 -07:00
])
2017-10-05 01:31:19 -07:00
ENABLE_CWFLAGS=yes
2017-10-05 01:35:50 -07:00
CPPFLAGS="$CPPFLAGS -DDEBUG=1 -U_FORTIFY_SOURCE"
2013-07-07 22:25:20 -07:00
])
])
2015-12-05 09:56:42 -07:00
AC_ARG_ENABLE(opt,
[AS_HELP_STRING(--enable-opt,Optimize for the native CPU - The resulting library will be faster but not portable)],
[
AS_IF([test "x$enableval" = "xyes"], [
2019-01-07 04:22:09 -07:00
AX_CHECK_COMPILE_FLAG([-ftree-vectorize], [CFLAGS="$CFLAGS -ftree-vectorize"])
AX_CHECK_COMPILE_FLAG([-ftree-slp-vectorize], [CFLAGS="$CFLAGS -ftree-slp-vectorize"])
2017-12-11 04:00:36 -07:00
AX_CHECK_COMPILE_FLAG([-fomit-frame-pointer], [CFLAGS="$CFLAGS -fomit-frame-pointer"])
2017-03-10 12:49:36 -07:00
AX_CHECK_COMPILE_FLAG([-march=native], [CFLAGS="$CFLAGS -march=native"])
2022-11-14 15:21:53 -07:00
AX_CHECK_COMPILE_FLAG([-mtune=native], [CFLAGS="$CFLAGS -mtune=native"])
2017-03-10 12:49:36 -07:00
])
2015-12-05 09:56:42 -07:00
])
2019-01-14 16:24:01 -07:00
AC_SUBST(MAINT)
AC_SUBST(PKGCONFIG_LIBS_PRIVATE)
2013-07-07 21:46:44 -07:00
2016-03-05 17:32:02 -07:00
AX_VALGRIND_CHECK
2013-07-07 21:46:44 -07:00
dnl Checks
2017-11-25 16:11:56 -07:00
AC_C_VARARRAYS
2014-11-02 20:24:08 -07:00
2019-04-08 12:02:22 -07:00
AC_CHECK_DEFINE([__wasi__], [WASI="yes"], [])
2019-12-04 15:30:37 -07:00
AS_CASE([$host_os], [linux-gnu], [AX_ADD_FORTIFY_SOURCE], [ ])
2013-01-19 17:02:02 -07:00
2018-02-20 17:59:15 -07:00
AX_CHECK_COMPILE_FLAG([-fvisibility=hidden],
[CFLAGS="$CFLAGS -fvisibility=hidden"])
2020-07-03 02:45:52 -07:00
AS_CASE([$host_os], [cygwin*|mingw*|msys|pw32*|cegcc*|eabi*], [ ], [
2016-12-28 23:51:50 -07:00
AX_CHECK_COMPILE_FLAG([-fPIC], [CFLAGS="$CFLAGS -fPIC"])
2013-04-24 13:08:25 -07:00
])
2013-01-19 17:02:02 -07:00
AS_IF([test "$enable_pie" != "no"],[
AX_CHECK_COMPILE_FLAG([-fPIE], [
2016-12-28 23:51:50 -07:00
AX_CHECK_LINK_FLAG([-pie], [
[CFLAGS="$CFLAGS -fPIE"
LDFLAGS="$LDFLAGS -pie"]
2013-01-19 17:02:02 -07:00
])
])
])
AX_CHECK_COMPILE_FLAG([-fno-strict-aliasing], [CFLAGS="$CFLAGS -fno-strict-aliasing"])
2014-11-25 13:19:08 -07:00
AX_CHECK_COMPILE_FLAG([-fno-strict-overflow], [CFLAGS="$CFLAGS -fno-strict-overflow"], [
AX_CHECK_COMPILE_FLAG([-fwrapv], [CFLAGS="$CFLAGS -fwrapv"])
])
2013-01-19 17:02:02 -07:00
2016-03-24 11:11:21 -07:00
AS_IF([test "$GCC" = "yes" ], [
AS_CASE([$host_cpu],
[i?86|amd64|x86_64], [
AC_COMPILE_IFELSE(
[AC_LANG_SOURCE([
#if !defined(__clang__) && defined(__GNUC__) && ((__GNUC__ << 8) | __GNUC_MINOR__) < 0x403
# error old gcc
#endif
int main(void) { return 0; }
])],,[
AX_CHECK_COMPILE_FLAG([-flax-vector-conversions], [CFLAGS="$CFLAGS -flax-vector-conversions"])
])
]
)
])
2014-02-22 18:07:52 -07:00
LIBTOOL_OLD_FLAGS="$LIBTOOL_EXTRA_FLAGS"
LIBTOOL_EXTRA_FLAGS="$LIBTOOL_EXTRA_FLAGS -version-info $SODIUM_LIBRARY_VERSION"
2014-02-20 09:54:05 -07:00
AC_ARG_ENABLE(soname-versions,
2021-03-16 11:30:52 -07:00
[AS_HELP_STRING([--enable-soname-versions], [enable soname versions (must be disabled for Android) (default: enabled)])],
2014-02-20 09:54:05 -07:00
[
2015-10-10 11:10:26 -07:00
AS_IF([test "x$enableval" = "xno"], [
2014-02-22 18:07:52 -07:00
LIBTOOL_EXTRA_FLAGS="$LIBTOOL_OLD_FLAGS -avoid-version"
2014-02-20 09:54:05 -07:00
])
]
)
2013-07-07 22:20:27 -07:00
2013-09-08 10:44:07 -07:00
AS_CASE([$host_os],
2014-08-04 14:30:07 -07:00
[cygwin*|mingw*|msys|pw32*|cegcc*], [
2013-01-19 17:02:02 -07:00
AX_CHECK_LINK_FLAG([-Wl,--dynamicbase], [LDFLAGS="$LDFLAGS -Wl,--dynamicbase"])
2015-12-27 12:53:08 -07:00
AX_CHECK_LINK_FLAG([-Wl,--high-entropy-va], [LDFLAGS="$LDFLAGS -Wl,--high-entropy-va"])
2013-01-19 17:02:02 -07:00
AX_CHECK_LINK_FLAG([-Wl,--nxcompat], [LDFLAGS="$LDFLAGS -Wl,--nxcompat"])
2013-09-08 10:44:07 -07:00
])
2013-07-07 22:20:27 -07:00
2017-09-15 06:15:31 -07:00
AS_CASE([$host_os],
2020-07-03 02:45:52 -07:00
[cygwin*|mingw*|msys|pw32*|cegcc*|eabi*], [
2017-09-15 06:49:13 -07:00
AX_CHECK_COMPILE_FLAG([-fno-asynchronous-unwind-tables], [
[CFLAGS="$CFLAGS -fno-asynchronous-unwind-tables"]
2017-09-15 06:15:31 -07:00
])
])
2013-07-07 22:20:27 -07:00
AS_IF([test "x$enable_ssp" != "xno"],[
2013-09-08 10:44:07 -07:00
AS_CASE([$host_os],
2020-07-03 02:45:52 -07:00
[cygwin*|mingw*|msys|pw32*|cegcc*|haiku|none|eabi*], [ ],
2014-09-14 13:25:29 -07:00
[*], [
2013-01-19 17:02:02 -07:00
AX_CHECK_COMPILE_FLAG([-fstack-protector], [
AX_CHECK_LINK_FLAG([-fstack-protector],
[CFLAGS="$CFLAGS -fstack-protector"]
)
])
2013-09-08 10:44:07 -07:00
])
2013-07-07 22:20:27 -07:00
])
2013-01-19 17:02:02 -07:00
2017-10-05 01:31:19 -07:00
AX_CHECK_COMPILE_FLAG([$CFLAGS -Wall], [CWFLAGS="$CFLAGS -Wall"])
2022-11-16 03:59:08 -07:00
AX_CHECK_COMPILE_FLAG([$CFLAGS -Wno-deprecated-declarations], [CFLAGS="$CFLAGS -Wno-deprecated-declarations"])
2022-11-16 11:05:39 -07:00
AX_CHECK_COMPILE_FLAG([$CFLAGS -Wno-unknown-pragmas], [CFLAGS="$CFLAGS -Wno-unknown-pragmas"])
2022-11-16 03:59:08 -07:00
AC_ARG_VAR([CWFLAGS], [compilation flags for generating extra warnings])
2013-01-19 17:02:02 -07:00
AC_MSG_CHECKING(for clang)
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[
#ifndef __clang__
2017-09-15 06:26:10 -07:00
#error Not clang
2013-01-19 17:02:02 -07:00
#endif
]])],
[AC_MSG_RESULT(yes)
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wno-unknown-warning-option],
2013-04-26 22:00:00 -07:00
[CWFLAGS="$CWFLAGS -Wno-unknown-warning-option"])
],
2013-01-19 17:02:02 -07:00
[AC_MSG_RESULT(no)
])
2022-11-16 03:59:08 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wextra], [CWFLAGS="$WCFLAGS -Wextra"])
2022-09-19 06:26:22 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Warray-bounds], [CWFLAGS="$CWFLAGS -Warray-bounds"])
2013-01-19 17:02:02 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wbad-function-cast], [CWFLAGS="$CWFLAGS -Wbad-function-cast"])
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wcast-qual], [CWFLAGS="$CWFLAGS -Wcast-qual"])
2017-10-05 01:31:19 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wdiv-by-zero], [CWFLAGS="$CWFLAGS -Wdiv-by-zero"])
2017-10-05 00:11:27 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wduplicated-branches], [CWFLAGS="$CWFLAGS -Wduplicated-branches"])
2016-03-26 16:42:45 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wduplicated-cond], [CWFLAGS="$CWFLAGS -Wduplicated-cond"])
2013-01-19 17:02:02 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wfloat-equal], [CWFLAGS="$CWFLAGS -Wfloat-equal"])
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wformat=2], [CWFLAGS="$CWFLAGS -Wformat=2"])
2017-10-05 00:11:27 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wlogical-op], [CWFLAGS="$CWFLAGS -Wlogical-op"])
2017-10-05 01:31:19 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmaybe-uninitialized], [CWFLAGS="$CWFLAGS -Wmaybe-uninitialized"])
2017-10-05 00:11:27 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmisleading-indentation], [CWFLAGS="$CWFLAGS -Wmisleading-indentation"])
2013-01-19 17:02:02 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmissing-declarations], [CWFLAGS="$CWFLAGS -Wmissing-declarations"])
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmissing-prototypes], [CWFLAGS="$CWFLAGS -Wmissing-prototypes"])
2016-03-26 16:42:45 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wnested-externs], [CWFLAGS="$CWFLAGS -Wnested-externs"])
2017-08-08 09:07:46 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wno-type-limits], [CWFLAGS="$CWFLAGS -Wno-type-limits"])
2016-03-26 16:42:45 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wno-unknown-pragmas], [CWFLAGS="$CWFLAGS -Wno-unknown-pragmas"])
2013-01-19 17:02:02 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wnormalized=id], [CWFLAGS="$CWFLAGS -Wnormalized=id"])
2016-03-26 16:42:45 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wnull-dereference], [CWFLAGS="$CWFLAGS -Wnull-dereference"])
2017-08-08 09:07:46 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wold-style-declaration], [CWFLAGS="$CWFLAGS -Wold-style-declaration"])
2013-01-19 17:02:02 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wpointer-arith], [CWFLAGS="$CWFLAGS -Wpointer-arith"])
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wredundant-decls], [CWFLAGS="$CWFLAGS -Wredundant-decls"])
2017-10-05 00:11:27 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wrestrict], [CWFLAGS="$CWFLAGS -Wrestrict"])
2017-03-21 15:25:55 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wshorten-64-to-32], [CWFLAGS="$CWFLAGS -Wshorten-64-to-32"])
2017-10-05 01:31:19 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wsometimes-uninitialized], [CWFLAGS="$CWFLAGS -Wsometimes-uninitialized"])
2013-01-19 17:02:02 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wstrict-prototypes], [CWFLAGS="$CWFLAGS -Wstrict-prototypes"])
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wswitch-enum], [CWFLAGS="$CWFLAGS -Wswitch-enum"])
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wvariable-decl], [CWFLAGS="$CWFLAGS -Wvariable-decl"])
2017-10-05 01:31:19 -07:00
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wwrite-strings], [CWFLAGS="$CWFLAGS -Wwrite-strings"])
2013-01-19 17:02:02 -07:00
2020-05-26 08:50:19 -07:00
AS_IF([test "x$EMSCRIPTEN" = "x"], [
AX_CHECK_LINK_FLAG([-Wl,-z,relro], [LDFLAGS="$LDFLAGS -Wl,-z,relro"])
AX_CHECK_LINK_FLAG([-Wl,-z,now], [LDFLAGS="$LDFLAGS -Wl,-z,now"])
AX_CHECK_LINK_FLAG([-Wl,-z,noexecstack], [LDFLAGS="$LDFLAGS -Wl,-z,noexecstack"])
])
2013-01-19 17:02:02 -07:00
2017-06-23 02:11:16 -07:00
AX_CHECK_CATCHABLE_SEGV
2017-09-19 13:33:09 -07:00
AX_CHECK_CATCHABLE_ABRT
2017-11-25 14:46:31 -07:00
AS_IF([test "x$with_threads" = "xyes"], [
2019-01-05 20:52:41 -07:00
AX_TLS([AC_MSG_RESULT(thread local storage is supported)
2019-01-05 21:04:34 -07:00
AX_CHECK_COMPILE_FLAG([-ftls-model=local-dynamic],
[CFLAGS="$CFLAGS -ftls-model=local-dynamic"])],
2017-11-25 14:46:31 -07:00
[AC_MSG_RESULT(thread local storage is not supported)]) ])
2017-06-23 02:11:16 -07:00
2013-01-19 17:37:13 -07:00
LT_INIT
AC_SUBST(LIBTOOL_DEPS)
2013-01-19 17:02:02 -07:00
AC_ARG_VAR([AR], [path to the ar utility])
AC_CHECK_TOOL([AR], [ar], [ar])
2020-07-01 09:34:06 -07:00
dnl Checks for headers and codegen feature flags
target_cpu_aarch64=no
AC_MSG_CHECKING(for ARM64 target)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE(
2020-07-01 09:34:06 -07:00
[AC_LANG_PROGRAM([
#ifndef __aarch64__
#error Not aarch64
#endif
#include <arm_neon.h>
], [(void) 0])],
[AC_MSG_RESULT(yes)
target_cpu_aarch64=yes],
[AC_MSG_RESULT(no)
target_cpu_aarch64=no])
2013-04-26 22:53:07 -07:00
2019-02-14 06:41:09 -07:00
AS_IF([test "x$EMSCRIPTEN" = "x"], [
2014-05-09 20:26:43 -07:00
2020-07-01 09:34:06 -07:00
AS_IF([test "x$target_cpu_aarch64" = "xyes"], [
have_armcrypto=no
2019-10-23 10:30:48 -07:00
AC_MSG_CHECKING(for ARM crypto instructions set)
2023-09-12 05:33:29 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
#ifdef __clang__
# pragma clang attribute push(__attribute__((target("neon,crypto,aes"))), apply_to = function)
#elif defined(__GNUC__)
# pragma GCC target("+simd+crypto")
#endif
#ifndef __ARM_FEATURE_CRYPTO
# define __ARM_FEATURE_CRYPTO 1
#endif
#ifndef __ARM_FEATURE_AES
# define __ARM_FEATURE_AES 1
#endif
#include <arm_neon.h>
]], [[
vaeseq_u8(vmovq_n_u8(0), vmovq_n_u8(0));
2023-09-13 09:56:14 -07:00
vmull_high_p64(vmovq_n_u8(0), vmovq_n_u8(0));
2023-09-12 05:33:29 -07:00
#ifdef __clang__
# pragma clang attribute pop
#endif
(void) 0
]])],
2020-07-01 09:34:06 -07:00
[
AC_MSG_RESULT(yes)
have_armcrypto=yes
],
[
AC_MSG_RESULT(no)
oldcflags="$CFLAGS"
2023-08-05 00:33:04 -07:00
AX_CHECK_COMPILE_FLAG([-march=armv8-a+crypto+aes], [
CFLAGS="$CFLAGS -march=armv8-a+crypto+aes"
AC_MSG_CHECKING(for ARM crypto instructions set with -march=armv8-a+crypto+aes)
2023-09-12 05:33:29 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
#ifdef __clang__
# pragma clang attribute push(__attribute__((target("neon,crypto,aes"))), apply_to = function)
#elif defined(__GNUC__)
# pragma GCC target("+simd+crypto")
#endif
#ifndef __ARM_FEATURE_CRYPTO
# define __ARM_FEATURE_CRYPTO 1
#endif
#ifndef __ARM_FEATURE_AES
# define __ARM_FEATURE_AES 1
#endif
2023-09-13 09:56:14 -07:00
#include <arm_neon.h>
2023-09-12 05:33:29 -07:00
]], [[
vaeseq_u8(vmovq_n_u8(0), vmovq_n_u8(0));
2023-09-13 09:56:14 -07:00
vmull_high_p64(vmovq_n_u8(0), vmovq_n_u8(0));
2023-09-12 05:33:29 -07:00
#ifdef __clang__
# pragma clang attribute pop
#endif
(void) 0
]])],
2020-07-01 09:34:06 -07:00
[
2023-08-05 00:33:04 -07:00
AC_MSG_RESULT(yes - with addition of -march=armv8-a+crypto+aes)
2020-07-01 09:34:06 -07:00
have_armcrypto=yes
2023-08-05 00:33:04 -07:00
CFLAGS_ARMCRYPTO="-march=armv8-a+crypto+aes"
2020-07-01 09:34:06 -07:00
],
[AC_MSG_RESULT(no)])
CFLAGS="$oldcflags"
])
])
AS_IF([test "$have_armcrypto" = "yes"],[AC_DEFINE([HAVE_ARMCRYPTO], [1], [ARM crypto extensions are available])])
2019-10-23 10:30:48 -07:00
])
2015-10-10 11:10:26 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-mmmx], [CFLAGS="$CFLAGS -mmmx"])
2017-03-05 13:26:28 -07:00
AC_MSG_CHECKING(for MMX instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2014-05-09 20:26:43 -07:00
#pragma GCC target("mmx")
#include <mmintrin.h>
]], [[ __m64 x = _mm_setzero_si64(); ]])],
[AC_MSG_RESULT(yes)
2015-10-10 10:23:39 -07:00
AC_DEFINE([HAVE_MMINTRIN_H], [1], [mmx is available])
AX_CHECK_COMPILE_FLAG([-mmmx], [CFLAGS_MMX="-mmmx"])],
2014-05-09 20:26:43 -07:00
[AC_MSG_RESULT(no)])
2015-10-10 11:10:26 -07:00
CFLAGS="$oldcflags"
2014-05-09 20:26:43 -07:00
2015-10-10 11:10:26 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-msse2], [CFLAGS="$CFLAGS -msse2"])
2017-03-05 13:26:28 -07:00
AC_MSG_CHECKING(for SSE2 instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2014-05-09 20:26:43 -07:00
#pragma GCC target("sse2")
2015-10-10 09:32:10 -07:00
#ifndef __SSE2__
# define __SSE2__
#endif
2014-05-09 20:26:43 -07:00
#include <emmintrin.h>
2015-12-29 15:18:28 -07:00
]], [[ __m128d x = _mm_setzero_pd();
2017-03-05 13:26:28 -07:00
__m128i z = _mm_srli_epi64(_mm_setzero_si128(), 26); ]])],
2014-05-09 20:26:43 -07:00
[AC_MSG_RESULT(yes)
2015-10-10 10:23:39 -07:00
AC_DEFINE([HAVE_EMMINTRIN_H], [1], [sse2 is available])
AX_CHECK_COMPILE_FLAG([-msse2], [CFLAGS_SSE2="-msse2"])],
2014-05-09 20:26:43 -07:00
[AC_MSG_RESULT(no)])
2015-10-10 11:10:26 -07:00
CFLAGS="$oldcflags"
2014-05-09 20:26:43 -07:00
2015-10-10 11:10:26 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-msse3], [CFLAGS="$CFLAGS -msse3"])
2014-05-09 20:26:43 -07:00
AC_MSG_CHECKING(for SSE3 instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2014-05-09 20:26:43 -07:00
#pragma GCC target("sse3")
#include <pmmintrin.h>
]], [[ __m128 x = _mm_addsub_ps(_mm_cvtpd_ps(_mm_setzero_pd()),
_mm_cvtpd_ps(_mm_setzero_pd())); ]])],
[AC_MSG_RESULT(yes)
2015-10-10 10:23:39 -07:00
AC_DEFINE([HAVE_PMMINTRIN_H], [1], [sse3 is available])
AX_CHECK_COMPILE_FLAG([-msse3], [CFLAGS_SSE3="-msse3"])],
2014-05-09 20:26:43 -07:00
[AC_MSG_RESULT(no)])
2015-10-10 11:10:26 -07:00
CFLAGS="$oldcflags"
2014-05-09 20:26:43 -07:00
2015-10-10 11:10:26 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-mssse3], [CFLAGS="$CFLAGS -mssse3"])
2014-05-14 22:34:27 -07:00
AC_MSG_CHECKING(for SSSE3 instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2014-05-14 22:34:27 -07:00
#pragma GCC target("ssse3")
#include <tmmintrin.h>
]], [[ __m64 x = _mm_abs_pi32(_m_from_int(0)); ]])],
[AC_MSG_RESULT(yes)
2015-10-10 10:23:39 -07:00
AC_DEFINE([HAVE_TMMINTRIN_H], [1], [ssse3 is available])
AX_CHECK_COMPILE_FLAG([-mssse3], [CFLAGS_SSSE3="-mssse3"])],
[AC_MSG_RESULT(no)])
2015-10-10 11:10:26 -07:00
CFLAGS="$oldcflags"
2015-10-10 10:23:39 -07:00
2015-10-10 11:10:26 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-msse4.1], [CFLAGS="$CFLAGS -msse4.1"])
2015-10-10 10:23:39 -07:00
AC_MSG_CHECKING(for SSE4.1 instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2015-10-10 10:23:39 -07:00
#pragma GCC target("sse4.1")
#include <smmintrin.h>
]], [[ __m128i x = _mm_minpos_epu16(_mm_setzero_si128()); ]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_SMMINTRIN_H], [1], [sse4.1 is available])
2015-10-31 22:09:04 -07:00
AX_CHECK_COMPILE_FLAG([-msse4.1], [CFLAGS_SSE41="-msse4.1"])],
2014-05-14 22:34:27 -07:00
[AC_MSG_RESULT(no)])
2015-10-10 11:10:26 -07:00
CFLAGS="$oldcflags"
2015-10-10 08:57:47 -07:00
2015-11-03 06:18:43 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-mavx], [CFLAGS="$CFLAGS -mavx"])
AC_MSG_CHECKING(for AVX instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2015-11-03 06:18:43 -07:00
#pragma GCC target("avx")
#include <immintrin.h>
]], [[ _mm256_zeroall(); ]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_AVXINTRIN_H], [1], [AVX is available])
AX_CHECK_COMPILE_FLAG([-mavx], [CFLAGS_AVX="-mavx"])],
[AC_MSG_RESULT(no)])
CFLAGS="$oldcflags"
2016-03-17 03:08:36 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-mavx2], [CFLAGS="$CFLAGS -mavx2"])
AC_MSG_CHECKING(for AVX2 instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2016-03-17 03:08:36 -07:00
#pragma GCC target("avx2")
#include <immintrin.h>
2016-08-04 11:58:48 -07:00
]], [[
__m256 x = _mm256_set1_ps(3.14);
__m256 y = _mm256_permutevar8x32_ps(x, _mm256_set1_epi32(42));
return _mm256_movemask_ps(_mm256_cmp_ps(x, y, _CMP_NEQ_OQ));
]])],
2016-03-17 03:08:36 -07:00
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_AVX2INTRIN_H], [1], [AVX2 is available])
2016-08-03 17:26:24 -07:00
AX_CHECK_COMPILE_FLAG([-mavx2], [CFLAGS_AVX2="-mavx2"])
2016-04-03 01:41:28 -07:00
AC_MSG_CHECKING(if _mm256_broadcastsi128_si256 is correctly defined)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2016-04-03 01:41:28 -07:00
#pragma GCC target("avx2")
#include <immintrin.h>
]], [[ __m256i y = _mm256_broadcastsi128_si256(_mm_setzero_si128()); ]])],
[AC_MSG_RESULT(yes)],
[AC_MSG_RESULT(no)
AC_DEFINE([_mm256_broadcastsi128_si256], [_mm_broadcastsi128_si256],
[Define to the local name of _mm256_broadcastsi128_si256])])
],
2016-03-17 03:08:36 -07:00
[AC_MSG_RESULT(no)])
CFLAGS="$oldcflags"
2017-09-13 14:35:20 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-mavx512f], [CFLAGS="$CFLAGS -mavx512f"])
AC_MSG_CHECKING(for AVX512F instructions set)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2017-09-13 14:35:20 -07:00
#pragma GCC target("avx512f")
#include <immintrin.h>
]], [[
2018-11-30 07:18:52 -07:00
#ifndef __AVX512F__
# error No AVX512 support
#elif defined(__clang__)
# if __clang_major__ < 4
# error Compiler AVX512 support may be broken
# endif
#elif defined(__GNUC__)
# if __GNUC__ < 6
# error Compiler AVX512 support may be broken
# endif
#endif
2017-09-13 14:35:20 -07:00
__m512i x = _mm512_setzero_epi32();
__m512i y = _mm512_permutexvar_epi64(_mm512_setr_epi64(0, 1, 4, 5, 2, 3, 6, 7), x);
]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_AVX512FINTRIN_H], [1], [AVX512F is available])
AX_CHECK_COMPILE_FLAG([-mavx512f], [CFLAGS_AVX512F="-mavx512f"])],
2018-11-30 07:18:52 -07:00
[AC_MSG_RESULT(no)
AX_CHECK_COMPILE_FLAG([$CFLAGS -mno-avx512f],
[CFLAGS="$CFLAGS -mno-avx512f"])
])
2017-09-13 14:35:20 -07:00
CFLAGS="$oldcflags"
2015-10-10 11:10:26 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-maes], [CFLAGS="$CFLAGS -maes"])
AX_CHECK_COMPILE_FLAG([-mpclmul], [CFLAGS="$CFLAGS -mpclmul"])
2015-10-10 08:57:47 -07:00
AC_MSG_CHECKING(for AESNI instructions set and PCLMULQDQ)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2015-10-10 08:57:47 -07:00
#pragma GCC target("aes")
#pragma GCC target("pclmul")
#include <wmmintrin.h>
]], [[ __m128i x = _mm_aesimc_si128(_mm_setzero_si128());
__m128i y = _mm_clmulepi64_si128(_mm_setzero_si128(), _mm_setzero_si128(), 0);]])],
[AC_MSG_RESULT(yes)
2015-10-10 09:21:33 -07:00
AC_DEFINE([HAVE_WMMINTRIN_H], [1], [aesni is available])
2015-10-10 10:23:39 -07:00
AX_CHECK_COMPILE_FLAG([-maes], [CFLAGS_AESNI="-maes"])
AX_CHECK_COMPILE_FLAG([-mpclmul], [CFLAGS_PCLMUL="-mpclmul"])
2015-10-10 09:21:33 -07:00
],
2015-10-10 08:57:47 -07:00
[AC_MSG_RESULT(no)])
2015-10-10 11:10:26 -07:00
CFLAGS="$oldcflags"
2017-11-25 09:53:33 -07:00
oldcflags="$CFLAGS"
AX_CHECK_COMPILE_FLAG([-mrdrnd], [CFLAGS="$CFLAGS -mrdrnd"])
AC_MSG_CHECKING(for RDRAND)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2017-11-25 09:53:33 -07:00
#pragma GCC target("rdrnd")
#include <immintrin.h>
]], [[ unsigned long long x; _rdrand64_step(&x); ]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_RDRAND], [1], [rdrand is available])
AX_CHECK_COMPILE_FLAG([-mrdrnd], [CFLAGS_RDRAND="-mrdrnd"])
],
[AC_MSG_RESULT(no)])
CFLAGS="$oldcflags"
2013-04-25 19:47:21 -07:00
])
2013-04-25 09:37:04 -07:00
2019-10-23 10:30:48 -07:00
AC_SUBST(CFLAGS_ARMCRYPTO)
2015-10-10 10:23:39 -07:00
AC_SUBST(CFLAGS_MMX)
AC_SUBST(CFLAGS_SSE2)
AC_SUBST(CFLAGS_SSE3)
AC_SUBST(CFLAGS_SSSE3)
2015-10-31 22:09:04 -07:00
AC_SUBST(CFLAGS_SSE41)
2016-03-17 02:45:11 -07:00
AC_SUBST(CFLAGS_AVX)
AC_SUBST(CFLAGS_AVX2)
2017-09-13 14:35:20 -07:00
AC_SUBST(CFLAGS_AVX512F)
2015-10-10 10:23:39 -07:00
AC_SUBST(CFLAGS_AESNI)
AC_SUBST(CFLAGS_PCLMUL)
2017-11-25 09:53:33 -07:00
AC_SUBST(CFLAGS_RDRAND)
2015-10-10 10:23:39 -07:00
2021-09-16 11:01:24 -07:00
AC_CHECK_HEADERS([sys/mman.h sys/param.h sys/random.h intrin.h sys/auxv.h])
2023-04-16 06:15:53 -07:00
AC_CHECK_HEADERS([CommonCrypto/CommonRandom.h])
2023-07-19 09:27:36 -07:00
AC_CHECK_HEADERS([cet.h])
2014-01-01 07:56:50 -07:00
2017-02-28 10:20:24 -07:00
AC_MSG_CHECKING([if _xgetbv() is available])
2017-04-14 10:01:04 -07:00
AC_LINK_IFELSE(
2017-02-28 10:20:24 -07:00
[AC_LANG_PROGRAM([[ #include <intrin.h> ]], [[ (void) _xgetbv(0) ]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE__XGETBV], [1], [_xgetbv() is available])],
[AC_MSG_RESULT(no)])
2013-01-19 17:02:02 -07:00
dnl Checks for typedefs, structures, and compiler characteristics.
2013-09-24 13:23:48 -07:00
AC_C_INLINE
2016-03-24 01:24:35 -07:00
AS_CASE([$host_cpu],
2016-03-24 11:11:21 -07:00
[i?86|amd64|x86_64],
2016-03-24 01:24:35 -07:00
[ac_cv_c_bigendian=no]
)
2013-04-19 16:25:13 -07:00
AC_C_BIGENDIAN(
AC_DEFINE(NATIVE_BIG_ENDIAN, 1, [machine is bigendian]),
AC_DEFINE(NATIVE_LITTLE_ENDIAN, 1, [machine is littleendian]),
2016-03-24 01:05:09 -07:00
AC_MSG_ERROR([unknown endianness]),
AC_MSG_ERROR([universal endianness is not supported - compile separately and use lipo(1)])
2013-04-19 16:25:13 -07:00
)
2013-01-19 17:02:02 -07:00
2013-04-27 13:40:22 -07:00
AC_MSG_CHECKING(whether __STDC_LIMIT_MACROS is required)
2021-04-08 02:06:56 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2013-04-27 13:40:22 -07:00
#include <limits.h>
#include <stdint.h>
]], [[
(void) SIZE_MAX;
(void) UINT64_MAX;
]])],
2013-04-27 13:42:55 -07:00
[AC_MSG_RESULT(no)],
2013-04-27 13:40:22 -07:00
[AC_MSG_RESULT(yes)
2013-04-27 13:42:55 -07:00
CPPFLAGS="$CPPFLAGS -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS"
2013-04-27 13:40:22 -07:00
])
2017-12-30 17:23:58 -07:00
AC_MSG_CHECKING(whether we can use inline asm code)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
]], [[
int a = 42;
int *pnt = &a;
__asm__ __volatile__ ("" : : "r"(pnt) : "memory");
]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_INLINE_ASM], [1], [inline asm code can be used])]
[AC_MSG_RESULT(no)]
)
2013-04-27 10:21:32 -07:00
HAVE_AMD64_ASM_V=0
2013-04-28 09:41:00 -07:00
AS_IF([test "$enable_asm" != "no"],[
2015-11-04 15:29:27 -07:00
AC_MSG_CHECKING(whether we can use x86_64 asm code)
2019-08-16 04:09:57 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2013-04-28 09:41:00 -07:00
]], [[
2013-04-27 10:21:32 -07:00
#if defined(__amd64) || defined(__amd64__) || defined(__x86_64__)
2014-08-04 16:24:11 -07:00
# if defined(__CYGWIN__) || defined(__MINGW32__) || defined(__MINGW64__) || defined(_WIN32) || defined(_WIN64)
# error Windows x86_64 calling conventions are not supported yet
# endif
2013-04-27 10:21:32 -07:00
/* neat */
#else
2014-08-04 16:29:13 -07:00
# error !x86_64
2013-04-27 10:21:32 -07:00
#endif
2015-12-06 10:30:00 -07:00
unsigned char i = 0, o = 0, t;
__asm__ __volatile__ ("pxor %%xmm12, %%xmm6 \n"
"movb (%[i]), %[t] \n"
"addb %[t], (%[o]) \n"
: [t] "=&r"(t)
: [o] "D"(&o), [i] "S"(&i)
: "memory", "flags", "cc");
2013-04-27 10:21:32 -07:00
]])],
2013-04-28 09:41:00 -07:00
[AC_MSG_RESULT(yes)
2015-11-04 15:29:27 -07:00
AC_DEFINE([HAVE_AMD64_ASM], [1], [x86_64 asm code can be used])
2013-04-28 09:41:00 -07:00
HAVE_AMD64_ASM_V=1],
[AC_MSG_RESULT(no)])
])
2013-04-27 10:21:32 -07:00
AM_CONDITIONAL([HAVE_AMD64_ASM], [test $HAVE_AMD64_ASM_V = 1])
AC_SUBST(HAVE_AMD64_ASM_V)
2015-11-04 15:29:27 -07:00
HAVE_AVX_ASM_V=0
AS_IF([test "$enable_asm" != "no"],[
AC_MSG_CHECKING(whether we can assemble AVX opcodes)
2019-08-16 04:09:57 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2015-11-04 15:29:27 -07:00
]], [[
#if defined(__amd64) || defined(__amd64__) || defined(__x86_64__)
# if defined(__CYGWIN__) || defined(__MINGW32__) || defined(__MINGW64__) || defined(_WIN32) || defined(_WIN64)
# error Windows x86_64 calling conventions are not supported yet
# endif
/* neat */
#else
# error !x86_64
#endif
2015-11-13 17:21:55 -07:00
__asm__ __volatile__ ("vpunpcklqdq %xmm0,%xmm13,%xmm0");
2015-11-04 15:29:27 -07:00
]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_AVX_ASM], [1], [AVX opcodes are supported])
HAVE_AVX_ASM_V=1],
[AC_MSG_RESULT(no)])
])
AM_CONDITIONAL([HAVE_AVX_ASM], [test $HAVE_AVX_ASM_V = 1])
AC_SUBST(HAVE_AVX_ASM_V)
2013-03-17 18:40:14 -07:00
AC_MSG_CHECKING(for 128-bit arithmetic)
2013-04-21 10:14:38 -07:00
HAVE_TI_MODE_V=0
2013-03-17 18:40:14 -07:00
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
2017-12-19 13:41:56 -07:00
#if !defined(__clang__) && !defined(__GNUC__) && !defined(__SIZEOF_INT128__)
2015-11-15 10:16:15 -07:00
# error mode(TI) is a gcc extension, and __int128 is not available
2013-04-21 10:14:38 -07:00
#endif
2018-01-07 07:40:27 -07:00
#if defined(__clang__) && !defined(__x86_64__) && !defined(__aarch64__)
2015-11-15 10:16:15 -07:00
# error clang does not properly handle the 128-bit type on 32-bit systems
2013-04-21 10:14:38 -07:00
#endif
2013-09-21 20:07:50 -07:00
#ifndef NATIVE_LITTLE_ENDIAN
2015-11-15 10:16:15 -07:00
# error libsodium currently expects a little endian CPU for the 128-bit type
2013-09-21 20:07:50 -07:00
#endif
2017-12-26 16:28:41 -07:00
#ifdef __EMSCRIPTEN__
# error emscripten currently doesn't support some operations on integers larger than 64 bits
#endif
2015-11-15 10:16:15 -07:00
#include <stddef.h>
2013-09-08 02:15:12 -07:00
#include <stdint.h>
2015-11-15 10:16:15 -07:00
#if defined(__SIZEOF_INT128__)
typedef unsigned __int128 uint128_t;
#else
2013-03-17 18:40:14 -07:00
typedef unsigned uint128_t __attribute__((mode(TI)));
2015-11-15 10:16:15 -07:00
#endif
2013-09-08 02:25:48 -07:00
void fcontract(uint128_t *t) {
*t += 0x8000000000000 - 1;
2017-12-26 16:10:18 -07:00
*t *= *t;
*t >>= 84;
2013-09-08 02:15:12 -07:00
}
]], [[
(void) fcontract;
2013-03-17 18:40:14 -07:00
]])],
[AC_MSG_RESULT(yes)
2013-04-19 07:08:43 -07:00
AC_DEFINE([HAVE_TI_MODE], [1], [gcc TI mode is available])
2013-04-21 10:14:38 -07:00
HAVE_TI_MODE_V=1],
2013-03-17 18:40:14 -07:00
[AC_MSG_RESULT(no)])
2013-04-21 10:14:38 -07:00
AM_CONDITIONAL([HAVE_TI_MODE], [test $HAVE_TI_MODE_V = 1])
AC_SUBST(HAVE_TI_MODE_V)
2013-03-17 18:40:14 -07:00
2013-04-25 18:59:55 -07:00
HAVE_CPUID_V=0
2019-02-14 06:41:09 -07:00
AS_IF([test "$enable_asm" != "no"],[
2014-05-02 14:40:39 -07:00
AC_MSG_CHECKING(for cpuid instruction)
2019-08-16 03:28:42 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
2014-05-02 21:24:31 -07:00
unsigned int cpu_info[4];
__asm__ __volatile__ ("xchgl %%ebx, %k1; cpuid; xchgl %%ebx, %k1" :
"=a" (cpu_info[0]), "=&r" (cpu_info[1]),
"=c" (cpu_info[2]), "=d" (cpu_info[3]) :
2014-05-06 12:31:08 -07:00
"0" (0U), "2" (0U));
2014-05-02 14:40:39 -07:00
]])],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_CPUID], [1], [cpuid instruction is available])
HAVE_CPUID_V=1],
[AC_MSG_RESULT(no)])
])
2013-04-25 18:59:55 -07:00
AC_SUBST(HAVE_CPUID_V)
2016-03-22 13:26:39 -07:00
asm_hide_symbol="unsupported"
2019-02-14 06:41:09 -07:00
AS_IF([test "$enable_asm" != "no"],[
2016-03-22 13:26:39 -07:00
AC_MSG_CHECKING(if the .private_extern asm directive is supported)
2016-03-24 02:55:47 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
2016-03-22 12:42:07 -07:00
__asm__ __volatile__ (".private_extern dummy_symbol \n"
".private_extern _dummy_symbol \n"
".globl dummy_symbol \n"
".globl _dummy_symbol \n"
"dummy_symbol: \n"
"_dummy_symbol: \n"
" nop \n"
);
]])],
[AC_MSG_RESULT(yes)
2016-03-22 13:26:39 -07:00
asm_hide_symbol=".private_extern"],
2016-03-22 12:42:07 -07:00
[AC_MSG_RESULT(no)])
2016-03-22 13:26:39 -07:00
AC_MSG_CHECKING(if the .hidden asm directive is supported)
2016-03-24 02:55:47 -07:00
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
2016-03-22 13:26:39 -07:00
__asm__ __volatile__ (".hidden dummy_symbol \n"
".hidden _dummy_symbol \n"
".globl dummy_symbol \n"
".globl _dummy_symbol \n"
"dummy_symbol: \n"
"_dummy_symbol: \n"
" nop \n"
);
]])],
[AC_MSG_RESULT(yes)
2016-03-24 02:55:47 -07:00
AS_IF([test "$asm_hide_symbol" = "unsupported"],
[asm_hide_symbol=".hidden"],
[AC_MSG_NOTICE([unable to reliably tag symbols as private])
asm_hide_symbol="unsupported"])
],
2016-03-22 13:26:39 -07:00
[AC_MSG_RESULT(no)])
AS_IF([test "$asm_hide_symbol" != "unsupported"],[
AC_DEFINE_UNQUOTED([ASM_HIDE_SYMBOL], [$asm_hide_symbol], [directive to hide symbols])
2016-03-22 12:42:07 -07:00
])
2016-03-22 13:26:39 -07:00
])
2016-03-22 12:42:07 -07:00
2014-06-20 21:09:18 -07:00
AC_MSG_CHECKING(if weak symbols are supported)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
2016-04-13 00:22:51 -07:00
#if !defined(__ELF__) && !defined(__APPLE_CC__)
# error Support for weak symbols may not be available
#endif
2014-06-20 21:09:18 -07:00
__attribute__((weak)) void __dummy(void *x) { }
void f(void *x) { __dummy(x); }
]], [[ ]]
)],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_WEAK_SYMBOLS], [1], [weak symbols are supported])],
[AC_MSG_RESULT(no)])
2016-12-16 08:37:12 -07:00
AC_MSG_CHECKING(if atomic operations are supported)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
static volatile int _sodium_lock;
__sync_lock_test_and_set(&_sodium_lock, 1);
__sync_lock_release(&_sodium_lock);
]]
)],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_ATOMIC_OPS], [1], [atomic operations are supported])],
[AC_MSG_RESULT(no)])
2022-03-07 08:47:43 -07:00
AC_MSG_CHECKING(if C11 memory fences are supported)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
#include <stdatomic.h>
]], [[
atomic_thread_fence(memory_order_acquire);
]]
)],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_C11_MEMORY_FENCES], [1], [C11 memory fences are supported])],
[AC_MSG_RESULT(no)])
AC_MSG_CHECKING(if gcc memory fences are supported)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
__atomic_thread_fence(__ATOMIC_ACQUIRE);
]]
)],
[AC_MSG_RESULT(yes)
AC_DEFINE([HAVE_GCC_MEMORY_FENCES], [1], [GCC memory fences are supported])],
[AC_MSG_RESULT(no)])
2013-01-21 20:18:15 -07:00
dnl Checks for functions and headers
2017-11-09 18:22:38 -07:00
AC_FUNC_ALLOCA
2014-04-22 18:12:49 -07:00
AS_IF([test "x$EMSCRIPTEN" = "x"],[
2019-04-18 15:51:06 -07:00
AC_CHECK_FUNCS([arc4random arc4random_buf])
2021-07-19 03:12:56 -07:00
AS_IF([test "x$WASI" = "x"],[
AC_CHECK_FUNCS([mmap mlock madvise mprotect])
2021-09-16 11:01:24 -07:00
AC_CHECK_FUNCS([raise])
AC_CHECK_FUNCS([sysconf])
2021-07-19 03:12:56 -07:00
])
2019-04-18 15:51:06 -07:00
AC_MSG_CHECKING(for getrandom with a standard API)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
#include <stdlib.h>
#ifdef HAVE_UNISTD_H
# include <unistd.h>
#endif
#ifdef HAVE_SYS_RANDOM_H
# include <sys/random.h>
#endif
]], [[
unsigned char buf;
2019-10-23 09:11:12 -07:00
if (&getrandom != NULL) {
(void) getrandom((void *) &buf, 1U, 0U);
}
2019-04-18 15:51:06 -07:00
]])],
[AC_MSG_RESULT(yes)
AC_CHECK_FUNCS([getrandom])],
[AC_MSG_RESULT(no)
])
AC_MSG_CHECKING(for getentropy with a standard API)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
#include <stdlib.h>
#ifdef HAVE_UNISTD_H
# include <unistd.h>
#endif
#ifdef HAVE_SYS_RANDOM_H
# include <sys/random.h>
#endif
]], [[
unsigned char buf;
2019-10-23 09:11:12 -07:00
if (&getentropy != NULL) {
(void) getentropy((void *) &buf, 1U);
}
2019-04-18 15:51:06 -07:00
]])],
[AC_MSG_RESULT(yes)
AC_CHECK_FUNCS([getentropy])],
[AC_MSG_RESULT(no)
])
2014-04-22 18:12:49 -07:00
])
2021-05-22 02:56:52 -07:00
AS_IF([test "x$WASI" = "x"],[
AC_CHECK_FUNCS([getpid])
2023-09-12 05:33:29 -07:00
AC_CHECK_FUNCS([getauxval elf_aux_info])
2021-05-22 02:56:52 -07:00
])
2023-02-15 11:42:08 -07:00
AC_CHECK_FUNCS([posix_memalign nanosleep clock_gettime])
2021-07-19 03:12:56 -07:00
AS_IF([test "x$WASI" = "x"],[
2022-11-21 07:26:18 -07:00
AC_CHECK_FUNCS([memset_s explicit_bzero memset_explicit explicit_memset])
2021-07-19 03:12:56 -07:00
])
2013-01-21 20:18:15 -07:00
2013-02-04 18:16:46 -07:00
AC_SUBST([LIBTOOL_EXTRA_FLAGS])
2013-01-19 17:02:02 -07:00
2014-11-24 18:19:55 -07:00
TEST_LDFLAGS=''
2014-11-22 15:31:43 -07:00
AS_IF([test "x$EMSCRIPTEN" != "x"],[
EXEEXT=.js
2016-04-02 03:18:52 -07:00
TEST_LDFLAGS='--memory-init-file 0 --pre-js pre.js.inc -s RESERVED_FUNCTION_POINTERS=8'
2014-11-22 15:31:43 -07:00
])
2014-11-24 18:19:55 -07:00
AC_SUBST(TEST_LDFLAGS)
2015-01-15 03:12:58 -07:00
AM_CONDITIONAL([EMSCRIPTEN], [test "x$EMSCRIPTEN" != "x"])
2019-04-08 12:45:08 -07:00
AM_CONDITIONAL([WASI], [test "x$WASI" != "x"])
2014-11-22 15:31:43 -07:00
2016-07-02 01:05:43 -07:00
AC_DEFINE([CONFIGURED], [1], [the build system was properly configured])
2013-01-19 17:37:13 -07:00
dnl Libtool.
2021-03-16 11:30:52 -07:00
LT_INIT([dlopen win32-dll])
2013-04-23 21:33:58 -07:00
gl_LD_OUTPUT_DEF
2013-01-19 17:37:13 -07:00
2013-01-19 17:02:02 -07:00
dnl Output.
2014-07-31 22:13:45 -07:00
AH_VERBATIM([NDEBUG], [/* Always evaluate assert() calls */
2013-01-19 17:02:02 -07:00
#ifdef NDEBUG
#/**/undef/**/ NDEBUG
#endif])
2017-10-05 01:31:19 -07:00
AS_IF([test "x$ENABLE_CWFLAGS" = "xyes"], [
CFLAGS="$CFLAGS $CWFLAGS"
])
2013-01-19 17:02:02 -07:00
AC_CONFIG_FILES([Makefile
2017-07-24 05:27:33 -07:00
builds/Makefile
2013-12-31 08:16:12 -07:00
dist-build/Makefile
2014-11-29 14:53:20 -07:00
libsodium.pc
2014-12-22 17:14:22 -07:00
libsodium-uninstalled.pc
2013-01-19 17:02:02 -07:00
src/Makefile
2013-01-20 12:14:35 -07:00
src/libsodium/Makefile
src/libsodium/include/Makefile
2013-01-20 15:03:05 -07:00
src/libsodium/include/sodium/version.h
2013-02-08 13:21:32 -07:00
test/default/Makefile
2013-01-20 15:03:05 -07:00
test/Makefile
])
2013-01-19 17:02:02 -07:00
AC_OUTPUT