wl12xx: disable 11a channels when regulatory changes if 11a is not supported
Instead of simply not scanning for the 11a channels when not supported by the hardware, disable the channels in reg_notify. This centralizes the decision on whether to scan 5GHz channel in one place and allows userspace to know exactly which channels are in use. Based on Juuso Oikarinen's idea. Cc: Juuso Oikarinen <juuso.oikarinen@nokia.com> Signed-off-by: Luciano Coelho <luciano.coelho@nokia.com> Reviewed-by: Juuso Oikarinen <juuso.oikarinen@nokia.com>
This commit is contained in:
parent
6735329934
commit
573c67cf81
1 changed files with 8 additions and 1 deletions
|
@ -336,7 +336,9 @@ static int wl1271_dev_notify(struct notifier_block *me, unsigned long what,
|
|||
}
|
||||
|
||||
static int wl1271_reg_notify(struct wiphy *wiphy,
|
||||
struct regulatory_request *request) {
|
||||
struct regulatory_request *request)
|
||||
{
|
||||
struct wl1271 *wl = wiphy_to_ieee80211_hw(wiphy)->priv;
|
||||
struct ieee80211_supported_band *band;
|
||||
struct ieee80211_channel *ch;
|
||||
int i;
|
||||
|
@ -347,6 +349,11 @@ static int wl1271_reg_notify(struct wiphy *wiphy,
|
|||
if (ch->flags & IEEE80211_CHAN_DISABLED)
|
||||
continue;
|
||||
|
||||
if (!wl->enable_11a) {
|
||||
ch->flags |= IEEE80211_CHAN_DISABLED;
|
||||
continue;
|
||||
}
|
||||
|
||||
if (ch->flags & IEEE80211_CHAN_RADAR)
|
||||
ch->flags |= IEEE80211_CHAN_NO_IBSS |
|
||||
IEEE80211_CHAN_PASSIVE_SCAN;
|
||||
|
|
Loading…
Reference in a new issue