diff options
author | Avraham Stern <avraham.stern@intel.com> | 2022-02-02 10:49:37 +0200 |
---|---|---|
committer | Johannes Berg <johannes.berg@intel.com> | 2022-02-04 16:24:41 +0100 |
commit | 5666ee154f4696c011dfa8544aaf5591b6b87515 (patch) | |
tree | af7743dd54fd946c6a3b6cff11f515a49b14ad7a /net/wireless/scan.c | |
parent | 667aa7426454154ec1e0922f92625bb33ae9951f (diff) | |
download | linux-5666ee154f4696c011dfa8544aaf5591b6b87515.tar.gz linux-5666ee154f4696c011dfa8544aaf5591b6b87515.tar.bz2 linux-5666ee154f4696c011dfa8544aaf5591b6b87515.zip |
cfg80211: don't add non transmitted BSS to 6GHz scanned channels
When adding 6GHz channels to scan request based on reported
co-located APs, don't add channels that have only APs with
"non-transmitted" BSSes if they only match the wildcard SSID since
they will be found by probing the "transmitted" BSS.
Signed-off-by: Avraham Stern <avraham.stern@intel.com>
Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
Link: https://lore.kernel.org/r/iwlwifi.20220202104617.f6ddf099f934.I231e55885d3644f292d00dfe0f42653269f2559e@changeid
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/wireless/scan.c')
-rw-r--r-- | net/wireless/scan.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/net/wireless/scan.c b/net/wireless/scan.c index b888522f133b..b2fdac96bab0 100644 --- a/net/wireless/scan.c +++ b/net/wireless/scan.c @@ -700,8 +700,12 @@ static bool cfg80211_find_ssid_match(struct cfg80211_colocated_ap *ap, for (i = 0; i < request->n_ssids; i++) { /* wildcard ssid in the scan request */ - if (!request->ssids[i].ssid_len) + if (!request->ssids[i].ssid_len) { + if (ap->multi_bss && !ap->transmitted_bssid) + continue; + return true; + } if (ap->ssid_len && ap->ssid_len == request->ssids[i].ssid_len) { @@ -827,6 +831,9 @@ static int cfg80211_scan_6ghz(struct cfg80211_registered_device *rdev) !cfg80211_find_ssid_match(ap, request)) continue; + if (!request->n_ssids && ap->multi_bss && !ap->transmitted_bssid) + continue; + cfg80211_scan_req_add_chan(request, chan, true); memcpy(scan_6ghz_params->bssid, ap->bssid, ETH_ALEN); scan_6ghz_params->short_ssid = ap->short_ssid; |