1 AC_PREREQ([2.65])
2 AC_INIT([libsodium],[1.0.16],
3 [https://github.com/jedisct1/libsodium/issues],
4 [libsodium],
5 [https://github.com/jedisct1/libsodium])
6 AC_CONFIG_AUX_DIR([build-aux])
7 AC_CONFIG_MACRO_DIR([m4])
8 AC_CONFIG_SRCDIR([src/libsodium/sodium/version.c])
9 AC_CANONICAL_HOST
10 AM_INIT_AUTOMAKE([1.11 dist-bzip2 tar-ustar foreign subdir-objects])
11 m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])])
12 AM_MAINTAINER_MODE
13 AM_DEP_TRACK
14
15 AC_SUBST(VERSION)
16 ISODATE=`date +%Y-%m-%d`
17 AC_SUBST(ISODATE)
18
19 SODIUM_LIBRARY_VERSION_MAJOR=10
20 SODIUM_LIBRARY_VERSION_MINOR=1
21 DLL_VERSION=8
22 SODIUM_LIBRARY_VERSION=24:0:1
23 # | | |
24 # +------+ | +---+
25 # | | |
26 # current:revision:age
27 # | | |
28 # | | +- increment if interfaces have been added
29 # | | set to zero if interfaces have been removed
30 # | | or changed
31 # | +- increment if source code has changed
32 # | set to zero if current is incremented
33 # +- increment if interfaces have been added, removed or changed
34 AC_SUBST(SODIUM_LIBRARY_VERSION_MAJOR)
35 AC_SUBST(SODIUM_LIBRARY_VERSION_MINOR)
36 AC_SUBST(SODIUM_LIBRARY_VERSION)
37 AC_SUBST(DLL_VERSION)
38
39 AC_LANG_ASSERT(C)
40 LX_CFLAGS=${CFLAGS-NONE}
41
42 dnl Path check
43
44 AS_IF([pwd | fgrep ' ' > /dev/null 2>&1],
45 [AC_MSG_ERROR([The build directory contains whitespaces - This can cause tests/installation to fail due to limitations of some libtool versions])]
46 )
47
48 dnl Switches
49
50 AC_ARG_ENABLE(ssp,
51 [AS_HELP_STRING(--disable-ssp,Do not compile with -fstack-protector)],
52 [
53 AS_IF([test "x$enableval" = "xno"], [
54 enable_ssp="no"
55 ], [
56 enable_ssp="yes"
57 ])
58 ],
59 [
60 enable_ssp="yes"
61 ])
62
63 AC_ARG_ENABLE(asm,
64 [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 and NativeClient.])],
65 [
66 AS_IF([test "x$enableval" = "xno"], [
67 enable_asm="no"
68 ], [
69 enable_asm="yes"
70 ])
71 ],
72 [
73 enable_asm="yes"
74 ])
75
76 AS_IF([test "x$EMSCRIPTEN" != "x"], [
77 AX_CHECK_COMPILE_FLAG([-s ASSERTIONS=0], [
78 enable_asm="no"
79 AC_MSG_WARN([compiling to JavaScript - asm implementations disabled])
80 ], [
81 AC_MSG_WARN([EMSCRIPTEN environment variable defined, but emcc doesn't appear to be used - Assuming compilation to native code])
82 CFLAGS="$CFLAGS -U__EMSCRIPTEN__"
83 unset EMSCRIPTEN
84 ])
85 ])
86 AS_IF([test "$host_os" = "nacl" -o "$host_os" = "pnacl"], [
87 enable_asm="no"
88 AC_MSG_WARN([compiling to Native Client - asm implementations disabled])
89 ])
90
91 AC_ARG_ENABLE(pie,
92 [AS_HELP_STRING(--disable-pie,Do not produce position independent executables)],
93 enable_pie=$enableval, enable_pie="maybe")
94
95 AS_CASE([$host_os], [mingw*|cygwin*|msys], [enable_pie="no"])
96
97 AC_ARG_ENABLE(blocking-random,
98 [AS_HELP_STRING(--enable-blocking-random,Enable this switch only if /dev/urandom is totally broken on the target platform)],
99 [
100 AS_IF([test "x$enableval" = "xyes"], [
101 AC_DEFINE([USE_BLOCKING_RANDOM], [1], [/dev/urandom is insecure on the target platform])
102 ])
103 ])
104
105 AC_ARG_ENABLE(minimal,
106 [AS_HELP_STRING(--enable-minimal,
107 [Only compile the minimum set of functions required for the high-level API])],
108 [
109 AS_IF([test "x$enableval" = "xyes"], [
110 enable_minimal="yes"
111 SODIUM_LIBRARY_MINIMAL_DEF="#define SODIUM_LIBRARY_MINIMAL 1"
112 AC_DEFINE([MINIMAL], [1], [Define for a minimal build, without deprecated functions and functions that high-level APIs depend on])
113 ], [
114 enable_minimal="no"
115 ])
116 ],
117 [
118 enable_minimal="no"
119 ])
120 AM_CONDITIONAL([MINIMAL], [test x$enable_minimal = xyes])
121 AC_SUBST(SODIUM_LIBRARY_MINIMAL_DEF)
122
123 AC_ARG_WITH(pthreads, AC_HELP_STRING([--with-pthreads],
124 [use pthreads library, or --without-pthreads to disable threading support.]),
125 [ ], [withval="yes"])
126
127 AS_IF([test "x$withval" = "xyes"], [
128 AX_PTHREAD([
129 AC_DEFINE([HAVE_PTHREAD], [1], [Define if you have POSIX threads libraries and header files])
130 with_threads="yes"
131 LIBS="$PTHREAD_LIBS $LIBS"
132 CFLAGS="$CFLAGS $PTHREAD_CFLAGS"
133 CC="$PTHREAD_CC"])
134 ], [with_threads="no"])
135
136 AC_ARG_WITH(safecode,
137 [AS_HELP_STRING(--with-safecode,For maintainers only - please do not use)],
138 [AS_IF([test "x$withval" = "xyes"], [
139 AC_ARG_VAR([SAFECODE_HOME], [set to the safecode base directory])
140 : ${SAFECODE_HOME:=/opt/safecode}
141 LDFLAGS="$LDFLAGS -L${SAFECODE_HOME}/lib"
142 LIBS="$LIBS -lsc_dbg_rt -lpoolalloc_bitmap -lstdc++"
143 CFLAGS="$CFLAGS -fmemsafety"
144 ])
145 ])
146
147 AC_ARG_WITH(ctgrind,
148 [AS_HELP_STRING(--with-ctgrind,For maintainers only - please do not use)],
149 [AS_IF([test "x$withval" = "xyes"], [
150 AC_CHECK_LIB(ctgrind, ct_poison)
151 ])
152 ])
153
154 ENABLE_CWFLAGS=no
155 AC_ARG_ENABLE(debug,
156 [AS_HELP_STRING(--enable-debug,For maintainers only - please do not use)],
157 [
158 AS_IF([test "x$enableval" = "xyes"], [
159 AS_IF([test "x$LX_CFLAGS" = "xNONE"], [
160 nxflags=""
161 for flag in `echo $CFLAGS`; do
162 AS_CASE([$flag],
163 [-O*], [ ],
164 [-g*], [ ],
165 [*], [AS_VAR_APPEND([nxflags], [" $flag"])])
166 done
167 CFLAGS="$nxflags -O -g3"
168 ])
169 ENABLE_CWFLAGS=yes
170 CPPFLAGS="$CPPFLAGS -DDEBUG=1 -U_FORTIFY_SOURCE"
171 ])
172 ])
173
174 AC_ARG_ENABLE(opt,
175 [AS_HELP_STRING(--enable-opt,Optimize for the native CPU - The resulting library will be faster but not portable)],
176 [
177 AS_IF([test "x$enableval" = "xyes"], [
178 AX_CHECK_COMPILE_FLAG([-Ofast], [CFLAGS="$CFLAGS -Ofast"])
179 AX_CHECK_COMPILE_FLAG([-fomit-frame-pointer], [CFLAGS="$CFLAGS -fomit-frame-pointer"])
180 AX_CHECK_COMPILE_FLAG([-march=native], [CFLAGS="$CFLAGS -march=native"])
181 ])
182 ])
183
184 AC_SUBST([MAINT])
185
186 AX_VALGRIND_CHECK
187
188 dnl Checks
189
190 AC_PROG_CC_C99
191 AM_PROG_AS
192 AC_USE_SYSTEM_EXTENSIONS
193 AC_C_VARARRAYS
194
195 AC_CHECK_DEFINE([__native_client__], [NATIVECLIENT="yes"], [])
196
197 AC_CHECK_DEFINE([_FORTIFY_SOURCE], [], [
198 AX_CHECK_COMPILE_FLAG([-D_FORTIFY_SOURCE=2],
199 [CPPFLAGS="$CPPFLAGS -D_FORTIFY_SOURCE=2"])
200 ])
201
202 AX_CHECK_COMPILE_FLAG([-mindirect-branch=thunk],
203 [CFLAGS="$CFLAGS -mindirect-branch=thunk"],
204 [
205 AX_CHECK_COMPILE_FLAG([-mretpoline], [CFLAGS="$CFLAGS -mretpoline"])
206 ])
207
208 AX_CHECK_COMPILE_FLAG([-fvisibility=hidden],
209 [CFLAGS="$CFLAGS -fvisibility=hidden"])
210
211 AS_CASE([$host_os], [cygwin*|mingw*|msys|pw32*|cegcc*], [ ], [
212 AX_CHECK_COMPILE_FLAG([-fPIC], [CFLAGS="$CFLAGS -fPIC"])
213 ])
214
215 AS_IF([test "$enable_pie" != "no"],[
216 AX_CHECK_COMPILE_FLAG([-fPIE], [
217 AX_CHECK_LINK_FLAG([-pie], [
218 [CFLAGS="$CFLAGS -fPIE"
219 LDFLAGS="$LDFLAGS -pie"]
220 ])
221 ])
222 ])
223
224 AX_CHECK_COMPILE_FLAG([-fno-strict-aliasing], [CFLAGS="$CFLAGS -fno-strict-aliasing"])
225 AX_CHECK_COMPILE_FLAG([-fno-strict-overflow], [CFLAGS="$CFLAGS -fno-strict-overflow"], [
226 AX_CHECK_COMPILE_FLAG([-fwrapv], [CFLAGS="$CFLAGS -fwrapv"])
227 ])
228
229 AS_IF([test "$GCC" = "yes" ], [
230 AS_CASE([$host_cpu],
231 [i?86|amd64|x86_64], [
232 AC_COMPILE_IFELSE(
233 [AC_LANG_SOURCE([
234 #if !defined(__clang__) && defined(__GNUC__) && ((__GNUC__ << 8) | __GNUC_MINOR__) < 0x403
235 # error old gcc
236 #endif
237 int main(void) { return 0; }
238 ])],,[
239 AX_CHECK_COMPILE_FLAG([-flax-vector-conversions], [CFLAGS="$CFLAGS -flax-vector-conversions"])
240 ])
241 ]
242 )
243 ])
244
245 LIBTOOL_OLD_FLAGS="$LIBTOOL_EXTRA_FLAGS"
246 LIBTOOL_EXTRA_FLAGS="$LIBTOOL_EXTRA_FLAGS -version-info $SODIUM_LIBRARY_VERSION"
247 AC_ARG_ENABLE(soname-versions,
248 [AC_HELP_STRING([--enable-soname-versions], [enable soname versions (must be disabled for Android) (default: enabled)])],
249 [
250 AS_IF([test "x$enableval" = "xno"], [
251 LIBTOOL_EXTRA_FLAGS="$LIBTOOL_OLD_FLAGS -avoid-version"
252 ])
253 ]
254 )
255
256 AS_CASE([$host_os],
257 [cygwin*|mingw*|msys|pw32*|cegcc*], [
258 AX_CHECK_LINK_FLAG([-Wl,--dynamicbase], [LDFLAGS="$LDFLAGS -Wl,--dynamicbase"])
259 AX_CHECK_LINK_FLAG([-Wl,--high-entropy-va], [LDFLAGS="$LDFLAGS -Wl,--high-entropy-va"])
260 AX_CHECK_LINK_FLAG([-Wl,--nxcompat], [LDFLAGS="$LDFLAGS -Wl,--nxcompat"])
261 ])
262
263 AS_CASE([$host_os],
264 [cygwin*|mingw*|msys|pw32*|cegcc*], [
265 AX_CHECK_COMPILE_FLAG([-fno-asynchronous-unwind-tables], [
266 [CFLAGS="$CFLAGS -fno-asynchronous-unwind-tables"]
267 ])
268 ])
269
270 AS_IF([test "x$enable_ssp" != "xno"],[
271
272 AS_CASE([$host_os],
273 [cygwin*|mingw*|msys|pw32*|cegcc*|haiku], [ ],
274 [*], [
275 AX_CHECK_COMPILE_FLAG([-fstack-protector], [
276 AX_CHECK_LINK_FLAG([-fstack-protector],
277 [CFLAGS="$CFLAGS -fstack-protector"]
278 )
279 ])
280 ])
281 ])
282
283 AC_ARG_VAR([CWFLAGS], [define to compilation flags for generating extra warnings])
284
285 AX_CHECK_COMPILE_FLAG([$CFLAGS -Wall], [CWFLAGS="$CFLAGS -Wall"])
286 AX_CHECK_COMPILE_FLAG([$CFLAGS -Wextra], [CWFLAGS="$CFLAGS -Wextra"])
287
288 AC_MSG_CHECKING(for clang)
289 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[
290 #ifndef __clang__
291 #error Not clang
292 #endif
293 ]])],
294 [AC_MSG_RESULT(yes)
295 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wno-unknown-warning-option],
296 [CWFLAGS="$CWFLAGS -Wno-unknown-warning-option"])
297 ],
298 [AC_MSG_RESULT(no)
299 ])
300
301 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wbad-function-cast], [CWFLAGS="$CWFLAGS -Wbad-function-cast"])
302 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wcast-qual], [CWFLAGS="$CWFLAGS -Wcast-qual"])
303 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wdiv-by-zero], [CWFLAGS="$CWFLAGS -Wdiv-by-zero"])
304 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wduplicated-branches], [CWFLAGS="$CWFLAGS -Wduplicated-branches"])
305 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wduplicated-cond], [CWFLAGS="$CWFLAGS -Wduplicated-cond"])
306 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wfloat-equal], [CWFLAGS="$CWFLAGS -Wfloat-equal"])
307 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wformat=2], [CWFLAGS="$CWFLAGS -Wformat=2"])
308 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wlogical-op], [CWFLAGS="$CWFLAGS -Wlogical-op"])
309 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmaybe-uninitialized], [CWFLAGS="$CWFLAGS -Wmaybe-uninitialized"])
310 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmisleading-indentation], [CWFLAGS="$CWFLAGS -Wmisleading-indentation"])
311 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmissing-declarations], [CWFLAGS="$CWFLAGS -Wmissing-declarations"])
312 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wmissing-prototypes], [CWFLAGS="$CWFLAGS -Wmissing-prototypes"])
313 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wnested-externs], [CWFLAGS="$CWFLAGS -Wnested-externs"])
314 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wno-type-limits], [CWFLAGS="$CWFLAGS -Wno-type-limits"])
315 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wno-unknown-pragmas], [CWFLAGS="$CWFLAGS -Wno-unknown-pragmas"])
316 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wnormalized=id], [CWFLAGS="$CWFLAGS -Wnormalized=id"])
317 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wnull-dereference], [CWFLAGS="$CWFLAGS -Wnull-dereference"])
318 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wold-style-declaration], [CWFLAGS="$CWFLAGS -Wold-style-declaration"])
319 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wpointer-arith], [CWFLAGS="$CWFLAGS -Wpointer-arith"])
320 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wredundant-decls], [CWFLAGS="$CWFLAGS -Wredundant-decls"])
321 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wrestrict], [CWFLAGS="$CWFLAGS -Wrestrict"])
322 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wshorten-64-to-32], [CWFLAGS="$CWFLAGS -Wshorten-64-to-32"])
323 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wsometimes-uninitialized], [CWFLAGS="$CWFLAGS -Wsometimes-uninitialized"])
324 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wstrict-prototypes], [CWFLAGS="$CWFLAGS -Wstrict-prototypes"])
325 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wswitch-enum], [CWFLAGS="$CWFLAGS -Wswitch-enum"])
326 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wvariable-decl], [CWFLAGS="$CWFLAGS -Wvariable-decl"])
327 AX_CHECK_COMPILE_FLAG([$CWFLAGS -Wwrite-strings], [CWFLAGS="$CWFLAGS -Wwrite-strings"])
328
329 AX_CHECK_LINK_FLAG([-Wl,-z,relro], [LDFLAGS="$LDFLAGS -Wl,-z,relro"])
330 AX_CHECK_LINK_FLAG([-Wl,-z,now], [LDFLAGS="$LDFLAGS -Wl,-z,now"])
331 AX_CHECK_LINK_FLAG([-Wl,-z,noexecstack], [LDFLAGS="$LDFLAGS -Wl,-z,noexecstack"])
332
333 AC_MSG_CHECKING(for a broken clang + AVX512 combination)
334 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[
335 #if !(defined(__AVX512F__) && defined(__clang__) && __clang_major__ < 4)
336 #error Not a broken clang + AVX512 combination
337 #endif
338 ]])],
339 [AC_MSG_RESULT(yes - disabling AVX512 optimizations)
340 AX_CHECK_COMPILE_FLAG([$CFLAGS -mno-avx512f],
341 [CFLAGS="$CFLAGS -mno-avx512f"])
342 ],
343 [AC_MSG_RESULT(no)
344 ])
345
346 AX_CHECK_CATCHABLE_SEGV
347 AX_CHECK_CATCHABLE_ABRT
348
349 AS_IF([test "x$with_threads" = "xyes"], [
350 AX_TLS([AC_MSG_RESULT(thread local storage is supported)],
351 [AC_MSG_RESULT(thread local storage is not supported)]) ])
352
353 LT_INIT
354 AC_SUBST(LIBTOOL_DEPS)
355
356 AC_ARG_VAR([AR], [path to the ar utility])
357 AC_CHECK_TOOL([AR], [ar], [ar])
358
359 dnl Checks for headers
360
361 AS_IF([test "x$EMSCRIPTEN" = "x" -a "$host_os" != "pnacl"], [
362
363 oldcflags="$CFLAGS"
364 AX_CHECK_COMPILE_FLAG([-mmmx], [CFLAGS="$CFLAGS -mmmx"])
365 AC_MSG_CHECKING(for MMX instructions set)
366 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
367 #pragma GCC target("mmx")
368 #include <mmintrin.h>
369 ]], [[ __m64 x = _mm_setzero_si64(); ]])],
370 [AC_MSG_RESULT(yes)
371 AC_DEFINE([HAVE_MMINTRIN_H], [1], [mmx is available])
372 AX_CHECK_COMPILE_FLAG([-mmmx], [CFLAGS_MMX="-mmmx"])],
373 [AC_MSG_RESULT(no)])
374 CFLAGS="$oldcflags"
375
376 oldcflags="$CFLAGS"
377 AX_CHECK_COMPILE_FLAG([-msse2], [CFLAGS="$CFLAGS -msse2"])
378 AC_MSG_CHECKING(for SSE2 instructions set)
379 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
380 #pragma GCC target("sse2")
381 #ifndef __SSE2__
382 # define __SSE2__
383 #endif
384 #include <emmintrin.h>
385 ]], [[ __m128d x = _mm_setzero_pd();
386 __m128i z = _mm_srli_epi64(_mm_setzero_si128(), 26); ]])],
387 [AC_MSG_RESULT(yes)
388 AC_DEFINE([HAVE_EMMINTRIN_H], [1], [sse2 is available])
389 AX_CHECK_COMPILE_FLAG([-msse2], [CFLAGS_SSE2="-msse2"])],
390 [AC_MSG_RESULT(no)])
391 CFLAGS="$oldcflags"
392
393 oldcflags="$CFLAGS"
394 AX_CHECK_COMPILE_FLAG([-msse3], [CFLAGS="$CFLAGS -msse3"])
395 AC_MSG_CHECKING(for SSE3 instructions set)
396 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
397 #pragma GCC target("sse3")
398 #include <pmmintrin.h>
399 ]], [[ __m128 x = _mm_addsub_ps(_mm_cvtpd_ps(_mm_setzero_pd()),
400 _mm_cvtpd_ps(_mm_setzero_pd())); ]])],
401 [AC_MSG_RESULT(yes)
402 AC_DEFINE([HAVE_PMMINTRIN_H], [1], [sse3 is available])
403 AX_CHECK_COMPILE_FLAG([-msse3], [CFLAGS_SSE3="-msse3"])],
404 [AC_MSG_RESULT(no)])
405 CFLAGS="$oldcflags"
406
407 oldcflags="$CFLAGS"
408 AX_CHECK_COMPILE_FLAG([-mssse3], [CFLAGS="$CFLAGS -mssse3"])
409 AC_MSG_CHECKING(for SSSE3 instructions set)
410 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
411 #pragma GCC target("ssse3")
412 #include <tmmintrin.h>
413 ]], [[ __m64 x = _mm_abs_pi32(_m_from_int(0)); ]])],
414 [AC_MSG_RESULT(yes)
415 AC_DEFINE([HAVE_TMMINTRIN_H], [1], [ssse3 is available])
416 AX_CHECK_COMPILE_FLAG([-mssse3], [CFLAGS_SSSE3="-mssse3"])],
417 [AC_MSG_RESULT(no)])
418 CFLAGS="$oldcflags"
419
420 oldcflags="$CFLAGS"
421 AX_CHECK_COMPILE_FLAG([-msse4.1], [CFLAGS="$CFLAGS -msse4.1"])
422 AC_MSG_CHECKING(for SSE4.1 instructions set)
423 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
424 #pragma GCC target("sse4.1")
425 #include <smmintrin.h>
426 ]], [[ __m128i x = _mm_minpos_epu16(_mm_setzero_si128()); ]])],
427 [AC_MSG_RESULT(yes)
428 AC_DEFINE([HAVE_SMMINTRIN_H], [1], [sse4.1 is available])
429 AX_CHECK_COMPILE_FLAG([-msse4.1], [CFLAGS_SSE41="-msse4.1"])],
430 [AC_MSG_RESULT(no)])
431 CFLAGS="$oldcflags"
432
433 oldcflags="$CFLAGS"
434 AX_CHECK_COMPILE_FLAG([-mavx], [CFLAGS="$CFLAGS -mavx"])
435 AC_MSG_CHECKING(for AVX instructions set)
436 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
437 #ifdef __native_client__
438 # error NativeClient detected - Avoiding AVX opcodes
439 #endif
440 #pragma GCC target("avx")
441 #include <immintrin.h>
442 ]], [[ _mm256_zeroall(); ]])],
443 [AC_MSG_RESULT(yes)
444 AC_DEFINE([HAVE_AVXINTRIN_H], [1], [AVX is available])
445 AX_CHECK_COMPILE_FLAG([-mavx], [CFLAGS_AVX="-mavx"])],
446 [AC_MSG_RESULT(no)])
447 CFLAGS="$oldcflags"
448
449 oldcflags="$CFLAGS"
450 AX_CHECK_COMPILE_FLAG([-mavx2], [CFLAGS="$CFLAGS -mavx2"])
451 AC_MSG_CHECKING(for AVX2 instructions set)
452 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
453 #ifdef __native_client__
454 # error NativeClient detected - Avoiding AVX2 opcodes
455 #endif
456 #pragma GCC target("avx2")
457 #include <immintrin.h>
458 ]], [[
459 __m256 x = _mm256_set1_ps(3.14);
460 __m256 y = _mm256_permutevar8x32_ps(x, _mm256_set1_epi32(42));
461 return _mm256_movemask_ps(_mm256_cmp_ps(x, y, _CMP_NEQ_OQ));
462 ]])],
463 [AC_MSG_RESULT(yes)
464 AC_DEFINE([HAVE_AVX2INTRIN_H], [1], [AVX2 is available])
465 AX_CHECK_COMPILE_FLAG([-mavx2], [CFLAGS_AVX2="-mavx2"])
466 AC_MSG_CHECKING(if _mm256_broadcastsi128_si256 is correctly defined)
467 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
468 #ifdef __native_client__
469 # error NativeClient detected - Avoiding AVX2 opcodes
470 #endif
471 #pragma GCC target("avx2")
472 #include <immintrin.h>
473 ]], [[ __m256i y = _mm256_broadcastsi128_si256(_mm_setzero_si128()); ]])],
474 [AC_MSG_RESULT(yes)],
475 [AC_MSG_RESULT(no)
476 AC_DEFINE([_mm256_broadcastsi128_si256], [_mm_broadcastsi128_si256],
477 [Define to the local name of _mm256_broadcastsi128_si256])])
478 ],
479 [AC_MSG_RESULT(no)])
480 CFLAGS="$oldcflags"
481
482 oldcflags="$CFLAGS"
483 AX_CHECK_COMPILE_FLAG([-mavx512f], [CFLAGS="$CFLAGS -mavx512f"])
484 AC_MSG_CHECKING(for AVX512F instructions set)
485 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
486 #ifdef __native_client__
487 # error NativeClient detected - Avoiding AVX512F opcodes
488 #endif
489 #pragma GCC target("avx512f")
490 #include <immintrin.h>
491 ]], [[
492 __m512i x = _mm512_setzero_epi32();
493 __m512i y = _mm512_permutexvar_epi64(_mm512_setr_epi64(0, 1, 4, 5, 2, 3, 6, 7), x);
494 ]])],
495 [AC_MSG_RESULT(yes)
496 AC_DEFINE([HAVE_AVX512FINTRIN_H], [1], [AVX512F is available])
497 AX_CHECK_COMPILE_FLAG([-mavx512f], [CFLAGS_AVX512F="-mavx512f"])],
498 [AC_MSG_RESULT(no)])
499 CFLAGS="$oldcflags"
500
501 oldcflags="$CFLAGS"
502 AX_CHECK_COMPILE_FLAG([-maes], [CFLAGS="$CFLAGS -maes"])
503 AX_CHECK_COMPILE_FLAG([-mpclmul], [CFLAGS="$CFLAGS -mpclmul"])
504 AC_MSG_CHECKING(for AESNI instructions set and PCLMULQDQ)
505 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
506 #ifdef __native_client__
507 # error NativeClient detected - Avoiding AESNI opcodes
508 #endif
509 #pragma GCC target("aes")
510 #pragma GCC target("pclmul")
511 #include <wmmintrin.h>
512 ]], [[ __m128i x = _mm_aesimc_si128(_mm_setzero_si128());
513 __m128i y = _mm_clmulepi64_si128(_mm_setzero_si128(), _mm_setzero_si128(), 0);]])],
514 [AC_MSG_RESULT(yes)
515 AC_DEFINE([HAVE_WMMINTRIN_H], [1], [aesni is available])
516 AX_CHECK_COMPILE_FLAG([-maes], [CFLAGS_AESNI="-maes"])
517 AX_CHECK_COMPILE_FLAG([-mpclmul], [CFLAGS_PCLMUL="-mpclmul"])
518 ],
519 [AC_MSG_RESULT(no)])
520 CFLAGS="$oldcflags"
521
522 oldcflags="$CFLAGS"
523 AX_CHECK_COMPILE_FLAG([-mrdrnd], [CFLAGS="$CFLAGS -mrdrnd"])
524 AC_MSG_CHECKING(for RDRAND)
525 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
526 #ifdef __native_client__
527 # error NativeClient detected - Avoiding RDRAND opcodes
528 #endif
529 #pragma GCC target("rdrnd")
530 #include <immintrin.h>
531 ]], [[ unsigned long long x; _rdrand64_step(&x); ]])],
532 [AC_MSG_RESULT(yes)
533 AC_DEFINE([HAVE_RDRAND], [1], [rdrand is available])
534 AX_CHECK_COMPILE_FLAG([-mrdrnd], [CFLAGS_RDRAND="-mrdrnd"])
535 ],
536 [AC_MSG_RESULT(no)])
537 CFLAGS="$oldcflags"
538
539 ])
540
541 AC_SUBST(CFLAGS_MMX)
542 AC_SUBST(CFLAGS_SSE2)
543 AC_SUBST(CFLAGS_SSE3)
544 AC_SUBST(CFLAGS_SSSE3)
545 AC_SUBST(CFLAGS_SSE41)
546 AC_SUBST(CFLAGS_AVX)
547 AC_SUBST(CFLAGS_AVX2)
548 AC_SUBST(CFLAGS_AVX512F)
549 AC_SUBST(CFLAGS_AESNI)
550 AC_SUBST(CFLAGS_PCLMUL)
551 AC_SUBST(CFLAGS_RDRAND)
552
553 AC_CHECK_HEADERS([sys/mman.h intrin.h])
554
555 AC_MSG_CHECKING([if _xgetbv() is available])
556 AC_LINK_IFELSE(
557 [AC_LANG_PROGRAM([[ #include <intrin.h> ]], [[ (void) _xgetbv(0) ]])],
558 [AC_MSG_RESULT(yes)
559 AC_DEFINE([HAVE__XGETBV], [1], [_xgetbv() is available])],
560 [AC_MSG_RESULT(no)])
561
562 dnl Checks for typedefs, structures, and compiler characteristics.
563
564 AC_C_INLINE
565 AS_CASE([$host_cpu],
566 [i?86|amd64|x86_64],
567 [ac_cv_c_bigendian=no]
568 )
569 AC_C_BIGENDIAN(
570 AC_DEFINE(NATIVE_BIG_ENDIAN, 1, [machine is bigendian]),
571 AC_DEFINE(NATIVE_LITTLE_ENDIAN, 1, [machine is littleendian]),
572 AC_MSG_ERROR([unknown endianness]),
573 AC_MSG_ERROR([universal endianness is not supported - compile separately and use lipo(1)])
574 )
575
576 AC_MSG_CHECKING(whether __STDC_LIMIT_MACROS is required)
577 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
578 #include <limits.h>
579 #include <stdint.h>
580 ]], [[
581 (void) SIZE_MAX;
582 (void) UINT64_MAX;
583 ]])],
584 [AC_MSG_RESULT(no)],
585 [AC_MSG_RESULT(yes)
586 CPPFLAGS="$CPPFLAGS -D__STDC_LIMIT_MACROS -D__STDC_CONSTANT_MACROS"
587 ])
588
589 AC_MSG_CHECKING(whether we can use inline asm code)
590 AC_LINK_IFELSE([AC_LANG_PROGRAM([[
591 ]], [[
592 int a = 42;
593 int *pnt = &a;
594 __asm__ __volatile__ ("" : : "r"(pnt) : "memory");
595 ]])],
596 [AC_MSG_RESULT(yes)
597 AC_DEFINE([HAVE_INLINE_ASM], [1], [inline asm code can be used])]
598 [AC_MSG_RESULT(no)]
599 )
600
601 HAVE_AMD64_ASM_V=0
602 AS_IF([test "$enable_asm" != "no"],[
603 AC_MSG_CHECKING(whether we can use x86_64 asm code)
604 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
605 ]], [[
606 #if defined(__amd64) || defined(__amd64__) || defined(__x86_64__)
607 # if defined(__CYGWIN__) || defined(__MINGW32__) || defined(__MINGW64__) || defined(_WIN32) || defined(_WIN64)
608 # error Windows x86_64 calling conventions are not supported yet
609 # endif
610 /* neat */
611 #else
612 # error !x86_64
613 #endif
614 unsigned char i = 0, o = 0, t;
615 __asm__ __volatile__ ("pxor %%xmm12, %%xmm6 \n"
616 "movb (%[i]), %[t] \n"
617 "addb %[t], (%[o]) \n"
618 : [t] "=&r"(t)
619 : [o] "D"(&o), [i] "S"(&i)
620 : "memory", "flags", "cc");
621 ]])],
622 [AC_MSG_RESULT(yes)
623 AC_DEFINE([HAVE_AMD64_ASM], [1], [x86_64 asm code can be used])
624 HAVE_AMD64_ASM_V=1],
625 [AC_MSG_RESULT(no)])
626 ])
627 AM_CONDITIONAL([HAVE_AMD64_ASM], [test $HAVE_AMD64_ASM_V = 1])
628 AC_SUBST(HAVE_AMD64_ASM_V)
629
630 HAVE_AVX_ASM_V=0
631 AS_IF([test "$enable_asm" != "no"],[
632 AC_MSG_CHECKING(whether we can assemble AVX opcodes)
633 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
634 ]], [[
635 #if defined(__amd64) || defined(__amd64__) || defined(__x86_64__)
636 # if defined(__CYGWIN__) || defined(__MINGW32__) || defined(__MINGW64__) || defined(_WIN32) || defined(_WIN64)
637 # error Windows x86_64 calling conventions are not supported yet
638 # endif
639 /* neat */
640 #else
641 # error !x86_64
642 #endif
643 __asm__ __volatile__ ("vpunpcklqdq %xmm0,%xmm13,%xmm0");
644 ]])],
645 [AC_MSG_RESULT(yes)
646 AC_DEFINE([HAVE_AVX_ASM], [1], [AVX opcodes are supported])
647 HAVE_AVX_ASM_V=1],
648 [AC_MSG_RESULT(no)])
649 ])
650 AM_CONDITIONAL([HAVE_AVX_ASM], [test $HAVE_AVX_ASM_V = 1])
651 AC_SUBST(HAVE_AVX_ASM_V)
652
653 AC_MSG_CHECKING(for 128-bit arithmetic)
654 HAVE_TI_MODE_V=0
655 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
656 #if !defined(__clang__) && !defined(__GNUC__) && !defined(__SIZEOF_INT128__)
657 # error mode(TI) is a gcc extension, and __int128 is not available
658 #endif
659 #if defined(__clang__) && !defined(__x86_64__) && !defined(__aarch64__)
660 # error clang does not properly handle the 128-bit type on 32-bit systems
661 #endif
662 #ifndef NATIVE_LITTLE_ENDIAN
663 # error libsodium currently expects a little endian CPU for the 128-bit type
664 #endif
665 #ifdef __EMSCRIPTEN__
666 # error emscripten currently doesn't support some operations on integers larger than 64 bits
667 #endif
668 #include <stddef.h>
669 #include <stdint.h>
670 #if defined(__SIZEOF_INT128__)
671 typedef unsigned __int128 uint128_t;
672 #else
673 typedef unsigned uint128_t __attribute__((mode(TI)));
674 #endif
675 void fcontract(uint128_t *t) {
676 *t += 0x8000000000000 - 1;
677 *t *= *t;
678 *t >>= 84;
679 }
680 ]], [[
681 (void) fcontract;
682 ]])],
683 [AC_MSG_RESULT(yes)
684 AC_DEFINE([HAVE_TI_MODE], [1], [gcc TI mode is available])
685 HAVE_TI_MODE_V=1],
686 [AC_MSG_RESULT(no)])
687 AM_CONDITIONAL([HAVE_TI_MODE], [test $HAVE_TI_MODE_V = 1])
688 AC_SUBST(HAVE_TI_MODE_V)
689
690 HAVE_CPUID_V=0
691 AS_IF([test "$enable_asm" != "no" -o "$host_alias" = "x86_64-nacl"],[
692 AC_MSG_CHECKING(for cpuid instruction)
693 AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ ]], [[
694 unsigned int cpu_info[4];
695 __asm__ __volatile__ ("xchgl %%ebx, %k1; cpuid; xchgl %%ebx, %k1" :
696 "=a" (cpu_info[0]), "=&r" (cpu_info[1]),
697 "=c" (cpu_info[2]), "=d" (cpu_info[3]) :
698 "0" (0U), "2" (0U));
699 ]])],
700 [AC_MSG_RESULT(yes)
701 AC_DEFINE([HAVE_CPUID], [1], [cpuid instruction is available])
702 HAVE_CPUID_V=1],
703 [AC_MSG_RESULT(no)])
704 ])
705 AC_SUBST(HAVE_CPUID_V)
706
707 asm_hide_symbol="unsupported"
708 AS_IF([test "$enable_asm" != "no" -o "$host_os" = "nacl"],[
709 AC_MSG_CHECKING(if the .private_extern asm directive is supported)
710 AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
711 __asm__ __volatile__ (".private_extern dummy_symbol \n"
712 ".private_extern _dummy_symbol \n"
713 ".globl dummy_symbol \n"
714 ".globl _dummy_symbol \n"
715 "dummy_symbol: \n"
716 "_dummy_symbol: \n"
717 " nop \n"
718 );
719 ]])],
720 [AC_MSG_RESULT(yes)
721 asm_hide_symbol=".private_extern"],
722 [AC_MSG_RESULT(no)])
723
724 AC_MSG_CHECKING(if the .hidden asm directive is supported)
725 AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
726 __asm__ __volatile__ (".hidden dummy_symbol \n"
727 ".hidden _dummy_symbol \n"
728 ".globl dummy_symbol \n"
729 ".globl _dummy_symbol \n"
730 "dummy_symbol: \n"
731 "_dummy_symbol: \n"
732 " nop \n"
733 );
734 ]])],
735 [AC_MSG_RESULT(yes)
736 AS_IF([test "$asm_hide_symbol" = "unsupported"],
737 [asm_hide_symbol=".hidden"],
738 [AC_MSG_NOTICE([unable to reliably tag symbols as private])
739 asm_hide_symbol="unsupported"])
740 ],
741 [AC_MSG_RESULT(no)])
742
743 AS_IF([test "$asm_hide_symbol" != "unsupported"],[
744 AC_DEFINE_UNQUOTED([ASM_HIDE_SYMBOL], [$asm_hide_symbol], [directive to hide symbols])
745 ])
746 ])
747
748 AC_MSG_CHECKING(if weak symbols are supported)
749 AC_LINK_IFELSE([AC_LANG_PROGRAM([[
750 #if !defined(__ELF__) && !defined(__APPLE_CC__)
751 # error Support for weak symbols may not be available
752 #endif
753 __attribute__((weak)) void __dummy(void *x) { }
754 void f(void *x) { __dummy(x); }
755 ]], [[ ]]
756 )],
757 [AC_MSG_RESULT(yes)
758 AC_DEFINE([HAVE_WEAK_SYMBOLS], [1], [weak symbols are supported])],
759 [AC_MSG_RESULT(no)])
760
761 AC_MSG_CHECKING(if data alignment is required)
762 aligned_access_required=yes
763 AS_CASE([$host_cpu],
764 [i?86|amd64|x86_64|powerpc*|s390*],
765 [aligned_access_required=no],
766 [arm*],
767 [AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
768 #ifndef __ARM_FEATURE_UNALIGNED
769 # error data alignment is required
770 #endif
771 ]], [[]])], [aligned_access_required=no], [])]
772 )
773 AS_IF([test "x$aligned_access_required" = "xyes"],
774 [AC_MSG_RESULT(yes)],
775 [AC_MSG_RESULT(no)
776 AC_DEFINE([CPU_UNALIGNED_ACCESS], [1], [unaligned memory access is supported])])
777
778 AC_MSG_CHECKING(if atomic operations are supported)
779 AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[
780 static volatile int _sodium_lock;
781 __sync_lock_test_and_set(&_sodium_lock, 1);
782 __sync_lock_release(&_sodium_lock);
783 ]]
784 )],
785 [AC_MSG_RESULT(yes)
786 AC_DEFINE([HAVE_ATOMIC_OPS], [1], [atomic operations are supported])],
787 [AC_MSG_RESULT(no)])
788
789 dnl Checks for functions and headers
790
791 AC_FUNC_ALLOCA
792 AS_IF([test "x$EMSCRIPTEN" = "x"],[
793 AC_CHECK_FUNCS([arc4random arc4random_buf])
794 AC_CHECK_FUNCS([mmap mlock madvise mprotect memset_s explicit_bzero nanosleep])
795 ])
796 AC_CHECK_FUNCS([posix_memalign getpid])
797
798 AC_SUBST([LIBTOOL_EXTRA_FLAGS])
799
800 TEST_LDFLAGS=''
801 AS_IF([test "x$EMSCRIPTEN" != "x"],[
802 EXEEXT=.js
803 TEST_LDFLAGS='--memory-init-file 0 --pre-js pre.js.inc -s RESERVED_FUNCTION_POINTERS=8'
804 ])
805 AC_SUBST(TEST_LDFLAGS)
806 AM_CONDITIONAL([EMSCRIPTEN], [test "x$EMSCRIPTEN" != "x"])
807
808 AM_CONDITIONAL([NATIVECLIENT], [test "x$NATIVECLIENT" != "x"])
809
810 AC_DEFINE([CONFIGURED], [1], [the build system was properly configured])
811
812 dnl Libtool.
813
814 LT_INIT([dlopen])
815 AC_LIBTOOL_WIN32_DLL
816 gl_LD_OUTPUT_DEF
817
818 dnl Output.
819
820 AH_VERBATIM([NDEBUG], [/* Always evaluate assert() calls */
821 #ifdef NDEBUG
822 #/**/undef/**/ NDEBUG
823 #endif])
824
825 AS_IF([test "x$ENABLE_CWFLAGS" = "xyes"], [
826 CFLAGS="$CFLAGS $CWFLAGS"
827 ])
828
829 AC_CONFIG_FILES([Makefile
830 builds/Makefile
831 contrib/Makefile
832 dist-build/Makefile
833 libsodium.pc
834 libsodium-uninstalled.pc
835 msvc-scripts/Makefile
836 src/Makefile
837 src/libsodium/Makefile
838 src/libsodium/include/Makefile
839 src/libsodium/include/sodium/version.h
840 test/default/Makefile
841 test/Makefile
842 ])
843 AC_OUTPUT
Cache object: cf9712fe7fadccc2b67a146af525d9ee
|