6 CFLAGS = -MMD -O2 -Wall -g
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
14 CFLAGS += -I../src/crypto
15 CFLAGS += -I../src/utils
16 CFLAGS += -I../src/common
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
25 ifdef CONFIG_NATIVE_WINDOWS
32 ifeq ($(CONFIG_OS), internal)
33 CFLAGS += -DOS_NO_C_LIB_DEFINES
36 ifdef CONFIG_NATIVE_WINDOWS
37 CFLAGS += -DCONFIG_NATIVE_WINDOWS
41 OBJS = hostapd.o ieee802_1x.o eapol_sm.o \
42 config.o ieee802_11_auth.o \
44 drivers.o preauth.o pmksa_cache.o \
46 tkip_countermeasures.o \
49 OBJS += ../src/utils/eloop.o
50 OBJS += ../src/utils/common.o
51 OBJS += ../src/utils/wpa_debug.o
52 OBJS += ../src/utils/wpabuf.o
53 OBJS += ../src/utils/os_$(CONFIG_OS).o
54 OBJS += ../src/utils/ip_addr.o
56 OBJS += ../src/common/ieee802_11_common.o
57 OBJS += ../src/common/wpa_common.o
59 ifdef CONFIG_NO_RADIUS
60 CFLAGS += -DCONFIG_NO_RADIUS
61 CONFIG_NO_ACCOUNTING=y
63 OBJS += ../src/radius/radius.o
64 OBJS += ../src/radius/radius_client.o
67 ifdef CONFIG_NO_ACCOUNTING
68 CFLAGS += -DCONFIG_NO_ACCOUNTING
74 CFLAGS += -DCONFIG_NO_VLAN
79 ifdef CONFIG_NO_CTRL_IFACE
80 CFLAGS += -DCONFIG_NO_CTRL_IFACE
85 OBJS += ../src/crypto/md5.o
86 OBJS += ../src/crypto/rc4.o
87 OBJS += ../src/crypto/md4.o
88 OBJS += ../src/crypto/sha1.o
89 OBJS += ../src/crypto/des.o
90 OBJS += ../src/crypto/aes_wrap.o
91 OBJS += ../src/crypto/aes.o
93 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 CFLAGS += -DCONFIG_CTRL_IFACE -DCONFIG_CTRL_IFACE_UNIX
98 CFLAGS += -DCONFIG_IAPP
102 ifdef CONFIG_RSN_PREAUTH
103 CFLAGS += -DCONFIG_RSN_PREAUTH
108 CFLAGS += -DCONFIG_PEERKEY
112 ifdef CONFIG_IEEE80211W
113 CFLAGS += -DCONFIG_IEEE80211W
117 ifdef CONFIG_IEEE80211R
118 CFLAGS += -DCONFIG_IEEE80211R
123 ifdef CONFIG_IEEE80211N
124 CFLAGS += -DCONFIG_IEEE80211N
127 ifdef CONFIG_DRIVER_HOSTAP
129 CFLAGS += -DCONFIG_DRIVER_HOSTAP
130 OBJS += driver_hostap.o
133 ifdef CONFIG_DRIVER_WIRED
134 CFLAGS += -DCONFIG_DRIVER_WIRED
135 OBJS += driver_wired.o
138 ifdef CONFIG_DRIVER_MADWIFI
139 CFLAGS += -DCONFIG_DRIVER_MADWIFI
140 OBJS += driver_madwifi.o
144 ifdef CONFIG_DRIVER_PRISM54
145 CFLAGS += -DCONFIG_DRIVER_PRISM54
146 OBJS += driver_prism54.o
149 ifdef CONFIG_DRIVER_NL80211
151 CFLAGS += -DCONFIG_DRIVER_NL80211
152 OBJS += driver_nl80211.o
153 OBJS += ../src/utils/radiotap.o
157 CFLAGS += -DCONFIG_LIBNL20
161 ifdef CONFIG_DRIVER_BSD
162 CFLAGS += -DCONFIG_DRIVER_BSD
169 ifdef CONFIG_DRIVER_TEST
171 CFLAGS += -DCONFIG_DRIVER_TEST
172 OBJS += driver_test.o
175 ifdef CONFIG_DRIVER_NONE
176 CFLAGS += -DCONFIG_DRIVER_NONE
177 OBJS += driver_none.o
180 ifdef CONFIG_L2_PACKET
181 ifdef CONFIG_DNET_PCAP
182 ifdef CONFIG_L2_FREEBSD
184 OBJS += ../src/l2_packet/l2_packet_freebsd.o
186 LIBS += -ldnet -lpcap
187 OBJS += ../src/l2_packet/l2_packet_pcap.o
190 OBJS += ../src/l2_packet/l2_packet_linux.o
193 OBJS += ../src/l2_packet/l2_packet_none.o
199 OBJS += ../src/eap_server/eap_md5.o
205 OBJS += ../src/eap_server/eap_tls.o
209 ifdef CONFIG_EAP_PEAP
211 OBJS += ../src/eap_server/eap_peap.o
212 OBJS += ../src/eap_common/eap_peap_common.o
214 CONFIG_EAP_MSCHAPV2=y
217 ifdef CONFIG_EAP_TTLS
219 OBJS += ../src/eap_server/eap_ttls.o
224 ifdef CONFIG_EAP_MSCHAPV2
225 CFLAGS += -DEAP_MSCHAPv2
226 OBJS += ../src/eap_server/eap_mschapv2.o
232 OBJS += ../src/eap_server/eap_gtc.o
237 OBJS += ../src/eap_server/eap_sim.o
238 CONFIG_EAP_SIM_COMMON=y
243 OBJS += ../src/eap_server/eap_aka.o
244 CONFIG_EAP_SIM_COMMON=y
247 ifdef CONFIG_EAP_AKA_PRIME
248 CFLAGS += -DEAP_AKA_PRIME
251 ifdef CONFIG_EAP_SIM_COMMON
252 OBJS += ../src/eap_common/eap_sim_common.o
253 # Example EAP-SIM/AKA interface for GSM/UMTS authentication. This can be
254 # replaced with another file implementating the interface specified in
256 OBJS += ../src/eap_server/eap_sim_db.o
262 OBJS += ../src/eap_server/eap_pax.o ../src/eap_common/eap_pax_common.o
267 OBJS += ../src/eap_server/eap_psk.o ../src/eap_common/eap_psk_common.o
270 ifdef CONFIG_EAP_SAKE
272 OBJS += ../src/eap_server/eap_sake.o ../src/eap_common/eap_sake_common.o
275 ifdef CONFIG_EAP_GPSK
277 OBJS += ../src/eap_server/eap_gpsk.o ../src/eap_common/eap_gpsk_common.o
278 ifdef CONFIG_EAP_GPSK_SHA256
279 CFLAGS += -DEAP_GPSK_SHA256
284 ifdef CONFIG_EAP_VENDOR_TEST
285 CFLAGS += -DEAP_VENDOR_TEST
286 OBJS += ../src/eap_server/eap_vendor_test.o
289 ifdef CONFIG_EAP_FAST
291 OBJS += ../src/eap_server/eap_fast.o
292 OBJS += ../src/eap_common/eap_fast_common.o
298 CFLAGS += -DCONFIG_WPS -DEAP_WSC
299 OBJS += ../src/utils/uuid.o
300 OBJS += wps_hostapd.o
301 OBJS += ../src/eap_server/eap_wsc.o ../src/eap_common/eap_wsc_common.o
302 OBJS += ../src/wps/wps.o
303 OBJS += ../src/wps/wps_common.o
304 OBJS += ../src/wps/wps_attr_parse.o
305 OBJS += ../src/wps/wps_attr_build.o
306 OBJS += ../src/wps/wps_attr_process.o
307 OBJS += ../src/wps/wps_dev_attr.o
308 OBJS += ../src/wps/wps_enrollee.o
309 OBJS += ../src/wps/wps_registrar.o
315 ifdef CONFIG_WPS_UPNP
316 CFLAGS += -DCONFIG_WPS_UPNP
317 OBJS += ../src/wps/wps_upnp.o
318 OBJS += ../src/wps/wps_upnp_ssdp.o
319 OBJS += ../src/wps/wps_upnp_web.o
320 OBJS += ../src/wps/wps_upnp_event.o
321 OBJS += ../src/wps/httpread.o
326 ifdef CONFIG_EAP_IKEV2
327 CFLAGS += -DEAP_IKEV2
328 OBJS += ../src/eap_server/eap_ikev2.o ../src/eap_server/ikev2.o
329 OBJS += ../src/eap_common/eap_ikev2_common.o ../src/eap_common/ikev2_common.o
335 OBJS += ../src/eap_server/eap_tnc.o
336 OBJS += ../src/eap_server/tncs.o
341 # Basic EAP functionality is needed for EAPOL
342 OBJS += ../src/eap_server/eap.o
343 OBJS += ../src/eap_common/eap_common.o
344 OBJS += ../src/eap_server/eap_methods.o
345 OBJS += ../src/eap_server/eap_identity.o
348 CFLAGS += -DEAP_SERVER
355 ifeq ($(CONFIG_TLS), internal)
357 CONFIG_CRYPTO=internal
360 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
361 CFLAGS += -DCONFIG_INTERNAL_X509
363 ifeq ($(CONFIG_CRYPTO), internal)
364 CFLAGS += -DCONFIG_INTERNAL_X509
369 # Shared TLS functions (needed for EAP_TLS, EAP_PEAP, and EAP_TTLS)
370 CFLAGS += -DEAP_TLS_FUNCS
371 OBJS += ../src/eap_server/eap_tls_common.o
373 ifeq ($(CONFIG_TLS), openssl)
374 OBJS += ../src/crypto/tls_openssl.o
375 LIBS += -lssl -lcrypto
379 ifeq ($(CONFIG_TLS), gnutls)
380 OBJS += ../src/crypto/tls_gnutls.o
381 LIBS += -lgnutls -lgcrypt -lgpg-error
385 ifdef CONFIG_GNUTLS_EXTRA
386 CFLAGS += -DCONFIG_GNUTLS_EXTRA
387 LIBS += -lgnutls-extra
389 ifeq ($(CONFIG_TLS), internal)
390 OBJS += ../src/crypto/tls_internal.o
391 OBJS += ../src/tls/tlsv1_common.o ../src/tls/tlsv1_record.o
392 OBJS += ../src/tls/tlsv1_cred.o ../src/tls/tlsv1_server.o
393 OBJS += ../src/tls/tlsv1_server_write.o ../src/tls/tlsv1_server_read.o
394 OBJS += ../src/tls/asn1.o ../src/tls/x509v3.o
395 OBJS_p += ../src/tls/asn1.o
396 OBJS_p += ../src/crypto/rc4.o ../src/crypto/aes_wrap.o ../src/crypto/aes.o
398 CFLAGS += -DCONFIG_TLS_INTERNAL
399 CFLAGS += -DCONFIG_TLS_INTERNAL_SERVER
400 ifeq ($(CONFIG_CRYPTO), internal)
401 ifdef CONFIG_INTERNAL_LIBTOMMATH
402 CFLAGS += -DCONFIG_INTERNAL_LIBTOMMATH
408 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
409 LIBS += -ltomcrypt -ltfm
410 LIBS_p += -ltomcrypt -ltfm
415 OBJS += ../src/crypto/tls_none.o
419 CFLAGS += -DPKCS12_FUNCS
423 OBJS += ../src/crypto/ms_funcs.o
428 OBJS += ../src/eap_common/chap.o
433 ifeq ($(CONFIG_TLS), openssl)
438 ifeq ($(CONFIG_TLS), gnutls)
443 ifeq ($(CONFIG_TLS), internal)
444 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
445 LIBS += -ltomcrypt -ltfm
446 LIBS_p += -ltomcrypt -ltfm
450 ifeq ($(CONFIG_TLS), openssl)
451 OBJS += ../src/crypto/crypto_openssl.o
452 OBJS_p += ../src/crypto/crypto_openssl.o
453 HOBJS += ../src/crypto/crypto_openssl.o
454 CONFIG_INTERNAL_SHA256=y
456 ifeq ($(CONFIG_TLS), gnutls)
457 OBJS += ../src/crypto/crypto_gnutls.o
458 OBJS_p += ../src/crypto/crypto_gnutls.o
459 HOBJS += ../src/crypto/crypto_gnutls.o
460 CONFIG_INTERNAL_SHA256=y
462 ifeq ($(CONFIG_TLS), internal)
463 ifeq ($(CONFIG_CRYPTO), libtomcrypt)
464 OBJS += ../src/crypto/crypto_libtomcrypt.o
465 OBJS_p += ../src/crypto/crypto_libtomcrypt.o
466 CONFIG_INTERNAL_SHA256=y
468 ifeq ($(CONFIG_CRYPTO), internal)
469 OBJS += ../src/crypto/crypto_internal.o ../src/tls/rsa.o ../src/tls/bignum.o
470 OBJS_p += ../src/crypto/crypto_internal.o ../src/tls/rsa.o ../src/tls/bignum.o
471 CFLAGS += -DCONFIG_CRYPTO_INTERNAL
472 CONFIG_INTERNAL_AES=y
473 CONFIG_INTERNAL_DES=y
474 CONFIG_INTERNAL_SHA1=y
475 CONFIG_INTERNAL_MD4=y
476 CONFIG_INTERNAL_MD5=y
477 CONFIG_INTERNAL_SHA256=y
481 CONFIG_INTERNAL_AES=y
482 CONFIG_INTERNAL_SHA1=y
483 CONFIG_INTERNAL_MD5=y
484 CONFIG_INTERNAL_SHA256=y
487 ifdef CONFIG_INTERNAL_AES
488 CFLAGS += -DINTERNAL_AES
490 ifdef CONFIG_INTERNAL_SHA1
491 CFLAGS += -DINTERNAL_SHA1
493 ifdef CONFIG_INTERNAL_SHA256
494 CFLAGS += -DINTERNAL_SHA256
496 ifdef CONFIG_INTERNAL_MD5
497 CFLAGS += -DINTERNAL_MD5
499 ifdef CONFIG_INTERNAL_MD4
500 CFLAGS += -DINTERNAL_MD4
502 ifdef CONFIG_INTERNAL_DES
503 CFLAGS += -DINTERNAL_DES
507 OBJS += ../src/crypto/sha256.o
511 OBJS += ../src/crypto/dh_groups.o
514 ifndef NEED_FIPS186_2_PRF
515 CFLAGS += -DCONFIG_NO_FIPS186_2_PRF
519 CFLAGS += -DCONFIG_NO_T_PRF
523 CFLAGS += -DCONFIG_NO_TLS_PRF
526 ifdef CONFIG_RADIUS_SERVER
527 CFLAGS += -DRADIUS_SERVER
528 OBJS += ../src/radius/radius_server.o
532 CFLAGS += -DCONFIG_IPV6
535 ifdef CONFIG_DRIVER_RADIUS_ACL
536 CFLAGS += -DCONFIG_DRIVER_RADIUS_ACL
539 ifdef CONFIG_FULL_DYNAMIC_VLAN
540 # define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
541 # and vlan interfaces for the vlan feature.
542 CFLAGS += -DCONFIG_FULL_DYNAMIC_VLAN
546 OBJS += ../src/utils/base64.o
550 OBJS += beacon.o wme.o ap_list.o ieee802_11.o
551 OBJS += hw_features.o
552 CFLAGS += -DNEED_MLME
555 ifdef CONFIG_NO_STDOUT_DEBUG
556 CFLAGS += -DCONFIG_NO_STDOUT_DEBUG
559 ifdef CONFIG_NO_AES_EXTRAS
560 CFLAGS += -DCONFIG_NO_AES_UNWRAP
561 CFLAGS += -DCONFIG_NO_AES_CTR -DCONFIG_NO_AES_OMAC1
562 CFLAGS += -DCONFIG_NO_AES_EAX -DCONFIG_NO_AES_CBC
563 CFLAGS += -DCONFIG_NO_AES_DECRYPT
564 CFLAGS += -DCONFIG_NO_AES_ENCRYPT_BLOCK
567 ALL=hostapd hostapd_cli
569 all: verify_config $(ALL)
572 @if [ ! -r .config ]; then \
573 echo 'Building hostapd requires a configuration file'; \
574 echo '(.config). See README for more instructions. You can'; \
575 echo 'run "cp defconfig .config" to create an example'; \
576 echo 'configuration.'; \
581 for i in $(ALL); do cp $$i /usr/local/bin/$$i; done
584 $(CC) -o hostapd $(OBJS) $(LIBS)
586 OBJS_c = hostapd_cli.o ../src/common/wpa_ctrl.o ../src/utils/os_$(CONFIG_OS).o
587 hostapd_cli: $(OBJS_c)
588 $(CC) -o hostapd_cli $(OBJS_c)
590 NOBJS = nt_password_hash.o ../src/crypto/ms_funcs.o ../src/crypto/sha1.o ../src/crypto/rc4.o ../src/crypto/md5.o
591 NOBJS += ../src/crypto/crypto_openssl.o ../src/utils/os_$(CONFIG_OS).o
596 nt_password_hash: $(NOBJS)
597 $(CC) -o nt_password_hash $(NOBJS) $(LIBS_n)
600 $(CC) -o hlr_auc_gw $(HOBJS) $(LIBS_h)
603 $(MAKE) -C ../src clean
604 rm -f core *~ *.o hostapd hostapd_cli nt_password_hash hlr_auc_gw
608 fig2dev -L eps $*.fig $*.eps
611 fig2dev -L png -m 3 $*.fig | pngtopnm | pnmscale 0.4 | pnmtopng \
614 docs-pics: doc/hostapd.png doc/hostapd.eps
617 (cd ..; doxygen hostapd/doc/doxygen.full; cd hostapd)
619 cp doc/latex/refman.pdf hostapd-devel.pdf
622 (cd ..; doxygen hostapd/doc/doxygen.fast; cd hostapd)
625 rm -rf doc/latex doc/html
626 rm -f doc/hostapd.{eps,png} hostapd-devel.pdf
628 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
629 test-milenage: $(TEST_SRC_MILENAGE)
630 $(CC) -o test-milenage -Wall -Werror $(TEST_SRC_MILENAGE) \
631 -DTEST_MAIN_MILENAGE -I. -DINTERNAL_AES \
632 -I../src/crypto -I../src/utils
636 -include $(OBJS:%.o=%.d)