- Revert "Mark authorization completed on driver indication
during 4-way HS offload" because of connection using WPA2-PSK or WPA-SAE problems with brcmfmac wifi hardware. (bsc#1230797) [+ Revert-Mark-authorization-completed-on-driver-indica.patch] OBS-URL: https://build.opensuse.org/package/show/hardware/wpa_supplicant?expand=0&rev=148
This commit is contained in:
commit
ae1b52fe7b
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
## Default LFS
|
||||||
|
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.png filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zst filter=lfs diff=lfs merge=lfs -text
|
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
.osc
|
210
CVE-2023-52160.patch
Normal file
210
CVE-2023-52160.patch
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
From 8e6485a1bcb0baffdea9e55255a81270b768439c Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jouni Malinen <j@w1.fi>
|
||||||
|
Date: Sat, 8 Jul 2023 19:55:32 +0300
|
||||||
|
Subject: PEAP client: Update Phase 2 authentication requirements
|
||||||
|
|
||||||
|
The previous PEAP client behavior allowed the server to skip Phase 2
|
||||||
|
authentication with the expectation that the server was authenticated
|
||||||
|
during Phase 1 through TLS server certificate validation. Various PEAP
|
||||||
|
specifications are not exactly clear on what the behavior on this front
|
||||||
|
is supposed to be and as such, this ended up being more flexible than
|
||||||
|
the TTLS/FAST/TEAP cases. However, this is not really ideal when
|
||||||
|
unfortunately common misconfiguration of PEAP is used in deployed
|
||||||
|
devices where the server trust root (ca_cert) is not configured or the
|
||||||
|
user has an easy option for allowing this validation step to be skipped.
|
||||||
|
|
||||||
|
Change the default PEAP client behavior to be to require Phase 2
|
||||||
|
authentication to be successfully completed for cases where TLS session
|
||||||
|
resumption is not used and the client certificate has not been
|
||||||
|
configured. Those two exceptions are the main cases where a deployed
|
||||||
|
authentication server might skip Phase 2 and as such, where a more
|
||||||
|
strict default behavior could result in undesired interoperability
|
||||||
|
issues. Requiring Phase 2 authentication will end up disabling TLS
|
||||||
|
session resumption automatically to avoid interoperability issues.
|
||||||
|
|
||||||
|
Allow Phase 2 authentication behavior to be configured with a new phase1
|
||||||
|
configuration parameter option:
|
||||||
|
'phase2_auth' option can be used to control Phase 2 (i.e., within TLS
|
||||||
|
tunnel) behavior for PEAP:
|
||||||
|
* 0 = do not require Phase 2 authentication
|
||||||
|
* 1 = require Phase 2 authentication when client certificate
|
||||||
|
(private_key/client_cert) is no used and TLS session resumption was
|
||||||
|
not used (default)
|
||||||
|
* 2 = require Phase 2 authentication in all cases
|
||||||
|
|
||||||
|
Signed-off-by: Jouni Malinen <j@w1.fi>
|
||||||
|
---
|
||||||
|
src/eap_peer/eap_config.h | 8 ++++++++
|
||||||
|
src/eap_peer/eap_peap.c | 40 +++++++++++++++++++++++++++++++++++---
|
||||||
|
src/eap_peer/eap_tls_common.c | 6 ++++++
|
||||||
|
src/eap_peer/eap_tls_common.h | 5 +++++
|
||||||
|
wpa_supplicant/wpa_supplicant.conf | 7 +++++++
|
||||||
|
5 files changed, 63 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/src/eap_peer/eap_config.h b/src/eap_peer/eap_config.h
|
||||||
|
index 26744ab68..58d5a1359 100644
|
||||||
|
--- a/src/eap_peer/eap_config.h
|
||||||
|
+++ b/src/eap_peer/eap_config.h
|
||||||
|
@@ -471,6 +471,14 @@ struct eap_peer_config {
|
||||||
|
* 1 = use cryptobinding if server supports it
|
||||||
|
* 2 = require cryptobinding
|
||||||
|
*
|
||||||
|
+ * phase2_auth option can be used to control Phase 2 (i.e., within TLS
|
||||||
|
+ * tunnel) behavior for PEAP:
|
||||||
|
+ * 0 = do not require Phase 2 authentication
|
||||||
|
+ * 1 = require Phase 2 authentication when client certificate
|
||||||
|
+ * (private_key/client_cert) is no used and TLS session resumption was
|
||||||
|
+ * not used (default)
|
||||||
|
+ * 2 = require Phase 2 authentication in all cases
|
||||||
|
+ *
|
||||||
|
* EAP-WSC (WPS) uses following options: pin=Device_Password and
|
||||||
|
* uuid=Device_UUID
|
||||||
|
*
|
||||||
|
diff --git a/src/eap_peer/eap_peap.c b/src/eap_peer/eap_peap.c
|
||||||
|
index 12e30df29..608069719 100644
|
||||||
|
--- a/src/eap_peer/eap_peap.c
|
||||||
|
+++ b/src/eap_peer/eap_peap.c
|
||||||
|
@@ -67,6 +67,7 @@ struct eap_peap_data {
|
||||||
|
u8 cmk[20];
|
||||||
|
int soh; /* Whether IF-TNCCS-SOH (Statement of Health; Microsoft NAP)
|
||||||
|
* is enabled. */
|
||||||
|
+ enum { NO_AUTH, FOR_INITIAL, ALWAYS } phase2_auth;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@@ -114,6 +115,19 @@ static void eap_peap_parse_phase1(struct eap_peap_data *data,
|
||||||
|
wpa_printf(MSG_DEBUG, "EAP-PEAP: Require cryptobinding");
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (os_strstr(phase1, "phase2_auth=0")) {
|
||||||
|
+ data->phase2_auth = NO_AUTH;
|
||||||
|
+ wpa_printf(MSG_DEBUG,
|
||||||
|
+ "EAP-PEAP: Do not require Phase 2 authentication");
|
||||||
|
+ } else if (os_strstr(phase1, "phase2_auth=1")) {
|
||||||
|
+ data->phase2_auth = FOR_INITIAL;
|
||||||
|
+ wpa_printf(MSG_DEBUG,
|
||||||
|
+ "EAP-PEAP: Require Phase 2 authentication for initial connection");
|
||||||
|
+ } else if (os_strstr(phase1, "phase2_auth=2")) {
|
||||||
|
+ data->phase2_auth = ALWAYS;
|
||||||
|
+ wpa_printf(MSG_DEBUG,
|
||||||
|
+ "EAP-PEAP: Require Phase 2 authentication for all cases");
|
||||||
|
+ }
|
||||||
|
#ifdef EAP_TNC
|
||||||
|
if (os_strstr(phase1, "tnc=soh2")) {
|
||||||
|
data->soh = 2;
|
||||||
|
@@ -142,6 +156,7 @@ static void * eap_peap_init(struct eap_sm *sm)
|
||||||
|
data->force_peap_version = -1;
|
||||||
|
data->peap_outer_success = 2;
|
||||||
|
data->crypto_binding = OPTIONAL_BINDING;
|
||||||
|
+ data->phase2_auth = FOR_INITIAL;
|
||||||
|
|
||||||
|
if (config && config->phase1)
|
||||||
|
eap_peap_parse_phase1(data, config->phase1);
|
||||||
|
@@ -454,6 +469,20 @@ static int eap_tlv_validate_cryptobinding(struct eap_sm *sm,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
+static bool peap_phase2_sufficient(struct eap_sm *sm,
|
||||||
|
+ struct eap_peap_data *data)
|
||||||
|
+{
|
||||||
|
+ if ((data->phase2_auth == ALWAYS ||
|
||||||
|
+ (data->phase2_auth == FOR_INITIAL &&
|
||||||
|
+ !tls_connection_resumed(sm->ssl_ctx, data->ssl.conn) &&
|
||||||
|
+ !data->ssl.client_cert_conf) ||
|
||||||
|
+ data->phase2_eap_started) &&
|
||||||
|
+ !data->phase2_eap_success)
|
||||||
|
+ return false;
|
||||||
|
+ return true;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
+
|
||||||
|
/**
|
||||||
|
* eap_tlv_process - Process a received EAP-TLV message and generate a response
|
||||||
|
* @sm: Pointer to EAP state machine allocated with eap_peer_sm_init()
|
||||||
|
@@ -568,6 +597,11 @@ static int eap_tlv_process(struct eap_sm *sm, struct eap_peap_data *data,
|
||||||
|
" - force failed Phase 2");
|
||||||
|
resp_status = EAP_TLV_RESULT_FAILURE;
|
||||||
|
ret->decision = DECISION_FAIL;
|
||||||
|
+ } else if (!peap_phase2_sufficient(sm, data)) {
|
||||||
|
+ wpa_printf(MSG_INFO,
|
||||||
|
+ "EAP-PEAP: Server indicated Phase 2 success, but sufficient Phase 2 authentication has not been completed");
|
||||||
|
+ resp_status = EAP_TLV_RESULT_FAILURE;
|
||||||
|
+ ret->decision = DECISION_FAIL;
|
||||||
|
} else {
|
||||||
|
resp_status = EAP_TLV_RESULT_SUCCESS;
|
||||||
|
ret->decision = DECISION_UNCOND_SUCC;
|
||||||
|
@@ -887,8 +921,7 @@ continue_req:
|
||||||
|
/* EAP-Success within TLS tunnel is used to indicate
|
||||||
|
* shutdown of the TLS channel. The authentication has
|
||||||
|
* been completed. */
|
||||||
|
- if (data->phase2_eap_started &&
|
||||||
|
- !data->phase2_eap_success) {
|
||||||
|
+ if (!peap_phase2_sufficient(sm, data)) {
|
||||||
|
wpa_printf(MSG_DEBUG, "EAP-PEAP: Phase 2 "
|
||||||
|
"Success used to indicate success, "
|
||||||
|
"but Phase 2 EAP was not yet "
|
||||||
|
@@ -1199,8 +1232,9 @@ static struct wpabuf * eap_peap_process(struct eap_sm *sm, void *priv,
|
||||||
|
static bool eap_peap_has_reauth_data(struct eap_sm *sm, void *priv)
|
||||||
|
{
|
||||||
|
struct eap_peap_data *data = priv;
|
||||||
|
+
|
||||||
|
return tls_connection_established(sm->ssl_ctx, data->ssl.conn) &&
|
||||||
|
- data->phase2_success;
|
||||||
|
+ data->phase2_success && data->phase2_auth != ALWAYS;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/eap_peer/eap_tls_common.c b/src/eap_peer/eap_tls_common.c
|
||||||
|
index 6193b4bdb..966cbd6c7 100644
|
||||||
|
--- a/src/eap_peer/eap_tls_common.c
|
||||||
|
+++ b/src/eap_peer/eap_tls_common.c
|
||||||
|
@@ -242,6 +242,12 @@ static int eap_tls_params_from_conf(struct eap_sm *sm,
|
||||||
|
|
||||||
|
sm->ext_cert_check = !!(params->flags & TLS_CONN_EXT_CERT_CHECK);
|
||||||
|
|
||||||
|
+ if (!phase2)
|
||||||
|
+ data->client_cert_conf = params->client_cert ||
|
||||||
|
+ params->client_cert_blob ||
|
||||||
|
+ params->private_key ||
|
||||||
|
+ params->private_key_blob;
|
||||||
|
+
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
diff --git a/src/eap_peer/eap_tls_common.h b/src/eap_peer/eap_tls_common.h
|
||||||
|
index 9ac00121f..334863413 100644
|
||||||
|
--- a/src/eap_peer/eap_tls_common.h
|
||||||
|
+++ b/src/eap_peer/eap_tls_common.h
|
||||||
|
@@ -79,6 +79,11 @@ struct eap_ssl_data {
|
||||||
|
* tls_v13 - Whether TLS v1.3 or newer is used
|
||||||
|
*/
|
||||||
|
int tls_v13;
|
||||||
|
+
|
||||||
|
+ /**
|
||||||
|
+ * client_cert_conf: Whether client certificate has been configured
|
||||||
|
+ */
|
||||||
|
+ bool client_cert_conf;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/wpa_supplicant/wpa_supplicant.conf b/wpa_supplicant/wpa_supplicant.conf
|
||||||
|
index f0b82443e..1b09f57d3 100644
|
||||||
|
--- a/wpa_supplicant/wpa_supplicant.conf
|
||||||
|
+++ b/wpa_supplicant/wpa_supplicant.conf
|
||||||
|
@@ -1370,6 +1370,13 @@ fast_reauth=1
|
||||||
|
# * 0 = do not use cryptobinding (default)
|
||||||
|
# * 1 = use cryptobinding if server supports it
|
||||||
|
# * 2 = require cryptobinding
|
||||||
|
+# 'phase2_auth' option can be used to control Phase 2 (i.e., within TLS
|
||||||
|
+# tunnel) behavior for PEAP:
|
||||||
|
+# * 0 = do not require Phase 2 authentication
|
||||||
|
+# * 1 = require Phase 2 authentication when client certificate
|
||||||
|
+# (private_key/client_cert) is no used and TLS session resumption was
|
||||||
|
+# not used (default)
|
||||||
|
+# * 2 = require Phase 2 authentication in all cases
|
||||||
|
# EAP-WSC (WPS) uses following options: pin=<Device Password> or
|
||||||
|
# pbc=1.
|
||||||
|
#
|
||||||
|
--
|
||||||
|
cgit v1.2.3-18-g5258
|
||||||
|
|
51
Revert-Mark-authorization-completed-on-driver-indica.patch
Normal file
51
Revert-Mark-authorization-completed-on-driver-indica.patch
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
From c970f0f54fd33307e90e355f40d436dfa084c35e Mon Sep 17 00:00:00 2001
|
||||||
|
From: Clemens Famulla-Conrad <cfamullaconrad@suse.de>
|
||||||
|
Date: Fri, 20 Sep 2024 12:35:04 +0200
|
||||||
|
Subject: [PATCH] Revert "Mark authorization completed on driver indication
|
||||||
|
during 4-way HS offload"
|
||||||
|
Reference: bsc#1230797
|
||||||
|
|
||||||
|
This reverts commit 41638606054a09867fe3f9a2b5523aa4678cbfa5.
|
||||||
|
---
|
||||||
|
wpa_supplicant/events.c | 25 ++++++++-----------------
|
||||||
|
1 file changed, 8 insertions(+), 17 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/wpa_supplicant/events.c b/wpa_supplicant/events.c
|
||||||
|
index 49917f7aa..bbb3a3eda 100644
|
||||||
|
--- a/wpa_supplicant/events.c
|
||||||
|
+++ b/wpa_supplicant/events.c
|
||||||
|
@@ -4327,23 +4327,14 @@ static void wpa_supplicant_event_assoc(struct wpa_supplicant *wpa_s,
|
||||||
|
eapol_sm_notify_eap_success(wpa_s->eapol, true);
|
||||||
|
} else if ((wpa_s->drv_flags & WPA_DRIVER_FLAGS_4WAY_HANDSHAKE_PSK) &&
|
||||||
|
wpa_key_mgmt_wpa_psk(wpa_s->key_mgmt)) {
|
||||||
|
- if (already_authorized) {
|
||||||
|
- /*
|
||||||
|
- * We are done; the driver will take care of RSN 4-way
|
||||||
|
- * handshake.
|
||||||
|
- */
|
||||||
|
- wpa_supplicant_cancel_auth_timeout(wpa_s);
|
||||||
|
- wpa_supplicant_set_state(wpa_s, WPA_COMPLETED);
|
||||||
|
- eapol_sm_notify_portValid(wpa_s->eapol, true);
|
||||||
|
- eapol_sm_notify_eap_success(wpa_s->eapol, true);
|
||||||
|
- } else {
|
||||||
|
- /* Update port, WPA_COMPLETED state from the
|
||||||
|
- * EVENT_PORT_AUTHORIZED handler when the driver is done
|
||||||
|
- * with the 4-way handshake.
|
||||||
|
- */
|
||||||
|
- wpa_msg(wpa_s, MSG_DEBUG,
|
||||||
|
- "ASSOC INFO: wait for driver port authorized indication");
|
||||||
|
- }
|
||||||
|
+ /*
|
||||||
|
+ * We are done; the driver will take care of RSN 4-way
|
||||||
|
+ * handshake.
|
||||||
|
+ */
|
||||||
|
+ wpa_supplicant_cancel_auth_timeout(wpa_s);
|
||||||
|
+ wpa_supplicant_set_state(wpa_s, WPA_COMPLETED);
|
||||||
|
+ eapol_sm_notify_portValid(wpa_s->eapol, true);
|
||||||
|
+ eapol_sm_notify_eap_success(wpa_s->eapol, true);
|
||||||
|
} else if ((wpa_s->drv_flags & WPA_DRIVER_FLAGS_4WAY_HANDSHAKE_8021X) &&
|
||||||
|
wpa_key_mgmt_wpa_ieee8021x(wpa_s->key_mgmt)) {
|
||||||
|
/*
|
||||||
|
--
|
||||||
|
2.43.0
|
||||||
|
|
640
config
Normal file
640
config
Normal file
@ -0,0 +1,640 @@
|
|||||||
|
# Example wpa_supplicant build time configuration
|
||||||
|
#
|
||||||
|
# This file lists the configuration options that are used when building the
|
||||||
|
# wpa_supplicant binary. All lines starting with # are ignored. Configuration
|
||||||
|
# option lines must be commented out complete, if they are not to be included,
|
||||||
|
# i.e., just setting VARIABLE=n is not disabling that variable.
|
||||||
|
#
|
||||||
|
# This file is included in Makefile, so variables like CFLAGS and LIBS can also
|
||||||
|
# be modified from here. In most cases, these lines should use += in order not
|
||||||
|
# to override previous values of the variables.
|
||||||
|
|
||||||
|
|
||||||
|
# Uncomment following two lines and fix the paths if you have installed OpenSSL
|
||||||
|
# or GnuTLS in non-default location
|
||||||
|
#CFLAGS += -I/usr/local/openssl/include
|
||||||
|
#LIBS += -L/usr/local/openssl/lib
|
||||||
|
|
||||||
|
# Some Red Hat versions seem to include kerberos header files from OpenSSL, but
|
||||||
|
# the kerberos files are not in the default include path. Following line can be
|
||||||
|
# used to fix build issues on such systems (krb5.h not found).
|
||||||
|
#CFLAGS += -I/usr/include/kerberos
|
||||||
|
|
||||||
|
# Driver interface for generic Linux wireless extensions
|
||||||
|
# Note: WEXT is deprecated in the current Linux kernel version and no new
|
||||||
|
# functionality is added to it. nl80211-based interface is the new
|
||||||
|
# replacement for WEXT and its use allows wpa_supplicant to properly control
|
||||||
|
# the driver to improve existing functionality like roaming and to support new
|
||||||
|
# functionality.
|
||||||
|
CONFIG_DRIVER_WEXT=y
|
||||||
|
|
||||||
|
# Driver interface for Linux drivers using the nl80211 kernel interface
|
||||||
|
CONFIG_DRIVER_NL80211=y
|
||||||
|
|
||||||
|
# QCA vendor extensions to nl80211
|
||||||
|
CONFIG_DRIVER_NL80211_QCA=y
|
||||||
|
|
||||||
|
# driver_nl80211.c requires libnl. If you are compiling it yourself
|
||||||
|
# you may need to point hostapd to your version of libnl.
|
||||||
|
#
|
||||||
|
#CFLAGS += -I$<path to libnl include files>
|
||||||
|
#LIBS += -L$<path to libnl library files>
|
||||||
|
|
||||||
|
# Use libnl v2.0 (or 3.0) libraries.
|
||||||
|
#CONFIG_LIBNL20=y
|
||||||
|
|
||||||
|
# Use libnl 3.2 libraries (if this is selected, CONFIG_LIBNL20 is ignored)
|
||||||
|
CONFIG_LIBNL32=y
|
||||||
|
|
||||||
|
|
||||||
|
# Driver interface for FreeBSD net80211 layer (e.g., Atheros driver)
|
||||||
|
#CONFIG_DRIVER_BSD=y
|
||||||
|
#CFLAGS += -I/usr/local/include
|
||||||
|
#LIBS += -L/usr/local/lib
|
||||||
|
#LIBS_p += -L/usr/local/lib
|
||||||
|
#LIBS_c += -L/usr/local/lib
|
||||||
|
|
||||||
|
# Driver interface for Windows NDIS
|
||||||
|
#CONFIG_DRIVER_NDIS=y
|
||||||
|
#CFLAGS += -I/usr/include/w32api/ddk
|
||||||
|
#LIBS += -L/usr/local/lib
|
||||||
|
# For native build using mingw
|
||||||
|
#CONFIG_NATIVE_WINDOWS=y
|
||||||
|
# Additional directories for cross-compilation on Linux host for mingw target
|
||||||
|
#CFLAGS += -I/opt/mingw/mingw32/include/ddk
|
||||||
|
#LIBS += -L/opt/mingw/mingw32/lib
|
||||||
|
#CC=mingw32-gcc
|
||||||
|
# By default, driver_ndis uses WinPcap for low-level operations. This can be
|
||||||
|
# replaced with the following option which replaces WinPcap calls with NDISUIO.
|
||||||
|
# However, this requires that WZC is disabled (net stop wzcsvc) before starting
|
||||||
|
# wpa_supplicant.
|
||||||
|
# CONFIG_USE_NDISUIO=y
|
||||||
|
|
||||||
|
# Driver interface for wired Ethernet drivers
|
||||||
|
CONFIG_DRIVER_WIRED=y
|
||||||
|
|
||||||
|
# Driver interface for MACsec capable Qualcomm Atheros drivers
|
||||||
|
#CONFIG_DRIVER_MACSEC_QCA=y
|
||||||
|
|
||||||
|
# Driver interface for Linux MACsec drivers
|
||||||
|
CONFIG_DRIVER_MACSEC_LINUX=y
|
||||||
|
|
||||||
|
# Driver interface for the Broadcom RoboSwitch family
|
||||||
|
#CONFIG_DRIVER_ROBOSWITCH=y
|
||||||
|
|
||||||
|
# Driver interface for no driver (e.g., WPS ER only)
|
||||||
|
CONFIG_DRIVER_NONE=y
|
||||||
|
|
||||||
|
# Solaris libraries
|
||||||
|
#LIBS += -lsocket -ldlpi -lnsl
|
||||||
|
#LIBS_c += -lsocket
|
||||||
|
|
||||||
|
# Enable IEEE 802.1X Supplicant (automatically included if any EAP method or
|
||||||
|
# MACsec is included)
|
||||||
|
CONFIG_IEEE8021X_EAPOL=y
|
||||||
|
|
||||||
|
# EAP-MD5
|
||||||
|
CONFIG_EAP_MD5=y
|
||||||
|
|
||||||
|
# EAP-MSCHAPv2
|
||||||
|
CONFIG_EAP_MSCHAPV2=y
|
||||||
|
|
||||||
|
# EAP-TLS
|
||||||
|
CONFIG_EAP_TLS=y
|
||||||
|
|
||||||
|
# EAL-PEAP
|
||||||
|
CONFIG_EAP_PEAP=y
|
||||||
|
|
||||||
|
# EAP-TTLS
|
||||||
|
CONFIG_EAP_TTLS=y
|
||||||
|
|
||||||
|
# EAP-FAST
|
||||||
|
CONFIG_EAP_FAST=y
|
||||||
|
|
||||||
|
# EAP-TEAP
|
||||||
|
# Note: The current EAP-TEAP implementation is experimental and should not be
|
||||||
|
# enabled for production use. The IETF RFC 7170 that defines EAP-TEAP has number
|
||||||
|
# of conflicting statements and missing details and the implementation has
|
||||||
|
# vendor specific workarounds for those and as such, may not interoperate with
|
||||||
|
# any other implementation. This should not be used for anything else than
|
||||||
|
# experimentation and interoperability testing until those issues has been
|
||||||
|
# resolved.
|
||||||
|
#CONFIG_EAP_TEAP=y
|
||||||
|
|
||||||
|
# EAP-GTC
|
||||||
|
CONFIG_EAP_GTC=y
|
||||||
|
|
||||||
|
# EAP-OTP
|
||||||
|
CONFIG_EAP_OTP=y
|
||||||
|
|
||||||
|
# EAP-SIM (enable CONFIG_PCSC, if EAP-SIM is used)
|
||||||
|
#CONFIG_EAP_SIM=y
|
||||||
|
|
||||||
|
# Enable SIM simulator (Milenage) for EAP-SIM
|
||||||
|
#CONFIG_SIM_SIMULATOR=y
|
||||||
|
|
||||||
|
# EAP-PSK (experimental; this is _not_ needed for WPA-PSK)
|
||||||
|
#CONFIG_EAP_PSK=y
|
||||||
|
|
||||||
|
# EAP-pwd (secure authentication using only a password)
|
||||||
|
CONFIG_EAP_PWD=y
|
||||||
|
|
||||||
|
# EAP-PAX
|
||||||
|
CONFIG_EAP_PAX=y
|
||||||
|
|
||||||
|
# LEAP
|
||||||
|
CONFIG_EAP_LEAP=y
|
||||||
|
|
||||||
|
# EAP-AKA (enable CONFIG_PCSC, if EAP-AKA is used)
|
||||||
|
CONFIG_EAP_AKA=y
|
||||||
|
|
||||||
|
# EAP-AKA' (enable CONFIG_PCSC, if EAP-AKA' is used).
|
||||||
|
# This requires CONFIG_EAP_AKA to be enabled, too.
|
||||||
|
CONFIG_EAP_AKA_PRIME=y
|
||||||
|
|
||||||
|
# Enable USIM simulator (Milenage) for EAP-AKA
|
||||||
|
#CONFIG_USIM_SIMULATOR=y
|
||||||
|
|
||||||
|
# EAP-SAKE
|
||||||
|
CONFIG_EAP_SAKE=y
|
||||||
|
|
||||||
|
# EAP-GPSK
|
||||||
|
CONFIG_EAP_GPSK=y
|
||||||
|
# Include support for optional SHA256 cipher suite in EAP-GPSK
|
||||||
|
CONFIG_EAP_GPSK_SHA256=y
|
||||||
|
|
||||||
|
# EAP-TNC and related Trusted Network Connect support (experimental)
|
||||||
|
CONFIG_EAP_TNC=y
|
||||||
|
|
||||||
|
# Wi-Fi Protected Setup (WPS)
|
||||||
|
CONFIG_WPS=y
|
||||||
|
# Enable WPS external registrar functionality
|
||||||
|
CONFIG_WPS_ER=y
|
||||||
|
# Disable credentials for an open network by default when acting as a WPS
|
||||||
|
# registrar.
|
||||||
|
CONFIG_WPS_REG_DISABLE_OPEN=y
|
||||||
|
# Enable WPS support with NFC config method
|
||||||
|
CONFIG_WPS_NFC=y
|
||||||
|
|
||||||
|
# EAP-IKEv2
|
||||||
|
CONFIG_EAP_IKEV2=y
|
||||||
|
|
||||||
|
# EAP-EKE
|
||||||
|
CONFIG_EAP_EKE=y
|
||||||
|
|
||||||
|
# MACsec
|
||||||
|
CONFIG_MACSEC=y
|
||||||
|
|
||||||
|
# PKCS#12 (PFX) support (used to read private key and certificate file from
|
||||||
|
# a file that usually has extension .p12 or .pfx)
|
||||||
|
CONFIG_PKCS12=y
|
||||||
|
|
||||||
|
# Smartcard support (i.e., private key on a smartcard), e.g., with openssl
|
||||||
|
# engine.
|
||||||
|
CONFIG_SMARTCARD=y
|
||||||
|
|
||||||
|
# PC/SC interface for smartcards (USIM, GSM SIM)
|
||||||
|
# Enable this if EAP-SIM or EAP-AKA is included
|
||||||
|
#CONFIG_PCSC=y
|
||||||
|
|
||||||
|
# Support HT overrides (disable HT/HT40, mask MCS rates, etc.)
|
||||||
|
CONFIG_HT_OVERRIDES=y
|
||||||
|
|
||||||
|
# Support VHT overrides (disable VHT, mask MCS rates, etc.)
|
||||||
|
CONFIG_VHT_OVERRIDES=y
|
||||||
|
|
||||||
|
# Development testing
|
||||||
|
#CONFIG_EAPOL_TEST=y
|
||||||
|
|
||||||
|
# Select control interface backend for external programs, e.g, wpa_cli:
|
||||||
|
# unix = UNIX domain sockets (default for Linux/*BSD)
|
||||||
|
# udp = UDP sockets using localhost (127.0.0.1)
|
||||||
|
# udp6 = UDP IPv6 sockets using localhost (::1)
|
||||||
|
# named_pipe = Windows Named Pipe (default for Windows)
|
||||||
|
# udp-remote = UDP sockets with remote access (only for tests systems/purpose)
|
||||||
|
# udp6-remote = UDP IPv6 sockets with remote access (only for tests purpose)
|
||||||
|
# y = use default (backwards compatibility)
|
||||||
|
# If this option is commented out, control interface is not included in the
|
||||||
|
# build.
|
||||||
|
CONFIG_CTRL_IFACE=y
|
||||||
|
|
||||||
|
# Include support for GNU Readline and History Libraries in wpa_cli.
|
||||||
|
# When building a wpa_cli binary for distribution, please note that these
|
||||||
|
# libraries are licensed under GPL and as such, BSD license may not apply for
|
||||||
|
# the resulting binary.
|
||||||
|
#CONFIG_READLINE=y
|
||||||
|
|
||||||
|
# Include internal line edit mode in wpa_cli. This can be used as a replacement
|
||||||
|
# for GNU Readline to provide limited command line editing and history support.
|
||||||
|
#CONFIG_WPA_CLI_EDIT=y
|
||||||
|
|
||||||
|
# Remove debugging code that is printing out debug message to stdout.
|
||||||
|
# This can be used to reduce the size of the wpa_supplicant considerably
|
||||||
|
# if debugging code is not needed. The size reduction can be around 35%
|
||||||
|
# (e.g., 90 kB).
|
||||||
|
#CONFIG_NO_STDOUT_DEBUG=y
|
||||||
|
|
||||||
|
# Remove WPA support, e.g., for wired-only IEEE 802.1X supplicant, to save
|
||||||
|
# 35-50 kB in code size.
|
||||||
|
#CONFIG_NO_WPA=y
|
||||||
|
|
||||||
|
# Remove IEEE 802.11i/WPA-Personal ASCII passphrase support
|
||||||
|
# This option can be used to reduce code size by removing support for
|
||||||
|
# converting ASCII passphrases into PSK. If this functionality is removed, the
|
||||||
|
# PSK can only be configured as the 64-octet hexstring (e.g., from
|
||||||
|
# wpa_passphrase). This saves about 0.5 kB in code size.
|
||||||
|
#CONFIG_NO_WPA_PASSPHRASE=y
|
||||||
|
|
||||||
|
# Simultaneous Authentication of Equals (SAE), WPA3-Personal
|
||||||
|
CONFIG_SAE=y
|
||||||
|
|
||||||
|
# WPA3-Enterprise (SuiteB-192)
|
||||||
|
CONFIG_SUITEB=y
|
||||||
|
CONFIG_SUITEB192=y
|
||||||
|
|
||||||
|
# Disable scan result processing (ap_scan=1) to save code size by about 1 kB.
|
||||||
|
# This can be used if ap_scan=1 mode is never enabled.
|
||||||
|
#CONFIG_NO_SCAN_PROCESSING=y
|
||||||
|
|
||||||
|
# Select configuration backend:
|
||||||
|
# file = text file (e.g., wpa_supplicant.conf; note: the configuration file
|
||||||
|
# path is given on command line, not here; this option is just used to
|
||||||
|
# select the backend that allows configuration files to be used)
|
||||||
|
# winreg = Windows registry (see win_example.reg for an example)
|
||||||
|
CONFIG_BACKEND=file
|
||||||
|
|
||||||
|
# Remove configuration write functionality (i.e., to allow the configuration
|
||||||
|
# file to be updated based on runtime configuration changes). The runtime
|
||||||
|
# configuration can still be changed, the changes are just not going to be
|
||||||
|
# persistent over restarts. This option can be used to reduce code size by
|
||||||
|
# about 3.5 kB.
|
||||||
|
#CONFIG_NO_CONFIG_WRITE=y
|
||||||
|
|
||||||
|
# Remove support for configuration blobs to reduce code size by about 1.5 kB.
|
||||||
|
#CONFIG_NO_CONFIG_BLOBS=y
|
||||||
|
|
||||||
|
# Select program entry point implementation:
|
||||||
|
# main = UNIX/POSIX like main() function (default)
|
||||||
|
# main_winsvc = Windows service (read parameters from registry)
|
||||||
|
# main_none = Very basic example (development use only)
|
||||||
|
#CONFIG_MAIN=main
|
||||||
|
|
||||||
|
# Select wrapper for operating system and C library specific functions
|
||||||
|
# unix = UNIX/POSIX like systems (default)
|
||||||
|
# win32 = Windows systems
|
||||||
|
# none = Empty template
|
||||||
|
CONFIG_OS=unix
|
||||||
|
|
||||||
|
# Select event loop implementation
|
||||||
|
# eloop = select() loop (default)
|
||||||
|
# eloop_win = Windows events and WaitForMultipleObject() loop
|
||||||
|
CONFIG_ELOOP=eloop
|
||||||
|
|
||||||
|
# Should we use poll instead of select? Select is used by default.
|
||||||
|
#CONFIG_ELOOP_POLL=y
|
||||||
|
|
||||||
|
# Should we use epoll instead of select? Select is used by default.
|
||||||
|
#CONFIG_ELOOP_EPOLL=y
|
||||||
|
|
||||||
|
# Should we use kqueue instead of select? Select is used by default.
|
||||||
|
#CONFIG_ELOOP_KQUEUE=y
|
||||||
|
|
||||||
|
# Select layer 2 packet implementation
|
||||||
|
# linux = Linux packet socket (default)
|
||||||
|
# pcap = libpcap/libdnet/WinPcap
|
||||||
|
# freebsd = FreeBSD libpcap
|
||||||
|
# winpcap = WinPcap with receive thread
|
||||||
|
# ndis = Windows NDISUIO (note: requires CONFIG_USE_NDISUIO=y)
|
||||||
|
# none = Empty template
|
||||||
|
CONFIG_L2_PACKET=linux
|
||||||
|
|
||||||
|
# Disable Linux packet socket workaround applicable for station interface
|
||||||
|
# in a bridge for EAPOL frames. This should be uncommented only if the kernel
|
||||||
|
# is known to not have the regression issue in packet socket behavior with
|
||||||
|
# bridge interfaces (commit 'bridge: respect RFC2863 operational state')').
|
||||||
|
#CONFIG_NO_LINUX_PACKET_SOCKET_WAR=y
|
||||||
|
|
||||||
|
# Support Operating Channel Validation
|
||||||
|
CONFIG_OCV=y
|
||||||
|
|
||||||
|
# Select TLS implementation
|
||||||
|
# openssl = OpenSSL (default)
|
||||||
|
# gnutls = GnuTLS
|
||||||
|
# internal = Internal TLSv1 implementation (experimental)
|
||||||
|
# linux = Linux kernel AF_ALG and internal TLSv1 implementation (experimental)
|
||||||
|
# none = Empty template
|
||||||
|
CONFIG_TLS=openssl
|
||||||
|
|
||||||
|
# TLS-based EAP methods require at least TLS v1.0. Newer version of TLS (v1.1)
|
||||||
|
# can be enabled to get a stronger construction of messages when block ciphers
|
||||||
|
# are used. It should be noted that some existing TLS v1.0 -based
|
||||||
|
# implementation may not be compatible with TLS v1.1 message (ClientHello is
|
||||||
|
# sent prior to negotiating which version will be used)
|
||||||
|
CONFIG_TLSV11=y
|
||||||
|
|
||||||
|
# TLS-based EAP methods require at least TLS v1.0. Newer version of TLS (v1.2)
|
||||||
|
# can be enabled to enable use of stronger crypto algorithms. It should be
|
||||||
|
# noted that some existing TLS v1.0 -based implementation may not be compatible
|
||||||
|
# with TLS v1.2 message (ClientHello is sent prior to negotiating which version
|
||||||
|
# will be used)
|
||||||
|
CONFIG_TLSV12=y
|
||||||
|
|
||||||
|
# Select which ciphers to use by default with OpenSSL if the user does not
|
||||||
|
# specify them.
|
||||||
|
CONFIG_TLS_DEFAULT_CIPHERS="DEFAULT@SECLEVEL=1"
|
||||||
|
|
||||||
|
# If CONFIG_TLS=internal is used, additional library and include paths are
|
||||||
|
# needed for LibTomMath. Alternatively, an integrated, minimal version of
|
||||||
|
# LibTomMath can be used. See beginning of libtommath.c for details on benefits
|
||||||
|
# and drawbacks of this option.
|
||||||
|
#CONFIG_INTERNAL_LIBTOMMATH=y
|
||||||
|
#ifndef CONFIG_INTERNAL_LIBTOMMATH
|
||||||
|
#LTM_PATH=/usr/src/libtommath-0.39
|
||||||
|
#CFLAGS += -I$(LTM_PATH)
|
||||||
|
#LIBS += -L$(LTM_PATH)
|
||||||
|
#LIBS_p += -L$(LTM_PATH)
|
||||||
|
#endif
|
||||||
|
# At the cost of about 4 kB of additional binary size, the internal LibTomMath
|
||||||
|
# can be configured to include faster routines for exptmod, sqr, and div to
|
||||||
|
# speed up DH and RSA calculation considerably
|
||||||
|
#CONFIG_INTERNAL_LIBTOMMATH_FAST=y
|
||||||
|
|
||||||
|
# Include NDIS event processing through WMI into wpa_supplicant/wpasvc.
|
||||||
|
# This is only for Windows builds and requires WMI-related header files and
|
||||||
|
# WbemUuid.Lib from Platform SDK even when building with MinGW.
|
||||||
|
#CONFIG_NDIS_EVENTS_INTEGRATED=y
|
||||||
|
#PLATFORMSDKLIB="/opt/Program Files/Microsoft Platform SDK/Lib"
|
||||||
|
|
||||||
|
# Add support for new DBus control interface
|
||||||
|
# (fi.w1.wpa_supplicant1)
|
||||||
|
CONFIG_CTRL_IFACE_DBUS_NEW=y
|
||||||
|
|
||||||
|
# Add introspection support for new DBus control interface
|
||||||
|
CONFIG_CTRL_IFACE_DBUS_INTRO=y
|
||||||
|
|
||||||
|
# Add support for loading EAP methods dynamically as shared libraries.
|
||||||
|
# When this option is enabled, each EAP method can be either included
|
||||||
|
# statically (CONFIG_EAP_<method>=y) or dynamically (CONFIG_EAP_<method>=dyn).
|
||||||
|
# Dynamic EAP methods are build as shared objects (eap_*.so) and they need to
|
||||||
|
# be loaded in the beginning of the wpa_supplicant configuration file
|
||||||
|
# (see load_dynamic_eap parameter in the example file) before being used in
|
||||||
|
# the network blocks.
|
||||||
|
#
|
||||||
|
# Note that some shared parts of EAP methods are included in the main program
|
||||||
|
# and in order to be able to use dynamic EAP methods using these parts, the
|
||||||
|
# main program must have been build with the EAP method enabled (=y or =dyn).
|
||||||
|
# This means that EAP-TLS/PEAP/TTLS/FAST cannot be added as dynamic libraries
|
||||||
|
# unless at least one of them was included in the main build to force inclusion
|
||||||
|
# of the shared code. Similarly, at least one of EAP-SIM/AKA must be included
|
||||||
|
# in the main build to be able to load these methods dynamically.
|
||||||
|
#
|
||||||
|
# Please also note that using dynamic libraries will increase the total binary
|
||||||
|
# size. Thus, it may not be the best option for targets that have limited
|
||||||
|
# amount of memory/flash.
|
||||||
|
#CONFIG_DYNAMIC_EAP_METHODS=y
|
||||||
|
|
||||||
|
# IEEE Std 802.11r-2008 (Fast BSS Transition) for station mode
|
||||||
|
# CONFIG_IEEE80211R=y
|
||||||
|
CONFIG_IEEE80211R=y
|
||||||
|
|
||||||
|
# Add support for writing debug log to a file (/tmp/wpa_supplicant-log-#.txt)
|
||||||
|
CONFIG_DEBUG_FILE=y
|
||||||
|
|
||||||
|
# Send debug messages to syslog instead of stdout
|
||||||
|
# CONFIG_DEBUG_SYSLOG=y
|
||||||
|
# Set syslog facility for debug messages
|
||||||
|
#CONFIG_DEBUG_SYSLOG_FACILITY=LOG_DAEMON
|
||||||
|
|
||||||
|
# Add support for sending all debug messages (regardless of debug verbosity)
|
||||||
|
# to the Linux kernel tracing facility. This helps debug the entire stack by
|
||||||
|
# making it easy to record everything happening from the driver up into the
|
||||||
|
# same file, e.g., using trace-cmd.
|
||||||
|
#CONFIG_DEBUG_LINUX_TRACING=y
|
||||||
|
|
||||||
|
# Add support for writing debug log to Android logcat instead of standard
|
||||||
|
# output
|
||||||
|
#CONFIG_ANDROID_LOG=y
|
||||||
|
|
||||||
|
# Enable privilege separation (see README 'Privilege separation' for details)
|
||||||
|
#CONFIG_PRIVSEP=y
|
||||||
|
|
||||||
|
# Enable mitigation against certain attacks against TKIP by delaying Michael
|
||||||
|
# MIC error reports by a random amount of time between 0 and 60 seconds
|
||||||
|
CONFIG_DELAYED_MIC_ERROR_REPORT=y
|
||||||
|
|
||||||
|
# Enable tracing code for developer debugging
|
||||||
|
# This tracks use of memory allocations and other registrations and reports
|
||||||
|
# incorrect use with a backtrace of call (or allocation) location.
|
||||||
|
#CONFIG_WPA_TRACE=y
|
||||||
|
# For BSD, uncomment these.
|
||||||
|
#LIBS += -lexecinfo
|
||||||
|
#LIBS_p += -lexecinfo
|
||||||
|
#LIBS_c += -lexecinfo
|
||||||
|
|
||||||
|
# Use libbfd to get more details for developer debugging
|
||||||
|
# This enables use of libbfd to get more detailed symbols for the backtraces
|
||||||
|
# generated by CONFIG_WPA_TRACE=y.
|
||||||
|
#CONFIG_WPA_TRACE_BFD=y
|
||||||
|
# For BSD, uncomment these.
|
||||||
|
#LIBS += -lbfd -liberty -lz
|
||||||
|
#LIBS_p += -lbfd -liberty -lz
|
||||||
|
#LIBS_c += -lbfd -liberty -lz
|
||||||
|
|
||||||
|
# wpa_supplicant depends on strong random number generation being available
|
||||||
|
# from the operating system. os_get_random() function is used to fetch random
|
||||||
|
# data when needed, e.g., for key generation. On Linux and BSD systems, this
|
||||||
|
# works by reading /dev/urandom. It should be noted that the OS entropy pool
|
||||||
|
# needs to be properly initialized before wpa_supplicant is started. This is
|
||||||
|
# important especially on embedded devices that do not have a hardware random
|
||||||
|
# number generator and may by default start up with minimal entropy available
|
||||||
|
# for random number generation.
|
||||||
|
#
|
||||||
|
# As a safety net, wpa_supplicant is by default trying to internally collect
|
||||||
|
# additional entropy for generating random data to mix in with the data fetched
|
||||||
|
# from the OS. This by itself is not considered to be very strong, but it may
|
||||||
|
# help in cases where the system pool is not initialized properly. However, it
|
||||||
|
# is very strongly recommended that the system pool is initialized with enough
|
||||||
|
# entropy either by using hardware assisted random number generator or by
|
||||||
|
# storing state over device reboots.
|
||||||
|
#
|
||||||
|
# wpa_supplicant can be configured to maintain its own entropy store over
|
||||||
|
# restarts to enhance random number generation. This is not perfect, but it is
|
||||||
|
# much more secure than using the same sequence of random numbers after every
|
||||||
|
# reboot. This can be enabled with -e<entropy file> command line option. The
|
||||||
|
# specified file needs to be readable and writable by wpa_supplicant.
|
||||||
|
#
|
||||||
|
# If the os_get_random() is known to provide strong random data (e.g., on
|
||||||
|
# Linux/BSD, the board in question is known to have reliable source of random
|
||||||
|
# data from /dev/urandom), the internal wpa_supplicant random pool can be
|
||||||
|
# disabled. This will save some in binary size and CPU use. However, this
|
||||||
|
# should only be considered for builds that are known to be used on devices
|
||||||
|
# that meet the requirements described above.
|
||||||
|
CONFIG_NO_RANDOM_POOL=y
|
||||||
|
|
||||||
|
# Should we attempt to use the getrandom(2) call that provides more reliable
|
||||||
|
# yet secure randomness source than /dev/random on Linux 3.17 and newer.
|
||||||
|
# Requires glibc 2.25 to build, falls back to /dev/random if unavailable.
|
||||||
|
CONFIG_GETRANDOM=y
|
||||||
|
|
||||||
|
# IEEE 802.11ac (Very High Throughput) support (mainly for AP mode)
|
||||||
|
CONFIG_IEEE80211AC=y
|
||||||
|
|
||||||
|
# Wireless Network Management (IEEE Std 802.11v-2011)
|
||||||
|
# Note: This is experimental and not complete implementation.
|
||||||
|
#CONFIG_WNM=y
|
||||||
|
|
||||||
|
# Interworking (IEEE 802.11u)
|
||||||
|
# This can be used to enable functionality to improve interworking with
|
||||||
|
# external networks (GAS/ANQP to learn more about the networks and network
|
||||||
|
# selection based on available credentials).
|
||||||
|
CONFIG_INTERWORKING=y
|
||||||
|
|
||||||
|
# Hotspot 2.0
|
||||||
|
CONFIG_HS20=y
|
||||||
|
|
||||||
|
# Enable interface matching in wpa_supplicant
|
||||||
|
#CONFIG_MATCH_IFACE=y
|
||||||
|
|
||||||
|
# Disable roaming in wpa_supplicant
|
||||||
|
#CONFIG_NO_ROAMING=y
|
||||||
|
|
||||||
|
# AP mode operations with wpa_supplicant
|
||||||
|
# This can be used for controlling AP mode operations with wpa_supplicant. It
|
||||||
|
# should be noted that this is mainly aimed at simple cases like
|
||||||
|
# WPA2-Personal while more complex configurations like WPA2-Enterprise with an
|
||||||
|
# external RADIUS server can be supported with hostapd.
|
||||||
|
CONFIG_AP=y
|
||||||
|
|
||||||
|
# P2P (Wi-Fi Direct)
|
||||||
|
# This can be used to enable P2P support in wpa_supplicant. See README-P2P for
|
||||||
|
# more information on P2P operations.
|
||||||
|
CONFIG_P2P=y
|
||||||
|
|
||||||
|
# Enable TDLS support
|
||||||
|
CONFIG_TDLS=y
|
||||||
|
|
||||||
|
# Wi-Fi Display
|
||||||
|
# This can be used to enable Wi-Fi Display extensions for P2P using an external
|
||||||
|
# program to control the additional information exchanges in the messages.
|
||||||
|
CONFIG_WIFI_DISPLAY=y
|
||||||
|
|
||||||
|
# Autoscan
|
||||||
|
# This can be used to enable automatic scan support in wpa_supplicant.
|
||||||
|
# See wpa_supplicant.conf for more information on autoscan usage.
|
||||||
|
#
|
||||||
|
# Enabling directly a module will enable autoscan support.
|
||||||
|
# For exponential module:
|
||||||
|
CONFIG_AUTOSCAN_EXPONENTIAL=y
|
||||||
|
# For periodic module:
|
||||||
|
CONFIG_AUTOSCAN_PERIODIC=y
|
||||||
|
|
||||||
|
# Password (and passphrase, etc.) backend for external storage
|
||||||
|
# These optional mechanisms can be used to add support for storing passwords
|
||||||
|
# and other secrets in external (to wpa_supplicant) location. This allows, for
|
||||||
|
# example, operating system specific key storage to be used
|
||||||
|
#
|
||||||
|
# External password backend for testing purposes (developer use)
|
||||||
|
#CONFIG_EXT_PASSWORD_TEST=y
|
||||||
|
# File-based backend to read passwords from an external file.
|
||||||
|
#CONFIG_EXT_PASSWORD_FILE=y
|
||||||
|
|
||||||
|
# Enable Fast Session Transfer (FST)
|
||||||
|
CONFIG_FST=y
|
||||||
|
|
||||||
|
# Enable CLI commands for FST testing
|
||||||
|
#CONFIG_FST_TEST=y
|
||||||
|
|
||||||
|
# OS X builds. This is only for building eapol_test.
|
||||||
|
#CONFIG_OSX=y
|
||||||
|
|
||||||
|
# Automatic Channel Selection
|
||||||
|
# This will allow wpa_supplicant to pick the channel automatically when channel
|
||||||
|
# is set to "0".
|
||||||
|
#
|
||||||
|
# TODO: Extend parser to be able to parse "channel=acs_survey" as an alternative
|
||||||
|
# to "channel=0". This would enable us to eventually add other ACS algorithms in
|
||||||
|
# similar way.
|
||||||
|
#
|
||||||
|
# Automatic selection is currently only done through initialization, later on
|
||||||
|
# we hope to do background checks to keep us moving to more ideal channels as
|
||||||
|
# time goes by. ACS is currently only supported through the nl80211 driver and
|
||||||
|
# your driver must have survey dump capability that is filled by the driver
|
||||||
|
# during scanning.
|
||||||
|
#
|
||||||
|
# TODO: In analogy to hostapd be able to customize the ACS survey algorithm with
|
||||||
|
# a newly to create wpa_supplicant.conf variable acs_num_scans.
|
||||||
|
#
|
||||||
|
# Supported ACS drivers:
|
||||||
|
# * ath9k
|
||||||
|
# * ath5k
|
||||||
|
# * ath10k
|
||||||
|
#
|
||||||
|
# For more details refer to:
|
||||||
|
# http://wireless.kernel.org/en/users/Documentation/acs
|
||||||
|
CONFIG_ACS=y
|
||||||
|
|
||||||
|
# Support Multi Band Operation
|
||||||
|
CONFIG_MBO=y
|
||||||
|
|
||||||
|
# Fast Initial Link Setup (FILS) (IEEE 802.11ai)
|
||||||
|
CONFIG_FILS=y
|
||||||
|
# FILS shared key authentication with PFS
|
||||||
|
CONFIG_FILS_SK_PFS=y
|
||||||
|
|
||||||
|
# Support RSN on IBSS networks
|
||||||
|
# This is needed to be able to use mode=1 network profile with proto=RSN and
|
||||||
|
# key_mgmt=WPA-PSK (i.e., full key management instead of WPA-None).
|
||||||
|
CONFIG_IBSS_RSN=y
|
||||||
|
|
||||||
|
# External PMKSA cache control
|
||||||
|
# This can be used to enable control interface commands that allow the current
|
||||||
|
# PMKSA cache entries to be fetched and new entries to be added.
|
||||||
|
#CONFIG_PMKSA_CACHE_EXTERNAL=y
|
||||||
|
|
||||||
|
# Mesh Networking (IEEE 802.11s)
|
||||||
|
CONFIG_MESH=y
|
||||||
|
|
||||||
|
# Background scanning modules
|
||||||
|
# These can be used to request wpa_supplicant to perform background scanning
|
||||||
|
# operations for roaming within an ESS (same SSID). See the bgscan parameter in
|
||||||
|
# the wpa_supplicant.conf file for more details.
|
||||||
|
# Periodic background scans based on signal strength
|
||||||
|
CONFIG_BGSCAN_SIMPLE=y
|
||||||
|
# Learn channels used by the network and try to avoid bgscans on other
|
||||||
|
# channels (experimental)
|
||||||
|
#CONFIG_BGSCAN_LEARN=y
|
||||||
|
|
||||||
|
# Opportunistic Wireless Encryption (OWE)
|
||||||
|
# Experimental implementation of draft-harkins-owe-07.txt
|
||||||
|
CONFIG_OWE=y
|
||||||
|
|
||||||
|
# Device Provisioning Protocol (DPP) (also known as Wi-Fi Easy Connect)
|
||||||
|
CONFIG_DPP=y
|
||||||
|
# DPP version 2 support
|
||||||
|
CONFIG_DPP2=y
|
||||||
|
# DPP version 3 support (experimental and still changing; do not enable for
|
||||||
|
# production use)
|
||||||
|
#CONFIG_DPP3=y
|
||||||
|
|
||||||
|
# Wired equivalent privacy (WEP)
|
||||||
|
# WEP is an obsolete cryptographic data confidentiality algorithm that is not
|
||||||
|
# considered secure. It should not be used for anything anymore. The
|
||||||
|
# functionality needed to use WEP is available in the current wpa_supplicant
|
||||||
|
# release under this optional build parameter. This functionality is subject to
|
||||||
|
# be completely removed in a future release.
|
||||||
|
CONFIG_WEP=y
|
||||||
|
|
||||||
|
# Remove all TKIP functionality
|
||||||
|
# TKIP is an old cryptographic data confidentiality algorithm that is not
|
||||||
|
# considered secure. It should not be used anymore for anything else than a
|
||||||
|
# backwards compatibility option as a group cipher when connecting to APs that
|
||||||
|
# use WPA+WPA2 mixed mode. For now, the default wpa_supplicant build includes
|
||||||
|
# support for this by default, but that functionality is subject to be removed
|
||||||
|
# in the future.
|
||||||
|
#CONFIG_NO_TKIP=y
|
||||||
|
|
||||||
|
# Pre-Association Security Negotiation (PASN)
|
||||||
|
# Experimental implementation based on IEEE P802.11z/D2.6 and the protocol
|
||||||
|
# design is still subject to change. As such, this should not yet be enabled in
|
||||||
|
# production use.
|
||||||
|
#CONFIG_PASN=y
|
46
dbus-Fix-property-DebugShowKeys-and-DebugTimestamp.patch
Normal file
46
dbus-Fix-property-DebugShowKeys-and-DebugTimestamp.patch
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
From 903f0848ce7d67c99eb5a2569aa5c31bcd7adbc1 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Clemens Famulla-Conrad <cfamullaconrad@suse.de>
|
||||||
|
Date: Tue, 5 Jul 2022 13:04:52 +0200
|
||||||
|
Subject: [PATCH] dbus: Fix property DebugShowKeys and DebugTimestamp
|
||||||
|
|
||||||
|
It is possible to specify -t or -K multiple times. With this the
|
||||||
|
value isn't boolean anymore and we hit a assert in libdbus
|
||||||
|
function `dbus_message_iter_append_basic()`, which expect 0 or 1
|
||||||
|
for DBUS_TYPE_BOOLEAN.
|
||||||
|
|
||||||
|
Signed-off-by: Clemens Famulla-Conrad <cfamullaconrad@suse.de>
|
||||||
|
---
|
||||||
|
wpa_supplicant/dbus/dbus_new_handlers.c | 8 ++++++--
|
||||||
|
1 file changed, 6 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/wpa_supplicant/dbus/dbus_new_handlers.c b/wpa_supplicant/dbus/dbus_new_handlers.c
|
||||||
|
index 0b1002bf1..de82930e8 100644
|
||||||
|
--- a/wpa_supplicant/dbus/dbus_new_handlers.c
|
||||||
|
+++ b/wpa_supplicant/dbus/dbus_new_handlers.c
|
||||||
|
@@ -908,8 +908,10 @@ dbus_bool_t wpas_dbus_getter_debug_timestamp(
|
||||||
|
const struct wpa_dbus_property_desc *property_desc,
|
||||||
|
DBusMessageIter *iter, DBusError *error, void *user_data)
|
||||||
|
{
|
||||||
|
+ dbus_bool_t b = wpa_debug_timestamp ? TRUE : FALSE;
|
||||||
|
+
|
||||||
|
return wpas_dbus_simple_property_getter(iter, DBUS_TYPE_BOOLEAN,
|
||||||
|
- &wpa_debug_timestamp, error);
|
||||||
|
+ &b, error);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -927,8 +929,10 @@ dbus_bool_t wpas_dbus_getter_debug_show_keys(
|
||||||
|
const struct wpa_dbus_property_desc *property_desc,
|
||||||
|
DBusMessageIter *iter, DBusError *error, void *user_data)
|
||||||
|
{
|
||||||
|
+ dbus_bool_t b = wpa_debug_timestamp ? TRUE : FALSE;
|
||||||
|
+
|
||||||
|
return wpas_dbus_simple_property_getter(iter, DBUS_TYPE_BOOLEAN,
|
||||||
|
- &wpa_debug_show_keys, error);
|
||||||
|
+ &b, error);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
--
|
||||||
|
2.35.3
|
||||||
|
|
5
fi.epitest.hostap.WPASupplicant.service
Normal file
5
fi.epitest.hostap.WPASupplicant.service
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
[D-BUS Service]
|
||||||
|
Name=fi.epitest.hostap.WPASupplicant
|
||||||
|
Exec=/usr/sbin/wpa_supplicant -c /etc/wpa_supplicant/wpa_supplicant.conf -u -t -f /var/log/wpa_supplicant.log
|
||||||
|
User=root
|
||||||
|
SystemdService=wpa_supplicant.service
|
5
fi.w1.wpa_supplicant1.service
Normal file
5
fi.w1.wpa_supplicant1.service
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
[D-BUS Service]
|
||||||
|
Name=fi.w1.wpa_supplicant1
|
||||||
|
Exec=/usr/sbin/wpa_supplicant -c /etc/wpa_supplicant/wpa_supplicant.conf -u -t -f /var/log/wpa_supplicant.log
|
||||||
|
User=root
|
||||||
|
SystemdService=wpa_supplicant.service
|
10
logrotate.wpa_supplicant
Normal file
10
logrotate.wpa_supplicant
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
/var/log/wpa_supplicant.log {
|
||||||
|
compress
|
||||||
|
dateext
|
||||||
|
maxage 365
|
||||||
|
rotate 99
|
||||||
|
missingok
|
||||||
|
notifempty
|
||||||
|
size +4096k
|
||||||
|
copytruncate
|
||||||
|
}
|
BIN
wpa_supplicant-2.10.tar.gz
(Stored with Git LFS)
Normal file
BIN
wpa_supplicant-2.10.tar.gz
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
wpa_supplicant-2.11.tar.gz
(Stored with Git LFS)
Normal file
BIN
wpa_supplicant-2.11.tar.gz
(Stored with Git LFS)
Normal file
Binary file not shown.
22
wpa_supplicant-alloc_size.patch
Normal file
22
wpa_supplicant-alloc_size.patch
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
Index: wpa_supplicant-2.10/src/utils/os.h
|
||||||
|
===================================================================
|
||||||
|
--- wpa_supplicant-2.10.orig/src/utils/os.h
|
||||||
|
+++ wpa_supplicant-2.10/src/utils/os.h
|
||||||
|
@@ -260,7 +260,7 @@ int os_fdatasync(FILE *stream);
|
||||||
|
*
|
||||||
|
* Caller is responsible for freeing the returned buffer with os_free().
|
||||||
|
*/
|
||||||
|
-void * os_zalloc(size_t size);
|
||||||
|
+void * os_zalloc(size_t size) __attribute((malloc, alloc_size(1)));
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_calloc - Allocate and zero memory for an array
|
||||||
|
@@ -274,6 +274,8 @@ void * os_zalloc(size_t size);
|
||||||
|
*
|
||||||
|
* Caller is responsible for freeing the returned buffer with os_free().
|
||||||
|
*/
|
||||||
|
+
|
||||||
|
+__attribute((malloc, alloc_size(1,2)))
|
||||||
|
static inline void * os_calloc(size_t nmemb, size_t size)
|
||||||
|
{
|
||||||
|
if (size && nmemb > (~(size_t) 0) / size)
|
71
wpa_supplicant-dump-certificate-as-PEM-in-debug-mode.diff
Normal file
71
wpa_supplicant-dump-certificate-as-PEM-in-debug-mode.diff
Normal file
@ -0,0 +1,71 @@
|
|||||||
|
From f40c1d989762c4f3b585c86ca5d9a216d120fa12 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Ludwig Nussel <ludwig.nussel@suse.de>
|
||||||
|
Date: Fri, 16 Sep 2011 11:41:16 +0200
|
||||||
|
Subject: [PATCH] dump certificate as PEM in debug mode
|
||||||
|
|
||||||
|
---
|
||||||
|
src/crypto/tls_openssl.c | 13 +++++++++++++
|
||||||
|
src/utils/wpa_debug.c | 5 +++++
|
||||||
|
src/utils/wpa_debug.h | 8 ++++++++
|
||||||
|
3 files changed, 26 insertions(+)
|
||||||
|
|
||||||
|
--- a/src/crypto/tls_openssl.c
|
||||||
|
+++ b/src/crypto/tls_openssl.c
|
||||||
|
@@ -2515,6 +2515,19 @@
|
||||||
|
debug_print_cert(err_cert, buf);
|
||||||
|
X509_NAME_oneline(X509_get_subject_name(err_cert), buf, sizeof(buf));
|
||||||
|
|
||||||
|
+ if (wpa_debug_enabled(MSG_DEBUG)) {
|
||||||
|
+ long len;
|
||||||
|
+ char* data = NULL;
|
||||||
|
+ BIO* bio = BIO_new(BIO_s_mem());
|
||||||
|
+ //X509_print_ex(bio, err_cert, (XN_FLAG_MULTILINE|ASN1_STRFLGS_UTF8_CONVERT)&~ASN1_STRFLGS_ESC_MSB, 0);
|
||||||
|
+ PEM_write_bio_X509(bio, err_cert);
|
||||||
|
+ len = BIO_get_mem_data(bio, &data);
|
||||||
|
+ if (len) {
|
||||||
|
+ wpa_printf(MSG_DEBUG, "OpenSSL certificate at depth %d:\n%*s", depth, (int)len, data);
|
||||||
|
+ }
|
||||||
|
+ BIO_free(bio);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
conn = SSL_get_app_data(ssl);
|
||||||
|
if (conn == NULL)
|
||||||
|
return 0;
|
||||||
|
--- a/src/utils/wpa_debug.c
|
||||||
|
+++ b/src/utils/wpa_debug.c
|
||||||
|
@@ -66,6 +66,11 @@
|
||||||
|
#endif /* CONFIG_DEBUG_FILE */
|
||||||
|
|
||||||
|
|
||||||
|
+int wpa_debug_enabled(int level)
|
||||||
|
+{
|
||||||
|
+ return level >= wpa_debug_level;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
void wpa_debug_print_timestamp(void)
|
||||||
|
{
|
||||||
|
#ifndef CONFIG_ANDROID_LOG
|
||||||
|
--- a/src/utils/wpa_debug.h
|
||||||
|
+++ b/src/utils/wpa_debug.h
|
||||||
|
@@ -25,6 +25,7 @@
|
||||||
|
|
||||||
|
#ifdef CONFIG_NO_STDOUT_DEBUG
|
||||||
|
|
||||||
|
+#define wpa_debug_enabled(x) do { } while (0)
|
||||||
|
#define wpa_debug_print_timestamp() do { } while (0)
|
||||||
|
#define wpa_printf(args...) do { } while (0)
|
||||||
|
#define wpa_hexdump(l,t,b,le) do { } while (0)
|
||||||
|
@@ -52,6 +53,13 @@
|
||||||
|
void wpa_debug_stop_log(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
+ * wpa_debug_enabled: check whether given debug level is enabled
|
||||||
|
+ * @level: priority level (MSG_*) of the message
|
||||||
|
+ * @return: 0 or 1
|
||||||
|
+ */
|
||||||
|
+int wpa_debug_enabled(int level);
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
* wpa_debug_printf_timestamp - Print timestamp for debug output
|
||||||
|
*
|
||||||
|
* This function prints a timestamp in seconds_from_1970.microsoconds
|
56
wpa_supplicant-flush-debug-output.patch
Normal file
56
wpa_supplicant-flush-debug-output.patch
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
Index: wpa_supplicant-2.10/src/utils/wpa_debug.c
|
||||||
|
===================================================================
|
||||||
|
--- wpa_supplicant-2.10.orig/src/utils/wpa_debug.c
|
||||||
|
+++ wpa_supplicant-2.10/src/utils/wpa_debug.c
|
||||||
|
@@ -76,9 +76,11 @@ void wpa_debug_print_timestamp(void)
|
||||||
|
|
||||||
|
os_get_time(&tv);
|
||||||
|
#ifdef CONFIG_DEBUG_FILE
|
||||||
|
- if (out_file)
|
||||||
|
+ if (out_file) {
|
||||||
|
fprintf(out_file, "%ld.%06u: ", (long) tv.sec,
|
||||||
|
(unsigned int) tv.usec);
|
||||||
|
+ fflush(out_file);
|
||||||
|
+ }
|
||||||
|
#endif /* CONFIG_DEBUG_FILE */
|
||||||
|
if (!out_file && !wpa_debug_syslog)
|
||||||
|
printf("%ld.%06u: ", (long) tv.sec, (unsigned int) tv.usec);
|
||||||
|
@@ -231,6 +233,7 @@ void wpa_printf(int level, const char *f
|
||||||
|
vfprintf(out_file, fmt, ap);
|
||||||
|
fprintf(out_file, "\n");
|
||||||
|
va_end(ap);
|
||||||
|
+ fflush(out_file);
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_DEBUG_FILE */
|
||||||
|
if (!wpa_debug_syslog && !out_file) {
|
||||||
|
@@ -365,6 +368,7 @@ static void _wpa_hexdump(int level, cons
|
||||||
|
fprintf(out_file, " [REMOVED]");
|
||||||
|
}
|
||||||
|
fprintf(out_file, "\n");
|
||||||
|
+ fflush(out_file);
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_DEBUG_FILE */
|
||||||
|
if (!wpa_debug_syslog && !out_file) {
|
||||||
|
@@ -436,12 +440,14 @@ static void _wpa_hexdump_ascii(int level
|
||||||
|
fprintf(out_file,
|
||||||
|
"%s - hexdump_ascii(len=%lu): [REMOVED]\n",
|
||||||
|
title, (unsigned long) len);
|
||||||
|
+ fflush(out_file);
|
||||||
|
goto file_done;
|
||||||
|
}
|
||||||
|
if (buf == NULL) {
|
||||||
|
fprintf(out_file,
|
||||||
|
"%s - hexdump_ascii(len=%lu): [NULL]\n",
|
||||||
|
title, (unsigned long) len);
|
||||||
|
+ fflush(out_file);
|
||||||
|
goto file_done;
|
||||||
|
}
|
||||||
|
fprintf(out_file, "%s - hexdump_ascii(len=%lu):\n",
|
||||||
|
@@ -466,6 +472,7 @@ static void _wpa_hexdump_ascii(int level
|
||||||
|
pos += llen;
|
||||||
|
len -= llen;
|
||||||
|
}
|
||||||
|
+ fflush(out_file);
|
||||||
|
}
|
||||||
|
file_done:
|
||||||
|
#endif /* CONFIG_DEBUG_FILE */
|
38
wpa_supplicant-sigusr1-changes-debuglevel.patch
Normal file
38
wpa_supplicant-sigusr1-changes-debuglevel.patch
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
---
|
||||||
|
wpa_supplicant/wpa_supplicant.c | 18 ++++++++++++++++++
|
||||||
|
1 file changed, 18 insertions(+)
|
||||||
|
|
||||||
|
--- a/wpa_supplicant/wpa_supplicant.c
|
||||||
|
+++ b/wpa_supplicant/wpa_supplicant.c
|
||||||
|
@@ -123,6 +123,22 @@
|
||||||
|
"\n";
|
||||||
|
#endif /* CONFIG_NO_STDOUT_DEBUG */
|
||||||
|
|
||||||
|
+static void wpa_supplicant_handle_sigusr1(int sig,
|
||||||
|
+ void *signal_ctx)
|
||||||
|
+{
|
||||||
|
+ /* Increase verbosity (by decreasing the debug level) and wrap back
|
||||||
|
+ * to MSG_INFO when needed.
|
||||||
|
+ */
|
||||||
|
+ if (wpa_debug_level)
|
||||||
|
+ wpa_debug_level--;
|
||||||
|
+ else
|
||||||
|
+ wpa_debug_level = MSG_INFO;
|
||||||
|
+
|
||||||
|
+ wpa_printf(MSG_INFO, "Signal %d received - changing debug level to %s", sig,
|
||||||
|
+ (wpa_debug_level == MSG_INFO) ? "INFO" :
|
||||||
|
+ ((wpa_debug_level == MSG_DEBUG) ? "DEBUG" :
|
||||||
|
+ ((wpa_debug_level == MSG_MSGDUMP) ? "MSGDUMP" : "UNKNOWN")));
|
||||||
|
+}
|
||||||
|
|
||||||
|
static void wpa_bss_tmp_disallow_timeout(void *eloop_ctx, void *timeout_ctx);
|
||||||
|
static void wpas_verify_ssid_beacon(void *eloop_ctx, void *timeout_ctx);
|
||||||
|
@@ -8189,6 +8205,8 @@
|
||||||
|
eloop_register_signal_terminate(wpa_supplicant_terminate, global);
|
||||||
|
eloop_register_signal_reconfig(wpa_supplicant_reconfig, global);
|
||||||
|
|
||||||
|
+ eloop_register_signal(SIGUSR1, wpa_supplicant_handle_sigusr1, NULL);
|
||||||
|
+
|
||||||
|
eloop_run();
|
||||||
|
|
||||||
|
return 0;
|
2431
wpa_supplicant.changes
Normal file
2431
wpa_supplicant.changes
Normal file
File diff suppressed because it is too large
Load Diff
3
wpa_supplicant.conf
Normal file
3
wpa_supplicant.conf
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
ctrl_interface=@RUNSTATEDIR@/wpa_supplicant
|
||||||
|
ctrl_interface_group=wheel
|
||||||
|
|
24
wpa_supplicant.service
Normal file
24
wpa_supplicant.service
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
[Unit]
|
||||||
|
Description=WPA Supplicant daemon
|
||||||
|
After=dbus.service
|
||||||
|
Before=network-pre.target
|
||||||
|
Wants=network-pre.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
# added automatically, for details please see
|
||||||
|
# https://en.opensuse.org/openSUSE:Security_Features#Systemd_hardening_effort
|
||||||
|
ProtectSystem=full
|
||||||
|
ProtectHome=read-only
|
||||||
|
ProtectHostname=true
|
||||||
|
ProtectKernelTunables=true
|
||||||
|
ProtectKernelModules=true
|
||||||
|
ProtectKernelLogs=true
|
||||||
|
ProtectControlGroups=true
|
||||||
|
RestrictRealtime=true
|
||||||
|
# end of automatic additions
|
||||||
|
Type=dbus
|
||||||
|
BusName=fi.w1.wpa_supplicant1
|
||||||
|
ExecStart=/usr/sbin/wpa_supplicant -c /etc/wpa_supplicant/wpa_supplicant.conf -u -t -f /var/log/wpa_supplicant.log
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
175
wpa_supplicant.spec
Normal file
175
wpa_supplicant.spec
Normal file
@ -0,0 +1,175 @@
|
|||||||
|
#
|
||||||
|
# spec file for package wpa_supplicant
|
||||||
|
#
|
||||||
|
# Copyright (c) 2024 SUSE LLC
|
||||||
|
#
|
||||||
|
# All modifications and additions to the file contributed by third parties
|
||||||
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
|
# upon. The license for this file, and modifications and additions to the
|
||||||
|
# file, is the same license as for the pristine package itself (unless the
|
||||||
|
# license for the pristine package is not an Open Source License, in which
|
||||||
|
# case the license is the MIT License). An "Open Source License" is a
|
||||||
|
# license that conforms to the Open Source Definition (Version 1.9)
|
||||||
|
# published by the Open Source Initiative.
|
||||||
|
|
||||||
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
Name: wpa_supplicant
|
||||||
|
Version: 2.11
|
||||||
|
Release: 0
|
||||||
|
Summary: WPA supplicant implementation
|
||||||
|
License: BSD-3-Clause AND GPL-2.0-or-later
|
||||||
|
URL: https://w1.fi/wpa_supplicant
|
||||||
|
Source0: https://w1.fi/releases/%{name}-%{version}.tar.gz
|
||||||
|
Source1: config
|
||||||
|
Source2: %{name}.conf
|
||||||
|
Source3: fi.epitest.hostap.WPASupplicant.service
|
||||||
|
Source4: logrotate.wpa_supplicant
|
||||||
|
Source5: fi.w1.wpa_supplicant1.service
|
||||||
|
Source6: wpa_supplicant.service
|
||||||
|
Source7: wpa_supplicant@.service
|
||||||
|
# wpa_supplicant-flush-debug-output.patch won't go upstream as it might
|
||||||
|
# change timings
|
||||||
|
Patch1: wpa_supplicant-flush-debug-output.patch
|
||||||
|
# wpa_supplicant-sigusr1-changes-debuglevel.patch won't go upstream as it
|
||||||
|
# is not portable
|
||||||
|
Patch2: wpa_supplicant-sigusr1-changes-debuglevel.patch
|
||||||
|
Patch3: wpa_supplicant-alloc_size.patch
|
||||||
|
Patch5: wpa_supplicant-dump-certificate-as-PEM-in-debug-mode.diff
|
||||||
|
Patch6: Revert-Mark-authorization-completed-on-driver-indica.patch
|
||||||
|
BuildRequires: pkgconfig
|
||||||
|
BuildRequires: readline-devel
|
||||||
|
BuildRequires: systemd-rpm-macros
|
||||||
|
BuildRequires: pkgconfig(Qt5Core)
|
||||||
|
BuildRequires: pkgconfig(Qt5Gui)
|
||||||
|
BuildRequires: pkgconfig(Qt5Widgets)
|
||||||
|
BuildRequires: pkgconfig(dbus-1)
|
||||||
|
BuildRequires: pkgconfig(libnl-3.0)
|
||||||
|
BuildRequires: pkgconfig(openssl)
|
||||||
|
Requires: logrotate
|
||||||
|
|
||||||
|
%description
|
||||||
|
wpa_supplicant is an implementation of the WPA Supplicant component,
|
||||||
|
i.e., the part that runs in the client stations. It implements key
|
||||||
|
negotiation with a WPA Authenticator and it controls the roaming and
|
||||||
|
IEEE 802.11 authentication/association of the wlan driver.
|
||||||
|
|
||||||
|
%package gui
|
||||||
|
Summary: WPA supplicant graphical front-end
|
||||||
|
Requires: wpa_supplicant
|
||||||
|
|
||||||
|
%description gui
|
||||||
|
This package contains a graphical front-end to wpa_supplicant, an
|
||||||
|
implementation of the WPA Supplicant component.
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%setup -q -n wpa_supplicant-%{version}
|
||||||
|
cp %{SOURCE1} wpa_supplicant/.config
|
||||||
|
%autopatch -p1
|
||||||
|
|
||||||
|
%build
|
||||||
|
cd wpa_supplicant
|
||||||
|
CFLAGS="%{optflags}" make V=1 %{?_smp_mflags}
|
||||||
|
CFLAGS="%{optflags}" make V=1 %{?_smp_mflags} eapol_test
|
||||||
|
cd wpa_gui-qt4
|
||||||
|
%qmake5
|
||||||
|
make %{?_smp_mflags}
|
||||||
|
|
||||||
|
%install
|
||||||
|
install -d %{buildroot}/%{_sbindir}
|
||||||
|
install -m 0755 wpa_supplicant/wpa_cli %{buildroot}%{_sbindir}
|
||||||
|
install -m 0755 wpa_supplicant/wpa_passphrase %{buildroot}%{_sbindir}
|
||||||
|
install -m 0755 wpa_supplicant/wpa_supplicant %{buildroot}%{_sbindir}
|
||||||
|
install -m 0755 wpa_supplicant/eapol_test %{buildroot}%{_sbindir}
|
||||||
|
install -d %{buildroot}%{_datadir}/dbus-1/system.d
|
||||||
|
install -m 0644 wpa_supplicant/dbus/dbus-wpa_supplicant.conf %{buildroot}%{_datadir}/dbus-1/system.d/wpa_supplicant.conf
|
||||||
|
install -d %{buildroot}/%{_sysconfdir}/%{name}
|
||||||
|
install -m 0600 %{SOURCE2} %{buildroot}/%{_sysconfdir}/%{name}
|
||||||
|
sed 's-@RUNSTATEDIR@-%{_rundir}-g' -i %{buildroot}/%{_sysconfdir}/%{name}/%{name}.conf
|
||||||
|
install -d %{buildroot}/%{_datadir}/dbus-1/system-services
|
||||||
|
install -m 0644 %{SOURCE3} %{buildroot}/%{_datadir}/dbus-1/system-services
|
||||||
|
install -m 0644 %{SOURCE5} %{buildroot}/%{_datadir}/dbus-1/system-services
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
install -d %{buildroot}/%{_distconfdir}/logrotate.d/
|
||||||
|
install -m 644 %{SOURCE4} %{buildroot}/%{_distconfdir}/logrotate.d/wpa_supplicant
|
||||||
|
%else
|
||||||
|
install -d %{buildroot}/%{_sysconfdir}/logrotate.d/
|
||||||
|
install -m 644 %{SOURCE4} %{buildroot}/%{_sysconfdir}/logrotate.d/wpa_supplicant
|
||||||
|
%endif
|
||||||
|
install -d %{buildroot}/%{_rundir}/%{name}
|
||||||
|
install -d %{buildroot}%{_mandir}/man{5,8}
|
||||||
|
install -m 0644 wpa_supplicant/doc/docbook/*.8 %{buildroot}%{_mandir}/man8
|
||||||
|
# wpa_supplicant is built without CONFIG_PRIVSEP
|
||||||
|
rm %{buildroot}%{_mandir}/man8/wpa_priv.*
|
||||||
|
install -m 0644 wpa_supplicant/doc/docbook/*.5 %{buildroot}%{_mandir}/man5
|
||||||
|
install -m 755 wpa_supplicant/wpa_gui-qt4/wpa_gui %{buildroot}%{_sbindir}
|
||||||
|
install -d %{buildroot}%{_unitdir}
|
||||||
|
install -m 0644 %{SOURCE6} %{buildroot}%{_unitdir}
|
||||||
|
install -m 0644 %{SOURCE7} %{buildroot}%{_unitdir}
|
||||||
|
ln -s service %{buildroot}/%{_sbindir}/rcwpa_supplicant
|
||||||
|
# avoid spurious dependency on /usr/bin/python
|
||||||
|
chmod -x wpa_supplicant/examples/*.py
|
||||||
|
# dbus auto activation boo#966535
|
||||||
|
ln -s wpa_supplicant.service %{buildroot}%{_unitdir}/dbus-fi.epitest.hostap.WPASupplicant.service
|
||||||
|
ln -s wpa_supplicant.service %{buildroot}%{_unitdir}/dbus-fi.w1.wpa_supplicant1.service
|
||||||
|
|
||||||
|
%pre
|
||||||
|
%service_add_pre wpa_supplicant.service
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
# Prepare for migration to /usr/etc; save any old .rpmsave
|
||||||
|
for i in logrotate.d/wpa_supplicant ; do
|
||||||
|
test -f %{_sysconfdir}/${i}.rpmsave && mv -v %{_sysconfdir}/${i}.rpmsave %{_sysconfdir}/${i}.rpmsave.old ||:
|
||||||
|
done
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
%posttrans
|
||||||
|
# Migration to /usr/etc, restore just created .rpmsave
|
||||||
|
for i in logrotate.d/wpa_supplicant ; do
|
||||||
|
test -f %{_sysconfdir}/${i}.rpmsave && mv -v %{_sysconfdir}/${i}.rpmsave %{_sysconfdir}/${i} ||:
|
||||||
|
done
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%post
|
||||||
|
%service_add_post wpa_supplicant.service
|
||||||
|
|
||||||
|
%preun
|
||||||
|
%service_del_preun wpa_supplicant.service
|
||||||
|
|
||||||
|
%postun
|
||||||
|
%service_del_postun wpa_supplicant.service
|
||||||
|
|
||||||
|
%files
|
||||||
|
%license COPYING
|
||||||
|
%doc wpa_supplicant/ChangeLog README wpa_supplicant/todo.txt wpa_supplicant/examples wpa_supplicant/wpa_supplicant.conf
|
||||||
|
%{_sbindir}/eapol_test
|
||||||
|
%{_sbindir}/rcwpa_supplicant
|
||||||
|
%{_sbindir}/wpa_cli
|
||||||
|
%{_sbindir}/wpa_passphrase
|
||||||
|
%{_sbindir}/wpa_supplicant
|
||||||
|
%{_datadir}/dbus-1/system.d/%{name}.conf
|
||||||
|
%{_datadir}/dbus-1/system-services
|
||||||
|
%config %{_sysconfdir}/%{name}/%{name}.conf
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
%{_distconfdir}/logrotate.d/wpa_supplicant
|
||||||
|
%else
|
||||||
|
%config(noreplace) %{_sysconfdir}/logrotate.d/wpa_supplicant
|
||||||
|
%endif
|
||||||
|
%dir %{_rundir}/%{name}
|
||||||
|
%ghost %{_rundir}/%{name}
|
||||||
|
%{_unitdir}/wpa_supplicant.service
|
||||||
|
%{_unitdir}/wpa_supplicant@.service
|
||||||
|
%{_unitdir}/dbus-fi.epitest.hostap.WPASupplicant.service
|
||||||
|
%{_unitdir}/dbus-fi.w1.wpa_supplicant1.service
|
||||||
|
%dir %{_sysconfdir}/%{name}
|
||||||
|
%{_mandir}/man8/*
|
||||||
|
%exclude %{_mandir}/man8/wpa_gui.*
|
||||||
|
%{_mandir}/man5/*
|
||||||
|
|
||||||
|
%files gui
|
||||||
|
%{_sbindir}/wpa_gui
|
||||||
|
%{_mandir}/man8/wpa_gui*
|
||||||
|
|
||||||
|
%changelog
|
13
wpa_supplicant@.service
Normal file
13
wpa_supplicant@.service
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
[Unit]
|
||||||
|
Description=WPA Supplicant daemon (interface %i)
|
||||||
|
After=dbus.service network.target
|
||||||
|
Requires=sys-subsystem-net-devices-%I.device
|
||||||
|
After=sys-subsystem-net-devices-%I.device
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=dbus
|
||||||
|
BusName=fi.w1.wpa_supplicant1
|
||||||
|
ExecStart=/usr/sbin/wpa_supplicant -i%i -c /etc/wpa_supplicant/wpa_supplicant.conf -u -t -f /var/log/wpa_supplicant.log
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
Loading…
Reference in New Issue
Block a user