1
0
mirror of https://git.openwrt.org/openwrt/openwrt.git synced 2024-11-20 07:24:36 +01:00
openwrt/package/wpa_supplicant/patches/120-ssid_scan.patch
Gabor Juhos 1354730b35 wpa_supplicant: update to 0.6.7
SVN-Revision: 14240
2009-01-28 13:48:22 +00:00

42 lines
1.0 KiB
Diff

Don't do broadcast SSID scans, if all configured SSIDs use scan_ssid=1. Improves background scanning in supplicant-managed roaming.
--- a/wpa_supplicant/scan.c
+++ b/wpa_supplicant/scan.c
@@ -73,6 +73,7 @@ static void wpa_supplicant_scan(void *el
struct wpabuf *wps_ie = NULL;
const u8 *extra_ie = NULL;
size_t extra_ie_len = 0;
+ int scan_ssid_all = 1;
int wps = 0;
#ifdef CONFIG_WPS
enum wps_request_type req_type = WPS_REQ_ENROLLEE_INFO;
@@ -82,6 +83,17 @@ static void wpa_supplicant_scan(void *el
return;
enabled = 0;
+
+ /* check if all configured ssids should be scanned directly */
+ ssid = wpa_s->conf->ssid;
+ while (ssid) {
+ if (!ssid->scan_ssid) {
+ scan_ssid_all = 0;
+ break;
+ }
+ ssid = ssid->next;
+ }
+
ssid = wpa_s->conf->ssid;
while (ssid) {
if (!ssid->disabled) {
@@ -154,6 +166,10 @@ static void wpa_supplicant_scan(void *el
return;
}
+ if (scan_ssid_all && !ssid) {
+ ssid = wpa_s->conf->ssid;
+ }
+
wpa_printf(MSG_DEBUG, "Starting AP scan (%s SSID)",
ssid ? "specific": "broadcast");
if (ssid) {