sched scan: Fix passive scanning

Scan wasn't initiated in case the config contained only networks without
scan_ssid. In such a case we want scan to be initiated without any SSIDs
to actively scan but include all the SSIDs in the filter list. Also
added some debug logs to easily see which SSIDs were included in which
list.

Cc: Luciano Coelho <coelho@ti.com>
Signed-off-by: Eyal Shapira <eyal@wizery.com>
This commit is contained in:
Eyal Shapira 2011-11-18 23:05:57 +02:00 committed by Jouni Malinen
parent e159cc5e9b
commit 1966e3d1b7

View file

@ -710,8 +710,10 @@ int wpa_supplicant_req_sched_scan(struct wpa_supplicant *wpa_s)
else else
max_sched_scan_ssids = wpa_s->max_sched_scan_ssids; max_sched_scan_ssids = wpa_s->max_sched_scan_ssids;
if (wpa_s->sched_scanning) if (wpa_s->sched_scanning) {
wpa_dbg(wpa_s, MSG_DEBUG, "Already sched scanning");
return 0; return 0;
}
os_memset(&params, 0, sizeof(params)); os_memset(&params, 0, sizeof(params));
@ -754,6 +756,8 @@ int wpa_supplicant_req_sched_scan(struct wpa_supplicant *wpa_s)
} }
if (params.filter_ssids && ssid->ssid && ssid->ssid_len) { if (params.filter_ssids && ssid->ssid && ssid->ssid_len) {
wpa_dbg(wpa_s, MSG_DEBUG, "add to filter ssid: %s",
wpa_ssid_txt(ssid->ssid, ssid->ssid_len));
os_memcpy(params.filter_ssids[params.num_filter_ssids].ssid, os_memcpy(params.filter_ssids[params.num_filter_ssids].ssid,
ssid->ssid, ssid->ssid_len); ssid->ssid, ssid->ssid_len);
params.filter_ssids[params.num_filter_ssids].ssid_len = params.filter_ssids[params.num_filter_ssids].ssid_len =
@ -762,6 +766,8 @@ int wpa_supplicant_req_sched_scan(struct wpa_supplicant *wpa_s)
} }
if (ssid->scan_ssid) { if (ssid->scan_ssid) {
wpa_dbg(wpa_s, MSG_DEBUG, "add to active scan ssid: %s",
wpa_ssid_txt(ssid->ssid, ssid->ssid_len));
params.ssids[params.num_ssids].ssid = params.ssids[params.num_ssids].ssid =
ssid->ssid; ssid->ssid;
params.ssids[params.num_ssids].ssid_len = params.ssids[params.num_ssids].ssid_len =
@ -779,11 +785,6 @@ int wpa_supplicant_req_sched_scan(struct wpa_supplicant *wpa_s)
ssid = ssid->next; ssid = ssid->next;
} }
if (!params.num_ssids) {
os_free(params.filter_ssids);
return 0;
}
if (wpa_s->wps) if (wpa_s->wps)
wps_ie = wpa_supplicant_extra_ies(wpa_s, &params); wps_ie = wpa_supplicant_extra_ies(wpa_s, &params);