nl80211: Abort an ongoing scan upon scan timeout indication
Currently, when scan is stuck in the kernel/driver/fw, the nl80211 driver tries to recover by faking a SCAN_RESULTS flow. However, the scan is still stuck in the kernel/driver/fw. To avoid that stuck request, abort it upon scan timeout. Signed-off-by: Ayala Beker <ayala.beker@intel.com>
This commit is contained in:
parent
d4b521a38b
commit
7441698fcf
1 changed files with 9 additions and 1 deletions
|
@ -96,12 +96,20 @@ static int nl80211_get_noise_for_scan_results(
|
||||||
void wpa_driver_nl80211_scan_timeout(void *eloop_ctx, void *timeout_ctx)
|
void wpa_driver_nl80211_scan_timeout(void *eloop_ctx, void *timeout_ctx)
|
||||||
{
|
{
|
||||||
struct wpa_driver_nl80211_data *drv = eloop_ctx;
|
struct wpa_driver_nl80211_data *drv = eloop_ctx;
|
||||||
|
|
||||||
|
wpa_printf(MSG_DEBUG, "nl80211: Scan timeout - try to abort it");
|
||||||
|
if (!wpa_driver_nl80211_abort_scan(drv->first_bss))
|
||||||
|
return;
|
||||||
|
|
||||||
|
wpa_printf(MSG_DEBUG, "nl80211: Failed to abort scan");
|
||||||
|
|
||||||
if (drv->ap_scan_as_station != NL80211_IFTYPE_UNSPECIFIED) {
|
if (drv->ap_scan_as_station != NL80211_IFTYPE_UNSPECIFIED) {
|
||||||
wpa_driver_nl80211_set_mode(drv->first_bss,
|
wpa_driver_nl80211_set_mode(drv->first_bss,
|
||||||
drv->ap_scan_as_station);
|
drv->ap_scan_as_station);
|
||||||
drv->ap_scan_as_station = NL80211_IFTYPE_UNSPECIFIED;
|
drv->ap_scan_as_station = NL80211_IFTYPE_UNSPECIFIED;
|
||||||
}
|
}
|
||||||
wpa_printf(MSG_DEBUG, "Scan timeout - try to get results");
|
|
||||||
|
wpa_printf(MSG_DEBUG, "nl80211: Try to get scan results");
|
||||||
wpa_supplicant_event(timeout_ctx, EVENT_SCAN_RESULTS, NULL);
|
wpa_supplicant_event(timeout_ctx, EVENT_SCAN_RESULTS, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue