Commit 25af8ff5 authored by Johannes Berg's avatar Johannes Berg

wifi: mac80211: optionally pass chandef to ieee80211_sta_cap_rx_bw()

We'll need this function to take a new chandef in
(some) channel switching cases, so prepare for that
by allowing that to be passed and using it if so.
Clean up the code a little bit while at it.
Reviewed-by: default avatarMiriam Rachel Korenblit <miriam.rachel.korenblit@intel.com>
Link: https://patch.msgid.link/20240612143418.772313f08b6a.If9708249e5870671e745d4c2b02e03b25092bea3@changeidSigned-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
parent b777bdfc
...@@ -2158,7 +2158,13 @@ ieee80211_vht_cap_ie_to_sta_vht_cap(struct ieee80211_sub_if_data *sdata, ...@@ -2158,7 +2158,13 @@ ieee80211_vht_cap_ie_to_sta_vht_cap(struct ieee80211_sub_if_data *sdata,
const struct ieee80211_vht_cap *vht_cap_ie2, const struct ieee80211_vht_cap *vht_cap_ie2,
struct link_sta_info *link_sta); struct link_sta_info *link_sta);
enum ieee80211_sta_rx_bandwidth enum ieee80211_sta_rx_bandwidth
ieee80211_sta_cap_rx_bw(struct link_sta_info *link_sta); _ieee80211_sta_cap_rx_bw(struct link_sta_info *link_sta,
struct cfg80211_chan_def *chandef);
static inline enum ieee80211_sta_rx_bandwidth
ieee80211_sta_cap_rx_bw(struct link_sta_info *link_sta)
{
return _ieee80211_sta_cap_rx_bw(link_sta, NULL);
}
enum ieee80211_sta_rx_bandwidth enum ieee80211_sta_rx_bandwidth
ieee80211_sta_cur_vht_bw(struct link_sta_info *link_sta); ieee80211_sta_cur_vht_bw(struct link_sta_info *link_sta);
void ieee80211_sta_init_nss(struct link_sta_info *link_sta); void ieee80211_sta_init_nss(struct link_sta_info *link_sta);
......
...@@ -351,7 +351,8 @@ ieee80211_vht_cap_ie_to_sta_vht_cap(struct ieee80211_sub_if_data *sdata, ...@@ -351,7 +351,8 @@ ieee80211_vht_cap_ie_to_sta_vht_cap(struct ieee80211_sub_if_data *sdata,
/* FIXME: move this to some better location - parses HE/EHT now */ /* FIXME: move this to some better location - parses HE/EHT now */
enum ieee80211_sta_rx_bandwidth enum ieee80211_sta_rx_bandwidth
ieee80211_sta_cap_rx_bw(struct link_sta_info *link_sta) _ieee80211_sta_cap_rx_bw(struct link_sta_info *link_sta,
struct cfg80211_chan_def *chandef)
{ {
unsigned int link_id = link_sta->link_id; unsigned int link_id = link_sta->link_id;
struct ieee80211_sub_if_data *sdata = link_sta->sta->sdata; struct ieee80211_sub_if_data *sdata = link_sta->sta->sdata;
...@@ -361,44 +362,43 @@ ieee80211_sta_cap_rx_bw(struct link_sta_info *link_sta) ...@@ -361,44 +362,43 @@ ieee80211_sta_cap_rx_bw(struct link_sta_info *link_sta)
u32 cap_width; u32 cap_width;
if (he_cap->has_he) { if (he_cap->has_he) {
struct ieee80211_bss_conf *link_conf; enum nl80211_band band;
enum ieee80211_sta_rx_bandwidth ret;
u8 info; u8 info;
rcu_read_lock(); if (chandef) {
link_conf = rcu_dereference(sdata->vif.link_conf[link_id]); band = chandef->chan->band;
} else {
struct ieee80211_bss_conf *link_conf;
rcu_read_lock();
link_conf = rcu_dereference(sdata->vif.link_conf[link_id]);
band = link_conf->chanreq.oper.chan->band;
rcu_read_unlock();
}
if (eht_cap->has_eht && if (eht_cap->has_eht && band == NL80211_BAND_6GHZ) {
link_conf->chanreq.oper.chan->band == NL80211_BAND_6GHZ) {
info = eht_cap->eht_cap_elem.phy_cap_info[0]; info = eht_cap->eht_cap_elem.phy_cap_info[0];
if (info & IEEE80211_EHT_PHY_CAP0_320MHZ_IN_6GHZ) { if (info & IEEE80211_EHT_PHY_CAP0_320MHZ_IN_6GHZ)
ret = IEEE80211_STA_RX_BW_320; return IEEE80211_STA_RX_BW_320;
goto out;
}
} }
info = he_cap->he_cap_elem.phy_cap_info[0]; info = he_cap->he_cap_elem.phy_cap_info[0];
if (link_conf->chanreq.oper.chan->band == NL80211_BAND_2GHZ) { if (band == NL80211_BAND_2GHZ) {
if (info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_40MHZ_IN_2G) if (info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_40MHZ_IN_2G)
ret = IEEE80211_STA_RX_BW_40; return IEEE80211_STA_RX_BW_40;
else return IEEE80211_STA_RX_BW_20;
ret = IEEE80211_STA_RX_BW_20;
goto out;
} }
if (info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_160MHZ_IN_5G || if (info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_160MHZ_IN_5G ||
info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_80PLUS80_MHZ_IN_5G) info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_80PLUS80_MHZ_IN_5G)
ret = IEEE80211_STA_RX_BW_160; return IEEE80211_STA_RX_BW_160;
else if (info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_40MHZ_80MHZ_IN_5G)
ret = IEEE80211_STA_RX_BW_80; if (info & IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_40MHZ_80MHZ_IN_5G)
else return IEEE80211_STA_RX_BW_80;
ret = IEEE80211_STA_RX_BW_20;
out:
rcu_read_unlock();
return ret; return IEEE80211_STA_RX_BW_20;
} }
if (!vht_cap->vht_supported) if (!vht_cap->vht_supported)
......
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