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