Commit 90bd5bee authored by Sriram R's avatar Sriram R Committed by Johannes Berg

cfg80211: use wiphy DFS domain if it is self-managed

Currently during CAC start or other radar events, the DFS
domain is fetched from cfg based on global DFS domain,
even if the wiphy regdomain disagrees.

But this could be different in case of self managed wiphy's
in case the self managed driver updates its database or supports
regions which has DFS domain set to UNSET in cfg80211 local
regdomain.

So for explicitly self-managed wiphys, just use their DFS
domain.
Signed-off-by: default avatarSriram R <srirrama@codeaurora.org>
Link: https://lore.kernel.org/r/1629934730-16388-1-git-send-email-srirrama@codeaurora.orgSigned-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent b0345850
...@@ -171,9 +171,11 @@ enum nl80211_dfs_regions reg_get_dfs_region(struct wiphy *wiphy) ...@@ -171,9 +171,11 @@ enum nl80211_dfs_regions reg_get_dfs_region(struct wiphy *wiphy)
{ {
const struct ieee80211_regdomain *regd = NULL; const struct ieee80211_regdomain *regd = NULL;
const struct ieee80211_regdomain *wiphy_regd = NULL; const struct ieee80211_regdomain *wiphy_regd = NULL;
enum nl80211_dfs_regions dfs_region;
rcu_read_lock(); rcu_read_lock();
regd = get_cfg80211_regdom(); regd = get_cfg80211_regdom();
dfs_region = regd->dfs_region;
if (!wiphy) if (!wiphy)
goto out; goto out;
...@@ -182,6 +184,11 @@ enum nl80211_dfs_regions reg_get_dfs_region(struct wiphy *wiphy) ...@@ -182,6 +184,11 @@ enum nl80211_dfs_regions reg_get_dfs_region(struct wiphy *wiphy)
if (!wiphy_regd) if (!wiphy_regd)
goto out; goto out;
if (wiphy->regulatory_flags & REGULATORY_WIPHY_SELF_MANAGED) {
dfs_region = wiphy_regd->dfs_region;
goto out;
}
if (wiphy_regd->dfs_region == regd->dfs_region) if (wiphy_regd->dfs_region == regd->dfs_region)
goto out; goto out;
...@@ -193,7 +200,7 @@ enum nl80211_dfs_regions reg_get_dfs_region(struct wiphy *wiphy) ...@@ -193,7 +200,7 @@ enum nl80211_dfs_regions reg_get_dfs_region(struct wiphy *wiphy)
out: out:
rcu_read_unlock(); rcu_read_unlock();
return regd->dfs_region; return dfs_region;
} }
static void rcu_free_regdom(const struct ieee80211_regdomain *r) static void rcu_free_regdom(const struct ieee80211_regdomain *r)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment