[PATCH 193/379][SRU][OEM-5.6] cfg80211/mac80211: avoid bss color setting in non-HE modes
You-Sheng Yang
vicamo.yang at canonical.com
Wed Dec 23 08:48:46 UTC 2020
From: P Praneesh <ppranees at codeaurora.org>
BugLink: https://bugs.launchpad.net/bugs/1879633
Adding bss-color configuration is only valid in HE mode.
Earlier we have enabled it by default, irrespective of
capabilities/mode. Fix that.
Reported-by: kernel test robot <lkp at intel.com>
Reported-by: Rajkumar Manoharan <rmanohar at codeaurora.org>
Signed-off-by: P Praneesh <ppranees at codeaurora.org>
Link: https://lore.kernel.org/r/1594262781-21444-1-git-send-email-ppranees@codeaurora.org
[fix up commit message]
Signed-off-by: Johannes Berg <johannes.berg at intel.com>
(backported from commit 322cd27c06450b2db2cb6bdc68f3814149baf767)
Signed-off-by: You-Sheng Yang <vicamo.yang at canonical.com>
---
net/mac80211/cfg.c | 8 +++++---
net/mac80211/mlme.c | 4 +++-
net/wireless/nl80211.c | 3 +++
3 files changed, 11 insertions(+), 4 deletions(-)
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c
index 32df7d6dcdd1..4fb5eab2fe16 100644
--- a/net/mac80211/cfg.c
+++ b/net/mac80211/cfg.c
@@ -979,9 +979,7 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev,
BSS_CHANGED_SSID |
BSS_CHANGED_P2P_PS |
BSS_CHANGED_TXPOWER |
- BSS_CHANGED_TWT |
- BSS_CHANGED_HE_OBSS_PD |
- BSS_CHANGED_HE_BSS_COLOR;
+ BSS_CHANGED_TWT;
int err;
int prev_beacon_int;
@@ -1017,6 +1015,10 @@ static int ieee80211_start_ap(struct wiphy *wiphy, struct net_device *dev,
sdata->vif.bss_conf.frame_time_rts_th =
le32_get_bits(params->he_oper->he_oper_params,
IEEE80211_HE_OPERATION_RTS_THRESHOLD_MASK);
+ changed |= BSS_CHANGED_HE_OBSS_PD;
+
+ if (!params->he_bss_color.disabled)
+ changed |= BSS_CHANGED_HE_BSS_COLOR;
}
mutex_lock(&local->mtx);
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
index 8df577c20586..21aade419771 100644
--- a/net/mac80211/mlme.c
+++ b/net/mac80211/mlme.c
@@ -3417,7 +3417,9 @@ static bool ieee80211_assoc_success(struct ieee80211_sub_if_data *sdata,
bss_conf->he_bss_color.disabled =
le32_get_bits(elems->he_operation->he_oper_params,
IEEE80211_HE_OPERATION_BSS_COLOR_DISABLED);
- changed |= BSS_CHANGED_HE_BSS_COLOR;
+
+ if (!bss_conf->he_bss_color.disabled)
+ changed |= BSS_CHANGED_HE_BSS_COLOR;
bss_conf->htc_trig_based_pkt_ext =
le32_get_bits(elems->he_operation->he_oper_params,
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c
index ecb8fcafeb0a..9e2848ceb2bd 100644
--- a/net/wireless/nl80211.c
+++ b/net/wireless/nl80211.c
@@ -4701,6 +4701,9 @@ static int nl80211_start_ap(struct sk_buff *skb, struct genl_info *info)
memset(¶ms, 0, sizeof(params));
+ /* disable BSS color by default */
+ params.he_bss_color.disabled = true;
+
/* these are required for START_AP */
if (!info->attrs[NL80211_ATTR_BEACON_INTERVAL] ||
!info->attrs[NL80211_ATTR_DTIM_PERIOD] ||
--
2.29.2
More information about the kernel-team
mailing list