Added CONFIG_NO_AES_EXTRAS for hostapd
[libeap.git] / hostapd / Makefile
1 ifndef CC
2 CC=gcc
3 endif
4
5 ifndef CFLAGS
6 CFLAGS = -MMD -O2 -Wall -g
7 endif
8
9 # define HOSTAPD_DUMP_STATE to include SIGUSR1 handler for dumping state to
10 # a file (undefine it, if you want to save in binary size)
11 CFLAGS += -DHOSTAPD_DUMP_STATE
12
13 CFLAGS += -I../src
14 CFLAGS += -I../src/crypto
15 CFLAGS += -I../src/utils
16 CFLAGS += -I../src/common
17
18 # Uncomment following line and set the path to your kernel tree include
19 # directory if your C library does not include all header files.
20 # CFLAGS += -DUSE_KERNEL_HEADERS -I/usr/src/linux/include
21
22 -include .config
23
24 ifndef CONFIG_OS
25 ifdef CONFIG_NATIVE_WINDOWS
26 CONFIG_OS=win32
27 else
28 CONFIG_OS=unix
29 endif
30 endif
31
32 ifeq ($(CONFIG_OS), internal)
33 CFLAGS += -DOS_NO_C_LIB_DEFINES
34 endif
35
36 ifdef CONFIG_NATIVE_WINDOWS
37 CFLAGS += -DCONFIG_NATIVE_WINDOWS
38 LIBS += -lws2_32
39 endif
40
41 OBJS =  hostapd.o ieee802_1x.o eapol_sm.o \
42         config.o ieee802_11_auth.o \
43         sta_info.o wpa.o ctrl_iface.o \
44         drivers.o preauth.o pmksa_cache.o \
45         hw_features.o \
46         drv_callbacks.o \
47         tkip_countermeasures.o \
48         mlme.o vlan_init.o wpa_auth_ie.o
49
50 OBJS += ../src/utils/eloop.o
51 OBJS += ../src/utils/common.o
52 OBJS += ../src/utils/wpa_debug.o
53 OBJS += ../src/utils/wpabuf.o
54 OBJS += ../src/utils/os_$(CONFIG_OS).o
55 OBJS += ../src/utils/ip_addr.o
56
57 OBJS += ../src/common/ieee802_11_common.o
58 OBJS += ../src/common/wpa_common.o
59
60 ifdef CONFIG_NO_RADIUS
61 CFLAGS += -DCONFIG_NO_RADIUS
62 CONFIG_NO_ACCOUNTING=y
63 else
64 OBJS += ../src/radius/radius.o
65 OBJS += ../src/radius/radius_client.o
66 endif
67
68 ifdef CONFIG_NO_ACCOUNTING
69 CFLAGS += -DCONFIG_NO_ACCOUNTING
70 else
71 OBJS += accounting.o
72 endif
73
74 OBJS += ../src/crypto/md5.o
75 OBJS += ../src/crypto/rc4.o
76 OBJS += ../src/crypto/md4.o
77 OBJS += ../src/crypto/sha1.o
78 OBJS += ../src/crypto/des.o
79 OBJS += ../src/crypto/aes_wrap.o
80 OBJS += ../src/crypto/aes.o
81
82 HOBJS=../src/hlr_auc_gw/hlr_auc_gw.o ../src/utils/common.o ../src/utils/wpa_debug.o ../src/utils/os_$(CONFIG_OS).o ../src/hlr_auc_gw/milenage.o ../src/crypto/aes_wrap.o ../src/crypto/aes.o
83
84 CFLAGS += -DCONFIG_CTRL_IFACE -DCONFIG_CTRL_IFACE_UNIX
85
86 ifdef CONFIG_IAPP
87 CFLAGS += -DCONFIG_IAPP
88 OBJS += iapp.o
89 endif
90
91 ifdef CONFIG_RSN_PREAUTH
92 CFLAGS += -DCONFIG_RSN_PREAUTH
93 CONFIG_L2_PACKET=y
94 endif
95
96 ifdef CONFIG_PEERKEY
97 CFLAGS += -DCONFIG_PEERKEY
98 OBJS += peerkey.o
99 endif
100
101 ifdef CONFIG_IEEE80211W
102 CFLAGS += -DCONFIG_IEEE80211W
103 NEED_SHA256=y
104 endif
105
106 ifdef CONFIG_IEEE80211R
107 CFLAGS += -DCONFIG_IEEE80211R
108 OBJS += wpa_ft.o
109 NEED_SHA256=y
110 endif
111
112 ifdef CONFIG_IEEE80211N
113 CFLAGS += -DCONFIG_IEEE80211N
114 endif
115
116 ifdef CONFIG_DRIVER_HOSTAP
117 NEED_MLME=y
118 CFLAGS += -DCONFIG_DRIVER_HOSTAP
119 OBJS += driver_hostap.o
120 endif
121
122 ifdef CONFIG_DRIVER_WIRED
123 CFLAGS += -DCONFIG_DRIVER_WIRED
124 OBJS += driver_wired.o
125 endif
126
127 ifdef CONFIG_DRIVER_MADWIFI
128 CFLAGS += -DCONFIG_DRIVER_MADWIFI
129 OBJS += driver_madwifi.o
130 CONFIG_L2_PACKET=y
131 endif
132
133 ifdef CONFIG_DRIVER_PRISM54
134 CFLAGS += -DCONFIG_DRIVER_PRISM54
135 OBJS += driver_prism54.o
136 endif
137
138 ifdef CONFIG_DRIVER_NL80211
139 NEED_MLME=y
140 CFLAGS += -DCONFIG_DRIVER_NL80211
141 OBJS += driver_nl80211.o
142 OBJS += ../src/utils/radiotap.o
143 LIBS += -lnl
144 ifdef CONFIG_LIBNL20
145 LIBS += -lnl-genl
146 CFLAGS += -DCONFIG_LIBNL20
147 endif
148 endif
149
150 ifdef CONFIG_DRIVER_BSD
151 CFLAGS += -DCONFIG_DRIVER_BSD
152 OBJS += driver_bsd.o
153 CONFIG_L2_PACKET=y
154 CONFIG_DNET_PCAP=y
155 CONFIG_L2_FREEBSD=y
156 endif
157
158 ifdef CONFIG_DRIVER_TEST
159 NEED_MLME=y
160 CFLAGS += -DCONFIG_DRIVER_TEST
161 OBJS += driver_test.o
162 endif
163
164 ifdef CONFIG_DRIVER_NONE
165 CFLAGS += -DCONFIG_DRIVER_NONE
166 OBJS += driver_none.o
167 endif
168
169 ifdef CONFIG_L2_PACKET
170 ifdef CONFIG_DNET_PCAP
171 ifdef CONFIG_L2_FREEBSD
172 LIBS += -lpcap
173 OBJS += ../src/l2_packet/l2_packet_freebsd.o
174 else
175 LIBS += -ldnet -lpcap
176 OBJS += ../src/l2_packet/l2_packet_pcap.o
177 endif
178 else
179 OBJS += ../src/l2_packet/l2_packet_linux.o
180 endif
181 else
182 OBJS += ../src/l2_packet/l2_packet_none.o
183 endif
184
185
186 ifdef CONFIG_EAP_MD5
187 CFLAGS += -DEAP_MD5
188 OBJS += ../src/eap_server/eap_md5.o
189 CHAP=y
190 endif
191
192 ifdef CONFIG_EAP_TLS
193 CFLAGS += -DEAP_TLS
194 OBJS += ../src/eap_server/eap_tls.o
195 TLS_FUNCS=y
196 endif
197
198 ifdef CONFIG_EAP_PEAP
199 CFLAGS += -DEAP_PEAP
200 OBJS += ../src/eap_server/eap_peap.o
201 OBJS += ../src/eap_common/eap_peap_common.o
202 TLS_FUNCS=y
203 CONFIG_EAP_MSCHAPV2=y
204 endif
205
206 ifdef CONFIG_EAP_TTLS
207 CFLAGS += -DEAP_TTLS
208 OBJS += ../src/eap_server/eap_ttls.o
209 TLS_FUNCS=y
210 CHAP=y
211 endif
212
213 ifdef CONFIG_EAP_MSCHAPV2
214 CFLAGS += -DEAP_MSCHAPv2
215 OBJS += ../src/eap_server/eap_mschapv2.o
216 MS_FUNCS=y
217 endif
218
219 ifdef CONFIG_EAP_GTC
220 CFLAGS += -DEAP_GTC
221 OBJS += ../src/eap_server/eap_gtc.o
222 endif
223
224 ifdef CONFIG_EAP_SIM
225 CFLAGS += -DEAP_SIM
226 OBJS += ../src/eap_server/eap_sim.o
227 CONFIG_EAP_SIM_COMMON=y
228 endif
229
230 ifdef CONFIG_EAP_AKA
231 CFLAGS += -DEAP_AKA
232 OBJS += ../src/eap_server/eap_aka.o
233 CONFIG_EAP_SIM_COMMON=y
234 endif
235
236 ifdef CONFIG_EAP_AKA_PRIME
237 CFLAGS += -DEAP_AKA_PRIME
238 endif
239
240 ifdef CONFIG_EAP_SIM_COMMON
241 OBJS += ../src/eap_common/eap_sim_common.o
242 # Example EAP-SIM/AKA interface for GSM/UMTS authentication. This can be
243 # replaced with another file implementating the interface specified in
244 # eap_sim_db.h.
245 OBJS += ../src/eap_server/eap_sim_db.o
246 NEED_FIPS186_2_PRF=y
247 endif
248
249 ifdef CONFIG_EAP_PAX
250 CFLAGS += -DEAP_PAX
251 OBJS += ../src/eap_server/eap_pax.o ../src/eap_common/eap_pax_common.o
252 endif
253
254 ifdef CONFIG_EAP_PSK
255 CFLAGS += -DEAP_PSK
256 OBJS += ../src/eap_server/eap_psk.o ../src/eap_common/eap_psk_common.o
257 endif
258
259 ifdef CONFIG_EAP_SAKE
260 CFLAGS += -DEAP_SAKE
261 OBJS += ../src/eap_server/eap_sake.o ../src/eap_common/eap_sake_common.o
262 endif
263
264 ifdef CONFIG_EAP_GPSK
265 CFLAGS += -DEAP_GPSK
266 OBJS += ../src/eap_server/eap_gpsk.o ../src/eap_common/eap_gpsk_common.o
267 ifdef CONFIG_EAP_GPSK_SHA256
268 CFLAGS += -DEAP_GPSK_SHA256
269 endif
270 NEED_SHA256=y
271 endif
272
273 ifdef CONFIG_EAP_VENDOR_TEST
274 CFLAGS += -DEAP_VENDOR_TEST
275 OBJS += ../src/eap_server/eap_vendor_test.o
276 endif
277
278 ifdef CONFIG_EAP_FAST
279 CFLAGS += -DEAP_FAST
280 OBJS += ../src/eap_server/eap_fast.o
281 OBJS += ../src/eap_common/eap_fast_common.o
282 TLS_FUNCS=y
283 NEED_T_PRF=y
284 endif
285
286 ifdef CONFIG_WPS
287 CFLAGS += -DCONFIG_WPS -DEAP_WSC
288 OBJS += ../src/utils/uuid.o
289 OBJS += wps_hostapd.o
290 OBJS += ../src/eap_server/eap_wsc.o ../src/eap_common/eap_wsc_common.o
291 OBJS += ../src/wps/wps.o
292 OBJS += ../src/wps/wps_common.o
293 OBJS += ../src/wps/wps_attr_parse.o
294 OBJS += ../src/wps/wps_attr_build.o
295 OBJS += ../src/wps/wps_attr_process.o
296 OBJS += ../src/wps/wps_dev_attr.o
297 OBJS += ../src/wps/wps_enrollee.o
298 OBJS += ../src/wps/wps_registrar.o
299 NEED_DH_GROUPS=y
300 NEED_SHA256=y
301 NEED_CRYPTO=y
302 NEED_BASE64=y
303 endif
304
305 ifdef CONFIG_EAP_IKEV2
306 CFLAGS += -DEAP_IKEV2
307 OBJS += ../src/eap_server/eap_ikev2.o ../src/eap_server/ikev2.o
308 OBJS += ../src/eap_common/eap_ikev2_common.o ../src/eap_common/ikev2_common.o
309 NEED_DH_GROUPS=y
310 endif
311
312 ifdef CONFIG_EAP_TNC
313 CFLAGS += -DEAP_TNC
314 OBJS += ../src/eap_server/eap_tnc.o
315 OBJS += ../src/eap_server/tncs.o
316 NEED_BASE64=y
317 endif
318
319 # Basic EAP functionality is needed for EAPOL
320 OBJS += ../src/eap_server/eap.o
321 OBJS += ../src/eap_common/eap_common.o
322 OBJS += ../src/eap_server/eap_methods.o
323 OBJS += ../src/eap_server/eap_identity.o
324
325 ifdef CONFIG_EAP
326 CFLAGS += -DEAP_SERVER
327 endif
328
329 ifndef CONFIG_TLS
330 CONFIG_TLS=openssl
331 endif
332
333 ifeq ($(CONFIG_TLS), internal)
334 ifndef CONFIG_CRYPTO
335 CONFIG_CRYPTO=internal
336 endif
337 endif
338 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
339 CFLAGS += -DCONFIG_INTERNAL_X509
340 endif
341 ifeq ($(CONFIG_CRYPTO), internal)
342 CFLAGS += -DCONFIG_INTERNAL_X509
343 endif
344
345
346 ifdef TLS_FUNCS
347 # Shared TLS functions (needed for EAP_TLS, EAP_PEAP, and EAP_TTLS)
348 CFLAGS += -DEAP_TLS_FUNCS
349 OBJS += ../src/eap_server/eap_tls_common.o
350 ifeq ($(CONFIG_TLS), openssl)
351 OBJS += ../src/crypto/tls_openssl.o
352 LIBS += -lssl -lcrypto
353 LIBS_p += -lcrypto
354 LIBS_h += -lcrypto
355 endif
356 ifeq ($(CONFIG_TLS), gnutls)
357 OBJS += ../src/crypto/tls_gnutls.o
358 LIBS += -lgnutls -lgcrypt -lgpg-error
359 LIBS_p += -lgcrypt
360 LIBS_h += -lgcrypt
361 endif
362 ifdef CONFIG_GNUTLS_EXTRA
363 CFLAGS += -DCONFIG_GNUTLS_EXTRA
364 LIBS += -lgnutls-extra
365 endif
366 ifeq ($(CONFIG_TLS), internal)
367 OBJS += ../src/crypto/tls_internal.o
368 OBJS += ../src/tls/tlsv1_common.o ../src/tls/tlsv1_record.o
369 OBJS += ../src/tls/tlsv1_cred.o ../src/tls/tlsv1_server.o
370 OBJS += ../src/tls/tlsv1_server_write.o ../src/tls/tlsv1_server_read.o
371 OBJS += ../src/tls/asn1.o ../src/tls/x509v3.o
372 OBJS_p += ../src/tls/asn1.o
373 OBJS_p += ../src/crypto/rc4.o ../src/crypto/aes_wrap.o ../src/crypto/aes.o
374 NEED_BASE64=y
375 CFLAGS += -DCONFIG_TLS_INTERNAL
376 CFLAGS += -DCONFIG_TLS_INTERNAL_SERVER
377 ifeq ($(CONFIG_CRYPTO), internal)
378 ifdef CONFIG_INTERNAL_LIBTOMMATH
379 CFLAGS += -DCONFIG_INTERNAL_LIBTOMMATH
380 else
381 LIBS += -ltommath
382 LIBS_p += -ltommath
383 endif
384 endif
385 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
386 LIBS += -ltomcrypt -ltfm
387 LIBS_p += -ltomcrypt -ltfm
388 endif
389 endif
390 NEED_CRYPTO=y
391 else
392 OBJS += ../src/crypto/tls_none.o
393 endif
394
395 ifdef CONFIG_PKCS12
396 CFLAGS += -DPKCS12_FUNCS
397 endif
398
399 ifdef MS_FUNCS
400 OBJS += ../src/crypto/ms_funcs.o
401 NEED_CRYPTO=y
402 endif
403
404 ifdef CHAP
405 OBJS += ../src/eap_common/chap.o
406 endif
407
408 ifdef NEED_CRYPTO
409 ifndef TLS_FUNCS
410 ifeq ($(CONFIG_TLS), openssl)
411 LIBS += -lcrypto
412 LIBS_p += -lcrypto
413 LIBS_h += -lcrypto
414 endif
415 ifeq ($(CONFIG_TLS), gnutls)
416 LIBS += -lgcrypt
417 LIBS_p += -lgcrypt
418 LIBS_h += -lgcrypt
419 endif
420 ifeq ($(CONFIG_TLS), internal)
421 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
422 LIBS += -ltomcrypt -ltfm
423 LIBS_p += -ltomcrypt -ltfm
424 endif
425 endif
426 endif
427 ifeq ($(CONFIG_TLS), openssl)
428 OBJS += ../src/crypto/crypto_openssl.o
429 OBJS_p += ../src/crypto/crypto_openssl.o
430 HOBJS += ../src/crypto/crypto_openssl.o
431 CONFIG_INTERNAL_SHA256=y
432 endif
433 ifeq ($(CONFIG_TLS), gnutls)
434 OBJS += ../src/crypto/crypto_gnutls.o
435 OBJS_p += ../src/crypto/crypto_gnutls.o
436 HOBJS += ../src/crypto/crypto_gnutls.o
437 CONFIG_INTERNAL_SHA256=y
438 endif
439 ifeq ($(CONFIG_TLS), internal)
440 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
441 OBJS += ../src/crypto/crypto_libtomcrypt.o
442 OBJS_p += ../src/crypto/crypto_libtomcrypt.o
443 CONFIG_INTERNAL_SHA256=y
444 endif
445 ifeq ($(CONFIG_CRYPTO), internal)
446 OBJS += ../src/crypto/crypto_internal.o ../src/tls/rsa.o ../src/tls/bignum.o
447 OBJS_p += ../src/crypto/crypto_internal.o ../src/tls/rsa.o ../src/tls/bignum.o
448 CFLAGS += -DCONFIG_CRYPTO_INTERNAL
449 CONFIG_INTERNAL_AES=y
450 CONFIG_INTERNAL_DES=y
451 CONFIG_INTERNAL_SHA1=y
452 CONFIG_INTERNAL_MD4=y
453 CONFIG_INTERNAL_MD5=y
454 CONFIG_INTERNAL_SHA256=y
455 endif
456 endif
457 else
458 CONFIG_INTERNAL_AES=y
459 CONFIG_INTERNAL_SHA1=y
460 CONFIG_INTERNAL_MD5=y
461 CONFIG_INTERNAL_SHA256=y
462 endif
463
464 ifdef CONFIG_INTERNAL_AES
465 CFLAGS += -DINTERNAL_AES
466 endif
467 ifdef CONFIG_INTERNAL_SHA1
468 CFLAGS += -DINTERNAL_SHA1
469 endif
470 ifdef CONFIG_INTERNAL_SHA256
471 CFLAGS += -DINTERNAL_SHA256
472 endif
473 ifdef CONFIG_INTERNAL_MD5
474 CFLAGS += -DINTERNAL_MD5
475 endif
476 ifdef CONFIG_INTERNAL_MD4
477 CFLAGS += -DINTERNAL_MD4
478 endif
479 ifdef CONFIG_INTERNAL_DES
480 CFLAGS += -DINTERNAL_DES
481 endif
482
483 ifdef NEED_SHA256
484 OBJS += ../src/crypto/sha256.o
485 endif
486
487 ifdef NEED_DH_GROUPS
488 OBJS += ../src/crypto/dh_groups.o
489 endif
490
491 ifndef NEED_FIPS186_2_PRF
492 CFLAGS += -DCONFIG_NO_FIPS186_2_PRF
493 endif
494
495 ifndef NEED_T_PRF
496 CFLAGS += -DCONFIG_NO_T_PRF
497 endif
498
499 ifdef CONFIG_RADIUS_SERVER
500 CFLAGS += -DRADIUS_SERVER
501 OBJS += ../src/radius/radius_server.o
502 endif
503
504 ifdef CONFIG_IPV6
505 CFLAGS += -DCONFIG_IPV6
506 endif
507
508 ifdef CONFIG_DRIVER_RADIUS_ACL
509 CFLAGS += -DCONFIG_DRIVER_RADIUS_ACL
510 endif
511
512 ifdef CONFIG_FULL_DYNAMIC_VLAN
513 # define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
514 # and vlan interfaces for the vlan feature.
515 CFLAGS += -DCONFIG_FULL_DYNAMIC_VLAN
516 endif
517
518 ifdef NEED_BASE64
519 OBJS += ../src/utils/base64.o
520 endif
521
522 ifdef NEED_MLME
523 OBJS += beacon.o wme.o ap_list.o ieee802_11.o
524 CFLAGS += -DNEED_MLME
525 endif
526
527 ifdef CONFIG_NO_STDOUT_DEBUG
528 CFLAGS += -DCONFIG_NO_STDOUT_DEBUG
529 endif
530
531 ifdef CONFIG_NO_AES_EXTRAS
532 CFLAGS += -DCONFIG_NO_AES_UNWRAP
533 CFLAGS += -DCONFIG_NO_AES_CTR -DCONFIG_NO_AES_OMAC1
534 CFLAGS += -DCONFIG_NO_AES_EAX -DCONFIG_NO_AES_CBC
535 CFLAGS += -DCONFIG_NO_AES_DECRYPT
536 CFLAGS += -DCONFIG_NO_AES_ENCRYPT_BLOCK
537 endif
538
539 ALL=hostapd hostapd_cli
540
541 all: verify_config $(ALL)
542
543 verify_config:
544         @if [ ! -r .config ]; then \
545                 echo 'Building hostapd requires a configuration file'; \
546                 echo '(.config). See README for more instructions. You can'; \
547                 echo 'run "cp defconfig .config" to create an example'; \
548                 echo 'configuration.'; \
549                 exit 1; \
550         fi
551
552 install: all
553         for i in $(ALL); do cp $$i /usr/local/bin/$$i; done
554
555 hostapd: $(OBJS)
556         $(CC) -o hostapd $(OBJS) $(LIBS)
557
558 OBJS_c = hostapd_cli.o ../src/common/wpa_ctrl.o ../src/utils/os_$(CONFIG_OS).o
559 hostapd_cli: $(OBJS_c)
560         $(CC) -o hostapd_cli $(OBJS_c)
561
562 NOBJS = nt_password_hash.o ../src/crypto/ms_funcs.o ../src/crypto/sha1.o ../src/crypto/rc4.o ../src/crypto/md5.o
563 NOBJS += ../src/crypto/crypto_openssl.o ../src/utils/os_$(CONFIG_OS).o
564 ifdef TLS_FUNCS
565 LIBS_n += -lcrypto
566 endif
567
568 nt_password_hash: $(NOBJS)
569         $(CC) -o nt_password_hash $(NOBJS) $(LIBS_n)
570
571 hlr_auc_gw: $(HOBJS)
572         $(CC) -o hlr_auc_gw $(HOBJS) $(LIBS_h)
573
574 clean:
575         $(MAKE) -C ../src clean
576         rm -f core *~ *.o hostapd hostapd_cli nt_password_hash hlr_auc_gw
577         rm -f *.d
578
579 %.eps: %.fig
580         fig2dev -L eps $*.fig $*.eps
581
582 %.png: %.fig
583         fig2dev -L png -m 3 $*.fig | pngtopnm | pnmscale 0.4 | pnmtopng \
584                 > $*.png
585
586 docs-pics: doc/hostapd.png doc/hostapd.eps
587
588 docs: docs-pics
589         (cd ..; doxygen hostapd/doc/doxygen.full; cd hostapd)
590         $(MAKE) -C doc/latex
591         cp doc/latex/refman.pdf hostapd-devel.pdf
592
593 docs-fast: docs-pics
594         (cd ..; doxygen hostapd/doc/doxygen.fast; cd hostapd)
595
596 clean-docs:
597         rm -rf doc/latex doc/html
598         rm -f doc/hostapd.{eps,png} hostapd-devel.pdf
599
600 TEST_SRC_MILENAGE = ../src/hlr_auc_gw/milenage.c ../src/crypto/aes_wrap.c ../src/crypto/aes.c ../src/utils/common.c ../src/utils/wpa_debug.o ../src/utils/os_$(CONFIG_OS).c
601 test-milenage: $(TEST_SRC_MILENAGE)
602         $(CC) -o test-milenage -Wall -Werror $(TEST_SRC_MILENAGE) \
603                 -DTEST_MAIN_MILENAGE -I. -DINTERNAL_AES \
604                 -I../src/crypto -I../src/utils
605         ./test-milenage
606         rm test-milenage
607
608 -include $(OBJS:%.o=%.d)