]>
Commit | Line | Data |
---|---|---|
6fc6879b JM |
1 | # Example wpa_supplicant build time configuration |
2 | # | |
3 | # This file lists the configuration options that are used when building the | |
212a8f48 JM |
4 | # wpa_supplicant binary. All lines starting with # are ignored. Configuration |
5 | # option lines must be commented out complete, if they are not to be included, | |
6 | # i.e., just setting VARIABLE=n is not disabling that variable. | |
6fc6879b JM |
7 | # |
8 | # This file is included in Makefile, so variables like CFLAGS and LIBS can also | |
9 | # be modified from here. In most cases, these lines should use += in order not | |
10 | # to override previous values of the variables. | |
11 | ||
12 | ||
13 | # Uncomment following two lines and fix the paths if you have installed OpenSSL | |
14 | # or GnuTLS in non-default location | |
15 | #CFLAGS += -I/usr/local/openssl/include | |
16 | #LIBS += -L/usr/local/openssl/lib | |
17 | ||
18 | # Some Red Hat versions seem to include kerberos header files from OpenSSL, but | |
19 | # the kerberos files are not in the default include path. Following line can be | |
20 | # used to fix build issues on such systems (krb5.h not found). | |
21 | #CFLAGS += -I/usr/include/kerberos | |
22 | ||
6fc6879b | 23 | # Driver interface for generic Linux wireless extensions |
0725cc7b JM |
24 | # Note: WEXT is deprecated in the current Linux kernel version and no new |
25 | # functionality is added to it. nl80211-based interface is the new | |
26 | # replacement for WEXT and its use allows wpa_supplicant to properly control | |
27 | # the driver to improve existing functionality like roaming and to support new | |
28 | # functionality. | |
6fc6879b JM |
29 | CONFIG_DRIVER_WEXT=y |
30 | ||
421b4ba5 | 31 | # Driver interface for Linux drivers using the nl80211 kernel interface |
0725cc7b | 32 | CONFIG_DRIVER_NL80211=y |
421b4ba5 | 33 | |
b658547d JM |
34 | # QCA vendor extensions to nl80211 |
35 | #CONFIG_DRIVER_NL80211_QCA=y | |
36 | ||
3043b4f4 BG |
37 | # driver_nl80211.c requires libnl. If you are compiling it yourself |
38 | # you may need to point hostapd to your version of libnl. | |
39 | # | |
40 | #CFLAGS += -I$<path to libnl include files> | |
41 | #LIBS += -L$<path to libnl library files> | |
42 | ||
43 | # Use libnl v2.0 (or 3.0) libraries. | |
44 | #CONFIG_LIBNL20=y | |
45 | ||
46 | # Use libnl 3.2 libraries (if this is selected, CONFIG_LIBNL20 is ignored) | |
55570efe | 47 | CONFIG_LIBNL32=y |
3043b4f4 BG |
48 | |
49 | ||
6fc6879b JM |
50 | # Driver interface for FreeBSD net80211 layer (e.g., Atheros driver) |
51 | #CONFIG_DRIVER_BSD=y | |
52 | #CFLAGS += -I/usr/local/include | |
53 | #LIBS += -L/usr/local/lib | |
953f0f63 MH |
54 | #LIBS_p += -L/usr/local/lib |
55 | #LIBS_c += -L/usr/local/lib | |
6fc6879b JM |
56 | |
57 | # Driver interface for Windows NDIS | |
58 | #CONFIG_DRIVER_NDIS=y | |
59 | #CFLAGS += -I/usr/include/w32api/ddk | |
60 | #LIBS += -L/usr/local/lib | |
61 | # For native build using mingw | |
62 | #CONFIG_NATIVE_WINDOWS=y | |
63 | # Additional directories for cross-compilation on Linux host for mingw target | |
64 | #CFLAGS += -I/opt/mingw/mingw32/include/ddk | |
65 | #LIBS += -L/opt/mingw/mingw32/lib | |
66 | #CC=mingw32-gcc | |
67 | # By default, driver_ndis uses WinPcap for low-level operations. This can be | |
68 | # replaced with the following option which replaces WinPcap calls with NDISUIO. | |
69 | # However, this requires that WZC is disabled (net stop wzcsvc) before starting | |
70 | # wpa_supplicant. | |
71 | # CONFIG_USE_NDISUIO=y | |
72 | ||
6fc6879b JM |
73 | # Driver interface for wired Ethernet drivers |
74 | CONFIG_DRIVER_WIRED=y | |
75 | ||
208263c0 JK |
76 | # Driver interface for MACsec capable Qualcomm Atheros drivers |
77 | #CONFIG_DRIVER_MACSEC_QCA=y | |
78 | ||
79 | # Driver interface for Linux MACsec drivers | |
a383db06 | 80 | CONFIG_DRIVER_MACSEC_LINUX=y |
208263c0 | 81 | |
e519314e JW |
82 | # Driver interface for the Broadcom RoboSwitch family |
83 | #CONFIG_DRIVER_ROBOSWITCH=y | |
84 | ||
a3c6598f JM |
85 | # Driver interface for no driver (e.g., WPS ER only) |
86 | #CONFIG_DRIVER_NONE=y | |
87 | ||
60da5e0f MH |
88 | # Solaris libraries |
89 | #LIBS += -lsocket -ldlpi -lnsl | |
90 | #LIBS_c += -lsocket | |
91 | ||
208263c0 JK |
92 | # Enable IEEE 802.1X Supplicant (automatically included if any EAP method or |
93 | # MACsec is included) | |
6fc6879b JM |
94 | CONFIG_IEEE8021X_EAPOL=y |
95 | ||
96 | # EAP-MD5 | |
97 | CONFIG_EAP_MD5=y | |
98 | ||
99 | # EAP-MSCHAPv2 | |
100 | CONFIG_EAP_MSCHAPV2=y | |
101 | ||
102 | # EAP-TLS | |
103 | CONFIG_EAP_TLS=y | |
104 | ||
105 | # EAL-PEAP | |
106 | CONFIG_EAP_PEAP=y | |
107 | ||
108 | # EAP-TTLS | |
109 | CONFIG_EAP_TTLS=y | |
110 | ||
111 | # EAP-FAST | |
eafc5fec | 112 | CONFIG_EAP_FAST=y |
6fc6879b | 113 | |
0ed57c5e JM |
114 | # EAP-TEAP |
115 | # Note: The current EAP-TEAP implementation is experimental and should not be | |
116 | # enabled for production use. The IETF RFC 7170 that defines EAP-TEAP has number | |
117 | # of conflicting statements and missing details and the implementation has | |
118 | # vendor specific workarounds for those and as such, may not interoperate with | |
119 | # any other implementation. This should not be used for anything else than | |
120 | # experimentation and interoperability testing until those issues has been | |
121 | # resolved. | |
122 | #CONFIG_EAP_TEAP=y | |
123 | ||
6fc6879b JM |
124 | # EAP-GTC |
125 | CONFIG_EAP_GTC=y | |
126 | ||
127 | # EAP-OTP | |
128 | CONFIG_EAP_OTP=y | |
129 | ||
130 | # EAP-SIM (enable CONFIG_PCSC, if EAP-SIM is used) | |
131 | #CONFIG_EAP_SIM=y | |
132 | ||
2f6700c9 MS |
133 | # Enable SIM simulator (Milenage) for EAP-SIM |
134 | #CONFIG_SIM_SIMULATOR=y | |
135 | ||
6fc6879b JM |
136 | # EAP-PSK (experimental; this is _not_ needed for WPA-PSK) |
137 | #CONFIG_EAP_PSK=y | |
138 | ||
27c9d333 | 139 | # EAP-pwd (secure authentication using only a password) |
eafc5fec | 140 | CONFIG_EAP_PWD=y |
27c9d333 | 141 | |
6fc6879b | 142 | # EAP-PAX |
eafc5fec | 143 | CONFIG_EAP_PAX=y |
6fc6879b JM |
144 | |
145 | # LEAP | |
146 | CONFIG_EAP_LEAP=y | |
147 | ||
148 | # EAP-AKA (enable CONFIG_PCSC, if EAP-AKA is used) | |
149 | #CONFIG_EAP_AKA=y | |
150 | ||
a9d1364c JM |
151 | # EAP-AKA' (enable CONFIG_PCSC, if EAP-AKA' is used). |
152 | # This requires CONFIG_EAP_AKA to be enabled, too. | |
153 | #CONFIG_EAP_AKA_PRIME=y | |
154 | ||
2a24bb31 JM |
155 | # Enable USIM simulator (Milenage) for EAP-AKA |
156 | #CONFIG_USIM_SIMULATOR=y | |
157 | ||
6fc6879b | 158 | # EAP-SAKE |
eafc5fec | 159 | CONFIG_EAP_SAKE=y |
6fc6879b JM |
160 | |
161 | # EAP-GPSK | |
eafc5fec | 162 | CONFIG_EAP_GPSK=y |
6fc6879b | 163 | # Include support for optional SHA256 cipher suite in EAP-GPSK |
eafc5fec | 164 | CONFIG_EAP_GPSK_SHA256=y |
6fc6879b JM |
165 | |
166 | # EAP-TNC and related Trusted Network Connect support (experimental) | |
eafc5fec | 167 | CONFIG_EAP_TNC=y |
6fc6879b | 168 | |
ad08c363 | 169 | # Wi-Fi Protected Setup (WPS) |
f87450a7 | 170 | CONFIG_WPS=y |
4aced422 JM |
171 | # Enable WPS external registrar functionality |
172 | #CONFIG_WPS_ER=y | |
745e8aba AB |
173 | # Disable credentials for an open network by default when acting as a WPS |
174 | # registrar. | |
175 | #CONFIG_WPS_REG_DISABLE_OPEN=y | |
51ca03f4 JM |
176 | # Enable WPS support with NFC config method |
177 | #CONFIG_WPS_NFC=y | |
ad08c363 | 178 | |
6fc6879b | 179 | # EAP-IKEv2 |
eafc5fec | 180 | CONFIG_EAP_IKEV2=y |
6fc6879b | 181 | |
7e7610d7 JM |
182 | # EAP-EKE |
183 | #CONFIG_EAP_EKE=y | |
184 | ||
208263c0 | 185 | # MACsec |
a383db06 | 186 | CONFIG_MACSEC=y |
208263c0 | 187 | |
6fc6879b JM |
188 | # PKCS#12 (PFX) support (used to read private key and certificate file from |
189 | # a file that usually has extension .p12 or .pfx) | |
190 | CONFIG_PKCS12=y | |
191 | ||
192 | # Smartcard support (i.e., private key on a smartcard), e.g., with openssl | |
193 | # engine. | |
194 | CONFIG_SMARTCARD=y | |
195 | ||
196 | # PC/SC interface for smartcards (USIM, GSM SIM) | |
197 | # Enable this if EAP-SIM or EAP-AKA is included | |
198 | #CONFIG_PCSC=y | |
199 | ||
80e8a5ee BG |
200 | # Support HT overrides (disable HT/HT40, mask MCS rates, etc.) |
201 | #CONFIG_HT_OVERRIDES=y | |
202 | ||
e9ee8dc3 JB |
203 | # Support VHT overrides (disable VHT, mask MCS rates, etc.) |
204 | #CONFIG_VHT_OVERRIDES=y | |
205 | ||
6fc6879b JM |
206 | # Development testing |
207 | #CONFIG_EAPOL_TEST=y | |
208 | ||
209 | # Select control interface backend for external programs, e.g, wpa_cli: | |
210 | # unix = UNIX domain sockets (default for Linux/*BSD) | |
211 | # udp = UDP sockets using localhost (127.0.0.1) | |
4db216fc | 212 | # udp6 = UDP IPv6 sockets using localhost (::1) |
6fc6879b | 213 | # named_pipe = Windows Named Pipe (default for Windows) |
afadf423 | 214 | # udp-remote = UDP sockets with remote access (only for tests systems/purpose) |
4db216fc | 215 | # udp6-remote = UDP IPv6 sockets with remote access (only for tests purpose) |
6fc6879b JM |
216 | # y = use default (backwards compatibility) |
217 | # If this option is commented out, control interface is not included in the | |
218 | # build. | |
219 | CONFIG_CTRL_IFACE=y | |
220 | ||
221 | # Include support for GNU Readline and History Libraries in wpa_cli. | |
222 | # When building a wpa_cli binary for distribution, please note that these | |
223 | # libraries are licensed under GPL and as such, BSD license may not apply for | |
224 | # the resulting binary. | |
225 | #CONFIG_READLINE=y | |
226 | ||
aee680e8 JM |
227 | # Include internal line edit mode in wpa_cli. This can be used as a replacement |
228 | # for GNU Readline to provide limited command line editing and history support. | |
229 | #CONFIG_WPA_CLI_EDIT=y | |
230 | ||
6fc6879b JM |
231 | # Remove debugging code that is printing out debug message to stdout. |
232 | # This can be used to reduce the size of the wpa_supplicant considerably | |
233 | # if debugging code is not needed. The size reduction can be around 35% | |
234 | # (e.g., 90 kB). | |
235 | #CONFIG_NO_STDOUT_DEBUG=y | |
236 | ||
237 | # Remove WPA support, e.g., for wired-only IEEE 802.1X supplicant, to save | |
238 | # 35-50 kB in code size. | |
239 | #CONFIG_NO_WPA=y | |
240 | ||
6fc6879b JM |
241 | # Remove IEEE 802.11i/WPA-Personal ASCII passphrase support |
242 | # This option can be used to reduce code size by removing support for | |
243 | # converting ASCII passphrases into PSK. If this functionality is removed, the | |
244 | # PSK can only be configured as the 64-octet hexstring (e.g., from | |
245 | # wpa_passphrase). This saves about 0.5 kB in code size. | |
246 | #CONFIG_NO_WPA_PASSPHRASE=y | |
247 | ||
bf46c6fc LR |
248 | # Simultaneous Authentication of Equals (SAE), WPA3-Personal |
249 | CONFIG_SAE=y | |
250 | ||
6fc6879b JM |
251 | # Disable scan result processing (ap_mode=1) to save code size by about 1 kB. |
252 | # This can be used if ap_scan=1 mode is never enabled. | |
253 | #CONFIG_NO_SCAN_PROCESSING=y | |
254 | ||
255 | # Select configuration backend: | |
256 | # file = text file (e.g., wpa_supplicant.conf; note: the configuration file | |
257 | # path is given on command line, not here; this option is just used to | |
258 | # select the backend that allows configuration files to be used) | |
259 | # winreg = Windows registry (see win_example.reg for an example) | |
260 | CONFIG_BACKEND=file | |
261 | ||
262 | # Remove configuration write functionality (i.e., to allow the configuration | |
263 | # file to be updated based on runtime configuration changes). The runtime | |
264 | # configuration can still be changed, the changes are just not going to be | |
265 | # persistent over restarts. This option can be used to reduce code size by | |
266 | # about 3.5 kB. | |
267 | #CONFIG_NO_CONFIG_WRITE=y | |
268 | ||
269 | # Remove support for configuration blobs to reduce code size by about 1.5 kB. | |
270 | #CONFIG_NO_CONFIG_BLOBS=y | |
271 | ||
272 | # Select program entry point implementation: | |
273 | # main = UNIX/POSIX like main() function (default) | |
274 | # main_winsvc = Windows service (read parameters from registry) | |
275 | # main_none = Very basic example (development use only) | |
276 | #CONFIG_MAIN=main | |
277 | ||
f0356ec8 | 278 | # Select wrapper for operating system and C library specific functions |
6fc6879b JM |
279 | # unix = UNIX/POSIX like systems (default) |
280 | # win32 = Windows systems | |
281 | # none = Empty template | |
282 | #CONFIG_OS=unix | |
283 | ||
284 | # Select event loop implementation | |
285 | # eloop = select() loop (default) | |
286 | # eloop_win = Windows events and WaitForMultipleObject() loop | |
6fc6879b JM |
287 | #CONFIG_ELOOP=eloop |
288 | ||
2df4c4ef BG |
289 | # Should we use poll instead of select? Select is used by default. |
290 | #CONFIG_ELOOP_POLL=y | |
291 | ||
f0356ec8 MH |
292 | # Should we use epoll instead of select? Select is used by default. |
293 | #CONFIG_ELOOP_EPOLL=y | |
294 | ||
634e2e29 RM |
295 | # Should we use kqueue instead of select? Select is used by default. |
296 | #CONFIG_ELOOP_KQUEUE=y | |
297 | ||
6fc6879b JM |
298 | # Select layer 2 packet implementation |
299 | # linux = Linux packet socket (default) | |
300 | # pcap = libpcap/libdnet/WinPcap | |
301 | # freebsd = FreeBSD libpcap | |
302 | # winpcap = WinPcap with receive thread | |
303 | # ndis = Windows NDISUIO (note: requires CONFIG_USE_NDISUIO=y) | |
304 | # none = Empty template | |
305 | #CONFIG_L2_PACKET=linux | |
306 | ||
67deaa58 MSS |
307 | # Disable Linux packet socket workaround applicable for station interface |
308 | # in a bridge for EAPOL frames. This should be uncommented only if the kernel | |
309 | # is known to not have the regression issue in packet socket behavior with | |
310 | # bridge interfaces (commit 'bridge: respect RFC2863 operational state')'). | |
311 | #CONFIG_NO_LINUX_PACKET_SOCKET_WAR=y | |
312 | ||
138205d6 MV |
313 | # Support Operating Channel Validation |
314 | #CONFIG_OCV=y | |
315 | ||
6fc6879b JM |
316 | # Select TLS implementation |
317 | # openssl = OpenSSL (default) | |
fd2f2d04 | 318 | # gnutls = GnuTLS |
6fc6879b | 319 | # internal = Internal TLSv1 implementation (experimental) |
206516e8 | 320 | # linux = Linux kernel AF_ALG and internal TLSv1 implementation (experimental) |
6fc6879b JM |
321 | # none = Empty template |
322 | #CONFIG_TLS=openssl | |
323 | ||
5c47af9a JM |
324 | # TLS-based EAP methods require at least TLS v1.0. Newer version of TLS (v1.1) |
325 | # can be enabled to get a stronger construction of messages when block ciphers | |
326 | # are used. It should be noted that some existing TLS v1.0 -based | |
327 | # implementation may not be compatible with TLS v1.1 message (ClientHello is | |
328 | # sent prior to negotiating which version will be used) | |
329 | #CONFIG_TLSV11=y | |
330 | ||
ca84eed7 JM |
331 | # TLS-based EAP methods require at least TLS v1.0. Newer version of TLS (v1.2) |
332 | # can be enabled to enable use of stronger crypto algorithms. It should be | |
333 | # noted that some existing TLS v1.0 -based implementation may not be compatible | |
334 | # with TLS v1.2 message (ClientHello is sent prior to negotiating which version | |
335 | # will be used) | |
336 | #CONFIG_TLSV12=y | |
337 | ||
2b9891bd BG |
338 | # Select which ciphers to use by default with OpenSSL if the user does not |
339 | # specify them. | |
340 | #CONFIG_TLS_DEFAULT_CIPHERS="DEFAULT:!EXP:!LOW" | |
341 | ||
6fc6879b JM |
342 | # If CONFIG_TLS=internal is used, additional library and include paths are |
343 | # needed for LibTomMath. Alternatively, an integrated, minimal version of | |
344 | # LibTomMath can be used. See beginning of libtommath.c for details on benefits | |
345 | # and drawbacks of this option. | |
346 | #CONFIG_INTERNAL_LIBTOMMATH=y | |
347 | #ifndef CONFIG_INTERNAL_LIBTOMMATH | |
348 | #LTM_PATH=/usr/src/libtommath-0.39 | |
349 | #CFLAGS += -I$(LTM_PATH) | |
350 | #LIBS += -L$(LTM_PATH) | |
351 | #LIBS_p += -L$(LTM_PATH) | |
352 | #endif | |
b95394c6 JM |
353 | # At the cost of about 4 kB of additional binary size, the internal LibTomMath |
354 | # can be configured to include faster routines for exptmod, sqr, and div to | |
187bc466 | 355 | # speed up DH and RSA calculation considerably |
b95394c6 | 356 | #CONFIG_INTERNAL_LIBTOMMATH_FAST=y |
6fc6879b JM |
357 | |
358 | # Include NDIS event processing through WMI into wpa_supplicant/wpasvc. | |
359 | # This is only for Windows builds and requires WMI-related header files and | |
360 | # WbemUuid.Lib from Platform SDK even when building with MinGW. | |
361 | #CONFIG_NDIS_EVENTS_INTEGRATED=y | |
362 | #PLATFORMSDKLIB="/opt/Program Files/Microsoft Platform SDK/Lib" | |
363 | ||
8fc2fb56 | 364 | # Add support for new DBus control interface |
ec1c0d15 | 365 | # (fi.w1.wpa_supplicant1) |
fafad852 | 366 | CONFIG_CTRL_IFACE_DBUS_NEW=y |
8fc2fb56 | 367 | |
ce4f7fdb | 368 | # Add introspection support for new DBus control interface |
fafad852 | 369 | CONFIG_CTRL_IFACE_DBUS_INTRO=y |
8fc2fb56 | 370 | |
6fc6879b JM |
371 | # Add support for loading EAP methods dynamically as shared libraries. |
372 | # When this option is enabled, each EAP method can be either included | |
373 | # statically (CONFIG_EAP_<method>=y) or dynamically (CONFIG_EAP_<method>=dyn). | |
374 | # Dynamic EAP methods are build as shared objects (eap_*.so) and they need to | |
375 | # be loaded in the beginning of the wpa_supplicant configuration file | |
376 | # (see load_dynamic_eap parameter in the example file) before being used in | |
377 | # the network blocks. | |
378 | # | |
379 | # Note that some shared parts of EAP methods are included in the main program | |
380 | # and in order to be able to use dynamic EAP methods using these parts, the | |
381 | # main program must have been build with the EAP method enabled (=y or =dyn). | |
382 | # This means that EAP-TLS/PEAP/TTLS/FAST cannot be added as dynamic libraries | |
383 | # unless at least one of them was included in the main build to force inclusion | |
384 | # of the shared code. Similarly, at least one of EAP-SIM/AKA must be included | |
385 | # in the main build to be able to load these methods dynamically. | |
386 | # | |
387 | # Please also note that using dynamic libraries will increase the total binary | |
388 | # size. Thus, it may not be the best option for targets that have limited | |
389 | # amount of memory/flash. | |
390 | #CONFIG_DYNAMIC_EAP_METHODS=y | |
391 | ||
4ec1fd8e | 392 | # IEEE Std 802.11r-2008 (Fast BSS Transition) for station mode |
9515fa92 | 393 | CONFIG_IEEE80211R=y |
6fc6879b JM |
394 | |
395 | # Add support for writing debug log to a file (/tmp/wpa_supplicant-log-#.txt) | |
f64050da | 396 | CONFIG_DEBUG_FILE=y |
6fc6879b | 397 | |
fe885594 | 398 | # Send debug messages to syslog instead of stdout |
f64050da | 399 | CONFIG_DEBUG_SYSLOG=y |
fe885594 JM |
400 | # Set syslog facility for debug messages |
401 | #CONFIG_DEBUG_SYSLOG_FACILITY=LOG_DAEMON | |
402 | ||
4f68895e JB |
403 | # Add support for sending all debug messages (regardless of debug verbosity) |
404 | # to the Linux kernel tracing facility. This helps debug the entire stack by | |
405 | # making it easy to record everything happening from the driver up into the | |
406 | # same file, e.g., using trace-cmd. | |
407 | #CONFIG_DEBUG_LINUX_TRACING=y | |
408 | ||
abfc3ad9 JM |
409 | # Add support for writing debug log to Android logcat instead of standard |
410 | # output | |
411 | #CONFIG_ANDROID_LOG=y | |
412 | ||
6fc6879b JM |
413 | # Enable privilege separation (see README 'Privilege separation' for details) |
414 | #CONFIG_PRIVSEP=y | |
46690a3b JM |
415 | |
416 | # Enable mitigation against certain attacks against TKIP by delaying Michael | |
417 | # MIC error reports by a random amount of time between 0 and 60 seconds | |
418 | #CONFIG_DELAYED_MIC_ERROR_REPORT=y | |
b22b41ee JM |
419 | |
420 | # Enable tracing code for developer debugging | |
421 | # This tracks use of memory allocations and other registrations and reports | |
422 | # incorrect use with a backtrace of call (or allocation) location. | |
423 | #CONFIG_WPA_TRACE=y | |
540609c5 | 424 | # For BSD, uncomment these. |
953f0f63 MH |
425 | #LIBS += -lexecinfo |
426 | #LIBS_p += -lexecinfo | |
427 | #LIBS_c += -lexecinfo | |
b22b41ee JM |
428 | |
429 | # Use libbfd to get more details for developer debugging | |
430 | # This enables use of libbfd to get more detailed symbols for the backtraces | |
431 | # generated by CONFIG_WPA_TRACE=y. | |
96603e4f | 432 | #CONFIG_WPA_TRACE_BFD=y |
540609c5 | 433 | # For BSD, uncomment these. |
953f0f63 MH |
434 | #LIBS += -lbfd -liberty -lz |
435 | #LIBS_p += -lbfd -liberty -lz | |
436 | #LIBS_c += -lbfd -liberty -lz | |
bbb921da JM |
437 | |
438 | # wpa_supplicant depends on strong random number generation being available | |
439 | # from the operating system. os_get_random() function is used to fetch random | |
440 | # data when needed, e.g., for key generation. On Linux and BSD systems, this | |
441 | # works by reading /dev/urandom. It should be noted that the OS entropy pool | |
442 | # needs to be properly initialized before wpa_supplicant is started. This is | |
443 | # important especially on embedded devices that do not have a hardware random | |
444 | # number generator and may by default start up with minimal entropy available | |
445 | # for random number generation. | |
446 | # | |
447 | # As a safety net, wpa_supplicant is by default trying to internally collect | |
448 | # additional entropy for generating random data to mix in with the data fetched | |
449 | # from the OS. This by itself is not considered to be very strong, but it may | |
450 | # help in cases where the system pool is not initialized properly. However, it | |
451 | # is very strongly recommended that the system pool is initialized with enough | |
38e24575 | 452 | # entropy either by using hardware assisted random number generator or by |
bbb921da JM |
453 | # storing state over device reboots. |
454 | # | |
38e24575 JM |
455 | # wpa_supplicant can be configured to maintain its own entropy store over |
456 | # restarts to enhance random number generation. This is not perfect, but it is | |
457 | # much more secure than using the same sequence of random numbers after every | |
458 | # reboot. This can be enabled with -e<entropy file> command line option. The | |
459 | # specified file needs to be readable and writable by wpa_supplicant. | |
460 | # | |
461 | # If the os_get_random() is known to provide strong random data (e.g., on | |
bbb921da JM |
462 | # Linux/BSD, the board in question is known to have reliable source of random |
463 | # data from /dev/urandom), the internal wpa_supplicant random pool can be | |
464 | # disabled. This will save some in binary size and CPU use. However, this | |
465 | # should only be considered for builds that are known to be used on devices | |
466 | # that meet the requirements described above. | |
467 | #CONFIG_NO_RANDOM_POOL=y | |
03948f42 | 468 | |
89a7cdd6 LR |
469 | # Should we attempt to use the getrandom(2) call that provides more reliable |
470 | # yet secure randomness source than /dev/random on Linux 3.17 and newer. | |
471 | # Requires glibc 2.25 to build, falls back to /dev/random if unavailable. | |
472 | #CONFIG_GETRANDOM=y | |
473 | ||
03948f42 | 474 | # IEEE 802.11n (High Throughput) support (mainly for AP mode) |
6b7a0da7 | 475 | CONFIG_IEEE80211N=y |
46ee0427 | 476 | |
f2112b2a EP |
477 | # IEEE 802.11ac (Very High Throughput) support (mainly for AP mode) |
478 | # (depends on CONFIG_IEEE80211N) | |
6b7a0da7 | 479 | CONFIG_IEEE80211AC=y |
f2112b2a | 480 | |
b6668734 JM |
481 | # Wireless Network Management (IEEE Std 802.11v-2011) |
482 | # Note: This is experimental and not complete implementation. | |
483 | #CONFIG_WNM=y | |
484 | ||
46ee0427 JM |
485 | # Interworking (IEEE 802.11u) |
486 | # This can be used to enable functionality to improve interworking with | |
487 | # external networks (GAS/ANQP to learn more about the networks and network | |
488 | # selection based on available credentials). | |
467004d6 | 489 | CONFIG_INTERWORKING=y |
25471fe3 JK |
490 | |
491 | # Hotspot 2.0 | |
467004d6 | 492 | CONFIG_HS20=y |
ef3e60bf | 493 | |
2e997eec RM |
494 | # Enable interface matching in wpa_supplicant |
495 | #CONFIG_MATCH_IFACE=y | |
496 | ||
abfc3ad9 JM |
497 | # Disable roaming in wpa_supplicant |
498 | #CONFIG_NO_ROAMING=y | |
499 | ||
ef3e60bf JM |
500 | # AP mode operations with wpa_supplicant |
501 | # This can be used for controlling AP mode operations with wpa_supplicant. It | |
502 | # should be noted that this is mainly aimed at simple cases like | |
503 | # WPA2-Personal while more complex configurations like WPA2-Enterprise with an | |
504 | # external RADIUS server can be supported with hostapd. | |
2d6d4721 | 505 | CONFIG_AP=y |
ef3e60bf JM |
506 | |
507 | # P2P (Wi-Fi Direct) | |
508 | # This can be used to enable P2P support in wpa_supplicant. See README-P2P for | |
509 | # more information on P2P operations. | |
c4eafad0 | 510 | CONFIG_P2P=y |
7c865c68 | 511 | |
abfc3ad9 JM |
512 | # Enable TDLS support |
513 | #CONFIG_TDLS=y | |
514 | ||
d989e67d JM |
515 | # Wi-Fi Display |
516 | # This can be used to enable Wi-Fi Display extensions for P2P using an external | |
215a02f3 | 517 | # program to control the additional information exchanges in the messages. |
c4eafad0 | 518 | CONFIG_WIFI_DISPLAY=y |
215a02f3 | 519 | |
7c865c68 TB |
520 | # Autoscan |
521 | # This can be used to enable automatic scan support in wpa_supplicant. | |
65015b2d | 522 | # See wpa_supplicant.conf for more information on autoscan usage. |
c0fba2b3 TB |
523 | # |
524 | # Enabling directly a module will enable autoscan support. | |
525 | # For exponential module: | |
526 | #CONFIG_AUTOSCAN_EXPONENTIAL=y | |
e3659c89 TB |
527 | # For periodic module: |
528 | #CONFIG_AUTOSCAN_PERIODIC=y | |
306ae225 JM |
529 | |
530 | # Password (and passphrase, etc.) backend for external storage | |
531 | # These optional mechanisms can be used to add support for storing passwords | |
532 | # and other secrets in external (to wpa_supplicant) location. This allows, for | |
533 | # example, operating system specific key storage to be used | |
534 | # | |
535 | # External password backend for testing purposes (developer use) | |
536 | #CONFIG_EXT_PASSWORD_TEST=y | |
79c7b36d AN |
537 | |
538 | # Enable Fast Session Transfer (FST) | |
539 | #CONFIG_FST=y | |
a8dab08a AN |
540 | |
541 | # Enable CLI commands for FST testing | |
542 | #CONFIG_FST_TEST=y | |
939471b9 AD |
543 | |
544 | # OS X builds. This is only for building eapol_test. | |
545 | #CONFIG_OSX=y | |
d9909717 TB |
546 | |
547 | # Automatic Channel Selection | |
548 | # This will allow wpa_supplicant to pick the channel automatically when channel | |
549 | # is set to "0". | |
550 | # | |
551 | # TODO: Extend parser to be able to parse "channel=acs_survey" as an alternative | |
552 | # to "channel=0". This would enable us to eventually add other ACS algorithms in | |
553 | # similar way. | |
554 | # | |
555 | # Automatic selection is currently only done through initialization, later on | |
556 | # we hope to do background checks to keep us moving to more ideal channels as | |
557 | # time goes by. ACS is currently only supported through the nl80211 driver and | |
558 | # your driver must have survey dump capability that is filled by the driver | |
559 | # during scanning. | |
560 | # | |
561 | # TODO: In analogy to hostapd be able to customize the ACS survey algorithm with | |
562 | # a newly to create wpa_supplicant.conf variable acs_num_scans. | |
563 | # | |
564 | # Supported ACS drivers: | |
565 | # * ath9k | |
566 | # * ath5k | |
567 | # * ath10k | |
568 | # | |
569 | # For more details refer to: | |
570 | # http://wireless.kernel.org/en/users/Documentation/acs | |
571 | #CONFIG_ACS=y | |
facf2c72 DS |
572 | |
573 | # Support Multi Band Operation | |
574 | #CONFIG_MBO=y | |
9b7a2b83 JM |
575 | |
576 | # Fast Initial Link Setup (FILS) (IEEE 802.11ai) | |
9b7a2b83 | 577 | #CONFIG_FILS=y |
76e20f4f JM |
578 | # FILS shared key authentication with PFS |
579 | #CONFIG_FILS_SK_PFS=y | |
913c3e1e JM |
580 | |
581 | # Support RSN on IBSS networks | |
582 | # This is needed to be able to use mode=1 network profile with proto=RSN and | |
583 | # key_mgmt=WPA-PSK (i.e., full key management instead of WPA-None). | |
ec52faa2 | 584 | CONFIG_IBSS_RSN=y |
3459381d JM |
585 | |
586 | # External PMKSA cache control | |
587 | # This can be used to enable control interface commands that allow the current | |
588 | # PMKSA cache entries to be fetched and new entries to be added. | |
589 | #CONFIG_PMKSA_CACHE_EXTERNAL=y | |
ce691a8d MH |
590 | |
591 | # Mesh Networking (IEEE 802.11s) | |
592 | #CONFIG_MESH=y | |
784710b7 JM |
593 | |
594 | # Background scanning modules | |
595 | # These can be used to request wpa_supplicant to perform background scanning | |
596 | # operations for roaming within an ESS (same SSID). See the bgscan parameter in | |
597 | # the wpa_supplicant.conf file for more details. | |
598 | # Periodic background scans based on signal strength | |
ae5240db | 599 | CONFIG_BGSCAN_SIMPLE=y |
784710b7 JM |
600 | # Learn channels used by the network and try to avoid bgscans on other |
601 | # channels (experimental) | |
602 | #CONFIG_BGSCAN_LEARN=y | |
61152384 JM |
603 | |
604 | # Opportunistic Wireless Encryption (OWE) | |
605 | # Experimental implementation of draft-harkins-owe-07.txt | |
606 | #CONFIG_OWE=y | |
ca098ee4 LR |
607 | |
608 | # Device Provisioning Protocol (DPP) | |
ca098ee4 | 609 | CONFIG_DPP=y |