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 ieee802_11.o config.o ieee802_11_auth.o accounting.o \
43 sta_info.o wpa.o ctrl_iface.o \
44 drivers.o preauth.o pmksa_cache.o beacon.o \
45 hw_features.o wme.o ap_list.o \
46 mlme.o vlan_init.o wpa_auth_ie.o
48 OBJS
+= ..
/src
/utils
/eloop.o
49 OBJS
+= ..
/src
/utils
/common.o
50 OBJS
+= ..
/src
/utils
/wpa_debug.o
51 OBJS
+= ..
/src
/utils
/wpabuf.o
52 OBJS
+= ..
/src
/utils
/os_
$(CONFIG_OS
).o
53 OBJS
+= ..
/src
/utils
/ip_addr.o
55 OBJS
+= ..
/src
/common
/ieee802_11_common.o
56 OBJS
+= ..
/src
/common
/wpa_common.o
58 OBJS
+= ..
/src
/radius
/radius.o
59 OBJS
+= ..
/src
/radius
/radius_client.o
61 OBJS
+= ..
/src
/crypto
/md5.o
62 OBJS
+= ..
/src
/crypto
/rc4.o
63 OBJS
+= ..
/src
/crypto
/md4.o
64 OBJS
+= ..
/src
/crypto
/sha1.o
65 OBJS
+= ..
/src
/crypto
/des.o
66 OBJS
+= ..
/src
/crypto
/aes_wrap.o
67 OBJS
+= ..
/src
/crypto
/aes.o
69 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
71 CFLAGS
+= -DCONFIG_CTRL_IFACE
-DCONFIG_CTRL_IFACE_UNIX
74 CFLAGS
+= -DCONFIG_IAPP
78 ifdef CONFIG_RSN_PREAUTH
79 CFLAGS
+= -DCONFIG_RSN_PREAUTH
84 CFLAGS
+= -DCONFIG_PEERKEY
88 ifdef CONFIG_IEEE80211W
89 CFLAGS
+= -DCONFIG_IEEE80211W
93 ifdef CONFIG_IEEE80211R
94 CFLAGS
+= -DCONFIG_IEEE80211R
99 ifdef CONFIG_IEEE80211N
100 CFLAGS
+= -DCONFIG_IEEE80211N
103 ifdef CONFIG_DRIVER_HOSTAP
104 CFLAGS
+= -DCONFIG_DRIVER_HOSTAP
105 OBJS
+= driver_hostap.o
108 ifdef CONFIG_DRIVER_WIRED
109 CFLAGS
+= -DCONFIG_DRIVER_WIRED
110 OBJS
+= driver_wired.o
113 ifdef CONFIG_DRIVER_MADWIFI
114 CFLAGS
+= -DCONFIG_DRIVER_MADWIFI
115 OBJS
+= driver_madwifi.o
119 ifdef CONFIG_DRIVER_PRISM54
120 CFLAGS
+= -DCONFIG_DRIVER_PRISM54
121 OBJS
+= driver_prism54.o
124 ifdef CONFIG_DRIVER_NL80211
125 CFLAGS
+= -DCONFIG_DRIVER_NL80211
126 OBJS
+= driver_nl80211.o radiotap.o
130 ifdef CONFIG_DRIVER_BSD
131 CFLAGS
+= -DCONFIG_DRIVER_BSD
138 ifdef CONFIG_DRIVER_TEST
139 CFLAGS
+= -DCONFIG_DRIVER_TEST
140 OBJS
+= driver_test.o
143 ifdef CONFIG_DRIVER_NONE
144 CFLAGS
+= -DCONFIG_DRIVER_NONE
145 OBJS
+= driver_none.o
148 ifdef CONFIG_L2_PACKET
149 ifdef CONFIG_DNET_PCAP
150 ifdef CONFIG_L2_FREEBSD
152 OBJS
+= ..
/src
/l2_packet
/l2_packet_freebsd.o
154 LIBS
+= -ldnet
-lpcap
155 OBJS
+= ..
/src
/l2_packet
/l2_packet_pcap.o
158 OBJS
+= ..
/src
/l2_packet
/l2_packet_linux.o
161 OBJS
+= ..
/src
/l2_packet
/l2_packet_none.o
167 OBJS
+= ..
/src
/eap_server
/eap_md5.o
173 OBJS
+= ..
/src
/eap_server
/eap_tls.o
177 ifdef CONFIG_EAP_PEAP
179 OBJS
+= ..
/src
/eap_server
/eap_peap.o
180 OBJS
+= ..
/src
/eap_common
/eap_peap_common.o
182 CONFIG_EAP_MSCHAPV2
=y
185 ifdef CONFIG_EAP_TTLS
187 OBJS
+= ..
/src
/eap_server
/eap_ttls.o
192 ifdef CONFIG_EAP_MSCHAPV2
193 CFLAGS
+= -DEAP_MSCHAPv2
194 OBJS
+= ..
/src
/eap_server
/eap_mschapv2.o
200 OBJS
+= ..
/src
/eap_server
/eap_gtc.o
205 OBJS
+= ..
/src
/eap_server
/eap_sim.o
206 CONFIG_EAP_SIM_COMMON
=y
211 OBJS
+= ..
/src
/eap_server
/eap_aka.o
212 CONFIG_EAP_SIM_COMMON
=y
215 ifdef CONFIG_EAP_AKA_PRIME
216 CFLAGS
+= -DEAP_AKA_PRIME
217 OBJS
+= ..
/src
/eap_server
/eap_aka_prime.o
218 CONFIG_EAP_SIM_COMMON
=y
221 ifdef CONFIG_EAP_SIM_COMMON
222 OBJS
+= ..
/src
/eap_common
/eap_sim_common.o
223 # Example EAP-SIM/AKA interface for GSM/UMTS authentication. This can be
224 # replaced with another file implementating the interface specified in
226 OBJS
+= ..
/src
/eap_server
/eap_sim_db.o
232 OBJS
+= ..
/src
/eap_server
/eap_pax.o ..
/src
/eap_common
/eap_pax_common.o
237 OBJS
+= ..
/src
/eap_server
/eap_psk.o ..
/src
/eap_common
/eap_psk_common.o
240 ifdef CONFIG_EAP_SAKE
242 OBJS
+= ..
/src
/eap_server
/eap_sake.o ..
/src
/eap_common
/eap_sake_common.o
245 ifdef CONFIG_EAP_GPSK
247 OBJS
+= ..
/src
/eap_server
/eap_gpsk.o ..
/src
/eap_common
/eap_gpsk_common.o
248 ifdef CONFIG_EAP_GPSK_SHA256
249 CFLAGS
+= -DEAP_GPSK_SHA256
254 ifdef CONFIG_EAP_VENDOR_TEST
255 CFLAGS
+= -DEAP_VENDOR_TEST
256 OBJS
+= ..
/src
/eap_server
/eap_vendor_test.o
259 ifdef CONFIG_EAP_FAST
261 OBJS
+= ..
/src
/eap_server
/eap_fast.o
262 OBJS
+= ..
/src
/eap_common
/eap_fast_common.o
268 CFLAGS
+= -DCONFIG_WPS
-DEAP_WSC
269 OBJS
+= ..
/src
/utils
/uuid.o
270 OBJS
+= wps_hostapd.o
271 OBJS
+= ..
/src
/eap_server
/eap_wsc.o ..
/src
/eap_common
/eap_wsc_common.o
272 OBJS
+= ..
/src
/wps
/wps.o
273 OBJS
+= ..
/src
/wps
/wps_common.o
274 OBJS
+= ..
/src
/wps
/wps_attr_parse.o
275 OBJS
+= ..
/src
/wps
/wps_attr_build.o
276 OBJS
+= ..
/src
/wps
/wps_attr_process.o
277 OBJS
+= ..
/src
/wps
/wps_dev_attr.o
278 OBJS
+= ..
/src
/wps
/wps_enrollee.o
279 OBJS
+= ..
/src
/wps
/wps_registrar.o
285 ifdef CONFIG_EAP_IKEV2
286 CFLAGS
+= -DEAP_IKEV2
287 OBJS
+= ..
/src
/eap_server
/eap_ikev2.o ..
/src
/eap_server
/ikev2.o
288 OBJS
+= ..
/src
/eap_common
/eap_ikev2_common.o ..
/src
/eap_common
/ikev2_common.o
294 OBJS
+= ..
/src
/eap_server
/eap_tnc.o
295 OBJS
+= ..
/src
/eap_server
/tncs.o
299 # Basic EAP functionality is needed for EAPOL
300 OBJS
+= ..
/src
/eap_server
/eap.o
301 OBJS
+= ..
/src
/eap_common
/eap_common.o
302 OBJS
+= ..
/src
/eap_server
/eap_methods.o
303 OBJS
+= ..
/src
/eap_server
/eap_identity.o
306 CFLAGS
+= -DEAP_SERVER
313 ifeq ($(CONFIG_TLS
), internal
)
315 CONFIG_CRYPTO
=internal
318 ifeq ($(CONFIG_CRYPTO
), libtomcrypt
)
319 CFLAGS
+= -DCONFIG_INTERNAL_X509
321 ifeq ($(CONFIG_CRYPTO
), internal
)
322 CFLAGS
+= -DCONFIG_INTERNAL_X509
327 # Shared TLS functions (needed for EAP_TLS, EAP_PEAP, and EAP_TTLS)
328 CFLAGS
+= -DEAP_TLS_FUNCS
329 OBJS
+= ..
/src
/eap_server
/eap_tls_common.o
330 ifeq ($(CONFIG_TLS
), openssl
)
331 OBJS
+= ..
/src
/crypto
/tls_openssl.o
332 LIBS
+= -lssl
-lcrypto
336 ifeq ($(CONFIG_TLS
), gnutls
)
337 OBJS
+= ..
/src
/crypto
/tls_gnutls.o
338 LIBS
+= -lgnutls
-lgcrypt
-lgpg-error
342 ifdef CONFIG_GNUTLS_EXTRA
343 CFLAGS
+= -DCONFIG_GNUTLS_EXTRA
344 LIBS
+= -lgnutls-extra
346 ifeq ($(CONFIG_TLS
), internal
)
347 OBJS
+= ..
/src
/crypto
/tls_internal.o
348 OBJS
+= ..
/src
/tls
/tlsv1_common.o ..
/src
/tls
/tlsv1_record.o
349 OBJS
+= ..
/src
/tls
/tlsv1_cred.o ..
/src
/tls
/tlsv1_server.o
350 OBJS
+= ..
/src
/tls
/tlsv1_server_write.o ..
/src
/tls
/tlsv1_server_read.o
351 OBJS
+= ..
/src
/tls
/asn1.o ..
/src
/tls
/x509v3.o
352 OBJS_p
+= ..
/src
/tls
/asn1.o
353 OBJS_p
+= ..
/src
/crypto
/rc4.o ..
/src
/crypto
/aes_wrap.o ..
/src
/crypto
/aes.o
355 CFLAGS
+= -DCONFIG_TLS_INTERNAL
356 CFLAGS
+= -DCONFIG_TLS_INTERNAL_SERVER
357 ifeq ($(CONFIG_CRYPTO
), internal
)
358 ifdef CONFIG_INTERNAL_LIBTOMMATH
359 CFLAGS
+= -DCONFIG_INTERNAL_LIBTOMMATH
365 ifeq ($(CONFIG_CRYPTO
), libtomcrypt
)
366 LIBS
+= -ltomcrypt
-ltfm
367 LIBS_p
+= -ltomcrypt
-ltfm
372 OBJS
+= ..
/src
/crypto
/tls_none.o
376 CFLAGS
+= -DPKCS12_FUNCS
380 OBJS
+= ..
/src
/crypto
/ms_funcs.o
385 OBJS
+= ..
/src
/eap_common
/chap.o
390 ifeq ($(CONFIG_TLS
), openssl
)
395 ifeq ($(CONFIG_TLS
), gnutls
)
400 ifeq ($(CONFIG_TLS
), internal
)
401 ifeq ($(CONFIG_CRYPTO
), libtomcrypt
)
402 LIBS
+= -ltomcrypt
-ltfm
403 LIBS_p
+= -ltomcrypt
-ltfm
407 ifeq ($(CONFIG_TLS
), openssl
)
408 OBJS
+= ..
/src
/crypto
/crypto_openssl.o
409 OBJS_p
+= ..
/src
/crypto
/crypto_openssl.o
410 HOBJS
+= ..
/src
/crypto
/crypto_openssl.o
411 CONFIG_INTERNAL_SHA256
=y
413 ifeq ($(CONFIG_TLS
), gnutls
)
414 OBJS
+= ..
/src
/crypto
/crypto_gnutls.o
415 OBJS_p
+= ..
/src
/crypto
/crypto_gnutls.o
416 HOBJS
+= ..
/src
/crypto
/crypto_gnutls.o
417 CONFIG_INTERNAL_SHA256
=y
419 ifeq ($(CONFIG_TLS
), internal
)
420 ifeq ($(CONFIG_CRYPTO
), libtomcrypt
)
421 OBJS
+= ..
/src
/crypto
/crypto_libtomcrypt.o
422 OBJS_p
+= ..
/src
/crypto
/crypto_libtomcrypt.o
423 CONFIG_INTERNAL_SHA256
=y
425 ifeq ($(CONFIG_CRYPTO
), internal
)
426 OBJS
+= ..
/src
/crypto
/crypto_internal.o ..
/src
/tls
/rsa.o ..
/src
/tls
/bignum.o
427 OBJS_p
+= ..
/src
/crypto
/crypto_internal.o ..
/src
/tls
/rsa.o ..
/src
/tls
/bignum.o
428 CFLAGS
+= -DCONFIG_CRYPTO_INTERNAL
429 CONFIG_INTERNAL_AES
=y
430 CONFIG_INTERNAL_DES
=y
431 CONFIG_INTERNAL_SHA1
=y
432 CONFIG_INTERNAL_MD4
=y
433 CONFIG_INTERNAL_MD5
=y
434 CONFIG_INTERNAL_SHA256
=y
438 CONFIG_INTERNAL_AES
=y
439 CONFIG_INTERNAL_SHA1
=y
440 CONFIG_INTERNAL_MD5
=y
441 CONFIG_INTERNAL_SHA256
=y
444 ifdef CONFIG_INTERNAL_AES
445 CFLAGS
+= -DINTERNAL_AES
447 ifdef CONFIG_INTERNAL_SHA1
448 CFLAGS
+= -DINTERNAL_SHA1
450 ifdef CONFIG_INTERNAL_SHA256
451 CFLAGS
+= -DINTERNAL_SHA256
453 ifdef CONFIG_INTERNAL_MD5
454 CFLAGS
+= -DINTERNAL_MD5
456 ifdef CONFIG_INTERNAL_MD4
457 CFLAGS
+= -DINTERNAL_MD4
459 ifdef CONFIG_INTERNAL_DES
460 CFLAGS
+= -DINTERNAL_DES
464 OBJS
+= ..
/src
/crypto
/sha256.o
468 OBJS
+= ..
/src
/crypto
/dh_groups.o
471 ifndef NEED_FIPS186_2_PRF
472 CFLAGS
+= -DCONFIG_NO_FIPS186_2_PRF
476 CFLAGS
+= -DCONFIG_NO_T_PRF
479 ifdef CONFIG_RADIUS_SERVER
480 CFLAGS
+= -DRADIUS_SERVER
481 OBJS
+= ..
/src
/radius
/radius_server.o
485 CFLAGS
+= -DCONFIG_IPV6
488 ifdef CONFIG_DRIVER_RADIUS_ACL
489 CFLAGS
+= -DCONFIG_DRIVER_RADIUS_ACL
492 ifdef CONFIG_FULL_DYNAMIC_VLAN
493 # define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
494 # and vlan interfaces for the vlan feature.
495 CFLAGS
+= -DCONFIG_FULL_DYNAMIC_VLAN
499 OBJS
+= ..
/src
/utils
/base64.o
502 ALL
=hostapd hostapd_cli
504 all: verify_config
$(ALL
)
507 @if
[ ! -r .config
]; then \
508 echo
'Building hostapd requires a configuration file'; \
509 echo
'(.config). See README for more instructions. You can'; \
510 echo
'run "cp defconfig .config" to create an example'; \
511 echo
'configuration.'; \
516 for i in
$(ALL
); do cp
$$i /usr
/local
/bin
/$$i; done
519 $(CC
) -o hostapd
$(OBJS
) $(LIBS
)
521 OBJS_c
= hostapd_cli.o ..
/src
/common
/wpa_ctrl.o ..
/src
/utils
/os_
$(CONFIG_OS
).o
522 hostapd_cli
: $(OBJS_c
)
523 $(CC
) -o hostapd_cli
$(OBJS_c
)
525 NOBJS
= nt_password_hash.o ..
/src
/crypto
/ms_funcs.o ..
/src
/crypto
/sha1.o ..
/src
/crypto
/rc4.o ..
/src
/crypto
/md5.o
526 NOBJS
+= ..
/src
/crypto
/crypto_openssl.o ..
/src
/utils
/os_
$(CONFIG_OS
).o
531 nt_password_hash
: $(NOBJS
)
532 $(CC
) -o nt_password_hash
$(NOBJS
) $(LIBS_n
)
535 $(CC
) -o hlr_auc_gw
$(HOBJS
) $(LIBS_h
)
538 $(MAKE
) -C ..
/src
clean
539 rm -f core
*~
*.o hostapd hostapd_cli nt_password_hash hlr_auc_gw
543 fig2dev
-L eps
$*.fig
$*.eps
546 fig2dev
-L png
-m
3 $*.fig | pngtopnm | pnmscale
0.4 | pnmtopng \
549 docs-pics
: doc
/hostapd.png doc
/hostapd.eps
552 doxygen doc
/doxygen.full
554 cp doc
/latex
/refman.pdf hostapd-devel.pdf
557 doxygen doc
/doxygen.fast
560 rm -rf doc
/latex doc
/html
561 rm -f doc
/hosta.d
{eps
,png
} hostapd-devel.pdf
563 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
564 test-milenage
: $(TEST_SRC_MILENAGE
)
565 $(CC
) -o test-milenage
-Wall
-Werror
$(TEST_SRC_MILENAGE
) \
566 -DTEST_MAIN_MILENAGE
-I.
-DINTERNAL_AES \
567 -I..
/src
/crypto
-I..
/src
/utils
571 hostapd-sparse
: $(OBJS
)
572 @echo Sparse run completed
575 CC
="sparse -D__linux__ -Dlinux -D__STDC__ -Dunix -D__unix__ -D__INT_MAX__=2147483647 -D__SHRT_MAX__=32767 -D__LONG_MAX__=2147483647 -D__SCHAR_MAX__=127 -Wbitwise" $(MAKE
) hostapd-sparse
577 -include $(OBJS
:%.o
=%.d
)