1 | dnl Process this file with autoconf to produce a configure script. |
1 | dnl Process this file with autoconf to produce a configure script. |
2 | |
2 | |
3 | AC_PREREQ(2.59) |
3 | AC_PREREQ(2.69) |
4 | AC_INIT |
4 | AC_INIT |
5 | AC_CONFIG_SRCDIR([src/vped.C]) |
5 | AC_CONFIG_SRCDIR([src/gvpe.C]) |
6 | AC_CANONICAL_TARGET |
6 | AC_CANONICAL_TARGET |
7 | AM_INIT_AUTOMAKE(gvpe, 1.7) |
7 | AM_INIT_AUTOMAKE(gvpe, 2.25) |
8 | AC_CONFIG_HEADERS([config.h]) |
8 | AC_CONFIG_HEADERS([config.h]) |
9 | AM_MAINTAINER_MODE |
9 | AM_MAINTAINER_MODE |
10 | |
10 | |
11 | AH_TOP([ |
11 | AH_TOP([ |
12 | #ifndef CONFIG_H__ |
12 | #ifndef CONFIG_H__ |
… | |
… | |
17 | #endif |
17 | #endif |
18 | |
18 | |
19 | ]) |
19 | ]) |
20 | |
20 | |
21 | AH_BOTTOM([ |
21 | AH_BOTTOM([ |
|
|
22 | typedef unsigned char u8; |
|
|
23 | typedef signed char s8; |
|
|
24 | |
22 | #if __CYGWIN__ |
25 | #if __CYGWIN__ |
23 | |
26 | |
24 | typedef unsigned char u8; |
|
|
25 | typedef unsigned short u16; |
27 | typedef unsigned short u16; |
26 | typedef unsigned int u32; |
28 | typedef unsigned int u32; |
|
|
29 | typedef signed short s16; |
|
|
30 | typedef signed int s32; |
27 | |
31 | |
28 | #else |
32 | #else |
29 | #include <inttypes.h> |
33 | #include <inttypes.h> |
30 | |
34 | |
31 | /* old modula-2 habits */ |
35 | /* old modula-2 habits */ |
32 | typedef unsigned char u8; |
|
|
33 | typedef uint16_t u16; |
36 | typedef uint16_t u16; |
34 | typedef uint32_t u32; |
37 | typedef uint32_t u32; |
|
|
38 | typedef int16_t s16; |
|
|
39 | typedef int32_t s32; |
35 | #endif |
40 | #endif |
36 | |
41 | |
37 | #endif |
42 | #endif |
38 | ]) |
|
|
39 | |
43 | |
40 | dnl Include the macros from the m4/ directory |
44 | #if HAVE_CLOCALE |
41 | AM_ACLOCAL_INCLUDE(m4) |
45 | # define CLOCALE <clocale> |
|
|
46 | #else |
|
|
47 | # define CLOCALE <locale.h> |
|
|
48 | #endif |
|
|
49 | ]) |
42 | |
50 | |
43 | AM_GNU_GETTEXT([external]) |
51 | AM_GNU_GETTEXT([external]) |
44 | AM_GNU_GETTEXT_VERSION(0.11.5) |
52 | AM_GNU_GETTEXT_VERSION(0.11.5) |
45 | |
53 | |
46 | # Enable GNU extensions. |
54 | # Enable GNU extensions. |
47 | # Define this here, not in acconfig's @TOP@ section, since definitions |
55 | # Define this here, not in acconfig's @TOP@ section, since definitions |
48 | # in the latter don't make it into the configure-time tests. |
56 | # in the latter don't make it into the configure-time tests. |
49 | AC_DEFINE([_GNU_SOURCE], 1, [Enable GNU extenstions]) |
57 | AC_DEFINE([_GNU_SOURCE], 1, [Enable GNU extensions]) |
50 | |
58 | |
51 | # do NOT define POSIX_SOURCE, sicne this clashes with many BSDs |
59 | # do NOT define POSIX_SOURCE, sicne this clashes with many BSDs |
52 | dnl AC_DEFINE([_POSIX_SOURCE], 1, [Enable POSIX 1003.1 extensions]) |
60 | dnl AC_DEFINE([_POSIX_SOURCE], 1, [Enable POSIX 1003.1 extensions]) |
53 | dnl AC_DEFINE([_XOPEN_SOURCE], 500, [Enable XOPEN extensions]) |
61 | dnl AC_DEFINE([_XOPEN_SOURCE], 500, [Enable XOPEN extensions]) |
54 | |
62 | |
55 | ALL_LINGUAS="" |
63 | ALL_LINGUAS="" |
56 | |
64 | |
57 | dnl Checks for programs. |
65 | dnl Checks for programs. |
58 | AC_PROG_CC |
|
|
59 | AC_PROG_CPP |
66 | AC_PROG_CPP |
60 | AC_PROG_CXX |
67 | AC_PROG_CXX |
61 | AC_PROG_GCC_TRADITIONAL |
68 | AC_PROG_GCC_TRADITIONAL |
62 | AC_PROG_AWK |
69 | AC_PROG_AWK |
63 | AC_PROG_INSTALL |
70 | AC_PROG_INSTALL |
… | |
… | |
66 | AC_PROG_RANLIB |
73 | AC_PROG_RANLIB |
67 | |
74 | |
68 | AC_ARG_ENABLE(iftype, |
75 | AC_ARG_ENABLE(iftype, |
69 | [AS_HELP_STRING(--enable-iftype=TYPE/SUBTYPE, |
76 | [AS_HELP_STRING(--enable-iftype=TYPE/SUBTYPE, |
70 | Use kernel/net device interface TYPE/SUBTYPE. |
77 | Use kernel/net device interface TYPE/SUBTYPE. |
71 | Working combinations are: |
78 | Working combinations are (see doc/gvpe.osdep.5.pod): |
72 | "native/linux" |
79 | "native/linux" |
73 | "tincd/linux" |
80 | "tincd/linux" |
|
|
81 | "tincd/netbsd" |
74 | "tincd/freebsd" |
82 | "tincd/freebsd" |
75 | "tincd/openbsd" |
83 | "tincd/openbsd" |
|
|
84 | "native/darwin" |
76 | "tincd/darwin" |
85 | "tincd/darwin" |
77 | "native/cygwin"; |
86 | "native/cygwin"; |
78 | Untested combinations are: |
87 | Untested combinations are: |
79 | "tincd/netbsd" |
88 | "tincd/bsd" |
80 | "tincd/solaris" |
89 | "tincd/solaris" |
81 | "tincd/mingw"; |
90 | "tincd/mingw" |
|
|
91 | "tincd/raw_socket" |
|
|
92 | "tincd/uml_socket"; |
82 | Broken combinations are: |
93 | Broken combinations are: |
83 | "tincd/cygwin"; |
94 | "tincd/cygwin"; |
84 | The default is to autodetect. |
95 | The default is to autodetect. |
85 | )], |
96 | )], |
86 | [ |
97 | [ |
… | |
… | |
103 | IFTYPE=tincd |
114 | IFTYPE=tincd |
104 | IFSUBTYPE=freebsd |
115 | IFSUBTYPE=freebsd |
105 | AC_DEFINE(HAVE_FREEBSD, 1, [FreeBSD]) |
116 | AC_DEFINE(HAVE_FREEBSD, 1, [FreeBSD]) |
106 | ;; |
117 | ;; |
107 | *darwin*) |
118 | *darwin*) |
108 | IFTYPE=tincd |
119 | IFTYPE=native |
109 | IFSUBTYPE=darwin |
120 | IFSUBTYPE=darwin |
110 | AC_DEFINE(HAVE_DARWIN, 1, [Darwin (MacOS/X)]) |
121 | AC_DEFINE(HAVE_DARWIN, 1, [Darwin (MacOS/X)]) |
111 | ;; |
122 | ;; |
112 | *solaris*) |
123 | *solaris*) |
113 | IFTYPE=tincd |
124 | IFTYPE=tincd |
… | |
… | |
143 | AC_CACHE_SAVE |
154 | AC_CACHE_SAVE |
144 | |
155 | |
145 | dnl Checks for libraries. |
156 | dnl Checks for libraries. |
146 | |
157 | |
147 | AC_LANG(C++) |
158 | AC_LANG(C++) |
148 | AC_CHECK_HEADERS(ext/hash_map) |
159 | AC_CHECK_HEADERS(tr1/unordered_map ext/hash_map clocale) |
149 | |
160 | |
150 | dnl Checks for header files. |
161 | dnl Checks for header files. |
151 | AC_CHECK_HEADERS([fcntl.h inttypes.h limits.h malloc.h stdint.h strings.h syslog.h unistd.h \ |
162 | AC_CHECK_HEADERS([fcntl.h inttypes.h limits.h malloc.h stdint.h strings.h syslog.h unistd.h \ |
152 | sys/file.h sys/ioctl.h sys/param.h sys/time.h netinet/in_systm.h sys/cygwin.h \ |
163 | sys/file.h sys/ioctl.h sys/param.h sys/time.h netinet/in_systm.h sys/cygwin.h \ |
153 | sys/mman.h netinet/in.h]) |
164 | sys/mman.h netinet/in.h]) |
… | |
… | |
211 | ]) |
222 | ]) |
212 | AC_CHECK_FUNC(gethostbyname, [], [ |
223 | AC_CHECK_FUNC(gethostbyname, [], [ |
213 | AC_CHECK_LIB(nsl, gethostbyname) |
224 | AC_CHECK_LIB(nsl, gethostbyname) |
214 | ]) |
225 | ]) |
215 | |
226 | |
|
|
227 | dnl libev support |
|
|
228 | m4_include([libev/libev.m4]) |
|
|
229 | |
216 | AC_LANG_POP |
230 | AC_LANG_POP |
217 | |
231 | |
218 | dnl AC_CHECK_FUNCS([freeaddrinfo gai_strerror getaddrinfo getnameinfo]) |
232 | dnl AC_CHECK_FUNCS([freeaddrinfo gai_strerror getaddrinfo getnameinfo]) |
219 | |
233 | |
220 | AC_CACHE_SAVE |
234 | AC_CACHE_SAVE |
… | |
… | |
226 | if test "x$openssl_include" != x; then |
240 | if test "x$openssl_include" != x; then |
227 | CXXFLAGS="$CXXFLAGS -I$openssl_include" |
241 | CXXFLAGS="$CXXFLAGS -I$openssl_include" |
228 | fi |
242 | fi |
229 | dnl tinc_ZLIB |
243 | dnl tinc_ZLIB |
230 | |
244 | |
|
|
245 | AC_ARG_ENABLE(threads, |
|
|
246 | [AS_HELP_STRING(--enable-threads,try to use threads for long-running asynchronous operations (default enabled).)], |
|
|
247 | [try_threads=$enableval], |
|
|
248 | [try_threads=yes] |
|
|
249 | ) |
|
|
250 | |
|
|
251 | if test "x$try_threads" = xyes; then |
|
|
252 | AC_CHECK_HEADER(pthread.h,[ |
|
|
253 | LIBS="$LIBS -lpthread" |
|
|
254 | AC_COMPILE_IFELSE( |
|
|
255 | [AC_LANG_PROGRAM([#include <pthread.h>], [pthread_t id; pthread_create (&id, 0, 0, 0);])], |
|
|
256 | [AC_DEFINE_UNQUOTED(ENABLE_PTHREADS, 1, [POSIX thread support.])] |
|
|
257 | ) |
|
|
258 | ]) |
|
|
259 | fi |
|
|
260 | |
231 | AC_ARG_ENABLE(static-daemon, |
261 | AC_ARG_ENABLE(static-daemon, |
232 | [AS_HELP_STRING(--enable-static-daemon,enable statically linked daemon.)], |
262 | [AS_HELP_STRING(--enable-static-daemon,enable statically linked daemon.)], |
233 | [LDFLAGS_DAEMON=-static] |
263 | [LDFLAGS_DAEMON=-static] |
234 | ) |
264 | ) |
235 | AC_SUBST(LDFLAGS_DAEMON) |
265 | AC_SUBST(LDFLAGS_DAEMON) |
236 | |
266 | |
237 | AC_ARG_ENABLE(rohc, |
267 | dnl AC_ARG_ENABLE(rohc, |
238 | [AS_HELP_STRING(--enable-rohc,enable robust header compression (rfc3095).)], |
268 | dnl [AS_HELP_STRING(--enable-rohc,enable robust header compression (rfc3095).)], |
|
|
269 | dnl [ |
|
|
270 | dnl echo |
|
|
271 | dnl echo "**********************************************************************" |
|
|
272 | dnl echo "**********************************************************************" |
|
|
273 | dnl echo "**** --enable-rohc is highly experimental, do not use ****************" |
|
|
274 | dnl echo "**********************************************************************" |
|
|
275 | dnl echo "**********************************************************************" |
|
|
276 | dnl echo |
|
|
277 | dnl rohc=true |
|
|
278 | dnl AC_DEFINE_UNQUOTED(ENABLE_ROHC, 1, [ROHC support]) |
|
|
279 | dnl ] |
|
|
280 | dnl ) |
|
|
281 | |
|
|
282 | AM_CONDITIONAL(ROHC, test x$rohc = xtrue) |
|
|
283 | |
|
|
284 | dnl AC_ARG_ENABLE(bridging, |
|
|
285 | dnl [AS_HELP_STRING(--enable-bridging,enable bridging support (default disabled).)], |
|
|
286 | dnl AC_DEFINE_UNQUOTED(ENABLE_BRIDGING, 1, [bridging support.]) |
|
|
287 | dnl ) |
|
|
288 | |
|
|
289 | ICMP=1 |
|
|
290 | AC_ARG_ENABLE(icmp, |
|
|
291 | [AS_HELP_STRING(--disable-icmp,enable icmp protocol support (default enabled).)], |
|
|
292 | if test "x$enableval" = xno; then |
|
|
293 | ICMP=0 |
|
|
294 | fi |
|
|
295 | ) |
|
|
296 | if test "x$ICMP" = x1; then |
|
|
297 | AC_DEFINE_UNQUOTED(ENABLE_ICMP, 1, [ICMP protocol support.]) |
|
|
298 | fi |
|
|
299 | |
|
|
300 | TCP=1 |
|
|
301 | AC_ARG_ENABLE(tcp, |
|
|
302 | [AS_HELP_STRING(--disable-tcp,enable tcp protocol support (default enabled).)], |
|
|
303 | if test "x$enableval" = xno; then |
|
|
304 | TCP=0 |
|
|
305 | fi |
|
|
306 | ) |
|
|
307 | if test "x$TCP" = x1; then |
|
|
308 | AC_DEFINE_UNQUOTED(ENABLE_TCP, 1, [TCP protocol support.]) |
|
|
309 | fi |
|
|
310 | |
|
|
311 | HTTP=1 |
|
|
312 | AC_ARG_ENABLE(http-proxy, |
|
|
313 | [AS_HELP_STRING(--disable-http-proxy,enable http proxy connect support (default enabled).)], |
|
|
314 | if test "x$enableval" = xno; then |
|
|
315 | HTTP=0 |
|
|
316 | fi |
|
|
317 | ) |
|
|
318 | if test "x$HTTP" = x1; then |
|
|
319 | AC_DEFINE_UNQUOTED(ENABLE_HTTP_PROXY, 1, [http proxy connect support.]) |
|
|
320 | fi |
|
|
321 | |
|
|
322 | AC_ARG_ENABLE(dns, |
|
|
323 | [AS_HELP_STRING(--enable-dns,enable dns tunnel protocol support (default disabled).)], |
239 | [ |
324 | [ |
240 | echo |
325 | AC_CHECK_HEADER(gmp.h,,[AC_MSG_ERROR([gmp.h not found, required for --enable-dns])]) |
241 | echo "**********************************************************************" |
326 | AC_CHECK_LIB(gmp,main,,[AC_MSG_ERROR([libgmp not found, required for --enable-dns])]) |
242 | echo "**********************************************************************" |
327 | |
243 | echo "**** --enable-rohc is highly experimental, do not use ****************" |
328 | AC_DEFINE_UNQUOTED(ENABLE_DNS, 1, [DNS tunnel protocol support.]) |
244 | echo "**********************************************************************" |
|
|
245 | echo "**********************************************************************" |
|
|
246 | echo |
|
|
247 | rohc=true |
|
|
248 | AC_DEFINE_UNQUOTED(ENABLE_ROHC, 1, [ROHC support]) |
|
|
249 | ] |
329 | ] |
250 | ) |
330 | ) |
251 | |
331 | |
252 | AM_CONDITIONAL(ROHC, test x$rohc = xtrue) |
332 | RSA=3072 |
253 | |
333 | AC_ARG_ENABLE(rsa-length, |
254 | AC_ARG_ENABLE(icmp, |
334 | [AS_HELP_STRING(--enable-rsa-length=BITS,[ |
255 | [AS_HELP_STRING(--enable-icmp,enable icmp protocol support (default disabled).)], |
335 | use BITS rsa keys (default 3072). Allowed values are 2048-10240.])], |
256 | AC_DEFINE_UNQUOTED(ENABLE_ICMP, 1, [ICMP protocol support.]) |
336 | RSA=$enableval |
257 | ) |
337 | ) |
|
|
338 | AC_DEFINE_UNQUOTED(RSABITS, $RSA, [Size of RSA keys.]) |
258 | |
339 | |
259 | AC_ARG_ENABLE(tcp, |
|
|
260 | [AS_HELP_STRING(--enable-tcp,enable tcp protocol support (default disabled).)], |
|
|
261 | AC_DEFINE_UNQUOTED(ENABLE_TCP, 1, [TCP protocol support.]) |
|
|
262 | ) |
|
|
263 | |
|
|
264 | AC_ARG_ENABLE(dns, |
|
|
265 | [AS_HELP_STRING(--enable-dns,enable dns tunnel protocol support (DOES NOT WORK).)], |
|
|
266 | AC_DEFINE_UNQUOTED(ENABLE_DNS, 1, [DNS tunnel protocol support.]) |
|
|
267 | ) |
|
|
268 | |
|
|
269 | AC_ARG_ENABLE(http-proxy, |
|
|
270 | [AS_HELP_STRING(--enable-http-proxy,enable http proxy connect support (default disabled).)], |
|
|
271 | AC_DEFINE_UNQUOTED(ENABLE_HTTP_PROXY, 1, [http proxy connect support.]) |
|
|
272 | ) |
|
|
273 | |
|
|
274 | HMAC=12 |
340 | HMACSIZE=12 |
275 | AC_ARG_ENABLE(hmac-length, |
341 | AC_ARG_ENABLE(hmac-length, |
276 | [AS_HELP_STRING(--enable-hmac-length=BYTES,[ |
342 | [AS_HELP_STRING(--enable-hmac-length=BYTES,[ |
277 | use a hmac of length BYTES bytes (default 12). Allowed values are 4, 8, 12, 16.])], |
343 | use a hmac of length BYTES bytes (default 12). Allowed values are 4, 8, 12, 16.])], |
278 | HMAC=$enableval |
344 | HMACSIZE=$enableval |
279 | ) |
345 | ) |
280 | AC_DEFINE_UNQUOTED(HMACLENGTH, $HMAC, [Size of HMAC in each packet in bytes.]) |
346 | AC_DEFINE_UNQUOTED(HMACLENGTH, $HMACSIZE, [Size of HMAC in each packet in bytes.]) |
281 | |
|
|
282 | RAND=8 |
|
|
283 | AC_ARG_ENABLE(rand-length, |
|
|
284 | [AS_HELP_STRING(--enable-rand-length=BYTES, |
|
|
285 | [use BYTES bytes of extra randomness (default 8). Allowed values are 0, 4, 8.])], |
|
|
286 | RAND=$enableval |
|
|
287 | ) |
|
|
288 | AC_DEFINE_UNQUOTED(RAND_SIZE, $RAND, [Add this many bytes of randomness to each packet.]) |
|
|
289 | |
347 | |
290 | MTU=1500 |
348 | MTU=1500 |
291 | AC_ARG_ENABLE(mtu, |
349 | AC_ARG_ENABLE(max-mtu, |
292 | [AS_HELP_STRING(--enable-max-mtu=BYTES,enable mtu sizes upto BYTES bytes (default 1500). Use 9100 for jumbogram support.)], |
350 | [AS_HELP_STRING(--enable-max-mtu=BYTES,enable mtu sizes upto BYTES bytes (default 1500). Use 9100 for jumbogram support.)], |
293 | MTU=$enableval |
351 | MTU=$enableval |
294 | ) |
352 | ) |
295 | AC_DEFINE_UNQUOTED(MAX_MTU, $MTU + 14, [Maximum MTU supported.]) |
353 | AC_DEFINE_UNQUOTED(MAX_MTU, ($MTU + 14), [Maximum MTU supported.]) |
296 | |
354 | |
297 | COMPRESS=1 |
355 | COMPRESS=1 |
298 | AC_ARG_ENABLE(compression, |
356 | AC_ARG_ENABLE(compression, |
299 | [AS_HELP_STRING(--disable-compression,Disable compression support.)], |
357 | [AS_HELP_STRING(--disable-compression,Disable compression support.)], |
300 | if test "x$enableval" = xno; then |
358 | if test "x$enableval" = xno; then |
301 | COMPRESS=0 |
359 | COMPRESS=0 |
302 | fi |
360 | fi |
303 | ) |
361 | ) |
304 | AC_DEFINE_UNQUOTED(ENABLE_COMPRESSION, $COMPRESS, [Enable compression support.]) |
362 | AC_DEFINE_UNQUOTED(ENABLE_COMPRESSION, $COMPRESS, [Enable compression support.]) |
305 | |
363 | |
306 | CIPHER=bf_cbc |
364 | CIPHER=aes_128_ctr |
307 | AC_ARG_ENABLE(cipher, |
365 | AC_ARG_ENABLE(cipher, |
308 | [AS_HELP_STRING(--enable-cipher,[ |
366 | [AS_HELP_STRING(--enable-cipher=CIPHER,[ |
309 | Select the symmetric cipher (default "bf"). |
367 | Select the symmetric cipher (default "aes-128"). |
310 | Must be one of "bf" (blowfish), "aes-128" (rijndael), "aes-192" or "aes-256".])], |
368 | Must be one of "aes-128" (rijndael), "aes-192", or "aes-256".])], |
311 | if test "x$enableval" = xbf ; then CIPHER=bf_cbc ; fi |
369 | #if test "x$enableval" = xbf ; then CIPHER=bf_ctr ; fi |
312 | if test "x$enableval" = xaes-128; then CIPHER=aes_128_cbc; fi |
370 | if test "x$enableval" = xaes-128 ; then CIPHER=aes_128_ctr ; fi |
313 | if test "x$enableval" = xaes-192; then CIPHER=aes_192_cbc; fi |
371 | if test "x$enableval" = xaes-192 ; then CIPHER=aes_192_ctr ; fi |
314 | if test "x$enableval" = xaes-256; then CIPHER=aes_256_cbc; fi |
372 | if test "x$enableval" = xaes-256 ; then CIPHER=aes_256_ctr ; fi |
|
|
373 | #if test "x$enableval" = xcamellia-128; then CIPHER=camellia_128_ctr; fi |
|
|
374 | #if test "x$enableval" = xcamellia-256; then CIPHER=camellia_256_ctr; fi |
315 | ) |
375 | ) |
316 | AC_DEFINE_UNQUOTED(ENABLE_CIPHER, EVP_${CIPHER}, [Select the symmetric cipher to use.]) |
376 | AC_DEFINE_UNQUOTED(ENABLE_CIPHER, EVP_${CIPHER}, [Select the symmetric cipher to use.]) |
317 | |
377 | |
318 | DIGEST=sha1 |
378 | HMAC=sha1 |
319 | AC_ARG_ENABLE(digest, |
379 | AC_ARG_ENABLE(hmac-digest, |
320 | [AS_HELP_STRING(--enable-digest,[ |
380 | [AS_HELP_STRING(--enable-hmac-digest=HMAC,[ |
321 | Select the digets algorithm to use (default "sha1"). Must be one of |
381 | Select the HMAC digest algorithm to use (default "sha1"). Must be one of |
322 | "sha1", "ripemd160", "md5" or "md4" (insecure).])], |
382 | "sha512", "sha256", "sha1", "ripemd160", "whirlpool".])], |
|
|
383 | if test "x$enableval" = xwhirlpool; then HMAC=whirlpool; fi |
|
|
384 | if test "x$enableval" = xsha512 ; then HMAC=sha512 ; fi |
|
|
385 | if test "x$enableval" = xsha256 ; then HMAC=sha256 ; fi |
323 | if test "x$enableval" = xsha1 ; then DIGEST=sha1 ; fi |
386 | if test "x$enableval" = xsha1 ; then HMAC=sha1 ; fi |
324 | if test "x$enableval" = xripemd160; then DIGEST=ripemd160; fi |
387 | if test "x$enableval" = xripemd160; then HMAC=ripemd160; fi |
|
|
388 | ) |
|
|
389 | AC_DEFINE_UNQUOTED(ENABLE_HMAC, EVP_${HMAC}, [Select the HMAC digest algorithm to use.]) |
|
|
390 | |
|
|
391 | AUTH=sha512 |
|
|
392 | AC_ARG_ENABLE(auth-digest, |
|
|
393 | [AS_HELP_STRING(--enable-auth-digest=DIGEST,[ |
|
|
394 | Select the hmac algorithm to use (default "sha512"). Must be one of |
|
|
395 | "sha512", "sha256", "whirlpool".])], |
|
|
396 | if test "x$enableval" = xwhirlpool; then AUTH=whirlpool; fi |
325 | if test "x$enableval" = xmd5 ; then DIGEST=md5 ; fi |
397 | if test "x$enableval" = xsha512 ; then AUTH=sha512 ; fi |
326 | if test "x$enableval" = xmd4 ; then DIGEST=md4 ; fi |
398 | if test "x$enableval" = xsha256 ; then AUTH=sha256 ; fi |
327 | ) |
399 | ) |
328 | AC_DEFINE_UNQUOTED(ENABLE_DIGEST, EVP_${DIGEST}, [Select the digest algorithm to use.]) |
400 | AC_DEFINE_UNQUOTED(ENABLE_AUTH, EVP_${AUTH}, [Select the auth digest algorithm to use.]) |
329 | |
401 | |
330 | if $CXX -v --help 2>&1 | grep -q fno-rtti; then |
402 | if $CXX -v --help 2>&1 | grep -q fno-rtti; then |
331 | CXXFLAGS="$CXXFLAGS -fno-rtti" |
403 | CXXFLAGS="$CXXFLAGS -fno-rtti" |
332 | fi |
404 | fi |
333 | |
405 | |
334 | if $CXX -v --help 2>&1 | grep -q fexceptions; then |
406 | #if $CXX -v --help 2>&1 | grep -q fexceptions; then |
335 | CXXFLAGS="$CXXFLAGS -fno-exceptions" |
407 | # CXXFLAGS="$CXXFLAGS -fno-exceptions" |
336 | fi |
408 | #fi |
|
|
409 | |
|
|
410 | LIBS="$EXTRA_LIBS $LIBS" |
337 | |
411 | |
338 | dnl if $CXX -v --help 2>&1 | grep -q ffunction-sections; then |
412 | dnl if $CXX -v --help 2>&1 | grep -q ffunction-sections; then |
339 | dnl CXXFLAGS="$CXXFLAGS -ffunction-sections" |
413 | dnl CXXFLAGS="$CXXFLAGS -ffunction-sections" |
340 | dnl fi |
414 | dnl fi |
341 | dnl |
415 | dnl |
342 | dnl if $LD -v --help 2>&1 | grep -q gc-sections; then |
416 | dnl if $LD -v --help 2>&1 | grep -q gc-sections; then |
343 | dnl LDFLAGS="$LDFLAGS -Wl,--gc-sections" |
417 | dnl LDFLAGS="$LDFLAGS -Wl,--gc-sections" |
344 | dnl fi |
418 | dnl fi |
345 | |
419 | |
346 | AC_CONFIG_COMMANDS_POST([ |
420 | AC_SUBST(INCLUDES) |
|
|
421 | |
|
|
422 | AC_CONFIG_FILES([Makefile po/Makefile.in |
|
|
423 | src/Makefile |
|
|
424 | doc/Makefile |
|
|
425 | lib/Makefile |
|
|
426 | m4/Makefile |
|
|
427 | ]) |
|
|
428 | AC_OUTPUT |
347 | |
429 | |
348 | echo |
430 | echo |
349 | echo "***" |
431 | echo "***" |
350 | echo "*** Configuration Summary" |
432 | echo "*** Configuration Summary" |
351 | echo "***" |
433 | echo "***" |
352 | echo "*** Kernel Iface: $IFTYPE/$IFSUBTYPE" |
434 | echo "*** Kernel Iface: $IFTYPE/$IFSUBTYPE" |
|
|
435 | echo "*** RSA size: $RSA" |
353 | echo "*** Cipher used: $CIPHER" |
436 | echo "*** Cipher used: $CIPHER" |
354 | echo "*** Digest used: $DIGEST" |
437 | echo "*** Digest used: $DIGEST" |
|
|
438 | echo "*** Authdigest: $AUTH" |
355 | echo "*** HMAC length: $HMAC" |
439 | echo "*** HMAC length: $HMAC" |
356 | echo "*** RAND used: $RAND" |
|
|
357 | echo "*** Max. MTU: $MTU" |
440 | echo "*** Max. MTU: $MTU" |
358 | echo "*** Compression: $COMPRESS" |
|
|
359 | |
441 | |
360 | if test "x$DIGEST" = xmd4; then |
|
|
361 | echo "***" |
442 | echo "***" |
362 | echo "*** WARNING: The digest you have chosen ($DIGEST) is known to be insecure" |
443 | echo "*** Enable options:" |
363 | fi |
444 | grep ENABLE_ config.h | sed -e 's/^/*** /' |
364 | |
445 | |
365 | if test "$HMAC" -lt 12; then |
446 | if test "$HMACSIZE" -lt 12; then |
366 | echo "***" |
447 | echo "***" |
367 | echo "*** WARNING: The hmac length you have chosen ($HMAC) is probably insecure" |
448 | echo "*** WARNING: The hmac length you have chosen ($HMACSIZE) is quite insecure" |
368 | fi |
449 | fi |
369 | |
450 | |
370 | if test "$RAND" -lt 8; then |
|
|
371 | echo "***" |
451 | echo "***" |
372 | echo "*** WARNING: The random prefix you have chosen ($RAND) is probably insecure" |
|
|
373 | fi |
|
|
374 | |
|
|
375 | echo "***" |
|
|
376 | |
|
|
377 | echo |
452 | echo |
378 | |
453 | |
379 | ]) |
|
|
380 | |
454 | |
381 | AC_SUBST(INCLUDES) |
|
|
382 | |
|
|
383 | AC_CONFIG_FILES([Makefile po/Makefile.in |
|
|
384 | src/Makefile |
|
|
385 | doc/Makefile |
|
|
386 | lib/Makefile |
|
|
387 | m4/Makefile |
|
|
388 | ]) |
|
|
389 | AC_OUTPUT |
|
|