]>
Commit | Line | Data |
---|---|---|
1 | dnl configure.in for linux strongSwan | |
2 | dnl Copyright (C) 2006 Martin Willi | |
3 | dnl Hochschule fuer Technik Rapperswil | |
4 | dnl | |
5 | dnl This program is free software; you can redistribute it and/or modify it | |
6 | dnl under the terms of the GNU General Public License as published by the | |
7 | dnl Free Software Foundation; either version 2 of the License, or (at your | |
8 | dnl option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>. | |
9 | dnl | |
10 | dnl This program is distributed in the hope that it will be useful, but | |
11 | dnl WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY | |
12 | dnl or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
13 | dnl for more details. | |
14 | ||
15 | dnl =========================== | |
16 | dnl initialize & set some vars | |
17 | dnl =========================== | |
18 | ||
19 | AC_INIT(strongSwan,5.0.0rc1) | |
20 | AM_INIT_AUTOMAKE(tar-ustar) | |
21 | AC_CONFIG_MACRO_DIR([m4/config]) | |
22 | PKG_PROG_PKG_CONFIG | |
23 | ||
24 | dnl ================================= | |
25 | dnl check --enable-xxx & --with-xxx | |
26 | dnl ================================= | |
27 | ||
28 | m4_include(m4/macros/with.m4) | |
29 | ||
30 | ARG_WITH_SUBST([default-pkcs11], [/usr/lib/opensc-pkcs11.so], [set the default PKCS11 library]) | |
31 | ARG_WITH_SUBST([random-device], [/dev/random], [set the device to read real random data from]) | |
32 | ARG_WITH_SUBST([urandom-device], [/dev/urandom], [set the device to read pseudo random data from]) | |
33 | ARG_WITH_SUBST([strongswan-conf], [${sysconfdir}/strongswan.conf], [set the strongswan.conf file location]) | |
34 | ARG_WITH_SUBST([resolv-conf], [${sysconfdir}/resolv.conf], [set the file to use in DNS handler plugin]) | |
35 | ARG_WITH_SUBST([piddir], [/var/run], [set path for PID and UNIX socket files]) | |
36 | ARG_WITH_SUBST([ipsecdir], [${libexecdir%/}/ipsec], [set installation path for ipsec tools]) | |
37 | ARG_WITH_SUBST([ipseclibdir], [${libdir%/}/ipsec], [set installation path for ipsec libraries]) | |
38 | ARG_WITH_SUBST([plugindir], [${ipseclibdir%/}/plugins], [set the installation path of plugins]) | |
39 | ARG_WITH_SUBST([imcvdir], [${ipseclibdir%/}/imcvs], [set the installation path of IMC and IMV dynamic librariers]) | |
40 | ARG_WITH_SUBST([nm-ca-dir], [/usr/share/ca-certificates], [directory the NM backend uses to look up trusted root certificates]) | |
41 | ARG_WITH_SUBST([linux-headers], [\${top_srcdir}/src/include], [set directory of linux header files to use]) | |
42 | ARG_WITH_SUBST([routing-table], [220], [set routing table to use for IPsec routes]) | |
43 | ARG_WITH_SUBST([routing-table-prio], [220], [set priority for IPsec routing table]) | |
44 | ||
45 | ARG_WITH_SET([capabilities], [no], [set capability dropping library. Currently supported values are "libcap" and "native"]) | |
46 | ARG_WITH_SET([mpz_powm_sec], [yes], [use the more side-channel resistant mpz_powm_sec in libgmp, if available]) | |
47 | ||
48 | if test -n "$PKG_CONFIG"; then | |
49 | systemdsystemunitdir_default=$($PKG_CONFIG --variable=systemdsystemunitdir systemd) | |
50 | fi | |
51 | ARG_WITH_SET([systemdsystemunitdir], [$systemdsystemunitdir_default], [directory for systemd service files]) | |
52 | AM_CONDITIONAL(HAVE_SYSTEMD, [test -n "$systemdsystemunitdir" -a "x$systemdsystemunitdir" != xno]) | |
53 | AC_SUBST(systemdsystemunitdir) | |
54 | ||
55 | AC_ARG_WITH( | |
56 | [xauth-module], | |
57 | AS_HELP_STRING([--with-xauth-module=lib],[set the path to the XAUTH module]), | |
58 | [AC_DEFINE_UNQUOTED(XAUTH_DEFAULT_LIB, "$withval")], | |
59 | ) | |
60 | ||
61 | AC_ARG_WITH( | |
62 | [user], | |
63 | AS_HELP_STRING([--with-user=user],[change user of the daemons to "user" after startup (default is "root").]), | |
64 | [AC_DEFINE_UNQUOTED(IPSEC_USER, "$withval") AC_SUBST(ipsecuser, "$withval")], | |
65 | [AC_SUBST(ipsecuser, "root")] | |
66 | ) | |
67 | ||
68 | AC_ARG_WITH( | |
69 | [group], | |
70 | AS_HELP_STRING([--with-group=group],[change group of the daemons to "group" after startup (default is "root").]), | |
71 | [AC_DEFINE_UNQUOTED(IPSEC_GROUP, "$withval") AC_SUBST(ipsecgroup, "$withval")], | |
72 | [AC_SUBST(ipsecgroup, "root")] | |
73 | ) | |
74 | ||
75 | m4_include(m4/macros/enable-disable.m4) | |
76 | ||
77 | ARG_ENABL_SET([curl], [enable CURL fetcher plugin to fetch files via libcurl. Requires libcurl.]) | |
78 | ARG_ENABL_SET([soup], [enable soup fetcher plugin to fetch from HTTP via libsoup. Requires libsoup.]) | |
79 | ARG_ENABL_SET([ldap], [enable LDAP fetching plugin to fetch files via libldap. Requires openLDAP.]) | |
80 | ARG_DISBL_SET([aes], [disable AES software implementation plugin.]) | |
81 | ARG_DISBL_SET([des], [disable DES/3DES software implementation plugin.]) | |
82 | ARG_ENABL_SET([blowfish], [enable Blowfish software implementation plugin.]) | |
83 | ARG_ENABL_SET([md4], [enable MD4 software implementation plugin.]) | |
84 | ARG_DISBL_SET([md5], [disable MD5 software implementation plugin.]) | |
85 | ARG_DISBL_SET([sha1], [disable SHA1 software implementation plugin.]) | |
86 | ARG_DISBL_SET([sha2], [disable SHA256/SHA384/SHA512 software implementation plugin.]) | |
87 | ARG_DISBL_SET([fips-prf], [disable FIPS PRF software implementation plugin.]) | |
88 | ARG_DISBL_SET([gmp], [disable GNU MP (libgmp) based crypto implementation plugin.]) | |
89 | ARG_DISBL_SET([random], [disable RNG implementation on top of /dev/(u)random.]) | |
90 | ARG_DISBL_SET([nonce], [disable nonce generation plugin.]) | |
91 | ARG_DISBL_SET([x509], [disable X509 certificate implementation plugin.]) | |
92 | ARG_DISBL_SET([revocation], [disable X509 CRL/OCSP revocation check plugin.]) | |
93 | ARG_DISBL_SET([constraints], [disable advanced X509 constraint checking plugin.]) | |
94 | ARG_DISBL_SET([pubkey], [disable RAW public key support plugin.]) | |
95 | ARG_DISBL_SET([pkcs1], [disable PKCS1 key decoding plugin.]) | |
96 | ARG_DISBL_SET([pkcs8], [disable PKCS8 private key decoding plugin.]) | |
97 | ARG_DISBL_SET([pgp], [disable PGP key decoding plugin.]) | |
98 | ARG_DISBL_SET([dnskey], [disable DNS RR key decoding plugin.]) | |
99 | ARG_DISBL_SET([pem], [disable PEM decoding plugin.]) | |
100 | ARG_DISBL_SET([hmac], [disable HMAC crypto implementation plugin.]) | |
101 | ARG_DISBL_SET([cmac], [disable CMAC crypto implementation plugin.]) | |
102 | ARG_DISBL_SET([xcbc], [disable xcbc crypto implementation plugin.]) | |
103 | ARG_ENABL_SET([af-alg], [enable AF_ALG crypto interface to Linux Crypto API.]) | |
104 | ARG_ENABL_SET([test-vectors], [enable plugin providing crypto test vectors.]) | |
105 | ARG_ENABL_SET([mysql], [enable MySQL database support. Requires libmysqlclient_r.]) | |
106 | ARG_ENABL_SET([sqlite], [enable SQLite database support. Requires libsqlite3.]) | |
107 | ARG_DISBL_SET([stroke], [disable charons stroke (pluto compatibility) configuration backend.]) | |
108 | ARG_ENABL_SET([medsrv], [enable mediation server web frontend and daemon plugin.]) | |
109 | ARG_ENABL_SET([medcli], [enable mediation client configuration database plugin.]) | |
110 | ARG_ENABL_SET([smp], [enable SMP configuration and control interface. Requires libxml.]) | |
111 | ARG_ENABL_SET([sql], [enable SQL database configuration backend.]) | |
112 | ARG_ENABL_SET([smartcard], [enable smartcard support.]) | |
113 | ARG_ENABL_SET([cisco-quirks], [enable support of Cisco VPN client.]) | |
114 | ARG_ENABL_SET([leak-detective], [enable malloc hooks to find memory leaks.]) | |
115 | ARG_ENABL_SET([lock-profiler], [enable lock/mutex profiling code.]) | |
116 | ARG_ENABL_SET([unit-tester], [enable unit tests on IKEv2 daemon startup.]) | |
117 | ARG_ENABL_SET([load-tester], [enable load testing plugin for IKEv2 daemon.]) | |
118 | ARG_ENABL_SET([eap-sim], [enable SIM authentication module for EAP.]) | |
119 | ARG_ENABL_SET([eap-sim-file], [enable EAP-SIM backend based on a triplet file.]) | |
120 | ARG_ENABL_SET([eap-sim-pcsc], [enable EAP-SIM backend based on a smartcard reader. Requires libpcsclite.]) | |
121 | ARG_ENABL_SET([eap-aka], [enable EAP AKA authentication module.]) | |
122 | ARG_ENABL_SET([eap-aka-3gpp2], [enable EAP AKA backend implementing 3GPP2 algorithms in software. Requires libgmp.]) | |
123 | ARG_ENABL_SET([eap-simaka-sql], [enable EAP-SIM/AKA backend based on a triplet/quintuplet SQL database.]) | |
124 | ARG_ENABL_SET([eap-simaka-pseudonym], [enable EAP-SIM/AKA pseudonym storage plugin.]) | |
125 | ARG_ENABL_SET([eap-simaka-reauth], [enable EAP-SIM/AKA reauthentication data storage plugin.]) | |
126 | ARG_ENABL_SET([eap-identity], [enable EAP module providing EAP-Identity helper.]) | |
127 | ARG_ENABL_SET([eap-md5], [enable EAP MD5 (CHAP) authentication module.]) | |
128 | ARG_ENABL_SET([eap-gtc], [enable PAM based EAP GTC authentication module.]) | |
129 | ARG_ENABL_SET([eap-mschapv2], [enable EAP MS-CHAPv2 authentication module.]) | |
130 | ARG_ENABL_SET([eap-tls], [enable EAP TLS authentication module.]) | |
131 | ARG_ENABL_SET([eap-ttls], [enable EAP TTLS authentication module.]) | |
132 | ARG_ENABL_SET([eap-peap], [enable EAP PEAP authentication module.]) | |
133 | ARG_ENABL_SET([eap-tnc], [enable EAP TNC trusted network connect module.]) | |
134 | ARG_ENABL_SET([eap-radius], [enable RADIUS proxy authentication module.]) | |
135 | ARG_ENABL_SET([xauth-generic], [enable generic XAuth backend.]) | |
136 | ARG_ENABL_SET([xauth-eap], [enable XAuth backend using EAP methods to verify passwords.]) | |
137 | ARG_ENABL_SET([tnc-ifmap], [enable TNC IF-MAP module.]) | |
138 | ARG_ENABL_SET([tnc-pdp], [enable TNC policy decision point module.]) | |
139 | ARG_ENABL_SET([tnc-imc], [enable TNC IMC module.]) | |
140 | ARG_ENABL_SET([tnc-imv], [enable TNC IMV module.]) | |
141 | ARG_ENABL_SET([tnccs-11], [enable TNCCS 1.1 protocol module.]) | |
142 | ARG_ENABL_SET([tnccs-20], [enable TNCCS 2.0 protocol module.]) | |
143 | ARG_ENABL_SET([tnccs-dynamic], [enable dynamic TNCCS protocol discovery module.]) | |
144 | ARG_ENABL_SET([imc-test], [enable IMC test module.]) | |
145 | ARG_ENABL_SET([imv-test], [enable IMV test module.]) | |
146 | ARG_ENABL_SET([imc-scanner], [enable IMC port scanner module.]) | |
147 | ARG_ENABL_SET([imv-scanner], [enable IMV port scanner module.]) | |
148 | ARG_ENABL_SET([imc-attestation],[enable IMC attestation module.]) | |
149 | ARG_ENABL_SET([imv-attestation],[enable IMV attestation module.]) | |
150 | ARG_DISBL_SET([kernel-netlink], [disable the netlink kernel interface.]) | |
151 | ARG_ENABL_SET([kernel-pfkey], [enable the PF_KEY kernel interface.]) | |
152 | ARG_ENABL_SET([kernel-pfroute], [enable the PF_ROUTE kernel interface.]) | |
153 | ARG_ENABL_SET([kernel-klips], [enable the KLIPS kernel interface.]) | |
154 | ARG_DISBL_SET([socket-default], [disable default socket implementation for charon.]) | |
155 | ARG_ENABL_SET([socket-raw], [enable raw socket implementation of charon, enforced if pluto is enabled]) | |
156 | ARG_ENABL_SET([socket-dynamic], [enable dynamic socket implementation for charon]) | |
157 | ARG_ENABL_SET([farp], [enable ARP faking plugin that responds to ARP requests to peers virtual IP]) | |
158 | ARG_ENABL_SET([nat-transport], [enable NAT traversal with IPsec transport mode in pluto.]) | |
159 | ARG_DISBL_SET([vendor-id], [disable the sending of the strongSwan vendor ID in pluto.]) | |
160 | ARG_DISBL_SET([xauth-vid], [disable the sending of the XAUTH vendor ID.]) | |
161 | ARG_ENABL_SET([dumm], [enable the DUMM UML test framework.]) | |
162 | ARG_ENABL_SET([fast], [enable libfast (FastCGI Application Server w/ templates.]) | |
163 | ARG_ENABL_SET([manager], [enable web management console (proof of concept).]) | |
164 | ARG_ENABL_SET([mediation], [enable IKEv2 Mediation Extension.]) | |
165 | ARG_ENABL_SET([integrity-test], [enable integrity testing of libstrongswan and plugins.]) | |
166 | ARG_DISBL_SET([load-warning], [disable the charon/pluto plugin load option warning in starter.]) | |
167 | ARG_ENABL_SET([pluto], [enable the IKEv1 keying daemon pluto.]) | |
168 | ARG_DISBL_SET([ikev1], [disable IKEv1 protocol support in charon.]) | |
169 | ARG_DISBL_SET([ikev2], [disable IKEv2 protocol support in charon.]) | |
170 | ARG_DISBL_SET([xauth], [disable xauth plugin.]) | |
171 | ARG_DISBL_SET([threads], [disable the use of threads in pluto. Charon always uses threads.]) | |
172 | ARG_DISBL_SET([adns], [disable the use of adns in pluto (disables opportunistic encryption).]) | |
173 | ARG_DISBL_SET([charon], [disable the IKEv1/IKEv2 keying daemon charon.]) | |
174 | ARG_DISBL_SET([tools], [disable additional utilities (openac, scepclient and pki).]) | |
175 | ARG_DISBL_SET([scripts], [disable additional utilities (found in directory scripts).]) | |
176 | ARG_ENABL_SET([conftest], [enforce Suite B conformance test framework.]) | |
177 | ARG_DISBL_SET([updown], [disable updown firewall script plugin.]) | |
178 | ARG_DISBL_SET([attr], [disable strongswan.conf based configuration attribute plugin.]) | |
179 | ARG_ENABL_SET([attr-sql], [enable SQL based configuration attribute plugin.]) | |
180 | ARG_ENABL_SET([dhcp], [enable DHCP based attribute provider plugin.]) | |
181 | ARG_DISBL_SET([resolve], [disable resolve DNS handler plugin.]) | |
182 | ARG_ENABL_SET([padlock], [enables VIA Padlock crypto plugin.]) | |
183 | ARG_ENABL_SET([openssl], [enables the OpenSSL crypto plugin.]) | |
184 | ARG_ENABL_SET([gcrypt], [enables the libgcrypt plugin.]) | |
185 | ARG_ENABL_SET([agent], [enables the ssh-agent signing plugin.]) | |
186 | ARG_ENABL_SET([pkcs11], [enables the PKCS11 token support plugin.]) | |
187 | ARG_ENABL_SET([ctr], [enables the Counter Mode wrapper crypto plugin.]) | |
188 | ARG_ENABL_SET([ccm], [enables the CCM AEAD wrapper crypto plugin.]) | |
189 | ARG_ENABL_SET([gcm], [enables the GCM AEAD wrapper crypto plugin.]) | |
190 | ARG_ENABL_SET([addrblock], [enables RFC 3779 address block constraint support.]) | |
191 | ARG_ENABL_SET([uci], [enable OpenWRT UCI configuration plugin.]) | |
192 | ARG_ENABL_SET([android], [enable Android specific plugin.]) | |
193 | ARG_ENABL_SET([maemo], [enable Maemo specific plugin.]) | |
194 | ARG_ENABL_SET([nm], [enable NetworkManager backend.]) | |
195 | ARG_ENABL_SET([ha], [enable high availability cluster plugin.]) | |
196 | ARG_ENABL_SET([whitelist], [enable peer identity whitelisting plugin.]) | |
197 | ARG_ENABL_SET([certexpire], [enable CSV export of expiration dates of used certificates.]) | |
198 | ARG_ENABL_SET([led], [enable plugin to control LEDs on IKEv2 activity using the Linux kernel LED subsystem.]) | |
199 | ARG_ENABL_SET([duplicheck], [advanced duplicate checking plugin using liveness checks.]) | |
200 | ARG_ENABL_SET([coupling], [enable IKEv2 plugin to couple peer certificates permanently to authentication.]) | |
201 | ARG_ENABL_SET([radattr], [enable plugin to inject and process custom RADIUS attributes as IKEv2 client.]) | |
202 | ARG_ENABL_SET([vstr], [enforce using the Vstr string library to replace glibc-like printf hooks.]) | |
203 | ARG_ENABL_SET([monolithic], [build monolithic version of libstrongswan that includes all enabled plugins. Similarly, the plugins of charon are assembled in libcharon.]) | |
204 | ||
205 | dnl ========================= | |
206 | dnl set up compiler and flags | |
207 | dnl ========================= | |
208 | ||
209 | if test -z "$CFLAGS"; then | |
210 | CFLAGS="-g -O2 -Wall -Wno-format -Wno-pointer-sign" | |
211 | fi | |
212 | AC_PROG_CC | |
213 | AC_LIB_PREFIX | |
214 | AC_C_BIGENDIAN | |
215 | ||
216 | dnl ========================= | |
217 | dnl check required programs | |
218 | dnl ========================= | |
219 | ||
220 | AC_PROG_INSTALL | |
221 | AC_PROG_LIBTOOL | |
222 | AC_PROG_EGREP | |
223 | AC_PROG_AWK | |
224 | AC_PROG_LEX | |
225 | AC_PROG_YACC | |
226 | AC_PATH_PROG([PERL], [perl], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) | |
227 | AC_PATH_PROG([GPERF], [gperf], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) | |
228 | ||
229 | dnl because gperf is not needed by end-users we just report it but do not abort on failure | |
230 | AC_MSG_CHECKING([gperf version >= 3.0.0]) | |
231 | if test -x "$GPERF"; then | |
232 | if test "`$GPERF --version | $AWK -F' ' '/^GNU gperf/ { print $3 }' | $AWK -F. '{ print $1 }'`" -ge "3"; then | |
233 | AC_MSG_RESULT([yes]) | |
234 | else | |
235 | AC_MSG_RESULT([no]) | |
236 | fi | |
237 | else | |
238 | AC_MSG_RESULT([not found]) | |
239 | fi | |
240 | ||
241 | dnl ========================= | |
242 | dnl dependency calculation | |
243 | dnl ========================= | |
244 | ||
245 | if test x$eap_aka_3gpp2 = xtrue; then | |
246 | gmp=true; | |
247 | fi | |
248 | ||
249 | if test x$eap_aka = xtrue; then | |
250 | fips_prf=true; | |
251 | simaka=true; | |
252 | fi | |
253 | ||
254 | if test x$eap_sim = xtrue; then | |
255 | fips_prf=true; | |
256 | simaka=true; | |
257 | fi | |
258 | ||
259 | if test x$eap_tls = xtrue -o x$eap_ttls = xtrue -o x$eap_peap = xtrue; then | |
260 | tls=true; | |
261 | fi | |
262 | ||
263 | if test x$eap_radius = xtrue -o x$radattr = xtrue -o x$tnc_pdp = xtrue; then | |
264 | radius=true; | |
265 | fi | |
266 | ||
267 | if test x$tnc_imc = xtrue -o x$tnc_imv = xtrue -o x$tnccs_11 = xtrue -o x$tnccs_11 = xtrue -o x$tnccs_dynamic = xtrue -o x$eap_tnc = xtrue; then | |
268 | tnc_tnccs=true; | |
269 | fi | |
270 | ||
271 | if test x$imc_test = xtrue -o x$imv_test = xtrue -o x$imc_scanner = xtrue -o x$imv_scanner = xtrue -o x$imc_attestation = xtrue -o x$imv_attestation = xtrue; then | |
272 | imcv=true; | |
273 | fi | |
274 | ||
275 | if test x$imc_attestation = xtrue -o x$imv_attestation = xtrue; then | |
276 | pts=true; | |
277 | fi | |
278 | ||
279 | if test x$fips_prf = xtrue; then | |
280 | if test x$openssl = xfalse; then | |
281 | sha1=true; | |
282 | fi | |
283 | fi | |
284 | ||
285 | if test x$smp = xtrue -o x$tnccs_11 = xtrue; then | |
286 | xml=true | |
287 | fi | |
288 | ||
289 | if test x$tnc_ifmap = xtrue; then | |
290 | axis2c=true | |
291 | fi | |
292 | ||
293 | if test x$manager = xtrue; then | |
294 | fast=true | |
295 | fi | |
296 | ||
297 | if test x$medsrv = xtrue; then | |
298 | mediation=true | |
299 | fast=true | |
300 | fi | |
301 | ||
302 | if test x$medcli = xtrue; then | |
303 | mediation=true | |
304 | fi | |
305 | ||
306 | if test x$pluto = xtrue; then | |
307 | if test x$socket_raw = xfalse; then | |
308 | AC_MSG_NOTICE([Enforcing --enable-socket-raw, as pluto is enabled]) | |
309 | socket_raw=true | |
310 | if test x$socket_default_given = xfalse; then | |
311 | socket_default=false | |
312 | fi | |
313 | fi | |
314 | fi | |
315 | ||
316 | dnl =========================================== | |
317 | dnl check required libraries and header files | |
318 | dnl =========================================== | |
319 | ||
320 | AC_HEADER_STDBOOL | |
321 | AC_FUNC_ALLOCA | |
322 | ||
323 | dnl libraries needed on some platforms but not on others | |
324 | dnl ==================================================== | |
325 | saved_LIBS=$LIBS | |
326 | ||
327 | dnl FreeBSD and Mac OS X have dlopen integrated in libc, Linux needs libdl | |
328 | LIBS="" | |
329 | AC_SEARCH_LIBS(dlopen, dl, [DLLIB=$LIBS]) | |
330 | AC_SUBST(DLLIB) | |
331 | ||
332 | dnl glibc's backtrace() can be replicated on FreeBSD with libexecinfo | |
333 | LIBS="" | |
334 | AC_SEARCH_LIBS(backtrace, execinfo, [BTLIB=$LIBS]) | |
335 | AC_CHECK_FUNCS(backtrace) | |
336 | AC_SUBST(BTLIB) | |
337 | ||
338 | dnl OpenSolaris needs libsocket and libnsl for socket() | |
339 | LIBS="" | |
340 | AC_SEARCH_LIBS(socket, socket, [SOCKLIB=$LIBS], | |
341 | [AC_CHECK_LIB(nsl, socket, [SOCKLIB="-lsocket -lnsl"], [], [-lsocket])] | |
342 | ) | |
343 | AC_SUBST(SOCKLIB) | |
344 | ||
345 | dnl FreeBSD has clock_gettime in libc, Linux needs librt | |
346 | LIBS="" | |
347 | AC_SEARCH_LIBS(clock_gettime, rt, [RTLIB=$LIBS]) | |
348 | AC_CHECK_FUNCS(clock_gettime) | |
349 | AC_SUBST(RTLIB) | |
350 | ||
351 | dnl Android has pthread_* functions in bionic (libc), others need libpthread | |
352 | LIBS="" | |
353 | AC_SEARCH_LIBS(pthread_create, pthread, [PTHREADLIB=$LIBS]) | |
354 | AC_SUBST(PTHREADLIB) | |
355 | ||
356 | LIBS=$saved_LIBS | |
357 | dnl ====================== | |
358 | ||
359 | AC_MSG_CHECKING(for dladdr) | |
360 | AC_TRY_COMPILE( | |
361 | [#define _GNU_SOURCE | |
362 | #include <dlfcn.h>], | |
363 | [Dl_info* info = 0; | |
364 | dladdr(0, info);], | |
365 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_DLADDR])], | |
366 | [AC_MSG_RESULT([no])] | |
367 | ) | |
368 | ||
369 | dnl check if pthread_condattr_setclock(CLOCK_MONOTONE) is supported | |
370 | saved_LIBS=$LIBS | |
371 | LIBS=$PTHREADLIB | |
372 | AC_MSG_CHECKING([for pthread_condattr_setclock(CLOCK_MONOTONE)]) | |
373 | AC_TRY_RUN( | |
374 | [#include <pthread.h> | |
375 | int main() { pthread_condattr_t attr; | |
376 | pthread_condattr_init(&attr); | |
377 | return pthread_condattr_setclock(&attr, CLOCK_MONOTONIC);}], | |
378 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_CONDATTR_CLOCK_MONOTONIC])], | |
379 | [AC_MSG_RESULT([no])], | |
380 | dnl Check existence of pthread_condattr_setclock if cross-compiling | |
381 | [AC_MSG_RESULT([unknown]); | |
382 | AC_CHECK_FUNCS(pthread_condattr_setclock, | |
383 | [AC_DEFINE([HAVE_CONDATTR_CLOCK_MONOTONIC])] | |
384 | )] | |
385 | ) | |
386 | dnl check if we actually are able to configure attributes on cond vars | |
387 | AC_CHECK_FUNCS(pthread_condattr_init) | |
388 | dnl instead of pthread_condattr_setclock Android has this function | |
389 | AC_CHECK_FUNCS(pthread_cond_timedwait_monotonic) | |
390 | dnl check if we can cancel threads | |
391 | AC_CHECK_FUNCS(pthread_cancel) | |
392 | dnl check if native rwlocks are available | |
393 | AC_CHECK_FUNCS(pthread_rwlock_init) | |
394 | LIBS=$saved_LIBS | |
395 | ||
396 | AC_CHECK_FUNC( | |
397 | [gettid], | |
398 | [AC_DEFINE(HAVE_GETTID)], | |
399 | [AC_MSG_CHECKING([for SYS_gettid]) | |
400 | AC_TRY_COMPILE( | |
401 | [#define _GNU_SOURCE | |
402 | #include <unistd.h> | |
403 | #include <sys/syscall.h>], | |
404 | [int main() { | |
405 | return syscall(SYS_gettid);}], | |
406 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_GETTID]) | |
407 | AC_DEFINE([HAVE_SYS_GETTID])], | |
408 | [AC_MSG_RESULT([no])] | |
409 | )] | |
410 | ) | |
411 | ||
412 | AC_CHECK_FUNCS(prctl mallinfo getpass closefrom) | |
413 | ||
414 | AC_CHECK_HEADERS(sys/sockio.h glob.h) | |
415 | AC_CHECK_HEADERS(net/pfkeyv2.h netipsec/ipsec.h netinet6/ipsec.h linux/udp.h) | |
416 | ||
417 | AC_CHECK_MEMBERS([struct sockaddr.sa_len], [], [], | |
418 | [ | |
419 | #include <sys/types.h> | |
420 | #include <sys/socket.h> | |
421 | ]) | |
422 | ||
423 | AC_CHECK_MEMBERS([struct sadb_x_policy.sadb_x_policy_priority], [], [], | |
424 | [ | |
425 | #include <sys/types.h> | |
426 | #ifdef HAVE_NET_PFKEYV2_H | |
427 | #include <net/pfkeyv2.h> | |
428 | #else | |
429 | #include <stdint.h> | |
430 | #include <linux/pfkeyv2.h> | |
431 | #endif | |
432 | ]) | |
433 | ||
434 | AC_MSG_CHECKING([for in6addr_any]) | |
435 | AC_TRY_COMPILE( | |
436 | [#include <sys/types.h> | |
437 | #include <sys/socket.h> | |
438 | #include <netinet/in.h>], | |
439 | [struct in6_addr in6; | |
440 | in6 = in6addr_any;], | |
441 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_IN6ADDR_ANY])], | |
442 | [AC_MSG_RESULT([no])] | |
443 | ) | |
444 | ||
445 | AC_MSG_CHECKING([for in6_pktinfo]) | |
446 | AC_TRY_COMPILE( | |
447 | [#define _GNU_SOURCE | |
448 | #include <sys/types.h> | |
449 | #include <sys/socket.h> | |
450 | #include <netinet/in.h>], | |
451 | [struct in6_pktinfo pi; | |
452 | if (pi.ipi6_ifindex) | |
453 | { | |
454 | return 0; | |
455 | }], | |
456 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_IN6_PKTINFO])], | |
457 | [AC_MSG_RESULT([no])] | |
458 | ) | |
459 | ||
460 | AC_MSG_CHECKING([for IPSEC_MODE_BEET]) | |
461 | AC_TRY_COMPILE( | |
462 | [#include <sys/types.h> | |
463 | #ifdef HAVE_NETIPSEC_IPSEC_H | |
464 | #include <netipsec/ipsec.h> | |
465 | #elif defined(HAVE_NETINET6_IPSEC_H) | |
466 | #include <netinet6/ipsec.h> | |
467 | #else | |
468 | #include <stdint.h> | |
469 | #include <linux/ipsec.h> | |
470 | #endif], | |
471 | [int mode = IPSEC_MODE_BEET; | |
472 | return mode;], | |
473 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_IPSEC_MODE_BEET])], | |
474 | [AC_MSG_RESULT([no])] | |
475 | ) | |
476 | ||
477 | AC_MSG_CHECKING([for IPSEC_DIR_FWD]) | |
478 | AC_TRY_COMPILE( | |
479 | [#include <sys/types.h> | |
480 | #ifdef HAVE_NETIPSEC_IPSEC_H | |
481 | #include <netipsec/ipsec.h> | |
482 | #elif defined(HAVE_NETINET6_IPSEC_H) | |
483 | #include <netinet6/ipsec.h> | |
484 | #else | |
485 | #include <stdint.h> | |
486 | #include <linux/ipsec.h> | |
487 | #endif], | |
488 | [int dir = IPSEC_DIR_FWD; | |
489 | return dir;], | |
490 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_IPSEC_DIR_FWD])], | |
491 | [AC_MSG_RESULT([no])] | |
492 | ) | |
493 | ||
494 | AC_MSG_CHECKING([for RTA_TABLE]) | |
495 | AC_TRY_COMPILE( | |
496 | [#include <sys/socket.h> | |
497 | #include <linux/netlink.h> | |
498 | #include <linux/rtnetlink.h>], | |
499 | [int rta_type = RTA_TABLE; | |
500 | return rta_type;], | |
501 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_RTA_TABLE])], | |
502 | [AC_MSG_RESULT([no])] | |
503 | ) | |
504 | ||
505 | AC_MSG_CHECKING([for gcc atomic operations]) | |
506 | AC_TRY_RUN( | |
507 | [ | |
508 | int main() { | |
509 | volatile int ref = 1; | |
510 | __sync_fetch_and_add (&ref, 1); | |
511 | __sync_sub_and_fetch (&ref, 1); | |
512 | /* Make sure test fails if operations are not supported */ | |
513 | __sync_val_compare_and_swap(&ref, 1, 0); | |
514 | return ref; | |
515 | } | |
516 | ], | |
517 | [AC_MSG_RESULT([yes]); AC_DEFINE(HAVE_GCC_ATOMIC_OPERATIONS)], | |
518 | [AC_MSG_RESULT([no])], | |
519 | [AC_MSG_RESULT([no])]) | |
520 | ||
521 | dnl check for the new register_printf_specifier function with len argument, | |
522 | dnl or the deprecated register_printf_function without | |
523 | AC_CHECK_FUNC( | |
524 | [register_printf_specifier], | |
525 | [AC_DEFINE(HAVE_PRINTF_SPECIFIER)], | |
526 | [AC_CHECK_FUNC( | |
527 | [register_printf_function], | |
528 | [AC_DEFINE(HAVE_PRINTF_FUNCTION)], | |
529 | [ | |
530 | AC_MSG_NOTICE([printf does not support custom format specifiers!]) | |
531 | vstr=true | |
532 | ] | |
533 | )] | |
534 | ) | |
535 | ||
536 | if test x$vstr = xtrue; then | |
537 | AC_HAVE_LIBRARY([vstr],[LIBS="$LIBS"],[AC_MSG_ERROR([Vstr string library not found])]) | |
538 | AC_DEFINE(USE_VSTR) | |
539 | fi | |
540 | ||
541 | if test x$gmp = xtrue; then | |
542 | saved_LIBS=$LIBS | |
543 | AC_HAVE_LIBRARY([gmp],,[AC_MSG_ERROR([GNU Multi Precision library gmp not found])]) | |
544 | AC_MSG_CHECKING([mpz_powm_sec]) | |
545 | if test x$mpz_powm_sec = xyes; then | |
546 | AC_TRY_COMPILE( | |
547 | [#include "gmp.h"], | |
548 | [ | |
549 | void *x = mpz_powm_sec; | |
550 | ], | |
551 | [AC_MSG_RESULT([yes]); AC_DEFINE(HAVE_MPZ_POWM_SEC)], [AC_MSG_RESULT([no])] | |
552 | ) | |
553 | else | |
554 | AC_MSG_RESULT([disabled]) | |
555 | fi | |
556 | LIBS=$saved_LIBS | |
557 | AC_MSG_CHECKING([gmp.h version >= 4.1.4]) | |
558 | AC_TRY_COMPILE( | |
559 | [#include "gmp.h"], | |
560 | [ | |
561 | #if (__GNU_MP_VERSION*100 + __GNU_MP_VERSION_MINOR*10 + __GNU_MP_VERSION_PATCHLEVEL) < 414 | |
562 | #error bad gmp | |
563 | #endif | |
564 | ], | |
565 | [AC_MSG_RESULT([yes])], [AC_MSG_RESULT([no]); AC_MSG_ERROR([No usable gmp.h found!])] | |
566 | ) | |
567 | fi | |
568 | ||
569 | if test x$ldap = xtrue; then | |
570 | AC_HAVE_LIBRARY([ldap],[LIBS="$LIBS"],[AC_MSG_ERROR([LDAP library ldap not found])]) | |
571 | AC_HAVE_LIBRARY([lber],[LIBS="$LIBS"],[AC_MSG_ERROR([LDAP library lber not found])]) | |
572 | AC_CHECK_HEADER([ldap.h],,[AC_MSG_ERROR([LDAP header ldap.h not found!])]) | |
573 | fi | |
574 | ||
575 | if test x$curl = xtrue; then | |
576 | AC_HAVE_LIBRARY([curl],[LIBS="$LIBS"],[AC_MSG_ERROR([CURL library curl not found])]) | |
577 | AC_CHECK_HEADER([curl/curl.h],,[AC_MSG_ERROR([CURL header curl/curl.h not found!])]) | |
578 | fi | |
579 | ||
580 | if test x$soup = xtrue; then | |
581 | PKG_CHECK_MODULES(soup, [libsoup-2.4]) | |
582 | AC_SUBST(soup_CFLAGS) | |
583 | AC_SUBST(soup_LIBS) | |
584 | fi | |
585 | ||
586 | if test x$xml = xtrue; then | |
587 | PKG_CHECK_MODULES(xml, [libxml-2.0]) | |
588 | AC_SUBST(xml_CFLAGS) | |
589 | AC_SUBST(xml_LIBS) | |
590 | fi | |
591 | ||
592 | if test x$axis2c = xtrue; then | |
593 | PKG_CHECK_MODULES(axis2c, [axis2c]) | |
594 | AC_SUBST(axis2c_CFLAGS) | |
595 | AC_SUBST(axis2c_LIBS) | |
596 | fi | |
597 | ||
598 | if test x$imc_attestation = xtrue -o x$imv_attestation = xtrue; then | |
599 | AC_HAVE_LIBRARY([tspi],[LIBS="$LIBS"],[AC_MSG_ERROR([TrouSerS library libtspi not found])]) | |
600 | AC_CHECK_HEADER([trousers/tss.h],,[AC_MSG_ERROR([TrouSerS header trousers/tss.h not found!])]) | |
601 | fi | |
602 | ||
603 | if test x$dumm = xtrue; then | |
604 | PKG_CHECK_MODULES(gtk, [gtk+-2.0 vte]) | |
605 | AC_SUBST(gtk_CFLAGS) | |
606 | AC_SUBST(gtk_LIBS) | |
607 | AC_CHECK_PROGS(RUBY, ruby) | |
608 | AC_MSG_CHECKING([for Ruby header files]) | |
609 | if test -n "$RUBY"; then | |
610 | RUBYDIR=`($RUBY -rmkmf -e 'print Config::CONFIG[["archdir"]] || $archdir') 2>/dev/null` | |
611 | if test -n "$RUBYDIR"; then | |
612 | dirs="$RUBYDIR" | |
613 | RUBYINCLUDE=none | |
614 | for i in $dirs; do | |
615 | if test -r $i/ruby.h; then | |
616 | AC_MSG_RESULT([$i]) | |
617 | RUBYINCLUDE="-I$i" | |
618 | break; | |
619 | fi | |
620 | done | |
621 | if test x"$RUBYINCLUDE" = xnone; then | |
622 | AC_MSG_ERROR([ruby.h not found]) | |
623 | fi | |
624 | AC_SUBST(RUBYINCLUDE) | |
625 | else | |
626 | AC_MSG_ERROR([unable to determine ruby configuration]) | |
627 | fi | |
628 | else | |
629 | AC_MSG_ERROR([don't know how to run ruby]) | |
630 | fi | |
631 | fi | |
632 | ||
633 | if test x$fast = xtrue; then | |
634 | AC_HAVE_LIBRARY([neo_cgi],[LIBS="$LIBS"],[AC_MSG_ERROR([ClearSilver library neo_cgi not found!])]) | |
635 | AC_HAVE_LIBRARY([neo_utl],[LIBS="$LIBS"],[AC_MSG_ERROR([ClearSilver library neo_utl not found!])]) | |
636 | AC_MSG_CHECKING([ClearSilver requires zlib]) | |
637 | saved_CFLAGS=$CFLAGS | |
638 | saved_LIBS=$LIBS | |
639 | LIBS="-lneo_cgi -lneo_cs -lneo_utl" | |
640 | CFLAGS="-I/usr/include/ClearSilver" | |
641 | AC_TRY_LINK( | |
642 | [#include <ClearSilver.h>], | |
643 | [ | |
644 | NEOERR *err = cgi_display(NULL, NULL); | |
645 | ], | |
646 | [AC_MSG_RESULT([no]); clearsilver_LIBS="$LIBS"], | |
647 | [AC_MSG_RESULT([yes]); clearsilver_LIBS="$LIBS -lz"] | |
648 | ) | |
649 | AC_SUBST(clearsilver_LIBS) | |
650 | LIBS=$saved_LIBS | |
651 | CFLAGS=$saved_CFLAGS | |
652 | dnl autoconf does not like CamelCase!? How to fix this? | |
653 | dnl AC_CHECK_HEADER([ClearSilver/ClearSilver.h],,[AC_MSG_ERROR([ClearSilver header file ClearSilver/ClearSilver.h not found!])]) | |
654 | ||
655 | AC_HAVE_LIBRARY([fcgi],[LIBS="$LIBS"],[AC_MSG_ERROR([FastCGI library fcgi not found!])]) | |
656 | AC_CHECK_HEADER([fcgiapp.h],,[AC_MSG_ERROR([FastCGI header file fcgiapp.h not found!])]) | |
657 | fi | |
658 | ||
659 | if test x$mysql = xtrue; then | |
660 | AC_PATH_PROG([MYSQLCONFIG], [mysql_config], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) | |
661 | if test x$MYSQLCONFIG = x; then | |
662 | AC_MSG_ERROR([mysql_config not found!]) | |
663 | fi | |
664 | AC_SUBST(MYSQLLIB, `$MYSQLCONFIG --libs_r`) | |
665 | AC_SUBST(MYSQLCFLAG, `$MYSQLCONFIG --cflags`) | |
666 | fi | |
667 | ||
668 | if test x$sqlite = xtrue; then | |
669 | AC_HAVE_LIBRARY([sqlite3],[LIBS="$LIBS"],[AC_MSG_ERROR([SQLite library sqlite3 not found])]) | |
670 | AC_CHECK_HEADER([sqlite3.h],,[AC_MSG_ERROR([SQLite header sqlite3.h not found!])]) | |
671 | AC_MSG_CHECKING([sqlite3_prepare_v2]) | |
672 | AC_TRY_COMPILE( | |
673 | [#include <sqlite3.h>], | |
674 | [ | |
675 | void *test = sqlite3_prepare_v2; | |
676 | ], | |
677 | [AC_MSG_RESULT([yes])]; AC_DEFINE_UNQUOTED(HAVE_SQLITE3_PREPARE_V2, 1), [AC_MSG_RESULT([no])]) | |
678 | AC_MSG_CHECKING([sqlite3.h version >= 3.3.1]) | |
679 | AC_TRY_COMPILE( | |
680 | [#include <sqlite3.h>], | |
681 | [ | |
682 | #if SQLITE_VERSION_NUMBER < 3003001 | |
683 | #error bad sqlite | |
684 | #endif | |
685 | ], | |
686 | [AC_MSG_RESULT([yes])], [AC_MSG_RESULT([no]); AC_MSG_ERROR([SQLite version >= 3.3.1 required!])]) | |
687 | fi | |
688 | ||
689 | if test x$openssl = xtrue; then | |
690 | AC_HAVE_LIBRARY([crypto],[LIBS="$LIBS"],[AC_MSG_ERROR([OpenSSL crypto library not found])]) | |
691 | AC_CHECK_HEADER([openssl/evp.h],,[AC_MSG_ERROR([OpenSSL header openssl/evp.h not found!])]) | |
692 | fi | |
693 | ||
694 | if test x$gcrypt = xtrue; then | |
695 | AC_HAVE_LIBRARY([gcrypt],[LIBS="$LIBS"],[AC_MSG_ERROR([gcrypt library not found])],[-lgpg-error]) | |
696 | AC_CHECK_HEADER([gcrypt.h],,[AC_MSG_ERROR([gcrypt header gcrypt.h not found!])]) | |
697 | AC_MSG_CHECKING([gcrypt CAMELLIA cipher]) | |
698 | AC_TRY_COMPILE( | |
699 | [#include <gcrypt.h>], | |
700 | [enum gcry_cipher_algos alg = GCRY_CIPHER_CAMELLIA128;], | |
701 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_GCRY_CIPHER_CAMELLIA])], | |
702 | [AC_MSG_RESULT([no])] | |
703 | ) | |
704 | fi | |
705 | ||
706 | if test x$uci = xtrue; then | |
707 | AC_HAVE_LIBRARY([uci],[LIBS="$LIBS"],[AC_MSG_ERROR([UCI library libuci not found])]) | |
708 | AC_CHECK_HEADER([uci.h],,[AC_MSG_ERROR([UCI header uci.h not found!])]) | |
709 | fi | |
710 | ||
711 | if test x$android = xtrue; then | |
712 | AC_HAVE_LIBRARY([cutils],[LIBS="$LIBS"],[AC_MSG_ERROR([Android library libcutils not found])]) | |
713 | AC_CHECK_HEADER([cutils/properties.h],,[AC_MSG_ERROR([Android header cutils/properties.h not found!])]) | |
714 | dnl we have to force the use of libdl here because the autodetection | |
715 | dnl above does not work correctly when cross-compiling for android. | |
716 | DLLIB="-ldl" | |
717 | AC_SUBST(DLLIB) | |
718 | fi | |
719 | ||
720 | if test x$maemo = xtrue; then | |
721 | PKG_CHECK_MODULES(maemo, [glib-2.0 gthread-2.0 libosso osso-af-settings]) | |
722 | AC_SUBST(maemo_CFLAGS) | |
723 | AC_SUBST(maemo_LIBS) | |
724 | dbusservicedir="/usr/share/dbus-1/system-services" | |
725 | AC_SUBST(dbusservicedir) | |
726 | fi | |
727 | ||
728 | if test x$eap_sim_pcsc = xtrue; then | |
729 | PKG_CHECK_MODULES(pcsclite, [libpcsclite]) | |
730 | AC_SUBST(pcsclite_CFLAGS) | |
731 | AC_SUBST(pcsclite_LIBS) | |
732 | fi | |
733 | ||
734 | if test x$nm = xtrue; then | |
735 | PKG_CHECK_EXISTS([libnm-glib], | |
736 | [PKG_CHECK_MODULES(nm, [NetworkManager gthread-2.0 libnm-util libnm-glib libnm-glib-vpn])], | |
737 | [PKG_CHECK_MODULES(nm, [NetworkManager gthread-2.0 libnm_util libnm_glib libnm_glib_vpn])] | |
738 | ) | |
739 | AC_SUBST(nm_CFLAGS) | |
740 | AC_SUBST(nm_LIBS) | |
741 | fi | |
742 | ||
743 | if test x$eap_gtc = xtrue; then | |
744 | AC_HAVE_LIBRARY([pam],[LIBS="$LIBS"],[AC_MSG_ERROR([PAM library not found])]) | |
745 | AC_CHECK_HEADER([security/pam_appl.h],,[AC_MSG_ERROR([PAM header security/pam_appl.h not found!])]) | |
746 | fi | |
747 | ||
748 | if test x$capabilities = xnative; then | |
749 | AC_MSG_NOTICE([Usage of the native Linux capabilities interface is deprecated, use libcap instead]) | |
750 | dnl Linux requires the following for capset(), Android does not have it, | |
751 | dnl but defines capset() in unistd.h instead. | |
752 | AC_CHECK_HEADERS([sys/capability.h]) | |
753 | AC_CHECK_FUNC(capset,,[AC_MSG_ERROR([capset() not found!])]) | |
754 | AC_DEFINE(CAPABILITIES_NATIVE) | |
755 | fi | |
756 | ||
757 | if test x$capabilities = xlibcap; then | |
758 | AC_HAVE_LIBRARY([cap],[LIBS="$LIBS"],[AC_MSG_ERROR([libcap library not found])]) | |
759 | AC_CHECK_HEADER([sys/capability.h], | |
760 | [AC_DEFINE(HAVE_SYS_CAPABILITY_H)], | |
761 | [AC_MSG_ERROR([libcap header sys/capability.h not found!])]) | |
762 | AC_DEFINE(CAPABILITIES_LIBCAP) | |
763 | fi | |
764 | ||
765 | if test x$integrity_test = xtrue; then | |
766 | AC_MSG_CHECKING([for dladdr()]) | |
767 | AC_TRY_COMPILE( | |
768 | [#define _GNU_SOURCE | |
769 | #include <dlfcn.h>], | |
770 | [Dl_info info; dladdr(main, &info);], | |
771 | [AC_MSG_RESULT([yes])], [AC_MSG_RESULT([no]); | |
772 | AC_MSG_ERROR([dladdr() not supported, required by integrity-test!])] | |
773 | ) | |
774 | AC_MSG_CHECKING([for dl_iterate_phdr()]) | |
775 | AC_TRY_COMPILE( | |
776 | [#define _GNU_SOURCE | |
777 | #include <link.h>], | |
778 | [dl_iterate_phdr((void*)0, (void*)0);], | |
779 | [AC_MSG_RESULT([yes])], [AC_MSG_RESULT([no]); | |
780 | AC_MSG_ERROR([dl_iterate_phdr() not supported, required by integrity-test!])] | |
781 | ) | |
782 | fi | |
783 | ||
784 | dnl ============================================== | |
785 | dnl collect plugin list for strongSwan components | |
786 | dnl ============================================== | |
787 | ||
788 | m4_include(m4/macros/add-plugin.m4) | |
789 | ||
790 | # plugin lists for all components | |
791 | charon_plugins= | |
792 | pluto_plugins= | |
793 | starter_plugins= | |
794 | pool_plugins= | |
795 | attest_plugins= | |
796 | openac_plugins= | |
797 | scepclient_plugins= | |
798 | pki_plugins= | |
799 | scripts_plugins= | |
800 | manager_plugins= | |
801 | medsrv_plugins= | |
802 | nm_plugins= | |
803 | ||
804 | # location specific lists for checksumming, | |
805 | # for src/libcharon, src/pluto, src/libhydra and src/libstrongswan | |
806 | c_plugins= | |
807 | p_plugins= | |
808 | h_plugins= | |
809 | s_plugins= | |
810 | ||
811 | ADD_PLUGIN([test-vectors], [s charon pluto openac scepclient pki]) | |
812 | ADD_PLUGIN([curl], [s charon pluto scepclient scripts nm]) | |
813 | ADD_PLUGIN([soup], [s charon pluto scripts nm]) | |
814 | ADD_PLUGIN([ldap], [s charon pluto scepclient scripts nm]) | |
815 | ADD_PLUGIN([mysql], [s charon pluto pool manager medsrv attest]) | |
816 | ADD_PLUGIN([sqlite], [s charon pluto pool manager medsrv attest]) | |
817 | ADD_PLUGIN([pkcs11], [s charon pki nm]) | |
818 | ADD_PLUGIN([aes], [s charon pluto openac scepclient pki scripts nm]) | |
819 | ADD_PLUGIN([des], [s charon pluto openac scepclient pki scripts nm]) | |
820 | ADD_PLUGIN([blowfish], [s charon pluto openac scepclient pki scripts nm]) | |
821 | ADD_PLUGIN([sha1], [s charon pluto openac scepclient pki scripts medsrv attest nm]) | |
822 | ADD_PLUGIN([sha2], [s charon pluto openac scepclient pki scripts medsrv attest nm]) | |
823 | ADD_PLUGIN([md4], [s charon openac manager scepclient pki nm]) | |
824 | ADD_PLUGIN([md5], [s charon pluto openac scepclient pki scripts attest nm]) | |
825 | ADD_PLUGIN([random], [s charon pluto openac scepclient pki scripts medsrv attest nm]) | |
826 | ADD_PLUGIN([nonce], [s charon nm]) | |
827 | ADD_PLUGIN([x509], [s charon pluto openac scepclient pki scripts attest nm]) | |
828 | ADD_PLUGIN([revocation], [s charon nm]) | |
829 | ADD_PLUGIN([constraints], [s charon nm]) | |
830 | ADD_PLUGIN([pubkey], [s charon]) | |
831 | ADD_PLUGIN([pkcs1], [s charon pluto openac scepclient pki scripts manager medsrv attest nm]) | |
832 | ADD_PLUGIN([pkcs8], [s charon pluto openac scepclient pki scripts manager medsrv attest nm]) | |
833 | ADD_PLUGIN([pgp], [s charon pluto]) | |
834 | ADD_PLUGIN([dnskey], [s pluto]) | |
835 | ADD_PLUGIN([pem], [s charon pluto openac scepclient pki scripts manager medsrv attest nm]) | |
836 | ADD_PLUGIN([padlock], [s charon]) | |
837 | ADD_PLUGIN([openssl], [s charon pluto openac scepclient pki scripts manager medsrv attest nm]) | |
838 | ADD_PLUGIN([gcrypt], [s charon pluto openac scepclient pki scripts manager medsrv attest nm]) | |
839 | ADD_PLUGIN([af-alg], [s charon pluto openac scepclient pki scripts medsrv attest nm]) | |
840 | ADD_PLUGIN([fips-prf], [s charon nm]) | |
841 | ADD_PLUGIN([gmp], [s charon pluto openac scepclient pki scripts manager medsrv attest nm]) | |
842 | ADD_PLUGIN([agent], [s charon nm]) | |
843 | ADD_PLUGIN([xcbc], [s charon nm]) | |
844 | ADD_PLUGIN([cmac], [s charon nm]) | |
845 | ADD_PLUGIN([hmac], [s charon pluto scripts nm]) | |
846 | ADD_PLUGIN([ctr], [s charon scripts nm]) | |
847 | ADD_PLUGIN([ccm], [s charon scripts nm]) | |
848 | ADD_PLUGIN([gcm], [s charon scripts nm]) | |
849 | ADD_PLUGIN([xauth], [p pluto]) | |
850 | ADD_PLUGIN([attr], [h charon pluto]) | |
851 | ADD_PLUGIN([attr-sql], [h charon pluto]) | |
852 | ADD_PLUGIN([load-tester], [c charon]) | |
853 | ADD_PLUGIN([kernel-pfkey], [h charon pluto starter nm]) | |
854 | ADD_PLUGIN([kernel-pfroute], [h charon pluto starter nm]) | |
855 | ADD_PLUGIN([kernel-klips], [h charon pluto starter]) | |
856 | ADD_PLUGIN([kernel-netlink], [h charon pluto starter nm]) | |
857 | ADD_PLUGIN([resolve], [h charon pluto]) | |
858 | ADD_PLUGIN([socket-default], [c charon nm]) | |
859 | ADD_PLUGIN([socket-raw], [c charon nm]) | |
860 | ADD_PLUGIN([socket-dynamic], [c charon]) | |
861 | ADD_PLUGIN([farp], [c charon]) | |
862 | ADD_PLUGIN([stroke], [c charon]) | |
863 | ADD_PLUGIN([smp], [c charon]) | |
864 | ADD_PLUGIN([sql], [c charon]) | |
865 | ADD_PLUGIN([updown], [c charon]) | |
866 | ADD_PLUGIN([eap-identity], [c charon nm]) | |
867 | ADD_PLUGIN([eap-sim], [c charon]) | |
868 | ADD_PLUGIN([eap-sim-file], [c charon]) | |
869 | ADD_PLUGIN([eap-sim-pcsc], [c charon]) | |
870 | ADD_PLUGIN([eap-aka], [c charon]) | |
871 | ADD_PLUGIN([eap-aka-3gpp2], [c charon]) | |
872 | ADD_PLUGIN([eap-simaka-sql], [c charon]) | |
873 | ADD_PLUGIN([eap-simaka-pseudonym], [c charon]) | |
874 | ADD_PLUGIN([eap-simaka-reauth], [c charon]) | |
875 | ADD_PLUGIN([eap-md5], [c charon nm]) | |
876 | ADD_PLUGIN([eap-gtc], [c charon nm]) | |
877 | ADD_PLUGIN([eap-mschapv2], [c charon nm]) | |
878 | ADD_PLUGIN([eap-radius], [c charon]) | |
879 | ADD_PLUGIN([eap-tls], [c charon nm]) | |
880 | ADD_PLUGIN([eap-ttls], [c charon nm]) | |
881 | ADD_PLUGIN([eap-peap], [c charon nm]) | |
882 | ADD_PLUGIN([eap-tnc], [c charon]) | |
883 | ADD_PLUGIN([xauth-generic], [c charon]) | |
884 | ADD_PLUGIN([xauth-eap], [c charon]) | |
885 | ADD_PLUGIN([tnc-ifmap], [c charon]) | |
886 | ADD_PLUGIN([tnc-pdp], [c charon]) | |
887 | ADD_PLUGIN([tnc-imc], [c charon]) | |
888 | ADD_PLUGIN([tnc-imv], [c charon]) | |
889 | ADD_PLUGIN([tnc-tnccs], [c charon]) | |
890 | ADD_PLUGIN([tnccs-20], [c charon]) | |
891 | ADD_PLUGIN([tnccs-11], [c charon]) | |
892 | ADD_PLUGIN([tnccs-dynamic], [c charon]) | |
893 | ADD_PLUGIN([medsrv], [c charon]) | |
894 | ADD_PLUGIN([medcli], [c charon]) | |
895 | ADD_PLUGIN([dhcp], [c charon]) | |
896 | ADD_PLUGIN([android], [c charon]) | |
897 | ADD_PLUGIN([ha], [c charon]) | |
898 | ADD_PLUGIN([whitelist], [c charon]) | |
899 | ADD_PLUGIN([certexpire], [c charon]) | |
900 | ADD_PLUGIN([led], [c charon]) | |
901 | ADD_PLUGIN([duplicheck], [c charon]) | |
902 | ADD_PLUGIN([coupling], [c charon]) | |
903 | ADD_PLUGIN([radattr], [c charon]) | |
904 | ADD_PLUGIN([maemo], [c charon]) | |
905 | ADD_PLUGIN([uci], [c charon]) | |
906 | ADD_PLUGIN([addrblock], [c charon]) | |
907 | ADD_PLUGIN([unit-tester], [c charon]) | |
908 | ||
909 | AC_SUBST(charon_plugins) | |
910 | AC_SUBST(pluto_plugins) | |
911 | AC_SUBST(starter_plugins) | |
912 | AC_SUBST(pool_plugins) | |
913 | AC_SUBST(attest_plugins) | |
914 | AC_SUBST(openac_plugins) | |
915 | AC_SUBST(scepclient_plugins) | |
916 | AC_SUBST(pki_plugins) | |
917 | AC_SUBST(scripts_plugins) | |
918 | AC_SUBST(manager_plugins) | |
919 | AC_SUBST(medsrv_plugins) | |
920 | AC_SUBST(nm_plugins) | |
921 | ||
922 | AC_SUBST(c_plugins) | |
923 | AC_SUBST(p_plugins) | |
924 | AC_SUBST(h_plugins) | |
925 | AC_SUBST(s_plugins) | |
926 | ||
927 | dnl ========================= | |
928 | dnl set Makefile.am vars | |
929 | dnl ========================= | |
930 | ||
931 | dnl libstrongswan plugins | |
932 | dnl ===================== | |
933 | AM_CONDITIONAL(USE_TEST_VECTORS, test x$test_vectors = xtrue) | |
934 | AM_CONDITIONAL(USE_CURL, test x$curl = xtrue) | |
935 | AM_CONDITIONAL(USE_SOUP, test x$soup = xtrue) | |
936 | AM_CONDITIONAL(USE_LDAP, test x$ldap = xtrue) | |
937 | AM_CONDITIONAL(USE_AES, test x$aes = xtrue) | |
938 | AM_CONDITIONAL(USE_DES, test x$des = xtrue) | |
939 | AM_CONDITIONAL(USE_BLOWFISH, test x$blowfish = xtrue) | |
940 | AM_CONDITIONAL(USE_MD4, test x$md4 = xtrue) | |
941 | AM_CONDITIONAL(USE_MD5, test x$md5 = xtrue) | |
942 | AM_CONDITIONAL(USE_SHA1, test x$sha1 = xtrue) | |
943 | AM_CONDITIONAL(USE_SHA2, test x$sha2 = xtrue) | |
944 | AM_CONDITIONAL(USE_FIPS_PRF, test x$fips_prf = xtrue) | |
945 | AM_CONDITIONAL(USE_GMP, test x$gmp = xtrue) | |
946 | AM_CONDITIONAL(USE_RANDOM, test x$random = xtrue) | |
947 | AM_CONDITIONAL(USE_NONCE, test x$nonce = xtrue) | |
948 | AM_CONDITIONAL(USE_X509, test x$x509 = xtrue) | |
949 | AM_CONDITIONAL(USE_REVOCATION, test x$revocation = xtrue) | |
950 | AM_CONDITIONAL(USE_CONSTRAINTS, test x$constraints = xtrue) | |
951 | AM_CONDITIONAL(USE_PUBKEY, test x$pubkey = xtrue) | |
952 | AM_CONDITIONAL(USE_PKCS1, test x$pkcs1 = xtrue) | |
953 | AM_CONDITIONAL(USE_PKCS8, test x$pkcs8 = xtrue) | |
954 | AM_CONDITIONAL(USE_PGP, test x$pgp = xtrue) | |
955 | AM_CONDITIONAL(USE_DNSKEY, test x$dnskey = xtrue) | |
956 | AM_CONDITIONAL(USE_PEM, test x$pem = xtrue) | |
957 | AM_CONDITIONAL(USE_HMAC, test x$hmac = xtrue) | |
958 | AM_CONDITIONAL(USE_CMAC, test x$cmac = xtrue) | |
959 | AM_CONDITIONAL(USE_XCBC, test x$xcbc = xtrue) | |
960 | AM_CONDITIONAL(USE_MYSQL, test x$mysql = xtrue) | |
961 | AM_CONDITIONAL(USE_SQLITE, test x$sqlite = xtrue) | |
962 | AM_CONDITIONAL(USE_PADLOCK, test x$padlock = xtrue) | |
963 | AM_CONDITIONAL(USE_OPENSSL, test x$openssl = xtrue) | |
964 | AM_CONDITIONAL(USE_GCRYPT, test x$gcrypt = xtrue) | |
965 | AM_CONDITIONAL(USE_AGENT, test x$agent = xtrue) | |
966 | AM_CONDITIONAL(USE_PKCS11, test x$pkcs11 = xtrue) | |
967 | AM_CONDITIONAL(USE_CTR, test x$ctr = xtrue) | |
968 | AM_CONDITIONAL(USE_CCM, test x$ccm = xtrue) | |
969 | AM_CONDITIONAL(USE_GCM, test x$gcm = xtrue) | |
970 | AM_CONDITIONAL(USE_AF_ALG, test x$af_alg = xtrue) | |
971 | ||
972 | dnl charon plugins | |
973 | dnl ============== | |
974 | AM_CONDITIONAL(USE_STROKE, test x$stroke = xtrue) | |
975 | AM_CONDITIONAL(USE_MEDSRV, test x$medsrv = xtrue) | |
976 | AM_CONDITIONAL(USE_MEDCLI, test x$medcli = xtrue) | |
977 | AM_CONDITIONAL(USE_UCI, test x$uci = xtrue) | |
978 | AM_CONDITIONAL(USE_ANDROID, test x$android = xtrue) | |
979 | AM_CONDITIONAL(USE_MAEMO, test x$maemo = xtrue) | |
980 | AM_CONDITIONAL(USE_SMP, test x$smp = xtrue) | |
981 | AM_CONDITIONAL(USE_SQL, test x$sql = xtrue) | |
982 | AM_CONDITIONAL(USE_UPDOWN, test x$updown = xtrue) | |
983 | AM_CONDITIONAL(USE_DHCP, test x$dhcp = xtrue) | |
984 | AM_CONDITIONAL(USE_UNIT_TESTS, test x$unit_tester = xtrue) | |
985 | AM_CONDITIONAL(USE_LOAD_TESTER, test x$load_tester = xtrue) | |
986 | AM_CONDITIONAL(USE_HA, test x$ha = xtrue) | |
987 | AM_CONDITIONAL(USE_WHITELIST, test x$whitelist = xtrue) | |
988 | AM_CONDITIONAL(USE_CERTEXPIRE, test x$certexpire = xtrue) | |
989 | AM_CONDITIONAL(USE_LED, test x$led = xtrue) | |
990 | AM_CONDITIONAL(USE_DUPLICHECK, test x$duplicheck = xtrue) | |
991 | AM_CONDITIONAL(USE_COUPLING, test x$coupling = xtrue) | |
992 | AM_CONDITIONAL(USE_RADATTR, test x$radattr = xtrue) | |
993 | AM_CONDITIONAL(USE_EAP_SIM, test x$eap_sim = xtrue) | |
994 | AM_CONDITIONAL(USE_EAP_SIM_FILE, test x$eap_sim_file = xtrue) | |
995 | AM_CONDITIONAL(USE_EAP_SIM_PCSC, test x$eap_sim_pcsc = xtrue) | |
996 | AM_CONDITIONAL(USE_EAP_SIMAKA_SQL, test x$eap_simaka_sql = xtrue) | |
997 | AM_CONDITIONAL(USE_EAP_SIMAKA_PSEUDONYM, test x$eap_simaka_pseudonym = xtrue) | |
998 | AM_CONDITIONAL(USE_EAP_SIMAKA_REAUTH, test x$eap_simaka_reauth = xtrue) | |
999 | AM_CONDITIONAL(USE_EAP_IDENTITY, test x$eap_identity = xtrue) | |
1000 | AM_CONDITIONAL(USE_EAP_MD5, test x$eap_md5 = xtrue) | |
1001 | AM_CONDITIONAL(USE_EAP_GTC, test x$eap_gtc = xtrue) | |
1002 | AM_CONDITIONAL(USE_EAP_AKA, test x$eap_aka = xtrue) | |
1003 | AM_CONDITIONAL(USE_EAP_AKA_3GPP2, test x$eap_aka_3gpp2 = xtrue) | |
1004 | AM_CONDITIONAL(USE_EAP_MSCHAPV2, test x$eap_mschapv2 = xtrue) | |
1005 | AM_CONDITIONAL(USE_EAP_TLS, test x$eap_tls = xtrue) | |
1006 | AM_CONDITIONAL(USE_EAP_TTLS, test x$eap_ttls = xtrue) | |
1007 | AM_CONDITIONAL(USE_EAP_PEAP, test x$eap_peap = xtrue) | |
1008 | AM_CONDITIONAL(USE_EAP_TNC, test x$eap_tnc = xtrue) | |
1009 | AM_CONDITIONAL(USE_EAP_RADIUS, test x$eap_radius = xtrue) | |
1010 | AM_CONDITIONAL(USE_XAUTH_GENERIC, test x$xauth_generic = xtrue) | |
1011 | AM_CONDITIONAL(USE_XAUTH_EAP, test x$xauth_eap = xtrue) | |
1012 | AM_CONDITIONAL(USE_TNC_IFMAP, test x$tnc_ifmap = xtrue) | |
1013 | AM_CONDITIONAL(USE_TNC_PDP, test x$tnc_pdp = xtrue) | |
1014 | AM_CONDITIONAL(USE_TNC_IMC, test x$tnc_imc = xtrue) | |
1015 | AM_CONDITIONAL(USE_TNC_IMV, test x$tnc_imv = xtrue) | |
1016 | AM_CONDITIONAL(USE_TNC_TNCCS, test x$tnc_tnccs = xtrue) | |
1017 | AM_CONDITIONAL(USE_TNCCS_11, test x$tnccs_11 = xtrue) | |
1018 | AM_CONDITIONAL(USE_TNCCS_20, test x$tnccs_20 = xtrue) | |
1019 | AM_CONDITIONAL(USE_TNCCS_DYNAMIC, test x$tnccs_dynamic = xtrue) | |
1020 | AM_CONDITIONAL(USE_IMC_TEST, test x$imc_test = xtrue) | |
1021 | AM_CONDITIONAL(USE_IMV_TEST, test x$imv_test = xtrue) | |
1022 | AM_CONDITIONAL(USE_IMC_SCANNER, test x$imc_scanner = xtrue) | |
1023 | AM_CONDITIONAL(USE_IMV_SCANNER, test x$imv_scanner = xtrue) | |
1024 | AM_CONDITIONAL(USE_IMC_ATTESTATION, test x$imc_attestation = xtrue) | |
1025 | AM_CONDITIONAL(USE_IMV_ATTESTATION, test x$imv_attestation = xtrue) | |
1026 | AM_CONDITIONAL(USE_SOCKET_DEFAULT, test x$socket_default = xtrue) | |
1027 | AM_CONDITIONAL(USE_SOCKET_RAW, test x$socket_raw = xtrue) | |
1028 | AM_CONDITIONAL(USE_SOCKET_DYNAMIC, test x$socket_dynamic = xtrue) | |
1029 | AM_CONDITIONAL(USE_FARP, test x$farp = xtrue) | |
1030 | AM_CONDITIONAL(USE_ADDRBLOCK, test x$addrblock = xtrue) | |
1031 | ||
1032 | dnl hydra plugins | |
1033 | dnl ============= | |
1034 | AM_CONDITIONAL(USE_ATTR, test x$attr = xtrue) | |
1035 | AM_CONDITIONAL(USE_ATTR_SQL, test x$attr_sql = xtrue -o x$sql = xtrue) | |
1036 | AM_CONDITIONAL(USE_KERNEL_KLIPS, test x$kernel_klips = xtrue) | |
1037 | AM_CONDITIONAL(USE_KERNEL_NETLINK, test x$kernel_netlink = xtrue) | |
1038 | AM_CONDITIONAL(USE_KERNEL_PFKEY, test x$kernel_pfkey = xtrue) | |
1039 | AM_CONDITIONAL(USE_KERNEL_PFROUTE, test x$kernel_pfroute = xtrue) | |
1040 | AM_CONDITIONAL(USE_RESOLVE, test x$resolve = xtrue) | |
1041 | ||
1042 | dnl pluto plugins | |
1043 | dnl ============= | |
1044 | AM_CONDITIONAL(USE_XAUTH, test x$xauth = xtrue) | |
1045 | ||
1046 | dnl other options | |
1047 | dnl ============= | |
1048 | AM_CONDITIONAL(USE_SMARTCARD, test x$smartcard = xtrue) | |
1049 | AM_CONDITIONAL(USE_CISCO_QUIRKS, test x$cisco_quirks = xtrue) | |
1050 | AM_CONDITIONAL(USE_LEAK_DETECTIVE, test x$leak_detective = xtrue) | |
1051 | AM_CONDITIONAL(USE_LOCK_PROFILER, test x$lock_profiler = xtrue) | |
1052 | AM_CONDITIONAL(USE_NAT_TRANSPORT, test x$nat_transport = xtrue) | |
1053 | AM_CONDITIONAL(USE_VENDORID, test x$vendor_id = xtrue) | |
1054 | AM_CONDITIONAL(USE_XAUTH_VID, test x$xauth_vid = xtrue) | |
1055 | AM_CONDITIONAL(USE_DUMM, test x$dumm = xtrue) | |
1056 | AM_CONDITIONAL(USE_FAST, test x$fast = xtrue) | |
1057 | AM_CONDITIONAL(USE_MANAGER, test x$manager = xtrue) | |
1058 | AM_CONDITIONAL(USE_ME, test x$mediation = xtrue) | |
1059 | AM_CONDITIONAL(USE_INTEGRITY_TEST, test x$integrity_test = xtrue) | |
1060 | AM_CONDITIONAL(USE_LOAD_WARNING, test x$load_warning = xtrue) | |
1061 | AM_CONDITIONAL(USE_PLUTO, test x$pluto = xtrue) | |
1062 | AM_CONDITIONAL(USE_IKEV1, test x$ikev1 = xtrue) | |
1063 | AM_CONDITIONAL(USE_IKEV2, test x$ikev2 = xtrue) | |
1064 | AM_CONDITIONAL(USE_THREADS, test x$threads = xtrue) | |
1065 | AM_CONDITIONAL(USE_ADNS, test x$adns = xtrue) | |
1066 | AM_CONDITIONAL(USE_CHARON, test x$charon = xtrue) | |
1067 | AM_CONDITIONAL(USE_NM, test x$nm = xtrue) | |
1068 | AM_CONDITIONAL(USE_TOOLS, test x$tools = xtrue) | |
1069 | AM_CONDITIONAL(USE_SCRIPTS, test x$scripts = xtrue) | |
1070 | AM_CONDITIONAL(USE_CONFTEST, test x$conftest = xtrue) | |
1071 | AM_CONDITIONAL(USE_LIBSTRONGSWAN, test x$charon = xtrue -o x$pluto = xtrue -o x$tools = xtrue -o x$conftest = xtrue -o x$fast = xtrue -o x$imcv = xtrue -o x$nm = xtrue) | |
1072 | AM_CONDITIONAL(USE_LIBHYDRA, test x$charon = xtrue -o x$pluto = xtrue -o x$nm = xtrue) | |
1073 | AM_CONDITIONAL(USE_LIBCHARON, test x$charon = xtrue -o x$conftest = xtrue -o x$nm = xtrue) | |
1074 | AM_CONDITIONAL(USE_LIBTNCIF, test x$tnc_tnccs = xtrue -o x$imcv = xtrue) | |
1075 | AM_CONDITIONAL(USE_LIBTNCCS, test x$tnc_tnccs = xtrue) | |
1076 | AM_CONDITIONAL(USE_FILE_CONFIG, test x$pluto = xtrue -o x$stroke = xtrue) | |
1077 | AM_CONDITIONAL(USE_IPSEC_SCRIPT, test x$pluto = xtrue -o x$stroke = xtrue -o x$tools = xtrue -o x$conftest = xtrue) | |
1078 | AM_CONDITIONAL(USE_LIBCAP, test x$capabilities = xlibcap) | |
1079 | AM_CONDITIONAL(USE_VSTR, test x$vstr = xtrue) | |
1080 | AM_CONDITIONAL(USE_SIMAKA, test x$simaka = xtrue) | |
1081 | AM_CONDITIONAL(USE_TLS, test x$tls = xtrue) | |
1082 | AM_CONDITIONAL(USE_RADIUS, test x$radius = xtrue) | |
1083 | AM_CONDITIONAL(USE_IMCV, test x$imcv = xtrue) | |
1084 | AM_CONDITIONAL(USE_PTS, test x$pts = xtrue) | |
1085 | AM_CONDITIONAL(MONOLITHIC, test x$monolithic = xtrue) | |
1086 | ||
1087 | dnl ============================== | |
1088 | dnl set global definitions | |
1089 | dnl ============================== | |
1090 | ||
1091 | if test x$mediation = xtrue; then | |
1092 | AC_DEFINE(ME) | |
1093 | fi | |
1094 | if test x$capabilities = xlibcap -o x$capabilities = xnative; then | |
1095 | AC_DEFINE(CAPABILITIES) | |
1096 | fi | |
1097 | if test x$monolithic = xtrue; then | |
1098 | AC_DEFINE(MONOLITHIC) | |
1099 | fi | |
1100 | if test x$ikev1 = xtrue; then | |
1101 | AC_DEFINE(USE_IKEV1) | |
1102 | fi | |
1103 | if test x$ikev2 = xtrue; then | |
1104 | AC_DEFINE(USE_IKEV2) | |
1105 | fi | |
1106 | ||
1107 | dnl ============================== | |
1108 | dnl build Makefiles | |
1109 | dnl ============================== | |
1110 | ||
1111 | AC_OUTPUT( | |
1112 | Makefile | |
1113 | man/Makefile | |
1114 | init/Makefile | |
1115 | init/systemd/Makefile | |
1116 | src/Makefile | |
1117 | src/include/Makefile | |
1118 | src/libstrongswan/Makefile | |
1119 | src/libstrongswan/plugins/aes/Makefile | |
1120 | src/libstrongswan/plugins/cmac/Makefile | |
1121 | src/libstrongswan/plugins/des/Makefile | |
1122 | src/libstrongswan/plugins/blowfish/Makefile | |
1123 | src/libstrongswan/plugins/md4/Makefile | |
1124 | src/libstrongswan/plugins/md5/Makefile | |
1125 | src/libstrongswan/plugins/sha1/Makefile | |
1126 | src/libstrongswan/plugins/sha2/Makefile | |
1127 | src/libstrongswan/plugins/fips_prf/Makefile | |
1128 | src/libstrongswan/plugins/gmp/Makefile | |
1129 | src/libstrongswan/plugins/random/Makefile | |
1130 | src/libstrongswan/plugins/nonce/Makefile | |
1131 | src/libstrongswan/plugins/hmac/Makefile | |
1132 | src/libstrongswan/plugins/xcbc/Makefile | |
1133 | src/libstrongswan/plugins/x509/Makefile | |
1134 | src/libstrongswan/plugins/revocation/Makefile | |
1135 | src/libstrongswan/plugins/constraints/Makefile | |
1136 | src/libstrongswan/plugins/pubkey/Makefile | |
1137 | src/libstrongswan/plugins/pkcs1/Makefile | |
1138 | src/libstrongswan/plugins/pkcs8/Makefile | |
1139 | src/libstrongswan/plugins/pgp/Makefile | |
1140 | src/libstrongswan/plugins/dnskey/Makefile | |
1141 | src/libstrongswan/plugins/pem/Makefile | |
1142 | src/libstrongswan/plugins/curl/Makefile | |
1143 | src/libstrongswan/plugins/soup/Makefile | |
1144 | src/libstrongswan/plugins/ldap/Makefile | |
1145 | src/libstrongswan/plugins/mysql/Makefile | |
1146 | src/libstrongswan/plugins/sqlite/Makefile | |
1147 | src/libstrongswan/plugins/padlock/Makefile | |
1148 | src/libstrongswan/plugins/openssl/Makefile | |
1149 | src/libstrongswan/plugins/gcrypt/Makefile | |
1150 | src/libstrongswan/plugins/agent/Makefile | |
1151 | src/libstrongswan/plugins/pkcs11/Makefile | |
1152 | src/libstrongswan/plugins/ctr/Makefile | |
1153 | src/libstrongswan/plugins/ccm/Makefile | |
1154 | src/libstrongswan/plugins/gcm/Makefile | |
1155 | src/libstrongswan/plugins/af_alg/Makefile | |
1156 | src/libstrongswan/plugins/test_vectors/Makefile | |
1157 | src/libhydra/Makefile | |
1158 | src/libhydra/plugins/attr/Makefile | |
1159 | src/libhydra/plugins/attr_sql/Makefile | |
1160 | src/libhydra/plugins/kernel_klips/Makefile | |
1161 | src/libhydra/plugins/kernel_netlink/Makefile | |
1162 | src/libhydra/plugins/kernel_pfkey/Makefile | |
1163 | src/libhydra/plugins/kernel_pfroute/Makefile | |
1164 | src/libhydra/plugins/resolve/Makefile | |
1165 | src/libfreeswan/Makefile | |
1166 | src/libsimaka/Makefile | |
1167 | src/libtls/Makefile | |
1168 | src/libradius/Makefile | |
1169 | src/libtncif/Makefile | |
1170 | src/libtnccs/Makefile | |
1171 | src/libpts/Makefile | |
1172 | src/libpts/plugins/imc_attestation/Makefile | |
1173 | src/libpts/plugins/imv_attestation/Makefile | |
1174 | src/libimcv/Makefile | |
1175 | src/libimcv/plugins/imc_test/Makefile | |
1176 | src/libimcv/plugins/imv_test/Makefile | |
1177 | src/libimcv/plugins/imc_scanner/Makefile | |
1178 | src/libimcv/plugins/imv_scanner/Makefile | |
1179 | src/pluto/Makefile | |
1180 | src/pluto/plugins/xauth/Makefile | |
1181 | src/whack/Makefile | |
1182 | src/charon/Makefile | |
1183 | src/charon-nm/Makefile | |
1184 | src/libcharon/Makefile | |
1185 | src/libcharon/plugins/eap_aka/Makefile | |
1186 | src/libcharon/plugins/eap_aka_3gpp2/Makefile | |
1187 | src/libcharon/plugins/eap_identity/Makefile | |
1188 | src/libcharon/plugins/eap_md5/Makefile | |
1189 | src/libcharon/plugins/eap_gtc/Makefile | |
1190 | src/libcharon/plugins/eap_sim/Makefile | |
1191 | src/libcharon/plugins/eap_sim_file/Makefile | |
1192 | src/libcharon/plugins/eap_sim_pcsc/Makefile | |
1193 | src/libcharon/plugins/eap_simaka_sql/Makefile | |
1194 | src/libcharon/plugins/eap_simaka_pseudonym/Makefile | |
1195 | src/libcharon/plugins/eap_simaka_reauth/Makefile | |
1196 | src/libcharon/plugins/eap_mschapv2/Makefile | |
1197 | src/libcharon/plugins/eap_tls/Makefile | |
1198 | src/libcharon/plugins/eap_ttls/Makefile | |
1199 | src/libcharon/plugins/eap_peap/Makefile | |
1200 | src/libcharon/plugins/eap_tnc/Makefile | |
1201 | src/libcharon/plugins/eap_radius/Makefile | |
1202 | src/libcharon/plugins/xauth_generic/Makefile | |
1203 | src/libcharon/plugins/xauth_eap/Makefile | |
1204 | src/libcharon/plugins/tnc_ifmap/Makefile | |
1205 | src/libcharon/plugins/tnc_pdp/Makefile | |
1206 | src/libcharon/plugins/tnc_imc/Makefile | |
1207 | src/libcharon/plugins/tnc_imv/Makefile | |
1208 | src/libcharon/plugins/tnc_tnccs/Makefile | |
1209 | src/libcharon/plugins/tnccs_11/Makefile | |
1210 | src/libcharon/plugins/tnccs_20/Makefile | |
1211 | src/libcharon/plugins/tnccs_dynamic/Makefile | |
1212 | src/libcharon/plugins/socket_default/Makefile | |
1213 | src/libcharon/plugins/socket_raw/Makefile | |
1214 | src/libcharon/plugins/socket_dynamic/Makefile | |
1215 | src/libcharon/plugins/farp/Makefile | |
1216 | src/libcharon/plugins/smp/Makefile | |
1217 | src/libcharon/plugins/sql/Makefile | |
1218 | src/libcharon/plugins/medsrv/Makefile | |
1219 | src/libcharon/plugins/medcli/Makefile | |
1220 | src/libcharon/plugins/addrblock/Makefile | |
1221 | src/libcharon/plugins/uci/Makefile | |
1222 | src/libcharon/plugins/ha/Makefile | |
1223 | src/libcharon/plugins/whitelist/Makefile | |
1224 | src/libcharon/plugins/certexpire/Makefile | |
1225 | src/libcharon/plugins/led/Makefile | |
1226 | src/libcharon/plugins/duplicheck/Makefile | |
1227 | src/libcharon/plugins/coupling/Makefile | |
1228 | src/libcharon/plugins/radattr/Makefile | |
1229 | src/libcharon/plugins/android/Makefile | |
1230 | src/libcharon/plugins/maemo/Makefile | |
1231 | src/libcharon/plugins/stroke/Makefile | |
1232 | src/libcharon/plugins/updown/Makefile | |
1233 | src/libcharon/plugins/dhcp/Makefile | |
1234 | src/libcharon/plugins/unit_tester/Makefile | |
1235 | src/libcharon/plugins/load_tester/Makefile | |
1236 | src/stroke/Makefile | |
1237 | src/ipsec/Makefile | |
1238 | src/starter/Makefile | |
1239 | src/_updown/Makefile | |
1240 | src/_updown_espmark/Makefile | |
1241 | src/_copyright/Makefile | |
1242 | src/openac/Makefile | |
1243 | src/scepclient/Makefile | |
1244 | src/pki/Makefile | |
1245 | src/dumm/Makefile | |
1246 | src/dumm/ext/extconf.rb | |
1247 | src/libfast/Makefile | |
1248 | src/manager/Makefile | |
1249 | src/medsrv/Makefile | |
1250 | src/checksum/Makefile | |
1251 | src/conftest/Makefile | |
1252 | scripts/Makefile | |
1253 | testing/Makefile | |
1254 | ) |