2013-08-27 02:37:08 -04:00
|
|
|
AC_PREREQ([2.65])
|
2015-11-01 09:45:36 -05:00
|
|
|
AC_INIT([libsodium],[1.0.6],
|
2013-04-27 14:42:27 -04:00
|
|
|
[https://github.com/jedisct1/libsodium/issues],
|
2013-04-27 19:39:23 -04:00
|
|
|
[libsodium],
|
2013-04-27 14:42:27 -04:00
|
|
|
[https://github.com/jedisct1/libsodium])
|
2014-11-02 19:49:17 -05:00
|
|
|
AC_CONFIG_AUX_DIR([build-aux])
|
2013-01-19 19:02:02 -05:00
|
|
|
AC_CONFIG_MACRO_DIR([m4])
|
2013-04-18 09:24:07 -04:00
|
|
|
AC_CONFIG_SRCDIR([src/libsodium/sodium/version.c])
|
2013-01-19 19:02:02 -05:00
|
|
|
AC_CANONICAL_HOST
|
2013-08-05 14:19:13 -04:00
|
|
|
AM_INIT_AUTOMAKE([1.11 dist-bzip2 tar-ustar foreign subdir-objects])
|
2013-01-20 21:06:07 -05:00
|
|
|
m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
|
2013-01-19 19:02:02 -05:00
|
|
|
AM_MAINTAINER_MODE
|
|
|
|
AM_DEP_TRACK
|
|
|
|
|
|
|
|
AC_SUBST(VERSION)
|
|
|
|
ISODATE=`date +%Y-%m-%d`
|
|
|
|
AC_SUBST(ISODATE)
|
|
|
|
|
2015-11-14 09:33:15 -05:00
|
|
|
SODIUM_LIBRARY_VERSION_MAJOR=9
|
2015-11-01 06:23:21 -05:00
|
|
|
SODIUM_LIBRARY_VERSION_MINOR=0
|
2015-11-14 09:33:15 -05:00
|
|
|
DLL_VERSION=8
|
|
|
|
SODIUM_LIBRARY_VERSION=18:0:0
|
2014-05-12 17:07:48 -04: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 18:22:43 -04:00
|
|
|
AC_SUBST(SODIUM_LIBRARY_VERSION_MAJOR)
|
|
|
|
AC_SUBST(SODIUM_LIBRARY_VERSION_MINOR)
|
2013-01-20 20:51:57 -05:00
|
|
|
AC_SUBST(SODIUM_LIBRARY_VERSION)
|
2013-04-24 00:24:35 -04:00
|
|
|
AC_SUBST(DLL_VERSION)
|
2013-01-20 20:51:57 -05:00
|
|
|
|
2013-07-08 01:25:20 -04:00
|
|
|
LX_CFLAGS=${CFLAGS-NONE}
|
|
|
|
|
2014-12-21 03:51:32 -05:00
|
|
|
dnl Path check
|
|
|
|
|
|
|
|
AS_IF([test pwd | fgrep ' ' > /dev/null 2>&1],
|
|
|
|
[AC_MSG_WARN([The build directory contains whitespaces - This can cause tests/installation to fail due to limitations of some libtool versions])]
|
|
|
|
)
|
|
|
|
|
2013-07-08 00:46:44 -04:00
|
|
|
dnl Switches
|
|
|
|
|
2013-07-08 01:20:27 -04:00
|
|
|
AC_ARG_ENABLE(ssp,
|
2013-07-08 01:38:51 -04:00
|
|
|
[AS_HELP_STRING(--disable-ssp,Do not compile with -fstack-protector)],
|
2013-07-08 01:20:27 -04:00
|
|
|
[
|
|
|
|
AS_IF([test "x$enableval" = "xno"], [
|
|
|
|
enable_ssp="no"
|
|
|
|
], [
|
|
|
|
enable_ssp="yes"
|
|
|
|
])
|
|
|
|
],
|
|
|
|
[
|
|
|
|
enable_ssp="yes"
|
|
|
|
])
|
|
|
|
|
2013-07-08 00:46:44 -04:00
|
|
|
AC_ARG_ENABLE(asm,
|
|
|
|
[AS_HELP_STRING(--disable-asm,Disable assembly implementations)],
|
|
|
|
[
|
|
|
|
AS_IF([test "x$enableval" = "xno"], [
|
|
|
|
enable_asm="no"
|
|
|
|
], [
|
|
|
|
enable_asm="yes"
|
|
|
|
])
|
|
|
|
],
|
|
|
|
[
|
|
|
|
enable_asm="yes"
|
|
|
|
])
|
|
|
|
|
|
|
|
AS_IF([test "x$EMSCRIPTEN" != "x"],[
|
|
|
|
enable_asm="no"
|
|
|
|
AC_MSG_WARN([compiling to javascript - asm implementations disabled])
|
|
|
|
])
|
|
|
|
|
2013-07-08 01:29:58 -04:00
|
|
|
AC_ARG_ENABLE(pie,
|
2013-07-08 01:35:34 -04:00
|
|
|
[AS_HELP_STRING(--disable-pie,Do not produce position independent executables)],
|
2013-07-08 01:29:58 -04:00
|
|
|
enable_pie=$enableval, enable_pie="maybe")
|
|
|
|
|
2014-08-04 17:30:07 -04:00
|
|
|
AS_CASE([$host_os], [mingw*|cygwin*|msys], [enable_pie="no"])
|
2013-09-09 01:06:27 -04:00
|
|
|
|
2013-07-08 00:46:44 -04:00
|
|
|
AC_ARG_ENABLE(blocking-random,
|
2014-12-23 14:24:23 -05:00
|
|
|
[AS_HELP_STRING(--enable-blocking-random,Enable this switch only if /dev/urandom is totally broken on the target platform)],
|
2013-08-18 16:06:00 -04:00
|
|
|
[
|
|
|
|
AS_IF([test "x$enableval" = "xyes"], [
|
2014-12-23 14:24:23 -05:00
|
|
|
AC_DEFINE([USE_BLOCKING_RANDOM], [1], [/dev/urandom is insecure on the target platform])
|
2013-08-18 16:06:00 -04:00
|
|
|
])
|
|
|
|
])
|
2013-07-08 00:46:44 -04:00
|
|
|
|
2014-07-09 23:24:04 -04:00
|
|
|
AC_ARG_ENABLE(minimal,
|
|
|
|
[AS_HELP_STRING(--enable-minimal,
|
2014-07-14 21:43:46 -04:00
|
|
|
[Only compile the minimum set of functions required for the high-level API])],
|
2014-07-09 23:24:04 -04:00
|
|
|
[
|
|
|
|
AS_IF([test "x$enableval" = "xyes"], [
|
|
|
|
enable_minimal="yes"
|
|
|
|
], [
|
|
|
|
enable_minimal="no"
|
|
|
|
])
|
|
|
|
],
|
|
|
|
[
|
|
|
|
enable_minimal="no"
|
|
|
|
])
|
|
|
|
AM_CONDITIONAL([MINIMAL], [test x$enable_minimal = xyes])
|
|
|
|
|
2013-07-08 00:46:44 -04: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"
|
|
|
|
])
|
|
|
|
])
|
|
|
|
|
2013-07-08 01:25:20 -04:00
|
|
|
AC_ARG_ENABLE(debug,
|
|
|
|
[AS_HELP_STRING(--enable-debug,For maintainers only - please do not use)],
|
|
|
|
[
|
2013-08-18 16:06:00 -04:00
|
|
|
AS_IF([test "x$enableval" = "xyes"], [
|
|
|
|
AS_IF([test "x$LX_CFLAGS" = "xNONE"], [
|
|
|
|
nxflags=""
|
|
|
|
for flag in `echo $CFLAGS`; do
|
2013-09-08 13:44:07 -04:00
|
|
|
AS_CASE([$flag],
|
|
|
|
[-O*], [ ],
|
|
|
|
[-g*], [ ],
|
|
|
|
[*], [AS_VAR_APPEND([nxflags], [" $flag"])])
|
2013-08-18 16:06:00 -04:00
|
|
|
done
|
|
|
|
CFLAGS="$nxflags -O0 -g3"
|
|
|
|
])
|
|
|
|
CPPFLAGS="$CPPFLAGS -DDEBUG=1"
|
2013-07-08 01:25:20 -04:00
|
|
|
])
|
|
|
|
])
|
|
|
|
|
2013-07-08 00:46:44 -04:00
|
|
|
AC_SUBST([MAINT])
|
|
|
|
|
|
|
|
dnl Checks
|
|
|
|
|
2013-01-19 19:02:02 -05:00
|
|
|
AC_PROG_CC_C99
|
2013-04-27 13:21:32 -04:00
|
|
|
AM_PROG_AS
|
2013-01-19 19:02:02 -05:00
|
|
|
AC_USE_SYSTEM_EXTENSIONS
|
2014-11-02 22:24:08 -05:00
|
|
|
|
2015-08-02 07:53:22 -04:00
|
|
|
AC_CHECK_DEFINE([__native_client__], [NATIVECLIENT="yes"], [])
|
|
|
|
|
2015-08-01 21:36:52 -04:00
|
|
|
AC_CHECK_DEFINE([_FORTIFY_SOURCE], [], [
|
|
|
|
AX_CHECK_COMPILE_FLAG([-D_FORTIFY_SOURCE=2],
|
|
|
|
[CPPFLAGS="$CPPFLAGS -D_FORTIFY_SOURCE=2"])
|
|
|
|
])
|
2013-01-19 19:02:02 -05:00
|
|
|
|
2013-04-24 11:46:39 -04:00
|
|
|
AX_CHECK_COMPILE_FLAG([-fvisibility=hidden],
|
|
|
|
[CFLAGS="$CFLAGS -fvisibility=hidden"])
|
|
|
|
|
2014-08-04 17:30:07 -04:00
|
|
|
AS_CASE([$host_os], [cygwin*|mingw*|msys|pw32*|cegcc*], [ ], [
|
|
|
|
AX_CHECK_COMPILE_FLAG([-fPIC], [
|
|
|
|
AX_CHECK_LINK_FLAG([-fPIC],
|
|
|
|
[CFLAGS="$CFLAGS -fPIC"]
|
|
|
|
)
|
|
|
|
])
|
2013-04-24 16:08:25 -04:00
|
|
|
])
|
2013-01-19 19:02:02 -05:00
|
|
|
|
|
|
|
AS_IF([test "$enable_pie" != "no"],[
|
|
|
|
AX_CHECK_COMPILE_FLAG([-fPIE], [
|
2015-01-15 10:21:09 -05:00
|
|
|
AX_CHECK_LINK_FLAG([-fPIE],
|
|
|
|
[AX_CHECK_LINK_FLAG([-pie],
|
|
|
|
[CFLAGS="$CFLAGS -fPIE"
|
|
|
|
LDFLAGS="$LDFLAGS -pie"])
|
2013-01-19 19:02:02 -05:00
|
|
|
])
|
|
|
|
])
|
|
|
|
])
|
|
|
|
|
|
|
|
AX_CHECK_COMPILE_FLAG([-fno-strict-aliasing], [CFLAGS="$CFLAGS -fno-strict-aliasing"])
|
2014-11-25 15:19:08 -05:00
|
|
|
AX_CHECK_COMPILE_FLAG([-fno-strict-overflow], [CFLAGS="$CFLAGS -fno-strict-overflow"], [
|
|
|
|
AX_CHECK_COMPILE_FLAG([-fwrapv], [CFLAGS="$CFLAGS -fwrapv"])
|
|
|
|
])
|
2013-01-19 19:02:02 -05:00
|
|
|
|
2014-02-22 20:07:52 -05:00
|
|
|
LIBTOOL_OLD_FLAGS="$LIBTOOL_EXTRA_FLAGS"
|
|
|
|
LIBTOOL_EXTRA_FLAGS="$LIBTOOL_EXTRA_FLAGS -version-info $SODIUM_LIBRARY_VERSION"
|
2014-02-20 11:54:05 -05:00
|
|
|
AC_ARG_ENABLE(soname-versions,
|
2014-09-14 16:56:02 -04:00
|
|
|
[AC_HELP_STRING([--enable-soname-versions], [enable soname versions (must be disabled for Android) (default: enabled)])],
|
2014-02-20 11:54:05 -05:00
|
|
|
[
|
2015-10-10 14:10:26 -04:00
|
|
|
AS_IF([test "x$enableval" = "xno"], [
|
2014-02-22 20:07:52 -05:00
|
|
|
LIBTOOL_EXTRA_FLAGS="$LIBTOOL_OLD_FLAGS -avoid-version"
|
2014-02-20 11:54:05 -05:00
|
|
|
])
|
|
|
|
]
|
|
|
|
)
|
2013-07-08 01:20:27 -04:00
|
|
|
|
2013-09-08 13:44:07 -04:00
|
|
|
AS_CASE([$host_os],
|
2014-08-04 17:30:07 -04:00
|
|
|
[cygwin*|mingw*|msys|pw32*|cegcc*], [
|
2013-01-19 19:02:02 -05:00
|
|
|
AX_CHECK_LINK_FLAG([-Wl,--dynamicbase], [LDFLAGS="$LDFLAGS -Wl,--dynamicbase"])
|
|
|
|
AX_CHECK_LINK_FLAG([-Wl,--nxcompat], [LDFLAGS="$LDFLAGS -Wl,--nxcompat"])
|
2013-09-08 13:44:07 -04:00
|
|
|
])
|
2013-07-08 01:20:27 -04:00
|
|
|
|
|
|
|
AS_IF([test "x$enable_ssp" != "xno"],[
|
2013-09-08 13:44:07 -04:00
|
|
|
|
|
|
|
AS_CASE([$host_os],
|
2014-08-04 17:30:07 -04:00
|
|
|
[cygwin*|mingw*|msys|pw32*|cegcc*], [ ],
|
2014-09-14 16:25:29 -04:00
|
|
|
[*], [
|
2013-01-19 19:02:02 -05:00
|
|
|
AX_CHECK_COMPILE_FLAG([-fstack-protector], [
|
|
|
|
AX_CHECK_LINK_FLAG([-fstack-protector],
|
|
|
|
[CFLAGS="$CFLAGS -fstack-protector"]
|
|
|
|
)
|
|
|
|
])
|
2013-09-08 13:44:07 -04:00
|
|
|
])
|
2013-07-08 01:20:27 -04:00
|
|
|
])
|
2013-01-19 19:02:02 -05:00
|
|
|
|
|
|
|
AX_CHECK_COMPILE_FLAG([-Winit-self], [CFLAGS="$CFLAGS -Winit-self"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([-Wwrite-strings], [CFLAGS="$CFLAGS -Wwrite-strings"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([-Wdiv-by-zero], [CFLAGS="$CFLAGS -Wdiv-by-zero"])
|
2013-01-21 23:50:50 -05:00
|
|
|
AX_CHECK_COMPILE_FLAG([-Wsometimes-uninitialized], [CFLAGS="$CFLAGS -Wsometimes-uninitialized"])
|
2013-01-19 19:02:02 -05:00
|
|
|
|
|
|
|
AC_ARG_VAR([CWFLAGS], [define to compilation flags for generating extra warnings])
|
|
|
|
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wall], [CWFLAGS="$CWFLAGS -Wall"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wextra], [CWFLAGS="$CWFLAGS -Wextra"])
|
|
|
|
|
|
|
|
AC_MSG_CHECKING(for clang)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[
|
|
|
|
#ifndef __clang__
|
|
|
|
be sad
|
|
|
|
#endif
|
|
|
|
]])],
|
|
|
|
[AC_MSG_RESULT(yes)
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wno-unknown-warning-option],
|
2013-04-27 01:00:00 -04:00
|
|
|
[CWFLAGS="$CWFLAGS -Wno-unknown-warning-option"])
|
|
|
|
],
|
2013-01-19 19:02:02 -05:00
|
|
|
[AC_MSG_RESULT(no)
|
|
|
|
])
|
|
|
|
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wbad-function-cast], [CWFLAGS="$CWFLAGS -Wbad-function-cast"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wcast-align], [CWFLAGS="$CWFLAGS -Wcast-align"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wcast-qual], [CWFLAGS="$CWFLAGS -Wcast-qual"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wchar-subscripts], [CWFLAGS="$CWFLAGS -Wchar-subscripts"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wcomment], [CWFLAGS="$CWFLAGS -Wcomment"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wfloat-equal], [CWFLAGS="$CWFLAGS -Wfloat-equal"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wformat=2], [CWFLAGS="$CWFLAGS -Wformat=2"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wimplicit], [CWFLAGS="$CWFLAGS -Wimplicit"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmissing-declarations], [CWFLAGS="$CWFLAGS -Wmissing-declarations"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmissing-prototypes], [CWFLAGS="$CWFLAGS -Wmissing-prototypes"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wnormalized=id], [CWFLAGS="$CWFLAGS -Wnormalized=id"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Woverride-init], [CWFLAGS="$CWFLAGS -Woverride-init"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wparentheses], [CWFLAGS="$CWFLAGS -Wparentheses"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wpointer-arith], [CWFLAGS="$CWFLAGS -Wpointer-arith"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wredundant-decls], [CWFLAGS="$CWFLAGS -Wredundant-decls"])
|
|
|
|
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"])
|
|
|
|
|
|
|
|
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 19:37:13 -05:00
|
|
|
LT_INIT
|
|
|
|
AC_SUBST(LIBTOOL_DEPS)
|
|
|
|
|
2013-01-19 19:02:02 -05:00
|
|
|
AC_ARG_VAR([AR], [path to the ar utility])
|
|
|
|
AC_CHECK_TOOL([AR], [ar], [ar])
|
|
|
|
|
2013-04-25 12:37:04 -04:00
|
|
|
dnl Checks for headers
|
2013-04-27 01:53:07 -04:00
|
|
|
|
2014-04-22 21:12:49 -04:00
|
|
|
AS_IF([test "x$EMSCRIPTEN" = "x"],[
|
2014-05-09 23:26:43 -04:00
|
|
|
|
|
|
|
AC_MSG_CHECKING(for MMX instructions set)
|
2015-10-10 14:10:26 -04:00
|
|
|
oldcflags="$CFLAGS"
|
|
|
|
AX_CHECK_COMPILE_FLAG([-mmmx], [CFLAGS="$CFLAGS -mmmx"])
|
2014-05-09 23:26:43 -04:00
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#pragma GCC target("mmx")
|
|
|
|
#include <mmintrin.h>
|
|
|
|
]], [[ __m64 x = _mm_setzero_si64(); ]])],
|
|
|
|
[AC_MSG_RESULT(yes)
|
2015-10-10 13:23:39 -04:00
|
|
|
AC_DEFINE([HAVE_MMINTRIN_H], [1], [mmx is available])
|
|
|
|
AX_CHECK_COMPILE_FLAG([-mmmx], [CFLAGS_MMX="-mmmx"])],
|
2014-05-09 23:26:43 -04:00
|
|
|
[AC_MSG_RESULT(no)])
|
2015-10-10 14:10:26 -04:00
|
|
|
CFLAGS="$oldcflags"
|
2014-05-09 23:26:43 -04:00
|
|
|
|
|
|
|
AC_MSG_CHECKING(for SSE2 instructions set)
|
2015-10-10 14:10:26 -04:00
|
|
|
oldcflags="$CFLAGS"
|
|
|
|
AX_CHECK_COMPILE_FLAG([-msse2], [CFLAGS="$CFLAGS -msse2"])
|
2014-05-09 23:26:43 -04:00
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#pragma GCC target("sse2")
|
2015-10-10 12:32:10 -04:00
|
|
|
#ifndef __SSE2__
|
|
|
|
# define __SSE2__
|
|
|
|
#endif
|
2014-05-09 23:26:43 -04:00
|
|
|
#include <emmintrin.h>
|
|
|
|
]], [[ __m128d x = _mm_setzero_pd(); ]])],
|
|
|
|
[AC_MSG_RESULT(yes)
|
2015-10-10 13:23:39 -04:00
|
|
|
AC_DEFINE([HAVE_EMMINTRIN_H], [1], [sse2 is available])
|
|
|
|
AX_CHECK_COMPILE_FLAG([-msse2], [CFLAGS_SSE2="-msse2"])],
|
2014-05-09 23:26:43 -04:00
|
|
|
[AC_MSG_RESULT(no)])
|
2015-10-10 14:10:26 -04:00
|
|
|
CFLAGS="$oldcflags"
|
2014-05-09 23:26:43 -04:00
|
|
|
|
2015-10-10 14:10:26 -04:00
|
|
|
oldcflags="$CFLAGS"
|
|
|
|
AX_CHECK_COMPILE_FLAG([-msse3], [CFLAGS="$CFLAGS -msse3"])
|
2014-05-09 23:26:43 -04:00
|
|
|
AC_MSG_CHECKING(for SSE3 instructions set)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#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 13:23:39 -04:00
|
|
|
AC_DEFINE([HAVE_PMMINTRIN_H], [1], [sse3 is available])
|
|
|
|
AX_CHECK_COMPILE_FLAG([-msse3], [CFLAGS_SSE3="-msse3"])],
|
2014-05-09 23:26:43 -04:00
|
|
|
[AC_MSG_RESULT(no)])
|
2015-10-10 14:10:26 -04:00
|
|
|
CFLAGS="$oldcflags"
|
2014-05-09 23:26:43 -04:00
|
|
|
|
2015-10-10 14:10:26 -04:00
|
|
|
oldcflags="$CFLAGS"
|
|
|
|
AX_CHECK_COMPILE_FLAG([-mssse3], [CFLAGS="$CFLAGS -mssse3"])
|
2014-05-15 01:34:27 -04:00
|
|
|
AC_MSG_CHECKING(for SSSE3 instructions set)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#pragma GCC target("ssse3")
|
|
|
|
#include <tmmintrin.h>
|
|
|
|
]], [[ __m64 x = _mm_abs_pi32(_m_from_int(0)); ]])],
|
|
|
|
[AC_MSG_RESULT(yes)
|
2015-10-10 13:23:39 -04: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 14:10:26 -04:00
|
|
|
CFLAGS="$oldcflags"
|
2015-10-10 13:23:39 -04:00
|
|
|
|
2015-10-10 14:10:26 -04:00
|
|
|
oldcflags="$CFLAGS"
|
|
|
|
AX_CHECK_COMPILE_FLAG([-msse4.1], [CFLAGS="$CFLAGS -msse4.1"])
|
2015-10-10 13:23:39 -04:00
|
|
|
AC_MSG_CHECKING(for SSE4.1 instructions set)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#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-11-01 01:09:04 -04:00
|
|
|
AX_CHECK_COMPILE_FLAG([-msse4.1], [CFLAGS_SSE41="-msse4.1"])],
|
2014-05-15 01:34:27 -04:00
|
|
|
[AC_MSG_RESULT(no)])
|
2015-10-10 14:10:26 -04:00
|
|
|
CFLAGS="$oldcflags"
|
2015-10-10 11:57:47 -04:00
|
|
|
|
2015-11-03 08:18:43 -05:00
|
|
|
oldcflags="$CFLAGS"
|
|
|
|
AX_CHECK_COMPILE_FLAG([-mavx], [CFLAGS="$CFLAGS -mavx"])
|
|
|
|
AC_MSG_CHECKING(for AVX instructions set)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#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"
|
|
|
|
|
2015-10-10 14:10:26 -04:00
|
|
|
oldcflags="$CFLAGS"
|
|
|
|
AX_CHECK_COMPILE_FLAG([-maes], [CFLAGS="$CFLAGS -maes"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([-mpclmul], [CFLAGS="$CFLAGS -mpclmul"])
|
2015-10-10 11:57:47 -04:00
|
|
|
AC_MSG_CHECKING(for AESNI instructions set and PCLMULQDQ)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#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 12:21:33 -04:00
|
|
|
AC_DEFINE([HAVE_WMMINTRIN_H], [1], [aesni is available])
|
2015-10-10 13:23:39 -04:00
|
|
|
AX_CHECK_COMPILE_FLAG([-maes], [CFLAGS_AESNI="-maes"])
|
|
|
|
AX_CHECK_COMPILE_FLAG([-mpclmul], [CFLAGS_PCLMUL="-mpclmul"])
|
2015-10-10 12:21:33 -04:00
|
|
|
],
|
2015-10-10 11:57:47 -04:00
|
|
|
[AC_MSG_RESULT(no)])
|
2015-10-10 14:10:26 -04:00
|
|
|
CFLAGS="$oldcflags"
|
|
|
|
|
2013-04-25 22:47:21 -04:00
|
|
|
])
|
2013-04-25 12:37:04 -04:00
|
|
|
|
2015-10-10 13:23:39 -04:00
|
|
|
AC_SUBST(CFLAGS_MMX)
|
|
|
|
AC_SUBST(CFLAGS_SSE2)
|
|
|
|
AC_SUBST(CFLAGS_SSE3)
|
|
|
|
AC_SUBST(CFLAGS_SSSE3)
|
2015-11-01 01:09:04 -04:00
|
|
|
AC_SUBST(CFLAGS_SSE41)
|
2015-10-10 13:23:39 -04:00
|
|
|
AC_SUBST(CFLAGS_AESNI)
|
|
|
|
AC_SUBST(CFLAGS_PCLMUL)
|
|
|
|
|
2014-01-01 09:56:50 -05:00
|
|
|
AC_CHECK_HEADERS([sys/mman.h])
|
|
|
|
|
2013-01-19 19:02:02 -05:00
|
|
|
dnl Checks for typedefs, structures, and compiler characteristics.
|
|
|
|
|
2013-09-24 16:23:48 -04:00
|
|
|
AC_C_INLINE
|
2013-04-19 19:25:13 -04:00
|
|
|
AC_C_BIGENDIAN(
|
|
|
|
AC_DEFINE(NATIVE_BIG_ENDIAN, 1, [machine is bigendian]),
|
|
|
|
AC_DEFINE(NATIVE_LITTLE_ENDIAN, 1, [machine is littleendian]),
|
|
|
|
AC_MSG_ERROR([unknown endianess]),
|
2013-10-24 15:27:50 -04:00
|
|
|
AC_MSG_ERROR([universal endianess is not supported - compile separately and use lipo(1)])
|
2013-04-19 19:25:13 -04:00
|
|
|
)
|
2013-01-19 19:02:02 -05:00
|
|
|
|
2013-04-27 16:40:22 -04:00
|
|
|
AC_MSG_CHECKING(whether __STDC_LIMIT_MACROS is required)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#include <limits.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
]], [[
|
|
|
|
(void) SIZE_MAX;
|
|
|
|
(void) UINT64_MAX;
|
|
|
|
]])],
|
2013-04-27 16:42:55 -04:00
|
|
|
[AC_MSG_RESULT(no)],
|
2013-04-27 16:40:22 -04:00
|
|
|
[AC_MSG_RESULT(yes)
|
2013-04-27 16:42:55 -04:00
|
|
|
CPPFLAGS="$CPPFLAGS -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS"
|
2013-04-27 16:40:22 -04:00
|
|
|
])
|
|
|
|
|
2013-04-27 13:21:32 -04:00
|
|
|
HAVE_AMD64_ASM_V=0
|
2013-04-28 12:41:00 -04:00
|
|
|
AS_IF([test "$enable_asm" != "no"],[
|
2015-11-04 17:29:27 -05:00
|
|
|
AC_MSG_CHECKING(whether we can use x86_64 asm code)
|
2013-04-28 12:41:00 -04:00
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
]], [[
|
2013-04-27 13:21:32 -04:00
|
|
|
#if defined(__amd64) || defined(__amd64__) || defined(__x86_64__)
|
2014-08-04 19:24:11 -04: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 13:21:32 -04:00
|
|
|
/* neat */
|
|
|
|
#else
|
2014-08-04 19:29:13 -04:00
|
|
|
# error !x86_64
|
2013-04-27 13:21:32 -04:00
|
|
|
#endif
|
2015-11-13 19:21:55 -05:00
|
|
|
__asm__ __volatile__ ("pxor %xmm12,%xmm6");
|
2013-04-27 13:21:32 -04:00
|
|
|
]])],
|
2013-04-28 12:41:00 -04:00
|
|
|
[AC_MSG_RESULT(yes)
|
2015-11-04 17:29:27 -05:00
|
|
|
AC_DEFINE([HAVE_AMD64_ASM], [1], [x86_64 asm code can be used])
|
2013-04-28 12:41:00 -04:00
|
|
|
HAVE_AMD64_ASM_V=1],
|
|
|
|
[AC_MSG_RESULT(no)])
|
|
|
|
])
|
2013-04-27 13:21:32 -04:00
|
|
|
AM_CONDITIONAL([HAVE_AMD64_ASM], [test $HAVE_AMD64_ASM_V = 1])
|
|
|
|
AC_SUBST(HAVE_AMD64_ASM_V)
|
|
|
|
|
2015-11-04 17:29:27 -05:00
|
|
|
HAVE_AVX_ASM_V=0
|
|
|
|
AS_IF([test "$enable_asm" != "no"],[
|
|
|
|
AC_MSG_CHECKING(whether we can assemble AVX opcodes)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
]], [[
|
|
|
|
#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 19:21:55 -05:00
|
|
|
__asm__ __volatile__ ("vpunpcklqdq %xmm0,%xmm13,%xmm0");
|
2015-11-04 17:29:27 -05: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 21:40:14 -04:00
|
|
|
AC_MSG_CHECKING(for 128-bit arithmetic)
|
2013-04-21 13:14:38 -04:00
|
|
|
HAVE_TI_MODE_V=0
|
2013-03-17 21:40:14 -04:00
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
2013-04-21 13:14:38 -04:00
|
|
|
#ifndef __GNUC__
|
|
|
|
# error mode(TI) is a gcc extension
|
|
|
|
#endif
|
2013-04-27 17:28:18 -04:00
|
|
|
#if defined(__clang__) && !defined(__x86_64__)
|
2015-10-18 18:24:39 -04:00
|
|
|
# error clang does not properly compile smult_curve25519_donna_c64.c
|
2013-04-21 13:14:38 -04:00
|
|
|
#endif
|
2013-09-21 23:07:50 -04:00
|
|
|
#ifndef NATIVE_LITTLE_ENDIAN
|
|
|
|
# error donna_c64 currently requires a little endian CPU
|
|
|
|
#endif
|
2015-11-04 16:07:36 -05:00
|
|
|
#ifdef __EMSCRIPTEN__
|
2014-05-20 13:53:31 -04:00
|
|
|
# error emscripten currently supports only shift operations on integers \
|
|
|
|
# larger than 64 bits
|
|
|
|
#endif
|
2013-09-08 05:15:12 -04:00
|
|
|
#include <stdint.h>
|
2013-03-17 21:40:14 -04:00
|
|
|
typedef unsigned uint128_t __attribute__((mode(TI)));
|
2013-09-08 05:25:48 -04:00
|
|
|
void fcontract(uint128_t *t) {
|
|
|
|
*t += 0x8000000000000 - 1;
|
2013-09-08 05:15:12 -04:00
|
|
|
}
|
|
|
|
]], [[
|
|
|
|
(void) fcontract;
|
2013-03-17 21:40:14 -04:00
|
|
|
]])],
|
|
|
|
[AC_MSG_RESULT(yes)
|
2013-04-19 10:08:43 -04:00
|
|
|
AC_DEFINE([HAVE_TI_MODE], [1], [gcc TI mode is available])
|
2013-04-21 13:14:38 -04:00
|
|
|
HAVE_TI_MODE_V=1],
|
2013-03-17 21:40:14 -04:00
|
|
|
[AC_MSG_RESULT(no)])
|
2013-04-21 13:14:38 -04:00
|
|
|
AM_CONDITIONAL([HAVE_TI_MODE], [test $HAVE_TI_MODE_V = 1])
|
|
|
|
AC_SUBST(HAVE_TI_MODE_V)
|
2013-03-17 21:40:14 -04:00
|
|
|
|
2013-04-25 21:59:55 -04:00
|
|
|
HAVE_CPUID_V=0
|
2014-05-02 17:40:39 -04:00
|
|
|
AS_IF([test "$enable_asm" != "no"],[
|
|
|
|
AC_MSG_CHECKING(for cpuid instruction)
|
|
|
|
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ ]], [[
|
2014-05-03 00:24:31 -04: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 15:31:08 -04:00
|
|
|
"0" (0U), "2" (0U));
|
2014-05-02 17:40:39 -04: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 21:59:55 -04:00
|
|
|
AC_SUBST(HAVE_CPUID_V)
|
|
|
|
|
2014-06-21 00:09:18 -04:00
|
|
|
AC_MSG_CHECKING(if weak symbols are supported)
|
|
|
|
AC_LINK_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
__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)])
|
|
|
|
|
2015-09-04 09:36:24 -04:00
|
|
|
AC_MSG_CHECKING(if data alignment is required)
|
|
|
|
aligned_access_required=yes
|
2013-09-08 13:39:27 -04:00
|
|
|
AS_CASE([$host_cpu],
|
|
|
|
[i*86 | x86_64 | powerpc* | s390*],
|
2015-09-04 09:36:24 -04:00
|
|
|
[aligned_access_required=no],
|
2015-09-03 20:29:34 -04:00
|
|
|
[arm*],
|
|
|
|
[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
|
|
|
|
#ifndef __ARM_FEATURE_UNALIGNED
|
2015-09-04 09:36:24 -04:00
|
|
|
# error data alignment is required
|
2015-09-03 20:29:34 -04:00
|
|
|
#endif
|
2015-09-04 09:36:24 -04:00
|
|
|
]], [[]])], [aligned_access_required=no], [])]
|
2013-09-08 13:39:27 -04:00
|
|
|
)
|
2015-09-04 09:36:24 -04:00
|
|
|
AS_IF([test "x$aligned_access_required" = "xyes"],
|
|
|
|
[AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE([CPU_ALIGNED_ACCESS_REQUIRED], [1], [data alignment is required])],
|
|
|
|
[AC_MSG_RESULT(no)])
|
2013-09-08 13:39:27 -04:00
|
|
|
|
2013-01-21 22:18:15 -05:00
|
|
|
dnl Checks for functions and headers
|
|
|
|
|
2014-04-22 21:12:49 -04:00
|
|
|
AS_IF([test "x$EMSCRIPTEN" = "x"],[
|
|
|
|
AC_CHECK_FUNCS([arc4random arc4random_buf])
|
2014-11-24 13:34:42 -05:00
|
|
|
AC_CHECK_FUNCS([mmap mlock madvise mprotect explicit_bzero])
|
2014-04-22 21:12:49 -04:00
|
|
|
])
|
2015-09-13 09:04:14 -04:00
|
|
|
AC_CHECK_FUNCS([posix_memalign getpid])
|
2013-01-21 22:18:15 -05:00
|
|
|
|
2013-02-04 20:16:46 -05:00
|
|
|
AC_SUBST([LIBTOOL_EXTRA_FLAGS])
|
2013-01-19 19:02:02 -05:00
|
|
|
|
2014-11-24 20:19:55 -05:00
|
|
|
TEST_LDFLAGS=''
|
2014-11-22 17:31:43 -05:00
|
|
|
AS_IF([test "x$EMSCRIPTEN" != "x"],[
|
|
|
|
EXEEXT=.js
|
2015-01-17 18:46:48 -05:00
|
|
|
TEST_LDFLAGS='--memory-init-file 0 --pre-js pre.js.inc -s NO_BROWSER=1 -s RESERVED_FUNCTION_POINTERS=8'
|
2014-11-22 17:31:43 -05:00
|
|
|
])
|
2014-11-24 20:19:55 -05:00
|
|
|
AC_SUBST(TEST_LDFLAGS)
|
2015-01-15 05:12:58 -05:00
|
|
|
AM_CONDITIONAL([EMSCRIPTEN], [test "x$EMSCRIPTEN" != "x"])
|
2014-11-22 17:31:43 -05:00
|
|
|
|
2015-06-22 14:02:21 -04:00
|
|
|
AM_CONDITIONAL([NATIVECLIENT], [test "x$NATIVECLIENT" != "x"])
|
|
|
|
|
2013-01-19 19:37:13 -05:00
|
|
|
dnl Libtool.
|
|
|
|
|
|
|
|
LT_INIT([dlopen])
|
2013-04-24 00:33:58 -04:00
|
|
|
AC_LIBTOOL_WIN32_DLL
|
|
|
|
gl_LD_OUTPUT_DEF
|
2013-01-19 19:37:13 -05:00
|
|
|
|
2013-01-19 19:02:02 -05:00
|
|
|
dnl Output.
|
|
|
|
|
2014-08-01 01:13:45 -04:00
|
|
|
AH_VERBATIM([NDEBUG], [/* Always evaluate assert() calls */
|
2013-01-19 19:02:02 -05:00
|
|
|
#ifdef NDEBUG
|
|
|
|
#/**/undef/**/ NDEBUG
|
|
|
|
#endif])
|
|
|
|
|
|
|
|
AC_CONFIG_FILES([Makefile
|
2013-12-31 10:16:12 -05:00
|
|
|
dist-build/Makefile
|
2014-11-29 16:53:20 -05:00
|
|
|
libsodium.pc
|
2014-12-22 19:14:22 -05:00
|
|
|
libsodium-uninstalled.pc
|
2013-09-30 16:36:31 -04:00
|
|
|
msvc-scripts/Makefile
|
2013-01-19 19:02:02 -05:00
|
|
|
src/Makefile
|
2013-01-20 14:14:35 -05:00
|
|
|
src/libsodium/Makefile
|
|
|
|
src/libsodium/include/Makefile
|
2013-01-20 17:03:05 -05:00
|
|
|
src/libsodium/include/sodium/version.h
|
2013-02-08 15:21:32 -05:00
|
|
|
test/default/Makefile
|
2013-01-20 17:03:05 -05:00
|
|
|
test/Makefile
|
|
|
|
])
|
2013-01-19 19:02:02 -05:00
|
|
|
AC_OUTPUT
|