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