Merge branch 'master' into net80211-update
[dragonfly.git] / usr.sbin / 802_11 / wpa_supplicant / Makefile
1 # $FreeBSD: head/usr.sbin/wpa/wpa_supplicant/Makefile 189263 2009-03-02 02:28:22Z sam $
2 # $DragonFly$
3
4 .include "${.CURDIR}/../Makefile.inc"
5
6 .PATH.c:${WPA_DISTDIR}/wpa_supplicant \
7         ${WPA_DISTDIR}/src/drivers \
8         ${WPA_DISTDIR}/src/eap_peer \
9         ${WPA_DISTDIR}/src/rsn_supp
10
11 PROG=   wpa_supplicant
12 SRCS=   aes.c aes_wrap.c blacklist.c common.c config.c ctrl_iface.c \
13         ctrl_iface_unix.c drivers.c eloop.c events.c l2_packet.c main.c \
14         md5.c preauth.c pmksa_cache.c rc4.c scan.c scan_helpers.c sha1.c \
15         wpa.c wpa_common.c wpa_debug.c wpa_ie.c wpa_supplicant.c \
16         wpabuf.c wpas_glue.c \
17         driver_ndis.c Packet32.c \
18         driver_wired.c \
19         driver_dragonfly.c os_unix.c
20
21 MAN=    wpa_supplicant.8 wpa_supplicant.conf.5
22
23 #.if ${MK_EXAMPLES} != "no"
24 #FILESDIR= ${SHAREDIR}/examples/etc
25 #.PATH: ${WPA_SUPPLICANT_DISTDIR}
26 #FILES= wpa_supplicant.conf
27 #.endif
28
29 CFLAGS+=-I${WPA_SUPPLICANT_DISTDIR}
30 CFLAGS+=-I${WPA_DISTDIR}/src/drivers
31 CFLAGS+=-I${WPA_DISTDIR}/src/rsn_supp
32
33 CFLAGS+= -DCONFIG_DRIVER_BSD
34 CFLAGS+= -DCONFIG_DRIVER_NDIS
35 CFLAGS+= -DCONFIG_DRIVER_WIRED
36 CFLAGS+= -DCONFIG_TERMINATE_ONLASTIF
37 CFLAGS+= -DCONFIG_DEBUG_SYSLOG
38 CFLAGS+= -g
39 DPADD+= ${LIBPCAP}
40 LDADD+= -lpcap
41
42 # NB: we only support wpa_supplicant.conf file
43 SRCS+=  config_file.c base64.c
44 CFLAGS+=-DCONFIG_BACKEND_FILE
45
46 # User customizations to the wpa_supplicant build environment
47 CFLAGS+=${WPA_SUPPLICANT_CFLAGS}
48 #DPADD+=${WPA_SUPPLICANT_DPADD}
49 LDADD+=${WPA_SUPPLICANT_LDADD}
50 #LDFLAGS+=${WPA_SUPPLICANT_LDFLAGS}
51
52 SRCS+=  eapol_supp_sm.c eap.c eap_common.c eap_methods.c
53 CFLAGS+= -DIEEE8021X_EAPOL
54
55 .if !defined(NO_CRYPT) && !defined(NO_OPENSSL)
56 CFLAGS+=-DEAP_TLS -DEAP_PEAP -DEAP_MSCHAPv2 -DEAP_LEAP -DEAP_PSK \
57         -DEAP_TLV -DEAP_TLS_FUNCS -DEAP_TLS_OPENSSL
58 SRCS+=  chap.c crypto_openssl.c \
59         eap_leap.c \
60         eap_mschapv2.c \
61         eap_peap.c eap_peap_common.c \
62         eap_psk.c eap_psk_common.c \
63         eap_tls.c eap_tls_common.c \
64         mschapv2.c ms_funcs.c tls_openssl.c
65
66 CFLAGS+=-DEAP_TTLS -DEAP_MD5
67 SRCS+=  eap_ttls.c eap_md5.c
68
69 .if !empty(CFLAGS:M*-DEAP_GTC)
70 SRCS+=  eap_gtc.c
71 .endif
72
73 .if !empty(CFLAGS:M*-DEAP_OTP)
74 SRCS+=  eap_otp.c
75 .endif
76
77 .if !empty(CFLAGS:M*-DEAP_AKA)
78 NEED_SIM_COMMON=        true
79 SRCS+=  eap_aka.c
80 .endif
81
82 .if !empty(CFLAGS:M*-DEAP_SIM)
83 NEED_SIM_COMMON=        true
84 SRCS+=  eap_sim.c
85 .endif
86
87 .if defined(NEED_SIM_COMMON)
88 SRCS+=  eap_sim_common.c
89
90 # PC/SC interface for smartcards (USIM, GSM SIM)
91 # GSM/UMTS authentication algorithm (for EAP-SIM/EAP-AKA)
92 # NB: requires devel/pcsc-lite
93 #
94 # WPA_SUPPLICANT_CFLAGS=-DEAP_AKA -DPCSC_FUNCS -I/usr/local/include/PCSC
95 # WPA_SUPPLICANT_LDADD=-L/usr/local/lib
96 #
97 .if !empty(CFLAGS:M*-DPCSC_FUNCS)
98 SRCS+=  pcsc_funcs.c
99 DPADD+=${LIBPTHREAD}
100 LDADD+=-lpcsclite -lpthread
101 .endif
102 .endif
103
104 .if !empty(CFLAGS:M*-DEAP_GPSK)
105 CFLAGS+=-DEAP_GPSK_SHA256
106 SRCS+=  eap_gpsk.c eap_gpsk_common.c
107 NEED_SHA256=    true
108 .endif
109
110 .if !empty(CFLAGS:M*-DEAP_PAX)
111 SRCS+=  eap_pax.c eap_pax_common.c
112 .endif
113
114 .if !empty(CFLAGS:M*-DEAP_SAKE)
115 SRCS+=  eap_sake.c eap_sake_common.c
116 .endif
117
118 # NB: requires patch to openssl
119 #CFLAGS+= -DEAP_FAST
120 #SRCS+= eap_fast.c
121
122 NEED_LIBSSL=    true
123 .else
124 CFLAGS+= -DEAP_TLS_NONE
125 SRCS+=  tls_none.c
126 .endif
127
128 #
129 # Configure crypto/cipher support.
130 #
131 # EAPOL support requires openssl in which case we use their
132 # cipher code.  Otherwise we use our internal versions.
133 #
134 .if !defined(NEED_LIBSSL)
135 CFLAGS+= -DINTERNAL_AES
136 CFLAGS+= -DINTERNAL_SHA1
137 CFLAGS+= -DINTERNAL_MD5
138 .else
139 DPADD+= ${LIBSSL} ${LIBCRYPTO}
140 LDADD+= -lssl -lcrypto
141 .endif
142
143 .if defined(NEED_SHA256)
144 CFLAGS+=-DINTERNAL_SHA256
145 SRCS+=  sha256.c
146 .endif
147
148 .include <bsd.prog.mk>