diff --git a/src/drivers/driver.h b/src/drivers/driver.h index ccc5a0e03..7ee71aaac 100644 --- a/src/drivers/driver.h +++ b/src/drivers/driver.h @@ -840,6 +840,8 @@ struct wpa_driver_capa { #define WPA_DRIVER_FLAGS_AP_MLME 0x01000000 /* Driver supports SAE with user space SME */ #define WPA_DRIVER_FLAGS_SAE 0x02000000 +/* Driver makes use of OBSS scan mechanism in wpa_supplicant */ +#define WPA_DRIVER_FLAGS_OBSS_SCAN 0x04000000 unsigned int flags; int max_scan_ssids; diff --git a/src/drivers/driver_nl80211.c b/src/drivers/driver_nl80211.c index 8ee8482a7..297f67767 100644 --- a/src/drivers/driver_nl80211.c +++ b/src/drivers/driver_nl80211.c @@ -2661,6 +2661,9 @@ broken_combination: if (flags & NL80211_FEATURE_SAE) capa->flags |= WPA_DRIVER_FLAGS_SAE; + + if (flags & NL80211_FEATURE_NEED_OBSS_SCAN) + capa->flags |= WPA_DRIVER_FLAGS_OBSS_SCAN; } if (tb[NL80211_ATTR_PROBE_RESP_OFFLOAD]) { diff --git a/wpa_supplicant/sme.c b/wpa_supplicant/sme.c index f6e106c88..a5f60d322 100644 --- a/wpa_supplicant/sme.c +++ b/wpa_supplicant/sme.c @@ -1033,9 +1033,14 @@ void sme_sched_obss_scan(struct wpa_supplicant *wpa_s, int enable) if (!enable) return; - if (!(wpa_s->drv_flags & WPA_DRIVER_FLAGS_SME) || ssid == NULL || - ssid->mode != IEEE80211_MODE_INFRA) - return; /* Not using station SME in wpa_supplicant */ + /* + * Schedule OBSS scan if driver is using station SME in wpa_supplicant + * or it expects OBSS scan to be performed by wpa_supplicant. + */ + if (!((wpa_s->drv_flags & WPA_DRIVER_FLAGS_SME) || + (wpa_s->drv_flags & WPA_DRIVER_FLAGS_OBSS_SCAN)) || + ssid == NULL || ssid->mode != IEEE80211_MODE_INFRA) + return; if (!wpa_s->hw.modes) return;