configure.ac 25 KB

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