Makefile 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575
  1. ifndef CC
  2. CC=gcc
  3. endif
  4. ifndef CFLAGS
  5. CFLAGS = -MMD -O2 -Wall -g
  6. endif
  7. # define HOSTAPD_DUMP_STATE to include SIGUSR1 handler for dumping state to
  8. # a file (undefine it, if you want to save in binary size)
  9. CFLAGS += -DHOSTAPD_DUMP_STATE
  10. CFLAGS += -I../src
  11. CFLAGS += -I../src/crypto
  12. CFLAGS += -I../src/utils
  13. CFLAGS += -I../src/common
  14. # Uncomment following line and set the path to your kernel tree include
  15. # directory if your C library does not include all header files.
  16. # CFLAGS += -DUSE_KERNEL_HEADERS -I/usr/src/linux/include
  17. -include .config
  18. ifndef CONFIG_OS
  19. ifdef CONFIG_NATIVE_WINDOWS
  20. CONFIG_OS=win32
  21. else
  22. CONFIG_OS=unix
  23. endif
  24. endif
  25. ifeq ($(CONFIG_OS), internal)
  26. CFLAGS += -DOS_NO_C_LIB_DEFINES
  27. endif
  28. ifdef CONFIG_NATIVE_WINDOWS
  29. CFLAGS += -DCONFIG_NATIVE_WINDOWS
  30. LIBS += -lws2_32
  31. endif
  32. OBJS = hostapd.o ieee802_1x.o eapol_sm.o \
  33. ieee802_11.o config.o ieee802_11_auth.o accounting.o \
  34. sta_info.o wpa.o ctrl_iface.o \
  35. drivers.o preauth.o pmksa_cache.o beacon.o \
  36. hw_features.o wme.o ap_list.o \
  37. mlme.o vlan_init.o wpa_auth_ie.o
  38. OBJS += ../src/utils/eloop.o
  39. OBJS += ../src/utils/common.o
  40. OBJS += ../src/utils/wpa_debug.o
  41. OBJS += ../src/utils/wpabuf.o
  42. OBJS += ../src/utils/os_$(CONFIG_OS).o
  43. OBJS += ../src/utils/ip_addr.o
  44. OBJS += ../src/common/ieee802_11_common.o
  45. OBJS += ../src/common/wpa_common.o
  46. OBJS += ../src/radius/radius.o
  47. OBJS += ../src/radius/radius_client.o
  48. OBJS += ../src/crypto/md5.o
  49. OBJS += ../src/crypto/rc4.o
  50. OBJS += ../src/crypto/md4.o
  51. OBJS += ../src/crypto/sha1.o
  52. OBJS += ../src/crypto/des.o
  53. OBJS += ../src/crypto/aes_wrap.o
  54. OBJS += ../src/crypto/aes.o
  55. 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
  56. CFLAGS += -DCONFIG_CTRL_IFACE -DCONFIG_CTRL_IFACE_UNIX
  57. ifdef CONFIG_IAPP
  58. CFLAGS += -DCONFIG_IAPP
  59. OBJS += iapp.o
  60. endif
  61. ifdef CONFIG_RSN_PREAUTH
  62. CFLAGS += -DCONFIG_RSN_PREAUTH
  63. CONFIG_L2_PACKET=y
  64. endif
  65. ifdef CONFIG_PEERKEY
  66. CFLAGS += -DCONFIG_PEERKEY
  67. OBJS += peerkey.o
  68. endif
  69. ifdef CONFIG_IEEE80211W
  70. CFLAGS += -DCONFIG_IEEE80211W
  71. NEED_SHA256=y
  72. endif
  73. ifdef CONFIG_IEEE80211R
  74. CFLAGS += -DCONFIG_IEEE80211R
  75. OBJS += wpa_ft.o
  76. NEED_SHA256=y
  77. endif
  78. ifdef CONFIG_IEEE80211N
  79. CFLAGS += -DCONFIG_IEEE80211N
  80. endif
  81. ifdef CONFIG_DRIVER_HOSTAP
  82. CFLAGS += -DCONFIG_DRIVER_HOSTAP
  83. OBJS += driver_hostap.o
  84. endif
  85. ifdef CONFIG_DRIVER_WIRED
  86. CFLAGS += -DCONFIG_DRIVER_WIRED
  87. OBJS += driver_wired.o
  88. endif
  89. ifdef CONFIG_DRIVER_MADWIFI
  90. CFLAGS += -DCONFIG_DRIVER_MADWIFI
  91. OBJS += driver_madwifi.o
  92. CONFIG_L2_PACKET=y
  93. endif
  94. ifdef CONFIG_DRIVER_PRISM54
  95. CFLAGS += -DCONFIG_DRIVER_PRISM54
  96. OBJS += driver_prism54.o
  97. endif
  98. ifdef CONFIG_DRIVER_NL80211
  99. CFLAGS += -DCONFIG_DRIVER_NL80211
  100. OBJS += driver_nl80211.o radiotap.o
  101. LIBS += -lnl
  102. endif
  103. ifdef CONFIG_DRIVER_BSD
  104. CFLAGS += -DCONFIG_DRIVER_BSD
  105. OBJS += driver_bsd.o
  106. CONFIG_L2_PACKET=y
  107. CONFIG_DNET_PCAP=y
  108. CONFIG_L2_FREEBSD=y
  109. endif
  110. ifdef CONFIG_DRIVER_TEST
  111. CFLAGS += -DCONFIG_DRIVER_TEST
  112. OBJS += driver_test.o
  113. endif
  114. ifdef CONFIG_DRIVER_NONE
  115. CFLAGS += -DCONFIG_DRIVER_NONE
  116. OBJS += driver_none.o
  117. endif
  118. ifdef CONFIG_L2_PACKET
  119. ifdef CONFIG_DNET_PCAP
  120. ifdef CONFIG_L2_FREEBSD
  121. LIBS += -lpcap
  122. OBJS += ../src/l2_packet/l2_packet_freebsd.o
  123. else
  124. LIBS += -ldnet -lpcap
  125. OBJS += ../src/l2_packet/l2_packet_pcap.o
  126. endif
  127. else
  128. OBJS += ../src/l2_packet/l2_packet_linux.o
  129. endif
  130. else
  131. OBJS += ../src/l2_packet/l2_packet_none.o
  132. endif
  133. ifdef CONFIG_EAP_MD5
  134. CFLAGS += -DEAP_MD5
  135. OBJS += ../src/eap_server/eap_md5.o
  136. CHAP=y
  137. endif
  138. ifdef CONFIG_EAP_TLS
  139. CFLAGS += -DEAP_TLS
  140. OBJS += ../src/eap_server/eap_tls.o
  141. TLS_FUNCS=y
  142. endif
  143. ifdef CONFIG_EAP_PEAP
  144. CFLAGS += -DEAP_PEAP
  145. OBJS += ../src/eap_server/eap_peap.o
  146. OBJS += ../src/eap_common/eap_peap_common.o
  147. TLS_FUNCS=y
  148. CONFIG_EAP_MSCHAPV2=y
  149. endif
  150. ifdef CONFIG_EAP_TTLS
  151. CFLAGS += -DEAP_TTLS
  152. OBJS += ../src/eap_server/eap_ttls.o
  153. TLS_FUNCS=y
  154. CHAP=y
  155. endif
  156. ifdef CONFIG_EAP_MSCHAPV2
  157. CFLAGS += -DEAP_MSCHAPv2
  158. OBJS += ../src/eap_server/eap_mschapv2.o
  159. MS_FUNCS=y
  160. endif
  161. ifdef CONFIG_EAP_GTC
  162. CFLAGS += -DEAP_GTC
  163. OBJS += ../src/eap_server/eap_gtc.o
  164. endif
  165. ifdef CONFIG_EAP_SIM
  166. CFLAGS += -DEAP_SIM
  167. OBJS += ../src/eap_server/eap_sim.o
  168. CONFIG_EAP_SIM_COMMON=y
  169. endif
  170. ifdef CONFIG_EAP_AKA
  171. CFLAGS += -DEAP_AKA
  172. OBJS += ../src/eap_server/eap_aka.o
  173. CONFIG_EAP_SIM_COMMON=y
  174. endif
  175. ifdef CONFIG_EAP_AKA_PRIME
  176. CFLAGS += -DEAP_AKA_PRIME
  177. endif
  178. ifdef CONFIG_EAP_SIM_COMMON
  179. OBJS += ../src/eap_common/eap_sim_common.o
  180. # Example EAP-SIM/AKA interface for GSM/UMTS authentication. This can be
  181. # replaced with another file implementating the interface specified in
  182. # eap_sim_db.h.
  183. OBJS += ../src/eap_server/eap_sim_db.o
  184. NEED_FIPS186_2_PRF=y
  185. endif
  186. ifdef CONFIG_EAP_PAX
  187. CFLAGS += -DEAP_PAX
  188. OBJS += ../src/eap_server/eap_pax.o ../src/eap_common/eap_pax_common.o
  189. endif
  190. ifdef CONFIG_EAP_PSK
  191. CFLAGS += -DEAP_PSK
  192. OBJS += ../src/eap_server/eap_psk.o ../src/eap_common/eap_psk_common.o
  193. endif
  194. ifdef CONFIG_EAP_SAKE
  195. CFLAGS += -DEAP_SAKE
  196. OBJS += ../src/eap_server/eap_sake.o ../src/eap_common/eap_sake_common.o
  197. endif
  198. ifdef CONFIG_EAP_GPSK
  199. CFLAGS += -DEAP_GPSK
  200. OBJS += ../src/eap_server/eap_gpsk.o ../src/eap_common/eap_gpsk_common.o
  201. ifdef CONFIG_EAP_GPSK_SHA256
  202. CFLAGS += -DEAP_GPSK_SHA256
  203. endif
  204. NEED_SHA256=y
  205. endif
  206. ifdef CONFIG_EAP_VENDOR_TEST
  207. CFLAGS += -DEAP_VENDOR_TEST
  208. OBJS += ../src/eap_server/eap_vendor_test.o
  209. endif
  210. ifdef CONFIG_EAP_FAST
  211. CFLAGS += -DEAP_FAST
  212. OBJS += ../src/eap_server/eap_fast.o
  213. OBJS += ../src/eap_common/eap_fast_common.o
  214. TLS_FUNCS=y
  215. NEED_T_PRF=y
  216. endif
  217. ifdef CONFIG_WPS
  218. CFLAGS += -DCONFIG_WPS -DEAP_WSC
  219. OBJS += ../src/utils/uuid.o
  220. OBJS += wps_hostapd.o
  221. OBJS += ../src/eap_server/eap_wsc.o ../src/eap_common/eap_wsc_common.o
  222. OBJS += ../src/wps/wps.o
  223. OBJS += ../src/wps/wps_common.o
  224. OBJS += ../src/wps/wps_attr_parse.o
  225. OBJS += ../src/wps/wps_attr_build.o
  226. OBJS += ../src/wps/wps_attr_process.o
  227. OBJS += ../src/wps/wps_dev_attr.o
  228. OBJS += ../src/wps/wps_enrollee.o
  229. OBJS += ../src/wps/wps_registrar.o
  230. NEED_DH_GROUPS=y
  231. NEED_SHA256=y
  232. NEED_CRYPTO=y
  233. endif
  234. ifdef CONFIG_EAP_IKEV2
  235. CFLAGS += -DEAP_IKEV2
  236. OBJS += ../src/eap_server/eap_ikev2.o ../src/eap_server/ikev2.o
  237. OBJS += ../src/eap_common/eap_ikev2_common.o ../src/eap_common/ikev2_common.o
  238. NEED_DH_GROUPS=y
  239. endif
  240. ifdef CONFIG_EAP_TNC
  241. CFLAGS += -DEAP_TNC
  242. OBJS += ../src/eap_server/eap_tnc.o
  243. OBJS += ../src/eap_server/tncs.o
  244. NEED_BASE64=y
  245. endif
  246. # Basic EAP functionality is needed for EAPOL
  247. OBJS += ../src/eap_server/eap.o
  248. OBJS += ../src/eap_common/eap_common.o
  249. OBJS += ../src/eap_server/eap_methods.o
  250. OBJS += ../src/eap_server/eap_identity.o
  251. ifdef CONFIG_EAP
  252. CFLAGS += -DEAP_SERVER
  253. endif
  254. ifndef CONFIG_TLS
  255. CONFIG_TLS=openssl
  256. endif
  257. ifeq ($(CONFIG_TLS), internal)
  258. ifndef CONFIG_CRYPTO
  259. CONFIG_CRYPTO=internal
  260. endif
  261. endif
  262. ifeq ($(CONFIG_CRYPTO), libtomcrypt)
  263. CFLAGS += -DCONFIG_INTERNAL_X509
  264. endif
  265. ifeq ($(CONFIG_CRYPTO), internal)
  266. CFLAGS += -DCONFIG_INTERNAL_X509
  267. endif
  268. ifdef TLS_FUNCS
  269. # Shared TLS functions (needed for EAP_TLS, EAP_PEAP, and EAP_TTLS)
  270. CFLAGS += -DEAP_TLS_FUNCS
  271. OBJS += ../src/eap_server/eap_tls_common.o
  272. ifeq ($(CONFIG_TLS), openssl)
  273. OBJS += ../src/crypto/tls_openssl.o
  274. LIBS += -lssl -lcrypto
  275. LIBS_p += -lcrypto
  276. LIBS_h += -lcrypto
  277. endif
  278. ifeq ($(CONFIG_TLS), gnutls)
  279. OBJS += ../src/crypto/tls_gnutls.o
  280. LIBS += -lgnutls -lgcrypt -lgpg-error
  281. LIBS_p += -lgcrypt
  282. LIBS_h += -lgcrypt
  283. endif
  284. ifdef CONFIG_GNUTLS_EXTRA
  285. CFLAGS += -DCONFIG_GNUTLS_EXTRA
  286. LIBS += -lgnutls-extra
  287. endif
  288. ifeq ($(CONFIG_TLS), internal)
  289. OBJS += ../src/crypto/tls_internal.o
  290. OBJS += ../src/tls/tlsv1_common.o ../src/tls/tlsv1_record.o
  291. OBJS += ../src/tls/tlsv1_cred.o ../src/tls/tlsv1_server.o
  292. OBJS += ../src/tls/tlsv1_server_write.o ../src/tls/tlsv1_server_read.o
  293. OBJS += ../src/tls/asn1.o ../src/tls/x509v3.o
  294. OBJS_p += ../src/tls/asn1.o
  295. OBJS_p += ../src/crypto/rc4.o ../src/crypto/aes_wrap.o ../src/crypto/aes.o
  296. NEED_BASE64=y
  297. CFLAGS += -DCONFIG_TLS_INTERNAL
  298. CFLAGS += -DCONFIG_TLS_INTERNAL_SERVER
  299. ifeq ($(CONFIG_CRYPTO), internal)
  300. ifdef CONFIG_INTERNAL_LIBTOMMATH
  301. CFLAGS += -DCONFIG_INTERNAL_LIBTOMMATH
  302. else
  303. LIBS += -ltommath
  304. LIBS_p += -ltommath
  305. endif
  306. endif
  307. ifeq ($(CONFIG_CRYPTO), libtomcrypt)
  308. LIBS += -ltomcrypt -ltfm
  309. LIBS_p += -ltomcrypt -ltfm
  310. endif
  311. endif
  312. NEED_CRYPTO=y
  313. else
  314. OBJS += ../src/crypto/tls_none.o
  315. endif
  316. ifdef CONFIG_PKCS12
  317. CFLAGS += -DPKCS12_FUNCS
  318. endif
  319. ifdef MS_FUNCS
  320. OBJS += ../src/crypto/ms_funcs.o
  321. NEED_CRYPTO=y
  322. endif
  323. ifdef CHAP
  324. OBJS += ../src/eap_common/chap.o
  325. endif
  326. ifdef NEED_CRYPTO
  327. ifndef TLS_FUNCS
  328. ifeq ($(CONFIG_TLS), openssl)
  329. LIBS += -lcrypto
  330. LIBS_p += -lcrypto
  331. LIBS_h += -lcrypto
  332. endif
  333. ifeq ($(CONFIG_TLS), gnutls)
  334. LIBS += -lgcrypt
  335. LIBS_p += -lgcrypt
  336. LIBS_h += -lgcrypt
  337. endif
  338. ifeq ($(CONFIG_TLS), internal)
  339. ifeq ($(CONFIG_CRYPTO), libtomcrypt)
  340. LIBS += -ltomcrypt -ltfm
  341. LIBS_p += -ltomcrypt -ltfm
  342. endif
  343. endif
  344. endif
  345. ifeq ($(CONFIG_TLS), openssl)
  346. OBJS += ../src/crypto/crypto_openssl.o
  347. OBJS_p += ../src/crypto/crypto_openssl.o
  348. HOBJS += ../src/crypto/crypto_openssl.o
  349. CONFIG_INTERNAL_SHA256=y
  350. endif
  351. ifeq ($(CONFIG_TLS), gnutls)
  352. OBJS += ../src/crypto/crypto_gnutls.o
  353. OBJS_p += ../src/crypto/crypto_gnutls.o
  354. HOBJS += ../src/crypto/crypto_gnutls.o
  355. CONFIG_INTERNAL_SHA256=y
  356. endif
  357. ifeq ($(CONFIG_TLS), internal)
  358. ifeq ($(CONFIG_CRYPTO), libtomcrypt)
  359. OBJS += ../src/crypto/crypto_libtomcrypt.o
  360. OBJS_p += ../src/crypto/crypto_libtomcrypt.o
  361. CONFIG_INTERNAL_SHA256=y
  362. endif
  363. ifeq ($(CONFIG_CRYPTO), internal)
  364. OBJS += ../src/crypto/crypto_internal.o ../src/tls/rsa.o ../src/tls/bignum.o
  365. OBJS_p += ../src/crypto/crypto_internal.o ../src/tls/rsa.o ../src/tls/bignum.o
  366. CFLAGS += -DCONFIG_CRYPTO_INTERNAL
  367. CONFIG_INTERNAL_AES=y
  368. CONFIG_INTERNAL_DES=y
  369. CONFIG_INTERNAL_SHA1=y
  370. CONFIG_INTERNAL_MD4=y
  371. CONFIG_INTERNAL_MD5=y
  372. CONFIG_INTERNAL_SHA256=y
  373. endif
  374. endif
  375. else
  376. CONFIG_INTERNAL_AES=y
  377. CONFIG_INTERNAL_SHA1=y
  378. CONFIG_INTERNAL_MD5=y
  379. CONFIG_INTERNAL_SHA256=y
  380. endif
  381. ifdef CONFIG_INTERNAL_AES
  382. CFLAGS += -DINTERNAL_AES
  383. endif
  384. ifdef CONFIG_INTERNAL_SHA1
  385. CFLAGS += -DINTERNAL_SHA1
  386. endif
  387. ifdef CONFIG_INTERNAL_SHA256
  388. CFLAGS += -DINTERNAL_SHA256
  389. endif
  390. ifdef CONFIG_INTERNAL_MD5
  391. CFLAGS += -DINTERNAL_MD5
  392. endif
  393. ifdef CONFIG_INTERNAL_MD4
  394. CFLAGS += -DINTERNAL_MD4
  395. endif
  396. ifdef CONFIG_INTERNAL_DES
  397. CFLAGS += -DINTERNAL_DES
  398. endif
  399. ifdef NEED_SHA256
  400. OBJS += ../src/crypto/sha256.o
  401. endif
  402. ifdef NEED_DH_GROUPS
  403. OBJS += ../src/crypto/dh_groups.o
  404. endif
  405. ifndef NEED_FIPS186_2_PRF
  406. CFLAGS += -DCONFIG_NO_FIPS186_2_PRF
  407. endif
  408. ifndef NEED_T_PRF
  409. CFLAGS += -DCONFIG_NO_T_PRF
  410. endif
  411. ifdef CONFIG_RADIUS_SERVER
  412. CFLAGS += -DRADIUS_SERVER
  413. OBJS += ../src/radius/radius_server.o
  414. endif
  415. ifdef CONFIG_IPV6
  416. CFLAGS += -DCONFIG_IPV6
  417. endif
  418. ifdef CONFIG_DRIVER_RADIUS_ACL
  419. CFLAGS += -DCONFIG_DRIVER_RADIUS_ACL
  420. endif
  421. ifdef CONFIG_FULL_DYNAMIC_VLAN
  422. # define CONFIG_FULL_DYNAMIC_VLAN to have hostapd manipulate bridges
  423. # and vlan interfaces for the vlan feature.
  424. CFLAGS += -DCONFIG_FULL_DYNAMIC_VLAN
  425. endif
  426. ifdef NEED_BASE64
  427. OBJS += ../src/utils/base64.o
  428. endif
  429. ALL=hostapd hostapd_cli
  430. all: verify_config $(ALL)
  431. verify_config:
  432. @if [ ! -r .config ]; then \
  433. echo 'Building hostapd requires a configuration file'; \
  434. echo '(.config). See README for more instructions. You can'; \
  435. echo 'run "cp defconfig .config" to create an example'; \
  436. echo 'configuration.'; \
  437. exit 1; \
  438. fi
  439. install: all
  440. for i in $(ALL); do cp $$i /usr/local/bin/$$i; done
  441. hostapd: $(OBJS)
  442. $(CC) -o hostapd $(OBJS) $(LIBS)
  443. OBJS_c = hostapd_cli.o ../src/common/wpa_ctrl.o ../src/utils/os_$(CONFIG_OS).o
  444. hostapd_cli: $(OBJS_c)
  445. $(CC) -o hostapd_cli $(OBJS_c)
  446. NOBJS = nt_password_hash.o ../src/crypto/ms_funcs.o ../src/crypto/sha1.o ../src/crypto/rc4.o ../src/crypto/md5.o
  447. NOBJS += ../src/crypto/crypto_openssl.o ../src/utils/os_$(CONFIG_OS).o
  448. ifdef TLS_FUNCS
  449. LIBS_n += -lcrypto
  450. endif
  451. nt_password_hash: $(NOBJS)
  452. $(CC) -o nt_password_hash $(NOBJS) $(LIBS_n)
  453. hlr_auc_gw: $(HOBJS)
  454. $(CC) -o hlr_auc_gw $(HOBJS) $(LIBS_h)
  455. clean:
  456. $(MAKE) -C ../src clean
  457. rm -f core *~ *.o hostapd hostapd_cli nt_password_hash hlr_auc_gw
  458. rm -f *.d
  459. %.eps: %.fig
  460. fig2dev -L eps $*.fig $*.eps
  461. %.png: %.fig
  462. fig2dev -L png -m 3 $*.fig | pngtopnm | pnmscale 0.4 | pnmtopng \
  463. > $*.png
  464. docs-pics: doc/hostapd.png doc/hostapd.eps
  465. docs: docs-pics
  466. doxygen doc/doxygen.full
  467. $(MAKE) -C doc/latex
  468. cp doc/latex/refman.pdf hostapd-devel.pdf
  469. docs-fast: docs-pics
  470. doxygen doc/doxygen.fast
  471. clean-docs:
  472. rm -rf doc/latex doc/html
  473. rm -f doc/hosta.d{eps,png} hostapd-devel.pdf
  474. 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
  475. test-milenage: $(TEST_SRC_MILENAGE)
  476. $(CC) -o test-milenage -Wall -Werror $(TEST_SRC_MILENAGE) \
  477. -DTEST_MAIN_MILENAGE -I. -DINTERNAL_AES \
  478. -I../src/crypto -I../src/utils
  479. ./test-milenage
  480. rm test-milenage
  481. hostapd-sparse: $(OBJS)
  482. @echo Sparse run completed
  483. run-sparse:
  484. 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
  485. -include $(OBJS:%.o=%.d)