aboutsummaryrefslogtreecommitdiffstats
path: root/package/hostapd/patches/300-scan_ssid.patch
blob: 47528f8b6b56bf79c60450dde0ba96b6541d075a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
--- a/wpa_supplicant/scan.c
+++ b/wpa_supplicant/scan.c
@@ -251,6 +251,7 @@ static void wpa_supplicant_scan(void *el
 	enum wps_request_type req_type = WPS_REQ_ENROLLEE_INFO;
 #endif /* CONFIG_WPS */
 	struct wpa_driver_scan_params params;
+	int scan_ssid_all = 1;
 	size_t max_ssids;
 	enum wpa_states prev_state;
 
@@ -307,6 +308,16 @@ static void wpa_supplicant_scan(void *el
 	    wpa_s->wpa_state == WPA_INACTIVE)
 		wpa_supplicant_set_state(wpa_s, WPA_SCANNING);
 
+	/* 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;
+	}
+
 	/* Find the starting point from which to continue scanning */
 	ssid = wpa_s->conf->ssid;
 	if (wpa_s->prev_scan_ssid != WILDCARD_SSID_SCAN) {
@@ -370,6 +381,9 @@ static void wpa_supplicant_scan(void *el
 		int_array_sort_unique(params.freqs);
 	}
 
+	if (scan_ssid_all && !ssid)
+		ssid = wpa_s->conf->ssid;
+
 	if (ssid) {
 		wpa_s->prev_scan_ssid = ssid;
 		if (max_ssids > 1) {