symm/rijndael-arm-crypto.S: Outdent the `.rept/.endr' directives.
[catacomb] / configure.ac
CommitLineData
ba6e6b64
MW
1dnl -*-autoconf-*-
2dnl
3dnl Configuration script for Catacomb
4dnl
5dnl (c) 2013 Straylight/Edgeware
6dnl
7
8dnl----- Licensing notice ---------------------------------------------------
9dnl
10dnl This file is part of Catacomb.
11dnl
12dnl Catacomb is free software; you can redistribute it and/or modify
13dnl it under the terms of the GNU Library General Public License as
14dnl published by the Free Software Foundation; either version 2 of the
15dnl License, or (at your option) any later version.
16dnl
17dnl Catacomb is distributed in the hope that it will be useful,
18dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
19dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20dnl GNU Library General Public License for more details.
21dnl
22dnl You should have received a copy of the GNU Library General Public
23dnl License along with Catacomb; if not, write to the Free
24dnl Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
25dnl MA 02111-1307, USA.
26
27dnl--------------------------------------------------------------------------
28dnl Initialization.
29
30mdw_AUTO_VERSION
31AC_INIT([catacomb], AUTO_VERSION, [mdw@distorted.org.uk])
32AC_CONFIG_SRCDIR([catacomb.pc.in])
33AC_CONFIG_AUX_DIR([config])
1c8e76bd 34AM_INIT_AUTOMAKE([foreign parallel-tests color-tests subdir-objects])
08e2be29 35AC_CANONICAL_HOST
ba6e6b64
MW
36mdw_SILENT_RULES
37
38AC_PROG_CC
39AX_CFLAGS_WARN_ALL
40AM_PROG_LIBTOOL
41mdw_LIBTOOL_VERSION_INFO
42
6adca914
MW
43AM_PROG_AS
44
ba6e6b64
MW
45AC_PROG_YACC
46
47AC_SUBST(AM_CFLAGS)
48
49dnl--------------------------------------------------------------------------
7a5af13c
MW
50dnl Define language support for assembler.
51dnl
52dnl This is stolen from https://gitlab.crest.iu.edu/jsfiroz/hpx/commit/
53dnl 84be4345db6eec3797a57b8e53483cb43f4733bf
54
55AC_LANG_DEFINE([CPPAS], [cppas], [CPPAS], [CCAS], [C],
56 [ac_ext=S ac_cpp='$CPP $CPPFLAGS'
57 ac_compile='$CCAS -c $CCASFLAGS $CPPFLAGS dnl
58 conftest.$ac_ext >&AS_MESSAGE_LOG_FD'
59 ac_link='$CCAS -oconftest$ac_exeext $CCASFLAGS $CPPFLAGS $LDFLAGS dnl
60 conftest.$ac_ext $LIBS >&AS_MESSAGE_LOG_FD'])
61
62AC_DEFUN([AC_LANG_PREPROC(CPPAS)], [AC_REQUIRE([AC_PROG_CPP])])
63AC_DEFUN([AC_LANG_COMPILER(CPPAS)], [AC_REQUIRE([AM_PROG_AS])])
64AC_DEFUN([AC_LANG_CONFTEST(CPPAS)],
65 [cat confdefs.h - <<_ACEOF >conftest.$ac_ext
66/* end confdefs.h. */
67$1
68_ACEOF])
69
70AC_CACHE_CHECK(
71 [whether the assembler is likely to work], [mdw_cv_gnuish_as],
72 [AC_LANG_PUSH([CPPAS])
73 AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
74 .text
75 .L\$_test = 23
76.macro mymac
77 .L\$_test = .L\$_test + 1
78.endm
79 .globl foo
80 .extern bar
81 mymac]])],
82 [mdw_cv_gnuish_as=yes], [mdw_cv_gnuish_as=no])
83 AC_LANG_POP([CPPAS])])
84AM_CONDITIONAL([GNUISH_AS], [test $mdw_cv_gnuish_as = yes])
85
86dnl--------------------------------------------------------------------------
08e2be29
MW
87dnl Host-specific configuration.
88
ff1f7e22
MW
89AC_MSG_CHECKING([CPU family and ABI])
90
91dnl The table of CPU families and ABIs which we might support. Support is
92dnl not uniform: each dispatched function might or might not have an
93dnl implementation for any particular CPU/ABI combination.
08e2be29 94AC_DEFUN([catacomb_CPU_FAMILIES],
0f23f75f
MW
95 [$1([i[[3-6]]86,cygwin], [x86], [win])
96 $1([i[[3-6]]86,*], [x86], [sysv])
97 $1([x86_64,cygwin], [amd64], [win])
61bd904b 98 $1([x86_64,*], [amd64], [sysv])
2cbeb9a2
MW
99 $1([arm,*-gnueabi | arm,*-gnueabihf | dnl
100 armv*,*-gnueabi | armv*,*-gnueabihf], [armel], [gnueabi])])
ff1f7e22
MW
101
102dnl A utility to clear the `seen' flags, used so as to process each CPU or
103dnl ABI once.
104m4_define([catacomb_CLEAR_FLAGS],
105[m4_ifdef([catacomb_seen_cpu/$2],
106 [m4_undefine([catacomb_seen_cpu/$2])])dnl
107m4_ifdef([catacomb_seen_abi/$3],
108 [m4_undefine([catacomb_seen_abi/$3])])])
08e2be29 109
ff1f7e22 110dnl Identify the current host.
7a5af13c
MW
111if test $mdw_cv_gnuish_as = no; then
112 CPUFAM=nil ABI=nil
113else
114 case $host_cpu,$host_os in
115 m4_define([catacomb_CPU_CASE],
116 [$1) CPUFAM=$2 ABI=$3 ;;
08e2be29 117])
7a5af13c
MW
118 catacomb_CPU_FAMILIES([catacomb_CPU_CASE])
119 *) CPUFAM=nil ABI=nil ;;
120 esac
121fi
ff1f7e22
MW
122
123dnl Figure out the current CPU.
124catacomb_CPU_FAMILIES([catacomb_CLEAR_FLAGS])
125case $CPUFAM in
126 m4_define([catacomb_DEFINE_CPU],
127 [m4_ifdef([catacomb_seen_cpu/$2], [],
128 [$2)
129 AC_DEFINE([CPUFAM_]m4_translit([$2], [a-z], [A-Z]), [1],
130 [Define if host CPU family is \`$2\'.])
131 ;;m4_define([catacomb_seen_cpu/$2], [t])])])
132 catacomb_CPU_FAMILIES([catacomb_DEFINE_CPU])
133 nil) ;;
134 *) AC_MSG_ERROR([BUG: unexpected cpufam \`$CPUFAM']) ;;
135esac
136AC_SUBST([CPUFAM])
137
138dnl Figure out the current ABI.
139catacomb_CPU_FAMILIES([catacomb_CLEAR_FLAGS])
140case $ABI in
141 m4_define([catacomb_DEFINE_ABI],
142 [m4_ifdef([catacomb_seen_abi/$3], [],
143 [$3)
144 AC_DEFINE([ABI_]m4_translit([$3], [a-z], [A-Z]), [1],
145 [Define if host ABI variant is \`$3\'.])
146 ;;m4_define([catacomb_seen_abi/$3], [t])])])
147 catacomb_CPU_FAMILIES([catacomb_DEFINE_ABI])
148 nil) ;;
149 *) AC_MSG_ERROR([BUG: unexpected ABI \`$ABI']) ;;
150esac
151AC_SUBST([ABI])
152
153dnl Establish Automake conditions for things.
154catacomb_CPU_FAMILIES([catacomb_CLEAR_FLAGS])
155m4_define([catacomb_COND_CPU],
156[m4_define([_CPU], m4_translit([$2], [a-z], [A-Z]))
157m4_define([_ABI], m4_translit([$3], [a-z], [A-Z]))
158AM_CONDITIONAL([CPUABI_]_CPU[_]_ABI, [test x$CPUFAM/$ABI = x$2/$3])
159m4_ifdef([catacomb_seen_cpu/$2], [],
160[AM_CONDITIONAL([CPUFAM_]_CPU, [test x$CPUFAM = x$2])dnl
161m4_define([catacomb_seen_cpu/$2], [t])])
162m4_ifdef([catacomb_seen_abi/$3], [],
163[AM_CONDITIONAL([ABI_]_ABI, [test x$ABI = x$3])dnl
164m4_define([catacomb_seen_abi/$3], [t])])])
165catacomb_CPU_FAMILIES([catacomb_COND_CPU])
166AM_CONDITIONAL([KNOWN_CPUFAM], [test x$CPUFAM != xnil])
167
168dnl Report on what we found.
169case $CPUFAM in
170 nil) AC_MSG_RESULT([not supported]) ;;
171 *) AC_MSG_RESULT([$CPUFAM/$ABI]) ;;
08e2be29 172esac
08e2be29
MW
173
174dnl--------------------------------------------------------------------------
26e182fc
MW
175dnl CPU-specific assembler features.
176
177AC_LANG([CPPAS])
178
179case $CPUFAM in
180 armel)
181 AC_CACHE_CHECK(
182 [whether the assembler understands ARMv8 crypto extensions],
183 [mdw_cv_as_armv8_crypto],
184 [AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
185 .arch armv8-a
186 .fpu crypto-neon-fp-armv8
187
188 .text
189 .globl foo
190foo:
191 vldmia r0, {d0-d3}
192 aese.8 q0, q1
193 aesmc.8 q0, q0
194 vstmia r0, {d0, d1}
195 bx r14]])],
196 [mdw_cv_as_armv8_crypto=yes],
197 [mdw_cv_as_armv8_crypto=no])])
198 ;;
199esac
200
201: ${mdw_cv_as_armv8_crypto=no}
202AM_CONDITIONAL([HAVE_AS_ARMV8_CRYPTO], [test $mdw_cv_as_armv8_crypto = yes])
203if test $mdw_cv_as_armv8_crypto = yes; then
204 AC_DEFINE([HAVE_AS_ARMV8_CRYPTO], [1],
205 [Define to 1 if your ARM assembler supports the ARMv8 crypto instructions.])
206fi
207
208dnl--------------------------------------------------------------------------
ba6e6b64
MW
209dnl C programming environment.
210
fedd2209
MW
211AC_LANG([C])
212
02fe0bac
MW
213CATACOMB_LIBS=
214
0f00dc4c
MW
215dnl Find out if we're cross-compiling.
216AM_CONDITIONAL([CROSS_COMPILING], [test "$cross_compiling" = yes])
217
ba6e6b64
MW
218dnl Various standard types.
219AC_CHECK_TYPE([pid_t], [int])
220AC_TYPE_UID_T
221AC_CHECK_TYPE([ssize_t], [int])
67ea7285 222AC_CHECK_TYPE([socklen_t], [int])
ba6e6b64
MW
223
224dnl The maths library.
1504e033 225mdw_ORIG_LIBS=$LIBS LIBS=
ba6e6b64
MW
226AC_SEARCH_LIBS([log], [m])
227AC_SEARCH_LIBS([sqrt], [m])
1504e033 228AC_SUBST([MATHLIBS], [$LIBS])
ba6e6b64
MW
229LIBS=$mdw_ORIG_LIBS
230
1c3d4cf5
MW
231dnl Find out whether very long integer types are available.
232AC_CHECK_HEADERS([stdint.h])
233AC_SUBST([have_stdint_h])
729a52ce 234AX_C_LONG_LONG
1c3d4cf5 235
fedd2209
MW
236dnl Some equipment wanted for checking CPU features at runtime.
237AC_CHECK_HEADERS([asm/hwcap.h])
238AC_CHECK_HEADERS([sys/auxv.h])
239AC_CHECK_HEADERS([linux/auxvec.h])
240AC_CHECK_FUNCS([getauxval])
241
1c3d4cf5
MW
242dnl Find the bit lengths of the obvious integer types. This will be useful
243dnl when deciding on a representation for multiprecision integers.
244type_bits="" type_bits_sep=""
245AC_DEFUN([catacomb_UINT_BITS],
246 [mdw_UINT_BITS([$2], [$1])
247 type_bits="$type_bits$type_bits_sep('$1', $[]$1_bits)"
248 type_bits_sep=", "])
249catacomb_UINT_BITS([uchar], [unsigned char])
250catacomb_UINT_BITS([ushort], [unsigned short])
251catacomb_UINT_BITS([uint], [unsigned int])
252catacomb_UINT_BITS([ulong], [unsigned long])
253if test "$ac_cv_c_long_long" = "yes"; then
254 catacomb_UINT_BITS([ullong], [unsigned long long])
255fi
256if test "$ac_cv_header_stdint_h" = "yes"; then
257 catacomb_UINT_BITS([uintmax], [uintmax_t])
258fi
259AC_SUBST([type_bits])
260
261dnl Determine the limits of common C integer types.
262limits="" limits_sep=""
263AC_DEFUN([catacomb_COMPILE_TIME_CONSTANT],
264 [case "$2" in
265 =*)
266 $1="$2"; $1=${$1#=}
267 ;;
268 *)
269 AC_CACHE_CHECK([compile-time value of $2], [mdw_cv_constant_$3],
270 [mdw_PROBE_CONSTANT([mdw_cv_constant_$3], [$2], [$4])])
271 $1=$mdw_cv_constant_$3
272 ;;
273 esac])
274AC_DEFUN([catacomb_LIMIT],
275[catacomb_COMPILE_TIME_CONSTANT([lo], [$2], [$1_min],
276[#include <limits.h>
277#include <stddef.h>])
278 catacomb_COMPILE_TIME_CONSTANT([hi], [$3], [$1_max],
279[#include <limits.h>
280#include <stddef.h>])
281 limits="$limits$limits_sep('$1', $lo, $hi)" limits_sep=", "])
282catacomb_LIMIT([SCHAR], [SCHAR_MIN], [SCHAR_MAX])
283catacomb_LIMIT([CHAR], [CHAR_MIN], [CHAR_MAX])
284catacomb_LIMIT([UCHAR], [=0], [UCHAR_MAX])
285catacomb_LIMIT([UINT8], [=0], [=0xff])
286catacomb_LIMIT([SHRT], [SHRT_MIN], [SHRT_MAX])
287catacomb_LIMIT([USHRT], [=0], [USHRT_MAX])
288catacomb_LIMIT([UINT16], [=0], [=0xffff])
289catacomb_LIMIT([INT], [INT_MIN], [INT_MAX])
290catacomb_LIMIT([UINT], [=0], [UINT_MAX])
291catacomb_LIMIT([LONG], [LONG_MIN], [LONG_MAX])
292catacomb_LIMIT([ULONG], [=0], [ULONG_MAX])
293catacomb_LIMIT([UINT32], [=0], [=0xffffffff])
294if test "$ac_cv_c_long_long" = "yes"; then
295 catacomb_LIMIT([LLONG], [LLONG_MIN], [LLONG_MAX])
296 catacomb_LIMIT([ULLONG], [=0], [ULLONG_MAX])
297fi
298catacomb_LIMIT([SIZET], [=0], [~(size_t)0])
299AC_SUBST([limits])
300
ba6e6b64
MW
301dnl Functions used for noise-gathering.
302AC_CHECK_FUNCS([setgroups])
baf5b59c 303AC_CHECK_HEADERS([linux/random.h])
8039afaf
MW
304mdw_ORIG_LIBS=$LIBS LIBS=$CATACOMB_LIBS
305AC_SEARCH_LIBS([clock_gettime], [rt])
306CATACOMB_LIBS=$LIBS LIBS=$mdw_ORIG_LIBS
fe54dc64 307if test "$ac_cv_search_clock_gettime" != no; then
8039afaf
MW
308 AC_DEFINE([HAVE_CLOCK_GETTIME], [1],
309 [Define if you have the \`clock_gettime' function.])
310fi
6d4416cc 311AC_CHECK_FUNCS([getentropy])
ba6e6b64
MW
312AC_CACHE_CHECK([whether the freewheel noise generator will work],
313 [catacomb_cv_freewheel],
314[AC_TRY_LINK(
315[#include <setjmp.h>
316#include <sys/time.h>],
317[struct itimerval itv = { { 0, 0 }, { 0, 5000 } };
318jmp_buf j;
319setitimer(ITIMER_REAL, &itv, 0);
f6ca8103 320sigsetjmp(j, 1);],
ba6e6b64
MW
321[catacomb_cv_freewheel=yes],
322[catacomb_cv_freewheel=no])])
323case $catacomb_cv_freewheel in
324 yes)
325 AC_DEFINE([USE_FREEWHEEL], [1],
326 [Define if you want to use the freewheel noise generator.])
327 ;;
328esac
329
330dnl Support for the passphrase pixie.
331mdw_ORIG_LIBS=$LIBS
332AC_SEARCH_LIBS([socket], [socket])
333AC_SUBST([PIXIE_LIBS], [$LIBS])
334LIBS=$mdw_ORIG_LIBS
335
336dnl Memory locking support.
337AC_CHECK_FUNCS([mlock])
338
02fe0bac
MW
339dnl Set the master libraries we need.
340AC_SUBST([CATACOMB_LIBS])
341
ba6e6b64 342dnl Necessary support libraries.
a1acefec 343PKG_CHECK_MODULES([mLib], [mLib >= 2.2.2.1])
ba6e6b64
MW
344AM_CFLAGS="$AM_CFLAGS $mLib_CFLAGS"
345
346dnl--------------------------------------------------------------------------
347dnl Python.
348
349dnl Make sure we have a suitable version.
350AM_PATH_PYTHON([2.5])
351
352dnl--------------------------------------------------------------------------
353dnl Special debugging options.
354
355AC_ARG_ENABLE([mpw],
356 [AS_HELP_STRING([--enable-mpw], [force small-width mp digits])],
357 [case "$enableval" in
358 y*|t*|short)
359 AC_DEFINE([FORCE_MPW_SHORT], [1],
360 [Define to force small-width mp digits.])
361 ;;
362 cussid)
363 AC_DEFINE([FORCE_MPW_CUSSID], [1],
364 [Define to force strange-width mp digits.])
365 ;;
366 esac])
367
368dnl--------------------------------------------------------------------------
369dnl Produce output.
370
371AC_CONFIG_HEADER([config/config.h])
372
373AC_CONFIG_FILES(
0f00dc4c
MW
374 [Makefile]
375 [base/Makefile]
376 [key/Makefile]
377 [math/Makefile]
378 [misc/Makefile]
379 [pub/Makefile]
380 [rand/Makefile]
381 [symm/Makefile]
382 [progs/Makefile])
ba6e6b64
MW
383AC_OUTPUT
384
385dnl----- That's all, folks --------------------------------------------------