WPS 2.0: Validate WPS attributes in management frames and WSC messages
[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 CFLAGS += -I../src
10 CFLAGS += -I../src/utils
11
12 # Uncomment following line and set the path to your kernel tree include
13 # directory if your C library does not include all header files.
14 # CFLAGS += -DUSE_KERNEL_HEADERS -I/usr/src/linux/include
15
16 -include .config
17
18 ifndef CONFIG_OS
19 ifdef CONFIG_NATIVE_WINDOWS
20 CONFIG_OS=win32
21 else
22 CONFIG_OS=unix
23 endif
24 endif
25
26 ifeq ($(CONFIG_OS), internal)
27 CFLAGS += -DOS_NO_C_LIB_DEFINES
28 endif
29
30 ifdef CONFIG_NATIVE_WINDOWS
31 CFLAGS += -DCONFIG_NATIVE_WINDOWS
32 LIBS += -lws2_32
33 endif
34
35 OBJS += main.o
36 OBJS += config_file.o
37
38 OBJS += ../src/ap/hostapd.o
39 OBJS += ../src/ap/wpa_auth_glue.o
40 OBJS += ../src/ap/drv_callbacks.o
41 OBJS += ../src/ap/ap_drv_ops.o
42 OBJS += ../src/ap/utils.o
43 OBJS += ../src/ap/authsrv.o
44 OBJS += ../src/ap/ieee802_1x.o
45 OBJS += ../src/ap/ap_config.o
46 OBJS += ../src/ap/ieee802_11_auth.o
47 OBJS += ../src/ap/sta_info.o
48 OBJS += ../src/ap/wpa_auth.o
49 OBJS += ../src/ap/tkip_countermeasures.o
50 OBJS += ../src/ap/ap_mlme.o
51 OBJS += ../src/ap/wpa_auth_ie.o
52 OBJS += ../src/ap/preauth_auth.o
53 OBJS += ../src/ap/pmksa_cache_auth.o
54
55 NEED_RC4=y
56 NEED_AES=y
57 NEED_MD5=y
58 NEED_SHA1=y
59
60 OBJS += ../src/drivers/drivers.o
61 CFLAGS += -DHOSTAPD
62
63 ifdef CONFIG_WPA_TRACE
64 CFLAGS += -DWPA_TRACE
65 OBJS += ../src/utils/trace.o
66 LDFLAGS += -rdynamic
67 CFLAGS += -funwind-tables
68 ifdef CONFIG_WPA_TRACE_BFD
69 CFLAGS += -DWPA_TRACE_BFD
70 LIBS += -lbfd
71 LIBS_c += -lbfd
72 endif
73 endif
74
75 OBJS += ../src/utils/eloop.o
76 OBJS += ../src/utils/common.o
77 OBJS += ../src/utils/wpa_debug.o
78 OBJS += ../src/utils/wpabuf.o
79 OBJS += ../src/utils/os_$(CONFIG_OS).o
80 OBJS += ../src/utils/ip_addr.o
81
82 OBJS += ../src/common/ieee802_11_common.o
83 OBJS += ../src/common/wpa_common.o
84
85 OBJS += ../src/eapol_auth/eapol_auth_sm.o
86
87
88 ifndef CONFIG_NO_DUMP_STATE
89 # define HOSTAPD_DUMP_STATE to include SIGUSR1 handler for dumping state to
90 # a file (undefine it, if you want to save in binary size)
91 CFLAGS += -DHOSTAPD_DUMP_STATE
92 OBJS += dump_state.o
93 OBJS += ../src/eapol_auth/eapol_auth_dump.o
94 endif
95
96 ifdef CONFIG_NO_RADIUS
97 CFLAGS += -DCONFIG_NO_RADIUS
98 CONFIG_NO_ACCOUNTING=y
99 else
100 OBJS += ../src/radius/radius.o
101 OBJS += ../src/radius/radius_client.o
102 endif
103
104 ifdef CONFIG_NO_ACCOUNTING
105 CFLAGS += -DCONFIG_NO_ACCOUNTING
106 else
107 OBJS += ../src/ap/accounting.o
108 endif
109
110 ifdef CONFIG_NO_VLAN
111 CFLAGS += -DCONFIG_NO_VLAN
112 else
113 OBJS += ../src/ap/vlan_init.o
114 endif
115
116 ifdef CONFIG_NO_CTRL_IFACE
117 CFLAGS += -DCONFIG_NO_CTRL_IFACE
118 else
119 OBJS += ctrl_iface.o
120 OBJS += ../src/ap/ctrl_iface_ap.o
121 endif
122
123 OBJS += ../src/crypto/md5.o
124
125 CFLAGS += -DCONFIG_CTRL_IFACE -DCONFIG_CTRL_IFACE_UNIX
126
127 ifdef CONFIG_IAPP
128 CFLAGS += -DCONFIG_IAPP
129 OBJS += ../src/ap/iapp.o
130 endif
131
132 ifdef CONFIG_RSN_PREAUTH
133 CFLAGS += -DCONFIG_RSN_PREAUTH
134 CONFIG_L2_PACKET=y
135 endif
136
137 ifdef CONFIG_PEERKEY
138 CFLAGS += -DCONFIG_PEERKEY
139 OBJS += ../src/ap/peerkey_auth.o
140 endif
141
142 ifdef CONFIG_IEEE80211W
143 CFLAGS += -DCONFIG_IEEE80211W
144 NEED_SHA256=y
145 NEED_AES_OMAC1=y
146 endif
147
148 ifdef CONFIG_IEEE80211R
149 CFLAGS += -DCONFIG_IEEE80211R
150 OBJS += ../src/ap/wpa_auth_ft.o
151 NEED_SHA256=y
152 NEED_AES_OMAC1=y
153 NEED_AES_UNWRAP=y
154 endif
155
156 ifdef CONFIG_IEEE80211N
157 CFLAGS += -DCONFIG_IEEE80211N
158 endif
159
160 include ../src/drivers/drivers.mak
161 OBJS += $(DRV_AP_OBJS)
162 CFLAGS += $(DRV_AP_CFLAGS)
163 LDFLAGS += $(DRV_AP_LDFLAGS)
164 LIBS += $(DRV_AP_LIBS)
165
166 ifdef CONFIG_L2_PACKET
167 ifdef CONFIG_DNET_PCAP
168 ifdef CONFIG_L2_FREEBSD
169 LIBS += -lpcap
170 OBJS += ../src/l2_packet/l2_packet_freebsd.o
171 else
172 LIBS += -ldnet -lpcap
173 OBJS += ../src/l2_packet/l2_packet_pcap.o
174 endif
175 else
176 OBJS += ../src/l2_packet/l2_packet_linux.o
177 endif
178 else
179 OBJS += ../src/l2_packet/l2_packet_none.o
180 endif
181
182
183 ifdef CONFIG_EAP_MD5
184 CFLAGS += -DEAP_SERVER_MD5
185 OBJS += ../src/eap_server/eap_server_md5.o
186 CHAP=y
187 endif
188
189 ifdef CONFIG_EAP_TLS
190 CFLAGS += -DEAP_SERVER_TLS
191 OBJS += ../src/eap_server/eap_server_tls.o
192 TLS_FUNCS=y
193 endif
194
195 ifdef CONFIG_EAP_PEAP
196 CFLAGS += -DEAP_SERVER_PEAP
197 OBJS += ../src/eap_server/eap_server_peap.o
198 OBJS += ../src/eap_common/eap_peap_common.o
199 TLS_FUNCS=y
200 CONFIG_EAP_MSCHAPV2=y
201 endif
202
203 ifdef CONFIG_EAP_TTLS
204 CFLAGS += -DEAP_SERVER_TTLS
205 OBJS += ../src/eap_server/eap_server_ttls.o
206 TLS_FUNCS=y
207 CHAP=y
208 endif
209
210 ifdef CONFIG_EAP_MSCHAPV2
211 CFLAGS += -DEAP_SERVER_MSCHAPV2
212 OBJS += ../src/eap_server/eap_server_mschapv2.o
213 MS_FUNCS=y
214 endif
215
216 ifdef CONFIG_EAP_GTC
217 CFLAGS += -DEAP_SERVER_GTC
218 OBJS += ../src/eap_server/eap_server_gtc.o
219 endif
220
221 ifdef CONFIG_EAP_SIM
222 CFLAGS += -DEAP_SERVER_SIM
223 OBJS += ../src/eap_server/eap_server_sim.o
224 CONFIG_EAP_SIM_COMMON=y
225 NEED_AES_CBC=y
226 endif
227
228 ifdef CONFIG_EAP_AKA
229 CFLAGS += -DEAP_SERVER_AKA
230 OBJS += ../src/eap_server/eap_server_aka.o
231 CONFIG_EAP_SIM_COMMON=y
232 NEED_SHA256=y
233 NEED_AES_CBC=y
234 endif
235
236 ifdef CONFIG_EAP_AKA_PRIME
237 CFLAGS += -DEAP_SERVER_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_SERVER_PAX
251 OBJS += ../src/eap_server/eap_server_pax.o ../src/eap_common/eap_pax_common.o
252 endif
253
254 ifdef CONFIG_EAP_PSK
255 CFLAGS += -DEAP_SERVER_PSK
256 OBJS += ../src/eap_server/eap_server_psk.o ../src/eap_common/eap_psk_common.o
257 NEED_AES_OMAC1=y
258 NEED_AES_ENCBLOCK=y
259 NEED_AES_EAX=y
260 endif
261
262 ifdef CONFIG_EAP_SAKE
263 CFLAGS += -DEAP_SERVER_SAKE
264 OBJS += ../src/eap_server/eap_server_sake.o ../src/eap_common/eap_sake_common.o
265 endif
266
267 ifdef CONFIG_EAP_GPSK
268 CFLAGS += -DEAP_SERVER_GPSK
269 OBJS += ../src/eap_server/eap_server_gpsk.o ../src/eap_common/eap_gpsk_common.o
270 ifdef CONFIG_EAP_GPSK_SHA256
271 CFLAGS += -DEAP_SERVER_GPSK_SHA256
272 endif
273 NEED_SHA256=y
274 NEED_AES_OMAC1=y
275 endif
276
277 ifdef CONFIG_EAP_VENDOR_TEST
278 CFLAGS += -DEAP_SERVER_VENDOR_TEST
279 OBJS += ../src/eap_server/eap_server_vendor_test.o
280 endif
281
282 ifdef CONFIG_EAP_FAST
283 CFLAGS += -DEAP_SERVER_FAST
284 OBJS += ../src/eap_server/eap_server_fast.o
285 OBJS += ../src/eap_common/eap_fast_common.o
286 TLS_FUNCS=y
287 NEED_T_PRF=y
288 NEED_AES_UNWRAP=y
289 endif
290
291 ifdef CONFIG_WPS
292 CFLAGS += -DCONFIG_WPS -DEAP_SERVER_WSC
293 OBJS += ../src/utils/uuid.o
294 OBJS += ../src/ap/wps_hostapd.o
295 OBJS += ../src/eap_server/eap_server_wsc.o ../src/eap_common/eap_wsc_common.o
296 OBJS += ../src/wps/wps.o
297 OBJS += ../src/wps/wps_common.o
298 OBJS += ../src/wps/wps_attr_parse.o
299 OBJS += ../src/wps/wps_attr_build.o
300 OBJS += ../src/wps/wps_attr_process.o
301 OBJS += ../src/wps/wps_dev_attr.o
302 OBJS += ../src/wps/wps_enrollee.o
303 OBJS += ../src/wps/wps_registrar.o
304 NEED_DH_GROUPS=y
305 NEED_SHA256=y
306 NEED_BASE64=y
307 NEED_AES_CBC=y
308 NEED_MODEXP=y
309 CONFIG_EAP=y
310
311 ifdef CONFIG_WPS_UFD
312 CFLAGS += -DCONFIG_WPS_UFD
313 OBJS += ../src/wps/wps_ufd.o
314 NEED_WPS_OOB=y
315 endif
316
317 ifdef CONFIG_WPS_NFC
318 CFLAGS += -DCONFIG_WPS_NFC
319 OBJS += ../src/wps/ndef.o
320 OBJS += ../src/wps/wps_nfc.o
321 NEED_WPS_OOB=y
322 ifdef CONFIG_WPS_NFC_PN531
323 PN531_PATH ?= /usr/local/src/nfc
324 CFLAGS += -DCONFIG_WPS_NFC_PN531
325 CFLAGS += -I${PN531_PATH}/inc
326 OBJS += ../src/wps/wps_nfc_pn531.o
327 LIBS += ${PN531_PATH}/lib/wpsnfc.dll
328 LIBS += ${PN531_PATH}/lib/libnfc_mapping_pn53x.dll
329 endif
330
331 ifdef CONFIG_WPS_STRICT
332 CFLAGS += -DCONFIG_WPS_STRICT
333 OBJS += ../src/wps/wps_validate.o
334 endif
335 endif
336
337 ifdef NEED_WPS_OOB
338 CFLAGS += -DCONFIG_WPS_OOB
339 endif
340
341 ifdef CONFIG_WPS_UPNP
342 CFLAGS += -DCONFIG_WPS_UPNP
343 OBJS += ../src/wps/wps_upnp.o
344 OBJS += ../src/wps/wps_upnp_ssdp.o
345 OBJS += ../src/wps/wps_upnp_web.o
346 OBJS += ../src/wps/wps_upnp_event.o
347 OBJS += ../src/wps/wps_upnp_ap.o
348 OBJS += ../src/wps/upnp_xml.o
349 OBJS += ../src/wps/httpread.o
350 OBJS += ../src/wps/http_client.o
351 OBJS += ../src/wps/http_server.o
352 endif
353
354 endif
355
356 ifdef CONFIG_EAP_IKEV2
357 CFLAGS += -DEAP_SERVER_IKEV2
358 OBJS += ../src/eap_server/eap_server_ikev2.o ../src/eap_server/ikev2.o
359 OBJS += ../src/eap_common/eap_ikev2_common.o ../src/eap_common/ikev2_common.o
360 NEED_DH_GROUPS=y
361 NEED_DH_GROUPS_ALL=y
362 NEED_MODEXP=y
363 NEED_CIPHER=y
364 endif
365
366 ifdef CONFIG_EAP_TNC
367 CFLAGS += -DEAP_SERVER_TNC
368 OBJS += ../src/eap_server/eap_server_tnc.o
369 OBJS += ../src/eap_server/tncs.o
370 NEED_BASE64=y
371 ifndef CONFIG_DRIVER_BSD
372 LIBS += -ldl
373 endif
374 endif
375
376 # Basic EAP functionality is needed for EAPOL
377 OBJS += eap_register.o
378 OBJS += ../src/eap_server/eap_server.o
379 OBJS += ../src/eap_common/eap_common.o
380 OBJS += ../src/eap_server/eap_server_methods.o
381 OBJS += ../src/eap_server/eap_server_identity.o
382 CFLAGS += -DEAP_SERVER_IDENTITY
383
384 ifdef CONFIG_EAP
385 CFLAGS += -DEAP_SERVER
386 endif
387
388 ifdef CONFIG_PKCS12
389 CFLAGS += -DPKCS12_FUNCS
390 endif
391
392 ifdef MS_FUNCS
393 OBJS += ../src/crypto/ms_funcs.o
394 NEED_DES=y
395 NEED_MD4=y
396 endif
397
398 ifdef CHAP
399 OBJS += ../src/eap_common/chap.o
400 endif
401
402 ifdef TLS_FUNCS
403 NEED_DES=y
404 # Shared TLS functions (needed for EAP_TLS, EAP_PEAP, and EAP_TTLS)
405 CFLAGS += -DEAP_TLS_FUNCS
406 OBJS += ../src/eap_server/eap_server_tls_common.o
407 NEED_TLS_PRF=y
408 endif
409
410 ifndef CONFIG_TLS
411 CONFIG_TLS=openssl
412 endif
413
414 ifeq ($(CONFIG_TLS), openssl)
415 ifdef TLS_FUNCS
416 OBJS += ../src/crypto/tls_openssl.o
417 LIBS += -lssl
418 endif
419 OBJS += ../src/crypto/crypto_openssl.o
420 HOBJS += ../src/crypto/crypto_openssl.o
421 ifdef NEED_FIPS186_2_PRF
422 OBJS += ../src/crypto/fips_prf_openssl.o
423 endif
424 LIBS += -lcrypto
425 LIBS_h += -lcrypto
426 endif
427
428 ifeq ($(CONFIG_TLS), gnutls)
429 ifdef TLS_FUNCS
430 OBJS += ../src/crypto/tls_gnutls.o
431 LIBS += -lgnutls -lgpg-error
432 ifdef CONFIG_GNUTLS_EXTRA
433 CFLAGS += -DCONFIG_GNUTLS_EXTRA
434 LIBS += -lgnutls-extra
435 endif
436 endif
437 OBJS += ../src/crypto/crypto_gnutls.o
438 HOBJS += ../src/crypto/crypto_gnutls.o
439 ifdef NEED_FIPS186_2_PRF
440 OBJS += ../src/crypto/fips_prf_gnutls.o
441 endif
442 LIBS += -lgcrypt
443 LIBS_h += -lgcrypt
444 CONFIG_INTERNAL_SHA256=y
445 CONFIG_INTERNAL_RC4=y
446 CONFIG_INTERNAL_DH_GROUP5=y
447 endif
448
449 ifeq ($(CONFIG_TLS), schannel)
450 ifdef TLS_FUNCS
451 OBJS += ../src/crypto/tls_schannel.o
452 endif
453 OBJS += ../src/crypto/crypto_cryptoapi.o
454 OBJS_p += ../src/crypto/crypto_cryptoapi.o
455 CONFIG_INTERNAL_SHA256=y
456 CONFIG_INTERNAL_RC4=y
457 CONFIG_INTERNAL_DH_GROUP5=y
458 endif
459
460 ifeq ($(CONFIG_TLS), nss)
461 ifdef TLS_FUNCS
462 OBJS += ../src/crypto/tls_nss.o
463 LIBS += -lssl3
464 endif
465 OBJS += ../src/crypto/crypto_nss.o
466 ifdef NEED_FIPS186_2_PRF
467 OBJS += ../src/crypto/fips_prf_nss.o
468 endif
469 LIBS += -lnss3
470 LIBS_h += -lnss3
471 CONFIG_INTERNAL_MD4=y
472 CONFIG_INTERNAL_DH_GROUP5=y
473 endif
474
475 ifeq ($(CONFIG_TLS), internal)
476 ifndef CONFIG_CRYPTO
477 CONFIG_CRYPTO=internal
478 endif
479 ifdef TLS_FUNCS
480 OBJS += ../src/crypto/crypto_internal-rsa.o
481 OBJS += ../src/crypto/tls_internal.o
482 OBJS += ../src/tls/tlsv1_common.o
483 OBJS += ../src/tls/tlsv1_record.o
484 OBJS += ../src/tls/tlsv1_cred.o
485 OBJS += ../src/tls/tlsv1_server.o
486 OBJS += ../src/tls/tlsv1_server_write.o
487 OBJS += ../src/tls/tlsv1_server_read.o
488 OBJS += ../src/tls/asn1.o
489 OBJS += ../src/tls/rsa.o
490 OBJS += ../src/tls/x509v3.o
491 OBJS += ../src/tls/pkcs1.o
492 OBJS += ../src/tls/pkcs5.o
493 OBJS += ../src/tls/pkcs8.o
494 NEED_SHA256=y
495 NEED_BASE64=y
496 NEED_TLS_PRF=y
497 NEED_MODEXP=y
498 NEED_CIPHER=y
499 CFLAGS += -DCONFIG_TLS_INTERNAL
500 CFLAGS += -DCONFIG_TLS_INTERNAL_SERVER
501 endif
502 ifdef NEED_CIPHER
503 NEED_DES=y
504 OBJS += ../src/crypto/crypto_internal-cipher.o
505 endif
506 ifdef NEED_MODEXP
507 OBJS += ../src/crypto/crypto_internal-modexp.o
508 OBJS += ../src/tls/bignum.o
509 endif
510 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
511 OBJS += ../src/crypto/crypto_libtomcrypt.o
512 LIBS += -ltomcrypt -ltfm
513 LIBS_h += -ltomcrypt -ltfm
514 CONFIG_INTERNAL_SHA256=y
515 CONFIG_INTERNAL_RC4=y
516 CONFIG_INTERNAL_DH_GROUP5=y
517 endif
518 ifeq ($(CONFIG_CRYPTO), internal)
519 OBJS += ../src/crypto/crypto_internal.o
520 NEED_AES_DEC=y
521 CFLAGS += -DCONFIG_CRYPTO_INTERNAL
522 ifdef CONFIG_INTERNAL_LIBTOMMATH
523 CFLAGS += -DCONFIG_INTERNAL_LIBTOMMATH
524 ifdef CONFIG_INTERNAL_LIBTOMMATH_FAST
525 CFLAGS += -DLTM_FAST
526 endif
527 else
528 LIBS += -ltommath
529 LIBS_h += -ltommath
530 endif
531 CONFIG_INTERNAL_AES=y
532 CONFIG_INTERNAL_DES=y
533 CONFIG_INTERNAL_SHA1=y
534 CONFIG_INTERNAL_MD4=y
535 CONFIG_INTERNAL_MD5=y
536 CONFIG_INTERNAL_SHA256=y
537 CONFIG_INTERNAL_RC4=y
538 CONFIG_INTERNAL_DH_GROUP5=y
539 endif
540 ifeq ($(CONFIG_CRYPTO), cryptoapi)
541 OBJS += ../src/crypto/crypto_cryptoapi.o
542 OBJS_p += ../src/crypto/crypto_cryptoapi.o
543 CFLAGS += -DCONFIG_CRYPTO_CRYPTOAPI
544 CONFIG_INTERNAL_SHA256=y
545 CONFIG_INTERNAL_RC4=y
546 endif
547 endif
548
549 ifeq ($(CONFIG_TLS), none)
550 ifdef TLS_FUNCS
551 OBJS += ../src/crypto/tls_none.o
552 CFLAGS += -DEAP_TLS_NONE
553 CONFIG_INTERNAL_AES=y
554 CONFIG_INTERNAL_SHA1=y
555 CONFIG_INTERNAL_MD5=y
556 endif
557 OBJS += ../src/crypto/crypto_none.o
558 OBJS_p += ../src/crypto/crypto_none.o
559 CONFIG_INTERNAL_SHA256=y
560 CONFIG_INTERNAL_RC4=y
561 endif
562
563 ifndef TLS_FUNCS
564 OBJS += ../src/crypto/tls_none.o
565 ifeq ($(CONFIG_TLS), internal)
566 CONFIG_INTERNAL_AES=y
567 CONFIG_INTERNAL_SHA1=y
568 CONFIG_INTERNAL_MD5=y
569 CONFIG_INTERNAL_RC4=y
570 endif
571 endif
572
573 AESOBJS = # none so far
574 ifdef CONFIG_INTERNAL_AES
575 AESOBJS += ../src/crypto/aes-internal.o ../src/crypto/aes-internal-enc.o
576 endif
577
578 AESOBJS += ../src/crypto/aes-wrap.o
579 ifdef NEED_AES_EAX
580 AESOBJS += ../src/crypto/aes-eax.o
581 NEED_AES_CTR=y
582 endif
583 ifdef NEED_AES_CTR
584 AESOBJS += ../src/crypto/aes-ctr.o
585 endif
586 ifdef NEED_AES_ENCBLOCK
587 AESOBJS += ../src/crypto/aes-encblock.o
588 endif
589 ifdef NEED_AES_OMAC1
590 AESOBJS += ../src/crypto/aes-omac1.o
591 endif
592 ifdef NEED_AES_UNWRAP
593 NEED_AES_DEC=y
594 AESOBJS += ../src/crypto/aes-unwrap.o
595 endif
596 ifdef NEED_AES_CBC
597 NEED_AES_DEC=y
598 AESOBJS += ../src/crypto/aes-cbc.o
599 endif
600 ifdef NEED_AES_DEC
601 ifdef CONFIG_INTERNAL_AES
602 AESOBJS += ../src/crypto/aes-internal-dec.o
603 endif
604 endif
605 ifdef NEED_AES
606 OBJS += $(AESOBJS)
607 endif
608
609 ifdef NEED_SHA1
610 SHA1OBJS += ../src/crypto/sha1.o
611 ifdef CONFIG_INTERNAL_SHA1
612 SHA1OBJS += ../src/crypto/sha1-internal.o
613 ifdef NEED_FIPS186_2_PRF
614 SHA1OBJS += ../src/crypto/fips_prf_internal.o
615 endif
616 endif
617 SHA1OBJS += ../src/crypto/sha1-pbkdf2.o
618 ifdef NEED_T_PRF
619 SHA1OBJS += ../src/crypto/sha1-tprf.o
620 endif
621 ifdef NEED_TLS_PRF
622 SHA1OBJS += ../src/crypto/sha1-tlsprf.o
623 endif
624 endif
625
626 ifdef NEED_SHA1
627 OBJS += $(SHA1OBJS)
628 endif
629
630 ifdef NEED_MD5
631 ifdef CONFIG_INTERNAL_MD5
632 OBJS += ../src/crypto/md5-internal.o
633 endif
634 endif
635
636 ifdef NEED_MD4
637 ifdef CONFIG_INTERNAL_MD4
638 OBJS += ../src/crypto/md4-internal.o
639 endif
640 endif
641
642 ifdef NEED_DES
643 ifdef CONFIG_INTERNAL_DES
644 OBJS += ../src/crypto/des-internal.o
645 endif
646 endif
647
648 ifdef NEED_RC4
649 ifdef CONFIG_INTERNAL_RC4
650 OBJS += ../src/crypto/rc4.o
651 endif
652 endif
653
654 ifdef NEED_SHA256
655 OBJS += ../src/crypto/sha256.o
656 ifdef CONFIG_INTERNAL_SHA256
657 OBJS += ../src/crypto/sha256-internal.o
658 endif
659 endif
660
661 ifdef NEED_DH_GROUPS
662 OBJS += ../src/crypto/dh_groups.o
663 endif
664 ifdef NEED_DH_GROUPS_ALL
665 CFLAGS += -DALL_DH_GROUPS
666 endif
667 ifdef CONFIG_INTERNAL_DH_GROUP5
668 ifdef NEED_DH_GROUPS
669 OBJS += ../src/crypto/dh_group5.o
670 endif
671 endif
672
673 ifdef CONFIG_RADIUS_SERVER
674 CFLAGS += -DRADIUS_SERVER
675 OBJS += ../src/radius/radius_server.o
676 endif
677
678 ifdef CONFIG_IPV6
679 CFLAGS += -DCONFIG_IPV6
680 endif
681
682 ifdef CONFIG_DRIVER_RADIUS_ACL
683 CFLAGS += -DCONFIG_DRIVER_RADIUS_ACL
684 endif
685
686 ifdef CONFIG_FULL_DYNAMIC_VLAN
687 # define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
688 # and vlan interfaces for the vlan feature.
689 CFLAGS += -DCONFIG_FULL_DYNAMIC_VLAN
690 endif
691
692 ifdef NEED_BASE64
693 OBJS += ../src/utils/base64.o
694 endif
695
696 ifdef NEED_AP_MLME
697 OBJS += ../src/ap/beacon.o
698 OBJS += ../src/ap/wmm.o
699 OBJS += ../src/ap/ap_list.o
700 OBJS += ../src/ap/ieee802_11.o
701 OBJS += ../src/ap/hw_features.o
702 CFLAGS += -DNEED_AP_MLME
703 endif
704 ifdef CONFIG_IEEE80211N
705 OBJS += ../src/ap/ieee802_11_ht.o
706 endif
707
708 ifdef CONFIG_NO_STDOUT_DEBUG
709 CFLAGS += -DCONFIG_NO_STDOUT_DEBUG
710 endif
711
712 ALL=hostapd hostapd_cli
713
714 all: verify_config $(ALL)
715
716 Q=@
717 E=echo
718 ifeq ($(V), 1)
719 Q=
720 E=true
721 endif
722
723 %.o: %.c
724         $(Q)$(CC) -c -o $@ $(CFLAGS) $<
725         @$(E) "  CC " $<
726
727 verify_config:
728         @if [ ! -r .config ]; then \
729                 echo 'Building hostapd requires a configuration file'; \
730                 echo '(.config). See README for more instructions. You can'; \
731                 echo 'run "cp defconfig .config" to create an example'; \
732                 echo 'configuration.'; \
733                 exit 1; \
734         fi
735
736 install: all
737         for i in $(ALL); do cp -f $$i /usr/local/bin/$$i; done
738
739 ../src/drivers/build.hostapd:
740         @if [ -f ../src/drivers/build.wpa_supplicant ]; then \
741                 $(MAKE) -C ../src/drivers clean; \
742         fi
743         @touch ../src/drivers/build.hostapd
744
745 BCHECK=../src/drivers/build.hostapd
746
747 hostapd: $(BCHECK) $(OBJS)
748         $(CC) $(LDFLAGS) -o hostapd $(OBJS) $(LIBS)
749
750 OBJS_c = hostapd_cli.o ../src/common/wpa_ctrl.o ../src/utils/os_$(CONFIG_OS).o
751 ifdef CONFIG_WPA_TRACE
752 OBJS_c += ../src/utils/trace.o
753 OBJS_c += ../src/utils/wpa_debug.o
754 endif
755 hostapd_cli: $(OBJS_c)
756         $(CC) $(LDFLAGS) -o hostapd_cli $(OBJS_c) $(LIBS_c)
757
758 NOBJS = nt_password_hash.o ../src/crypto/ms_funcs.o $(SHA1OBJS) ../src/crypto/md5.o
759 ifdef NEED_RC4
760 ifdef CONFIG_INTERNAL_RC4
761 NOBJS += ../src/crypto/rc4.o
762 endif
763 endif
764 ifdef CONFIG_INTERNAL_MD5
765 NOBJS += ../src/crypto/md5-internal.o
766 endif
767 NOBJS += ../src/crypto/crypto_openssl.o ../src/utils/os_$(CONFIG_OS).o
768 NOBJS += ../src/utils/wpa_debug.o
769 NOBJS += ../src/utils/wpabuf.o
770 ifdef CONFIG_WPA_TRACE
771 NOBJS += ../src/utils/trace.o
772 LIBS_n += -lbfd
773 endif
774 ifdef TLS_FUNCS
775 LIBS_n += -lcrypto
776 endif
777
778 HOBJS += hlr_auc_gw.o ../src/utils/common.o ../src/utils/wpa_debug.o ../src/utils/os_$(CONFIG_OS).o ../src/utils/wpabuf.o ../src/crypto/milenage.o
779 HOBJS += ../src/crypto/aes-encblock.o
780 ifdef CONFIG_INTERNAL_AES
781 HOBJS += ../src/crypto/aes-internal.o
782 HOBJS += ../src/crypto/aes-internal-enc.o
783 endif
784
785 nt_password_hash: $(NOBJS)
786         $(CC) $(LDFLAGS) -o nt_password_hash $(NOBJS) $(LIBS_n)
787
788 hlr_auc_gw: $(HOBJS)
789         $(CC) $(LDFLAGS) -o hlr_auc_gw $(HOBJS) $(LIBS_h)
790
791 clean:
792         $(MAKE) -C ../src clean
793         rm -f core *~ *.o hostapd hostapd_cli nt_password_hash hlr_auc_gw
794         rm -f *.d
795
796 -include $(OBJS:%.o=%.d)